X-Git-Url: http://git.shiar.nl/sc2-widget/blobdiff_plain/12f56f9cb78506076b690bae00531330ace88fd3..15085024b6df2d7bb16285c5d420772bc9732ac1:/getsc2clan diff --git a/getsc2clan b/getsc2clan index 23190e4..b23d2ac 100755 --- a/getsc2clan +++ b/getsc2clan @@ -32,7 +32,10 @@ sub blizget { # prefer deprecated interface to prevent costly ladder search my $ladderdata = blizget(legacy => profile => 2 => 1 => $profileid => 'ladders'); my @ladders = ( - sort { $b->{characters}->@* <=> $a->{characters}->@* } # population desc + sort { + $b->{ladder}->[0]->{wins}+$b->{ladder}->[0]->{losses} <=> + $a->{ladder}->[0]->{wins}+$a->{ladder}->[0]->{losses} + } # activity desc grep { !$clanmatch or all { fc $_->{clanName} eq fc $clanmatch } $_->{characters}->@* @@ -40,8 +43,9 @@ my @ladders = ( grep { $_->{ladder}->[0]->{division} } $ladderdata->{currentSeason}->@* ) or die "No matching groups found\n"; -my @members = $ladders[0]->{characters}->@*; -my %memberidx = map { $members[$_]->{id} => $_ } 0 .. $#members; +my (@members, %memberidx); +$memberidx{ $_->{id} } //= push(@members, $_) && $#members + for map { $_->{characters}->@* } @ladders; say JSON->new->canonical->pretty->encode({ name => $members[0]->{clanName}, @@ -51,9 +55,11 @@ say JSON->new->canonical->pretty->encode({ division => $_->{ladder}->[0]->{ladderName}, rank => $_->{ladder}->[0]->{rank}, members => [map { $memberidx{$_->{id}} } $_->{characters}->@*], + wins => $_->{ladder}->[0]->{wins}, + losses => $_->{ladder}->[0]->{losses}, }} @ladders], members => [map { blizget(metadata => profile => 2 => 1 => $_->{id}) # lacks mmr, fav race (available in new api) } @members], -}); +}) =~ s/(?: \G \d,? | \[ ) \K \s+ (?=\d|\])/ /grx; # concat arrays of single digits