diff options
author | Andy Wingo <wingo@pobox.com> | 2014-04-28 11:27:31 +0200 |
---|---|---|
committer | Andy Wingo <wingo@pobox.com> | 2014-04-28 13:03:58 +0200 |
commit | 4b8ce7c75283efa6ac0ce24fc6e1aba99b47944b (patch) | |
tree | e0072c47ea88d57f0b47652e7a447d566d9d983e | |
parent | 682a55d59bff1b79ecce17b2344896efce390565 (diff) |
Add more foreign object interfaces
* libguile/foreign-object.c:
* libguile/foreign-object.h (scm_make_foreign_object_1)
(scm_make_foreign_object_2, scm_make_foreign_object_3)
(scm_make_foreign_object_n): Change to take void * arguments, and to
add a comment to the header indicating that these are convenience
constructors.
* libguile/foreign-object.c:
* libguile/foreign-object.h (scm_foreign_object_unsigned_ref)
(scm_foreign_object_unsigned_set_x): New functions, equivalent to the
old scm_foreign_object_ref and scm_foreign_object_set_x.
* libguile/foreign-object.c:
* libguile/foreign-object.h (scm_foreign_object_signed_ref)
(scm_foreign_object_signed_set_x): New functions taking
scm_t_signed_bits.
* libguile/foreign-object.c:
* libguile/foreign-object.h (scm_foreign_object_ref)
(scm_foreign_object_set_x): New functions that take void*.
-rw-r--r-- | libguile/foreign-object.c | 47 | ||||
-rw-r--r-- | libguile/foreign-object.h | 31 | ||||
-rw-r--r-- | test-suite/standalone/test-foreign-object-c.c | 9 |
3 files changed, 63 insertions, 24 deletions
diff --git a/libguile/foreign-object.c b/libguile/foreign-object.c index 4c81f6da3..830f73f80 100644 --- a/libguile/foreign-object.c +++ b/libguile/foreign-object.c @@ -70,15 +70,15 @@ scm_make_foreign_object_0 (SCM type) } SCM -scm_make_foreign_object_1 (SCM type, scm_t_bits val0) +scm_make_foreign_object_1 (SCM type, void *val0) { return scm_make_foreign_object_n (type, 1, &val0); } SCM -scm_make_foreign_object_2 (SCM type, scm_t_bits val0, scm_t_bits val1) +scm_make_foreign_object_2 (SCM type, void *val0, void *val1) { - scm_t_bits vals[2]; + void *vals[2]; vals[0] = val0; vals[1] = val1; @@ -87,10 +87,9 @@ scm_make_foreign_object_2 (SCM type, scm_t_bits val0, scm_t_bits val1) } SCM -scm_make_foreign_object_3 (SCM type, scm_t_bits val0, scm_t_bits val1, - scm_t_bits val2) +scm_make_foreign_object_3 (SCM type, void *val0, void *val1, void *val2) { - scm_t_bits vals[3]; + void *vals[3]; vals[0] = val0; vals[1] = val1; @@ -100,7 +99,7 @@ scm_make_foreign_object_3 (SCM type, scm_t_bits val0, scm_t_bits val1, } SCM -scm_make_foreign_object_n (SCM type, size_t n, scm_t_bits vals[]) +scm_make_foreign_object_n (SCM type, size_t n, void *vals[]) #define FUNC_NAME "make-foreign-object" { SCM obj; @@ -123,14 +122,14 @@ scm_make_foreign_object_n (SCM type, size_t n, scm_t_bits vals[]) obj = scm_c_make_structv (type, 0, 0, NULL); for (i = 0; i < n; i++) - SCM_STRUCT_DATA_SET (obj, i, vals[i]); + SCM_STRUCT_DATA_SET (obj, i, (scm_t_bits) vals[i]); return obj; } #undef FUNC_NAME scm_t_bits -scm_foreign_object_ref (SCM obj, size_t n) +scm_foreign_object_unsigned_ref (SCM obj, size_t n) #define FUNC_NAME "foreign-object-ref" { SCM layout; @@ -149,7 +148,7 @@ scm_foreign_object_ref (SCM obj, size_t n) #undef FUNC_NAME void -scm_foreign_object_set_x (SCM obj, size_t n, scm_t_bits val) +scm_foreign_object_unsigned_set_x (SCM obj, size_t n, scm_t_bits val) #define FUNC_NAME "foreign-object-set!" { SCM layout; @@ -166,6 +165,34 @@ scm_foreign_object_set_x (SCM obj, size_t n, scm_t_bits val) SCM_STRUCT_DATA_SET (obj, n, val); } #undef FUNC_NAME + +scm_t_signed_bits +scm_foreign_object_signed_ref (SCM obj, size_t n) +{ + scm_t_bits bits = scm_foreign_object_unsigned_ref (obj, n); + return (scm_t_signed_bits) bits; +} + +void +scm_foreign_object_signed_set_x (SCM obj, size_t n, scm_t_signed_bits val) +{ + scm_t_bits bits = (scm_t_bits) val; + scm_foreign_object_unsigned_set_x (obj, n, bits); +} + +void* +scm_foreign_object_ref (SCM obj, size_t n) +{ + scm_t_bits bits = scm_foreign_object_unsigned_ref (obj, n); + return (void *) bits; +} + +void +scm_foreign_object_set_x (SCM obj, size_t n, void *val) +{ + scm_t_bits bits = (scm_t_bits) val; + scm_foreign_object_unsigned_set_x (obj, n, bits); +} static void invoke_finalizer (void *obj, void *data) diff --git a/libguile/foreign-object.h b/libguile/foreign-object.h index 3b7784eb6..806b7eddb 100644 --- a/libguile/foreign-object.h +++ b/libguile/foreign-object.h @@ -32,16 +32,29 @@ SCM_API SCM scm_make_foreign_object_type (SCM name, SCM slot_names, SCM_API void scm_assert_foreign_object_type (SCM type, SCM val); +/* All objects of a given foreign object type have the same number of + fields. When constructing a foreign object, you don't have to pass + initializers for all of the fields; it is always OK to call + scm_make_foreign_object_0 and initialize the fields by hand with + scm_foreign_object_set_x or other setters. The initial value of + fields that haven't been explicitly given a value is 0. */ SCM_API SCM scm_make_foreign_object_0 (SCM type); -SCM_API SCM scm_make_foreign_object_1 (SCM type, scm_t_bits val0); -SCM_API SCM scm_make_foreign_object_2 (SCM type, scm_t_bits val0, - scm_t_bits val1); -SCM_API SCM scm_make_foreign_object_3 (SCM type, scm_t_bits val0, - scm_t_bits val1, scm_t_bits val2); -SCM_API SCM scm_make_foreign_object_n (SCM type, size_t n, scm_t_bits vals[]); - -SCM_API scm_t_bits scm_foreign_object_ref (SCM obj, size_t n); -SCM_API void scm_foreign_object_set_x (SCM obj, size_t n, scm_t_bits val); +SCM_API SCM scm_make_foreign_object_1 (SCM type, void *val0); +SCM_API SCM scm_make_foreign_object_2 (SCM type, void *val0, void *val1); +SCM_API SCM scm_make_foreign_object_3 (SCM type, void *val0, void *val1, + void *val2); +SCM_API SCM scm_make_foreign_object_n (SCM type, size_t n, void *vals[]); + +SCM_API void* scm_foreign_object_ref (SCM obj, size_t n); +SCM_API void scm_foreign_object_set_x (SCM obj, size_t n, void *val); + +SCM_API scm_t_bits scm_foreign_object_unsigned_ref (SCM obj, size_t n); +SCM_API void scm_foreign_object_unsigned_set_x (SCM obj, size_t n, + scm_t_bits val); + +SCM_API scm_t_signed_bits scm_foreign_object_signed_ref (SCM obj, size_t n); +SCM_API void scm_foreign_object_signed_set_x (SCM obj, size_t n, + scm_t_signed_bits val); SCM_INTERNAL void scm_register_foreign_object (void); diff --git a/test-suite/standalone/test-foreign-object-c.c b/test-suite/standalone/test-foreign-object-c.c index 9cd8d6721..613c1f631 100644 --- a/test-suite/standalone/test-foreign-object-c.c +++ b/test-suite/standalone/test-foreign-object-c.c @@ -38,8 +38,7 @@ enum static void finalizer (SCM obj) { - scm_t_bits addr = scm_foreign_object_ref (obj, CSTR_SLOT_ADDR); - free ((void *) addr); + free (scm_foreign_object_ref (obj, CSTR_SLOT_ADDR)); } static SCM @@ -50,7 +49,7 @@ make_cstr_from_static (SCM type, const char *str) if (!ours) abort (); - return scm_make_foreign_object_2 (type, (scm_t_bits) ours, strlen (ours)); + return scm_make_foreign_object_2 (type, ours, (void *) strlen (ours)); } static int @@ -59,8 +58,8 @@ cstr_equals_static_p (SCM cstr, const char *str) const char *addr; size_t len; - addr = (const char *) scm_foreign_object_ref (cstr, CSTR_SLOT_ADDR); - len = scm_foreign_object_ref (cstr, CSTR_SLOT_LEN); + addr = scm_foreign_object_ref (cstr, CSTR_SLOT_ADDR); + len = scm_foreign_object_unsigned_ref (cstr, CSTR_SLOT_LEN); if (strlen (str) != len) return 0; |