1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     Doc/View classes 
   4 // Author:      Julian Smart 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  15 #if defined(__GNUG__) && !defined(__APPLE__) 
  16     #pragma interface "docview.h" 
  21 #include "wx/cmndata.h" 
  22 #include "wx/string.h" 
  25 #if wxUSE_PRINTING_ARCHITECTURE 
  29 class WXDLLEXPORT wxWindow
; 
  30 class WXDLLEXPORT wxDocument
; 
  31 class WXDLLEXPORT wxView
; 
  32 class WXDLLEXPORT wxDocTemplate
; 
  33 class WXDLLEXPORT wxDocManager
; 
  34 class WXDLLEXPORT wxPrintInfo
; 
  35 class WXDLLEXPORT wxCommandProcessor
; 
  36 class WXDLLEXPORT wxFileHistory
; 
  37 class WXDLLEXPORT wxConfigBase
; 
  39 #if wxUSE_STD_IOSTREAM 
  40   #include "wx/ioswrap.h" 
  42   #include "wx/stream.h" 
  45 // Document manager flags 
  52     wxDEFAULT_DOCMAN_FLAGS 
= wxDOC_SDI
 
  55 // Document template flags 
  58     wxTEMPLATE_VISIBLE 
= 1, 
  60     wxDEFAULT_TEMPLATE_FLAGS 
= wxTEMPLATE_VISIBLE
 
  63 #define wxMAX_FILE_HISTORY 9 
  65 class WXDLLEXPORT wxDocument 
: public wxEvtHandler
 
  68     wxDocument(wxDocument 
*parent 
= (wxDocument 
*) NULL
); 
  72     void SetFilename(const wxString
& filename
, bool notifyViews 
= FALSE
); 
  73     wxString 
GetFilename() const { return m_documentFile
; } 
  75     void SetTitle(const wxString
& title
) { m_documentTitle 
= title
; }; 
  76     wxString 
GetTitle() const { return m_documentTitle
; } 
  78     void SetDocumentName(const wxString
& name
) { m_documentTypeName 
= name
; }; 
  79     wxString 
GetDocumentName() const { return m_documentTypeName
; } 
  81     bool GetDocumentSaved() const { return m_savedYet
; } 
  82     void SetDocumentSaved(bool saved 
= TRUE
) { m_savedYet 
= saved
; } 
  86     virtual bool SaveAs(); 
  87     virtual bool Revert(); 
  89 #if wxUSE_STD_IOSTREAM 
  90     virtual wxSTD ostream
& SaveObject(wxSTD ostream
& stream
); 
  91     virtual wxSTD istream
& LoadObject(wxSTD istream
& stream
); 
  93     virtual wxOutputStream
& SaveObject(wxOutputStream
& stream
); 
  94     virtual wxInputStream
& LoadObject(wxInputStream
& stream
); 
  97     // Called by wxWindows 
  98     virtual bool OnSaveDocument(const wxString
& filename
); 
  99     virtual bool OnOpenDocument(const wxString
& filename
); 
 100     virtual bool OnNewDocument(); 
 101     virtual bool OnCloseDocument(); 
 103     // Prompts for saving if about to close a modified document. Returns TRUE 
 104     // if ok to close the document (may have saved in the meantime, or set 
 105     // modified to FALSE) 
 106     virtual bool OnSaveModified(); 
 108     // Called by framework if created automatically by the default document 
 109     // manager: gives document a chance to initialise and (usually) create a 
 111     virtual bool OnCreate(const wxString
& path
, long flags
); 
 113     // By default, creates a base wxCommandProcessor. 
 114     virtual wxCommandProcessor 
*OnCreateCommandProcessor(); 
 115     virtual wxCommandProcessor 
*GetCommandProcessor() const { return m_commandProcessor
; } 
 116     virtual void SetCommandProcessor(wxCommandProcessor 
*proc
) { m_commandProcessor 
= proc
; } 
 118     // Called after a view is added or removed. The default implementation 
 119     // deletes the document if this is there are no more views. 
 120     virtual void OnChangedViewList(); 
 122     virtual bool DeleteContents(); 
 124     virtual bool Draw(wxDC
&); 
 125     virtual bool IsModified() const { return m_documentModified
; } 
 126     virtual void Modify(bool mod
) { m_documentModified 
= mod
; } 
 128     virtual bool AddView(wxView 
*view
); 
 129     virtual bool RemoveView(wxView 
*view
); 
 130     wxList
