NAME
Class::Scaffold::App - large-scale OOP application support
SYNOPSIS
use base 'Class::Scaffold::App';
sub app_code {
my $self = shift;
$self->SUPER::app_code(@_);
# ... application-specific tasks ...
}
main->new->run_app;
DESCRIPTION
This is the base class for applications built with the Class::Scaffold framework, be they command-line applications or server-based applications. Applications will subclass this class, implement their specific tasks and call run_app()
.
METHODS
- run_app
-
This is the main method that application subclasses should invoke. It calls the other methods described here. If there is an exception, it catches and logs it.
- app_code
-
Called by
run_app()
right at the beginning. Override this method in your application-specific subclass to do any initialization your application needs. - app_finish
-
Called by
run_app()
within atry
/catch
-block. Override this method to do the actual application-specific work. - app_init
-
Called by
run_app()
right before the end. Override this method to do any cleanup your application needs. clear_initialized
-
$obj->clear_initialized;
Clears the boolean value by setting it to 0.
initialized
-
$obj->initialized($value); my $value = $obj->initialized;
If called without an argument, returns the boolean value (0 or 1). If called with an argument, it normalizes it to the boolean value. That is, the values 0, undef and the empty string become 0; everything else becomes 1.
initialized_clear
-
$obj->initialized_clear;
Clears the boolean value by setting it to 0.
initialized_set
-
$obj->initialized_set;
Sets the boolean value to 1.
set_initialized
-
$obj->set_initialized;
Sets the boolean value to 1.
Class::Scaffold::App inherits from Class::Scaffold::Storable.
The superclass Class::Scaffold::Storable defines these methods and functions:
MUNGE_CONSTRUCTOR_ARGS(), clear_storage_info(), clear_storage_type(),
delete_storage_info(), exists_storage_info(), id(),
keys_storage_info(), storage(), storage_info(), storage_info_clear(),
storage_info_delete(), storage_info_exists(), storage_info_keys(),
storage_info_values(), storage_type(), storage_type_clear(),
values_storage_info()
The superclass Class::Scaffold::Base defines these methods and functions:
new(), FIRST_CONSTRUCTOR_ARGS(), add_autoloaded_package(), init(),
log()
The superclass Data::Inherited defines these methods and functions:
every_hash(), every_list(), flush_every_cache_by_key()
The superclass Data::Comparable defines these methods and functions:
comparable(), comparable_scalar(), dump_comparable(),
prepare_comparable(), yaml_dump_comparable()
The superclass Class::Scaffold::Delegate::Mixin defines these methods and functions:
delegate()
The superclass Class::Scaffold::Accessor defines these methods and functions:
mk_framework_object_accessors(), mk_framework_object_array_accessors(),
mk_readonly_accessors()
The superclass Class::Accessor::Complex defines these methods and functions:
mk_abstract_accessors(), mk_array_accessors(), mk_boolean_accessors(),
mk_class_array_accessors(), mk_class_hash_accessors(),
mk_class_scalar_accessors(), mk_concat_accessors(),
mk_forward_accessors(), mk_hash_accessors(), mk_integer_accessors(),
mk_new(), mk_object_accessors(), mk_scalar_accessors(),
mk_set_accessors(), mk_singleton()
The superclass Class::Accessor defines these methods and functions:
_carp(), _croak(), _mk_accessors(), accessor_name_for(),
best_practice_accessor_name_for(), best_practice_mutator_name_for(),
follow_best_practice(), get(), make_accessor(), make_ro_accessor(),
make_wo_accessor(), mk_accessors(), mk_ro_accessors(),
mk_wo_accessors(), mutator_name_for(), set()
The superclass Class::Accessor::Installer defines these methods and functions:
install_accessor()
The superclass Class::Accessor::Constructor defines these methods and functions:
_make_constructor(), mk_constructor(), mk_constructor_with_dirty(),
mk_singleton_constructor()
The superclass Class::Accessor::FactoryTyped defines these methods and functions:
clear_factory_typed_accessors(), clear_factory_typed_array_accessors(),
count_factory_typed_accessors(), count_factory_typed_array_accessors(),
factory_typed_accessors(), factory_typed_accessors_clear(),
factory_typed_accessors_count(), factory_typed_accessors_index(),
factory_typed_accessors_pop(), factory_typed_accessors_push(),
factory_typed_accessors_set(), factory_typed_accessors_shift(),
factory_typed_accessors_splice(), factory_typed_accessors_unshift(),
factory_typed_array_accessors(), factory_typed_array_accessors_clear(),
factory_typed_array_accessors_count(),
factory_typed_array_accessors_index(),
factory_typed_array_accessors_pop(),
factory_typed_array_accessors_push(),
factory_typed_array_accessors_set(),
factory_typed_array_accessors_shift(),
factory_typed_array_accessors_splice(),
factory_typed_array_accessors_unshift(),
index_factory_typed_accessors(), index_factory_typed_array_accessors(),
mk_factory_typed_accessors(), mk_factory_typed_array_accessors(),
pop_factory_typed_accessors(), pop_factory_typed_array_accessors(),
push_factory_typed_accessors(), push_factory_typed_array_accessors(),
set_factory_typed_accessors(), set_factory_typed_array_accessors(),
shift_factory_typed_accessors(), shift_factory_typed_array_accessors(),
splice_factory_typed_accessors(),
splice_factory_typed_array_accessors(),
unshift_factory_typed_accessors(),
unshift_factory_typed_array_accessors()
The superclass Class::Scaffold::Factory::Type defines these methods and functions:
factory_log()
The superclass Class::Factory::Enhanced defines these methods and functions:
add_factory_type(), make_object_for_type(), register_factory_type()
The superclass Class::Factory defines these methods and functions:
factory_error(), get_factory_class(), get_factory_type_for(),
get_loaded_classes(), get_loaded_types(), get_my_factory(),
get_my_factory_type(), get_registered_class(),
get_registered_classes(), get_registered_types(),
remove_factory_type(), unregister_factory_type()
The superclass Class::Accessor::Constructor::Base defines these methods and functions:
STORE(), clear_dirty(), clear_hygienic(), clear_unhygienic(),
contains_hygienic(), contains_unhygienic(), delete_hygienic(),
delete_unhygienic(), dirty(), dirty_clear(), dirty_set(),
elements_hygienic(), elements_unhygienic(), hygienic(),
hygienic_clear(), hygienic_contains(), hygienic_delete(),
hygienic_elements(), hygienic_insert(), hygienic_is_empty(),
hygienic_size(), insert_hygienic(), insert_unhygienic(),
is_empty_hygienic(), is_empty_unhygienic(), set_dirty(),
size_hygienic(), size_unhygienic(), unhygienic(), unhygienic_clear(),
unhygienic_contains(), unhygienic_delete(), unhygienic_elements(),
unhygienic_insert(), unhygienic_is_empty(), unhygienic_size()
The superclass Tie::StdHash defines these methods and functions:
CLEAR(), DELETE(), EXISTS(), FETCH(), FIRSTKEY(), NEXTKEY(), SCALAR(),
TIEHASH()
BUGS AND LIMITATIONS
No bugs have been reported.
Please report any bugs or feature requests through the web interface at http://rt.cpan.org.
INSTALLATION
See perlmodinstall for information and options on installing Perl modules.
AVAILABILITY
The latest version of this module is available from the Comprehensive Perl Archive Network (CPAN). Visit <http://www.perl.com/CPAN/> to find a CPAN site near you. Or see <http://www.perl.com/CPAN/authors/id/M/MA/MARCEL/>.
AUTHORS
Florian Helmberger <fh@univie.ac.at>
Achim Adam <ac@univie.ac.at>
Mark Hofstetter <mh@univie.ac.at>
Heinz Ekker <ek@univie.ac.at>
Marcel Grünauer, <marcel@cpan.org>
COPYRIGHT AND LICENSE
Copyright 2004-2009 by the authors.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.