Compare commits
21 Commits
2f328f3b70
...
65217b8673
Author | SHA1 | Date | |
---|---|---|---|
65217b8673 | |||
2d95304da4 | |||
8e64f8f58e | |||
3b04aaf8be | |||
42886b3c1d | |||
1dfdac516b | |||
63e4c409bb | |||
98dbb5e3d6 | |||
45eae50c24 | |||
24bb7014f9 | |||
92145ac4b7 | |||
7292e0625e | |||
ffa4dbc51a | |||
8a86d9dc29 | |||
641b8fb825 | |||
a6b8420c26 | |||
68d3a850c0 | |||
7e75763cee | |||
2d3961e0f5 | |||
72ad0786c8 | |||
b64d9de0c4 |
2
Makefile
2
Makefile
@ -40,6 +40,8 @@ $(databases): .dbs/%.rec: %/ | .dbs/
|
|||||||
db.rec: $(databases)
|
db.rec: $(databases)
|
||||||
printf '%s\n' '%rec: guide' > $@
|
printf '%s\n' '%rec: guide' > $@
|
||||||
printf '%s\n' '%key: title' >> $@
|
printf '%s\n' '%key: title' >> $@
|
||||||
|
printf '%s\n' '%type: requires rec guide' >> $@
|
||||||
|
printf '%s\n' '%type: provides rec guide' >> $@
|
||||||
printf '%s\n' '%type: wordcount int' >> $@
|
printf '%s\n' '%type: wordcount int' >> $@
|
||||||
printf '%s\n\n' '%sort: wordcount' >> $@
|
printf '%s\n\n' '%sort: wordcount' >> $@
|
||||||
cat $^ >> $@
|
cat $^ >> $@
|
||||||
|
23
README.md
23
README.md
@ -4,23 +4,29 @@ title: "Linux Knowledge Base"
|
|||||||
|
|
||||||
The Linux Knowledge-Base provides quick-start guides for working with terminal programs.
|
The Linux Knowledge-Base provides quick-start guides for working with terminal programs.
|
||||||
|
|
||||||
|
If you like this style of short articles with a miniature database, then join me in my quest to remove the nausea of poorly-written documentation.
|
||||||
|
|
||||||
# Setup
|
# Setup
|
||||||
|
|
||||||
Install `make`, `recutils`, and any fuzzy-finder (i.e. `sk`, `fzy`, or `fzf`).
|
Install `make`, `recutils`, and any fuzzy-finder (i.e. `sk`, `fzy`, or `fzf`).
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
|
Set up the database and try a few queries:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
make
|
make
|
||||||
make database
|
make database
|
||||||
|
|
||||||
|
recsel db.rec -m 3
|
||||||
recsel db.rec -q database
|
recsel db.rec -q database
|
||||||
recsel db.rec -q gpg
|
|
||||||
recsel db.rec -e "title = 'ssh'"
|
recsel db.rec -e "title = 'ssh'"
|
||||||
recsel db.rec -e "title ~ 'ssh'"
|
recsel db.rec -e "title ~ 'ssh'"
|
||||||
recsel db.rec -e "title ~ 'bash'" -R title,wordcount
|
recsel db.rec -e "title ~ 'bash'" -R title,wordcount
|
||||||
recsel db.rec -m 1 -P content | less -R
|
|
||||||
|
recsel db.rec -t guide -j provides -G title \
|
||||||
|
-e "title = 'ssh'" \
|
||||||
|
-p 'sum(provides_wordcount)'
|
||||||
```
|
```
|
||||||
|
|
||||||
# Style
|
# Style
|
||||||
@ -30,6 +36,14 @@ recsel db.rec -m 1 -P content | less -R
|
|||||||
- Nobody cares about how the project started.
|
- Nobody cares about how the project started.
|
||||||
- Nobody wants to read what `ffmpeg` is, because anyone who wants to use it already knows what it is.
|
- Nobody wants to read what `ffmpeg` is, because anyone who wants to use it already knows what it is.
|
||||||
|
|
||||||
|
## State Knowledge Dependencies
|
||||||
|
|
||||||
|
Articles should state what you need to understand in order to read them *at the start*.
|
||||||
|
They should not assume the reader knows much beyond common terminal commands, and should not provide a link to some other resource half-way through an article.
|
||||||
|
|
||||||
|
People should be able to read an article from the beginning, then keep going until the end, and then stop.
|
||||||
|
Articles should not take a detour through a chain of other articles of unknown size.
|
||||||
|
|
||||||
## Be Opinionated
|
## Be Opinionated
|
||||||
|
|
||||||
- Guides should not ask the reader to select options half-way through.
|
- Guides should not ask the reader to select options half-way through.
|
||||||
@ -74,6 +88,11 @@ grep ls --color=always $HISTFILE | $PAGER
|
|||||||
|
|
||||||
Now we can see what can be changed.
|
Now we can see what can be changed.
|
||||||
|
|
||||||
|
## Assume People Follow the Instructions
|
||||||
|
|
||||||
|
Articles should say what to type, not the output.
|
||||||
|
If the command is `ls`, users will see files once they try the command, but the article does not need to provide an example list of files unless an important point has to be made about output.
|
||||||
|
|
||||||
# What's Wrong with Everything Else?
|
# What's Wrong with Everything Else?
|
||||||
|
|
||||||
## Man pages
|
## Man pages
|
||||||
|
@ -56,7 +56,7 @@ Then set that language, with:
|
|||||||
LANG=pl_PL.UTF-8
|
LANG=pl_PL.UTF-8
|
||||||
```
|
```
|
||||||
|
|
||||||
... then reboot.
|
...then reboot.
|
||||||
|
|
||||||
# Network Time Protocol
|
# Network Time Protocol
|
||||||
|
|
||||||
|
@ -142,4 +142,3 @@ You can ensure omemo automatcally turns on:
|
|||||||
```
|
```
|
||||||
---
|
---
|
||||||
|
|
||||||
'OTR' encryption is mostly dead, but you can find the old instructions [here](profanity-otr).
|
|
||||||
|
@ -6,41 +6,40 @@ tags: [ "data" ]
|
|||||||
|
|
||||||
## New Machines
|
## New Machines
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git config --global user.email "$YOUR_EMAIL"
|
git config --global user.email "$YOUR_EMAIL"
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git config --global user.name "$YOUR_NAME"
|
git config --global user.name "$YOUR_NAME"
|
||||||
```
|
```
|
||||||
|
|
||||||
# New Git
|
# New Git
|
||||||
|
|
||||||
Start a git in directory `$DIR`:
|
Decide on algorithm:
|
||||||
|
|
||||||
```bash
|
- If you're scared of insecure hash-sums, go with `hash=sha256`.
|
||||||
mkdir $DIR && cd $DIR
|
- If you don't know what a hash sum is, go with `hash=sha1`.
|
||||||
|
|
||||||
|
## Init the Git
|
||||||
|
|
||||||
|
Start a git in directory `${DIR}`:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
git init --object-format=${hash} ${DIR}
|
||||||
|
cd ${DIR}
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
Make a file explaining what the project does, and tell `git` to track it:
|
||||||
git init
|
|
||||||
```
|
|
||||||
|
|
||||||
Make a file explaining what the project does:
|
```sh
|
||||||
|
echo "I hereby solemnly swear never to commit a binary file." > README.md
|
||||||
```bash
|
|
||||||
vim README.md
|
|
||||||
```
|
|
||||||
|
|
||||||
Add this to the git:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
git add README.md
|
git add README.md
|
||||||
```
|
```
|
||||||
|
|
||||||
Then make the initial commit, explaining the change you just made:
|
Then make the initial commit, explaining the change you just made:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git commit
|
git commit
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -48,17 +47,17 @@ git commit
|
|||||||
|
|
||||||
Once you make a change to some file, add it and make a commit explaining it.
|
Once you make a change to some file, add it and make a commit explaining it.
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git add $FILE
|
git add $FILE
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git commit -m"change $FILE"
|
git commit -m"change $FILE"
|
||||||
```
|
```
|
||||||
|
|
||||||
Check your history:
|
Check your history:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git log
|
git log
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -69,20 +68,20 @@ Give it the same name as the `$DIR` directory, above.
|
|||||||
|
|
||||||
Add this as a remote:
|
Add this as a remote:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
REMOTE=gitlab
|
REMOTE=gitlab
|
||||||
git remote add $REMOTE https://gitlab.com/$USERNAME/$DIR
|
git remote add $REMOTE https://gitlab.com/$USERNAME/$DIR
|
||||||
```
|
```
|
||||||
|
|
||||||
Tell git you're pushing the branch "master" to the remote repo "origin":
|
Tell git you're pushing the branch "master" to the remote repo "origin":
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git push -u master origin
|
git push -u master origin
|
||||||
```
|
```
|
||||||
|
|
||||||
If someone makes a change on the remote, pull it down with:
|
If someone makes a change on the remote, pull it down with:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git pull
|
git pull
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -91,31 +90,31 @@ git pull
|
|||||||
A branch is a full copy of the project to test additional ideas.
|
A branch is a full copy of the project to test additional ideas.
|
||||||
You can make a new branch called 'featurez' like this:
|
You can make a new branch called 'featurez' like this:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git branch $FEATURE_BRANCH
|
git branch $FEATURE_BRANCH
|
||||||
```
|
```
|
||||||
|
|
||||||
Have a look at all your branches:
|
Have a look at all your branches:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git branch
|
git branch
|
||||||
```
|
```
|
||||||
|
|
||||||
Switch to your new branch:
|
Switch to your new branch:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git checkout $FEATURE_BRANCH
|
git checkout $FEATURE_BRANCH
|
||||||
```
|
```
|
||||||
|
|
||||||
And if your changes are rubbish, checkout the "master" branch again, then delete "featurez":
|
And if your changes are rubbish, checkout the "master" branch again, then delete "featurez":
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git branch -D $FEATURE_BRANCH
|
git branch -D $FEATURE_BRANCH
|
||||||
```
|
```
|
||||||
|
|
||||||
Or if it's a good branch, push it to the remote:
|
Or if it's a good branch, push it to the remote:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
remote=origin
|
remote=origin
|
||||||
git push $remote $FEATURE_BRANCH
|
git push $remote $FEATURE_BRANCH
|
||||||
```
|
```
|
||||||
@ -124,13 +123,13 @@ git push $remote $FEATURE_BRANCH
|
|||||||
|
|
||||||
Once you like the feature, merge it into the main branch. Switch to master then merge it:
|
Once you like the feature, merge it into the main branch. Switch to master then merge it:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git merge $FEATURE_BRANCH
|
git merge $FEATURE_BRANCH
|
||||||
```
|
```
|
||||||
|
|
||||||
And delete the branch, as you've already merged it:
|
And delete the branch, as you've already merged it:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git branch -d $FEATURE_BRANCH
|
git branch -d $FEATURE_BRANCH
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -138,7 +137,7 @@ git branch -d $FEATURE_BRANCH
|
|||||||
|
|
||||||
## Pulling another git repo into a subtree
|
## Pulling another git repo into a subtree
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git subtree add -P config git@gitlab.com:bindrpg/config.git master
|
git subtree add -P config git@gitlab.com:bindrpg/config.git master
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -146,27 +145,27 @@ git subtree add -P config git@gitlab.com:bindrpg/config.git master
|
|||||||
|
|
||||||
## Delete All History
|
## Delete All History
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git checkout --orphan temp
|
git checkout --orphan temp
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git add -A
|
git add -A
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git commit -am "release the commits!"
|
git commit -am "release the commits!"
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git branch -D master
|
git branch -D master
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git branch -m master
|
git branch -m master
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git push -f origin master
|
git push -f origin master
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -174,21 +173,21 @@ Gitlab requires more changes, such as going to `settings > repository` and switc
|
|||||||
|
|
||||||
## Clean up Bloated Repo
|
## Clean up Bloated Repo
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git fsck --full
|
git fsck --full
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git gc --prune=now --aggressive
|
git gc --prune=now --aggressive
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git repack
|
git repack
|
||||||
```
|
```
|
||||||
|
|
||||||
## Find Binary Blobs
|
## Find Binary Blobs
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
git rev-list --objects --all \
|
git rev-list --objects --all \
|
||||||
| git cat-file --batch-check='%(objecttype) %(objectname) %(objectsize) %(rest)' \
|
| git cat-file --batch-check='%(objecttype) %(objectname) %(objectsize) %(rest)' \
|
||||||
| sed -n 's/^blob //p' \
|
| sed -n 's/^blob //p' \
|
||||||
|
22
data/git/commit_for_another.md
Normal file
22
data/git/commit_for_another.md
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
---
|
||||||
|
title: "Commit for Another"
|
||||||
|
tags: [ "data", "git" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
You can make Alice the author, while you are still the commiter:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
name="Alice Bobinson"
|
||||||
|
email="alice@email.com"
|
||||||
|
|
||||||
|
git add ${file}
|
||||||
|
git commit --author="${name} <${email}>"
|
||||||
|
```
|
||||||
|
|
||||||
|
Or, make Alice both the committer and the author:
|
||||||
|
|
||||||
|
|
||||||
|
```sh
|
||||||
|
git -c user.name="${name}" -c user.email="${email}" commit -m "${message}"
|
||||||
|
```
|
||||||
|
|
19
data/interactive_string_substitution.md
Normal file
19
data/interactive_string_substitution.md
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
---
|
||||||
|
title: "Interactive String Substitution"
|
||||||
|
tags: [ "data", "vim", "substitution" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
Want to find and replace, but also confirm each instance?
|
||||||
|
|
||||||
|
```sh
|
||||||
|
vim -c "%s/${pattern}/${replacement}/gc" -c 'wq' ${file}
|
||||||
|
```
|
||||||
|
|
||||||
|
Notice that double-quotes (`"`) in the first command (`-c`).
|
||||||
|
|
||||||
|
Alternatively, check with an example string:
|
||||||
|
|
||||||
|
|
||||||
|
```sh
|
||||||
|
sed "s/${pattern}/ARGLEBARGLE/g" ${file} | grep 'ARGLEBARGLE'
|
||||||
|
```
|
13
data/sc-im/convert_spreadsheets.md
Normal file
13
data/sc-im/convert_spreadsheets.md
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
---
|
||||||
|
title: "Convert Spreadsheets"
|
||||||
|
tags: [ "data", "sc-im" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
Convert between spreadsheet formats with `sc-im`.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
sc-im --quiet --quit_afterload --nocurses --export_csv ${file}.xlsx
|
||||||
|
sc-im --quiet --quit_afterload --nocurses --export_tab ${file}.sc
|
||||||
|
sc-im --quiet --quit_afterload --nocurses --export_mkd ${file}.csv
|
||||||
|
sc-im --quiet --quit_afterload --nocurses --export_txt ${file}.tsv
|
||||||
|
```
|
@ -5,19 +5,19 @@ tags: [ "organization" ]
|
|||||||
|
|
||||||
Set up the configuration file:
|
Set up the configuration file:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task
|
task
|
||||||
```
|
```
|
||||||
|
|
||||||
Add a task:
|
Add a task:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task add update linux
|
task add update linux
|
||||||
```
|
```
|
||||||
|
|
||||||
See which task is next:
|
See which task is next:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task next
|
task next
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -25,13 +25,13 @@ Note the id number.
|
|||||||
|
|
||||||
Mark a task as started:
|
Mark a task as started:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task start 1
|
task start 1
|
||||||
```
|
```
|
||||||
|
|
||||||
Once finished:
|
Once finished:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task 1 done
|
task 1 done
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ task 1 done
|
|||||||
|
|
||||||
Add a project:
|
Add a project:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task add project:house buy potted plant
|
task add project:house buy potted plant
|
||||||
task add proj:house.repair buy screwdriver
|
task add proj:house.repair buy screwdriver
|
||||||
task add proj:house.repair buy shelf brackets
|
task add proj:house.repair buy shelf brackets
|
||||||
@ -51,11 +51,11 @@ task add pro:house.paint buy brushes
|
|||||||
|
|
||||||
## Summary
|
## Summary
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task pro:house sum
|
task pro:house sum
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task burndown.daily pro:house
|
task burndown.daily pro:house
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -63,13 +63,13 @@ The summaries will show how fast a project is being completed, and when you can
|
|||||||
|
|
||||||
# Tags
|
# Tags
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task add +buy toothbrush
|
task add +buy toothbrush
|
||||||
```
|
```
|
||||||
|
|
||||||
You can then see only tasks which involve buying something with:
|
You can then see only tasks which involve buying something with:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task +buy
|
task +buy
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -77,27 +77,27 @@ task +buy
|
|||||||
|
|
||||||
Set three contexts by their tags:
|
Set three contexts by their tags:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task context define work +sa or +hr
|
task context define work +sa or +hr
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task context define study +ed or +void or +rat
|
task context define study +ed or +void or +rat
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task context define home -sa -hr -ed -void -rat
|
task context define home -sa -hr -ed -void -rat
|
||||||
```
|
```
|
||||||
|
|
||||||
Change to the first context.
|
Change to the first context.
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task context work
|
task context work
|
||||||
```
|
```
|
||||||
|
|
||||||
Then stop.
|
Then stop.
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task context none
|
task context none
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -105,7 +105,7 @@ task context none
|
|||||||
|
|
||||||
View list of tasks completed in the last week:
|
View list of tasks completed in the last week:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task end.after:today-1wk completed
|
task end.after:today-1wk completed
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -113,19 +113,19 @@ task end.after:today-1wk completed
|
|||||||
|
|
||||||
Make a UDA 'size'.
|
Make a UDA 'size'.
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task config uda.size.type string
|
task config uda.size.type string
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task config uda.size.label Size
|
task config uda.size.label Size
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task config uda.size.values large,medium,small
|
task config uda.size.values large,medium,small
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
uda.size.default=medium
|
uda.size.default=medium
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -133,7 +133,7 @@ uda.size.default=medium
|
|||||||
|
|
||||||
This command shows tasks I'm most interested in:
|
This command shows tasks I'm most interested in:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
task next +ACTIVE or +OVERDUE or due:today or scheduled:today or pri:H
|
task next +ACTIVE or +OVERDUE or due:today or scheduled:today or pri:H
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -6,13 +6,13 @@ tags: [ "data", "tracking", "time", "timew" ]
|
|||||||
|
|
||||||
Try:
|
Try:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew summary :yesterday
|
timew summary :yesterday
|
||||||
```
|
```
|
||||||
|
|
||||||
You can also use :week, :lastweek, :month, :quarter, :year, or a range such as:
|
You can also use :week, :lastweek, :month, :quarter, :year, or a range such as:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew summary today to tomorrow
|
timew summary today to tomorrow
|
||||||
timew today - tomorrow
|
timew today - tomorrow
|
||||||
2018-10-15T06:00 - 2018-10-17T06:00
|
2018-10-15T06:00 - 2018-10-17T06:00
|
||||||
@ -22,7 +22,7 @@ Each of these can gain with the :ids tag.
|
|||||||
|
|
||||||
# Basics
|
# Basics
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew start
|
timew start
|
||||||
timew stop
|
timew stop
|
||||||
timew continue
|
timew continue
|
||||||
@ -32,7 +32,7 @@ timew tags
|
|||||||
|
|
||||||
And add ids with:
|
And add ids with:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew summary :ids
|
timew summary :ids
|
||||||
timew track 10am - 1pm timewarrior
|
timew track 10am - 1pm timewarrior
|
||||||
timew track 1pm for 2h walk
|
timew track 1pm for 2h walk
|
||||||
@ -42,50 +42,50 @@ timew track 1pm for 2h walk
|
|||||||
|
|
||||||
First get ids.
|
First get ids.
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew summary :ids
|
timew summary :ids
|
||||||
```
|
```
|
||||||
|
|
||||||
Then if we're looking at task @2:
|
Then if we're looking at task @2:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew move @2 12:00
|
timew move @2 12:00
|
||||||
timew lengthen @2 3mins
|
timew lengthen @2 3mins
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
time shorten @2 40mins
|
time shorten @2 40mins
|
||||||
```
|
```
|
||||||
|
|
||||||
# Forgetting
|
# Forgetting
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew start 1h ago @4
|
timew start 1h ago @4
|
||||||
```
|
```
|
||||||
|
|
||||||
Or if your action actually had a break:
|
Or if your action actually had a break:
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew split @8
|
timew split @8
|
||||||
```
|
```
|
||||||
|
|
||||||
Or maybe not?
|
Or maybe not?
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew join @4 @8
|
timew join @4 @8
|
||||||
timew @8 delete
|
timew @8 delete
|
||||||
```
|
```
|
||||||
|
|
||||||
Start at previous time
|
Start at previous time
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew start 3pm 'Read chapter 12'
|
timew start 3pm 'Read chapter 12'
|
||||||
timew start 90mins ago 'Read chapter 12'
|
timew start 90mins ago 'Read chapter 12'
|
||||||
```
|
```
|
||||||
|
|
||||||
Cancel currently tracked time.
|
Cancel currently tracked time.
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
timew cancel
|
timew cancel
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -157,11 +157,11 @@ with:
|
|||||||
|
|
||||||
# Fixing Errors
|
# Fixing Errors
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
curl -O https://taskwarrior.org/download/timew-dbcorrection.py
|
curl -O https://taskwarrior.org/download/timew-dbcorrection.py
|
||||||
```
|
```
|
||||||
|
|
||||||
```bash
|
```sh
|
||||||
python timew-dbcorrections.py
|
python timew-dbcorrections.py
|
||||||
```
|
```
|
||||||
|
|
||||||
|
11
data/view_torrents.md
Normal file
11
data/view_torrents.md
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
---
|
||||||
|
title: "View Torrents"
|
||||||
|
tags: [ "data", "transmission", "torrenting" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
```sh
|
||||||
|
transmission-show $file.torrent | less
|
||||||
|
```
|
||||||
|
|
||||||
|
`TRACKERS` shows where transmission will ask who has the torrent, but will probably be out of date.
|
@ -57,5 +57,5 @@ brightnessctl s 10%+
|
|||||||
|
|
||||||
- [autologin](autologin.md)
|
- [autologin](autologin.md)
|
||||||
- [services](sv.md)
|
- [services](sv.md)
|
||||||
- [wifi](wpa_cli.md)
|
- [wifi](../../networking/wpa_supplicant.md)
|
||||||
|
|
||||||
|
20
networking/bad_horse.md
Normal file
20
networking/bad_horse.md
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
---
|
||||||
|
title: "Mapping the Net"
|
||||||
|
tags: [ "networking", "graph", "fun" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
Find the path to a domain:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
domain=bad.horse
|
||||||
|
max_hops=50
|
||||||
|
|
||||||
|
tracepath -m $maximum_hops $domain
|
||||||
|
```
|
||||||
|
|
||||||
|
If you're on Debian, you can use `graph-easy` and `dothost` to make an instant diagram:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
domain=dice.camp
|
||||||
|
dothost $domain | graph-easy --boxart
|
||||||
|
```
|
@ -1,48 +0,0 @@
|
|||||||
---
|
|
||||||
title: "vim navigation"
|
|
||||||
tags: [ "vim" ]
|
|
||||||
---
|
|
||||||
|
|
||||||
| Move | Command |
|
|
||||||
|:-----|:-------------|
|
|
||||||
|Down page | C-f |
|
|
||||||
| Down half page | C-d |
|
|
||||||
| Up page | C-b |
|
|
||||||
| Up half page | C-u |
|
|
||||||
|
|
||||||
## Scroll
|
|
||||||
|
|
||||||
> C-e
|
|
||||||
|
|
||||||
> C-y
|
|
||||||
|
|
||||||
## Jumps
|
|
||||||
|
|
||||||
Go through your last jumps:
|
|
||||||
|
|
||||||
> C-I
|
|
||||||
|
|
||||||
> C-O
|
|
||||||
|
|
||||||
Go to the last and previous places you've changed:
|
|
||||||
|
|
||||||
> g;
|
|
||||||
|
|
||||||
> g,
|
|
||||||
|
|
||||||
Go to a filename, and type `gf` (Go-to-File).
|
|
||||||
For example, if you put your cursor over the `~/.vimrc` in this line, you can edit your vim configuration file.
|
|
||||||
|
|
||||||
`source ~/.vimrc`
|
|
||||||
|
|
||||||
# Project Structure
|
|
||||||
|
|
||||||
Make a 20 character 'visual split' in the current working directory ('`.`').
|
|
||||||
|
|
||||||
> :20vs .
|
|
||||||
|
|
||||||
Change the view for this:
|
|
||||||
|
|
||||||
> C-w x
|
|
||||||
|
|
||||||
|
|
@ -1,14 +0,0 @@
|
|||||||
---
|
|
||||||
title: "vim windows"
|
|
||||||
tags: [ "vim" ]
|
|
||||||
---
|
|
||||||
|
|
||||||
| Command | Keys |
|
|
||||||
|:-----|:----:|
|
|
||||||
| split window | C-w s |
|
|
||||||
| split window vertically | C-w v |
|
|
||||||
| close window | C-q |
|
|
||||||
| change window | C-w w |
|
|
||||||
| rotate windows | C-w r |
|
|
||||||
| split open new file | :sf path/file |
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
|||||||
---
|
|
||||||
title: "Vim Tricks"
|
|
||||||
tags: [ "vim" ]
|
|
||||||
---
|
|
||||||
|
|
||||||
## Remote Editing
|
|
||||||
|
|
||||||
> vim scp://*user*@*myserver*[:*port*]//*path/to/file.txt*
|
|
||||||
|
|
78
writing/latex_setup.md
Normal file
78
writing/latex_setup.md
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
---
|
||||||
|
title: "LaTeX Setup the Hard Way"
|
||||||
|
tags: [ "writing" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
# Warm Up
|
||||||
|
|
||||||
|
1. Deep breath.
|
||||||
|
1. Cup of tea.
|
||||||
|
1. Remove the old LaTeX junk you've installed. Search for 'texlive' or 'latex' in your package manager's installed files.
|
||||||
|
1. Find `tlmgr` in your package manager.
|
||||||
|
|
||||||
|
# `tlmgr`
|
||||||
|
|
||||||
|
The LaTeX Package manager is known as `tlmgr`, and often resides in `/opt/texlive/${YEAR}/bin/x86_64-linux/tlmgr`.
|
||||||
|
Double-check the location:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
ls -l /opt/texlive/${YEAR}/bin/x86_64-linux/tlmgr
|
||||||
|
ls /opt/texlive/${YEAR}/texmf-dist/scripts/texlive/tlmgr.pl
|
||||||
|
```
|
||||||
|
|
||||||
|
Double-check the year.
|
||||||
|
It should *not* match the real year, it should match the `texlive`.
|
||||||
|
|
||||||
|
## Problems along the Path
|
||||||
|
|
||||||
|
You can't use `tlmgr` unless it's in the `$PATH`.
|
||||||
|
|
||||||
|
Check if it *is* in the `$PATH` then if it *should* be in the path:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
echo $PATH
|
||||||
|
grep texlive -r /etc/profile*
|
||||||
|
```
|
||||||
|
|
||||||
|
If `tlmgr` is where it should be, but not in the path, you can add it temporarily:
|
||||||
|
|
||||||
|
|
||||||
|
```sh
|
||||||
|
export PATH=${PATH}:/opt/texlive/${YEAR}/bin/x86_64-linux
|
||||||
|
```
|
||||||
|
|
||||||
|
...or just reboot.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
Search packages:
|
||||||
|
|
||||||
|
|
||||||
|
```sh
|
||||||
|
tlmgr search --global epstopdf
|
||||||
|
```
|
||||||
|
|
||||||
|
Can't find what you need?
|
||||||
|
Search for a specific file instead:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
tlmgr search --global --file epstopdf-base.sty
|
||||||
|
sudo tlmgr install epstopdf-pkg
|
||||||
|
```
|
||||||
|
|
||||||
|
## Recommended Packages
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
latexmk
|
||||||
|
luatex
|
||||||
|
titletoc
|
||||||
|
titlesec
|
||||||
|
multicol
|
||||||
|
microtype
|
||||||
|
graphicx
|
||||||
|
fontspec
|
||||||
|
makeindex
|
||||||
|
imakeidx
|
||||||
|
```
|
||||||
|
|
@ -10,7 +10,8 @@ tags: [ "vim", "basic" ]
|
|||||||
|
|
||||||
## Extras
|
## Extras
|
||||||
|
|
||||||
- [Navigation](navigate.md)
|
- [Navigation](vim/navigate.md)
|
||||||
- [Completion](vim-completion.md)
|
- [Completion](vim/completion.md)
|
||||||
- [Search](vim-search.md)
|
- [Search](vim/search.md)
|
||||||
- [Window Splits](vim-windows.md)
|
- [Window Splits](vim/windows.md)
|
||||||
|
- [Use vim bindings in bash](vim/vim_in_bash.md)
|
@ -1,16 +1,17 @@
|
|||||||
---
|
---
|
||||||
title: "vim completion"
|
title: "vim completion"
|
||||||
tags: [ "vim" ]
|
tags: [ "vim", "completion" ]
|
||||||
|
requires: [ "vim basics" ]
|
||||||
---
|
---
|
||||||
|
|
||||||
Complete the word by searching for the *n*ext similar word:
|
Complete the word by searching for the *n*ext similar word:
|
||||||
|
|
||||||
> C-n
|
`C-n`
|
||||||
|
|
||||||
Complete the word by searching for a *p*revious similar word:
|
Complete the word by searching for a *p*revious similar word:
|
||||||
|
|
||||||
> C-p
|
`C-p`
|
||||||
|
|
||||||
Complete the full line:
|
Complete the full line:
|
||||||
|
|
||||||
> C-x C-l
|
`C-x C-l`
|
36
writing/vim/navigate.md
Normal file
36
writing/vim/navigate.md
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
---
|
||||||
|
title: "vim navigation"
|
||||||
|
tags: [ "vim", "navigation" ]
|
||||||
|
requires: [ "vim basics" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
| Move | Command |
|
||||||
|
|:------------------------|:-------------|
|
||||||
|
| Down page | Ctl-f |
|
||||||
|
| Down half page | Ctl-d |
|
||||||
|
| Up page | Ctl-b |
|
||||||
|
| Up half page | Ctl-u |
|
||||||
|
| Scroll down | Ctl-e |
|
||||||
|
| Scroll up | Ctl-y |
|
||||||
|
| Jump to previous place | Ctl-i |
|
||||||
|
| Jump to back | Ctl-o |
|
||||||
|
| Jump to last change | g; |
|
||||||
|
| Jump to next change | g, |
|
||||||
|
| Go to current filename | gf |
|
||||||
|
|
||||||
|
Go to a filename, and type `gf` (Go-to-File).
|
||||||
|
For example, if you put your cursor over the `~/.vimrc` in this line, you can edit your vim configuration file.
|
||||||
|
|
||||||
|
`source ~/.vimrc`
|
||||||
|
|
||||||
|
# Project Structure
|
||||||
|
|
||||||
|
Make a 20 character 'visual split' in the current working directory ('`.`').
|
||||||
|
|
||||||
|
`:20vs .`
|
||||||
|
|
||||||
|
Swap buffer positions:
|
||||||
|
|
||||||
|
`C-w x`
|
||||||
|
|
||||||
|
|
@ -1,22 +1,23 @@
|
|||||||
---
|
---
|
||||||
title: "vim search"
|
title: "vim search"
|
||||||
tags: [ "vim" ]
|
tags: [ "vim", "search" ]
|
||||||
|
requires: [ "vim basics" ]
|
||||||
---
|
---
|
||||||
Search for the next and or previous occurrence of the word under your cursor with `*` and `#`.
|
Search for the next and or previous occurrence of the word under your cursor with `*` and `#`.
|
||||||
|
|
||||||
Search and replace the first 'one' found with 'two':
|
Search and replace the first 'one' found with 'two':
|
||||||
|
|
||||||
> :%s/one/two/
|
`:%s/one/two/`
|
||||||
|
|
||||||
Same, but replace 'one' globally:
|
Same, but replace 'one' globally:
|
||||||
|
|
||||||
> :%s/one/two/g
|
`:%s/one/two/g`
|
||||||
|
|
||||||
Put quotes around every occurrence of `$HOME`:
|
Put quotes around every occurrence of `$HOME`:
|
||||||
|
|
||||||
> :%s/$HOME/"&"
|
`:%s/$HOME/"&"`
|
||||||
|
|
||||||
Same, but add curly brackets around `$HOSTNAME`:
|
Same, but add curly brackets around `$HOSTNAME`:
|
||||||
|
|
||||||
> :%s/$HOSTNAME/{&}
|
`:%s/$HOSTNAME/{&}`
|
||||||
|
|
@ -1,13 +1,14 @@
|
|||||||
---
|
---
|
||||||
title: "vim in bash"
|
title: "vim in bash"
|
||||||
tags: [ "vim", "bash", "inputrc" ]
|
tags: [ "vim", "bash", "inputrc" ]
|
||||||
|
requires: [ "vim basics" ]
|
||||||
---
|
---
|
||||||
|
|
||||||
Put bash in vim mode!
|
Put bash in vim mode!
|
||||||
|
|
||||||
Place the following in your `~/.inputrc`:
|
Place the following in your `~/.inputrc`:
|
||||||
|
|
||||||
```bash
|
```
|
||||||
set editing-mode vi
|
set editing-mode vi
|
||||||
set show-mode-in-prompt on
|
set show-mode-in-prompt on
|
||||||
set vi-ins-mode-string \1\e[33;32m\2[>]=\1\e[0m\2
|
set vi-ins-mode-string \1\e[33;32m\2[>]=\1\e[0m\2
|
15
writing/vim/windows.md
Normal file
15
writing/vim/windows.md
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
---
|
||||||
|
title: "vim windows"
|
||||||
|
tags: [ "vim" ]
|
||||||
|
requires: [ "vim basics" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
| Command | Keys |
|
||||||
|
|:--------------------------|:-------------------:|
|
||||||
|
| split window | `C-w s` |
|
||||||
|
| split window vertically | `C-w v` |
|
||||||
|
| close window | `C-q` |
|
||||||
|
| change window | `C-w w` |
|
||||||
|
| rotate windows | `C-w r` |
|
||||||
|
| split open new file | `:sf $filepath` |
|
||||||
|
|
10
writing/vim_tricks.md
Normal file
10
writing/vim_tricks.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
---
|
||||||
|
title: "Vim Tricks"
|
||||||
|
tags: [ "vim" ]
|
||||||
|
requiered: [ "ssh" ]
|
||||||
|
---
|
||||||
|
|
||||||
|
## Remote Editing
|
||||||
|
|
||||||
|
`vim scp://*user*@*myserver*[:*port*]//*path/to/file.txt*`
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user