1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
use build_context::BridgeModel;
use compile;
use failure::{Context, Error, ResultExt};
use module_writer::write_bindings_module;
use module_writer::write_cffi_module;
use module_writer::DevelopModuleWriter;
use std::path::Path;
use BuildOptions;
use PythonInterpreter;
use Target;
pub fn develop(
binding_crate: &Option<String>,
manifest_file: &Path,
cargo_extra_args: Vec<String>,
rustc_extra_args: Vec<String>,
venv_dir: &Path,
) -> Result<(), Error> {
let target = Target::current();
let python = target.get_venv_python(&venv_dir);
let interpreter = PythonInterpreter::check_executable(python, &target)?.ok_or_else(|| {
Context::new("Expected `python` to be a python interpreter inside a virtualenv ಠ_ಠ")
})?;
let build_options = BuildOptions {
interpreter: vec!["python".to_string()],
bindings: binding_crate.clone(),
manifest_path: manifest_file.to_path_buf(),
out: None,
debug: true,
skip_auditwheel: false,
cargo_extra_args,
rustc_extra_args,
};
let build_context = build_options.into_build_context()?;
let mut builder = DevelopModuleWriter::venv(&target, &venv_dir)?;
let context = "Failed to build a native library through cargo";
match build_context.bridge {
BridgeModel::Cffi => {
let artifact = compile(&build_context, None, None).context(context)?;
write_cffi_module(
&mut builder,
&build_context.module_name,
&artifact,
&build_context.target,
)?;
}
BridgeModel::Bindings {
ref bindings_crate, ..
} => {
let artifact = compile(
&build_context,
Some(&interpreter),
Some(bindings_crate.clone()),
).context(context)?;
write_bindings_module(
&mut builder,
&build_context.module_name,
&artifact,
&interpreter,
)?;
}
}
Ok(())
}