Readme cleanup

This commit is contained in:
Daniel Flanagan 2020-07-02 11:29:01 -05:00
parent cf2116b197
commit c2d827ba30
Signed by: lytedev
GPG Key ID: 5B2020A0F9921EF4
1 changed files with 35 additions and 67 deletions

102
readme.md
View File

@ -1,94 +1,62 @@
# My Dotfiles # dotfiles by lytedev
[🖥️ Upstream][upstream] • [🐙 GitHub Mirror][github] [🖥️ Upstream][upstream] • [🐙 GitHub Mirror][github]
![Desktop Screenshot][desktop-screenshot] ![Desktop Screenshot][desktop-screenshot]
This repository contains the majority of application or OS configuration files This repository contains the majority of application or OS configuration files
I use on a daily basis. I keep the here and public in an effort to inform others I use on a daily basis. I keep them public in an effort to inform others who may
who may not know either how to go about organizing such files or to learn how to not know either how to go about organizing such files or to learn how to achieve
achieve certain behavior in their software and to have quick and easy access for certain behavior in their software and to have quick and easy access for myself
myself when setting up a new machine. when setting up a new machine.
## Setup ## Setup
* Clone the repo into `~/.config/dotfiles` **NOTE**: Unless you're me, you probably shouldn't use my setup exactly. Just
* Run `~/.config/dotfiles/setup.bash` take chunks you like instead! Backup your files first!
* Read the warning, obey it, backup your files, *then* agree
* **Optional**: Reboot once the script finishes
**NOTE**: I'm in the middle of migrating from urxvt+bash to kitty+fish (and ```
a less anything-dependent system in general). Lots of things are broken. The git clone https://git.lyte.dev/lytedev/dotfiles.git ~/.config/dotfiles
setup script probably no longer sets up *absolutely everything*. cd ~/.config/dotfiles && ./setup.bash # follow the instructions!
```
## Priorities ## Priorities
I have specific needs and desires (as does any developer) and I will lay those + Productivity
out in order of priority here: + Flexibility and extensibility
+ Primarily configured for Linux
+ Terminal-based applications that play well with others
+ Quick setup
+ Portability
* These files are primarily configured for Linux, (specifically, Arch Linux) but ## Primary Applications
I try to keep the OS-specific stuff in the `os-specific` directory.
* I also prefer apps in my terminal. If I could, I would do everything that
makes sense to do so in a terminal using only my keyboard. **So if you know
about really cool and usable terminal-based software, let me know!**
* I prefer keeping my dotfiles as portable as possible (within reason) though
this is obviously very difficult since I only run one OS.
* Setup should be very quick (downloading and installing packages aside).
* I aim to keep the dotfiles flexible and extendible, as I usually use them on
multiple machines with specific use-cases. For example, a shared laptop should
allow for other non-technical users ease-of-access, while my workstation
should focus on being quick, powerful, and highly usable for me alone.
## Applications + **Terminal**: Kitty + tmux
+ **Editor**: Neovim
There are several types of applications I use every day, some more than others, + **Browser**: Firefox
and sometimes different applications that have the same purpose. Here are the + **Music**: Google Play Music in Firefox
applications I use: + **Email**: Gmail in Firefox
+ **Image Editing**: Inkscape, Krita, GIMP
* **Terminal Emulator**: Kitty + **Gaming**: Steam, Dolphin Emulator, Lutris
* **Text Editor**: Neovim
* **Terminal Multiplexers**: tmux
* **Web Browser**: Firefox
* **Music**: Google Play Music
* **Email**: Google Inbox, mutt
* **Image Editing**: GIMP, Inkscape, Krita, Aseprite
* **Documents**: Neovim + Markdown, sc-im, LibreOffice
* **Gaming**: Steam, various emulators
## Workflow ## Workflow
Here are some bullet points on my workflow: *Coming someday... maybe!*
* **Text Editing**: I use `Neovim` in my terminal as my primary text ## Improvements
editor. I usually run it in a `tmux` session alongside a few terminals to
have a very flexible IDE-like development environment. More on that in other
bullet points. I keep a `tmux` session for each project or group of
terminals concerning a similar mind-space.
* **Version Control**: I use `git` in the terminal and commit often. I work in
feature branches that go to a `dev` branch as sort of a staging area for
testing until it's time to go live, then I merge into master.
* **Compiler/Debugging**: I rely heavily on auto-reloading and
watch-and-test-and-compile features during development to iterate quickly.
Language servers, linters, and simple file watches to trigger your tests are
amazing tools to take care of the cruft of writing code and integrating them
heavily into Neovim is my current top need/priority.
## To Do and Improvements
+ Makefile instead of setup script
+ Vulkan is broken on my desktop
+ `c` (and similar aliases) could utilize `CDPATH` envvar? + `c` (and similar aliases) could utilize `CDPATH` envvar?
+ Better/more secure remote management configuration in dotfiles? [1][1] + Better/more secure remote management configuration in dotfiles? [1][1]
+ Wayland stuff + Add vim in the terminal as the handler for many MIME types (xdg-open and such)
+ Sway hotkey parity (as much as is possible) with sxhkd/bspwm
+ Clean out all the X11 cruft?
* Add vim in the terminal as the handler for many MIME types (xdg-open and such)
for the rare time I'm in a file manager or for opening easily from for the rare time I'm in a file manager or for opening easily from
the browser. the browser.
* Unify all the common variables... somehow? (and use templates and `envsubst`?) + Unify all the common variables... somehow? (and use templates and `envsubst`?)
* Makefile instead of setup script + [Vimux](https://github.com/benmills/vimux)?
* [Vimux](https://github.com/benmills/vimux)? + Custom Iosevka font with kitty-compatible ligatures?
* Custom Iosevka font with kitty-compatible ligatures + Setup network file share?
* Setup network file sharing directory + Investigate systemd services that may help with various tasks (homed, etc.)
+ Investigate some systemd services (homed,
[upstream]: https://git.faceless.lytedev.io/lytedev/dotfiles [upstream]: https://git.faceless.lytedev.io/lytedev/dotfiles