The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package Froody::API;
use base qw(Froody::Base);

use strict;
use warnings;

=head1 NAME

Froody::API - Base class for API definition

=head1 SYNOPSIS

  package Project::API;
  use base 'Froody::API';

  # return all things that this API should register with a repository
  sub load { @stuff }

=head1 DESCRIPTION

This is the base class for classes that define Froody::Method objects,
Froody::ErrorType objects and all other objects that you register in a
repository.

You really shouldn't have to deal with this unless you're creating your
Froody::Methods by hand.  In most cases you'll use the Froody::API::XML
subclass of this.

=head1 METHODS

=over

=item load()

Called by C<define>.  Subclass must override this method to return a list of
objects that we should register with the API some how.  Currently we expect
this list to contain Froody::Method or Froody::ErrorType subclasses, and then
everything else is ignored.

NOTE: C<load()> should return a new instance of the objects each time the method
is called rather than the same one.  This is to prevent bad things happening
if you have more than one repository and they're using different implementations
etc.

=cut

sub load {
  Froody::Error->throw("perl.methodcall.unimplemented", "load must be implemented.");
}

=back

=head1 BUGS

The current implementation of C<get_methods> and C<get_errortypes> doesn't
do anything clever, and therefore calls C<load> twice.  We should refactor
so this isn't the case.

Please report any bugs you find via the CPAN RT system.
L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Froody>

=head1 AUTHOR

Copyright Fotango 2005.  All rights reserved.

Please see the main L<Froody> documentation for details of who has worked
on this project.

This module is free software; you can redistribute it and/or modify it under
the same terms as Perl itself.

=head1 SEE ALSO

L<Froody>, L<Froody::Method>

=cut

1;