summaryrefslogtreecommitdiff
path: root/perl/rpm.pm
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