In order to fix bug 1935076, we'll have to add a pure js fallback in case wasm is disabled or simd isn't supported. Unfortunately, this fallback will take some space. So, the main goal of this patch is to reduce the overall size (by ~93k). As a side effect, it should make easier to use an other wasm file (which must export _jp2_decode, _malloc and _free).
143 lines
3.1 KiB
JavaScript
143 lines
3.1 KiB
JavaScript
/* Copyright 2021 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.
|
|
*/
|
|
|
|
import { bytesToString, shadow, unreachable } from "../shared/util.js";
|
|
|
|
class BaseStream {
|
|
constructor() {
|
|
if (
|
|
(typeof PDFJSDev === "undefined" || PDFJSDev.test("TESTING")) &&
|
|
this.constructor === BaseStream
|
|
) {
|
|
unreachable("Cannot initialize BaseStream.");
|
|
}
|
|
}
|
|
|
|
// eslint-disable-next-line getter-return
|
|
get length() {
|
|
unreachable("Abstract getter `length` accessed");
|
|
}
|
|
|
|
// eslint-disable-next-line getter-return
|
|
get isEmpty() {
|
|
unreachable("Abstract getter `isEmpty` accessed");
|
|
}
|
|
|
|
get isDataLoaded() {
|
|
return shadow(this, "isDataLoaded", true);
|
|
}
|
|
|
|
getByte() {
|
|
unreachable("Abstract method `getByte` called");
|
|
}
|
|
|
|
getBytes(length) {
|
|
unreachable("Abstract method `getBytes` called");
|
|
}
|
|
|
|
/**
|
|
* NOTE: This method can only be used to get image-data that is guaranteed
|
|
* to be fully loaded, since otherwise intermittent errors may occur;
|
|
* note the `ObjectLoader` class.
|
|
*/
|
|
async getImageData(length, decoderOptions) {
|
|
return this.getBytes(length, decoderOptions);
|
|
}
|
|
|
|
async asyncGetBytes() {
|
|
unreachable("Abstract method `asyncGetBytes` called");
|
|
}
|
|
|
|
get isAsync() {
|
|
return false;
|
|
}
|
|
|
|
get isAsyncDecoder() {
|
|
return false;
|
|
}
|
|
|
|
get canAsyncDecodeImageFromBuffer() {
|
|
return false;
|
|
}
|
|
|
|
async getTransferableImage() {
|
|
return null;
|
|
}
|
|
|
|
peekByte() {
|
|
const peekedByte = this.getByte();
|
|
if (peekedByte !== -1) {
|
|
this.pos--;
|
|
}
|
|
return peekedByte;
|
|
}
|
|
|
|
peekBytes(length) {
|
|
const bytes = this.getBytes(length);
|
|
this.pos -= bytes.length;
|
|
return bytes;
|
|
}
|
|
|
|
getUint16() {
|
|
const b0 = this.getByte();
|
|
const b1 = this.getByte();
|
|
if (b0 === -1 || b1 === -1) {
|
|
return -1;
|
|
}
|
|
return (b0 << 8) + b1;
|
|
}
|
|
|
|
getInt32() {
|
|
const b0 = this.getByte();
|
|
const b1 = this.getByte();
|
|
const b2 = this.getByte();
|
|
const b3 = this.getByte();
|
|
return (b0 << 24) + (b1 << 16) + (b2 << 8) + b3;
|
|
}
|
|
|
|
getByteRange(begin, end) {
|
|
unreachable("Abstract method `getByteRange` called");
|
|
}
|
|
|
|
getString(length) {
|
|
return bytesToString(this.getBytes(length));
|
|
}
|
|
|
|
skip(n) {
|
|
this.pos += n || 1;
|
|
}
|
|
|
|
reset() {
|
|
unreachable("Abstract method `reset` called");
|
|
}
|
|
|
|
moveStart() {
|
|
unreachable("Abstract method `moveStart` called");
|
|
}
|
|
|
|
makeSubStream(start, length, dict = null) {
|
|
unreachable("Abstract method `makeSubStream` called");
|
|
}
|
|
|
|
/**
|
|
* @returns {Array | null}
|
|
*/
|
|
getBaseStreams() {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
export { BaseStream };
|