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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
#endif
#ifdef OF_HAVE_THREADS
OF_CONSTRUCTOR()
{
for (size_t i = 0; i < numSpinlocks; i++)
if (OFSpinlockNew(&spinlocks[i]) != 0)
OBJC_ERROR("Failed to initialize spinlocks!");
}
#endif
id
objc_getProperty(id self, SEL _cmd, ptrdiff_t offset, bool atomic)
{
if (atomic) {
id *ptr = (id *)(void *)((char *)self + offset);
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(ptr);
OFEnsure(OFSpinlockLock(&spinlocks[slot]) == 0);
@try {
return [[*ptr retain] autorelease];
} @finally {
OFEnsure(OFSpinlockUnlock(&spinlocks[slot]) == 0);
}
#else
return [[*ptr retain] autorelease];
#endif
}
return *(id *)(void *)((char *)self + offset);
}
void
objc_setProperty(id self, SEL _cmd, ptrdiff_t offset, id value, bool atomic,
signed char copy)
{
if (atomic) {
id *ptr = (id *)(void *)((char *)self + offset);
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(ptr);
OFEnsure(OFSpinlockLock(&spinlocks[slot]) == 0);
@try {
#endif
id old = *ptr;
switch (copy) {
case 0:
*ptr = [value retain];
break;
case 2:
*ptr = [value mutableCopy];
break;
default:
*ptr = [value copy];
}
[old release];
#ifdef OF_HAVE_THREADS
} @finally {
OFEnsure(OFSpinlockUnlock(&spinlocks[slot]) == 0);
}
#endif
return;
}
id *ptr = (id *)(void *)((char *)self + offset);
|
|
|
>
|
>
|
>
|
>
|
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
#endif
#ifdef OF_HAVE_THREADS
OF_CONSTRUCTOR()
{
for (size_t i = 0; i < numSpinlocks; i++)
if (OFSpinlockNew(&spinlocks[i]) != 0)
OBJC_ERROR("Failed to create spinlocks!");
}
#endif
id
objc_getProperty(id self, SEL _cmd, ptrdiff_t offset, bool atomic)
{
if (atomic) {
id *ptr = (id *)(void *)((char *)self + offset);
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(ptr);
if (OFSpinlockLock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to lock spinlock!");
@try {
return [[*ptr retain] autorelease];
} @finally {
if (OFSpinlockUnlock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to unlock spinlock!");
}
#else
return [[*ptr retain] autorelease];
#endif
}
return *(id *)(void *)((char *)self + offset);
}
void
objc_setProperty(id self, SEL _cmd, ptrdiff_t offset, id value, bool atomic,
signed char copy)
{
if (atomic) {
id *ptr = (id *)(void *)((char *)self + offset);
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(ptr);
if (OFSpinlockLock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to lock spinlock!");
@try {
#endif
id old = *ptr;
switch (copy) {
case 0:
*ptr = [value retain];
break;
case 2:
*ptr = [value mutableCopy];
break;
default:
*ptr = [value copy];
}
[old release];
#ifdef OF_HAVE_THREADS
} @finally {
if (OFSpinlockUnlock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to unlock spinlock!");
}
#endif
return;
}
id *ptr = (id *)(void *)((char *)self + offset);
|
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
|
objc_getPropertyStruct(void *dest, const void *src, ptrdiff_t size, bool atomic,
bool strong)
{
if (atomic) {
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(src);
OFEnsure(OFSpinlockLock(&spinlocks[slot]) == 0);
#endif
memcpy(dest, src, size);
#ifdef OF_HAVE_THREADS
OFEnsure(OFSpinlockUnlock(&spinlocks[slot]) == 0);
#endif
return;
}
memcpy(dest, src, size);
}
void
objc_setPropertyStruct(void *dest, const void *src, ptrdiff_t size, bool atomic,
bool strong)
{
if (atomic) {
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(src);
OFEnsure(OFSpinlockLock(&spinlocks[slot]) == 0);
#endif
memcpy(dest, src, size);
#ifdef OF_HAVE_THREADS
OFEnsure(OFSpinlockUnlock(&spinlocks[slot]) == 0);
#endif
return;
}
memcpy(dest, src, size);
}
|
|
>
|
>
|
>
|
>
|
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
|
objc_getPropertyStruct(void *dest, const void *src, ptrdiff_t size, bool atomic,
bool strong)
{
if (atomic) {
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(src);
if (OFSpinlockLock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to lock spinlock!");
#endif
memcpy(dest, src, size);
#ifdef OF_HAVE_THREADS
if (OFSpinlockUnlock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to unlock spinlock!");
#endif
return;
}
memcpy(dest, src, size);
}
void
objc_setPropertyStruct(void *dest, const void *src, ptrdiff_t size, bool atomic,
bool strong)
{
if (atomic) {
#ifdef OF_HAVE_THREADS
size_t slot = spinlockSlot(src);
if (OFSpinlockLock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to lock spinlock!");
#endif
memcpy(dest, src, size);
#ifdef OF_HAVE_THREADS
if (OFSpinlockUnlock(&spinlocks[slot]) != 0)
OBJC_ERROR("Failed to unlock spinlock!");
#endif
return;
}
memcpy(dest, src, size);
}
|
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
|
if (properties == NULL)
OBJC_ERROR("Not enough memory to copy properties");
i = 0;
for (iter = class->propertyList; iter != NULL; iter = iter->next)
for (unsigned int j = 0; j < iter->count; j++)
properties[i++] = &iter->properties[j];
OFEnsure(i == count);
properties[count] = NULL;
if (outCount != NULL)
*outCount = count;
objc_globalMutex_unlock();
|
>
|
>
>
|
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
|
if (properties == NULL)
OBJC_ERROR("Not enough memory to copy properties");
i = 0;
for (iter = class->propertyList; iter != NULL; iter = iter->next)
for (unsigned int j = 0; j < iter->count; j++)
properties[i++] = &iter->properties[j];
if (i != count)
OBJC_ERROR("Fatal internal inconsistency!");
properties[count] = NULL;
if (outCount != NULL)
*outCount = count;
objc_globalMutex_unlock();
|
254
255
256
257
258
259
260
261
262
263
264
|
BOOL_CASE('D', extendedAttributes, OBJC_PROPERTY_DYNAMIC)
BOOL_CASE('W', extendedAttributes, OBJC_PROPERTY_WEAK)
#undef BOOL_CASE
}
if (nullIsError && ret == NULL)
OBJC_ERROR("Not enough memory to copy property attribute "
"value");
return ret;
}
|
|
|
265
266
267
268
269
270
271
272
273
274
275
|
BOOL_CASE('D', extendedAttributes, OBJC_PROPERTY_DYNAMIC)
BOOL_CASE('W', extendedAttributes, OBJC_PROPERTY_WEAK)
#undef BOOL_CASE
}
if (nullIsError && ret == NULL)
OBJC_ERROR("Not enough memory to copy property attribute "
"value!");
return ret;
}
|