ObjFW  Diff

Differences From Artifact [de75aa3e70]:

To Artifact [496d3ca31d]:


100
101
102
103
104
105
106
107
108


109
110
111
112
113
114
115
116
117
118
119
120


121
122
123
124
125
126
127
128


129
130
131
132
133
134
135
136
137
138


139
140
141
142
143
144
145
146


147
148
149
150
151
152
153
154


155
156
157
158
159
160
161
162
163
164
165
166


167
168
169
170


171
172

173
174
175
176
177


178
179
180


181
182
183
184
185


186
187
188
189


190
191
192
193
194


195
196
197
198


199
200
201
202
203


204
205
206


207
208
209
210
211


212
213
214


215
216
217
218
219


220
221
222


223
224
225
226
227


228
229
230


231
232
233
234
235


236
237
238


239
240

241
242
243
244
245
246


247
248
249


250
251

252
253

254
255
256
257
258
259
260


261
262
263
264
265
266


267
268
269
270
271


272
273
274
275
276

277
278
279
280
281


282
283
284
285
286
287
288
289


290
291

292
293
294
295
296


297
298
299
300
301
302
303
304


305
306
307

308
309
310
311
312


313
314

315
316
317
318
319


320
321

322
323
324
325
326
327


328
329
330
331
332
333
334
335
336
337


338
339
340
341
342
343
344
345
346


347
348
349
350
351
352
353
354
355
356
357


358
359
360
361
362
363

364
365
366
367
368
369



370
371
372
373
374


375
376

377
378
379
380
381


382
383

384
385
386
387
388


389
390
391
392


393
394
395
396
397


398
399

400
401
402
403
404


405
406
407


408
409
410
411
412
413


414
415
416


417
418
419
420
421


422
423
424
425


426
427
428
429
430
431


432
433
434
435


436
437
438
439
440


441
442
443
444

445
446
447
448
449


450
451
452
453



454
455
456
457
458
459


460
461
462
463
464



465
466
467
468
469
470


471
472
473
474
475
476
477
478
479




480
481
482
483
484
485
486


487
488
489
490
491
492
493
494
495




496
497
498
499
500
501
502


503
504
505
506
507
508
509
510
511
512
513
514
515
516
517

518
519
520
521
522


523
524
525
526
527

528
529
530
531
532


533
534
535
536
537

538
539
540
541
542


543
544
545
546
547
548

549
550
551
552
553


554
555

556
557
558
559
560


561
562
563
564

565
566
567
568
569


570
571
572
573
574


575
576
577
578
579


580
581
582
583
584
585
586



587
588
589
590
591
592


593
594
595
596
597
598
599



600
601
602
603
604
605


606
607
608
609
610
611
612
613
614




615
616
617
618
619
620
621


622
623
624
625

626
627
628
629
630


631
632
633
634
635
636
637
638
639


640
641
642


643
644
645
646
647
648


649
650
651
652


653
654

655
656
657
658
659
660
661


662
663
664
665


666
667

668
669

670
671
672
673
674
675
676
677


678
679
680
681



682
683
684
685
686
687
688


689
690
691
692
693



694
695

696
697
698
699
700
701
702
703


704
705
706
707
708



709
710

711
712

713
714
715
716
717
718
719
720
721


722
723
724


725
726
727
728
729
730


731
732
733
734


735
736

737
738
739
740
741
742
743


744
745
746
747


748
749

750
751

752
753
754
755
756
757
758
759


760
761
762
763
764



765
766
767
768
769
770
771


772
773
774
775
776



777
778

779
780
781
782
783
784
785
786


787
788
789
790
791



792
793

794
795

796
797
798
799
800
801
802
803
804
805


806
807
808
809


810
811
812
813
814
815

816
817
818
819
820
821


822
823
824
825
826
827
828


829
830

831
832
833
834
835
836


837
838
839
840
841
842


843
844
845


846
847
848
849
850
851
852
100
101
102
103
104
105
106


107
108
109
110
111
112
113
114
115
116
117
118


119
120
121
122
123
124
125
126


127
128
129
130
131
132
133
134
135
136


137
138
139
140
141
142
143
144


145
146
147
148
149
150
151
152


153
154
155
156
157
158
159
160
161
162
163
164


165
166
167
168


169
170
171

172
173
174
175


176
177
178


179
180
181
182
183


184
185
186
187


188
189
190
191
192


193
194
195
196


197
198
199
200
201


202
203
204


205
206
207
208
209


210
211
212


213
214
215
216
217


218
219
220


221
222
223
224
225


226
227
228


229
230
231
232
233


234
235
236


237
238
239

240
241
242
243
244


245
246
247


248
249
250

251
252

253
254
255
256
257
258


259
260
261
262
263
264


265
266
267
268
269


270
271
272
273
274
275

276
277
278
279


280
281
282
283
284
285
286
287


288
289
290

291
292
293
294


295
296
297
298
299
300
301
302


