Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix errors from "make lint" #3078

Merged
merged 1 commit into from
Aug 5, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion lib/api/src/sys/store.rs
Original file line number Diff line number Diff line change
Expand Up @@ -242,7 +242,7 @@ impl<'a> StoreRef<'a> {
self.inner
.trap_handler
.as_ref()
.map(|handler| &*handler as *const _)
.map(|handler| handler as *const _)
}
}

Expand Down
2 changes: 1 addition & 1 deletion lib/cli/src/commands/compile.rs
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ impl Compile {
println!("Target: {}", target.triple());

let module = Module::from_file(&store, &self.path)?;
let _ = module.serialize_to_file(&self.output)?;
module.serialize_to_file(&self.output)?;
eprintln!(
"✔ File compiled successfully to `{}`.",
self.output.display(),
Expand Down
8 changes: 7 additions & 1 deletion lib/cli/src/commands/create_exe.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,12 @@ use structopt::StructOpt;
use wasmer::*;
use wasmer_object::{emit_serialized, get_object_for_target};

/// The `prefixer` returns the a String to prefix each of the
/// functions in the static object generated by the
/// so we can assure no collisions.
#[cfg(feature = "static-artifact-create")]
pub type PrefixerFn = Box<dyn Fn(&[u8]) -> String + Send>;

const WASMER_MAIN_C_SOURCE: &[u8] = include_bytes!("wasmer_create_exe_main.c");
#[cfg(feature = "static-artifact-create")]
const WASMER_STATIC_MAIN_C_SOURCE: &[u8] = include_bytes!("wasmer_static_create_exe_main.c");
Expand Down Expand Up @@ -135,7 +141,7 @@ impl CreateExe {
let features = engine_inner.features();
let tunables = store.tunables();
let data: Vec<u8> = fs::read(wasm_module_path)?;
let prefixer: Option<Box<dyn Fn(&[u8]) -> String + Send>> = None;
let prefixer: Option<PrefixerFn> = None;
let (module_info, obj, metadata_length, symbol_registry) =
Artifact::generate_object(
compiler, &data, prefixer, &target, tunables, features,
Expand Down
4 changes: 2 additions & 2 deletions lib/cli/src/commands/create_obj.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
//! Create a standalone native executable for a given Wasm file.

use super::ObjectFormat;
use crate::store::CompilerOptions;
use crate::{commands::PrefixerFn, store::CompilerOptions};
use anyhow::{Context, Result};
use std::env;
use std::fs;
Expand Down Expand Up @@ -114,7 +114,7 @@ impl CreateObj {
let features = engine_inner.features();
let tunables = store.tunables();
let data: Vec<u8> = fs::read(wasm_module_path)?;
let prefixer: Option<Box<dyn Fn(&[u8]) -> String + Send>> = None;
let prefixer: Option<PrefixerFn> = None;
let (module_info, obj, metadata_length, symbol_registry) =
Artifact::generate_object(
compiler, &data, prefixer, &target, tunables, features,
Expand Down
4 changes: 2 additions & 2 deletions lib/compiler-singlepass/src/emitter_arm64.rs
Original file line number Diff line number Diff line change
Expand Up @@ -663,7 +663,7 @@ impl EmitterARM64 for Assembler {
addr: GPR,
offset: i32,
) -> Result<(), CodegenError> {
assert!((offset >= -255) && (offset <= 255));
assert!((-255..=255).contains(&offset));
match (sz, reg) {
(Size::S64, Location::GPR(reg)) => {
let reg = reg.into_index() as u32;
Expand Down Expand Up @@ -702,7 +702,7 @@ impl EmitterARM64 for Assembler {
addr: GPR,
offset: i32,
) -> Result<(), CodegenError> {
assert!((offset >= -255) && (offset <= 255));
assert!((-255..=255).contains(&offset));
match (sz, reg) {
(Size::S64, Location::GPR(reg)) => {
let reg = reg.into_index() as u32;
Expand Down
5 changes: 4 additions & 1 deletion lib/compiler/src/engine/artifact.rs
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,9 @@ pub struct UniversalArtifact {
finished_function_lengths: BoxedSlice<LocalFunctionIndex, usize>,
}

#[cfg(feature = "static-artifact-create")]
pub type PrefixerFn = Box<dyn Fn(&[u8]) -> String + Send>;

/// Stores functions etc as symbols and data meant to be stored in object files and
/// executables.
#[cfg(feature = "static-artifact-create")]
Expand Down Expand Up @@ -541,7 +544,7 @@ impl Artifact {
pub fn generate_object<'data>(
compiler: &dyn Compiler,
data: &[u8],
prefixer: Option<Box<dyn Fn(&[u8]) -> String + Send>>,
prefixer: Option<PrefixerFn>,
target: &'data Target,
tunables: &dyn Tunables,
features: &Features,
Expand Down
2 changes: 1 addition & 1 deletion lib/compiler/src/translator/state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ impl ModuleTranslationState {
wasmparser::TypeOrFuncType::FuncType(ty_index) => {
let sig_idx = SignatureIndex::from_u32(ty_index);
let (ref params, ref results) = self.wasm_types[sig_idx];
(&*params, &*results)
(params, results)
}
})
}
Expand Down
2 changes: 1 addition & 1 deletion lib/emscripten/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -562,7 +562,7 @@ pub fn emscripten_call_main(
.get::<Function>(function_name)
.map_err(|e| RuntimeError::new(e.to_string()))?;
let num_params = main_func.ty(&env).params().len();
let _result = match num_params {
match num_params {
2 => {
let mut new_args = vec![path];
new_args.extend(args);
Expand Down
5 changes: 1 addition & 4 deletions lib/emscripten/src/varargs.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,7 @@ impl VarArgs {
// pub fn getStr<'a>(&mut self, ctx: &mut Ctx) -> &'a CStr {
pub fn get_str(&mut self, ctx: &FunctionEnvMut<EmEnv>) -> *const c_char {
let ptr_addr: u32 = self.get(ctx);
let ptr =
emscripten_memory_pointer!(ctx.data().memory_view(0, &ctx), ptr_addr) as *const c_char;
ptr
// unsafe { CStr::from_ptr(ptr) }
emscripten_memory_pointer!(ctx.data().memory_view(0, &ctx), ptr_addr) as *const c_char
}
}

Expand Down
2 changes: 1 addition & 1 deletion lib/middlewares/src/metering.rs
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,7 @@ pub struct FunctionMetering<F: Fn(&Operator) -> u64 + Send + Sync> {
/// # Example
///
/// See the [`get_remaining_points`] function to get an example.
#[derive(Debug, PartialEq)]
#[derive(Debug, Eq, PartialEq)]
pub enum MeteringPoints {
/// The given number of metering points is left for the execution.
/// If the value is 0, all points are consumed but the execution
Expand Down
2 changes: 1 addition & 1 deletion lib/vm/src/instance/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -773,7 +773,7 @@ impl Instance {
///
/// This is more or less a public facade of the private `Instance`,
/// providing useful higher-level API.
#[derive(Debug, Clone, PartialEq)]
#[derive(Debug, Clone, Eq, PartialEq)]
pub struct InstanceHandle {
/// The layout of `Instance` (which can vary).
instance_layout: Layout,
Expand Down
2 changes: 1 addition & 1 deletion lib/vm/src/memory.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ use thiserror::Error;
use wasmer_types::{Bytes, MemoryStyle, MemoryType, Pages};

/// Error type describing things that can go wrong when operating on Wasm Memories.
#[derive(Error, Debug, Clone, PartialEq, Hash)]
#[derive(Error, Debug, Clone, Eq, PartialEq, Hash)]
pub enum MemoryError {
/// Low level error with mmap.
#[error("Error when allocating memory: {0}")]
Expand Down
3 changes: 2 additions & 1 deletion lib/vm/src/sig_registry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,8 @@ impl SignatureRegistry {
pub fn register(&self, sig: &FunctionType) -> VMSharedSignatureIndex {
let mut inner = self.inner.write().unwrap();
let len = inner.signature2index.len();
match inner.signature2index.entry(sig.clone()) {
let entry = inner.signature2index.entry(sig.clone());
match entry {
hash_map::Entry::Occupied(entry) => *entry.get(),
hash_map::Entry::Vacant(entry) => {
// Keep `signature_hash` len under 2**32 -- VMSharedSignatureIndex::new(std::u32::MAX)
Expand Down
2 changes: 1 addition & 1 deletion lib/vm/src/vmcontext.rs
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,7 @@ mod test_vmdynamicfunction_import_context {
}

/// A function kind is a calling convention into and out of wasm code.
#[derive(Debug, Copy, Clone, PartialEq)]
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
#[repr(C)]
pub enum VMFunctionKind {
/// A static function has the native signature:
Expand Down
3 changes: 2 additions & 1 deletion lib/wasi/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,8 @@ impl WasiThread {
/// Waits for the thread to exit (false = timeout)
pub fn join(&self, timeout: Duration) -> bool {
let guard = self.join.lock().unwrap();
match guard.recv_timeout(timeout) {
let timeout = guard.recv_timeout(timeout);
match timeout {
Ok(_) => true,
Err(mpsc::RecvTimeoutError::Disconnected) => true,
Err(mpsc::RecvTimeoutError::Timeout) => false,
Expand Down
7 changes: 3 additions & 4 deletions lib/wasi/src/state/builder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,8 @@ fn validate_mapped_dir_alias(alias: &str) -> Result<(), WasiStateCreationError>
Ok(())
}

pub type SetupFsFn = Box<dyn Fn(&mut WasiInodes, &mut WasiFs) -> Result<(), String> + Send>;

// TODO add other WasiFS APIs here like swapping out stdout, for example (though we need to
// return stdout somehow, it's unclear what that API should look like)
impl WasiStateBuilder {
Expand Down Expand Up @@ -318,10 +320,7 @@ impl WasiStateBuilder {

/// Configure the WASI filesystem before running.
// TODO: improve ergonomics on this function
pub fn setup_fs(
&mut self,
setup_fs_fn: Box<dyn Fn(&mut WasiInodes, &mut WasiFs) -> Result<(), String> + Send>,
) -> &mut Self {
pub fn setup_fs(&mut self, setup_fs_fn: SetupFsFn) -> &mut Self {
self.setup_fs_fn = Some(setup_fs_fn);

self
Expand Down
48 changes: 32 additions & 16 deletions lib/wasi/src/state/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -654,7 +654,8 @@ impl WasiFs {
for c in path.components() {
let segment_name = c.as_os_str().to_string_lossy().to_string();
let guard = inodes.arena[cur_inode].read();
match guard.deref() {
let deref = guard.deref();
match deref {
Kind::Dir { ref entries, .. } | Kind::Root { ref entries } => {
if let Some(_entry) = entries.get(&segment_name) {
// TODO: this should be fixed
Expand All @@ -678,7 +679,8 @@ impl WasiFs {
// reborrow to insert
{
let mut guard = inodes.arena[cur_inode].write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::Dir {
ref mut entries, ..
}
Expand Down Expand Up @@ -725,7 +727,8 @@ impl WasiFs {
let base_inode = self.get_fd_inode(base).map_err(fs_error_from_wasi_err)?;

let guard = inodes.arena[base_inode].read();
match guard.deref() {
let deref = guard.deref();
match deref {
Kind::Dir { ref entries, .. } | Kind::Root { ref entries } => {
if let Some(_entry) = entries.get(&name) {
// TODO: eventually change the logic here to allow overwrites
Expand All @@ -745,7 +748,8 @@ impl WasiFs {

{
let mut guard = inodes.arena[base_inode].write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::Dir {
ref mut entries, ..
}
Expand Down Expand Up @@ -790,7 +794,8 @@ impl WasiFs {
_ => {
let base_inode = self.get_fd_inode(fd).map_err(fs_error_from_wasi_err)?;
let mut guard = inodes.arena[base_inode].write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::File { ref mut handle, .. } => {
std::mem::swap(handle, &mut ret);
}
Expand All @@ -810,7 +815,8 @@ impl WasiFs {
) -> Result<__wasi_filesize_t, __wasi_errno_t> {
let inode = self.get_fd_inode(fd)?;
let mut guard = inodes.arena[inode].write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::File { handle, .. } => {
if let Some(h) = handle {
let new_size = h.size();
Expand Down Expand Up @@ -899,7 +905,8 @@ impl WasiFs {
// loading inodes as necessary
'symlink_resolution: while symlink_count < MAX_SYMLINKS {
let mut guard = inodes.arena[cur_inode].write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::Buffer { .. } => unimplemented!("state::get_inode_at_path for buffers"),
Kind::Dir {
ref mut entries,
Expand Down Expand Up @@ -1165,10 +1172,12 @@ impl WasiFs {
let mut res = BaseFdAndRelPath::None;
// for each preopened directory
let preopen_fds = self.preopen_fds.read().unwrap();
for po_fd in preopen_fds.deref() {
let deref = preopen_fds.deref();
for po_fd in deref {
let po_inode = self.fd_map.read().unwrap()[po_fd].inode;
let guard = inodes.arena[po_inode].read();
let po_path = match guard.deref() {
let deref = guard.deref();
let po_path = match deref {
Kind::Dir { path, .. } => &**path,
Kind::Root { .. } => Path::new("/"),
_ => unreachable!("Preopened FD that's not a directory or the root"),
Expand Down Expand Up @@ -1210,7 +1219,8 @@ impl WasiFs {
while cur_inode != base_inode {
counter += 1;
let guard = inodes.arena[cur_inode].read();
match guard.deref() {
let deref = guard.deref();
match deref {
Kind::Dir { parent, .. } => {
if let Some(p) = parent {
cur_inode = *p;
Expand Down Expand Up @@ -1345,8 +1355,9 @@ impl WasiFs {
debug!("fdstat: {:?}", fd);

let guard = inodes.arena[fd.inode].read();
let deref = guard.deref();
Ok(__wasi_fdstat_t {
fs_filetype: match guard.deref() {
fs_filetype: match deref {
Kind::File { .. } => __WASI_FILETYPE_REGULAR_FILE,
Kind::Dir { .. } => __WASI_FILETYPE_DIRECTORY,
Kind::Symlink { .. } => __WASI_FILETYPE_SYMBOLIC_LINK,
Expand Down Expand Up @@ -1408,7 +1419,8 @@ impl WasiFs {
}

let mut guard = inodes.arena[fd.inode].write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::File {
handle: Some(file), ..
} => file.flush().map_err(|_| __WASI_EIO)?,
Expand Down Expand Up @@ -1643,7 +1655,8 @@ impl WasiFs {
let base_po_inode = &self.fd_map.read().unwrap()[base_po_dir].inode;
let base_po_inode_v = &inodes.arena[*base_po_inode];
let guard = base_po_inode_v.read();
match guard.deref() {
let deref = guard.deref();
match deref {
Kind::Root { .. } => {
self.fs_backing.symlink_metadata(path_to_symlink).map_err(fs_error_into_wasi_err)?
}
Expand Down Expand Up @@ -1685,7 +1698,8 @@ impl WasiFs {
let is_preopened = inodeval.is_preopened;

let mut guard = inodeval.write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::File { ref mut handle, .. } => {
let mut empty_handle = None;
std::mem::swap(handle, &mut empty_handle);
Expand All @@ -1707,14 +1721,16 @@ impl WasiFs {
if let Some(p) = *parent {
drop(guard);
let mut guard = inodes.arena[p].write();
match guard.deref_mut() {
let deref_mut = guard.deref_mut();
match deref_mut {
Kind::Dir { entries, .. } | Kind::Root { entries } => {
self.fd_map.write().unwrap().remove(&fd).unwrap();
if is_preopened {
let mut idx = None;
{
let preopen_fds = self.preopen_fds.read().unwrap();
for (i, po_fd) in preopen_fds.iter().enumerate() {
let preopen_fds_iter = preopen_fds.iter().enumerate();
for (i, po_fd) in preopen_fds_iter {
if *po_fd == fd {
idx = Some(i);
break;
Expand Down
3 changes: 2 additions & 1 deletion lib/wasi/src/state/types.rs
Original file line number Diff line number Diff line change
Expand Up @@ -392,7 +392,8 @@ impl Read for Pipe {
fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
let mut buffer = self.buffer.lock().unwrap();
let amt = std::cmp::min(buf.len(), buffer.len());
for (i, byte) in buffer.drain(..amt).enumerate() {
let buf_iter = buffer.drain(..amt).enumerate();
for (i, byte) in buf_iter {
buf[i] = byte;
}
Ok(amt)
Expand Down
Loading