diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /third_party/rust/clang-sys/build.rs | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/rust/clang-sys/build.rs')
-rw-r--r-- | third_party/rust/clang-sys/build.rs | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/third_party/rust/clang-sys/build.rs b/third_party/rust/clang-sys/build.rs new file mode 100644 index 0000000000..2eed15cea9 --- /dev/null +++ b/third_party/rust/clang-sys/build.rs @@ -0,0 +1,79 @@ +// SPDX-License-Identifier: Apache-2.0
+
+//! Finds `libclang` static or shared libraries and links to them.
+//!
+//! # Environment Variables
+//!
+//! This build script can make use of several environment variables to help it
+//! find the required static or shared libraries.
+//!
+//! * `LLVM_CONFIG_PATH` - provides a path to an `llvm-config` executable
+//! * `LIBCLANG_PATH` - provides a path to a directory containing a `libclang`
+//! shared library or a path to a specific `libclang` shared library
+//! * `LIBCLANG_STATIC_PATH` - provides a path to a directory containing LLVM
+//! and Clang static libraries
+
+#![allow(unused_attributes)]
+
+extern crate glob;
+
+use std::path::Path;
+
+#[macro_use]
+#[path = "build/macros.rs"]
+pub mod macros;
+
+#[path = "build/common.rs"]
+pub mod common;
+#[path = "build/dynamic.rs"]
+pub mod dynamic;
+#[path = "build/static.rs"]
+pub mod r#static;
+
+/// Copies a file.
+#[cfg(feature = "runtime")]
+fn copy(source: &str, destination: &Path) {
+ use std::fs::File;
+ use std::io::{Read, Write};
+
+ let mut string = String::new();
+ File::open(source)
+ .unwrap()
+ .read_to_string(&mut string)
+ .unwrap();
+ File::create(destination)
+ .unwrap()
+ .write_all(string.as_bytes())
+ .unwrap();
+}
+
+/// Copies the code used to find and link to `libclang` shared libraries into
+/// the build output directory so that it may be used when linking at runtime.
+#[cfg(feature = "runtime")]
+fn main() {
+ use std::env;
+
+ if cfg!(feature = "static") {
+ panic!("`runtime` and `static` features can't be combined");
+ }
+
+ let out = env::var("OUT_DIR").unwrap();
+ copy("build/macros.rs", &Path::new(&out).join("macros.rs"));
+ copy("build/common.rs", &Path::new(&out).join("common.rs"));
+ copy("build/dynamic.rs", &Path::new(&out).join("dynamic.rs"));
+}
+
+/// Finds and links to the required libraries dynamically or statically.
+#[cfg(not(feature = "runtime"))]
+fn main() {
+ if cfg!(feature = "static") {
+ r#static::link();
+ } else {
+ dynamic::link();
+ }
+
+ if let Some(output) = common::run_llvm_config(&["--includedir"]) {
+ let directory = Path::new(output.trim_end());
+ println!("cargo:include={}", directory.display());
+ }
+}
|