Skip to content

Commit

Permalink
Merge pull request #38 from aurora-is-near/feat/fix-clippy
Browse files Browse the repository at this point in the history
Feat: update Rust and fix clippy
  • Loading branch information
mrLSD authored Mar 29, 2024
2 parents 2521c50 + 954ce7f commit 20ce89e
Show file tree
Hide file tree
Showing 22 changed files with 93 additions and 50 deletions.
36 changes: 19 additions & 17 deletions .github/workflows/rust.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,26 +12,28 @@ jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Rustfmt
run: cargo fmt --all -- --check
- name: Clippy
run: cargo clippy --workspace --all-targets -- -D clippy::all -D clippy::nursery
- uses: actions/checkout@v4
- name: Rustfmt
run: cargo fmt --all -- --check
- name: Clippy
run: cargo clippy --all-targets -- -D clippy::all -D clippy::nursery
- name: Clippy no_std
run: cargo clippy --all-targets --no-default-features -- -D clippy::all -D clippy::nursery
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Build
run: cargo build --verbose
- name: Build NoStd
run: cargo build --no-default-features --verbose
- name: Build for feature (tracing)
run: cargo build --features tracing --verbose
- uses: actions/checkout@v4
- name: Build
run: cargo build --verbose
- name: Build NoStd
run: cargo build --no-default-features --verbose
- name: Build for feature (tracing)
run: cargo build --features tracing --verbose
tests:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- name: Run tests
run: cargo test --all --verbose
- uses: actions/checkout@v4
with:
submodules: recursive
- name: Run tests
run: cargo test --all --verbose
2 changes: 1 addition & 1 deletion core/src/error.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::prelude::*;
use crate::Opcode;
use alloc::borrow::Cow;

/// Trap which indicates that an `ExternalOpcode` has to be handled.
pub type Trap = Opcode;
Expand Down
15 changes: 12 additions & 3 deletions core/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,18 @@
#![forbid(unsafe_code, unused_variables, unused_imports)]
#![cfg_attr(not(feature = "std"), no_std)]

#[cfg(not(feature = "std"))]
extern crate alloc;

#[cfg(not(feature = "std"))]
pub mod prelude {
pub use alloc::{borrow::Cow, rc::Rc, vec, vec::Vec};
}
#[cfg(feature = "std")]
pub mod prelude {
pub use std::{borrow::Cow, rc::Rc, vec::Vec};
}

mod error;
mod eval;
mod external;
Expand All @@ -23,8 +33,7 @@ pub use crate::stack::Stack;
pub use crate::valids::Valids;

use crate::eval::{eval, Control};
use alloc::rc::Rc;
use alloc::vec::Vec;
use crate::prelude::*;
use core::ops::Range;
use primitive_types::{H160, U256};

