blob: b86f44f1d6ed006aa190728f62e1ffd7ab776f91 (
plain)
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
107
108
109
110
111
112
113
114
115
116
117
|
package rpm;
use strict;
use Carp;
use vars qw($VERSION @ISA @EXPORT @EXPORT_OK $AUTOLOAD);
require Exporter;
require DynaLoader;
require AutoLoader;
@ISA = qw(Exporter DynaLoader);
# Items to export into callers namespace by default. Note: do not export
# names by default without a very good reason. Use EXPORT_OK instead.
# Do not simply export all your public functions/methods/constants.
@EXPORT = qw(
);
$VERSION = '0.01';
sub AUTOLOAD {
# This AUTOLOAD is used to 'autoload' constants from the constant()
# XS function. If a constant is not found then control is passed
# to the AUTOLOAD in AutoLoader.
my $constname;
($constname = $AUTOLOAD) =~ s/.*:://;
croak "& not defined" if $constname eq 'constant';
my $val = constant($constname, @_ ? $_[0] : 0);
if ($! != 0) {
if ($! =~ /Invalid/) {
$AutoLoader::AUTOLOAD = $AUTOLOAD;
goto &AutoLoader::AUTOLOAD;
}
else {
croak "Your vendor has not defined rpm macro $constname";
}
}
no strict 'refs';
*$AUTOLOAD = sub () { $val };
goto &$AUTOLOAD;
}
bootstrap rpm $VERSION;
# Preloaded methods go here.
sub Header::ItemByName {
my $header = shift;
my $item = shift;
my $item_index = shift;
if (defined $item_index) {
return @{$header->ItemByNameRef($item)}[$item_index];
} else {
return @{$header->ItemByNameRef($item)};
}
}
sub Header::ItemByVal {
my $header = shift;
my $item = shift;
my $item_index = shift;
if (defined $item_index) {
return @{$header->ItemByValRef($item)}[$item_index];
} else {
return @{$header->ItemByValRef($item)};
}
}
sub Header::List {
my $header = shift;
return %{$header->ListRef()};
}
sub Header::Tags {
my $header = shift;
return @{$header->TagsRef()};
}
# Autoload methods go after =cut, and are processed by the autosplit program.
1;
__END__
# Below is the stub of documentation for your module. You better edit it!
=head1 NAME
rpm - Perl extension for blah blah blah
=head1 SYNOPSIS
use rpm;
blah blah blah
=head1 DESCRIPTION
Stub documentation for rpm was created by h2xs. It looks like the
author of the extension was negligent enough to leave the stub
unedited.
Blah blah blah.
=head1 Exported constants
=head1 AUTHOR
Cristian Gafton, gafton@redhat.com
=head1 SEE ALSO
perl(1), rpm(8).
=cut
|