NAME
MDV::Repsys::Remote
SYNOPSYS
Module to access and build rpm from a svn
FUNCTIONS
new(%options)
Create a new MDV::Repsys::Remote object
options:
- configfile
-
Use this repsys configuration file instead /etc/repsys.conf
- nocommit
-
Disable commit action, usefull for testing purpose
last_error
Return the last error message after a failure.
set_verbosity($level)
Set the verbosity verbosity of the module:
0 silent
1 progress message
2 debug message
get_pkgurl_parent($pkgname, %options)
Return the parent svn url location for package named $pkgname
get_pkgurl($pkgname, %options)
Return the svn url location for package named $pkgname
checkout_pkg($pkgname, $destdir, %options)
Checkout a package from svn into $destdir directory
get_old_changelog($pkgname, $handle, %options)
Read old changelog entry from svn and write it into $handle. If not specified, $handle is set to STDOUT.
log_pkg($pkgname, $handle, %options)
Build a log from svn and print it into $handle. If not specified, $handle is set to STDOUT.
build_final_changelog($pkgname, $handle, %options)
Build the complete changelog for a package and print it into $handle. If not specified, $handle is set to STDOUT.
get_final_spec_fd($pecfile, $fh, %options)
Generated the final specfile from $pecfile into $fh filehandle.
get_final_spec($specfile, %options)
Build the final changelog for upload from $specfile.
$options{pkgname} is the package name, if not specified, it is evaluate from the specfile.
The new specfile will generated into $options{specfile} is specified, otherwise a file with same name is create into $options{destdir}.
The module is safe, the source and destination can be the same file, the content will be replaced.
if $options{destdir} is not specified, a temporary directory is created. This directory will be trashed on MDV::Repsys::Remote object destruction. So this kind of code will not work:
my $o = MDV::Repsys::Remote->new();
my $newspec = $o->get_final_spec($specfile);
$o = undef;
do_something_with($newspecfile); # the directory has been deleted
Notice this kind of code produce a warning.
get_pkg_lastrev($pkgname, %options)
Return the real last revision change for a package.
get_dir_lastrev($dir, %options)
Return the real last revision change for package checkout into $dir.
get_srpm($pkgname, %options)
Build the final src.rpm from the svn. Return the svn revision and the src.rpm location.
create_pkg($pkgname)
Create a package directory on the svn.
import_pkg($rpmfile, %options)
Import a source package into the svn.
splitchangelog($specfile, %options)
Strip the changelog from a specfile and commit it into the svn.
commit($dir, %options)
Synchronize sources found into the spec and commit files into the svn.
tag_pkg($pkgname, %options)
TAG a package into the svn, aka copy the current tree into VERSION/RELEASE/. The operation is done directly into the svn.
get_pkg_info($pkgname, %options)
Return a hash containing usefull information about $pkgname:
- pkgname
-
The name of the package
- size
-
The size of the package (sum of files size)
- last_rev
-
The revision of the last changed
-
The author of the last change
- last_time
-
The time of last change (integer value, use loacaltime to have a human readable value)
submit($pkgname, %options)
Submit the package on the build host.
cleanup
This module creates a number of temporary directories; all are deleted when the program terminates, but with this function you can force a removal of these directories.
FUNCTION OPTIONS
- revision
-
Work on this revision from the svn
- destdir
-
Extract files into this directories instead a temporary directory.
AUTHORS
Olivier Thauvin <nanardon@mandriva.org>