diff options
| author | Jonas Maier <jonas@x77.dev> | 2026-05-31 19:21:44 +0200 |
|---|---|---|
| committer | Jonas Maier <jonas@x77.dev> | 2026-05-31 19:21:44 +0200 |
| commit | 81759dd51eb1f6f9a7dc8af9b2b8126ff7dfab24 (patch) | |
| tree | af451a170b30e05148088d477b725023d02c505d /src/run/mod.rs | |
| parent | 08f3af622cc3e7b3f85a60c6ffe83d9d70e9dc02 (diff) | |
| download | pish-81759dd51eb1f6f9a7dc8af9b2b8126ff7dfab24.tar.gz | |
regex based case statements
Diffstat (limited to 'src/run/mod.rs')
| -rw-r--r-- | src/run/mod.rs | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/src/run/mod.rs b/src/run/mod.rs index f86278d..c3ceb76 100644 --- a/src/run/mod.rs +++ b/src/run/mod.rs @@ -456,8 +456,9 @@ impl Executor { stdout: OutputWriter, ) -> SpawnedCmd { for branch in c.branches.into_iter() { - // TODO: regex case patterns - if branch.pattern == c.discriminant { + // TODO: do not compile every time + let compiled = branch.pattern.compile(); + if compiled.matches(&c.discriminant) { return self.execute_block(branch.block, stdin, stdout); } } @@ -732,6 +733,8 @@ const BUILTINS: &[&'static dyn BuiltinClone] = &[ &builtin::logo, &builtin::export, &builtin::pish_theme, + #[cfg(debug_assertions)] + &builtin::case_match, ]; pub fn builtin_map() -> HashMap<BString, &'static dyn BuiltinClone> { |
