Skip to content

Commit

Permalink
Merge branch 'main' into main
Browse files Browse the repository at this point in the history
  • Loading branch information
chu2508 authored Oct 28, 2024
2 parents 2a9b48a + d936b77 commit d15403b
Show file tree
Hide file tree
Showing 203 changed files with 31,305 additions and 27,454 deletions.
4 changes: 2 additions & 2 deletions .cargo/config.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,5 +20,5 @@ rustflags = ["-C", "target-feature=+crt-static"]
# Alias to build actual SWC plugin binary for the specified target.
build-wasi = "build --target wasm32-wasi"
build-wasm32 = "build --target wasm32-unknown-unknown"
build-swc-plugins = "build-wasi --release -p swc_plugin_compile_mode -p swc_plugin_define_config"
test-swc-plugins = "test -p swc_plugin_compile_mode -p swc_plugin_define_config"
build-swc-plugins = "build-wasi --release -p swc_plugin_compile_mode -p swc_plugin_define_config -p swc_plugin_compile_mode_pre_process"
test-swc-plugins = "test -p swc_plugin_compile_mode -p swc_plugin_define_config -p swc_plugin_compile_mode_pre_process"
2 changes: 1 addition & 1 deletion .github/workflows/build-rust-binding.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ jobs:
- name: Setup pnpm
uses: pnpm/[email protected]
with:
version: 8
version: 9
- name: Setup Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
if: ${{ !matrix.settings.docker }}
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/nodejs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ jobs:
- name: Setup pnpm
uses: pnpm/[email protected]
with:
version: 8
version: 9
- name: Setup Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/publish.yml
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ jobs:
- name: Setup pnpm
uses: pnpm/[email protected]
with:
version: 8
version: 9
- name: Setup Node 18
uses: actions/setup-node@v4
with:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/sync-components-types.yml
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ jobs:
- name: install
uses: pnpm/[email protected]
with:
version: 8
version: 9
run_install: |
- recursive: true
args: [--frozen-lockfile, --strict-peer-dependencies]
Expand Down
Empty file modified .husky/commit-msg
100644 → 100755
Empty file.
Empty file modified .husky/pre-commit
100644 → 100755
Empty file.
3 changes: 2 additions & 1 deletion .vscode/settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,8 @@
"./crates/taro_init/Cargo.toml",
"./crates/native_binding/Cargo.toml",
"./crates/swc_plugin_compile_mode/Cargo.toml",
"./crates/swc_plugin_define_config/Cargo.toml"
"./crates/swc_plugin_define_config/Cargo.toml",
"./crates/swc_plugin_compile_mode_pre_process/Cargo.toml"
],
"rust-analyzer.showUnlinkedFileNotification": false
}
11 changes: 11 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion crates/native_binding/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@tarojs/binding",
"version": "4.0.6",
"version": "4.0.7",
"description": "Node binding for taro",
"main": "binding.js",
"typings": "binding.d.ts",
Expand Down
6 changes: 0 additions & 6 deletions crates/swc_plugin_compile_mode/.editorconfig

This file was deleted.

102 changes: 52 additions & 50 deletions crates/swc_plugin_compile_mode/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,54 +1,60 @@
use serde::Deserialize;
use std::collections::HashMap;
use swc_core::{
ecma::{
ast::Program,
visit::{as_folder, FoldWith, VisitMut},
},
plugin::{
plugin_transform,
proxies::TransformPluginProgramMetadata
}
ecma::{
ast::Program,
visit::{as_folder, FoldWith, VisitMut},
},
plugin::{plugin_transform, proxies::TransformPluginProgramMetadata},
};
use serde::{Deserialize};
use std::collections::HashMap;

mod utils;
mod transform;
mod transform_harmony;
#[cfg(test)]
mod tests;
mod transform;
mod transform_harmony;
mod utils;

struct SerdeDefault;
impl SerdeDefault {
fn platform_default () -> String {
String::from("WEAPP")
}
fn platform_default() -> String {
String::from("WEAPP")
}
fn is_use_xs_default() -> bool {
true
}
fn template_tag_default() -> String {
String::from("")
}
}

