summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2005-02-11 09:01:54 +0000
committerJakub Jelinek <jakub@redhat.com>2005-02-11 09:01:54 +0000
commitbf8419b987d24394676108127af8a599f7f7a9fa (patch)
treefdb3f9da34d5c942f223afc6736cd67b433cdf36 /scripts
parentd4f7a4c095da67f295204513c4be90f602daa7b4 (diff)
downloadglibc-bf8419b987d24394676108127af8a599f7f7a9fa.tar
glibc-bf8419b987d24394676108127af8a599f7f7a9fa.tar.gz
glibc-bf8419b987d24394676108127af8a599f7f7a9fa.tar.bz2
glibc-bf8419b987d24394676108127af8a599f7f7a9fa.zip
Updated to fedora-glibc-20050211T0853
Diffstat (limited to 'scripts')
-rw-r--r--scripts/lib-names.awk66
-rw-r--r--scripts/soversions.awk58
2 files changed, 109 insertions, 15 deletions
diff --git a/scripts/lib-names.awk b/scripts/lib-names.awk
new file mode 100644
index 0000000000..77e6668515
--- /dev/null
+++ b/scripts/lib-names.awk
@@ -0,0 +1,66 @@
+# awk script for soversions.i -> gnu/lib-names.h; see Makeconfig.
+
+$1 != "DEFAULT" { multi = 1 }
+
+#
+{
+ lib = $2;
+ version = $3;
+ if ($3 !~ /^[0-9]/) {
+ soname = $3;
+ extra = $3;
+ sub(/\.so.*$/, "", extra);
+ }
+ else {
+ soname = lib ".so." $3;
+ extra = "";
+ }
+ soname = "\"" soname "\"";
+ lib = toupper(lib);
+ extra = toupper(extra);
+ gsub(/-/, "_", lib);
+ gsub(/-/, "_", extra);
+ macros[$1 FS lib "_SO"] = soname;
+ if (extra)
+ macros[$1 FS extra "_SO"] = soname;
+}
+
+END {
+ print "/* This file is automatically generated.";
+ print " It defines macros to allow user program to find the shared";
+ print " library files which come as part of GNU libc. */";
+ print "#ifndef __GNU_LIB_NAMES_H";
+ print "#define __GNU_LIB_NAMES_H 1";
+ print "";
+
+ pfx = multi ? "# define " : "#define ";
+ for (elt in macros) {
+ split(elt, x);
+ line = sprintf("%-40s%s", pfx x[2], macros[elt]);
+ if (x[1] in lines)
+ lines[x[1]] = lines[x[1]] "\n" line;
+ else
+ lines[x[1]] = line;
+ }
+
+ if (multi) {
+ # Print these in a fixed order so the result is identical
+ # on both sides of the coin.
+ if (!("WORDSIZE32" in lines))
+ lines["WORDSIZE32"] = lines["DEFAULT"];
+ if (!("WORDSIZE64" in lines))
+ lines["WORDSIZE64"] = lines["DEFAULT"];
+ print "#include <bits/wordsize.h>\n";
+ print "#if __WORDSIZE == 32";
+ cmd = "LC_ALL=C sort"; print lines["WORDSIZE32"] | cmd; close(cmd);
+ print "#else"
+ cmd = "LC_ALL=C sort"; print lines["WORDSIZE64"] | cmd; close(cmd);
+ print "#endif";
+ }
+ else {
+ cmd = "LC_ALL=C sort"; print lines["DEFAULT"] | cmd; close(cmd);
+ }
+
+ print "";
+ print "#endif /* gnu/lib-names.h */"
+}
diff --git a/scripts/soversions.awk b/scripts/soversions.awk
index 6207088514..3d50c4deeb 100644
--- a/scripts/soversions.awk
+++ b/scripts/soversions.awk
@@ -1,14 +1,29 @@
-# awk script for shlib-versions.v.i -> soversions.i; see Makeconfig.
+# awk script for shlib-versions.v -> soversions.i; see Makeconfig.
-# Only lines matching `config' (set with -v) are relevant to us.
-config !~ $1 { next }
+BEGIN {
+ config = cpu "-" vendor "-" os;
+ configs[config] = "DEFAULT";
+}
+
+{ thiscf = $1 }
+
+$2 ~ /WORDSIZE[3264]/ {
+ if (config ~ thiscf) {
+ othercf = $3;
+ sub(/@CPU@/, cpu, othercf);
+ sub(/@VENDOR@/, vendor, othercf);
+ sub(/@OS@/, os, othercf);
+ configs[othercf] = $2;
+ }
+ next;
+}
# Obey the first matching DEFAULT line.
$2 == "DEFAULT" {
- if (!matched_default) {
- matched_default = 1;
+ if (!matched_default[thiscf]) {
+ matched_default[thiscf] = 1;
$1 = $2 = "";
- default_setname = $0;
+ default_set[thiscf] = $0;
}
next
}
@@ -19,20 +34,33 @@ $2 == "DEFAULT" {
lib = number = $2;
sub(/=.*$/, "", lib);
sub(/^.*=/, "", number);
- if (lib in numbers) next;
- numbers[lib] = number;
+ if ((thiscf FS lib) in numbers) next;
+ numbers[thiscf FS lib] = number;
+ order[thiscf FS lib] = ++order_n;
if (NF > 2) {
$1 = $2 = "";
- versions[lib] = $0
+ versions[thiscf FS lib] = $0
}
}
END {
- for (lib in numbers) {
- set = (lib in versions) ? versions[lib] : default_setname;
- if (set)
- print lib, numbers[lib], set;
- else
- print lib, numbers[lib];
+ for (elt in numbers) {
+ split(elt, x);
+ cf = x[1];
+ lib = x[2];
+ if (default_setname && !(cf in default_set) && config ~ cf)
+ default_set[cf] = default_setname;
+ set = (elt in versions) ? versions[elt] : default_set[cf];
+ line = set ? (lib FS numbers[elt] FS set) : (lib FS numbers[elt]);
+ for (c in configs)
+ if (c ~ cf) {
+ if (!((c FS lib) in lineorder) || order[elt] < lineorder[c FS lib]) {
+ lineorder[c FS lib] = order[elt];
+ lines[c FS lib] = configs[c] FS line;
+ }
+ }
+ }
+ for (c in lines) {
+ print lines[c]
}
}