summaryrefslogtreecommitdiffstats
path: root/third_party/rust/coreaudio-sys
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /third_party/rust/coreaudio-sys
parentInitial commit. (diff)
downloadfirefox-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.json1
-rw-r--r--third_party/rust/coreaudio-sys/Cargo.toml39
-rw-r--r--third_party/rust/coreaudio-sys/LICENSE25
-rw-r--r--third_party/rust/coreaudio-sys/README.md19
-rw-r--r--third_party/rust/coreaudio-sys/build.rs142
-rw-r--r--third_party/rust/coreaudio-sys/src/lib.rs6
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"));