@ui5/cli 3.0.0-alpha.5 → 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/CHANGELOG.md +30 -1
- package/lib/cli/commands/add.js +4 -4
- package/lib/cli/commands/base.js +9 -5
- package/lib/cli/commands/build.js +52 -62
- package/lib/cli/commands/remove.js +4 -4
- package/lib/cli/commands/serve.js +16 -14
- package/lib/cli/commands/tree.js +80 -45
- package/lib/cli/commands/use.js +4 -4
- package/lib/framework/add.js +27 -20
- package/lib/framework/remove.js +14 -13
- package/lib/framework/updateYaml.js +14 -4
- package/lib/framework/use.js +10 -12
- package/lib/framework/utils.js +14 -10
- package/npm-shrinkwrap.json +572 -733
- package/package.json +7 -7
- package/lib/utils/buildHelper.js +0 -216
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ui5/cli",
|
|
3
|
-
"version": "3.0.0-alpha.
|
|
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.
|
|
112
|
-
"@ui5/fs": "^3.0.0-alpha.
|
|
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.
|
|
115
|
-
"@ui5/server": "^3.0.0-alpha.
|
|
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
|
},
|
package/lib/utils/buildHelper.js
DELETED
|
@@ -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
|
-
};
|