Skip to content

Commit

Permalink
Merge pull request #41 from Certora/cnandi/evmversion
Browse files Browse the repository at this point in the history
CERT-5925 support for evm-version
  • Loading branch information
chandrakananandi authored Apr 22, 2024
2 parents a97670e + 31af55f commit 6a6f72e
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 12 deletions.
16 changes: 11 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -161,8 +161,11 @@ Mutants can be used to evaluate test suites or specs used for formal

## Installation

You can download prebuilt Gambit binaries for Mac and Linux from our
[releases](https://github.com/Certora/gambit/releases) page.
You can download prebuilt Gambit binaries for Linux x86-64 and Mac from our
[releases](https://github.com/Certora/gambit/releases) page. For Windows and Linux ARM, you must build Gambit from source.

<!-- ANCHOR: (build-gambit-from-source)= -->
### Building Gambit from source

To build Gambit from source, clone [the Gambit repository](https://github.com/Certora/gambit) and run

Expand Down Expand Up @@ -317,6 +320,10 @@ For projects that have complex dependencies and imports, you may need to:
--solc_remappings @openzeppelin=node_modules/@openzeppelin @foo=node_modules/@foo
```

```{warning}
The paths should ***NOT*** end with a trailing /
```

* **Specify allow paths:** To include additional allowed paths via `solc`'s
[`--allow-paths`][allowed] argument, use `--solc_allow_paths`:

Expand Down Expand Up @@ -344,9 +351,7 @@ For projects that have complex dependencies and imports, you may need to:
[basepath]: https://docs.soliditylang.org/en/v0.8.17/path-resolution.html#base-path-and-include-paths
[allowed]: https://docs.soliditylang.org/en/v0.8.17/path-resolution.html#allowed-paths


<!-- ANCHOR: (gambit-config)= -->
### Example 5: The `--sourceroot` option
### Example 5: The `--sourceroot` option

Gambit needs to track the location of source files that it mutates within a
project: for instance, imagine there are files `foo/Foo.sol` and `bar/Foo.sol`.
Expand Down Expand Up @@ -423,6 +428,7 @@ Here are some examples of using the `--sourceroot` option.

Gambit prints an error and exits.

<!-- ANCHOR: (gambit-config)= -->
### Example 6: Running Gambit using a configuration file

To run gambit with a configuration file, use the `--json` argument:
Expand Down
4 changes: 4 additions & 0 deletions src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,10 @@ pub struct MutateParams {
#[serde(default = "default_solc_optimize")]
pub solc_optimize: bool,

/// Run solc with the `--evm-version` flag
#[arg(long)]
pub solc_evm_version: Option<String>,

/// Specify function names to mutate
#[arg(long, num_args(1..))]
pub functions: Option<Vec<String>>,
Expand Down
20 changes: 13 additions & 7 deletions src/compile.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ static INCLUDEPATH: &str = "--include-path";
static BASEPATH: &str = "--base-path";
static OPTIMIZE: &str = "--optimize";
static DOT_JSON: &str = ".json";
static EVM_VERSION: &str = "--evm-version";

/// Compilation configurations. This exists across compilations of individual
/// files
Expand All @@ -33,6 +34,7 @@ pub struct Solc {
include_path: Option<String>,
remappings: Option<Vec<String>>,
optimize: bool,
evm_version: Option<String>,
}

impl Solc {
Expand All @@ -45,20 +47,14 @@ impl Solc {
include_path: None,
remappings: None,
optimize: false,
evm_version: None,
}
}

pub fn output_directory(&self) -> &Path {
&self.output_directory
}

pub fn basepath(&self) -> Option<&String> {
match &self.basepath {
Some(bp) => Some(bp),
None => None,
}
}

pub fn with_basepath(&mut self, basepath: String) -> &Self {
self.basepath = Some(basepath);
self
Expand All @@ -83,6 +79,11 @@ impl Solc {
self.optimize = optimize;
self
}

pub fn with_evm_version(&mut self, evm_version: String) -> &Self {
self.evm_version = Some(evm_version);
self
}
}

impl Solc {
Expand Down Expand Up @@ -320,6 +321,11 @@ impl Solc {
flags.push(OPTIMIZE.into());
}

if let Some(evm_version) = &self.evm_version {
flags.push(EVM_VERSION.into());
flags.push(evm_version.clone());
}

flags
}
}
4 changes: 4 additions & 0 deletions src/mutator.rs
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,10 @@ impl From<&MutateParams> for Mutator {
.into(),
);
solc.with_optimize(value.solc_optimize);

if let Some(evm_version) = value.solc_evm_version.clone() {
solc.with_evm_version(evm_version);
}
if let Some(basepath) = value.solc_base_path.clone() {
solc.with_basepath(basepath);
}
Expand Down

0 comments on commit 6a6f72e

Please sign in to comment.