303
304
305
306

307
308
309
310


311
312
313

314
315
316
317


318
319
320

321
322
323
324
325


326
327
328
329
330
331
332
333
334
335


336
337
338
339
340
341
342
343
344


345
346
347
348
349
350
351
352
353
354
355


356
357
358
359
360
361
362

363
364
365
366



367
368
369
370
371
372


373
374
375

376
377
378
379


380
381
382

383
384
385
386


387
388
389
390


391
392
393
394
395


396
397
398

399
400
401
402


403
404
405


406
407
408
409
410
411


412
413
414


415
416
417
418
419


420
421
422
423


424
425
426
427
428
429


430
431
432
433


434
435
436
437
438


439
440
441
442
443

444
445
446
447


448
449
450



451
452
453
454
455
456
457


458
459
460
461



462
463
464
465
466
467
468


469
470
471
472
473
474
475




476
477
478
479
480
481
482
483
484


485
486
487
488
489
490
491




492
493
494
495
496
497
498
499
500


501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516

517
518
519
520


521
522
523
524
525
526

527
528
529
530


531
532
533
534
535
536

537
538
539
540


541
542
543
544
545
546
547

548
549
550
551


552
553
554

555
556
557
558


559
560
561
562
563

564
565
566
567


568
569
570
571
572


573
574
575
576
577


578
579
580
581
582
583



584
585
586
587
588
589
590


591
592
593
594
595
596



597
598
599
600
601
602
603


604
605
606
607
608
609
610




611
612
613
614
615
616
617
618
619


620
621
622
623
624

625
626
627
628


629
630
631
632
633
634
635
636
637


638
639
640


641
642
643
644
645
646


647
648
649
650


651
652
653

654
655
656
657
658
659


660
661
662
663


664
665
666

667
668

669
670
671
672
673
674
675


676
677
678



679
680
681
682
683
684
685
686


687
688
689
690



691
692
693
694

695
696
697
698
699
700
701


702
703
704
705



706
707
708
709

710
711

712
713
714
715
716
717
718
719


720
721
722


723
724
725
726
727
728


729
730
731
732


733
734
735

736
737
738
739
740
741


742
743
744
745


746
747
748

749
750

751
752
753
754
755
756
757


758
759
760
761



762
763
764
765
766
767
768
769


770
771
772
773



774
775
776
777

778
779
780
781
782
783
784


785
786
787
788



789
790
791
792

793
794

795
796
797
798
799
800
801
802
803


804
805
806
807


808
809
810
811
812
813
814

815
816
817
818
819


820
821
822
823
824
825
826


827
828
829

830
831
832
833
834


835
836
837
838
839
840


841
842
843


844
845
846
847
848
849
850
851
852







-
-
+
+










-
-
+
+






-
-
+
+








-
-
+
+






-
-
+
+






-
-
+
+










-
-
+
+


-
-
+
+

-
+



-
-
+
+

-
-
+
+



-
-
+
+


-
-
+
+



-
-
+
+


-
-
+
+



-
-
+
+

-
-
+
+



-
-
+
+

-
-
+
+



-
-
+
+

-
-
+
+



-
-
+
+

-
-
+
+



-
-
+
+

-
-
+
+

-
+




-
-
+
+

-
-
+
+

-
+

-
+





-
-
+
+




-
-
+
+



-
-
+
+




-
+



-
-
+
+






-
-
+
+

-
+



-
-
+
+






-
-
+
+


-
+



-
-
+
+

-
+



-
-
+
+

-
+




-
-
+
+








-
-
+
+







-
-
+
+









-
-
+
+





-
+



-
-
-
+
+
+



-
-
+
+

-
+



-
-
+
+

-
+



-
-
+
+


-
-
+
+



-
-
+
+

-
+



-
-
+
+

-
-
+
+




-
-
+
+

-
-
+
+



-
-
+
+


-
-
+
+




-
-
+
+


-
-
+
+



-
-
+
+



-
+



-
-
+
+

-
-
-
+
+
+




-
-
+
+


-
-
-
+
+
+




-
-
+
+





-
-
-
-
+
+
+
+





-
-
+
+





-
-
-
-
+
+
+
+





-
-
+
+














-
+



-
-
+
+




-
+



-
-
+
+




-
+



-
-
+
+





-
+



-
-
+
+

-
+



-
-
+
+



-
+



-
-
+
+



-
-
+
+



-
-
+
+




-
-
-
+
+
+




-
-
+
+




-
-
-
+
+
+




-
-
+
+





-
-
-
-
+
+
+
+





-
-
+
+



-
+



-
-
+
+







-
-
+
+

-
-
+
+




-
-
+
+


-
-
+
+

-
+





-
-
+
+


-
-
+
+

-
+

-
+






-
-
+
+

-
-
-
+
+
+





-
-
+
+


-
-
-
+
+
+

-
+






-
-
+
+


-
-
-
+
+
+

-
+

-
+







-
-
+
+

