2017-02-17 21:44:49 +09:00
|
|
|
/* Copyright 2017 Mozilla Foundation
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2019-02-11 03:29:38 +09:00
|
|
|
import { assert, CMapCompressionType } from '../../src/shared/util';
|
2019-11-10 23:10:18 +09:00
|
|
|
import { isNodeJS } from '../../src/shared/is_node';
|
2017-07-29 07:35:10 +09:00
|
|
|
import { isRef } from '../../src/core/primitives';
|
2019-04-20 19:36:49 +09:00
|
|
|
import { Page } from '../../src/core/document';
|
2017-02-17 21:44:49 +09:00
|
|
|
|
2019-02-17 20:34:37 +09:00
|
|
|
class DOMFileReaderFactory {
|
|
|
|
static async fetch(params) {
|
|
|
|
const response = await fetch(params.path);
|
|
|
|
if (!response.ok) {
|
|
|
|
throw new Error(response.statusText);
|
|
|
|
}
|
|
|
|
return new Uint8Array(await response.arrayBuffer());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-09 00:09:54 +09:00
|
|
|
class NodeFileReaderFactory {
|
2019-02-17 20:34:37 +09:00
|
|
|
static async fetch(params) {
|
|
|
|
const fs = require('fs');
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
fs.readFile(params.path, (error, data) => {
|
|
|
|
if (error || !data) {
|
|
|
|
reject(error || new Error(`Empty file for: ${params.path}`));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
resolve(new Uint8Array(data));
|
|
|
|
});
|
|
|
|
});
|
2017-04-09 00:09:54 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-05-16 20:01:03 +09:00
|
|
|
const TEST_PDFS_PATH = {
|
|
|
|
dom: '../pdfs/',
|
|
|
|
node: './test/pdfs/',
|
|
|
|
};
|
|
|
|
|
|
|
|
function buildGetDocumentParams(filename, options) {
|
|
|
|
let params = Object.create(null);
|
2019-11-11 00:42:46 +09:00
|
|
|
if (isNodeJS) {
|
2018-01-28 22:34:45 +09:00
|
|
|
params.url = TEST_PDFS_PATH.node + filename;
|
2017-05-16 20:01:03 +09:00
|
|
|
} else {
|
|
|
|
params.url = new URL(TEST_PDFS_PATH.dom + filename, window.location).href;
|
|
|
|
}
|
|
|
|
for (let option in options) {
|
|
|
|
params[option] = options[option];
|
|
|
|
}
|
|
|
|
return params;
|
|
|
|
}
|
|
|
|
|
2019-02-11 03:29:38 +09:00
|
|
|
class NodeCanvasFactory {
|
|
|
|
create(width, height) {
|
|
|
|
assert(width > 0 && height > 0, 'Invalid canvas size');
|
|
|
|
|
|
|
|
const Canvas = require('canvas');
|
|
|
|
const canvas = Canvas.createCanvas(width, height);
|
|
|
|
return {
|
|
|
|
canvas,
|
|
|
|
context: canvas.getContext('2d'),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
reset(canvasAndContext, width, height) {
|
|
|
|
assert(canvasAndContext.canvas, 'Canvas is not specified');
|
|
|
|
assert(width > 0 && height > 0, 'Invalid canvas size');
|
|
|
|
|
|
|
|
canvasAndContext.canvas.width = width;
|
|
|
|
canvasAndContext.canvas.height = height;
|
|
|
|
}
|
|
|
|
|
|
|
|
destroy(canvasAndContext) {
|
|
|
|
assert(canvasAndContext.canvas, 'Canvas is not specified');
|
|
|
|
|
|
|
|
// Zeroing the width and height cause Firefox to release graphics
|
|
|
|
// resources immediately, which can greatly reduce memory consumption.
|
|
|
|
canvasAndContext.canvas.width = 0;
|
|
|
|
canvasAndContext.canvas.height = 0;
|
|
|
|
canvasAndContext.canvas = null;
|
|
|
|
canvasAndContext.context = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-17 05:30:27 +09:00
|
|
|
class NodeCMapReaderFactory {
|
2017-05-06 00:55:02 +09:00
|
|
|
constructor({ baseUrl = null, isCompressed = false, }) {
|
|
|
|
this.baseUrl = baseUrl;
|
|
|
|
this.isCompressed = isCompressed;
|
2017-02-17 21:44:49 +09:00
|
|
|
}
|
|
|
|
|
2019-02-24 23:22:25 +09:00
|
|
|
async fetch({ name, }) {
|
2017-09-28 19:29:01 +09:00
|
|
|
if (!this.baseUrl) {
|
2019-02-24 23:22:25 +09:00
|
|
|
throw new Error(
|
2018-02-18 00:57:24 +09:00
|
|
|
'The CMap "baseUrl" parameter must be specified, ensure that ' +
|
2019-02-24 23:22:25 +09:00
|
|
|
'the "cMapUrl" and "cMapPacked" API parameters are provided.');
|
2017-09-28 19:29:01 +09:00
|
|
|
}
|
2017-04-17 05:30:27 +09:00
|
|
|
if (!name) {
|
2019-02-24 23:22:25 +09:00
|
|
|
throw new Error('CMap name must be specified.');
|
2017-04-17 05:30:27 +09:00
|
|
|
}
|
2019-02-24 23:22:25 +09:00
|
|
|
const url = this.baseUrl + name + (this.isCompressed ? '.bcmap' : '');
|
|
|
|
const compressionType = (this.isCompressed ? CMapCompressionType.BINARY :
|
|
|
|
CMapCompressionType.NONE);
|
2017-02-17 21:44:49 +09:00
|
|
|
|
2019-02-24 23:22:25 +09:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
const fs = require('fs');
|
2017-04-17 05:30:27 +09:00
|
|
|
fs.readFile(url, (error, data) => {
|
|
|
|
if (error || !data) {
|
2019-02-24 23:22:25 +09:00
|
|
|
reject(new Error(error));
|
2017-04-17 05:30:27 +09:00
|
|
|
return;
|
|
|
|
}
|
2019-02-24 23:22:25 +09:00
|
|
|
resolve({ cMapData: new Uint8Array(data), compressionType, });
|
2017-04-17 05:30:27 +09:00
|
|
|
});
|
2019-02-24 23:22:25 +09:00
|
|
|
}).catch((reason) => {
|
|
|
|
throw new Error(`Unable to load ${this.isCompressed ? 'binary ' : ''}` +
|
|
|
|
`CMap at: ${url}`);
|
2017-04-17 05:30:27 +09:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2017-02-17 21:44:49 +09:00
|
|
|
|
2017-07-29 07:35:10 +09:00
|
|
|
class XRefMock {
|
|
|
|
constructor(array) {
|
|
|
|
this._map = Object.create(null);
|
|
|
|
|
|
|
|
for (let key in array) {
|
|
|
|
let obj = array[key];
|
|
|
|
this._map[obj.ref.toString()] = obj.data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fetch(ref) {
|
|
|
|
return this._map[ref.toString()];
|
|
|
|
}
|
|
|
|
|
|
|
|
fetchAsync(ref) {
|
|
|
|
return Promise.resolve(this.fetch(ref));
|
|
|
|
}
|
|
|
|
|
|
|
|
fetchIfRef(obj) {
|
|
|
|
if (!isRef(obj)) {
|
|
|
|
return obj;
|
|
|
|
}
|
|
|
|
return this.fetch(obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
fetchIfRefAsync(obj) {
|
|
|
|
return Promise.resolve(this.fetchIfRef(obj));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-20 19:36:49 +09:00
|
|
|
function createIdFactory(pageIndex) {
|
|
|
|
const page = new Page({
|
|
|
|
pdfManager: {
|
|
|
|
get docId() {
|
|
|
|
return 'd0';
|
|
|
|
},
|
|
|
|
},
|
|
|
|
pageIndex,
|
|
|
|
});
|
|
|
|
return page.idFactory;
|
|
|
|
}
|
|
|
|
|
2017-04-17 05:30:27 +09:00
|
|
|
export {
|
2019-02-17 20:34:37 +09:00
|
|
|
DOMFileReaderFactory,
|
2017-04-09 00:09:54 +09:00
|
|
|
NodeFileReaderFactory,
|
2019-02-11 03:29:38 +09:00
|
|
|
NodeCanvasFactory,
|
2017-04-17 05:30:27 +09:00
|
|
|
NodeCMapReaderFactory,
|
2017-07-29 07:35:10 +09:00
|
|
|
XRefMock,
|
2017-05-16 20:01:03 +09:00
|
|
|
buildGetDocumentParams,
|
|
|
|
TEST_PDFS_PATH,
|
2019-04-20 19:36:49 +09:00
|
|
|
createIdFactory,
|
2017-04-17 05:30:27 +09:00
|
|
|
};
|