Test::AutoBuild::ArchiveManager::Memory - Disk based archive manager


Test-AutoBuild documentation Contained in the Test-AutoBuild distribution.

Index


Code Index:

NAME

Top

Test::AutoBuild::ArchiveManager::Memory - Disk based archive manager

SYNOPSIS

Top

  use Test::AutoBuild::ArchiveManager::Memory;

METHODS

Top

AUTHORS

Top

Daniel Berrange <dan@berrange.com>, Dennis Gregorovic <dgregorovic@alum.mit.edu>

COPYRIGHT

Top

SEE ALSO

Top

perl(1), Test::AutoBuild, Test::AutoBuild::Runtime


Test-AutoBuild documentation Contained in the Test-AutoBuild distribution.
# -*- perl -*-
#
# Test::AutoBuild::ArchiveManager::Memory
#
# Daniel Berrange <dan@berrange.com>
# Dennis Gregorovic <dgregorovic@alum.mit.edu>
#
# Copyright (C) 2004-2005 Dennis Gregorovice, Daniel Berrange
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# 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.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
#
# $Id: Memory.pm,v 1.4 2007/12/08 17:35:16 danpb Exp $

package Test::AutoBuild::ArchiveManager::Memory;

use base qw(Test::AutoBuild::ArchiveManager);
use warnings;
use strict;
use Log::Log4perl;
use Test::AutoBuild::Archive::Memory;

sub init {
    my $self = shift;
    my %params = @_;

    $self->SUPER::init(@_);

    $self->{archives} = {};
}

sub create_archive {
    my $self = shift;
    my $key = shift;

    $self->{archives}->{$key} = Test::AutoBuild::Archive::Memory->new(key => $key);
}

sub get_current_archive {
    my $self = shift;
    my $runtime = shift;

    my $key = $runtime->build_counter;

    return $self->{archives}->{$key};
}


sub list_archives {
    my $self = shift;

    return sort { $a->key cmp $b->key } values %{$self->{archives}};
}


1 # So that the require or use succeeds.

__END__