Dain-Bread Simple TODO list
Project description
dbs == dain-bread simple
========================
TODO list for minimalists
# SPDX-License-Identifier: GPL-2.0-only
# Copyright (c) 2022, Al Stone <ahs3@ahs3.net>
A "task" consists of a file that looks something like this:
Task: get something done
State: open
Project: stuff
Priority: h
Note: this is a note
Note: this is another note
(sans indenting, of course). Each key:value is exactly one line (everything
up until the newline). There are a few limits:
-- State is one of 'open', 'active', 'done' or 'deleted' [0]
-- Priority is one of 'h', 'm', 'l'
It's all pretty self-explanatory. I've tried to keep this as simple as
possible, but Python wants things packaged properly, and I wanted to have
both a CLI version (dbs) and an ncurses version (dbsui) using the same code
for managing tasks. So, yeah, needed to create a module to package and
distribute with.
Installation is simple: clone the source tree, cd to the clone, then:
$ make install
Or:
$ pip install dbs-todo
That's it. Python3 is the only requirement. Most distros will have the
right Python modules by default. I use this on Fedora and Debian, so
your mileage may vary.
To add a task like the one above:
$ dbs add 0001 stuff h "get something done"
That's it. It's automatically created as an open task. You can find all
open tasks with:
$ dbs lo
('lo' == 'list open' -- extra credit if you can figure out the command for
'list active' and 'list done').
If you do this:
$ dbs
You'll get a list of all current commands and any parameters they might need.
There is a config file: it is always $HOME/.config/dbs/config. The only thing
you can specify is this:
repo: <some directory path>
If it does not exist, it will be created. If the repo path does not exist,
it will be created, also. In the repo, there is a directory for each task
state containing one file for each task in that state. Task names must be
unique across all states since we move the files around in the various repo
directories [1].
With 0.6.0, I've added an ncurses-based UI. It's crude, probably buggy
even. It can be invoked with:
$ dbsui
There is a 'help' command ('?'). The left panel lists the projects that
have open tasks, and the right panel lists the tasks for the current
project. This is still experimental code so caveat emptor.
Notes:
[0] Nothing ever gets actually deleted unless you remove the files.
[1] In order to sync across machines, I create ~/Dropbox/dbs and use
Dropbox to sync that directory across machines.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
dbs-todo-0.6.0.tar.gz
(27.3 kB
view details)
Built Distribution
dbs_todo-0.6.0-py3-none-any.whl
(27.9 kB
view details)
File details
Details for the file dbs-todo-0.6.0.tar.gz
.
File metadata
- Download URL: dbs-todo-0.6.0.tar.gz
- Upload date:
- Size: 27.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 467e9562f465e99d19fb1c097a403b1520341be37e024a83c839aa53a9da4aac |
|
MD5 | a8720d610d0581b2bd4db4189f7fccca |
|
BLAKE2b-256 | aaf3c898a95b9ea79e874de9bc651460b92319d848949bdb6d7cbb2bbb9856d6 |
File details
Details for the file dbs_todo-0.6.0-py3-none-any.whl
.
File metadata
- Download URL: dbs_todo-0.6.0-py3-none-any.whl
- Upload date:
- Size: 27.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c14d486e4ab0c9b94dcefbae370521743b262c3f32ade225e285b817eea6be5e |
|
MD5 | f888a2e92d760a7fdd896b5b412b5b8f |
|
BLAKE2b-256 | 1f1fb6f0770c35f0e60f5951553266694b3e88fe1e406828059f7593c381df44 |