X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/13667460824c1a4d55d44f96adaee6eeda2394f4..2df88396d94796a341f1dbaa1d41f3162745d927:/src/smpi/include/smpi_f2c.hpp diff --git a/src/smpi/include/smpi_f2c.hpp b/src/smpi/include/smpi_f2c.hpp index 207c699c4f..1d965e9aba 100644 --- a/src/smpi/include/smpi_f2c.hpp +++ b/src/smpi/include/smpi_f2c.hpp @@ -1,6 +1,6 @@ /* Handle Fortan - C conversion for MPI Types*/ -/* Copyright (c) 2010, 2013-2017. The SimGrid Team. +/* Copyright (c) 2010-2019. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it @@ -27,17 +27,20 @@ class F2C { static void set_f2c_lookup(std::unordered_map* map); static int f2c_id(); static void f2c_id_increment(); + int my_f2c_id_; public: + char* get_my_key(char* key); static char* get_key(char* key, int id); - static char* get_key_id(char* key, int id); static void delete_lookup(); static std::unordered_map* lookup(); + F2C() : my_f2c_id_(-1){} + virtual ~F2C() = default; //Override these to handle specific values. - int add_f(); + virtual int add_f(); static void free_f(int id); - int c2f(); - + virtual int c2f(); + static void print_f2c_lookup(); // This method should be overridden in all subclasses to avoid casting the result when calling it. // For the default one, the MPI_*_NULL returned is assumed to be NULL. static F2C* f2c(int id);