NAME
Git::Class::Cmd
SYNOPSIS
use strict;
use warnings;
use Git::Class;
my $git = Git::Class::Cmd->new;
my $worktree = $git->clone('git://github.com/charsbar/git-class.git');
my $captured = $git->status; # as a whole
my @captured = $git->status; # split by "\n"
# other interface, mainly for internal use
my $cmd = Git::Class::Cmd->new( die_on_error => 1, verbose => 1 );
$cmd->git( commit => { message => 'a commit message', all => '' } );
DESCRIPTION
This is a simple wrapper of a git
executable. The strength is that you can run a git
command and capture the output in a simple and more portable way than using open
to pipe (which is not always implemented fully).
As of this writing, most of the git commands (methods of this class) simply returns the output, but this will be changed in the near future, especially when called in the list context, where we may want sort of proccessed data like what files are affected etc.
METHODS
Most of the git commands are implemented as a role. See Git::Class::Role::* for details.
is_available
returns true if the git
command exists (or specified explicitly).
git
takes a git command name (whatever git
executable recognizes; it doesn't matter if it's implemented in this package (as a method/role) or not), and options/arguments for that.
Options may be in a hash reference (or hash references if you prefer). You don't need to care about the order and shell-quoting, and you don't need to prepend '--' to the key in this case, but you do need to set its value to a blank string(""
) (or undef
) if the option doesn't take a value. Of course you can pass option strings merged in the argument list.
Note that if you want to pass options for git
executable (instead of git command options), pass them as a hash reference first, before you pass a command string, and command parameters.
$cmd->git({ git_dir => '/path/to/repo/' }, 'command', ...);
Returns a captured text in the scalar context, or split lines in the list context. If some error (or warnings?) might occur, you can see it in $object->_error
.
Note that if the $object->is_verbose
, the captured output is printed as well. This may help if you want to issue interactive commands.
If you want to trace commands, set GIT_CLASS_TRACE
environmental variable to true.
no_capture
is an accessor/mutator to determine if we should use Capture::Tiny to capture the output of git commands. If your web apps hang because of the capturing, set this to true to disable it.
AUTHOR
Kenichi Ishigaki, <ishigaki@cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2009 by Kenichi Ishigaki.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.