File: external-lib.c

package info (click to toggle)
scheme48 1.9.2-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 18,332 kB
  • sloc: lisp: 88,907; ansic: 87,519; sh: 3,224; makefile: 771
file content (106 lines) | stat: -rw-r--r-- 2,912 bytes parent folder | download | duplicates (4)
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
 * Part of Scheme 48 1.9.  See file COPYING for notices and license.
 *
 * Authors: Mike Sperber, Harald Glab-Phlak
 */

/*
 * Access to various Scheme-side libraries via the FFI
 */

#include <stdlib.h>
#include "scheme48.h"

/*
 * Enum sets
 */

static s48_ref_t enum_set_type_binding = NULL;

/*
 * This needs to be in synch with the layout of :ENUM-SET in enum-set.scm
 */

static void
check_enum_set(s48_value sch_thing)
{
  s48_check_record_type(sch_thing, s48_deref(enum_set_type_binding));
}

static void
check_enum_set_2(s48_call_t call, s48_ref_t sch_thing)
{
  s48_check_record_type_2(call, sch_thing, enum_set_type_binding);
}

void
s48_check_enum_set_type(s48_value sch_thing, s48_value sch_enum_set_type_binding)
{
  check_enum_set(sch_thing);
  {
    s48_value actual_type = S48_UNSAFE_RECORD_REF(sch_thing, 0);
    s48_value binding_val = S48_SHARED_BINDING_REF(sch_enum_set_type_binding);
    s48_value unspecific = S48_UNSPECIFIC;
  
      
  if (!S48_EQ_P(S48_UNSAFE_RECORD_REF(sch_thing, 0),
		S48_SHARED_BINDING_REF(sch_enum_set_type_binding)))
    s48_assertion_violation("s48_check_enum_set_type", "invalid enum-set type", 2,
			    sch_thing, binding_val);
  }
}

void
s48_check_enum_set_type_2(s48_call_t call, s48_ref_t sch_thing, s48_ref_t sch_enum_set_type_binding)
{
  check_enum_set_2(call, sch_thing);
  {
    s48_ref_t actual_type = s48_unsafe_record_ref_2(call, sch_thing, 0);
    s48_ref_t binding_val = s48_shared_binding_ref_2(call, sch_enum_set_type_binding);
      
    if (!s48_eq_p_2(call, actual_type, binding_val))
      s48_assertion_violation_2(call, "s48_check_enum_set_type_2",
				"invalid enum-set type", 2,
				sch_thing, binding_val);
  }
}

long
s48_enum_set2integer(s48_value sch_enum_set)
{
  check_enum_set(sch_enum_set);
  return s48_extract_fixnum(S48_UNSAFE_RECORD_REF(sch_enum_set, 1));
}

long
s48_enum_set2integer_2(s48_call_t call, s48_ref_t sch_enum_set)
{
  check_enum_set_2(call, sch_enum_set);
  return s48_extract_long_2(call, s48_unsafe_record_ref_2(call, sch_enum_set, 1));
}

s48_value
s48_integer2enum_set(s48_value sch_enum_set_type_binding, long mask)
{
  s48_value sch_enum_set = s48_make_record(s48_deref(enum_set_type_binding));
  S48_UNSAFE_RECORD_SET(sch_enum_set, 0, S48_SHARED_BINDING_REF(sch_enum_set_type_binding));
  S48_UNSAFE_RECORD_SET(sch_enum_set, 1, s48_enter_fixnum(mask));
  return sch_enum_set;
}

s48_ref_t
s48_integer2enum_set_2(s48_call_t call, s48_ref_t sch_enum_set_type_binding, long mask)
{
  s48_ref_t sch_enum_set = s48_make_record_2(call, enum_set_type_binding);
  s48_unsafe_record_set_2(call, sch_enum_set, 0, 
			  s48_shared_binding_ref_2(call, sch_enum_set_type_binding));
  s48_unsafe_record_set_2(call, sch_enum_set, 1,
			  s48_enter_long_as_fixnum_2(call, mask));
  return sch_enum_set;
}

void
s48_init_external_libs(void)
{
  enum_set_type_binding = s48_get_imported_binding_2("enum-set-type");
}