Expand Down Expand Up @@ -127,7 +136,7 @@ impl Machine {
#[must_use]
pub fn return_value(&self) -> Vec<u8> {
if self.return_range.start > U256::from(usize::MAX) {
alloc::vec![0; (self.return_range.end - self.return_range.start).as_usize()]
vec![0; (self.return_range.end - self.return_range.start).as_usize()]
} else if self.return_range.end > U256::from(usize::MAX) {
let mut ret = self.memory.get(
self.return_range.start.as_usize(),
Expand Down
2 changes: 1 addition & 1 deletion core/src/memory.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::prelude::*;
use crate::{ExitError, ExitFatal};
use alloc::vec::Vec;
use core::cmp::min;
use core::ops::{BitAnd, Not};
use primitive_types::{H256, U256};
Expand Down
2 changes: 1 addition & 1 deletion core/src/stack.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::prelude::*;
use crate::ExitError;
use alloc::vec::Vec;
use primitive_types::{H256, U256};

/// EVM stack.
Expand Down
2 changes: 1 addition & 1 deletion core/src/valids.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::prelude::*;
use crate::Opcode;
use alloc::vec::Vec;

/// Mapping of valid jump destination from code.
#[derive(Clone, Debug, Eq, PartialEq)]
Expand Down
1 change: 0 additions & 1 deletion evm-tests/ethjson/src/spec/authority_round.rs
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,6 @@ mod tests {
use std::str::FromStr;

use ethereum_types::{H160, U256};
use serde_json;

use super::{Address, StepDuration, Uint};
use crate::spec::{authority_round::AuthorityRound, validator_set::ValidatorSet};
Expand Down
1 change: 0 additions & 1 deletion evm-tests/ethjson/src/test_helpers/state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,6 @@ pub struct PostStateResult {
#[cfg(test)]
mod tests {
use super::{MultiTransaction, State};
use serde_json;

#[test]
fn multi_transaction_deserialization() {
Expand Down
12 changes: 11 additions & 1 deletion gasometer/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,18 @@
#![forbid(unsafe_code, unused_variables)]
#![cfg_attr(not(feature = "std"), no_std)]

#[cfg(not(feature = "std"))]
extern crate alloc;

#[cfg(not(feature = "std"))]
pub mod prelude {
pub use alloc::vec::Vec;
}
#[cfg(feature = "std")]
pub mod prelude {
pub use std::vec::Vec;
}

#[cfg(feature = "tracing")]
pub mod tracing;

Expand Down Expand Up @@ -37,7 +47,7 @@ mod costs;
mod memory;
mod utils;

use alloc::vec::Vec;
use crate::prelude::*;
use core::cmp::max;
use evm_core::{ExitError, Opcode, Stack};
use evm_runtime::{Config, Handler};
Expand Down
2 changes: 1 addition & 1 deletion gasometer/src/utils.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
use primitive_types::U256;

pub fn log2floor(value: U256) -> u64 {
assert!(value != U256::zero());
assert_ne!(value, U256::zero());
let mut l: u64 = 256;
for i in 0..4 {
let i = 3 - i;
Expand Down
2 changes: 1 addition & 1 deletion runtime/src/eval/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
mod macros;
mod system;

use crate::prelude::*;
use crate::{CallScheme, ExitReason, Handler, Opcode, Runtime};
use alloc::vec::Vec;
use core::cmp::min;
use primitive_types::{H160, H256, U256};

Expand Down
2 changes: 1 addition & 1 deletion runtime/src/eval/system.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
use super::Control;
use crate::prelude::*;
use crate::{
CallScheme, Capture, Context, CreateScheme, ExitError, ExitSucceed, Handler, Runtime, Transfer,
};
use alloc::vec::Vec;
use primitive_types::{H256, U256};
use sha3::{Digest, Keccak256};

Expand Down
2 changes: 1 addition & 1 deletion runtime/src/handler.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::prelude::*;
use crate::{Capture, Context, CreateScheme, ExitError, ExitReason, Machine, Opcode};
use alloc::vec::Vec;
use primitive_types::{H160, H256, U256};

/// Transfer from source to target, with given value.
Expand Down
13 changes: 11 additions & 2 deletions runtime/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,18 @@
#![forbid(unsafe_code, unused_variables)]
#![cfg_attr(not(feature = "std"), no_std)]

#[cfg(not(feature = "std"))]
extern crate alloc;

#[cfg(not(feature = "std"))]
pub mod prelude {
pub use alloc::{rc::Rc, vec::Vec};
}
#[cfg(feature = "std")]
pub mod prelude {
pub use std::{rc::Rc, vec::Vec};
}

#[cfg(feature = "tracing")]
pub mod tracing;

Expand Down Expand Up @@ -33,8 +43,7 @@ pub use crate::context::{CallScheme, Context, CreateScheme};
pub use crate::handler::{Handler, Transfer};
pub use crate::interrupt::{Resolve, ResolveCall, ResolveCreate};

use alloc::rc::Rc;
use alloc::vec::Vec;
use prelude::*;
use primitive_types::H160;

macro_rules! step {
Expand Down
2 changes: 1 addition & 1 deletion rust-toolchain.toml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
[toolchain]
channel = "1.72.1"
channel = "1.77.0"
profile = "minimal"
components = [ "rustfmt", "clippy" ]
3 changes: 1 addition & 2 deletions src/backend/memory.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
use super::{Apply, ApplyBackend, Backend, Basic, Log};
use alloc::collections::BTreeMap;
use alloc::vec::Vec;
use crate::prelude::*;
use primitive_types::{H160, H256, U256};

/// Vicinity value of a memory backend.
Expand Down
7 changes: 4 additions & 3 deletions src/backend/mod.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
//! # EVM backends
//!
//! Backends store state information of the VM, and exposes it to runtime.
use crate::prelude::*;
use primitive_types::{H160, H256, U256};

pub use self::memory::{MemoryAccount, MemoryBackend, MemoryVicinity};

mod memory;

pub use self::memory::{MemoryAccount, MemoryBackend, MemoryVicinity};
use alloc::vec::Vec;
use primitive_types::{H160, H256, U256};
/// Basic account information.
#[derive(Clone, Eq, PartialEq, Debug, Default)]
#[cfg_attr(
Expand Down
2 changes: 1 addition & 1 deletion src/executor/stack/executor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,11 @@ use crate::executor::stack::precompile::{
use crate::executor::stack::tagged_runtime::{RuntimeKind, TaggedRuntime};
use crate::gasometer::{self, Gasometer, StorageTarget};
use crate::maybe_borrowed::MaybeBorrowed;
use crate::prelude::*;
use crate::{
Capture, Config, Context, CreateScheme, ExitError, ExitReason, Handler, Opcode, Runtime,
Transfer,
};
use alloc::{collections::BTreeSet, rc::Rc, vec::Vec};
use core::{cmp::min, convert::Infallible};
use evm_core::{ExitFatal, InterpreterHandler, Machine, Trap};
use evm_runtime::Resolve;
Expand Down
10 changes: 3 additions & 7 deletions src/executor/stack/memory.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,7 @@
use crate::backend::{Apply, Backend, Basic, Log};
use crate::executor::stack::executor::{Accessed, StackState, StackSubstateMetadata};
use crate::prelude::*;
use crate::{ExitError, Transfer};
use alloc::{
boxed::Box,
collections::{BTreeMap, BTreeSet},
vec::Vec,
};
use core::mem;
use primitive_types::{H160, H256, U256};

Expand All @@ -30,7 +26,7 @@ impl<'config> MemoryStackSubstate<'config> {
pub const fn new(metadata: StackSubstateMetadata<'config>) -> Self {
Self {
metadata,
parent: None,
parent: None::<Box<_>>,
logs: Vec::new(),
accounts: BTreeMap::new(),
storages: BTreeMap::new(),
Expand Down Expand Up @@ -291,7 +287,7 @@ impl<'config> MemoryStackSubstate<'config> {
})
.unwrap_or_else(|| MemoryStackAccount {
basic: backend.basic(address),
code: None,
code: None::<Vec<_>>,
reset: false,
});
self.accounts.insert(address, account);
Expand Down
4 changes: 2 additions & 2 deletions src/executor/stack/mod.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
//! A stack-based executor with customizable state.
//! A memory-based state is provided, but can replaced by a custom
//! implementation, for exemple one interacting with a database.
//! A memory-based state is provided, but can be replaced by a custom
//! implementation, for example one interacting with a database.
mod executor;
mod memory;
Expand Down
2 changes: 1 addition & 1 deletion src/executor/stack/precompile.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::prelude::*;
use crate::{Context, ExitError, ExitFatal, ExitReason, ExitRevert, ExitSucceed, Transfer};
use alloc::{collections::BTreeMap, vec::Vec};
use primitive_types::{H160, H256};

/// A precompile result.
Expand Down
19 changes: 19 additions & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,27 @@
#![forbid(unsafe_code, unused_variables)]
#![cfg_attr(not(feature = "std"), no_std)]

#[cfg(not(feature = "std"))]
extern crate alloc;

#[cfg(not(feature = "std"))]
pub mod prelude {
pub use alloc::{
boxed::Box,
collections::{BTreeMap, BTreeSet},
rc::Rc,
vec::Vec,
};
}
#[cfg(feature = "std")]
pub mod prelude {
pub use std::{
collections::{BTreeMap, BTreeSet},
rc::Rc,
vec::Vec,
};
}

pub use evm_core::*;
pub use evm_gasometer as gasometer;
pub use evm_runtime::*;
Expand Down

0 comments on commit 20ce89e

Please sign in to comment.