djm@eng.umd.edu (David J. MacKenzie) (02/24/91)
I use this program to prepare termcap files so that `diff' gives meaningful results when comparing them. The program alphabetizes the entries in the file by their canonical names (the first name following the two-letter Unix V6 name), and sorts the capabilities within each entry, moving them each onto their own line. This makes it easy to see the differences between two entries. #!/usr/local/bin/perl # -*- C -*- # tcsort -- reorder a termcap file so it is easier to compare two of them. # # Read a termcap file. # Sort the capabilities in each entry and move them so there is # one per line, in the format `cap:\'. # Sort the entries by the second name (the first long name). # Write the resulting file to standard out. # # David MacKenzie <djm@eng.umd.edu> # Public domain. while (<>) { if (/^[ ]*#/ || /^[ ]*$/) { $comments = $comments . $_; } else { chop; if (substr ($_, length ($_) - 1) eq "\\") { chop; $ent = $ent . $_; } else { $ent = $ent . $_; # Remove empty cap fields. $ent =~ s/:[ ]*:/:/g; @caps = split (/:/, $ent); # Don't sort the terminal names with the caps. $termname = shift (@caps) . ":\\\n"; @caps = sort (@caps); $ent = join (":\\\n", @caps) . ":\n"; $entries[$nentries++] = $comments . $termname . $ent; $comments = ""; $ent = ""; } } } @entries = sort (cmpent @entries); for ($i = 0; $i < $nentries; $i++) { print $entries[$i], "\n"; } # Compare the canonical names. sub cmpent { substr ($a, index ($a, '|') + 1) cmp substr ($b, index ($b, '|') + 1); } -- David J. MacKenzie <djm@eng.umd.edu> <djm@ai.mit.edu>