blob: 0a93aaf88f6090b9e5644405b2d62da2f46316a9 (
plain)
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
|
#import "runtime-compatibility.h"
#import <Foundation/NSException.h>
#import <Foundation/NSNull.h>
#import "MLKSymbol.h"
#define DEFINE_GMP_OPERATION(SIGNATURE, TYPE, GMPOP, RETTYPE, OBJTYPE, CONSTRUCTOR) \
-(RETTYPE *) SIGNATURE \
{ \
TYPE##_t mpval; \
RETTYPE *result; \
\
TYPE##_init (mpval); \
GMPOP; \
result = [OBJTYPE CONSTRUCTOR mpval]; \
TYPE##_clear (mpval); \
\
return result; \
}
static id nullify (id value) __attribute__ ((pure, unused));
static id denullify (id value) __attribute__ ((pure, unused));
static id stringify (id value) __attribute__ ((pure, unused));
static id nullify (id value)
{
if (value)
return value;
else
return [NSNull null];
}
static id denullify (id value)
{
if (value == [NSNull null])
return nil;
else
return value;
}
static id stringify (id thing)
{
// FIXME: Some cases may be missing.
if (!thing)
return @"NIL";
if ([thing isKindOfClass:[NSString class]])
return thing;
else if ([thing isKindOfClass:[MLKSymbol class]])
return [thing name];
[NSException raise:@"MLKTypeError" format:@"Can't coerce %@ to a string.",
[thing descriptionForLisp]];
return nil;
}
|