-
Notifications
You must be signed in to change notification settings - Fork 0
/
DKLinkedList.h
88 lines (56 loc) · 3.91 KB
/
DKLinkedList.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/*****************************************************************************************
DKLinkedList.h
Copyright (c) 2014 Derek W. Nylen
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
*****************************************************************************************/
#ifndef _DK_LINKED_LIST_H_
#define _DK_LINKED_LIST_H_
#ifdef __cplusplus
extern "C"
{
#endif
typedef struct DKLinkedList * DKLinkedListRef;
typedef struct DKLinkedList * DKMutableLinkedListRef;
DK_API DKClassRef DKLinkedListClass( void );
DK_API DKClassRef DKMutableLinkedListClass( void );
#define DKEmptyLinkedList() DKAutorelease( DKNew( DKLinkedListClass() ) )
#define DKMutableLinkedList() DKAutorelease( DKNew( DKMutableLinkedListClass() ) )
#define DKLinkedListWithCArray( objects, count ) DKLinkedListInitWithObjects( DKAlloc( DKLinkedListClass() ), objects, count )
#define DKLinkedListWithCollection( collection ) DKLinkedListInitWithCollection( DKAlloc( DKLinkedListClass() ), collection )
#define DKNewMutableLinkedList() DKNew( DKMutableLinkedListClass() )
DK_API DKObjectRef DKLinkedListInitWithVAObjects( DKLinkedListRef _self, va_list objects );
DK_API DKObjectRef DKLinkedListInitWithCArray( DKLinkedListRef _self, DKObjectRef objects[], DKIndex count );
DK_API DKObjectRef DKLinkedListInitWithCollection( DKLinkedListRef _self, DKObjectRef srcCollection );
DK_API DKLinkedListRef DKLinkedListCopy( DKLinkedListRef _self );
DK_API DKMutableLinkedListRef DKLinkedListMutableCopy( DKLinkedListRef _self );
DK_API DKIndex DKLinkedListGetCount( DKLinkedListRef _self );
DK_API DKObjectRef DKLinkedListGetObjectAtIndex( DKLinkedListRef _self, DKIndex index );
DK_API DKIndex DKLinkedListGetObjectsInRange( DKLinkedListRef _self, DKRange range, DKObjectRef objects[] );
DK_API void DKLinkedListAppendCArray( DKMutableLinkedListRef _self, DKObjectRef objects[], DKIndex count );
DK_API void DKLinkedListAppendCollection( DKMutableLinkedListRef _self, DKObjectRef srcCollection );
DK_API void DKLinkedListReplaceRangeWithCArray( DKMutableLinkedListRef _self, DKRange range, DKObjectRef objects[], DKIndex count );
DK_API void DKLinkedListReplaceRangeWithCollection( DKMutableLinkedListRef _self, DKRange range, DKObjectRef srcCollection );
DK_API void DKLinkedListSort( DKMutableLinkedListRef _self, DKCompareFunction cmp );
DK_API void DKLinkedListReverse( DKMutableLinkedListRef _self );
DK_API void DKLinkedListShuffle( DKMutableLinkedListRef _self );
DK_API int DKLinkedListApplyFunction( DKLinkedListRef _self, DKApplierFunction callback, void * context );
DK_API bool DKLinkedListInsertObjectWithPriority( DKMutableLinkedListRef _self, DKObjectRef object, double priority, DKInsertPolicy policy );
DK_API double DKLinkedListGetPriorityOfObjectAtIndex( DKLinkedListRef _self, DKIndex index );
#ifdef __cplusplus
}
#endif
#endif // _DK_LINKED_LIST_H_