]> git.deb.at Git - deb/packages.git/blob - lib/Packages/SrcPage.pm
Merge branch 'master' into ubuntu-master
[deb/packages.git] / lib / Packages / SrcPage.pm
1 package Packages::SrcPage;
2
3 use strict;
4 use warnings;
5
6 use Data::Dumper;
7 use Deb::Versions;
8 use Packages::CGI;
9 use Packages::Page qw( :all );
10
11 our @ISA = qw( Packages::Page );
12
13 #FIXME: change parameters so that we can use the version from Packages::Page
14 sub merge_data {
15     my ($self, $pkg, $suite, $archive, $data) = @_;
16
17     my %data = split /\00/o, $data;
18     $data{package} = $pkg;
19     $data{suite} = $suite;
20     $data{archive} = $archive;
21
22     return $self->merge_package( \%data );
23 }
24
25 our @DEP_FIELDS = qw( build-depends build-depends-indep
26                       build-conflicts build-conflicts-indep);
27 sub merge_package {
28     my ($self, $data) = @_;
29
30     ($data->{package} && $data->{suite} && $data->{archive}) || return;
31     $self->{package} ||= $data->{package};
32     ($self->{package} eq $data->{package}) || return;
33     debug( "merge package $data->{package}/$data->{version} into $self (".($self->{version}||'').")", 2 ) if DEBUG;
34
35     if (!$self->{version}
36         || (version_cmp( $data->{version}, $self->{version} ) > 0)) {
37         debug( "added package is newer, replacing old information" ) if DEBUG;
38
39         $self->{data} = $data;
40
41         my ($uploaders, $orig_uploaders) = $self->handle_maintainer_fields($data);
42         $self->{uploaders} = $uploaders;
43         $self->{orig_uploaders} = $orig_uploaders if @$orig_uploaders;
44
45         if ($data->{files}) {
46             my @files = split /\01/so, $data->{files};
47             $self->{files} = \@files;
48         }
49
50         foreach (@DEP_FIELDS) {
51             $self->normalize_dependencies( $_, $data );
52         }
53
54         $self->{version} = $data->{version};
55     }
56 }
57
58 #FIXME: should be mergable with the Packages::Page version
59 sub normalize_dependencies {
60     my ($self, $dep_field, $data) = @_;
61
62     my ($deps_norm, $deps) = parse_deps( $data->{$dep_field}||'' );
63     $self->{dep_fields}{$dep_field} =
64         [ $deps_norm, $deps ];
65 }
66
67 sub get_src {
68     my ($self, $field) = @_;
69     
70     return $self->{$field} if exists $self->{$field};
71     return $self->{data}{$field};
72 }
73
74 sub get_architectures {
75     die "NOT SUPPORTED";
76 }
77
78 sub get_arch_field {
79     my ($self, $field) = @_;
80
81     return $self->{data}{$field};
82 }
83
84 sub get_versions {
85     my ($self) = @_;
86
87     return [ $self->{version} ];
88 }
89
90 sub get_version_string {
91     my ($self) = @_;
92
93     my $versions = $self->get_versions;
94
95     return ($self->{version}, $versions);
96 }
97
98 sub get_dep_field {
99     my ($self, $dep_field) = @_;
100
101     my @deps;
102     foreach my $dep (@{$self->{dep_fields}{$dep_field}[1]}) {
103         my @or_deps;
104         foreach my $or_dep ( @$dep ) {
105             my $p_name = $or_dep->[0];
106             my $p_version = $or_dep->[1] ? "$or_dep->[1] $or_dep->[2]" : undef;
107             my $arch_neg;
108             my $arch_str = '';
109             if ($or_dep->[3] && @{$or_dep->[3]}) {
110                 # as either all or no archs have to be prepended with
111                 # exlamation marks, use the first and delete the others
112                 if ($or_dep->[3][0] =~ /^!/) {
113                     $arch_neg = 1;
114                     foreach (@{$or_dep->[3]}) {
115                         $_ =~ s/^!//go;
116                     }
117                 }
118                 $arch_str = join(" ",sort(@{$or_dep->[3]}));
119             }
120
121             push @or_deps, [ $p_name, $p_version, $arch_neg, $arch_str ];
122         }
123         push @deps, [ 0, @or_deps ];
124     }
125     return \@deps;
126 }
127
128 1;