Merge pull request #2592 from Sorky/patch-1
beautiful.init: Fix return values and improve doco. fixes: #2588
This commit is contained in:
commit
e8bf75ef3c
|
@ -180,28 +180,57 @@ function beautiful.get_font_height(name)
|
||||||
return load_font(name).height
|
return load_font(name).height
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Init function, should be run at the beginning of configuration file.
|
--- Function that initializes the theme settings. Should be run at the
|
||||||
|
-- beginning of the awesome configuration file (normally rc.lua).
|
||||||
|
--
|
||||||
|
-- Example usages:
|
||||||
|
--
|
||||||
|
-- -- Using a table
|
||||||
|
-- beautiful.init({font = 'Monospace Bold 10'})
|
||||||
|
--
|
||||||
|
-- -- From a config file
|
||||||
|
-- beautiful.init("<path>/theme.lua")
|
||||||
|
--
|
||||||
|
-- Example "<path>/theme.lua" (see `05-awesomerc.md:Variable_definitions`):
|
||||||
|
--
|
||||||
|
-- theme = {}
|
||||||
|
-- theme.font = 'Monospace Bold 10'
|
||||||
|
-- return theme
|
||||||
|
--
|
||||||
|
-- Example using the return value:
|
||||||
|
--
|
||||||
|
-- local beautiful = require("beautiful")
|
||||||
|
-- if not beautiful.init("<path>/theme.lua") then
|
||||||
|
-- beautiful.init("<path>/.last.theme.lua") -- a known good fallback
|
||||||
|
-- end
|
||||||
|
--
|
||||||
-- @tparam string|table config The theme to load. It can be either the path to
|
-- @tparam string|table config The theme to load. It can be either the path to
|
||||||
-- the theme file (returning a table) or directly the table
|
-- the theme file (which should return a table) or directly a table
|
||||||
-- containing all the theme values.
|
-- containing all the theme values.
|
||||||
|
-- @treturn true|nil True if successful, nil in case of error.
|
||||||
function beautiful.init(config)
|
function beautiful.init(config)
|
||||||
if config then
|
if config then
|
||||||
|
local state, t_theme = nil, nil
|
||||||
local homedir = os.getenv("HOME")
|
local homedir = os.getenv("HOME")
|
||||||
|
|
||||||
-- If `config` is the path to a theme file, run this file,
|
-- If `config` is the path to a theme file, run this file,
|
||||||
-- otherwise if it is a theme table, save it.
|
-- otherwise if it is a theme table, save it.
|
||||||
if type(config) == 'string' then
|
local t_config = type(config)
|
||||||
|
if t_config == 'string' then
|
||||||
-- Expand the '~' $HOME shortcut
|
-- Expand the '~' $HOME shortcut
|
||||||
config = config:gsub("^~/", homedir .. "/")
|
config = config:gsub("^~/", homedir .. "/")
|
||||||
local dir = Gio.File.new_for_path(config):get_parent()
|
local dir = Gio.File.new_for_path(config):get_parent()
|
||||||
rawset(beautiful, "theme_path", dir and (dir:get_path().."/") or nil)
|
rawset(beautiful, "theme_path", dir and (dir:get_path().."/") or nil)
|
||||||
theme = protected_call(dofile, config)
|
theme = protected_call(dofile, config)
|
||||||
elseif type(config) == 'table' then
|
t_theme = type(theme)
|
||||||
|
state = t_theme == 'table' and next(theme)
|
||||||
|
elseif t_config == 'table' then
|
||||||
rawset(beautiful, "theme_path", nil)
|
rawset(beautiful, "theme_path", nil)
|
||||||
theme = config
|
theme = config
|
||||||
|
state = next(theme)
|
||||||
end
|
end
|
||||||
|
|
||||||
if theme then
|
if state then
|
||||||
-- expand '~'
|
-- expand '~'
|
||||||
if homedir then
|
if homedir then
|
||||||
for k, v in pairs(theme) do
|
for k, v in pairs(theme) do
|
||||||
|
@ -210,9 +239,16 @@ function beautiful.init(config)
|
||||||
end
|
end
|
||||||
|
|
||||||
if theme.font then set_font(theme.font) end
|
if theme.font then set_font(theme.font) end
|
||||||
|
return true
|
||||||
else
|
else
|
||||||
|
rawset(beautiful, "theme_path", nil)
|
||||||
theme = {}
|
theme = {}
|
||||||
return gears_debug.print_error("beautiful: error loading theme file " .. config)
|
local file = t_config == 'string' and (" from: " .. config)
|
||||||
|
local err = (file and t_theme == 'table' and "got an empty table" .. file)
|
||||||
|
or (file and t_theme ~= 'table' and "got a " .. t_theme .. file)
|
||||||
|
or (t_config == 'table' and "got an empty table")
|
||||||
|
or ("got a " .. t_config)
|
||||||
|
return gears_debug.print_error("beautiful: error loading theme: " .. err)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
return gears_debug.print_error("beautiful: error loading theme: no theme specified")
|
return gears_debug.print_error("beautiful: error loading theme: no theme specified")
|
||||||
|
|
|
@ -0,0 +1,80 @@
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
-- @author
|
||||||
|
-- @copyright 2019
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
local beautiful = require("beautiful")
|
||||||
|
local gdebug = require("gears.debug")
|
||||||
|
|
||||||
|
describe("beautiful init", function()
|
||||||
|
local dir = (os.getenv("SOURCE_DIRECTORY") or '.') .. "/spec/beautiful/tests/"
|
||||||
|
local shim
|
||||||
|
|
||||||
|
-- Check beautiful.get_font and get_merged_font
|
||||||
|
it('Check beautiful.get_font', function()
|
||||||
|
assert.is_same(beautiful.get_font("Monospace Bold 12"),
|
||||||
|
beautiful.get_merged_font("Monospace 12", "Bold"))
|
||||||
|
end)
|
||||||
|
|
||||||
|
-- Check beautiful.get_font_height
|
||||||
|
it('Check beautiful.get_font_height', function()
|
||||||
|
-- TODO: Will requires lgi-dpi
|
||||||
|
end)
|
||||||
|
|
||||||
|
-- Check beautiful.init
|
||||||
|
it('Check beautiful.init', function()
|
||||||
|
-- Check the error messages (needs a shim)
|
||||||
|
shim = gdebug.print_error
|
||||||
|
gdebug.print_error = function(message) error(message) end
|
||||||
|
|
||||||
|
assert.has_error(function() beautiful.init({}) end,
|
||||||
|
"beautiful: error loading theme: got an empty table")
|
||||||
|
assert.has_error(function() beautiful.init(dir .. "Bad_1.lua") end,
|
||||||
|
"beautiful: error loading theme: got an empty table from: " .. dir .. "Bad_1.lua")
|
||||||
|
assert.has_error(function() beautiful.init(dir .. "Bad_2.lua") end,
|
||||||
|
"beautiful: error loading theme: got a function from: " .. dir .. "Bad_2.lua")
|
||||||
|
assert.has_error(function() beautiful.init(dir .. "Bad_3.lua") end,
|
||||||
|
"beautiful: error loading theme: got a number from: " .. dir .. "Bad_3.lua")
|
||||||
|
assert.has_error(function() beautiful.init(dir .. "Bad_4.lua") end,
|
||||||
|
"beautiful: error loading theme: got a nil from: " .. dir .. "Bad_4.lua")
|
||||||
|
assert.has_error(function() beautiful.init(dir .. "Bad_5.lua") end,
|
||||||
|
"beautiful: error loading theme: got a nil from: " .. dir .. "Bad_5.lua")
|
||||||
|
assert.has_error(function() beautiful.init(dir .. "NO_FILE") end,
|
||||||
|
"beautiful: error loading theme: got a nil from: " .. dir .. "NO_FILE")
|
||||||
|
|
||||||
|
assert.has_no_error(function() beautiful.init({ font = "Monospace Bold 12" }) end, "")
|
||||||
|
assert.has_no_error(function() beautiful.init(dir .. "Good.lua") end, "")
|
||||||
|
|
||||||
|
-- Check the return values (remove the shim)
|
||||||
|
gdebug.print_error = shim
|
||||||
|
|
||||||
|
assert.is_nil(beautiful.init({}))
|
||||||
|
assert.is_nil(beautiful.init(dir .. "Bad_1.lua"))
|
||||||
|
assert.is_nil(beautiful.init(dir .. "Bad_2.lua"))
|
||||||
|
assert.is_nil(beautiful.init(dir .. "Bad_3.lua"))
|
||||||
|
assert.is_nil(beautiful.init(dir .. "Bad_4.lua"))
|
||||||
|
assert.is_nil(beautiful.init(dir .. "Bad_5.lua"))
|
||||||
|
assert.is_nil(beautiful.init(dir .. "NO_FILE"))
|
||||||
|
|
||||||
|
assert.is_true(beautiful.init({ font = "Monospace Bold 12" }))
|
||||||
|
assert.is_true(beautiful.init(dir .. "Good.lua"))
|
||||||
|
end)
|
||||||
|
|
||||||
|
-- Check beautiful.get
|
||||||
|
it('Check beautiful.get', function()
|
||||||
|
assert.is_same(beautiful.get(), { font = "Monospace Bold 12" })
|
||||||
|
end)
|
||||||
|
|
||||||
|
-- Check getting a beautiful.value
|
||||||
|
it('Check getting a beautiful.value', function()
|
||||||
|
assert.is_same(beautiful.font, "Monospace Bold 12")
|
||||||
|
end)
|
||||||
|
|
||||||
|
-- Check setting a beautiful.value
|
||||||
|
it('Check setting a beautiful.value', function()
|
||||||
|
beautiful.font = "Monospace Bold 10"
|
||||||
|
assert.is_same(beautiful.font, "Monospace Bold 10")
|
||||||
|
end)
|
||||||
|
end)
|
||||||
|
|
||||||
|
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80
|
|
@ -0,0 +1,2 @@
|
||||||
|
local me = {}
|
||||||
|
return me
|
|
@ -0,0 +1,2 @@
|
||||||
|
local me = function() end
|
||||||
|
return me
|
|
@ -0,0 +1,2 @@
|
||||||
|
local me = 9
|
||||||
|
return me
|
|
@ -0,0 +1,2 @@
|
||||||
|
local me = nil
|
||||||
|
return me
|
|
@ -0,0 +1,2 @@
|
||||||
|
local var = nil
|
||||||
|
print( var.bad )
|
|
@ -0,0 +1,2 @@
|
||||||
|
local me = { font = "Monospace Bold 12" }
|
||||||
|
return me
|
|
@ -7,6 +7,6 @@ require("lgi")
|
||||||
_G.awesome = {version = "v9999"}
|
_G.awesome = {version = "v9999"}
|
||||||
|
|
||||||
-- "fix" some intentional beautiful breakage done by .travis.yml
|
-- "fix" some intentional beautiful breakage done by .travis.yml
|
||||||
require("beautiful").init{}
|
require("beautiful").init{a_key="a_value"}
|
||||||
|
|
||||||
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80
|
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80
|
||||||
|
|
Loading…
Reference in New Issue