From 496391d23309aeabfbbf1f9088db3e508c548d6c Mon Sep 17 00:00:00 2001 From: Daniel Friesel Date: Sun, 20 Jun 2021 11:14:08 +0200 Subject: identify and add missing stations from train routes --- share/find-missing | 72 ++++++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 59 insertions(+), 13 deletions(-) (limited to 'share/find-missing') diff --git a/share/find-missing b/share/find-missing index 909c203..e69a7a1 100755 --- a/share/find-missing +++ b/share/find-missing @@ -1,13 +1,59 @@ -#!/bin/zsh - -: > missing.txt - -./xml2json | fgrep missing | shuf | while read m eva x ; do - if [[ $x != *,* ]] && db-iris -x $eva &> /dev/null; then - echo "\n$m $eva $x" - echo $m $eva $x >> missing.txt - else - echo -n . - fi - sleep .2 -done +#!/usr/bin/env perl + +use strict; +use warnings; +use 5.010; + +use Cache::File; +use List::Util qw(uniq); +use Travel::Status::DE::IRIS; +use Travel::Status::DE::IRIS::Stations; + +my ($station) = @ARGV; + +my $cache_path = $ENV{XDG_CACHE_HOME} // "$ENV{HOME}/.cache"; +my $schedule_cache_path = "${cache_path}/db-iris-schedule"; +my $realtime_cache_path = "${cache_path}/db-iris-realtime"; +my ( $schedule_cache, $realtime_cache ); + +eval { + use Cache::File; + $schedule_cache = Cache::File->new( + cache_root => $schedule_cache_path, + default_expires => '6 hours', + lock_level => Cache::File::LOCK_LOCAL(), + ); + $realtime_cache = Cache::File->new( + cache_root => $realtime_cache_path, + default_expires => '180 seconds', + lock_level => Cache::File::LOCK_LOCAL(), + ); +}; +if ($@) { + $schedule_cache = undef; + $realtime_cache = undef; +} + +my $status = Travel::Status::DE::IRIS->new( + station => $station, + main_cache => $schedule_cache, + realtime_cache => $realtime_cache, + with_related => 1, +); + +my @missing; + +for my $result ( $status->results ) { + for my $name ( $result->route_pre, $result->route_post ) { + my @matches + = Travel::Status::DE::IRIS::Stations::get_station_by_name($name); + if ( @matches != 1 ) { + push( @missing, $name ); + } + elsif ( $matches[0][1] ne $name ) { + push( @missing, $name ); + } + } +} + +say join( "\n", uniq @missing ); -- cgit v1.2.3