]> git.mjollnir.org Git - cil.git/commitdiff
Added the 'work' command to cil
authorAndrew Chilton <andychilton@gmail.com>
Thu, 9 Oct 2008 00:41:35 +0000 (13:41 +1300)
committerAndrew Chilton <andychilton@gmail.com>
Thu, 9 Oct 2008 00:41:35 +0000 (13:41 +1300)
lib/CIL/Command/Work.pm [new file with mode: 0644]
lib/CIL/VCS/Git.pm

diff --git a/lib/CIL/Command/Work.pm b/lib/CIL/Command/Work.pm
new file mode 100644 (file)
index 0000000..7ffc6dd
--- /dev/null
@@ -0,0 +1,57 @@
+## ----------------------------------------------------------------------------
+# cil is a Command line Issue List
+# Copyright (C) 2008 Andrew Chilton
+#
+# This file is part of 'cil'.
+#
+# cil is free software: you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation, either version 3 of the License, or (at your option) any later
+# version.
+#
+# This program is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+# FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
+# details.
+#
+# You should have received a copy of the GNU General Public License along with
+# this program.  If not, see <http://www.gnu.org/licenses/>.
+#
+## ----------------------------------------------------------------------------
+
+package CIL::Command::Work;
+
+use strict;
+use warnings;
+use File::Slurp qw(read_file write_file);
+
+use base qw(CIL::Command);
+
+## ----------------------------------------------------------------------------
+
+sub name { 'work' }
+
+sub run {
+    my ($self, $cil, $args, $issue_name) = @_;
+
+    # firstly, read the issue in
+    my $issue = CIL::Utils->load_issue_fuzzy( $cil, $issue_name );
+
+    # right, got it's name, let's see if there is a branch for it
+    use Data::Dumper;
+    my @branches = $cil->vcs->branches();
+    my $branch = {};
+    foreach ( @branches ) {
+        $branch->{substr $_, 2} = 1;
+    }
+    if ( exists $branch->{$issue->name} ) {
+        $cil->vcs->switch_to_branch( $issue->name );
+    }
+    else {
+        $cil->vcs->create_branch( $issue->name );
+    }
+}
+
+1;
+
+## ----------------------------------------------------------------------------
index b41d545db9484154bed43a6b0a740820b2fa8241..abc30fd5d317af33eea3f4d50045f99b7a873aab 100644 (file)
@@ -93,6 +93,21 @@ sub UserEmail {
     return $_[0]->git->config( 'user.email' );
 }
 
+sub branches {
+    my ($self) = @_;
+    return $self->git->command('branch');
+}
+
+sub switch_to_branch {
+    my ($self, $branch_name) = @_;
+    $self->git->command('checkout', $branch_name);
+}
+
+sub create_branch {
+    my ($self, $branch_name) = @_;
+    $self->git->command('checkout', '-b', $branch_name);
+}
+
 ## ----------------------------------------------------------------------------
 1;
 ## ----------------------------------------------------------------------------