3 releases (breaking)

Uses old Rust 2015

0.3.0 Aug 30, 2016
0.2.0 Aug 30, 2016
0.1.0 Aug 26, 2016

#59 in #time-tracking

BSD-3-Clause

44KB
825 lines

Timmy

Timmy is a time tracker. At the moment it is not particularly stable or even well written! Things like parsing dates in english (eg. "yesterday 12:00") may be buggy. If you do want to install it run:

matt@box:~/$ cargo install timmy

and make sure ~/.cargo/bin or equivalent is in your PATH.

Example usage

Creating a new project can be done with the new command. Tags are comma separated.

matt@box:~/$ # Creating a new project called timmy with the customer 'me' and tags 'rust,cli'
matt@box:~/$ timmy new timmy -c me -t rust,cli

You can get a list of projects like so:

matt@box:~/$ timmy projects
┌───────┬──────────┬──────────┐
│ Name  │ Customer │ Tags     │
├───────┼──────────┼──────────┤
│ timmy │ me       │ cli,rust │
└───────┴──────────┴──────────┘

You can start tracking using timmy track. You can optionally add a start point or a start and end point to add some time that you forgot to track.

matt@box:~/$ timmy track <project>
matt@box:~/$ # Starting time 
matt@box:~/$ timmy track <project> -s "12:00" 
matt@box:~/$ # Starting time and end
matt@box:~/$ timmy track <project> -s "12:00" -e "13:00"

Timmy will monitor what programs you are using, this can be disabled by passing -n. At the end of a session timmy will automatically look for any git commits in the repo in the current directory. If you edit history (eg. reverting a commit) you can run:

matt@box:~/$ timmy git <project>

and it will repopulate the commits for the project.

To get all information on a particular project use the project command:

matt@box:~/$ timmy project timmy
timmy
Tags: rust,cli
Total time spent: 14hrs 31mins

Program usage
98.97% emacs
 1.03% gnome-terminal-

Activity
Thu 25 August 2016 17:55-18:02 6mins
    * Print what commits have been found
    * Add total time to activity printout
Thu 25 August 2016 17:44-17:54 9mins
    * Add week flag to show activity in last week
Thu 25 August 2016 17:18-17:27 9mins
    * Add support for dates like 20/08 to chronny
    * Fix 20/08 date not being parsed
Thu 25 August 2016 16:32-17:15 42mins
    * Add filtering activity by dates
    * Add absolute dates to chronny
    * Remove id from projects table
Wed 24 August 2016 14:09-14:30 21mins
    * Add start and end options to track
    * Add kitchen sink test for chronny
Tue 23 August 2016 20:35-21:24 48mins
    * Add relative times
Tue 23 August 2016 15:47-17:12 1hrs 25mins
    * Start writing a human datetime parsing lib
    * Use i64 for row ids
    * Automatically look for commits at the end of track
Tue 23 August 2016 15:28-15:46 18mins
Mon 22 August 2016 21:18-21:27 8mins: Example usage
    * Extend readme with example usage
Mon 22 August 2016 20:30-21:04 34mins
    * Add short weeks view
    * Use debug! instead of error!
    * Rename week command to weeks
    * Stop projects panicing when project is not found
Mon 22 August 2016 15:38-17:47 2hrs 9mins
    * Add total separator to week view
    * Use tables lib in timmy
    * Remove double bordering from tables
    * First attempt at a tables lib
Mon 22 August 2016 14:50-15:33 42mins
    * Add total to weeks view
    * Move formatting a time difference into a function
    * First version of weeks view
Mon 22 August 2016 14:20-14:41 20mins
Sun 21 August 2016 18:22-18:25 2mins: bugfixing
    * Make total time display correct
Sun 21 August 2016 17:04-18:20 1hrs 15mins: Upload to github
    * Add readme
    * Make project view work with no timeperiods or tags
Sun 21 August 2016 15:49-16:03 13mins
    * Remove abc
    * Refactor project view
    * Fix clippy warnings
    * Rename SqliteError to Sqlite