& GetViews() const { return (wxList
&) m_documentViews
; } 
 131     wxView 
*GetFirstView() const; 
 133     virtual void UpdateAllViews(wxView 
*sender 
= (wxView 
*) NULL
, wxObject 
*hint 
= (wxObject 
*) NULL
); 
 134     virtual void NotifyClosing(); 
 136     // Remove all views (because we're closing the document) 
 137     virtual bool DeleteAllViews(); 
 140     virtual wxDocManager 
*GetDocumentManager() const; 
 141     virtual wxDocTemplate 
*GetDocumentTemplate() const { return m_documentTemplate
; } 
 142     virtual void SetDocumentTemplate(wxDocTemplate 
*temp
) { m_documentTemplate 
= temp
; } 
 144     // Get title, or filename if no title, else [unnamed] 
 145     virtual bool GetPrintableName(wxString
& buf
) const; 
 147     // Returns a window that can be used as a parent for document-related 
 148     // dialogs. Override if necessary. 
 149     virtual wxWindow 
*GetDocumentWindow() const; 
 152     wxList                m_documentViews
; 
 153     wxString              m_documentFile
; 
 154     wxString              m_documentTitle
; 
 155     wxString              m_documentTypeName
; 
 156     wxDocTemplate
*        m_documentTemplate
; 
 157     bool                  m_documentModified
; 
 158     wxDocument
*           m_documentParent
; 
 159     wxCommandProcessor
*   m_commandProcessor
; 
 163     DECLARE_ABSTRACT_CLASS(wxDocument
) 
 166 class WXDLLEXPORT wxView
: public wxEvtHandler
 
 169     //  wxView(wxDocument *doc = (wxDocument *) NULL); 
 173     wxDocument 
*GetDocument() const { return m_viewDocument
; } 
 174     virtual void SetDocument(wxDocument 
*doc
); 
 176     wxString 
GetViewName() const { return m_viewTypeName
; } 
 177     void SetViewName(const wxString
& name
) { m_viewTypeName 
= name
; }; 
 179     wxWindow 
*GetFrame() const { return m_viewFrame 
; } 
 180     void SetFrame(wxWindow 
*frame
) { m_viewFrame 
= frame
; } 
 182     virtual void OnActivateView(bool activate
, wxView 
*activeView
, wxView 
*deactiveView
); 
 183     virtual void OnDraw(wxDC 
*dc
) = 0; 
 184     virtual void OnPrint(wxDC 
*dc
, wxObject 
*info
); 
 185     virtual void OnUpdate(wxView 
*sender
, wxObject 
*hint 
= (wxObject 
*) NULL
); 
 186     virtual void OnClosingDocument() {}; 
 187     virtual void OnChangeFilename(); 
 189     // Called by framework if created automatically by the default document 
 190     // manager class: gives view a chance to initialise 
 191     virtual bool OnCreate(wxDocument 
*WXUNUSED(doc
), long WXUNUSED(flags
)) { return TRUE
; }; 
 193     // Checks if the view is the last one for the document; if so, asks user 
 194     // to confirm save data (if modified). If ok, deletes itself and returns 
 196     virtual bool Close(bool deleteWindow 
= TRUE
); 
 198     // Override to do cleanup/veto close 
 199     virtual bool OnClose(bool deleteWindow
); 
 201 #if WXWIN_COMPATIBILITY 
 202     // Defeat compiler warning 
 203     bool OnClose() { return wxEvtHandler::OnClose(); } 
 206     // Extend event processing to search the document's event table 
 207     virtual bool ProcessEvent(wxEvent
& event
); 
 209     // A view's window can call this to notify the view it is (in)active. 
 210     // The function then notifies the document manager. 
 211     virtual void Activate(bool activate
); 
 213     wxDocManager 
