jeudi 26 février 2015

C++ default copy/move assignment operator for extern C structure not const

I have a std::map<CXCursor, DeclarationContent> from which I want to remove elements using std::remove_if.


CXCursor is a (typedef of a) struct in external C code (libClang) that I cannot / must not modify.


Error messages from clang++ 3.4.2 --std=c++11 :



stl_pair.h:170:8: error: no viable overloaded '='
stl_algo.h:1152:23: note: in instantiation of member function std::pair<const CXCursor, DeclarationContent>::operator=' requested here

extract.cc:34:8: in instantiation of function template specialization 'std::remove_if<std::_Rb_tree_iterator<std::pair<const CXCursor, DeclarationContent> >, bool (*)(std::pair<const CXCursor, DeclarationContent> &)>' requested here
std::remove_if(decls.begin(), decls.end(), noCodeGenerationRequested);

include/clang-c/Index.h:2137:9: note: candidate function (the implicit copy assignment operator) not viable:
'this' argument has type 'const CXCursor', but method is not marked const

/include/clang-c/Index.h:2137:9: note: candidate function (the implicit move assignment operator) not viable:
'this' argument has type 'const CXCursor', but method is not marked const


The code is basically:



std::map<CXCursor, DeclarationContent> decls;
// filling the map
std::remove_if(decls.begin(), decls.end(), noCodeGenerationRequested);


with



bool noCodeGenerationRequested(std::map<CXCursor, DeclarationContent>::value_type & v)
{ /* FUN GOES HERE */ return true; }


From reading the error message it seems that the implicit assignment operators are not const qualified, which is needed in case of a map (as it's key is always const).


I could write a wrapper class around CXCursor that provides those assignment operators, but maybe there is another way?


Aucun commentaire:

Enregistrer un commentaire