TITLE: My workflow, tmux, vim, etc. DATE: 2017-11-01 AUTHOR: John L. Godlee ==================================================================== I thought I should do the sort of post that everyone seems to do and show off my workflow, with all the horrendously try-hard command line utilities, and DIY config files. You can find my dotfiles [here]. [here]: https://github.com/johngodlee/dotfiles I spend most of my time working on my macbook pro, within an iTerm2 window running tmux. I have a bash script that builds a tmux session and fills it with useful programs. I have vim in one window, then a whole load of small empty shell panes in the next window, and finally cmus in the last window for playing music: #!/bin/sh # Create new session tmux -2 new -s 'dash' # Start vim tmux send-keys "vim" Enter # New window, split into 4 tmux new-window -n 'bash' tmux split-window -v tmux split-window -h tmux select-pane -t 1 tmux split-window -h # Split pane 1 vertically tmux select-pane -t 1 tmux split-window -v # Split pane 5 horizontally tmux select-pane -t 5 tmux split-window -h # Resize panes tmux resize-pane -D 8 # New window, start cmus tmux new-window -n 'cmus' tmux send-keys "cmus" Enter # Detach and reattach to make it work properly tmux detach tmux a -t dash tmux select-window -t 1 I dabbled in using tmux-resurrect and tmux-continuum to save my tmux sessions when I rebooted, but I found that these plugins weren’t always reliable. Besides, I don’t usually reboot my laptop unless I’ve first saved all my files. I used to have a lot more things running in tmux. I used alpine to manage email from my gmail account, and I used the calendar.vim plugin with a custom .vimrc to link to my google calendar, but when I started back working full time I found that it actually saved me a bit of time to just use the default macOS Calendar and Mail apps. Note-taking I use vim to take all my notes. I use markdown to format all my notes. I have a note for each day, or at least each workday. The basic format of my daily note is: # Item 1 * Thing to do one * Thing to do two * detail 1 * detail 2 <hr> # Item 2 * Thing to do one ==================DONE=================== * Thing to do, done ==================DONE=================== At the end of the day, I copy that day’s note into a new note with tomorrow’s date. So in the end I have a folder of notes with names like this: Daily_2017_10_26.md Daily_2017_10_27.md Daily_2017_10_28.md I also have this neat way of roughly tracking how productive I’ve been. I can count the number of lines within the ==================DONE=================== tags. Then I can turn that into a csv, then import that into R and plot a graph of how much I’ve done over time. It’s not that useful, but was a fun project to put together, and a way to learn about grep. The bash script: #!/bin/bash # Create csv file of completed items from daily notes by counting lines between #DONE# marks touch ~/Desktop/word_count.txt # Using a for loop and multiple sed arguments to amend the file (takes longer) for f in ./*; do { printf '%s ' "$f"; sed -n '/DONE/,/DONE/p' "$f" | wc -l; } >> ~/Desktop/word_count.txt; done # Make multiple whitespace into 1 whitespace, to csv awk '{$1=$1}1' ~/Desktop/word_count.txt > ~/Desktop/word_count.csv # Replace "md " with "md," perl -pi -w -e 's/md\s/md,/g;' ~/Desktop/word_count.csv # Add column names echo -e "date,count\n$(cat ~/Desktop/word_count.csv)" > ~/Desktop/word_count.csv # delete txt file rm ~/Desktop/word_count.txt # Run R script Rscript ~/Google_Drive/Code/R/done_count.R The R script: # Personal productivity by #DONE# items in Daily notes # Packages ---- library(ggplot2) library(dplyr) # Load data ---- prod <- read.csv("~/Desktop/word_count.csv") # Clean up ---- prod$date <- prod$date %>% gsub("./Daily_", "", .) %>% # Remove leading filename section gsub(".md", "", .) %>% # Remove trailing filename section as.Date(., format = "%Y_%m_%d") # Transform to Date class # ggplot line graph ---- done_count <- ggplot(prod, aes(x = date, y = count)) + geom_line() + scale_x_date(date_labels = "%b", date_breaks = "1 month") ggsave(filename = "ggplot_done_count.png", plot = done_count, width = 20, height = 20, units = "cm") Edit 2017_12_08 I’ve been thinking more about the note-taking philosophy and have noticed a few trends in my own note-taking that make it easier for me to read things back at a later date. This has mostly come about because I am now starting to re-read my notes on academic papers as I start to write my confirmation report. - Keep notes short - It’s much easier to read notes back when they are only on short lines. Only one sentence per line - Nested bullet points - In line with trying to keep notes short, it follows that nested bullet points are a great way to give some sense of inherent structure to your note taking, and make it easier to memorise things like lists of species. Nested notes also do a good job at maintaining a logical flow to discussions, by allowing you to put a retort to a particular piece of evidence as a nested bullet under the main bullet point. - Use keywords and repeat yourself - I find it much easier to search through long sets of notes if I have keywords to search for. In this sense, it follows that each bullet point should be its own self-encapsulated bundle of information, which relies little on other bullet points to give it context, this makes it much easier to scan through bullet points for the useful information. - Use Markdown - This isn’t entirely necessary, but I’ve found it to be a great way of quickly applying formatting to my notes, as opposed to what I used to do with Microsoft Word and WYSIWYG formatting. Screens and deskspace I do nearly all of my work at my desk in the University. I have a widescreen monitor with a trailing HDMI cable that I can plug into my laptop, then to the right I have a HP all-in-one running Windows that is hooked up to the University network, just in case I need to use some piece of Windows software. For example, when I’m testing workshops for undergraduate students. {IMAGE}