@ui5/cli 3.0.0-alpha.7 → 3.0.0-alpha.8

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ui5/cli",
3
- "version": "3.0.0-alpha.7",
3
+ "version": "3.0.0-alpha.8",
4
4
  "description": "UI5 Tooling - CLI",
5
5
  "author": {
6
6
  "name": "SAP SE",
@@ -43,7 +43,7 @@
43
43
  "version": "git-chglog --sort semver --next-tag v$npm_package_version -o CHANGELOG.md && git add CHANGELOG.md",
44
44
  "prepublishOnly": "git push --follow-tags",
45
45
  "release-note": "git-chglog --sort semver -c .chglog/release-config.yml v$npm_package_version | node .chglog/consolidate-changelogs.js",
46
- "depcheck": "depcheck --ignores docdash,@ui5/fs"
46
+ "depcheck": "depcheck --ignores docdash,@ui5/fs,@ui5/builder"
47
47
  },
48
48
  "files": [
49
49
  "CHANGELOG.md",
@@ -108,18 +108,18 @@
108
108
  "url": "git@github.com:SAP/ui5-cli.git"
109
109
  },
110
110
  "dependencies": {
111
- "@ui5/builder": "^3.0.0-alpha.6",
112
- "@ui5/fs": "^3.0.0-alpha.3",
111
+ "@ui5/builder": "^3.0.0-alpha.7",
112
+ "@ui5/fs": "^3.0.0-alpha.4",
113
113
  "@ui5/logger": "^3.0.1-alpha.1",
114
- "@ui5/project": "^3.0.0-alpha.2",
115
- "@ui5/server": "^3.0.0-alpha.1",
114
+ "@ui5/project": "^3.0.0-alpha.3",
115
+ "@ui5/server": "^3.0.0-alpha.2",
116
116
  "chalk": "^4.1.2",
117
117
  "data-with-position": "^0.5.0",
118
118
  "import-local": "^3.1.0",
119
119
  "js-yaml": "^4.1.0",
120
120
  "open": "^7.4.2",
121
+ "pretty-hrtime": "^1.0.3",
121
122
  "semver": "^7.3.5",
122
- "treeify": "^1.0.1",
123
123
  "update-notifier": "^5.1.0",
124
124
  "yargs": "^16.2.0"
125
125
  },
