@cogeotiff/core 6.0.2 → 7.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/cog.tiff.js CHANGED
@@ -26,23 +26,23 @@ export class CogTiff {
26
26
  *
27
27
  * @param loadGeoKeys Whether to also initialize the GeoKeyDirectory
28
28
  */
29
- init(loadGeoKeys = false, logger) {
29
+ init(loadGeoKeys = false) {
30
30
  if (this._initPromise)
31
31
  return this._initPromise;
32
- this._initPromise = this.doInit(loadGeoKeys, logger);
32
+ this._initPromise = this.doInit(loadGeoKeys);
33
33
  return this._initPromise;
34
34
  }
35
- async doInit(loadGeoKeys = false, logger) {
35
+ async doInit(loadGeoKeys = false) {
36
36
  if (this.isInitialized)
37
37
  return this;
38
38
  // Load the first few KB in, more loads will run as more data is required
39
- await this.source.loadBytes(0, this.source.chunkSize, logger);
40
- await this.fetchIfd(logger);
41
- await Promise.all(this.images.map((c) => c.init(loadGeoKeys, logger)));
39
+ await this.source.loadBytes(0, this.source.chunkSize);
40
+ await this.fetchIfd();
41
+ await Promise.all(this.images.map((c) => c.init(loadGeoKeys)));
42
42
  this.isInitialized = true;
43
43
  return this;
44
44
  }
45
- async fetchIfd(logger) {
45
+ async fetchIfd() {
46
46
  const view = this.cursor.seekTo(0);
47
47
  const endian = view.uint16();
48
48
  this.source.isLittleEndian = endian === TiffEndian.Little;
@@ -69,10 +69,13 @@ export class CogTiff {
69
69
  const ghostSize = nextOffsetIfd - this.cursor.currentOffset;
70
70
  // GDAL now stores metadata between the IFD inside a ghost storage area
71
71
  if (ghostSize > 0 && ghostSize < 16 * 1024) {
72
- logger === null || logger === void 0 ? void 0 : logger.debug({ offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) }, 'GhostOptions');
72
+ // logger?.debug(
73
+ // { offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) },
74
+ // 'GhostOptions',
75
+ // );
73
76
  // this.options.process(this.source, view.currentOffset, ghostSize);
74
77
  }
75
- return this.processIfd(nextOffsetIfd, logger);
78
+ return this.processIfd(nextOffsetIfd);
76
79
  }
77
80
  getImage(z) {
78
81
  return this.images[z];
@@ -116,58 +119,27 @@ export class CogTiff {
116
119
  throw new Error('Tif is not tiled');
117
120
  return image.getTile(x, y);
118
121
  }
119
- async processIfd(offset, logger) {
120
- logger === null || logger === void 0 ? void 0 : logger.trace({ offset: toHexString(offset) }, 'NextImageOffset');
121
- if (!this.source.hasBytes(offset, 4096)) {
122
- await this.source.loadBytes(offset, 4096, logger);
123
- }
124
- const { image, nextOffset } = await this.readIfd(offset, logger);
122
+ async processIfd(offset) {
123
+ if (!this.source.hasBytes(offset, 4096))
124
+ await this.source.loadBytes(offset, 4096);
125
+ const { image, nextOffset } = await this.readIfd(offset);
125
126
  this.images.push(image);
126
- const size = image.size;
127
- if (image.isTiled()) {
128
- const tile = image.tileSize;
129
- logger === null || logger === void 0 ? void 0 : logger.debug({
130
- ...size,
131
- tileWidth: tile.width,
132
- tileHeight: tile.height,
133
- tileCount: Math.ceil(size.width / tile.width),
134
- }, 'GotImage');
135
- }
136
127
  if (nextOffset)
137
- await this.processIfd(nextOffset, logger);
128
+ await this.processIfd(nextOffset);
138
129
  }
139
- async readIfd(offset, log) {
130
+ async readIfd(offset) {
140
131
  if (!this.source.hasBytes(offset, 1024))
141
- await this.source.loadBytes(offset, this.source.chunkSize, log);
132
+ await this.source.loadBytes(offset, this.source.chunkSize);
142
133
  const view = this.cursor.seekTo(offset);
143
134
  const tagCount = view.offset();
144
135
  const byteStart = offset + this.ifdConfig.offset;
145
- const logger = log === null || log === void 0 ? void 0 : log.child({ imageId: this.images.length });
146
136
  const tags = new Map();
147
137
  let pos = byteStart;
148
138
  for (let i = 0; i < tagCount; i++) {
149
139
  const tag = CogTiffTag.create(this, pos);
150
140
  pos += tag.size;
151
- if (tag.name == null) {
152
- logger === null || logger === void 0 ? void 0 : logger.error({ code: toHexString(tag.id) }, `IFDUnknown`);
153
- continue;
154
- }
155
- if (!tag.isReady) {
156
- logger === null || logger === void 0 ? void 0 : logger.trace({
157
- offset: toHexString(pos - offset),
158
- code: toHexString(tag.id),
159
- tagName: tag.name,
160
- ptr: toHexString(tag.valuePointer),
161
- }, 'PartialReadIFD');
162
- }
163
- else {
164
- logger === null || logger === void 0 ? void 0 : logger.trace({
165
- offset: toHexString(pos - offset),
166
- code: toHexString(tag.id),
167
- tagName: tag.name,
168
- value: Array.isArray(tag.value) ? `[${tag.value.length}]` : tag.value,
169
- }, 'ReadIFD');
170
- }
141
+ if (tag.name == null)
142
+ throw new Error('Unknown IFD Tag: ' + toHexString(tag.id));
171
143
  tags.set(tag.id, tag);
172
144
  }
173
145
  const image = new CogTiffImage(this, this.images.length, tags);
@@ -180,4 +152,4 @@ export class CogTiff {
180
152
  await ((_b = (_a = this.source) === null || _a === void 0 ? void 0 : _a.close) === null || _b === void 0 ? void 0 : _b.call(_a));
181
153
  }
182
154
  }
183
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cog.tiff.js","sourceRoot":"","sources":["../src/cog.tiff.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChunkSource, LogType } from '@chunkd/core';\nimport { CogTiffImage } from './cog.tiff.image.js';\nimport { TiffEndian } from './const/tiff.endian.js';\nimport { TiffTag } from './const/tiff.tag.id.js';\nimport { TiffVersion } from './const/tiff.version.js';\nimport { CogTiffTagBase } from './read/tag/tiff.tag.base.js';\nimport { CogTifGhostOptions } from './read/tiff.gdal.js';\nimport { TagTiffBigConfig, TagTiffConfig, TiffIfdConfig } from './read/tiff.ifd.config.js';\nimport { CogTiffTag } from './read/tiff.tag.js';\nimport { CogSourceCursor } from './source/cog.source.view.js';\nimport { toHexString } from './util/util.hex.js';\n\nexport class CogTiff {\n    source: ChunkSource;\n    version = TiffVersion.Tiff;\n    images: CogTiffImage[] = [];\n    options = new CogTifGhostOptions();\n\n    private cursor: CogSourceCursor;\n    ifdConfig: TiffIfdConfig = TagTiffConfig;\n\n    constructor(source: ChunkSource) {\n        this.source = source;\n        this.cursor = new CogSourceCursor(this);\n    }\n\n    /** Create and initialize a CogTiff */\n    static create(source: ChunkSource): Promise<CogTiff> {\n        return new CogTiff(source).init();\n    }\n\n    /** Has init() been called */\n    isInitialized = false;\n\n    _initPromise?: Promise<CogTiff>;\n    /**\n     * Initialize the COG loading in the header and all image headers\n     *\n     * @param loadGeoKeys Whether to also initialize the GeoKeyDirectory\n     */\n    init(loadGeoKeys = false, logger?: LogType): Promise<CogTiff> {\n        if (this._initPromise) return this._initPromise;\n        this._initPromise = this.doInit(loadGeoKeys, logger);\n        return this._initPromise;\n    }\n\n    private async doInit(loadGeoKeys = false, logger?: LogType): Promise<CogTiff> {\n        if (this.isInitialized) return this;\n        // Load the first few KB in, more loads will run as more data is required\n        await this.source.loadBytes(0, this.source.chunkSize, logger);\n        await this.fetchIfd(logger);\n        await Promise.all(this.images.map((c) => c.init(loadGeoKeys, logger)));\n\n        this.isInitialized = true;\n        return this;\n    }\n\n    private async fetchIfd(logger?: LogType): Promise<void> {\n        const view = this.cursor.seekTo(0);\n        const endian = view.uint16();\n        this.source.isLittleEndian = endian === TiffEndian.Little;\n        if (!this.source.isLittleEndian) throw new Error('Only little endian is supported');\n        this.version = view.uint16();\n\n        let nextOffsetIfd: number;\n        if (this.version === TiffVersion.BigTiff) {\n            this.ifdConfig = TagTiffBigConfig;\n            const pointerSize = view.uint16();\n            if (pointerSize !== 8) throw new Error('Only 8byte pointers are supported');\n            const zeros = view.uint16();\n            if (zeros !== 0) throw new Error('Invalid big tiff header');\n            nextOffsetIfd = view.pointer();\n        } else if (this.version === TiffVersion.Tiff) {\n            nextOffsetIfd = view.pointer();\n        } else {\n            throw new Error(`Only tiff supported version:${this.version}`);\n        }\n\n        const ghostSize = nextOffsetIfd - this.cursor.currentOffset;\n        // GDAL now stores metadata between the IFD inside a ghost storage area\n        if (ghostSize > 0 && ghostSize < 16 * 1024) {\n            logger?.debug(\n                { offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) },\n                'GhostOptions',\n            );\n            // this.options.process(this.source, view.currentOffset, ghostSize);\n        }\n\n        return this.processIfd(nextOffsetIfd, logger);\n    }\n\n    getImage(z: number): CogTiffImage {\n        return this.images[z];\n    }\n\n    /**\n     * Find a image which has a resolution similar to the provided resolution\n     *\n     * @param resolution resolution to find\n     */\n    getImageByResolution(resolution: number): CogTiffImage {\n        const firstImage = this.images[0];\n        const firstImageSize = firstImage.size;\n        const [refX] = firstImage.resolution;\n\n        const resolutionBaseX = refX * firstImageSize.width;\n        // const resolutionBaseY = refY * firstImageSize.height;\n        for (let i = this.images.length - 1; i > 0; i--) {\n            const img = this.images[i];\n            const imgSize = img.size;\n\n            const imgResolutionX = resolutionBaseX / imgSize.width;\n            // TODO do we care about y resolution\n            // const imgResolutionY = resolutionBaseY / imgSize.height;\n\n            if (imgResolutionX - resolution <= 0.01) return img;\n        }\n        return firstImage;\n    }\n\n    /**\n     * Get the raw bytes for a tile at a given x,y, index.\n     *\n     * This may return null if the tile does not exist eg Sparse cogs,\n     *\n     * @param x tile x index\n     * @param y tile y index\n     * @param index image index\n     */\n    async getTile(x: number, y: number, index: number): Promise<{ mimeType: string; bytes: Uint8Array } | null> {\n        const image = this.getImage(index);\n        if (image == null) throw new Error(`Missing z: ${index}`);\n        if (!image.isTiled()) throw new Error('Tif is not tiled');\n\n        return image.getTile(x, y);\n    }\n\n    private async processIfd(offset: number, logger?: LogType): Promise<void> {\n        logger?.trace({ offset: toHexString(offset) }, 'NextImageOffset');\n\n        if (!this.source.hasBytes(offset, 4096)) {\n            await this.source.loadBytes(offset, 4096, logger);\n        }\n\n        const { image, nextOffset } = await this.readIfd(offset, logger);\n        this.images.push(image);\n        const size = image.size;\n        if (image.isTiled()) {\n            const tile = image.tileSize;\n            logger?.debug(\n                {\n                    ...size,\n                    tileWidth: tile.width,\n                    tileHeight: tile.height,\n                    tileCount: Math.ceil(size.width / tile.width),\n                },\n                'GotImage',\n            );\n        }\n\n        if (nextOffset) await this.processIfd(nextOffset, logger);\n    }\n\n    private async readIfd(offset: number, log?: LogType): Promise<{ nextOffset: number; image: CogTiffImage }> {\n        if (!this.source.hasBytes(offset, 1024)) await this.source.loadBytes(offset, this.source.chunkSize, log);\n        const view = this.cursor.seekTo(offset);\n        const tagCount = view.offset();\n        const byteStart = offset + this.ifdConfig.offset;\n        const logger = log?.child({ imageId: this.images.length });\n        const tags: Map<TiffTag, CogTiffTagBase> = new Map();\n\n        let pos = byteStart;\n        for (let i = 0; i < tagCount; i++) {\n            const tag = CogTiffTag.create(this, pos);\n            pos += tag.size;\n\n            if (tag.name == null) {\n                logger?.error({ code: toHexString(tag.id) }, `IFDUnknown`);\n                continue;\n            }\n\n            if (!tag.isReady) {\n                logger?.trace(\n                    {\n                        offset: toHexString(pos - offset),\n                        code: toHexString(tag.id),\n                        tagName: tag.name,\n                        ptr: toHexString(tag.valuePointer),\n                    },\n                    'PartialReadIFD',\n                );\n            } else {\n                logger?.trace(\n                    {\n                        offset: toHexString(pos - offset),\n                        code: toHexString(tag.id),\n                        tagName: tag.name,\n                        value: Array.isArray(tag.value) ? `[${tag.value.length}]` : tag.value,\n                    },\n                    'ReadIFD',\n                );\n            }\n\n            tags.set(tag.id, tag);\n        }\n\n        const image = new CogTiffImage(this, this.images.length, tags);\n        const nextOffset = this.source.getUint(pos, this.ifdConfig.pointer);\n        return { nextOffset, image };\n    }\n\n    /** Close the file source if it needs closing */\n    async close(): Promise<void> {\n        await this.source?.close?.();\n    }\n}\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cog.tiff.js","sourceRoot":"","sources":["../src/cog.tiff.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChunkSource } from '@chunkd/core';\nimport { CogTiffImage } from './cog.tiff.image.js';\nimport { TiffEndian } from './const/tiff.endian.js';\nimport { TiffTag } from './const/tiff.tag.id.js';\nimport { TiffVersion } from './const/tiff.version.js';\nimport { CogTiffTagBase } from './read/tag/tiff.tag.base.js';\nimport { CogTifGhostOptions } from './read/tiff.gdal.js';\nimport { TagTiffBigConfig, TagTiffConfig, TiffIfdConfig } from './read/tiff.ifd.config.js';\nimport { CogTiffTag } from './read/tiff.tag.js';\nimport { CogSourceCursor } from './source/cog.source.view.js';\nimport { toHexString } from './util/util.hex.js';\n\nexport class CogTiff {\n    source: ChunkSource;\n    version = TiffVersion.Tiff;\n    images: CogTiffImage[] = [];\n    options = new CogTifGhostOptions();\n\n    private cursor: CogSourceCursor;\n    ifdConfig: TiffIfdConfig = TagTiffConfig;\n\n    constructor(source: ChunkSource) {\n        this.source = source;\n        this.cursor = new CogSourceCursor(this);\n    }\n\n    /** Create and initialize a CogTiff */\n    static create(source: ChunkSource): Promise<CogTiff> {\n        return new CogTiff(source).init();\n    }\n\n    /** Has init() been called */\n    isInitialized = false;\n\n    _initPromise?: Promise<CogTiff>;\n    /**\n     * Initialize the COG loading in the header and all image headers\n     *\n     * @param loadGeoKeys Whether to also initialize the GeoKeyDirectory\n     */\n    init(loadGeoKeys = false): Promise<CogTiff> {\n        if (this._initPromise) return this._initPromise;\n        this._initPromise = this.doInit(loadGeoKeys);\n        return this._initPromise;\n    }\n\n    private async doInit(loadGeoKeys = false): Promise<CogTiff> {\n        if (this.isInitialized) return this;\n        // Load the first few KB in, more loads will run as more data is required\n        await this.source.loadBytes(0, this.source.chunkSize);\n        await this.fetchIfd();\n        await Promise.all(this.images.map((c) => c.init(loadGeoKeys)));\n\n        this.isInitialized = true;\n        return this;\n    }\n\n    private async fetchIfd(): Promise<void> {\n        const view = this.cursor.seekTo(0);\n        const endian = view.uint16();\n        this.source.isLittleEndian = endian === TiffEndian.Little;\n        if (!this.source.isLittleEndian) throw new Error('Only little endian is supported');\n        this.version = view.uint16();\n\n        let nextOffsetIfd: number;\n        if (this.version === TiffVersion.BigTiff) {\n            this.ifdConfig = TagTiffBigConfig;\n            const pointerSize = view.uint16();\n            if (pointerSize !== 8) throw new Error('Only 8byte pointers are supported');\n            const zeros = view.uint16();\n            if (zeros !== 0) throw new Error('Invalid big tiff header');\n            nextOffsetIfd = view.pointer();\n        } else if (this.version === TiffVersion.Tiff) {\n            nextOffsetIfd = view.pointer();\n        } else {\n            throw new Error(`Only tiff supported version:${this.version}`);\n        }\n\n        const ghostSize = nextOffsetIfd - this.cursor.currentOffset;\n        // GDAL now stores metadata between the IFD inside a ghost storage area\n        if (ghostSize > 0 && ghostSize < 16 * 1024) {\n            // logger?.debug(\n            //     { offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) },\n            //     'GhostOptions',\n            // );\n            // this.options.process(this.source, view.currentOffset, ghostSize);\n        }\n\n        return this.processIfd(nextOffsetIfd);\n    }\n\n    getImage(z: number): CogTiffImage {\n        return this.images[z];\n    }\n\n    /**\n     * Find a image which has a resolution similar to the provided resolution\n     *\n     * @param resolution resolution to find\n     */\n    getImageByResolution(resolution: number): CogTiffImage {\n        const firstImage = this.images[0];\n        const firstImageSize = firstImage.size;\n        const [refX] = firstImage.resolution;\n\n        const resolutionBaseX = refX * firstImageSize.width;\n        // const resolutionBaseY = refY * firstImageSize.height;\n        for (let i = this.images.length - 1; i > 0; i--) {\n            const img = this.images[i];\n            const imgSize = img.size;\n\n            const imgResolutionX = resolutionBaseX / imgSize.width;\n            // TODO do we care about y resolution\n            // const imgResolutionY = resolutionBaseY / imgSize.height;\n\n            if (imgResolutionX - resolution <= 0.01) return img;\n        }\n        return firstImage;\n    }\n\n    /**\n     * Get the raw bytes for a tile at a given x,y, index.\n     *\n     * This may return null if the tile does not exist eg Sparse cogs,\n     *\n     * @param x tile x index\n     * @param y tile y index\n     * @param index image index\n     */\n    async getTile(x: number, y: number, index: number): Promise<{ mimeType: string; bytes: Uint8Array } | null> {\n        const image = this.getImage(index);\n        if (image == null) throw new Error(`Missing z: ${index}`);\n        if (!image.isTiled()) throw new Error('Tif is not tiled');\n\n        return image.getTile(x, y);\n    }\n\n    private async processIfd(offset: number): Promise<void> {\n        if (!this.source.hasBytes(offset, 4096)) await this.source.loadBytes(offset, 4096);\n\n        const { image, nextOffset } = await this.readIfd(offset);\n        this.images.push(image);\n\n        if (nextOffset) await this.processIfd(nextOffset);\n    }\n\n    private async readIfd(offset: number): Promise<{ nextOffset: number; image: CogTiffImage }> {\n        if (!this.source.hasBytes(offset, 1024)) await this.source.loadBytes(offset, this.source.chunkSize);\n        const view = this.cursor.seekTo(offset);\n        const tagCount = view.offset();\n        const byteStart = offset + this.ifdConfig.offset;\n        const tags: Map<TiffTag, CogTiffTagBase> = new Map();\n\n        let pos = byteStart;\n        for (let i = 0; i < tagCount; i++) {\n            const tag = CogTiffTag.create(this, pos);\n            pos += tag.size;\n\n            if (tag.name == null) throw new Error('Unknown IFD Tag: ' + toHexString(tag.id));\n            tags.set(tag.id, tag);\n        }\n\n        const image = new CogTiffImage(this, this.images.length, tags);\n        const nextOffset = this.source.getUint(pos, this.ifdConfig.pointer);\n        return { nextOffset, image };\n    }\n\n    /** Close the file source if it needs closing */\n    async close(): Promise<void> {\n        await this.source?.close?.();\n    }\n}\n"]}
@@ -2,6 +2,7 @@
2
2
  * MimeType conversion for common tif image types
3
3
  */
4
4
  export declare enum TiffMimeType {
5
+ NONE = "application/octet-stream",
5
6
  JPEG = "image/jpeg",
6
7
  JP2 = "image/jp2",
7
8
  WEBP = "image/webp",
@@ -1 +1 @@
1
- {"version":3,"file":"tiff.mime.d.ts","sourceRoot":"","sources":["../../src/const/tiff.mime.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,oBAAY,YAAY;IACpB,IAAI,eAAe;IACnB,GAAG,cAAc;IACjB,IAAI,eAAe;IACnB,GAAG,oBAAoB;IACvB,OAAO,wBAAwB;CAClC;AAED,eAAO,MAAM,eAAe,EAAE;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAAA;CAO1D,CAAC"}
1
+ {"version":3,"file":"tiff.mime.d.ts","sourceRoot":"","sources":["../../src/const/tiff.mime.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,oBAAY,YAAY;IACpB,IAAI,6BAA6B;IACjC,IAAI,eAAe;IACnB,GAAG,cAAc;IACjB,IAAI,eAAe;IACnB,GAAG,oBAAoB;IACvB,OAAO,wBAAwB;CAClC;AAED,eAAO,MAAM,eAAe,EAAE;IAAE,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAAA;CAQ1D,CAAC"}
@@ -3,6 +3,7 @@
3
3
  */
4
4
  export var TiffMimeType;
5
5
  (function (TiffMimeType) {
6
+ TiffMimeType["NONE"] = "application/octet-stream";
6
7
  TiffMimeType["JPEG"] = "image/jpeg";
7
8
  TiffMimeType["JP2"] = "image/jp2";
8
9
  TiffMimeType["WEBP"] = "image/webp";
@@ -10,6 +11,7 @@ export var TiffMimeType;
10
11
  TiffMimeType["DEFLATE"] = "application/deflate";
11
12
  })(TiffMimeType || (TiffMimeType = {}));
12
13
  export const TiffCompression = {
14
+ 1: TiffMimeType.NONE,
13
15
  5: TiffMimeType.LZW,
14
16
  6: TiffMimeType.JPEG,
15
17
  7: TiffMimeType.JPEG,
@@ -17,4 +19,4 @@ export const TiffCompression = {
17
19
  34712: TiffMimeType.JP2,
18
20
  50001: TiffMimeType.WEBP,
19
21
  };
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi5taW1lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0L3RpZmYubWltZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBTixJQUFZLFlBTVg7QUFORCxXQUFZLFlBQVk7SUFDcEIsbUNBQW1CLENBQUE7SUFDbkIsaUNBQWlCLENBQUE7SUFDakIsbUNBQW1CLENBQUE7SUFDbkIsdUNBQXVCLENBQUE7SUFDdkIsK0NBQStCLENBQUE7QUFDbkMsQ0FBQyxFQU5XLFlBQVksS0FBWixZQUFZLFFBTXZCO0FBRUQsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFvQztJQUM1RCxDQUFDLEVBQUUsWUFBWSxDQUFDLEdBQUc7SUFDbkIsQ0FBQyxFQUFFLFlBQVksQ0FBQyxJQUFJO0lBQ3BCLENBQUMsRUFBRSxZQUFZLENBQUMsSUFBSTtJQUNwQixDQUFDLEVBQUUsWUFBWSxDQUFDLE9BQU87SUFDdkIsS0FBSyxFQUFFLFlBQVksQ0FBQyxHQUFHO0lBQ3ZCLEtBQUssRUFBRSxZQUFZLENBQUMsSUFBSTtDQUMzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNaW1lVHlwZSBjb252ZXJzaW9uIGZvciBjb21tb24gdGlmIGltYWdlIHR5cGVzXG4gKi9cbmV4cG9ydCBlbnVtIFRpZmZNaW1lVHlwZSB7XG4gICAgSlBFRyA9ICdpbWFnZS9qcGVnJyxcbiAgICBKUDIgPSAnaW1hZ2UvanAyJyxcbiAgICBXRUJQID0gJ2ltYWdlL3dlYnAnLFxuICAgIExaVyA9ICdhcHBsaWNhdGlvbi9sencnLFxuICAgIERFRkxBVEUgPSAnYXBwbGljYXRpb24vZGVmbGF0ZScsXG59XG5cbmV4cG9ydCBjb25zdCBUaWZmQ29tcHJlc3Npb246IHsgW2tleTogbnVtYmVyXTogVGlmZk1pbWVUeXBlIH0gPSB7XG4gICAgNTogVGlmZk1pbWVUeXBlLkxaVyxcbiAgICA2OiBUaWZmTWltZVR5cGUuSlBFRyxcbiAgICA3OiBUaWZmTWltZVR5cGUuSlBFRyxcbiAgICA4OiBUaWZmTWltZVR5cGUuREVGTEFURSxcbiAgICAzNDcxMjogVGlmZk1pbWVUeXBlLkpQMixcbiAgICA1MDAwMTogVGlmZk1pbWVUeXBlLldFQlAsXG59O1xuIl19
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi5taW1lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0L3RpZmYubWltZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBTixJQUFZLFlBT1g7QUFQRCxXQUFZLFlBQVk7SUFDcEIsaURBQWlDLENBQUE7SUFDakMsbUNBQW1CLENBQUE7SUFDbkIsaUNBQWlCLENBQUE7SUFDakIsbUNBQW1CLENBQUE7SUFDbkIsdUNBQXVCLENBQUE7SUFDdkIsK0NBQStCLENBQUE7QUFDbkMsQ0FBQyxFQVBXLFlBQVksS0FBWixZQUFZLFFBT3ZCO0FBRUQsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFvQztJQUM1RCxDQUFDLEVBQUUsWUFBWSxDQUFDLElBQUk7SUFDcEIsQ0FBQyxFQUFFLFlBQVksQ0FBQyxHQUFHO0lBQ25CLENBQUMsRUFBRSxZQUFZLENBQUMsSUFBSTtJQUNwQixDQUFDLEVBQUUsWUFBWSxDQUFDLElBQUk7SUFDcEIsQ0FBQyxFQUFFLFlBQVksQ0FBQyxPQUFPO0lBQ3ZCLEtBQUssRUFBRSxZQUFZLENBQUMsR0FBRztJQUN2QixLQUFLLEVBQUUsWUFBWSxDQUFDLElBQUk7Q0FDM0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTWltZVR5cGUgY29udmVyc2lvbiBmb3IgY29tbW9uIHRpZiBpbWFnZSB0eXBlc1xuICovXG5leHBvcnQgZW51bSBUaWZmTWltZVR5cGUge1xuICAgIE5PTkUgPSAnYXBwbGljYXRpb24vb2N0ZXQtc3RyZWFtJyxcbiAgICBKUEVHID0gJ2ltYWdlL2pwZWcnLFxuICAgIEpQMiA9ICdpbWFnZS9qcDInLFxuICAgIFdFQlAgPSAnaW1hZ2Uvd2VicCcsXG4gICAgTFpXID0gJ2FwcGxpY2F0aW9uL2x6dycsXG4gICAgREVGTEFURSA9ICdhcHBsaWNhdGlvbi9kZWZsYXRlJyxcbn1cblxuZXhwb3J0IGNvbnN0IFRpZmZDb21wcmVzc2lvbjogeyBba2V5OiBudW1iZXJdOiBUaWZmTWltZVR5cGUgfSA9IHtcbiAgICAxOiBUaWZmTWltZVR5cGUuTk9ORSxcbiAgICA1OiBUaWZmTWltZVR5cGUuTFpXLFxuICAgIDY6IFRpZmZNaW1lVHlwZS5KUEVHLFxuICAgIDc6IFRpZmZNaW1lVHlwZS5KUEVHLFxuICAgIDg6IFRpZmZNaW1lVHlwZS5ERUZMQVRFLFxuICAgIDM0NzEyOiBUaWZmTWltZVR5cGUuSlAyLFxuICAgIDUwMDAxOiBUaWZmTWltZVR5cGUuV0VCUCxcbn07XG4iXX0=
@@ -20,4 +20,4 @@ o.spec('TiffTag', () => {
20
20
  o(lazy.value).deepEquals(res);
21
21
  });
22
22
  });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcmVhZC90YWcvX190ZXN0X18vdGFnLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDdkYsT0FBTyxDQUFDLE1BQU0sT0FBTyxDQUFDO0FBQ3RCLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBQzdCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxLQUFLLENBQUM7QUFDcEMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUVyRCxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUU7SUFDbkIsTUFBTSxPQUFPLEdBQUcsYUFBYSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDL0MsTUFBTSxhQUFhLEdBQUcsSUFBSSxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxzQ0FBc0MsQ0FBQyxDQUFDLENBQUM7SUFFMUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7UUFDZCxhQUFhLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ2pDLENBQUMsQ0FBQyxDQUFDO0lBRUgsQ0FBQyxDQUFDLHVCQUF1QixFQUFFLEtBQUssSUFBSSxFQUFFO1FBQ2xDLE1BQU0sSUFBSSxHQUFHLElBQUksT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBRXhDLE1BQU0sYUFBYSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDdkMsTUFBTSxJQUFJLEdBQUcsSUFBSSxjQUFjLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNqRCxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUUzQixNQUFNLEdBQUcsR0FBRyxNQUFNLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUMvQixDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNyQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsQyxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVzdEZpbGVDaHVua1NvdXJjZSB9IGZyb20gJ0BjaHVua2QvY29yZS9idWlsZC9fX3Rlc3RfXy9jaHVuay5zb3VyY2UuZmFrZS5qcyc7XG5pbXBvcnQgbyBmcm9tICdvc3BlYyc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgZmlsZVVSTFRvUGF0aCB9IGZyb20gJ3VybCc7XG5pbXBvcnQgeyBDb2dUaWZmIH0gZnJvbSAnLi4vLi4vLi4vY29nLnRpZmYuanMnO1xuaW1wb3J0IHsgQ29nVGlmZlRhZ0xhenkgfSBmcm9tICcuLi90aWZmLnRhZy5sYXp5LmpzJztcblxuby5zcGVjKCdUaWZmVGFnJywgKCkgPT4ge1xuICAgIGNvbnN0IGRpck5hbWUgPSBmaWxlVVJMVG9QYXRoKGltcG9ydC5tZXRhLnVybCk7XG4gICAgY29uc3QgY29nU291cmNlRmlsZSA9IG5ldyBUZXN0RmlsZUNodW5rU291cmNlKHBhdGguam9pbihkaXJOYW1lLCAnLi4vLi4vLi4vLi4vLi4vZGF0YS9yZ2JhOF90aWxlZC50aWZmJykpO1xuXG4gICAgby5iZWZvcmVFYWNoKCgpID0+IHtcbiAgICAgICAgY29nU291cmNlRmlsZS5jaHVua3MuY2xlYXIoKTtcbiAgICB9KTtcblxuICAgIG8oJ3Nob3VsZCBsb2FkIGxhenkgdGFncycsIGFzeW5jICgpID0+IHtcbiAgICAgICAgY29uc3QgdGlmZiA9IG5ldyBDb2dUaWZmKGNvZ1NvdXJjZUZpbGUpO1xuXG4gICAgICAgIGF3YWl0IGNvZ1NvdXJjZUZpbGUubG9hZEJ5dGVzKDM2ODAsIDgpO1xuICAgICAgICBjb25zdCBsYXp5ID0gbmV3IENvZ1RpZmZUYWdMYXp5KDMzOSwgdGlmZiwgMzY4MCk7XG4gICAgICAgIG8obGF6eS52YWx1ZSkuZXF1YWxzKG51bGwpO1xuXG4gICAgICAgIGNvbnN0IHJlcyA9IGF3YWl0IGxhenkuZmV0Y2goKTtcbiAgICAgICAgbyhyZXMpLmRlZXBFcXVhbHMoWzE4NzYxLCA0MywgOCwgMF0pO1xuICAgICAgICBvKGxhenkudmFsdWUpLmRlZXBFcXVhbHMocmVzKTtcbiAgICB9KTtcbn0pO1xuIl19
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcmVhZC90YWcvX190ZXN0X18vdGFnLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDdkYsT0FBTyxDQUFDLE1BQU0sT0FBTyxDQUFDO0FBQ3RCLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBQzdCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxLQUFLLENBQUM7QUFDcEMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUVyRCxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUU7SUFDbkIsTUFBTSxPQUFPLEdBQUcsYUFBYSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDL0MsTUFBTSxhQUFhLEdBQUcsSUFBSSxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxzQ0FBc0MsQ0FBQyxDQUFDLENBQUM7SUFFMUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7UUFDYixhQUFhLENBQUMsTUFBZ0MsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM1RCxDQUFDLENBQUMsQ0FBQztJQUVILENBQUMsQ0FBQyx1QkFBdUIsRUFBRSxLQUFLLElBQUksRUFBRTtRQUNsQyxNQUFNLElBQUksR0FBRyxJQUFJLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUV4QyxNQUFNLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3ZDLE1BQU0sSUFBSSxHQUFHLElBQUksY0FBYyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDakQsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFM0IsTUFBTSxHQUFHLEdBQUcsTUFBTSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDL0IsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDckMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbEMsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3RGaWxlQ2h1bmtTb3VyY2UgfSBmcm9tICdAY2h1bmtkL2NvcmUvYnVpbGQvX190ZXN0X18vY2h1bmsuc291cmNlLmZha2UuanMnO1xuaW1wb3J0IG8gZnJvbSAnb3NwZWMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IGZpbGVVUkxUb1BhdGggfSBmcm9tICd1cmwnO1xuaW1wb3J0IHsgQ29nVGlmZiB9IGZyb20gJy4uLy4uLy4uL2NvZy50aWZmLmpzJztcbmltcG9ydCB7IENvZ1RpZmZUYWdMYXp5IH0gZnJvbSAnLi4vdGlmZi50YWcubGF6eS5qcyc7XG5cbm8uc3BlYygnVGlmZlRhZycsICgpID0+IHtcbiAgICBjb25zdCBkaXJOYW1lID0gZmlsZVVSTFRvUGF0aChpbXBvcnQubWV0YS51cmwpO1xuICAgIGNvbnN0IGNvZ1NvdXJjZUZpbGUgPSBuZXcgVGVzdEZpbGVDaHVua1NvdXJjZShwYXRoLmpvaW4oZGlyTmFtZSwgJy4uLy4uLy4uLy4uLy4uL2RhdGEvcmdiYThfdGlsZWQudGlmZicpKTtcblxuICAgIG8uYmVmb3JlRWFjaCgoKSA9PiB7XG4gICAgICAgIChjb2dTb3VyY2VGaWxlLmNodW5rcyBhcyBNYXA8dW5rbm93biwgdW5rbm93bj4pLmNsZWFyKCk7XG4gICAgfSk7XG5cbiAgICBvKCdzaG91bGQgbG9hZCBsYXp5IHRhZ3MnLCBhc3luYyAoKSA9PiB7XG4gICAgICAgIGNvbnN0IHRpZmYgPSBuZXcgQ29nVGlmZihjb2dTb3VyY2VGaWxlKTtcblxuICAgICAgICBhd2FpdCBjb2dTb3VyY2VGaWxlLmxvYWRCeXRlcygzNjgwLCA4KTtcbiAgICAgICAgY29uc3QgbGF6eSA9IG5ldyBDb2dUaWZmVGFnTGF6eSgzMzksIHRpZmYsIDM2ODApO1xuICAgICAgICBvKGxhenkudmFsdWUpLmVxdWFscyhudWxsKTtcblxuICAgICAgICBjb25zdCByZXMgPSBhd2FpdCBsYXp5LmZldGNoKCk7XG4gICAgICAgIG8ocmVzKS5kZWVwRXF1YWxzKFsxODc2MSwgNDMsIDgsIDBdKTtcbiAgICAgICAgbyhsYXp5LnZhbHVlKS5kZWVwRXF1YWxzKHJlcyk7XG4gICAgfSk7XG59KTtcbiJdfQ==
@@ -8,7 +8,7 @@ export class CogTiffTagBase {
8
8
  this.id = id;
9
9
  this.name = TiffTag[this.id];
10
10
  this.dataType = this.tiff.source.getUint16(offset + 2);
11
- this.dataCount = this.tiff.source.getUint(offset + 4, this.tiff.ifdConfig.offset);
11
+ this.dataCount = this.tiff.source.getUint(offset + 4, this.tiff.ifdConfig.pointer);
12
12
  this.dataTypeSize = getTiffTagSize(this.dataType);
13
13
  this.dataLength = this.dataTypeSize * this.dataCount;
14
14
  }
@@ -76,4 +76,4 @@ export class CogTiffTagBase {
76
76
  };
77
77
  }
78
78
  }
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiff.tag.base.js","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { CogTiff } from '../../cog.tiff.js';\nimport { TiffTag } from '../../const/tiff.tag.id.js';\nimport { TiffTagValueType } from '../../const/tiff.tag.value.js';\nimport { getTiffTagSize, getTiffTagValueReader } from '../tiff.value.reader.js';\n\nexport abstract class CogTiffTagBase<T = unknown> {\n    /**\n     * Value of the tiff tag, may be null if the value has not been read\n     */\n    abstract value: T | null;\n\n    /** Raw offset for where in the tif this tag starts */\n    private byteOffset: number;\n\n    /** Name of the tag */\n    name: string;\n\n    /** TifTagId @see TiffTag */\n    id: number;\n\n    /** Type of data inside the record @see this.dataTypeName */\n    dataType: number;\n\n    /** Number of records inside the tag */\n    dataCount: number;\n\n    tiff: CogTiff;\n\n    constructor(id: number, tiff: CogTiff, offset: number) {\n        this.tiff = tiff;\n        this.byteOffset = offset;\n\n        this.id = id;\n        this.name = TiffTag[this.id];\n\n        this.dataType = this.tiff.source.getUint16(offset + 2);\n        this.dataCount = this.tiff.source.getUint(offset + 4, this.tiff.ifdConfig.offset);\n        this.dataTypeSize = getTiffTagSize(this.dataType);\n        this.dataLength = this.dataTypeSize * this.dataCount;\n    }\n\n    /**\n     * Have the bytes for the tag been loaded, or is a fetch required to read the tag\n     */\n    get hasBytes(): boolean {\n        return this.tiff.source.hasBytes(this.valuePointer, this.dataLength);\n    }\n\n    /**\n     * is the tag ready to be read\n     */\n    get isReady(): boolean {\n        return true;\n    }\n\n    /**\n     * Get the size of the data type\n     *\n     * @remarks\n     * This is only the size of one instance of the data @see this.dataLength for total byte size\n     *\n     */\n    dataTypeSize: number;\n\n    /**\n     * Get a human readable name for a datatype\n     *\n     */\n    get dataTypeName(): string {\n        return TiffTagValueType[this.dataType];\n    }\n\n    /**\n     * Get the number of bytes used for the all of the data\n     */\n    dataLength: number;\n\n    /** absolute offset of the Tag value */\n    get valuePointer(): number {\n        const valueOffset = this.size - this.tiff.ifdConfig.pointer;\n        if (this.isValueInline) return this.byteOffset + valueOffset;\n        return this.tiff.source.getUint(this.byteOffset + valueOffset, this.tiff.ifdConfig.pointer);\n    }\n\n    /** Size of the IFD (bytes) */\n    get size(): number {\n        return this.tiff.ifdConfig.ifd;\n    }\n\n    /** Is the value of this tag inline, or is it a pointer to the real value */\n    get isValueInline(): boolean {\n        return this.dataLength <= this.tiff.ifdConfig.pointer;\n    }\n\n    /** Read the value in from the byte array */\n    readValue(): T {\n        const offset = this.valuePointer;\n        const dataTypeSize = this.dataTypeSize;\n        const convert = getTiffTagValueReader(this.dataType);\n        const count = this.dataCount;\n        const dataLength = count * dataTypeSize;\n\n        if (count === 1) return convert(this.tiff.source, offset) as unknown as T;\n\n        const output = [];\n        for (let i = 0; i < dataLength; i += dataTypeSize) {\n            output.push(convert(this.tiff.source, offset + i));\n        }\n\n        // Convert to a string if ascii\n        if (this.dataType === TiffTagValueType.ASCII) return output.join('').trim() as unknown as T;\n\n        return output as unknown as T;\n    }\n\n    /** Get a human(ish) friendly output for the tags */\n    toJSON(): Record<string, unknown> {\n        return {\n            id: this.id,\n            name: this.name,\n            offset: this.byteOffset,\n            isReady: this.isReady,\n            type: this.dataTypeName,\n            value: this.value,\n        };\n    }\n}\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiff.tag.base.js","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { CogTiff } from '../../cog.tiff.js';\nimport { TiffTag } from '../../const/tiff.tag.id.js';\nimport { TiffTagValueType } from '../../const/tiff.tag.value.js';\nimport { getTiffTagSize, getTiffTagValueReader } from '../tiff.value.reader.js';\n\nexport abstract class CogTiffTagBase<T = unknown> {\n    /**\n     * Value of the tiff tag, may be null if the value has not been read\n     */\n    abstract value: T | null;\n\n    /** Raw offset for where in the tif this tag starts */\n    private byteOffset: number;\n\n    /** Name of the tag */\n    name: string;\n\n    /** TifTagId @see TiffTag */\n    id: number;\n\n    /** Type of data inside the record @see this.dataTypeName */\n    dataType: number;\n\n    /** Number of records inside the tag */\n    dataCount: number;\n\n    tiff: CogTiff;\n\n    constructor(id: number, tiff: CogTiff, offset: number) {\n        this.tiff = tiff;\n        this.byteOffset = offset;\n\n        this.id = id;\n        this.name = TiffTag[this.id];\n\n        this.dataType = this.tiff.source.getUint16(offset + 2);\n        this.dataCount = this.tiff.source.getUint(offset + 4, this.tiff.ifdConfig.pointer);\n        this.dataTypeSize = getTiffTagSize(this.dataType);\n        this.dataLength = this.dataTypeSize * this.dataCount;\n    }\n\n    /**\n     * Have the bytes for the tag been loaded, or is a fetch required to read the tag\n     */\n    get hasBytes(): boolean {\n        return this.tiff.source.hasBytes(this.valuePointer, this.dataLength);\n    }\n\n    /**\n     * is the tag ready to be read\n     */\n    get isReady(): boolean {\n        return true;\n    }\n\n    /**\n     * Get the size of the data type\n     *\n     * @remarks\n     * This is only the size of one instance of the data @see this.dataLength for total byte size\n     *\n     */\n    dataTypeSize: number;\n\n    /**\n     * Get a human readable name for a datatype\n     *\n     */\n    get dataTypeName(): string {\n        return TiffTagValueType[this.dataType];\n    }\n\n    /**\n     * Get the number of bytes used for the all of the data\n     */\n    dataLength: number;\n\n    /** absolute offset of the Tag value */\n    get valuePointer(): number {\n        const valueOffset = this.size - this.tiff.ifdConfig.pointer;\n        if (this.isValueInline) return this.byteOffset + valueOffset;\n        return this.tiff.source.getUint(this.byteOffset + valueOffset, this.tiff.ifdConfig.pointer);\n    }\n\n    /** Size of the IFD (bytes) */\n    get size(): number {\n        return this.tiff.ifdConfig.ifd;\n    }\n\n    /** Is the value of this tag inline, or is it a pointer to the real value */\n    get isValueInline(): boolean {\n        return this.dataLength <= this.tiff.ifdConfig.pointer;\n    }\n\n    /** Read the value in from the byte array */\n    readValue(): T {\n        const offset = this.valuePointer;\n        const dataTypeSize = this.dataTypeSize;\n        const convert = getTiffTagValueReader(this.dataType);\n        const count = this.dataCount;\n        const dataLength = count * dataTypeSize;\n\n        if (count === 1) return convert(this.tiff.source, offset) as unknown as T;\n\n        const output = [];\n        for (let i = 0; i < dataLength; i += dataTypeSize) {\n            output.push(convert(this.tiff.source, offset + i));\n        }\n\n        // Convert to a string if ascii\n        if (this.dataType === TiffTagValueType.ASCII) return output.join('').trim() as unknown as T;\n\n        return output as unknown as T;\n    }\n\n    /** Get a human(ish) friendly output for the tags */\n    toJSON(): Record<string, unknown> {\n        return {\n            id: this.id,\n            name: this.name,\n            offset: this.byteOffset,\n            isReady: this.isReady,\n            type: this.dataTypeName,\n            value: this.value,\n        };\n    }\n}\n"]}
@@ -1,8 +1,7 @@
1
- import { LogType } from '@chunkd/core';
2
1
  import { CogTiffTagBase } from './tiff.tag.base.js';
3
2
  export declare class CogTiffTagLazy<T> extends CogTiffTagBase<T> {
4
3
  value: T | null;
5
4
  get isReady(): boolean;
6
- fetch(l?: LogType): Promise<T>;
5
+ fetch(): Promise<T>;
7
6
  }
8
7
  //# sourceMappingURL=tiff.tag.lazy.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"tiff.tag.lazy.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.lazy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,qBAAa,cAAc,CAAC,CAAC,CAAE,SAAQ,cAAc,CAAC,CAAC,CAAC;IACpD,KAAK,EAAE,CAAC,GAAG,IAAI,CAAQ;IAEvB,IAAI,OAAO,IAAI,OAAO,CAErB;IAEK,KAAK,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;CAOvC"}
1
+ {"version":3,"file":"tiff.tag.lazy.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.lazy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,qBAAa,cAAc,CAAC,CAAC,CAAE,SAAQ,cAAc,CAAC,CAAC,CAAC;IACpD,KAAK,EAAE,CAAC,GAAG,IAAI,CAAQ;IAEvB,IAAI,OAAO,IAAI,OAAO,CAErB;IAEK,KAAK,IAAI,OAAO,CAAC,CAAC,CAAC;CAO5B"}
@@ -7,12 +7,12 @@ export class CogTiffTagLazy extends CogTiffTagBase {
7
7
  get isReady() {
8
8
  return this.value != null;
9
9
  }
10
- async fetch(l) {
10
+ async fetch() {
11
11
  if (this.tiff.source.hasBytes(this.valuePointer, this.dataLength) === false) {
12
- await this.tiff.source.loadBytes(this.valuePointer, this.dataLength, l);
12
+ await this.tiff.source.loadBytes(this.valuePointer, this.dataLength);
13
13
  }
14
14
  this.value = this.readValue();
15
15
  return this.value;
16
16
  }
17
17
  }
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcubGF6eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9yZWFkL3RhZy90aWZmLnRhZy5sYXp5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxNQUFNLE9BQU8sY0FBa0IsU0FBUSxjQUFpQjtJQUF4RDs7UUFDSSxVQUFLLEdBQWEsSUFBSSxDQUFDO0lBYTNCLENBQUM7SUFYRyxJQUFJLE9BQU87UUFDUCxPQUFPLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDO0lBQzlCLENBQUM7SUFFRCxLQUFLLENBQUMsS0FBSyxDQUFDLENBQVc7UUFDbkIsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssS0FBSyxFQUFFO1lBQ3pFLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUMsQ0FBQztTQUMzRTtRQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQzlCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2dUeXBlIH0gZnJvbSAnQGNodW5rZC9jb3JlJztcbmltcG9ydCB7IENvZ1RpZmZUYWdCYXNlIH0gZnJvbSAnLi90aWZmLnRhZy5iYXNlLmpzJztcblxuZXhwb3J0IGNsYXNzIENvZ1RpZmZUYWdMYXp5PFQ+IGV4dGVuZHMgQ29nVGlmZlRhZ0Jhc2U8VD4ge1xuICAgIHZhbHVlOiBUIHwgbnVsbCA9IG51bGw7XG5cbiAgICBnZXQgaXNSZWFkeSgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMudmFsdWUgIT0gbnVsbDtcbiAgICB9XG5cbiAgICBhc3luYyBmZXRjaChsPzogTG9nVHlwZSk6IFByb21pc2U8VD4ge1xuICAgICAgICBpZiAodGhpcy50aWZmLnNvdXJjZS5oYXNCeXRlcyh0aGlzLnZhbHVlUG9pbnRlciwgdGhpcy5kYXRhTGVuZ3RoKSA9PT0gZmFsc2UpIHtcbiAgICAgICAgICAgIGF3YWl0IHRoaXMudGlmZi5zb3VyY2UubG9hZEJ5dGVzKHRoaXMudmFsdWVQb2ludGVyLCB0aGlzLmRhdGFMZW5ndGgsIGwpO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMudmFsdWUgPSB0aGlzLnJlYWRWYWx1ZSgpO1xuICAgICAgICByZXR1cm4gdGhpcy52YWx1ZTtcbiAgICB9XG59XG4iXX0=
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcubGF6eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9yZWFkL3RhZy90aWZmLnRhZy5sYXp5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxNQUFNLE9BQU8sY0FBa0IsU0FBUSxjQUFpQjtJQUF4RDs7UUFDSSxVQUFLLEdBQWEsSUFBSSxDQUFDO0lBYTNCLENBQUM7SUFYRyxJQUFJLE9BQU87UUFDUCxPQUFPLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDO0lBQzlCLENBQUM7SUFFRCxLQUFLLENBQUMsS0FBSztRQUNQLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEtBQUssRUFBRTtZQUN6RSxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUN4RTtRQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQzlCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2dUaWZmVGFnQmFzZSB9IGZyb20gJy4vdGlmZi50YWcuYmFzZS5qcyc7XG5cbmV4cG9ydCBjbGFzcyBDb2dUaWZmVGFnTGF6eTxUPiBleHRlbmRzIENvZ1RpZmZUYWdCYXNlPFQ+IHtcbiAgICB2YWx1ZTogVCB8IG51bGwgPSBudWxsO1xuXG4gICAgZ2V0IGlzUmVhZHkoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlICE9IG51bGw7XG4gICAgfVxuXG4gICAgYXN5bmMgZmV0Y2goKTogUHJvbWlzZTxUPiB7XG4gICAgICAgIGlmICh0aGlzLnRpZmYuc291cmNlLmhhc0J5dGVzKHRoaXMudmFsdWVQb2ludGVyLCB0aGlzLmRhdGFMZW5ndGgpID09PSBmYWxzZSkge1xuICAgICAgICAgICAgYXdhaXQgdGhpcy50aWZmLnNvdXJjZS5sb2FkQnl0ZXModGhpcy52YWx1ZVBvaW50ZXIsIHRoaXMuZGF0YUxlbmd0aCk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy52YWx1ZSA9IHRoaXMucmVhZFZhbHVlKCk7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,4 +1,3 @@
1
- import { LogType } from '@chunkd/core';
2
1
  import { CogTiff } from '../../cog.tiff.js';
3
2
  import { CogTiffTagBase } from './tiff.tag.base.js';
4
3
  /**
@@ -11,12 +10,12 @@ export declare class CogTiffTagOffset extends CogTiffTagBase<number[]> {
11
10
  constructor(tagId: number, tiff: CogTiff, offset: number);
12
11
  get value(): number[] | null;
13
12
  /** Load the entire index into memory */
14
- load(l: LogType): Promise<void>;
13
+ load(): Promise<void>;
15
14
  readValue(): number[];
16
15
  /**
17
16
  * Read a specific value from the offset array
18
17
  * @param index index to read at
19
18
  */
20
- getValueAt(index: number, l?: LogType): Promise<number>;
19
+ getValueAt(index: number): Promise<number>;
21
20
  }
22
21
  //# sourceMappingURL=tiff.tag.offset.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"tiff.tag.offset.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.offset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD;;;;GAIG;AACH,qBAAa,gBAAiB,SAAQ,cAAc,CAAC,MAAM,EAAE,CAAC;IAC1D,OAAO,CAAC,YAAY,CAAyB;gBAEjC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM;IAIxD,IAAI,KAAK,IAAI,MAAM,EAAE,GAAG,IAAI,CAS3B;IAED,wCAAwC;IAClC,IAAI,CAAC,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAKrC,SAAS,IAAI,MAAM,EAAE;IAWrB;;;OAGG;IACG,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC;CAYhE"}
1
+ {"version":3,"file":"tiff.tag.offset.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.offset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD;;;;GAIG;AACH,qBAAa,gBAAiB,SAAQ,cAAc,CAAC,MAAM,EAAE,CAAC;IAC1D,OAAO,CAAC,YAAY,CAAyB;gBAEjC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM;IAIxD,IAAI,KAAK,IAAI,MAAM,EAAE,GAAG,IAAI,CAS3B;IAED,wCAAwC;IAClC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAK3B,SAAS,IAAI,MAAM,EAAE;IAWrB;;;OAGG;IACG,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAYnD"}
@@ -20,8 +20,8 @@ export class CogTiffTagOffset extends CogTiffTagBase {
20
20
  return null;
21
21
  }
22
22
  /** Load the entire index into memory */
23
- async load(l) {
24
- await this.tiff.source.loadBytes(this.valuePointer, this.dataLength, l);
23
+ async load() {
24
+ await this.tiff.source.loadBytes(this.valuePointer, this.dataLength);
25
25
  this.readValue();
26
26
  }
27
27
  readValue() {
@@ -39,16 +39,16 @@ export class CogTiffTagOffset extends CogTiffTagBase {
39
39
  * Read a specific value from the offset array
40
40
  * @param index index to read at
41
41
  */
42
- async getValueAt(index, l) {
42
+ async getValueAt(index) {
43
43
  if (this.loadedValues)
44
44
  return this.loadedValues[index];
45
45
  const dataSize = this.dataTypeSize;
46
46
  const valueOffset = this.valuePointer + dataSize * index;
47
47
  const convert = getTiffTagValueReader(this.dataType);
48
48
  if (!this.tiff.source.hasBytes(valueOffset, dataSize)) {
49
- await this.tiff.source.loadBytes(valueOffset, dataSize, l);
49
+ await this.tiff.source.loadBytes(valueOffset, dataSize);
50
50
  }
51
51
  return convert(this.tiff.source, valueOffset);
52
52
  }
53
53
  }
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcub2Zmc2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlYWQvdGFnL3RpZmYudGFnLm9mZnNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFcEQ7Ozs7R0FJRztBQUNILE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxjQUF3QjtJQUcxRCxZQUFZLEtBQWEsRUFBRSxJQUFhLEVBQUUsTUFBYztRQUNwRCxLQUFLLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztRQUh2QixpQkFBWSxHQUFvQixJQUFJLENBQUM7SUFJN0MsQ0FBQztJQUVELElBQUksS0FBSztRQUNMLElBQUksSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJO1lBQUUsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO1FBRXhELElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNmLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNqQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7U0FDNUI7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRUQsd0NBQXdDO0lBQ3hDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBVTtRQUNqQixNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDeEUsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxTQUFTO1FBQ0wsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQzlCLG1FQUFtRTtRQUNuRSxJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVEsRUFBRTtZQUN6QixJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDN0I7YUFBTTtZQUNILElBQUksQ0FBQyxZQUFZLEdBQUcsR0FBRyxDQUFDO1NBQzNCO1FBQ0QsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzdCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxLQUFLLENBQUMsVUFBVSxDQUFDLEtBQWEsRUFBRSxDQUFXO1FBQ3ZDLElBQUksSUFBSSxDQUFDLFlBQVk7WUFBRSxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFdkQsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQztRQUNuQyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsWUFBWSxHQUFHLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDekQsTUFBTSxPQUFPLEdBQUcscUJBQXFCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXJELElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxFQUFFO1lBQ25ELE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUM7U0FDOUQ7UUFDRCxPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQVcsQ0FBQztJQUM1RCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2dUeXBlIH0gZnJvbSAnQGNodW5rZC9jb3JlJztcbmltcG9ydCB7IENvZ1RpZmYgfSBmcm9tICcuLi8uLi9jb2cudGlmZi5qcyc7XG5pbXBvcnQgeyBnZXRUaWZmVGFnVmFsdWVSZWFkZXIgfSBmcm9tICcuLi90aWZmLnZhbHVlLnJlYWRlci5qcyc7XG5pbXBvcnQgeyBDb2dUaWZmVGFnQmFzZSB9IGZyb20gJy4vdGlmZi50YWcuYmFzZS5qcyc7XG5cbi8qKlxuICogVGlmZlRhZyBmb3Igb2Zmc2V0IGFycmF5c1xuICpcbiAqIEFsbG93cyBpbmRpdmlkdWFsIGFjY2VzcyB0byBzcGVjaWZpYyByZWNvcmRzIHdpdGhvdXQgaGF2aW5nIHRvIHJlYWQgdGhlIGVudGlyZSB0YWcgaW4uXG4gKi9cbmV4cG9ydCBjbGFzcyBDb2dUaWZmVGFnT2Zmc2V0IGV4dGVuZHMgQ29nVGlmZlRhZ0Jhc2U8bnVtYmVyW10+IHtcbiAgICBwcml2YXRlIGxvYWRlZFZhbHVlczogbnVtYmVyW10gfCBudWxsID0gbnVsbDtcblxuICAgIGNvbnN0cnVjdG9yKHRhZ0lkOiBudW1iZXIsIHRpZmY6IENvZ1RpZmYsIG9mZnNldDogbnVtYmVyKSB7XG4gICAgICAgIHN1cGVyKHRhZ0lkLCB0aWZmLCBvZmZzZXQpO1xuICAgIH1cblxuICAgIGdldCB2YWx1ZSgpOiBudW1iZXJbXSB8IG51bGwge1xuICAgICAgICBpZiAodGhpcy5sb2FkZWRWYWx1ZXMgIT0gbnVsbCkgcmV0dXJuIHRoaXMubG9hZGVkVmFsdWVzO1xuXG4gICAgICAgIGlmICh0aGlzLmhhc0J5dGVzKSB7XG4gICAgICAgICAgICB0aGlzLnJlYWRWYWx1ZSgpO1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMubG9hZGVkVmFsdWVzO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgLyoqIExvYWQgdGhlIGVudGlyZSBpbmRleCBpbnRvIG1lbW9yeSAqL1xuICAgIGFzeW5jIGxvYWQobDogTG9nVHlwZSk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBhd2FpdCB0aGlzLnRpZmYuc291cmNlLmxvYWRCeXRlcyh0aGlzLnZhbHVlUG9pbnRlciwgdGhpcy5kYXRhTGVuZ3RoLCBsKTtcbiAgICAgICAgdGhpcy5yZWFkVmFsdWUoKTtcbiAgICB9XG5cbiAgICByZWFkVmFsdWUoKTogbnVtYmVyW10ge1xuICAgICAgICBjb25zdCB2YWwgPSBzdXBlci5yZWFkVmFsdWUoKTtcbiAgICAgICAgLy8gaWYgb25seSBvbmUgdmFsdWUgaXMgcmVhZCBpbiwgaXQgd2lsbCBub3QgYmUgcmV0dXJuZWQgYXMgYSBhcnJheVxuICAgICAgICBpZiAodHlwZW9mIHZhbCA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgICAgIHRoaXMubG9hZGVkVmFsdWVzID0gW3ZhbF07XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmxvYWRlZFZhbHVlcyA9IHZhbDtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy5sb2FkZWRWYWx1ZXM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmVhZCBhIHNwZWNpZmljIHZhbHVlIGZyb20gdGhlIG9mZnNldCBhcnJheVxuICAgICAqIEBwYXJhbSBpbmRleCBpbmRleCB0byByZWFkIGF0XG4gICAgICovXG4gICAgYXN5bmMgZ2V0VmFsdWVBdChpbmRleDogbnVtYmVyLCBsPzogTG9nVHlwZSk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgICAgIGlmICh0aGlzLmxvYWRlZFZhbHVlcykgcmV0dXJuIHRoaXMubG9hZGVkVmFsdWVzW2luZGV4XTtcblxuICAgICAgICBjb25zdCBkYXRhU2l6ZSA9IHRoaXMuZGF0YVR5cGVTaXplO1xuICAgICAgICBjb25zdCB2YWx1ZU9mZnNldCA9IHRoaXMudmFsdWVQb2ludGVyICsgZGF0YVNpemUgKiBpbmRleDtcbiAgICAgICAgY29uc3QgY29udmVydCA9IGdldFRpZmZUYWdWYWx1ZVJlYWRlcih0aGlzLmRhdGFUeXBlKTtcblxuICAgICAgICBpZiAoIXRoaXMudGlmZi5zb3VyY2UuaGFzQnl0ZXModmFsdWVPZmZzZXQsIGRhdGFTaXplKSkge1xuICAgICAgICAgICAgYXdhaXQgdGhpcy50aWZmLnNvdXJjZS5sb2FkQnl0ZXModmFsdWVPZmZzZXQsIGRhdGFTaXplLCBsKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY29udmVydCh0aGlzLnRpZmYuc291cmNlLCB2YWx1ZU9mZnNldCkgYXMgbnVtYmVyO1xuICAgIH1cbn1cbiJdfQ==
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcub2Zmc2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlYWQvdGFnL3RpZmYudGFnLm9mZnNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFcEQ7Ozs7R0FJRztBQUNILE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxjQUF3QjtJQUcxRCxZQUFZLEtBQWEsRUFBRSxJQUFhLEVBQUUsTUFBYztRQUNwRCxLQUFLLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztRQUh2QixpQkFBWSxHQUFvQixJQUFJLENBQUM7SUFJN0MsQ0FBQztJQUVELElBQUksS0FBSztRQUNMLElBQUksSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJO1lBQUUsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO1FBRXhELElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNmLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNqQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7U0FDNUI7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRUQsd0NBQXdDO0lBQ3hDLEtBQUssQ0FBQyxJQUFJO1FBQ04sTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDckUsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxTQUFTO1FBQ0wsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQzlCLG1FQUFtRTtRQUNuRSxJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVEsRUFBRTtZQUN6QixJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDN0I7YUFBTTtZQUNILElBQUksQ0FBQyxZQUFZLEdBQUcsR0FBRyxDQUFDO1NBQzNCO1FBQ0QsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzdCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxLQUFLLENBQUMsVUFBVSxDQUFDLEtBQWE7UUFDMUIsSUFBSSxJQUFJLENBQUMsWUFBWTtZQUFFLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUV2RCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDO1FBQ25DLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxZQUFZLEdBQUcsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN6RCxNQUFNLE9BQU8sR0FBRyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFckQsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDLEVBQUU7WUFDbkQsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1NBQzNEO1FBQ0QsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFXLENBQUM7SUFDNUQsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29nVGlmZiB9IGZyb20gJy4uLy4uL2NvZy50aWZmLmpzJztcbmltcG9ydCB7IGdldFRpZmZUYWdWYWx1ZVJlYWRlciB9IGZyb20gJy4uL3RpZmYudmFsdWUucmVhZGVyLmpzJztcbmltcG9ydCB7IENvZ1RpZmZUYWdCYXNlIH0gZnJvbSAnLi90aWZmLnRhZy5iYXNlLmpzJztcblxuLyoqXG4gKiBUaWZmVGFnIGZvciBvZmZzZXQgYXJyYXlzXG4gKlxuICogQWxsb3dzIGluZGl2aWR1YWwgYWNjZXNzIHRvIHNwZWNpZmljIHJlY29yZHMgd2l0aG91dCBoYXZpbmcgdG8gcmVhZCB0aGUgZW50aXJlIHRhZyBpbi5cbiAqL1xuZXhwb3J0IGNsYXNzIENvZ1RpZmZUYWdPZmZzZXQgZXh0ZW5kcyBDb2dUaWZmVGFnQmFzZTxudW1iZXJbXT4ge1xuICAgIHByaXZhdGUgbG9hZGVkVmFsdWVzOiBudW1iZXJbXSB8IG51bGwgPSBudWxsO1xuXG4gICAgY29uc3RydWN0b3IodGFnSWQ6IG51bWJlciwgdGlmZjogQ29nVGlmZiwgb2Zmc2V0OiBudW1iZXIpIHtcbiAgICAgICAgc3VwZXIodGFnSWQsIHRpZmYsIG9mZnNldCk7XG4gICAgfVxuXG4gICAgZ2V0IHZhbHVlKCk6IG51bWJlcltdIHwgbnVsbCB7XG4gICAgICAgIGlmICh0aGlzLmxvYWRlZFZhbHVlcyAhPSBudWxsKSByZXR1cm4gdGhpcy5sb2FkZWRWYWx1ZXM7XG5cbiAgICAgICAgaWYgKHRoaXMuaGFzQnl0ZXMpIHtcbiAgICAgICAgICAgIHRoaXMucmVhZFZhbHVlKCk7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5sb2FkZWRWYWx1ZXM7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICAvKiogTG9hZCB0aGUgZW50aXJlIGluZGV4IGludG8gbWVtb3J5ICovXG4gICAgYXN5bmMgbG9hZCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgYXdhaXQgdGhpcy50aWZmLnNvdXJjZS5sb2FkQnl0ZXModGhpcy52YWx1ZVBvaW50ZXIsIHRoaXMuZGF0YUxlbmd0aCk7XG4gICAgICAgIHRoaXMucmVhZFZhbHVlKCk7XG4gICAgfVxuXG4gICAgcmVhZFZhbHVlKCk6IG51bWJlcltdIHtcbiAgICAgICAgY29uc3QgdmFsID0gc3VwZXIucmVhZFZhbHVlKCk7XG4gICAgICAgIC8vIGlmIG9ubHkgb25lIHZhbHVlIGlzIHJlYWQgaW4sIGl0IHdpbGwgbm90IGJlIHJldHVybmVkIGFzIGEgYXJyYXlcbiAgICAgICAgaWYgKHR5cGVvZiB2YWwgPT09ICdudW1iZXInKSB7XG4gICAgICAgICAgICB0aGlzLmxvYWRlZFZhbHVlcyA9IFt2YWxdO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5sb2FkZWRWYWx1ZXMgPSB2YWw7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMubG9hZGVkVmFsdWVzO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJlYWQgYSBzcGVjaWZpYyB2YWx1ZSBmcm9tIHRoZSBvZmZzZXQgYXJyYXlcbiAgICAgKiBAcGFyYW0gaW5kZXggaW5kZXggdG8gcmVhZCBhdFxuICAgICAqL1xuICAgIGFzeW5jIGdldFZhbHVlQXQoaW5kZXg6IG51bWJlcik6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgICAgIGlmICh0aGlzLmxvYWRlZFZhbHVlcykgcmV0dXJuIHRoaXMubG9hZGVkVmFsdWVzW2luZGV4XTtcblxuICAgICAgICBjb25zdCBkYXRhU2l6ZSA9IHRoaXMuZGF0YVR5cGVTaXplO1xuICAgICAgICBjb25zdCB2YWx1ZU9mZnNldCA9IHRoaXMudmFsdWVQb2ludGVyICsgZGF0YVNpemUgKiBpbmRleDtcbiAgICAgICAgY29uc3QgY29udmVydCA9IGdldFRpZmZUYWdWYWx1ZVJlYWRlcih0aGlzLmRhdGFUeXBlKTtcblxuICAgICAgICBpZiAoIXRoaXMudGlmZi5zb3VyY2UuaGFzQnl0ZXModmFsdWVPZmZzZXQsIGRhdGFTaXplKSkge1xuICAgICAgICAgICAgYXdhaXQgdGhpcy50aWZmLnNvdXJjZS5sb2FkQnl0ZXModmFsdWVPZmZzZXQsIGRhdGFTaXplKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY29udmVydCh0aGlzLnRpZmYuc291cmNlLCB2YWx1ZU9mZnNldCkgYXMgbnVtYmVyO1xuICAgIH1cbn1cbiJdfQ==
@@ -14,4 +14,4 @@ export class CogTifTagStatic extends CogTiffTagBase {
14
14
  return this._value;
15
15
  }
16
16
  }
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcuc3RhdGljLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlYWQvdGFnL3RpZmYudGFnLnN0YXRpYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFcEQsTUFBTSxPQUFPLGVBQW1CLFNBQVEsY0FBaUI7SUFBekQ7O1FBQ0ksWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixXQUFNLEdBQWEsSUFBSSxDQUFDO0lBVTVCLENBQUM7SUFSRyxxQ0FBcUM7SUFDckMsSUFBSSxLQUFLO1FBQ0wsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLEtBQUssRUFBRTtZQUN4QixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztTQUN2QjtRQUNELE9BQU8sSUFBSSxDQUFDLE1BQU8sQ0FBQztJQUN4QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2dUaWZmVGFnQmFzZSB9IGZyb20gJy4vdGlmZi50YWcuYmFzZS5qcyc7XG5cbmV4cG9ydCBjbGFzcyBDb2dUaWZUYWdTdGF0aWM8VD4gZXh0ZW5kcyBDb2dUaWZmVGFnQmFzZTxUPiB7XG4gICAgX2lzUmVhZCA9IGZhbHNlO1xuICAgIF92YWx1ZTogVCB8IG51bGwgPSBudWxsO1xuXG4gICAgLyoqIExhenkgcmVhZCB0aGUgaW5saW5lIHRpZmYgdGFncyAqL1xuICAgIGdldCB2YWx1ZSgpOiBUIHtcbiAgICAgICAgaWYgKHRoaXMuX2lzUmVhZCA9PT0gZmFsc2UpIHtcbiAgICAgICAgICAgIHRoaXMuX3ZhbHVlID0gdGhpcy5yZWFkVmFsdWUoKTtcbiAgICAgICAgICAgIHRoaXMuX2lzUmVhZCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMuX3ZhbHVlITtcbiAgICB9XG59XG4iXX0=
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcuc3RhdGljLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlYWQvdGFnL3RpZmYudGFnLnN0YXRpYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFcEQsTUFBTSxPQUFPLGVBQW1CLFNBQVEsY0FBaUI7SUFBekQ7O1FBQ0ksWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixXQUFNLEdBQWEsSUFBSSxDQUFDO0lBVTVCLENBQUM7SUFSRyxxQ0FBcUM7SUFDckMsSUFBSSxLQUFLO1FBQ0wsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLEtBQUssRUFBRTtZQUN4QixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztTQUN2QjtRQUNELE9BQU8sSUFBSSxDQUFDLE1BQVcsQ0FBQztJQUM1QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2dUaWZmVGFnQmFzZSB9IGZyb20gJy4vdGlmZi50YWcuYmFzZS5qcyc7XG5cbmV4cG9ydCBjbGFzcyBDb2dUaWZUYWdTdGF0aWM8VD4gZXh0ZW5kcyBDb2dUaWZmVGFnQmFzZTxUPiB7XG4gICAgX2lzUmVhZCA9IGZhbHNlO1xuICAgIF92YWx1ZTogVCB8IG51bGwgPSBudWxsO1xuXG4gICAgLyoqIExhenkgcmVhZCB0aGUgaW5saW5lIHRpZmYgdGFncyAqL1xuICAgIGdldCB2YWx1ZSgpOiBUIHtcbiAgICAgICAgaWYgKHRoaXMuX2lzUmVhZCA9PT0gZmFsc2UpIHtcbiAgICAgICAgICAgIHRoaXMuX3ZhbHVlID0gdGhpcy5yZWFkVmFsdWUoKTtcbiAgICAgICAgICAgIHRoaXMuX2lzUmVhZCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMuX3ZhbHVlIGFzIFQ7XG4gICAgfVxufVxuIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cogeotiff/core",
3
- "version": "6.0.2",
3
+ "version": "7.0.0",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "https://github.com/blacha/cogeotiff.git",
@@ -18,16 +18,15 @@
18
18
  "test": "ospec --globs 'build/**/*.test.js'"
19
19
  },
20
20
  "dependencies": {
21
- "@chunkd/core": "^7.2.2",
21
+ "@chunkd/core": "^8.1.0",
22
22
  "ieee754": "^1.1.13"
23
23
  },
24
24
  "devDependencies": {
25
25
  "@types/node": "^14.14.22",
26
- "@types/ospec": "^4.0.0",
27
- "ospec": "^4.0.0"
26
+ "@types/ospec": "^4.0.3"
28
27
  },
29
28
  "publishConfig": {
30
29
  "access": "public"
31
30
  },
32
- "gitHead": "c2abab63abb6b570f670138fa4e451a46fb1fed3"
31
+ "gitHead": "a2352ec8df0f0eb5f5dddacc0f3cdea855dceda3"
33
32
  }