diff --git a/awesome/autostart.sh b/awesome/autostart.sh
deleted file mode 100755
index 3217501..0000000
--- a/awesome/autostart.sh
+++ /dev/null
@@ -1,37 +0,0 @@
-#!/bin/bash
-
-function run {
- if ! pgrep $1 ;
- then
- $@&
- fi
-}
-run "scripts/polybar.sh"
-#run "xrandr --output VGA-1 --primary --mode 1360x768 --pos 0x0 --rotate normal"
-#run "xrandr --output HDMI2 --mode 1920x1080 --pos 1920x0 --rotate normal --output HDMI1 --primary --mode 1920x1080 --pos 0x0 --rotate normal --output VIRTUAL1 --off"
-#run "wicd-client -t"
-run "copyq"
-run "picom"
-run "nm-applet"
-#run "caffeine"
-#run "pamac-tray"
-#run "variety"
-run "xfce4-power-manager"
-#run "blueberry-tray"
-run "blueman-applet"
-run "/usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1"
-run "numlockx on"
-#run "volumeicon"
-run "nitrogen --restore"
-#run "conky -c $HOME/.config/awesome/system-overview"
-#you can set wallpapers in themes as well
-#feh --bg-fill /usr/share/backgrounds/arcolinux/arco-wallpaper.jpg &
-#run applications from startup
-#run "firefox"
-#run "atom"
-#run "dropbox"
-#run "insync start"
-#run "spotify"
-#run "ckb-next -b"
-#run "discord"
-#run "telegram-desktop"
diff --git a/awesome/backup/compton-2019-01-27.conf b/awesome/backup/compton-2019-01-27.conf
deleted file mode 100644
index 264c7d1..0000000
--- a/awesome/backup/compton-2019-01-27.conf
+++ /dev/null
@@ -1,185 +0,0 @@
-####################################
-####### BACK-END ########
-####################################
-
-# Backend to use: "xrender" or "glx".
-# GLX backend is typically much faster but depends on a sane driver.
-
-#backend = "glx";
-backend = "xrender";
-
-
-####################################
-####### GLX ########
-####################################
-
-#glx-no-stencil = true; # Recommended.
-
-# GLX backend: Copy unmodified regions from front buffer instead of redrawing them all.
-# My tests with nvidia-drivers show a 10% decrease in performance when the whole screen is modified,
-# but a 20% increase when only 1/4 is.
-# My tests on nouveau show terrible slowdown.
-# Useful with --glx-swap-method, as well.
-
-glx-copy-from-front = false;
-
-# GLX backend: Use MESA_copy_sub_buffer to do partial screen update.
-# My tests on nouveau shows a 200% performance boost when only 1/4 of the screen is updated.
-# May break VSync and is not available on some drivers.
-# Overrides --glx-copy-from-front.
-
-# glx-use-copysubbuffermesa = true;
-
-# GLX backend: Avoid rebinding pixmap on window damage.
-# Probably could improve performance on rapid window content changes, but is known to break things on some drivers (LLVMpipe).
-# Recommended if it works.
-
-# glx-no-rebind-pixmap = true;
-
-# GLX backend: GLX buffer swap method we assume.
-# Could be undefined (0), copy (1), exchange (2), 3-6, or buffer-age (-1).
-# undefined is the slowest and the safest, and the default value.
-# copy is fastest, but may fail on some drivers,
-# 2-6 are gradually slower but safer (6 is still faster than 0).
-# Usually, double buffer means 2, triple buffer means 3.
-# buffer-age means auto-detect using GLX_EXT_buffer_age, supported by some drivers.
-# Useless with --glx-use-copysubbuffermesa.
-# Partially breaks --resize-damage.
-# Defaults to undefined.
-
-glx-swap-method = "undefined";
-
-# glx-use-gpushader4 = true;
-
-# xrender-sync = true;
-# xrender-sync-fence = true;
-
-####################################
-####### Shadow ########
-####################################
-shadow = false; # Enabled client-side shadows on windows.
-no-dnd-shadow = true; # Don't draw shadows on DND windows.
-no-dock-shadow = true; # Avoid drawing shadows on dock/panel windows.
-clear-shadow = true; # Zero the part of the shadow's mask behind the
- # window. Fix some weirdness with ARGB windows.
-shadow-radius = 7; # The blur radius for shadows. (default 12)
-shadow-offset-x = -7; # The left offset for shadows. (default -15)
-shadow-offset-y = -7; # The top offset for shadows. (default -15)
-# shadow-opacity = 0.5; # The translucency for shadows. (default .75)
-# shadow-red = 0.0; # Red color value of shadow. (0.0 - 1.0, defaults to 0)
-# shadow-green = 0.0; # Green color value of shadow. (0.0 - 1.0, defaults to 0)
-# shadow-blue = 0.0; # Blue color value of shadow. (0.0 - 1.0, defaults to 0)
-
-# Exclude conditions for shadows.
-shadow-exclude = [
- "name = 'Notification'",
- "class_g ?= 'Notify-osd'",
- "class_g = 'VirtualBox'",
- "class_g = 'Conky'",
- "_GTK_FRAME_EXTENTS@:c",
- "class_g = 'Cairo-clock'",
- "class_g = 'i3-frame'",
- "window_type *= 'normal' && ! name ~= ''"
-];
-
-# shadow-exclude-reg = "x10+0+0";
-# xinerama-shadow-crop = true;
-shadow-ignore-shaped = true; # Avoid drawing shadow on all shaped windows
- # (see also: --detect-rounded-corners)
-
-####################################
-####### Opacity ########
-####################################
-#menu-opacity = 0.9; # The opacity for menus. (default 1.0)
-#inactive-opacity = 0.9; # Default opacity of inactive windows. (0.0 - 1.0)
-# active-opacity = 0.8; # Default opacity for active windows. (0.0 - 1.0)
-# frame-opacity = 0.9; # Opacity of window titlebars and borders. (0.1 - 1.0)
-# inactive-opacity-override = true; # Let inactive opacity set by 'inactive-opacity' overrides
- # value of _NET_WM_OPACITY. Bad choice.
-alpha-step = 0.06; # XRender backend: Step size for alpha pictures. Increasing
- # it may result in less X resource usage,
- # Yet fading may look bad.
-# inactive-dim = 0.2; # Dim inactive windows. (0.0 - 1.0)
-# inactive-dim-fixed = true; # Do not let dimness adjust based on window opacity.
-# blur-background = true; # Blur background of transparent windows.
- # Bad performance with X Render backend.
- # GLX backend is an alternative.
-# blur-background-frame = true; # Blur background of opaque windows with transparent
- # frames as well.
-blur-background-fixed = false; # Do not let blur radius adjust based on window opacity.
-#blur-kern = "3x3box";
-# blur-kern = "5,5,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1";
-# Exclude conditions for background blur.
-# find the names with xwininfo
-blur-background-exclude = [
- "window_type = 'dock'",
- "class_g = 'Peek'",
- "window_type = 'desktop'",
- "window_type = 'tooltip'",
- "_GTK_FRAME_EXTENTS@:c"
-];
-
-opacity-rule = [ "80:class_g = 'XTerm'" ];
-#opacity-rule = [ "80:class_g = 'UXTerm'" ];
-#opacity-rule = [ "99:class_g = 'VirtualBox'" ];
-
-####################################
-####### Fading ########
-####################################
-#fading = true; # Fade windows during opacity changes.
-# fade-delta = 10; # The time between steps in a fade in milliseconds. (default 10).
-#fade-in-step = 0.03; # Opacity change between steps while fading in. (default 0.028).
-#fade-out-step = 0.03; # Opacity change between steps while fading out. (default 0.03).
-# no-fading-openclose = true; # Avoid fade windows in/out when opening/closing.
-# no-fading-destroyed-argb = true;
-focus-exclude = [
- "class_g = 'Cairo-clock'",
- "name *?= 'Steam'",
- "class_g *?= 'Steam'",
- "class_g *?= 'Virtualbox'"
-];
-
-####################################
-####### Other ########
-####################################
-
-mark-wmwin-focused = true; # Try to detect WM windows and mark them as active.
-mark-ovredir-focused = true; # Mark all non-WM but override-redirect windows active (e.g. menus).
-use-ewmh-active-win = false; # Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused
- # instead of using FocusIn/Out events. Usually more reliable but
- # depends on a EWMH-compliant WM.
-detect-rounded-corners = true; # Detect rounded corners and treat them as rectangular when --shadow-ignore- shaped is on.
-detect-client-opacity = true; # Detect _NET_WM_OPACITY on client windows, useful for window
- # managers not passing _NET_WM_OPACITY of client windows to frame
- # windows.
-refresh-rate = 0; # For --sw-opti: Specify refresh rate of the screen. 0 for auto.
-vsync = "none"; # "none", "drm", "opengl", "opengl-oml", "opengl-swc", "opengl-mswc"
- # See man page for more details.
-dbe = false; # Enable DBE painting mode. Rarely needed.
-paint-on-overlay = false; # Painting on X Composite overlay window. Recommended.
-sw-opti = false; # Limit compton to repaint at most once every 1 / refresh_rate.
- # Incompatible with certain VSync methods.
-unredir-if-possible = false; # Unredirect all windows if a full-screen opaque window is
- # detected, to maximize performance for full-screen windows.
-# unredir-if-possible-delay = 5000;
-# unredir-if-possible-exclude = [ ];
-
-detect-transient = true; # Use WM_TRANSIENT_FOR to group windows, and consider windows in
- # the same group focused at the same time.
-detect-client-leader = true; # Use WM_CLIENT_LEADER to group windows.
-invert-color-include = [ ]; # Conditions for windows to be painted with inverted color.
-
-# resize-damage = 1;
-
-
-####################################
-###### Window type settings ########
-####################################
-wintypes:
-{
- tooltip = { fade = true; shadow = true; opacity = 0.75; focus = true; };
- # fade: Fade the particular type of windows.
- # shadow: Give those windows shadow
- # opacity: Default opacity for the type of windows.
- # focus: Whether to always consider windows of this type focused.
-};
diff --git a/awesome/backup/compton-2019-02-02.conf b/awesome/backup/compton-2019-02-02.conf
deleted file mode 100644
index 455ec56..0000000
--- a/awesome/backup/compton-2019-02-02.conf
+++ /dev/null
@@ -1,153 +0,0 @@
-# Shadow
-shadow = false;
-shadow-radius = 5;
-shadow-offset-x = -5;
-shadow-offset-y = -5;
-log-level = "warn";
-#change your username here
-#log-file = "/home/erik/.config/compton.log";
-shadow-opacity = 0.5;
-# Set if you want different colour shadows
-# shadow-red = 0.0;
-# shadow-green = 0.0;
-# shadow-blue = 0.0;
-# The shadow exclude options are helpful if you have shadows enabled.
-# Due to the way compton draws its shadows, certain applications will have visual glitches
-# (most applications are fine, only apps that do weird things with xshapes or argb are affected).
-# This list includes all the affected apps I found in my testing.
-# The "! name~=''" part excludes shadows on any "Unknown" windows, this prevents
-# a visual glitch with the XFWM alt tab switcher.
-shadow-exclude = [
- "! name~=''",
- "name = 'Notification'",
- "class_g = 'Conky'",
- "class_g ?= 'Notify-osd'",
- "class_g = 'Cairo-clock'",
- "class_g ?= 'Cairo-dock'",
- "class_g = 'Kupfer'",
- "class_g = 'Synapse'",
- "class_g ?= 'Xfce4-notifyd'",
- "class_g ?= 'Xfce4-power-manager'",
- "name = 'Plank'",
- "name = 'Docky'",
- "name = 'Kupfer'",
- "name = 'xfce4-notifyd'",
- "name *= 'VLC'",
- "name *= 'compton'",
- "name *= 'Chromium'",
- "name *= 'Chrome'",
- "n:w:*VirtualBox*",
- "_GTK_FRAME_EXTENTS@:c"
-];
-# shadow-exclude = "n:e:Notification";
-# shadow-exclude-reg = "x10+0+0";
-# xinerama-shadow-crop = true;
-
-# Opacity
-inactive-opacity = 1;
-active-opacity = 1;
-frame-opacity = 1;
-inactive-opacity-override = false;
-# inactive-dim = 0.2;
-# Do not let dimness adjust based on window opacity.
-# inactive-dim-fixed = true;
-# Blur background of transparent windows. Bad performance with X Render backend. GLX backend is preferred.
-# blur-background = true;
-# Blur background of opaque windows with transparent frames as well.
-# blur-background-frame = true;
-blur-kern = "3x3box";
-# blur-kern = "5,5,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1";
-# Do not let blur radius adjust based on window opacity.
-# blur-background-fixed = true;
-blur-background-exclude = [
- "window_type = 'dock'",
- "window_type = 'desktop'",
- "_GTK_FRAME_EXTENTS@:c"
-];
-
-# If you have issues with transparency with these terminals
-# maybe next lines will help
-#opacity-rule = [ "80:class_g = 'URxvt'" ];
-#opacity-rule = [ "80:class_g = 'termite'" ];
-
-# Fading
-# Fade windows during opacity changes.
-fading = false;
-# The time between steps in a fade in milliseconds. (default 30).
-fade-delta = 5;
-# Opacity change between steps while fading in. (default 0.03).
-fade-in-step = 0.03;
-# Opacity change between steps while fading out. (default 0.03).
-fade-out-step = 0.03;
-# Fade windows in/out when opening/closing
-# no-fading-openclose = true;
-# no-fading-destroyed-argb = true;
-# Specify a list of conditions of windows that should not be faded.
-fade-exclude = [ ];
-
-# Other
-#backend = "glx";
-backend = "xrender";
-# Try to detect WM windows and mark them as active.
-mark-wmwin-focused = true;
-# Mark all non-WM but override-redirect windows active (e.g. menus).
-mark-ovredir-focused = true;
-# Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused instead of using FocusIn/Out events.
-# Usually more reliable but depends on a EWMH-compliant WM.
-# use-ewmh-active-win = true;
-# Detect rounded corners and treat them as rectangular when --shadow-ignore-shaped is on.
-detect-rounded-corners = true;
-
-# Detect _NET_WM_OPACITY on client windows, useful for window managers not passing _NET_WM_OPACITY of client windows to frame windows.
-# This prevents opacity being ignored for some apps.
-# For example without this enabled my xfce4-notifyd is 100% opacity no matter what.
-detect-client-opacity = true;
-# Specify refresh rate of the screen.
-# If not specified or 0, compton will try detecting this with X RandR extension.
-refresh-rate = 0;
-# Set VSync method. VSync methods currently available:
-# none: No VSync
-# drm: VSync with DRM_IOCTL_WAIT_VBLANK. May only work on some drivers.
-# opengl: Try to VSync with SGI_video_sync OpenGL extension. Only work on some drivers.
-# opengl-oml: Try to VSync with OML_sync_control OpenGL extension. Only work on some drivers.
-# opengl-swc: Try to VSync with SGI_swap_control OpenGL extension. Only work on some drivers. Works only with GLX backend. Known to be most effective on many drivers. Does not actually control paint timing, only buffer swap is affected, so it doesn’t have the effect of --sw-opti unlike other methods. Experimental.
-# opengl-mswc: Try to VSync with MESA_swap_control OpenGL extension. Basically the same as opengl-swc above, except the extension we use.
-# (Note some VSync methods may not be enabled at compile time.)
-vsync = "none";
-# Limit compton to repaint at most once every 1 / refresh_rate second to boost performance.
-# This should not be used with --vsync drm/opengl/opengl-oml as they essentially does --sw-opti's job already,
-# unless you wish to specify a lower refresh rate than the actual value.
-# sw-opti = true;
-# Unredirect all windows if a full-screen opaque window is detected, to maximize performance for full-screen windows, like games.
-# Known to cause flickering when redirecting/unredirecting windows.
-# paint-on-overlay may make the flickering less obvious.
-# unredir-if-possible = true;
-# unredir-if-possible-delay = 5000;
-# unredir-if-possible-exclude = [ ];
-# Specify a list of conditions of windows that should always be considered focused.
-focus-exclude = [ "class_g = 'Cairo-clock'" ];
-# Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time.
-detect-transient = true;
-# Use WM_CLIENT_LEADER to group windows, and consider windows in the same group focused at the same time.
-# WM_TRANSIENT_FOR has higher priority if --detect-transient is enabled, too.
-detect-client-leader = true;
-invert-color-include = [ ];
-# resize-damage = 1;
-
-# GLX backend
-# glx-no-stencil = true;
-# glx-no-rebind-pixmap = true;
-glx-swap-method = "undefined";
-# glx-use-gpushader4 = true;
-# xrender-sync = true;
-# xrender-sync-fence = true;
-
-# Window type settings
-wintypes:
-{
- tooltip = { fade = true; shadow = true; opacity = 0.9; focus = true; full-shadow = false; };
- dock = { shadow = false; }
- dnd = { shadow = false; }
- popup_menu = { opacity = 0.9; }
- dropdown_menu = { opacity = 0.9; }
-};
diff --git a/awesome/backup/compton-2019-04-01.conf b/awesome/backup/compton-2019-04-01.conf
deleted file mode 100644
index b45fb9b..0000000
--- a/awesome/backup/compton-2019-04-01.conf
+++ /dev/null
@@ -1,153 +0,0 @@
-# Shadow
-shadow = false;
-shadow-radius = 5;
-shadow-offset-x = -5;
-shadow-offset-y = -5;
-log-level = "warn";
-#change your username here
-#log-file = "/home/erik/.config/compton.log";
-shadow-opacity = 0.5;
-# Set if you want different colour shadows
-# shadow-red = 0.0;
-# shadow-green = 0.0;
-# shadow-blue = 0.0;
-# The shadow exclude options are helpful if you have shadows enabled.
-# Due to the way compton draws its shadows, certain applications will have visual glitches
-# (most applications are fine, only apps that do weird things with xshapes or argb are affected).
-# This list includes all the affected apps I found in my testing.
-# The "! name~=''" part excludes shadows on any "Unknown" windows, this prevents
-# a visual glitch with the XFWM alt tab switcher.
-shadow-exclude = [
- "! name~=''",
- "name = 'Notification'",
- "class_g = 'Conky'",
- "class_g ?= 'Notify-osd'",
- "class_g = 'Cairo-clock'",
- "class_g ?= 'Cairo-dock'",
- "class_g = 'Kupfer'",
- "class_g = 'Synapse'",
- "class_g ?= 'Xfce4-notifyd'",
- "class_g ?= 'Xfce4-power-manager'",
- "name = 'Plank'",
- "name = 'Docky'",
- "name = 'Kupfer'",
- "name = 'xfce4-notifyd'",
- "name *= 'VLC'",
- "name *= 'compton'",
- "name *= 'Chromium'",
- "name *= 'Chrome'",
- "n:w:*VirtualBox*",
- "_GTK_FRAME_EXTENTS@:c"
-];
-# shadow-exclude = "n:e:Notification";
-# shadow-exclude-reg = "x10+0+0";
-# xinerama-shadow-crop = true;
-
-# Opacity
-inactive-opacity = 1;
-active-opacity = 1;
-frame-opacity = 1;
-inactive-opacity-override = false;
-# inactive-dim = 0.2;
-# Do not let dimness adjust based on window opacity.
-# inactive-dim-fixed = true;
-# Blur background of transparent windows. Bad performance with X Render backend. GLX backend is preferred.
-# blur-background = true;
-# Blur background of opaque windows with transparent frames as well.
-# blur-background-frame = true;
-blur-kern = "3x3box";
-# blur-kern = "5,5,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1";
-# Do not let blur radius adjust based on window opacity.
-# blur-background-fixed = true;
-blur-background-exclude = [
- "window_type = 'dock'",
- "window_type = 'desktop'",
- "_GTK_FRAME_EXTENTS@:c"
-];
-
-# If you have issues with transparency with these terminals
-# maybe next lines will help
-#opacity-rule = [ "80:class_g = 'URxvt'" ];
-#opacity-rule = [ "80:class_g = 'termite'" ];
-
-# Fading
-# Fade windows during opacity changes.
-fading = false;
-# The time between steps in a fade in milliseconds. (default 30).
-fade-delta = 5;
-# Opacity change between steps while fading in. (default 0.03).
-fade-in-step = 0.03;
-# Opacity change between steps while fading out. (default 0.03).
-fade-out-step = 0.03;
-# Fade windows in/out when opening/closing
-# no-fading-openclose = true;
-# no-fading-destroyed-argb = true;
-# Specify a list of conditions of windows that should not be faded.
-fade-exclude = [ ];
-
-# Other
-#backend = "glx";
-backend = "xrender";
-# Try to detect WM windows and mark them as active.
-mark-wmwin-focused = true;
-# Mark all non-WM but override-redirect windows active (e.g. menus).
-mark-ovredir-focused = true;
-# Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused instead of using FocusIn/Out events.
-# Usually more reliable but depends on a EWMH-compliant WM.
-# use-ewmh-active-win = true;
-# Detect rounded corners and treat them as rectangular when --shadow-ignore-shaped is on.
-detect-rounded-corners = true;
-
-# Detect _NET_WM_OPACITY on client windows, useful for window managers not passing _NET_WM_OPACITY of client windows to frame windows.
-# This prevents opacity being ignored for some apps.
-# For example without this enabled my xfce4-notifyd is 100% opacity no matter what.
-detect-client-opacity = true;
-# Specify refresh rate of the screen.
-# If not specified or 0, compton will try detecting this with X RandR extension.
-refresh-rate = 0;
-# Set VSync method. VSync methods currently available:
-# none: No VSync
-# drm: VSync with DRM_IOCTL_WAIT_VBLANK. May only work on some drivers.
-# opengl: Try to VSync with SGI_video_sync OpenGL extension. Only work on some drivers.
-# opengl-oml: Try to VSync with OML_sync_control OpenGL extension. Only work on some drivers.
-# opengl-swc: Try to VSync with SGI_swap_control OpenGL extension. Only work on some drivers. Works only with GLX backend. Known to be most effective on many drivers. Does not actually control paint timing, only buffer swap is affected, so it doesn’t have the effect of --sw-opti unlike other methods. Experimental.
-# opengl-mswc: Try to VSync with MESA_swap_control OpenGL extension. Basically the same as opengl-swc above, except the extension we use.
-# (Note some VSync methods may not be enabled at compile time.)
-vsync = "none";
-# Limit compton to repaint at most once every 1 / refresh_rate second to boost performance.
-# This should not be used with --vsync drm/opengl/opengl-oml as they essentially does --sw-opti's job already,
-# unless you wish to specify a lower refresh rate than the actual value.
-# sw-opti = true;
-# Unredirect all windows if a full-screen opaque window is detected, to maximize performance for full-screen windows, like games.
-# Known to cause flickering when redirecting/unredirecting windows.
-# paint-on-overlay may make the flickering less obvious.
-# unredir-if-possible = true;
-# unredir-if-possible-delay = 5000;
-# unredir-if-possible-exclude = [ ];
-# Specify a list of conditions of windows that should always be considered focused.
-focus-exclude = [ "class_g = 'Cairo-clock'" ];
-# Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time.
-detect-transient = true;
-# Use WM_CLIENT_LEADER to group windows, and consider windows in the same group focused at the same time.
-# WM_TRANSIENT_FOR has higher priority if --detect-transient is enabled, too.
-detect-client-leader = true;
-invert-color-include = [ ];
-# resize-damage = 1;
-
-# GLX backend
-glx-no-stencil = true;
-glx-no-rebind-pixmap = true;
-# glx-swap-method = "undefined";
-# glx-use-gpushader4 = true;
-# xrender-sync = true;
-# xrender-sync-fence = true;
-
-# Window type settings
-wintypes:
-{
- tooltip = { fade = true; shadow = true; opacity = 0.9; focus = true; full-shadow = false; };
- dock = { shadow = false; }
- dnd = { shadow = false; }
- popup_menu = { opacity = 0.9; }
- dropdown_menu = { opacity = 0.9; }
-};
diff --git a/awesome/backup/compton-arch.conf b/awesome/backup/compton-arch.conf
deleted file mode 100644
index c018b2f..0000000
--- a/awesome/backup/compton-arch.conf
+++ /dev/null
@@ -1,226 +0,0 @@
-# Thank you code_nomad: http://9m.no/ꪯ鵞
-# and Arch Wiki contributors: https://wiki.archlinux.org/index.php/Compton
-
-#################################
-#
-# Backend
-#
-#################################
-
-# Backend to use: "xrender" or "glx".
-# GLX backend is typically much faster but depends on a sane driver.
-backend = "glx";
-
-#################################
-#
-# GLX backend
-#
-#################################
-
-glx-no-stencil = true;
-
-# GLX backend: Copy unmodified regions from front buffer instead of redrawing them all.
-# My tests with nvidia-drivers show a 10% decrease in performance when the whole screen is modified,
-# but a 20% increase when only 1/4 is.
-# My tests on nouveau show terrible slowdown.
-glx-copy-from-front = false;
-
-# GLX backend: Use MESA_copy_sub_buffer to do partial screen update.
-# My tests on nouveau shows a 200% performance boost when only 1/4 of the screen is updated.
-# May break VSync and is not available on some drivers.
-# Overrides --glx-copy-from-front.
-# glx-use-copysubbuffermesa = true;
-
-# GLX backend: Avoid rebinding pixmap on window damage.
-# Probably could improve performance on rapid window content changes, but is known to break things on some drivers (LLVMpipe).
-# Recommended if it works.
-# glx-no-rebind-pixmap = true;
-
-# GLX backend: GLX buffer swap method we assume.
-# Could be undefined (0), copy (1), exchange (2), 3-6, or buffer-age (-1).
-# undefined is the slowest and the safest, and the default value.
-# copy is fastest, but may fail on some drivers,
-# 2-6 are gradually slower but safer (6 is still faster than 0).
-# Usually, double buffer means 2, triple buffer means 3.
-# buffer-age means auto-detect using GLX_EXT_buffer_age, supported by some drivers.
-# Useless with --glx-use-copysubbuffermesa.
-# Partially breaks --resize-damage.
-# Defaults to undefined.
-#glx-swap-method = "undefined";
-
-#################################
-#
-# Shadows
-#
-#################################
-
-# Enabled client-side shadows on windows.
-shadow = true;
-# The blur radius for shadows. (default 12)
-shadow-radius = 5;
-# The left offset for shadows. (default -15)
-shadow-offset-x = -5;
-# The top offset for shadows. (default -15)
-shadow-offset-y = -5;
-# The translucency for shadows. (default .75)
-shadow-opacity = 0.5;
-
-# Set if you want different colour shadows
-# shadow-red = 0.0;
-# shadow-green = 0.0;
-# shadow-blue = 0.0;
-
-# The shadow exclude options are helpful if you have shadows enabled. Due to the way compton draws its shadows, certain applications will have visual glitches
-# (most applications are fine, only apps that do weird things with xshapes or argb are affected).
-# This list includes all the affected apps I found in my testing. The "! name~=''" part excludes shadows on any "Unknown" windows, this prevents a visual glitch with the XFWM alt tab switcher.
-shadow-exclude = [
- "! name~=''",
- "name = 'Notification'",
- "name = 'Plank'",
- "name = 'Docky'",
- "name = 'Kupfer'",
- "name = 'xfce4-notifyd'",
- "name *= 'VLC'",
- "name *= 'compton'",
- "name *= 'Chromium'",
- "name *= 'Chrome'",
- "class_g = 'Firefox' && argb",
- "class_g = 'Conky'",
- "class_g = 'Kupfer'",
- "class_g = 'Synapse'",
- "class_g ?= 'Notify-osd'",
- "class_g ?= 'Cairo-dock'",
- "class_g ?= 'Xfce4-notifyd'",
- "class_g ?= 'Xfce4-power-manager'",
- "_GTK_FRAME_EXTENTS@:c",
- "_NET_WM_STATE@:32a *= '_NET_WM_STATE_HIDDEN'"
-];
-# Avoid drawing shadow on all shaped windows (see also: --detect-rounded-corners)
-shadow-ignore-shaped = false;
-
-#################################
-#
-# Opacity
-#
-#################################
-
-inactive-opacity = 1;
-active-opacity = 1;
-frame-opacity = 1;
-inactive-opacity-override = false;
-
-# Dim inactive windows. (0.0 - 1.0)
-# inactive-dim = 0.2;
-# Do not let dimness adjust based on window opacity.
-# inactive-dim-fixed = true;
-# Blur background of transparent windows. Bad performance with X Render backend. GLX backend is preferred.
-# blur-background = true;
-# Blur background of opaque windows with transparent frames as well.
-# blur-background-frame = true;
-# Do not let blur radius adjust based on window opacity.
-blur-background-fixed = false;
-blur-background-exclude = [
- "window_type = 'dock'",
- "window_type = 'desktop'"
-];
-
-#################################
-#
-# Fading
-#
-#################################
-
-# Fade windows during opacity changes.
-fading = true;
-# The time between steps in a fade in milliseconds. (default 10).
-fade-delta = 4;
-# Opacity change between steps while fading in. (default 0.028).
-fade-in-step = 0.03;
-# Opacity change between steps while fading out. (default 0.03).
-fade-out-step = 0.03;
-# Fade windows in/out when opening/closing
-# no-fading-openclose = true;
-
-# Specify a list of conditions of windows that should not be faded.
-fade-exclude = [ ];
-
-#################################
-#
-# Other
-#
-#################################
-
-# Try to detect WM windows and mark them as active.
-mark-wmwin-focused = true;
-# Mark all non-WM but override-redirect windows active (e.g. menus).
-mark-ovredir-focused = true;
-# Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused instead of using FocusIn/Out events.
-# Usually more reliable but depends on a EWMH-compliant WM.
-use-ewmh-active-win = true;
-# Detect rounded corners and treat them as rectangular when --shadow-ignore-shaped is on.
-detect-rounded-corners = true;
-
-# Detect _NET_WM_OPACITY on client windows, useful for window managers not passing _NET_WM_OPACITY of client windows to frame windows.
-# This prevents opacity being ignored for some apps.
-# For example without this enabled my xfce4-notifyd is 100% opacity no matter what.
-detect-client-opacity = true;
-
-# Specify refresh rate of the screen.
-# If not specified or 0, compton will try detecting this with X RandR extension.
-refresh-rate = 0;
-
-# Vertical synchronization: match the refresh rate of the monitor
-vsync = true;
-
-# Enable DBE painting mode, intended to use with VSync to (hopefully) eliminate tearing.
-# Reported to have no effect, though.
-dbe = false;
-
-# Limit compton to repaint at most once every 1 / refresh_rate second to boost performance.
-# This should not be used with --vsync drm/opengl/opengl-oml as they essentially does --sw-opti's job already,
-# unless you wish to specify a lower refresh rate than the actual value.
-#sw-opti = true;
-
-# Unredirect all windows if a full-screen opaque window is detected, to maximize performance for full-screen windows, like games.
-# Known to cause flickering when redirecting/unredirecting windows.
-unredir-if-possible = false;
-
-# Specify a list of conditions of windows that should always be considered focused.
-focus-exclude = [ ];
-
-# Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time.
-detect-transient = true;
-# Use WM_CLIENT_LEADER to group windows, and consider windows in the same group focused at the same time.
-# WM_TRANSIENT_FOR has higher priority if --detect-transient is enabled, too.
-detect-client-leader = true;
-
-#################################
-#
-# Window type settings
-#
-#################################
-
-wintypes:
-{
- tooltip =
- {
- # fade: Fade the particular type of windows.
- fade = true;
- # shadow: Give those windows shadow
- shadow = false;
- # opacity: Default opacity for the type of windows.
- opacity = 0.85;
- # focus: Whether to always consider windows of this type focused.
- focus = true;
- };
-};
-
-######################
-#
-# XSync
-# See: https://github.com/yshui/compton/commit/b18d46bcbdc35a3b5620d817dd46fbc76485c20d
-#
-######################
-
-# Use X Sync fence to sync clients' draw calls. Needed on nvidia-drivers with GLX backend for some users.
-xrender-sync-fence = true;
diff --git a/awesome/backup/compton-picom-rename-11-2019.conf b/awesome/backup/compton-picom-rename-11-2019.conf
deleted file mode 100644
index 5d9bd44..0000000
--- a/awesome/backup/compton-picom-rename-11-2019.conf
+++ /dev/null
@@ -1,228 +0,0 @@
-# Thank you code_nomad: http://9m.no/ꪯ鵞
-# and Arch Wiki contributors: https://wiki.archlinux.org/index.php/Compton
-
-#################################
-#
-# Backend
-#
-#################################
-
-# Backend to use: "xrender" or "glx".
-# GLX backend is typically much faster but depends on a sane driver.
-backend = "glx";
-#backend = "xrender"
-
-#################################
-#
-# GLX backend
-#
-#################################
-
-glx-no-stencil = true;
-
-# GLX backend: Copy unmodified regions from front buffer instead of redrawing them all.
-# My tests with nvidia-drivers show a 10% decrease in performance when the whole screen is modified,
-# but a 20% increase when only 1/4 is.
-# My tests on nouveau show terrible slowdown.
-glx-copy-from-front = false;
-
-# GLX backend: Use MESA_copy_sub_buffer to do partial screen update.
-# My tests on nouveau shows a 200% performance boost when only 1/4 of the screen is updated.
-# May break VSync and is not available on some drivers.
-# Overrides --glx-copy-from-front.
-# glx-use-copysubbuffermesa = true;
-
-# GLX backend: Avoid rebinding pixmap on window damage.
-# Probably could improve performance on rapid window content changes, but is known to break things on some drivers (LLVMpipe).
-# Recommended if it works.
-# glx-no-rebind-pixmap = true;
-
-# GLX backend: GLX buffer swap method we assume.
-# Could be undefined (0), copy (1), exchange (2), 3-6, or buffer-age (-1).
-# undefined is the slowest and the safest, and the default value.
-# copy is fastest, but may fail on some drivers,
-# 2-6 are gradually slower but safer (6 is still faster than 0).
-# Usually, double buffer means 2, triple buffer means 3.
-# buffer-age means auto-detect using GLX_EXT_buffer_age, supported by some drivers.
-# Useless with --glx-use-copysubbuffermesa.
-# Partially breaks --resize-damage.
-# Defaults to undefined.
-#glx-swap-method = "undefined";
-
-#################################
-#
-# Shadows
-#
-#################################
-
-# Enabled client-side shadows on windows.
-shadow = false;
-# The blur radius for shadows. (default 12)
-shadow-radius = 5;
-# The left offset for shadows. (default -15)
-shadow-offset-x = -5;
-# The top offset for shadows. (default -15)
-shadow-offset-y = -5;
-# The translucency for shadows. (default .75)
-shadow-opacity = 0.5;
-
-log-level = "warn";
-#change your username here
-#log-file = "/home/erik/.config/compton.log";
-
-# Set if you want different colour shadows
-# shadow-red = 0.0;
-# shadow-green = 0.0;
-# shadow-blue = 0.0;
-
-# The shadow exclude options are helpful if you have shadows enabled. Due to the way compton draws its shadows, certain applications will have visual glitches
-# (most applications are fine, only apps that do weird things with xshapes or argb are affected).
-# This list includes all the affected apps I found in my testing. The "! name~=''" part excludes shadows on any "Unknown" windows, this prevents a visual glitch with the XFWM alt tab switcher.
-shadow-exclude = [
- "! name~=''",
- "name = 'Notification'",
- "name = 'Plank'",
- "name = 'Docky'",
- "name = 'Kupfer'",
- "name = 'xfce4-notifyd'",
- "name *= 'VLC'",
- "name *= 'compton'",
- "name *= 'Chromium'",
- "name *= 'Chrome'",
- "class_g = 'Firefox' && argb",
- "class_g = 'Conky'",
- "class_g = 'Kupfer'",
- "class_g = 'Synapse'",
- "class_g ?= 'Notify-osd'",
- "class_g ?= 'Cairo-dock'",
- "class_g = 'Cairo-clock'",
- "class_g ?= 'Xfce4-notifyd'",
- "class_g ?= 'Xfce4-power-manager'",
- "_GTK_FRAME_EXTENTS@:c",
- "_NET_WM_STATE@:32a *= '_NET_WM_STATE_HIDDEN'"
-];
-# Avoid drawing shadow on all shaped windows (see also: --detect-rounded-corners)
-shadow-ignore-shaped = false;
-
-#################################
-#
-# Opacity
-#
-#################################
-
-inactive-opacity = 1;
-active-opacity = 1;
-frame-opacity = 1;
-inactive-opacity-override = false;
-
-# Dim inactive windows. (0.0 - 1.0)
-# inactive-dim = 0.2;
-# Do not let dimness adjust based on window opacity.
-# inactive-dim-fixed = true;
-# Blur background of transparent windows. Bad performance with X Render backend. GLX backend is preferred.
-# blur-background = true;
-# Blur background of opaque windows with transparent frames as well.
-# blur-background-frame = true;
-# Do not let blur radius adjust based on window opacity.
-blur-background-fixed = false;
-blur-background-exclude = [
- "window_type = 'dock'",
- "window_type = 'desktop'",
- "_GTK_FRAME_EXTENTS@:c"
-];
-
-#################################
-#
-# Fading
-#
-#################################
-
-# Fade windows during opacity changes.
-fading = false;
-# The time between steps in a fade in milliseconds. (default 10).
-fade-delta = 4;
-# Opacity change between steps while fading in. (default 0.028).
-fade-in-step = 0.03;
-# Opacity change between steps while fading out. (default 0.03).
-fade-out-step = 0.03;
-# Fade windows in/out when opening/closing
-# no-fading-openclose = true;
-
-# Specify a list of conditions of windows that should not be faded.
-fade-exclude = [ ];
-
-#################################
-#
-# Other
-#
-#################################
-
-# Try to detect WM windows and mark them as active.
-mark-wmwin-focused = true;
-# Mark all non-WM but override-redirect windows active (e.g. menus).
-mark-ovredir-focused = true;
-# Use EWMH _NET_WM_ACTIVE_WINDOW to determine which window is focused instead of using FocusIn/Out events.
-# Usually more reliable but depends on a EWMH-compliant WM.
-use-ewmh-active-win = true;
-# Detect rounded corners and treat them as rectangular when --shadow-ignore-shaped is on.
-detect-rounded-corners = true;
-
-# Detect _NET_WM_OPACITY on client windows, useful for window managers not passing _NET_WM_OPACITY of client windows to frame windows.
-# This prevents opacity being ignored for some apps.
-# For example without this enabled my xfce4-notifyd is 100% opacity no matter what.
-detect-client-opacity = true;
-
-# Specify refresh rate of the screen.
-# If not specified or 0, compton will try detecting this with X RandR extension.
-refresh-rate = 0;
-
-# Vertical synchronization: match the refresh rate of the monitor
-# this breaks transparency in virtualbox - put a "#" before next line to fix that
-vsync = true;
-
-# Enable DBE painting mode, intended to use with VSync to (hopefully) eliminate tearing.
-# Reported to have no effect, though.
-dbe = false;
-
-# Limit compton to repaint at most once every 1 / refresh_rate second to boost performance.
-# This should not be used with --vsync drm/opengl/opengl-oml as they essentially does --sw-opti's job already,
-# unless you wish to specify a lower refresh rate than the actual value.
-#sw-opti = true;
-
-# Unredirect all windows if a full-screen opaque window is detected, to maximize performance for full-screen windows, like games.
-# Known to cause flickering when redirecting/unredirecting windows.
-unredir-if-possible = false;
-
-# Specify a list of conditions of windows that should always be considered focused.
-focus-exclude = [ ];
-
-# Use WM_TRANSIENT_FOR to group windows, and consider windows in the same group focused at the same time.
-detect-transient = true;
-# Use WM_CLIENT_LEADER to group windows, and consider windows in the same group focused at the same time.
-# WM_TRANSIENT_FOR has higher priority if --detect-transient is enabled, too.
-detect-client-leader = true;
-
-#################################
-#
-# Window type settings
-#
-#################################
-
-wintypes:
-{
- tooltip = { fade = true; shadow = true; opacity = 0.9; focus = true;};
- dock = { shadow = false; }
- dnd = { shadow = false; }
- popup_menu = { opacity = 0.9; }
- dropdown_menu = { opacity = 0.9; }
-};
-
-######################
-#
-# XSync
-# See: https://github.com/yshui/compton/commit/b18d46bcbdc35a3b5620d817dd46fbc76485c20d
-#
-######################
-
-# Use X Sync fence to sync clients' draw calls. Needed on nvidia-drivers with GLX backend for some users.
-xrender-sync-fence = true;
diff --git a/awesome/backup/compton.conf.github b/awesome/backup/compton.conf.github
deleted file mode 100644
index 5466990..0000000
--- a/awesome/backup/compton.conf.github
+++ /dev/null
@@ -1,89 +0,0 @@
-# 2018 12 21
-# https://github.com/yshui/compton/blob/next/compton.sample.conf
-#
-# Shadow
-shadow = true;
-shadow-radius = 7;
-shadow-offset-x = -7;
-shadow-offset-y = -7;
-log-level = "warn";
-# log-file = "/path/to/your/log/file";
-# shadow-opacity = 0.7;
-# shadow-red = 0.0;
-# shadow-green = 0.0;
-# shadow-blue = 0.0;
-shadow-exclude = [
- "name = 'Notification'",
- "class_g = 'Conky'",
- "class_g ?= 'Notify-osd'",
- "class_g = 'Cairo-clock'",
- "_GTK_FRAME_EXTENTS@:c"
-];
-# shadow-exclude = "n:e:Notification";
-# shadow-exclude-reg = "x10+0+0";
-# xinerama-shadow-crop = true;
-
-# Opacity
-inactive-opacity = 0.8;
-# active-opacity = 0.8;
-frame-opacity = 0.7;
-inactive-opacity-override = false;
-# inactive-dim = 0.2;
-# inactive-dim-fixed = true;
-# blur-background = true;
-# blur-background-frame = true;
-blur-kern = "3x3box";
-# blur-kern = "5,5,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1";
-# blur-background-fixed = true;
-blur-background-exclude = [
- "window_type = 'dock'",
- "window_type = 'desktop'",
- "_GTK_FRAME_EXTENTS@:c"
-];
-# opacity-rule = [ "80:class_g = 'URxvt'" ];
-
-# Fading
-fading = true;
-# fade-delta = 30;
-fade-in-step = 0.03;
-fade-out-step = 0.03;
-# no-fading-openclose = true;
-# no-fading-destroyed-argb = true;
-fade-exclude = [ ];
-
-# Other
-backend = "xrender";
-mark-wmwin-focused = true;
-mark-ovredir-focused = true;
-# use-ewmh-active-win = true;
-detect-rounded-corners = true;
-detect-client-opacity = true;
-refresh-rate = 0;
-vsync = "none";
-# sw-opti = true;
-# unredir-if-possible = true;
-# unredir-if-possible-delay = 5000;
-# unredir-if-possible-exclude = [ ];
-focus-exclude = [ "class_g = 'Cairo-clock'" ];
-detect-transient = true;
-detect-client-leader = true;
-invert-color-include = [ ];
-# resize-damage = 1;
-
-# GLX backend
-# glx-no-stencil = true;
-# glx-no-rebind-pixmap = true;
-glx-swap-method = "undefined";
-# glx-use-gpushader4 = true;
-# xrender-sync = true;
-# xrender-sync-fence = true;
-
-# Window type settings
-wintypes:
-{
- tooltip = { fade = true; shadow = true; opacity = 0.75; focus = true; full-shadow = false; };
- dock = { shadow = false; }
- dnd = { shadow = false; }
- popup_menu = { opacity = 0.8; }
- dropdown_menu = { opacity = 0.8; }
-};
diff --git a/awesome/freedesktop/desktop.lua b/awesome/freedesktop/desktop.lua
deleted file mode 100644
index 748debd..0000000
--- a/awesome/freedesktop/desktop.lua
+++ /dev/null
@@ -1,254 +0,0 @@
---[[
-
- Awesome-Freedesktop
- Freedesktop.org compliant desktop entries and menu
-
- Desktop section
-
- Licensed under GNU General Public License v2
- * (c) 2016, Luke Bonham
- * (c) 2009-2015, Antonio Terceiro
-
---]]
-
-local awful = require("awful")
-local theme = require("beautiful")
-local utils = require("menubar.utils")
-local wibox = require("wibox")
-
-local capi = capi
-local io = io
-local ipairs = ipairs
-local mouse = mouse
-local os = os
-local string = string
-local table = table
-
--- Desktop icons
--- freedesktop.desktop
-local desktop = {
- -- Default desktop basic icons
- baseicons = {
- [1] = {
- label = "This PC",
- icon = "computer",
- onclick = "computer://"
- },
- [2] = {
- label = "Home",
- icon = "user-home",
- onclick = os.getenv("HOME")
- },
- [3] = {
- label = "Trash",
- icon = "user-trash",
- onclick = "trash://"
- }
- },
- -- Default parameters
- iconsize = { width = 48, height = 48 },
- labelsize = { width = 140, height = 20 },
- margin = { x = 20, y = 20 },
-}
-
--- MIME types list
-local mime_types = {}
-
--- Icons positioning
-local desktop_current_pos = {}
-
--- @return iterator on input pipe
-local function pipelines(...)
- local f = assert(io.popen(...))
- return function ()
- local data = f:read()
- if data == nil then f:close() end
- return data
- end
-end
-
--- Adds an icon to desktop
--- @param args settings from desktop.add_icons
--- @param label icon string label
--- @param icon icon string file path
--- @param onclick function to execute on click
-function desktop.add_single_icon(args, label, icon, onclick)
- local s = args.screen
-
- -- define icon dimensions and position
- if not desktop_current_pos[s] then
- desktop_current_pos[s] = { x = (capi.screen[s].geometry.x + args.iconsize.width + args.margin.x), y = 40 }
- end
-
- local totheight = (icon and args.iconsize.height or 0) + (label and args.labelsize.height or 0)
- if totheight == 0 then return end
-
- if desktop_current_pos[s].y + totheight > capi.screen[s].geometry.height - 40 then
- desktop_current_pos[s].x = desktop_current_pos[s].x + args.labelsize.width + args.iconsize.width + args.margin.x
- desktop_current_pos[s].y = 40
- end
-
- local common = { screen = s, bg = "#00000000", visible = true, type = "desktop" }
-
- -- create icon container
- if icon then
- common.width = args.iconsize.width
- common.height = args.iconsize.height
- common.x = desktop_current_pos[s].x
- common.y = desktop_current_pos[s].y
-
- icon = wibox.widget {
- image = icon,
- resize = false,
- widget = wibox.widget.imagebox
- }
-
- icon:buttons(awful.button({ }, 1, nil, onclick))
-
- icon_container = wibox(common)
- icon_container:set_widget(icon)
-
- desktop_current_pos[s].y = desktop_current_pos[s].y + args.iconsize.height + 5
- end
-
- -- create label container
- if label then
- common.width = args.labelsize.width
- common.height = args.labelsize.height
- common.x = desktop_current_pos[s].x - (args.labelsize.width/2) + args.iconsize.width/2
- common.y = desktop_current_pos[s].y
-
- caption = wibox.widget {
- text = label,
- align = "center",
- forced_width = common.width,
- forced_height = common.height,
- ellipsize = "middle",
- widget = wibox.widget.textbox
- }
-
- caption:buttons(awful.button({ }, 1, onclick))
- caption_container = wibox(common)
- caption_container:set_widget(caption)
- end
-
- desktop_current_pos[s].y = desktop_current_pos[s].y + args.labelsize.height + args.margin.y
-end
-
--- Adds base icons (This PC, Trash, etc) to desktop
--- @param args settings from desktop.add_icons
-function desktop.add_base_icons(args)
- for _,base in ipairs(args.baseicons) do
- desktop.add_single_icon(args, base.label, utils.lookup_icon(base.icon), function()
- awful.spawn(string.format("%s '%s'", args.open_with, base.onclick))
- end)
- end
-end
-
--- Looks up a suitable icon for filename
--- @param filename string file name
--- @return icon file path (string)
-function desktop.lookup_file_icon(filename)
- -- load system MIME types
- if #mime_types == 0 then
- for line in io.lines("/etc/mime.types") do
- if not line:find("^#") then
- local parsed = {}
- for w in line:gmatch("[^%s]+") do
- table.insert(parsed, w)
- end
- if #parsed > 1 then
- for i = 2, #parsed do
- mime_types[parsed[i]] = parsed[1]:gsub("/", "-")
- end
- end
- end
- end
- end
-
- -- try to search a possible icon among standards
- local extension = filename:match("%a+$")
- local mime = mime_types[extension] or ""
- local mime_family = mime:match("^%a+") or ""
-
- local possible_filenames = {
- mime, "gnome-mime-" .. mime,
- mime_family, "gnome-mime-" .. mime_family,
- extension
- }
-
- for i, filename in ipairs(possible_filenames) do
- local icon = utils.lookup_icon(filename)
- if icon then return icon end
- end
-
- -- if we don"t find ad icon, then pretend is a plain text file
- return utils.lookup_icon("text-x-generic")
-end
-
--- Parse subdirectories and files list from input directory
--- @input dir directory to parse (string)
--- @return files table with found entries
-function desktop.parse_dirs_and_files(dir)
- local files = {}
- local paths = pipelines('find '..dir..' -maxdepth 1 -type d | tail -1')
- for path in paths do
- if path:match("[^/]+$") then
- local file = {}
- file.filename = path:match("[^/]+$")
- file.path = path
- file.show = true
- file.icon = utils.lookup_icon("folder")
- table.insert(files, file)
- end
- end
- local paths = pipelines('find '..dir..' -maxdepth 1 -type f')
- for path in paths do
- if not path:find("%.desktop$") then
- local file = {}
- file.filename = path:match("[^/]+$")
- file.path = path
- file.show = true
- file.icon = desktop.lookup_file_icon(file.filename)
- table.insert(files, file)
- end
- end
- return files
-end
-
--- Adds subdirectories and files icons from args.dir
--- @param args settings from desktop.add_icons
-function desktop.add_dirs_and_files_icons(args)
- for _, file in ipairs(desktop.parse_dirs_and_files(args.dir)) do
- if file.show then
- local label = args.showlabels and file.filename or nil
- local onclick = function () awful.spawn(string.format("%s '%s'", args.open_with, file.path)) end
- desktop.add_single_icon(args, label, file.icon, onclick)
- end
- end
-end
-
--- Main function, adds base, directory and files icons
--- @param args user defined settings, with fallback on defaults
-function desktop.add_icons(args)
- args = args or {}
- args.screen = args.screen or mouse.screen
- args.dir = args.dir or os.getenv("HOME") .. "/Desktop"
- args.showlabels = args.showlabel or true
- args.open_with = args.open_with or "xdg_open"
- args.baseicons = args.baseicons or desktop.baseicons
- args.iconsize = args.iconsize or desktop.iconsize
- args.labelsize = args.labelsize or desktop.labelsize
- args.margin = args.margin or desktop.margin
-
- -- trying to fallback on Adwaita if theme.icon_theme is not defined
- -- if Adwaita is missing too, no icons will be shown
- if not theme.icon_theme then
- theme.icon_theme = args.icon_theme or "Adwaita"
- end
-
- desktop.add_base_icons(args)
- desktop.add_dirs_and_files_icons(args)
-end
-
-return desktop
diff --git a/awesome/freedesktop/init.lua b/awesome/freedesktop/init.lua
deleted file mode 100644
index 9350b44..0000000
--- a/awesome/freedesktop/init.lua
+++ /dev/null
@@ -1,15 +0,0 @@
---[[
-
- Awesome-Freedesktop
- Freedesktop.org compliant desktop entries and menu
-
- Licensed under GNU General Public License v2
- * (c) 2016, Luke Bonham
- * (c) 2009-2015, Antonio Terceiro
-
---]]
-
-return {
- desktop = require("freedesktop.desktop"),
- menu = require("freedesktop.menu")
-}
diff --git a/awesome/freedesktop/menu.lua b/awesome/freedesktop/menu.lua
deleted file mode 100644
index 56f1204..0000000
--- a/awesome/freedesktop/menu.lua
+++ /dev/null
@@ -1,133 +0,0 @@
---[[
-
- Awesome-Freedesktop
- Freedesktop.org compliant desktop entries and menu
-
- Menu section
-
- Licensed under GNU General Public License v2
- * (c) 2016, Luke Bonham
- * (c) 2014, Harvey Mittens
-
---]]
-
-local awful_menu = require("awful.menu")
-local menu_gen = require("menubar.menu_gen")
-local menu_utils = require("menubar.utils")
---local icon_theme = require("menubar.icon_theme")
-
-local io, pairs, string, table, os = io, pairs, string, table, os
-
--- Add support for NixOS systems too
-table.insert(menu_gen.all_menu_dirs, string.format("%s/.nix-profile/share/applications", os.getenv("HOME")))
-
--- Expecting a wm_name of awesome omits too many applications and tools
-menu_utils.wm_name = ""
-
--- Menu
--- freedesktop.menu
-local menu = {}
-
--- Determines if a path points to a directory, by checking if it can be read
--- (which is `nil` also for empty files) and if its size is not 0.
--- @author blueyed
--- @param path the path to check
-function menu.is_dir(path)
- local f = io.open(path)
- return f and not f:read(0) and f:seek("end") ~= 0 and f:close()
-end
-
--- Remove non existent paths in order to avoid issues
-local existent_paths = {}
-for k,v in pairs(menu_gen.all_menu_dirs) do
- if menu.is_dir(v) then
- table.insert(existent_paths, v)
- end
-end
-menu_gen.all_menu_dirs = existent_paths
-
--- Determines whether an table includes a certain element
--- @param tab a given table
--- @param val the element to search for
--- @return true if the given string is found within the search table; otherwise, false if not
-function menu.has_value (tab, val)
- for index, value in pairs(tab) do
- if val:find(value) then
- return true
- end
- end
- return false
-end
-
--- Use MenuBar parsing utils to build a menu for Awesome
--- @return awful.menu
-function menu.build(args)
- local args = args or {}
--- local icon_size = args.icon_size
- local before = args.before or {}
- local after = args.after or {}
- local skip_items = args.skip_items or {}
- local sub_menu = args.sub_menu or false
-
- local result = {}
- local _menu = awful_menu({ items = before })
-
- menu_gen.generate(function(entries)
- -- Add category icons
- for k in pairs(menu_gen.all_categories) do
- table.insert(result, { k, {}, })
- end
-
- -- Get items table
- for k, v in pairs(entries) do
- for _, cat in pairs(result) do
- if cat[1] == v.category then
- if not menu.has_value(skip_items, v.name) then
- table.insert(cat[2], { v.name, v.cmdline })
- end
- break
- end
- end
- end
-
- -- Cleanup things a bit
- for i = #result, 1, -1 do
- local v = result[i]
- if #v[2] == 0 then
- -- Remove unused categories
- table.remove(result, i)
- else
- --Sort entries alphabetically (by name)
- table.sort(v[2], function (a, b) return string.byte(a[1]) < string.byte(b[1]) end)
- -- Replace category name with nice name
- v[1] = menu_gen.all_categories[v[1]].name
- end
- end
-
- -- Sort categories alphabetically also
- table.sort(result, function(a, b) return string.byte(a[1]) < string.byte(b[1]) end)
-
- -- Add menu item to hold the generated menu
- if sub_menu then
- result = {{sub_menu, result}}
- end
-
- -- Add items to menu
- for _, v in pairs(result) do _menu:add(v) end
- for _, v in pairs(after) do _menu:add(v) end
- end)
-
- -- Set icon size
---[[ if icon_size then
- for _,v in pairs(menu_gen.all_categories) do
- v.icon = icon_theme():find_icon_path(v.icon_name, icon_size)
- end
- end
---]]
- -- Hold the menu in the module
- menu.menu = _menu
-
- return _menu
-end
-
-return menu
diff --git a/awesome/lain/helpers.lua b/awesome/lain/helpers.lua
deleted file mode 100644
index d6f6b3c..0000000
--- a/awesome/lain/helpers.lua
+++ /dev/null
@@ -1,204 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
-
---]]
-
-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
-
--- Lain helper functions for internal use
--- lain.helpers
-local helpers = {}
-
-helpers.lain_dir = debug.getinfo(1, 'S').source:match[[^@(.*/).*$]]
-helpers.icons_dir = helpers.lain_dir .. 'icons/'
-helpers.scripts_dir = helpers.lain_dir .. 'scripts/'
-
--- {{{ Modules loader
-
-function helpers.wrequire(table, key)
- local module = rawget(table, key)
- return module or require(table._NAME .. '.' .. key)
-end
-
--- }}}
-
--- {{{ File operations
-
--- check if the file exists and is readable
-function helpers.file_exists(path)
- local file = io.open(path, "rb")
- if file then file:close() end
- return file ~= nil
-end
-
--- get a table with all lines from a file
-function helpers.lines_from(path)
- local lines = {}
- for line in io.lines(path) do
- lines[#lines + 1] = line
- end
- return lines
-end
-
--- get a table with all lines from a file matching regexp
-function helpers.lines_match(regexp, path)
- local lines = {}
- for line in io.lines(path) do
- if string.match(line, regexp) then
- lines[#lines + 1] = line
- end
- end
- return lines
-end
-
--- get first line of a file
-function helpers.first_line(path)
- local file, first = io.open(path, "rb"), nil
- if file then
- first = file:read("*l")
- file:close()
- end
- return first
-end
-
--- get first non empty line from a file
-function helpers.first_nonempty_line(path)
- for line in io.lines(path) do
- if #line then return line end
- end
- return nil
-end
-
--- }}}
-
--- {{{ Timer maker
-
-helpers.timer_table = {}
-
-function helpers.newtimer(name, timeout, fun, nostart, stoppable)
- if not name or #name == 0 then return end
- name = (stoppable and name) or timeout
- if not helpers.timer_table[name] then
- helpers.timer_table[name] = timer({ timeout = timeout })
- helpers.timer_table[name]:start()
- end
- helpers.timer_table[name]:connect_signal("timeout", fun)
- if not nostart then
- helpers.timer_table[name]:emit_signal("timeout")
- end
- return stoppable and helpers.timer_table[name]
-end
-
--- }}}
-
--- {{{ Pipe operations
-
--- run a command and execute a function on its output (asynchronous pipe)
--- @param cmd the input command
--- @param callback function to execute on cmd output
--- @return cmd PID
-function helpers.async(cmd, callback)
- return spawn.easy_async(cmd,
- function (stdout, stderr, reason, exit_code)
- callback(stdout, exit_code)
- end)
-end
-
--- like above, but call spawn.easy_async with a shell
-function helpers.async_with_shell(cmd, callback)
- return spawn.easy_async_with_shell(cmd,
- function (stdout, stderr, reason, exit_code)
- callback(stdout, exit_code)
- end)
-end
-
--- run a command and execute a function on its output line by line
-function helpers.line_callback(cmd, callback)
- return spawn.with_line_callback(cmd, {
- stdout = function (line)
- callback(line)
- end,
- })
-end
-
--- }}}
-
--- {{{ A map utility
-
-helpers.map_table = {}
-
-function helpers.set_map(element, value)
- helpers.map_table[element] = value
-end
-
-function helpers.get_map(element)
- return helpers.map_table[element]
-end
-
--- }}}
-
--- {{{ Misc
-
--- check if an element exist on a table
-function helpers.element_in_table(element, tbl)
- for _, i in pairs(tbl) do
- if i == element then
- return true
- end
- end
- return false
-end
-
--- iterate over table of records sorted by keys
-function helpers.spairs(t)
- -- collect the keys
- local keys = {}
- for k in pairs(t) do keys[#keys+1] = k end
-
- table.sort(keys)
-
- -- return the iterator function
- local i = 0
- return function()
- i = i + 1
- if keys[i] then
- return keys[i], t[keys[i]]
- end
- end
-end
-
--- create the partition of singletons of a given set
--- example: the trivial partition set of {a, b, c}, is {{a}, {b}, {c}}
-function helpers.trivial_partition_set(set)
- local ss = {}
- for _,e in pairs(set) do
- ss[#ss+1] = {e}
- end
- return ss
-end
-
--- create the powerset of a given set
-function helpers.powerset(s)
- if not s then return {} end
- local t = {{}}
- for i = 1, #s do
- for j = 1, #t do
- t[#t+1] = {s[i],unpack(t[j])}
- end
- end
- return t
-end
-
--- }}}
-
-return helpers
diff --git a/awesome/lain/icons/cal/black/1.png b/awesome/lain/icons/cal/black/1.png
deleted file mode 100644
index d2fb62e..0000000
Binary files a/awesome/lain/icons/cal/black/1.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/10.png b/awesome/lain/icons/cal/black/10.png
deleted file mode 100644
index 507b079..0000000
Binary files a/awesome/lain/icons/cal/black/10.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/11.png b/awesome/lain/icons/cal/black/11.png
deleted file mode 100644
index 336141b..0000000
Binary files a/awesome/lain/icons/cal/black/11.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/12.png b/awesome/lain/icons/cal/black/12.png
deleted file mode 100644
index c589729..0000000
Binary files a/awesome/lain/icons/cal/black/12.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/13.png b/awesome/lain/icons/cal/black/13.png
deleted file mode 100644
index 377518b..0000000
Binary files a/awesome/lain/icons/cal/black/13.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/14.png b/awesome/lain/icons/cal/black/14.png
deleted file mode 100644
index 6f4a9fe..0000000
Binary files a/awesome/lain/icons/cal/black/14.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/15.png b/awesome/lain/icons/cal/black/15.png
deleted file mode 100644
index 1a271c1..0000000
Binary files a/awesome/lain/icons/cal/black/15.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/16.png b/awesome/lain/icons/cal/black/16.png
deleted file mode 100644
index 5e65835..0000000
Binary files a/awesome/lain/icons/cal/black/16.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/17.png b/awesome/lain/icons/cal/black/17.png
deleted file mode 100644
index f3fa0a9..0000000
Binary files a/awesome/lain/icons/cal/black/17.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/18.png b/awesome/lain/icons/cal/black/18.png
deleted file mode 100644
index 7acb37a..0000000
Binary files a/awesome/lain/icons/cal/black/18.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/19.png b/awesome/lain/icons/cal/black/19.png
deleted file mode 100644
index a557957..0000000
Binary files a/awesome/lain/icons/cal/black/19.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/2.png b/awesome/lain/icons/cal/black/2.png
deleted file mode 100644
index 17b33e0..0000000
Binary files a/awesome/lain/icons/cal/black/2.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/20.png b/awesome/lain/icons/cal/black/20.png
deleted file mode 100644
index 558d111..0000000
Binary files a/awesome/lain/icons/cal/black/20.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/21.png b/awesome/lain/icons/cal/black/21.png
deleted file mode 100644
index 0bbedc8..0000000
Binary files a/awesome/lain/icons/cal/black/21.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/22.png b/awesome/lain/icons/cal/black/22.png
deleted file mode 100644
index 762d262..0000000
Binary files a/awesome/lain/icons/cal/black/22.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/23.png b/awesome/lain/icons/cal/black/23.png
deleted file mode 100644
index a39dcee..0000000
Binary files a/awesome/lain/icons/cal/black/23.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/24.png b/awesome/lain/icons/cal/black/24.png
deleted file mode 100644
index c00dbca..0000000
Binary files a/awesome/lain/icons/cal/black/24.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/25.png b/awesome/lain/icons/cal/black/25.png
deleted file mode 100644
index dc9243c..0000000
Binary files a/awesome/lain/icons/cal/black/25.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/26.png b/awesome/lain/icons/cal/black/26.png
deleted file mode 100644
index 50bb182..0000000
Binary files a/awesome/lain/icons/cal/black/26.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/27.png b/awesome/lain/icons/cal/black/27.png
deleted file mode 100644
index 0fbf9fc..0000000
Binary files a/awesome/lain/icons/cal/black/27.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/28.png b/awesome/lain/icons/cal/black/28.png
deleted file mode 100644
index def6ab2..0000000
Binary files a/awesome/lain/icons/cal/black/28.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/29.png b/awesome/lain/icons/cal/black/29.png
deleted file mode 100644
index 531923c..0000000
Binary files a/awesome/lain/icons/cal/black/29.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/3.png b/awesome/lain/icons/cal/black/3.png
deleted file mode 100644
index 98b552d..0000000
Binary files a/awesome/lain/icons/cal/black/3.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/30.png b/awesome/lain/icons/cal/black/30.png
deleted file mode 100644
index ca58151..0000000
Binary files a/awesome/lain/icons/cal/black/30.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/31.png b/awesome/lain/icons/cal/black/31.png
deleted file mode 100644
index 6e8da21..0000000
Binary files a/awesome/lain/icons/cal/black/31.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/4.png b/awesome/lain/icons/cal/black/4.png
deleted file mode 100644
index 4335979..0000000
Binary files a/awesome/lain/icons/cal/black/4.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/5.png b/awesome/lain/icons/cal/black/5.png
deleted file mode 100644
index 576ec11..0000000
Binary files a/awesome/lain/icons/cal/black/5.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/6.png b/awesome/lain/icons/cal/black/6.png
deleted file mode 100644
index 56fa8ab..0000000
Binary files a/awesome/lain/icons/cal/black/6.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/7.png b/awesome/lain/icons/cal/black/7.png
deleted file mode 100644
index 7c90b3a..0000000
Binary files a/awesome/lain/icons/cal/black/7.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/8.png b/awesome/lain/icons/cal/black/8.png
deleted file mode 100644
index 9d1f28e..0000000
Binary files a/awesome/lain/icons/cal/black/8.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/black/9.png b/awesome/lain/icons/cal/black/9.png
deleted file mode 100644
index 00d0933..0000000
Binary files a/awesome/lain/icons/cal/black/9.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/1.png b/awesome/lain/icons/cal/white/1.png
deleted file mode 100644
index a0faa20..0000000
Binary files a/awesome/lain/icons/cal/white/1.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/10.png b/awesome/lain/icons/cal/white/10.png
deleted file mode 100644
index 7d9343b..0000000
Binary files a/awesome/lain/icons/cal/white/10.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/11.png b/awesome/lain/icons/cal/white/11.png
deleted file mode 100644
index 7af5e99..0000000
Binary files a/awesome/lain/icons/cal/white/11.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/12.png b/awesome/lain/icons/cal/white/12.png
deleted file mode 100644
index b164f85..0000000
Binary files a/awesome/lain/icons/cal/white/12.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/13.png b/awesome/lain/icons/cal/white/13.png
deleted file mode 100644
index fef74f3..0000000
Binary files a/awesome/lain/icons/cal/white/13.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/14.png b/awesome/lain/icons/cal/white/14.png
deleted file mode 100644
index d747a6b..0000000
Binary files a/awesome/lain/icons/cal/white/14.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/15.png b/awesome/lain/icons/cal/white/15.png
deleted file mode 100644
index 64418a6..0000000
Binary files a/awesome/lain/icons/cal/white/15.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/16.png b/awesome/lain/icons/cal/white/16.png
deleted file mode 100644
index 8b86700..0000000
Binary files a/awesome/lain/icons/cal/white/16.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/17.png b/awesome/lain/icons/cal/white/17.png
deleted file mode 100644
index 033b5ff..0000000
Binary files a/awesome/lain/icons/cal/white/17.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/18.png b/awesome/lain/icons/cal/white/18.png
deleted file mode 100644
index 0cf1c24..0000000
Binary files a/awesome/lain/icons/cal/white/18.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/19.png b/awesome/lain/icons/cal/white/19.png
deleted file mode 100644
index bfd3530..0000000
Binary files a/awesome/lain/icons/cal/white/19.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/2.png b/awesome/lain/icons/cal/white/2.png
deleted file mode 100644
index e7f3fa4..0000000
Binary files a/awesome/lain/icons/cal/white/2.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/20.png b/awesome/lain/icons/cal/white/20.png
deleted file mode 100644
index 9a5a1fb..0000000
Binary files a/awesome/lain/icons/cal/white/20.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/21.png b/awesome/lain/icons/cal/white/21.png
deleted file mode 100644
index 266ab9f..0000000
Binary files a/awesome/lain/icons/cal/white/21.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/22.png b/awesome/lain/icons/cal/white/22.png
deleted file mode 100644
index f486289..0000000
Binary files a/awesome/lain/icons/cal/white/22.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/23.png b/awesome/lain/icons/cal/white/23.png
deleted file mode 100644
index 244dceb..0000000
Binary files a/awesome/lain/icons/cal/white/23.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/24.png b/awesome/lain/icons/cal/white/24.png
deleted file mode 100644
index 0ce1c75..0000000
Binary files a/awesome/lain/icons/cal/white/24.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/25.png b/awesome/lain/icons/cal/white/25.png
deleted file mode 100644
index 48d279c..0000000
Binary files a/awesome/lain/icons/cal/white/25.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/26.png b/awesome/lain/icons/cal/white/26.png
deleted file mode 100644
index 7535855..0000000
Binary files a/awesome/lain/icons/cal/white/26.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/27.png b/awesome/lain/icons/cal/white/27.png
deleted file mode 100644
index 2aa9074..0000000
Binary files a/awesome/lain/icons/cal/white/27.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/28.png b/awesome/lain/icons/cal/white/28.png
deleted file mode 100644
index 0201976..0000000
Binary files a/awesome/lain/icons/cal/white/28.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/29.png b/awesome/lain/icons/cal/white/29.png
deleted file mode 100644
index 9305b9b..0000000
Binary files a/awesome/lain/icons/cal/white/29.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/3.png b/awesome/lain/icons/cal/white/3.png
deleted file mode 100644
index f1eb5de..0000000
Binary files a/awesome/lain/icons/cal/white/3.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/30.png b/awesome/lain/icons/cal/white/30.png
deleted file mode 100644
index 1ba61aa..0000000
Binary files a/awesome/lain/icons/cal/white/30.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/31.png b/awesome/lain/icons/cal/white/31.png
deleted file mode 100644
index e9a873b..0000000
Binary files a/awesome/lain/icons/cal/white/31.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/4.png b/awesome/lain/icons/cal/white/4.png
deleted file mode 100644
index ee1ed6a..0000000
Binary files a/awesome/lain/icons/cal/white/4.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/5.png b/awesome/lain/icons/cal/white/5.png
deleted file mode 100644
index 466aa71..0000000
Binary files a/awesome/lain/icons/cal/white/5.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/6.png b/awesome/lain/icons/cal/white/6.png
deleted file mode 100644
index 0a7bf4d..0000000
Binary files a/awesome/lain/icons/cal/white/6.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/7.png b/awesome/lain/icons/cal/white/7.png
deleted file mode 100644
index e971951..0000000
Binary files a/awesome/lain/icons/cal/white/7.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/8.png b/awesome/lain/icons/cal/white/8.png
deleted file mode 100644
index cb03d0b..0000000
Binary files a/awesome/lain/icons/cal/white/8.png and /dev/null differ
diff --git a/awesome/lain/icons/cal/white/9.png b/awesome/lain/icons/cal/white/9.png
deleted file mode 100644
index fca554a..0000000
Binary files a/awesome/lain/icons/cal/white/9.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/cascade.png b/awesome/lain/icons/layout/default/cascade.png
deleted file mode 100644
index 292a057..0000000
Binary files a/awesome/lain/icons/layout/default/cascade.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/cascadetile.png b/awesome/lain/icons/layout/default/cascadetile.png
deleted file mode 100644
index ba30f43..0000000
Binary files a/awesome/lain/icons/layout/default/cascadetile.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/cascadetilew.png b/awesome/lain/icons/layout/default/cascadetilew.png
deleted file mode 100644
index d15eb70..0000000
Binary files a/awesome/lain/icons/layout/default/cascadetilew.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/cascadew.png b/awesome/lain/icons/layout/default/cascadew.png
deleted file mode 100644
index da64bd6..0000000
Binary files a/awesome/lain/icons/layout/default/cascadew.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/centerfair.png b/awesome/lain/icons/layout/default/centerfair.png
deleted file mode 100644
index 188c243..0000000
Binary files a/awesome/lain/icons/layout/default/centerfair.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/centerfairw.png b/awesome/lain/icons/layout/default/centerfairw.png
deleted file mode 100644
index ed4bcf5..0000000
Binary files a/awesome/lain/icons/layout/default/centerfairw.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/centerwork.png b/awesome/lain/icons/layout/default/centerwork.png
deleted file mode 100644
index 51e06bc..0000000
Binary files a/awesome/lain/icons/layout/default/centerwork.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/centerworkh.png b/awesome/lain/icons/layout/default/centerworkh.png
deleted file mode 100644
index c59092f..0000000
Binary files a/awesome/lain/icons/layout/default/centerworkh.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/centerworkhw.png b/awesome/lain/icons/layout/default/centerworkhw.png
deleted file mode 100644
index 7820f8c..0000000
Binary files a/awesome/lain/icons/layout/default/centerworkhw.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/centerworkw.png b/awesome/lain/icons/layout/default/centerworkw.png
deleted file mode 100644
index 85e6996..0000000
Binary files a/awesome/lain/icons/layout/default/centerworkw.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/termfair.png b/awesome/lain/icons/layout/default/termfair.png
deleted file mode 100644
index 06226c1..0000000
Binary files a/awesome/lain/icons/layout/default/termfair.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/default/termfairw.png b/awesome/lain/icons/layout/default/termfairw.png
deleted file mode 100644
index 0a8b576..0000000
Binary files a/awesome/lain/icons/layout/default/termfairw.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/zenburn/cascade.png b/awesome/lain/icons/layout/zenburn/cascade.png
deleted file mode 100644
index fbe4fac..0000000
Binary files a/awesome/lain/icons/layout/zenburn/cascade.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/zenburn/cascadetile.png b/awesome/lain/icons/layout/zenburn/cascadetile.png
deleted file mode 100644
index 2e03a80..0000000
Binary files a/awesome/lain/icons/layout/zenburn/cascadetile.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/zenburn/centerfair.png b/awesome/lain/icons/layout/zenburn/centerfair.png
deleted file mode 100644
index 75dc993..0000000
Binary files a/awesome/lain/icons/layout/zenburn/centerfair.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/zenburn/centerwork.png b/awesome/lain/icons/layout/zenburn/centerwork.png
deleted file mode 100644
index af7a863..0000000
Binary files a/awesome/lain/icons/layout/zenburn/centerwork.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/zenburn/centerworkh.png b/awesome/lain/icons/layout/zenburn/centerworkh.png
deleted file mode 100644
index 88019b3..0000000
Binary files a/awesome/lain/icons/layout/zenburn/centerworkh.png and /dev/null differ
diff --git a/awesome/lain/icons/layout/zenburn/termfair.png b/awesome/lain/icons/layout/zenburn/termfair.png
deleted file mode 100644
index f7640b5..0000000
Binary files a/awesome/lain/icons/layout/zenburn/termfair.png and /dev/null differ
diff --git a/awesome/lain/icons/mail.png b/awesome/lain/icons/mail.png
deleted file mode 100644
index 9c0c7a3..0000000
Binary files a/awesome/lain/icons/mail.png and /dev/null differ
diff --git a/awesome/lain/icons/no_net.png b/awesome/lain/icons/no_net.png
deleted file mode 100644
index 3613372..0000000
Binary files a/awesome/lain/icons/no_net.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/01d.png b/awesome/lain/icons/openweathermap/01d.png
deleted file mode 100644
index 569965e..0000000
Binary files a/awesome/lain/icons/openweathermap/01d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/01n.png b/awesome/lain/icons/openweathermap/01n.png
deleted file mode 100644
index ce5b135..0000000
Binary files a/awesome/lain/icons/openweathermap/01n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/02d.png b/awesome/lain/icons/openweathermap/02d.png
deleted file mode 100644
index 2ba9799..0000000
Binary files a/awesome/lain/icons/openweathermap/02d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/02n.png b/awesome/lain/icons/openweathermap/02n.png
deleted file mode 100644
index 12e4283..0000000
Binary files a/awesome/lain/icons/openweathermap/02n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/03d.png b/awesome/lain/icons/openweathermap/03d.png
deleted file mode 100644
index 1cf0e9d..0000000
Binary files a/awesome/lain/icons/openweathermap/03d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/03n.png b/awesome/lain/icons/openweathermap/03n.png
deleted file mode 100644
index 89a42b8..0000000
Binary files a/awesome/lain/icons/openweathermap/03n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/04d.png b/awesome/lain/icons/openweathermap/04d.png
deleted file mode 100644
index e7fb67f..0000000
Binary files a/awesome/lain/icons/openweathermap/04d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/04n.png b/awesome/lain/icons/openweathermap/04n.png
deleted file mode 100644
index e7fb67f..0000000
Binary files a/awesome/lain/icons/openweathermap/04n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/09d.png b/awesome/lain/icons/openweathermap/09d.png
deleted file mode 100644
index cfa066a..0000000
Binary files a/awesome/lain/icons/openweathermap/09d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/09n.png b/awesome/lain/icons/openweathermap/09n.png
deleted file mode 100644
index cfa066a..0000000
Binary files a/awesome/lain/icons/openweathermap/09n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/10d.png b/awesome/lain/icons/openweathermap/10d.png
deleted file mode 100644
index 712d0c8..0000000
Binary files a/awesome/lain/icons/openweathermap/10d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/10n.png b/awesome/lain/icons/openweathermap/10n.png
deleted file mode 100644
index 712d0c8..0000000
Binary files a/awesome/lain/icons/openweathermap/10n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/11d.png b/awesome/lain/icons/openweathermap/11d.png
deleted file mode 100644
index 3b62f7c..0000000
Binary files a/awesome/lain/icons/openweathermap/11d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/11n.png b/awesome/lain/icons/openweathermap/11n.png
deleted file mode 100644
index 3b62f7c..0000000
Binary files a/awesome/lain/icons/openweathermap/11n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/13d.png b/awesome/lain/icons/openweathermap/13d.png
deleted file mode 100644
index e265b01..0000000
Binary files a/awesome/lain/icons/openweathermap/13d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/13n.png b/awesome/lain/icons/openweathermap/13n.png
deleted file mode 100644
index e265b01..0000000
Binary files a/awesome/lain/icons/openweathermap/13n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/50d.png b/awesome/lain/icons/openweathermap/50d.png
deleted file mode 100644
index 905ace3..0000000
Binary files a/awesome/lain/icons/openweathermap/50d.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/50n.png b/awesome/lain/icons/openweathermap/50n.png
deleted file mode 100644
index 905ace3..0000000
Binary files a/awesome/lain/icons/openweathermap/50n.png and /dev/null differ
diff --git a/awesome/lain/icons/openweathermap/README.md b/awesome/lain/icons/openweathermap/README.md
deleted file mode 100644
index f908fbd..0000000
--- a/awesome/lain/icons/openweathermap/README.md
+++ /dev/null
@@ -1,3 +0,0 @@
-[Plain Weather Icons](http://merlinthered.deviantart.com/art/plain-weather-icons-157162192), created by [MerlinTheRed](http://merlinthered.deviantart.com/).
-
-
diff --git a/awesome/lain/icons/openweathermap/na.png b/awesome/lain/icons/openweathermap/na.png
deleted file mode 100644
index 1cc5132..0000000
Binary files a/awesome/lain/icons/openweathermap/na.png and /dev/null differ
diff --git a/awesome/lain/icons/taskwarrior.png b/awesome/lain/icons/taskwarrior.png
deleted file mode 100644
index c64fe86..0000000
Binary files a/awesome/lain/icons/taskwarrior.png and /dev/null differ
diff --git a/awesome/lain/init.lua b/awesome/lain/init.lua
deleted file mode 100644
index b59d5dd..0000000
--- a/awesome/lain/init.lua
+++ /dev/null
@@ -1,15 +0,0 @@
---[[
-
- Lain
- Layouts, widgets and utilities for Awesome WM
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
-
---]]
-
-return {
- layout = require("lain.layout"),
- util = require("lain.util"),
- widget = require("lain.widget")
-}
diff --git a/awesome/lain/layout/cascade.lua b/awesome/lain/layout/cascade.lua
deleted file mode 100644
index cbc3877..0000000
--- a/awesome/lain/layout/cascade.lua
+++ /dev/null
@@ -1,172 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2014, projektile
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local floor = math.floor
-local screen = screen
-
-local cascade = {
- name = "cascade",
- nmaster = 0,
- offset_x = 32,
- offset_y = 8,
- tile = {
- name = "cascadetile",
- nmaster = 0,
- ncol = 0,
- mwfact = 0,
- offset_x = 5,
- offset_y = 32,
- extra_padding = 0
- }
-}
-
-local function do_cascade(p, tiling)
- local t = p.tag or screen[p.screen].selected_tag
- local wa = p.workarea
- local cls = p.clients
-
- if #cls == 0 then return end
-
- if not tiling then
- -- Cascade windows.
-
- local num_c
- if cascade.nmaster > 0 then
- num_c = cascade.nmaster
- else
- num_c = t.master_count
- end
-
- -- Opening a new window will usually force all existing windows to
- -- get resized. This wastes a lot of CPU time. So let's set a lower
- -- bound to "how_many": This wastes a little screen space but you'll
- -- get a much better user experience.
- local how_many = (#cls >= num_c and #cls) or num_c
-
- local current_offset_x = cascade.offset_x * (how_many - 1)
- local current_offset_y = cascade.offset_y * (how_many - 1)
-
- -- Iterate.
- for i = 1,#cls,1 do
- local c = cls[i]
- local g = {}
-
- g.x = wa.x + (how_many - i) * cascade.offset_x
- g.y = wa.y + (i - 1) * cascade.offset_y
- g.width = wa.width - current_offset_x
- g.height = wa.height - current_offset_y
-
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
-
- p.geometries[c] = g
- end
- else
- -- Layout with one fixed column meant for a master window. Its
- -- width is calculated according to mwfact. Other clients are
- -- cascaded or "tabbed" in a slave column on the right.
-
- -- (1) (2) (3) (4)
- -- +----------+---+ +----------+---+ +----------+---+ +----------+---+
- -- | | | | | 3 | | | 4 | | +---+|
- -- | | | -> | | | -> | +---++ -> | +---+|+
- -- | 1 | 2 | | 1 +---++ | 1 | 3 || | 1 +---+|+|
- -- | | | | | 2 || | +---++| | +---+|+ |
- -- | | | | | || | | 2 | | | | 2 |+ |
- -- +----------+---+ +---------+---++ +--------+---+-+ +------+---+---+
-
- local mwfact
- if cascade.tile.mwfact > 0 then
- mwfact = cascade.tile.mwfact
- else
- mwfact = t.master_width_factor
- end
-
- -- Make slave windows overlap main window? Do this if ncol is 1.
- local overlap_main
- if cascade.tile.ncol > 0 then
- overlap_main = cascade.tile.ncol
- else
- overlap_main = t.column_count
- end
-
- -- Minimum space for slave windows? See cascade.tile.lua.
- local num_c
- if cascade.tile.nmaster > 0 then
- num_c = cascade.tile.nmaster
- else
- num_c = t.master_count
- end
-
- local how_many = (#cls - 1 >= num_c and (#cls - 1)) or num_c
-
- local current_offset_x = cascade.tile.offset_x * (how_many - 1)
- local current_offset_y = cascade.tile.offset_y * (how_many - 1)
-
- if #cls <= 0 then return end
-
- -- Main column, fixed width and height.
- local c = cls[1]
- local g = {}
- -- Rounding is necessary to prevent the rendered size of slavewid
- -- from being 1 pixel off when the result is not an integer.
- local mainwid = floor(wa.width * mwfact)
- local slavewid = wa.width - mainwid
-
- if overlap_main == 1 then
- g.width = wa.width
-
- -- The size of the main window may be reduced a little bit.
- -- This allows you to see if there are any windows below the
- -- main window.
- -- This only makes sense, though, if the main window is
- -- overlapping everything else.
- g.width = g.width - cascade.tile.extra_padding
- else
- g.width = mainwid
- end
-
- g.height = wa.height
- g.x = wa.x
- g.y = wa.y
-
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
-
- p.geometries[c] = g
-
- -- Remaining clients stacked in slave column, new ones on top.
- if #cls <= 1 then return end
- for i = 2,#cls do
- c = cls[i]
- g = {}
-
- g.width = slavewid - current_offset_x
- g.height = wa.height - current_offset_y
-
- g.x = wa.x + mainwid + (how_many - (i - 1)) * cascade.tile.offset_x
- g.y = wa.y + (i - 2) * cascade.tile.offset_y
-
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
-
- p.geometries[c] = g
- end
- end
-end
-
-function cascade.tile.arrange(p)
- return do_cascade(p, true)
-end
-
-function cascade.arrange(p)
- return do_cascade(p, false)
-end
-
-return cascade
diff --git a/awesome/lain/layout/centerwork.lua b/awesome/lain/layout/centerwork.lua
deleted file mode 100644
index 2b38a69..0000000
--- a/awesome/lain/layout/centerwork.lua
+++ /dev/null
@@ -1,194 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2018, Eugene Pakhomov
- * (c) 2016, Henrik Antonsson
- * (c) 2015, Joerg Jaspert
- * (c) 2014, projektile
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local floor, max, mouse, mousegrabber, screen = math.floor, math.max, mouse, mousegrabber, screen
-
-local centerwork = {
- name = "centerwork",
- horizontal = { name = "centerworkh" }
-}
-
-local function arrange(p, layout)
- local t = p.tag or screen[p.screen].selected_tag
- local wa = p.workarea
- local cls = p.clients
-
- if #cls == 0 then return end
-
- local c, g = cls[1], {}
-
- -- Main column, fixed width and height
- local mwfact = t.master_width_factor
- local mainhei = floor(wa.height * mwfact)
- local mainwid = floor(wa.width * mwfact)
- local slavewid = wa.width - mainwid
- local slaveLwid = floor(slavewid / 2)
- local slaveRwid = slavewid - slaveLwid
- local slavehei = wa.height - mainhei
- local slaveThei = floor(slavehei / 2)
- local slaveBhei = slavehei - slaveThei
- local nbrFirstSlaves = floor(#cls / 2)
- local nbrSecondSlaves = floor((#cls - 1) / 2)
-
- local slaveFirstDim, slaveSecondDim = 0, 0
-
- if layout.name == "centerwork" then -- vertical
- if nbrFirstSlaves > 0 then slaveFirstDim = floor(wa.height / nbrFirstSlaves) end
- if nbrSecondSlaves > 0 then slaveSecondDim = floor(wa.height / nbrSecondSlaves) end
-
- g.height = wa.height
- g.width = mainwid
-
- g.x = wa.x + slaveLwid
- g.y = wa.y
- else -- horizontal
- if nbrFirstSlaves > 0 then slaveFirstDim = floor(wa.width / nbrFirstSlaves) end
- if nbrSecondSlaves > 0 then slaveSecondDim = floor(wa.width / nbrSecondSlaves) end
-
- g.height = mainhei
- g.width = wa.width
-
- g.x = wa.x
- g.y = wa.y + slaveThei
- end
-
- g.width = max(g.width, 1)
- g.height = max(g.height, 1)
-
- p.geometries[c] = g
-
- -- Auxiliary clients
- if #cls <= 1 then return end
- for i = 2, #cls do
- local c, g = cls[i], {}
- local idxChecker, dimToAssign
-
- local rowIndex = floor(i/2)
-
- if layout.name == "centerwork" then
- if i % 2 == 0 then -- left slave
- g.x = wa.x
- g.y = wa.y + (rowIndex - 1) * slaveFirstDim
- g.width = slaveLwid
-
- idxChecker, dimToAssign = nbrFirstSlaves, slaveFirstDim
- else -- right slave
- g.x = wa.x + slaveLwid + mainwid
- g.y = wa.y + (rowIndex - 1) * slaveSecondDim
- g.width = slaveRwid
-
- idxChecker, dimToAssign = nbrSecondSlaves, slaveSecondDim
- end
-
- -- if last slave in row, use remaining space for it
- if rowIndex == idxChecker then
- g.height = wa.y + wa.height - g.y
- else
- g.height = dimToAssign
- end
- else
- if i % 2 == 0 then -- top slave
- g.x = wa.x + (rowIndex - 1) * slaveFirstDim
- g.y = wa.y
- g.height = slaveThei
-
- idxChecker, dimToAssign = nbrFirstSlaves, slaveFirstDim
- else -- bottom slave
- g.x = wa.x + (rowIndex - 1) * slaveSecondDim
- g.y = wa.y + slaveThei + mainhei
- g.height = slaveBhei
-
- idxChecker, dimToAssign = nbrSecondSlaves, slaveSecondDim
- end
-
- -- if last slave in row, use remaining space for it
- if rowIndex == idxChecker then
- g.width = wa.x + wa.width - g.x
- else
- g.width = dimToAssign
- end
- end
-
- g.width = max(g.width, 1)
- g.height = max(g.height, 1)
-
- p.geometries[c] = g
- end
-end
-
-local function mouse_resize_handler(c, corner, x, y, orientation)
- local wa = c.screen.workarea
- local mwfact = c.screen.selected_tag.master_width_factor
- local g = c:geometry()
- local offset = 0
- local cursor = "cross"
-
- local corner_coords
-
- if orientation == 'vertical' then
- 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
- offset = g.height
- end
- corner_coords = { x = wa.x + wa.width * (1 - mwfact) / 2, y = g.y + offset }
- else
- 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
- offset = g.width
- end
- corner_coords = { y = wa.y + wa.height * (1 - mwfact) / 2, x = g.x + offset }
- end
-
- mouse.coords(corner_coords)
-
- local prev_coords = {}
-
- mousegrabber.run(function(_mouse)
- if not c.valid then return false end
- for _, v in ipairs(_mouse.buttons) do
- if v then
- prev_coords = { x = _mouse.x, y = _mouse.y }
- local new_mwfact
- if orientation == 'vertical' then
- new_mwfact = 1 - (_mouse.x - wa.x) / wa.width * 2
- else
- new_mwfact = 1 - (_mouse.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
- end, cursor)
-end
-
-function centerwork.arrange(p)
- return arrange(p, centerwork)
-end
-
-function centerwork.horizontal.arrange(p)
- return arrange(p, centerwork.horizontal)
-end
-
-function centerwork.mouse_resize_handler(c, corner, x, y)
- return mouse_resize_handler(c, corner, x, y, 'vertical')
-end
-
-function centerwork.horizontal.mouse_resize_handler(c, corner, x, y)
- return mouse_resize_handler(c, corner, x, y, 'horizontal')
-end
-
-return centerwork
diff --git a/awesome/lain/layout/init.lua b/awesome/lain/layout/init.lua
deleted file mode 100644
index 6478b06..0000000
--- a/awesome/lain/layout/init.lua
+++ /dev/null
@@ -1,19 +0,0 @@
---[[
-
- Lain
- Layouts, widgets and utilities for Awesome WM
-
- Layouts section
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local wrequire = require("lain.helpers").wrequire
-local setmetatable = setmetatable
-
-local layout = { _NAME = "lain.layout" }
-
-return setmetatable(layout, { __index = wrequire })
diff --git a/awesome/lain/layout/termfair.lua b/awesome/lain/layout/termfair.lua
deleted file mode 100644
index e33894e..0000000
--- a/awesome/lain/layout/termfair.lua
+++ /dev/null
@@ -1,237 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2014, projektile
- * (c) 2013, Luca CPZ
- * (c) 2010, Nicolas Estibals
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local math = math
-local screen = screen
-local tonumber = tonumber
-
-local termfair = { name = "termfair" }
-termfair.center = { name = "centerfair" }
-
-local function do_fair(p, orientation)
- local t = p.tag or screen[p.screen].selected_tag
- local wa = p.workarea
- local cls = p.clients
-
- if #cls == 0 then return end
-
- if orientation == "west" then
- -- Layout with fixed number of vertical columns (read from nmaster).
- -- New windows align from left to right. When a row is full, a now
- -- one above it is created. Like this:
-
- -- (1) (2) (3)
- -- +---+---+---+ +---+---+---+ +---+---+---+
- -- | | | | | | | | | | | |
- -- | 1 | | | -> | 2 | 1 | | -> | 3 | 2 | 1 | ->
- -- | | | | | | | | | | | |
- -- +---+---+---+ +---+---+---+ +---+---+---+
-
- -- (4) (5) (6)
- -- +---+---+---+ +---+---+---+ +---+---+---+
- -- | 4 | | | | 5 | 4 | | | 6 | 5 | 4 |
- -- +---+---+---+ -> +---+---+---+ -> +---+---+---+
- -- | 3 | 2 | 1 | | 3 | 2 | 1 | | 3 | 2 | 1 |
- -- +---+---+---+ +---+---+---+ +---+---+---+
-
- -- How many vertical columns? Read from nmaster on the tag.
- local num_x = tonumber(termfair.nmaster) or t.master_count
- local ncol = tonumber(termfair.ncol) or t.column_count
-
- if num_x <= 2 then num_x = 2 end
- if ncol <= 1 then ncol = 1 end
- local width = math.floor(wa.width/num_x)
-
- local num_y = math.max(math.ceil(#cls / num_x), ncol)
- local height = math.floor(wa.height/num_y)
- local cur_num_x = num_x
- local at_x = 0
- local at_y = 0
-
- local remaining_clients = #cls
-
- -- We start the first row. Left-align by limiting the number of
- -- available slots.
- if remaining_clients < num_x then
- cur_num_x = remaining_clients
- end
-
- -- Iterate in reversed order.
- for i = #cls,1,-1 do
- -- Get x and y position.
- local c = cls[i]
- local this_x = cur_num_x - at_x - 1
- local this_y = num_y - at_y - 1
-
- -- Calculate geometry.
- local g = {}
- if this_x == (num_x - 1) then
- g.width = wa.width - (num_x - 1)*width
- else
- g.width = width
- end
-
- if this_y == (num_y - 1) then
- g.height = wa.height - (num_y - 1)*height
- else
- g.height = height
- end
-
- g.x = wa.x + this_x*width
- g.y = wa.y + this_y*height
-
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
-
- p.geometries[c] = g
-
- remaining_clients = remaining_clients - 1
-
- -- Next grid position.
- at_x = at_x + 1
- if at_x == num_x then
- -- Row full, create a new one above it.
- at_x = 0
- at_y = at_y + 1
-
- -- We start a new row. Left-align.
- if remaining_clients < num_x then
- cur_num_x = remaining_clients
- end
- end
- end
- elseif orientation == "center" then
- -- Layout with fixed number of vertical columns (read from nmaster).
- -- Cols are centerded until there is nmaster columns, then windows
- -- are stacked in the slave columns, with at most ncol clients per
- -- column if possible.
-
- -- with nmaster=3 and ncol=1 you'll have
- -- (1) (2) (3)
- -- +---+---+---+ +-+---+---+-+ +---+---+---+
- -- | | | | | | | | | | | | |
- -- | | 1 | | -> | | 1 | 2 | | -> | 1 | 2 | 3 | ->
- -- | | | | | | | | | | | | |
- -- +---+---+---+ +-+---+---+-+ +---+---+---+
-
- -- (4) (5)
- -- +---+---+---+ +---+---+---+
- -- | | | 3 | | | 2 | 4 |
- -- + 1 + 2 +---+ -> + 1 +---+---+
- -- | | | 4 | | | 3 | 5 |
- -- +---+---+---+ +---+---+---+
-
- -- How many vertical columns? Read from nmaster on the tag.
- local num_x = tonumber(termfair.center.nmaster) or t.master_count
- local ncol = tonumber(termfair.center.ncol) or t.column_count
-
- if num_x <= 2 then num_x = 2 end
- if ncol <= 1 then ncol = 1 end
-
- local width = math.floor(wa.width / num_x)
-
- if #cls < num_x then
- -- Less clients than the number of columns, let's center it!
- local offset_x = wa.x + (wa.width - #cls*width) / 2
- for i = 1, #cls do
- local g = { y = wa.y }
- g.width = width
- g.height = wa.height
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
- g.x = offset_x + (i - 1) * width
- p.geometries[cls[i]] = g
- end
- else
- -- More clients than the number of columns, let's arrange it!
- -- Master client deserves a special treatement
- local g = {}
- g.width = wa.width - (num_x - 1)*width
- g.height = wa.height
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
- g.x = wa.x
- g.y = wa.y
- p.geometries[cls[1]] = g
-
- -- Treat the other clients
-
- -- Compute distribution of clients among columns
- local num_y = {}
- local remaining_clients = #cls-1
- local ncol_min = math.ceil(remaining_clients/(num_x-1))
-
- if ncol >= ncol_min then
- for i = (num_x-1), 1, -1 do
- if (remaining_clients-i+1) < ncol then
- num_y[i] = remaining_clients-i + 1
- else
- num_y[i] = ncol
- end
- remaining_clients = remaining_clients - num_y[i]
- end
- else
- local rem = remaining_clients % (num_x-1)
- if rem == 0 then
- for i = 1, num_x-1 do
- num_y[i] = ncol_min
- end
- else
- for i = 1, num_x-1 do
- num_y[i] = ncol_min - 1
- end
- for i = 0, rem-1 do
- num_y[num_x-1-i] = num_y[num_x-1-i] + 1
- end
- end
- end
-
- -- Compute geometry of the other clients
- local nclient = 2 -- we start with the 2nd client
- local wx = g.x + g.width
- for i = 1, (num_x-1) do
- local height = math.floor(wa.height / num_y[i])
- local wy = wa.y
- for j = 0, (num_y[i]-2) do
- local g = {}
- g.x = wx
- g.y = wy
- g.height = height
- g.width = width
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
- p.geometries[cls[nclient]] = g
- nclient = nclient + 1
- wy = wy + height
- end
- local g = {}
- g.x = wx
- g.y = wy
- g.height = wa.height - (num_y[i] - 1)*height
- g.width = width
- if g.width < 1 then g.width = 1 end
- if g.height < 1 then g.height = 1 end
- p.geometries[cls[nclient]] = g
- nclient = nclient + 1
- wx = wx + width
- end
- end
- end
-end
-
-function termfair.center.arrange(p)
- return do_fair(p, "center")
-end
-
-function termfair.arrange(p)
- return do_fair(p, "west")
-end
-
-return termfair
diff --git a/awesome/lain/util/dkjson.lua b/awesome/lain/util/dkjson.lua
deleted file mode 100644
index 89aa2e1..0000000
--- a/awesome/lain/util/dkjson.lua
+++ /dev/null
@@ -1,713 +0,0 @@
--- Module options:
-local always_try_using_lpeg = true
-local register_global_module_table = false
-local global_module_name = 'json'
-
---[==[
-
-David Kolf's JSON module for Lua 5.1/5.2
-
-Version 2.5
-
-
-For the documentation see the corresponding readme.txt or visit
-.
-
-You can contact the author by sending an e-mail to 'david' at the
-domain 'dkolf.de'.
-
-
-Copyright (C) 2010-2013 David Heiko Kolf
-
-Permission is hereby granted, free of charge, to any person obtaining
-a copy of this software and associated documentation files (the
-"Software"), to deal in the Software without restriction, including
-without limitation the rights to use, copy, modify, merge, publish,
-distribute, sublicense, and/or sell copies of the Software, and to
-permit persons to whom the Software is furnished to do so, subject to
-the following conditions:
-
-The above copyright notice and this permission notice shall be
-included in all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
-BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
-ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
-CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
-SOFTWARE.
-
---]==]
-
--- global dependencies:
-local pairs, type, tostring, tonumber, getmetatable, setmetatable, rawset =
- pairs, type, tostring, tonumber, getmetatable, setmetatable, rawset
-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 =
- string.rep, string.gsub, string.sub, string.byte, string.char,
- string.find, string.len, string.format
-local strmatch = string.match
-local concat = table.concat
-
-local json = { version = "dkjson 2.5" }
-
-if register_global_module_table then
- _G[global_module_name] = json
-end
-
-local _ENV = nil -- blocking globals in Lua 5.2
-
-pcall (function()
- -- Enable access to blocked metatables.
- -- Don't worry, this module doesn't change anything in them.
- local debmeta = require "debug".getmetatable
- if debmeta then getmetatable = debmeta end
-end)
-
-json.null = setmetatable ({}, {
- __tojson = function () return "null" end
-})
-
-local function isarray (tbl)
- local max, n, arraylen = 0, 0, 0
- for k,v in pairs (tbl) do
- if k == 'n' and type(v) == 'number' then
- arraylen = v
- if v > max then
- max = v
- end
- else
- if type(k) ~= 'number' or k < 1 or floor(k) ~= k then
- return false
- end
- if k > max then
- max = k
- end
- n = n + 1
- end
- end
- if max > 10 and max > arraylen and max > n * 2 then
- return false -- don't create an array with too many holes
- end
- return true, max
-end
-
-local escapecodes = {
- ["\""] = "\\\"", ["\\"] = "\\\\", ["\b"] = "\\b", ["\f"] = "\\f",
- ["\n"] = "\\n", ["\r"] = "\\r", ["\t"] = "\\t"
-}
-
-local function escapeutf8 (uchar)
- local value = escapecodes[uchar]
- if value then
- return value
- end
- local a, b, c, d = strbyte (uchar, 1, 4)
- a, b, c, d = a or 0, b or 0, c or 0, d or 0
- if a <= 0x7f then
- value = a
- elseif 0xc0 <= a and a <= 0xdf and b >= 0x80 then
- value = (a - 0xc0) * 0x40 + b - 0x80
- elseif 0xe0 <= a and a <= 0xef and b >= 0x80 and c >= 0x80 then
- value = ((a - 0xe0) * 0x40 + b - 0x80) * 0x40 + c - 0x80
- elseif 0xf0 <= a and a <= 0xf7 and b >= 0x80 and c >= 0x80 and d >= 0x80 then
- value = (((a - 0xf0) * 0x40 + b - 0x80) * 0x40 + c - 0x80) * 0x40 + d - 0x80
- else
- return ""
- end
- if value <= 0xffff then
- return strformat ("\\u%.4x", value)
- elseif value <= 0x10ffff then
- -- encode as UTF-16 surrogate pair
- value = value - 0x10000
- local highsur, lowsur = 0xD800 + floor (value/0x400), 0xDC00 + (value % 0x400)
- return strformat ("\\u%.4x\\u%.4x", highsur, lowsur)
- else
- return ""
- end
-end
-
-local function fsub (str, pattern, repl)
- -- gsub always builds a new string in a buffer, even when no match
- -- exists. First using find should be more efficient when most strings
- -- don't contain the pattern.
- if strfind (str, pattern) then
- return gsub (str, pattern, repl)
- else
- return str
- end
-end
-
-local function quotestring (value)
- -- based on the regexp "escapable" in https://github.com/douglascrockford/JSON-js
- value = fsub (value, "[%z\1-\31\"\\\127]", escapeutf8)
- if strfind (value, "[\194\216\220\225\226\239]") then
- value = fsub (value, "\194[\128-\159\173]", escapeutf8)
- value = fsub (value, "\216[\128-\132]", escapeutf8)
- value = fsub (value, "\220\143", escapeutf8)
- value = fsub (value, "\225\158[\180\181]", escapeutf8)
- value = fsub (value, "\226\128[\140-\143\168-\175]", escapeutf8)
- value = fsub (value, "\226\129[\160-\175]", escapeutf8)
- value = fsub (value, "\239\187\191", escapeutf8)
- value = fsub (value, "\239\191[\176-\191]", escapeutf8)
- end
- return "\"" .. value .. "\""
-end
-json.quotestring = quotestring
-
-local function replace(str, o, n)
- local i, j = strfind (str, o, 1, true)
- if i then
- return strsub(str, 1, i-1) .. n .. strsub(str, j+1, -1)
- else
- return str
- end
-end
-
--- locale independent num2str and str2num functions
-local decpoint, numfilter
-
-local function updatedecpoint ()
- decpoint = strmatch(tostring(0.5), "([^05+])")
- -- build a filter that can be used to remove group separators
- numfilter = "[^0-9%-%+eE" .. gsub(decpoint, "[%^%$%(%)%%%.%[%]%*%+%-%?]", "%%%0") .. "]+"
-end
-
-updatedecpoint()
-
-local function num2str (num)
- return replace(fsub(tostring(num), numfilter, ""), decpoint, ".")
-end
-
-local function str2num (str)
- local num = tonumber(replace(str, ".", decpoint))
- if not num then
- updatedecpoint()
- num = tonumber(replace(str, ".", decpoint))
- end
- return num
-end
-
-local function addnewline2 (level, buffer, buflen)
- buffer[buflen+1] = "\n"
- buffer[buflen+2] = strrep (" ", level)
- buflen = buflen + 2
- return buflen
-end
-
-function json.addnewline (state)
- if state.indent then
- state.bufferlen = addnewline2 (state.level or 0,
- state.buffer, state.bufferlen or #(state.buffer))
- end
-end
-
-local encode2 -- forward declaration
-
-local function addpair (key, value, prev, indent, level, buffer, buflen, tables, globalorder, state)
- local kt = type (key)
- if kt ~= 'string' and kt ~= 'number' then
- return nil, "type '" .. kt .. "' is not supported as a key by JSON."
- end
- if prev then
- buflen = buflen + 1
- buffer[buflen] = ","
- end
- if indent then
- buflen = addnewline2 (level, buffer, buflen)
- end
- buffer[buflen+1] = quotestring (key)
- buffer[buflen+2] = ":"
- return encode2 (value, indent, level, buffer, buflen + 2, tables, globalorder, state)
-end
-
-local function appendcustom(res, buffer, state)
- local buflen = state.bufferlen
- if type (res) == 'string' then
- buflen = buflen + 1
- buffer[buflen] = res
- end
- return buflen
-end
-
-local function exception(reason, value, state, buffer, buflen, defaultmessage)
- defaultmessage = defaultmessage or reason
- local handler = state.exception
- if not handler then
- return nil, defaultmessage
- else
- state.bufferlen = buflen
- local ret, msg = handler (reason, value, state, defaultmessage)
- if not ret then return nil, msg or defaultmessage end
- return appendcustom(ret, buffer, state)
- end
-end
-
-function json.encodeexception(reason, value, state, defaultmessage)
- return quotestring("<" .. defaultmessage .. ">")
-end
-
-encode2 = function (value, indent, level, buffer, buflen, tables, globalorder, state)
- local valtype = type (value)
- local valmeta = getmetatable (value)
- valmeta = type (valmeta) == 'table' and valmeta -- only tables
- local valtojson = valmeta and valmeta.__tojson
- if valtojson then
- if tables[value] then
- return exception('reference cycle', value, state, buffer, buflen)
- end
- tables[value] = true
- state.bufferlen = buflen
- local ret, msg = valtojson (value, state)
- if not ret then return exception('custom encoder failed', value, state, buffer, buflen, msg) end
- tables[value] = nil
- buflen = appendcustom(ret, buffer, state)
- elseif value == nil then
- buflen = buflen + 1
- buffer[buflen] = "null"
- elseif valtype == 'number' then
- local s
- if value ~= value or value >= huge or -value >= huge then
- -- This is the behaviour of the original JSON implementation.
- s = "null"
- else
- s = num2str (value)
- end
- buflen = buflen + 1
- buffer[buflen] = s
- elseif valtype == 'boolean' then
- buflen = buflen + 1
- buffer[buflen] = value and "true" or "false"
- elseif valtype == 'string' then
- buflen = buflen + 1
- buffer[buflen] = quotestring (value)
- elseif valtype == 'table' then
- if tables[value] then
- return exception('reference cycle', value, state, buffer, buflen)
- end
- tables[value] = true
- level = level + 1
- local isa, n = isarray (value)
- if n == 0 and valmeta and valmeta.__jsontype == 'object' then
- isa = false
- end
- local msg
- if isa then -- JSON array
- buflen = buflen + 1
- buffer[buflen] = "["
- for i = 1, n do
- buflen, msg = encode2 (value[i], indent, level, buffer, buflen, tables, globalorder, state)
- if not buflen then return nil, msg end
- if i < n then
- buflen = buflen + 1
- buffer[buflen] = ","
- end
- end
- buflen = buflen + 1
- buffer[buflen] = "]"
- else -- JSON object
- local prev = false
- buflen = buflen + 1
- buffer[buflen] = "{"
- local order = valmeta and valmeta.__jsonorder or globalorder
- if order then
- local used = {}
- n = #order
- for i = 1, n do
- local k = order[i]
- local v = value[k]
- if v then
- used[k] = true
- buflen, msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state)
- prev = true -- add a seperator before the next element
- end
- end
- for k,v in pairs (value) do
- if not used[k] then
- buflen, msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state)
- if not buflen then return nil, msg end
- prev = true -- add a seperator before the next element
- end
- end
- else -- unordered
- for k,v in pairs (value) do
- buflen, msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state)
- if not buflen then return nil, msg end
- prev = true -- add a seperator before the next element
- end
- end
- if indent then
- buflen = addnewline2 (level - 1, buffer, buflen)
- end
- buflen = buflen + 1
- buffer[buflen] = "}"
- end
- tables[value] = nil
- else
- return exception ('unsupported type', value, state, buffer, buflen,
- "type '" .. valtype .. "' is not supported by JSON.")
- end
- return buflen
-end
-
-function json.encode (value, state)
- state = state or {}
- local oldbuffer = state.buffer
- local buffer = oldbuffer or {}
- state.buffer = buffer
- updatedecpoint()
- local ret, msg = encode2 (value, state.indent, state.level or 0,
- buffer, state.bufferlen or 0, state.tables or {}, state.keyorder, state)
- if not ret then
- error (msg, 2)
- elseif oldbuffer == buffer then
- state.bufferlen = ret
- return true
- else
- state.bufferlen = nil
- state.buffer = nil
- return concat (buffer)
- end
-end
-
-local function loc (str, where)
- local line, pos, linepos = 1, 1, 0
- while true do
- pos = strfind (str, "\n", pos, true)
- if pos and pos < where then
- line = line + 1
- linepos = pos
- pos = pos + 1
- else
- break
- end
- end
- return "line " .. line .. ", column " .. (where - linepos)
-end
-
-local function unterminated (str, what, where)
- return nil, strlen (str) + 1, "unterminated " .. what .. " at " .. loc (str, where)
-end
-
-local function scanwhite (str, pos)
- while true do
- pos = strfind (str, "%S", pos)
- if not pos then return nil end
- local sub2 = strsub (str, pos, pos + 1)
- if sub2 == "\239\187" and strsub (str, pos + 2, pos + 2) == "\191" then
- -- UTF-8 Byte Order Mark
- pos = pos + 3
- elseif sub2 == "//" then
- pos = strfind (str, "[\n\r]", pos + 2)
- if not pos then return nil end
- elseif sub2 == "/*" then
- pos = strfind (str, "*/", pos + 2)
- if not pos then return nil end
- pos = pos + 2
- else
- return pos
- end
- end
-end
-
-local escapechars = {
- ["\""] = "\"", ["\\"] = "\\", ["/"] = "/", ["b"] = "\b", ["f"] = "\f",
- ["n"] = "\n", ["r"] = "\r", ["t"] = "\t"
-}
-
-local function unichar (value)
- if value < 0 then
- return nil
- elseif value <= 0x007f then
- return strchar (value)
- elseif value <= 0x07ff then
- return strchar (0xc0 + floor(value/0x40),
- 0x80 + (floor(value) % 0x40))
- elseif value <= 0xffff then
- return strchar (0xe0 + floor(value/0x1000),
- 0x80 + (floor(value/0x40) % 0x40),
- 0x80 + (floor(value) % 0x40))
- elseif value <= 0x10ffff then
- return strchar (0xf0 + floor(value/0x40000),
- 0x80 + (floor(value/0x1000) % 0x40),
- 0x80 + (floor(value/0x40) % 0x40),
- 0x80 + (floor(value) % 0x40))
- else
- return nil
- end
-end
-
-local function scanstring (str, pos)
- local lastpos = pos + 1
- local buffer, n = {}, 0
- while true do
- local nextpos = strfind (str, "[\"\\]", lastpos)
- if not nextpos then
- return unterminated (str, "string", pos)
- end
- if nextpos > lastpos then
- n = n + 1
- buffer[n] = strsub (str, lastpos, nextpos - 1)
- end
- if strsub (str, nextpos, nextpos) == "\"" then
- lastpos = nextpos + 1
- break
- else
- local escchar = strsub (str, nextpos + 1, nextpos + 1)
- local value
- if escchar == "u" then
- value = tonumber (strsub (str, nextpos + 2, nextpos + 5), 16)
- if value then
- local value2
- if 0xD800 <= value and value <= 0xDBff then
- -- we have the high surrogate of UTF-16. Check if there is a
- -- low surrogate escaped nearby to combine them.
- if strsub (str, nextpos + 6, nextpos + 7) == "\\u" then
- value2 = tonumber (strsub (str, nextpos + 8, nextpos + 11), 16)
- if value2 and 0xDC00 <= value2 and value2 <= 0xDFFF then
- value = (value - 0xD800) * 0x400 + (value2 - 0xDC00) + 0x10000
- else
- value2 = nil -- in case it was out of range for a low surrogate
- end
- end
- end
- value = value and unichar (value)
- if value then
- if value2 then
- lastpos = nextpos + 12
- else
- lastpos = nextpos + 6
- end
- end
- end
- end
- if not value then
- value = escapechars[escchar] or escchar
- lastpos = nextpos + 2
- end
- n = n + 1
- buffer[n] = value
- end
- end
- if n == 1 then
- return buffer[1], lastpos
- elseif n > 1 then
- return concat (buffer), lastpos
- else
- return "", lastpos
- end
-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
- setmetatable (tbl, objectmeta)
- else
- setmetatable (tbl, arraymeta)
- end
- while true do
- pos = scanwhite (str, pos)
- if not pos then return unterminated (str, what, startpos) end
- local char = strsub (str, pos, pos)
- if char == closechar then
- return tbl, pos + 1
- end
- local val1, err
- val1, pos, err = scanvalue (str, pos, nullval, objectmeta, arraymeta)
- if err then return nil, pos, err end
- pos = scanwhite (str, pos)
- if not pos then return unterminated (str, what, startpos) end
- char = strsub (str, pos, pos)
- if char == ":" then
- if val1 == nil then
- return nil, pos, "cannot use nil as table index (at " .. loc (str, pos) .. ")"
- end
- pos = scanwhite (str, pos + 1)
- if not pos then return unterminated (str, what, startpos) end
- local val2
- val2, pos, err = scanvalue (str, pos, nullval, objectmeta, arraymeta)
- if err then return nil, pos, err end
- tbl[val1] = val2
- pos = scanwhite (str, pos)
- if not pos then return unterminated (str, what, startpos) end
- char = strsub (str, pos, pos)
- else
- n = n + 1
- tbl[n] = val1
- end
- if char == "," then
- pos = pos + 1
- end
- end
-end
-
-scanvalue = function (str, pos, nullval, objectmeta, arraymeta)
- pos = pos or 1
- pos = scanwhite (str, pos)
- if not pos then
- return nil, strlen (str) + 1, "no valid JSON value (reached the end)"
- end
- local char = strsub (str, pos, pos)
- if char == "{" then
- return scantable ('object', "}", str, pos, nullval, objectmeta, arraymeta)
- elseif char == "[" then
- return scantable ('array', "]", str, pos, nullval, objectmeta, arraymeta)
- elseif char == "\"" then
- return scanstring (str, pos)
- else
- local pstart, pend = strfind (str, "^%-?[%d%.]+[eE]?[%+%-]?%d*", pos)
- if pstart then
- local number = str2num (strsub (str, pstart, pend))
- if number then
- return number, pend + 1
- end
- end
- pstart, pend = strfind (str, "^%a%w*", pos)
- if pstart then
- local name = strsub (str, pstart, pend)
- if name == "true" then
- return true, pend + 1
- elseif name == "false" then
- return false, pend + 1
- elseif name == "null" then
- return nullval, pend + 1
- end
- end
- return nil, pos, "no valid JSON value at " .. loc (str, pos)
- end
-end
-
-local function optionalmetatables(...)
- if select("#", ...) > 0 then
- return ...
- else
- return {__jsontype = 'object'}, {__jsontype = 'array'}
- end
-end
-
-function json.decode (str, pos, nullval, ...)
- local objectmeta, arraymeta = optionalmetatables(...)
- return scanvalue (str, pos, nullval, objectmeta, arraymeta)
-end
-
-function json.use_lpeg ()
- local g = require ("lpeg")
-
- if g.version() == "0.11" then
- error "due to a bug in LPeg 0.11, it cannot be used for JSON matching"
- end
-
- local pegmatch = g.match
- local P, S, R = g.P, g.S, g.R
-
- local function ErrorCall (str, pos, msg, state)
- if not state.msg then
- state.msg = msg .. " at " .. loc (str, pos)
- state.pos = pos
- end
- return false
- end
-
- local function Err (msg)
- return g.Cmt (g.Cc (msg) * g.Carg (2), ErrorCall)
- end
-
- local SingleLineComment = P"//" * (1 - S"\n\r")^0
- local MultiLineComment = P"/*" * (1 - P"*/")^0 * P"*/"
- local Space = (S" \n\r\t" + P"\239\187\191" + SingleLineComment + MultiLineComment)^0
-
- 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)
- 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)
- else
- return false
- end
- end
- local function UTF16BMP (hex)
- return unichar (tonumber (hex, 16))
- end
- local U16Sequence = (P"\\u" * g.C (HexDigit * HexDigit * HexDigit * HexDigit))
- local UnicodeEscape = g.Cmt (U16Sequence * U16Sequence, UTF16Surrogate) + U16Sequence/UTF16BMP
- local Char = UnicodeEscape + EscapeSequence + PlainChar
- local String = P"\"" * g.Cs (Char ^ 0) * (P"\"" + Err "unterminated string")
- local Integer = P"-"^(-1) * (P"0" + (R"19" * R"09"^0))
- local Fractal = P"." * R"09"^0
- local Exponent = (S"eE") * (S"+-")^(-1) * R"09"^1
- local Number = (Integer * Fractal^(-1) * Exponent^(-1))/str2num
- local Constant = P"true" * g.Cc (true) + P"false" * g.Cc (false) + P"null" * g.Carg (1)
- local SimpleValue = Number + String + Constant
- local ArrayContent, ObjectContent
-
- -- The functions parsearray and parseobject parse only a single value/pair
- -- at a time and store them directly to avoid hitting the LPeg limits.
- local function parsearray (str, pos, nullval, state)
- local obj, cont
- local npos
- local t, nt = {}, 0
- repeat
- obj, cont, npos = pegmatch (ArrayContent, str, pos, nullval, state)
- if not npos then break end
- pos = npos
- nt = nt + 1
- t[nt] = obj
- until cont == 'last'
- return pos, setmetatable (t, state.arraymeta)
- end
-
- local function parseobject (str, pos, nullval, state)
- local obj, key, cont
- local npos
- local t = {}
- repeat
- key, obj, cont, npos = pegmatch (ObjectContent, str, pos, nullval, state)
- if not npos then break end
- pos = npos
- t[key] = obj
- until cont == 'last'
- return pos, setmetatable (t, state.objectmeta)
- end
-
- local Array = P"[" * g.Cmt (g.Carg(1) * g.Carg(2), parsearray) * Space * (P"]" + Err "']' expected")
- local Object = P"{" * g.Cmt (g.Carg(1) * g.Carg(2), parseobject) * Space * (P"}" + Err "'}' expected")
- local Value = Space * (Array + Object + SimpleValue)
- local ExpectedValue = Value + Space * Err "value expected"
- ArrayContent = Value * Space * (P"," * g.Cc'cont' + g.Cc'last') * g.Cp()
- local Pair = g.Cg (Space * String * Space * (P":" + Err "colon expected") * ExpectedValue)
- ObjectContent = Pair * Space * (P"," * g.Cc'cont' + g.Cc'last') * g.Cp()
- local DecodeValue = ExpectedValue * g.Cp ()
-
- function json.decode (str, pos, nullval, ...)
- local state = {}
- state.objectmeta, state.arraymeta = optionalmetatables(...)
- local obj, retpos = pegmatch (DecodeValue, str, pos, nullval, state)
- if state.msg then
- return nil, state.pos, state.msg
- else
- return obj, retpos
- end
- end
-
- -- use this function only once:
- json.use_lpeg = function () return json end
-
- json.using_lpeg = true
-
- return json -- so you can get the module using json = require "dkjson".use_lpeg()
-end
-
-if always_try_using_lpeg then
- pcall (json.use_lpeg)
-end
-
-return json
diff --git a/awesome/lain/util/init.lua b/awesome/lain/util/init.lua
deleted file mode 100644
index 55bfa26..0000000
--- a/awesome/lain/util/init.lua
+++ /dev/null
@@ -1,168 +0,0 @@
---[[
-
- Lain
- Layouts, widgets and utilities for Awesome WM
-
- Utilities section
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local awful = require("awful")
-local sqrt = math.sqrt
-local pairs = pairs
-local client = client
-local tonumber = tonumber
-local wrequire = require("lain.helpers").wrequire
-local setmetatable = setmetatable
-
--- Lain utilities submodule
--- lain.util
-local util = { _NAME = "lain.util" }
-
--- Like awful.menu.clients, but only show clients of currently selected tags
-function util.menu_clients_current_tags(menu, args)
- -- List of currently selected tags.
- local cls_tags = awful.screen.focused().selected_tags
-
- if cls_tags == nil then return nil end
-
- -- Final list of menu items.
- local cls_t = {}
-
- -- For each selected tag get all clients of that tag and add them to
- -- the menu. A click on a menu item will raise that client.
- for i = 1,#cls_tags do
- local t = cls_tags[i]
- local cls = t:clients()
-
- for k, c in pairs(cls) do
- cls_t[#cls_t + 1] = { awful.util.escape(c.name) or "",
- function ()
- c.minimized = false
- client.focus = c
- c:raise()
- end,
- c.icon }
- end
- end
-
- -- No clients? Then quit.
- if #cls_t <= 0 then return nil end
-
- -- menu may contain some predefined values, otherwise start with a
- -- fresh menu.
- if not menu then menu = {} end
-
- -- Set the list of items and show the menu.
- menu.items = cls_t
- local m = awful.menu(menu)
- m:show(args)
-
- return m
-end
-
--- Magnify a client: set it to "float" and resize it.
-function util.magnify_client(c, width_f, height_f)
- if c and not c.floating then
- util.magnified_client = c
- util.mc(c, width_f, height_f)
- else
- util.magnified_client = nil
- c.floating = false
- end
-end
-
--- https://github.com/lcpz/lain/issues/195
-function util.mc(c, width_f, height_f)
- c = c or util.magnified_client
- if not c then return end
-
- c.floating = true
- local s = awful.screen.focused()
- local mg = s.workarea
- local g = {}
- local mwfact = width_f or s.selected_tag.master_width_factor or 0.5
- g.width = sqrt(mwfact) * mg.width
- g.height = sqrt(height_f or mwfact) * mg.height
- g.x = mg.x + (mg.width - g.width) / 2
- g.y = mg.y + (mg.height - g.height) / 2
-
- if c then c:geometry(g) end -- if c is still a valid object
-end
-
--- Non-empty tag browsing
--- direction in {-1, 1} <-> {previous, next} non-empty tag
-function util.tag_view_nonempty(direction, sc)
- local s = sc or awful.screen.focused()
-
- for i = 1, #s.tags do
- awful.tag.viewidx(direction, s)
- if #s.clients > 0 then
- return
- end
- end
-end
-
--- {{{ Dynamic tagging
-
--- Add a new tag
-function util.add_tag(layout)
- awful.prompt.run {
- prompt = "New tag name: ",
- textbox = awful.screen.focused().mypromptbox.widget,
- exe_callback = function(name)
- if not name or #name == 0 then return end
- awful.tag.add(name, { screen = awful.screen.focused(), layout = layout or awful.layout.suit.tile }):view_only()
- end
- }
-end
-
--- Rename current tag
-function util.rename_tag()
- awful.prompt.run {
- prompt = "Rename tag: ",
- textbox = awful.screen.focused().mypromptbox.widget,
- exe_callback = function(new_name)
- if not new_name or #new_name == 0 then return end
- local t = awful.screen.focused().selected_tag
- if t then
- t.name = new_name
- end
- end
- }
-end
-
--- Move current tag
--- pos in {-1, 1} <-> {previous, next} tag position
-function util.move_tag(pos)
- local tag = awful.screen.focused().selected_tag
- if tonumber(pos) <= -1 then
- awful.tag.move(tag.index - 1, tag)
- else
- awful.tag.move(tag.index + 1, tag)
- end
-end
-
--- Delete current tag
--- Any rule set on the tag shall be broken
-function util.delete_tag()
- local t = awful.screen.focused().selected_tag
- if not t then return end
- t:delete()
-end
-
--- }}}
-
--- On the fly useless gaps change
-function util.useless_gaps_resize(thatmuch, s, t)
- local scr = s or awful.screen.focused()
- local tag = t or scr.selected_tag
- tag.gap = tag.gap + tonumber(thatmuch)
- awful.layout.arrange(scr)
-end
-
-return setmetatable(util, { __index = wrequire })
diff --git a/awesome/lain/util/markup.lua b/awesome/lain/util/markup.lua
deleted file mode 100644
index 63f9486..0000000
--- a/awesome/lain/util/markup.lua
+++ /dev/null
@@ -1,66 +0,0 @@
---[[
-
- Licensed under MIT License
- * (c) 2013, Luca CPZ
- * (c) 2009, Uli Schlachter
- * (c) 2009, Majic
-
---]]
-
-local format = string.format
-local setmetatable = setmetatable
-
--- Lain markup util submodule
--- lain.util.markup
-local markup = { fg = {}, bg = {} }
-
--- Convenience tags
-function markup.bold(text) return format("%s", text) end
-function markup.italic(text) return format("%s", text) end
-function markup.strike(text) return format("%s", text) end
-function markup.underline(text) return format("%s", text) end
-function markup.monospace(text) return format("%s", text) end
-function markup.big(text) return format("%s", text) end
-function markup.small(text) return format("%s", text) end
-
--- Set the font
-function markup.font(font, text)
- return format("%s", font, text)
-end
-
--- Set the foreground
-function markup.fg.color(color, text)
- return format("%s", color, text)
-end
-
--- Set the background
-function markup.bg.color(color, text)
- return format("%s", color, text)
-end
-
--- Set foreground and background
-function markup.color(fg, bg, text)
- return format("%s", fg, bg, text)
-end
-
--- Set font and foreground
-function markup.fontfg(font, fg, text)
- return format("%s", font, fg, text)
-end
-
--- Set font and background
-function markup.fontbg(font, bg, text)
- return format("%s", font, bg, text)
-end
-
--- Set font, foreground and background
-function markup.fontcolor(font, fg, bg, text)
- return 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 })
-setmetatable(markup.bg, { __call = function(_, ...) return markup.bg.color(...) end })
-
--- link markup(...) calls to markup.fg.color(...)
-return setmetatable(markup, { __call = function(_, ...) return markup.fg.color(...) end })
diff --git a/awesome/lain/util/menu_iterator.lua b/awesome/lain/util/menu_iterator.lua
deleted file mode 100644
index 9959b25..0000000
--- a/awesome/lain/util/menu_iterator.lua
+++ /dev/null
@@ -1,145 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2017, Simon Désaulniers
- * (c) 2017, Uli Schlachter
- * (c) 2017, Jeferson Siqueira
-
---]]
-
--- Menu iterator with Naughty notifications
--- lain.util.menu_iterator
-
-local naughty = require("naughty")
-local helpers = require("lain.helpers")
-local util = require("lain.util")
-local atable = require("awful.util").table
-local assert = assert
-local pairs = pairs
-local tconcat = table.concat
-local unpack = unpack or table.unpack -- lua 5.1 retro-compatibility
-
-local state = { cid = nil }
-
-local function naughty_destroy_callback(reason)
- local closed = naughty.notificationClosedReason
- if reason == closed.expired or reason == closed.dismissedByUser then
- local actions = state.index and state.menu[state.index - 1][2]
- if actions then
- for _,action in pairs(actions) do
- -- don't try to call nil callbacks
- if action then action() end
- end
- state.index = nil
- end
- end
-end
-
--- Iterates over a menu.
--- After the timeout, callbacks associated to the last visited choice are
--- executed. Inputs:
--- * menu: a list of {label, {callbacks}} pairs
--- * timeout: time to wait before confirming the menu selection
--- * icon: icon to display in the notification of the chosen label
-local function iterate(menu, timeout, icon)
- local timeout = timeout or 4 -- default timeout for each menu entry
- local icon = icon or nil -- icon to display on the menu
-
- -- Build the list of choices
- if not state.index then
- state.menu = menu
- state.index = 1
- end
-
- -- Select one and display the appropriate notification
- local label
- local next = state.menu[state.index]
- state.index = state.index + 1
-
- if not next then
- label = "Cancel"
- state.index = nil
- else
- label, _ = unpack(next)
- end
-
- state.cid = naughty.notify({
- text = label,
- icon = icon,
- timeout = timeout,
- screen = mouse.screen,
- replaces_id = state.cid,
- destroy = naughty_destroy_callback
- }).id
-end
-
--- Generates a menu compatible with the first argument of `iterate` function and
--- suitable for the following cases:
--- * all possible choices individually (partition of singletons);
--- * all possible subsets of the set of choices (powerset).
---
--- Inputs:
--- * args: an array containing the following members:
--- * choices: Array of choices (string) on which the menu will be
--- generated.
--- * name: Displayed name of the menu (in the form "name: choices").
--- * selected_cb: Callback to execute for each selected choice. Takes
--- the choice as a string argument. Can be `nil` (no action
--- to execute).
--- * rejected_cb: Callback to execute for each rejected choice (possible
--- choices which are not selected). Takes the choice as a
--- string argument. Can be `nil` (no action to execute).
--- * extra_choices: An array of extra { choice_str, callback_fun } pairs to be
--- added to the menu. Each callback_fun can be `nil`.
--- * combination: The combination of choices to generate. Possible values:
--- "powerset" and "single" (default).
--- Output:
--- * m: menu to be iterated over.
-local function menu(args)
- local choices = assert(args.choices or args[1])
- local name = assert(args.name or args[2])
- local selected_cb = args.selected_cb
- local rejected_cb = args.rejected_cb
- local extra_choices = args.extra_choices or {}
-
- local ch_combinations = args.combination == "powerset" and helpers.powerset(choices) or helpers.trivial_partition_set(choices)
-
- for _,c in pairs(extra_choices) do
- ch_combinations = atable.join(ch_combinations, {{c[1]}})
- end
-
- local m = {} -- the menu
-
- for _,c in pairs(ch_combinations) do
- if #c > 0 then
- local cbs = {}
-
- -- selected choices
- for _,ch in pairs(c) do
- if atable.hasitem(choices, ch) then
- cbs[#cbs + 1] = selected_cb and function() selected_cb(ch) end or nil
- end
- end
-
- -- rejected choices
- for _,ch in pairs(choices) do
- if not atable.hasitem(c, ch) and atable.hasitem(choices, ch) then
- cbs[#cbs + 1] = rejected_cb and function() rejected_cb(ch) end or nil
- end
- end
-
- -- add user extra choices (like the choice "None" for example)
- for _,x in pairs(extra_choices) do
- if x[1] == c[1] then
- cbs[#cbs + 1] = x[2]
- end
- end
-
- m[#m + 1] = { name .. ": " .. tconcat(c, " + "), cbs }
- end
- end
-
- return m
-end
-
-return { iterate = iterate, menu = menu }
diff --git a/awesome/lain/util/quake.lua b/awesome/lain/util/quake.lua
deleted file mode 100644
index 01891b0..0000000
--- a/awesome/lain/util/quake.lua
+++ /dev/null
@@ -1,168 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2016, Luca CPZ
- * (c) 2015, unknown
-
---]]
-
-local awful = require("awful")
-local capi = { client = client }
-local math = math
-local string = string
-local pairs = pairs
-local screen = screen
-local setmetatable = setmetatable
-
--- Quake-like Dropdown application spawn
-local quake = {}
-
--- If you have a rule like "awful.client.setslave" for your terminals,
--- ensure you use an exception for QuakeDD. Otherwise, you may
--- run into problems with focus.
-
-function quake:display()
- if self.followtag then self.screen = awful.screen.focused() end
-
- -- First, we locate the client
- local client = nil
- local i = 0
- for c in awful.client.iterate(function (c)
- -- c.name may be changed!
- return c.instance == self.name
- end)
- do
- i = i + 1
- if i == 1 then
- client = c
- else
- -- Additional matching clients, let's remove the sticky bit
- -- which may persist between awesome restarts. We don't close
- -- them as they may be valuable. They will just turn into
- -- normal clients.
- c.sticky = false
- c.ontop = false
- c.above = false
- end
- end
-
- if not client and not self.visible then return end
-
- if not client then
- -- The client does not exist, we spawn it
- cmd = string.format("%s %s %s", self.app,
- string.format(self.argname, self.name), self.extra)
- awful.spawn(cmd, { tag = self.screen.selected_tag })
- return
- end
-
- -- Set geometry
- client.floating = true
- client.border_width = self.border
- client.size_hints_honor = false
- client:geometry(self.geometry[self.screen.index] or self:compute_size())
-
- -- Set not sticky and on top
- client.sticky = false
- client.ontop = true
- client.above = true
- client.skip_taskbar = true
-
- -- Additional user settings
- if self.settings then self.settings(client) end
-
- -- Toggle display
- if self.visible then
- client.hidden = false
- client:raise()
- self.last_tag = self.screen.selected_tag
- client:tags({self.screen.selected_tag})
- capi.client.focus = client
- else
- client.hidden = true
- local ctags = client:tags()
- for i, t in pairs(ctags) do
- ctags[i] = nil
- end
- client:tags(ctags)
- end
-
- return client
-end
-
-function quake:compute_size()
- -- skip if we already have a geometry for this screen
- if not self.geometry[self.screen.index] then
- local geom
- if not self.overlap then
- geom = screen[self.screen.index].workarea
- else
- geom = screen[self.screen.index].geometry
- end
- local width, height = self.width, self.height
- if width <= 1 then width = math.floor(geom.width * width) - 2 * self.border end
- if height <= 1 then height = math.floor(geom.height * height) end
- local x, y
- if self.horiz == "left" then x = geom.x
- elseif self.horiz == "right" then x = geom.width + geom.x - width
- else x = geom.x + (geom.width - width)/2 end
- if self.vert == "top" then y = geom.y
- elseif self.vert == "bottom" then y = geom.height + geom.y - height
- else y = geom.y + (geom.height - height)/2 end
- self.geometry[self.screen.index] = { x = x, y = y, width = width, height = height }
- end
- return self.geometry[self.screen.index]
-end
-
-function quake:new(config)
- local conf = config or {}
-
- conf.app = conf.app or "xterm" -- application to spawn
- conf.name = conf.name or "QuakeDD" -- window name
- conf.argname = conf.argname or "-name %s" -- how to specify window name
- conf.extra = conf.extra or "" -- extra arguments
- conf.border = conf.border or 1 -- client border width
- conf.visible = conf.visible or false -- initially not visible
- conf.followtag = conf.followtag or false -- spawn on currently focused screen
- conf.overlap = conf.overlap or false -- overlap wibox
- conf.screen = conf.screen or awful.screen.focused()
- conf.settings = conf.settings
-
- -- If width or height <= 1 this is a proportion of the workspace
- conf.height = conf.height or 0.25 -- height
- conf.width = conf.width or 1 -- width
- conf.vert = conf.vert or "top" -- top, bottom or center
- conf.horiz = conf.horiz or "left" -- left, right or center
- conf.geometry = {} -- internal use
-
- local dropdown = setmetatable(conf, { __index = quake })
-
- capi.client.connect_signal("manage", function(c)
- if c.instance == dropdown.name and c.screen == dropdown.screen then
- dropdown:display()
- end
- end)
- capi.client.connect_signal("unmanage", function(c)
- if c.instance == dropdown.name and c.screen == dropdown.screen then
- dropdown.visible = false
- end
- end)
-
- return dropdown
-end
-
-function quake:toggle()
- if self.followtag then self.screen = awful.screen.focused() end
- local current_tag = self.screen.selected_tag
- if current_tag and self.last_tag ~= current_tag and self.visible then
- local c=self:display()
- if c then
- c:move_to_tag(current_tag)
- end
- else
- self.visible = not self.visible
- self:display()
- end
-end
-
-return setmetatable(quake, { __call = function(_, ...) return quake:new(...) end })
diff --git a/awesome/lain/util/separators.lua b/awesome/lain/util/separators.lua
deleted file mode 100644
index 465132d..0000000
--- a/awesome/lain/util/separators.lua
+++ /dev/null
@@ -1,117 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2015, Luca CPZ
- * (c) 2015, plotnikovanton
-
---]]
-
-local wibox = require("wibox")
-local gears = require("gears")
-
--- Lain Cairo separators util submodule
--- lain.util.separators
-local separators = { height = 0, width = 9 }
-
--- [[ Arrow
-
--- Right
-function separators.arrow_right(col1, col2)
- local widget = wibox.widget.base.make_widget()
- widget.col1 = col1
- widget.col2 = col2
-
- widget.fit = function(m, w, h)
- return separators.width, separators.height
- end
-
- widget.update = function(col1, col2)
- widget.col1 = col1
- widget.col2 = col2
- widget:emit_signal("widget::redraw_needed")
- end
-
- widget.draw = function(mycross, wibox, cr, width, height)
- if widget.col2 ~= "alpha" then
- cr:set_source_rgb(gears.color.parse_color(widget.col2))
- cr:new_path()
- cr:move_to(0, 0)
- cr:line_to(width, height/2)
- cr:line_to(width, 0)
- cr:close_path()
- cr:fill()
-
- cr:new_path()
- cr:move_to(0, height)
- cr:line_to(width, height/2)
- cr:line_to(width, height)
- cr:close_path()
- cr:fill()
- end
-
- if widget.col1 ~= "alpha" then
- cr:set_source_rgb(gears.color.parse_color(widget.col1))
- cr:new_path()
- cr:move_to(0, 0)
- cr:line_to(width, height/2)
- cr:line_to(0, height)
- cr:close_path()
- cr:fill()
- end
- end
-
- return widget
-end
-
--- Left
-function separators.arrow_left(col1, col2)
- local widget = wibox.widget.base.make_widget()
- widget.col1 = col1
- widget.col2 = col2
-
- widget.fit = function(m, w, h)
- return separators.width, separators.height
- end
-
- widget.update = function(col1, col2)
- widget.col1 = col1
- widget.col2 = col2
- widget:emit_signal("widget::redraw_needed")
- end
-
- widget.draw = function(mycross, wibox, cr, width, height)
- if widget.col1 ~= "alpha" then
- cr:set_source_rgb(gears.color.parse_color(widget.col1))
- cr:new_path()
- cr:move_to(width, 0)
- cr:line_to(0, height/2)
- cr:line_to(0, 0)
- cr:close_path()
- cr:fill()
-
- cr:new_path()
- cr:move_to(width, height)
- cr:line_to(0, height/2)
- cr:line_to(0, height)
- cr:close_path()
- cr:fill()
- end
-
- if widget.col2 ~= "alpha" then
- cr:new_path()
- cr:move_to(width, 0)
- cr:line_to(0, height/2)
- cr:line_to(width, height)
- cr:close_path()
-
- cr:set_source_rgb(gears.color.parse_color(widget.col2))
- cr:fill()
- end
- end
-
- return widget
-end
-
--- ]]
-
-return separators
diff --git a/awesome/lain/widget/alsa.lua b/awesome/lain/widget/alsa.lua
deleted file mode 100644
index 3b6c6d6..0000000
--- a/awesome/lain/widget/alsa.lua
+++ /dev/null
@@ -1,53 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010, Adrian C.
-
---]]
-
-local helpers = require("lain.helpers")
-local shell = require("awful.util").shell
-local wibox = require("wibox")
-local string = string
-
--- ALSA volume
--- lain.widget.alsa
-
-local function factory(args)
- local alsa = { widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 5
- local settings = args.settings or function() end
-
- alsa.cmd = args.cmd or "amixer"
- alsa.channel = args.channel or "Master"
- alsa.togglechannel = args.togglechannel
-
- local format_cmd = string.format("%s get %s", alsa.cmd, alsa.channel)
-
- if alsa.togglechannel then
- format_cmd = { shell, "-c", string.format("%s get %s; %s get %s",
- alsa.cmd, alsa.channel, alsa.cmd, alsa.togglechannel) }
- end
-
- alsa.last = {}
-
- function alsa.update()
- helpers.async(format_cmd, function(mixer)
- local l,s = string.match(mixer, "([%d]+)%%.*%[([%l]*)")
- if alsa.last.level ~= l or alsa.last.status ~= s then
- volume_now = { level = l, status = s }
- widget = alsa.widget
- settings()
- alsa.last = volume_now
- end
- end)
- end
-
- helpers.newtimer(string.format("alsa-%s-%s", alsa.cmd, alsa.channel), timeout, alsa.update)
-
- return alsa
-end
-
-return factory
diff --git a/awesome/lain/widget/alsabar.lua b/awesome/lain/widget/alsabar.lua
deleted file mode 100644
index 9b9f4b9..0000000
--- a/awesome/lain/widget/alsabar.lua
+++ /dev/null
@@ -1,153 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2013, Rman
-
---]]
-
-local helpers = require("lain.helpers")
-local awful = require("awful")
-local naughty = require("naughty")
-local wibox = require("wibox")
-local math = math
-local string = string
-local type = type
-local tonumber = tonumber
-
--- ALSA volume bar
--- lain.widget.alsabar
-
-local function factory(args)
- local alsabar = {
- colors = {
- background = "#000000",
- mute = "#EB8F8F",
- unmute = "#A4CE8A"
- },
-
- _current_level = 0,
- _playback = "off"
- }
-
- local args = args or {}
- local timeout = args.timeout or 5
- local settings = args.settings or function() end
- local width = args.width or 63
- local height = args.height or 1
- local margins = args.margins or 1
- local paddings = args.paddings or 1
- local ticks = args.ticks or false
- local ticks_size = args.ticks_size or 7
-
- alsabar.cmd = args.cmd or "amixer"
- alsabar.channel = args.channel or "Master"
- alsabar.togglechannel = args.togglechannel
- alsabar.colors = args.colors or alsabar.colors
- alsabar.followtag = args.followtag or false
- alsabar.notification_preset = args.notification_preset
-
- if not alsabar.notification_preset then
- alsabar.notification_preset = {}
- alsabar.notification_preset.font = "Monospace 10"
- end
-
- local format_cmd = string.format("%s get %s", alsabar.cmd, alsabar.channel)
-
- if alsabar.togglechannel then
- format_cmd = { awful.util.shell, "-c", string.format("%s get %s; %s get %s",
- alsabar.cmd, alsabar.channel, alsabar.cmd, alsabar.togglechannel) }
- end
-
- alsabar.bar = wibox.widget {
- color = alsabar.colors.unmute,
- background_color = alsabar.colors.background,
- forced_height = height,
- forced_width = width,
- margins = margins,
- paddings = margins,
- ticks = ticks,
- ticks_size = ticks_size,
- widget = wibox.widget.progressbar
- }
-
- alsabar.tooltip = awful.tooltip({ objects = { alsabar.bar } })
-
- function alsabar.update(callback)
- helpers.async(format_cmd, function(mixer)
- local vol, playback = string.match(mixer, "([%d]+)%%.*%[([%l]*)")
-
- if not vol or not playback then return end
-
- if vol ~= alsabar._current_level or playback ~= alsabar._playback then
- alsabar._current_level = tonumber(vol)
- alsabar.bar:set_value(alsabar._current_level / 100)
- if alsabar._current_level == 0 or playback == "off" then
- alsabar._playback = playback
- alsabar.tooltip:set_text("[Muted]")
- alsabar.bar.color = alsabar.colors.mute
- else
- alsabar._playback = "on"
- alsabar.tooltip:set_text(string.format("%s: %s", alsabar.channel, vol))
- alsabar.bar.color = alsabar.colors.unmute
- end
-
- volume_now = {
- level = alsabar._current_level,
- status = alsabar._playback
- }
-
- settings()
-
- if type(callback) == "function" then callback() end
- end
- end)
- end
-
- function alsabar.notify()
- alsabar.update(function()
- local preset = alsabar.notification_preset
-
- preset.title = string.format("%s - %s%%", alsabar.channel, alsabar._current_level)
-
- if alsabar._playback == "off" then
- preset.title = preset.title .. " Muted"
- end
-
- -- tot is the maximum number of ticks to display in the notification
- -- fallback: default horizontal wibox height
- local wib, tot = awful.screen.focused().mywibox, 20
-
- -- if we can grab mywibox, tot is defined as its height if
- -- horizontal, or width otherwise
- if wib then
- if wib.position == "left" or wib.position == "right" then
- tot = wib.width
- else
- tot = wib.height
- end
- end
-
- int = math.modf((alsabar._current_level / 100) * tot)
- preset.text = string.format("[%s%s]", string.rep("|", int),
- string.rep(" ", tot - int))
-
- if alsabar.followtag then preset.screen = awful.screen.focused() end
-
- if not alsabar.notification then
- alsabar.notification = naughty.notify {
- preset = preset,
- destroy = function() alsabar.notification = nil end
- }
- else
- naughty.replace_text(alsabar.notification, preset.title, preset.text)
- end
- end)
- end
-
- helpers.newtimer(string.format("alsabar-%s-%s", alsabar.cmd, alsabar.channel), timeout, alsabar.update)
-
- return alsabar
-end
-
-return factory
diff --git a/awesome/lain/widget/bat.lua b/awesome/lain/widget/bat.lua
deleted file mode 100644
index c5e1803..0000000
--- a/awesome/lain/widget/bat.lua
+++ /dev/null
@@ -1,220 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local helpers = require("lain.helpers")
-local fs = require("gears.filesystem")
-local naughty = require("naughty")
-local wibox = require("wibox")
-local math = math
-local string = string
-local ipairs = ipairs
-local tonumber = tonumber
-
--- Battery infos
--- lain.widget.bat
-
-local function factory(args)
- local pspath = args.pspath or "/sys/class/power_supply/"
-
- if not fs.is_dir(pspath) then
- naughty.notify { text = "lain.widget.bat: invalid power supply path", timeout = 0 }
- return
- end
-
- local bat = { widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 30
- local notify = args.notify or "on"
- local full_notify = args.full_notify or notify
- local n_perc = args.n_perc or { 5, 15 }
- local batteries = args.batteries or (args.battery and {args.battery}) or {}
- local ac = args.ac or "AC0"
- local settings = args.settings or function() end
-
- function bat.get_batteries()
- helpers.line_callback("ls -1 " .. pspath, function(line)
- local bstr = string.match(line, "BAT%w+")
- if bstr then
- batteries[#batteries + 1] = bstr
- else
- ac = string.match(line, "A%w+") or "AC0"
- end
- end)
- end
-
- if #batteries == 0 then bat.get_batteries() end
-
- bat_notification_critical_preset = {
- title = "Battery exhausted",
- text = "Shutdown imminent",
- timeout = 15,
- fg = "#000000",
- bg = "#FFFFFF"
- }
-
- bat_notification_low_preset = {
- title = "Battery low",
- text = "Plug the cable!",
- timeout = 15,
- fg = "#202020",
- bg = "#CDCDCD"
- }
-
- bat_notification_charged_preset = {
- title = "Battery full",
- text = "You can unplug the cable",
- timeout = 15,
- fg = "#202020",
- bg = "#CDCDCD"
- }
-
- bat_now = {
- status = "N/A",
- ac_status = "N/A",
- perc = "N/A",
- time = "N/A",
- watt = "N/A"
- }
-
- bat_now.n_status = {}
- bat_now.n_perc = {}
- for i = 1, #batteries do
- bat_now.n_status[i] = "N/A"
- bat_now.n_perc[i] = 0
- end
-
- -- used to notify full charge only once before discharging
- local fullnotification = false
-
- function bat.update()
- local sum_rate_current = 0
- local sum_rate_voltage = 0
- local sum_rate_power = 0
- local sum_rate_energy = 0
- local sum_energy_now = 0
- local sum_energy_full = 0
-
- for i, battery in ipairs(batteries) do
- local bstr = pspath .. battery
- local present = helpers.first_line(bstr .. "/present")
-
- if tonumber(present) == 1 then
- -- current_now(I)[uA], voltage_now(U)[uV], power_now(P)[uW]
- local rate_current = tonumber(helpers.first_line(bstr .. "/current_now"))
- local rate_voltage = tonumber(helpers.first_line(bstr .. "/voltage_now"))
- local rate_power = tonumber(helpers.first_line(bstr .. "/power_now"))
-
- -- energy_now(P)[uWh], charge_now(I)[uAh]
- local energy_now = tonumber(helpers.first_line(bstr .. "/energy_now") or
- helpers.first_line(bstr .. "/charge_now"))
-
- -- energy_full(P)[uWh], charge_full(I)[uAh]
- local energy_full = tonumber(helpers.first_line(bstr .. "/energy_full") or
- helpers.first_line(bstr .. "/charge_full"))
-
- local energy_percentage = tonumber(helpers.first_line(bstr .. "/capacity")) or
- math.floor((energy_now / energy_full) * 100)
-
- bat_now.n_status[i] = helpers.first_line(bstr .. "/status") or "N/A"
- bat_now.n_perc[i] = energy_percentage or bat_now.n_perc[i]
-
- sum_rate_current = sum_rate_current + (rate_current or 0)
- sum_rate_voltage = sum_rate_voltage + (rate_voltage or 0)
- sum_rate_power = sum_rate_power + (rate_power or 0)
- sum_rate_energy = sum_rate_energy + (rate_power or (((rate_voltage or 0) * (rate_current or 0)) / 1e6))
- sum_energy_now = sum_energy_now + (energy_now or 0)
- sum_energy_full = sum_energy_full + (energy_full or 0)
- end
- end
-
- -- When one of the battery is charging, others' status are either
- -- "Full", "Unknown" or "Charging". When the laptop is not plugged in,
- -- one or more of the batteries may be full, but only one battery
- -- discharging suffices to set global status to "Discharging".
- bat_now.status = bat_now.n_status[1]
- for _,status in ipairs(bat_now.n_status) do
- if status == "Discharging" or status == "Charging" then
- bat_now.status = status
- end
- end
- bat_now.ac_status = tonumber(helpers.first_line(string.format("%s%s/online", pspath, ac))) or "N/A"
-
- if bat_now.status ~= "N/A" then
- if bat_now.status ~= "Full" and sum_rate_power == 0 and bat_now.ac_status == 1 then
- bat_now.perc = math.floor(math.min(100, (sum_energy_now / sum_energy_full) * 100))
- bat_now.time = "00:00"
- bat_now.watt = 0
-
- -- update {perc,time,watt} iff battery not full and rate > 0
- elseif bat_now.status ~= "Full" then
- local rate_time = 0
- -- Calculate time and watt if rates are greater then 0
- if (sum_rate_power > 0 or sum_rate_current > 0) then
- local div = (sum_rate_power > 0 and sum_rate_power) or sum_rate_current
-
- if bat_now.status == "Charging" then
- rate_time = (sum_energy_full - sum_energy_now) / div
- else -- Discharging
- rate_time = sum_energy_now / div
- end
-
- if 0 < rate_time and rate_time < 0.01 then -- check for magnitude discrepancies (#199)
- rate_time_magnitude = math.abs(math.floor(math.log10(rate_time)))
- rate_time = rate_time * 10^(rate_time_magnitude - 2)
- end
- end
-
- local hours = math.floor(rate_time)
- local minutes = math.floor((rate_time - hours) * 60)
- bat_now.perc = math.floor(math.min(100, (sum_energy_now / sum_energy_full) * 100))
- bat_now.time = string.format("%02d:%02d", hours, minutes)
- bat_now.watt = tonumber(string.format("%.2f", sum_rate_energy / 1e6))
- elseif bat_now.status == "Full" then
- bat_now.perc = 100
- bat_now.time = "00:00"
- bat_now.watt = 0
- end
- end
-
- widget = bat.widget
- settings()
-
- -- notifications for critical, low, and full levels
- --[[
- if notify == "on" then
- if bat_now.status == "Discharging" then
- if tonumber(bat_now.perc) <= n_perc[1] then
- bat.id = naughty.notify({
- preset = bat_notification_critical_preset,
- replaces_id = bat.id
- }).id
- elseif tonumber(bat_now.perc) <= n_perc[2] then
- bat.id = naughty.notify({
- preset = bat_notification_low_preset,
- replaces_id = bat.id
- }).id
- end
- fullnotification = false
- elseif bat_now.status == "Full" and full_notify == "on" and not fullnotification then
- bat.id = naughty.notify({
- preset = bat_notification_charged_preset,
- replaces_id = bat.id
- }).id
- fullnotification = true
- end
- end
- ]]
- end
-
-
- helpers.newtimer("batteries", timeout, bat.update)
-
- return bat
-end
-
-return factory
diff --git a/awesome/lain/widget/cal.lua b/awesome/lain/widget/cal.lua
deleted file mode 100644
index 928a7bd..0000000
--- a/awesome/lain/widget/cal.lua
+++ /dev/null
@@ -1,175 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2018, Luca CPZ
-
---]]
-
-local helpers = require("lain.helpers")
-local markup = require("lain.util.markup")
-local awful = require("awful")
-local naughty = require("naughty")
-local floor = math.floor
-local os = os
-local pairs = pairs
-local string = string
-local tconcat = table.concat
-local type = type
-local tonumber = tonumber
-local tostring = tostring
-
--- Calendar notification
--- lain.widget.cal
-
-local function factory(args)
- args = args or {}
- local cal = {
- attach_to = args.attach_to or {},
- week_start = args.week_start or 2,
- three = args.three or false,
- followtag = args.followtag or false,
- week_number = args.week_number or "none",
- week_number_format = args.week_number_format or args.week_number == "left" and "%3d | " or "| %-3d",
- icons = args.icons or helpers.icons_dir .. "cal/white/",
- notification_preset = args.notification_preset or {
- font = "Monospace 10", fg = "#FFFFFF", bg = "#000000"
- }
- }
-
- function cal.get_week_number(m, st_day, x)
- return string.format(cal.week_number_format, os.date("%V", m) + (x ~= 0 and floor((x + st_day) / 7) - 1 or 0))
- end
-
- function cal.sum_week_days(x, y)
- return (x + y) % 7
- end
-
- function cal.build(month, year)
- local current_month, current_year = tonumber(os.date("%m")), tonumber(os.date("%Y"))
- local is_current_month = (not month or not year) or (month == current_month and year == current_year)
- local today = is_current_month and tonumber(os.date("%d")) -- otherwise nil and not highlighted
- local t = os.time { year = year or current_year, month = month and month+1 or current_month+1, day = 0 }
- local d = os.date("*t", t)
- local mth_days, st_day, this_month = d.day, (d.wday-d.day-cal.week_start+1)%7, os.date("%B %Y", t)
- local notifytable = { [1] = string.format("%s%s\n", string.rep(" ", floor((28 - this_month:len())/2)), markup.bold(this_month)) }
- for x = 0,6 do notifytable[#notifytable+1] = os.date("%a", os.time { year=2006, month=1, day=x+cal.week_start }):sub(1, 3) .. " " end
- notifytable[#notifytable] = string.format("%s\n%s", notifytable[#notifytable]:sub(1, -2), string.rep(" ", st_day*4))
- local strx
- for x = 1,mth_days do
- strx = x
- if x == today then
- if x < 10 then x = " " .. x end
- strx = markup.bold(markup.color(cal.notification_preset.bg, cal.notification_preset.fg, x) .. " ")
- end
- strx = string.format("%s%s", string.rep(" ", 3 - tostring(x):len()), strx)
- notifytable[#notifytable+1] = string.format("%-4s%s", strx, (x+st_day)%7==0 and x ~= mth_days and "\n" or "")
- end
- if string.len(cal.icons or "") > 0 and today then cal.icon = cal.icons .. today .. ".png" end
- cal.month, cal.year = d.month, d.year
-
- if cal.week_number ~= "none" then
- local m = os.time { year = year or current_year, month = month and month or current_month, day = 0 }
- local head_prepend = string.rep(" ", tostring(string.format(cal.week_number_format, 0)):len())
-
- if cal.week_number == "left" then
- notifytable[1] = head_prepend .. notifytable[1] -- month-year row
- notifytable[2] = head_prepend .. notifytable[2] -- weekdays row
- notifytable[8] = notifytable[8]:gsub("\n", "\n" .. cal.get_week_number(m, st_day, 0)) -- first week of the month
-
- for x = 10,#notifytable do
- if cal.sum_week_days(st_day, x) == 2 then
- notifytable[x] = cal.get_week_number(m, st_day, x) .. notifytable[x]
- end
- end
- elseif cal.week_number == "right" then
- notifytable[8] = notifytable[8]:gsub("\n", head_prepend .. "\n") -- weekdays row
- for x = 9,#notifytable do
- if cal.sum_week_days(st_day, x) == 1 then
- notifytable[x] = notifytable[x]:gsub("\n", cal.get_week_number(m, st_day, x - 7) .. "\n")
- end
- end
- -- last week of the month
- local end_days = cal.sum_week_days(st_day, mth_days)
- if end_days ~= 0 then end_days = 7 - end_days end
- notifytable[#notifytable] = notifytable[#notifytable] .. string.rep(" ", 4 * end_days) .. cal.get_week_number(m, st_day, mth_days + end_days)
- end
- end
-
- return notifytable
- end
-
- function cal.getdate(month, year, offset)
- if not month or not year then
- month = tonumber(os.date("%m"))
- year = tonumber(os.date("%Y"))
- end
-
- month = month + offset
-
- while month > 12 do
- month = month - 12
- year = year + 1
- end
-
- while month < 1 do
- month = month + 12
- year = year - 1
- end
-
- return month, year
- end
-
- function cal.hide()
- if not cal.notification then return end
- naughty.destroy(cal.notification)
- cal.notification = nil
- end
-
- function cal.show(seconds, month, year, scr)
- cal.notification_preset.text = tconcat(cal.build(month, year))
-
- if cal.three then
- local current_month, current_year = cal.month, cal.year
- local prev_month, prev_year = cal.getdate(cal.month, cal.year, -1)
- local next_month, next_year = cal.getdate(cal.month, cal.year, 1)
- cal.notification_preset.text = string.format("%s\n\n%s\n\n%s",
- tconcat(cal.build(prev_month, prev_year)), cal.notification_preset.text,
- tconcat(cal.build(next_month, next_year)))
- cal.month, cal.year = current_month, current_year
- end
-
- cal.hide()
- cal.notification = naughty.notify {
- preset = cal.notification_preset,
- screen = cal.followtag and awful.screen.focused() or scr or 1,
- icon = cal.icon,
- timeout = type(seconds) == "number" and seconds or cal.notification_preset.timeout or 5
- }
- end
-
- function cal.hover_on() cal.show(0) end
- function cal.move(offset)
- local offset = offset or 0
- cal.month, cal.year = cal.getdate(cal.month, cal.year, offset)
- cal.show(0, cal.month, cal.year)
- end
- function cal.prev() cal.move(-1) end
- function cal.next() cal.move( 1) end
-
- function cal.attach(widget)
- widget:connect_signal("mouse::enter", cal.hover_on)
- widget:connect_signal("mouse::leave", cal.hide)
- widget:buttons(awful.util.table.join(
- awful.button({}, 1, cal.prev),
- awful.button({}, 3, cal.next),
- awful.button({}, 2, cal.hover_on),
- awful.button({}, 5, cal.prev),
- awful.button({}, 4, cal.next)))
- end
-
- for _, widget in pairs(cal.attach_to) do cal.attach(widget) end
-
- return cal
-end
-
-return factory
diff --git a/awesome/lain/widget/contrib/init.lua b/awesome/lain/widget/contrib/init.lua
deleted file mode 100644
index 9e863a5..0000000
--- a/awesome/lain/widget/contrib/init.lua
+++ /dev/null
@@ -1,18 +0,0 @@
---[[
-
- Lain
- Layouts, widgets and utilities for Awesome WM
-
- Users contributed widgets section
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
-
---]]
-
-local wrequire = require("lain.helpers").wrequire
-local setmetatable = setmetatable
-
-local widget = { _NAME = "lain.widget.contrib" }
-
-return setmetatable(widget, { __index = wrequire })
diff --git a/awesome/lain/widget/contrib/moc.lua b/awesome/lain/widget/contrib/moc.lua
deleted file mode 100644
index f429c77..0000000
--- a/awesome/lain/widget/contrib/moc.lua
+++ /dev/null
@@ -1,96 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2014, anticlockwise
-
---]]
-
-local helpers = require("lain.helpers")
-local shell = require("awful.util").shell
-local focused = require("awful.screen").focused
-local escape_f = require("awful.util").escape
-local naughty = require("naughty")
-local wibox = require("wibox")
-local os = os
-local string = string
-
--- MOC audio player
--- lain.widget.contrib.moc
-
-local function factory(args)
- local moc = { widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 2
- local music_dir = args.music_dir or os.getenv("HOME") .. "/Music"
- local cover_pattern = args.cover_pattern or "*\\.(jpg|jpeg|png|gif)$"
- local cover_size = args.cover_size or 100
- local default_art = args.default_art or ""
- local followtag = args.followtag or false
- local settings = args.settings or function() end
-
- moc_notification_preset = { title = "Now playing", timeout = 6 }
-
- helpers.set_map("current moc track", nil)
-
- function moc.update()
- helpers.async("mocp -i", function(f)
- moc_now = {
- state = "N/A",
- file = "N/A",
- artist = "N/A",
- title = "N/A",
- album = "N/A",
- elapsed = "N/A",
- total = "N/A"
- }
-
- for line in string.gmatch(f, "[^\n]+") do
- for k, v in string.gmatch(line, "([%w]+):[%s](.*)$") do
- if k == "State" then moc_now.state = v
- elseif k == "File" then moc_now.file = v
- elseif k == "Artist" then moc_now.artist = escape_f(v)
- elseif k == "SongTitle" then moc_now.title = escape_f(v)
- elseif k == "Album" then moc_now.album = escape_f(v)
- elseif k == "CurrentTime" then moc_now.elapsed = escape_f(v)
- elseif k == "TotalTime" then moc_now.total = escape_f(v)
- end
- end
- end
-
- moc_notification_preset.text = string.format("%s (%s) - %s\n%s", moc_now.artist,
- moc_now.album, moc_now.total, moc_now.title)
- widget = moc.widget
- settings()
-
- if moc_now.state == "PLAY" then
- if moc_now.title ~= helpers.get_map("current moc track") then
- helpers.set_map("current moc track", moc_now.title)
-
- if followtag then moc_notification_preset.screen = focused() end
-
- local common = {
- preset = moc_notification_preset,
- icon = default_art,
- icon_size = cover_size,
- replaces_id = moc.id,
- }
-
- local path = string.format("%s/%s", music_dir, string.match(moc_now.file, ".*/"))
- local cover = string.format("find '%s' -maxdepth 1 -type f | egrep -i -m1 '%s'", path, cover_pattern)
- helpers.async({ shell, "-c", cover }, function(current_icon)
- common.icon = current_icon:gsub("\n", "")
- moc.id = naughty.notify(common).id
- end)
- end
- elseif moc_now.state ~= "PAUSE" then
- helpers.set_map("current moc track", nil)
- end
- end)
- end
-
- moc.timer = helpers.newtimer("moc", timeout, moc.update, true, true)
-
- return moc
-end
-
-return factory
diff --git a/awesome/lain/widget/contrib/redshift.lua b/awesome/lain/widget/contrib/redshift.lua
deleted file mode 100644
index d0e5eed..0000000
--- a/awesome/lain/widget/contrib/redshift.lua
+++ /dev/null
@@ -1,54 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2017, Luca CPZ
- * (c) 2014, blueluke
-
---]]
-
-local async = require("lain.helpers").async
-local awful = require("awful")
-local execute = os.execute
-local type = type
-
--- Redshift
--- lain.widget.contrib.redshift
-local redshift = { active = false, pid = nil }
-
-function redshift:start()
- execute("pkill redshift")
- awful.spawn.with_shell("redshift -x") -- clear adjustments
- redshift.pid = awful.spawn.with_shell("redshift")
- redshift.active = true
- if type(redshift.update_fun) == "function" then
- redshift.update_fun(redshift.active)
- end
-end
-
-function redshift:toggle()
- async({ awful.util.shell, "-c", string.format("ps -p %d -o pid=", redshift.pid) }, function(f)
- if f and #f > 0 then -- redshift is running
- -- Sending -USR1 toggles redshift (See project website)
- execute("pkill -USR1 redshift")
- redshift.active = not redshift.active
- else -- not started or killed, (re)start it
- redshift:start()
- end
- redshift.update_fun(redshift.active)
- end)
-end
-
--- Attach to a widget
--- Provides a button which toggles redshift on/off on click
--- @param widget: Widget to attach to.
--- @param fun: Function to be run each time redshift is toggled (optional).
--- Use it to update widget text or icons on status change.
-function redshift:attach(widget, fun)
- redshift.update_fun = fun or function() end
- if not redshift.pid then redshift:start() end
- if widget then
- widget:buttons(awful.util.table.join(awful.button({}, 1, function () redshift:toggle() end)))
- end
-end
-
-return redshift
diff --git a/awesome/lain/widget/contrib/task.lua b/awesome/lain/widget/contrib/task.lua
deleted file mode 100644
index 536e006..0000000
--- a/awesome/lain/widget/contrib/task.lua
+++ /dev/null
@@ -1,92 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Jan Xie
-
---]]
-
-local helpers = require("lain.helpers")
-local markup = require("lain.util").markup
-local awful = require("awful")
-local naughty = require("naughty")
-local mouse = mouse
-local string = string
-
--- Taskwarrior notification
--- lain.widget.contrib.task
-local task = {}
-
-function task.hide()
- if not task.notification then return end
- naughty.destroy(task.notification)
- task.notification = nil
-end
-
-function task.show(scr)
- task.notification_preset.screen = task.followtag and awful.screen.focused() or scr or 1
-
- helpers.async({ awful.util.shell, "-c", task.show_cmd }, function(f)
- local widget_focused = true
-
- if mouse.current_widgets then
- widget_focused = false
- for _,v in ipairs(mouse.current_widgets) do
- if task.widget == v then
- widget_focused = true
- break
- end
- end
- end
-
- if widget_focused then
- task.hide()
- task.notification = naughty.notify {
- preset = task.notification_preset,
- title = "task next",
- text = markup.font(task.notification_preset.font,
- awful.util.escape(f:gsub("\n*$", "")))
- }
- end
- end)
-end
-
-function task.prompt()
- awful.prompt.run {
- prompt = task.prompt_text,
- textbox = awful.screen.focused().mypromptbox.widget,
- exe_callback = function(t)
- helpers.async(t, function(f)
- naughty.notify {
- preset = task.notification_preset,
- title = t,
- text = markup.font(task.notification_preset.font,
- awful.util.escape(f:gsub("\n*$", "")))
- }
- end)
- end,
- history_path = awful.util.getdir("cache") .. "/history_task"
- }
-end
-
-function task.attach(widget, args)
- local args = args or {}
- task.show_cmd = args.show_cmd or "task next"
- task.prompt_text = args.prompt_text or "Enter task command: "
- task.followtag = args.followtag or false
- task.notification_preset = args.notification_preset
- task.widget = widget
-
- if not task.notification_preset then
- task.notification_preset = {
- font = "Monospace 10",
- icon = helpers.icons_dir .. "/taskwarrior.png"
- }
- end
-
- if widget then
- widget:connect_signal("mouse::enter", function () task.show() end)
- widget:connect_signal("mouse::leave", function () task.hide() end)
- end
-end
-
-return task
diff --git a/awesome/lain/widget/contrib/tp_smapi.lua b/awesome/lain/widget/contrib/tp_smapi.lua
deleted file mode 100644
index b8acbe2..0000000
--- a/awesome/lain/widget/contrib/tp_smapi.lua
+++ /dev/null
@@ -1,147 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2018, Luca CPZ
- * (c) 2013, Conor Heine
-
---]]
-
-local helpers = require("lain.helpers")
-local focused = require("awful.screen").focused
-local gears = require("gears")
-local naughty = require("naughty")
-local wibox = require("wibox")
-local string = string
-local type = type
-
--- ThinkPad battery infos and widget creator
--- http://www.thinkwiki.org/wiki/Tp_smapi
--- lain.widget.contrib.tp_smapi
-
-local function factory(apipath)
- local tp_smapi = {
- path = apipath or "/sys/devices/platform/smapi"
- }
-
- function tp_smapi.get(batid, feature)
- return helpers.first_line(string.format("%s/%s/%s", tp_smapi.path, batid or "BAT0", feature or ""))
- end
-
- function tp_smapi.installed(batid)
- return tp_smapi.get(batid, "installed") == "1"
- end
-
- function tp_smapi.status(batid)
- return tp_smapi.get(batid, "state")
- end
-
- function tp_smapi.percentage(batid)
- return tp_smapi.get(batid, "remaining_percent")
- end
-
- -- either running or charging time
- function tp_smapi.time(batid)
- local status = tp_smapi.status(batid)
- local mins_left = tp_smapi.get(batid, string.match(string.lower(status), "discharging") and "remaining_running_time" or "remaining_charging_time")
- if not string.find(mins_left, "^%d+") then return "N/A" end
- return string.format("%02d:%02d", math.floor(mins_left / 60), mins_left % 60) -- HH:mm
- end
-
- function tp_smapi.hide()
- if not tp_smapi.notification then return end
- naughty.destroy(tp_smapi.notification)
- tp_smapi.notification = nil
- end
-
- function tp_smapi.show(batid, seconds, scr)
- if not tp_smapi.installed(batid) then return end
-
- local mfgr = tp_smapi.get(batid, "manufacturer") or "no_mfgr"
- local model = tp_smapi.get(batid, "model") or "no_model"
- local chem = tp_smapi.get(batid, "chemistry") or "no_chem"
- local status = tp_smapi.get(batid, "state")
- local time = tp_smapi.time(batid)
- local msg = ""
-
- if status and status ~= "idle" then
- msg = string.format("[%s] %s %s", status, time ~= "N/A" and time or "unknown remaining time",
- string.lower(status):gsub(" ", ""):gsub("\n", "") == "charging" and " until charged" or " remaining")
- else
- msg = "On AC power"
- end
-
- tp_smapi.hide()
- tp_smapi.notification = naughty.notify {
- title = string.format("%s: %s %s (%s)", batid, mfgr, model, chem),
- text = msg,
- timeout = type(seconds) == "number" and seconds or 0,
- screen = scr or focused()
- }
- end
-
- function tp_smapi.create_widget(args)
- local args = args or {}
- local pspath = args.pspath or "/sys/class/power_supply/"
- local batteries = args.batteries or (args.battery and {args.battery}) or {}
- local timeout = args.timeout or 30
- local settings = args.settings or function() end
-
- if #batteries == 0 then
- helpers.line_callback("ls -1 " .. pspath, function(line)
- local bstr = string.match(line, "BAT%w+")
- if bstr then batteries[#batteries + 1] = bstr end
- end)
- end
-
- local all_batteries_installed = true
-
- for i, battery in ipairs(batteries) do
- if not tp_smapi.installed(battery) then
- naughty.notify {
- preset = naughty.config.critical,
- title = "tp_smapi: error while creating widget",
- text = string.format("battery %s is not installed", battery)
- }
- all_batteries_installed = false
- break
- end
- end
-
- if not all_batteries_installed then return end
-
- tpbat = {
- batteries = batteries,
- widget = args.widget or wibox.widget.textbox()
- }
-
- function tpbat.update()
- tpbat_now = {
- n_status = {},
- n_perc = {},
- n_time = {},
- status = "N/A"
- }
-
- for i = 1, #batteries do
- tpbat_now.n_status[i] = tp_smapi.status(batteries[i]) or "N/A"
- tpbat_now.n_perc[i] = tp_smapi.percentage(batteries[i])
- tpbat_now.n_time[i] = tp_smapi.time(batteries[i]) or "N/A"
-
- if not tpbat_now.n_status[i]:lower():match("full") then
- tpbat_now.status = tpbat_now.n_status[i]
- end
- end
-
- widget = tpbat.widget -- backwards compatibility
- settings()
- end
-
- helpers.newtimer("thinkpad-batteries", timeout, tpbat.update)
-
- return tpbat
- end
-
- return tp_smapi
-end
-
-return factory
diff --git a/awesome/lain/widget/cpu.lua b/awesome/lain/widget/cpu.lua
deleted file mode 100644
index f4cce73..0000000
--- a/awesome/lain/widget/cpu.lua
+++ /dev/null
@@ -1,75 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local helpers = require("lain.helpers")
-local wibox = require("wibox")
-local math = math
-local string = string
-local tostring = tostring
-
--- CPU usage
--- lain.widget.cpu
-
-local function factory(args)
- local cpu = { core = {}, widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 2
- local settings = args.settings or function() end
-
- function cpu.update()
- -- Read the amount of time the CPUs have spent performing
- -- different kinds of work. Read the first line of /proc/stat
- -- which is the sum of all CPUs.
- for index,time in pairs(helpers.lines_match("cpu","/proc/stat")) do
- local coreid = index - 1
- local core = cpu.core[coreid] or
- { last_active = 0 , last_total = 0, usage = 0 }
- local at = 1
- local idle = 0
- local total = 0
-
- for field in string.gmatch(time, "[%s]+([^%s]+)") do
- -- 4 = idle, 5 = ioWait. Essentially, the CPUs have done
- -- nothing during these times.
- if at == 4 or at == 5 then
- idle = idle + field
- end
- total = total + field
- at = at + 1
- end
-
- local active = total - idle
-
- if core.last_active ~= active or core.last_total ~= total then
- -- Read current data and calculate relative values.
- local dactive = active - core.last_active
- local dtotal = total - core.last_total
- local usage = math.ceil((dactive / dtotal) * 100)
-
- core.last_active = active
- core.last_total = total
- core.usage = usage
-
- -- Save current data for the next run.
- cpu.core[coreid] = core
- end
- end
-
- cpu_now = cpu.core
- cpu_now.usage = cpu_now[0].usage
- widget = cpu.widget
-
- settings()
- end
-
- helpers.newtimer("cpu", timeout, cpu.update)
-
- return cpu
-end
-
-return factory
diff --git a/awesome/lain/widget/fs.lua b/awesome/lain/widget/fs.lua
deleted file mode 100644
index 58fbf93..0000000
--- a/awesome/lain/widget/fs.lua
+++ /dev/null
@@ -1,151 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2018, Uli Schlacter
- * (c) 2018, Otto Modinos
- * (c) 2013, Luca CPZ
-
---]]
-
-local helpers = require("lain.helpers")
-local Gio = require("lgi").Gio
-local focused = require("awful.screen").focused
-local wibox = require("wibox")
-local naughty = require("naughty")
-local math = math
-local string = string
-local tconcat = table.concat
-local type = type
-local tonumber = tonumber
-local query_size = Gio.FILE_ATTRIBUTE_FILESYSTEM_SIZE
-local query_free = Gio.FILE_ATTRIBUTE_FILESYSTEM_FREE
-local query_used = Gio.FILE_ATTRIBUTE_FILESYSTEM_USED
-local query = query_size .. "," .. query_free .. "," .. query_used
-
--- File systems info
--- lain.widget.fs
-
-local function factory(args)
- local fs = {
- widget = wibox.widget.textbox(),
- units = {
- [1] = "Kb", [2] = "Mb", [3] = "Gb",
- [4] = "Tb", [5] = "Pb", [6] = "Eb",
- [7] = "Zb", [8] = "Yb"
- }
- }
-
- function fs.hide()
- if not fs.notification then return end
- naughty.destroy(fs.notification)
- fs.notification = nil
- end
-
- function fs.show(seconds, scr)
- fs.hide(); fs.update()
- fs.notification_preset.screen = fs.followtag and focused() or scr or 1
- fs.notification = naughty.notify {
- preset = fs.notification_preset,
- timeout = type(seconds) == "number" and seconds or 5
- }
- end
-
- local args = args or {}
- local timeout = args.timeout or 600
- local partition = args.partition
- local threshold = args.threshold or 99
- local showpopup = args.showpopup or "on"
- local settings = args.settings or function() end
-
- fs.followtag = args.followtag or false
- fs.notification_preset = args.notification_preset
-
- if not fs.notification_preset then
- fs.notification_preset = {
- font = "Monospace 10",
- fg = "#FFFFFF",
- bg = "#000000"
- }
- end
-
- function fs.update()
- local notifytable = { [1] = string.format("%-10s %4s\t%6s\t%6s\t\n", "path", "used", "free", "size") }
- local pathlen = 10
- local maxpathidx = 1
- fs_now = {}
-
- for _, mount in ipairs(Gio.unix_mounts_get()) do
- local path = Gio.unix_mount_get_mount_path(mount)
- local root = Gio.File.new_for_path(path)
- local info = root:query_filesystem_info(query)
-
- if info then
- local size = info:get_attribute_uint64(query_size)
- local used = info:get_attribute_uint64(query_used)
- local free = info:get_attribute_uint64(query_free)
-
- if size > 0 then
- local units = math.floor(math.log(size)/math.log(1024))
-
- fs_now[path] = {
- units = fs.units[units],
- percentage = math.floor(100 * used / size), -- used percentage
- size = size / math.pow(1024, math.floor(units)),
- used = used / math.pow(1024, math.floor(units)),
- free = free / math.pow(1024, math.floor(units))
- }
-
- if fs_now[path].percentage > 0 then -- don't notify unused file systems
- notifytable[#notifytable+1] = string.format("\n%-10s %3s%%\t%6.2f\t%6.2f\t%s", path,
- math.floor(fs_now[path].percentage), fs_now[path].free, fs_now[path].size,
- fs_now[path].units)
-
- if #path > pathlen then
- pathlen = #path
- maxpathidx = #notifytable
- end
- end
- end
- end
- end
-
- widget = fs.widget
- settings()
-
- if partition and fs_now[partition] and fs_now[partition].percentage >= threshold then
- if not helpers.get_map(partition) then
- naughty.notify {
- preset = naughty.config.presets.critical,
- title = "Warning",
- text = string.format("%s is above %d%% (%d%%)", partition, threshold, fs_now[partition].percentage)
- }
- helpers.set_map(partition, true)
- else
- helpers.set_map(partition, false)
- end
- end
-
- if pathlen > 10 then -- if are there paths longer than 10 chars, reformat first column accordingly
- local pathspaces
- for i = 1, #notifytable do
- pathspaces = notifytable[i]:match("[ ]+")
- if i ~= maxpathidx and pathspaces then
- notifytable[i] = notifytable[i]:gsub(pathspaces, pathspaces .. string.rep(" ", pathlen - 10))
- end
- end
- end
-
- fs.notification_preset.text = tconcat(notifytable)
- end
-
- if showpopup == "on" then
- fs.widget:connect_signal('mouse::enter', function () fs.show(0) end)
- fs.widget:connect_signal('mouse::leave', function () fs.hide() end)
- end
-
- helpers.newtimer(partition or "fs", timeout, fs.update)
-
- return fs
-end
-
-return factory
diff --git a/awesome/lain/widget/imap.lua b/awesome/lain/widget/imap.lua
deleted file mode 100644
index b3d9dc7..0000000
--- a/awesome/lain/widget/imap.lua
+++ /dev/null
@@ -1,93 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
-
---]]
-
-local helpers = require("lain.helpers")
-local naughty = require("naughty")
-local wibox = require("wibox")
-local awful = require("awful")
-local string = string
-local type = type
-local tonumber = tonumber
-
--- Mail IMAP check
--- lain.widget.imap
-
-local function factory(args)
- local imap = { widget = wibox.widget.textbox() }
- local args = args or {}
- local server = args.server
- local mail = args.mail
- local password = args.password
- local port = args.port or 993
- local timeout = args.timeout or 60
- local pwdtimeout = args.pwdtimeout or 10
- local is_plain = args.is_plain or false
- local followtag = args.followtag or false
- local notify = args.notify or "on"
- local settings = args.settings or function() end
-
- local head_command = "curl --connect-timeout 3 -fsm 3"
- local request = "-X 'STATUS INBOX (MESSAGES RECENT UNSEEN)'"
-
- if not server or not mail or not password then return end
-
- mail_notification_preset = {
- icon = helpers.icons_dir .. "mail.png",
- position = "top_left"
- }
-
- helpers.set_map(mail, 0)
-
- if not is_plain then
- if type(password) == "string" or type(password) == "table" then
- helpers.async(password, function(f) password = f:gsub("\n", "") end)
- elseif type(password) == "function" then
- imap.pwdtimer = helpers.newtimer(mail .. "-password", pwdtimeout, function()
- local retrieved_password, try_again = password()
- if not try_again then
- imap.pwdtimer:stop() -- stop trying to retrieve
- password = retrieved_password or "" -- failsafe
- end
- end, true, true)
- end
- end
-
- function imap.update()
- -- do not update if the password has not been retrieved yet
- if type(password) ~= "string" then return end
-
- local curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:'%s' %s -k",
- head_command, server, port, mail, password, request)
-
- helpers.async(curl, function(f)
- imap_now = { ["MESSAGES"] = 0, ["RECENT"] = 0, ["UNSEEN"] = 0 }
-
- for s,d in f:gmatch("(%w+)%s+(%d+)") do imap_now[s] = tonumber(d) end
- mailcount = imap_now["UNSEEN"] -- backwards compatibility
- widget = imap.widget
-
- settings()
-
- if notify == "on" and mailcount and mailcount >= 1 and mailcount > helpers.get_map(mail) then
- if followtag then mail_notification_preset.screen = awful.screen.focused() end
- naughty.notify {
- preset = mail_notification_preset,
- text = string.format("%s has %d new message%s", mail, mailcount, mailcount == 1 and "" or "s")
- }
- end
-
- helpers.set_map(mail, imap_now["UNSEEN"])
- end)
-
- end
-
- imap.timer = helpers.newtimer(mail, timeout, imap.update, true, true)
-
- return imap
-end
-
-return factory
diff --git a/awesome/lain/widget/init.lua b/awesome/lain/widget/init.lua
deleted file mode 100644
index 57b86bb..0000000
--- a/awesome/lain/widget/init.lua
+++ /dev/null
@@ -1,19 +0,0 @@
---[[
-
- Lain
- Layouts, widgets and utilities for Awesome WM
-
- Widgets section
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local wrequire = require("lain.helpers").wrequire
-local setmetatable = setmetatable
-
-local widget = { _NAME = "lain.widget" }
-
-return setmetatable(widget, { __index = wrequire })
diff --git a/awesome/lain/widget/mem.lua b/awesome/lain/widget/mem.lua
deleted file mode 100644
index 9f31f3a..0000000
--- a/awesome/lain/widget/mem.lua
+++ /dev/null
@@ -1,50 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local helpers = require("lain.helpers")
-local wibox = require("wibox")
-local gmatch, lines, floor = string.gmatch, io.lines, math.floor
-
--- Memory usage (ignoring caches)
--- lain.widget.mem
-
-local function factory(args)
- local mem = { widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 2
- local settings = args.settings or function() end
-
- function mem.update()
- mem_now = {}
- for line in lines("/proc/meminfo") do
- for k, v in gmatch(line, "([%a]+):[%s]+([%d]+).+") do
- if k == "MemTotal" then mem_now.total = floor(v / 1024 + 0.5)
- elseif k == "MemFree" then mem_now.free = floor(v / 1024 + 0.5)
- elseif k == "Buffers" then mem_now.buf = floor(v / 1024 + 0.5)
- elseif k == "Cached" then mem_now.cache = floor(v / 1024 + 0.5)
- elseif k == "SwapTotal" then mem_now.swap = floor(v / 1024 + 0.5)
- elseif k == "SwapFree" then mem_now.swapf = floor(v / 1024 + 0.5)
- elseif k == "SReclaimable" then mem_now.srec = floor(v / 1024 + 0.5)
- end
- end
- end
-
- mem_now.used = mem_now.total - mem_now.free - mem_now.buf - mem_now.cache
- mem_now.swapused = mem_now.swap - mem_now.swapf
- mem_now.perc = math.floor(mem_now.used / mem_now.total * 100)
-
- widget = mem.widget
- settings()
- end
-
- helpers.newtimer("mem", timeout, mem.update)
-
- return mem
-end
-
-return factory
diff --git a/awesome/lain/widget/mpd.lua b/awesome/lain/widget/mpd.lua
deleted file mode 100644
index 01f28e6..0000000
--- a/awesome/lain/widget/mpd.lua
+++ /dev/null
@@ -1,132 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010, Adrian C.
-
---]]
-
-local helpers = require("lain.helpers")
-local shell = require("awful.util").shell
-local escape_f = require("awful.util").escape
-local focused = require("awful.screen").focused
-local naughty = require("naughty")
-local wibox = require("wibox")
-local os = os
-local string = string
-
--- MPD infos
--- lain.widget.mpd
-
-local function factory(args)
- local mpd = { widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 2
- local password = (args.password and #args.password > 0 and string.format("password %s\\n", args.password)) or ""
- local host = args.host or os.getenv("MPD_HOST") or "127.0.0.1"
- local port = args.port or os.getenv("MPD_PORT") or "6600"
- local music_dir = args.music_dir or os.getenv("HOME") .. "/Music"
- local cover_pattern = args.cover_pattern or "*\\.(jpg|jpeg|png|gif)$"
- local cover_size = args.cover_size or 100
- local default_art = args.default_art
- local notify = args.notify or "on"
- local followtag = args.followtag or false
- local settings = args.settings or function() end
-
- local mpdh = string.format("telnet://%s:%s", host, port)
- local echo = string.format("printf \"%sstatus\\ncurrentsong\\nclose\\n\"", password)
- local cmd = string.format("%s | curl --connect-timeout 1 -fsm 3 %s", echo, mpdh)
-
- mpd_notification_preset = { title = "Now playing", timeout = 6 }
-
- helpers.set_map("current mpd track", nil)
-
- function mpd.update()
- helpers.async({ shell, "-c", cmd }, function(f)
- mpd_now = {
- random_mode = false,
- single_mode = false,
- repeat_mode = false,
- consume_mode = false,
- pls_pos = "N/A",
- pls_len = "N/A",
- state = "N/A",
- file = "N/A",
- name = "N/A",
- artist = "N/A",
- title = "N/A",
- album = "N/A",
- genre = "N/A",
- track = "N/A",
- date = "N/A",
- time = "N/A",
- elapsed = "N/A"
- }
-
- for line in string.gmatch(f, "[^\n]+") do
- for k, v in string.gmatch(line, "([%w]+):[%s](.*)$") do
- if k == "state" then mpd_now.state = v
- elseif k == "file" then mpd_now.file = v
- elseif k == "Name" then mpd_now.name = escape_f(v)
- elseif k == "Artist" then mpd_now.artist = escape_f(v)
- elseif k == "Title" then mpd_now.title = escape_f(v)
- elseif k == "Album" then mpd_now.album = escape_f(v)
- elseif k == "Genre" then mpd_now.genre = escape_f(v)
- elseif k == "Track" then mpd_now.track = escape_f(v)
- elseif k == "Date" then mpd_now.date = escape_f(v)
- elseif k == "Time" then mpd_now.time = v
- elseif k == "elapsed" then mpd_now.elapsed = string.match(v, "%d+")
- elseif k == "song" then mpd_now.pls_pos = v
- elseif k == "playlistlength" then mpd_now.pls_len = v
- elseif k == "repeat" then mpd_now.repeat_mode = v ~= "0"
- elseif k == "single" then mpd_now.single_mode = v ~= "0"
- elseif k == "random" then mpd_now.random_mode = v ~= "0"
- elseif k == "consume" then mpd_now.consume_mode = v ~= "0"
- end
- end
- end
-
- mpd_notification_preset.text = string.format("%s (%s) - %s\n%s", mpd_now.artist,
- mpd_now.album, mpd_now.date, mpd_now.title)
- widget = mpd.widget
- settings()
-
- if mpd_now.state == "play" then
- if notify == "on" and mpd_now.title ~= helpers.get_map("current mpd track") then
- helpers.set_map("current mpd track", mpd_now.title)
-
- if followtag then mpd_notification_preset.screen = focused() end
-
- local common = {
- preset = mpd_notification_preset,
- icon = default_art,
- icon_size = cover_size,
- replaces_id = mpd.id
- }
-
- if not string.match(mpd_now.file, "http.*://") then -- local file instead of http stream
- local path = string.format("%s/%s", music_dir, string.match(mpd_now.file, ".*/"))
- local cover = string.format("find '%s' -maxdepth 1 -type f | egrep -i -m1 '%s'",
- path:gsub("'", "'\\''"), cover_pattern)
- helpers.async({ shell, "-c", cover }, function(current_icon)
- common.icon = current_icon:gsub("\n", "")
- if #common.icon == 0 then common.icon = nil end
- mpd.id = naughty.notify(common).id
- end)
- else
- mpd.id = naughty.notify(common).id
- end
-
- end
- elseif mpd_now.state ~= "pause" then
- helpers.set_map("current mpd track", nil)
- end
- end)
- end
-
- mpd.timer = helpers.newtimer("mpd", timeout, mpd.update, true, true)
-
- return mpd
-end
-
-return factory
diff --git a/awesome/lain/widget/net.lua b/awesome/lain/widget/net.lua
deleted file mode 100644
index 805b577..0000000
--- a/awesome/lain/widget/net.lua
+++ /dev/null
@@ -1,113 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local helpers = require("lain.helpers")
-local naughty = require("naughty")
-local wibox = require("wibox")
-local string = string
-
--- Network infos
--- lain.widget.net
-
-local function factory(args)
- local net = { widget = wibox.widget.textbox(), devices = {} }
- local args = args or {}
- local timeout = args.timeout or 2
- local units = args.units or 1024 -- KB
- local notify = args.notify or "on"
- local wifi_state = args.wifi_state or "off"
- local eth_state = args.eth_state or "off"
- local screen = args.screen or 1
- local settings = args.settings or function() end
-
- -- Compatibility with old API where iface was a string corresponding to 1 interface
- net.iface = (args.iface and (type(args.iface) == "string" and {args.iface}) or
- (type(args.iface) == "table" and args.iface)) or {}
-
- function net.get_device()
- helpers.line_callback("ip link", function(line)
- net.iface[#net.iface + 1] = not string.match(line, "LOOPBACK") and string.match(line, "(%w+): <") or nil
- end)
- end
-
- if #net.iface == 0 then net.get_device() end
-
- function net.update()
- -- These are the totals over all specified interfaces
- net_now = {
- devices = {},
- -- Bytes since last iteration
- sent = 0,
- received = 0
- }
-
- for _, dev in ipairs(net.iface) do
- local dev_now = {}
- local dev_before = net.devices[dev] or { last_t = 0, last_r = 0 }
- local now_t = tonumber(helpers.first_line(string.format("/sys/class/net/%s/statistics/tx_bytes", dev)) or 0)
- local now_r = tonumber(helpers.first_line(string.format("/sys/class/net/%s/statistics/rx_bytes", dev)) or 0)
-
- dev_now.carrier = helpers.first_line(string.format("/sys/class/net/%s/carrier", dev)) or "0"
- dev_now.state = helpers.first_line(string.format("/sys/class/net/%s/operstate", dev)) or "down"
-
- dev_now.sent = (now_t - dev_before.last_t) / timeout / units
- dev_now.received = (now_r - dev_before.last_r) / timeout / units
-
- net_now.sent = net_now.sent + dev_now.sent
- net_now.received = net_now.received + dev_now.received
-
- dev_now.sent = string.format("%.1f", dev_now.sent)
- dev_now.received = string.format("%.1f", dev_now.received)
-
- dev_now.last_t = now_t
- dev_now.last_r = now_r
-
- if wifi_state == "on" and helpers.first_line(string.format("/sys/class/net/%s/uevent", dev)) == "DEVTYPE=wlan" and string.match(dev_now.carrier, "1") then
- dev_now.wifi = true
- dev_now.signal = tonumber(string.match(helpers.lines_from("/proc/net/wireless")[3], "(%-%d+%.)")) or nil
- end
-
- if eth_state == "on" and helpers.first_line(string.format("/sys/class/net/%s/uevent", dev)) ~= "DEVTYPE=wlan" and string.match(dev_now.carrier, "1") then
- dev_now.ethernet = true
- end
-
- net.devices[dev] = dev_now
-
- -- Notify only once when connection is lost
- if string.match(dev_now.carrier, "0") and notify == "on" and helpers.get_map(dev) then
- naughty.notify {
- title = dev,
- text = "No carrier",
- icon = helpers.icons_dir .. "no_net.png",
- screen = screen
- }
- helpers.set_map(dev, false)
- elseif string.match(dev_now.carrier, "1") then
- helpers.set_map(dev, true)
- end
-
- net_now.carrier = dev_now.carrier
- net_now.state = dev_now.state
- net_now.devices[dev] = dev_now
- -- net_now.sent and net_now.received will be
- -- the totals across all specified devices
- end
-
- net_now.sent = string.format("%.1f", net_now.sent)
- net_now.received = string.format("%.1f", net_now.received)
-
- widget = net.widget
- settings()
- end
-
- helpers.newtimer("network", timeout, net.update)
-
- return net
-end
-
-return factory
diff --git a/awesome/lain/widget/pulse.lua b/awesome/lain/widget/pulse.lua
deleted file mode 100644
index f63fe55..0000000
--- a/awesome/lain/widget/pulse.lua
+++ /dev/null
@@ -1,57 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2016, Luca CPZ
-
---]]
-
-local helpers = require("lain.helpers")
-local shell = require("awful.util").shell
-local wibox = require("wibox")
-local string = string
-local type = type
-
--- PulseAudio volume
--- lain.widget.pulse
-
-local function factory(args)
- local pulse = { widget = wibox.widget.textbox(), device = "N/A" }
- local args = args or {}
- local timeout = args.timeout or 5
- local settings = args.settings or function() end
-
- pulse.devicetype = args.devicetype or "sink"
- pulse.cmd = args.cmd or "pacmd list-" .. pulse.devicetype .. "s | sed -n -e '/*/,$!d' -e '/index/p' -e '/base volume/d' -e '/volume:/p' -e '/muted:/p' -e '/device\\.string/p'"
-
- function pulse.update()
- helpers.async({ shell, "-c", type(pulse.cmd) == "string" and pulse.cmd or pulse.cmd() },
- function(s)
- volume_now = {
- index = string.match(s, "index: (%S+)") or "N/A",
- device = string.match(s, "device.string = \"(%S+)\"") or "N/A",
- muted = string.match(s, "muted: (%S+)") or "N/A"
- }
-
- pulse.device = volume_now.index
-
- local ch = 1
- volume_now.channel = {}
- for v in string.gmatch(s, ":.-(%d+)%%") do
- volume_now.channel[ch] = v
- ch = ch + 1
- end
-
- volume_now.left = volume_now.channel[1] or "N/A"
- volume_now.right = volume_now.channel[2] or "N/A"
-
- widget = pulse.widget
- settings()
- end)
- end
-
- helpers.newtimer("pulse", timeout, pulse.update)
-
- return pulse
-end
-
-return factory
diff --git a/awesome/lain/widget/pulsebar.lua b/awesome/lain/widget/pulsebar.lua
deleted file mode 100644
index 317468f..0000000
--- a/awesome/lain/widget/pulsebar.lua
+++ /dev/null
@@ -1,162 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2013, Rman
-
---]]
-
-local helpers = require("lain.helpers")
-local awful = require("awful")
-local naughty = require("naughty")
-local wibox = require("wibox")
-local math = math
-local string = string
-local type = type
-local tonumber = tonumber
-
--- PulseAudio volume bar
--- lain.widget.pulsebar
-
-local function factory(args)
- local pulsebar = {
- colors = {
- background = "#000000",
- mute = "#EB8F8F",
- unmute = "#A4CE8A"
- },
-
- _current_level = 0,
- _mute = "no",
- device = "N/A"
- }
-
- local args = args or {}
- local timeout = args.timeout or 5
- local settings = args.settings or function() end
- local width = args.width or 63
- local height = args.height or 1
- local margins = args.margins or 1
- local paddings = args.paddings or 1
- local ticks = args.ticks or false
- local ticks_size = args.ticks_size or 7
-
- pulsebar.colors = args.colors or pulsebar.colors
- pulsebar.followtag = args.followtag or false
- pulsebar.notification_preset = args.notification_preset
- pulsebar.devicetype = args.devicetype or "sink"
- pulsebar.cmd = args.cmd or "pacmd list-" .. pulsebar.devicetype .. "s | sed -n -e '/*/,$!d' -e '/index/p' -e '/base volume/d' -e '/volume:/p' -e '/muted:/p' -e '/device\\.string/p'"
-
- if not pulsebar.notification_preset then
- pulsebar.notification_preset = {
- font = "Monospace 10"
- }
- end
-
- pulsebar.bar = wibox.widget {
- color = pulsebar.colors.unmute,
- background_color = pulsebar.colors.background,
- forced_height = height,
- forced_width = width,
- margins = margins,
- paddings = paddings,
- ticks = ticks,
- ticks_size = ticks_size,
- widget = wibox.widget.progressbar,
- }
-
- pulsebar.tooltip = awful.tooltip({ objects = { pulsebar.bar } })
-
- function pulsebar.update(callback)
- helpers.async({ awful.util.shell, "-c", type(pulsebar.cmd) == "string" and pulsebar.cmd or pulsebar.cmd() },
- function(s)
- volume_now = {
- index = string.match(s, "index: (%S+)") or "N/A",
- device = string.match(s, "device.string = \"(%S+)\"") or "N/A",
- muted = string.match(s, "muted: (%S+)") or "N/A"
- }
-
- pulsebar.device = volume_now.index
-
- local ch = 1
- volume_now.channel = {}
- for v in string.gmatch(s, ":.-(%d+)%%") do
- volume_now.channel[ch] = v
- ch = ch + 1
- end
-
- volume_now.left = volume_now.channel[1] or "N/A"
- volume_now.right = volume_now.channel[2] or "N/A"
-
- local volu = volume_now.left
- local mute = volume_now.muted
-
- if volu:match("N/A") or mute:match("N/A") then return end
-
- if volu ~= pulsebar._current_level or mute ~= pulsebar._mute then
- pulsebar._current_level = tonumber(volu)
- pulsebar.bar:set_value(pulsebar._current_level / 100)
- if pulsebar._current_level == 0 or mute == "yes" then
- pulsebar._mute = mute
- pulsebar.tooltip:set_text ("[muted]")
- pulsebar.bar.color = pulsebar.colors.mute
- else
- pulsebar._mute = "no"
- pulsebar.tooltip:set_text(string.format("%s %s: %s", pulsebar.devicetype, pulsebar.device, volu))
- pulsebar.bar.color = pulsebar.colors.unmute
- end
-
- settings()
-
- if type(callback) == "function" then callback() end
- end
- end)
- end
-
- function pulsebar.notify()
- pulsebar.update(function()
- local preset = pulsebar.notification_preset
-
- preset.title = string.format("%s %s - %s%%", pulsebar.devicetype, pulsebar.device, pulsebar._current_level)
-
- if pulsebar._mute == "yes" then
- preset.title = preset.title .. " muted"
- end
-
- -- tot is the maximum number of ticks to display in the notification
- -- fallback: default horizontal wibox height
- local wib, tot = awful.screen.focused().mywibox, 20
-
- -- if we can grab mywibox, tot is defined as its height if
- -- horizontal, or width otherwise
- if wib then
- if wib.position == "left" or wib.position == "right" then
- tot = wib.width
- else
- tot = wib.height
- end
- end
-
- int = math.modf((pulsebar._current_level / 100) * tot)
- preset.text = string.format("[%s%s]", string.rep("|", int),
- string.rep(" ", tot - int))
-
- if pulsebar.followtag then preset.screen = awful.screen.focused() end
-
- if not pulsebar.notification then
- pulsebar.notification = naughty.notify {
- preset = preset,
- destroy = function() pulsebar.notification = nil end
- }
- else
- naughty.replace_text(pulsebar.notification, preset.title, preset.text)
- end
- end)
- end
-
- helpers.newtimer(string.format("pulsebar-%s", pulsebar.sink), timeout, pulsebar.update)
-
- return pulsebar
-end
-
-return factory
diff --git a/awesome/lain/widget/sysload.lua b/awesome/lain/widget/sysload.lua
deleted file mode 100644
index adf3e03..0000000
--- a/awesome/lain/widget/sysload.lua
+++ /dev/null
@@ -1,38 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
- * (c) 2010-2012, Peter Hofmann
-
---]]
-
-local helpers = require("lain.helpers")
-local wibox = require("wibox")
-local open, match = io.open, string.match
-
--- System load
--- lain.widget.sysload
-
-local function factory(args)
- local sysload = { widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 2
- local settings = args.settings or function() end
-
- function sysload.update()
- local f = open("/proc/loadavg")
- local ret = f:read("*all")
- f:close()
-
- load_1, load_5, load_15 = match(ret, "([^%s]+) ([^%s]+) ([^%s]+)")
-
- widget = sysload.widget
- settings()
- end
-
- helpers.newtimer("sysload", timeout, sysload.update)
-
- return sysload
-end
-
-return factory
diff --git a/awesome/lain/widget/temp.lua b/awesome/lain/widget/temp.lua
deleted file mode 100644
index e909b32..0000000
--- a/awesome/lain/widget/temp.lua
+++ /dev/null
@@ -1,44 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2013, Luca CPZ
-
---]]
-
-local helpers = require("lain.helpers")
-local wibox = require("wibox")
-local tonumber = tonumber
-
--- {thermal,core} temperature info
--- lain.widget.temp
-
-local function factory(args)
- local temp = { widget = wibox.widget.textbox() }
- local args = args or {}
- local timeout = args.timeout or 30
- local tempfile = args.tempfile or "/sys/devices/virtual/thermal/thermal_zone0/temp"
- local settings = args.settings or function() end
-
- function temp.update()
- helpers.async({"find", "/sys/devices", "-type", "f", "-name", "*temp*"}, function(f)
- temp_now = {}
- local temp_fl, temp_value
- for t in f:gmatch("[^\n]+") do
- temp_fl = helpers.first_line(t)
- if temp_fl then
- temp_value = tonumber(temp_fl)
- temp_now[t] = temp_value and temp_value/1e3 or temp_fl
- end
- end
- coretemp_now = temp_now[tempfile] or "N/A"
- widget = temp.widget
- settings()
- end)
- end
-
- helpers.newtimer("thermal", timeout, temp.update)
-
- return temp
-end
-
-return factory
diff --git a/awesome/lain/widget/weather.lua b/awesome/lain/widget/weather.lua
deleted file mode 100644
index 9c1e797..0000000
--- a/awesome/lain/widget/weather.lua
+++ /dev/null
@@ -1,148 +0,0 @@
---[[
-
- Licensed under GNU General Public License v2
- * (c) 2015, Luca CPZ
-
---]]
-
-local helpers = require("lain.helpers")
-local json = require("lain.util").dkjson
-local focused = require("awful.screen").focused
-local naughty = require("naughty")
-local wibox = require("wibox")
-local math = math
-local os = os
-local string = string
-local type = type
-local tonumber = tonumber
-
--- OpenWeatherMap
--- current weather and X-days forecast
--- lain.widget.weather
-
-local function factory(args)
- local weather = { widget = wibox.widget.textbox() }
- local args = args or {}
- local APPID = args.APPID or "3e321f9414eaedbfab34983bda77a66e" -- lain's default
- local timeout = args.timeout or 60 * 15 -- 15 min
- local timeout_forecast = args.timeout or 60 * 60 * 24 -- 24 hrs
- local current_call = args.current_call or "curl -s 'http://api.openweathermap.org/data/2.5/weather?id=%s&units=%s&lang=%s&APPID=%s'"
- local forecast_call = args.forecast_call or "curl -s 'http://api.openweathermap.org/data/2.5/forecast/daily?id=%s&units=%s&lang=%s&cnt=%s&APPID=%s'"
- local city_id = args.city_id or 0 -- placeholder
- local units = args.units or "metric"
- local lang = args.lang or "en"
- local cnt = args.cnt or 5
- local date_cmd = args.date_cmd or "date -u -d @%d +'%%a %%d'"
- local icons_path = args.icons_path or helpers.icons_dir .. "openweathermap/"
- local notification_preset = args.notification_preset or {}
- local notification_text_fun = args.notification_text_fun or
- function (wn)
- local day = os.date("%a %d", wn["dt"])
- local tmin = math.floor(wn["temp"]["min"])
- local tmax = math.floor(wn["temp"]["max"])
- local desc = wn["weather"][1]["description"]
- return string.format("%s: %s, %d - %d ", day, desc, tmin, tmax)
- end
- local weather_na_markup = args.weather_na_markup or " N/A "
- local followtag = args.followtag or false
- local showpopup = args.showpopup or "on"
- local settings = args.settings or function() end
-
- weather.widget:set_markup(weather_na_markup)
- weather.icon_path = icons_path .. "na.png"
- weather.icon = wibox.widget.imagebox(weather.icon_path)
-
- function weather.show(seconds)
- weather.hide()
-
- if followtag then
- notification_preset.screen = focused()
- end
-
- if not weather.notification_text then
- weather.update()
- weather.forecast_update()
- end
-
- weather.notification = naughty.notify {
- preset = notification_preset,
- text = weather.notification_text,
- icon = weather.icon_path,
- timeout = type(seconds == "number") and seconds or notification_preset.timeout
- }
- end
-
- function weather.hide()
- if weather.notification then
- naughty.destroy(weather.notification)
- weather.notification = nil
- end
- end
-
- function weather.attach(obj)
- obj:connect_signal("mouse::enter", function()
- weather.show(0)
- end)
- obj:connect_signal("mouse::leave", function()
- weather.hide()
- end)
- end
-
- function weather.forecast_update()
- local cmd = string.format(forecast_call, city_id, units, lang, cnt, APPID)
- helpers.async(cmd, function(f)
- local pos, err
- weather_now, pos, err = json.decode(f, 1, nil)
-
- if not err and type(weather_now) == "table" and tonumber(weather_now["cod"]) == 200 then
- weather.notification_text = ""
- for i = 1, weather_now["cnt"] do
- weather.notification_text = weather.notification_text ..
- notification_text_fun(weather_now["list"][i])
- if i < weather_now["cnt"] then
- weather.notification_text = weather.notification_text .. "\n"
- end
- end
- end
- end)
- end
-
- function weather.update()
- local cmd = string.format(current_call, city_id, units, lang, APPID)
- helpers.async(cmd, function(f)
- local pos, err, icon
- weather_now, pos, err = json.decode(f, 1, nil)
-
- if not err and type(weather_now) == "table" and tonumber(weather_now["cod"]) == 200 then
- local sunrise = tonumber(weather_now["sys"]["sunrise"])
- local sunset = tonumber(weather_now["sys"]["sunset"])
- local icon = weather_now["weather"][1]["icon"]
- local loc_now = os.time()
-
- if sunrise <= loc_now and loc_now <= sunset then
- icon = string.gsub(icon, "n", "d")
- else
- icon = string.gsub(icon, "d", "n")
- end
-
- weather.icon_path = icons_path .. icon .. ".png"
- widget = weather.widget
- settings()
- else
- weather.icon_path = icons_path .. "na.png"
- weather.widget:set_markup(weather_na_markup)
- end
-
- weather.icon:set_image(weather.icon_path)
- end)
- end
-
- if showpopup == "on" then weather.attach(weather.widget) end
-
- weather.timer = helpers.newtimer("weather-" .. city_id, timeout, weather.update, false, true)
- weather.timer_forecast = helpers.newtimer("weather_forecast-" .. city_id, timeout, weather.forecast_update, false, true)
-
- return weather
-end
-
-return factory
diff --git a/awesome/lain/wiki/Home.md b/awesome/lain/wiki/Home.md
deleted file mode 100644
index d098efe..0000000
--- a/awesome/lain/wiki/Home.md
+++ /dev/null
@@ -1,43 +0,0 @@
-Welcome to the Lain wiki!
-
-If you spot a typo or have a suggestion to improve these pages, please notify me opening an [issue](https://github.com/lcpz/lain/issues) format. Thank you.
-
-Dependencies
-------------
-
-Package | Requested by | Reasons of choice
---- | --- | ---
-[curl](https://curl.haxx.se) | `imap`, `mpd`, and `weather` widgets | 1. faster and simpler to use than [LuaSocket](https://github.com/diegonehab/luasocket); 2. it's in the core of almost every distro; 3. can be called [asynchronously](https://awesomewm.org/doc/api/libraries/awful.spawn.html#easy_async)
-GLib >= 2.54 | `fs` widget | Pure Awesome/Lua implementation.
-
-The second dependency will be removed once all major distros update their Gio/Glib versions.
-
-Installation
-------------
-
-### Arch Linux
-
-[AUR package](https://aur.archlinux.org/packages/lain-git/)
-
-### Other distributions
-
-```shell
-git clone https://github.com/lcpz/lain.git ~/.config/awesome/lain
-```
-
-Also available via [LuaRocks](https://luarocks.org/modules/aajjbb/lain).
-
-Usage
---------
-
-First, include it into your `rc.lua`:
-
-```lua
-local lain = require("lain")
-```
-
-Then check out the submodules you want:
-
-- [Layouts](https://github.com/lcpz/lain/wiki/Layouts)
-- [Widgets](https://github.com/lcpz/lain/wiki/Widgets)
-- [Utilities](https://github.com/lcpz/lain/wiki/Utilities)
diff --git a/awesome/lain/wiki/Layouts.md b/awesome/lain/wiki/Layouts.md
deleted file mode 100644
index 0286d4b..0000000
--- a/awesome/lain/wiki/Layouts.md
+++ /dev/null
@@ -1,255 +0,0 @@
-
- lain/layout
- .
- |-- termfair
- |-- termfair.center
- |-- cascade
- |-- cascade.tile
- |-- centerwork
- |-- centerwork.horizontal
-
-Usage
-=====
-
-As usual, specify your favourites in `awful.layout.layouts`, or set them on specific tags with [`awful.layout.set`](https://awesomewm.org/doc/api/libraries/awful.layout.html#set).
-
-```lua
-awful.layout.set(lain.layout.termfair, tag)
-```
-
-How do layouts work?
-====================
-
-`termfair`
---------
-
-This layout restricts the size of each window. Each window will have the
-same width but is variable in height. Furthermore, windows are
-left-aligned. The basic workflow is as follows (the number above the
-screen is the number of open windows, the number in a cell is the fixed
-number of a client):
-
- (1) (2) (3)
- +---+---+---+ +---+---+---+ +---+---+---+
- | | | | | | | | | | | |
- | 1 | | | -> | 2 | 1 | | -> | 3 | 2 | 1 | ->
- | | | | | | | | | | | |
- +---+---+---+ +---+---+---+ +---+---+---+
-
- (4) (5) (6)
- +---+---+---+ +---+---+---+ +---+---+---+
- | 4 | | | | 5 | 4 | | | 6 | 5 | 4 |
- +---+---+---+ -> +---+---+---+ -> +---+---+---+
- | 3 | 2 | 1 | | 3 | 2 | 1 | | 3 | 2 | 1 |
- +---+---+---+ +---+---+---+ +---+---+---+
-
-The first client will be located in the left column. When opening
-another window, this new window will be placed in the left column while
-moving the first window into the middle column. Once a row is full,
-another row above it will be created.
-
-Default number of columns and rows are respectively taken from `nmaster`
-and `ncol` values in `awful.tag`, but you can set your own.
-
-For example, this sets `termfair` to 3 columns and at least 1 row:
-
-```lua
-lain.layout.termfair.nmaster = 3
-lain.layout.termfair.ncol = 1
-```
-
-`termfair.center`
-----------
-
-Similar to `termfair`, but with fixed number of vertical columns. Cols are centerded until there are `nmaster` columns, then windows are stacked as slaves, with possibly `ncol` clients per column at most.
-
- (1) (2) (3)
- +---+---+---+ +-+---+---+-+ +---+---+---+
- | | | | | | | | | | | | |
- | | 1 | | -> | | 1 | 2 | | -> | 1 | 2 | 3 | ->
- | | | | | | | | | | | | |
- +---+---+---+ +-+---+---+-+ +---+---+---+
-
- (4) (5)
- +---+---+---+ +---+---+---+
- | | | 3 | | | 2 | 4 |
- + 1 + 2 +---+ -> + 1 +---+---+
- | | | 4 | | | 3 | 5 |
- +---+---+---+ +---+---+---+
-
-Like `termfair`, default number of columns and rows are respectively taken from `nmaster`
-and `ncol` values in `awful.tag`, but you can set your own.
-
-For example, this sets `termfair.center` to 3 columns and at least 1 row:
-
-```lua
-lain.layout.termfair.center.nmaster = 3
-lain.layout.termfair.center.ncol = 1
-```
-
-`cascade`
--------
-
-Cascade all windows of a tag.
-
-You can control the offsets by setting these two variables:
-
-```lua
-lain.layout.cascade.offset_x = 64
-lain.layout.cascade.offset_y = 16
-```
-
-The following reserves space for 5 windows:
-
-```lua
-lain.layout.cascade.nmaster = 5
-```
-
-That is, no window will get resized upon the creation of a new window,
-unless there's more than 5 windows.
-
-`cascade.tile`
------------
-
-Similar to `awful.layout.suit.tile` layout, however, clients in the slave
-column are cascaded instead of tiled.
-
-Left column size can be set, otherwise is controlled by `mwfact` of the
-tag. Additional windows will be opened in another column on the right.
-New windows are placed above old windows.
-
-Whether the slave column is placed on top of the master window or not is
-controlled by the value of `ncol`. A value of 1 means "overlapping slave column"
-and anything else means "don't overlap windows".
-
-Usage example:
-
-```lua
-lain.layout.cascade.tile.offset_x = 2
-lain.layout.cascade.tile.offset_y = 32
-lain.layout.cascade.tile.extra_padding = 5
-lain.layout.cascade.tile.nmaster = 5
-lain.layout.cascade.tile.ncol = 2
-```
-
-`extra_padding` reduces the size of the master window if "overlapping
-slave column" is activated. This allows you to see if there are any
-windows in your slave column.
-
-Setting `offset_x` to a very small value or even 0 is recommended to avoid wasting space.
-
-`centerwork`
-----------
-
-You start with one window, centered horizontally:
-
- +--------------------------+
- | +----------+ |
- | | | |
- | | | |
- | | | |
- | | MAIN | |
- | | | |
- | | | |
- | | | |
- | | | |
- | +----------+ |
- +--------------------------+
-
-This is your main working window. You do most of the work right here.
-Sometimes, you may want to open up additional windows. They're put on left and right, alternately.
-
- +--------------------------+
- | +---+ +----------+ +---+ |
- | | | | | | | |
- | | | | | | | |
- | | | | | | | |
- | +---+ | MAIN | +---+ |
- | +---+ | | +---+ |
- | | | | | | | |
- | | | | | | | |
- | | | | | | | |
- | +---+ +----------+ +---+ |
- +--------------------------+
-
-*Please note:* If you use Awesome's default configuration, navigation in
-this layout may be very confusing. How do you get from the main window
-to satellite ones depends on the order in which the windows are opened.
-Thus, use of `awful.client.focus.bydirection()` is suggested.
-Here's an example:
-
-```lua
-globalkeys = awful.util.table.join(
- -- [...]
- awful.key({ modkey }, "j",
- function()
- awful.client.focus.bydirection("down")
- if client.focus then client.focus:raise() end
- end),
- awful.key({ modkey }, "k",
- function()
- awful.client.focus.bydirection("up")
- if client.focus then client.focus:raise() end
- end),
- awful.key({ modkey }, "h",
- function()
- awful.client.focus.bydirection("left")
- if client.focus then client.focus:raise() end
- end),
- awful.key({ modkey }, "l",
- function()
- awful.client.focus.bydirection("right")
- if client.focus then client.focus:raise() end
- end),
- -- [...]
-)
-```
-
-`centerwork.horizontal`
------------
-
-Same as `centerwork`, except that the main
-window expands horizontally, and the additional windows
-are put ontop/below it. Useful if you have a screen turned 90°.
-
-Pre 4.0 `uselesstile` patches
-=============================
-
-In branch 3.5, this module provided useless gaps layouts. Since useless gaps have been implemented in Awesome 4.0, those layouts have been removed.
-
-Following are a couple of `uselesstile` variants that were not part of lain. They are kept only for reference and are not supported.
-
-Xmonad-like
------------
-
-If you want to have `awful.layout.suit.tile` behave like xmonad, with internal gaps two times wider than external ones, download [this](https://gist.github.com/lcpz/9e56dcfbe66bfe14967c) as `lain/layout/uselesstile`.
-
-Inverted master
----------------
-
-Want to invert master window position? Use [this](https://gist.github.com/lcpz/c59dc59c9f99d98218eb) version. You can set `single_gap` with `width` and `height` in your `theme.lua`, in order to define the window geometry when there's only one client, otherwise it goes maximized. An example:
-
- theme.single_gap = { width = 600, height = 100 }
-
-What about layout icons?
-========================
-
-They are located in ``lain/icons/layout``.
-
-To use them, define new `layout_*` variables in your ``theme.lua``. For instance:
-
-```lua
-theme.lain_icons = os.getenv("HOME") ..
- "/.config/awesome/lain/icons/layout/default/"
-theme.layout_termfair = theme.lain_icons .. "termfair.png"
-theme.layout_centerfair = theme.lain_icons .. "centerfair.png" -- termfair.center
-theme.layout_cascade = theme.lain_icons .. "cascade.png"
-theme.layout_cascadetile = theme.lain_icons .. "cascadetile.png" -- cascade.tile
-theme.layout_centerwork = theme.lain_icons .. "centerwork.png"
-theme.layout_centerworkh = theme.lain_icons .. "centerworkh.png" -- centerwork.horizontal
-```
-
-Credit goes to [Nicolas Estibals](https://github.com/nestibal) for creating
-layout icons for default theme.
-
-You can use them as a template for your custom versions.
\ No newline at end of file
diff --git a/awesome/lain/wiki/Utilities.md b/awesome/lain/wiki/Utilities.md
deleted file mode 100644
index 4ec3057..0000000
--- a/awesome/lain/wiki/Utilities.md
+++ /dev/null
@@ -1,338 +0,0 @@
-Quake
------
-
-A Quake-like dropdown container for your favourite application.
-
-**Usage**
-
-Define it globally to have a single instance for all screens:
-
-```lua
-local quake = lain.util.quake()
-```
-
-or define it in `connect_for_each_screen` to have one instance for each screen:
-
-```lua
-awful.screen.connect_for_each_screen(function(s)
- -- Quake application
- s.quake = lain.util.quake()
- -- [...]
-```
-
-**Keybinding example**
-
-If using a global instance:
-```lua
-awful.key({ modkey, }, "z", function () quake:toggle() end),
-```
-
-If using a per-screen instance:
-```lua
-awful.key({ modkey, }, "z", function () awful.screen.focused().quake:toggle() end),
-```
-
-**Input table**
-
-Variable | Meaning | Type | Default
---- | --- | --- | ---
-`app` | client to spawn | string | "xterm"
-`name` | client name | string | "QuakeDD"
-`argname` | how to specify client name | string | "-name %s"
-`extra` | extra `app` arguments | string | empty string
-`border` | border width | integer | 1
-`visible` | initially visible | boolean | false
-`followtag` | always spawn on currently focused screen | boolean | false
-`overlap` | Overlap the wibox or not | boolean | false
-`settings` | Additional settings to make on the client | function | `nil`
-`screen` | screen where to spawn the client | integer | `awful.screen.focused()`
-`height` | dropdown client height | float in [0,1] or exact pixels number | 0.25
-`width` | dropdown client width | float in [0,1] or exact pixels number | 1
-`vert` | vertical position | string, possible values: "top", "bottom", "center" | "top"
-`horiz` | horizontal position | string, possible values: "left", "right", "center" | "left"
-
-`height` and `width` express a fraction of the workspace.
-
-`settings` is a function which takes the client as input, and can be used to customize its properties. For instance:
-
-```lua
--- set the client sticky
-s.quake = lain.util.quake { settings = function(c) c.sticky = true end }
-```
-
-Read [here](https://awesomewm.org/doc/api/classes/client.html#Object_properties) for the complete list of properties.
-
-**Notes**
-
-* [Does not work](https://github.com/lcpz/lain/issues/358) with `gnome-terminal`, `konsole`, or any other terminal which is strictly designed for a Desktop Environment. Just pick a better terminal, [there's plenty](https://wiki.archlinux.org/index.php/List_of_applications#Terminal_emulators).
-* Set `followtag = true` if [experiencing issues with multiple screens](https://github.com/lcpz/lain/issues/346).
-* If you have a `awful.client.setslave` rule for your application, ensure you use an exception for `QuakeDD` (or your defined `name`). Otherwise, you may run into problems with focus.
-* If you are using a VTE-based terminal like `termite`, be sure to set [`argname = "--name %s"`](https://github.com/lcpz/lain/issues/211).
-
-Separators
-----------
-
-Adds Cairo separators.
-
-```lua
-local separators = lain.util.separators
-```
-
-A separator function `separators.separator` takes two color arguments, defined as strings. `"alpha"` argument is allowed. Example:
-
-```lua
-arrl_dl = separators.arrow_left(beautiful.bg_focus, "alpha")
-arrl_ld = separators.arrow_left("alpha", beautiful.bg_focus)
-```
-
-You can customize height and width by setting `separators_height` and `separators_width` in your `theme.lua`. Default values are 0 and 9, respectively.
-
-List of functions:
-
- +-- separators
- |
- |`-- arrow_right() Draw a right arrow.
- `-- arrow_left() Draw a left arrow.
-
-markup
-------
-
-Mades markup easier.
-
-```lua
-local markup = lain.util.markup
-```
-
-List of functions:
-
- +-- 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.
- |`-- font() Set the font of the text.
- |`-- color() Set background and foreground color.
- |`-- fontfg() Set font and foreground color.
- |`-- fontbg() Set font and background color.
- `-- fontcolor() Set font, plus background and foreground colors.
- |
- |`--+ bg
- | |
- | `-- color() Set background color.
- |
- `--+ fg
- |
- `-- color() Set foreground color.
-
-they all take one argument, which is the text to markup, except the following:
-
-```lua
-markup.font(font, text)
-markup.color(fg, bg, text)
-markup.fontfg(font, fg, text)
-markup.fontbg(font, bg, text)
-markup.fontcolor(font, fg, bg, text)
-markup.fg.color(color, text)
-markup.bg.color(color, text)
-```
-
-Dynamic tagging
----------------
-
-That is:
-
-- add a new tag;
-- rename current tag;
-- move current tag;
-- delete current tag.
-
-If you delete a tag, any rule set on it shall be broken, so be careful.
-
-Use it with key bindings like these:
-
-```lua
-awful.key({ modkey, "Shift" }, "n", function () lain.util.add_tag(mylayout) end),
-awful.key({ modkey, "Shift" }, "r", function () lain.util.rename_tag() end),
-awful.key({ modkey, "Shift" }, "Left", function () lain.util.move_tag(1) end), -- move to next tag
-awful.key({ modkey, "Shift" }, "Right", function () lain.util.move_tag(-1) end), -- move to previous tag
-awful.key({ modkey, "Shift" }, "d", function () lain.util.delete_tag() end),
-```
-
-The argument in `lain.util.add_tag` represents the tag layout, and is optional: if not present, it will be defaulted to `awful.layout.suit.tile`.
-
-Useless gaps resize
----------------------
-
-Changes `beautiful.useless_gaps` on the fly.
-
-```lua
-lain.util.useless_gap_resize(thatmuch, s, t)
-```
-
-The argument `thatmuch` is the number of pixel to add to/substract from gaps (integer).
-
-The arguments `s` and `t` are the `awful.screen` and `awful.tag` in which you want to change the gap. They are optional.
-
-Following are example keybindings for changing client gaps on current screen and tag.
-
-Example 1:
-
-```lua
--- On the fly useless gaps change
-awful.key({ altkey, "Control" }, "+", function () lain.util.useless_gaps_resize(1) end),
-awful.key({ altkey, "Control" }, "-", function () lain.util.useless_gaps_resize(-1) end),
-```
-
-where `altkey = Mod1`. Example 2:
-
-```lua
-mywidget:buttons(awful.util.table.join (
- awful.button({}, 4, function() lain.util.useless_gaps_resize(-1) end),
- awful.button({}, 5, function() lain.util.useless_gaps_resize(1) end)
- end)
-))
-```
-
-so when hovering the mouse over `mywidget`, you can adjust useless gaps size by scrolling with the mouse wheel.
-
-tag\_view\_nonempty
--------------------
-
-This function lets you jump to the next/previous non-empty tag.
-It takes two arguments:
-
-* `direction`: `1` for next non-empty tag, `-1` for previous.
-* `sc`: Screen which the taglist is in. Default is `mouse.screen` or `1`. This
- argument is optional.
-
-You can use it with key bindings like these:
-
-```lua
--- Non-empty tag browsing
-awful.key({ altkey }, "Left", function () lain.util.tag_view_nonempty(-1) end),
-awful.key({ altkey }, "Right", function () lain.util.tag_view_nonempty(1) end),
-```
-
-where `altkey = "Mod1"`.
-
-magnify\_client
----------------
-
-Set a client to floating and resize it in the same way the "magnifier"
-layout does it. Place it on the "current" screen (derived from the mouse
-position). This allows you to magnify any client you wish, regardless of
-the currently used layout. Use it with a client keybinding like this:
-
-```lua
-clientkeys = awful.util.table.join(
- -- [...]
- awful.key({ modkey, "Control" }, "m", lain.util.magnify_client),
- -- [...]
-)
-```
-
-If you want to "de-magnify" it, just retype the keybinding.
-
-If you want magnified client to respond to `incmwfact`, read [here](https://github.com/lcpz/lain/issues/195).
-
-menu\_clients\_current\_tags
-----------------------------
-
-Similar to `awful.menu.clients`, but this menu only shows the clients
-of currently visible tags. Use it with a key binding like this:
-
-```lua
-awful.key({ "Mod1" }, "Tab", function()
- lain.util.menu_clients_current_tags({ width = 350 }, { keygrabber = true })
-end),
-```
-
-menu\_iterator
---------------
-
-A generic menu utility which enables iteration over lists of possible
-actions to execute. The perfect example is a menu for choosing what
-configuration to apply to X with `xrandr`, as suggested on the [Awesome wiki page](https://awesomewm.org/recipes/xrandr).
-
-