forked from saetre/busstuc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinterfaceroute.pl
207 lines (157 loc) · 8.02 KB
/
interfaceroute.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
%% FILE interfaceroute.pl
%% SYSTEN BUSSTUC/BUSTER
%% CREATED TA-040421
%% REVISED TA-060101
%% REVISED RS-140101 modularized
% Interface procedures for handling interface to route modules
:-module( interfaceroute, [ current_period/4, decide_period/2, domain_module/2, reset_period/0, search_period_module/3,
thisdate_period_module/3, valid_period/2 ] ).
% thisdate_period_module( TT, _Module, Period ) contains the actual period (for today==when the question was asked, not the travel-day)... Dynamicly updated by reset_period/0
:-volatile thisdate_period_module/3 . %% RS-120915 Not stored in the save_program
:-dynamic thisdate_period_module/3 .
%:- ensure_loaded( 'declare.pl' ). %, [ := /2 etc. ] ). META: set/2, value/2
:- use_module( declare, [ set/2, value/2 ] ). %% RS-141105 General (semantic) Operators, %helpers := /2, =: /2, set/2, value/2. set( X, Y ) is X := Y .
:- use_module( sicstus4compatibility, [ output/1 ] ). %% Compatible with sicstus4, get0/1 etc.
%:- use_module( 'main.pl', [ set/2, value/2 ] ).
%:- use_module( 'utility/utility', [ charno/3 ] ). %% RS-150329 Trying to make more generic Easter Routes handling.
%:- use_module( 'app/buslog', [ seqno_day/4 ] ). %mod_day_in_set/5 ]). %% default_message/3, period_message/2, is not used?, Really?!
:- use_module( 'db/topreg', [ default_period/3, routedomain/1 ]). %% default_message/3, period_message/2, is not used?, Really?!
:- use_module( 'db/route_period', [ route_period/4 ]). %% default_message/3, period_message/2, is not used?, Really?!
:- use_module( 'utility/datecalc', [ off_valid_period/3, on_valid_period/3, todaysdate/1 ] ). % timenow/1, If passing midnight?
%% NB decide_period is called before each question
%% Base Date is the date of today, determines current Period Module
%% Question Date is the date occurring in the question
domain_module(D,M):-
routedomain(D), % unique solutions
route_period( D, M, _, _ ).
%% RS-20190812 Tram is included as route 9 in the main module. %% RS-20190812
%reset_period :- %% called from main.pl
% value(tramflag,true),
% set(actual_domain,gb),
% set_period_module(gb),
% current_period( gb, CP, _, _ ),
% set( actual_period, CP ),
%
% !. %% ///////// %% RS-140616 Tram ONLY? Use ONLY the FIRST MATCH for a given domain.
reset_period :- %% main.pl
value(tmnflag,true),
set(actual_domain,tmn),
set_period_module(tmn),
current_period(tmn,CP,_,_),
set(actual_period,CP),
!. %% ///////// %% RS-140616 Trafikanten MidtNorge ONLY? Use ONLY the FIRST MATCH for a GIVEN domain?
reset_period :- %% NB TT
set(actual_domain,tt), %% TA-110208
set_period_module(tt), %% Default
current_period(tt,CP,_,_),
set(actual_period,CP),
%%% verify_movedates, %% check consistency ---> main.pl ---> timedat.pl moved to create_named_dates
!. %% ///////// %% RS-140616 Don't re-reset period? Use ONLY the FIRST MATCH for a given domain.
reset_period :- output('Reset Period failed'),abort.
set_period_module(TT) :- %% Date is the days date, not the date that is asked !
todaysdate(Date), %% May change overnight // utility/datecalc.pl
thisdate_period_module(TT,Date,_Period),
!. %% Today is compatible with current period
set_period_module(TT) :-
todaysdate(Todate),
\+ thisdate_period_module(TT,Todate,_CurrentPeriod), % and nothing assigned to Todate
search_period_module(TT,Todate,NewPeriod),
!,
retractall( thisdate_period_module(TT,_,_)),
assert( thisdate_period_module(TT,Todate,NewPeriod)),
!. %% /////////
set_period_module(TT) :-
output('interfacesroute.pl~89: UNABLE TO FIND CURRENT MODULE FOR THIS DATE for '),
output(TT).
%%, abort.
search_period_module(TT,Date,Period):-
route_period( TT, Period, FromDate, Todate ), % first
on_valid_period( Date, FromDate, Todate ), % that matches (RS-150328 including dko-bits!)
!.
search_period_module(TT,_Date,DO):- %% BUSTER assumes default winter route
value(dialog,1),
!,
default_period(TT,winter,DO). %% AD HOC TT WINTER ROUTE
search_period_module(_TT,_Date,_Noperiod):-
!,
fail.
current_period( T, CurrentPeriod, Date1, Date2 ):-
thisdate_period_module( T, _, CurrentPeriod ),
route_period( T, CurrentPeriod, Date1, Date2 ),
!.
valid_period(X,Y) :- current_period(_,_,X,Y).
%%%% Search the special holiday routes first %%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% RS-150103
%% Check if DayX (eg 35) contains '1' in the DayCode (eg 3) string (eg 00000110000011...)
%% ...Or if DayX-1 (eg 34) contains '1' in the DayCode (eg 3) string AND Time>2400 (nightbus?)
%
%% timenow(NOW), %% 150328
%
%% ONLY if MAP Date to day is applied,
%mod_day_in_set( TTP, DayX, DayCode, Time, Time ) :- %% example, May 1=sunday route
% number(DayX), %% not separate module
% number(DayCode),
% seqno_day( TTP, DayX, _May1, XN ), %% NEVER APPLIES TO nightbus %% TA-100412
%%% !, %% SDay route ! %%RS-130327, Try new (backup? / nightbus?) Regime below?
% TTP:dko( DayCode, _, _, _, _, _, _, MASK ),
% atom(MASK), %% string of zeros and ones '0100' for whole period
% charno( XN, MASK, '1' ). %% utility.pl
%
%% For nightbuses only?
%mod_day_in_set( TTP, DayX, DayCode, Time, TodayTime ) :-
% number(DayX),
% number(DayCode),
% !,
% TTP:dko( DayCode, _, _, _, _, _, _, MASK ),
% atom( MASK ), %% string of zeros and ones '0100' for whole period
%
% DayBefore is DayX-1,
% ( Time > 2359 -> % if %% utility:charno before or after midnight
% TodayTime is Time-2400, charno( DayBefore, MASK, '1' ) ; % then
% TodayTime=Time, charno( DayX, MASK, '1' ) ). % else
%
%% RS-150328 First rule was TOO straight-forward... Could be multiple modules spanning the same date-range (Easter, Christmas, etc.)
decide_period( DateInQuestion, ThePeriod ) :-
value(actual_domain,TT),
search_period_module(TT,DateInQuestion,ThePeriod),
%% RS-150328
%timenow(NOW),
%mod_day_in_set( ThePeriod, _DayX, DayCode, NOW, _NOW ), %% example, May 1=sunday route
% seqno_day( ThePeriod, DayX, _May1, XN ), %% NOT for nightbus, see below %% TA-100412
% ThePeriod:dko( _DayCode, _Two, _One, _W1, _W2, _W3, _W4, MASK ),
% atom(MASK), %% string of zeros and ones '0100' for whole period
% charno( XN, MASK, '1' ), %% utility.pl
set(actual_period, ThePeriod), %% This only needs to be done ones pr. question-setup.
!
. % actual_period := ThePeriod
%decide_period( DateInQuestion, ThePeriod ) :-
% value(actual_domain,TT),
% search_period_module(TT,DateInQuestion,ThePeriod),
% !,
% set(actual_period, ThePeriod). % actual_period := ThePeriod
%% The decide_period_predicates below here are obsolete?! RS-150328
decide_period( DateInQuestion, CurrentPeriod ) :- %% Same date => Period = current period
value(actual_domain,TT),
todaysdate(DateInQuestion),
!,
thisdate_period_module(TT,_,CurrentPeriod),
set(actual_period, CurrentPeriod). % actual_period := CurrentPeriod.
decide_period( DateInQuestion, ActualPeriod ) :-
value( actual_domain, TT ),
current_period( TT, ActualPeriod, Date1, Date2 ), %% Extra Check
on_valid_period( DateInQuestion, Date1, Date2 ), %% utility/datecalc
!,
set(actual_period, ActualPeriod). % actual_period := ActualPeriod. %% This is the Period in the Question
decide_period( DateInQuestion, NextPeriod ) :-
value(actual_domain,TT),
current_period(TT,_NOW,Date1,Date2), %% Extra Check
off_valid_period(DateInQuestion,Date1,Date2), %% utility/datecalc
search_period_module(TT,DateInQuestion,NextPeriod),
!,
set(actual_period, NextPeriod). % actual_period := NextPeriod. %% This is the Period in Question
decide_period(_,Nil):-
!,
Nil= nil, %% Bloody Trap %% TA-060101
set(actual_period,nil). %% actual_period := nil.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%