forked from aburch/simutrans
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsimhalt.h
799 lines (643 loc) · 21.7 KB
/
simhalt.h
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
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
/*
* Copyright (c) 1997 - 2001 Hansjörg Malthaner
*
* This file is part of the Simutrans project under the artistic license.
* (see license.txt)
*/
#ifndef simhalt_h
#define simhalt_h
#include "convoihandle_t.h"
#include "linehandle_t.h"
#include "halthandle_t.h"
#include "simobj.h"
#include "display/simgraph.h"
#include "simtypes.h"
#include "bauer/warenbauer.h"
#include "besch/ware_besch.h"
#include "dataobj/koord.h"
#include "tpl/inthashtable_tpl.h"
#include "tpl/slist_tpl.h"
#include "tpl/vector_tpl.h"
#include "tpl/binary_heap_tpl.h"
#define RECONNECTING (1)
#define REROUTING (2)
#define MAX_HALT_COST 8 // Total number of cost items
#define MAX_MONTHS 12 // Max history
#define MAX_HALT_NON_MONEY_TYPES 7 // number of non money types in HALT's financial statistic
#define HALT_ARRIVED 0 // the amount of ware that arrived here
#define HALT_DEPARTED 1 // the amount of ware that has departed from here
#define HALT_WAITING 2 // the amount of ware waiting
#define HALT_HAPPY 3 // number of happy passangers
#define HALT_UNHAPPY 4 // number of unhappy passangers
#define HALT_NOROUTE 5 // number of no-route passangers
#define HALT_CONVOIS_ARRIVED 6 // number of convois arrived this month
#define HALT_WALKED 7 // could walk to destination
class cbuffer_t;
class grund_t;
class fabrik_t;
class karte_t;
class karte_ptr_t;
class koord3d;
class loadsave_t;
class schedule_t;
class spieler_t;
class ware_t;
// -------------------------- Haltestelle ----------------------------
/**
* Haltestellen in Simutrans. Diese Klasse managed das Routing und Verladen
* von Waren. Eine Haltestelle ist somit auch ein Warenumschlagplatz.
*
* @author Hj. Malthaner
* @see stadt_t
* @see fabrik_t
* @see convoi_t
*/
class haltestelle_t
{
public:
enum station_flags { NOT_ENABLED=0, PAX=1, POST=2, WARE=4, CROWDED=8 };
//13-Jan-02 Markus Weber Added
enum stationtyp {invalid=0, loadingbay=1, railstation = 2, dock = 4, busstop = 8, airstop = 16, monorailstop = 32, tramstop = 64, maglevstop=128, narrowgaugestop=256 }; //could be combined with or!
private:
/**
* Manche Methoden müssen auf alle Haltestellen angewandt werden
* deshalb verwaltet die Klasse eine Liste aller Haltestellen
* @author Hj. Malthaner
*/
static vector_tpl<halthandle_t> alle_haltestellen;
/**
* finds a stop by its name
* @author prissi
*/
static stringhashtable_tpl<halthandle_t> all_names;
/**
* Finds a stop by coordinate.
* only used during loading.
* @author prissi
*/
static inthashtable_tpl<sint32,halthandle_t> *all_koords;
/*
* struct holds new financial history for line
* @author hsiegeln
*/
sint64 financial_history[MAX_MONTHS][MAX_HALT_COST];
/**
* initialize the financial history
* @author hsiegeln
*/
void init_financial_history();
COLOR_VAL status_color, last_status_color;
sint16 last_bar_count;
vector_tpl<KOORD_VAL> last_bar_height; // caches the last height of the station bar for each good type drawn in display_status(). used for dirty tile management
uint32 capacity[3]; // passenger, post, goods
uint8 overcrowded[8]; // bit set, when overcrowded
static uint8 status_step; // NONE or SCHEDULING or REROUTING
slist_tpl<convoihandle_t> loading_here;
long last_loading_step;
koord init_pos; // for halt without grounds, created during game initialisation
/**
* Handle for ourselves. Can be used like the 'this' pointer
* @author Hj. Malthaner
*/
halthandle_t self;
public:
const slist_tpl<convoihandle_t> &get_loading_convois() const { return loading_here; }
// add convoi to loading queue
void request_loading( convoihandle_t cnv );
// removes convoi from laoding quee
void finish_loading( convoihandle_t cnv ) { loading_here.remove(cnv); }
/* recalculates the station bar */
void recalc_status();
/**
* Handles changes of schedules and the resulting rerouting.
*/
static void step_all();
static uint8 get_rerouting_status() { return status_step; }
/**
* Resets reconnect_counter.
* The next call to step_all() will start complete reconnecting.
*/
static void reset_routing();
/**
* Tries to generate some pedestrians on the sqaure and the
* adjacent sqaures. Return actual number of generated
* pedestrians.
*
* @author Hj. Malthaner
*/
static int erzeuge_fussgaenger(const koord3d pos, int anzahl);
/**
* Returns an index to a halt at koord k
* optionally limit to that owned by player sp
* by default create a new halt if none found
* Only used during loading.
*/
static halthandle_t get_halt_koord_index(koord k);
/*
* this will only return something if this stop belongs to same player or is public, or is a dock (when on water)
*/
static halthandle_t get_halt(const koord3d pos, const spieler_t *sp );
static const vector_tpl<halthandle_t>& get_alle_haltestellen() { return alle_haltestellen; }
/**
* Station factory method. Returns handles instead of pointers.
* @author Hj. Malthaner
*/
static halthandle_t create(koord pos, spieler_t *sp);
/**
* Station factory method. Returns handles instead of pointers.
* @author Hj. Malthaner
*/
static halthandle_t create(loadsave_t *file);
/*
* removes a ground tile from a station, deletes the building and, if last tile, also the halthandle
* @author prissi
*/
static bool remove(spieler_t *sp, koord3d pos);
/**
* Station destruction method.
* @author Hj. Malthaner
*/
static void destroy(halthandle_t);
/**
* destroys all stations
* @author Hj. Malthaner
*/
static void destroy_all();
/**
* Liste aller felder (Grund-Objekte) die zu dieser Haltestelle gehören
* @author Hj. Malthaner
*/
struct tile_t
{
tile_t(grund_t* grund_) : grund(grund_) {}
bool operator ==(const tile_t& o) { return grund == o.grund; }
bool operator !=(const tile_t& o) { return grund != o.grund; }
grund_t* grund;
convoihandle_t reservation;
};
const slist_tpl<tile_t> &get_tiles() const { return tiles; };
/**
* directly reachable halt with its connection weight
* @author Knightly
*/
struct connection_t
{
/// directly reachable halt
halthandle_t halt;
/// best connection weight to reach this destination
uint16 weight:15;
/// is halt a transfer halt
bool is_transfer:1;
connection_t() : weight(0), is_transfer(false) { }
connection_t(halthandle_t _halt, uint16 _weight=0) : halt(_halt), weight(_weight), is_transfer(false) { }
bool operator == (const connection_t &other) const { return halt == other.halt; }
bool operator != (const connection_t &other) const { return halt != other.halt; }
static bool compare(const connection_t &a, const connection_t &b) { return a.halt.get_id() < b.halt.get_id(); }
};
bool is_transfer(const uint8 catg) const { return all_links[catg].is_transfer; }
private:
slist_tpl<tile_t> tiles;
/**
* Stores information about link to cargo network of a certain category
*/
struct link_t {
/// List of all directly reachable halts with their respective connection weights
vector_tpl<connection_t> connections;
/**
* A transfer/interchange is a halt whereby ware can change line or lineless convoy.
* Thus, if a halt is served by 2 or more schedules (of lines or lineless convoys)
* for a particular ware type, it is a transfer/interchange for that ware type.
* Route searching is accelerated by differentiating transfer and non-transfer halts.
* @author Knightly
*/
bool is_transfer;
/**
* Id of connected component in link graph.
* Two halts are connected if and only if they belong to the same connected component.
* Exception: if value == UNDECIDED_CONNECTED_COMPONENT, then we are in the middle of
* recalculating the link graph.
*
* The id of the component has to be equal to the halt-id of one of its halts.
* This ensures that we always have unique component ids.
*/
uint16 catg_connected_component;
# define UNDECIDED_CONNECTED_COMPONENT (0xffff)
link_t() { clear(); }
void clear()
{
connections.clear();
is_transfer = false;
catg_connected_component = UNDECIDED_CONNECTED_COMPONENT;
}
};
/// All links to networks of all freight categories, filled by rebuild_connected_components.
link_t* all_links;
/**
* Fills in catg_connected_component values for all halts and all categories.
* Uses depth-first search.
*/
static void rebuild_connected_components();
/**
* Helper method: This halt (and all its connected neighbors) belong
* to the same component.
* Also sets connection_t::is_transfer.
* @param catg category of cargo network
* @param comp number of component
*/
void fill_connected_component(uint8 catg, uint16 comp);
// Array with different categries that contains all waiting goods at this stop
vector_tpl<ware_t> **waren;
/**
* Liste der angeschlossenen Fabriken
* @author Hj. Malthaner
*/
slist_tpl<fabrik_t *> fab_list;
spieler_t *besitzer_p;
static karte_ptr_t welt;
/**
* What is that for a station (for the image)
* @author prissi
*/
stationtyp station_type;
// private helper function for recalc_station_type()
void add_to_station_type( grund_t *gr );
/**
* Reconnect and reroute if counter different from welt->get_schedule_counter()
*/
static uint8 reconnect_counter;
// since we do partial routing, we remember the last offset
uint8 last_catg_index;
/* station flags (most what enabled) */
uint8 enables;
/**
* versucht die ware mit beriets wartender ware zusammenzufassen
* @author Hj. Malthaner
*/
bool vereinige_waren(const ware_t &ware);
// add the ware to the internal storage, called only internally
void add_ware_to_halt(ware_t ware);
/**
* liefert wartende ware an eine Fabrik
* @author Hj. Malthaner
*/
void liefere_an_fabrik(const ware_t& ware) const;
/*
* transfers all goods to given station
*
* @author Dwachs
*/
void transfer_goods(halthandle_t halt);
/*
* parameter to ease sorting
* sortierung is local and stores the sortorder for the individual station
* @author hsiegeln
*/
uint8 sortierung;
bool resort_freight_info;
haltestelle_t(loadsave_t *file);
haltestelle_t(koord pos, spieler_t *sp);
~haltestelle_t();
public:
/**
* Called after schedule calculation of all stations is finished
* will distribute the goods to changed routes (if there are any)
* returns true upon completion
* @author Hj. Malthaner
*/
bool reroute_goods(sint16 &units_remaining);
/**
* getter/setter for sortby
* @author hsiegeln
*/
uint8 get_sortby() { return sortierung; }
void set_sortby(uint8 sm) { resort_freight_info =true; sortierung = sm; }
/**
* Calculates a status color for status bars
* @author Hj. Malthaner
*/
COLOR_VAL get_status_farbe() const { return status_color; }
/**
* Draws some nice colored bars giving some status information
* @author Hj. Malthaner
*/
void display_status(KOORD_VAL xpos, KOORD_VAL ypos);
/**
* sucht umliegende, erreichbare fabriken und baut daraus die
* Fabrikliste auf.
* @author Hj. Malthaner
*/
void verbinde_fabriken();
void remove_fabriken(fabrik_t *fab);
/**
* Rebuilds the list of connections to reachable halts
* returns the search number of connections
* @author Hj. Malthaner
*/
sint32 rebuild_connections();
uint8 get_reconnect_counter() const { return reconnect_counter; }
void rotate90( const sint16 y_size );
spieler_t *get_besitzer() const {return besitzer_p;}
// just for info so far
sint64 calc_maintenance() const;
void make_public_and_join( spieler_t *sp );
vector_tpl<connection_t> const& get_pax_connections() const { return all_links[warenbauer_t::INDEX_PAS].connections; }
vector_tpl<connection_t> const& get_mail_connections() const { return all_links[warenbauer_t::INDEX_MAIL].connections; }
// returns the matchin warenziele
vector_tpl<connection_t> const& get_connections(uint8 const catg_index) const { return all_links[catg_index].connections; }
/**
* Checks if there is connection for certain freight to the other halt.
* @param halt the other halt
* @param catg_index freight category index
* @return 0 - not connected, 1 - connected, -1 - undecided (call again later...)
*/
sint8 is_connected(halthandle_t halt, uint8 catg_index) const;
const slist_tpl<fabrik_t*>& get_fab_list() const { return fab_list; }
/**
* called regularily to update status and reroute stuff
* @author Hj. Malthaner
*/
bool step(uint8 what, sint16 &units_remaining);
/**
* Called every month/every 24 game hours
* @author Hj. Malthaner
*/
void neuer_monat();
private:
/* Node used during route search */
struct route_node_t
{
halthandle_t halt;
uint16 aggregate_weight;
route_node_t() : aggregate_weight(0) {}
route_node_t(halthandle_t h, uint16 w) : halt(h), aggregate_weight(w) {}
// dereferencing to be used in binary_heap_tpl
inline uint16 operator * () const { return aggregate_weight; }
};
/* Extra data for route search */
struct halt_data_t
{
// transfer halt:
// in static function search_route(): previous transfer halt (to track back route)
// in member function search_route_resumable(): first transfer halt to get there
halthandle_t transfer;
uint16 best_weight;
uint16 depth:14;
bool destination:1;
bool overcrowded:1;
};
// store the best weight so far for a halt, and indicate whether it is a destination
static halt_data_t halt_data[65536];
// for efficient retrieval of the node with the smallest weight
static binary_heap_tpl<route_node_t> open_list;
/**
* Markers used in route searching to avoid processing the same halt more than once
* @author Knightly
*/
static uint8 markers[65536];
static uint8 current_marker;
/**
* Remember last route search start and catg to resume search
* @author dwachs
*/
static halthandle_t last_search_origin;
static uint8 last_search_ware_catg_idx;
public:
enum routing_result_flags { NO_ROUTE=0, ROUTE_OK=1, ROUTE_WALK=2, ROUTE_OVERCROWDED=8 };
/**
* Kann die Ware nicht zum Ziel geroutet werden (keine Route), dann werden
* Ziel und Zwischenziel auf koord::invalid gesetzt.
*
* @param ware die zu routende Ware
* @author Hj. Malthaner
*
* for reverse routing, also the next to last stop can be added, if next_to_ziel!=NULL
*
* if avoid_overcrowding is set, a valid route in only found when there is no overflowing stop in between
*
* @author prissi
*/
static int search_route( const halthandle_t *const start_halts, const uint16 start_halt_count, const bool no_routing_over_overcrowding, ware_t &ware, ware_t *const return_ware=NULL );
/**
* A separate version of route searching code for re-calculating routes
* Search is resumable, that is if called for the same halt and same goods category
* it reuses search history from last search
* It is faster than calling the above version on each packet, and is used for re-routing packets from the same halt.
*/
void search_route_resumable( ware_t &ware );
bool get_pax_enabled() const { return enables & PAX; }
bool get_post_enabled() const { return enables & POST; }
bool get_ware_enabled() const { return enables & WARE; }
// check, if we accepts this good
// often called, thus inline ...
bool is_enabled( const ware_besch_t *wtyp ) const {
return is_enabled(wtyp->get_catg_index());
}
// a separate version for checking with goods category index
bool is_enabled( const uint8 catg_index ) const
{
if (catg_index == warenbauer_t::INDEX_PAS) {
return enables&PAX;
}
else if(catg_index == warenbauer_t::INDEX_MAIL) {
return enables&POST;
}
return enables&WARE;
}
/**
* Found route and station uncrowded
* @author Hj. Malthaner
*/
void add_pax_happy(int n);
/**
* Station in walking distance
* @author prissi
*/
void add_pax_walked(int n);
/**
* Found no route
* @author Hj. Malthaner
*/
void add_pax_no_route(int n);
/**
* Station crowded
* @author Hj. Malthaner
*/
void add_pax_unhappy(int n);
int get_pax_happy() const { return (int)financial_history[0][HALT_HAPPY]; }
int get_pax_no_route() const { return (int)financial_history[0][HALT_NOROUTE]; }
int get_pax_unhappy() const { return (int)financial_history[0][HALT_UNHAPPY]; }
bool add_grund(grund_t *gb);
bool rem_grund(grund_t *gb);
uint32 get_capacity(uint8 typ) const { return capacity[typ]; }
bool existiert_in_welt() const;
koord get_init_pos() const { return init_pos; }
koord get_basis_pos() const;
koord3d get_basis_pos3d() const;
/* return the closest square that belongs to this halt
* @author prissi
*/
koord get_next_pos( koord start ) const;
// true, if this station is overcroded for this category
bool is_overcrowded( const uint8 idx ) const { return (overcrowded[idx/8] & (1<<(idx%8)))!=0; }
/**
* gibt Gesamtmenge derware vom typ typ zurück
* @author Hj. Malthaner
*/
uint32 get_ware_summe(const ware_besch_t *warentyp) const;
/**
* returns total number for a certain position (since more than one factory might connect to a stop)
* @author Hj. Malthaner
*/
uint32 get_ware_fuer_zielpos(const ware_besch_t *warentyp, const koord zielpos) const;
// true, if we accept/deliver this kind of good
bool gibt_ab(const ware_besch_t *warentyp) const { return waren[warentyp->get_catg_index()] != NULL; }
/* retrieves a ware packet for any destination in the list
* needed, if the factory in question wants to remove something
*/
bool recall_ware( ware_t& w, uint32 menge );
/**
* fetches goods from this halt
* @param fracht goods will be put into this list, vehicle has to load it
* @author Hj. Malthaner, dwachs
*/
void hole_ab( slist_tpl<ware_t> &fracht, const ware_besch_t *warentyp, uint32 menge, const schedule_t *fpl, const spieler_t *sp );
/* liefert ware an. Falls die Ware zu wartender Ware dazugenommen
* werden kann, kann ware_t gelöscht werden! D.h. man darf ware nach
* aufruf dieser Methode nicht mehr referenzieren!
*
* The second version is like the first, but will not recalculate the route
* This is used for inital passenger, since they already know a route
*
* @return angenommene menge
* @author Hj. Malthaner/prissi
*/
uint32 liefere_an(ware_t ware);
uint32 starte_mit_route(ware_t ware);
const grund_t *find_matching_position(waytype_t wt) const;
/* checks, if there is an unoccupied loading bay for this kind of thing
* @author prissi
*/
bool find_free_position(const waytype_t w ,convoihandle_t cnv,const obj_t::typ d) const;
/* reserves a position (caution: railblocks work differently!
* @author prissi
*/
bool reserve_position(grund_t *gr,convoihandle_t cnv);
/* frees a reserved position (caution: railblocks work differently!
* @author prissi
*/
bool unreserve_position(grund_t *gr, convoihandle_t cnv);
/* true, if this can be reserved
* @author prissi
*/
bool is_reservable(const grund_t *gr, convoihandle_t cnv) const;
void info(cbuffer_t & buf) const;
/**
* @param buf the buffer to fill
* @return Goods description text (buf)
* @author Hj. Malthaner
*/
void get_freight_info(cbuffer_t & buf);
/**
* @param buf the buffer to fill
* @return short list of the waiting goods (i.e. 110 Wood, 15 Coal)
* @author Hj. Malthaner
*/
void get_short_freight_info(cbuffer_t & buf) const;
/**
* Opens an information window for this station.
* @author Hj. Malthaner
*/
void zeige_info();
/**
* @return the type of a station
* (combination of: railstation, loading bay, dock)
* @author Markus Weber
*/
stationtyp get_station_type() const { return station_type; }
void recalc_station_type();
/**
* fragt den namen der Haltestelle ab.
* Der Name ist der text des ersten Untergrundes der Haltestelle
* @return der Name der Haltestelle.
* @author Hj. Malthaner
*/
const char *get_name() const;
void set_name(const char *name);
// create an unique name: better to be called with valid handle, althoug it will work without
char* create_name(koord k, char const* typ);
void rdwr(loadsave_t *file);
void laden_abschliessen();
/**
* Called before savegame will be loaded.
* Creates all_koords table.
*/
static void start_load_game();
/**
* Called after loading of savegame almost finished,
* i.e. after laden_abschliessen is finished.
* Deletes all_koords table.
*/
static void end_load_game();
/*
* called, if a line serves this stop
* @author hsiegeln
*/
void add_line(linehandle_t line) { registered_lines.append_unique(line); }
/*
* called, if a line removes this stop from it's schedule
* @author hsiegeln
*/
void remove_line(linehandle_t line) { registered_lines.remove(line); }
/*
* list of line ids that serve this stop
* @author hsiegeln
*/
vector_tpl<linehandle_t> registered_lines;
/**
* Register a lineless convoy which serves this stop
* @author Knightly
*/
void add_convoy(convoihandle_t convoy) { registered_convoys.append_unique(convoy); }
/**
* Unregister a lineless convoy
* @author Knightly
*/
void remove_convoy(convoihandle_t convoy) { registered_convoys.remove(convoy); }
/**
* A list of lineless convoys serving this stop
* @author Knightly
*/
vector_tpl<convoihandle_t> registered_convoys;
/**
* book a certain amount into the halt's financial history
* @author hsiegeln
*/
void book(sint64 amount, int cost_type);
/**
* return a pointer to the financial history
* @author hsiegeln
*/
sint64* get_finance_history() { return *financial_history; }
/**
* return a specified element from the financial history
* @author hsiegeln
*/
sint64 get_finance_history(int month, int cost_type) const { return financial_history[month][cost_type]; }
// flags station for a crowded message at the beginning of next month
void bescheid_station_voll() { enables |= CROWDED; status_color = COL_RED; }
/* marks a coverage area
* @author prissi
*/
void mark_unmark_coverage(const bool mark) const;
/*
* deletes factory references so map rotation won't segfault
*/
void release_factory_links();
/**
* Initialise the markers to zero
* @author Knightly
*/
static void init_markers();
};
ENUM_BITSET(haltestelle_t::stationtyp)
#endif