From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

# Created on: 2014-03-11 20:58:59
# Create by: Ivan Wills
# $Id$
# $Revision$, $HeadURL$, $Date$
# $Revision$, $Source$, $Date$
use strict;
use version;
use English qw/ -no_match_vars /;
use Term::ANSIColor qw/colored/;
use App::Git::Workflow::Command qw/get_options/;
our $VERSION = version->new(1.1.20);
our $workflow = App::Git::Workflow->new;
our ($name) = $PROGRAM_NAME =~ m{^.*/(.*?)$}mxs;
our %option;
sub run {
get_options(
\%option,
'all|a',
'insensitive|i',
);
my $search = shift @ARGV;
my @shas = map {/([a-fA-F\d]+)/; $1} `git rev-list --remotes`;
for my $sha (@shas) {
my $log = `git log -n 1 --name-status --oneline $sha`;
if ( $log =~ /$search/ ) {
print "$sha\n";
}
}
}
1;
__DATA__
=head1 NAME
git-search - grep for branch names
=head1 VERSION
This documentation refers to git-search version 1.1.20
=head1 SYNOPSIS
git-search [--remote|-r|--all|-a] regex
OPTIONS:
regex grep's perl (-P) regular expression
-r --remote List all remote branches
-a --all List all branches
-v Find all branches that don't match regex
--verbose Show more detailed option
--version Prints the version information
--help Prints this help information
--man Prints the full documentation for git-search
=head1 DESCRIPTION
Short hand for running
C<git branch (-r|-a)? | grep -P 'regex'>
=head1 SUBROUTINES/METHODS
=head2 C<run ()>
Executes the git workflow command
=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) 2014 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