ObjFW
|
A class for storing arbitrary data in an array. More...
#include <ObjFW/ObjFW.h>
Instance Methods | |
(instancetype) | - init |
Initializes an already allocated OFData to be empty with an item size of 1. | |
(instancetype) | - initWithItemSize: |
Initializes an already allocated OFData to be empty with the specified item size. | |
(instancetype) | - initWithItems:count: |
Initializes an already allocated OFData with the specified count items of size 1. | |
(instancetype) | - initWithItems:count:itemSize: |
Initializes an already allocated OFData with the specified count items of the specified size. | |
(instancetype) | - initWithItemsNoCopy:count:freeWhenDone: |
Initializes an already allocated OFData with the specified count items of size 1 by taking over ownership of the specified items pointer. | |
(instancetype) | - initWithItemsNoCopy:count:itemSize:freeWhenDone: |
Initializes an already allocated OFData with the specified count items of the specified size by taking ownership of the specified items pointer. | |
(instancetype) | - initWithContentsOfFile: |
Initializes an already allocated OFData with an item size of 1, containing the data of the specified file. | |
(instancetype) | - initWithContentsOfIRI: |
Initializes an already allocated OFData with an item size of 1, containing the data of the specified IRI. | |
(instancetype) | - initWithStringRepresentation: |
Initializes an already allocated OFData with an item size of 1, containing the data of the hex string representation. | |
(instancetype) | - initWithBase64EncodedString: |
Initializes an already allocated OFData with an item size of 1, containing the data of the Base64-encoded string. | |
(OFComparisonResult) | - compare: |
Compares the data to other data. | |
(const void *) | - itemAtIndex: |
Returns a specific item of the OFData. | |
(OFData *) | - subdataWithRange: |
Returns the data in the specified range as a new OFData. | |
(OFRange) | - rangeOfData:options:range: |
Returns the range of the data. | |
(void) | - writeToFile: |
Writes the OFData into the specified file. | |
(void) | - writeToIRI: |
Writes the OFData to the specified IRI. | |
(id) | - objectByParsingMessagePackWithDepthLimit: |
Parses the MessagePack representation and returns it as an object. | |
Instance Methods inherited from OFObject | |
(nullable OFMethodSignature *) | - methodSignatureForSelector: |
Returns the method signature for the specified selector. | |
(void) | - dealloc |
Deallocates the object. | |
(void) | - performSelector:afterDelay: |
Performs the specified selector after the specified delay. | |
(void) | - performSelector:withObject:afterDelay: |
Performs the specified selector with the specified object after the specified delay. | |
(void) | - performSelector:withObject:withObject:afterDelay: |
Performs the specified selector with the specified objects after the specified delay. | |
(void) | - performSelector:withObject:withObject:withObject:afterDelay: |
Performs the specified selector with the specified objects after the specified delay. | |
(void) | - performSelector:withObject:withObject:withObject:withObject:afterDelay: |
Performs the specified selector with the specified objects after the specified delay. | |
(void) | - performSelector:onThread:waitUntilDone: |
Performs the specified selector on the specified thread. | |
(void) | - performSelector:onThread:withObject:waitUntilDone: |
Performs the specified selector on the specified thread with the specified object. | |
(void) | - performSelector:onThread:withObject:withObject:waitUntilDone: |
Performs the specified selector on the specified thread with the specified objects. | |
(void) | - performSelector:onThread:withObject:withObject:withObject:waitUntilDone: |
Performs the specified selector on the specified thread with the specified objects. | |
(void) | - performSelector:onThread:withObject:withObject:withObject:withObject:waitUntilDone: |
Performs the specified selector on the specified thread with the specified objects. | |
(void) | - performSelectorOnMainThread:waitUntilDone: |
Performs the specified selector on the main thread. | |
(void) | - performSelectorOnMainThread:withObject:waitUntilDone: |
Performs the specified selector on the main thread with the specified object. | |
(void) | - performSelectorOnMainThread:withObject:withObject:waitUntilDone: |
Performs the specified selector on the main thread with the specified objects. | |
(void) | - performSelectorOnMainThread:withObject:withObject:withObject:waitUntilDone: |
Performs the specified selector on the main thread with the specified objects. | |
(void) | - performSelectorOnMainThread:withObject:withObject:withObject:withObject:waitUntilDone: |
Performs the specified selector on the main thread with the specified objects. | |
(void) | - performSelector:onThread:afterDelay: |
Performs the specified selector on the specified thread after the specified delay. | |
(void) | - performSelector:onThread:withObject:afterDelay: |
Performs the specified selector on the specified thread with the specified object after the specified delay. | |
(void) | - performSelector:onThread:withObject:withObject:afterDelay: |
Performs the specified selector on the specified thread with the specified objects after the specified delay. | |
(void) | - performSelector:onThread:withObject:withObject:withObject:afterDelay: |
Performs the specified selector on the specified thread with the specified objects after the specified delay. | |
(void) | - performSelector:onThread:withObject:withObject:withObject:withObject:afterDelay: |
Performs the specified selector on the specified thread with the specified objects after the specified delay. | |
(nullable id) | - forwardingTargetForSelector: |
This method is called when resolveClassMethod: or resolveInstanceMethod: returned false. It should return a target to which the message should be forwarded. | |
(void) | - doesNotRecognizeSelector: |
Handles messages which are not understood by the receiver. | |
Instance Methods inherited from <OFObject> | |
(unsigned long) | - hash |
Returns a hash for the object. | |
(unsigned int) | - retainCount |
Returns the retain count. | |
(bool) | - isProxy |
Returns whether the object is a proxy object. | |
(bool) | - isKindOfClass: |
Returns a boolean whether the object is of the specified kind. | |
(bool) | - isMemberOfClass: |
Returns a boolean whether the object is a member of the specified class. | |
(bool) | - respondsToSelector: |
Returns a boolean whether the object responds to the specified selector. | |
(nullable IMP) | - methodForSelector: |
Returns the implementation for the specified selector. | |
(nullable id) | - performSelector: |
Performs the specified selector. | |
(nullable id) | - performSelector:withObject: |
Performs the specified selector with the specified object. | |
(nullable id) | - performSelector:withObject:withObject: |
Performs the specified selector with the specified objects. | |
(nullable id) | - performSelector:withObject:withObject:withObject: |
Performs the specified selector with the specified objects. | |
(nullable id) | - performSelector:withObject:withObject:withObject:withObject: |
Performs the specified selector with the specified objects. | |
(bool) | - isEqual: |
Checks two objects for equality. | |
(instancetype) | - retain |
Increases the retain count. | |
(void) | - release |
Decreases the retain count. | |
(instancetype) | - autorelease |
Adds the object to the topmost autorelease pool of the thread's autorelease pool stack. | |
(instancetype) | - self |
Returns the receiver. | |
(bool) | - allowsWeakReference |
Returns whether the object allows a weak reference. | |
(bool) | - retainWeakReference |
Retain a weak reference to this object. | |
Instance Methods inherited from <OFCopying> | |
(id) | - copy |
Copies the object. | |
Instance Methods inherited from <OFMutableCopying> | |
(id) | - mutableCopy |
Creates a mutable copy of the object. | |
Instance Methods inherited from <OFComparing> | |
(OFComparisonResult) | - compare: |
Compares the object to another object. | |
Class Methods | |
(instancetype) | + data |
Creates a new OFData that is empty with an item size of 1. | |
(instancetype) | + dataWithItemSize: |
Creates a new OFData that is empty with the specified item size. | |
(instancetype) | + dataWithItems:count: |
Creates a new OFData with the specified count items of size 1. | |
(instancetype) | + dataWithItems:count:itemSize: |
Creates a new OFData with the specified count items of the specified size. | |
(instancetype) | + dataWithItemsNoCopy:count:freeWhenDone: |
Creates a new OFData with the specified count items of size 1 by taking over ownership of the specified items pointer. | |
(instancetype) | + dataWithItemsNoCopy:count:itemSize:freeWhenDone: |
Creates a new OFData with the specified count items of the specified size by taking ownership of the specified items pointer. | |
(instancetype) | + dataWithContentsOfFile: |
Creates a new OFData with an item size of 1, containing the data of the specified file. | |
(instancetype) | + dataWithContentsOfIRI: |
Creates a new OFData with an item size of 1, containing the data of the specified IRI. | |
(instancetype) | + dataWithStringRepresentation: |
Creates a new OFData with an item size of 1, containing the data of the hex string representation. | |
(instancetype) | + dataWithBase64EncodedString: |
Creates a new OFData with an item size of 1, containing the data of the Base64-encoded string. | |
Class Methods inherited from OFObject | |
(void) | + load |
A method which is called once when the class is loaded into the runtime. | |
(void) | + unload |
A method which is called when the class is unloaded from the runtime. | |
(void) | + initialize |
A method which is called the moment before the first call to the class is being made. | |
(instancetype) | + alloc |
Allocates memory for an instance of the class and sets up the memory pool for the object. | |
(Class) | + class |
Returns the class. | |
(OFString *) | + className |
Returns the name of the class as a string. | |
(bool) | + isSubclassOfClass: |
Returns a boolean whether the class is a subclass of the specified class. | |
(nullable Class) | + superclass |
Returns the superclass of the class. | |
(bool) | + instancesRespondToSelector: |
Checks whether instances of the class respond to a given selector. | |
(bool) | + conformsToProtocol: |
Checks whether the class conforms to a given protocol. | |
(nullable IMP) | + instanceMethodForSelector: |
Returns the implementation of the instance method for the specified selector. | |
(nullable OFMethodSignature *) | + instanceMethodSignatureForSelector: |
Returns the method signature of the instance method for the specified selector. | |
(OFString *) | + description |
Returns a description for the class, which is usually the class name. | |
(nullable IMP) | + replaceClassMethod:withMethodFromClass: |
Replaces a class method with a class method from another class. | |
(nullable IMP) | + replaceInstanceMethod:withMethodFromClass: |
Replaces an instance method with an instance method from another class. | |
(void) | + inheritMethodsFromClass: |
Adds all methods from the specified class to the class that is the receiver. | |
(bool) | + resolveClassMethod: |
Try to resolve the specified class method. | |
(bool) | + resolveInstanceMethod: |
Try to resolve the specified instance method. | |
(id) | + copy |
Returns the class. | |
Properties | |
size_t | itemSize |
The size of a single item in the OFData in bytes. | |
size_t | count |
The number of items in the OFData. | |
const void * | items |
All elements of the OFData as a C array. | |
const void * | firstItem |
The first item of the OFData or NULL . | |
const void * | lastItem |
The last item of the OFData or NULL . | |
OFString * | stringRepresentation |
The string representation of the data. | |
OFString * | stringByBase64Encoding |
A string containing the data in Base64 encoding. | |
OFString * | stringByMD5Hashing |
The MD5 hash of the data as a string. | |
OFString * | stringByRIPEMD160Hashing |
The RIPEMD-160 hash of the data as a string. | |
OFString * | stringBySHA1Hashing |
The SHA-1 hash of the data as a string. | |
OFString * | stringBySHA224Hashing |
The SHA-224 hash of the data as a string. | |
OFString * | stringBySHA256Hashing |
The SHA-256 hash of the data as a string. | |
OFString * | stringBySHA384Hashing |
The SHA-384 hash of the data as a string. | |
OFString * | stringBySHA512Hashing |
The SHA-512 hash of the data as a string. | |
id | objectByParsingMessagePack |
The data interpreted as MessagePack representation and parsed as an object. | |
Properties inherited from OFObject | |
OFString * | className |
The name of the object's class. | |
OFString * | description |
A description for the object. | |
Properties inherited from <OFMessagePackRepresentation> | |
OFData * | messagePackRepresentation |
The MessagePack representation of the object as OFData. | |
A class for storing arbitrary data in an array.
- (OFComparisonResult) compare: | (OFData *) | data |
Compares the data to other data.
data | Data to compare the data to |
+ (instancetype) data |
+ (instancetype) dataWithBase64EncodedString: | (OFString *) | string |
Creates a new OFData with an item size of 1, containing the data of the Base64-encoded string.
string | The string with the Base64-encoded data |
OFInvalidFormatException | The specified string is not correctly formatted |
Reimplemented in OFSecureData.
+ (instancetype) dataWithContentsOfFile: | (OFString *) | path |
Creates a new OFData with an item size of 1, containing the data of the specified file.
path | The path of the file |
Reimplemented in OFSecureData.
+ (instancetype) dataWithContentsOfIRI: | (OFIRI *) | IRI |
Creates a new OFData with an item size of 1, containing the data of the specified IRI.
IRI | The IRI to the contents for the OFData |
Reimplemented in OFSecureData.
+ (instancetype) dataWithItems: | (const void *) | items | |
count: | (size_t) | count |
Creates a new OFData with the specified count
items of size 1.
items | The items to store in the OFData |
count | The number of items |
Reimplemented in OFSecureData.
+ (instancetype) dataWithItems: | (const void *) | items | |
count: | (size_t) | count | |
itemSize: | (size_t) | itemSize |
Creates a new OFData with the specified count
items of the specified size.
items | The items to store in the OFData |
count | The number of items |
itemSize | The item size of a single item in bytes |
Reimplemented in OFSecureData.
+ (instancetype) dataWithItemSize: | (size_t) | itemSize |
+ (instancetype) dataWithItemsNoCopy: | (void *) | items | |
count: | (size_t) | count | |
freeWhenDone: | (bool) | freeWhenDone |
Creates a new OFData with the specified count
items of size 1 by taking over ownership of the specified items pointer.
If initialization fails for whatever reason, the passed memory is not freed if freeWhenDone
is true.
items | The items to store in the OFData |
count | The number of items |
freeWhenDone | Whether to free the pointer when it is no longer needed by the OFData |
Reimplemented in OFSecureData.
+ (instancetype) dataWithItemsNoCopy: | (void *) | items | |
count: | (size_t) | count | |
itemSize: | (size_t) | itemSize | |
freeWhenDone: | (bool) | freeWhenDone |
Creates a new OFData with the specified count
items of the specified size by taking ownership of the specified items pointer.
If initialization fails for whatever reason, the passed memory is not freed if freeWhenDone
is true.
items | The items to store in the OFData |
count | The number of items |
itemSize | The item size of a single item in bytes |
freeWhenDone | Whether to free the pointer when it is no longer needed by the OFData |
Reimplemented in OFSecureData.
+ (instancetype) dataWithStringRepresentation: | (OFString *) | string |
Creates a new OFData with an item size of 1, containing the data of the hex string representation.
string | The hex string representation of the data |
OFInvalidFormatException | The specified string is not correctly formatted |
Reimplemented in OFSecureData.
- (instancetype) init |
- (instancetype) initWithBase64EncodedString: | (OFString *) | string |
Initializes an already allocated OFData with an item size of 1, containing the data of the Base64-encoded string.
string | The string with the Base64-encoded data |
OFInvalidFormatException | The specified string is not correctly formatted |
Reimplemented in OFSecureData.
- (instancetype) initWithContentsOfFile: | (OFString *) | path |
Initializes an already allocated OFData with an item size of 1, containing the data of the specified file.
path | The path of the file |
Reimplemented in OFSecureData.
- (instancetype) initWithContentsOfIRI: | (OFIRI *) | IRI |
Initializes an already allocated OFData with an item size of 1, containing the data of the specified IRI.
IRI | The IRI to the contents for the OFData |
Reimplemented in OFSecureData.
- (instancetype) initWithItems: | (const void *) | items | |
count: | (size_t) | count |
Initializes an already allocated OFData with the specified count
items of size 1.
items | The items to store in the OFData |
count | The number of items |
Reimplemented in OFSecureData.
- (instancetype) initWithItems: | (const void *) | items | |
count: | (size_t) | count | |
itemSize: | (size_t) | itemSize |
Initializes an already allocated OFData with the specified count
items of the specified size.
items | The items to store in the OFData |
count | The number of items |
itemSize | The item size of a single item in bytes |
Reimplemented in OFSecureData.
- (instancetype) initWithItemSize: | (size_t) | itemSize |
Initializes an already allocated OFData to be empty with the specified item size.
itemSize | The size of a single element in the OFData |
Reimplemented in OFSecureData.
- (instancetype) initWithItemsNoCopy: | (void *) | items | |
count: | (size_t) | count | |
freeWhenDone: | (bool) | freeWhenDone |
Initializes an already allocated OFData with the specified count
items of size 1 by taking over ownership of the specified items pointer.
If initialization fails for whatever reason, the passed memory is not freed if freeWhenDone
is true.
items | The items to store in the OFData |
count | The number of items |
freeWhenDone | Whether to free the pointer when it is no longer needed by the OFData |
Reimplemented in OFSecureData.
- (instancetype) initWithItemsNoCopy: | (void *) | items | |
count: | (size_t) | count | |
itemSize: | (size_t) | itemSize | |
freeWhenDone: | (bool) | freeWhenDone |
Initializes an already allocated OFData with the specified count
items of the specified size by taking ownership of the specified items pointer.
If initialization fails for whatever reason, the passed memory is not freed if freeWhenDone
is true.
items | The items to store in the OFData |
count | The number of items |
itemSize | The item size of a single item in bytes |
freeWhenDone | Whether to free the pointer when it is no longer needed by the OFData |
Reimplemented in OFSecureData.
- (instancetype) initWithStringRepresentation: | (OFString *) | string |
Initializes an already allocated OFData with an item size of 1, containing the data of the hex string representation.
string | The hex string representation of the data |
OFInvalidFormatException | The specified string is not correctly formatted |
Reimplemented in OFSecureData.
- (const void *) itemAtIndex: | (size_t) | index |
- (id) objectByParsingMessagePackWithDepthLimit: | (size_t) | depthLimit |
Parses the MessagePack representation and returns it as an object.
depthLimit | The maximum depth the parser should accept (defaults to 32 if not specified, 0 means no limit (insecure!)) |
OFInvalidFormatException | The MessagePack representation contained in the data contained an invalid format |
OFTruncatedDataException | The MessagePack representation contained in the data is truncated |
OFOutOfRangeException | The depth limit has been exceeded |
- (OFRange) rangeOfData: | (OFData *) | data | |
options: | (OFDataSearchOptions) | options | |
range: | (OFRange) | range |
Returns the range of the data.
data | The data to search for |
options | Options modifying search behavior |
range | The range in which to search |
OFNotFound
as start position if it was not found. - (void) writeToFile: | (OFString *) | path |
Writes the OFData into the specified file.
path | The path of the file to write to |
Reimplemented in OFSecureData.
- (void) writeToIRI: | (OFIRI *) | IRI |
Writes the OFData to the specified IRI.
IRI | The IRI to write to |
Reimplemented in OFSecureData.
|
readwriteatomic |
|
readnonatomicassign |
The data interpreted as MessagePack representation and parsed as an object.
OFInvalidFormatException | The MessagePack representation contained in the data contained an invalid format |
OFTruncatedDataException | The MessagePack representation contained in the data is truncated |
OFOutOfRangeException | The depth limit has been exceeded |
|
readnonatomicassign |
The string representation of the data.
The string representation is a hex dump of the data, grouped by itemSize bytes.