X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b8df87e176f27b25534f27d7e240defa32ca35bc..2df88396d94796a341f1dbaa1d41f3162745d927:/src/smpi/include/smpi_keyvals.hpp diff --git a/src/smpi/include/smpi_keyvals.hpp b/src/smpi/include/smpi_keyvals.hpp index e94c01f3d7..a23be10fa3 100644 --- a/src/smpi/include/smpi_keyvals.hpp +++ b/src/smpi/include/smpi_keyvals.hpp @@ -49,7 +49,9 @@ class Keyval{ // Each subclass should have two members, as we want to separate the ones for Win, Comm, and Datatypes : // static std::unordered_map keyvals_; // static int keyval_id_; - template static int keyval_create(smpi_copy_fn copy_fn, smpi_delete_fn delete_fn, int* keyval, void* extra_statee); + template + static int keyval_create(const smpi_copy_fn& copy_fn, const smpi_delete_fn& delete_fn, int* keyval, + void* extra_state); template static int keyval_free(int* keyval); template int attr_delete(int keyval); template int attr_get(int keyval, void* attr_value, int* flag); @@ -58,8 +60,9 @@ class Keyval{ template void cleanup_attr(); }; -template int Keyval::keyval_create(smpi_copy_fn copy_fn, smpi_delete_fn delete_fn, int* keyval, void* extra_state){ - +template +int Keyval::keyval_create(const smpi_copy_fn& copy_fn, const smpi_delete_fn& delete_fn, int* keyval, void* extra_state) +{ smpi_key_elem value = new s_smpi_key_elem_t; value->copy_fn=copy_fn; @@ -155,7 +158,7 @@ template void Keyval::cleanup_attr(){ call_deleter((T*)this, elem, it.first,it.second,&flag); } } else { - //already deleted, not a problem; + // already deleted, not a problem flag=0; } }