diff options
author | Logan Johnson <ljohnson@users.sourceforge.net> | 2003-05-01 16:12:56 +0000 |
---|---|---|
committer | Logan Johnson <ljohnson@users.sourceforge.net> | 2003-05-01 16:12:56 +0000 |
commit | b49895faf2b5e5b34c188f69f646de6f1c6ef958 (patch) | |
tree | 1f99fa4b187656f8f3a701bd49c1100ee5e438f6 /Lib | |
parent | 0b4f3c499cb99a542c538707668e6fe4d1c714ed (diff) | |
download | swig-b49895faf2b5e5b34c188f69f646de6f1c6ef958.tar.gz |
*** empty log message ***
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@4761 626c5289-ae23-0410-ae9c-e8d60b6d4f22
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/pike/std_string.i | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/Lib/pike/std_string.i b/Lib/pike/std_string.i new file mode 100644 index 000000000..7247de788 --- /dev/null +++ b/Lib/pike/std_string.i @@ -0,0 +1,59 @@ +// +// SWIG typemaps for std::string +// Lyle Johnson +// May 1, 2003 +// +// Pike implementation + +%{ +#include <string> +%} + +namespace std { + + class string; + + /* Overloading check */ + + %typemap(typecheck) string = char *; + %typemap(typecheck) const string & = char *; + + %typemap(in, pikedesc="tStr") string { + if ($input.type != T_STRING) + Pike_error("Bad argument: Expected a string.\n"); + $1 = std::string(STR0($input.u.string)); + } + + %typemap(in, pikedesc="tStr") const string & (std::string temp) { + if ($input.type != T_STRING) + Pike_error("Bad argument: Expected a string.\n"); + temp = std::string(STR0($input.u.string)); + $1 = &temp; + } + + %typemap(out, pikedesc="tStr") string "push_text($1.c_str());"; + + %typemap(out, pikedesc="tStr") const string & "push_text($1->c_str());"; + + %typemap(inv) string, const string &, string & "$1_name.c_str()"; + + %typemap(inv) string *, const string * "$1_name->c_str()"; + + %typemap(outv) string { + if ($input.type == T_STRING) + $result = std::string(STR0($input.u.string)); + else + throw SWIG_DIRECTOR_TYPE_MISMATCH("string expected"); + } + + %typemap(outv) const string & (std::string temp) { + if ($input.type == T_STRING) { + temp = std::string(STR0($input.u.string)); + $result = &temp; + } else { + throw SWIG_DIRECTOR_TYPE_MISMATCH("string expected"); + } + } + +} + |