ag-psd 15.0.0 → 15.0.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.
Files changed (102) hide show
  1. package/TODO +0 -2
  2. package/clean.js +3 -0
  3. package/dist/abr.d.ts +132 -132
  4. package/dist/abr.js +270 -271
  5. package/dist/abr.js.map +1 -0
  6. package/dist/additionalInfo.d.ts +25 -25
  7. package/dist/additionalInfo.js +2026 -2045
  8. package/dist/additionalInfo.js.map +1 -0
  9. package/dist/bundle.js +9133 -8707
  10. package/dist/csh.d.ts +10 -10
  11. package/dist/csh.js +48 -49
  12. package/dist/csh.js.map +1 -0
  13. package/dist/descriptor.d.ts +411 -390
  14. package/dist/descriptor.js +1689 -1644
  15. package/dist/descriptor.js.map +1 -0
  16. package/dist/effectsHelpers.d.ts +5 -5
  17. package/dist/effectsHelpers.js +309 -310
  18. package/dist/effectsHelpers.js.map +1 -0
  19. package/dist/engineData.d.ts +2 -2
  20. package/dist/engineData.js +337 -338
  21. package/dist/engineData.js.map +1 -0
  22. package/dist/helpers.d.ts +93 -93
  23. package/dist/helpers.js +332 -333
  24. package/dist/helpers.js.map +1 -0
  25. package/dist/imageResources.d.ts +13 -13
  26. package/dist/imageResources.js +1007 -788
  27. package/dist/imageResources.js.map +1 -0
  28. package/dist/index.d.ts +20 -20
  29. package/dist/index.js +53 -54
  30. package/dist/index.js.map +1 -0
  31. package/dist/initializeCanvas.d.ts +1 -1
  32. package/dist/initializeCanvas.js +26 -27
  33. package/dist/initializeCanvas.js.map +1 -0
  34. package/dist/jpeg.d.ts +1 -1
  35. package/dist/jpeg.js +1019 -1020
  36. package/dist/jpeg.js.map +1 -0
  37. package/dist/psd.d.ts +1200 -1147
  38. package/dist/psd.js +22 -23
  39. package/dist/psd.js.map +1 -0
  40. package/dist/psdReader.d.ts +36 -34
  41. package/dist/psdReader.js +958 -941
  42. package/dist/psdReader.js.map +1 -0
  43. package/dist/psdWriter.d.ts +27 -27
  44. package/dist/psdWriter.js +694 -690
  45. package/dist/psdWriter.js.map +1 -0
  46. package/dist/text.d.ts +168 -168
  47. package/dist/text.js +557 -558
  48. package/dist/text.js.map +1 -0
  49. package/dist/utf8.d.ts +5 -5
  50. package/dist/utf8.js +152 -153
  51. package/dist/utf8.js.map +1 -0
  52. package/dist-es/abr.d.ts +132 -132
  53. package/dist-es/abr.js +266 -267
  54. package/dist-es/abr.js.map +1 -0
  55. package/dist-es/additionalInfo.d.ts +25 -25
  56. package/dist-es/additionalInfo.js +2020 -2039
  57. package/dist-es/additionalInfo.js.map +1 -0
  58. package/dist-es/csh.d.ts +10 -10
  59. package/dist-es/csh.js +44 -45
  60. package/dist-es/csh.js.map +1 -0
  61. package/dist-es/descriptor.d.ts +411 -390
  62. package/dist-es/descriptor.js +1661 -1616
  63. package/dist-es/descriptor.js.map +1 -0
  64. package/dist-es/effectsHelpers.d.ts +5 -5
  65. package/dist-es/effectsHelpers.js +304 -305
  66. package/dist-es/effectsHelpers.js.map +1 -0
  67. package/dist-es/engineData.d.ts +2 -2
  68. package/dist-es/engineData.js +332 -333
  69. package/dist-es/engineData.js.map +1 -0
  70. package/dist-es/helpers.d.ts +93 -93
  71. package/dist-es/helpers.js +315 -316
  72. package/dist-es/helpers.js.map +1 -0
  73. package/dist-es/imageResources.d.ts +13 -13
  74. package/dist-es/imageResources.js +1004 -785
  75. package/dist-es/imageResources.js.map +1 -0
  76. package/dist-es/index.d.ts +20 -20
  77. package/dist-es/index.js +31 -32
  78. package/dist-es/index.js.map +1 -0
  79. package/dist-es/initializeCanvas.d.ts +1 -1
  80. package/dist-es/initializeCanvas.js +22 -23
  81. package/dist-es/initializeCanvas.js.map +1 -0
  82. package/dist-es/jpeg.d.ts +1 -1
  83. package/dist-es/jpeg.js +1015 -1016
  84. package/dist-es/jpeg.js.map +1 -0
  85. package/dist-es/psd.d.ts +1200 -1147
  86. package/dist-es/psd.js +19 -20
  87. package/dist-es/psd.js.map +1 -0
  88. package/dist-es/psdReader.d.ts +36 -34
  89. package/dist-es/psdReader.js +928 -912
  90. package/dist-es/psdReader.js.map +1 -0
  91. package/dist-es/psdWriter.d.ts +27 -27
  92. package/dist-es/psdWriter.js +670 -666
  93. package/dist-es/psdWriter.js.map +1 -0
  94. package/dist-es/text.d.ts +168 -168
  95. package/dist-es/text.js +552 -553
  96. package/dist-es/text.js.map +1 -0
  97. package/dist-es/utf8.d.ts +5 -5
  98. package/dist-es/utf8.js +145 -146
  99. package/dist-es/utf8.js.map +1 -0
  100. package/package.json +11 -17
  101. package/tsconfig-es6.json +7 -0
  102. package/tsconfig.json +7 -1