*GetDocumentManager() const 
 214         { return m_viewDocument
->GetDocumentManager(); } 
 216 #if wxUSE_PRINTING_ARCHITECTURE 
 217     virtual wxPrintout 
*OnCreatePrintout(); 
 221     wxDocument
*       m_viewDocument
; 
 222     wxString          m_viewTypeName
; 
 223     wxWindow
*         m_viewFrame
; 
 226     DECLARE_ABSTRACT_CLASS(wxView
) 
 229 // Represents user interface (and other) properties of documents and views 
 230 class WXDLLEXPORT wxDocTemplate
: public wxObject
 
 233 friend class WXDLLEXPORT wxDocManager
; 
 236     // Associate document and view types. They're for identifying what view is 
 237     // associated with what template/document type 
 238     wxDocTemplate(wxDocManager 
*manager
, 
 239                   const wxString
& descr
, 
 240                   const wxString
& filter
, 
 243                   const wxString
& docTypeName
, 
 244                   const wxString
& viewTypeName
, 
 245                   wxClassInfo 
*docClassInfo 
= (wxClassInfo 
*) NULL
, 
 246                   wxClassInfo 
*viewClassInfo 
= (wxClassInfo 
*)NULL
, 
 247                   long flags 
= wxDEFAULT_TEMPLATE_FLAGS
); 
 251     // By default, these two member functions dynamically creates document and 
 252     // view using dynamic instance construction. Override these if you need a 
 253     // different method of construction. 
 254     virtual wxDocument 
*CreateDocument(const wxString
& path
, long flags 
= 0); 
 255     virtual wxView 
*CreateView(wxDocument 
*doc
, long flags 
= 0); 
 257     wxString 
GetDefaultExtension() const { return m_defaultExt
; }; 
 258     wxString 
GetDescription() const { return m_description
; } 
 259     wxString 
GetDirectory() const { return m_directory
; }; 
 260     wxDocManager 
*GetDocumentManager() const { return m_documentManager
; } 
 261     void SetDocumentManager(wxDocManager 
*manager
) { m_documentManager 
= manager
; } 
 262     wxString 
GetFileFilter() const { return m_fileFilter
; }; 
 263     long GetFlags() const { return m_flags
; }; 
 264     virtual wxString 
GetViewName() const { return m_viewTypeName
; } 
 265     virtual wxString 
GetDocumentName() const { return m_docTypeName
; } 
 267     void SetFileFilter(const wxString
& filter
) { m_fileFilter 
= filter
; }; 
 268     void SetDirectory(const wxString
& dir
) { m_directory 
= dir
; }; 
 269     void SetDescription(const wxString
& descr
) { m_description 
= descr
; }; 
 270     void SetDefaultExtension(const wxString
& ext
) { m_defaultExt 
= ext
; }; 
 271     void SetFlags(long flags
) { m_flags 
= flags
; }; 
 273     bool IsVisible() const { return ((m_flags 
& wxTEMPLATE_VISIBLE
) == wxTEMPLATE_VISIBLE
); } 
 275     virtual bool FileMatchesTemplate(const wxString
& path
); 
 279     wxString          m_fileFilter
; 
 280     wxString          m_directory
; 
 281     wxString          m_description
; 
 282     wxString          m_defaultExt
; 
 283     wxString          m_docTypeName
; 
 284     wxString          m_viewTypeName
; 
 285     wxDocManager
*     m_documentManager
; 
 287     // For dynamic creation of appropriate instances. 
 288     wxClassInfo
*      m_docClassInfo
; 
 289     wxClassInfo
*      m_viewClassInfo
; 
 292     DECLARE_CLASS(wxDocTemplate
) 
 295 // One object of this class may be created in an application, to manage all 
 296 // the templates and documents. 
 297 class WXDLLEXPORT wxDocManager
