@angular-devkit/core 0.0.10 → 0.0.15

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.
Files changed (54) hide show
  1. package/{src/logger → node}/cli-logger.d.ts +2 -2
  2. package/node/cli-logger.js +43 -0
  3. package/node/fs.d.ts +1 -0
  4. package/node/fs.js +25 -0
  5. package/node/index.d.ts +11 -0
  6. package/node/index.js +17 -0
  7. package/node/resolve.d.ts +58 -0
  8. package/node/resolve.js +214 -0
  9. package/package.json +4 -2
  10. package/src/index.d.ts +3 -1
  11. package/src/index.js +4 -2
  12. package/src/json/index.d.ts +2 -0
  13. package/src/json/index.js +3 -1
  14. package/src/json/schema/index.d.ts +14 -0
  15. package/src/json/schema/index.js +19 -0
  16. package/src/json/schema/registry.d.ts +19 -0
  17. package/src/json/schema/registry.js +34 -0
  18. package/src/json/schema/schema.d.ts +83 -0
  19. package/src/json/schema/schema.js +3 -0
  20. package/src/json/schema/serializers/interface.d.ts +11 -0
  21. package/src/json/schema/serializers/interface.js +6 -0
  22. package/src/json/schema/serializers/javascript.d.ts +46 -0
  23. package/src/json/schema/serializers/javascript.js +94 -0
  24. package/src/json/schema/serializers/javascript_benchmark.d.ts +0 -0
  25. package/src/json/schema/serializers/javascript_benchmark.js +45 -0
  26. package/src/json/schema/serializers/templates/javascript/index.d.ts +11 -0
  27. package/src/json/schema/serializers/templates/javascript/index.js +21 -0
  28. package/src/json/schema/serializers/templates/javascript/prop-any.js +40 -0
  29. package/src/json/schema/serializers/templates/javascript/prop-array.js +166 -0
  30. package/src/json/schema/serializers/templates/javascript/prop-boolean.js +54 -0
  31. package/src/json/schema/serializers/templates/javascript/prop-number.js +130 -0
  32. package/src/json/schema/serializers/templates/javascript/prop-object.js +231 -0
  33. package/src/json/schema/serializers/templates/javascript/prop-string.js +98 -0
  34. package/src/json/schema/serializers/templates/javascript/root.js +41 -0
  35. package/src/json/schema/serializers/templates/javascript/subschema.js +65 -0
  36. package/src/logger/index.d.ts +0 -1
  37. package/src/logger/index.js +1 -2
  38. package/src/logger/logger.d.ts +12 -1
  39. package/src/logger/logger.js +17 -1
  40. package/src/logger/null-logger.d.ts +2 -1
  41. package/src/logger/null-logger.js +12 -1
  42. package/src/utils/index.d.ts +3 -0
  43. package/src/utils/index.js +4 -1
  44. package/src/utils/literals.d.ts +12 -0
  45. package/src/utils/literals.js +42 -0
  46. package/src/utils/template.d.ts +82 -0
  47. package/src/utils/template.js +258 -0
  48. package/src/virtual-fs/index.d.ts +8 -0
  49. package/src/virtual-fs/index.js +14 -0
  50. package/src/virtual-fs/path.d.ts +90 -0
  51. package/src/virtual-fs/path.js +233 -0
  52. package/src/virtual-fs/path_benchmark.d.ts +0 -0
  53. package/src/virtual-fs/path_benchmark.js +18 -0
  54. package/src/logger/cli-logger.js +0 -44