package/dist/psdReader.js CHANGED
@@ -1,941 +1,958 @@
1
- "use strict";
2
- var __assign = (this && this.__assign) || function () {
3
- __assign = Object.assign || function(t) {
4
- for (var s, i = 1, n = arguments.length; i < n; i++) {
5
- s = arguments[i];
6
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
- t[p] = s[p];
8
- }
9
- return t;
10
- };
11
- return __assign.apply(this, arguments);
12
- };
13
- Object.defineProperty(exports, "__esModule", { value: true });
14
- exports.readPattern = exports.readColor = exports.readSection = exports.readDataRLE = exports.readDataZipWithoutPrediction = exports.readPsd = exports.checkSignature = exports.skipBytes = exports.readAsciiString = exports.readUnicodeStringWithLength = exports.readUnicodeString = exports.readPascalString = exports.readSignature = exports.readBytes = exports.readFixedPointPath32 = exports.readFixedPoint32 = exports.readFloat64 = exports.readFloat32 = exports.readUint32 = exports.readInt32LE = exports.readInt32 = exports.readUint16 = exports.readInt16 = exports.peekUint8 = exports.readUint8 = exports.createReader = exports.supportedColorModes = void 0;
15
- var pako_1 = require("pako");
16
- var helpers_1 = require("./helpers");
17
- var additionalInfo_1 = require("./additionalInfo");
18
- var imageResources_1 = require("./imageResources");
19
- exports.supportedColorModes = [0 /* ColorMode.Bitmap */, 1 /* ColorMode.Grayscale */, 3 /* ColorMode.RGB */];
20
- var colorModes = ['bitmap', 'grayscale', 'indexed', 'RGB', 'CMYK', 'multichannel', 'duotone', 'lab'];
21
- function setupGrayscale(data) {
22
- var size = data.width * data.height * 4;
23
- for (var i = 0; i < size; i += 4) {
24
- data.data[i + 1] = data.data[i];
25
- data.data[i + 2] = data.data[i];
26
- }
27
- }
28
- function createReader(buffer, offset, length) {
29
- var view = new DataView(buffer, offset, length);
30
- return { view: view, offset: 0, strict: false };
31
- }
32
- exports.createReader = createReader;
33
- function readUint8(reader) {
34
- reader.offset += 1;
35
- return reader.view.getUint8(reader.offset - 1);
36
- }
37
- exports.readUint8 = readUint8;
38
- function peekUint8(reader) {
39
- return reader.view.getUint8(reader.offset);
40
- }
41
- exports.peekUint8 = peekUint8;
42
- function readInt16(reader) {
43
- reader.offset += 2;
44
- return reader.view.getInt16(reader.offset - 2, false);
45
- }
46
- exports.readInt16 = readInt16;
47
- function readUint16(reader) {
48
- reader.offset += 2;
49
- return reader.view.getUint16(reader.offset - 2, false);
50
- }
51
- exports.readUint16 = readUint16;
52
- function readInt32(reader) {
53
- reader.offset += 4;
54
- return reader.view.getInt32(reader.offset - 4, false);
55
- }
56
- exports.readInt32 = readInt32;
57
- function readInt32LE(reader) {
58
- reader.offset += 4;
59
- return reader.view.getInt32(reader.offset - 4, true);
60
- }
61
- exports.readInt32LE = readInt32LE;
62
- function readUint32(reader) {
63
- reader.offset += 4;
64
- return reader.view.getUint32(reader.offset - 4, false);
65
- }
66
- exports.readUint32 = readUint32;
67
- function readFloat32(reader) {
68
- reader.offset += 4;
69
- return reader.view.getFloat32(reader.offset - 4, false);
70
- }
71
- exports.readFloat32 = readFloat32;
72
- function readFloat64(reader) {
73
- reader.offset += 8;
74
- return reader.view.getFloat64(reader.offset - 8, false);
75
- }
76
- exports.readFloat64 = readFloat64;
77
- // 32-bit fixed-point number 16.16
78
- function readFixedPoint32(reader) {
79
- return readInt32(reader) / (1 << 16);
80
- }
81
- exports.readFixedPoint32 = readFixedPoint32;
82
- // 32-bit fixed-point number 8.24
83
- function readFixedPointPath32(reader) {
84
- return readInt32(reader) / (1 << 24);
85
- }
86
- exports.readFixedPointPath32 = readFixedPointPath32;
87
- function readBytes(reader, length) {
88
- reader.offset += length;
89
- return new Uint8Array(reader.view.buffer, reader.view.byteOffset + reader.offset - length, length);
90
- }
91
- exports.readBytes = readBytes;
92
- function readSignature(reader) {
93
- return readShortString(reader, 4);
94
- }
95
- exports.readSignature = readSignature;
96
- function readPascalString(reader, padTo) {
97
- var length = readUint8(reader);
98
- var text = length ? readShortString(reader, length) : '';
99
- while (++length % padTo) {
100
- reader.offset++;
101
- }
102
- return text;
103
- }
104
- exports.readPascalString = readPascalString;
105
- function readUnicodeString(reader) {
106
- var length = readUint32(reader);
107
- return readUnicodeStringWithLength(reader, length);
108
- }
109
- exports.readUnicodeString = readUnicodeString;
110
- function readUnicodeStringWithLength(reader, length) {
111
- var text = '';
112
- while (length--) {
113
- var value = readUint16(reader);
114
- if (value || length > 0) { // remove trailing \0
115
- text += String.fromCharCode(value);
116
- }
117
- }
118
- return text;
119
- }
120
- exports.readUnicodeStringWithLength = readUnicodeStringWithLength;
121
- function readAsciiString(reader, length) {
122
- var text = '';
123
- while (length--) {
124
- text += String.fromCharCode(readUint8(reader));
125
- }
126
- return text;
127
- }
128
- exports.readAsciiString = readAsciiString;
129
- function skipBytes(reader, count) {
130
- reader.offset += count;
131
- }
132
- exports.skipBytes = skipBytes;
133
- function checkSignature(reader, a, b) {
134
- var offset = reader.offset;
135
- var signature = readSignature(reader);
136
- if (signature !== a && signature !== b) {
137
- throw new Error("Invalid signature: '".concat(signature, "' at 0x").concat(offset.toString(16)));
138
- }
139
- }
140
- exports.checkSignature = checkSignature;
141
- function readShortString(reader, length) {
142
- var buffer = readBytes(reader, length);
143
- var result = '';
144
- for (var i = 0; i < buffer.length; i++) {
145
- result += String.fromCharCode(buffer[i]);
146
- }
147
- return result;
148
- }
149
- function isValidSignature(sig) {
150
- return sig === '8BIM' || sig === 'MeSa' || sig === 'AgHg' || sig === 'PHUT' || sig === 'DCSR';
151
- }
152
- function readPsd(reader, options) {
153
- var _a;
154
- if (options === void 0) { options = {}; }
155
- // header
156
- checkSignature(reader, '8BPS');
157
- var version = readUint16(reader);
158
- if (version !== 1 && version !== 2)
159
- throw new Error("Invalid PSD file version: ".concat(version));
160
- skipBytes(reader, 6);
161
- var channels = readUint16(reader);
162
- var height = readUint32(reader);
163
- var width = readUint32(reader);
164
- var bitsPerChannel = readUint16(reader);
165
- var colorMode = readUint16(reader);
166
- var maxSize = version === 1 ? 30000 : 300000;
167
- if (width > maxSize || height > maxSize)
168
- throw new Error("Invalid size");
169
- if (channels > 16)
170
- throw new Error("Invalid channel count");
171
- if (bitsPerChannel > 32)
172
- throw new Error("Invalid bitsPerChannel count");
173
- if (exports.supportedColorModes.indexOf(colorMode) === -1)
174
- throw new Error("Color mode not supported: ".concat((_a = colorModes[colorMode]) !== null && _a !== void 0 ? _a : colorMode));
175
- var psd = { width: width, height: height, channels: channels, bitsPerChannel: bitsPerChannel, colorMode: colorMode };
176
- var opt = __assign(__assign({}, options), { large: version === 2 });
177
- var fixOffsets = [0, 1, -1, 2, -2, 3, -3, 4, -4];
178
- // color mode data
179
- readSection(reader, 1, function (left) {
180
- if (opt.throwForMissingFeatures)
181
- throw new Error('Color mode data not supported');
182
- skipBytes(reader, left());
183
- });
184
- // image resources
185
- readSection(reader, 1, function (left) {
186
- var _loop_1 = function () {
187
- var sigOffset = reader.offset;
188
- var sig = '';
189
- // attempt to fix broken document by realigning with the signature
190
- for (var _i = 0, fixOffsets_1 = fixOffsets; _i < fixOffsets_1.length; _i++) {
191
- var offset = fixOffsets_1[_i];
192
- try {
193
- reader.offset = sigOffset + offset;
194
- sig = readSignature(reader);
195
- }
196
- catch (_a) { }
197
- if (isValidSignature(sig))
198
- break;
199
- }
200
- if (!isValidSignature(sig)) {
201
- throw new Error("Invalid signature: '".concat(sig, "' at 0x").concat((sigOffset).toString(16)));
202
- }
203
- var id = readUint16(reader);
204
- readPascalString(reader, 2); // name
205
- readSection(reader, 2, function (left) {
206
- var handler = imageResources_1.resourceHandlersMap[id];
207
- var skip = id === 1036 && !!opt.skipThumbnail;
208
- if (!psd.imageResources) {
209
- psd.imageResources = {};
210
- }
211
- if (handler && !skip) {
212
- try {
213
- handler.read(reader, psd.imageResources, left, opt);
214
- }
215
- catch (e) {
216
- if (opt.throwForMissingFeatures)
217
- throw e;
218
- skipBytes(reader, left());
219
- }
220
- }
221
- else {
222
- // options.logMissingFeatures && console.log(`Unhandled image resource: ${id}`);
223
- skipBytes(reader, left());
224
- }
225
- });
226
- };
227
- while (left()) {
228
- _loop_1();
229
- }
230
- });
231
- // layer and mask info
232
- var globalAlpha = false;
233
- readSection(reader, 1, function (left) {
234
- globalAlpha = readLayerInfo(reader, psd, opt);
235
- // SAI does not include this section
236
- if (left() > 0) {
237
- var globalLayerMaskInfo = readGlobalLayerMaskInfo(reader);
238
- if (globalLayerMaskInfo)
239
- psd.globalLayerMaskInfo = globalLayerMaskInfo;
240
- }
241
- else {
242
- // revert back to end of section if exceeded section limits
243
- // opt.logMissingFeatures && console.log('reverting to end of section');
244
- skipBytes(reader, left());
245
- }
246
- while (left() > 0) {
247
- // sometimes there are empty bytes here
248
- while (left() && peekUint8(reader) === 0) {
249
- // opt.logMissingFeatures && console.log('skipping 0 byte');
250
- skipBytes(reader, 1);
251
- }
252
- if (left() >= 12) {
253
- readAdditionalLayerInfo(reader, psd, psd, opt);
254
- }
255
- else {
256
- // opt.logMissingFeatures && console.log('skipping leftover bytes', left());
257
- skipBytes(reader, left());
258
- }
259
- }
260
- }, undefined, opt.large);
261
- var hasChildren = psd.children && psd.children.length;
262
- var skipComposite = opt.skipCompositeImageData && (opt.skipLayerImageData || hasChildren);
263
- if (!skipComposite) {
264
- readImageData(reader, psd, globalAlpha, opt);
265
- }
266
- // TODO: show converted color mode instead of original PSD file color mode
267
- // but add option to preserve file color mode (need to return image data instead of canvas in that case)
268
- // psd.colorMode = ColorMode.RGB; // we convert all color modes to RGB
269
- return psd;
270
- }
271
- exports.readPsd = readPsd;
272
- function readLayerInfo(reader, psd, options) {
273
- var globalAlpha = false;
274
- readSection(reader, 2, function (left) {
275
- var layerCount = readInt16(reader);
276
- if (layerCount < 0) {
277
- globalAlpha = true;
278
- layerCount = -layerCount;
279
- }
280
- var layers = [];
281
- var layerChannels = [];
282
- for (var i = 0; i < layerCount; i++) {
283
- var _a = readLayerRecord(reader, psd, options), layer = _a.layer, channels = _a.channels;
284
- layers.push(layer);
285
- layerChannels.push(channels);
286
- }
287
- if (!options.skipLayerImageData) {
288
- for (var i = 0; i < layerCount; i++) {
289
- readLayerChannelImageData(reader, psd, layers[i], layerChannels[i], options);
290
- }
291
- }
292
- skipBytes(reader, left());
293
- if (!psd.children)
294
- psd.children = [];
295
- var stack = [psd];
296
- for (var i = layers.length - 1; i >= 0; i--) {
297
- var l = layers[i];
298
- var type = l.sectionDivider ? l.sectionDivider.type : 0 /* SectionDividerType.Other */;
299
- if (type === 1 /* SectionDividerType.OpenFolder */ || type === 2 /* SectionDividerType.ClosedFolder */) {
300
- l.opened = type === 1 /* SectionDividerType.OpenFolder */;
301
- l.children = [];
302
- stack[stack.length - 1].children.unshift(l);
303
- stack.push(l);
304
- }
305
- else if (type === 3 /* SectionDividerType.BoundingSectionDivider */) {
306
- stack.pop();
307
- // this was workaround because I didn't know what `lsdk` section was, now it's probably not needed anymore
308
- // } else if (l.name === '</Layer group>' && !l.sectionDivider && !l.top && !l.left && !l.bottom && !l.right) {
309
- // // sometimes layer group terminator doesn't have sectionDivider, so we just guess here (PS bug ?)
310
- // stack.pop();
311
- }
312
- else {
313
- stack[stack.length - 1].children.unshift(l);
314
- }
315
- }
316
- }, undefined, options.large);
317
- return globalAlpha;
318
- }
319
- function readLayerRecord(reader, psd, options) {
320
- var layer = {};
321
- layer.top = readInt32(reader);
322
- layer.left = readInt32(reader);
323
- layer.bottom = readInt32(reader);
324
- layer.right = readInt32(reader);
325
- var channelCount = readUint16(reader);
326
- var channels = [];
327
- for (var i = 0; i < channelCount; i++) {
328
- var channelID = readInt16(reader);
329
- var channelLength = readUint32(reader);
330
- if (options.large) {
331
- if (channelLength !== 0)
332
- throw new Error('Sizes larger than 4GB are not supported');
333
- channelLength = readUint32(reader);
334
- }
335
- channels.push({ id: channelID, length: channelLength });
336
- }
337
- checkSignature(reader, '8BIM');
338
- var blendMode = readSignature(reader);
339
- if (!helpers_1.toBlendMode[blendMode])
340
- throw new Error("Invalid blend mode: '".concat(blendMode, "'"));
341
- layer.blendMode = helpers_1.toBlendMode[blendMode];
342
- layer.opacity = readUint8(reader) / 0xff;
343
- layer.clipping = readUint8(reader) === 1;
344
- var flags = readUint8(reader);
345
- layer.transparencyProtected = (flags & 0x01) !== 0;
346
- layer.hidden = (flags & 0x02) !== 0;
347
- // 0x04 - obsolete
348
- // 0x08 - 1 for Photoshop 5.0 and later, tells if bit 4 has useful information
349
- // 0x10 - pixel data irrelevant to appearance of document
350
- // 0x20 - ???
351
- // if (flags & 0x20) (layer as any)._2 = true; // TEMP !!!!
352
- skipBytes(reader, 1);
353
- readSection(reader, 1, function (left) {
354
- var mask = readLayerMaskData(reader, options);
355
- if (mask)
356
- layer.mask = mask;
357
- /*const blendingRanges =*/ readLayerBlendingRanges(reader);
358
- layer.name = readPascalString(reader, 4);
359
- while (left()) {
360
- readAdditionalLayerInfo(reader, layer, psd, options);
361
- }
362
- });
363
- return { layer: layer, channels: channels };
364
- }
365
- function readLayerMaskData(reader, options) {
366
- return readSection(reader, 1, function (left) {
367
- if (!left())
368
- return undefined;
369
- var mask = {};
370
- mask.top = readInt32(reader);
371
- mask.left = readInt32(reader);
372
- mask.bottom = readInt32(reader);
373
- mask.right = readInt32(reader);
374
- mask.defaultColor = readUint8(reader);
375
- var flags = readUint8(reader);
376
- mask.positionRelativeToLayer = (flags & 1 /* LayerMaskFlags.PositionRelativeToLayer */) !== 0;
377
- mask.disabled = (flags & 2 /* LayerMaskFlags.LayerMaskDisabled */) !== 0;
378
- mask.fromVectorData = (flags & 8 /* LayerMaskFlags.LayerMaskFromRenderingOtherData */) !== 0;
379
- if (flags & 16 /* LayerMaskFlags.MaskHasParametersAppliedToIt */) {
380
- var params = readUint8(reader);
381
- if (params & 1 /* MaskParams.UserMaskDensity */)
382
- mask.userMaskDensity = readUint8(reader) / 0xff;
383
- if (params & 2 /* MaskParams.UserMaskFeather */)
384
- mask.userMaskFeather = readFloat64(reader);
385
- if (params & 4 /* MaskParams.VectorMaskDensity */)
386
- mask.vectorMaskDensity = readUint8(reader) / 0xff;
387
- if (params & 8 /* MaskParams.VectorMaskFeather */)
388
- mask.vectorMaskFeather = readFloat64(reader);
389
- }
390
- if (left() > 2) {
391
- options.logMissingFeatures && console.log('Unhandled extra mask params');
392
- // TODO: handle these values
393
- /*const realFlags =*/ readUint8(reader);
394
- /*const realUserMaskBackground =*/ readUint8(reader);
395
- /*const top2 =*/ readInt32(reader);
396
- /*const left2 =*/ readInt32(reader);
397
- /*const bottom2 =*/ readInt32(reader);
398
- /*const right2 =*/ readInt32(reader);
399
- }
400
- skipBytes(reader, left());
401
- return mask;
402
- });
403
- }
404
- function readLayerBlendingRanges(reader) {
405
- return readSection(reader, 1, function (left) {
406
- var compositeGrayBlendSource = readUint32(reader);
407
- var compositeGraphBlendDestinationRange = readUint32(reader);
408
- var ranges = [];
409
- while (left()) {
410
- var sourceRange = readUint32(reader);
411
- var destRange = readUint32(reader);
412
- ranges.push({ sourceRange: sourceRange, destRange: destRange });
413
- }
414
- return { compositeGrayBlendSource: compositeGrayBlendSource, compositeGraphBlendDestinationRange: compositeGraphBlendDestinationRange, ranges: ranges };
415
- });
416
- }
417
- function readLayerChannelImageData(reader, psd, layer, channels, options) {
418
- var layerWidth = (layer.right || 0) - (layer.left || 0);
419
- var layerHeight = (layer.bottom || 0) - (layer.top || 0);
420
- var cmyk = psd.colorMode === 4 /* ColorMode.CMYK */;
421
- var imageData;
422
- if (layerWidth && layerHeight) {
423
- if (cmyk) {
424
- imageData = { width: layerWidth, height: layerHeight, data: new Uint8ClampedArray(layerWidth * layerHeight * 5) };
425
- for (var p = 4; p < imageData.data.byteLength; p += 5)
426
- imageData.data[p] = 255;
427
- }
428
- else {
429
- imageData = (0, helpers_1.createImageData)(layerWidth, layerHeight);
430
- (0, helpers_1.resetImageData)(imageData);
431
- }
432
- }
433
- if (helpers_1.RAW_IMAGE_DATA)
434
- layer.imageDataRaw = [];
435
- for (var _i = 0, channels_1 = channels; _i < channels_1.length; _i++) {
436
- var channel = channels_1[_i];
437
- if (channel.length === 0)
438
- continue;
439
- if (channel.length < 2)
440
- throw new Error('Invalid channel length');
441
- var start = reader.offset;
442
- var compression = readUint16(reader);
443
- if (channel.id === -2 /* ChannelID.UserMask */) {
444
- var mask = layer.mask;
445
- if (!mask)
446
- throw new Error("Missing layer mask data");
447
- var maskWidth = (mask.right || 0) - (mask.left || 0);
448
- var maskHeight = (mask.bottom || 0) - (mask.top || 0);
449
- if (maskWidth && maskHeight) {
450
- var maskData = (0, helpers_1.createImageData)(maskWidth, maskHeight);
451
- (0, helpers_1.resetImageData)(maskData);
452
- var start_1 = reader.offset;
453
- readData(reader, channel.length, maskData, compression, maskWidth, maskHeight, 0, options.large, 4);
454
- if (helpers_1.RAW_IMAGE_DATA) {
455
- layer.maskDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start_1, reader.offset - start_1);
456
- }
457
- setupGrayscale(maskData);
458
- if (options.useImageData) {
459
- mask.imageData = maskData;
460
- }
461
- else {
462
- mask.canvas = (0, helpers_1.createCanvas)(maskWidth, maskHeight);
463
- mask.canvas.getContext('2d').putImageData(maskData, 0, 0);
464
- }
465
- }
466
- }
467
- else {
468
- var offset = (0, helpers_1.offsetForChannel)(channel.id, cmyk);
469
- var targetData = imageData;
470
- if (offset < 0) {
471
- targetData = undefined;
472
- if (options.throwForMissingFeatures) {
473
- throw new Error("Channel not supported: ".concat(channel.id));
474
- }
475
- }
476
- readData(reader, channel.length, targetData, compression, layerWidth, layerHeight, offset, options.large, cmyk ? 5 : 4);
477
- if (helpers_1.RAW_IMAGE_DATA) {
478
- layer.imageDataRaw[channel.id] = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start + 2, channel.length - 2);
479
- }
480
- reader.offset = start + channel.length;
481
- if (targetData && psd.colorMode === 1 /* ColorMode.Grayscale */) {
482
- setupGrayscale(targetData);
483
- }
484
- }
485
- }
486
- if (imageData) {
487
- if (cmyk) {
488
- var cmykData = imageData;
489
- imageData = (0, helpers_1.createImageData)(cmykData.width, cmykData.height);
490
- cmykToRgb(cmykData, imageData, false);
491
- }
492
- if (options.useImageData) {
493
- layer.imageData = imageData;
494
- }
495
- else {
496
- layer.canvas = (0, helpers_1.createCanvas)(layerWidth, layerHeight);
497
- layer.canvas.getContext('2d').putImageData(imageData, 0, 0);
498
- }
499
- }
500
- }
501
- function readData(reader, length, data, compression, width, height, offset, large, step) {
502
- if (compression === 0 /* Compression.RawData */) {
503
- readDataRaw(reader, data, width, height, step, offset);
504
- }
505
- else if (compression === 1 /* Compression.RleCompressed */) {
506
- readDataRLE(reader, data, width, height, step, [offset], large);
507
- }
508
- else if (compression === 2 /* Compression.ZipWithoutPrediction */) {
509
- readDataZipWithoutPrediction(reader, length, data, width, height, step, offset);
510
- }
511
- else if (compression === 3 /* Compression.ZipWithPrediction */) {
512
- throw new Error("Compression type not supported: ".concat(compression));
513
- }
514
- else {
515
- throw new Error("Invalid Compression type: ".concat(compression));
516
- }
517
- }
518
- function readGlobalLayerMaskInfo(reader) {
519
- return readSection(reader, 1, function (left) {
520
- if (!left())
521
- return undefined;
522
- var overlayColorSpace = readUint16(reader);
523
- var colorSpace1 = readUint16(reader);
524
- var colorSpace2 = readUint16(reader);
525
- var colorSpace3 = readUint16(reader);
526
- var colorSpace4 = readUint16(reader);
527
- var opacity = readUint16(reader) / 0xff;
528
- var kind = readUint8(reader);
529
- skipBytes(reader, left()); // 3 bytes of padding ?
530
- return { overlayColorSpace: overlayColorSpace, colorSpace1: colorSpace1, colorSpace2: colorSpace2, colorSpace3: colorSpace3, colorSpace4: colorSpace4, opacity: opacity, kind: kind };
531
- });
532
- }
533
- function readAdditionalLayerInfo(reader, target, psd, options) {
534
- var sig = readSignature(reader);
535
- if (sig !== '8BIM' && sig !== '8B64')
536
- throw new Error("Invalid signature: '".concat(sig, "' at 0x").concat((reader.offset - 4).toString(16)));
537
- var key = readSignature(reader);
538
- // `largeAdditionalInfoKeys` fallback, because some keys don't have 8B64 signature even when they are 64bit
539
- var u64 = sig === '8B64' || (options.large && helpers_1.largeAdditionalInfoKeys.indexOf(key) !== -1);
540
- readSection(reader, 2, function (left) {
541
- var handler = additionalInfo_1.infoHandlersMap[key];
542
- if (handler) {
543
- try {
544
- handler.read(reader, target, left, psd, options);
545
- }
546
- catch (e) {
547
- if (options.throwForMissingFeatures)
548
- throw e;
549
- }
550
- }
551
- else {
552
- options.logMissingFeatures && console.log("Unhandled additional info: ".concat(key));
553
- skipBytes(reader, left());
554
- }
555
- if (left()) {
556
- options.logMissingFeatures && console.log("Unread ".concat(left(), " bytes left for additional info: ").concat(key));
557
- skipBytes(reader, left());
558
- }
559
- }, false, u64);
560
- }
561
- function readImageData(reader, psd, globalAlpha, options) {
562
- var compression = readUint16(reader);
563
- if (exports.supportedColorModes.indexOf(psd.colorMode) === -1)
564
- throw new Error("Color mode not supported: ".concat(psd.colorMode));
565
- if (compression !== 0 /* Compression.RawData */ && compression !== 1 /* Compression.RleCompressed */)
566
- throw new Error("Compression type not supported: ".concat(compression));
567
- var imageData = (0, helpers_1.createImageData)(psd.width, psd.height);
568
- (0, helpers_1.resetImageData)(imageData);
569
- switch (psd.colorMode) {
570
- case 0 /* ColorMode.Bitmap */: {
571
- var bytes = void 0;
572
- if (compression === 0 /* Compression.RawData */) {
573
- bytes = readBytes(reader, Math.ceil(psd.width / 8) * psd.height);
574
- }
575
- else if (compression === 1 /* Compression.RleCompressed */) {
576
- bytes = new Uint8Array(psd.width * psd.height);
577
- readDataRLE(reader, { data: bytes, width: psd.width, height: psd.height }, psd.width, psd.height, 1, [0], options.large);
578
- }
579
- else {
580
- throw new Error("Bitmap compression not supported: ".concat(compression));
581
- }
582
- (0, helpers_1.decodeBitmap)(bytes, imageData.data, psd.width, psd.height);
583
- break;
584
- }
585
- case 3 /* ColorMode.RGB */:
586
- case 1 /* ColorMode.Grayscale */: {
587
- var channels = psd.colorMode === 1 /* ColorMode.Grayscale */ ? [0] : [0, 1, 2];
588
- if (psd.channels && psd.channels > 3) {
589
- for (var i = 3; i < psd.channels; i++) {
590
- // TODO: store these channels in additional image data
591
- channels.push(i);
592
- }
593
- }
594
- else if (globalAlpha) {
595
- channels.push(3);
596
- }
597
- if (compression === 0 /* Compression.RawData */) {
598
- for (var i = 0; i < channels.length; i++) {
599
- readDataRaw(reader, imageData, psd.width, psd.height, 4, channels[i]);
600
- }
601
- }
602
- else if (compression === 1 /* Compression.RleCompressed */) {
603
- var start = reader.offset;
604
- readDataRLE(reader, imageData, psd.width, psd.height, 4, channels, options.large);
605
- if (helpers_1.RAW_IMAGE_DATA)
606
- psd.imageDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start, reader.offset - start);
607
- }
608
- if (psd.colorMode === 1 /* ColorMode.Grayscale */) {
609
- setupGrayscale(imageData);
610
- }
611
- break;
612
- }
613
- case 4 /* ColorMode.CMYK */: {
614
- if (psd.channels !== 4)
615
- throw new Error("Invalid channel count");
616
- var channels = [0, 1, 2, 3];
617
- if (globalAlpha)
618
- channels.push(4);
619
- if (compression === 0 /* Compression.RawData */) {
620
- throw new Error("Not implemented");
621
- // TODO: ...
622
- // for (let i = 0; i < channels.length; i++) {
623
- // readDataRaw(reader, imageData, channels[i], psd.width, psd.height);
624
- // }
625
- }
626
- else if (compression === 1 /* Compression.RleCompressed */) {
627
- var cmykImageData = {
628
- width: imageData.width,
629
- height: imageData.height,
630
- data: new Uint8Array(imageData.width * imageData.height * 5),
631
- };
632
- var start = reader.offset;
633
- readDataRLE(reader, cmykImageData, psd.width, psd.height, 5, channels, options.large);
634
- cmykToRgb(cmykImageData, imageData, true);
635
- if (helpers_1.RAW_IMAGE_DATA)
636
- psd.imageDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start, reader.offset - start);
637
- }
638
- break;
639
- }
640
- default: throw new Error("Color mode not supported: ".concat(psd.colorMode));
641
- }
642
- if (options.useImageData) {
643
- psd.imageData = imageData;
644
- }
645
- else {
646
- psd.canvas = (0, helpers_1.createCanvas)(psd.width, psd.height);
647
- psd.canvas.getContext('2d').putImageData(imageData, 0, 0);
648
- }
649
- }
650
- function cmykToRgb(cmyk, rgb, reverseAlpha) {
651
- var size = rgb.width * rgb.height * 4;
652
- var srcData = cmyk.data;
653
- var dstData = rgb.data;
654
- for (var src = 0, dst = 0; dst < size; src += 5, dst += 4) {
655
- var c = srcData[src];
656
- var m = srcData[src + 1];
657
- var y = srcData[src + 2];
658
- var k = srcData[src + 3];
659
- dstData[dst] = ((((c * k) | 0) / 255) | 0);
660
- dstData[dst + 1] = ((((m * k) | 0) / 255) | 0);
661
- dstData[dst + 2] = ((((y * k) | 0) / 255) | 0);
662
- dstData[dst + 3] = reverseAlpha ? 255 - srcData[src + 4] : srcData[src + 4];
663
- }
664
- // for (let src = 0, dst = 0; dst < size; src += 5, dst += 4) {
665
- // const c = 1 - (srcData[src + 0] / 255);
666
- // const m = 1 - (srcData[src + 1] / 255);
667
- // const y = 1 - (srcData[src + 2] / 255);
668
- // // const k = srcData[src + 3] / 255;
669
- // dstData[dst + 0] = ((1 - c * 0.8) * 255) | 0;
670
- // dstData[dst + 1] = ((1 - m * 0.8) * 255) | 0;
671
- // dstData[dst + 2] = ((1 - y * 0.8) * 255) | 0;
672
- // dstData[dst + 3] = reverseAlpha ? 255 - srcData[src + 4] : srcData[src + 4];
673
- // }
674
- }
675
- function readDataRaw(reader, pixelData, width, height, step, offset) {
676
- var size = width * height;
677
- var buffer = readBytes(reader, size);
678
- if (pixelData && offset < step) {
679
- var data = pixelData.data;
680
- for (var i = 0, p = offset | 0; i < size; i++, p = (p + step) | 0) {
681
- data[p] = buffer[i];
682
- }
683
- }
684
- }
685
- function readDataZipWithoutPrediction(reader, length, pixelData, width, height, step, offset) {
686
- var compressed = readBytes(reader, length);
687
- var decompressed = (0, pako_1.inflate)(compressed);
688
- var size = width * height;
689
- if (pixelData && offset < step) {
690
- var data = pixelData.data;
691
- for (var i = 0, p = offset | 0; i < size; i++, p = (p + step) | 0) {
692
- data[p] = decompressed[i];
693
- }
694
- }
695
- }
696
- exports.readDataZipWithoutPrediction = readDataZipWithoutPrediction;
697
- function readDataRLE(reader, pixelData, _width, height, step, offsets, large) {
698
- var data = pixelData && pixelData.data;
699
- var lengths;
700
- if (large) {
701
- lengths = new Uint32Array(offsets.length * height);
702
- for (var o = 0, li = 0; o < offsets.length; o++) {
703
- for (var y = 0; y < height; y++, li++) {
704
- lengths[li] = readUint32(reader);
705
- }
706
- }
707
- }
708
- else {
709
- lengths = new Uint16Array(offsets.length * height);
710
- for (var o = 0, li = 0; o < offsets.length; o++) {
711
- for (var y = 0; y < height; y++, li++) {
712
- lengths[li] = readUint16(reader);
713
- }
714
- }
715
- }
716
- var extraLimit = (step - 1) | 0; // 3 for rgb, 4 for cmyk
717
- for (var c = 0, li = 0; c < offsets.length; c++) {
718
- var offset = offsets[c] | 0;
719
- var extra = c > extraLimit || offset > extraLimit;
720
- if (!data || extra) {
721
- for (var y = 0; y < height; y++, li++) {
722
- skipBytes(reader, lengths[li]);
723
- }
724
- }
725
- else {
726
- for (var y = 0, p = offset | 0; y < height; y++, li++) {
727
- var length_1 = lengths[li];
728
- var buffer = readBytes(reader, length_1);
729
- for (var i = 0; i < length_1; i++) {
730
- var header = buffer[i];
731
- if (header > 128) {
732
- var value = buffer[++i];
733
- header = (256 - header) | 0;
734
- for (var j = 0; j <= header; j = (j + 1) | 0) {
735
- data[p] = value;
736
- p = (p + step) | 0;
737
- }
738
- }
739
- else if (header < 128) {
740
- for (var j = 0; j <= header; j = (j + 1) | 0) {
741
- data[p] = buffer[++i];
742
- p = (p + step) | 0;
743
- }
744
- }
745
- else {
746
- // ignore 128
747
- }
748
- if (i >= length_1) {
749
- throw new Error("Invalid RLE data: exceeded buffer size ".concat(i, "/").concat(length_1));
750
- }
751
- }
752
- }
753
- }
754
- }
755
- }
756
- exports.readDataRLE = readDataRLE;
757
- function readSection(reader, round, func, skipEmpty, eightBytes) {
758
- if (skipEmpty === void 0) { skipEmpty = true; }
759
- if (eightBytes === void 0) { eightBytes = false; }
760
- var length = readUint32(reader);
761
- if (eightBytes) {
762
- if (length !== 0)
763
- throw new Error('Sizes larger than 4GB are not supported');
764
- length = readUint32(reader);
765
- }
766
- if (length <= 0 && skipEmpty)
767
- return undefined;
768
- var end = reader.offset + length;
769
- if (end > reader.view.byteLength)
770
- throw new Error('Section exceeds file size');
771
- var result = func(function () { return end - reader.offset; });
772
- if (reader.offset !== end && reader.strict) {
773
- if (reader.offset > end) {
774
- // throw new Error('Exceeded section limits');
775
- console.warn('Exceeded section limits');
776
- }
777
- else {
778
- // throw new Error(`Unread section data: ${end - reader.offset} bytes at 0x${reader.offset.toString(16)}`);
779
- console.warn('Unread section data');
780
- }
781
- }
782
- while (end % round)
783
- end++;
784
- reader.offset = end;
785
- return result;
786
- }
787
- exports.readSection = readSection;
788
- function readColor(reader) {
789
- var colorSpace = readUint16(reader);
790
- switch (colorSpace) {
791
- case 0 /* ColorSpace.RGB */: {
792
- var r = readUint16(reader) / 257;
793
- var g = readUint16(reader) / 257;
794
- var b = readUint16(reader) / 257;
795
- skipBytes(reader, 2);
796
- return { r: r, g: g, b: b };
797
- }
798
- case 1 /* ColorSpace.HSB */: {
799
- var h = readUint16(reader) / 0xffff;
800
- var s = readUint16(reader) / 0xffff;
801
- var b = readUint16(reader) / 0xffff;
802
- skipBytes(reader, 2);
803
- return { h: h, s: s, b: b };
804
- }
805
- case 2 /* ColorSpace.CMYK */: {
806
- var c = readUint16(reader) / 257;
807
- var m = readUint16(reader) / 257;
808
- var y = readUint16(reader) / 257;
809
- var k = readUint16(reader) / 257;
810
- return { c: c, m: m, y: y, k: k };
811
- }
812
- case 7 /* ColorSpace.Lab */: {
813
- var l = readInt16(reader) / 10000;
814
- var ta = readInt16(reader);
815
- var tb = readInt16(reader);
816
- var a = ta < 0 ? (ta / 12800) : (ta / 12700);
817
- var b = tb < 0 ? (tb / 12800) : (tb / 12700);
818
- skipBytes(reader, 2);
819
- return { l: l, a: a, b: b };
820
- }
821
- case 8 /* ColorSpace.Grayscale */: {
822
- var k = readUint16(reader) * 255 / 10000;
823
- skipBytes(reader, 6);
824
- return { k: k };
825
- }
826
- default:
827
- throw new Error('Invalid color space');
828
- }
829
- }
830
- exports.readColor = readColor;
831
- function readPattern(reader) {
832
- readUint32(reader); // length
833
- var version = readUint32(reader);
834
- if (version !== 1)
835
- throw new Error("Invalid pattern version: ".concat(version));
836
- var colorMode = readUint32(reader);
837
- var x = readInt16(reader);
838
- var y = readInt16(reader);
839
- // we only support RGB and grayscale for now
840
- if (colorMode !== 3 /* ColorMode.RGB */ && colorMode !== 1 /* ColorMode.Grayscale */ && colorMode !== 2 /* ColorMode.Indexed */) {
841
- throw new Error("Unsupported pattern color mode: ".concat(colorMode));
842
- }
843
- var name = readUnicodeString(reader);
844
- var id = readPascalString(reader, 1);
845
- var palette = [];
846
- if (colorMode === 2 /* ColorMode.Indexed */) {
847
- for (var i = 0; i < 256; i++) {
848
- palette.push({
849
- r: readUint8(reader),
850
- g: readUint8(reader),
851
- b: readUint8(reader),
852
- });
853
- }
854
- skipBytes(reader, 4); // no idea what this is
855
- }
856
- // virtual memory array list
857
- var version2 = readUint32(reader);
858
- if (version2 !== 3)
859
- throw new Error("Invalid pattern VMAL version: ".concat(version2));
860
- readUint32(reader); // length
861
- var top = readUint32(reader);
862
- var left = readUint32(reader);
863
- var bottom = readUint32(reader);
864
- var right = readUint32(reader);
865
- var channelsCount = readUint32(reader);
866
- var width = right - left;
867
- var height = bottom - top;
868
- var data = new Uint8Array(width * height * 4);
869
- for (var i = 3; i < data.byteLength; i += 4) {
870
- data[i] = 255;
871
- }
872
- for (var i = 0, ch = 0; i < (channelsCount + 2); i++) {
873
- var has = readUint32(reader);
874
- if (!has)
875
- continue;
876
- var length_2 = readUint32(reader);
877
- var pixelDepth = readUint32(reader);
878
- var ctop = readUint32(reader);
879
- var cleft = readUint32(reader);
880
- var cbottom = readUint32(reader);
881
- var cright = readUint32(reader);
882
- var pixelDepth2 = readUint16(reader);
883
- var compressionMode = readUint8(reader); // 0 - raw, 1 - zip
884
- var dataLength = length_2 - (4 + 16 + 2 + 1);
885
- var cdata = readBytes(reader, dataLength);
886
- if (pixelDepth !== 8 || pixelDepth2 !== 8) {
887
- throw new Error('16bit pixel depth not supported for patterns');
888
- }
889
- var w = cright - cleft;
890
- var h = cbottom - ctop;
891
- var ox = cleft - left;
892
- var oy = ctop - top;
893
- if (compressionMode === 0) {
894
- if (colorMode === 3 /* ColorMode.RGB */ && ch < 3) {
895
- for (var y_1 = 0; y_1 < h; y_1++) {
896
- for (var x_1 = 0; x_1 < w; x_1++) {
897
- var src = x_1 + y_1 * w;
898
- var dst = (ox + x_1 + (y_1 + oy) * width) * 4;
899
- data[dst + ch] = cdata[src];
900
- }
901
- }
902
- }
903
- if (colorMode === 1 /* ColorMode.Grayscale */ && ch < 1) {
904
- for (var y_2 = 0; y_2 < h; y_2++) {
905
- for (var x_2 = 0; x_2 < w; x_2++) {
906
- var src = x_2 + y_2 * w;
907
- var dst = (ox + x_2 + (y_2 + oy) * width) * 4;
908
- var value = cdata[src];
909
- data[dst + 0] = value;
910
- data[dst + 1] = value;
911
- data[dst + 2] = value;
912
- }
913
- }
914
- }
915
- if (colorMode === 2 /* ColorMode.Indexed */) {
916
- // TODO:
917
- throw new Error('Indexed pattern color mode not implemented');
918
- }
919
- }
920
- else if (compressionMode === 1) {
921
- // console.log({ colorMode });
922
- // require('fs').writeFileSync('zip.bin', Buffer.from(cdata));
923
- // const data = require('zlib').inflateRawSync(cdata);
924
- // const data = require('zlib').unzipSync(cdata);
925
- // console.log(data);
926
- // throw new Error('Zip compression not supported for pattern');
927
- // throw new Error('Unsupported pattern compression');
928
- console.error('Unsupported pattern compression');
929
- name += ' (failed to decode)';
930
- }
931
- else {
932
- throw new Error('Invalid pattern compression mode');
933
- }
934
- ch++;
935
- }
936
- // TODO: use canvas instead of data ?
937
- return { id: id, name: name, x: x, y: y, bounds: { x: left, y: top, w: width, h: height }, data: data };
938
- }
939
- exports.readPattern = readPattern;
940
-
941
- //# sourceMappingURL=data:application/json;charset=utf8;base64,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TSxDQUFDLEdBQUcsR0FBRyxDQUFDO1lBQ25DLFNBQVMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDckIsT0FBTyxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUM7U0FDbkI7UUFDRCwyQkFBbUIsQ0FBQyxDQUFDO1lBQ3BCLElBQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUMsR0FBRyxNQUFNLENBQUM7WUFDdEMsSUFBTSxDQUFDLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxHQUFHLE1BQU0sQ0FBQztZQUN0QyxJQUFNLENBQUMsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDLEdBQUcsTUFBTSxDQUFDO1lBQ3RDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDckIsT0FBTyxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUM7U0FDbkI7UUFDRCw0QkFBb0IsQ0FBQyxDQUFDO1lBQ3JCLElBQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUM7WUFDbkMsSUFBTSxDQUFDLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEdBQUcsQ0FBQztZQUNuQyxJQUFNLENBQUMsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDLEdBQUcsR0FBRyxDQUFDO1lBQ25DLElBQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUM7WUFDbkMsT0FBTyxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUMsR0FBQSxFQUFFLENBQUM7U0FDdEI7UUFDRCwyQkFBbUIsQ0FBQyxDQUFDO1lBQ3BCLElBQU0sQ0FBQyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDcEMsSUFBTSxFQUFFLEdBQUcsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQzdC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WUFDakQsSUFBSSxJQUFJLHFCQUFxQixDQUFDO1NBQzlCO2FBQU07WUFDTixNQUFNLElBQUksS0FBSyxDQUFDLGtDQUFrQyxDQUFDLENBQUM7U0FDcEQ7UUFFRCxFQUFFLEVBQUUsQ0FBQztLQUNMO0lBRUQscUNBQXFDO0lBRXJDLE9BQU8sRUFBRSxFQUFFLElBQUEsRUFBRSxJQUFJLE1BQUEsRUFBRSxDQUFDLEdBQUEsRUFBRSxDQUFDLEdBQUEsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUUsSUFBSSxNQUFBLEVBQUUsQ0FBQztBQUNuRixDQUFDO0FBeEhELGtDQXdIQyIsImZpbGUiOiJwc2RSZWFkZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmZsYXRlIH0gZnJvbSAncGFrbyc7XG5pbXBvcnQge1xuXHRQc2QsIExheWVyLCBDb2xvck1vZGUsIFNlY3Rpb25EaXZpZGVyVHlwZSwgTGF5ZXJBZGRpdGlvbmFsSW5mbywgUmVhZE9wdGlvbnMsIExheWVyTWFza0RhdGEsIENvbG9yLFxuXHRQYXR0ZXJuSW5mbywgR2xvYmFsTGF5ZXJNYXNrSW5mbywgUkdCXG59IGZyb20gJy4vcHNkJztcbmltcG9ydCB7XG5cdHJlc2V0SW1hZ2VEYXRhLCBvZmZzZXRGb3JDaGFubmVsLCBkZWNvZGVCaXRtYXAsIFBpeGVsRGF0YSwgY3JlYXRlQ2FudmFzLCBjcmVhdGVJbWFnZURhdGEsXG5cdHRvQmxlbmRNb2RlLCBDaGFubmVsSUQsIENvbXByZXNzaW9uLCBMYXllck1hc2tGbGFncywgTWFza1BhcmFtcywgQ29sb3JTcGFjZSwgUkFXX0lNQUdFX0RBVEEsIGxhcmdlQWRkaXRpb25hbEluZm9LZXlzXG59IGZyb20gJy4vaGVscGVycyc7XG5pbXBvcnQgeyBpbmZvSGFuZGxlcnNNYXAgfSBmcm9tICcuL2FkZGl0aW9uYWxJbmZvJztcbmltcG9ydCB7IHJlc291cmNlSGFuZGxlcnNNYXAgfSBmcm9tICcuL2ltYWdlUmVzb3VyY2VzJztcblxuaW50ZXJmYWNlIENoYW5uZWxJbmZvIHtcblx0aWQ6IENoYW5uZWxJRDtcblx0bGVuZ3RoOiBudW1iZXI7XG59XG5cbmludGVyZmFjZSBSZWFkT3B0aW9uc0V4dCBleHRlbmRzIFJlYWRPcHRpb25zIHtcblx0bGFyZ2U6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBzdXBwb3J0ZWRDb2xvck1vZGVzID0gW0NvbG9yTW9kZS5CaXRtYXAsIENvbG9yTW9kZS5HcmF5c2NhbGUsIENvbG9yTW9kZS5SR0JdO1xuY29uc3QgY29sb3JNb2RlcyA9IFsnYml0bWFwJywgJ2dyYXlzY2FsZScsICdpbmRleGVkJywgJ1JHQicsICdDTVlLJywgJ211bHRpY2hhbm5lbCcsICdkdW90b25lJywgJ2xhYiddO1xuXG5mdW5jdGlvbiBzZXR1cEdyYXlzY2FsZShkYXRhOiBQaXhlbERhdGEpIHtcblx0Y29uc3Qgc2l6ZSA9IGRhdGEud2lkdGggKiBkYXRhLmhlaWdodCAqIDQ7XG5cblx0Zm9yIChsZXQgaSA9IDA7IGkgPCBzaXplOyBpICs9IDQpIHtcblx0XHRkYXRhLmRhdGFbaSArIDFdID0gZGF0YS5kYXRhW2ldO1xuXHRcdGRhdGEuZGF0YVtpICsgMl0gPSBkYXRhLmRhdGFbaV07XG5cdH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBQc2RSZWFkZXIge1xuXHRvZmZzZXQ6IG51bWJlcjtcblx0dmlldzogRGF0YVZpZXc7XG5cdHN0cmljdDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlYWRlcihidWZmZXI6IEFycmF5QnVmZmVyLCBvZmZzZXQ/OiBudW1iZXIsIGxlbmd0aD86IG51bWJlcik6IFBzZFJlYWRlciB7XG5cdGNvbnN0IHZpZXcgPSBuZXcgRGF0YVZpZXcoYnVmZmVyLCBvZmZzZXQsIGxlbmd0aCk7XG5cdHJldHVybiB7IHZpZXcsIG9mZnNldDogMCwgc3RyaWN0OiBmYWxzZSB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZFVpbnQ4KHJlYWRlcjogUHNkUmVhZGVyKSB7XG5cdHJlYWRlci5vZmZzZXQgKz0gMTtcblx0cmV0dXJuIHJlYWRlci52aWV3LmdldFVpbnQ4KHJlYWRlci5vZmZzZXQgLSAxKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHBlZWtVaW50OChyZWFkZXI6IFBzZFJlYWRlcikge1xuXHRyZXR1cm4gcmVhZGVyLnZpZXcuZ2V0VWludDgocmVhZGVyLm9mZnNldCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkSW50MTYocmVhZGVyOiBQc2RSZWFkZXIpIHtcblx0cmVhZGVyLm9mZnNldCArPSAyO1xuXHRyZXR1cm4gcmVhZGVyLnZpZXcuZ2V0SW50MTYocmVhZGVyLm9mZnNldCAtIDIsIGZhbHNlKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlYWRVaW50MTYocmVhZGVyOiBQc2RSZWFkZXIpIHtcblx0cmVhZGVyLm9mZnNldCArPSAyO1xuXHRyZXR1cm4gcmVhZGVyLnZpZXcuZ2V0VWludDE2KHJlYWRlci5vZmZzZXQgLSAyLCBmYWxzZSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkSW50MzIocmVhZGVyOiBQc2RSZWFkZXIpIHtcblx0cmVhZGVyLm9mZnNldCArPSA0O1xuXHRyZXR1cm4gcmVhZGVyLnZpZXcuZ2V0SW50MzIocmVhZGVyLm9mZnNldCAtIDQsIGZhbHNlKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlYWRJbnQzMkxFKHJlYWRlcjogUHNkUmVhZGVyKSB7XG5cdHJlYWRlci5vZmZzZXQgKz0gNDtcblx0cmV0dXJuIHJlYWRlci52aWV3LmdldEludDMyKHJlYWRlci5vZmZzZXQgLSA0LCB0cnVlKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlYWRVaW50MzIocmVhZGVyOiBQc2RSZWFkZXIpIHtcblx0cmVhZGVyLm9mZnNldCArPSA0O1xuXHRyZXR1cm4gcmVhZGVyLnZpZXcuZ2V0VWludDMyKHJlYWRlci5vZmZzZXQgLSA0LCBmYWxzZSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkRmxvYXQzMihyZWFkZXI6IFBzZFJlYWRlcikge1xuXHRyZWFkZXIub2Zmc2V0ICs9IDQ7XG5cdHJldHVybiByZWFkZXIudmlldy5nZXRGbG9hdDMyKHJlYWRlci5vZmZzZXQgLSA0LCBmYWxzZSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkRmxvYXQ2NChyZWFkZXI6IFBzZFJlYWRlcikge1xuXHRyZWFkZXIub2Zmc2V0ICs9IDg7XG5cdHJldHVybiByZWFkZXIudmlldy5nZXRGbG9hdDY0KHJlYWRlci5vZmZzZXQgLSA4LCBmYWxzZSk7XG59XG5cbi8vIDMyLWJpdCBmaXhlZC1wb2ludCBudW1iZXIgMTYuMTZcbmV4cG9ydCBmdW5jdGlvbiByZWFkRml4ZWRQb2ludDMyKHJlYWRlcjogUHNkUmVhZGVyKTogbnVtYmVyIHtcblx0cmV0dXJuIHJlYWRJbnQzMihyZWFkZXIpIC8gKDEgPDwgMTYpO1xufVxuXG4vLyAzMi1iaXQgZml4ZWQtcG9pbnQgbnVtYmVyIDguMjRcbmV4cG9ydCBmdW5jdGlvbiByZWFkRml4ZWRQb2ludFBhdGgzMihyZWFkZXI6IFBzZFJlYWRlcik6IG51bWJlciB7XG5cdHJldHVybiByZWFkSW50MzIocmVhZGVyKSAvICgxIDw8IDI0KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlYWRCeXRlcyhyZWFkZXI6IFBzZFJlYWRlciwgbGVuZ3RoOiBudW1iZXIpIHtcblx0cmVhZGVyLm9mZnNldCArPSBsZW5ndGg7XG5cdHJldHVybiBuZXcgVWludDhBcnJheShyZWFkZXIudmlldy5idWZmZXIsIHJlYWRlci52aWV3LmJ5dGVPZmZzZXQgKyByZWFkZXIub2Zmc2V0IC0gbGVuZ3RoLCBsZW5ndGgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZFNpZ25hdHVyZShyZWFkZXI6IFBzZFJlYWRlcikge1xuXHRyZXR1cm4gcmVhZFNob3J0U3RyaW5nKHJlYWRlciwgNCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkUGFzY2FsU3RyaW5nKHJlYWRlcjogUHNkUmVhZGVyLCBwYWRUbzogbnVtYmVyKSB7XG5cdGxldCBsZW5ndGggPSByZWFkVWludDgocmVhZGVyKTtcblx0Y29uc3QgdGV4dCA9IGxlbmd0aCA/IHJlYWRTaG9ydFN0cmluZyhyZWFkZXIsIGxlbmd0aCkgOiAnJztcblxuXHR3aGlsZSAoKytsZW5ndGggJSBwYWRUbykge1xuXHRcdHJlYWRlci5vZmZzZXQrKztcblx0fVxuXG5cdHJldHVybiB0ZXh0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZFVuaWNvZGVTdHJpbmcocmVhZGVyOiBQc2RSZWFkZXIpIHtcblx0Y29uc3QgbGVuZ3RoID0gcmVhZFVpbnQzMihyZWFkZXIpO1xuXHRyZXR1cm4gcmVhZFVuaWNvZGVTdHJpbmdXaXRoTGVuZ3RoKHJlYWRlciwgbGVuZ3RoKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlYWRVbmljb2RlU3RyaW5nV2l0aExlbmd0aChyZWFkZXI6IFBzZFJlYWRlciwgbGVuZ3RoOiBudW1iZXIpIHtcblx0bGV0IHRleHQgPSAnJztcblxuXHR3aGlsZSAobGVuZ3RoLS0pIHtcblx0XHRjb25zdCB2YWx1ZSA9IHJlYWRVaW50MTYocmVhZGVyKTtcblxuXHRcdGlmICh2YWx1ZSB8fCBsZW5ndGggPiAwKSB7IC8vIHJlbW92ZSB0cmFpbGluZyBcXDBcblx0XHRcdHRleHQgKz0gU3RyaW5nLmZyb21DaGFyQ29kZSh2YWx1ZSk7XG5cdFx0fVxuXHR9XG5cblx0cmV0dXJuIHRleHQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkQXNjaWlTdHJpbmcocmVhZGVyOiBQc2RSZWFkZXIsIGxlbmd0aDogbnVtYmVyKSB7XG5cdGxldCB0ZXh0ID0gJyc7XG5cblx0d2hpbGUgKGxlbmd0aC0tKSB7XG5cdFx0dGV4dCArPSBTdHJpbmcuZnJvbUNoYXJDb2RlKHJlYWRVaW50OChyZWFkZXIpKTtcblx0fVxuXG5cdHJldHVybiB0ZXh0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2tpcEJ5dGVzKHJlYWRlcjogUHNkUmVhZGVyLCBjb3VudDogbnVtYmVyKSB7XG5cdHJlYWRlci5vZmZzZXQgKz0gY291bnQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjaGVja1NpZ25hdHVyZShyZWFkZXI6IFBzZFJlYWRlciwgYTogc3RyaW5nLCBiPzogc3RyaW5nKSB7XG5cdGNvbnN0IG9mZnNldCA9IHJlYWRlci5vZmZzZXQ7XG5cdGNvbnN0IHNpZ25hdHVyZSA9IHJlYWRTaWduYXR1cmUocmVhZGVyKTtcblxuXHRpZiAoc2lnbmF0dXJlICE9PSBhICYmIHNpZ25hdHVyZSAhPT0gYikge1xuXHRcdHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBzaWduYXR1cmU6ICcke3NpZ25hdHVyZX0nIGF0IDB4JHtvZmZzZXQudG9TdHJpbmcoMTYpfWApO1xuXHR9XG59XG5cbmZ1bmN0aW9uIHJlYWRTaG9ydFN0cmluZyhyZWFkZXI6IFBzZFJlYWRlciwgbGVuZ3RoOiBudW1iZXIpIHtcblx0Y29uc3QgYnVmZmVyID0gcmVhZEJ5dGVzKHJlYWRlciwgbGVuZ3RoKTtcblx0bGV0IHJlc3VsdCA9ICcnO1xuXG5cdGZvciAobGV0IGkgPSAwOyBpIDwgYnVmZmVyLmxlbmd0aDsgaSsrKSB7XG5cdFx0cmVzdWx0ICs9IFN0cmluZy5mcm9tQ2hhckNvZGUoYnVmZmVyW2ldKTtcblx0fVxuXG5cdHJldHVybiByZXN1bHQ7XG59XG5cbmZ1bmN0aW9uIGlzVmFsaWRTaWduYXR1cmUoc2lnOiBzdHJpbmcpIHtcblx0cmV0dXJuIHNpZyA9PT0gJzhCSU0nIHx8IHNpZyA9PT0gJ01lU2EnIHx8IHNpZyA9PT0gJ0FnSGcnIHx8IHNpZyA9PT0gJ1BIVVQnIHx8IHNpZyA9PT0gJ0RDU1InO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZFBzZChyZWFkZXI6IFBzZFJlYWRlciwgb3B0aW9uczogUmVhZE9wdGlvbnMgPSB7fSkge1xuXHQvLyBoZWFkZXJcblx0Y2hlY2tTaWduYXR1cmUocmVhZGVyLCAnOEJQUycpO1xuXHRjb25zdCB2ZXJzaW9uID0gcmVhZFVpbnQxNihyZWFkZXIpO1xuXHRpZiAodmVyc2lvbiAhPT0gMSAmJiB2ZXJzaW9uICE9PSAyKSB0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgUFNEIGZpbGUgdmVyc2lvbjogJHt2ZXJzaW9ufWApO1xuXG5cdHNraXBCeXRlcyhyZWFkZXIsIDYpO1xuXHRjb25zdCBjaGFubmVscyA9IHJlYWRVaW50MTYocmVhZGVyKTtcblx0Y29uc3QgaGVpZ2h0ID0gcmVhZFVpbnQzMihyZWFkZXIpO1xuXHRjb25zdCB3aWR0aCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0Y29uc3QgYml0c1BlckNoYW5uZWwgPSByZWFkVWludDE2KHJlYWRlcik7XG5cdGNvbnN0IGNvbG9yTW9kZSA9IHJlYWRVaW50MTYocmVhZGVyKTtcblx0Y29uc3QgbWF4U2l6ZSA9IHZlcnNpb24gPT09IDEgPyAzMDAwMCA6IDMwMDAwMDtcblxuXHRpZiAod2lkdGggPiBtYXhTaXplIHx8IGhlaWdodCA+IG1heFNpemUpIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBzaXplYCk7XG5cdGlmIChjaGFubmVscyA+IDE2KSB0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgY2hhbm5lbCBjb3VudGApO1xuXHRpZiAoYml0c1BlckNoYW5uZWwgPiAzMikgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGJpdHNQZXJDaGFubmVsIGNvdW50YCk7XG5cdGlmIChzdXBwb3J0ZWRDb2xvck1vZGVzLmluZGV4T2YoY29sb3JNb2RlKSA9PT0gLTEpXG5cdFx0dGhyb3cgbmV3IEVycm9yKGBDb2xvciBtb2RlIG5vdCBzdXBwb3J0ZWQ6ICR7Y29sb3JNb2Rlc1tjb2xvck1vZGVdID8/IGNvbG9yTW9kZX1gKTtcblxuXHRjb25zdCBwc2Q6IFBzZCA9IHsgd2lkdGgsIGhlaWdodCwgY2hhbm5lbHMsIGJpdHNQZXJDaGFubmVsLCBjb2xvck1vZGUgfTtcblx0Y29uc3Qgb3B0OiBSZWFkT3B0aW9uc0V4dCA9IHsgLi4ub3B0aW9ucywgbGFyZ2U6IHZlcnNpb24gPT09IDIgfTtcblx0Y29uc3QgZml4T2Zmc2V0cyA9IFswLCAxLCAtMSwgMiwgLTIsIDMsIC0zLCA0LCAtNF07XG5cblx0Ly8gY29sb3IgbW9kZSBkYXRhXG5cdHJlYWRTZWN0aW9uKHJlYWRlciwgMSwgbGVmdCA9PiB7XG5cdFx0aWYgKG9wdC50aHJvd0Zvck1pc3NpbmdGZWF0dXJlcykgdGhyb3cgbmV3IEVycm9yKCdDb2xvciBtb2RlIGRhdGEgbm90IHN1cHBvcnRlZCcpO1xuXHRcdHNraXBCeXRlcyhyZWFkZXIsIGxlZnQoKSk7XG5cdH0pO1xuXG5cdC8vIGltYWdlIHJlc291cmNlc1xuXHRyZWFkU2VjdGlvbihyZWFkZXIsIDEsIGxlZnQgPT4ge1xuXHRcdHdoaWxlIChsZWZ0KCkpIHtcblx0XHRcdGNvbnN0IHNpZ09mZnNldCA9IHJlYWRlci5vZmZzZXQ7XG5cdFx0XHRsZXQgc2lnID0gJyc7XG5cblx0XHRcdC8vIGF0dGVtcHQgdG8gZml4IGJyb2tlbiBkb2N1bWVudCBieSByZWFsaWduaW5nIHdpdGggdGhlIHNpZ25hdHVyZVxuXHRcdFx0Zm9yIChjb25zdCBvZmZzZXQgb2YgZml4T2Zmc2V0cykge1xuXHRcdFx0XHR0cnkge1xuXHRcdFx0XHRcdHJlYWRlci5vZmZzZXQgPSBzaWdPZmZzZXQgKyBvZmZzZXQ7XG5cdFx0XHRcdFx0c2lnID0gcmVhZFNpZ25hdHVyZShyZWFkZXIpO1xuXHRcdFx0XHR9IGNhdGNoIHsgfVxuXHRcdFx0XHRpZiAoaXNWYWxpZFNpZ25hdHVyZShzaWcpKSBicmVhaztcblx0XHRcdH1cblxuXHRcdFx0aWYgKCFpc1ZhbGlkU2lnbmF0dXJlKHNpZykpIHtcblx0XHRcdFx0dGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIHNpZ25hdHVyZTogJyR7c2lnfScgYXQgMHgkeyhzaWdPZmZzZXQpLnRvU3RyaW5nKDE2KX1gKTtcblx0XHRcdH1cblxuXHRcdFx0Y29uc3QgaWQgPSByZWFkVWludDE2KHJlYWRlcik7XG5cdFx0XHRyZWFkUGFzY2FsU3RyaW5nKHJlYWRlciwgMik7IC8vIG5hbWVcblxuXHRcdFx0cmVhZFNlY3Rpb24ocmVhZGVyLCAyLCBsZWZ0ID0+IHtcblx0XHRcdFx0Y29uc3QgaGFuZGxlciA9IHJlc291cmNlSGFuZGxlcnNNYXBbaWRdO1xuXHRcdFx0XHRjb25zdCBza2lwID0gaWQgPT09IDEwMzYgJiYgISFvcHQuc2tpcFRodW1ibmFpbDtcblxuXHRcdFx0XHRpZiAoIXBzZC5pbWFnZVJlc291cmNlcykge1xuXHRcdFx0XHRcdHBzZC5pbWFnZVJlc291cmNlcyA9IHt9O1xuXHRcdFx0XHR9XG5cblx0XHRcdFx0aWYgKGhhbmRsZXIgJiYgIXNraXApIHtcblx0XHRcdFx0XHR0cnkge1xuXHRcdFx0XHRcdFx0aGFuZGxlci5yZWFkKHJlYWRlciwgcHNkLmltYWdlUmVzb3VyY2VzLCBsZWZ0LCBvcHQpO1xuXHRcdFx0XHRcdH0gY2F0Y2ggKGUpIHtcblx0XHRcdFx0XHRcdGlmIChvcHQudGhyb3dGb3JNaXNzaW5nRmVhdHVyZXMpIHRocm93IGU7XG5cdFx0XHRcdFx0XHRza2lwQnl0ZXMocmVhZGVyLCBsZWZ0KCkpO1xuXHRcdFx0XHRcdH1cblx0XHRcdFx0fSBlbHNlIHtcblx0XHRcdFx0XHQvLyBvcHRpb25zLmxvZ01pc3NpbmdGZWF0dXJlcyAmJiBjb25zb2xlLmxvZyhgVW5oYW5kbGVkIGltYWdlIHJlc291cmNlOiAke2lkfWApO1xuXHRcdFx0XHRcdHNraXBCeXRlcyhyZWFkZXIsIGxlZnQoKSk7XG5cdFx0XHRcdH1cblx0XHRcdH0pO1xuXHRcdH1cblx0fSk7XG5cblx0Ly8gbGF5ZXIgYW5kIG1hc2sgaW5mb1xuXHRsZXQgZ2xvYmFsQWxwaGEgPSBmYWxzZTtcblxuXHRyZWFkU2VjdGlvbihyZWFkZXIsIDEsIGxlZnQgPT4ge1xuXHRcdGdsb2JhbEFscGhhID0gcmVhZExheWVySW5mbyhyZWFkZXIsIHBzZCwgb3B0KTtcblxuXHRcdC8vIFNBSSBkb2VzIG5vdCBpbmNsdWRlIHRoaXMgc2VjdGlvblxuXHRcdGlmIChsZWZ0KCkgPiAwKSB7XG5cdFx0XHRjb25zdCBnbG9iYWxMYXllck1hc2tJbmZvID0gcmVhZEdsb2JhbExheWVyTWFza0luZm8ocmVhZGVyKTtcblx0XHRcdGlmIChnbG9iYWxMYXllck1hc2tJbmZvKSBwc2QuZ2xvYmFsTGF5ZXJNYXNrSW5mbyA9IGdsb2JhbExheWVyTWFza0luZm87XG5cdFx0fSBlbHNlIHtcblx0XHRcdC8vIHJldmVydCBiYWNrIHRvIGVuZCBvZiBzZWN0aW9uIGlmIGV4Y2VlZGVkIHNlY3Rpb24gbGltaXRzXG5cdFx0XHQvLyBvcHQubG9nTWlzc2luZ0ZlYXR1cmVzICYmIGNvbnNvbGUubG9nKCdyZXZlcnRpbmcgdG8gZW5kIG9mIHNlY3Rpb24nKTtcblx0XHRcdHNraXBCeXRlcyhyZWFkZXIsIGxlZnQoKSk7XG5cdFx0fVxuXG5cdFx0d2hpbGUgKGxlZnQoKSA+IDApIHtcblx0XHRcdC8vIHNvbWV0aW1lcyB0aGVyZSBhcmUgZW1wdHkgYnl0ZXMgaGVyZVxuXHRcdFx0d2hpbGUgKGxlZnQoKSAmJiBwZWVrVWludDgocmVhZGVyKSA9PT0gMCkge1xuXHRcdFx0XHQvLyBvcHQubG9nTWlzc2luZ0ZlYXR1cmVzICYmIGNvbnNvbGUubG9nKCdza2lwcGluZyAwIGJ5dGUnKTtcblx0XHRcdFx0c2tpcEJ5dGVzKHJlYWRlciwgMSk7XG5cdFx0XHR9XG5cblx0XHRcdGlmIChsZWZ0KCkgPj0gMTIpIHtcblx0XHRcdFx0cmVhZEFkZGl0aW9uYWxMYXllckluZm8ocmVhZGVyLCBwc2QsIHBzZCwgb3B0KTtcblx0XHRcdH0gZWxzZSB7XG5cdFx0XHRcdC8vIG9wdC5sb2dNaXNzaW5nRmVhdHVyZXMgJiYgY29uc29sZS5sb2coJ3NraXBwaW5nIGxlZnRvdmVyIGJ5dGVzJywgbGVmdCgpKTtcblx0XHRcdFx0c2tpcEJ5dGVzKHJlYWRlciwgbGVmdCgpKTtcblx0XHRcdH1cblx0XHR9XG5cdH0sIHVuZGVmaW5lZCwgb3B0LmxhcmdlKTtcblxuXHRjb25zdCBoYXNDaGlsZHJlbiA9IHBzZC5jaGlsZHJlbiAmJiBwc2QuY2hpbGRyZW4ubGVuZ3RoO1xuXHRjb25zdCBza2lwQ29tcG9zaXRlID0gb3B0LnNraXBDb21wb3NpdGVJbWFnZURhdGEgJiYgKG9wdC5za2lwTGF5ZXJJbWFnZURhdGEgfHwgaGFzQ2hpbGRyZW4pO1xuXG5cdGlmICghc2tpcENvbXBvc2l0ZSkge1xuXHRcdHJlYWRJbWFnZURhdGEocmVhZGVyLCBwc2QsIGdsb2JhbEFscGhhLCBvcHQpO1xuXHR9XG5cblx0Ly8gVE9ETzogc2hvdyBjb252ZXJ0ZWQgY29sb3IgbW9kZSBpbnN0ZWFkIG9mIG9yaWdpbmFsIFBTRCBmaWxlIGNvbG9yIG1vZGVcblx0Ly8gICAgICAgYnV0IGFkZCBvcHRpb24gdG8gcHJlc2VydmUgZmlsZSBjb2xvciBtb2RlIChuZWVkIHRvIHJldHVybiBpbWFnZSBkYXRhIGluc3RlYWQgb2YgY2FudmFzIGluIHRoYXQgY2FzZSlcblx0Ly8gcHNkLmNvbG9yTW9kZSA9IENvbG9yTW9kZS5SR0I7IC8vIHdlIGNvbnZlcnQgYWxsIGNvbG9yIG1vZGVzIHRvIFJHQlxuXG5cdHJldHVybiBwc2Q7XG59XG5cbmZ1bmN0aW9uIHJlYWRMYXllckluZm8ocmVhZGVyOiBQc2RSZWFkZXIsIHBzZDogUHNkLCBvcHRpb25zOiBSZWFkT3B0aW9uc0V4dCkge1xuXHRsZXQgZ2xvYmFsQWxwaGEgPSBmYWxzZTtcblxuXHRyZWFkU2VjdGlvbihyZWFkZXIsIDIsIGxlZnQgPT4ge1xuXHRcdGxldCBsYXllckNvdW50ID0gcmVhZEludDE2KHJlYWRlcik7XG5cblx0XHRpZiAobGF5ZXJDb3VudCA8IDApIHtcblx0XHRcdGdsb2JhbEFscGhhID0gdHJ1ZTtcblx0XHRcdGxheWVyQ291bnQgPSAtbGF5ZXJDb3VudDtcblx0XHR9XG5cblx0XHRjb25zdCBsYXllcnM6IExheWVyW10gPSBbXTtcblx0XHRjb25zdCBsYXllckNoYW5uZWxzOiBDaGFubmVsSW5mb1tdW10gPSBbXTtcblxuXHRcdGZvciAobGV0IGkgPSAwOyBpIDwgbGF5ZXJDb3VudDsgaSsrKSB7XG5cdFx0XHRjb25zdCB7IGxheWVyLCBjaGFubmVscyB9ID0gcmVhZExheWVyUmVjb3JkKHJlYWRlciwgcHNkLCBvcHRpb25zKTtcblx0XHRcdGxheWVycy5wdXNoKGxheWVyKTtcblx0XHRcdGxheWVyQ2hhbm5lbHMucHVzaChjaGFubmVscyk7XG5cdFx0fVxuXG5cdFx0aWYgKCFvcHRpb25zLnNraXBMYXllckltYWdlRGF0YSkge1xuXHRcdFx0Zm9yIChsZXQgaSA9IDA7IGkgPCBsYXllckNvdW50OyBpKyspIHtcblx0XHRcdFx0cmVhZExheWVyQ2hhbm5lbEltYWdlRGF0YShyZWFkZXIsIHBzZCwgbGF5ZXJzW2ldLCBsYXllckNoYW5uZWxzW2ldLCBvcHRpb25zKTtcblx0XHRcdH1cblx0XHR9XG5cblx0XHRza2lwQnl0ZXMocmVhZGVyLCBsZWZ0KCkpO1xuXG5cdFx0aWYgKCFwc2QuY2hpbGRyZW4pIHBzZC5jaGlsZHJlbiA9IFtdO1xuXG5cdFx0Y29uc3Qgc3RhY2s6IChMYXllciB8IFBzZClbXSA9IFtwc2RdO1xuXG5cdFx0Zm9yIChsZXQgaSA9IGxheWVycy5sZW5ndGggLSAxOyBpID49IDA7IGktLSkge1xuXHRcdFx0Y29uc3QgbCA9IGxheWVyc1tpXTtcblx0XHRcdGNvbnN0IHR5cGUgPSBsLnNlY3Rpb25EaXZpZGVyID8gbC5zZWN0aW9uRGl2aWRlci50eXBlIDogU2VjdGlvbkRpdmlkZXJUeXBlLk90aGVyO1xuXG5cdFx0XHRpZiAodHlwZSA9PT0gU2VjdGlvbkRpdmlkZXJUeXBlLk9wZW5Gb2xkZXIgfHwgdHlwZSA9PT0gU2VjdGlvbkRpdmlkZXJUeXBlLkNsb3NlZEZvbGRlcikge1xuXHRcdFx0XHRsLm9wZW5lZCA9IHR5cGUgPT09IFNlY3Rpb25EaXZpZGVyVHlwZS5PcGVuRm9sZGVyO1xuXHRcdFx0XHRsLmNoaWxkcmVuID0gW107XG5cdFx0XHRcdHN0YWNrW3N0YWNrLmxlbmd0aCAtIDFdLmNoaWxkcmVuIS51bnNoaWZ0KGwpO1xuXHRcdFx0XHRzdGFjay5wdXNoKGwpO1xuXHRcdFx0fSBlbHNlIGlmICh0eXBlID09PSBTZWN0aW9uRGl2aWRlclR5cGUuQm91bmRpbmdTZWN0aW9uRGl2aWRlcikge1xuXHRcdFx0XHRzdGFjay5wb3AoKTtcblx0XHRcdFx0Ly8gdGhpcyB3YXMgd29ya2Fyb3VuZCBiZWNhdXNlIEkgZGlkbid0IGtub3cgd2hhdCBgbHNka2Agc2VjdGlvbiB3YXMsIG5vdyBpdCdzIHByb2JhYmx5IG5vdCBuZWVkZWQgYW55bW9yZVxuXHRcdFx0XHQvLyB9IGVsc2UgaWYgKGwubmFtZSA9PT0gJzwvTGF5ZXIgZ3JvdXA+JyAmJiAhbC5zZWN0aW9uRGl2aWRlciAmJiAhbC50b3AgJiYgIWwubGVmdCAmJiAhbC5ib3R0b20gJiYgIWwucmlnaHQpIHtcblx0XHRcdFx0Ly8gXHQvLyBzb21ldGltZXMgbGF5ZXIgZ3JvdXAgdGVybWluYXRvciBkb2Vzbid0IGhhdmUgc2VjdGlvbkRpdmlkZXIsIHNvIHdlIGp1c3QgZ3Vlc3MgaGVyZSAoUFMgYnVnID8pXG5cdFx0XHRcdC8vIFx0c3RhY2sucG9wKCk7XG5cdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRzdGFja1tzdGFjay5sZW5ndGggLSAxXS5jaGlsZHJlbiEudW5zaGlmdChsKTtcblx0XHRcdH1cblx0XHR9XG5cdH0sIHVuZGVmaW5lZCwgb3B0aW9ucy5sYXJnZSk7XG5cblx0cmV0dXJuIGdsb2JhbEFscGhhO1xufVxuXG5mdW5jdGlvbiByZWFkTGF5ZXJSZWNvcmQocmVhZGVyOiBQc2RSZWFkZXIsIHBzZDogUHNkLCBvcHRpb25zOiBSZWFkT3B0aW9uc0V4dCkge1xuXHRjb25zdCBsYXllcjogTGF5ZXIgPSB7fTtcblx0bGF5ZXIudG9wID0gcmVhZEludDMyKHJlYWRlcik7XG5cdGxheWVyLmxlZnQgPSByZWFkSW50MzIocmVhZGVyKTtcblx0bGF5ZXIuYm90dG9tID0gcmVhZEludDMyKHJlYWRlcik7XG5cdGxheWVyLnJpZ2h0ID0gcmVhZEludDMyKHJlYWRlcik7XG5cblx0Y29uc3QgY2hhbm5lbENvdW50ID0gcmVhZFVpbnQxNihyZWFkZXIpO1xuXHRjb25zdCBjaGFubmVsczogQ2hhbm5lbEluZm9bXSA9IFtdO1xuXG5cdGZvciAobGV0IGkgPSAwOyBpIDwgY2hhbm5lbENvdW50OyBpKyspIHtcblx0XHRsZXQgY2hhbm5lbElEID0gcmVhZEludDE2KHJlYWRlcikgYXMgQ2hhbm5lbElEO1xuXHRcdGxldCBjaGFubmVsTGVuZ3RoID0gcmVhZFVpbnQzMihyZWFkZXIpO1xuXG5cdFx0aWYgKG9wdGlvbnMubGFyZ2UpIHtcblx0XHRcdGlmIChjaGFubmVsTGVuZ3RoICE9PSAwKSB0aHJvdyBuZXcgRXJyb3IoJ1NpemVzIGxhcmdlciB0aGFuIDRHQiBhcmUgbm90IHN1cHBvcnRlZCcpO1xuXHRcdFx0Y2hhbm5lbExlbmd0aCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0XHR9XG5cblx0XHRjaGFubmVscy5wdXNoKHsgaWQ6IGNoYW5uZWxJRCwgbGVuZ3RoOiBjaGFubmVsTGVuZ3RoIH0pO1xuXHR9XG5cblx0Y2hlY2tTaWduYXR1cmUocmVhZGVyLCAnOEJJTScpO1xuXHRjb25zdCBibGVuZE1vZGUgPSByZWFkU2lnbmF0dXJlKHJlYWRlcik7XG5cdGlmICghdG9CbGVuZE1vZGVbYmxlbmRNb2RlXSkgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGJsZW5kIG1vZGU6ICcke2JsZW5kTW9kZX0nYCk7XG5cdGxheWVyLmJsZW5kTW9kZSA9IHRvQmxlbmRNb2RlW2JsZW5kTW9kZV07XG5cblx0bGF5ZXIub3BhY2l0eSA9IHJlYWRVaW50OChyZWFkZXIpIC8gMHhmZjtcblx0bGF5ZXIuY2xpcHBpbmcgPSByZWFkVWludDgocmVhZGVyKSA9PT0gMTtcblxuXHRjb25zdCBmbGFncyA9IHJlYWRVaW50OChyZWFkZXIpO1xuXHRsYXllci50cmFuc3BhcmVuY3lQcm90ZWN0ZWQgPSAoZmxhZ3MgJiAweDAxKSAhPT0gMDtcblx0bGF5ZXIuaGlkZGVuID0gKGZsYWdzICYgMHgwMikgIT09IDA7XG5cdC8vIDB4MDQgLSBvYnNvbGV0ZVxuXHQvLyAweDA4IC0gMSBmb3IgUGhvdG9zaG9wIDUuMCBhbmQgbGF0ZXIsIHRlbGxzIGlmIGJpdCA0IGhhcyB1c2VmdWwgaW5mb3JtYXRpb25cblx0Ly8gMHgxMCAtIHBpeGVsIGRhdGEgaXJyZWxldmFudCB0byBhcHBlYXJhbmNlIG9mIGRvY3VtZW50XG5cdC8vIDB4MjAgLSA/Pz9cblx0Ly8gaWYgKGZsYWdzICYgMHgyMCkgKGxheWVyIGFzIGFueSkuXzIgPSB0cnVlOyAvLyBURU1QICEhISFcblxuXHRza2lwQnl0ZXMocmVhZGVyLCAxKTtcblxuXHRyZWFkU2VjdGlvbihyZWFkZXIsIDEsIGxlZnQgPT4ge1xuXHRcdGNvbnN0IG1hc2sgPSByZWFkTGF5ZXJNYXNrRGF0YShyZWFkZXIsIG9wdGlvbnMpO1xuXHRcdGlmIChtYXNrKSBsYXllci5tYXNrID0gbWFzaztcblxuXHRcdC8qY29uc3QgYmxlbmRpbmdSYW5nZXMgPSovIHJlYWRMYXllckJsZW5kaW5nUmFuZ2VzKHJlYWRlcik7XG5cdFx0bGF5ZXIubmFtZSA9IHJlYWRQYXNjYWxTdHJpbmcocmVhZGVyLCA0KTtcblxuXHRcdHdoaWxlIChsZWZ0KCkpIHtcblx0XHRcdHJlYWRBZGRpdGlvbmFsTGF5ZXJJbmZvKHJlYWRlciwgbGF5ZXIsIHBzZCwgb3B0aW9ucyk7XG5cdFx0fVxuXHR9KTtcblxuXHRyZXR1cm4geyBsYXllciwgY2hhbm5lbHMgfTtcbn1cblxuZnVuY3Rpb24gcmVhZExheWVyTWFza0RhdGEocmVhZGVyOiBQc2RSZWFkZXIsIG9wdGlvbnM6IFJlYWRPcHRpb25zKSB7XG5cdHJldHVybiByZWFkU2VjdGlvbjxMYXllck1hc2tEYXRhIHwgdW5kZWZpbmVkPihyZWFkZXIsIDEsIGxlZnQgPT4ge1xuXHRcdGlmICghbGVmdCgpKSByZXR1cm4gdW5kZWZpbmVkO1xuXG5cdFx0Y29uc3QgbWFzazogTGF5ZXJNYXNrRGF0YSA9IHt9O1xuXHRcdG1hc2sudG9wID0gcmVhZEludDMyKHJlYWRlcik7XG5cdFx0bWFzay5sZWZ0ID0gcmVhZEludDMyKHJlYWRlcik7XG5cdFx0bWFzay5ib3R0b20gPSByZWFkSW50MzIocmVhZGVyKTtcblx0XHRtYXNrLnJpZ2h0ID0gcmVhZEludDMyKHJlYWRlcik7XG5cdFx0bWFzay5kZWZhdWx0Q29sb3IgPSByZWFkVWludDgocmVhZGVyKTtcblxuXHRcdGNvbnN0IGZsYWdzID0gcmVhZFVpbnQ4KHJlYWRlcik7XG5cdFx0bWFzay5wb3NpdGlvblJlbGF0aXZlVG9MYXllciA9IChmbGFncyAmIExheWVyTWFza0ZsYWdzLlBvc2l0aW9uUmVsYXRpdmVUb0xheWVyKSAhPT0gMDtcblx0XHRtYXNrLmRpc2FibGVkID0gKGZsYWdzICYgTGF5ZXJNYXNrRmxhZ3MuTGF5ZXJNYXNrRGlzYWJsZWQpICE9PSAwO1xuXHRcdG1hc2suZnJvbVZlY3RvckRhdGEgPSAoZmxhZ3MgJiBMYXllck1hc2tGbGFncy5MYXllck1hc2tGcm9tUmVuZGVyaW5nT3RoZXJEYXRhKSAhPT0gMDtcblxuXHRcdGlmIChmbGFncyAmIExheWVyTWFza0ZsYWdzLk1hc2tIYXNQYXJhbWV0ZXJzQXBwbGllZFRvSXQpIHtcblx0XHRcdGNvbnN0IHBhcmFtcyA9IHJlYWRVaW50OChyZWFkZXIpO1xuXHRcdFx0aWYgKHBhcmFtcyAmIE1hc2tQYXJhbXMuVXNlck1hc2tEZW5zaXR5KSBtYXNrLnVzZXJNYXNrRGVuc2l0eSA9IHJlYWRVaW50OChyZWFkZXIpIC8gMHhmZjtcblx0XHRcdGlmIChwYXJhbXMgJiBNYXNrUGFyYW1zLlVzZXJNYXNrRmVhdGhlcikgbWFzay51c2VyTWFza0ZlYXRoZXIgPSByZWFkRmxvYXQ2NChyZWFkZXIpO1xuXHRcdFx0aWYgKHBhcmFtcyAmIE1hc2tQYXJhbXMuVmVjdG9yTWFza0RlbnNpdHkpIG1hc2sudmVjdG9yTWFza0RlbnNpdHkgPSByZWFkVWludDgocmVhZGVyKSAvIDB4ZmY7XG5cdFx0XHRpZiAocGFyYW1zICYgTWFza1BhcmFtcy5WZWN0b3JNYXNrRmVhdGhlcikgbWFzay52ZWN0b3JNYXNrRmVhdGhlciA9IHJlYWRGbG9hdDY0KHJlYWRlcik7XG5cdFx0fVxuXG5cdFx0aWYgKGxlZnQoKSA+IDIpIHtcblx0XHRcdG9wdGlvbnMubG9nTWlzc2luZ0ZlYXR1cmVzICYmIGNvbnNvbGUubG9nKCdVbmhhbmRsZWQgZXh0cmEgbWFzayBwYXJhbXMnKTtcblx0XHRcdC8vIFRPRE86IGhhbmRsZSB0aGVzZSB2YWx1ZXNcblx0XHRcdC8qY29uc3QgcmVhbEZsYWdzID0qLyByZWFkVWludDgocmVhZGVyKTtcblx0XHRcdC8qY29uc3QgcmVhbFVzZXJNYXNrQmFja2dyb3VuZCA9Ki8gcmVhZFVpbnQ4KHJlYWRlcik7XG5cdFx0XHQvKmNvbnN0IHRvcDIgPSovIHJlYWRJbnQzMihyZWFkZXIpO1xuXHRcdFx0Lypjb25zdCBsZWZ0MiA9Ki8gcmVhZEludDMyKHJlYWRlcik7XG5cdFx0XHQvKmNvbnN0IGJvdHRvbTIgPSovIHJlYWRJbnQzMihyZWFkZXIpO1xuXHRcdFx0Lypjb25zdCByaWdodDIgPSovIHJlYWRJbnQzMihyZWFkZXIpO1xuXHRcdH1cblxuXHRcdHNraXBCeXRlcyhyZWFkZXIsIGxlZnQoKSk7XG5cdFx0cmV0dXJuIG1hc2s7XG5cdH0pO1xufVxuXG5mdW5jdGlvbiByZWFkTGF5ZXJCbGVuZGluZ1JhbmdlcyhyZWFkZXI6IFBzZFJlYWRlcikge1xuXHRyZXR1cm4gcmVhZFNlY3Rpb24ocmVhZGVyLCAxLCBsZWZ0ID0+IHtcblx0XHRjb25zdCBjb21wb3NpdGVHcmF5QmxlbmRTb3VyY2UgPSByZWFkVWludDMyKHJlYWRlcik7XG5cdFx0Y29uc3QgY29tcG9zaXRlR3JhcGhCbGVuZERlc3RpbmF0aW9uUmFuZ2UgPSByZWFkVWludDMyKHJlYWRlcik7XG5cdFx0Y29uc3QgcmFuZ2VzID0gW107XG5cblx0XHR3aGlsZSAobGVmdCgpKSB7XG5cdFx0XHRjb25zdCBzb3VyY2VSYW5nZSA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0XHRcdGNvbnN0IGRlc3RSYW5nZSA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0XHRcdHJhbmdlcy5wdXNoKHsgc291cmNlUmFuZ2UsIGRlc3RSYW5nZSB9KTtcblx0XHR9XG5cblx0XHRyZXR1cm4geyBjb21wb3NpdGVHcmF5QmxlbmRTb3VyY2UsIGNvbXBvc2l0ZUdyYXBoQmxlbmREZXN0aW5hdGlvblJhbmdlLCByYW5nZXMgfTtcblx0fSk7XG59XG5cbmZ1bmN0aW9uIHJlYWRMYXllckNoYW5uZWxJbWFnZURhdGEoXG5cdHJlYWRlcjogUHNkUmVhZGVyLCBwc2Q6IFBzZCwgbGF5ZXI6IExheWVyLCBjaGFubmVsczogQ2hhbm5lbEluZm9bXSwgb3B0aW9uczogUmVhZE9wdGlvbnNFeHRcbikge1xuXHRjb25zdCBsYXllcldpZHRoID0gKGxheWVyLnJpZ2h0IHx8IDApIC0gKGxheWVyLmxlZnQgfHwgMCk7XG5cdGNvbnN0IGxheWVySGVpZ2h0ID0gKGxheWVyLmJvdHRvbSB8fCAwKSAtIChsYXllci50b3AgfHwgMCk7XG5cdGNvbnN0IGNteWsgPSBwc2QuY29sb3JNb2RlID09PSBDb2xvck1vZGUuQ01ZSztcblxuXHRsZXQgaW1hZ2VEYXRhOiBJbWFnZURhdGEgfCB1bmRlZmluZWQ7XG5cblx0aWYgKGxheWVyV2lkdGggJiYgbGF5ZXJIZWlnaHQpIHtcblx0XHRpZiAoY215aykge1xuXHRcdFx0aW1hZ2VEYXRhID0geyB3aWR0aDogbGF5ZXJXaWR0aCwgaGVpZ2h0OiBsYXllckhlaWdodCwgZGF0YTogbmV3IFVpbnQ4Q2xhbXBlZEFycmF5KGxheWVyV2lkdGggKiBsYXllckhlaWdodCAqIDUpIH0gYXMgYW55IGFzIEltYWdlRGF0YTtcblx0XHRcdGZvciAobGV0IHAgPSA0OyBwIDwgaW1hZ2VEYXRhLmRhdGEuYnl0ZUxlbmd0aDsgcCArPSA1KSBpbWFnZURhdGEuZGF0YVtwXSA9IDI1NTtcblx0XHR9IGVsc2Uge1xuXHRcdFx0aW1hZ2VEYXRhID0gY3JlYXRlSW1hZ2VEYXRhKGxheWVyV2lkdGgsIGxheWVySGVpZ2h0KTtcblx0XHRcdHJlc2V0SW1hZ2VEYXRhKGltYWdlRGF0YSk7XG5cdFx0fVxuXHR9XG5cblx0aWYgKFJBV19JTUFHRV9EQVRBKSAobGF5ZXIgYXMgYW55KS5pbWFnZURhdGFSYXcgPSBbXTtcblxuXHRmb3IgKGNvbnN0IGNoYW5uZWwgb2YgY2hhbm5lbHMpIHtcblx0XHRpZiAoY2hhbm5lbC5sZW5ndGggPT09IDApIGNvbnRpbnVlO1xuXHRcdGlmIChjaGFubmVsLmxlbmd0aCA8IDIpIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBjaGFubmVsIGxlbmd0aCcpO1xuXG5cdFx0Y29uc3Qgc3RhcnQgPSByZWFkZXIub2Zmc2V0O1xuXHRcdGNvbnN0IGNvbXByZXNzaW9uID0gcmVhZFVpbnQxNihyZWFkZXIpIGFzIENvbXByZXNzaW9uO1xuXG5cdFx0aWYgKGNoYW5uZWwuaWQgPT09IENoYW5uZWxJRC5Vc2VyTWFzaykge1xuXHRcdFx0Y29uc3QgbWFzayA9IGxheWVyLm1hc2s7XG5cblx0XHRcdGlmICghbWFzaykgdGhyb3cgbmV3IEVycm9yKGBNaXNzaW5nIGxheWVyIG1hc2sgZGF0YWApO1xuXG5cdFx0XHRjb25zdCBtYXNrV2lkdGggPSAobWFzay5yaWdodCB8fCAwKSAtIChtYXNrLmxlZnQgfHwgMCk7XG5cdFx0XHRjb25zdCBtYXNrSGVpZ2h0ID0gKG1hc2suYm90dG9tIHx8IDApIC0gKG1hc2sudG9wIHx8IDApO1xuXG5cdFx0XHRpZiAobWFza1dpZHRoICYmIG1hc2tIZWlnaHQpIHtcblx0XHRcdFx0Y29uc3QgbWFza0RhdGEgPSBjcmVhdGVJbWFnZURhdGEobWFza1dpZHRoLCBtYXNrSGVpZ2h0KTtcblx0XHRcdFx0cmVzZXRJbWFnZURhdGEobWFza0RhdGEpO1xuXG5cdFx0XHRcdGNvbnN0IHN0YXJ0ID0gcmVhZGVyLm9mZnNldDtcblx0XHRcdFx0cmVhZERhdGEocmVhZGVyLCBjaGFubmVsLmxlbmd0aCwgbWFza0RhdGEsIGNvbXByZXNzaW9uLCBtYXNrV2lkdGgsIG1hc2tIZWlnaHQsIDAsIG9wdGlvbnMubGFyZ2UsIDQpO1xuXG5cdFx0XHRcdGlmIChSQVdfSU1BR0VfREFUQSkge1xuXHRcdFx0XHRcdChsYXllciBhcyBhbnkpLm1hc2tEYXRhUmF3ID0gbmV3IFVpbnQ4QXJyYXkocmVhZGVyLnZpZXcuYnVmZmVyLCByZWFkZXIudmlldy5ieXRlT2Zmc2V0ICsgc3RhcnQsIHJlYWRlci5vZmZzZXQgLSBzdGFydCk7XG5cdFx0XHRcdH1cblxuXHRcdFx0XHRzZXR1cEdyYXlzY2FsZShtYXNrRGF0YSk7XG5cblx0XHRcdFx0aWYgKG9wdGlvbnMudXNlSW1hZ2VEYXRhKSB7XG5cdFx0XHRcdFx0bWFzay5pbWFnZURhdGEgPSBtYXNrRGF0YTtcblx0XHRcdFx0fSBlbHNlIHtcblx0XHRcdFx0XHRtYXNrLmNhbnZhcyA9IGNyZWF0ZUNhbnZhcyhtYXNrV2lkdGgsIG1hc2tIZWlnaHQpO1xuXHRcdFx0XHRcdG1hc2suY2FudmFzLmdldENvbnRleHQoJzJkJykhLnB1dEltYWdlRGF0YShtYXNrRGF0YSwgMCwgMCk7XG5cdFx0XHRcdH1cblx0XHRcdH1cblx0XHR9IGVsc2Uge1xuXHRcdFx0Y29uc3Qgb2Zmc2V0ID0gb2Zmc2V0Rm9yQ2hhbm5lbChjaGFubmVsLmlkLCBjbXlrKTtcblx0XHRcdGxldCB0YXJnZXREYXRhID0gaW1hZ2VEYXRhO1xuXG5cdFx0XHRpZiAob2Zmc2V0IDwgMCkge1xuXHRcdFx0XHR0YXJnZXREYXRhID0gdW5kZWZpbmVkO1xuXG5cdFx0XHRcdGlmIChvcHRpb25zLnRocm93Rm9yTWlzc2luZ0ZlYXR1cmVzKSB7XG5cdFx0XHRcdFx0dGhyb3cgbmV3IEVycm9yKGBDaGFubmVsIG5vdCBzdXBwb3J0ZWQ6ICR7Y2hhbm5lbC5pZH1gKTtcblx0XHRcdFx0fVxuXHRcdFx0fVxuXG5cdFx0XHRyZWFkRGF0YShyZWFkZXIsIGNoYW5uZWwubGVuZ3RoLCB0YXJnZXREYXRhLCBjb21wcmVzc2lvbiwgbGF5ZXJXaWR0aCwgbGF5ZXJIZWlnaHQsIG9mZnNldCwgb3B0aW9ucy5sYXJnZSwgY215ayA/IDUgOiA0KTtcblxuXHRcdFx0aWYgKFJBV19JTUFHRV9EQVRBKSB7XG5cdFx0XHRcdChsYXllciBhcyBhbnkpLmltYWdlRGF0YVJhd1tjaGFubmVsLmlkXSA9IG5ldyBVaW50OEFycmF5KHJlYWRlci52aWV3LmJ1ZmZlciwgcmVhZGVyLnZpZXcuYnl0ZU9mZnNldCArIHN0YXJ0ICsgMiwgY2hhbm5lbC5sZW5ndGggLSAyKTtcblx0XHRcdH1cblxuXHRcdFx0cmVhZGVyLm9mZnNldCA9IHN0YXJ0ICsgY2hhbm5lbC5sZW5ndGg7XG5cblx0XHRcdGlmICh0YXJnZXREYXRhICYmIHBzZC5jb2xvck1vZGUgPT09IENvbG9yTW9kZS5HcmF5c2NhbGUpIHtcblx0XHRcdFx0c2V0dXBHcmF5c2NhbGUodGFyZ2V0RGF0YSk7XG5cdFx0XHR9XG5cdFx0fVxuXHR9XG5cblx0aWYgKGltYWdlRGF0YSkge1xuXHRcdGlmIChjbXlrKSB7XG5cdFx0XHRjb25zdCBjbXlrRGF0YSA9IGltYWdlRGF0YTtcblx0XHRcdGltYWdlRGF0YSA9IGNyZWF0ZUltYWdlRGF0YShjbXlrRGF0YS53aWR0aCwgY215a0RhdGEuaGVpZ2h0KTtcblx0XHRcdGNteWtUb1JnYihjbXlrRGF0YSwgaW1hZ2VEYXRhLCBmYWxzZSk7XG5cdFx0fVxuXG5cdFx0aWYgKG9wdGlvbnMudXNlSW1hZ2VEYXRhKSB7XG5cdFx0XHRsYXllci5pbWFnZURhdGEgPSBpbWFnZURhdGE7XG5cdFx0fSBlbHNlIHtcblx0XHRcdGxheWVyLmNhbnZhcyA9IGNyZWF0ZUNhbnZhcyhsYXllcldpZHRoLCBsYXllckhlaWdodCk7XG5cdFx0XHRsYXllci5jYW52YXMuZ2V0Q29udGV4dCgnMmQnKSEucHV0SW1hZ2VEYXRhKGltYWdlRGF0YSwgMCwgMCk7XG5cdFx0fVxuXHR9XG59XG5cbmZ1bmN0aW9uIHJlYWREYXRhKFxuXHRyZWFkZXI6IFBzZFJlYWRlciwgbGVuZ3RoOiBudW1iZXIsIGRhdGE6IEltYWdlRGF0YSB8IHVuZGVmaW5lZCwgY29tcHJlc3Npb246IENvbXByZXNzaW9uLCB3aWR0aDogbnVtYmVyLCBoZWlnaHQ6IG51bWJlcixcblx0b2Zmc2V0OiBudW1iZXIsIGxhcmdlOiBib29sZWFuLCBzdGVwOiBudW1iZXJcbikge1xuXHRpZiAoY29tcHJlc3Npb24gPT09IENvbXByZXNzaW9uLlJhd0RhdGEpIHtcblx0XHRyZWFkRGF0YVJhdyhyZWFkZXIsIGRhdGEsIHdpZHRoLCBoZWlnaHQsIHN0ZXAsIG9mZnNldCk7XG5cdH0gZWxzZSBpZiAoY29tcHJlc3Npb24gPT09IENvbXByZXNzaW9uLlJsZUNvbXByZXNzZWQpIHtcblx0XHRyZWFkRGF0YVJMRShyZWFkZXIsIGRhdGEsIHdpZHRoLCBoZWlnaHQsIHN0ZXAsIFtvZmZzZXRdLCBsYXJnZSk7XG5cdH0gZWxzZSBpZiAoY29tcHJlc3Npb24gPT09IENvbXByZXNzaW9uLlppcFdpdGhvdXRQcmVkaWN0aW9uKSB7XG5cdFx0cmVhZERhdGFaaXBXaXRob3V0UHJlZGljdGlvbihyZWFkZXIsIGxlbmd0aCwgZGF0YSwgd2lkdGgsIGhlaWdodCwgc3RlcCwgb2Zmc2V0KTtcblx0fSBlbHNlIGlmIChjb21wcmVzc2lvbiA9PT0gQ29tcHJlc3Npb24uWmlwV2l0aFByZWRpY3Rpb24pIHtcblx0XHR0aHJvdyBuZXcgRXJyb3IoYENvbXByZXNzaW9uIHR5cGUgbm90IHN1cHBvcnRlZDogJHtjb21wcmVzc2lvbn1gKTtcblx0fSBlbHNlIHtcblx0XHR0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgQ29tcHJlc3Npb24gdHlwZTogJHtjb21wcmVzc2lvbn1gKTtcblx0fVxufVxuXG5mdW5jdGlvbiByZWFkR2xvYmFsTGF5ZXJNYXNrSW5mbyhyZWFkZXI6IFBzZFJlYWRlcikge1xuXHRyZXR1cm4gcmVhZFNlY3Rpb248R2xvYmFsTGF5ZXJNYXNrSW5mbyB8IHVuZGVmaW5lZD4ocmVhZGVyLCAxLCBsZWZ0ID0+IHtcblx0XHRpZiAoIWxlZnQoKSkgcmV0dXJuIHVuZGVmaW5lZDtcblxuXHRcdGNvbnN0IG92ZXJsYXlDb2xvclNwYWNlID0gcmVhZFVpbnQxNihyZWFkZXIpO1xuXHRcdGNvbnN0IGNvbG9yU3BhY2UxID0gcmVhZFVpbnQxNihyZWFkZXIpO1xuXHRcdGNvbnN0IGNvbG9yU3BhY2UyID0gcmVhZFVpbnQxNihyZWFkZXIpO1xuXHRcdGNvbnN0IGNvbG9yU3BhY2UzID0gcmVhZFVpbnQxNihyZWFkZXIpO1xuXHRcdGNvbnN0IGNvbG9yU3BhY2U0ID0gcmVhZFVpbnQxNihyZWFkZXIpO1xuXHRcdGNvbnN0IG9wYWNpdHkgPSByZWFkVWludDE2KHJlYWRlcikgLyAweGZmO1xuXHRcdGNvbnN0IGtpbmQgPSByZWFkVWludDgocmVhZGVyKTtcblx0XHRza2lwQnl0ZXMocmVhZGVyLCBsZWZ0KCkpOyAvLyAzIGJ5dGVzIG9mIHBhZGRpbmcgP1xuXHRcdHJldHVybiB7IG92ZXJsYXlDb2xvclNwYWNlLCBjb2xvclNwYWNlMSwgY29sb3JTcGFjZTIsIGNvbG9yU3BhY2UzLCBjb2xvclNwYWNlNCwgb3BhY2l0eSwga2luZCB9O1xuXHR9KTtcbn1cblxuZnVuY3Rpb24gcmVhZEFkZGl0aW9uYWxMYXllckluZm8ocmVhZGVyOiBQc2RSZWFkZXIsIHRhcmdldDogTGF5ZXJBZGRpdGlvbmFsSW5mbywgcHNkOiBQc2QsIG9wdGlvbnM6IFJlYWRPcHRpb25zRXh0KSB7XG5cdGNvbnN0IHNpZyA9IHJlYWRTaWduYXR1cmUocmVhZGVyKTtcblx0aWYgKHNpZyAhPT0gJzhCSU0nICYmIHNpZyAhPT0gJzhCNjQnKSB0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgc2lnbmF0dXJlOiAnJHtzaWd9JyBhdCAweCR7KHJlYWRlci5vZmZzZXQgLSA0KS50b1N0cmluZygxNil9YCk7XG5cdGNvbnN0IGtleSA9IHJlYWRTaWduYXR1cmUocmVhZGVyKTtcblxuXHQvLyBgbGFyZ2VBZGRpdGlvbmFsSW5mb0tleXNgIGZhbGxiYWNrLCBiZWNhdXNlIHNvbWUga2V5cyBkb24ndCBoYXZlIDhCNjQgc2lnbmF0dXJlIGV2ZW4gd2hlbiB0aGV5IGFyZSA2NGJpdFxuXHRjb25zdCB1NjQgPSBzaWcgPT09ICc4QjY0JyB8fCAob3B0aW9ucy5sYXJnZSAmJiBsYXJnZUFkZGl0aW9uYWxJbmZvS2V5cy5pbmRleE9mKGtleSkgIT09IC0xKTtcblxuXHRyZWFkU2VjdGlvbihyZWFkZXIsIDIsIGxlZnQgPT4ge1xuXHRcdGNvbnN0IGhhbmRsZXIgPSBpbmZvSGFuZGxlcnNNYXBba2V5XTtcblxuXHRcdGlmIChoYW5kbGVyKSB7XG5cdFx0XHR0cnkge1xuXHRcdFx0XHRoYW5kbGVyLnJlYWQocmVhZGVyLCB0YXJnZXQsIGxlZnQsIHBzZCwgb3B0aW9ucyk7XG5cdFx0XHR9IGNhdGNoIChlKSB7XG5cdFx0XHRcdGlmIChvcHRpb25zLnRocm93Rm9yTWlzc2luZ0ZlYXR1cmVzKSB0aHJvdyBlO1xuXHRcdFx0fVxuXHRcdH0gZWxzZSB7XG5cdFx0XHRvcHRpb25zLmxvZ01pc3NpbmdGZWF0dXJlcyAmJiBjb25zb2xlLmxvZyhgVW5oYW5kbGVkIGFkZGl0aW9uYWwgaW5mbzogJHtrZXl9YCk7XG5cdFx0XHRza2lwQnl0ZXMocmVhZGVyLCBsZWZ0KCkpO1xuXHRcdH1cblxuXHRcdGlmIChsZWZ0KCkpIHtcblx0XHRcdG9wdGlvbnMubG9nTWlzc2luZ0ZlYXR1cmVzICYmIGNvbnNvbGUubG9nKGBVbnJlYWQgJHtsZWZ0KCl9IGJ5dGVzIGxlZnQgZm9yIGFkZGl0aW9uYWwgaW5mbzogJHtrZXl9YCk7XG5cdFx0XHRza2lwQnl0ZXMocmVhZGVyLCBsZWZ0KCkpO1xuXHRcdH1cblx0fSwgZmFsc2UsIHU2NCk7XG59XG5cbmZ1bmN0aW9uIHJlYWRJbWFnZURhdGEocmVhZGVyOiBQc2RSZWFkZXIsIHBzZDogUHNkLCBnbG9iYWxBbHBoYTogYm9vbGVhbiwgb3B0aW9uczogUmVhZE9wdGlvbnNFeHQpIHtcblx0Y29uc3QgY29tcHJlc3Npb24gPSByZWFkVWludDE2KHJlYWRlcikgYXMgQ29tcHJlc3Npb247XG5cblx0aWYgKHN1cHBvcnRlZENvbG9yTW9kZXMuaW5kZXhPZihwc2QuY29sb3JNb2RlISkgPT09IC0xKVxuXHRcdHRocm93IG5ldyBFcnJvcihgQ29sb3IgbW9kZSBub3Qgc3VwcG9ydGVkOiAke3BzZC5jb2xvck1vZGV9YCk7XG5cblx0aWYgKGNvbXByZXNzaW9uICE9PSBDb21wcmVzc2lvbi5SYXdEYXRhICYmIGNvbXByZXNzaW9uICE9PSBDb21wcmVzc2lvbi5SbGVDb21wcmVzc2VkKVxuXHRcdHRocm93IG5ldyBFcnJvcihgQ29tcHJlc3Npb24gdHlwZSBub3Qgc3VwcG9ydGVkOiAke2NvbXByZXNzaW9ufWApO1xuXG5cdGNvbnN0IGltYWdlRGF0YSA9IGNyZWF0ZUltYWdlRGF0YShwc2Qud2lkdGgsIHBzZC5oZWlnaHQpO1xuXHRyZXNldEltYWdlRGF0YShpbWFnZURhdGEpO1xuXG5cdHN3aXRjaCAocHNkLmNvbG9yTW9kZSkge1xuXHRcdGNhc2UgQ29sb3JNb2RlLkJpdG1hcDoge1xuXHRcdFx0bGV0IGJ5dGVzOiBVaW50OEFycmF5O1xuXG5cdFx0XHRpZiAoY29tcHJlc3Npb24gPT09IENvbXByZXNzaW9uLlJhd0RhdGEpIHtcblx0XHRcdFx0Ynl0ZXMgPSByZWFkQnl0ZXMocmVhZGVyLCBNYXRoLmNlaWwocHNkLndpZHRoIC8gOCkgKiBwc2QuaGVpZ2h0KTtcblx0XHRcdH0gZWxzZSBpZiAoY29tcHJlc3Npb24gPT09IENvbXByZXNzaW9uLlJsZUNvbXByZXNzZWQpIHtcblx0XHRcdFx0Ynl0ZXMgPSBuZXcgVWludDhBcnJheShwc2Qud2lkdGggKiBwc2QuaGVpZ2h0KTtcblx0XHRcdFx0cmVhZERhdGFSTEUocmVhZGVyLCB7IGRhdGE6IGJ5dGVzLCB3aWR0aDogcHNkLndpZHRoLCBoZWlnaHQ6IHBzZC5oZWlnaHQgfSwgcHNkLndpZHRoLCBwc2QuaGVpZ2h0LCAxLCBbMF0sIG9wdGlvbnMubGFyZ2UpO1xuXHRcdFx0fSBlbHNlIHtcblx0XHRcdFx0dGhyb3cgbmV3IEVycm9yKGBCaXRtYXAgY29tcHJlc3Npb24gbm90IHN1cHBvcnRlZDogJHtjb21wcmVzc2lvbn1gKTtcblx0XHRcdH1cblxuXHRcdFx0ZGVjb2RlQml0bWFwKGJ5dGVzLCBpbWFnZURhdGEuZGF0YSwgcHNkLndpZHRoLCBwc2QuaGVpZ2h0KTtcblx0XHRcdGJyZWFrO1xuXHRcdH1cblx0XHRjYXNlIENvbG9yTW9kZS5SR0I6XG5cdFx0Y2FzZSBDb2xvck1vZGUuR3JheXNjYWxlOiB7XG5cdFx0XHRjb25zdCBjaGFubmVscyA9IHBzZC5jb2xvck1vZGUgPT09IENvbG9yTW9kZS5HcmF5c2NhbGUgPyBbMF0gOiBbMCwgMSwgMl07XG5cblx0XHRcdGlmIChwc2QuY2hhbm5lbHMgJiYgcHNkLmNoYW5uZWxzID4gMykge1xuXHRcdFx0XHRmb3IgKGxldCBpID0gMzsgaSA8IHBzZC5jaGFubmVsczsgaSsrKSB7XG5cdFx0XHRcdFx0Ly8gVE9ETzogc3RvcmUgdGhlc2UgY2hhbm5lbHMgaW4gYWRkaXRpb25hbCBpbWFnZSBkYXRhXG5cdFx0XHRcdFx0Y2hhbm5lbHMucHVzaChpKTtcblx0XHRcdFx0fVxuXHRcdFx0fSBlbHNlIGlmIChnbG9iYWxBbHBoYSkge1xuXHRcdFx0XHRjaGFubmVscy5wdXNoKDMpO1xuXHRcdFx0fVxuXG5cdFx0XHRpZiAoY29tcHJlc3Npb24gPT09IENvbXByZXNzaW9uLlJhd0RhdGEpIHtcblx0XHRcdFx0Zm9yIChsZXQgaSA9IDA7IGkgPCBjaGFubmVscy5sZW5ndGg7IGkrKykge1xuXHRcdFx0XHRcdHJlYWREYXRhUmF3KHJlYWRlciwgaW1hZ2VEYXRhLCBwc2Qud2lkdGgsIHBzZC5oZWlnaHQsIDQsIGNoYW5uZWxzW2ldKTtcblx0XHRcdFx0fVxuXHRcdFx0fSBlbHNlIGlmIChjb21wcmVzc2lvbiA9PT0gQ29tcHJlc3Npb24uUmxlQ29tcHJlc3NlZCkge1xuXHRcdFx0XHRjb25zdCBzdGFydCA9IHJlYWRlci5vZmZzZXQ7XG5cdFx0XHRcdHJlYWREYXRhUkxFKHJlYWRlciwgaW1hZ2VEYXRhLCBwc2Qud2lkdGgsIHBzZC5oZWlnaHQsIDQsIGNoYW5uZWxzLCBvcHRpb25zLmxhcmdlKTtcblx0XHRcdFx0aWYgKFJBV19JTUFHRV9EQVRBKSAocHNkIGFzIGFueSkuaW1hZ2VEYXRhUmF3ID0gbmV3IFVpbnQ4QXJyYXkocmVhZGVyLnZpZXcuYnVmZmVyLCByZWFkZXIudmlldy5ieXRlT2Zmc2V0ICsgc3RhcnQsIHJlYWRlci5vZmZzZXQgLSBzdGFydCk7XG5cdFx0XHR9XG5cblx0XHRcdGlmIChwc2QuY29sb3JNb2RlID09PSBDb2xvck1vZGUuR3JheXNjYWxlKSB7XG5cdFx0XHRcdHNldHVwR3JheXNjYWxlKGltYWdlRGF0YSk7XG5cdFx0XHR9XG5cdFx0XHRicmVhaztcblx0XHR9XG5cdFx0Y2FzZSBDb2xvck1vZGUuQ01ZSzoge1xuXHRcdFx0aWYgKHBzZC5jaGFubmVscyAhPT0gNCkgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGNoYW5uZWwgY291bnRgKTtcblxuXHRcdFx0Y29uc3QgY2hhbm5lbHMgPSBbMCwgMSwgMiwgM107XG5cdFx0XHRpZiAoZ2xvYmFsQWxwaGEpIGNoYW5uZWxzLnB1c2goNCk7XG5cblx0XHRcdGlmIChjb21wcmVzc2lvbiA9PT0gQ29tcHJlc3Npb24uUmF3RGF0YSkge1xuXHRcdFx0XHR0aHJvdyBuZXcgRXJyb3IoYE5vdCBpbXBsZW1lbnRlZGApO1xuXHRcdFx0XHQvLyBUT0RPOiAuLi5cblx0XHRcdFx0Ly8gZm9yIChsZXQgaSA9IDA7IGkgPCBjaGFubmVscy5sZW5ndGg7IGkrKykge1xuXHRcdFx0XHQvLyBcdHJlYWREYXRhUmF3KHJlYWRlciwgaW1hZ2VEYXRhLCBjaGFubmVsc1tpXSwgcHNkLndpZHRoLCBwc2QuaGVpZ2h0KTtcblx0XHRcdFx0Ly8gfVxuXHRcdFx0fSBlbHNlIGlmIChjb21wcmVzc2lvbiA9PT0gQ29tcHJlc3Npb24uUmxlQ29tcHJlc3NlZCkge1xuXHRcdFx0XHRjb25zdCBjbXlrSW1hZ2VEYXRhOiBQaXhlbERhdGEgPSB7XG5cdFx0XHRcdFx0d2lkdGg6IGltYWdlRGF0YS53aWR0aCxcblx0XHRcdFx0XHRoZWlnaHQ6IGltYWdlRGF0YS5oZWlnaHQsXG5cdFx0XHRcdFx0ZGF0YTogbmV3IFVpbnQ4QXJyYXkoaW1hZ2VEYXRhLndpZHRoICogaW1hZ2VEYXRhLmhlaWdodCAqIDUpLFxuXHRcdFx0XHR9O1xuXG5cdFx0XHRcdGNvbnN0IHN0YXJ0ID0gcmVhZGVyLm9mZnNldDtcblx0XHRcdFx0cmVhZERhdGFSTEUocmVhZGVyLCBjbXlrSW1hZ2VEYXRhLCBwc2Qud2lkdGgsIHBzZC5oZWlnaHQsIDUsIGNoYW5uZWxzLCBvcHRpb25zLmxhcmdlKTtcblx0XHRcdFx0Y215a1RvUmdiKGNteWtJbWFnZURhdGEsIGltYWdlRGF0YSwgdHJ1ZSk7XG5cblx0XHRcdFx0aWYgKFJBV19JTUFHRV9EQVRBKSAocHNkIGFzIGFueSkuaW1hZ2VEYXRhUmF3ID0gbmV3IFVpbnQ4QXJyYXkocmVhZGVyLnZpZXcuYnVmZmVyLCByZWFkZXIudmlldy5ieXRlT2Zmc2V0ICsgc3RhcnQsIHJlYWRlci5vZmZzZXQgLSBzdGFydCk7XG5cdFx0XHR9XG5cblx0XHRcdGJyZWFrO1xuXHRcdH1cblx0XHRkZWZhdWx0OiB0aHJvdyBuZXcgRXJyb3IoYENvbG9yIG1vZGUgbm90IHN1cHBvcnRlZDogJHtwc2QuY29sb3JNb2RlfWApO1xuXHR9XG5cblx0aWYgKG9wdGlvbnMudXNlSW1hZ2VEYXRhKSB7XG5cdFx0cHNkLmltYWdlRGF0YSA9IGltYWdlRGF0YTtcblx0fSBlbHNlIHtcblx0XHRwc2QuY2FudmFzID0gY3JlYXRlQ2FudmFzKHBzZC53aWR0aCwgcHNkLmhlaWdodCk7XG5cdFx0cHNkLmNhbnZhcy5nZXRDb250ZXh0KCcyZCcpIS5wdXRJbWFnZURhdGEoaW1hZ2VEYXRhLCAwLCAwKTtcblx0fVxufVxuXG5mdW5jdGlvbiBjbXlrVG9SZ2IoY215azogUGl4ZWxEYXRhLCByZ2I6IFBpeGVsRGF0YSwgcmV2ZXJzZUFscGhhOiBib29sZWFuKSB7XG5cdGNvbnN0IHNpemUgPSByZ2Iud2lkdGggKiByZ2IuaGVpZ2h0ICogNDtcblx0Y29uc3Qgc3JjRGF0YSA9IGNteWsuZGF0YTtcblx0Y29uc3QgZHN0RGF0YSA9IHJnYi5kYXRhO1xuXG5cdGZvciAobGV0IHNyYyA9IDAsIGRzdCA9IDA7IGRzdCA8IHNpemU7IHNyYyArPSA1LCBkc3QgKz0gNCkge1xuXHRcdGNvbnN0IGMgPSBzcmNEYXRhW3NyY107XG5cdFx0Y29uc3QgbSA9IHNyY0RhdGFbc3JjICsgMV07XG5cdFx0Y29uc3QgeSA9IHNyY0RhdGFbc3JjICsgMl07XG5cdFx0Y29uc3QgayA9IHNyY0RhdGFbc3JjICsgM107XG5cdFx0ZHN0RGF0YVtkc3RdID0gKCgoKGMgKiBrKSB8IDApIC8gMjU1KSB8IDApO1xuXHRcdGRzdERhdGFbZHN0ICsgMV0gPSAoKCgobSAqIGspIHwgMCkgLyAyNTUpIHwgMCk7XG5cdFx0ZHN0RGF0YVtkc3QgKyAyXSA9ICgoKCh5ICogaykgfCAwKSAvIDI1NSkgfCAwKTtcblx0XHRkc3REYXRhW2RzdCArIDNdID0gcmV2ZXJzZUFscGhhID8gMjU1IC0gc3JjRGF0YVtzcmMgKyA0XSA6IHNyY0RhdGFbc3JjICsgNF07XG5cdH1cblxuXHQvLyBmb3IgKGxldCBzcmMgPSAwLCBkc3QgPSAwOyBkc3QgPCBzaXplOyBzcmMgKz0gNSwgZHN0ICs9IDQpIHtcblx0Ly8gXHRjb25zdCBjID0gMSAtIChzcmNEYXRhW3NyYyArIDBdIC8gMjU1KTtcblx0Ly8gXHRjb25zdCBtID0gMSAtIChzcmNEYXRhW3NyYyArIDFdIC8gMjU1KTtcblx0Ly8gXHRjb25zdCB5ID0gMSAtIChzcmNEYXRhW3NyYyArIDJdIC8gMjU1KTtcblx0Ly8gXHQvLyBjb25zdCBrID0gc3JjRGF0YVtzcmMgKyAzXSAvIDI1NTtcblx0Ly8gXHRkc3REYXRhW2RzdCArIDBdID0gKCgxIC0gYyAqIDAuOCkgKiAyNTUpIHwgMDtcblx0Ly8gXHRkc3REYXRhW2RzdCArIDFdID0gKCgxIC0gbSAqIDAuOCkgKiAyNTUpIHwgMDtcblx0Ly8gXHRkc3REYXRhW2RzdCArIDJdID0gKCgxIC0geSAqIDAuOCkgKiAyNTUpIHwgMDtcblx0Ly8gXHRkc3REYXRhW2RzdCArIDNdID0gcmV2ZXJzZUFscGhhID8gMjU1IC0gc3JjRGF0YVtzcmMgKyA0XSA6IHNyY0RhdGFbc3JjICsgNF07XG5cdC8vIH1cbn1cblxuZnVuY3Rpb24gcmVhZERhdGFSYXcocmVhZGVyOiBQc2RSZWFkZXIsIHBpeGVsRGF0YTogUGl4ZWxEYXRhIHwgdW5kZWZpbmVkLCB3aWR0aDogbnVtYmVyLCBoZWlnaHQ6IG51bWJlciwgc3RlcDogbnVtYmVyLCBvZmZzZXQ6IG51bWJlcikge1xuXHRjb25zdCBzaXplID0gd2lkdGggKiBoZWlnaHQ7XG5cdGNvbnN0IGJ1ZmZlciA9IHJlYWRCeXRlcyhyZWFkZXIsIHNpemUpO1xuXG5cdGlmIChwaXhlbERhdGEgJiYgb2Zmc2V0IDwgc3RlcCkge1xuXHRcdGNvbnN0IGRhdGEgPSBwaXhlbERhdGEuZGF0YTtcblxuXHRcdGZvciAobGV0IGkgPSAwLCBwID0gb2Zmc2V0IHwgMDsgaSA8IHNpemU7IGkrKywgcCA9IChwICsgc3RlcCkgfCAwKSB7XG5cdFx0XHRkYXRhW3BdID0gYnVmZmVyW2ldO1xuXHRcdH1cblx0fVxufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZERhdGFaaXBXaXRob3V0UHJlZGljdGlvbihcblx0cmVhZGVyOiBQc2RSZWFkZXIsIGxlbmd0aDogbnVtYmVyLCBwaXhlbERhdGE6IFBpeGVsRGF0YSB8IHVuZGVmaW5lZCwgd2lkdGg6IG51bWJlciwgaGVpZ2h0OiBudW1iZXIsXG5cdHN0ZXA6IG51bWJlciwgb2Zmc2V0OiBudW1iZXJcbikge1xuXHRjb25zdCBjb21wcmVzc2VkID0gcmVhZEJ5dGVzKHJlYWRlciwgbGVuZ3RoKTtcblx0Y29uc3QgZGVjb21wcmVzc2VkID0gaW5mbGF0ZShjb21wcmVzc2VkKTtcblx0Y29uc3Qgc2l6ZSA9IHdpZHRoICogaGVpZ2h0O1xuXG5cdGlmIChwaXhlbERhdGEgJiYgb2Zmc2V0IDwgc3RlcCkge1xuXHRcdGNvbnN0IGRhdGEgPSBwaXhlbERhdGEuZGF0YTtcblxuXHRcdGZvciAobGV0IGkgPSAwLCBwID0gb2Zmc2V0IHwgMDsgaSA8IHNpemU7IGkrKywgcCA9IChwICsgc3RlcCkgfCAwKSB7XG5cdFx0XHRkYXRhW3BdID0gZGVjb21wcmVzc2VkW2ldO1xuXHRcdH1cblx0fVxufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZERhdGFSTEUoXG5cdHJlYWRlcjogUHNkUmVhZGVyLCBwaXhlbERhdGE6IFBpeGVsRGF0YSB8IHVuZGVmaW5lZCwgX3dpZHRoOiBudW1iZXIsIGhlaWdodDogbnVtYmVyLCBzdGVwOiBudW1iZXIsIG9mZnNldHM6IG51bWJlcltdLFxuXHRsYXJnZTogYm9vbGVhblxuKSB7XG5cdGNvbnN0IGRhdGEgPSBwaXhlbERhdGEgJiYgcGl4ZWxEYXRhLmRhdGE7XG5cdGxldCBsZW5ndGhzOiBVaW50MTZBcnJheSB8IFVpbnQzMkFycmF5O1xuXG5cdGlmIChsYXJnZSkge1xuXHRcdGxlbmd0aHMgPSBuZXcgVWludDMyQXJyYXkob2Zmc2V0cy5sZW5ndGggKiBoZWlnaHQpO1xuXG5cdFx0Zm9yIChsZXQgbyA9IDAsIGxpID0gMDsgbyA8IG9mZnNldHMubGVuZ3RoOyBvKyspIHtcblx0XHRcdGZvciAobGV0IHkgPSAwOyB5IDwgaGVpZ2h0OyB5KyssIGxpKyspIHtcblx0XHRcdFx0bGVuZ3Roc1tsaV0gPSByZWFkVWludDMyKHJlYWRlcik7XG5cdFx0XHR9XG5cdFx0fVxuXHR9IGVsc2Uge1xuXHRcdGxlbmd0aHMgPSBuZXcgVWludDE2QXJyYXkob2Zmc2V0cy5sZW5ndGggKiBoZWlnaHQpO1xuXG5cdFx0Zm9yIChsZXQgbyA9IDAsIGxpID0gMDsgbyA8IG9mZnNldHMubGVuZ3RoOyBvKyspIHtcblx0XHRcdGZvciAobGV0IHkgPSAwOyB5IDwgaGVpZ2h0OyB5KyssIGxpKyspIHtcblx0XHRcdFx0bGVuZ3Roc1tsaV0gPSByZWFkVWludDE2KHJlYWRlcik7XG5cdFx0XHR9XG5cdFx0fVxuXHR9XG5cblx0Y29uc3QgZXh0cmFMaW1pdCA9IChzdGVwIC0gMSkgfCAwOyAvLyAzIGZvciByZ2IsIDQgZm9yIGNteWtcblxuXHRmb3IgKGxldCBjID0gMCwgbGkgPSAwOyBjIDwgb2Zmc2V0cy5sZW5ndGg7IGMrKykge1xuXHRcdGNvbnN0IG9mZnNldCA9IG9mZnNldHNbY10gfCAwO1xuXHRcdGNvbnN0IGV4dHJhID0gYyA+IGV4dHJhTGltaXQgfHwgb2Zmc2V0ID4gZXh0cmFMaW1pdDtcblxuXHRcdGlmICghZGF0YSB8fCBleHRyYSkge1xuXHRcdFx0Zm9yIChsZXQgeSA9IDA7IHkgPCBoZWlnaHQ7IHkrKywgbGkrKykge1xuXHRcdFx0XHRza2lwQnl0ZXMocmVhZGVyLCBsZW5ndGhzW2xpXSk7XG5cdFx0XHR9XG5cdFx0fSBlbHNlIHtcblx0XHRcdGZvciAobGV0IHkgPSAwLCBwID0gb2Zmc2V0IHwgMDsgeSA8IGhlaWdodDsgeSsrLCBsaSsrKSB7XG5cdFx0XHRcdGNvbnN0IGxlbmd0aCA9IGxlbmd0aHNbbGldO1xuXHRcdFx0XHRjb25zdCBidWZmZXIgPSByZWFkQnl0ZXMocmVhZGVyLCBsZW5ndGgpO1xuXG5cdFx0XHRcdGZvciAobGV0IGkgPSAwOyBpIDwgbGVuZ3RoOyBpKyspIHtcblx0XHRcdFx0XHRsZXQgaGVhZGVyID0gYnVmZmVyW2ldO1xuXG5cdFx0XHRcdFx0aWYgKGhlYWRlciA+IDEyOCkge1xuXHRcdFx0XHRcdFx0Y29uc3QgdmFsdWUgPSBidWZmZXJbKytpXTtcblx0XHRcdFx0XHRcdGhlYWRlciA9ICgyNTYgLSBoZWFkZXIpIHwgMDtcblxuXHRcdFx0XHRcdFx0Zm9yIChsZXQgaiA9IDA7IGogPD0gaGVhZGVyOyBqID0gKGogKyAxKSB8IDApIHtcblx0XHRcdFx0XHRcdFx0ZGF0YVtwXSA9IHZhbHVlO1xuXHRcdFx0XHRcdFx0XHRwID0gKHAgKyBzdGVwKSB8IDA7XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0fSBlbHNlIGlmIChoZWFkZXIgPCAxMjgpIHtcblx0XHRcdFx0XHRcdGZvciAobGV0IGogPSAwOyBqIDw9IGhlYWRlcjsgaiA9IChqICsgMSkgfCAwKSB7XG5cdFx0XHRcdFx0XHRcdGRhdGFbcF0gPSBidWZmZXJbKytpXTtcblx0XHRcdFx0XHRcdFx0cCA9IChwICsgc3RlcCkgfCAwO1xuXHRcdFx0XHRcdFx0fVxuXHRcdFx0XHRcdH0gZWxzZSB7XG5cdFx0XHRcdFx0XHQvLyBpZ25vcmUgMTI4XG5cdFx0XHRcdFx0fVxuXG5cdFx0XHRcdFx0aWYgKGkgPj0gbGVuZ3RoKSB7XG5cdFx0XHRcdFx0XHR0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgUkxFIGRhdGE6IGV4Y2VlZGVkIGJ1ZmZlciBzaXplICR7aX0vJHtsZW5ndGh9YCk7XG5cdFx0XHRcdFx0fVxuXHRcdFx0XHR9XG5cdFx0XHR9XG5cdFx0fVxuXHR9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkU2VjdGlvbjxUPihcblx0cmVhZGVyOiBQc2RSZWFkZXIsIHJvdW5kOiBudW1iZXIsIGZ1bmM6IChsZWZ0OiAoKSA9PiBudW1iZXIpID0+IFQsIHNraXBFbXB0eSA9IHRydWUsIGVpZ2h0Qnl0ZXMgPSBmYWxzZVxuKTogVCB8IHVuZGVmaW5lZCB7XG5cdGxldCBsZW5ndGggPSByZWFkVWludDMyKHJlYWRlcik7XG5cblx0aWYgKGVpZ2h0Qnl0ZXMpIHtcblx0XHRpZiAobGVuZ3RoICE9PSAwKSB0aHJvdyBuZXcgRXJyb3IoJ1NpemVzIGxhcmdlciB0aGFuIDRHQiBhcmUgbm90IHN1cHBvcnRlZCcpO1xuXHRcdGxlbmd0aCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0fVxuXG5cdGlmIChsZW5ndGggPD0gMCAmJiBza2lwRW1wdHkpIHJldHVybiB1bmRlZmluZWQ7XG5cblx0bGV0IGVuZCA9IHJlYWRlci5vZmZzZXQgKyBsZW5ndGg7XG5cdGlmIChlbmQgPiByZWFkZXIudmlldy5ieXRlTGVuZ3RoKSB0aHJvdyBuZXcgRXJyb3IoJ1NlY3Rpb24gZXhjZWVkcyBmaWxlIHNpemUnKTtcblxuXHRjb25zdCByZXN1bHQgPSBmdW5jKCgpID0+IGVuZCAtIHJlYWRlci5vZmZzZXQpO1xuXG5cdGlmIChyZWFkZXIub2Zmc2V0ICE9PSBlbmQgJiYgcmVhZGVyLnN0cmljdCkge1xuXHRcdGlmIChyZWFkZXIub2Zmc2V0ID4gZW5kKSB7XG5cdFx0XHQvLyB0aHJvdyBuZXcgRXJyb3IoJ0V4Y2VlZGVkIHNlY3Rpb24gbGltaXRzJyk7XG5cdFx0XHRjb25zb2xlLndhcm4oJ0V4Y2VlZGVkIHNlY3Rpb24gbGltaXRzJyk7XG5cdFx0fSBlbHNlIHtcblx0XHRcdC8vIHRocm93IG5ldyBFcnJvcihgVW5yZWFkIHNlY3Rpb24gZGF0YTogJHtlbmQgLSByZWFkZXIub2Zmc2V0fSBieXRlcyBhdCAweCR7cmVhZGVyLm9mZnNldC50b1N0cmluZygxNil9YCk7XG5cdFx0XHRjb25zb2xlLndhcm4oJ1VucmVhZCBzZWN0aW9uIGRhdGEnKTtcblx0XHR9XG5cdH1cblxuXHR3aGlsZSAoZW5kICUgcm91bmQpIGVuZCsrO1xuXHRyZWFkZXIub2Zmc2V0ID0gZW5kO1xuXG5cdHJldHVybiByZXN1bHQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWFkQ29sb3IocmVhZGVyOiBQc2RSZWFkZXIpOiBDb2xvciB7XG5cdGNvbnN0IGNvbG9yU3BhY2UgPSByZWFkVWludDE2KHJlYWRlcikgYXMgQ29sb3JTcGFjZTtcblxuXHRzd2l0Y2ggKGNvbG9yU3BhY2UpIHtcblx0XHRjYXNlIENvbG9yU3BhY2UuUkdCOiB7XG5cdFx0XHRjb25zdCByID0gcmVhZFVpbnQxNihyZWFkZXIpIC8gMjU3O1xuXHRcdFx0Y29uc3QgZyA9IHJlYWRVaW50MTYocmVhZGVyKSAvIDI1Nztcblx0XHRcdGNvbnN0IGIgPSByZWFkVWludDE2KHJlYWRlcikgLyAyNTc7XG5cdFx0XHRza2lwQnl0ZXMocmVhZGVyLCAyKTtcblx0XHRcdHJldHVybiB7IHIsIGcsIGIgfTtcblx0XHR9XG5cdFx0Y2FzZSBDb2xvclNwYWNlLkhTQjoge1xuXHRcdFx0Y29uc3QgaCA9IHJlYWRVaW50MTYocmVhZGVyKSAvIDB4ZmZmZjtcblx0XHRcdGNvbnN0IHMgPSByZWFkVWludDE2KHJlYWRlcikgLyAweGZmZmY7XG5cdFx0XHRjb25zdCBiID0gcmVhZFVpbnQxNihyZWFkZXIpIC8gMHhmZmZmO1xuXHRcdFx0c2tpcEJ5dGVzKHJlYWRlciwgMik7XG5cdFx0XHRyZXR1cm4geyBoLCBzLCBiIH07XG5cdFx0fVxuXHRcdGNhc2UgQ29sb3JTcGFjZS5DTVlLOiB7XG5cdFx0XHRjb25zdCBjID0gcmVhZFVpbnQxNihyZWFkZXIpIC8gMjU3O1xuXHRcdFx0Y29uc3QgbSA9IHJlYWRVaW50MTYocmVhZGVyKSAvIDI1Nztcblx0XHRcdGNvbnN0IHkgPSByZWFkVWludDE2KHJlYWRlcikgLyAyNTc7XG5cdFx0XHRjb25zdCBrID0gcmVhZFVpbnQxNihyZWFkZXIpIC8gMjU3O1xuXHRcdFx0cmV0dXJuIHsgYywgbSwgeSwgayB9O1xuXHRcdH1cblx0XHRjYXNlIENvbG9yU3BhY2UuTGFiOiB7XG5cdFx0XHRjb25zdCBsID0gcmVhZEludDE2KHJlYWRlcikgLyAxMDAwMDtcblx0XHRcdGNvbnN0IHRhID0gcmVhZEludDE2KHJlYWRlcik7XG5cdFx0XHRjb25zdCB0YiA9IHJlYWRJbnQxNihyZWFkZXIpO1xuXHRcdFx0Y29uc3QgYSA9IHRhIDwgMCA/ICh0YSAvIDEyODAwKSA6ICh0YSAvIDEyNzAwKTtcblx0XHRcdGNvbnN0IGIgPSB0YiA8IDAgPyAodGIgLyAxMjgwMCkgOiAodGIgLyAxMjcwMCk7XG5cdFx0XHRza2lwQnl0ZXMocmVhZGVyLCAyKTtcblx0XHRcdHJldHVybiB7IGwsIGEsIGIgfTtcblx0XHR9XG5cdFx0Y2FzZSBDb2xvclNwYWNlLkdyYXlzY2FsZToge1xuXHRcdFx0Y29uc3QgayA9IHJlYWRVaW50MTYocmVhZGVyKSAqIDI1NSAvIDEwMDAwO1xuXHRcdFx0c2tpcEJ5dGVzKHJlYWRlciwgNik7XG5cdFx0XHRyZXR1cm4geyBrIH07XG5cdFx0fVxuXHRcdGRlZmF1bHQ6XG5cdFx0XHR0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgY29sb3Igc3BhY2UnKTtcblx0fVxufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZFBhdHRlcm4ocmVhZGVyOiBQc2RSZWFkZXIpOiBQYXR0ZXJuSW5mbyB7XG5cdHJlYWRVaW50MzIocmVhZGVyKTsgLy8gbGVuZ3RoXG5cdGNvbnN0IHZlcnNpb24gPSByZWFkVWludDMyKHJlYWRlcik7XG5cdGlmICh2ZXJzaW9uICE9PSAxKSB0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgcGF0dGVybiB2ZXJzaW9uOiAke3ZlcnNpb259YCk7XG5cblx0Y29uc3QgY29sb3JNb2RlID0gcmVhZFVpbnQzMihyZWFkZXIpIGFzIENvbG9yTW9kZTtcblx0Y29uc3QgeCA9IHJlYWRJbnQxNihyZWFkZXIpO1xuXHRjb25zdCB5ID0gcmVhZEludDE2KHJlYWRlcik7XG5cblx0Ly8gd2Ugb25seSBzdXBwb3J0IFJHQiBhbmQgZ3JheXNjYWxlIGZvciBub3dcblx0aWYgKGNvbG9yTW9kZSAhPT0gQ29sb3JNb2RlLlJHQiAmJiBjb2xvck1vZGUgIT09IENvbG9yTW9kZS5HcmF5c2NhbGUgJiYgY29sb3JNb2RlICE9PSBDb2xvck1vZGUuSW5kZXhlZCkge1xuXHRcdHRocm93IG5ldyBFcnJvcihgVW5zdXBwb3J0ZWQgcGF0dGVybiBjb2xvciBtb2RlOiAke2NvbG9yTW9kZX1gKTtcblx0fVxuXG5cdGxldCBuYW1lID0gcmVhZFVuaWNvZGVTdHJpbmcocmVhZGVyKTtcblx0Y29uc3QgaWQgPSByZWFkUGFzY2FsU3RyaW5nKHJlYWRlciwgMSk7XG5cdGNvbnN0IHBhbGV0dGU6IFJHQltdID0gW107XG5cblx0aWYgKGNvbG9yTW9kZSA9PT0gQ29sb3JNb2RlLkluZGV4ZWQpIHtcblx0XHRmb3IgKGxldCBpID0gMDsgaSA8IDI1NjsgaSsrKSB7XG5cdFx0XHRwYWxldHRlLnB1c2goe1xuXHRcdFx0XHRyOiByZWFkVWludDgocmVhZGVyKSxcblx0XHRcdFx0ZzogcmVhZFVpbnQ4KHJlYWRlciksXG5cdFx0XHRcdGI6IHJlYWRVaW50OChyZWFkZXIpLFxuXHRcdFx0fSlcblx0XHR9XG5cblx0XHRza2lwQnl0ZXMocmVhZGVyLCA0KTsgLy8gbm8gaWRlYSB3aGF0IHRoaXMgaXNcblx0fVxuXG5cdC8vIHZpcnR1YWwgbWVtb3J5IGFycmF5IGxpc3Rcblx0Y29uc3QgdmVyc2lvbjIgPSByZWFkVWludDMyKHJlYWRlcik7XG5cdGlmICh2ZXJzaW9uMiAhPT0gMykgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIHBhdHRlcm4gVk1BTCB2ZXJzaW9uOiAke3ZlcnNpb24yfWApO1xuXG5cdHJlYWRVaW50MzIocmVhZGVyKTsgLy8gbGVuZ3RoXG5cdGNvbnN0IHRvcCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0Y29uc3QgbGVmdCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0Y29uc3QgYm90dG9tID0gcmVhZFVpbnQzMihyZWFkZXIpO1xuXHRjb25zdCByaWdodCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0Y29uc3QgY2hhbm5lbHNDb3VudCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0Y29uc3Qgd2lkdGggPSByaWdodCAtIGxlZnQ7XG5cdGNvbnN0IGhlaWdodCA9IGJvdHRvbSAtIHRvcDtcblx0Y29uc3QgZGF0YSA9IG5ldyBVaW50OEFycmF5KHdpZHRoICogaGVpZ2h0ICogNCk7XG5cblx0Zm9yIChsZXQgaSA9IDM7IGkgPCBkYXRhLmJ5dGVMZW5ndGg7IGkgKz0gNCkge1xuXHRcdGRhdGFbaV0gPSAyNTU7XG5cdH1cblxuXHRmb3IgKGxldCBpID0gMCwgY2ggPSAwOyBpIDwgKGNoYW5uZWxzQ291bnQgKyAyKTsgaSsrKSB7XG5cdFx0Y29uc3QgaGFzID0gcmVhZFVpbnQzMihyZWFkZXIpO1xuXHRcdGlmICghaGFzKSBjb250aW51ZTtcblxuXHRcdGNvbnN0IGxlbmd0aCA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0XHRjb25zdCBwaXhlbERlcHRoID0gcmVhZFVpbnQzMihyZWFkZXIpO1xuXHRcdGNvbnN0IGN0b3AgPSByZWFkVWludDMyKHJlYWRlcik7XG5cdFx0Y29uc3QgY2xlZnQgPSByZWFkVWludDMyKHJlYWRlcik7XG5cdFx0Y29uc3QgY2JvdHRvbSA9IHJlYWRVaW50MzIocmVhZGVyKTtcblx0XHRjb25zdCBjcmlnaHQgPSByZWFkVWludDMyKHJlYWRlcik7XG5cdFx0Y29uc3QgcGl4ZWxEZXB0aDIgPSByZWFkVWludDE2KHJlYWRlcik7XG5cdFx0Y29uc3QgY29tcHJlc3Npb25Nb2RlID0gcmVhZFVpbnQ4KHJlYWRlcik7IC8vIDAgLSByYXcsIDEgLSB6aXBcblx0XHRjb25zdCBkYXRhTGVuZ3RoID0gbGVuZ3RoIC0gKDQgKyAxNiArIDIgKyAxKTtcblx0XHRjb25zdCBjZGF0YSA9IHJlYWRCeXRlcyhyZWFkZXIsIGRhdGFMZW5ndGgpO1xuXG5cdFx0aWYgKHBpeGVsRGVwdGggIT09IDggfHwgcGl4ZWxEZXB0aDIgIT09IDgpIHtcblx0XHRcdHRocm93IG5ldyBFcnJvcignMTZiaXQgcGl4ZWwgZGVwdGggbm90IHN1cHBvcnRlZCBmb3IgcGF0dGVybnMnKTtcblx0XHR9XG5cblx0XHRjb25zdCB3ID0gY3JpZ2h0IC0gY2xlZnQ7XG5cdFx0Y29uc3QgaCA9IGNib3R0b20gLSBjdG9wO1xuXHRcdGNvbnN0IG94ID0gY2xlZnQgLSBsZWZ0O1xuXHRcdGNvbnN0IG95ID0gY3RvcCAtIHRvcDtcblxuXHRcdGlmIChjb21wcmVzc2lvbk1vZGUgPT09IDApIHtcblx0XHRcdGlmIChjb2xvck1vZGUgPT09IENvbG9yTW9kZS5SR0IgJiYgY2ggPCAzKSB7XG5cdFx0XHRcdGZvciAobGV0IHkgPSAwOyB5IDwgaDsgeSsrKSB7XG5cdFx0XHRcdFx0Zm9yIChsZXQgeCA9IDA7IHggPCB3OyB4KyspIHtcblx0XHRcdFx0XHRcdGNvbnN0IHNyYyA9IHggKyB5ICogdztcblx0XHRcdFx0XHRcdGNvbnN0IGRzdCA9IChveCArIHggKyAoeSArIG95KSAqIHdpZHRoKSAqIDQ7XG5cdFx0XHRcdFx0XHRkYXRhW2RzdCArIGNoXSA9IGNkYXRhW3NyY107XG5cdFx0XHRcdFx0fVxuXHRcdFx0XHR9XG5cdFx0XHR9XG5cblx0XHRcdGlmIChjb2xvck1vZGUgPT09IENvbG9yTW9kZS5HcmF5c2NhbGUgJiYgY2ggPCAxKSB7XG5cdFx0XHRcdGZvciAobGV0IHkgPSAwOyB5IDwgaDsgeSsrKSB7XG5cdFx0XHRcdFx0Zm9yIChsZXQgeCA9IDA7IHggPCB3OyB4KyspIHtcblx0XHRcdFx0XHRcdGNvbnN0IHNyYyA9IHggKyB5ICogdztcblx0XHRcdFx0XHRcdGNvbnN0IGRzdCA9IChveCArIHggKyAoeSArIG95KSAqIHdpZHRoKSAqIDQ7XG5cdFx0XHRcdFx0XHRjb25zdCB2YWx1ZSA9IGNkYXRhW3NyY107XG5cdFx0XHRcdFx0XHRkYXRhW2RzdCArIDBdID0gdmFsdWU7XG5cdFx0XHRcdFx0XHRkYXRhW2RzdCArIDFdID0gdmFsdWU7XG5cdFx0XHRcdFx0XHRkYXRhW2RzdCArIDJdID0gdmFsdWU7XG5cdFx0XHRcdFx0fVxuXHRcdFx0XHR9XG5cdFx0XHR9XG5cblx0XHRcdGlmIChjb2xvck1vZGUgPT09IENvbG9yTW9kZS5JbmRleGVkKSB7XG5cdFx0XHRcdC8vIFRPRE86XG5cdFx0XHRcdHRocm93IG5ldyBFcnJvcignSW5kZXhlZCBwYXR0ZXJuIGNvbG9yIG1vZGUgbm90IGltcGxlbWVudGVkJyk7XG5cdFx0XHR9XG5cdFx0fSBlbHNlIGlmIChjb21wcmVzc2lvbk1vZGUgPT09IDEpIHtcblx0XHRcdC8vIGNvbnNvbGUubG9nKHsgY29sb3JNb2RlIH0pO1xuXHRcdFx0Ly8gcmVxdWlyZSgnZnMnKS53cml0ZUZpbGVTeW5jKCd6aXAuYmluJywgQnVmZmVyLmZyb20oY2RhdGEpKTtcblx0XHRcdC8vIGNvbnN0IGRhdGEgPSByZXF1aXJlKCd6bGliJykuaW5mbGF0ZVJhd1N5bmMoY2RhdGEpO1xuXHRcdFx0Ly8gY29uc3QgZGF0YSA9IHJlcXVpcmUoJ3psaWInKS51bnppcFN5bmMoY2RhdGEpO1xuXHRcdFx0Ly8gY29uc29sZS5sb2coZGF0YSk7XG5cdFx0XHQvLyB0aHJvdyBuZXcgRXJyb3IoJ1ppcCBjb21wcmVzc2lvbiBub3Qgc3VwcG9ydGVkIGZvciBwYXR0ZXJuJyk7XG5cdFx0XHQvLyB0aHJvdyBuZXcgRXJyb3IoJ1Vuc3VwcG9ydGVkIHBhdHRlcm4gY29tcHJlc3Npb24nKTtcblx0XHRcdGNvbnNvbGUuZXJyb3IoJ1Vuc3VwcG9ydGVkIHBhdHRlcm4gY29tcHJlc3Npb24nKTtcblx0XHRcdG5hbWUgKz0gJyAoZmFpbGVkIHRvIGRlY29kZSknO1xuXHRcdH0gZWxzZSB7XG5cdFx0XHR0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgcGF0dGVybiBjb21wcmVzc2lvbiBtb2RlJyk7XG5cdFx0fVxuXG5cdFx0Y2grKztcblx0fVxuXG5cdC8vIFRPRE86IHVzZSBjYW52YXMgaW5zdGVhZCBvZiBkYXRhID9cblxuXHRyZXR1cm4geyBpZCwgbmFtZSwgeCwgeSwgYm91bmRzOiB7IHg6IGxlZnQsIHk6IHRvcCwgdzogd2lkdGgsIGg6IGhlaWdodCB9LCBkYXRhIH07XG59XG4iXSwic291cmNlUm9vdCI6IkM6XFxQcm9qZWN0c1xcZ2l0aHViXFxhZy1wc2RcXHNyYyJ9
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.readPattern = exports.readColor = exports.readSection = exports.readDataRLE = exports.readDataZipWithoutPrediction = exports.readPsd = exports.checkSignature = exports.skipBytes = exports.readAsciiString = exports.readUnicodeStringWithLength = exports.readUnicodeString = exports.readPascalString = exports.readSignature = exports.readBytes = exports.readFixedPointPath32 = exports.readFixedPoint32 = exports.readFloat64 = exports.readFloat32 = exports.readUint32 = exports.readInt32LE = exports.readInt32 = exports.readUint16 = exports.readInt16 = exports.peekUint8 = exports.readUint8 = exports.warnOrThrow = exports.createReader = exports.supportedColorModes = void 0;
15
+ var pako_1 = require("pako");
16
+ var helpers_1 = require("./helpers");
17
+ var additionalInfo_1 = require("./additionalInfo");
18
+ var imageResources_1 = require("./imageResources");
19
+ exports.supportedColorModes = [0 /* ColorMode.Bitmap */, 1 /* ColorMode.Grayscale */, 3 /* ColorMode.RGB */];
20
+ var colorModes = ['bitmap', 'grayscale', 'indexed', 'RGB', 'CMYK', 'multichannel', 'duotone', 'lab'];
21
+ function setupGrayscale(data) {
22
+ var size = data.width * data.height * 4;
23
+ for (var i = 0; i < size; i += 4) {
24
+ data.data[i + 1] = data.data[i];
25
+ data.data[i + 2] = data.data[i];
26
+ }
27
+ }
28
+ function createReader(buffer, offset, length) {
29
+ var view = new DataView(buffer, offset, length);
30
+ return { view: view, offset: 0, strict: false, debug: false };
31
+ }
32
+ exports.createReader = createReader;
33
+ function warnOrThrow(reader, message) {
34
+ if (reader.strict)
35
+ throw new Error(message);
36
+ if (reader.debug)
37
+ console.warn(message);
38
+ }
39
+ exports.warnOrThrow = warnOrThrow;
40
+ function readUint8(reader) {
41
+ reader.offset += 1;
42
+ return reader.view.getUint8(reader.offset - 1);
43
+ }
44
+ exports.readUint8 = readUint8;
45
+ function peekUint8(reader) {
46
+ return reader.view.getUint8(reader.offset);
47
+ }
48
+ exports.peekUint8 = peekUint8;
49
+ function readInt16(reader) {
50
+ reader.offset += 2;
51
+ return reader.view.getInt16(reader.offset - 2, false);
52
+ }
53
+ exports.readInt16 = readInt16;
54
+ function readUint16(reader) {
55
+ reader.offset += 2;
56
+ return reader.view.getUint16(reader.offset - 2, false);
57
+ }
58
+ exports.readUint16 = readUint16;
59
+ function readInt32(reader) {
60
+ reader.offset += 4;
61
+ return reader.view.getInt32(reader.offset - 4, false);
62
+ }
63
+ exports.readInt32 = readInt32;
64
+ function readInt32LE(reader) {
65
+ reader.offset += 4;
66
+ return reader.view.getInt32(reader.offset - 4, true);
67
+ }
68
+ exports.readInt32LE = readInt32LE;
69
+ function readUint32(reader) {
70
+ reader.offset += 4;
71
+ return reader.view.getUint32(reader.offset - 4, false);
72
+ }
73
+ exports.readUint32 = readUint32;
74
+ function readFloat32(reader) {
75
+ reader.offset += 4;
76
+ return reader.view.getFloat32(reader.offset - 4, false);
77
+ }
78
+ exports.readFloat32 = readFloat32;
79
+ function readFloat64(reader) {
80
+ reader.offset += 8;
81
+ return reader.view.getFloat64(reader.offset - 8, false);
82
+ }
83
+ exports.readFloat64 = readFloat64;
84
+ // 32-bit fixed-point number 16.16
85
+ function readFixedPoint32(reader) {
86
+ return readInt32(reader) / (1 << 16);
87
+ }
88
+ exports.readFixedPoint32 = readFixedPoint32;
89
+ // 32-bit fixed-point number 8.24
90
+ function readFixedPointPath32(reader) {
91
+ return readInt32(reader) / (1 << 24);
92
+ }
93
+ exports.readFixedPointPath32 = readFixedPointPath32;
94
+ function readBytes(reader, length) {
95
+ var start = reader.view.byteOffset + reader.offset;
96
+ reader.offset += length;
97
+ if ((start + length) > reader.view.buffer.byteLength) {
98
+ // fix for broken PSD files that are missing part of file at the end
99
+ warnOrThrow(reader, 'Reading bytes exceeding buffer length');
100
+ if (length > (100 * 1024 * 1024))
101
+ throw new Error('Reading past end of file'); // limit to 100MB
102
+ var result = new Uint8Array(length);
103
+ var len = Math.min(length, reader.view.byteLength - start);
104
+ if (len > 0)
105
+ result.set(new Uint8Array(reader.view.buffer, start, len));
106
+ return result;
107
+ }
108
+ else {
109
+ return new Uint8Array(reader.view.buffer, start, length);
110
+ }
111
+ }
112
+ exports.readBytes = readBytes;
113
+ function readSignature(reader) {
114
+ return readShortString(reader, 4);
115
+ }
116
+ exports.readSignature = readSignature;
117
+ function readPascalString(reader, padTo) {
118
+ var length = readUint8(reader);
119
+ var text = length ? readShortString(reader, length) : '';
120
+ while (++length % padTo) {
121
+ reader.offset++;
122
+ }
123
+ return text;
124
+ }
125
+ exports.readPascalString = readPascalString;
126
+ function readUnicodeString(reader) {
127
+ var length = readUint32(reader);
128
+ return readUnicodeStringWithLength(reader, length);
129
+ }
130
+ exports.readUnicodeString = readUnicodeString;
131
+ function readUnicodeStringWithLength(reader, length) {
132
+ var text = '';
133
+ while (length--) {
134
+ var value = readUint16(reader);
135
+ if (value || length > 0) { // remove trailing \0
136
+ text += String.fromCharCode(value);
137
+ }
138
+ }
139
+ return text;
140
+ }
141
+ exports.readUnicodeStringWithLength = readUnicodeStringWithLength;
142
+ function readAsciiString(reader, length) {
143
+ var text = '';
144
+ while (length--) {
145
+ text += String.fromCharCode(readUint8(reader));
146
+ }
147
+ return text;
148
+ }
149
+ exports.readAsciiString = readAsciiString;
150
+ function skipBytes(reader, count) {
151
+ reader.offset += count;
152
+ }
153
+ exports.skipBytes = skipBytes;
154
+ function checkSignature(reader, a, b) {
155
+ var offset = reader.offset;
156
+ var signature = readSignature(reader);
157
+ if (signature !== a && signature !== b) {
158
+ throw new Error("Invalid signature: '".concat(signature, "' at 0x").concat(offset.toString(16)));
159
+ }
160
+ }
161
+ exports.checkSignature = checkSignature;
162
+ function readShortString(reader, length) {
163
+ var buffer = readBytes(reader, length);
164
+ var result = '';
165
+ for (var i = 0; i < buffer.length; i++) {
166
+ result += String.fromCharCode(buffer[i]);
167
+ }
168
+ return result;
169
+ }
170
+ function isValidSignature(sig) {
171
+ return sig === '8BIM' || sig === 'MeSa' || sig === 'AgHg' || sig === 'PHUT' || sig === 'DCSR';
172
+ }
173
+ function readPsd(reader, options) {
174
+ var _a;
175
+ if (options === void 0) { options = {}; }
176
+ // header
177
+ checkSignature(reader, '8BPS');
178
+ var version = readUint16(reader);
179
+ if (version !== 1 && version !== 2)
180
+ throw new Error("Invalid PSD file version: ".concat(version));
181
+ skipBytes(reader, 6);
182
+ var channels = readUint16(reader);
183
+ var height = readUint32(reader);
184
+ var width = readUint32(reader);
185
+ var bitsPerChannel = readUint16(reader);
186
+ var colorMode = readUint16(reader);
187
+ var maxSize = version === 1 ? 30000 : 300000;
188
+ if (width > maxSize || height > maxSize)
189
+ throw new Error("Invalid size");
190
+ if (channels > 16)
191
+ throw new Error("Invalid channel count");
192
+ if (bitsPerChannel > 32)
193
+ throw new Error("Invalid bitsPerChannel count");
194
+ if (exports.supportedColorModes.indexOf(colorMode) === -1)
195
+ throw new Error("Color mode not supported: ".concat((_a = colorModes[colorMode]) !== null && _a !== void 0 ? _a : colorMode));
196
+ var psd = { width: width, height: height, channels: channels, bitsPerChannel: bitsPerChannel, colorMode: colorMode };
197
+ var opt = __assign(__assign({}, options), { large: version === 2 });
198
+ var fixOffsets = [0, 1, -1, 2, -2, 3, -3, 4, -4];
199
+ // color mode data
200
+ readSection(reader, 1, function (left) {
201
+ if (opt.throwForMissingFeatures)
202
+ throw new Error('Color mode data not supported');
203
+ skipBytes(reader, left());
204
+ });
205
+ // image resources
206
+ readSection(reader, 1, function (left) {
207
+ var _loop_1 = function () {
208
+ var sigOffset = reader.offset;
209
+ var sig = '';
210
+ // attempt to fix broken document by realigning with the signature
211
+ for (var _i = 0, fixOffsets_1 = fixOffsets; _i < fixOffsets_1.length; _i++) {
212
+ var offset = fixOffsets_1[_i];
213
+ try {
214
+ reader.offset = sigOffset + offset;
215
+ sig = readSignature(reader);
216
+ }
217
+ catch (_a) { }
218
+ if (isValidSignature(sig))
219
+ break;
220
+ }
221
+ if (!isValidSignature(sig)) {
222
+ throw new Error("Invalid signature: '".concat(sig, "' at 0x").concat((sigOffset).toString(16)));
223
+ }
224
+ var id = readUint16(reader);
225
+ readPascalString(reader, 2); // name
226
+ readSection(reader, 2, function (left) {
227
+ var handler = imageResources_1.resourceHandlersMap[id];
228
+ var skip = id === 1036 && !!opt.skipThumbnail;
229
+ if (!psd.imageResources) {
230
+ psd.imageResources = {};
231
+ }
232
+ if (handler && !skip) {
233
+ try {
234
+ handler.read(reader, psd.imageResources, left, opt);
235
+ }
236
+ catch (e) {
237
+ if (opt.throwForMissingFeatures)
238
+ throw e;
239
+ skipBytes(reader, left());
240
+ }
241
+ }
242
+ else {
243
+ // options.logMissingFeatures && console.log(`Unhandled image resource: ${id}`);
244
+ skipBytes(reader, left());
245
+ }
246
+ });
247
+ };
248
+ while (left()) {
249
+ _loop_1();
250
+ }
251
+ });
252
+ // layer and mask info
253
+ var globalAlpha = false;
254
+ readSection(reader, 1, function (left) {
255
+ globalAlpha = readLayerInfo(reader, psd, opt);
256
+ // SAI does not include this section
257
+ if (left() > 0) {
258
+ var globalLayerMaskInfo = readGlobalLayerMaskInfo(reader);
259
+ if (globalLayerMaskInfo)
260
+ psd.globalLayerMaskInfo = globalLayerMaskInfo;
261
+ }
262
+ else {
263
+ // revert back to end of section if exceeded section limits
264
+ // opt.logMissingFeatures && console.log('reverting to end of section');
265
+ skipBytes(reader, left());
266
+ }
267
+ while (left() > 0) {
268
+ // sometimes there are empty bytes here
269
+ while (left() && peekUint8(reader) === 0) {
270
+ // opt.logMissingFeatures && console.log('skipping 0 byte');
271
+ skipBytes(reader, 1);
272
+ }
273
+ if (left() >= 12) {
274
+ readAdditionalLayerInfo(reader, psd, psd, opt);
275
+ }
276
+ else {
277
+ // opt.logMissingFeatures && console.log('skipping leftover bytes', left());
278
+ skipBytes(reader, left());
279
+ }
280
+ }
281
+ }, undefined, opt.large);
282
+ var hasChildren = psd.children && psd.children.length;
283
+ var skipComposite = opt.skipCompositeImageData && (opt.skipLayerImageData || hasChildren);
284
+ if (!skipComposite) {
285
+ readImageData(reader, psd, globalAlpha, opt);
286
+ }
287
+ // TODO: show converted color mode instead of original PSD file color mode
288
+ // but add option to preserve file color mode (need to return image data instead of canvas in that case)
289
+ // psd.colorMode = ColorMode.RGB; // we convert all color modes to RGB
290
+ return psd;
291
+ }
292
+ exports.readPsd = readPsd;
293
+ function readLayerInfo(reader, psd, options) {
294
+ var globalAlpha = false;
295
+ readSection(reader, 2, function (left) {
296
+ var layerCount = readInt16(reader);
297
+ if (layerCount < 0) {
298
+ globalAlpha = true;
299
+ layerCount = -layerCount;
300
+ }
301
+ var layers = [];
302
+ var layerChannels = [];
303
+ for (var i = 0; i < layerCount; i++) {
304
+ var _a = readLayerRecord(reader, psd, options), layer = _a.layer, channels = _a.channels;
305
+ layers.push(layer);
306
+ layerChannels.push(channels);
307
+ }
308
+ if (!options.skipLayerImageData) {
309
+ for (var i = 0; i < layerCount; i++) {
310
+ readLayerChannelImageData(reader, psd, layers[i], layerChannels[i], options);
311
+ }
312
+ }
313
+ skipBytes(reader, left());
314
+ if (!psd.children)
315
+ psd.children = [];
316
+ var stack = [psd];
317
+ for (var i = layers.length - 1; i >= 0; i--) {
318
+ var l = layers[i];
319
+ var type = l.sectionDivider ? l.sectionDivider.type : 0 /* SectionDividerType.Other */;
320
+ if (type === 1 /* SectionDividerType.OpenFolder */ || type === 2 /* SectionDividerType.ClosedFolder */) {
321
+ l.opened = type === 1 /* SectionDividerType.OpenFolder */;
322
+ l.children = [];
323
+ stack[stack.length - 1].children.unshift(l);
324
+ stack.push(l);
325
+ }
326
+ else if (type === 3 /* SectionDividerType.BoundingSectionDivider */) {
327
+ stack.pop();
328
+ // this was workaround because I didn't know what `lsdk` section was, now it's probably not needed anymore
329
+ // } else if (l.name === '</Layer group>' && !l.sectionDivider && !l.top && !l.left && !l.bottom && !l.right) {
330
+ // // sometimes layer group terminator doesn't have sectionDivider, so we just guess here (PS bug ?)
331
+ // stack.pop();
332
+ }
333
+ else {
334
+ stack[stack.length - 1].children.unshift(l);
335
+ }
336
+ }
337
+ }, undefined, options.large);
338
+ return globalAlpha;
339
+ }
340
+ function readLayerRecord(reader, psd, options) {
341
+ var layer = {};
342
+ layer.top = readInt32(reader);
343
+ layer.left = readInt32(reader);
344
+ layer.bottom = readInt32(reader);
345
+ layer.right = readInt32(reader);
346
+ var channelCount = readUint16(reader);
347
+ var channels = [];
348
+ for (var i = 0; i < channelCount; i++) {
349
+ var channelID = readInt16(reader);
350
+ var channelLength = readUint32(reader);
351
+ if (options.large) {
352
+ if (channelLength !== 0)
353
+ throw new Error('Sizes larger than 4GB are not supported');
354
+ channelLength = readUint32(reader);
355
+ }
356
+ channels.push({ id: channelID, length: channelLength });
357
+ }
358
+ checkSignature(reader, '8BIM');
359
+ var blendMode = readSignature(reader);
360
+ if (!helpers_1.toBlendMode[blendMode])
361
+ throw new Error("Invalid blend mode: '".concat(blendMode, "'"));
362
+ layer.blendMode = helpers_1.toBlendMode[blendMode];
363
+ layer.opacity = readUint8(reader) / 0xff;
364
+ layer.clipping = readUint8(reader) === 1;
365
+ var flags = readUint8(reader);
366
+ layer.transparencyProtected = (flags & 0x01) !== 0;
367
+ layer.hidden = (flags & 0x02) !== 0;
368
+ // 0x04 - obsolete
369
+ // 0x08 - 1 for Photoshop 5.0 and later, tells if bit 4 has useful information
370
+ // 0x10 - pixel data irrelevant to appearance of document
371
+ // 0x20 - ???
372
+ // if (flags & 0x20) (layer as any)._2 = true; // TEMP !!!!
373
+ skipBytes(reader, 1);
374
+ readSection(reader, 1, function (left) {
375
+ var mask = readLayerMaskData(reader, options);
376
+ if (mask)
377
+ layer.mask = mask;
378
+ /*const blendingRanges =*/ readLayerBlendingRanges(reader);
379
+ layer.name = readPascalString(reader, 4);
380
+ while (left()) {
381
+ readAdditionalLayerInfo(reader, layer, psd, options);
382
+ }
383
+ });
384
+ return { layer: layer, channels: channels };
385
+ }
386
+ function readLayerMaskData(reader, options) {
387
+ return readSection(reader, 1, function (left) {
388
+ if (!left())
389
+ return undefined;
390
+ var mask = {};
391
+ mask.top = readInt32(reader);
392
+ mask.left = readInt32(reader);
393
+ mask.bottom = readInt32(reader);
394
+ mask.right = readInt32(reader);
395
+ mask.defaultColor = readUint8(reader);
396
+ var flags = readUint8(reader);
397
+ mask.positionRelativeToLayer = (flags & 1 /* LayerMaskFlags.PositionRelativeToLayer */) !== 0;
398
+ mask.disabled = (flags & 2 /* LayerMaskFlags.LayerMaskDisabled */) !== 0;
399
+ mask.fromVectorData = (flags & 8 /* LayerMaskFlags.LayerMaskFromRenderingOtherData */) !== 0;
400
+ if (flags & 16 /* LayerMaskFlags.MaskHasParametersAppliedToIt */) {
401
+ var params = readUint8(reader);
402
+ if (params & 1 /* MaskParams.UserMaskDensity */)
403
+ mask.userMaskDensity = readUint8(reader) / 0xff;
404
+ if (params & 2 /* MaskParams.UserMaskFeather */)
405
+ mask.userMaskFeather = readFloat64(reader);
406
+ if (params & 4 /* MaskParams.VectorMaskDensity */)
407
+ mask.vectorMaskDensity = readUint8(reader) / 0xff;
408
+ if (params & 8 /* MaskParams.VectorMaskFeather */)
409
+ mask.vectorMaskFeather = readFloat64(reader);
410
+ }
411
+ if (left() > 2) {
412
+ options.logMissingFeatures && console.log('Unhandled extra mask params');
413
+ // TODO: handle these values
414
+ /*const realFlags =*/ readUint8(reader);
415
+ /*const realUserMaskBackground =*/ readUint8(reader);
416
+ /*const top2 =*/ readInt32(reader);
417
+ /*const left2 =*/ readInt32(reader);
418
+ /*const bottom2 =*/ readInt32(reader);
419
+ /*const right2 =*/ readInt32(reader);
420
+ }
421
+ skipBytes(reader, left());
422
+ return mask;
423
+ });
424
+ }
425
+ function readLayerBlendingRanges(reader) {
426
+ return readSection(reader, 1, function (left) {
427
+ var compositeGrayBlendSource = readUint32(reader);
428
+ var compositeGraphBlendDestinationRange = readUint32(reader);
429
+ var ranges = [];
430
+ while (left()) {
431
+ var sourceRange = readUint32(reader);
432
+ var destRange = readUint32(reader);
433
+ ranges.push({ sourceRange: sourceRange, destRange: destRange });
434
+ }
435
+ return { compositeGrayBlendSource: compositeGrayBlendSource, compositeGraphBlendDestinationRange: compositeGraphBlendDestinationRange, ranges: ranges };
436
+ });
437
+ }
438
+ function readLayerChannelImageData(reader, psd, layer, channels, options) {
439
+ var layerWidth = (layer.right || 0) - (layer.left || 0);
440
+ var layerHeight = (layer.bottom || 0) - (layer.top || 0);
441
+ var cmyk = psd.colorMode === 4 /* ColorMode.CMYK */;
442
+ var imageData;
443
+ if (layerWidth && layerHeight) {
444
+ if (cmyk) {
445
+ imageData = { width: layerWidth, height: layerHeight, data: new Uint8ClampedArray(layerWidth * layerHeight * 5) };
446
+ for (var p = 4; p < imageData.data.byteLength; p += 5)
447
+ imageData.data[p] = 255;
448
+ }
449
+ else {
450
+ imageData = (0, helpers_1.createImageData)(layerWidth, layerHeight);
451
+ (0, helpers_1.resetImageData)(imageData);
452
+ }
453
+ }
454
+ if (helpers_1.RAW_IMAGE_DATA)
455
+ layer.imageDataRaw = [];
456
+ for (var _i = 0, channels_1 = channels; _i < channels_1.length; _i++) {
457
+ var channel = channels_1[_i];
458
+ if (channel.length === 0)
459
+ continue;
460
+ if (channel.length < 2)
461
+ throw new Error('Invalid channel length');
462
+ var start = reader.offset;
463
+ var compression = readUint16(reader);
464
+ if (channel.id === -2 /* ChannelID.UserMask */) {
465
+ var mask = layer.mask;
466
+ if (!mask)
467
+ throw new Error("Missing layer mask data");
468
+ var maskWidth = (mask.right || 0) - (mask.left || 0);
469
+ var maskHeight = (mask.bottom || 0) - (mask.top || 0);
470
+ if (maskWidth && maskHeight) {
471
+ var maskData = (0, helpers_1.createImageData)(maskWidth, maskHeight);
472
+ (0, helpers_1.resetImageData)(maskData);
473
+ var start_1 = reader.offset;
474
+ readData(reader, channel.length, maskData, compression, maskWidth, maskHeight, 0, options.large, 4);
475
+ if (helpers_1.RAW_IMAGE_DATA) {
476
+ layer.maskDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start_1, reader.offset - start_1);
477
+ }
478
+ setupGrayscale(maskData);
479
+ if (options.useImageData) {
480
+ mask.imageData = maskData;
481
+ }
482
+ else {
483
+ mask.canvas = (0, helpers_1.createCanvas)(maskWidth, maskHeight);
484
+ mask.canvas.getContext('2d').putImageData(maskData, 0, 0);
485
+ }
486
+ }
487
+ }
488
+ else {
489
+ var offset = (0, helpers_1.offsetForChannel)(channel.id, cmyk);
490
+ var targetData = imageData;
491
+ if (offset < 0) {
492
+ targetData = undefined;
493
+ if (options.throwForMissingFeatures) {
494
+ throw new Error("Channel not supported: ".concat(channel.id));
495
+ }
496
+ }
497
+ readData(reader, channel.length, targetData, compression, layerWidth, layerHeight, offset, options.large, cmyk ? 5 : 4);
498
+ if (helpers_1.RAW_IMAGE_DATA) {
499
+ layer.imageDataRaw[channel.id] = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start + 2, channel.length - 2);
500
+ }
501
+ reader.offset = start + channel.length;
502
+ if (targetData && psd.colorMode === 1 /* ColorMode.Grayscale */) {
503
+ setupGrayscale(targetData);
504
+ }
505
+ }
506
+ }
507
+ if (imageData) {
508
+ if (cmyk) {
509
+ var cmykData = imageData;
510
+ imageData = (0, helpers_1.createImageData)(cmykData.width, cmykData.height);
511
+ cmykToRgb(cmykData, imageData, false);
512
+ }
513
+ if (options.useImageData) {
514
+ layer.imageData = imageData;
515
+ }
516
+ else {
517
+ layer.canvas = (0, helpers_1.createCanvas)(layerWidth, layerHeight);
518
+ layer.canvas.getContext('2d').putImageData(imageData, 0, 0);
519
+ }
520
+ }
521
+ }
522
+ function readData(reader, length, data, compression, width, height, offset, large, step) {
523
+ if (compression === 0 /* Compression.RawData */) {
524
+ readDataRaw(reader, data, width, height, step, offset);
525
+ }
526
+ else if (compression === 1 /* Compression.RleCompressed */) {
527
+ readDataRLE(reader, data, width, height, step, [offset], large);
528
+ }
529
+ else if (compression === 2 /* Compression.ZipWithoutPrediction */) {
530
+ readDataZipWithoutPrediction(reader, length, data, width, height, step, offset);
531
+ }
532
+ else if (compression === 3 /* Compression.ZipWithPrediction */) {
533
+ throw new Error("Compression type not supported: ".concat(compression));
534
+ }
535
+ else {
536
+ throw new Error("Invalid Compression type: ".concat(compression));
537
+ }
538
+ }
539
+ function readGlobalLayerMaskInfo(reader) {
540
+ return readSection(reader, 1, function (left) {
541
+ if (!left())
542
+ return undefined;
543
+ var overlayColorSpace = readUint16(reader);
544
+ var colorSpace1 = readUint16(reader);
545
+ var colorSpace2 = readUint16(reader);
546
+ var colorSpace3 = readUint16(reader);
547
+ var colorSpace4 = readUint16(reader);
548
+ var opacity = readUint16(reader) / 0xff;
549
+ var kind = readUint8(reader);
550
+ skipBytes(reader, left()); // 3 bytes of padding ?
551
+ return { overlayColorSpace: overlayColorSpace, colorSpace1: colorSpace1, colorSpace2: colorSpace2, colorSpace3: colorSpace3, colorSpace4: colorSpace4, opacity: opacity, kind: kind };
552
+ });
553
+ }
554
+ function readAdditionalLayerInfo(reader, target, psd, options) {
555
+ var sig = readSignature(reader);
556
+ if (sig !== '8BIM' && sig !== '8B64')
557
+ throw new Error("Invalid signature: '".concat(sig, "' at 0x").concat((reader.offset - 4).toString(16)));
558
+ var key = readSignature(reader);
559
+ // `largeAdditionalInfoKeys` fallback, because some keys don't have 8B64 signature even when they are 64bit
560
+ var u64 = sig === '8B64' || (options.large && helpers_1.largeAdditionalInfoKeys.indexOf(key) !== -1);
561
+ readSection(reader, 2, function (left) {
562
+ var handler = additionalInfo_1.infoHandlersMap[key];
563
+ if (handler) {
564
+ try {
565
+ handler.read(reader, target, left, psd, options);
566
+ }
567
+ catch (e) {
568
+ if (options.throwForMissingFeatures)
569
+ throw e;
570
+ }
571
+ }
572
+ else {
573
+ options.logMissingFeatures && console.log("Unhandled additional info: ".concat(key));
574
+ skipBytes(reader, left());
575
+ }
576
+ if (left()) {
577
+ options.logMissingFeatures && console.log("Unread ".concat(left(), " bytes left for additional info: ").concat(key));
578
+ skipBytes(reader, left());
579
+ }
580
+ }, false, u64);
581
+ }
582
+ function readImageData(reader, psd, globalAlpha, options) {
583
+ var compression = readUint16(reader);
584
+ if (exports.supportedColorModes.indexOf(psd.colorMode) === -1)
585
+ throw new Error("Color mode not supported: ".concat(psd.colorMode));
586
+ if (compression !== 0 /* Compression.RawData */ && compression !== 1 /* Compression.RleCompressed */)
587
+ throw new Error("Compression type not supported: ".concat(compression));
588
+ var imageData = (0, helpers_1.createImageData)(psd.width, psd.height);
589
+ (0, helpers_1.resetImageData)(imageData);
590
+ switch (psd.colorMode) {
591
+ case 0 /* ColorMode.Bitmap */: {
592
+ var bytes = void 0;
593
+ if (compression === 0 /* Compression.RawData */) {
594
+ bytes = readBytes(reader, Math.ceil(psd.width / 8) * psd.height);
595
+ }
596
+ else if (compression === 1 /* Compression.RleCompressed */) {
597
+ bytes = new Uint8Array(psd.width * psd.height);
598
+ readDataRLE(reader, { data: bytes, width: psd.width, height: psd.height }, psd.width, psd.height, 1, [0], options.large);
599
+ }
600
+ else {
601
+ throw new Error("Bitmap compression not supported: ".concat(compression));
602
+ }
603
+ (0, helpers_1.decodeBitmap)(bytes, imageData.data, psd.width, psd.height);
604
+ break;
605
+ }
606
+ case 3 /* ColorMode.RGB */:
607
+ case 1 /* ColorMode.Grayscale */: {
608
+ var channels = psd.colorMode === 1 /* ColorMode.Grayscale */ ? [0] : [0, 1, 2];
609
+ if (psd.channels && psd.channels > 3) {
610
+ for (var i = 3; i < psd.channels; i++) {
611
+ // TODO: store these channels in additional image data
612
+ channels.push(i);
613
+ }
614
+ }
615
+ else if (globalAlpha) {
616
+ channels.push(3);
617
+ }
618
+ if (compression === 0 /* Compression.RawData */) {
619
+ for (var i = 0; i < channels.length; i++) {
620
+ readDataRaw(reader, imageData, psd.width, psd.height, 4, channels[i]);
621
+ }
622
+ }
623
+ else if (compression === 1 /* Compression.RleCompressed */) {
624
+ var start = reader.offset;
625
+ readDataRLE(reader, imageData, psd.width, psd.height, 4, channels, options.large);
626
+ if (helpers_1.RAW_IMAGE_DATA)
627
+ psd.imageDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start, reader.offset - start);
628
+ }
629
+ if (psd.colorMode === 1 /* ColorMode.Grayscale */) {
630
+ setupGrayscale(imageData);
631
+ }
632
+ break;
633
+ }
634
+ case 4 /* ColorMode.CMYK */: {
635
+ if (psd.channels !== 4)
636
+ throw new Error("Invalid channel count");
637
+ var channels = [0, 1, 2, 3];
638
+ if (globalAlpha)
639
+ channels.push(4);
640
+ if (compression === 0 /* Compression.RawData */) {
641
+ throw new Error("Not implemented");
642
+ // TODO: ...
643
+ // for (let i = 0; i < channels.length; i++) {
644
+ // readDataRaw(reader, imageData, channels[i], psd.width, psd.height);
645
+ // }
646
+ }
647
+ else if (compression === 1 /* Compression.RleCompressed */) {
648
+ var cmykImageData = {
649
+ width: imageData.width,
650
+ height: imageData.height,
651
+ data: new Uint8Array(imageData.width * imageData.height * 5),
652
+ };
653
+ var start = reader.offset;
654
+ readDataRLE(reader, cmykImageData, psd.width, psd.height, 5, channels, options.large);
655
+ cmykToRgb(cmykImageData, imageData, true);
656
+ if (helpers_1.RAW_IMAGE_DATA)
657
+ psd.imageDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start, reader.offset - start);
658
+ }
659
+ break;
660
+ }
661
+ default: throw new Error("Color mode not supported: ".concat(psd.colorMode));
662
+ }
663
+ if (options.useImageData) {
664
+ psd.imageData = imageData;
665
+ }
666
+ else {
667
+ psd.canvas = (0, helpers_1.createCanvas)(psd.width, psd.height);
668
+ psd.canvas.getContext('2d').putImageData(imageData, 0, 0);
669
+ }
670
+ }
671
+ function cmykToRgb(cmyk, rgb, reverseAlpha) {
672
+ var size = rgb.width * rgb.height * 4;
673
+ var srcData = cmyk.data;
674
+ var dstData = rgb.data;
675
+ for (var src = 0, dst = 0; dst < size; src += 5, dst += 4) {
676
+ var c = srcData[src];
677
+ var m = srcData[src + 1];
678
+ var y = srcData[src + 2];
679
+ var k = srcData[src + 3];
680
+ dstData[dst] = ((((c * k) | 0) / 255) | 0);
681
+ dstData[dst + 1] = ((((m * k) | 0) / 255) | 0);
682
+ dstData[dst + 2] = ((((y * k) | 0) / 255) | 0);
683
+ dstData[dst + 3] = reverseAlpha ? 255 - srcData[src + 4] : srcData[src + 4];
684
+ }
685
+ // for (let src = 0, dst = 0; dst < size; src += 5, dst += 4) {
686
+ // const c = 1 - (srcData[src + 0] / 255);
687
+ // const m = 1 - (srcData[src + 1] / 255);
688
+ // const y = 1 - (srcData[src + 2] / 255);
689
+ // // const k = srcData[src + 3] / 255;
690
+ // dstData[dst + 0] = ((1 - c * 0.8) * 255) | 0;
691
+ // dstData[dst + 1] = ((1 - m * 0.8) * 255) | 0;
692
+ // dstData[dst + 2] = ((1 - y * 0.8) * 255) | 0;
693
+ // dstData[dst + 3] = reverseAlpha ? 255 - srcData[src + 4] : srcData[src + 4];
694
+ // }
695
+ }
696
+ function readDataRaw(reader, pixelData, width, height, step, offset) {
697
+ var size = width * height;
698
+ var buffer = readBytes(reader, size);
699
+ if (pixelData && offset < step) {
700
+ var data = pixelData.data;
701
+ for (var i = 0, p = offset | 0; i < size; i++, p = (p + step) | 0) {
702
+ data[p] = buffer[i];
703
+ }
704
+ }
705
+ }
706
+ function readDataZipWithoutPrediction(reader, length, pixelData, width, height, step, offset) {
707
+ var compressed = readBytes(reader, length);
708
+ var decompressed = (0, pako_1.inflate)(compressed);
709
+ var size = width * height;
710
+ if (pixelData && offset < step) {
711
+ var data = pixelData.data;
712
+ for (var i = 0, p = offset | 0; i < size; i++, p = (p + step) | 0) {
713
+ data[p] = decompressed[i];
714
+ }
715
+ }
716
+ }
717
+ exports.readDataZipWithoutPrediction = readDataZipWithoutPrediction;
718
+ function readDataRLE(reader, pixelData, _width, height, step, offsets, large) {
719
+ var data = pixelData && pixelData.data;
720
+ var lengths;
721
+ if (large) {
722
+ lengths = new Uint32Array(offsets.length * height);
723
+ for (var o = 0, li = 0; o < offsets.length; o++) {
724
+ for (var y = 0; y < height; y++, li++) {
725
+ lengths[li] = readUint32(reader);
726
+ }
727
+ }
728
+ }
729
+ else {
730
+ lengths = new Uint16Array(offsets.length * height);
731
+ for (var o = 0, li = 0; o < offsets.length; o++) {
732
+ for (var y = 0; y < height; y++, li++) {
733
+ lengths[li] = readUint16(reader);
734
+ }
735
+ }
736
+ }
737
+ var extraLimit = (step - 1) | 0; // 3 for rgb, 4 for cmyk
738
+ for (var c = 0, li = 0; c < offsets.length; c++) {
739
+ var offset = offsets[c] | 0;
740
+ var extra = c > extraLimit || offset > extraLimit;
741
+ if (!data || extra) {
742
+ for (var y = 0; y < height; y++, li++) {
743
+ skipBytes(reader, lengths[li]);
744
+ }
745
+ }
746
+ else {
747
+ for (var y = 0, p = offset | 0; y < height; y++, li++) {
748
+ var length_1 = lengths[li];
749
+ var buffer = readBytes(reader, length_1);
750
+ for (var i = 0; i < length_1; i++) {
751
+ var header = buffer[i];
752
+ if (header > 128) {
753
+ var value = buffer[++i];
754
+ header = (256 - header) | 0;
755
+ for (var j = 0; j <= header; j = (j + 1) | 0) {
756
+ data[p] = value;
757
+ p = (p + step) | 0;
758
+ }
759
+ }
760
+ else if (header < 128) {
761
+ for (var j = 0; j <= header; j = (j + 1) | 0) {
762
+ data[p] = buffer[++i];
763
+ p = (p + step) | 0;
764
+ }
765
+ }
766
+ else {
767
+ // ignore 128
768
+ }
769
+ // This showed up on some images from non-photoshop programs, ignoring it seems to work just fine.
770
+ // if (i >= length) throw new Error(`Invalid RLE data: exceeded buffer size ${i}/${length}`);
771
+ }
772
+ }
773
+ }
774
+ }
775
+ }
776
+ exports.readDataRLE = readDataRLE;
777
+ function readSection(reader, round, func, skipEmpty, eightBytes) {
778
+ if (skipEmpty === void 0) { skipEmpty = true; }
779
+ if (eightBytes === void 0) { eightBytes = false; }
780
+ var length = readUint32(reader);
781
+ if (eightBytes) {
782
+ if (length !== 0)
783
+ throw new Error('Sizes larger than 4GB are not supported');
784
+ length = readUint32(reader);
785
+ }
786
+ if (length <= 0 && skipEmpty)
787
+ return undefined;
788
+ var end = reader.offset + length;
789
+ if (end > reader.view.byteLength)
790
+ throw new Error('Section exceeds file size');
791
+ var result = func(function () { return end - reader.offset; });
792
+ if (reader.offset !== end) {
793
+ if (reader.offset > end) {
794
+ warnOrThrow(reader, 'Exceeded section limits');
795
+ }
796
+ else {
797
+ warnOrThrow(reader, "Unread section data"); // : ${end - reader.offset} bytes at 0x${reader.offset.toString(16)}`);
798
+ }
799
+ }
800
+ while (end % round)
801
+ end++;
802
+ reader.offset = end;
803
+ return result;
804
+ }
805
+ exports.readSection = readSection;
806
+ function readColor(reader) {
807
+ var colorSpace = readUint16(reader);
808
+ switch (colorSpace) {
809
+ case 0 /* ColorSpace.RGB */: {
810
+ var r = readUint16(reader) / 257;
811
+ var g = readUint16(reader) / 257;
812
+ var b = readUint16(reader) / 257;
813
+ skipBytes(reader, 2);
814
+ return { r: r, g: g, b: b };
815
+ }
816
+ case 1 /* ColorSpace.HSB */: {
817
+ var h = readUint16(reader) / 0xffff;
818
+ var s = readUint16(reader) / 0xffff;
819
+ var b = readUint16(reader) / 0xffff;
820
+ skipBytes(reader, 2);
821
+ return { h: h, s: s, b: b };
822
+ }
823
+ case 2 /* ColorSpace.CMYK */: {
824
+ var c = readUint16(reader) / 257;
825
+ var m = readUint16(reader) / 257;
826
+ var y = readUint16(reader) / 257;
827
+ var k = readUint16(reader) / 257;
828
+ return { c: c, m: m, y: y, k: k };
829
+ }
830
+ case 7 /* ColorSpace.Lab */: {
831
+ var l = readInt16(reader) / 10000;
832
+ var ta = readInt16(reader);
833
+ var tb = readInt16(reader);
834
+ var a = ta < 0 ? (ta / 12800) : (ta / 12700);
835
+ var b = tb < 0 ? (tb / 12800) : (tb / 12700);
836
+ skipBytes(reader, 2);
837
+ return { l: l, a: a, b: b };
838
+ }
839
+ case 8 /* ColorSpace.Grayscale */: {
840
+ var k = readUint16(reader) * 255 / 10000;
841
+ skipBytes(reader, 6);
842
+ return { k: k };
843
+ }
844
+ default:
845
+ throw new Error('Invalid color space');
846
+ }
847
+ }
848
+ exports.readColor = readColor;
849
+ function readPattern(reader) {
850
+ readUint32(reader); // length
851
+ var version = readUint32(reader);
852
+ if (version !== 1)
853
+ throw new Error("Invalid pattern version: ".concat(version));
854
+ var colorMode = readUint32(reader);
855
+ var x = readInt16(reader);
856
+ var y = readInt16(reader);
857
+ // we only support RGB and grayscale for now
858
+ if (colorMode !== 3 /* ColorMode.RGB */ && colorMode !== 1 /* ColorMode.Grayscale */ && colorMode !== 2 /* ColorMode.Indexed */) {
859
+ throw new Error("Unsupported pattern color mode: ".concat(colorMode));
860
+ }
861
+ var name = readUnicodeString(reader);
862
+ var id = readPascalString(reader, 1);
863
+ var palette = [];
864
+ if (colorMode === 2 /* ColorMode.Indexed */) {
865
+ for (var i = 0; i < 256; i++) {
866
+ palette.push({
867
+ r: readUint8(reader),
868
+ g: readUint8(reader),
869
+ b: readUint8(reader),
870
+ });
871
+ }
872
+ skipBytes(reader, 4); // no idea what this is
873
+ }
874
+ // virtual memory array list
875
+ var version2 = readUint32(reader);
876
+ if (version2 !== 3)
877
+ throw new Error("Invalid pattern VMAL version: ".concat(version2));
878
+ readUint32(reader); // length
879
+ var top = readUint32(reader);
880
+ var left = readUint32(reader);
881
+ var bottom = readUint32(reader);
882
+ var right = readUint32(reader);
883
+ var channelsCount = readUint32(reader);
884
+ var width = right - left;
885
+ var height = bottom - top;
886
+ var data = new Uint8Array(width * height * 4);
887
+ for (var i = 3; i < data.byteLength; i += 4) {
888
+ data[i] = 255;
889
+ }
890
+ for (var i = 0, ch = 0; i < (channelsCount + 2); i++) {
891
+ var has = readUint32(reader);
892
+ if (!has)
893
+ continue;
894
+ var length_2 = readUint32(reader);
895
+ var pixelDepth = readUint32(reader);
896
+ var ctop = readUint32(reader);
897
+ var cleft = readUint32(reader);
898
+ var cbottom = readUint32(reader);
899
+ var cright = readUint32(reader);
900
+ var pixelDepth2 = readUint16(reader);
901
+ var compressionMode = readUint8(reader); // 0 - raw, 1 - zip
902
+ var dataLength = length_2 - (4 + 16 + 2 + 1);
903
+ var cdata = readBytes(reader, dataLength);
904
+ if (pixelDepth !== 8 || pixelDepth2 !== 8) {
905
+ throw new Error('16bit pixel depth not supported for patterns');
906
+ }
907
+ var w = cright - cleft;
908
+ var h = cbottom - ctop;
909
+ var ox = cleft - left;
910
+ var oy = ctop - top;
911
+ if (compressionMode === 0) {
912
+ if (colorMode === 3 /* ColorMode.RGB */ && ch < 3) {
913
+ for (var y_1 = 0; y_1 < h; y_1++) {
914
+ for (var x_1 = 0; x_1 < w; x_1++) {
915
+ var src = x_1 + y_1 * w;
916
+ var dst = (ox + x_1 + (y_1 + oy) * width) * 4;
917
+ data[dst + ch] = cdata[src];
918
+ }
919
+ }
920
+ }
921
+ if (colorMode === 1 /* ColorMode.Grayscale */ && ch < 1) {
922
+ for (var y_2 = 0; y_2 < h; y_2++) {
923
+ for (var x_2 = 0; x_2 < w; x_2++) {
924
+ var src = x_2 + y_2 * w;
925
+ var dst = (ox + x_2 + (y_2 + oy) * width) * 4;
926
+ var value = cdata[src];
927
+ data[dst + 0] = value;
928
+ data[dst + 1] = value;
929
+ data[dst + 2] = value;
930
+ }
931
+ }
932
+ }
933
+ if (colorMode === 2 /* ColorMode.Indexed */) {
934
+ // TODO:
935
+ throw new Error('Indexed pattern color mode not implemented');
936
+ }
937
+ }
938
+ else if (compressionMode === 1) {
939
+ // console.log({ colorMode });
940
+ // require('fs').writeFileSync('zip.bin', Buffer.from(cdata));
941
+ // const data = require('zlib').inflateRawSync(cdata);
942
+ // const data = require('zlib').unzipSync(cdata);
943
+ // console.log(data);
944
+ // throw new Error('Zip compression not supported for pattern');
945
+ // throw new Error('Unsupported pattern compression');
946
+ console.error('Unsupported pattern compression');
947
+ name += ' (failed to decode)';
948
+ }
949
+ else {
950
+ throw new Error('Invalid pattern compression mode');
951
+ }
952
+ ch++;
953
+ }
954
+ // TODO: use canvas instead of data ?
955
+ return { id: id, name: name, x: x, y: y, bounds: { x: left, y: top, w: width, h: height }, data: data };
956
+ }
957
+ exports.readPattern = readPattern;
958
+ //# sourceMappingURL=psdReader.js.map