-
-
+
+




-
-
+
+


-
-
+
+

-
+





-
-
+
+


-
-
+
+

-
+

-
+






-
-
+
+


-
-
-
+
+
+





-
-
+
+


-
-
-
+
+
+

-
+






-
-
+
+


-
-
-
+
+
+

-
+

-
+








-
-
+
+


-
-
+
+





-
+




-
-
+
+





-
-
+
+

-
+




-
-
+
+




-
-
+
+

-
-
+
+







# define __bridge
# define __autoreleasing
#endif

#define OF_RETAIN_COUNT_MAX UINT_MAX
#define OF_NOT_FOUND SIZE_MAX

/**
 * \brief A result of a comparison.
/*!
 * @brief A result of a comparison.
 */
typedef enum of_comparison_result_t {
	/// The left object is smaller than the right
	OF_ORDERED_ASCENDING = -1,
	/// Both objects are equal
	OF_ORDERED_SAME = 0,
	/// The left object is bigger than the right
	OF_ORDERED_DESCENDING = 1
} of_comparison_result_t;

/**
 * \brief An enum for storing endianess.
/*!
 * @brief An enum for storing endianess.
 */
typedef enum of_byte_order_t {
	OF_BYTE_ORDER_BIG_ENDIAN,
	OF_BYTE_ORDER_LITTLE_ENDIAN
} of_byte_order_t;

/**
 * \brief A range.
/*!
 * @brief A range.
 */
typedef struct of_range_t {
	/// The start of the range
	size_t location;
	/// The length of the range
	size_t length;
} of_range_t;

/**
 * \brief A point.
/*!
 * @brief A point.
 */
typedef struct of_point_t {
	float x;
	float y;
} of_point_t;

/**
 * \brief A dimension.
/*!
 * @brief A dimension.
 */
typedef struct of_dimension_t {
	float width;
	float height;
} of_dimension_t;

/**
 * \brief A rectangle.
/*!
 * @brief A rectangle.
 */
typedef struct of_rectangle_t
{
	of_point_t origin;
	of_dimension_t size;
} of_rectangle_t;

@class OFString;
@class OFThread;

/**
 * \brief The protocol which all root classes implement.
/*!
 * @brief The protocol which all root classes implement.
 */
@protocol OFObject
/**
 * \brief Returns the class of the object.
/*!
 * @brief Returns the class of the object.
 *
 * \return The class of the object
 * @return The class of the object
 */
- (Class)class;

/**
 * \brief Returns a boolean whether the object of the specified kind.
/*!
 * @brief Returns a boolean whether the object of the specified kind.
 *
 * \param class_ The class whose kind is checked
 * \return A boolean whether the object is of the specified kind
 * @param class_ The class whose kind is checked
 * @return A boolean whether the object is of the specified kind
 */
- (BOOL)isKindOfClass: (Class)class_;

/**
 * \brief Returns a boolean whether the object is a member of the specified
/*!
 * @brief Returns a boolean whether the object is a member of the specified
 *	  class.
 *
 * \param class_ The class for which the receiver is checked
 * \return A boolean whether the object is a member of the specified class
 * @param class_ The class for which the receiver is checked
 * @return A boolean whether the object is a member of the specified class
 */
- (BOOL)isMemberOfClass: (Class)class_;

/**
 * \brief Returns a boolean whether the object responds to the specified
/*!
 * @brief Returns a boolean whether the object responds to the specified
 *	  selector.
 *
 * \param selector The selector which should be checked for respondance
 * \return A boolean whether the objects responds to the specified selector
 * @param selector The selector which should be checked for respondance
 * @return A boolean whether the objects responds to the specified selector
 */
- (BOOL)respondsToSelector: (SEL)selector;

/**
 * \brief Checks whether the object conforms to the specified protocol.
/*!
 * @brief Checks whether the object conforms to the specified protocol.
 *
 * \param protocol The protocol which should be checked for conformance
 * \return A boolean whether the object conforms to the specified protocol
 * @param protocol The protocol which should be checked for conformance
 * @return A boolean whether the object conforms to the specified protocol
 */
- (BOOL)conformsToProtocol: (Protocol*)protocol;

/**
 * \brief Returns the implementation for the specified selector.
/*!
 * @brief Returns the implementation for the specified selector.
 *
 * \param selector The selector for which the method should be returned
 * \return The implementation for the specified selector
 * @param selector The selector for which the method should be returned
 * @return The implementation for the specified selector
 */
- (IMP)methodForSelector: (SEL)selector;

/**
 * \brief Returns the type encoding for the specified selector.
/*!
 * @brief Returns the type encoding for the specified selector.
 *
 * \param selector The selector for which the type encoding should be returned
 * \return The type encoding for the specified selector
 * @param selector The selector for which the type encoding should be returned
 * @return The type encoding for the specified selector
 */
- (const char*)typeEncodingForSelector: (SEL)selector;

