Merge pull request #1581 from Veratil/gears-fs

Move filesystem functions out of awful.util into new gears.filesystem
This commit is contained in:
Emmanuel Lepage Vallée 2017-03-15 20:38:49 -04:00 committed by GitHub
commit f57e3eb48c
18 changed files with 210 additions and 63 deletions

View File

@ -71,7 +71,7 @@ Awesome has four themes you can choose from: *default*, *sky*, *xresources*, and
To change the theme, open your rc.lua and edit this line near the beginning of To change the theme, open your rc.lua and edit this line near the beginning of
the file: the file:
beautiful.init(awful.util.getdir("config") .. "/themes/default/theme.lua") beautiful.init(gears.filesystem.get_dir("config") .. "/themes/default/theme.lua")
For this tutorial we will stick with the default theme. For this tutorial we will stick with the default theme.

View File

@ -15,11 +15,11 @@ require("sample_files")(
-- `~/.config/awesome/mytheme.lua` -- `~/.config/awesome/mytheme.lua`
-- and replace: -- and replace:
-- --
-- beautiful.init(awful.util.get_themes_dir() .. "default/theme.lua") -- beautiful.init(gears.filesystem.get_themes_dir() .. "default/theme.lua")
-- --
-- with -- with
-- --
-- beautiful.init(awful.util.getdir("config") .. "mytheme.lua") -- beautiful.init(gears.filesystem.get_dir("config") .. "mytheme.lua")
-- --
-- in your `rc.lua`. -- in your `rc.lua`.
-- --

View File

@ -129,6 +129,7 @@ local debug = require('gears.debug')
local gtable = require("gears.table") local gtable = require("gears.table")
local gcolor = require("gears.color") local gcolor = require("gears.color")
local gstring = require("gears.string") local gstring = require("gears.string")
local gfs = require("gears.filesystem")
local prompt = {} local prompt = {}
@ -216,7 +217,7 @@ local function history_save(id)
for d in id:gmatch(".-/") do for d in id:gmatch(".-/") do
i = i + #d i = i + #d
end end
util.mkdir(id:sub(1, i - 1)) gfs.mkdir(id:sub(1, i - 1))
f = assert(io.open(id, "w")) f = assert(io.open(id, "w"))
end end
for i = 1, math.min(#data.history[id].table, data.history[id].max) do for i = 1, math.min(#data.history[id].table, data.history[id].max) do

View File

@ -18,8 +18,8 @@ local gtable = require("gears.table")
local string = string local string = string
local gstring = require("gears.string") local gstring = require("gears.string")
local grect = require("gears.geometry").rectangle local grect = require("gears.geometry").rectangle
local Gio = require("lgi").Gio
local gcolor = require("gears.color") local gcolor = require("gears.color")
local gfs = require("gears.filesystem")
local capi = local capi =
{ {
awesome = awesome, awesome = awesome,
@ -126,10 +126,14 @@ function util.cycle(t, i)
end end
--- Create a directory --- Create a directory
-- @deprecated mkdir
-- @param dir The directory. -- @param dir The directory.
-- @return mkdir return code -- @return mkdir return code
-- @see gears.filesystem
function util.mkdir(dir) function util.mkdir(dir)
return os.execute("mkdir -p " .. dir) util.deprecate("gears.filesystem.mkdir", {deprecated_in=5})
return gfs.mkdir(dir)
end end
--- Eval Lua code. --- Eval Lua code.
@ -188,55 +192,77 @@ function util.restart()
end end
--- Get the config home according to the XDG basedir specification. --- Get the config home according to the XDG basedir specification.
-- @deprecated get_xdg_config_home
-- @return the config home (XDG_CONFIG_HOME) with a slash at the end. -- @return the config home (XDG_CONFIG_HOME) with a slash at the end.
-- @see gears.filesystem
function util.get_xdg_config_home() function util.get_xdg_config_home()
return (os.getenv("XDG_CONFIG_HOME") or os.getenv("HOME") .. "/.config") .. "/" util.deprecate("gears.filesystem.get_xdg_config_home", {deprecated_in=5})
return gfs.get_xdg_config_home()
end end
--- Get the cache home according to the XDG basedir specification. --- Get the cache home according to the XDG basedir specification.
-- @deprecated get_xdg_cache_home
-- @return the cache home (XDG_CACHE_HOME) with a slash at the end. -- @return the cache home (XDG_CACHE_HOME) with a slash at the end.
-- @see gears.filesystem
function util.get_xdg_cache_home() function util.get_xdg_cache_home()
return (os.getenv("XDG_CACHE_HOME") or os.getenv("HOME") .. "/.cache") .. "/" util.deprecate("gears.filesystem.get_xdg_cache_home", {deprecated_in=5})
return gfs.get_xdg_cache_home()
end end
--- Get the path to the user's config dir. --- Get the path to the user's config dir.
-- This is the directory containing the configuration file ("rc.lua"). -- This is the directory containing the configuration file ("rc.lua").
-- @deprecated get_configuration_dir
-- @return A string with the requested path with a slash at the end. -- @return A string with the requested path with a slash at the end.
-- @see gears.filesystem
function util.get_configuration_dir() function util.get_configuration_dir()
return capi.awesome.conffile:match(".*/") or "./" util.deprecate("gears.filesystem.get_configuration_dir", {deprecated_in=5})
return gfs.get_configuration_dir()
end end
--- Get the path to a directory that should be used for caching data. --- Get the path to a directory that should be used for caching data.
-- @deprecated get_cache_dir
-- @return A string with the requested path with a slash at the end. -- @return A string with the requested path with a slash at the end.
-- @see gears.filesystem
function util.get_cache_dir() function util.get_cache_dir()
return util.get_xdg_cache_home() .. "awesome/" util.deprecate("gears.filesystem.get_cache_dir", {deprecated_in=5})
return gfs.get_cache_dir()
end end
--- Get the path to the directory where themes are installed. --- Get the path to the directory where themes are installed.
-- @deprecated get_themes_dir
-- @return A string with the requested path with a slash at the end. -- @return A string with the requested path with a slash at the end.
-- @see gears.filesystem
function util.get_themes_dir() function util.get_themes_dir()
return (os.getenv('AWESOME_THEMES_PATH') or awesome.themes_path) .. "/" util.deprecate("gears.filesystem.get_themes_dir", {deprecated_in=5})
return gfs.get_themes_dir()
end end
--- Get the path to the directory where our icons are installed. --- Get the path to the directory where our icons are installed.
-- @deprecated get_awesome_icon_dir
-- @return A string with the requested path with a slash at the end. -- @return A string with the requested path with a slash at the end.
-- @see gears.filesystem
function util.get_awesome_icon_dir() function util.get_awesome_icon_dir()
return (os.getenv('AWESOME_ICON_PATH') or awesome.icon_path) .. "/" util.deprecate("gears.filesystem.get_awesome_icon_dir", {deprecated_in=5})
return gfs.get_awesome_icon_dir()
end end
--- Get the user's config or cache dir. --- Get the user's config or cache dir.
-- It first checks XDG_CONFIG_HOME / XDG_CACHE_HOME, but then goes with the -- It first checks XDG_CONFIG_HOME / XDG_CACHE_HOME, but then goes with the
-- default paths. -- default paths.
-- @deprecated getdir
-- @param d The directory to get (either "config" or "cache"). -- @param d The directory to get (either "config" or "cache").
-- @return A string containing the requested path. -- @return A string containing the requested path.
-- @see gears.filesystem
function util.getdir(d) function util.getdir(d)
if d == "config" then util.deprecate("gears.filesystem.get_dir", {deprecated_in=5})
-- No idea why this is what is returned, I recommend everyone to use
-- get_configuration_dir() instead return gfs.get_dir(d)
return util.get_xdg_config_home() .. "awesome/"
elseif d == "cache" then
return util.get_cache_dir()
end
end end
--- Search for an icon and return the full path. --- Search for an icon and return the full path.
@ -256,13 +282,13 @@ function util.geticonpath(iconname, exts, dirs, size)
local icon local icon
for _, e in pairs(exts) do for _, e in pairs(exts) do
icon = d .. iconname .. '.' .. e icon = d .. iconname .. '.' .. e
if util.file_readable(icon) then if gfs.file_readable(icon) then
return icon return icon
end end
if size then if size then
for _, t in pairs(icontypes) do for _, t in pairs(icontypes) do
icon = string.format("%s%ux%u/%s/%s.%s", d, size, size, t, iconname, e) icon = string.format("%s%ux%u/%s/%s.%s", d, size, size, t, iconname, e)
if util.file_readable(icon) then if gfs.file_readable(icon) then
return icon return icon
end end
end end
@ -271,33 +297,37 @@ function util.geticonpath(iconname, exts, dirs, size)
end end
end end
--- Check if a file exists, is not readable and not a directory. --- Check if a file exists, is readable and not a directory.
-- @deprecated file_readable
-- @param filename The file path. -- @param filename The file path.
-- @return True if file exists and is readable. -- @return True if file exists and is readable.
-- @see gears.filesystem
function util.file_readable(filename) function util.file_readable(filename)
local gfile = Gio.File.new_for_path(filename) util.deprecate("gears.filesystem.file_readable", {deprecated_in=5})
local gfileinfo = gfile:query_info("standard::type,access::can-read",
Gio.FileQueryInfoFlags.NONE) return gfs.file_readable(filename)
return gfileinfo and gfileinfo:get_file_type() ~= "DIRECTORY" and
gfileinfo:get_attribute_boolean("access::can-read")
end end
--- Check if a path exists, is readable and is a directory. --- Check if a path exists, is readable and is a directory.
-- @deprecated dir_readable
-- @tparam string path The directory path. -- @tparam string path The directory path.
-- @treturn boolean True if dir exists and is readable. -- @treturn boolean True if dir exists and is readable.
-- @see gears.filesystem
function util.dir_readable(path) function util.dir_readable(path)
local gfile = Gio.File.new_for_path(path) util.deprecate("gears.filesystem.dir_readable", {deprecated_in=5})
local gfileinfo = gfile:query_info("standard::type,access::can-read",
Gio.FileQueryInfoFlags.NONE) return gfs.dir_readable(path)
return gfileinfo and gfileinfo:get_file_type() == "DIRECTORY" and
gfileinfo:get_attribute_boolean("access::can-read")
end end
--- Check if a path is a directory. --- Check if a path is a directory.
-- @deprecated is_dir
-- @tparam string path -- @tparam string path
-- @treturn bool True if path exists and is a directory. -- @treturn bool True if path exists and is a directory.
-- @see gears.filesystem
function util.is_dir(path) function util.is_dir(path)
return Gio.File.new_for_path(path):query_file_type({}) == "DIRECTORY" util.deprecate("gears.filesystem.is_dir", {deprecated_in=5})
return gfs.is_dir(path)
end end
--- Return all subsets of a specific set. --- Return all subsets of a specific set.

View File

@ -21,7 +21,7 @@
local setmetatable = setmetatable local setmetatable = setmetatable
local completion = require("awful.completion") local completion = require("awful.completion")
local util = require("awful.util") local gfs = require("gears.filesystem")
local spawn = require("awful.spawn") local spawn = require("awful.spawn")
local prompt = require("awful.prompt") local prompt = require("awful.prompt")
local beautiful = require("beautiful") local beautiful = require("beautiful")
@ -39,7 +39,7 @@ local function run(promptbox)
prompt = promptbox.prompt, prompt = promptbox.prompt,
textbox = promptbox.widget, textbox = promptbox.widget,
completion_callback = completion.shell, completion_callback = completion.shell,
history_path = util.get_cache_dir() .. "/history", history_path = gfs.get_cache_dir() .. "/history",
exe_callback = function (...) exe_callback = function (...)
promptbox:spawn_and_handle_error(...) promptbox:spawn_and_handle_error(...)
end, end,

109
lib/gears/filesystem.lua Normal file
View File

@ -0,0 +1,109 @@
---------------------------------------------------------------------------
--- Filesystem module for gears
--
-- @module gears.filesystem
---------------------------------------------------------------------------
-- Grab environment we need
local Gio = require("lgi").Gio
local filesystem = {}
--- Create a directory
-- @tparam string dir The directory.
-- @return (true, nil) on success, (false, err) on failure
function filesystem.mkdir(dir)
local gfile = Gio.File.new_for_path(dir)
local success, err = gfile:make_directory_with_parents()
if success then
return true
end
if err.domain == Gio.IOErrorEnum and err.code == "EXISTS" then
-- Direcotry already exists, let this count as success
return true
end
return false, err
end
--- Check if a file exists, is readable and not a directory.
-- @tparam string filename The file path.
-- @treturn boolean True if file exists and is readable.
function filesystem.file_readable(filename)
local gfile = Gio.File.new_for_path(filename)
local gfileinfo = gfile:query_info("standard::type,access::can-read",
Gio.FileQueryInfoFlags.NONE)
return gfileinfo and gfileinfo:get_file_type() ~= "DIRECTORY" and
gfileinfo:get_attribute_boolean("access::can-read")
end
--- Check if a path exists, is readable and a directory.
-- @tparam string path The directory path.
-- @treturn boolean True if path exists and is readable.
function filesystem.dir_readable(path)
local gfile = Gio.File.new_for_path(path)
local gfileinfo = gfile:query_info("standard::type,access::can-read",
Gio.FileQueryInfoFlags.NONE)
return gfileinfo and gfileinfo:get_file_type() == "DIRECTORY" and
gfileinfo:get_attribute_boolean("access::can-read")
end
--- Check if a path is a directory.
-- @tparam string path The directory path
-- @treturn boolean True if path exists and is a directory.
function filesystem.is_dir(path)
return Gio.File.new_for_path(path):query_file_type({}) == "DIRECTORY"
end
--- Get the config home according to the XDG basedir specification.
-- @return the config home (XDG_CONFIG_HOME) with a slash at the end.
function filesystem.get_xdg_config_home()
return (os.getenv("XDG_CONFIG_HOME") or os.getenv("HOME") .. "/.config") .. "/"
end
--- Get the cache home according to the XDG basedir specification.
-- @return the cache home (XDG_CACHE_HOME) with a slash at the end.
function filesystem.get_xdg_cache_home()
return (os.getenv("XDG_CACHE_HOME") or os.getenv("HOME") .. "/.cache") .. "/"
end
--- Get the path to the user's config dir.
-- This is the directory containing the configuration file ("rc.lua").
-- @return A string with the requested path with a slash at the end.
function filesystem.get_configuration_dir()
return awesome.conffile:match(".*/") or "./"
end
--- Get the path to a directory that should be used for caching data.
-- @return A string with the requested path with a slash at the end.
function filesystem.get_cache_dir()
return filesystem.get_xdg_cache_home() .. "awesome/"
end
--- Get the path to the directory where themes are installed.
-- @return A string with the requested path with a slash at the end.
function filesystem.get_themes_dir()
return (os.getenv('AWESOME_THEMES_PATH') or awesome.themes_path) .. "/"
end
--- Get the path to the directory where our icons are installed.
-- @return A string with the requested path with a slash at the end.
function filesystem.get_awesome_icon_dir()
return (os.getenv('AWESOME_ICON_PATH') or awesome.icon_path) .. "/"
end
--- Get the user's config or cache dir.
-- It first checks XDG_CONFIG_HOME / XDG_CACHE_HOME, but then goes with the
-- default paths.
-- @param d The directory to get (either "config" or "cache").
-- @return A string containing the requested path.
function filesystem.get_dir(d)
if d == "config" then
-- No idea why this is what is returned, I recommend everyone to use
-- get_configuration_dir() instead
return filesystem.get_xdg_config_home() .. "awesome/"
elseif d == "cache" then
return filesystem.get_cache_dir()
end
end
return filesystem

View File

@ -21,6 +21,7 @@ return
math = require("gears.math"); math = require("gears.math");
table = require("gears.table"); table = require("gears.table");
string = require("gears.string"); string = require("gears.string");
filesystem = require("gears.filesystem");
} }
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80 -- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80

View File

@ -11,7 +11,7 @@
-- http://standards.freedesktop.org/icon-theme-spec/icon-theme-spec-0.12.html -- http://standards.freedesktop.org/icon-theme-spec/icon-theme-spec-0.12.html
local beautiful = require("beautiful") local beautiful = require("beautiful")
local awful_util = require("awful.util") local gfs = require("gears.filesystem")
local GLib = require("lgi").GLib local GLib = require("lgi").GLib
local index_theme = require("menubar.index_theme") local index_theme = require("menubar.index_theme")
@ -25,18 +25,18 @@ local get_pragmatic_base_directories = function()
local dirs = {} local dirs = {}
local dir = GLib.build_filenamev({GLib.get_home_dir(), ".icons"}) local dir = GLib.build_filenamev({GLib.get_home_dir(), ".icons"})
if awful_util.dir_readable(dir) then if gfs.dir_readable(dir) then
table.insert(dirs, dir) table.insert(dirs, dir)
end end
dir = GLib.build_filenamev({GLib.get_user_data_dir(), "icons"}) dir = GLib.build_filenamev({GLib.get_user_data_dir(), "icons"})
if awful_util.dir_readable(dir) then if gfs.dir_readable(dir) then
table.insert(dirs, dir) table.insert(dirs, dir)
end end
for _, v in ipairs(GLib.get_system_data_dirs()) do for _, v in ipairs(GLib.get_system_data_dirs()) do
dir = GLib.build_filenamev({v, "icons"}) dir = GLib.build_filenamev({v, "icons"})
if awful_util.dir_readable(dir) then if gfs.dir_readable(dir) then
table.insert(dirs, dir) table.insert(dirs, dir)
end end
end end
@ -44,7 +44,7 @@ local get_pragmatic_base_directories = function()
local need_usr_share_pixmaps = true local need_usr_share_pixmaps = true
for _, v in ipairs(GLib.get_system_data_dirs()) do for _, v in ipairs(GLib.get_system_data_dirs()) do
dir = GLib.build_filenamev({v, "pixmaps"}) dir = GLib.build_filenamev({v, "pixmaps"})
if awful_util.dir_readable(dir) then if gfs.dir_readable(dir) then
table.insert(dirs, dir) table.insert(dirs, dir)
end end
if dir == "/usr/share/pixmaps" then if dir == "/usr/share/pixmaps" then
@ -53,7 +53,7 @@ local get_pragmatic_base_directories = function()
end end
dir = "/usr/share/pixmaps" dir = "/usr/share/pixmaps"
if need_usr_share_pixmaps and awful_util.dir_readable(dir) then if need_usr_share_pixmaps and gfs.dir_readable(dir) then
table.insert(dirs, dir) table.insert(dirs, dir)
end end
@ -65,7 +65,7 @@ local get_default_icon_theme_name = function()
for _, dir in ipairs(get_pragmatic_base_directories()) do for _, dir in ipairs(get_pragmatic_base_directories()) do
for _, icon_theme_name in ipairs(icon_theme_names) do for _, icon_theme_name in ipairs(icon_theme_names) do
local filename = string.format("%s/%s/index.theme", dir, icon_theme_name) local filename = string.format("%s/%s/index.theme", dir, icon_theme_name)
if awful_util.file_readable(filename) then if gfs.file_readable(filename) then
return icon_theme_name return icon_theme_name
end end
end end
@ -152,7 +152,7 @@ local lookup_icon = function(self, icon_name, icon_size)
local filename = string.format("%s/%s/%s/%s.%s", local filename = string.format("%s/%s/%s/%s.%s",
basedir, self.icon_theme_name, subdir, basedir, self.icon_theme_name, subdir,
icon_name, ext) icon_name, ext)
if awful_util.file_readable(filename) then if gfs.file_readable(filename) then
return filename return filename
else else
checked_already[filename] = true checked_already[filename] = true
@ -173,7 +173,7 @@ local lookup_icon = function(self, icon_name, icon_size)
basedir, self.icon_theme_name, subdir, basedir, self.icon_theme_name, subdir,
icon_name, ext) icon_name, ext)
if not checked_already[filename] then if not checked_already[filename] then
if awful_util.file_readable(filename) then if gfs.file_readable(filename) then
closest_filename = filename closest_filename = filename
minimal_size = dist minimal_size = dist
end end
@ -209,7 +209,7 @@ local lookup_fallback_icon = function(self, icon_name)
local filename = string.format("%s/%s.%s", local filename = string.format("%s/%s.%s",
dir, dir,
icon_name, ext) icon_name, ext)
if awful_util.file_readable(filename) then if gfs.file_readable(filename) then
return filename return filename
end end
end end

