package Lire::DlfAnalyser;

use strict;

use base qw/Lire::Plugin/;

use Carp;

=pod

=head1 NAME

Lire::DlfAnalyser - Base interface for all DLF analysers.

=head1 SYNOPSIS

  use base qw/ Lire::DlfAnalyser /;


=head1 DESCRIPTION

This package defines the interface that must be implemented by all DLF
Analysers. All the methods defined in this package will throw a
'method not implemented' exception if they are called.

Analyser which produce DLF records for an extended schema should
probably use the simpler Lire::DlfCategoriser interface.

=head1 META INFORMATION METHODS

These methods provides information to the Lire framework about the DLF
analysers.

The Lire::DlfAnalyser interface extends the Lire::Plugin interface, so
they must implement all standard meta-information methods (name(),
title(), description()).

=pod

=head2 src_schema()

Returns the Dlf schema which is analysed by this analyser.

E.g. C<www>

=cut

sub src_schema {
    croak "src_schema() not implemented by ", ref $_[0] || $_[0];
}

=pod

=head2 dst_schema()

Returns the Dlf schema which is producted by this analyser.

E.g. C<www-user_session>

=cut

sub dst_schema {
    croak "dst_schema() not implemented by ", ref $_[0] || $_[0];
}

sub type { return 'dlf_analyser' }

=head1 IMPLEMENTATION METHOD

The analyser does its job using the analyse() method. 

=head2 analyse( $process, $config )

The $process parameter contains the Lire::DlfAnalyserProcess object
which is controlling the conversion process.

The $config parameter contains configuration data that was specified
in the AnalysisJob for that converter. To register configuration
specification for you DlfAnalyser, you just need to define a
configuration specification under the name
I<analyser_name>_properties. This should be either a RecordSpec or
ObjectSpec.

=cut

sub analyse {
    croak "analyse() not implemented by ", ref $_[0] || $_[0];
}

# keep perl happy
1;

__END__

=pod

=head1 SEE ALSO

Lire::DlfAnalyserProcess(3pm), Lire::DlfStore(3pm),
Lire::PluginManager(3pm), Lire::DlfCategoriser(3pm).

=head1 AUTHOR

Francis J. Lacoste <flacoste@logreport.org>

=head1 VERSION

$Id: DlfAnalyser.pm,v 1.4 2006/07/23 13:16:28 vanbaal Exp $

=head1 COPYRIGHT

Copyright (C) 2004 Stichting LogReport Foundation LogReport@LogReport.org

This file is part of Lire.

Lire 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 (see COPYING); if not, check with
http://www.gnu.org/copyleft/gpl.html.

=cut



syntax highlighted by Code2HTML, v. 0.9.1