]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/docview.h
RCS-IDs
[wxWidgets.git] / interface / wx / docview.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: docview.h
0c1fe6e9 3// Purpose: interface of various doc/view framework classes
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxDocTemplate
7c913512 11
23324ae1
FM
12 The wxDocTemplate class is used to model the relationship between a
13 document class and a view class.
7c913512 14
23324ae1 15 @library{wxcore}
0c1fe6e9 16 @category{docview}
7c913512 17
0c1fe6e9 18 @see @ref overview_docview_wxdoctemplate, wxDocument, wxView
23324ae1
FM
19*/
20class wxDocTemplate : public wxObject
21{
22public:
23 /**
0c1fe6e9
BP
24 Constructor. Create instances dynamically near the start of your
25 application after creating a wxDocManager instance, and before doing
26 any document or view operations.
27
28 @param manager
29 The document manager object which manages this template.
30 @param descr
31 A short description of what the template is for. This string will
32 be displayed in the file filter list of Windows file selectors.
33 @param filter
34 An appropriate file filter such as "*.txt".
35 @param dir
36 The default directory to use for file selectors.
37 @param ext
38 The default file extension (such as "txt").
39 @param docTypeName
40 A name that should be unique for a given type of document, used for
41 gathering a list of views relevant to a particular document.
42 @param viewTypeName
43 A name that should be unique for a given view.
44 @param docClassInfo
45 A pointer to the run-time document class information as returned by
46 the CLASSINFO() macro, e.g. CLASSINFO(MyDocumentClass). If this is
47 not supplied, you will need to derive a new wxDocTemplate class and
48 override the CreateDocument() member to return a new document
49 instance on demand.
50 @param viewClassInfo
51 A pointer to the run-time view class information as returned by the
52 CLASSINFO() macro, e.g. CLASSINFO(MyViewClass). If this is not
53 supplied, you will need to derive a new wxDocTemplate class and
54 override the CreateView() member to return a new view instance on
55 demand.
56 @param flags
57 A bit list of the following:
58 - wxTEMPLATE_VISIBLE - The template may be displayed to the
59 user in dialogs.
60 - wxTEMPLATE_INVISIBLE - The template may not be displayed to
61 the user in dialogs.
62 - wxDEFAULT_TEMPLATE_FLAGS - Defined as wxTEMPLATE_VISIBLE.
23324ae1
FM
63 */
64 wxDocTemplate(wxDocManager* manager, const wxString& descr,
0c1fe6e9
BP
65 const wxString& filter, const wxString& dir,
66 const wxString& ext, const wxString& docTypeName,
b91c4601
FM
67 const wxString& viewTypeName, wxClassInfo* docClassInfo = 0,
68 wxClassInfo* viewClassInfo = 0,
69 long flags = wxTEMPLATE_VISIBLE);
23324ae1
FM
70
71 /**
72 Destructor.
73 */
adaaa686 74 virtual ~wxDocTemplate();
23324ae1
FM
75
76 /**
0c1fe6e9
BP
77 Creates a new instance of the associated document class. If you have
78 not supplied a wxClassInfo parameter to the template constructor, you
79 will need to override this function to return an appropriate document
80 instance.
81
82 This function calls InitDocument() which in turns calls
83 wxDocument::OnCreate().
23324ae1 84 */
adaaa686 85 virtual wxDocument* CreateDocument(const wxString& path, long flags = 0);
23324ae1
FM
86
87 /**
0c1fe6e9
BP
88 Creates a new instance of the associated view class. If you have not
89 supplied a wxClassInfo parameter to the template constructor, you will
90 need to override this function to return an appropriate view instance.
23324ae1 91 */
adaaa686 92 virtual wxView* CreateView(wxDocument* doc, long flags = 0);
23324ae1
FM
93
94 /**
0c1fe6e9
BP
95 Returns the default file extension for the document data, as passed to
96 the document template constructor.
23324ae1 97 */
adaaa686 98 wxString GetDefaultExtension() const;
23324ae1
FM
99
100 /**
0c1fe6e9
BP
101 Returns the text description of this template, as passed to the
102 document template constructor.
23324ae1 103 */
adaaa686 104 wxString GetDescription() const;
23324ae1
FM
105
106 /**
0c1fe6e9
BP
107 Returns the default directory, as passed to the document template
108 constructor.
23324ae1 109 */
adaaa686 110 wxString GetDirectory() const;
23324ae1
FM
111
112 /**
0c1fe6e9
BP
113 Returns a pointer to the document manager instance for which this
114 template was created.
23324ae1 115 */
adaaa686 116 wxDocManager* GetDocumentManager() const;
23324ae1
FM
117
118 /**
0c1fe6e9
BP
119 Returns the document type name, as passed to the document template
120 constructor.
23324ae1 121 */
adaaa686 122 virtual wxString GetDocumentName() const;
23324ae1
FM
123
124 /**
0c1fe6e9
BP
125 Returns the file filter, as passed to the document template
126 constructor.
23324ae1 127 */
adaaa686 128 wxString GetFileFilter() const;
23324ae1
FM
129
130 /**
131 Returns the flags, as passed to the document template constructor.
132 */
adaaa686 133 long GetFlags() const;
23324ae1
FM
134
135 /**
0c1fe6e9
BP
136 Returns the view type name, as passed to the document template
137 constructor.
23324ae1 138 */
adaaa686 139 virtual wxString GetViewName() const;
23324ae1
FM
140
141 /**
0c1fe6e9
BP
142 Initialises the document, calling wxDocument::OnCreate(). This is
143 called from CreateDocument().
23324ae1 144 */
adaaa686
FM
145 virtual bool InitDocument(wxDocument* doc, const wxString& path,
146 long flags = 0);
23324ae1
FM
147
148 /**
0c1fe6e9
BP
149 Returns @true if the document template can be shown in user dialogs,
150 @false otherwise.
23324ae1 151 */
adaaa686 152 bool IsVisible() const;
23324ae1
FM
153
154 /**
155 Sets the default file extension.
156 */
157 void SetDefaultExtension(const wxString& ext);
158
159 /**
160 Sets the template description.
161 */
162 void SetDescription(const wxString& descr);
163
164 /**
165 Sets the default directory.
166 */
167 void SetDirectory(const wxString& dir);
168
169 /**
0c1fe6e9
BP
170 Sets the pointer to the document manager instance for which this
171 template was created. Should not be called by the application.
23324ae1 172 */
4cc4bfaf 173 void SetDocumentManager(wxDocManager* manager);
23324ae1
FM
174
175 /**
176 Sets the file filter.
177 */
178 void SetFileFilter(const wxString& filter);
179
180 /**
0c1fe6e9
BP
181 Sets the internal document template flags (see the constructor
182 description for more details).
23324ae1
FM
183 */
184 void SetFlags(long flags);
185
186 /**
23324ae1
FM
187 The default extension for files of this type.
188 */
0c1fe6e9 189 wxString m_defaultExt;
23324ae1
FM
190
191 /**
23324ae1
FM
192 A short description of this template.
193 */
0c1fe6e9 194 wxString m_description;
23324ae1
FM
195
196 /**
23324ae1
FM
197 The default directory for files of this type.
198 */
0c1fe6e9 199 wxString m_directory;
23324ae1
FM
200
201 /**
0c1fe6e9
BP
202 Run-time class information that allows document instances to be
203 constructed dynamically.
23324ae1 204 */
0c1fe6e9 205 wxClassInfo* m_docClassInfo;
23324ae1
FM
206
207 /**
23324ae1
FM
208 The named type of the document associated with this template.
209 */
0c1fe6e9 210 wxString m_docTypeName;
23324ae1
FM
211
212 /**
23324ae1
FM
213 A pointer to the document manager for which this template was created.
214 */
0c1fe6e9 215 wxDocTemplate* m_documentManager;
23324ae1
FM
216
217 /**
0c1fe6e9 218 The file filter (such as "*.txt") to be used in file selector dialogs.
23324ae1 219 */
0c1fe6e9 220 wxString m_fileFilter;
23324ae1
FM
221
222 /**
23324ae1
FM
223 The flags passed to the constructor.
224 */
0c1fe6e9 225 long m_flags;
23324ae1
FM
226
227 /**
23324ae1
FM
228 Run-time class information that allows view instances to be constructed
229 dynamically.
230 */
0c1fe6e9 231 wxClassInfo* m_viewClassInfo;
23324ae1
FM
232
233 /**
23324ae1
FM
234 The named type of the view associated with this template.
235 */
0c1fe6e9 236 wxString m_viewTypeName;
23324ae1
FM
237};
238
239
e54c96f1 240
23324ae1
FM
241/**
242 @class wxDocManager
7c913512 243
23324ae1 244 The wxDocManager class is part of the document/view framework supported by
0c1fe6e9
BP
245 wxWidgets, and cooperates with the wxView, wxDocument and wxDocTemplate
246 classes.
7c913512 247
23324ae1 248 @library{wxcore}
0c1fe6e9 249 @category{docview}
7c913512 250
0c1fe6e9
BP
251 @see @ref overview_docview_wxdocmanager, wxDocument, wxView, wxDocTemplate,
252 wxFileHistory
23324ae1
FM
253*/
254class wxDocManager : public wxEvtHandler
255{
256public:
257 /**
0c1fe6e9
BP
258 Constructor. Create a document manager instance dynamically near the
259 start of your application before doing any document or view operations.
260
0c1fe6e9
BP
261 If @a initialize is @true, the Initialize() function will be called to
262 create a default history list object. If you derive from wxDocManager,
263 you may wish to call the base constructor with @false, and then call
264 Initialize() in your own constructor, to allow your own Initialize() or
265 OnCreateFileHistory functions to be called.
c77049a0
VZ
266
267 @param flags
268 Currently unused.
269 @param initialize
270 Indicates whether Initialize() should be called by this ctor.
23324ae1 271 */
c77049a0 272 wxDocManager(long flags = 0, bool initialize = true);
23324ae1
FM
273
274 /**
275 Destructor.
276 */
adaaa686 277 virtual ~wxDocManager();
23324ae1
FM
278
279 /**
280 Sets the current view.
281 */
adaaa686 282 virtual void ActivateView(wxView* doc, bool activate = true);
23324ae1
FM
283
284 /**
285 Adds the document to the list of documents.
286 */
4cc4bfaf 287 void AddDocument(wxDocument* doc);
23324ae1
FM
288
289 /**
0c1fe6e9
BP
290 Adds a file to the file history list, if we have a pointer to an
291 appropriate file menu.
23324ae1 292 */
adaaa686 293 virtual void AddFileToHistory(const wxString& filename);
23324ae1
FM
294
295 /**
296 Adds the template to the document manager's template list.
297 */
4cc4bfaf 298 void AssociateTemplate(wxDocTemplate* temp);
23324ae1
FM
299
300 /**
301 Closes all currently opened documents.
302 */
4cc4bfaf 303 bool CloseDocuments(bool force = true);
23324ae1
FM
304
305 /**
c77049a0
VZ
306 Creates a new document.
307
308 This function can either create a document corresponding to a new
309 file or to an already existing one depending on whether @c wxDOC_NEW is
310 specified in the @a flags.
311
312 By default, this function asks the user for the type of document to
313 open and the path to its file if it's not specified, i.e. if @a path is
314 empty. Specifying @c wxDOC_SILENT flag suppresses any prompts and means
315 that the @a path must be non-empty and there must be a registered
316 document template handling the extension of this file, otherwise a
317 warning message is logged and the function returns @NULL. Notice that
318 @c wxDOC_SILENT can be combined with @c wxDOC_NEW, however in this case
319 the @a path must still be specified, even if the file with this path
320 typically won't exist.
321
322 Finally notice that if this document manager was configured to allow
323 only a limited number of simultaneously opened documents using
324 SetMaxDocsOpen(), this function will try to close the oldest existing
325 document if this number was reached before creating a new document.
326 And if closing the old document fails (e.g. because it was vetoed by
327 user), this function fails as well.
328
329 @param path
330 Path to a file or an empty string. If the path is empty, the user
331 will be asked to select it (thus, this is incompatible with the use
332 of @c wxDOC_SILENT). The file should exist unless @a flags includes
333 @c wxDOC_NEW.
334 @param flags
335 By default, none. May include @c wxDOC_NEW to indicate that the new
336 document corresponds to a new file and not an existing one and
337 @c wxDOC_SILENT to suppress any dialogs asking the user about the
338 file path and type.
339 @return a new document object or @NULL on failure.
23324ae1 340 */
adaaa686 341 virtual wxDocument* CreateDocument(const wxString& path, long flags = 0);
23324ae1 342
b5412983
VZ
343 /**
344 Creates an empty new document.
345
346 This is equivalent to calling CreateDocument() with @c wxDOC_NEW flags
347 and without the file name.
348 */
349 wxDocument *CreateNewDocument();
350
23324ae1 351 /**
0c1fe6e9
BP
352 Creates a new view for the given document. If more than one view is
353 allowed for the document (by virtue of multiple templates mentioning
354 the same document type), a choice of view is presented to the user.
23324ae1 355 */
b91c4601 356 virtual wxView* CreateView(wxDocument* doc, long flags = 0);
23324ae1
FM
357
358 /**
359 Removes the template from the list of templates.
360 */
4cc4bfaf 361 void DisassociateTemplate(wxDocTemplate* temp);
23324ae1 362
23324ae1 363 /**
0c1fe6e9
BP
364 Appends the files in the history list to all menus managed by the file
365 history object.
23324ae1 366 */
adaaa686 367 virtual void FileHistoryAddFilesToMenu();
0c1fe6e9
BP
368 /**
369 Appends the files in the history list to the given @a menu only.
370 */
adaaa686 371 virtual void FileHistoryAddFilesToMenu(wxMenu* menu);
23324ae1
FM
372
373 /**
374 Loads the file history from a config object.
3c4f71cc 375
0c1fe6e9 376 @see wxConfigBase
23324ae1 377 */
adaaa686 378 virtual void FileHistoryLoad(const wxConfigBase& config);
23324ae1
FM
379
380 /**
0c1fe6e9
BP
381 Removes the given menu from the list of menus managed by the file
382 history object.
23324ae1 383 */
adaaa686 384 virtual void FileHistoryRemoveMenu(wxMenu* menu);
23324ae1
FM
385
386 /**
387 Saves the file history into a config object. This must be called
388 explicitly by the application.
3c4f71cc 389
0c1fe6e9 390 @see wxConfigBase
23324ae1 391 */
adaaa686 392 virtual void FileHistorySave(wxConfigBase& resourceFile);
23324ae1
FM
393
394 /**
0c1fe6e9
BP
395 Use this menu for appending recently-visited document filenames, for
396 convenient access. Calling this function with a valid menu pointer
397 enables the history list functionality.
398
399 @note You can add multiple menus using this function, to be managed by
400 the file history object.
23324ae1 401 */
adaaa686 402 virtual void FileHistoryUseMenu(wxMenu* menu);
23324ae1
FM
403
404 /**
0c1fe6e9
BP
405 Given a path, try to find template that matches the extension. This is
406 only an approximate method of finding a template for creating a
407 document.
23324ae1 408 */
adaaa686 409 virtual wxDocTemplate* FindTemplateForPath(const wxString& path);
23324ae1
FM
410
411 /**
0c1fe6e9
BP
412 Returns the document associated with the currently active view (if
413 any).
23324ae1 414 */
adaaa686 415 wxDocument* GetCurrentDocument() const;
23324ae1
FM
416
417 /**
418 Returns the currently active view
419 */
adaaa686 420 virtual wxView* GetCurrentView() const;
23324ae1
FM
421
422 /**
423 Returns a reference to the list of documents.
424 */
b91c4601 425 wxList& GetDocuments();
23324ae1
FM
426
427 /**
428 Returns a pointer to file history.
429 */
adaaa686 430 virtual wxFileHistory* GetFileHistory() const;
23324ae1
FM
431
432 /**
433 Returns the number of files currently stored in the file history.
434 */
adaaa686 435 virtual size_t GetHistoryFilesCount() const;
23324ae1
FM
436
437 /**
0c1fe6e9
BP
438 Returns the directory last selected by the user when opening a file.
439 Initially empty.
23324ae1 440 */
328f5751 441 wxString GetLastDirectory() const;
23324ae1
FM
442
443 /**
444 Returns the number of documents that can be open simultaneously.
445 */
adaaa686 446 int GetMaxDocsOpen() const;
23324ae1
FM
447
448 /**
449 Returns a reference to the list of associated templates.
450 */
b91c4601 451 wxList& GetTemplates();
23324ae1
FM
452
453 /**
0c1fe6e9
BP
454 Initializes data; currently just calls OnCreateFileHistory().
455
456 Some data cannot always be initialized in the constructor because the
457 programmer must be given the opportunity to override functionality. If
458 OnCreateFileHistory() was called from the constructor, an overridden
459 virtual OnCreateFileHistory() would not be called due to C++'s
460 'interesting' constructor semantics. In fact Initialize() @e is called
461 from the wxDocManager constructor, but this can be vetoed by passing
462 @false to the second argument, allowing the derived class's constructor
463 to call Initialize(), possibly calling a different
464 OnCreateFileHistory() from the default.
465
466 The bottom line: if you're not deriving from Initialize(), forget it
467 and construct wxDocManager with no arguments.
23324ae1 468 */
adaaa686 469 virtual bool Initialize();
23324ae1
FM
470
471 /**
0c1fe6e9
BP
472 Return a string containing a suitable default name for a new document.
473 By default this is implemented by appending an integer counter to the
474 string @b unnamed but can be overridden in the derived classes to do
475 something more appropriate.
23324ae1 476 */
adaaa686 477 virtual wxString MakeNewDocumentName();
23324ae1
FM
478
479 /**
0c1fe6e9
BP
480 A hook to allow a derived class to create a different type of file
481 history. Called from Initialize().
23324ae1 482 */
adaaa686 483 virtual wxFileHistory* OnCreateFileHistory();
23324ae1
FM
484
485 /**
486 Closes and deletes the currently active document.
487 */
488 void OnFileClose(wxCommandEvent& event);
489
490 /**
491 Closes and deletes all the currently opened documents.
492 */
493 void OnFileCloseAll(wxCommandEvent& event);
494
495 /**
0c1fe6e9
BP
496 Creates a document from a list of templates (if more than one
497 template).
23324ae1
FM
498 */
499 void OnFileNew(wxCommandEvent& event);
500
501 /**
502 Creates a new document and reads in the selected file.
503 */
504 void OnFileOpen(wxCommandEvent& event);
505
506 /**
0c1fe6e9
BP
507 Reverts the current document by calling wxDocument::Revert() for the
508 current document.
23324ae1
FM
509 */
510 void OnFileRevert(wxCommandEvent& event);
511
512 /**
0c1fe6e9
BP
513 Saves the current document by calling wxDocument::Save() for the
514 current document.
23324ae1
FM
515 */
516 void OnFileSave(wxCommandEvent& event);
517
518 /**
0c1fe6e9 519 Calls wxDocument::SaveAs() for the current document.
23324ae1
FM
520 */
521 void OnFileSaveAs(wxCommandEvent& event);
522
523 /**
524 Removes the document from the list of documents.
525 */
4cc4bfaf 526 void RemoveDocument(wxDocument* doc);
23324ae1
FM
527
528 /**
0c1fe6e9
BP
529 Under Windows, pops up a file selector with a list of filters
530 corresponding to document templates. The wxDocTemplate corresponding to
531 the selected file's extension is returned.
532
533 On other platforms, if there is more than one document template a
534 choice list is popped up, followed by a file selector.
535
23324ae1 536 This function is used in CreateDocument().
23324ae1 537 */
b91c4601
FM
538 virtual wxDocTemplate* SelectDocumentPath(wxDocTemplate** templates,
539 int noTemplates, wxString& path,
540 long flags, bool save = false);
23324ae1
FM
541
542 /**
0c1fe6e9
BP
543 Returns a document template by asking the user (if there is more than
544 one template). This function is used in CreateDocument().
3c4f71cc 545
7c913512 546 @param templates
0c1fe6e9
BP
547 Pointer to an array of templates from which to choose a desired
548 template.
7c913512 549 @param noTemplates
4cc4bfaf 550 Number of templates being pointed to by the templates pointer.
7c913512 551 @param sort
0c1fe6e9
BP
552 If more than one template is passed in in templates, then this
553 parameter indicates whether the list of templates that the user
554 will have to choose from is sorted or not when shown the choice box
555 dialog. Default is @false.
23324ae1 556 */
4cc4bfaf 557 wxDocTemplate* SelectDocumentType(wxDocTemplate** templates,
0c1fe6e9 558 int noTemplates, bool sort = false);
23324ae1
FM
559
560 /**
0c1fe6e9
BP
561 Returns a document template by asking the user (if there is more than
562 one template), displaying a list of valid views. This function is used
563 in CreateView(). The dialog normally will not appear because the array
564 of templates only contains those relevant to the document in question,
565 and often there will only be one such.
3c4f71cc 566
7c913512 567 @param templates
0c1fe6e9
BP
568 Pointer to an array of templates from which to choose a desired
569 template.
7c913512 570 @param noTemplates
4cc4bfaf 571 Number of templates being pointed to by the templates pointer.
7c913512 572 @param sort
0c1fe6e9
BP
573 If more than one template is passed in in templates, then this
574 parameter indicates whether the list of templates that the user
575 will have to choose from is sorted or not when shown the choice box
576 dialog. Default is @false.
23324ae1 577 */
4cc4bfaf 578 wxDocTemplate* SelectViewType(wxDocTemplate** templates,
0c1fe6e9 579 int noTemplates, bool sort = false);
23324ae1
FM
580
581 /**
0c1fe6e9
BP
582 Sets the directory to be displayed to the user when opening a file.
583 Initially this is empty.
23324ae1
FM
584 */
585 void SetLastDirectory(const wxString& dir);
586
587 /**
0c1fe6e9 588 Sets the maximum number of documents that can be open at a time. By
c77049a0
VZ
589 default, this is @c INT_MAX, i.e. the number of documents is unlimited.
590 If you set it to 1, existing documents will be saved and deleted when
591 the user tries to open or create a new one (similar to the behaviour of
592 Windows Write, for example). Allowing multiple documents gives
593 behaviour more akin to MS Word and other Multiple Document Interface
594 applications.
23324ae1
FM
595 */
596 void SetMaxDocsOpen(int n);
597
598 /**
23324ae1
FM
599 The currently active view.
600 */
0c1fe6e9 601 wxView* m_currentView;
23324ae1
FM
602
603 /**
23324ae1
FM
604 Stores the integer to be used for the next default document name.
605 */
0c1fe6e9 606 int m_defaultDocumentNameCounter;
23324ae1
FM
607
608 /**
23324ae1
FM
609 A list of all documents.
610 */
0c1fe6e9 611 wxList m_docs;
23324ae1
FM
612
613 /**
0c1fe6e9
BP
614 A pointer to an instance of wxFileHistory, which manages the history of
615 recently-visited files on the File menu.
23324ae1 616 */
0c1fe6e9 617 wxFileHistory* m_fileHistory;
23324ae1
FM
618
619 /**
23324ae1
FM
620 Stores the flags passed to the constructor.
621 */
0c1fe6e9 622 long m_flags;
23324ae1
FM
623
624 /**
625 The directory last selected by the user when opening a file.
23324ae1 626 */
0c1fe6e9 627 wxFileHistory* m_fileHistory;
23324ae1
FM
628
629 /**
23324ae1
FM
630 Stores the maximum number of documents that can be opened before
631 existing documents are closed. By default, this is 10,000.
632 */
0c1fe6e9 633 int m_maxDocsOpen;
23324ae1
FM
634};
635
636
e54c96f1 637
23324ae1
FM
638/**
639 @class wxView
7c913512 640
23324ae1
FM
641 The view class can be used to model the viewing and editing component of
642 an application's file-based data. It is part of the document/view framework
0c1fe6e9 643 supported by wxWidgets, and cooperates with the wxDocument, wxDocTemplate
23324ae1 644 and wxDocManager classes.
7c913512 645
23324ae1 646 @library{wxcore}
0c1fe6e9 647 @category{docview}
7c913512 648
0c1fe6e9 649 @see @ref overview_docview_wxview, wxDocument, wxDocTemplate, wxDocManager
23324ae1
FM
650*/
651class wxView : public wxEvtHandler
652{
653public:
654 /**
655 Constructor. Define your own default constructor to initialize
0c1fe6e9 656 application-specific data.
23324ae1
FM
657 */
658 wxView();
659
660 /**
661 Destructor. Removes itself from the document's list of views.
662 */
adaaa686 663 virtual ~wxView();
23324ae1
FM
664
665 /**
0c1fe6e9
BP
666 Call this from your view frame's wxDocChildFrame::OnActivate() member
667 to tell the framework which view is currently active. If your windowing
668 system doesn't call wxDocChildFrame::OnActivate(), you may need to call
669 this function from any place where you know the view must be active,
670 and the framework will need to get the current view.
671
672 The prepackaged view frame wxDocChildFrame calls Activate() from its
673 wxDocChildFrame::OnActivate() member.
674
23324ae1
FM
675 This function calls OnActivateView().
676 */
677 virtual void Activate(bool activate);
678
679 /**
0c1fe6e9
BP
680 Closes the view by calling OnClose(). If @a deleteWindow is @true, this
681 function should delete the window associated with the view.
23324ae1 682 */
4cc4bfaf 683 virtual bool Close(bool deleteWindow = true);
23324ae1
FM
684
685 /**
686 Gets a pointer to the document associated with the view.
687 */
328f5751 688 wxDocument* GetDocument() const;
23324ae1
FM
689
690 /**
0c1fe6e9
BP
691 Returns a pointer to the document manager instance associated with this
692 view.
23324ae1 693 */
328f5751 694 wxDocManager* GetDocumentManager() const;
23324ae1
FM
695
696 /**
0c1fe6e9
BP
697 Gets the frame associated with the view (if any). Note that this
698 "frame" is not a wxFrame at all in the generic MDI implementation which
699 uses notebook pages instead of frames and this is why this method
700 returns a wxWindow and not a wxFrame.
23324ae1 701 */
adaaa686 702 wxWindow* GetFrame() const;
23324ae1
FM
703
704 /**
705 Gets the name associated with the view (passed to the wxDocTemplate
0c1fe6e9 706 constructor). Not currently used by the framework.
23324ae1 707 */
328f5751 708 wxString GetViewName() const;
23324ae1
FM
709
710 /**
711 Called when a view is activated by means of Activate(). The default
0c1fe6e9 712 implementation does nothing.
23324ae1 713 */
4cc4bfaf
FM
714 virtual void OnActivateView(bool activate, wxView* activeView,
715 wxView* deactiveView);
23324ae1
FM
716
717 /**
0c1fe6e9
BP
718 Called when the filename has changed. The default implementation
719 constructs a suitable title and sets the title of the view frame (if
720 any).
23324ae1
FM
721 */
722 virtual void OnChangeFilename();
723
724 /**
0c1fe6e9
BP
725 Implements closing behaviour. The default implementation calls
726 wxDocument::Close() to close the associated document. Does not delete
727 the view. The application may wish to do some cleaning up operations in
728 this function, @e if a call to wxDocument::Close() succeeded. For
729 example, if your views all share the same window, you need to
730 disassociate the window from the view and perhaps clear the window. If
731 @a deleteWindow is @true, delete the frame associated with the view.
23324ae1
FM
732 */
733 virtual bool OnClose(bool deleteWindow);
734
735 /**
0c1fe6e9 736 Override this to clean up the view when the document is being closed.
23324ae1
FM
737 */
738 virtual void OnClosingDocument();
739
740 /**
0c1fe6e9
BP
741 wxDocManager or wxDocument creates a wxView via a wxDocTemplate. Just
742 after the wxDocTemplate creates the wxView, it calls OnCreate(). The
743 wxView can create a wxDocChildFrame (or derived class) in its
744 wxView::OnCreate() member function. This wxDocChildFrame provides user
745 interface elements to view and/or edit the contents of the wxDocument.
746
23324ae1
FM
747 By default, simply returns @true. If the function returns @false, the
748 view will be deleted.
749 */
750 virtual bool OnCreate(wxDocument* doc, long flags);
751
752 /**
0c1fe6e9
BP
753 If the printing framework is enabled in the library, this function
754 returns a wxPrintout object for the purposes of printing. It should
755 create a new object every time it is called; the framework will delete
756 objects it creates.
757
758 By default, this function returns an instance of wxDocPrintout, which
759 prints and previews one page by calling OnDraw().
760
23324ae1
FM
761 Override to return an instance of a class other than wxDocPrintout.
762 */
763 virtual wxPrintout* OnCreatePrintout();
764
765 /**
766 Override this function to render the view on the given device context.
767 */
b91c4601 768 virtual void OnDraw(wxDC* dc) = 0;
23324ae1
FM
769
770 /**
0c1fe6e9
BP
771 Called when the view should be updated.
772
773 @param sender
774 A pointer to the wxView that sent the update request, or @NULL if
775 no single view requested the update (for instance, when the
776 document is opened).
777 @param hint
778 This is unused currently, but may in future contain
779 application-specific information for making updating more
780 efficient.
23324ae1 781 */
b91c4601 782 virtual void OnUpdate(wxView* sender, wxObject* hint = 0);
23324ae1
FM
783
784 /**
785 Associates the given document with the view. Normally called by the
786 framework.
787 */
adaaa686 788 virtual void SetDocument(wxDocument* doc);
23324ae1
FM
789
790 /**
0c1fe6e9
BP
791 Sets the frame associated with this view. The application should call
792 this if possible, to tell the view about the frame.
793
794 See GetFrame() for the explanation about the mismatch between the
795 "Frame" in the method name and the type of its parameter.
23324ae1
FM
796 */
797 void SetFrame(wxWindow* frame);
798
799 /**
800 Sets the view type name. Should only be called by the framework.
801 */
802 void SetViewName(const wxString& name);
803
804 /**
0c1fe6e9
BP
805 The document associated with this view. There may be more than one view
806 per document, but there can never be more than one document for one
807 view.
23324ae1 808 */
0c1fe6e9 809 wxDocument* m_viewDocument;
23324ae1
FM
810
811 /**
23324ae1
FM
812 Frame associated with the view, if any.
813 */
0c1fe6e9 814 wxFrame* m_viewFrame;
23324ae1
FM
815
816 /**
0c1fe6e9
BP
817 The view type name given to the wxDocTemplate constructor, copied to
818 this variable when the view is created. Not currently used by the
819 framework.
23324ae1 820 */
0c1fe6e9 821 wxString m_viewTypeName;
23324ae1
FM
822};
823
824
e54c96f1 825
23324ae1
FM
826/**
827 @class wxDocChildFrame
7c913512 828
23324ae1 829 The wxDocChildFrame class provides a default frame for displaying documents
0c1fe6e9
BP
830 on separate windows. This class can only be used for SDI (not MDI) child
831 frames.
7c913512 832
23324ae1 833 The class is part of the document/view framework supported by wxWidgets,
0c1fe6e9
BP
834 and cooperates with the wxView, wxDocument, wxDocManager and wxDocTemplate
835 classes.
7c913512 836
23324ae1 837 @library{wxcore}
0c1fe6e9 838 @category{docview}
7c913512 839
0c1fe6e9 840 @see @ref overview_docview, @ref page_samples_docview, wxFrame
23324ae1
FM
841*/
842class wxDocChildFrame : public wxFrame
843{
844public:
845 /**
846 Constructor.
847 */
848 wxDocChildFrame(wxDocument* doc, wxView* view, wxFrame* parent,
0c1fe6e9 849 wxWindowID id, const wxString& title,
23324ae1
FM
850 const wxPoint& pos = wxDefaultPosition,
851 const wxSize& size = wxDefaultSize,
852 long style = wxDEFAULT_FRAME_STYLE,
853 const wxString& name = "frame");
854
855 /**
856 Destructor.
857 */
adaaa686 858 virtual ~wxDocChildFrame();
23324ae1
FM
859
860 /**
861 Returns the document associated with this frame.
862 */
328f5751 863 wxDocument* GetDocument() const;
23324ae1
FM
864
865 /**
866 Returns the view associated with this frame.
867 */
328f5751 868 wxView* GetView() const;
23324ae1
FM
869
870 /**
0c1fe6e9
BP
871 Sets the currently active view to be the frame's view. You may need to
872 override (but still call) this function in order to set the keyboard
23324ae1
FM
873 focus for your subwindow.
874 */
b91c4601 875 void OnActivate(wxActivateEvent& event);
23324ae1
FM
876
877 /**
878 Closes and deletes the current view and document.
879 */
880 void OnCloseWindow(wxCloseEvent& event);
881
882 /**
883 Sets the document for this frame.
884 */
4cc4bfaf 885 void SetDocument(wxDocument* doc);
23324ae1
FM
886
887 /**
888 Sets the view for this frame.
889 */
4cc4bfaf 890 void SetView(wxView* view);
23324ae1
FM
891
892 /**
23324ae1
FM
893 The document associated with the frame.
894 */
0c1fe6e9 895 wxDocument* m_childDocument;
23324ae1
FM
896
897 /**
23324ae1
FM
898 The view associated with the frame.
899 */
0c1fe6e9 900 wxView* m_childView;
23324ae1
FM
901};
902
903
e54c96f1 904
23324ae1
FM
905/**
906 @class wxDocParentFrame
7c913512 907
23324ae1 908 The wxDocParentFrame class provides a default top-level frame for
0c1fe6e9
BP
909 applications using the document/view framework. This class can only be used
910 for SDI (not MDI) parent frames.
7c913512 911
0c1fe6e9
BP
912 It cooperates with the wxView, wxDocument, wxDocManager and wxDocTemplate
913 classes.
7c913512 914
23324ae1 915 @library{wxcore}
0c1fe6e9 916 @category{docview}
7c913512 917
0c1fe6e9 918 @see @ref overview_docview, @ref page_samples_docview, wxFrame
23324ae1
FM
919*/
920class wxDocParentFrame : public wxFrame
921{
922public:
23324ae1 923 /**
0c1fe6e9 924 Default constructor.
23324ae1
FM
925 */
926 wxDocParentFrame();
0c1fe6e9
BP
927 /**
928 Constructor.
929 */
4cc4bfaf 930 wxDocParentFrame(wxDocManager* manager, wxFrame* parent,
0c1fe6e9 931 wxWindowID id, const wxString& title,
7c913512
FM
932 const wxPoint& pos = wxDefaultPosition,
933 const wxSize& size = wxDefaultSize,
934 long style = wxDEFAULT_FRAME_STYLE,
935 const wxString& name = "frame");
23324ae1
FM
936
937 /**
938 Destructor.
939 */
adaaa686 940 virtual ~wxDocParentFrame();
23324ae1
FM
941
942 /**
943 Used in two-step construction.
944 */
b91c4601
FM
945 bool Create(wxDocManager* manager, wxFrame* parent, wxWindowID id,
946 const wxString& title, const wxPoint& pos = wxDefaultPosition,
947 const wxSize& size = wxDefaultSize, long style = 541072960,
948 const wxString& name = wxFrameNameStr);
23324ae1
FM
949
950 /**
0c1fe6e9 951 Returns the associated document manager object.
23324ae1 952 */
328f5751 953 wxDocManager* GetDocumentManager() const;
23324ae1
FM
954
955 /**
956 Deletes all views and documents. If no user input cancelled the
957 operation, the frame will be destroyed and the application will exit.
0c1fe6e9
BP
958 Since understanding how document/view clean-up takes place can be
959 difficult, the implementation of this function is shown below:
960
961 @code
962 void wxDocParentFrame::OnCloseWindow(wxCloseEvent& event)
963 {
964 if (m_docManager->Clear(!event.CanVeto()))
965 {
966 this->Destroy();
967 }
968 else
969 event.Veto();
970 }
971 @endcode
23324ae1
FM
972 */
973 void OnCloseWindow(wxCloseEvent& event);
974};
975
976
e54c96f1 977
23324ae1
FM
978/**
979 @class wxDocument
7c913512 980
0c1fe6e9
BP
981 The document class can be used to model an application's file-based data.
982 It is part of the document/view framework supported by wxWidgets, and
983 cooperates with the wxView, wxDocTemplate and wxDocManager classes.
7c913512 984
23324ae1 985 @library{wxcore}
0c1fe6e9 986 @category{docview}
7c913512 987
0c1fe6e9 988 @see @ref overview_docview, wxView, wxDocTemplate, wxDocManager
23324ae1
FM
989*/
990class wxDocument : public wxEvtHandler
991{
992public:
993 /**
994 Constructor. Define your own default constructor to initialize
0c1fe6e9 995 application-specific data.
23324ae1 996 */
b91c4601 997 wxDocument(wxDocument* parent = 0);
23324ae1
FM
998
999 /**
1000 Destructor. Removes itself from the document manager.
1001 */
adaaa686 1002 virtual ~wxDocument();
23324ae1
FM
1003
1004 /**
0c1fe6e9
BP
1005 If the view is not already in the list of views, adds the view and
1006 calls OnChangedViewList().
23324ae1 1007 */
4cc4bfaf 1008 virtual bool AddView(wxView* view);
23324ae1
FM
1009
1010 /**
0c1fe6e9
BP
1011 Closes the document, by calling OnSaveModified() and then (if this
1012 returned @true) OnCloseDocument(). This does not normally delete the
1013 document object, use DeleteAllViews() to do this implicitly.
23324ae1
FM
1014 */
1015 virtual bool Close();
1016
1017 /**
0c1fe6e9
BP
1018 Calls wxView::Close() and deletes each view. Deleting the final view
1019 will implicitly delete the document itself, because the wxView
1020 destructor calls RemoveView(). This in turns calls OnChangedViewList(),
1021 whose default implemention is to save and delete the document if no
1022 views exist.
23324ae1
FM
1023 */
1024 virtual bool DeleteAllViews();
1025
1026 /**
0c1fe6e9
BP
1027 Returns a pointer to the command processor associated with this
1028 document.
1029
1030 @see wxCommandProcessor
23324ae1 1031 */
adaaa686 1032 virtual wxCommandProcessor* GetCommandProcessor() const;
23324ae1
FM
1033
1034 /**
1035 Gets a pointer to the associated document manager.
1036 */
adaaa686 1037 virtual wxDocManager* GetDocumentManager() const;
23324ae1
FM
1038
1039 /**
1040 Gets the document type name for this document. See the comment for
0c1fe6e9 1041 @ref m_documentTypeName.
23324ae1 1042 */
328f5751 1043 wxString GetDocumentName() const;
23324ae1
FM
1044
1045 /**
1046 Gets a pointer to the template that created the document.
1047 */
adaaa686 1048 virtual wxDocTemplate* GetDocumentTemplate() const;
23324ae1
FM
1049
1050 /**
0c1fe6e9
BP
1051 Intended to return a suitable window for using as a parent for
1052 document-related dialog boxes. By default, uses the frame associated
1053 with the first view.
23324ae1 1054 */
adaaa686 1055 virtual wxWindow* GetDocumentWindow() const;
23324ae1
FM
1056
1057 /**
1058 Gets the filename associated with this document, or "" if none is
1059 associated.
1060 */
328f5751 1061 wxString GetFilename() const;
23324ae1
FM
1062
1063 /**
0c1fe6e9
BP
1064 A convenience function to get the first view for a document, because in
1065 many cases a document will only have a single view.
1066
1067 @see GetViews()
23324ae1 1068 */
328f5751 1069 wxView* GetFirstView() const;
23324ae1
FM
1070
1071 /**
0c1fe6e9
BP
1072 Gets the title for this document. The document title is used for an
1073 associated frame (if any), and is usually constructed by the framework
1074 from the filename.
23324ae1 1075 */
328f5751 1076 wxString GetTitle() const;
23324ae1
FM
1077
1078 /**
1079 Return the document name suitable to be shown to the user. The default
1080 implementation uses the document title, if any, of the name part of the
1081 document filename if it was set or, otherwise, the string @b unnamed.
1082 */
328f5751 1083 virtual wxString GetUserReadableName() const;
23324ae1
FM
1084
1085 /**
1086 Returns the list whose elements are the views on the document.
0c1fe6e9
BP
1087
1088 @see GetFirstView()
23324ae1 1089 */
328f5751 1090 wxList GetViews() const;
23324ae1
FM
1091
1092 /**
0c1fe6e9
BP
1093 Returns @true if the document has been modified since the last save,
1094 @false otherwise. You may need to override this if your document view
1095 maintains its own record of being modified.
1096
1097 @see Modify()
23324ae1 1098 */
328f5751 1099 virtual bool IsModified() const;
23324ae1
FM
1100
1101 //@{
1102 /**
0c1fe6e9
BP
1103 Override this function and call it from your own LoadObject() before
1104 streaming your own data. LoadObject() is called by the framework
23324ae1 1105 automatically when the document contents need to be loaded.
0c1fe6e9
BP
1106
1107 @note This version of LoadObject() may not exist depending on how
1108 wxWidgets was configured.
23324ae1 1109 */
0c1fe6e9
BP
1110 virtual istream& LoadObject(istream& stream);
1111 virtual wxInputStream& LoadObject(wxInputStream& stream);
23324ae1
FM
1112 //@}
1113
1114 /**
0c1fe6e9
BP
1115 Call with @true to mark the document as modified since the last save,
1116 @false otherwise. You may need to override this if your document view
1117 maintains its own record of being modified.
1118
1119 @see IsModified()
23324ae1
FM
1120 */
1121 virtual void Modify(bool modify);
1122
1123 /**
0c1fe6e9
BP
1124 Called when a view is added to or deleted from this document. The
1125 default implementation saves and deletes the document if no views exist
1126 (the last one has just been removed).
23324ae1
FM
1127 */
1128 virtual void OnChangedViewList();
1129
1130 /**
c6e4d276
VZ
1131 This virtual function is called when the document is being closed.
1132
0c1fe6e9 1133 The default implementation calls DeleteContents() (an empty
c6e4d276
VZ
1134 implementation) and sets the modified flag to @false. You can override
1135 it to supply additional behaviour when the document is closed with
1136 Close().
1137
1138 Notice that previous wxWidgets versions used to call this function also
1139 from OnNewDocument(), rather counter-intuitively. This is no longer the
1140 case since wxWidgets 2.9.0.
23324ae1
FM
1141 */
1142 virtual bool OnCloseDocument();
1143
1144 /**
0c1fe6e9
BP
1145 Called just after the document object is created to give it a chance to
1146 initialize itself. The default implementation uses the template
1147 associated with the document to create an initial view. If this
1148 function returns @false, the document is deleted.
23324ae1
FM
1149 */
1150 virtual bool OnCreate(const wxString& path, long flags);
1151
1152 /**
0c1fe6e9
BP
1153 Override this function if you want a different (or no) command
1154 processor to be created when the document is created. By default, it
1155 returns an instance of wxCommandProcessor.
1156
1157 @see wxCommandProcessor
23324ae1
FM
1158 */
1159 virtual wxCommandProcessor* OnCreateCommandProcessor();
1160
1161 /**
0c1fe6e9
BP
1162 The default implementation calls OnSaveModified() and DeleteContents(),
1163 makes a default title for the document, and notifies the views that the
1164 filename (in fact, the title) has changed.
23324ae1
FM
1165 */
1166 virtual bool OnNewDocument();
1167
1168 /**
0c1fe6e9
BP
1169 Constructs an input file stream for the given filename (which must not
1170 be empty), and calls LoadObject(). If LoadObject() returns @true, the
1171 document is set to unmodified; otherwise, an error message box is
1172 displayed. The document's views are notified that the filename has
1173 changed, to give windows an opportunity to update their titles. All of
1174 the document's views are then updated.
23324ae1
FM
1175 */
1176 virtual bool OnOpenDocument(const wxString& filename);
1177
1178 /**
0c1fe6e9
BP
1179 Constructs an output file stream for the given filename (which must not
1180 be empty), and calls SaveObject(). If SaveObject() returns @true, the
1181 document is set to unmodified; otherwise, an error message box is
1182 displayed.
23324ae1
FM
1183 */
1184 virtual bool OnSaveDocument(const wxString& filename);
1185
1186 /**
0c1fe6e9
BP
1187 If the document has been modified, prompts the user to ask if the
1188 changes should be changed. If the user replies Yes, the Save() function
1189 is called. If No, the document is marked as unmodified and the function
1190 succeeds. If Cancel, the function fails.
23324ae1
FM
1191 */
1192 virtual bool OnSaveModified();
1193
1194 /**
0c1fe6e9
BP
1195 Removes the view from the document's list of views, and calls
1196 OnChangedViewList().
23324ae1
FM
1197 */
1198 virtual bool RemoveView(wxView* view);
1199
1200 /**
0c1fe6e9
BP
1201 Saves the document by calling OnSaveDocument() if there is an
1202 associated filename, or SaveAs() if there is no filename.
23324ae1
FM
1203 */
1204 virtual bool Save();
1205
1206 /**
0c1fe6e9
BP
1207 Prompts the user for a file to save to, and then calls
1208 OnSaveDocument().
23324ae1
FM
1209 */
1210 virtual bool SaveAs();
1211
1212 //@{
1213 /**
0c1fe6e9
BP
1214 Override this function and call it from your own SaveObject() before
1215 streaming your own data. SaveObject() is called by the framework
23324ae1 1216 automatically when the document contents need to be saved.
0c1fe6e9
BP
1217
1218 @note This version of SaveObject() may not exist depending on how
1219 wxWidgets was configured.
23324ae1 1220 */
0c1fe6e9
BP
1221 virtual ostream& SaveObject(ostream& stream);
1222 virtual wxOutputStream& SaveObject(wxOutputStream& stream);
23324ae1
FM
1223 //@}
1224
1225 /**
0c1fe6e9
BP
1226 Sets the command processor to be used for this document. The document
1227 will then be responsible for its deletion. Normally you should not call
1228 this; override OnCreateCommandProcessor() instead.
1229
1230 @see wxCommandProcessor
23324ae1 1231 */
4cc4bfaf 1232 virtual void SetCommandProcessor(wxCommandProcessor* processor);
23324ae1
FM
1233
1234 /**
1235 Sets the document type name for this document. See the comment for
0c1fe6e9 1236 @ref m_documentTypeName.
23324ae1
FM
1237 */
1238 void SetDocumentName(const wxString& name);
1239
1240 /**
0c1fe6e9
BP
1241 Sets the pointer to the template that created the document. Should only
1242 be called by the framework.
23324ae1 1243 */
adaaa686 1244 virtual void SetDocumentTemplate(wxDocTemplate* templ);
23324ae1
FM
1245
1246 /**
1247 Sets the filename for this document. Usually called by the framework.
0c1fe6e9
BP
1248
1249 If @a notifyViews is @true, wxView::OnChangeFilename() is called for
1250 all views.
23324ae1 1251 */
0c1fe6e9 1252 void SetFilename(const wxString& filename, bool notifyViews = false);
23324ae1
FM
1253
1254 /**
0c1fe6e9
BP
1255 Sets the title for this document. The document title is used for an
1256 associated frame (if any), and is usually constructed by the framework
1257 from the filename.
23324ae1
FM
1258 */
1259 void SetTitle(const wxString& title);
1260
1261 /**
0c1fe6e9
BP
1262 Updates all views. If @a sender is non-@NULL, does not update this
1263 view. @a hint represents optional information to allow a view to
1264 optimize its update.
23324ae1 1265 */
adaaa686 1266 virtual void UpdateAllViews(wxView* sender = NULL, wxObject* hint = NULL);
23324ae1 1267
0bbe61b8
VZ
1268protected:
1269 /**
1270 This method is called by OnSaveDocument() to really save the document
1271 contents to the specified file.
1272
1273 Base class version creates a file-based stream and calls SaveObject().
1274 Override this if you need to do something else or prefer not to use
1275 SaveObject() at all.
1276 */
1277 virtual bool DoSaveDocument(const wxString& file);
1278
1279 /**
1280 This method is called by OnOpenDocument() to really load the document
1281 contents from the specified file.
1282
1283 Base class version creates a file-based stream and calls LoadObject().
1284 Override this if you need to do something else or prefer not to use
1285 LoadObject() at all.
1286 */
1287 virtual bool DoOpenDocument(const wxString& file);
1288
23324ae1 1289 /**
23324ae1
FM
1290 A pointer to the command processor associated with this document.
1291 */
0c1fe6e9 1292 wxCommandProcessor* m_commandProcessor;
23324ae1
FM
1293
1294 /**
23324ae1
FM
1295 Filename associated with this document ("" if none).
1296 */
0c1fe6e9 1297 wxString m_documentFile;
23324ae1
FM
1298
1299 /**
23324ae1
FM
1300 @true if the document has been modified, @false otherwise.
1301 */
0c1fe6e9 1302 bool m_documentModified;
23324ae1
FM
1303
1304 /**
23324ae1
FM
1305 A pointer to the template from which this document was created.
1306 */
0c1fe6e9 1307 wxDocTemplate* m_documentTemplate;
23324ae1
FM
1308
1309 /**
0c1fe6e9
BP
1310 Document title. The document title is used for an associated frame (if
1311 any), and is usually constructed by the framework from the filename.
23324ae1 1312 */
0c1fe6e9 1313 wxString m_documentTitle;
23324ae1
FM
1314
1315 /**
0c1fe6e9
BP
1316 The document type name given to the wxDocTemplate constructor, copied
1317 to this variable when the document is created. If several document
1318 templates are created that use the same document type, this variable is
1319 used in wxDocManager::CreateView() to collate a list of alternative
1320 view types that can be used on this kind of document. Do not change the
1321 value of this variable.
23324ae1 1322 */
0c1fe6e9 1323 wxString m_documentTypeName;
23324ae1
FM
1324
1325 /**
23324ae1
FM
1326 List of wxView instances associated with this document.
1327 */
0c1fe6e9 1328 wxList m_documentViews;
23324ae1
FM
1329};
1330
1331
e54c96f1 1332
23324ae1
FM
1333/**
1334 @class wxFileHistory
7c913512 1335
0c1fe6e9
BP
1336 The wxFileHistory encapsulates a user interface convenience, the list of
1337 most recently visited files as shown on a menu (usually the File menu).
7c913512 1338
23324ae1 1339 wxFileHistory can manage one or more file menus. More than one menu may be
0c1fe6e9
BP
1340 required in an MDI application, where the file history should appear on
1341 each MDI child menu as well as the MDI parent frame.
7c913512 1342
23324ae1 1343 @library{wxcore}
0c1fe6e9 1344 @category{docview}
7c913512 1345
0c1fe6e9 1346 @see @ref overview_docview, wxDocManager
23324ae1
FM
1347*/
1348class wxFileHistory : public wxObject
1349{
1350public:
1351 /**
1352 Constructor. Pass the maximum number of files that should be stored and
1353 displayed.
0c1fe6e9
BP
1354
1355 @a idBase defaults to wxID_FILE1 and represents the id given to the
1356 first history menu item. Since menu items can't share the same ID you
1357 should change @a idBase (to one of your own defined IDs) when using
1358 more than one wxFileHistory in your application.
23324ae1 1359 */
0c1fe6e9 1360 wxFileHistory(size_t maxFiles = 9, wxWindowID idBase = wxID_FILE1);
23324ae1
FM
1361
1362 /**
1363 Destructor.
1364 */
adaaa686 1365 virtual ~wxFileHistory();
23324ae1
FM
1366
1367 /**
1368 Adds a file to the file history list, if the object has a pointer to an
1369 appropriate file menu.
1370 */
adaaa686 1371 virtual void AddFileToHistory(const wxString& filename);
23324ae1 1372
23324ae1 1373 /**
0c1fe6e9
BP
1374 Appends the files in the history list, to all menus managed by the file
1375 history object.
23324ae1 1376 */
adaaa686 1377 virtual void AddFilesToMenu();
0c1fe6e9
BP
1378 /**
1379 Appends the files in the history list, to the given menu only.
1380 */
adaaa686 1381 virtual void AddFilesToMenu(wxMenu* menu);
23324ae1
FM
1382
1383 /**
1384 Returns the base identifier for the range used for appending items.
1385 */
328f5751 1386 wxWindowID GetBaseId() const;
23324ae1
FM
1387
1388 /**
1389 Returns the number of files currently stored in the file history.
1390 */
adaaa686 1391 virtual size_t GetCount() const;
23324ae1
FM
1392
1393 /**
1394 Returns the file at this index (zero-based).
1395 */
adaaa686 1396 virtual wxString GetHistoryFile(size_t index) const;
23324ae1
FM
1397
1398 /**
1399 Returns the maximum number of files that can be stored.
1400 */
adaaa686 1401 virtual int GetMaxFiles() const;
23324ae1
FM
1402
1403 /**
1404 Returns the list of menus that are managed by this file history object.
3c4f71cc 1405
4cc4bfaf 1406 @see UseMenu()
23324ae1 1407 */
0c1fe6e9 1408 const wxList& GetMenus() const;
23324ae1
FM
1409
1410 /**
0c1fe6e9
BP
1411 Loads the file history from the given config object. This function
1412 should be called explicitly by the application.
3c4f71cc 1413
0c1fe6e9 1414 @see wxConfigBase
23324ae1 1415 */
adaaa686 1416 virtual void Load(const wxConfigBase& config);
23324ae1
FM
1417
1418 /**
1419 Removes the specified file from the history.
1420 */
adaaa686 1421 virtual void RemoveFileFromHistory(size_t i);
23324ae1
FM
1422
1423 /**
1424 Removes this menu from the list of those managed by this object.
1425 */
adaaa686 1426 virtual void RemoveMenu(wxMenu* menu);
23324ae1
FM
1427
1428 /**
0c1fe6e9
BP
1429 Saves the file history into the given config object. This must be
1430 called explicitly by the application.
3c4f71cc 1431
0c1fe6e9 1432 @see wxConfigBase
23324ae1 1433 */
adaaa686 1434 virtual void Save(wxConfigBase& config);
23324ae1
FM
1435
1436 /**
1437 Sets the base identifier for the range used for appending items.
1438 */
1439 void SetBaseId(wxWindowID baseId);
1440
1441 /**
0c1fe6e9
BP
1442 Adds this menu to the list of those menus that are managed by this file
1443 history object. Also see AddFilesToMenu() for initializing the menu
1444 with filenames that are already in the history when this function is
1445 called, as this is not done automatically.
23324ae1 1446 */
adaaa686 1447 virtual void UseMenu(wxMenu* menu);
23324ae1
FM
1448
1449 /**
23324ae1
FM
1450 A character array of strings corresponding to the most recently opened
1451 files.
1452 */
0c1fe6e9 1453 char** m_fileHistory;
23324ae1
FM
1454
1455 /**
23324ae1
FM
1456 The number of files stored in the history array.
1457 */
0c1fe6e9 1458 size_t m_fileHistoryN;
23324ae1
FM
1459
1460 /**
23324ae1
FM
1461 The maximum number of files to be stored and displayed on the menu.
1462 */
0c1fe6e9 1463 size_t m_fileMaxFiles;
23324ae1
FM
1464
1465 /**
23324ae1
FM
1466 The file menu used to display the file history list (if enabled).
1467 */
0c1fe6e9 1468 wxMenu* m_fileMenu;
23324ae1
FM
1469};
1470
1471
e54c96f1 1472
23324ae1
FM
1473// ============================================================================
1474// Global functions/macros
1475// ============================================================================
1476
1ba0de2e
BP
1477/** @ingroup group_funcmacro_file */
1478//@{
1479
23324ae1 1480/**
1ba0de2e
BP
1481 Copies the given file to @a stream. Useful when converting an old
1482 application to use streams (within the document/view framework, for
1483 example).
1484
1485 @header{wx/docview.h}
23324ae1
FM
1486*/
1487bool wxTransferFileToStream(const wxString& filename,
1488 ostream& stream);
1489
1ba0de2e
BP
1490/**
1491 Copies the given stream to the file @a filename. Useful when converting an
1492 old application to use streams (within the document/view framework, for
1493 example).
1494
1495 @header{wx/docview.h}
1496*/
1497bool wxTransferStreamToFile(istream& stream,
1498 const wxString& filename);
1499
1500//@}
1501