From 0b56d50899b8bb67b94023c79eb622368135a127 Mon Sep 17 00:00:00 2001 From: underfin Date: Mon, 1 Jul 2024 16:45:00 +0800 Subject: [PATCH] chore(napi): make transformer options optional (#3989) --- napi/transform/index.d.ts | 38 ++++++++++------- napi/transform/src/lib.rs | 2 +- napi/transform/src/transformer.rs | 71 ++++++++++++++++--------------- 3 files changed, 61 insertions(+), 50 deletions(-) diff --git a/napi/transform/index.d.ts b/napi/transform/index.d.ts index 42f04ad75ba0f..8f0fad58daaf0 100644 --- a/napi/transform/index.d.ts +++ b/napi/transform/index.d.ts @@ -4,17 +4,17 @@ /* auto-generated by NAPI-RS */ export interface TypeScriptBindingOptions { - jsxPragma: string - jsxPragmaFrag: string - onlyRemoveTypeImports: boolean - allowNamespaces: boolean - allowDeclareFields: boolean + jsxPragma?: string + jsxPragmaFrag?: string + onlyRemoveTypeImports?: boolean + allowNamespaces?: boolean + allowDeclareFields?: boolean } export interface ReactBindingOptions { - runtime: 'classic' | 'automatic' - development: boolean - throwIfNamespace: boolean - pure: boolean + runtime?: 'classic' | 'automatic' + development?: boolean + throwIfNamespace?: boolean + pure?: boolean importSource?: string pragma?: string pragmaFrag?: string @@ -22,15 +22,23 @@ export interface ReactBindingOptions { useSpread?: boolean } export interface ArrowFunctionsBindingOptions { - spec: boolean + spec?: boolean } export interface Es2015BindingOptions { arrowFunction?: ArrowFunctionsBindingOptions } export interface TransformBindingOptions { - typescript: TypeScriptBindingOptions - react: ReactBindingOptions - es2015: Es2015BindingOptions + typescript?: TypeScriptBindingOptions + react?: ReactBindingOptions + es2015?: Es2015BindingOptions + /** + * Enable Sourcemap + * + * * `true` to generate a sourcemap for the code and include it in the result object. + * + * Default: false + */ + sourcemap?: boolean } export interface Sourcemap { file?: string @@ -45,10 +53,10 @@ export interface TransformResult { map?: Sourcemap errors: Array } -export function transform(filename: string, sourceText: string, options: TransformBindingOptions): TransformResult +function transform(filename: string, sourceText: string, options?: TransformBindingOptions | undefined | null): TransformResult export interface IsolatedDeclarationsResult { sourceText: string errors: Array } /** TypeScript Isolated Declarations for Standalone DTS Emit */ -export function isolatedDeclaration(filename: string, sourceText: string): IsolatedDeclarationsResult +function isolatedDeclaration(filename: string, sourceText: string): IsolatedDeclarationsResult diff --git a/napi/transform/src/lib.rs b/napi/transform/src/lib.rs index 8f0fb5f910d00..1bcabab170c6e 100644 --- a/napi/transform/src/lib.rs +++ b/napi/transform/src/lib.rs @@ -1,4 +1,4 @@ -mod transformer; +pub mod transformer; use napi_derive::napi; diff --git a/napi/transform/src/transformer.rs b/napi/transform/src/transformer.rs index 2956bba155c8d..de82c804a0e42 100644 --- a/napi/transform/src/transformer.rs +++ b/napi/transform/src/transformer.rs @@ -12,21 +12,24 @@ use oxc_transformer::{ #[napi(object)] pub struct TypeScriptBindingOptions { - pub jsx_pragma: String, - pub jsx_pragma_frag: String, - pub only_remove_type_imports: bool, - pub allow_namespaces: bool, - pub allow_declare_fields: bool, + pub jsx_pragma: Option, + pub jsx_pragma_frag: Option, + pub only_remove_type_imports: Option, + pub allow_namespaces: Option, + pub allow_declare_fields: Option, } impl From for TypeScriptOptions { fn from(options: TypeScriptBindingOptions) -> Self { + let ops = TypeScriptOptions::default(); TypeScriptOptions { - jsx_pragma: options.jsx_pragma.into(), - jsx_pragma_frag: options.jsx_pragma_frag.into(), - only_remove_type_imports: options.only_remove_type_imports, - allow_namespaces: options.allow_namespaces, - allow_declare_fields: options.allow_declare_fields, + jsx_pragma: options.jsx_pragma.map(Into::into).unwrap_or(ops.jsx_pragma), + jsx_pragma_frag: options.jsx_pragma_frag.map(Into::into).unwrap_or(ops.jsx_pragma_frag), + only_remove_type_imports: options + .only_remove_type_imports + .unwrap_or(ops.only_remove_type_imports), + allow_namespaces: options.allow_namespaces.unwrap_or(ops.allow_namespaces), + allow_declare_fields: options.allow_declare_fields.unwrap_or(ops.allow_declare_fields), } } } @@ -34,10 +37,10 @@ impl From for TypeScriptOptions { #[napi(object)] pub struct ReactBindingOptions { #[napi(ts_type = "'classic' | 'automatic'")] - pub runtime: String, - pub development: bool, - pub throw_if_namespace: bool, - pub pure: bool, + pub runtime: Option, + pub development: Option, + pub throw_if_namespace: Option, + pub pure: Option, pub import_source: Option, pub pragma: Option, pub pragma_frag: Option, @@ -47,14 +50,15 @@ pub struct ReactBindingOptions { impl From for ReactOptions { fn from(options: ReactBindingOptions) -> Self { + let ops = ReactOptions::default(); ReactOptions { - runtime: match options.runtime.as_str() { - "classic" => ReactJsxRuntime::Classic, + runtime: match options.runtime.as_deref() { + Some("classic") => ReactJsxRuntime::Classic, /* "automatic" */ _ => ReactJsxRuntime::Automatic, }, - development: options.development, - throw_if_namespace: options.throw_if_namespace, - pure: options.pure, + development: options.development.unwrap_or(ops.development), + throw_if_namespace: options.throw_if_namespace.unwrap_or(ops.throw_if_namespace), + pure: options.pure.unwrap_or(ops.pure), import_source: options.import_source, pragma: options.pragma, pragma_frag: options.pragma_frag, @@ -67,12 +71,12 @@ impl From for ReactOptions { #[napi(object)] pub struct ArrowFunctionsBindingOptions { - pub spec: bool, + pub spec: Option, } impl From for ArrowFunctionsOptions { fn from(options: ArrowFunctionsBindingOptions) -> Self { - ArrowFunctionsOptions { spec: options.spec } + ArrowFunctionsOptions { spec: options.spec.unwrap_or_default() } } } @@ -89,23 +93,23 @@ impl From for ES2015Options { #[napi(object)] pub struct TransformBindingOptions { - pub typescript: TypeScriptBindingOptions, - pub react: ReactBindingOptions, - pub es2015: ES2015BindingOptions, - /// Enable Sourcemaps + pub typescript: Option, + pub react: Option, + pub es2015: Option, + /// Enable Sourcemap /// /// * `true` to generate a sourcemap for the code and include it in the result object. /// /// Default: false - pub sourcemaps: bool, + pub sourcemap: Option, } impl From for TransformOptions { fn from(options: TransformBindingOptions) -> Self { TransformOptions { - typescript: options.typescript.into(), - react: options.react.into(), - es2015: options.es2015.into(), + typescript: options.typescript.map(Into::into).unwrap_or_default(), + react: options.react.map(Into::into).unwrap_or_default(), + es2015: options.es2015.map(Into::into).unwrap_or_default(), ..TransformOptions::default() } } @@ -124,7 +128,6 @@ pub struct Sourcemap { #[napi(object)] pub struct TransformResult { pub source_text: String, - /// Sourcemap pub map: Option, pub errors: Vec, } @@ -134,9 +137,9 @@ pub struct TransformResult { pub fn transform( filename: String, source_text: String, - options: TransformBindingOptions, + options: Option, ) -> TransformResult { - let sourcemaps = options.sourcemaps; + let sourcemap = options.as_ref().is_some_and(|x| x.sourcemap.unwrap_or_default()); let mut errors = vec![]; let source_path = Path::new(&filename); @@ -148,7 +151,7 @@ pub fn transform( } let mut program = parser_ret.program; - let transform_options = TransformOptions::from(options); + let transform_options = options.map(Into::into).unwrap_or_default(); let ret = Transformer::new( &allocator, source_path, @@ -164,7 +167,7 @@ pub fn transform( } let mut codegen = CodeGenerator::new(); - if sourcemaps { + if sourcemap { codegen = codegen.enable_source_map(source_path.to_string_lossy().as_ref(), &source_text); } let ret = codegen.build(&program);