Change the BaseCMapReaderFactory fetch-helper to return a Uint8Array

This moves more functionality into the base-class, rather than having to duplicate that in the extending classes.
For consistency, also updates the `BaseStandardFontDataFactory` and introduces more `async`/`await` in various relevant code.
This commit is contained in:
Jonas Jenwald 2024-10-20 17:54:04 +02:00
parent d37e4b08e4
commit df696063b9
3 changed files with 35 additions and 32 deletions

View File

@ -127,22 +127,27 @@ class BaseCMapReaderFactory {
throw new Error("CMap name must be specified."); throw new Error("CMap name must be specified.");
} }
const url = this.baseUrl + name + (this.isCompressed ? ".bcmap" : ""); const url = this.baseUrl + name + (this.isCompressed ? ".bcmap" : "");
const compressionType = this.isCompressed
? CMapCompressionType.BINARY
: CMapCompressionType.NONE;
return this._fetchData(url, compressionType).catch(reason => { return this._fetch(url)
throw new Error( .then(cMapData => ({
`Unable to load ${this.isCompressed ? "binary " : ""}CMap at: ${url}` cMapData,
); compressionType: this.isCompressed
}); ? CMapCompressionType.BINARY
: CMapCompressionType.NONE,
}))
.catch(reason => {
throw new Error(
`Unable to load ${this.isCompressed ? "binary " : ""}CMap at: ${url}`
);
});
} }
/** /**
* @ignore * @ignore
* @returns {Promise<Uint8Array>}
*/ */
_fetchData(url, compressionType) { async _fetch(url) {
unreachable("Abstract method `_fetchData` called."); unreachable("Abstract method `_fetch` called.");
} }
} }
@ -168,16 +173,17 @@ class BaseStandardFontDataFactory {
} }
const url = `${this.baseUrl}${filename}`; const url = `${this.baseUrl}${filename}`;
return this._fetchData(url).catch(reason => { return this._fetch(url).catch(reason => {
throw new Error(`Unable to load font data at: ${url}`); throw new Error(`Unable to load font data at: ${url}`);
}); });
} }
/** /**
* @ignore * @ignore
* @returns {Promise<Uint8Array>}
*/ */
_fetchData(url) { async _fetch(url) {
unreachable("Abstract method `_fetchData` called."); unreachable("Abstract method `_fetch` called.");
} }
} }

View File

@ -564,17 +564,14 @@ class DOMCMapReaderFactory extends BaseCMapReaderFactory {
/** /**
* @ignore * @ignore
*/ */
_fetchData(url, compressionType) { async _fetch(url) {
return fetchData( const data = await fetchData(
url, url,
/* type = */ this.isCompressed ? "arraybuffer" : "text" /* type = */ this.isCompressed ? "arraybuffer" : "text"
).then(data => ({ );
cMapData: return data instanceof ArrayBuffer
data instanceof ArrayBuffer ? new Uint8Array(data)
? new Uint8Array(data) : stringToBytes(data);
: stringToBytes(data),
compressionType,
}));
} }
} }
@ -582,10 +579,9 @@ class DOMStandardFontDataFactory extends BaseStandardFontDataFactory {
/** /**
* @ignore * @ignore
*/ */
_fetchData(url) { async _fetch(url) {
return fetchData(url, /* type = */ "arraybuffer").then( const data = await fetchData(url, /* type = */ "arraybuffer");
data => new Uint8Array(data) return new Uint8Array(data);
);
} }
} }

View File

@ -113,10 +113,11 @@ class NodePackages {
} }
} }
const fetchData = function (url) { async function fetchData(url) {
const fs = NodePackages.get("fs"); const fs = NodePackages.get("fs");
return fs.promises.readFile(url).then(data => new Uint8Array(data)); const data = await fs.promises.readFile(url);
}; return new Uint8Array(data);
}
class NodeFilterFactory extends BaseFilterFactory {} class NodeFilterFactory extends BaseFilterFactory {}
@ -134,8 +135,8 @@ class NodeCMapReaderFactory extends BaseCMapReaderFactory {
/** /**
* @ignore * @ignore
*/ */
_fetchData(url, compressionType) { async _fetch(url) {
return fetchData(url).then(data => ({ cMapData: data, compressionType })); return fetchData(url);
} }
} }
@ -143,7 +144,7 @@ class NodeStandardFontDataFactory extends BaseStandardFontDataFactory {
/** /**
* @ignore * @ignore
*/ */
_fetchData(url) { async _fetch(url) {
return fetchData(url); return fetchData(url);
} }
} }