From 042ed7c1d141f9da0ce54eb680bc42dc706371b2 Mon Sep 17 00:00:00 2001 From: Robert Remen Date: Fri, 25 Oct 2024 07:49:25 -0300 Subject: [PATCH] fix: remove the need for the `regex` crate's `pattern` feature (#51) The `std::str::pattern::Pattern` trait implementation in the `regex` crate recently broke compilation with the nightly rust toolchain. The removal of the trait implementation and the corresponding `pattern` feature is being [planned](https://github.com/rust-lang/regex/issues/1233). This PR removes the reliance on this trait implementation. --- crates/zkevm_test_harness/Cargo.toml | 2 +- .../src/tests/utils/preprocess_asm.rs | 12 ++++++------ 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/crates/zkevm_test_harness/Cargo.toml b/crates/zkevm_test_harness/Cargo.toml index 64835e5..f8f1dd3 100644 --- a/crates/zkevm_test_harness/Cargo.toml +++ b/crates/zkevm_test_harness/Cargo.toml @@ -44,7 +44,7 @@ env_logger = "0.9" smallvec = "1.13" structopt = "0.3.26" codegen = "0.2.0" -regex = { version = "1.10.6", features = ["pattern"] } +regex = "1.11.1" [dev-dependencies] rand = "0.4" diff --git a/crates/zkevm_test_harness/src/tests/utils/preprocess_asm.rs b/crates/zkevm_test_harness/src/tests/utils/preprocess_asm.rs index 958ef3e..8bb2a15 100644 --- a/crates/zkevm_test_harness/src/tests/utils/preprocess_asm.rs +++ b/crates/zkevm_test_harness/src/tests/utils/preprocess_asm.rs @@ -74,7 +74,7 @@ fn replace_tags_in_template( let mut result = asm_template.clone(); let template_regex = Regex::new(r#"\$\{[^\}]+\}"#).expect("Invalid regex"); - for (_, matched) in asm_template.match_indices(&template_regex) { + for matched in template_regex.find_iter(&asm_template).map(|m| m.as_str()) { let prefix = "${"; let suffix = "}"; let key_to_replace = matched @@ -111,7 +111,7 @@ fn link_additional_contracts( // regex: let contract_regex = Regex::new(r#"<\d+\.asm>"#).expect("Invalid regex"); - for (_, matched) in asm.match_indices(&contract_regex) { + for matched in contract_regex.find_iter(asm).map(|m| m.as_str()) { let prefix = "<"; let suffix = ".asm>"; let contract_address = Address::from_low_u64_be( @@ -214,7 +214,7 @@ fn replace_directives(asm: String, directive: Directive) -> (String, Vec }; let mut args_for_commands: Vec = Vec::new(); - for (index, matched) in asm.match_indices(®ex) { + for (index, matched) in regex.find_iter(&asm).map(|m| (m.start(), m.as_str())) { // skip if directive commented out if asm[..index] .chars() @@ -330,9 +330,9 @@ fn parse_args<'a>(text: &'a str, prefix: &str, suffix: &str) -> Vec<&'a str> { .expect("Invalid text in directive") .trim(); - trimmed_content - .matches(&args_regex) - .map(|x| x.trim_matches(',').trim().trim_matches('"')) + args_regex + .find_iter(trimmed_content) + .map(|x| x.as_str().trim_matches(',').trim().trim_matches('"')) .collect() }