/**
 * \brief Performs the specified selector.
/*!
 * @brief Performs the specified selector.
 *
 * \param selector The selector to perform
 * \return The object returned by the method specified by the selector
 * @param selector The selector to perform
 * @return The object returned by the method specified by the selector
 */
- (id)performSelector: (SEL)selector;

/**
 * \brief Performs the specified selector with the specified object.
/*!
 * @brief Performs the specified selector with the specified object.
 *
 * \param selector The selector to perform
 * \param object The object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param object The object that is passed to the method specified by the
 *		 selector
 * \return The object returned by the method specified by the selector
 * @return The object returned by the method specified by the selector
 */
- (id)performSelector: (SEL)selector
	   withObject: (id)object;

/**
 * \brief Performs the specified selector with the specified objects.
/*!
 * @brief Performs the specified selector with the specified objects.
 *
 * \param selector The selector to perform
 * \param object1 The first object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param object1 The first object that is passed to the method specified by the
 *		 selector
 * \param object2 The second object that is passed to the method specified by
 * @param object2 The second object that is passed to the method specified by
 *		  the selector
 * \return The object returned by the method specified by the selector
 * @return The object returned by the method specified by the selector
 */
- (id)performSelector: (SEL)selector
	   withObject: (id)object1
	   withObject: (id)object2;

/**
 * \brief Checks two objects for equality.
/*!
 * @brief Checks two objects for equality.
 *
 * Classes containing data (like strings, arrays, lists etc.) should reimplement
 * this!
 *
 * \param object The object which should be tested for equality
 * \return A boolean whether the object is equal to the specified object
 * @param object The object which should be tested for equality
 * @return A boolean whether the object is equal to the specified object
 */
- (BOOL)isEqual: (id)object;

/**
 * \brief Calculates a hash for the object.
/*!
 * @brief Calculates a hash for the object.
 *
 * Classes containing data (like strings, arrays, lists etc.) should reimplement
 * this!
 *
 * \return A 32 bit hash for the object
 * @return A 32 bit hash for the object
 */
- (uint32_t)hash;

/**
 * \brief Increases the retain count.
/*!
 * @brief Increases the retain count.
 *
 * Each time an object is released, the retain count gets decreased and the
 * object deallocated if it reaches 0.
 */
- retain;

/**
 * \brief Returns the retain count.
/*!
 * @brief Returns the retain count.
 *
 * \return The retain count
 * @return The retain count
 */
- (unsigned int)retainCount;

/**
 * \brief Decreases the retain count.
/*!
 * @brief Decreases the retain count.
 *
 * Each time an object is released, the retain count gets decreased and the
 * object deallocated if it reaches 0.
 */
- (void)release;

/**
 * \brief Adds the object to the topmost OFAutoreleasePool of the thread's
/*!
 * @brief Adds the object to the topmost OFAutoreleasePool of the thread's
 *	  autorelease pool stack.
 *
 * \return The object
 * @return The object
 */
- autorelease;

/**
 * \brief Returns the receiver.
/*!
 * @brief Returns the receiver.
 *
 * \return The receiver
 * @return The receiver
 */
- self;

/**
 * \brief Returns whether the object is a proxy object.
/*!
 * @brief Returns whether the object is a proxy object.
 *
 * \return A boolean whether the object is a proxy object
 * @return A boolean whether the object is a proxy object
 */
- (BOOL)isProxy;
@end

/**
 * \brief The root class for all other classes inside ObjFW.
/*!
 * @brief The root class for all other classes inside ObjFW.
 */
@interface OFObject <OFObject>
{
@public
	/// The class of the object
	Class isa;
}

/**
 * \brief A method which is called once when the class is loaded into the
/*!
 * @brief A method which is called once when the class is loaded into the
 *	  runtime.
 *
 * Derived classes can overide this to execute their own code when the class is
 * loaded.
 */
+ (void)load;

/**
 * \brief A method which is called the moment before the first call to the class
/*!
 * @brief A method which is called the moment before the first call to the class
 *	  is being made.
 *
 * Derived classes can override this to execute their own code on
 * initialization. They should make sure to not execute any code if self is not
 * the class itself, as it might happen that the method was called for a
 * subclass which did not override this method.
 */
+ (void)initialize;

/**
 * \brief Allocates memory for an instance of the class and sets up the memory
/*!
 * @brief Allocates memory for an instance of the class and sets up the memory
 *	  pool for the object.
 *
 * This method will never return nil, instead, it will throw an
 * OFAllocFailedException.
 *
 * \return The allocated object
 * @return The allocated object
 */
+ alloc;

/**
 * \brief Allocates memory for a new instance and calls -[init] on it.
 * \return An allocated and initialized object
/*!
 * @brief Allocates memory for a new instance and calls -[init] on it.
 * @return An allocated and initialized object
 */
+ new;

/**
 * \brief Returns the class.
/*!
 * @brief Returns the class.
 *
 * \return The class
 * @return The class
 */
+ (Class)class;

