aboutsummaryrefslogtreecommitdiffstats
path: root/configure.pl
diff options
context:
space:
mode:
authorlloyd <[email protected]>2006-09-04 14:28:03 +0000
committerlloyd <[email protected]>2006-09-04 14:28:03 +0000
commitddd05deabcd3ab3a2c4bcf7b7dd3bf053c244853 (patch)
tree8e88edd2cce668d20404a636dd85b3a4e0f62c75 /configure.pl
parent493157a1f3db04778a36036ee25e164cc5c50ec1 (diff)
Implement get_arch_info, which handles reading a single architecture
file and getting the results, which is called by set_arch_defines as needed.
Diffstat (limited to 'configure.pl')
-rwxr-xr-xconfigure.pl61
1 files changed, 42 insertions, 19 deletions
diff --git a/configure.pl b/configure.pl
index bbddf8891..93b00cafa 100755
--- a/configure.pl
+++ b/configure.pl
@@ -1744,39 +1744,62 @@ sub get_module_info {
return %modinfo;
}
+sub get_arch_info {
+ my ($name,$file) = @_;
+ my $reader = make_reader($file);
+
+ my %info;
+ $info{'name'} = $name;
+
+ while($_ = &$reader()) {
+ set_if_quoted($_, 'realname', \$info{'realname'});
+ set_if($_, 'default_submodel', \$info{'default_submodel'});
+
+ read_hash($_, $reader, 'aliases', list_push(\@{$info{'aliases'}}));
+ read_hash($_, $reader, 'submodels', list_push(\@{$info{'submodels'}}));
+
+ read_hash($_, $reader, 'submodel_aliases',
+ sub {
+ my $line = $_[0];
+ $line =~ m/^(\S*) -> (\S*)$/;
+ $info{'submodel_aliases'}{$1} = $2;
+ });
+ }
+ return %info;
+}
+
sub set_arch_defines {
my $dir = $_[0];
foreach my $arch (dir_list($dir)) {
- my $reader = make_reader(File::Spec->catfile($dir, $arch));
+ my %info = get_arch_info($arch, File::Spec->catfile($dir, $arch));
- $ARCH{$arch} = $arch;
- while($_ = &$reader()) {
- set_if_quoted($_, 'realname', \$REALNAME{$arch});
- set_if($_, 'default_submodel', \$DEFAULT_SUBMODEL{$arch});
+ $ARCH{$arch} = $info{'name'};
+ $REALNAME{$arch} = $info{'realname'};
+ $DEFAULT_SUBMODEL{$arch} = $info{'default_submodel'};
- read_hash($_, $reader, 'aliases',
- sub { $ARCH_ALIAS{$_[0]} = $arch; });
- read_hash($_, $reader, 'submodels',
- sub { $ARCH{$_[0]} = $arch; });
+ foreach my $alias (@{$info{'aliases'}}) {
+ $ARCH_ALIAS{$alias} = $arch;
+ }
- read_hash($_, $reader, 'submodel_aliases',
- sub {
- my $line = $_[0];
- $line =~ m/^(\S*) -> (\S*)$/;
- $SUBMODEL_ALIAS{$1} = $2;
- });
+ foreach my $submodel (@{$info{'submodels'}}) {
+ $ARCH{$submodel} = $arch;
+ }
+
+ if(defined($info{'submodel_aliases'})) {
+ my %submodel_aliases = %{$info{'submodel_aliases'}};
+ foreach my $sm_alias (keys %submodel_aliases) {
+ $SUBMODEL_ALIAS{$sm_alias} = $submodel_aliases{$sm_alias};
+ }
}
}
}
sub get_os_info {
- my ($file,$name) = @_;
-
+ my ($name,$file) = @_;
my $reader = make_reader($file);
my %info;
-
$info{'name'} = $name;
$info{'needs_ranlib'} = 0;
@@ -1804,7 +1827,7 @@ sub set_os_defines {
my $dir = $_[0];
foreach my $os (dir_list($dir)) {
- my %info = get_os_info(File::Spec->catfile($dir, $os), $os);
+ my %info = get_os_info($os, File::Spec->catfile($dir, $os));
$REALNAME{$os} = $info{'realname'};
$OS_TYPE{$os} = $info{'os_type'};