chiark / gitweb /
bug fix in guile wrapper, to match latest C++ api
authorstevenj <stevenj@alum.mit.edu>
Sun, 13 Jun 2010 02:07:26 +0000 (22:07 -0400)
committerstevenj <stevenj@alum.mit.edu>
Sun, 13 Jun 2010 02:07:26 +0000 (22:07 -0400)
darcs-hash:20100613020726-c8de0-c70e2d5c022756ef40e0b493e46dbfb9dcd37849.gz

swig/nlopt-guile.i

index f70b6e0393a567488032311ff8ea0c59e10c53a7..aea311028f30d1cb2eed3f76f8eac08b8696ef75 100644 (file)
@@ -10,7 +10,7 @@ static void *free_guilefunc(void *p) {
 static void *dup_guilefunc(void *p) { 
   scm_gc_protect_object((SCM) p); return p; }
 
-// vfunc wrapper around Guile function (val . grad) = f(x)
+// func wrapper around Guile function (val . grad) = f(x)
 static double func_guile(unsigned n, const double *x, double *grad, void *f) {
   SCM xscm = scm_c_make_vector(n, SCM_UNSPECIFIED);
   for (unsigned i = 0; i < n; ++i)
@@ -36,13 +36,13 @@ static double func_guile(unsigned n, const double *x, double *grad, void *f) {
 }
 %}
 
-%typemap(in)(nlopt::vfunc vf, void *f_data, nlopt_munge md, nlopt_munge mc) {
-  $1 = vfunc_guile;
+%typemap(in)(nlopt::func f, void *f_data, nlopt_munge md, nlopt_munge mc) {
+  $1 = func_guile;
   $2 = dup_guilefunc((void*) $input); // input = SCM pointer to Scheme function
   $3 = free_guilefunc;
   $4 = dup_guilefunc;
 }
-%typecheck(SWIG_TYPECHECK_POINTER)(nlopt::vfunc vf, void *f_data, nlopt_munge md, nlopt_munge mc) {
+%typecheck(SWIG_TYPECHECK_POINTER)(nlopt::func f, void *f_data, nlopt_munge md, nlopt_munge mc) {
   $1 = SCM_NFALSEP(scm_procedure_p($input));
 }