#include <order_base.h>

| Public Member Functions | |
| OrderList (VehicleOrderID num_orders=INVALID_VEH_ORDER_ID) | |
| Default constructor producing an invalid order list. | |
| OrderList (Order *chain, Vehicle *v) | |
| Create an order list with the given order chain for the given vehicle. | |
| ~OrderList () | |
| Destructor. | |
| void | Initialize (Order *chain, Vehicle *v) | 
| Recomputes everything. | |
| Order * | GetFirstOrder () const | 
| Get the first order of the order chain. | |
| Order * | GetOrderAt (int index) const | 
| Get a certain order of the order chain. | |
| Order * | GetLastOrder () const | 
| Get the last order of the order chain. | |
| VehicleOrderID | GetNumOrders () const | 
| Get number of orders in the order list. | |
| void | InsertOrderAt (Order *new_order, int index) | 
| Insert a new order into the order chain. | |
| void | DeleteOrderAt (int index) | 
| Remove an order from the order list and delete it. | |
| void | MoveOrder (int from, int to) | 
| Move an order to another position within the order list. | |
| bool | IsShared () const | 
| Is this a shared order list? | |
| Vehicle * | GetFirstSharedVehicle () const | 
| Get the first vehicle of this vehicle chain. | |
| uint | GetNumVehicles () const | 
| Return the number of vehicles that share this orders list. | |
| bool | IsVehicleInSharedOrdersList (const Vehicle *v) const | 
| Checks whether a vehicle is part of the shared vehicle chain. | |
| int | GetPositionInSharedOrderList (const Vehicle *v) const | 
| Gets the position of the given vehicle within the shared order vehicle list. | |
| void | AddVehicle (Vehicle *v) | 
| Adds the given vehicle to this shared order list. | |
| void | RemoveVehicle (Vehicle *v) | 
| Removes the vehicle from the shared order list. | |
| bool | IsCompleteTimetable () const | 
| Checks whether all orders of the list have a filled timetable. | |
| Ticks | GetTimetableTotalDuration () const | 
| Gets the total duration of the vehicles timetable or INVALID_TICKS is the timetable is not complete. | |
| Ticks | GetTimetableDurationIncomplete () const | 
| Gets the known duration of the vehicles timetable even if the timetable is not complete. | |
| void | UpdateOrderTimetable (Ticks delta) | 
| Must be called if an order's timetable is changed to update internal book keeping. | |
| void | FreeChain (bool keep_orderlist=false) | 
| Free a complete order chain. | |
| void | DebugCheckSanity () const | 
| Checks for internal consistency of order list. | |
| Private Attributes | |
| Order * | first | 
| First order of the order list. | |
| VehicleOrderID | num_orders | 
| NOSAVE: How many orders there are in the list. | |
| uint | num_vehicles | 
| NOSAVE: Number of vehicles that share this order list. | |
| Vehicle * | first_shared | 
| NOSAVE: pointer to the first vehicle in the shared order chain. | |
| Ticks | timetable_duration | 
| NOSAVE: Total duration of the order list. | |
| Friends | |
| void | AfterLoadVehicles (bool part_of_load) | 
| For instantiating the shared vehicle chain. | |
| struct SaveLoad * | GetOrderListDescription () | 
| Saving and loading of order lists. | |
Definition at line 259 of file order_base.h.
| OrderList::OrderList | ( | VehicleOrderID | num_orders = INVALID_VEH_ORDER_ID | ) |  [inline] | 
Default constructor producing an invalid order list.
Definition at line 273 of file order_base.h.
Referenced by CmdCloneOrder(), and CmdInsertOrder().
| OrderList::OrderList | ( | Order * | chain, | |
| Vehicle * | v | |||
| ) |  [inline] | 
Create an order list with the given order chain for the given vehicle.
| chain | pointer to the first order of the order chain | |
| v | any vehicle using this orderlist | 
Definition at line 281 of file order_base.h.
References Initialize().
| OrderList::~OrderList | ( | ) |  [inline] | 
Destructor.
Invalidates OrderList for re-usage by the pool.
Definition at line 284 of file order_base.h.
| void OrderList::Initialize | ( | Order * | chain, | |
| Vehicle * | v | |||
| ) | 
Recomputes everything.
| chain | first order in the chain | |
| v | one of vehicle that is using this orderlist | 
Definition at line 209 of file order_cmd.cpp.
References first, first_shared, num_orders, num_vehicles, and timetable_duration.
Referenced by OrderList().
| Order* OrderList::GetFirstOrder | ( | ) | const  [inline] | 
Get the first order of the order chain.
Definition at line 297 of file order_base.h.
References first.
Referenced by MoveBuoysToWaypoints(), and MoveWaypointsToBaseStations().
| Order * OrderList::GetOrderAt | ( | int | index | ) | const | 
Get a certain order of the order chain.
| index | zero-based index of the order within the chain. | 
Definition at line 248 of file order_cmd.cpp.
References first.
Referenced by DeleteOrderAt(), GetLastOrder(), InsertOrderAt(), and MoveOrder().
| Order* OrderList::GetLastOrder | ( | ) | const  [inline] | 
Get the last order of the order chain.
Definition at line 310 of file order_base.h.
References GetOrderAt(), and num_orders.
Referenced by InsertOrderAt().
| VehicleOrderID OrderList::GetNumOrders | ( | ) | const  [inline] | 
Get number of orders in the order list.
Definition at line 315 of file order_base.h.
References num_orders.
Referenced by CmdInsertOrder().
| void OrderList::InsertOrderAt | ( | Order * | new_order, | |
| int | index | |||
| ) | 
Insert a new order into the order chain.
| new_order | is the order to insert into the chain. | |
| index | is the position where the order is supposed to be inserted. | 
Definition at line 260 of file order_cmd.cpp.
References first, GetLastOrder(), GetOrderAt(), num_orders, and timetable_duration.
| void OrderList::DeleteOrderAt | ( | int | index | ) | 
Remove an order from the order list and delete it.
| index | is the position of the order which is to be deleted. | 
Definition at line 284 of file order_cmd.cpp.
References first, GetOrderAt(), num_orders, and timetable_duration.
| void OrderList::MoveOrder | ( | int | from, | |
| int | to | |||
| ) | 
Move an order to another position within the order list.
| from | is the zero-based position of the order to move. | |
| to | is the zero-based position where the order is moved to. | 
Definition at line 303 of file order_cmd.cpp.
References first, GetOrderAt(), and num_orders.
| bool OrderList::IsShared | ( | ) | const  [inline] | 
Is this a shared order list?
Definition at line 339 of file order_base.h.
References num_vehicles.
| Vehicle* OrderList::GetFirstSharedVehicle | ( | ) | const  [inline] | 
Get the first vehicle of this vehicle chain.
Definition at line 345 of file order_base.h.
References first_shared.
Referenced by MoveBuoysToWaypoints(), and MoveWaypointsToBaseStations().
| uint OrderList::GetNumVehicles | ( | ) | const  [inline] | 
Return the number of vehicles that share this orders list.
Definition at line 351 of file order_base.h.
References num_vehicles.
| bool OrderList::IsVehicleInSharedOrdersList | ( | const Vehicle * | v | ) | const | 
Checks whether a vehicle is part of the shared vehicle chain.
| v | is the vehicle to search in the shared vehicle chain. | 
Definition at line 336 of file order_cmd.cpp.
References first_shared.
| int OrderList::GetPositionInSharedOrderList | ( | const Vehicle * | v | ) | const | 
Gets the position of the given vehicle within the shared order vehicle list.
| v | is the vehicle of which to get the position | 
Definition at line 345 of file order_cmd.cpp.
| void OrderList::AddVehicle | ( | Vehicle * | v | ) |  [inline] | 
Adds the given vehicle to this shared order list.
| v | vehicle to add to the list | 
Definition at line 372 of file order_base.h.
References num_vehicles.
| void OrderList::RemoveVehicle | ( | Vehicle * | v | ) | 
Removes the vehicle from the shared order list.
| v | vehicle to remove from the list | 
Definition at line 330 of file order_cmd.cpp.
References first_shared, and num_vehicles.
| bool OrderList::IsCompleteTimetable | ( | ) | const | 
Checks whether all orders of the list have a filled timetable.
Definition at line 352 of file order_cmd.cpp.
References first.
Referenced by GetTimetableTotalDuration().
| Ticks OrderList::GetTimetableTotalDuration | ( | ) | const  [inline] | 
Gets the total duration of the vehicles timetable or INVALID_TICKS is the timetable is not complete.
Definition at line 391 of file order_base.h.
References INVALID_TICKS, IsCompleteTimetable(), and timetable_duration.
| Ticks OrderList::GetTimetableDurationIncomplete | ( | ) | const  [inline] | 
Gets the known duration of the vehicles timetable even if the timetable is not complete.
Definition at line 397 of file order_base.h.
References timetable_duration.
| void OrderList::UpdateOrderTimetable | ( | Ticks | delta | ) |  [inline] | 
Must be called if an order's timetable is changed to update internal book keeping.
| delta | By how many ticks has the timetable duration changed | 
Definition at line 403 of file order_base.h.
References timetable_duration.
| void OrderList::FreeChain | ( | bool | keep_orderlist = false | ) | 
Free a complete order chain.
| keep_orderlist | If this is true only delete the orders, otherwise also delete the OrderList. | 
Definition at line 231 of file order_cmd.cpp.
References first, num_orders, and timetable_duration.
| void OrderList::DebugCheckSanity | ( | ) | const | 
Checks for internal consistency of order list.
Triggers assertion if something is wrong.
Definition at line 360 of file order_cmd.cpp.
References first, first_shared, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::PoolItem< Tpool >::index, num_orders, num_vehicles, and timetable_duration.
 1.5.6
 1.5.6