diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
commit | 2aa4a82499d4becd2284cdb482213d541b8804dd (patch) | |
tree | b80bf8bf13c3766139fbacc530efd0dd9d54394c /third_party/rust/coreaudio-sys | |
parent | Initial commit. (diff) | |
download | firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip |
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/rust/coreaudio-sys')
-rw-r--r-- | third_party/rust/coreaudio-sys/.cargo-checksum.json | 1 | ||||
-rw-r--r-- | third_party/rust/coreaudio-sys/Cargo.toml | 39 | ||||
-rw-r--r-- | third_party/rust/coreaudio-sys/LICENSE | 25 | ||||
-rw-r--r-- | third_party/rust/coreaudio-sys/README.md | 19 | ||||
-rw-r--r-- | third_party/rust/coreaudio-sys/build.rs | 142 | ||||
-rw-r--r-- | third_party/rust/coreaudio-sys/src/lib.rs | 6 |
6 files changed, 232 insertions, 0 deletions
diff --git a/third_party/rust/coreaudio-sys/.cargo-checksum.json b/third_party/rust/coreaudio-sys/.cargo-checksum.json new file mode 100644 index 0000000000..db64db3fb0 --- /dev/null +++ b/third_party/rust/coreaudio-sys/.cargo-checksum.json @@ -0,0 +1 @@ +{"files":{"Cargo.toml":"aa7a2eef3c054f7e85d333f9eaad07b360ab7548facd12c960003961964fe4f8","LICENSE":"7576269ea71f767b99297934c0b2367532690f8c4badc695edf8e04ab6a1e545","README.md":"a8adeaf1947035175b890109b36604ac3676f887911b5b8debd216689c0b65bd","build.rs":"92378306b530db031b825425870ace29acb9d4398ede04901b3c9407cab52c1b","src/lib.rs":"22c9dbbb1dc38d6f77b9362e806a7ee59a8ca1aa9b2c9344d1a487a91287ed59"},"package":"2b7e3347be6a09b46aba228d6608386739fb70beff4f61e07422da87b0bb31fa"}
\ No newline at end of file diff --git a/third_party/rust/coreaudio-sys/Cargo.toml b/third_party/rust/coreaudio-sys/Cargo.toml new file mode 100644 index 0000000000..1867a67fed --- /dev/null +++ b/third_party/rust/coreaudio-sys/Cargo.toml @@ -0,0 +1,39 @@ +# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO +# +# When uploading crates to the registry Cargo will automatically +# "normalize" Cargo.toml files for maximal compatibility +# with all versions of Cargo and also rewrite `path` dependencies +# to registry (e.g., crates.io) dependencies +# +# If you believe there's an error in this file please file an +# issue against the rust-lang/cargo repository. If you're +# editing this file be aware that the upstream Cargo.toml +# will likely look very different (and much more reasonable) + +[package] +name = "coreaudio-sys" +version = "0.2.8" +authors = ["Mitchell Nordine <mitchell.nordine@gmail.com>"] +build = "build.rs" +description = "Bindings for Apple's CoreAudio frameworks generated via rust-bindgen" +homepage = "https://github.com/RustAudio/coreaudio-sys" +readme = "README.md" +keywords = ["core", "audio", "unit", "osx", "ios"] +license = "MIT" +repository = "https://github.com/RustAudio/coreaudio-sys.git" +[package.metadata.docs.rs] +all-features = true +default-target = "x86_64-apple-darwin" +targets = ["x86_64-apple-darwin", "x86_64-apple-ios"] +[build-dependencies.bindgen] +version = "0.56" +features = ["runtime"] +default-features = false + +[features] +audio_toolbox = [] +audio_unit = [] +core_audio = [] +core_midi = [] +default = ["audio_toolbox", "audio_unit", "core_audio", "open_al", "core_midi"] +open_al = [] diff --git a/third_party/rust/coreaudio-sys/LICENSE b/third_party/rust/coreaudio-sys/LICENSE new file mode 100644 index 0000000000..9203baa055 --- /dev/null +++ b/third_party/rust/coreaudio-sys/LICENSE @@ -0,0 +1,25 @@ +Copyright (c) 2015 + +Permission is hereby granted, free of charge, to any +person obtaining a copy of this software and associated +documentation files (the "Software"), to deal in the +Software without restriction, including without +limitation the rights to use, copy, modify, merge, +publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software +is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice +shall be included in all copies or substantial portions +of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF +ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED +TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A +PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT +SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR +IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +DEALINGS IN THE SOFTWARE. diff --git a/third_party/rust/coreaudio-sys/README.md b/third_party/rust/coreaudio-sys/README.md new file mode 100644 index 0000000000..e6cacf3ac3 --- /dev/null +++ b/third_party/rust/coreaudio-sys/README.md @@ -0,0 +1,19 @@ +# coreaudio-sys [![Actions Status](https://github.com/rustaudio/coreaudio-sys/workflows/coreaudio-sys/badge.svg)](https://github.com/rustaudio/coreaudio-sys/actions) [![Crates.io](https://img.shields.io/crates/v/coreaudio-sys.svg)](https://crates.io/crates/coreaudio-sys) [![Crates.io](https://img.shields.io/crates/l/coreaudio-sys.svg)](https://github.com/RustAudio/coreaudio-sys/blob/master/LICENSE) [![docs.rs](https://docs.rs/coreaudio-sys/badge.svg)](https://docs.rs/coreaudio-sys/) + +Raw bindings to Apple's Core Audio API for macos and iOS generated using [rust-bindgen](https://github.com/rust-lang-nursery/rust-bindgen). [coreaudio-rs](https://github.com/RustAudio/coreaudio-rs) is an attempt at offering a higher level API around this crate. + +## Cross Compiling + +[Rust Cross](https://github.com/japaric/rust-cross) has a good explanation of how cross-compiling Rust works in general. While the author of Rust Cross advises against it, it is perfectly possible to cross-compile Rust for MacOS on Linux. [OSXCross](https://github.com/tpoechtrager/osxcross) can be used to create a compiler toolchain that can compile for MacOS on Linux. + +### Environment Variables + +When cross-compiling for MacOS on Linux there are two environment variables that are used to configure how `coreaudio-sys` finds the required headers and libraries. The following examples assume that you have OSXCross installed at `/build/osxcross`. + +#### `COREAUDIO_SDK_PATH` + +This tell `coreaudio-sys` where to find the MacOS SDK: + +```bash +export COREAUDIO_SDK_PATH=/build/osxcross/target/SDK/MacOSX10.11.sdk +``` diff --git a/third_party/rust/coreaudio-sys/build.rs b/third_party/rust/coreaudio-sys/build.rs new file mode 100644 index 0000000000..314d128abe --- /dev/null +++ b/third_party/rust/coreaudio-sys/build.rs @@ -0,0 +1,142 @@ +extern crate bindgen; + +fn sdk_path(target: &str) -> Result<String, std::io::Error> { + // Use environment variable if set + println!("cargo:rerun-if-env-changed=COREAUDIO_SDK_PATH"); + if let Ok(path) = std::env::var("COREAUDIO_SDK_PATH") { + return Ok(path); + } + + use std::process::Command; + + let sdk = if target.contains("apple-darwin") { + "macosx" + } else if target == "x86_64-apple-ios" || target == "i386-apple-ios" { + "iphonesimulator" + } else if target == "aarch64-apple-ios" + || target == "armv7-apple-ios" + || target == "armv7s-apple-ios" + { + "iphoneos" + } else { + unreachable!(); + }; + let output = Command::new("xcrun") + .args(&["--sdk", sdk, "--show-sdk-path"]) + .output()? + .stdout; + let prefix_str = std::str::from_utf8(&output).expect("invalid output from `xcrun`"); + Ok(prefix_str.trim_end().to_string()) +} + +fn build(sdk_path: Option<&str>, target: &str) { + // Generate one large set of bindings for all frameworks. + // + // We do this rather than generating a module per framework as some frameworks depend on other + // frameworks and in turn share types. To ensure all types are compatible across each + // framework, we feed all headers to bindgen at once. + // + // Only link to each framework and include their headers if their features are enabled and they + // are available on the target os. + + use std::env; + use std::path::PathBuf; + + let mut headers: Vec<&'static str> = vec![]; + + #[cfg(feature = "audio_toolbox")] + { + println!("cargo:rustc-link-lib=framework=AudioToolbox"); + headers.push("AudioToolbox/AudioToolbox.h"); + } + + #[cfg(feature = "audio_unit")] + { + println!("cargo:rustc-link-lib=framework=AudioToolbox"); + headers.push("AudioUnit/AudioUnit.h"); + } + + #[cfg(feature = "core_audio")] + { + println!("cargo:rustc-link-lib=framework=CoreAudio"); + + if target.contains("apple-ios") { + headers.push("CoreAudio/CoreAudioTypes.h"); + } else { + headers.push("CoreAudio/CoreAudio.h"); + } + } + + #[cfg(feature = "open_al")] + { + println!("cargo:rustc-link-lib=framework=OpenAL"); + headers.push("OpenAL/al.h"); + headers.push("OpenAL/alc.h"); + } + + #[cfg(all(feature = "core_midi"))] + { + if target.contains("apple-darwin") { + println!("cargo:rustc-link-lib=framework=CoreMIDI"); + headers.push("CoreMIDI/CoreMIDI.h"); + } + } + + println!("cargo:rerun-if-env-changed=BINDGEN_EXTRA_CLANG_ARGS"); + // Get the cargo out directory. + let out_dir = PathBuf::from(env::var("OUT_DIR").expect("env variable OUT_DIR not found")); + + // Begin building the bindgen params. + let mut builder = bindgen::Builder::default(); + + // See https://github.com/rust-lang/rust-bindgen/issues/1211 + // Technically according to the llvm mailing list, the argument to clang here should be + // -arch arm64 but it looks cleaner to just change the target. + let target = if target == "aarch64-apple-ios" { + "arm64-apple-ios" + } else if target == "aarch64-apple-darwin" { + "arm64-apple-darwin" + } else { + target + }; + builder = builder.size_t_is_usize(true); + + builder = builder.clang_args(&[&format!("--target={}", target)]); + + if let Some(sdk_path) = sdk_path { + builder = builder.clang_args(&["-isysroot", sdk_path]); + } + if target.contains("apple-ios") { + // time.h as has a variable called timezone that conflicts with some of the objective-c + // calls from NSCalendar.h in the Foundation framework. This removes that one variable. + builder = builder.blacklist_item("timezone"); + builder = builder.blacklist_item("objc_object"); + } + + let meta_header: Vec<_> = headers + .iter() + .map(|h| format!("#include <{}>\n", h)) + .collect(); + + builder = builder.header_contents("coreaudio.h", &meta_header.concat()); + + // Generate the bindings. + builder = builder.trust_clang_mangling(false).derive_default(true); + + let bindings = builder.generate().expect("unable to generate bindings"); + + // Write them to the crate root. + bindings + .write_to_file(out_dir.join("coreaudio.rs")) + .expect("could not write bindings"); +} + +fn main() { + let target = std::env::var("TARGET").unwrap(); + if !(target.contains("apple-darwin") || target.contains("apple-ios")) { + panic!("coreaudio-sys requires macos or ios target"); + } + + let directory = sdk_path(&target).ok(); + build(directory.as_ref().map(String::as_ref), &target); +} diff --git a/third_party/rust/coreaudio-sys/src/lib.rs b/third_party/rust/coreaudio-sys/src/lib.rs new file mode 100644 index 0000000000..c85c8e8eaf --- /dev/null +++ b/third_party/rust/coreaudio-sys/src/lib.rs @@ -0,0 +1,6 @@ +#![cfg(any(target_os = "macos", target_os = "ios"))] +#![allow(non_camel_case_types)] +#![allow(non_snake_case)] +#![allow(non_upper_case_globals)] + +include!(concat!(env!("OUT_DIR"), "/coreaudio.rs")); |