2020-06-04 12:46:12 +03:00
|
|
|
/*
|
|
|
|
* Copyright 2020 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
use super::custom::WIT_SECTION_NAME;
|
|
|
|
use super::errors::WITParserError;
|
|
|
|
|
2020-06-04 14:44:36 +03:00
|
|
|
use walrus::{IdsToIndices, ModuleConfig};
|
2020-06-04 12:46:12 +03:00
|
|
|
use wasmer_wit::ast::Interfaces;
|
2020-06-04 19:06:23 +03:00
|
|
|
use wasmer_core::Module as WasmerModule;
|
2020-06-04 12:46:12 +03:00
|
|
|
|
|
|
|
use std::path::PathBuf;
|
|
|
|
|
2020-06-04 19:06:23 +03:00
|
|
|
/// Extracts WIT section of provided Wasm binary and converts it to a string.
|
2020-06-04 12:46:12 +03:00
|
|
|
pub fn extract_text_wit(wasm_file_path: PathBuf) -> Result<String, WITParserError> {
|
2020-06-04 19:06:23 +03:00
|
|
|
let wit_section_bytes = extract_wit_section_bytes(wasm_file_path)?;
|
2020-06-06 01:03:49 +03:00
|
|
|
let wit = extract_wit_with_fn(&wit_section_bytes)?;
|
|
|
|
Ok((&wit).to_string())
|
2020-06-04 12:46:12 +03:00
|
|
|
}
|
|
|
|
|
2020-06-04 19:06:23 +03:00
|
|
|
/// Extracts WIT section of provided Wasm binary and converts it to a FCEWITInterfaces.
|
2020-06-06 01:03:49 +03:00
|
|
|
pub fn extract_wit(wasmer_module: &WasmerModule) -> Result<Interfaces<'_>, WITParserError> {
|
2020-06-04 19:06:23 +03:00
|
|
|
let wit_sections = wasmer_module
|
|
|
|
.custom_sections(WIT_SECTION_NAME)
|
2020-10-21 22:21:16 +03:00
|
|
|
.ok_or(WITParserError::NoWITSection)?;
|
2020-06-04 19:06:23 +03:00
|
|
|
|
|
|
|
if wit_sections.len() > 1 {
|
|
|
|
return Err(WITParserError::MultipleWITSections);
|
|
|
|
}
|
|
|
|
|
2020-06-06 01:03:49 +03:00
|
|
|
extract_wit_with_fn(&wit_sections[0])
|
2020-06-04 12:46:12 +03:00
|
|
|
}
|
|
|
|
|
2020-06-06 01:03:49 +03:00
|
|
|
fn extract_wit_with_fn(wit_section_bytes: &[u8]) -> Result<Interfaces<'_>, WITParserError> {
|
|
|
|
match wasmer_wit::decoders::binary::parse::<()>(&wit_section_bytes) {
|
|
|
|
Ok((remainder, wit)) if remainder.is_empty() => Ok(wit),
|
|
|
|
Ok(_) => Err(WITParserError::WITRemainderNotEmpty),
|
|
|
|
Err(_) => Err(WITParserError::CorruptedWITSection),
|
|
|
|
}
|
2020-06-04 12:46:12 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
fn extract_wit_section_bytes(wasm_file_path: PathBuf) -> Result<Vec<u8>, WITParserError> {
|
|
|
|
let module = ModuleConfig::new()
|
|
|
|
.parse_file(wasm_file_path)
|
|
|
|
.map_err(WITParserError::CorruptedWasmFile)?;
|
|
|
|
|
|
|
|
let sections = module
|
|
|
|
.customs
|
|
|
|
.iter()
|
|
|
|
.filter(|(_, section)| section.name() == WIT_SECTION_NAME)
|
|
|
|
.collect::<Vec<_>>();
|
|
|
|
|
|
|
|
if sections.is_empty() {
|
|
|
|
return Err(WITParserError::NoWITSection);
|
|
|
|
}
|
|
|
|
if sections.len() > 1 {
|
|
|
|
return Err(WITParserError::MultipleWITSections);
|
|
|
|
}
|
|
|
|
|
|
|
|
let default_ids = IdsToIndices::default();
|
|
|
|
Ok(sections[0].1.data(&default_ids).into_owned())
|
|
|
|
}
|