https://swig.svn.sourceforge.net/svnroot/swig/trunk ................ r10487 | wsfulton | 2008-05-21 23:15:52 +0100 (Wed, 21 May 2008) | 1 line Apply patch from Petr Viktorin to fix some recent regressions in CFFI/CLOS ................ r10498 | talby | 2008-05-26 21:09:56 +0100 (Mon, 26 May 2008) | 2 lines run test cases in the Perl set by the --with-perl5 configure option. ................ r10499 | talby | 2008-05-26 22:04:06 +0100 (Mon, 26 May 2008) | 3 lines The perl5 minherit runtime test will work better if the classes are actually built under SWIGPERL. ................ r10503 | wsfulton | 2008-05-28 10:44:37 +0100 (Wed, 28 May 2008) | 1 line Fix variable wrappers when using -proxy. Patch from Jan Jezabek ................ r10504 | bhy | 2008-05-28 18:27:48 +0100 (Wed, 28 May 2008) | 2 lines Fixed SF #1971977: typo in pycontainer.swg (related to -extranative option) ................ r10506 | wsfulton | 2008-05-29 01:45:28 +0100 (Thu, 29 May 2008) | 1 line Fix variable wrappers when using -noproxy ................ r10508 | bhy | 2008-05-30 14:53:33 +0100 (Fri, 30 May 2008) | 1 line Fixed SF #1976978, apply the macros for primitive types to std::wstring ................ r10511 | olly | 2008-05-30 17:11:27 +0100 (Fri, 30 May 2008) | 4 lines Fix typo in handling of /*@SWIG[...]*/ comments in the scanner. This just meant we were only actually looking for /*@SWI at the start of the comment, so was pretty harmless in practice. ................ r10515 | wsfulton | 2008-06-02 21:10:40 +0100 (Mon, 02 Jun 2008) | 1 line Fix samename testcase for c# and java ................ r10516 | wsfulton | 2008-06-02 21:15:39 +0100 (Mon, 02 Jun 2008) | 1 line Fix enums when using -noproxy ................ r10518 | bhy | 2008-06-07 12:20:07 +0100 (Sat, 07 Jun 2008) | 4 lines Added a test case for keyword renaming. Now it works for Python in SWIG's -c++ mode, but in C mode it doesn't work! (you can try with make keyword_rename.ctest) ................ r10519 | bhy | 2008-06-07 14:40:51 +0100 (Sat, 07 Jun 2008) | 1 line fixed keyword_rename.ctest tese case, caused by a mistake in Swig/naming.c ................ r10527 | mgossage | 2008-06-17 03:57:15 +0100 (Tue, 17 Jun 2008) | 1 line [lua] bugfix 1938142 (bool& and bool* support) ................ r10530 | wsfulton | 2008-06-19 21:02:13 +0100 (Thu, 19 Jun 2008) | 1 line Add R keyword support. Rename keywords for successful compilation of Java and C# code. More consistent keyword warnings across the different languages. ................ r10531 | wsfulton | 2008-06-19 22:15:48 +0100 (Thu, 19 Jun 2008) | 1 line add complete list of R reserved words ................ r10536 | wsfulton | 2008-06-21 12:35:33 +0100 (Sat, 21 Jun 2008) | 1 line better terminology for static types ................ r10537 | wsfulton | 2008-06-21 12:42:48 +0100 (Sat, 21 Jun 2008) | 1 line remove raise as keyword test- it conflicts with _raise in LIBCMT on windows ................ r10539 | wsfulton | 2008-06-21 16:21:29 +0100 (Sat, 21 Jun 2008) | 1 line Lua example warning removal fixes for vc++ ................ r10540 | wsfulton | 2008-06-21 16:23:02 +0100 (Sat, 21 Jun 2008) | 1 line Remove some vc++ /W4 warnings ................ r10541 | wsfulton | 2008-06-21 17:04:55 +0100 (Sat, 21 Jun 2008) | 1 line minor vc++ /W4 warning fixes ................ r10542 | wsfulton | 2008-06-21 20:07:51 +0100 (Sat, 21 Jun 2008) | 1 line 'byte' is already used in Ruby on windows, so use another keyword ................ r10543 | wsfulton | 2008-06-21 21:45:32 +0100 (Sat, 21 Jun 2008) | 1 line Fix crashing in the Ruby reject method in the STL wrappers ................ r10544 | wsfulton | 2008-06-21 21:48:28 +0100 (Sat, 21 Jun 2008) | 1 line Fix crashing in the Ruby reject method in the STL wrappers ................ r10545 | wsfulton | 2008-06-21 21:49:10 +0100 (Sat, 21 Jun 2008) | 1 line remove unnecessary variable int the char **STRING_ARRAY out typemap ................ r10546 | wsfulton | 2008-06-21 22:07:49 +0100 (Sat, 21 Jun 2008) | 1 line Fix Ruby C++ example dependencies in dsp files ................ r10547 | wsfulton | 2008-06-21 23:25:36 +0100 (Sat, 21 Jun 2008) | 1 line Fix unused parameter warnings in python when using gcc's -W -Wall options ................ r10548 | wsfulton | 2008-06-21 23:26:35 +0100 (Sat, 21 Jun 2008) | 1 line Fix virtual destructor ................ r10549 | wsfulton | 2008-06-22 00:25:20 +0100 (Sun, 22 Jun 2008) | 1 line various warning fixes ................ r10550 | wsfulton | 2008-06-22 01:09:11 +0100 (Sun, 22 Jun 2008) | 1 line Another fix for the JVM hanging on exit problem when using directors ................ r10551 | wsfulton | 2008-06-22 01:09:51 +0100 (Sun, 22 Jun 2008) | 1 line documentation sections update ................ r10552 | wsfulton | 2008-06-22 01:18:10 +0100 (Sun, 22 Jun 2008) | 1 line more docs on defining macros for the thread hanging problem ................ r10558 | wsfulton | 2008-06-22 22:30:20 +0100 (Sun, 22 Jun 2008) | 1 line fix unused parms in last commit for C code ................ r10559 | wsfulton | 2008-06-22 23:12:43 +0100 (Sun, 22 Jun 2008) | 1 line Suppress unused methods warning for VC++ ................ r10560 | wsfulton | 2008-06-23 21:26:07 +0100 (Mon, 23 Jun 2008) | 1 line fix partialcheck-test-suite and parallel make for r, chicken, tcl and php ................ r10561 | wsfulton | 2008-06-23 21:39:41 +0100 (Mon, 23 Jun 2008) | 1 line correct message display when running the partialcheck-test-suite make target ................ r10562 | wsfulton | 2008-06-23 22:14:53 +0100 (Mon, 23 Jun 2008) | 1 line fix typo ................ r10563 | olly | 2008-06-23 22:23:54 +0100 (Mon, 23 Jun 2008) | 3 lines Fix bad use of Python API (untested, since I can't even compile this code on x86-64!) ................ r10564 | olly | 2008-06-23 23:58:03 +0100 (Mon, 23 Jun 2008) | 3 lines [PHP] Fix segfault when wrapping a non-class function marked with %newobject (testcase char_strings). ................ r10565 | olly | 2008-06-24 01:27:34 +0100 (Tue, 24 Jun 2008) | 3 lines [PHP] Fix assertion failure when handling %typemap(in,numinputs=0) (testcase ignore_parameter). ................ r10566 | olly | 2008-06-24 01:33:08 +0100 (Tue, 24 Jun 2008) | 2 lines [PHP] Fix typemap_namespace.i to not try to copy a non-existent typemap. ................ r10567 | olly | 2008-06-24 01:41:07 +0100 (Tue, 24 Jun 2008) | 3 lines Clean up dead and unused code in SwigToPhpType(), and rename to GetShadowReturnType(). ................ r10568 | olly | 2008-06-24 01:42:29 +0100 (Tue, 24 Jun 2008) | 2 lines Fix cosmetic typo in string constant. ................ r10574 | wsfulton | 2008-06-24 21:10:28 +0100 (Tue, 24 Jun 2008) | 1 line zap last entry ................ r10575 | wsfulton | 2008-06-24 21:11:46 +0100 (Tue, 24 Jun 2008) | 1 line variable name changes to remove php keywords ................ r10576 | wsfulton | 2008-06-24 21:12:08 +0100 (Tue, 24 Jun 2008) | 1 line variable name hiding fix ................ r10577 | wsfulton | 2008-06-24 21:12:43 +0100 (Tue, 24 Jun 2008) | 1 line More info about numobjects added ................ r10578 | wsfulton | 2008-06-24 21:13:41 +0100 (Tue, 24 Jun 2008) | 1 line update for 1.3.36 release ................ r10579 | wsfulton | 2008-06-24 22:48:46 +0100 (Tue, 24 Jun 2008) | 1 line remove deprecated -c commandline option (runtime library generation) ................ r10580 | wsfulton | 2008-06-24 22:53:12 +0100 (Tue, 24 Jun 2008) | 1 line correct comment about deprecated option ................ r10582 | wsfulton | 2008-06-25 00:00:27 +0100 (Wed, 25 Jun 2008) | 1 line use rsync and ssh to upload releases to SourceForge as ftp no longer works ................ r10584 | wsfulton | 2008-06-25 00:24:48 +0100 (Wed, 25 Jun 2008) | 1 line correction for 1.3.36 ................ r10588 | wsfulton | 2008-06-25 01:16:04 +0100 (Wed, 25 Jun 2008) | 1 line section update ................ r10589 | wsfulton | 2008-06-25 01:16:40 +0100 (Wed, 25 Jun 2008) | 1 line bump version to 1.3.37 ................ r10594 | wsfulton | 2008-06-26 19:33:06 +0100 (Thu, 26 Jun 2008) | 1 line correct typo in first entry about %fragment ................ r10607 | wsfulton | 2008-06-29 01:19:05 +0100 (Sun, 29 Jun 2008) | 1 line fix some potential null pointer usage as reported by CoveriCoverity Prevent ................ r10608 | wsfulton | 2008-06-29 01:50:27 +0100 (Sun, 29 Jun 2008) | 1 line fix potential null pointer usage as reported by Coverity Prevent ................ r10609 | wsfulton | 2008-06-29 10:57:41 +0100 (Sun, 29 Jun 2008) | 1 line make life easier for svn status updates as everyone has different autotool versions installed - use svn:ignore on config.sub and config.guess ................ r10610 | wsfulton | 2008-06-29 11:08:14 +0100 (Sun, 29 Jun 2008) | 1 line make life easier for svn status updates as everyone has different autotool versions installed - use svn:ignore on config.sub and config.guess ................ r10616 | talby | 2008-07-01 00:41:27 +0100 (Tue, 01 Jul 2008) | 2 lines Hopefully this provides more portable values for Infinity and NaN in Perl. ................ r10621 | wsfulton | 2008-07-01 23:02:14 +0100 (Tue, 01 Jul 2008) | 1 line update old commandline option ................ r10624 | olly | 2008-07-02 04:17:46 +0100 (Wed, 02 Jul 2008) | 5 lines [Python] Import the C extension differently for Python 2.6 and later so that an implicit relative import doesn't produce a deprecation warning for 2.6 and a failure for 2.7 and later. Patch from Richard Boulton in SF#2008229. ................ r10625 | bhy | 2008-07-02 05:56:11 +0100 (Wed, 02 Jul 2008) | 1 line fix the relative import patch by try both relative and absolute import ................ r10626 | olly | 2008-07-02 06:55:18 +0100 (Wed, 02 Jul 2008) | 4 lines [PHP4] Support for PHP4 has been removed. The PHP developers are no longer making new PHP4 releases, and won't even be patching critical security issues after 2008-08-08. ................ r10627 | bhy | 2008-07-02 07:06:56 +0100 (Wed, 02 Jul 2008) | 1 line fix the previous commit -- new approach using imp module ................ r10628 | bhy | 2008-07-02 07:29:15 +0100 (Wed, 02 Jul 2008) | 1 line minor fix on relative import: close fp if exception occured during imp.find_module ................ r10629 | bhy | 2008-07-02 08:08:00 +0100 (Wed, 02 Jul 2008) | 1 line reconstruct the relative import, now the generated code looks better ................ r10633 | olly | 2008-07-03 01:09:56 +0100 (Thu, 03 Jul 2008) | 9 lines WARN_* constants are user visible, so keep existing WARN_PHP4_* for backward compatibility, but add preferred forms WARN_PHP_* and use these ourselves. Rename Lib/php4 to Lib/php, Source/Modules/php4.cxx to Source/Modules/php.cxx. Add typemaps for const reference so Examples/test-suite/apply_signed_char.i works. ................ r10634 | olly | 2008-07-03 01:12:58 +0100 (Thu, 03 Jul 2008) | 2 lines Remove file added in error. ................ r10635 | olly | 2008-07-03 01:37:38 +0100 (Thu, 03 Jul 2008) | 2 lines Rename php4*.swg to php*.swg. ................ r10636 | olly | 2008-07-03 02:13:51 +0100 (Thu, 03 Jul 2008) | 2 lines Update wrt PHP4. ................ r10637 | olly | 2008-07-03 03:32:11 +0100 (Thu, 03 Jul 2008) | 4 lines [PHP] The deprecated command line option "-phpfull" has been removed. We recommend building your extension as a dynamically loadable module. ................ r10638 | olly | 2008-07-03 03:32:41 +0100 (Thu, 03 Jul 2008) | 2 lines Fix version number ................ r10639 | olly | 2008-07-03 07:04:24 +0100 (Thu, 03 Jul 2008) | 2 lines Make t_output_helper() static. ................ r10640 | olly | 2008-07-03 07:05:34 +0100 (Thu, 03 Jul 2008) | 2 lines Make testcase li_typemaps work for PHP. ................ r10641 | olly | 2008-07-03 10:12:16 +0100 (Thu, 03 Jul 2008) | 2 lines Fix check::classname() to compare case-insensitively and not try to interpolate objects into strings. ................ r10643 | olly | 2008-07-03 23:00:01 +0100 (Thu, 03 Jul 2008) | 4 lines The operator& trick in allowexcept.i doesn't work for SWIG/PHP because the generated code takes the address of the variable in the code in the "vinit" section. So comment out the private operator& for PHP. ................ r10647 | olly | 2008-07-04 00:55:33 +0100 (Fri, 04 Jul 2008) | 2 lines [PHP] The SWIG cdata.i library module is now supported. ................ r10649 | olly | 2008-07-04 02:02:22 +0100 (Fri, 04 Jul 2008) | 4 lines [PHP] The deprecated command line option "-make" has been removed. Searches on Google codesearch suggest that nobody is using it now anyway. ................ r10650 | olly | 2008-07-04 02:22:11 +0100 (Fri, 04 Jul 2008) | 4 lines [PHP] For std_vector.i and std_map.i, rename empty() to is_empty() since "empty" is a PHP reserved word. Based of patch from Mark Klein in SF#1943417. ................ r10662 | wsfulton | 2008-07-14 22:09:23 +0100 (Mon, 14 Jul 2008) | 1 line Fix director typemaps for pointers so that NULL pointers are correctly marshalled to C#/Java null in director methods ................ r10672 | olly | 2008-07-17 02:17:08 +0100 (Thu, 17 Jul 2008) | 2 lines Fix a typo; improve wording. ................ r10676 | wsfulton | 2008-07-17 22:05:49 +0100 (Thu, 17 Jul 2008) | 1 line SF #2019156 Configuring with --without-octave or --without-alllang did not disable octave. ................ r10677 | wsfulton | 2008-07-17 22:08:22 +0100 (Thu, 17 Jul 2008) | 1 line tidy output after detecting X11 headers ................ r10682 | wsfulton | 2008-07-19 19:08:06 +0100 (Sat, 19 Jul 2008) | 1 line a bit more on pgcpp ................ r10683 | wsfulton | 2008-07-19 23:45:54 +0100 (Sat, 19 Jul 2008) | 1 line Fix building of Tcl examples/test-suite on Mac OSX ................ r10714 | olly | 2008-07-27 13:51:16 +0100 (Sun, 27 Jul 2008) | 2 lines Fix "can can" typo in docs (SF#2026756) ................ r10726 | wuzzeb | 2008-08-02 09:28:02 +0100 (Sat, 02 Aug 2008) | 1 line Commit patch 2019314 ................ r10727 | wuzzeb | 2008-08-02 09:49:43 +0100 (Sat, 02 Aug 2008) | 1 line add assert.h to fix chicken build of external runtime (ext_test testsuite) ................ r10738 | talby | 2008-08-07 07:28:13 +0100 (Thu, 07 Aug 2008) | 2 lines hoist globals to local scope where trival. ................ r10743 | talby | 2008-08-08 04:10:55 +0100 (Fri, 08 Aug 2008) | 2 lines initial steps to clean up perl5 class methods (primarily constructors). ................ r10747 | talby | 2008-08-09 05:08:26 +0100 (Sat, 09 Aug 2008) | 2 lines moves perl space constructor fixups into wrapper code. ................ r10749 | talby | 2008-08-10 00:57:55 +0100 (Sun, 10 Aug 2008) | 2 lines usage_func() fix + CHANGES.current entry to explain my past few commits. ................ r10794 | talby | 2008-08-19 08:09:29 +0100 (Tue, 19 Aug 2008) | 3 lines rollback 10737:10749, this work is better left on a branch until it is in support a significant feature enhancement. ................ r10801 | drjoe | 2008-08-31 17:07:43 +0100 (Sun, 31 Aug 2008) | 2 lines change Rf_warning to warning. Looks like a typo ................ r10802 | wsfulton | 2008-09-01 20:59:23 +0100 (Mon, 01 Sep 2008) | 1 line Fix ruby detection problem breaking configure ................ r10803 | wsfulton | 2008-09-01 21:00:28 +0100 (Mon, 01 Sep 2008) | 1 line Fix another perl global namespace pollution ................ r10804 | wsfulton | 2008-09-01 21:32:53 +0100 (Mon, 01 Sep 2008) | 1 line Fix array bounds checking in C# std::vector wrappers ................ r10805 | wsfulton | 2008-09-01 21:34:49 +0100 (Mon, 01 Sep 2008) | 1 line fix runtime problem in Ruby std_vector example ................ r10806 | wsfulton | 2008-09-01 21:42:40 +0100 (Mon, 01 Sep 2008) | 1 line Fix portability problem using /dev/null ................ r10807 | wsfulton | 2008-09-01 22:46:41 +0100 (Mon, 01 Sep 2008) | 1 line patch #2079381 submitted by Boris Smilga - constant exprs put into no-eval context in DEFCENUM ................ r10808 | wsfulton | 2008-09-02 21:56:52 +0100 (Tue, 02 Sep 2008) | 1 line Add new terminator attribute for the csin typemap for C# ................ r10809 | wsfulton | 2008-09-03 00:01:37 +0100 (Wed, 03 Sep 2008) | 1 line Fix #1988296 - Multiple module director linking issue ................ r10827 | richardb | 2008-09-10 11:08:21 +0100 (Wed, 10 Sep 2008) | 6 lines [Python] Commit patch #2089149: Director exception handling mangles returned exception. Exceptions raised by Python code in directors are now passed through to the caller without change. Also, remove the ": " prefix which used to be added to other director exceptions (eg, those due to incorrect return types). ................ r10828 | bhy | 2008-09-10 11:45:33 +0100 (Wed, 10 Sep 2008) | 3 lines Initialized merge tracking via "svnmerge" with revisions "1-10827" from https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-bhy ................ r10829 | bhy | 2008-09-10 12:04:09 +0100 (Wed, 10 Sep 2008) | 4 lines Removed merge tracking for "svnmerge" for https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-bhy (Undo the init due to user error) ................ r10830 | bhy | 2008-09-10 12:08:16 +0100 (Wed, 10 Sep 2008) | 3 lines Initialized merge tracking via "svnmerge" with revisions "1-10403" from https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-bhy ................ r10831 | bhy | 2008-09-10 12:51:12 +0100 (Wed, 10 Sep 2008) | 11 lines (Still trying to set right properity to get svnmerge work...) Recorded merge of revisions 10404 via svnmerge from https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-bhy ........ r10404 | bhy | 2008-05-01 08:35:49 +0800 (Thu, 01 May 2008) | 5 lines Start of gsoc2008-bhy branch. This is a branch for Haoyu Bai's Python 3.0 backend project. Some file already modified since a little of work already done when starting the branch. ........ ................ r10834 | bhy | 2008-09-11 18:18:07 +0100 (Thu, 11 Sep 2008) | 8 lines Merged the Python 3.0 support branch. The merging progress is not so smooth, so hope this commit won't make anything broken. This is the (incomplemete) log produced by svnmerge.py: Merged revisions 10405-10409,10420-10422,10426,10438,10445,10451,10454-10465,10467,10473-10475,10485,10488-10489,10493-10495,10497,10509-10510,10513-10514,10517,10520,10525,10528-10529,10533-10535,10554-10557,10570,10573,10593,10614,10666-10669,10673,10678,10687,10690,10704-10706,10731,10744,10750-10752,10755,10759,10770,10775-10776,10813,10819 via svnmerge from https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-bhy ................ git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2008-cherylfoil@10837 626c5289-ae23-0410-ae9c-e8d60b6d4f22
371 lines
12 KiB
Text
371 lines
12 KiB
Text
/* -----------------------------------------------------------------------------
|
|
* See the LICENSE file for information on copyright, usage and redistribution
|
|
* of SWIG, and the README file for authors - http://www.swig.org/release.html.
|
|
*
|
|
* luatypemaps.swg
|
|
*
|
|
* basic typemaps for Lua.
|
|
* ----------------------------------------------------------------------------- */
|
|
|
|
/* -----------------------------------------------------------------------------
|
|
* standard typemaps
|
|
* ----------------------------------------------------------------------------- */
|
|
/* NEW LANGUAGE NOTE:
|
|
the 'checkfn' param is something that I added for typemap(in)
|
|
it is an optional fn call to check the type of the lua object
|
|
the fn call must be of the form
|
|
int checkfn(lua_State *L, int index);
|
|
and return 1/0 depending upon if this is the correct type
|
|
For the typemap(out), an additional SWIG_arg parmeter must be incremented
|
|
to reflect the number of values returned (normally SWIG_arg++; will do)
|
|
*/
|
|
// numbers
|
|
%typemap(in,checkfn="lua_isnumber") int,short,long,
|
|
unsigned int,unsigned short,unsigned long,
|
|
signed char,unsigned char,
|
|
float,double
|
|
%{$1 = ($type)lua_tonumber(L, $input);%}
|
|
|
|
%typemap(out) int,short,long,
|
|
unsigned int,unsigned short,unsigned long,
|
|
signed char,unsigned char,
|
|
float,double
|
|
%{ lua_pushnumber(L, (lua_Number) $1); SWIG_arg++;%}
|
|
|
|
// we must also provide typemaps for privitives by const reference:
|
|
// given a function:
|
|
// int intbyref(const int& i);
|
|
// SWIG assumes that this code will need a pointer to int to be passed in
|
|
// (this might be ok for objects by const ref, but not for numeric primitives)
|
|
// therefore we add a set of typemaps to fix this (for both in & out)
|
|
%typemap(in,checkfn="lua_isnumber") const int&($basetype temp)
|
|
%{ temp=($basetype)lua_tonumber(L,$input); $1=&temp;%}
|
|
|
|
%typemap(out) const int&
|
|
%{ lua_pushnumber(L, (lua_Number) *$1); SWIG_arg++;%}
|
|
|
|
// for the other numbers we can just use an apply statement to cover them
|
|
%apply const int & {const short&,const long&,
|
|
const unsigned int&,const unsigned short&,const unsigned long&,
|
|
const signed char&,const unsigned char&,
|
|
const float&,const double&};
|
|
|
|
/* enums have to be handled slightly differently
|
|
VC++ .net will not allow a cast from lua_Number(double) to enum directly.
|
|
*/
|
|
%typemap(in,checkfn="lua_isnumber") enum SWIGTYPE
|
|
%{$1 = ($type)(int)lua_tonumber(L, $input);%}
|
|
|
|
%typemap(out) enum SWIGTYPE
|
|
%{ lua_pushnumber(L, (lua_Number)(int)($1)); SWIG_arg++;%}
|
|
|
|
// and const refs
|
|
%typemap(in,checkfn="lua_isnumber") const enum SWIGTYPE &($basetype temp)
|
|
%{ temp=($basetype)(int)lua_tonumber(L,$input); $1=&temp;%}
|
|
%typemap(out) const enum SWIGTYPE &
|
|
%{ lua_pushnumber(L, (lua_Number) *$1); SWIG_arg++;%}
|
|
|
|
|
|
// boolean (which is a special type in lua)
|
|
// note: lua_toboolean() returns 1 or 0
|
|
// note: 1 & 0 are not booleans in lua, only true & false
|
|
%typemap(in,checkfn="lua_isboolean") bool
|
|
%{$1 = (lua_toboolean(L, $input)!=0);%}
|
|
|
|
%typemap(out) bool
|
|
%{ lua_pushboolean(L,(int)($1!=0)); SWIG_arg++;%}
|
|
|
|
// for const bool&, SWIG treats this as a const bool* so we must dereference it
|
|
%typemap(in,checkfn="lua_isboolean") const bool& (bool temp)
|
|
%{temp=(lua_toboolean(L, $input)!=0);
|
|
$1=&temp;%}
|
|
|
|
%typemap(out) const bool&
|
|
%{ lua_pushboolean(L,(int)((*$1)!=0)); SWIG_arg++;%}
|
|
|
|
// strings (char* and char[])
|
|
%typemap(in,checkfn="lua_isstring") const char*, char*
|
|
%{$1 = ($ltype)lua_tostring(L, $input);%}
|
|
|
|
%typemap(in,checkfn="lua_isstring") const char[ANY], char[ANY]
|
|
%{$1 = ($ltype)lua_tostring(L, $input);%}
|
|
|
|
%typemap(out) const char*, char*
|
|
%{ lua_pushstring(L,(const char*)$1); SWIG_arg++;%}
|
|
|
|
%typemap(out) const char[ANY], char[ANY]
|
|
%{ lua_pushstring(L,(const char*)$1); SWIG_arg++;%}
|
|
|
|
// char's
|
|
// currently treating chars as small strings, not as numbers
|
|
// (however signed & unsigned char's are numbers...)
|
|
%typemap(in,checkfn="lua_isstring") char
|
|
%{$1 = (lua_tostring(L, $input))[0];%}
|
|
|
|
%typemap(out) char
|
|
%{ lua_pushfstring(L,"%c",$1); SWIG_arg++;%}
|
|
|
|
// by const ref
|
|
%typemap(in,checkfn="lua_isstring") const char& (char temp)
|
|
%{temp = (lua_tostring(L, $input))[0]; $1=&temp;%}
|
|
|
|
%typemap(out) const char&
|
|
%{ lua_pushfstring(L,"%c",*$1); SWIG_arg++;%}
|
|
|
|
// pointers and references
|
|
// under SWIG rules, it is ok, to have a pass in a lua nil,
|
|
// it should be converted to a SWIG NULL.
|
|
// This will only be allowed for pointers & arrays, not refs or by value
|
|
// the checkfn lua_isuserdata will only work for userdata
|
|
// the checkfn SWIG_isptrtype will work for both userdata and nil's
|
|
%typemap(in,checkfn="SWIG_isptrtype") SWIGTYPE*,SWIGTYPE[]
|
|
%{
|
|
if (!SWIG_IsOK(SWIG_ConvertPtr(L,$input,(void**)&$1,$descriptor,$disown))){
|
|
SWIG_fail_ptr("$symname",$argnum,$descriptor);
|
|
}
|
|
%}
|
|
|
|
%typemap(in,checkfn="lua_isuserdata") SWIGTYPE&
|
|
%{
|
|
if (!SWIG_IsOK(SWIG_ConvertPtr(L,$input,(void**)&$1,$descriptor,$disown))){
|
|
SWIG_fail_ptr("$symname",$argnum,$descriptor);
|
|
}
|
|
%}
|
|
|
|
// out is simple
|
|
%typemap(out) SWIGTYPE*,SWIGTYPE&
|
|
%{SWIG_NewPointerObj(L,$1,$descriptor,$owner); SWIG_arg++; %}
|
|
|
|
// dynamic casts
|
|
// this uses the SWIG_TypeDynamicCast() which relies on RTTI to find out what the pointer really is
|
|
// the we return it as the correct type
|
|
%typemap(out) SWIGTYPE *DYNAMIC,
|
|
SWIGTYPE &DYNAMIC
|
|
{
|
|
swig_type_info *ty = SWIG_TypeDynamicCast($1_descriptor, (void **) &$1);
|
|
SWIG_NewPointerObj(L,(void*)$1,ty,$owner); SWIG_arg++;
|
|
}
|
|
|
|
|
|
// passing objects by value
|
|
// SWIG_ConvertPtr wants an object pointer (the $<ype argp)
|
|
// then dereferences it to get the object
|
|
%typemap(in,checkfn="lua_isuserdata") SWIGTYPE ($<ype argp)
|
|
%{
|
|
if (!SWIG_IsOK(SWIG_ConvertPtr(L,$input,(void**)&argp,$&descriptor,0))){
|
|
SWIG_fail_ptr("$symname",$argnum,$&descriptor);
|
|
}
|
|
$1 = *argp;
|
|
%}
|
|
|
|
// Also needed for object ptrs by const ref
|
|
// eg A* const& ref_pointer(A* const& a);
|
|
// found in mixed_types.i
|
|
%typemap(in,checkfn="lua_isuserdata") SWIGTYPE *&($*ltype temp)
|
|
%{temp=($*ltype)SWIG_MustGetPtr(L,$input,$*descriptor,0,$argnum,"$symname");
|
|
$1=&temp;%}
|
|
|
|
%typemap(out) SWIGTYPE *&
|
|
%{SWIG_NewPointerObj(L,*$1,$*descriptor,$owner); SWIG_arg++; %}
|
|
|
|
|
|
// DISOWN-ing typemaps
|
|
// if you have an object pointer which must be disowned, use this typemap
|
|
// eg. for void destroy_foo(Foo* toDie);
|
|
// use %apply SWIGTYPE* DISOWN {Foo* toDie};
|
|
// you could just use %delobject, but this is more flexible
|
|
%typemap(in,checkfn="SWIG_isptrtype") SWIGTYPE* DISOWN,SWIGTYPE DISOWN[]
|
|
%{ if (!SWIG_IsOK(SWIG_ConvertPtr(L,$input,(void**)&$1,$descriptor,SWIG_POINTER_DISOWN))){
|
|
SWIG_fail_ptr("$symname",$argnum,$descriptor);
|
|
}
|
|
%}
|
|
|
|
|
|
// Primitive types--return by value
|
|
// must make a new object, copy the data & return the new object
|
|
// Note: the brackets are {...} and not %{..%}, because we want them to be included in the wrapper
|
|
// this is because typemap(out) does not support local variables, like in typemap(in) does
|
|
// and we need the $&1_ltype resultptr; to be declared
|
|
#ifdef __cplusplus
|
|
%typemap(out) SWIGTYPE
|
|
{
|
|
$&1_ltype resultptr = new $1_ltype((const $1_ltype &) $1);
|
|
SWIG_NewPointerObj(L,(void *) resultptr,$&1_descriptor,1); SWIG_arg++;
|
|
}
|
|
#else
|
|
%typemap(out) SWIGTYPE
|
|
{
|
|
$&1_ltype resultptr;
|
|
resultptr = ($&1_ltype) malloc(sizeof($1_type));
|
|
memmove(resultptr, &$1, sizeof($1_type));
|
|
SWIG_NewPointerObj(L,(void *) resultptr,$&1_descriptor,1); SWIG_arg++;
|
|
}
|
|
#endif
|
|
|
|
// member function pointer
|
|
// a member fn ptr is not 4 bytes like a normal pointer, but 8 bytes (at least on mingw)
|
|
// so the standard wrappering cannot be done
|
|
// nor can you cast a member function pointer to a void* (obviously)
|
|
// therefore a special wrappering functions SWIG_ConvertMember() & SWIG_NewMemberObj() were written
|
|
#ifdef __cplusplus
|
|
%typemap(in,checkfn="lua_isuserdata") SWIGTYPE (CLASS::*)
|
|
%{
|
|
if (!SWIG_IsOK(SWIG_ConvertMember(L,$input,(void*)(&$1),sizeof($type),$descriptor)))
|
|
SWIG_fail_ptr("$symname",$argnum,$descriptor);
|
|
%}
|
|
|
|
%typemap(out) SWIGTYPE (CLASS::*)
|
|
%{
|
|
SWIG_NewMemberObj(L,(void*)(&$1),sizeof($type),$descriptor); SWIG_arg++;
|
|
%}
|
|
#endif
|
|
|
|
|
|
// void (must be empty without the SWIG_arg++)
|
|
%typemap(out) void "";
|
|
|
|
/* void* is a special case
|
|
A function void fn(void*) should take any kind of pointer as a parameter (just like C/C++ does)
|
|
but if its an output, then it should be wrappered like any other SWIG object (using default typemap)
|
|
*/
|
|
%typemap(in,checkfn="SWIG_isptrtype") void*
|
|
%{$1=($1_ltype)SWIG_MustGetPtr(L,$input,0,0,$argnum,"$symname");%}
|
|
|
|
/* long long is another special case:
|
|
as lua only supports one numeric type (lua_Number), we will just
|
|
cast it to that & accept the loss of precision.
|
|
An alternative solution would be a long long struct or class
|
|
with the relevant operators.
|
|
*/
|
|
%apply long {long long, signed long long, unsigned long long};
|
|
%apply const long& {const long long&, const signed long long&, const unsigned long long&};
|
|
|
|
/* It is possible to also pass a lua_State* into a function, so
|
|
void fn(int a, float b, lua_State* s) is wrappable as
|
|
> fn(1,4.3) -- note: the state is implicitly passed in
|
|
*/
|
|
%typemap(in, numinputs=0) lua_State*
|
|
%{$1 = L;%}
|
|
|
|
|
|
|
|
/* -----------------------------------------------------------------------------
|
|
* typecheck rules
|
|
* ----------------------------------------------------------------------------- */
|
|
/* These are needed for the overloaded functions
|
|
These define the detection routines which will spot what
|
|
parmeters match which function
|
|
*/
|
|
|
|
// unfortunately lua only considers one type of number
|
|
// so all numbers (int,float,double) match
|
|
// you could add an advanced fn to get type & check if its integral
|
|
%typecheck(SWIG_TYPECHECK_INTEGER)
|
|
int, short, long,
|
|
unsigned int, unsigned short, unsigned long,
|
|
signed char, unsigned char,
|
|
long long, unsigned long long, signed long long,
|
|
const int &, const short &, const long &,
|
|
const unsigned int &, const unsigned short &, const unsigned long &,
|
|
const signed char&, const unsigned char&,
|
|
const long long &, const unsigned long long &,
|
|
enum SWIGTYPE, const enum SWIGTYPE&,
|
|
float, double, const float &, const double&
|
|
{
|
|
$1 = lua_isnumber(L,$input);
|
|
}
|
|
|
|
%typecheck(SWIG_TYPECHECK_BOOL)
|
|
bool, const bool &
|
|
{
|
|
$1 = lua_isboolean(L,$input);
|
|
}
|
|
|
|
// special check for a char (string of length 1)
|
|
%typecheck(SWIG_TYPECHECK_CHAR) char, const char& {
|
|
$1 = lua_isstring(L,$input) && (lua_strlen(L,$input)==1);
|
|
}
|
|
|
|
%typecheck(SWIG_TYPECHECK_STRING) char *, char[] {
|
|
$1 = lua_isstring(L,$input);
|
|
}
|
|
|
|
%typecheck(SWIG_TYPECHECK_POINTER) SWIGTYPE *, SWIGTYPE [] {
|
|
void *ptr;
|
|
if (SWIG_isptrtype(L,$input)==0 || SWIG_ConvertPtr(L,$input, (void **) &ptr, $1_descriptor, 0)) {
|
|
$1 = 0;
|
|
} else {
|
|
$1 = 1;
|
|
}
|
|
}
|
|
|
|
%typecheck(SWIG_TYPECHECK_POINTER) SWIGTYPE & {
|
|
void *ptr;
|
|
if (lua_isuserdata(L,$input)==0 || SWIG_ConvertPtr(L,$input, (void **) &ptr, $1_descriptor, 0)) {
|
|
$1 = 0;
|
|
} else {
|
|
$1 = 1;
|
|
}
|
|
}
|
|
|
|
%typecheck(SWIG_TYPECHECK_POINTER) SWIGTYPE {
|
|
void *ptr;
|
|
if (lua_isuserdata(L,$input)==0 || SWIG_ConvertPtr(L,$input, (void **) &ptr, $&1_descriptor, 0)) {
|
|
$1 = 0;
|
|
} else {
|
|
$1 = 1;
|
|
}
|
|
}
|
|
|
|
%typecheck(SWIG_TYPECHECK_VOIDPTR) void * {
|
|
void *ptr;
|
|
if (SWIG_isptrtype(L,$input)==0 || SWIG_ConvertPtr(L,$input, (void **) &ptr, 0, 0)) {
|
|
$1 = 0;
|
|
} else {
|
|
$1 = 1;
|
|
}
|
|
}
|
|
|
|
// Also needed for object ptrs by const ref
|
|
// eg const A* ref_pointer(A* const& a);
|
|
// found in mixed_types.i
|
|
%typecheck(SWIG_TYPECHECK_POINTER) SWIGTYPE* const &
|
|
{
|
|
void *ptr;
|
|
if (lua_isuserdata(L,$input)==0 || SWIG_ConvertPtr(L,$input, (void **) &ptr, $*descriptor, 0)) {
|
|
$1 = 0;
|
|
} else {
|
|
$1 = 1;
|
|
}
|
|
}
|
|
|
|
/* -----------------------------------------------------------------------------
|
|
* Others
|
|
* ----------------------------------------------------------------------------- */
|
|
|
|
// Array reference typemaps
|
|
%apply SWIGTYPE & { SWIGTYPE ((&)[ANY]) }
|
|
|
|
// size_t (which is just a unsigned long)
|
|
%apply unsigned long { size_t };
|
|
%apply const unsigned long & { const size_t & };
|
|
|
|
|
|
/* -----------------------------------------------------------------------------
|
|
* Specials
|
|
* ----------------------------------------------------------------------------- */
|
|
// swig::LANGUAGE_OBJ was added to allow containers of native objects
|
|
// however its rather difficult to do this in lua, as you cannot hold pointers
|
|
// to native objects (they are held in the interpreter)
|
|
// therefore for now: just ignoring this feature
|
|
#ifdef __cplusplus
|
|
%ignore swig::LANGUAGE_OBJ;
|
|
|
|
//%inline %{
|
|
%{
|
|
namespace swig {
|
|
typedef struct{} LANGUAGE_OBJ;
|
|
}
|
|
%}
|
|
|
|
#endif // __cplusplus
|