-
Notifications
You must be signed in to change notification settings - Fork 85
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: replace the "typeof __webpack_require__" content (#1688)
* fix: replace the "typeof __webpack_require__" content * fix: add some other webpack string name * fix: 增加对typeof 表达式的处理 * fix: delete log * fix: rename --------- Co-authored-by: shikuan.sk <[email protected]>
- Loading branch information
Showing
3 changed files
with
91 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
use swc_core::common::{Mark, DUMMY_SP}; | ||
use swc_core::ecma::ast::{Expr, Ident, UnaryExpr}; | ||
use swc_core::ecma::visit::{VisitMut, VisitMutWith}; | ||
|
||
pub const WEBPACK_VALUES: [&str; 14] = [ | ||
"__webpack_get_script_filename__", | ||
"__webpack_runtime_id__", | ||
"__webpack_chunkname__", | ||
"__webpack_nonce__", | ||
"__webpack_init_sharing__", | ||
"__webpack_share_scopes__", | ||
"__system_context__", | ||
"__non_webpack_require__", | ||
"__webpack_require__", | ||
"__webpack_hash__", | ||
"__webpack_modules__", | ||
"__webpack_module__", | ||
"__webpack_chunk_load__", | ||
"__webpack_base_uri__", | ||
]; | ||
|
||
pub struct WebpackRuntimeReplacement { | ||
pub unresolved_mark: Mark, | ||
} | ||
|
||
impl WebpackRuntimeReplacement { | ||
pub fn new(unresolved_mark: Mark) -> Self { | ||
Self { unresolved_mark } | ||
} | ||
fn is_ident_webpack(&self, ident: &Ident, unresolved_mark: &Mark) -> bool { | ||
WEBPACK_VALUES.iter().any(|&i| i == &ident.sym) && ident.ctxt.outer() == *unresolved_mark | ||
} | ||
} | ||
|
||
impl VisitMut for WebpackRuntimeReplacement { | ||
// find the "typeof __webpack_require__" in the ast tree | ||
fn visit_mut_unary_expr(&mut self, unary_expr: &mut UnaryExpr) { | ||
if unary_expr.op.as_str() == "typeof" | ||
&& let Some(arg_ident) = unary_expr.arg.as_ident() | ||
&& self.is_ident_webpack(arg_ident, &self.unresolved_mark) | ||
{ | ||
unary_expr.arg = Expr::undefined(DUMMY_SP) | ||
} else { | ||
unary_expr.visit_mut_children_with(self); | ||
} | ||
} | ||
} | ||
|
||
#[cfg(test)] | ||
mod tests { | ||
use swc_core::common::GLOBALS; | ||
use swc_core::ecma::visit::VisitMutWith; | ||
|
||
use super::WebpackRuntimeReplacement; | ||
use crate::ast::tests::TestUtils; | ||
|
||
#[test] | ||
fn test_webpack_require_ident() { | ||
assert_eq!( | ||
run(r#"typeof __webpack_require__ === 'function';"#), | ||
r#"typeof void 0 === 'function';"# | ||
); | ||
} | ||
|
||
#[test] | ||
fn test_webpack_module_ident() { | ||
assert_eq!(run(r#"typeof __webpack_modules__;"#), r#"typeof void 0;"#); | ||
} | ||
#[test] | ||
fn test_dbcheck_webpack_module_ident() { | ||
assert_eq!( | ||
run(r#"typeof typeof __webpack_modules__;"#), | ||
r#"typeof typeof void 0;"# | ||
); | ||
} | ||
|
||
fn run(js_code: &str) -> String { | ||
let mut test_utils = TestUtils::gen_js_ast(js_code); | ||
let ast = test_utils.ast.js_mut(); | ||
GLOBALS.set(&test_utils.context.meta.script.globals, || { | ||
let mut visitor = WebpackRuntimeReplacement { | ||
unresolved_mark: ast.unresolved_mark, | ||
}; | ||
ast.ast.visit_mut_with(&mut visitor); | ||
}); | ||
test_utils.js_ast_to_code() | ||
} | ||
} |