chiark / gitweb /
commodity ordering: more comprehensive output
authorIan Jackson <ian@liberator.relativity.greenend.org.uk>
Sat, 31 Oct 2009 16:08:30 +0000 (16:08 +0000)
committerIan Jackson <ian@liberator.relativity.greenend.org.uk>
Sat, 31 Oct 2009 16:08:30 +0000 (16:08 +0000)
yarrg/commod-results-processor

index de65f1b903be775ea4e331e46206bc552b0b7ceb..9525330652b02051e35921a7feae25789faafce7 100755 (executable)
@@ -227,15 +227,24 @@ sub main__tsv () {
     write_tsv(\*STDOUT);
 }
 
+sub undef_printable { my ($ov)= @_; defined $ov ? $ov : '?'; };
+
+sub commodsinorder_print1 ($$) {
+    my ($keyword,$commod) = @_;
+    printf("%s\t%-40s %10s %s",
+          $keyword,
+          $commod,
+          undef_printable($commods{$commod}{Ordval}),
+          undef_printable($commods{$commod}{Class}))
+       or die $!;
+}
+
 sub main__commodsinorder () {
     parse_info_serverside();
     my $last_ov;
     foreach my $commod (@commods_inorder) {
        my $ov= $commods{$commod}{Ordval};
-       printf("found\t%-40s %10s",
-              $commod,
-              defined $ov ? $ov : '?')
-           or die $!;
+       commodsinorder_print1('found',$commod);
        if (defined $ov) {
            if (defined $last_ov && $ov <= $last_ov) {
                print " out-of-order" or die $!;
@@ -244,9 +253,13 @@ sub main__commodsinorder () {
        }
        print "\n" or die $!;
     }
-    foreach my $commod (sort keys %commods) {
+    foreach my $commod (sort {
+           undef_printable($commods{$a}{Ordval}) cmp
+           undef_printable($commods{$b}{Ordval})
+       } keys %commods) {
        next if exists $commod{$commod};
-       printf "missing\t%s\n", $commod or die $!;
+       commodsinorder_print1('none',$commod);
+       print "\n" or die $!;
     }
 }