/**
 * \brief Returns the name of the class as a string.
/*!
 * @brief Returns the name of the class as a string.
 *
 * \return The name of the class as a string
 * @return The name of the class as a string
 */
+ (OFString*)className;

/**
 * \brief Returns a boolean whether the class is a subclass of the specified
/*!
 * @brief Returns a boolean whether the class is a subclass of the specified
 *	  class.
 *
 * \param class_ The class which is checked for being a superclass
 * \return A boolean whether the class is a subclass of the specified class
 * @param class_ The class which is checked for being a superclass
 * @return A boolean whether the class is a subclass of the specified class
 */
+ (BOOL)isSubclassOfClass: (Class)class_;

/**
 * \brief Returns the superclass of the class.
/*!
 * @brief Returns the superclass of the class.
 *
 * \return The superclass of the class
 * @return The superclass of the class
 */
+ (Class)superclass;

/**
 * \brief Checks whether instances of the class respond to a given selector.
/*!
 * @brief Checks whether instances of the class respond to a given selector.
 *
 * \param selector The selector which should be checked for respondance
 * \return A boolean whether instances of the class respond to the specified
 * @param selector The selector which should be checked for respondance
 * @return A boolean whether instances of the class respond to the specified
 *	   selector
 */
+ (BOOL)instancesRespondToSelector: (SEL)selector;

/**
 * \brief Checks whether the class conforms to a given protocol.
/*!
 * @brief Checks whether the class conforms to a given protocol.
 *
 * \param protocol The protocol which should be checked for conformance
 * \return A boolean whether the class conforms to the specified protocol
 * @param protocol The protocol which should be checked for conformance
 * @return A boolean whether the class conforms to the specified protocol
 */
+ (BOOL)conformsToProtocol: (Protocol*)protocol;

/**
 * \brief Returns the implementation of the instance method for the specified
/*!
 * @brief Returns the implementation of the instance method for the specified
 *	  selector.
 *
 * \param selector The selector for which the method should be returned
 * \return The implementation of the instance method for the specified selector
 * @param selector The selector for which the method should be returned
 * @return The implementation of the instance method for the specified selector
 *	   or nil if it isn't implemented
 */
+ (IMP)instanceMethodForSelector: (SEL)selector;

/**
 * \brief Returns the type encoding of the instance method for the specified
/*!
 * @brief Returns the type encoding of the instance method for the specified
 *	  selector.
 *
 * \param selector The selector for which the type encoding should be returned
 * \return The type encoding of the instance method for the specified selector
 * @param selector The selector for which the type encoding should be returned
 * @return The type encoding of the instance method for the specified selector
 */
+ (const char*)typeEncodingForInstanceSelector: (SEL)selector;

/**
 * \brief Returns a description for the class, which is usually the class name.
/*!
 * @brief Returns a description for the class, which is usually the class name.
 *
 * This is mostly for debugging purposes.
 *
 * \return A description for the class, which is usually the class name
 * @return A description for the class, which is usually the class name
 */
+ (OFString*)description;

/**
 * \brief Replaces a class method with a class method from another class.
/*!
 * @brief Replaces a class method with a class method from another class.
 *
 * \param selector The selector of the class method to replace
 * \param class_ The class from which the new class method should be taken
 * \return The old implementation
 * @param selector The selector of the class method to replace
 * @param class_ The class from which the new class method should be taken
 * @return The old implementation
 */
+ (IMP)replaceClassMethod: (SEL)selector
      withMethodFromClass: (Class)class_;

/**
 * \brief Replaces an instance method with an instance method from another
/*!
 * @brief Replaces an instance method with an instance method from another
 *	  class.
 *
 * \param selector The selector of the instance method to replace
 * \param class_ The class from which the new instance method should be taken
 * \return The old implementation
 * @param selector The selector of the instance method to replace
 * @param class_ The class from which the new instance method should be taken
 * @return The old implementation
 */
+ (IMP)replaceInstanceMethod: (SEL)selector
	 withMethodFromClass: (Class)class_;

/**
 * \brief Replaces or adds a class method.
/*!
 * @brief Replaces or adds a class method.
 *
 * If the method already exists, it is replaced and the old implementation
 * returned. If the method does not exist, it is added with the specified type
 * encoding.
 *
 * \param selector The selector for the new method
 * \param implementation The implementation for the new method
 * \param typeEncoding The type encoding for the new method
 * \return The old implementation or nil if the method was added
 * @param selector The selector for the new method
 * @param implementation The implementation for the new method
 * @param typeEncoding The type encoding for the new method
 * @return The old implementation or nil if the method was added
 */
+ (IMP)replaceClassMethod: (SEL)selector
       withImplementation: (IMP)implementation
	     typeEncoding: (const char*)typeEncoding;

