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:
parent
d37e4b08e4
commit
df696063b9
@ -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.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -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);
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user