Skip to content

Commit

Permalink
fix(parser): include export token in spans of TSNamespaceExportDeclar…
Browse files Browse the repository at this point in the history
…ation (oxc-project#7963)

Spans of `TSNamespaceExportDeclaration`(`export as namespace Foo`)
should start with `export`:


https://astexplorer.net/#/gist/c1a2023d6bbc600f5f2b812ecb379129/cc89efb2b7dccb454a7f891fbef453377e0c61ed
  • Loading branch information
branchseer authored Dec 17, 2024
1 parent ec2128e commit 111dc52
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions crates/oxc_parser/src/js/module.rs
Original file line number Diff line number Diff line change
Expand Up @@ -221,13 +221,13 @@ impl<'a> ParserImpl<'a> {

pub(crate) fn parse_ts_export_namespace(
&mut self,
start_span: Span,
) -> Result<Box<'a, TSNamespaceExportDeclaration<'a>>> {
let span = self.start_span();
self.expect(Kind::As)?;
self.expect(Kind::Namespace)?;
let id = self.parse_identifier_name()?;
self.asi()?;
Ok(self.ast.alloc_ts_namespace_export_declaration(self.end_span(span), id))
Ok(self.ast.alloc_ts_namespace_export_declaration(self.end_span(start_span), id))
}

/// [Exports](https://tc39.es/ecma262/#sec-exports)
Expand All @@ -240,7 +240,7 @@ impl<'a> ParserImpl<'a> {
.parse_ts_export_assignment_declaration(span)
.map(ModuleDeclaration::TSExportAssignment),
Kind::As if self.peek_at(Kind::Namespace) && self.is_ts => self
.parse_ts_export_namespace()
.parse_ts_export_namespace(span)
.map(ModuleDeclaration::TSNamespaceExportDeclaration),
Kind::Default => self
.parse_export_default_declaration(span)
Expand Down

0 comments on commit 111dc52

Please sign in to comment.