mirror of
https://github.com/fluencelabs/marine-rs-sdk
synced 2025-03-14 14:00:49 +00:00
73 lines
2.1 KiB
Rust
73 lines
2.1 KiB
Rust
/*
|
|
* Copyright 2018 Fluence Labs Limited
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
//! The main part of Fluence backend SDK. Contains `export_allocator`, `logger` and `result`
|
|
//! modules.
|
|
|
|
#![allow(clippy::missing_safety_doc)]
|
|
#![allow(clippy::needless_doctest_main)]
|
|
#![doc(html_root_url = "https://docs.rs/fluence-sdk-main/0.6.8")]
|
|
#![deny(
|
|
dead_code,
|
|
nonstandard_style,
|
|
unused_imports,
|
|
unused_mut,
|
|
unused_variables,
|
|
unused_unsafe,
|
|
unreachable_patterns
|
|
)]
|
|
#![warn(rust_2018_idioms)]
|
|
|
|
mod export_allocator;
|
|
#[cfg(any(feature = "debug", feature = "logger"))]
|
|
mod logger;
|
|
mod module_manifest;
|
|
mod result;
|
|
mod sdk_version_embedder;
|
|
|
|
pub use export_allocator::allocate;
|
|
|
|
#[cfg(feature = "logger")]
|
|
pub use logger::WasmLoggerBuilder;
|
|
#[cfg(feature = "logger")]
|
|
pub use logger::TargetMap;
|
|
#[cfg(feature = "logger")]
|
|
pub use logger::WASM_LOG_ENV_NAME;
|
|
|
|
pub use result::get_result_ptr;
|
|
pub use result::get_result_size;
|
|
pub use result::set_result_ptr;
|
|
pub use result::set_result_size;
|
|
pub use result::release_objects;
|
|
pub use result::add_object_to_release;
|
|
|
|
pub use module_manifest::MANIFEST_SECTION_NAME;
|
|
pub use sdk_version_embedder::VERSION_SECTION_NAME;
|
|
|
|
// these logs will be printed only if debug feature is enabled
|
|
#[macro_export]
|
|
macro_rules! debug_log {
|
|
($msg_generator:expr) => {
|
|
#[cfg(feature = "debug")]
|
|
{
|
|
let level = log::Level::Info as i32;
|
|
let target = 0i32;
|
|
let msg = $msg_generator;
|
|
crate::logger::log_utf8_string(level, target, msg.as_ptr() as i32, msg.len() as i32);
|
|
}
|
|
};
|
|
}
|