From 4d45732c2f24a63f76cff2fc78a09844f34a0e84 Mon Sep 17 00:00:00 2001 From: Omikhleia Date: Fri, 8 Dec 2023 02:22:50 +0100 Subject: [PATCH 1/7] fix: Resilient manual fails to compile with Lua 5.1 --- packages/resilient/styles/init.lua | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/resilient/styles/init.lua b/packages/resilient/styles/init.lua index 2a2e687..4eecce2 100644 --- a/packages/resilient/styles/init.lua +++ b/packages/resilient/styles/init.lua @@ -563,14 +563,14 @@ function package:registerCommands () local hbox = SILE.typesetter:makeHbox(function () SILE.call("style:apply", { name = name }, { text }) end) - if hbox.width < 0 then + if hbox.width:tonumber() < 0 then SU.warn("Negative hbox width should not occur any more, please report an issue") end - local remainingSpace = hbox.width < 0 and -hbox.width or -beforekern:absolute() - hbox.width + local remainingSpace = hbox.width:tonumber() < 0 and -hbox.width or -beforekern:absolute() - hbox.width -- We want at least the space of a figure digit between the number -- and the text. - if remainingSpace:tonumber() - SILE.length("1nspc"):absolute() <= 0 then + if remainingSpace:tonumber() - SILE.length("1nspc"):tonumber() <= 0 then -- It's not the case, the number goes beyond the available space. -- So add a fixed interword space after it. SILE.call("style:apply", { name = name }, { text }) From e5e29bf1a5bc051885917c633990eb9e55f3687e Mon Sep 17 00:00:00 2001 From: Omikhleia Date: Fri, 8 Dec 2023 02:35:40 +0100 Subject: [PATCH 2/7] chore: Update Luacheck CI action and check for minimum Lua version See related commits in https://github.com/Omikhleia/markdown.sile/pull/101 Co-authored-by: Caleb Maclennan --- .github/workflows/luacheck.yml | 4 ++-- .luacheckrc | 11 +---------- 2 files changed, 3 insertions(+), 12 deletions(-) diff --git a/.github/workflows/luacheck.yml b/.github/workflows/luacheck.yml index e4576b7..9cb784c 100644 --- a/.github/workflows/luacheck.yml +++ b/.github/workflows/luacheck.yml @@ -8,6 +8,6 @@ jobs: runs-on: ubuntu-22.04 steps: - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Luacheck - uses: lunarmodules/luacheck@v0 + uses: lunarmodules/luacheck@v1 diff --git a/.luacheckrc b/.luacheckrc index a5d3578..f45e094 100644 --- a/.luacheckrc +++ b/.luacheckrc @@ -1,4 +1,4 @@ -std = "max" +std = "min+sile" include_files = { "**/*.lua", "sile.in", @@ -19,15 +19,6 @@ exclude_files = { files["**/*_spec.lua"] = { std = "+busted" } -globals = { - "SILE", - "SU", - "luautf8", - "pl", - "fluent", - "SYSTEM_SILE_PATH", - "SHARED_LIB_EXT" -} max_line_length = false ignore = { "581" -- operator order warning doesn't account for custom table metamethods From e8d0bb26c83da751ebb630689b5cf937a6152245 Mon Sep 17 00:00:00 2001 From: Omikhleia Date: Fri, 8 Dec 2023 11:33:27 +0100 Subject: [PATCH 3/7] refactor: Apply Lua "min" profile without math.log10 and math.pow Not a fix as those exist in Lua 5.1 to 5.4 at the time of writing, but were marked deprecated in 5.2 and 5.3... --- lua-libraries/README.tinyyaml | 2 ++ lua-libraries/resilient-tinyyaml.lua | 2 +- packages/resilient/bookmatters/init.lua | 7 +++++-- packages/resilient/poetry/init.lua | 4 +++- 4 files changed, 11 insertions(+), 4 deletions(-) diff --git a/lua-libraries/README.tinyyaml b/lua-libraries/README.tinyyaml index 9af1448..ea1f681 100644 --- a/lua-libraries/README.tinyyaml +++ b/lua-libraries/README.tinyyaml @@ -18,3 +18,5 @@ RESILIENT was to avoid a C binding dependency, since style files are reasonably small theoretically (so performance do not really matter) and only need a subset of YAML (so a pure-Lua implementation, even possibly incomplete, ought to be sufficient.) + +Modications are marked with comments MODIFIED RESILIENT diff --git a/lua-libraries/resilient-tinyyaml.lua b/lua-libraries/resilient-tinyyaml.lua index 85bec40..10cd45e 100644 --- a/lua-libraries/resilient-tinyyaml.lua +++ b/lua-libraries/resilient-tinyyaml.lua @@ -107,7 +107,7 @@ function types.timestamp:__init(y, m, d, h, i, s, f, z) self.minute = tonumber(i or 0) self.second = tonumber(s or 0) if type(f) == 'string' and sfind(f, '^%d+$') then - self.fraction = tonumber(f) * math.pow(10, 3 - #f) + self.fraction = tonumber(f) * 10^(3 - #f) -- MODIFIED RESILIENT Lua min compat elseif f then self.fraction = f else diff --git a/packages/resilient/bookmatters/init.lua b/packages/resilient/bookmatters/init.lua index c6d098b..0bc6248 100644 --- a/packages/resilient/bookmatters/init.lua +++ b/packages/resilient/bookmatters/init.lua @@ -77,7 +77,11 @@ end -- Source: https://www.nbdtech.com/Blog/archive/2008/04/27/Calculating-the-Perceived-Brightness-of-a-Color.aspx local function weightedColorDistanceIn3D (color) - return math.sqrt(math.pow(color.r * 255, 2) * 0.241 + math.pow(color.g * 255, 2) * 0.691 + math.pow(color.b * 255, 2) * 0.068) + return math.sqrt( + (color.r * 255)^2 * 0.241 + + (color.g * 255)^2 * 0.691 + + (color.b * 255)^2 * 0.068 + ) end local function contrastColor(color) if not color.r then @@ -160,7 +164,6 @@ function package:registerCommands () end if metadata["meta:isbn"] then - -- local H = SILE.measurement("100%fh"):tonumber() - SILE.measurement("40mm"):tonumber() SILE.call("skip", { height = offset }) SILE.call("kern", { width = SILE.nodefactory.hfillglue() }) SILE.call("framebox", { fillcolor = "white", padding = pad1, borderwidth = 0 }, { diff --git a/packages/resilient/poetry/init.lua b/packages/resilient/poetry/init.lua index a44baf8..8cf96b2 100644 --- a/packages/resilient/poetry/init.lua +++ b/packages/resilient/poetry/init.lua @@ -5,6 +5,7 @@ -- local ast = require("silex.ast") local createStructuredCommand = ast.createStructuredCommand +local LOG10 = math.log(10) local base = require("packages.resilient.base") @@ -178,7 +179,8 @@ function package:registerCommands () digitSize = SILE.shaper:measureChar("0").width end) local setback = SILE.length("1.75em"):absolute() - indent = SILE.length((math.floor(math.log10(nVerse + iVerse)) + 1) * digitSize):absolute() + local logv = math.floor(math.log(nVerse + iVerse) / LOG10) -- Reminder: math.log10 is not in Lua "min" profiile + indent = SILE.length((logv + 1) * digitSize):absolute() + setback + SILE.length(SILE.settings:get("document.parindent")):absolute() end From 28ed48c5e7f141b0e8f61c83b2b07846cfa3760a Mon Sep 17 00:00:00 2001 From: Omikhleia Date: Fri, 8 Dec 2023 15:35:23 +0100 Subject: [PATCH 4/7] chore: Add linting on vendored libraries On a second thought, we don't want troubles later, so let's also enforce our vendored content is checked. --- .luacheckrc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.luacheckrc b/.luacheckrc index f45e094..5fe0403 100644 --- a/.luacheckrc +++ b/.luacheckrc @@ -11,7 +11,7 @@ exclude_files = { "compare-*", "sile-*", "lua_modules", - "lua-libraries", + -- "lua-libraries", ".lua", ".luarocks", ".install" From 10e5c72e5386f105220f0f4541df02b907a372d2 Mon Sep 17 00:00:00 2001 From: Omikhleia Date: Fri, 8 Dec 2023 18:05:36 +0100 Subject: [PATCH 5/7] chore: Ignore acceptable lint warnings on vendored libraries --- .luacheckrc | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/.luacheckrc b/.luacheckrc index 5fe0403..70e3195 100644 --- a/.luacheckrc +++ b/.luacheckrc @@ -11,7 +11,6 @@ exclude_files = { "compare-*", "sile-*", "lua_modules", - -- "lua-libraries", ".lua", ".luarocks", ".install" @@ -19,6 +18,14 @@ exclude_files = { files["**/*_spec.lua"] = { std = "+busted" } +files["lua-libraries"] = { + -- matter of taste and not harmful + ignore = { + "211", -- unused function / unused variable + "212/self", -- unused argument self + "412", --variable was previously defined as an argument + } +} max_line_length = false ignore = { "581" -- operator order warning doesn't account for custom table metamethods From bfcc8d87757219196cf100069fb0f9b4a1c295b1 Mon Sep 17 00:00:00 2001 From: Omikhleia Date: Fri, 8 Dec 2023 18:07:20 +0100 Subject: [PATCH 6/7] fix: YAML error on array of multiline string Synchronized tinyyaml vendored copy with api7's v0.4.4 --- lua-libraries/README.tinyyaml | 3 +-- lua-libraries/resilient-tinyyaml.lua | 4 +++- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/lua-libraries/README.tinyyaml b/lua-libraries/README.tinyyaml index ea1f681..a70d773 100644 --- a/lua-libraries/README.tinyyaml +++ b/lua-libraries/README.tinyyaml @@ -1,6 +1,5 @@ The "vendored" version of tinyyaml used here is: -https://github.com/api7/lua-tinyyaml (0.4.3 rockspec at the time of initial -import) +https://github.com/api7/lua-tinyyaml (0.4.4 rockspec) It's a fork from: https://github.com/peposso/lua-tinyyaml (which had a 1.0 rockspec earlier) diff --git a/lua-libraries/resilient-tinyyaml.lua b/lua-libraries/resilient-tinyyaml.lua index 10cd45e..a1521ff 100644 --- a/lua-libraries/resilient-tinyyaml.lua +++ b/lua-libraries/resilient-tinyyaml.lua @@ -611,8 +611,10 @@ function Parser:parseseq(line, lines, indent) error("did not find expected alphabetic or numeric character") elseif rest then -- Array entry with a value + local nextline = lines[1] + local indent2 = countindent(nextline) tremove(lines, 1) - tinsert(seq, self:parsescalar(rest, lines)) + tinsert(seq, self:parsescalar(rest, lines, indent2)) end end return seq From bc3f04fb3c370f73ea7681a4d0e099ce8d3b2261 Mon Sep 17 00:00:00 2001 From: Omikhleia Date: Fri, 8 Dec 2023 18:41:25 +0100 Subject: [PATCH 7/7] fix: Add more robustness to master document parsing --- inputters/silm.lua | 2 +- lua-libraries/resilient-tinyyaml.lua | 5 +++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/inputters/silm.lua b/inputters/silm.lua index 2435d22..2bda4d0 100644 --- a/inputters/silm.lua +++ b/inputters/silm.lua @@ -578,7 +578,7 @@ function inputter:parse (doc) end -- Document wrap-up - local options = master.sile.options or {} + local options = sile.options or {} local classopts = isRoot and { class = options.class or "resilient.book", -- Sane default. We Are Resilient. papersize = options.papersize, diff --git a/lua-libraries/resilient-tinyyaml.lua b/lua-libraries/resilient-tinyyaml.lua index a1521ff..0dc2c53 100644 --- a/lua-libraries/resilient-tinyyaml.lua +++ b/lua-libraries/resilient-tinyyaml.lua @@ -775,6 +775,11 @@ end -- : (list)->dict function Parser:parsedocuments(lines) lines = compactifyemptylines(lines) + -- BEGIN MODIFIED RESILIENT + if #lines == 0 then + return {} + end + -- END MODIFIED RESILIENT if sfind(lines[1], '^%%YAML') then tremove(lines, 1) end