2002-10-30 12:57:05 +01:00
|
|
|
# $Id: dbname.awk,v 1.5 2002/05/07 05:45:51 ubell Exp $
|
2001-03-05 01:42:05 +01:00
|
|
|
#
|
|
|
|
# Take a comma-separated list of database names and spit out all the
|
|
|
|
# log records that affect those databases.
|
|
|
|
|
|
|
|
NR == 1 {
|
|
|
|
nfiles = 0
|
|
|
|
while ((ndx = index(DBNAME, ",")) != 0) {
|
|
|
|
filenames[nfiles] = substr(DBNAME, 1, ndx - 1) 0;
|
|
|
|
DBNAME = substr(DBNAME, ndx + 1, length(DBNAME) - ndx);
|
|
|
|
files[nfiles] = -1
|
|
|
|
nfiles++
|
|
|
|
}
|
|
|
|
filenames[nfiles] = DBNAME 0;
|
|
|
|
files[nfiles] = -1
|
|
|
|
myfile = -1;
|
|
|
|
}
|
|
|
|
|
2002-10-30 12:57:05 +01:00
|
|
|
/^\[.*dbreg_register/ {
|
2001-03-05 01:42:05 +01:00
|
|
|
register = 1;
|
|
|
|
}
|
|
|
|
/opcode:/ {
|
|
|
|
if (register == 1) {
|
|
|
|
if ($2 == 1)
|
|
|
|
register = 3;
|
|
|
|
else
|
|
|
|
register = $2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/name:/ {
|
|
|
|
if (register >= 2) {
|
|
|
|
for (i = 0; i <= nfiles; i++) {
|
|
|
|
if ($2 == filenames[i]) {
|
|
|
|
if (register == 2) {
|
|
|
|
printme = 0;
|
|
|
|
myfile = -1;
|
|
|
|
files[i] = -1;
|
|
|
|
} else {
|
|
|
|
myfile = i;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
register = 0;
|
|
|
|
}
|
|
|
|
/fileid:/{
|
|
|
|
if (myfile != -1) {
|
|
|
|
files[myfile] = $2;
|
|
|
|
printme = 1;
|
|
|
|
register = 0;
|
|
|
|
myfile = -1;
|
|
|
|
} else
|
|
|
|
for (i = 0; i <= nfiles; i++)
|
|
|
|
if ($2 == files[i]) {
|
|
|
|
printme = 1
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/^\[/{
|
|
|
|
if (printme == 1) {
|
|
|
|
printf("%s\n", rec);
|
|
|
|
printme = 0
|
|
|
|
}
|
|
|
|
rec = "";
|
|
|
|
|
|
|
|
rec = $0
|
|
|
|
}
|
2002-10-30 12:57:05 +01:00
|
|
|
|
|
|
|
TXN == 1 && /txn_regop/ {printme = 1}
|
2001-03-05 01:42:05 +01:00
|
|
|
/^ /{
|
|
|
|
rec = sprintf("%s\n%s", rec, $0);
|
|
|
|
}
|
|
|
|
|
|
|
|
END {
|
|
|
|
if (printme == 1)
|
|
|
|
printf("%s\n", rec);
|
|
|
|
}
|