diff options
author | Vince Harron <vharron@google.com> | 2015-06-02 18:58:48 -0700 |
---|---|---|
committer | Vince Harron <vharron@google.com> | 2015-06-02 18:58:48 -0700 |
commit | b46a6ee1ee38582dd3af57ebe1b6d5e4158c34e0 (patch) | |
tree | b342a62eea47f607a7c0846c731bf151c1503359 /share/swig/2.0.11/pike/pikerun.swg | |
parent | 6c85ed3bdac5c6dd65ad8cef83fc4fc7ef99a6c9 (diff) | |
download | linux-x86-studio-1.3-dev.tar.gz |
Adding binaries for 2.0.11HEADstudio-master-dev_before_27917934studio-master-dev_before_26911779studio-3.1.2studio-2.3studio-2.0-rc1studio-2.0studio-1.5studio-1.4gradle_3.1.2gradle_2.3.0gradle_2.0.0studio-master-releasestudio-1.4-releasestudio-1.4-devstudio-1.3-releasestudio-1.3-devmastermain
Diffstat (limited to 'share/swig/2.0.11/pike/pikerun.swg')
-rw-r--r-- | share/swig/2.0.11/pike/pikerun.swg | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/share/swig/2.0.11/pike/pikerun.swg b/share/swig/2.0.11/pike/pikerun.swg new file mode 100644 index 0000000..6ec1143 --- /dev/null +++ b/share/swig/2.0.11/pike/pikerun.swg @@ -0,0 +1,71 @@ +/* ----------------------------------------------------------------------------- + * pikerun.swg + * + * This file contains the runtime support for Pike modules + * and includes code for managing global variables and pointer + * type checking. + * ----------------------------------------------------------------------------- */ + +#ifdef __cplusplus +extern "C" { +#endif +#include "pike/object.h" +#include "pike/program.h" +#ifdef __cplusplus +} +#endif +#include <assert.h> + +/* Stores information about a wrapped object */ +typedef struct swig_object_wrapper { + void *self; + swig_type_info *type; +} swig_object_wrapper; + +#ifdef THIS +#undef THIS +#endif +#define THIS (((swig_object_wrapper *) Pike_fp->current_storage)->self) + +#define SWIG_ConvertPtr SWIG_Pike_ConvertPtr +#define SWIG_NewPointerObj SWIG_Pike_NewPointerObj +#define SWIG_GetModule(clientdata) SWIG_Pike_GetModule(clientdata) +#define SWIG_SetModule(clientdata, pointer) SWIG_Pike_SetModule(pointer) + +/* These need to be filled in before type sharing between modules will work */ +static swig_module_info *SWIG_Pike_GetModule(void *SWIGUNUSEDPARM(clientdata)) { + return 0; +} + +static void SWIG_Pike_SetModule(swig_module_info *pointer) { + +} + +/* Convert a pointer value */ +static int +SWIG_Pike_ConvertPtr(struct object *obj, void **ptr, swig_type_info *ty, int flags) { + struct program *pr; + swig_cast_info *tc; + swig_object_wrapper *obj_wrapper; + + if (ty) { + pr = (struct program *) ty->clientdata; + obj_wrapper = (swig_object_wrapper *) get_storage(obj, pr); + if (obj_wrapper && obj_wrapper->type) { + tc = SWIG_TypeCheckStruct(obj_wrapper->type, ty); + if (tc) { + int newmemory = 0; + *ptr = SWIG_TypeCast(tc, obj_wrapper->self, &newmemory); + assert(!newmemory); /* newmemory handling not yet implemented */ + return 0; + } + } + } + return -1; +} + +/* Create a new pointer object */ +static struct object * +SWIG_Pike_NewPointerObj(void *ptr, swig_type_info *type, int own) { + return 0; +} |