From 57dee4c91b0941faf60b0535cc86cd28c0e8e3e3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Albin=20Wahl=C3=A9n?= <63047114+wahlencraft@users.noreply.github.com> Date: Sat, 26 Mar 2022 18:58:50 +0100 Subject: [PATCH 01/11] Fix temp widget show N/A when no sensor found (#528) --- widget/temp.lua | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/widget/temp.lua b/widget/temp.lua index bafdcdc..f267283 100644 --- a/widget/temp.lua +++ b/widget/temp.lua @@ -32,7 +32,11 @@ local function factory(args) temp_now[t] = temp_value and temp_value/1e3 or temp_fl end end - coretemp_now = string.format(format, temp_now[tempfile]) or "N/A" + if temp_now[tempfile] then + coretemp_now = string.format(format, temp_now[tempfile]) + else + coretemp_now = "N/A" + end widget = temp.widget settings() end) From 0df20e38bbd047c1afea46ab25e8ecf758bb5d45 Mon Sep 17 00:00:00 2001 From: Luca Capezzuto Date: Sat, 26 Mar 2022 12:11:15 -0600 Subject: [PATCH 02/11] fixed rockspec --- lain-scm-1.rockspec | 10 +++------- wiki | 2 +- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/lain-scm-1.rockspec b/lain-scm-1.rockspec index 6a76aba..70b0f43 100644 --- a/lain-scm-1.rockspec +++ b/lain-scm-1.rockspec @@ -6,16 +6,12 @@ source = { } description = { summary = "Layout, widgets and utilities for Awesome WM", - detailed = [[ - Successor of awesome-vain, this module provides alternative layouts, asynchronous widgets and utility functions for Awesome WM. - - Dependencies: curl (for IMAP, MPD and weather widgets); Glib >= 2.54 (for filesystems widget). - ]], + detailed = "Alternative layouts, asynchronous widgets and utility functions for Awesome WM. Non-Lua dependency: curl (for IMAP, MPD and weather widgets).", homepage = "https://github.com/lcpz/lain", - license = "GPL-2.0" + license = "GPL2" } dependencies = { - "lua >= 5.1", + "lua >= 5.3", "dkjson >= 2.6-1" } supported_platforms = { "linux" } diff --git a/wiki b/wiki index 74a423d..ad8081c 160000 --- a/wiki +++ b/wiki @@ -1 +1 @@ -Subproject commit 74a423dac2c8ea2f0f6827b209aa6de9b741a3a1 +Subproject commit ad8081cb3e3cb336323d1f72d34c7c8304490b14 From 29f8d1fc361ee0f0b11fb08cccaa0a0a5b93aa48 Mon Sep 17 00:00:00 2001 From: Neville Li Date: Wed, 11 May 2022 12:04:57 -0400 Subject: [PATCH 03/11] exclude minimized windows in centerwork focus/swap (#530) --- layout/centerwork.lua | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/layout/centerwork.lua b/layout/centerwork.lua index 142ccbe..aeb2efb 100644 --- a/layout/centerwork.lua +++ b/layout/centerwork.lua @@ -208,7 +208,10 @@ end local function clients_by_position() local this = client.focus if this then - local sorted = client.focus.first_tag:clients() + local sorted = {} + for _, c in ipairs(client.focus.first_tag:clients()) do + if not c.minimized then sorted[#sorted+1] = c end + end table.sort(sorted, compare_position) local idx = 0 From 5403835b961f5bf173fc2da265dbd4aed0324864 Mon Sep 17 00:00:00 2001 From: Luca Capezzuto Date: Sat, 11 Jun 2022 11:26:23 +0200 Subject: [PATCH 04/11] Some linting - layout/centerwork: specify client as a dependency, improve logic at lines 141, 149 - widget/temp: remove whitespace Signed-off-by: Luca Capezzuto --- layout/centerwork.lua | 23 ++++++++++++++--------- widget/temp.lua | 2 +- 2 files changed, 15 insertions(+), 10 deletions(-) diff --git a/layout/centerwork.lua b/layout/centerwork.lua index aeb2efb..528d19e 100644 --- a/layout/centerwork.lua +++ b/layout/centerwork.lua @@ -10,7 +10,12 @@ --]] -local floor, max, mouse, mousegrabber, screen = math.floor, math.max, mouse, mousegrabber, screen +local floor = math.floor +local max = math.max +local mouse = mouse +local mousegrabber = mousegrabber +local screen = screen +local client = client local centerwork = { name = "centerwork", @@ -138,7 +143,7 @@ local function mouse_resize_handler(c, _, _, _, orientation) if g.height + 15 >= wa.height then offset = g.height * .5 cursor = "sb_h_double_arrow" - elseif not (g.y + g.height + 15 > wa.y + wa.height) then + elseif g.y + g.height + 15 <= wa.y + wa.height then offset = g.height end corner_coords = { x = wa.x + wa.width * (1 - mwfact) / 2, y = g.y + offset } @@ -146,7 +151,7 @@ local function mouse_resize_handler(c, _, _, _, orientation) if g.width + 15 >= wa.width then offset = g.width * .5 cursor = "sb_v_double_arrow" - elseif not (g.x + g.width + 15 > wa.x + wa.width) then + elseif g.x + g.width + 15 <= wa.x + wa.width then offset = g.width end corner_coords = { y = wa.y + wa.height * (1 - mwfact) / 2, x = g.x + offset } @@ -156,22 +161,22 @@ local function mouse_resize_handler(c, _, _, _, orientation) local prev_coords = {} - mousegrabber.run(function(_mouse) + mousegrabber.run(function(m) if not c.valid then return false end - for _, v in ipairs(_mouse.buttons) do + for _, v in ipairs(m.buttons) do if v then - prev_coords = { x = _mouse.x, y = _mouse.y } + prev_coords = { x = m.x, y = m.y } local new_mwfact if orientation == 'vertical' then - new_mwfact = 1 - (_mouse.x - wa.x) / wa.width * 2 + new_mwfact = 1 - (m.x - wa.x) / wa.width * 2 else - new_mwfact = 1 - (_mouse.y - wa.y) / wa.height * 2 + new_mwfact = 1 - (m.y - wa.y) / wa.height * 2 end c.screen.selected_tag.master_width_factor = math.min(math.max(new_mwfact, 0.01), 0.99) return true end end - return prev_coords.x == _mouse.x and prev_coords.y == _mouse.y + return prev_coords.x == m.x and prev_coords.y == m.y end, cursor) end diff --git a/widget/temp.lua b/widget/temp.lua index f267283..99f8700 100644 --- a/widget/temp.lua +++ b/widget/temp.lua @@ -33,7 +33,7 @@ local function factory(args) end end if temp_now[tempfile] then - coretemp_now = string.format(format, temp_now[tempfile]) + coretemp_now = string.format(format, temp_now[tempfile]) else coretemp_now = "N/A" end From dbf6e9cfb142533a360c1c4096b2fc491da8d97f Mon Sep 17 00:00:00 2001 From: Luca Capezzuto Date: Sat, 11 Jun 2022 11:33:40 +0200 Subject: [PATCH 05/11] layout/centerwork: fix comments/spacing style Signed-off-by: Luca Capezzuto --- layout/centerwork.lua | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/layout/centerwork.lua b/layout/centerwork.lua index 528d19e..c105676 100644 --- a/layout/centerwork.lua +++ b/layout/centerwork.lua @@ -15,7 +15,6 @@ local max = math.max local mouse = mouse local mousegrabber = mousegrabber local screen = screen -local client = client local centerwork = { name = "centerwork", @@ -196,11 +195,14 @@ function centerwork.horizontal.mouse_resize_handler(c, corner, x, y) return mouse_resize_handler(c, corner, x, y, 'horizontal') end -------------------------------------------------------------------------------- --- make focus.byidx and swap.byidx behave more consistently with other layouts + +--[[ +Make focus.byidx and swap.byidx behave more consistently with other layouts. +--]] local awful = require("awful") local gears = require("gears") +local client = client local function compare_position(a, b) if a.x == b.x then @@ -242,10 +244,9 @@ centerwork.focus = {} --[[ Drop in replacements for awful.client.focus.byidx and awful.client.swap.byidx -that behaves consistently with other layouts +that behaves consistently with other layouts. --]] - function centerwork.focus.byidx(i) if in_centerwork() then local cls = clients_by_position() From aa2f9138f46cde9ab36d6d5f086e5cbf9319cc8e Mon Sep 17 00:00:00 2001 From: Thomas Croft <103956335+thomascft@users.noreply.github.com> Date: Sat, 11 Jun 2022 03:39:21 -0600 Subject: [PATCH 06/11] Automated testing with Luacheck (#533) --- .github/workflows/main.yml | 12 ++++++++++++ .luacheckrc | 11 +++++++++++ 2 files changed, 23 insertions(+) create mode 100644 .github/workflows/main.yml create mode 100644 .luacheckrc diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml new file mode 100644 index 0000000..2959d64 --- /dev/null +++ b/.github/workflows/main.yml @@ -0,0 +1,12 @@ +name: Luacheck +on: [push] +jobs: + Luacheck_Tests: + runs-on: ubuntu-latest + steps: + - run: echo "Running tests triggered by a ${{ github.event_name }} event." + - run: echo "Testing ${{ github.ref }} from ${{ github.repository }} on ${{ runner.os }}" + - name: Check out code + uses: actions/checkout@v3 + - name: Run tests + uses: lunarmodules/luacheck@v0 diff --git a/.luacheckrc b/.luacheckrc new file mode 100644 index 0000000..5889780 --- /dev/null +++ b/.luacheckrc @@ -0,0 +1,11 @@ +codes = true +allow_defined = true +max_line_length = false + +globals = { + "client", "screen", "mouse" +} + +ignore = { + "131", +} From 853946b6653da07fd7f7f1923b072bee4045a652 Mon Sep 17 00:00:00 2001 From: Luca Capezzuto Date: Sat, 11 Jun 2022 11:51:02 +0200 Subject: [PATCH 07/11] Luacheck: ignore W113 too; GitHub Action: specify permissions Ignoring W113 safely avoids warnings due to Awesome modules not found by Luacheck. Signed-off-by: Luca Capezzuto --- .github/workflows/main.yml | 18 ++++++++++++------ .luacheckrc | 4 +++- 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 2959d64..70635ae 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -1,12 +1,18 @@ -name: Luacheck +name: Lain + on: [push] -jobs: - Luacheck_Tests: + +permissions: + contents: read + +jobs: + linting: runs-on: ubuntu-latest steps: - - run: echo "Running tests triggered by a ${{ github.event_name }} event." - - run: echo "Testing ${{ github.ref }} from ${{ github.repository }} on ${{ runner.os }}" + - run: | + echo "Running tests triggered by a ${{ github.event_name }} event." + echo "Testing ${{ github.ref }} from ${{ github.repository }} on ${{ runner.os }}" - name: Check out code uses: actions/checkout@v3 - name: Run tests - uses: lunarmodules/luacheck@v0 + uses: lunarmodules/luacheck@v0 diff --git a/.luacheckrc b/.luacheckrc index 5889780..811a783 100644 --- a/.luacheckrc +++ b/.luacheckrc @@ -6,6 +6,8 @@ globals = { "client", "screen", "mouse" } +-- https://luacheck.readthedocs.io/en/stable/warnings.html ignore = { - "131", + "113", + "131" } From 4b5c98612cf9e05f1a99aacf00d6c5e5d35a6ab3 Mon Sep 17 00:00:00 2001 From: Luca Capezzuto Date: Sat, 11 Jun 2022 12:00:07 +0200 Subject: [PATCH 08/11] README: add workflow badge Signed-off-by: Luca Capezzuto --- .github/workflows/main.yml | 5 ++--- README.rst | 2 ++ 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 70635ae..37957f6 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -9,9 +9,8 @@ jobs: linting: runs-on: ubuntu-latest steps: - - run: | - echo "Running tests triggered by a ${{ github.event_name }} event." - echo "Testing ${{ github.ref }} from ${{ github.repository }} on ${{ runner.os }}" + - run: echo "Running tests triggered by a ${{ github.event_name }} event." + - run: echo "Testing ${{ github.ref }} from ${{ github.repository }} on ${{ runner.os }}" - name: Check out code uses: actions/checkout@v3 - name: Run tests diff --git a/README.rst b/README.rst index 3d2f13f..616c7cd 100644 --- a/README.rst +++ b/README.rst @@ -1,6 +1,8 @@ Lain ==== +.. image:: https://github.com/lcpz/lain/actions/workflows/main.yml/badge.svg + ------------------------------------------------- Layouts, widgets and utilities for Awesome WM 4.x ------------------------------------------------- From c7c50bbf8c7e13d07e4196a78481852c25e5f084 Mon Sep 17 00:00:00 2001 From: Luca Capezzuto Date: Sat, 11 Jun 2022 12:07:45 +0200 Subject: [PATCH 09/11] luacheck: fix dkjson warnings Signed-off-by: Luca Capezzuto --- util/dkjson.lua | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/util/dkjson.lua b/util/dkjson.lua index fadb5ef..61cccb9 100644 --- a/util/dkjson.lua +++ b/util/dkjson.lua @@ -42,8 +42,8 @@ SOFTWARE. --]==] -- global dependencies: -local pairs, type, tostring, tonumber, getmetatable, setmetatable, rawset = - pairs, type, tostring, tonumber, getmetatable, setmetatable, rawset +local pairs, type, tostring, tonumber, getmetatable, setmetatable = + pairs, type, tostring, tonumber, getmetatable, setmetatable local error, require, pcall, select = error, require, pcall, select local floor, huge = math.floor, math.huge local strrep, gsub, strsub, strbyte, strchar, strfind, strlen, strformat = @@ -64,7 +64,7 @@ if register_global_module_table then end end -local _ENV = nil -- blocking globals in Lua 5.2 and later +_ENV = nil -- blocking globals in Lua 5.2 and later pcall (function() -- Enable access to blocked metatables. @@ -252,7 +252,7 @@ local function exception(reason, value, state, buffer, buflen, defaultmessage) end end -function json.encodeexception(reason, value, state, defaultmessage) +function json.encodeexception(_reason, _value, _state, defaultmessage) return quotestring("<" .. defaultmessage .. ">") end @@ -327,7 +327,7 @@ encode2 = function (value, indent, level, buffer, buflen, tables, globalorder, s local v = value[k] if v ~= nil then used[k] = true - buflen, msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state) + buflen, _msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state) prev = true -- add a seperator before the next element end end @@ -510,7 +510,6 @@ end local scanvalue -- forward declaration local function scantable (what, closechar, str, startpos, nullval, objectmeta, arraymeta) - local len = strlen (str) local tbl, n = {}, 0 local pos = startpos + 1 if what == 'object' then @@ -640,7 +639,7 @@ function json.use_lpeg () local PlainChar = 1 - S"\"\\\n\r" local EscapeSequence = (P"\\" * g.C (S"\"\\/bfnrt" + Err "unsupported escape sequence")) / escapechars local HexDigit = R("09", "af", "AF") - local function UTF16Surrogate (match, pos, high, low) + local function UTF16Surrogate (_match, _pos, high, low) high, low = tonumber (high, 16), tonumber (low, 16) if 0xD800 <= high and high <= 0xDBff and 0xDC00 <= low and low <= 0xDFFF then return true, unichar ((high - 0xD800) * 0x400 + (low - 0xDC00) + 0x10000) From 17036612738e6adad581aad991643566840cc4aa Mon Sep 17 00:00:00 2001 From: Luca Capezzuto Date: Sat, 11 Jun 2022 12:25:17 +0200 Subject: [PATCH 10/11] luacheck: add global objects, ignore W131 only Inspired by AwesomeWM's luacheckrc: https://github.com/awesomeWM/awesome/blob/master/.luacheckrc Signed-off-by: Luca Capezzuto --- .luacheckrc | 20 +++++++++++++++++--- helpers.lua | 20 ++++++++++---------- 2 files changed, 27 insertions(+), 13 deletions(-) diff --git a/.luacheckrc b/.luacheckrc index 811a783..9944223 100644 --- a/.luacheckrc +++ b/.luacheckrc @@ -1,13 +1,27 @@ -codes = true +-- Only allow symbols available in all Lua versions +std = "min" + allow_defined = true max_line_length = false +cache = true + +-- Global objects defined by the C code +read_globals = { + "awesome", + "mousegrabber", + "table.unpack", + "unpack", + "utf8" +} globals = { - "client", "screen", "mouse" + "client", + "mouse", + "root", + "screen" } -- https://luacheck.readthedocs.io/en/stable/warnings.html ignore = { - "113", "131" } diff --git a/helpers.lua b/helpers.lua index 45f090f..ef9e08b 100644 --- a/helpers.lua +++ b/helpers.lua @@ -5,15 +5,15 @@ --]] -local spawn = require("awful.spawn") -local timer = require("gears.timer") -local debug = require("debug") -local io = { lines = io.lines, - open = io.open } -local pairs = pairs -local rawget = rawget -local table = { sort = table.sort, unpack = table.unpack } -local unpack = unpack or table.unpack -- lua 5.1 retro-compatibility +local spawn = require("awful.spawn") +local timer = require("gears.timer") +local debug = require("debug") +local io = { lines = io.lines, + open = io.open } +local pairs = pairs +local rawget = rawget +local tsort = table.sort +local unpack = unpack or table.unpack -- lua 5.1 retro-compatibility -- Lain helper functions for internal use -- lain.helpers @@ -164,7 +164,7 @@ function helpers.spairs(t) local keys = {} for k in pairs(t) do keys[#keys+1] = k end - table.sort(keys) + tsort(keys) -- return the iterator function local i = 0 From c489aa63acc1364851e0e51152be3db5c75e145d Mon Sep 17 00:00:00 2001 From: Teivel <41545008+DemonInTheCloset@users.noreply.github.com> Date: Sat, 25 Jun 2022 13:43:16 +0200 Subject: [PATCH 11/11] fix(#485): Separators not following theme (#535) * fix(util/separators): Not following theme Fix issue #485 `lain.util.separators` not following theme variables separators_width and separators_height as stated in the wiki * fix: Removed redundant parenthesis --- util/separators.lua | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/util/separators.lua b/util/separators.lua index ae384ec..04402bb 100644 --- a/util/separators.lua +++ b/util/separators.lua @@ -8,10 +8,11 @@ local wibox = require("wibox") local gears = require("gears") +local beautiful = require("beautiful") -- Lain Cairo separators util submodule -- lain.util.separators -local separators = { height = 0, width = 9 } +local separators = { height = beautiful.separators_height or 0, width = beautiful.separators_width or 9 } -- [[ Arrow