/* ---------------------------------------------------------------------------- * This file was automatically generated by SWIG (http://www.swig.org). * Version 1.3.27 * * This file is not intended to be easily readable and contains a number of * coding conventions designed to improve portability and efficiency. Do not make * changes to this file unless you know what you are doing--modify the SWIG * interface file instead. * ----------------------------------------------------------------------------- */ /*********************************************************************** * * This section contains generic SWIG labels for method/variable * declarations/attributes, and other compiler dependent labels. * ************************************************************************/ /* template workaround for compilers that cannot correctly implement the C++ standard */ #ifndef SWIGTEMPLATEDISAMBIGUATOR # if defined(__SUNPRO_CC) && (__SUNPRO_CC <= 0x560) # define SWIGTEMPLATEDISAMBIGUATOR template # else # define SWIGTEMPLATEDISAMBIGUATOR # endif #endif /* inline attribute */ #ifndef SWIGINLINE # if defined(__cplusplus) || (defined(__GNUC__) && !defined(__STRICT_ANSI__)) # define SWIGINLINE inline # else # define SWIGINLINE # endif #endif /* attribute recognised by some compilers to avoid 'unused' warnings */ #ifndef SWIGUNUSED # if defined(__GNUC__) || defined(__ICC) # define SWIGUNUSED __attribute__ ((unused)) # else # define SWIGUNUSED # endif #endif /* internal SWIG method */ #ifndef SWIGINTERN # define SWIGINTERN static SWIGUNUSED #endif /* internal inline SWIG method */ #ifndef SWIGINTERNINLINE # define SWIGINTERNINLINE SWIGINTERN SWIGINLINE #endif /* exporting methods for Windows DLLs */ #ifndef SWIGEXPORT # if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__) # if defined(STATIC_LINKED) # define SWIGEXPORT # else # define SWIGEXPORT __declspec(dllexport) # endif # else # define SWIGEXPORT # endif #endif /* calling conventions for Windows */ #ifndef SWIGSTDCALL # if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__) # define SWIGSTDCALL __stdcall # else # define SWIGSTDCALL # endif #endif /*********************************************************************** * swigrun.swg * * This file contains generic CAPI SWIG runtime support for pointer * type checking. * ************************************************************************/ /* This should only be incremented when either the layout of swig_type_info changes, or for whatever reason, the runtime changes incompatibly */ #define SWIG_RUNTIME_VERSION "2" /* define SWIG_TYPE_TABLE_NAME as "SWIG_TYPE_TABLE" */ #ifdef SWIG_TYPE_TABLE # define SWIG_QUOTE_STRING(x) #x # define SWIG_EXPAND_AND_QUOTE_STRING(x) SWIG_QUOTE_STRING(x) # define SWIG_TYPE_TABLE_NAME SWIG_EXPAND_AND_QUOTE_STRING(SWIG_TYPE_TABLE) #else # define SWIG_TYPE_TABLE_NAME #endif /* You can use the SWIGRUNTIME and SWIGRUNTIMEINLINE macros for creating a static or dynamic library from the swig runtime code. In 99.9% of the cases, swig just needs to declare them as 'static'. But only do this if is strictly necessary, ie, if you have problems with your compiler or so. */ #ifndef SWIGRUNTIME # define SWIGRUNTIME SWIGINTERN #endif #ifndef SWIGRUNTIMEINLINE # define SWIGRUNTIMEINLINE SWIGRUNTIME SWIGINLINE #endif #include #ifdef __cplusplus extern "C" { #endif typedef void *(*swig_converter_func)(void *); typedef struct swig_type_info *(*swig_dycast_func)(void **); /* Structure to store inforomation on one type */ typedef struct swig_type_info { const char *name; /* mangled name of this type */ const char *str; /* human readable name of this type */ swig_dycast_func dcast; /* dynamic cast function down a hierarchy */ struct swig_cast_info *cast; /* linked list of types that can cast into this type */ void *clientdata; /* language specific type data */ } swig_type_info; /* Structure to store a type and conversion function used for casting */ typedef struct swig_cast_info { swig_type_info *type; /* pointer to type that is equivalent to this type */ swig_converter_func converter; /* function to cast the void pointers */ struct swig_cast_info *next; /* pointer to next cast in linked list */ struct swig_cast_info *prev; /* pointer to the previous cast */ } swig_cast_info; /* Structure used to store module information * Each module generates one structure like this, and the runtime collects * all of these structures and stores them in a circularly linked list.*/ typedef struct swig_module_info { swig_type_info **types; /* Array of pointers to swig_type_info structures that are in this module */ size_t size; /* Number of types in this module */ struct swig_module_info *next; /* Pointer to next element in circularly linked list */ swig_type_info **type_initial; /* Array of initially generated type structures */ swig_cast_info **cast_initial; /* Array of initially generated casting structures */ void *clientdata; /* Language specific module data */ } swig_module_info; /* Compare two type names skipping the space characters, therefore "char*" == "char *" and "Class" == "Class", etc. Return 0 when the two name types are equivalent, as in strncmp, but skipping ' '. */ SWIGRUNTIME int SWIG_TypeNameComp(const char *f1, const char *l1, const char *f2, const char *l2) { for (;(f1 != l1) && (f2 != l2); ++f1, ++f2) { while ((*f1 == ' ') && (f1 != l1)) ++f1; while ((*f2 == ' ') && (f2 != l2)) ++f2; if (*f1 != *f2) return (int)(*f1 - *f2); } return (l1 - f1) - (l2 - f2); } /* Check type equivalence in a name list like ||... Return 0 if not equal, 1 if equal */ SWIGRUNTIME int SWIG_TypeEquiv(const char *nb, const char *tb) { int equiv = 0; const char* te = tb + strlen(tb); const char* ne = nb; while (!equiv && *ne) { for (nb = ne; *ne; ++ne) { if (*ne == '|') break; } equiv = (SWIG_TypeNameComp(nb, ne, tb, te) == 0) ? 1 : 0; if (*ne) ++ne; } return equiv; } /* Check type equivalence in a name list like ||... Return 0 if equal, -1 if nb < tb, 1 if nb > tb */ SWIGRUNTIME int SWIG_TypeCompare(const char *nb, const char *tb) { int equiv = 0; const char* te = tb + strlen(tb); const char* ne = nb; while (!equiv && *ne) { for (nb = ne; *ne; ++ne) { if (*ne == '|') break; } equiv = (SWIG_TypeNameComp(nb, ne, tb, te) == 0) ? 1 : 0; if (*ne) ++ne; } return equiv; } /* think of this as a c++ template<> or a scheme macro */ #define SWIG_TypeCheck_Template(comparison, ty) \ if (ty) { \ swig_cast_info *iter = ty->cast; \ while (iter) { \ if (comparison) { \ if (iter == ty->cast) return iter; \ /* Move iter to the top of the linked list */ \ iter->prev->next = iter->next; \ if (iter->next) \ iter->next->prev = iter->prev; \ iter->next = ty->cast; \ iter->prev = 0; \ if (ty->cast) ty->cast->prev = iter; \ ty->cast = iter; \ return iter; \ } \ iter = iter->next; \ } \ } \ return 0 /* Check the typename */ SWIGRUNTIME swig_cast_info * SWIG_TypeCheck(const char *c, swig_type_info *ty) { SWIG_TypeCheck_Template(strcmp(iter->type->name, c) == 0, ty); } /* Same as previous function, except strcmp is replaced with a pointer comparison */ SWIGRUNTIME swig_cast_info * SWIG_TypeCheckStruct(swig_type_info *from, swig_type_info *into) { SWIG_TypeCheck_Template(iter->type == from, into); } /* Cast a pointer up an inheritance hierarchy */ SWIGRUNTIMEINLINE void * SWIG_TypeCast(swig_cast_info *ty, void *ptr) { return ((!ty) || (!ty->converter)) ? ptr : (*ty->converter)(ptr); } /* Dynamic pointer casting. Down an inheritance hierarchy */ SWIGRUNTIME swig_type_info * SWIG_TypeDynamicCast(swig_type_info *ty, void **ptr) { swig_type_info *lastty = ty; if (!ty || !ty->dcast) return ty; while (ty && (ty->dcast)) { ty = (*ty->dcast)(ptr); if (ty) lastty = ty; } return lastty; } /* Return the name associated with this type */ SWIGRUNTIMEINLINE const char * SWIG_TypeName(const swig_type_info *ty) { return ty->name; } /* Return the pretty name associated with this type, that is an unmangled type name in a form presentable to the user. */ SWIGRUNTIME const char * SWIG_TypePrettyName(const swig_type_info *type) { /* The "str" field contains the equivalent pretty names of the type, separated by vertical-bar characters. We choose to print the last name, as it is often (?) the most specific. */ if (type->str != NULL) { const char *last_name = type->str; const char *s; for (s = type->str; *s; s++) if (*s == '|') last_name = s+1; return last_name; } else return type->name; } /* Set the clientdata field for a type */ SWIGRUNTIME void SWIG_TypeClientData(swig_type_info *ti, void *clientdata) { swig_cast_info *cast = ti->cast; /* if (ti->clientdata == clientdata) return; */ ti->clientdata = clientdata; while (cast) { if (!cast->converter) { swig_type_info *tc = cast->type; if (!tc->clientdata) { SWIG_TypeClientData(tc, clientdata); } } cast = cast->next; } } /* Search for a swig_type_info structure only by mangled name Search is a O(log #types) We start searching at module start, and finish searching when start == end. Note: if start == end at the beginning of the function, we go all the way around the circular list. */ SWIGRUNTIME swig_type_info * SWIG_MangledTypeQueryModule(swig_module_info *start, swig_module_info *end, const char *name) { swig_module_info *iter = start; do { if (iter->size) { register size_t l = 0; register size_t r = iter->size - 1; do { /* since l+r >= 0, we can (>> 1) instead (/ 2) */ register size_t i = (l + r) >> 1; const char *iname = iter->types[i]->name; if (iname) { register int compare = strcmp(name, iname); if (compare == 0) { return iter->types[i]; } else if (compare < 0) { if (i) { r = i - 1; } else { break; } } else if (compare > 0) { l = i + 1; } } else { break; /* should never happen */ } } while (l <= r); } iter = iter->next; } while (iter != end); return 0; } /* Search for a swig_type_info structure for either a mangled name or a human readable name. It first searches the mangled names of the types, which is a O(log #types) If a type is not found it then searches the human readable names, which is O(#types). We start searching at module start, and finish searching when start == end. Note: if start == end at the beginning of the function, we go all the way around the circular list. */ SWIGRUNTIME swig_type_info * SWIG_TypeQueryModule(swig_module_info *start, swig_module_info *end, const char *name) { /* STEP 1: Search the name field using binary search */ swig_type_info *ret = SWIG_MangledTypeQueryModule(start, end, name); if (ret) { return ret; } else { /* STEP 2: If the type hasn't been found, do a complete search of the str field (the human readable name) */ swig_module_info *iter = start; do { register size_t i = 0; for (; i < iter->size; ++i) { if (iter->types[i]->str && (SWIG_TypeEquiv(iter->types[i]->str, name))) return iter->types[i]; } iter = iter->next; } while (iter != end); } /* neither found a match */ return 0; } /* Pack binary data into a string */ SWIGRUNTIME char * SWIG_PackData(char *c, void *ptr, size_t sz) { static const char hex[17] = "0123456789abcdef"; register const unsigned char *u = (unsigned char *) ptr; register const unsigned char *eu = u + sz; for (; u != eu; ++u) { register unsigned char uu = *u; *(c++) = hex[(uu & 0xf0) >> 4]; *(c++) = hex[uu & 0xf]; } return c; } /* Unpack binary data from a string */ SWIGRUNTIME const char * SWIG_UnpackData(const char *c, void *ptr, size_t sz) { register unsigned char *u = (unsigned char *) ptr; register const unsigned char *eu = u + sz; for (; u != eu; ++u) { register char d = *(c++); register unsigned char uu = 0; if ((d >= '0') && (d <= '9')) uu = ((d - '0') << 4); else if ((d >= 'a') && (d <= 'f')) uu = ((d - ('a'-10)) << 4); else return (char *) 0; d = *(c++); if ((d >= '0') && (d <= '9')) uu |= (d - '0'); else if ((d >= 'a') && (d <= 'f')) uu |= (d - ('a'-10)); else return (char *) 0; *u = uu; } return c; } /* Pack 'void *' into a string buffer. */ SWIGRUNTIME char * SWIG_PackVoidPtr(char *buff, void *ptr, const char *name, size_t bsz) { char *r = buff; if ((2*sizeof(void *) + 2) > bsz) return 0; *(r++) = '_'; r = SWIG_PackData(r,&ptr,sizeof(void *)); if (strlen(name) + 1 > (bsz - (r - buff))) return 0; strcpy(r,name); return buff; } SWIGRUNTIME const char * SWIG_UnpackVoidPtr(const char *c, void **ptr, const char *name) { if (*c != '_') { if (strcmp(c,"NULL") == 0) { *ptr = (void *) 0; return name; } else { return 0; } } return SWIG_UnpackData(++c,ptr,sizeof(void *)); } SWIGRUNTIME char * SWIG_PackDataName(char *buff, void *ptr, size_t sz, const char *name, size_t bsz) { char *r = buff; size_t lname = (name ? strlen(name) : 0); if ((2*sz + 2 + lname) > bsz) return 0; *(r++) = '_'; r = SWIG_PackData(r,ptr,sz); if (lname) { strncpy(r,name,lname+1); } else { *r = 0; } return buff; } SWIGRUNTIME const char * SWIG_UnpackDataName(const char *c, void *ptr, size_t sz, const char *name) { if (*c != '_') { if (strcmp(c,"NULL") == 0) { memset(ptr,0,sz); return name; } else { return 0; } } return SWIG_UnpackData(++c,ptr,sz); } #ifdef __cplusplus } #endif /* ---------------------------------------------------------------------- -*- c -*- * perl5.swg * * Perl5 runtime library * $Header: /cvsroot/swig/SWIG/Lib/perl5/perlrun.swg,v 1.21 2005/02/01 00:08:17 wuzzeb Exp $ * ----------------------------------------------------------------------------- */ #define SWIGPERL #define SWIGPERL5 #ifdef __cplusplus /* Needed on some windows machines---since MS plays funny games with the header files under C++ */ #include #include extern "C" { #endif #include "EXTERN.h" #include "perl.h" #include "XSUB.h" /* Get rid of free and malloc defined by perl */ #undef free #undef malloc #ifndef pTHX_ #define pTHX_ #endif #include #ifdef __cplusplus } #endif /* Macro to call an XS function */ #ifdef PERL_OBJECT # define SWIG_CALLXS(_name) _name(cv,pPerl) #else # ifndef MULTIPLICITY # define SWIG_CALLXS(_name) _name(cv) # else # define SWIG_CALLXS(_name) _name(PERL_GET_THX, cv) # endif #endif /* Contract support */ #define SWIG_contract_assert(expr,msg) if (!(expr)) { SWIG_croak(msg); } else /* Note: SwigMagicFuncHack is a typedef used to get the C++ compiler to just shut up already */ #ifdef PERL_OBJECT #define MAGIC_PPERL CPerlObj *pPerl = (CPerlObj *) this; typedef int (CPerlObj::*SwigMagicFunc)(SV *, MAGIC *); #ifdef __cplusplus extern "C" { #endif typedef int (CPerlObj::*SwigMagicFuncHack)(SV *, MAGIC *); #ifdef __cplusplus } #endif #define SWIG_MAGIC(a,b) (SV *a, MAGIC *b) #define SWIGCLASS_STATIC #else #define MAGIC_PPERL #define SWIGCLASS_STATIC static #ifndef MULTIPLICITY #define SWIG_MAGIC(a,b) (SV *a, MAGIC *b) typedef int (*SwigMagicFunc)(SV *, MAGIC *); #ifdef __cplusplus extern "C" { #endif typedef int (*SwigMagicFuncHack)(SV *, MAGIC *); #ifdef __cplusplus } #endif #else #define SWIG_MAGIC(a,b) (struct interpreter *interp, SV *a, MAGIC *b) typedef int (*SwigMagicFunc)(struct interpreter *, SV *, MAGIC *); #ifdef __cplusplus extern "C" { #endif typedef int (*SwigMagicFuncHack)(struct interpreter *, SV *, MAGIC *); #ifdef __cplusplus } #endif #endif #endif #if defined(WIN32) && defined(PERL_OBJECT) && !defined(PerlIO_exportFILE) #define PerlIO_exportFILE(fh,fl) (FILE*)(fh) #endif /* Modifications for newer Perl 5.005 releases */ #if !defined(PERL_REVISION) || ((PERL_REVISION >= 5) && ((PERL_VERSION < 5) || ((PERL_VERSION == 5) && (PERL_SUBVERSION < 50)))) # ifndef PL_sv_yes # define PL_sv_yes sv_yes # endif # ifndef PL_sv_undef # define PL_sv_undef sv_undef # endif # ifndef PL_na # define PL_na na # endif #endif #include #ifdef __cplusplus extern "C" { #endif #define SWIG_OWNER 1 #define SWIG_SHADOW 2 /* Common SWIG API */ #ifdef PERL_OBJECT # define SWIG_ConvertPtr(obj, pp, type, flags) \ SWIG_Perl_ConvertPtr(pPerl, obj, pp, type, flags) # define SWIG_NewPointerObj(p, type, flags) \ SWIG_Perl_NewPointerObj(pPerl, p, type, flags) # define SWIG_MakePackedObj(sv, p, s, type) \ SWIG_Perl_MakePackedObj(pPerl, sv, p, s, type) # define SWIG_ConvertPacked(obj, p, s, type, flags) \ SWIG_Perl_ConvertPacked(pPerl, obj, p, s, type, flags) #else # define SWIG_ConvertPtr(obj, pp, type, flags) \ SWIG_Perl_ConvertPtr(obj, pp, type, flags) # define SWIG_NewPointerObj(p, type, flags) \ SWIG_Perl_NewPointerObj(p, type, flags) # define SWIG_MakePackedObj(sv, p, s, type) \ SWIG_Perl_MakePackedObj(sv, p, s, type ) # define SWIG_ConvertPacked(obj, p, s, type, flags) \ SWIG_Perl_ConvertPacked(obj, p, s, type, flags) #endif /* Runtime API */ #define SWIG_GetModule(clientdata) SWIG_Perl_GetModule() #define SWIG_SetModule(clientdata, pointer) SWIG_Perl_SetModule(pointer) /* Perl-specific API */ #ifdef PERL_OBJECT # define SWIG_MakePtr(sv, ptr, type, flags) \ SWIG_Perl_MakePtr(pPerl, sv, ptr, type, flags) # define SWIG_SetError(str) \ SWIG_Perl_SetError(pPerl, str) #else # define SWIG_MakePtr(sv, ptr, type, flags) \ SWIG_Perl_MakePtr(sv, ptr, type, flags) # define SWIG_SetError(str) \ SWIG_Perl_SetError(str) # define SWIG_SetErrorSV(str) \ SWIG_Perl_SetErrorSV(str) #endif #define SWIG_SetErrorf SWIG_Perl_SetErrorf #ifdef PERL_OBJECT # define SWIG_MAYBE_PERL_OBJECT CPerlObj *pPerl, #else # define SWIG_MAYBE_PERL_OBJECT #endif static swig_cast_info * SWIG_Perl_TypeCheckRV(SWIG_MAYBE_PERL_OBJECT SV *rv, swig_type_info *ty) { SWIG_TypeCheck_Template(sv_derived_from(rv, (char *) iter->type->name), ty); } /* Function for getting a pointer value */ static int SWIG_Perl_ConvertPtr(SWIG_MAYBE_PERL_OBJECT SV *sv, void **ptr, swig_type_info *_t, int flags) { swig_cast_info *tc; void *voidptr = (void *)0; /* If magical, apply more magic */ if (SvGMAGICAL(sv)) mg_get(sv); /* Check to see if this is an object */ if (sv_isobject(sv)) { SV *tsv = (SV*) SvRV(sv); IV tmp = 0; if ((SvTYPE(tsv) == SVt_PVHV)) { MAGIC *mg; if (SvMAGICAL(tsv)) { mg = mg_find(tsv,'P'); if (mg) { sv = mg->mg_obj; if (sv_isobject(sv)) { tmp = SvIV((SV*)SvRV(sv)); } } } else { return -1; } } else { tmp = SvIV((SV*)SvRV(sv)); } voidptr = (void *)tmp; if (!_t) { *(ptr) = voidptr; return 0; } } else if (! SvOK(sv)) { /* Check for undef */ *(ptr) = (void *) 0; return 0; } else if (SvTYPE(sv) == SVt_RV) { /* Check for NULL pointer */ *(ptr) = (void *) 0; if (!SvROK(sv)) return 0; else return -1; } else { /* Don't know what it is */ *(ptr) = (void *) 0; return -1; } if (_t) { /* Now see if the types match */ char *_c = HvNAME(SvSTASH(SvRV(sv))); tc = SWIG_TypeCheck(_c,_t); if (!tc) { *ptr = voidptr; return -1; } *ptr = SWIG_TypeCast(tc,voidptr); return 0; } *ptr = voidptr; return 0; } static void SWIG_Perl_MakePtr(SWIG_MAYBE_PERL_OBJECT SV *sv, void *ptr, swig_type_info *t, int flags) { if (ptr && (flags & SWIG_SHADOW)) { SV *self; SV *obj=newSV(0); HV *hash=newHV(); HV *stash; sv_setref_pv(obj, (char *) t->name, ptr); stash=SvSTASH(SvRV(obj)); if (flags & SWIG_OWNER) { HV *hv; GV *gv=*(GV**)hv_fetch(stash, "OWNER", 5, TRUE); if (!isGV(gv)) gv_init(gv, stash, "OWNER", 5, FALSE); hv=GvHVn(gv); hv_store_ent(hv, obj, newSViv(1), 0); } sv_magic((SV *)hash, (SV *)obj, 'P', Nullch, 0); SvREFCNT_dec(obj); self=newRV_noinc((SV *)hash); sv_setsv(sv, self); SvREFCNT_dec((SV *)self); sv_bless(sv, stash); } else { sv_setref_pv(sv, (char *) t->name, ptr); } } static SWIGINLINE SV * SWIG_Perl_NewPointerObj(SWIG_MAYBE_PERL_OBJECT void *ptr, swig_type_info *t, int flags) { SV *result = sv_newmortal(); SWIG_MakePtr(result, ptr, t, flags); return result; } static void SWIG_Perl_MakePackedObj(SWIG_MAYBE_PERL_OBJECT SV *sv, void *ptr, int sz, swig_type_info *type) { char result[1024]; char *r = result; if ((2*sz + 1 + strlen(type->name)) > 1000) return; *(r++) = '_'; r = SWIG_PackData(r,ptr,sz); strcpy(r,type->name); sv_setpv(sv, result); } /* Convert a packed value value */ static int SWIG_Perl_ConvertPacked(SWIG_MAYBE_PERL_OBJECT SV *obj, void *ptr, int sz, swig_type_info *ty, int flags) { swig_cast_info *tc; const char *c = 0; if ((!obj) || (!SvOK(obj))) return -1; c = SvPV(obj, PL_na); /* Pointer values must start with leading underscore */ if (*c != '_') return -1; c++; c = SWIG_UnpackData(c,ptr,sz); if (ty) { tc = SWIG_TypeCheck(c,ty); if (!tc) return -1; } return 0; } static SWIGINLINE void SWIG_Perl_SetError(SWIG_MAYBE_PERL_OBJECT const char *error) { if (error) sv_setpv(perl_get_sv("@", TRUE), error); } static SWIGINLINE void SWIG_Perl_SetErrorSV(SWIG_MAYBE_PERL_OBJECT SV *error) { if (error) sv_setsv(perl_get_sv("@", TRUE), error); } static void SWIG_Perl_SetErrorf(const char *fmt, ...) { va_list args; va_start(args, fmt); sv_vsetpvfn(perl_get_sv("@", TRUE), fmt, strlen(fmt), &args, Null(SV**), 0, Null(bool*)); va_end(args); } /* Macros for low-level exception handling */ #define SWIG_fail goto fail #define SWIG_croak(x) { SWIG_SetError(x); goto fail; } #define SWIG_croakSV(x) { SWIG_SetErrorSV(x); goto fail; } /* most preprocessors do not support vararg macros :-( */ /* #define SWIG_croakf(x...) { SWIG_SetErrorf(x); goto fail; } */ typedef XS(SwigPerlWrapper); typedef SwigPerlWrapper *SwigPerlWrapperPtr; /* Structure for command table */ typedef struct { const char *name; SwigPerlWrapperPtr wrapper; } swig_command_info; /* Information for constant table */ #define SWIG_INT 1 #define SWIG_FLOAT 2 #define SWIG_STRING 3 #define SWIG_POINTER 4 #define SWIG_BINARY 5 /* Constant information structure */ typedef struct swig_constant_info { int type; const char *name; long lvalue; double dvalue; void *pvalue; swig_type_info **ptype; } swig_constant_info; #ifdef __cplusplus } #endif /* Structure for variable table */ typedef struct { const char *name; SwigMagicFunc set; SwigMagicFunc get; swig_type_info **type; } swig_variable_info; /* Magic variable code */ #ifndef PERL_OBJECT #define swig_create_magic(s,a,b,c) _swig_create_magic(s,a,b,c) #ifndef MULTIPLICITY static void _swig_create_magic(SV *sv, char *name, int (*set)(SV *, MAGIC *), int (*get)(SV *,MAGIC *)) { #else static void _swig_create_magic(SV *sv, char *name, int (*set)(struct interpreter*, SV *, MAGIC *), int (*get)(struct interpreter*, SV *,MAGIC *)) { #endif #else # define swig_create_magic(s,a,b,c) _swig_create_magic(pPerl,s,a,b,c) static void _swig_create_magic(CPerlObj *pPerl, SV *sv, const char *name, int (CPerlObj::*set)(SV *, MAGIC *), int (CPerlObj::*get)(SV *, MAGIC *)) { #endif MAGIC *mg; sv_magic(sv,sv,'U',(char *) name,strlen(name)); mg = mg_find(sv,'U'); mg->mg_virtual = (MGVTBL *) malloc(sizeof(MGVTBL)); mg->mg_virtual->svt_get = (SwigMagicFuncHack) get; mg->mg_virtual->svt_set = (SwigMagicFuncHack) set; mg->mg_virtual->svt_len = 0; mg->mg_virtual->svt_clear = 0; mg->mg_virtual->svt_free = 0; } static swig_module_info * SWIG_Perl_GetModule() { static void *type_pointer = (void *)0; SV *pointer; /* first check if pointer already created */ if (!type_pointer) { pointer = get_sv("swig_runtime_data::type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, FALSE); if (pointer && SvOK(pointer)) { type_pointer = INT2PTR(swig_type_info **, SvIV(pointer)); } } return (swig_module_info *) type_pointer; } static void SWIG_Perl_SetModule(swig_module_info *module) { SV *pointer; /* create a new pointer */ pointer = get_sv("swig_runtime_data::type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, TRUE); sv_setiv(pointer, PTR2IV(module)); } #ifdef do_open #undef do_open #endif #ifdef do_close #undef do_close #endif #ifdef scalar #undef scalar #endif #ifdef list #undef list #endif #ifdef apply #undef apply #endif #ifdef convert #undef convert #endif #ifdef Error #undef Error #endif #ifdef form #undef form #endif #ifdef vform #undef vform #endif #ifdef LABEL #undef LABEL #endif #ifdef METHOD #undef METHOD #endif #ifdef Move #undef Move #endif #ifdef yylex #undef yylex #endif #ifdef yyparse #undef yyparse #endif #ifdef yyerror #undef yyerror #endif #ifdef invert #undef invert #endif #ifdef ref #undef ref #endif #ifdef ENTER #undef ENTER #endif #ifdef read #undef read #endif #ifdef write #undef write #endif #ifdef eof #undef eof #endif #ifdef bool #undef bool #endif #ifdef close #undef close #endif #ifdef rewind #undef rewind #endif /* -------- TYPES TABLE (BEGIN) -------- */ #define SWIGTYPE_p_int swig_types[0] #define SWIGTYPE_p_p_char swig_types[1] #define SWIGTYPE_p_p_p_char swig_types[2] #define SWIGTYPE_p_pcre swig_types[3] #define SWIGTYPE_p_pcre_callout_block swig_types[4] #define SWIGTYPE_p_pcre_extra swig_types[5] #define SWIGTYPE_p_unsigned_char swig_types[6] #define SWIGTYPE_p_void swig_types[7] static swig_type_info *swig_types[9]; static swig_module_info swig_module = {swig_types, 8, 0, 0, 0, 0}; #define SWIG_TypeQuery(name) SWIG_TypeQueryModule(&swig_module, &swig_module, name) #define SWIG_MangledTypeQuery(name) SWIG_MangledTypeQueryModule(&swig_module, &swig_module, name) /* -------- TYPES TABLE (END) -------- */ #define SWIG_init boot_re__override__PCRE #define SWIG_name "re::override::PCRE::boot_re__override__PCRE" #define SWIG_prefix "re::override::PCRE::" #ifdef __cplusplus extern "C" #endif #ifndef PERL_OBJECT #ifndef MULTIPLICITY SWIGEXPORT void SWIG_init (CV* cv); #else SWIGEXPORT void SWIG_init (pTHXo_ CV* cv); #endif #else SWIGEXPORT void SWIG_init (CV *cv, CPerlObj *); #endif typedef SV* Perl_Scalar; #include "pcre.h" pcre* compile(const char *pat, int opt) { pcre *re; const char *error; int erroffset; re = pcre_compile( pat, opt, &error, &erroffset, NULL ); return re; } Perl_Scalar execute(const pcre *re, const char *str, int opt) { int rc; int *ovector; AV* seq = newAV(); int i; unsigned long int length; pcre_fullinfo( re, NULL, PCRE_INFO_SIZE, &length ); ovector = malloc(sizeof(int) * length); rc = pcre_exec( re, NULL, str, strlen(str), 0, 0, ovector, 30 ); if (rc >= 0) { for (i = 0; i < (rc*2); i++ ) { av_push(seq, newSViv(ovector[i])); } } free(ovector); return newRV_inc((SV*)seq); } #ifdef PERL_OBJECT #define MAGIC_CLASS _wrap_re::override::PCRE_var:: class _wrap_re::override::PCRE_var : public CPerlObj { public: #else #define MAGIC_CLASS #endif SWIGCLASS_STATIC int swig_magic_readonly(pTHX_ SV *sv, MAGIC *mg) { MAGIC_PPERL sv = sv; mg = mg; croak("Value is read-only."); return 0; } #ifdef PERL_OBJECT }; #endif #ifdef __cplusplus extern "C" { #endif XS(_wrap_compile) { { char *arg1 = (char *) 0 ; int arg2 ; pcre *result; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: compile(char const *,int);"); } if (!SvOK((SV*) ST(0))) arg1 = 0; else arg1 = (char *) SvPV(ST(0), PL_na); arg2 = (int) SvIV(ST(1)); result = (pcre *)compile((char const *)arg1,arg2); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_pcre, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_execute) { { pcre *arg1 = (pcre *) 0 ; char *arg2 = (char *) 0 ; int arg3 ; Perl_Scalar result; int argvi = 0; dXSARGS; if ((items < 3) || (items > 3)) { SWIG_croak("Usage: execute(pcre const *,char const *,int);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of execute. Expected _p_pcre"); } } if (!SvOK((SV*) ST(1))) arg2 = 0; else arg2 = (char *) SvPV(ST(1), PL_na); arg3 = (int) SvIV(ST(2)); result = execute((pcre const *)arg1,(char const *)arg2,arg3); { ST(argvi) = newSVsv((SV *)result); sv_2mortal(ST(argvi)); argvi++; } XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_compile) { { char *arg1 = (char *) 0 ; int arg2 ; char **arg3 = (char **) 0 ; int *arg4 = (int *) 0 ; unsigned char *arg5 = (unsigned char *) 0 ; pcre *result; int argvi = 0; dXSARGS; if ((items < 5) || (items > 5)) { SWIG_croak("Usage: pcre_compile(char const *,int,char const **,int *,unsigned char const *);"); } if (!SvOK((SV*) ST(0))) arg1 = 0; else arg1 = (char *) SvPV(ST(0), PL_na); arg2 = (int) SvIV(ST(1)); { if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_p_char,0) < 0) { SWIG_croak("Type error in argument 3 of pcre_compile. Expected _p_p_char"); } } { if (SWIG_ConvertPtr(ST(3), (void **) &arg4, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 4 of pcre_compile. Expected _p_int"); } } { if (SWIG_ConvertPtr(ST(4), (void **) &arg5, SWIGTYPE_p_unsigned_char,0) < 0) { SWIG_croak("Type error in argument 5 of pcre_compile. Expected _p_unsigned_char"); } } result = (pcre *)pcre_compile((char const *)arg1,arg2,(char const **)arg3,arg4,(unsigned char const *)arg5); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_pcre, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_config) { { int arg1 ; void *arg2 = (void *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_config(int,void *);"); } arg1 = (int) SvIV(ST(0)); { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, 0,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_config. Expected _p_void"); } } result = (int)pcre_config(arg1,arg2); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_copy_named_substring) { { pcre *arg1 = (pcre *) 0 ; char *arg2 = (char *) 0 ; int *arg3 = (int *) 0 ; int arg4 ; char *arg5 = (char *) 0 ; char *arg6 = (char *) 0 ; int arg7 ; int result; int argvi = 0; dXSARGS; if ((items < 7) || (items > 7)) { SWIG_croak("Usage: pcre_copy_named_substring(pcre const *,char const *,int *,int,char const *,char *,int);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_copy_named_substring. Expected _p_pcre"); } } if (!SvOK((SV*) ST(1))) arg2 = 0; else arg2 = (char *) SvPV(ST(1), PL_na); { if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 3 of pcre_copy_named_substring. Expected _p_int"); } } arg4 = (int) SvIV(ST(3)); if (!SvOK((SV*) ST(4))) arg5 = 0; else arg5 = (char *) SvPV(ST(4), PL_na); if (!SvOK((SV*) ST(5))) arg6 = 0; else arg6 = (char *) SvPV(ST(5), PL_na); arg7 = (int) SvIV(ST(6)); result = (int)pcre_copy_named_substring((pcre const *)arg1,(char const *)arg2,arg3,arg4,(char const *)arg5,arg6,arg7); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_copy_substring) { { char *arg1 = (char *) 0 ; int *arg2 = (int *) 0 ; int arg3 ; int arg4 ; char *arg5 = (char *) 0 ; int arg6 ; int result; int argvi = 0; dXSARGS; if ((items < 6) || (items > 6)) { SWIG_croak("Usage: pcre_copy_substring(char const *,int *,int,int,char *,int);"); } if (!SvOK((SV*) ST(0))) arg1 = 0; else arg1 = (char *) SvPV(ST(0), PL_na); { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_copy_substring. Expected _p_int"); } } arg3 = (int) SvIV(ST(2)); arg4 = (int) SvIV(ST(3)); if (!SvOK((SV*) ST(4))) arg5 = 0; else arg5 = (char *) SvPV(ST(4), PL_na); arg6 = (int) SvIV(ST(5)); result = (int)pcre_copy_substring((char const *)arg1,arg2,arg3,arg4,arg5,arg6); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_exec) { { pcre *arg1 = (pcre *) 0 ; pcre_extra *arg2 = (pcre_extra *) 0 ; char *arg3 = (char *) 0 ; int arg4 ; int arg5 ; int arg6 ; int *arg7 = (int *) 0 ; int arg8 ; int result; int argvi = 0; dXSARGS; if ((items < 8) || (items > 8)) { SWIG_croak("Usage: pcre_exec(pcre const *,pcre_extra const *,char const *,int,int,int,int *,int);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_exec. Expected _p_pcre"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_exec. Expected _p_pcre_extra"); } } if (!SvOK((SV*) ST(2))) arg3 = 0; else arg3 = (char *) SvPV(ST(2), PL_na); arg4 = (int) SvIV(ST(3)); arg5 = (int) SvIV(ST(4)); arg6 = (int) SvIV(ST(5)); { if (SWIG_ConvertPtr(ST(6), (void **) &arg7, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 7 of pcre_exec. Expected _p_int"); } } arg8 = (int) SvIV(ST(7)); result = (int)pcre_exec((pcre const *)arg1,(struct pcre_extra const *)arg2,(char const *)arg3,arg4,arg5,arg6,arg7,arg8); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_free_substring) { { char *arg1 = (char *) 0 ; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_free_substring(char const *);"); } if (!SvOK((SV*) ST(0))) arg1 = 0; else arg1 = (char *) SvPV(ST(0), PL_na); pcre_free_substring((char const *)arg1); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_free_substring_list) { { char **arg1 = (char **) 0 ; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_free_substring_list(char const **);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_p_char,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_free_substring_list. Expected _p_p_char"); } } pcre_free_substring_list((char const **)arg1); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_fullinfo) { { pcre *arg1 = (pcre *) 0 ; pcre_extra *arg2 = (pcre_extra *) 0 ; int arg3 ; void *arg4 = (void *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 4) || (items > 4)) { SWIG_croak("Usage: pcre_fullinfo(pcre const *,pcre_extra const *,int,void *);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_fullinfo. Expected _p_pcre"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_fullinfo. Expected _p_pcre_extra"); } } arg3 = (int) SvIV(ST(2)); { if (SWIG_ConvertPtr(ST(3), (void **) &arg4, 0,0) < 0) { SWIG_croak("Type error in argument 4 of pcre_fullinfo. Expected _p_void"); } } result = (int)pcre_fullinfo((pcre const *)arg1,(struct pcre_extra const *)arg2,arg3,arg4); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_get_named_substring) { { pcre *arg1 = (pcre *) 0 ; char *arg2 = (char *) 0 ; int *arg3 = (int *) 0 ; int arg4 ; char *arg5 = (char *) 0 ; char **arg6 = (char **) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 6) || (items > 6)) { SWIG_croak("Usage: pcre_get_named_substring(pcre const *,char const *,int *,int,char const *,char const **);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_get_named_substring. Expected _p_pcre"); } } if (!SvOK((SV*) ST(1))) arg2 = 0; else arg2 = (char *) SvPV(ST(1), PL_na); { if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 3 of pcre_get_named_substring. Expected _p_int"); } } arg4 = (int) SvIV(ST(3)); if (!SvOK((SV*) ST(4))) arg5 = 0; else arg5 = (char *) SvPV(ST(4), PL_na); { if (SWIG_ConvertPtr(ST(5), (void **) &arg6, SWIGTYPE_p_p_char,0) < 0) { SWIG_croak("Type error in argument 6 of pcre_get_named_substring. Expected _p_p_char"); } } result = (int)pcre_get_named_substring((pcre const *)arg1,(char const *)arg2,arg3,arg4,(char const *)arg5,(char const **)arg6); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_get_stringnumber) { { pcre *arg1 = (pcre *) 0 ; char *arg2 = (char *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_get_stringnumber(pcre const *,char const *);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_get_stringnumber. Expected _p_pcre"); } } if (!SvOK((SV*) ST(1))) arg2 = 0; else arg2 = (char *) SvPV(ST(1), PL_na); result = (int)pcre_get_stringnumber((pcre const *)arg1,(char const *)arg2); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_get_substring) { { char *arg1 = (char *) 0 ; int *arg2 = (int *) 0 ; int arg3 ; int arg4 ; char **arg5 = (char **) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 5) || (items > 5)) { SWIG_croak("Usage: pcre_get_substring(char const *,int *,int,int,char const **);"); } if (!SvOK((SV*) ST(0))) arg1 = 0; else arg1 = (char *) SvPV(ST(0), PL_na); { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_get_substring. Expected _p_int"); } } arg3 = (int) SvIV(ST(2)); arg4 = (int) SvIV(ST(3)); { if (SWIG_ConvertPtr(ST(4), (void **) &arg5, SWIGTYPE_p_p_char,0) < 0) { SWIG_croak("Type error in argument 5 of pcre_get_substring. Expected _p_p_char"); } } result = (int)pcre_get_substring((char const *)arg1,arg2,arg3,arg4,(char const **)arg5); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_get_substring_list) { { char *arg1 = (char *) 0 ; int *arg2 = (int *) 0 ; int arg3 ; char ***arg4 = (char ***) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 4) || (items > 4)) { SWIG_croak("Usage: pcre_get_substring_list(char const *,int *,int,char const ***);"); } if (!SvOK((SV*) ST(0))) arg1 = 0; else arg1 = (char *) SvPV(ST(0), PL_na); { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_get_substring_list. Expected _p_int"); } } arg3 = (int) SvIV(ST(2)); { if (SWIG_ConvertPtr(ST(3), (void **) &arg4, SWIGTYPE_p_p_p_char,0) < 0) { SWIG_croak("Type error in argument 4 of pcre_get_substring_list. Expected _p_p_p_char"); } } result = (int)pcre_get_substring_list((char const *)arg1,arg2,arg3,(char const ***)arg4); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_info) { { pcre *arg1 = (pcre *) 0 ; int *arg2 = (int *) 0 ; int *arg3 = (int *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 3) || (items > 3)) { SWIG_croak("Usage: pcre_info(pcre const *,int *,int *);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_info. Expected _p_pcre"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_info. Expected _p_int"); } } { if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 3 of pcre_info. Expected _p_int"); } } result = (int)pcre_info((pcre const *)arg1,arg2,arg3); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_maketables) { { unsigned char *result; int argvi = 0; dXSARGS; if ((items < 0) || (items > 0)) { SWIG_croak("Usage: pcre_maketables();"); } result = (unsigned char *)pcre_maketables(); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_unsigned_char, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_study) { { pcre *arg1 = (pcre *) 0 ; int arg2 ; char **arg3 = (char **) 0 ; pcre_extra *result; int argvi = 0; dXSARGS; if ((items < 3) || (items > 3)) { SWIG_croak("Usage: pcre_study(pcre const *,int,char const **);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_study. Expected _p_pcre"); } } arg2 = (int) SvIV(ST(1)); { if (SWIG_ConvertPtr(ST(2), (void **) &arg3, SWIGTYPE_p_p_char,0) < 0) { SWIG_croak("Type error in argument 3 of pcre_study. Expected _p_p_char"); } } result = (pcre_extra *)pcre_study((pcre const *)arg1,arg2,(char const **)arg3); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_pcre_extra, SWIG_SHADOW|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_version) { { char *result; int argvi = 0; dXSARGS; if ((items < 0) || (items > 0)) { SWIG_croak("Usage: pcre_version();"); } result = (char *)pcre_version(); ST(argvi) = sv_newmortal(); if (result) { sv_setpv((SV*)ST(argvi++), (char *) result); } else { sv_setsv((SV*)ST(argvi++), &PL_sv_undef); } XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_flags_set) { { pcre_extra *arg1 = (pcre_extra *) 0 ; unsigned long arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_extra_flags_set(self,flags);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_flags_set. Expected _p_pcre_extra"); } } arg2 = (unsigned long) SvUV(ST(1)); if (arg1) (arg1)->flags = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_flags_get) { { pcre_extra *arg1 = (pcre_extra *) 0 ; unsigned long result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_extra_flags_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_flags_get. Expected _p_pcre_extra"); } } result = (unsigned long) ((arg1)->flags); ST(argvi) = sv_newmortal(); sv_setuv(ST(argvi++), (UV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_study_data_set) { { pcre_extra *arg1 = (pcre_extra *) 0 ; void *arg2 = (void *) 0 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_extra_study_data_set(self,study_data);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_study_data_set. Expected _p_pcre_extra"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, 0,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_extra_study_data_set. Expected _p_void"); } } if (arg1) (arg1)->study_data = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_study_data_get) { { pcre_extra *arg1 = (pcre_extra *) 0 ; void *result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_extra_study_data_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_study_data_get. Expected _p_pcre_extra"); } } result = (void *) ((arg1)->study_data); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_match_limit_set) { { pcre_extra *arg1 = (pcre_extra *) 0 ; unsigned long arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_extra_match_limit_set(self,match_limit);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_match_limit_set. Expected _p_pcre_extra"); } } arg2 = (unsigned long) SvUV(ST(1)); if (arg1) (arg1)->match_limit = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_match_limit_get) { { pcre_extra *arg1 = (pcre_extra *) 0 ; unsigned long result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_extra_match_limit_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_match_limit_get. Expected _p_pcre_extra"); } } result = (unsigned long) ((arg1)->match_limit); ST(argvi) = sv_newmortal(); sv_setuv(ST(argvi++), (UV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_callout_data_set) { { pcre_extra *arg1 = (pcre_extra *) 0 ; void *arg2 = (void *) 0 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_extra_callout_data_set(self,callout_data);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_callout_data_set. Expected _p_pcre_extra"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, 0,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_extra_callout_data_set. Expected _p_void"); } } if (arg1) (arg1)->callout_data = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_callout_data_get) { { pcre_extra *arg1 = (pcre_extra *) 0 ; void *result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_extra_callout_data_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_callout_data_get. Expected _p_pcre_extra"); } } result = (void *) ((arg1)->callout_data); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_tables_set) { { pcre_extra *arg1 = (pcre_extra *) 0 ; unsigned char *arg2 = (unsigned char *) 0 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_extra_tables_set(self,tables);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_tables_set. Expected _p_pcre_extra"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_unsigned_char,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_extra_tables_set. Expected _p_unsigned_char"); } } if (arg1) (arg1)->tables = (unsigned char const *)arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_extra_tables_get) { { pcre_extra *arg1 = (pcre_extra *) 0 ; unsigned char *result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_extra_tables_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_extra_tables_get. Expected _p_pcre_extra"); } } result = (unsigned char *) ((arg1)->tables); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_unsigned_char, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_new_pcre_extra) { { pcre_extra *result; int argvi = 0; dXSARGS; if ((items < 0) || (items > 0)) { SWIG_croak("Usage: new_pcre_extra();"); } result = (pcre_extra *)(pcre_extra *) calloc(1, sizeof(pcre_extra)); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_pcre_extra, SWIG_SHADOW|SWIG_OWNER); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_delete_pcre_extra) { { pcre_extra *arg1 = (pcre_extra *) 0 ; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: delete_pcre_extra(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_extra,0) < 0) { SWIG_croak("Type error in argument 1 of delete_pcre_extra. Expected _p_pcre_extra"); } } free((char *) arg1); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_version_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_version_set(self,version);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_version_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->version = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_version_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_version_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_version_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->version); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_callout_number_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_callout_number_set(self,callout_number);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_callout_number_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->callout_number = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_callout_number_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_callout_number_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_callout_number_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->callout_number); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_offset_vector_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int *arg2 = (int *) 0 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_offset_vector_set(self,offset_vector);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_offset_vector_set. Expected _p_pcre_callout_block"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, SWIGTYPE_p_int,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_callout_block_offset_vector_set. Expected _p_int"); } } if (arg1) (arg1)->offset_vector = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_offset_vector_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int *result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_offset_vector_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_offset_vector_get. Expected _p_pcre_callout_block"); } } result = (int *) ((arg1)->offset_vector); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_int, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_subject_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; char *arg2 = (char *) 0 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_subject_set(self,subject);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_subject_set. Expected _p_pcre_callout_block"); } } if (!SvOK((SV*) ST(1))) arg2 = 0; else arg2 = (char *) SvPV(ST(1), PL_na); { if (arg2) { arg1->subject = (char const *) malloc(strlen(arg2)+1); strcpy((char*)arg1->subject,arg2); } else { arg1->subject = 0; } } XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_subject_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; char *result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_subject_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_subject_get. Expected _p_pcre_callout_block"); } } result = (char *) ((arg1)->subject); ST(argvi) = sv_newmortal(); if (result) { sv_setpv((SV*)ST(argvi++), (char *) result); } else { sv_setsv((SV*)ST(argvi++), &PL_sv_undef); } XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_subject_length_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_subject_length_set(self,subject_length);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_subject_length_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->subject_length = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_subject_length_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_subject_length_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_subject_length_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->subject_length); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_start_match_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_start_match_set(self,start_match);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_start_match_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->start_match = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_start_match_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_start_match_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_start_match_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->start_match); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_current_position_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_current_position_set(self,current_position);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_current_position_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->current_position = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_current_position_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_current_position_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_current_position_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->current_position); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_capture_top_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_capture_top_set(self,capture_top);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_capture_top_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->capture_top = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_capture_top_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_capture_top_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_capture_top_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->capture_top); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_capture_last_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_capture_last_set(self,capture_last);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_capture_last_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->capture_last = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_capture_last_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_capture_last_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_capture_last_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->capture_last); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_callout_data_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; void *arg2 = (void *) 0 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_callout_data_set(self,callout_data);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_callout_data_set. Expected _p_pcre_callout_block"); } } { if (SWIG_ConvertPtr(ST(1), (void **) &arg2, 0,0) < 0) { SWIG_croak("Type error in argument 2 of pcre_callout_block_callout_data_set. Expected _p_void"); } } if (arg1) (arg1)->callout_data = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_callout_data_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; void *result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_callout_data_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_callout_data_get. Expected _p_pcre_callout_block"); } } result = (void *) ((arg1)->callout_data); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_void, 0|0); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_pattern_position_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_pattern_position_set(self,pattern_position);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_pattern_position_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->pattern_position = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_pattern_position_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_pattern_position_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_pattern_position_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->pattern_position); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_next_item_length_set) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int arg2 ; int argvi = 0; dXSARGS; if ((items < 2) || (items > 2)) { SWIG_croak("Usage: pcre_callout_block_next_item_length_set(self,next_item_length);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_next_item_length_set. Expected _p_pcre_callout_block"); } } arg2 = (int) SvIV(ST(1)); if (arg1) (arg1)->next_item_length = arg2; XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_pcre_callout_block_next_item_length_get) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int result; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: pcre_callout_block_next_item_length_get(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of pcre_callout_block_next_item_length_get. Expected _p_pcre_callout_block"); } } result = (int) ((arg1)->next_item_length); ST(argvi) = sv_newmortal(); sv_setiv(ST(argvi++), (IV) result); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_new_pcre_callout_block) { { pcre_callout_block *result; int argvi = 0; dXSARGS; if ((items < 0) || (items > 0)) { SWIG_croak("Usage: new_pcre_callout_block();"); } result = (pcre_callout_block *)(pcre_callout_block *) calloc(1, sizeof(pcre_callout_block)); ST(argvi) = sv_newmortal(); SWIG_MakePtr(ST(argvi++), (void *) result, SWIGTYPE_p_pcre_callout_block, SWIG_SHADOW|SWIG_OWNER); XSRETURN(argvi); fail: ; } croak(Nullch); } XS(_wrap_delete_pcre_callout_block) { { pcre_callout_block *arg1 = (pcre_callout_block *) 0 ; int argvi = 0; dXSARGS; if ((items < 1) || (items > 1)) { SWIG_croak("Usage: delete_pcre_callout_block(self);"); } { if (SWIG_ConvertPtr(ST(0), (void **) &arg1, SWIGTYPE_p_pcre_callout_block,0) < 0) { SWIG_croak("Type error in argument 1 of delete_pcre_callout_block. Expected _p_pcre_callout_block"); } } free((char *) arg1); XSRETURN(argvi); fail: ; } croak(Nullch); } /* -------- TYPE CONVERSION AND EQUIVALENCE RULES (BEGIN) -------- */ static swig_type_info _swigt__p_int = {"_p_int", "int *", 0, 0, 0}; static swig_type_info _swigt__p_p_char = {"_p_p_char", "char **", 0, 0, 0}; static swig_type_info _swigt__p_p_p_char = {"_p_p_p_char", "char ***", 0, 0, 0}; static swig_type_info _swigt__p_pcre = {"_p_pcre", "pcre *", 0, 0, 0}; static swig_type_info _swigt__p_pcre_callout_block = {"_p_pcre_callout_block", "struct pcre_callout_block *|pcre_callout_block *", 0, 0, 0}; static swig_type_info _swigt__p_pcre_extra = {"_p_pcre_extra", "struct pcre_extra *|pcre_extra *", 0, 0, 0}; static swig_type_info _swigt__p_unsigned_char = {"_p_unsigned_char", "unsigned char *", 0, 0, 0}; static swig_type_info _swigt__p_void = {"_p_void", "void *", 0, 0, 0}; static swig_type_info *swig_type_initial[] = { &_swigt__p_int, &_swigt__p_p_char, &_swigt__p_p_p_char, &_swigt__p_pcre, &_swigt__p_pcre_callout_block, &_swigt__p_pcre_extra, &_swigt__p_unsigned_char, &_swigt__p_void, }; static swig_cast_info _swigc__p_int[] = { {&_swigt__p_int, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info _swigc__p_p_char[] = { {&_swigt__p_p_char, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info _swigc__p_p_p_char[] = { {&_swigt__p_p_p_char, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info _swigc__p_pcre[] = { {&_swigt__p_pcre, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info _swigc__p_pcre_callout_block[] = { {&_swigt__p_pcre_callout_block, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info _swigc__p_pcre_extra[] = { {&_swigt__p_pcre_extra, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info _swigc__p_unsigned_char[] = { {&_swigt__p_unsigned_char, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info _swigc__p_void[] = { {&_swigt__p_void, 0, 0, 0},{0, 0, 0, 0}}; static swig_cast_info *swig_cast_initial[] = { _swigc__p_int, _swigc__p_p_char, _swigc__p_p_p_char, _swigc__p_pcre, _swigc__p_pcre_callout_block, _swigc__p_pcre_extra, _swigc__p_unsigned_char, _swigc__p_void, }; /* -------- TYPE CONVERSION AND EQUIVALENCE RULES (END) -------- */ static swig_constant_info swig_constants[] = { {0,0,0,0,0,0} }; #ifdef __cplusplus } #endif static swig_variable_info swig_variables[] = { {0,0,0,0} }; static swig_command_info swig_commands[] = { {"re::override::PCRE::compile", _wrap_compile}, {"re::override::PCRE::execute", _wrap_execute}, {"re::override::PCRE::pcre_compile", _wrap_pcre_compile}, {"re::override::PCRE::pcre_config", _wrap_pcre_config}, {"re::override::PCRE::pcre_copy_named_substring", _wrap_pcre_copy_named_substring}, {"re::override::PCRE::pcre_copy_substring", _wrap_pcre_copy_substring}, {"re::override::PCRE::pcre_exec", _wrap_pcre_exec}, {"re::override::PCRE::pcre_free_substring", _wrap_pcre_free_substring}, {"re::override::PCRE::pcre_free_substring_list", _wrap_pcre_free_substring_list}, {"re::override::PCRE::pcre_fullinfo", _wrap_pcre_fullinfo}, {"re::override::PCRE::pcre_get_named_substring", _wrap_pcre_get_named_substring}, {"re::override::PCRE::pcre_get_stringnumber", _wrap_pcre_get_stringnumber}, {"re::override::PCRE::pcre_get_substring", _wrap_pcre_get_substring}, {"re::override::PCRE::pcre_get_substring_list", _wrap_pcre_get_substring_list}, {"re::override::PCRE::pcre_info", _wrap_pcre_info}, {"re::override::PCRE::pcre_maketables", _wrap_pcre_maketables}, {"re::override::PCRE::pcre_study", _wrap_pcre_study}, {"re::override::PCRE::pcre_version", _wrap_pcre_version}, {"re::override::PCRE::pcre_extra_flags_set", _wrap_pcre_extra_flags_set}, {"re::override::PCRE::pcre_extra_flags_get", _wrap_pcre_extra_flags_get}, {"re::override::PCRE::pcre_extra_study_data_set", _wrap_pcre_extra_study_data_set}, {"re::override::PCRE::pcre_extra_study_data_get", _wrap_pcre_extra_study_data_get}, {"re::override::PCRE::pcre_extra_match_limit_set", _wrap_pcre_extra_match_limit_set}, {"re::override::PCRE::pcre_extra_match_limit_get", _wrap_pcre_extra_match_limit_get}, {"re::override::PCRE::pcre_extra_callout_data_set", _wrap_pcre_extra_callout_data_set}, {"re::override::PCRE::pcre_extra_callout_data_get", _wrap_pcre_extra_callout_data_get}, {"re::override::PCRE::pcre_extra_tables_set", _wrap_pcre_extra_tables_set}, {"re::override::PCRE::pcre_extra_tables_get", _wrap_pcre_extra_tables_get}, {"re::override::PCRE::new_pcre_extra", _wrap_new_pcre_extra}, {"re::override::PCRE::delete_pcre_extra", _wrap_delete_pcre_extra}, {"re::override::PCRE::pcre_callout_block_version_set", _wrap_pcre_callout_block_version_set}, {"re::override::PCRE::pcre_callout_block_version_get", _wrap_pcre_callout_block_version_get}, {"re::override::PCRE::pcre_callout_block_callout_number_set", _wrap_pcre_callout_block_callout_number_set}, {"re::override::PCRE::pcre_callout_block_callout_number_get", _wrap_pcre_callout_block_callout_number_get}, {"re::override::PCRE::pcre_callout_block_offset_vector_set", _wrap_pcre_callout_block_offset_vector_set}, {"re::override::PCRE::pcre_callout_block_offset_vector_get", _wrap_pcre_callout_block_offset_vector_get}, {"re::override::PCRE::pcre_callout_block_subject_set", _wrap_pcre_callout_block_subject_set}, {"re::override::PCRE::pcre_callout_block_subject_get", _wrap_pcre_callout_block_subject_get}, {"re::override::PCRE::pcre_callout_block_subject_length_set", _wrap_pcre_callout_block_subject_length_set}, {"re::override::PCRE::pcre_callout_block_subject_length_get", _wrap_pcre_callout_block_subject_length_get}, {"re::override::PCRE::pcre_callout_block_start_match_set", _wrap_pcre_callout_block_start_match_set}, {"re::override::PCRE::pcre_callout_block_start_match_get", _wrap_pcre_callout_block_start_match_get}, {"re::override::PCRE::pcre_callout_block_current_position_set", _wrap_pcre_callout_block_current_position_set}, {"re::override::PCRE::pcre_callout_block_current_position_get", _wrap_pcre_callout_block_current_position_get}, {"re::override::PCRE::pcre_callout_block_capture_top_set", _wrap_pcre_callout_block_capture_top_set}, {"re::override::PCRE::pcre_callout_block_capture_top_get", _wrap_pcre_callout_block_capture_top_get}, {"re::override::PCRE::pcre_callout_block_capture_last_set", _wrap_pcre_callout_block_capture_last_set}, {"re::override::PCRE::pcre_callout_block_capture_last_get", _wrap_pcre_callout_block_capture_last_get}, {"re::override::PCRE::pcre_callout_block_callout_data_set", _wrap_pcre_callout_block_callout_data_set}, {"re::override::PCRE::pcre_callout_block_callout_data_get", _wrap_pcre_callout_block_callout_data_get}, {"re::override::PCRE::pcre_callout_block_pattern_position_set", _wrap_pcre_callout_block_pattern_position_set}, {"re::override::PCRE::pcre_callout_block_pattern_position_get", _wrap_pcre_callout_block_pattern_position_get}, {"re::override::PCRE::pcre_callout_block_next_item_length_set", _wrap_pcre_callout_block_next_item_length_set}, {"re::override::PCRE::pcre_callout_block_next_item_length_get", _wrap_pcre_callout_block_next_item_length_get}, {"re::override::PCRE::new_pcre_callout_block", _wrap_new_pcre_callout_block}, {"re::override::PCRE::delete_pcre_callout_block", _wrap_delete_pcre_callout_block}, {0,0} }; /************************************************************************* * Type initialization: * This problem is tough by the requirement that no dynamic * memory is used. Also, since swig_type_info structures store pointers to * swig_cast_info structures and swig_cast_info structures store pointers back * to swig_type_info structures, we need some lookup code at initialization. * The idea is that swig generates all the structures that are needed. * The runtime then collects these partially filled structures. * The SWIG_InitializeModule function takes these initial arrays out of * swig_module, and does all the lookup, filling in the swig_module.types * array with the correct data and linking the correct swig_cast_info * structures together. * The generated swig_type_info structures are assigned staticly to an initial * array. We just loop though that array, and handle each type individually. * First we lookup if this type has been already loaded, and if so, use the * loaded structure instead of the generated one. Then we have to fill in the * cast linked list. The cast data is initially stored in something like a * two-dimensional array. Each row corresponds to a type (there are the same * number of rows as there are in the swig_type_initial array). Each entry in * a column is one of the swig_cast_info structures for that type. * The cast_initial array is actually an array of arrays, because each row has * a variable number of columns. So to actually build the cast linked list, * we find the array of casts associated with the type, and loop through it * adding the casts to the list. The one last trick we need to do is making * sure the type pointer in the swig_cast_info struct is correct. * First off, we lookup the cast->type name to see if it is already loaded. * There are three cases to handle: * 1) If the cast->type has already been loaded AND the type we are adding * casting info to has not been loaded (it is in this module), THEN we * replace the cast->type pointer with the type pointer that has already * been loaded. * 2) If BOTH types (the one we are adding casting info to, and the * cast->type) are loaded, THEN the cast info has already been loaded by * the previous module so we just ignore it. * 3) Finally, if cast->type has not already been loaded, then we add that * swig_cast_info to the linked list (because the cast->type) pointer will * be correct. **/ #ifdef __cplusplus extern "C" { #endif SWIGRUNTIME void SWIG_InitializeModule(void *clientdata) { swig_type_info *type, *ret; swig_cast_info *cast; size_t i; swig_module_info *module_head; static int init_run = 0; clientdata = clientdata; if (init_run) return; init_run = 1; /* Initialize the swig_module */ swig_module.type_initial = swig_type_initial; swig_module.cast_initial = swig_cast_initial; /* Try and load any already created modules */ module_head = SWIG_GetModule(clientdata); if (module_head) { swig_module.next = module_head->next; module_head->next = &swig_module; } else { /* This is the first module loaded */ swig_module.next = &swig_module; SWIG_SetModule(clientdata, &swig_module); } /* Now work on filling in swig_module.types */ for (i = 0; i < swig_module.size; ++i) { type = 0; /* if there is another module already loaded */ if (swig_module.next != &swig_module) { type = SWIG_MangledTypeQueryModule(swig_module.next, &swig_module, swig_module.type_initial[i]->name); } if (type) { /* Overwrite clientdata field */ if (swig_module.type_initial[i]->clientdata) type->clientdata = swig_module.type_initial[i]->clientdata; } else { type = swig_module.type_initial[i]; } /* Insert casting types */ cast = swig_module.cast_initial[i]; while (cast->type) { /* Don't need to add information already in the list */ ret = 0; if (swig_module.next != &swig_module) { ret = SWIG_MangledTypeQueryModule(swig_module.next, &swig_module, cast->type->name); } if (ret && type == swig_module.type_initial[i]) { cast->type = ret; ret = 0; } if (!ret) { if (type->cast) { type->cast->prev = cast; cast->next = type->cast; } type->cast = cast; } cast++; } /* Set entry in modules->types array equal to the type */ swig_module.types[i] = type; } swig_module.types[i] = 0; } /* This function will propagate the clientdata field of type to * any new swig_type_info structures that have been added into the list * of equivalent types. It is like calling * SWIG_TypeClientData(type, clientdata) a second time. */ SWIGRUNTIME void SWIG_PropagateClientData(void) { size_t i; swig_cast_info *equiv; static int init_run = 0; if (init_run) return; init_run = 1; for (i = 0; i < swig_module.size; i++) { if (swig_module.types[i]->clientdata) { equiv = swig_module.types[i]->cast; while (equiv) { if (!equiv->converter) { if (equiv->type && !equiv->type->clientdata) SWIG_TypeClientData(equiv->type, swig_module.types[i]->clientdata); } equiv = equiv->next; } } } } #ifdef __cplusplus } #endif #ifdef __cplusplus extern "C" #endif XS(SWIG_init) { dXSARGS; int i; SWIG_InitializeModule(0); /* Install commands */ for (i = 0; swig_commands[i].name; i++) { newXS((char*) swig_commands[i].name,swig_commands[i].wrapper, (char*)__FILE__); } /* Install variables */ for (i = 0; swig_variables[i].name; i++) { SV *sv; sv = perl_get_sv((char*) swig_variables[i].name, TRUE | 0x2); if (swig_variables[i].type) { SWIG_MakePtr(sv,(void *)1, *swig_variables[i].type,0); } else { sv_setiv(sv,(IV) 0); } swig_create_magic(sv, (char *) swig_variables[i].name, swig_variables[i].set, swig_variables[i].get); } /* Install constant */ for (i = 0; swig_constants[i].type; i++) { SV *sv; sv = perl_get_sv((char*)swig_constants[i].name, TRUE | 0x2); switch(swig_constants[i].type) { case SWIG_INT: sv_setiv(sv, (IV) swig_constants[i].lvalue); break; case SWIG_FLOAT: sv_setnv(sv, (double) swig_constants[i].dvalue); break; case SWIG_STRING: sv_setpv(sv, (char *) swig_constants[i].pvalue); break; case SWIG_POINTER: SWIG_MakePtr(sv, swig_constants[i].pvalue, *(swig_constants[i].ptype),0); break; case SWIG_BINARY: SWIG_MakePackedObj(sv, swig_constants[i].pvalue, swig_constants[i].lvalue, *(swig_constants[i].ptype)); break; default: break; } SvREADONLY_on(sv); } ST(0) = &PL_sv_yes; XSRETURN(1); }