View File

@ -27,6 +27,7 @@ local capi = {
} }
local gmath = require("gears.math") local gmath = require("gears.math")
local awful = require("awful") local awful = require("awful")
local gfs = require("gears.filesystem")
local common = require("awful.widget.common") local common = require("awful.widget.common")
local theme = require("beautiful") local theme = require("beautiful")
local wibox = require("wibox") local wibox = require("wibox")
@ -128,7 +129,7 @@ local function load_count_table()
return instance.count_table return instance.count_table
end end
instance.count_table = {} instance.count_table = {}
local count_file_name = awful.util.getdir("cache") .. "/menu_count_file" local count_file_name = gfs.get_dir("cache") .. "/menu_count_file"
local count_file = io.open (count_file_name, "r") local count_file = io.open (count_file_name, "r")
if count_file then if count_file then
for line in count_file:lines() do for line in count_file:lines() do
@ -144,7 +145,7 @@ end
local function write_count_table(count_table) local function write_count_table(count_table)
count_table = count_table or instance.count_table count_table = count_table or instance.count_table
local count_file_name = awful.util.getdir("cache") .. "/menu_count_file" local count_file_name = gfs.get_dir("cache") .. "/menu_count_file"
local count_file = io.open (count_file_name, "w") local count_file = io.open (count_file_name, "w")
for name, count in pairs(count_table) do for name, count in pairs(count_table) do
local str = string.format("%s;%d\n", name, count) local str = string.format("%s;%d\n", name, count)
@ -434,7 +435,7 @@ function menubar.show(scr)
prompt = "Run: ", prompt = "Run: ",
textbox = instance.prompt.widget, textbox = instance.prompt.widget,
completion_callback = awful.completion.shell, completion_callback = awful.completion.shell,
history_path = awful.util.get_cache_dir() .. "/history_menu", history_path = gfs.get_cache_dir() .. "/history_menu",
done_callback = menubar.hide, done_callback = menubar.hide,
changed_callback = function(query) changed_callback = function(query)
instance.query = query instance.query = query

