diff options
author | Matthias Köppe <mkoeppe@mail.math.uni-magdeburg.de> | 2004-05-17 15:47:45 +0000 |
---|---|---|
committer | Matthias Köppe <mkoeppe@mail.math.uni-magdeburg.de> | 2004-05-17 15:47:45 +0000 |
commit | 2593d326f6dfadc326d5f14a42e86ae4d928c8dd (patch) | |
tree | 9c879277c7579da7ae0d59d25792548b9707ad71 /Lib/guile/guile_scm_run.swg | |
parent | c25bb79fdb5c49af1eb41b6252f1415a300799dd (diff) | |
download | swig-2593d326f6dfadc326d5f14a42e86ae4d928c8dd.tar.gz |
04/24/2004: mkoeppe (Matthias Koeppe)
[Guile] New runtime functions SWIG_PointerAddress,
SWIG_PointerType, SWIG_IsPointerOfType, SWIG_IsPointer.
[Guile] In -scm mode, wrap several SWIG runtime functions
and export them into the module (Swig swigrun). The
runtime module is now built with "module" linkage.
[Guile] GOOPS proxy objects now also print the pointer
address of the C object.
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@5912 626c5289-ae23-0410-ae9c-e8d60b6d4f22
Diffstat (limited to 'Lib/guile/guile_scm_run.swg')
-rw-r--r-- | Lib/guile/guile_scm_run.swg | 99 |
1 files changed, 80 insertions, 19 deletions
diff --git a/Lib/guile/guile_scm_run.swg b/Lib/guile/guile_scm_run.swg index 536a56202..c02190cc1 100644 --- a/Lib/guile/guile_scm_run.swg +++ b/Lib/guile/guile_scm_run.swg @@ -34,6 +34,14 @@ typedef struct swig_guile_clientdata { SWIG_Guile_MustGetPtr(s, type, argnum, flags, FUNC_NAME) #define SWIG_NewPointerObj(ptr, type, owner) \ SWIG_Guile_NewPointerObj((void*)ptr, type, owner) +#define SWIG_PointerAddress(object) \ + SWIG_Guile_PointerAddress(object) +#define SWIG_PointerType(object) \ + SWIG_Guile_PointerType(object) +#define SWIG_IsPointerOfType(object, type) \ + SWIG_Guile_IsPointerOfType(object, type) +#define SWIG_IsPointer(object) \ + SWIG_Guile_IsPointer(object) #define SWIG_PropagateClientData(type) \ SWIG_Guile_PropagateClientData(type) #define SWIG_contract_assert(expr, msg) \ @@ -68,7 +76,16 @@ SWIG_Guile_MarkPointerNoncollectable(SCM s); /* Mark a pointer object destroyed */ SWIGIMPORT(void) SWIG_Guile_MarkPointerDestroyed(SCM s); - +/* Access type and address of a pointer object. */ +SWIGIMPORT(unsigned long) +SWIG_Guile_PointerAddress(SCM object); +SWIGIMPORT(swig_type_info *) +SWIG_Guile_PointerType(SCM object); +SWIGIMPORT(int) +SWIG_Guile_IsPointer(SCM object); +SWIGIMPORT(int) +SWIG_Guile_IsPointerOfType(SCM object, swig_type_info *type); + #else SWIGRUNTIME(char *) @@ -130,6 +147,32 @@ SWIG_Guile_NewPointerObj(void *ptr, swig_type_info *type, int owner) } } +SWIGRUNTIME(unsigned long) +SWIG_Guile_PointerAddress(SCM object) +{ + SCM smob = SWIG_Guile_GetSmob(object); + if (SCM_NULLP(smob)) return 0; + else if (SCM_SMOB_PREDICATE(swig_tag, smob) + || SCM_SMOB_PREDICATE(swig_collectable_tag, smob) + || SCM_SMOB_PREDICATE(swig_destroyed_tag, smob)) { + return (unsigned long) (void *) SCM_CELL_WORD_1(smob); + } + else scm_wrong_type_arg("SWIG-Guile-PointerAddress", 1, object); +} + +SWIGRUNTIME(swig_type_info *) +SWIG_Guile_PointerType(SCM object) +{ + SCM smob = SWIG_Guile_GetSmob(object); + if (SCM_NULLP(smob)) return NULL; + else if (SCM_SMOB_PREDICATE(swig_tag, smob) + || SCM_SMOB_PREDICATE(swig_collectable_tag, smob) + || SCM_SMOB_PREDICATE(swig_destroyed_tag, smob)) { + return (swig_type_info *) SCM_CELL_WORD_2(smob); + } + else scm_wrong_type_arg("SWIG-Guile-PointerType", 1, object); +} + /* Return 0 if successful. */ SWIGRUNTIME(int) SWIG_Guile_ConvertPtr(SCM s, void **result, swig_type_info *type, int flags) @@ -173,6 +216,23 @@ SWIG_Guile_MustGetPtr (SCM s, swig_type_info *type, return result; } +SWIGRUNTIME(int) +SWIG_Guile_IsPointerOfType (SCM s, swig_type_info *type) +{ + void *result; + if (SWIG_Guile_ConvertPtr(s, &result, type, 0)) { + /* type mismatch */ + return 0; + } + else return 1; +} + +SWIGRUNTIME(int) +SWIG_Guile_IsPointer (SCM s) +{ + return SWIG_Guile_IsPointerOfType (s, NULL); +} + /* Mark a pointer object non-collectable */ SWIGRUNTIME(void) SWIG_Guile_MarkPointerNoncollectable(SCM s) @@ -264,29 +324,30 @@ free_swig(SCM A) SWIGRUNTIME(void) SWIG_Guile_Init () { - if (!swig_tag) { - swig_tag = scm_make_smob_type((char*)"swig-pointer", 0); - scm_set_smob_print(swig_tag, print_swig); - scm_set_smob_equalp(swig_tag, equalp_swig); - } - - if (!swig_collectable_tag) { - swig_collectable_tag = scm_make_smob_type((char*)"collectable-swig-pointer", 0); - scm_set_smob_print(swig_collectable_tag, print_collectable_swig); - scm_set_smob_equalp(swig_collectable_tag, equalp_swig); - scm_set_smob_free(swig_collectable_tag, free_swig); - } - - if (!swig_destroyed_tag) { - swig_destroyed_tag = scm_make_smob_type((char*)"destroyed-swig-pointer", 0); - scm_set_smob_print(swig_destroyed_tag, print_destroyed_swig); - scm_set_smob_equalp(swig_destroyed_tag, equalp_swig); - } + static int initialized = 0; + if (initialized) return; + initialized = 1; + + swig_tag = scm_make_smob_type((char*)"swig-pointer", 0); + scm_set_smob_print(swig_tag, print_swig); + scm_set_smob_equalp(swig_tag, equalp_swig); + + swig_collectable_tag = scm_make_smob_type((char*)"collectable-swig-pointer", 0); + scm_set_smob_print(swig_collectable_tag, print_collectable_swig); + scm_set_smob_equalp(swig_collectable_tag, equalp_swig); + scm_set_smob_free(swig_collectable_tag, free_swig); + + swig_destroyed_tag = scm_make_smob_type((char*)"destroyed-swig-pointer", 0); + scm_set_smob_print(swig_destroyed_tag, print_destroyed_swig); + scm_set_smob_equalp(swig_destroyed_tag, equalp_swig); swig_make_func = scm_permanent_object( scm_variable_ref(scm_c_module_lookup(scm_c_resolve_module("oop goops"), "make"))); swig_keyword = scm_permanent_object(scm_c_make_keyword((char*) "init-smob")); swig_symbol = scm_permanent_object(scm_str2symbol("swig-smob")); +#ifdef SWIG_INIT_RUNTIME_MODULE + SWIG_INIT_RUNTIME_MODULE +#endif } SWIGRUNTIME(int) |