|
|
@ -3,7 +3,8 @@ const path = require("path"); |
|
|
|
const prettier = require("prettier"); |
|
|
|
const prettier = require("prettier"); |
|
|
|
const { exec } = require("child_process"); |
|
|
|
const { exec } = require("child_process"); |
|
|
|
const { search, initDepts, depts } = require("./es6.xtype"); |
|
|
|
const { search, initDepts, depts } = require("./es6.xtype"); |
|
|
|
const _ = require("lodash"); |
|
|
|
const lodash = require("lodash"); |
|
|
|
|
|
|
|
const DEPTS = depts; |
|
|
|
|
|
|
|
|
|
|
|
// const XTYPE_ONLY = false;
|
|
|
|
// const XTYPE_ONLY = false;
|
|
|
|
// const THIS_REPLACE = false;
|
|
|
|
// const THIS_REPLACE = false;
|
|
|
@ -12,6 +13,10 @@ const ConflictImport = []; |
|
|
|
const CircularDependency = []; |
|
|
|
const CircularDependency = []; |
|
|
|
|
|
|
|
|
|
|
|
function objHaveFunction(obj) { |
|
|
|
function objHaveFunction(obj) { |
|
|
|
|
|
|
|
if (obj === null) { |
|
|
|
|
|
|
|
return false; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return Object.keys(obj).some(key => { |
|
|
|
return Object.keys(obj).some(key => { |
|
|
|
const value = obj[key]; |
|
|
|
const value = obj[key]; |
|
|
|
if (typeof value === "object") { |
|
|
|
if (typeof value === "object") { |
|
|
@ -32,10 +37,11 @@ function parserImport(code) { |
|
|
|
while (regResult) { |
|
|
|
while (regResult) { |
|
|
|
importMap[regResult[2]] = regResult[1] |
|
|
|
importMap[regResult[2]] = regResult[1] |
|
|
|
.split(",") |
|
|
|
.split(",") |
|
|
|
.map(el => el.trim()).filter(el => el); |
|
|
|
.map(el => el.trim()) |
|
|
|
|
|
|
|
.filter(el => el); |
|
|
|
regResult = reg.exec(code); |
|
|
|
regResult = reg.exec(code); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return importMap; |
|
|
|
return importMap; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -46,7 +52,7 @@ async function saveAndFixCode(path, code) { |
|
|
|
} |
|
|
|
} |
|
|
|
const prettierCode = prettier.format(_code, { |
|
|
|
const prettierCode = prettier.format(_code, { |
|
|
|
tabWidth: 4, |
|
|
|
tabWidth: 4, |
|
|
|
parser: 'babel', |
|
|
|
parser: "babel", |
|
|
|
printWidth: 120, |
|
|
|
printWidth: 120, |
|
|
|
}); |
|
|
|
}); |
|
|
|
fs.writeFileSync(path, prettierCode); |
|
|
|
fs.writeFileSync(path, prettierCode); |
|
|
@ -58,56 +64,18 @@ async function saveAndFixCode(path, code) { |
|
|
|
}); |
|
|
|
}); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const target = [ |
|
|
|
// const target = [];
|
|
|
|
"isNull", |
|
|
|
|
|
|
|
"toPix", |
|
|
|
|
|
|
|
"isKey", |
|
|
|
|
|
|
|
"isObject", |
|
|
|
|
|
|
|
"map", |
|
|
|
|
|
|
|
"extend", |
|
|
|
|
|
|
|
"isFunction", |
|
|
|
|
|
|
|
"isEmptyArray", |
|
|
|
|
|
|
|
"isArray", |
|
|
|
|
|
|
|
"Controller", |
|
|
|
|
|
|
|
"createWidget", |
|
|
|
|
|
|
|
"Events", |
|
|
|
|
|
|
|
"emptyFn", |
|
|
|
|
|
|
|
"nextTick", |
|
|
|
|
|
|
|
"bind", |
|
|
|
|
|
|
|
"i18nText", |
|
|
|
|
|
|
|
"isNotNull", |
|
|
|
|
|
|
|
"isString", |
|
|
|
|
|
|
|
"isNumber", |
|
|
|
|
|
|
|
"isEmpty", |
|
|
|
|
|
|
|
"isEmptyString", |
|
|
|
|
|
|
|
"any", |
|
|
|
|
|
|
|
"deepContains", |
|
|
|
|
|
|
|
"isNotEmptyString", |
|
|
|
|
|
|
|
"each", |
|
|
|
|
|
|
|
"contains", |
|
|
|
|
|
|
|
"remove", |
|
|
|
|
|
|
|
"createItems", |
|
|
|
|
|
|
|
"makeArrayByArray", |
|
|
|
|
|
|
|
"VerticalAlign", |
|
|
|
|
|
|
|
"pushDistinct", |
|
|
|
|
|
|
|
"endWith", |
|
|
|
|
|
|
|
"transformItems", |
|
|
|
|
|
|
|
"print", |
|
|
|
|
|
|
|
"Tree", |
|
|
|
|
|
|
|
"Func", |
|
|
|
|
|
|
|
"Selection", |
|
|
|
|
|
|
|
]; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 加载模块
|
|
|
|
// 加载模块
|
|
|
|
const loader = { |
|
|
|
const loader = { |
|
|
|
// G: { "@/core": { shortcut: true } },
|
|
|
|
// G: { "@/core": { shortcut: true } },
|
|
|
|
load(srcName, module) { |
|
|
|
load(srcName, module) { |
|
|
|
const G = loader.G; |
|
|
|
const G = loader.G; |
|
|
|
if (target.indexOf(module) >= 0) { |
|
|
|
// if (target.indexOf(module) >= 0) {
|
|
|
|
G["@/core"][module] = true; |
|
|
|
// G["@/core"][module] = true;
|
|
|
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
// return true;
|
|
|
|
} |
|
|
|
// }
|
|
|
|
if (module.startsWith('"bi.')) { |
|
|
|
if (module.startsWith('"bi.')) { |
|
|
|
const key = search(srcName, module); |
|
|
|
const key = search(srcName, module); |
|
|
|
if (key) { |
|
|
|
if (key) { |
|
|
@ -136,15 +104,16 @@ const loader = { |
|
|
|
async function handleFile(srcName) { |
|
|
|
async function handleFile(srcName) { |
|
|
|
await saveAndFixCode(srcName); |
|
|
|
await saveAndFixCode(srcName); |
|
|
|
// 全局状态回归
|
|
|
|
// 全局状态回归
|
|
|
|
let G = loader.G = { }; |
|
|
|
let G = (loader.G = {}); |
|
|
|
|
|
|
|
|
|
|
|
const sourceCode = fs.readFileSync(srcName).toString(); |
|
|
|
const sourceCode = fs.readFileSync(srcName).toString(); |
|
|
|
|
|
|
|
|
|
|
|
const result = /BI\.(.*?)\s=\sBI\.inherit\(/.exec(sourceCode); |
|
|
|
const result = /BI\.(.*?)\s=\sBI\.inherit\(/.exec(sourceCode); |
|
|
|
|
|
|
|
|
|
|
|
if (!result) { |
|
|
|
if (!result) { |
|
|
|
// console.log(`已经es6过,替换 xtype => ${srcName}`);
|
|
|
|
// console.log(`已经es6过,替换 xtype => ${srcName}`);
|
|
|
|
if (!/export class/.test(sourceCode)) { |
|
|
|
if (!/export class/.test(sourceCode)) { |
|
|
|
console.log("忽略文件", srcName); |
|
|
|
// console.log("忽略文件", srcName);
|
|
|
|
|
|
|
|
|
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
@ -165,9 +134,9 @@ async function handleFile(srcName) { |
|
|
|
}); |
|
|
|
}); |
|
|
|
// 识别 import
|
|
|
|
// 识别 import
|
|
|
|
const importMap = parserImport(noXtypeCode); |
|
|
|
const importMap = parserImport(noXtypeCode); |
|
|
|
|
|
|
|
|
|
|
|
// 合并原来的 import 到 G
|
|
|
|
// 合并原来的 import 到 G
|
|
|
|
_.forEach(importMap, (depts, module) => { |
|
|
|
lodash.forEach(importMap, (depts, module) => { |
|
|
|
depts.forEach(dept => { |
|
|
|
depts.forEach(dept => { |
|
|
|
if (!G[module]) { |
|
|
|
if (!G[module]) { |
|
|
|
G[module] = {}; |
|
|
|
G[module] = {}; |
|
|
@ -176,56 +145,113 @@ async function handleFile(srcName) { |
|
|
|
G[module][dept] = true; |
|
|
|
G[module][dept] = true; |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 合并 core
|
|
|
|
// 合并包
|
|
|
|
const crossPackages = fs.readdirSync("src"); |
|
|
|
const crossPackages = fs.readdirSync("src").map(el => `@/${el}`); |
|
|
|
_.forEach(G, (depts, module) => { |
|
|
|
lodash.forEach(G, (depts, module) => { |
|
|
|
crossPackages.forEach(crosspackage => { |
|
|
|
crossPackages.forEach(crosspackage => { |
|
|
|
if (module.indexOf(crosspackage) >= 0) { |
|
|
|
if (module.indexOf(crosspackage.replace(/^@\//, "")) >= 0) { |
|
|
|
if (!G[`@/${crosspackage}`]) { |
|
|
|
if (!G[crosspackage]) { |
|
|
|
G[`@/${crosspackage}`] = {}; |
|
|
|
G[crosspackage] = {}; |
|
|
|
} |
|
|
|
} |
|
|
|
Object.assign(G[`@/${crosspackage}`], depts); |
|
|
|
Object.assign(G[crosspackage], depts); |
|
|
|
} |
|
|
|
} |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const tmpG = {}; |
|
|
|
const tmpG = {}; |
|
|
|
_.forEach(G, (depts, module) => { |
|
|
|
lodash.forEach(G, (depts, module) => { |
|
|
|
const flag = _.some(crossPackages, crosspackage => module.indexOf(crosspackage) >= 0 && !module.startsWith("@")); |
|
|
|
const flag = lodash.some( |
|
|
|
|
|
|
|
crossPackages, |
|
|
|
|
|
|
|
crosspackage => |
|
|
|
|
|
|
|
module.indexOf(crosspackage) >= 0 && !module.startsWith("@"), |
|
|
|
|
|
|
|
); |
|
|
|
if (!flag) { |
|
|
|
if (!flag) { |
|
|
|
tmpG[module] = depts; |
|
|
|
tmpG[module] = depts; |
|
|
|
} |
|
|
|
} |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let circle = false; |
|
|
|
|
|
|
|
// 处理循环依赖,base: ["@/case", "@/base", "@/widget"] 等于 base 不能直接引数组内的包
|
|
|
|
|
|
|
|
const forbiddenCrossRules = { |
|
|
|
|
|
|
|
base: ["@/case", "@/base", "@/widget"], |
|
|
|
|
|
|
|
"case": ["@/case", "@/widget"], |
|
|
|
|
|
|
|
widget: ["@/widget"], |
|
|
|
|
|
|
|
component: ["@/component"], |
|
|
|
|
|
|
|
core: ["@/core", "@base", "@/widget", "@/case"], |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const forbiddenKeys = []; |
|
|
|
|
|
|
|
const circleG = {}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lodash.forEach(G, (depts, module) => { |
|
|
|
|
|
|
|
// 找出 rule
|
|
|
|
|
|
|
|
const packages = Object.keys(forbiddenCrossRules); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let key = packages.filter( |
|
|
|
|
|
|
|
_package => srcName.indexOf(_package) >= 0, |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
if (key.length !== 1) { |
|
|
|
|
|
|
|
throw new Error( |
|
|
|
|
|
|
|
"理论不可能出现这个问题,需要 treecat 优化下找包逻辑1", |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
key = key[0]; |
|
|
|
|
|
|
|
const rule = forbiddenCrossRules[key]; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (lodash.includes(rule, module)) { |
|
|
|
|
|
|
|
circle = true; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const deptsArr = Object.keys(depts); |
|
|
|
|
|
|
|
if (deptsArr.filter(dept => !DEPTS[dept]).length > 0) { |
|
|
|
|
|
|
|
throw new Error( |
|
|
|
|
|
|
|
"理论不可能出现这个问题,需要 treecat 优化下找包逻辑2", |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
deptsArr |
|
|
|
|
|
|
|
.filter(dept => DEPTS[dept]) |
|
|
|
|
|
|
|
.forEach(dept => { |
|
|
|
|
|
|
|
const value = `@${DEPTS[dept].replace(path.resolve("src"), "").replace(/\\/g, "/").replace(/\.js$/, "")}`; |
|
|
|
|
|
|
|
if (!tmpG[value]) { |
|
|
|
|
|
|
|
tmpG[value] = {}; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
tmpG[value][dept] = true; |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
forbiddenKeys.push(module); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
Object.assign(tmpG, circleG); |
|
|
|
|
|
|
|
forbiddenKeys.forEach(key => { |
|
|
|
|
|
|
|
delete tmpG[key]; |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 较验手工 import 错误
|
|
|
|
// 较验手工 import 错误
|
|
|
|
const map = {}; |
|
|
|
const map = {}; |
|
|
|
let conflict = false; |
|
|
|
let conflict = false; |
|
|
|
let circle = false; |
|
|
|
|
|
|
|
_.forEach(tmpG, (imports, fromStr) => { |
|
|
|
|
|
|
|
if (srcName.indexOf("base") >= 0) { |
|
|
|
|
|
|
|
if (fromStr === "@/case" || fromStr === "@/base") { |
|
|
|
|
|
|
|
circle = true; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_.forEach(imports, (bools, _import) => { |
|
|
|
lodash.forEach(tmpG, (depts, module) => { |
|
|
|
if (map[_import] && map[_import] !== fromStr) { |
|
|
|
lodash.forEach(depts, (_, _import) => { |
|
|
|
|
|
|
|
if (map[_import] && map[_import] !== module) { |
|
|
|
conflict = true; |
|
|
|
conflict = true; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
map[_import] = fromStr; |
|
|
|
map[_import] = module; |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
conflict && ConflictImport.push(srcName); |
|
|
|
conflict && ConflictImport.push(srcName); |
|
|
|
circle && CircularDependency.push(srcName); |
|
|
|
circle && CircularDependency.push(srcName); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
G = tmpG; |
|
|
|
G = tmpG; |
|
|
|
|
|
|
|
|
|
|
|
const noImportCode = noXtypeCode.replace(/import {([\s\S]*?)} from "(.*?)";/g, ""); |
|
|
|
const noImportCode = noXtypeCode.replace( |
|
|
|
|
|
|
|
/import {([\s\S]*?)} from "(.*?)";/g, |
|
|
|
|
|
|
|
"", |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
let I = ""; |
|
|
|
let I = ""; |
|
|
|
Object.keys(G).forEach(key => { |
|
|
|
Object.keys(G).forEach(key => { |
|
|
|
let moduleKey = key; |
|
|
|
let moduleKey = key; |
|
|
@ -236,14 +262,13 @@ async function handleFile(srcName) { |
|
|
|
Object.keys(G[moduleKey]).forEach(key => { |
|
|
|
Object.keys(G[moduleKey]).forEach(key => { |
|
|
|
i += `${key}, `; |
|
|
|
i += `${key}, `; |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
// 必须以 . 开头
|
|
|
|
// 必须以 . 开头
|
|
|
|
const moduleInValid = /^[^@.]/.test(moduleKey); |
|
|
|
const moduleInValid = /^[^@.]/.test(moduleKey); |
|
|
|
if (moduleInValid) { |
|
|
|
if (moduleInValid) { |
|
|
|
moduleKey = `./${moduleKey}`; |
|
|
|
moduleKey = `./${moduleKey}`; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
I += `import {${i}} from '${moduleKey}'\n`; |
|
|
|
I += `import {${i}} from '${moduleKey}'\n`; |
|
|
|
}); |
|
|
|
}); |
|
|
|
const code = `${I}\n${noImportCode}`; |
|
|
|
const code = `${I}\n${noImportCode}`; |
|
|
@ -255,17 +280,16 @@ async function handleFile(srcName) { |
|
|
|
|
|
|
|
|
|
|
|
G["@/core"] = { shortcut: true }; |
|
|
|
G["@/core"] = { shortcut: true }; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const clzName = result[1]; |
|
|
|
const clzName = result[1]; |
|
|
|
|
|
|
|
|
|
|
|
if (!clzName) { |
|
|
|
if (!clzName) { |
|
|
|
console.log(`${srcName} 不需要 es6 化`); |
|
|
|
console.log(`${srcName} 不需要 es6 化`); |
|
|
|
|
|
|
|
|
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const superName = /inherit\(BI\.(.*?),/.exec(sourceCode)[1]; |
|
|
|
const superName = /inherit\(BI\.(.*?),/.exec(sourceCode)[1]; |
|
|
|
|
|
|
|
|
|
|
|
// const xtype = /BI.shortcut\(\"(.*?)\"/.exec(sourceCode)[1];
|
|
|
|
// const xtype = /BI.shortcut\(\"(.*?)\"/.exec(sourceCode)[1];
|
|
|
|
|
|
|
|
|
|
|
|
const collection = { |
|
|
|
const collection = { |
|
|
@ -391,6 +415,10 @@ async function handleFile(srcName) { |
|
|
|
M += `${f}\n`; |
|
|
|
M += `${f}\n`; |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!collection.xtype) { |
|
|
|
|
|
|
|
delete G["@/core"].shortcut; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Object.keys(G).forEach(key => { |
|
|
|
Object.keys(G).forEach(key => { |
|
|
|
let moduleKey = key; |
|
|
|
let moduleKey = key; |
|
|
|
if (moduleKey === path.basename(srcName).replace(/.js$/g, "")) { |
|
|
|
if (moduleKey === path.basename(srcName).replace(/.js$/g, "")) { |
|
|
@ -413,9 +441,9 @@ async function handleFile(srcName) { |
|
|
|
const outputCode = ` |
|
|
|
const outputCode = ` |
|
|
|
${I} |
|
|
|
${I} |
|
|
|
|
|
|
|
|
|
|
|
@shortcut() |
|
|
|
${collection.xtype ? "@shortcut()" : ""} |
|
|
|
export class ${clzName} extends ${superName} { |
|
|
|
export class ${clzName} extends ${superName} { |
|
|
|
\tstatic xtype = "${collection.xtype}" |
|
|
|
${collection.xtype ? `static xtype = "${collection.xtype}"` : ""} |
|
|
|
|
|
|
|
|
|
|
|
${A} |
|
|
|
${A} |
|
|
|
|
|
|
|
|
|
|
@ -463,19 +491,6 @@ async function traverse(srcName) { |
|
|
|
const srcName = process.argv[2]; |
|
|
|
const srcName = process.argv[2]; |
|
|
|
|
|
|
|
|
|
|
|
initDepts().then(async () => { |
|
|
|
initDepts().then(async () => { |
|
|
|
const content = fs.readFileSync("src/core/2.base.js").toString(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let result = content.match(/export function (.*?)\(/g); |
|
|
|
|
|
|
|
target.push( |
|
|
|
|
|
|
|
...result.map(el => |
|
|
|
|
|
|
|
el.replace("export function ", "").replace("(", ""), |
|
|
|
|
|
|
|
), |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
result = content.match(/export const (.*?) =/g); |
|
|
|
|
|
|
|
target.push( |
|
|
|
|
|
|
|
...result.map(el => el.replace("export const ", "").replace(" =", "")), |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await traverse(srcName); |
|
|
|
await traverse(srcName); |
|
|
|
|
|
|
|
|
|
|
|
// 对数据处理
|
|
|
|
// 对数据处理
|
|
|
@ -483,6 +498,6 @@ initDepts().then(async () => { |
|
|
|
console.log(`导入冲突 ${el}`); |
|
|
|
console.log(`导入冲突 ${el}`); |
|
|
|
}); |
|
|
|
}); |
|
|
|
CircularDependency.forEach(el => { |
|
|
|
CircularDependency.forEach(el => { |
|
|
|
console.log(`出现循环依赖 ${el}`); |
|
|
|
console.log(`出现循环依赖(已经fixed) ${el}`); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|
}); |
|
|
|