View File

@ -13,6 +13,7 @@ local ipairs = ipairs
local string = string local string = string
local screen = screen local screen = screen
local awful_util = require("awful.util") local awful_util = require("awful.util")
local gfs = require("gears.filesystem")
local theme = require("beautiful") local theme = require("beautiful")
local lgi = require("lgi") local lgi = require("lgi")
local gio = lgi.Gio local gio = lgi.Gio
@ -77,7 +78,7 @@ local icon_lookup_path = nil
local function get_icon_lookup_path() local function get_icon_lookup_path()
if not icon_lookup_path then if not icon_lookup_path then
local add_if_readable = function(t, path) local add_if_readable = function(t, path)
if awful_util.dir_readable(path) then if gfs.dir_readable(path) then
table.insert(t, path) table.insert(t, path)
end end
end end
@ -90,7 +91,7 @@ local function get_icon_lookup_path()
'.icons'})) '.icons'}))
for _,dir in ipairs(paths) do for _,dir in ipairs(paths) do
local icons_dir = glib.build_filenamev({dir, 'icons'}) local icons_dir = glib.build_filenamev({dir, 'icons'})
if awful_util.dir_readable(icons_dir) then if gfs.dir_readable(icons_dir) then
if icon_theme then if icon_theme then
add_if_readable(icon_theme_paths, add_if_readable(icon_theme_paths,
glib.build_filenamev({icons_dir, glib.build_filenamev({icons_dir,
@ -130,11 +131,11 @@ function utils.lookup_icon_uncached(icon_file)
if icon_file:sub(1, 1) == '/' and is_format_supported(icon_file) then if icon_file:sub(1, 1) == '/' and is_format_supported(icon_file) then
-- If the path to the icon is absolute and its format is -- If the path to the icon is absolute and its format is
-- supported, do not perform a lookup. -- supported, do not perform a lookup.
return awful_util.file_readable(icon_file) and icon_file or nil return gfs.file_readable(icon_file) and icon_file or nil
else else
for _, directory in ipairs(get_icon_lookup_path()) do for _, directory in ipairs(get_icon_lookup_path()) do
if is_format_supported(icon_file) and if is_format_supported(icon_file) and
awful_util.file_readable(directory .. "/" .. icon_file) then gfs.file_readable(directory .. "/" .. icon_file) then
return directory .. "/" .. icon_file return directory .. "/" .. icon_file
else else
-- Icon is probably specified without path and format, -- Icon is probably specified without path and format,
@ -142,7 +143,7 @@ function utils.lookup_icon_uncached(icon_file)
-- it and see if such file exists. -- it and see if such file exists.
for _, format in ipairs(icon_formats) do for _, format in ipairs(icon_formats) do
local possible_file = directory .. "/" .. icon_file .. "." .. format local possible_file = directory .. "/" .. icon_file .. "." .. format
if awful_util.file_readable(possible_file) then if gfs.file_readable(possible_file) then
return possible_file return possible_file
end end
end end

View File

@ -21,6 +21,7 @@ local button = require("awful.button")
local screen = require("awful.screen") local screen = require("awful.screen")
local util = require("awful.util") local util = require("awful.util")
local gtable = require("gears.table") local gtable = require("gears.table")
local gfs = require("gears.filesystem")
local bt = require("beautiful") local bt = require("beautiful")
local wibox = require("wibox") local wibox = require("wibox")
local surface = require("gears.surface") local surface = require("gears.surface")
@ -648,7 +649,7 @@ function naughty.notify(args)
icon = string.gsub(icon, "%%(%x%x)", function(x) return string.char(tonumber(x, 16)) end ) icon = string.gsub(icon, "%%(%x%x)", function(x) return string.char(tonumber(x, 16)) end )
end end
-- try to guess icon if the provided one is non-existent/readable -- try to guess icon if the provided one is non-existent/readable
if type(icon) == "string" and not util.file_readable(icon) then if type(icon) == "string" and not gfs.file_readable(icon) then
icon = util.geticonpath(icon, naughty.config.icon_formats, naughty.config.icon_dirs, icon_size) or icon icon = util.geticonpath(icon, naughty.config.icon_formats, naughty.config.icon_dirs, icon_size) or icon
end end

View File

@ -4,6 +4,7 @@ local awful = { prompt = require("awful.prompt"),--DOC_HIDE
util = require("awful.util"), --DOC_HIDE util = require("awful.util"), --DOC_HIDE
spawn = function () end } --DOC_HIDE spawn = function () end } --DOC_HIDE
local beautiful = require( "beautiful" ) --DOC_HIDE local beautiful = require( "beautiful" ) --DOC_HIDE
local gfs = require("gears.filesystem") --DOC_HIDE
local atextbox = wibox.widget.textbox() local atextbox = wibox.widget.textbox()
@ -53,7 +54,7 @@ local beautiful = require( "beautiful" ) --DOC_HIDE
prompt = "<b>Run: </b>", prompt = "<b>Run: </b>",
hooks = hooks, hooks = hooks,
textbox = atextbox, textbox = atextbox,
history_path = awful.util.getdir("cache") .. "/history", history_path = gfs.get_dir("cache") .. "/history",
done_callback = clear, done_callback = clear,
} }

View File

@ -4,6 +4,7 @@ local awful = { prompt = require("awful.prompt"),--DOC_HIDE
util = require("awful.util"),--DOC_HIDE util = require("awful.util"),--DOC_HIDE
screen = require("awful.screen")}--DOC_HIDE screen = require("awful.screen")}--DOC_HIDE
local beautiful = require( "beautiful" ) --DOC_HIDE local beautiful = require( "beautiful" ) --DOC_HIDE
local gfs = require("gears.filesystem") --DOC_HIDE
local naughty = {} --DOC_HIDE local naughty = {} --DOC_HIDE
local atextbox = wibox.widget.textbox() local atextbox = wibox.widget.textbox()
@ -23,7 +24,7 @@ local naughty = {} --DOC_HIDE
end end
end, end,
textbox = atextbox, textbox = atextbox,
history_path = awful.util.getdir("cache") .. "/history", history_path = gfs.get_dir("cache") .. "/history",
} }
parent:add( wibox.widget { --DOC_HIDE parent:add( wibox.widget { --DOC_HIDE

View File

@ -3,6 +3,7 @@ local wibox = require( "wibox" ) --DOC_HIDE
local awful = { prompt = require("awful.prompt"),--DOC_HIDE local awful = { prompt = require("awful.prompt"),--DOC_HIDE
util = require("awful.util")}--DOC_HIDE util = require("awful.util")}--DOC_HIDE
local beautiful = require( "beautiful" ) --DOC_HIDE local beautiful = require( "beautiful" ) --DOC_HIDE
local gfs = require("gears.filesystem") --DOC_HIDE
local terminal = "xterm" --DOC_HIDE local terminal = "xterm" --DOC_HIDE
local atextbox = wibox.widget.textbox() local atextbox = wibox.widget.textbox()
@ -43,7 +44,7 @@ local terminal = "xterm" --DOC_HIDE
end}, end},
}, },
textbox = atextbox, textbox = atextbox,
history_path = awful.util.getdir('cache') .. '/history', history_path = gfs.get_dir('cache') .. '/history',
exe_callback = function(cmd) awful.spawn(cmd) end exe_callback = function(cmd) awful.spawn(cmd) end
} }

