1 /* Copyright (c) 2007-2022. The SimGrid Team.
2 * All rights reserved. */
4 /* This program is free software; you can redistribute it and/or modify it
5 * under the terms of the license (GNU LGPL) which comes with this package. */
7 #include "smpi_keyvals.hpp"
8 #include "xbt/sysdep.h"
13 template <> int Keyval::call_deleter<Comm>(Comm* obj, const smpi_key_elem& elem, int keyval, void* value, int* /*flag*/)
15 int ret = MPI_SUCCESS;
16 if (elem.delete_fn.comm_delete_fn != MPI_NULL_DELETE_FN)
17 ret = elem.delete_fn.comm_delete_fn(obj, keyval, value, elem.extra_state);
18 else if (elem.delete_fn.comm_delete_fn_fort != MPI_NULL_DELETE_FN)
19 elem.delete_fn.comm_delete_fn_fort(obj, keyval, value, elem.extra_state, &ret);
25 template <> int Keyval::call_deleter<Win>(Win* obj, const smpi_key_elem& elem, int keyval, void* value, int* /*flag*/)
27 int ret = MPI_SUCCESS;
28 if (elem.delete_fn.win_delete_fn != MPI_NULL_DELETE_FN)
29 ret = elem.delete_fn.win_delete_fn(obj, keyval, value, elem.extra_state);
30 else if (elem.delete_fn.win_delete_fn_fort != MPI_NULL_DELETE_FN)
31 elem.delete_fn.win_delete_fn_fort(obj, keyval, value, elem.extra_state, &ret);
38 int Keyval::call_deleter<Datatype>(Datatype* obj, const smpi_key_elem& elem, int keyval, void* value, int* /*flag*/)
40 int ret = MPI_SUCCESS;
41 if (elem.delete_fn.type_delete_fn != MPI_NULL_DELETE_FN)
42 ret = elem.delete_fn.type_delete_fn(obj, keyval, value, elem.extra_state);
43 else if (elem.delete_fn.type_delete_fn_fort != MPI_NULL_DELETE_FN)
44 elem.delete_fn.type_delete_fn_fort(obj, keyval, value, elem.extra_state, &ret);