fbf6dee8ee
As it turns out, most of the code-paths in the `PDFImage`-class won't actually pass the TypedArray (containing the image-data) to the `ColorSpace`-code. Hence we *generally* don't need to force the image-data to be a `Uint8ClampedArray`, and can just as well directly use a `Uint8Array` instead. In the following cases we're returning the data without any `ColorSpace`-parsing, and the exact TypedArray used shouldn't matter: -b72a448327/src/core/image.js (L714)
-b72a448327/src/core/image.js (L751)
In the following cases the image-data is only used *internally*, and again the exact TypedArray used shouldn't matter: -b72a448327/src/core/image.js (L762)
with the actual image-data being defined (as `Uint8ClampedArray`) further below -b72a448327/src/core/image.js (L837)
*Please note:* This is tagged `api-minor` because it's API-observable, given that *some* image/mask-data will now be returned as `Uint8Array` rather than using `Uint8ClampedArray` unconditionally. However, that seems like a small price to pay to (slightly) reduce memory usage during image-conversion.
111 lines
2.4 KiB
JavaScript
111 lines
2.4 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 (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");
|
|
}
|
|
|
|
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 };
|