my %set_path;
my %set_id;
-my $st_set = $DB->prepare("SELECT id, name, ndisc FROM dvd_set");
-my $st_disc = $DB->prepare("SELECT disc, path FROM dvd_disc
- WHERE set_id = ?
- ORDER BY disc");
+my %box;
+my $st_set = $DB->prepare("SELECT id, name, n_disc FROM dvd_set");
+my $st_disc = $DB->prepare
+ ("SELECT disc, path, box FROM dvd_disc WHERE set_id = ? ORDER BY disc");
$st_set->execute;
-SET: for (;;) {
- my @r = $st_set->fetchrow_array; last SET unless @r;
+while (my @r = $st_set->fetchrow_array) {
my ($id, $name, $ndisc) = @r;
my @path;
$st_disc->execute($id);
- DISC: for (;;) {
- my @r = $st_disc->fetchrow_array; last DISC unless @r;
- my ($disc, $path) = @r;
+ while (my @r = $st_disc->fetchrow_array) {
+ my ($disc, $path, $box) = @r;
$disc == @path or die "bad disc sequence for `$name'";
+ $box{$path} = $box if defined $box;
push @path, $path;
}
@path == $ndisc or die "wrong number of discs for `$name'";
}
my @iso = sort keys %iso;
-for my $name (sort { $set_path{$a}[0] cmp $set_path{$b}[0] }
+my $lastbox = "#nil";
+sub set_box ($) {
+ my ($box) = @_;
+ $box //= "#nil";
+ if ($box ne $lastbox) { print "!box $box\n"; $lastbox = $box; }
+}
+
+sub path_key ($) {
+ my ($p) = @_;
+ if ($p =~ m{^ ([a-z]) / ([^/]+) ((?: / .*)?) $}ix) {
+ my $init = $1;
+ my $focus = $2;
+ my $tail = $3;
+ my $head = undef;
+ if ($focus =~ /^ (the | a ) \s+ (\S .*) $/x)
+ { $head = $1; $focus = $2; }
+ if (lc $init ne lc substr($focus, 0, 1) &&
+ $focus =~ /^ (.*) \s+ ($init .*) $/x)
+ { $head .= (defined $head && " ") . $1; $focus = $2; }
+ if (defined $head) { return "$init/$focus, $head$tail"; }
+ }
+ return $p;
+}
+
+for my $name (sort { my $pa = $set_path{$a}[0]; my $ba = $box{$pa} // "~~~";
+ my $pb = $set_path{$b}[0]; my $bb = $box{$pb} // "~~~";
+ $ba cmp $bb || path_key $pa cmp path_key $pb }
keys %set_path) {
my $paths = $set_path{$name};
my @unk;
+ set_box $box{$paths->[0]};
while (@iso && $iso[0] lt $paths->[0]) { push @unk, shift @iso; }
if (@unk) {
print "[#UNK: *]\n";
printf "\t!! (disc %d)\n", $i;
} else {
my $fn = "$ROOT/$path";
+ set_box $box{$path};
if (-f $fn && ! -l $fn) { print "\t" . $path . "\n"; }
else { print "\t!! ". $path . "\n"; }
}