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 78 79 80 81 82 83 84 85 86 87
#[cfg(target_arch = "wasm32")] macro_rules! check { ($check:expr) => {{ $check }}; } #[cfg(not(target_arch = "wasm32"))] macro_rules! check { ($check:expr) => {{ let result = $check; if br::ScInternalResult::Success != result { if br::ScInternalResult::CompilationError == result { let mut message_ptr = ptr::null(); if br::ScInternalResult::Success != br::sc_internal_get_latest_exception_message(&mut message_ptr) { return Err(ErrorCode::Unhandled); } let message = match std::ffi::CStr::from_ptr(message_ptr) .to_owned() .into_string() { Err(_) => return Err(ErrorCode::Unhandled), Ok(v) => v, }; if br::ScInternalResult::Success != br::sc_internal_free_pointer(message_ptr as *mut std::os::raw::c_void) { return Err(ErrorCode::Unhandled); } return Err(ErrorCode::CompilationError(message)); } return Err(ErrorCode::Unhandled); } }}; } mod compiler; #[cfg(feature = "glsl")] pub mod glsl; #[cfg(feature = "hlsl")] pub mod hlsl; #[cfg(feature = "msl")] pub mod msl; pub mod spirv; #[cfg(target_arch = "wasm32")] pub(crate) mod emscripten; pub(crate) mod ptr_util; #[cfg(target_arch = "wasm32")] mod bindings_wasm_functions; #[cfg(target_arch = "wasm32")] mod bindings { #![allow(dead_code)] #![allow(non_upper_case_globals)] #![allow(non_camel_case_types)] #![allow(non_snake_case)] include!(concat!("bindings_wasm.rs")); pub use crate::bindings_wasm_functions::*; pub use root::*; } #[cfg(not(target_arch = "wasm32"))] mod bindings { #![allow(dead_code)] #![allow(non_upper_case_globals)] #![allow(non_camel_case_types)] #![allow(non_snake_case)] include!(concat!("bindings_native.rs")); pub use root::*; } #[derive(Clone, Debug, Hash, Eq, PartialEq)] pub enum ErrorCode { Unhandled, CompilationError(String), }