Move '[const] T const **' and 'size_t' of 'in' typemap into macros
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2012-c@13671 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
89725492f2
commit
f9c0e104e6
1 changed files with 5 additions and 16 deletions
21
Lib/c/c.swg
21
Lib/c/c.swg
|
|
@ -134,7 +134,7 @@ PRE short POST, PRE int POST, PRE long POST, PRE long long POST, PRE char POST,
|
|||
|
||||
//this macro is necessary, because 'unsigned double' is not allowed.
|
||||
%define in_assignment_cast_unsigned_only(PRE, POST)
|
||||
PRE float POST, PRE double POST, PRE signed char POST "$1 = ($1_ltype) $input;"
|
||||
PRE float POST, PRE double POST, PRE signed char POST, PRE size_t POST "$1 = ($1_ltype) $input;"
|
||||
%enddef
|
||||
|
||||
%define in_assignment_group(PRE)
|
||||
|
|
@ -144,6 +144,7 @@ in_assignment_cast(PRE,&);
|
|||
in_assignment_cast(PRE,[ANY]);
|
||||
in_assignment_cast(PRE,*&);
|
||||
in_assignment_cast(PRE,**);
|
||||
in_assignment_cast(PRE,** const);
|
||||
%enddef
|
||||
|
||||
in_assignment_group();
|
||||
|
|
@ -157,30 +158,18 @@ in_assignment_cast_unsigned_only(,&);
|
|||
in_assignment_cast_unsigned_only(,[ANY]);
|
||||
in_assignment_cast_unsigned_only(,**);
|
||||
in_assignment_cast_unsigned_only(,*&);
|
||||
in_assignment_cast_unsigned_only(,** const);
|
||||
in_assignment_cast_unsigned_only(const,);
|
||||
in_assignment_cast_unsigned_only(const,*);
|
||||
in_assignment_cast_unsigned_only(const,&);
|
||||
in_assignment_cast_unsigned_only(const,[ANY]);
|
||||
in_assignment_cast_unsigned_only(const,*&);
|
||||
in_assignment_cast_unsigned_only(const,**);
|
||||
in_assignment_cast_unsigned_only(const,** const);
|
||||
|
||||
%typemap(in) short [ANY], int [ANY], long [ANY], long long [ANY], char [ANY], float [ANY], double [ANY], unsigned char [ANY] "$1 = ($1_basetype *) $input;"
|
||||
%typemap(in) short * [ANY], int * [ANY], long * [ANY], long long * [ANY], char * [ANY], float * [ANY], double * [ANY] "$1 = ($1_basetype *) $input;"
|
||||
|
||||
// constant pointers
|
||||
%typemap(in) short* * const, int* * const, long* * const, long long* * const, char* * const, float* * const, double* * const "$1 = ($1_ltype) $input;"
|
||||
%typemap(in) const short* * const, const int* * const, const long* * const, const long long* * const, const char* * const, const float* * const, const double* * const "$1 = ($1_ltype) $input;"
|
||||
|
||||
// size_t
|
||||
%typemap(in) size_t, const size_t "$1 = (size_t) $input;"
|
||||
%typemap(in) size_t*, size_t&, size_t[ANY], size_t[] "$1 = (size_t *) $input;"
|
||||
%typemap(in) const size_t&, const size_t*, const size_t[ANY], const size_t[] "$1 = (const size_t *) &$input;"
|
||||
%typemap(in) size_t**, size_t*&, size_t*[ANY], size_t[ANY][ANY] "$1 = (size_t **) $input;"
|
||||
%typemap(in) const size_t**, const size_t*&, const size_t*[ANY], const size_t[ANY][ANY] "$1 = (const size_t **) $input;"
|
||||
// constant pointers
|
||||
%typemap(in) size_t * const "$1 = (size_t) $input;"
|
||||
%typemap(in) size_t* * const "$1 = (size_t *) $input;"
|
||||
%typemap(in) const size_t* * const "$1 = (const size_t **) $input;"
|
||||
|
||||
%typemap(in, fragment="stdbool_inc") bool, bool *, bool **, const bool, const bool * "$1 = ($1_ltype) $input;"
|
||||
%typemap(in, fragment="stdbool_inc") bool & "$1 = ($1_basetype *) $input;"
|
||||
%typemap(in, fragment="stdbool_inc") const bool &, const bool * "$1 = ($1_basetype *) $input;"
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue