ag-psd 15.0.0 → 15.0.2

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