ag-psd 15.0.1 → 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 -8725
  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 -36
  41. package/dist/psdReader.js +958 -959
  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 -36
  89. package/dist-es/psdReader.js +928 -929
  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,959 +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.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
-
959
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["psdReader.ts"],"names":[],"mappings":"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","file":"psdReader.js","sourcesContent":["import { inflate } from 'pako';\nimport {\n\tPsd, Layer, ColorMode, SectionDividerType, LayerAdditionalInfo, ReadOptions, LayerMaskData, Color,\n\tPatternInfo, GlobalLayerMaskInfo, RGB\n} from './psd';\nimport {\n\tresetImageData, offsetForChannel, decodeBitmap, PixelData, createCanvas, createImageData,\n\ttoBlendMode, ChannelID, Compression, LayerMaskFlags, MaskParams, ColorSpace, RAW_IMAGE_DATA, largeAdditionalInfoKeys\n} from './helpers';\nimport { infoHandlersMap } from './additionalInfo';\nimport { resourceHandlersMap } from './imageResources';\n\ninterface ChannelInfo {\n\tid: ChannelID;\n\tlength: number;\n}\n\ninterface ReadOptionsExt extends ReadOptions {\n\tlarge: boolean;\n}\n\nexport const supportedColorModes = [ColorMode.Bitmap, ColorMode.Grayscale, ColorMode.RGB];\nconst colorModes = ['bitmap', 'grayscale', 'indexed', 'RGB', 'CMYK', 'multichannel', 'duotone', 'lab'];\n\nfunction setupGrayscale(data: PixelData) {\n\tconst size = data.width * data.height * 4;\n\n\tfor (let i = 0; i < size; i += 4) {\n\t\tdata.data[i + 1] = data.data[i];\n\t\tdata.data[i + 2] = data.data[i];\n\t}\n}\n\nexport interface PsdReader {\n\toffset: number;\n\tview: DataView;\n\tstrict: boolean;\n\tdebug: boolean;\n}\n\nexport function createReader(buffer: ArrayBuffer, offset?: number, length?: number): PsdReader {\n\tconst view = new DataView(buffer, offset, length);\n\treturn { view, offset: 0, strict: false, debug: false };\n}\n\nexport function warnOrThrow(reader: PsdReader, message: string) {\n\tif (reader.strict) throw new Error(message);\n\tif (reader.debug) console.warn(message);\n}\n\nexport function readUint8(reader: PsdReader) {\n\treader.offset += 1;\n\treturn reader.view.getUint8(reader.offset - 1);\n}\n\nexport function peekUint8(reader: PsdReader) {\n\treturn reader.view.getUint8(reader.offset);\n}\n\nexport function readInt16(reader: PsdReader) {\n\treader.offset += 2;\n\treturn reader.view.getInt16(reader.offset - 2, false);\n}\n\nexport function readUint16(reader: PsdReader) {\n\treader.offset += 2;\n\treturn reader.view.getUint16(reader.offset - 2, false);\n}\n\nexport function readInt32(reader: PsdReader) {\n\treader.offset += 4;\n\treturn reader.view.getInt32(reader.offset - 4, false);\n}\n\nexport function readInt32LE(reader: PsdReader) {\n\treader.offset += 4;\n\treturn reader.view.getInt32(reader.offset - 4, true);\n}\n\nexport function readUint32(reader: PsdReader) {\n\treader.offset += 4;\n\treturn reader.view.getUint32(reader.offset - 4, false);\n}\n\nexport function readFloat32(reader: PsdReader) {\n\treader.offset += 4;\n\treturn reader.view.getFloat32(reader.offset - 4, false);\n}\n\nexport function readFloat64(reader: PsdReader) {\n\treader.offset += 8;\n\treturn reader.view.getFloat64(reader.offset - 8, false);\n}\n\n// 32-bit fixed-point number 16.16\nexport function readFixedPoint32(reader: PsdReader): number {\n\treturn readInt32(reader) / (1 << 16);\n}\n\n// 32-bit fixed-point number 8.24\nexport function readFixedPointPath32(reader: PsdReader): number {\n\treturn readInt32(reader) / (1 << 24);\n}\n\nexport function readBytes(reader: PsdReader, length: number) {\n\tconst start = reader.view.byteOffset + reader.offset;\n\treader.offset += length;\n\n\tif ((start + length) > reader.view.buffer.byteLength) {\n\t\t// fix for broken PSD files that are missing part of file at the end\n\t\twarnOrThrow(reader, 'Reading bytes exceeding buffer length');\n\t\tif (length > (100 * 1024 * 1024)) throw new Error('Reading past end of file'); // limit to 100MB\n\t\tconst result = new Uint8Array(length);\n\t\tconst len = Math.min(length, reader.view.byteLength - start);\n\t\tif (len > 0) result.set(new Uint8Array(reader.view.buffer, start, len));\n\t\treturn result;\n\t} else {\n\t\treturn new Uint8Array(reader.view.buffer, start, length);\n\t}\n}\n\nexport function readSignature(reader: PsdReader) {\n\treturn readShortString(reader, 4);\n}\n\nexport function readPascalString(reader: PsdReader, padTo: number) {\n\tlet length = readUint8(reader);\n\tconst text = length ? readShortString(reader, length) : '';\n\n\twhile (++length % padTo) {\n\t\treader.offset++;\n\t}\n\n\treturn text;\n}\n\nexport function readUnicodeString(reader: PsdReader) {\n\tconst length = readUint32(reader);\n\treturn readUnicodeStringWithLength(reader, length);\n}\n\nexport function readUnicodeStringWithLength(reader: PsdReader, length: number) {\n\tlet text = '';\n\n\twhile (length--) {\n\t\tconst value = readUint16(reader);\n\n\t\tif (value || length > 0) { // remove trailing \\0\n\t\t\ttext += String.fromCharCode(value);\n\t\t}\n\t}\n\n\treturn text;\n}\n\nexport function readAsciiString(reader: PsdReader, length: number) {\n\tlet text = '';\n\n\twhile (length--) {\n\t\ttext += String.fromCharCode(readUint8(reader));\n\t}\n\n\treturn text;\n}\n\nexport function skipBytes(reader: PsdReader, count: number) {\n\treader.offset += count;\n}\n\nexport function checkSignature(reader: PsdReader, a: string, b?: string) {\n\tconst offset = reader.offset;\n\tconst signature = readSignature(reader);\n\n\tif (signature !== a && signature !== b) {\n\t\tthrow new Error(`Invalid signature: '${signature}' at 0x${offset.toString(16)}`);\n\t}\n}\n\nfunction readShortString(reader: PsdReader, length: number) {\n\tconst buffer = readBytes(reader, length);\n\tlet result = '';\n\n\tfor (let i = 0; i < buffer.length; i++) {\n\t\tresult += String.fromCharCode(buffer[i]);\n\t}\n\n\treturn result;\n}\n\nfunction isValidSignature(sig: string) {\n\treturn sig === '8BIM' || sig === 'MeSa' || sig === 'AgHg' || sig === 'PHUT' || sig === 'DCSR';\n}\n\nexport function readPsd(reader: PsdReader, options: ReadOptions = {}) {\n\t// header\n\tcheckSignature(reader, '8BPS');\n\tconst version = readUint16(reader);\n\tif (version !== 1 && version !== 2) throw new Error(`Invalid PSD file version: ${version}`);\n\n\tskipBytes(reader, 6);\n\tconst channels = readUint16(reader);\n\tconst height = readUint32(reader);\n\tconst width = readUint32(reader);\n\tconst bitsPerChannel = readUint16(reader);\n\tconst colorMode = readUint16(reader);\n\tconst maxSize = version === 1 ? 30000 : 300000;\n\n\tif (width > maxSize || height > maxSize) throw new Error(`Invalid size`);\n\tif (channels > 16) throw new Error(`Invalid channel count`);\n\tif (bitsPerChannel > 32) throw new Error(`Invalid bitsPerChannel count`);\n\tif (supportedColorModes.indexOf(colorMode) === -1)\n\t\tthrow new Error(`Color mode not supported: ${colorModes[colorMode] ?? colorMode}`);\n\n\tconst psd: Psd = { width, height, channels, bitsPerChannel, colorMode };\n\tconst opt: ReadOptionsExt = { ...options, large: version === 2 };\n\tconst fixOffsets = [0, 1, -1, 2, -2, 3, -3, 4, -4];\n\n\t// color mode data\n\treadSection(reader, 1, left => {\n\t\tif (opt.throwForMissingFeatures) throw new Error('Color mode data not supported');\n\t\tskipBytes(reader, left());\n\t});\n\n\t// image resources\n\treadSection(reader, 1, left => {\n\t\twhile (left()) {\n\t\t\tconst sigOffset = reader.offset;\n\t\t\tlet sig = '';\n\n\t\t\t// attempt to fix broken document by realigning with the signature\n\t\t\tfor (const offset of fixOffsets) {\n\t\t\t\ttry {\n\t\t\t\t\treader.offset = sigOffset + offset;\n\t\t\t\t\tsig = readSignature(reader);\n\t\t\t\t} catch { }\n\t\t\t\tif (isValidSignature(sig)) break;\n\t\t\t}\n\n\t\t\tif (!isValidSignature(sig)) {\n\t\t\t\tthrow new Error(`Invalid signature: '${sig}' at 0x${(sigOffset).toString(16)}`);\n\t\t\t}\n\n\t\t\tconst id = readUint16(reader);\n\t\t\treadPascalString(reader, 2); // name\n\n\t\t\treadSection(reader, 2, left => {\n\t\t\t\tconst handler = resourceHandlersMap[id];\n\t\t\t\tconst skip = id === 1036 && !!opt.skipThumbnail;\n\n\t\t\t\tif (!psd.imageResources) {\n\t\t\t\t\tpsd.imageResources = {};\n\t\t\t\t}\n\n\t\t\t\tif (handler && !skip) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\thandler.read(reader, psd.imageResources, left, opt);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\tif (opt.throwForMissingFeatures) throw e;\n\t\t\t\t\t\tskipBytes(reader, left());\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// options.logMissingFeatures && console.log(`Unhandled image resource: ${id}`);\n\t\t\t\t\tskipBytes(reader, left());\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t});\n\n\t// layer and mask info\n\tlet globalAlpha = false;\n\n\treadSection(reader, 1, left => {\n\t\tglobalAlpha = readLayerInfo(reader, psd, opt);\n\n\t\t// SAI does not include this section\n\t\tif (left() > 0) {\n\t\t\tconst globalLayerMaskInfo = readGlobalLayerMaskInfo(reader);\n\t\t\tif (globalLayerMaskInfo) psd.globalLayerMaskInfo = globalLayerMaskInfo;\n\t\t} else {\n\t\t\t// revert back to end of section if exceeded section limits\n\t\t\t// opt.logMissingFeatures && console.log('reverting to end of section');\n\t\t\tskipBytes(reader, left());\n\t\t}\n\n\t\twhile (left() > 0) {\n\t\t\t// sometimes there are empty bytes here\n\t\t\twhile (left() && peekUint8(reader) === 0) {\n\t\t\t\t// opt.logMissingFeatures && console.log('skipping 0 byte');\n\t\t\t\tskipBytes(reader, 1);\n\t\t\t}\n\n\t\t\tif (left() >= 12) {\n\t\t\t\treadAdditionalLayerInfo(reader, psd, psd, opt);\n\t\t\t} else {\n\t\t\t\t// opt.logMissingFeatures && console.log('skipping leftover bytes', left());\n\t\t\t\tskipBytes(reader, left());\n\t\t\t}\n\t\t}\n\t}, undefined, opt.large);\n\n\tconst hasChildren = psd.children && psd.children.length;\n\tconst skipComposite = opt.skipCompositeImageData && (opt.skipLayerImageData || hasChildren);\n\n\tif (!skipComposite) {\n\t\treadImageData(reader, psd, globalAlpha, opt);\n\t}\n\n\t// TODO: show converted color mode instead of original PSD file color mode\n\t//       but add option to preserve file color mode (need to return image data instead of canvas in that case)\n\t// psd.colorMode = ColorMode.RGB; // we convert all color modes to RGB\n\n\treturn psd;\n}\n\nfunction readLayerInfo(reader: PsdReader, psd: Psd, options: ReadOptionsExt) {\n\tlet globalAlpha = false;\n\n\treadSection(reader, 2, left => {\n\t\tlet layerCount = readInt16(reader);\n\n\t\tif (layerCount < 0) {\n\t\t\tglobalAlpha = true;\n\t\t\tlayerCount = -layerCount;\n\t\t}\n\n\t\tconst layers: Layer[] = [];\n\t\tconst layerChannels: ChannelInfo[][] = [];\n\n\t\tfor (let i = 0; i < layerCount; i++) {\n\t\t\tconst { layer, channels } = readLayerRecord(reader, psd, options);\n\t\t\tlayers.push(layer);\n\t\t\tlayerChannels.push(channels);\n\t\t}\n\n\t\tif (!options.skipLayerImageData) {\n\t\t\tfor (let i = 0; i < layerCount; i++) {\n\t\t\t\treadLayerChannelImageData(reader, psd, layers[i], layerChannels[i], options);\n\t\t\t}\n\t\t}\n\n\t\tskipBytes(reader, left());\n\n\t\tif (!psd.children) psd.children = [];\n\n\t\tconst stack: (Layer | Psd)[] = [psd];\n\n\t\tfor (let i = layers.length - 1; i >= 0; i--) {\n\t\t\tconst l = layers[i];\n\t\t\tconst type = l.sectionDivider ? l.sectionDivider.type : SectionDividerType.Other;\n\n\t\t\tif (type === SectionDividerType.OpenFolder || type === SectionDividerType.ClosedFolder) {\n\t\t\t\tl.opened = type === SectionDividerType.OpenFolder;\n\t\t\t\tl.children = [];\n\t\t\t\tstack[stack.length - 1].children!.unshift(l);\n\t\t\t\tstack.push(l);\n\t\t\t} else if (type === SectionDividerType.BoundingSectionDivider) {\n\t\t\t\tstack.pop();\n\t\t\t\t// this was workaround because I didn't know what `lsdk` section was, now it's probably not needed anymore\n\t\t\t\t// } else if (l.name === '</Layer group>' && !l.sectionDivider && !l.top && !l.left && !l.bottom && !l.right) {\n\t\t\t\t// \t// sometimes layer group terminator doesn't have sectionDivider, so we just guess here (PS bug ?)\n\t\t\t\t// \tstack.pop();\n\t\t\t} else {\n\t\t\t\tstack[stack.length - 1].children!.unshift(l);\n\t\t\t}\n\t\t}\n\t}, undefined, options.large);\n\n\treturn globalAlpha;\n}\n\nfunction readLayerRecord(reader: PsdReader, psd: Psd, options: ReadOptionsExt) {\n\tconst layer: Layer = {};\n\tlayer.top = readInt32(reader);\n\tlayer.left = readInt32(reader);\n\tlayer.bottom = readInt32(reader);\n\tlayer.right = readInt32(reader);\n\n\tconst channelCount = readUint16(reader);\n\tconst channels: ChannelInfo[] = [];\n\n\tfor (let i = 0; i < channelCount; i++) {\n\t\tlet channelID = readInt16(reader) as ChannelID;\n\t\tlet channelLength = readUint32(reader);\n\n\t\tif (options.large) {\n\t\t\tif (channelLength !== 0) throw new Error('Sizes larger than 4GB are not supported');\n\t\t\tchannelLength = readUint32(reader);\n\t\t}\n\n\t\tchannels.push({ id: channelID, length: channelLength });\n\t}\n\n\tcheckSignature(reader, '8BIM');\n\tconst blendMode = readSignature(reader);\n\tif (!toBlendMode[blendMode]) throw new Error(`Invalid blend mode: '${blendMode}'`);\n\tlayer.blendMode = toBlendMode[blendMode];\n\n\tlayer.opacity = readUint8(reader) / 0xff;\n\tlayer.clipping = readUint8(reader) === 1;\n\n\tconst flags = readUint8(reader);\n\tlayer.transparencyProtected = (flags & 0x01) !== 0;\n\tlayer.hidden = (flags & 0x02) !== 0;\n\t// 0x04 - obsolete\n\t// 0x08 - 1 for Photoshop 5.0 and later, tells if bit 4 has useful information\n\t// 0x10 - pixel data irrelevant to appearance of document\n\t// 0x20 - ???\n\t// if (flags & 0x20) (layer as any)._2 = true; // TEMP !!!!\n\n\tskipBytes(reader, 1);\n\n\treadSection(reader, 1, left => {\n\t\tconst mask = readLayerMaskData(reader, options);\n\t\tif (mask) layer.mask = mask;\n\n\t\t/*const blendingRanges =*/ readLayerBlendingRanges(reader);\n\t\tlayer.name = readPascalString(reader, 4);\n\n\t\twhile (left()) {\n\t\t\treadAdditionalLayerInfo(reader, layer, psd, options);\n\t\t}\n\t});\n\n\treturn { layer, channels };\n}\n\nfunction readLayerMaskData(reader: PsdReader, options: ReadOptions) {\n\treturn readSection<LayerMaskData | undefined>(reader, 1, left => {\n\t\tif (!left()) return undefined;\n\n\t\tconst mask: LayerMaskData = {};\n\t\tmask.top = readInt32(reader);\n\t\tmask.left = readInt32(reader);\n\t\tmask.bottom = readInt32(reader);\n\t\tmask.right = readInt32(reader);\n\t\tmask.defaultColor = readUint8(reader);\n\n\t\tconst flags = readUint8(reader);\n\t\tmask.positionRelativeToLayer = (flags & LayerMaskFlags.PositionRelativeToLayer) !== 0;\n\t\tmask.disabled = (flags & LayerMaskFlags.LayerMaskDisabled) !== 0;\n\t\tmask.fromVectorData = (flags & LayerMaskFlags.LayerMaskFromRenderingOtherData) !== 0;\n\n\t\tif (flags & LayerMaskFlags.MaskHasParametersAppliedToIt) {\n\t\t\tconst params = readUint8(reader);\n\t\t\tif (params & MaskParams.UserMaskDensity) mask.userMaskDensity = readUint8(reader) / 0xff;\n\t\t\tif (params & MaskParams.UserMaskFeather) mask.userMaskFeather = readFloat64(reader);\n\t\t\tif (params & MaskParams.VectorMaskDensity) mask.vectorMaskDensity = readUint8(reader) / 0xff;\n\t\t\tif (params & MaskParams.VectorMaskFeather) mask.vectorMaskFeather = readFloat64(reader);\n\t\t}\n\n\t\tif (left() > 2) {\n\t\t\toptions.logMissingFeatures && console.log('Unhandled extra mask params');\n\t\t\t// TODO: handle these values\n\t\t\t/*const realFlags =*/ readUint8(reader);\n\t\t\t/*const realUserMaskBackground =*/ readUint8(reader);\n\t\t\t/*const top2 =*/ readInt32(reader);\n\t\t\t/*const left2 =*/ readInt32(reader);\n\t\t\t/*const bottom2 =*/ readInt32(reader);\n\t\t\t/*const right2 =*/ readInt32(reader);\n\t\t}\n\n\t\tskipBytes(reader, left());\n\t\treturn mask;\n\t});\n}\n\nfunction readLayerBlendingRanges(reader: PsdReader) {\n\treturn readSection(reader, 1, left => {\n\t\tconst compositeGrayBlendSource = readUint32(reader);\n\t\tconst compositeGraphBlendDestinationRange = readUint32(reader);\n\t\tconst ranges = [];\n\n\t\twhile (left()) {\n\t\t\tconst sourceRange = readUint32(reader);\n\t\t\tconst destRange = readUint32(reader);\n\t\t\tranges.push({ sourceRange, destRange });\n\t\t}\n\n\t\treturn { compositeGrayBlendSource, compositeGraphBlendDestinationRange, ranges };\n\t});\n}\n\nfunction readLayerChannelImageData(\n\treader: PsdReader, psd: Psd, layer: Layer, channels: ChannelInfo[], options: ReadOptionsExt\n) {\n\tconst layerWidth = (layer.right || 0) - (layer.left || 0);\n\tconst layerHeight = (layer.bottom || 0) - (layer.top || 0);\n\tconst cmyk = psd.colorMode === ColorMode.CMYK;\n\n\tlet imageData: ImageData | undefined;\n\n\tif (layerWidth && layerHeight) {\n\t\tif (cmyk) {\n\t\t\timageData = { width: layerWidth, height: layerHeight, data: new Uint8ClampedArray(layerWidth * layerHeight * 5) } as any as ImageData;\n\t\t\tfor (let p = 4; p < imageData.data.byteLength; p += 5) imageData.data[p] = 255;\n\t\t} else {\n\t\t\timageData = createImageData(layerWidth, layerHeight);\n\t\t\tresetImageData(imageData);\n\t\t}\n\t}\n\n\tif (RAW_IMAGE_DATA) (layer as any).imageDataRaw = [];\n\n\tfor (const channel of channels) {\n\t\tif (channel.length === 0) continue;\n\t\tif (channel.length < 2) throw new Error('Invalid channel length');\n\n\t\tconst start = reader.offset;\n\t\tconst compression = readUint16(reader) as Compression;\n\n\t\tif (channel.id === ChannelID.UserMask) {\n\t\t\tconst mask = layer.mask;\n\n\t\t\tif (!mask) throw new Error(`Missing layer mask data`);\n\n\t\t\tconst maskWidth = (mask.right || 0) - (mask.left || 0);\n\t\t\tconst maskHeight = (mask.bottom || 0) - (mask.top || 0);\n\n\t\t\tif (maskWidth && maskHeight) {\n\t\t\t\tconst maskData = createImageData(maskWidth, maskHeight);\n\t\t\t\tresetImageData(maskData);\n\n\t\t\t\tconst start = reader.offset;\n\t\t\t\treadData(reader, channel.length, maskData, compression, maskWidth, maskHeight, 0, options.large, 4);\n\n\t\t\t\tif (RAW_IMAGE_DATA) {\n\t\t\t\t\t(layer as any).maskDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start, reader.offset - start);\n\t\t\t\t}\n\n\t\t\t\tsetupGrayscale(maskData);\n\n\t\t\t\tif (options.useImageData) {\n\t\t\t\t\tmask.imageData = maskData;\n\t\t\t\t} else {\n\t\t\t\t\tmask.canvas = createCanvas(maskWidth, maskHeight);\n\t\t\t\t\tmask.canvas.getContext('2d')!.putImageData(maskData, 0, 0);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tconst offset = offsetForChannel(channel.id, cmyk);\n\t\t\tlet targetData = imageData;\n\n\t\t\tif (offset < 0) {\n\t\t\t\ttargetData = undefined;\n\n\t\t\t\tif (options.throwForMissingFeatures) {\n\t\t\t\t\tthrow new Error(`Channel not supported: ${channel.id}`);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treadData(reader, channel.length, targetData, compression, layerWidth, layerHeight, offset, options.large, cmyk ? 5 : 4);\n\n\t\t\tif (RAW_IMAGE_DATA) {\n\t\t\t\t(layer as any).imageDataRaw[channel.id] = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start + 2, channel.length - 2);\n\t\t\t}\n\n\t\t\treader.offset = start + channel.length;\n\n\t\t\tif (targetData && psd.colorMode === ColorMode.Grayscale) {\n\t\t\t\tsetupGrayscale(targetData);\n\t\t\t}\n\t\t}\n\t}\n\n\tif (imageData) {\n\t\tif (cmyk) {\n\t\t\tconst cmykData = imageData;\n\t\t\timageData = createImageData(cmykData.width, cmykData.height);\n\t\t\tcmykToRgb(cmykData, imageData, false);\n\t\t}\n\n\t\tif (options.useImageData) {\n\t\t\tlayer.imageData = imageData;\n\t\t} else {\n\t\t\tlayer.canvas = createCanvas(layerWidth, layerHeight);\n\t\t\tlayer.canvas.getContext('2d')!.putImageData(imageData, 0, 0);\n\t\t}\n\t}\n}\n\nfunction readData(\n\treader: PsdReader, length: number, data: ImageData | undefined, compression: Compression, width: number, height: number,\n\toffset: number, large: boolean, step: number\n) {\n\tif (compression === Compression.RawData) {\n\t\treadDataRaw(reader, data, width, height, step, offset);\n\t} else if (compression === Compression.RleCompressed) {\n\t\treadDataRLE(reader, data, width, height, step, [offset], large);\n\t} else if (compression === Compression.ZipWithoutPrediction) {\n\t\treadDataZipWithoutPrediction(reader, length, data, width, height, step, offset);\n\t} else if (compression === Compression.ZipWithPrediction) {\n\t\tthrow new Error(`Compression type not supported: ${compression}`);\n\t} else {\n\t\tthrow new Error(`Invalid Compression type: ${compression}`);\n\t}\n}\n\nfunction readGlobalLayerMaskInfo(reader: PsdReader) {\n\treturn readSection<GlobalLayerMaskInfo | undefined>(reader, 1, left => {\n\t\tif (!left()) return undefined;\n\n\t\tconst overlayColorSpace = readUint16(reader);\n\t\tconst colorSpace1 = readUint16(reader);\n\t\tconst colorSpace2 = readUint16(reader);\n\t\tconst colorSpace3 = readUint16(reader);\n\t\tconst colorSpace4 = readUint16(reader);\n\t\tconst opacity = readUint16(reader) / 0xff;\n\t\tconst kind = readUint8(reader);\n\t\tskipBytes(reader, left()); // 3 bytes of padding ?\n\t\treturn { overlayColorSpace, colorSpace1, colorSpace2, colorSpace3, colorSpace4, opacity, kind };\n\t});\n}\n\nfunction readAdditionalLayerInfo(reader: PsdReader, target: LayerAdditionalInfo, psd: Psd, options: ReadOptionsExt) {\n\tconst sig = readSignature(reader);\n\tif (sig !== '8BIM' && sig !== '8B64') throw new Error(`Invalid signature: '${sig}' at 0x${(reader.offset - 4).toString(16)}`);\n\tconst key = readSignature(reader);\n\n\t// `largeAdditionalInfoKeys` fallback, because some keys don't have 8B64 signature even when they are 64bit\n\tconst u64 = sig === '8B64' || (options.large && largeAdditionalInfoKeys.indexOf(key) !== -1);\n\n\treadSection(reader, 2, left => {\n\t\tconst handler = infoHandlersMap[key];\n\n\t\tif (handler) {\n\t\t\ttry {\n\t\t\t\thandler.read(reader, target, left, psd, options);\n\t\t\t} catch (e) {\n\t\t\t\tif (options.throwForMissingFeatures) throw e;\n\t\t\t}\n\t\t} else {\n\t\t\toptions.logMissingFeatures && console.log(`Unhandled additional info: ${key}`);\n\t\t\tskipBytes(reader, left());\n\t\t}\n\n\t\tif (left()) {\n\t\t\toptions.logMissingFeatures && console.log(`Unread ${left()} bytes left for additional info: ${key}`);\n\t\t\tskipBytes(reader, left());\n\t\t}\n\t}, false, u64);\n}\n\nfunction readImageData(reader: PsdReader, psd: Psd, globalAlpha: boolean, options: ReadOptionsExt) {\n\tconst compression = readUint16(reader) as Compression;\n\n\tif (supportedColorModes.indexOf(psd.colorMode!) === -1)\n\t\tthrow new Error(`Color mode not supported: ${psd.colorMode}`);\n\n\tif (compression !== Compression.RawData && compression !== Compression.RleCompressed)\n\t\tthrow new Error(`Compression type not supported: ${compression}`);\n\n\tconst imageData = createImageData(psd.width, psd.height);\n\tresetImageData(imageData);\n\n\tswitch (psd.colorMode) {\n\t\tcase ColorMode.Bitmap: {\n\t\t\tlet bytes: Uint8Array;\n\n\t\t\tif (compression === Compression.RawData) {\n\t\t\t\tbytes = readBytes(reader, Math.ceil(psd.width / 8) * psd.height);\n\t\t\t} else if (compression === Compression.RleCompressed) {\n\t\t\t\tbytes = new Uint8Array(psd.width * psd.height);\n\t\t\t\treadDataRLE(reader, { data: bytes, width: psd.width, height: psd.height }, psd.width, psd.height, 1, [0], options.large);\n\t\t\t} else {\n\t\t\t\tthrow new Error(`Bitmap compression not supported: ${compression}`);\n\t\t\t}\n\n\t\t\tdecodeBitmap(bytes, imageData.data, psd.width, psd.height);\n\t\t\tbreak;\n\t\t}\n\t\tcase ColorMode.RGB:\n\t\tcase ColorMode.Grayscale: {\n\t\t\tconst channels = psd.colorMode === ColorMode.Grayscale ? [0] : [0, 1, 2];\n\n\t\t\tif (psd.channels && psd.channels > 3) {\n\t\t\t\tfor (let i = 3; i < psd.channels; i++) {\n\t\t\t\t\t// TODO: store these channels in additional image data\n\t\t\t\t\tchannels.push(i);\n\t\t\t\t}\n\t\t\t} else if (globalAlpha) {\n\t\t\t\tchannels.push(3);\n\t\t\t}\n\n\t\t\tif (compression === Compression.RawData) {\n\t\t\t\tfor (let i = 0; i < channels.length; i++) {\n\t\t\t\t\treadDataRaw(reader, imageData, psd.width, psd.height, 4, channels[i]);\n\t\t\t\t}\n\t\t\t} else if (compression === Compression.RleCompressed) {\n\t\t\t\tconst start = reader.offset;\n\t\t\t\treadDataRLE(reader, imageData, psd.width, psd.height, 4, channels, options.large);\n\t\t\t\tif (RAW_IMAGE_DATA) (psd as any).imageDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start, reader.offset - start);\n\t\t\t}\n\n\t\t\tif (psd.colorMode === ColorMode.Grayscale) {\n\t\t\t\tsetupGrayscale(imageData);\n\t\t\t}\n\t\t\tbreak;\n\t\t}\n\t\tcase ColorMode.CMYK: {\n\t\t\tif (psd.channels !== 4) throw new Error(`Invalid channel count`);\n\n\t\t\tconst channels = [0, 1, 2, 3];\n\t\t\tif (globalAlpha) channels.push(4);\n\n\t\t\tif (compression === Compression.RawData) {\n\t\t\t\tthrow new Error(`Not implemented`);\n\t\t\t\t// TODO: ...\n\t\t\t\t// for (let i = 0; i < channels.length; i++) {\n\t\t\t\t// \treadDataRaw(reader, imageData, channels[i], psd.width, psd.height);\n\t\t\t\t// }\n\t\t\t} else if (compression === Compression.RleCompressed) {\n\t\t\t\tconst cmykImageData: PixelData = {\n\t\t\t\t\twidth: imageData.width,\n\t\t\t\t\theight: imageData.height,\n\t\t\t\t\tdata: new Uint8Array(imageData.width * imageData.height * 5),\n\t\t\t\t};\n\n\t\t\t\tconst start = reader.offset;\n\t\t\t\treadDataRLE(reader, cmykImageData, psd.width, psd.height, 5, channels, options.large);\n\t\t\t\tcmykToRgb(cmykImageData, imageData, true);\n\n\t\t\t\tif (RAW_IMAGE_DATA) (psd as any).imageDataRaw = new Uint8Array(reader.view.buffer, reader.view.byteOffset + start, reader.offset - start);\n\t\t\t}\n\n\t\t\tbreak;\n\t\t}\n\t\tdefault: throw new Error(`Color mode not supported: ${psd.colorMode}`);\n\t}\n\n\tif (options.useImageData) {\n\t\tpsd.imageData = imageData;\n\t} else {\n\t\tpsd.canvas = createCanvas(psd.width, psd.height);\n\t\tpsd.canvas.getContext('2d')!.putImageData(imageData, 0, 0);\n\t}\n}\n\nfunction cmykToRgb(cmyk: PixelData, rgb: PixelData, reverseAlpha: boolean) {\n\tconst size = rgb.width * rgb.height * 4;\n\tconst srcData = cmyk.data;\n\tconst dstData = rgb.data;\n\n\tfor (let src = 0, dst = 0; dst < size; src += 5, dst += 4) {\n\t\tconst c = srcData[src];\n\t\tconst m = srcData[src + 1];\n\t\tconst y = srcData[src + 2];\n\t\tconst k = srcData[src + 3];\n\t\tdstData[dst] = ((((c * k) | 0) / 255) | 0);\n\t\tdstData[dst + 1] = ((((m * k) | 0) / 255) | 0);\n\t\tdstData[dst + 2] = ((((y * k) | 0) / 255) | 0);\n\t\tdstData[dst + 3] = reverseAlpha ? 255 - srcData[src + 4] : srcData[src + 4];\n\t}\n\n\t// for (let src = 0, dst = 0; dst < size; src += 5, dst += 4) {\n\t// \tconst c = 1 - (srcData[src + 0] / 255);\n\t// \tconst m = 1 - (srcData[src + 1] / 255);\n\t// \tconst y = 1 - (srcData[src + 2] / 255);\n\t// \t// const k = srcData[src + 3] / 255;\n\t// \tdstData[dst + 0] = ((1 - c * 0.8) * 255) | 0;\n\t// \tdstData[dst + 1] = ((1 - m * 0.8) * 255) | 0;\n\t// \tdstData[dst + 2] = ((1 - y * 0.8) * 255) | 0;\n\t// \tdstData[dst + 3] = reverseAlpha ? 255 - srcData[src + 4] : srcData[src + 4];\n\t// }\n}\n\nfunction readDataRaw(reader: PsdReader, pixelData: PixelData | undefined, width: number, height: number, step: number, offset: number) {\n\tconst size = width * height;\n\tconst buffer = readBytes(reader, size);\n\n\tif (pixelData && offset < step) {\n\t\tconst data = pixelData.data;\n\n\t\tfor (let i = 0, p = offset | 0; i < size; i++, p = (p + step) | 0) {\n\t\t\tdata[p] = buffer[i];\n\t\t}\n\t}\n}\n\nexport function readDataZipWithoutPrediction(\n\treader: PsdReader, length: number, pixelData: PixelData | undefined, width: number, height: number,\n\tstep: number, offset: number\n) {\n\tconst compressed = readBytes(reader, length);\n\tconst decompressed = inflate(compressed);\n\tconst size = width * height;\n\n\tif (pixelData && offset < step) {\n\t\tconst data = pixelData.data;\n\n\t\tfor (let i = 0, p = offset | 0; i < size; i++, p = (p + step) | 0) {\n\t\t\tdata[p] = decompressed[i];\n\t\t}\n\t}\n}\n\nexport function readDataRLE(\n\treader: PsdReader, pixelData: PixelData | undefined, _width: number, height: number, step: number, offsets: number[],\n\tlarge: boolean\n) {\n\tconst data = pixelData && pixelData.data;\n\tlet lengths: Uint16Array | Uint32Array;\n\n\tif (large) {\n\t\tlengths = new Uint32Array(offsets.length * height);\n\n\t\tfor (let o = 0, li = 0; o < offsets.length; o++) {\n\t\t\tfor (let y = 0; y < height; y++, li++) {\n\t\t\t\tlengths[li] = readUint32(reader);\n\t\t\t}\n\t\t}\n\t} else {\n\t\tlengths = new Uint16Array(offsets.length * height);\n\n\t\tfor (let o = 0, li = 0; o < offsets.length; o++) {\n\t\t\tfor (let y = 0; y < height; y++, li++) {\n\t\t\t\tlengths[li] = readUint16(reader);\n\t\t\t}\n\t\t}\n\t}\n\n\tconst extraLimit = (step - 1) | 0; // 3 for rgb, 4 for cmyk\n\n\tfor (let c = 0, li = 0; c < offsets.length; c++) {\n\t\tconst offset = offsets[c] | 0;\n\t\tconst extra = c > extraLimit || offset > extraLimit;\n\n\t\tif (!data || extra) {\n\t\t\tfor (let y = 0; y < height; y++, li++) {\n\t\t\t\tskipBytes(reader, lengths[li]);\n\t\t\t}\n\t\t} else {\n\t\t\tfor (let y = 0, p = offset | 0; y < height; y++, li++) {\n\t\t\t\tconst length = lengths[li];\n\t\t\t\tconst buffer = readBytes(reader, length);\n\n\t\t\t\tfor (let i = 0; i < length; i++) {\n\t\t\t\t\tlet header = buffer[i];\n\n\t\t\t\t\tif (header > 128) {\n\t\t\t\t\t\tconst value = buffer[++i];\n\t\t\t\t\t\theader = (256 - header) | 0;\n\n\t\t\t\t\t\tfor (let j = 0; j <= header; j = (j + 1) | 0) {\n\t\t\t\t\t\t\tdata[p] = value;\n\t\t\t\t\t\t\tp = (p + step) | 0;\n\t\t\t\t\t\t}\n\t\t\t\t\t} else if (header < 128) {\n\t\t\t\t\t\tfor (let j = 0; j <= header; j = (j + 1) | 0) {\n\t\t\t\t\t\t\tdata[p] = buffer[++i];\n\t\t\t\t\t\t\tp = (p + step) | 0;\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// ignore 128\n\t\t\t\t\t}\n\n\t\t\t\t\t// This showed up on some images from non-photoshop programs, ignoring it seems to work just fine.\n\t\t\t\t\t// if (i >= length) throw new Error(`Invalid RLE data: exceeded buffer size ${i}/${length}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport function readSection<T>(\n\treader: PsdReader, round: number, func: (left: () => number) => T, skipEmpty = true, eightBytes = false\n): T | undefined {\n\tlet length = readUint32(reader);\n\n\tif (eightBytes) {\n\t\tif (length !== 0) throw new Error('Sizes larger than 4GB are not supported');\n\t\tlength = readUint32(reader);\n\t}\n\n\tif (length <= 0 && skipEmpty) return undefined;\n\n\tlet end = reader.offset + length;\n\tif (end > reader.view.byteLength) throw new Error('Section exceeds file size');\n\n\tconst result = func(() => end - reader.offset);\n\n\tif (reader.offset !== end) {\n\t\tif (reader.offset > end) {\n\t\t\twarnOrThrow(reader, 'Exceeded section limits');\n\t\t} else {\n\t\t\twarnOrThrow(reader, `Unread section data`); // : ${end - reader.offset} bytes at 0x${reader.offset.toString(16)}`);\n\t\t}\n\t}\n\n\twhile (end % round) end++;\n\treader.offset = end;\n\n\treturn result;\n}\n\nexport function readColor(reader: PsdReader): Color {\n\tconst colorSpace = readUint16(reader) as ColorSpace;\n\n\tswitch (colorSpace) {\n\t\tcase ColorSpace.RGB: {\n\t\t\tconst r = readUint16(reader) / 257;\n\t\t\tconst g = readUint16(reader) / 257;\n\t\t\tconst b = readUint16(reader) / 257;\n\t\t\tskipBytes(reader, 2);\n\t\t\treturn { r, g, b };\n\t\t}\n\t\tcase ColorSpace.HSB: {\n\t\t\tconst h = readUint16(reader) / 0xffff;\n\t\t\tconst s = readUint16(reader) / 0xffff;\n\t\t\tconst b = readUint16(reader) / 0xffff;\n\t\t\tskipBytes(reader, 2);\n\t\t\treturn { h, s, b };\n\t\t}\n\t\tcase ColorSpace.CMYK: {\n\t\t\tconst c = readUint16(reader) / 257;\n\t\t\tconst m = readUint16(reader) / 257;\n\t\t\tconst y = readUint16(reader) / 257;\n\t\t\tconst k = readUint16(reader) / 257;\n\t\t\treturn { c, m, y, k };\n\t\t}\n\t\tcase ColorSpace.Lab: {\n\t\t\tconst l = readInt16(reader) / 10000;\n\t\t\tconst ta = readInt16(reader);\n\t\t\tconst tb = readInt16(reader);\n\t\t\tconst a = ta < 0 ? (ta / 12800) : (ta / 12700);\n\t\t\tconst b = tb < 0 ? (tb / 12800) : (tb / 12700);\n\t\t\tskipBytes(reader, 2);\n\t\t\treturn { l, a, b };\n\t\t}\n\t\tcase ColorSpace.Grayscale: {\n\t\t\tconst k = readUint16(reader) * 255 / 10000;\n\t\t\tskipBytes(reader, 6);\n\t\t\treturn { k };\n\t\t}\n\t\tdefault:\n\t\t\tthrow new Error('Invalid color space');\n\t}\n}\n\nexport function readPattern(reader: PsdReader): PatternInfo {\n\treadUint32(reader); // length\n\tconst version = readUint32(reader);\n\tif (version !== 1) throw new Error(`Invalid pattern version: ${version}`);\n\n\tconst colorMode = readUint32(reader) as ColorMode;\n\tconst x = readInt16(reader);\n\tconst y = readInt16(reader);\n\n\t// we only support RGB and grayscale for now\n\tif (colorMode !== ColorMode.RGB && colorMode !== ColorMode.Grayscale && colorMode !== ColorMode.Indexed) {\n\t\tthrow new Error(`Unsupported pattern color mode: ${colorMode}`);\n\t}\n\n\tlet name = readUnicodeString(reader);\n\tconst id = readPascalString(reader, 1);\n\tconst palette: RGB[] = [];\n\n\tif (colorMode === ColorMode.Indexed) {\n\t\tfor (let i = 0; i < 256; i++) {\n\t\t\tpalette.push({\n\t\t\t\tr: readUint8(reader),\n\t\t\t\tg: readUint8(reader),\n\t\t\t\tb: readUint8(reader),\n\t\t\t})\n\t\t}\n\n\t\tskipBytes(reader, 4); // no idea what this is\n\t}\n\n\t// virtual memory array list\n\tconst version2 = readUint32(reader);\n\tif (version2 !== 3) throw new Error(`Invalid pattern VMAL version: ${version2}`);\n\n\treadUint32(reader); // length\n\tconst top = readUint32(reader);\n\tconst left = readUint32(reader);\n\tconst bottom = readUint32(reader);\n\tconst right = readUint32(reader);\n\tconst channelsCount = readUint32(reader);\n\tconst width = right - left;\n\tconst height = bottom - top;\n\tconst data = new Uint8Array(width * height * 4);\n\n\tfor (let i = 3; i < data.byteLength; i += 4) {\n\t\tdata[i] = 255;\n\t}\n\n\tfor (let i = 0, ch = 0; i < (channelsCount + 2); i++) {\n\t\tconst has = readUint32(reader);\n\t\tif (!has) continue;\n\n\t\tconst length = readUint32(reader);\n\t\tconst pixelDepth = readUint32(reader);\n\t\tconst ctop = readUint32(reader);\n\t\tconst cleft = readUint32(reader);\n\t\tconst cbottom = readUint32(reader);\n\t\tconst cright = readUint32(reader);\n\t\tconst pixelDepth2 = readUint16(reader);\n\t\tconst compressionMode = readUint8(reader); // 0 - raw, 1 - zip\n\t\tconst dataLength = length - (4 + 16 + 2 + 1);\n\t\tconst cdata = readBytes(reader, dataLength);\n\n\t\tif (pixelDepth !== 8 || pixelDepth2 !== 8) {\n\t\t\tthrow new Error('16bit pixel depth not supported for patterns');\n\t\t}\n\n\t\tconst w = cright - cleft;\n\t\tconst h = cbottom - ctop;\n\t\tconst ox = cleft - left;\n\t\tconst oy = ctop - top;\n\n\t\tif (compressionMode === 0) {\n\t\t\tif (colorMode === ColorMode.RGB && ch < 3) {\n\t\t\t\tfor (let y = 0; y < h; y++) {\n\t\t\t\t\tfor (let x = 0; x < w; x++) {\n\t\t\t\t\t\tconst src = x + y * w;\n\t\t\t\t\t\tconst dst = (ox + x + (y + oy) * width) * 4;\n\t\t\t\t\t\tdata[dst + ch] = cdata[src];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (colorMode === ColorMode.Grayscale && ch < 1) {\n\t\t\t\tfor (let y = 0; y < h; y++) {\n\t\t\t\t\tfor (let x = 0; x < w; x++) {\n\t\t\t\t\t\tconst src = x + y * w;\n\t\t\t\t\t\tconst dst = (ox + x + (y + oy) * width) * 4;\n\t\t\t\t\t\tconst value = cdata[src];\n\t\t\t\t\t\tdata[dst + 0] = value;\n\t\t\t\t\t\tdata[dst + 1] = value;\n\t\t\t\t\t\tdata[dst + 2] = value;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (colorMode === ColorMode.Indexed) {\n\t\t\t\t// TODO:\n\t\t\t\tthrow new Error('Indexed pattern color mode not implemented');\n\t\t\t}\n\t\t} else if (compressionMode === 1) {\n\t\t\t// console.log({ colorMode });\n\t\t\t// require('fs').writeFileSync('zip.bin', Buffer.from(cdata));\n\t\t\t// const data = require('zlib').inflateRawSync(cdata);\n\t\t\t// const data = require('zlib').unzipSync(cdata);\n\t\t\t// console.log(data);\n\t\t\t// throw new Error('Zip compression not supported for pattern');\n\t\t\t// throw new Error('Unsupported pattern compression');\n\t\t\tconsole.error('Unsupported pattern compression');\n\t\t\tname += ' (failed to decode)';\n\t\t} else {\n\t\t\tthrow new Error('Invalid pattern compression mode');\n\t\t}\n\n\t\tch++;\n\t}\n\n\t// TODO: use canvas instead of data ?\n\n\treturn { id, name, x, y, bounds: { x: left, y: top, w: width, h: height }, data };\n}\n"],"sourceRoot":"C:\\Projects\\github\\ag-psd\\src"}
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