: public wxEvtHandler
 
 299     DECLARE_DYNAMIC_CLASS(wxDocManager
) 
 302     wxDocManager(long flags 
= wxDEFAULT_DOCMAN_FLAGS
, bool initialize 
= TRUE
); 
 305     virtual bool Initialize(); 
 307     // Handlers for common user commands 
 308     void OnFileClose(wxCommandEvent
& event
); 
 309     void OnFileCloseAll(wxCommandEvent
& event
); 
 310     void OnFileNew(wxCommandEvent
& event
); 
 311     void OnFileOpen(wxCommandEvent
& event
); 
 312     void OnFileRevert(wxCommandEvent
& event
); 
 313     void OnFileSave(wxCommandEvent
& event
); 
 314     void OnFileSaveAs(wxCommandEvent
& event
); 
 315     void OnPrint(wxCommandEvent
& event
); 
 316     void OnPrintSetup(wxCommandEvent
& event
); 
 317     void OnPreview(wxCommandEvent
& event
); 
 318     void OnUndo(wxCommandEvent
& event
); 
 319     void OnRedo(wxCommandEvent
& event
); 
 321     // Handlers for UI update commands 
 322     void OnUpdateFileOpen(wxUpdateUIEvent
& event
); 
 323     void OnUpdateFileClose(wxUpdateUIEvent
& event
); 
 324     void OnUpdateFileRevert(wxUpdateUIEvent
& event
); 
 325     void OnUpdateFileNew(wxUpdateUIEvent
& event
); 
 326     void OnUpdateFileSave(wxUpdateUIEvent
& event
); 
 327     void OnUpdateFileSaveAs(wxUpdateUIEvent
& event
); 
 328     void OnUpdateUndo(wxUpdateUIEvent
& event
); 
 329     void OnUpdateRedo(wxUpdateUIEvent
& event
); 
 331     void OnUpdatePrint(wxUpdateUIEvent
& event
); 
 332     void OnUpdatePrintSetup(wxUpdateUIEvent
& event
); 
 333     void OnUpdatePreview(wxUpdateUIEvent
& event
); 
 335     // Extend event processing to search the view's event table 
 336     virtual bool ProcessEvent(wxEvent
& event
); 
 338     // called when file format detection didn't work, can be overridden to do 
 339     // something in this case 
 340     virtual void OnOpenFileFailure() { } 
 342     virtual wxDocument 
*CreateDocument(const wxString
& path
, long flags 
= 0); 
 343     virtual wxView 
*CreateView(wxDocument 
*doc
, long flags 
= 0); 
 344     virtual void DeleteTemplate(wxDocTemplate 
*temp
, long flags 
= 0); 
 345     virtual bool FlushDoc(wxDocument 
*doc
); 
 346     virtual wxDocTemplate 
*MatchTemplate(const wxString
& path
); 
 347     virtual wxDocTemplate 
*SelectDocumentPath(wxDocTemplate 
**templates
, 
 348             int noTemplates
, wxString
& path
, long flags
, bool save 
= FALSE
); 
 349     virtual wxDocTemplate 
*SelectDocumentType(wxDocTemplate 
**templates
, 
 350             int noTemplates
, bool sort 
= FALSE
); 
 351     virtual wxDocTemplate 
*SelectViewType(wxDocTemplate 
**templates
, 
 352             int noTemplates
, bool sort 
= FALSE
); 
 353     virtual wxDocTemplate 
*FindTemplateForPath(const wxString
& path
); 
 355     void AssociateTemplate(wxDocTemplate 
*temp
); 
 356     void DisassociateTemplate(wxDocTemplate 
*temp
); 
 358     wxDocument 
*GetCurrentDocument() const; 
 360     void SetMaxDocsOpen(int n
) { m_maxDocsOpen 
= n
; } 
 361     int GetMaxDocsOpen() const { return m_maxDocsOpen
; } 
 363     // Add and remove a document from the manager's list 
 364     void AddDocument(wxDocument 
*doc
); 
 365     void RemoveDocument(wxDocument 
*doc
); 
 367     // closes all currently open documents 
 368     bool CloseDocuments(bool force 
= TRUE
); 
 370     // Clear remaining documents and templates 
 371     bool Clear(bool force 
= TRUE
); 
 373     // Views or windows should inform the document manager 
 374     // when a view is going in or out of focus 
 375     virtual void ActivateView(wxView 
*view
, bool activate 
= TRUE
, bool deleting 
= FALSE
); 
 376     virtual wxView 
