From 4d3483ca7f8a0656ef8a804f2161c6390cf2ea69 Mon Sep 17 00:00:00 2001 From: Remo Senekowitsch Date: Sun, 25 Aug 2024 19:24:47 +0200 Subject: [PATCH] Remove lazy_static (#1990) This crate is not needed anymore since all its functionality has been merged into the standard library over time. --- .../practice/pig-latin/.meta/Cargo-example.toml | 1 - exercises/practice/pig-latin/.meta/example.rs | 17 ++++++++--------- .../robot-name/.meta/Cargo-example.toml | 1 - exercises/practice/robot-name/.meta/example.rs | 12 ++++++------ 4 files changed, 14 insertions(+), 17 deletions(-) diff --git a/exercises/practice/pig-latin/.meta/Cargo-example.toml b/exercises/practice/pig-latin/.meta/Cargo-example.toml index 0d0b60aa4..42bcba31f 100644 --- a/exercises/practice/pig-latin/.meta/Cargo-example.toml +++ b/exercises/practice/pig-latin/.meta/Cargo-example.toml @@ -5,4 +5,3 @@ version = "1.0.0" [dependencies] regex = "0.2" -lazy_static = "1.4.0" diff --git a/exercises/practice/pig-latin/.meta/example.rs b/exercises/practice/pig-latin/.meta/example.rs index d3a26d20b..f6daf2cd0 100644 --- a/exercises/practice/pig-latin/.meta/example.rs +++ b/exercises/practice/pig-latin/.meta/example.rs @@ -1,6 +1,4 @@ -#[macro_use] -extern crate lazy_static; -extern crate regex; +use std::sync::LazyLock; use regex::Regex; @@ -9,12 +7,13 @@ use regex::Regex; pub fn translate_word(word: &str) -> String { // Prevent creation and compilation at every call. // These are compiled exactly once - lazy_static! { - // Detects if it starts with a vowel - static ref VOWEL: Regex = Regex::new(r"^([aeiou]|y[^aeiou]|xr)[a-z]*").unwrap(); - // Detects splits for initial consonants - static ref CONSONANTS: Regex = Regex::new(r"^([^aeiou]?qu|[^aeiou][^aeiouy]*)([a-z]*)").unwrap(); - } + + // Detects if it starts with a vowel + static VOWEL: LazyLock = + LazyLock::new(|| Regex::new(r"^([aeiou]|y[^aeiou]|xr)[a-z]*").unwrap()); + // Detects splits for initial consonants + static CONSONANTS: LazyLock = + LazyLock::new(|| Regex::new(r"^([^aeiou]?qu|[^aeiou][^aeiouy]*)([a-z]*)").unwrap()); if VOWEL.is_match(word) { String::from(word) + "ay" diff --git a/exercises/practice/robot-name/.meta/Cargo-example.toml b/exercises/practice/robot-name/.meta/Cargo-example.toml index be60f1e17..5713b6191 100644 --- a/exercises/practice/robot-name/.meta/Cargo-example.toml +++ b/exercises/practice/robot-name/.meta/Cargo-example.toml @@ -4,5 +4,4 @@ name = "robot-name" version = "0.0.0" [dependencies] -lazy_static = "1.4.0" rand = "0.3.12" diff --git a/exercises/practice/robot-name/.meta/example.rs b/exercises/practice/robot-name/.meta/example.rs index 07fbba8bf..8e79c0b78 100644 --- a/exercises/practice/robot-name/.meta/example.rs +++ b/exercises/practice/robot-name/.meta/example.rs @@ -1,11 +1,11 @@ -use lazy_static::lazy_static; +use std::{ + collections::HashSet, + sync::{LazyLock, Mutex}, +}; + use rand::{thread_rng, Rng}; -use std::collections::HashSet; -use std::sync::Mutex; -lazy_static! { - static ref NAMES: Mutex> = Mutex::new(HashSet::new()); -} +static NAMES: LazyLock>> = LazyLock::new(|| Mutex::new(HashSet::new())); pub struct Robot { name: String,