1
0
mirror of https://sourceware.org/git/glibc.git synced 2025-10-12 19:04:54 +03:00

2003-01-16 Roland McGrath <roland@redhat.com>

Tweak merged .abilist file format to merge duplicate symbols in
	different sets into multi-version stanzas with new "| SET regexp..."
	header continuation lines.
	* scripts/merge-abilist.awk: Rewritten for new format.
	* scripts/extract-abilist.awk: Likewise.
This commit is contained in:
Roland McGrath
2003-01-16 11:28:59 +00:00
parent e09edf23c2
commit 81043d1ad8
2 changed files with 154 additions and 129 deletions

View File

@@ -2,43 +2,94 @@
# This must be passed run with awk -v config=TUPLE to specify the configuration # This must be passed run with awk -v config=TUPLE to specify the configuration
# tuple we will match. The merged file contains stanzas in the form: # tuple we will match. The merged file contains stanzas in the form:
# GLIBC_x.y regexp... # GLIBC_x.y regexp...
# | GLIBC_x.y.z regexp...
# | GLIBC_m.n regexp...
# function F # function F
# variable D 0x4 # variable D 0x4
# Each regexp is matched against TUPLE, and only matching stanzas go # Each regexp is matched against TUPLE, and only matching stanzas go
# into the output, with the regexp list removed. The result matches the # into the output, with the regexp list removed. Multiple version lines
# original .symlist file from abilist.awk that was fed into merge-abilist.awk. # can match with the same regexp, meaning the stanza is duplicated in
# multiple version sets. The result matches the original .symlist file
# from abilist.awk that was fed into merge-abilist.awk.
BEGIN { BEGIN {
outpipe = ""; inside = 0;
} }
/^ / { if (!ignore) print | outpipe; next; } /^ / {
inside = 1;
if (!ignore) {
for (version in current) {
if (version in versions)
versions[version] = versions[version] "\n" $0;
else
versions[version] = $0;
}
}
next;
}
{ {
for (i = 2; i <= NF; ++i) { second = ($1 == "|");
if (second && inside) {
printf "%s:%d: bad input line inside stanza: %s\n", FILENAME, FNR, $0;
exit 1;
}
inside = 0;
for (i = second ? 3 : 2; i <= NF; ++i) {
regex = "^" $i "$"; regex = "^" $i "$";
if (match(config, regex) != 0) { if (match(config, regex) != 0) {
if ($1 != version) { if (!second || ignore)
if (outpipe != "") { # Clear old array.
close(outpipe); split("", current);
} current[second ? $2 : $1] = 1;
version = $1;
print version;
outpipe = "sort";
}
ignore = 0; ignore = 0;
next; next;
} }
} }
ignore = 1;
if (!second)
ignore = 1;
next; next;
} }
END { END {
if (outpipe == "") { nverlist = 0;
print "No stanza matched", config > "/dev/stderr"; for (version in versions) {
exit 2; if (nverslist == 0) {
verslist = version;
nverslist = 1;
continue;
}
split(verslist, s, "\n");
if (version < s[1]) {
verslist = version;
for (i = 1; i <= nverslist; ++i) {
verslist = verslist "\n" s[i];
}
}
else {
verslist = s[1];
for (i = 2; i <= nverslist; ++i) {
if (version < s[i]) break;
verslist = verslist "\n" s[i];
}
verslist = verslist "\n" version;
for (; i <= nverslist; ++i) {
verslist = verslist "\n" s[i];
}
}
++nverslist;
} }
else
split(verslist, order, "\n");
for (i = 1; i <= nverslist; ++i) {
version = order[i];
print version;
outpipe = "sort";
print versions[version] | outpipe;
close(outpipe); close(outpipe);
}
} }

View File

