]> git.defcon.no Git - trk/blobdiff - trk
Fixed up reporting to be more useful
[trk] / trk
diff --git a/trk b/trk
index 8940a49c20c4ea5f3db6cb2e230b6826463b5fee..bd10e9ec45c9f2724e2d1ba855130282b16f739c 100755 (executable)
--- a/trk
+++ b/trk
@@ -1,4 +1,25 @@
 #!/usr/bin/perl
+#
+# Copyright © Jon Langseth
+# 
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+# 
+# The above copyright notice and this permission notice shall be included in
+# all copies or substantial portions of the Software.
+# 
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
 use Time::Local;
 use Digest::MD5  qw(md5_hex);
 use File::Basename;
@@ -6,6 +27,11 @@ use POSIX;
 use strict;
 
 my $trk_dir = "$ENV{HOME}/.trk";
+if ( $ENV{TRK_DIR} )
+{
+       if ( -d $ENV{TRK_DIR} ) { $trk_dir = $ENV{TRK_DIR} if -d $ENV{TRK_DIR}; }
+       else { printf("Environment variable TRK_DIR is not a directory\n"); exit(1); }
+}
 
 use constant {
        START => 1,
@@ -70,7 +96,6 @@ sub parse_time ($$)
 sub str2time ($)
 {
        my $i = shift;
-       printf("%s\n", $i);
        return 0 if not $i =~ m/(\d\d\d\d-\d\d-\d\d) (\d\d:\d\d)/;
        return parse_time($1, $2);
 }
@@ -198,7 +223,7 @@ sub get_track_id ($;$)
        my $tracks = get_tracks($trk_id);
 
        # Look up name in list
-       foreach my $id ( keys $tracks )
+       foreach my $id ( keys %$tracks )
        {
                # Return ID for name
                return $id if ( $tracks->{$id} eq $title ) 
@@ -315,6 +340,46 @@ sub close_track ($;$)
        unlink ( $wrk_dir . "/current" );
 }
 
+
+sub report ($$;$)
+{      
+       my $current = shift;
+       my $silent = shift;
+       my $trk_id = shift;
+       my $wrk_dir = $trk_dir; 
+       $wrk_dir = $trk_dir . "/" . $trk_id if $trk_id;
+
+       my $total = 0;
+
+       my $name = get_track_name( $current, $trk_id );
+       printf("# Report for '%s':\n\n", $name) unless $silent;
+
+       open (TRACK, "<" . $wrk_dir . "/" . $current . "/tracking" ) or die ("Unable to open file, $!");
+       while ( <TRACK> )
+       {
+               next if not $_ =~ m/\[(.*)\] to \[(.*)\]/;
+               my $start = $1;
+               my $end = $2;
+               my $t_start = str2time( $start );
+               my $t_end = str2time( $end );
+               my $delta = $t_end - $t_start;
+
+               if ( not $silent )
+               {
+                       my $t = $delta;
+                       my $hours = $t / 3600;
+                       $t = $delta % 3600;
+                       my $minutes = $t / 60;
+                       printf("  %s to %s => %d hours %d minutes\n", $start, $end, $hours, $minutes);
+               }
+               $total += $delta;
+
+       }
+       close ( TRACK );
+       return $total;
+
+}      
+
 ############################################################
 
 if ( ! -d $trk_dir )
@@ -469,12 +534,96 @@ elsif ( ( $command eq "projects" ) || ( $command eq "list" )  )
        printf("Currently tracked project names:\n\n");
        my $current = get_current_id();
 
-       foreach my $id ( keys $tracks )
+       #foreach my $id ( keys %$tracks )
+       foreach my $id ( sort { $tracks->{$a} cmp $tracks->{$b} || $a cmp $b } keys %$tracks  )
        {
                printf(" %s %s\n", ($id eq $current ? ">" : " " ),$tracks->{$id} );
        }
        print("\n");
 }
+elsif ( $command eq "report" )
+{
+
+       my $format = "standard";
+       my $output = 0;
+
+        if (( $#ARGV >= 1) && 
+       ( ( $ARGV[1] eq "standard" )
+       || ( $ARGV[1] eq "terse" )
+       || ( $ARGV[1] eq "verbose" )
+       || ( $ARGV[1] eq "details" ) ) )
+       {
+               $format = $ARGV[1];
+               shift @ARGV;
+       }
+
+       $output = 0 if $format eq "terse";
+       $output = 1 if $format eq "standard";
+       $output = 2 if $format eq "verbose";
+       $output = 3 if $format eq "details";
+
+       my ( undef, $title ) = parse_arguments(START);
+
+       printf("Report format: %s\nTitle:         %s\n", $format, $title);
+
+       my $track = undef;
+
+       if ( $title )
+       {
+               $track = get_track_id( $title );
+       }
+       else
+       {
+               $track = get_last_id();
+       }
+
+       if ( not $track )
+       {
+               printf ("Unable to get info for that track\n");
+               exit(1);
+       }
+
+       my $total = 0;
+       my $subtotals = 0;
+
+       my $activities = get_tracks( $track );
+       if ( keys %$activities )
+       {
+               printf("# Reporting for sub-task/activities:\n\n") if $output >= 2;
+
+               foreach my $id ( sort { $activities->{$a} cmp $activities->{$b} || $a cmp $b } keys %$activities )
+               #foreach my $id ( keys %$activities )
+               {
+                       $subtotals += report( $id, ( $output >= 2 ? 0 : 1 ), $track );
+                       printf("# --------------------------------------------------------------\n\n") if $output >= 2;
+               }
+       }
+
+       printf("# Reporting for main track/project/task\n") if $output >= 2;
+       $total += report($track, ( ( $output >= 1 ? 0 : 1 ) ) );
+       printf("\n# ==============================================================\n\n") if $output >= 2;
+       print("\n") if $output >= 1;
+
+
+       my $t = $total;
+       my $hours = $t / 3600;
+       $t = $total % 3600;
+       my $minutes = $t / 60;
+
+       printf("Total: %d hours %d minutes\n", $hours, $minutes);
+       if ( $output >= 2 )
+       {
+               my $t = $subtotals;
+               my $hours = $t / 3600;
+               $t = $subtotals % 3600;
+               my $minutes = $t / 60;
+               printf("Time logged on tasks: %d hours %d minutes\n", $hours, $minutes);
+       }
+
+       print("# End of report\n") if $output >= 1;
+
+}
+
 elsif ( $command eq "edit" )
 {