NAME
VCS::Which - Generically interface with version control systems
VERSION
This documentation refers to VCS::Which version 0.0.2.
SYNOPSIS
use VCS::Which;
# create a new object
my $vcs = VCS::Which->new();
if ( !$vcs->uptodate('.') ) {
warn "Directory has uncommitted changes\n";
}
DESCRIPTION
This module provides methods to interface with a version control system (vcs) with out having to care which command to use or which sub command in needed for several basic operations like checking if there are any uncommitted changes.
SUBROUTINES/METHODS
new ( %args )
Arg: dir
- string - (optional) a directory that will be used for determining the used version control system. It is used for other methods that require a directory and one is not supplied.
Return: VCS::Which - A new object.
Description:
load_systems ()
Description: Creates new objects for each version control system found
get_systems ()
Description: Searches for version control systems plugins installed
capabilities ( [$dir] )
Param: $dir
- string - Directory to base out put on
Return: list context - The data for each system's capabilities scalar context - A string displaying each system's capabilities
Description: Gets the capabilities of each system and returns the results
which ( [$dir] )
Param: $dir
- string - Directory to work out which system it is using
Return: VCS::Which::Plugin - Object which can be used against the directory
Description: Determines which version control plugin can be used to with the supplied directory.
uptodate ( $dir )
Param: $dir
- string - Directory to base out put on
Return: bool - True if the everything is checked in for the directory
Description: Determines if there are any changes that have not been committed to the VCS running the directory.
exec ( @args )
Param: @args
- array - Arguments to pass on to the appropriate vcs command
Description: Runs the appropriate vcs command with the parameters supplied
DIAGNOSTICS
CONFIGURATION AND ENVIRONMENT
DEPENDENCIES
INCOMPATIBILITIES
BUGS AND LIMITATIONS
The initial template usually just has:
There are no known bugs in this module.
Please report problems to Ivan Wills (ivan.wills@gmail.com).
Patches are welcome.
AUTHOR
Ivan Wills - (ivan.wills@gmail.com)
LICENSE AND COPYRIGHT
Copyright (c) 2009 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 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.