En fait, j'ai un problème avec la compilation d'une bibliothèque avec un compilateur intel.Problème de modèles ('typename' en tant que paramètre de fonction non template)
Cette même bibliothèque a été compilée correctement avec g ++.
Un problème est dû aux modèles. Ce que je voudrais comprendre est la déclaration de **typename**
ne pas paramètre de fonction modèle et la déclaration variable dans le corps de la fonction
exemple:
void func(typename sometype){..
...
typename some_other_type;
..
}
Compilation ce genre de produits de code erreurs suivantes (intel), (gcc ne prétend pas): J'ai des erreurs suivantes
../../../libs/log/src/attribute_set.cpp(415): error: no operator "!=" matches these operands
operand types are: boost::log_st::basic_attribute_set<wchar_t>::iter<'\000'> != boost::log_st::basic_attribute_set<wchar_t>::iter<'\000'>
while (begin != end)
^
detected during instantiation of "void boost::log_st::basic_attribute_set<CharT>::erase(boost::log_st::basic_attribute_set<CharT>::iter<'\000'>, boost::log_st::basic_attribute_set<CharT>::iter<'\000'>) [with CharT=wchar_t]" at line 438
../../../boost/log/attributes/attribute_set.hpp(115): error: no operator "!=" matches these operands
operand types are: boost::log_st::basic_attribute_set<wchar_t>::iter<'\000'> != boost::log_st::basic_attribute_set<wchar_t>::iter<'\000'>
if (it != m_pContainer->end())
Ce que je voudrais comprendre est l'utilisation de la typename à l'intérieur du BOD y de fonctions, déclarations de paramètres.
ex .:
template< typename CharT >
struct basic_attribute_values_view<CharT>::implementation
{
public:
..
..
void adopt_nodes(**typename attribu**te_set_type::const_iterator& it, **typename attribut**e_set_type::const_iterator end)
{
for (; it != end; ++it)
push_back(it->first, it->second.get());
}
dans un fichier différent j'ai:
template< typename CharT >
class basic_attribute_set
{
friend class basic_attribute_values_view<CharT>;
//! Self type
typedef basic_attribute_set<CharT> this_type;
public:
//! Character type
typedef CharT char_type;
//! String type
typedef std::basic_string<char_type> string_type;
//! Key type
typedef basic_slim_string<char_type> key_type;
//! Mapped attribute type
typedef shared_ptr<attribute> mapped_type;
//! Value type
typedef std::pair< const key_type, mapped_type > value_type;
//! Allocator type
typedef std::allocator<value_type> allocator_type;
//! Reference type
**typedef typename allocator_type::reference reference;**
Ce serait plus facile ... si nous avions le code qui a généré l'erreur du compilateur (avec les lignes incriminées indiquées). Notez que l'utilisation de '**' pour la syntaxe ne fonctionne pas dans les blocs de code. –
Toutes les actions iterator! = Dans mon exemple produisent des erreurs simmilar, donc ce serait la ligne (it! = End;) dans mon premier exemple de code. – bua