@lcap/nasl
Version:
NetEase Application Specific Language
107 lines • 4.07 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.upgrade = void 0;
const nasl = __importStar(require("@lcap/nasl"));
const excludedKeySet = new Set([
'parentNode',
'sourceMap',
'storageJSON',
'tsErrorDetail',
'NaslAnnotatedJSON',
'calledFrom',
'_events',
'_collectingList',
'_historyList',
]);
/**
* 升级要点:
* - 补充前端全局变量
* - 迁移绑定事件
* - 处理 scope 后缀
* - 处理 H5 loginButton 的特殊情况
* @param json 升级前的 JSON
* @returns 升级后的 JSON
*/
function upgrade(json) {
nasl.utils.traverse((current) => {
const { node, parent } = current;
// 原有枚举的处理
if (node.concept === 'Identifier' && node.namespace && node.namespace.endsWith('enums') && parent.concept !== 'MemberExpression') {
// 新增状态
node.concept = 'CallFunction';
node.label = '内置函数';
node.calleeNamespace = 'nasl.util';
node.calleeName = 'EnumToList';
node.typeArguments = [
{
concept: 'TypeAnnotation',
name: '',
typeKind: 'reference',
typeNamespace: node.namespace,
typeName: node.name,
},
];
node.arguments = [];
// 清除原来的状态
node.name = '';
delete node.namespace;
}
// 原有枚举的enum函数的处理
if (node.concept === 'CallFunction' && node.calleeName === 'Enum') {
const typeArgument = (node.arguments.splice(0, 1) || [])[0];
if (typeArgument && typeArgument.expression && typeArgument.expression.concept === 'StringLiteral' && typeArgument.expression.value) {
let typeNamespace = '';
let typeName = '';
const arr = typeArgument.expression.value.split('.');
if (arr?.length && arr.length > 0) {
typeName = arr.pop();
// 如果原来有名字而且没有typeNamespace, 就默认是app下的,
if (typeName) {
typeNamespace = arr.length ? arr.join('.') : 'app.enums';
}
}
node.calleeName = 'EnumItemToText';
node.typeArguments = [
{
concept: 'TypeAnnotation',
name: '',
typeNamespace,
typeName,
typeArguments: null,
returnType: null,
properties: null,
},
];
}
else {
node.typeArguments = [];
}
}
}, { node: json }, { mode: 'anyObject', depthFirst: true, excludedKeySet });
return json;
}
exports.upgrade = upgrade;
//# sourceMappingURL=2.18.js.map