遗憾的是,由于包装器的生成方式,您无法完全摆脱铸件.
但是,您可以拦截基本数据类型并将它们重定向到模板函数,如下所示:
%module sphp
%{
#include
extern int hello(char *str);
template
int hello(const T &)
{
std::cout << "unsupported data type" << std::endl;
}
%}
extern int hello(char *str);
template
int hello(const T &);
%template(hello) hello;
要拦截更多数据类型,只需添加一个新的运算符重载:
%template(hello) hello;
更新:
这是一个更加困难的方法,可以通过覆盖SWIG的typemaps来实现.这取自SWIG的PHP类型映射并进行修改以防止它转换值.
%module sphp
%{
extern int hello(char *str);
%}
%typemap(in) char *
{
if ((*$input)->type != IS_STRING)
SWIG_PHP_Error(E_ERROR, "Type error in argument $argnum of $symname. Expected string");
$1 = ($1_ltype) Z_STRVAL_PP($input);
}
%typemap(in) (char *STRING, int LENGTH), (char *STRING, size_t LENGTH) {
if ((*$input)->type != IS_STRING)
SWIG_PHP_Error(E_ERROR, "Type error in argument $argnum of $symname. Expected string");
$1 = ($1_ltype) Z_STRVAL_PP($input);
$2 = ($2_ltype) Z_STRLEN_PP($input);
}
extern int hello(char *str);
输出:
php > include ("sphp.php");
php > hello("test");
Hello World: test
php > hello(3);
PHP Fatal error: Type error in argument 1 of hello. Expected string in php shell code on line 1
php > hello([]);
PHP Fatal error: Type error in argument 1 of hello. Expected string in php shell code on line 1
php >
这更加乏味,因为如果你想完全摆脱自动参数转换,你必须以相同的方式覆盖每一种类型,另一方面它可以让你更好地控制参数转发的行为.