mirror of
git://sourceware.org/git/glibc.git
synced 2025-02-11 12:50:58 +08:00
Kludge fix for Versions.def regression
This commit is contained in:
parent
00f4012a2f
commit
a5e5f1e281
@ -1,3 +1,8 @@
|
||||
2014-03-25 Roland McGrath <roland@hack.frob.com>
|
||||
|
||||
* scripts/versionlist.awk: Partition the version sets and emit all
|
||||
GLIBC_* (sorted) before all others (sorted).
|
||||
|
||||
2014-03-25 Joseph Myers <joseph@codesourcery.com>
|
||||
|
||||
* elf/Versions (libc) [EXPORT_UNWIND_FIND_FDE]: Add empty
|
||||
|
@ -3,14 +3,25 @@
|
||||
|
||||
BEGIN { in_lib = ""; in_version = 0 }
|
||||
|
||||
!in_lib && NF == 2 && $2 == "{" { in_lib = $1; next }
|
||||
!in_lib && NF == 2 && $2 == "{" {
|
||||
in_lib = $1;
|
||||
all_libs[in_lib] = 1;
|
||||
next
|
||||
}
|
||||
!in_lib { next }
|
||||
|
||||
NF == 2 && $2 == "{" {
|
||||
in_version = 1;
|
||||
libs[in_lib] = libs[in_lib] " " $1 "\n";
|
||||
lib_versions[in_lib, $1] = 1;
|
||||
all_versions[$1] = 1;
|
||||
# Partition the version sets into GLIBC_* and others.
|
||||
if ($1 ~ /GLIBC_/) {
|
||||
libs[in_lib] = libs[in_lib] " " $1 "\n";
|
||||
all_versions[$1] = 1;
|
||||
}
|
||||
else {
|
||||
others_libs[in_lib] = others_libs[in_lib] " " $1 "\n";
|
||||
others_all_versions[$1] = 1;
|
||||
}
|
||||
next
|
||||
}
|
||||
|
||||
@ -20,20 +31,37 @@ in_version { next }
|
||||
$1 == "}" { in_lib = ""; next }
|
||||
|
||||
END {
|
||||
nlibs = asorti(libs, libs_order);
|
||||
nlibs = asorti(all_libs, libs_order);
|
||||
for (i = 1; i <= nlibs; ++i) {
|
||||
lib = libs_order[i];
|
||||
|
||||
for (v in all_versions) {
|
||||
if (!((in_lib, v) in lib_versions)) {
|
||||
if (!((lib, v) in lib_versions)) {
|
||||
libs[lib] = libs[lib] " " v "\n";
|
||||
}
|
||||
}
|
||||
|
||||
for (v in others_all_versions) {
|
||||
if (!((lib, v) in lib_versions)) {
|
||||
others_libs[lib] = others_libs[lib] " " v "\n";
|
||||
}
|
||||
}
|
||||
|
||||
print lib, "{";
|
||||
|
||||
# Sort and print all the GLIBC_* sets first, then all the others.
|
||||
# This is not really generically right, but it suffices
|
||||
# for the cases we have so far. e.g. GCC_3.0 is "later than"
|
||||
# all GLIBC_* sets that matter for purposes of Versions files.
|
||||
|
||||
sort = "sort -u -t. -k 1,1 -k 2n,2n -k 3";
|
||||
printf "%s", libs[lib] | sort;
|
||||
close(sort);
|
||||
|
||||
sort = "sort -u -t. -k 1,1 -k 2n,2n -k 3";
|
||||
printf "%s", others_libs[lib] | sort;
|
||||
close(sort);
|
||||
|
||||
print "}";
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user