Sun 21 August 2016 15:23-15:48 24mins: Clean up
Sun 21 August 2016 14:50-15:03 12mins: Total time on project vew
    * Add total time to project view
Sun 21 August 2016 14:35-14:46 11mins: Fix projects list
    * Fix projects view
Sun 21 August 2016 13:48-14:24 35mins: Project view
    * Add tags to project view
    * Move getting tags into query
    * Add project view
Sat 20 August 2016 21:28-21:42 13mins: Project view
Sat 20 August 2016 20:06-20:47 41mins: Views
    * Refactor printing a row into a function
    * Implement projects list
Sat 20 August 2016 18:39-19:21 42mins: Views
Sat 20 August 2016 14:50-14:57 6mins: Test sqlites support for times
Sat 20 August 2016 13:45-13:59 13mins
    * Use question mark instead of try!
    * Add description to timeperiods
    * Rename timeperiod to timeperiods for consistency
Sat 20 August 2016 13:40-13:41 0mins
Sat 20 August 2016 12:56-13:38 41mins
Fri 19 August 2016 19:18-19:58 39mins
Fri 19 August 2016 18:08-18:23 15mins
    * Use own error type
Total: 14hrs 31mins

This is quite long so you can get the activity between certain times or dates like so:

matt@box:~/$ timmy project timmy -s 22/08/16 -u 24/08/16
timmy
Tags: rust,cli
Total time spent: 14hrs 31mins

Program usage
98.97% emacs
 1.03% gnome-terminal-

Activity
Wed 24 August 2016 14:09-14:30 21mins
    * Add start and end options to track
    * Add kitchen sink test for chronny
Tue 23 August 2016 20:35-21:24 48mins
    * Add relative times
Tue 23 August 2016 15:47-17:12 1hrs 25mins
    * Start writing a human datetime parsing lib
    * Use i64 for row ids
    * Automatically look for commits at the end of track
Tue 23 August 2016 15:28-15:46 18mins
Mon 22 August 2016 21:18-21:27 8mins: Example usage
    * Extend readme with example usage
Mon 22 August 2016 20:30-21:04 34mins
    * Add short weeks view
    * Use debug! instead of error!
    * Rename week command to weeks
    * Stop projects panicing when project is not found
Total: 3hrs 37mins

You can even use English date descriptions like so:

matt@box:~/$ timmy project timmy -s "yesterday 12:00"
timmy 
Tags: rust,cli
Total time spent: 14hrs 31mins

Program usage
98.97% emacs
 1.03% gnome-terminal-

Activity
Thu 25 August 2016 17:55-18:02 6mins
    * Print what commits have been found
    * Add total time to activity printout
Thu 25 August 2016 17:44-17:54 9mins
    * Add week flag to show activity in last week
Thu 25 August 2016 17:18-17:27 9mins
    * Add support for dates like 20/08 to chronny
    * Fix 20/08 date not being parsed
Thu 25 August 2016 16:32-17:15 42mins
    * Add filtering activity by dates
    * Add absolute dates to chronny
    * Remove id from projects table
Total: 1hrs 8mins

You can get a week by week view of a project as well:

matt@box:~/$ timmy weeks timmy
┌──────────┬───────┬─────────────┐
│ Week     │ Day   │ Time        │
├──────────┼───────┼─────────────┤
│ 22/08/16 │ Mon   │ 3hrs 56mins │
│          │ Tue   │ 2hrs 32mins │
│          │ Wed   │ 21mins      │
│          │ Thu   │ 1hrs 8mins  │
│          ├───────┼─────────────┤
│          │ Total │ 7hrs 58mins │
├──────────┼───────┼─────────────┤
│ 15/08/16 │ Fri   │ 55mins      │
│          │ Sat   │ 2hrs 40mins │
│          │ Sun   │ 2hrs 57mins │
│          ├───────┼─────────────┤
│          │ Total │ 6hrs 33mins │
└──────────┴───────┴─────────────┘

Dependencies

~28MB
~532K SLoC