Envoyé par
gbdivers
Bienvenue dans le troisième article de la série « le C++ expressif », une série d'articles consacrés aux Domain-Specific Embedded Language (DSEL) et à Boost.Proto, une bibliothèque pour les implémenter en C++.
Dans cet article, Eric Niebler aborde le problème délicat des messages d'erreurs générés par les templates et surtout le fait que ce n'est pas une fatalité. Il insiste en particulier sur le fait qu'il est de la responsabilités des concepteurs de bibliothèques de faire en sorte que les messages d'erreurs soient compréhensibles par les utilisateurs.
Le C++ expressif n° 3 : pourquoi les erreurs des templates posent des problèmes et qu'est-ce que vous pouvez faire pour ça ? Pensez-vous que la compléxité de message d'erreurs générés par les templates sont un frein à leurs utilisation ?
Quelles techniques utilisez-vous pour générer des messages d'erreurs compréhensibles ?Retrouvez l'ensemble des articles de la série « Le C++ expressif » sur la
page d'index.
Pensez-vous que la compléxité de message d'erreurs générés par les templates sont un frein à leurs utilisation ?
100 fois OUI.
Une erreur dans l'usage d'un template avec G++ va générer des dizaines de lignes d'erreurs, qui dépassent largement les 80 caractères. Comprendre: il faut scroller, et pas qu'un peu.
Sachant que la plus grosse partie de ces fameuses erreurs résulte dans le fait d'afficher les paramètres de chaque template. Y compris ceux par défaut (qu'on à donc pas changé et donc dont on se cogne).
Exemple concret:
std::unique_ptr prends 2 paramètres: le type, et la fonction de nettoyage. La fonction de nettoyage par défaut utilisant elle-même un type template utilisant le 1er template, on se retrouve vite avec un truc immonde et illisible.
Idem pour les implémentations, elles sont généralement proprement imbuvables, même si à force je commence à comprendre vaguement comment ça marche.
Bon, c'est sûr, une fois que c'est compilé, ça marche bien...
Quelles techniques utilisez-vous pour générer des messages d'erreurs compréhensibles ?
A la main malheureusement: je copie le message d'erreur et je vire tous les paramètres auxquels je n'ai pas touchés dans le code. Ca divise la taille du message par 3 minimum et c'est directement plus lisible.
Mais je vais lire cet article et voir si le résultat est bon. Si c'est le cas, je me ferais un plaisir d'oublier ma vieille "méthode"...
[edit]
C'est le petit tiret [...]
ça s'appelle une tilde.
Suggestions:
Remplacer les occurrences de C++0x par C++11
même si vu que c'est une traduction d'un article pré-C++11, il est logique de conserver C++0x.
Le lien vers "l'article précédent" renvoie à la description de l'article. Boucle infinie neuronale? Bon, certes, cette description contiens un lien vers une sorte de sommaire, mais bon, tant qu'a faire, autant faire un vrai lien, ou ne pas mettre de lien à ce moment la.
0 |
0 |