↔️ move old dotfiles to config
This commit is contained in:
45
config/.Brewfile
Normal file
45
config/.Brewfile
Normal file
@ -0,0 +1,45 @@
|
||||
# ~/.Brewfile
|
||||
|
||||
# taps
|
||||
tap 'homebrew/cask-drivers'
|
||||
tap 'homebrew/cask-fonts'
|
||||
|
||||
# brews
|
||||
brew 'coreutils'
|
||||
brew 'mas'
|
||||
|
||||
# casks
|
||||
cask '1password'
|
||||
cask 'alfred'
|
||||
cask 'brave-browser'
|
||||
cask 'dash'
|
||||
cask 'discord'
|
||||
cask 'docker'
|
||||
cask 'fantastical'
|
||||
cask 'figma'
|
||||
cask 'firefox'
|
||||
cask 'font-jetbrains-mono'
|
||||
cask 'google-chrome'
|
||||
cask 'hazel'
|
||||
cask 'iterm2'
|
||||
cask 'keybase'
|
||||
cask 'microsoft-edge'
|
||||
cask 'slack'
|
||||
cask 'sonos'
|
||||
cask 'spotify'
|
||||
cask 'stats'
|
||||
cask 'syncthing'
|
||||
cask 'synology-drive'
|
||||
cask 'visual-studio-code'
|
||||
cask 'zoomus'
|
||||
|
||||
# mac app store
|
||||
mas 'Bumpr', id: 1166066070
|
||||
mas 'Day One', id: 1055511498
|
||||
mas 'Drafts', id: 1435957248
|
||||
mas 'Magnet', id: 441258766
|
||||
mas 'Parcel', id: 639968404
|
||||
mas 'Reeder', id: 1529448980
|
||||
mas 'Todoist', id: 585829637
|
||||
mas 'UlyssesMac', id: 1225570693
|
||||
mas 'Xcode', id: 497799835
|
17
config/.config/starship.toml
Normal file
17
config/.config/starship.toml
Normal file
@ -0,0 +1,17 @@
|
||||
[character]
|
||||
success_symbol = "[»](bold green) "
|
||||
error_symbol = "[✗](bold red) "
|
||||
|
||||
[directory]
|
||||
fish_style_pwd_dir_length = 1
|
||||
truncation_length = 1
|
||||
|
||||
[gcloud]
|
||||
disabled=true
|
||||
|
||||
[hostname]
|
||||
ssh_only = false
|
||||
format = "[$hostname]($style):"
|
||||
|
||||
[username]
|
||||
format = "[$user]($style)@"
|
6
config/.default-gems
Normal file
6
config/.default-gems
Normal file
@ -0,0 +1,6 @@
|
||||
bundler
|
||||
cocoapods
|
||||
jekyll
|
||||
homesick
|
||||
rails
|
||||
rubocop
|
2
config/.default-npm-packages
Normal file
2
config/.default-npm-packages
Normal file
@ -0,0 +1,2 @@
|
||||
expo-cli
|
||||
yarn
|
6
config/.default-python-packages
Normal file
6
config/.default-python-packages
Normal file
@ -0,0 +1,6 @@
|
||||
flake8
|
||||
pipenv
|
||||
pylint
|
||||
pytest
|
||||
pytest-cache
|
||||
wakatime
|
64
config/.doom.d/config.el
Normal file
64
config/.doom.d/config.el
Normal file
@ -0,0 +1,64 @@
|
||||
;;; $DOOMDIR/config.el -*- lexical-binding: t; -*-
|
||||
|
||||
;; Place your private configuration here! Remember, you do not need to run 'doom
|
||||
;; sync' after modifying this file!
|
||||
|
||||
|
||||
;; Some functionality uses this to identify you, e.g. GPG configuration, email
|
||||
;; clients, file templates and snippets.
|
||||
(setq user-full-name "James Walker"
|
||||
user-mail-address "walkah@walkah.net")
|
||||
|
||||
;; Doom exposes five (optional) variables for controlling fonts in Doom. Here
|
||||
;; are the three important ones:
|
||||
;;
|
||||
;; + `doom-font'
|
||||
;; + `doom-variable-pitch-font'
|
||||
;; + `doom-big-font' -- used for `doom-big-font-mode'; use this for
|
||||
;; presentations or streaming.
|
||||
;;
|
||||
;; They all accept either a font-spec, font string ("Input Mono-12"), or xlfd
|
||||
;; font string. You generally only need these two:
|
||||
;; (setq doom-font (font-spec :family "monospace" :size 12 :weight 'semi-light)
|
||||
;; doom-variable-pitch-font (font-spec :family "sans" :size 13))
|
||||
(setq doom-font (font-spec :family "JetBrains Mono" :size 14))
|
||||
|
||||
;; There are two ways to load a theme. Both assume the theme is installed and
|
||||
;; available. You can either set `doom-theme' or manually load a theme with the
|
||||
;; `load-theme' function. This is the default:
|
||||
(setq doom-theme 'doom-one)
|
||||
|
||||
;; If you use `org' and don't want your org files in the default location below,
|
||||
;; change `org-directory'. It must be set before org loads!
|
||||
(setq org-directory "~/.org"
|
||||
org-roam-directory "~/.org"
|
||||
deft-directory "~/.org"
|
||||
deft-default-extension "org"
|
||||
deft-recursive t)
|
||||
|
||||
;; This determines the style of line numbers in effect. If set to `nil', line
|
||||
;; numbers are disabled. For relative line numbers, set this to `relative'.
|
||||
(setq display-line-numbers-type t)
|
||||
|
||||
|
||||
;; Here are some additional functions/macros that could help you configure Doom:
|
||||
;;
|
||||
;; - `load!' for loading external *.el files relative to this one
|
||||
;; - `use-package!' for configuring packages
|
||||
;; - `after!' for running code after a package has loaded
|
||||
;; - `add-load-path!' for adding directories to the `load-path', relative to
|
||||
;; this file. Emacs searches the `load-path' when you load packages with
|
||||
;; `require' or `use-package'.
|
||||
;; - `map!' for binding new keys
|
||||
;;
|
||||
;; To get information about any of these functions/macros, move the cursor over
|
||||
;; the highlighted symbol at press 'K' (non-evil users must press 'C-c c k').
|
||||
;; This will open documentation for it, including demos of how they are used.
|
||||
;;
|
||||
;; You can also try 'gd' (or 'C-c c d') to jump to their definition and see how
|
||||
;; they are implemented.
|
||||
;;
|
||||
(global-wakatime-mode)
|
||||
(pinentry-start)
|
||||
|
||||
(add-to-list 'auto-mode-alist '("\\.njk" . web-mode))
|
188
config/.doom.d/init.el
Normal file
188
config/.doom.d/init.el
Normal file
@ -0,0 +1,188 @@
|
||||
;;; init.el -*- lexical-binding: t; -*-
|
||||
;;;
|
||||
|
||||
;; This file controls what Doom modules are enabled and what order they load
|
||||
;; in. Remember to run 'doom sync' after modifying it!
|
||||
|
||||
;; NOTE Press 'SPC h d h' (or 'C-h d h' for non-vim users) to access Doom's
|
||||
;; documentation. There you'll find a "Module Index" link where you'll find
|
||||
;; a comprehensive list of Doom's modules and what flags they support.
|
||||
|
||||
;; NOTE Move your cursor over a module's name (or its flags) and press 'K' (or
|
||||
;; 'C-c c k' for non-vim users) to view its documentation. This works on
|
||||
;; flags as well (those symbols that start with a plus).
|
||||
;;
|
||||
;; Alternatively, press 'gd' (or 'C-c c d') on a module to browse its
|
||||
;; directory (for easy access to its source code).
|
||||
|
||||
(doom! :input
|
||||
;;chinese
|
||||
;;japanese
|
||||
;;layout ; auie,ctsrnm is the superior home row
|
||||
|
||||
:completion
|
||||
company ; the ultimate code completion backend
|
||||
;;helm ; the *other* search engine for love and life
|
||||
;;ido ; the other *other* search engine...
|
||||
ivy ; a search engine for love and life
|
||||
|
||||
:ui
|
||||
deft ; notational velocity for Emacs
|
||||
doom ; what makes DOOM look the way it does
|
||||
doom-dashboard ; a nifty splash screen for Emacs
|
||||
doom-quit ; DOOM quit-message prompts when you quit Emacs
|
||||
(emoji +unicode) ; 🙂
|
||||
fill-column ; a `fill-column' indicator
|
||||
hl-todo ; highlight TODO/FIXME/NOTE/DEPRECATED/HACK/REVIEW
|
||||
;;hydra
|
||||
;;indent-guides ; highlighted indent columns
|
||||
ligatures ; ligatures and symbols to make your code pretty again
|
||||
minimap ; show a map of the code on the side
|
||||
modeline ; snazzy, Atom-inspired modeline, plus API
|
||||
;;nav-flash ; blink cursor line after big motions
|
||||
;;neotree ; a project drawer, like NERDTree for vim
|
||||
ophints ; highlight the region an operation acts on
|
||||
(popup +defaults) ; tame sudden yet inevitable temporary windows
|
||||
;;tabs ; a tab bar for Emacs
|
||||
treemacs ; a project drawer, like neotree but cooler
|
||||
unicode ; extended unicode support for various languages
|
||||
vc-gutter ; vcs diff in the fringe
|
||||
vi-tilde-fringe ; fringe tildes to mark beyond EOB
|
||||
;;window-select ; visually switch windows
|
||||
workspaces ; tab emulation, persistence & separate workspaces
|
||||
;;zen ; distraction-free coding or writing
|
||||
|
||||
:editor
|
||||
(evil +everywhere) ; come to the dark side, we have cookies
|
||||
file-templates ; auto-snippets for empty files
|
||||
fold ; (nigh) universal code folding
|
||||
(format +onsave) ; automated prettiness
|
||||
;;god ; run Emacs commands without modifier keys
|
||||
;;lispy ; vim for lisp, for people who don't like vim
|
||||
;;multiple-cursors ; editing in many places at once
|
||||
;;objed ; text object editing for the innocent
|
||||
;;parinfer ; turn lisp into python, sort of
|
||||
;;rotate-text ; cycle region at point between text candidates
|
||||
snippets ; my elves. They type so I don't have to
|
||||
;;word-wrap ; soft wrapping with language-aware indent
|
||||
|
||||
:emacs
|
||||
dired ; making dired pretty [functional]
|
||||
electric ; smarter, keyword-based electric-indent
|
||||
;;ibuffer ; interactive buffer management
|
||||
undo ; persistent, smarter undo for your inevitable mistakes
|
||||
vc ; version-control and Emacs, sitting in a tree
|
||||
|
||||
:term
|
||||
;;eshell ; the elisp shell that works everywhere
|
||||
;;shell ; simple shell REPL for Emacs
|
||||
;;term ; basic terminal emulator for Emacs
|
||||
vterm ; the best terminal emulation in Emacs
|
||||
|
||||
:checkers
|
||||
syntax ; tasing you for every semicolon you forget
|
||||
;;spell ; tasing you for misspelling mispelling
|
||||
;;grammar ; tasing grammar mistake every you make
|
||||
|
||||
:tools
|
||||
;;ansible
|
||||
;;debugger ; FIXME stepping through code, to help you add bugs
|
||||
direnv
|
||||
docker
|
||||
;;editorconfig ; let someone else argue about tabs vs spaces
|
||||
;;ein ; tame Jupyter notebooks with emacs
|
||||
(eval +overlay) ; run code, run (also, repls)
|
||||
gist ; interacting with github gists
|
||||
lookup ; navigate your code and its documentation
|
||||
lsp
|
||||
magit ; a git porcelain for Emacs
|
||||
make ; run make tasks from Emacs
|
||||
;;pass ; password manager for nerds
|
||||
;;pdf ; pdf enhancements
|
||||
;;prodigy ; FIXME managing external services & code builders
|
||||
;;rgb ; creating color strings
|
||||
;;taskrunner ; taskrunner for all your projects
|
||||
;;terraform ; infrastructure as code
|
||||
;;tmux ; an API for interacting with tmux
|
||||
;;upload ; map local to remote projects via ssh/ftp
|
||||
|
||||
:os
|
||||
(:if IS-MAC macos) ; improve compatibility with macOS
|
||||
;;tty ; improve the terminal Emacs experience
|
||||
|
||||
:lang
|
||||
;;agda ; types of types of types of types...
|
||||
;;cc ; C/C++/Obj-C madness
|
||||
;;clojure ; java with a lisp
|
||||
;;common-lisp ; if you've seen one lisp, you've seen them all
|
||||
;;coq ; proofs-as-programs
|
||||
;;crystal ; ruby at the speed of c
|
||||
;;csharp ; unity, .NET, and mono shenanigans
|
||||
;;data ; config/data formats
|
||||
;;(dart +flutter) ; paint ui and not much else
|
||||
elixir ; erlang done right
|
||||
(elm +lsp) ; care for a cup of TEA?
|
||||
emacs-lisp ; drown in parentheses
|
||||
;;erlang ; an elegant language for a more civilized age
|
||||
;;ess ; emacs speaks statistics
|
||||
;;faust ; dsp, but you get to keep your soul
|
||||
;;fsharp ; ML stands for Microsoft's Language
|
||||
;;fstar ; (dependent) types and (monadic) effects and Z3
|
||||
;;gdscript ; the language you waited for
|
||||
(go +lsp) ; the hipster dialect
|
||||
(haskell +lsp) ; a language that's lazier than I am
|
||||
;;hy ; readability of scheme w/ speed of python
|
||||
;;idris ; a language you can depend on
|
||||
json ; At least it ain't XML
|
||||
;;(java +meghanada) ; the poster child for carpal tunnel syndrome
|
||||
javascript ; all(hope(abandon(ye(who(enter(here))))))
|
||||
;;julia ; a better, faster MATLAB
|
||||
;;kotlin ; a better, slicker Java(Script)
|
||||
;;latex ; writing papers in Emacs has never been so fun
|
||||
;;lean
|
||||
;;factor
|
||||
;;ledger ; an accounting system in Emacs
|
||||
;;lua ; one-based indices? one-based indices
|
||||
markdown ; writing docs for people to ignore
|
||||
;;nim ; python + lisp at the speed of c
|
||||
nix ; I hereby declare "nix geht mehr!"
|
||||
;;ocaml ; an objective camel
|
||||
(org +roam) ; organize your plain life in plain text
|
||||
;;php ; perl's insecure younger brother
|
||||
;;plantuml ; diagrams for confusing people more
|
||||
;;purescript ; javascript, but functional
|
||||
python ; beautiful is better than ugly
|
||||
;;qt ; the 'cutest' gui framework ever
|
||||
;;racket ; a DSL for DSLs
|
||||
;;raku ; the artist formerly known as perl6
|
||||
rest ; Emacs as a REST client
|
||||
;;rst ; ReST in peace
|
||||
(ruby +rails) ; 1.step {|i| p "Ruby is #{i.even? ? 'love' : 'life'}"}
|
||||
(rust +lsp) ; Fe2O3.unwrap().unwrap().unwrap().unwrap()
|
||||
;;scala ; java, but good
|
||||
;;scheme ; a fully conniving family of lisps
|
||||
sh ; she sells {ba,z,fi}sh shells on the C xor
|
||||
;;sml
|
||||
;;solidity ; do you need a blockchain? No.
|
||||
;;swift ; who asked for emoji variables?
|
||||
;;terra ; Earth and Moon in alignment for performance.
|
||||
web ; the tubes
|
||||
yaml ; JSON, but readable
|
||||
|
||||
:email
|
||||
;;(mu4e +gmail)
|
||||
;;notmuch
|
||||
;;(wanderlust +gmail)
|
||||
|
||||
:app
|
||||
;;calendar
|
||||
;;irc ; how neckbeards socialize
|
||||
;;(rss +org) ; emacs as an RSS reader
|
||||
;;twitter ; twitter client https://twitter.com/vnought
|
||||
|
||||
:config
|
||||
;;literate
|
||||
(default +bindings +smartparens))
|
||||
|
||||
(when noninteractive
|
||||
(add-to-list 'doom-env-whitelist "^SSH_"))
|
53
config/.doom.d/packages.el
Normal file
53
config/.doom.d/packages.el
Normal file
@ -0,0 +1,53 @@
|
||||
;; -*- no-byte-compile: t; -*-
|
||||
;;; $DOOMDIR/packages.el
|
||||
|
||||
;; To install a package with Doom you must declare them here and run 'doom sync'
|
||||
;; on the command line, then restart Emacs for the changes to take effect -- or
|
||||
;; use 'M-x doom/reload'.
|
||||
|
||||
|
||||
;; To install SOME-PACKAGE from MELPA, ELPA or emacsmirror:
|
||||
;(package! some-package)
|
||||
|
||||
(package! wakatime-mode)
|
||||
(package! pinentry)
|
||||
|
||||
;; To install a package directly from a remote git repo, you must specify a
|
||||
;; `:recipe'. You'll find documentation on what `:recipe' accepts here:
|
||||
;; https://github.com/raxod502/straight.el#the-recipe-format
|
||||
;(package! another-package
|
||||
; :recipe (:host github :repo "username/repo"))
|
||||
|
||||
;; If the package you are trying to install does not contain a PACKAGENAME.el
|
||||
;; file, or is located in a subdirectory of the repo, you'll need to specify
|
||||
;; `:files' in the `:recipe':
|
||||
;(package! this-package
|
||||
; :recipe (:host github :repo "username/repo"
|
||||
; :files ("some-file.el" "src/lisp/*.el")))
|
||||
|
||||
;; If you'd like to disable a package included with Doom, you can do so here
|
||||
;; with the `:disable' property:
|
||||
;(package! builtin-package :disable t)
|
||||
|
||||
;; You can override the recipe of a built in package without having to specify
|
||||
;; all the properties for `:recipe'. These will inherit the rest of its recipe
|
||||
;; from Doom or MELPA/ELPA/Emacsmirror:
|
||||
;(package! builtin-package :recipe (:nonrecursive t))
|
||||
;(package! builtin-package-2 :recipe (:repo "myfork/package"))
|
||||
|
||||
;; Specify a `:branch' to install a package from a particular branch or tag.
|
||||
;; This is required for some packages whose default branch isn't 'master' (which
|
||||
;; our package manager can't deal with; see raxod502/straight.el#279)
|
||||
;(package! builtin-package :recipe (:branch "develop"))
|
||||
|
||||
;; Use `:pin' to specify a particular commit to install.
|
||||
;(package! builtin-package :pin "1a2b3c4d5e")
|
||||
|
||||
|
||||
;; Doom's packages are pinned to a specific commit and updated from release to
|
||||
;; release. The `unpin!' macro allows you to unpin single packages...
|
||||
;(unpin! pinned-package)
|
||||
;; ...or multiple packages
|
||||
;(unpin! pinned-package another-pinned-package)
|
||||
;; ...Or *all* packages (NOT RECOMMENDED; will likely break things)
|
||||
;(unpin! t)
|
1
config/.gemrc
Normal file
1
config/.gemrc
Normal file
@ -0,0 +1 @@
|
||||
gem: --no-ri --no-rdoc
|
31
config/.gitconfig
Normal file
31
config/.gitconfig
Normal file
@ -0,0 +1,31 @@
|
||||
[user]
|
||||
name = James Walker
|
||||
email = walkah@walkah.net
|
||||
signingkey = 4D47A81C
|
||||
[color]
|
||||
diff = auto
|
||||
status = auto
|
||||
branch = auto
|
||||
ui = auto
|
||||
[alias]
|
||||
lg = log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --date=relative
|
||||
st = status -s
|
||||
smu = submodule update --init --recursive
|
||||
ignore = "!gi() { curl -L -s https://www.gitignore.io/api/$@ ;}; gi"
|
||||
up = pull --rebase --autostash
|
||||
cleanup = "!git branch --merged | grep -v '\\*\\|master\\|develop' | xargs -n 1 git branch -d"
|
||||
[github]
|
||||
user = walkah
|
||||
[git-up "bundler"]
|
||||
check = true
|
||||
autoinstall = true
|
||||
[filter "lfs"]
|
||||
clean = git lfs clean %f
|
||||
smudge = git lfs smudge %f
|
||||
required = true
|
||||
[commit]
|
||||
gpgsign = true
|
||||
[pull]
|
||||
rebase = false
|
||||
[init]
|
||||
defaultBranch = main
|
18
config/.mackup.cfg
Normal file
18
config/.mackup.cfg
Normal file
@ -0,0 +1,18 @@
|
||||
[storage]
|
||||
engine = file_system
|
||||
path = Sync
|
||||
|
||||
directory = Config
|
||||
|
||||
[applications_to_sync]
|
||||
asdf
|
||||
aws
|
||||
emacs-org
|
||||
exercism
|
||||
myrepos
|
||||
ngrok
|
||||
npm
|
||||
ssh
|
||||
|
||||
[applications_to_ignore]
|
||||
gnupg
|
6
config/.mackup/asdf.cfg
Normal file
6
config/.mackup/asdf.cfg
Normal file
@ -0,0 +1,6 @@
|
||||
[application]
|
||||
name = asdf
|
||||
|
||||
[configuration_files]
|
||||
.asdfrc
|
||||
.tool-versions
|
5
config/.mackup/emacs-org.cfg
Normal file
5
config/.mackup/emacs-org.cfg
Normal file
@ -0,0 +1,5 @@
|
||||
[application]
|
||||
name = emacs-org
|
||||
|
||||
[configuration_files]
|
||||
.org
|
5
config/.mackup/exercism.cfg
Normal file
5
config/.mackup/exercism.cfg
Normal file
@ -0,0 +1,5 @@
|
||||
[application]
|
||||
name = Exercism
|
||||
|
||||
[configuration_files]
|
||||
.config/exercism/user.json
|
3
config/.psqlrc
Normal file
3
config/.psqlrc
Normal file
@ -0,0 +1,3 @@
|
||||
\x auto
|
||||
\pset null 'NULL'
|
||||
|
1
config/.railsrc
Normal file
1
config/.railsrc
Normal file
@ -0,0 +1 @@
|
||||
--database=postgresql
|
15
config/.screenrc
Normal file
15
config/.screenrc
Normal file
@ -0,0 +1,15 @@
|
||||
# walkah's screenrc
|
||||
#
|
||||
# $Id: .screenrc,v 1.8 2007-03-30 02:31:27 walkah Exp $
|
||||
|
||||
# no startup message
|
||||
startup_message off
|
||||
|
||||
# i like the caption at the bottom, so i know what screen i'm on
|
||||
caption always "%w %-= %m/%d/%y %C%a"
|
||||
|
||||
# i use ctrl-a waay too much in emacs/readline remap to ctrl-o
|
||||
escape ^Oo
|
||||
|
||||
hardstatus off
|
||||
hardstatus string "%H:%t [%n]"
|
4
config/.ssh/.gitignore
vendored
Normal file
4
config/.ssh/.gitignore
vendored
Normal file
@ -0,0 +1,4 @@
|
||||
environment*
|
||||
id_dsa
|
||||
known_hosts
|
||||
*.pem
|
13
config/.timetrap.yml
Normal file
13
config/.timetrap.yml
Normal file
@ -0,0 +1,13 @@
|
||||
---
|
||||
database_file: <%= File.expand_path("~/.timetrap/timetrap.db") %>
|
||||
round_in_seconds: 900
|
||||
append_notes_delimiter: ", "
|
||||
formatter_search_paths:
|
||||
- <%= File.expand_path("~/.timetrap/formatters") %>
|
||||
default_formatter: text
|
||||
auto_sheet: dotfiles
|
||||
auto_sheet_search_paths:
|
||||
- <%= File.expand_path("~/.timetrap/auto_sheets") %>
|
||||
default_command:
|
||||
auto_checkout: false
|
||||
require_note: false
|
16
config/.tmux.conf
Normal file
16
config/.tmux.conf
Normal file
@ -0,0 +1,16 @@
|
||||
unbind C-b
|
||||
set -g prefix C-o
|
||||
|
||||
set -g set-titles on
|
||||
set -g set-titles-string "[#S] #W@#h (#I)"
|
||||
set -g status-right ""
|
||||
set -g default-terminal "screen-256color"
|
||||
|
||||
set-option -g status-left-length 60
|
||||
|
||||
set -g status-bg black
|
||||
set -g status-fg white
|
||||
|
||||
bind-key X kill-session
|
||||
|
||||
#set-option -g default-command "reattach-to-user-namespace -l zsh"
|
45
config/.vimrc
Normal file
45
config/.vimrc
Normal file
@ -0,0 +1,45 @@
|
||||
"
|
||||
" walkah's vimrc (vim 6)
|
||||
"
|
||||
" $Id: .vimrc,v 1.2 2005-11-08 20:17:32 walkah Exp $
|
||||
|
||||
" no compatible
|
||||
set nocp
|
||||
|
||||
" don't wrap lines
|
||||
set nowrap
|
||||
|
||||
" don't keep backups
|
||||
set nobackup
|
||||
|
||||
" visual bell
|
||||
set visualbell
|
||||
|
||||
set laststatus=2
|
||||
|
||||
" indenting stuff
|
||||
set expandtab
|
||||
set tabstop=2
|
||||
set shiftwidth=2
|
||||
set smarttab
|
||||
set autoindent
|
||||
set smartindent
|
||||
|
||||
set title
|
||||
|
||||
" folding
|
||||
set foldmethod=marker
|
||||
|
||||
" search
|
||||
set nohlsearch
|
||||
set incsearch
|
||||
set ignorecase
|
||||
|
||||
set showmatch
|
||||
|
||||
" syntax hilighting
|
||||
syntax on
|
||||
|
||||
" mappings
|
||||
map <PageUp> <C-B>
|
||||
map <PageDown> <C-F>
|
284
config/.zsh/custom/plugins/gh/_gh
Normal file
284
config/.zsh/custom/plugins/gh/_gh
Normal file
@ -0,0 +1,284 @@
|
||||
#compdef _gh gh
|
||||
|
||||
|
||||
function _gh {
|
||||
local -a commands
|
||||
|
||||
_arguments -C \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:' \
|
||||
'--version[Show gh version]' \
|
||||
"1: :->cmnds" \
|
||||
"*::arg:->args"
|
||||
|
||||
case $state in
|
||||
cmnds)
|
||||
commands=(
|
||||
"completion:Generate shell completion scripts"
|
||||
"help:Help about any command"
|
||||
"issue:Create and view issues"
|
||||
"pr:Create, view, and checkout pull requests"
|
||||
"repo:Create, clone, fork, and view repositories"
|
||||
)
|
||||
_describe "command" commands
|
||||
;;
|
||||
esac
|
||||
|
||||
case "$words[1]" in
|
||||
completion)
|
||||
_gh_completion
|
||||
;;
|
||||
help)
|
||||
_gh_help
|
||||
;;
|
||||
issue)
|
||||
_gh_issue
|
||||
;;
|
||||
pr)
|
||||
_gh_pr
|
||||
;;
|
||||
repo)
|
||||
_gh_repo
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
function _gh_completion {
|
||||
_arguments \
|
||||
'(-s --shell)'{-s,--shell}'[Shell type: {bash|zsh|fish|powershell}]:' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_help {
|
||||
_arguments \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
|
||||
function _gh_issue {
|
||||
local -a commands
|
||||
|
||||
_arguments -C \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:' \
|
||||
"1: :->cmnds" \
|
||||
"*::arg:->args"
|
||||
|
||||
case $state in
|
||||
cmnds)
|
||||
commands=(
|
||||
"create:Create a new issue"
|
||||
"list:List and filter issues in this repository"
|
||||
"status:Show status of relevant issues"
|
||||
"view:View an issue"
|
||||
)
|
||||
_describe "command" commands
|
||||
;;
|
||||
esac
|
||||
|
||||
case "$words[1]" in
|
||||
create)
|
||||
_gh_issue_create
|
||||
;;
|
||||
list)
|
||||
_gh_issue_list
|
||||
;;
|
||||
status)
|
||||
_gh_issue_status
|
||||
;;
|
||||
view)
|
||||
_gh_issue_view
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
function _gh_issue_create {
|
||||
_arguments \
|
||||
'(-b --body)'{-b,--body}'[Supply a body. Will prompt for one otherwise.]:' \
|
||||
'(-t --title)'{-t,--title}'[Supply a title. Will prompt for one otherwise.]:' \
|
||||
'(-w --web)'{-w,--web}'[Open the browser to create an issue]' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_issue_list {
|
||||
_arguments \
|
||||
'(-a --assignee)'{-a,--assignee}'[Filter by assignee]:' \
|
||||
'(-A --author)'{-A,--author}'[Filter by author]:' \
|
||||
'(*-l *--label)'{\*-l,\*--label}'[Filter by label]:' \
|
||||
'(-L --limit)'{-L,--limit}'[Maximum number of issues to fetch]:' \
|
||||
'(-s --state)'{-s,--state}'[Filter by state: {open|closed|all}]:' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_issue_status {
|
||||
_arguments \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_issue_view {
|
||||
_arguments \
|
||||
'(-w --web)'{-w,--web}'[Open issue in browser]' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
|
||||
function _gh_pr {
|
||||
local -a commands
|
||||
|
||||
_arguments -C \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:' \
|
||||
"1: :->cmnds" \
|
||||
"*::arg:->args"
|
||||
|
||||
case $state in
|
||||
cmnds)
|
||||
commands=(
|
||||
"checkout:Check out a pull request in Git"
|
||||
"create:Create a pull request"
|
||||
"list:List and filter pull requests in this repository"
|
||||
"status:Show status of relevant pull requests"
|
||||
"view:View a pull request in the browser"
|
||||
)
|
||||
_describe "command" commands
|
||||
;;
|
||||
esac
|
||||
|
||||
case "$words[1]" in
|
||||
checkout)
|
||||
_gh_pr_checkout
|
||||
;;
|
||||
create)
|
||||
_gh_pr_create
|
||||
;;
|
||||
list)
|
||||
_gh_pr_list
|
||||
;;
|
||||
status)
|
||||
_gh_pr_status
|
||||
;;
|
||||
view)
|
||||
_gh_pr_view
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
function _gh_pr_checkout {
|
||||
_arguments \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_pr_create {
|
||||
_arguments \
|
||||
'(-B --base)'{-B,--base}'[The branch into which you want your code merged]:' \
|
||||
'(-b --body)'{-b,--body}'[Supply a body. Will prompt for one otherwise.]:' \
|
||||
'(-d --draft)'{-d,--draft}'[Mark pull request as a draft]' \
|
||||
'(-f --fill)'{-f,--fill}'[Do not prompt for title/body and just use commit info]' \
|
||||
'(-t --title)'{-t,--title}'[Supply a title. Will prompt for one otherwise.]:' \
|
||||
'(-w --web)'{-w,--web}'[Open the web browser to create a pull request]' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_pr_list {
|
||||
_arguments \
|
||||
'(-a --assignee)'{-a,--assignee}'[Filter by assignee]:' \
|
||||
'(-B --base)'{-B,--base}'[Filter by base branch]:' \
|
||||
'(*-l *--label)'{\*-l,\*--label}'[Filter by label]:' \
|
||||
'(-L --limit)'{-L,--limit}'[Maximum number of items to fetch]:' \
|
||||
'(-s --state)'{-s,--state}'[Filter by state: {open|closed|merged|all}]:' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_pr_status {
|
||||
_arguments \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_pr_view {
|
||||
_arguments \
|
||||
'(-w --web)'{-w,--web}'[Open pull request in browser]' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
|
||||
function _gh_repo {
|
||||
local -a commands
|
||||
|
||||
_arguments -C \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:' \
|
||||
"1: :->cmnds" \
|
||||
"*::arg:->args"
|
||||
|
||||
case $state in
|
||||
cmnds)
|
||||
commands=(
|
||||
"clone:Clone a repository locally"
|
||||
"create:Create a new repository"
|
||||
"fork:Create a fork of a repository"
|
||||
"view:View a repository in the browser"
|
||||
)
|
||||
_describe "command" commands
|
||||
;;
|
||||
esac
|
||||
|
||||
case "$words[1]" in
|
||||
clone)
|
||||
_gh_repo_clone
|
||||
;;
|
||||
create)
|
||||
_gh_repo_create
|
||||
;;
|
||||
fork)
|
||||
_gh_repo_fork
|
||||
;;
|
||||
view)
|
||||
_gh_repo_view
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
function _gh_repo_clone {
|
||||
_arguments \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_repo_create {
|
||||
_arguments \
|
||||
'(-d --description)'{-d,--description}'[Description of repository]:' \
|
||||
'--enable-issues[Enable issues in the new repository]' \
|
||||
'--enable-wiki[Enable wiki in the new repository]' \
|
||||
'(-h --homepage)'{-h,--homepage}'[Repository home page URL]:' \
|
||||
'--public[Make the new repository public]' \
|
||||
'(-t --team)'{-t,--team}'[The name of the organization team to be granted access]:' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_repo_fork {
|
||||
_arguments \
|
||||
'--clone[Clone fork: {true|false|prompt}]' \
|
||||
'--remote[Add remote for fork: {true|false|prompt}]' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
||||
function _gh_repo_view {
|
||||
_arguments \
|
||||
'(-w --web)'{-w,--web}'[Open repository in browser]' \
|
||||
'--help[Show help for command]' \
|
||||
'(-R --repo)'{-R,--repo}'[Select another repository using the `OWNER/REPO` format]:'
|
||||
}
|
||||
|
1
config/.zsh/custom/walkah.zsh
Normal file
1
config/.zsh/custom/walkah.zsh
Normal file
@ -0,0 +1 @@
|
||||
# oh-my-zsh complains without a .zsh file in here
|
18
config/.zsh/custom/walkah.zsh-theme
Normal file
18
config/.zsh/custom/walkah.zsh-theme
Normal file
@ -0,0 +1,18 @@
|
||||
# walkah ZSH Theme
|
||||
|
||||
if [ -z $SSH_CONNECTION ]; then HCOLOR="green"; else HCOLOR="blue"; fi
|
||||
local return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})"
|
||||
|
||||
function asdf_prompt() {
|
||||
echo $(asdf current $1|awk '{print $2}')
|
||||
}
|
||||
|
||||
PROMPT='%{$fg[$HCOLOR]%}%m%{$reset_color%}:$(shrink_path -f) $(git_prompt_info)%{$fg[red]%}%(!.#.»)%{$reset_color%} '
|
||||
PROMPT2='%{$fg[red]%}\ %{$reset_color%}'
|
||||
if (( $+commands[asdf] )); then
|
||||
RPS1='%{$fg[cyan]%}(%{$fg[red]%}$(asdf_prompt ruby) %{$fg[green]%}$(asdf_prompt nodejs) %{$fg[blue]%}$(asdf_prompt python)%{$fg[cyan]%}) %{$reset_color%}${return_code}'
|
||||
fi
|
||||
ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[green]%}±%{$fg[yellow]%}"
|
||||
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%} "
|
||||
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}✗%{$reset_color%}"
|
25
config/.zshenv
Normal file
25
config/.zshenv
Normal file
@ -0,0 +1,25 @@
|
||||
# ignore system zsh
|
||||
IGNORE_SYSTEM_ZSH=1
|
||||
|
||||
|
||||
# unique path... and put my stuff first
|
||||
typeset -U path
|
||||
path=(~/bin ~/local/bin ~/local/sbin /usr/local/bin /usr/local/sbin /usr/bin /usr/X11R6/bin /bin /usr/sbin /sbin /usr/games)
|
||||
|
||||
### environment
|
||||
export PAGER=less
|
||||
export RSYNC_RSH=ssh
|
||||
export CVS_RSH=ssh
|
||||
#export CVSROOT=/home/cvs
|
||||
|
||||
[ -f $HOME/.environment ] && . $HOME/.environment
|
||||
|
||||
# Load asdf
|
||||
if command -v brew &> /dev/null; then
|
||||
. $(brew --prefix asdf)/asdf.sh
|
||||
else
|
||||
. ~/.asdf/asdf.sh
|
||||
fi
|
||||
|
||||
[ -e $HOME/.nix-profile/etc/profile.d/nix.sh ] && . $HOME/.nix-profile/etc/profile.d/nix.sh
|
||||
|
69
config/.zshrc
Normal file
69
config/.zshrc
Normal file
@ -0,0 +1,69 @@
|
||||
# Path to your oh-my-zsh configuration.
|
||||
export ZSH=$HOME/.oh-my-zsh
|
||||
|
||||
# Set to the name theme to load.
|
||||
# Look in ~/.oh-my-zsh/themes/
|
||||
# export ZSH_THEME="walkah"
|
||||
|
||||
# My custom directory
|
||||
export ZSH_CUSTOM=$HOME/.zsh/custom
|
||||
|
||||
# Set to this to use case-sensitive completion
|
||||
# export CASE_SENSITIVE="true"
|
||||
|
||||
# Comment this out to disable weekly auto-update checks
|
||||
# export DISABLE_AUTO_UPDATE="true"
|
||||
|
||||
# Uncomment following line if you want to disable colors in ls
|
||||
# export DISABLE_LS_COLORS="true"
|
||||
|
||||
# Which plugins would you like to load? (plugins can be found in ~/.oh-my-zsh/plugins/*)
|
||||
# Example format: plugins=(rails git textmate ruby lighthouse)
|
||||
plugins=(asdf direnv aws gcloud extract command-not-found tmux git github ssh-agent docker docker-compose mix)
|
||||
|
||||
# ruby
|
||||
if [ -x ruby ]; then
|
||||
plugins=($plugins ruby gem rails bundler heroku)
|
||||
fi
|
||||
|
||||
# node
|
||||
plugins=($plugins npm yarn react-native)
|
||||
|
||||
# python
|
||||
plugins=($plugins pip pipenv)
|
||||
|
||||
# Platform specific settings
|
||||
case "$OSTYPE" in
|
||||
darwin*)
|
||||
plugins=($plugins osx)
|
||||
;;
|
||||
linux*)
|
||||
plugins=($plugins debian)
|
||||
export PATH=/snap/bin:$PATH
|
||||
;;
|
||||
esac
|
||||
|
||||
# OH MY ZSH!
|
||||
source $ZSH/oh-my-zsh.sh
|
||||
|
||||
# Android Studio
|
||||
if [ -d ~/Library/Android/sdk ]; then
|
||||
export ANDROID_SDK=~/Library/Android/sdk
|
||||
export PATH=~/Library/Android/sdk/platform-tools:$PATH
|
||||
fi
|
||||
|
||||
# zsh autosuggestions
|
||||
if command -v brew &> /dev/null; then
|
||||
zsh_autosuggestions=$(brew --prefix)/share/zsh-autosuggestions/zsh-autosuggestions.zsh
|
||||
if [ -f $zsh_autosuggestions ]; then
|
||||
source $zsh_autosuggestions
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ $TERM = "screen" ]; then
|
||||
export DISABLE_AUTO_TITLE="true"
|
||||
fi
|
||||
export EDITOR="vim"
|
||||
export LSCOLORS="ExGxFxdxCxDxDxhbadExEx"
|
||||
|
||||
eval "$(starship init zsh)"
|
47
config/bin/goodmorning.sh
Executable file
47
config/bin/goodmorning.sh
Executable file
@ -0,0 +1,47 @@
|
||||
#!/bin/bash
|
||||
|
||||
function install_latest() {
|
||||
version=$(asdf list-all $1 | grep -v '[a-z]' | tail -1)
|
||||
asdf install $1 $version
|
||||
asdf global $1 $version
|
||||
}
|
||||
|
||||
echo "* Updating homesick..."
|
||||
homesick pull
|
||||
homesick symlink
|
||||
|
||||
case "$OSTYPE" in
|
||||
darwin*)
|
||||
echo "* Restoring mackup..."
|
||||
mackup restore
|
||||
|
||||
echo "* Homebrew updates..."
|
||||
brew bundle --global --no-lock
|
||||
brew upgrade
|
||||
|
||||
echo "* Upgrading mac app store apps..."
|
||||
mas upgrade
|
||||
;;
|
||||
linux*)
|
||||
sudo apt update && sudo apt upgrade
|
||||
sudo snap refresh
|
||||
|
||||
;;
|
||||
esac
|
||||
|
||||
|
||||
|
||||
echo "* asdf update..."
|
||||
export R_CONFIGURE_OPTIONS="--with-x=no"
|
||||
for plugin in $(cat ~/.tool-versions | awk '{print $1}'); do asdf plugin-add $plugin; done
|
||||
asdf update
|
||||
asdf plugin-update --all
|
||||
asdf install
|
||||
for plugin in $(cat ~/.tool-versions | awk '{print $1}'); do install_latest $plugin; done
|
||||
|
||||
echo "* Syncing repositories..."
|
||||
mr -j 5 update
|
||||
|
||||
echo "* Upgrading oh-my-zsh..."
|
||||
cd ~/.oh-my-zsh
|
||||
git pull --rebase --stat origin master
|
21
config/bin/goodnight.sh
Executable file
21
config/bin/goodnight.sh
Executable file
@ -0,0 +1,21 @@
|
||||
#!/bin/sh
|
||||
|
||||
echo "* Shutdown vagrant..."
|
||||
for box in $(vagrant global-status|grep running|awk '{ print $1 }'); do vagrant halt $box; done
|
||||
|
||||
echo "* Shutdown docker..."
|
||||
# for machine in $(docker-machine ls -q); do docker-machine stop $machine; done
|
||||
for container in $(docker ps -a -q); do docker stop $container; done
|
||||
docker system prune -f
|
||||
|
||||
echo "* Stop running services..."
|
||||
brew services stop --all
|
||||
|
||||
echo "* Kill tmux sessions..."
|
||||
tmux kill-server
|
||||
|
||||
echo "* Uncommitted projects..."
|
||||
mr -m status
|
||||
|
||||
echo "* Homesick status..."
|
||||
homesick status
|
42
config/bin/macos.sh
Executable file
42
config/bin/macos.sh
Executable file
@ -0,0 +1,42 @@
|
||||
#!/bin/sh
|
||||
# Inspired by https://github.com/mathiasbynens/dotfiles/blob/master/.macos
|
||||
|
||||
# Dock settings
|
||||
defaults write com.apple.dock 'orientation' -string 'left'
|
||||
defaults write com.apple.dock autohide -bool true
|
||||
killall Dock
|
||||
|
||||
# Finder settings
|
||||
# TODO: turn on stacks?
|
||||
defaults write com.apple.finder ShowExternalHardDrivesOnDesktop -bool true
|
||||
defaults write com.apple.finder ShowHardDrivesOnDesktop -bool true
|
||||
defaults write com.apple.finder ShowMountedServersOnDesktop -bool true
|
||||
defaults write com.apple.finder ShowRemovableMediaOnDesktop -bool true
|
||||
killall Finder
|
||||
|
||||
# Safari
|
||||
|
||||
# Enable the Develop menu
|
||||
defaults write -app Safari IncludeDevelopMenu -bool true
|
||||
defaults write -app Safari WebKitDeveloperExtrasEnabledPreferenceKey -bool true
|
||||
defaults write -app Safari WebKitPreferences.developerExtrasEnabled -bool true
|
||||
# Disable AutoFill
|
||||
defaults write -app Safari AutoFillFromAddressBook -bool false
|
||||
defaults write -app Safari AutoFillPasswords -bool false
|
||||
defaults write -app Safari AutoFillCreditCardData -bool false
|
||||
defaults write -app Safari AutoFillMiscellaneousForms -bool false
|
||||
|
||||
# Mail
|
||||
# TODO: notifications for contacts only
|
||||
# TODO: disable sounds
|
||||
|
||||
# Sharing
|
||||
# Turn on SSH
|
||||
sudo launchctl load -w /System/Library/LaunchDaemons/ssh.plist
|
||||
# TODO: turn on VNC?
|
||||
|
||||
# iTerm 2
|
||||
# Specify the preferences directory
|
||||
defaults write com.googlecode.iterm2.plist PrefsCustomFolder -string "~/SynologyDrive/Config/iTerm/"
|
||||
# Tell iTerm2 to use the custom preferences in the directory
|
||||
defaults write com.googlecode.iterm2.plist LoadPrefsFromCustomFolder -bool true
|
Reference in New Issue
Block a user