one
Version:
One is a new React Framework that makes Vite serve both native and web.
136 lines (134 loc) • 5.44 kB
JavaScript
import { extname, relative } from "path";
import BabelGenerate from "@babel/generator";
import { parse } from "@babel/parser";
import BabelTraverse from "@babel/traverse";
import { deadCodeElimination, findReferencedIdentifiers } from "babel-dead-code-elimination";
import { EMPTY_LOADER_STRING } from "../constants.native.js";
function _instanceof(left, right) {
return right != null && typeof Symbol < "u" && right[Symbol.hasInstance] ? !!right[Symbol.hasInstance](left) : left instanceof right;
}
var traverse = BabelTraverse.default || BabelTraverse,
generate = BabelGenerate.default || BabelGenerate;
function collectTypeImports(ast) {
var typeImports = [];
return traverse(ast, {
ImportDeclaration(path) {
path.node.importKind === "type" && typeImports.push(path.node);
}
}), typeImports;
}
function restoreTypeImports(ast, typeImports) {
if (typeImports.length !== 0) {
var existingSources = /* @__PURE__ */new Set();
traverse(ast, {
ImportDeclaration(path) {
path.node.importKind === "type" && existingSources.add(path.node.source.value);
}
});
var _iteratorNormalCompletion = !0,
_didIteratorError = !1,
_iteratorError = void 0;
try {
for (var _iterator = typeImports[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) {
var typeImport = _step.value;
existingSources.has(typeImport.source.value) || ast.program.body.unshift(typeImport);
}
} catch (err) {
_didIteratorError = !0, _iteratorError = err;
} finally {
try {
!_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
} finally {
if (_didIteratorError) throw _iteratorError;
}
}
}
}
var clientTreeShakePlugin = function () {
return {
name: "one-client-tree-shake",
enforce: "pre",
applyToEnvironment(env) {
return env.name === "client" || env.name === "ios" || env.name === "android";
},
transform: {
order: "pre",
async handler(code, id, settings) {
if (this.environment.name !== "ssr" && /\.(js|jsx|ts|tsx)/.test(extname(id)) && !/node_modules/.test(id)) {
var out = await transformTreeShakeClient(code, id);
return out;
}
}
}
};
};
async function transformTreeShakeClient(code, id) {
if (/generateStaticParams|loader/.test(code)) {
var ast;
try {
ast = parse(code, {
sourceType: "module",
plugins: ["typescript", "jsx"]
});
} catch (error) {
var errorMessage = _instanceof(error, Error) ? error.message : String(error);
console.warn(`[one] Skipping tree shaking for ${id} due to syntax error:`, errorMessage);
return;
}
var referenced;
try {
referenced = findReferencedIdentifiers(ast);
} catch (error) {
var errorMessage1 = _instanceof(error, Error) ? error.message : String(error);
console.warn(`[one] Skipping tree shaking for ${id} due to identifier analysis error:`, errorMessage1);
return;
}
var removed = {
loader: !1,
generateStaticParams: !1
};
try {
traverse(ast, {
ExportNamedDeclaration(path) {
if (path.node.declaration && path.node.declaration.type === "FunctionDeclaration") {
if (!path.node.declaration.id) return;
var functionName = path.node.declaration.id.name;
(functionName === "loader" || functionName === "generateStaticParams") && (path.remove(), removed[functionName] = !0);
} else path.node.declaration && path.node.declaration.type === "VariableDeclaration" && path.node.declaration.declarations.forEach(function (declarator, index) {
if (declarator.id.type === "Identifier" && (declarator.id.name === "loader" || declarator.id.name === "generateStaticParams")) {
var declaration = path.get("declaration.declarations." + index);
!Array.isArray(declaration) && declaration && (declaration.remove(), removed[declarator.id.name] = !0);
}
});
}
});
} catch (error) {
var errorMessage2 = _instanceof(error, Error) ? error.message : String(error);
console.warn(`[one] Skipping tree shaking for ${id} due to traversal error:`, errorMessage2);
return;
}
var removedFunctions = Object.keys(removed).filter(function (key) {
return removed[key];
});
if (removedFunctions.length) try {
var typeImports = collectTypeImports(ast);
deadCodeElimination(ast, referenced), restoreTypeImports(ast, typeImports);
var out = generate(ast),
codeOut = out.code + `
` + removedFunctions.map(function (key) {
return key === "loader" ? EMPTY_LOADER_STRING : "export function generateStaticParams() {};";
}).join(`
`);
return console.info(` \u{1F9F9} [one] ${relative(process.cwd(), id)} removed ${removedFunctions.length} server-only exports`), {
code: codeOut,
map: out.map
};
} catch (error) {
var errorMessage3 = _instanceof(error, Error) ? error.message : String(error);
console.warn(`[one] Skipping tree shaking for ${id} due to code generation error:`, errorMessage3);
return;
}
}
}
export { clientTreeShakePlugin, transformTreeShakeClient };
//# sourceMappingURL=clientTreeShakePlugin.native.js.map