1
0
mirror of https://github.com/RyanGreenup/cadmus.git synced 2025-01-17 20:58:38 +01:00
cadmus/README.md

248 lines
9.8 KiB
Markdown
Raw Normal View History

2020-07-12 14:07:45 +10:00
# cadmus
Shell Scripts to Facilitate Effective Note Taking
2020-07-13 00:11:59 +10:00
2020-07-14 01:40:13 +10:00
## Introduction
2020-07-13 00:22:22 +10:00
2020-07-14 00:04:46 +10:00
Essentially I ~~used to~~ have a dozen shell scripts in `~/bin` that I use to capture notes,
this is an attempt to wrap them into a single script and then have aliases to make them quick to access.
2020-07-14 01:40:13 +10:00
![](./MainMenu.png)
2020-07-17 04:34:39 +10:00
The idea is that it is just a menu to dispatch different scripts so I could
share those scripts with classmates.
## Design Philosophy
2020-07-14 01:40:13 +10:00
- ****<span style="color:rgb(90,210,90);font-family:Courier New,Courier, monospace,serif;">cadmus</span>**** acts as a menu for scripts to acheive things
2020-07-17 04:34:39 +10:00
- the script name ~~will~~ should always be printed to the terminal so the individual
script can be repurposed with out fishing through code.
- Subscripts ~~will~~ should take *only one* argument (or `STDIN`)
- If the first argument is either `-h` or `--help` help will be printed and then `exit 0`
- This might lead to some limitations but the simplicity is for sanity, modularity and extensibility.
2020-07-15 15:19:20 +10:00
- Will always return absolute path.
- I played around with relative path but it got confusing when calling the script from inside a function inside a script, so instead if you want a relative path you should do `scriptname './' | xargs realpath --relative-to='./'`
2020-07-13 00:50:04 +10:00
- Be a Front end to tie together different scripts and tools
- Don't replicate work other people have done.
- Plain Text, Open Source.
2020-07-14 01:02:06 +10:00
- Be Modular
- Pipe in input, output goes to STDOUT
- Leave Aliases and piping to the user
- See [Recommended Aliases](#recommended-aliases)
2020-07-17 04:34:39 +10:00
- ****<span style="color:rgb(90,210,90);font-family:Courier New,Courier, monospace,serif;">cadmus</span>**** will take the notes directory from the global variable `CADMUS_NOTES_DIR`
- The Actual work will be done by subscripts denoted by `description.bash`
- The subscripts will take the note directory as an argument so they are portable and modular
- The Arguments will be shifted and then all passed down to subfunctions
2020-07-13 00:22:22 +10:00
2020-07-13 00:11:59 +10:00
## Installation
2020-07-16 05:37:29 +10:00
To install:
1. satisfy [the dependencies](#Dependencies)
2. [Set up Recoll](#Configuring-recoll)
2020-07-17 04:28:18 +10:00
3. Download cadmus and put it in the `PATH`
```bash
2020-07-17 06:39:57 +10:00
git clone https://github.com/RyanGreenup/cadmus ~/.cadmus \
2020-07-20 05:10:02 +10:00
|| echo "Delete $HOME/.cadmus first"
2020-07-19 19:53:39 +10:00
mkdir -p $HOME/.local/bin
2020-07-20 05:10:02 +10:00
ln -s "$HOME/.cadmus/bin/cadmus" "$HOME/.local/bin/"
2020-07-17 04:28:18 +10:00
```
2020-07-20 05:10:02 +10:00
3. According to the [*SystemD Standard*](https://www.freedesktop.org/software/systemd/man/file-hierarchy.html) `~/.local/bin` should be in `$PATH`, if you are using some other init implementation you can add this directory to `"$PATH"` it by doing something like this:
2020-07-16 05:37:29 +10:00
2020-07-17 04:30:00 +10:00
``` bash
2020-07-20 05:10:02 +10:00
## Should work in bash/zsh/fish
echo $PATH | grep "$HOME/.local/bin" &> /dev/null && echo "$HOME/.local/bin in path already" || ls "$HOME/.local/bin" &> /dev/null && echo 'PATH="$PATH:$HOME/.local/bin"' >> $HOME/.profile
2020-07-17 04:30:00 +10:00
```
2020-07-17 04:28:18 +10:00
2020-07-20 01:52:24 +10:00
4. When first running the script it will prompt you to make a config file in the directory in which it is run.
2020-07-17 04:28:18 +10:00
<!---
2020-07-16 05:37:29 +10:00
4. Copy the help files to `/usr/share/cadmus`
5. Copy in the scripts, with [*stow*] something like this should be sensible:
```bash
exec bash
cd ~/DotFiles
if [[ -d ".git" ]]; then
echo "Adding Submodule";
git submodule add https://github.com/RyanGreenup/cadmus
else echo "Cloning Repository";
git clone https://github.com/RyanGreenup/cadmus
fi
stow -t $HOME -S cadmus
```
2020-07-12 22:07:01 +10:00
2020-07-13 22:41:08 +10:00
|:warning: WARNING |
| --- |
| Stow is [currently broken][stowIssue] on Arch If you are using Stow 2.3.1-2 downgrade |
2020-07-13 22:40:34 +10:00
> Downgrade with:
> sudo pacman -U https://archive.archlinux.org/packages/s/stow/stow-2.2.2-5-any.pkg.tar.xz
2020-07-17 04:28:18 +10:00
[stowIssue]: https://github.com/aspiers/stow/issues/65 -->
-->
2020-07-13 22:40:34 +10:00
2020-07-15 16:10:13 +10:00
### Configuring recoll
2020-07-17 04:28:18 +10:00
Currently the search just uses the default recoll config, I intend to modify this to use `~/.cadmus` as a config directory so as to not interfere with the default config.
It isn't in practice an issue if `~/.recoll` is indexing more than the notes because you can just modify the call to *Skim* (`sk`) in ..cadmus.. to start the call with `~/Notes/MD`.
2020-07-15 16:10:13 +10:00
<!---
By default *Cadmus* will use a rcoll configuration at `~/.cadmus`, this is to ensure that it doesn't conflict with any previous configuration.
Set this up by performing:
``` bash
mkdir ~/.cadmus
recoll -c ~/.cadmus
```
then select *index configuration* and configure recoll to have `~/Notes/MD` as the top directory and to exclude `~`, ideally `recoll` will index live which can configured with *indexing schedule*. *Recoll* will then start indexing the files and afterwards (≅ 1-2 minutes) the *GUI* will pop up and you can confirm that the indexing was successful.
|:note: NOTE|
| --- |
| If you want to change the notes directory change the variable `NOTES_DIR` in ****<span style="color:rgb(90,210,90);font-family:Courier New,Courier, monospace,serif;">cadmus</span>**** |
-->
2020-07-13 00:50:04 +10:00
## Usage
2020-07-13 01:45:03 +10:00
2020-07-13 01:34:07 +10:00
It's all Menu driven so just follow the diagram to do what you need.
2020-07-13 01:28:58 +10:00
![Mindmap of Program Flow](./usage.svg "Diagram of the flow of the script")
2020-07-13 01:45:03 +10:00
### Assumptions
2020-07-13 23:24:02 +10:00
It is assumed that:
2020-07-17 04:28:18 +10:00
1. Notes are:
2020-07-13 23:24:02 +10:00
1. *Markdown* files with a `.md` extension
2020-07-17 04:28:18 +10:00
2. Underneath `~/Notes` (you ma)
2020-07-13 23:24:02 +10:00
3. Recoll updates it's index on the fly
* `~/Notes` will need to be indexed by *Recoll* so the results will show up.
2020-07-14 04:26:05 +10:00
3. SSD
* I use an SSD and some scripts are pretty inefficient (like `grep | cut |
xargs find` to avoid creating a variable), I don't know if things like
would work on a HDD.
2020-07-15 02:59:08 +10:00
5. All Notes have Unique Names
2020-07-17 04:28:18 +10:00
6. On *MacOS* you'll need to define `xdg-open` so do something like:
```bash
alias xdg-open='open &>/dev/null'
```
<!---
2. You're going to use [Kitty](https://sw.kovidgoyal.net/kitty/)
* You could either change the source or use anoter terminal that supports
calling functions with `--`, e.g. `kitty -- nvim`
-->
<!---
2020-07-14 19:29:06 +10:00
5. I use [*Fish*] and *Oh My Fish* ([*OMF*]) as my default shell, this means `basename $SHELL` is `fish` for
me and even though this is written in `bash` maybe that could cause issues.
* Try [*Fish*] for a while, it's quite good, when you need to test something
it's easy to temporarily jump back with `exec zsh`.
* I wonder if this would work for [*nushell*]???
2020-07-17 04:28:18 +10:00
-->
2020-07-14 19:29:06 +10:00
[*nushell*]: https://github.com/nushell/nushell
[*Fish*]: https://fishshell.com/
[*OMF*]: https://github.com/oh-my-fish/oh-my-fish
2020-07-13 01:45:03 +10:00
2020-07-12 22:07:01 +10:00
## Dependencies
2020-07-17 04:28:18 +10:00
<!---
This was a dependency but I switched to java script
- [R](https://en.wikipedia.org/wiki/R_(programming_language))
-->
2020-07-12 22:08:13 +10:00
- [highlight](https://www.archlinux.org/packages/community/x86_64/highlight/)
2020-07-14 01:02:06 +10:00
- [recode](https://www.archlinux.org/packages/extra/x86_64/recode/)
2020-07-12 22:08:13 +10:00
- [node](https://nodejs.org/en/)
- [fzf](https://github.com/junegunn/fzf)
2020-07-17 04:28:18 +10:00
- [skim](https://github.com/lotabout/skim)
2020-07-12 22:08:13 +10:00
- [rg](https://www.google.com/search?client=firefox-b-d&q=ripgrep+github)
2020-07-17 07:39:49 +10:00
- Make sure to include `pcre2`, this comes in *Arch*, if using `cargo`:
```bash
cargo install ripgrep --features 'pcre2'
```
2020-07-12 22:08:13 +10:00
- [perl](https://wiki.archlinux.org/index.php/Perl)
- [python](https://www.python.org/download/releases/3.0/)
2020-07-13 01:40:14 +10:00
- [tmsu](https://aur.archlinux.org/packages/tmsu/)<sup>AUR</sup>
2020-07-12 22:08:13 +10:00
- [ranger](https://www.archlinux.org/packages/community/any/ranger/)
2020-07-13 01:40:14 +10:00
- [mdcat](https://aur.archlinux.org/packages/mdcat/)<sup>AUR</sup>
2020-07-12 22:08:13 +10:00
- [xclip](https://www.archlinux.org/packages/extra/x86_64/xclip/)
- [sd](https://github.com/chmln/sd)
- [fd](https://github.com/sharkdp/fd)
- [sed](https://www.gnu.org/software/sed/)
- [cut](https://www.gnu.org/software/coreutils/manual/html_node/The-cut-command.html)
- [grep](https://www.gnu.org/software/grep/)
- [find](https://man7.org/linux/man-pages/man1/find.1.html)
- [GNU realpath](https://www.gnu.org/software/coreutils/manual/html_node/realpath-invocation.html#realpath-invocation)
2020-07-13 00:28:57 +10:00
- [Recoll](https://www.lesbonscomptes.com/recoll/)
2020-07-13 00:59:48 +10:00
- [Pandoc](https://github.com/jgm/pandoc)
2020-07-16 21:16:20 +10:00
- [bat](https://github.com/sharkdp/bat)
2020-07-20 01:52:24 +10:00
- [jq]
2020-07-16 21:16:20 +10:00
2020-07-17 04:31:13 +10:00
### Recommended for all Features
- [WeasyPrint](https://aur.archlinux.org/packages/python-weasyprint/)
- [tectonic](https://tectonic-typesetting.github.io/en-US/)
- [nvim](https://neovim.io/)
- [Kitty](https://sw.kovidgoyal.net/kitty/)
- I've also heard good things about [iterm2](https://www.iterm2.com/)
- [MkDocs](https://pypi.org/project/mkdocs-material-extensions/)
- [MkDocs Material Theme](https://github.com/squidfunk/mkdocs-material)
- [MkDocs Material Extensions](https://pypi.org/project/mkdocs-material-extensions/)
- [MarkText](https://github.com/marktext/marktext)
- [VNote](https://github.com/tamlok/vnote)
### recommended / Interesting / Helpful packages not required
- [readability-cli](https://gitlab.com/gardenappl/readability-cli)
- mdless
- VSCode
2020-07-17 04:08:31 +10:00
### PATH
If installed with `pip` or `cargo` it will be necessary to add these directories to your `PATH`:
``` bash
## bash
echo '
export PATH="$HOME/.local/bin:$PATH"
export PATH="$HOME/.cargo/bin:$PATH"
' >> ~/.bashrc
## zsh
echo '
export PATH="$HOME/.local/bin:$PATH"
export PATH="$HOME/.cargo/bin:$PATH"
' >> ~/.bashrc
## fish
echo '
set PATH $HOME/.local/bin $PATH
set PATH $HOME/bin $PATH
set PATH "$HOME/.cargo/bin $PATH
' >> ~/.config/fish/config.fish
```
2020-07-14 01:02:06 +10:00
## Recommended Aliases
2020-07-17 04:28:18 +10:00
I wrote all this with aliases in mind, when I settle on some aliases i'll put up my `fish` functions. (I also wanted to do some autocomplete.)
2020-07-13 00:30:51 +10:00
## Related
- [DNote]
- [TNote]
- [Notable]
[Notable]: https://github.com/notable/notable
[TNote]: https://github.com/tasdikrahman/tnote
[DNote]: https://github.com/dnote
2020-07-14 04:26:05 +10:00
[tmpfs]: https://wiki.archlinux.org/index.php/Tmpfs
2020-07-14 04:32:20 +10:00
[shared_memory]: http://en.wikipedia.org/wiki/Shared_memory
2020-07-14 01:02:06 +10:00
[*stow*]: https://www.google.com/search?client=firefox-b-d&q=gnu+stow