die $_[0];
};
+sub total_history_cmp ();
+
sub unkopt ($$) {
my ($what,$opt) = @_;
if ($opt =~ m/^[A-Z]/) {
}
}
+my $display_cmp = \&total_history_cmp;
+
+while (@ARGV && $ARGV[0] =~ m/^\-/) {
+ $_ = shift @ARGV;
+ if (m/^--$/) {
+ last;
+ } elsif (m/^--sort=alpha$/) {
+ $display_cmp = sub { $b->{Cand} cmp $a->{Cand} };
+ } else {
+ die;
+ }
+}
+
for (;;) {
$_ = <>;
if (m/^\| /) {
sub prf {
my $fmt = shift;
- printf "stage %d: ".$fmt, $stage, @_;
+ printf " ".$fmt, @_;
}
sub countballots () {
$c->{History}[$stage-1] = $c->{Total};
}
- foreach my $c (reverse sort total_history_cmp
+ foreach my $c (reverse sort $display_cmp
grep { !$_->{NonCont} } values %cands) {
prf "candidate %-10s: %s votes\n", $c->{Cand}, sv $c->{Total};
}
my $totalvalid = 0/1;
$totalvalid += $_->{Total} foreach values %cands;
$quota = floor($totalvalid / (1 + $seats) + 1);
- prf "total valid %s quota %s\n", (sv $totalvalid), (sv $quota);
+ prf "total valid %s\n", sv $totalvalid;
+ prf "quota %s\n", sv $quota;
}
sub total_history_cmp () {
for (;;) {
$stage++;
+ printf "stage %3d:\n", $stage;
sortballots @allvotes if $stage == 1;