我想从 Haxe 程序访问 C++ 代码。我正在尝试使用外部类,但遇到了一些问题。我正在尝试使用 haxe -main Cpp_Extern -cpp Cpp_Extern 进行编译。
我的 Haxe 代码:
@:include("./Rectangle.cpp")
@:extern("Rectangle*")
extern class Rectangle
{
@:native("set_values") public function set_values(w : Int, h : Int) : Void;
@:native("new Rectangle") public static function create() : Rectangle;
}
class Cpp_Extern
{
public static function main()
{
Rectangle.set_values(10,20);
}
}
C++代码
#include <iostream>
class Rectangle
{
public:
void set_values (int x, int y)
{
std::cout << "x = " << x << "\n";
std::cout << "y = " << y << "\n";
}
};
int main()
{
Rectangle one;
return 0;
}
错误是
C:\Users\ila5\Desktop\CPP\Cpp_Extern>haxe -main Cpp_Extern -cpp Cpp_Extern
haxelib run hxcpp Build.xml haxe -Dhaxe3="1" -Dhaxe_ver="3.201" -Dhxcpp_api_level="321" -I"C:\\HaxeToolkit\\haxe\\extraLibs/" -I"" -I"C:\\HaxeToolkit\\haxe\\std/cpp/_std/" -I"C:\\HaxeToolkit\\haxe\\std/"
cl.exe -Iinclude -nologo -O2 /WX- /fp:precise -DHX_WINDOWS -D_USING_V140_SDK71_ -GR -FS -Oy- -c -EHs -GS- -arch:SSE -IC:/HaxeToolkit/haxe/lib/hxcpp/3,2,205/include -DHXCPP_VISIT_ALLOCS -DHXCPP_API_LEVEL=321 -D_CRT_SECURE_NO_DEPRECATE -D_ALLOW_MSC_VER_MISMATCH -D_ALLOW_ITERATOR_DEBUG_LEVEL_MISMATCH -wd4996 -MT ./src/Cpp_Extern.cpp -FoC:/Users/ila5/Desktop/CPP/Cpp_Extern/Cpp_Extern/obj/msvc19xp/2c1b12bd_Cpp_Extern.obj
Cpp_Extern.cpp
./src/Cpp_Extern.cpp(30): error C2440: 'initializing': cannot convert from 'Rectangle *' to 'Rectangle'
./src/Cpp_Extern.cpp(30): note: No constructor could take the source type, or constructor overload resolution was ambiguous
./src/Cpp_Extern.cpp(34): error C2819: type 'Rectangle' does not have an overloaded member 'operator ->'
C:/Users/ila5/Desktop/CPP/Cpp_Extern/Rectangle.cpp(4): note: see declaration of 'Rectangle'
./src/Cpp_Extern.cpp(34): note: did you intend to use '.' instead?
./src/Cpp_Extern.cpp(34): error C2232: '->Rectangle::set_values': left operand has 'class' type, use '.'
Error: Build failed
最佳答案
您需要添加 @:include
和 @:extern
元数据到您的外部类,以便 hxcpp 可以指向正确的文件并在编译时解析。
@:include
元标记允许您指向一个文件,该文件位于您的外部类定义之上。该文件需要相对于您的构建输出目录。
@:extern
meta 标记告诉 hxcpp 将类定义解析为您希望在 C++ 中看到的类的名称。因此,如果您正在创建一个指针,该类将使用 new
实例化。关键字,外部定义如下:
@:include("includes/Rectangle.cpp")
@:extern("Rectangle*")
extern class Rectangle
{
@:native("set_values") public function set_values(w : Int, h : Int) : Void;
@:native("new Rectangle") public static function create() : Rectangle;
}
您不能使用 new
带有 extern 类的函数定义,因为它不是常规的 Haxe 类。相反,你需要创建一个静态函数来执行实例化,它将 extern 类类型返回到 Haxe 上下文中,然后允许你访问它的成员变量。
如果您在包含供 hxcpp 查找的文件时遇到问题,您可以使用 XML 文件,您可以使用该文件告诉 hxcpp 要查找的文件夹。
在 Windows 上,您可以使用 <files id="haxe">
标签后跟内容 <compilerflag value="-I/../includes/" />
.当然,关闭此标记并确保 includes 文件夹位于项目的根目录中。
这将生成一个额外的编译器标志,告诉 Haxe 编译器在一个额外的文件夹中查找要包含的 C++ 源文件。然后您可以删除 include/
在你的 @:include
中加上前缀就在您的外部类定义之前。
然后要告诉 hxcpp 使用 XML 文件,您需要使用 @:buildXml
主入口点上方的元标记,应包含以下内容:<include name="${haxelib:myCustomRepo}/../Build.xml" />
同样,这需要与项目的根相关。
在上面的 XML 示例中,我使用了 ${haxelib:myCustomRepo}
它告诉 Haxe 寻找给定 haxelib 的路径。您可以使用以下命令设置 haxelib 存储库开发目录:haxelib dev myCustomRepo ./
在这种情况下可能会对您有所帮助。这将完全取决于您是否使用该路线。
您不必使用 XML 文件,但建议将其用于较大的项目,尤其是在跨平台和目标构建时。
我还注意到您的 C++ 代码中缺少构造函数,所以不要忘记将其放入。此外,您的主要入口点代码现在应如下所示:
@:buildXml('<include name="${haxelib:myCustomRepo}/../Build.xml" />') //only if you are using XML
class Main {
public static function main() {
var rect = Rectangle.create();
rect.set_values(10, 20);
}
}
在 C++ 中有两种实例化对象的方法。您可以使用 new
关键字,在这种情况下,返回的对象应该是指向该类型的指针。所以new Rectangle()
将返回 Rectangle*
在 C++ 中。如果你使用 Rectangle.create()
在 Haxe 中,并将其分配给一个变量,这就是您有效获得的结果。
您还可以使用 Rectangle rect;
实例化或声明在 C++ 中。这是像结构一样访问的,所以不是使用 ->
要访问成员,请使用句号“.”。
要在 Haxe 中运行,您需要添加 @:structAccess
外部的元数据。此外,您需要更改 @:native
来自@:native("Rectangle*")
至 @:native("Rectangle&")
.这确保初始变量将始终用作引用。
&
意味着使用一个变量作为一个引用,不像指针,它是一个引用。
关于c++ - 使用 extern 从 Haxe 访问 C++ 类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35620851/