diff options
Diffstat (limited to 'lib/CIL/Command/Status.pm')
-rw-r--r-- | lib/CIL/Command/Status.pm | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/lib/CIL/Command/Status.pm b/lib/CIL/Command/Status.pm new file mode 100644 index 0000000..b74f2ae --- /dev/null +++ b/lib/CIL/Command/Status.pm @@ -0,0 +1,71 @@ +## ---------------------------------------------------------------------------- +# 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::Status; + +use strict; +use warnings; + +use base qw(CIL::Command); + +## ---------------------------------------------------------------------------- + +sub name { 'status' } + +sub run { + my ($self, $cil, $args, $status, @issue_names) = @_; + + unless ( defined $status ) { + CIL::Utils->fatal("provide a valid status to set this issue to"); + } + + my @issues; + + # for every issue, read it it and set the Status + foreach my $issue_name ( @issue_names ) { + # firstly, read the issue in + my $issue = CIL::Utils->load_issue_fuzzy( $cil, $issue_name ); + + # set the label for this issue + $issue->Status( $status ); + $issue->save($cil); + + # if we want to add or commit this issue + if ( $cil->UseGit ) { + if ( $args->{add} or $args->{commit} ) { + $cil->git->add( $cil, $issue ); + } + } + + push @issues, $issue; + } + + if ( $cil->UseGit ) { + # if we want to commit these issues + if ( $args->{commit} ) { + my $message = "Status changed to '$status'"; + $cil->git->commit_multiple( $cil, $message, @issues ); + } + } +} + +1; +## ---------------------------------------------------------------------------- |