/usr/share/perl5/HTML/Widgets/NavMenu/Object.pm is in libhtml-widgets-navmenu-perl 1.0702-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 | package HTML::Widgets::NavMenu::Object;
use strict;
use warnings;
use Class::XSAccessor;
sub new
{
my $class = shift;
my $self = {};
bless $self, $class;
$self->_init(@_);
return $self;
}
sub _init
{
my $self = shift;
return 0;
}
sub destroy_
{
my $self = shift;
return 0;
}
sub DESTROY
{
my $self = shift;
$self->destroy_();
}
=head2 __PACKAGE__->mk_accessors(qw(method1 method2 method3))
Equivalent to L<Class::Accessor>'s mk_accessors only using Class::XSAccessor.
It beats running an ugly script on my code, and can be done at run-time.
Gotta love dynamic languages like Perl 5.
=cut
sub mk_accessors
{
my $package = shift;
return $package->mk_acc_ref([@_]);
}
=head2 __PACKAGE__->mk_acc_ref([qw(method1 method2 method3)])
Creates the accessors in the array-ref of names at run-time.
=cut
sub mk_acc_ref
{
my $package = shift;
my $names = shift;
my $mapping = +{ map { $_ => $_ } @$names };
eval <<"EOF";
package $package;
Class::XSAccessor->import(
accessors => \$mapping,
);
EOF
}
=head1 NAME
HTML::Widgets::NavMenu::Object - a base object for HTML::Widgets::NavMenu
=head1 SYNOPSIS
For internal use only
=head1 FUNCTIONS
=head2 my $obj = HTML::Widgets::NavMenu::Object->new(@args)
Instantiates a new object. Calls C<$obj-E<gt>_init()> with C<@args>.
=head2 my $obj = HTML::Widgets::NavMenu::Object->destroy_();
A method that can be used to explicitly destroy an object.
=head1 COPYRIGHT & LICENSE
Copyright 2006 Shlomi Fish, all rights reserved.
This program is released under the following license: MIT X11.
=cut
1;
|