main
m455 2019-05-25 09:49:47 -04:00
commit 224b9b85b3
2 changed files with 91 additions and 60 deletions

147
README.md
View File

@ -6,6 +6,27 @@ A easy-to-use todo list program for people who live on the command line
![](screenshot.png) ![](screenshot.png)
# Table of Contents
* [TL;DR](https://github.com/m455/rodo#tldr)
* [New things](https://github.com/m455/rodo#new-things)
* [Todos](https://github.com/m455/rodo#todos)
* [Platforms](https://github.com/m455/rodo#platforms)
* [Requirements](https://github.com/m455/rodo#requirements)
* [Downloading Racket](https://github.com/m455/rodo#downloading-racket)
* [To download Racket using apt](https://github.com/m455/rodo#to-download-racket-using-apt)
* [To download Racket using pacman](https://github.com/m455/rodo#to-download-racket-using-pacman)
* [Downloading the rodo source code](https://github.com/m455/rodo#downloading-the-rodo-source-code)
* [To download the rodo source code](https://github.com/m455/rodo#to-download-the-rodo-source-code)
* [Setup](https://github.com/m455/rodo#setup)
* [Setting up a $PATH](https://github.com/m455/rodo#setting-up-a-path)
* [To set up a $PATH](https://github.com/m455/rodo#to-set-up-a-path)
* [Adding rodo to your $PATH](https://github.com/m455/rodo#adding-rodo-to-your-path)
* [To add rodo to your $PATH](https://github.com/m455/rodo#to-add-rodo-to-your-path)
* [List of commands](https://github.com/m455/rodo#list-of-commands)
* [Usage examples](https://github.com/m455/rodo#usage-examples)
* [Configuration](https://github.com/m455/rodo#configuring-rodo)
# TL;DR # TL;DR
1. Make sure [Racket](https://racket-lang.org/) is installed 1. Make sure [Racket](https://racket-lang.org/) is installed
@ -16,8 +37,7 @@ A easy-to-use todo list program for people who live on the command line
* To use `rodo` as an single-file executable follow the two steps below: * To use `rodo` as an single-file executable follow the two steps below:
1. Run `raco exe rodo.rkt` to compile the `rodo` into a single-file executable 1. Run `raco exe rodo.rkt` to compile the `rodo` into a single-file executable
2. Run `./rodo` 2. Run `./rodo`
5. (optional) Add the following to your `$PATH` directory to run `rodo` from 5. (optional) Add the following to your `$PATH` directory to run `rodo` from anywhere.
anywhere.
``` ```
#!/usr/bin/env bash #!/usr/bin/env bash
@ -26,7 +46,7 @@ racket ~/path/to/rodo.rkt "$@"
Note: If you made an executable, remember to change the `rodo.rkt` part above to `rodo` Note: If you made an executable, remember to change the `rodo.rkt` part above to `rodo`
# New things! # New things
Now the default directory and todo list file have better default permissions: Now the default directory and todo list file have better default permissions:
@ -36,69 +56,85 @@ Now the default directory and todo list file have better default permissions:
# Todos # Todos
- Update README so it's up to "technical writing standards" When I have time, I plan on adding the following features to rodo:
- Add color option to `config.rkt` file - Add color option to `config.rkt` file
- Encrypt `todo.txt` file - Encrypt `todo.txt` file
# Table of Contents
* [Platforms](https://github.com/m455/rodo#platforms)
* [Requirements](https://github.com/m455/rodo#requirements)
* [Downloading](https://github.com/m455/rodo#downloading)
* [Setup](https://github.com/m455/rodo#setup)
* [Usage](https://github.com/m455/rodo#usage)
* [Usage examples](https://github.com/m455/rodo#usage-examples)
* [Configuration](https://github.com/m455/rodo#configuring-rodo)
# Platforms # Platforms
Below is a list of platform(s) that `rodo` is currently available for. Below is a list of platforms that `rodo` can run on.
* Unix-like operating systems: * Windows Subsystem for Linux
* Windows Subsystem for Linux (Works)
* GNU/Linux (Untested) * GNU/Linux (Untested)
* macOS (Untested) * macOS (Untested)
# Requirements # Requirements
Below is a list of items needed for running `rodo` on your machine. This section will provide you with the requirements needed to run `rodo`. This
section will guide you through downloading Racket and downloading the `rodo`
source code.
* [Racket 6.x](https://racket-lang.org/) * [Racket 6.x](https://racket-lang.org/)
* `rodo` source code
# Downloading ## Downloading Racket
Run the command below to download `rodo` using the `git` command. Racket can be download using your machine's package manager. Depending on what
package manager you use, commands may vary. See the two sections below for a
list of examples using the `apt` and `pacman` package managers on the command
line.
### To download Racket using apt
1. run `sudo apt install racket`
Note: You may need to run this command as root
### To download Racket using pacman
1. run `pacman -Syu racket`
Note: You may need to run this command as root
## Downloading the rodo source code
The `rodo` source code is available from this repository, and can be downloaded using `git`.
### To download the rodo source code
1. run `git clone https://github.com/m455/rodo`
Tip: If you want to download this into a different directory, you can specify a
directory by running the command below:
``` ```
git clone https://github.com/m455/rodo git clone https://github.com/m455/rodo your-directory-name/
``` ```
# Setup # Setup
Follow the sections below to set up `rodo`, so it can be used from anywhere on For convenience, `rodo` can be added to your `$PATH`. This section will guide
your system. you through setting up a `$PATH` and adding `rodo` to your `$PATH`.
**Tip: If you just want to test `rodo` out, then just `cd` into the directory you downloaded ## Setting up a $PATH
`rodo` into, and then run `./rodo.rkt`.**
## Set up a `$PATH` A `$PATH` is a directory in which you can place executable files or script files. These files
can then be ran from any directory on your machine.
Follow the steps below if you haven't set up a `$PATH`. Tip: If you have set up a `$PATH` already, then skip to the next step, [Adding
`rodo` to your `$PATH`](https://github.com/m455/rodo#adding-rodo-to-your-path).
**Tip: If you have set up a `$PATH` already, then skip to the next step, [Adding ### To set up a $PATH
`rodo` to your `$PATH`](https://github.com/m455/rodo#adding-rodo-to-your-path).**
1. Create a directory for your `$PATH` by running `mkdir ~/bin/` 1. Create a directory for your `$PATH` by running `mkdir ~/bin/`
2. Add your newly-created `~/bin/` to your `$PATH` by running `echo "export PATH=~/bin:\$PATH" >> .bashrc` 2. Add your newly-created `~/bin/` to your `$PATH` by running `echo "export PATH=~/bin:\$PATH" >> .bashrc`
## Adding `rodo` to your `$PATH` ## Adding rodo to your $PATH
Follow the steps below to add the `rodo.rkt` file to your `$PATH`. Adding `rodo` to your `$PATH` allows you to run `rodo` from any directory on your machine.
**Tip: If you prefer to use an executable, rather than a wrapper (see the note after step one below to see what a "wrapper" is), you can create an ### To add rodo to your $PATH
executable binary file with `raco exe rodo.rkt` when in the same folder as the
`rodo.rkt` file. If you are having trouble with the `raco exe` command, refer to Racket's
documentation regarding the [creation of standalone executables](https://docs.racket-lang.org/raco/exe.html).**
1. Create a file in your `~/bin/` directory with the following contents in it: 1. Create a file in your `~/bin/` directory with the following contents in it:
@ -107,39 +143,34 @@ documentation regarding the [creation of standalone executables](https://docs.ra
racket ~/path/to/rodo.rkt "$@" racket ~/path/to/rodo.rkt "$@"
``` ```
**Note: The file created above is called a "wrapper". This is a script that
runs the `rodo.rkt` file through the Racket interpreter. If you wish to
directly run `rodo` as an executable from your `$PATH`, see the tip above**
For example: If you downloaded the project to your `~/downloads/` folder you would change the line For example: If you downloaded the project to your `~/downloads/` folder you would change the line
`racket ~/path/to/rodo.rkt "$@"` to `racket ~/downloads/rodo/rodo.rkt "$@"`. `racket ~/path/to/rodo.rkt "$@"` to `racket ~/downloads/rodo/rodo.rkt "$@"`.
2. Save the file 2. Save the file
3. Make the file executable by running `chmod u+x ~/bin/name-of-your-file` 3. Make the file executable by running `chmod u+x ~/bin/name-of-your-file`
# Usage Tip: Racket can make executables. You can do this by running the following
command when in the same folder as the `rodo.rkt` file:
Type `rodo` plus one of the commands below with a space ```
between `rodo` and the command. raco exe rodo.rkt
```
`-h` or `--help` - Displays the help message # List of commands
`init` - Creates a file called `todo.txt` in `~/.rodo/` by default This section lists and describes `rodo`'s commands.
**Note: The directory and filename can be changed by modifying the `config.rkt` file** * `-h` or `--help` displays the help message
* `init` creates a file called `todo.txt` in `~/.rodo/` by default
* `ls` displays numbered items in the todo list
* `add` adds an item to the todo list
* `rm` removes an item from the todo list
`ls` - Displays numbered items in the todo list Note: You may have to run `rodo ls` to see which number corresponds to which item when removing items.
`add` - Adds an item to the todo list # Usage examples
`rm` - Removes an item from the todo list The examples below assume that you have [added `rodo` to your `$PATH`](https://github.com/m455/rodo#adding-rodo-to-your-path).
**Note: You may have to run `rodo ls` to see which number corresponds to which item when removing items.**
## Usage examples
The examples below assume that you have `rodo` [set up in your `$PATH`](https://github.com/m455/rodo#set-up-a-path) in your `$PATH`
`rodo -h` `rodo -h`
@ -153,13 +184,13 @@ The examples below assume that you have `rodo` [set up in your `$PATH`](https://
`rodo add this is a task without quotes` `rodo add this is a task without quotes`
`rodo rm 1` `rodo rm 1` (This removes the first item in your list)
**Note: You may have to run `rodo ls` to see which number corresponds to which item when removing items.** Note: You may have to run `rodo ls` to see which number corresponds to which item when removing items.
# Configuring `rodo` # Configuring `rodo`
**Caution: Change the `config.rkt` file at your own risk, as it may break things!** **Caution: Changing the `config.rkt` file should be done at your own risk as it may break `rodo`'s functionality**
Right now, the configurations can be found in the `config.rkt file`. Settings, Right now, the configurations can be found in the `config.rkt file`. Settings,
such as the program name, directory, and the filename of the todo list file can such as the program name, directory, and the filename of the todo list file can

Binary file not shown.

Before

Width:  |  Height:  |  Size: 18 KiB

After

Width:  |  Height:  |  Size: 23 KiB