*GetCurrentView() const; 
 378     wxList
& GetDocuments() { return m_docs
; } 
 379     wxList
& GetTemplates() { return m_templates
; } 
 381     // Make a default document name 
 382     virtual bool MakeDefaultName(wxString
& buf
); 
 384     // Make a frame title (override this to do something different) 
 385     virtual wxString 
MakeFrameTitle(wxDocument
* doc
); 
 387     virtual wxFileHistory 
*OnCreateFileHistory(); 
 388     virtual wxFileHistory 
*GetFileHistory() const { return m_fileHistory
; } 
 390     // File history management 
 391     virtual void AddFileToHistory(const wxString
& file
); 
 392     virtual void RemoveFileFromHistory(int i
); 
 393     virtual int GetNoHistoryFiles() const; 
 394     virtual wxString 
GetHistoryFile(int i
) const; 
 395     virtual void FileHistoryUseMenu(wxMenu 
*menu
); 
 396     virtual void FileHistoryRemoveMenu(wxMenu 
*menu
); 
 398     virtual void FileHistoryLoad(wxConfigBase
& config
); 
 399     virtual void FileHistorySave(wxConfigBase
& config
); 
 400 #endif // wxUSE_CONFIG 
 402     virtual void FileHistoryAddFilesToMenu(); 
 403     virtual void FileHistoryAddFilesToMenu(wxMenu
* menu
); 
 405     inline wxString 
GetLastDirectory() const { return m_lastDirectory
; } 
 406     inline void SetLastDirectory(const wxString
& dir
) { m_lastDirectory 
= dir
; } 
 408     // Get the current document manager 
 409     static wxDocManager
* GetDocumentManager() { return sm_docManager
; } 
 413     int               m_defaultDocumentNameCounter
; 
 417     wxView
*           m_currentView
; 
 418     wxFileHistory
*    m_fileHistory
; 
 419     wxString          m_lastDirectory
; 
 420     static wxDocManager
* sm_docManager
; 
 422     DECLARE_EVENT_TABLE() 
 425 // ---------------------------------------------------------------------------- 
 426 // A default child frame 
 427 // ---------------------------------------------------------------------------- 
 429 class WXDLLEXPORT wxDocChildFrame 
: public wxFrame
 
 432     wxDocChildFrame(wxDocument 
*doc
, 
 436                     const wxString
& title
, 
 437                     const wxPoint
& pos 
= wxDefaultPosition
, 
 438                     const wxSize
& size 
= wxDefaultSize
, 
 439                     long type 
= wxDEFAULT_FRAME_STYLE
, 
 440                     const wxString
& name 
= wxT("frame")); 
 443     // Extend event processing to search the view's event table 
 444     virtual bool ProcessEvent(wxEvent
& event
); 
 446     void OnActivate(wxActivateEvent
& event
); 
 447     void OnCloseWindow(wxCloseEvent
& event
); 
 449     wxDocument 
*GetDocument() const { return m_childDocument
; } 
 450     wxView 
*GetView() const { return m_childView
; } 
 451     void SetDocument(wxDocument 
*doc
) { m_childDocument 
= doc
; } 
 452     void SetView(wxView 
*view
) { m_childView 
= view
; } 
 453     bool Destroy() { m_childView 
= (wxView 
*)NULL
; return wxFrame::Destroy(); } 
 456     wxDocument
*       m_childDocument
; 
 460     DECLARE_CLASS(wxDocChildFrame
) 
 461     DECLARE_EVENT_TABLE() 
 464 // ---------------------------------------------------------------------------- 
 465 // A default parent frame 
 466 // ---------------------------------------------------------------------------- 
 468 class WXDLLEXPORT wxDocParentFrame 
: public wxFrame
 
 471     wxDocParentFrame(wxDocManager 
*manager
, 
 474                      const wxString
& title
, 
 475                      const wxPoint
& pos 
= wxDefaultPosition
, 
 476                      const wxSize
& size 
= wxDefaultSize
, 
 477                      long type 
= wxDEFAULT_FRAME_STYLE
, 
 478                      const wxString
& name 
= wxT("frame")); 
 480     // Extend event processing to search the document manager's event table 
 481     virtual bool ProcessEvent(wxEvent
& event
); 
 483     wxDocManager 
