NAME

VCP::Plugin - A base class for VCP::Source and VCP::Dest

SYNOPSIS

use VCP::Plugin;
@ISA = qw( VCP::Plugin );
...

DESCRIPTION

Some functionality is common to sources and destinations, such as cache access, help text generation , command-line access shortcut member, etc.

EXTERNAL METHODS

new

Creates an instance, see subclasses for options. The options passed are usually native command-line options for the underlying repository's client. These are usually parsed and, perhaps, checked for validity by calling the underlying command line.

plugin_documentation
$text = $p->plugin_documentation;

Returns the text of the DESCRIPTION section of a module's .pm as contained in VCP::Help. The DESCRIPTION returned is determined by $self.

SUBCLASSING

This class uses the fields pragma, so you'll need to use base and possibly fields in any subclasses.

SUBCLASS API

These methods are intended to support subclasses.

init

This is called after new() and before processing. No attempt to connect to or open a repository or database file should be made until init() is called (ie not in new()).

usage_and_exit
GetOptions( ... ) or $self->usage_and_exit ;

Used by subclasses to die if unknown options are passed in.

tmp_dir

Returns the temporary directory this plugin should use, usually something like "/tmp/vcp123/dest-p4".

queue_END_sub

In order to provide ordered destruction and cleanup at application shutdown, plugins can queue up code to run before all directories are deleted.

mkdir
$self->mkdir( $filename ) ;
$self->mkdir( $filename, $mode ) ;

Makes a directory and any necessary parent directories.

The default mode is 770. Does some debug logging if any directories are created.

Returns nothing.

mkpdir
$self->mkpdir( $filename ) ;
$self->mkpdir( $filename, $mode ) ;

Makes the parent directory of a filename and all directories down to it.

The default mode is 770. Does some debug logging if any directories are created.

Returns the path of the parent directory.

COPYRIGHT

Copyright 2000, Perforce Software, Inc. All Rights Reserved.

This module and the VCP package are licensed according to the terms given in the file LICENSE accompanying this distribution, a copy of which is included in vcp.

AUTHOR

Barrie Slaymaker <barries@slaysys.com>