@abaplint/cli 2.93.45 → 2.93.47
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cli.js +7 -7
- package/package.json +2 -2
package/build/cli.js
CHANGED
|
@@ -8761,7 +8761,7 @@ eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\n
|
|
|
8761
8761
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
8762
8762
|
|
|
8763
8763
|
"use strict";
|
|
8764
|
-
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.ExpressionNode = void 0;\r\nconst token_node_1 = __webpack_require__(/*! ./token_node */ \"./node_modules/@abaplint/core/build/src/abap/nodes/token_node.js\");\r\nconst tokens_1 = __webpack_require__(/*! ../1_lexer/tokens */ \"./node_modules/@abaplint/core/build/src/abap/1_lexer/tokens/index.js\");\r\nconst _abstract_node_1 = __webpack_require__(/*! ./_abstract_node */ \"./node_modules/@abaplint/core/build/src/abap/nodes/_abstract_node.js\");\r\nclass ExpressionNode extends _abstract_node_1.AbstractNode {\r\n constructor(expression) {\r\n super();\r\n this.expression = expression;\r\n }\r\n get() {\r\n return this.expression;\r\n }\r\n countTokens() {\r\n let ret = 0;\r\n for (const c of this.getChildren()) {\r\n ret = ret + c.countTokens();\r\n }\r\n return ret;\r\n }\r\n getFirstToken() {\r\n for (const child of this.getChildren()) {\r\n return child.getFirstToken();\r\n }\r\n throw new Error(\"ExpressionNode, getFirstToken, no children\");\r\n }\r\n concatTokens() {\r\n let str = \"\";\r\n let prev;\r\n for (const token of this.getTokens()) {\r\n if (token instanceof tokens_1.Pragma) {\r\n continue;\r\n }\r\n if (str === \"\") {\r\n str = token.getStr();\r\n }\r\n else if (prev && prev.getStr().length + prev.getCol() === token.getCol()\r\n && prev.getRow() === token.getRow()) {\r\n str = str + token.getStr();\r\n }\r\n else {\r\n str = str + \" \" + token.getStr();\r\n }\r\n prev = token;\r\n }\r\n return str;\r\n }\r\n concatTokensWithoutStringsAndComments() {\r\n let str = \"\";\r\n let prev;\r\n for (const token of this.getTokens()) {\r\n if (token instanceof tokens_1.Comment\r\n || token instanceof tokens_1.String\r\n || token instanceof tokens_1.StringTemplate\r\n || token instanceof tokens_1.StringTemplateBegin\r\n || token instanceof tokens_1.StringTemplateMiddle\r\n || token instanceof tokens_1.StringTemplateEnd) {\r\n continue;\r\n }\r\n if (str === \"\") {\r\n str = token.getStr();\r\n }\r\n else if (prev && prev.getStr().length + prev.getCol() === token.getCol()\r\n && prev.getRow() === token.getRow()) {\r\n str = str + token.getStr();\r\n }\r\n else {\r\n str = str + \" \" + token.getStr();\r\n }\r\n prev = token;\r\n }\r\n return str;\r\n }\r\n getTokens() {\r\n const tokens = [];\r\n for (const c of this.getChildren()) {\r\n tokens.push(...this.toTokens(c));\r\n }\r\n return tokens;\r\n }\r\n toTokens(b) {\r\n const tokens = [];\r\n if (b instanceof token_node_1.TokenNode) {\r\n tokens.push(b.get());\r\n return tokens;\r\n }\r\n for (const c of b.getChildren()) {\r\n if (c instanceof token_node_1.TokenNode) {\r\n tokens.push(c.get());\r\n }\r\n else {\r\n tokens.push(...this.toTokens(c));\r\n }\r\n }\r\n return tokens;\r\n }\r\n getLastToken() {\r\n const child = this.getLastChild();\r\n if (child) {\r\n return child.getLastToken();\r\n }\r\n throw new Error(\"ExpressionNode, getLastToken, no children\");\r\n }\r\n getAllTokens() {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n ret.push(child.get());\r\n }\r\n else {\r\n ret.push(...child.getAllTokens());\r\n }\r\n }\r\n return ret;\r\n }\r\n getDirectTokens() {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n ret.push(child.get());\r\n }\r\n }\r\n return ret;\r\n }\r\n findDirectExpression(type) {\r\n for (const child of this.getChildren()) {\r\n if (child instanceof ExpressionNode && child.get() instanceof type) {\r\n return child;\r\n }\r\n }\r\n return undefined;\r\n }\r\n findExpressionAfterToken(text) {\r\n const children = this.getChildren();\r\n for (let i = 0; i < children.length - 1; i++) {\r\n const c = children[i];\r\n const next = children[i + 1];\r\n if (c instanceof token_node_1.TokenNode\r\n && c.get().getStr().toUpperCase() === text.toUpperCase()\r\n && next instanceof ExpressionNode) {\r\n return next;\r\n }\r\n }\r\n return undefined;\r\n }\r\n findDirectExpressions(type) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof ExpressionNode && child.get() instanceof type) {\r\n ret.push(child);\r\n }\r\n }\r\n return ret;\r\n }\r\n findDirectTokenByText(text) {\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode && child.get().getStr().toUpperCase() === text.toUpperCase()) {\r\n return child.get();\r\n }\r\n }\r\n return undefined;\r\n }\r\n findAllExpressionsRecursive(type) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n else if (child.get() instanceof type) {\r\n ret.push(child);\r\n }\r\n ret.push(...child.findAllExpressionsRecursive(type));\r\n }\r\n return ret;\r\n }\r\n findAllExpressions(type) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n else if (child.get() instanceof type) {\r\n ret.push(child);\r\n }\r\n else {\r\n ret.push(...child.findAllExpressions(type));\r\n }\r\n }\r\n return ret;\r\n }\r\n findAllExpressionsMulti(type, recursive = false) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n const before = ret.length;\r\n for (const t of type) {\r\n if (child.get() instanceof t) {\r\n ret.push(child);\r\n }\r\n }\r\n if (before === ret.length || recursive === true) {\r\n ret.push(...child.findAllExpressionsMulti(type));\r\n }\r\n }\r\n return ret;\r\n }\r\n findFirstExpression(type) {\r\n if (this.get() instanceof type) {\r\n return this;\r\n }\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n else if (child.get() instanceof type) {\r\n return child;\r\n }\r\n else {\r\n const res = child.findFirstExpression(type);\r\n if (res) {\r\n return res;\r\n }\r\n }\r\n }\r\n return undefined;\r\n }\r\n}\r\nexports.ExpressionNode = ExpressionNode;\r\n//# sourceMappingURL=expression_node.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/abap/nodes/expression_node.js?");
|
|
8764
|
+
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.ExpressionNode = void 0;\r\nconst token_node_1 = __webpack_require__(/*! ./token_node */ \"./node_modules/@abaplint/core/build/src/abap/nodes/token_node.js\");\r\nconst tokens_1 = __webpack_require__(/*! ../1_lexer/tokens */ \"./node_modules/@abaplint/core/build/src/abap/1_lexer/tokens/index.js\");\r\nconst _abstract_node_1 = __webpack_require__(/*! ./_abstract_node */ \"./node_modules/@abaplint/core/build/src/abap/nodes/_abstract_node.js\");\r\nclass ExpressionNode extends _abstract_node_1.AbstractNode {\r\n constructor(expression) {\r\n super();\r\n this.expression = expression;\r\n }\r\n get() {\r\n return this.expression;\r\n }\r\n countTokens() {\r\n let ret = 0;\r\n for (const c of this.getChildren()) {\r\n ret = ret + c.countTokens();\r\n }\r\n return ret;\r\n }\r\n getFirstToken() {\r\n for (const child of this.getChildren()) {\r\n return child.getFirstToken();\r\n }\r\n throw new Error(\"ExpressionNode, getFirstToken, no children\");\r\n }\r\n concatTokens() {\r\n let str = \"\";\r\n let prev;\r\n for (const token of this.getTokens()) {\r\n if (token instanceof tokens_1.Pragma) {\r\n continue;\r\n }\r\n if (str === \"\") {\r\n str = token.getStr();\r\n }\r\n else if (prev && prev.getStr().length + prev.getCol() === token.getCol()\r\n && prev.getRow() === token.getRow()) {\r\n str = str + token.getStr();\r\n }\r\n else {\r\n str = str + \" \" + token.getStr();\r\n }\r\n prev = token;\r\n }\r\n return str;\r\n }\r\n concatTokensWithoutStringsAndComments() {\r\n let str = \"\";\r\n let prev;\r\n for (const token of this.getTokens()) {\r\n if (token instanceof tokens_1.Comment\r\n || token instanceof tokens_1.String\r\n || token instanceof tokens_1.StringTemplate\r\n || token instanceof tokens_1.StringTemplateBegin\r\n || token instanceof tokens_1.StringTemplateMiddle\r\n || token instanceof tokens_1.StringTemplateEnd) {\r\n continue;\r\n }\r\n if (str === \"\") {\r\n str = token.getStr();\r\n }\r\n else if (prev && prev.getStr().length + prev.getCol() === token.getCol()\r\n && prev.getRow() === token.getRow()) {\r\n str = str + token.getStr();\r\n }\r\n else {\r\n str = str + \" \" + token.getStr();\r\n }\r\n prev = token;\r\n }\r\n return str;\r\n }\r\n getTokens() {\r\n const tokens = [];\r\n for (const c of this.getChildren()) {\r\n tokens.push(...this.toTokens(c));\r\n }\r\n return tokens;\r\n }\r\n toTokens(b) {\r\n const tokens = [];\r\n if (b instanceof token_node_1.TokenNode) {\r\n tokens.push(b.get());\r\n return tokens;\r\n }\r\n for (const c of b.getChildren()) {\r\n if (c instanceof token_node_1.TokenNode) {\r\n tokens.push(c.get());\r\n }\r\n else {\r\n tokens.push(...this.toTokens(c));\r\n }\r\n }\r\n return tokens;\r\n }\r\n getLastToken() {\r\n const child = this.getLastChild();\r\n if (child) {\r\n return child.getLastToken();\r\n }\r\n throw new Error(\"ExpressionNode, getLastToken, no children\");\r\n }\r\n getAllTokens() {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n ret.push(child.get());\r\n }\r\n else {\r\n ret.push(...child.getAllTokens());\r\n }\r\n }\r\n return ret;\r\n }\r\n getDirectTokens() {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n ret.push(child.get());\r\n }\r\n }\r\n return ret;\r\n }\r\n findDirectExpression(type) {\r\n for (const child of this.getChildren()) {\r\n if (child instanceof ExpressionNode && child.get() instanceof type) {\r\n return child;\r\n }\r\n }\r\n return undefined;\r\n }\r\n findExpressionAfterToken(text) {\r\n const children = this.getChildren();\r\n for (let i = 0; i < children.length - 1; i++) {\r\n const c = children[i];\r\n const next = children[i + 1];\r\n if (c instanceof token_node_1.TokenNode\r\n && c.get().getStr().toUpperCase() === text.toUpperCase()\r\n && next instanceof ExpressionNode) {\r\n return next;\r\n }\r\n }\r\n return undefined;\r\n }\r\n findDirectExpressions(type) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof ExpressionNode && child.get() instanceof type) {\r\n ret.push(child);\r\n }\r\n }\r\n return ret;\r\n }\r\n findDirectTokenByText(text) {\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode && child.get().getStr().toUpperCase() === text.toUpperCase()) {\r\n return child.get();\r\n }\r\n }\r\n return undefined;\r\n }\r\n findAllExpressionsRecursive(type) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n else if (child.get() instanceof type) {\r\n ret.push(child);\r\n }\r\n ret.push(...child.findAllExpressionsRecursive(type));\r\n }\r\n return ret;\r\n }\r\n findAllExpressions(type) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n else if (child.get() instanceof type) {\r\n ret.push(child);\r\n }\r\n else {\r\n ret.push(...child.findAllExpressions(type));\r\n }\r\n }\r\n return ret;\r\n }\r\n findAllExpressionsMulti(type, recursive = false) {\r\n const ret = [];\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n const before = ret.length;\r\n for (const t of type) {\r\n if (child.get() instanceof t) {\r\n ret.push(child);\r\n }\r\n }\r\n if (before === ret.length || recursive === true) {\r\n ret.push(...child.findAllExpressionsMulti(type, recursive));\r\n }\r\n }\r\n return ret;\r\n }\r\n findFirstExpression(type) {\r\n if (this.get() instanceof type) {\r\n return this;\r\n }\r\n for (const child of this.getChildren()) {\r\n if (child instanceof token_node_1.TokenNode) {\r\n continue;\r\n }\r\n else if (child.get() instanceof type) {\r\n return child;\r\n }\r\n else {\r\n const res = child.findFirstExpression(type);\r\n if (res) {\r\n return res;\r\n }\r\n }\r\n }\r\n return undefined;\r\n }\r\n}\r\nexports.ExpressionNode = ExpressionNode;\r\n//# sourceMappingURL=expression_node.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/abap/nodes/expression_node.js?");
|
|
8765
8765
|
|
|
8766
8766
|
/***/ }),
|
|
8767
8767
|
|
|
@@ -10664,7 +10664,7 @@ eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\n
|
|
|
10664
10664
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
10665
10665
|
|
|
10666
10666
|
"use strict";
|
|
10667
|
-
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.FunctionGroup = void 0;\r\nconst _abap_object_1 = __webpack_require__(/*! ./_abap_object */ \"./node_modules/@abaplint/core/build/src/objects/_abap_object.js\");\r\nconst types_1 = __webpack_require__(/*! ../abap/types */ \"./node_modules/@abaplint/core/build/src/abap/types/index.js\");\r\nconst xml_utils_1 = __webpack_require__(/*! ../xml_utils */ \"./node_modules/@abaplint/core/build/src/xml_utils.js\");\r\nconst fast_xml_parser_1 = __webpack_require__(/*! fast-xml-parser */ \"./node_modules/fast-xml-parser/src/fxp.js\");\r\nclass FunctionGroup extends _abap_object_1.ABAPObject {\r\n constructor() {\r\n super(...arguments);\r\n this.includes = undefined;\r\n this.modules = undefined;\r\n }\r\n getType() {\r\n return \"FUGR\";\r\n }\r\n getDescription() {\r\n // todo\r\n return undefined;\r\n }\r\n setDirty() {\r\n super.setDirty();\r\n this.includes = undefined;\r\n this.modules = undefined;\r\n }\r\n getAllowedNaming() {\r\n return {\r\n maxLength: 26,\r\n allowNamespace: true,\r\n };\r\n }\r\n getSequencedFiles() {\r\n const main = this.getMainABAPFile();\r\n if (main === undefined) {\r\n return [];\r\n }\r\n const sequence = [main];\r\n for (const m of this.getModules()) {\r\n const search = \".\" + m.getName().toLocaleLowerCase() + \".abap\";\r\n for (const f of this.getABAPFiles()) {\r\n if (f.getFilename().toLocaleLowerCase().endsWith(search)) {\r\n if (sequence.indexOf(f) < 0) {\r\n sequence.push(f);\r\n }\r\n break;\r\n }\r\n }\r\n }\r\n return sequence;\r\n }\r\n getModules() {\r\n if (this.modules === undefined) {\r\n this.parseXML();\r\n }\r\n if (this.modules === undefined) {\r\n throw new Error(\"getIncludes, undefined\");\r\n }\r\n return this.modules;\r\n }\r\n getIncludeFiles() {\r\n const ret = [];\r\n const includes = this.getIncludes();\r\n for (const f of this.getABAPFiles()) {\r\n for (const i of includes) {\r\n const namespaced = i.startsWith(\"/\") && i.includes(\"/L\");\r\n let search = i;\r\n if (namespaced) {\r\n search = search.replace(/\\//g, \"#\");\r\n }\r\n if ((i.startsWith(\"L\") || namespaced) && f.getFilename().includes(search.toLowerCase())) {\r\n ret.push({ file: f, name: i });\r\n }\r\n // fix for URL encoded? Uris\r\n if (namespaced) {\r\n search = i.replace(/\\//g, \"%23\");\r\n if (f.getFilename().includes(search.toLowerCase())) {\r\n ret.push({ file: f, name: i });\r\n }\r\n }\r\n }\r\n }\r\n return ret;\r\n }\r\n getInclude(name) {\r\n const upper = name.toUpperCase();\r\n const includes = this.getIncludeFiles();\r\n for (const i of includes) {\r\n if (i.name.toUpperCase() === upper) {\r\n return i.file;\r\n }\r\n }\r\n return undefined;\r\n }\r\n getMainABAPFile() {\r\n const regex = new RegExp(/\\.fugr\\.(#\\w+#)?sapl/, \"i\");\r\n for (const f of this.getABAPFiles()) {\r\n if (regex.test(f.getFilename())) {\r\n return f;\r\n }\r\n }\r\n return undefined;\r\n }\r\n getIncludes() {\r\n if (this.includes === undefined) {\r\n this.parseXML();\r\n }\r\n if (this.includes === undefined) {\r\n throw new Error(\"getIncludes, undefined\");\r\n }\r\n return this.includes;\r\n }\r\n getModule(name) {\r\n for (const mod of this.getModules()) {\r\n if (mod.getName().toUpperCase() === name.toUpperCase()) {\r\n return mod;\r\n }\r\n }\r\n return undefined;\r\n }\r\n getTexts() {\r\n if (this.texts === undefined) {\r\n const found = this.findTextFile();\r\n if (found === undefined) {\r\n return {};\r\n }\r\n const parsed = new fast_xml_parser_1.XMLParser({ parseTagValue: false, ignoreAttributes: true, trimValues: false }).parse(found.getRaw());\r\n this.findTexts(parsed);\r\n }\r\n return this.texts;\r\n }\r\n /////////////////////////////////\r\n parseXML() {\r\n var _a, _b;\r\n this.includes = [];\r\n this.modules = [];\r\n const parsed = this.parseRaw2();\r\n if (parsed === undefined) {\r\n return;\r\n }\r\n // INCLUDES\r\n const includes = (_a = parsed.abapGit[\"asx:abap\"][\"asx:values\"]) === null || _a === void 0 ? void 0 : _a.INCLUDES;\r\n if (includes !== undefined) {\r\n for (const i of (0, xml_utils_1.xmlToArray)(includes.SOBJ_NAME)) {\r\n this.includes.push(i);\r\n }\r\n }\r\n // FUNCTION MODULES\r\n const functions = (_b = parsed.abapGit[\"asx:abap\"][\"asx:values\"]) === null || _b === void 0 ? void 0 : _b.FUNCTIONS;\r\n for (const module of (0, xml_utils_1.xmlToArray)(functions === null || functions === void 0 ? void 0 : functions.item)) {\r\n this.modules.push(new types_1.FunctionModuleDefinition(module));\r\n }\r\n }\r\n findTextFile() {\r\n const search = this.getName() + \".fugr.sapl\" + this.getName() + \".xml\";\r\n for (const f of this.getFiles()) {\r\n if (f.getFilename().includes(search.toLowerCase())) {\r\n return f;\r\n }\r\n }\r\n return undefined;\r\n }\r\n}\r\nexports.FunctionGroup = FunctionGroup;\r\n//# sourceMappingURL=function_group.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/objects/function_group.js?");
|
|
10667
|
+
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.FunctionGroup = void 0;\r\nconst _abap_object_1 = __webpack_require__(/*! ./_abap_object */ \"./node_modules/@abaplint/core/build/src/objects/_abap_object.js\");\r\nconst types_1 = __webpack_require__(/*! ../abap/types */ \"./node_modules/@abaplint/core/build/src/abap/types/index.js\");\r\nconst xml_utils_1 = __webpack_require__(/*! ../xml_utils */ \"./node_modules/@abaplint/core/build/src/xml_utils.js\");\r\nconst fast_xml_parser_1 = __webpack_require__(/*! fast-xml-parser */ \"./node_modules/fast-xml-parser/src/fxp.js\");\r\nclass FunctionGroup extends _abap_object_1.ABAPObject {\r\n constructor() {\r\n super(...arguments);\r\n this.includes = undefined;\r\n this.modules = undefined;\r\n }\r\n getType() {\r\n return \"FUGR\";\r\n }\r\n getDescription() {\r\n // todo\r\n return undefined;\r\n }\r\n setDirty() {\r\n super.setDirty();\r\n this.includes = undefined;\r\n this.modules = undefined;\r\n }\r\n getAllowedNaming() {\r\n return {\r\n maxLength: 26,\r\n allowNamespace: true,\r\n };\r\n }\r\n getSequencedFiles() {\r\n const main = this.getMainABAPFile();\r\n if (main === undefined) {\r\n return [];\r\n }\r\n const sequence = [main];\r\n for (const m of this.getModules()) {\r\n const search = \".\" + m.getName().toLocaleLowerCase().replace(/\\//g, \"#\") + \".abap\";\r\n for (const f of this.getABAPFiles()) {\r\n if (f.getFilename().toLocaleLowerCase().endsWith(search)) {\r\n if (sequence.indexOf(f) < 0) {\r\n sequence.push(f);\r\n }\r\n break;\r\n }\r\n }\r\n }\r\n return sequence;\r\n }\r\n getModules() {\r\n if (this.modules === undefined) {\r\n this.parseXML();\r\n }\r\n if (this.modules === undefined) {\r\n throw new Error(\"getIncludes, undefined\");\r\n }\r\n return this.modules;\r\n }\r\n getIncludeFiles() {\r\n const ret = [];\r\n const includes = this.getIncludes();\r\n for (const f of this.getABAPFiles()) {\r\n for (const i of includes) {\r\n const namespaced = i.startsWith(\"/\") && i.includes(\"/L\");\r\n let search = i;\r\n if (namespaced) {\r\n search = search.replace(/\\//g, \"#\");\r\n }\r\n if ((i.startsWith(\"L\") || namespaced) && f.getFilename().includes(search.toLowerCase())) {\r\n ret.push({ file: f, name: i });\r\n }\r\n // fix for URL encoded? Uris\r\n if (namespaced) {\r\n search = i.replace(/\\//g, \"%23\");\r\n if (f.getFilename().includes(search.toLowerCase())) {\r\n ret.push({ file: f, name: i });\r\n }\r\n }\r\n }\r\n }\r\n return ret;\r\n }\r\n getInclude(name) {\r\n const upper = name.toUpperCase();\r\n const includes = this.getIncludeFiles();\r\n for (const i of includes) {\r\n if (i.name.toUpperCase() === upper) {\r\n return i.file;\r\n }\r\n }\r\n return undefined;\r\n }\r\n getMainABAPFile() {\r\n const regex = new RegExp(/\\.fugr\\.(#\\w+#)?sapl/, \"i\");\r\n for (const f of this.getABAPFiles()) {\r\n if (regex.test(f.getFilename())) {\r\n return f;\r\n }\r\n }\r\n return undefined;\r\n }\r\n getIncludes() {\r\n if (this.includes === undefined) {\r\n this.parseXML();\r\n }\r\n if (this.includes === undefined) {\r\n throw new Error(\"getIncludes, undefined\");\r\n }\r\n return this.includes;\r\n }\r\n getModule(name) {\r\n for (const mod of this.getModules()) {\r\n if (mod.getName().toUpperCase() === name.toUpperCase()) {\r\n return mod;\r\n }\r\n }\r\n return undefined;\r\n }\r\n getTexts() {\r\n if (this.texts === undefined) {\r\n const found = this.findTextFile();\r\n if (found === undefined) {\r\n return {};\r\n }\r\n const parsed = new fast_xml_parser_1.XMLParser({ parseTagValue: false, ignoreAttributes: true, trimValues: false }).parse(found.getRaw());\r\n this.findTexts(parsed);\r\n }\r\n return this.texts;\r\n }\r\n /////////////////////////////////\r\n parseXML() {\r\n var _a, _b;\r\n this.includes = [];\r\n this.modules = [];\r\n const parsed = this.parseRaw2();\r\n if (parsed === undefined) {\r\n return;\r\n }\r\n // INCLUDES\r\n const includes = (_a = parsed.abapGit[\"asx:abap\"][\"asx:values\"]) === null || _a === void 0 ? void 0 : _a.INCLUDES;\r\n if (includes !== undefined) {\r\n for (const i of (0, xml_utils_1.xmlToArray)(includes.SOBJ_NAME)) {\r\n this.includes.push(i);\r\n }\r\n }\r\n // FUNCTION MODULES\r\n const functions = (_b = parsed.abapGit[\"asx:abap\"][\"asx:values\"]) === null || _b === void 0 ? void 0 : _b.FUNCTIONS;\r\n for (const module of (0, xml_utils_1.xmlToArray)(functions === null || functions === void 0 ? void 0 : functions.item)) {\r\n this.modules.push(new types_1.FunctionModuleDefinition(module));\r\n }\r\n }\r\n findTextFile() {\r\n const search = this.getName() + \".fugr.sapl\" + this.getName() + \".xml\";\r\n for (const f of this.getFiles()) {\r\n if (f.getFilename().includes(search.toLowerCase())) {\r\n return f;\r\n }\r\n }\r\n return undefined;\r\n }\r\n}\r\nexports.FunctionGroup = FunctionGroup;\r\n//# sourceMappingURL=function_group.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/objects/function_group.js?");
|
|
10668
10668
|
|
|
10669
10669
|
/***/ }),
|
|
10670
10670
|
|
|
@@ -11456,7 +11456,7 @@ eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\n
|
|
|
11456
11456
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
11457
11457
|
|
|
11458
11458
|
"use strict";
|
|
11459
|
-
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.Indent = void 0;\r\nconst Statements = __webpack_require__(/*! ../abap/2_statements/statements */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/index.js\");\r\nconst Expressions = __webpack_require__(/*! ../abap/2_statements/expressions */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/expressions/index.js\");\r\nconst _statement_1 = __webpack_require__(/*! ../abap/2_statements/statements/_statement */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/_statement.js\");\r\nconst position_1 = __webpack_require__(/*! ../position */ \"./node_modules/@abaplint/core/build/src/position.js\");\r\n// todo, will break if there is multiple statements per line?\r\nclass Indent {\r\n constructor(options) {\r\n this.globalClasses = new Set();\r\n this.options = options || {};\r\n }\r\n execute(original, modified) {\r\n const statements = original.getStatements();\r\n const expected = this.getExpectedIndents(original);\r\n const lines = modified.split(\"\\n\");\r\n for (const statement of statements) {\r\n if (statement.getFirstToken().getStart() instanceof position_1.VirtualPosition) {\r\n continue; // macro contents\r\n }\r\n const exp = expected.shift();\r\n if (exp === undefined || exp < 0) {\r\n continue;\r\n }\r\n const row = statement.getFirstToken().getStart().getRow() - 1;\r\n lines[row] = lines[row].trim();\r\n for (let i = 1; i < exp; i++) {\r\n lines[row] = \" \" + lines[row];\r\n }\r\n }\r\n return lines.join(\"\\n\");\r\n }\r\n // returns list of expected indentation for each line/statement?\r\n getExpectedIndents(file) {\r\n const ret = [];\r\n const init = 1;\r\n const stack = new Stack();\r\n let indent = init;\r\n let parentIsEvent = false;\r\n let previousStatement = undefined;\r\n for (const statement of file.getStatements()) {\r\n if (statement.getFirstToken().getStart() instanceof position_1.VirtualPosition) {\r\n continue; // skip macro contents\r\n }\r\n const type = statement.get();\r\n if (type instanceof Statements.EndIf\r\n || type instanceof Statements.EndWhile\r\n || type instanceof Statements.EndModule\r\n || type instanceof Statements.EndSelect\r\n || type instanceof Statements.EndMethod\r\n || type instanceof Statements.EndAt\r\n || type instanceof Statements.Else\r\n || type instanceof Statements.EndExec\r\n || type instanceof Statements.EndOfDefinition\r\n || type instanceof Statements.EndLoop\r\n || type instanceof Statements.EndTestInjection\r\n || type instanceof Statements.EndTestSeam\r\n || type instanceof Statements.EndForm\r\n || type instanceof Statements.EndCatch\r\n || (this.options.selectionScreenBlockIndentation === true\r\n && type instanceof Statements.SelectionScreen\r\n && (statement.concatTokens().toUpperCase().includes(\"END OF SCREEN\") ||\r\n statement.concatTokens().toUpperCase().includes(\"END OF BLOCK\") ||\r\n statement.concatTokens().toUpperCase().includes(\"END OF LINE\")))\r\n || type instanceof Statements.ElseIf\r\n || type instanceof Statements.EndFunction\r\n || type instanceof Statements.EndInterface\r\n || type instanceof Statements.EndDo) {\r\n indent = indent - 2;\r\n }\r\n else if (type instanceof Statements.StartOfSelection\r\n || type instanceof Statements.AtSelectionScreen\r\n || type instanceof Statements.AtLineSelection\r\n || type instanceof Statements.Initialization\r\n || type instanceof Statements.AtUserCommand\r\n || type instanceof Statements.TopOfPage\r\n || type instanceof Statements.EndOfSelection\r\n || type instanceof Statements.LoadOfProgram) {\r\n indent = init;\r\n parentIsEvent = true;\r\n }\r\n else if (type instanceof Statements.Form\r\n || (type instanceof Statements.Include && parentIsEvent)\r\n || type instanceof Statements.Module\r\n || type instanceof Statements.ClassImplementation\r\n || type instanceof Statements.ClassDefinition) {\r\n indent = init;\r\n parentIsEvent = false;\r\n }\r\n else if (type instanceof Statements.Cleanup\r\n || type instanceof Statements.Catch) {\r\n indent = stack.peek() - 2;\r\n }\r\n else if (type instanceof Statements.Public\r\n || type instanceof Statements.Protected\r\n || type instanceof Statements.Private\r\n || type instanceof Statements.WhenType\r\n || type instanceof Statements.WhenOthers\r\n || type instanceof Statements.When) {\r\n indent = stack.peek();\r\n }\r\n else if (type instanceof Statements.EndTry) {\r\n indent = stack.pop() - (this.options.alignTryCatch ? 2 : 4);\r\n }\r\n else if (type instanceof Statements.EndClass\r\n || type instanceof Statements.EndCase) {\r\n indent = stack.pop() - 2;\r\n indent = Math.max(indent, init); // maybe move this out of switch before ret.push(indent)\r\n }\r\n else if (type instanceof _statement_1.Comment\r\n || type instanceof Statements.IncludeType\r\n || type instanceof _statement_1.Empty\r\n || type instanceof _statement_1.MacroContent) {\r\n ret.push(-1);\r\n previousStatement = statement;\r\n continue;\r\n }\r\n if (previousStatement\r\n && !(previousStatement.get() instanceof _statement_1.Comment)\r\n && previousStatement.getLastToken().getEnd().getRow() === statement.getFirstToken().getStart().getRow()) {\r\n // any indentation allowed if there are multiple statements on the same line\r\n ret.push(-1);\r\n previousStatement = statement;\r\n continue;\r\n }\r\n ret.push(indent);\r\n if (type instanceof Statements.If\r\n || type instanceof Statements.While\r\n || type instanceof Statements.Module\r\n || type instanceof Statements.SelectLoop\r\n || type instanceof Statements.FunctionModule\r\n || type instanceof Statements.Interface\r\n || type instanceof Statements.Do\r\n || type instanceof Statements.At\r\n || type instanceof Statements.ExecSQL\r\n || type instanceof Statements.Catch\r\n || type instanceof Statements.Define\r\n || type instanceof Statements.When\r\n || type instanceof Statements.WhenType\r\n || type instanceof Statements.WhenOthers\r\n || type instanceof Statements.Cleanup\r\n || type instanceof Statements.Loop\r\n || type instanceof Statements.LoopAtScreen\r\n || type instanceof Statements.CatchSystemExceptions\r\n || type instanceof Statements.Form\r\n || type instanceof Statements.Else\r\n || type instanceof Statements.ElseIf\r\n || type instanceof Statements.MethodImplementation\r\n || type instanceof Statements.TestInjection\r\n || type instanceof Statements.TestSeam\r\n || (this.options.selectionScreenBlockIndentation === true\r\n && type instanceof Statements.SelectionScreen\r\n && (statement.concatTokens().toUpperCase().includes(\"BEGIN OF SCREEN\") ||\r\n statement.concatTokens().toUpperCase().includes(\"BEGIN OF TABBED BLOCK\") ||\r\n statement.concatTokens().toUpperCase().includes(\"BEGIN OF BLOCK\") ||\r\n statement.concatTokens().toUpperCase().includes(\"BEGIN OF LINE\")))\r\n || type instanceof Statements.StartOfSelection\r\n || type instanceof Statements.AtSelectionScreen\r\n || type instanceof Statements.AtLineSelection\r\n || type instanceof Statements.LoadOfProgram\r\n || type instanceof Statements.Initialization\r\n || type instanceof Statements.AtUserCommand\r\n || type instanceof Statements.TopOfPage\r\n || type instanceof Statements.EndOfSelection\r\n || type instanceof Statements.Public\r\n || type instanceof Statements.Protected\r\n || type instanceof Statements.Private) {\r\n indent = indent + 2;\r\n }\r\n else if (type instanceof Statements.Try) {\r\n indent = indent + (this.options.alignTryCatch ? 2 : 4);\r\n stack.push(indent);\r\n }\r\n else if (type instanceof Statements.ClassDefinition\r\n || type instanceof Statements.Case\r\n || type instanceof Statements.CaseType\r\n || type instanceof Statements.ClassImplementation) {\r\n indent = indent + (this.skipIndentForGlobalClass(statement) ? 0 : 2);\r\n stack.push(indent);\r\n }\r\n previousStatement = statement;\r\n }\r\n return ret;\r\n }\r\n skipIndentForGlobalClass(statement) {\r\n if (!this.options.globalClassSkipFirst) {\r\n return false;\r\n }\r\n const type = statement.get();\r\n if (type instanceof Statements.ClassDefinition && statement.findFirstExpression(Expressions.ClassGlobal)) {\r\n const className = statement.findFirstExpression(Expressions.ClassName);\r\n if (className) {\r\n this.globalClasses.add(className.getFirstToken().getStr().toUpperCase());\r\n }\r\n return true;\r\n }\r\n else if (type instanceof Statements.ClassImplementation) {\r\n const className = statement.findFirstExpression(Expressions.ClassName);\r\n if (className && this.globalClasses.has(className.getFirstToken().getStr().toUpperCase())) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n}\r\nexports.Indent = Indent;\r\nclass Stack {\r\n constructor() {\r\n this.items = [];\r\n }\r\n push(item) {\r\n this.items.push(item);\r\n }\r\n peek() {\r\n return this.items[this.items.length - 1];\r\n }\r\n pop() {\r\n const peek = this.peek();\r\n this.items = this.items.slice(0, this.items.length - 1);\r\n return peek;\r\n }\r\n}\r\n//# sourceMappingURL=indent.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/pretty_printer/indent.js?");
|
|
11459
|
+
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.Indent = void 0;\r\nconst Statements = __webpack_require__(/*! ../abap/2_statements/statements */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/index.js\");\r\nconst Expressions = __webpack_require__(/*! ../abap/2_statements/expressions */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/expressions/index.js\");\r\nconst _statement_1 = __webpack_require__(/*! ../abap/2_statements/statements/_statement */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/_statement.js\");\r\nconst position_1 = __webpack_require__(/*! ../position */ \"./node_modules/@abaplint/core/build/src/position.js\");\r\n// todo, will break if there is multiple statements per line?\r\nclass Indent {\r\n constructor(options) {\r\n this.globalClasses = new Set();\r\n this.options = options || {};\r\n }\r\n execute(original, modified) {\r\n const statements = original.getStatements();\r\n const expected = this.getExpectedIndents(original);\r\n const lines = modified.split(\"\\n\");\r\n for (const statement of statements) {\r\n if (statement.getFirstToken().getStart() instanceof position_1.VirtualPosition) {\r\n continue; // macro contents\r\n }\r\n const exp = expected.shift();\r\n if (exp === undefined || exp < 0) {\r\n continue;\r\n }\r\n const row = statement.getFirstToken().getStart().getRow() - 1;\r\n lines[row] = lines[row].trim();\r\n for (let i = 1; i < exp; i++) {\r\n lines[row] = \" \" + lines[row];\r\n }\r\n }\r\n return lines.join(\"\\n\");\r\n }\r\n // returns list of expected indentation for each line/statement?\r\n getExpectedIndents(file) {\r\n const ret = [];\r\n const init = 1;\r\n const stack = new Stack();\r\n let indent = init;\r\n let parentIsEvent = false;\r\n let previousStatement = undefined;\r\n for (const statement of file.getStatements()) {\r\n if (statement.getFirstToken().getStart() instanceof position_1.VirtualPosition) {\r\n continue; // skip macro contents\r\n }\r\n const type = statement.get();\r\n if (type instanceof Statements.EndIf\r\n || type instanceof Statements.EndWhile\r\n || type instanceof Statements.EndModule\r\n || type instanceof Statements.EndSelect\r\n || type instanceof Statements.EndMethod\r\n || type instanceof Statements.EndAt\r\n || type instanceof Statements.Else\r\n || type instanceof Statements.EndExec\r\n || type instanceof Statements.EndOfDefinition\r\n || type instanceof Statements.EndLoop\r\n || type instanceof Statements.EndTestInjection\r\n || type instanceof Statements.EndTestSeam\r\n || type instanceof Statements.EndForm\r\n || type instanceof Statements.EndCatch\r\n || (this.options.selectionScreenBlockIndentation === true\r\n && type instanceof Statements.SelectionScreen\r\n && (statement.concatTokens().toUpperCase().includes(\"END OF SCREEN\") ||\r\n statement.concatTokens().toUpperCase().includes(\"END OF BLOCK\") ||\r\n statement.concatTokens().toUpperCase().includes(\"END OF LINE\")))\r\n || type instanceof Statements.ElseIf\r\n || type instanceof Statements.EndFunction\r\n || type instanceof Statements.EndInterface\r\n || type instanceof Statements.EndDo) {\r\n indent = indent - 2;\r\n }\r\n else if (type instanceof Statements.StartOfSelection\r\n || type instanceof Statements.AtSelectionScreen\r\n || type instanceof Statements.AtLineSelection\r\n || type instanceof Statements.Initialization\r\n || type instanceof Statements.AtUserCommand\r\n || type instanceof Statements.TopOfPage\r\n || type instanceof Statements.Get\r\n || type instanceof Statements.EndOfSelection\r\n || type instanceof Statements.LoadOfProgram) {\r\n indent = init;\r\n parentIsEvent = true;\r\n }\r\n else if (type instanceof Statements.Form\r\n || (type instanceof Statements.Include && parentIsEvent)\r\n || type instanceof Statements.Module\r\n || type instanceof Statements.ClassImplementation\r\n || type instanceof Statements.ClassDefinition) {\r\n indent = init;\r\n parentIsEvent = false;\r\n }\r\n else if (type instanceof Statements.Cleanup\r\n || type instanceof Statements.Catch) {\r\n indent = stack.peek() - 2;\r\n }\r\n else if (type instanceof Statements.Public\r\n || type instanceof Statements.Protected\r\n || type instanceof Statements.Private\r\n || type instanceof Statements.WhenType\r\n || type instanceof Statements.WhenOthers\r\n || type instanceof Statements.When) {\r\n indent = stack.peek();\r\n }\r\n else if (type instanceof Statements.EndTry) {\r\n indent = stack.pop() - (this.options.alignTryCatch ? 2 : 4);\r\n }\r\n else if (type instanceof Statements.EndClass\r\n || type instanceof Statements.EndCase) {\r\n indent = stack.pop() - 2;\r\n indent = Math.max(indent, init); // maybe move this out of switch before ret.push(indent)\r\n }\r\n else if (type instanceof _statement_1.Comment\r\n || type instanceof Statements.IncludeType\r\n || type instanceof _statement_1.Empty\r\n || type instanceof _statement_1.MacroContent) {\r\n ret.push(-1);\r\n previousStatement = statement;\r\n continue;\r\n }\r\n if (previousStatement\r\n && !(previousStatement.get() instanceof _statement_1.Comment)\r\n && previousStatement.getLastToken().getEnd().getRow() === statement.getFirstToken().getStart().getRow()) {\r\n // any indentation allowed if there are multiple statements on the same line\r\n ret.push(-1);\r\n previousStatement = statement;\r\n continue;\r\n }\r\n ret.push(indent);\r\n if (type instanceof Statements.If\r\n || type instanceof Statements.While\r\n || type instanceof Statements.Module\r\n || type instanceof Statements.SelectLoop\r\n || type instanceof Statements.FunctionModule\r\n || type instanceof Statements.Interface\r\n || type instanceof Statements.Do\r\n || type instanceof Statements.At\r\n || type instanceof Statements.ExecSQL\r\n || type instanceof Statements.Catch\r\n || type instanceof Statements.Define\r\n || type instanceof Statements.When\r\n || type instanceof Statements.WhenType\r\n || type instanceof Statements.WhenOthers\r\n || type instanceof Statements.Cleanup\r\n || type instanceof Statements.Loop\r\n || type instanceof Statements.LoopAtScreen\r\n || type instanceof Statements.CatchSystemExceptions\r\n || type instanceof Statements.Form\r\n || type instanceof Statements.Else\r\n || type instanceof Statements.ElseIf\r\n || type instanceof Statements.MethodImplementation\r\n || type instanceof Statements.TestInjection\r\n || type instanceof Statements.TestSeam\r\n || (this.options.selectionScreenBlockIndentation === true\r\n && type instanceof Statements.SelectionScreen\r\n && (statement.concatTokens().toUpperCase().includes(\"BEGIN OF SCREEN\") ||\r\n statement.concatTokens().toUpperCase().includes(\"BEGIN OF TABBED BLOCK\") ||\r\n statement.concatTokens().toUpperCase().includes(\"BEGIN OF BLOCK\") ||\r\n statement.concatTokens().toUpperCase().includes(\"BEGIN OF LINE\")))\r\n || type instanceof Statements.StartOfSelection\r\n || type instanceof Statements.Get\r\n || type instanceof Statements.AtSelectionScreen\r\n || type instanceof Statements.AtLineSelection\r\n || type instanceof Statements.LoadOfProgram\r\n || type instanceof Statements.Initialization\r\n || type instanceof Statements.AtUserCommand\r\n || type instanceof Statements.TopOfPage\r\n || type instanceof Statements.EndOfSelection\r\n || type instanceof Statements.Public\r\n || type instanceof Statements.Protected\r\n || type instanceof Statements.Private) {\r\n indent = indent + 2;\r\n }\r\n else if (type instanceof Statements.Try) {\r\n indent = indent + (this.options.alignTryCatch ? 2 : 4);\r\n stack.push(indent);\r\n }\r\n else if (type instanceof Statements.ClassDefinition\r\n || type instanceof Statements.Case\r\n || type instanceof Statements.CaseType\r\n || type instanceof Statements.ClassImplementation) {\r\n indent = indent + (this.skipIndentForGlobalClass(statement) ? 0 : 2);\r\n stack.push(indent);\r\n }\r\n previousStatement = statement;\r\n }\r\n return ret;\r\n }\r\n skipIndentForGlobalClass(statement) {\r\n if (!this.options.globalClassSkipFirst) {\r\n return false;\r\n }\r\n const type = statement.get();\r\n if (type instanceof Statements.ClassDefinition && statement.findFirstExpression(Expressions.ClassGlobal)) {\r\n const className = statement.findFirstExpression(Expressions.ClassName);\r\n if (className) {\r\n this.globalClasses.add(className.getFirstToken().getStr().toUpperCase());\r\n }\r\n return true;\r\n }\r\n else if (type instanceof Statements.ClassImplementation) {\r\n const className = statement.findFirstExpression(Expressions.ClassName);\r\n if (className && this.globalClasses.has(className.getFirstToken().getStr().toUpperCase())) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n}\r\nexports.Indent = Indent;\r\nclass Stack {\r\n constructor() {\r\n this.items = [];\r\n }\r\n push(item) {\r\n this.items.push(item);\r\n }\r\n peek() {\r\n return this.items[this.items.length - 1];\r\n }\r\n pop() {\r\n const peek = this.peek();\r\n this.items = this.items.slice(0, this.items.length - 1);\r\n return peek;\r\n }\r\n}\r\n//# sourceMappingURL=indent.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/pretty_printer/indent.js?");
|
|
11460
11460
|
|
|
11461
11461
|
/***/ }),
|
|
11462
11462
|
|
|
@@ -11489,7 +11489,7 @@ eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\n
|
|
|
11489
11489
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
11490
11490
|
|
|
11491
11491
|
"use strict";
|
|
11492
|
-
eval("\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nexports.Registry = void 0;\nconst config_1 = __webpack_require__(/*! ./config */ \"./node_modules/@abaplint/core/build/src/config.js\");\nconst artifacts_objects_1 = __webpack_require__(/*! ./artifacts_objects */ \"./node_modules/@abaplint/core/build/src/artifacts_objects.js\");\nconst find_global_definitions_1 = __webpack_require__(/*! ./abap/5_syntax/global_definitions/find_global_definitions */ \"./node_modules/@abaplint/core/build/src/abap/5_syntax/global_definitions/find_global_definitions.js\");\nconst excludeHelper_1 = __webpack_require__(/*! ./utils/excludeHelper */ \"./node_modules/@abaplint/core/build/src/utils/excludeHelper.js\");\nconst ddic_references_1 = __webpack_require__(/*! ./ddic_references */ \"./node_modules/@abaplint/core/build/src/ddic_references.js\");\nconst rules_runner_1 = __webpack_require__(/*! ./rules_runner */ \"./node_modules/@abaplint/core/build/src/rules_runner.js\");\n// todo, this should really be an instance in case there are multiple Registry'ies\nclass ParsingPerformance {\n static clear() {\n this.results = [];\n this.lexing = 0;\n this.statements = 0;\n this.structure = 0;\n }\n static push(obj, result) {\n if (result.runtimeExtra) {\n this.lexing += result.runtimeExtra.lexing;\n this.statements += result.runtimeExtra.statements;\n this.structure += result.runtimeExtra.structure;\n }\n if (result.runtime < 100) {\n return;\n }\n if (this.results === undefined) {\n this.results = [];\n }\n let extra = \"\";\n if (result.runtimeExtra) {\n extra = `\\t(lexing: ${result.runtimeExtra.lexing}ms, statements: ${result.runtimeExtra.statements}ms, structure: ${result.runtimeExtra.structure}ms)`;\n }\n this.results.push({\n runtime: result.runtime,\n extra,\n name: obj.getType() + \" \" + obj.getName(),\n });\n }\n static output() {\n const MAX = 10;\n this.results.sort((a, b) => { return b.runtime - a.runtime; });\n for (let i = 0; i < MAX; i++) {\n const row = this.results[i];\n if (row === undefined) {\n break;\n }\n process.stderr.write(`\\t${row.runtime}ms\\t${row.name} ${row.extra}\\n`);\n }\n process.stderr.write(`\\tTotal lexing: ${this.lexing}ms\\n`);\n process.stderr.write(`\\tTotal statements: ${this.statements}ms\\n`);\n process.stderr.write(`\\tTotal structure: ${this.structure}ms\\n`);\n }\n}\n///////////////////////////////////////////////////////////////////////////////////////////////\nclass Registry {\n constructor(conf) {\n this.objects = {};\n this.objectsByType = {};\n this.dependencies = {};\n this.conf = conf ? conf : config_1.Config.getDefault();\n this.references = new ddic_references_1.DDICReferences();\n }\n static abaplintVersion() {\n // magic, see build script \"version.sh\"\n return \"2.93.44\";\n }\n getDDICReferences() {\n return this.references;\n }\n *getObjects() {\n for (const name in this.objects) {\n for (const type in this.objects[name]) {\n yield this.objects[name][type];\n }\n }\n }\n *getObjectsByType(type) {\n for (const name in this.objectsByType[type] || []) {\n yield this.objectsByType[type][name];\n }\n }\n *getFiles() {\n for (const obj of this.getObjects()) {\n for (const file of obj.getFiles()) {\n yield file;\n }\n }\n }\n getFirstObject() {\n for (const name in this.objects) {\n for (const type in this.objects[name]) {\n return this.objects[name][type];\n }\n }\n return undefined;\n }\n getObjectCount(skipDependencies = true) {\n let res = 0;\n for (const o of this.getObjects()) {\n if (skipDependencies === true && this.isDependency(o)) {\n continue;\n }\n res = res + 1;\n }\n return res;\n }\n getFileByName(filename) {\n const upper = filename.toUpperCase();\n for (const o of this.getObjects()) {\n for (const f of o.getFiles()) {\n if (f.getFilename().toUpperCase() === upper) {\n return f;\n }\n }\n }\n return undefined;\n }\n getObject(type, name) {\n if (type === undefined || name === undefined) {\n return undefined;\n }\n const searchName = name.toUpperCase();\n if (this.objects[searchName]) {\n return this.objects[searchName][type];\n }\n return undefined;\n }\n getConfig() {\n return this.conf;\n }\n // assumption: Config is immutable, and can only be changed via this method\n setConfig(conf) {\n for (const obj of this.getObjects()) {\n obj.setDirty();\n }\n this.conf = conf;\n return this;\n }\n inErrorNamespace(name) {\n // todo: performance? cache regexp?\n const reg = new RegExp(this.getConfig().getSyntaxSetttings().errorNamespace, \"i\");\n return reg.test(name);\n }\n addFile(file) {\n return this.addFiles([file]);\n }\n updateFile(file) {\n const obj = this.find(file.getObjectName(), file.getObjectType());\n obj.updateFile(file);\n return this;\n }\n removeFile(file) {\n const obj = this.find(file.getObjectName(), file.getObjectType());\n obj.removeFile(file);\n if (obj.getFiles().length === 0) {\n this.references.clear(obj);\n this.removeObject(obj);\n }\n return this;\n }\n _addFiles(files, dependency) {\n var _a;\n const globalExclude = ((_a = this.conf.getGlobal().exclude) !== null && _a !== void 0 ? _a : [])\n .map(pattern => new RegExp(pattern, \"i\"));\n for (const f of files) {\n const filename = f.getFilename();\n const isNotAbapgitFile = filename.split(\".\").length <= 2;\n if (isNotAbapgitFile || excludeHelper_1.ExcludeHelper.isExcluded(filename, globalExclude)) {\n continue;\n }\n let found = this.findOrCreate(f.getObjectName(), f.getObjectType());\n if (dependency === false && found && this.isDependency(found)) {\n this.removeDependency(found);\n found = this.findOrCreate(f.getObjectName(), f.getObjectType());\n }\n found.addFile(f);\n }\n return this;\n }\n addFiles(files) {\n this._addFiles(files, false);\n return this;\n }\n addDependencies(files) {\n for (const f of files) {\n this.addDependency(f);\n }\n return this;\n }\n addDependency(file) {\n var _a;\n const type = (_a = file.getObjectType()) === null || _a === void 0 ? void 0 : _a.toUpperCase();\n if (type === undefined) {\n return this;\n }\n const name = file.getObjectName().toUpperCase();\n if (this.dependencies[type] === undefined) {\n this.dependencies[type] = {};\n }\n this.dependencies[type][name] = true;\n this._addFiles([file], true);\n return this;\n }\n removeDependency(obj) {\n var _a;\n (_a = this.dependencies[obj.getType()]) === null || _a === void 0 ? true : delete _a[obj.getName()];\n this.removeObject(obj);\n }\n isDependency(obj) {\n var _a;\n return ((_a = this.dependencies[obj.getType()]) === null || _a === void 0 ? void 0 : _a[obj.getName()]) === true;\n }\n isFileDependency(filename) {\n var _a, _b;\n const f = this.getFileByName(filename);\n if (f === undefined) {\n return false;\n }\n const type = (_a = f.getObjectType()) === null || _a === void 0 ? void 0 : _a.toUpperCase();\n if (type === undefined) {\n return false;\n }\n const name = f.getObjectName().toUpperCase();\n return ((_b = this.dependencies[type]) === null || _b === void 0 ? void 0 : _b[name]) === true;\n }\n // assumption: the file is already in the registry\n findObjectForFile(file) {\n const filename = file.getFilename();\n for (const obj of this.getObjects()) {\n for (const ofile of obj.getFiles()) {\n if (ofile.getFilename() === filename) {\n return obj;\n }\n }\n }\n return undefined;\n }\n // todo, this will be changed to async sometime\n findIssues(input) {\n if (this.isDirty() === true) {\n this.parse();\n }\n return new rules_runner_1.RulesRunner(this).runRules(this.getObjects(), input);\n }\n // todo, this will be changed to async sometime\n findIssuesObject(iobj) {\n if (this.isDirty() === true) {\n this.parse();\n }\n return new rules_runner_1.RulesRunner(this).runRules([iobj]);\n }\n // todo, this will be changed to async sometime\n parse() {\n if (this.isDirty() === false) {\n return this;\n }\n ParsingPerformance.clear();\n for (const o of this.getObjects()) {\n this.parsePrivate(o);\n }\n new find_global_definitions_1.FindGlobalDefinitions(this).run();\n return this;\n }\n async parseAsync(input) {\n var _a, _b;\n if (this.isDirty() === false) {\n return this;\n }\n ParsingPerformance.clear();\n (_a = input === null || input === void 0 ? void 0 : input.progress) === null || _a === void 0 ? void 0 : _a.set(this.getObjectCount(false), \"Lexing and parsing\");\n for (const o of this.getObjects()) {\n await ((_b = input === null || input === void 0 ? void 0 : input.progress) === null || _b === void 0 ? void 0 : _b.tick(\"Lexing and parsing(\" + this.conf.getVersion() + \") - \" + o.getType() + \" \" + o.getName()));\n this.parsePrivate(o);\n }\n if ((input === null || input === void 0 ? void 0 : input.outputPerformance) === true) {\n ParsingPerformance.output();\n }\n new find_global_definitions_1.FindGlobalDefinitions(this).run(input === null || input === void 0 ? void 0 : input.progress);\n return this;\n }\n //////////////////////////////////////////\n // todo, refactor, this is a mess, see where-used, a lot of the code should be in this method instead\n parsePrivate(input) {\n const config = this.getConfig();\n const result = input.parse(config.getVersion(), config.getSyntaxSetttings().globalMacros, this);\n ParsingPerformance.push(input, result);\n }\n isDirty() {\n for (const o of this.getObjects()) {\n const dirty = o.isDirty();\n if (dirty === true) {\n return true;\n }\n }\n return false;\n }\n findOrCreate(name, type) {\n try {\n return this.find(name, type);\n }\n catch (_a) {\n const newName = name.toUpperCase();\n const newType = type ? type : \"UNKNOWN\";\n const add = artifacts_objects_1.ArtifactsObjects.newObject(newName, newType);\n if (this.objects[newName] === undefined) {\n this.objects[newName] = {};\n }\n this.objects[newName][newType] = add;\n if (this.objectsByType[newType] === undefined) {\n this.objectsByType[newType] = {};\n }\n this.objectsByType[newType][newName] = add;\n return add;\n }\n }\n removeObject(remove) {\n if (remove === undefined) {\n return;\n }\n if (this.objects[remove.getName()][remove.getType()] === undefined) {\n throw new Error(\"removeObject: object not found\");\n }\n if (Object.keys(this.objects[remove.getName()]).length === 1) {\n delete this.objects[remove.getName()];\n }\n else {\n delete this.objects[remove.getName()][remove.getType()];\n }\n if (Object.keys(this.objectsByType[remove.getType()]).length === 1) {\n delete this.objectsByType[remove.getType()];\n }\n else {\n delete this.objectsByType[remove.getType()][remove.getName()];\n }\n }\n find(name, type) {\n const searchType = type ? type : \"UNKNOWN\";\n const searchName = name.toUpperCase();\n if (this.objects[searchName] !== undefined\n && this.objects[searchName][searchType]) {\n return this.objects[searchName][searchType];\n }\n throw new Error(\"find: object not found, \" + type + \" \" + name);\n }\n}\nexports.Registry = Registry;\n//# sourceMappingURL=registry.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/registry.js?");
|
|
11492
|
+
eval("\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nexports.Registry = void 0;\nconst config_1 = __webpack_require__(/*! ./config */ \"./node_modules/@abaplint/core/build/src/config.js\");\nconst artifacts_objects_1 = __webpack_require__(/*! ./artifacts_objects */ \"./node_modules/@abaplint/core/build/src/artifacts_objects.js\");\nconst find_global_definitions_1 = __webpack_require__(/*! ./abap/5_syntax/global_definitions/find_global_definitions */ \"./node_modules/@abaplint/core/build/src/abap/5_syntax/global_definitions/find_global_definitions.js\");\nconst excludeHelper_1 = __webpack_require__(/*! ./utils/excludeHelper */ \"./node_modules/@abaplint/core/build/src/utils/excludeHelper.js\");\nconst ddic_references_1 = __webpack_require__(/*! ./ddic_references */ \"./node_modules/@abaplint/core/build/src/ddic_references.js\");\nconst rules_runner_1 = __webpack_require__(/*! ./rules_runner */ \"./node_modules/@abaplint/core/build/src/rules_runner.js\");\n// todo, this should really be an instance in case there are multiple Registry'ies\nclass ParsingPerformance {\n static clear() {\n this.results = [];\n this.lexing = 0;\n this.statements = 0;\n this.structure = 0;\n }\n static push(obj, result) {\n if (result.runtimeExtra) {\n this.lexing += result.runtimeExtra.lexing;\n this.statements += result.runtimeExtra.statements;\n this.structure += result.runtimeExtra.structure;\n }\n if (result.runtime < 100) {\n return;\n }\n if (this.results === undefined) {\n this.results = [];\n }\n let extra = \"\";\n if (result.runtimeExtra) {\n extra = `\\t(lexing: ${result.runtimeExtra.lexing}ms, statements: ${result.runtimeExtra.statements}ms, structure: ${result.runtimeExtra.structure}ms)`;\n }\n this.results.push({\n runtime: result.runtime,\n extra,\n name: obj.getType() + \" \" + obj.getName(),\n });\n }\n static output() {\n const MAX = 10;\n this.results.sort((a, b) => { return b.runtime - a.runtime; });\n for (let i = 0; i < MAX; i++) {\n const row = this.results[i];\n if (row === undefined) {\n break;\n }\n process.stderr.write(`\\t${row.runtime}ms\\t${row.name} ${row.extra}\\n`);\n }\n process.stderr.write(`\\tTotal lexing: ${this.lexing}ms\\n`);\n process.stderr.write(`\\tTotal statements: ${this.statements}ms\\n`);\n process.stderr.write(`\\tTotal structure: ${this.structure}ms\\n`);\n }\n}\n///////////////////////////////////////////////////////////////////////////////////////////////\nclass Registry {\n constructor(conf) {\n this.objects = {};\n this.objectsByType = {};\n this.dependencies = {};\n this.conf = conf ? conf : config_1.Config.getDefault();\n this.references = new ddic_references_1.DDICReferences();\n }\n static abaplintVersion() {\n // magic, see build script \"version.sh\"\n return \"2.93.47\";\n }\n getDDICReferences() {\n return this.references;\n }\n *getObjects() {\n for (const name in this.objects) {\n for (const type in this.objects[name]) {\n yield this.objects[name][type];\n }\n }\n }\n *getObjectsByType(type) {\n for (const name in this.objectsByType[type] || []) {\n yield this.objectsByType[type][name];\n }\n }\n *getFiles() {\n for (const obj of this.getObjects()) {\n for (const file of obj.getFiles()) {\n yield file;\n }\n }\n }\n getFirstObject() {\n for (const name in this.objects) {\n for (const type in this.objects[name]) {\n return this.objects[name][type];\n }\n }\n return undefined;\n }\n getObjectCount(skipDependencies = true) {\n let res = 0;\n for (const o of this.getObjects()) {\n if (skipDependencies === true && this.isDependency(o)) {\n continue;\n }\n res = res + 1;\n }\n return res;\n }\n getFileByName(filename) {\n const upper = filename.toUpperCase();\n for (const o of this.getObjects()) {\n for (const f of o.getFiles()) {\n if (f.getFilename().toUpperCase() === upper) {\n return f;\n }\n }\n }\n return undefined;\n }\n getObject(type, name) {\n if (type === undefined || name === undefined) {\n return undefined;\n }\n const searchName = name.toUpperCase();\n if (this.objects[searchName]) {\n return this.objects[searchName][type];\n }\n return undefined;\n }\n getConfig() {\n return this.conf;\n }\n // assumption: Config is immutable, and can only be changed via this method\n setConfig(conf) {\n for (const obj of this.getObjects()) {\n obj.setDirty();\n }\n this.conf = conf;\n return this;\n }\n inErrorNamespace(name) {\n // todo: performance? cache regexp?\n const reg = new RegExp(this.getConfig().getSyntaxSetttings().errorNamespace, \"i\");\n return reg.test(name);\n }\n addFile(file) {\n return this.addFiles([file]);\n }\n updateFile(file) {\n const obj = this.find(file.getObjectName(), file.getObjectType());\n obj.updateFile(file);\n return this;\n }\n removeFile(file) {\n const obj = this.find(file.getObjectName(), file.getObjectType());\n obj.removeFile(file);\n if (obj.getFiles().length === 0) {\n this.references.clear(obj);\n this.removeObject(obj);\n }\n return this;\n }\n _addFiles(files, dependency) {\n var _a;\n const globalExclude = ((_a = this.conf.getGlobal().exclude) !== null && _a !== void 0 ? _a : [])\n .map(pattern => new RegExp(pattern, \"i\"));\n for (const f of files) {\n const filename = f.getFilename();\n const isNotAbapgitFile = filename.split(\".\").length <= 2;\n if (isNotAbapgitFile || excludeHelper_1.ExcludeHelper.isExcluded(filename, globalExclude)) {\n continue;\n }\n let found = this.findOrCreate(f.getObjectName(), f.getObjectType());\n if (dependency === false && found && this.isDependency(found)) {\n this.removeDependency(found);\n found = this.findOrCreate(f.getObjectName(), f.getObjectType());\n }\n found.addFile(f);\n }\n return this;\n }\n addFiles(files) {\n this._addFiles(files, false);\n return this;\n }\n addDependencies(files) {\n for (const f of files) {\n this.addDependency(f);\n }\n return this;\n }\n addDependency(file) {\n var _a;\n const type = (_a = file.getObjectType()) === null || _a === void 0 ? void 0 : _a.toUpperCase();\n if (type === undefined) {\n return this;\n }\n const name = file.getObjectName().toUpperCase();\n if (this.dependencies[type] === undefined) {\n this.dependencies[type] = {};\n }\n this.dependencies[type][name] = true;\n this._addFiles([file], true);\n return this;\n }\n removeDependency(obj) {\n var _a;\n (_a = this.dependencies[obj.getType()]) === null || _a === void 0 ? true : delete _a[obj.getName()];\n this.removeObject(obj);\n }\n isDependency(obj) {\n var _a;\n return ((_a = this.dependencies[obj.getType()]) === null || _a === void 0 ? void 0 : _a[obj.getName()]) === true;\n }\n isFileDependency(filename) {\n var _a, _b;\n const f = this.getFileByName(filename);\n if (f === undefined) {\n return false;\n }\n const type = (_a = f.getObjectType()) === null || _a === void 0 ? void 0 : _a.toUpperCase();\n if (type === undefined) {\n return false;\n }\n const name = f.getObjectName().toUpperCase();\n return ((_b = this.dependencies[type]) === null || _b === void 0 ? void 0 : _b[name]) === true;\n }\n // assumption: the file is already in the registry\n findObjectForFile(file) {\n const filename = file.getFilename();\n for (const obj of this.getObjects()) {\n for (const ofile of obj.getFiles()) {\n if (ofile.getFilename() === filename) {\n return obj;\n }\n }\n }\n return undefined;\n }\n // todo, this will be changed to async sometime\n findIssues(input) {\n if (this.isDirty() === true) {\n this.parse();\n }\n return new rules_runner_1.RulesRunner(this).runRules(this.getObjects(), input);\n }\n // todo, this will be changed to async sometime\n findIssuesObject(iobj) {\n if (this.isDirty() === true) {\n this.parse();\n }\n return new rules_runner_1.RulesRunner(this).runRules([iobj]);\n }\n // todo, this will be changed to async sometime\n parse() {\n if (this.isDirty() === false) {\n return this;\n }\n ParsingPerformance.clear();\n for (const o of this.getObjects()) {\n this.parsePrivate(o);\n }\n new find_global_definitions_1.FindGlobalDefinitions(this).run();\n return this;\n }\n async parseAsync(input) {\n var _a, _b;\n if (this.isDirty() === false) {\n return this;\n }\n ParsingPerformance.clear();\n (_a = input === null || input === void 0 ? void 0 : input.progress) === null || _a === void 0 ? void 0 : _a.set(this.getObjectCount(false), \"Lexing and parsing\");\n for (const o of this.getObjects()) {\n await ((_b = input === null || input === void 0 ? void 0 : input.progress) === null || _b === void 0 ? void 0 : _b.tick(\"Lexing and parsing(\" + this.conf.getVersion() + \") - \" + o.getType() + \" \" + o.getName()));\n this.parsePrivate(o);\n }\n if ((input === null || input === void 0 ? void 0 : input.outputPerformance) === true) {\n ParsingPerformance.output();\n }\n new find_global_definitions_1.FindGlobalDefinitions(this).run(input === null || input === void 0 ? void 0 : input.progress);\n return this;\n }\n //////////////////////////////////////////\n // todo, refactor, this is a mess, see where-used, a lot of the code should be in this method instead\n parsePrivate(input) {\n const config = this.getConfig();\n const result = input.parse(config.getVersion(), config.getSyntaxSetttings().globalMacros, this);\n ParsingPerformance.push(input, result);\n }\n isDirty() {\n for (const o of this.getObjects()) {\n const dirty = o.isDirty();\n if (dirty === true) {\n return true;\n }\n }\n return false;\n }\n findOrCreate(name, type) {\n try {\n return this.find(name, type);\n }\n catch (_a) {\n const newName = name.toUpperCase();\n const newType = type ? type : \"UNKNOWN\";\n const add = artifacts_objects_1.ArtifactsObjects.newObject(newName, newType);\n if (this.objects[newName] === undefined) {\n this.objects[newName] = {};\n }\n this.objects[newName][newType] = add;\n if (this.objectsByType[newType] === undefined) {\n this.objectsByType[newType] = {};\n }\n this.objectsByType[newType][newName] = add;\n return add;\n }\n }\n removeObject(remove) {\n if (remove === undefined) {\n return;\n }\n if (this.objects[remove.getName()][remove.getType()] === undefined) {\n throw new Error(\"removeObject: object not found\");\n }\n if (Object.keys(this.objects[remove.getName()]).length === 1) {\n delete this.objects[remove.getName()];\n }\n else {\n delete this.objects[remove.getName()][remove.getType()];\n }\n if (Object.keys(this.objectsByType[remove.getType()]).length === 1) {\n delete this.objectsByType[remove.getType()];\n }\n else {\n delete this.objectsByType[remove.getType()][remove.getName()];\n }\n }\n find(name, type) {\n const searchType = type ? type : \"UNKNOWN\";\n const searchName = name.toUpperCase();\n if (this.objects[searchName] !== undefined\n && this.objects[searchName][searchType]) {\n return this.objects[searchName][searchType];\n }\n throw new Error(\"find: object not found, \" + type + \" \" + name);\n }\n}\nexports.Registry = Registry;\n//# sourceMappingURL=registry.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/registry.js?");
|
|
11493
11493
|
|
|
11494
11494
|
/***/ }),
|
|
11495
11495
|
|
|
@@ -11555,7 +11555,7 @@ eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\n
|
|
|
11555
11555
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
11556
11556
|
|
|
11557
11557
|
"use strict";
|
|
11558
|
-
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.Abapdoc = exports.AbapdocConf = void 0;\r\nconst _abap_rule_1 = __webpack_require__(/*! ./_abap_rule */ \"./node_modules/@abaplint/core/build/src/rules/_abap_rule.js\");\r\nconst _basic_rule_config_1 = __webpack_require__(/*! ./_basic_rule_config */ \"./node_modules/@abaplint/core/build/src/rules/_basic_rule_config.js\");\r\nconst issue_1 = __webpack_require__(/*! ../issue */ \"./node_modules/@abaplint/core/build/src/issue.js\");\r\nconst visibility_1 = __webpack_require__(/*! ../abap/4_file_information/visibility */ \"./node_modules/@abaplint/core/build/src/abap/4_file_information/visibility.js\");\r\nconst _irule_1 = __webpack_require__(/*! ./_irule */ \"./node_modules/@abaplint/core/build/src/rules/_irule.js\");\r\nclass AbapdocConf extends _basic_rule_config_1.BasicRuleConfig {\r\n constructor() {\r\n super(...arguments);\r\n /** Check local classes and interfaces for abapdoc. */\r\n this.checkLocal = false;\r\n this.classDefinition = false;\r\n this.interfaceDefinition = false;\r\n }\r\n}\r\nexports.AbapdocConf = AbapdocConf;\r\nclass Abapdoc extends _abap_rule_1.ABAPRule {\r\n constructor() {\r\n super(...arguments);\r\n this.conf = new AbapdocConf();\r\n }\r\n getMetadata() {\r\n return {\r\n key: \"abapdoc\",\r\n title: \"Check abapdoc\",\r\n shortDescription: `Various checks regarding abapdoc.\r\nBase rule checks for existence of abapdoc for public class methods and all interface methods.\r\n\r\nPlus class and interface definitions.`,\r\n tags: [_irule_1.RuleTag.SingleFile],\r\n };\r\n }\r\n getConfig() {\r\n return this.conf;\r\n }\r\n setConfig(conf) {\r\n this.conf = conf;\r\n }\r\n runParsed(file) {\r\n var _a, _b;\r\n const issues = [];\r\n const rows = file.getRawRows();\r\n let methods = [];\r\n for (const classDef of file.getInfo().listClassDefinitions()) {\r\n if (this.conf.checkLocal === false && classDef.isLocal === true) {\r\n continue;\r\n }\r\n methods = methods.concat(classDef.methods.filter(m => m.visibility === visibility_1.Visibility.Public));\r\n if (this.getConfig().classDefinition === true) {\r\n const previousRow = classDef.identifier.getStart().getRow() - 2;\r\n if (((_a = rows[previousRow]) === null || _a === void 0 ? void 0 : _a.trim().substring(0, 2)) !== \"\\\"!\") {\r\n const message = \"Missing ABAP Doc for class \" + classDef.identifier.getToken().getStr();\r\n const issue = issue_1.Issue.atIdentifier(classDef.identifier, message, this.getMetadata().key, this.conf.severity);\r\n issues.push(issue);\r\n }\r\n }\r\n }\r\n for (const interfaceDef of file.getInfo().listInterfaceDefinitions()) {\r\n if (this.conf.checkLocal === false && interfaceDef.isLocal === true) {\r\n continue;\r\n }\r\n methods = methods.concat(interfaceDef.methods);\r\n if (this.getConfig().interfaceDefinition === true) {\r\n const previousRow = interfaceDef.identifier.getStart().getRow() - 2;\r\n if (((_b = rows[previousRow]) === null || _b === void 0 ? void 0 : _b.trim().substring(0, 2)) !== \"\\\"!\") {\r\n const message = \"Missing ABAP Doc for interface \" + interfaceDef.identifier.getToken().getStr();\r\n const issue = issue_1.Issue.atIdentifier(interfaceDef.identifier, message, this.getMetadata().key, this.conf.severity);\r\n issues.push(issue);\r\n }\r\n }\r\n }\r\n for (const method of methods) {\r\n if (method.isRedefinition === true) {\r\n continue;\r\n }\r\n const
|
|
11558
|
+
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.Abapdoc = exports.AbapdocConf = void 0;\r\nconst _abap_rule_1 = __webpack_require__(/*! ./_abap_rule */ \"./node_modules/@abaplint/core/build/src/rules/_abap_rule.js\");\r\nconst _basic_rule_config_1 = __webpack_require__(/*! ./_basic_rule_config */ \"./node_modules/@abaplint/core/build/src/rules/_basic_rule_config.js\");\r\nconst issue_1 = __webpack_require__(/*! ../issue */ \"./node_modules/@abaplint/core/build/src/issue.js\");\r\nconst visibility_1 = __webpack_require__(/*! ../abap/4_file_information/visibility */ \"./node_modules/@abaplint/core/build/src/abap/4_file_information/visibility.js\");\r\nconst _irule_1 = __webpack_require__(/*! ./_irule */ \"./node_modules/@abaplint/core/build/src/rules/_irule.js\");\r\nclass AbapdocConf extends _basic_rule_config_1.BasicRuleConfig {\r\n constructor() {\r\n super(...arguments);\r\n /** Check local classes and interfaces for abapdoc. */\r\n this.checkLocal = false;\r\n this.classDefinition = false;\r\n this.interfaceDefinition = false;\r\n }\r\n}\r\nexports.AbapdocConf = AbapdocConf;\r\nclass Abapdoc extends _abap_rule_1.ABAPRule {\r\n constructor() {\r\n super(...arguments);\r\n this.conf = new AbapdocConf();\r\n }\r\n getMetadata() {\r\n return {\r\n key: \"abapdoc\",\r\n title: \"Check abapdoc\",\r\n shortDescription: `Various checks regarding abapdoc.\r\nBase rule checks for existence of abapdoc for public class methods and all interface methods.\r\n\r\nPlus class and interface definitions.`,\r\n tags: [_irule_1.RuleTag.SingleFile],\r\n };\r\n }\r\n getConfig() {\r\n return this.conf;\r\n }\r\n setConfig(conf) {\r\n this.conf = conf;\r\n }\r\n runParsed(file) {\r\n var _a, _b;\r\n const issues = [];\r\n const rows = file.getRawRows();\r\n let methods = [];\r\n for (const classDef of file.getInfo().listClassDefinitions()) {\r\n if (this.conf.checkLocal === false && classDef.isLocal === true) {\r\n continue;\r\n }\r\n methods = methods.concat(classDef.methods.filter(m => m.visibility === visibility_1.Visibility.Public));\r\n if (this.getConfig().classDefinition === true) {\r\n const previousRow = classDef.identifier.getStart().getRow() - 2;\r\n if (((_a = rows[previousRow]) === null || _a === void 0 ? void 0 : _a.trim().substring(0, 2)) !== \"\\\"!\") {\r\n const message = \"Missing ABAP Doc for class \" + classDef.identifier.getToken().getStr();\r\n const issue = issue_1.Issue.atIdentifier(classDef.identifier, message, this.getMetadata().key, this.conf.severity);\r\n issues.push(issue);\r\n }\r\n }\r\n }\r\n for (const interfaceDef of file.getInfo().listInterfaceDefinitions()) {\r\n if (this.conf.checkLocal === false && interfaceDef.isLocal === true) {\r\n continue;\r\n }\r\n methods = methods.concat(interfaceDef.methods);\r\n if (this.getConfig().interfaceDefinition === true) {\r\n const previousRow = interfaceDef.identifier.getStart().getRow() - 2;\r\n if (((_b = rows[previousRow]) === null || _b === void 0 ? void 0 : _b.trim().substring(0, 2)) !== \"\\\"!\") {\r\n const message = \"Missing ABAP Doc for interface \" + interfaceDef.identifier.getToken().getStr();\r\n const issue = issue_1.Issue.atIdentifier(interfaceDef.identifier, message, this.getMetadata().key, this.conf.severity);\r\n issues.push(issue);\r\n }\r\n }\r\n }\r\n for (const method of methods) {\r\n if (method.isRedefinition === true) {\r\n continue;\r\n }\r\n const previousRowText = this.getPreviousRow(rows, method.identifier.getStart());\r\n if (!(previousRowText.substring(0, 2) === \"\\\"!\")) {\r\n const message = \"Missing ABAP Doc for method \" + method.identifier.getToken().getStr();\r\n const issue = issue_1.Issue.atIdentifier(method.identifier, message, this.getMetadata().key, this.conf.severity);\r\n issues.push(issue);\r\n }\r\n }\r\n return issues;\r\n }\r\n getPreviousRow(rows, pos) {\r\n const previousRow = pos.getRow() - 2;\r\n const text = rows[previousRow].trim().toUpperCase();\r\n if (text === \"METHODS\" || text === \"CLASS-METHODS\") {\r\n const previousRow = pos.getRow() - 3;\r\n const text = rows[previousRow].trim().toUpperCase();\r\n return text;\r\n }\r\n return text;\r\n }\r\n}\r\nexports.Abapdoc = Abapdoc;\r\n//# sourceMappingURL=abapdoc.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/rules/abapdoc.js?");
|
|
11559
11559
|
|
|
11560
11560
|
/***/ }),
|
|
11561
11561
|
|
|
@@ -12336,7 +12336,7 @@ eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\n
|
|
|
12336
12336
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
12337
12337
|
|
|
12338
12338
|
"use strict";
|
|
12339
|
-
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.MainFileContents = exports.MainFileContentsConf = void 0;\r\nconst issue_1 = __webpack_require__(/*! ../issue */ \"./node_modules/@abaplint/core/build/src/issue.js\");\r\nconst _basic_rule_config_1 = __webpack_require__(/*! ./_basic_rule_config */ \"./node_modules/@abaplint/core/build/src/rules/_basic_rule_config.js\");\r\nconst Objects = __webpack_require__(/*! ../objects */ \"./node_modules/@abaplint/core/build/src/objects/index.js\");\r\nconst _abap_object_1 = __webpack_require__(/*! ../objects/_abap_object */ \"./node_modules/@abaplint/core/build/src/objects/_abap_object.js\");\r\nconst Statements = __webpack_require__(/*! ../abap/2_statements/statements */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/index.js\");\r\nconst Expressions = __webpack_require__(/*! ../abap/2_statements/expressions */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/expressions/index.js\");\r\nconst position_1 = __webpack_require__(/*! ../position */ \"./node_modules/@abaplint/core/build/src/position.js\");\r\nconst _statement_1 = __webpack_require__(/*! ../abap/2_statements/statements/_statement */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/_statement.js\");\r\nconst version_1 = __webpack_require__(/*! ../version */ \"./node_modules/@abaplint/core/build/src/version.js\");\r\nclass MainFileContentsConf extends _basic_rule_config_1.BasicRuleConfig {\r\n}\r\nexports.MainFileContentsConf = MainFileContentsConf;\r\nclass MainFileContents {\r\n constructor() {\r\n this.conf = new MainFileContentsConf();\r\n }\r\n getMetadata() {\r\n return {\r\n key: \"main_file_contents\",\r\n title: \"Main file contents\",\r\n shortDescription: `Checks related to report declarations.`,\r\n extendedInformation: `Does not run if the target version is Cloud`,\r\n };\r\n }\r\n getDescription(details) {\r\n return \"Main file must have specific contents: \" + details;\r\n }\r\n getConfig() {\r\n return this.conf;\r\n }\r\n setConfig(conf) {\r\n this.conf = conf;\r\n }\r\n initialize(reg) {\r\n this.reg = reg;\r\n return this;\r\n }\r\n run(obj) {\r\n if (!(obj instanceof _abap_object_1.ABAPObject)\r\n || this.reg.getConfig().getVersion() === version_1.Version.Cloud) {\r\n return [];\r\n }\r\n const main = obj.getMainABAPFile();\r\n if (main === undefined) {\r\n return [];\r\n }\r\n const stru = main.getStructure();\r\n if (stru === undefined) {\r\n return [];\r\n }\r\n if (obj instanceof Objects.Program && obj.isInclude() === false) {\r\n let count = 0;\r\n let first = main.getStatements()[count];\r\n while (first !== undefined && first.get() instanceof _statement_1.Comment) {\r\n count = count + 1;\r\n first = main.getStatements()[count];\r\n }\r\n if (first === undefined || !(first.get() instanceof Statements.Report\r\n || first.get() instanceof Statements.Program)) {\r\n const position = new position_1.Position(1, 1);\r\n const issue = issue_1.Issue.atPosition(main, position, this.getDescription(\"Report must begin with REPORT or PROGRAM\"), this.getMetadata().key, this.conf.severity);\r\n return [issue];\r\n }\r\n const name = first.findFirstExpression(Expressions.ReportName);\r\n if (name === undefined) {\r\n const token = first.getFirstToken();\r\n const issue = issue_1.Issue.atToken(main, token, this.getDescription(\"Add report name to REPORT or PROGRAM statement\"), this.getMetadata().key, this.conf.severity);\r\n return [issue];\r\n }\r\n else if (name.getFirstToken().getStr().toUpperCase() !== obj.getName()) {\r\n const token = name.getFirstToken();\r\n const issue = issue_1.Issue.atToken(main, token, this.getDescription(\"REPORT or PROGRAM name
|
|
12339
|
+
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.MainFileContents = exports.MainFileContentsConf = void 0;\r\nconst issue_1 = __webpack_require__(/*! ../issue */ \"./node_modules/@abaplint/core/build/src/issue.js\");\r\nconst _basic_rule_config_1 = __webpack_require__(/*! ./_basic_rule_config */ \"./node_modules/@abaplint/core/build/src/rules/_basic_rule_config.js\");\r\nconst Objects = __webpack_require__(/*! ../objects */ \"./node_modules/@abaplint/core/build/src/objects/index.js\");\r\nconst _abap_object_1 = __webpack_require__(/*! ../objects/_abap_object */ \"./node_modules/@abaplint/core/build/src/objects/_abap_object.js\");\r\nconst Statements = __webpack_require__(/*! ../abap/2_statements/statements */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/index.js\");\r\nconst Expressions = __webpack_require__(/*! ../abap/2_statements/expressions */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/expressions/index.js\");\r\nconst position_1 = __webpack_require__(/*! ../position */ \"./node_modules/@abaplint/core/build/src/position.js\");\r\nconst _statement_1 = __webpack_require__(/*! ../abap/2_statements/statements/_statement */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/_statement.js\");\r\nconst version_1 = __webpack_require__(/*! ../version */ \"./node_modules/@abaplint/core/build/src/version.js\");\r\nclass MainFileContentsConf extends _basic_rule_config_1.BasicRuleConfig {\r\n}\r\nexports.MainFileContentsConf = MainFileContentsConf;\r\nclass MainFileContents {\r\n constructor() {\r\n this.conf = new MainFileContentsConf();\r\n }\r\n getMetadata() {\r\n return {\r\n key: \"main_file_contents\",\r\n title: \"Main file contents\",\r\n shortDescription: `Checks related to report declarations.`,\r\n extendedInformation: `Does not run if the target version is Cloud\r\n\r\n* PROGs must begin with \"REPORT <name>.\" or \"PROGRAM <name>.\r\n* TYPEs must begin with \"TYPE-POOL <name>.\"\r\n`,\r\n };\r\n }\r\n getDescription(details) {\r\n return \"Main file must have specific contents: \" + details;\r\n }\r\n getConfig() {\r\n return this.conf;\r\n }\r\n setConfig(conf) {\r\n this.conf = conf;\r\n }\r\n initialize(reg) {\r\n this.reg = reg;\r\n return this;\r\n }\r\n run(obj) {\r\n if (!(obj instanceof _abap_object_1.ABAPObject)\r\n || this.reg.getConfig().getVersion() === version_1.Version.Cloud) {\r\n return [];\r\n }\r\n const main = obj.getMainABAPFile();\r\n if (main === undefined) {\r\n return [];\r\n }\r\n const stru = main.getStructure();\r\n if (stru === undefined) {\r\n return [];\r\n }\r\n if (obj instanceof Objects.Program && obj.isInclude() === false) {\r\n let count = 0;\r\n let first = main.getStatements()[count];\r\n while (first !== undefined && first.get() instanceof _statement_1.Comment) {\r\n count = count + 1;\r\n first = main.getStatements()[count];\r\n }\r\n if (first === undefined || !(first.get() instanceof Statements.Report\r\n || first.get() instanceof Statements.Program)) {\r\n const position = new position_1.Position(1, 1);\r\n const issue = issue_1.Issue.atPosition(main, position, this.getDescription(\"Report must begin with REPORT or PROGRAM\"), this.getMetadata().key, this.conf.severity);\r\n return [issue];\r\n }\r\n const name = first.findFirstExpression(Expressions.ReportName);\r\n if (name === undefined) {\r\n const token = first.getFirstToken();\r\n const issue = issue_1.Issue.atToken(main, token, this.getDescription(\"Add report name to REPORT or PROGRAM statement\"), this.getMetadata().key, this.conf.severity);\r\n return [issue];\r\n }\r\n else if (name.getFirstToken().getStr().toUpperCase() !== obj.getName()) {\r\n const token = name.getFirstToken();\r\n const issue = issue_1.Issue.atToken(main, token, this.getDescription(\"REPORT or PROGRAM name must match filename\"), this.getMetadata().key, this.conf.severity);\r\n return [issue];\r\n }\r\n }\r\n else if (obj instanceof Objects.TypePool) {\r\n let count = 0;\r\n let first = main.getStatements()[count];\r\n while (first !== undefined && first.get() instanceof _statement_1.Comment) {\r\n count = count + 1;\r\n first = main.getStatements()[count];\r\n }\r\n if (first === undefined || !(first.get() instanceof Statements.TypePool)) {\r\n const position = new position_1.Position(1, 1);\r\n const issue = issue_1.Issue.atPosition(main, position, this.getDescription(\"Type pool must begin with TYPE-POOL\"), this.getMetadata().key, this.conf.severity);\r\n return [issue];\r\n }\r\n const name = first.getChildren()[3];\r\n if (name.getFirstToken().getStr().toUpperCase() !== obj.getName()) {\r\n const token = name.getFirstToken();\r\n const issue = issue_1.Issue.atToken(main, token, this.getDescription(\"TYPE-POOL name must match filename\"), this.getMetadata().key, this.conf.severity);\r\n return [issue];\r\n }\r\n }\r\n return [];\r\n }\r\n}\r\nexports.MainFileContents = MainFileContents;\r\n//# sourceMappingURL=main_file_contents.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/rules/main_file_contents.js?");
|
|
12340
12340
|
|
|
12341
12341
|
/***/ }),
|
|
12342
12342
|
|
|
@@ -13051,7 +13051,7 @@ eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\n
|
|
|
13051
13051
|
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
|
|
13052
13052
|
|
|
13053
13053
|
"use strict";
|
|
13054
|
-
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.UnnecessaryPragma = exports.UnnecessaryPragmaConf = void 0;\r\nconst issue_1 = __webpack_require__(/*! ../issue */ \"./node_modules/@abaplint/core/build/src/issue.js\");\r\nconst Statements = __webpack_require__(/*! ../abap/2_statements/statements */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/index.js\");\r\nconst Expressions = __webpack_require__(/*! ../abap/2_statements/expressions */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/expressions/index.js\");\r\nconst _abap_rule_1 = __webpack_require__(/*! ./_abap_rule */ \"./node_modules/@abaplint/core/build/src/rules/_abap_rule.js\");\r\nconst _basic_rule_config_1 = __webpack_require__(/*! ./_basic_rule_config */ \"./node_modules/@abaplint/core/build/src/rules/_basic_rule_config.js\");\r\nconst _statement_1 = __webpack_require__(/*! ../abap/2_statements/statements/_statement */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/_statement.js\");\r\nconst _irule_1 = __webpack_require__(/*! ./_irule */ \"./node_modules/@abaplint/core/build/src/rules/_irule.js\");\r\nclass UnnecessaryPragmaConf extends _basic_rule_config_1.BasicRuleConfig {\r\n}\r\nexports.UnnecessaryPragmaConf = UnnecessaryPragmaConf;\r\nclass UnnecessaryPragma extends _abap_rule_1.ABAPRule {\r\n constructor() {\r\n super(...arguments);\r\n this.conf = new UnnecessaryPragmaConf();\r\n }\r\n getMetadata() {\r\n return {\r\n key: \"unnecessary_pragma\",\r\n title: \"Unnecessary Pragma\",\r\n shortDescription: `Finds pragmas which can be removed`,\r\n extendedInformation: `* NO_HANDLER with handler\r\n\r\n* NEEDED without definition\r\n\r\n* NO_TEXT without texts\r\n\r\n* SUBRC_OK where sy-subrc is checked`,\r\n tags: [_irule_1.RuleTag.SingleFile],\r\n badExample: `TRY.\r\n ...\r\n CATCH zcx_abapgit_exception ##NO_HANDLER.\r\n RETURN. \" it has a handler\r\nENDTRY.\r\nMESSAGE w125(zbar) WITH c_foo INTO message ##NEEDED ##NO_TEXT.\r\nSELECT SINGLE * FROM tadir INTO @DATA(sdfs) ##SUBRC_OK.\r\nIF sy-subrc <> 0.\r\nENDIF.`,\r\n goodExample: `TRY.\r\n ...\r\n CATCH zcx_abapgit_exception.\r\n RETURN.\r\nENDTRY.\r\nMESSAGE w125(zbar) WITH c_foo INTO message.\r\nSELECT SINGLE * FROM tadir INTO @DATA(sdfs).\r\nIF sy-subrc <> 0.\r\nENDIF.`,\r\n };\r\n }\r\n getConfig() {\r\n return this.conf;\r\n }\r\n setConfig(conf) {\r\n this.conf = conf;\r\n }\r\n runParsed(file) {\r\n const issues = [];\r\n let noHandler = false;\r\n const statements = file.getStatements();\r\n for (let i = 0; i < statements.length; i++) {\r\n const statement = statements[i];\r\n const nextStatement = statements[i + 1];\r\n if (statement.get() instanceof Statements.EndTry) {\r\n noHandler = false;\r\n }\r\n else if (statement.get() instanceof _statement_1.Comment) {\r\n continue;\r\n }\r\n else if (noHandler === true && !(statement.get() instanceof Statements.Catch)) {\r\n const message = \"NO_HANDLER pragma or pseudo comment can be removed\";\r\n const issue = issue_1.Issue.atStatement(file, statement, message, this.getMetadata().key, this.conf.severity);\r\n issues.push(issue);\r\n noHandler = false;\r\n }\r\n else {\r\n noHandler = this.containsNoHandler(statement, statements[i + 1]);\r\n }\r\n issues.push(...this.checkText(statement, file));\r\n issues.push(...this.checkNeeded(statement, file));\r\n issues.push(...this.checkSubrc(statement, nextStatement, file));\r\n }\r\n return issues;\r\n }\r\n checkText(statement, file) {\r\n const p = statement.getPragmas().find(t => t.getStr().toUpperCase() === \"##NO_TEXT\");\r\n if (p === undefined) {\r\n return [];\r\n }\r\n if (statement.findFirstExpression(Expressions.ConstantString) === undefined\r\n && statement.findFirstExpression(Expressions.StringTemplate) === undefined) {\r\n const message = \"There is no text, NO_TEXT can be removed\";\r\n return [issue_1.Issue.atToken(file, p, message, this.getMetadata().key, this.getConfig().severity)];\r\n }\r\n return [];\r\n }\r\n checkSubrc(statement, next, file) {\r\n const p = statement.getPragmas().find(t => t.getStr().toUpperCase() === \"##SUBRC_OK\");\r\n if (p === undefined) {\r\n return [];\r\n }\r\n const concat = next.concatTokens().toUpperCase();\r\n if (concat.includes(\" SY-SUBRC\")) {\r\n const message = \"SUBRC_OK can be removed as sy-subrc is checked\";\r\n return [issue_1.Issue.atToken(file, p, message, this.getMetadata().key, this.getConfig().severity)];\r\n }\r\n return [];\r\n }\r\n checkNeeded(statement, file) {\r\n const p = statement.getPragmas().find(t => t.getStr().toUpperCase() === \"##NEEDED\");\r\n if (p === undefined) {\r\n return [];\r\n }\r\n if (statement.findFirstExpression(Expressions.InlineData) === undefined\r\n && !(statement.get() instanceof Statements.Parameter)\r\n && !(statement.get() instanceof Statements.Data)\r\n && !(statement.get() instanceof Statements.DataEnd)\r\n && !(statement.get() instanceof Statements.Type)\r\n && !(statement.get() instanceof Statements.TypeEnd)\r\n && !(statement.get() instanceof Statements.Constant)\r\n && !(statement.get() instanceof Statements.ConstantEnd)\r\n && !(statement.get() instanceof Statements.TypeEnum)\r\n && !(statement.get() instanceof Statements.TypeEnumEnd)\r\n && !(statement.get() instanceof Statements.MethodImplementation)\r\n && !(statement.get() instanceof Statements.MethodDef)\r\n && statement.findFirstExpression(Expressions.InlineFS) === undefined) {\r\n const message = \"There is no data definition, NEEDED can be removed\";\r\n return [issue_1.Issue.atToken(file, p, message, this.getMetadata().key, this.getConfig().severity)];\r\n }\r\n return [];\r\n }\r\n containsNoHandler(statement, next) {\r\n for (const t of statement.getPragmas()) {\r\n if (t.getStr().toUpperCase() === \"##NO_HANDLER\") {\r\n return true;\r\n }\r\n }\r\n if (next\r\n && next.get() instanceof _statement_1.Comment\r\n && next.concatTokens().toUpperCase().includes(\"#EC NO_HANDLER\")) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n}\r\nexports.UnnecessaryPragma = UnnecessaryPragma;\r\n//# sourceMappingURL=unnecessary_pragma.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/rules/unnecessary_pragma.js?");
|
|
13054
|
+
eval("\r\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\r\nexports.UnnecessaryPragma = exports.UnnecessaryPragmaConf = void 0;\r\nconst issue_1 = __webpack_require__(/*! ../issue */ \"./node_modules/@abaplint/core/build/src/issue.js\");\r\nconst Statements = __webpack_require__(/*! ../abap/2_statements/statements */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/index.js\");\r\nconst Expressions = __webpack_require__(/*! ../abap/2_statements/expressions */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/expressions/index.js\");\r\nconst _abap_rule_1 = __webpack_require__(/*! ./_abap_rule */ \"./node_modules/@abaplint/core/build/src/rules/_abap_rule.js\");\r\nconst _basic_rule_config_1 = __webpack_require__(/*! ./_basic_rule_config */ \"./node_modules/@abaplint/core/build/src/rules/_basic_rule_config.js\");\r\nconst _statement_1 = __webpack_require__(/*! ../abap/2_statements/statements/_statement */ \"./node_modules/@abaplint/core/build/src/abap/2_statements/statements/_statement.js\");\r\nconst _irule_1 = __webpack_require__(/*! ./_irule */ \"./node_modules/@abaplint/core/build/src/rules/_irule.js\");\r\nclass UnnecessaryPragmaConf extends _basic_rule_config_1.BasicRuleConfig {\r\n}\r\nexports.UnnecessaryPragmaConf = UnnecessaryPragmaConf;\r\nclass UnnecessaryPragma extends _abap_rule_1.ABAPRule {\r\n constructor() {\r\n super(...arguments);\r\n this.conf = new UnnecessaryPragmaConf();\r\n }\r\n getMetadata() {\r\n return {\r\n key: \"unnecessary_pragma\",\r\n title: \"Unnecessary Pragma\",\r\n shortDescription: `Finds pragmas which can be removed`,\r\n extendedInformation: `* NO_HANDLER with handler\r\n\r\n* NEEDED without definition\r\n\r\n* NO_TEXT without texts\r\n\r\n* SUBRC_OK where sy-subrc is checked`,\r\n tags: [_irule_1.RuleTag.SingleFile],\r\n badExample: `TRY.\r\n ...\r\n CATCH zcx_abapgit_exception ##NO_HANDLER.\r\n RETURN. \" it has a handler\r\nENDTRY.\r\nMESSAGE w125(zbar) WITH c_foo INTO message ##NEEDED ##NO_TEXT.\r\nSELECT SINGLE * FROM tadir INTO @DATA(sdfs) ##SUBRC_OK.\r\nIF sy-subrc <> 0.\r\nENDIF.`,\r\n goodExample: `TRY.\r\n ...\r\n CATCH zcx_abapgit_exception.\r\n RETURN.\r\nENDTRY.\r\nMESSAGE w125(zbar) WITH c_foo INTO message.\r\nSELECT SINGLE * FROM tadir INTO @DATA(sdfs).\r\nIF sy-subrc <> 0.\r\nENDIF.`,\r\n };\r\n }\r\n getConfig() {\r\n return this.conf;\r\n }\r\n setConfig(conf) {\r\n this.conf = conf;\r\n }\r\n runParsed(file) {\r\n const issues = [];\r\n let noHandler = false;\r\n const statements = file.getStatements();\r\n for (let i = 0; i < statements.length; i++) {\r\n const statement = statements[i];\r\n const nextStatement = statements[i + 1];\r\n if (statement.get() instanceof Statements.EndTry) {\r\n noHandler = false;\r\n }\r\n else if (statement.get() instanceof _statement_1.Comment) {\r\n continue;\r\n }\r\n else if (noHandler === true && !(statement.get() instanceof Statements.Catch)) {\r\n const message = \"NO_HANDLER pragma or pseudo comment can be removed\";\r\n const issue = issue_1.Issue.atStatement(file, statement, message, this.getMetadata().key, this.conf.severity);\r\n issues.push(issue);\r\n noHandler = false;\r\n }\r\n else {\r\n noHandler = this.containsNoHandler(statement, statements[i + 1]);\r\n }\r\n issues.push(...this.checkText(statement, file));\r\n issues.push(...this.checkNeeded(statement, file));\r\n issues.push(...this.checkSubrc(statement, nextStatement, file));\r\n }\r\n return issues;\r\n }\r\n checkText(statement, file) {\r\n const p = statement.getPragmas().find(t => t.getStr().toUpperCase() === \"##NO_TEXT\");\r\n if (p === undefined) {\r\n return [];\r\n }\r\n if (statement.findFirstExpression(Expressions.ConstantString) === undefined\r\n && statement.findFirstExpression(Expressions.StringTemplate) === undefined) {\r\n const message = \"There is no text, NO_TEXT can be removed\";\r\n return [issue_1.Issue.atToken(file, p, message, this.getMetadata().key, this.getConfig().severity)];\r\n }\r\n return [];\r\n }\r\n checkSubrc(statement, next, file) {\r\n const p = statement.getPragmas().find(t => t.getStr().toUpperCase() === \"##SUBRC_OK\");\r\n if (p === undefined) {\r\n return [];\r\n }\r\n const concat = next.concatTokens().toUpperCase();\r\n if (concat.includes(\" SY-SUBRC\")) {\r\n const message = \"SUBRC_OK can be removed as sy-subrc is checked\";\r\n return [issue_1.Issue.atToken(file, p, message, this.getMetadata().key, this.getConfig().severity)];\r\n }\r\n return [];\r\n }\r\n checkNeeded(statement, file) {\r\n const p = statement.getPragmas().find(t => t.getStr().toUpperCase() === \"##NEEDED\");\r\n if (p === undefined) {\r\n return [];\r\n }\r\n if (statement.findFirstExpression(Expressions.InlineData) === undefined\r\n && !(statement.get() instanceof Statements.Parameter)\r\n && !(statement.get() instanceof Statements.Data)\r\n && !(statement.get() instanceof Statements.DataEnd)\r\n && !(statement.get() instanceof Statements.Type)\r\n && !(statement.get() instanceof Statements.Form)\r\n && !(statement.get() instanceof Statements.TypeEnd)\r\n && !(statement.get() instanceof Statements.Constant)\r\n && !(statement.get() instanceof Statements.ConstantEnd)\r\n && !(statement.get() instanceof Statements.TypeEnum)\r\n && !(statement.get() instanceof Statements.TypeEnumEnd)\r\n && !(statement.get() instanceof Statements.MethodImplementation)\r\n && !(statement.get() instanceof Statements.MethodDef)\r\n && statement.findFirstExpression(Expressions.InlineFS) === undefined) {\r\n const message = \"There is no data definition, NEEDED can be removed\";\r\n return [issue_1.Issue.atToken(file, p, message, this.getMetadata().key, this.getConfig().severity)];\r\n }\r\n return [];\r\n }\r\n containsNoHandler(statement, next) {\r\n for (const t of statement.getPragmas()) {\r\n if (t.getStr().toUpperCase() === \"##NO_HANDLER\") {\r\n return true;\r\n }\r\n }\r\n if (next\r\n && next.get() instanceof _statement_1.Comment\r\n && next.concatTokens().toUpperCase().includes(\"#EC NO_HANDLER\")) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n}\r\nexports.UnnecessaryPragma = UnnecessaryPragma;\r\n//# sourceMappingURL=unnecessary_pragma.js.map\n\n//# sourceURL=webpack://@abaplint/cli/./node_modules/@abaplint/core/build/src/rules/unnecessary_pragma.js?");
|
|
13055
13055
|
|
|
13056
13056
|
/***/ }),
|
|
13057
13057
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@abaplint/cli",
|
|
3
|
-
"version": "2.93.
|
|
3
|
+
"version": "2.93.47",
|
|
4
4
|
"description": "abaplint - Command Line Interface",
|
|
5
5
|
"bin": {
|
|
6
6
|
"abaplint": "./abaplint"
|
|
@@ -39,7 +39,7 @@
|
|
|
39
39
|
},
|
|
40
40
|
"homepage": "https://abaplint.org",
|
|
41
41
|
"devDependencies": {
|
|
42
|
-
"@abaplint/core": "^2.93.
|
|
42
|
+
"@abaplint/core": "^2.93.47",
|
|
43
43
|
"@types/chai": "^4.3.3",
|
|
44
44
|
"@types/glob": "^7.2.0",
|
|
45
45
|
"@types/minimist": "^1.2.2",
|