@@ -1,216 +0,0 @@
1
- const log = require("@ui5/logger").getLogger("cli:utils:buildHelper");
2
-
3
- /**
4
- * Creates an object containing the flattened project dependency tree. Each dependency is defined as an object key while
5
- * its value is an array of all of its transitive dependencies.
6
- *
7
- * @param {object} tree Project tree as generated by the [@ui5/project.normalizer]{@link module:@ui5/project.normalizer}
8
- * @returns {object<string, string[]>} An object with dependency names as key and each with an array of its transitive
9
- * dependencies as value
10
- */
11
- function getFlattenedDependencyTree(tree) {
12
- const dependencyInfo = {};
13
-
14
- function _getTransitiveDependencies(project, dependencies) {
15
- project.dependencies.forEach((dep) => {
16
- if (!dependencies.includes(dep.metadata.name)) {
17
- dependencies.push(dep.metadata.name);
18
- _getTransitiveDependencies(dep, dependencies);
19
- }
20
- });
21
- return dependencies;
22
- }
23
- function _processDependencies(project) {
24
- project.dependencies.forEach((dep) => {
25
- if (!dependencyInfo[dep.metadata.name]) {
26
- dependencyInfo[dep.metadata.name] = _getTransitiveDependencies(dep, []);
27
- _processDependencies(dep);
28
- }
29
- });
30
- }
31
-
32
- _processDependencies(tree);
33
- return dependencyInfo;
34
- }
35
-
36
- /**
37
- * Creates dependency lists for 'includedDependencies' and 'excludedDependencies'. Regular expressions are directly
38
- * applied to a list of all project dependencies so that they don't need to be evaluated in later processing steps.
39
- * Generally, includes are handled with a higher priority than excludes. Additionally, operations for processing
40
- * transitive dependencies are handled with a lower priority than explicitly mentioned dependencies. The default
41
- * dependencies set in the build settings are appended in the end.
42
- *
43
- * The priority of the various dependency lists is applied in the following order, but note that a later list can't
44
- * overrule earlier ones:
45
- * <ol>
46
- * <li>includeDependency, includeDependencyRegExp</li>
47
- * <li>excludeDependency, excludeDependencyRegExp</li>
48
- * <li>includeDependencyTree</li>
49
- * <li>excludeDependencyTree</li>
50
- * <li>defaultIncludeDependency, defaultIncludeDependencyRegExp, defaultIncludeDependencyTree</li>
51
- * </ol>
52
- *
53
- * @param {object} parameters Parameters
54
- * @param {object} parameters.tree Project tree as generated by the
55
- * [@ui5/project.normalizer]{@link module:@ui5/project.normalizer}
56
- * @param {string[]} parameters.includeDependency The dependencies to be considered in 'includedDependencies'; the
57
- * "*" character can be used as wildcard for all dependencies and is an alias for the CLI option "--all"
58
- * @param {string[]} parameters.includeDependencyRegExp Strings which are interpreted as regular expressions
59
- * to describe the selection of dependencies to be considered in 'includedDependencies'
60
- * @param {string[]} parameters.includeDependencyTree The dependencies to be considered in 'includedDependencies';
61
- * transitive dependencies are also appended
62
- * @param {string[]} parameters.excludeDependency The dependencies to be considered in 'excludedDependencies'
63
- * @param {string[]} parameters.excludeDependencyRegExp Strings which are interpreted as regular expressions
64
- * to describe the selection of dependencies to be considered in 'excludedDependencies'
65
- * @param {string[]} parameters.excludeDependencyTree The dependencies to be considered in 'excludedDependencies';
66
- * transitive dependencies are also appended
67
- * @param {string[]} parameters.defaultIncludeDependency Same as 'includeDependency' parameter; used for build
68
- * settings
69
- * @param {string[]} parameters.defaultIncludeDependencyRegExp Same as 'includeDependencyRegExp' parameter; used
70
- * for build settings
71
- * @param {string[]} parameters.defaultIncludeDependencyTree Same as 'includeDependencyTree' parameter; used for
72
- * build settings
73
- * @returns {{includedDependencies:string[],excludedDependencies:string[]}} An object containing the
74
- * 'includedDependencies' and 'excludedDependencies'
75
- */
76
- function createDependencyLists({
77
- tree,
78
- includeDependency = [], includeDependencyRegExp = [], includeDependencyTree = [],
79
- excludeDependency = [], excludeDependencyRegExp = [], excludeDependencyTree = [],
80
- defaultIncludeDependency = [], defaultIncludeDependencyRegExp = [], defaultIncludeDependencyTree = []
81
- }) {
82
- if (
83
- !includeDependency.length && !includeDependencyRegExp.length && !includeDependencyTree.length &&
84
- !excludeDependency.length && !excludeDependencyRegExp.length && !excludeDependencyTree.length &&
85
- !defaultIncludeDependency.length && !defaultIncludeDependencyRegExp.length &&
86
- !defaultIncludeDependencyTree.length
87
- ) {
88
- return {includedDependencies: [], excludedDependencies: []};
89
- }
90
-
91
- const flattenedDependencyTree = getFlattenedDependencyTree(tree);
92
-
93
- function isExcluded(excludeList, depName) {
94
- return excludeList && excludeList.has(depName);
95
- }
96
- function processDependencies({targetList, dependencies, dependenciesRegExp = [], excludeList, handleSubtree}) {
97
- if (handleSubtree && dependenciesRegExp.length) {
98
- throw new Error("dependenciesRegExp can't be combined with handleSubtree:true option");
99
- }
100
- dependencies.forEach((depName) => {
101
- if (depName === "*") {
102
- targetList.add(depName);
103
- } else if (flattenedDependencyTree[depName]) {
104
- if (!isExcluded(excludeList, depName)) {
105
- targetList.add(depName);
106
- }
107
- if (handleSubtree) {
108
- flattenedDependencyTree[depName].forEach((dep) => {
109
- if (!isExcluded(excludeList, dep)) {
110
- targetList.add(dep);
111
- }
112
- });
113
- }
114
- } else {
115
- log.warn(
116
- `Could not find dependency "${depName}" for project ${tree.metadata.name}. Dependency filter is ` +
117
- `ignored`);
118
- }
119
- });
120
- dependenciesRegExp.map((exp) => new RegExp(exp)).forEach((regExp) => {
121
- for (const depName in flattenedDependencyTree) {
122
- if (regExp.test(depName) && !isExcluded(excludeList, depName)) {
123
- targetList.add(depName);
124
- }
125
- }
126
- });
127
- }
128
-
129
- const includedDependencies = new Set();
130
- const excludedDependencies = new Set();
131
-
132
- // add dependencies defined in includeDependency and includeDependencyRegExp to the list of includedDependencies
133
- processDependencies({
134
- targetList: includedDependencies,
135
- dependencies: includeDependency,
136
- dependenciesRegExp: includeDependencyRegExp
137
- });
138
- // add dependencies defined in excludeDependency and excludeDependencyRegExp to the list of excludedDependencies
139
- processDependencies({
140
- targetList: excludedDependencies,
141
- dependencies: excludeDependency,
142
- dependenciesRegExp: excludeDependencyRegExp
143
- });
144
- // add dependencies defined in includeDependencyTree with their transitive dependencies to the list of
145
- // includedDependencies; due to prioritization only those dependencies are added which are not excluded
146
- // by excludedDependencies
147
- processDependencies({
148
- targetList: includedDependencies,
149
- dependencies: includeDependencyTree,
150
- excludeList: excludedDependencies,
151
- handleSubtree: true
152
- });
153
- // add dependencies defined in excludeDependencyTree with their transitive dependencies to the list of
154
- // excludedDependencies; due to prioritization only those dependencies are added which are not excluded
155
- // by includedDependencies
156
- processDependencies({
157
- targetList: excludedDependencies,
158
- dependencies: excludeDependencyTree,
159
- excludeList: includedDependencies,
160
- handleSubtree: true
161
- });
162
- // due to the lowest priority only add the dependencies defined in build settings if they are not excluded
163
- // by any other dependency defined in excludedDependencies
164
- processDependencies({
165
- targetList: includedDependencies,
166
- dependencies: defaultIncludeDependency,
167
- dependenciesRegExp: defaultIncludeDependencyRegExp,
168
- excludeList: excludedDependencies
169
- });
170
- processDependencies({
171
- targetList: includedDependencies,
172
- dependencies: defaultIncludeDependencyTree,
173
- excludeList: excludedDependencies,
174
- handleSubtree: true
175
- });
176
-
177
- return {
178
- includedDependencies: Array.from(includedDependencies),
179
- excludedDependencies: Array.from(excludedDependencies)
180
- };
181
- }
182
-
183
- /**
184
- * Returns whether project dependencies have to be built influenced by <code>includedDependencies</code> and
185
- * <code>excludedDependencies</code>.
186
- * If only selected dependencies (via <code>includedDependencies</code>) have to be built, the "*" character
187
- * is added to the <code>excludedDependencies</code> to make sure that all other dependencies are
188
- * excluded.
189
- * In case a "*" character is included in <code>includedDependencies</code>, it is removed and the
190
- * <code>buildAll</code> flag is set to <code>true</code> as it behaves as an alias.
191
- *
192
- * @param {boolean} buildAll The value of the <code>all</code> command line parameter to decide if project
193
- * dependencies have to be built
194
- * @param {string[]} includedDependencies The list of included dependencies
195
- * @param {string[]} excludedDependencies The list of excluded dependencies
196
- * @returns {boolean} Whether it is required to build project dependencies
197
- */
198
- function alignWithBuilderApi(buildAll, includedDependencies, excludedDependencies) {
199
- if ((!buildAll && !includedDependencies.includes("*")) && includedDependencies.length) {
200
- excludedDependencies.push("*");
201
- }
202
- if (includedDependencies.includes("*")) {
203
- buildAll = true;
204
- includedDependencies.splice(includedDependencies.indexOf("*"), 1);
205
- }
206
- if (!buildAll && includedDependencies.length) {
207
- buildAll = true;
208
- }
209
- return buildAll;
210
- }
211
-
212
- module.exports = {
213
- getFlattenedDependencyTree,
214
- createDependencyLists,
215
- alignWithBuilderApi
216
- };