From b6dc680c8e2c9c00adffbf5b4399052b7203cd55 Mon Sep 17 00:00:00 2001 From: Andrew Chilton Date: Thu, 9 Oct 2008 13:41:35 +1300 Subject: [PATCH] Added the 'work' command to cil --- lib/CIL/Command/Work.pm | 57 +++++++++++++++++++++++++++++++++++++++++ lib/CIL/VCS/Git.pm | 15 +++++++++++ 2 files changed, 72 insertions(+) create mode 100644 lib/CIL/Command/Work.pm diff --git a/lib/CIL/Command/Work.pm b/lib/CIL/Command/Work.pm new file mode 100644 index 0000000..7ffc6dd --- /dev/null +++ b/lib/CIL/Command/Work.pm @@ -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 . +# +## ---------------------------------------------------------------------------- + +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; + +## ---------------------------------------------------------------------------- diff --git a/lib/CIL/VCS/Git.pm b/lib/CIL/VCS/Git.pm index b41d545..abc30fd 100644 --- a/lib/CIL/VCS/Git.pm +++ b/lib/CIL/VCS/Git.pm @@ -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; ## ---------------------------------------------------------------------------- -- 2.39.5