如何从Rust FFI创建和返回C ++结构?

时间:2017-09-25 14:22:36

标签: rust ffi

我试图创建并返回一个C ++结构。我在尝试编译时遇到cannot move out of dereference of raw pointer错误。知道我怎么能做这个工作吗?

#![allow(non_snake_case)]
#![allow(unused_variables)]

extern crate octh;

// https://thefullsnack.com/en/string-ffi-rust.html
use std::ffi::CString;

#[no_mangle]
pub unsafe extern "C" fn Ghelloworld(
    shl: *const octh::root::octave::dynamic_library,
    relative: bool,
) -> *mut octh::root::octave_dld_function {
    let name = CString::new("helloworld").unwrap();
    let pname = name.as_ptr() as *const octh::root::std::string;
    std::mem::forget(pname);

    let doc = CString::new("Hello World Help String").unwrap();
    let pdoc = doc.as_ptr() as *const octh::root::std::string;
    std::mem::forget(pdoc);

    return octh::root::octave_dld_function_create(Some(Fhelloworld), shl, pname, pdoc);
}

pub unsafe extern "C" fn Fhelloworld(
    args: *const octh::root::octave_value_list,
    nargout: ::std::os::raw::c_int,
) -> octh::root::octave_value_list {
    let list: *mut octh::root::octave_value_list = ::std::ptr::null_mut();
    octh::root::octave_value_list_new(list);
    std::mem::forget(list);
    return *list;
}

1 个答案:

答案 0 :(得分:6)

  

我试图创建并返回一个C ++结构

你不能; C ++(如Rust)没有稳定的,定义的ABI。 Rust中没有办法指定结构具有repr(C++),因此您无法创建这样的结构,更不用说返回它了。

唯一稳定的ABI是由C提供的。您可以将结构定义为repr(C)以便能够直接返回它们:

extern crate libc;

use std::ptr;

#[repr(C)]
pub struct ValueList {
    id: libc::int32_t,
}

#[no_mangle]
pub extern "C" fn hello_world() -> ValueList {
    let list_ptr = ::std::ptr::null_mut();
    // untested, will cause segfault unless list_ptr is set
    unsafe { ptr::read(list_ptr) }
}

但这种方法非常可疑;通常你会把它看成是

#[no_mangle]
pub extern "C" fn hello_world() -> ValueList {
    unsafe {
        let mut list = mem::uninitialized();
        list_initialize(&mut list);
        list
    }
}

另见:

我鼓励您阅读我的Rust FFI Omnibus