/**
 * \brief Replaces or adds an instance method.
/*!
 * @brief Replaces or adds an instance method.
 *
 * If the method already exists, it is replaced and the old implementation
 * returned. If the method does not exist, it is added with the specified type
 * encoding.
 *
 * \param selector The selector for the new method
 * \param implementation The implementation for the new method
 * \param typeEncoding The type encoding for the new method
 * \return The old implementation or nil if the method was added
 * @param selector The selector for the new method
 * @param implementation The implementation for the new method
 * @param typeEncoding The type encoding for the new method
 * @return The old implementation or nil if the method was added
 */
+ (IMP)replaceInstanceMethod: (SEL)selector
	  withImplementation: (IMP)implementation
		typeEncoding: (const char*)typeEncoding;

/**
 * \brief Adds all methods from the specified class to the class that is the
/*!
 * @brief Adds all methods from the specified class to the class that is the
 *	  receiver.
 *
 * Methods implemented by the receiving class itself will not be overridden,
 * however methods implemented by its superclass will. Therefore it behaves
 * similar as if the specified class is the superclass of the receiver.
 *
 * All methods from the superclasses of the specified class will also be added.
 *
 * If the specified class is a superclass of the receiving class, nothing is
 * done.
 *
 * The methods which will be added from the specified class are not allowed to
 * use super or access instance variables, instead they have to use accessors.
 *
 * \param class The class from which the instance methods should be inherited
 * @param class The class from which the instance methods should be inherited
 */
+ (void)inheritMethodsFromClass: (Class)class_;

/**
 * \brief Try to resolve the specified class method.
/*!
 * @brief Try to resolve the specified class method.
 *
 * This method is called if a class method was not found, so that an
 * implementation can be provided at runtime.
 *
 * \return Whether the method has been added to the class
 * @return Whether the method has been added to the class
 */
+ (BOOL)resolveClassMethod: (SEL)selector;

/**
 * \brief Try to resolve the specified instance method.
/*!
 * @brief Try to resolve the specified instance method.
 *
 * This method is called if an instance method was not found, so that an
 * implementation can be provided at runtime.
 *
 * \return Whether the method has been added to the class
 * @return Whether the method has been added to the class
 */
+ (BOOL)resolveInstanceMethod: (SEL)selector;

/**
 * \brief Initializes an already allocated object.
/*!
 * @brief Initializes an already allocated object.
 *
 * Derived classes may override this, but need to do self = [super init] before
 * they do any initialization themselves. init may never return nil, instead
 * an exception (for example OFInitializationFailed) should be thrown.
 *
 * \return An initialized object
 * @return An initialized object
 */
- init;

/**
 * \brief Returns the name of the object's class.
/*!
 * @brief Returns the name of the object's class.
 *
 * \return The name of the object's class
 * @return The name of the object's class
 */
- (OFString*)className;

/**
 * \brief Returns a description for the object.
/*!
 * @brief Returns a description for the object.
 *
 * This is mostly for debugging purposes.
 *
 * \return A description for the object
 * @return A description for the object
 */
- (OFString*)description;

/**
 * \brief Allocates memory and stores it in the object's memory pool.
/*!
 * @brief Allocates memory and stores it in the object's memory pool.
 *
 * It will be free'd automatically when the object is deallocated.
 *
 * \param size The size of the memory to allocate
 * \return A pointer to the allocated memory
 * @param size The size of the memory to allocate
 * @return A pointer to the allocated memory
 */
- (void*)allocMemoryWithSize: (size_t)size;

/**
 * \brief Allocates memory for the specified number of items and stores it in
/*!
 * @brief Allocates memory for the specified number of items and stores it in
 *	  the object's memory pool.
 *
 * It will be free'd automatically when the object is deallocated.
 *
 * \param size The size of each item to allocate
 * \param count The number of items to allocate
 * \return A pointer to the allocated memory
 * @param size The size of each item to allocate
 * @param count The number of items to allocate
 * @return A pointer to the allocated memory
 */
- (void*)allocMemoryWithSize: (size_t)size
		       count: (size_t)count;

/**
 * \brief Resizes memory in the object's memory pool to the specified size.
/*!
 * @brief Resizes memory in the object's memory pool to the specified size.
 *
 * If the pointer is NULL, this is equivalent to allocating memory.
 * If the size is 0, this is equivalent to freeing memory.
 *
 * \param pointer A pointer to the already allocated memory
 * \param size The new size for the memory chunk
 * \return A pointer to the resized memory chunk
 * @param pointer A pointer to the already allocated memory
 * @param size The new size for the memory chunk
 * @return A pointer to the resized memory chunk
 */
- (void*)resizeMemory: (void*)pointer
		 size: (size_t)size;

/**
 * \brief Resizes memory in the object's memory pool to the specific number of
/*!
 * @brief Resizes memory in the object's memory pool to the specific number of
 *	  items of the specified size.
 *
 * If the pointer is NULL, this is equivalent to allocating memory.
 * If the size or number of items is 0, this is equivalent to freeing memory.
 *
 * \param pointer A pointer to the already allocated memory
 * \param size The size of each item to resize to
 * \param count The number of items to resize to
 * \return A pointer to the resized memory chunk
 * @param pointer A pointer to the already allocated memory
 * @param size The size of each item to resize to
 * @param count The number of items to resize to
 * @return A pointer to the resized memory chunk
 */
