Made TypeScript code more robust by adding Readonly<> wrapper around appropriate array types in function parameters.

pull/134/head
Project Nayuki 3 years ago
parent a6f886f6ff
commit c6cbb388a7

@ -68,7 +68,7 @@ namespace qrcodegen {
// This function always encodes using the binary segment mode, not any text mode. The maximum number of // This function always encodes using the binary segment mode, not any text mode. The maximum number of
// bytes allowed is 2953. The smallest possible QR Code version is automatically chosen for the output. // bytes allowed is 2953. The smallest possible QR Code version is automatically chosen for the output.
// The ECC level of the result may be higher than the ecl argument if it can be done without increasing the version. // The ECC level of the result may be higher than the ecl argument if it can be done without increasing the version.
public static encodeBinary(data: Array<byte>, ecl: QrCode.Ecc): QrCode { public static encodeBinary(data: Readonly<Array<byte>>, ecl: QrCode.Ecc): QrCode {
const seg: QrSegment = qrcodegen.QrSegment.makeBytes(data); const seg: QrSegment = qrcodegen.QrSegment.makeBytes(data);
return QrCode.encodeSegments([seg], ecl); return QrCode.encodeSegments([seg], ecl);
} }
@ -85,7 +85,7 @@ namespace qrcodegen {
// This function allows the user to create a custom sequence of segments that switches // This function allows the user to create a custom sequence of segments that switches
// between modes (such as alphanumeric and byte) to encode text in less space. // between modes (such as alphanumeric and byte) to encode text in less space.
// This is a mid-level API; the high-level API is encodeText() and encodeBinary(). // This is a mid-level API; the high-level API is encodeText() and encodeBinary().
public static encodeSegments(segs: Array<QrSegment>, ecl: QrCode.Ecc, public static encodeSegments(segs: Readonly<Array<QrSegment>>, ecl: QrCode.Ecc,
minVersion: int = 1, maxVersion: int = 40, minVersion: int = 1, maxVersion: int = 40,
mask: int = -1, boostEcl: boolean = true): QrCode { mask: int = -1, boostEcl: boolean = true): QrCode {
@ -177,7 +177,7 @@ namespace qrcodegen {
// The error correction level used in this QR Code. // The error correction level used in this QR Code.
public readonly errorCorrectionLevel: QrCode.Ecc, public readonly errorCorrectionLevel: QrCode.Ecc,
dataCodewords: Array<byte>, dataCodewords: Readonly<Array<byte>>,
// The index of the mask pattern used in this QR Code, which is between 0 and 7 (inclusive). // The index of the mask pattern used in this QR Code, which is between 0 and 7 (inclusive).
// Even if a QR Code is created with automatic masking requested (mask = -1), // Even if a QR Code is created with automatic masking requested (mask = -1),
@ -363,7 +363,7 @@ namespace qrcodegen {
// Returns a new byte string representing the given data with the appropriate error correction // Returns a new byte string representing the given data with the appropriate error correction
// codewords appended to it, based on this object's version and error correction level. // codewords appended to it, based on this object's version and error correction level.
private addEccAndInterleave(data: Array<byte>): Array<byte> { private addEccAndInterleave(data: Readonly<Array<byte>>): Array<byte> {
const ver: int = this.version; const ver: int = this.version;
const ecl: QrCode.Ecc = this.errorCorrectionLevel; const ecl: QrCode.Ecc = this.errorCorrectionLevel;
if (data.length != QrCode.getNumDataCodewords(ver, ecl)) if (data.length != QrCode.getNumDataCodewords(ver, ecl))
@ -405,7 +405,7 @@ namespace qrcodegen {
// Draws the given sequence of 8-bit codewords (data and error correction) onto the entire // Draws the given sequence of 8-bit codewords (data and error correction) onto the entire
// data area of this QR Code. Function modules need to be marked off before this is called. // data area of this QR Code. Function modules need to be marked off before this is called.
private drawCodewords(data: Array<byte>): void { private drawCodewords(data: Readonly<Array<byte>>): void {
if (data.length != Math.floor(QrCode.getNumRawDataModules(this.version) / 8)) if (data.length != Math.floor(QrCode.getNumRawDataModules(this.version) / 8))
throw "Invalid argument"; throw "Invalid argument";
let i: int = 0; // Bit index into the data let i: int = 0; // Bit index into the data
@ -613,7 +613,7 @@ namespace qrcodegen {
// Returns the Reed-Solomon error correction codeword for the given data and divisor polynomials. // Returns the Reed-Solomon error correction codeword for the given data and divisor polynomials.
private static reedSolomonComputeRemainder(data: Array<byte>, divisor: Array<byte>): Array<byte> { private static reedSolomonComputeRemainder(data: Readonly<Array<byte>>, divisor: Readonly<Array<byte>>): Array<byte> {
let result: Array<byte> = divisor.map(_ => 0); let result: Array<byte> = divisor.map(_ => 0);
for (const b of data) { // Polynomial division for (const b of data) { // Polynomial division
const factor: byte = b ^ (result.shift() as byte); const factor: byte = b ^ (result.shift() as byte);
@ -644,7 +644,7 @@ namespace qrcodegen {
// Can only be called immediately after a light run is added, and // Can only be called immediately after a light run is added, and
// returns either 0, 1, or 2. A helper function for getPenaltyScore(). // returns either 0, 1, or 2. A helper function for getPenaltyScore().
private finderPenaltyCountPatterns(runHistory: Array<int>): int { private finderPenaltyCountPatterns(runHistory: Readonly<Array<int>>): int {
const n: int = runHistory[1]; const n: int = runHistory[1];
if (n > this.size * 3) if (n > this.size * 3)
throw "Assertion error"; throw "Assertion error";
@ -746,7 +746,7 @@ namespace qrcodegen {
// Returns a segment representing the given binary data encoded in // Returns a segment representing the given binary data encoded in
// byte mode. All input byte arrays are acceptable. Any text string // byte mode. All input byte arrays are acceptable. Any text string
// can be converted to UTF-8 bytes and encoded as a byte mode segment. // can be converted to UTF-8 bytes and encoded as a byte mode segment.
public static makeBytes(data: Array<byte>): QrSegment { public static makeBytes(data: Readonly<Array<byte>>): QrSegment {
let bb: Array<bit> = [] let bb: Array<bit> = []
for (const b of data) for (const b of data)
appendBits(b, 8, bb); appendBits(b, 8, bb);
@ -870,7 +870,7 @@ namespace qrcodegen {
// (Package-private) Calculates and returns the number of bits needed to encode the given segments at // (Package-private) Calculates and returns the number of bits needed to encode the given segments at
// the given version. The result is infinity if a segment has too many characters to fit its length field. // the given version. The result is infinity if a segment has too many characters to fit its length field.
public static getTotalBits(segs: Array<QrSegment>, version: int): number { public static getTotalBits(segs: Readonly<Array<QrSegment>>, version: int): number {
let result: number = 0; let result: number = 0;
for (const seg of segs) { for (const seg of segs) {
const ccbits: int = seg.mode.numCharCountBits(version); const ccbits: int = seg.mode.numCharCountBits(version);

Loading…
Cancel
Save