You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
595 lines
17 KiB
595 lines
17 KiB
4 years ago
|
//
|
||
|
// Use the macro SWIG_PRESERVE_CARRAY_SIZE if you prefer to preserve
|
||
|
// the size of char arrays, ie
|
||
|
// ------------------------------------------
|
||
|
// C Side => Language Side
|
||
|
// ------------------------------------------
|
||
|
// char name[5] = "hola" => 'hola\0'
|
||
|
//
|
||
|
// the default behaviour is
|
||
|
//
|
||
|
// char name[5] = "hola" => 'hola'
|
||
|
//
|
||
|
//
|
||
|
//#define SWIG_PRESERVE_CARRAY_SIZE
|
||
|
|
||
|
/* ------------------------------------------------------------
|
||
|
* String typemaps for type Char (char or wchar_t)
|
||
|
* ------------------------------------------------------------ */
|
||
|
|
||
|
%define %_typemap_string(StringCode,
|
||
|
Char,
|
||
|
SWIG_AsCharPtrAndSize,
|
||
|
SWIG_FromCharPtrAndSize,
|
||
|
SWIG_CharPtrLen,
|
||
|
SWIG_AsCharPtr,
|
||
|
SWIG_FromCharPtr,
|
||
|
SWIG_AsCharArray)
|
||
|
|
||
|
/* in */
|
||
|
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharPtr)
|
||
|
Char * (int res, Char *buf = 0, int alloc = 0),
|
||
|
const Char * (int res, Char *buf = 0, int alloc = 0) {
|
||
|
res = SWIG_AsCharPtr($input, &buf, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res,"$type",$symname, $argnum);
|
||
|
}
|
||
|
$1 = %reinterpret_cast(buf, $1_ltype);
|
||
|
}
|
||
|
%typemap(freearg,noblock=1,match="in") Char *, const Char * {
|
||
|
if (alloc$argnum == SWIG_NEWOBJ) %delete_array(buf$argnum);
|
||
|
}
|
||
|
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharPtr) Char const*& (int res, Char *buf = 0, int alloc = 0) {
|
||
|
res = SWIG_AsCharPtr($input, &buf, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res,"$type",$symname, $argnum);
|
||
|
}
|
||
|
$1 = &buf;
|
||
|
}
|
||
|
%typemap(freearg, noblock=1,match="in") Char const*& {
|
||
|
if (alloc$argnum == SWIG_NEWOBJ) %delete_array(buf$argnum);
|
||
|
}
|
||
|
|
||
|
/* out */
|
||
|
|
||
|
%typemap(out,noblock=1,fragment=#SWIG_FromCharPtr) Char *, const Char* {
|
||
|
%set_output(SWIG_FromCharPtr((const Char *)$1));
|
||
|
}
|
||
|
|
||
|
|
||
|
%typemap(out,noblock=1,fragment=#SWIG_FromCharPtr) Char const*& {
|
||
|
%set_output(SWIG_FromCharPtr(*$1));
|
||
|
}
|
||
|
|
||
|
%typemap(newfree,noblock=1) Char * {
|
||
|
%delete_array($1);
|
||
|
}
|
||
|
|
||
|
/* varin */
|
||
|
|
||
|
%typemap(varin,fragment=#SWIG_AsCharPtrAndSize) Char * {
|
||
|
Char *cptr = 0; size_t csize = 0; int alloc = SWIG_NEWOBJ;
|
||
|
int res = SWIG_AsCharPtrAndSize($input, &cptr, &csize, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%variable_fail(res,"$type","$name");
|
||
|
}
|
||
|
if ($1) %delete_array($1);
|
||
|
if (alloc == SWIG_NEWOBJ) {
|
||
|
$1 = cptr;
|
||
|
} else {
|
||
|
$1 = csize ? ($1_type)%new_copy_array(cptr, csize, Char) : 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
%typemap(varin,fragment=#SWIG_AsCharPtrAndSize,warning=SWIGWARN_TYPEMAP_CHARLEAK_MSG) const Char * {
|
||
|
Char *cptr = 0; size_t csize = 0; int alloc = SWIG_NEWOBJ;
|
||
|
int res = SWIG_AsCharPtrAndSize($input, &cptr, &csize, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%variable_fail(res, "$type", "$name");
|
||
|
}
|
||
|
if (alloc == SWIG_NEWOBJ) {
|
||
|
$1 = cptr;
|
||
|
} else {
|
||
|
$1 = csize ? ($1_type)%new_copy_array(cptr, csize, Char) : 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* varout */
|
||
|
|
||
|
%typemap(varout,noblock=1,fragment=#SWIG_FromCharPtr) Char*, const Char* {
|
||
|
%set_varoutput(SWIG_FromCharPtr($1));
|
||
|
}
|
||
|
|
||
|
/* memberin */
|
||
|
|
||
|
%typemap(memberin,noblock=1) Char * {
|
||
|
if ($1) %delete_array($1);
|
||
|
if ($input) {
|
||
|
size_t size = SWIG_CharPtrLen(%reinterpret_cast($input, const Char *)) + 1;
|
||
|
$1 = ($1_type)%new_copy_array(%reinterpret_cast($input, const Char *), size, Char);
|
||
|
} else {
|
||
|
$1 = 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
%typemap(memberin,noblock=1,warning=SWIGWARN_TYPEMAP_CHARLEAK_MSG) const Char * {
|
||
|
if ($input) {
|
||
|
size_t size = SWIG_CharPtrLen(%reinterpret_cast(%reinterpret_cast($input, const Char *), const Char *)) + 1;
|
||
|
$1 = ($1_type)%new_copy_array($input, size, Char);
|
||
|
} else {
|
||
|
$1 = 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* globalin */
|
||
|
|
||
|
%typemap(globalin,noblock=1) Char * {
|
||
|
if ($1) %delete_array($1);
|
||
|
if ($input) {
|
||
|
size_t size = SWIG_CharPtrLen(%reinterpret_cast(%reinterpret_cast($input, const Char *), const Char *)) + 1;
|
||
|
$1 = ($1_type)%new_copy_array($input, size, Char);
|
||
|
} else {
|
||
|
$1 = 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
%typemap(globalin,noblock=1,warning=SWIGWARN_TYPEMAP_CHARLEAK_MSG) const Char * {
|
||
|
if ($input) {
|
||
|
size_t size = SWIG_CharPtrLen($input) + 1;
|
||
|
$1 = ($1_type)%new_copy_array($input, size, Char);
|
||
|
} else {
|
||
|
$1 = 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* constant */
|
||
|
|
||
|
%typemap(constcode,noblock=1,fragment=#SWIG_FromCharPtr)
|
||
|
Char *, Char const*, Char * const, Char const* const {
|
||
|
%set_constant("$symname", SWIG_FromCharPtr($value));
|
||
|
}
|
||
|
|
||
|
|
||
|
#if defined(SWIG_DIRECTOR_TYPEMAPS)
|
||
|
|
||
|
/* directorin */
|
||
|
|
||
|
%typemap(directorin,noblock=1,fragment=#SWIG_FromCharPtr)
|
||
|
Char *, Char const*, Char *const, Char const *const,
|
||
|
Char const *&, Char *const &, Char const *const & {
|
||
|
$input = SWIG_FromCharPtr((const Char *)$1_name);
|
||
|
}
|
||
|
|
||
|
|
||
|
/* directorout */
|
||
|
|
||
|
%typemap(directorout,noblock=1,fragment=#SWIG_AsCharPtr,warning=SWIGWARN_TYPEMAP_DIRECTOROUT_PTR_MSG)
|
||
|
Char * (int res, Char* buf = 0, int alloc = SWIG_NEWOBJ) {
|
||
|
res = SWIG_AsCharPtr($input, &buf, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%dirout_fail(res, "$type");
|
||
|
}
|
||
|
if (alloc == SWIG_NEWOBJ) {
|
||
|
swig_acquire_ownership_array(buf);
|
||
|
}
|
||
|
$result = %reinterpret_cast(buf, $1_ltype);
|
||
|
}
|
||
|
%typemap(directorfree,noblock=1) Char *
|
||
|
{
|
||
|
if (director) {
|
||
|
director->swig_release_ownership(%as_voidptr($input));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
%typemap(directorout,noblock=1,fragment=#SWIG_AsCharPtr,warning=SWIGWARN_TYPEMAP_DIRECTOROUT_PTR_MSG)
|
||
|
Char * const& (int res, Char* buf = 0, int alloc = SWIG_NEWOBJ),
|
||
|
Char const* const& (int res, Char* buf = 0, int alloc = SWIG_NEWOBJ) {
|
||
|
res = SWIG_AsCharPtr($input, &buf, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%dirout_fail(res, "$type");
|
||
|
}
|
||
|
static $*1_ltype tmp = buf;
|
||
|
$result = &tmp;
|
||
|
if (alloc == SWIG_NEWOBJ) {
|
||
|
swig_acquire_ownership_array(buf);
|
||
|
}
|
||
|
}
|
||
|
%typemap(directorfree,noblock=1)
|
||
|
Char * const&, Char const* const& {
|
||
|
if (director) {
|
||
|
director->swig_release_ownership(%as_voidptr(*$input));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#endif /* SWIG_DIRECTOR_TYPEMAPS */
|
||
|
|
||
|
/* typecheck */
|
||
|
|
||
|
%typemap(typecheck,noblock=1,precedence=StringCode,
|
||
|
fragment=#SWIG_AsCharPtr) Char *, Char const*& {
|
||
|
int res = SWIG_AsCharPtr($input, 0, 0);
|
||
|
$1 = SWIG_CheckState(res);
|
||
|
}
|
||
|
|
||
|
|
||
|
/* throws */
|
||
|
|
||
|
%typemap(throws,noblock=1,fragment=#SWIG_FromCharPtr) Char * {
|
||
|
%raise(SWIG_FromCharPtr($1), "$type", 0);
|
||
|
}
|
||
|
|
||
|
|
||
|
/* ------------------------------------------------------------
|
||
|
* Unknown size const Character array Char[ANY] handling
|
||
|
* ------------------------------------------------------------ */
|
||
|
|
||
|
%apply Char* { Char [] };
|
||
|
%apply const Char* { const Char [] };
|
||
|
|
||
|
%typemap(varin,noblock=1,warning="462:Unable to set variable of type Char []") Char []
|
||
|
{
|
||
|
%variable_fail(SWIG_AttributeError, "$type", "read-only $name");
|
||
|
}
|
||
|
|
||
|
|
||
|
/* ------------------------------------------------------------
|
||
|
* Fixed size Character array Char[ANY] handling
|
||
|
* ------------------------------------------------------------ */
|
||
|
|
||
|
/* memberin and globalin typemaps */
|
||
|
|
||
|
%typemap(memberin,noblock=1) Char [ANY]
|
||
|
{
|
||
|
if ($input) memcpy($1,$input,$1_dim0*sizeof(Char));
|
||
|
else memset($1,0,$1_dim0*sizeof(Char));
|
||
|
}
|
||
|
|
||
|
%typemap(globalin,noblock=1) Char [ANY]
|
||
|
{
|
||
|
if ($input) memcpy($1,$input,$1_dim0*sizeof(Char));
|
||
|
else memset($1,0,$1_dim0*sizeof(Char));
|
||
|
}
|
||
|
|
||
|
/* in */
|
||
|
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharArray)
|
||
|
Char [ANY] (Char temp[$1_dim0], int res),
|
||
|
const Char [ANY](Char temp[$1_dim0], int res)
|
||
|
{
|
||
|
res = SWIG_AsCharArray($input, temp, $1_dim0);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res,"$type",$symname, $argnum);
|
||
|
}
|
||
|
$1 = %reinterpret_cast(temp, $1_ltype);
|
||
|
}
|
||
|
%typemap(freearg) Char [ANY], const Char [ANY] "";
|
||
|
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharArray) const Char (&)[ANY] (Char temp[$1_dim0], int res)
|
||
|
{
|
||
|
res = SWIG_AsCharArray($input, temp, $1_dim0);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res,"$type",$symname, $argnum);
|
||
|
}
|
||
|
$1 = &temp;
|
||
|
}
|
||
|
%typemap(freearg) const Char (&)[ANY] "";
|
||
|
|
||
|
%typemap(out,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char [ANY], const Char[ANY]
|
||
|
{
|
||
|
size_t size = $1_dim0;
|
||
|
%#ifndef SWIG_PRESERVE_CARRAY_SIZE
|
||
|
while (size && ($1[size - 1] == '\0')) --size;
|
||
|
%#endif
|
||
|
%set_output(SWIG_FromCharPtrAndSize($1, size));
|
||
|
}
|
||
|
|
||
|
/* varin */
|
||
|
|
||
|
%typemap(varin,fragment=#SWIG_AsCharArray) Char [ANY]
|
||
|
{
|
||
|
int res = SWIG_AsCharArray($input, $1, $1_dim0);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%variable_fail(res, "$type", "$name");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* varout */
|
||
|
|
||
|
%typemap(varout,noblock=1,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char [ANY], const Char [ANY] {
|
||
|
size_t size = $1_dim0;
|
||
|
%#ifndef SWIG_PRESERVE_CARRAY_SIZE
|
||
|
while (size && ($1[size - 1] == '\0')) --size;
|
||
|
%#endif
|
||
|
%set_varoutput(SWIG_FromCharPtrAndSize($1, size));
|
||
|
}
|
||
|
|
||
|
/* constant */
|
||
|
|
||
|
%typemap(constcode,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char [ANY], const Char [ANY]
|
||
|
{
|
||
|
size_t size = $value_dim0;
|
||
|
%#ifndef SWIG_PRESERVE_CARRAY_SIZE
|
||
|
while (size && ($value[size - 1] == '\0')) --size;
|
||
|
%#endif
|
||
|
%set_constant("$symname", SWIG_FromCharPtrAndSize($value,size));
|
||
|
}
|
||
|
|
||
|
|
||
|
#if defined(SWIG_DIRECTOR_TYPEMAPS)
|
||
|
|
||
|
/* directorin */
|
||
|
%typemap(directorin,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char [ANY], const Char [ANY]
|
||
|
{
|
||
|
size_t size = $1_dim0;
|
||
|
%#ifndef SWIG_PRESERVE_CARRAY_SIZE
|
||
|
while (size && ($1_name[size - 1] == '\0')) --size;
|
||
|
%#endif
|
||
|
$input = SWIG_FromCharPtrAndSize($1_name, size);
|
||
|
}
|
||
|
|
||
|
/* directorout */
|
||
|
|
||
|
%typemap(directorout,noblock=1,fragment=#SWIG_AsCharArray)
|
||
|
Char [ANY] (Char temp[$result_dim0]),
|
||
|
const Char [ANY] (Char temp[$result_dim0], int res)
|
||
|
{
|
||
|
res = SWIG_AsCharArray($input, temp, $result_dim0);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%dirout_fail(res, "$type");
|
||
|
}
|
||
|
$result = temp;
|
||
|
}
|
||
|
|
||
|
#endif /* SWIG_DIRECTOR_TYPEMAPS */
|
||
|
|
||
|
/* typecheck */
|
||
|
|
||
|
%typemap(typecheck,noblock=1,precedence=StringCode,
|
||
|
fragment=#SWIG_AsCharArray)
|
||
|
Char [ANY], const Char[ANY] {
|
||
|
int res = SWIG_AsCharArray($input, (Char *)0, 0);
|
||
|
$1 = SWIG_CheckState(res);
|
||
|
}
|
||
|
|
||
|
|
||
|
/* throws */
|
||
|
|
||
|
%typemap(throws,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char [ANY], const Char[ANY]
|
||
|
{
|
||
|
size_t size = $1_dim0;
|
||
|
%#ifndef SWIG_PRESERVE_CARRAY_SIZE
|
||
|
while (size && ($1[size - 1] == '\0')) --size;
|
||
|
%#endif
|
||
|
%raise(SWIG_FromCharPtrAndSize($1, size), "$type", 0);
|
||
|
}
|
||
|
|
||
|
/* -------------------------------------------------------------------
|
||
|
* --- Really fix size Char arrays, including '\0'chars at the end ---
|
||
|
* ------------------------------------------------------------------- */
|
||
|
|
||
|
%typemap(varout,noblock=1,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char FIXSIZE[ANY], const Char FIXSIZE[ANY]
|
||
|
{
|
||
|
%set_varoutput(SWIG_FromCharPtrAndSize($1, $1_dim0));
|
||
|
}
|
||
|
|
||
|
%typemap(out,noblock=1,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char FIXSIZE[ANY], const Char FIXSIZE[ANY]
|
||
|
{
|
||
|
%set_output(SWIG_FromCharPtrAndSize($1, $1_dim0));
|
||
|
}
|
||
|
|
||
|
#if defined(SWIG_DIRECTOR_TYPEMAPS)
|
||
|
|
||
|
%typemap(directorin,noblock=1,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char FIXSIZE[ANY], const Char FIXSIZE[ANY]
|
||
|
{
|
||
|
$input = SWIG_FromCharPtrAndSize($1_name, $1_dim0);
|
||
|
}
|
||
|
|
||
|
#endif /* SWIG_DIRECTOR_TYPEMAPS */
|
||
|
|
||
|
%typemap(throws,noblock=1,fragment=#SWIG_FromCharPtrAndSize)
|
||
|
Char FIXSIZE[ANY], const Char FIXSIZE[ANY] {
|
||
|
%raise(SWIG_FromCharPtrAndSize($1, $1_dim0), "$type", 0);
|
||
|
}
|
||
|
|
||
|
/* ------------------------------------------------------------
|
||
|
* --- String & length ---
|
||
|
* ------------------------------------------------------------ */
|
||
|
|
||
|
/* Here len doesn't include the '0' terminator */
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharPtrAndSize)
|
||
|
(Char *STRING, size_t LENGTH) (int res, Char *buf = 0, size_t size = 0, int alloc = 0),
|
||
|
(const Char *STRING, size_t LENGTH) (int res, Char *buf = 0, size_t size = 0, int alloc = 0)
|
||
|
{
|
||
|
res = SWIG_AsCharPtrAndSize($input, &buf, &size, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res,"$type",$symname, $argnum);
|
||
|
}
|
||
|
$1 = %reinterpret_cast(buf, $1_ltype);
|
||
|
$2 = %numeric_cast(size - 1, $2_ltype);
|
||
|
}
|
||
|
%typemap(freearg,noblock=1,match="in") (Char *STRING, size_t LENGTH) {
|
||
|
if (alloc$argnum == SWIG_NEWOBJ) %delete_array(buf$argnum);
|
||
|
}
|
||
|
/* old 'int' form */
|
||
|
%typemap(in) (Char *STRING, int LENGTH) = (Char *STRING, size_t LENGTH);
|
||
|
%typemap(freearg) (Char *STRING, int LENGTH) = (Char *STRING, size_t LENGTH);
|
||
|
|
||
|
|
||
|
/* Here size includes the '0' terminator */
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharPtrAndSize)
|
||
|
(Char *STRING, size_t SIZE) (int res, Char *buf = 0, size_t size = 0, int alloc = 0),
|
||
|
(const Char *STRING, size_t SIZE) (int res, Char *buf = 0, size_t size = 0, int alloc = 0)
|
||
|
{
|
||
|
res = SWIG_AsCharPtrAndSize($input, &buf, &size, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res,"$type",$symname, $argnum);
|
||
|
}
|
||
|
$1 = %reinterpret_cast(buf, $1_ltype);
|
||
|
$2 = %numeric_cast(size, $2_ltype);
|
||
|
}
|
||
|
%typemap(freearg,noblock=1,match="in") (Char *STRING, size_t SIZE) {
|
||
|
if (alloc$argnum == SWIG_NEWOBJ) %delete_array(buf$argnum);
|
||
|
}
|
||
|
/* old 'int' form */
|
||
|
%typemap(in) (Char *STRING, int SIZE) = (Char *STRING, size_t SIZE);
|
||
|
%typemap(freearg) (Char *STRING, int SIZE) = (Char *STRING, size_t SIZE);
|
||
|
|
||
|
|
||
|
/* reverse order versions */
|
||
|
|
||
|
/* Here len doesn't include the '0' terminator */
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharPtrAndSize)
|
||
|
(size_t LENGTH, Char *STRING) (int res, Char *buf = 0, size_t size = 0, int alloc = 0),
|
||
|
(size_t LENGHT, const Char *STRING) (int res, Char *buf = 0, size_t size = 0, int alloc = 0)
|
||
|
{
|
||
|
res = SWIG_AsCharPtrAndSize($input, &buf, &size, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res,"$type",$symname, $argnum);
|
||
|
}
|
||
|
$2 = %reinterpret_cast(buf, $2_ltype) ;
|
||
|
$1 = %numeric_cast(size - 1, $1_ltype) ;
|
||
|
}
|
||
|
%typemap(freearg, noblock=1, match="in") (size_t LENGTH, Char *STRING) {
|
||
|
if (alloc$argnum == SWIG_NEWOBJ) %delete_array(buf$argnum);
|
||
|
}
|
||
|
/* old 'int' form */
|
||
|
%typemap(in) (int LENGTH, Char *STRING) = (size_t LENGTH, Char *STRING);
|
||
|
%typemap(freearg) (int LENGTH, Char *STRING) = (size_t LENGTH, Char *STRING);
|
||
|
|
||
|
/* Here size includes the '0' terminator */
|
||
|
%typemap(in,noblock=1,fragment=#SWIG_AsCharPtrAndSize)
|
||
|
(size_t SIZE, Char *STRING) (int res, Char *buf = 0, size_t size = 0, int alloc = 0),
|
||
|
(size_t SIZE, const Char *STRING) (int res, Char *buf = 0, size_t size = 0, int alloc = 0)
|
||
|
{
|
||
|
res = SWIG_AsCharPtrAndSize($input, &buf, &size, &alloc);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
%argument_fail(res, "$type",$symname, $argnum);
|
||
|
}
|
||
|
$2 = %reinterpret_cast(buf, $2_ltype) ;
|
||
|
$1 = %numeric_cast(size, $1_ltype) ;
|
||
|
}
|
||
|
%typemap(freearg, noblock=1, match="in") (size_t SIZE, Char *STRING) {
|
||
|
if (alloc$argnum == SWIG_NEWOBJ) %delete_array(buf$argnum);
|
||
|
}
|
||
|
/* old 'int' form */
|
||
|
%typemap(in) (int SIZE, Char *STRING) = (size_t SIZE, Char *STRING);
|
||
|
%typemap(freearg) (int SIZE, Char *STRING) = (size_t SIZE, Char *STRING);
|
||
|
|
||
|
|
||
|
%enddef
|
||
|
|
||
|
|
||
|
/* ------------------------------------------------------------
|
||
|
* --- String fragment methods ---
|
||
|
* ------------------------------------------------------------ */
|
||
|
|
||
|
|
||
|
%define %typemaps_string(StringCode, CharCode,
|
||
|
Char, CharName,
|
||
|
SWIG_AsCharPtrAndSize,
|
||
|
SWIG_FromCharPtrAndSize,
|
||
|
SWIG_CharPtrLen,
|
||
|
FragLimits, CHAR_MIN, CHAR_MAX)
|
||
|
|
||
|
%fragment("SWIG_From"#CharName"Ptr","header",fragment=#SWIG_FromCharPtrAndSize) {
|
||
|
SWIGINTERNINLINE SWIG_Object
|
||
|
SWIG_From##CharName##Ptr(const Char *cptr)
|
||
|
{
|
||
|
return SWIG_FromCharPtrAndSize(cptr, (cptr ? SWIG_CharPtrLen(cptr) : 0));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
%fragment("SWIG_From"#CharName"Array","header",fragment=#SWIG_FromCharPtrAndSize) {
|
||
|
SWIGINTERNINLINE SWIG_Object
|
||
|
SWIG_From##CharName##Array(const Char *cptr, size_t size)
|
||
|
{
|
||
|
return SWIG_FromCharPtrAndSize(cptr, size);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
%fragment("SWIG_As" #CharName "Ptr","header",fragment=#SWIG_AsCharPtrAndSize) {
|
||
|
%define_as(SWIG_As##CharName##Ptr(obj, val, alloc), SWIG_AsCharPtrAndSize(obj, val, NULL, alloc))
|
||
|
}
|
||
|
|
||
|
%fragment("SWIG_As" #CharName "Array","header",fragment=#SWIG_AsCharPtrAndSize) {
|
||
|
SWIGINTERN int
|
||
|
SWIG_As##CharName##Array(SWIG_Object obj, Char *val, size_t size)
|
||
|
{
|
||
|
Char* cptr = 0; size_t csize = 0; int alloc = SWIG_OLDOBJ;
|
||
|
int res = SWIG_AsCharPtrAndSize(obj, &cptr, &csize, &alloc);
|
||
|
if (SWIG_IsOK(res)) {
|
||
|
if ((csize == size + 1) && cptr && !(cptr[csize-1])) --csize;
|
||
|
if (csize <= size) {
|
||
|
if (val) {
|
||
|
if (csize) memcpy(val, cptr, csize*sizeof(Char));
|
||
|
if (csize < size) memset(val + csize, 0, (size - csize)*sizeof(Char));
|
||
|
}
|
||
|
if (alloc == SWIG_NEWOBJ) {
|
||
|
%delete_array(cptr);
|
||
|
res = SWIG_DelNewMask(res);
|
||
|
}
|
||
|
return res;
|
||
|
}
|
||
|
if (alloc == SWIG_NEWOBJ) %delete_array(cptr);
|
||
|
}
|
||
|
return SWIG_TypeError;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* Char */
|
||
|
|
||
|
%fragment(SWIG_From_frag(Char),"header",fragment=#SWIG_FromCharPtrAndSize) {
|
||
|
SWIGINTERNINLINE SWIG_Object
|
||
|
SWIG_From_dec(Char)(Char c)
|
||
|
{
|
||
|
return SWIG_FromCharPtrAndSize(&c,1);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
%fragment(SWIG_AsVal_frag(Char),"header",
|
||
|
fragment="SWIG_As"#CharName"Array",
|
||
|
fragment=FragLimits,
|
||
|
fragment=SWIG_AsVal_frag(long)) {
|
||
|
SWIGINTERN int
|
||
|
SWIG_AsVal_dec(Char)(SWIG_Object obj, Char *val)
|
||
|
{
|
||
|
int res = SWIG_As##CharName##Array(obj, val, 1);
|
||
|
if (!SWIG_IsOK(res)) {
|
||
|
long v;
|
||
|
res = SWIG_AddCast(SWIG_AsVal(long)(obj, &v));
|
||
|
if (SWIG_IsOK(res)) {
|
||
|
if ((CHAR_MIN <= v) && (v <= CHAR_MAX)) {
|
||
|
if (val) *val = %numeric_cast(v, Char);
|
||
|
} else {
|
||
|
res = SWIG_OverflowError;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
return res;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
%typemaps_asvalfromn(CharCode, Char);
|
||
|
|
||
|
%_typemap_string(StringCode,
|
||
|
Char,
|
||
|
SWIG_AsCharPtrAndSize,
|
||
|
SWIG_FromCharPtrAndSize,
|
||
|
SWIG_CharPtrLen,
|
||
|
SWIG_As##CharName##Ptr,
|
||
|
SWIG_From##CharName##Ptr,
|
||
|
SWIG_As##CharName##Array)
|
||
|
|
||
|
%enddef
|