Compare commits
No commits in common. "8af64936804d4493022385980212aaae73197ab0" and "ef8da74f1ae38d9eceb68846fe9ef402c8e30fcf" have entirely different histories.
8af6493680
...
ef8da74f1a
34
Makefile
@ -1,34 +0,0 @@
|
||||
|
||||
# prevents default audio devices from changing when connecting to audio dock
|
||||
setup-pulseaudio:
|
||||
sudo sed -i 's/^load-module module-switch-on-connect$/# load-module module-switch-on-connect/g' /etc/pulse/default.pa
|
||||
pulseaudio -k
|
||||
|
||||
# add vfat to MODULES in /etc/mkinitcpio.conf
|
||||
# add `cryptkey=UUID=<uuid>:vfat:/keyfile` to boot line in bootloader
|
||||
# - use lsblk -o NAME,UUID to get UUID
|
||||
install-rm-keyfile:
|
||||
sudo cp ./base/rm-keyfile.service /etc/systemd/system
|
||||
sudo systemctl daemon-reload
|
||||
|
||||
install-pamd:
|
||||
drv=$$(nix-instantiate -E '((import ./pkgs.nix).stable {}).i3lock'); \
|
||||
store=$$(nix-store --realise $$drv); \
|
||||
sudo cp $$store"/etc/pam.d/i3lock" /etc/pam.d/i3lock
|
||||
|
||||
install-loadout:
|
||||
@if [ -z "$(HOSTNAME)" ]; then echo "USAGE: make HOSTNAME=... install-loadout"; exit 1; fi
|
||||
nix-env -i loadout -f default.nix --arg hostConfig "import ./config/$(HOSTNAME).nix"
|
||||
|
||||
install-fonts:
|
||||
@if [ -z "$(HOSTNAME)" ]; then echo "USAGE: make HOSTNAME=... install-loadout"; exit 1; fi
|
||||
mkdir -p ~/.local/share/fonts/
|
||||
p=$$(nix-build --no-out-link --arg hostConfig ./config/$(HOSTNAME).nix -A fonts); \
|
||||
cp -rL $$p/share/fonts ~/.local/share/fonts/loadout
|
||||
chmod o+w -R ~/.local/share/fonts/loadout
|
||||
fc-cache
|
||||
|
||||
install-keyboard:
|
||||
sudo cp ./base/00-keyboard.conf /etc/X11/xorg.conf.d/00-keyboard.conf
|
||||
|
||||
install: setup-pulseaudio install-pamd install-rm-keyfile install-fonts install-keyboard install-loadout
|
105
README.md
Normal file
@ -0,0 +1,105 @@
|
||||
# Mediocre Loadout
|
||||
|
||||
This repo contains everything needed to build my loadout, which is everything
|
||||
which I tend to take from one linux machine to the next. This includes:
|
||||
|
||||
* My development environment (neovim + plugins + a lot of customization)
|
||||
* My shell (zsh + plugins + a custom theme)
|
||||
* My window manager (awesome + plugins + a lot of customization)
|
||||
|
||||
I'm calling the result the "Mediocre Loadout". It is designed to be completely
|
||||
agnostic to the system it is running on, and to make little to no mutations to
|
||||
that system.
|
||||
|
||||
# Build/Installation/Usage options
|
||||
|
||||
To build the Mediocre Loadout you must have a working
|
||||
[nix](https://nixos.org/manual/nix/stable/) installation, as well as an `x86_64`
|
||||
machine. That's it.
|
||||
|
||||
There are multiple build/installation options:
|
||||
|
||||
## nix Derivation
|
||||
|
||||
To build the nix derivation of the loadout you can do:
|
||||
|
||||
```
|
||||
nix-build -A loadout
|
||||
```
|
||||
|
||||
This will place the result in the `result` symlink in the root directory.
|
||||
Components of the loadout can then be executed from the `bin` subdirectory,
|
||||
e.g.:
|
||||
|
||||
```
|
||||
./result/bin/nvim
|
||||
```
|
||||
|
||||
## nix Environment
|
||||
|
||||
Alternatively, to install it to your nix profile do:
|
||||
|
||||
```
|
||||
nix-env -i default.nix -A loadout
|
||||
```
|
||||
|
||||
Assuming your nix environment is set up correctly, you should be able to execute
|
||||
components directly:
|
||||
|
||||
```
|
||||
nvim
|
||||
```
|
||||
|
||||
## AppImage
|
||||
|
||||
An [AppImage](https://appimage.org/) binary can be built which can run any
|
||||
component of the loadout individually. This binary can be copied from one
|
||||
machine to the next without any of them requiring nix or any other dependencry
|
||||
to run it.
|
||||
|
||||
To build the binary:
|
||||
|
||||
```
|
||||
nix-build -A appimage
|
||||
```
|
||||
|
||||
The resulting binary will be placed in the `result` symlink in the root
|
||||
directory.
|
||||
|
||||
Specific components of the loadout can be run by passing an argument to the
|
||||
binary:
|
||||
|
||||
```
|
||||
./Mediocre_Loadout-x86_64.AppImage nvim
|
||||
```
|
||||
|
||||
NOTE that the AppImage doesn't like working with files within `/tmp`. I don't
|
||||
know of a workaround for this at the moment.
|
||||
|
||||
# Available Components
|
||||
|
||||
Components of the loadout can be run separate from the others, depending on what
|
||||
you're trying to do. The following components are available to be run:
|
||||
|
||||
* `zsh`: My terminal shell. There's some customization
|
||||
to it but it should be pretty self-explanatory to "just use".
|
||||
|
||||
* `nvim`: My neovim development environment, plus all plugins I use. I mostly
|
||||
work in golang, so it's most tuned for that, but it does fine for general dev
|
||||
work. `Ctrl-N` will open NerdTree, `<backslash>tn` will open a terminal tab,
|
||||
and `<backslash>th`/`<backslash>tl` can be used to navigate tabs. There's a
|
||||
lot more customization that's been done, see the `nvim/init.vim` file.
|
||||
|
||||
* `alacritty`: Terminal GUI which I use. Yes, I always use a light-mode theme,
|
||||
because I work in well lit spaces generally. There's not much else to this.
|
||||
|
||||
* `awesome`: My window manager. There's so much customization I couldn't begin
|
||||
to start. `Meta+Enter` should open a terminal, where `Meta` is probably the
|
||||
windows key on your keyboard.
|
||||
|
||||
# Status
|
||||
|
||||
This configuration is still fairly new, and so expect it to be fairly broken.
|
||||
I'll be updating it as I go though, so it should stabalize into something
|
||||
functional. I don't test the AppImage build very much, it's more of a gimick,
|
||||
but the shell and dev environment should work well from it at least.
|
@ -101,76 +101,82 @@ env:
|
||||
# Scrolling distance multiplier.
|
||||
#multiplier: 3
|
||||
|
||||
# Font configuration
|
||||
## Font configuration
|
||||
font:
|
||||
# Normal (roman) font face
|
||||
normal:
|
||||
# Font family
|
||||
size: 7
|
||||
|
||||
#
|
||||
# Default:
|
||||
# - (macOS) Menlo
|
||||
# - (Linux/BSD) monospace
|
||||
# - (Windows) Consolas
|
||||
family: "Source Code Pro"
|
||||
|
||||
# The `style` can be specified to pick a specific face.
|
||||
style: Regular
|
||||
|
||||
# Bold font face
|
||||
bold:
|
||||
# Font family
|
||||
#TODO I'd like to restore this font configuration, but I can't cause nix
|
||||
#doesn't play nicely with fontconfig
|
||||
#font:
|
||||
# # Normal (roman) font face
|
||||
# normal:
|
||||
# # Font family
|
||||
# #
|
||||
# # Default:
|
||||
# # - (macOS) Menlo
|
||||
# # - (Linux/BSD) monospace
|
||||
# # - (Windows) Consolas
|
||||
# family: Source Code Pro
|
||||
#
|
||||
# If the bold family is not specified, it will fall back to the
|
||||
# value specified for the normal font.
|
||||
family: "Source Code Pro"
|
||||
|
||||
# The `style` can be specified to pick a specific face.
|
||||
style: Bold
|
||||
|
||||
# Italic font face
|
||||
italic:
|
||||
# Font family
|
||||
# # The `style` can be specified to pick a specific face.
|
||||
# style: Regular
|
||||
#
|
||||
# If the italic family is not specified, it will fall back to the
|
||||
# value specified for the normal font.
|
||||
family: "Source Code Pro"
|
||||
|
||||
# The `style` can be specified to pick a specific face.
|
||||
style: Italic
|
||||
|
||||
# Bold italic font face
|
||||
bold_italic:
|
||||
# Font family
|
||||
# # Bold font face
|
||||
# bold:
|
||||
# # Font family
|
||||
# #
|
||||
# # If the bold family is not specified, it will fall back to the
|
||||
# # value specified for the normal font.
|
||||
# family: Source Code Pro
|
||||
#
|
||||
# If the bold italic family is not specified, it will fall back to the
|
||||
# value specified for the normal font.
|
||||
family: "Source Code Pro"
|
||||
|
||||
# The `style` can be specified to pick a specific face.
|
||||
style: Bold Italic
|
||||
|
||||
# Point size
|
||||
size: 6.3
|
||||
|
||||
# Offset is the extra space around each character. `offset.y` can be thought
|
||||
# of as modifying the line spacing, and `offset.x` as modifying the letter
|
||||
# spacing.
|
||||
#offset:
|
||||
# x: 0
|
||||
# y: 0
|
||||
|
||||
# Glyph offset determines the locations of the glyphs within their cells with
|
||||
# the default being at the bottom. Increasing `x` moves the glyph to the
|
||||
# right, increasing `y` moves the glyph upward.
|
||||
#glyph_offset:
|
||||
# x: 0
|
||||
# y: 0
|
||||
|
||||
# Thin stroke font rendering (macOS only)
|
||||
# # The `style` can be specified to pick a specific face.
|
||||
# style: Bold
|
||||
#
|
||||
# Thin strokes are suitable for retina displays, but for non-retina screens
|
||||
# it is recommended to set `use_thin_strokes` to `false`.
|
||||
#use_thin_strokes: true
|
||||
# # Italic font face
|
||||
# italic:
|
||||
# # Font family
|
||||
# #
|
||||
# # If the italic family is not specified, it will fall back to the
|
||||
# # value specified for the normal font.
|
||||
# family: Source Code Pro
|
||||
#
|
||||
# # The `style` can be specified to pick a specific face.
|
||||
# style: Italic
|
||||
#
|
||||
# # Bold italic font face
|
||||
# bold_italic:
|
||||
# # Font family
|
||||
# #
|
||||
# # If the bold italic family is not specified, it will fall back to the
|
||||
# # value specified for the normal font.
|
||||
# family: Source Code Pro
|
||||
#
|
||||
# # The `style` can be specified to pick a specific face.
|
||||
# style: Bold Italic
|
||||
#
|
||||
# # Point size
|
||||
# size: 6.3
|
||||
#
|
||||
# # Offset is the extra space around each character. `offset.y` can be thought
|
||||
# # of as modifying the line spacing, and `offset.x` as modifying the letter
|
||||
# # spacing.
|
||||
# #offset:
|
||||
# # x: 0
|
||||
# # y: 0
|
||||
#
|
||||
# # Glyph offset determines the locations of the glyphs within their cells with
|
||||
# # the default being at the bottom. Increasing `x` moves the glyph to the
|
||||
# # right, increasing `y` moves the glyph upward.
|
||||
# #glyph_offset:
|
||||
# # x: 0
|
||||
# # y: 0
|
||||
#
|
||||
# # Thin stroke font rendering (macOS only)
|
||||
# #
|
||||
# # Thin strokes are suitable for retina displays, but for non-retina screens
|
||||
# # it is recommended to set `use_thin_strokes` to `false`.
|
||||
# #use_thin_strokes: true
|
||||
|
||||
# If `true`, bold text is drawn using the bright color variants.
|
||||
#draw_bold_text_with_bright_colors: false
|
||||
@ -849,54 +855,7 @@ colors:
|
||||
# - Info
|
||||
# - Debug
|
||||
# - Trace
|
||||
#log_level: Trace
|
||||
#log_level: Warn
|
||||
|
||||
# Print all received window events.
|
||||
#print_events: false
|
||||
|
||||
# Hints
|
||||
#
|
||||
# Terminal hints can be used to find text or hyperlink in the visible part of
|
||||
# the terminal and pipe it to other applications.
|
||||
#hints:
|
||||
# Keys used for the hint labels.
|
||||
#alphabet: "jfkdls;ahgurieowpq"
|
||||
|
||||
# List with all available hints
|
||||
#
|
||||
# Each hint must have any of `regex` or `hyperlinks` field and either an
|
||||
# `action` or a `command` field. The fields `mouse`, `binding` and
|
||||
# `post_processing` are optional.
|
||||
#
|
||||
# The `hyperlinks` option will cause OSC 8 escape sequence hyperlinks to be
|
||||
# highlighted.
|
||||
#
|
||||
# The fields `command`, `binding.key`, `binding.mods`, `binding.mode` and
|
||||
# `mouse.mods` accept the same values as they do in the `key_bindings` section.
|
||||
#
|
||||
# The `mouse.enabled` field controls if the hint should be underlined while
|
||||
# the mouse with all `mouse.mods` keys held or the vi mode cursor is above it.
|
||||
#
|
||||
# If the `post_processing` field is set to `true`, heuristics will be used to
|
||||
# shorten the match if there are characters likely not to be part of the hint
|
||||
# (e.g. a trailing `.`). This is most useful for URIs and applies only to
|
||||
# `regex` matches.
|
||||
#
|
||||
# Values for `action`:
|
||||
# - Copy
|
||||
# Copy the hint's text to the clipboard.
|
||||
# - Paste
|
||||
# Paste the hint's text to the terminal or search.
|
||||
# - Select
|
||||
# Select the hint's text.
|
||||
# - MoveViModeCursor
|
||||
# Move the vi mode cursor to the beginning of the hint.
|
||||
#enabled:
|
||||
# - regex: "(ipfs:|ipns:|magnet:|mailto:|gemini:|gopher:|https:|http:|news:|file:|git:|ssh:|ftp:)[^\u0000-\u001F\u007F-\u009F<>\"\\s{-}\\^⟨⟩`]+"
|
||||
# hyperlinks: true
|
||||
# command: xdg-open
|
||||
# post_processing: true
|
||||
# mouse:
|
||||
# enabled: true
|
||||
# mods: None
|
||||
hints: $HINTS
|
||||
|
@ -1,49 +1,35 @@
|
||||
{
|
||||
|
||||
config,
|
||||
|
||||
pkgs ? (import ../pkgs.nix).stable2305 {},
|
||||
pkgs ? (import ../pkgs.nix) {},
|
||||
zsh ? pkgs.zsh,
|
||||
|
||||
}: rec {
|
||||
|
||||
defaultXDGOpenRules = [
|
||||
{
|
||||
name = "open-url";
|
||||
pattern = "(ipfs:|ipns:|magnet:|mailto:|gemini:|gopher:|https:|http:|news:|file:|git:|ssh:|ftp:)[^<>\"\\s{-}\\^⟨⟩`]+";
|
||||
xdgOpen = "$1";
|
||||
}
|
||||
];
|
||||
# TODO figure out a way to provide my font to alacritty at runtime. fontconfig
|
||||
# is a hot mess...
|
||||
#
|
||||
#dataDir = pkgs.stdenv.mkDerivation {
|
||||
# name = "alacritty-dataDir";
|
||||
# src = ./fonts;
|
||||
# buildInputs = [ pkgs.fontconfig ];
|
||||
# builder = builtins.toFile "builder.sh" ''
|
||||
# source $stdenv/setup
|
||||
# mkdir "$out"
|
||||
# cp -r "$src" "$out"/fonts
|
||||
# chmod -R +w "$out"
|
||||
|
||||
xdgOpenRules = defaultXDGOpenRules ++ config.alacritty.xdgOpenRules;
|
||||
# env
|
||||
|
||||
hints = {
|
||||
enabled = (builtins.map (r:
|
||||
{
|
||||
regex = r.pattern;
|
||||
hyperlinks = true;
|
||||
command = (pkgs.writeShellScript "alacritty-hints-${r.name}" ''
|
||||
xdg-open "${r.xdgOpen}"
|
||||
'');
|
||||
post_processing = true;
|
||||
mouse.enabled = true;
|
||||
}
|
||||
) xdgOpenRules);
|
||||
};
|
||||
# export FONTCONFIG_FILE="$out"/fontconfig
|
||||
# fc-cache --verbose "$out"/fonts
|
||||
|
||||
configFile = pkgs.writeText "alacritty-config" (
|
||||
builtins.replaceStrings
|
||||
["$HINTS"]
|
||||
[(builtins.toJSON hints)]
|
||||
(builtins.readFile ./alacritty.yml)
|
||||
);
|
||||
# '';
|
||||
#};
|
||||
|
||||
alacritty = pkgs.writeScriptBin "alacritty" ''
|
||||
#!${pkgs.bash}/bin/bash
|
||||
|
||||
exec ${pkgs.nixgl}/bin/nixGL ${pkgs.alacritty}/bin/alacritty \
|
||||
-o font.size=${builtins.toString config.alacritty.fontSize} \
|
||||
--config-file ${configFile} \
|
||||
exec ${pkgs.nixgl}/bin/nixGLIntel ${pkgs.alacritty}/bin/alacritty \
|
||||
--config-file ${./alacritty.yml} \
|
||||
-e "${zsh}/bin/zsh"
|
||||
'';
|
||||
}
|
||||
|
BIN
alacritty/fonts/SourceCodePro-Black.ttf
Normal file
BIN
alacritty/fonts/SourceCodePro-Bold.ttf
Normal file
BIN
alacritty/fonts/SourceCodePro-ExtraLight.ttf
Normal file
BIN
alacritty/fonts/SourceCodePro-Light.ttf
Normal file
BIN
alacritty/fonts/SourceCodePro-Medium.ttf
Normal file
BIN
alacritty/fonts/SourceCodePro-Regular.ttf
Normal file
BIN
alacritty/fonts/SourceCodePro-Semibold.ttf
Normal file
17
appimage.nix
Normal file
@ -0,0 +1,17 @@
|
||||
{
|
||||
|
||||
pkgsSrc ? ./pkgs.nix,
|
||||
|
||||
}: let
|
||||
|
||||
nixBundle = builtins.fetchGit {
|
||||
url = "https://github.com/matthewbauer/nix-bundle.git";
|
||||
rev = "223f4ffc4179aa318c34dc873a08cb00090db829";
|
||||
};
|
||||
|
||||
appimageTop = (import "${nixBundle}/appimage-top.nix") {
|
||||
nixpkgs' = pkgsSrc;
|
||||
};
|
||||
|
||||
in { name, target }:
|
||||
appimageTop.appimage (appimageTop.appdir { inherit name target; })
|
9
awesome/awesome.desktop
Normal file
@ -0,0 +1,9 @@
|
||||
# For use in ubuntu, just copy into /usr/share/xsessions
|
||||
|
||||
[Desktop Entry]
|
||||
Name=awesome
|
||||
Comment=Highly configurable framework window manager
|
||||
Exec=/home/mediocregopher/.nix-profile/bin/awesome
|
||||
Type=Application
|
||||
Icon=/usr/share/pixmaps/awesome.xpm
|
||||
Keywords=Window manager
|
43
awesome/bat.lua
Normal file
@ -0,0 +1,43 @@
|
||||
local io = io
|
||||
local math = math
|
||||
local tonumber = tonumber
|
||||
local string = string
|
||||
local naughty = require("naughty")
|
||||
|
||||
function batteryInfo()
|
||||
for i=0,1 do
|
||||
local dir = "/sys/class/power_supply/BAT" .. tostring(i) .. "/"
|
||||
local f_status = io.popen("cat " .. dir .. "status 2>/dev/null")
|
||||
local c_status = f_status:read()
|
||||
f_status:close()
|
||||
|
||||
if c_status and c_status ~= "" then
|
||||
local prefix = "energy"
|
||||
local f_now = io.popen("cat " .. dir .. prefix .. "_now 2>/dev/null")
|
||||
local c_now_str = f_now:read()
|
||||
f_now:close()
|
||||
|
||||
if not c_now_str or c_now_str == "" then
|
||||
prefix = "charge"
|
||||
local f_now = io.popen("cat " .. dir .. prefix .. "_now")
|
||||
c_now_str = f_now:read()
|
||||
f_now:close()
|
||||
end
|
||||
|
||||
local f_full = io.popen("cat " .. dir .. prefix .. "_full")
|
||||
local c_full_str = f_full:read()
|
||||
f_full:close()
|
||||
|
||||
local c_now = tonumber(c_now_str)
|
||||
local c_full = tonumber(c_full_str)
|
||||
|
||||
local charging = (c_status == "Charging" or c_status == "Full")
|
||||
|
||||
if c_now ~= nil and c_full ~= nil then
|
||||
local percent = math.floor((c_now/c_full) * 100)
|
||||
return percent, charging
|
||||
end
|
||||
end
|
||||
end
|
||||
return nil, charging
|
||||
end
|
BIN
awesome/bin/cricket
Executable file
4
awesome/bin/scrot-gobin.sh
Executable file
@ -0,0 +1,4 @@
|
||||
#!/bin/sh
|
||||
|
||||
scrot -o -s "/tmp/shot.png"
|
||||
eog /tmp/shot.png
|
@ -1,7 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
set -e
|
||||
mkdir -p ~/Screenshots
|
||||
f="$HOME/Screenshots/shot-$(date +%s).png"
|
||||
scrot -o -s "$f"
|
||||
feh "$f"
|
50
awesome/bin/sysstats.sh
Executable file
@ -0,0 +1,50 @@
|
||||
#!/bin/bash
|
||||
|
||||
cd $(dirname "$0")
|
||||
|
||||
sep=" | "
|
||||
|
||||
out=$(/home/mediocregopher/.config/awesome/bin/cricket \
|
||||
--limit 1 \
|
||||
--ping-hosts 8.8.8.8 \
|
||||
--net-interval "" \
|
||||
--disk-interval "" \
|
||||
--disk-io-interval "")
|
||||
|
||||
function outNum {
|
||||
echo "$out" | grep "$1" | grep -oP "$2=\"[0-9]+\"" | grep -oP '[0-9]+'
|
||||
}
|
||||
|
||||
echo -n "ping:$(outNum "ping result" "tookMSAvg")ms"
|
||||
|
||||
echo -n "$sep"
|
||||
|
||||
memBarSize=10
|
||||
memPer=$(outNum "mem stats" "memUsedPer")
|
||||
memUsed=$(expr $memPer / $memBarSize)
|
||||
memUnused=$(expr $memBarSize - $memUsed)
|
||||
echo -n "mem:"
|
||||
for i in $(seq $memUsed); do echo -n "█"; done
|
||||
for i in $(seq $memUnused); do echo -n "░"; done
|
||||
for i in $(seq $(expr $memBarSize - $memUsed - $memUnused)); do echo -n "░"; done
|
||||
|
||||
echo -n "$sep"
|
||||
|
||||
cpuBarSize=20
|
||||
cpuIdle=$(outNum "cpu stats" "cpuIdle")
|
||||
cpuSys=$(outNum "cpu stats" "cpuSystem")
|
||||
cpuUser=$(outNum "cpu stats" "cpuUser")
|
||||
cpuTot=$(expr $cpuIdle + $cpuSys + $cpuUser)
|
||||
function cpuL {
|
||||
python -c "print(int($1 / $cpuTot * $cpuBarSize))"
|
||||
}
|
||||
cpuLIdle=$(cpuL $cpuIdle)
|
||||
cpuLSys=$(cpuL $cpuSys)
|
||||
cpuLUser=$(cpuL $cpuUser)
|
||||
echo -n "cpu:"
|
||||
for i in $(seq $cpuLUser); do echo -n "█"; done
|
||||
for i in $(seq $cpuLSys); do echo -n "▓"; done
|
||||
for i in $(seq $cpuLIdle); do echo -n "░"; done
|
||||
for i in $(seq $(expr $cpuBarSize - $cpuLIdle - $cpuLSys - $cpuLUser)); do echo -n "░"; done
|
||||
|
||||
echo ""
|
@ -1,3 +0,0 @@
|
||||
file:///tmp
|
||||
file:///home/mediocregopher/Screenshots
|
||||
file:///home/mediocregopher/Downloads
|
@ -1,2 +0,0 @@
|
||||
[Settings]
|
||||
gtk-icon-theme-name = Tela
|
@ -1,122 +1,29 @@
|
||||
{
|
||||
|
||||
config,
|
||||
|
||||
pkgs ? (import ../pkgs.nix) {},
|
||||
|
||||
}: rec {
|
||||
|
||||
pkgs = (import ../pkgs.nix).stable {};
|
||||
pkgs2305 = (import ../pkgs.nix).stable2305 {};
|
||||
pkgsEdge = (import ../pkgs.nix).edge {};
|
||||
|
||||
# nativeWrap is used for apps which are not installed via nix which don't play
|
||||
# nicely with it.
|
||||
nativeWrap = pkgs.writeScriptBin "native-wrap" ''
|
||||
#!${pkgs.bash}/bin/bash
|
||||
|
||||
unset XDG_CONFIG_DIRS
|
||||
unset XDG_DATA_DIRS
|
||||
unset GDK_PIXBUF_MODULE_FILE
|
||||
|
||||
exec "$@"
|
||||
'';
|
||||
|
||||
browser = pkgs.writeScriptBin "browser" ''
|
||||
#!${pkgs.bash}/bin/bash
|
||||
exec ${nativeWrap}/bin/native-wrap ${config.browser} "$@"
|
||||
'';
|
||||
|
||||
env = pkgs.buildEnv {
|
||||
name = "awesome-env";
|
||||
paths = [
|
||||
|
||||
pkgs.awesome
|
||||
pkgs.tela-icon-theme
|
||||
|
||||
nativeWrap
|
||||
browser
|
||||
|
||||
pkgs.xorg.xrandr
|
||||
pkgs.xsel
|
||||
pkgs.pavucontrol
|
||||
pkgs.xdg-utils
|
||||
pkgs.arandr
|
||||
|
||||
pkgs.i3lock
|
||||
pkgs.scrot
|
||||
pkgs.feh
|
||||
pkgs.brightnessctl
|
||||
|
||||
pkgs.cbatticon
|
||||
pkgs.phwmon
|
||||
|
||||
pkgs.castor
|
||||
pkgs2305.libreoffice
|
||||
pkgs.gimp
|
||||
pkgs.inkscape
|
||||
pkgs.vlc
|
||||
pkgs.sylpheed
|
||||
|
||||
pkgsEdge.lagrange
|
||||
];
|
||||
};
|
||||
|
||||
cfg = ./.;
|
||||
wp = ../wallpapers;
|
||||
|
||||
dirsLua = pkgs.writeTextDir "dirs.lua" ''
|
||||
home_dir = os.getenv("HOME").."/"
|
||||
bin_dir = "${./bin}/"
|
||||
share_dir = "${./share}/"
|
||||
conf_dir = "${cfg}/"
|
||||
wp_dir = "${wp}/"
|
||||
'';
|
||||
|
||||
awesome = pkgs.writeScriptBin "awesome" ''
|
||||
#!${pkgs.bash}/bin/bash
|
||||
|
||||
export BROWSER=${browser}/bin/browser
|
||||
export BROWSER=/usr/bin/google-chrome
|
||||
|
||||
# Turn off powersaving (fuck the environment)
|
||||
xset -dpms
|
||||
xset s off
|
||||
|
||||
export PATH=${env}/bin:$PATH
|
||||
|
||||
export XDG_CONFIG_DIRS=${./config}
|
||||
|
||||
export XDG_DATA_DIRS=${env}/share
|
||||
export XDG_DATA_DIRS=$XDG_DATA_DIRS:/home/mediocregopher/.nix-profile/share
|
||||
|
||||
${config.awesome.startupExtra}
|
||||
|
||||
# HACK: This sleep is here because phwmon actually creates a separate tray
|
||||
# icon for each thing it monitors, and if the process runs at the same time
|
||||
# as another process which creates a tray icon they can get interleaved.
|
||||
(sleep 5 && phwmon.py) &
|
||||
|
||||
############################################################################
|
||||
# Init awesome
|
||||
|
||||
data_dir="$HOME/.local/share/awesome";
|
||||
mkdir -p "$dataDir"
|
||||
|
||||
log_dir="$data_dir"/logs
|
||||
mkdir -p $log_dir
|
||||
|
||||
# only keep last N awesome.log files
|
||||
ls "$log_dir" | sort -n | head -n -5 | while read f; do rm "$log_dir"/"$f"; done
|
||||
|
||||
############################################################################
|
||||
# Exec
|
||||
|
||||
this_log=$log_dir/awesome.$(date '+%Y%m%d.%H%M%S').log
|
||||
|
||||
echo "New awesome session starting" > $this_log
|
||||
|
||||
exec awesome \
|
||||
-c ${./rc.lua} \
|
||||
echo "[$(date)] New awesome session starting" > ~/.awesome.log
|
||||
exec ${pkgs.awesome}/bin/awesome \
|
||||
-c ${cfg}/rc.lua \
|
||||
--search ${dirsLua} \
|
||||
--search ${./share} \
|
||||
--search ${env}/share/awesome/themes \
|
||||
2>&1 2>>$this_log
|
||||
--search ${cfg} \
|
||||
2>&1 2>>~/.awesome.log
|
||||
'';
|
||||
|
||||
}
|
||||
|
Before Width: | Height: | Size: 26 KiB After Width: | Height: | Size: 26 KiB |
13
awesome/mediocregopher-sysstats.service
Normal file
@ -0,0 +1,13 @@
|
||||
[Unit]
|
||||
Description=mediocregopher's sysstats
|
||||
Requires=network.target
|
||||
After=network.target
|
||||
|
||||
[Service]
|
||||
Restart=always
|
||||
RestartSec=1s
|
||||
User=mediocregopher
|
||||
ExecStart=/bin/bash -c 'while [ 1 ]; do out=$(~/.config/awesome/bin/sysstats.sh); echo "$out" > /tmp/sysstats; sleep 1; done'
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
117
awesome/rc.lua
@ -1,6 +1,7 @@
|
||||
-- Standard awesome library
|
||||
local gears = require("gears")
|
||||
local awful = require("awful")
|
||||
awful.rules = require("awful.rules")
|
||||
require("awful.autofocus")
|
||||
-- Widget and layout library
|
||||
local wibox = require("wibox")
|
||||
@ -18,13 +19,17 @@ local function info(msg)
|
||||
end
|
||||
|
||||
require("dirs")
|
||||
require("bat")
|
||||
require("pulseaudio")
|
||||
muteAll() -- pre-emptively mute all mics, just in-case
|
||||
|
||||
-- for sanity
|
||||
local home_dir = os.getenv("HOME").."/"
|
||||
|
||||
-- {{{ Naughty config (the notification library)
|
||||
naughty.config.defaults.position = "bottom_right"
|
||||
naughty.config.defaults.width = 250
|
||||
naughty.config.defaults.icon=share_dir .. "helper.png"
|
||||
naughty.config.defaults.icon=conf_dir .. "helper.png"
|
||||
naughty.config.defaults.icon_size = 75
|
||||
-- }}}
|
||||
|
||||
@ -62,15 +67,15 @@ local beautiful = require("beautiful")
|
||||
function rand_wp()
|
||||
local ls = io.popen("ls " .. wp_dir .. " | shuf -n1")
|
||||
local wp = ls:read("*l")
|
||||
return wp_dir .. wp
|
||||
return wp_dir .. '/' .. wp
|
||||
end
|
||||
|
||||
function rand_wp_lock()
|
||||
awful.spawn(bin_dir.."random_i3lock.sh "..wp_dir, false)
|
||||
awful.spawn(conf_dir.."bin/random_i3lock.sh "..wp_dir, false)
|
||||
end
|
||||
|
||||
local wp = rand_wp()
|
||||
local imgavg = io.popen("cat " .. wp .. " | " .. bin_dir .. "imgavg")
|
||||
local imgavg = io.popen("cat " .. wp .. " | " .. conf_dir .. "/bin/imgavg")
|
||||
local avgcolor = imgavg:read()
|
||||
local comcolor = imgavg:read()
|
||||
imgavg:close()
|
||||
@ -80,7 +85,7 @@ for s = 1, screen.count() do
|
||||
end
|
||||
-- }}}
|
||||
|
||||
require("theme")
|
||||
require("theme/theme")
|
||||
local theme = load_theme(avgcolor, comcolor)
|
||||
beautiful.init(theme)
|
||||
|
||||
@ -130,6 +135,48 @@ menubar.utils.terminal = terminal -- Set the terminal for applications that requ
|
||||
|
||||
-- {{{ Wibox
|
||||
|
||||
-- {{{ Battery widget
|
||||
local battimerintvl = 4
|
||||
batwidget = wibox.widget.textbox("")
|
||||
battimer = gears.timer({ timeout = battimerintvl })
|
||||
battimer:connect_signal("timeout",
|
||||
function()
|
||||
local batlevel, charging = batteryInfo()
|
||||
if batlevel == nil then batlevel = "unk"
|
||||
elseif (tonumber(batlevel) < 10) then
|
||||
naughty.notify({
|
||||
preset = naughty.config.presets.critical,
|
||||
title="ALERT",
|
||||
text="BATTERY LEVEL LOW",
|
||||
timeout=battimerintvl-1,
|
||||
})
|
||||
end
|
||||
if charging then
|
||||
batwidget:set_markup('bat:'..batlevel)
|
||||
else
|
||||
batwidget:set_markup('<b>bat:'..batlevel..'</b>')
|
||||
end
|
||||
end)
|
||||
battimer:start()
|
||||
-- }}}
|
||||
|
||||
-- {{{ sysstats widget
|
||||
sysstatswidget = wibox.widget.textbox("")
|
||||
sysstatstimer = gears.timer({ timeout = 1 })
|
||||
sysstatstimer:connect_signal("timeout",
|
||||
function()
|
||||
local sysstats = "??? STATS ???"
|
||||
local f_sysstats = io.open("/tmp/sysstats")
|
||||
if f_sysstats then
|
||||
c_sysstats = f_sysstats:read()
|
||||
f_sysstats:close()
|
||||
if c_sysstats then sysstats = c_sysstats end
|
||||
end
|
||||
sysstatswidget:set_markup(sysstats)
|
||||
end)
|
||||
sysstatstimer:start()
|
||||
-- }}}
|
||||
|
||||
-- {{{ notifier for when my mic isn't muted
|
||||
local unmuteNot
|
||||
mutechecktimer = gears.timer({ timeout = 0.5 })
|
||||
@ -233,6 +280,10 @@ for s = 1, screen.count() do
|
||||
-- Widgets that are aligned to the right
|
||||
local right_sep = " | "
|
||||
local right_layout = wibox.layout.fixed.horizontal()
|
||||
--right_layout:add(wibox.widget.textbox(right_sep))
|
||||
right_layout:add(sysstatswidget)
|
||||
right_layout:add(wibox.widget.textbox(right_sep))
|
||||
right_layout:add(batwidget)
|
||||
right_layout:add(wibox.widget.textbox(right_sep))
|
||||
right_layout:add(wibox.widget.systray())
|
||||
right_layout:add(wibox.widget.textbox(right_sep))
|
||||
@ -330,7 +381,7 @@ globalkeys = awful.util.table.join(
|
||||
end),
|
||||
|
||||
--PrintScreen
|
||||
awful.key({}, "Print", false, function () awful.spawn(bin_dir.."scrot.sh",false) end),
|
||||
awful.key({}, "Print", false, function () awful.spawn(conf_dir.."bin/scrot-gobin.sh",false) end),
|
||||
awful.key({ "Control" }, "Print", function ()
|
||||
local scr_dir = home_dir..'Screenshots'
|
||||
awful.spawn("mkdir -p "..scr_dir, false)
|
||||
@ -356,11 +407,11 @@ globalkeys = awful.util.table.join(
|
||||
end),
|
||||
|
||||
awful.key( { }, "XF86MonBrightnessUp", function()
|
||||
awful.spawn("brightnessctl s +5%", false)
|
||||
awful.spawn("/usr/bin/xbacklight -inc 5", false)
|
||||
end),
|
||||
|
||||
awful.key( { }, "XF86MonBrightnessDown", function()
|
||||
awful.spawn("brightnessctl s 5%-", false)
|
||||
awful.spawn("/usr/bin/xbacklight -dec 5", false)
|
||||
end),
|
||||
|
||||
-- Push to talk
|
||||
@ -368,8 +419,10 @@ globalkeys = awful.util.table.join(
|
||||
awful.spawn("/usr/bin/pactl set-source-mute @DEFAULT_SOURCE@ 0")
|
||||
end,
|
||||
muteAll,
|
||||
{ }),
|
||||
{ })
|
||||
)
|
||||
|
||||
globalkeys = awful.util.table.join(globalkeys,
|
||||
awful.key( { modkey }, "a", function()
|
||||
info(tostring(os.time()))
|
||||
end)
|
||||
@ -388,24 +441,8 @@ clientkeys = awful.util.table.join(
|
||||
end),
|
||||
awful.key({ modkey, }, "m",
|
||||
function (c)
|
||||
if c.maximized then
|
||||
c.maximized = false
|
||||
else
|
||||
c.maximized_horizontal = not c.maximized_horizontal
|
||||
c.maximized_vertical = not c.maximized_vertical
|
||||
end
|
||||
end),
|
||||
|
||||
awful.key({ modkey }, "d", function (c)
|
||||
info(gears.debug.dump_return(c, "client"))
|
||||
info(gears.debug.dump_return({
|
||||
maximized = c.maximized,
|
||||
maximized_horizontal = c.maximized_horizontal,
|
||||
maximized_vertical = c.maximized_vertical,
|
||||
motif_wm_hints = c.motif_wm_hints,
|
||||
is_fixed = c.is_fixed(),
|
||||
immobilized = c.immobilized
|
||||
}, "client_stuff"))
|
||||
end)
|
||||
)
|
||||
|
||||
@ -464,26 +501,16 @@ awful.rules.rules = {
|
||||
focus = awful.client.focus.filter,
|
||||
raise = true,
|
||||
keys = clientkeys,
|
||||
buttons = clientbuttons,
|
||||
screen = awful.screen.preferred,
|
||||
placement = awful.placement.no_overlap+awful.placement.no_offscreen
|
||||
}
|
||||
},
|
||||
|
||||
{ rule = { class = "firefox" },
|
||||
properties = { screen = 1, tag = "1" } },
|
||||
|
||||
{ rule = { class = "lagrange" },
|
||||
properties = { screen = 1, tag = "1" } },
|
||||
|
||||
{ rule = { class = "zoom" },
|
||||
properties = { screen = 1, tag = "5" } },
|
||||
|
||||
{ rule = { class = "Signal" },
|
||||
properties = { screen = 1, tag = "9" } },
|
||||
|
||||
{ rule = { class = "Sylpheed" },
|
||||
properties = { screen = 1, tag = "9" } },
|
||||
buttons = clientbuttons } },
|
||||
{ rule = { class = "MPlayer" },
|
||||
properties = { floating = true } },
|
||||
{ rule = { class = "pinentry" },
|
||||
properties = { floating = true } },
|
||||
{ rule = { class = "gimp" },
|
||||
properties = { floating = true } }
|
||||
-- Set Firefox to always map on tags number 2 of screen 1.
|
||||
-- { rule = { class = "Firefox" },
|
||||
-- properties = { tag = tags[1][2] } },
|
||||
}
|
||||
-- }}}
|
||||
|
||||
|
@ -1,22 +0,0 @@
|
||||
function load_theme(avgcolor, comcolor)
|
||||
|
||||
local theme = require("default/theme")
|
||||
|
||||
if avgcolor then
|
||||
theme.bg_normal = avgcolor
|
||||
theme.bg_focus = theme.bg_normal
|
||||
theme.bg_urgent = "#ff0000" -- TODO should be opposite of bg_normal
|
||||
theme.bg_minimize = theme.bg_normal
|
||||
theme.bg_systray = theme.bg_normal
|
||||
end
|
||||
|
||||
if comcolor then
|
||||
theme.fg_normal = comcolor
|
||||
theme.fg_focus = comcolor
|
||||
theme.fg_urgent = "#ffffff"
|
||||
theme.fg_minimize = comcolor
|
||||
end
|
||||
|
||||
return theme
|
||||
|
||||
end
|
3
awesome/theme/README
Normal file
@ -0,0 +1,3 @@
|
||||
Background images:
|
||||
Mikael Eriksson <mikael_eriksson@miffe.org>
|
||||
Licensed under CC-BY-SA-3.0
|
BIN
awesome/theme/background.png
Normal file
After Width: | Height: | Size: 220 KiB |
BIN
awesome/theme/background_white.png
Normal file
After Width: | Height: | Size: 265 KiB |
BIN
awesome/theme/layouts/dwindle.png
Normal file
After Width: | Height: | Size: 967 B |
BIN
awesome/theme/layouts/dwindlew.png
Normal file
After Width: | Height: | Size: 997 B |
BIN
awesome/theme/layouts/fairh.png
Normal file
After Width: | Height: | Size: 194 B |
BIN
awesome/theme/layouts/fairhw.png
Normal file
After Width: | Height: | Size: 194 B |
BIN
awesome/theme/layouts/fairv.png
Normal file
After Width: | Height: | Size: 201 B |
BIN
awesome/theme/layouts/fairvw.png
Normal file
After Width: | Height: | Size: 201 B |
BIN
awesome/theme/layouts/floating.png
Normal file
After Width: | Height: | Size: 395 B |
BIN
awesome/theme/layouts/floatingw.png
Normal file
After Width: | Height: | Size: 388 B |
BIN
awesome/theme/layouts/fullscreen.png
Normal file
After Width: | Height: | Size: 202 B |
BIN
awesome/theme/layouts/fullscreenw.png
Normal file
After Width: | Height: | Size: 202 B |
BIN
awesome/theme/layouts/magnifier.png
Normal file
After Width: | Height: | Size: 209 B |
BIN
awesome/theme/layouts/magnifierw.png
Normal file
After Width: | Height: | Size: 209 B |
BIN
awesome/theme/layouts/max.png
Normal file
After Width: | Height: | Size: 321 B |
BIN
awesome/theme/layouts/maxw.png
Normal file
After Width: | Height: | Size: 321 B |
BIN
awesome/theme/layouts/spiral.png
Normal file
After Width: | Height: | Size: 1.5 KiB |
BIN
awesome/theme/layouts/spiralw.png
Normal file
After Width: | Height: | Size: 1.5 KiB |
BIN
awesome/theme/layouts/tile.png
Normal file
After Width: | Height: | Size: 174 B |
BIN
awesome/theme/layouts/tilebottom.png
Normal file
After Width: | Height: | Size: 195 B |
BIN
awesome/theme/layouts/tilebottomw.png
Normal file
After Width: | Height: | Size: 216 B |
BIN
awesome/theme/layouts/tileleft.png
Normal file
After Width: | Height: | Size: 172 B |
BIN
awesome/theme/layouts/tileleftw.png
Normal file
After Width: | Height: | Size: 170 B |
BIN
awesome/theme/layouts/tiletop.png
Normal file
After Width: | Height: | Size: 195 B |
BIN
awesome/theme/layouts/tiletopw.png
Normal file
After Width: | Height: | Size: 215 B |
BIN
awesome/theme/layouts/tilew.png
Normal file
After Width: | Height: | Size: 168 B |
BIN
awesome/theme/submenu.png
Normal file
After Width: | Height: | Size: 440 B |
BIN
awesome/theme/taglist/squarefw.png
Normal file
After Width: | Height: | Size: 187 B |
BIN
awesome/theme/taglist/squarew.png
Normal file
After Width: | Height: | Size: 193 B |
105
awesome/theme/theme.lua
Normal file
@ -0,0 +1,105 @@
|
||||
---------------------------
|
||||
-- Default awesome theme --
|
||||
---------------------------
|
||||
|
||||
function load_theme(avgcolor, comcolor)
|
||||
if not avgcolor then avgcolor = "#000000" end
|
||||
if not comcolor then comcolor = "#FFFFFF" end
|
||||
|
||||
local theme = {}
|
||||
|
||||
theme.font = "sans 8"
|
||||
|
||||
--theme.bg_normal = "#222222"
|
||||
theme.bg_normal = avgcolor
|
||||
theme.bg_focus = theme.bg_normal
|
||||
theme.bg_urgent = "#ff0000" -- TODO should be opposite of bg_normal
|
||||
theme.bg_minimize = theme.bg_normal
|
||||
theme.bg_systray = theme.bg_normal
|
||||
|
||||
|
||||
--theme.fg_normal = "#aaaaaa"
|
||||
theme.fg_normal = comcolor
|
||||
theme.fg_focus = comcolor
|
||||
theme.fg_urgent = "#ffffff"
|
||||
theme.fg_minimize = comcolor
|
||||
|
||||
theme.border_width = 1
|
||||
theme.border_normal = "#000000"
|
||||
theme.border_focus = "#535d6c"
|
||||
theme.border_marked = "#91231c"
|
||||
|
||||
-- There are other variable sets
|
||||
-- overriding the default one when
|
||||
-- defined, the sets are:
|
||||
-- [taglist|tasklist]_[bg|fg]_[focus|urgent]
|
||||
-- titlebar_[bg|fg]_[normal|focus]
|
||||
-- tooltip_[font|opacity|fg_color|bg_color|border_width|border_color]
|
||||
-- mouse_finder_[color|timeout|animate_timeout|radius|factor]
|
||||
-- Example:
|
||||
--theme.taglist_bg_focus = "#ff0000"
|
||||
|
||||
-- Display the taglist squares
|
||||
theme.taglist_squares_sel = "/usr/share/awesome/themes/default/taglist/squarefw.png"
|
||||
theme.taglist_squares_unsel = "/usr/share/awesome/themes/default/taglist/squarew.png"
|
||||
|
||||
-- Variables set for theming the menu:
|
||||
-- menu_[bg|fg]_[normal|focus]
|
||||
-- menu_[border_color|border_width]
|
||||
theme.menu_submenu_icon = "/usr/share/awesome/themes/default/submenu.png"
|
||||
theme.menu_height = 15
|
||||
theme.menu_width = 100
|
||||
|
||||
-- You can add as many variables as
|
||||
-- you wish and access them by using
|
||||
-- beautiful.variable in your rc.lua
|
||||
--theme.bg_widget = "#cc0000"
|
||||
|
||||
-- Define the image to load
|
||||
theme.titlebar_close_button_normal = "/usr/share/awesome/themes/default/titlebar/close_normal.png"
|
||||
theme.titlebar_close_button_focus = "/usr/share/awesome/themes/default/titlebar/close_focus.png"
|
||||
|
||||
theme.titlebar_ontop_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/ontop_normal_inactive.png"
|
||||
theme.titlebar_ontop_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/ontop_focus_inactive.png"
|
||||
theme.titlebar_ontop_button_normal_active = "/usr/share/awesome/themes/default/titlebar/ontop_normal_active.png"
|
||||
theme.titlebar_ontop_button_focus_active = "/usr/share/awesome/themes/default/titlebar/ontop_focus_active.png"
|
||||
|
||||
theme.titlebar_sticky_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/sticky_normal_inactive.png"
|
||||
theme.titlebar_sticky_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/sticky_focus_inactive.png"
|
||||
theme.titlebar_sticky_button_normal_active = "/usr/share/awesome/themes/default/titlebar/sticky_normal_active.png"
|
||||
theme.titlebar_sticky_button_focus_active = "/usr/share/awesome/themes/default/titlebar/sticky_focus_active.png"
|
||||
|
||||
theme.titlebar_floating_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/floating_normal_inactive.png"
|
||||
theme.titlebar_floating_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/floating_focus_inactive.png"
|
||||
theme.titlebar_floating_button_normal_active = "/usr/share/awesome/themes/default/titlebar/floating_normal_active.png"
|
||||
theme.titlebar_floating_button_focus_active = "/usr/share/awesome/themes/default/titlebar/floating_focus_active.png"
|
||||
|
||||
theme.titlebar_maximized_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/maximized_normal_inactive.png"
|
||||
theme.titlebar_maximized_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/maximized_focus_inactive.png"
|
||||
theme.titlebar_maximized_button_normal_active = "/usr/share/awesome/themes/default/titlebar/maximized_normal_active.png"
|
||||
theme.titlebar_maximized_button_focus_active = "/usr/share/awesome/themes/default/titlebar/maximized_focus_active.png"
|
||||
|
||||
theme.wallpaper = "/usr/share/awesome/themes/default/background.png"
|
||||
|
||||
-- You can use your own layout icons like this:
|
||||
theme.layout_fairh = "/usr/share/awesome/themes/default/layouts/fairhw.png"
|
||||
theme.layout_fairv = "/usr/share/awesome/themes/default/layouts/fairvw.png"
|
||||
theme.layout_floating = "/usr/share/awesome/themes/default/layouts/floatingw.png"
|
||||
theme.layout_magnifier = "/usr/share/awesome/themes/default/layouts/magnifierw.png"
|
||||
theme.layout_max = "/usr/share/awesome/themes/default/layouts/maxw.png"
|
||||
theme.layout_fullscreen = "/usr/share/awesome/themes/default/layouts/fullscreenw.png"
|
||||
theme.layout_tilebottom = "/usr/share/awesome/themes/default/layouts/tilebottomw.png"
|
||||
theme.layout_tileleft = "/usr/share/awesome/themes/default/layouts/tileleftw.png"
|
||||
theme.layout_tile = "/usr/share/awesome/themes/default/layouts/tilew.png"
|
||||
theme.layout_tiletop = "/usr/share/awesome/themes/default/layouts/tiletopw.png"
|
||||
theme.layout_spiral = "/usr/share/awesome/themes/default/layouts/spiralw.png"
|
||||
theme.layout_dwindle = "/usr/share/awesome/themes/default/layouts/dwindlew.png"
|
||||
|
||||
theme.awesome_icon = "/usr/share/awesome/icons/awesome16.png"
|
||||
|
||||
-- Define the icon theme for application icons. If not set then the icons
|
||||
-- from /usr/share/icons and /usr/share/icons/hicolor will be used.
|
||||
theme.icon_theme = nil
|
||||
|
||||
return theme
|
||||
end
|
BIN
awesome/theme/titlebar/close_focus.png
Normal file
After Width: | Height: | Size: 666 B |
BIN
awesome/theme/titlebar/close_normal.png
Normal file
After Width: | Height: | Size: 830 B |
BIN
awesome/theme/titlebar/floating_focus_active.png
Normal file
After Width: | Height: | Size: 598 B |
BIN
awesome/theme/titlebar/floating_focus_inactive.png
Normal file
After Width: | Height: | Size: 549 B |
BIN
awesome/theme/titlebar/floating_normal_active.png
Normal file
After Width: | Height: | Size: 814 B |
BIN
awesome/theme/titlebar/floating_normal_inactive.png
Normal file
After Width: | Height: | Size: 553 B |
BIN
awesome/theme/titlebar/maximized_focus_active.png
Normal file
After Width: | Height: | Size: 1013 B |
BIN
awesome/theme/titlebar/maximized_focus_inactive.png
Normal file
After Width: | Height: | Size: 754 B |
BIN
awesome/theme/titlebar/maximized_normal_active.png
Normal file
After Width: | Height: | Size: 1.5 KiB |
BIN
awesome/theme/titlebar/maximized_normal_inactive.png
Normal file
After Width: | Height: | Size: 740 B |
BIN
awesome/theme/titlebar/ontop_focus_active.png
Normal file
After Width: | Height: | Size: 774 B |
BIN
awesome/theme/titlebar/ontop_focus_inactive.png
Normal file
After Width: | Height: | Size: 679 B |
BIN
awesome/theme/titlebar/ontop_normal_active.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
BIN
awesome/theme/titlebar/ontop_normal_inactive.png
Normal file
After Width: | Height: | Size: 682 B |
BIN
awesome/theme/titlebar/sticky_focus_active.png
Normal file
After Width: | Height: | Size: 833 B |
BIN
awesome/theme/titlebar/sticky_focus_inactive.png
Normal file
After Width: | Height: | Size: 624 B |
BIN
awesome/theme/titlebar/sticky_normal_active.png
Normal file
After Width: | Height: | Size: 1.3 KiB |
BIN
awesome/theme/titlebar/sticky_normal_inactive.png
Normal file
After Width: | Height: | Size: 601 B |
@ -1,6 +0,0 @@
|
||||
Section "InputClass"
|
||||
Identifier "system-keyboard"
|
||||
MatchIsKeyboard "on"
|
||||
Option "XkbLayout" "us"
|
||||
Option "XkbOptions" "caps:swapescape"
|
||||
EndSection
|
@ -1,14 +1,7 @@
|
||||
[include]
|
||||
path = custom
|
||||
|
||||
[push]
|
||||
default = simple
|
||||
|
||||
[alias]
|
||||
# main-branch outputs 'main' if there is a main branch, otherwise it outputs
|
||||
# 'master'
|
||||
main-branch = "!if git rev-parse --verify main 2>1 >/dev/null; then echo 'main'; else echo 'master'; fi"
|
||||
|
||||
#Shows diff in log
|
||||
ll = log --stat --abbrev-commit
|
||||
|
||||
@ -22,16 +15,15 @@
|
||||
lug = log --color --graph --date=short --pretty=format:'%Cgreen%cd (%cr)%Creset %C(bold blue)%an%Creset %Cred%h%Creset -%C(yellow)%d%Creset %s' --abbrev-commit
|
||||
purr = pull --rebase
|
||||
chk = checkout
|
||||
from = !git fetch origin "$(git main-branch)" && git rebase -i origin/"$(git main-branch)"
|
||||
from = !git fetch origin master && git rebase -i origin/master
|
||||
|
||||
# print local branches and their last commit times
|
||||
blanch = for-each-ref --sort=authordate --format '%(HEAD)%(align:left,40)%(refname:short)%(end) | %(align:left,20)%(authordate:iso)%(end) | %(subject)' refs/heads
|
||||
|
||||
# checkout master/main and delete previously checked out branch
|
||||
close = !git checkout "$(git main-branch)" && git branch -D @{-1}
|
||||
# checkout master and delete previously checked out branch
|
||||
close = !git checkout master && git branch -D @{-1}
|
||||
|
||||
[color]
|
||||
branch = auto
|
||||
diff = auto
|
||||
status = auto
|
||||
|
||||
|
@ -1,9 +0,0 @@
|
||||
[Unit]
|
||||
Description=rm keyfile
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart=/bin/sh -c 'rm /boot/keyfile || true'
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
@ -1,16 +0,0 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
xrandr \
|
||||
--output eDP-1 \
|
||||
--primary \
|
||||
--mode 1920x1080 \
|
||||
--pos 0x0 \
|
||||
--rotate normal \
|
||||
--output DP-1 --off \
|
||||
--output HDMI-1 --off \
|
||||
--output DP-2 --off \
|
||||
--output HDMI-2 \
|
||||
--mode 1920x1080 \
|
||||
--pos 0x0 \
|
||||
--rotate normal \
|
||||
--brightness 0.9
|
921
bin/git-remote-gcrypt
Executable file
@ -0,0 +1,921 @@
|
||||
#!/bin/sh
|
||||
|
||||
# git-remote-gcrypt
|
||||
#
|
||||
# Copyright (c) 2013 engla
|
||||
# Copyright (c) 2013, 2014 Joey Hess <id@joeyh.name>
|
||||
# Copyright (c) 2016 Sean Whitton <spwhitton@spwhitton.name> and contributors
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) version 2 or any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
#
|
||||
# See README.rst for usage instructions
|
||||
|
||||
set -e # errexit
|
||||
set -f # noglob
|
||||
set -C # noclobber
|
||||
|
||||
export GITCEPTION="${GITCEPTION:-}+" # Reuse $Gref except when stacked
|
||||
Gref="refs/gcrypt/gitception$GITCEPTION"
|
||||
Gref_rbranch="refs/heads/master"
|
||||
Packkey_bytes=63 # nbr random bytes for packfile keys, any >= 256 bit is ok
|
||||
Hashtype=SHA256 # SHA512 SHA384 SHA256 SHA224 supported.
|
||||
Manifestfile=91bd0c092128cf2e60e1a608c31e92caf1f9c1595f83f2890ef17c0e4881aa0a
|
||||
Hex40="[a-f0-9]"
|
||||
Hex40=$Hex40$Hex40$Hex40$Hex40$Hex40$Hex40$Hex40$Hex40
|
||||
Hex40=$Hex40$Hex40$Hex40$Hex40$Hex40 # Match SHA-1 hexdigest
|
||||
GPG="$(git config --get "gpg.program" '.+' || echo gpg)"
|
||||
|
||||
Did_find_repo= # yes for connected, no for no repo
|
||||
Localdir="${GIT_DIR:=.git}/remote-gcrypt"
|
||||
Tempdir=
|
||||
|
||||
Repoid=
|
||||
Refslist=
|
||||
Packlist=
|
||||
Keeplist=
|
||||
Extnlist=
|
||||
Repack_limit=25
|
||||
|
||||
Recipients=
|
||||
|
||||
# compat/utility functions
|
||||
# xfeed: The most basic output function puts $1 into the stdin of $2..$#
|
||||
xfeed()
|
||||
{
|
||||
local input_=
|
||||
input_=$1; shift
|
||||
"$@" <<EOF
|
||||
$input_
|
||||
EOF
|
||||
}
|
||||
xecho() { xfeed "$*" cat; }
|
||||
xecho_n() { xecho "$@" | tr -d \\n ; } # kill newlines
|
||||
echo_git() { xecho "$@" ; } # Code clarity
|
||||
echo_info() { xecho "gcrypt:" "$@" >&2; }
|
||||
echo_die() { echo_info "$@" ; exit 1; }
|
||||
|
||||
isnull() { case "$1" in "") return 0;; *) return 1;; esac; }
|
||||
isnonnull() { ! isnull "$1"; }
|
||||
iseq() { case "$1" in "$2") return 0;; *) return 1;; esac; }
|
||||
isnoteq() { ! iseq "$1" "$2"; }
|
||||
negate() { ! "$@"; }
|
||||
|
||||
# Execute $@ or die
|
||||
pipefail()
|
||||
{
|
||||
"$@" || { echo_info "'$1' failed!"; kill $$; exit 1; }
|
||||
}
|
||||
|
||||
isurl() { isnull "${2%%$1://*}"; }
|
||||
islocalrepo() { isnull "${1##/*}" && [ ! -e "$1/HEAD" ]; }
|
||||
|
||||
xgrep() { command grep "$@" || : ; }
|
||||
|
||||
# setvar is used for named return variables
|
||||
# $1 *must* be a valid variable name, $2 is any value
|
||||
#
|
||||
# Conventions
|
||||
# return variable names are passed with a @ prefix
|
||||
# return variable functions use f_ prefix local vars
|
||||
# return var consumers use r_ prefix vars (or Titlecase globals)
|
||||
setvar()
|
||||
{
|
||||
isnull "${1##@*}" || echo_die "Missing @ for return variable: $1"
|
||||
eval ${1#@}=\$2
|
||||
}
|
||||
|
||||
Newline="
|
||||
"
|
||||
|
||||
# $1 is return var, $2 is value appended with newline separator
|
||||
append_to()
|
||||
{
|
||||
local f_append_tmp_=
|
||||
eval f_append_tmp_=\$${1#@}
|
||||
isnull "$f_append_tmp_" || f_append_tmp_=$f_append_tmp_$Newline
|
||||
setvar "$1" "$f_append_tmp_$2"
|
||||
}
|
||||
|
||||
# Pick words from each line
|
||||
# $1 return variable name
|
||||
# $2 input value
|
||||
pick_fields_1_2()
|
||||
{
|
||||
local f_ret= f_one= f_two=
|
||||
while read f_one f_two _ # from << here-document
|
||||
do
|
||||
f_ret="$f_ret$f_one $f_two$Newline"
|
||||
done <<EOF
|
||||
$2
|
||||
EOF
|
||||
setvar "$1" "${f_ret#$Newline}"
|
||||
}
|
||||
|
||||
# Take all lines matching $2 (full line)
|
||||
# $1 return variable name
|
||||
# $2 filter word
|
||||
# $3 input value
|
||||
# if $1 is a literal `!', the match is reversed (and arguments shift)
|
||||
# we instead remove all lines matching
|
||||
filter_to()
|
||||
{
|
||||
local f_neg= f_line= f_ret= IFS=
|
||||
isnoteq "$1" "!" || { f_neg=negate; shift; }
|
||||
IFS=$Newline
|
||||
for f_line in $3
|
||||
do
|
||||
$f_neg isnonnull "${f_line##$2}" || f_ret=$f_ret$f_line$Newline
|
||||
done
|
||||
setvar "$1" "${f_ret%$Newline}"
|
||||
}
|
||||
|
||||
# Output the number of lines in $1
|
||||
line_count()
|
||||
{
|
||||
local IFS=
|
||||
IFS=$Newline
|
||||
set -- $1
|
||||
xecho "$#"
|
||||
}
|
||||
|
||||
|
||||
## gitception part
|
||||
# Fetch giturl $1, file $2
|
||||
gitception_get()
|
||||
{
|
||||
# Take care to preserve FETCH_HEAD
|
||||
local ret_=: obj_id= fet_head="$GIT_DIR/FETCH_HEAD"
|
||||
[ -e "$fet_head" ] && command mv -f "$fet_head" "$fet_head.$$~" || :
|
||||
git fetch -q -f "$1" "$Gref_rbranch:$Gref" >/dev/null &&
|
||||
obj_id="$(git ls-tree "$Gref" | xgrep -E '\b'"$2"'$' | awk '{print $3}')" &&
|
||||
isnonnull "$obj_id" && git cat-file blob "$obj_id" && ret_=: ||
|
||||
{ ret_=false && : ; }
|
||||
[ -e "$fet_head.$$~" ] && command mv -f "$fet_head.$$~" "$fet_head" || :
|
||||
$ret_
|
||||
}
|
||||
|
||||
anon_commit()
|
||||
{
|
||||
GIT_AUTHOR_NAME="root" GIT_AUTHOR_EMAIL="root@localhost" \
|
||||
GIT_AUTHOR_DATE="1356994801 -0400" GIT_COMMITTER_NAME="root" \
|
||||
GIT_COMMITTER_EMAIL="root@localhost" \
|
||||
GIT_COMMITTER_DATE="1356994801 -0400" \
|
||||
git commit-tree "$@" <<EOF
|
||||
Initial commit
|
||||
EOF
|
||||
}
|
||||
|
||||
# Get 'tree' from $1, change file $2 to obj id $3
|
||||
update_tree()
|
||||
{
|
||||
local tab_=" "
|
||||
# $2 is a filename from the repo format
|
||||
(set +e;
|
||||
git ls-tree "$1" | xgrep -v -E '\b'"$2"'$';
|
||||
xecho "100644 blob $3$tab_$2"
|
||||
) | git mktree
|
||||
}
|
||||
|
||||
# Put giturl $1, file $2
|
||||
# depends on previous GET to set $Gref and depends on PUT_FINAL later
|
||||
gitception_put()
|
||||
{
|
||||
local obj_id= tree_id= commit_id=
|
||||
obj_id=$(git hash-object -w --stdin) &&
|
||||
tree_id=$(update_tree "$Gref" "$2" "$obj_id") &&
|
||||
commit_id=$(anon_commit "$tree_id") &&
|
||||
git update-ref "$Gref" "$commit_id"
|
||||
}
|
||||
|
||||
# Remove giturl $1, file $2
|
||||
# depends on previous GET like put
|
||||
gitception_remove()
|
||||
{
|
||||
local tree_id= commit_id= tab_=" "
|
||||
# $2 is a filename from the repo format
|
||||
tree_id=$(git ls-tree "$Gref" | xgrep -v -E '\b'"$2"'$' | git mktree) &&
|
||||
commit_id=$(anon_commit "$tree_id") &&
|
||||
git update-ref "$Gref" "$commit_id"
|
||||
}
|
||||
|
||||
gitception_new_repo()
|
||||
{
|
||||
local commit_id= empty_tree=4b825dc642cb6eb9a060e54bf8d69288fbee4904
|
||||
# get any file to update Gref, and if it's not updated we create empty
|
||||
git update-ref -d "$Gref" || :
|
||||
gitception_get "$1" "x" 2>/dev/null >&2 || :
|
||||
git rev-parse -q --verify "$Gref" >/dev/null && return 0 ||
|
||||
commit_id=$(anon_commit "$empty_tree") &&
|
||||
git update-ref "$Gref" "$commit_id"
|
||||
}
|
||||
## end gitception
|
||||
|
||||
# Fetch repo $1, file $2, tmpfile in $3
|
||||
GET()
|
||||
{
|
||||
if isurl sftp "$1"
|
||||
then
|
||||
(exec 0>&-; curl -s -S -k "$1/$2") > "$3"
|
||||
elif isurl rsync "$1"
|
||||
then
|
||||
(exec 0>&-; rsync -I -W "${1#rsync://}"/"$2" "$3" >&2)
|
||||
elif islocalrepo "$1"
|
||||
then
|
||||
cat "$1/$2" > "$3"
|
||||
else
|
||||
gitception_get "${1#gitception://}" "$2" > "$3"
|
||||
fi
|
||||
}
|
||||
|
||||
# Put repo $1, file $2 or fail, tmpfile in $3
|
||||
PUT()
|
||||
{
|
||||
if isurl sftp "$1"
|
||||
then
|
||||
curl -s -S -k --ftp-create-dirs -T "$3" "$1/$2"
|
||||
elif isurl rsync "$1"
|
||||
then
|
||||
rsync -I -W "$3" "${1#rsync://}"/"$2" >&2
|
||||
elif islocalrepo "$1"
|
||||
then
|
||||
cat >| "$1/$2" < "$3"
|
||||
else
|
||||
gitception_put "${1#gitception://}" "$2" < "$3"
|
||||
fi
|
||||
}
|
||||
|
||||
# Put all PUT changes for repo $1 at once
|
||||
PUT_FINAL()
|
||||
{
|
||||
if isurl sftp "$1" || islocalrepo "$1" || isurl rsync "$1"
|
||||
then
|
||||
:
|
||||
else
|
||||
git push --quiet -f "${1#gitception://}" "$Gref:$Gref_rbranch"
|
||||
fi
|
||||
}
|
||||
|
||||
# Put directory for repo $1
|
||||
PUTREPO()
|
||||
{
|
||||
if isurl sftp "$1"
|
||||
then
|
||||
:
|
||||
elif isurl rsync "$1"
|
||||
then
|
||||
rsync -q -r --exclude='*' "$Localdir/" "${1#rsync://}" >&2
|
||||
elif islocalrepo "$1"
|
||||
then
|
||||
mkdir -p "$1"
|
||||
else
|
||||
gitception_new_repo "${1#gitception://}"
|
||||
fi
|
||||
}
|
||||
|
||||
# For repo $1, delete all newline-separated files in $2
|
||||
REMOVE()
|
||||
{
|
||||
local fn_=
|
||||
if isurl sftp "$1"
|
||||
then
|
||||
# FIXME
|
||||
echo_info "sftp: Ignore remove request $1/$2"
|
||||
elif isurl rsync "$1"
|
||||
then
|
||||
xfeed "$2" rsync -I -W -v -r --delete --include-from=- \
|
||||
--exclude='*' "$Localdir"/ "${1#rsync://}/" >&2
|
||||
elif islocalrepo "$1"
|
||||
then
|
||||
for fn_ in $2; do
|
||||
rm -f "$1"/"$fn_"
|
||||
done
|
||||
else
|
||||
for fn_ in $2; do
|
||||
gitception_remove "${1#gitception://}" "$fn_"
|
||||
done
|
||||
fi
|
||||
}
|
||||
|
||||
CLEAN_FINAL()
|
||||
{
|
||||
if isurl sftp "$1" || islocalrepo "$1" || isurl rsync "$1"
|
||||
then
|
||||
:
|
||||
else
|
||||
git update-ref -d "$Gref" || :
|
||||
fi
|
||||
}
|
||||
|
||||
ENCRYPT()
|
||||
{
|
||||
rungpg --batch --force-mdc --compress-algo none --trust-model=always --passphrase-fd 3 -c 3<<EOF
|
||||
$1
|
||||
EOF
|
||||
}
|
||||
|
||||
DECRYPT()
|
||||
{
|
||||
rungpg -q --batch --no-default-keyring --secret-keyring /dev/null \
|
||||
--keyring /dev/null --passphrase-fd 3 -d 3<<EOF
|
||||
$1
|
||||
EOF
|
||||
}
|
||||
|
||||
# Encrypt to recipients $1
|
||||
PRIVENCRYPT()
|
||||
{
|
||||
set -- $1
|
||||
if isnonnull "$Conf_signkey"; then
|
||||
set -- "$@" -u "$Conf_signkey"
|
||||
fi
|
||||
rungpg --compress-algo none --trust-model=always -se "$@"
|
||||
}
|
||||
|
||||
# $1 is the match for good signature, $2 is the textual signers list
|
||||
PRIVDECRYPT()
|
||||
{
|
||||
local status_=
|
||||
exec 4>&1 &&
|
||||
status_=$(rungpg --status-fd 3 -q -d 3>&1 1>&4) &&
|
||||
xfeed "$status_" grep "^\[GNUPG:\] ENC_TO " >/dev/null &&
|
||||
(xfeed "$status_" grep -e "$1" >/dev/null || {
|
||||
echo_info "Failed to verify manifest signature!" &&
|
||||
echo_info "Only accepting signatories: ${2:-(none)}" &&
|
||||
return 1
|
||||
})
|
||||
}
|
||||
|
||||
# Generate $1 random bytes
|
||||
genkey()
|
||||
{
|
||||
rungpg --armor --gen-rand 1 "$1"
|
||||
}
|
||||
|
||||
gpg_hash()
|
||||
{
|
||||
local hash_=
|
||||
hash_=$(rungpg --with-colons --print-md "$1" | tr A-F a-f)
|
||||
hash_=${hash_#:*:}
|
||||
xecho "${hash_%:}"
|
||||
}
|
||||
|
||||
rungpg()
|
||||
{
|
||||
if isnonnull "$Conf_gpg_args"; then
|
||||
set -- "$Conf_gpg_args" "$@"
|
||||
fi
|
||||
# gpg will fail to run when there is no controlling tty,
|
||||
# due to trying to print messages to it, even if a gpg agent is set
|
||||
# up. --no-tty fixes this.
|
||||
if [ "x$GPG_AGENT_INFO" != "x" ]; then
|
||||
${GPG} --no-tty $@
|
||||
else
|
||||
${GPG} $@
|
||||
fi
|
||||
}
|
||||
|
||||
# Pass the branch/ref by pipe to git
|
||||
safe_git_rev_parse()
|
||||
{
|
||||
git cat-file --batch-check 2>/dev/null |
|
||||
xgrep -v "missing" | cut -f 1 -d ' '
|
||||
}
|
||||
|
||||
make_new_repo()
|
||||
{
|
||||
echo_info "Setting up new repository"
|
||||
PUTREPO "$URL"
|
||||
|
||||
# Needed assumption: the same user should have no duplicate Repoid
|
||||
Repoid=":id:$(genkey 15)"
|
||||
iseq "${NAME#gcrypt::}" "$URL" ||
|
||||
git config "remote.$NAME.gcrypt-id" "$Repoid"
|
||||
echo_info "Remote ID is $Repoid"
|
||||
Extnlist="extn comment"
|
||||
}
|
||||
|
||||
|
||||
# $1 return var for goodsig match, $2 return var for signers text
|
||||
read_config()
|
||||
{
|
||||
local recp_= r_tail= r_keyinfo= r_keyfpr= gpg_list= cap_= conf_part= good_sig= signers_=
|
||||
Conf_signkey=$(git config --get "remote.$NAME.gcrypt-signingkey" '.+' ||
|
||||
git config --path user.signingkey || :)
|
||||
conf_part=$(git config --get "remote.$NAME.gcrypt-participants" '.+' ||
|
||||
git config --get gcrypt.participants '.+' || :)
|
||||
Conf_pubish_participants=$(git config --get --bool "remote.$NAME.gcrypt-publish-participants" '.+' ||
|
||||
git config --get --bool gcrypt.publish-participants || :)
|
||||
Conf_gpg_args=$(git config --get gcrypt.gpg-args '.+' || :)
|
||||
|
||||
# Figure out which keys we should encrypt to or accept signatures from
|
||||
if isnull "$conf_part" || iseq "$conf_part" simple
|
||||
then
|
||||
signers_="(default keyring)"
|
||||
Recipients="--throw-keyids --default-recipient-self"
|
||||
good_sig="^\[GNUPG:\] GOODSIG "
|
||||
setvar "$1" "$good_sig"
|
||||
setvar "$2" "$signers_"
|
||||
return 0
|
||||
fi
|
||||
|
||||
for recp_ in $conf_part
|
||||
do
|
||||
gpg_list=$(rungpg --with-colons --fingerprint -k "$recp_")
|
||||
r_tail_=$(echo "$recp_" | sed -e 's/^0x//')
|
||||
filter_to @r_keyinfo "pub*" "$gpg_list"
|
||||
if echo "$recp_" | grep -E -q '^[xA-F0-9]+$'; then # is $recp_ a keyid?
|
||||
filter_to @r_keyfpr "fpr*$r_tail_*" "$gpg_list"
|
||||
else
|
||||
filter_to @r_keyfpr "fpr*" "$gpg_list"
|
||||
fi
|
||||
isnull "$r_keyinfo" || isnonnull "${r_keyinfo##*"$Newline"*}" ||
|
||||
echo_info "WARNING: '$recp_' matches multiple keys, using one"
|
||||
isnull "$r_keyfpr" || isnonnull "${r_keyfpr##*"$Newline"*}" ||
|
||||
echo_info "WARNING: '$recp_' matches multiple fingerprints, using one"
|
||||
r_keyinfo=${r_keyinfo%%"$Newline"*}
|
||||
r_keyfpr=${r_keyfpr%%"$Newline"*}
|
||||
keyid_=$(xfeed "$r_keyinfo" cut -f 5 -d :)
|
||||
fprid_=$(xfeed "$r_keyfpr" cut -f 10 -d :)
|
||||
|
||||
isnonnull "$fprid_" &&
|
||||
signers_="$signers_ $keyid_" &&
|
||||
append_to @good_sig "^\[GNUPG:\] VALIDSIG .*$fprid_$" || {
|
||||
echo_info "WARNING: Skipping missing key $recp_"
|
||||
continue
|
||||
}
|
||||
# Check 'E'ncrypt capability
|
||||
cap_=$(xfeed "$r_keyinfo" cut -f 12 -d :)
|
||||
if ! iseq "${cap_#*E}" "$cap_"; then
|
||||
if [ "$Conf_pubish_participants" = true ]; then
|
||||
Recipients="$Recipients -r $keyid_"
|
||||
else
|
||||
Recipients="$Recipients -R $keyid_"
|
||||
fi
|
||||
fi
|
||||
done
|
||||
|
||||
if isnull "$Recipients"
|
||||
then
|
||||
echo_info "You have not configured any keys you can encrypt to" \
|
||||
"for this repository"
|
||||
echo_info "Use ::"
|
||||
echo_info " git config gcrypt.participants YOURKEYID"
|
||||
exit 1
|
||||
fi
|
||||
setvar "$1" "$good_sig"
|
||||
setvar "$2" "$signers_"
|
||||
}
|
||||
|
||||
ensure_connected()
|
||||
{
|
||||
local manifest_= r_repoid= r_name= url_frag= r_sigmatch= r_signers= \
|
||||
tmp_manifest=
|
||||
|
||||
if isnonnull "$Did_find_repo"
|
||||
then
|
||||
return
|
||||
fi
|
||||
Did_find_repo=no
|
||||
read_config @r_sigmatch @r_signers
|
||||
|
||||
iseq "${NAME#gcrypt::}" "$URL" || r_name=$NAME
|
||||
|
||||
if isurl gitception "$URL" && isnonnull "$r_name"; then
|
||||
git config "remote.$r_name.url" "gcrypt::${URL#gitception://}"
|
||||
echo_info "Updated URL for $r_name, gitception:// -> ()"
|
||||
fi
|
||||
|
||||
# Find the URL fragment
|
||||
url_frag=${URL##*"#"}
|
||||
isnoteq "$url_frag" "$URL" || url_frag=
|
||||
URL=${URL%"#$url_frag"}
|
||||
|
||||
# manifestfile -- sha224 hash if we can, else the default location
|
||||
if isurl sftp "$URL" || islocalrepo "$URL" || isurl rsync "$URL"
|
||||
then
|
||||
# not for gitception
|
||||
isnull "$url_frag" ||
|
||||
Manifestfile=$(xecho_n "$url_frag" | gpg_hash SHA224)
|
||||
else
|
||||
isnull "$url_frag" || Gref_rbranch="refs/heads/$url_frag"
|
||||
fi
|
||||
|
||||
Repoid=
|
||||
isnull "$r_name" ||
|
||||
Repoid=$(git config "remote.$r_name.gcrypt-id" || :)
|
||||
|
||||
|
||||
tmp_manifest="$Tempdir/maniF"
|
||||
GET "$URL" "$Manifestfile" "$tmp_manifest" 2>/dev/null || {
|
||||
echo_info "Repository not found: $URL"
|
||||
if ! isnull "$Repoid"; then
|
||||
echo_info "..but repository ID is set. Aborting."
|
||||
return 1
|
||||
else
|
||||
return 0
|
||||
fi
|
||||
}
|
||||
|
||||
Did_find_repo=yes
|
||||
echo_info "Decrypting manifest"
|
||||
manifest_=$(PRIVDECRYPT "$r_sigmatch" "$r_signers" < "$tmp_manifest") &&
|
||||
isnonnull "$manifest_" ||
|
||||
echo_die "Failed to decrypt manifest!"
|
||||
rm -f "$tmp_manifest"
|
||||
|
||||
filter_to @Refslist "$Hex40 *" "$manifest_"
|
||||
filter_to @Packlist "pack :*:* *" "$manifest_"
|
||||
filter_to @Keeplist "keep :*:*" "$manifest_"
|
||||
filter_to @Extnlist "extn *" "$manifest_"
|
||||
filter_to @r_repoid "repo *" "$manifest_"
|
||||
|
||||
r_repoid=${r_repoid#repo }
|
||||
r_repoid=${r_repoid% *}
|
||||
if isnull "$Repoid"
|
||||
then
|
||||
echo_info "Remote ID is $r_repoid"
|
||||
Repoid=$r_repoid
|
||||
elif isnoteq "$r_repoid" "$Repoid"
|
||||
then
|
||||
echo_info "WARNING:"
|
||||
echo_info "WARNING: Remote ID has changed!"
|
||||
echo_info "WARNING: from $Repoid"
|
||||
echo_info "WARNING: to $r_repoid"
|
||||
echo_info "WARNING:"
|
||||
Repoid=$r_repoid
|
||||
else
|
||||
return 0
|
||||
fi
|
||||
|
||||
isnull "$r_name" || git config "remote.$r_name.gcrypt-id" "$r_repoid"
|
||||
}
|
||||
|
||||
# $1 is the hash type (SHA256 etc)
|
||||
# $2 the pack id
|
||||
# $3 the key
|
||||
get_verify_decrypt_pack()
|
||||
{
|
||||
local rcv_id= tmp_encrypted=
|
||||
tmp_encrypted="$Tempdir/packF"
|
||||
GET "$URL" "$2" "$tmp_encrypted" &&
|
||||
rcv_id=$(gpg_hash "$1" < "$tmp_encrypted") &&
|
||||
iseq "$rcv_id" "$2" || echo_die "Packfile $2 does not match digest!"
|
||||
DECRYPT "$3" < "$tmp_encrypted"
|
||||
rm -f "$tmp_encrypted"
|
||||
}
|
||||
|
||||
# download all packlines (pack :SHA256:a32abc1231) from stdin (or die)
|
||||
# $1 destdir (when repack, else "")
|
||||
get_pack_files()
|
||||
{
|
||||
local pack_id= r_pack_key_line= htype_= pack_= key_=
|
||||
while IFS=': ' read -r _ htype_ pack_ # <<here-document
|
||||
do
|
||||
isnonnull "$pack_" || continue
|
||||
|
||||
# Get the Packlist line with the key
|
||||
pack_id=":${htype_}:$pack_"
|
||||
filter_to @r_pack_key_line "pack $pack_id *" "$Packlist"
|
||||
key_=${r_pack_key_line#pack $pack_id }
|
||||
|
||||
if isnonnull "${pack_##$Hex40*}" ||
|
||||
isnoteq "$htype_" SHA256 && isnoteq "$htype_" SHA224 &&
|
||||
isnoteq "$htype_" SHA384 && isnoteq "$htype_" SHA512
|
||||
then
|
||||
echo_die "Packline malformed: $pack_id"
|
||||
fi
|
||||
|
||||
get_verify_decrypt_pack "$htype_" "$pack_" "$key_" | \
|
||||
if isnull "${1:-}"
|
||||
then
|
||||
# add to local pack list
|
||||
git index-pack -v --stdin >/dev/null
|
||||
xecho "pack $pack_id" >> "$Localdir/have_packs$GITCEPTION"
|
||||
else
|
||||
git index-pack -v --stdin "$1/${pack_}.pack" >/dev/null
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
# Download and unpack remote packfiles
|
||||
# $1 return var for list of packfiles to delete
|
||||
repack_if_needed()
|
||||
{
|
||||
local n_= m_= kline_= r_line= r_keep_packlist= r_del_list=
|
||||
|
||||
isnonnull "$Packlist" || return 0
|
||||
|
||||
if isnonnull "${GCRYPT_FULL_REPACK:-}"
|
||||
then
|
||||
Keeplist=
|
||||
Repack_limit=0
|
||||
fi
|
||||
|
||||
pick_fields_1_2 @r_del_list "$Packlist"
|
||||
|
||||
n_=$(line_count "$Packlist")
|
||||
m_=$(line_count "$Keeplist")
|
||||
if iseq 0 "$(( $Repack_limit < ($n_ - $m_) ))"; then
|
||||
return
|
||||
fi
|
||||
echo_info "Repacking remote $NAME, ..."
|
||||
|
||||
mkdir "$Tempdir/pack"
|
||||
|
||||
# Split packages to keep and to repack
|
||||
if isnonnull "$Keeplist"; then
|
||||
while read -r _ kline_ _ # <<here-document
|
||||
do
|
||||
isnonnull "$kline_" || continue
|
||||
filter_to @r_line "pack $kline_ *" "$Packlist"
|
||||
append_to @r_keep_packlist "$r_line"
|
||||
filter_to ! @r_del_list "pack $kline_" "$r_del_list"
|
||||
done <<EOF
|
||||
$Keeplist
|
||||
EOF
|
||||
fi
|
||||
|
||||
xfeed "$r_del_list" get_pack_files "$Tempdir/pack/"
|
||||
|
||||
(set +f; pipefail git verify-pack -v "$Tempdir"/pack/*.idx) |
|
||||
grep -E '^[0-9a-f]{40}' | cut -f 1 -d ' '
|
||||
|
||||
Packlist=$r_keep_packlist
|
||||
setvar "$1" "$r_del_list"
|
||||
}
|
||||
|
||||
do_capabilities()
|
||||
{
|
||||
echo_git fetch
|
||||
echo_git push
|
||||
echo_git
|
||||
}
|
||||
|
||||
do_list()
|
||||
{
|
||||
local obj_id= ref_name= line_=
|
||||
ensure_connected
|
||||
|
||||
xecho "$Refslist" | while read line_
|
||||
do
|
||||
isnonnull "$line_" || break
|
||||
obj_id=${line_%% *}
|
||||
ref_name=${line_##* }
|
||||
echo_git "$obj_id" "$ref_name"
|
||||
if iseq "$ref_name" "refs/heads/master"
|
||||
then
|
||||
echo_git "@refs/heads/master HEAD"
|
||||
fi
|
||||
done
|
||||
|
||||
# end with blank line
|
||||
echo_git
|
||||
}
|
||||
|
||||
do_fetch()
|
||||
{
|
||||
# Download packs in the manifest that don't appear in have_packs
|
||||
local pneed_= premote_=
|
||||
|
||||
ensure_connected
|
||||
|
||||
# The `+` for $GITCEPTION is pointless but we will be safe for stacking
|
||||
pick_fields_1_2 @premote_ "$Packlist"
|
||||
if [ -s "$Localdir/have_packs+" ]
|
||||
then
|
||||
pneed_=$(xfeed "$premote_" xgrep -v -x -f "$Localdir/have_packs+")
|
||||
else
|
||||
pneed_=$premote_
|
||||
fi
|
||||
|
||||
xfeed "$pneed_" get_pack_files
|
||||
|
||||
echo_git # end with blank line
|
||||
}
|
||||
|
||||
# do_push PUSHARGS (multiple lines like +src:dst, with both + and src opt.)
|
||||
do_push()
|
||||
{
|
||||
# Security protocol:
|
||||
# Each git packfile is encrypted and then named for the encrypted
|
||||
# file's hash. The manifest is updated with the pack id.
|
||||
# The manifest is encrypted.
|
||||
local r_revlist= pack_id= key_= obj_= src_= dst_= \
|
||||
r_pack_delete= tmp_encrypted= tmp_objlist= tmp_manifest=
|
||||
|
||||
ensure_connected
|
||||
|
||||
if iseq "$Did_find_repo" "no"
|
||||
then
|
||||
make_new_repo
|
||||
fi
|
||||
|
||||
if isnonnull "$Refslist"
|
||||
then
|
||||
# mark all remote refs with ^<sha-1> (if sha-1 exists locally)
|
||||
r_revlist=$(xfeed "$Refslist" cut -f 1 -d ' ' |
|
||||
safe_git_rev_parse | sed -e 's/^\(.\)/^&/')
|
||||
fi
|
||||
|
||||
while IFS=: read -r src_ dst_ # << +src:dst
|
||||
do
|
||||
src_=${src_#+}
|
||||
filter_to ! @Refslist "$Hex40 $dst_" "$Refslist"
|
||||
|
||||
if isnonnull "$src_"
|
||||
then
|
||||
append_to @r_revlist "$src_"
|
||||
obj_=$(xfeed "$src_" safe_git_rev_parse)
|
||||
append_to @Refslist "$obj_ $dst_"
|
||||
fi
|
||||
done <<EOF
|
||||
$1
|
||||
EOF
|
||||
|
||||
tmp_encrypted="$Tempdir/packP"
|
||||
tmp_objlist="$Tempdir/objlP"
|
||||
|
||||
{
|
||||
xfeed "$r_revlist" git rev-list --objects --stdin --
|
||||
repack_if_needed @r_pack_delete
|
||||
} > "$tmp_objlist"
|
||||
|
||||
# Only send pack if we have any objects to send
|
||||
if [ -s "$tmp_objlist" ]
|
||||
then
|
||||
key_=$(genkey "$Packkey_bytes")
|
||||
pack_id=$(export GIT_ALTERNATE_OBJECT_DIRECTORIES=$Tempdir;
|
||||
pipefail git pack-objects --stdout < "$tmp_objlist" |
|
||||
pipefail ENCRYPT "$key_" |
|
||||
tee "$tmp_encrypted" | gpg_hash "$Hashtype")
|
||||
|
||||
append_to @Packlist "pack :${Hashtype}:$pack_id $key_"
|
||||
if isnonnull "$r_pack_delete"
|
||||
then
|
||||
append_to @Keeplist "keep :${Hashtype}:$pack_id 1"
|
||||
fi
|
||||
fi
|
||||
|
||||
# Generate manifest
|
||||
echo_info "Encrypting to: $Recipients"
|
||||
echo_info "Requesting manifest signature"
|
||||
|
||||
tmp_manifest="$Tempdir/maniP"
|
||||
PRIVENCRYPT "$Recipients" > "$tmp_manifest" <<EOF
|
||||
$Refslist
|
||||
$Packlist
|
||||
$Keeplist
|
||||
repo $Repoid
|
||||
$Extnlist
|
||||
EOF
|
||||
|
||||
# Upload pack
|
||||
if [ -s "$tmp_objlist" ]
|
||||
then
|
||||
PUT "$URL" "$pack_id" "$tmp_encrypted"
|
||||
fi
|
||||
|
||||
# Upload manifest
|
||||
PUT "$URL" "$Manifestfile" "$tmp_manifest"
|
||||
|
||||
rm -f "$tmp_encrypted"
|
||||
rm -f "$tmp_objlist"
|
||||
rm -f "$tmp_manifest"
|
||||
|
||||
# Delete packs
|
||||
if isnonnull "$r_pack_delete"; then
|
||||
REMOVE "$URL" "$(xecho "$r_pack_delete" | \
|
||||
while IFS=': ' read -r _ _ pack_
|
||||
do
|
||||
isnonnull "$pack_" || continue
|
||||
xecho "$pack_"
|
||||
done)"
|
||||
fi
|
||||
|
||||
PUT_FINAL "$URL"
|
||||
|
||||
# ok all updates
|
||||
while IFS=: read -r src_ dst_ # << +src:dst
|
||||
do
|
||||
echo_git "ok $dst_"
|
||||
done <<EOF
|
||||
$1
|
||||
EOF
|
||||
|
||||
echo_git
|
||||
}
|
||||
|
||||
cleanup_tmpfiles()
|
||||
{
|
||||
if isnonnull "${Tempdir%%*."$$"}"; then
|
||||
echo_die "Unexpected Tempdir value: $Tempdir"
|
||||
fi
|
||||
rm -r -f -- "${Tempdir}" >&2
|
||||
}
|
||||
|
||||
setup()
|
||||
{
|
||||
mkdir -p "$Localdir"
|
||||
|
||||
# Set up a subdirectory in /tmp
|
||||
temp_key=$(genkey 9 | tr '/' _)
|
||||
Tempdir="${TMPDIR:-/tmp}/git-remote-gcrypt-${temp_key}.$$"
|
||||
case "${MSYSTEM:-unknown}" in
|
||||
MSYS*|MINGW*)
|
||||
mkdir "${Tempdir}"
|
||||
echo_info "Warning: Not securing tempdir ${Tempdir} because we are on mingw/msys"
|
||||
;;
|
||||
unknown|*)
|
||||
mkdir -m 700 "${Tempdir}"
|
||||
;;
|
||||
esac
|
||||
|
||||
trap cleanup_tmpfiles EXIT
|
||||
trap 'exit 1' 1 2 3 15
|
||||
}
|
||||
|
||||
# handle git-remote-helpers protocol
|
||||
gcrypt_main_loop()
|
||||
{
|
||||
local input_= input_inner= r_args= temp_key=
|
||||
|
||||
NAME=$1 # Remote name
|
||||
URL=$2 # Remote URL
|
||||
|
||||
setup
|
||||
|
||||
while read input_
|
||||
do
|
||||
case "$input_" in
|
||||
capabilities)
|
||||
do_capabilities
|
||||
;;
|
||||
list|list\ for-push)
|
||||
do_list
|
||||
;;
|
||||
fetch\ *)
|
||||
r_args=${input_##fetch }
|
||||
while read input_inner
|
||||
do
|
||||
case "$input_inner" in
|
||||
fetch*)
|
||||
r_args= #ignored
|
||||
;;
|
||||
*)
|
||||
break
|
||||
;;
|
||||
esac
|
||||
done
|
||||
do_fetch "$r_args"
|
||||
;;
|
||||
push\ *)
|
||||
r_args=${input_##push }
|
||||
while read input_inner
|
||||
do
|
||||
case "$input_inner" in
|
||||
push\ *)
|
||||
append_to @r_args "${input_inner#push }"
|
||||
;;
|
||||
*)
|
||||
break
|
||||
;;
|
||||
esac
|
||||
done
|
||||
do_push "$r_args"
|
||||
;;
|
||||
?*)
|
||||
echo_die "Unknown input!"
|
||||
;;
|
||||
*)
|
||||
CLEAN_FINAL "$URL"
|
||||
exit 0
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
if [ "x$1" = x--check ]
|
||||
then
|
||||
NAME=dummy-gcrypt-check
|
||||
URL=$2
|
||||
setup
|
||||
ensure_connected
|
||||
git remote remove $NAME 2>/dev/null || true
|
||||
if iseq "$Did_find_repo" "no"
|
||||
then
|
||||
exit 100
|
||||
fi
|
||||
else
|
||||
gcrypt_main_loop "$@"
|
||||
fi
|
@ -1,5 +1,5 @@
|
||||
#!/bin/sh
|
||||
cd "$(mktemp -d)";
|
||||
go mod init local-playground;
|
||||
echo 'package main\n\nimport (\n\t"fmt"\n)\n\nfunc main() {\n\tfmt.Println("aloha")\n}\n' > main.go;
|
||||
echo -e 'package main\n\nimport (\n\t"fmt"\n)\n\nfunc main() {\n\tfmt.Println("aloha")\n}\n' > main.go;
|
||||
$EDITOR main.go;
|
||||
|
@ -1,31 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
set -e
|
||||
|
||||
# This assumes that /proc/cmdline contains a cryptdevice with a UUID identifier,
|
||||
# like:
|
||||
#
|
||||
# cryptdevice=UUID=1ff1d6f7-7540-4500-8011-1abe1e9ac00d:cryptroot
|
||||
uuid=$(cat /proc/cmdline | \
|
||||
tr ' ' '\n' | \
|
||||
grep cryptdevice | \
|
||||
cut -d= -f3 | \
|
||||
cut -d: -f1)
|
||||
|
||||
device=$(lsblk -o PATH,UUID | grep "$uuid" | awk '{print $1}')
|
||||
echo "Root device is $device"
|
||||
|
||||
echo -n "Enter root key: "
|
||||
read -s pw
|
||||
echo ""
|
||||
|
||||
# This will check if the key is right, and cause the process to exit if not due
|
||||
# to the "set -e"
|
||||
echo "Checking key..."
|
||||
echo "$pw" | sudo cryptsetup open --test-passphrase "$device"
|
||||
|
||||
echo "Good job, writing /boot/keyfile..."
|
||||
echo -n "$pw" | sudo tee /boot/keyfile >/dev/null
|
||||
|
||||
echo "Rebooting..."
|
||||
sudo systemctl reboot
|
@ -1,31 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
set -e
|
||||
|
||||
# This assumes that /proc/cmdline contains a cryptdevice with a UUID identifier,
|
||||
# like:
|
||||
#
|
||||
# cryptdevice=UUID=1ff1d6f7-7540-4500-8011-1abe1e9ac00d:cryptroot
|
||||
uuid=$(cat /proc/cmdline | \
|
||||
tr ' ' '\n' | \
|
||||
grep cryptdevice | \
|
||||
cut -d= -f3 | \
|
||||
cut -d: -f1)
|
||||
|
||||
device=$(lsblk -o PATH,UUID | grep "$uuid" | awk '{print $1}')
|
||||
echo "Root device is $device"
|
||||
|
||||
echo -n "Enter root key: "
|
||||
read -s pw
|
||||
echo ""
|
||||
|
||||
# This will check if the key is right, and cause the process to exit if not due
|
||||
# to the "set -e"
|
||||
echo "Checking key..."
|
||||
echo "$pw" | sudo cryptsetup open --test-passphrase "$device"
|
||||
|
||||
echo "Good job, writing /boot/keyfile..."
|
||||
echo -n "$pw" | sudo tee /boot/keyfile >/dev/null
|
||||
|
||||
echo "Shutting down..."
|
||||
sudo systemctl poweroff
|
353
bin/rotcheck
@ -1,353 +0,0 @@
|
||||
#!/bin/sh
|
||||
set -uf
|
||||
IFS="$(printf '\n\t')"
|
||||
LC_ALL="C"
|
||||
|
||||
# Copyright (C) 2019 Jamie Nguyen <j@jamielinux.com>
|
||||
#
|
||||
# A simple shell script to recursively generate, update and verify checksums
|
||||
# for files you care about. It's useful for detecting bit rot.
|
||||
#
|
||||
# It's written in POSIX shell, but requires GNU coreutils, BusyBox or some
|
||||
# other collection that includes similar checksum tools.
|
||||
|
||||
VERSION=1.1.2
|
||||
COMMAND="sha512sum"
|
||||
CHECKFILE="./.rotcheck"
|
||||
|
||||
APPEND_MODE=0
|
||||
CHECK_MODE=0
|
||||
DELETE_MODE=0
|
||||
UPDATE_MODE=0
|
||||
|
||||
IGNORE_MISSING=0
|
||||
FOLLOW_SYMLINKS=1
|
||||
VERBOSE=0
|
||||
WARN_FORMATTING=0
|
||||
EXCLUDE_HIDDEN=0
|
||||
FORCE_UPDATE=0
|
||||
|
||||
usage() {
|
||||
cat << EOF
|
||||
rotcheck $VERSION
|
||||
Usage: rotcheck MODE [OPTIONS]
|
||||
or: rotcheck MODE [OPTIONS] -- [DIRECTORY]... [ARBITRARY FIND OPTION]...
|
||||
Recursively generate, update and verify checksums.
|
||||
|
||||
MODES:
|
||||
-a APPEND mode: Record checksums for any files without a checksum
|
||||
already. Never modify existing checksums.
|
||||
-c CHECK mode: Check that files checksums are the same.
|
||||
-d DELETE mode: Remove checksums for files that don't exist.
|
||||
-u APPEND-AND-UPDATE mode: Like append-only mode, but also update
|
||||
checksums for files with a modification date newer than the
|
||||
the checksum file. (NB: Also see \`-M\`.)
|
||||
|
||||
OPTIONS:
|
||||
-b COMMAND Checksum command to use. Default: sha512sum
|
||||
-f FILE File to store checksums. For relative paths, prefix with "./"
|
||||
or the checksum file will be checksummed. Default: ./.rotcheck
|
||||
-h Display this help.
|
||||
-n Don't follow symlinks. The default is to follow symlinks.
|
||||
-v Be more verbose when adding, deleting, changing or verifying
|
||||
checksums.
|
||||
-w Warn about improperly formatted checksum lines.
|
||||
-x Exclude all hidden files and directories when generating
|
||||
checksums. The default is to include them.
|
||||
-M Use with \`-u\` to update checksums regardless of modification
|
||||
time. This is very slow so avoid if possible; try \`touch\`
|
||||
instead to bump the modification time of specific files.
|
||||
WARNING: The checksums might have changed due to bit rot so
|
||||
use this option with care!
|
||||
|
||||
(specific to GNU coreutils >= 8.25)
|
||||
-i Ignore missing files when verifying checksums.
|
||||
|
||||
|
||||
Supported commands:
|
||||
GNU coreutils:
|
||||
md5sum, sha1sum, sha224sum, sha256sum, sha384sum, sha512sum, b2sum
|
||||
|
||||
BusyBox (applets must be symlinked):
|
||||
md5sum, sha1sum, sha256sum, sha512sum, sha3sum
|
||||
|
||||
BSD & macOS (install GNU coreutils):
|
||||
gmd5sum, gsha1sum, gsha224sum, gsha256sum, gsha384sum, gsha512sum, gb2sum
|
||||
|
||||
|
||||
Examples:
|
||||
# Create checksum file (located at "./.rotcheck"):
|
||||
rotcheck -a
|
||||
|
||||
# You've added some new files and need to append some checksums:
|
||||
rotcheck -va
|
||||
|
||||
# You've edited some files and need to update the checksums (for files with
|
||||
# a modification time newer than the checksum file):
|
||||
rotcheck -vu
|
||||
|
||||
# Verify checksums:
|
||||
rotcheck -c
|
||||
|
||||
# Search other directories instead of the current directory.
|
||||
# WARNING: checksums might get duplicated if mixing relative and absolute
|
||||
# paths, or if you change the way you specify directory paths!
|
||||
rotcheck -a -- /mnt/archive-2018/ /mnt/archive-2019/
|
||||
|
||||
# Exclude .git folders (these arguments are passed directly to find):
|
||||
rotcheck -a -- ! -path '*/\\.git/*'
|
||||
|
||||
EOF
|
||||
exit 0
|
||||
}
|
||||
|
||||
fail() {
|
||||
printf '%s\n' "$@"; exit 1
|
||||
}
|
||||
|
||||
# Curiously, I stumbled across a bug in bash-3.0.16 (c. 2004) or older
|
||||
# where \0177 (DEL) isn't handled properly. See the `find_safe` function below.
|
||||
# bash-3.1 (c. 2005), dash-0.5.2 (c. 2005), and zsh-3.1 (c. 2000) all work
|
||||
# and probably others too.
|
||||
if [ -n ${BASH+x} ] && [ -n ${BASH_VERSION+x} ]; then
|
||||
if printf '%s' "${BASH_VERSION:-x}" | grep -qE '^[0-2]+|^3\.0'; then
|
||||
fail "bash-3.0.16 and older are broken." \
|
||||
"Try bash>=3.1, dash, zsh, or another POSIX shell."
|
||||
fi
|
||||
fi
|
||||
|
||||
# Command-line arguments. `getopts` is POSIX, while `getopt` is not.
|
||||
[ $# -gt 0 ] && [ "$1" = "--help" ] && usage
|
||||
while getopts ":acdub:f:hinvwxM" opt; do
|
||||
case "$opt" in
|
||||
a) APPEND_MODE=1;;
|
||||
c) CHECK_MODE=1;;
|
||||
d) DELETE_MODE=1;;
|
||||
u) UPDATE_MODE=1;;
|
||||
b) COMMAND="$OPTARG";;
|
||||
f) CHECKFILE="$OPTARG";;
|
||||
h) usage;;
|
||||
i) IGNORE_MISSING=1;;
|
||||
n) FOLLOW_SYMLINKS=0;;
|
||||
v) VERBOSE=1;;
|
||||
w) WARN_FORMATTING=1;;
|
||||
x) EXCLUDE_HIDDEN=1;;
|
||||
M) FORCE_UPDATE=1;;
|
||||
\?) fail "-$OPTARG: Invalid argument";;
|
||||
:) fail "-$OPTARG requires an argument";;
|
||||
esac
|
||||
done; shift $(($OPTIND - 1))
|
||||
|
||||
|
||||
|
||||
# A few sanity checks.
|
||||
MODE=$(($APPEND_MODE + $CHECK_MODE + $DELETE_MODE + $UPDATE_MODE))
|
||||
if [ $MODE -eq 0 ]; then
|
||||
fail "Please specify one of -a, -c, -d, or -u." \
|
||||
"See \`rotcheck -h\` for help with usage."
|
||||
elif [ $MODE -gt 1 ]; then
|
||||
fail "You can only use one of -a, -c, -d, or -u options." \
|
||||
"See \`rotcheck -h\` for help with usage."
|
||||
elif [ $CHECK_MODE -eq 1 ] || [ $DELETE_MODE -eq 1 ]; then
|
||||
if [ ! -f "$CHECKFILE" ]; then
|
||||
fail "$CHECKFILE: No such file." \
|
||||
"Try running \`rotcheck -a\` first, or see \`rotcheck -h\`."
|
||||
fi
|
||||
elif ! command -v "$COMMAND" >/dev/null 2>/dev/null; then
|
||||
fail "$COMMAND: command not found" \
|
||||
"Try specifying a supported command using \`rotcheck -b COMMAND\`." \
|
||||
"You may need to install GNU coreutils or BusyBox." \
|
||||
"On *BSD, GNU coreutils commands begin with 'g', like 'gsha512sum'." \
|
||||
"See \`rotcheck -h\` for help with usage."
|
||||
fi
|
||||
|
||||
# When printing text to terminal, make sure it won't do anything unexpected.
|
||||
printf_sanitized() {
|
||||
printf '%s' "$@" | tr -d '[:cntrl:]' | iconv -cs -f UTF-8 -t UTF-8
|
||||
printf '\n'
|
||||
}
|
||||
|
||||
verify_checksums() {
|
||||
IGNORE="" ; [ $IGNORE_MISSING -eq 1 ] && IGNORE="--ignore-missing"
|
||||
WARN="" ; [ $WARN_FORMATTING -eq 1 ] && WARN="-w"
|
||||
$COMMAND -c $WARN $IGNORE -- "$CHECKFILE"
|
||||
}
|
||||
|
||||
# Just verify checksums.
|
||||
if [ $CHECK_MODE -eq 1 ]; then
|
||||
# Only GNU coreutils supports `--quiet`, so use `grep -v` instead.
|
||||
# Unfortunately, pipefail isn't POSIX so to return the exit status from the
|
||||
# checksum command, we have to be clever (aka crazy) with file descriptors
|
||||
# and subshells instead.
|
||||
if [ $VERBOSE -eq 1 ]; then
|
||||
verify_checksums
|
||||
exit $?
|
||||
else
|
||||
exec 4>&1
|
||||
(
|
||||
exec 3>&1
|
||||
(
|
||||
# 2>&1 preserves order of stdout/stderr.
|
||||
verify_checksums 2>&1; printf '%d' $? 1>&3
|
||||
) | grep -Ev ': OK$' 1>&4
|
||||
exec 3>&-
|
||||
) | ( read -r retval; exit $retval ); retval=$?
|
||||
exec 4>&-
|
||||
exit $retval
|
||||
fi
|
||||
fi
|
||||
|
||||
# Delete checksums for files that no longer exist.
|
||||
if [ $DELETE_MODE -eq 1 ]; then
|
||||
i=1
|
||||
for file in $(cut -d ' ' -f 3- -- "$CHECKFILE"); do
|
||||
# `sed -i` isn't POSIX (nor is `mktemp`), so use `ex` instead.
|
||||
if [ ! -f "$file" ]; then
|
||||
cat << EOF | ex -s -- "$CHECKFILE"
|
||||
${i}d
|
||||
x
|
||||
EOF
|
||||
# Print what checksums were deleted.
|
||||
if [ $VERBOSE -eq 1 ]; then
|
||||
printf '%s' "DELETED: "
|
||||
printf_sanitized "$file"
|
||||
fi
|
||||
else
|
||||
# Only increment the line number if we didn't delete a line.
|
||||
i=$(($i + 1))
|
||||
fi
|
||||
done
|
||||
exit $?
|
||||
fi
|
||||
|
||||
# For safety and sanity, ignore all filenames that have control characters
|
||||
# like newline, tab, delete etc.
|
||||
find_safe() {
|
||||
FIND_L=""
|
||||
FIND_FOLLOW=""
|
||||
if [ $FOLLOW_SYMLINKS -eq 1 ]; then
|
||||
# Old versions of findutils don't have -L. Use it if available.
|
||||
if find -L / -maxdepth 0 -type d >/dev/null 2>/dev/null; then
|
||||
FIND_L="-L"
|
||||
else
|
||||
FIND_FOLLOW="-follow"
|
||||
fi
|
||||
fi
|
||||
|
||||
# POSIX find requires that you specify the search path either first
|
||||
# or immediately after -H/-L. Use current directory by default unless
|
||||
# user has specified a path.
|
||||
FIND_DOT="./"
|
||||
if [ $# -gt 0 ]; then
|
||||
first_char="$(printf '%s' "$1" | cut -c 1)"
|
||||
# Replace search path unless first arg is a non-path `find` option.
|
||||
if [ "$first_char" != "-" ] \
|
||||
&& [ "$first_char" != "!" ] && [ "$first_char" != "(" ]; then
|
||||
FIND_DOT=""
|
||||
fi
|
||||
fi
|
||||
|
||||
HIDDEN=""
|
||||
[ $EXCLUDE_HIDDEN -eq 1 ] && HIDDEN='*/\.*'
|
||||
|
||||
find $FIND_L $FIND_DOT "$@" $FIND_FOLLOW \
|
||||
-type f ! -path "$CHECKFILE" ! -path "$HIDDEN" \
|
||||
! -name "$(printf '*%b*' '\0001')" ! -name "$(printf '*%b*' '\0002')" \
|
||||
! -name "$(printf '*%b*' '\0003')" ! -name "$(printf '*%b*' '\0004')" \
|
||||
! -name "$(printf '*%b*' '\0005')" ! -name "$(printf '*%b*' '\0006')" \
|
||||
! -name "$(printf '*%b*' '\0007')" ! -name "$(printf '*%b*' '\0010')" \
|
||||
! -name "$(printf '*%b*' '\0011')" ! -name "$(printf '*%b*' '\0012')" \
|
||||
! -name "$(printf '*%b*' '\0013')" ! -name "$(printf '*%b*' '\0014')" \
|
||||
! -name "$(printf '*%b*' '\0015')" ! -name "$(printf '*%b*' '\0016')" \
|
||||
! -name "$(printf '*%b*' '\0017')" ! -name "$(printf '*%b*' '\0020')" \
|
||||
! -name "$(printf '*%b*' '\0021')" ! -name "$(printf '*%b*' '\0022')" \
|
||||
! -name "$(printf '*%b*' '\0023')" ! -name "$(printf '*%b*' '\0024')" \
|
||||
! -name "$(printf '*%b*' '\0025')" ! -name "$(printf '*%b*' '\0026')" \
|
||||
! -name "$(printf '*%b*' '\0027')" ! -name "$(printf '*%b*' '\0030')" \
|
||||
! -name "$(printf '*%b*' '\0031')" ! -name "$(printf '*%b*' '\0032')" \
|
||||
! -name "$(printf '*%b*' '\0033')" ! -name "$(printf '*%b*' '\0034')" \
|
||||
! -name "$(printf '*%b*' '\0035')" ! -name "$(printf '*%b*' '\0036')" \
|
||||
! -name "$(printf '*%b*' '\0037')" ! -name "$(printf '*%b*' '\0177')"
|
||||
}
|
||||
|
||||
find_updated_files() {
|
||||
if [ $FORCE_UPDATE -eq 1 ]; then
|
||||
find_safe "$@"
|
||||
else
|
||||
find_safe "$@" -newer "$CHECKFILE"
|
||||
fi
|
||||
}
|
||||
|
||||
# This function could be replaced entirely with the much simpler:
|
||||
# cut -d ' ' -f 3- "$CHECKFILE" | grep -Fxn -- "$file" | cut -d ':' -f 1
|
||||
# But this function is slightly faster as it avoids passing huge chunks of text
|
||||
# (ie, the whole checksum file minus the first column) through a pipe.
|
||||
get_line_number() {
|
||||
# Avoid `grep -E` as filename characters might get interpreted (eg, $).
|
||||
for l in $(grep -Fn -- "$file" "$CHECKFILE" | cut -d ':' -f 1); do
|
||||
if sed -n -e "${l}p" -- "$CHECKFILE" \
|
||||
| cut -d ' ' -f 3- | grep -Fxq -- "$file" >/dev/null; then
|
||||
printf '%d' "$l"
|
||||
return 0
|
||||
fi
|
||||
done
|
||||
printf '%d' "0"
|
||||
}
|
||||
|
||||
umask 077
|
||||
# For files with a modification date newer than the checksum file, if there's
|
||||
# an existing checksum then update it. Otherwise append a new checksum.
|
||||
if [ $UPDATE_MODE -eq 1 ] && [ -f "$CHECKFILE" ]; then
|
||||
for file in $(find_updated_files "$@"); do
|
||||
line_num="$(get_line_number)"
|
||||
if [ ${line_num:-0} -eq 0 ]; then
|
||||
# No checksum yet, so append one.
|
||||
$COMMAND -- "$file" >> "$CHECKFILE"
|
||||
else
|
||||
old="$(sed -n -e "${line_num}p" -- "$CHECKFILE" | cut -d ' ' -f 1)"
|
||||
new="$($COMMAND -- "$file")"
|
||||
# Should never happen, but double check these aren't empty:
|
||||
if [ -z ${old:+x} ] || [ -z ${new:+x} ]; then
|
||||
continue
|
||||
fi
|
||||
# `sed -i` isn't POSIX (nor is `mktemp`), so use `ex` instead.
|
||||
if [ "$old" != "${new%% *}" ]; then
|
||||
cat << EOF | ex -s -- "$CHECKFILE"
|
||||
${line_num}c
|
||||
$new
|
||||
.
|
||||
x
|
||||
EOF
|
||||
# Bail immediately if something went wrong.
|
||||
[ $? -ne 0 ] && fail "Failed to update checksum file."
|
||||
|
||||
# Print what checksums were changed.
|
||||
if [ $VERBOSE -eq 1 ]; then
|
||||
printf '%s' "CHANGED: "
|
||||
printf_sanitized "$file"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
# Append checksums for files that have no checksum yet.
|
||||
if [ $APPEND_MODE -eq 1 ] || [ $UPDATE_MODE -eq 1 ]; then
|
||||
for file in $(find_safe "$@"); do
|
||||
# Avoid `grep -E` as filename characters might get interpreted (eg, $).
|
||||
# The first grep isn't strictly needed, but grep+cut+grep is faster
|
||||
# than just cut+grep here.
|
||||
if [ ! -f "$CHECKFILE" ] || ! grep -- "$file" "$CHECKFILE" \
|
||||
| cut -d ' ' -f 3- | grep -Fxq -- "$file"; then
|
||||
if ! $COMMAND -- "$file" >> "$CHECKFILE"; then
|
||||
fail "Failed to write to checksum file."
|
||||
fi
|
||||
|
||||
# Print what checksums were appended.
|
||||
if [ $VERBOSE -eq 1 ]; then
|
||||
printf '%s' "ADDED: "
|
||||
printf_sanitized "$file"
|
||||
fi
|
||||
fi
|
||||
done
|
||||
fi
|
3
config/.gitignore
vendored
@ -1,3 +0,0 @@
|
||||
*
|
||||
!.gitignore
|
||||
!default.nix
|
@ -1,29 +0,0 @@
|
||||
{
|
||||
browser = "/usr/bin/firefox";
|
||||
|
||||
git = {
|
||||
user = {
|
||||
email = "me@mediocregopher.com";
|
||||
name = "Brian Picciano";
|
||||
};
|
||||
};
|
||||
|
||||
awesome = {
|
||||
startupExtra = "";
|
||||
};
|
||||
|
||||
alacritty = {
|
||||
fontSize = 11;
|
||||
xdgOpenRules = [
|
||||
#{
|
||||
# name = "some-unique-name";
|
||||
# pattern = "regex pattern";
|
||||
|
||||
# # where $1 is the string which matched pattern
|
||||
# xdgOpen = "https://some-url/$1";
|
||||
#}
|
||||
];
|
||||
};
|
||||
|
||||
binExtra = [];
|
||||
}
|
109
default.nix
@ -1,34 +1,13 @@
|
||||
{
|
||||
|
||||
hostConfig,
|
||||
pkgsSrc ? ./pkgs.nix
|
||||
|
||||
pkgs ? (import ./pkgs.nix).stable {},
|
||||
pkgs2305 ? (import ./pkgs.nix).stable2305 {},
|
||||
}: rec {
|
||||
|
||||
}: let
|
||||
pkgs = (import pkgsSrc) {};
|
||||
|
||||
config = (import ./config/default.nix) // hostConfig ;
|
||||
|
||||
in rec {
|
||||
|
||||
gitConfig = pkgs.stdenv.mkDerivation {
|
||||
name = "mediocregopher-git-config";
|
||||
|
||||
gitConfigBase = ./base/gitconfig;
|
||||
gitConfigCustom = builtins.toFile "mediocregopher-git-config-custom"
|
||||
(pkgs.lib.generators.toGitINI config.git);
|
||||
|
||||
builder = builtins.toFile "builder.sh" ''
|
||||
source $stdenv/setup
|
||||
|
||||
dir="$out"/git
|
||||
mkdir -p "$dir"
|
||||
|
||||
cp "$gitConfigBase" "$dir"/config
|
||||
cp "$gitConfigCustom" "$dir"/custom
|
||||
'';
|
||||
|
||||
};
|
||||
gitConfig = pkgs.writeTextDir "git/config"
|
||||
(builtins.readFile ./base/gitconfig);
|
||||
|
||||
git = pkgs.writeScriptBin "git" ''
|
||||
#!${pkgs.bash}/bin/bash
|
||||
@ -36,22 +15,21 @@ in rec {
|
||||
exec ${pkgs.git}/bin/git "$@"
|
||||
'';
|
||||
|
||||
zsh = ((import ./zsh) { inherit config; }).zsh;
|
||||
zsh = ((import ./zsh) { inherit pkgs; }).zsh;
|
||||
|
||||
loadout = pkgs.buildEnv {
|
||||
name = "loadout";
|
||||
paths = [
|
||||
pkgs2305.nix
|
||||
|
||||
pkgs.gnugrep
|
||||
pkgs.ag
|
||||
pkgs.gawk
|
||||
pkgs.tree
|
||||
|
||||
git
|
||||
pkgs.mercurial
|
||||
pkgs.breezy # bzr
|
||||
|
||||
pkgs.gcc
|
||||
pkgs.gnumake
|
||||
pkgs.cmake
|
||||
pkgs.strace
|
||||
@ -65,14 +43,11 @@ in rec {
|
||||
pkgs.nmap
|
||||
pkgs.dnsutils
|
||||
pkgs.openssh
|
||||
pkgs.sshfs
|
||||
pkgs.fuse3
|
||||
|
||||
pkgs.tmux
|
||||
|
||||
pkgs.ncdu
|
||||
pkgs.htop
|
||||
pkgs.jnettop
|
||||
|
||||
pkgs.unzip
|
||||
pkgs.unrar
|
||||
@ -80,22 +55,70 @@ in rec {
|
||||
|
||||
pkgs.jq
|
||||
pkgs.yq
|
||||
pkgs.go
|
||||
|
||||
pkgs.tomb
|
||||
pkgs.udiskie
|
||||
pkgs.xsel
|
||||
pkgs.pavucontrol
|
||||
pkgs.xdg-utils
|
||||
|
||||
((import ./nvim) {}).nvim
|
||||
(pkgs.nerdfonts.override { fonts = [ "SourceCodePro" ]; })
|
||||
|
||||
((import ./nvim) { inherit pkgs; }).nvim
|
||||
zsh
|
||||
((import ./alacritty) { inherit config zsh; }).alacritty
|
||||
((import ./awesome) { inherit config; }).awesome
|
||||
((import ./alacritty) { inherit pkgs zsh; }).alacritty
|
||||
((import ./awesome) { inherit pkgs; }).awesome
|
||||
];
|
||||
};
|
||||
|
||||
fonts = pkgs.buildEnv {
|
||||
name = "fonts";
|
||||
paths = [
|
||||
pkgs.nerdfonts
|
||||
pkgs.source-code-pro
|
||||
];
|
||||
appimageEntrypoint = pkgs.writeScript "mediocre-loadout" ''
|
||||
#!${pkgs.bash}/bin/bash
|
||||
|
||||
cmd="$1"; shift;
|
||||
|
||||
if [ "$cmd" = "nvim" ]; then exec nvim "$@"; fi
|
||||
if [ "$cmd" = "zsh" ]; then exec zsh "$@"; fi
|
||||
if [ "$cmd" = "alacritty" ]; then exec alacritty "$@"; fi
|
||||
if [ "$cmd" = "awesome" ]; then exec awesome "$@"; fi
|
||||
|
||||
echo "USAGE: $0 [nvim|zsh|alacritty|awesome] [passthrough args...]"
|
||||
exit 1
|
||||
'';
|
||||
|
||||
appimageDesktopFile = builtins.toFile "mediocre-loadout.desktop" ''
|
||||
[Desktop Entry]
|
||||
Name=Mediocre Loadout
|
||||
Exec=mediocre-loadout alacritty
|
||||
Icon=mediocre-loadout
|
||||
Type=Application
|
||||
Categories=Utility;
|
||||
'';
|
||||
|
||||
appdir = pkgs.stdenv.mkDerivation {
|
||||
name = "mediocre-loadout-target-flat";
|
||||
|
||||
inherit appimageEntrypoint appimageDesktopFile;
|
||||
appimageIcon = ./bonzi.png;
|
||||
src = loadout;
|
||||
|
||||
builder = builtins.toFile "builder.sh" ''
|
||||
source $stdenv/setup
|
||||
|
||||
cp -rL "$src" "$out"
|
||||
chmod -R +w "$out"
|
||||
|
||||
rm -rf "$out"/share/applications/*
|
||||
cp "$appimageDesktopFile" "$out"/share/applications/mediocre-loadout.desktop
|
||||
cp "$appimageEntrypoint" "$out"/bin/mediocre-loadout
|
||||
|
||||
icondir=share/icons/hicolor/256x256/apps
|
||||
mkdir -p "$out"/$icondir
|
||||
cp "$appimageIcon" "$out"/$icondir/mediocre-loadout.png
|
||||
'';
|
||||
};
|
||||
|
||||
appimage = ((import ./appimage.nix) { pkgsSrc = pkgsSrc; }) {
|
||||
name = "mediocre-loadout";
|
||||
target = appdir;
|
||||
};
|
||||
|
||||
}
|
||||
|
@ -1,6 +1,19 @@
|
||||
{}: rec {
|
||||
{
|
||||
|
||||
pkgs = (import ../pkgs.nix).stable2305 {};
|
||||
pkgs ? (import ../pkgs.nix) {},
|
||||
|
||||
}: rec {
|
||||
|
||||
goimports = pkgs.buildGoModule rec {
|
||||
pname = "goimports";
|
||||
version = "v0.1.7";
|
||||
src = builtins.fetchGit {
|
||||
url = "https://go.googlesource.com/tools";
|
||||
rev = "0df0ca0f43117120bd7cc900ebf765f9b799438a";
|
||||
};
|
||||
vendorSha256 = "1vs4vbl3kh8lbqrm4yqqn27ammlqj7jdbi0ca9s4fkja2sk45ibi";
|
||||
subPackages = [ "cmd/goimports" ];
|
||||
};
|
||||
|
||||
misspell = pkgs.buildGoPackage rec {
|
||||
pname = "misspell";
|
||||
@ -17,10 +30,36 @@
|
||||
goDeps = ./misspellDeps.nix;
|
||||
};
|
||||
|
||||
# the gocode-gomod which comes with nixpkgs places the binary at
|
||||
# gocode-gomod, we gotta rename it
|
||||
gocode = pkgs.stdenv.mkDerivation {
|
||||
name = "gocode";
|
||||
src = pkgs.gocode-gomod;
|
||||
builder = builtins.toFile "builder.sh" ''
|
||||
source $stdenv/setup
|
||||
mkdir -p "$out"/bin/
|
||||
cp "$src"/bin/gocode-gomod "$out"/bin/gocode
|
||||
'';
|
||||
};
|
||||
|
||||
env = pkgs.buildEnv {
|
||||
name = "nvim-env";
|
||||
paths = [
|
||||
pkgs.shellcheck
|
||||
pkgs.vimPlugins.vim-plug
|
||||
pkgs.vimPlugins.deoplete-nvim
|
||||
pkgs.vimPlugins.deoplete-go
|
||||
pkgs.vimPlugins.nerdtree
|
||||
pkgs.vimPlugins.nerdtree-git-plugin
|
||||
pkgs.vimPlugins.vim-gitgutter
|
||||
pkgs.vimPlugins.neomake
|
||||
pkgs.vimPlugins.papercolor-theme
|
||||
pkgs.vimPlugins.vim-go
|
||||
pkgs.vimPlugins.vim-nix
|
||||
|
||||
pkgs.golangci-lint
|
||||
pkgs.gopls
|
||||
gocode
|
||||
goimports
|
||||
misspell
|
||||
];
|
||||
};
|
||||
@ -28,18 +67,18 @@
|
||||
envPlugins = "${env}/share/vim-plugins";
|
||||
|
||||
init = pkgs.writeText "nvim-init" ''
|
||||
source ${pkgs.vimPlugins.vim-plug}/plug.vim
|
||||
source ${envPlugins}/vim-plug/plug.vim
|
||||
|
||||
call plug#begin()
|
||||
Plug '${pkgs.vimPlugins.deoplete-nvim}'
|
||||
Plug '${pkgs.vimPlugins.nerdtree}', { 'on': 'NERDTreeToggle' }
|
||||
Plug '${pkgs.vimPlugins.nerdtree-git-plugin}'
|
||||
Plug '${pkgs.vimPlugins.vim-gitgutter}'
|
||||
Plug '${pkgs.vimPlugins.neomake}'
|
||||
Plug '${pkgs.vimPlugins.papercolor-theme}'
|
||||
Plug '${pkgs.vimPlugins.vim-go}', { 'for': 'go' }
|
||||
Plug '${pkgs.vimPlugins.vim-nix}', { 'for': 'nix' }
|
||||
Plug '${pkgs.vimPlugins.rust-vim}', { 'for': 'rust' }
|
||||
call plug#begin('${envPlugins}')
|
||||
Plug '${envPlugins}/deoplete-nvim'
|
||||
Plug '${envPlugins}/deoplete-go', { 'for': 'go' }
|
||||
Plug '${envPlugins}/nerdtree', { 'on': 'NERDTreeToggle' }
|
||||
Plug '${envPlugins}/nerdtree-git-plugin'
|
||||
Plug '${envPlugins}/vim-gitgutter'
|
||||
Plug '${envPlugins}/neomake'
|
||||
Plug '${envPlugins}/papercolor-theme'
|
||||
Plug '${envPlugins}/vim-go', { 'for': 'go' }
|
||||
Plug '${envPlugins}/vim-nix', { 'for': 'nix' }
|
||||
call plug#end()
|
||||
|
||||
source ${./init.vim}
|
||||
@ -53,12 +92,12 @@
|
||||
|
||||
rplugin = pkgs.stdenv.mkDerivation {
|
||||
name = "nvim-rplugin";
|
||||
buildInputs = [ pkgs.git pkgs.tree nvimRaw ];
|
||||
buildInputs = [ pkgs.git nvimRaw ];
|
||||
builder = builtins.toFile "builder.sh" ''
|
||||
source $stdenv/setup
|
||||
mkdir -p "$out"/
|
||||
export NVIM_RPLUGIN_MANIFEST="$out"/rplugin.vim
|
||||
nvim -i NONE -c ':UpdateRemotePlugins' -c ':exit' >/dev/null
|
||||
nvim -c ':UpdateRemotePlugins' -c ':exit' >/dev/null
|
||||
'';
|
||||
};
|
||||
|
||||
|
@ -1,23 +1,16 @@
|
||||
|
||||
set noswapfile
|
||||
|
||||
" PaperColor ###############################################################
|
||||
|
||||
set background=light
|
||||
colorscheme PaperColor
|
||||
|
||||
" Deoplete #################################################################
|
||||
|
||||
let g:deoplete#enable_at_startup = 1
|
||||
" use tab to cycle
|
||||
inoremap <expr><tab> pumvisible() ? "\<c-n>" : "\<tab>"
|
||||
" close preview when leaving insert
|
||||
autocmd InsertLeave,CompleteDone * if pumvisible() == 0 | pclose | endif
|
||||
" use omni completion for go, provided by vim-go
|
||||
call deoplete#custom#option('omni_patterns', { 'go': '[^. *\t]\.\w*' })
|
||||
|
||||
" NERDTree #################################################################
|
||||
|
||||
let NERDTreeMouseMode=3
|
||||
let NERDTreeMinimalUI=1
|
||||
let NERDTreeAutoDeleteBuffer=1
|
||||
@ -40,16 +33,11 @@ map <C-n> :NERDTreeToggle<CR>
|
||||
autocmd BufEnter * if &buftype == 'terminal' | :startinsert | endif
|
||||
|
||||
" vim-go ###################################################################
|
||||
|
||||
let g:go_fmt_autosave = 1
|
||||
let g:go_fmt_command="goimports"
|
||||
|
||||
" rust.vim ###################################################################
|
||||
|
||||
let g:rustfmt_autosave = 1
|
||||
"
|
||||
"use goimports for formatting instead of gofmt
|
||||
let g:go_fmt_command = "goimports"
|
||||
|
||||
" neomake ##################################################################
|
||||
|
||||
autocmd! BufWritePost * Neomake
|
||||
"let g:neomake_verbose=3
|
||||
"let g:neomake_logfile='/tmp/neomake.log'
|
||||
@ -61,6 +49,35 @@ autocmd! BufWritePost * Neomake
|
||||
let g:neomake_open_list=0
|
||||
let g:neomake_place_signs=0
|
||||
|
||||
let g:neomake_go_enabled_makers = ['go', 'golangcilint']
|
||||
let g:neomake_go_golangcilint_maker = {
|
||||
\ 'exe': 'golangci-lint',
|
||||
\ 'args': [
|
||||
\ 'run',
|
||||
\ '--no-config',
|
||||
\ '--out-format=line-number',
|
||||
\ '--print-issued-lines=false',
|
||||
\ '-E=durationcheck',
|
||||
\ '-E=errorlint',
|
||||
\ '-E=exportloopref',
|
||||
\ '-E=forbidigo',
|
||||
\ '-E=gochecknoinits',
|
||||
\ '-E=godot',
|
||||
\ '-E=goimports',
|
||||
\ '-E=misspell',
|
||||
\ '-E=revive',
|
||||
\ '-E=unconvert',
|
||||
\ '-E=unparam',
|
||||
\ '.'
|
||||
\ ],
|
||||
\ 'output_stream': 'stdout',
|
||||
\ 'append_file': 0,
|
||||
\ 'cwd': '%:h',
|
||||
\ 'errorformat':
|
||||
\ '%f:%l:%c: %m,' .
|
||||
\ '%f:%l: %m'
|
||||
\ }
|
||||
|
||||
let g:neomake_markdown_enabled_makers = ['misspell']
|
||||
let g:neomake_markdown_misspell_maker = {
|
||||
\ 'errorformat': '%f:%l:%c:%m',
|
||||
@ -71,7 +88,11 @@ let g:neomake_markdown_misspell_maker = {
|
||||
"Makes current line/column highlighted, and set text width
|
||||
set tw=80
|
||||
set colorcolumn=+1
|
||||
"autocmd bufenter * set cursorline cursorcolumn colorcolumn=+1
|
||||
"autocmd bufleave * set nocursorline nocursorcolumn colorcolumn=0
|
||||
hi ColorColumn ctermfg=none ctermbg=grey cterm=none
|
||||
"hi CursorLine ctermfg=none ctermbg=lightgrey cterm=none
|
||||
"hi CursorColumn ctermfg=none ctermbg=lightgrey cterm=none
|
||||
|
||||
"Buffers scroll a bit so cursor doens't go all the way to the bottom before
|
||||
"scroll begins
|
||||
@ -102,7 +123,6 @@ au FileType yaml setlocal tabstop=2 shiftwidth=2
|
||||
au FileType html setlocal tabstop=2 shiftwidth=2
|
||||
au FileType proto setlocal tabstop=2 shiftwidth=2
|
||||
au FileType javascript setlocal tabstop=2 shiftwidth=2
|
||||
au FileType typescript setlocal tabstop=2 shiftwidth=2
|
||||
|
||||
"We want certain types to use tabs instead of spaces
|
||||
au FileType go setlocal nolist noexpandtab
|
||||
@ -140,9 +160,6 @@ noremap <leader>tx :tabclose<CR>
|
||||
" yank/paste into/from clipboard
|
||||
set clipboard+=unnamedplus
|
||||
|
||||
" Enable mouse in all modes
|
||||
set mouse=
|
||||
|
||||
"Clojure specific mappings
|
||||
" Eval outerform
|
||||
au FileType clojure nmap <buffer> cpP :Eval<cr>
|
||||
|
43
pkgs.nix
@ -1,6 +1,10 @@
|
||||
rec {
|
||||
let
|
||||
|
||||
mkPkgs = src: let
|
||||
src = builtins.fetchTarball {
|
||||
name = "nixpkgs-2105";
|
||||
url = "https://github.com/nixos/nixpkgs/archive/7e9b0dff974c89e070da1ad85713ff3c20b0ca97.tar.gz";
|
||||
sha256 = "1ckzhh24mgz6jd1xhfgx0i9mijk6xjqxwsshnvq789xsavrmsc36";
|
||||
};
|
||||
|
||||
normalPkgs = (import src) {};
|
||||
|
||||
@ -8,12 +12,17 @@ rec {
|
||||
allowUnfree = true;
|
||||
packageOverrides = pkgs: {
|
||||
|
||||
go = builtins.fetchTarball {
|
||||
url = "https://golang.org/dl/go1.17.1.linux-amd64.tar.gz";
|
||||
sha256 = "1196h1jx9cn5ks1y9r95z0q2s6m6ssvnx7jd34g435jvxjgb2c94";
|
||||
};
|
||||
|
||||
nixgl = let
|
||||
|
||||
src = builtins.fetchTarball {
|
||||
name = "nixgl-unstable";
|
||||
url = "https://github.com/guibou/nixGL/archive/7165ffbccbd2cf4379b6cd6d2edd1620a427e5ae.tar.gz";
|
||||
sha256 = "1wc85xqnq2wb008y9acb29jbfkc242m9697g2b8j6q3yqmfhrks1";
|
||||
url = "https://github.com/guibou/nixGL/archive/51f19871a31b15b482ac4c80976da173289e77fb.tar.gz";
|
||||
sha256 = "0dj2apbx5iqvkiixyz1dzx4id51iw9s2isp1f9x60a03f5sqcvvi";
|
||||
};
|
||||
|
||||
nixgl = (import src) {
|
||||
@ -21,30 +30,12 @@ rec {
|
||||
enable32bits = false;
|
||||
};
|
||||
|
||||
in nixgl.auto.nixGLDefault;
|
||||
in nixgl.nixGLIntel;
|
||||
|
||||
};
|
||||
};
|
||||
|
||||
in pkgsArg: (import src) (
|
||||
in pkgsArg:
|
||||
(import src) (
|
||||
normalPkgs.lib.attrsets.recursiveUpdate { config = config; } pkgsArg
|
||||
);
|
||||
|
||||
stable = mkPkgs (builtins.fetchTarball {
|
||||
name = "nixpkgs-2105";
|
||||
url = "https://github.com/nixos/nixpkgs/archive/7e9b0dff974c89e070da1ad85713ff3c20b0ca97.tar.gz";
|
||||
sha256 = "1ckzhh24mgz6jd1xhfgx0i9mijk6xjqxwsshnvq789xsavrmsc36";
|
||||
});
|
||||
|
||||
stable2305 = mkPkgs (builtins.fetchTarball {
|
||||
name = "nixpkgs-2305";
|
||||
url = "https://github.com/nixos/nixpkgs/archive/4ecab3273592f27479a583fb6d975d4aba3486fe.tar.gz";
|
||||
sha256 = "sha256:10wn0l08j9lgqcw8177nh2ljrnxdrpri7bp0g7nvrsn9rkawvlbf";
|
||||
});
|
||||
|
||||
edge = mkPkgs (builtins.fetchTarball {
|
||||
name = "nixpkgs-edge";
|
||||
url = "https://github.com/nixos/nixpkgs/archive/f9418c4c7fab906c52ae07cf27a618de7722d1e9.tar.gz";
|
||||
sha256 = "sha256:067m1gzj1n06m3anshwgabd1liaja8gcvd90spmnyi3a6vhqdvq0";
|
||||
});
|
||||
}
|
||||
)
|
||||
|
@ -1,29 +1,11 @@
|
||||
{
|
||||
|
||||
pkgs ? (import ../pkgs.nix).stable {},
|
||||
config,
|
||||
pkgs ? (import ../pkgs.nix) {},
|
||||
|
||||
}: rec {
|
||||
|
||||
ohMyZsh = ./oh-my-zsh;
|
||||
|
||||
bin = pkgs.buildEnv {
|
||||
name = "mediocregopher-bin";
|
||||
paths = [
|
||||
(pkgs.stdenv.mkDerivation {
|
||||
name = "mediocregopher-default-bin";
|
||||
src = ../bin;
|
||||
builder = builtins.toFile "builder.sh" ''
|
||||
source $stdenv/setup
|
||||
mkdir -p "$out"
|
||||
cp -rL "$src" "$out"/bin
|
||||
'';
|
||||
})
|
||||
] ++ (
|
||||
builtins.map (cFn: cFn pkgs) config.binExtra
|
||||
);
|
||||
};
|
||||
|
||||
zshrc = pkgs.writeTextDir ".zshrc" ''
|
||||
|
||||
# oh-my-zsh
|
||||
@ -34,15 +16,10 @@
|
||||
plugins=(git vi-mode)
|
||||
source $ZSH/oh-my-zsh.sh
|
||||
|
||||
export PATH=${bin}/bin:$PATH
|
||||
|
||||
#Global stuff shitty programs use
|
||||
export EDITOR=~/.nix-profile/bin/nvim
|
||||
|
||||
# GPG is needy
|
||||
export GPG_TTY=$(tty)
|
||||
PATH=${../bin}:$PATH
|
||||
|
||||
. ${./zshrc}
|
||||
. ${./env}
|
||||
. ${./aliases}
|
||||
. ${pkgs.nix}/etc/profile.d/nix.sh
|
||||
'';
|
||||
|
18
zsh/env
Normal file
@ -0,0 +1,18 @@
|
||||
#Global stuff shitty programs use
|
||||
export EDITOR=~/.nix-profile/bin/nvim
|
||||
|
||||
#Basics
|
||||
export PATH=$PATH:/bin
|
||||
export PATH=$PATH:/usr/bin
|
||||
export PATH=$PATH:/usr/local/bin
|
||||
|
||||
#my shit
|
||||
export PATH=~/bin:$PATH
|
||||
|
||||
#Go has its own path system. Way to be difficult go
|
||||
export GOPATH=~/.go
|
||||
export GOBIN=$GOPATH/bin
|
||||
export PATH=$GOPATH/bin:$PATH
|
||||
|
||||
# GPG is needy
|
||||
export GPG_TTY=$(tty)
|