- (void*)resizeMemory: (void*)pointer
		 size: (size_t)size
		count: (size_t)count;

/**
 * \brief Frees allocated memory and removes it from the object's memory pool.
/*!
 * @brief Frees allocated memory and removes it from the object's memory pool.
 *
 * Does nothing if the pointer is NULL.
 *
 * \param pointer A pointer to the allocated memory
 * @param pointer A pointer to the allocated memory
 */
- (void)freeMemory: (void*)pointer;

/**
 * \brief Deallocates the object.
/*!
 * @brief Deallocates the object.
 *
 * It is automatically called when the retain count reaches zero.
 *
 * This also frees all memory in its memory pool.
 */
- (void)dealloc;

/**
 * \brief Performs the specified selector after the specified delay.
/*!
 * @brief Performs the specified selector after the specified delay.
 *
 * \param selector The selector to perform
 * \param delay The delay after which the selector will be performed
 * @param selector The selector to perform
 * @param delay The delay after which the selector will be performed
 */
- (void)performSelector: (SEL)selector
	     afterDelay: (double)delay;

/**
 * \brief Performs the specified selector with the specified object after the
/*!
 * @brief Performs the specified selector with the specified object after the
 *	  specified delay.
 *
 * \param selector The selector to perform
 * \param object The object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param object The object that is passed to the method specified by the
 *		 selector
 * \param delay The delay after which the selector will be performed
 * @param delay The delay after which the selector will be performed
 */
- (void)performSelector: (SEL)selector
	     withObject: (id)object
	     afterDelay: (double)delay;

/**
 * \brief Performs the specified selector with the specified objects after the
/*!
 * @brief Performs the specified selector with the specified objects after the
 *	  specified delay.
 *
 * \param selector The selector to perform
 * \param object1 The first object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param object1 The first object that is passed to the method specified by the
 *		 selector
 * \param object2 The second object that is passed to the method specified by
 * @param object2 The second object that is passed to the method specified by
 *		  the selector
 * \param delay The delay after which the selector will be performed
 * @param delay The delay after which the selector will be performed
 */
- (void)performSelector: (SEL)selector
	     withObject: (id)object1
	     withObject: (id)object2
	     afterDelay: (double)delay;

/**
 * \brief Performs the specified selector on the specified thread.
/*!
 * @brief Performs the specified selector on the specified thread.
 *
 * \param selector The selector to perform
 * \param thread The thread on which to perform the selector
 * \param waitUntilDone Whether to wait until the perform finished
 * @param selector The selector to perform
 * @param thread The thread on which to perform the selector
 * @param waitUntilDone Whether to wait until the perform finished
 */
- (void)performSelector: (SEL)selector
	       onThread: (OFThread*)thread
	  waitUntilDone: (BOOL)waitUntilDone;

/**
 * \brief Performs the specified selector on the specified thread with the
/*!
 * @brief Performs the specified selector on the specified thread with the
 *	  specified object.
 *
 * \param selector The selector to perform
 * \param thread The thread on which to perform the selector
 * \param object The object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param thread The thread on which to perform the selector
 * @param object The object that is passed to the method specified by the
 *		 selector
 * \param waitUntilDone Whether to wait until the perform finished
 * @param waitUntilDone Whether to wait until the perform finished
 */
- (void)performSelector: (SEL)selector
	       onThread: (OFThread*)thread
	     withObject: (id)object
	  waitUntilDone: (BOOL)waitUntilDone;

/**
 * \brief Performs the specified selector on the specified thread with the
/*!
 * @brief Performs the specified selector on the specified thread with the
 *	  specified objects.
 *
 * \param selector The selector to perform
 * \param thread The thread on which to perform the selector
 * \param object1 The first object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param thread The thread on which to perform the selector
 * @param object1 The first object that is passed to the method specified by the
 *		 selector
 * \param object2 The second object that is passed to the method specified by
 * @param object2 The second object that is passed to the method specified by
 *		  the selector
 * \param waitUntilDone Whether to wait until the perform finished
 * @param waitUntilDone Whether to wait until the perform finished
 */
- (void)performSelector: (SEL)selector
	       onThread: (OFThread*)thread
	     withObject: (id)object1
	     withObject: (id)object2
	  waitUntilDone: (BOOL)waitUntilDone;

/**
 * \brief Performs the specified selector on the main thread.
/*!
 * @brief Performs the specified selector on the main thread.
 *
 * \param selector The selector to perform
 * \param waitUntilDone Whether to wait until the perform finished
 * @param selector The selector to perform
 * @param waitUntilDone Whether to wait until the perform finished
 */
