Skip to content

Commit f5bb354

Browse files
committed
Allow static and dynamic linking
Currently bindgen always uses clang-sys with the "runtime" feature - that is, load libclang at runtime with dlopen (or similar) at runtime. This PR keeps this default, but also - adds "static" to statically link libclang - without either "runtime" or "static", link with the shared library Many distributions don't ship with a static libclang, but linking with the dynamic library will use normal ld.so mechanisms to define where the .so file should be found. (Ditto for the Mac and Windows equivalents.)
1 parent d92cdf7 commit f5bb354

File tree

2 files changed

+14
-9
lines changed

2 files changed

+14
-9
lines changed

Cargo.toml

+4-3
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,7 @@ cexpr = "0.3.3"
4949
cfg-if = "0.1.0"
5050
# This kinda sucks: https://github.com/rust-lang/cargo/issues/1982
5151
clap = { version = "2", optional = true }
52-
clang-sys = { version = "0.28.0", features = ["runtime", "clang_6_0"] }
52+
clang-sys = { version = "0.28.0", features = ["clang_6_0"] }
5353
lazycell = "1"
5454
lazy_static = "1"
5555
peeking_take_while = "0.1.2"
@@ -71,9 +71,10 @@ optional = true
7171
version = "0.4"
7272

7373
[features]
74-
default = ["logging", "clap", "which-rustfmt"]
74+
default = ["logging", "clap", "runtime", "which-rustfmt"]
7575
logging = ["env_logger", "log"]
76-
static = []
76+
static = ["clang-sys/static"]
77+
runtime = ["clang-sys/runtime"]
7778
# Dynamically discover a `rustfmt` binary using the `which` crate
7879
which-rustfmt = ["which"]
7980

src/lib.rs

+10-6
Original file line numberDiff line numberDiff line change
@@ -96,7 +96,6 @@ use std::fs::{File, OpenOptions};
9696
use std::io::{self, Write};
9797
use std::path::{Path, PathBuf};
9898
use std::process::{Command, Stdio};
99-
use std::sync::Arc;
10099
use std::{env, iter};
101100

102101
// Some convenient typedefs for a fast hash map and hash set.
@@ -1720,6 +1719,7 @@ impl Default for BindgenOptions {
17201719
}
17211720
}
17221721

1722+
#[cfg(feature = "runtime")]
17231723
fn ensure_libclang_is_loaded() {
17241724
if clang_sys::is_loaded() {
17251725
return;
@@ -1730,7 +1730,7 @@ fn ensure_libclang_is_loaded() {
17301730
// across different threads.
17311731

17321732
lazy_static! {
1733-
static ref LIBCLANG: Arc<clang_sys::SharedLibrary> = {
1733+
static ref LIBCLANG: std::sync::Arc<clang_sys::SharedLibrary> = {
17341734
clang_sys::load().expect("Unable to find libclang");
17351735
clang_sys::get_library().expect(
17361736
"We just loaded libclang and it had better still be \
@@ -1742,6 +1742,10 @@ fn ensure_libclang_is_loaded() {
17421742
clang_sys::set_library(Some(LIBCLANG.clone()));
17431743
}
17441744

1745+
#[cfg(not(feature = "runtime"))]
1746+
fn ensure_libclang_is_loaded() {
1747+
}
1748+
17451749
/// Generated Rust bindings.
17461750
#[derive(Debug)]
17471751
pub struct Bindings {
@@ -1756,10 +1760,13 @@ impl Bindings {
17561760
) -> Result<Bindings, ()> {
17571761
ensure_libclang_is_loaded();
17581762

1763+
#[cfg(feature = "runtime")]
17591764
debug!(
17601765
"Generating bindings, libclang at {}",
17611766
clang_sys::get_library().unwrap().path().display()
17621767
);
1768+
#[cfg(not(feature = "runtime"))]
1769+
debug!("Generating bindings, libclang linked");
17631770

17641771
options.build();
17651772

@@ -2115,10 +2122,7 @@ pub struct ClangVersion {
21152122

21162123
/// Get the major and the minor semver numbers of Clang's version
21172124
pub fn clang_version() -> ClangVersion {
2118-
if !clang_sys::is_loaded() {
2119-
// TODO(emilio): Return meaningful error (breaking).
2120-
clang_sys::load().expect("Unable to find libclang");
2121-
}
2125+
ensure_libclang_is_loaded();
21222126

21232127
let raw_v: String = clang::extract_clang_version();
21242128
let split_v: Option<Vec<&str>> = raw_v

0 commit comments

Comments
 (0)