# Copyright (C) 2003, 2004, 2007 Free Software Foundation, Inc.
|
# Copyright (C) 2003, 2004, 2007 Free Software Foundation, Inc.
|
# Contributed by Kelley Cook, June 2004.
|
# Contributed by Kelley Cook, June 2004.
|
# Original code from Neil Booth, May 2003.
|
# Original code from Neil Booth, May 2003.
|
#
|
#
|
# This program is free software; you can redistribute it and/or modify it
|
# This program is free software; you can redistribute it and/or modify it
|
# under the terms of the GNU General Public License as published by the
|
# under the terms of the GNU General Public License as published by the
|
# Free Software Foundation; either version 3, or (at your option) any
|
# Free Software Foundation; either version 3, or (at your option) any
|
# later version.
|
# later version.
|
#
|
#
|
# This program is distributed in the hope that it will be useful,
|
# This program is distributed in the hope that it will be useful,
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
# GNU General Public License for more details.
|
# GNU General Public License for more details.
|
#
|
#
|
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
# along with this program; see the file COPYING3. If not see
|
# along with this program; see the file COPYING3. If not see
|
# <http://www.gnu.org/licenses/>.
|
# <http://www.gnu.org/licenses/>.
|
|
|
# This Awk script takes a list of *.opt files and combines them into
|
# This Awk script takes a list of *.opt files and combines them into
|
# a three-field sorted list suitable for input into opt[ch]-gen.awk.
|
# a three-field sorted list suitable for input into opt[ch]-gen.awk.
|
#
|
#
|
# Usage: awk -f opt-gather.awk file1.opt [...] > outputfile
|
# Usage: awk -f opt-gather.awk file1.opt [...] > outputfile
|
|
|
function sort(ARRAY, ELEMENTS)
|
function sort(ARRAY, ELEMENTS)
|
{
|
{
|
for (i = 2; i <= ELEMENTS; ++i) {
|
for (i = 2; i <= ELEMENTS; ++i) {
|
for (j = i; ARRAY[j-1] > ARRAY[j]; --j) {
|
for (j = i; ARRAY[j-1] > ARRAY[j]; --j) {
|
temp = ARRAY[j]
|
temp = ARRAY[j]
|
ARRAY[j] = ARRAY[j-1]
|
ARRAY[j] = ARRAY[j-1]
|
ARRAY[j-1] = temp
|
ARRAY[j-1] = temp
|
}
|
}
|
}
|
}
|
return
|
return
|
}
|
}
|
|
|
BEGIN { numrec = 0 }
|
BEGIN { numrec = 0 }
|
|
|
# Ignore comments and blank lines
|
# Ignore comments and blank lines
|
/^[ \t]*(;|$)/ { flag = 0; next }
|
/^[ \t]*(;|$)/ { flag = 0; next }
|
/^[^ \t]/ { if (flag == 0) {
|
/^[^ \t]/ { if (flag == 0) {
|
record[++numrec] = $0
|
record[++numrec] = $0
|
flag = 1 }
|
flag = 1 }
|
else {
|
else {
|
record[numrec] = record[numrec] SUBSEP $0
|
record[numrec] = record[numrec] SUBSEP $0
|
}
|
}
|
}
|
}
|
|
|
# Sort it and output it
|
# Sort it and output it
|
END {
|
END {
|
sort(record,numrec)
|
sort(record,numrec)
|
|
|
for (i = 1; i <= numrec; i++) {
|
for (i = 1; i <= numrec; i++) {
|
print record[i] }
|
print record[i] }
|
}
|
}
|
|
|