包装C头文件以将其与dll和JNA(erator)一起使用

|| 我有一个我需要访问的特定库的C标头。所以我用JNAerator进行了无聊的代码转换-在我读到人们最近推荐它之后。从我所看到的似乎很扎实:
public class Z3_apiLibrary implements Library {
public static final String JNA_LIBRARY_NAME = LibraryExtractor.getLibraryPath(\"z3_api\", true, z3_api.Z3_apiLibrary.class);

    public static final NativeLibrary JNA_NATIVE_LIB = NativeLibrary.getInstance(JNA_LIBRARY_NAME, com.ochafik.lang.jnaerator.runtime.MangledFunctionMapper.DEFAULT_OPTIONS);

static {
    Native.register(JNA_LIBRARY_NAME);
    }
public static interface Z3_lbool {
public static final int Z3_L_FALSE = -1;
public static final int Z3_L_UNDEF = 0;
public static final int Z3_L_TRUE = 1;
};

public static interface Z3_symbol_kind {
public static final int Z3_INT_SYMBOL = 0;
public static final int Z3_STRING_SYMBOL = 1;
};
完整的代码在我的GitHub上。 现在,我想将dll实例化为一个对象,并通过我的书面接口将标头信息作为包装器传递:
public class z3_Solver {

   public static void main(String[] args) {
    Z3_apiLibrary solver = (Z3_apiLibrary) Native.loadLibrary(\"z3\", Z3_apiLibrary.class);
    Z3_apiLibrary config = new Z3_apiLibrary.Z3_config(); // will not work!


   }
令我惊讶的是,这没有用。 .Z3_config()是抽象的。 mk_config是静态的和本地的。因此,我也无法解决该问题。...实际上,我认为需要将Path传递给Native.loadLibrary函数作为找到dll的参数。我将dll与Java类放在相同的路径中。这令人困惑,我怀疑也是错误的。 那么,实例化该JNAerator生成的接口的正确方法是什么?     
已邀请:
您发布的标头没有定义Z3_config是什么,它只显示DEFINE_TYPE(Z3_config);该头文件没有足够的信息来生成有效的绑定。清理标题,删除所有的#ifdef等,包括那些类型实际上应该是什么,然后尝试再次生成代码。     

要回复问题请先登录注册