diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2006-11-29 16:54:12 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2006-11-29 16:54:12 +0000 |
commit | 2b9d6d89d30a53b5607200e3036f435ec767999e (patch) | |
tree | 11ba02a70770d26d15ee5df24e3a1c1a1c9fcf57 /usr.sbin/pkg_add/OpenBSD | |
parent | db74f1b63350d8dc9874b39cdb520d45ee9542a6 (diff) |
let compress filter out stuff, add method add_bases, make sure write_fh
writes to fh.
Diffstat (limited to 'usr.sbin/pkg_add/OpenBSD')
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/PkgConfig.pm | 32 |
1 files changed, 27 insertions, 5 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/PkgConfig.pm b/usr.sbin/pkg_add/OpenBSD/PkgConfig.pm index c44c0aad4e8..7a0a6be96a6 100644 --- a/usr.sbin/pkg_add/OpenBSD/PkgConfig.pm +++ b/usr.sbin/pkg_add/OpenBSD/PkgConfig.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: PkgConfig.pm,v 1.1 2006/11/29 11:10:16 espie Exp $ +# $OpenBSD: PkgConfig.pm,v 1.2 2006/11/29 16:54:11 espie Exp $ # # Copyright (c) 2004 Marc Espie <espie@openbsd.org> # @@ -93,11 +93,11 @@ sub write_fh my ($self, $fh) = @_; foreach my $variable (@{$self->{vlist}}) { - print "$variable=", $self->{variables}->{$variable}, "\n"; + print $fh "$variable=", $self->{variables}->{$variable}, "\n"; } - print "\n\n"; + print $fh "\n\n"; foreach my $property (@{$self->{proplist}}) { - print "$property:", + print $fh "$property:", (map { " $_" } @{$self->{properties}->{$property}}), "\n"; } @@ -112,11 +112,12 @@ sub write_file sub compress { - my ($class, $l) = @_; + my ($class, $l, $keep) = @_; my $h = {}; my @r = (); foreach my $i (@$l) { next if defined $h->{$i}; + next if defined $keep && !&$keep($i); push(@r, $i); $h->{$i} = 1; } @@ -172,4 +173,25 @@ sub get_variable } } +# to be used to make sure a config does not depend on absolute path names, +# e.g., $cfg->add_bases(X11R6 => '/usr/X11R6'); + +sub add_bases +{ + my ($self, $extra) = @_; + + while (my ($k, $v) = each %$extra) { + for my $name (keys %{$self->{variables}}) { + $self->{variables}->{$name} =~ s/\Q$v\E\b/\$\{\Q$k\E\}/g; + } + for my $name (keys %{$self->{properties}}) { + for my $e (@{$self->{properties}->{$name}}) { + $e =~ s/\Q$v\E\b/\$\{\Q$k\E\}/g; + } + } + $self->{variables}->{$k} = $v; + unshift(@{$self->{vlist}}, $k); + } +} + 1; |