*GetDocumentManager() const { return m_docManager
; } 
 485     void OnExit(wxCommandEvent
& event
); 
 486     void OnMRUFile(wxCommandEvent
& event
); 
 487     void OnCloseWindow(wxCloseEvent
& event
); 
 490     wxDocManager 
*m_docManager
; 
 493     DECLARE_CLASS(wxDocParentFrame
) 
 494     DECLARE_EVENT_TABLE() 
 497 // ---------------------------------------------------------------------------- 
 498 // Provide simple default printing facilities 
 499 // ---------------------------------------------------------------------------- 
 501 #if wxUSE_PRINTING_ARCHITECTURE 
 502 class WXDLLEXPORT wxDocPrintout 
: public wxPrintout
 
 505     wxDocPrintout(wxView 
*view 
= (wxView 
*) NULL
, const wxString
& title 
= wxT("Printout")); 
 506     bool OnPrintPage(int page
); 
 507     bool HasPage(int page
); 
 508     bool OnBeginDocument(int startPage
, int endPage
); 
 509     void GetPageInfo(int *minPage
, int *maxPage
, int *selPageFrom
, int *selPageTo
); 
 511     virtual wxView 
*GetView() { return m_printoutView
; } 
 514     wxView
*       m_printoutView
; 
 517     DECLARE_DYNAMIC_CLASS(wxDocPrintout
) 
 519 #endif // wxUSE_PRINTING_ARCHITECTURE 
 521 // ---------------------------------------------------------------------------- 
 522 // File history management 
 523 // ---------------------------------------------------------------------------- 
 525 class WXDLLEXPORT wxFileHistory 
: public wxObject
 
 528     wxFileHistory(int maxFiles 
= 9); 
 532     virtual void AddFileToHistory(const wxString
& file
); 
 533     virtual void RemoveFileFromHistory(int i
); 
 534     virtual int GetMaxFiles() const { return m_fileMaxFiles
; } 
 535     virtual void UseMenu(wxMenu 
*menu
); 
 537     // Remove menu from the list (MDI child may be closing) 
 538     virtual void RemoveMenu(wxMenu 
*menu
); 
 541     virtual void Load(wxConfigBase
& config
); 
 542     virtual void Save(wxConfigBase
& config
); 
 543 #endif // wxUSE_CONFIG 
 545     virtual void AddFilesToMenu(); 
 546     virtual void AddFilesToMenu(wxMenu
* menu
); // Single menu 
 549     virtual wxString 
GetHistoryFile(int i
) const; 
 551     // A synonym for GetNoHistoryFiles 
 552     virtual int GetCount() const { return m_fileHistoryN
; } 
 553     int GetNoHistoryFiles() const { return m_fileHistoryN
; } 
 555     wxList
& GetMenus() const { return (wxList
&) m_fileMenus
; } 
 559     wxChar
**          m_fileHistory
; 
 560     // Number of files saved 
 562     // Menus to maintain (may need several for an MDI app) 
 564     // Max files to maintain 
 568     DECLARE_DYNAMIC_CLASS(wxFileHistory
) 
 571 #if wxUSE_STD_IOSTREAM 
 572 // For compatibility with existing file formats: 
 573 // converts from/to a stream to/from a temporary file. 
 574 bool WXDLLEXPORT 
wxTransferFileToStream(const wxString
& filename
, wxSTD ostream
& stream
); 
 575 bool WXDLLEXPORT 
wxTransferStreamToFile(wxSTD istream
& stream
, const wxString
& filename
); 
 577 // For compatibility with existing file formats: 
 578 // converts from/to a stream to/from a temporary file. 
 579 bool WXDLLEXPORT 
wxTransferFileToStream(const wxString
& filename
, wxOutputStream
& stream
); 
 580 bool WXDLLEXPORT 
wxTransferStreamToFile(wxInputStream
& stream
, const wxString
& filename
);