@@ -0,0 +1,90 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import { BaseException } from '@angular-devkit/core';
9
+ export declare class InvalidPathException extends BaseException {
10
+ constructor(path: string);
11
+ }
12
+ export declare class PathMustBeAbsoluteException extends BaseException {
13
+ constructor(path: string);
14
+ }
15
+ /**
16
+ * A Path recognized by most methods in the DevKit.
17
+ */
18
+ export declare type Path = string & {
19
+ __PRIVATE_DEVKIT_PATH: void;
20
+ };
21
+ /**
22
+ * The Separator for normalized path.
23
+ * @type {Path}
24
+ */
25
+ export declare const NormalizedSep: Path;
26
+ /**
27
+ * The root of a normalized path.
28
+ * @type {Path}
29
+ */
30
+ export declare const NormalizedRoot: Path;
31
+ /**
32
+ * Split a path into multiple path fragments. Each fragments except the last one will end with
33
+ * a path separator.
34
+ * @param {Path} path The path to split.
35
+ * @returns {Path[]} An array of path fragments.
36
+ */
37
+ export declare function split(path: Path): Path[];
38
+ /**
39
+ *
40
+ */
41
+ export declare function extname(path: Path): string;
42
+ /**
43
+ * This is the equivalent of calling dirname() over and over, until the root, then getting the
44
+ * basename.
45
+ *
46
+ * @example rootname('/a/b/c') == 'a'
47
+ * @example rootname('a/b') == '.'
48
+ * @param path The path to get the rootname from.
49
+ * @returns {Path} The first directory name.
50
+ */
51
+ export declare function rootname(path: Path): Path;
52
+ /**
53
+ * Return the basename of the path, as a Path. See path.basename
54
+ */
55
+ export declare function basename(path: Path): Path;
56
+ /**
57
+ * Return the dirname of the path, as a Path. See path.dirname
58
+ */
59
+ export declare function dirname(path: Path): Path;
60
+ /**
61
+ * Join multiple paths together, and normalize the result. Accepts strings that will be
62
+ * normalized as well (but the original must be a path).
63
+ */
64
+ export declare function join(p1: Path, ...others: string[]): Path;
65
+ /**
66
+ * Returns true if a path is absolute.
67
+ */
68
+ export declare function isAbsolute(p: Path): boolean;
69
+ /**
70
+ * Returns a path such that `join(from, relative(from, to)) == to`.
71
+ * Both paths must be absolute, otherwise it does not make much sense.
72
+ */
73
+ export declare function relative(from: Path, to: Path): Path;
74
+ /**
75
+ * Returns a Path that is the resolution of p2, from p1. If p2 is absolute, it will return p2,
76
+ * otherwise will join both p1 and p2.
77
+ */
78
+ export declare function resolve(p1: Path, p2: Path): Path;
79
+ /**
80
+ * Normalize a string into a Path. This is the only mean to get a Path type from a string that
81
+ * represents a system path. Normalization includes:
82
+ * - Windows backslashes `\\` are replaced with `/`.
83
+ * - Windows drivers are replaced with `/X/`, where X is the drive letter.
84
+ * - Absolute paths starts with `/`.
85
+ * - Multiple `/` are replaced by a single one.
86
+ * - Path segments `.` are removed.
87
+ * - Path segments `..` are resolved.
88
+ * - If a path is absolute, having a `..` at the start is invalid (and will throw).
89
+ */
90
+ export declare function normalize(path: string): Path;
@@ -0,0 +1,233 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ /**
4
+ * @license
5
+ * Copyright Google Inc. All Rights Reserved.
6
+ *
7
+ * Use of this source code is governed by an MIT-style license that can be
8
+ * found in the LICENSE file at https://angular.io/license
9
+ */
10
+ const core_1 = require("@angular-devkit/core");
11
+ class InvalidPathException extends core_1.BaseException {
12
+ constructor(path) { super(`Path ${JSON.stringify(path)} is invalid.`); }
13
+ }
14
+ exports.InvalidPathException = InvalidPathException;
15
+ class PathMustBeAbsoluteException extends core_1.BaseException {
16
+ constructor(path) { super(`Path ${JSON.stringify(path)} must be absolute.`); }
17
+ }
18
+ exports.PathMustBeAbsoluteException = PathMustBeAbsoluteException;
19
+ /**
20
+ * The Separator for normalized path.
21
+ * @type {Path}
22
+ */
23
+ exports.NormalizedSep = '/';
24
+ /**
25
+ * The root of a normalized path.
26
+ * @type {Path}
27
+ */
28
+ exports.NormalizedRoot = exports.NormalizedSep;
29
+ /**
30
+ * Split a path into multiple path fragments. Each fragments except the last one will end with
31
+ * a path separator.
32
+ * @param {Path} path The path to split.
33
+ * @returns {Path[]} An array of path fragments.
34
+ */
35
+ function split(path) {
36
+ const arr = path.split(exports.NormalizedSep);
37
+ return arr.map((fragment, i) => fragment + (i < arr.length - 1 ? exports.NormalizedSep : ''));
38
+ }
39
+ exports.split = split;
40
+ /**
41
+ *
42
+ */
43
+ function extname(path) {
44
+ const base = basename(path);
45
+ const i = base.lastIndexOf('.');
46
+ if (i < 1) {
47
+ return '';
48
+ }
49
+ else {
50
+ return base.substr(i);
51
+ }
52
+ }
53
+ exports.extname = extname;
54
+ /**
55
+ * This is the equivalent of calling dirname() over and over, until the root, then getting the
56
+ * basename.
57
+ *
58
+ * @example rootname('/a/b/c') == 'a'
59
+ * @example rootname('a/b') == '.'
60
+ * @param path The path to get the rootname from.
61
+ * @returns {Path} The first directory name.
62
+ */
63
+ function rootname(path) {
64
+ const i = path.indexOf(exports.NormalizedSep);
65
+ if (!isAbsolute(path)) {
66
+ return '.';
67
+ }
68
+ else if (i == -1) {
69
+ return path;
70
+ }
71
+ else {
72
+ return path.substr(path.lastIndexOf(exports.NormalizedSep) + 1);
73
+ }
74
+ }
75
+ exports.rootname = rootname;
76
+ /**
77
+ * Return the basename of the path, as a Path. See path.basename
78
+ */
79
+ function basename(path) {
80
+ const i = path.lastIndexOf(exports.NormalizedSep);
81
+ if (i == -1) {
82
+ return path;
83
+ }
84
+ else {
85
+ return path.substr(path.lastIndexOf(exports.NormalizedSep) + 1);
86
+ }
87
+ }
88
+ exports.basename = basename;
89
+ /**
90
+ * Return the dirname of the path, as a Path. See path.dirname
91
+ */
92
+ function dirname(path) {
93
+ const i = path.lastIndexOf(exports.NormalizedSep);
94
+ if (i == -1) {
95
+ return '';
96
+ }
97
+ else {
98
+ return normalize(path.substr(0, i));
99
+ }
100
+ }
101
+ exports.dirname = dirname;
102
+ /**
103
+ * Join multiple paths together, and normalize the result. Accepts strings that will be
104
+ * normalized as well (but the original must be a path).
105
+ */
106
+ function join(p1, ...others) {
107
+ if (others.length > 0) {
108
+ return normalize((p1 ? p1 + exports.NormalizedSep : '') + others.join(exports.NormalizedSep));
109
+ }
110
+ else {
111
+ return p1;
112
+ }
113
+ }
114
+ exports.join = join;
115
+ /**
116
+ * Returns true if a path is absolute.
117
+ */
118
+ function isAbsolute(p) {
119
+ return p.startsWith(exports.NormalizedSep);
120
+ }
121
+ exports.isAbsolute = isAbsolute;
122
+ /**
123
+ * Returns a path such that `join(from, relative(from, to)) == to`.
124
+ * Both paths must be absolute, otherwise it does not make much sense.
125
+ */
126
+ function relative(from, to) {
127
+ if (!isAbsolute(from)) {
128
+ throw new PathMustBeAbsoluteException(from);
129
+ }
130
+ if (!isAbsolute(to)) {
131
+ throw new PathMustBeAbsoluteException(to);
132
+ }
133
+ let p;
134
+ if (from == to) {
135
+ p = '';
136
+ }
137
+ else {
138
+ const splitFrom = from.split(exports.NormalizedSep);
139
+ const splitTo = to.split(exports.NormalizedSep);
140
+ while (splitFrom.length > 0 && splitTo.length > 0 && splitFrom[0] == splitTo[0]) {
141
+ splitFrom.shift();
142
+ splitTo.shift();
143
+ }
144
+ if (splitFrom.length == 0) {
145
+ p = splitTo.join(exports.NormalizedSep);
146
+ }
147
+ else {
148
+ p = splitFrom.map(_ => '..').concat(splitTo).join(exports.NormalizedSep);
149
+ }
150
+ }
151
+ return normalize(p);
152
+ }
153
+ exports.relative = relative;
154
+ /**
155
+ * Returns a Path that is the resolution of p2, from p1. If p2 is absolute, it will return p2,
156
+ * otherwise will join both p1 and p2.
157
+ */
158
+ function resolve(p1, p2) {
159
+ if (isAbsolute(p2)) {
160
+ return p2;
161
+ }
162
+ else {
163
+ return join(p1, p2);
164
+ }
165
+ }
166
+ exports.resolve = resolve;
167
+ /**
168
+ * Normalize a string into a Path. This is the only mean to get a Path type from a string that
169
+ * represents a system path. Normalization includes:
170
+ * - Windows backslashes `\\` are replaced with `/`.
171
+ * - Windows drivers are replaced with `/X/`, where X is the drive letter.
172
+ * - Absolute paths starts with `/`.
173
+ * - Multiple `/` are replaced by a single one.
174
+ * - Path segments `.` are removed.
175
+ * - Path segments `..` are resolved.
176
+ * - If a path is absolute, having a `..` at the start is invalid (and will throw).
177
+ */
178
+ function normalize(path) {
179
+ if (path == '' || path == '.') {
180
+ return '';
181
+ }
182
+ else if (path == exports.NormalizedRoot) {
183
+ return exports.NormalizedRoot;
184
+ }
185
+ // Match absolute windows path.
186
+ const original = path;
187
+ if (path.match(/^[A-Z]:\\/)) {
188
+ path = '\\' + path[0] + '\\' + path.substr(3);
189
+ }
190
+ // We convert Windows paths as well here.
191
+ const p = path.split(/[\/\\]/g);
192
+ let relative = false;
193
+ let i = 1;
194
+ // Special case the first one.
195
+ if (p[0] != '') {
196
+ p.unshift('.');
197
+ relative = true;
198
+ }
199
+ while (i < p.length) {
200
+ if (p[i] == '.') {
201
+ p.splice(i, 1);
202
+ }
203
+ else if (p[i] == '..') {
204
+ if (i < 2 && !relative) {
205
+ throw new InvalidPathException(original);
206
+ }
207
+ else if (i >= 2 && p[i - 1] != '..') {
208
+ p.splice(i - 1, 2);
209
+ i--;
210
+ }
211
+ else {
212
+ i++;
213
+ }
214
+ }
215
+ else if (p[i] == '') {
216
+ p.splice(i, 1);
217
+ }
218
+ else {
219
+ i++;
220
+ }
221
+ }
222
+ if (p.length == 1) {
223
+ return p[0] == '' ? exports.NormalizedSep : '';
224
+ }
225
+ else {
226
+ if (p[0] == '.') {
227
+ p.shift();
228
+ }
229
+ return p.join(exports.NormalizedSep);
230
+ }
231
+ }
232
+ exports.normalize = normalize;
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"path.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/core/src/virtual-fs/path.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { BaseException } from '@angular-devkit/core';\n\n\nexport class InvalidPathException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} is invalid.`); }\n}\nexport class PathMustBeAbsoluteException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} must be absolute.`); }\n}\n\n\n/**\n * A Path recognized by most methods in the DevKit.\n */\nexport type Path = string & {\n  __PRIVATE_DEVKIT_PATH: void;\n};\n\n\n/**\n * The Separator for normalized path.\n * @type {Path}\n */\nexport const NormalizedSep = '/' as Path;\n\n\n/**\n * The root of a normalized path.\n * @type {Path}\n */\nexport const NormalizedRoot = NormalizedSep as Path;\n\n\n/**\n * Split a path into multiple path fragments. Each fragments except the last one will end with\n * a path separator.\n * @param {Path} path The path to split.\n * @returns {Path[]} An array of path fragments.\n */\nexport function split(path: Path): Path[] {\n  const arr = path.split(NormalizedSep);\n\n  return arr.map((fragment, i) => fragment + (i < arr.length - 1 ? NormalizedSep : '')) as Path[];\n}\n\n/**\n *\n */\nexport function extname(path: Path): string {\n  const base = basename(path);\n  const i = base.lastIndexOf('.');\n  if (i < 1) {\n    return '';\n  } else {\n    return base.substr(i);\n  }\n}\n\n/**\n * This is the equivalent of calling dirname() over and over, until the root, then getting the\n * basename.\n *\n * @example rootname('/a/b/c') == 'a'\n * @example rootname('a/b') == '.'\n * @param path The path to get the rootname from.\n * @returns {Path} The first directory name.\n */\nexport function rootname(path: Path): Path {\n  const i = path.indexOf(NormalizedSep);\n  if (!isAbsolute(path)) {\n    return '.' as Path;\n  } else if (i == -1) {\n    return path;\n  } else {\n    return path.substr(path.lastIndexOf(NormalizedSep) + 1) as Path;\n  }\n}\n\n\n/**\n * Return the basename of the path, as a Path. See path.basename\n */\nexport function basename(path: Path): Path {\n  const i = path.lastIndexOf(NormalizedSep);\n  if (i == -1) {\n    return path;\n  } else {\n    return path.substr(path.lastIndexOf(NormalizedSep) + 1) as Path;\n  }\n}\n\n\n/**\n * Return the dirname of the path, as a Path. See path.dirname\n */\nexport function dirname(path: Path): Path {\n  const i = path.lastIndexOf(NormalizedSep);\n  if (i == -1) {\n    return '' as Path;\n  } else {\n    return normalize(path.substr(0, i));\n  }\n}\n\n\n/**\n * Join multiple paths together, and normalize the result. Accepts strings that will be\n * normalized as well (but the original must be a path).\n */\nexport function join(p1: Path, ...others: string[]): Path {\n  if (others.length > 0) {\n    return normalize((p1 ? p1 + NormalizedSep : '') + others.join(NormalizedSep));\n  } else {\n    return p1;\n  }\n}\n\n\n/**\n * Returns true if a path is absolute.\n */\nexport function isAbsolute(p: Path) {\n  return p.startsWith(NormalizedSep);\n}\n\n\n/**\n * Returns a path such that `join(from, relative(from, to)) == to`.\n * Both paths must be absolute, otherwise it does not make much sense.\n */\nexport function relative(from: Path, to: Path): Path {\n  if (!isAbsolute(from)) {\n    throw new PathMustBeAbsoluteException(from);\n  }\n  if (!isAbsolute(to)) {\n    throw new PathMustBeAbsoluteException(to);\n  }\n\n  let p: string;\n\n  if (from == to) {\n    p = '';\n  } else {\n    const splitFrom = from.split(NormalizedSep);\n    const splitTo = to.split(NormalizedSep);\n\n    while (splitFrom.length > 0 && splitTo.length > 0 && splitFrom[0] == splitTo[0]) {\n      splitFrom.shift();\n      splitTo.shift();\n    }\n\n    if (splitFrom.length == 0) {\n      p = splitTo.join(NormalizedSep);\n    } else {\n      p = splitFrom.map(_ => '..').concat(splitTo).join(NormalizedSep);\n    }\n  }\n\n  return normalize(p);\n}\n\n\n/**\n * Returns a Path that is the resolution of p2, from p1. If p2 is absolute, it will return p2,\n * otherwise will join both p1 and p2.\n */\nexport function resolve(p1: Path, p2: Path) {\n  if (isAbsolute(p2)) {\n    return p2;\n  } else {\n    return join(p1, p2);\n  }\n}\n\n\n/**\n * Normalize a string into a Path. This is the only mean to get a Path type from a string that\n * represents a system path. Normalization includes:\n *   - Windows backslashes `\\\\` are replaced with `/`.\n *   - Windows drivers are replaced with `/X/`, where X is the drive letter.\n *   - Absolute paths starts with `/`.\n *   - Multiple `/` are replaced by a single one.\n *   - Path segments `.` are removed.\n *   - Path segments `..` are resolved.\n *   - If a path is absolute, having a `..` at the start is invalid (and will throw).\n */\nexport function normalize(path: string): Path {\n  if (path == '' || path == '.') {\n    return '' as Path;\n  } else if (path == NormalizedRoot) {\n    return NormalizedRoot;\n  }\n\n  // Match absolute windows path.\n  const original = path;\n  if (path.match(/^[A-Z]:\\\\/)) {\n    path = '\\\\' + path[0] + '\\\\' + path.substr(3);\n  }\n\n  // We convert Windows paths as well here.\n  const p = path.split(/[\\/\\\\]/g);\n  let relative = false;\n  let i = 1;\n\n  // Special case the first one.\n  if (p[0] != '') {\n    p.unshift('.');\n    relative = true;\n  }\n\n  while (i < p.length) {\n    if (p[i] == '.') {\n      p.splice(i, 1);\n    } else if (p[i] == '..') {\n      if (i < 2 && !relative) {\n        throw new InvalidPathException(original);\n      } else if (i >= 2 && p[i - 1] != '..') {\n        p.splice(i - 1, 2);\n        i--;\n      } else {\n        i++;\n      }\n    } else if (p[i] == '') {\n      p.splice(i, 1);\n    } else {\n      i++;\n    }\n  }\n\n  if (p.length == 1) {\n    return p[0] == '' ? NormalizedSep : '' as Path;\n  } else {\n    if (p[0] == '.') {\n      p.shift();\n    }\n\n    return p.join(NormalizedSep) as Path;\n  }\n}\n"]}
File without changes
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ /**
4
+ * @license
5
+ * Copyright Google Inc. All Rights Reserved.
6
+ *
7
+ * Use of this source code is governed by an MIT-style license that can be
8
+ * found in the LICENSE file at https://angular.io/license
9
+ */
10
+ const benchmark_1 = require("@_/benchmark");
11
+ const path_1 = require("./path");
12
+ const p1 = '/b/././a/tt/../../../a/b/./d/../c';
13
+ const p2 = '/a/tt/../../../a/b/./d';
14
+ describe('Virtual FS Path', () => {
15
+ benchmark_1.benchmark('normalize', () => path_1.normalize(p1));
16
+ benchmark_1.benchmark('join', () => path_1.join(path_1.normalize(p1), path_1.normalize(p2)));
17
+ });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0aF9iZW5jaG1hcmsuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL2hhbnNsL1NvdXJjZXMvZGV2a2l0LyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvY29yZS9zcmMvdmlydHVhbC1mcy9wYXRoX2JlbmNobWFyay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7R0FNRztBQUNILDRDQUF5QztBQUN6QyxpQ0FBeUM7QUFHekMsTUFBTSxFQUFFLEdBQUcsbUNBQW1DLENBQUM7QUFDL0MsTUFBTSxFQUFFLEdBQUcsd0JBQXdCLENBQUM7QUFHcEMsUUFBUSxDQUFDLGlCQUFpQixFQUFFO0lBQzFCLHFCQUFTLENBQUMsV0FBVyxFQUFFLE1BQU0sZ0JBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzVDLHFCQUFTLENBQUMsTUFBTSxFQUFFLE1BQU0sV0FBSSxDQUFDLGdCQUFTLENBQUMsRUFBRSxDQUFDLEVBQUUsZ0JBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDOUQsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyBiZW5jaG1hcmsgfSBmcm9tICdAXy9iZW5jaG1hcmsnO1xuaW1wb3J0IHsgam9pbiwgbm9ybWFsaXplIH0gZnJvbSAnLi9wYXRoJztcblxuXG5jb25zdCBwMSA9ICcvYi8uLy4vYS90dC8uLi8uLi8uLi9hL2IvLi9kLy4uL2MnO1xuY29uc3QgcDIgPSAnL2EvdHQvLi4vLi4vLi4vYS9iLy4vZCc7XG5cblxuZGVzY3JpYmUoJ1ZpcnR1YWwgRlMgUGF0aCcsICgpID0+IHtcbiAgYmVuY2htYXJrKCdub3JtYWxpemUnLCAoKSA9PiBub3JtYWxpemUocDEpKTtcbiAgYmVuY2htYXJrKCdqb2luJywgKCkgPT4gam9pbihub3JtYWxpemUocDEpLCBub3JtYWxpemUocDIpKSk7XG59KTtcbiJdfQ==
@@ -1,44 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- /**
4
- * @license
5
- * Copyright Google Inc. All Rights Reserved.
6
- *
7
- * Use of this source code is governed by an MIT-style license that can be
8
- * found in the LICENSE file at https://angular.io/license
9
- */
10
- require("rxjs/add/operator/filter");
11
- const terminal_1 = require("../terminal");
12
- const indent_1 = require("./indent");
13
- /**
14
- * A Logger that sends information to STDOUT and STDERR.
15
- */
16
- function createLogger(verbose = false) {
17
- const logger = new indent_1.IndentLogger('cling');
18
- logger
19
- .filter((entry) => (entry.level != 'debug' || verbose))
20
- .subscribe((entry) => {
21
- let color = x => terminal_1.dim(terminal_1.white(x));
22
- let output = process.stdout;
23
- switch (entry.level) {
24
- case 'info':
25
- color = terminal_1.white;
26
- break;
27
- case 'warn':
28
- color = terminal_1.yellow;
29
- break;
30
- case 'error':
31
- color = terminal_1.red;
32
- output = process.stderr;
33
- break;
34
- case 'fatal':
35
- color = (x) => terminal_1.bold(terminal_1.red(x));
36
- output = process.stderr;
37
- break;
38
- }
39
- output.write(color(entry.message) + '\n');
40
- });
41
- return logger;
42
- }
43
- exports.createLogger = createLogger;
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpLWxvZ2dlci5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvaGFuc2wvU291cmNlcy9kZXZraXQvIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9jb3JlL3NyYy9sb2dnZXIvY2xpLWxvZ2dlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7R0FNRztBQUNILG9DQUFrQztBQUNsQywwQ0FBNEQ7QUFDNUQscUNBQXdDO0FBSXhDOztHQUVHO0FBQ0gsc0JBQTZCLE9BQU8sR0FBRyxLQUFLO0lBQzFDLE1BQU0sTUFBTSxHQUFHLElBQUkscUJBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUV6QyxNQUFNO1NBQ0gsTUFBTSxDQUFDLENBQUMsS0FBZSxLQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxPQUFPLElBQUksT0FBTyxDQUFDLENBQUM7U0FDaEUsU0FBUyxDQUFDLENBQUMsS0FBZTtRQUN6QixJQUFJLEtBQUssR0FBMEIsQ0FBQyxJQUFJLGNBQUcsQ0FBQyxnQkFBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEQsSUFBSSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztRQUM1QixNQUFNLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUNwQixLQUFLLE1BQU07Z0JBQ1QsS0FBSyxHQUFHLGdCQUFLLENBQUM7Z0JBQ2QsS0FBSyxDQUFDO1lBQ1IsS0FBSyxNQUFNO2dCQUNULEtBQUssR0FBRyxpQkFBTSxDQUFDO2dCQUNmLEtBQUssQ0FBQztZQUNSLEtBQUssT0FBTztnQkFDVixLQUFLLEdBQUcsY0FBRyxDQUFDO2dCQUNaLE1BQU0sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDO2dCQUN4QixLQUFLLENBQUM7WUFDUixLQUFLLE9BQU87Z0JBQ1YsS0FBSyxHQUFHLENBQUMsQ0FBUyxLQUFLLGVBQUksQ0FBQyxjQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDcEMsTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUM7Z0JBQ3hCLEtBQUssQ0FBQztRQUNWLENBQUM7UUFFRCxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDNUMsQ0FBQyxDQUFDLENBQUM7SUFFTCxNQUFNLENBQUMsTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUE3QkQsb0NBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0ICdyeGpzL2FkZC9vcGVyYXRvci9maWx0ZXInO1xuaW1wb3J0IHsgYm9sZCwgZGltLCByZWQsIHdoaXRlLCB5ZWxsb3cgfSBmcm9tICcuLi90ZXJtaW5hbCc7XG5pbXBvcnQgeyBJbmRlbnRMb2dnZXIgfSBmcm9tICcuL2luZGVudCc7XG5pbXBvcnQgeyBMb2dFbnRyeSwgTG9nZ2VyIH0gZnJvbSAnLi9sb2dnZXInO1xuXG5cbi8qKlxuICogQSBMb2dnZXIgdGhhdCBzZW5kcyBpbmZvcm1hdGlvbiB0byBTVERPVVQgYW5kIFNUREVSUi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUxvZ2dlcih2ZXJib3NlID0gZmFsc2UpOiBMb2dnZXIge1xuICBjb25zdCBsb2dnZXIgPSBuZXcgSW5kZW50TG9nZ2VyKCdjbGluZycpO1xuXG4gIGxvZ2dlclxuICAgIC5maWx0ZXIoKGVudHJ5OiBMb2dFbnRyeSkgPT4gKGVudHJ5LmxldmVsICE9ICdkZWJ1ZycgfHwgdmVyYm9zZSkpXG4gICAgLnN1YnNjcmliZSgoZW50cnk6IExvZ0VudHJ5KSA9PiB7XG4gICAgICBsZXQgY29sb3I6IChzOiBzdHJpbmcpID0+IHN0cmluZyA9IHggPT4gZGltKHdoaXRlKHgpKTtcbiAgICAgIGxldCBvdXRwdXQgPSBwcm9jZXNzLnN0ZG91dDtcbiAgICAgIHN3aXRjaCAoZW50cnkubGV2ZWwpIHtcbiAgICAgICAgY2FzZSAnaW5mbyc6XG4gICAgICAgICAgY29sb3IgPSB3aGl0ZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnd2Fybic6XG4gICAgICAgICAgY29sb3IgPSB5ZWxsb3c7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ2Vycm9yJzpcbiAgICAgICAgICBjb2xvciA9IHJlZDtcbiAgICAgICAgICBvdXRwdXQgPSBwcm9jZXNzLnN0ZGVycjtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnZmF0YWwnOlxuICAgICAgICAgIGNvbG9yID0gKHg6IHN0cmluZykgPT4gYm9sZChyZWQoeCkpO1xuICAgICAgICAgIG91dHB1dCA9IHByb2Nlc3Muc3RkZXJyO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgfVxuXG4gICAgICBvdXRwdXQud3JpdGUoY29sb3IoZW50cnkubWVzc2FnZSkgKyAnXFxuJyk7XG4gICAgfSk7XG5cbiAgcmV0dXJuIGxvZ2dlcjtcbn1cbiJdfQ==