X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/43f7ca1cac5ab1858e318fdd6239d0a0c3b3d893..fbcf6ab31cae1988be858f9f894dafe529c575d7:/src/smpi/mpi/smpi_keyvals.cpp diff --git a/src/smpi/mpi/smpi_keyvals.cpp b/src/smpi/mpi/smpi_keyvals.cpp index 559ef5c3c9..d22bbf205c 100644 --- a/src/smpi/mpi/smpi_keyvals.cpp +++ b/src/smpi/mpi/smpi_keyvals.cpp @@ -1,10 +1,10 @@ -/* Copyright (c) 2007-2017. The SimGrid Team. +/* Copyright (c) 2007-2019. 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 "private.h" +//#include "private.hpp" #include "smpi_keyvals.hpp" namespace simgrid{ @@ -14,32 +14,35 @@ std::unordered_map* Keyval::attributes(){ return &attributes_; }; - -template <> int Keyval::call_deleter(Comm* obj, smpi_key_elem elem, int keyval, void * value, int* flag){ - if(elem->delete_fn.comm_delete_fn!=MPI_NULL_DELETE_FN){ - int ret = elem->delete_fn.comm_delete_fn(obj, keyval, value, flag); - if(ret!=MPI_SUCCESS) - return ret; - } - return MPI_SUCCESS; +template <> int Keyval::call_deleter(Comm* obj, smpi_key_elem elem, int keyval, void* value, int* /*flag*/) +{ + int ret = MPI_SUCCESS; + if(elem->delete_fn.comm_delete_fn!=MPI_NULL_DELETE_FN) + ret = elem->delete_fn.comm_delete_fn(obj, keyval, value, elem->extra_state); + else if(elem->delete_fn.comm_delete_fn_fort!=MPI_NULL_DELETE_FN) + elem->delete_fn.comm_delete_fn_fort(obj, keyval, value, elem->extra_state, &ret); + return ret; } -template <> int Keyval::call_deleter(Win* obj, smpi_key_elem elem, int keyval, void * value, int* flag){ - if(elem->delete_fn.win_delete_fn!=MPI_NULL_DELETE_FN){ - int ret = elem->delete_fn.win_delete_fn(obj, keyval, value, flag); - if(ret!=MPI_SUCCESS) - return ret; - } - return MPI_SUCCESS; +template <> int Keyval::call_deleter(Win* obj, smpi_key_elem elem, int keyval, void* value, int* /*flag*/) +{ + int ret = MPI_SUCCESS; + if(elem->delete_fn.win_delete_fn!=MPI_NULL_DELETE_FN) + ret = elem->delete_fn.win_delete_fn(obj, keyval, value, elem->extra_state); + else if(elem->delete_fn.win_delete_fn_fort!=MPI_NULL_DELETE_FN) + elem->delete_fn.win_delete_fn_fort(obj, keyval, value, elem->extra_state, &ret); + return ret; } -template <> int Keyval::call_deleter(Datatype* obj, smpi_key_elem elem, int keyval, void * value, int* flag){ - if(elem->delete_fn.type_delete_fn!=MPI_NULL_DELETE_FN){ - int ret = elem->delete_fn.type_delete_fn(obj, keyval, value, flag); - if(ret!=MPI_SUCCESS) - return ret; - } - return MPI_SUCCESS; +template <> +int Keyval::call_deleter(Datatype* obj, smpi_key_elem elem, int keyval, void* value, int* /*flag*/) +{ + int ret = MPI_SUCCESS; + if(elem->delete_fn.type_delete_fn!=MPI_NULL_DELETE_FN) + ret = elem->delete_fn.type_delete_fn(obj, keyval, value, elem->extra_state); + else if(elem->delete_fn.type_delete_fn_fort!=MPI_NULL_DELETE_FN) + elem->delete_fn.type_delete_fn_fort(obj, keyval, value, elem->extra_state, &ret); + return ret; } }