#[derive(Deserialize, Debug)]
#[derive(Deserialize, Debug)]
pub struct ComponentReplace {
pub current_init: String,
pub dependency_define: String,
pub current_init: String,
pub dependency_define: String,
}
#[derive(Deserialize, Debug)]
pub struct PluginConfig {
pub tmpl_prefix: String,
#[serde(default = "SerdeDefault::platform_default")]
pub platform: String,
#[serde(default)]
pub is_harmony: bool,
#[serde(default)]
pub components: HashMap<String, HashMap<String, String>>,
#[serde(default)]
pub adapter: HashMap<String, String>,
#[serde(default)]
pub support_events: Vec<String>,
#[serde(default)]
pub support_components: Vec<String>,
#[serde(default)]
pub event_adapter: HashMap<String, String>,
#[serde(default)]
pub component_replace: HashMap<String, ComponentReplace>,

pub tmpl_prefix: String,
#[serde(default = "SerdeDefault::platform_default")]
pub platform: String,
#[serde(default)]
pub is_harmony: bool,
#[serde(default)]
pub components: HashMap<String, HashMap<String, String>>,
#[serde(default)]
pub adapter: HashMap<String, String>,
#[serde(default)]
pub support_events: Vec<String>,
#[serde(default)]
pub support_components: Vec<String>,
#[serde(default)]
pub event_adapter: HashMap<String, String>,
#[serde(default)]
pub component_replace: HashMap<String, ComponentReplace>,
#[serde(default = "SerdeDefault::is_use_xs_default")]
pub is_use_xs: bool,
#[serde(default = "SerdeDefault::template_tag_default")]
pub template_tag: String,
}

/// An example plugin function with macro support.
Expand All @@ -68,19 +74,15 @@ pub struct PluginConfig {
/// Refer swc_plugin_macro to see how does it work internally.
#[plugin_transform]
pub fn process_transform(program: Program, metadata: TransformPluginProgramMetadata) -> Program {
let config = serde_json::from_str::<PluginConfig>(
&metadata
.get_transform_plugin_config()
.unwrap()
)
.unwrap();
let config =
serde_json::from_str::<PluginConfig>(&metadata.get_transform_plugin_config().unwrap()).unwrap();

// 如果 config 中的 is_harmony 字段为 true 则走 harmony_transform, 否则则走 transform
let visitor: Box<dyn VisitMut> = if config.is_harmony {
Box::new(transform_harmony::TransformVisitor::new(config))
} else {
Box::new(transform::TransformVisitor::new(config))
};
// 如果 config 中的 is_harmony 字段为 true 则走 harmony_transform, 否则则走 transform
let visitor: Box<dyn VisitMut> = if config.is_harmony {
Box::new(transform_harmony::TransformVisitor::new(config))
} else {
Box::new(transform::TransformVisitor::new(config))
};

program.fold_with(&mut as_folder(visitor))
program.fold_with(&mut as_folder(visitor))
}
26 changes: 13 additions & 13 deletions crates/swc_plugin_compile_mode/src/tests/attributes.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
use super::{get_syntax_config, tr};
use swc_core::ecma::transforms::testing::test;
use super::{tr, get_syntax_config};

test!(
get_syntax_config(),
|_| tr(),
should_keep_static_attrs_only_in_templates,
r#"
get_syntax_config(),
|_| tr(),
should_keep_static_attrs_only_in_templates,
r#"
function Index () {
return (
<View compileMode>
Expand All @@ -17,10 +17,10 @@ test!(
);

test!(
get_syntax_config(),
|_| tr(),
should_turn_dynamic_attrs,
r#"
get_syntax_config(),
|_| tr(),
should_turn_dynamic_attrs,
r#"
function Index () {
return (
<View compileMode>
Expand All @@ -37,10 +37,10 @@ test!(
);

test!(
get_syntax_config(),
|_| tr(),
should_handle_events,
r#"
get_syntax_config(),
|_| tr(),
should_handle_events,
r#"
function Index () {
return (
<View compileMode>
Expand Down
42 changes: 21 additions & 21 deletions crates/swc_plugin_compile_mode/src/tests/children.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
use super::{get_syntax_config, tr};
use swc_core::ecma::transforms::testing::test;
use super::{tr, get_syntax_config};

test!(
get_syntax_config(),
|_| tr(),
should_support_render_fn,
r#"
get_syntax_config(),
|_| tr(),
should_support_render_fn,
r#"
function Index () {
return (
<View compileMode>
Expand All @@ -19,10 +19,10 @@ test!(
);

test!(
get_syntax_config(),
|_| tr(),
should_support_fragment,
r#"
get_syntax_config(),
|_| tr(),
should_support_fragment,
r#"
function Index () {
return (
<View compileMode>
Expand Down Expand Up @@ -54,10 +54,10 @@ test!(
);

test!(
get_syntax_config(),
|_| tr(),
should_support_context_api,
r#"
get_syntax_config(),
|_| tr(),
should_support_context_api,
r#"
function Index () {
return (
<View compileMode>
Expand All @@ -77,10 +77,10 @@ test!(
);

test!(
get_syntax_config(),
|_| tr(),
should_render_react_component,
r#"
get_syntax_config(),
|_| tr(),
should_render_react_component,
r#"
function Index () {
return (
<View compileMode>
Expand All @@ -94,10 +94,10 @@ test!(
);

test!(
get_syntax_config(),
|_| tr(),
should_render_native_component,
r#"
get_syntax_config(),
|_| tr(),
should_render_native_component,
r#"
function Index () {
return (
<View compileMode>
Expand Down
Loading

0 comments on commit d15403b

Please sign in to comment.