summaryrefslogtreecommitdiff
path: root/src/ebuild/parsers.rs
diff options
context:
space:
mode:
authorJohn Turner <jturner.usa@gmail.com>2025-11-13 23:21:46 +0000
committerJohn Turner <jturner.usa@gmail.com>2025-11-13 23:21:46 +0000
commit50ab68c9c51dc14989ad5ee3d11442c8e452ebff (patch)
tree04e01cb0782d7caad0d648b238056dbd2b87f8e0 /src/ebuild/parsers.rs
parent58b4592b7b4e3a9ba8c39d2654342e0a34df487f (diff)
downloadgentoo-utils-50ab68c9c51dc14989ad5ee3d11442c8e452ebff.tar.gz
use new mon parsers
Diffstat (limited to 'src/ebuild/parsers.rs')
-rw-r--r--src/ebuild/parsers.rs15
1 files changed, 6 insertions, 9 deletions
diff --git a/src/ebuild/parsers.rs b/src/ebuild/parsers.rs
index f685df3..8ab2978 100644
--- a/src/ebuild/parsers.rs
+++ b/src/ebuild/parsers.rs
@@ -1,6 +1,6 @@
use std::path::PathBuf;
-use mon::{Parser, ParserIter, alpha1, r#if, tag, whitespace1};
+use mon::{Parser, ParserIter, alpha1, alphanumeric, r#if, one_of, tag, whitespace1};
use crate::{
Parseable,
@@ -48,6 +48,7 @@ impl<'a> Parseable<'a, &'a str> for SrcUri {
.recognize()
.map(|output: &str| PathBuf::from(output))
};
+
let uri = UriPrefix::parser()
.opt()
.and(Uri::parser())
@@ -66,10 +67,8 @@ impl<'a> Parseable<'a, &'a str> for License {
type Parser = impl Parser<&'a str, Output = Self>;
fn parser() -> Self::Parser {
- let start = r#if(|c: &char| c.is_ascii_alphanumeric() || "_".contains(*c));
- let rest = r#if(|c: &char| c.is_ascii_alphanumeric() || "+_.-".contains(*c))
- .repeated()
- .many();
+ let start = alphanumeric().or(one_of("_".chars()));
+ let rest = alphanumeric().or(one_of("+_.-".chars())).repeated().many();
start
.and(rest)
@@ -82,10 +81,8 @@ impl<'a> Parseable<'a, &'a str> for Eapi {
type Parser = impl Parser<&'a str, Output = Self>;
fn parser() -> Self::Parser {
- let start = r#if(|c: &char| c.is_ascii_alphanumeric() || "_".contains(*c));
- let rest = r#if(|c: &char| c.is_ascii_alphanumeric() || "+_.-".contains(*c))
- .repeated()
- .many();
+ let start = alphanumeric().or(one_of("_".chars()));
+ let rest = alphanumeric().or(one_of("+_.-".chars())).repeated().many();
start
.and(rest)