X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/7a4d6f5ffa594603ef83bc8b0e9945d12e082490..fc5974a9c2838efa8dedbd350d9623e193ab71a3:/util/markup.lua
diff --git a/util/markup.lua b/util/markup.lua
index e7baec0..346cfe1 100644
--- a/util/markup.lua
+++ b/util/markup.lua
@@ -1,98 +1,53 @@
--[[
-
- Licensed under MIT License
- * (c) 2013, Luke Bonham
- * (c) 2009, Uli Schlachter
- * (c) 2009, Majic
-
+
+ Licensed under MIT License
+ * (c) 2013, Luke Bonham
+ * (c) 2009, Uli Schlachter
+ * (c) 2009, Majic
+
--]]
-local beautiful = require("beautiful")
-local tostring = tostring
+local string = { format = string.format }
local setmetatable = setmetatable
-- Lain markup util submodule
-- lain.util.markup
-local markup = {}
-
-local fg = {}
-local bg = {}
-
---[[ clean this as soon as you document it
-
- +-- markup
- |
- |`-- bold() Set bold.
- |`-- italic() Set italicized text.
- |`-- strike() Set strikethrough text.
- |`-- underline() Set underlined text.
- |`-- monospace() Set monospaced text.
- |`-- big() Set bigger text.
- |`-- small() Set smaller text.
- |`-- font() Set the font of the text.
- |
- |`--+ bg
- | |
- | |`-- color() Set background color.
- | |`-- focus() Set focus background color.
- | |`-- normal() Set normal background color.
- | `-- urgent() Set urgent background color.
- |
- |`--+ fg
- | |
- | |`-- color() Set foreground color.
- | |`-- focus() Set focus foreground color.
- | |`-- normal() Set normal foreground color.
- | `-- urgent() Set urgent foreground color.
- |
- |`-- focus() Set both foreground and background focus colors.
- |`-- normal() Set both foreground and background normal colors.
- `-- urgent() Set both foreground and background urgent colors.
-
-]]
+local markup = { fg = {}, bg = {} }
-- Convenience tags.
-function markup.bold(text) return '' .. tostring(text) .. '' end
-function markup.italic(text) return '' .. tostring(text) .. '' end
-function markup.strike(text) return '' .. tostring(text) .. '' end
-function markup.underline(text) return '' .. tostring(text) .. '' end
-function markup.monospace(text) return '' .. tostring(text) .. '' end
-function markup.big(text) return '' .. tostring(text) .. '' end
-function markup.small(text) return '' .. tostring(text) .. '' end
+function markup.bold(text) return '' .. text .. '' end
+function markup.italic(text) return '' .. text .. '' end
+function markup.strike(text) return '' .. text .. '' end
+function markup.underline(text) return '' .. text .. '' end
+function markup.monospace(text) return '' .. text .. '' end
+function markup.big(text) return '' .. text .. '' end
+function markup.small(text) return '' .. text .. '' end
-- Set the font.
function markup.font(font, text)
- return '' .. tostring(text) ..''
+ return '' .. text ..''
end
-- Set the foreground.
-function fg.color(color, text)
- return '' .. tostring(text) .. ''
+function markup.fg.color(color, text)
+ return '' .. text .. ''
end
-- Set the background.
-function bg.color(color, text)
- return '' .. tostring(text) .. ''
+function markup.bg.color(color, text)
+ return '' .. text .. ''
end
--- Context: focus
-function fg.focus(text) return fg.color(beautiful.fg_focus, text) end
-function bg.focus(text) return bg.color(beautiful.bg_focus, text) end
-function markup.focus(text) return bg.focus(fg.focus(text)) end
-
--- Context: normal
-function fg.normal(text) return fg.color(beautiful.fg_normal, text) end
-function bg.normal(text) return bg.color(beautiful.bg_normal, text) end
-function markup.normal(text) return bg.normal(fg.normal(text)) end
-
--- Context: urgent
-function fg.urgent(text) return fg.color(beautiful.fg_urgent, text) end
-function bg.urgent(text) return bg.color(beautiful.bg_urgent, text) end
-function markup.urgent(text) return bg.urgent(fg.urgent(text)) end
+-- Set foreground and background.
+function markup.color(fg, bg, text)
+ return string.format('%s', fg, bg, text)
+end
-markup.fg = fg
-markup.bg = bg
+-- Set font, foreground and background.
+function markup.fontcolor(font, fg, bg, text)
+ return string.format('%s', font, fg, bg, text)
+end
-- link markup.{fg,bg}(...) calls to markup.{fg,bg}.color(...)
setmetatable(markup.fg, { __call = function(_, ...) return markup.fg.color(...) end })