-
Notifications
You must be signed in to change notification settings - Fork 1
/
Status.pm
129 lines (80 loc) · 2.38 KB
/
Status.pm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
package Group::Git::Cmd::Status;
# Created on: 2013-05-06 21:57:07
# Create by: Ivan Wills
# $Id$
# $Revision$, $HeadURL$, $Date$
# $Revision$, $Source$, $Date$
use Moo::Role;
use strict;
use warnings;
use version;
use Carp;
use English qw/ -no_match_vars /;
use File::chdir;
use Getopt::Alt;
our $VERSION = version->new('0.6.5');
requires 'repos';
requires 'verbose';
my $opt = Getopt::Alt->new(
{ help => __PACKAGE__, },
[
'quiet|q',
]
);
sub status_start {
$opt->process;
return;
}
sub status {
my ($self, $name) = @_;
return unless -d $name;
my $repo = $self->repos->{$name};
my $cmd;
local $CWD = $name;
$cmd = join ' ', 'git', 'status', map { $self->shell_quote } @ARGV;
my $out = `$cmd 2>&1`;
return $out if $self->verbose;
return if $out =~ /nothing \s+ to \s+ commit/xms && $opt->opt->quiet;
return $out;
}
1;
__END__
=head1 NAME
Group::Git::Cmd::Status - Runs git status on a git project
=head1 VERSION
This documentation refers to Group::Git::Cmd::Status version 0.6.5.
=head1 SYNOPSIS
use Group::Git::Cmd::Status;
# Brief but working code example(s) here showing the most common usage(s)
# This section will be as far as many users bother reading, so make it as
# educational and exemplary as possible.
=head1 DESCRIPTION
=head1 SUBROUTINES/METHODS
=over 4
=item C<status ($name)>
Runs git status on each directory if the status message includes:
"nothing to commit"
The status is suppressed to keep the output clean. This can be overridden
if verbose is set.
=item C<status_start ()>
Process the command line arguments for status
=back
=head1 DIAGNOSTICS
=head1 CONFIGURATION AND ENVIRONMENT
=head1 DEPENDENCIES
=head1 INCOMPATIBILITIES
=head1 BUGS AND LIMITATIONS
There are no known bugs in this module.
Please report problems to Ivan Wills (ivan.wills@gmail.com).
Patches are welcome.
=head1 AUTHOR
Ivan Wills - (ivan.wills@gmail.com)
=head1 LICENSE AND COPYRIGHT
Copyright (c) 2013 Ivan Wills (14 Mullion Close, Hornsby Heights, NSW Australia 2077).
All rights reserved.
This module is free software; you can redistribute it and/or modify it under
the same terms as Perl itself. See L<perlartistic>. 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.
=cut