Add support for member function pointers.
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@8617 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
ad0b6ca329
commit
edba3add6b
3 changed files with 101 additions and 0 deletions
|
|
@ -1,6 +1,10 @@
|
|||
Version 1.3.28 (unreleased).
|
||||
===========================
|
||||
|
||||
01/28/2006: mkoeppe
|
||||
[Guile -scm]
|
||||
Add typemaps for handling of member function pointers.
|
||||
|
||||
01/24/2006: mmatus
|
||||
- Better support for the %naturalvar directive, now it
|
||||
works along the scripting languages as well as
|
||||
|
|
|
|||
|
|
@ -48,6 +48,10 @@ typedef struct swig_guile_clientdata {
|
|||
(char *) FUNC_NAME, (char *) msg, \
|
||||
SCM_EOL, SCM_BOOL_F); else
|
||||
|
||||
/* for C++ member pointers, ie, member methods */
|
||||
#define SWIG_ConvertMember(obj, ptr, sz, ty) SWIG_Guile_ConvertMember(obj, ptr, sz, ty, FUNC_NAME)
|
||||
#define SWIG_NewMemberObj(ptr, sz, type) SWIG_Guile_NewMemberObj(ptr, sz, type, FUNC_NAME)
|
||||
|
||||
/* Runtime API */
|
||||
#define SWIG_GetModule(clientdata) SWIG_Guile_GetModule()
|
||||
#define SWIG_SetModule(clientdata, pointer) SWIG_Guile_SetModule(pointer)
|
||||
|
|
@ -75,6 +79,7 @@ static int swig_initialized = 0;
|
|||
static scm_t_bits swig_tag = 0;
|
||||
static scm_t_bits swig_collectable_tag = 0;
|
||||
static scm_t_bits swig_destroyed_tag = 0;
|
||||
static scm_t_bits swig_member_function_tag = 0;
|
||||
static SCM swig_make_func = SCM_EOL;
|
||||
static SCM swig_keyword = SCM_EOL;
|
||||
static SCM swig_symbol = SCM_EOL;
|
||||
|
|
@ -224,6 +229,40 @@ SWIG_Guile_MarkPointerDestroyed(SCM s)
|
|||
}
|
||||
}
|
||||
|
||||
/* Member functions */
|
||||
|
||||
static SCM
|
||||
SWIG_Guile_NewMemberObj(void *ptr, size_t sz, swig_type_info *type,
|
||||
const char *func_name)
|
||||
{
|
||||
SCM smob;
|
||||
void *copy = malloc(sz);
|
||||
memcpy(copy, ptr, sz);
|
||||
SCM_NEWSMOB2(smob, swig_member_function_tag, copy, (void *) type);
|
||||
return smob;
|
||||
}
|
||||
|
||||
static int
|
||||
SWIG_Guile_ConvertMember(SCM smob, void *ptr, size_t sz, swig_type_info *type,
|
||||
const char *func_name)
|
||||
{
|
||||
swig_cast_info *cast;
|
||||
swig_type_info *from;
|
||||
|
||||
if (SCM_SMOB_PREDICATE(swig_member_function_tag, smob)) {
|
||||
from = (swig_type_info *) SCM_CELL_WORD_2(smob);
|
||||
if (!from) return 1;
|
||||
if (type) {
|
||||
cast = SWIG_TypeCheckStruct(from, type);
|
||||
if (!cast) return 1;
|
||||
}
|
||||
memcpy(ptr, (void *) SCM_CELL_WORD_1(smob), sz);
|
||||
return 0;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
/* Init */
|
||||
|
||||
static int
|
||||
|
|
@ -266,6 +305,23 @@ print_destroyed_swig (SCM swig_smob, SCM port, scm_print_state *pstate)
|
|||
return print_swig_aux(swig_smob, port, pstate, "destroyed-");
|
||||
}
|
||||
|
||||
static int
|
||||
print_member_function_swig (SCM swig_smob, SCM port, scm_print_state *pstate)
|
||||
{
|
||||
swig_type_info *type;
|
||||
type = (swig_type_info *) SCM_CELL_WORD_2(swig_smob);
|
||||
if (type) {
|
||||
scm_puts((char *) "#<", port);
|
||||
scm_puts((char *) "swig-member-function-pointer ", port);
|
||||
scm_puts((char *) SWIG_TypePrettyName(type), port);
|
||||
scm_puts((char *) " >", port);
|
||||
/* non-zero means success */
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
static SCM
|
||||
equalp_swig (SCM A, SCM B)
|
||||
{
|
||||
|
|
@ -286,6 +342,12 @@ free_swig(SCM A)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static size_t
|
||||
free_swig_member_function(SCM A)
|
||||
{
|
||||
free((swig_type_info *) SCM_CELL_WORD_1(A));
|
||||
}
|
||||
|
||||
static int
|
||||
ensure_smob_tag(SCM swig_module,
|
||||
scm_t_bits *tag_variable,
|
||||
|
|
@ -333,6 +395,11 @@ SWIG_Guile_Init ()
|
|||
scm_set_smob_print(swig_destroyed_tag, print_destroyed_swig);
|
||||
scm_set_smob_equalp(swig_destroyed_tag, equalp_swig);
|
||||
}
|
||||
if (ensure_smob_tag(swig_module, &swig_member_function_tag,
|
||||
"swig-member-function-pointer", "swig-member-function-pointer-tag")) {
|
||||
scm_set_smob_print(swig_member_function_tag, print_member_function_swig);
|
||||
scm_set_smob_free(swig_member_function_tag, free_swig_member_function);
|
||||
}
|
||||
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"));
|
||||
|
|
|
|||
|
|
@ -346,6 +346,36 @@ typedef unsigned long SCM;
|
|||
$2 = ($2_ltype) temp;
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------
|
||||
* CLASS::* (member function pointer) typemaps
|
||||
* taken from typemaps/swigtype.swg
|
||||
* ------------------------------------------------------------ */
|
||||
|
||||
#define %set_output(obj) $result = obj
|
||||
#define %set_varoutput(obj) $result = obj
|
||||
|
||||
%typemap(in) SWIGTYPE (CLASS::*) {
|
||||
int res = SWIG_ConvertMember($input, (void*)(&$1), sizeof($type),$descriptor);
|
||||
if (res) {
|
||||
scm_wrong_type_arg((char *) FUNC_NAME, $argnum, $input);
|
||||
}
|
||||
}
|
||||
|
||||
%typemap(out,noblock=1) SWIGTYPE (CLASS::*) {
|
||||
%set_output(SWIG_NewMemberObj((void*)(&$1), sizeof($type), $descriptor));
|
||||
}
|
||||
|
||||
%typemap(varin) SWIGTYPE (CLASS::*) {
|
||||
int res = SWIG_ConvertMember($input,(void*)(&$1), sizeof($type), $descriptor);
|
||||
if (!SWIG_IsOK(res)) {
|
||||
scm_wrong_type_arg((char *) FUNC_NAME, 1, $input);
|
||||
}
|
||||
}
|
||||
|
||||
%typemap(varout,noblock=1) SWIGTYPE (CLASS::*) {
|
||||
%set_varoutput(SWIG_NewMemberObj((void*)(&$1), sizeof($type), $descriptor));
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------
|
||||
* Typechecking rules
|
||||
* ------------------------------------------------------------ */
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue