mirror of
https://github.com/nickshanks/ResKnife.git
synced 2025-01-06 23:30:09 +00:00
69 lines
2.7 KiB
Objective-C
69 lines
2.7 KiB
Objective-C
#import <Foundation/Foundation.h>
|
|
#import "TemplateStream.h"
|
|
|
|
/*
|
|
This is the base class for all template field types. Subclass this to
|
|
define a field type of your own.
|
|
|
|
Note that subclasses *must* implement the NSCopying protocol, which means
|
|
if you have instance variables, you must provide your own copyWithZone:
|
|
implementation that calls through to the superclass and then copies its
|
|
own variables' values (or retains references to them, if that is more
|
|
effective and the object in question isn't mutable).
|
|
*/
|
|
|
|
@interface Element : NSObject <NSCopying>
|
|
{
|
|
BOOL _isTMPL; // for debugging
|
|
NSString *type; // Type code of this item (4 chars if from TMPL resource, but we may support longer types later).
|
|
NSString *label; // Label ("name") of this field.
|
|
NSMutableArray *parentArray; // The NSMutableArray* of the template field containing us, or the template window's list.
|
|
}
|
|
|
|
+ (id)elementForType:(NSString *)type withLabel:(NSString *)label;
|
|
- (id)initForType:(NSString *)type withLabel:(NSString *)label;
|
|
|
|
// This is used to instantiate copies of the item from the template for storing data of the resource. A copy created with this is then sent readDataFrom:.
|
|
- (id)copyWithZone:(NSZone *)zone;
|
|
|
|
// Accessors:
|
|
- (void)setIsTMPL:(BOOL)t;
|
|
- (BOOL)isTMPL;
|
|
|
|
- (void)setType:(NSString *)t;
|
|
- (NSString *)type;
|
|
|
|
- (void)setLabel:(NSString *)l;
|
|
- (NSString *)label;
|
|
|
|
- (void)setParentArray:(NSMutableArray *)array;
|
|
- (NSMutableArray *)parentArray;
|
|
|
|
- (NSString *)stringValue; // Used to display your data in the list.
|
|
- (BOOL)editable;
|
|
|
|
// Items that have sub-items (like LSTB, LSTZ, LSTC and other lists) should implement these:
|
|
- (int)subElementCount;
|
|
- (Element *)subElementAtIndex:(int)n;
|
|
- (void)readSubElementsFrom:(TemplateStream *)stream;
|
|
|
|
// This is called on an item of your class when displaying resource data using a template that uses your field:
|
|
- (void)readDataFrom:(TemplateStream *)stream;
|
|
|
|
// The following are used to write resource data back out:
|
|
- (unsigned int)sizeOnDisk;
|
|
- (void)writeDataTo:(TemplateStream *)stream;
|
|
|
|
/* Apart from these messages, a Element may also implement the IBActions for
|
|
the standard edit commands (cut, copy, paste, clear). When an element is selected,
|
|
the template editor will forward any calls to these items to the element, if it
|
|
implements them, and it will automatically enable the appropriate menu items. It
|
|
will also forward validateMenuItem:for the Paste menu item to the element.
|
|
|
|
The createListEntry:action will also be forwarded to elements by the
|
|
template editor. Use this to allow creating new list items or for similar
|
|
purposes ("Create New Resource..." is renamed to "Create List Entry" while the
|
|
template editor is key). */
|
|
|
|
@end
|