#include <unordered_map>
#include <string>
-#define KEY_SIZE (sizeof(int) * 2 + 1)
-
namespace simgrid{
namespace smpi{
static void f2c_id_increment();
public:
- char* get_my_key(char* key);
- static char* get_key(char* key, int id);
+ std::string get_my_key() { return get_key(my_f2c_id_); }
+ static std::string get_key(int id) { return std::to_string(id); }
static void delete_lookup();
static std::unordered_map<std::string, F2C*>* lookup();
F2C();
} else if(id==0){
return MPI_COMM_WORLD;
} else if(F2C::f2c_lookup() != nullptr && id >= 0) {
- char key[KEY_SIZE];
const auto& lookup = F2C::f2c_lookup();
- auto comm = lookup->find(get_key(key, id));
+ auto comm = lookup->find(get_key(id));
return comm == lookup->end() ? MPI_COMM_NULL : static_cast<MPI_Comm>(comm->second);
} else {
return MPI_COMM_NULL;
}
void Comm::free_f(int id) {
- char key[KEY_SIZE];
- F2C::f2c_lookup()->erase(get_key(key, id));
+ F2C::f2c_lookup()->erase(get_key(id));
}
void Comm::add_rma_win(MPI_Win win){
MPI_Errhandler Errhandler::f2c(int id) {
if(F2C::f2c_lookup() != nullptr && id >= 0) {
- char key[KEY_SIZE];
- return static_cast<MPI_Errhandler>(F2C::f2c_lookup()->at(get_key(key, id)));
+ return static_cast<MPI_Errhandler>(F2C::f2c_lookup()->at(get_key(id)));
} else {
return MPI_ERRHANDLER_NULL;
}
return f2c_id_;
}
-char* F2C::get_my_key(char* key) {
- std::snprintf(key, KEY_SIZE, "%d", my_f2c_id_);
- return key;
-}
-
-char* F2C::get_key(char* key, int id) {
- std::snprintf(key, KEY_SIZE, "%d", id);
- return key;
-}
-
void F2C::delete_lookup(){
delete f2c_lookup_;
}
void F2C::free_f(int id)
{
- char key[KEY_SIZE];
- f2c_lookup_->erase(get_key(key,id));
+ f2c_lookup_->erase(get_key(id));
}
int F2C::add_f()
if (f2c_lookup_ == nullptr)
f2c_lookup_ = new std::unordered_map<std::string, F2C*>();
- char key[KEY_SIZE];
my_f2c_id_=f2c_id_;
- (*f2c_lookup_)[get_my_key(key)] = this;
+ (*f2c_lookup_)[get_my_key()] = this;
f2c_id_increment();
return my_f2c_id_;
}
f2c_lookup_ = new std::unordered_map<std::string, F2C*>();
if(id >= 0){
- char key[KEY_SIZE];
- auto comm = f2c_lookup_->find(get_key(key,id));
+ auto comm = f2c_lookup_->find(get_key(id));
return comm == f2c_lookup_->end() ? nullptr : comm->second;
}else
return nullptr;
if(id == -2) {
return MPI_GROUP_EMPTY;
} else if(F2C::f2c_lookup() != nullptr && id >= 0) {
- char key[KEY_SIZE];
- return static_cast<MPI_Group>(F2C::f2c_lookup()->at(get_key(key, id)));
+ return static_cast<MPI_Group>(F2C::f2c_lookup()->at(get_key(id)));
} else {
return MPI_GROUP_NULL;
}
MPI_Request Request::f2c(int id)
{
- char key[KEY_SIZE];
if(id==MPI_FORTRAN_REQUEST_NULL)
return MPI_REQUEST_NULL;
- return static_cast<MPI_Request>(F2C::f2c_lookup()->at(get_key(key,id)));
+ return static_cast<MPI_Request>(F2C::f2c_lookup()->at(get_key(id)));
}
void Request::free_f(int id)
{
if (id != MPI_FORTRAN_REQUEST_NULL) {
- char key[KEY_SIZE];
- F2C::f2c_lookup()->erase(get_key(key, id));
+ F2C::f2c_lookup()->erase(get_key(id));
}
}