Skip to content

Commit

Permalink
fix(formatjs): Failed to parse unicode
Browse files Browse the repository at this point in the history
  • Loading branch information
cuyl committed Dec 24, 2024
1 parent 429b9b2 commit 2205dd5
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 4 deletions.
21 changes: 17 additions & 4 deletions crates/swc_icu_messageformat_parser/src/parser.rs
Original file line number Diff line number Diff line change
Expand Up @@ -831,8 +831,14 @@ impl<'s> Parser<'s> {
while !self.is_eof() && is_potential_element_name_char(self.char()) {
self.bump();
}

&self.message[start_offset..self.offset()]
#[cfg(feature = "utf16")]
return Box::leak(
self.message_utf16[start_offset..self.offset()]
.to_string()
.into_boxed_str(),
);
#[cfg(not(feature = "utf16"))]
return &self.message[start_offset..self.offset()];
}

fn parse_literal(&self, nesting_level: usize, parent_arg_type: &str) -> Result<AstElement> {
Expand Down Expand Up @@ -1735,9 +1741,16 @@ impl<'s> Parser<'s> {
if self.is_eof() {
return None;
}
self.message[self.offset() + self.char().len_utf8()..]

#[cfg(feature = "utf16")]
return self.message_utf16[self.offset() + self.char().len_utf16()..]
.chars()
.next()
.next();

#[cfg(not(feature = "utf16"))]
return self.message[self.offset() + self.char().len_utf8()..]
.chars()
.next();
}

/// Returns true if the next call to `bump` would return false.
Expand Down
43 changes: 43 additions & 0 deletions crates/swc_icu_messageformat_parser/tests/fixtures/unicode_1
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
<a>ö🚀</a>
---
{}
---
{
"err": null,
"val": [
{
"children": [
{
"location": {
"end": {
"column": 6,
"line": 1,
"offset": 6
},
"start": {
"column": 4,
"line": 1,
"offset": 3
}
},
"type": 0,
"value": "ö🚀"
}
],
"location": {
"end": {
"column": 10,
"line": 1,
"offset": 10
},
"start": {
"column": 1,
"line": 1,
"offset": 0
}
},
"type": 8,
"value": "a"
}
]
}
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ fn read_sections(file: PathBuf) -> TestFixtureSections {
fixture("tests/fixtures/treat_unicode_nbsp_as_whitespace")
)]
#[cfg_attr(feature = "utf16", fixture("tests/fixtures/trivial_2"))]
#[cfg_attr(feature = "utf16", fixture("tests/fixtures/unicode_1"))]
#[fixture("tests/fixtures/uppercase_tag_1")]
#[fixture("tests/fixtures/expect_number_arg_skeleton_token_1")]
#[fixture("tests/fixtures/self_closing_tag_1")]
Expand Down

0 comments on commit 2205dd5

Please sign in to comment.