-/* Copyright (c) 2010-2020. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2010-2022. 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. */
#include "smpi_comm.hpp"
#include "smpi_status.hpp"
+#include <memory>
-typedef SMPI_Topology *MPI_Topology;
+using MPI_Topology = std::shared_ptr<SMPI_Topology>;
-namespace simgrid{
-namespace smpi{
+namespace simgrid::smpi {
class Topo {
MPI_Comm comm_ = MPI_COMM_NULL;
int get(int maxdims, int* dims, int* periods, int* coords);
int rank(const int* coords, int* rank);
int shift(int direction, int disp, int* rank_source, int* rank_dest);
- int dim_get(int* ndims);
+ int dim_get(int* ndims) const;
static int Dims_create(int nnodes, int ndims, int dims[]);
};
std::vector<int> out_weights_;
};
-}
-}
-
+} // namespace simgrid::smpi
#endif