-/* Copyright (c) 2013-2018. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2013-2021. The SimGrid Team. All rights reserved. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
* (somewhere between the one of @{DijkstraZone} and the one of @{FullZone}).
*/
class XBT_PRIVATE FloydZone : public RoutedZone {
+ /* vars to compute the Floyd algorithm. */
+ std::vector<int> predecessor_table_;
+ std::vector<double> cost_table_;
+ std::vector<RouteCreationArgs*> link_table_;
+
+ void init_tables(unsigned int table_size);
+ void do_seal() override;
+
public:
- explicit FloydZone(NetZoneImpl* father, std::string name, resource::NetworkModel* netmodel);
+ using RoutedZone::RoutedZone;
+ FloydZone(const FloydZone&) = delete;
+ FloydZone& operator=(const FloydZone&) = delete;
~FloydZone() override;
void get_local_route(NetPoint* src, NetPoint* dst, RouteCreationArgs* into, double* latency) override;
void add_route(NetPoint* src, NetPoint* dst, NetPoint* gw_src, NetPoint* gw_dst,
- std::vector<resource::LinkImpl*>& link_list, bool symmetrical) override;
- void seal() override;
-
-private:
- /* vars to compute the Floyd algorithm. */
- int* predecessor_table_;
- double* cost_table_;
- RouteCreationArgs** link_table_;
+ const std::vector<resource::LinkImpl*>& link_list, bool symmetrical) override;
};
} // namespace routing
} // namespace kernel