@@ -1,11 +1,18 @@
# awk script to merge a config-specific .symlist file with others. # awk script to merge a config-specific .symlist file with others.
# The input files should be an existing .abilist file, and a .symlist file. # The input files should be existing .abilist files, and a .symlist
# This must be passed run with awk -v config=REGEXP to specify a regexp # file. This must be run with awk -v config=REGEXP to specify a
# matching configuration tuples for which the .symlist input defines an ABI. # regexp matching configuration tuples for which the .symlist input
# The result merges all duplicate occurrences of any symbol in a version set # defines an ABI. The result merges all duplicate occurrences of any
# into a stanza listing the regexps matching configurations that contain it. # symbol into a stanza listing the regexps matching configurations
# that contain it and giving associated versions.
# The merged file contains stanzas in the form:
# GLIBC_x.y regexp...
# | GLIBC_x.y.z regexp...
# | GLIBC_m.n regexp...
# function F
# variable D 0x4
/^[^ ]/ { /^[^| ]/ {
if (NF < 2 && config == "") { if (NF < 2 && config == "") {
print "BAD LINE:", $0 > "/dev/stderr"; print "BAD LINE:", $0 > "/dev/stderr";
exit 2; exit 2;
@@ -36,127 +43,94 @@
next; next;
} }
/^\| / {
if (NF < 3) {
print "BAD LINE:", $0 > "/dev/stderr";
exit 2;
}
nc = 0;
for (i = 3; i <= NF; ++i)
if ($i != config)
c[nc++] = $i;
for (i = 0; i < nc; ++i)
current = current "," $2 ":" c[i];
next;
}
{ {
if (current == "") next; if (current == "") next;
if ($0 in seen) { ns = split(seen[$0], s, ",");
seen[$0] = seen[$0] "\n" current; nc = split(current, c, ",");
} for (i = 1; i <= nc; ++i) {
else { # Sorted insert.
seen[$0] = current; for (j = 1; j <= ns; ++j) {
if (c[i] < s[j]) {
for (k = ns; k >= j; --k)
s[k + 1] = s[k];
s[j] = c[i];
++ns;
break;
}
}
if (j >= ns)
s[++ns] = c[i];
} }
seen[$0] = s[1];
for (i = 2; i <= ns; ++i)
seen[$0] = seen[$0] "," s[i];
next; next;
} }
END { END {
for (line in seen) { for (line in seen) {
split(seen[line], setlist, "\n"); if (seen[line] in stanzas)
for (i in setlist) { stanzas[seen[line]] = stanzas[seen[line]] "\n" line;
split(setlist[i], configs, ","); else
for (j in configs) { stanzas[seen[line]] = line;
split(configs[j], temp, ":");
version = temp[1];
conf = temp[2];
if ((version,conf) in have) continue;
have[version,conf] = 1;
if (version in confs) {
split(confs[version], c, " ");
if (conf < c[1]) {
confs[version] = conf;
for (k = 1; k <= nconfs[version]; ++k) {
confs[version] = confs[version] " " c[k];
}
}
else {
confs[version] = c[1];
for (k = 2; k <= nconfs[version]; ++k) {
if (conf < c[k]) break;
confs[version] = confs[version] " " c[k];
}
confs[version] = confs[version] " " conf;
for (; k <= nconfs[version]; ++k) {
confs[version] = confs[version] " " c[k];
}
}
++nconfs[version];
}
else {
confs[version] = conf;
nconfs[version] = 1;
}
}
}
for (idx in have) delete have[idx];
for (version in confs) {
# Hack: if an element is foo.*/bar and there is also a foo.*,
# then we can omit the foo.*/bar since foo.* matches already.
nc = split(confs[version], c, " ");
for (i = 1; i <= nc; ++i) {
slash = index(c[i], ".*/");
if (slash > 0) {
beforeslash = substr(c[i], 1, slash + 2 - 1);
for (j = 1; j <= nc; ++j)
if (j != i && c[j] == beforeslash) {
c[i] = c[nc--];
break;
}
}
}
idx = version;
for (i = 1; i <= nc; ++i)
idx = idx " " c[i];
if (idx in final) {
final[idx] = final[idx] "\n" line;
}
else {
final[idx] = line;
}
delete confs[version];
delete nconfs[version];
}
} }
nstanzas = 0; ns = split("", s);
for (stanza in final) { for (configs in stanzas) {
if (nstanzas == 0) { # Sorted insert.
stanzas = stanza; for (j = 1; j <= ns; ++j)
nstanzas = 1; if (configs < s[j]) {
continue; for (k = ns; k >= j; --k)
} s[k + 1] = s[k];
split(stanzas, s, "\n"); s[j] = configs;
if (stanza < s[1]) { ++ns;
stanzas = stanza; break;
for (i = 1; i <= nstanzas; ++i) {
stanzas = stanzas "\n" s[i];
} }
} if (j >= ns)
else { s[++ns] = configs;
stanzas = s[1];
for (i = 2; i <= nstanzas; ++i) {
if (stanza < s[i]) break;
stanzas = stanzas "\n" s[i];
}
stanzas = stanzas "\n" stanza;
for (; i <= nstanzas; ++i) {
stanzas = stanzas "\n" s[i];
}
}
++nstanzas;
} }
split(stanzas, order, "\n"); # S[1..NS] is now a sorted list of stanza identifiers.
for (i = 1; i <= nstanzas; ++i) { # STANZAS[ID] contains the lines for that stanza.
stanza = order[i]; # All we have to do is pretty-print the stanza ID,
print stanza; # and then print the sorted list.
for (i = 1; i <= ns; ++i) {
# S[I] is a sorted, comma-separated list of SET:CONFIG pairs.
# All we have to do is pretty-print them.
nc = split(s[i], c, ",");
lastvers = "";
for (j = 1; j <= nc; ++j) {
split(c[j], temp, ":");
version = temp[1];
conf = temp[2];
if (version != lastvers)
printf "%s%s", (lastvers != "" ? "\n| " : ""), version;
printf " %s", conf;
lastvers = version;
}
print "";
outpipe = "sort"; outpipe = "sort";
print final[stanza] | outpipe; print stanzas[s[i]] | outpipe;
close(outpipe); close(outpipe);
} }
} }