Sophie

Sophie

distrib > Mandriva > 10.0-com > i586 > by-pkgid > af7a4b7f1ee5a4a084c41b9005da5527 > files > 1600

libfox1.1_46-devel-1.1.46-1mdk.i586.rpm

<html>
<head>
<link rel="stylesheet" href="page.css" type="text/css">
<title>fox-toolkit.org - Documentation</title>
</head>
<body bgcolor=#ffffff link=#990033 vlink=#990033 alink=#990033 text=#000000>
<font face='verdana,sans-serif' size=2 >

<!---- TOPIC TITLE WITH LOGO--->
<table border=0 cellpadding= cellspacing=2 width=100% ><tr><td><a href='http://www.fox-toolkit.org/doc.html'><img src='../art/foxlogo_small.jpg' border=0></a></td><td width=100% valign=bottom><font face='verdana,sans-serif' size=2 ><b>
<a class="qindex" href="index.html">Main Page</a> &nbsp; <a class="qindex" href="hierarchy.html">Class Hierarchy</a> &nbsp; <a class="qindex" href="classes.html">Alphabetical List</a> &nbsp; <a class="qindex" href="annotated.html">Compound List</a> &nbsp; <a class="qindex" href="files.html">File List</a> &nbsp; <a class="qindex" href="functions.html">Compound Members</a>
<br><img src='../art/line.gif' width=100% height=1></b></font></td></tr></table>
<p>
<!--- TOPIC TITLE WITH LOGO --->
<!-- Generated by Doxygen 1.3.3 -->
<h1>FXUndoList.h</h1><div class="fragment"><pre>00001 <span class="comment">/********************************************************************************</span>
00002 <span class="comment">*                                                                               *</span>
00003 <span class="comment">*                  U n d o / R e d o - a b l e   C o m m a n d                  *</span>
00004 <span class="comment">*                                                                               *</span>
00005 <span class="comment">*********************************************************************************</span>
00006 <span class="comment">* Copyright (C) 2000,2004 by Jeroen van der Zijp.   All Rights Reserved.        *</span>
00007 <span class="comment">*********************************************************************************</span>
00008 <span class="comment">* This library is free software; you can redistribute it and/or                 *</span>
00009 <span class="comment">* modify it under the terms of the GNU Lesser General Public                    *</span>
00010 <span class="comment">* License as published by the Free Software Foundation; either                  *</span>
00011 <span class="comment">* version 2.1 of the License, or (at your option) any later version.            *</span>
00012 <span class="comment">*                                                                               *</span>
00013 <span class="comment">* This library is distributed in the hope that it will be useful,               *</span>
00014 <span class="comment">* but WITHOUT ANY WARRANTY; without even the implied warranty of                *</span>
00015 <span class="comment">* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU             *</span>
00016 <span class="comment">* Lesser General Public License for more details.                               *</span>
00017 <span class="comment">*                                                                               *</span>
00018 <span class="comment">* You should have received a copy of the GNU Lesser General Public              *</span>
00019 <span class="comment">* License along with this library; if not, write to the Free Software           *</span>
00020 <span class="comment">* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA.    *</span>
00021 <span class="comment">*********************************************************************************</span>
00022 <span class="comment">* $Id: FXUndoList.h,v 1.33 2004/02/08 17:17:34 fox Exp $                        *</span>
00023 <span class="comment">********************************************************************************/</span>
00024 <span class="preprocessor">#ifndef FXUNDOLIST_H</span>
00025 <span class="preprocessor"></span><span class="preprocessor">#define FXUNDOLIST_H</span>
00026 <span class="preprocessor"></span>
00027 <span class="preprocessor">#ifndef FXOBJECT_H</span>
00028 <span class="preprocessor"></span><span class="preprocessor">#include "FXObject.h"</span>
00029 <span class="preprocessor">#endif</span>
00030 <span class="preprocessor"></span>
00031 <span class="keyword">namespace </span>FX {
00032 
00033 
00034 <span class="keyword">class </span>FXUndoList;
00035 <span class="keyword">class </span>FXCommandGroup;
00036 
00037 <span class="comment"></span>
00038 <span class="comment">/**</span>
00039 <span class="comment">* Base class for undoable commands.  Each undo records all the</span>
00040 <span class="comment">* information necessary to undo as well as redo a given operation.</span>
00041 <span class="comment">* Since commands are derived from FXObject, subclassed commands can</span>
00042 <span class="comment">* both send and receive messages (like ID_GETINTVALUE, for example).</span>
00043 <span class="comment">*/</span>
<a name="l00044"></a><a class="code" href="classFX_1_1FXCommand.html">00044</a> <span class="keyword">class </span>FXAPI FXCommand : <span class="keyword">public</span> <a class="code" href="classFX_1_1FXObject.html">FXObject</a> {
00045   FXDECLARE_ABSTRACT(FXCommand)
00046   <span class="keyword">friend</span> <span class="keyword">class </span><a class="code" href="classFX_1_1FXUndoList.html">FXUndoList</a>;
00047   <span class="keyword">friend</span> <span class="keyword">class </span><a class="code" href="classFX_1_1FXCommandGroup.html">FXCommandGroup</a>;
00048 <span class="keyword">private</span>:
00049   FXCommand *next;
00050 <span class="keyword">private</span>:
00051   FXCommand(<span class="keyword">const</span> FXCommand&amp;);
00052   FXCommand &amp;operator=(<span class="keyword">const</span> FXCommand&amp;);
00053 <span class="keyword">protected</span>:
00054   FXCommand():next(NULL){}
00055 <span class="keyword">public</span>:
00056 <span class="comment"></span>
00057 <span class="comment">  /**</span>
00058 <span class="comment">  * Undo this command; this should save the</span>
00059 <span class="comment">  * information for a subsequent redo.</span>
00060 <span class="comment">  */</span>
00061   <span class="keyword">virtual</span> <span class="keywordtype">void</span> undo() = 0;
00062 <span class="comment"></span>
00063 <span class="comment">  /**</span>
00064 <span class="comment">  * Redo this command; this should save the</span>
00065 <span class="comment">  * information for a subsequent undo.</span>
00066 <span class="comment">  */</span>
00067   <span class="keyword">virtual</span> <span class="keywordtype">void</span> redo() = 0;
00068 <span class="comment"></span>
00069 <span class="comment">  /**</span>
00070 <span class="comment">  * Return the size of the information in the undo record.</span>
00071 <span class="comment">  * The undo list may be trimmed to limit memory usage to</span>
00072 <span class="comment">  * a certain limit.  The value returned should include</span>
00073 <span class="comment">  * the size of the command record itself as well as any</span>
00074 <span class="comment">  * data linked from it.</span>
00075 <span class="comment">  */</span>
00076   <span class="keyword">virtual</span> FXuint size() <span class="keyword">const</span>;
00077 <span class="comment"></span>
00078 <span class="comment">  /**</span>
00079 <span class="comment">  * Name of the undo command to be shown on a button;</span>
00080 <span class="comment">  * for example, "Undo Delete".</span>
00081 <span class="comment">  */</span>
00082   <span class="keyword">virtual</span> <a class="code" href="classFX_1_1FXString.html">FXString</a> undoName() <span class="keyword">const</span>;
00083 <span class="comment"></span>
<a name="l00084"></a><a class="code" href="classFX_1_1FXCommand.html#a5">00084</a> <span class="comment">  /**</span>
00085 <span class="comment">  * Name of the redo command to be shown on a button;</span>
00086 <span class="comment">  * for example, "Redo Delete".</span>
00087 <span class="comment">  */</span>
00088   <span class="keyword">virtual</span> <a class="code" href="classFX_1_1FXString.html">FXString</a> redoName() <span class="keyword">const</span>;
00089 <span class="comment"></span>
00090 <span class="comment">  /// Delete undo command</span>
00091 <span class="comment"></span>  <span class="keyword">virtual</span> ~FXCommand(){}
00092   };
00093 
00094 
<a name="l00095"></a><a class="code" href="classFX_1_1FXCommandGroup.html">00095</a> <span class="comment"></span>
00096 <span class="comment">/**</span>
00097 <span class="comment">* Group of undoable commands.  A group may comprise multiple</span>
00098 <span class="comment">* individual actions which together undo (or redo) a larger</span>
00099 <span class="comment">* operation.  Even larger operations may be built by nesting</span>
00100 <span class="comment">* multiple undo groups.</span>
<a name="l00101"></a><a class="code" href="classFX_1_1FXCommandGroup.html#a0">00101</a> <span class="comment">*/</span>
00102 <span class="keyword">class </span>FXAPI FXCommandGroup : <span class="keyword">public</span> FXCommand {
00103   FXDECLARE(FXCommandGroup)
<a name="l00104"></a><a class="code" href="classFX_1_1FXCommandGroup.html#a1">00104</a>   <span class="keyword">friend</span> <span class="keyword">class </span><a class="code" href="classFX_1_1FXUndoList.html">FXUndoList</a>;
00105 <span class="keyword">private</span>:
00106   FXCommand      *undolist;
00107   FXCommand      *redolist;
00108   FXCommandGroup *group;
00109 <span class="keyword">private</span>:
00110   FXCommandGroup(<span class="keyword">const</span> FXCommandGroup&amp;);
00111   FXCommandGroup &amp;operator=(<span class="keyword">const</span> FXCommandGroup&amp;);
00112 <span class="keyword">public</span>:
00113 <span class="comment"></span>
00114 <span class="comment">  /// Construct initially empty undo command group</span>
00115 <span class="comment"></span>  FXCommandGroup():undolist(NULL),redolist(NULL),group(NULL){}
00116 <span class="comment"></span>
00117 <span class="comment">  /// Return TRUE if empty</span>
00118 <span class="comment"></span>  FXbool empty(){ <span class="keywordflow">return</span> !undolist; }
00119 <span class="comment"></span>
00120 <span class="comment">  /// Undo whole command group</span>
00121 <span class="comment"></span>  <span class="keyword">virtual</span> <span class="keywordtype">void</span> undo();
00122 <span class="comment"></span>
00123 <span class="comment">  /// Redo whole command group</span>
<a name="l00124"></a><a class="code" href="classFX_1_1FXUndoList.html">00124</a> <span class="comment"></span>  <span class="keyword">virtual</span> <span class="keywordtype">void</span> redo();
00125 <span class="comment"></span>
00126 <span class="comment">  /// Return the size of the command group</span>
00127 <span class="comment"></span>  <span class="keyword">virtual</span> FXuint size() <span class="keyword">const</span>;
00128 <span class="comment"></span>
00129 <span class="comment">  /// Delete undo command and sub-commands</span>
00130 <span class="comment"></span>  <span class="keyword">virtual</span> ~FXCommandGroup();
00131   };
00132 
00133 
00134 <span class="comment"></span>
00135 <span class="comment">/**</span>
00136 <span class="comment">* The Undo List class manages a list of undoable commands.</span>
00137 <span class="comment">*/</span>
00138 <span class="keyword">class </span>FXAPI FXUndoList : <span class="keyword">public</span> FXCommandGroup {
00139   FXDECLARE(FXUndoList)
00140 <span class="keyword">private</span>:
00141   FXint      undocount;     <span class="comment">// Number of undo records</span>
00142   FXint      redocount;     <span class="comment">// Number of redo records</span>
00143   FXint      marker;        <span class="comment">// Marker value</span>
00144   FXuint     space;         <span class="comment">// Space taken up by all the undo records</span>
00145   FXbool     working;       <span class="comment">// Currently busy with undo or redo</span>
00146 <span class="keyword">private</span>:
00147   FXUndoList(<span class="keyword">const</span> FXUndoList&amp;);
00148   FXUndoList &amp;operator=(<span class="keyword">const</span> FXUndoList&amp;);
00149 <span class="keyword">public</span>:
00150   <span class="keywordtype">long</span> onCmdUndo(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00151   <span class="keywordtype">long</span> onUpdUndo(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00152   <span class="keywordtype">long</span> onCmdRedo(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00153   <span class="keywordtype">long</span> onUpdRedo(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00154   <span class="keywordtype">long</span> onCmdClear(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00155   <span class="keywordtype">long</span> onUpdClear(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00156   <span class="keywordtype">long</span> onCmdRevert(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00157   <span class="keywordtype">long</span> onUpdRevert(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00158   <span class="keywordtype">long</span> onCmdUndoAll(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00159   <span class="keywordtype">long</span> onCmdRedoAll(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00160   <span class="keywordtype">long</span> onUpdUndoCount(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00161   <span class="keywordtype">long</span> onUpdRedoCount(FXObject*,FXSelector,<span class="keywordtype">void</span>*);
00162 <span class="keyword">public</span>:
00163   <span class="keyword">enum</span>{
00164     ID_CLEAR=FXWindow::ID_LAST,
00165     ID_REVERT,
00166     ID_UNDO,
00167     ID_REDO,
00168     ID_UNDO_ALL,
00169     ID_REDO_ALL,
00170     ID_UNDO_COUNT,
00171     ID_REDO_COUNT,
00172     ID_LAST
00173     };
00174 <span class="keyword">public</span>:
00175 <span class="comment"></span>
00176 <span class="comment">  /**</span>
00177 <span class="comment">  * Make new empty undo list, initially unmarked.</span>
00178 <span class="comment">  */</span>
00179   FXUndoList();
00180 <span class="comment"></span>
00181 <span class="comment">  /**</span>
00182 <span class="comment">  * Cut the redo list.</span>
00183 <span class="comment">  * This is automatically invoked when a new undo command is added.</span>
00184 <span class="comment">  */</span>
00185   <span class="keywordtype">void</span> cut();
00186 <span class="comment"></span>
00187 <span class="comment">  /**</span>
00188 <span class="comment">  * Add new command, executing it if desired. The new command</span>
00189 <span class="comment">  * will be appended after the last undo command.  All redo commands</span>
00190 <span class="comment">  * will be deleted.</span>
00191 <span class="comment">  */</span>
00192   <span class="keywordtype">void</span> add(FXCommand* command,FXbool doit=FALSE);
00193 <span class="comment"></span>
00194 <span class="comment">  /**</span>
00195 <span class="comment">  * Begin undo command sub-group. This begins a new group of commands that</span>
00196 <span class="comment">  * are treated as a single command.  Must eventually be followed by a</span>
00197 <span class="comment">  * matching end() after recording the sub-commands.  The new sub-group</span>
00198 <span class="comment">  * will be appended to its parent group's undo list when end() is called.</span>
00199 <span class="comment">  */</span>
00200   <span class="keywordtype">void</span> begin(FXCommandGroup *command);
00201 <span class="comment"></span>
00202 <span class="comment">  /**</span>
00203 <span class="comment">  * End undo command sub-group.  If the sub-group is still empty, it will</span>
00204 <span class="comment">  * be deleted; otherwise, the sub-group will be added as a new command</span>
00205 <span class="comment">  * into parent group.</span>
00206 <span class="comment">  * A matching begin() must have been called previously.</span>
00207 <span class="comment">  */</span>
00208   <span class="keywordtype">void</span> end();
00209 <span class="comment"></span>
00210 <span class="comment">  /**</span>
00211 <span class="comment">  * Abort the current command sub-group being compiled.  All commands</span>
00212 <span class="comment">  * already added to the sub-groups undo list will be discarded.</span>
00213 <span class="comment">  * Intermediate command groups will be left intact.</span>
00214 <span class="comment">  */</span>
00215   <span class="keywordtype">void</span> abort();
00216 <span class="comment"></span>
00217 <span class="comment">  /**</span>
00218 <span class="comment">  * Undo last command. This will move the command to the redo list.</span>
00219 <span class="comment">  */</span>
00220   <span class="keyword">virtual</span> <span class="keywordtype">void</span> undo();
00221 <span class="comment"></span>
00222 <span class="comment">  /**</span>
00223 <span class="comment">  * Redo next command. This will move the command back to the undo list.</span>
00224 <span class="comment">  */</span>
00225   <span class="keyword">virtual</span> <span class="keywordtype">void</span> redo();
00226 <span class="comment"></span>
<a name="l00227"></a><a class="code" href="classFX_1_1FXUndoList.html#a14">00227</a> <span class="comment">  /// Undo all commands</span>
00228 <span class="comment"></span>  <span class="keywordtype">void</span> undoAll();
00229 <span class="comment"></span>
<a name="l00230"></a><a class="code" href="classFX_1_1FXUndoList.html#a15">00230</a> <span class="comment">  /// Redo all commands</span>
00231 <span class="comment"></span>  <span class="keywordtype">void</span> redoAll();
00232 <span class="comment"></span>
00233 <span class="comment">  /// Revert to marked</span>
00234 <span class="comment"></span>  <span class="keywordtype">void</span> revert();
00235 <span class="comment"></span>
00236 <span class="comment">  /// Can we undo more commands</span>
00237 <span class="comment"></span>  FXbool canUndo() <span class="keyword">const</span>;
00238 <span class="comment"></span>
00239 <span class="comment">  /// Can we redo more commands</span>
00240 <span class="comment"></span>  FXbool canRedo() <span class="keyword">const</span>;
00241 <span class="comment"></span>
00242 <span class="comment">  /// Can revert to marked</span>
00243 <span class="comment"></span>  FXbool canRevert() <span class="keyword">const</span>;
00244 <span class="comment"></span>
<a name="l00245"></a><a class="code" href="classFX_1_1FXUndoList.html#a18">00245</a> <span class="comment">  /**</span>
00246 <span class="comment">  * Return TRUE if currently inside undo or redo operation; this</span>
00247 <span class="comment">  * is useful to avoid generating another undo command while inside</span>
<a name="l00248"></a><a class="code" href="classFX_1_1FXUndoList.html#a19">00248</a> <span class="comment">  * an undo operation.</span>
00249 <span class="comment">  */</span>
00250   FXbool busy()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> working; }
00251 <span class="comment"></span>
00252 <span class="comment">  /// Current top level undo command</span>
00253 <span class="comment"></span>  FXCommand* current()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> undolist; }
00254 <span class="comment"></span>
00255 <span class="comment">  /**</span>
00256 <span class="comment">  * Return name of the first undo command available; if no</span>
00257 <span class="comment">  * undo command available this will return the empty string.</span>
00258 <span class="comment">  */</span>
00259   <span class="keyword">virtual</span> FXString undoName() <span class="keyword">const</span>;
00260 <span class="comment"></span>
00261 <span class="comment">  /**</span>
00262 <span class="comment">  * Return name of the first redo command available; if no</span>
00263 <span class="comment">  * Redo command available this will return the empty string.</span>
00264 <span class="comment">  */</span>
00265   <span class="keyword">virtual</span> FXString redoName() <span class="keyword">const</span>;
00266 <span class="comment"></span>
00267 <span class="comment">  /// Number of undo records</span>
00268 <span class="comment"></span>  FXint undoCount()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> undocount; }
00269 <span class="comment"></span>
00270 <span class="comment">  /// Number of redo records</span>
00271 <span class="comment"></span>  FXint redoCount()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> redocount; }
00272 <span class="comment"></span>
00273 <span class="comment">  /// Size of undo information</span>
00274 <span class="comment"></span>  <span class="keyword">virtual</span> FXuint size() <span class="keyword">const</span>;
00275 <span class="comment"></span>
00276 <span class="comment">  /**</span>
00277 <span class="comment">  * Clear list, and unmark all states.</span>
00278 <span class="comment">  * All undo and redo information will be destroyed.</span>
00279 <span class="comment">  */</span>
00280   <span class="keywordtype">void</span> clear();
00281 <span class="comment"></span>
00282 <span class="comment">  /**</span>
00283 <span class="comment">  * Trim undo list down to at most nc commands.</span>
00284 <span class="comment">  * Call this periodically to prevent the undo-list from growing</span>
00285 <span class="comment">  * beyond a certain number of records.</span>
00286 <span class="comment">  */</span>
00287   <span class="keywordtype">void</span> trimCount(FXint nc);
00288 <span class="comment"></span>
00289 <span class="comment">  /**</span>
00290 <span class="comment">  * Trim undo list down to at most size sz.</span>
00291 <span class="comment">  * Call this periodically to prevent the undo-list from growing</span>
00292 <span class="comment">  * beyond a certain amount of memory.</span>
00293 <span class="comment">  */</span>
00294   <span class="keywordtype">void</span> trimSize(FXuint sz);
00295 <span class="comment"></span>
00296 <span class="comment">  /**</span>
00297 <span class="comment">  * Mark the current state of the undo list, which is initially unmarked.</span>
00298 <span class="comment">  * There can be only one active mark at any time.  Call mark() at any</span>
00299 <span class="comment">  * time when you know the document to be "clean"; for example when you</span>
00300 <span class="comment">  * save the document to disk.</span>
00301 <span class="comment">  */</span>
00302   <span class="keywordtype">void</span> mark();
00303 <span class="comment"></span>
00304 <span class="comment">  /**</span>
00305 <span class="comment">  * Unmark all states in the undo list.</span>
00306 <span class="comment">  */</span>
00307   <span class="keywordtype">void</span> unmark();
00308 <span class="comment"></span>
00309 <span class="comment">  /**</span>
00310 <span class="comment">  * Check if the current state was marked, if the application has returned</span>
00311 <span class="comment">  * to the previously marked state.</span>
00312 <span class="comment">  */</span>
00313   FXbool marked() <span class="keyword">const</span>;
00314   };
00315 
00316 
00317 }
00318 
00319 <span class="preprocessor">#endif</span>
</pre></div></font>

<!--- COPYRIGHT -->
<p>
<table width=100% cellpadding=0 cellspacing=0><tr><td width=100% valign=top id=HEADLINE align=right>
<img src='../art/line.gif' width=100% height=1><font size=-1>
Copyright &copy; 1997-2004 Jeroen van der Zijp</font>
</td></tr></table>
</p>
<!--- COPYRIGHT -->
</body>
</html>