1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
use std::str::FromStr;
use crate::ast::ClassOrObjectMemberKey;
use crate::error::{SyntaxError, SyntaxErrorType, SyntaxResult};
use crate::num::JsNumber;
use crate::parse::expr::parse_expr;
use crate::parse::parser::Parser;
use crate::source::SourceRange;
use crate::symbol::ScopeId;
use crate::token::TokenType;
use super::pattern::ParsePatternSyntax;
fn parse_radix(raw: &str, radix: u32) -> Result<f64, ()> {
u64::from_str_radix(raw, radix)
.map_err(|_| ())
.map(|v| v as f64)
}
pub fn normalise_literal_number(raw: &SourceRange) -> SyntaxResult<JsNumber> {
match raw.as_str() {
s if s.starts_with("0b") || s.starts_with("0B") => parse_radix(&s[2..], 2),
s if s.starts_with("0o") || s.starts_with("0o") => parse_radix(&s[2..], 8),
s if s.starts_with("0x") || s.starts_with("0X") => parse_radix(&s[2..], 16),
s => f64::from_str(s).map_err(|_| ()),
}
.map(|n| JsNumber(n))
.map_err(|_| SyntaxError::from_loc(raw, SyntaxErrorType::MalformedLiteralNumber, None))
}
pub fn normalise_literal_string(raw: &SourceRange) -> SyntaxResult<String> {
Ok(raw.as_str()[1..raw.len() - 1].to_string())
}
pub fn parse_and_normalise_literal_string(parser: &mut Parser) -> SyntaxResult<String> {
let t = parser.require(TokenType::LiteralString)?;
let s = normalise_literal_string(t.loc())?;
Ok(s)
}
pub fn parse_class_or_object_member_key(
scope: ScopeId,
parser: &mut Parser,
syntax: &ParsePatternSyntax,
) -> SyntaxResult<ClassOrObjectMemberKey> {
Ok(if parser.consume_if(TokenType::BracketOpen)?.is_match() {
let expr = parse_expr(scope, parser, TokenType::BracketClose, syntax)?;
parser.require(TokenType::BracketClose)?;
ClassOrObjectMemberKey::Computed(expr)
} else {
let name = parser.require(TokenType::Identifier)?;
ClassOrObjectMemberKey::Direct(name.loc().clone())
})
}