1 /* Handle Fortran - C conversion for MPI Types*/
3 /* Copyright (c) 2010-2021. The SimGrid Team.
4 * All rights reserved. */
6 /* This program is free software; you can redistribute it and/or modify it
7 * under the terms of the license (GNU LGPL) which comes with this package. */
9 #ifndef SMPI_F2C_HPP_INCLUDED
10 #define SMPI_F2C_HPP_INCLUDED
13 #include <unordered_map>
21 using f2c_lookup_type = std::unordered_map<unsigned int, F2C*>;
23 // We use a single lookup table for every type.
24 // Beware of collisions if id in mpif.h is not unique
25 static std::unique_ptr<f2c_lookup_type> f2c_lookup_;
27 static f2c_lookup_type::size_type num_default_handles_;
29 bool deleted_ = false;
30 std::string call_location_;
33 static void allocate_lookup()
36 f2c_lookup_ = std::make_unique<f2c_lookup_type>();
38 int f2c_id() const { return my_f2c_id_; }
39 static int global_f2c_id() { return f2c_id_; }
40 static void f2c_id_increment() { f2c_id_++; }
43 void mark_as_deleted() { deleted_ = true; };
44 bool deleted() const { return deleted_; }
45 static f2c_lookup_type* lookup() { return f2c_lookup_.get(); }
47 virtual ~F2C() = default;
48 virtual std::string name() const = 0;
51 static void free_f(int id) { if(id!=-1) f2c_lookup_->erase(id); }
54 // This method should be overridden in all subclasses to avoid casting the result when calling it.
55 // For the default one, the MPI_*_NULL returned is assumed to be NULL.
56 static F2C* f2c(int id);
57 static void finish_initialization() { num_default_handles_ = f2c_lookup_->size(); }
58 static f2c_lookup_type::size_type get_num_default_handles() { return num_default_handles_; }
59 const std::string& call_location() const { return call_location_; }