libs-base/Headers/Foundation/NSUndoManager.h

147 lines
4.1 KiB
C
Raw Normal View History

/* Interface for <NSUndoManager> for GNUStep
Copyright (C) 1998 Free Software Foundation, Inc.
Written by: Richard Frith-Macdonald <richard@brainstorm.co.uk>
This file is part of the GNUstep Base Library.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free
Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02111 USA.
*/
#ifndef __NSUndoManager_h_OBJECTS_INCLUDE
#define __NSUndoManager_h_OBJECTS_INCLUDE
#import <GNUstepBase/GSVersionMacros.h>
#if OS_API_VERSION(GS_API_MACOSX, GS_API_LATEST)
#import <Foundation/NSObject.h>
#if defined(__cplusplus)
extern "C" {
#endif
@class NSArray;
@class NSString;
@class NSMutableArray;
@class NSInvocation;
* Headers/gnustep/base/NSUndoManager.h: Add NSUndoCloseGroupingRunLoopOrdering enum. Replace instance variables _registeredUndo with _runLoopGroupingPending and _actionName with _unused1. * Source/NSUndoManager.m: Added documentation. Added actionName instance variable to PrivateUndoGroup. (-[PrivateUndoGroup actionName]): New method. (-[PrivateUndoGroup setActionName]): Ditto. (-[PrivateUndoGroup dealloc]): Release new instance variable. (-[PrivateUndoGroup initWithParent:]): Initialize actionName. (-[NSUndoManager forwardInvocation]): Implicitly call beginUndoGrouping if group has not been setup and we are grouping by events. Register _loop: invocation if none is already pending and if we are grouping by event. (-[NSUndoManager registerUndoWithTarget:selector:object]): Ditto. (-[NSUndoManager methodSignatureForSelector:]): Overriden to forward request to target supplied by -prepareWithInvocationTarget: if available. (-[NSUndoManager _loop:]): Set flag to determine pending _loop: processing. (-[NSUndoManager init]): Removed access to _actionName. Have receiver default to group by event. (-[NSUndoManager dealloc]): Ditto. (-[NSUndoManager enableUndoRegistration]): Remove access to _registeredUndo. (-[NSUndoManager redo]): Simplified implementation. (-[NSUndoManager redoActionName:]: Retrieve action name from first grouping of the redo stack. (-[NSUndoManager redoMenuTitleForUndoActionName:]): Add comment about localization. (-[NSUndoManager undoMenuTitleForUndoActionName:]): Ditto. (-[NSUndoManager setActionName:]): Forward call to current grouping. (-[NSUndoManager undoActionName:]: Retrieve action name from first grouping of the undo stack. (-[NSUndoManager setRunLoopModes:]): Use correct run loop ordering and set flag for pending _loop: invocation. (-[NSUndoManager undoNestedGroup]): Removed special case handling of _registeredUndo. Raise NSInternalInconsistencyException if grouping is still in progress. Simplified implementation. git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@17221 72102866-910b-0410-8b05-ffd578937521
2003-07-15 11:56:22 +00:00
/** Defines run loop ordering for closing undo groupings. */
enum {
NSUndoCloseGroupingRunLoopOrdering = 350000
};
/* Public notification */
/**
* Notification posted whenever [NSUndoManager] opens or closes an undo
* group. The undo manager itself is the notification object, with no
* <em>userInfo</em> dictionary.
*/
GS_EXPORT NSString* const NSUndoManagerCheckpointNotification;
/**
* Notification posted after an [NSUndoManager] opens an undo group.
*/
GS_EXPORT NSString* const NSUndoManagerDidOpenUndoGroupNotification;
/**
* Notification posted after an [NSUndoManager] executes a redo operation.
*/
GS_EXPORT NSString* const NSUndoManagerDidRedoChangeNotification;
/**
* Notification posted after an [NSUndoManager] executes an undo operation.
*/
GS_EXPORT NSString* const NSUndoManagerDidUndoChangeNotification;
/**
* Notification posted before an [NSUndoManager] closes an undo group.
*/
GS_EXPORT NSString* const NSUndoManagerWillCloseUndoGroupNotification;
/**
* Notification posted before an [NSUndoManager] will execute a redo operation.
*/
GS_EXPORT NSString* const NSUndoManagerWillRedoChangeNotification;
/**
* Notification posted before an [NSUndoManager] will execute an undo operation.
*/
GS_EXPORT NSString* const NSUndoManagerWillUndoChangeNotification;
@interface NSUndoManager : NSObject
{
#if GS_EXPOSE(NSUndoManager)
@private
NSMutableArray *_redoStack;
NSMutableArray *_undoStack;
id *_unused1;
id _group;
id _nextTarget;
NSArray *_modes;
BOOL _isRedoing;
BOOL _isUndoing;
BOOL _groupsByEvent;
BOOL _runLoopGroupingPending;
unsigned _disableCount;
unsigned _levelsOfUndo;
#endif
}
- (void) beginUndoGrouping;
- (BOOL) canRedo;
- (BOOL) canUndo;
- (void) disableUndoRegistration;
- (void) enableUndoRegistration;
- (void) endUndoGrouping;
- (void) forwardInvocation: (NSInvocation*)anInvocation;
- (NSInteger) groupingLevel;
- (BOOL) groupsByEvent;
- (BOOL) isRedoing;
- (BOOL) isUndoing;
- (BOOL) isUndoRegistrationEnabled;
- (NSUInteger) levelsOfUndo;
- (id) prepareWithInvocationTarget: (id)target;
- (void) redo;
- (NSString*) redoActionName;
- (NSString*) redoMenuItemTitle;
* Headers/gnustep/base/NSUndoManager.h: Add NSUndoCloseGroupingRunLoopOrdering enum. Replace instance variables _registeredUndo with _runLoopGroupingPending and _actionName with _unused1. * Source/NSUndoManager.m: Added documentation. Added actionName instance variable to PrivateUndoGroup. (-[PrivateUndoGroup actionName]): New method. (-[PrivateUndoGroup setActionName]): Ditto. (-[PrivateUndoGroup dealloc]): Release new instance variable. (-[PrivateUndoGroup initWithParent:]): Initialize actionName. (-[NSUndoManager forwardInvocation]): Implicitly call beginUndoGrouping if group has not been setup and we are grouping by events. Register _loop: invocation if none is already pending and if we are grouping by event. (-[NSUndoManager registerUndoWithTarget:selector:object]): Ditto. (-[NSUndoManager methodSignatureForSelector:]): Overriden to forward request to target supplied by -prepareWithInvocationTarget: if available. (-[NSUndoManager _loop:]): Set flag to determine pending _loop: processing. (-[NSUndoManager init]): Removed access to _actionName. Have receiver default to group by event. (-[NSUndoManager dealloc]): Ditto. (-[NSUndoManager enableUndoRegistration]): Remove access to _registeredUndo. (-[NSUndoManager redo]): Simplified implementation. (-[NSUndoManager redoActionName:]: Retrieve action name from first grouping of the redo stack. (-[NSUndoManager redoMenuTitleForUndoActionName:]): Add comment about localization. (-[NSUndoManager undoMenuTitleForUndoActionName:]): Ditto. (-[NSUndoManager setActionName:]): Forward call to current grouping. (-[NSUndoManager undoActionName:]: Retrieve action name from first grouping of the undo stack. (-[NSUndoManager setRunLoopModes:]): Use correct run loop ordering and set flag for pending _loop: invocation. (-[NSUndoManager undoNestedGroup]): Removed special case handling of _registeredUndo. Raise NSInternalInconsistencyException if grouping is still in progress. Simplified implementation. git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@17221 72102866-910b-0410-8b05-ffd578937521
2003-07-15 11:56:22 +00:00
- (NSString*) redoMenuTitleForUndoActionName: (NSString*)actionName;
- (void) registerUndoWithTarget: (id)target
selector: (SEL)aSelector
object: (id)anObject;
- (void) removeAllActions;
- (void) removeAllActionsWithTarget: (id)target;
- (NSArray*) runLoopModes;
- (void) setActionName: (NSString*)name;
- (void) setGroupsByEvent: (BOOL)flag;
- (void) setLevelsOfUndo: (NSUInteger)num;
- (void) setRunLoopModes: (NSArray*)newModes;
- (void) undo;
- (NSString*) undoActionName;
- (NSString*) undoMenuItemTitle;
* Headers/gnustep/base/NSUndoManager.h: Add NSUndoCloseGroupingRunLoopOrdering enum. Replace instance variables _registeredUndo with _runLoopGroupingPending and _actionName with _unused1. * Source/NSUndoManager.m: Added documentation. Added actionName instance variable to PrivateUndoGroup. (-[PrivateUndoGroup actionName]): New method. (-[PrivateUndoGroup setActionName]): Ditto. (-[PrivateUndoGroup dealloc]): Release new instance variable. (-[PrivateUndoGroup initWithParent:]): Initialize actionName. (-[NSUndoManager forwardInvocation]): Implicitly call beginUndoGrouping if group has not been setup and we are grouping by events. Register _loop: invocation if none is already pending and if we are grouping by event. (-[NSUndoManager registerUndoWithTarget:selector:object]): Ditto. (-[NSUndoManager methodSignatureForSelector:]): Overriden to forward request to target supplied by -prepareWithInvocationTarget: if available. (-[NSUndoManager _loop:]): Set flag to determine pending _loop: processing. (-[NSUndoManager init]): Removed access to _actionName. Have receiver default to group by event. (-[NSUndoManager dealloc]): Ditto. (-[NSUndoManager enableUndoRegistration]): Remove access to _registeredUndo. (-[NSUndoManager redo]): Simplified implementation. (-[NSUndoManager redoActionName:]: Retrieve action name from first grouping of the redo stack. (-[NSUndoManager redoMenuTitleForUndoActionName:]): Add comment about localization. (-[NSUndoManager undoMenuTitleForUndoActionName:]): Ditto. (-[NSUndoManager setActionName:]): Forward call to current grouping. (-[NSUndoManager undoActionName:]: Retrieve action name from first grouping of the undo stack. (-[NSUndoManager setRunLoopModes:]): Use correct run loop ordering and set flag for pending _loop: invocation. (-[NSUndoManager undoNestedGroup]): Removed special case handling of _registeredUndo. Raise NSInternalInconsistencyException if grouping is still in progress. Simplified implementation. git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@17221 72102866-910b-0410-8b05-ffd578937521
2003-07-15 11:56:22 +00:00
- (NSString*) undoMenuTitleForUndoActionName: (NSString*)actionName;
- (void) undoNestedGroup;
@end
#if defined(__cplusplus)
}
#endif
#endif /* GS_API_MACOSX */
#endif /* __NSUndoManager_h_OBJECTS_INCLUDE */