- (void)performSelectorOnMainThread: (SEL)selector
		      waitUntilDone: (BOOL)waitUntilDone;

/**
 * \brief Performs the specified selector on the main thread with the specified
/*!
 * @brief Performs the specified selector on the main thread with the specified
 *	  object.
 *
 * \param selector The selector to perform
 * \param object The object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param object The object that is passed to the method specified by the
 *		 selector
 * \param waitUntilDone Whether to wait until the perform finished
 * @param waitUntilDone Whether to wait until the perform finished
 */
- (void)performSelectorOnMainThread: (SEL)selector
			 withObject: (id)object
		      waitUntilDone: (BOOL)waitUntilDone;

/**
 * \brief Performs the specified selector on the main thread with the specified
/*!
 * @brief Performs the specified selector on the main thread with the specified
 *	  objects.
 *
 * \param selector The selector to perform
 * \param object1 The first object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param object1 The first object that is passed to the method specified by the
 *		 selector
 * \param object2 The second object that is passed to the method specified by
 * @param object2 The second object that is passed to the method specified by
 *		  the selector
 * \param waitUntilDone Whether to wait until the perform finished
 * @param waitUntilDone Whether to wait until the perform finished
 */
- (void)performSelectorOnMainThread: (SEL)selector
			 withObject: (id)object1
			 withObject: (id)object2
		      waitUntilDone: (BOOL)waitUntilDone;

/**
 * \brief Performs the specified selector on the specified thread after the
/*!
 * @brief Performs the specified selector on the specified thread after the
 *	  specified delay.
 *
 * \param selector The selector to perform
 * \param thread The thread on which to perform the selector
 * \param delay The delay after which the selector will be performed
 * @param selector The selector to perform
 * @param thread The thread on which to perform the selector
 * @param delay The delay after which the selector will be performed
 */
- (void)performSelector: (SEL)selector
	       onThread: (OFThread*)thread
	     afterDelay: (double)delay;

/**
 * \brief Performs the specified selector on the specified thread with the
/*!
 * @brief Performs the specified selector on the specified thread with the
 *	  specified object after the specified delay.
 *
 * \param selector The selector to perform
 * \param thread The thread on which to perform the selector
 * \param object The object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param thread The thread on which to perform the selector
 * @param object The object that is passed to the method specified by the
 *		 selector
 * \param delay The delay after which the selector will be performed
 * @param delay The delay after which the selector will be performed
 */
- (void)performSelector: (SEL)selector
	       onThread: (OFThread*)thread
	     withObject: (id)object
	     afterDelay: (double)delay;

/**
 * \brief Performs the specified selector on the specified thread with the
/*!
 * @brief Performs the specified selector on the specified thread with the
 *	  specified objects after the specified delay.
 *
 * \param selector The selector to perform
 * \param thread The thread on which to perform the selector
 * \param object1 The first object that is passed to the method specified by the
 * @param selector The selector to perform
 * @param thread The thread on which to perform the selector
 * @param object1 The first object that is passed to the method specified by the
 *		 selector
 * \param object2 The second object that is passed to the method specified by
 * @param object2 The second object that is passed to the method specified by
 *		  the selector
 * \param delay The delay after which the selector will be performed
 * @param delay The delay after which the selector will be performed
 */
- (void)performSelector: (SEL)selector
	       onThread: (OFThread*)thread
	     withObject: (id)object1
	     withObject: (id)object2
	     afterDelay: (double)delay;
@end

/**
 * \brief A protocol for the creation of copies.
/*!
 * @brief A protocol for the creation of copies.
 */
@protocol OFCopying
/**
 * \brief Copies the object.
/*!
 * @brief Copies the object.
 *
 * For classes which can be immutable or mutable, this returns an immutable
 * copy. If only a mutable version of the class exists, it creates a mutable
 * copy.
 *
 * \return A copy of the object
 * @return A copy of the object
 */
- copy;
@end

/**
 * \brief A protocol for the creation of mutable copies.
/*!
 * @brief A protocol for the creation of mutable copies.
 *
 * This protocol is implemented by objects that can be mutable and immutable
 * and allows returning a mutable copy.
 */
@protocol OFMutableCopying
/**
 * \brief Creates a mutable copy of the object.
/*!
 * @brief Creates a mutable copy of the object.
 *
 * \return A mutable copy of the object
 * @return A mutable copy of the object
 */
- mutableCopy;
@end

/**
 * \brief A protocol for comparing objects.
/*!
 * @brief A protocol for comparing objects.
 *
 * This protocol is implemented by objects that can be compared.
 */
@protocol OFComparing <OFObject>
/**
 * \brief Compares the object with another object.
/*!
 * @brief Compares the object with another object.
 *
 * \param object An object to compare the object to
 * \return The result of the comparison
 * @param object An object to compare the object to
 * @return The result of the comparison
 */
- (of_comparison_result_t)compare: (id <OFComparing>)object;
@end

#import "OFObject+Serialization.h"

#ifdef __cplusplus