perf: Split parsers into erlang/js targets
This commit is contained in:
@@ -729,6 +729,7 @@ fn parse_unreserved(str: String) -> Result(#(String, String), Nil) {
|
|||||||
// / "*" / "+" / "," / ";" / "="
|
// / "*" / "+" / "," / ";" / "="
|
||||||
// %21 / %24 / %26 / %27 / %28 / %29
|
// %21 / %24 / %26 / %27 / %28 / %29
|
||||||
// / %2A / %2B / %2C / %3B / %3D
|
// / %2A / %2B / %2C / %3B / %3D
|
||||||
|
@target(erlang)
|
||||||
fn parse_sub_delim(str: String) -> Result(#(String, String), Nil) {
|
fn parse_sub_delim(str: String) -> Result(#(String, String), Nil) {
|
||||||
case string.pop_grapheme(str) {
|
case string.pop_grapheme(str) {
|
||||||
Ok(#("!" as char, tail))
|
Ok(#("!" as char, tail))
|
||||||
@@ -746,7 +747,26 @@ fn parse_sub_delim(str: String) -> Result(#(String, String), Nil) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@target(javascript)
|
||||||
|
fn parse_sub_delim(str: String) -> Result(#(String, String), Nil) {
|
||||||
|
case str {
|
||||||
|
"!" as char <> tail
|
||||||
|
| "$" as char <> tail
|
||||||
|
| "&" as char <> tail
|
||||||
|
| "'" as char <> tail
|
||||||
|
| "(" as char <> tail
|
||||||
|
| ")" as char <> tail
|
||||||
|
| "*" as char <> tail
|
||||||
|
| "+" as char <> tail
|
||||||
|
| "," as char <> tail
|
||||||
|
| ";" as char <> tail
|
||||||
|
| "=" as char <> tail -> Ok(#(char, tail))
|
||||||
|
_ -> Error(Nil)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// DIGIT = %x30–39
|
// DIGIT = %x30–39
|
||||||
|
@target(erlang)
|
||||||
fn parse_digit(str: String) -> Result(#(String, String), Nil) {
|
fn parse_digit(str: String) -> Result(#(String, String), Nil) {
|
||||||
case string.pop_grapheme(str) {
|
case string.pop_grapheme(str) {
|
||||||
Ok(#("0" as char, tail))
|
Ok(#("0" as char, tail))
|
||||||
@@ -764,7 +784,26 @@ fn parse_digit(str: String) -> Result(#(String, String), Nil) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@target(javascript)
|
||||||
|
fn parse_digit(str: String) -> Result(#(String, String), Nil) {
|
||||||
|
case str {
|
||||||
|
"0" as char <> tail
|
||||||
|
| "1" as char <> tail
|
||||||
|
| "2" as char <> tail
|
||||||
|
| "3" as char <> tail
|
||||||
|
| "4" as char <> tail
|
||||||
|
| "5" as char <> tail
|
||||||
|
| "6" as char <> tail
|
||||||
|
| "7" as char <> tail
|
||||||
|
| "8" as char <> tail
|
||||||
|
| "9" as char <> tail -> Ok(#(char, tail))
|
||||||
|
|
||||||
|
_ -> Error(Nil)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// DIGIT (non-zero) = %x31–39
|
// DIGIT (non-zero) = %x31–39
|
||||||
|
@target(erlang)
|
||||||
fn parse_digit_nz(str: String) -> Result(#(String, String), Nil) {
|
fn parse_digit_nz(str: String) -> Result(#(String, String), Nil) {
|
||||||
case string.pop_grapheme(str) {
|
case string.pop_grapheme(str) {
|
||||||
Ok(#("1" as char, tail))
|
Ok(#("1" as char, tail))
|
||||||
@@ -781,6 +820,23 @@ fn parse_digit_nz(str: String) -> Result(#(String, String), Nil) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@target(javascript)
|
||||||
|
fn parse_digit_nz(str: String) -> Result(#(String, String), Nil) {
|
||||||
|
case str {
|
||||||
|
"1" as char <> tail
|
||||||
|
| "2" as char <> tail
|
||||||
|
| "3" as char <> tail
|
||||||
|
| "4" as char <> tail
|
||||||
|
| "5" as char <> tail
|
||||||
|
| "6" as char <> tail
|
||||||
|
| "7" as char <> tail
|
||||||
|
| "8" as char <> tail
|
||||||
|
| "9" as char <> tail -> Ok(#(char, tail))
|
||||||
|
|
||||||
|
_ -> Error(Nil)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn parse_digits(str: String, digits: String) {
|
fn parse_digits(str: String, digits: String) {
|
||||||
case parse_digit(str) {
|
case parse_digit(str) {
|
||||||
Ok(#(d, rest)) -> {
|
Ok(#(d, rest)) -> {
|
||||||
@@ -791,6 +847,7 @@ fn parse_digits(str: String, digits: String) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ALPHA = %x41–5A | %x61–7A
|
// ALPHA = %x41–5A | %x61–7A
|
||||||
|
@target(erlang)
|
||||||
fn parse_alpha(str: String) -> Result(#(String, String), Nil) {
|
fn parse_alpha(str: String) -> Result(#(String, String), Nil) {
|
||||||
case string.pop_grapheme(str) {
|
case string.pop_grapheme(str) {
|
||||||
Ok(#("a" as char, tail))
|
Ok(#("a" as char, tail))
|
||||||
@@ -850,6 +907,66 @@ fn parse_alpha(str: String) -> Result(#(String, String), Nil) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@target(javascript)
|
||||||
|
fn parse_alpha(str: String) -> Result(#(String, String), Nil) {
|
||||||
|
case str {
|
||||||
|
"a" as char <> tail
|
||||||
|
| "b" as char <> tail
|
||||||
|
| "c" as char <> tail
|
||||||
|
| "d" as char <> tail
|
||||||
|
| "e" as char <> tail
|
||||||
|
| "f" as char <> tail
|
||||||
|
| "g" as char <> tail
|
||||||
|
| "h" as char <> tail
|
||||||
|
| "i" as char <> tail
|
||||||
|
| "j" as char <> tail
|
||||||
|
| "k" as char <> tail
|
||||||
|
| "l" as char <> tail
|
||||||
|
| "m" as char <> tail
|
||||||
|
| "n" as char <> tail
|
||||||
|
| "o" as char <> tail
|
||||||
|
| "p" as char <> tail
|
||||||
|
| "q" as char <> tail
|
||||||
|
| "r" as char <> tail
|
||||||
|
| "s" as char <> tail
|
||||||
|
| "t" as char <> tail
|
||||||
|
| "u" as char <> tail
|
||||||
|
| "v" as char <> tail
|
||||||
|
| "w" as char <> tail
|
||||||
|
| "x" as char <> tail
|
||||||
|
| "y" as char <> tail
|
||||||
|
| "z" as char <> tail
|
||||||
|
| "A" as char <> tail
|
||||||
|
| "B" as char <> tail
|
||||||
|
| "C" as char <> tail
|
||||||
|
| "D" as char <> tail
|
||||||
|
| "E" as char <> tail
|
||||||
|
| "F" as char <> tail
|
||||||
|
| "G" as char <> tail
|
||||||
|
| "H" as char <> tail
|
||||||
|
| "I" as char <> tail
|
||||||
|
| "J" as char <> tail
|
||||||
|
| "K" as char <> tail
|
||||||
|
| "L" as char <> tail
|
||||||
|
| "M" as char <> tail
|
||||||
|
| "N" as char <> tail
|
||||||
|
| "O" as char <> tail
|
||||||
|
| "P" as char <> tail
|
||||||
|
| "Q" as char <> tail
|
||||||
|
| "R" as char <> tail
|
||||||
|
| "S" as char <> tail
|
||||||
|
| "T" as char <> tail
|
||||||
|
| "U" as char <> tail
|
||||||
|
| "V" as char <> tail
|
||||||
|
| "W" as char <> tail
|
||||||
|
| "X" as char <> tail
|
||||||
|
| "Y" as char <> tail
|
||||||
|
| "Z" as char <> tail -> Ok(#(char, tail))
|
||||||
|
|
||||||
|
_ -> Error(Nil)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn parse_query_parts(query: String) -> Result(List(#(String, String)), Nil) {
|
pub fn parse_query_parts(query: String) -> Result(List(#(String, String)), Nil) {
|
||||||
let splitter = splitter.new(["&"])
|
let splitter = splitter.new(["&"])
|
||||||
|
|
||||||
|
|||||||
@@ -370,6 +370,7 @@ fn unescape_percent(str: String) -> String {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@target(erlang)
|
||||||
pub fn parse_hex_digit(str: String) -> Result(#(String, String), Nil) {
|
pub fn parse_hex_digit(str: String) -> Result(#(String, String), Nil) {
|
||||||
case string.pop_grapheme(str) {
|
case string.pop_grapheme(str) {
|
||||||
Ok(#("0" as char, tail))
|
Ok(#("0" as char, tail))
|
||||||
@@ -399,6 +400,36 @@ pub fn parse_hex_digit(str: String) -> Result(#(String, String), Nil) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@target(javascript)
|
||||||
|
pub fn parse_hex_digit(str: String) -> Result(#(String, String), Nil) {
|
||||||
|
case str {
|
||||||
|
"0" as char <> tail
|
||||||
|
| "1" as char <> tail
|
||||||
|
| "2" as char <> tail
|
||||||
|
| "3" as char <> tail
|
||||||
|
| "4" as char <> tail
|
||||||
|
| "5" as char <> tail
|
||||||
|
| "6" as char <> tail
|
||||||
|
| "7" as char <> tail
|
||||||
|
| "8" as char <> tail
|
||||||
|
| "9" as char <> tail
|
||||||
|
| "a" as char <> tail
|
||||||
|
| "b" as char <> tail
|
||||||
|
| "c" as char <> tail
|
||||||
|
| "d" as char <> tail
|
||||||
|
| "e" as char <> tail
|
||||||
|
| "f" as char <> tail
|
||||||
|
| "A" as char <> tail
|
||||||
|
| "B" as char <> tail
|
||||||
|
| "C" as char <> tail
|
||||||
|
| "D" as char <> tail
|
||||||
|
| "E" as char <> tail
|
||||||
|
| "F" as char <> tail -> Ok(#(char, tail))
|
||||||
|
|
||||||
|
_ -> Error(Nil)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn parse_hex_digits(str, min, max) {
|
pub fn parse_hex_digits(str, min, max) {
|
||||||
parse_min_max(str, min, max, parse_hex_digit)
|
parse_min_max(str, min, max, parse_hex_digit)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user