#[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(all(feature = "hlsl", not(target_arch = "wasm32")))] pub mod hlsl; #[cfg(all(feature = "msl", not(target_arch = "wasm32")))] 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), } impl std::fmt::Display for ErrorCode { fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result { write!(f, "{:?}", self) } } impl std::error::Error for ErrorCode {}