2006-03-29 18:29:03 +00:00
|
|
|
/*
|
|
|
|
* interface for rendering objects whose state is saved in
|
|
|
|
* session-history (back-forward navigation)
|
|
|
|
*/
|
|
|
|
|
1999-08-30 22:38:58 +00:00
|
|
|
#ifndef _nsIStatefulFrame_h
|
|
|
|
#define _nsIStatefulFrame_h
|
|
|
|
|
|
|
|
#include "nsISupports.h"
|
|
|
|
|
2004-07-31 23:15:21 +00:00
|
|
|
class nsPresContext;
|
2005-01-27 22:52:53 +00:00
|
|
|
class nsPresState;
|
1999-08-30 22:38:58 +00:00
|
|
|
|
|
|
|
#define NS_ISTATEFULFRAME_IID \
|
2005-12-06 23:56:17 +00:00
|
|
|
{ 0x25c232cf, 0x40ba, 0x4394, \
|
|
|
|
{ 0x84, 0xe4, 0x73, 0xa2, 0xf7, 0x4d, 0x8b, 0x64 } }
|
1999-08-30 22:38:58 +00:00
|
|
|
|
|
|
|
class nsIStatefulFrame : public nsISupports {
|
|
|
|
public:
|
2005-11-11 14:36:26 +00:00
|
|
|
NS_DECLARE_STATIC_IID_ACCESSOR(NS_ISTATEFULFRAME_IID)
|
1999-08-30 22:38:58 +00:00
|
|
|
|
2000-06-14 23:37:06 +00:00
|
|
|
// If you create a special type stateful frame (e.g. scroll) that needs
|
|
|
|
// to be captured outside of the standard pass through the frames, you'll need
|
|
|
|
// a special ID by which to refer to that type.
|
|
|
|
enum SpecialStateID {eNoID=0, eDocumentScrollState};
|
|
|
|
|
2005-12-06 23:56:17 +00:00
|
|
|
// Save the state for this frame. Some implementations may choose to return
|
|
|
|
// different states depending on the value of aStateID. If this method
|
|
|
|
// succeeds, the caller is responsible for deleting the resulting state when
|
|
|
|
// done with it.
|
|
|
|
NS_IMETHOD SaveState(SpecialStateID aStateID, nsPresState** aState) = 0;
|
|
|
|
|
|
|
|
// Restore the state for this frame from aState
|
|
|
|
NS_IMETHOD RestoreState(nsPresState* aState) = 0;
|
1999-08-30 22:38:58 +00:00
|
|
|
};
|
|
|
|
|
2005-11-11 14:36:26 +00:00
|
|
|
NS_DEFINE_STATIC_IID_ACCESSOR(nsIStatefulFrame, NS_ISTATEFULFRAME_IID)
|
|
|
|
|
1999-08-31 04:20:22 +00:00
|
|
|
#endif /* _nsIStatefulFrame_h */
|