ng2-logger 13.1.1 → 13.1.2
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/README.md +206 -206
- package/app/index.d.ts +4 -4
- package/app/index.js +19 -19
- package/app/ng2-logger.component.d.ts +5 -5
- package/app/ng2-logger.component.js +33 -33
- package/app/ng2-logger.module.d.ts +2 -2
- package/app/ng2-logger.module.js +30 -30
- package/browser/README.md +24 -24
- package/browser/esm2020/lib/backend-logging.mjs +91 -91
- package/browser/esm2020/lib/display.mjs +96 -96
- package/browser/esm2020/lib/helpers.mjs +1 -1
- package/browser/esm2020/lib/index.mjs +5 -5
- package/browser/esm2020/lib/level.mjs +30 -30
- package/browser/esm2020/lib/log.mjs +163 -163
- package/browser/esm2020/lib/logger.mjs +234 -234
- package/browser/esm2020/ng2-logger.mjs +4 -4
- package/browser/esm2020/public-api.mjs +1 -1
- package/browser/fesm2015/ng2-logger.mjs +512 -512
- package/browser/fesm2020/ng2-logger.mjs +512 -512
- package/browser/lib/backend-logging.d.ts +4 -4
- package/browser/lib/display.d.ts +4 -4
- package/browser/lib/helpers.d.ts +1 -1
- package/browser/lib/index.d.ts +5 -5
- package/browser/lib/level.d.ts +21 -21
- package/browser/lib/log.d.ts +25 -25
- package/browser/lib/logger.d.ts +81 -81
- package/browser/ng2-logger.d.ts +5 -5
- package/browser/public-api.d.ts +1 -1
- package/client/README.md +24 -24
- package/client/esm2020/lib/backend-logging.mjs +91 -91
- package/client/esm2020/lib/display.mjs +96 -96
- package/client/esm2020/lib/helpers.mjs +1 -1
- package/client/esm2020/lib/index.mjs +5 -5
- package/client/esm2020/lib/level.mjs +30 -30
- package/client/esm2020/lib/log.mjs +163 -163
- package/client/esm2020/lib/logger.mjs +234 -234
- package/client/esm2020/ng2-logger.mjs +4 -4
- package/client/esm2020/public-api.mjs +1 -1
- package/client/fesm2015/ng2-logger.mjs +512 -512
- package/client/fesm2020/ng2-logger.mjs +512 -512
- package/client/lib/backend-logging.d.ts +4 -4
- package/client/lib/display.d.ts +4 -4
- package/client/lib/helpers.d.ts +1 -1
- package/client/lib/index.d.ts +5 -5
- package/client/lib/level.d.ts +21 -21
- package/client/lib/log.d.ts +25 -25
- package/client/lib/logger.d.ts +81 -81
- package/client/ng2-logger.d.ts +5 -5
- package/client/public-api.d.ts +1 -1
- package/index.d.ts +1 -1
- package/index.js +5 -5
- package/lib/backend-logging.d.ts +4 -4
- package/lib/backend-logging.js +115 -115
- package/lib/display.d.ts +4 -4
- package/lib/display.js +104 -104
- package/lib/helpers.d.ts +1 -1
- package/lib/helpers.js +6 -6
- package/lib/index.d.ts +5 -5
- package/lib/index.js +9 -9
- package/lib/level.d.ts +21 -21
- package/lib/level.js +35 -35
- package/lib/log.d.ts +25 -25
- package/lib/log.js +197 -197
- package/lib/logger.d.ts +81 -81
- package/lib/logger.js +340 -340
- package/package.json +3 -3
- package/package.json_devDependencies.json +184 -184
- package/package.json_tnp.json5 +47 -47
- package/tmp-environment.json +15 -14
- package/websql/README.md +24 -24
- package/websql/esm2020/lib/backend-logging.mjs +91 -91
- package/websql/esm2020/lib/display.mjs +96 -96
- package/websql/esm2020/lib/helpers.mjs +1 -1
- package/websql/esm2020/lib/index.mjs +5 -5
- package/websql/esm2020/lib/level.mjs +30 -30
- package/websql/esm2020/lib/log.mjs +163 -163
- package/websql/esm2020/lib/logger.mjs +234 -234
- package/websql/esm2020/ng2-logger.mjs +4 -4
- package/websql/esm2020/public-api.mjs +1 -1
- package/websql/fesm2015/ng2-logger.mjs +512 -512
- package/websql/fesm2020/ng2-logger.mjs +512 -512
- package/websql/lib/backend-logging.d.ts +4 -4
- package/websql/lib/display.d.ts +4 -4
- package/websql/lib/helpers.d.ts +1 -1
- package/websql/lib/index.d.ts +5 -5
- package/websql/lib/level.d.ts +21 -21
- package/websql/lib/log.d.ts +25 -25
- package/websql/lib/logger.d.ts +81 -81
- package/websql/ng2-logger.d.ts +5 -5
- package/websql/public-api.d.ts +1 -1
|
@@ -1,164 +1,164 @@
|
|
|
1
|
-
import { Logger } from './logger';
|
|
2
|
-
import { Level, LevelOrder, LevelKey } from './level';
|
|
3
|
-
import { Helpers } from 'tnp-core/websql';
|
|
4
|
-
/* */
|
|
5
|
-
/* */
|
|
6
|
-
/* */
|
|
7
|
-
/* */
|
|
8
|
-
/* */
|
|
9
|
-
export class Log {
|
|
10
|
-
//#region singleton
|
|
11
|
-
constructor() {
|
|
12
|
-
this._logOnly = false;
|
|
13
|
-
this._logModules = false;
|
|
14
|
-
this.isDevelopmentMode = true;
|
|
15
|
-
this.modeIsSet = false;
|
|
16
|
-
this.fixedWidth = 0;
|
|
17
|
-
this.instances = {};
|
|
18
|
-
this.levels = [];
|
|
19
|
-
this.modules = [];
|
|
20
|
-
}
|
|
21
|
-
// @ts-ignore
|
|
22
|
-
static get instance() {
|
|
23
|
-
// @ts-ignore
|
|
24
|
-
if (!Log['_instance']) {
|
|
25
|
-
// @ts-ignore
|
|
26
|
-
Log['_instance'] = new Log();
|
|
27
|
-
}
|
|
28
|
-
// @ts-ignore
|
|
29
|
-
return Log['_instance'];
|
|
30
|
-
}
|
|
31
|
-
static create(name, ...level) {
|
|
32
|
-
return Log.instance.create(name, ...level);
|
|
33
|
-
}
|
|
34
|
-
static disableLogs(level = Level.__NOTHING) {
|
|
35
|
-
/* */
|
|
36
|
-
/* */
|
|
37
|
-
/* */
|
|
38
|
-
/* */
|
|
39
|
-
/* */
|
|
40
|
-
/* */
|
|
41
|
-
/* */
|
|
42
|
-
LevelOrder.reverse().find(a => {
|
|
43
|
-
// @ts-ignore
|
|
44
|
-
if (!this.consolelogfn[a]) {
|
|
45
|
-
// @ts-ignore
|
|
46
|
-
this.consolelogfn[a] = console[a];
|
|
47
|
-
}
|
|
48
|
-
// @ts-ignore
|
|
49
|
-
console[a] = () => { };
|
|
50
|
-
if (a === LevelKey[level]) {
|
|
51
|
-
return true;
|
|
52
|
-
}
|
|
53
|
-
return false;
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
static enableLogs() {
|
|
57
|
-
/* */
|
|
58
|
-
/* */
|
|
59
|
-
/* */
|
|
60
|
-
/* */
|
|
61
|
-
LevelOrder.forEach(a => {
|
|
62
|
-
// @ts-ignore
|
|
63
|
-
console[a] = this.consolelogfn[a];
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
//#region public api
|
|
67
|
-
setProductionMode() {
|
|
68
|
-
if (this.modeIsSet) {
|
|
69
|
-
this.modeIsSet = false;
|
|
70
|
-
throw '[ng2-logger] Production mode is already set';
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
this.modeIsSet = true;
|
|
74
|
-
setTimeout(() => {
|
|
75
|
-
if (this.modeIsSet && console !== void 0 && console.clear !== void 0) {
|
|
76
|
-
console.clear();
|
|
77
|
-
console.log = () => { };
|
|
78
|
-
console.error = () => { };
|
|
79
|
-
console.warn = () => { };
|
|
80
|
-
console.info = () => { };
|
|
81
|
-
}
|
|
82
|
-
});
|
|
83
|
-
this.isDevelopmentMode = false;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
onlyModules(...modules) {
|
|
87
|
-
if (this._logModules) {
|
|
88
|
-
throw '[ng2-logger] You should use funcion onlyModules only once';
|
|
89
|
-
}
|
|
90
|
-
if (!this._logModules) {
|
|
91
|
-
this._logModules = true;
|
|
92
|
-
}
|
|
93
|
-
if (modules.length === 0)
|
|
94
|
-
return;
|
|
95
|
-
this.modules = modules;
|
|
96
|
-
// console.log('only log this', Log.modules)
|
|
97
|
-
this.muteAllOtherModules();
|
|
98
|
-
}
|
|
99
|
-
onlyLevel(...level) {
|
|
100
|
-
if (this._logOnly) {
|
|
101
|
-
throw '[ng2-logger] You should use funcion onlyLevel only once';
|
|
102
|
-
}
|
|
103
|
-
if (!this._logOnly) {
|
|
104
|
-
this._logOnly = true;
|
|
105
|
-
}
|
|
106
|
-
this.levels = Array.isArray(level) ? level : [level];
|
|
107
|
-
for (const logName in this.instances) {
|
|
108
|
-
if (this.instances.hasOwnProperty(logName)) {
|
|
109
|
-
const element = this.instances[logName];
|
|
110
|
-
element['allowed'] = this.levels;
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
//#endregion
|
|
115
|
-
create(name, ...level) {
|
|
116
|
-
let i;
|
|
117
|
-
if (Array.isArray(this.levels) && this.levels.length > 0) {
|
|
118
|
-
level = this.levels;
|
|
119
|
-
}
|
|
120
|
-
if (this.instances[name] === void 0) {
|
|
121
|
-
i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0);
|
|
122
|
-
this.instances[name] = i;
|
|
123
|
-
}
|
|
124
|
-
else {
|
|
125
|
-
i = this.instances[name];
|
|
126
|
-
}
|
|
127
|
-
return i;
|
|
128
|
-
}
|
|
129
|
-
isMutedModule(moduleName) {
|
|
130
|
-
if (this.modules.length == 0)
|
|
131
|
-
return false;
|
|
132
|
-
if (!Helpers.contain(this.modules, moduleName))
|
|
133
|
-
return true;
|
|
134
|
-
return false;
|
|
135
|
-
}
|
|
136
|
-
muteAllOtherModules() {
|
|
137
|
-
for (var moduleName in this.instances) {
|
|
138
|
-
if (!Helpers.contain(this.modules, moduleName))
|
|
139
|
-
this.instances[moduleName].mute();
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
//#endregion
|
|
144
|
-
Log.Logger = Logger;
|
|
145
|
-
Log.consolelogfn = {};
|
|
146
|
-
function getRandomColor() {
|
|
147
|
-
/* */
|
|
148
|
-
/* */
|
|
149
|
-
/* */
|
|
150
|
-
/* */
|
|
151
|
-
let letters = '012345'.split('');
|
|
152
|
-
let color = '#';
|
|
153
|
-
color += letters[Math.round(Math.random() * 5)];
|
|
154
|
-
letters = '0123456789ABCDEF'.split('');
|
|
155
|
-
for (let i = 0; i < 5; i++) {
|
|
156
|
-
color += letters[Math.round(Math.random() * 15)];
|
|
157
|
-
}
|
|
158
|
-
if (color === void 0) {
|
|
159
|
-
return getRandomColor();
|
|
160
|
-
}
|
|
161
|
-
;
|
|
162
|
-
return color;
|
|
163
|
-
}
|
|
1
|
+
import { Logger } from './logger';
|
|
2
|
+
import { Level, LevelOrder, LevelKey } from './level';
|
|
3
|
+
import { Helpers } from 'tnp-core/websql';
|
|
4
|
+
/* */
|
|
5
|
+
/* */
|
|
6
|
+
/* */
|
|
7
|
+
/* */
|
|
8
|
+
/* */
|
|
9
|
+
export class Log {
|
|
10
|
+
//#region singleton
|
|
11
|
+
constructor() {
|
|
12
|
+
this._logOnly = false;
|
|
13
|
+
this._logModules = false;
|
|
14
|
+
this.isDevelopmentMode = true;
|
|
15
|
+
this.modeIsSet = false;
|
|
16
|
+
this.fixedWidth = 0;
|
|
17
|
+
this.instances = {};
|
|
18
|
+
this.levels = [];
|
|
19
|
+
this.modules = [];
|
|
20
|
+
}
|
|
21
|
+
// @ts-ignore
|
|
22
|
+
static get instance() {
|
|
23
|
+
// @ts-ignore
|
|
24
|
+
if (!Log['_instance']) {
|
|
25
|
+
// @ts-ignore
|
|
26
|
+
Log['_instance'] = new Log();
|
|
27
|
+
}
|
|
28
|
+
// @ts-ignore
|
|
29
|
+
return Log['_instance'];
|
|
30
|
+
}
|
|
31
|
+
static create(name, ...level) {
|
|
32
|
+
return Log.instance.create(name, ...level);
|
|
33
|
+
}
|
|
34
|
+
static disableLogs(level = Level.__NOTHING) {
|
|
35
|
+
/* */
|
|
36
|
+
/* */
|
|
37
|
+
/* */
|
|
38
|
+
/* */
|
|
39
|
+
/* */
|
|
40
|
+
/* */
|
|
41
|
+
/* */
|
|
42
|
+
LevelOrder.reverse().find(a => {
|
|
43
|
+
// @ts-ignore
|
|
44
|
+
if (!this.consolelogfn[a]) {
|
|
45
|
+
// @ts-ignore
|
|
46
|
+
this.consolelogfn[a] = console[a];
|
|
47
|
+
}
|
|
48
|
+
// @ts-ignore
|
|
49
|
+
console[a] = () => { };
|
|
50
|
+
if (a === LevelKey[level]) {
|
|
51
|
+
return true;
|
|
52
|
+
}
|
|
53
|
+
return false;
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
static enableLogs() {
|
|
57
|
+
/* */
|
|
58
|
+
/* */
|
|
59
|
+
/* */
|
|
60
|
+
/* */
|
|
61
|
+
LevelOrder.forEach(a => {
|
|
62
|
+
// @ts-ignore
|
|
63
|
+
console[a] = this.consolelogfn[a];
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
//#region public api
|
|
67
|
+
setProductionMode() {
|
|
68
|
+
if (this.modeIsSet) {
|
|
69
|
+
this.modeIsSet = false;
|
|
70
|
+
throw '[ng2-logger] Production mode is already set';
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
this.modeIsSet = true;
|
|
74
|
+
setTimeout(() => {
|
|
75
|
+
if (this.modeIsSet && console !== void 0 && console.clear !== void 0) {
|
|
76
|
+
console.clear();
|
|
77
|
+
console.log = () => { };
|
|
78
|
+
console.error = () => { };
|
|
79
|
+
console.warn = () => { };
|
|
80
|
+
console.info = () => { };
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
this.isDevelopmentMode = false;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
onlyModules(...modules) {
|
|
87
|
+
if (this._logModules) {
|
|
88
|
+
throw '[ng2-logger] You should use funcion onlyModules only once';
|
|
89
|
+
}
|
|
90
|
+
if (!this._logModules) {
|
|
91
|
+
this._logModules = true;
|
|
92
|
+
}
|
|
93
|
+
if (modules.length === 0)
|
|
94
|
+
return;
|
|
95
|
+
this.modules = modules;
|
|
96
|
+
// console.log('only log this', Log.modules)
|
|
97
|
+
this.muteAllOtherModules();
|
|
98
|
+
}
|
|
99
|
+
onlyLevel(...level) {
|
|
100
|
+
if (this._logOnly) {
|
|
101
|
+
throw '[ng2-logger] You should use funcion onlyLevel only once';
|
|
102
|
+
}
|
|
103
|
+
if (!this._logOnly) {
|
|
104
|
+
this._logOnly = true;
|
|
105
|
+
}
|
|
106
|
+
this.levels = Array.isArray(level) ? level : [level];
|
|
107
|
+
for (const logName in this.instances) {
|
|
108
|
+
if (this.instances.hasOwnProperty(logName)) {
|
|
109
|
+
const element = this.instances[logName];
|
|
110
|
+
element['allowed'] = this.levels;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
//#endregion
|
|
115
|
+
create(name, ...level) {
|
|
116
|
+
let i;
|
|
117
|
+
if (Array.isArray(this.levels) && this.levels.length > 0) {
|
|
118
|
+
level = this.levels;
|
|
119
|
+
}
|
|
120
|
+
if (this.instances[name] === void 0) {
|
|
121
|
+
i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0);
|
|
122
|
+
this.instances[name] = i;
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
i = this.instances[name];
|
|
126
|
+
}
|
|
127
|
+
return i;
|
|
128
|
+
}
|
|
129
|
+
isMutedModule(moduleName) {
|
|
130
|
+
if (this.modules.length == 0)
|
|
131
|
+
return false;
|
|
132
|
+
if (!Helpers.contain(this.modules, moduleName))
|
|
133
|
+
return true;
|
|
134
|
+
return false;
|
|
135
|
+
}
|
|
136
|
+
muteAllOtherModules() {
|
|
137
|
+
for (var moduleName in this.instances) {
|
|
138
|
+
if (!Helpers.contain(this.modules, moduleName))
|
|
139
|
+
this.instances[moduleName].mute();
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
//#endregion
|
|
144
|
+
Log.Logger = Logger;
|
|
145
|
+
Log.consolelogfn = {};
|
|
146
|
+
function getRandomColor() {
|
|
147
|
+
/* */
|
|
148
|
+
/* */
|
|
149
|
+
/* */
|
|
150
|
+
/* */
|
|
151
|
+
let letters = '012345'.split('');
|
|
152
|
+
let color = '#';
|
|
153
|
+
color += letters[Math.round(Math.random() * 5)];
|
|
154
|
+
letters = '0123456789ABCDEF'.split('');
|
|
155
|
+
for (let i = 0; i < 5; i++) {
|
|
156
|
+
color += letters[Math.round(Math.random() * 15)];
|
|
157
|
+
}
|
|
158
|
+
if (color === void 0) {
|
|
159
|
+
return getRandomColor();
|
|
160
|
+
}
|
|
161
|
+
;
|
|
162
|
+
return color;
|
|
163
|
+
}
|
|
164
164
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWJ1bmRsZS13ZWJzcWwvbmcyLWxvZ2dlci9wcm9qZWN0cy9uZzItbG9nZ2VyL3NyYy9saWIvbG9nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDbEMsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3RELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxLQUFLO0FBQ0wsS0FBSztBQUNMLEtBQUs7QUFJTCxLQUFLO0FBQ0wsS0FBSztBQUlMLE1BQU0sT0FBTyxHQUFHO0lBQ2QsbUJBQW1CO0lBQ25CO1FBdURRLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsc0JBQWlCLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLGNBQVMsR0FBWSxLQUFLLENBQUM7UUFDM0IsZUFBVSxHQUFHLENBQUMsQ0FBQztRQUNmLGNBQVMsR0FBcUMsRUFBRSxDQUFDO1FBQ2pELFdBQU0sR0FBWSxFQUFFLENBQUM7UUFDckIsWUFBTyxHQUF3QixFQUFFLENBQUM7SUE5RGxCLENBQUM7SUFDekIsYUFBYTtJQUNMLE1BQU0sS0FBSyxRQUFRO1FBQ3pCLGFBQWE7UUFDYixJQUFJLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUFFO1lBQ3JCLGFBQWE7WUFDYixHQUFHLENBQUMsV0FBVyxDQUFDLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztTQUM5QjtRQUNELGFBQWE7UUFDYixPQUFPLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBSUQsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFZLEVBQUUsR0FBRyxLQUFjO1FBQzNDLE9BQU8sR0FBRyxDQUFDLFFBQVEs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QUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFO1FBQzFCLEtBQUssSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztLQUNsRDtJQUNELElBQUksS0FBSyxLQUFLLEtBQUssQ0FBQyxFQUFFO1FBQ3BCLE9BQU8sY0FBYyxFQUFFLENBQUE7S0FDeEI7SUFBQSxDQUFDO0lBQ0YsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTG9nZ2VyIH0gZnJvbSAnLi9sb2dnZXInO1xuaW1wb3J0IHsgTGV2ZWwsIExldmVsT3JkZXIsIExldmVsS2V5IH0gZnJvbSAnLi9sZXZlbCc7XG5pbXBvcnQgeyBIZWxwZXJzIH0gZnJvbSAndG5wLWNvcmUvd2Vic3FsJztcbi8qICovXG4vKiAqL1xuLyogKi9cbiAgXG5cblxuLyogKi9cbi8qICovXG4gIFxuXG5cbmV4cG9ydCBjbGFzcyBMb2cge1xuICAvLyNyZWdpb24gc2luZ2xldG9uXG4gIHByaXZhdGUgY29uc3RydWN0b3IoKSB7IH1cbiAgLy8gQHRzLWlnbm9yZVxuICBwcml2YXRlIHN0YXRpYyBnZXQgaW5zdGFuY2UoKTogYW55IHtcbiAgICAvLyBAdHMtaWdub3JlXG4gICAgaWYgKCFMb2dbJ19pbnN0YW5jZSddKSB7XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBMb2dbJ19pbnN0YW5jZSddID0gbmV3IExvZygpO1xuICAgIH1cbiAgICAvLyBAdHMtaWdub3JlXG4gICAgcmV0dXJuIExvZ1snX2luc3RhbmNlJ107XG4gIH1cbiAgLy8jZW5kcmVnaW9uXG5cbiAgc3RhdGljIExvZ2dlcjogKHR5cGVvZiBMb2dnZXIpID0gTG9nZ2VyO1xuICBzdGF0aWMgY3JlYXRlKG5hbWU6IHN0cmluZywgLi4ubGV2ZWw6IExldmVsW10pOiBMb2dnZXIge1xuICAgIHJldHVybiBMb2cuaW5zdGFuY2UuY3JlYXRlKG5hbWUsIC4uLmxldmVsKTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIHJlYWRvbmx5IGNvbnNvbGVsb2dmbiA9IHt9O1xuICBzdGF0aWMgZGlzYWJsZUxvZ3MobGV2ZWwgPSBMZXZlbC5fX05PVEhJTkcpIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuICAgIExldmVsT3JkZXIucmV2ZXJzZSgpLmZpbmQoYSA9PiB7XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBpZiAoIXRoaXMuY29uc29sZWxvZ2ZuW2FdKSB7XG4gICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgdGhpcy5jb25zb2xlbG9nZm5bYV0gPSBjb25zb2xlW2FdO1xuICAgICAgfVxuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgY29uc29sZVthXSA9ICgpID0+IHsgfTtcbiAgICAgIGlmIChhID09PSBMZXZlbEtleVtsZXZlbF0pIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfSk7XG4gIH1cblxuICBzdGF0aWMgZW5hYmxlTG9ncygpIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuICAgIExldmVsT3JkZXIuZm9yRWFjaChhID0+IHtcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIGNvbnNvbGVbYV0gPSB0aGlzLmNvbnNvbGVsb2dmblthXVxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfbG9nT25seSA9IGZhbHNlO1xuICBwcml2YXRlIF9sb2dNb2R1bGVzID0gZmFsc2U7XG4gIHByaXZhdGUgaXNEZXZlbG9wbWVudE1vZGUgPSB0cnVlO1xuICBwcml2YXRlIG1vZGVJc1NldDogYm9vbGVhbiA9IGZhbHNlO1xuICBwcml2YXRlIGZpeGVkV2lkdGggPSAwO1xuICBwcml2YXRlIGluc3RhbmNlczogeyBbbW9kdWxlTmFtZTogc3RyaW5nXTogTG9nZ2VyIH0gPSB7fTtcbiAgcHJpdmF0ZSBsZXZlbHM6IExldmVsW10gPSBbXTtcbiAgcHJpdmF0ZSBtb2R1bGVzOiAoc3RyaW5nIHwgUmVnRXhwKVtdID0gW107XG5cbiAgLy8jcmVnaW9uIHB1YmxpYyBhcGlcbiAgcHVibGljIHNldFByb2R1Y3Rpb25Nb2RlKCkge1xuICAgIGlmICh0aGlzLm1vZGVJc1NldCkge1xuICAgICAgdGhpcy5tb2RlSXNTZXQgPSBmYWxzZVxuICAgICAgdGhyb3cgJ1tuZzItbG9nZ2VyXSBQcm9kdWN0aW9uIG1vZGUgaXMgYWxyZWFkeSBzZXQnO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1vZGVJc1NldCA9IHRydWU7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcblxuICAgICAgICBpZiAodGhpcy5tb2RlSXNTZXQgJiYgY29uc29sZSAhPT0gdm9pZCAwICYmIGNvbnNvbGUuY2xlYXIgIT09IHZvaWQgMCkge1xuXG4gICAgICAgICAgY29uc29sZS5jbGVhcigpO1xuICAgICAgICAgIGNvbnNvbGUubG9nID0gKCkgPT4geyB9O1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IgPSAoKSA9PiB7IH07XG4gICAgICAgICAgY29uc29sZS53YXJuID0gKCkgPT4geyB9O1xuICAgICAgICAgIGNvbnNvbGUuaW5mbyA9ICgpID0+IHsgfTtcbiAgICAgICAgfVxuICAgICAgfSk7XG5cbiAgICAgIHRoaXMuaXNEZXZlbG9wbWVudE1vZGUgPSBmYWxzZTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgb25seU1vZHVsZXMoLi4ubW9kdWxlczogKHN0cmluZyB8IFJlZ0V4cClbXSkge1xuICAgIGlmICh0aGlzLl9sb2dNb2R1bGVzKSB7XG4gICAgICB0aHJvdyAnW25nMi1sb2dnZXJdIFlvdSBzaG91bGQgdXNlIGZ1bmNpb24gb25seU1vZHVsZXMgb25seSBvbmNlJztcbiAgICB9XG4gICAgaWYgKCF0aGlzLl9sb2dNb2R1bGVzKSB7XG4gICAgICB0aGlzLl9sb2dNb2R1bGVzID0gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKG1vZHVsZXMubGVuZ3RoID09PSAwKSByZXR1cm47XG4gICAgdGhpcy5tb2R1bGVzID0gbW9kdWxlcztcbiAgICAvLyBjb25zb2xlLmxvZygnb25seSBsb2cgdGhpcycsIExvZy5tb2R1bGVzKVxuICAgIHRoaXMubXV0ZUFsbE90aGVyTW9kdWxlcygpO1xuICB9XG5cblxuICBwdWJsaWMgb25seUxldmVsKC4uLmxldmVsOiBMZXZlbFtdKSB7XG4gICAgaWYgKHRoaXMuX2xvZ09ubHkpIHtcbiAgICAgIHRocm93ICdbbmcyLWxvZ2dlcl0gWW91IHNob3VsZCB1c2UgZnVuY2lvbiBvbmx5TGV2ZWwgb25seSBvbmNlJztcbiAgICB9XG4gICAgaWYgKCF0aGlzLl9sb2dPbmx5KSB7XG4gICAgICB0aGlzLl9sb2dPbmx5ID0gdHJ1ZTtcbiAgICB9XG5cbiAgICB0aGlzLmxldmVscyA9IEFycmF5LmlzQXJyYXkobGV2ZWwpID8gbGV2ZWwgOiBbbGV2ZWxdO1xuXG5cbiAgICBmb3IgKGNvbnN0IGxvZ05hbWUgaW4gdGhpcy5pbnN0YW5jZXMpIHtcbiAgICAgIGlmICh0aGlzLmluc3RhbmNlcy5oYXNPd25Qcm9wZXJ0eShsb2dOYW1lKSkge1xuICAgICAgICBjb25zdCBlbGVtZW50ID0gdGhpcy5pbnN0YW5jZXNbbG9nTmFtZV07XG4gICAgICAgIGVsZW1lbnRbJ2FsbG93ZWQnXSA9IHRoaXMubGV2ZWxzO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8vI2VuZHJlZ2lvblxuXG4gIHByaXZhdGUgY3JlYXRlKG5hbWU6IHN0cmluZywgLi4ubGV2ZWw6IExldmVsW10pOiBMb2dnZXIge1xuICAgIGxldCBpOiBMb2dnZXI7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkodGhpcy5sZXZlbHMpICYmIHRoaXMubGV2ZWxzLmxlbmd0aCA+IDApIHtcbiAgICAgIGxldmVsID0gdGhpcy5sZXZlbHM7XG4gICAgfVxuICAgIGlmICh0aGlzLmluc3RhbmNlc1tuYW1lXSA9PT0gdm9pZCAwKSB7XG4gICAgICBpID0gbmV3IChMb2cuTG9nZ2VyKShcbiAgICAgICAgbmFtZSxcbiAgICAgICAgZ2V0UmFuZG9tQ29sb3IoKSxcbiAgICAgICAgdGhpcy5pc0RldmVsb3BtZW50TW9kZSxcbiAgICAgICAgbGV2ZWwsXG4gICAgICAgIHRoaXMuaXNNdXRlZE1vZHVsZShuYW1lKSxcbiAgICAgICAgdGhpcy5sZXZlbHMubGVuZ3RoID4gMCA/IHRoaXMuZml4ZWRXaWR0aCA6IHZvaWQgMCxcbiAgICAgICAgLy8gTG9nLmxldmVscy5sZW5ndGggPiAwID8gTG9nLmRpc3BsYXkgOiB1bmRlZmluZWQsXG4gICAgICApO1xuICAgICAgdGhpcy5pbnN0YW5jZXNbbmFtZV0gPSBpO1xuICAgIH0gZWxzZSB7XG4gICAgICBpID0gdGhpcy5pbnN0YW5jZXNbbmFtZV07XG4gICAgfVxuICAgIHJldHVybiBpO1xuICB9XG5cbiAgcHJpdmF0ZSBpc011dGVkTW9kdWxlKG1vZHVsZU5hbWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIGlmICh0aGlzLm1vZHVsZXMubGVuZ3RoID09IDApIHJldHVybiBmYWxzZTtcbiAgICBpZiAoIUhlbHBlcnMuY29udGFpbih0aGlzLm1vZHVsZXMsIG1vZHVsZU5hbWUpKSByZXR1cm4gdHJ1ZTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgcHJpdmF0ZSBtdXRlQWxsT3RoZXJNb2R1bGVzKCkge1xuICAgIGZvciAodmFyIG1vZHVsZU5hbWUgaW4gdGhpcy5pbnN0YW5jZXMpIHtcbiAgICAgIGlmICghSGVscGVycy5jb250YWluKHRoaXMubW9kdWxlcywgbW9kdWxlTmFtZSkpXG4gICAgICAgIHRoaXMuaW5zdGFuY2VzW21vZHVsZU5hbWVdLm11dGUoKVxuICAgIH1cbiAgfVxuXG59XG5cblxuZnVuY3Rpb24gZ2V0UmFuZG9tQ29sb3IoKTogc3RyaW5nIHtcbi8qICovXG4vKiAqL1xuLyogKi9cbi8qICovXG4gIFxuXG4gIGxldCBsZXR0ZXJzID0gJzAxMjM0NScuc3BsaXQoJycpO1xuICBsZXQgY29sb3IgPSAnIyc7XG4gIGNvbG9yICs9IGxldHRlcnNbTWF0aC5yb3VuZChNYXRoLnJhbmRvbSgpICogNSldO1xuICBsZXR0ZXJzID0gJzAxMjM0NTY3ODlBQkNERUYnLnNwbGl0KCcnKTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCA1OyBpKyspIHtcbiAgICBjb2xvciArPSBsZXR0ZXJzW01hdGgucm91bmQoTWF0aC5yYW5kb20oKSAqIDE1KV07XG4gIH1cbiAgaWYgKGNvbG9yID09PSB2b2lkIDApIHtcbiAgICByZXR1cm4gZ2V0UmFuZG9tQ29sb3IoKVxuICB9O1xuICByZXR1cm4gY29sb3I7XG59XG4iXX0=
|