From 2b1a59e963a3610c8f664af3dd6b03afb8d89646 Mon Sep 17 00:00:00 2001 From: Tan Kian-ting Date: Mon, 20 Nov 2023 22:15:09 +0800 Subject: [PATCH] fix unused return --- output.pdf | Bin 11595 -> 11725 bytes src/libclo/breakLines.js | 125 ++++++++++++++++++++++----------------- src/libclo/breakLines.ts | 1 - 3 files changed, 70 insertions(+), 56 deletions(-) diff --git a/output.pdf b/output.pdf index bc6726d751a135616456c426ed0e9d5acf11aae2..14c2d0a1620fd37abbcf87e13c1239a1d1b706b6 100644 GIT binary patch delta 5711 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 akMIqPK!pWdkTW$k0b0xH={dMN%KZnAF$aYJ diff --git a/src/libclo/breakLines.js b/src/libclo/breakLines.js index f194aa5..cdd4f6e 100644 --- a/src/libclo/breakLines.js +++ b/src/libclo/breakLines.js @@ -1,4 +1,13 @@ "use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; Object.defineProperty(exports, "__esModule", { value: true }); exports.BreakLineAlgorithm = void 0; /** @@ -72,25 +81,27 @@ class BreakLineAlgorithm { * check all the total cost of paragraphes of the segnemt */ totalCost(items, lineWidth) { - let lineWidthFixed = lineWidth * 0.75; - let itemsLength = items.length; - this.lineCostStorage = Array(itemsLength); - this.prevNodes = Array(itemsLength).fill(null); - for (var i = 0; i < itemsLength; i++) { - this.lineCostStorage[i] = Array(itemsLength).fill(null); - } - this.totalCostAuxStorage = Array(itemsLength).fill(null); - let a = Infinity; - for (var k = itemsLength - 2; this.lineCost(items, k + 1, itemsLength - 1, lineWidthFixed) < Infinity; k--) { - let tmp = this.totalCostAux(items, k, lineWidthFixed); - if (a > tmp) { - this.prevNodes[itemsLength - 1] = k; - a = tmp; + return __awaiter(this, void 0, void 0, function* () { + let lineWidthFixed = lineWidth * 0.75; + let itemsLength = items.length; + this.lineCostStorage = Array(itemsLength); + this.prevNodes = Array(itemsLength).fill(null); + for (var i = 0; i < itemsLength; i++) { + this.lineCostStorage[i] = Array(itemsLength).fill(null); } - } - console.log("~~~", lineWidth); - console.log(items[itemsLength - 2]); - return a; + this.totalCostAuxStorage = Array(itemsLength).fill(null); + let a = Infinity; + for (var k = itemsLength - 2; (yield this.lineCost(items, k + 1, itemsLength - 1, lineWidthFixed)) < Infinity; k--) { + let tmp = yield this.totalCostAux(items, k, lineWidthFixed); + if (a > tmp) { + this.prevNodes[itemsLength - 1] = k; + a = tmp; + } + } + console.log("~~~", lineWidth); + console.log(items[itemsLength - 2]); + return a; + }); } /** * check the total cost item[0..j]. @@ -99,27 +110,29 @@ class BreakLineAlgorithm { * @param lineWidth */ totalCostAux(items, j, lineWidth) { - if (this.totalCostAuxStorage[j] !== null) { - return this.totalCostAuxStorage[j]; - } - let rawLineCost = this.lineCost(items, 0, j, lineWidth); - if (rawLineCost != Infinity) { - this.totalCostAuxStorage[j] = rawLineCost ** 3.0; - return rawLineCost ** 3.0; - } - else { - var returnCost = Infinity; - for (var k = 0; k < j; k++) { - let tmp = this.totalCostAux(items, k, lineWidth) + this.lineCost(items, k + 1, j, lineWidth) ** 3.0; - if (returnCost > tmp) { - this.prevNodes[j] = k; - returnCost = tmp; - } + return __awaiter(this, void 0, void 0, function* () { + if (this.totalCostAuxStorage[j] !== null) { + return this.totalCostAuxStorage[j]; } - this.totalCostAuxStorage[j] = returnCost; - return returnCost; - } - return returnCost; + let rawLineCost = yield this.lineCost(items, 0, j, lineWidth); + if (rawLineCost != Infinity) { + this.totalCostAuxStorage[j] = rawLineCost ** 3.0; + return rawLineCost ** 3.0; + } + else { + var returnCost = Infinity; + for (var k = 0; k < j; k++) { + let tmp1 = yield Promise.all([this.totalCostAux(items, k, lineWidth), this.lineCost(items, k + 1, j, lineWidth)]); + let tmp = tmp1[0] + tmp1[1] ** 3; + if (returnCost > tmp) { + this.prevNodes[j] = k; + returnCost = tmp; + } + } + this.totalCostAuxStorage[j] = returnCost; + return returnCost; + } + }); } /** * check the line cost of a line containing items[i..j] @@ -129,29 +142,31 @@ class BreakLineAlgorithm { * @param lineWidth line width */ lineCost(items, i, j, lineWidth) { - if (this.lineCostStorage[i] !== null && this.lineCostStorage[i][j] !== null) { - return this.lineCostStorage[i][j]; - } - if (!this.isBreakPoint(items[j])) { - this.lineCostStorage[i][j] = Infinity; - return Infinity; - } - else { - var tmpItemWidth = 0; - for (var k = i; k < j; k++) { - tmpItemWidth += this.origWidth(items[k]); + return __awaiter(this, void 0, void 0, function* () { + if (this.lineCostStorage[i] !== null && this.lineCostStorage[i][j] !== null) { + return this.lineCostStorage[i][j]; } - tmpItemWidth += this.newLineWidth(items[j]); - if (tmpItemWidth > lineWidth) { + if (!this.isBreakPoint(items[j])) { this.lineCostStorage[i][j] = Infinity; return Infinity; } else { - let returnValue = (lineWidth - tmpItemWidth); - this.lineCostStorage[i][j] = returnValue; - return returnValue; + var tmpItemWidth = 0; + for (var k = i; k < j; k++) { + tmpItemWidth += this.origWidth(items[k]); + } + tmpItemWidth += this.newLineWidth(items[j]); + if (tmpItemWidth > lineWidth) { + this.lineCostStorage[i][j] = Infinity; + return Infinity; + } + else { + let returnValue = (lineWidth - tmpItemWidth); + this.lineCostStorage[i][j] = returnValue; + return returnValue; + } } - } + }); } } exports.BreakLineAlgorithm = BreakLineAlgorithm; diff --git a/src/libclo/breakLines.ts b/src/libclo/breakLines.ts index fba0282..f761b18 100644 --- a/src/libclo/breakLines.ts +++ b/src/libclo/breakLines.ts @@ -150,7 +150,6 @@ export class BreakLineAlgorithm { } - return returnCost; }