VCS::LibCVS::Repository - A CVS Repository.


VCS-LibCVS documentation Contained in the VCS-LibCVS distribution.

Index


Code Index:

NAME

Top

VCS::LibCVS::Repository - A CVS Repository.

SYNOPSIS

Top

DESCRIPTION

Top

Represents a CVS Repository.

CLASS ROUTINES

Top

new()

$repo = VCS::LibCVS::Repository->new($root)

return type: VCS::LibCVS::Repository
argument 1 type: . . .

The root of the repository, like this: :pserver:user@cvs.cvshome.org:/cvs

&32;&32;option 1: scalar string
&32;&32;option 2: VCS::LibCVS::Datum::Root

Creates a new Repository object with the specified root.

There is no check that the specified repository actually exists or is accessible.

INSTANCE ROUTINES

Top

get_root()

$root = $repo->get_root()

return type: VCS::LibCVS::Datum::Root

Returns the root of this repository

get_version()

$CVS_version = $repo->get_version()

return type: scalar string

Returns the version of CVS running at this repository

get_ignoreChecker()

$ignoreChecker = $repo->get_ignoreChecker()

return type: VCS::LibCVS::IgnoreChecker

Returns an IgnoreChecker for this repository

equals()

if ($repo1->equals($repo2)) {

return type: boolean
argument 1 type: VCS::LibCVS::Repository

Returns true if this and the argument represent the same the repository.

SEE ALSO

Top

  VCS::LibCVS


VCS-LibCVS documentation Contained in the VCS-LibCVS distribution.
#
# Copyright (c) 2003,2004,2005 Alexander Taler (dissent@0--0.org)
#
# All rights reserved. This program is free software; you can redistribute it
# and/or modify it under the same terms as Perl itself.
#

package VCS::LibCVS::Repository;

use strict;
use Carp;

###############################################################################
# Class constants
###############################################################################

use constant REVISION => '$Header: /cvsroot/libcvs-perl/libcvs-perl/VCS/LibCVS/Repository.pm,v 1.19 2005/10/10 12:52:11 dissent Exp $ ';

###############################################################################
# Class variables
###############################################################################

# Cache Repository objects.  Any attempt to create a new repository object with
# the same Root will return one from the cache.
use vars ('%Repository_Cache');

###############################################################################
# Private variables
###############################################################################

# $self->{Root}           object of type VCS::LibCVS::Datum::Root
# $self->{Client}         already connected VCS::LibCVS::Client
# $self->{IgnoreChecker}  object of type VCS::LibCVS::IgnoreChecker

# $self->{RepositoryFileOrDirectoryCache} hashref containing
#                                         RepositoryFileOrDirectory instances
#                                         in this repo, keys are filenames
#                                         relative to the root

##########
# $self->{FileRevisionContentsCache} hashref containing file revision contents
#
# keys are filenames (relative to the root) and revisions, like so:
# "CVSROOT/modules:1.2"
#
# This cache is populated by objects of type FileRevision.  This cache is
# necessary because of the way CVS works; it won't return the contents of the
# same revision twice in a row over a single client connection.
#
# It can grow large if FileRevision is used often across a single connection.
# For this reason it makes sense to clean it up as soon as possible once the
# connection comes down.  That's why the cache is here and not in the
# FileContents class itself.  Furthermore, if another class wanted direct
# access to the contents of a revision, it would need access to this Cache
# also.
##########

###############################################################################
# Class routines
###############################################################################

sub new {
  my $class = shift;
  my $root = shift;
  my $root_string;

  if (!ref($root)) {
    $root_string = $root;
    $root = VCS::LibCVS::Datum::Root->new($root);
  } else {
    $root_string = $root->as_string();
  }

  if ($VCS::LibCVS::Cache_Repository && $Repository_Cache{$root_string}) {
    return ($Repository_Cache{$root_string})
  }

  my $that = bless {}, $class;
  $that->{Root} = $root;
  $that->{FileRevisionContentsCache} = {};
  $that->{RepositoryFileOrDirectoryCache} = {};

  $Repository_Cache{$root_string} = $that if $VCS::LibCVS::Cache_Repository;

  return $that;
}

###############################################################################
# Instance routines
###############################################################################

sub get_root {
  my $self = shift;
  return $self->{Root};
}

sub get_version {
  my $self = shift;

  my $client = $self->_new_client();

  # If the version request is not supported, then it's pre 1.11
  return "pre 1.11" unless ($client->valid_requests()->{version});

  # Call the version request and return its result
  my $request = VCS::LibCVS::Client::Request::version->new();
  my @responses = $client->submit_request($request);

  # Throw an exception in case of error
  if (($responses[-1]->isa("VCS::LibCVS::Client::Response::error"))) {
    my $errors;
    foreach my $resp (@responses) { $errors .= ($resp->get_errors() || ""); };
    confess "Request failed: \"$errors\"";
  }

  # The first response should be of type M, with it's value the version
  return $responses[0]->get_message();
}

sub get_ignoreChecker {
  my $self = shift;

  if ( ! $self->{IgnoreChecker} ) {
    $self->{IgnoreChecker} = VCS::LibCVS::IgnoreChecker->new($self);
  }
  return $self->{IgnoreChecker};
}

sub equals {
  my $self = shift;
  my $other = shift;
  return $self->{Root}->equals($other->{Root});
}

###############################################################################
# Private routines
###############################################################################

# VCS::LibCVS::Client
#
# Returns a client connected to this repository.
# See Client.pm for details of why a repository directory name is passed.
# Used in Command.pm

sub _get_client {
  my $self = shift;
  my $any_repo_dir = shift;

  if ( ! $self->{Client} ) {
    $self->{Client} = $self->_new_client($any_repo_dir);
  }

  return $self->{Client};
}

# create a new client, connected to the repo.

sub _new_client {
  my $self = shift;
  my $any_repo_dir = shift;

  my $conn = VCS::LibCVS::Client::Connection->new($self->{Root});
  my $client = VCS::LibCVS::Client->new($conn, $self->{Root}->{RootDir});
  # Turn off two possible responses.  This will put all file transmissions
  # through the Updated responses, which is fine since this client is smarter
  # than the regular cvs client.
  $client->valid_responses()->{'Update-existing'} = 0;
  $client->valid_responses()->{'Created'} = 0;

  $client->testing_dir($any_repo_dir);

  $client->connect();
  return $client;
}

# Clean up the Repository_Cache
sub END {
  foreach my $key (keys (%Repository_Cache)) {
    delete ($Repository_Cache{$key});
  }
}

1;