-
Notifications
You must be signed in to change notification settings - Fork 1
/
Sh.pm
146 lines (97 loc) · 2.91 KB
/
Sh.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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
package Group::Git::Cmd::Sh;
# 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;
use Path::Tiny;
our $VERSION = version->new('0.6.10');
requires 'repos';
requires 'verbose';
my $opt = Getopt::Alt->new(
{ help => __PACKAGE__, },
[
'file|f=s',
'quote|q!',
'interactive|i',
]
);
sub sh_start {
$opt->process;
if ( $opt->opt->file && -x $opt->opt->file ) {
$opt->opt->file( '' . path($opt->opt->file)->absolute);
}
return;
}
sub sh {
my ($self, $name) = @_;
return unless -d $name;
my $repo = $self->repos->{$name};
local $CWD = $name;
my $cmd
= $opt->opt->file ? $opt->opt->file
: $opt->opt->quote ? join ' ', map { $self->shell_quote } @ARGV
: join ' ', @ARGV;
local $ENV{GROUP_GIT_NAME} = $name;
if ($opt->opt->interactive) {
system $cmd;
return;
}
my $out = `$cmd`;
return $out if $self->verbose;
return if !$out || $out =~ /\A\s*\Z/xms;
return $out;
}
1;
__END__
=head1 NAME
Group::Git::Cmd::Sh - Runs shell script in each git project
=head1 VERSION
This documentation refers to Group::Git::Cmd::Sh version 0.6.10.
=head1 SYNOPSIS
group-get sh program ...
group-git sh [--quote|-q] program ...
OPTIONS:
-q --quote Quote the program arguments before running saves you from
having to work out the next level quoting but stops you from
using other shell options eg piping (|).
-i --interactive
Stops capturing STDOUT so that interactive programs will
work as expected eg if program is bash this will let you
see the results of commands run
=head1 DESCRIPTION
Run the program in each checked out git repository.
=head1 SUBROUTINES/METHODS
=over 4
=item C<sh ($name)>
Runs all the reset of the command line in each directory as a shell script.
=item C<sh_start ()>
Process the command line arguments for sh
=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