doing is a basic CLI for adding and listing “what was I doing” reminders in a
TaskPaper-formatted text file. It allows for
multiple sections/categories and flexible output formatting.
While I’m working, I have hourly reminders to record what I’m working on, and I
try to remember to punch in quick notes if I’m unexpectedly called away from a
project. I can do this just by typing doing now tracking down the CG bug.
If there’s something I want to look at later but doesn’t need to be added to a
task list or tracker, I can type doing later check out the pinboard bookmarks
from macdrifter. When I get back to my computer — or just need a refresher
after a distraction — I can type doing last to see what the last thing on
my plate was. I can also type doing recent (or just doing) to get a list of
the last few entries. doing today gives me everything since midnight for the
current day, making it easy to see what I’ve accomplished over a sleepless
night.
Doing has over 30 commands for tracking your status, recording your time, and
analyzing the results.
See the wiki for installation and usage instructions.
Launchbar/Alfred
The LaunchBar action requires that doing be available in
/usr/local/bin/doing. If it’s not (because you’re using RVM or similar),
you’ll need to symlink it there. Running the action with Return will show the
latest 9 items from Currently, along with any time intervals recorded, and
includes a submenu of Timers for each tag.
Pressing Spacebar and typing allows you to add a new entry to currently. You an
also trigger a custom show command by typing “show [section/tag]” and hitting
return. Include any command line flags at the end of the string, and if you add
text in parenthesis, it will be processed as a note on the entry.
Point of interest, the LaunchBar Action makes use of the -o json flag for
outputting JSON to the action’s script for parsing.
If you create a plugin, custom command, or hook you can share, please
let me know. If I get a few plugin contributions, I’ll set up a
second repository for them.
Feel free to fork the repository on GitHub and make pull requests
with changes. Please target the develop branch with pull requests.
Changelog
Click to expand
2.1.88
2025-01-12 12:05
FIXED
Ruby 3.4 compatibility
2.1.87
2024-12-14 15:27
FIXED
Trying to fix runtime slowness
2.1.86
2024-03-26 10:57
FIXED
Unterminated date range, e.g. --from today will now assume current time as end date. Results of doing show all --from today will now match doing today.
2.1.85
2024-03-26 10:17
NEW
Add todo as an example command plugin
FIXED
Error thrown when trying to guess a section/view when there’s no match.
2.1.84
2023-08-17 09:49
NEW
Shortdate format config options (run doing config update and see the new shortdate_format section in your config file)
2.1.83
2023-07-01 12:49
FIXED
Error on deep_set when value is an array
2.1.82
2023-07-01 12:39
IMPROVED
Better handling of defaults for normalize functions
FIXED
Allow value of 0 to be considered a good result when testing for good values
2.1.81
2023-05-31 11:47
IMPROVED
Most commands that allow –section can now take multiple values, either by using –section multiple times or providing a comma separated list of sections to the flag
2.1.80
2023-03-11 10:50
FIXED
Remove extra divider line before grand total in byday table
2.1.79
2023-03-11 10:21
FIXED
Table header in byday output
2.1.78
2023-03-11 06:03
IMPROVED
Add plugins.byday.item_width config for byday plugin
2.1.77
2023-03-11 05:50
IMPROVED
Formatting and color for byday table
Remove @done tag from byday items
2.1.76
2023-03-10 15:16
NEW
‘byday’ export plugin to allow display of items grouped by day with total times
2.1.75
2023-01-01 07:30
FIXED
Error running commands list without --style flag
2.1.69
2022-08-28 14:37
IMPROVED
Add –since as alias for –back on again, done, meanwhile and now
2.1.68
2022-08-08 12:19
FIXED
Comparison of Doing::Section to string
2.1.66
2022-08-08 12:05
FIXED
Deprecation warning
2.1.65
2022-08-08 11:58
2.1.64
2022-07-21 09:31
Maintenance release
2.1.63
2022-07-21 07:11
NEW
Allow gem-based plugins. Any gem that starts with doing-plugin-* will be loaded and available to doing.
2.1.62
2022-07-01 10:02
IMPROVED
Better way to insert a colored string into a another string and return the the previous color at the end of the inserted string. Whew, that was a weird way to say it.
FIXED
doing view not respecting search.highlight config
2.1.61
2022-06-29 05:54
IMPROVED
Remove @meanwhile from tag totals
Less spacing between items in default HTML export CSS
FIXED
Code duplication in timers.rb
2.1.60
2022-06-29 02:06
FIXED
Failed to include update command in release
2.1.59
2022-06-29 01:59
NEW
doing update will update doing to the latest available version
FIXED
doing done ... wasn’t autotagging the new entry
2.1.58
2022-06-01 10:20
CHANGED
BREAKING: The -s flag on doing show now means section instead of search. Use --search for the search flag.
NEW
You can now use %#FFFFFF style hex strings to set colors in templates. Use %bg#FFFFFF to set a background color. Colors must be 6-digit hex codes
doing show --section NAME allows limiting tag results to a section (same as running doing show SECTION_NAME @TAG but added for compatibility with other commands)
2.1.57
2022-05-26 11:20
IMPROVED
Add i[:finished] as a boolean in Markdown export template (tests for @done tag and provides true/false)
2.1.56
2022-05-26 10:20
IMPROVED
In Markdown templates (erb), i[:flagged] will be set to true or false based on whether the item has @flagged (or whatever marker_tag is set to) present
FIXED
doing recent --interactive XX wasn’t respecting XX count and instead showing all
doing recent --section SECT COUNT not respecting count when section is provided
2.1.55
2022-05-26 07:11
FIXED
more permissions issues
2.1.54
2022-05-25 16:10
FIXED
permissions issue
IMPROVED
Reduce keypath translation logging
2.1.52
2022-05-25 12:36
FIXED
doing select -> select repeat/resume from menu, failed to repeat
2.1.51
2022-05-25 12:33
FIXED
doing archive --no-label not being respected
2.1.50
2022-05-16 07:40
FIXED
Bash completion linking dash vs underscore in path
2.1.49
2022-05-12 08:49
FIXED
When using doing again, don’t replace an existing @done tag on the entry to be repeated
2.1.48
2022-05-11 10:13
FIXED
doing now --finish_last not finishing most recent entry
doing now --from not parsing finish date from time range
2.1.47
2022-03-26 11:12
IMPROVED
--output doing now outputs true Doing file format, including IDs, so existing entries can be updated when re-importing this output
Add doing config open as a synonym for edit
Help output for --bool flag
2.1.46
2022-03-23 08:19
NEW
Store MD5 ids with each entry
JSON import takes Doing format JSON and updates existing items with matching ids, adding new entries for unmatched
IMPROVED
JSON output includes section and id for each entry
2.1.45
2022-03-22 08:57
FIXED
Specifying ‘12am’ as a start time filter resulted in a Nil error
2.1.44
2022-03-21 07:46
NEW
doing views --remove NAME to delete a view
Deleting all view content in editor (doing views -e) deletes the view
IMPROVED
When saving a view, ignore keys that are the same as the default template
Commands accepting --save also accept --title TITLE
FIXED
When saving a view, store original date string instead of chronified result
Error when testing for valid date
2.1.43
2022-03-20 12:44
NEW
‘parent’ key in view config allows inheritance
Use --save NAME with view commands to store command line options as a view in config
Views function as commands, so you can run doing custom and get doing view custom if ‘custom’ is not a recognized command
Breaking change - boolean switches on the command line no longer override views
Add an argument to doing views to dump the YAML for a single view
Use doing views NAME --editor to open the YAML for a single view in the default editor, saving the result to main config
Use doing views [-e] -o json NAME to dump or edit a view as json instead of YAML
IMPROVED
doing changes --only [changed,new,improved,fixed] to only show changes of a type
Allow all show options in view config
Disable autocorrect for command names so custom views can better override similarly-spelled commands
doing changes --prefix will output each change with a type prefix
Include -F switch in less when paging to avoid pager if less than one screen
FIXED
doing templates --list returning error
2.1.42
2022-03-17 09:38
NEW
Config option editors.pager allows you to force a pager (ignore env settings)
IMPROVED
Change pager preference order to $PAGER, less -Xr, $GIT_PAGER
Remove bat from pager options as it just falls back to less -Xr anyway
Using CTRL-C when entring a note interactively won’t cancel the whole operation, just the note
FIXED
Add delay between doing select --editor and opening the editor, fixes some TTY echo issues
If doing last --editor has no changes, exit gracefully
Trigger pre/post_write hooks when using undo/redo
doing config set issues with keys that default to nil
Notification for doing config set --remove missing last element of key path
2.1.41
2022-03-16 09:29
NEW
Filter methods available to plugins on Items collection - #in_section, #search, #tagged, #between_dates
IMPROVED
Better comparison methods for Items and Sections
doing tag_dir -r TAG can remove an indivudal tag from default_tags (–clear removes all)
doing tag_dir accepts --editor to edit tag list in default editor
doing tag_dir without arguments requests input via readline
Use .txt instead of .md for editor temp file to avoid incorrect syntax higlighting in editor
Further API documentation
FIXED
Security warnings related to regular expressions
Items.diff method returning too many changes
2.1.40
2022-03-14 19:56
NEW
doing finish accepts --from ranges to update both start and finish dates
doing finish allows --back and --took to be used together
doing finish allows --search and --tag to be used together
doing finish --from 'DATE to DATE' allows you to set a new start and end time with a single range string
doing reset --from 'DATE to DATE' allows you to reset an entry’s start time and update or add @done time
doing reset accepts a --took Xm flag to change the finish time
--output FORMAT option for all display commands, including last, recent and today
IMPROVED
Code refactoring, split up WWID class
Better diff method available to hooks to see what changed
FIXED
Search highlighting was being skipped in all cases
2.1.39
2022-03-13 04:32
NEW
--val accepts date, time, title, note, text for comparisons
IMPROVED
Allow time filtering for --val where if only a time is supplied for a date query, ignore the date and filter entries by time of day
Check for tag matching property name before assuming property in --val comparisons
Allow doing tag 'name(value)' to update an existing value (already works with --value flag)
--editor flag for doing show to batch edit results
When adding a tag via doing select, allow a tag with a value to update an existing value
FIXED
doing on today breaking on Ruby 2.6
Sort entries by both date and title to prevent shuffling between revisions
2.1.38
2022-03-12 15:40
NEW
--val 'duration > 2h' allows querying elapsed time of entries
IMPROVED
Exclude never_finish entries when searching for @done items
FIXED
--editor not saving results in some commands (including doing search -e)
Clock or dhm interval output not converting hours to days in some cases
2.1.37
2022-03-12 11:37
FIXED
Recognize STDIN input on non-Mac systems. I don’t know if this will translate to Windows or not. Resolves #136, thanks @sjsrey for the pointer
Recongnition of ‘today’ as a date input, e.g. doing on today, converts to ‘current date 12am to 11:59pm’
2.1.36
2022-02-25 08:44
FIXED
Warning when using doing done --took
2.1.35
2022-02-21 14:53
FIXED
Revert switch to sys-uname, hopefully solve crash
2.1.34
2022-02-20 09:32
IMPROVED
Allow --from 8am time range without end time to mean 8am to 11:59pm
--tag_order for commands with --totals output that were missing it
Tag and search filters for on, since, today and yesterday
Time filters for today and yesterday
--only_timed filter for yesterday
--only_timed for today
Remove exact duplicates from content before saving
doing sections now has subcommands – sections list, sections add SECTION (replaces add_section) and sections remove SECTION allows removal of a section and archiving of its contents
FIXED
doing yesterday --from not filtering time range
Don’t return a duration or interval for entries configured as never_time or never_finish
--from time filter for yesterday
Regex error in doing archive
--times error in doing today
2.1.33
2022-02-18 12:09
FIXED
Major fixes for completion scripts, especially zsh
2.1.32
2022-02-18 08:34
NEW
doing config set --local flag to force updates to local .doingrc, creating if it doesn’t exist, and bypassing menu selection
IMPROVED
doing tag_dir will not allow duplicate tags or tags that are already applied by a config higher up the hierarchy
doing tag_dir will force updates to .doingrc in the current directory rather than offering a menu
FIXED
When running without subcommand, e.g. doing this thing, the first word was being lost
Remove blank lines when running doing changes --changes --md (output changes only in Markdown format)
2.1.31
2022-02-17 12:59
NEW
doing completion install SHELL will copy the default completion scripts to your ~/.local/share/doing folder and offer to symlink them to autoload directories. These scripts are generated with each release but will not include any custom commands or plugins in the completions.
doing completion now uses subcommands, generate and install. The install command will write default scripts to ~/.local/share/doing/completion and link them into the appropriate autoload directory for the shell. The generate command will create new scripts that include any custom commands and plugins.
Convenience methods for plugins getting and setting configuration options using dot key paths (Doing.setting('plugins.myplugin.setting') and Doing.set('plugins.myplugin.setting', value))
IMPROVED
When generating completion scripts using doing completion --file FILE_PATH, if the file specified is not in an auto-load directory for the shell type, offer to symlink the output to an appropriate directory
Update examples in doing help completion and its subcommands
Move in-memory configuration into a module variable so it can be persisted/accessed outside of a WWID object using Doing.config
Clean up/update wiki example command
FIXED
Don’t output empty notes as empty brackets in JSON output (also fixes the LaunchBar view of recent entries)
Error in --back flag for doing again
Don’t try to finish items already marked @done in doing again
Generating scripts using doing completion would fail if the terminal running it was narrow enough to wrap help output
2.1.29
2022-02-14 12:42
IMPROVED
doing changes --interactive will load up a changelog viewer using fzf. Because it makes me happy, that’s why.
2.1.28
2022-02-14 11:39
FIXED
Lines merging in doing changes --changes output
2.1.27
2022-02-14 06:04
NEW
doing finish --update will overwrite any existing @done tag with a new date (current time or set with --at or --back)
IMPROVED
Code refactoring and cleanup
Include release dates in doing changes output when available
Allow various naming conventions for %color strings in templates. Now boldwhite, brightwhite, bg_bold_cyan, and bold_bg_cyan all work (for example)
Common flags (e.g. –search, –tag) found on multiple commands consolidated and help descriptions matched
commands_accepting now accepts multiple arguments and a --bool flag
changes command can now output changes only (no version numbers) and defaults to raw Markdown if not a TTY or the --md flag is used
doing archive now accepts --after and --from date filters
FIXED
Some flag descriptions in help
Editor detection
2.1.26
2022-01-23 16:14
NEW
Use plugins.hidden_commands in configuration to disable any command (array of command names). Note that some commands use aliases and the first name should be used.
doing commands [add|remove] allows interactive enabling and disabling of default and custom commands
IMPROVED
Moved all commands into separate files for management
FIXED
Changelog command regex too greedy when parsing changelog
2.1.25
2022-01-23 09:25
2.1.24
2022-01-22 17:27
IMPROVED
Minor update to Fish completion script
FIXED
Changelog formatting issue
2.1.23
2022-01-22 15:52
NEW
All display commands (except view) now accept --config_template TEMPLATE_KEY to override that commands default template.
Display commands accept --template, which takes a template string containing %placeholders and overrides the commands default template output. Affects grep, last, on, recent, show, since, today, yesterday
IMPROVED
With complete examples in the help output for most commands, doing help almost always requires scrolling up. It now automatically paginates using your system $PAGER (or best detected option).
doing tags takes a MAX_COUNT argument to limit results when searching
doing tags --line flag to output tags in a single line
Mostly for my own use, doing changes (which views the changelog) now accepts --lookup VERSION and --search SEARCH_PATTERN
doing changes --lookup accepts "< 2.1 > 2.0", "2.1.10-2.2", a specific version, or a version number with wildcards
When registering hooks, you can pass an array to register a block for multiple events, assuming the events provide the same block arguments (like post_entry_added and post_entry_updated)
FIXED
Running --tag "@doing" wouldn’t work where --tag "doing" would. Now properly ignoring @ symbols
2.1.22
2022-01-21 14:53
2.1.21
2022-01-20 12:05
FIXED
Custom types not available to custom commands
2.1.20
2022-01-20 11:49
NEW
Autotag option for interactive doing select menu
(Breaking change) Made the later command an optional plugin, see wiki for how to install (and create) custom commands
Config setting doing_file_sort (asc or desc) determines the sort order of entries in the actual Doing file. Has no effect on other operations, just allows you to store the file with newest entries at top (desc) or bottom (asc).
IMPROVED
Autotag improvements
If doing is run without a command but with arguments, execute it as if you’d run doing now, passing the arguments to that. So you can just write “doing this thing” instead of “doing now this thing”, as long as the first word of the arguments is not a recognized command.
FIXED
doing again should only mark the original repeating entry @done, not search for the last unfinished entry
Error when using doing finish --auto
doing on wed when today is wednesday not returning results
Using config set with a false value deleted the key from config
config set with true or false value was inserting a quoted string
Entries were not being sorted (at all) within sections when writing the Doing file
2.1.19
2022-01-18 08:40
FIXED
Search highlighting error with some pattern searches
Reverse sort of items in menu from --interactive flags
Nil error when --interactive was called without search results
2.1.18
Build automation test
2.1.17
2022-01-18 07:26
NEW
--hilite option for doing search to highlight matches in search results (terminal output only)
--hilite flag for show and view to highlight results when used with --search
IMPROVED
Show preview of up to 5 items when confirming a delete operation so you actually know what you’re deleting
Allow --ask when creating new entry via STDIN pipe
Tab completion for known tags when creating an entry interactively
Add purple as an alias for magenta in template colors
FIXED
Clear STDIN before requesting input
2.1.16
2022-01-18 02:45
NEW
doing done --from "3pm to 3:15pm" to set start and end times with natural language string
IMPROVED
Running doing tag without arguments takes command line input
If doing now or doing later are run without arguments, interactively request necessary information (you can still use --editor to edit in your preferred editor)
Tab completion for tags when entering at prompt
Use readline when requesting input text, better editing features
doing done --at no longer overrides --back
FIXED
doing select -> output formatted empty output
Sort items by date when using doing select --editor (was loading in selection order instead)
Ruby 2.7 error in template output (.empty? on FalseClass)
Don’t add empty entry when cancelling --editor
Batch editing bugs
2.1.15
2022-01-17 07:25
NEW
When completing an entry, if the elapsed time would be greater than a (configurable) amount, doing will now ask for confirmation and allow you to enter a new duration before setting the @done date
IMPROVED
When entering intervals, you can now use 1h30m in addition to 1.5h or 90m
Date expansion works in more circumstances
You can include date tags with natural language values when adding tags via doing select
FIXED
Tags containing values with spaces no longer cause errors
2.1.14
NEW
All commands that accept --note now accept --ask, which requests input via readline after creating the note. Multiple lines are allowed, hit return twice to end editing. Works alongside --note and --editor
IMPROVED
Implement --search and --from filtering for import plugins
UTC format date strings in select menus for consistency (was relative date formatting)
Don’t populate the fzf search with --search, it’s already filtered. Separated --query from --search if you do want to populate the query string in addition to --search filtering
When showing relative dates, don’t include the year if the date is the previous year but a later month than the current month (less than a year old)
When using --editor while adding an entry, include any note specified on the command line or via --ask for further editing
2.1.13
NEW
--val flag for all display commands, allows tag value queries. Tag values are contained in parenthesis after the tag, e.g. @progress(50). Queries look like --val "done < two weeks ago", “project *= oracle” or “progress >= 50”. Wildcards allowed in value, comparators can be <, >, <=, >=, ==, *= (contains), ^= (begins with), $= (ends with). Numeric and date comparisons are detected automatically. Text comparisons are case insensitive. --val can be used multiple times in a command and you can use --bool to specify AND, OR, or NOT (default AND)
doing tag now accepts a --value flag to define a value for a single tag, e.g. @tag(value)
FIXED
doing last --editor errors
2.1.12
NEW
Tag_dir command creates/updates .doingrc files in the current directory with default_tags values. Then all entries created within that directory (or subdirs) get tagged with that value.
Synonym triggers allow * and ? wildcards
Add --delete flag for doing last to delete last entry
--delete and --editor flags for doing search, batch edit and delete
Example hook to add new entries containing a certain tag to Day One
New hooks: pre_entry_add, post_entry_added, post_entry_updated, post_entry_removed, pre_export
IMPROVED
If you need to use a colon in an autotag transform pattern, you can split with double colon, e.g. pattern::replacement
Arrays defined in local configurations merge with main config instead of overwriting
FIXED
doing tags --interactive wasn’t showing menu
2.1.10
NEW
--age (oldest
newest) option for view command
2.1.9
IMPROVED
Only attempt to install fzf if it doesn’t exist on the system. In case of errors, this means a user can manually install fzf and still be able to access --interactive options
FIXED
Rotate command only archiving half of requested items
Frozen string error in doing import plugin
2.1.8
NEW
Hidden command doing commands_accepting which shows all commands that accept a given option, e.g. doing commands_accepting search shows all commands that take a search filter
Hidden command doing changelog which outputs a paginated, formatted version of the change history.
IMPROVED
The output of doing template --list now shows the file type of each template
Output templates can now be saved to a default location/filename using doing template html --save
FIXED
Error running doing recent on certain older ruby versions
2.1.6
NEW
doing redo undoes a redo
doing undo -i offers a list of available versions for selection
Multiple undo. Every time a command modifies the doing file, a backup is written. Running doing undo repeatedly steps back through history, doing undo 5 jumps back 5 versions
When resetting via doing select, prompt for a date string
doing reset accepts a date string argument to use as start date instead of current time if provided
doing tags lists tags used in any/all sections, sortable, with or without frequency counts
doing show --menu offers an interactive menu for selecting section and tag filters
All commands that accept a --tag filter can now handle wildcards in the tag names. * to match any number of characters, ? to match a single character.
New boolean type for tag searches, PATTERN (which is now the default). Combine tags using symbols to create more complex boolean searches, e.g. “doing +coding -work”
You can now define date_tags in config, an array of tags/patterns that will be recognized when parsing for natural language dates which are converted when saving new entries
--search strings can contain quoted phrases and use +/- to require or ban terms, e.g. `–search ‘doing +coding -writing’
Interactive option for redo command
Plugins for Day One export
IMPROVED
Better diff output for fzf preview of doing undo history
Fall back to good ol’ sed for colorizing diffs when no good tool is available
doing redo (a.k.a. doing undo --redo) can be run multiple times, stepping forward through undo history. Can also take a count to jump
Matching algorithm can be configured in settings
All template placeholders can now use the “printf” formatting that %title and %note have, allowing for padding, prefixes, etc.
Move default locations for doing file and backups to ~/.local/share/doing
doing show --menu will only offer tags that exist after any tag/search filters have been run
doing show @tag with --menu will first filter by the @tag, then do an OR search for tags selected from the menu
FIXED
doing reset without filter not automatically affecting most recent entry
config set now preserves value type (string, array, mapping) of previous value, coercing new value if needed
Preserve colors when wrapping text to new lines
Tag highlighting errors
Template options specified in views were being overriden by options in templates. View config now has precedence, but will fall back to template config for missing keys
IMPROVED
Better diff output for fzf preview of doing undo history
Fall back to good ol’ sed for colorizing diffs when no good tool is available
doing redo (a.k.a. doing undo --redo) can be run multiple times, stepping forward through undo history. Can also take a count to jump
FIXED
doing reset without filter not automatically affecting most recent entry
config set now preserves value type (string, array, mapping) of previous value, coercing new value if needed
2.1.3
NEW
BREAKING CHANGE: custom classes for Section (hash) and Items (Array). @content is still a regular Hash. Sections have methods :original and :items. This will affect plugins as wwid.content[section][:items] is now wwid[section].items (same for :original)
doing config set -r key.path will delete a key from any config file, removing empty parent keys
config list will list detected .doingrc files and the main config file in order of precedence - refactoring
When modifying start dates or @done dates via an editor command, natural language strings can be used and will be parsed into doing-formatted dates automatically
When editor is invoked, entry titles include start date, which can be modified
--before, --after, and --from date filters for select command
--from flag for doing today and doing yesterday, filter by time range
--from flag for doing search, filter by date/time range
Commands that accept --before, --after, and --from can now filter on time ranges. If the date string given contains only a time (no day or date), it will be interpreted as a time range, meaning the date isn’t filtered, but only entries within the time range are shown/processed
Add %duration placeholder to template variables
Add interval_format setting to config (applies to root or any view/template) to set intervals/durations to human (2h 15m) or text (00:02:15)
Add duration key to config (root or view/template). If set to true, will display durations by default (no need for --duration)
Most display commands now have a --duration flag that will display an elapsed time if the entry is not marked @done
IMPROVED
Config -o raw outputs value as YAML if result is a Hash/mapping, unquoted string if a single value, comma-separated list if it’s an Array.
Config -o json no longer includes key, only value.
System agnostic method for checking available executables (pager, editor)
Using config set and selecting a local config will no longer write the entire config to the local .doingrc. Instead, a nested path to the particular setting will be added to the config file.
Config set will create missing keys. Fuzzy matching will work until the path fails, then path elements after that point will be added as verbatim keys to the specified configuration (with confirmation)
Make menus only as tall as needed, so 5 options don’t take up the whole screen
Better word wrap for long note lines
FIXED
finish --took 60m is supposed to backdate the start date if needed to finish at the current time and maintain an elapsed time
If an editor was specified for config (or default as fallback) with command line options (e.g. emacs -nw), Doing would fail to recognize that the executable was available.
2.0.25
NEW
doing config set to set single config values from command line
BREAKING CHANGE: Moves ~/.doingrc to ~/.config/doing/config.yml
BREAKING CHANGE: convert config flags to subcommands, e.g. doing config --udpate => doing config update, and doing config --dump => doing config dump
2.0.24
include fzf source directly, in case git isn’t installed
fall back to installing fzf with sudo on error
2.0.20
IMPROVED
completion script generator refactor and progress bars
FIXED
compile fzf for current operating system
2.0.19
FIXED
Remove any coloring before writing to doing file
2.0.18
FIXED
Escape codes being included in doing file
2.0.17
IMPROVED
Improvements to %title formatting and wrapping
2.0.16
Test release to validate git flow automation
2.0.13
FIXED
Remove amatch gem dependency due to compatibility issues with Windows systems (also removes --fuzzy option from all search commands)
2.0.11
NEW
Append /r to tag transforms to replace original tag
FIXED
Autotag tag transform fixes
2.0.10
NEW
Add ‘timer_format’ config with ‘human’ option for tag totals
If doing view and doing show are confused, offer option to run the other command
doing completion to generate shell completion scripts for zsh, bash, and fish
--search and --not for cancel command
--case flag for commands with --search. Can be (c)ase-sensitive, (i)nsensitive, or (s)mart (default smart, case insensitive unless search string contains uppercase letters)
Add --exact flag to all commands with --search flag to force exact matching without requiring single quote prefix
Add --not flag to all commands with filters (--tag, --search, --before, etc.) to negate the filter and return entries NOT matched
IMPROVED
More command line feedback
Error formatting and output
Add subcommand completion for doing help in fish shell
Logging and error handling
FIXED
Zsh completion not outputting results
Remove --[no] from non-negatable options
doing plugins -t export -c not outputting columns
View config not respecting tag_order setting
2.0.3.pre
NEW
Import calendar events from Calendar.app on macOS
doing config --update will add newly added config keys to your existing config file (handy with plugins that define their own config keys)
Add %idnote template placeholder for “indented note” (entire note indented one tab)
(loosely printf-esque) formatting options for %note template placeholder
--interactive mode to act on results of doing grep
Printf formatting for title and date
Doing import plugin
Plugins command to list plugins
--dump option for doing config to output a key.path config key as JSON, YAML, or raw output
--no-color global flag
Log levels, with --quiet and --verbose global flags
Convert CLI messaging to Logger-based system
Use DOING_DEBUG, DOING_QUIET, or DOING_LOG_LEVEL environment variables to specify log levels before configuration is read
Hooks, register plugins to run based on events
–[no-]pager and paginate: config option to enable paging output
Never_finish and never_time config options to prevent items matching tags/sections from ever receiving @done (never_finish) or @done timestamp (never_time) - More configuration refactoring
IMPROVED
Timeline output formatting
Major plugin architecture refactoring
Fix regression where notes stored in doing file were outdented, breaking TaskPaper compatibility
When accepting a date filter, allow end date to be in the future
If an edited item has no changes, don’t update/output notification - Don’t start with query when using grep --interactive
Select menu item formatting
Output wrapping for terminal display
Redirect warn to STDOUT when run with --stdout
Fish autocomplete
--config_file global flag deprected, now uses $DOING_CONFIG environment variable so that config overrides can be available before the initial configuration is run
When --stdout or not a TTY, no color or output formatting
Highlight tags when showing results. Because it looks nice.
--tag and --search for doing note
View/section fuzzy guessing
Error reporting
If doing config finds local doingrc files, offers a menu for editing
More filtering options for doing finish
Doing done accepts --unfinished flag to finish last entry not marked @done (instead of last entry)
Doing done accepts --note flag to append a note when completing an entry
FIXED
Multi-word unquoted arguments to add_section being truncated
Show --from with date span
Handling of arbitrary times in natural language dates
Backward scope of since command with arbitrary times
doing rotate --keep wasn’t respecting keep value
1.0.93
FIXED
Gemfile error
1.0.91
NEW
“taskpaper” format available for all output options
“markdown” format available for all output commands (GFM-style task list, customizable template)
--rename option for tag command to replace tags
--regex option for tag command, for --remove and --rename
1.0.90
IMPROVED
doing finish --auto now pulls from all sections, not just the section of the target entry
FIXED
Minor fix for shell command in doing select
Fix for doing finish --auto when matched item is last in list
1.0.89
NEW
Pretty print JSON output
--no-menu option for select command to use --query as a filter and act on matching entries without displaying menu
1.0.88
IMPROVED
Add --before and --after time search to yesterday command
Add --before and --after date search to search/grep command
Add --tag_order to yesterday command
1.0.87
IMPROVED
Add leading spaces to make %shortdate align properly, at least for the last week
Add --tag, --bool, and --search to view command
Add --before and --after date search to view command
Add --before and --after date search to show command
Add --before and --after time search to today command
Add --search filter to show command
More alignment/formatting fixes for %shortdate
1.0.86
IMPROVED
Add count config option for templates->recent
1.0.85
IMPROVED
Add --before DATE_STRING to archive and rotate commands
Only create on rotate file per day, merge new entries into existing file
FIXED
Fix --auto for finish command
1.0.84
NEW
rotate command for archiving entries to new file
FIXED
Fixed current_section config key not being honored in some commands
1.0.83
FIXED
Fixes for doing view options, additional config keys for views
1.0.82
FIXED
Bugfixes
1.0.81
IMPROVED
fzf menu improvements
allow multiple selections doing select action menu
1.0.80
IMPROVED
Convert all menus to fzf screens
1.0.79
IMPROVED
Wildcard tag removal using doing select -t "tag*" -r
fzf menu display polish
FIXED
FIXED
Gem missing fzf
1.0.78
IMPROVED
If no action is specified with select command, an interactive menu is
presented
add output action select command with formatting and save options
Don’t link URLs in html output that don’t have a protocol
1.0.76
IMPROVED
Refine editing multiple selections (doing select)
1.0.74
NEW
Add --tag and --search flags to tag command to tag all entries matching search terms
Add since command, which is the same as doing on tuesday to now but doing since tuesday just feels more intuitive.
1.0.73
FIXED
Fix for timeline output
1.0.72
NEW
Add doing select to show menu of all tasks, searchable with fuzzy matching and the ability to perform certain tasks on multiple selections.
1.0.71
FIXED
Fix for template command not working at all
1.0.70
FIXED
Fix for doing done --took 30m setting the wrong @done timestamp when completing previous item
1.0.69
IMPROVED
Add --unfinished option to finish and cancel commands
1.0.68
FIXED
Fix error in doing show --sort argument parsing
1.0.67
FIXED
Gem packaging error
1.0.66
IMPROVED
More flexible boolean specification, can be: all, and, any, or, not, or none
FIXED
Fix for some long flags being interpreted as arrays instead of strings
Fix for archive command not removing original entries from archived section
1.0.65
IMPROVED
Prevent duplicates/overlapping entries when importing
1.0.64
NEW
Initial import feature for Timing.app reports
1.0.63
IMPROVED
If doing done --took=X results in completion date greater than current time, use current time as completion date and backdate the entry’s timestamp to fit
1.0.62
FIXED
doing done with --took= and without --back= should set end time to start date plus --took value
1.0.61
IMPROVED
Add --search filter to doing archive
1.0.60
FIXED
Default value for doing again --bool was ALL, should be AND
1.0.59
IMPROVED
Improvements to doing again --tag= functionality
1.0.58
IMPROVED
Finish previous task if doing again and not already completed
1.0.57
IMPROVED
Unit tests
1.0.56
IMPROVED
Tag command tests
FIXED
Doing not reading per-directory .doingrc configs
1.0.55
NEW
Added config_editor_app setting to config so you can have
A parenthetical at the end of an entry title becomes an attached
--editor flag for doing last to edit last entry
--tag= flag to filter doing last by tag
--search= to filter doing last by text/regex search
--search= for doing finish, finish last X entries matching search
Add tags_color as a primary config key to highlight @tags in displayed entries
IMPROVED
Clean up command line help
--editor improvements for all commands that use it
FIXED
Doing finish --took throwing error
Doing tag --remove was adding tags if they didn’t exist
Creating a meanwhile task with a note resulted in an error
1.0.54
FIXED
Bugfix for finish --tag=TAG
1.0.53
NEW
--tag and --bool filtering for again/resume, cancel
--in flag for again/resume to specify to which section the new
Finish command accepts --tag= flag, finishing last entry
doing cancel to end X tasks without completion date
IMPROVED
Add --no-color option to view command
Add --tag to show for compatibility
FIXED
Error running finish without --tag flag
--archive flag on finish, done, and cancel causing error
1.0.52
NEW
Finish command accepts --tag= flag, finishing last entry
FIXED
--archive flag on finish, done, and cancel causing error
1.0.49
FIXED
Fix for missing date on @done tags
1.0.48
FIXED
Fix confirmation dialog for doing tag -a -c 0 (autotag all)
1.0.47
IMPROVED
Remove check for file existence before attempting to run run_after script
Don’t autotag entries restarted with again/resume
Add short flags (-b) for --back on all commands that support it
1.0.46
IMPROVED
Code cleanup
1.0.45
IMPROVED
Only execute run_after script if changes are written
1.0.44
IMPROVED
Remove unnecessary console logging
1.0.43
NEW
Add again command to repeat last entry without @done tag
Add run_after configuration option to execute external script after any change
1.0.42
FIXED
Fix note indentation in doing file
1.0.41
FIXED
Fix for repeated backreferences in tag transform
1.0.40
IMPROVED
Add --tag_sort to all subcommands with --totals option
1.0.39
NEW
Tag transforms
Option to sort tags by name in --totals
1.0.33
FIXED
Gem dependency updates
1.0.30
FIXED
Fix for array comparison error
1.0.29
FIXED
Bugfixes
1.0.28
IMPROVED
Global option -x to skip autotags and default_tags from global/local .doingrc
Remove extra spaces when creating entry
1.0.27
IMPROVED
More graceful writing of default config (~/.doingrc) on first run
Repaired testing setup. Needs moar tests.
1.0.26
IMPROVED
Add --at flag for doing done, e.g. doing done --at=1:35pm --took=15m A new task I already finished
Allow decimal quantities when using natural language for hours or days, e.g. --took=2.5h
Add did as a synonym for done subcommand
1.0.25
IMPROVED
IMPROVED
Smarter method of getting user $HOME
Improved avoiding duplicate tags when autotagging
Improved autotag reporting
1.0.24
IMPROVED
doing note operates on whatever is most recent, not just the last note in Currently
doing tag with no count specified operates on most recent entry in any section, not just Currently
doing tag with a count greater than 1 requires a section to be specified
Improved results reporting for doing tag
When removing tag do a whole-word match to avoid removing part of a longer tag
1.0.23
IMPROVED
Apply default_tags after autotagging to avoid tags triggering tags
Set doing recent to default to All sections instead of Currently
Fix error in time reporting
improved y/n prompt for TTY
1.0.22
IMPROVED
Allow cascading of local config files
Allow doing today and yesterday to specify a section
FIXED
Fix handling of “local” config files, allowing per-project configurations
1.0.21
NEW
Add legitimate regex search capabilities
Synonyms for grep (search) and now (next)
FIXED
CSS fix
1.0.20
NEW
New command doing templates to export default templates for HAML and CSS
New config options under html_template for haml and css
IMPROVED
Rewrite HTML export templates with responsive layout and typography
Ability to customize the HTML output using HAML and CSS
1.0.19
IMPROVED
For doing note -e include the entry title so you know what you’re adding a note to
For any other command that allows -e include a comment noting that anything after the first line creates a note
Ignore # comments when parsing editor results
Add a .md extension to the temp file passed to the editor so you can take advantage of any syntax highlighting and other features in your editor
1.0.18
IMPROVED
Loosened up the template color resetting a bit more
FIXED
Fix undefined method [] for nil class error in doing view
1.0.17
NEW
Add --stdout global option to send reporting to STDOUT instead of STDERR (for use with LaunchBar et al)
1.0.16
FIXED
Fixes overzealous color resetting
1.0.15
FIXED
CLI/text totals block was outputting when HTML output was selected
Have all template colors reset bold and background automatically when called
1.0.14
IMPROVED
Fish completion
views and sections subcommands have -c option to output single column
Fix html title when tag_bool is NONE
Fix @from tagging missing closing paren
Fix tag coloring
1.0.13
FIXED
Fix gsub error in doing meanwhile
1.0.8pre
NEW
added doing on command
Added autotagging to tag command
JSON output option to view commands
date filtering, improved date language
let view templates define output format (csv, json, html, template)
IMPROVED
add %chompnote template variable (item note with newlines and extra whitespace stripped)
1.0.7pre
IMPROVED
Slightly fuzzier searching in the grep command
cleaner exits, only_timed key for view configs
making the note command append new notes better, and load existing notes in the editor if -e is called
handle multiple tag input in show tag filter
Global tag operations, better reporting
FIXED
fix for -v option
1.0.4pre
IMPROVED
Improved HTML output
--only_timed option for view/show commands that only outputs items with elapsed timers (interval between start and done dates)
add seconds for timed items in CSV output, run --only_timed before chopping off --count #
fix for 1.8.7 Dir.home issue
version bump
don’t show tag totals with zero times
zsh completion for doing
HTML styling
--only_timed option
added zsh completion file to README.md
add zsh completion file
1.0.3pre
IMPROVED
done command: making --took modify start time if --back isn’t specified
Cleaned up time totals, improved HTML output
fixes for --back and --took parsing
Adding more complete terminal reporting to archive command
1.0.0pre
IMPROVED
Skipped ahead in the version numbering. Because I don’t care.
Added a note command and --note flags for entry creation commands
0.2.6pre
IMPROVED
--totals, --[no-]times, --output [csv,html] options for yesterday command.
Add tests for Darwin to hide OS X-only features on other systems
-f flag to now command for finishing last task when starting a new one (Looks back for the last unfinished task in the list)
--took option for done and finish for specifying intervals from the start date for the completion date
Basic command line reporting
--auto flag for finish and done that will automatically set the completion time to 1 minute before the next start time in the list. You can use it retroactively to add times to sequential todos.
doing grep for searching by text or regex
0.2.5
IMPROVED
Default to showing times #26, show totals even if no tags exist #27, fix indentation #29
Add section label to archived tasks automatically, excepting Currently section
Today outputs and backdate for finish
HTML styling and fix for 1.8.7 HAML errors
Look, HTML output! (--output html)
Also, --output csv
let doing archive function on all sections
option to exclude date from @done,
output newlines in sections and views
Flagging (doing mark)
fix for view/section guess error
Adding tag filtering to archive command (doing archive \@done)
doing yesterday
doing done -r to remove last doing tag (optionally from -s Section)
Add -f flag to specify alternate doing file
meanwhile command
0.2.1
IMPROVED
CSV output for show command (--csv)
HTML output for show command (--output html)
fuzzy searching for all commands that specify a view.
In the terminal, you’ll see “Assume you meant XXX” to show what match it found, but this is output to STDERR (and won’t show up if you’re redirecting the output or using it in GeekTool, etc.)
tags_color in view config to highlight tags at the end of the lines. Can be set to any of the %colors.
Basic time tracking.
-t on show and view will turn on time calculations
Intervals between timestamps and dated @done tags are calculated for each line, if the tag exists.
You must include a %interval token in the appropriate template for it to show
@start(date) tags can optionally be used to override the timestamp in the calculation
Any other tags in the line have that line’s total added to them
Totals for tags can be displayed at the end of output with --totals
0.2.0
IMPROVED
doing done without argument tags last entry done
-a archives them
doing finish or doing finish X marks last X entries done
-a archives them
doing tag tag1 [tag2] tags last entry or -c X entries
doing tag -r tag1 [tag2] removes said tag(s)
custom views additions
custom views can include tags and tags_bool
tags is a space-separated list of tags to filter the results by
tags_bool defines AND (all tags must exist), OR (any tag exists), or NONE (none of the tags exist)
order key (asc or desc) defines output sort order by date
section key can be set to All to combine sections
doing show updates
accepts all as a section
arguments following section name are tags to filter by