View File

@ -6,8 +6,8 @@ local theme_assets = require("beautiful.theme_assets")
local xresources = require("beautiful.xresources") local xresources = require("beautiful.xresources")
local dpi = xresources.apply_dpi local dpi = xresources.apply_dpi
local util = require('awful.util') local gfs = require("gears.filesystem")
local themes_path = util.get_themes_dir() local themes_path = gfs.get_themes_dir()
local theme = {} local theme = {}

View File

@ -7,7 +7,7 @@
local theme_assets = require("beautiful.theme_assets") local theme_assets = require("beautiful.theme_assets")
local xresources = require("beautiful.xresources") local xresources = require("beautiful.xresources")
local dpi = xresources.apply_dpi local dpi = xresources.apply_dpi
local themes_path = require("awful.util").get_themes_dir() local themes_path = require("gears.filesystem").get_themes_dir()
-- BASICS -- BASICS

View File

@ -7,8 +7,8 @@ local theme_assets = require("beautiful.theme_assets")
local xresources = require("beautiful.xresources") local xresources = require("beautiful.xresources")
local dpi = xresources.apply_dpi local dpi = xresources.apply_dpi
local xrdb = xresources.get_current_theme() local xrdb = xresources.get_current_theme()
local util = require('awful.util') local gfs = require("gears.filesystem")
local themes_path = util.get_themes_dir() local themes_path = gfs.get_themes_dir()
-- inherit default theme -- inherit default theme
local theme = dofile(themes_path.."default/theme.lua") local theme = dofile(themes_path.."default/theme.lua")

View File

@ -3,7 +3,7 @@
-- By Adrian C. (anrxc) -- -- By Adrian C. (anrxc) --
------------------------------- -------------------------------
local themes_path = require("awful.util").get_themes_dir() local themes_path = require("gears.filesystem").get_themes_dir()
-- {{{ Main -- {{{ Main
local theme = {} local theme = {}