summaryrefslogtreecommitdiff
path: root/share/json2json
diff options
context:
space:
mode:
Diffstat (limited to 'share/json2json')
-rwxr-xr-xshare/json2json90
1 files changed, 90 insertions, 0 deletions
diff --git a/share/json2json b/share/json2json
new file mode 100755
index 0000000..7cdc577
--- /dev/null
+++ b/share/json2json
@@ -0,0 +1,90 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+use 5.010;
+
+use File::Slurp qw(read_file write_file);
+use JSON;
+
+my $json_str = read_file('stations.json');
+my $stations = JSON->new->utf8->decode($json_str);
+@{$stations}
+ = sort { $a->{name} cmp $b->{name} or $a->{eva} <=> $b->{eva} } @{$stations};
+
+$json_str = read_file('old_stations.json');
+my $old_stations = JSON->new->utf8->decode($json_str);
+@{$old_stations}
+ = sort { $a->{name} cmp $b->{name} or $a->{eva} <=> $b->{eva} }
+ @{$old_stations};
+
+my $have_duplicates = 0;
+my @names = map { $_->{name} } @{$stations};
+my @ds100
+ = map { $_->{ds100} } sort { $a->{ds100} cmp $b->{ds100} } @{$stations};
+my @eva_ids = map { $_->{eva} } sort { $a->{eva} <=> $b->{eva} } @{$stations};
+
+my %name = map { $_ => 1 } @names;
+my %ds100 = map { $_ => 1 } @ds100;
+my %eva_id = map { $_ => 1 } @eva_ids;
+
+my @old_names = map { $_->{name} } @{$old_stations};
+my @old_ds100
+ = map { $_->{ds100} } sort { $a->{ds100} cmp $b->{ds100} } @{$old_stations};
+my @old_eva_ids
+ = map { $_->{eva} } sort { $a->{eva} <=> $b->{eva} } @{$old_stations};
+
+for my $i ( 1 .. $#ds100 ) {
+ if ( $ds100[ $i - 1 ] eq $ds100[$i] ) {
+ say "Duplicate DS100 code: $ds100[$i]";
+ $have_duplicates = 1;
+ }
+}
+for my $i ( 1 .. $#eva_ids ) {
+ if ( $eva_ids[ $i - 1 ] == $eva_ids[$i] ) {
+ say "Duplicate EVA ID: $eva_ids[$i]";
+ $have_duplicates = 1;
+ }
+}
+
+for my $old_ds100 (@old_ds100) {
+ if ( $ds100{$old_ds100} ) {
+ say "Old DS100 also present in new station list: $old_ds100";
+ }
+}
+
+for my $old_eva (@old_eva_ids) {
+ if ( $eva_id{$old_eva} ) {
+ say "Old EVA also present in new station list: $old_eva";
+ }
+}
+
+for my $old_name (@old_names) {
+ if ( $name{$old_name} ) {
+ say "Old name also present in new station list: $old_name";
+ }
+}
+
+if ($have_duplicates) {
+ say "Thank you for your contribution.";
+ say "Please remove duplicate entries before opening a pull request.";
+}
+
+for my $station ( @{$stations} ) {
+ $station->{eva} = 0 + $station->{eva};
+ if ( $station->{latlong}
+ and $station->{latlong}[0] == 0
+ and $station->{latlong}[1] == 0 )
+ {
+ $station->{latlong} = undef;
+ }
+ elsif ( not exists $station->{latlong} ) {
+ $station->{latlong} = undef;
+ }
+}
+
+my $json_out = JSON->new->utf8->canonical->pretty->encode($stations);
+write_file( 'stations.json', $json_out );
+
+$json_out = JSON->new->utf8->canonical->pretty->encode($old_stations);
+write_file( 'old_stations.json', $json_out );