[gtkmm-documentation] New french translation
- From: Bruno Brouard <bbrouard src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtkmm-documentation] New french translation
- Date: Thu, 16 Dec 2010 16:46:10 +0000 (UTC)
commit 775eedeeceef0429cbafaef2fef10eb0a7a87d10
Author: Bruno Brouard <annoa b gmail com>
Date: Thu Dec 16 17:45:20 2010 +0100
New french translation
Contributed by Gérard Baylard <Geodebay gmail com>
and Bruno Brouard <annoa b gmail com>
docs/tutorial/Makefile.am | 2 +-
docs/tutorial/fr/fr.po |16183 +++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 16184 insertions(+), 1 deletions(-)
---
diff --git a/docs/tutorial/Makefile.am b/docs/tutorial/Makefile.am
index 82243a8..53cac5f 100644
--- a/docs/tutorial/Makefile.am
+++ b/docs/tutorial/Makefile.am
@@ -89,7 +89,7 @@ DOC_FIGURES = \
figures/treeview_tree.png \
figures/update_ui.png
-DOC_LINGUAS = de es sl zh_CN
+DOC_LINGUAS = de es fr sl zh_CN
MAINTAINERCLEANFILES = html/*.html $(srcdir)/html/*.html
diff --git a/docs/tutorial/fr/fr.po b/docs/tutorial/fr/fr.po
new file mode 100644
index 0000000..401d6fa
--- /dev/null
+++ b/docs/tutorial/fr/fr.po
@@ -0,0 +1,16183 @@
+# French translation for gtkmm-documentation.
+# Copyright (C) 2010 gtkmm-documentation's COPYRIGHT HOLDER
+# This file is distributed under the same license as the gtkmm-documentation package.
+# Gérard Baylard <Geodebay gmail com>, 2010.
+# Bruno Brouard <annoa b gmail com>, 2010
+msgid ""
+msgstr ""
+"Project-Id-Version: gtkmm-documentation master\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2010-12-08 11:17+0000\n"
+"PO-Revision-Date: 2010-10-13 18:58+0200\n"
+"Last-Translator: Gérard Baylard <Geodebay gmail com>\n"
+"Language-Team: français <GNOME French Team <gnomefr traduc org>>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"Plural-Forms: nplurals=2; plural=(n > 1);\n"
+
+#: C/gtkmm-tutorial-in.xml:34(title)
+msgid "Programming with <application>gtkmm</application>"
+msgstr "Programmation avec <application>gtkmm</application>"
+
+#: C/gtkmm-tutorial-in.xml:38(firstname)
+msgid "Murray"
+msgstr "Murray"
+
+#: C/gtkmm-tutorial-in.xml:39(surname)
+msgid "Cumming"
+msgstr "Cumming"
+
+#: C/gtkmm-tutorial-in.xml:42(firstname)
+msgid "Bernhard"
+msgstr "Bernhard"
+
+#: C/gtkmm-tutorial-in.xml:43(surname)
+msgid "Rieder"
+msgstr "Rieder"
+
+#: C/gtkmm-tutorial-in.xml:44(contrib)
+msgid "Chapter on \"Timeouts\"."
+msgstr "Chapitre « Fonctions à délai échu »."
+
+#: C/gtkmm-tutorial-in.xml:47(firstname)
+msgid "Jonathon"
+msgstr "Jonathon"
+
+#: C/gtkmm-tutorial-in.xml:48(surname)
+msgid "Jongsma"
+msgstr "Jongsma"
+
+#: C/gtkmm-tutorial-in.xml:49(contrib)
+msgid "Chapter on \"Drawing with Cairo\"."
+msgstr "Chapitre « Tracés avec Cairo »."
+
+#: C/gtkmm-tutorial-in.xml:50(contrib)
+msgid "Chapter on \"Working with gtkmm's Source Code\"."
+msgstr "Chapitre « Travail sur le code source de gtkmm »"
+
+#: C/gtkmm-tutorial-in.xml:51(contrib)
+msgid "Chapter on \"Recent Files\"."
+msgstr "Chapitre « Documents récents »."
+
+#: C/gtkmm-tutorial-in.xml:54(firstname)
+msgid "Ole"
+msgstr "Ole"
+
+#: C/gtkmm-tutorial-in.xml:55(surname)
+msgid "Laursen"
+msgstr "Laursen"
+
+#: C/gtkmm-tutorial-in.xml:56(contrib) C/gtkmm-tutorial-in.xml:72(contrib)
+msgid "Parts of chapter on \"Internationalization\"."
+msgstr "Parties du chapitre « Internationalisation »."
+
+#: C/gtkmm-tutorial-in.xml:59(firstname)
+msgid "Gene"
+msgstr "Gene"
+
+#: C/gtkmm-tutorial-in.xml:60(surname)
+msgid "Ruebsamen"
+msgstr "Ruebsamen"
+
+#: C/gtkmm-tutorial-in.xml:61(contrib) C/gtkmm-tutorial-in.xml:66(contrib)
+msgid "Chapter on \"Win32 Installation\"."
+msgstr "Chapitre « Installation sur Win32 »."
+
+#: C/gtkmm-tutorial-in.xml:64(firstname)
+msgid "Cedric"
+msgstr "Cedric"
+
+#: C/gtkmm-tutorial-in.xml:65(surname)
+msgid "Gustin"
+msgstr "Gustin"
+
+#: C/gtkmm-tutorial-in.xml:69(firstname)
+msgid "Marko"
+msgstr "Marko"
+
+#: C/gtkmm-tutorial-in.xml:70(surname)
+msgid "Anastasov"
+msgstr "Anastasov"
+
+#: C/gtkmm-tutorial-in.xml:71(contrib)
+msgid "Chapter on \"Printing\"."
+msgstr "Chapitre « Impression »."
+
+#: C/gtkmm-tutorial-in.xml:75(firstname)
+msgid "Daniel"
+msgstr "Daniel"
+
+#: C/gtkmm-tutorial-in.xml:76(surname)
+msgid "Elstner"
+msgstr "Elstner"
+
+#: C/gtkmm-tutorial-in.xml:77(contrib)
+msgid ""
+"Section \"Build Structure\" of chapter on \"Wrapping C Libraries with gmmproc"
+"\"."
+msgstr ""
+"Section « Structure de construction » du chapitre « Habillage des "
+"bibliothèques C avec gmmproc »."
+
+#. This text is copied from the introduction.
+#: C/gtkmm-tutorial-in.xml:85(para)
+msgid ""
+"This book explains key concepts of the <application>gtkmm</application> C++ "
+"API for creating user interfaces. It also introduces the main user interface "
+"elements (\"widgets\")."
+msgstr ""
+"Cet ouvrage explicite les concepts-clés de l'API C++ <application>gtkmm</"
+"application> pour la création d'interfaces utilisateur. Il présente "
+"également les principaux éléments graphiques d'interfaçage utilisateur "
+"(« widgets » en anglais, « contrôles » ou « éléments graphiques » en français)."
+
+#: C/gtkmm-tutorial-in.xml:91(year)
+msgid "2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010"
+msgstr "2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010"
+
+#: C/gtkmm-tutorial-in.xml:92(holder)
+msgid "Murray Cumming"
+msgstr "Murray Cumming"
+
+#: C/gtkmm-tutorial-in.xml:96(para)
+msgid ""
+"Permission is granted to copy, distribute and/or modify this document under "
+"the terms of the GNU Free Documentation License, Version 1.2 or any later "
+"version published by the Free Software Foundation; with no Invariant "
+"Sections, no Front-Cover Texts, and no Back-Cover Texts. You may obtain a "
+"copy of the GNU Free Documentation License from the Free Software Foundation "
+"by visiting their Web site or by writing to: Free Software Foundation, Inc., "
+"59 Temple Place - Suite 330, Boston, MA 02111-1307, USA."
+msgstr ""
+"Permission vous est donnée de copier, distribuer et/ou modifier ce document "
+"selon les termes de la licence de documentation libre GNU, Version 1.2 ou "
+"ultérieure publiée par la Free Software Foundation sans section inaltérable, "
+"sans texte de première page de couverture ni texte de dernière page de "
+"couverture. Vous pouvez obtenir un exemplaire de cette licence en visitant "
+"le site Web de cette organisation ou en écrivant à  : Free Software "
+"Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA."
+
+#: C/gtkmm-tutorial-in.xml:108(title)
+msgid "Introduction"
+msgstr "Introduction"
+
+#: C/gtkmm-tutorial-in.xml:111(title)
+msgid "This book"
+msgstr "Cet ouvrage"
+
+#: C/gtkmm-tutorial-in.xml:113(para)
+msgid ""
+"This book explains key concepts of the <application>gtkmm</application> C++ "
+"API for creating user interfaces. It also introduces the main user interface "
+"elements (\"widgets\"). Although it mentions classes, constructors, and "
+"methods, it does not go into great detail. Therefore, for full API "
+"information you should follow the links into the reference documentation."
+msgstr ""
+"Cet ouvrage explicite les concepts-clés de l'API C++ <application>gtkmm</"
+"application> pour la création d'interfaces utilisateur. Il présente "
+"également les principaux éléments graphiques de l'interfaçage utilisateur "
+"(« widgets » en anglais, « contrôles » ou « éléments graphiques » en français). "
+"Même s'il est fait mention de classes, de constructeurs et de fonctions "
+"membres, ces concepts ne sont pas examinés en détail. Par conséquent, pour "
+"une information complète sur l'API, il conviendra de vous reporter à la "
+"documentation de référence."
+
+#: C/gtkmm-tutorial-in.xml:115(para)
+msgid ""
+"This book assumes a good understanding of C++, and how to create C++ "
+"programs."
+msgstr ""
+"Cet ouvrage suppose une bonne connaissance du C++, ainsi que des méthodes de "
+"création de programmes avec ce langage."
+
+#: C/gtkmm-tutorial-in.xml:117(para)
+msgid ""
+"We would very much like to hear of any problems you have learning "
+"<application>gtkmm</application> with this document, and would appreciate "
+"input regarding improvements. Please see the <link linkend=\"chapter-"
+"contributing\">Contributing</link> section for further information."
+msgstr ""
+"Nous souhaitons vivement que vous nous rapportiez tout problème rencontré "
+"dans l'apprentissage de <application>gtkmm</application> avec ce document ; "
+"cela nous permet d'y apporter des améliorations en conséquence. Veuillez "
+"vous reporter au chapitre <link linkend=\"chapter-contributing"
+"\">Contribution</link> pour plus d'informations."
+
+#: C/gtkmm-tutorial-in.xml:124(title)
+msgid "gtkmm"
+msgstr "gtkmm"
+
+#: C/gtkmm-tutorial-in.xml:125(para)
+msgid ""
+"<application>gtkmm</application> is a C++ wrapper for <ulink url=\"http://"
+"www.gtk.org/\">GTK+</ulink>, a library used to create graphical user "
+"interfaces. It is licensed using the LGPL license, so you can develop open "
+"software, free software, or even commercial non-free software using "
+"<application>gtkmm</application> without purchasing licenses."
+msgstr ""
+"<application>gtkmm</application> est un habillage (« wrapper ») C++ pour "
+"<ulink url=\"http://www.gtk.org/\">GTK+</ulink>, une bibliothèque servant "
+"elle-même à créer des interfaces utilisateur graphique. <application>gtkmm</"
+"application> est sous licence LGPL : vous pouvez donc développer des "
+"logiciels ouverts, des logiciels libres ou même des logiciels commerciaux "
+"non-libres sans acheter de licence."
+
+#: C/gtkmm-tutorial-in.xml:133(para)
+msgid ""
+"<application>gtkmm</application> was originally named gtk-- because GTK+ "
+"already has a + in the name. However, as -- is not easily indexed by search "
+"engines the package generally went by the name <application>gtkmm</"
+"application>, and that's what we stuck with."
+msgstr ""
+"� l'origine <application>gtkmm</application> s'appelait « gtk-- » étant donné "
+"que GTK+ avait déjà un signe « + » dans le nom. Mais, comme « -- » n'est pas "
+"facilement indexé par les moteurs de recherche, le paquet logiciel a "
+"couramment été désigné par <application>gtkmm</application> et c'est ainsi "
+"que nous le désignerons dans la suite."
+
+#: C/gtkmm-tutorial-in.xml:136(title)
+msgid "Why use <application>gtkmm</application> instead of GTK+?"
+msgstr "Pourquoi utiliser <application>gtkmm</application> plutôt que GTK+ ?"
+
+#: C/gtkmm-tutorial-in.xml:137(para)
+msgid ""
+"<application>gtkmm</application> allows you to write code using normal C++ "
+"techniques such as encapsulation, derivation, and polymorphism. As a C++ "
+"programmer you probably already realise that this leads to clearer and "
+"better organized code."
+msgstr ""
+"<application>gtkmm</application> vous permet d'écrire du code en se servant "
+"des techniques habituelles du C++ telles que l'encapsulation, la dérivation "
+"et le polymorphisme. En tant que programmeur C++, vous avez probablement "
+"déjà perçu que ces possibilités conduisent à un code plus clair et mieux "
+"organisé."
+
+#: C/gtkmm-tutorial-in.xml:138(para)
+msgid ""
+"<application>gtkmm</application> is more type-safe, so the compiler can "
+"detect errors that would only be detected at run time when using C. This use "
+"of specific types also makes the API clearer because you can see what types "
+"should be used just by looking at a method's declaration."
+msgstr ""
+"<application>gtkmm</application> possède une sécurité améliorée pour la "
+"typologie des données ; le compilateur détecte donc des erreurs qui ne "
+"seraient apparues qu'au moment de l'exécution en C. L'utilisation de ces "
+"types spécifiques rend l'API plus claire puisque vous pouvez voir les types "
+"à utiliser à la simple lecture de la déclaration d'une fonction membre."
+
+#: C/gtkmm-tutorial-in.xml:139(para)
+msgid ""
+"Inheritance can be used to derive new widgets. The derivation of new widgets "
+"in GTK+ C code is so complicated and error prone that almost no C coders do "
+"it. As a C++ developer you know that derivation is an essential Object "
+"Orientated technique."
+msgstr ""
+"L'héritage s'utilise pour dériver de nouveaux éléments graphiques. Dans un "
+"code C de GTK+, ce processus de dérivation est si complexe et sujet à erreur "
+"que quasiment aucun programmeur C ne l'utilise. En tant que développeur C++, "
+"vous savez que la dérivation est une technique essentielle dans la "
+"programmation orientée objet."
+
+#: C/gtkmm-tutorial-in.xml:140(para)
+msgid ""
+"Member instances can be used, simplifying memory management. All GTK+ C "
+"widgets are dealt with by use of pointers. As a C++ coder you know that "
+"pointers should be avoided where possible."
+msgstr ""
+"L'utilisation des instances membres simplifie la gestion de la mémoire. Tous "
+"les éléments graphiques C de GTK+ sont traités en utilisant des pointeurs. "
+"Vous savez, comme tout programmeur C++, que les pointeurs doivent, si "
+"possible, être évités."
+
+#: C/gtkmm-tutorial-in.xml:141(para)
+msgid ""
+"<application>gtkmm</application> involves less code compared to GTK+, which "
+"uses prefixed function names and lots of cast macros."
+msgstr ""
+"Comparé à GTK+, avec l'utilisation des noms de fonctions préfixés et de "
+"nombreuses macros de forçage de type, <application>gtkmm</application> "
+"nécessite moins de code."
+
+#: C/gtkmm-tutorial-in.xml:145(title)
+msgid "<application>gtkmm</application> compared to Qt"
+msgstr ""
+"<application>gtkmm</application> comparée à <application>Qt</application>"
+
+#: C/gtkmm-tutorial-in.xml:146(para)
+msgid ""
+"Trolltech's Qt is the closest competition to <application>gtkmm</"
+"application>, so it deserves discussion."
+msgstr ""
+"Qt de Trolltech est le plus proche concurrent de <application>gtkmm</"
+"application> ; cela mérite une explication."
+
+#: C/gtkmm-tutorial-in.xml:148(para)
+msgid ""
+"<application>gtkmm</application> developers tend to prefer "
+"<application>gtkmm</application> to Qt because <application>gtkmm</"
+"application> does things in a more C++ way. Qt originates from a time when C+"
+"+ and the standard library were not standardised or well supported by "
+"compilers. It therefore duplicates a lot of stuff that is now in the "
+"standard library, such as containers and type information. Most "
+"significantly, Trolltech modified the C++ language to provide signals, so "
+"that Qt classes cannot be used easily with non-Qt classes. "
+"<application>gtkmm</application> was able to use standard C++ to provide "
+"signals without changing the C++ language. See the FAQ for more detailed "
+"differences."
+msgstr ""
+"Les développeurs inclinent à préférer <application>gtkmm</application> à Qt, "
+"car <application>gtkmm</application> fait les choses d'une façon plus proche "
+"du C++. Qt est né à une époque où le C++ et les bibliothèques standard "
+"n'étaient, ni normalisées, ni bien prises en charge par les compilateurs. "
+"Ainsi, nombre de choses, aujourd'hui dans la bibliothèque normalisée, sont "
+"en double, comme les conteneurs et des définitions de types. Plus "
+"significatif encore, Trolltech a modifié le langage C++ afin de fournir des "
+"signaux, de sorte que les classes Qt ne se marient pas facilement avec des "
+"classes non-Qt. <application>gtkmm</application> a été capable d'utiliser du "
+"C++ standard sans modification pour fournir des signaux sans modification du "
+"langage C++. Consultez la foire aux questions pour plus de précisions."
+
+#: C/gtkmm-tutorial-in.xml:152(title)
+msgid "<application>gtkmm</application> is a wrapper"
+msgstr "<application>gtkmm</application> est un habillage"
+
+#: C/gtkmm-tutorial-in.xml:153(para)
+msgid ""
+"<application>gtkmm</application> is not a native C++ toolkit, but a C++ "
+"wrapper of a C toolkit. This separation of interface and implementation has "
+"advantages. The <application>gtkmm</application> developers spend most of "
+"their time talking about how <application>gtkmm</application> can present "
+"the clearest API, without awkward compromises due to obscure technical "
+"details. We contribute a little to the underlying GTK+ code base, but so do "
+"the C coders, and the Perl coders and the Python coders, etc. Therefore GTK+ "
+"benefits from a broader user base than language-specific toolkits - there "
+"are more implementers, more developers, more testers, and more users."
+msgstr ""
+"<application>gtkmm</application> n'est pas une boîte à outils en C++ natif, "
+"mais un habillage C++ d'une boîte à outils en C. Cette séparation entre "
+"interface et implémentation a des avantages. Les développeurs "
+"<application>gtkmm</application> passent la majeure partie de leur temps à "
+"discuter de la manière dont <application>gtkmm</application> peut présenter "
+"l'API la plus claire, sans compromis délicat en raison d'obscurs détails "
+"techniques. Nous contribuons un peu aux fondements du code GTK+ sous-jacent, "
+"mais les codeurs en C, Perl et Python, etc. font de même. Ainsi GTK+ "
+"bénéficie d'une base d'utilisateurs plus large que n'aurait une boîte à "
+"outils spécifique à un langage â?? il y a plus d'implémentations, plus de "
+"développeurs, plus de testeurs et plus d'utilisateurs."
+
+#: C/gtkmm-tutorial-in.xml:161(title)
+msgid "Installation"
+msgstr "Installation"
+
+#: C/gtkmm-tutorial-in.xml:163(title)
+msgid "Dependencies"
+msgstr "Dépendances"
+
+#: C/gtkmm-tutorial-in.xml:164(para)
+msgid ""
+"Before attempting to install <application>gtkmm</application> 2.4, you might "
+"first need to install these other packages."
+msgstr ""
+"Avant de procéder à l'installation de <application>gtkmm</application> 2.4, "
+"il se peut que vous ayez besoin d'installer au préalable d'autres paquets "
+"logiciels."
+
+#: C/gtkmm-tutorial-in.xml:169(application)
+msgid "libsigc++ 2.0"
+msgstr "libsigc++ 2.0"
+
+#: C/gtkmm-tutorial-in.xml:170(application)
+msgid "GTK+ 2.4"
+msgstr "GTK+ 2.4"
+
+#: C/gtkmm-tutorial-in.xml:171(application)
+msgid "cairomm"
+msgstr "cairomm"
+
+#: C/gtkmm-tutorial-in.xml:173(para)
+msgid ""
+"These dependencies have their own dependencies, including the following "
+"applications and libraries:"
+msgstr ""
+"Ces dépendances ont elles-mêmes leurs propres dépendances, comprenant les "
+"applications et bibliothèques suivantes :"
+
+#: C/gtkmm-tutorial-in.xml:178(application)
+msgid "pkg-config"
+msgstr "pkg-config"
+
+#: C/gtkmm-tutorial-in.xml:179(application)
+msgid "glib"
+msgstr "glib"
+
+#: C/gtkmm-tutorial-in.xml:180(application)
+msgid "ATK"
+msgstr "ATK"
+
+#: C/gtkmm-tutorial-in.xml:181(application)
+msgid "Pango"
+msgstr "Pango"
+
+#: C/gtkmm-tutorial-in.xml:182(application)
+msgid "cairo"
+msgstr "cairo"
+
+#: C/gtkmm-tutorial-in.xml:187(title)
+msgid "Unix and Linux"
+msgstr "Unix et Linux"
+
+#: C/gtkmm-tutorial-in.xml:190(title)
+msgid "Prebuilt Packages"
+msgstr "Paquets logiciels pré-compilés"
+
+#: C/gtkmm-tutorial-in.xml:192(para)
+msgid ""
+"Recent versions of <application>gtkmm</application> are packaged by nearly "
+"every major Linux distribution these days. So, if you use Linux, you can "
+"probably get started with <application>gtkmm</application> by installing the "
+"package from the official repository for your distribution. Distributions "
+"that include <application>gtkmm</application> in their repositories include "
+"Debian, Ubuntu, Red Hat, Fedora, Mandriva, Suse, and many others."
+msgstr ""
+"Les versions récentes de <application>gtkmm</application> sont empaquetées "
+"par pratiquement toutes les grandes distributions Linux. Donc, si vous êtes "
+"un utilisateur de Linux, vous pourrez probablement débuter avec "
+"<application>gtkmm</application> en installant son paquet à partir du dépôt "
+"officiel de votre distribution. Parmi les distributions qui mettent à "
+"disposition <application>gtkmm</application> dans leurs dépôts, citons "
+"Debian, Ubuntu, Red Hat, Fedora, Mandriva, Suse, mais il y en a beaucoup "
+"d'autres."
+
+#: C/gtkmm-tutorial-in.xml:200(para)
+msgid ""
+"The names of the <application>gtkmm</application> packages vary from "
+"distribution to distribution (e.g. <application>libgtkmm2.4-dev</"
+"application> on Debian and Ubuntu or <application>gtkmm24-devel</"
+"application> on Red Hat Fedora), so check with your distribution's package "
+"management program for the correct package name and install it like you "
+"would any other package."
+msgstr ""
+"Les noms des paquets <application>gtkmm</application> varient selon les "
+"distributions (par exemple, <application>libgtkmm2.4-dev</application> sur "
+"Debian et Ubuntu ou <application>gtkmm24-devel</application> sur Red Hat "
+"Fedora) ; vérifiez donc avec le programme de gestion de paquets de votre "
+"distribution la dénomination correcte, puis installez-le comme vous feriez "
+"pour tout autre paquet."
+
+#: C/gtkmm-tutorial-in.xml:208(para)
+msgid ""
+"The package names will not change when new API/ABI-compatible versions of "
+"<application>gtkmm</application> are released. Otherwise they would not be "
+"API/ABI-compatible. So don't be surprised, for instance, to find "
+"<application>gtkmm</application> 2.8 supplied by Debian's "
+"<application>libgtkmm2.4-dev</application> package."
+msgstr ""
+"Les noms des paquets ne changent pas quand de nouvelles versions de "
+"<application>gtkmm</application> compatibles API/ABI(Application Binary "
+"Interface) sont publiées. Si ce n'était pas le cas, elles ne seraient pas "
+"compatibles. Donc ne soyez pas surpris, par exemple, de trouver la version "
+"2.8 de <application>gtkmm</application> livrée dans le paquet "
+"<application>libgtkmm2.4-dev</application> par Debian."
+
+#: C/gtkmm-tutorial-in.xml:218(title)
+msgid "Installing From Source"
+msgstr "Installation à partir des sources"
+
+#: C/gtkmm-tutorial-in.xml:220(para)
+msgid ""
+"If your distribution does not provide a pre-built <application>gtkmm</"
+"application> package, or if you want to install a different version than the "
+"one provided by your distribution, you can also install <application>gtkmm</"
+"application> from source. The source code for <application>gtkmm</"
+"application> can be downloaded from <ulink url=\"http://www.gtkmm.org/\"/>."
+msgstr ""
+"Si votre distribution ne met pas à disposition un paquet pré-compilé de "
+"<application>gtkmm</application>, ou bien si vous souhaitez installer une "
+"version différente de celle fournie, vous pouvez installer "
+"<application>gtkmm</application> Ã partir des sources. Le code source de "
+"<application>gtkmm</application> est téléchargeable à partir de <ulink url="
+"\"http://www.gtkmm.org/\"/>."
+
+#: C/gtkmm-tutorial-in.xml:226(para)
+msgid ""
+"After you've installed all of the dependencies, download the "
+"<application>gtkmm</application> source code, unpack it, and change to the "
+"newly created directory. <application>gtkmm</application> can be built and "
+"installed with the following sequence of commands:"
+msgstr ""
+"Après installation de toutes les dépendances, téléchargez le code source de "
+"<application>gtkmm</application>, extrayez-le et déplacez vous dans le "
+"nouveau répertoire. <application>gtkmm</application> se construit et "
+"s'installe en saisissant cette suite de commandes :"
+
+#: C/gtkmm-tutorial-in.xml:231(screen)
+#, no-wrap
+msgid ""
+"\n"
+"# ./configure\n"
+"# make\n"
+"# make install\n"
+msgstr ""
+"\n"
+"# ./configure\n"
+"# make\n"
+"# make install\n"
+
+#: C/gtkmm-tutorial-in.xml:237(para)
+msgid ""
+"Remember that on a Unix or Linux operating system, you will probably need to "
+"be <literal>root</literal> to install software. The <command>su</command> "
+"command will allow you to enter the <literal>root</literal> password and "
+"have <literal>root</literal> status temporarily."
+msgstr ""
+"N'oubliez pas qu'avec un système d'exploitation Unix ou Linux, vous aurez "
+"besoin d'être <literal>root</literal> (avoir les privilèges administrateur) "
+"pour installer le logiciel. La commande <command>su</command> vous confère "
+"temporairement le statut d'administrateur après la saisie du mot de passe "
+"<literal>root</literal>."
+
+#: C/gtkmm-tutorial-in.xml:244(para)
+msgid ""
+"The <filename>configure</filename> script will check to make sure all of the "
+"required dependencies are already installed. If you are missing any "
+"dependencies, it will exit and display an error."
+msgstr ""
+"Le script <filename>configure</filename> effectue une vérification pour "
+"s'assurer que toutes les dépendances requises sont déjà installées. Si une "
+"quelconque manque, il s'arrête et affiche une erreur."
+
+#: C/gtkmm-tutorial-in.xml:249(para)
+msgid ""
+"By default, <application>gtkmm</application> will be installed under the "
+"<filename>/usr/local</filename> directory. On some systems you may need to "
+"install to a different location. For instance, on Red Hat Linux systems you "
+"might use the <literal>--prefix</literal> option with configure, like so: "
+"<screen>\n"
+"# ./configure --prefix=/usr\n"
+"</screen>"
+msgstr ""
+"Par défaut, <application>gtkmm</application> est installé dans le répertoire "
+"<filename>/usr/local</filename>. Sur certains systèmes, il sera peut-être "
+"nécessaire de l'installer à un autre emplacement. Par exemple, sur les "
+"systèmes Linux Red Hat, vous utiliserez peut-être l'option <literal>--"
+"prefix</literal> avec configure, ainsi : <screen>\n"
+"# ./configure --prefix=/usr\n"
+"</screen>"
+
+#: C/gtkmm-tutorial-in.xml:260(para)
+msgid ""
+"You should be very careful when installing to standard system prefixes such "
+"as <filename>/usr</filename>. Linux distributions install software packages "
+"to <filename>/usr</filename>, so installing a source package to this prefix "
+"could corrupt or conflict with software installed using your distribution's "
+"package-management system. Ideally, you should use a separate prefix for all "
+"software you install from source."
+msgstr ""
+"Il faut être très précautionneux si vous faites une installation avec comme "
+"préfixe un des répertoires système standard, comme <filename>/usr</"
+"filename>. Les distributions Linux installent leurs paquets logiciels dans "
+"<filename>/usr</filename>Â ; donc, le fait d'installer un paquet source dans "
+"ce répertoire peut corrompre ou entrer en conflit avec un logiciel installé "
+"par le système de gestion des paquets de votre distribution. Dans un monde "
+"idéal, vous devriez utiliser un préfixe à part pour tous les logiciels "
+"installés à partir des sources."
+
+#: C/gtkmm-tutorial-in.xml:269(para)
+msgid ""
+"If you want to help develop <application>gtkmm</application> or experiment "
+"with new features, you can also install <application>gtkmm</application> "
+"from git. Most users will never need to do this, but if you're interested in "
+"helping with <application>gtkmm</application> development, see the <link "
+"linkend=\"chapter-working-with-source\">Working with gtkmm's Source Code</"
+"link> appendix."
+msgstr ""
+"Si vous souhaitez participer au développement de <application>gtkmm</"
+"application> ou expérimenter de nouvelles fonctionnalités, vous pouvez "
+"installer <application>gtkmm</application> à partir du dépôt « git ». La "
+"plupart des utilisateurs n'ont jamais besoin de faire ainsi, mais si vous "
+"êtes intéressé par une participation au développement de <application>gtkmm</"
+"application>, consultez l'annexe <link linkend=\"chapter-working-with-source"
+"\">Travail sur le code source de gtkmm</link>"
+
+#: C/gtkmm-tutorial-in.xml:280(title)
+msgid "Microsoft Windows"
+msgstr "Windows Microsoft"
+
+#: C/gtkmm-tutorial-in.xml:281(para)
+msgid ""
+"GTK+ and <application>gtkmm</application> were designed to work well with "
+"Microsoft Windows, and the developers encourage its use on the win32 "
+"platform. However, Windows has no standard installation system for "
+"development libraries. Please see the <ulink url=\"http://live.gnome.org/"
+"gtkmm/MSWindows\">Windows Installation</ulink> page for Windows-specific "
+"installation instructions and notes."
+msgstr ""
+"GTK+ et <application>gtkmm</application> ont été conçus pour bien "
+"fonctionner avec Windows Microsoft ; les développeurs poussent à son "
+"utilisation sur les plates-formes win32. Mais, Windows ne dispose d'aucune "
+"norme d'installation pour les bibliothèques de développement. Consultez les "
+"pages spécifiques relatives aux instructions et notes spécifiques à l'<ulink "
+"url=\"http://live.gnome.org/gtkmm/MSWindows\">Installation sous Windows</"
+"ulink>."
+
+#: C/gtkmm-tutorial-in.xml:288(title)
+msgid "Basics"
+msgstr "Fondamentaux"
+
+#: C/gtkmm-tutorial-in.xml:290(para)
+msgid ""
+"This chapter will introduce some of the most important aspects of "
+"<application>gtkmm</application> coding. These will be demonstrated with "
+"simple working example code. However, this is just a taster, so you need to "
+"look at the other chapters for more substantial information."
+msgstr ""
+"Ce chapitre présente quelques aspects parmi les plus importants du codage "
+"avec <application>gtkmm</application>. Nous les montrerons à partir "
+"d'exemples simples et fonctionnels de code. Ce n'est toutefois qu'un avant-"
+"goût et vous aurez besoin d'examiner les autres chapitres pour des "
+"informations plus conséquentes."
+
+#: C/gtkmm-tutorial-in.xml:293(para)
+msgid ""
+"Your existing knowledge of C++ will help you with <application>gtkmm</"
+"application> as it would with any library. Unless we state otherwise, you "
+"can expect <application>gtkmm</application> classes to behave like any other "
+"C++ class, and you can expect to use your existing C++ techniques with "
+"<application>gtkmm</application> classes."
+msgstr ""
+"Vos connaissances en matière de C++ vous seront d'un bon secours pour "
+"<application>gtkmm</application> comme pour toute autre bibliothèque. � "
+"moins que nous n'indiquions le contraire, vous pouvez vous attendre à ce que "
+"les classes <application>gtkmm</application> aient un comportement identique "
+"à celui des autres classes C++ et donc à utiliser vos techniques C++ "
+"habituelles avec elles."
+
+#: C/gtkmm-tutorial-in.xml:298(title) C/gtkmm-tutorial-in.xml:3341(title)
+msgid "Simple Example"
+msgstr "Un exemple simple"
+
+#: C/gtkmm-tutorial-in.xml:300(para)
+msgid ""
+"To begin our introduction to <application>gtkmm</application>, we'll start "
+"with the simplest program possible. This program will create an empty 200 x "
+"200 pixel window."
+msgstr ""
+"Comme entrée en matière avec <application>gtkmm</application>, nous "
+"débuterons avec le programme le plus simple qui soit. Ce programme crée une "
+"fenêtre vide de 200 x 200 pixels."
+
+#: C/gtkmm-tutorial-in.xml:305(ulink) C/gtkmm-tutorial-in.xml:482(ulink)
+#: C/gtkmm-tutorial-in.xml:698(ulink) C/gtkmm-tutorial-in.xml:806(ulink)
+#: C/gtkmm-tutorial-in.xml:915(ulink) C/gtkmm-tutorial-in.xml:1080(ulink)
+#: C/gtkmm-tutorial-in.xml:1134(ulink) C/gtkmm-tutorial-in.xml:1189(ulink)
+#: C/gtkmm-tutorial-in.xml:1236(ulink) C/gtkmm-tutorial-in.xml:1263(ulink)
+#: C/gtkmm-tutorial-in.xml:1288(ulink) C/gtkmm-tutorial-in.xml:1436(ulink)
+#: C/gtkmm-tutorial-in.xml:1502(ulink) C/gtkmm-tutorial-in.xml:1526(ulink)
+#: C/gtkmm-tutorial-in.xml:1601(ulink) C/gtkmm-tutorial-in.xml:1642(ulink)
+#: C/gtkmm-tutorial-in.xml:1687(ulink) C/gtkmm-tutorial-in.xml:1722(ulink)
+#: C/gtkmm-tutorial-in.xml:1761(ulink) C/gtkmm-tutorial-in.xml:1890(ulink)
+#: C/gtkmm-tutorial-in.xml:2018(ulink) C/gtkmm-tutorial-in.xml:2061(ulink)
+#: C/gtkmm-tutorial-in.xml:2220(ulink) C/gtkmm-tutorial-in.xml:2268(ulink)
+#: C/gtkmm-tutorial-in.xml:2308(ulink) C/gtkmm-tutorial-in.xml:2904(ulink)
+#: C/gtkmm-tutorial-in.xml:2923(ulink) C/gtkmm-tutorial-in.xml:2942(ulink)
+#: C/gtkmm-tutorial-in.xml:2964(ulink) C/gtkmm-tutorial-in.xml:2986(ulink)
+#: C/gtkmm-tutorial-in.xml:3059(ulink) C/gtkmm-tutorial-in.xml:3072(ulink)
+#: C/gtkmm-tutorial-in.xml:3106(ulink) C/gtkmm-tutorial-in.xml:3119(ulink)
+#: C/gtkmm-tutorial-in.xml:3350(ulink) C/gtkmm-tutorial-in.xml:3525(ulink)
+#: C/gtkmm-tutorial-in.xml:3538(ulink) C/gtkmm-tutorial-in.xml:3594(ulink)
+#: C/gtkmm-tutorial-in.xml:3852(ulink) C/gtkmm-tutorial-in.xml:3914(ulink)
+#: C/gtkmm-tutorial-in.xml:3941(ulink) C/gtkmm-tutorial-in.xml:3963(ulink)
+#: C/gtkmm-tutorial-in.xml:3986(ulink) C/gtkmm-tutorial-in.xml:4182(ulink)
+#: C/gtkmm-tutorial-in.xml:4279(ulink) C/gtkmm-tutorial-in.xml:4360(ulink)
+#: C/gtkmm-tutorial-in.xml:4528(ulink) C/gtkmm-tutorial-in.xml:4744(ulink)
+#: C/gtkmm-tutorial-in.xml:4904(ulink) C/gtkmm-tutorial-in.xml:4924(ulink)
+#: C/gtkmm-tutorial-in.xml:5302(ulink) C/gtkmm-tutorial-in.xml:5517(ulink)
+#: C/gtkmm-tutorial-in.xml:5651(ulink) C/gtkmm-tutorial-in.xml:5757(ulink)
+#: C/gtkmm-tutorial-in.xml:5854(ulink) C/gtkmm-tutorial-in.xml:5891(ulink)
+#: C/gtkmm-tutorial-in.xml:6242(ulink) C/gtkmm-tutorial-in.xml:6310(ulink)
+#: C/gtkmm-tutorial-in.xml:6926(ulink) C/gtkmm-tutorial-in.xml:6950(ulink)
+#: C/gtkmm-tutorial-in.xml:7699(ulink)
+msgid "Source Code"
+msgstr "Code source"
+
+#: C/gtkmm-tutorial-in.xml:307(para)
+msgid "We will now explain each line of the example"
+msgstr "Détaillons maintenant chaque ligne de l'exemple"
+
+#: C/gtkmm-tutorial-in.xml:308(programlisting)
+#, no-wrap
+msgid "#include <gtkmm.h>"
+msgstr "#include <gtkmm.h>"
+
+#: C/gtkmm-tutorial-in.xml:309(para)
+msgid ""
+"All <application>gtkmm</application> programs must include certain "
+"<application>gtkmm</application> headers; <literal>gtkmm.h</literal> "
+"includes the entire <application>gtkmm</application> kit. This is usually "
+"not a good idea, because it includes a megabyte or so of headers, but for "
+"simple programs, it suffices."
+msgstr ""
+"Tous les programmes <application>gtkmm</application> doivent inclure "
+"certains fichiers d'en-tête <application>gtkmm</application> ; "
+"<literal>gtkmm.h</literal> inclut la totalité du jeu d'en-têtes "
+"<application>gtkmm</application>. En règle générale, ce n'est pas une bonne "
+"idée parce que cette façon de faire inclut à peu près un mégaoctet d'en-"
+"têtes, mais pour des programmes simples, c'est acceptable."
+
+#: C/gtkmm-tutorial-in.xml:319(programlisting)
+#, no-wrap
+msgid "Gtk::Main kit(argc, argv);"
+msgstr "Gtk::Main kit(argc, argv);"
+
+#: C/gtkmm-tutorial-in.xml:316(para)
+msgid ""
+"The next line: <placeholder-1/> creates a <classname>Gtk::Main</classname> "
+"object. This is needed in all <application>gtkmm</application> applications. "
+"The constructor for this object initializes <application>gtkmm</"
+"application>, and checks the arguments passed to your application on the "
+"command line, looking for standard options such as <literal>-display</"
+"literal>. It takes these from the argument list, leaving anything it does "
+"not recognize for your application to parse or ignore. This ensures that all "
+"<application>gtkmm</application> applications accept the same set of "
+"standard arguments."
+msgstr ""
+"La ligne suivante : <placeholder-1/> crée un objet <classname>Gtk::Main</"
+"classname>, nécessaire pour toutes les applications <application>gtkmm</"
+"application>. Le constructeur de cet objet initialise <application>gtkmm</"
+"application> et vérifie les paramètres passés à l'application sur la ligne "
+"de commande. Il examine les options standard, comme <literal>-display</"
+"literal>, les enlève de la liste des paramètres en ne gardant que celles "
+"qu'il n'a pas reconnues pour un traitement éventuel par l'application. Cela "
+"garantit que toutes les applications <application>gtkmm</application> "
+"accepteront le même ensemble de paramètres normalisés."
+
+#: C/gtkmm-tutorial-in.xml:329(para)
+msgid "The next two lines of code create and display a window:"
+msgstr "Les deux lignes de code suivantes créent et affichent une fenêtre :"
+
+#: C/gtkmm-tutorial-in.xml:332(programlisting)
+#, no-wrap
+msgid "Gtk::Window window;"
+msgstr "Gtk::Window window;"
+
+#: C/gtkmm-tutorial-in.xml:333(para)
+msgid ""
+"The last line shows the window and enters the <application>gtkmm</"
+"application> main processing loop, which will finish when the window is "
+"closed."
+msgstr ""
+"La deuxième ligne affiche la fenêtre et entre dans la boucle principale de "
+"traitement, boucle dont on ne sort qu'à la fermeture de la fenêtre."
+
+#: C/gtkmm-tutorial-in.xml:337(programlisting)
+#, no-wrap
+msgid "Gtk::Main::run(window);"
+msgstr "Gtk::Main::run(window);"
+
+#: C/gtkmm-tutorial-in.xml:341(programlisting)
+#, no-wrap
+msgid "g++ simple.cc -o simple `pkg-config gtkmm-2.4 --cflags --libs`"
+msgstr "g++ simple.cc -o simple `pkg-config gtkmm-2.4 --cflags --libs`"
+
+#: C/gtkmm-tutorial-in.xml:339(para)
+msgid ""
+"After putting the source code in <literal>simple.cc</literal> you can "
+"compile the above program with gcc using: <placeholder-1/> Note that you "
+"must surround the <literal>pkg-config</literal> invocation with backquotes. "
+"Backquotes cause the shell to execute the command inside them, and to use "
+"the command's output as part of the command line."
+msgstr ""
+"Après avoir incorporé ces lignes de code source dans <literal>simple.cc</"
+"literal>, vous pouvez compiler ce programme avec la commande : <placeholder-"
+"1/> Notez qu'il est impératif d'entourer l'appel à <literal>pkg-config</"
+"literal> d'apostrophes inverses. Elles demandent à l'interpréteur de "
+"commandes d'exécuter la commande entourée et d'intégrer au même emplacement "
+"la sortie correspondante dans la ligne de commande."
+
+#: C/gtkmm-tutorial-in.xml:350(title)
+msgid "Headers and Linking"
+msgstr "Fichiers d'en-têtes et édition des liens "
+
+#: C/gtkmm-tutorial-in.xml:351(para)
+msgid ""
+"Although we have shown the compilation command for the simple example, you "
+"really should use the automake and autoconf tools, as described in "
+"\"Autoconf, Automake, Libtool\", by G. V. Vaughan et al. The examples used "
+"in this book are included in the <application>gtkmm</application> package, "
+"with appropriate build files, so we won't show the build commands in future. "
+"You'll just need to find the appropriate directory and type <literal>make</"
+"literal>."
+msgstr ""
+"Même si nous avons indiqué la commande de compilation pour cet exemple "
+"simple, vous devriez vraiment utiliser les outils <application>automake</"
+"application> et <application>autoconf</application> tels que décrits dans "
+"« Autoconf, Automake, Libtool » par G.V. Vaughan et autres. Les exemples "
+"utilisés dans le présent ouvrage sont incorporés dans le paquet logiciel de "
+"<application>gtkmm</application>, avec les fichiers de construction "
+"appropriés ; nous ne mentionnerons donc pas ces commandes dans le futur. Il "
+"conviendra simplement de trouver le répertoire convenable, de s'y placer et "
+"de saisir <literal>make</literal>."
+
+#: C/gtkmm-tutorial-in.xml:354(para)
+msgid ""
+"To simplify compilation, we use <literal>pkg-config</literal>, which is "
+"present in all (properly installed) <application>gtkmm</application> "
+"installations. This program 'knows' what compiler switches are needed to "
+"compile programs that use <application>gtkmm</application>. The <literal>--"
+"cflags</literal> option causes <literal>pkg-config</literal> to output a "
+"list of include directories for the compiler to look in; the <literal>--"
+"libs</literal> option requests the list of libraries for the compiler to "
+"link with and the directories to find them in. Try running it from your "
+"shell-prompt to see the results on your system."
+msgstr ""
+"Pour simplifier la compilation, nous utilisons <literal>pkg-config</"
+"literal>, présent dans toutes les installations de <application>gtkmm</"
+"application> (correctement effectuées). Ce programme « sait » quels sont les "
+"commutateurs nécessaires à la compilation des programmes utilisant "
+"<application>gtkmm</application>. L'option <literal>--cflags</literal> "
+"demande à <literal>pkg-config</literal> de produire la liste des répertoires "
+"des en-têtes, répertoires que le compilateur devra parcourir ; l'option "
+"<literal>--libs</literal> demande la liste des bibliothèques nécessaires à "
+"l'édition des liens par le compilateur ainsi que les répertoires où elles se "
+"trouvent. Essayez de lancer directement cette commande à l'invite de votre "
+"terminal pour voir les résultats sur votre système."
+
+#: C/gtkmm-tutorial-in.xml:367(programlisting)
+#, no-wrap
+msgid "PKG_CHECK_MODULES([MYAPP], [gtkmm-2.4 >= 2.8.0])"
+msgstr "PKG_CHECK_MODULES([MYAPP], [gtkmm-2.4 >= 2.8.0])"
+
+#: C/gtkmm-tutorial-in.xml:364(para)
+msgid ""
+"However, this is even simpler when using the <function>PKG_CHECK_MODULES()</"
+"function> macro in a standard configure.ac file with autoconf and automake. "
+"For instance: <placeholder-1/> This checks for the presence of gtkmm and "
+"defines MYAPP_LIBS and MYAPP_CFLAGS for use in your Makefile.am files."
+msgstr ""
+"Mais, il est plus simple d'utiliser la macro <function>PKG_CHECK_MODULES()</"
+"function> dans un fichier standard <filename>configure.ac</filename> avec "
+"<application>autoconf</application> et <application>automake</application>. "
+"Par exemple : <placeholder-1/> Cette commande vérifie la présence de "
+"<application>gtkmm</application> et définit les variables MYAPP_LIBS et "
+"MYAPP_CFLAGS Ã utiliser dans vos fichiers <filename>Makefile.am</filename>."
+
+#: C/gtkmm-tutorial-in.xml:370(para)
+msgid ""
+"gtkmm-2.4 is the name of the current stable API. There was an older API "
+"called gtkmm-2-0 which installs in parallel when it is available. There are "
+"several versions of gtkmm-2.4, such as gtkmm 2.10. Note that the API name "
+"does not change for every version because that would be an incompatible API "
+"and ABI break. Theoretically, there might be a future gtkmm-3.0 API which "
+"would install in parallel with gtkmm-2.4 without affecting existing "
+"applications."
+msgstr ""
+"gtkmm-2.4 est le nom de l'actuelle API stable. Il existe une API plus "
+"ancienne nommée gtkmm-2-0 qui s'installe en parallèle quand elle est "
+"disponible. Il existe plusieurs versions de gtkmm-2.4, comme gtkmm 2.10. "
+"Notez que le nom de l'API ne change pas pour chaque version car il y aurait "
+"rupture de compatibilité de l'API et ABI. En théorie, une future API gtkmm-"
+"3.0 API devrait paraître. Elle s'installera en parallèle avec gtkmm-2.4 sans "
+"affecter les applications existantes."
+
+#: C/gtkmm-tutorial-in.xml:373(para)
+msgid ""
+"Note that if you mention extra modules in addition to gtkmm-2.4, they should "
+"be separated by spaces, not commas."
+msgstr ""
+"Notez que si vous mentionnez des modules complémentaires en plus de ceux "
+"pour gtkmm-2.4, ils doivent être séparés par des espaces et non des virgules."
+
+#: C/gtkmm-tutorial-in.xml:375(para)
+msgid ""
+"Openismus has more <ulink url=\"http://www.openismus.com/documents/linux/"
+"automake/automake.shtml\">basic help with automake and autoconf</ulink>."
+msgstr ""
+"Openismus fournit une <ulink url=\"http://www.openismus.com/documents/linux/"
+"automake/automake.shtml\">Aide sur les fondamentaux avec automake et "
+"autoconf</ulink>."
+
+#: C/gtkmm-tutorial-in.xml:382(title) C/gtkmm-tutorial-in.xml:5914(title)
+msgid "Widgets"
+msgstr "�léments graphiques"
+
+#: C/gtkmm-tutorial-in.xml:383(para)
+msgid ""
+"<application>gtkmm</application> applications consist of windows containing "
+"widgets, such as buttons and text boxes. In some other systems, widgets are "
+"called \"controls\". For each widget in your application's windows, there is "
+"a C++ object in your application's code. So you just need to call a method "
+"of the widget's class to affect the visible widget."
+msgstr ""
+"Les applications <application>gtkmm</application> sont constituées par des "
+"fenêtres comportant des éléments graphiques, comme des boutons ou des boîtes "
+"de texte. Dans certains autres systèmes, les éléments graphiques sont "
+"appelés « contrôles ». Pour chaque élément graphique dans les fenêtres d'une "
+"application, il existe un objet C++ dans le code de l'application. Il vous "
+"suffit donc d'appeler une fonction membre de la classe de l'élément "
+"graphique pour en modifier l'apparence."
+
+#: C/gtkmm-tutorial-in.xml:385(programlisting)
+#, no-wrap
+msgid ""
+"m_box.pack_start(m_Button1);\n"
+"m_box.pack_start(m_Button2);"
+msgstr ""
+"m_box.pack_start(m_Button1);\n"
+"m_box.pack_start(m_Button2);"
+
+#: C/gtkmm-tutorial-in.xml:388(programlisting)
+#, no-wrap
+msgid "m_frame.add(m_box);"
+msgstr "m_frame.add(m_box);"
+
+#: C/gtkmm-tutorial-in.xml:384(para)
+msgid ""
+"Widgets are arranged inside container widgets such as frames and notebooks, "
+"in a hierarchy of widgets within widgets. Some of these container widgets, "
+"such as Gtk::VBox, are not visible - they exist only to arrange other "
+"widgets. Here is some example code that adds 2 Gtk::Button widgets to a Gtk::"
+"VBox container widgets: <placeholder-1/> and here is how to add the Gtk::"
+"VBox, containing those buttons, to a Gtk::Frame, which has a visible frame "
+"and title: <placeholder-2/>"
+msgstr ""
+"Les éléments graphiques sont disposés dans des conteneurs tels que cadres et "
+"bloc-notes, avec une hiérarchie entre éléments graphiques. Certains de ces "
+"conteneurs d'éléments graphiques, comme les Gtk::VBox, ne sont pas visibles "
+"â?? ils ne participent qu'à la disposition relative des éléments graphiques. "
+"Voici un exemple de code qui place deux contrôles Gtk::Button dans un "
+"conteneur d'éléments graphiques Gtk::VBox : <placeholder-1/> et voici "
+"comment ajouter le Gtk::VBox, contenant ces boutons, dans un Gtk::Frame, qui "
+"possède un cadre et un titre visibles : <placeholder-2/>"
+
+#: C/gtkmm-tutorial-in.xml:390(para)
+msgid ""
+"Most of the chapters in this book deal with specific widgets. See the <link "
+"linkend=\"chapter-container-widgets\">Container Widgets</link> section for "
+"more details about adding widgets to container widgets."
+msgstr ""
+"La plupart des chapitres de cet ouvrage traitent d'éléments graphiques "
+"spécifiques. Consultez la section <link linkend=\"chapter-container-widgets"
+"\">�léments graphiques conteneurs</link> pour de plus amples précisions sur "
+"la manière de placer des éléments graphiques dans des conteneurs."
+
+#: C/gtkmm-tutorial-in.xml:394(para)
+msgid ""
+"Although you can specify the layout and appearance of windows and widgets "
+"with C++ code, you will probably find it more convenient to design your user "
+"interfaces with <literal>Glade</literal> and load them at runtime with "
+"<literal>Gtk::Builder</literal>. See the <link linkend=\"chapter-builder"
+"\">Glade and Gtk::Builder</link> chapter."
+msgstr ""
+"Même s'il est possible de préciser la disposition et l'apparence des "
+"fenêtres ainsi que des éléments graphiques dans le code C++, vous trouverez "
+"certainement plus pratique de concevoir vos interfaces utilisateur avec "
+"<literal>Glade</literal> et de les charger avec <literal>Gtk::Builder</"
+"literal> à l'exécution de l'application. Consultez le chapitre <link linkend="
+"\"chapter-builder\">Glade et Gtk::Builder</link>."
+
+#: C/gtkmm-tutorial-in.xml:397(para)
+msgid ""
+"Although <application>gtkmm</application> widget instances have lifetimes "
+"and scopes just like those of other C++ classes, <application>gtkmm</"
+"application> has an optional time-saving feature that you will see in some "
+"of the examples. <function>Gtk::manage()</function> allows you to say that a "
+"child widget is owned by the container into which you place it. This allows "
+"you to <function>new</function> the widget, add it to the container and "
+"forget about deleting it. You can learn more about <application>gtkmm</"
+"application> memory management techniques in the <link linkend=\"chapter-"
+"memory\">Memory Management chapter</link>."
+msgstr ""
+"Même si les instances d'éléments graphiques <application>gtkmm</application> "
+"ont des durées de vie et des portées comme toute autre classe C++, "
+"<application>gtkmm</application> dispose d'une fonctionnalité optionnelle "
+"que vous pourrez observer dans certains exemples ; elle permet de gagner du "
+"temps. <function>Gtk::manage()</function> vous permet d'indiquer qu'un "
+"élément graphique enfant est détenu par le conteneur dans lequel vous le "
+"placez. Cela permet de créer l'élément graphique avec <function>new</"
+"function>, l'ajouter au conteneur et ne pas vous préoccuper de sa "
+"destruction. Vous en apprendrez plus au sujet des techniques de gestion de "
+"la mémoire dans <application>gtkmm</application> dans le chapitre <link "
+"linkend=\"chapter-memory\">Gestion de la mémoire</link>."
+
+#: C/gtkmm-tutorial-in.xml:403(title) C/gtkmm-tutorial-in.xml:702(title)
+#: C/gtkmm-tutorial-in.xml:4662(title) C/gtkmm-tutorial-in.xml:4957(title)
+#: C/gtkmm-tutorial-in.xml:7235(title)
+msgid "Signals"
+msgstr "Signaux"
+
+#: C/gtkmm-tutorial-in.xml:405(para)
+msgid ""
+"<application>gtkmm</application>, like most GUI toolkits, is <emphasis>event-"
+"driven</emphasis>. When an event occurs, such as the press of a mouse "
+"button, the appropriate signal will be <emphasis>emitted</emphasis> by the "
+"Widget that was pressed. Each Widget has a different set of signals that it "
+"can emit. To make a button click result in an action, we set up a "
+"<emphasis>signal handler</emphasis> to catch the button's \"clicked\" signal."
+msgstr ""
+"<application>gtkmm</application>, comme la plupart des boîtes à outils GUI, "
+"est <emphasis>piloté par événements</emphasis>. Lorsqu'un événement "
+"survient, comme un clic de bouton de souris, le signal approprié est "
+"<emphasis>émis</emphasis> par l'élément graphique pointé. Chaque élément "
+"graphique dispose d'un jeu de signaux à émettre. Pour qu'un clic de bouton "
+"se traduise par une action, nous mettons en Å?uvre un <emphasis>gestionnaire "
+"de signal</emphasis> pour capturer le signal « clicked » du bouton."
+
+#: C/gtkmm-tutorial-in.xml:413(programlisting)
+#, no-wrap
+msgid ""
+"m_button1.signal_clicked().connect( sigc::mem_fun(*this,\n"
+" &HelloWorld::on_button_clicked) );"
+msgstr ""
+"m_button1.signal_clicked().connect( sigc::mem_fun(*this,\n"
+" &HelloWorld::on_button_clicked) );"
+
+#: C/gtkmm-tutorial-in.xml:412(para)
+msgid ""
+"<application>gtkmm</application> uses the libsigc++ library to implement "
+"signals. Here is an example line of code that connects a Gtk::Button's "
+"\"clicked\" signal with a signal handler called \"on_button_clicked\": "
+"<placeholder-1/>"
+msgstr ""
+"<application>gtkmm</application> utilise la bibliothèque libsigc++ pour "
+"implémenter les signaux. Voici un exemple de ligne de code qui connecte le "
+"signal « clicked » émis par un Gtk::Button à un gestionnaire de signal nommé "
+"« on_button_clicked » : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:417(para)
+msgid ""
+"For more detailed information about signals, see the <link linkend=\"chapter-"
+"signals\">appendix</link>."
+msgstr ""
+"Pour plus de détails à propos des signaux, consultez cette <link linkend="
+"\"chapter-signals\">annexe</link>."
+
+#: C/gtkmm-tutorial-in.xml:418(para)
+msgid ""
+"For information about implementing your own signals rather than just "
+"connecting to the existing <application>gtkmm</application> signals, see the "
+"<link linkend=\"chapter-custom-signals\">appendix</link>."
+msgstr ""
+"Pour des informations sur l'implémentation de vos propres signaux au lieu "
+"d'une simple connexion aux signaux prédéfinis de <application>gtkmm</"
+"application>, consultez cette <link linkend=\"chapter-custom-signals"
+"\">annexe</link>."
+
+#: C/gtkmm-tutorial-in.xml:424(title) C/gtkmm-tutorial-in.xml:8783(classname)
+msgid "Glib::ustring"
+msgstr "Glib::ustring"
+
+#: C/gtkmm-tutorial-in.xml:425(para)
+msgid ""
+"You might be surprised to learn that <application>gtkmm</application> "
+"doesn't use <classname>std::string</classname> in it its interfaces. Instead "
+"it uses <classname>Glib::ustring</classname>, which is so similar and "
+"unobtrusive that you could actually pretend that each Glib::ustring is a "
+"<classname>std::string</classname> and ignore the rest of this section. But "
+"read on if you want to use languages other than English in your application."
+msgstr ""
+"Peut-être serez-vous surpris d'apprendre que <application>gtkmm</"
+"application> n'utilise pas la classe <classname>std::string</classname> dans "
+"ses interfaces. Ã? la place, <application>gtkmm</application> utilise la "
+"classe <classname>Glib::ustring</classname> ; les deux classes sont tout à "
+"fait semblables et tellement amalgamées que vous pouvez vraiment prétendre "
+"que chaque Glib::ustring est un <classname>std::string</classname> et "
+"ignorer la suite de ce paragraphe. Mais poursuivez la lecture si vous voulez "
+"utiliser des langues autres que l'anglais dans vos applications."
+
+#: C/gtkmm-tutorial-in.xml:426(para)
+msgid ""
+"std::string uses 8 bit per character, but 8 bits aren't enough to encode "
+"languages such as Arabic, Chinese, and Japanese. Although the encodings for "
+"these languages has now been specified by the Unicode Constortium, the C and "
+"C++ languages do not yet provide any standardised Unicode support. GTK+ and "
+"GNOME chose to implement Unicode using UTF-8, and that's what is wrapped by "
+"Glib::ustring. It provides almost exactly the same interface as std::string, "
+"along with automatic conversions to and from std::string."
+msgstr ""
+"std::string utilise 8 bits par caractère, mais 8 bits ne sont pas suffisants "
+"pour coder des langues telles que l'arabe, le chinois ou le japonais. Même "
+"si les codages pour ces langues ont maintenant été définis par le Consortium "
+"Unicode, les langages informatiques C et C++ ne fournissent pas encore une "
+"prise en charge normalisée de l'Unicode. GTK+ et GNOME ont choisi "
+"d'implémenter l'Unicode en utilisant l'UTF-8 ; c'est ce codage qui est "
+"intégré dans Glib::ustring. Il fournit une interface pratiquement identique "
+"Ã std::string, tout en permettant des conversions automatiques de ou vers "
+"std::string."
+
+#: C/gtkmm-tutorial-in.xml:427(para)
+msgid ""
+"One of the benefits of UTF-8 is that you don't need to use it unless you "
+"want to, so you don't need to retrofit all of your code at once. "
+"<classname>std::string</classname> will still work for 7-bit ASCII strings. "
+"But when you try to localize your application for languages like Chinese, "
+"for instance, you will start to see strange errors, and possible crashes. "
+"Then all you need to do is start using <classname>Glib::ustring</classname> "
+"instead."
+msgstr ""
+"Un des avantages de UTF-8 est que son utilisation n'est pas obligatoire, "
+"sauf à le vouloir ; vous n'avez pas besoin de retoucher tout votre code sur "
+"le champ. <classname>std::string</classname> fonctionne toujours bien avec "
+"les chaînes ASCII 7 bits. Mais si vous essayez de régionaliser vos "
+"applications pour des langues comme le chinois, par exemple, vous "
+"constaterez des erreurs étranges, voire des blocages. Alors, il ne vous "
+"reste plus qu'à utiliser dès maintenant <classname>Glib::ustring</classname> "
+"Ã la place."
+
+#: C/gtkmm-tutorial-in.xml:428(para)
+msgid ""
+"Note that UTF-8 isn't compatible with 8-bit encodings like ISO-8859-1. For "
+"instance, German umlauts are not in the ASCII range and need more than 1 "
+"byte in the UTF-8 encoding. If your code contains 8-bit string literals, you "
+"have to convert them to UTF-8 (e.g. the Bavarian greeting \"Grü� Gott\" "
+"would be \"Gr\\xC3\\xBC\\xC3\\x9F Gott\")."
+msgstr ""
+"Notez que UTF-8 n'est pas compatible avec des encodages 8 bits comme ISO-"
+"8859-1. Par exemple, les trémas de l'allemand ne font pas partie de la gamme "
+"des caractères ASCII ; ils nécessitent plus d'un octet en UTF-8. Si votre "
+"code comporte des chaînes littérales sur 8 bits, vous devez les convertir en "
+"UTF-8 (par exemple, la formule de salut bavaroise « Grü� Gott » devient « Gr"
+"\\xC3\\xBC\\xC3\\x9F Gott »)."
+
+#: C/gtkmm-tutorial-in.xml:429(para)
+msgid ""
+"You should avoid C-style pointer arithmetic, and functions such as strlen(). "
+"In UTF-8, each character might need anywhere from 1 to 6 bytes, so it's not "
+"possible to assume that the next byte is another character. <classname>Glib::"
+"ustring</classname> worries about the details of this for you so you can use "
+"methods such as Glib::ustring::substr() while still thinking in terms of "
+"characters instead of bytes."
+msgstr ""
+"Vous devez éviter les arithmétiques de pointeurs dans le style du C et les "
+"fonctions comme strlen(). En UTF-8, chaque caractère peut nécessiter de 1 à "
+"6 octets ; il n'est donc pas possible de présupposer que l'octet suivant est "
+"un nouveau caractère. <classname>Glib::ustring</classname> se préoccupe de "
+"ces détails à votre place ; vous pouvez employer des fonctions membres "
+"telles que Glib::ustring::substr() en pensant caractères et non octets."
+
+#: C/gtkmm-tutorial-in.xml:431(para)
+msgid ""
+"Unlike the Windows UCS-2 Unicode solution, this does not require any special "
+"compiler options to process string literals, and it does not result in "
+"Unicode executables and libraries which are incompatible with ASCII ones."
+msgstr ""
+"Contrairement à la solution de l'Unicode UCS-2 de Windows, UTF-8 ne requiert "
+"aucune option spéciale de compilation pour le traitement des chaînes de "
+"caractères ; en conséquence, il n'existe pas de bibliothèque ou d'exécutable "
+"Unicode incompatible avec ceux en ASCII."
+
+#: C/gtkmm-tutorial-in.xml:433(ulink) C/gtkmm-tutorial-in.xml:682(ulink)
+#: C/gtkmm-tutorial-in.xml:780(ulink) C/gtkmm-tutorial-in.xml:795(ulink)
+#: C/gtkmm-tutorial-in.xml:898(ulink) C/gtkmm-tutorial-in.xml:952(ulink)
+#: C/gtkmm-tutorial-in.xml:970(ulink) C/gtkmm-tutorial-in.xml:1016(ulink)
+#: C/gtkmm-tutorial-in.xml:1118(ulink) C/gtkmm-tutorial-in.xml:1173(ulink)
+#: C/gtkmm-tutorial-in.xml:1219(ulink) C/gtkmm-tutorial-in.xml:1419(ulink)
+#: C/gtkmm-tutorial-in.xml:1467(ulink) C/gtkmm-tutorial-in.xml:1515(ulink)
+#: C/gtkmm-tutorial-in.xml:1590(ulink) C/gtkmm-tutorial-in.xml:1631(ulink)
+#: C/gtkmm-tutorial-in.xml:1672(ulink) C/gtkmm-tutorial-in.xml:1705(ulink)
+#: C/gtkmm-tutorial-in.xml:1745(ulink) C/gtkmm-tutorial-in.xml:1982(ulink)
+#: C/gtkmm-tutorial-in.xml:2049(ulink) C/gtkmm-tutorial-in.xml:2202(ulink)
+#: C/gtkmm-tutorial-in.xml:2257(ulink) C/gtkmm-tutorial-in.xml:2297(ulink)
+#: C/gtkmm-tutorial-in.xml:2344(ulink) C/gtkmm-tutorial-in.xml:2360(ulink)
+#: C/gtkmm-tutorial-in.xml:2378(ulink) C/gtkmm-tutorial-in.xml:2486(ulink)
+#: C/gtkmm-tutorial-in.xml:3005(ulink) C/gtkmm-tutorial-in.xml:3158(ulink)
+#: C/gtkmm-tutorial-in.xml:3186(ulink) C/gtkmm-tutorial-in.xml:3215(ulink)
+#: C/gtkmm-tutorial-in.xml:3267(ulink) C/gtkmm-tutorial-in.xml:3287(ulink)
+#: C/gtkmm-tutorial-in.xml:3335(ulink) C/gtkmm-tutorial-in.xml:3834(ulink)
+#: C/gtkmm-tutorial-in.xml:3891(ulink) C/gtkmm-tutorial-in.xml:3902(ulink)
+#: C/gtkmm-tutorial-in.xml:3929(ulink) C/gtkmm-tutorial-in.xml:3951(ulink)
+#: C/gtkmm-tutorial-in.xml:3974(ulink) C/gtkmm-tutorial-in.xml:4772(ulink)
+#: C/gtkmm-tutorial-in.xml:5047(ulink) C/gtkmm-tutorial-in.xml:5079(ulink)
+#: C/gtkmm-tutorial-in.xml:7103(ulink)
+msgid "Reference"
+msgstr "Référence"
+
+#: C/gtkmm-tutorial-in.xml:435(para)
+msgid ""
+"See the <link linkend=\"chapter-internationalization\">Internationalization</"
+"link> section for information about providing the UTF-8 string literals."
+msgstr ""
+"Consultez le chapitre sur l'<link linkend=\"chapter-internationalization"
+"\">Internationalisation</link> pour des informations concernant les chaînes "
+"littérales UTF-8."
+
+#: C/gtkmm-tutorial-in.xml:440(title)
+msgid "Intermediate types"
+msgstr "Types intermédiaires"
+
+#: C/gtkmm-tutorial-in.xml:443(para)
+msgid ""
+"<classname>Glib::StringArrayHandle</classname> or <classname>Glib::"
+"ArrayHandle<Glib::ustring></classname>: Use <classname>std::vector<"
+"Glib::ustring></classname>, <classname>std::list<Glib::ustring></"
+"classname>, <type>const char*[]</type>, etc."
+msgstr ""
+"<classname>Glib::StringArrayHandle</classname> ou <classname>Glib::"
+"ArrayHandle<Glib::ustring></classname>Â : utilisez <classname>std::"
+"vector<Glib::ustring></classname>, <classname>std::list<Glib::"
+"ustring></classname>, <literal>const char*[]</literal>, etc."
+
+#: C/gtkmm-tutorial-in.xml:444(para)
+msgid ""
+"<classname>Glib::ListHandle<Gtk::Widget*></classname>: Use "
+"<classname>std::vector<Gtk::Widget*></classname>, <classname>std::"
+"list<Gtk::Widget*></classname>, etc."
+msgstr ""
+"<classname>Glib::ListHandle<Gtk::Widget*></classname>Â : utilisez "
+"<classname>std::vector<Gtk::Widget*></classname>, <classname>std::"
+"list<Gtk::Widget*></classname>, etc."
+
+#: C/gtkmm-tutorial-in.xml:445(para)
+msgid ""
+"<classname>Glib::SListHandle<Gtk::Widget*></classname>: Use "
+"<classname>std::vector<Gtk::Widget*></classname>, <classname>std::"
+"list<Gtk::Widget*></classname>, etc."
+msgstr ""
+"<classname>Glib::SListHandle<Gtk::Widget*></classname>Â : utilisez "
+"<classname>std::vector<Gtk::Widget*></classname>, <classname>std::"
+"list<Gtk::Widget*></classname>, etc."
+
+#: C/gtkmm-tutorial-in.xml:441(para)
+msgid ""
+"Some parts of the <application>gtkmm</application> API use intermediate data "
+"containers, such as <classname>Glib::StringArrayHandle</classname> instead "
+"of a specific Standard C++ container such as <classname>std::vector</"
+"classname> or <classname>std::list</classname>. You should not declare these "
+"types yourself -- you should use whatever Standard C++ container you prefer "
+"instead. <application>gtkmm</application> will do the conversion for you. "
+"Here are some of these intermediate types: <placeholder-1/>"
+msgstr ""
+"Certaines parties de l'API <application>gtkmm</application> utilisent des "
+"conteneurs de données intermédiaires, tels que <classname>Glib::"
+"StringArrayHandle</classname>, à la place des conteneurs normalisés "
+"spécifiques C++ comme <classname>std::vector</classname> ou <classname>std::"
+"list</classname>. Vous ne devez pas déclarer de variables de ces types vous-"
+"même â?? vous devez utiliser à la place n'importe quel conteneur normalisé C+"
+"+, celui que vous préférez. <application>gtkmm</application> fera les "
+"conversions pour vous. Voici quelques-uns de ces types intermédiaires : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:453(title)
+msgid "Mixing C and C++ APIs"
+msgstr "Mélange des API C et C++"
+
+#: C/gtkmm-tutorial-in.xml:454(para)
+msgid ""
+"You can use C APIs which do not yet have convenient C++ interfaces. It is "
+"generally not a problem to use C APIs from C++, and <application>gtkmm</"
+"application> helps by providing access to the underlying C object, and "
+"providing an easy way to create a C++ wrapper object from a C object, "
+"provided that the C API is also based on the GObject system."
+msgstr ""
+"Vous pouvez utiliser des API C, si elles n'ont pas encore d'interfaces C++ "
+"commodes. Il n'y a généralement aucun problème avec l'utilisation des API C "
+"dans le C++ ; <application>gtkmm</application> vous aide en donnant un accès "
+"à l'objet C sous-jacent et en facilitant la création d'un objet C++ "
+"enveloppe de l'objet C, à condition que l'API C soit également fondée sur le "
+"système GObject."
+
+#: C/gtkmm-tutorial-in.xml:456(para)
+msgid ""
+"To use a <application>gtkmm</application> instance with a C function that "
+"requires a C GObject instance, use the <function>gobj()</function> function "
+"to obtain a pointer to the underlying GObject instance. For instance"
+msgstr ""
+"Pour utiliser un élément <application>gtkmm</application> avec une fonction "
+"C demandant un type d'objet GObject C, servez-vous de la fonction "
+"<function>gobj()</function> pour obtenir un pointeur sur l'instance du "
+"GObject sous-jacent. Par exemple"
+
+#: C/gtkmm-tutorial-in.xml:459(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Gtk::Button* button = new Gtk::Button(\"example\");\n"
+"gtk_button_do_something_new(button->gobj());\n"
+msgstr ""
+"\n"
+"Gtk::Button* button = new Gtk::Button(\"exemple\");\n"
+"gtk_button_do_something_new(button->gobj());\n"
+
+#: C/gtkmm-tutorial-in.xml:465(para)
+msgid ""
+"To obtain a <application>gtkmm</application> instance from a C GObject "
+"instance, use the Glib::wrap() function. For instance"
+msgstr ""
+"Pour obtenir un objet <application>gtkmm</application> à partir d'un élément "
+"GObject C, utilisez la fonction Glib::wrap(). Par exemple"
+
+#: C/gtkmm-tutorial-in.xml:467(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"GtkButton* cbutton = get_a_button();\n"
+"Gtk::Button* button = Glib::wrap(cbutton);\n"
+msgstr ""
+"\n"
+"GtkButton* cbutton = get_a_button();\n"
+"Gtk::Button* button = Glib::wrap(cbutton);\n"
+
+#: C/gtkmm-tutorial-in.xml:475(title)
+msgid "Hello World in <application>gtkmm</application>"
+msgstr "Hello World en <application>gtkmm</application>"
+
+#: C/gtkmm-tutorial-in.xml:477(para)
+msgid ""
+"We've now learned enough to look at a real example. In accordance with an "
+"ancient tradition of computer science, we now introduce Hello World, a la "
+"<application>gtkmm</application>:"
+msgstr ""
+"Nous en savons maintenant assez pour examiner un exemple réel. Pour "
+"reprendre une vieille tradition du monde de l'informatique, nous allons "
+"maintenant présenter le programme « Hello World » accommodé à la "
+"<application>gtkmm</application>Â :"
+
+#: C/gtkmm-tutorial-in.xml:484(para)
+msgid ""
+"Try to compile and run it before going on. You should see something like "
+"this:"
+msgstr ""
+"Essayez de le compiler et de le lancer avant de poursuivre. Vous devriez "
+"voir quelque chose comme :"
+
+#: C/gtkmm-tutorial-in.xml:489(title)
+msgid "Hello World"
+msgstr "Hello World"
+
+#: C/gtkmm-tutorial-in.xml:495(para)
+msgid ""
+"Pretty thrilling, eh? Let's examine the code. First, the "
+"<classname>HelloWorld</classname> class:"
+msgstr ""
+"Tout à fait palpitant, n'est-ce-pas ? Examinons le code. D'abord, la classe "
+"<classname>HelloWorld</classname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:500(programlisting)
+#, no-wrap
+msgid ""
+"class HelloWorld : public Gtk::Window\n"
+"{\n"
+"\n"
+"public:\n"
+" HelloWorld();\n"
+" virtual ~HelloWorld();\n"
+"\n"
+"protected:\n"
+" //Signal handlers:\n"
+" virtual void on_button_clicked();\n"
+"\n"
+" //Member widgets:\n"
+" Gtk::Button m_button;\n"
+"};"
+msgstr ""
+"class HelloWorld : public Gtk::Window\n"
+"{\n"
+"\n"
+"public:\n"
+" HelloWorld();\n"
+" virtual ~HelloWorld();\n"
+"\n"
+"protected:\n"
+" //Gestionnaire de signal :\n"
+" virtual void on_button_clicked();\n"
+"\n"
+" //éléments graphiques membres :\n"
+" Gtk::Button m_button;\n"
+"};"
+
+#: C/gtkmm-tutorial-in.xml:515(para)
+msgid ""
+"This class implements the \"Hello World\" window. It's derived from "
+"<classname>Gtk::Window</classname>, and has a single <classname>Gtk::Button</"
+"classname> as a member. We've chosen to use the constructor to do all of the "
+"initialisation work for the window, including setting up the signals. Here "
+"it is, with the comments omitted:"
+msgstr ""
+"Cette classe implémente la fenêtre « Hello World ». Elle est dérivée de la "
+"classe <classname>Gtk::Window</classname> et possède un simple "
+"<classname>Gtk::Button</classname> comme membre. Nous avons pris le parti "
+"d'utiliser le constructeur pour faire toutes les tâches d'initialisation de "
+"la fenêtre, y compris la définition des signaux. Voici le code, les "
+"commentaires sont omis :"
+
+#: C/gtkmm-tutorial-in.xml:524(programlisting)
+#, no-wrap
+msgid ""
+"HelloWorld::HelloWorld()\n"
+":\n"
+" m_button (\"Hello World\")\n"
+"{\n"
+" set_border_width(10);\n"
+" m_button.signal_clicked().connect(sigc::mem_fun(*this,\n"
+" &HelloWorld::on_button_clicked));\n"
+" add(m_button);.\n"
+" m_button.show();\n"
+"}"
+msgstr ""
+"HelloWorld::HelloWorld()\n"
+":\n"
+" m_button (\"Hello World\")\n"
+"{\n"
+" set_border_width(10);\n"
+" m_button.signal_clicked().connect(sigc::mem_fun(*this,\n"
+" &HelloWorld::on_button_clicked));\n"
+" add(m_button);.\n"
+" m_button.show();\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:535(para)
+msgid ""
+"Notice that we've used an initialiser statement to give the "
+"<literal>m_button</literal> object the label \"Hello World\"."
+msgstr ""
+"Notez que nous avons utilisé une instruction d'initialisation pour étiqueter "
+"l'objet <literal>m_button</literal> avec « Hello World »."
+
+#: C/gtkmm-tutorial-in.xml:540(para)
+msgid ""
+"Next we call the Window's <methodname>set_border_width()</methodname> "
+"method. This sets the amount of space between the sides of the window and "
+"the widget it contains."
+msgstr ""
+"Puis nous appelons la fonction membre <methodname>set_border_width()</"
+"methodname> de l'objet Window. Elle fixe la dimension de l'espace entre les "
+"côtés de la fenêtre et l'élément graphique qu'elle contient."
+
+#: C/gtkmm-tutorial-in.xml:546(para)
+msgid ""
+"We then hook up a signal handler to <literal>m_button</literal>'s "
+"<literal>clicked</literal> signal. This prints our friendly greeting to "
+"<literal>stdout</literal>."
+msgstr ""
+"Ensuite, nous raccordons un gestionnaire de signal pour le signal "
+"<literal>clicked</literal> du <literal>m_button</literal>. Le gestionnaire "
+"affiche sur <literal>stdout</literal> notre salut amical."
+
+#: C/gtkmm-tutorial-in.xml:551(para)
+msgid ""
+"Next, we use the Window's <methodname>add()</methodname> method to put "
+"<literal>m_button</literal> in the Window. (<methodname>add()</methodname> "
+"comes from <classname>Gtk::Container</classname>, which is described in the "
+"chapter on container widgets.) The <methodname>add()</methodname> method "
+"places the Widget in the Window, but it doesn't display the widget. "
+"<application>gtkmm</application> widgets are always invisible when you "
+"create them - to display them, you must call their <methodname>show()</"
+"methodname> method, which is what we do in the next line."
+msgstr ""
+"Puis, nous utilisons la fonction membre <methodname>add()</methodname> avec "
+"l'objet Window pour y placer le <literal>m_button</literal> (<methodname>add"
+"()</methodname> est une fonction membre de la classe <classname>Gtk::"
+"Container</classname> que nous décrirons dans le chapitre des éléments "
+"graphiques conteneurs). La fonction <methodname>add()</methodname> place "
+"l'élément graphique dans la fenêtre, mais elle ne l'affiche pas. Les "
+"éléments graphiques <application>gtkmm</application> sont toujours "
+"invisibles à leur création â?? pour les afficher, vous devez faire appel à la "
+"fonction <methodname>show()</methodname>, ce que nous faisons à la ligne "
+"suivante."
+
+#: C/gtkmm-tutorial-in.xml:561(para)
+msgid ""
+"Now let's look at our program's <function>main()</function> function. Here "
+"it is, without comments:"
+msgstr ""
+"Maintenant examinons la fonction <function>main()</function> du programme. "
+"La voici, sans commentaire :"
+
+#: C/gtkmm-tutorial-in.xml:566(programlisting)
+#, no-wrap
+msgid ""
+"int main(int argc, char** argv)\n"
+"{\n"
+" Gtk::Main kit(argc, argv);\n"
+"\n"
+" HelloWorld helloworld;\n"
+" Gtk::Main::run(helloworld);\n"
+"\n"
+" return 0;\n"
+"}"
+msgstr ""
+"int main(int argc, char** argv)\n"
+"{\n"
+" Gtk::Main kit(argc, argv);\n"
+"\n"
+" HelloWorld helloworld;\n"
+" Gtk::Main::run(helloworld);\n"
+"\n"
+" return 0;\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:576(para)
+msgid ""
+"First we instantiate an object called <literal>kit</literal>. This is of "
+"type <classname>Gtk::Main</classname>. Every <application>gtkmm</"
+"application> program must have one of these. We pass our command-line "
+"arguments to its constructor. It takes the arguments it wants, and leaves "
+"you the rest, as we described earlier."
+msgstr ""
+"Tout d'abord nous créons un exemplaire d'un objet nommé <literal>kit</"
+"literal>. Il est du type <classname>Gtk::Main</classname>. Tout programme "
+"<application>gtkmm</application> doit en posséder un. Nous passons les "
+"paramètres en ligne de commande à son constructeur. Il prélève les arguments "
+"dont il a besoin et vous laisse le reste, comme nous l'avons expliqué plus "
+"haut."
+
+#: C/gtkmm-tutorial-in.xml:583(para)
+msgid ""
+"Next we make an object of our <classname>HelloWorld</classname> class, whose "
+"constructor takes no arguments, but it isn't visible yet. When we call Gtk::"
+"Main::run(), giving it the helloworld Window, it shows the Window and starts "
+"the <application>gtkmm</application><emphasis>event loop</emphasis>. During "
+"the event loop <application>gtkmm</application> idles, waiting for actions "
+"from the user, and responding appropriately. When the user closes the "
+"Window, run() will return, causing the final line of our main() function be "
+"to executed. The application will then finish."
+msgstr ""
+"Ensuite nous définissons un objet de la classe <classname>HelloWorld</"
+"classname> dont le constructeur ne prend pas de paramètres ; il n'est pas "
+"encore visible. Quand nous appelons Gtk::Main::run(), avec comme paramètre "
+"la fenêtre helloworld, la fonction main() affiche la fenêtre et démarre la "
+"<emphasis>boucle des événements</emphasis> <application>gtkmm</application>. "
+"Lorsque la boucle des événements <application>gtkmm</application> est "
+"inactive, elle est en attente des actions de l'utilisateur pour y répondre "
+"de façon appropriée. Quand l'utilisateur ferme la fenêtre, la fonction run() "
+"retourne et déclenche l'exécution de la dernière ligne de la fonction main"
+"(). Et le programme se termine."
+
+#: C/gtkmm-tutorial-in.xml:593(title)
+msgid "Buttons"
+msgstr "Boutons"
+
+#: C/gtkmm-tutorial-in.xml:595(para)
+msgid "<application>gtkmm</application> provides four basic types of buttons:"
+msgstr ""
+"<application>gtkmm</application> met à votre disposition quatre types "
+"basiques de boutons :"
+
+#: C/gtkmm-tutorial-in.xml:602(term)
+msgid "Push-Buttons"
+msgstr "Bouton poussoir"
+
+#: C/gtkmm-tutorial-in.xml:604(para)
+msgid ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1Button.html\"><classname>Gtk::Button</classname></ulink>. "
+"Standard buttons, usually marked with a label or picture. Pushing one "
+"triggers an action. See the <link linkend=\"sec-pushbuttons\">Button</link> "
+"section."
+msgstr ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1Button.html\"><classname>Gtk::Button</classname></ulink>. C'est "
+"le bouton classique, traditionnellement orné d'une étiquette ou d'une image. "
+"Le fait de le presser déclenche une action. Consultez le paragraphe <link "
+"linkend=\"sec-pushbuttons\">Bouton</link>."
+
+#: C/gtkmm-tutorial-in.xml:611(term)
+msgid "Toggle buttons"
+msgstr "Bouton bascule"
+
+#: C/gtkmm-tutorial-in.xml:613(para)
+msgid ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1ToggleButton.html\"><classname>Gtk::ToggleButton</classname></"
+"ulink>. Unlike a normal Button, which springs back up, a ToggleButton stays "
+"down until you press it again. It might be useful as an on/off switch. See "
+"the <link linkend=\"sec-toggle-buttons\">ToggleButton</link> section."
+msgstr ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1ToggleButton.html\"><classname>Gtk::ToggleButton</classname></"
+"ulink>. Contrairement au précédent, qui se relève après avoir été pressé, un "
+"bouton bascule reste en position basse jusqu'à ce que vous le pressiez à "
+"nouveau. Il est utile en tant qu'interrupteur marche/arrêt. Consultez le "
+"paragraphe <link linkend=\"sec-toggle-buttons\">Bouton bascule</link>."
+
+#: C/gtkmm-tutorial-in.xml:621(term)
+msgid "Checkboxes"
+msgstr "Case à cocher"
+
+#: C/gtkmm-tutorial-in.xml:623(para)
+msgid ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1CheckButton.html\"><classname>Gtk::CheckButton</classname></"
+"ulink>. These act like ToggleButtons, but show their state in small squares, "
+"with their label at the side. They should be used in most situations which "
+"require an on/off setting. See the <link linkend=\"sec-checkboxes"
+"\">CheckBox</link> section."
+msgstr ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1CheckButton.html\"><classname>Gtk::CheckButton</classname></"
+"ulink>. Elle agit comme un bouton-bascule, mais affiche son état dans un "
+"petit carré. L'étiquette est disposée sur son côté. Elle peut s'utiliser "
+"dans la plupart des situations où l'on doit définir un état actif/inactif. "
+"Consultez le paragraphe <link linkend=\"sec-checkboxes\">Cases à cocher</"
+"link>."
+
+#: C/gtkmm-tutorial-in.xml:633(term)
+msgid "Radio buttons"
+msgstr "Bouton radio"
+
+#: C/gtkmm-tutorial-in.xml:635(para)
+msgid ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1RadioButton.html\"><classname>Gtk::RadioButton</classname></"
+"ulink>. Named after the station selectors on old car radios, these buttons "
+"are used in groups for options which are mutually exclusive. Pressing one "
+"causes all the others in its group to turn off. They are similar to "
+"CheckBoxes (a small widget with a label at the side), but usually look "
+"different. See the <link linkend=\"sec-radio-buttons\">RadioButton</link> "
+"section."
+msgstr ""
+"<ulink url=\"http://library.gnome.org/devel/gtkmm/unstable/"
+"classGtk_1_1RadioButton.html\"><classname>Gtk::RadioButton</classname></"
+"ulink>. Ainsi dénommé d'après le comportement des sélecteurs de stations sur "
+"les anciens autoradios, ce bouton s'utilise en groupe pour des choix "
+"mutuellement exclusifs. Presser sur l'un d'eux désélectionne tout autre "
+"bouton du groupe. Il ressemble à une case à cocher (petit élément graphique "
+"avec une étiquette sur le côté), mais il a généralement un aspect "
+"différencié. Consultez le paragraphe <link linkend=\"sec-radio-buttons"
+"\">Bouton radio</link>."
+
+#: C/gtkmm-tutorial-in.xml:649(para)
+msgid ""
+"Note that, due to GTK+'s theming system, the appearance of these widgets "
+"will vary. In the case of checkboxes and radio buttons, they may vary "
+"considerably."
+msgstr ""
+"Notez qu'en raison du système des thèmes d'apparence de GTK+, l'aspect de "
+"ces éléments graphiques peut varier. Dans le cas des cases à cocher et des "
+"boutons radio, les variations peuvent être conséquentes."
+
+#: C/gtkmm-tutorial-in.xml:656(title)
+msgid "Button"
+msgstr "Bouton"
+
+#: C/gtkmm-tutorial-in.xml:658(title)
+msgid "Constructors"
+msgstr "Constructeurs"
+
+#: C/gtkmm-tutorial-in.xml:660(para)
+msgid ""
+"There are two ways to create a Button. You can specify a label string in the "
+"<classname>Gtk::Button</classname> constructor, or set it later with "
+"<methodname>set_label()</methodname>."
+msgstr ""
+"Il y a deux façons de créer un bouton. Vous pouvez indiquer la chaîne "
+"étiquette dans le constructeur de <classname>Gtk::Button</classname> ou bien "
+"la définir plus tard avec <methodname>set_label()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:666(para)
+msgid ""
+"To define an accelerator key for keyboard navigation, place an underscore "
+"before one of the label's characters and specify <literal>true</literal> for "
+"the optional <literal>mnemonic</literal> parameter. For instance:"
+msgstr ""
+"Pour définir une touche d'accès direct de navigation au clavier, placez un "
+"caractère souligné avant l'un des caractères de l'étiquette et définissez à "
+"<literal>true</literal> le paramètre optionnel <literal>mnemonic</literal> "
+"(mnémonique). Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:668(programlisting)
+#, no-wrap
+msgid "Gtk::Button* pButton = new Gtk::Button(\"_Something\", true);"
+msgstr "Gtk::Button* pButton = new Gtk::Button(\"_Quelquechose\", true);"
+
+#: C/gtkmm-tutorial-in.xml:672(programlisting)
+#, no-wrap
+msgid "Gtk::Button* pButton = new Gtk::Button(Gtk::Stock::OK);"
+msgstr "Gtk::Button* pButton = new Gtk::Button(Gtk::Stock::OK);"
+
+#: C/gtkmm-tutorial-in.xml:670(para)
+msgid ""
+"Wherever possible you should use Stock items, to ensure consistency with "
+"other applications, and to improve the appearance of your applications by "
+"using icons. For instance, <placeholder-1/> This will use standard text, in "
+"all languages, with standard keyboard accelerators, with a standard icon."
+msgstr ""
+"Chaque fois que cela est possible, vous devez utiliser les éléments du "
+"catalogue pour être cohérent avec les autres applications et en améliorer "
+"l'aspect en utilisant des icônes. Par exemple, <placeholder-1/> utilise un "
+"texte normalisé, dans toutes les langues, avec un raccourci clavier et une "
+"icône standard."
+
+#: C/gtkmm-tutorial-in.xml:676(para)
+msgid ""
+"<classname>Gtk::Button</classname> is also a container so you could put any "
+"other widget, such as a <classname>Gtk::Image</classname> into it."
+msgstr ""
+"<classname>Gtk::Button</classname> est aussi un conteneur ; vous pouvez donc "
+"y mettre n'importe quel autre élément graphique à l'intérieur, comme une "
+"<classname>Gtk::Image</classname>."
+
+#: C/gtkmm-tutorial-in.xml:685(title) C/gtkmm-tutorial-in.xml:797(title)
+#: C/gtkmm-tutorial-in.xml:902(title) C/gtkmm-tutorial-in.xml:1063(title)
+#: C/gtkmm-tutorial-in.xml:1120(title) C/gtkmm-tutorial-in.xml:1423(title)
+#: C/gtkmm-tutorial-in.xml:1493(title) C/gtkmm-tutorial-in.xml:1517(title)
+#: C/gtkmm-tutorial-in.xml:1592(title) C/gtkmm-tutorial-in.xml:1633(title)
+#: C/gtkmm-tutorial-in.xml:1674(title) C/gtkmm-tutorial-in.xml:1708(title)
+#: C/gtkmm-tutorial-in.xml:1748(title) C/gtkmm-tutorial-in.xml:2014(title)
+#: C/gtkmm-tutorial-in.xml:2052(title) C/gtkmm-tutorial-in.xml:2206(title)
+#: C/gtkmm-tutorial-in.xml:2259(title) C/gtkmm-tutorial-in.xml:2299(title)
+#: C/gtkmm-tutorial-in.xml:3837(title) C/gtkmm-tutorial-in.xml:3905(title)
+#: C/gtkmm-tutorial-in.xml:3932(title) C/gtkmm-tutorial-in.xml:3954(title)
+#: C/gtkmm-tutorial-in.xml:3977(title) C/gtkmm-tutorial-in.xml:4144(title)
+#: C/gtkmm-tutorial-in.xml:4267(title) C/gtkmm-tutorial-in.xml:4347(title)
+#: C/gtkmm-tutorial-in.xml:4734(title) C/gtkmm-tutorial-in.xml:5283(title)
+#: C/gtkmm-tutorial-in.xml:6236(title) C/gtkmm-tutorial-in.xml:6305(title)
+#: C/gtkmm-tutorial-in.xml:6913(title) C/gtkmm-tutorial-in.xml:6939(title)
+#: C/gtkmm-tutorial-in.xml:7693(title)
+msgid "Example"
+msgstr "Exemple"
+
+#: C/gtkmm-tutorial-in.xml:687(para)
+msgid "This example creates a button with a picture and a label."
+msgstr "Cet exemple crée un bouton avec image et étiquette."
+
+#: C/gtkmm-tutorial-in.xml:692(title)
+msgid "buttons example"
+msgstr "Exemple de bouton"
+
+#: C/gtkmm-tutorial-in.xml:704(para)
+msgid ""
+"The <classname>Gtk::Button</classname> widget has the following signals, but "
+"most of the time you will just handle the <literal>clicked</literal> signal:"
+msgstr ""
+"L'élément graphique <classname>Gtk::Button</classname> émet les signaux "
+"suivants, mais la plupart du temps vous ne gérerez que le signal "
+"<literal>clicked</literal> (cliqué) :"
+
+#: C/gtkmm-tutorial-in.xml:712(literal)
+msgid "pressed"
+msgstr "pressed (enfoncé)"
+
+#: C/gtkmm-tutorial-in.xml:714(para)
+msgid "Emitted when the button is pressed."
+msgstr "�mis quand le bouton est enfoncé."
+
+#: C/gtkmm-tutorial-in.xml:720(literal)
+msgid "released"
+msgstr "released (relâché)"
+
+#: C/gtkmm-tutorial-in.xml:722(para)
+msgid "Emitted when the button is released."
+msgstr "�mis quand le bouton est relâché."
+
+#: C/gtkmm-tutorial-in.xml:728(literal)
+msgid "clicked"
+msgstr "clicked (cliqué)"
+
+#: C/gtkmm-tutorial-in.xml:730(para)
+msgid "Emitted when the button is pressed and released."
+msgstr "�mis quand le bouton est enfoncé et relâché."
+
+#: C/gtkmm-tutorial-in.xml:736(literal)
+msgid "enter"
+msgstr "enter (entré)"
+
+#: C/gtkmm-tutorial-in.xml:738(para)
+msgid "Emitted when the mouse pointer moves over the button's window."
+msgstr "�mis quand le pointeur de souris entre dans la fenêtre du bouton."
+
+#: C/gtkmm-tutorial-in.xml:744(literal)
+msgid "leave"
+msgstr "leave (quitté)"
+
+#: C/gtkmm-tutorial-in.xml:746(para)
+msgid "Emitted when the mouse pointer leaves the button's window."
+msgstr "�mis lorsque le pointeur de souris sort de la fenêtre du bouton."
+
+#: C/gtkmm-tutorial-in.xml:758(title)
+msgid "ToggleButton"
+msgstr "Bouton bascule"
+
+#: C/gtkmm-tutorial-in.xml:760(para)
+msgid ""
+"<classname>ToggleButton</classname>s are like normal <classname>Button</"
+"classname>s, but when clicked they remain activated, or pressed, until "
+"clicked again."
+msgstr ""
+"Un objet de la classe <classname>ToggleButton</classname> est semblable à un "
+"objet de la classe <classname>Button</classname>, mais les boutons bascules "
+"restent activés, ou enfoncés, jusqu'à ce qu'ils soient à nouveau cliqués. "
+
+#: C/gtkmm-tutorial-in.xml:762(para)
+msgid ""
+"To retrieve the state of the <classname>ToggleButton</classname>, you can "
+"use the <methodname>get_active()</methodname> method. This returns "
+"<literal>true</literal> if the button is \"down\". You can also set the "
+"toggle button's state, with <methodname>set_active()</methodname>. Note "
+"that, if you do this, and the state actually changes, it causes the \"clicked"
+"\" signal to be emitted. This is usually what you want."
+msgstr ""
+"Pour obtenir l'état du <classname>ToggleButton</classname>, utilisez la "
+"fonction membre <methodname>get_active()</methodname>. Elle renvoie "
+"<literal>true</literal> si le bouton est « enfoncé ». Vous pouvez aussi "
+"définir l'état du bouton bascule avec <methodname>set_active()</methodname>. "
+"Notez que, si vous faites cet appel et que l'état du bouton est "
+"effectivement modifié, le signal « clicked » sera émis : ce comportement est "
+"celui habituellement recherché."
+
+#: C/gtkmm-tutorial-in.xml:769(para)
+msgid ""
+"You can use the <methodname>toggled()</methodname> method to toggle the "
+"button, rather than forcing it to be up or down: This switches the button's "
+"state, and causes the <literal>toggled</literal> signal to be emitted."
+msgstr ""
+"Utilisez la fonction membre <methodname>toggled()</methodname> pour inverser "
+"l'état du bouton, au lieu de l'obliger à être enfoncé ou pas : l'état du "
+"bouton est modifié et le signal <literal>toggled</literal> (basculé) est "
+"émis."
+
+#: C/gtkmm-tutorial-in.xml:774(para)
+msgid ""
+"<classname>Gtk::ToggleButton</classname> is most useful as a base class for "
+"the <classname>Gtk::CheckButton</classname> and <classname>Gtk::RadioButton</"
+"classname> classes."
+msgstr ""
+"<classname>Gtk::ToggleButton</classname> est de grande utilité en tant que "
+"classe de base pour les classes <classname>Gtk::CheckButton</classname> et "
+"<classname>Gtk::RadioButton</classname>."
+
+#: C/gtkmm-tutorial-in.xml:785(title) C/gtkmm-tutorial-in.xml:800(title)
+msgid "CheckButton"
+msgstr "Case à cocher"
+
+#: C/gtkmm-tutorial-in.xml:787(para)
+msgid ""
+"<classname>Gtk::CheckButton</classname> inherits from <classname>Gtk::"
+"ToggleButton</classname>. The only real difference between the two is "
+"<classname>Gtk::CheckButton</classname>'s appearance. You can check, set, "
+"and toggle a checkbox using the same member methods as for <classname>Gtk::"
+"ToggleButton</classname>."
+msgstr ""
+"La classe <classname>Gtk::CheckButton</classname> hérite de la classe "
+"<classname>Gtk::ToggleButton</classname>. La seule réelle différence entre "
+"les deux classes se situe au niveau de l'aspect graphique du <classname>Gtk::"
+"CheckButton</classname>. Vous obtenez, définissez et inversez son état à "
+"l'aide des mêmes fonctions membres que <classname>Gtk::ToggleButton</"
+"classname>."
+
+#: C/gtkmm-tutorial-in.xml:812(title) C/gtkmm-tutorial-in.xml:909(title)
+msgid "RadioButton"
+msgstr "Bouton radio"
+
+#: C/gtkmm-tutorial-in.xml:814(para)
+msgid ""
+"Like checkboxes, radio buttons also inherit from <classname>Gtk::"
+"ToggleButton</classname>, but these work in groups, and only one RadioButton "
+"in a group can be selected at any one time."
+msgstr ""
+"De même que les cases à cocher, les boutons radio héritent aussi des "
+"propriétés des <classname>Gtk::ToggleButton</classname>, mais les boutons "
+"radio fonctionnent en groupe et, dans un groupe, un seul et unique bouton "
+"radio peut être sélectionné à un moment donné."
+
+#: C/gtkmm-tutorial-in.xml:820(title)
+msgid "Groups"
+msgstr "Groupes"
+
+#: C/gtkmm-tutorial-in.xml:821(para)
+msgid ""
+"There are two ways to set up a group of radio buttons. The first way is to "
+"create the buttons, and set up their groups afterwards. Only the first two "
+"constructors are used. In the following example, we make a new window class "
+"called <classname>RadioButtons</classname>, and then put three radio buttons "
+"in it:"
+msgstr ""
+"Il y a deux façons de définir un groupe de boutons radio. La première est de "
+"créer les boutons et de définir leur groupement après-coup. Seuls les deux "
+"premiers constructeurs sont utilisés dans ce cas. Dans l'exemple suivant, "
+"nous créons une nouvelle classe de fenêtre nommée <classname>RadioButtons</"
+"classname> dans laquelle nous plaçons trois boutons radio :"
+
+#: C/gtkmm-tutorial-in.xml:829(programlisting)
+#, no-wrap
+msgid ""
+"class RadioButtons : public Gtk::Window\n"
+"{\n"
+"public:\n"
+" RadioButtons();\n"
+"\n"
+"protected:\n"
+" Gtk::RadioButton m_rb1, m_rb2, m_rb3;\n"
+"};\n"
+"\n"
+"RadioButtons::RadioButtons()\n"
+" : m_rb1(\"button1\"),\n"
+" m_rb2(\"button2\"),\n"
+" m_rb3(\"button3\")\n"
+"{\n"
+" Gtk::RadioButton::Group group = m_rb1.get_group();\n"
+" m_rb2.set_group(group);\n"
+" m_rb3.set_group(group);\n"
+"}"
+msgstr ""
+"class RadioButtons : public Gtk::Window\n"
+"{\n"
+"public:\n"
+" RadioButtons();\n"
+"\n"
+"protected:\n"
+" Gtk::RadioButton m_rb1, m_rb2, m_rb3;\n"
+"};\n"
+"\n"
+"RadioButtons::RadioButtons()\n"
+" : m_rb1(\"Bouton1\"),\n"
+" m_rb2(\"Bouton2\"),\n"
+" m_rb3(\"Bouton3\")\n"
+"{\n"
+" Gtk::RadioButton::Group group = m_rb1.get_group();\n"
+" m_rb2.set_group(group);\n"
+" m_rb3.set_group(group);\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:847(para)
+msgid ""
+"We told <application>gtkmm</application> to put all three "
+"<classname>RadioButton</classname>s in the same group by obtaining the group "
+"with <methodname>get_group()</methodname> and using <methodname>set_group()</"
+"methodname> to tell the other <classname>RadioButton</classname>s to share "
+"that group."
+msgstr ""
+"Nous indiquons à <application>gtkmm</application> de placer les trois objets "
+"<classname>RadioButton</classname> dans un même groupe en obtenant un "
+"pointeur sur le groupe avec <methodname>get_group()</methodname> et en "
+"utilisant <methodname>set_group()</methodname> pour faire en sorte que les "
+"autres <classname>RadioButton</classname> partagent le même groupe."
+
+#: C/gtkmm-tutorial-in.xml:856(programlisting)
+#, no-wrap
+msgid "m_rb2.set_group(m_rb1.get_group()); //doesn't work"
+msgstr "m_rb2.set_group(m_rb1.get_group()); // ne fonctionne pas !"
+
+#: C/gtkmm-tutorial-in.xml:854(para)
+msgid ""
+"Note that you can't just do <placeholder-1/> because the group is modified "
+"by <methodname>set_group()</methodname> and therefore non-const."
+msgstr ""
+"Notez qu'il n'est pas possible d'écrire simplement <placeholder-1/> étant "
+"donné que <methodname>set_group()</methodname> modifie le groupe et qu'en "
+"conséquence, le pointeur n'est pas constant."
+
+#: C/gtkmm-tutorial-in.xml:862(para)
+msgid ""
+"The second way to set up radio buttons is to make a group first, and then "
+"add radio buttons to it. Here's an example:"
+msgstr ""
+"La deuxième façon pour grouper des boutons radio consiste à créer un "
+"groupement au préalable, puis y intégrer les boutons. Voici un exemple :"
+
+#: C/gtkmm-tutorial-in.xml:866(programlisting)
+#, no-wrap
+msgid ""
+"class RadioButtons : public Gtk::Window\n"
+"{\n"
+"public:\n"
+" RadioButtons();\n"
+"};\n"
+"\n"
+"RadioButtons::RadioButtons()\n"
+"{\n"
+" Gtk::RadioButton::Group group;\n"
+" Gtk::RadioButton *m_rb1 = Gtk::manage(\n"
+" new Gtk::RadioButton(group,\"button1\"));\n"
+" Gtk::RadioButton *m_rb2 = manage(\n"
+" new Gtk::RadioButton(group,\"button2\"));\n"
+" Gtk::RadioButton *m_rb3 = manage(\n"
+" new Gtk::RadioButton(group,\"button3\"));\n"
+"}"
+msgstr ""
+"class RadioButtons : public Gtk::Window\n"
+"{\n"
+"public:\n"
+" RadioButtons();\n"
+"};\n"
+"\n"
+"RadioButtons::RadioButtons()\n"
+"{\n"
+" Gtk::RadioButton::Group group;\n"
+" Gtk::RadioButton *m_rb1 = Gtk::manage(\n"
+" new Gtk::RadioButton(group,\"Bouton1\"));\n"
+" Gtk::RadioButton *m_rb2 = manage(\n"
+" new Gtk::RadioButton(group,\"Bouton2\"));\n"
+" Gtk::RadioButton *m_rb3 = manage(\n"
+" new Gtk::RadioButton(group,\"Bouton3\"));\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:883(para)
+msgid ""
+"We made a new group by simply declaring a variable, <literal>group</"
+"literal>, of type <classname>Gtk::RadioButton::Group</classname>. Then we "
+"made three radio buttons, using a constructor to make each of them part of "
+"<literal>group</literal>."
+msgstr ""
+"Nous générons un nouveau groupe par une simple déclaration de variable, "
+"<literal>group</literal>, du type <classname>Gtk::RadioButton::Group</"
+"classname>, puis nous créons trois boutons radio avec le constructeur "
+"indiquant qu'ils font partie du groupe <literal>group</literal>."
+
+#: C/gtkmm-tutorial-in.xml:891(title) C/gtkmm-tutorial-in.xml:1373(title)
+#: C/gtkmm-tutorial-in.xml:4605(title)
+msgid "Methods"
+msgstr "Fonctions membres"
+
+#: C/gtkmm-tutorial-in.xml:892(para)
+msgid ""
+"<classname>RadioButtons</classname> are \"off\" when created; this means "
+"that when you first make a group of them, they will all be off. Don't forget "
+"to turn one of them on using <methodname>set_active()</methodname>:"
+msgstr ""
+"� leur création, les objets de la classe <classname>RadioButtons</classname> "
+"sont « inactifs », donc, lors de la création du groupe, tous les boutons sont "
+"désactivés. N'oubliez donc pas d'en activer un avec <methodname>set_active()"
+"</methodname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:903(para)
+msgid ""
+"The following example demonstrates the use of <classname>RadioButton</"
+"classname>s:"
+msgstr ""
+"L'exemple suivant montre l'utilisation de la classe <classname>RadioButton</"
+"classname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:925(title) C/gtkmm-tutorial-in.xml:1074(title)
+msgid "Range Widgets"
+msgstr "�léments graphiques à plage de réglage"
+
+#: C/gtkmm-tutorial-in.xml:927(para)
+msgid ""
+"<classname>Gtk::Scale</classname> and <classname>Gtk::Scrollbar</classname> "
+"both inherit from <classname>Gtk::Range</classname> and share much "
+"functionality. They contain a \"trough\" and a \"slider\" (sometimes called "
+"a \"thumbwheel\" in other GUI environments). Dragging the slider with the "
+"pointer moves it within the trough, while clicking in the trough advances "
+"the slider towards the location of the click, either completely, or by a "
+"designated amount, depending on which mouse button is used. This should be "
+"familiar scrollbar behaviour."
+msgstr ""
+"Les classes <classname>Gtk::Scale</classname> et <classname>Gtk::Scrollbar</"
+"classname> dérivent toutes deux de <classname>Gtk::Range</classname>, elles "
+"partagent un grand nombre de fonctionnalités. Elles comportent une "
+"« glissière » (ou « coulisse ») et un « curseur » (quelquefois nommé « molette » "
+"dans d'autres environnements GUI). Vous déplacez le curseur dans la "
+"glissière en le faisant glisser à l'aide du pointeur de souris ; si vous "
+"cliquez dans la glissière, le curseur avance vers l'endroit cliqué, soit "
+"directement, soit d'un pas donné, selon le bouton de souris utilisé. C'est "
+"le comportement habituel des barres de défilement."
+
+#: C/gtkmm-tutorial-in.xml:938(para)
+msgid ""
+"As will be explained in the <link linkend=\"chapter-adjustment\">Adjustment</"
+"link> section, all Range widgets are associated with a "
+"<classname>Adjustment</classname> object. To change the lower, upper, and "
+"current values used by the widget you need to use the methods of its "
+"<classname>Adjustment</classname>, which you can get with the "
+"<methodname>get_adjustment()</methodname> method. The <classname>Range</"
+"classname> widgets' default constructors create an <classname>Adjustment</"
+"classname> automatically, or you can specify an existing "
+"<classname>Adjustment</classname>, maybe to share it with another widget. "
+"See the <link linkend=\"chapter-adjustment\">Adjustments</link> section for "
+"further details."
+msgstr ""
+"Ainsi que nous l'expliquons dans le chapitre <link linkend=\"chapter-"
+"adjustment\">Ajustements</link>, tous les éléments graphiques à plage de "
+"réglage disposent d'un objet <classname>Adjustment</classname> associé. Pour "
+"modifier les valeurs minimale, maximale ou actuelles associées à la position "
+"du curseur dans l'élément graphique, vous devez utiliser les fonctions "
+"membres de la classe <classname>Adjustment</classname> dont on obtient le "
+"pointeur avec <methodname>get_adjustment()</methodname>. Les constructeurs "
+"d'un élément graphique à plage de réglage créent automatiquement, par "
+"défaut, un objet <classname>Adjustment</classname> ; vous pouvez aussi "
+"désigner un objet <classname>Adjustment</classname> préexistant, en vue peut-"
+"être de le partager avec un autre élément graphique. Consultez le chapitre "
+"<link linkend=\"chapter-adjustment\">Ajustements</link> pour de plus amples "
+"détails."
+
+#: C/gtkmm-tutorial-in.xml:955(title)
+msgid "Scrollbar Widgets"
+msgstr "�léments graphiques barres de défilement"
+
+#: C/gtkmm-tutorial-in.xml:957(para)
+msgid ""
+"These are standard scrollbars. They should be used only to scroll another "
+"widget, such as, a <classname>Gtk::Entry</classname>, or a <classname>Gtk::"
+"Viewport</classname>, though it's usually easier to use the <classname>Gtk::"
+"ScrolledWindow</classname> widget in most cases."
+msgstr ""
+"Ce sont les barres de défilement classiques. Elles ne s'utilisent que pour "
+"déplacer un autre élément graphique, comme un <classname>Gtk::Entry</"
+"classname> ou un <classname>Gtk::Viewport</classname>, même s'il est "
+"habituellement plus facile d'utiliser un élément graphique de la classe "
+"<classname>Gtk::ScrolledWindow</classname> dans la plupart des cas."
+
+#: C/gtkmm-tutorial-in.xml:964(para)
+msgid ""
+"There are horizontal and vertical scrollbar classes - <classname>Gtk::"
+"HScrollbar</classname> and <classname>Gtk::VScrollbar</classname>."
+msgstr ""
+"Il existe une classe pour les barres de défilement horizontal et une classe "
+"pour les barres de défilement vertical â?? <classname>Gtk::HScrollbar</"
+"classname> et <classname>Gtk::VScrollbar</classname>."
+
+#: C/gtkmm-tutorial-in.xml:975(title)
+msgid "Scale Widgets"
+msgstr "�léments graphiques échelles de valeur"
+
+#: C/gtkmm-tutorial-in.xml:977(para)
+msgid ""
+"<classname>Gtk::Scale</classname> widgets (or \"sliders\") allow the user to "
+"visually select and manipulate a value within a specific range. You might "
+"use one, for instance, to adjust the magnification level on a zoomed preview "
+"of a picture, or to control the brightness of a colour, or to specify the "
+"number of minutes of inactivity before a screensaver takes over the screen."
+msgstr ""
+"Les éléments graphiques de la classe <classname>Gtk::Scale</classname> "
+"(« coulisses », « glissières ») permettent à l'utilisateur de sélectionner et "
+"manipuler visuellement une valeur dans une plage donnée. Vous les utilisez, "
+"par exemple, pour ajuster le niveau de zoom de l'aperçu d'une image, pour "
+"contrôler la luminosité d'une couleur ou bien pour définir le nombre de "
+"minutes d'inactivité avant le déclenchement de l'économiseur d'écran."
+
+#: C/gtkmm-tutorial-in.xml:986(para)
+msgid ""
+"As with <classname>Scrollbar</classname>s, there are separate widget types "
+"for horizontal and vertical widgets - <classname>Gtk::HScale</classname> and "
+"<classname>Gtk::VScale</classname>. The default constructors create an "
+"<classname>Adjustment</classname> with all of its values set to "
+"<literal>0.0</literal>. This isn't useful so you will need to set some "
+"<classname>Adjustment</classname> details to get meaningful behaviour."
+msgstr ""
+"Comme pour les objets de la classe <classname>Scrollbar</classname>, il "
+"existe un type distinct pour l'élément graphique d'allure horizontale et "
+"celui d'allure verticale â?? <classname>Gtk::HScale</classname> et "
+"<classname>Gtk::VScale</classname>. Le constructeur par défaut crée un objet "
+"<classname>Adjustment</classname> dont toutes les valeurs sont fixées à "
+"<literal>0,0</literal>. Ce n'est pas utilisable en l'état : vous devez "
+"définir certains détails de l'objet <classname>Adjustment</classname> pour "
+"obtenir un comportement signifiant."
+
+#: C/gtkmm-tutorial-in.xml:996(title)
+msgid "Useful methods"
+msgstr "Fonctions membres utiles"
+
+#: C/gtkmm-tutorial-in.xml:998(para)
+msgid ""
+"<classname>Scale</classname> widgets can display their current value as a "
+"number next to the trough. By default they show the value, but you can "
+"change this with the <methodname>set_draw_value()</methodname> method."
+msgstr ""
+"Les éléments graphiques de la classe <classname>Scale</classname> peuvent "
+"afficher la valeur correspondant à la position actuelle du curseur sous "
+"forme d'un nombre près de la glissière. C'est le comportement par défaut, "
+"mais vous pouvez modifier ce dernier avec la fonction membre "
+"<methodname>set_draw_value()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1004(para)
+msgid ""
+"The value displayed by a scale widget is rounded to one decimal point by "
+"default, as is the <literal>value</literal> field in its <classname>Gtk::"
+"Adjustment</classname>. You can change this with the <methodname>set_digits()"
+"</methodname> method."
+msgstr ""
+"La valeur affichée par un élément graphique coulisse est, par défaut, "
+"arrondie à un chiffre après la virgule ; cette valeur affichée correspond à "
+"celle du champ <literal>value</literal> de l'objet <classname>Gtk::"
+"Adjustment</classname> associé. Vous pouvez modifier la précision avec la "
+"fonction membre <methodname>set_digits()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1011(para)
+msgid ""
+"Also, the value can be drawn in different positions relative to the trough, "
+"specified by the <methodname>set_value_pos()</methodname> method."
+msgstr ""
+"En outre, la valeur peut être placée à diverses positions par rapport à la "
+"glissière ; la position se définit avec la fonction membre "
+"<methodname>set_value_pos()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1022(title)
+msgid "Update Policies"
+msgstr "Politiques de mise à jour"
+
+#: C/gtkmm-tutorial-in.xml:1034(para)
+msgid ""
+"<literal>Gtk::UPDATE_CONTINUOUS</literal> - This is the default. The "
+"<literal>value_changed</literal> signal is emitted continuously, i.e. "
+"whenever the slider is moved by even the tiniest amount."
+msgstr ""
+"<literal>Gtk::UPDATE_CONTINUOUS</literal> â?? C'est la valeur par défaut. Le "
+"signal <literal>value_changed</literal> est émis de manière continue, c'est-"
+"à -dire même si le curseur est déplacé d'une quantité infime."
+
+#: C/gtkmm-tutorial-in.xml:1042(para)
+msgid ""
+"<literal>Gtk::UPDATE_DISCONTINUOUS</literal> - The <literal>value_changed</"
+"literal> signal is only emitted once the slider has stopped moving and the "
+"user has released the mouse button."
+msgstr ""
+"<literal>Gtk::UPDATE_DISCONTINUOUS</literal> â?? Le signal "
+"<literal>value_changed</literal> n'est émis que lorsque le curseur n'est "
+"plus déplacé et que l'utilisateur a relâché le bouton de la souris."
+
+#: C/gtkmm-tutorial-in.xml:1050(para)
+msgid ""
+"<literal>Gtk::UPDATE_DELAYED</literal> - The <literal>value_changed</"
+"literal> signal is emitted when the user releases the mouse button, or if "
+"the slider stops moving for a short period of time."
+msgstr ""
+"<literal>Gtk::UPDATE_DELAYED</literal> â?? Le signal <literal>value_changed</"
+"literal> n'est émis que lorsque l'utilisateur a relâché le bouton de la "
+"souris ou si la coulisse n'est pas déplacée pendant un court délai."
+
+#: C/gtkmm-tutorial-in.xml:1024(para)
+msgid ""
+"The <emphasis>update policy</emphasis> of a <classname>Range</classname> "
+"widget defines at what points during user interaction it will change the "
+"<literal>value</literal> field of its <classname>Gtk::Adjustment</classname> "
+"and emit the <literal>value_changed</literal> signal. The update policies, "
+"set with the <methodname>set_update_policy()</methodname> method, are: "
+"<placeholder-1/>"
+msgstr ""
+"Le <emphasis>principe de mise à jour</emphasis> d'un élément graphique de la "
+"classe <classname>Range</classname> définit le moment où, au cours des "
+"interactions de l'utilisateur, le champ <literal>value</literal> de l'objet "
+"<classname>Gtk::Adjustment</classname> sera modifié et le signal "
+"<literal>value_changed</literal> (valeur modifiée) émis. Les principes de "
+"mises à jour, définis avec la fonction membre <methodname>set_update_policy()"
+"</methodname>, sont les suivants : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:1065(para)
+msgid ""
+"This example displays a window with three range widgets all connected to the "
+"same adjustment, along with a couple of controls for adjusting some of the "
+"parameters mentioned above and in the section on adjustments, so you can see "
+"how they affect the way these widgets work for the user."
+msgstr ""
+"Cet exemple affiche une fenêtre avec trois éléments graphiques coulisses "
+"tous connectés au même ajustement. � côté, sont disposés quelques contrôles "
+"pour ajuster certains paramètres mentionnés plus haut (et rappelés au "
+"chapitre Ajustements)Â : vous pouvez ainsi voir comment ils modifient la "
+"façon dont ces éléments graphiques réagissent vis à vis de l'utilisateur."
+
+#: C/gtkmm-tutorial-in.xml:1087(title)
+msgid "Miscellaneous Widgets"
+msgstr "�léments graphiques divers"
+
+#: C/gtkmm-tutorial-in.xml:1090(title) C/gtkmm-tutorial-in.xml:1128(title)
+msgid "Label"
+msgstr "Ã?tiquette"
+
+#: C/gtkmm-tutorial-in.xml:1092(para)
+msgid ""
+"Labels are the main method of placing non-editable text in windows, for "
+"instance to place a title next to a <classname>Entry</classname> widget. You "
+"can specify the text in the constructor, or later with the "
+"<methodname>set_text()</methodname> or set_markup() methods."
+msgstr ""
+"Les étiquettes sont le moyen essentiel pour placer du texte non-modifiable "
+"dans une fenêtre, par exemple pour placer un intitulé à côté de l'élément "
+"graphique <classname>Entry</classname>. Vous pouvez définir le texte dans le "
+"constructeur ou, plus tard, Ã l'aide des fonctions membres "
+"<methodname>set_text()</methodname> ou <methodname>set_markup()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1099(para)
+msgid ""
+"The width of the label will be adjusted automatically. You can produce multi-"
+"line labels by putting line breaks (\"\\n\") in the label string."
+msgstr ""
+"La largeur de l'étiquette sera ajustée automatiquement. Vous pouvez écrire "
+"des étiquettes sur plusieurs lignes en mettant des sauts de ligne (« \\n ») "
+"dans la chaîne de l'étiquette."
+
+#: C/gtkmm-tutorial-in.xml:1103(para)
+msgid ""
+"The label text can be justified using the <methodname>set_justify()</"
+"methodname> method. The widget is also capable of word-wrapping, which can "
+"be activated with <methodname>set_line_wrap()</methodname>."
+msgstr ""
+"Le texte de l'étiquette peut être justifié avec la fonction membre "
+"<methodname>set_justify()</methodname>. L'élément graphique est également "
+"susceptible de prendre en charge le retour à ligne automatique, "
+"fonctionnalité activée avec la fonction membre <methodname>set_line_wrap()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1109(para)
+msgid ""
+"Gtk::Label support some simple formatting, for instance allowing you to make "
+"some text bold, colored, or larger. You can do this by providing a string to "
+"<methodname>set_markup()</methodname>, using the <ulink url=\"http://library."
+"gnome.org/devel/pango/unstable/PangoMarkupFormat.html\">Pango Markup syntax</"
+"ulink>. For instance, <code> <b>bold text</b> and <s>"
+"strikethrough text</s> </code> ."
+msgstr ""
+"Gtk::Label prend en charge les mises en forme simples comme la graisse, la "
+"couleur et la taille de la police. Il suffit de fournir une chaîne de "
+"caractère à la fonction membre <methodname>set_markup()</methodname> en "
+"utilisant la <ulink url=\"http://library.gnome.org/devel/pango/unstable/"
+"PangoMarkupFormat.html\">syntaxe de balisage Pango</ulink>. Par exemple, "
+"<code> <b>texte gras</b> et <s>texte barré</s> </"
+"code> ."
+
+#: C/gtkmm-tutorial-in.xml:1121(para)
+msgid ""
+"Below is a short example to illustrate these functions. This example makes "
+"use of the Frame widget to better demonstrate the label styles. (The Frame "
+"widget is explained in the <link linkend=\"sec-frame\">Frame</link> section.)"
+msgstr ""
+"Ci-dessous se trouve un court exemple pour illustrer ces fonctions. Cet "
+"exemple utilise l'élément graphique cadre pour mieux séparer les styles "
+"d'étiquettes (l'élément graphique cadre est exposé au paragraphe <link "
+"linkend=\"sec-frame\">Cadre</link>)."
+
+#: C/gtkmm-tutorial-in.xml:1141(title) C/gtkmm-tutorial-in.xml:1183(title)
+msgid "Entry"
+msgstr "Champ de saisie"
+
+#: C/gtkmm-tutorial-in.xml:1144(title)
+msgid "Simple Use"
+msgstr "Utilisation simple"
+
+#: C/gtkmm-tutorial-in.xml:1146(para)
+msgid ""
+"Entry widgets allow the user to enter text. You can change the contents with "
+"the <methodname>set_text()</methodname> method, and read the current "
+"contents with the <methodname>get_text()</methodname> method."
+msgstr ""
+"Les éléments graphiques <classname>Entry</classname> permettent à "
+"l'utilisateur de saisir du texte. Vous pouvez en modifier le contenu avec la "
+"fonction membre <methodname>set_text()</methodname> et en lire le contenu "
+"actuel avec la fonction membre <methodname>get_text()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1151(para)
+msgid ""
+"Occasionally you might want to make an <classname>Entry</classname> widget "
+"read-only. This can be done by passing <literal>false</literal> to the "
+"<methodname>set_editable()</methodname> method."
+msgstr ""
+"Parfois, vous voudrez que le contenu d'un élément graphique "
+"<classname>Entry</classname> soit en lecture seule. Vous obtenez ce résultat "
+"en passant le paramètre <literal>false</literal> à la fonction membre "
+"<methodname>set_editable()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1157(para)
+msgid ""
+"For the input of passwords, passphrases and other information you don't want "
+"echoed on the screen, calling <methodname>set_visibility()</methodname> with "
+"<literal>false</literal> will cause the text to be hidden."
+msgstr ""
+"Pour la saisie de mots de passe, phrases de passe et autres informations que "
+"vous ne souhaitez pas voir reprises à l'affichage, l'appel de la fonction "
+"membre <methodname>set_visibility()</methodname> avec <literal>false</"
+"literal> comme paramètre provoque le masquage du texte."
+
+#: C/gtkmm-tutorial-in.xml:1163(para)
+msgid ""
+"You might want to be notified whenever the user types in a text entry "
+"widget. <classname>Gtk::Entry</classname> provides two signals, "
+"<literal>activate</literal> and <literal>changed</literal>, for just this "
+"purpose. <literal>activate</literal> is emitted when the user presses the "
+"enter key in a text-entry widget; <literal>changed</literal> is emitted when "
+"the text in the widget changes. You can use these, for instance, to validate "
+"or filter the text the user types."
+msgstr ""
+"Vous pouvez vouloir être prévenu chaque fois que l'utilisateur saisit du "
+"texte dans un contrôle de saisie. � cette fin, <classname>Gtk::Entry</"
+"classname> dispose de deux signaux : <literal>activate</literal> (activé) et "
+"<literal>changed</literal> (modifié). <literal>activate</literal> est émis "
+"quand l'utilisateur presse la touche Entrée dans l'élément graphique, "
+"<literal>changed</literal> quand le contenu de l'élément graphique est "
+"modifié. Vous pouvez vous servir de ces signaux, par exemple, pour valider "
+"ou filtrer le texte que l'utilisateur saisit."
+
+#: C/gtkmm-tutorial-in.xml:1175(title)
+msgid "Simple Entry Example"
+msgstr "Exemple simple de saisie"
+
+#: C/gtkmm-tutorial-in.xml:1176(para)
+msgid ""
+"This example uses <classname>Gtk::Entry</classname>. It also has two "
+"<classname>CheckButton</classname>s, with which you can toggle the editable "
+"and visible flags."
+msgstr ""
+"Cet exemple utilise la classe <classname>Gtk::Entry</classname>. Deux cases "
+"Ã cocher de la classe <classname>CheckButton</classname> vous permettent "
+"d'inverser les marqueurs « editable » et « visible »."
+
+#: C/gtkmm-tutorial-in.xml:1196(title) C/gtkmm-tutorial-in.xml:1230(title)
+msgid "Entry Completion"
+msgstr "Complétion de saisie"
+
+#: C/gtkmm-tutorial-in.xml:1197(para)
+msgid ""
+"A <classname>Entry</classname> widget can offer a drop-down list of pre-"
+"existing choices based on the first few characters typed by the user. For "
+"instance, a search dialog could suggest text from previous searches."
+msgstr ""
+"Un élément graphique <classname>Entry</classname> peut offrir une liste "
+"déroulante de choix préétablis à partir des premiers caractères saisis par "
+"l'utilisateur. Par exemple, une boîte de dialogue de recherche peut suggérer "
+"un texte en fonction des recherches antérieures."
+
+#: C/gtkmm-tutorial-in.xml:1202(para)
+msgid ""
+"To enable this functionality, you must create a <classname>EntryCompletion</"
+"classname> object, and provide it to the <classname>Entry</classname> widget "
+"via the <methodname>set_completion()</methodname> method."
+msgstr ""
+"Pour activer cette fonctionnalité, vous devez créer un objet "
+"<classname>EntryCompletion</classname> et le mettre à disposition de "
+"l'élément graphique <classname>Entry</classname> par l'intermédiaire de la "
+"fonction membre <methodname>set_completion()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1207(para)
+msgid ""
+"The <classname>EntryCompletion</classname> may use a <classname>TreeModel</"
+"classname> containing possible entries, specified with <methodname>set_model"
+"()</methodname>. You should then call <methodname>set_text_column()</"
+"methodname> to specify which of your model columns should be used to match "
+"possible text entries."
+msgstr ""
+"L'objet <classname>EntryCompletion</classname> peut utiliser une classe "
+"<classname>TreeModel</classname> contenant les entrées possibles définies à "
+"l'aide de <methodname>set_model()</methodname>. Faites ensuite appel à "
+"<methodname>set_text_column()</methodname> pour définir quelles colonnes de "
+"votre modèle doivent être utilisées pour chercher une possible concordance "
+"avec le texte saisi."
+
+#: C/gtkmm-tutorial-in.xml:1213(para)
+msgid ""
+"Alternatively, if a complete list of possible entries would be too large or "
+"too inconvenient to generate, a callback slot may instead be specified with "
+"<methodname>set_match_func()</methodname>. That callback function. This is "
+"also useful if you wish to match on a part of the string other than the "
+"start."
+msgstr ""
+"Autrement, si la liste complète des saisies possibles est trop grande ou "
+"trop délicate à produire, il est possible de définir l'emplacement d'une "
+"fonction de rappel à l'aide de la fonction membre <methodname>set_match_func"
+"()</methodname>, dont le paramètre est un pointeur sur la-dite fonction de "
+"rappel. Cela peut se révéler utile si vous souhaitez chercher une "
+"concordance sur une partie de chaîne littérale autre que son début."
+
+#: C/gtkmm-tutorial-in.xml:1221(title)
+msgid "Entry Completion Example"
+msgstr "Exemple de complétion de saisie"
+
+#: C/gtkmm-tutorial-in.xml:1222(para)
+msgid ""
+"This example creates a <classname>Gtk::EntryCompletion</classname> and "
+"associates it with a <classname>Gtk::Entry</classname> widget. The "
+"completion uses a <classname>Gtk::TreeModel</classname> of possible entries, "
+"and some additional actions."
+msgstr ""
+"Dans cet exemple, nous créons un objet <classname>Gtk::EntryCompletion</"
+"classname> et nous l'associons à un élément graphique <classname>Gtk::Entry</"
+"classname>. La complétion fait appel à un objet <classname>Gtk::TreeModel</"
+"classname> pour les diverses saisies possibles et quelques actions "
+"supplémentaires."
+
+#: C/gtkmm-tutorial-in.xml:1242(title)
+msgid "Entry Icons"
+msgstr "Icône dans un champ de saisie"
+
+#: C/gtkmm-tutorial-in.xml:1243(para)
+msgid ""
+"An <classname>Entry</classname> widget can show an icon at the start or end "
+"of the text area. The icon can be specifed by methods such as "
+"<methodname>set_icon_from_pixbuf()</methodname> or "
+"<methodname>set_icon_from_stock()</methodname>. An application can respond "
+"to the user pressing the icon by handling the <methodname>signal_icon_press</"
+"methodname> signal."
+msgstr ""
+"Un élément graphique <classname>Entry</classname> peut afficher une icône au "
+"début ou à la fin de la zone de texte. L'icône est définie par des fonctions "
+"membres telles que <methodname>set_icon_from_pixbuf()</methodname> ou "
+"<methodname>set_icon_from_stock()</methodname>. Une application peut "
+"répondre à un utilisateur qui clique sur l'icône en prenant en charge le "
+"signal <methodname>signal_icon_press</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1250(title)
+msgid "Entry Icon Example"
+msgstr "Exemple d'icône dans un champ de saisie"
+
+#: C/gtkmm-tutorial-in.xml:1251(para)
+msgid ""
+"This example shows a <classname>Gtk::Entry</classname> widget with a stock "
+"search icon, and prints text to the terminal when the icon is pressed."
+msgstr ""
+"Cet exemple montre un élément graphique <classname>Gtk::Entry</classname> "
+"avec une icône « rechercher » prise dans le catalogue. Le texte dans le champ "
+"de saisie est reproduit dans la fenêtre du terminal quand l'icône est "
+"cliquée."
+
+#: C/gtkmm-tutorial-in.xml:1257(title)
+msgid "Entry with Icon"
+msgstr "Saisie avec icône"
+
+#: C/gtkmm-tutorial-in.xml:1269(title)
+msgid "Entry Progress"
+msgstr "Saisie avec barre de progression"
+
+#: C/gtkmm-tutorial-in.xml:1270(para)
+msgid ""
+"An <classname>Entry</classname> widget can show a progress bar inside the "
+"text area, under the entered text. The progress bar will be shown if the "
+"<methodname>set_progress_fraction()</methodname> or "
+"<methodname>set_progress_pulse_step()</methodname> methods are called."
+msgstr ""
+"Un élément graphique <classname>Entry</classname> peut afficher une barre de "
+"progression dans la zone de saisie du texte, en arrière plan du texte. La "
+"barre de progression est affichée en faisant appel aux fonctions membres "
+"<methodname>set_progress_fraction()</methodname> ou "
+"<methodname>set_progress_pulse_step()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1275(title)
+msgid "Entry Progress Example"
+msgstr "Exemple de saisie avec barre de progression"
+
+#: C/gtkmm-tutorial-in.xml:1276(para)
+msgid ""
+"This example shows a <classname>Gtk::Entry</classname> widget with a "
+"progress bar."
+msgstr ""
+"Cet exemple montre un élément graphique <classname>Gtk::Entry</classname> "
+"avec barre de progression."
+
+#: C/gtkmm-tutorial-in.xml:1282(title)
+msgid "Entry with Progress Bar"
+msgstr "Saisie avec barre de progression"
+
+#: C/gtkmm-tutorial-in.xml:1296(title) C/gtkmm-tutorial-in.xml:1430(title)
+msgid "SpinButton"
+msgstr "Bouton compteur"
+
+#: C/gtkmm-tutorial-in.xml:1298(para)
+msgid ""
+"A <classname>SpinButton</classname> allows the user to select a value from a "
+"range of numeric values. It has an Entry widget with up and down arrow "
+"buttons at the side. Clicking the buttons causes the value to 'spin' up and "
+"down across the range of possible values. The <classname>Entry</classname> "
+"widget may also be used to enter a value directly."
+msgstr ""
+"Un objet <classname>SpinButton</classname> permet à l'utilisateur de "
+"sélectionner une valeur à l'intérieur d'un segment de valeurs numériques. Il "
+"est constitué d'un contrôle saisie de texte avec des boutons flèche en haut "
+"et flèche en bas sur le côté. Le fait de cliquer sur un des boutons fait "
+"« tourner » la valeur affichée en l'incrémentant ou la décrémentant dans les "
+"limites de la plage des valeurs admises. Il est aussi possible de saisir "
+"directement une valeur dans l'élément <classname>Entry</classname>."
+
+#: C/gtkmm-tutorial-in.xml:1306(para)
+msgid ""
+"The value can have an adjustable number of decimal places, and the step size "
+"is configurable. <classname>SpinButton</classname>s have an 'auto-repeat' "
+"feature as well: holding down one of the arrows can optionally cause the "
+"value to change more quickly the longer the arrow is held down."
+msgstr ""
+"Le nombre de décimales après la virgule de la valeur est ajustable, de même "
+"que la valeur de l'incrément. Le <classname>SpinButton</classname> dispose "
+"d'une fonctionnalité de « répétition automatique » : si l'option est retenue, "
+"le fait de maintenir enfoncée l'une des flèches provoque une accélération "
+"des changements de valeur en fonction de la durée d'appui sur le bouton."
+
+#: C/gtkmm-tutorial-in.xml:1321(para)
+msgid "<literal>value</literal>: value for the Spin Button"
+msgstr "<literal>value</literal>Â : valeur initiale du compteur"
+
+#: C/gtkmm-tutorial-in.xml:1327(para)
+msgid "<literal>lower</literal>: lower range value"
+msgstr "<literal>lower</literal> : limite inférieure de la plage"
+
+#: C/gtkmm-tutorial-in.xml:1333(para)
+msgid "<literal>upper</literal>: upper range value"
+msgstr "<literal>upper</literal> : limite supérieure de la plage"
+
+#: C/gtkmm-tutorial-in.xml:1338(para)
+msgid ""
+"<literal>step_increment</literal>: value to increment/decrement when "
+"pressing mouse button 1 on a button"
+msgstr ""
+"<literal>step_increment</literal> : valeur de l'incrément/ du décrément lors "
+"d'un clic avec le bouton 1 de la souris sur une flèche du compteur"
+
+#: C/gtkmm-tutorial-in.xml:1345(para)
+msgid ""
+"<literal>page_increment</literal>: value to increment/decrement when "
+"pressing mouse button 2 on a button"
+msgstr ""
+"<literal>page_increment</literal> : valeur de l'incrément/de décrément lors "
+"d'un clic avec le bouton 2 de la souris sur une flèche du compteur"
+
+#: C/gtkmm-tutorial-in.xml:1352(para)
+msgid "<literal>page_size</literal>: unused"
+msgstr "<literal>page_size</literal> : inutilisé"
+
+#: C/gtkmm-tutorial-in.xml:1313(para)
+msgid ""
+"<classname>SpinButton</classname>s use an <link linkend=\"chapter-adjustment"
+"\">Adjustment</link> object to hold information about the range of values. "
+"These Adjustment attributes are used by the Spin Button like so: "
+"<placeholder-1/>"
+msgstr ""
+"Un objet <classname>SpinButton</classname> utilise un objet <link linkend="
+"\"chapter-adjustment\">Ajustement</link> pour mémoriser l'information sur la "
+"plage des valeurs permises. Le compteur utilise les attributs de l'objet "
+"Adjustment comme suit : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:1360(para)
+msgid ""
+"Additionally, mouse button 3 can be used to jump directly to the "
+"<literal>upper</literal> or <literal>lower</literal> values."
+msgstr ""
+"De plus, il est possible d'utiliser le bouton 3 de la souris pour sauter "
+"directement aux valeurs <literal>upper</literal> ou <literal>lower</literal>."
+
+#: C/gtkmm-tutorial-in.xml:1365(para)
+msgid ""
+"The <classname>SpinButton</classname> can create a default "
+"<classname>Adjustment</classname>, which you can access via the "
+"<methodname>get_adjustment()</methodname> method, or you can specify an "
+"existing <classname>Adjustment</classname> in the constructor."
+msgstr ""
+"L'objet <classname>SpinButton</classname> crée un objet "
+"<classname>Adjustment</classname> par défaut dont le pointeur est accessible "
+"avec la fonction membre <methodname>get_adjustment()</methodname>. Vous "
+"pouvez également préciser un objet <classname>Adjustment</classname> "
+"existant dans le constructeur."
+
+#: C/gtkmm-tutorial-in.xml:1375(para)
+msgid ""
+"The number of decimal places can be altered using the <methodname>set_digits"
+"()</methodname> method."
+msgstr ""
+"Le nombre de décimales est modifié à l'aide de la fonction membre "
+"<methodname>set_digits()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1380(para)
+msgid ""
+"You can set the spinbutton's value using the <methodname>set_value()</"
+"methodname> method, and retrieve it with <methodname>get_value()</"
+"methodname>."
+msgstr ""
+"Il est possible de définir la valeur du compteur avec la fonction membre "
+"<methodname>set_value()</methodname> et de la récupérer avec "
+"<methodname>get_value()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1385(para)
+msgid ""
+"The <methodname>spin()</methodname> method 'spins' the "
+"<classname>SpinButton</classname>, as if one of its arrows had been clicked. "
+"You need to specify a <classname>Gtk::SpinType</classname> to specify the "
+"direction or new position."
+msgstr ""
+"La fonction membre <methodname>spin()</methodname> fait « tourner » le "
+"<classname>SpinButton</classname>, comme si l'une des flèches avait été "
+"cliquée. Il est nécessaire de préciser un <classname>Gtk::SpinType</"
+"classname> pour définir le sens de modification ou une nouvelle position du "
+"compteur."
+
+#: C/gtkmm-tutorial-in.xml:1392(para)
+msgid ""
+"To prevent the user from typing non-numeric characters into the entry box, "
+"pass <literal>true</literal> to the <methodname>set_numeric()</methodname> "
+"method."
+msgstr ""
+"Pour empêcher l'utilisateur d'entrer des caractères non-numériques dans le "
+"champ de saisie, passez le paramètre <literal>true</literal> à la fonction "
+"membre <methodname>set_numeric()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1397(para)
+msgid ""
+"To make the <classname>SpinButton</classname> 'wrap' between its upper and "
+"lower bounds, use the <methodname>set_wrap()</methodname> method."
+msgstr ""
+"Pour que le <classname>SpinButton</classname> « boucle » de la limite "
+"supérieure à la limite inférieure de la plage de valeurs (et inversement), "
+"utilisez la fonction membre <methodname>set_wrap()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1402(para)
+msgid ""
+"To force it to snap to the nearest <literal>step_increment</literal>, use "
+"<methodname>set_snap_to_ticks()</methodname>."
+msgstr ""
+"Pour forcer le <classname>SpinButton</classname> Ã arrondir sa valeur au "
+"<literal>step_increment</literal> (pas d'incrément) le plus proche, utilisez "
+"la fonction membre <methodname>set_snap_to_ticks()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1407(para)
+msgid ""
+"You can modify the update policy using the <methodname>set_update_policy()</"
+"methodname> method, specifying either <literal>Gtk::UPDATE_ALWAYS</literal> "
+"or <literal>Gtk::UPDATE_IF_VALID</literal>. <literal>Gtk::UPDATE_ALWAYS</"
+"literal> causes the <classname>SpinButton</classname> to ignore errors "
+"encountered while converting the text in the entry box to a numeric value. "
+"This setting also therefore allows the <classname>SpinButton</classname> to "
+"accept non-numeric values. You can force an immediate update using the "
+"<methodname>update()</methodname> method."
+msgstr ""
+"Vous pouvez modifier la politique de mise à jour avec la fonction membre "
+"<methodname>set_update_policy()</methodname> en choisissant, soit "
+"<literal>Gtk::UPDATE_ALWAYS</literal>, soit <literal>Gtk::UPDATE_IF_VALID</"
+"literal>. Si vous sélectionnez <literal>Gtk::UPDATE_ALWAYS</literal>, le "
+"<classname>SpinButton</classname> ignore les erreurs de conversion en valeur "
+"numérique du texte saisi dans la boîte. Par conséquent, ce réglage autorise "
+"le <classname>SpinButton</classname> à accepter également des valeurs non-"
+"numériques. Vous pouvez forcer une mise à jour immédiate avec la fonction "
+"membre <methodname>update()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1425(para)
+msgid "Here's an example of a <classname>SpinButton</classname> in action:"
+msgstr "Voici un exemple de <classname>SpinButton</classname> en action :"
+
+#: C/gtkmm-tutorial-in.xml:1443(title) C/gtkmm-tutorial-in.xml:1496(title)
+msgid "ProgressBar"
+msgstr "Barres de progression"
+
+#: C/gtkmm-tutorial-in.xml:1445(para)
+msgid ""
+"Progress bars are used to show the status of an ongoing operation. For "
+"instance, a <classname>ProgressBar</classname> can show how much of a task "
+"has been completed."
+msgstr ""
+"Les barres de progression s'utilisent pour afficher l'avancement d'une "
+"opération en cours. Par exemple, un objet <classname>ProgressBar</classname> "
+"peut afficher le pourcentage de réalisation d'une tâche."
+
+#: C/gtkmm-tutorial-in.xml:1451(para)
+msgid ""
+"To change the value shown, use the <methodname>set_fraction()</methodname> "
+"method, passing a double between 0 and 1 to provide the new percentage."
+msgstr ""
+"Pour modifier la valeur affichée, utilisez la fonction membre "
+"<methodname>set_fraction()</methodname> Ã laquelle vous passez une valeur de "
+"type double comprise entre 0 et 1 pour définir le nouveau pourcentage."
+
+#: C/gtkmm-tutorial-in.xml:1456(para)
+msgid ""
+"where <literal>percentage</literal> is a number, from 0 to 1, indicating "
+"what fraction of the bar should be filled."
+msgstr ""
+"Le paramètre <literal>percentage</literal> est un nombre, entre 0 et 1, "
+"indiquant la proportion de remplissage de la barre."
+
+#: C/gtkmm-tutorial-in.xml:1461(para)
+msgid ""
+"A <classname>ProgressBar</classname>is horizontal and left-to-right by "
+"default, but you can change it to a vertical progress bar by using the "
+"<methodname>set_orientation()</methodname> method."
+msgstr ""
+"Par défaut, un objet <classname>ProgressBar</classname> est disposé "
+"horizontalement et le remplissage s'effectue de la gauche vers la droite, "
+"mais il est possible de disposer cette barre verticalement avec la fonction "
+"membre <methodname>set_orientation()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1470(title)
+msgid "Activity Mode"
+msgstr "Mode activité"
+
+#: C/gtkmm-tutorial-in.xml:1471(para)
+msgid ""
+"Besides indicating the amount of progress that has occured, the progress bar "
+"can also be used to indicate that there is some activity; this is done by "
+"placing the progress bar in <emphasis>activity mode</emphasis>. In this "
+"mode, the progress bar displays a small rectangle which moves back and "
+"forth. Activity mode is useful in situations where the progress of an "
+"operation cannot be calculated as a value range (e.g., receiving a file of "
+"unknown length)."
+msgstr ""
+"Outre l'indication du taux de progression d'une tâche, la barre de "
+"progression peut aussi s'utiliser pour indiquer qu'il y a une certaine "
+"activité ; cela s'effectue en mettant la barre de progression en "
+"<emphasis>mode activité</emphasis>. Dans ce mode, la barre de progression "
+"affiche un petit rectangle se déplaçant d'une extrémité à l'autre de la "
+"barre. Ce mode est utile dans les cas où le taux de progression d'une "
+"opération ne peut pas être calculé sous forme de valeur numérique (par "
+"exemple, pour la réception d'un fichier de taille inconnue)."
+
+#: C/gtkmm-tutorial-in.xml:1481(para)
+msgid ""
+"To do this, you need to call the <methodname>pulse()</methodname> method at "
+"regular intervals. You can also choose the step size, with the "
+"<methodname>set_pulse_step()</methodname> method."
+msgstr ""
+"Pour basculer dans ce mode, appelez la fonction membre <methodname>pulse()</"
+"methodname> à intervalles réguliers. Vous pourrez aussi choisir la durée des "
+"intervalles d'appel avec <methodname>set_pulse_step()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1487(para)
+msgid ""
+"When in continuous mode, the progress bar can also display a configurable "
+"text string within its trough, using the <methodname>set_text()</methodname> "
+"method."
+msgstr ""
+"En mode continu, la barre de progression peut aussi afficher un texte "
+"configurable dans la glissière, en utilisant la fonction membre "
+"<methodname>set_text()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1510(title) C/gtkmm-tutorial-in.xml:1520(title)
+msgid "InfoBar"
+msgstr "Infobarre"
+
+#: C/gtkmm-tutorial-in.xml:1512(para)
+msgid ""
+"An <classname>InfoBar</classname> may show small items of information or to "
+"ask brief questions. Unlike a <classname>Dialog</classname>, it appears at "
+"the top of the current window instead of opening a new window. Its API is "
+"very similar to the <link linkend=\"chapter-dialogs\">Gtk::Dialog</link> API."
+msgstr ""
+"Un objet <classname>InfoBar</classname> permet d'afficher de courts éléments "
+"d'informations ou de poser de brèves questions. Contrairement à l'objet "
+"<classname>Dialog</classname>, il apparaît au dessus de la fenêtre actuelle "
+"au lieu d'ouvrir une nouvelle fenêtre. Son API est tout à fait semblable à "
+"celle de l'objet <link linkend=\"chapter-dialogs\">Gtk::Dialog</link>."
+
+#: C/gtkmm-tutorial-in.xml:1533(title)
+msgid "Tooltips"
+msgstr "Infobulles"
+
+#: C/gtkmm-tutorial-in.xml:1535(para)
+msgid ""
+"Tooltips are the little information windows that pop up when you leave your "
+"pointer over a widget for a few seconds. Use <methodname>set_tooltip_text()</"
+"methodname> to set a text string as a tooltip on any <classname>Widget</"
+"classname>. <classname>Gtk::ToolItem</classname>s are not <classname>Widget</"
+"classname>s, but have the same method for convenience. <classname>Gtk::"
+"Tooltip</classname> is used for more advanced tooltip usage, such as showing "
+"an image as well as text."
+msgstr ""
+"L'infobulle est un petite fenêtre informative qui apparaît quand vous "
+"laissez votre pointeur de souris sur un élément graphique pendant quelques "
+"secondes. Servez-vous de la fonction membre <methodname>set_tooltip_text()</"
+"methodname> pour définir une chaîne textuelle d'infobulle sur n'importe quel "
+"élément graphique de la classe <classname>Widget</classname>. Les objets "
+"<classname>Gtk::ToolItem</classname> ne sont pas des objets de la classe "
+"<classname>Widget</classname>, mais disposent des mêmes fonctions membres "
+"pour des raisons de commodité. <classname>Gtk::Tooltip</classname> s'utilise "
+"pour une utilisation plus sophistiquée des infobulles, comme l'affichage "
+"d'images et de texte."
+
+#: C/gtkmm-tutorial-in.xml:1545(ulink)
+msgid "Widget Reference"
+msgstr "Référence pour les éléments graphiques"
+
+#: C/gtkmm-tutorial-in.xml:1546(ulink)
+msgid "Tooltip Reference"
+msgstr "Référence Infobulles"
+
+#: C/gtkmm-tutorial-in.xml:1553(title)
+msgid "Container Widgets"
+msgstr "�léments graphiques conteneurs"
+
+#: C/gtkmm-tutorial-in.xml:1555(para)
+msgid ""
+"All container widgets derive from <classname>Gtk::Container</classname>, not "
+"always directly. Some container widgets, such as <classname>Gtk::Table</"
+"classname> can hold many child widgets, so these typically have more complex "
+"interfaces. Others, such as <classname>Gtk::Frame</classname> contain only "
+"one child widget."
+msgstr ""
+"Tous les éléments conteneurs dérivent de la classe <classname>Gtk::"
+"Container</classname>, mais pas toujours directement. Quelques éléments "
+"conteneurs, tels que <classname>Gtk::Table</classname>, peuvent incorporer "
+"plusieurs éléments graphiques enfants ; leur interface est donc bien "
+"évidemment plus complexe. D'autres, comme <classname>Gtk::Frame</classname>, "
+"ne comportent qu'un seul élément graphique enfant."
+
+#: C/gtkmm-tutorial-in.xml:1564(title)
+msgid "Single-item Containers"
+msgstr "Conteneurs mono-éléments"
+
+#: C/gtkmm-tutorial-in.xml:1566(para)
+msgid ""
+"The single-item container widgets derive from <classname>Gtk::Bin</"
+"classname>, which provides the <methodname>add()</methodname> and "
+"<methodname>remove()</methodname> methods for the child widget. Note that "
+"<classname>Gtk::Button</classname> and <classname>Gtk::Window</classname> "
+"are technically single-item containers, but we have discussed them already "
+"elsewhere."
+msgstr ""
+"Les éléments conteneurs mono-éléments dérivent de la classe <classname>Gtk::"
+"Bin</classname>Â ; cette classe comporte les fonctions membres <methodname>add"
+"()</methodname> et <methodname>remove()</methodname> pour les éléments "
+"graphiques enfants. Notez que les objets de la classe <classname>Gtk::"
+"Button</classname> et <classname>Gtk::Window</classname> sont techniquement "
+"des conteneurs mono-éléments ; nous l'avons déjà signalé par ailleurs."
+
+#: C/gtkmm-tutorial-in.xml:1574(para)
+msgid ""
+"We also discuss the <classname>Gtk::Paned</classname> widget, which allows "
+"you to divide a window into two separate \"panes\". This widget actually "
+"contains two child widgets, but the number is fixed so it seems appropriate."
+msgstr ""
+"Nous évoquerons également l'élément graphique <classname>Gtk::Paned</"
+"classname> qui vous permet de partager une fenêtre en deux « volets » "
+"séparés. Cet élément graphique comporte en réalité deux éléments graphiques "
+"enfants, mais comme ce nombre est fixe, son classement dans les mono-"
+"éléments paraît approprié."
+
+#: C/gtkmm-tutorial-in.xml:1581(title) C/gtkmm-tutorial-in.xml:1595(title)
+msgid "Frame"
+msgstr "Cadre"
+
+#: C/gtkmm-tutorial-in.xml:1583(para)
+msgid ""
+"Frames can enclose one or a group of widgets within a box, optionally with a "
+"title. For instance, you might place a group of <classname>RadioButton</"
+"classname>s or <classname>CheckButton</classname>s in a <classname>Frame</"
+"classname>."
+msgstr ""
+"Les cadres, avec un intitulé en option, peuvent entourer un ou un groupe "
+"d'éléments graphiques dans une boîte. Par exemple, vous pouvez placer un "
+"groupe de <classname>RadioButton</classname> ou de <classname>CheckButton</"
+"classname> dans un objet <classname>Frame</classname>."
+
+#: C/gtkmm-tutorial-in.xml:1609(title) C/gtkmm-tutorial-in.xml:1636(title)
+msgid "Paned"
+msgstr "Volets"
+
+#: C/gtkmm-tutorial-in.xml:1611(para)
+msgid ""
+"Panes divide a widget into two halves, separated by a moveable divider. "
+"There are two such widgets: <classname>Gtk::HPaned</classname> adds a "
+"horizontal divider, and <classname>Gtk::VPaned</classname> adds a vertical "
+"one. Other than the names and the orientations, there's no difference "
+"between the two."
+msgstr ""
+"Les volets résultent de la division d'un élément graphique en deux parties "
+"délimitées par une séparation mobile. Il existe deux sortes d'éléments "
+"graphiques de ce type : <classname>Gtk::HPaned</classname> avec une division "
+"horizontale et <classname>Gtk::VPaned</classname> avec une division "
+"verticale."
+
+#: C/gtkmm-tutorial-in.xml:1618(para)
+msgid ""
+"Unlike the other widgets in this chapter, pane widgets contain not one but "
+"two child widgets, one in each pane. Therefore, you should use "
+"<methodname>add1()</methodname> and <methodname>add2()</methodname> instead "
+"of the <methodname>add()</methodname> method."
+msgstr ""
+"Contrairement aux autres éléments graphiques de ce chapitre, les éléments "
+"graphiques à volet comportent non pas un, mais deux éléments graphiques "
+"enfants, un dans chaque volet. C'est pourquoi, vous devez utilisez les "
+"fonctions membres <methodname>add1()</methodname> et <methodname>add2()</"
+"methodname> au lieu de la fonction membre <methodname>add()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1625(para)
+msgid ""
+"You can adjust the position of the divider using the <methodname>set_position"
+"()</methodname> method, and you will probably need to do so."
+msgstr ""
+"Il est possible d'ajuster la position de la division avec la fonction membre "
+"<methodname>set_position()</methodname>Â ; vous aurez certainement besoin de "
+"le faire."
+
+#: C/gtkmm-tutorial-in.xml:1649(title) C/gtkmm-tutorial-in.xml:1681(title)
+msgid "ScrolledWindow"
+msgstr "Fenêtre à défilement"
+
+#: C/gtkmm-tutorial-in.xml:1651(para)
+msgid ""
+"<classname>ScrolledWindow</classname> widgets create a scrollable area. You "
+"can insert any type of widget into a <classname>ScrolledWindow</classname> "
+"window, and it will be accessible regardless of its size by using the "
+"scrollbars. Note that <classname>ScrolledWindow</classname> is not a "
+"<classname>Gtk::Window</classname> despite the slightly misleading name."
+msgstr ""
+"Les éléments graphiques <classname>ScrolledWindow</classname> créent une "
+"zone qu'il est possible de faire défiler. Vous pouvez insérer n'importe quel "
+"type d'élément graphique dans une fenêtre de la classe "
+"<classname>ScrolledWindow</classname> ; cet élément graphique restera "
+"totalement accessible quelle que soit sa taille grâce aux barres de "
+"défilement. Notez que la classe <classname>ScrolledWindow</classname> ne "
+"dérive pas de la classe <classname>Gtk::Window</classname>, même si les "
+"dénominations peuvent prêter à confusion."
+
+#: C/gtkmm-tutorial-in.xml:1660(para)
+msgid ""
+"Scrolled windows have <emphasis>scrollbar policies</emphasis> which "
+"determine whether the <classname>Scrollbar</classname>s will be displayed. "
+"The policies can be set with the <methodname>set_policy()</methodname> "
+"method. The policy may be one of <literal>Gtk::POLICY_AUTOMATIC</literal> or "
+"<literal>Gtk::POLICY_ALWAYS</literal>. <literal>Gtk::POLICY_AUTOMATIC</"
+"literal> will cause the scrolled window to display the scrollbar only if the "
+"contained widget is larger than the visible area. <literal>Gtk::"
+"POLICY_ALWAYS</literal> will cause the scrollbar to be displayed always."
+msgstr ""
+"La fenêtre déroulante définit une <emphasis>politique de barres de "
+"défilement</emphasis> pour indiquer comment son objet <classname>Scrollbar</"
+"classname> doit être affiché. Cette politique est définie à l'aide de la "
+"fonction membre <methodname>set_policy()</methodname>. Le paramètre "
+"<literal>policy</literal> prend l'une des deux valeurs suivantes : "
+"<literal>Gtk::POLICY_AUTOMATIC</literal> ou bien <literal>Gtk::"
+"POLICY_ALWAYS</literal>. <literal>Gtk::POLICY_AUTOMATIC</literal> déclenche "
+"l'affichage de la barre de défilement uniquement si l'élément graphique "
+"incorporé est plus grand que la zone visible. Avec <literal>Gtk::"
+"POLICY_ALWAYS</literal>, les barres de défilement sont toujours affichées."
+
+#: C/gtkmm-tutorial-in.xml:1676(para)
+msgid ""
+"Here is a simple example that packs 100 toggle buttons into a "
+"ScrolledWindow. Try resizing the window to see the scrollbars react."
+msgstr ""
+"Voici un exemple simple qui place 100 boutons bascules dans une fenêtre à "
+"défilement. Essayez de redimensionner la fenêtre pour voir comment les "
+"barres de défilement réagissent."
+
+#: C/gtkmm-tutorial-in.xml:1694(title) C/gtkmm-tutorial-in.xml:1716(title)
+msgid "AspectFrame"
+msgstr "Cadre proportionné"
+
+#: C/gtkmm-tutorial-in.xml:1696(para)
+msgid ""
+"The <classname>AspectFrame</classname> widget looks like a <classname>Frame</"
+"classname> widget, but it also enforces the <emphasis>aspect ratio</"
+"emphasis> (the ratio of the width to the height) of the child widget, adding "
+"extra space if necessary. For instance, this would allow you to display a "
+"photograph without allowing the user to distort it horizontally or "
+"vertically while resizing."
+msgstr ""
+"L'élément graphique de la classe <classname>AspectFrame</classname> est "
+"semblable à l'élément graphique <classname>Frame</classname>, mais, en plus, "
+"il impose à l'élément graphique enfant de garder un rapport de "
+"<emphasis>proportion</emphasis> (rapport de la largeur à la hauteur) "
+"constant ; il laisse un espace libre si nécessaire. Par exemple, vous "
+"pourrez afficher une photographie sans que l'utilisateur puisse la déformer "
+"horizontalement ou verticalement lorsqu'il la redimensionne."
+
+#: C/gtkmm-tutorial-in.xml:1709(para)
+msgid ""
+"The following program uses a <classname>Gtk::AspectFrame</classname> to "
+"present a drawing area whose aspect ratio will always be 2:1, no matter how "
+"the user resizes the top-level window."
+msgstr ""
+"Le programme suivant utilise un objet <classname>Gtk::AspectFrame</"
+"classname> pour afficher une surface de tracé dont les proportions sont "
+"toujours égales à 2:1 quelles que soient les dimensions données à la fenêtre "
+"principale par l'utilisateur."
+
+#: C/gtkmm-tutorial-in.xml:1729(title) C/gtkmm-tutorial-in.xml:1755(title)
+msgid "Alignment"
+msgstr "Alignement"
+
+#: C/gtkmm-tutorial-in.xml:1731(para)
+msgid ""
+"The <classname>Alignment</classname> widget allows you to place a widget at "
+"a position and size relative to the size of the <classname>Alignment</"
+"classname> widget itself. For instance, it might be used to center a widget."
+msgstr ""
+"L'élément conteneur <classname>Alignment</classname> vous permet de placer "
+"dans une fenêtre un élément graphique dont la taille et la position sont "
+"mesurés en rapport de celle du conteneur <classname>Alignment</classname> "
+"lui-même. Par exemple, vous pourrez l'utiliser pour centrer un contrôle."
+
+#: C/gtkmm-tutorial-in.xml:1737(para)
+msgid ""
+"You need to specify the <classname>Alignment</classname>'s characteristics "
+"to the constructor, or to the <methodname>set()</methodname> method. In "
+"particular, you won't notice much effect unless you specify a number other "
+"than 1.0 for the <literal>xscale</literal> and <literal>yscale</literal> "
+"parameters, because 1.0 simply means that the child widget will expand to "
+"fill all available space."
+msgstr ""
+"Il est nécessaire de préciser les caractéristiques de l'objet "
+"<classname>Alignment</classname> dans son constructeur, ou bien à l'aide de "
+"la fonction membre <methodname>set()</methodname>. En particulier, vous ne "
+"noterez aucun effet si vous ne définissez pas un nombre différent de 1.0 "
+"pour les paramètres <literal>xscale</literal> et <literal>yscale</literal> ; "
+"en effet, 1.0 signifie simplement que l'élément graphique enfant doit "
+"prendre tout l'espace disponible."
+
+#: C/gtkmm-tutorial-in.xml:1749(para)
+msgid ""
+"This example right-aligns a button in a window by using an "
+"<classname>Alignment</classname> widget."
+msgstr ""
+"Cet exemple aligne à droite un bouton dans une fenêtre à l'aide de l'élément "
+"conteneur <classname>Alignment</classname>."
+
+#: C/gtkmm-tutorial-in.xml:1763(para)
+msgid ""
+"See the <link linkend=\"sec-progressbar\">ProgressBar</link> section for "
+"another example that uses an <classname>Alignment</classname>."
+msgstr ""
+"Dans le paragraphe sur les <link linkend=\"sec-progressbar\">Barres de "
+"progression</link>, vous pourrez voir un autre exemple d'utilisation de la "
+"classe <classname>Alignment</classname>."
+
+#: C/gtkmm-tutorial-in.xml:1775(title)
+msgid "Multiple-item widgets"
+msgstr "Conteneurs multi-éléments"
+
+#: C/gtkmm-tutorial-in.xml:1777(para)
+msgid ""
+"Multiple-item widgets inherit from <classname>Gtk::Container</classname>; "
+"just as with <classname>Gtk::Bin</classname>, you use the <methodname>add()</"
+"methodname> and <methodname>remove()</methodname> methods to add and remove "
+"contained widgets. Unlike <methodname>Gtk::Bin::remove()</methodname>, "
+"however, the <methodname>remove()</methodname> method for <classname>Gtk::"
+"Container</classname> takes an argument, specifiying which widget to remove."
+msgstr ""
+"Les éléments graphiques conteneurs multi-éléments héritent de la classe "
+"<classname>Gtk::Container</classname>Â ; comme avec <classname>Gtk::Bin</"
+"classname>, vous utilisez les fonctions membres <methodname>add()</"
+"methodname> et <methodname>remove()</methodname> pour ajouter ou supprimer "
+"des éléments graphiques du conteneur. Mais, contrairement à <methodname>Gtk::"
+"Bin::remove()</methodname>, la fonction membre <methodname>remove()</"
+"methodname> de la classe <classname>Gtk::Container</classname> exige un "
+"paramètre désignant l'élément graphique à enlever."
+
+#: C/gtkmm-tutorial-in.xml:1787(title)
+msgid "Packing"
+msgstr "Empaquetage"
+
+#: C/gtkmm-tutorial-in.xml:1788(para)
+msgid ""
+"You've probably noticed that <application>gtkmm</application> windows seem "
+"\"elastic\" - they can usually be stretched in many different ways. This is "
+"due to the <emphasis>widget packing</emphasis> system."
+msgstr ""
+"Vous avez probablement remarqué que les fenêtres <application>gtkmm</"
+"application> semblent « élastiques » â?? elles peuvent être étirées de diverses "
+"manières. Cette propriété résulte du système « d'empaquetage des éléments "
+"graphiques »."
+
+#: C/gtkmm-tutorial-in.xml:1793(para)
+msgid ""
+"Many GUI toolkits require you to precisely place widgets in a window, using "
+"absolute positioning, often using a visual editor. This leads to several "
+"problems:"
+msgstr ""
+"Beaucoup de boîtes à outils GUI exigent que les éléments graphiques soient "
+"placés avec précision dans une fenêtre, avec un positionnement absolu, "
+"souvent en utilisant un utilitaire visuel. Plusieurs problèmes en découlent :"
+
+#: C/gtkmm-tutorial-in.xml:1800(para)
+msgid ""
+"The widgets don't rearrange themselves when the window is resized. Some "
+"widgets are hidden when the window is made smaller, and lots of useless "
+"space appears when the window is made larger."
+msgstr ""
+"Les éléments graphiques ne se réarrangent pas par eux-mêmes quand la fenêtre "
+"est redimensionnée. Certains éléments graphiques sont masqués quand la "
+"fenêtre est rapetissée et des espaces libres inutiles apparaissent quand la "
+"fenêtre est agrandie."
+
+#: C/gtkmm-tutorial-in.xml:1804(para)
+msgid ""
+"It's impossible to predict the amount of space necessary for text after it "
+"has been translated to other languages, or displayed in a different font. On "
+"Unix it is also impossible to anticipate the effects of every theme and "
+"window manager."
+msgstr ""
+"Il n'est pas possible de prévoir l'espace nécessaire à un texte après "
+"traduction en d'autres langues ou après affichage avec une police "
+"différente. Sur Unix, il est également impossible d'anticiper les effets de "
+"chaque thème ou de chaque gestionnaire de fenêtres."
+
+#: C/gtkmm-tutorial-in.xml:1808(para)
+msgid ""
+"Changing the layout of a window \"on the fly\", to make some extra widgets "
+"appear, for instance, is complex. It requires tedious recalculation of every "
+"widget's position."
+msgstr ""
+"Modifier la disposition d'une fenêtre « à la volée », pour faire apparaître "
+"quelques éléments graphiques supplémentaires, par exemple, est compliqué. "
+"Cela demande un nouveau calcul ennuyeux de la position de chaque élément "
+"graphique."
+
+#: C/gtkmm-tutorial-in.xml:1814(para)
+msgid ""
+"<application>gtkmm</application> uses the packing system to solve these "
+"problems. Rather than specifying the position and size of each widget in the "
+"window, you can arrange your widgets in rows, columns, and/or tables. "
+"<application>gtkmm</application> can size your window automatically, based "
+"on the sizes of the widgets it contains. And the sizes of the widgets are, "
+"in turn, determined by the amount of text they contain, or the minimum and "
+"maximum sizes that you specify, and/or how you have requested that the "
+"available space should be shared between sets of widgets. You can perfect "
+"your layout by specifying padding distance and centering values for each of "
+"your widgets. <application>gtkmm</application> then uses all this "
+"information to resize and reposition everything sensibly and smoothly when "
+"the user manipulates the window."
+msgstr ""
+"<application>gtkmm</application> utilise un système d'empaquetage pour "
+"résoudre ces problèmes. Plutôt que de définir la position et la taille de "
+"chaque élément graphique dans la fenêtre, vous pouvez les disposer en "
+"rangées, en colonnes ou en tableaux. <application>gtkmm</application> "
+"dimensionne votre fenêtre automatiquement, selon la taille des éléments "
+"graphiques qu'elle contient. Les tailles des éléments graphiques sont, à "
+"leur tour, déterminées par la quantité de texte contenue ou bien par les "
+"tailles minimales ou maximales fixées de même que par les règles voulues "
+"pour le partage des espaces libres entre les jeux d'éléments graphiques. "
+"Vous pouvez parfaire la disposition en définissant les dimensions des "
+"remplissages et des valeurs de centrage pour chacun des éléments graphiques. "
+"<application>gtkmm</application> utilise ces informations pour "
+"redimensionner et repositionner chaque élément intelligemment et souplement "
+"quand l'utilisateur manipule la fenêtre."
+
+#: C/gtkmm-tutorial-in.xml:1823(para)
+msgid ""
+"<application>gtkmm</application> arranges widgets hierarchically, using "
+"<emphasis>containers</emphasis>. A Container widget contains other widgets. "
+"Most <application>gtkmm</application> widgets are containers. Windows, "
+"Notebook tabs, and Buttons are all container widgets. There are two flavours "
+"of containers: single-child containers, which are all descendants of "
+"<classname>Gtk::Bin</classname>, and multiple-child containers, which are "
+"descendants of <classname>Gtk::Container</classname>. Most widgets in "
+"<application>gtkmm</application> are descendants of <classname>Gtk::Bin</"
+"classname>, including <classname>Gtk::Window</classname>."
+msgstr ""
+"<application>gtkmm</application> dispose les éléments graphiques de manière "
+"hiérarchique en utilisant des <emphasis>conteneurs</emphasis>. Un élément "
+"graphique conteneur contient d'autres éléments graphiques. La plupart des "
+"éléments graphiques <application>gtkmm</application> sont des conteneurs. "
+"Fenêtres, onglets de bloc-notes et boutons sont tous des éléments graphiques "
+"conteneurs. Il existe deux sortes de conteneurs : les conteneurs mono-"
+"enfant, qui dérivent tous de la classe <classname>Gtk::Bin</classname> et "
+"les conteneurs multi-enfants qui héritent de la classe <classname>Gtk::"
+"Container</classname>. La plupart des éléments graphiques de "
+"<application>gtkmm</application> dérivent de la classe <classname>Gtk::Bin</"
+"classname>, y compris <classname>Gtk::Window</classname>."
+
+#: C/gtkmm-tutorial-in.xml:1834(para)
+msgid ""
+"Yes, that's correct: a Window can contain at most one widget. How, then, can "
+"we use a window for anything useful? By placing a multiple-child container "
+"in the window. The most useful container widgets are <classname>Gtk:VBox</"
+"classname>, <classname>Gtk::HBox</classname>, and <classname>Gtk::Table</"
+"classname>."
+msgstr ""
+"Oui, ceci est correct : un objet Window peut contenir au plus un élément "
+"graphique. Comment, alors, se servir utilement d'une fenêtre ? En y plaçant "
+"un conteneur multi-enfants. Les conteneurs d'éléments graphiques les plus "
+"utiles sont les objets <classname>Gtk:VBox</classname>, <classname>Gtk::"
+"HBox</classname> et <classname>Gtk::Table</classname>."
+
+#: C/gtkmm-tutorial-in.xml:1846(para)
+msgid ""
+"<classname>Gtk::VBox</classname> and <classname>Gtk::HBox</classname> "
+"arrange their child widgets vertically and horizontally, respectively. Use "
+"<methodname>pack_start()</methodname> and <methodname>pack_end()</"
+"methodname> to insert child widgets."
+msgstr ""
+"<classname>Gtk::VBox</classname> et <classname>Gtk::HBox</classname> "
+"disposent respectivement leurs éléments graphiques enfants verticalement et "
+"horizontalement. Utilisez <methodname>pack_start()</methodname> et "
+"<methodname>pack_end()</methodname> pour insérer des éléments graphiques "
+"enfants."
+
+#: C/gtkmm-tutorial-in.xml:1855(para)
+msgid ""
+"<classname>Gtk::Table</classname> arranges its widgets in a grid. Use "
+"<methodname>attach()</methodname> to insert widgets."
+msgstr ""
+"<classname>Gtk::Table</classname> place ses éléments graphiques sur une "
+"grille. Utilisez <methodname>attach()</methodname> pour insérer les éléments "
+"graphiques."
+
+#: C/gtkmm-tutorial-in.xml:1863(para)
+msgid "There are several other containers, which we will also discuss."
+msgstr "Il existe plusieurs autres conteneurs. Nous en parlerons également."
+
+#: C/gtkmm-tutorial-in.xml:1867(para)
+msgid ""
+"If you've never used a packing toolkit before, it can take some getting used "
+"to. You'll probably find, however, that you don't need to rely on visual "
+"form editors quite as much as you might with other toolkits."
+msgstr ""
+"Si vous n'avez jamais utilisé auparavant un utilitaire d'empaquetage, son "
+"utilisation nécessitera une prise en main. Toutefois, vous constaterez "
+"probablement que, contrairement à d'autres boîtes à outils, il n'y a pas "
+"besoin de faire appel à un éditeur de type visuel."
+
+#: C/gtkmm-tutorial-in.xml:1877(title)
+msgid "An improved Hello World"
+msgstr "Un Hello World amélioré"
+
+#: C/gtkmm-tutorial-in.xml:1879(para)
+msgid ""
+"Let's take a look at a slightly improved <literal>helloworld</literal>, "
+"showing what we've learnt."
+msgstr ""
+"Regardons un <literal>helloworld</literal> légèrement perfectionné en se "
+"servant de nos nouvelles connaissances."
+
+#: C/gtkmm-tutorial-in.xml:1884(title)
+msgid "Hello World 2"
+msgstr "Hello World 2"
+
+#: C/gtkmm-tutorial-in.xml:1892(para)
+msgid ""
+"After building and running this program, try resizing the window to see the "
+"behaviour. Also, try playing with the options to <methodname>pack_start()</"
+"methodname> while reading the <link linkend=\"sec-boxes\">Boxes</link> "
+"section."
+msgstr ""
+"Après avoir construit et lancé ce programme, essayez de redimensionner la "
+"fenêtre pour voir son comportement. �galement, essayez de jouer avec les "
+"options de la fonction membre <methodname>pack_start()</methodname> après "
+"avoir lu le paragraphe relatif aux <link linkend=\"sec-boxes\">boîtes</link>."
+
+#: C/gtkmm-tutorial-in.xml:1902(title)
+msgid "Boxes"
+msgstr "Boîtes"
+
+#: C/gtkmm-tutorial-in.xml:1904(para)
+msgid ""
+"Most packing uses boxes as in the above example. These are invisible "
+"containers into which we can pack our widgets. When packing widgets into a "
+"horizontal box, the objects are inserted horizontally from left to right or "
+"right to left depending on whether <methodname>pack_start()</methodname> or "
+"<methodname>pack_end()</methodname> is used. In a vertical box, widgets are "
+"packed from top to bottom or vice versa. You may use any combination of "
+"boxes inside or beside other boxes to create the desired effect."
+msgstr ""
+"Beaucoup d'empaquetages utilisent des boîtes comme dans l'exemple précédent. "
+"Ce sont des conteneurs invisibles dans lesquels nous pouvons placer les "
+"éléments graphiques. Si nous empaquetons dans une boîte horizontale, les "
+"objets seront insérés horizontalement de la gauche vers la droite ou "
+"inversement selon que l'on utilise <methodname>pack_start()</methodname> ou "
+"<methodname>pack_end()</methodname>. Dans une boîte verticale, les éléments "
+"graphiques sont empaquetés du haut vers le bas ou vice versa. Vous pouvez "
+"utiliser toute combinaison de boîtes dans ou à côté d'autres boîtes pour "
+"créer les effets voulus."
+
+#: C/gtkmm-tutorial-in.xml:1915(title) C/gtkmm-tutorial-in.xml:2107(title)
+msgid "Adding widgets"
+msgstr "Ajout d'éléments graphiques"
+
+#: C/gtkmm-tutorial-in.xml:1916(title)
+msgid "Per-child packing options"
+msgstr "Options d'empaquetage par enfant"
+
+#: C/gtkmm-tutorial-in.xml:1917(para)
+msgid ""
+"The <methodname>pack_start()</methodname> and <methodname>pack_end()</"
+"methodname> methods place widgets inside these containers. The "
+"<methodname>pack_start()</methodname> method will start at the top and work "
+"its way down in a <classname>VBox</classname>, or pack left to right in an "
+"<classname>HBox</classname>. <methodname>pack_end()</methodname> will do the "
+"opposite, packing from bottom to top in a <classname>VBox</classname>, or "
+"right to left in an <classname>HBox</classname>. Using these methods allows "
+"us to right justify or left justify our widgets. We will use "
+"<methodname>pack_start()</methodname> in most of our examples."
+msgstr ""
+"Les fonctions membres <methodname>pack_start()</methodname> et "
+"<methodname>pack_end()</methodname> placent les éléments graphiques dans ces "
+"conteneurs. La fonction membre <methodname>pack_start()</methodname> débute "
+"l'insertion en haut de l'objet <classname>VBox</classname> et va en "
+"descendant ; elle empaquette de gauche vers la droite dans un objet "
+"<classname>HBox</classname>. La fonction membre <methodname>pack_end()</"
+"methodname> fait l'inverse. Elle empaquette de bas en haut dans un "
+"<classname>VBox</classname>, de droite à gauche dans un <classname>HBox</"
+"classname>. L'utilisation de ces fonctions membres vous permet de justifier "
+"à droite ou à gauche les éléments graphiques. Nous nous servirons de "
+"<methodname>pack_start()</methodname> dans la plupart de nos exemples."
+
+#: C/gtkmm-tutorial-in.xml:1930(para)
+msgid ""
+"There are several options governing how widgets are to be packed, and this "
+"can be confusing at first. If you have difficulties then it is sometimes a "
+"good idea to play with the <application>glade</application> GUI designer to "
+"see what is possible. You might even decide to use the <application>Gtk::"
+"Builder</application> API to load your GUI at runtime."
+msgstr ""
+"Il y a plusieurs options régissant la manière dont les éléments graphiques "
+"doivent être empaquetés ; cela peut sembler confus au début. Si vous avez "
+"des difficultés, nous vous suggérons l'idée de manipuler le concepteur GUI "
+"<application>glade</application> pour voir ce qui est possible. Vous pourrez "
+"même décider d'utiliser l'API <application>Gtk::Builder</application> pour "
+"charger les interfaces utilisateur au lancement du programme."
+
+#: C/gtkmm-tutorial-in.xml:1938(para)
+msgid "There are basically five different styles, as shown in this picture:"
+msgstr ""
+"� la base, il y cinq styles différents comme illustré dans cette figure :"
+
+#: C/gtkmm-tutorial-in.xml:1944(title)
+msgid "Box Packing 1"
+msgstr "Empaquetage dans boîte n°1"
+
+#: C/gtkmm-tutorial-in.xml:1950(para)
+msgid ""
+"Each line contains one horizontal box (<classname>HBox</classname>) with "
+"several buttons. Each of the buttons on a line is packed into the "
+"<classname>HBox</classname> with the same arguments to the "
+"<methodname>pack_start()</methodname> method)."
+msgstr ""
+"Chaque ligne est constituée d'une boîte horizontale (<classname>HBox</"
+"classname>) avec plusieurs boutons. Chacun des boutons de la ligne est "
+"empaqueté dans l'objet <classname>HBox</classname> avec les mêmes paramètres "
+"Ã l'aide de la fonction membre <methodname>pack_start()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:1957(para)
+msgid ""
+"This is the declaration of the <methodname>pack_start()</methodname> method:"
+msgstr ""
+"Voici la déclaration de la fonction membre <methodname>pack_start()</"
+"methodname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:1960(programlisting)
+#, no-wrap
+msgid ""
+"void pack_start(Gtk::Widget& child,\n"
+" PackOptions options = PACK_EXPAND_WIDGET,\n"
+" guint padding = 0);"
+msgstr ""
+"void pack_start(Gtk::Widget& child,\n"
+" PackOptions options = PACK_EXPAND_WIDGET,\n"
+" guint padding = 0);"
+
+#: C/gtkmm-tutorial-in.xml:1964(para)
+msgid ""
+"The first argument is the widget you're packing. In our example these are "
+"all <classname>Button</classname>s."
+msgstr ""
+"Le premier paramètre désigne l'élément graphique à empaquer. Dans notre "
+"exemple, ce sont tous des objets <classname>Button</classname>."
+
+#: C/gtkmm-tutorial-in.xml:1971(para)
+msgid ""
+"<literal>PACK_SHRINK</literal>: Space is contracted to the child widget "
+"size. The widget will take up just-enough space and never expand."
+msgstr ""
+"<literal>PACK_SHRINK</literal> : l'espace est condensé à la taille des "
+"éléments graphiques enfants. L'élément graphique prend la place qui lui est "
+"juste nécessaire et n'est jamais étiré."
+
+#: C/gtkmm-tutorial-in.xml:1972(para)
+msgid ""
+"<literal>PACK_EXPAND_PADDING</literal>: Extra space is filled with padding. "
+"The widgets will be spaced out evenly, but their sizes won't change - there "
+"will be empty space between the widgets instead."
+msgstr ""
+"<literal>PACK_EXPAND_PADDING</literal> : l'espace excédentaire est constitué "
+"de remplissage. Les éléments graphiques sont régulièrement espacés, mais "
+"leurs tailles ne varient pas â?? des espaces vides sont ménagés entre éléments "
+"graphiques."
+
+#: C/gtkmm-tutorial-in.xml:1973(para)
+msgid ""
+"<literal>PACK_EXPAND_WIDGET</literal>: Extra space is taken up by increasing "
+"the child widget size, without changing the amount of space between widgets."
+msgstr ""
+"<literal>PACK_EXPAND_WIDGET</literal> : l'espace excédentaire est occupé par "
+"une augmentation de la taille des éléments graphiques enfants, sans modifier "
+"la répartition de l'espacement entre éléments graphiques."
+
+#: C/gtkmm-tutorial-in.xml:1968(para)
+msgid ""
+"The <parameter>options</parameter> argument can take one of these three "
+"options: <placeholder-1/>"
+msgstr ""
+"Le paramètre <parameter>options</parameter> peut prendre une des trois "
+"valeurs suivantes : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:1977(para)
+msgid ""
+"The <parameter>padding</parameter> argument specifies the width of an extra "
+"border area to leave around the packed widget."
+msgstr ""
+"Le paramètre <parameter>padding</parameter> définit la largeur de la bordure "
+"libre autour de l'élément graphique empaqueté."
+
+#: C/gtkmm-tutorial-in.xml:1986(title)
+msgid "Per-container packing options"
+msgstr "Options d'empaquetage par conteneur"
+
+#: C/gtkmm-tutorial-in.xml:1989(programlisting)
+#, no-wrap
+msgid "Gtk::Box(bool homogeneous = false, int spacing = 0);"
+msgstr "Gtk::Box(bool homogeneous = false, int spacing = 0);"
+
+#: C/gtkmm-tutorial-in.xml:1987(para)
+msgid ""
+"Here's the constructor for the box widgets: <placeholder-1/> Passing "
+"<literal>true</literal> for <parameter>homogeneous</parameter> will cause "
+"all of the contained widgets to be the same size. <parameter>spacing</"
+"parameter> is a (minimum) number of pixels to leave between each widget."
+msgstr ""
+"Voici le constructeur des éléments graphiques de la boîte : <placeholder-1/> "
+"Si le paramètre <parameter>homogeneous</parameter> est défini à "
+"<literal>true</literal>, tous les éléments graphiques de la boîte auront la "
+"même taille. <parameter>spacing</parameter> représente le nombre de pixels "
+"(minimum) à laisser entre chaque élément graphique."
+
+#: C/gtkmm-tutorial-in.xml:1996(para)
+msgid ""
+"What's the difference between spacing (set when the box is created) and "
+"padding (set when elements are packed)? Spacing is added between objects, "
+"and padding is added on either side of a widget. The following figure should "
+"make it clearer:"
+msgstr ""
+"Quelle est la différence entre espacement (déterminé quand la boîte est "
+"crée) et remplissage (défini quand les éléments sont empaquetés) ? "
+"L'espacement est inséré entre les objets alors que le remplissage est ajouté "
+"sur les côtés du élément graphique. L'illustration ci-après clarifie cela :"
+
+#: C/gtkmm-tutorial-in.xml:2004(title)
+msgid "Box Packing 2"
+msgstr "Empaquetage dans boîte n°2"
+
+#: C/gtkmm-tutorial-in.xml:2015(para)
+msgid ""
+"Here is the source code for the example that produced the screenshots above. "
+"When you run this example, provide a number between 1 and 3 as a command-"
+"line option, to see different packing options in use."
+msgstr ""
+"Voici le code source de l'exemple qui a servi à générer la capture d'écran "
+"ci-dessus. Quand vous lancez cet exemple, indiquez un nombre entre 1 et 3 en "
+"option de ligne de commande pour voir les diverses options d'empaquetage "
+"utilisées."
+
+#: C/gtkmm-tutorial-in.xml:2024(title)
+msgid "ButtonBoxes"
+msgstr "Boîtes à boutons"
+
+#: C/gtkmm-tutorial-in.xml:2026(para)
+msgid ""
+"Button boxes are a convenient way to quickly arrange a group of buttons. "
+"They come in both horizontal (<classname>Gtk::HButtonBox</classname>) and "
+"vertical (<classname>Gtk::VButtonBox</classname>) flavours. They are exactly "
+"alike, except in name and orientation."
+msgstr ""
+"Les boîtes à boutons sont un moyen commode de disposer rapidement un groupe "
+"de boutons. Il en existe deux types : un horizontal (<classname>Gtk::"
+"HButtonBox</classname>) et un vertical (<classname>Gtk::VButtonBox</"
+"classname>). Ils sont tout à fait semblables ; ils ne différent que par leur "
+"nom et leur orientation."
+
+#: C/gtkmm-tutorial-in.xml:2033(para)
+msgid ""
+"<classname>ButtonBox</classname>es help to make applications appear "
+"consistent because they use standard settings, such as inter-button spacing "
+"and packing."
+msgstr ""
+"Les <classname>ButtonBox</classname> donnent une apparence homogène aux "
+"applications en utilisant des réglages normalisés pour l'espacement entre "
+"boutons et pour l'empaquetage."
+
+#: C/gtkmm-tutorial-in.xml:2038(para)
+msgid ""
+"Buttons are added to a <classname>ButtonBox</classname> with the "
+"<methodname>add()</methodname> method."
+msgstr ""
+"Les boutons sont insérés dans l'objet <classname>ButtonBox</classname> à "
+"l'aide de la fonction membre <methodname>add()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2043(para)
+msgid ""
+"Button boxes support several layout styles. The style can be retrieved and "
+"changed using <methodname>get_layout()</methodname> and "
+"<methodname>set_layout()</methodname>."
+msgstr ""
+"Les boîtes à boutons prennent en charge divers styles de dispositions. Le "
+"style peut être obtenu et modifié avec les fonctions membres "
+"<methodname>get_layout()</methodname> et <methodname>set_layout()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2055(title)
+msgid "ButtonBox"
+msgstr "Boîte à bouton"
+
+#: C/gtkmm-tutorial-in.xml:2068(title) C/gtkmm-tutorial-in.xml:2214(title)
+msgid "Table"
+msgstr "Tableau"
+
+#: C/gtkmm-tutorial-in.xml:2070(para)
+msgid "Tables allows us to place widgets in a grid."
+msgstr ""
+"Les tableaux permettent de placer les éléments graphiques sur une grille."
+
+#: C/gtkmm-tutorial-in.xml:2074(title)
+msgid "Constructor"
+msgstr "Constructeur"
+
+#: C/gtkmm-tutorial-in.xml:2075(para)
+msgid "The grid's dimensions need to be specified in the constructor:"
+msgstr ""
+"Il est nécessaire de définir les dimensions de la grille dans le "
+"constructeur :"
+
+#: C/gtkmm-tutorial-in.xml:2078(programlisting)
+#, no-wrap
+msgid "Gtk::Table(int rows = 1, int columns = 1, bool homogeneous = false);"
+msgstr "Gtk::Table(int rows = 1, int columns = 1, bool homogeneous = false);"
+
+#: C/gtkmm-tutorial-in.xml:2080(para)
+msgid ""
+"The first argument is the number of rows to make in the table, while the "
+"second, obviously, is the number of columns. If <parameter>homogeneous</"
+"parameter> is <literal>true</literal>, the table cells will all be the same "
+"size (the size of the largest widget in the table)."
+msgstr ""
+"Le premier paramètre est le nombre de lignes du tableau, le second le nombre "
+"de colonnes. Si <parameter>homogeneous</parameter> est égal à <literal>true</"
+"literal>, toutes les cellules du tableau auront la même taille (la taille du "
+"plus grand élément graphique du tableau)."
+
+#: C/gtkmm-tutorial-in.xml:2087(para)
+msgid ""
+"The rows and columns are indexed starting at 0. If you specify "
+"<parameter>rows</parameter> = 2 and <parameter>columns</parameter> = 2, the "
+"layout would look something like this:"
+msgstr ""
+"Les lignes et les colonnes sont numérotées à partir de zéro. Si vous "
+"définissez <parameter>rows</parameter> = 2 et <parameter>columns</parameter> "
+"= 2, la disposition ressemble à ceci :"
+
+#: C/gtkmm-tutorial-in.xml:2093(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+" 0 1 2\n"
+"0+----------+----------+\n"
+" | | |\n"
+"1+----------+----------+\n"
+" | | |\n"
+"2+----------+----------+\n"
+msgstr ""
+"\n"
+" 0 1 2\n"
+"0+----------+----------+\n"
+" | | |\n"
+"1+----------+----------+\n"
+" | | |\n"
+"2+----------+----------+\n"
+
+#: C/gtkmm-tutorial-in.xml:2102(para)
+msgid "Note that the coordinate system starts in the upper left hand corner."
+msgstr ""
+"Notez que l'origine du système de coordonnées est l'angle supérieur gauche."
+
+#: C/gtkmm-tutorial-in.xml:2108(para)
+msgid "To place a widget into a box, use the following method:"
+msgstr ""
+"Pour placer un élément graphique dans une cellule, utilisez la fonction "
+"membre suivante :"
+
+#: C/gtkmm-tutorial-in.xml:2111(programlisting)
+#, no-wrap
+msgid ""
+"void Gtk::Table::attach(Gtk::Widget& child,\n"
+" guint left_attach, guint right_attach,\n"
+" guint top_attach, guint bottom_attach,\n"
+" guint xoptions = Gtk::FILL | Gtk::EXPAND,\n"
+" guint yoptions = Gtk::FILL | Gtk::EXPAND,\n"
+" guint xpadding = 0, guint ypadding = 0);"
+msgstr ""
+"void Gtk::Table::attach(Gtk::Widget& child,\n"
+" guint left_attach, guint right_attach,\n"
+" guint top_attach, guint bottom_attach,\n"
+" guint xoptions = Gtk::FILL | Gtk::EXPAND,\n"
+" guint yoptions = Gtk::FILL | Gtk::EXPAND,\n"
+" guint xpadding = 0, guint ypadding = 0);"
+
+#: C/gtkmm-tutorial-in.xml:2117(para)
+msgid "The first argument is the widget you wish to place in the table."
+msgstr ""
+"Le premier paramètre est l'élément graphique que vous souhaitez placer dans "
+"la table."
+
+#: C/gtkmm-tutorial-in.xml:2121(para)
+msgid ""
+"The <parameter>left_attach</parameter> and <parameter>right_attach</"
+"parameter> arguments specify where to place the widget, and how many boxes "
+"to use. For example, if you want a button in the lower-right cell of a 2 x 2 "
+"table, and want it to occupy that cell <emphasis>only</emphasis>, then "
+"<parameter>left_attach</parameter> would be 1, <parameter>right_attach</"
+"parameter> 2, <parameter>top_attach</parameter> 1, and "
+"<parameter>bottom_attach</parameter> 2. If, on the other hand, you wanted a "
+"widget to take up the entire top row of our 2 x 2 table, you'd set "
+"<parameter>left_attach</parameter> = 0, <parameter>right_attach</parameter> "
+"= 2, <parameter>top_attach</parameter> = 0, and <parameter>bottom_attach</"
+"parameter> = 1."
+msgstr ""
+"Les paramètres <parameter>left_attach</parameter> et "
+"<parameter>right_attach</parameter> indiquent où placer l'élément graphique "
+"et combien de cellules utiliser. Par exemple, si vous voulez placer un "
+"bouton dans la cellule inférieure droite d'un tableau 2 x 2 et souhaitez "
+"qu'il occupe <emphasis>uniquement</emphasis> cette cellule, alors "
+"<parameter>left_attach</parameter> doit être égal à 1, "
+"<parameter>right_attach</parameter> Ã 2, <parameter>top_attach</parameter> Ã "
+"1 et <parameter>bottom_attach</parameter> Ã 2. Si, d'autre part, vous "
+"souhaitez que l'élément graphique occupe la totalité de la rangée haute du "
+"tableau 2 x 2, vous définirez <parameter>left_attach</parameter> = 0, "
+"<parameter>right_attach</parameter> = 2, <parameter>top_attach</parameter> = "
+"0 et <parameter>bottom_attach</parameter> = 1."
+
+#: C/gtkmm-tutorial-in.xml:2137(para)
+msgid ""
+"<parameter>xoptions</parameter> and <parameter>yoptions</parameter> are used "
+"to specify packing options and may be bitwise ORed together to allow "
+"multiple options. These options are:"
+msgstr ""
+"Les paramètres <parameter>xoptions</parameter> et <parameter>yoptions</"
+"parameter> s'utilisent pour définir les options d'empaquetage. Pour définir "
+"des options multiples, il convient de les lier entre elles avec l'opérateur "
+"binaire OR. Ces options sont :"
+
+#: C/gtkmm-tutorial-in.xml:2147(literal)
+msgid "Gtk::FILL"
+msgstr "Gtk::FILL"
+
+#: C/gtkmm-tutorial-in.xml:2149(para)
+msgid ""
+"If the table box is larger than the widget, and <literal>Gtk::FILL</literal> "
+"is specified, the widget will expand to use all the room available."
+msgstr ""
+"Si la cellule du tableau est plus grande que l'élément graphique et si "
+"<literal>Gtk::FILL</literal> est indiqué, l'élément graphique sera étiré "
+"pour utiliser toute la place disponible."
+
+#: C/gtkmm-tutorial-in.xml:2157(literal)
+msgid "Gtk::SHRINK"
+msgstr "Gtk::SHRINK"
+
+#: C/gtkmm-tutorial-in.xml:2159(para)
+msgid ""
+"If the table widget is allocated less space than it requested (because the "
+"user resized the window), then the widgets will normally just disappear off "
+"the bottom of the window. If <literal>Gtk::SHRINK</literal> is specified, "
+"the widgets will shrink with the table."
+msgstr ""
+"Si l'élément graphique tableau dispose de moins de place que nécessaire "
+"(parce que l'utilisateur a redimensionné la fenêtre), les éléments "
+"graphiques dans les cellules vont être cachés par le bas de la fenêtre. Si "
+"<literal>Gtk::SHRINK</literal> est indiqué, les éléments graphiques vont "
+"rétrécir avec le tableau."
+
+#: C/gtkmm-tutorial-in.xml:2170(literal)
+msgid "Gtk::EXPAND"
+msgstr "Gtk::EXPAND"
+
+#: C/gtkmm-tutorial-in.xml:2172(para)
+msgid ""
+"This will cause the table to expand to use up anyremaining space in the "
+"window."
+msgstr ""
+"Cette option va provoquer l'étalement du tableau jusqu'à occuper tout "
+"l'espace libre de la fenêtre."
+
+#: C/gtkmm-tutorial-in.xml:2180(para)
+msgid ""
+"The padding arguments work just as they do for <methodname>pack_start()</"
+"methodname>."
+msgstr ""
+"Les paramètres de remplissage fonctionnent exactement comme pour la fonction "
+"membre <methodname>pack_start()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2186(title)
+msgid "Other methods"
+msgstr "Autres fonctions membres"
+
+#: C/gtkmm-tutorial-in.xml:2188(para)
+msgid ""
+"<methodname>set_row_spacing()</methodname> and <methodname>set_col_spacing()"
+"</methodname> set the spacing between the rows at the specified row or "
+"column. Note that for columns, the space goes to the right of the column, "
+"and for rows, the space goes below the row."
+msgstr ""
+"<methodname>set_row_spacing()</methodname> et <methodname>set_col_spacing()</"
+"methodname> définissent l'espacement entre lignes ou entre colonnes pour la "
+"ligne ou la colonne indiquée. Notez que, pour les colonnes, l'espacement se "
+"situe à droite de la colonne et que, pour les lignes, l'espacement se situe "
+"sous la ligne."
+
+#: C/gtkmm-tutorial-in.xml:2195(para)
+msgid ""
+"You can also set a consistent spacing for all rows and/or columns with "
+"<methodname>set_row_spacings()</methodname> and <methodname>set_col_spacings"
+"()</methodname>. Note that with these calls, the last row and last column do "
+"not get any spacing."
+msgstr ""
+"Vous pouvez également fixer un espacement d'ensemble pour toutes les lignes "
+"et toutes les colonnes avec <methodname>set_row_spacings()</methodname> et "
+"<methodname>set_col_spacings()</methodname>. Notez qu'avec ces fonctions "
+"membres, la dernière ligne et la dernière colonne n'ont pas l'espacement "
+"indiqué."
+
+#: C/gtkmm-tutorial-in.xml:2207(para)
+msgid ""
+"In the following example, we make a window with three buttons in a 2 x 2 "
+"table. The first two buttons will be placed in the upper row. A third button "
+"is placed in the lower row, spanning both columns."
+msgstr ""
+"Dans l'exemple ci-après, nous créons une fenêtre avec trois boutons dans un "
+"tableau 2 x 2. Les deux premiers boutons sont placés dans la ligne "
+"supérieure. Le troisième bouton est placé dans la ligne inférieure et occupe "
+"les deux colonnes."
+
+#: C/gtkmm-tutorial-in.xml:2227(title) C/gtkmm-tutorial-in.xml:2262(title)
+msgid "Notebook"
+msgstr "Bloc-note"
+
+#: C/gtkmm-tutorial-in.xml:2229(para)
+msgid ""
+"A <classname>Notebook</classname> has a set of stacked <literal>pages</"
+"literal>, each of which contains widgets. Labelled <literal>tabs</literal> "
+"allow the user to select the pages. <classname>Notebook</classname>s allow "
+"several sets of widgets to be placed in a small space, by only showing one "
+"page at a time. For instance, they are often used in preferences dialogs."
+msgstr ""
+"L'objet <classname>Notebook</classname> est constitué d'un jeu de "
+"<literal>pages</literal> empilées, chacune contenant des éléments "
+"graphiques. Les onglets étiquetés permettent à l'utilisateur de choisir les "
+"pages. <classname>Notebook</classname> permet de placer plusieurs jeux "
+"d'éléments graphiques dans un espace réduit, mais en ne montrant qu'une "
+"seule page à la fois. Cet objet est souvent utilisé, par exemple, dans les "
+"boîtes de dialogue de préférences."
+
+#: C/gtkmm-tutorial-in.xml:2238(para)
+msgid ""
+"Use the <methodname>append_page()</methodname>, <methodname>prepend_page()</"
+"methodname> and <methodname>insert_page()</methodname> methods to add tabbed "
+"pages to the <literal>Notebook</literal>, supplying the child widget and the "
+"name for the tab."
+msgstr ""
+"Servez-vous des fonctions membres <methodname>append_page()</methodname>, "
+"<methodname>prepend_page()</methodname> et <methodname>insert_page()</"
+"methodname> pour ajouter des pages à onglets dans l'objet <literal>Notebook</"
+"literal> en précisant l'élément graphique enfant et le nom de l'onglet."
+
+#: C/gtkmm-tutorial-in.xml:2245(para)
+msgid ""
+"To discover the currently visible page, use the <methodname>get_current_page"
+"()</methodname> method. This returns the page number, and then calling "
+"<methodname>get_nth_page()</methodname> with that number will give you a "
+"pointer to the actual child widget."
+msgstr ""
+"Pour connaître la page actuellement affichée, utilisez la fonction membre "
+"<methodname>get_current_page()</methodname>. Elle renvoie un numéro de page, "
+"puis, en appelant <methodname>get_nth_page()</methodname> avec ce numéro de "
+"page, vous obtiendrez un pointeur sur l'élément graphique enfant de la page."
+
+#: C/gtkmm-tutorial-in.xml:2252(para)
+msgid ""
+"To programmatically change the selected page, use the "
+"<methodname>set_current_page()</methodname> method."
+msgstr ""
+"Pour changer de page sélectionnée au cours du programme, utilisez la "
+"fonction membre <methodname>set_current_page()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2275(title) C/gtkmm-tutorial-in.xml:2302(title)
+msgid "Assistant"
+msgstr "Assistant"
+
+#: C/gtkmm-tutorial-in.xml:2277(para)
+msgid ""
+"An <classname>Assistant</classname> splits a complex operation into steps. "
+"Each step is a page, containing a header, a child widget and an action area. "
+"The Assistant's action area has navigation buttons which update "
+"automatically depending on the type of the page, set with "
+"<methodname>set_page_type()</methodname>."
+msgstr ""
+"Un objet <classname>Assistant</classname> divise une opération complexe en "
+"étapes successives. � chaque étape correspond une page, avec un en-tête, un "
+"élément graphique enfant et une zone d'action. La zone d'action de "
+"l'assistant possède des boutons de navigation qui se mettent à jour "
+"automatiquement selon le type de page fixé avec <methodname>set_page_type()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2281(para)
+msgid ""
+"Use the <methodname>append_page()</methodname>, <methodname>prepend_page</"
+"methodname> and <methodname>insert_page()</methodname> methods to add pages "
+"to the <classname>Assistant</classname>, supplying the child widget for each "
+"page."
+msgstr ""
+"Utilisez les fonctions membres <methodname>append_page()</methodname>, "
+"<methodname>prepend_page</methodname> et <methodname>insert_page()</"
+"methodname> pour ajouter des pages à un objet <classname>Assistant</"
+"classname>, tout en indiquant l'élément graphique enfant pour chacune "
+"d'entre elles."
+
+#: C/gtkmm-tutorial-in.xml:2285(para)
+msgid ""
+"To determine the currently-visible page, use the <methodname>get_current_page"
+"()</methodname> method, and pass the result to <methodname>get_nth_page()</"
+"methodname>, which returns a pointer to the actual widget. To "
+"programmatically change the current page, use the "
+"<methodname>set_current_page()</methodname> method."
+msgstr ""
+"Pour connaître la page en cours d'utilisation, servez-vous de la fonction "
+"membre <methodname>get_current_page()</methodname>, passez le résultat à "
+"<methodname>get_nth_page()</methodname> qui vous renverra un pointeur sur "
+"l'élément graphique affiché. Pour changer en cours de programme la page "
+"active, utilisez la fonction membre <methodname>set_current_page()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2289(para)
+msgid ""
+"To set the title of a page, use the <methodname>set_page_title()</"
+"methodname> method. The header and side images of a page can be set with the "
+"<methodname>set_page_header_image()</methodname> and "
+"<methodname>set_page_side_image()</methodname> methods."
+msgstr ""
+"Pour définir le titre de la page, servez-vous de la fonction membre "
+"<methodname>set_page_title()</methodname>. Les images de l'en-tête et du "
+"côté de la page sont insérées avec les fonctions membres "
+"<methodname>set_page_header_image()</methodname> et "
+"<methodname>set_page_side_image()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2293(para)
+msgid ""
+"To add widgets to the action area, use the <methodname>add_action_widget()</"
+"methodname> method. They will be packed alongside the default buttons. Use "
+"the <methodname>remove_action_widget()</methodname> method to remove widgets."
+msgstr ""
+"Pour ajouter des éléments graphiques dans la zone d'action, utilisez la "
+"fonction membre <methodname>add_action_widget()</methodname>. Ils seront "
+"empaquetés à côté des boutons par défaut. Servez-vous de la fonction membre "
+"<methodname>remove_action_widget()</methodname> pour enlever des éléments "
+"graphiques."
+
+#: C/gtkmm-tutorial-in.xml:2320(title)
+msgid "The TreeView widget"
+msgstr "L'élément graphique arborescence"
+
+#: C/gtkmm-tutorial-in.xml:2321(para)
+msgid ""
+"The <classname>Gtk::TreeView</classname> widget can contain lists or trees "
+"of data, in columns."
+msgstr ""
+"L'élément graphique <classname>Gtk::TreeView</classname> peut incorporer des "
+"listes ou des arborescences de données, disposées en colonnes."
+
+#: C/gtkmm-tutorial-in.xml:2327(title)
+msgid "The Model"
+msgstr "Le modèle"
+
+#: C/gtkmm-tutorial-in.xml:2328(para)
+msgid ""
+"Each <classname>Gtk::TreeView</classname> has an associated <classname>Gtk::"
+"TreeModel</classname>, which contains the data displayed by the "
+"<classname>TreeView</classname>. Each <classname>Gtk::TreeModel</classname> "
+"can be used by more than one <classname>Gtk::TreeView</classname>. For "
+"instance, this allows the same underlying data to be displayed and edited in "
+"2 different ways at the same time. Or the 2 Views might display different "
+"columns from the same Model data, in the same way that 2 SQL queries (or "
+"\"views\") might show different fields from the same database table."
+msgstr ""
+"Chaque objet <classname>Gtk::TreeView</classname> possède un objet "
+"<classname>Gtk::TreeModel</classname> associé ; il contient les données à "
+"afficher par l'objet <classname>TreeView</classname>. Tout <classname>Gtk::"
+"TreeModel</classname> peut être utilisé par plus d'un <classname>Gtk::"
+"TreeView</classname>. Par exemple, il est possible d'afficher et modifier "
+"simultanément sous deux formes différentes les mêmes données sous-jacentes ; "
+"ou bien encore, les deux vues peuvent afficher des colonnes différentes à "
+"partir du même modèle de données, tout comme deux requêtes SQL (ou « vues ») "
+"sont susceptibles d'afficher des champs différents à partir d'une même base "
+"de données."
+
+#: C/gtkmm-tutorial-in.xml:2338(para)
+msgid ""
+"Although you can theoretically implement your own Model, you will normally "
+"use either the <classname>ListStore</classname> or <classname>TreeStore</"
+"classname> model classes."
+msgstr ""
+"Même si vous pouvez théoriquement implémenter votre propre modèle, vous "
+"utiliserez normalement, soit la classe modèle <classname>ListStore</"
+"classname>, soit la classe modèle <classname>TreeStore</classname>."
+
+#: C/gtkmm-tutorial-in.xml:2347(title)
+msgid "ListStore, for rows"
+msgstr "Modèle listStore, pour des colonnes"
+
+#: C/gtkmm-tutorial-in.xml:2348(para)
+msgid ""
+"The <classname>ListStore</classname> contains simple rows of data, and each "
+"row has no children."
+msgstr ""
+"Un objet <classname>ListStore</classname> contient de simples colonnes de "
+"données et chaque colonne n'a pas d'enfant."
+
+#: C/gtkmm-tutorial-in.xml:2354(title) C/gtkmm-tutorial-in.xml:2898(title)
+msgid "TreeView - ListStore"
+msgstr "TreeView - ListStore"
+
+#: C/gtkmm-tutorial-in.xml:2365(title)
+msgid "TreeStore, for a hierarchy"
+msgstr "Modèle treeStore, pour une hiérarchie"
+
+#: C/gtkmm-tutorial-in.xml:2366(para)
+msgid ""
+"The <classname>TreeStore</classname> contains rows of data, and each row may "
+"have child rows."
+msgstr ""
+"L'objet <classname>TreeStore</classname> contient des colonnes de données et "
+"chaque colonne peut avoir des colonnes enfants."
+
+#: C/gtkmm-tutorial-in.xml:2372(title) C/gtkmm-tutorial-in.xml:2917(title)
+msgid "TreeView - TreeStore"
+msgstr "TreeView - TreeStore"
+
+#: C/gtkmm-tutorial-in.xml:2383(title)
+msgid "Model Columns"
+msgstr "Modèle colonnes"
+
+#: C/gtkmm-tutorial-in.xml:2384(para)
+msgid ""
+"The <classname>TreeModelColumnRecord</classname> class is used to keep track "
+"of the columns and their data types. You add <classname>TreeModelColumn</"
+"classname> instances to the <classname>ColumnRecord</classname> and then use "
+"those <classname>TreeModelColumns</classname> when getting and setting the "
+"data in model rows. You will probably find it convenient to derive a new "
+"<classname>TreeModelColumnRecord</classname> which has your "
+"<classname>TreeModelColumn</classname> instances as member data."
+msgstr ""
+"La classe <classname>TreeModelColumnRecord</classname> s'utilise pour "
+"enregistrer les colonnes et leurs types de données. Vous ajoutez des "
+"exemplaires de <classname>TreeModelColumn</classname> au "
+"<classname>ColumnRecord</classname>, puis utilisez ces "
+"<classname>TreeModelColumns</classname> pour obtenir ou placer les données "
+"dans les colonnes du modèle. Vous trouverez certainement commode de dériver "
+"un nouveau <classname>TreeModelColumnRecord</classname> incorporant vos "
+"exemplaires de <classname>TreeModelColumn</classname> en tant que données "
+"membres."
+
+#: C/gtkmm-tutorial-in.xml:2395(programlisting)
+#, no-wrap
+msgid ""
+"class ModelColumns : public Gtk::TreeModelColumnRecord\n"
+"{\n"
+"public:\n"
+"\n"
+" ModelColumns()\n"
+" { add(m_col_text); add(m_col_number); }\n"
+"\n"
+" Gtk::TreeModelColumn<Glib::ustring> m_col_text;\n"
+" Gtk::TreeModelColumn<int> m_col_number;\n"
+"};\n"
+"\n"
+"ModelColumns m_Columns;"
+msgstr ""
+"class ModelColumns : public Gtk::TreeModelColumnRecord\n"
+"{\n"
+"public:\n"
+"\n"
+" ModelColumns()\n"
+" { add(m_col_text); add(m_col_number); }\n"
+"\n"
+" Gtk::TreeModelColumn<Glib::ustring> m_col_text;\n"
+" Gtk::TreeModelColumn<int> m_col_number;\n"
+"};\n"
+"\n"
+"ModelColumns m_Columns;"
+
+#: C/gtkmm-tutorial-in.xml:2408(para)
+msgid ""
+"You specify the <classname>ColumnRecord</classname> when creating the Model, "
+"like so:"
+msgstr ""
+"Vous précisez le <classname>ColumnRecord</classname> à la création du "
+"modèle, ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:2412(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::ListStore> refListStore =\n"
+" Gtk::ListStore::create(m_Columns);"
+msgstr ""
+"Glib::RefPtr<Gtk::ListStore> refListStore =\n"
+" Gtk::ListStore::create(m_Columns);"
+
+#: C/gtkmm-tutorial-in.xml:2414(para)
+msgid ""
+"Note that the instance (such as m_Columns here) should usually not be "
+"static, because it often needs to be instantiated after glibmm has been "
+"instantiated."
+msgstr ""
+"Notez que les exemplaires de colonnes (tels que m_Columns ici) ne sont "
+"habituellement pas qualifiés « static », étant donné qu'ils doivent être "
+"instanciés après que glibmm l'ait été lui-même."
+
+#: C/gtkmm-tutorial-in.xml:2419(title)
+msgid "Adding Rows"
+msgstr "Ajout de lignes"
+
+#: C/gtkmm-tutorial-in.xml:2420(para)
+msgid ""
+"Add rows to the model with the <methodname>append()</methodname>, "
+"<methodname>prepend()</methodname>, or <methodname>insert()</methodname> "
+"methods."
+msgstr ""
+"Ajoutez des lignes au modèle avec les fonctions membres <methodname>append()"
+"</methodname>, <methodname>prepend()</methodname> ou <methodname>insert()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2424(programlisting)
+#, no-wrap
+msgid "Gtk::TreeModel::iterator iter = m_refListStore->append();"
+msgstr "Gtk::TreeModel::iterator iter = m_refListStore->append();"
+
+#: C/gtkmm-tutorial-in.xml:2425(para)
+msgid "You can dereference the iterator to get the Row:"
+msgstr "Vous pouvez déréférencer l'itérateur pour obtenir la ligne :"
+
+#: C/gtkmm-tutorial-in.xml:2427(programlisting)
+#, no-wrap
+msgid "Gtk::TreeModel::Row row = *iter;"
+msgstr "Gtk::TreeModel::Row row = *iter;"
+
+#: C/gtkmm-tutorial-in.xml:2428(title)
+msgid "Adding child rows"
+msgstr "Ajout de colonnes enfants"
+
+#: C/gtkmm-tutorial-in.xml:2429(para)
+msgid ""
+"<classname>Gtk::TreeStore</classname> models can have child items. Add them "
+"with the <methodname>append()</methodname>, <methodname>prepend()</"
+"methodname>, or <methodname>insert()</methodname> methods, like so:"
+msgstr ""
+"Les modèles <classname>Gtk::TreeStore</classname> peuvent avoir des éléments "
+"enfants. Pour les ajouter, servez-vous des fonctions membres "
+"<methodname>append()</methodname>, <methodname>prepend()</methodname> ou "
+"<methodname>insert()</methodname>, ainsi : "
+
+#: C/gtkmm-tutorial-in.xml:2434(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::TreeModel::iterator iter_child =\n"
+" m_refListStore->append(row.children());"
+msgstr ""
+"Gtk::TreeModel::iterator iter_child =\n"
+" m_refListStore->append(row.children());"
+
+#: C/gtkmm-tutorial-in.xml:2441(title)
+msgid "Setting values"
+msgstr "Définition des valeurs"
+
+#: C/gtkmm-tutorial-in.xml:2442(para)
+msgid ""
+"You can use the <methodname>operator[]</methodname> override to set the data "
+"for a particular column in the row, specifying the "
+"<classname>TreeModelColumn</classname> used to create the model."
+msgstr ""
+"Vous pouvez utiliser la surdéfinition de <methodname>operator[]</methodname> "
+"pour définir les données d'une colonne désignée dans la ligne en indiquant "
+"le <classname>TreeModelColumn</classname> utilisé pour créer le modèle."
+
+#: C/gtkmm-tutorial-in.xml:2447(programlisting)
+#, no-wrap
+msgid "row[m_Columns.m_col_text] = \"sometext\";"
+msgstr "row[m_Columns.m_col_text] = \"textedonné\";"
+
+#: C/gtkmm-tutorial-in.xml:2451(title)
+msgid "Getting values"
+msgstr "Obtention des valeurs"
+
+#: C/gtkmm-tutorial-in.xml:2452(para)
+msgid ""
+"You can use the <methodname>operator[]</methodname> override to get the data "
+"in a particular column in a row, specifiying the <classname>TreeModelColumn</"
+"classname> used to create the model."
+msgstr ""
+"Vous pouvez utiliser la surdéfinition de <methodname>operator[]</methodname> "
+"pour obtenir les données d'une colonne particulière dans une ligne, en "
+"précisant le <classname>TreeModelColumn</classname> qui a été utilisé pour "
+"créer le modèle."
+
+#: C/gtkmm-tutorial-in.xml:2457(programlisting)
+#, no-wrap
+msgid ""
+"Glib::ustring strText = row[m_Columns.m_col_text];\n"
+"int number = row[m_Columns.m_col_number];"
+msgstr ""
+"Glib::ustring strText = row[m_Columns.m_col_text];\n"
+"int number = row[m_Columns.m_col_number];"
+
+#: C/gtkmm-tutorial-in.xml:2459(para)
+msgid ""
+"The compiler will complain if you use an inappropriate type. For instance, "
+"this would generate a compiler error:"
+msgstr ""
+"Le compilateur se plaint si vous utilisez un type inapproprié et génère, par "
+"exemple, l'erreur de compilation suivante :"
+
+#: C/gtkmm-tutorial-in.xml:2463(programlisting)
+#, no-wrap
+msgid ""
+"//compiler error - no conversion from ustring to int.\n"
+"int number = row[m_Columns.m_col_text];"
+msgstr ""
+"//compiler error - no conversion from ustring to int.\n"
+"int number = row[m_Columns.m_col_text];"
+
+#: C/gtkmm-tutorial-in.xml:2468(title)
+msgid "\"Hidden\" Columns"
+msgstr "Colonnes « cachées »"
+
+#: C/gtkmm-tutorial-in.xml:2469(para)
+msgid ""
+"You might want to associate extra data with each row. If so, just add it as "
+"a Model column, but don't add it to the View."
+msgstr ""
+"Vous pouvez associer des données supplémentaires à chaque ligne. Pour ce "
+"faire, ajoutez-les en tant que colonne du modèle, mais sans les placer dans "
+"la vue."
+
+#: C/gtkmm-tutorial-in.xml:2478(title) C/gtkmm-tutorial-in.xml:3272(title)
+msgid "The View"
+msgstr "La vue"
+
+#: C/gtkmm-tutorial-in.xml:2479(para)
+msgid ""
+"The View is the actual widget (<classname>Gtk::TreeView</classname>) that "
+"displays the model (<classname>Gtk::TreeModel</classname>) data and allows "
+"the user to interact with it. The View can show all of the model's columns, "
+"or just some, and it can show them in various ways."
+msgstr ""
+"La vue est l'élément graphique (<classname>Gtk::TreeView</classname>) qui "
+"affiche concrètement les données du modèle (<classname>Gtk::TreeModel</"
+"classname>) et qui autorise l'utilisateur à interagir. Elle peut afficher, "
+"de diverses manières, toutes les colonnes du modèle ou seulement quelques "
+"unes."
+
+#: C/gtkmm-tutorial-in.xml:2489(title)
+msgid "Using a Model"
+msgstr "Utilisation d'un modèle"
+
+#: C/gtkmm-tutorial-in.xml:2490(para)
+msgid ""
+"You can specify a <classname>Gtk::TreeModel</classname> when constructing "
+"the <classname>Gtk::TreeView</classname>, or you can use the "
+"<methodname>set_model()</methodname> method, like so:"
+msgstr ""
+"Vous pouvez définir le modèle <classname>Gtk::TreeModel</classname> à la "
+"construction de l'objet vue <classname>Gtk::TreeView</classname> ou bien "
+"vous pouvez utiliser la fonction membre <methodname>set_model()</"
+"methodname>, comme suit :"
+
+#: C/gtkmm-tutorial-in.xml:2495(programlisting)
+#, no-wrap
+msgid "m_TreeView.set_model(m_refListStore);"
+msgstr "m_TreeView.set_model(m_refListStore);"
+
+#: C/gtkmm-tutorial-in.xml:2499(title)
+msgid "Adding View Columns"
+msgstr "Ajout de colonnes à la vue"
+
+#: C/gtkmm-tutorial-in.xml:2500(para)
+msgid ""
+"You can use the <methodname>append_column()</methodname> method to tell the "
+"View that it should display certain Model columns, in a certain order, with "
+"a certain column title."
+msgstr ""
+"Vous pouvez utiliser la fonction membre <methodname>append_column()</"
+"methodname> pour demander à la vue d'afficher certaines colonnes du modèle, "
+"dans un certain ordre, avec un certain intitulé."
+
+#: C/gtkmm-tutorial-in.xml:2505(programlisting)
+#, no-wrap
+msgid "m_TreeView.append_column(\"Messages\", m_Columns.m_col_text);"
+msgstr "m_TreeView.append_column(\"Messages\", m_Columns.m_col_text);"
+
+#: C/gtkmm-tutorial-in.xml:2506(para)
+msgid ""
+"When using this simple <methodname>append_column()</methodname> override, "
+"the <classname>TreeView</classname> will display the model data with an "
+"appropriate <classname>CellRenderer</classname>. For instance, strings and "
+"numbers are shown in a simple <classname>Gtk::Entry</classname> widget, and "
+"booleans are shown in a <classname>Gtk::CheckButton</classname>. This is "
+"usually what you need. For other column types you must either connect a "
+"callback that converts your type into a string representation, with "
+"<methodname>TreeViewColumn::set_cell_data_func()</methodname>, or derive a "
+"custom <classname>CellRenderer</classname>. Note that (unsigned) short is "
+"not supported by default - You could use (unsigned) int or (unsigned) long "
+"as the column type instead."
+msgstr ""
+"En utilisant cette simple surdéfinition de <methodname>append_column()</"
+"methodname>, l'objet <classname>TreeView</classname> affiche la donnée du "
+"modèle avec un <classname>CellRenderer</classname> approprié. Par exemple, "
+"les chaînes littérales et les nombres sont affichés dans un simple contrôle "
+"<classname>Gtk::Entry</classname> et les booléens dans un <classname>Gtk::"
+"CheckButton</classname>. Cela correspond aux besoins habituels. Pour des "
+"colonnes relatives à d'autres types, vous pouvez, soit connecter une "
+"fonction de rappel qui convertit avec <methodname>TreeViewColumn::"
+"set_cell_data_func()</methodname> le type en chaîne littérale le "
+"représentant, soit créer par dérivation un <classname>CellRenderer</"
+"classname> personnalisé. Notez que le type <literal>(unsigned) short</"
+"literal> n'est pas pris en charge par défaut â?? à la place, vous pouvez "
+"utiliser le type <literal>(unsigned) int</literal> ou <literal>(unsigned) "
+"long</literal>."
+
+#: C/gtkmm-tutorial-in.xml:2522(title)
+msgid "More than one Model Column per View Column"
+msgstr "Plus d'une colonne de modèle par colonne de vue"
+
+#: C/gtkmm-tutorial-in.xml:2523(para)
+msgid ""
+"To render more than one model column in a view column, you need to create "
+"the <classname>TreeView::Column</classname> widget manually, and use "
+"<methodname>pack_start()</methodname> to add the model columns to it."
+msgstr ""
+"Pour afficher à l'écran plus d'une colonne du modèle dans une colonne de "
+"vue, vous aurez besoin de créer un élément graphique <classname>TreeView::"
+"Column</classname> manuellement et d'utiliser la fonction membre "
+"<methodname>pack_start()</methodname> pour y ajouter les colonnes du modèle."
+
+#: C/gtkmm-tutorial-in.xml:2529(para)
+msgid ""
+"Then use <methodname>append_column()</methodname> to add the view Column to "
+"the View. Notice that <methodname>Gtk::View::append_column()</methodname> is "
+"overridden to accept either a prebuilt <classname>Gtk::View::Column</"
+"classname> widget, or just the <classname>TreeModelColumn</classname> from "
+"which it generates an appropriate <classname>Gtk::View::Column</classname> "
+"widget."
+msgstr ""
+"Ensuite, avec <methodname>append_column()</methodname>, ajoutez la colonne à "
+"la vue. Vous noterez que <methodname>Gtk::View::append_column()</methodname> "
+"a été surdéfini pour accepter, soit un élément graphique <classname>Gtk::"
+"View::Column</classname> préalablement construit, soit uniquement un "
+"<classname>TreeModelColumn</classname> Ã partir duquel cette fonction membre "
+"génére un élément graphique <classname>Gtk::View::Column</classname> "
+"approprié."
+
+#: C/gtkmm-tutorial-in.xml:2536(para)
+msgid ""
+"Here is some example code from <filename>demos/gtk-demo/example_stockbrowser."
+"cc</filename>, which has a pixbuf icon and a text name in the same column:"
+msgstr ""
+"Voici quelques exemples de code extraits de <filename>demos/gtk-demo/"
+"example_stockbrowser.cc</filename>, qui possède une icône pixelisée et du "
+"texte dans une même colonne :"
+
+#: C/gtkmm-tutorial-in.xml:2541(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::TreeView::Column* pColumn =\n"
+" Gtk::manage( new Gtk::TreeView::Column(\"Symbol\") );\n"
+"\n"
+"// m_columns.icon and m_columns.symbol are columns in the model.\n"
+"// pColumn is the column in the TreeView:\n"
+"pColumn->pack_start(m_columns.icon, false); //false = don't expand.\n"
+"pColumn->pack_start(m_columns.symbol);\n"
+"\n"
+"m_TreeView.append_column(*pColumn);"
+msgstr ""
+"Gtk::TreeView::Column* pColumn =\n"
+" Gtk::manage( new Gtk::TreeView::Column(\"Symbole\") );\n"
+"\n"
+"// m_columns.icon et m_columns.symbol sont des colonnes du modèle.\n"
+"// pColumn est la colonne dans l'objet TreeView :\n"
+"pColumn->pack_start(m_columns.icon, false); //false = ne pas développer.\n"
+"pColumn->pack_start(m_columns.symbol);\n"
+"\n"
+"m_TreeView.append_column(*pColumn);"
+
+#: C/gtkmm-tutorial-in.xml:2553(title)
+msgid "Specifying CellRenderer details"
+msgstr "Détails pour la définition du CellRenderer"
+
+#: C/gtkmm-tutorial-in.xml:2554(para)
+msgid ""
+"The default <classname>CellRenderers</classname> and their default behaviour "
+"will normally suffice, but you might occasionally need finer control. For "
+"instance, this example code from <filename>demos/gtk-demo/example_treestore."
+"cc</filename>, manually constructs a <classname>Gtk::CellRenderer</"
+"classname> widget and instructs it to render the data from various model "
+"columns through various aspects of its appearance."
+msgstr ""
+"Le comportement par défaut de la classe <classname>CellRenderers</classname> "
+"suffit en règle générale, mais vous pouvez dans certains cas avoir besoin "
+"d'un contrôle plus fin. Ainsi, cet exemple de code, pris dans "
+"<filename>demos/gtk-demo/example_treestore.cc</filename>, construit "
+"manuellement un élément graphique <classname>Gtk::CellRenderer</classname> "
+"et le programme pour qu'il effectue un rendu avec variations d'aspect selon "
+"les données des diverses colonnes du modèle."
+
+#: C/gtkmm-tutorial-in.xml:2562(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::CellRendererToggle* pRenderer =\n"
+" Gtk::manage( new Gtk::CellRendererToggle() );\n"
+"int cols_count = m_TreeView.append_column(\"Alex\", *pRenderer);\n"
+"Gtk::TreeViewColumn* pColumn = m_TreeView.get_column(cols_count-1);\n"
+"if(pColumn)\n"
+"{\n"
+" pColumn->add_attribute(pRenderer->property_active(),\n"
+" m_columns.alex);\n"
+" pColumn->add_attribute(pRenderer->property_visible(),\n"
+" m_columns.visible);\n"
+" pColumn->add_attribute(pRenderer->property_activatable(),\n"
+" m_columns.world);"
+msgstr ""
+"Gtk::CellRendererToggle* pRenderer =\n"
+" Gtk::manage( new Gtk::CellRendererToggle() );\n"
+"int cols_count = m_TreeView.append_column(\"Alex\", *pRenderer);\n"
+"Gtk::TreeViewColumn* pColumn = m_TreeView.get_column(cols_count-1);\n"
+"if(pColumn)\n"
+"{\n"
+" pColumn->add_attribute(pRenderer->property_active(),\n"
+" m_columns.alex);\n"
+" pColumn->add_attribute(pRenderer->property_visible(),\n"
+" m_columns.visible);\n"
+" pColumn->add_attribute(pRenderer->property_activatable(),\n"
+" m_columns.world);"
+
+#: C/gtkmm-tutorial-in.xml:2575(para)
+msgid ""
+"You can also connect to <classname>CellRenderer</classname> signals to "
+"detect user actions. For instance:"
+msgstr ""
+"Vous pouvez aussi connecter les signaux du <classname>CellRenderer</"
+"classname> pour détecter des actions utilisateur. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:2579(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::CellRendererToggle* pRenderer =\n"
+" Gtk::manage( new Gtk::CellRendererToggle() );\n"
+"pRenderer->signal_toggled().connect(\n"
+" sigc::bind( sigc::mem_fun(*this,\n"
+" &Example_TreeView_TreeStore::on_cell_toggled), m_columns.dave)\n"
+");"
+msgstr ""
+"Gtk::CellRendererToggle* pRenderer =\n"
+" Gtk::manage( new Gtk::CellRendererToggle() );\n"
+"pRenderer->signal_toggled().connect(\n"
+" sigc::bind( sigc::mem_fun(*this,\n"
+" &Example_TreeView_TreeStore::on_cell_toggled), m_columns.dave)\n"
+");"
+
+#: C/gtkmm-tutorial-in.xml:2588(title) C/gtkmm-tutorial-in.xml:2927(title)
+msgid "Editable Cells"
+msgstr "Cellules modifiables"
+
+#: C/gtkmm-tutorial-in.xml:2591(title)
+msgid "Automatically-stored editable cells."
+msgstr "Cellules modifiables à enregistrement automatique."
+
+#: C/gtkmm-tutorial-in.xml:2592(para)
+msgid ""
+"Cells in a <classname>TreeView</classname> can be edited in-place by the "
+"user. To allow this, use the <classname>Gtk::TreeView</"
+"classname><methodname>insert_column_editable()</methodname> and "
+"<methodname>append_column_editable()</methodname> methods instead of "
+"<methodname>insert_column()</methodname> and <methodname>append_column()</"
+"methodname>. When these cells are edited the new values will be stored "
+"immediately in the Model. Note that these methods are templates which can "
+"only be instantiated for simple column types such as <classname>Glib::"
+"ustring</classname>, int, and long."
+msgstr ""
+"Des cellules d'un objet <classname>TreeView</classname> peuvent être "
+"modifiées in-situ par l'utilisateur. Pour permettre ce comportement, "
+"utilisez les fonctions membres <classname>Gtk::TreeView</"
+"classname><methodname>insert_column_editable()</methodname> et "
+"<methodname>append_column_editable()</methodname> au lieu de "
+"<methodname>insert_column()</methodname> et <methodname>append_column()</"
+"methodname>. Quand ces colonnes sont modifiées, les nouvelles valeurs sont "
+"immédiatement enregistrées dans le modèle. Notez que ces fonctions membres "
+"sont des prototypes qui ne peuvent être utilisés que dans le cas de types de "
+"colonnes simples tels que des <classname>Glib::ustring</classname>, des "
+"<literal>int</literal> et des <literal>long</literal>."
+
+#: C/gtkmm-tutorial-in.xml:2606(title)
+msgid "Implementing custom logic for editable cells."
+msgstr ""
+"Implémentation d'une logique personnalisée pour les cellules modifiables."
+
+#: C/gtkmm-tutorial-in.xml:2607(para)
+msgid ""
+"However, you might not want the new values to be stored immediately. For "
+"instance, maybe you want to restrict the input to certain characters or "
+"ranges of values."
+msgstr ""
+"Toutefois, vous pouvez vouloir que les nouvelles valeurs ne soient pas "
+"immédiatement enregistrées. Vous voulez, par exemple, limiter la saisie à "
+"certains caractères ou plages de valeurs."
+
+#: C/gtkmm-tutorial-in.xml:2612(para)
+msgid ""
+"To achieve this, you should use the normal <classname>Gtk::TreeView</"
+"classname><methodname>insert_column()</methodname> and "
+"<methodname>append_column()</methodname> methods, then use "
+"<methodname>get_column_cell_renderer()</methodname> to get the "
+"<classname>Gtk::CellRenderer</classname> used by that column."
+msgstr ""
+"Pour réaliser cela, utilisez les fonctions membres normales <classname>Gtk::"
+"TreeView</classname><methodname>insert_column()</methodname> et "
+"<methodname>append_column()</methodname>, puis, avec "
+"<methodname>get_column_cell_renderer()</methodname>, obtenez le pointeur sur "
+"le <classname>Gtk::CellRenderer</classname> utilisé par cette colonne."
+
+#: C/gtkmm-tutorial-in.xml:2618(para)
+msgid ""
+"You should then cast that <classname>Gtk::CellRenderer*</classname> to the "
+"specific <classname>CellRenderer</classname> that you expect, so you can use "
+"specific API."
+msgstr ""
+"Ensuite vous ferez un forçage du type de ce pointeur <classname>Gtk::"
+"CellRenderer*</classname> vers un <classname>CellRenderer</classname> donné, "
+"conforme à vos attentes. Vous utilisez ainsi une API particulière."
+
+#: C/gtkmm-tutorial-in.xml:2622(para)
+msgid ""
+"For instance, for a CellRendererText, you would set the cell's "
+"<emphasis>editable</emphasis> property to true, like so:"
+msgstr ""
+"Par exemple, pour un CellRendererText, vous définissez la propriété "
+"<emphasis>editable</emphasis> égale à <literal>true</literal>, comme ceci :"
+
+#: C/gtkmm-tutorial-in.xml:2625(programlisting)
+#, no-wrap
+msgid "cell.property_editable() = true;"
+msgstr "cell.property_editable() = true;"
+
+#: C/gtkmm-tutorial-in.xml:2626(para)
+msgid ""
+"For a CellRendererToggle, you would set the <emphasis>activatable</emphasis> "
+"property instead."
+msgstr ""
+"Pour un « CellRendererToggle », vous paramétrez la propriété "
+"<emphasis>activatable</emphasis> Ã la place."
+
+#: C/gtkmm-tutorial-in.xml:2630(para)
+msgid ""
+"You can then connect to the appropriate \"edited\" signal. For instance, "
+"connect to <methodname>Gtk::CellRendererText::signal_edited()</methodname>, "
+"or <methodname>Gtk::CellRendererToggle::signal_toggled()</methodname>. If "
+"the column contains more than one <classname>CellRenderer</classname> then "
+"you will need to use <methodname>Gtk::TreeView::get_column()</methodname> "
+"and then call <methodname>get_cell_renderers()</methodname> on that view "
+"Column."
+msgstr ""
+"Vous pouvez alors connecter le signal « edited » approprié, par exemple, "
+"connecter à <methodname>Gtk::CellRendererText::signal_edited()</methodname> "
+"ou <methodname>Gtk::CellRendererToggle::signal_toggled()</methodname>. Si la "
+"colonne comprend plus d'un <classname>CellRenderer</classname>, vous aurez "
+"besoin d'utiliser <methodname>Gtk::TreeView::get_column()</methodname>, puis "
+"d'appeler <methodname>get_cell_renderers()</methodname> sur cette colonne de "
+"la vue."
+
+#: C/gtkmm-tutorial-in.xml:2638(para)
+msgid ""
+"In your signal handler, you should examine the new value and then store it "
+"in the Model if that is appropriate for your application."
+msgstr ""
+"Dans le gestionnaire de signal, vous devriez examiner la nouvelle valeur et "
+"l'enregistrer dans le modèle si vous la jugez appropriée pour l'application."
+
+#: C/gtkmm-tutorial-in.xml:2650(title)
+msgid "Iterating over Model Rows"
+msgstr "Itération parmi les colonnes du modèle"
+
+#: C/gtkmm-tutorial-in.xml:2651(para)
+msgid ""
+"<classname>Gtk::TreeModel</classname> provides a C++ Standard Library-style "
+"container of its children, via the <methodname>children()</methodname> "
+"method. You can use the familiar <methodname>begin()</methodname> and "
+"<methodname>end()</methodname> methods iterator incrementing, like so:"
+msgstr ""
+"<classname>Gtk::TreeModel</classname> fournit un conteneur dans le style de "
+"la bibliothèque standard C++ pour ses enfants par l'intermédiaire de la "
+"fonction membre <methodname>children()</methodname>. Vous pouvez utiliser "
+"les fonctions membres habituelles <methodname>begin()</methodname> et "
+"<methodname>end()</methodname> pour incrémenter un itérateur, comme ceci :"
+
+#: C/gtkmm-tutorial-in.xml:2657(programlisting)
+#, no-wrap
+msgid ""
+"typedef Gtk::TreeModel::Children type_children; //minimise code length.\n"
+"type_children children = refModel->children();\n"
+"for(type_children::iterator iter = children.begin();\n"
+" iter != children.end(); ++iter)\n"
+"{\n"
+" Gtk::TreeModel::Row row = *iter;\n"
+" //Do something with the row - see above for set/get.\n"
+"}"
+msgstr ""
+"typedef Gtk::TreeModel::Children type_children; // minimise la longueur du code.\n"
+"type_children children = refModel->children();\n"
+"for(type_children::iterator iter = children.begin();\n"
+" iter != children.end(); ++iter)\n"
+"{\n"
+" Gtk::TreeModel::Row row = *iter;\n"
+" // Faire quelque chose avec la ligne - voir plus haut pour set/get.\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:2667(title)
+msgid "Row children"
+msgstr "Ligne enfant"
+
+#: C/gtkmm-tutorial-in.xml:2672(programlisting)
+#, no-wrap
+msgid "Gtk::TreeModel::Children children = row.children();"
+msgstr "Gtk::TreeModel::Children children = row.children();"
+
+#: C/gtkmm-tutorial-in.xml:2668(para)
+msgid ""
+"When using a <classname>Gtk::TreeStore</classname>, the rows can have child "
+"rows, which can have their own children in turn. Use <methodname>Gtk::"
+"TreeModel::Row::children()</methodname> to get the container of child "
+"<classname>Row</classname>s: <placeholder-1/>"
+msgstr ""
+"Si vous vous servez d'un objet <classname>Gtk::TreeStore</classname>, les "
+"lignes peuvent avoir des lignes enfants qui, Ã leur tour, peuvent avoir leur "
+"propres enfants. Utilisez <methodname>Gtk::TreeModel::Row::children()</"
+"methodname> pour obtenir le conteneur des objets <classname>Row</classname> "
+"enfants : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:2679(title)
+msgid "The Selection"
+msgstr "La sélection"
+
+#: C/gtkmm-tutorial-in.xml:2680(para)
+msgid ""
+"To find out what rows the user has selected, get the <classname>Gtk::"
+"TreeView::Selection</classname> object from the <classname>TreeView</"
+"classname>, like so:"
+msgstr ""
+"Pour retrouver quelles sont les lignes sélectionnées par l'utilisateur, "
+"obtenez l'objet <classname>Gtk::TreeView::Selection</classname> du "
+"<classname>TreeView</classname> ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:2685(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::TreeSelection> refTreeSelection =\n"
+" m_TreeView.get_selection();"
+msgstr ""
+"Glib::RefPtr<Gtk::TreeSelection> refTreeSelection =\n"
+" m_TreeView.get_selection();"
+
+#: C/gtkmm-tutorial-in.xml:2689(title)
+msgid "Single or multiple selection"
+msgstr "Sélection simple ou multiple"
+
+#: C/gtkmm-tutorial-in.xml:2693(programlisting)
+#, no-wrap
+msgid "refTreeSelection->set_mode(Gtk::SELECTION_MULTIPLE);"
+msgstr "refTreeSelection->set_mode(Gtk::SELECTION_MULTIPLE);"
+
+#: C/gtkmm-tutorial-in.xml:2690(para)
+msgid ""
+"By default, only single rows can be selected, but you can allow multiple "
+"selection by setting the mode, like so: <placeholder-1/>"
+msgstr ""
+"Par défaut, vous ne pouvez sélectionner qu'une seule ligne, mais la "
+"sélection multiple est possible en activant le mode correspondant, comme "
+"ceci : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:2698(title)
+msgid "The selected rows"
+msgstr "Les lignes sélectionnées"
+
+#: C/gtkmm-tutorial-in.xml:2699(para)
+msgid ""
+"For single-selection, you can just call <methodname>get_selected()</"
+"methodname>, like so:"
+msgstr ""
+"Pour une simple sélection, appelez simplement la fonction membre "
+"<methodname>get_selected()</methodname>, comme suit :"
+
+#: C/gtkmm-tutorial-in.xml:2703(programlisting)
+#, no-wrap
+msgid ""
+"TreeModel::iterator iter = refTreeSelection->get_selected();\n"
+"if(iter) //If anything is selected\n"
+"{\n"
+" TreeModel::Row row = *iter;\n"
+" //Do something with the row.\n"
+"}"
+msgstr ""
+"TreeModel::iterator iter = refTreeSelection->get_selected();\n"
+"if(iter) // si quelque chose est sélectionné\n"
+"{\n"
+" TreeModel::Row row = *iter;\n"
+" // Faire quelque chose avec la ligne.\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:2710(para)
+msgid ""
+"For multiple-selection, you need to define a callback, and give it to "
+"<methodname>selected_foreach()</methodname>, "
+"<methodname>selected_foreach_path()</methodname>, or "
+"<methodname>selected_foreach_iter()</methodname>, like so:"
+msgstr ""
+"Pour une sélection multiple, vous aurez besoin de définir une fonction de "
+"rappel et de la fournir en paramètre à <methodname>selected_foreach()</"
+"methodname>, <methodname>selected_foreach_path()</methodname> ou "
+"<methodname>selected_foreach_iter()</methodname>, ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:2716(programlisting)
+#, no-wrap
+msgid ""
+"refTreeSelection->selected_foreach_iter(\n"
+" sigc::mem_fun(*this, &TheClass::selected_row_callback) );\n"
+"\n"
+"void TheClass::selected_row_callback(\n"
+" const Gtk::TreeModel::iterator& iter)\n"
+"{\n"
+" TreeModel::Row row = *iter;\n"
+" //Do something with the row.\n"
+"}"
+msgstr ""
+"refTreeSelection->selected_foreach_iter(\n"
+" sigc::mem_fun(*this, &TheClass::selected_row_callback) );\n"
+"\n"
+"void TheClass::selected_row_callback(\n"
+" const Gtk::TreeModel::iterator& iter)\n"
+"{\n"
+" TreeModel::Row row = *iter;\n"
+" // Faire quelque chose avec la ligne.\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:2729(title)
+msgid "The \"changed\" signal"
+msgstr "Le signal « changed »"
+
+#: C/gtkmm-tutorial-in.xml:2730(para)
+msgid ""
+"To respond to the user clicking on a row or range of rows, connect to the "
+"signal like so:"
+msgstr ""
+"Pour répondre à l'utilisateur qui clique sur une ligne ou une plage de "
+"lignes, connectez le signal ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:2734(programlisting)
+#, no-wrap
+msgid ""
+"refTreeSelection->signal_changed().connect(\n"
+" sigc::mem_fun(*this, &Example_StockBrowser::on_selection_changed)\n"
+");"
+msgstr ""
+"refTreeSelection->signal_changed().connect(\n"
+" sigc::mem_fun(*this, &Example_StockBrowser::on_selection_changed)\n"
+");"
+
+#: C/gtkmm-tutorial-in.xml:2740(title)
+msgid "Preventing row selection"
+msgstr "Empêcher la sélection de lignes"
+
+#: C/gtkmm-tutorial-in.xml:2741(para)
+msgid ""
+"Maybe the user should not be able to select every item in your list or tree. "
+"For instance, in the gtk-demo, you can select a demo to see the source code, "
+"but it doesn't make any sense to select a demo category."
+msgstr ""
+"Il est possible que l'utilisateur n'ait pas le droit de sélectionner tous "
+"les éléments d'une liste ou d'une arborescence. Ainsi, dans le programme gtk-"
+"demo, vous pouvez choisir un exemple pour voir le code source, mais choisir "
+"une catégorie d'exemples n'a pas de sens."
+
+#: C/gtkmm-tutorial-in.xml:2746(para)
+msgid ""
+"To control which rows can be selected, use the "
+"<methodname>set_select_function()</methodname> method, providing a "
+"<classname>sigc::slot</classname> callback. For instance:"
+msgstr ""
+"Pour contrôler quelles lignes peuvent être sélectionnées, utilisez la "
+"fonction membre <methodname>set_select_function()</methodname> et passez lui "
+"en paramètre un signal de rappel <classname>sigc::slot</classname>. Par "
+"exemple :"
+
+#: C/gtkmm-tutorial-in.xml:2751(programlisting)
+#, no-wrap
+msgid ""
+"m_refTreeSelection->set_select_function( sigc::mem_fun(*this,\n"
+" &DemoWindow::select_function) );"
+msgstr ""
+"m_refTreeSelection->set_select_function( sigc::mem_fun(*this,\n"
+" &DemoWindow::select_function) );"
+
+#: C/gtkmm-tutorial-in.xml:2753(para)
+msgid "and then"
+msgstr "puis"
+
+#: C/gtkmm-tutorial-in.xml:2756(programlisting)
+#, no-wrap
+msgid ""
+"bool DemoWindow::select_function(\n"
+" const Glib::RefPtr<Gtk::TreeModel>& model,\n"
+" const Gtk::TreeModel::Path& path, bool)\n"
+"{\n"
+" const Gtk::TreeModel::iterator iter = model->get_iter(path);\n"
+" return iter->children().empty(); // only allow leaf nodes to be selected\n"
+"}"
+msgstr ""
+"bool DemoWindow::select_function(\n"
+" const Glib::RefPtr<Gtk::TreeModel>& model,\n"
+" const Gtk::TreeModel::Path& path, bool)\n"
+"{\n"
+" const Gtk::TreeModel::iterator iter = model->get_iter(path);\n"
+" // n'autoriser que la sélection des nÅ?uds d'extrémité\n"
+" return iter->children().empty(); \n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:2766(title)
+msgid "Changing the selection"
+msgstr "Modification de la sélection"
+
+#: C/gtkmm-tutorial-in.xml:2767(para)
+msgid ""
+"To change the selection, specify a <classname>Gtk::TreeModel::iterator</"
+"classname> or <classname>Gtk::TreeModel::Row</classname>, like so:"
+msgstr ""
+"Pour modifier la sélection, précisez un <classname>Gtk::TreeModel::iterator</"
+"classname> ou <classname>Gtk::TreeModel::Row</classname>, ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:2772(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::TreeModel::Row row = m_refModel->children()[5]; //The fifth row.\n"
+"if(row)\n"
+" refTreeSelection->select(row);"
+msgstr ""
+"Gtk::TreeModel::Row row = m_refModel->children()[5]; // 5ième ligne.\n"
+"if(row)\n"
+" refTreeSelection->select(row);"
+
+#: C/gtkmm-tutorial-in.xml:2775(para)
+msgid "or"
+msgstr "ou"
+
+#: C/gtkmm-tutorial-in.xml:2778(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::TreeModel::iterator iter = m_refModel->children().begin()\n"
+"if(iter)\n"
+" refTreeSelection->select(iter);"
+msgstr ""
+"Gtk::TreeModel::iterator iter = m_refModel->children().begin()\n"
+"if(iter)\n"
+" refTreeSelection->select(iter);"
+
+#: C/gtkmm-tutorial-in.xml:2787(title)
+msgid "Sorting"
+msgstr "Tris"
+
+#: C/gtkmm-tutorial-in.xml:2788(para)
+msgid ""
+"The standard tree models (<classname>TreeStore</classname> and "
+"<classname>ListStore</classname> derive from <classname>TreeSortable</"
+"classname>, so they offer sorting functionality. For instance, call "
+"<methodname>set_sort_column()</methodname>, to sort the model by the "
+"specified column. Or supply a callback function to <methodname>set_sort_func"
+"()</methodname> to implement a more complicated sorting algorithm."
+msgstr ""
+"Les modèles standard d'arborescence (<classname>TreeStore</classname> et "
+"<classname>ListStore</classname>) dérivent de la classe "
+"<classname>TreeSortable</classname> ; ils offrent donc la possibilité de "
+"tri. Par exemple, faites appel à <methodname>set_sort_column()</methodname> "
+"pour trier le modèle sur la colonne donnée, ou bien définissez une fonction "
+"de rappel pour <methodname>set_sort_func()</methodname> pour implémenter un "
+"algorithme de tri plus complexe."
+
+#: C/gtkmm-tutorial-in.xml:2792(ulink)
+msgid "TreeSortable Reference"
+msgstr "Référence de TreeSortable"
+
+#: C/gtkmm-tutorial-in.xml:2795(title)
+msgid "Sorting by clicking on columns"
+msgstr "Tri en cliquant sur l'en-tête de colonne"
+
+#: C/gtkmm-tutorial-in.xml:2796(para)
+msgid ""
+"So that a user can click on a <classname>TreeView</classname>'s column "
+"header to sort the <classname>TreeView</classname>'s contents, call "
+"<methodname>Gtk::TreeViewModel::set_sort_column()</methodname>, supplying "
+"the model column on which model should be sorted when the header is clicked. "
+"For instance:"
+msgstr ""
+"Pour implémenter le tri par clic sur l'en-tête d'une colonne d'un objet "
+"<classname>TreeView</classname> afin d'ordonner son contenu, appelez "
+"<methodname>Gtk::TreeViewModel::set_sort_column()</methodname> en indiquant "
+"la colonne du modèle sur laquelle le tri est effectué quand l'en-tête est "
+"cliquée. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:2799(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::TreeView::Column* pColumn = treeview.get_column(0);\n"
+"if(pColumn)\n"
+" pColumn->set_sort_column(m_columns.m_col_id);"
+msgstr ""
+"Gtk::TreeView::Column* pColumn = treeview.get_column(0);\n"
+"if(pColumn)\n"
+" pColumn->set_sort_column(m_columns.m_col_id);"
+
+#: C/gtkmm-tutorial-in.xml:2805(title)
+msgid "Independently sorted views of the same model"
+msgstr "Vues d'un même modèle triées de manière indépendante"
+
+#: C/gtkmm-tutorial-in.xml:2806(para)
+msgid ""
+"The <classname>TreeView</classname> already allows you to show the same "
+"<classname>TreeModel</classname> in two <classname>TreeView</classname> "
+"widgets. If you need one of these TreeViews to sort the model differently "
+"than the other then you should use a <classname>TreeModelSort</classname> "
+"instead of just, for instance, <methodname>Gtk::TreeViewModel::"
+"set_sort_column()</methodname>. <classname>TreeModelSort</classname> is a "
+"model that contains another model, presenting a sorted version of that "
+"model. For instance, you might add a sorted version of a model to a "
+"<classname>TreeView</classname> like so:"
+msgstr ""
+"Nous avons déjà vu que la classe <classname>TreeView</classname> vous permet "
+"d'afficher le même <classname>TreeModel</classname> dans deux éléments "
+"graphiques <classname>TreeView</classname> distincts. Si vous avez besoin "
+"qu'un des TreeView trie le modèle de manière différente de l'autre, vous "
+"devez utiliser un objet <classname>TreeModelSort</classname> au lieu "
+"d'utiliser uniquement <methodname>Gtk::TreeViewModel::set_sort_column()</"
+"methodname>, par exemple. <classname>TreeModelSort</classname> est un modèle "
+"contenant une version triée d'un autre modèle. Par exemple, vous pouvez "
+"ajouter une autre version triée d'un modèle à un objet <classname>TreeView</"
+"classname> ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:2809(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::TreeModelSort> sorted_model =\n"
+" Gtk::TreeModelSort::create(model);\n"
+"sorted_model->set_sort_column(columns.m_col_name, Gtk::SORT_ASCENDING);\n"
+"treeview.set_model(sorted_model);"
+msgstr ""
+"Glib::RefPtr<Gtk::TreeModelSort> sorted_model =\n"
+" Gtk::TreeModelSort::create(model);\n"
+"sorted_model->set_sort_column(columns.m_col_name, Gtk::SORT_ASCENDING);\n"
+"treeview.set_model(sorted_model);"
+
+#: C/gtkmm-tutorial-in.xml:2814(para)
+msgid ""
+"Note, however, that the TreeView will provide iterators to the sorted model. "
+"You must convert them to iterators to the underlying child model in order to "
+"perform actions on that model. For instance:"
+msgstr ""
+"Notez, toutefois, que la vue arborescente fournit des itérateurs sur le "
+"modèle trié. Vous devez les convertir en itérateurs du modèle enfant sous-"
+"jacent pour effectuer des opérations sur ce modèle. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:2816(programlisting)
+#, no-wrap
+msgid ""
+"void ExampleWindow::on_button_delete()\n"
+"{\n"
+" Glib::RefPtr<Gtk::TreeSelection> refTreeSelection =\n"
+" m_treeview.get_selection();\n"
+" if(refTreeSelection)\n"
+" {\n"
+" Gtk::TreeModel::iterator sorted_iter =\n"
+" m_refTreeSelection->get_selected();\n"
+" if(sorted_iter)\n"
+" {\n"
+" Gtk::TreeModel::iterator iter =\n"
+" m_refModelSort->convert_iter_to_child_iter(sorted_iter);\n"
+" m_refModel->erase(iter);\n"
+" }\n"
+" }\n"
+"}"
+msgstr ""
+"void ExampleWindow::on_button_delete()\n"
+"{\n"
+" Glib::RefPtr<Gtk::TreeSelection> refTreeSelection =\n"
+" m_treeview.get_selection();\n"
+" if(refTreeSelection)\n"
+" {\n"
+" Gtk::TreeModel::iterator sorted_iter =\n"
+" m_refTreeSelection->get_selected();\n"
+" if(sorted_iter)\n"
+" {\n"
+" Gtk::TreeModel::iterator iter =\n"
+" m_refModelSort->convert_iter_to_child_iter(sorted_iter);\n"
+" m_refModel->erase(iter);\n"
+" }\n"
+" }\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:2833(ulink)
+msgid "TreeModelSort Reference"
+msgstr "Référence de TreeModelSort"
+
+#: C/gtkmm-tutorial-in.xml:2839(title) C/gtkmm-tutorial-in.xml:2946(title)
+#: C/gtkmm-tutorial-in.xml:3578(title) C/gtkmm-tutorial-in.xml:4576(title)
+#: C/gtkmm-tutorial-in.xml:4738(title)
+msgid "Drag and Drop"
+msgstr "Glisser-déposer"
+
+#: C/gtkmm-tutorial-in.xml:2840(para)
+msgid ""
+"<classname>Gtk::TreeView</classname> already implments simple drag-and-drop "
+"when used with the <classname>Gtk::ListStore</classname> or <classname>Gtk::"
+"TreeStore</classname> models. If necessary, it also allows you to implement "
+"more complex behaviour when items are dragged and dropped, using the normal "
+"<link linkend=\"chapter-draganddrop\">Drag and Drop</link> API."
+msgstr ""
+"<classname>Gtk::TreeView</classname> implémente déjà le simple glisser-"
+"déposer lorsqu'on l'utilise avec des modèles <classname>Gtk::ListStore</"
+"classname> ou <classname>Gtk::TreeStore</classname>. Mais, si nécessaire, il "
+"vous permet d'implémenter des comportements plus complexes lorsque les "
+"éléments sont glissés et déposés en utilisant l'API classique du <link "
+"linkend=\"chapter-draganddrop\">glisser-déposer</link>."
+
+#: C/gtkmm-tutorial-in.xml:2849(title)
+msgid "Reorderable rows"
+msgstr "Réarrangement de lignes"
+
+#: C/gtkmm-tutorial-in.xml:2850(para)
+msgid ""
+"If you call <methodname>Gtk::TreeView::set_reorderable()</methodname> then "
+"your TreeView's items can be moved within the treeview itself. This is "
+"demonstrated in the <classname>TreeStore</classname> example."
+msgstr ""
+"Si vous faites appel à la fonction membre <methodname>Gtk::TreeView::"
+"set_reorderable()</methodname>, les éléments d'un objet TreeView peuvent "
+"être déplacés au sein même de la vue arborescente. Ceci est montré dans "
+"l'exemple <classname>TreeStore</classname>."
+
+#: C/gtkmm-tutorial-in.xml:2855(para)
+msgid ""
+"However, this does not allow you any control of which items can be dragged, "
+"and where they can be dropped. If you need that extra control then you might "
+"create a derived <literal>Gtk::TreeModel</literal> from <literal>Gtk::"
+"TreeStore</literal> or <literal>Gtk::ListStore</literal> and override the "
+"<literal>Gtk::TreeDragSource::row_draggable()</literal> and <literal>Gdk::"
+"TreeDragDest::row_drop_possible()</literal> virtual methods. You can examine "
+"the <literal>Gtk::TreeModel::Path</literal>s provided and allow or disallow "
+"dragging or dropping by return <literal>true</literal> or <literal>false</"
+"literal>."
+msgstr ""
+"Toutefois, cela ne vous donne aucun contrôle sur les éléments qu'il est "
+"possible de faire glisser et sur l'emplacement où ils peuvent être déposés. "
+"Si vous avez besoin de ce contrôle supplémentaire, vous devez créer un "
+"<literal>Gtk::TreeModel</literal> dérivé de <literal>Gtk::TreeStore</"
+"literal> ou <literal>Gtk::ListStore</literal> et opérer une surdéfinition "
+"des fonctions membres virtuelles <literal>Gtk::TreeDragSource::row_draggable"
+"()</literal> et <literal>Gdk::TreeDragDest::row_drop_possible()</literal>. "
+"Vous examinez alors les <literal>Gtk::TreeModel::Path</literal> fournis et "
+"autorisez/interdisez le glisser ou le déposer en renvoyant <literal>true</"
+"literal> ou <literal>false</literal>."
+
+#: C/gtkmm-tutorial-in.xml:2856(para)
+msgid "This is demonstrated in the drag_and_drop example."
+msgstr "Cette construction est montrée dans l'exemple du glisser-déposer."
+
+#: C/gtkmm-tutorial-in.xml:2862(title) C/gtkmm-tutorial-in.xml:2968(title)
+msgid "Popup Context Menu"
+msgstr "Menu contextuel"
+
+#: C/gtkmm-tutorial-in.xml:2863(para)
+msgid ""
+"Lots of people need to implement right-click context menus for "
+"<classname>TreeView</classname>'s so we will explain how to do that here to "
+"save you some time. Apart from one or two points, it's much the same as a "
+"normal context menu, as described in the <link linkend=\"sec-menus-popup"
+"\">menus chapter</link>."
+msgstr ""
+"Nombre de programmeurs ont besoin d'implémenter des menus contextuels "
+"s'ouvrant d'un clic droit de souris sur des objets <classname>TreeView</"
+"classname>. Pour vous faire gagner du temps, nous allons expliquer ici "
+"comment faire. � un ou deux points près, cela ressemble tout à fait à un "
+"menu contextuel normal tel que décrit dans le <link linkend=\"sec-menus-popup"
+"\">chapitre Menus</link>."
+
+#: C/gtkmm-tutorial-in.xml:2872(title)
+msgid "Handling <literal>button_press_event</literal>"
+msgstr "Gestion du signal <literal>button_press_event</literal>"
+
+#: C/gtkmm-tutorial-in.xml:2873(para)
+msgid ""
+"To detect a click of the right mouse button, you need to handle the "
+"<literal>button_press_event</literal> signal, and check exactly which button "
+"was pressed. Because the <classname>TreeView</classname> normally handles "
+"this signal completely, you need to either override the default signal "
+"handler in a derived <classname>TreeView</classname> class, or use "
+"<methodname>connect_nofify()</methodname> instead of <methodname>connect()</"
+"methodname>. You probably also want to call the default handler before doing "
+"anything else, so that the right-click will cause the row to be selected "
+"first."
+msgstr ""
+"Pour détecter un clic du bouton droit de la souris, il faut gérer le signal "
+"<literal>button_press_event</literal> et vérifier quel est exactement le "
+"bouton pressé. Comme <classname>TreeView</classname> gère normalement ce "
+"signal intégralement, vous devrez, soit procéder à la surdéfinition du "
+"gestionnaire de signal par défaut dans une classe <classname>TreeView</"
+"classname> dérivée, soit utiliser la fonction membre "
+"<methodname>connect_notify()</methodname> Ã la place de <methodname>connect()"
+"</methodname>. Vous souhaiterez probablement aussi appeler le gestionnaire "
+"par défaut avant de faire quoi que ce soit d'autre ; un clic-droit provoque "
+"donc au préalable la sélection de la ligne."
+
+#: C/gtkmm-tutorial-in.xml:2883(para)
+msgid "This is demonstrated in the Popup Custom Menu example."
+msgstr "Ceci est montré dans l'exemple Menu contextuel personnalisé."
+
+#: C/gtkmm-tutorial-in.xml:2888(title) C/gtkmm-tutorial-in.xml:3339(title)
+#: C/gtkmm-tutorial-in.xml:3514(title) C/gtkmm-tutorial-in.xml:4887(title)
+msgid "Examples"
+msgstr "Exemples"
+
+#: C/gtkmm-tutorial-in.xml:2890(title)
+msgid "ListStore"
+msgstr "ListStore"
+
+#: C/gtkmm-tutorial-in.xml:2891(para)
+msgid ""
+"This example has a <classname>Gtk::TreeView</classname> widget, with a "
+"<classname>Gtk::ListStore</classname> model."
+msgstr ""
+"Voici un exemple d'élément graphique <classname>Gtk::TreeView</classname> "
+"avec un modèle <classname>Gtk::ListStore</classname>."
+
+#: C/gtkmm-tutorial-in.xml:2908(title)
+msgid "TreeStore"
+msgstr "TreeStore"
+
+#: C/gtkmm-tutorial-in.xml:2910(para)
+msgid ""
+"This example is very similar to the <classname>ListStore</classname> "
+"example, but uses a <classname>Gtk::TreeStore</classname> model instead, and "
+"adds children to the rows."
+msgstr ""
+"C'est exemple est tout à fait semblable au précédent, mais il utilise un "
+"modèle <classname>Gtk::TreeStore</classname> à la place et il ajoute des "
+"enfants aux colonnes."
+
+#: C/gtkmm-tutorial-in.xml:2929(para)
+msgid ""
+"This example is identical to the <classname>ListStore</classname> example, "
+"but it uses <methodname>TreeView::append_column_editable()</methodname> "
+"instead of <methodname>TreeView::append_column()</methodname>."
+msgstr ""
+"Cet exemple est identique à l'exemple avec <classname>ListStore</classname>, "
+"mais il utilise <methodname>TreeView::append_column_editable()</methodname> "
+"Ã la place de <methodname>TreeView::append_column()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:2936(title)
+msgid "TreeView - Editable Cells"
+msgstr "TreeView - Cellules modifiables"
+
+#: C/gtkmm-tutorial-in.xml:2948(para)
+msgid ""
+"This example is much like the <classname>TreeStore</classname> example, but "
+"has 2 extra columns to indicate whether the row can be dragged, and whether "
+"it can receive drag-and-dropped rows. It uses a derived <classname>Gtk::"
+"TreeStore</classname> which overrides the virtual functions as described in "
+"the <link linkend=\"sec-treeview-draganddrop\">TreeView Drag and Drop</link> "
+"section.."
+msgstr ""
+"Cet exemple est similaire à l'exemple <classname>TreeStore</classname>, mais "
+"il a deux colonnes supplémentaires, une pour indiquer si la ligne peut être "
+"glissée, une pour indiquer si elle accepte des lignes déposées. Il se sert "
+"d'une classe <classname>Gtk::TreeStore</classname> dérivée dans laquelle "
+"s'opère une surdéfinition des fonctions virtuelles comme décrit dans le "
+"paragraphe <link linkend=\"sec-treeview-draganddrop\">TreeView et glisser-"
+"déposer</link>."
+
+#: C/gtkmm-tutorial-in.xml:2958(title)
+msgid "TreeView - Drag And Drop"
+msgstr "TreeView - Glisser-déposer"
+
+#: C/gtkmm-tutorial-in.xml:2970(para)
+msgid ""
+"This example is much like the <classname>ListStore</classname> example, but "
+"derives a custom <classname>TreeView</classname> in order to override the "
+"<literal>button_press_event</literal>, and also to encapsulate the tree "
+"model code in our derived class. See the <link linkend=\"sec-treeview-"
+"contextmenu\">TreeView Popup Context Menu</link> section."
+msgstr ""
+"Cet exemple est tout à fait semblable à l'exemple <classname>ListStore</"
+"classname>, excepté qu'il crée un <classname>TreeView</classname> "
+"personnalisé par dérivation pour permettre la surdéfinition de "
+"<literal>button_press_event</literal> et pour encapsuler le code du modèle "
+"d'arborescence dans cette classe dérivée. Consultez le paragraphe <link "
+"linkend=\"sec-treeview-contextmenu\">Menu contextuel et TreeView</link>."
+
+#: C/gtkmm-tutorial-in.xml:2980(title)
+msgid "TreeView - Popup Context Menu"
+msgstr "TreeView - Menu contextuel"
+
+#: C/gtkmm-tutorial-in.xml:2997(title)
+msgid "Combo Boxes"
+msgstr "Boîtes combinées"
+
+#: C/gtkmm-tutorial-in.xml:2999(para)
+msgid ""
+"The <classname>ComboBox</classname> widgets offers a list (or tree) of "
+"choices in a dropdown menu. If appropriate, it can show extra information "
+"about each item, such as text, a picture, a checkbox, or a progress bar. The "
+"<classname>ComboBox</classname> widget usually restricts the user to the "
+"available choices, but it can optionally have an <classname>Entry</"
+"classname>, allowing the user to enter arbitrary text if the none of the "
+"available choices are suitable."
+msgstr ""
+"Les éléments graphiques de la classe <classname>ComboBox</classname> offrent "
+"une liste (ou un arbre) de choix dans un menu déroulant. Opportunément, elle "
+"peut afficher des informations supplémentaires concernant chacun des "
+"éléments, comme du texte, une image, une case à cocher ou une barre de "
+"progression. L'élément graphique <classname>ComboBox</classname> n'autorise "
+"habituellement que les choix prédéfinis, mais il peut à l'occasion posséder "
+"une boîte <classname>Entry</classname>, permettant à l'utilisateur de saisir "
+"un texte quelconque si aucun de ceux qui sont proposés ne lui conviennent."
+
+#: C/gtkmm-tutorial-in.xml:3002(para)
+msgid ""
+"The list is provided via a <classname>TreeModel</classname>, and columns "
+"from this model are added to the ComboBox's view with the "
+"<methodname>ComboBox::pack_start()</methodname> method. This provides "
+"flexibility and compile-time type-safety, but the <classname>ComboBoxText</"
+"classname> class provides a simpler text-based specialization in case that "
+"flexibility is not required."
+msgstr ""
+"La liste est donnée via un objet <classname>TreeModel</classname> et les "
+"colonnes provenant de ce modèle sont insérées dans la vue de la boîte "
+"combinée avec la fonction membre <methodname>ComboBox::pack_start()</"
+"methodname>. Cela procure beaucoup de souplesse et de sécurité sur les types "
+"de données à la compilation ; mais la classe <classname>ComboBoxText</"
+"classname> dispose d'un paramétrage texte simple pour les cas où cette "
+"souplesse n'est pas recherchée."
+
+#: C/gtkmm-tutorial-in.xml:3008(title)
+msgid "The model"
+msgstr "Le modèle"
+
+#: C/gtkmm-tutorial-in.xml:3009(para)
+msgid ""
+"The model for a ComboBox can be defined and filled exactly as for a "
+"<classname>TreeView</classname>. For instance, you might derive a ComboBox "
+"class with one integer and one text columns, like so:"
+msgstr ""
+"Le modèle d'une boîte combinée se définit et se remplit exactement comme un "
+"objet <classname>TreeView</classname>. Par exemple, vous pouvez dériver à "
+"partir de ComboBox une classe comportant une colonne d'entiers et une "
+"colonne texte comme suit :"
+
+#: C/gtkmm-tutorial-in.xml:3011(programlisting)
+#, no-wrap
+msgid ""
+"ModelColumns()\n"
+"{ add(m_col_id); add(m_col_name); }\n"
+"\n"
+" Gtk::TreeModelColumn<int> m_col_id;\n"
+" Gtk::TreeModelColumn<Glib::ustring> m_col_name;\n"
+"};\n"
+"\n"
+"ModelColumns m_columns;"
+msgstr ""
+"ModelColumns()\n"
+"{ add(m_col_id); add(m_col_name); }\n"
+"\n"
+" Gtk::TreeModelColumn<int> m_col_id;\n"
+" Gtk::TreeModelColumn<Glib::ustring> m_col_name;\n"
+"};\n"
+"\n"
+"ModelColumns m_columns;"
+
+#: C/gtkmm-tutorial-in.xml:3020(para)
+msgid ""
+"After appending rows to this model, you should provide the model to the "
+"<classname>ComboBox</classname> with the <methodname>set_model()</"
+"methodname> method. Then use the <methodname>pack_start()</methodname> or "
+"<methodname>pack_end()</methodname> methods to specify what methods will be "
+"displayed in the ComboBox. As with the TreeView you may either use the "
+"default cell renderer by passing the <classname>TreeModelColumn</classname> "
+"to the pack methods, or you may instantiate a specific "
+"<classname>CellRenderer</classname> and specify a particular mapping with "
+"either <methodname>add_attribute()</methodname> or "
+"<methodname>set_cell_data_func()</methodname>. Note that these methods are "
+"in the <classname>CellLayout</classname> base class."
+msgstr ""
+"Après avoir ajouté des lignes à ce modèle, intégrez le modèle dans l'objet "
+"<classname>ComboBox</classname> avec la fonction membre <methodname>set_model"
+"()</methodname>. Puis, servez-vous des fonctions membres "
+"<methodname>pack_start()</methodname> ou <methodname>pack_end()</methodname> "
+"pour définir les colonnes à afficher dans la boîte combinée. Comme avec une "
+"vue arborescente vous pouvez, soit utiliser le moteur de rendu par défaut en "
+"passant le <classname>TreeModelColumn</classname> aux fonctions membres "
+"d'empaquetage, soit créer un exemplaire particulier de "
+"<classname>CellRenderer</classname> en définissant une correspondance "
+"personnalisée avec <methodname>add_attribute()</methodname> ou "
+"<methodname>set_cell_data_func()</methodname>. Notez que ces fonctions "
+"membres font partie de la classe de base <classname>CellLayout</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3024(title)
+msgid "The chosen item"
+msgstr "L'élément choisi"
+
+#: C/gtkmm-tutorial-in.xml:3025(para)
+msgid ""
+"To discover what item, if any, the user has chosen from the ComboBox, call "
+"<methodname>ComboBox::get_active()</methodname>. This returns a "
+"<classname>TreeModel::iterator</classname> that you can dereference to a "
+"<classname>Row</classname> in order to read the values in your columns. For "
+"instance, you might read an integer ID value from the model, even though you "
+"have chosen only to show the human-readable description in the Combo. For "
+"instance:"
+msgstr ""
+"Pour savoir quel élément, s'il y lieu, a été sélectionné dans la boîte "
+"combinée par l'utilisateur, faites appel à <methodname>ComboBox::get_active()"
+"</methodname>. Cette fonction membre renvoie un pointeur sur un "
+"<classname>TreeModel::iterator</classname> que vous pouvez déréférencer pour "
+"obtenir un objet <classname>Row</classname> afin de lire les valeurs des "
+"colonnes. Ainsi, vous pourriez lire à partir du modèle une valeur "
+"d'identification sous forme d'un entier, même si vous avez choisi de "
+"n'afficher qu'une description littérale dans la boîte combinée. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3027(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::TreeModel::iterator iter = m_Combo.get_active();\n"
+"if(iter)\n"
+"{\n"
+" Gtk::TreeModel::Row row = *iter;\n"
+"\n"
+" //Get the data for the selected row, using our knowledge\n"
+" //of the tree model:\n"
+" int id = row[m_Columns.m_col_id];\n"
+" set_something_id_chosen(id); //Your own function.\n"
+"}\n"
+"else\n"
+" set_nothing_chosen(); //Your own function."
+msgstr ""
+"Gtk::TreeModel::iterator iter = m_Combo.get_active();\n"
+"if(iter)\n"
+"{\n"
+" Gtk::TreeModel::Row row = *iter;\n"
+"\n"
+" // Obtenir les données de la ligne choisie grâce à notre \n"
+" // connaissance du modèle d'arborescence :\n"
+" int id = row[m_Columns.m_col_id];\n"
+" set_something_id_chosen(id); // Votre fonction.\n"
+"}\n"
+"else\n"
+" set_nothing_chosen(); // Votre fonction."
+
+#: C/gtkmm-tutorial-in.xml:3042(title)
+msgid "Responding to changes"
+msgstr "Réponse à une modification"
+
+#: C/gtkmm-tutorial-in.xml:3043(para)
+msgid ""
+"You might need to react to every change of selection in the ComboBox, for "
+"instance to update other widgets. To do so, you should handle the \"changed"
+"\" signal. For instance:"
+msgstr ""
+"Vous pouvez avoir besoin de réagir à un changement de sélection dans la "
+"boîte combinée, par exemple pour mettre à jour d'autres éléments graphiques. "
+"Pour cela, vous devez gérer le signal « changed ». Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3046(programlisting)
+#, no-wrap
+msgid ""
+"m_combo.signal_changed().connect( sigc::mem_fun(*this,\n"
+" &ExampleWindow::on_combo_changed) );"
+msgstr ""
+"m_combo.signal_changed().connect( sigc::mem_fun(*this,\n"
+" &ExampleWindow::on_combo_changed) );"
+
+#: C/gtkmm-tutorial-in.xml:3050(title) C/gtkmm-tutorial-in.xml:3097(title)
+msgid "Full Example"
+msgstr "Exemple complet"
+
+#: C/gtkmm-tutorial-in.xml:3053(title) C/gtkmm-tutorial-in.xml:3066(title)
+msgid "ComboBox"
+msgstr "ComboBox"
+
+#: C/gtkmm-tutorial-in.xml:3063(title) C/gtkmm-tutorial-in.xml:3110(title)
+msgid "Simple Text Example"
+msgstr "Exemple texte simple"
+
+#: C/gtkmm-tutorial-in.xml:3077(title)
+msgid "ComboBox with an Entry"
+msgstr "Boîte combinée avec saisie"
+
+#: C/gtkmm-tutorial-in.xml:3079(para)
+msgid ""
+"A <classname>ComboBox</classname> may contain an <classname>Entry</"
+"classname> widget for entering of arbitrary text, by specifying true for the "
+"constructor's <literal>has_entry</literal> parameter."
+msgstr ""
+"Une <classname>ComboBox</classname> peut contenir un élément graphique "
+"<classname>Entry</classname> afin de saisir un texte arbitraire en fixant à "
+"true (vrai) le paramètre <literal>has_entry</literal> du constructeur."
+
+#: C/gtkmm-tutorial-in.xml:3082(title)
+msgid "The text column"
+msgstr "La colonne texte"
+
+#: C/gtkmm-tutorial-in.xml:3084(programlisting)
+#, no-wrap
+msgid "m_combo.set_text_column(m_columns.m_col_name);"
+msgstr "m_combo.set_text_column(m_columns.m_col_name);"
+
+#: C/gtkmm-tutorial-in.xml:3083(para)
+msgid ""
+"So that the Entry can interact with the drop-down list of choices, you must "
+"specify which of your model columns are the text column, with "
+"<methodname>set_text_column()</methodname>. For instance: <placeholder-1/>"
+msgstr ""
+"Comme l'objet <classname>Entry</classname> peut interagir avec la liste "
+"déroulante des choix, vous devez indiquer parmi les colonnes de votre modèle "
+"quelle est la colonne texte concernée avec <methodname>set_text_column()</"
+"methodname>. Par exemple : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:3086(para)
+msgid ""
+"When you select a choice from the drop-down menu, the value from this column "
+"will be placed in the <classname>Entry</classname>."
+msgstr ""
+"Si vous faites une sélection dans le menu déroulant, la valeur de cette "
+"colonne sera placée dans l'élément graphique <classname>Entry</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3092(title)
+msgid "The entry"
+msgstr "La saisie"
+
+#: C/gtkmm-tutorial-in.xml:3093(para)
+msgid ""
+"Because the user may enter arbitrary text, an active model row isn't enough "
+"to tell us what text the user has inputted. Therefore, you should retrieve "
+"the <classname>Entry</classname> widget with the <methodname>ComboBoxEntry::"
+"get_entry()</methodname> method and call <methodname>get_text()</methodname> "
+"on that."
+msgstr ""
+"�tant donné que l'utilisateur peut saisir n'importe quel texte, une ligne "
+"active du modèle ne suffit pas pour indiquer quel est le texte saisi par "
+"l'utilisateur. C'est pourquoi, vous devez retrouver l'élément graphique "
+"<classname>Entry</classname> avec la fonction membre "
+"<methodname>ComboBoxEntry::get_entry()</methodname> et appeler "
+"<methodname>get_text()</methodname> sur cet objet."
+
+#: C/gtkmm-tutorial-in.xml:3100(title)
+msgid "ComboBoxEntry"
+msgstr "Boîte combinée avec saisie"
+
+#: C/gtkmm-tutorial-in.xml:3113(title)
+msgid "ComboBoxEntryText"
+msgstr "Boîte combinée avec saisie de texte"
+
+#: C/gtkmm-tutorial-in.xml:3132(title) C/gtkmm-tutorial-in.xml:3344(title)
+msgid "TextView"
+msgstr "�lément graphique TextView"
+
+#: C/gtkmm-tutorial-in.xml:3133(para)
+msgid ""
+"The <classname>TextView</classname> widget can be used to display and edit "
+"large amounts of formatted text. Like the <classname>TreeView</classname>, "
+"it has a model/view design. In this case the <classname>TextBuffer</"
+"classname> is the model."
+msgstr ""
+"L'élément graphique <classname>TextView</classname> s'utilise pour afficher "
+"et modifier de grosses quantités de texte formatté. Comme l'objet "
+"<classname>TreeView</classname>, il y a une correspondance vue/modèle. Dans "
+"le cas présent, le modèle est l'objet <classname>TextBuffer</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3141(title)
+msgid "The Buffer"
+msgstr "Le tampon"
+
+#: C/gtkmm-tutorial-in.xml:3142(para)
+msgid ""
+"<classname>Gtk::TextBuffer</classname> is a model containing the data for "
+"the <classname>Gtk::TextView</classname>, like the <classname>Gtk::"
+"TreeModel</classname> used by <classname>Gtk::TreeView</classname>. This "
+"allows two or more <classname>Gtk::TextView</classname>s to share the same "
+"<classname>TextBuffer</classname>, and allows those TextBuffers to be "
+"displayed slightly differently. Or you could maintain several "
+"<classname>Gtk::TextBuffer</classname>s and choose to display each one at "
+"different times in the same <classname>Gtk::TextView</classname> widget."
+msgstr ""
+"<classname>Gtk::TextBuffer</classname> est un modèle contenant les données "
+"pour <classname>Gtk::TextView</classname>, tout comme <classname>Gtk::"
+"TreeModel</classname> utilisé par <classname>Gtk::TreeView</classname>. Cela "
+"permet à deux <classname>Gtk::TextView</classname> ou plus de partager le "
+"même <classname>TextBuffer</classname> tout en étant affichés de façon "
+"légèrement différente. Ou bien encore, vous pouvez disposer de plusieurs "
+"<classname>Gtk::TextBuffer</classname> et choisir d'afficher dans le même "
+"élément graphique <classname>Gtk::TextView</classname> le contenu de l'un ou "
+"l'autre d'entre eux selon les circonstances."
+
+#: C/gtkmm-tutorial-in.xml:3152(para)
+msgid ""
+"The <classname>TextView</classname> creates its own default "
+"<classname>TextBuffer</classname>, which you can access via the "
+"<methodname>get_buffer()</methodname> method."
+msgstr ""
+"L'objet <classname>TextView</classname> crée par défaut son propre "
+"<classname>TextBuffer</classname>. Vous y accédez avec la fonction membre "
+"<methodname>get_buffer()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:3161(title)
+msgid "Iterators"
+msgstr "Itérateurs"
+
+#: C/gtkmm-tutorial-in.xml:3167(title)
+msgid "Tags and Formatting"
+msgstr "Balisages et formats"
+
+#: C/gtkmm-tutorial-in.xml:3170(title)
+msgid "Tags"
+msgstr "Balisages"
+
+#: C/gtkmm-tutorial-in.xml:3171(para)
+msgid ""
+"To specify that some text in the buffer should have specific formatting, you "
+"must define a tag to hold that formatting information, and then apply that "
+"tag to the region of text. For instance, to define the tag and its "
+"properties:"
+msgstr ""
+"Pour indiquer que du texte dans le tampon doit bénéficier de tel ou tel "
+"format, vous devez définir une balise précisant cette information de format, "
+"puis appliquer ce balisage à une zone de texte. Ainsi, pour définir le "
+"balisage et ses propriétés :"
+
+#: C/gtkmm-tutorial-in.xml:3174(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::TextBuffer::Tag> refTagMatch =\n"
+" Gtk::TextBuffer::Tag::create();\n"
+"refTagMatch->property_background() = \"orange\";"
+msgstr ""
+"Glib::RefPtr<Gtk::TextBuffer::Tag> refTagMatch =\n"
+" Gtk::TextBuffer::Tag::create();\n"
+"refTagMatch->property_background() = \"orange\";"
+
+#: C/gtkmm-tutorial-in.xml:3177(para)
+msgid ""
+"You can specify a name for the <classname>Tag</classname> when using the "
+"<methodname>create()</methodname> method, but it is not necessary."
+msgstr ""
+"Vous pouvez définir un nom pour l'objet <classname>Tag</classname> quand "
+"vous appelez la fonction membre <methodname>create()</methodname>, mais ce "
+"n'est pas obligatoire."
+
+#: C/gtkmm-tutorial-in.xml:3182(para)
+msgid "The <classname>Tag</classname> class has many other properties."
+msgstr ""
+"La classe <classname>Tag</classname> dispose de nombreuses autres propriétés."
+
+#: C/gtkmm-tutorial-in.xml:3191(title)
+msgid "TagTable"
+msgstr "Tableau des balises"
+
+#: C/gtkmm-tutorial-in.xml:3193(para)
+msgid ""
+"Each <classname>Gtk::TextBuffer</classname> uses a <classname>Gtk::"
+"TextBuffer::TagTable</classname>, which contains the <classname>Tag</"
+"classname>s for that buffer. 2 or more <classname>TextBuffer</classname>s "
+"may share the same <classname>TagTable</classname>. When you create "
+"<classname>Tag</classname>s you should add them to the <classname>TagTable</"
+"classname>. For instance:"
+msgstr ""
+"Chaque <classname>Gtk::TextBuffer</classname> utilise un objet "
+"<classname>Gtk::TextBuffer::TagTable</classname> contenant les balises pour "
+"ce tampon. Deux objets <classname>TextBuffer</classname> ou plus peuvent "
+"partager le même objet <classname>TagTable</classname>. Quand vous créez un "
+"objet <classname>Tag</classname> vous devez l'incorporer dans l'objet "
+"<classname>TagTable</classname>. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3201(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::TextBuffer::TagTable> refTagTable =\n"
+" Gtk::TextBuffer::TagTable::create();\n"
+"refTagTable->add(refTagMatch);\n"
+"//Hopefully a future version of <application>gtkmm</application> will have a set_tag_table() method,\n"
+"//for use after creation of the buffer.\n"
+"Glib::RefPtr<Gtk::TextBuffer> refBuffer =\n"
+" Gtk::TextBuffer::create(refTagTable);"
+msgstr ""
+"Glib::RefPtr<Gtk::TextBuffer::TagTable> refTagTable =\n"
+" Gtk::TextBuffer::TagTable::create();\n"
+"refTagTable->add(refTagMatch);\n"
+"// Avec un peu de chance une future version de <application>gtkmm</application> \n"
+"// disposera d'une fonction membre set_tag_table(),\n"
+"// à utiliser après la création du tampon.\n"
+"Glib::RefPtr<Gtk::TextBuffer> refBuffer =\n"
+" Gtk::TextBuffer::create(refTagTable);"
+
+#: C/gtkmm-tutorial-in.xml:3209(para)
+msgid ""
+"You can also use <methodname>get_tag_table()</methodname> to get, and maybe "
+"modify, the <classname>TextBuffer</classname>'s default <classname>TagTable</"
+"classname> instead of creating one explicitly."
+msgstr ""
+"Vous pouvez aussi utiliser <methodname>get_tag_table()</methodname> pour "
+"obtenir, et peut-être modifier, l'objet <classname>TagTable</classname> par "
+"défaut du <classname>TextBuffer</classname> au lieu d'en créer un "
+"explicitement."
+
+#: C/gtkmm-tutorial-in.xml:3220(title)
+msgid "Applying Tags"
+msgstr "Application des balises"
+
+#: C/gtkmm-tutorial-in.xml:3221(para)
+msgid ""
+"If you have created a <classname>Tag</classname> and added it to the "
+"<classname>TagTable</classname>, you may apply that tag to part of the "
+"<classname>TextBuffer</classname> so that some of the text is displayed with "
+"that formatting. You define the start and end of the range of text by "
+"specifying <classname>Gtk::TextBuffer::iterator</classname>s. For instance:"
+msgstr ""
+"Si vous avez créé un <classname>Tag</classname> et l'avez ajouté à l'objet "
+"<classname>TagTable</classname>, vous pouvez appliquer cette balise sur une "
+"partie du texte du <classname>TextBuffer</classname> et faire ainsi en sorte "
+"que ce texte soit affiché avec ce format. Vous définissez le début et la fin "
+"de la plage de texte en définissant des marqueurs du type <classname>Gtk::"
+"TextBuffer::iterator</classname>. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3228(programlisting)
+#, no-wrap
+msgid "refBuffer->apply_tag(refTagMatch, iterRangeStart, iterRangeStop);"
+msgstr "refBuffer->apply_tag(refTagMatch, iterRangeStart, iterRangeStop);"
+
+#: C/gtkmm-tutorial-in.xml:3229(para)
+msgid ""
+"Or you could specify the tag when first inserting the text: refBuffer->"
+"insert_with_tag(iter, \"Some text\", refTagMatch);"
+msgstr ""
+"Vous pouvez également définir le balisage dès l'insertion du texte : "
+"refBuffer->insert_with_tag(iter, \"Un peu de texte\", refTagMatch);"
+
+#: C/gtkmm-tutorial-in.xml:3234(para)
+msgid ""
+"You can apply more than one <classname>Tag</classname> to the same text, by "
+"using <methodname>apply_tag()</methodname> more than once, or by using "
+"<methodname>insert_with_tags()</methodname>. The <classname>Tag</classname>s "
+"might specify different values for the same properties, but you can resolve "
+"these conflicts by using <methodname>Tag::set_priority()</methodname>."
+msgstr ""
+"Vous pouvez appliquer plus d'un objet <classname>Tag</classname> au même "
+"texte en utilisant plusieurs fois la fonction membre <methodname>apply_tag()"
+"</methodname> ou en utilisant <methodname>insert_with_tags()</methodname>. "
+"L'objet <classname>Tag</classname> peut définir des valeurs différentes pour "
+"les mêmes propriétés : dans ce cas là , il faut résoudre les conflits avec la "
+"fonction membre <methodname>Tag::set_priority()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:3246(title)
+msgid "Marks"
+msgstr "Marquages"
+
+#: C/gtkmm-tutorial-in.xml:3247(para)
+msgid ""
+"<classname>TextBuffer</classname> iterators are generally invalidated when "
+"the text changes, but you can use a <classname>Gtk::TextBuffer::Mark</"
+"classname> to remember a position in these situations. For instance,"
+msgstr ""
+"Les itérateurs du <classname>TextBuffer</classname> sont généralement "
+"invalidés si le texte est modifié ; mais, vous pouvez utiliser un objet "
+"<classname>Gtk::TextBuffer::Mark</classname> pour mémoriser une position "
+"dans ces cas-là . Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3252(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::TextBuffer::Mark> refMark =\n"
+" refBuffer->create_mark(iter);"
+msgstr ""
+"Glib::RefPtr<Gtk::TextBuffer::Mark> refMark =\n"
+" refBuffer->create_mark(iter);"
+
+#: C/gtkmm-tutorial-in.xml:3255(para)
+msgid ""
+"You can then use the <methodname>get_iter()</methodname> method later to "
+"create an iterator for the <classname>Mark</classname>'s new position."
+msgstr ""
+"Puis vous utiliserez ultérieurement la fonction membre <methodname>get_iter()"
+"</methodname> pour créer un itérateur pour la nouvelle position de l'objet "
+"<classname>Mark</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3260(para)
+msgid ""
+"There are two built-in <classname>Mark</classname>s - <literal>insert</"
+"literal> and <literal>select_bound</literal>, which you can access with "
+"<classname>TextBuffer</classname>'s <methodname>get_insert()</methodname> "
+"and <methodname>get_selection_bound()</methodname> methods."
+msgstr ""
+"Il y a deux objets <classname>Mark</classname> prédéfinis â?? <literal>insert</"
+"literal> et <literal>select_bound</literal>, objets auxquels vous aurez "
+"accès grâce aux fonctions membres <methodname>get_insert()</methodname> et "
+"<methodname>get_selection_bound()</methodname> de la classe "
+"<classname>TextBuffer</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3273(para)
+msgid ""
+"As mentioned above, each <classname>TextView</classname> has a "
+"<classname>TextBuffer</classname>, and one or more <classname>TextView</"
+"classname> can share the same <classname>TextBuffer</classname>."
+msgstr ""
+"Comme mentionné plus haut, chaque <classname>TextView</classname> possède un "
+"<classname>TextBuffer</classname> et un ou plusieurs <classname>TextView</"
+"classname> peuvent partager le même <classname>TextBuffer</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3280(para)
+msgid ""
+"Like the <classname>TreeView</classname>, you should probably put your "
+"<classname>TextView</classname> inside a <classname>ScrolledWindow</"
+"classname> to allow the user to see and move around the whole text area with "
+"scrollbars."
+msgstr ""
+"Comme pour un <classname>TreeView</classname>, vous pouvez placer l'objet "
+"<classname>TextView</classname> dans un objet <classname>ScrolledWindow</"
+"classname> pour permettre à l'utilisateur d'explorer la totalité du texte à "
+"l'aide de barres de défilement."
+
+#: C/gtkmm-tutorial-in.xml:3290(title)
+msgid "Default formatting"
+msgstr "Format par défaut"
+
+#: C/gtkmm-tutorial-in.xml:3291(para)
+msgid ""
+"<classname>TextView</classname> has various methods which allow you to "
+"change the presentation of the buffer for this particular view. Some of "
+"these may be overridden by the <classname>Gtk::TextTag</classname>s in the "
+"buffer, if they specify the same things. For instance, "
+"<methodname>set_left_margin()</methodname>, <methodname>set_right_margin()</"
+"methodname>, <methodname>set_indent()</methodname>, etc."
+msgstr ""
+"<classname>TextView</classname> dispose de diverses fonctions membres vous "
+"permettant de changer la présentation du contenu du tampon dans cette vue. "
+"Certaines peuvent être surdéfinies par les objets <classname>Gtk::TextTag</"
+"classname> dans le tampon, si elles définissent les mêmes choses. Par "
+"exemple, <methodname>set_left_margin()</methodname>, "
+"<methodname>set_right_margin()</methodname>, <methodname>set_indent()</"
+"methodname>, etc."
+
+#: C/gtkmm-tutorial-in.xml:3302(title)
+msgid "Scrolling"
+msgstr "Défilement"
+
+#: C/gtkmm-tutorial-in.xml:3303(para)
+msgid ""
+"<classname>Gtk::TextView</classname> has various <methodname>scroll_to_*()</"
+"methodname> methods. These allow you to ensure that a particular part of the "
+"text buffer is visible. For instance, your application's Find feature might "
+"use <methodname>Gtk::TextView::scroll_to_iter()</methodname> to show the "
+"found text."
+msgstr ""
+"<classname>Gtk::TextView</classname> dispose de diverses fonctions membres "
+"<methodname>scroll_to_*()</methodname>. Elles vous permettent de vous "
+"assurer qu'une zone donnée du texte du tampon est visible. Ainsi, la "
+"fonctionnalité Rechercher de votre application pourra utiliser la fonction "
+"membre <methodname>Gtk::TextView::scroll_to_iter()</methodname> pour "
+"afficher le texte trouvé."
+
+#: C/gtkmm-tutorial-in.xml:3318(title)
+msgid "Widgets and ChildAnchors"
+msgstr "�léments graphiques et ancres pour enfant"
+
+#: C/gtkmm-tutorial-in.xml:3319(para)
+msgid ""
+"You can embed widgets, such as <classname>Gtk::Button</classname>s, in the "
+"text. Each such child widget needs a <classname>ChildAnchor</classname>. "
+"ChildAnchors are associated with <classname>iterators</classname>. For "
+"instance, to create a child anchor at a particular position, use "
+"<methodname>Gtk::TextBuffer::create_child_anchor()</methodname>:"
+msgstr ""
+"Vous pouvez incorporer des éléments graphiques, comme des <classname>Gtk::"
+"Button</classname>, dans le texte. Chaque élément graphique de ce type a "
+"besoin d'un objet <classname>ChildAnchor</classname>. Les ancrages des "
+"(objets) enfants sont associés à des <classname>iterators</classname>. "
+"Ainsi, pour créer un ancrage pour un objet enfant à une position donnée, "
+"utilisez <methodname>Gtk::TextBuffer::create_child_anchor()</methodname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:3326(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::TextChildAnchor> refAnchor =\n"
+" refBuffer->create_child_anchor(iter);"
+msgstr ""
+"Glib::RefPtr<Gtk::TextChildAnchor> refAnchor =\n"
+" refBuffer->create_child_anchor(iter);"
+
+#: C/gtkmm-tutorial-in.xml:3329(para)
+msgid ""
+"Then, to add a widget at that position, use <methodname>Gtk::TextView::"
+"add_child_at_anchor()</methodname>:"
+msgstr ""
+"Puis, pour ajouter l'élément graphique à la position indiquée, servez-vous "
+"de <methodname>Gtk::TextView::add_child_at_anchor()</methodname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:3333(programlisting)
+#, no-wrap
+msgid "m_TextView.add_child_at_anchor(m_Button, refAnchor);"
+msgstr "m_TextView.add_child_at_anchor(m_Button, refAnchor);"
+
+#: C/gtkmm-tutorial-in.xml:3359(title)
+msgid "Menus and Toolbars"
+msgstr "Menus et barres d'outils"
+
+#: C/gtkmm-tutorial-in.xml:3361(para)
+msgid ""
+"There are specific APIs for Menus and toolbars, but you should usually deal "
+"with them together, using the <classname>UIManager</classname> to define "
+"<classname>Action</classname>s which you can then arrange in menu and "
+"toolbars. In this way you can handle activation of the action instead of "
+"responding to the menu and toolbar items separately. And you can enable or "
+"disable both the menu and toolbar item via the action."
+msgstr ""
+"Les menus et les barres d'outils ont des API distinctes, mais vous pouvez "
+"les manipuler simultanément en utilisant l'<classname>UIManager</classname> "
+"pour définir une <classname>Action</classname> que vous disposez ensuite à "
+"la fois dans le menu et dans la barre d'outils. De la sorte, vous pourrez "
+"gérer le déclenchement de l'action d'un coup au lieu d'organiser une réponse "
+"séparée aux éléments du menu et à ceux de la barre d'outils. Vous pourrez "
+"également activer ou désactiver les éléments de menu et de barre d'outils "
+"par l'intermédiaire de l'objet <classname>Action</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3369(para)
+msgid ""
+"This involves the use of the <classname>Gtk::ActionGroup</classname>, "
+"<classname>Gtk::Action</classname>, and <classname>UIManager</classname> "
+"classes, all of which should be instantiated via their <methodname>create()</"
+"methodname> methods, which return <classname>RefPtr</classname>s."
+msgstr ""
+"Cette façon d'opérer implique l'utilisation des classes <classname>Gtk::"
+"ActionGroup</classname>, <classname>Gtk::Action</classname> et "
+"<classname>UIManager</classname> ; chacune d'entre elles sera instanciée "
+"avec la fonction membre <methodname>create()</methodname> qui renverra un "
+"pointeur <classname>RefPtr</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3378(title)
+msgid "Actions"
+msgstr "Actions"
+
+#: C/gtkmm-tutorial-in.xml:3379(para)
+msgid ""
+"First create the <classname>Action</classname>s and add them to an "
+"<classname>ActionGroup</classname>, with <methodname>ActionGroup::add()</"
+"methodname>."
+msgstr ""
+"Créez tout d'abord un objet <classname>Action</classname> et ajoutez-le à un "
+"<classname>ActionGroup</classname> avec <methodname>ActionGroup::add()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:3385(para)
+msgid ""
+"The arguments to <methodname>Action::create()</methodname> specify the "
+"action's name and how it will appear in menus and toolbars. Use stock items "
+"where possible so that you don't need to specify the label, accelerator, "
+"icon, and tooltips, and so you can use pre-existing translations."
+msgstr ""
+"Les paramètres de <methodname>Action::create()</methodname> définissent le "
+"nom de l'action et la manière dont celle-ci apparaîtra dans les menus et "
+"barres d'outils. Utilisez des éléments du catalogue si possible ; ainsi, il "
+"ne vous sera pas nécessaire de préciser l'étiquette, le raccourci clavier, "
+"l'icône et les infobulles ; de plus, vous bénéficierez des traductions "
+"existantes."
+
+#: C/gtkmm-tutorial-in.xml:3391(para)
+msgid ""
+"You can also specify a signal handler when calling <methodname>ActionGroup::"
+"add()</methodname>. This signal handler will be called when the action is "
+"activated via either a menu item or a toolbar button."
+msgstr ""
+"Vous pouvez également indiquer le gestionnaire de signal lors de l'appel à "
+"<methodname>ActionGroup::add()</methodname>. Ce gestionnaire de signal sera "
+"appelé quand l'action sera activée par l'intermédiaire, soit de l'élément de "
+"menu, soit du bouton de la barre d'outils."
+
+#: C/gtkmm-tutorial-in.xml:3396(para)
+msgid "Note that you must specify actions for sub menus as well as menu items."
+msgstr ""
+"Notez que vous devez définir des actions pour les éléments de sous-menus de "
+"la même manière que pour les menus."
+
+#: C/gtkmm-tutorial-in.xml:3398(para)
+msgid "For instance:"
+msgstr "Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3400(programlisting)
+#, no-wrap
+msgid ""
+"m_refActionGroup = Gtk::ActionGroup::create();\n"
+"\n"
+"m_refActionGroup->add( Gtk::Action::create(\"MenuFile\", \"_File\") );\n"
+"m_refActionGroup->add( Gtk::Action::create(\"New\", Gtk::Stock::NEW),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_action_file_new) );\n"
+"m_refActionGroup->add( Gtk::Action::create(\"ExportData\", \"Export Data\"),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_action_file_open) );\n"
+"m_refActionGroup->add( Gtk::Action::create(\"Quit\", Gtk::Stock::QUIT),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_action_file_quit) );"
+msgstr ""
+"m_refActionGroup = Gtk::ActionGroup::create();\n"
+"\n"
+"m_refActionGroup->add( Gtk::Action::create(\"MenuFile\", \"_File\") );\n"
+"m_refActionGroup->add( Gtk::Action::create(\"New\", Gtk::Stock::NEW),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_action_file_new) );\n"
+"m_refActionGroup->add( Gtk::Action::create(\"ExportData\", \"Export Data\"),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_action_file_open) );\n"
+"m_refActionGroup->add( Gtk::Action::create(\"Quit\", Gtk::Stock::QUIT),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_action_file_quit) );"
+
+#: C/gtkmm-tutorial-in.xml:3410(para)
+msgid ""
+"Note that this is where we specify the names of the actions as they will be "
+"seen by users in menus and toolbars. Therefore, this is where you should "
+"make strings translatable, by putting them inside the _() macro. When we use "
+"the Gtk::Stock items, of course, translations are automatically available."
+msgstr ""
+"Notez que les noms des actions, tels qu'ils seront vus par l'utilisateur "
+"dans les menus et les barres d'outils, est précisé ici. En les plaçant dans "
+"la macro _(), ces chaînes pourront être traduites. Quand vous utilisez les "
+"éléments du catalogue Gtk::Stock, les traductions sont, bien entendu, "
+"automatiquement accessibles."
+
+#: C/gtkmm-tutorial-in.xml:3415(title)
+msgid "UIManager"
+msgstr "UIManager"
+
+#: C/gtkmm-tutorial-in.xml:3416(para)
+msgid ""
+"Next you should create a <classname>UIManager</classname> and add the "
+"<classname>ActionGroup</classname> to the <classname>UIManager</classname> "
+"with <methodname>insert_action_group()</methodname> At this point is also a "
+"good idea to tell the parent window to respond to the specified keyboard "
+"shortcuts, by using <methodname>add_accel_group()</methodname>."
+msgstr ""
+"Vous devez ensuite créer un <classname>UIManager</classname> dans lequel "
+"vous ajoutez les objets <classname>ActionGroup</classname> avec "
+"<methodname>insert_action_group()</methodname>. Il est judicieux d'indiquer "
+"à cet instant à la fenêtre parent de répondre aux raccourcis claviers avec "
+"la fonction membre <methodname>add_accel_group()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:3424(para) C/gtkmm-tutorial-in.xml:4805(para)
+msgid "For instance,"
+msgstr "Par exemple,"
+
+#: C/gtkmm-tutorial-in.xml:3426(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::UIManager> m_refUIManager =\n"
+" Gtk::UIManager::create();\n"
+"m_refUIManager->insert_action_group(m_refActionGroup);\n"
+"add_accel_group(m_refUIManager->get_accel_group());"
+msgstr ""
+"Glib::RefPtr<Gtk::UIManager> m_refUIManager =\n"
+" Gtk::UIManager::create();\n"
+"m_refUIManager->insert_action_group(m_refActionGroup);\n"
+"add_accel_group(m_refUIManager->get_accel_group());"
+
+#: C/gtkmm-tutorial-in.xml:3430(para)
+msgid ""
+"Then, you can define the actual visible layout of the menus and toolbars, "
+"and add the UI layout to the <classname>UIManager</classname>. This \"ui "
+"string\" uses an XML format, in which you should mention the names of the "
+"actions that you have already created. For instance:"
+msgstr ""
+"Puis, vous définissez la disposition réelle de l'affichage des menus et des "
+"barres d'outils en insérant l'agencement de l'UI dans "
+"l'<classname>UIManager</classname>. Cette « chaîne ui » utilise un format XML "
+"dans lequel vous mentionnez le nom des actions que vous venez de créer. Par "
+"exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3436(programlisting)
+#, no-wrap
+msgid ""
+"Glib::ustring ui_info =\n"
+" \"<ui>\"\n"
+" \" <menubar name='MenuBar'>\"\n"
+" \" <menu action='MenuFile'>\"\n"
+" \" <menuitem action='New'/>\"\n"
+" \" <menuitem action='Open'/>\"\n"
+" \" <separator/>\"\n"
+" \" <menuitem action='Quit'/>\"\n"
+" \" </menu>\"\n"
+" \" <menu action='MenuEdit'>\"\n"
+" \" <menuitem action='Cut'/>\"\n"
+" \" <menuitem action='Copy'/>\"\n"
+" \" <menuitem action='Paste'/>\"\n"
+" \" </menu>\"\n"
+" \" </menubar>\"\n"
+" \" <toolbar name='ToolBar'>\"\n"
+" \" <toolitem action='Open'/>\"\n"
+" \" <toolitem action='Quit'/>\"\n"
+" \" </toolbar>\"\n"
+" \"</ui>\";\n"
+"\n"
+"m_refUIManager->add_ui_from_string(ui_info);"
+msgstr ""
+"Glib::ustring ui_info =\n"
+" \"<ui>\"\n"
+" \" <menubar name='MenuBar'>\"\n"
+" \" <menu action='MenuFile'>\"\n"
+" \" <menuitem action='New'/>\"\n"
+" \" <menuitem action='Open'/>\"\n"
+" \" <separator/>\"\n"
+" \" <menuitem action='Quit'/>\"\n"
+" \" </menu>\"\n"
+" \" <menu action='MenuEdit'>\"\n"
+" \" <menuitem action='Cut'/>\"\n"
+" \" <menuitem action='Copy'/>\"\n"
+" \" <menuitem action='Paste'/>\"\n"
+" \" </menu>\"\n"
+" \" </menubar>\"\n"
+" \" <toolbar name='ToolBar'>\"\n"
+" \" <toolitem action='Open'/>\"\n"
+" \" <toolitem action='Quit'/>\"\n"
+" \" </toolbar>\"\n"
+" \"</ui>\";\n"
+"\n"
+"m_refUIManager->add_ui_from_string(ui_info);"
+
+#: C/gtkmm-tutorial-in.xml:3459(para)
+msgid ""
+"Remember that these names are just the identifiers that we used when "
+"creating the actions. They are not the text that the user will see in the "
+"menus and toolbars. We provided those human-readable names when we created "
+"the actions."
+msgstr ""
+"Souvenez-vous que ces noms sont uniquement les identifiants utilisés lors de "
+"la création des actions. Ce n'est pas le texte que l'utilisateur verra dans "
+"les menus et les barres d'outils. Nous avons indiqué les libellés lisibles "
+"par l'utilisateur lors de la création des actions."
+
+#: C/gtkmm-tutorial-in.xml:3460(para)
+msgid ""
+"To instantiate a <classname>Gtk::MenuBar</classname> or <classname>Gtk::"
+"Toolbar</classname> which you can actually show, you should use the "
+"<methodname>UIManager::get_widget()</methodname> method, and then add the "
+"widget to a container. For instance:"
+msgstr ""
+"Pour créer un objet <classname>Gtk::MenuBar</classname> ou <classname>Gtk::"
+"Toolbar</classname> que vous pouvez vraiment afficher, utilisez la fonction "
+"membre <methodname>UIManager::get_widget()</methodname> et ajoutez l'élément "
+"graphique dans un conteneur. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3466(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::Widget* pMenubar = m_refUIManager->get_widget(\"/MenuBar\");\n"
+"pBox->add(*pMenuBar, Gtk::PACK_SHRINK);"
+msgstr ""
+"Gtk::Widget* pMenubar = m_refUIManager->get_widget(\"/MenuBar\");\n"
+"pBox->add(*pMenuBar, Gtk::PACK_SHRINK);"
+
+#: C/gtkmm-tutorial-in.xml:3472(title)
+msgid "Popup Menus"
+msgstr "Menus contextuels"
+
+#: C/gtkmm-tutorial-in.xml:3473(para)
+msgid ""
+"<classname>Menus</classname> are normally just added to a window, but they "
+"can also be displayed temporarily as the result of a mouse button click. For "
+"instance, a context menu might be displayed when the user clicks their right "
+"mouse button."
+msgstr ""
+"Normalement, les menus sont seulement ajoutés à une fenêtre, mais ils "
+"peuvent aussi être temporairement affichés lors d'un clic de souris. Par "
+"exemple, un menu contextuel peut s'afficher si l'utilisateur clique sur un "
+"élément avec le bouton droit de la souris."
+
+#: C/gtkmm-tutorial-in.xml:3480(para)
+msgid ""
+"The UI layout for a popup menu should use the <literal>popup</literal> node. "
+"For instance:"
+msgstr ""
+"La présentation UI d'un menu contextuel utilise la balise <literal>popup</"
+"literal>. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3482(programlisting)
+#, no-wrap
+msgid ""
+"Glib::ustring ui_info =\n"
+" \"<ui>\"\n"
+" \" <popup name='PopupMenu'>\"\n"
+" \" <menuitem action='ContextEdit'/>\"\n"
+" \" <menuitem action='ContextProcess'/>\"\n"
+" \" <menuitem action='ContextRemove'/>\"\n"
+" \" </popup>\"\n"
+" \"</ui>\";\n"
+"\n"
+"m_refUIManager->add_ui_from_string(ui_info);"
+msgstr ""
+"Glib::ustring ui_info =\n"
+" \"<ui>\"\n"
+" \" <popup name='PopupMenu'>\"\n"
+" \" <menuitem action='ContextEdit'/>\"\n"
+" \" <menuitem action='ContextProcess'/>\"\n"
+" \" <menuitem action='ContextRemove'/>\"\n"
+" \" </popup>\"\n"
+" \"</ui>\";\n"
+"\n"
+"m_refUIManager->add_ui_from_string(ui_info);"
+
+#: C/gtkmm-tutorial-in.xml:3493(para)
+msgid ""
+"To show the popup menu, use <classname>Gtk::Menu</classname>'s "
+"<methodname>popup()</methodname> method, providing the button identifier and "
+"the time of activation, as provided by the <literal>button_press_event</"
+"literal> signal, which you will need to handle anyway. For instance:"
+msgstr ""
+"Pour afficher le menu contextuel, utilisez la fonction membre "
+"<methodname>popup()</methodname> de la classe <classname>Gtk::Menu</"
+"classname>. Vous indiquez l'identifiant du bouton de souris et le délai "
+"d'activation tels que fournis par le signal <literal>button_press_event</"
+"literal>, signal que vous devez gérer de toutes façons. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:3499(programlisting)
+#, no-wrap
+msgid ""
+"bool ExampleWindow::on_button_press_event(GdkEventButton* event)\n"
+"{\n"
+" if( (event->type == GDK_BUTTON_PRESS) &&\n"
+" (event->button == 3) )\n"
+" {\n"
+" m_Menu_Popup->popup(event->button, event->time);\n"
+" return true; //It has been handled.\n"
+" }\n"
+" else\n"
+" return false;\n"
+"}"
+msgstr ""
+"bool ExampleWindow::on_button_press_event(GdkEventButton* event)\n"
+"{\n"
+" if( (event->type == GDK_BUTTON_PRESS) &&\n"
+" (event->button == 3) )\n"
+" {\n"
+" m_Menu_Popup->popup(event->button, event->time);\n"
+" return true; // Il est géré.\n"
+" }\n"
+" else\n"
+" return false;\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:3516(title)
+msgid "Main Menu example"
+msgstr "Exemple de menu principal"
+
+#: C/gtkmm-tutorial-in.xml:3519(title)
+msgid "Main Menu"
+msgstr "Menu principal"
+
+#: C/gtkmm-tutorial-in.xml:3529(title)
+msgid "Popup Menu example"
+msgstr "Exemple de menu contextuel"
+
+#: C/gtkmm-tutorial-in.xml:3532(title)
+msgid "Popup Menu"
+msgstr "Menu contextuel"
+
+#: C/gtkmm-tutorial-in.xml:3547(title) C/gtkmm-tutorial-in.xml:3588(title)
+msgid "ToolPalette"
+msgstr "Palette d'outils"
+
+#: C/gtkmm-tutorial-in.xml:3549(para)
+msgid ""
+"A <classname>ToolPalette</classname> is similar to a <classname>Toolbar</"
+"classname> but can contain a grid of items, categorized into groups. The "
+"user may hide or expand each group. As in a toolbar, the items may be "
+"displayed as only icons, as only text, or as icons with text."
+msgstr ""
+"L'objet <classname>ToolPalette</classname> est semblable à un objet "
+"<classname>Toolbar</classname>, mais il peut comporter un quadrillage "
+"d'éléments classés en groupements. L'utilisateur peut masquer ou développer "
+"chaque groupement. Comme dans une barre d'outils, les éléments sont affichés "
+"sous forme d'icônes uniquement, texte uniquement ou icônes avec texte."
+
+#: C/gtkmm-tutorial-in.xml:3551(para)
+msgid ""
+"The <classname>ToolPalette</classname>'s items might be dragged or simply "
+"activated. For instance, the user might drag objects to a canvas to create "
+"new items there. Or the user might click an item to activate a certain brush "
+"size in a drawing application."
+msgstr ""
+"Il est possible de faire glisser, ou simplement activer, les éléments d'un "
+"objet <classname>ToolPalette</classname>. Par exemple, l'utilisateur peut "
+"faire glisser des objets sur un canevas pour y créer de nouveaux éléments, "
+"ou bien, il peut cliquer sur un élément pour activer une taille de plume "
+"donnée dans une application de tracé."
+
+#: C/gtkmm-tutorial-in.xml:3552(para)
+msgid ""
+"<classname>ToolItemGroup</classname>s should be added to the tool pallete "
+"via the base class's <function>Gtk::Container::add()</function> method, for "
+"instance like so:"
+msgstr ""
+"Ajoutez un <classname>ToolItemGroup</classname> Ã une palette d'outils par "
+"l'intermédiaire de la fonction membre <function>Gtk::Container::add()</"
+"function> de la classe de base. Comme ceci :"
+
+#: C/gtkmm-tutorial-in.xml:3555(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Gtk::ToolItemGroup* group_brushes =\n"
+" Gtk::manage(new Gtk::ToolItemGroup(\"Brushes\"));\n"
+"m_ToolPalette.add(*group_brushes);\n"
+msgstr ""
+"\n"
+"Gtk::ToolItemGroup* group_brushes =\n"
+" Gtk::manage(new Gtk::ToolItemGroup(\"Brosses\"));\n"
+"m_ToolPalette.add(*group_brushes);\n"
+
+#: C/gtkmm-tutorial-in.xml:3561(para)
+msgid ""
+"<classname>Gtk::ToolItem</classname>s can then be added to the group. For "
+"instance, like so:"
+msgstr ""
+"Les éléments <classname>Gtk::ToolItem</classname> sont ensuite ajoutés au "
+"groupement. Ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:3565(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Gtk::ToolButton* button = Gtk::manage(new Gtk::ToolButton(icon, \"Big\"));\n"
+"button->set_tooltip_text(\"Big Brush);\n"
+"group_brushes->insert(*button);\n"
+msgstr ""
+"\n"
+"Gtk::ToolButton* button = Gtk::manage(new Gtk::ToolButton(icon, \"Grande\"));\n"
+"button->set_tooltip_text(\"Grande brosse);\n"
+"group_brushes->insert(*button);\n"
+
+#: C/gtkmm-tutorial-in.xml:3571(para)
+msgid ""
+"You might then handle the <classname>ToolButton</classname>'s "
+"<literal>clicked</literal> signal. Alternatively, you could allow the item "
+"to be dragged to another widget, by calling <methodname>Gtk::ToolPalette::"
+"add_drag_dest()</methodname> and then using <methodname>Gtk::ToolPalette::"
+"get_drag_item()</methodname> in the other widget's "
+"<literal>drag_data_received</literal> signal handler."
+msgstr ""
+"Vous pouvez après cela gérer le signal <literal>clicked</literal> sur "
+"l'objet <classname>ToolButton</classname>. Autre possibilité, vous pouvez "
+"autoriser le glisser-déposer de l'élément sur un autre élément graphique "
+"avec <methodname>Gtk::ToolPalette::add_drag_dest()</methodname>, puis en "
+"faisant appel à <methodname>Gtk::ToolPalette::get_drag_item()</methodname> "
+"dans le gestionnaire du signal <literal>drag_data_received</literal> de "
+"l'autre élément graphique."
+
+#: C/gtkmm-tutorial-in.xml:3573(ulink)
+msgid "ToolPalette Reference"
+msgstr "Référence de ToolPalette"
+
+#: C/gtkmm-tutorial-in.xml:3574(ulink)
+msgid "ToolItemGroup Reference"
+msgstr "Référence de ToolItemGroup"
+
+#: C/gtkmm-tutorial-in.xml:3575(ulink)
+msgid "ToolItem Reference"
+msgstr "Référence de ToolItem"
+
+#: C/gtkmm-tutorial-in.xml:3579(para)
+msgid ""
+"Call <methodname>add_drag_dest()</methodname> to allow items or groups to be "
+"dragged from the tool palette to a particular destination widget. You can "
+"then use <methodname>get_drag_item()</methodname> to discover which ToolItem "
+"or ToolItemGroup is being dragged. You can use <literal>dynamic_cast</"
+"literal> to discover whether is it an item or a group. For instance, you "
+"might use this in your <literal>drag_data_received</literal> signal handler, "
+"to add a dropped item, or to show a suitable icon while dragging."
+msgstr ""
+"Appelez la fonction membre <methodname>add_drag_dest()</methodname> pour "
+"permettre le glisser-déposer d'éléments ou de groupes depuis une palette "
+"d'outils jusqu'à un élément graphique destination donné. Puis vous pouvez "
+"vous servir de <methodname>get_drag_item()</methodname> pour savoir quel "
+"outil élémentaire ou quel groupe a été glissé. Un <literal>dynamic_cast</"
+"literal> vous permet de savoir s'il s'agit d'un élément ou d'un groupe. "
+"Ainsi, dans le gestionnaire du signal <literal>drag_data_received</literal> "
+"vous utilisez ce forçage de type pour ajouter un élément déposé ou pour "
+"afficher une icône adaptée pendant le glissé."
+
+#: C/gtkmm-tutorial-in.xml:3580(para)
+msgid ""
+"See the <link linkend=\"chapter-draganddrop\">Drag and Drop</link> chapter "
+"for general advice about Drag and Drop with gtkmm."
+msgstr ""
+"Consultez le chapitre <link linkend=\"chapter-draganddrop\">Glisser-déposer</"
+"link> pour des considérations générales sur cette fonctionnalité avec gtkmm."
+
+#: C/gtkmm-tutorial-in.xml:3583(title)
+msgid "ToolPalette Example"
+msgstr "Exemple de palette d'outils"
+
+#: C/gtkmm-tutorial-in.xml:3585(para)
+msgid ""
+"This example adds a <classname>ToolPalette</classname> and a "
+"<classname>DrawingArea</classname> to a window and allows the user to drag "
+"icons from the tool palette to the drawing area. The tool palette contains "
+"several groups of items. The combo boxes allow the user to change the style "
+"and orientation of the tool palette."
+msgstr ""
+"Dans cet exemple, des objets <classname>ToolPalette</classname> et "
+"<classname>DrawingArea</classname> sont associés à une fenêtre. "
+"L'utilisateur est autorisé à faire un glisser-déposer depuis la palette "
+"d'outils sur la surface de tracé. La palette d'outils contient divers "
+"groupes d'éléments. Des boîtes combinées permettent à l'utilisateur de "
+"changer le style et l'orientation de la palette d'outils."
+
+#: C/gtkmm-tutorial-in.xml:3601(title)
+msgid "Adjustments"
+msgstr "Ajustements"
+
+#: C/gtkmm-tutorial-in.xml:3603(para)
+msgid ""
+"<application>gtkmm</application> has various widgets that can be visually "
+"adjusted using the mouse or the keyboard, such as the <classname>Range</"
+"classname> widgets (described in the <link linkend=\"chapter-range-widgets"
+"\">Range Widgets</link> section). There are also a few widgets that display "
+"some adjustable part of a larger area, such as the <classname>Viewport</"
+"classname> widget. These widgets have <classname>Gtk::Adjustment</classname> "
+"objects that express this common part of their API."
+msgstr ""
+"<application>gtkmm</application> dispose de nombreux éléments graphiques "
+"pouvant être visuellement ajustés avec la souris ou le clavier, tels les "
+"éléments graphiques <classname>Range</classname> (décrits dans le paragraphe "
+"<link linkend=\"chapter-range-widgets\">�léments graphiques à plage de "
+"réglage</link>). Il existe également un petit nombre d'éléments graphiques "
+"qui n'affichent qu'une partie ajustable d'une zone plus grande, comme "
+"l'élément graphique <classname>Viewport</classname>. Tous ces éléments "
+"graphiques sont adossés à un objet <classname>Gtk::Adjustment</classname> "
+"pour définir cette part commune du comportement de leur API."
+
+#: C/gtkmm-tutorial-in.xml:3613(para)
+msgid ""
+"So that applications can react to changes, for instance when a user moves a "
+"scrollbar, <classname>Gtk::Adjustment</classname> has a <literal>changed</"
+"literal> signal. You can then use the <methodname>get_changed()</methodname> "
+"method to discover the new value."
+msgstr ""
+"Ainsi pour que les applications puissent réagir à une demande de "
+"modification, par exemple quand l'utilisateur déplace le curseur dans la "
+"barre de défilement, l'objet <classname>Gtk::Adjustment</classname> émet le "
+"signal <literal>changed</literal>. Vous pourrez alors utiliser la fonction "
+"membre <methodname>get_changed()</methodname> pour connaître la nouvelle "
+"valeur."
+
+#: C/gtkmm-tutorial-in.xml:3621(title)
+msgid "Creating an Adjustment"
+msgstr "Création d'un objet Adjustment"
+
+#: C/gtkmm-tutorial-in.xml:3623(para)
+msgid "The <classname>Gtk::Adjustment</classname> constructor is as follows:"
+msgstr ""
+"Le constructeur de <classname>Gtk::Adjustment</classname> crée la structure "
+"suivante :"
+
+#: C/gtkmm-tutorial-in.xml:3627(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::Adjustment(float value,\n"
+" float lower,\n"
+" float upper,\n"
+" float step_increment = 1,\n"
+" float page_increment = 10,\n"
+" float page_size = 0);"
+msgstr ""
+"Gtk::Adjustment(float value,\n"
+" float lower,\n"
+" float upper,\n"
+" float step_increment = 1,\n"
+" float page_increment = 10,\n"
+" float page_size = 0);"
+
+#: C/gtkmm-tutorial-in.xml:3634(para)
+msgid ""
+"The <parameter>value</parameter> argument is the initial value of the "
+"adjustment, usually corresponding to the topmost or leftmost position of an "
+"adjustable widget. The <parameter>lower</parameter> and <parameter>upper</"
+"parameter> arguments specifies the possible range of values which the "
+"adjustment can hold. The <parameter>step_increment</parameter> argument "
+"specifies the smaller of the two increments by which the user can change the "
+"value, while the <parameter>page_increment</parameter> is the larger one. "
+"The <parameter>page_size</parameter> argument usually corresponds somehow to "
+"the visible area of a panning widget. The <parameter>upper</parameter> "
+"argument is used to represent the bottom most or right most coordinate in a "
+"panning widget's child."
+msgstr ""
+"Le paramètre <parameter>value</parameter> définit la valeur initiale de "
+"l'ajustement ; habituellement, elle correspond à la position la plus haute "
+"ou la plus à gauche de l'élément graphique à plage de réglage. Les "
+"paramètres <parameter>lower</parameter> et <parameter>upper</parameter> "
+"bornent la plage des valeurs que l'ajustement est autorisé à gérer. "
+"<parameter>step_increment</parameter> est la plus petite valeur de "
+"modification incrémentale de <parameter>value</parameter>, "
+"<parameter>page_increment</parameter> la plus grande. Le paramètre "
+"<parameter>page_size</parameter> correspond communément à quelque chose "
+"comme la partie visible d'un élément graphique panneau. Le paramètre "
+"<parameter>upper</parameter> représente la coordonnée la plus basse ou la "
+"plus à droite pour un enfant d'un élément graphique panneau."
+
+#: C/gtkmm-tutorial-in.xml:3653(title)
+msgid "Using Adjustments the Easy Way"
+msgstr "Facilité d'utilisation des objets Adjustment"
+
+#: C/gtkmm-tutorial-in.xml:3655(para)
+msgid ""
+"The adjustable widgets can be roughly divided into those which use and "
+"require specific units for these values, and those which treat them as "
+"arbitrary numbers."
+msgstr ""
+"Il est possible, grosso modo, de diviser les éléments graphiques à plage de "
+"réglage en, d'une part, ceux dont la structure d'ajustement utilise et "
+"nécessite des valeurs précises, et ceux, d'autre part, qui considèrent ces "
+"valeurs comme des nombres arbitraires."
+
+#: C/gtkmm-tutorial-in.xml:3660(para)
+msgid ""
+"The group which treats the values as arbitrary numbers includes the "
+"<classname>Range</classname> widgets (<classname>Scrollbars</classname> and "
+"<classname>Scales</classname>, the <classname>Progressbar</classname> "
+"widget, and the <classname>SpinButton</classname> widget). These widgets are "
+"typically \"adjusted\" directly by the user with the mouse or keyboard. They "
+"will treat the <parameter>lower</parameter> and <parameter>upper</parameter> "
+"values of an adjustment as a range within which the user can manipulate the "
+"adjustment's <parameter>value</parameter>. By default, they will only modify "
+"the <parameter>value</parameter> of an adjustment."
+msgstr ""
+"Le groupe qui traite ces valeurs comme des nombres arbitraires est celui des "
+"éléments graphiques <classname>Range</classname> (les éléments "
+"<classname>Scrollbars</classname>, <classname>Scales</classname>, "
+"<classname>Progressbar</classname> et <classname>SpinButton</classname>). "
+"Ces éléments graphiques sont typiquement ceux qui sont « ajustés » "
+"directement par l'utilisateur avec la souris ou le clavier. Ils considèrent "
+"les valeurs de <parameter>lower</parameter> et <parameter>upper</parameter> "
+"comme étant les bornes de la plage des valeurs dans laquelle l'utilisateur "
+"peut définir <parameter>value</parameter>. Par défaut, l'utilisateur ne peut "
+"modifier que la grandeur <parameter>value</parameter> de l'ajustement."
+
+#: C/gtkmm-tutorial-in.xml:3672(para)
+msgid ""
+"The other group includes the <classname>Viewport</classname> widget and the "
+"<classname>ScrolledWindow</classname> widget. All of these widgets use pixel "
+"values for their adjustments. These are also typically adjusted indirectly "
+"using scrollbars. While all widgets which use adjustments can either create "
+"their own adjustments or use ones you supply, you'll generally want to let "
+"this particular category of widgets create its own adjustments."
+msgstr ""
+"L'autre groupe comprend les éléments graphiques <classname>Viewport</"
+"classname> et <classname>ScrolledWindow</classname>. Tous ceux-ci utilisent "
+"des valeurs en pixels dans leur structure <literal>adjustment</literal>. Ils "
+"sont, en règle générale, « ajustés » indirectement à l'aide de barres de "
+"défilement. Comme tous les éléments graphiques utilisant des ajustements "
+"peuvent, soit créer leurs propres structures <literal>adjustement</literal>, "
+"soit utiliser celle qui leur est fournie, nous souhaiterons, en règle "
+"générale, laisser à cette catégorie particulière d'éléments graphiques le "
+"soin de créer elle-même leurs propres structures d'ajustement."
+
+#: C/gtkmm-tutorial-in.xml:3681(para)
+msgid ""
+"If you share an adjustment object between a Scrollbar and a TextView widget, "
+"manipulating the scrollbar will automagically adjust the TextView widget. "
+"You can set it up like this:"
+msgstr ""
+"Si vous partagez une structure d'ajustement entre un élément Scrollbar et un "
+"élément TextView, la manipulation de la barre de défilement ajustera comme "
+"par magie l'élément TextView. Vous pouvez définir cela comme suit :"
+
+#: C/gtkmm-tutorial-in.xml:3686(programlisting)
+#, no-wrap
+msgid ""
+"// creates its own adjustments\n"
+"Gtk::TextView textview;\n"
+"// uses the newly-created adjustment for the scrollbar as well\n"
+"Gtk::VScrollbar vscrollbar (*(textview.get_vadjustment()));"
+msgstr ""
+"// crée ses propres ajustements\n"
+"Gtk::TextView textview;\n"
+"// utilise également l'ajustement nouvellement créé pour la barre de défilement\n"
+"Gtk::VScrollbar vscrollbar (*(textview.get_vadjustment()));"
+
+#: C/gtkmm-tutorial-in.xml:3694(title)
+msgid "Adjustment Internals"
+msgstr "� l'intérieur des ajustements"
+
+#: C/gtkmm-tutorial-in.xml:3696(para)
+msgid ""
+"OK, you say, that's nice, but what if I want to create my own handlers to "
+"respond when the user adjusts a <classname>Range</classname> widget or a "
+"<classname>SpinButton</classname>. To access the value of a <classname>Gtk::"
+"Adjustment</classname>, you can use the <methodname>get_value()</methodname> "
+"and <methodname>set_value()</methodname> methods:"
+msgstr ""
+"Oui, dites-vous, c'est bien beau, mais que faire si je souhaite créer mes "
+"propres gestionnaires pour répondre à la modification par l'utilisateur d'un "
+"élément graphique <classname>Range</classname> ou <classname>SpinButton</"
+"classname>. Pour avoir accès à la valeur du paramètre <parameter>value</"
+"parameter> d'un <classname>Gtk::Adjustment</classname>, utilisez les "
+"fonctions membres <methodname>get_value()</methodname> et "
+"<methodname>set_value()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:3704(para)
+msgid ""
+"As mentioned earlier, <classname>Gtk::Adjustment</classname> can emit "
+"signals. This is, of course, how updates happen automatically when you share "
+"an <classname>Adjustment</classname> object between a <classname>Scrollbar</"
+"classname> and another adjustable widget; all adjustable widgets connect "
+"signal handlers to their adjustment's <literal>value_changed</literal> "
+"signal, as can your program."
+msgstr ""
+"Comme mentionné plus haut, <classname>Gtk::Adjustment</classname> peut "
+"émettre des signaux. C'est pourquoi, bien entendu, les mises à jour se font "
+"automatiquement quand vous partagez un objet ajustement entre un "
+"<classname>Scrollbar</classname> et un autre élément graphique ajustable ; "
+"tous les éléments graphiques ajustables connectent leurs gestionnaires de "
+"signaux au signal <literal>value_changed</literal> de l'ajustement, comme "
+"pourrait le faire le programme."
+
+#: C/gtkmm-tutorial-in.xml:3713(para)
+msgid ""
+"So, for example, if you have a <classname>Scale</classname> widget, and you "
+"want to change the rotation of a picture whenever its value changes, you "
+"would create a signal handler like this:"
+msgstr ""
+"Ainsi, par exemple, avec un élément graphique <classname>Scale</classname>, "
+"si vous voulez modifier la rotation d'une image chaque fois que "
+"<literal>value</literal> change, vous créez une fonction de rappel du type :"
+
+#: C/gtkmm-tutorial-in.xml:3718(programlisting)
+#, no-wrap
+msgid ""
+"void cb_rotate_picture (Gtk::Widget *picture)\n"
+"{\n"
+" picture->set_rotation (adj->value);\n"
+"..."
+msgstr ""
+"void cb_rotate_picture (Gtk::Widget *picture)\n"
+"{\n"
+" picture->set_rotation (adj->value);\n"
+"..."
+
+#: C/gtkmm-tutorial-in.xml:3722(para)
+msgid "and connect it to the scale widget's adjustment like this:"
+msgstr ""
+"et la connectez à l'ajustement de l'élément graphique <literal>Scale</"
+"literal> ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:3725(programlisting)
+#, no-wrap
+msgid ""
+"adj.value_changed.connect(sigc::bind<Widget*>(sigc::mem_fun(*this,\n"
+" &cb_rotate_picture), picture));"
+msgstr ""
+"adj.value_changed.connect(sigc::bind<Widget*>(sigc::mem_fun(*this,\n"
+" &cb_rotate_picture), picture));"
+
+#: C/gtkmm-tutorial-in.xml:3728(para)
+msgid ""
+"What if a widget reconfigures the <parameter>upper</parameter> or "
+"<parameter>lower</parameter> fields of its <classname>Adjustment</"
+"classname>, such as when a user adds more text to a text widget? In this "
+"case, it emits the <literal>changed</literal> signal."
+msgstr ""
+"Que se passe-t-il quand un élément graphique reconfigure les champs "
+"<parameter>upper</parameter> ou <parameter>lower</parameter> de son "
+"<classname>Adjustment</classname>, ou bien, quand un utilisateur ajoute du "
+"texte dans un élément graphique texte ? Dans ce cas, l'élément graphique "
+"émet le signal <literal>changed</literal>."
+
+#: C/gtkmm-tutorial-in.xml:3735(para)
+msgid ""
+"<classname>Range</classname> widgets typically connect a handler to this "
+"signal, which changes their appearance to reflect the change - for example, "
+"the size of the slider in a scrollbar will grow or shrink in inverse "
+"proportion to the difference between the <parameter>lower</parameter> and "
+"<parameter>upper</parameter> values of its <classname>Adjustment</classname>."
+msgstr ""
+"Les éléments graphiques <classname>Range</classname> connectent "
+"habituellement à ce signal un gestionnaire qui modifie leur apparence pour "
+"refléter le changement â?? par exemple, la taille du curseur dans une barre de "
+"défilement va croître ou diminuer en proportion inverse de la différence "
+"entre les valeurs <parameter>lower</parameter> et <parameter>upper</"
+"parameter> de son <classname>Adjustment</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3744(para)
+msgid ""
+"You probably won't ever need to attach a handler to this signal, unless "
+"you're writing a new type of range widget."
+msgstr ""
+"Vous n'aurez probablement pas besoin d'attacher un gestionnaire à ce signal, "
+"sauf si vous écrivez un nouveau type d'élément graphique à plage de réglage."
+
+#: C/gtkmm-tutorial-in.xml:3748(programlisting)
+#, no-wrap
+msgid "adjustment->changed();"
+msgstr "adjustment->changed();"
+
+#: C/gtkmm-tutorial-in.xml:3755(title)
+msgid "Widgets Without X-Windows"
+msgstr "�léments graphiques sans fenêtre-X"
+
+#: C/gtkmm-tutorial-in.xml:3757(para)
+msgid ""
+"Some Widgets do not have an associated X-Window, so they therefore do not "
+"receive X events. This means that the signals described in the <link linkend="
+"\"sec-xeventsignals\">X event signals</link> section will not be emitted. If "
+"you want to capture events for these widgets you can use a special container "
+"called <classname>Gtk::EventBox</classname>, which is described in the <link "
+"linkend=\"sec-eventbox\">EventBox</link> section."
+msgstr ""
+"Certains éléments graphiques n'ont pas de fenêtre-X associée ; ils ne sont "
+"donc pas capables de recevoir les notifications des événements X. Autrement "
+"dit : les signaux décrits au paragraphe <link linkend=\"sec-xeventsignals"
+"\">Signaux d'événements X</link> ne seront pas émis. Si vous souhaitez "
+"capturer des événements pour ces éléments graphiques, vous devez utiliser un "
+"conteneur spécial nommé <classname>Gtk::EventBox</classname> décrit au "
+"paragraphe <link linkend=\"sec-eventbox\">EventBox</link>."
+
+#: C/gtkmm-tutorial-in.xml:3766(para)
+msgid "Here is a list of some of these Widgets:"
+msgstr "Voici une liste de quelques uns de ces éléments graphiques :"
+
+#: C/gtkmm-tutorial-in.xml:3769(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::Alignment\n"
+"Gtk::Arrow\n"
+"Gtk::Bin\n"
+"Gtk::Box\n"
+"Gtk::Button\n"
+"Gtk::CheckButton\n"
+"Gtk::Fixed\n"
+"Gtk::Image\n"
+"Gtk::Item\n"
+"Gtk::Label\n"
+"Gtk::MenuItem\n"
+"Gtk::Notebook\n"
+"Gtk::Paned\n"
+"Gtk::Pixmap\n"
+"Gtk::RadioButton\n"
+"Gtk::Range\n"
+"Gtk::ScrolledWindow\n"
+"Gtk::Separator\n"
+"Gtk::Table\n"
+"Gtk::Toolbar\n"
+"Gtk::AspectFrame\n"
+"Gtk::Frame\n"
+"Gtk::VBox\n"
+"Gtk::HBox\n"
+"Gtk::VSeparator\n"
+"Gtk::HSeparator"
+msgstr ""
+"Gtk::Alignment\n"
+"Gtk::Arrow\n"
+"Gtk::Bin\n"
+"Gtk::Box\n"
+"Gtk::Button\n"
+"Gtk::CheckButton\n"
+"Gtk::Fixed\n"
+"Gtk::Image\n"
+"Gtk::Item\n"
+"Gtk::Label\n"
+"Gtk::MenuItem\n"
+"Gtk::Notebook\n"
+"Gtk::Paned\n"
+"Gtk::Pixmap\n"
+"Gtk::RadioButton\n"
+"Gtk::Range\n"
+"Gtk::ScrolledWindow\n"
+"Gtk::Separator\n"
+"Gtk::Table\n"
+"Gtk::Toolbar\n"
+"Gtk::AspectFrame\n"
+"Gtk::Frame\n"
+"Gtk::VBox\n"
+"Gtk::HBox\n"
+"Gtk::VSeparator\n"
+"Gtk::HSeparator"
+
+#: C/gtkmm-tutorial-in.xml:3796(para)
+msgid ""
+"These widgets are mainly used for decoration or layout, so you won't often "
+"need to capture events on them. They are intended to have no X-Window in "
+"order to improve performance."
+msgstr ""
+"Ces éléments graphiques sont essentiellement utilisés pour l'agencement ou "
+"la décoration ; la plupart du temps, il ne sera donc pas nécessaire de "
+"capturer d'événements sur eux. Ils n'ont pas été pourvus d'une fenêtre-X "
+"intentionnellement pour améliorer la performance."
+
+#: C/gtkmm-tutorial-in.xml:3802(title) C/gtkmm-tutorial-in.xml:3846(title)
+msgid "EventBox"
+msgstr "EventBox"
+
+#: C/gtkmm-tutorial-in.xml:3804(para)
+msgid ""
+"Some <application>gtkmm</application> widgets don't have associated X "
+"windows; they draw on their parents' windows. Because of this, they cannot "
+"receive events. Also, if they are incorrectly sized, they don't clip, so you "
+"can get messy overwriting etc. To receive events on one of these widgets, "
+"you can it inside an <classname>EventBox</classname> widget and then call "
+"<methodname>Gtk::Widget::set_events()</methodname> on the EventBox before "
+"showing it."
+msgstr ""
+"Certains éléments graphiques <application>gtkmm</application> n'ont pas de "
+"fenêtre-X associée ; ils sont affichés sur les fenêtres parentes. Pour cette "
+"raison, ils ne peuvent pas recevoir d'événements. Ainsi, s'ils ne sont pas "
+"correctement dimensionnés, ils ne seront pas rognés : vous observez alors "
+"des chevauchements désordonnés, etc. Pour recevoir des événements sur un de "
+"ces éléments graphiques, placez-le dans un conteneur <classname>EventBox</"
+"classname> et faites appel ensuite à <methodname>Gtk::Widget::set_events()</"
+"methodname> sur l'objet EventBox avant de l'afficher."
+
+#: C/gtkmm-tutorial-in.xml:3812(para)
+msgid ""
+"Although the name <classname>EventBox</classname> emphasises the event-"
+"handling method, the widget can also be used for clipping (and more; see the "
+"example below)."
+msgstr ""
+"Même si le nom <classname>EventBox</classname> met en valeur l'aspect "
+"gestion des événements, cet élément graphique peut être utilisé pour la "
+"délimitation des contours (ou plus ; voir l'exemple ci-dessous)."
+
+#. <para>TODO: Why don't they have X Windows - explain clipping.
+#. Also, how does this affect platform such as Windows and MacOS that don't use X.
+#. </para>
+#: C/gtkmm-tutorial-in.xml:3822(para)
+msgid "The constructor for <classname>Gtk::EventBox</classname> is:"
+msgstr "Le constructeur d'un objet <classname>Gtk::EventBox</classname> est :"
+
+#: C/gtkmm-tutorial-in.xml:3826(programlisting)
+#, no-wrap
+msgid "Gtk::EventBox();"
+msgstr "Gtk::EventBox();"
+
+#: C/gtkmm-tutorial-in.xml:3828(para)
+msgid ""
+"A child widget can be added to the <classname>EventBox</classname> using:"
+msgstr ""
+"L'ajout d'un élément graphique enfant à un <classname>EventBox</classname> "
+"s'effectue avec :"
+
+#: C/gtkmm-tutorial-in.xml:3832(programlisting)
+#, no-wrap
+msgid "event_box.add(child_widget);"
+msgstr "event_box.add(child_widget);"
+
+#: C/gtkmm-tutorial-in.xml:3838(para)
+msgid ""
+"The following example demonstrates both uses of an <classname>EventBox</"
+"classname> - a label is created that is clipped to a small box, and set up "
+"so that a mouse-click on the label causes the program to exit. Resizing the "
+"window reveals varying amounts of the label."
+msgstr ""
+"L'exemple suivant montre deux utilisations d'un <classname>EventBox</"
+"classname> â?? création d'une étiquette tronquée dans une petite boîte et "
+"configuration pour qu'un clic de souris sur l'étiquette fasse quitter le "
+"programme. Le redimensionnement de la fenêtre révèle plus ou moins le "
+"contenu de l'étiquette."
+
+#: C/gtkmm-tutorial-in.xml:3860(title)
+msgid "Dialogs"
+msgstr "Boîtes de dialogue"
+
+#: C/gtkmm-tutorial-in.xml:3862(para)
+msgid ""
+"Dialogs are used as secondary windows, to provide specific information or to "
+"ask questions. <classname>Gtk::Dialog</classname> windows contain a few pre-"
+"packed widgets to ensure consistency, and a <methodname>run()</methodname> "
+"method which blocks until the user dismisses the dialog."
+msgstr ""
+"Les boîtes de dialogue s'utilisent en tant que fenêtres accessoires pour "
+"donner des informations particulières ou pour poser des questions. Les "
+"fenêtres <classname>Gtk::Dialog</classname> contiennent des éléments "
+"graphiques pré-incorporés pour assurer une certaine cohérence ; elles "
+"disposent également d'une fonction membre <methodname>run()</methodname> "
+"bloquante jusqu'à ce que l'utilisateur ferme la boîte de dialogue."
+
+#: C/gtkmm-tutorial-in.xml:3869(para)
+msgid ""
+"There are several derived <classname>Dialog</classname> classes which you "
+"might find useful. <classname>Gtk::MessageDialog</classname> is used for "
+"most simple notifications. But at other times you might need to derive your "
+"own dialog class to provide more complex functionality."
+msgstr ""
+"Il y a plusieurs classes dérivées de <classname>Dialog</classname> ; vous "
+"les trouverez certainement utiles. <classname>Gtk::MessageDialog</classname> "
+"s'utilise pour la plupart des simples notifications. Mais, dans d'autres "
+"circonstances, vous aurez besoin de dériver vous-même vos propres classes de "
+"boîtes de dialogue pour obtenir des fonctionnalités plus élaborées."
+
+#: C/gtkmm-tutorial-in.xml:3876(para)
+msgid ""
+"To pack widgets into a custom dialog, you should pack them into the "
+"<classname>Gtk::VBox</classname>, available via <methodname>get_vbox()</"
+"methodname>. To just add a <classname>Button</classname> to the bottom of "
+"the <classname>Dialog</classname>, you could use the <methodname>add_button()"
+"</methodname> method."
+msgstr ""
+"Pour empaqueter des éléments graphiques dans une boîte de dialogue "
+"personnalisée, il convient de les placer dans le <classname>Gtk::VBox</"
+"classname>, obtenu par l'intermédiaire de la fonction membre "
+"<methodname>get_vbox()</methodname>. Pour simplement ajouter un bouton au "
+"bas de l'objet <classname>Dialog</classname>, utilisez la fonction membre "
+"<methodname>add_button()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:3884(para)
+msgid ""
+"The <methodname>run()</methodname> method returns an <literal>int</literal>. "
+"This may be a value from the <literal>Gtk::ResponseType</literal> if the "
+"user closed the button by clicking a standard button, or it could be the "
+"custom response value that you specified when using <methodname>add_button()"
+"</methodname>."
+msgstr ""
+"La fonction membre <methodname>run()</methodname> renvoie un entier "
+"<literal>int</literal>. C'est une valeur du type <literal>Gtk::ResponseType</"
+"literal> si l'utilisateur a fermé la fenêtre en cliquant sur un bouton "
+"standard, ou bien la valeur de réponse personnalisée définie lors de l'appel "
+"Ã la fonction membre <methodname>add_button()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:3893(title) C/gtkmm-tutorial-in.xml:3908(title)
+msgid "MessageDialog"
+msgstr "Boîte de dialogue Message"
+
+#: C/gtkmm-tutorial-in.xml:3894(para)
+msgid ""
+"<classname>MessageDialog</classname> is a convenience class, used to create "
+"simple, standard message dialogs, with a message, an icon, and buttons for "
+"user response. You can specify the type of message and the text in the "
+"constructor, as well as specifying standard buttons via the <literal>Gtk::"
+"ButtonsType</literal> enum."
+msgstr ""
+"<classname>MessageDialog</classname> est une classe de commodité, utilisée "
+"pour créer des boîtes de dialogues destinées à des messages standards "
+"simples ; elles comportent un message, une icône et des boutons pour la "
+"réponse de l'utilisateur. Vous pouvez définir le type de message et le texte "
+"à afficher dans le constructeur, de même que les boutons standards à "
+"utiliser par l'intermédiaire de l'énumération <literal>Gtk::ButtonsType</"
+"literal>."
+
+#: C/gtkmm-tutorial-in.xml:3919(title)
+msgid "FileChooserDialog"
+msgstr "Boîte de dialogue Sélection de fichier"
+
+#: C/gtkmm-tutorial-in.xml:3920(para)
+msgid ""
+"The <classname>FileChooserDialog</classname> is suitable for use with \"Open"
+"\" or \"Save\" menu items."
+msgstr ""
+"La boîte de dialogue de la classe <classname>FileChooserDialog</classname> "
+"convient pour une utilisation avec les éléments de menu « Ouvrir » ou "
+"« Enregistrer »."
+
+#: C/gtkmm-tutorial-in.xml:3924(para)
+msgid ""
+"Most of the useful member methods for this class are actually in the "
+"<classname>Gtk::FileChooser</classname> base class."
+msgstr ""
+"La plupart des fonctions membres utiles de cette classe sont en fait dans la "
+"classe de base <classname>Gtk::FileChooser</classname>."
+
+#: C/gtkmm-tutorial-in.xml:3935(title)
+msgid "FileChooser"
+msgstr "Boîte de dialogue Sélection de fichier"
+
+#: C/gtkmm-tutorial-in.xml:3945(title) C/gtkmm-tutorial-in.xml:3957(title)
+msgid "ColorSelectionDialog"
+msgstr "Boîte de dialogue Sélection de couleur"
+
+#: C/gtkmm-tutorial-in.xml:3946(para)
+msgid ""
+"The <classname>ColorSelectionDialog</classname> allows the user to choose a "
+"color."
+msgstr ""
+"La boîte de dialogue <classname>ColorSelectionDialog</classname> permet à "
+"l'utilisateur de choisir une couleur."
+
+#: C/gtkmm-tutorial-in.xml:3968(title) C/gtkmm-tutorial-in.xml:3980(title)
+msgid "FontSelectionDialog"
+msgstr "Boîte de dialogue Sélection de police"
+
+#: C/gtkmm-tutorial-in.xml:3969(para)
+msgid ""
+"The <classname>FontSelectionDialog</classname> allows the user to choose a "
+"font."
+msgstr ""
+"La boîte de dialogue <classname>FontSelectionDialog</classname> permet à "
+"l'utilisateur de choisir une police de caractères."
+
+#: C/gtkmm-tutorial-in.xml:3995(title)
+msgid "The Drawing Area Widget"
+msgstr "L'élément graphique zone de dessin"
+
+#: C/gtkmm-tutorial-in.xml:3996(para)
+msgid ""
+"The <classname>DrawingArea</classname> widget is a blank window that gives "
+"you the freedom to create any graphic you desire. Along with that freedom "
+"comes the responsibility to handle expose events on the widget. When a "
+"widget is first shown, or when it is covered and then uncovered again it "
+"needs to redraw itself. Most widgets have code to do this, but the "
+"DrawingArea does not, allowing you to write your own expose event signal "
+"handler to determine how the contents of the widget will be drawn. This is "
+"most often done by overriding the virtual <methodname>on_expose_event()</"
+"methodname> member function."
+msgstr ""
+"L'élément graphique <classname>DrawingArea</classname> est une fenêtre "
+"vierge qui vous offre la possibilité de créer librement tous les graphiques "
+"voulus. Mais, en contrepartie de cette liberté, il vous incombe la "
+"responsabilité de gérer les événements d'exposition sur l'élément graphique. "
+"Quand un élément graphique est affiché pour la première fois ou quand il est "
+"couvert puis découvert, il est nécessaire de le tracer. La plupart des "
+"éléments graphiques sont pourvus de code pour effectuer ces opérations, mais "
+"l'élément graphique DrawingArea n'en dispose pas ; il vous laisse le soin "
+"d'écrire votre propre gestionnaire des signaux d'événements d'exposition "
+"pour définir la façon dont le contenu du widget sera tracé. C'est effectué "
+"le plus souvent en surdéfinissant la fonction membre virtuelle "
+"<methodname>on_expose_event()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4008(para)
+msgid ""
+"GTK+ uses the <ulink url=\"http://cairographics.org\">Cairo</ulink> drawing "
+"API. With gtkmm, you may use the <ulink url=\"http://www.cairographics.org/"
+"cairomm/\">cairomm</ulink> C++ API for cairo."
+msgstr ""
+"GTK+ utilise l'API de dessin <ulink url=\"http://cairographics.org\">Cairo</"
+"ulink>. Avec gtkmm, vous pouvez faire usage de l'API C++ pour cairo nommée "
+"<ulink url=\"http://www.cairographics.org/cairomm/\">cairomm</ulink>."
+
+#: C/gtkmm-tutorial-in.xml:4013(para)
+msgid ""
+"You can draw very sophisticated shapes using Cairo, but the methods to do so "
+"are quite basic. Cairo provides methods for drawing straight lines, curved "
+"lines, and arcs (including circles). These basic shapes can be combined to "
+"create more complex shapes and paths which can be filled with solid colors, "
+"gradients, patterns, and other things. In addition, Cairo can perform "
+"complex transformations, do compositing of images, and render antialiased "
+"text."
+msgstr ""
+"Avec Cairo, vous pouvez tracer des figures très sophistiquées, mais les "
+"fonctions membres pour réaliser cela sont tout à fait simples. Cairo fournit "
+"des fonctions membres pour tracer des lignes droites, des lignes courbes et "
+"des arcs (y compris des cercles). Ces figures de base peuvent être combinées "
+"pour créer des formes complexes et des régions qui peuvent être remplies par "
+"des couleurs unies, des dégradés, des motifs et autres choses. En plus, "
+"Cairo peut effectuer des transformations complexes, des compositions "
+"d'images et effectuer des rendus de texte sans crénelage."
+
+#: C/gtkmm-tutorial-in.xml:4023(title)
+msgid "Cairo and Pango"
+msgstr "Cairo et Pango"
+
+#: C/gtkmm-tutorial-in.xml:4024(para)
+msgid ""
+"Although Cairo can render text, it's not meant to be a replacement for "
+"Pango. Pango is a better choice if you need to perform more advanced text "
+"rendering such as wrapping or ellipsizing text. Drawing text with Cairo "
+"should only be done if the text is part of a graphic."
+msgstr ""
+"Même si Cairo peut afficher du texte, il n'a pas été conçu pour être un "
+"remplaçant de Pango. Pango est un meilleur choix si vous devez exécuter des "
+"rendus de texte complexes comme des textes enveloppants ou inscrits dans une "
+"ellipse. L'écriture avec Cairo doit être réservée à des textes intégrés dans "
+"un graphique."
+
+#: C/gtkmm-tutorial-in.xml:4029(para)
+msgid ""
+"In this section of the tutorial, we'll cover the basic Cairo drawing model, "
+"describe each of the basic drawing elements in some detail (with examples), "
+"and then present a simple application that uses Cairo to draw a custom clock "
+"widget."
+msgstr ""
+"Dans ce paragraphe du tutoriel, nous voyons le modèle du tracé de base "
+"Cairo ; nous décrivons chacun des éléments de tracé de base dans le détail "
+"(avec des exemples) et ensuite nous présentons une application simple "
+"utilisant Cairo pour dessiner un élément graphique d'horloge analogique."
+
+#: C/gtkmm-tutorial-in.xml:4036(title)
+msgid "The Cairo Drawing Model"
+msgstr "Le modèle de tracé Cairo"
+
+#: C/gtkmm-tutorial-in.xml:4037(para)
+msgid ""
+"The basic concept of drawing in Cairo involves defining 'invisible' paths "
+"and then stroking or filling them to make them visible."
+msgstr ""
+"Le concept de base du tracé dans Cairo consiste à définir des chemins "
+"« invisibles », puis à les tracer ou les remplir pour les rendre visibles."
+
+#: C/gtkmm-tutorial-in.xml:4041(para)
+msgid ""
+"To do any drawing in <application>gtkmm</application> with Cairo, you must "
+"first create a <classname>Cairo::Context</classname> object. This class "
+"holds all of the graphics state parameters that describe how drawing is to "
+"be done. This includes information such as line width, color, the surface to "
+"draw to, and many other things. This allows the actual drawing functions to "
+"take fewer arguments to simplify the interface. In <application>gtkmm</"
+"application>, a <classname>Cairo::Context</classname> is created by calling "
+"the <methodname>Gdk::Window::create_cairo_context()</methodname> function. "
+"Since Cairo context are reference-counted objects, this function returns a "
+"<classname>Cairo::RefPtr<Cairo::Context></classname> object."
+msgstr ""
+"Pour effectuer un tracé dans <application>gtkmm</application> avec Cairo, "
+"vous devez au préalable créer un objet <classname>Cairo::Context</"
+"classname>. Cette classe contient tous les paramètres d'état graphiques "
+"décrivant comment le tracé doit être fait. Ces informations comprennent "
+"entre autres l'épaisseur du trait, la couleur, le contour à tracer et de "
+"nombreuses autres choses. Cela permet aux fonctions effectives de tracé de "
+"ne comporter qu'un minimum de paramètres pour simplifier l'interface. Dans "
+"<application>gtkmm</application>, un <classname>Cairo::Context</classname> "
+"est créé en appelant la fonction <methodname>Gdk::Window::"
+"create_cairo_context()</methodname>. �tant donné que les contextes Cairo "
+"sont des objets à décompte de référencement, cette fonction renvoie un objet "
+"<classname>Cairo::RefPtr<Cairo::Context></classname>."
+
+#: C/gtkmm-tutorial-in.xml:4054(para)
+msgid ""
+"The following example shows how to set up a Cairo context with a foreground "
+"color of red and a width of 2. Any drawing functions that use this context "
+"will use these settings."
+msgstr ""
+"L'exemple ci-après montre comment définir un contexte Cairo avec une couleur "
+"de premier plan rouge et une épaisseur de trait de 2. Toute fonction de "
+"tracé se servant de ce contexte utilisera ces réglages."
+
+#: C/gtkmm-tutorial-in.xml:4059(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::DrawingArea myArea;\n"
+"Cairo::RefPtr<Cairo::Context> myContext = myArea.get_window()->create_cairo_context();\n"
+"myContext->set_source_rgb(1.0, 0.0, 0.0);\n"
+"myContext->set_line_width(2.0);"
+msgstr ""
+"Gtk::DrawingArea myArea;\n"
+"Cairo::RefPtr<Cairo::Context> myContext = myArea.get_window()->create_cairo_context();\n"
+"myContext->set_source_rgb(1.0, 0.0, 0.0);\n"
+"myContext->set_line_width(2.0);"
+
+#: C/gtkmm-tutorial-in.xml:4063(para)
+msgid ""
+"Each <classname>Cairo::Context</classname> is associated with a particular "
+"<classname>Gdk::Window</classname>, so the first line of the above example "
+"creates a <classname>Gtk::DrawingArea</classname> widget and the second line "
+"uses its associated <classname>Gdk::Window</classname> to create a "
+"<classname>Cairo::Context</classname> object. The final two lines change the "
+"graphics state of the context."
+msgstr ""
+"Chaque <classname>Cairo::Context</classname> est associé à une fenêtre "
+"<classname>Gdk::Window</classname> donnée ; ainsi, la première ligne de "
+"l'exemple ci-dessus crée un élément graphique <classname>Gtk::DrawingArea</"
+"classname> et la deuxième ligne utilise son objet <classname>Gdk::Window</"
+"classname> associé pour créer un objet <classname>Cairo::Context</"
+"classname>. Les deux dernières lignes modifient les caractéristiques "
+"graphiques du contexte."
+
+#: C/gtkmm-tutorial-in.xml:4072(para)
+msgid ""
+"There are a number of graphics state variables that can be set for a Cairo "
+"context. The most common context attributes are color (using "
+"<methodname>set_source_rgb()</methodname> or <methodname>set_source_rgba()</"
+"methodname> for translucent colors), line width (using "
+"<methodname>set_line_width()</methodname>), line dash pattern (using "
+"<methodname>set_dash()</methodname>), line cap style (using "
+"<methodname>set_line_cap()</methodname>), and line join style (using "
+"<methodname>set_line_join()</methodname>), and font styles (using "
+"<methodname>set_font_size()</methodname>, <methodname>set_font_face()</"
+"methodname> and others). There are many other settings as well, such as "
+"transformation matrices, fill rules, whether to perform antialiasing, and "
+"others. For further information, see the <ulink url=\"http://www."
+"cairographics.org/cairomm/\">cairomm</ulink> API documentation."
+msgstr ""
+"De nombreuses variables d'état graphique peuvent être définies pour un "
+"contexte Cairo. Les attributs les plus courants sont la couleur (avec "
+"<methodname>set_source_rgb()</methodname> ou <methodname>set_source_rgba()</"
+"methodname> pour des couleurs transparentes), l'épaisseur du trait (avec "
+"<methodname>set_line_width()</methodname>), le type de pointillé (avec "
+"<methodname>set_dash()</methodname>), les bouts de lignes (avec "
+"<methodname>set_line_cap()</methodname>), les jonctions de lignes (avec "
+"<methodname>set_line_join()</methodname>) et les styles de polices de "
+"caractères (avec <methodname>set_font_size()</methodname>, "
+"<methodname>set_font_face()</methodname> et autres). Il existe beaucoup "
+"d'autres réglages : les matrices de transformation, les règles de "
+"remplissage, les types d'anti-crénelage, etc. Pour plus d'informations, "
+"consultez la documentation de l'API <ulink url=\"http://www.cairographics."
+"org/cairomm/\">cairomm</ulink>."
+
+#: C/gtkmm-tutorial-in.xml:4104(para)
+msgid ""
+"It is good practice to put all modifications to the graphics state between "
+"<methodname>save()</methodname>/<methodname>restore()</methodname> function "
+"calls. For example, if you have a function that takes a <classname>Cairo::"
+"Context</classname> reference as an argument, you might implement it as "
+"follows:"
+msgstr ""
+"Il est de bonne pratique de placer toute modification de l'état graphique "
+"entre des appels aux fonctions <methodname>save()</methodname>/"
+"<methodname>restore()</methodname>. Par exemple, si vous avez une fonction "
+"qui prend en paramètre une référence à un <classname>Cairo::Context</"
+"classname>, vous pouvez l'implémenter comme suit :"
+
+#: C/gtkmm-tutorial-in.xml:4110(programlisting)
+#, no-wrap
+msgid ""
+"void doSomething(Cairo::RefPtr<Cairo::Context> context, int x)\n"
+"{\n"
+" context->save();\n"
+" // change graphics state\n"
+" // peform drawing operations\n"
+" context->restore();\n"
+"}"
+msgstr ""
+"void doSomething(Cairo::RefPtr<Cairo::Context> context, int x)\n"
+"{\n"
+" context->save();\n"
+" // modifier l'état graphique\n"
+" // réaliser les opérations de tracé\n"
+" context->restore();\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:4087(para)
+msgid ""
+"The current state of a <classname>Cairo::Context</classname> can be saved to "
+"an internal stack of saved states and later be restored to the state it was "
+"in when you saved it. To do this, use the <methodname>save()</methodname> "
+"method and the <methodname>restore()</methodname> method. This can be useful "
+"if you need to temporarily change the line width and color (or any other "
+"graphics setting) in order to draw something and then return to the previous "
+"settings. In this situation, you could call <methodname>Cairo::Context::save"
+"()</methodname>, change the graphics settings, draw the lines, and then call "
+"<methodname>Cairo::Context::restore()</methodname> to restore the original "
+"graphics state. Multiple calls to <methodname>save()</methodname> and "
+"<methodname>restore()</methodname> can be nested; each call to "
+"<methodname>restore()</methodname> restores the state from the matching "
+"paired <methodname>save()</methodname>. <placeholder-1/>"
+msgstr ""
+"L'état présent d'un <classname>Cairo::Context</classname> peut être "
+"enregistré dans une pile interne de contextes enregistrés et ultérieurement "
+"rétablis dans leur état antérieur. Pour réaliser cette opération, utilisez "
+"les fonctions membres <methodname>save()</methodname> et <methodname>restore"
+"()</methodname>. Ce processus est utile si vous avez besoin de modifier "
+"temporairement l'épaisseur de trait ou la couleur (ou toute autre "
+"caractéristique graphique) pour tracer un élément puis revenir aux réglages "
+"antérieurs. Dans ce cas, appelez <methodname>Cairo::Context::save()</"
+"methodname>, modifiez les caractéristiques graphiques, effectuez le tracé, "
+"puis appelez <methodname>Cairo::Context::restore()</methodname> pour "
+"rétablir l'état graphique initial. Des appels multiples à <methodname>save()"
+"</methodname> et <methodname>restore()</methodname> peuvent être imbriqués ; "
+"chaque appel à <methodname>restore()</methodname> rétablit l'état "
+"correspondant à celui qui prévalait lors de l'appel de <methodname>save()</"
+"methodname>. <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:4121(title)
+msgid "Drawing Straight Lines"
+msgstr "Tracé de droites"
+
+#: C/gtkmm-tutorial-in.xml:4130(para)
+msgid ""
+"Since the Cairo graphics library was written with support for multiple "
+"output targets (the X window system, PNG images, OpenGL, etc), there is a "
+"distinction between user-space and device-space coordinates. The mapping "
+"between these two coordinate systems defaults to one-to-one so that integer "
+"values map roughly to pixels on the screen, but this setting can be adjusted "
+"if desired. Sometimes it may be useful to scale the coordinates so that the "
+"full width and height of a window both range from 0 to 1 (the 'unit square') "
+"or some other mapping that works for your application. this can be done with "
+"the <methodname>Cairo::Context::scale()</methodname> function."
+msgstr ""
+"�tant donné que la bibliothèque graphique Cairo a été écrite pour prendre en "
+"charge de multiples cibles en sortie (le système de fenêtrage X, les images "
+"PNG, Open GL, etc.), une distinction est faite entre les coordonnées dans "
+"l'espace-utilisateur et les coordonnées dans l'espace du périphérique "
+"d'affichage. La correspondance entre ces deux systèmes de coordonnées est "
+"par défaut de un pour un, de sorte que les valeurs entières du premier "
+"système correspondent grosso modo à des pixels à l'écran, mais ce réglage "
+"peut être modifié si vous le souhaitez. Quelquefois il peut être commode "
+"d'échelonner les coordonnées de sorte que la largeur et la hauteur totale "
+"d'une fenêtre se situent tous deux dans la plage de 0 à 1 (carré « unité »), "
+"ou tout autre correspondance qui fonctionnerait bien pour votre application. "
+"Ces modifications d'échelle sont effectuées à l'aide de la fonction "
+"<methodname>Cairo::Context::scale()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4122(para)
+msgid ""
+"Now that we understand the basics of the Cairo graphics library, we're "
+"almost ready to start drawing. We'll start with the simplest of drawing "
+"elements: the straight line. But first you need to know a little bit about "
+"Cairo's coordinate system. The origin of the Cairo coordinate system is "
+"located in the upper-left corner of the window with positive x values to the "
+"right and positive y values going down. <placeholder-1/>"
+msgstr ""
+"Maintenant que nous connaissons les bases de la bibliothèque graphique "
+"Cairo, nous voilà prêts pour débuter un tracé. Commençons par le plus simple "
+"des éléments de tracé : la droite. Mais d'abord, il est nécessaire d'en "
+"savoir un peu plus sur le système de coordonnées de Cairo. L'origine du "
+"système de coordonnées de Cairo se situe dans l'angle supérieur gauche de la "
+"fenêtre avec les valeurs positives de x vers la droite et de y vers le bas. "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:4145(para)
+msgid ""
+"In this example, we'll construct a small but fully functional "
+"<application>gtkmm</application> program and draw some lines into the "
+"window. The lines are drawn by creating a path and then stroking it. A path "
+"is created using the functions <methodname>Cairo::Context::move_to()</"
+"methodname> and <methodname>Cairo::Context::line_to()</methodname>. The "
+"function <methodname>move_to()</methodname> is similar to the act of lifting "
+"your pen off of the paper and placing it somewhere else -- no line is drawn "
+"between the point you were at and the point you moved to. To draw a line "
+"between two points, use the <methodname>line_to()</methodname> function."
+msgstr ""
+"Dans cet exemple, nous allons écrire un programme <application>gtkmm</"
+"application> petit, mais pleinement fonctionnel, et tracer quelques lignes "
+"dans la fenêtre. Les lignes sont dessinées en créant un chemin, puis en le "
+"traçant. Un tracé est créé avec les fonctions <methodname>Cairo::Context::"
+"move_to()</methodname> et <methodname>Cairo::Context::line_to()</"
+"methodname>. La fonction <methodname>move_to()</methodname> est semblable à "
+"l'action de lever la pointe de votre crayon au dessus du papier et de la "
+"placer quelque part ailleurs â?? aucune ligne n'est tracée entre le point où "
+"vous étiez et celui où vous vous êtes déplacé. Pour tracer une ligne entre "
+"deux points, utilisez la fonction <methodname>line_to()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4157(para)
+msgid ""
+"After you've finished creating your path, you still haven't drawn anything "
+"visible yet. To make the path visible, you must use the function "
+"<methodname>stroke()</methodname> which will stroke the current path with "
+"the line width and style specified in your <classname>Cairo::Context</"
+"classname> object. After stroking, the current path will be cleared so that "
+"you can start on your next path."
+msgstr ""
+"Après avoir terminé la création de votre chemin, vous n'avez encore dessiné "
+"rien de visible. Pour rendre le chemin visible, il faut utiliser la fonction "
+"<methodname>stroke()</methodname> qui dessine le tracé actuel avec une ligne "
+"d'épaisseur et de style précisés dans l'objet <classname>Cairo::Context</"
+"classname>. Après le traçage, le chemin actuel est effacé ; vous pouvez donc "
+"en débuter un nouveau."
+
+#: C/gtkmm-tutorial-in.xml:4166(para)
+msgid ""
+"Many Cairo drawing functions have a <methodname>_preserve()</methodname> "
+"variant. Normally drawing functions such as <methodname>clip()</methodname>, "
+"<methodname>fill()</methodname>, or <methodname>stroke()</methodname> will "
+"clear the current path. If you use the <methodname>_preserve()</methodname> "
+"variant, the current path will be retained so that you can use the same path "
+"with the next drawing function."
+msgstr ""
+"Beaucoup de fonctions de dessin de Cairo disposent d'une variante "
+"<methodname>_preserve()</methodname>. Normalement, les fonctions de dessin "
+"telles que <methodname>clip()</methodname>, <methodname>fill()</methodname> "
+"ou <methodname>stroke()</methodname> effacent le chemin actuel. Si vous "
+"utilisez la variante <methodname>_preserve()</methodname>, le chemin actuel "
+"sera préservé de sorte que vous pouvez à nouveau l'utiliser avec une autre "
+"fonction de dessin."
+
+#: C/gtkmm-tutorial-in.xml:4176(title) C/gtkmm-tutorial-in.xml:4273(title)
+msgid "Drawing Area - Lines"
+msgstr "Zone de dessin â?? Lignes"
+
+#: C/gtkmm-tutorial-in.xml:4184(para)
+msgid ""
+"This program contains a single class, <classname>MyArea</classname>, which "
+"is a subclass of <classname>Gtk::DrawingArea</classname> and contains an "
+"<methodname>on_expose_event()</methodname> member function. This method is "
+"called whenever the image in the drawing area needs to be redrawn. This "
+"function is passed a pointer to a <classname>GdkEventExpose</classname> "
+"structure which defines the area that needs to be redrawn. We use these "
+"values to create a rectangle path in Cairo (using the <methodname>rectangle()"
+"</methodname> function) and then <methodname>clip()</methodname> to this "
+"path. The <methodname>clip()</methodname> function sets a clip region. The "
+"current clip region affects all drawing operations by effectively masking "
+"out any changes to the surface that are outside the current clip region. "
+"This allows us to limit our redrawing to only the area that needs to be "
+"redrawn. The actual drawing code sets the color we want to use for drawing "
+"by using <methodname>set_source_rgb()</methodname> which takes arguments "
+"defining the Red, Green, and Blue components of the desired color (valid "
+"values are between 0 and 1). After setting the color, we created a new path "
+"using the functions <methodname>move_to()</methodname> and "
+"<methodname>line_to()</methodname>, and then stroked this path with "
+"<methodname>stroke()</methodname>."
+msgstr ""
+"Ce programme ne comporte qu'une seule classe, <classname>MyArea</classname>, "
+"sous-classe de <classname>Gtk::DrawingArea</classname> avec une fonction "
+"membre <methodname>on_expose_event()</methodname>. Cette fonction membre est "
+"appelée chaque fois que l'image dans la zone de tracé a besoin d'être "
+"retracée. � cette fonction est passé un pointeur sur une structure "
+"<classname>GdkEventExpose</classname> définissant la zone ayant besoin "
+"d'être redessinée. Nous utilisons ces valeurs pour créer un chemin de "
+"rectangle dans Cairo (avec la fonction <methodname>rectangle()</methodname>) "
+"puis découper ce chemin avec <methodname>clip()</methodname>. La fonction "
+"<methodname>clip()</methodname> définit une zone de découpe. Cette zone "
+"affecte toutes les opérations de tracé en occultant effectivement toute "
+"modification sur la surface extérieure à la découpe. Cela nous permet de "
+"limiter le retraçage à la zone qui le nécessite. Le code de tracé définit la "
+"couleur que nous voulons en fait utiliser avec <methodname>set_source_rgb()</"
+"methodname> dont les paramètres définissent les composantes rouge, verte et "
+"bleue de la couleur voulue (les valeurs correctes sont comprises entre 0 et "
+"1). Après avoir précisé la couleur, nous créons un nouveau chemin avec les "
+"fonctions <methodname>move_to()</methodname> et <methodname>line_to()</"
+"methodname> et nous le traçons avec <methodname>stroke()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4208(title)
+msgid "Drawing with relative coordinates"
+msgstr "Tracé en coordonnées relatives"
+
+#: C/gtkmm-tutorial-in.xml:4209(para)
+msgid ""
+"In the example above we drew everything using absolute coordinates. You can "
+"also draw using relative coordinates. For a straight line, this is done with "
+"the function <methodname>Cairo::Context::rel_line_to()</methodname>."
+msgstr ""
+"Dans l'exemple ci-dessus nous avons tout tracé en utilisant des coordonnées "
+"absolues. Nous pouvons également tracer en coordonnées relatives. Pour une "
+"droite, on utilise la fonction <methodname>Cairo::Context::rel_line_to()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4215(title)
+msgid "Line styles"
+msgstr "Styles de trait"
+
+#: C/gtkmm-tutorial-in.xml:4216(para)
+msgid ""
+"In addition to drawing basic straight lines, there are a number of things "
+"that you can customize about a line. You've already seen examples of setting "
+"a line's color and width, but there are others as well."
+msgstr ""
+"En plus du tracé élémentaire de droites, vous pouvez personnaliser un "
+"certain nombre de choses dans les tracés de lignes. Nous avons déjà vu des "
+"exemples de paramétrage de couleur et d'épaisseur de trait, mais il en "
+"existe bien d'autres."
+
+#: C/gtkmm-tutorial-in.xml:4222(para)
+msgid ""
+"If you've drawn a series of lines that form a path, you may want them to "
+"join together in a certain way. Cairo offers three different ways to join "
+"lines together: Miter, Bevel, and Round. These are show below:"
+msgstr ""
+"Si vous avez tiré une série de traits formant un chemin, vous pouvez vouloir "
+"les raccorder d'une certaine façon. Cairo offre trois façons différentes de "
+"raccorder les lignes entre elles : l'onglet, le biseau et l'arrondi. Voyez-"
+"les ci-dessous :"
+
+#: C/gtkmm-tutorial-in.xml:4229(title)
+msgid "Different join types in Cairo"
+msgstr "Différents types de raccord dans Cairo"
+
+#: C/gtkmm-tutorial-in.xml:4234(para)
+msgid ""
+"The line join style is set using the function <methodname>Cairo::Context::"
+"set_line_join()</methodname>."
+msgstr ""
+"Le type de raccord est défini avec la fonction <methodname>Cairo::Context::"
+"set_line_join()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4238(para)
+msgid ""
+"Line ends can have different styles as well. The default style is for the "
+"line to start and stop exactly at the destination points of the line. This "
+"is called a Butt cap. The other options are Round (uses a round ending, with "
+"the center of the circle at the end point) or Square (uses a squared ending, "
+"with the center of the square at the end point). This setting is set using "
+"the function <methodname>Cairo::Context::set_line_cap()</methodname>."
+msgstr ""
+"Les fins de ligne peuvent avoir différents styles également. Le style par "
+"défaut est de débuter et arrêter la ligne exactement aux points de "
+"définition. On nomme cela la coupe droite. Les autres options sont l'arrondi "
+"(utilise une terminaison en demi-cercle, le centre du demi-cercle étant au "
+"point terminal de la ligne) ou le carré (utilise une terminaison carrée "
+"diagonale, le centre du carré étant au point terminal de la ligne). Ce "
+"paramétrage est défini avec la fonction <methodname>Cairo::Context::"
+"set_line_cap()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4248(para)
+msgid ""
+"There are other things you can customize as well, including creating dashed "
+"lines and other things. For more information , see the Cairo API "
+"documentation."
+msgstr ""
+"Vous pouvez encore personnaliser d'autres paramètres, y compris la création "
+"de pointillés entre autres. Pour plus d'informations, consultez la "
+"documentation de l'API Cairo. "
+
+#: C/gtkmm-tutorial-in.xml:4256(title)
+msgid "Drawing Curved Lines"
+msgstr "Tracé de courbes"
+
+#: C/gtkmm-tutorial-in.xml:4257(para)
+msgid ""
+"In addition to drawing straight lines Cairo allows you to easily draw curved "
+"lines (technically a cubic Bézier spline) using the <methodname>Cairo::"
+"Context::curve_to()</methodname> and <methodname>Cairo::Context::rel_curve_to"
+"()</methodname> functions. These functions take coordinates for a "
+"destination point as well as coordinates for two 'control' points. This is "
+"best explained using an example, so let's dive in."
+msgstr ""
+"Outre la possibilité de tracer des droites, Cairo vous permet de tracer "
+"facilement des lignes courbes (techniquement une courbe de Bézier d'ordre 3) "
+"avec les fonctions <methodname>Cairo::Context::curve_to()</methodname> et "
+"<methodname>Cairo::Context::rel_curve_to()</methodname>. Ces fonctions "
+"prennent en paramètres les coordonnées des extrémités ainsi que celles de "
+"deux points de « contrôle ». Ce sera plus facile à expliquer sur un exemple, "
+"alors lançons-nous."
+
+#: C/gtkmm-tutorial-in.xml:4268(para)
+msgid ""
+"This simple application draws a curve with Cairo and displays the control "
+"points for each end of the curve."
+msgstr ""
+"Cette simple application trace une courbe avec Cairo et affiche les points "
+"de contrôle pour chaque extrémité de la courbe."
+
+#: C/gtkmm-tutorial-in.xml:4280(para)
+msgid ""
+"The only difference between this example and the straight line example is in "
+"the <methodname>on_expose_event()</methodname> function, but there are a few "
+"new concepts and functions introduced here, so let's examine them briefly."
+msgstr ""
+"La seule différence entre cet exemple et l'exemple des droites réside dans "
+"la fonction <methodname>on_expose_event()</methodname>, mais quelques "
+"nouveaux concepts et fonctions sont introduits ici ; examinons-les "
+"brièvement."
+
+#: C/gtkmm-tutorial-in.xml:4286(para)
+msgid ""
+"Note that we clip to the area that needs re-exposing just as we did in the "
+"last example. After clipping, however, we make a call to <methodname>Cairo::"
+"Context::scale()</methodname>, passing in the width and height of the "
+"drawing area. This scales the user-space coordinate system such that the the "
+"width and height of the widget are both equal to 1.0 'units'. There's no "
+"particular reason to scale the coordinate system in this case, but sometimes "
+"it can make drawing operations easier."
+msgstr ""
+"Notez que nous découpons la surface nécessitant d'être redessinée exactement "
+"comme nous l'avions fait dans l'exemple précédent. Après découpe, toutefois, "
+"nous faisons appel à <methodname>Cairo::Context::scale()</methodname> en "
+"passant à cette fonction la largeur et la hauteur de cette surface de tracé. "
+"Le système de coordonnées de l'espace utilisateur est ainsi gradué de telle "
+"sorte que la hauteur et la largeur du élément graphique ont tous deux une "
+"mesure de 1,0 « unité ». Il n'y avait pas de raison particulière de modifier "
+"la graduation du système de coordonnées dans notre cas, mais cela peut "
+"quelquefois faciliter les opérations de tracé."
+
+#: C/gtkmm-tutorial-in.xml:4296(para)
+msgid ""
+"The call to <methodname>Cairo::Context::curve_to()</methodname> should be "
+"fairly self-explanatory. The first pair of coordinates define the control "
+"point for the beginning of the curve. The second set of coordinates define "
+"the control point for the end of the curve, and the last set of coordinates "
+"define the destination point. To make the concept of control points a bit "
+"easier to visualize, a line has been draw from each control point to the end-"
+"point on the curve that it is associated with. Note that these control point "
+"lines are both translucent. This is achieved with a variant of "
+"<methodname>set_source_rgb()</methodname> called <methodname>set_source_rgba"
+"()</methodname>. This function takes a fourth argument specifying the alpha "
+"value of the color (valid values are between 0 and 1)."
+msgstr ""
+"L'appel à <methodname>Cairo::Context::curve_to()</methodname> est vraiment "
+"explicite en soi. Le premier couple de coordonnées définit le point de "
+"contrôle au début de la courbe, le deuxième celui à la fin de la courbe. Le "
+"dernier groupe de coordonnées indique les extrémités de la courbe. Pour "
+"faire en sorte que le concept des points de contrôle soit plus facile à "
+"visualiser, nous avons tracé une droite entre extrémité de la courbe et "
+"point de contrôle associé. Notez que ces droites (tangentes aux extrémités "
+"de la courbe) sont translucides. Ceci est réalisé à l'aide d'une variante de "
+"<methodname>set_source_rgb()</methodname> intitulée "
+"<methodname>set_source_rgba()</methodname>. Cette fonction prend un "
+"quatrième argument indiquant le coefficient alpha de la couleur (les valeurs "
+"correctes s'échelonnent entre 0 et 1)."
+
+#: C/gtkmm-tutorial-in.xml:4314(title)
+msgid "Drawing Arcs and Circles"
+msgstr "Tracé des arcs et des cercles"
+
+#: C/gtkmm-tutorial-in.xml:4315(para)
+msgid ""
+"With Cairo, the same function is used to draw arcs, circles, or ellipses: "
+"<methodname>Cairo::Context::arc()</methodname>. This function takes five "
+"arguments. The first two are the coordinates of the center point of the arc, "
+"the third argument is the radius of the arc, and the final two arguments "
+"define the start and end angle of the arc. All angles are defined in "
+"radians, so drawing a circle is the same as drawing an arc from 0 to 2 * "
+"M_PI radians. An angle of 0 is in the direction of the positive X axis (in "
+"user-space). An angle of M_PI/2 radians (90 degrees) is in the direction of "
+"the positive Y axis (in user-space). Angles increase in the direction from "
+"the positive X axis toward the positive Y axis. So with the default "
+"transformation matrix, angles increase in a clockwise direction."
+msgstr ""
+"Avec Cairo, on utilise la même fonction pour tracer des arcs, des cercles ou "
+"des ellipses : <methodname>Cairo::Context::arc()</methodname>. Cette "
+"fonction prend cinq paramètres. Les deux premiers sont les coordonnées du "
+"centre de l'arc, le troisième est le rayon et les deux derniers définissent "
+"l'angle de début et l'angle de fin de l'arc. Tous les angles sont définis en "
+"radians ; ainsi, tracer un cercle est identique au fait de tracer un arc de "
+"0 Ã 2Ï? radians. L'angle 0 est dans le sens positif des X (dans l'espace "
+"utilisateur). L'angle de Ï?/2 radians (90 degrés) est dans le sens positif "
+"des Y (dans l'espace utilisateur). Les angles vont croissant en allant de "
+"l'axe des X vers l'axe des Y. Ainsi, avec la matrice de transformation par "
+"défaut, les angles croissent en tournant dans le sens des aiguilles d'une "
+"montre."
+
+#: C/gtkmm-tutorial-in.xml:4336(programlisting)
+#, no-wrap
+msgid ""
+"context->save();\n"
+"context->translate(x, y);\n"
+"context->scale(width / 2.0, height / 2.0);\n"
+"context->arc(0.0, 0.0, 1.0, 0.0, 2 * M_PI);\n"
+"context->restore();"
+msgstr ""
+"context->save();\n"
+"context->translate(x, y);\n"
+"context->scale(width / 2.0, height / 2.0);\n"
+"context->arc(0.0, 0.0, 1.0, 0.0, 2 * M_PI);\n"
+"context->restore();"
+
+#: C/gtkmm-tutorial-in.xml:4329(para)
+msgid ""
+"To draw an ellipse, you can scale the current transformation matrix by "
+"different amounts in the X and Y directions. For example, to draw an ellipse "
+"in the box given by <varname>x</varname>, <varname>y</varname>, "
+"<varname>width</varname>, <varname>height</varname>: <placeholder-1/> Note "
+"that this contradicts the <ulink url=\"http://www.cairographics.org/manual/"
+"cairo-Paths.html#cairo-arc\">advice given in the official Cairo "
+"documentation</ulink>, but it seems to work."
+msgstr ""
+"Pour tracer une ellipse, vous graduez la matrice de transformation de façon "
+"différente dans le sens des X et dans le sens des Y. Par exemple, pour "
+"tracer une ellipse dans la boîte définie par <varname>x</varname>, "
+"<varname>y</varname>, <varname>width</varname>, <varname>height</varname>Â : "
+"<placeholder-1/> Notez que ceci est en contradiction avec la <ulink url="
+"\"http://www.cairographics.org/manual/cairo-Paths.html#cairo-arc\"> "
+"directive de la documentation officielle Cairo</ulink>, mais cela semble "
+"fonctionner correctement."
+
+#: C/gtkmm-tutorial-in.xml:4348(para)
+msgid ""
+"Here's an example of a simple program that draws an arc, a circle and an "
+"ellipse into a drawing area."
+msgstr ""
+"Voici un exemple de programme simple traçant un arc, un cercle et une "
+"ellipse sur une zone de dessin."
+
+#: C/gtkmm-tutorial-in.xml:4353(title)
+msgid "Drawing Area - Arcs"
+msgstr "Zone de dessin â?? Arcs"
+
+#: C/gtkmm-tutorial-in.xml:4362(para)
+msgid ""
+"There are a couple of things to note about this example code. Again, the "
+"only real difference between this example and the previous ones is the "
+"<methodname>on_expose_event()</methodname> function, so we'll limit our "
+"focus to that function. In addition, the first part of the function is "
+"nearly identical to the previous examples, so we'll skip that portion."
+msgstr ""
+"Il y a deux choses à noter concernant cet exemple de code. � nouveau, la "
+"seule différence entre cet exemple et les précédents se situe dans la "
+"fonction <methodname>on_expose_event()</methodname>Â ; nous limitons donc nos "
+"remarques à cette fonction. En outre, la première partie de la fonction est "
+"pratiquement identique aux exemples précédents, nous ne la commentons donc "
+"pas."
+
+#: C/gtkmm-tutorial-in.xml:4370(para)
+msgid ""
+"Note that in this case, we've expressed nearly everything in terms of the "
+"height and width of the window, including the width of the lines. Because of "
+"this, when you resize the window, everything scales with the window. Also "
+"note that there are three drawing sections in the function and each is "
+"wrapped with a <methodname>save()</methodname>/<methodname>restore()</"
+"methodname> pair so that we're back at a known state after each drawing."
+msgstr ""
+"Notez que dans ce cas, nous avons pratiquement tout exprimé en termes de "
+"hauteur et de largeur de la fenêtre, y compris la largeur des lignes. En "
+"raison de cela, quand vous redimensionnez la fenêtre, tous les objets se "
+"mettent à l'échelle. �galement, il y a trois parties concernant les tracés "
+"dans la fonction et chacune est entourée avec une paire <methodname>save()</"
+"methodname>/<methodname>restore()</methodname> pour revenir à un état bien "
+"défini après chaque tracé."
+
+#: C/gtkmm-tutorial-in.xml:4379(para)
+msgid ""
+"The section for drawing an arc introduces one new function, "
+"<methodname>close_path()</methodname>. This function will in effect draw a "
+"straight line from the current point back to the first point in the path. "
+"There is a significant difference between calling <methodname>close_path()</"
+"methodname> and manually drawing a line back to the starting point, however. "
+"If you use <methodname>close_path()</methodname>, the lines will be nicely "
+"joined together. If you use <methodname>line_to()</methodname> instead, the "
+"lines will end at the same point, but Cairo won't do any special joining."
+msgstr ""
+"La partie concernant le tracé de l'arc comporte une nouvelle fonction : "
+"<methodname>close_path()</methodname>. Cette fonction a pour effet de "
+"provoquer le tracé d'une droite entre le point de fin et de début du tracé. "
+"Il y a toutefois une différence significative entre l'appel de "
+"<methodname>close_path()</methodname> et le tracé à la main d'une ligne "
+"jusqu'au point de départ. Si vous utilisez <methodname>close_path()</"
+"methodname>, les lignes seront proprement jointes. Si vous utilisez "
+"<methodname>line_to()</methodname> Ã la place, les lignes se rejoindront, "
+"mais Cairo ne fera rien de spécial pour les joindre."
+
+#: C/gtkmm-tutorial-in.xml:4392(title)
+msgid "Drawing counter-clockwise"
+msgstr "Tracé en sens inverse des aiguilles d'une montre"
+
+#: C/gtkmm-tutorial-in.xml:4393(para)
+msgid ""
+"The function <methodname>Cairo::Context::arc_negative()</methodname> is "
+"exactly the same as <methodname>Cairo::Context::arc()</methodname> but the "
+"angles go the opposite direction."
+msgstr ""
+"La fonction <methodname>Cairo::Context::arc_negative()</methodname> est "
+"identique à <methodname>Cairo::Context::arc()</methodname> mais les angles "
+"tournent dans le sens opposé."
+
+#: C/gtkmm-tutorial-in.xml:4405(title)
+msgid "Drawing Text"
+msgstr "Tracé de textes"
+
+#: C/gtkmm-tutorial-in.xml:4407(title)
+msgid "Drawing Text with Pango"
+msgstr "Tracé de texte avec Pango"
+
+#: C/gtkmm-tutorial-in.xml:4408(para)
+msgid ""
+"Text is drawn via Pango Layouts. The easiest way to create a "
+"<classname>Pango::Layout</classname> is to use "
+"<methodname>create_pango_layout</methodname>. Once created, the layout can "
+"be manipulated in various ways, including changing the text, font, etc. "
+"Finally, the layout can be rendered using the <methodname>draw_layout</"
+"methodname> method of <classname>Gdk::Drawable</classname>, which takes a "
+"<classname>Gdk::GC</classname> object, an x-position, a y-position and the "
+"layout itself."
+msgstr ""
+"Le texte est tracé par l'intermédiaire des objets « layout » tracé de Pango. "
+"Le moyen le plus facile pour créer un objet <classname>Pango::Layout</"
+"classname> est d'utiliser <methodname>create_pango_layout</methodname>. Une "
+"fois créé, le tracé peut être manipulée de diverses manières en modifiant le "
+"texte, les polices, etc. Finalement, le tracé est affiché à l'aide de la "
+"fonction membre <methodname>draw_layout</methodname> de la classe "
+"<classname>Gdk::Drawable</classname> ; il prend comme paramètres un objet "
+"<classname>Gdk::GC</classname>, une position x, une position y et un "
+"pointeur sur le tracé lui-même."
+
+#: C/gtkmm-tutorial-in.xml:4430(title)
+msgid "Drawing Images"
+msgstr "Affichage d'images"
+
+#: C/gtkmm-tutorial-in.xml:4432(title)
+msgid "Drawing Images with Gdk"
+msgstr "Affichage d'images avec Gdk"
+
+#: C/gtkmm-tutorial-in.xml:4433(para)
+msgid ""
+"There are a couple of drawing methods for putting image data into a drawing "
+"area. <methodname>draw_pixmap()</methodname> can copy the contents of a "
+"<classname>Gdk::Drawable</classname> (the window of a drawing area is one) "
+"into the drawing area. There is also <methodname>draw_bitmap()</methodname> "
+"for drawing a two-color image into the drawing area, and "
+"<methodname>draw_image()</methodname> for drawing an image with more than "
+"two colors."
+msgstr ""
+"Il y a deux ou trois fonctions membres de tracé pour positionner les données "
+"d'une image dans une zone de dessin. <methodname>draw_pixmap()</methodname> "
+"peut copier dans une zone de dessin le contenu d'un objet <classname>Gdk::"
+"Drawable</classname> (la fenêtre d'une zone de dessin fait partie de cette "
+"classe). <methodname>draw_bitmap()</methodname> permet d'afficher une image "
+"bicolore dans une zone de tracé ; utilisez <methodname>draw_image()</"
+"methodname> si l'image comporte plus de deux couleurs."
+
+#: C/gtkmm-tutorial-in.xml:4442(para)
+msgid ""
+"For all of these methods, the first argument is the <classname>Gdk::GC</"
+"classname>. The second argument is the object of the appropriate type to "
+"copy in: <classname>Gdk::Drawable</classname>, <classname>Gdk::Bitmap</"
+"classname>, <classname>Gdk::Image</classname>. The next two arguments are "
+"the x and y points in the image to begin copying from. Then come the x and y "
+"points in the drawing area to copy to. The final two arguments are the width "
+"and height of the area to copy."
+msgstr ""
+"Pour chacune de ces fonctions membres, le premier paramètre est le "
+"<classname>Gdk::GC</classname>. Le second est l'objet de type approprié à "
+"copier : <classname>Gdk::Drawable</classname>, <classname>Gdk::Bitmap</"
+"classname> ou <classname>Gdk::Image</classname>. Les deux paramètres "
+"suivants sont les coordonnées x et y du point de départ de la copie dans "
+"l'image à copier , puis les coordonnées x et y du point de destination de la "
+"copie dans la zone de dessin et enfin la largeur et la hauteur de la région "
+"Ã copier."
+
+#: C/gtkmm-tutorial-in.xml:4453(para)
+msgid ""
+"There is also a method for drawing from a <classname>Gdk::Pixbuf</"
+"classname>. A <classname>Gdk::Pixbuf</classname> buffer is a useful wrapper "
+"around a collection of pixels, which can be read from files, and manipulated "
+"in various ways."
+msgstr ""
+"Il y a également une fonction membre pour dessiner à partir d'un objet "
+"<classname>Gdk::Pixbuf</classname>. Un tampon <classname>Gdk::Pixbuf</"
+"classname> est une enveloppe commode pour un ensemble de pixels. Il peut "
+"être lu à partir d'un fichier et manipulé de diverses manières."
+
+#: C/gtkmm-tutorial-in.xml:4460(para)
+msgid ""
+"Probably the most common way of creating <classname>Gdk::Pixbuf</classname>s "
+"is to use <methodname>Gdk::Pixbuf::create_from_file()</methodname>, which "
+"can read an image file, such as a png file into a pixbuf ready for rendering."
+msgstr ""
+"La façon la plus courante pour créer un objet <classname>Gdk::Pixbuf</"
+"classname> est d'utiliser la fonction <methodname>Gdk::Pixbuf::"
+"create_from_file()</methodname>. Elle peut lire un fichier d'image, comme un "
+"fichier .png dans un tampon <classname>Gdk::Pixbuf</classname> prêt à être "
+"rendu."
+
+#: C/gtkmm-tutorial-in.xml:4467(para)
+msgid ""
+"The <classname>Gdk::Pixbuf</classname> can be rendered with "
+"<methodname>render_to_drawable</methodname>, which takes quite a few "
+"parameters. The <methodname>render_to_drawable</methodname> is a member of "
+"<classname>Gdk::Pixbuf</classname> rather than <classname>Gdk::Drawable</"
+"classname>, which is unlike the <methodname>draw_*</methodname> functions "
+"described earlier. As such, its first parameter is the drawable to render "
+"to. The second parameter is still the <classname>Gdk::GC</classname>. The "
+"next two parameters are the point in the pixbuf to start drawing from. This "
+"is followed by the point in the drawable to draw it at, and by the width and "
+"height to actually draw (which may not be the whole image, especially if "
+"you're only responding to an expose event for part of the window). Finally, "
+"there are the dithering parameters. If you use Gdk::RGB_DITHER_NONE as the "
+"dither type, then the dither offset parameters can both be 0."
+msgstr ""
+"L'objet <classname>Gdk::Pixbuf</classname> peut être rendu à l'aide de la "
+"fonction membre <methodname>render_to_drawable</methodname>Â ; elle prend peu "
+"de paramètres. Cette fonction est une fonction membre de la classe "
+"<classname>Gdk::Pixbuf</classname> (et non <classname>Gdk::Drawable</"
+"classname>) ; elle diffère des fonctions <methodname>draw_*</methodname> "
+"décrites plus haut. Ainsi, son premier paramètre est l'objet à tracer. Le "
+"deuxième est encore le contexte <classname>Gdk::GC</classname>. Les deux "
+"paramètres suivants définissent le point de départ dans l'image à copier, "
+"suivis par le point de destination dans la zone de tracé ainsi que par la "
+"largeur et la hauteur à tracer effectivement (ce n'est pas forcément la "
+"totalité de l'image, spécialement si vous répondez à un événement "
+"d'exposition d'une partie de la fenêtre). Pour terminer, il y a les "
+"paramètres de diffusion de l'image. Si vous prenez comme type de diffusion "
+"Gdk::RGB_DITHER_NONE, les paramètres de décalage de diffusion seront tous "
+"deux égaux à 0."
+
+#: C/gtkmm-tutorial-in.xml:4484(para)
+msgid ""
+"Here is a small bit of code to tie it all together: (Note that usually you "
+"wouldn't load the image every time in the expose event handler! It's just "
+"shown here to keep it all together)"
+msgstr ""
+"Voici un petit bout de code pour lier l'ensemble : (notez qu'habituellement, "
+"vous ne procédez pas au chargement de l'image à chaque fois dans le "
+"gestionnaire de l'événement d'exposition ! Ici, c'est uniquement pour que le "
+"code soit complet)"
+
+#: C/gtkmm-tutorial-in.xml:4489(programlisting)
+#, no-wrap
+msgid ""
+"bool myarea::on_expose_event(GdkEventExpose* ev)\n"
+"{\n"
+"Glib::RefPtr<Gdk::Pixbuf> image = Gdk::Pixbuf::create_from_file(\"myimage.png\");\n"
+"image->render_to_drawable(get_window(), get_style()->get_black_gc(),\n"
+"0, 0, 100, 80, image->get_width(), image->get_height(), // draw the whole image (from 0,0 to the full width,height) at 100,80 in the window\n"
+"Gdk::RGB_DITHER_NONE, 0, 0);\n"
+"return true;\n"
+"}"
+msgstr ""
+"bool myarea::on_expose_event(GdkEventExpose* ev)\n"
+"{\n"
+"Glib::RefPtr<Gdk::Pixbuf> image = Gdk::Pixbuf::create_from_file(\"myimage.png\");\n"
+"image->render_to_drawable(get_window(), get_style()->get_black_gc(),\n"
+"0, 0, 100, 80, image->get_width(), image->get_height(),\n"
+"// tracer la totalité de l'image (de 0,0 à toute la largeur,hauteur) à 100,80\n"
+"// dans la fenêtre\n"
+"Gdk::RGB_DITHER_NONE, 0, 0);\n"
+"return true;\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:4516(title)
+msgid "Example Application: Creating a Clock with Cairo"
+msgstr "Exemple d'application : création d'un cadran d'horloge avec Cairo"
+
+#: C/gtkmm-tutorial-in.xml:4517(para)
+msgid ""
+"Now that we've covered the basics of drawing with Cairo, let's try to put it "
+"all together and create a simple application that actually does something. "
+"The following example uses Cairo to create a custom <classname>Clock</"
+"classname> widget. The clock has a second hand, a minute hand, and an hour "
+"hand, and updates itself every second."
+msgstr ""
+"Maintenant que nous avons vu les fondements du tracé avec Cairo, rassemblons "
+"le tout et créons une application simple qui fasse effectivement quelque "
+"chose. L'exemple qui suit utilise Cairo pour créer un élément graphique "
+"<classname>Clock</classname> classique. L'horloge dispose d'aiguilles pour "
+"les secondes, les minutes et les heures ; elle se met à jour toutes les "
+"secondes."
+
+#: C/gtkmm-tutorial-in.xml:4529(para)
+msgid ""
+"As before, almost all of the interesting stuff is done in the expose event "
+"handler <methodname>on_expose_event()</methodname>. Before we dig into the "
+"expose event handler, notice that the constructor for the <classname>Clock</"
+"classname> widget connects a handler function <methodname>onSecondElapsed()</"
+"methodname> to a timer with a timeout period of 1000 milliseconds (1 "
+"second). This means that <methodname>onSecondElapsed()</methodname> will get "
+"called once per second. The sole responsibility of this function is to "
+"invalidate the window so that <application>gtkmm</application> will be "
+"forced to redraw it."
+msgstr ""
+"Comme auparavant, la plupart des choses intéressantes se passent dans le "
+"gestionnaire des événements d'exposition <methodname>on_expose_event()</"
+"methodname>. Avant de creuser ce gestionnaire, notez que le constructeur de "
+"l'élément graphique <classname>Clock</classname> connecte sa fonction de "
+"rappel <methodname>onSecondElapsed()</methodname> à un séquenceur qui se "
+"déclenche toutes les 1000 millisecondes (1 seconde). Cela signifie que "
+"<methodname>onSecondElapsed()</methodname> sera appelée toutes les secondes. "
+"La seule responsabilité de cette fonction consiste à invalider la fenêtre de "
+"façon à ce que <application>gtkmm</application> soit obligé de la retracer."
+
+#: C/gtkmm-tutorial-in.xml:4540(para)
+msgid ""
+"Now let's take a look at the code that performs the actual drawing. The "
+"first section of <methodname>on_expose_event()</methodname> should be pretty "
+"familiar by now as it's mostly 'boilerplate' code for getting the "
+"<classname>Gdk::Window</classname>, creating a <classname>Cairo::Context</"
+"classname>, and clipping to the area that we want to re-draw. This example "
+"again scales the coordinate system to be a unit square so that it's easier "
+"to draw the clock as a percentage of window size so that it will "
+"automatically scale when the window size is adjusted. Furthermore, the "
+"coordinate system is scaled over and down so that the (0, 0) coordinate is "
+"in the very center of the window."
+msgstr ""
+"Regardons maintenant le code qui effectue en fait le tracé. La première "
+"partie de <methodname>on_expose_event()</methodname> doit maintenant vous "
+"être familière car il s'agit de code « standardisé » pour obtenir le "
+"<classname>Gdk::Window</classname>, créer le <classname>Cairo::Context</"
+"classname> et découper la zone que nous souhaitons retracer. � nouveau cet "
+"exemple inscrit son système de coordonnées dans un carré unité : il est "
+"ainsi plus facile de tracer le cadran en proportion de la taille de la "
+"fenêtre qui est automatiquement mise à l'échelle en cas de "
+"redimensionnement. Mieux, le système de coordonnées est gradué de façon à ce "
+"que l'origine (0, 0) soit situé au centre réel de la fenêtre."
+
+#: C/gtkmm-tutorial-in.xml:4553(para)
+msgid ""
+"The function <methodname>Cairo::Context::paint()</methodname> is used here "
+"to set the background color of the window. This function takes no arguments "
+"and fills the current surface (or the clipped portion of the surface) with "
+"the source color currently active. After setting the background color of the "
+"window, we draw a circle for the clock outline, fill it with white, and then "
+"stroke the outline in black. Notice that both of these actions use the "
+"<methodname>_preserve</methodname> variant to preserve the current path, and "
+"then this same path is clipped to make sure than our next lines don't go "
+"outside the outline of the clock."
+msgstr ""
+"La fonction <methodname>Cairo::Context::paint()</methodname> est ici "
+"utilisée pour définir la couleur d'arrière-plan de la fenêtre. Cette "
+"fonction ne prend aucun paramètre et remplit la surface actuelle (ou la "
+"partie tronquée de la surface) avec la couleur source actuellement active. "
+"Après avoir défini la couleur de fond, nous traçons un cercle pour délimiter "
+"le cadran, le remplissons en blanc et soulignons le pourtour de noir. Notez "
+"que ces actions utilisent la variante <methodname>_preserve</methodname> "
+"pour conserver le chemin en cours, puis ce même chemin est découpé pour "
+"s'assurer que nos prochains tracés ne sortiront pas du pourtour du cadran."
+
+#: C/gtkmm-tutorial-in.xml:4565(para)
+msgid ""
+"After drawing the outline, we go around the clock and draw ticks for every "
+"hour, with a larger tick at 12, 3, 6, and 9. Now we're finally ready to "
+"implement the time-keeping functionality of the clock, which simply involves "
+"getting the current values for hours, minutes and seconds, and drawing the "
+"hands at the correct angles."
+msgstr ""
+"Après avoir tracé le pourtour, nous parcourons la circonférence du cadran et "
+"traçons des marques pour chaque heure, avec une marque plus importante pour "
+"midi, trois, six et neuf heures. Nous sommes maintenant prêts pour "
+"implémenter la fonctionnalité horloge de notre cadran : cela consiste à "
+"obtenir la valeur actuelle des heures, minutes et secondes et à tracer les "
+"aiguilles avec les angles adéquats."
+
+#: C/gtkmm-tutorial-in.xml:4577(para)
+msgid ""
+"<classname>Gtk::Widget</classname> has several methods and signals which are "
+"prefixed with \"drag_\". These are used for Drag and Drop."
+msgstr ""
+"<classname>Gtk::Widget</classname> dispose de plusieurs fonctions membres et "
+"signaux préfixés par « drag_ » qui sont utilisés pour le glisser-déposer."
+
+#: C/gtkmm-tutorial-in.xml:4582(title)
+msgid "Sources and Destinations"
+msgstr "Sources et destinations"
+
+#: C/gtkmm-tutorial-in.xml:4583(para)
+msgid ""
+"Things are dragged from <literal>sources</literal> to be dropped on "
+"<literal>destinations</literal>. Each source and destination has infomation "
+"about the data formats that it can send or receive, provided by "
+"<classname>Gtk::TargetEntry</classname> items. A drop destination will only "
+"accept a dragged item if they both share a compatible <classname>Gtk::"
+"TargetEntry</classname> item. Appropriate signals will then be emitted, "
+"telling the signal handlers which <classname>Gtk::TargetEntry</classname> "
+"was used."
+msgstr ""
+"Les objets sont glissés à partir de <literal>sources</literal> pour être "
+"déposés sur des <literal>destinations</literal>. Chaque source et chaque "
+"destination dispose d'informations à propos du format des données qu'elle "
+"peut recevoir ou envoyer, informations fournies par les éléments "
+"<classname>Gtk::TargetEntry</classname>. Une destination de dépôt n'accepte "
+"un élément glissé que s'ils partagent un élément <classname>Gtk::"
+"TargetEntry</classname> compatible. Les signaux appropriés sont alors émis, "
+"indiquant au gestionnaire de signaux le <classname>Gtk::TargetEntry</"
+"classname> qui a été utilisé."
+
+#: C/gtkmm-tutorial-in.xml:4596(para)
+msgid "target: A name, such as \"STRING\""
+msgstr "cible : un nom, tel que « STRING »"
+
+#: C/gtkmm-tutorial-in.xml:4597(para)
+msgid ""
+"info: An identifier which will be sent to your signals to tell you which "
+"TargetEntry was used."
+msgstr ""
+"info : un identifiant envoyé aux signaux pour indiquer quel TargetEntry a "
+"été utilisé."
+
+#: C/gtkmm-tutorial-in.xml:4598(para)
+msgid ""
+"flags: Used only for drag and drop, this specifies whether the data may be "
+"dragged to other widgets and applications, or only to the same ones."
+msgstr ""
+"drapeaux : utilisé seulement pour le glisser-déposer, il indique si les "
+"données peuvent être glisser vers d'autres éléments graphiques et "
+"applications ou seulement vers les mêmes éléments graphiques."
+
+#: C/gtkmm-tutorial-in.xml:4593(para)
+msgid ""
+"<classname>Gtk::TargetEntry</classname> objects contain this information: "
+"<placeholder-1/>"
+msgstr ""
+"Les objets <classname>Gtk::TargetEntry</classname> contiennent ces "
+"informations : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:4606(para)
+msgid ""
+"<classname>Widgets</classname> can be identified as sources or destinations "
+"using these <classname>Gtk::Widget</classname> methods:"
+msgstr ""
+"Les <classname>éléments graphiques</classname> sont identifiés en tant que "
+"sources ou destinations à l'aide des fonctions membres <classname>Gtk::"
+"Widget</classname> suivantes :"
+
+#: C/gtkmm-tutorial-in.xml:4610(programlisting)
+#, no-wrap
+msgid ""
+"void drag_source_set(const ArrayHandle_TargetEntry& targets,\n"
+" GdkModifierType start_button_mask, GdkDragAction actions);"
+msgstr ""
+"void drag_source_set(const ArrayHandle_TargetEntry& targets,\n"
+" GdkModifierType start_button_mask, GdkDragAction actions);"
+
+#: C/gtkmm-tutorial-in.xml:4615(para)
+msgid ""
+"<literal>targets</literal> is a container of <classname>Gtk::TargetEntry</"
+"classname> (<classname>std::list<Gtk::TargetEntry></classname> or "
+"<classname>std::vector<Gtk::TargetEntry></classname>, for instance) "
+"elements."
+msgstr ""
+"<literal>targets</literal> est un conteneur pour éléments <classname>Gtk::"
+"TargetEntry</classname> (<classname>std::list<Gtk::TargetEntry></"
+"classname> ou <classname>std::vector<Gtk::TargetEntry></classname>, "
+"par exemple)."
+
+#: C/gtkmm-tutorial-in.xml:4624(para)
+msgid ""
+"<literal>start_button_mask</literal> is an ORed combination of values, which "
+"specify which modifier key or mouse button must be pressed to start the drag."
+msgstr ""
+"<literal>start_button_mask</literal> est une combinaison de valeurs liées "
+"avec l'opérateur binaire OR ; ces valeurs définissent quelle touche "
+"modificatrice ou quel bouton de souris doit être pressé pour démarrer le "
+"glisser."
+
+#: C/gtkmm-tutorial-in.xml:4631(para)
+msgid ""
+"<literal>actions</literal> is an ORed combination of values, which specified "
+"which Drag and Drop operations will be possible from this source - for "
+"instance, copy, move, or link. The user can choose between the actions by "
+"using modifier keys, such as <keycap>Shift</keycap> to change from "
+"<literal>copy</literal> to <literal>move</literal>, and this will be shown "
+"by a different cursor."
+msgstr ""
+"<literal>actions</literal> est une combinaison de valeurs liées avec "
+"l'opérateur binaire OR ; elle précise les opérations de glisser-déposer "
+"possibles à partir de cette source â?? par exemple, copier, déplacer ou lier. "
+"L'utilisateur peut choisir le type d'opérations avec les touches "
+"modificatrices ; ainsi, <keycap>Maj</keycap> permet de transformer la "
+"« <literal>copie</literal> » en « <literal>déplacement</literal> » ; ce "
+"changement est indiqué par la modification de la forme du pointeur de souris."
+
+#: C/gtkmm-tutorial-in.xml:4642(programlisting)
+#, no-wrap
+msgid ""
+"void drag_dest_set(const ArrayHandle_TargetEntry& targets,\n"
+" GtkDestDefaults flags, GdkDragAction actions);"
+msgstr ""
+"void drag_dest_set(const ArrayHandle_TargetEntry& targets,\n"
+" GtkDestDefaults flags, GdkDragAction actions);"
+
+#: C/gtkmm-tutorial-in.xml:4647(para)
+msgid ""
+"<literal>flags</literal> is an ORed combination of values which indicates "
+"how the widget will respond visually to Drag and Drop items."
+msgstr ""
+"<literal>flags</literal> est une combinaison de valeurs liées par "
+"l'opérateur binaire OR ; cette combinaison indique comment l'élément "
+"graphique répond visuellement aux éléments du glisser-déposer."
+
+#: C/gtkmm-tutorial-in.xml:4653(para)
+msgid ""
+"<literal>actions</literal> indicates the Drag and Drop actions which this "
+"destination can receive - see the description above."
+msgstr ""
+"<literal>actions</literal> indique les actions de glisser-déposer que cette "
+"destination peut accepter â?? voir la description plus haut."
+
+#: C/gtkmm-tutorial-in.xml:4663(para)
+msgid ""
+"When a drop destination has accepted a dragged item, certain signals will be "
+"emitted, depending on what action has been selected. For instance, the user "
+"might have held down the <keycap>Shift</keycap> key to specify a "
+"<literal>move</literal> rather than a <literal>copy</literal>. Remember that "
+"the user can only select the actions which you have specified in your calls "
+"to <methodname>drag_dest_set()</methodname> and <methodname>drag_source_set()"
+"</methodname>."
+msgstr ""
+"Quand une destination a accepté un élément glissé, certains signaux vont "
+"être émis selon l'action choisie. Par exemple, l'utilisateur peut avoir "
+"maintenu enfoncée la touche <keycap>Maj</keycap> pour indiquer un "
+"<literal>déplacement</literal> plutôt qu'une <literal>copie</literal>. "
+"Souvenez-vous que l'utilisateur ne peut sélectionner que les actions "
+"définies dans vos appels à <methodname>drag_dest_set()</methodname> et "
+"<methodname>drag_source_set()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4674(title) C/gtkmm-tutorial-in.xml:4797(title)
+msgid "Copy"
+msgstr "Copie"
+
+#: C/gtkmm-tutorial-in.xml:4678(para)
+msgid "<literal>drag_begin</literal>: Provides DragContext."
+msgstr "<literal>drag_begin</literal>Â : fournit un objet DragContext."
+
+#: C/gtkmm-tutorial-in.xml:4679(para)
+msgid ""
+"<literal>drag_motion</literal>: Provides DragContext and coordinates. You "
+"can call the drag_status() method of the DragContext to indicate which "
+"target will be accepted."
+msgstr ""
+"<literal>drag_motion</literal>Â : fournit un objet DragContext et les "
+"coordonnées. Vous pouvez appeler la fonction membre drag_status() de l'objet "
+"DragContext pour faire savoir les cibles acceptées."
+
+#: C/gtkmm-tutorial-in.xml:4680(para)
+msgid ""
+"<literal>drag_get</literal>: Provides <literal>info</literal> about the "
+"dragged data format, and a <literal>GtkSelectionData</literal> structure, in "
+"which you should put the requested data."
+msgstr ""
+"<literal>drag_get</literal>Â : fournit un objet <literal>info</literal> "
+"concernant le format des données glissées et une structure "
+"<literal>GtkSelectionData</literal> dans laquelle vous pouvez mettre les "
+"données requises."
+
+#: C/gtkmm-tutorial-in.xml:4681(para)
+msgid "<literal>drag_drop</literal>: Provides DragContext and coordinates."
+msgstr ""
+"<literal>drag_drop</literal>Â : fournit un objet DragContext et les "
+"coordonnées."
+
+#: C/gtkmm-tutorial-in.xml:4682(para)
+msgid "<literal>drag_end</literal>: Provides DragContext."
+msgstr "<literal>drag_end</literal>Â : fournit un objet DragContext."
+
+#: C/gtkmm-tutorial-in.xml:4675(para)
+msgid ""
+"The source widget will emit these signals, in this order: <placeholder-1/>"
+msgstr ""
+"L'élément graphique source va émettre ces signaux, dans cet ordre : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:4689(para)
+msgid ""
+"<literal>drag_data_received</literal>: Provides <literal>info</literal> "
+"about the dragged data format, and a <literal>GtkSelectionData</literal> "
+"structure which contains the dropped data. You should call the "
+"<methodname>drag_finish()</methodname> method of the <literal>DragContext</"
+"literal> to indicate whether the operation was successful."
+msgstr ""
+"<literal>drag_data_received</literal>Â : fournit un objet <literal>info</"
+"literal> concernant le format des données glissées et une structure "
+"<literal>GtkSelectionData</literal> contenant les données déposées. Vous "
+"pouvez appeller la fonction membre <methodname>drag_finish()</methodname> "
+"sur l'objet <literal>DragContext</literal> pour savoir si l'opération a "
+"réussi ou non."
+
+#: C/gtkmm-tutorial-in.xml:4685(para)
+msgid ""
+"The destination widget will emit this signal, after the source destination "
+"has emitted the <literal>drag_get</literal> signal: <placeholder-1/>"
+msgstr ""
+"L'élément graphique destination émet ce signal après que l'élément source a "
+"émis le signal <literal>drag_get</literal> : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:4704(title)
+msgid "Move"
+msgstr "Déplacement"
+
+#: C/gtkmm-tutorial-in.xml:4707(para)
+msgid ""
+"<literal>drag_delete</literal>: Gives the source the opportunity to delete "
+"the original data if that's appropriate."
+msgstr ""
+"<literal>drag_delete</literal> : offre à la source la possibilité de "
+"détruire les données initiales si c'est approprié."
+
+#: C/gtkmm-tutorial-in.xml:4705(para)
+msgid ""
+"During a <literal>move</literal>, the source widget will also emit this "
+"signal: <placeholder-1/>"
+msgstr ""
+"Pendant un <literal>déplacement</literal>, l'élément graphique source émet "
+"également le signal : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:4721(title)
+msgid "DragContext"
+msgstr "DragContext"
+
+#: C/gtkmm-tutorial-in.xml:4722(para)
+msgid ""
+"The drag and drop signals provide a DragContext, which contains some "
+"information about the drag and drop operation and can be used to influence "
+"the process. For instance, you can discover the source widget, or change the "
+"drag and drop icon, by using the <methodname>set_icon()</methodname> "
+"methods. More importantly, you should call the <methodname>drag_finish()</"
+"methodname> method from your <literal>drag_data_received</literal> signal "
+"handler to indicate whether the drop was successful."
+msgstr ""
+"Les signaux de glisser-déposer fournissent un objet DragContext contenant "
+"certaines informations à propos de l'opération de glisser-déposer ; ces "
+"informations peuvent être utilisées pour influer sur le processus. Par "
+"exemple, vous pouvez faire apparaître l'élément graphique source ou modifier "
+"l'icône de glisser-déposer avec <methodname>set_icon()</methodname>. Plus "
+"important, vous pouvez faire appel à la fonction membre "
+"<methodname>drag_finish()</methodname> dans le gestionnaire du signal "
+"<literal>drag_data_received</literal> pour savoir si le dépôt a réussi ou "
+"non."
+
+#: C/gtkmm-tutorial-in.xml:4735(para)
+msgid ""
+"Here is a very simple example, demonstrating a drag and drop <literal>Copy</"
+"literal> operation:"
+msgstr ""
+"Voici un exemple très simple montrant une opération de glisser-déposer avec "
+"<literal>copie</literal>Â :"
+
+#: C/gtkmm-tutorial-in.xml:4746(para)
+msgid "There is a more complex example in examples/dnd."
+msgstr ""
+"Dans le dossier examples/dnd, vous pouvez trouver un exemple un peu plus "
+"élaboré."
+
+#: C/gtkmm-tutorial-in.xml:4755(title)
+msgid "The Clipboard"
+msgstr "Le presse-papier"
+
+#: C/gtkmm-tutorial-in.xml:4756(para)
+msgid ""
+"Simple text copy-paste functionality is provided for free by widgets such as "
+"Gtk::Entry and Gtk::TextView, but you might need special code to deal with "
+"your own data formats. For instance, a drawing program would need special "
+"code to allow copy and paste within a view, or between documents."
+msgstr ""
+"La fonctionnalité de copier-coller du texte brut est incorporée par "
+"construction pour des éléments graphiques tels que Gtk::Entry et Gtk::"
+"TextView, mais vous devez prévoir un code adapté pour faire des échanges "
+"dans le cas de vos propres formats de données. Par exemple, un programme de "
+"dessin a besoin de code spécialisé pour permettre le copier-coller dans une "
+"vue ou entre documents."
+
+#: C/gtkmm-tutorial-in.xml:4758(para)
+msgid ""
+"<classname>Gtk::Clipboard</classname> is a singleton. You can get the one "
+"and only instance with <methodname>Gtk::Clipboard::get()</methodname>."
+msgstr ""
+"L'objet <classname>Gtk::Clipboard</classname> est un singleton. Vous ne "
+"pourrez en obtenir qu'une seule et unique instance avec <methodname>Gtk::"
+"Clipboard::get()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4763(para)
+msgid ""
+"So your application doesn't need to wait for clipboard operations, "
+"particularly between the time when the user chooses Copy and then later "
+"chooses Paste, most <classname>Gtk::Clipboard</classname> methods take "
+"<classname>sigc::slot</classname>s which specify callback methods. When "
+"<classname>Gtk::Clipboard</classname> is ready, it will call these methods, "
+"either providing the requested data, or asking for data."
+msgstr ""
+"Ainsi votre application n'a pas besoin d'attendre pendant les opérations "
+"avec le presse-papier, en particulier, entre le moment où l'utilisateur "
+"sélectionne Copier et celui plus tard où il fait Coller ; la plupart des "
+"fonctions membres <classname>Gtk::Clipboard</classname> prennent comme "
+"paramètre <classname>sigc::slot</classname> qui définit les fonctions de "
+"rappel. Quand <classname>Gtk::Clipboard</classname> est prêt, il fait appel "
+"à ces fonctions membres, soit pour fournir les données requises, soit pour "
+"les demander."
+
+#: C/gtkmm-tutorial-in.xml:4775(title)
+msgid "Targets"
+msgstr "Cibles"
+
+#: C/gtkmm-tutorial-in.xml:4776(para)
+msgid ""
+"Different applications contain different types of data, and they might make "
+"that data available in a variety of formats. <application>gtkmm</"
+"application> calls these data types <literal>target</literal>s."
+msgstr ""
+"Diverses applications contiennent divers types de données ; elles peuvent "
+"mettre ces données à disposition sous des formats variés. "
+"<application>gtkmm</application> appelle ces types de données des "
+"« <literal>targets</literal> » (cibles)."
+
+#: C/gtkmm-tutorial-in.xml:4780(para)
+msgid ""
+"For instance, gedit can supply and receive the <literal>\"UTF8_STRING\"</"
+"literal> target, so you can paste data into gedit from any application that "
+"supplies that target. Or two different image editing applications might "
+"supply and receive a variety of image formats as targets. As long as one "
+"application can receive one of the targets that the other supplies then you "
+"will be able to copy data from one to the other."
+msgstr ""
+"Par exemple, <application>gedit</application> peut fournir et recevoir la "
+"cible <literal>« UTF8_STRING »</literal> ; vous pouvez donc coller dans "
+"<application>gedit</application> des données de toute application "
+"fournissant cette cible. Ou bien, deux applications différentes de "
+"modification d'images peuvent fournir et recevoir divers formats d'image en "
+"tant que cibles. Tant qu'une application peut recevoir une des cibles que "
+"l'autre fournit, vous pouvez copier des données de l'une vers l'autre."
+
+#: C/gtkmm-tutorial-in.xml:4784(para)
+msgid ""
+"A target can be in a variety of binary formats. This chapter, and the "
+"examples, assume that the data is 8-bit text. This would allow us to use an "
+"XML format for the clipboard data. However this would probably not be "
+"appropriate for binary data such as images. <classname>Gtk::Clipboard</"
+"classname> provides overloads that allow you to specify the format in more "
+"detail if necessary."
+msgstr ""
+"Une cible peut se présenter sous des formats binaires divers. Ce chapitre, "
+"et ses exemples, supposent que les données sont du texte 8 bits. Cela vous "
+"permet d'utiliser un format XML pour les données du presse-papier. Toutefois "
+"ce format ne sera certainement pas approprié pour des données binaires comme "
+"les images. La classe <classname>Gtk::Clipboard</classname> autorise des sur-"
+"définitions permettant de spécifier le format de façon plus détaillée si "
+"nécessaire."
+
+#: C/gtkmm-tutorial-in.xml:4793(para)
+msgid ""
+"The <link linkend=\"chapter-draganddrop\">Drag and Drop</link> API uses the "
+"same mechanism. You should probably use the same data targets and formats "
+"for both Clipboard and Drag and Drap operations."
+msgstr ""
+"L'API du <link linkend=\"chapter-draganddrop\">glisser-déposer</link> "
+"utilise les mêmes mécanismes. Vous utiliserez probablement les mêmes formats "
+"et cibles de données à la fois pour les opérations avec le presse-papier et "
+"pour le glisser-déposer."
+
+#: C/gtkmm-tutorial-in.xml:4798(para)
+msgid ""
+"When the user asks to copy some data, you should tell the "
+"<classname>Clipboard</classname> what targets are available, and provide the "
+"callback methods that it can use to get the data. At this point you should "
+"store a copy of the data, to be provided when the clipboard calls your "
+"callback method in repsonse to a paste."
+msgstr ""
+"Quand l'utilisateur demande de copier des données, vous devez indiquer à "
+"l'objet <classname>Clipboard</classname> quelles sont les cibles disponibles "
+"et fournir les fonctions de rappel à utiliser pour obtenir les données. � ce "
+"stade, vous stockez une copie des données à fournir quand le presse-papier "
+"appelle votre fonction de rappel en réponse à un coller."
+
+#: C/gtkmm-tutorial-in.xml:4807(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::Clipboard> refClipboard = Gtk::Clipboard::get();\n"
+"\n"
+"//Targets:\n"
+"std::list<Gtk::TargetEntry> listTargets;\n"
+"listTargets.push_back( Gtk::TargetEntry(\"example_custom_target\") );\n"
+"listTargets.push_back( Gtk::TargetEntry(\"UTF8_STRING\") );\n"
+"\n"
+"refClipboard->set( listTargets,\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_clipboard_get),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_clipboard_clear) );"
+msgstr ""
+"Glib::RefPtr<Gtk::Clipboard> refClipboard = Gtk::Clipboard::get();\n"
+"\n"
+"// Cibles :\n"
+"std::list<Gtk::TargetEntry> listTargets;\n"
+"listTargets.push_back( Gtk::TargetEntry(\"example_custom_target\") );\n"
+"listTargets.push_back( Gtk::TargetEntry(\"UTF8_STRING\") );\n"
+"\n"
+"refClipboard->set( listTargets,\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_clipboard_get),\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_clipboard_clear) );"
+
+#: C/gtkmm-tutorial-in.xml:4818(para)
+msgid ""
+"Your callback will then provide the store data when the user chooses to "
+"paste the data. For instance:"
+msgstr ""
+"Votre fonction de rappel fournit alors les données enregistrées quand "
+"l'utilisateur décide de coller les données. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:4820(programlisting)
+#, no-wrap
+msgid ""
+"void ExampleWindow::on_clipboard_get(\n"
+" Gtk::SelectionData& selection_data, guint info)\n"
+"{\n"
+" const Glib::ustring target = selection_data.get_target();\n"
+"\n"
+" if(target == \"example_custom_target\")\n"
+" selection_data.set(\"example_custom_target\", m_ClipboardStore);\n"
+"}"
+msgstr ""
+"void ExampleWindow::on_clipboard_get(\n"
+" Gtk::SelectionData& selection_data, guint info)\n"
+"{\n"
+" const Glib::ustring target = selection_data.get_target();\n"
+"\n"
+" if(target == \"example_custom_target\")\n"
+" selection_data.set(\"example_custom_target\", m_ClipboardStore);\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:4828(para)
+msgid ""
+"The <literal>ideal</literal> example below can supply more than one "
+"clipboard target."
+msgstr ""
+"L'exemple « <literal>idéal</literal> » ci-après peut fournir plus d'une cible "
+"de presse-papier."
+
+#: C/gtkmm-tutorial-in.xml:4832(para)
+msgid ""
+"The clear callback allows you to free the memory used by your stored data "
+"when the clipboard replaces its data with something else."
+msgstr ""
+"La fonction de rappel de nettoyage libère la mémoire utilisée par le "
+"stockage de vos données quand le presse-papier remplace ses données par "
+"d'autres."
+
+#: C/gtkmm-tutorial-in.xml:4838(title)
+msgid "Paste"
+msgstr "Coller"
+
+#: C/gtkmm-tutorial-in.xml:4839(para)
+msgid ""
+"When the user asks to paste data from the <classname>Clipboard</classname>, "
+"you should request a specific format and provide a callback method which "
+"will be called with the actual data. For instance:"
+msgstr ""
+"Quand l'utilisateur demande à coller des données à partir du "
+"<classname>Clipboard</classname>, vous devez demander un format défini et "
+"fournir une fonction de rappel qui est appelée avec les vraies données. Par "
+"exemple :"
+
+#: C/gtkmm-tutorial-in.xml:4844(programlisting)
+#, no-wrap
+msgid ""
+"refClipboard->request_contents(\"example_custom_target\",\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_clipboard_received) );"
+msgstr ""
+"refClipboard->request_contents(\"example_custom_target\",\n"
+" sigc::mem_fun(*this, &ExampleWindow::on_clipboard_received) );"
+
+#: C/gtkmm-tutorial-in.xml:4847(para)
+msgid "Here is an example callback method:"
+msgstr "Voici un exemple de fonction de rappel :"
+
+#: C/gtkmm-tutorial-in.xml:4849(programlisting)
+#, no-wrap
+msgid ""
+"void ExampleWindow::on_clipboard_received(\n"
+" const Gtk::SelectionData& selection_data)\n"
+"{\n"
+" Glib::ustring clipboard_data = selection_data.get_data_as_string();\n"
+" //Do something with the pasted data.\n"
+"}"
+msgstr ""
+"void ExampleWindow::on_clipboard_received(\n"
+" const Gtk::SelectionData& selection_data)\n"
+"{\n"
+" Glib::ustring clipboard_data = selection_data.get_data_as_string();\n"
+" // Faire quelque choses avec les données collées.\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:4857(title)
+msgid "Discovering the available targets"
+msgstr "Détermination des cibles admissibles"
+
+#: C/gtkmm-tutorial-in.xml:4858(para)
+msgid ""
+"To find out what targets are currently available on the "
+"<classname>Clipboard</classname> for pasting, call the "
+"<methodname>request_targets()</methodname> method, specifying a method to be "
+"called with the information. For instance:"
+msgstr ""
+"Pour retrouver quelles sont les cibles actuellement admissibles dans "
+"<classname>Clipboard</classname> pour le collage, appelez la fonction membre "
+"<methodname>request_targets()</methodname> en indiquant une fonction membre "
+"à appeler avec l'information. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:4864(programlisting)
+#, no-wrap
+msgid ""
+"refClipboard->request_targets( sigc::mem_fun(*this,\n"
+" &ExampleWindow::on_clipboard_received_targets) );"
+msgstr ""
+"refClipboard->request_targets( sigc::mem_fun(*this,\n"
+" &ExampleWindow::on_clipboard_received_targets) );"
+
+#: C/gtkmm-tutorial-in.xml:4867(para)
+msgid ""
+"In your callback, compare the list of available targets with those that your "
+"application supports for pasting. You could enable or disable a Paste menu "
+"item, depending on whether pasting is currently possible. For instance:"
+msgstr ""
+"Dans votre fonction de rappel, comparez la liste des cibles disponibles avec "
+"celle des cibles que votre application prend en charge pour le collage. Vous "
+"pouvez activer ou désactiver un élément de menu Coller selon que le collage "
+"est ou n'est pas actuellement possible. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:4870(programlisting)
+#, no-wrap
+msgid ""
+"void ExampleWindow::on_clipboard_received_targets(\n"
+" const Glib::StringArrayHandle& targets_array)\n"
+"{\n"
+" // Get the list of available clipboard targets:\n"
+" std::list<std::string> targets = targets_array;\n"
+"\n"
+" const bool bPasteIsPossible =\n"
+" std::find(targets.begin(), targets.end(),\n"
+" example_target_custom) != targets.end();\n"
+"\n"
+" // Enable/Disable the Paste button appropriately:\n"
+" m_Button_Paste.set_sensitive(bPasteIsPossible);\n"
+"}"
+msgstr ""
+"void ExampleWindow::on_clipboard_received_targets(\n"
+" const Glib::StringArrayHandle& targets_array)\n"
+"{\n"
+" // Obtenir la liste des cibles disponibles dans le presse-papier :\n"
+" std::list<std::string> targets = targets_array;\n"
+"\n"
+" const bool bPasteIsPossible =\n"
+" std::find(targets.begin(), targets.end(),\n"
+" example_target_custom) != targets.end();\n"
+"\n"
+" // Activer/désactiver le bouton Coller de manière appropriée :\n"
+" m_Button_Paste.set_sensitive(bPasteIsPossible);\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:4889(title) C/gtkmm-tutorial-in.xml:5286(title)
+msgid "Simple"
+msgstr "Simple"
+
+#: C/gtkmm-tutorial-in.xml:4890(para)
+msgid ""
+"This example allows copy and pasting of application-specific data, using the "
+"standard text target. Although this is simple, it's not ideal because it "
+"does not identify the <classname>Clipboard</classname> data as being of a "
+"particular type."
+msgstr ""
+"Cet exemple permet le copier-coller de données propres à une application, "
+"avec une cible texte standard. Il est simple, mais il n'est pas idéal parce "
+"qu'il n'identifie pas les données <classname>Clipboard</classname> comme "
+"étant d'un type donné."
+
+#: C/gtkmm-tutorial-in.xml:4898(title)
+msgid "Clipboard - Simple"
+msgstr "Presse-papier - Simple"
+
+#: C/gtkmm-tutorial-in.xml:4908(title)
+msgid "Ideal"
+msgstr "Idéal"
+
+#: C/gtkmm-tutorial-in.xml:4911(simpara)
+msgid ""
+"Defines a custom clipboard target, though the format of that target is still "
+"text."
+msgstr ""
+"définit une cible de presse-papier personnalisée, même si le format de cette "
+"cible est toujours du texte,"
+
+#: C/gtkmm-tutorial-in.xml:4912(simpara)
+msgid ""
+"It supports pasting of 2 targets - both the custom one and a text one that "
+"creates an arbitrary text representation of the custom data."
+msgstr ""
+"prend en charge le collage de 2 cibles â?? d'une part la cible personnalisée, "
+"d'autre part une cible texte créant un représentation textuelle arbitraire "
+"des données personnalisées,"
+
+#: C/gtkmm-tutorial-in.xml:4913(simpara)
+msgid ""
+"It uses <methodname>request_targets()</methodname> and the "
+"<literal>owner_change</literal> signal and disables the Paste button if it "
+"can't use anything on the clipboard."
+msgstr ""
+"utilise <methodname>request_targets()</methodname> et le signal "
+"<literal>owner_change</literal> et désactive le bouton "
+"Coller s'il ne peut pas utiliser les données du presse-papier."
+
+#: C/gtkmm-tutorial-in.xml:4909(para)
+msgid "This is like the simple example, but it <placeholder-1/>"
+msgstr "Il est identique à l'exemple simple, mais il <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:4918(title)
+msgid "Clipboard - Ideal"
+msgstr "Presse-papier - Idéal"
+
+#: C/gtkmm-tutorial-in.xml:4934(title)
+msgid "Printing"
+msgstr "Impression"
+
+#: C/gtkmm-tutorial-in.xml:4937(para)
+msgid ""
+"Printing support is available in <application>gtkmm</application> version "
+"2.10 and later."
+msgstr ""
+"La prise en charge de l'impression est disponible dans les versions "
+"<application>gtkmm</application> 2.10 et ultérieures."
+
+#: C/gtkmm-tutorial-in.xml:4940(para)
+msgid ""
+"At the application development level, <application>gtkmm</application>'s "
+"printing API provides dialogs that are consistent across applications and "
+"allows us of Cairo's common drawing API, with Pango-driven text rendering. "
+"In the implementation of this common API, platform-specific backends and "
+"printer-specific drivers are used."
+msgstr ""
+"Au niveau développement d'une application, l'API impression de "
+"<application>gtkmm</application> fournit des boîtes de dialogue cohérentes "
+"entre applications et autorise l'API de dessin courant de Cairo avec un "
+"moteur de rendu de texte piloté par Pango. Pour l'implémentation courante de "
+"cette API, sont utilisés des moteurs de traitement particuliers à la plate-"
+"forme et des pilotes d'imprimantes spécifiques au périphérique."
+
+#: C/gtkmm-tutorial-in.xml:4946(title)
+msgid "PrintOperation"
+msgstr "Objet PrintOperation"
+
+#: C/gtkmm-tutorial-in.xml:4948(para)
+msgid ""
+"The primary object is <classname>Gtk::PrintOperation</classname>, allocated "
+"for each print operation. To handle page drawing connect to its signals, or "
+"inherit from it and override the default virtual signal handlers. "
+"<classname>PrintOperation</classname> automatically handles all the settings "
+"affecting the print loop."
+msgstr ""
+"L'objet principal est <classname>Gtk::PrintOperation</classname>, alloué "
+"pour chaque opération d'impression. Pour gérer le tracé de la page, il faut "
+"se connecter à ses signaux, ou bien créer un objet dérivé et surdéfinir les "
+"gestionnaires de signaux virtuels fournis par défaut. "
+"<classname>PrintOperation</classname> gère automatiquement tous les "
+"paramètres affectant la boucle d'impression."
+
+#: C/gtkmm-tutorial-in.xml:4965(para)
+msgid ""
+"<literal>begin_print</literal>: You must handle this signal, because this is "
+"where you create and set up a <classname>Pango::Layout</classname> using the "
+"provided <classname>Gtk::PrintContext</classname>, and break up your "
+"printing output into pages."
+msgstr ""
+"<literal>begin_print</literal> : vous devez gérer ce signal car c'est à cet "
+"instant que vous créez et définissez un objet <classname>Pango::Layout</"
+"classname> en utilisant le <classname>Gtk::PrintContext</classname> fourni "
+"et que vous y divisez la sortie d'impression en plusieurs pages."
+
+#: C/gtkmm-tutorial-in.xml:4975(para)
+msgid ""
+"<literal>paginate</literal>: Pagination is potentially slow so if you need "
+"to monitor it you can call the <methodname>PrintOperation::set_show_progress"
+"()</methodname> method and handle this signal."
+msgstr ""
+"<literal>paginate</literal> : la pagination est en règle générale lente, "
+"donc si vous voulez la contrôler, vous pouvez appeler la fonction membre "
+"<methodname>PrintOperation::set_show_progress()</methodname> et gérer ce "
+"signal."
+
+#: C/gtkmm-tutorial-in.xml:4989(para)
+msgid ""
+"<literal>request_page_setup</literal>: Provides a <classname>PrintContext</"
+"classname>, page number and <classname>Gtk::PageSetup</classname>. Handle "
+"this signal if you need to modify page setup on a per-page basis."
+msgstr ""
+"<literal>request_page_setup</literal>Â : fournit un objet "
+"<classname>PrintContext</classname>, un numéro de page et un objet "
+"<classname>Gtk::PageSetup</classname>. Gérez ce signal si vous voulez "
+"modifier page par page les réglages de la page."
+
+#: C/gtkmm-tutorial-in.xml:4998(para)
+msgid ""
+"<literal>draw_page</literal>: You must handle this signal, which provides a "
+"<classname>PrintContext</classname> and a page number. The "
+"<classname>PrintContext</classname> should be used to create a "
+"<classname>Cairo::Context</classname> into which the provided page should be "
+"drawn. To render text, iterate over the <classname>Pango::Layout</classname> "
+"you created in the <literal>begin_print</literal> handler."
+msgstr ""
+"<literal>draw_page</literal> : vous devez gérer ce signal qui fournit un "
+"objet <classname>PrintContext</classname> et un numéro de page. L'objet "
+"<classname>PrintContext</classname> sera utilisé pour créer un "
+"<classname>Cairo::Context</classname> dans lequel la page donnée sera "
+"dessinée. Pour le rendu du texte, itérez sur le <classname>Pango::Layout</"
+"classname> que vous avez créé dans le gestionnaire du signal "
+"<literal>begin_print</literal>."
+
+#: C/gtkmm-tutorial-in.xml:4984(para)
+msgid ""
+"For each page that needs to be rendered, the following signals are emitted: "
+"<placeholder-1/>"
+msgstr ""
+"Pour chaque page devant être imprimée, les signaux suivants sont émis : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5013(para)
+msgid ""
+"<literal>end_print</literal>: A handler for it is a safe place to free any "
+"resources related to a <classname>PrintOperation</classname>. If you have "
+"your custom class that inherits from <classname>PrintOperation</classname>, "
+"it is naturally simpler to do it in the destructor."
+msgstr ""
+"<literal>end_print</literal>Â : un gestionnaire pour ce signal est une place "
+"sûre pour libérer les ressources relatives à <classname>PrintOperation</"
+"classname>. Si vous avez une classe personnalisée dérivée de "
+"<classname>PrintOperation</classname>, il est évidemment plus simple de "
+"faire cela dans le destructeur."
+
+#: C/gtkmm-tutorial-in.xml:5023(para)
+msgid ""
+"<literal>done</literal>: This signal is emitted when printing is finished, "
+"meaning when the print data is spooled. Note that the provided <literal>Gtk::"
+"PrintOperationResult</literal> may indicate that an error occurred. In any "
+"case you probably want to notify the user about the final status."
+msgstr ""
+"<literal>done</literal> : ce signal est émis quand l'impression est "
+"terminée, cela signifie que les données de l'impression ont été placées en "
+"file d'attente. Notez que la valeur <literal>Gtk::PrintOperationResult</"
+"literal> renvoyée peut indiquer qu'une erreur est survenue. Dans tous les "
+"cas, vous souhaiterez probablement avertir l'utilisateur du résultat final."
+
+#: C/gtkmm-tutorial-in.xml:5033(para)
+msgid ""
+"<literal>status_changed</literal>: Emitted whenever a print job's status "
+"changes, until it is finished. Call the <methodname>PrintOperation::"
+"set_track_print_status()</methodname> method to monitor the job status after "
+"spooling. To see the status, use <methodname>get_status()</methodname> or "
+"<methodname>get_status_string()</methodname>."
+msgstr ""
+"<literal>status_changed</literal> : ce signal est émis chaque fois que "
+"l'état d'une tâche d'impression change jusqu'à ce qu'elle soit terminée. "
+"Appelez la fonction membre <methodname>PrintOperation::set_track_print_status"
+"()</methodname> pour contrôler l'état de la tâche après qu'elle a été placée "
+"en file d'attente. Pour afficher l'état, utilisez <methodname>get_status()</"
+"methodname> ou <methodname>get_status_string()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:4959(para)
+msgid ""
+"The <methodname>PrintOperation::run()</methodname> method starts the print "
+"loop, during which various signals are emitted: <placeholder-1/>"
+msgstr ""
+"La fonction membre <methodname>PrintOperation::run()</methodname> démarre la "
+"boucle d'impression au cours de laquelle divers signaux sont émis : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5055(title)
+msgid "Page setup"
+msgstr "Mise en page"
+
+#: C/gtkmm-tutorial-in.xml:5057(para)
+msgid ""
+"The <classname>PrintOperation</classname> class has a method called "
+"<methodname>set_default_page_setup()</methodname> which selects the default "
+"paper size, orientation and margins. To show a page setup dialog from your "
+"application, use the <methodname>Gtk::run_page_setup_dialog()</methodname> "
+"method, which returns a <classname>Gtk::PageSetup</classname> object with "
+"the chosen settings. Use this object to update a <classname>PrintOperation</"
+"classname> and to access the selected <classname>Gtk::PaperSize</classname>, "
+"<literal>Gtk::PageOrientation</literal> and printer-specific margins."
+msgstr ""
+"La classe <classname>PrintOperation</classname> dispose d'une fonction "
+"membre nommée <methodname>set_default_page_setup()</methodname> qui choisit "
+"par défaut une taille du papier, une orientation et des marges. Pour "
+"afficher la boîte de dialogue de mise en page dans l'application, servez-"
+"vous de la fonction membre <methodname>Gtk::run_page_setup_dialog()</"
+"methodname> qui renvoie un objet <classname>Gtk::PageSetup</classname> avec "
+"les réglages choisis. Utilisez cet objet pour mettre à jour un "
+"<classname>PrintOperation</classname> et avoir accès aux variables "
+"<classname>Gtk::PaperSize</classname>, <literal>Gtk::PageOrientation</"
+"literal> choisies ainsi qu'aux marges particulières à l'imprimante."
+
+#: C/gtkmm-tutorial-in.xml:5067(para)
+msgid ""
+"You should save the chosen <classname>Gtk::PageSetup</classname> so you can "
+"use it again if the page setup dialog is shown again."
+msgstr ""
+"Enregistrez l'objet <classname>Gtk::PageSetup</classname> avec vos choix, "
+"ainsi vous pourrez l'utiliser à nouveau si la boîte de dialogue de mise en "
+"page est à nouveau affichée."
+
+#: C/gtkmm-tutorial-in.xml:5071(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"//Within a class that inherits from Gtk::Window and keeps m_refPageSetup and m_refSettings as members...\n"
+"Glib::RefPtr<Gtk::PageSetup> new_page_setup = Gtk::run_page_setup_dialog(*this, m_refPageSetup, m_refSettings);\n"
+"m_refPageSetup = new_page_setup;\n"
+msgstr ""
+"\n"
+"// Dans une classe dérivée de Gtk::Window \n"
+"// avec m_refPageSetup et m_refSettings comme membres...\n"
+"Glib::RefPtr<Gtk::PageSetup> new_page_setup = Gtk::run_page_setup_dialog(*this,\n"
+" m_refPageSetup, m_refSettings);\n"
+"m_refPageSetup = new_page_setup;\n"
+
+#: C/gtkmm-tutorial-in.xml:5070(para) C/gtkmm-tutorial-in.xml:5135(para)
+#: C/gtkmm-tutorial-in.xml:8915(para)
+msgid "For instance, <placeholder-1/>"
+msgstr "Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5082(para)
+msgid ""
+"The Cairo coordinate system, in the <literal>draw_page</literal> handler, is "
+"automatically rotated to the current page orientation. It is normally within "
+"the printer margins, but you can change that via the "
+"<methodname>PrintOperation::set_use_full_page()</methodname> method. The "
+"default measurement unit is device pixels. To select other units, use the "
+"<methodname>PrintOperation::set_unit()</methodname> method."
+msgstr ""
+"Le système de coordonnées de Cairo, dans le gestionnaire de "
+"<literal>draw_page</literal>, est automatiquement tourné selon l'orientation "
+"de la page en cours. Il est normalement situé à l'intérieur des marges de "
+"l'imprimante, mais vous pouvez modifier ce réglage avec la fonction membre "
+"<methodname>PrintOperation::set_use_full_page()</methodname>. L'unité de "
+"mesure par défaut est le pixel du périphérique. Pour choisir d'autres "
+"unités, servez-vous de la fonction membre <methodname>PrintOperation::"
+"set_unit()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:5094(title)
+msgid "Rendering text"
+msgstr "Rendu de texte"
+
+#: C/gtkmm-tutorial-in.xml:5096(para)
+msgid ""
+"Text rendering is done using Pango. The <classname>Pango::Layout</classname> "
+"object for printing should be created by calling the "
+"<methodname>PrintContext::create_pango_layout()</methodname> method. The "
+"<classname>PrintContext</classname> object also provides the page metrics, "
+"via <methodname>get_width()</methodname> and <methodname>get_height()</"
+"methodname>. The number of pages can be set with <methodname>PrintOperation::"
+"set_n_pages()</methodname>. To actually render the Pango text in "
+"<literal>on_draw_page</literal>, get a <classname>Cairo::Context</classname> "
+"with <methodname>PrintContext::get_cairo_context()</methodname> and show the "
+"<classname>Pango::LayoutLine</classname>s that appear within the requested "
+"page number."
+msgstr ""
+"Le rendu du texte s'effectue avec Pango. L'objet <classname>Pango::Layout</"
+"classname> pour l'impression est créé en appelant la fonction membre "
+"<methodname>PrintContext::create_pango_layout()</methodname>. L'objet "
+"<classname>PrintContext</classname> indique également la métrique de la page "
+"par l'intermédiaire des fonctions <methodname>get_width()</methodname> et "
+"<methodname>get_height()</methodname>. Le nombre de pages peut être fixé à "
+"l'aide de <methodname>PrintOperation::set_n_pages()</methodname>. Pour "
+"effectuer le rendu effectif du texte Pango dans <literal>on_draw_page</"
+"literal>, obtenez un <classname>Cairo::Context</classname> avec la fonction "
+"membre <methodname>PrintContext::get_cairo_context()</methodname> et "
+"affichez les objets <classname>Pango::LayoutLine</classname> qui "
+"apparaissent dans le nombre de pages demandées."
+
+#: C/gtkmm-tutorial-in.xml:5111(para)
+msgid ""
+"See <link linkend=\"sec-printing-example-simple\">an example</link> of "
+"exactly how this can be done."
+msgstr ""
+"Pour voir exactement comment réaliser ceci, consultez <link linkend=\"sec-"
+"printing-example-simple\">cet exemple</link>."
+
+#: C/gtkmm-tutorial-in.xml:5119(title)
+msgid "Asynchronous operations"
+msgstr "Opérations asynchrones"
+
+#: C/gtkmm-tutorial-in.xml:5121(para)
+msgid ""
+"By default, <methodname>PrintOperation::run()</methodname> returns when a "
+"print operation is completed. If you need to run a non-blocking print "
+"operation, call <methodname>PrintOperation::set_allow_async()</methodname>. "
+"Note that <methodname>set_allow_async()</methodname> is not supported on all "
+"platforms, however the <literal>done</literal> signal will still be emitted."
+msgstr ""
+"Par défaut, <methodname>PrintOperation::run()</methodname> rend la main "
+"quand l'opération d'impression est terminée. Si vous voulez lancer une "
+"opération d'impression non-bloquante, appelez <methodname>PrintOperation::"
+"set_allow_async()</methodname>. Notez que <methodname>set_allow_async()</"
+"methodname> n'est pas pris en charge sur toutes les plates-formes, bien que "
+"le signal <literal>done</literal> soit toujours émis."
+
+#: C/gtkmm-tutorial-in.xml:5128(para)
+msgid ""
+"<methodname>run()</methodname> may return "
+"<literal>PRINT_OPERATION_RESULT_IN_PROGRESS</literal>. To track status and "
+"handle the result or error you need to implement signal handlers for the "
+"<literal>done</literal> and <literal>status_changed</literal> signals:"
+msgstr ""
+"Il se peut que la fonction membre <methodname>run()</methodname> renvoie "
+"<literal>PRINT_OPERATION_RESULT_IN_PROGRESS</literal>. Pour suivre l'état et "
+"gérer le résultat ou une erreur, vous devez implémenter des gestionnaires "
+"pour les signaux <literal>done</literal> et <literal>status_changed</"
+"literal>Â :"
+
+#: C/gtkmm-tutorial-in.xml:5136(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"// in class ExampleWindow's method...\n"
+"Glib::RefPtr<PrintOperation> op = PrintOperation::create();\n"
+"// ...set up op...\n"
+"op->signal_done().connect(sigc::bind(sigc::mem_fun(*this, &ExampleWindow::on_printoperation_done), op));\n"
+"// run the op\n"
+msgstr ""
+"\n"
+"// dans la fonction membre de la classe ExampleWindow...\n"
+"Glib::RefPtr<PrintOperation> op = PrintOperation::create();\n"
+"// ...paramétrer op...\n"
+"op->signal_done().connect(sigc::bind(sigc::mem_fun(*this, \n"
+" &ExampleWindow::on_printoperation_done), op));\n"
+"// lancer op\n"
+
+#: C/gtkmm-tutorial-in.xml:5146(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"void ExampleWindow::on_printoperation_done(Gtk::PrintOperationResult result, const Glib::RefPtr<PrintOperation>& op)\n"
+"{\n"
+" if (result == Gtk::PRINT_OPERATION_RESULT_ERROR)\n"
+" //notify user\n"
+" else if (result == Gtk::PRINT_OPERATION_RESULT_APPLY)\n"
+" //Update PrintSettings with the ones used in this PrintOperation\n"
+"\n"
+" if (! op->is_finished())\n"
+" op->signal_status_changed().connect(sigc::bind(sigc::mem_fun(*this, &ExampleWindow::on_printoperation_status_changed), op));\n"
+"}\n"
+msgstr ""
+"\n"
+"void ExampleWindow::on_printoperation_done(Gtk::PrintOperationResult result,\n"
+" const Glib::RefPtr<PrintOperation>& op)\n"
+"{\n"
+" if (result == Gtk::PRINT_OPERATION_RESULT_ERROR)\n"
+" // avertir l'utilisateur\n"
+" else if (result == Gtk::PRINT_OPERATION_RESULT_APPLY)\n"
+" // mettre à jour PrintSettings avec ceux de cette PrintOperation\n"
+"\n"
+" if (! op->is_finished())\n"
+" op->signal_status_changed().connect(sigc::bind(sigc::mem_fun(*this,\n"
+" &ExampleWindow::on_printoperation_status_changed), op));\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:5145(para)
+msgid ""
+"Second, check for an error and connect to the <literal>status_changed</"
+"literal> signal. For instance: <placeholder-1/>"
+msgstr ""
+"Ensuite, vérifiez si une erreur est survenue et connectez le signal "
+"<literal>status_changed</literal>. Par exemple : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5161(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"void ExampleWindow::on_printoperation_status_changed(const Glib::RefPtr<PrintFormOperation>& op)\n"
+"{\n"
+" if (op->is_finished())\n"
+" //the print job is finished\n"
+" else\n"
+" //get the status with get_status() or get_status_string()\n"
+"\n"
+" //update UI\n"
+"}\n"
+msgstr ""
+"\n"
+"void ExampleWindow::on_printoperation_status_changed(\n"
+" const Glib::RefPtr<PrintFormOperation>& op)\n"
+"{\n"
+" if (op->is_finished())\n"
+" // la tâche d'impression est terminée \n"
+" else\n"
+" // obtenir l'état avec get_status() ou get_status_string()\n"
+"\n"
+" // mettre à jour l'UI\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:5160(para)
+msgid "Finally, check the status. For instance, <placeholder-1/>"
+msgstr "Pour terminer, vérifiez l'état. Par exemple : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5177(title)
+msgid "Export to PDF"
+msgstr "Exportation au format PDF"
+
+#: C/gtkmm-tutorial-in.xml:5181(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gtk::PrintOperation> op = Gtk::PrintOperation::create();\n"
+"// ...set up op...\n"
+"op->set_export_filename(\"test.pdf\");\n"
+"Gtk::PrintOperationResult res = op->run(Gtk::PRINT_OPERATION_ACTION_EXPORT);\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gtk::PrintOperation> op = Gtk::PrintOperation::create();\n"
+"// ...configurer op...\n"
+"op->set_export_filename(\"test.pdf\");\n"
+"Gtk::PrintOperationResult res = op->run(Gtk::PRINT_OPERATION_ACTION_EXPORT);\n"
+
+#: C/gtkmm-tutorial-in.xml:5178(para)
+msgid ""
+"The 'Print to file' option is available in the print dialog, without the "
+"need for extra implementation. However, it is sometimes useful to generate a "
+"pdf file directly from code. For instance, <placeholder-1/>"
+msgstr ""
+"L'option « Imprimer dans un fichier » est disponible dans la boîte de "
+"dialogue d'impression sans qu'il soit nécessaire de réaliser d'autres "
+"implémentations. Toutefois, il est quelquefois utile de générer un fichier ."
+"pdf directement dans le code. Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5193(title)
+msgid "Extending the print dialog"
+msgstr "Extension de la boîte de dialogue d'impression"
+
+#: C/gtkmm-tutorial-in.xml:5200(para)
+msgid ""
+"Set the title of the tab via <methodname>PrintOperation::set_custom_tab_label"
+"()</methodname>, create a new widget and return it from the "
+"<literal>create_custom_widget</literal> signal handler. You'll probably want "
+"this to be a container widget, packed with some others."
+msgstr ""
+"définissez l'intitulé de l'onglet avec <methodname>PrintOperation::"
+"set_custom_tab_label()</methodname>, créez un nouvel élément graphique et "
+"renvoyez un pointeur sur celui-ci dans le gestionnaire de signal "
+"<literal>create_custom_widget</literal>. Vous souhaiterez probablement que "
+"ce soit un élément graphique conteneur en empaquetant quelques autres."
+
+#: C/gtkmm-tutorial-in.xml:5210(para)
+msgid ""
+"Get the data from the widgets in the <literal>custom_widget_apply</literal> "
+"signal handler."
+msgstr ""
+"recueillez les données des éléments graphiques dans le gestionnaire de "
+"signal <literal>custom_widget_apply</literal>."
+
+#: C/gtkmm-tutorial-in.xml:5195(para)
+msgid "You may add a custom tab to the print dialog: <placeholder-1/>"
+msgstr ""
+"Vous pouvez ajouter un onglet personnalisé à la boîte de dialogue "
+"d'impression : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5225(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Gtk::Widget* CustomPrintOperation::on_create_custom_widget()\n"
+"{\n"
+" set_custom_tab_label(\"My custom tab\");\n"
+"\n"
+" Gtk::HBox* hbox = new Gtk::HBox(false, 8);\n"
+" hbox->set_border_width(6);\n"
+"\n"
+" Gtk::Label* label = Gtk::manage(new Gtk::Label(\"Enter some text: \"));\n"
+" hbox->pack_start(*label, false, false);\n"
+" label->show();\n"
+"\n"
+" hbox->pack_start(m_Entry, false, false);\n"
+" m_Entry.show();\n"
+"\n"
+" return hbox;\n"
+"}\n"
+"\n"
+"void CustomPrintOperation::on_custom_widget_apply(Gtk::Widget* /* widget */)\n"
+"{\n"
+" Glib::ustring user_input = m_Entry.get_text();\n"
+" //...\n"
+"}\n"
+msgstr ""
+"\n"
+"Gtk::Widget* CustomPrintOperation::on_create_custom_widget()\n"
+"{\n"
+" set_custom_tab_label(\"Onglet personnalisé\");\n"
+"\n"
+" Gtk::HBox* hbox = new Gtk::HBox(false, 8);\n"
+" hbox->set_border_width(6);\n"
+"\n"
+" Gtk::Label* label = Gtk::manage(new Gtk::Label(\"Saisissez du texte : \"));\n"
+" hbox->pack_start(*label, false, false);\n"
+" label->show();\n"
+"\n"
+" hbox->pack_start(m_Entry, false, false);\n"
+" m_Entry.show();\n"
+"\n"
+" return hbox;\n"
+"}\n"
+"\n"
+"void CustomPrintOperation::on_custom_widget_apply(Gtk::Widget* /* widget */)\n"
+"{\n"
+" Glib::ustring user_input = m_Entry.get_text();\n"
+" //...\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:5218(para)
+msgid ""
+"Although the <literal>custom_widget_apply</literal> signal provides the "
+"widget you previously created, to simplify things you can keep the widgets "
+"you expect to contain some user input as class members. For example, let's "
+"say you have a <classname>Gtk::Entry</classname> called <literal>m_Entry</"
+"literal> as a member of your <classname>CustomPrintOperation</classname> "
+"class: <placeholder-1/>"
+msgstr ""
+"Bien que le signal <literal>custom_widget_apply</literal> fournisse un "
+"pointeur sur l'élément graphique précédemment créé, pour simplifier les "
+"choses, vous pouvez conserver en tant que membres de la classe, les éléments "
+"graphiques présumés contenir des entrées utilisateur. Par exemple, disons "
+"que nous avons un <classname>Gtk::Entry</classname> nommé <literal>m_Entry</"
+"literal> membre de votre classe <classname>CustomPrintOperation</"
+"classname>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5252(para)
+msgid "The example in examples/book/printing/advanced demonstrates this."
+msgstr ""
+"L'exemple dans le dossier <filename>examples/book/printing/advanced</"
+"filename> démontre cette façon d'opérer."
+
+#: C/gtkmm-tutorial-in.xml:5259(title)
+msgid "Preview"
+msgstr "Aperçu"
+
+#: C/gtkmm-tutorial-in.xml:5265(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"// in a class that inherits from Gtk::Window...\n"
+"Glib::RefPtr<PrintOperation> op = PrintOperation::create();\n"
+"// ...set up op...\n"
+"op->run(Gtk::PRINT_OPERATION_ACTION_PREVIEW, *this);\n"
+msgstr ""
+"\n"
+"// dans une classe qui hérite de Gtk::Window...\n"
+"Glib::RefPtr<PrintOperation> op = PrintOperation::create();\n"
+"// ...paramétrer op...\n"
+"op->run(Gtk::PRINT_OPERATION_ACTION_PREVIEW, *this);\n"
+
+#: C/gtkmm-tutorial-in.xml:5261(para)
+msgid ""
+"The native GTK+ print dialog has a preview button, but you may also start a "
+"preview directly from an application: <placeholder-1/>"
+msgstr ""
+"La boîte de dialogue d'impression native de GTK+ dispose d'un bouton "
+"d'aperçu, mais vous pouvez également lancer l'aperçu directement à partir de "
+"l'application : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5273(para)
+msgid ""
+"On Unix, the default preview handler uses an external viewer program. On "
+"Windows, the native preview dialog will be shown. If necessary you may "
+"override this behaviour and provide a custom preview dialog. See the example "
+"located in /examples/book/printing/advanced."
+msgstr ""
+"Sous Unix, le gestionnaire d'aperçu par défaut utilise un programme externe "
+"de visualisation. Sous Windows, la boîte de dialogue d'aperçu native est "
+"affichée. Si nécessaire, vous pouvez surdéfinir ce comportement et fournir "
+"une boîte de dialogue d'aperçu personnalisée. Consultez l'exemple dans le "
+"dossier <filename>/examples/book/printing/advanced</filename>."
+
+#: C/gtkmm-tutorial-in.xml:5288(para)
+msgid ""
+"The following example demonstrates how to print some input from a user "
+"interface. It shows how to implement <literal>on_begin_print</literal> and "
+"<literal>on_draw_page</literal>, as well as how to track print status and "
+"update the print settings."
+msgstr ""
+"L'exemple suivant montre comment imprimer une saisie à partir d'une "
+"interface utilisateur. Il montre comment implémenter "
+"<literal>on_begin_print</literal> et <literal>on_draw_page</literal>, de "
+"même que suivre l'état de l'impression et mettre à jour les réglages."
+
+#: C/gtkmm-tutorial-in.xml:5296(title)
+msgid "Printing - Simple"
+msgstr "Impression - Simple"
+
+#: C/gtkmm-tutorial-in.xml:5311(title)
+msgid "Recently Used Documents"
+msgstr "Documents récents"
+
+#: C/gtkmm-tutorial-in.xml:5313(para) C/gtkmm-tutorial-in.xml:5469(para)
+msgid ""
+"Recent Files support is available in <application>gtkmm</application> "
+"version 2.10 and later"
+msgstr ""
+"La prise en charge des « Fichiers récents... » est disponible dans "
+"<application>gtkmm</application> version 2.10 et ultérieures"
+
+#: C/gtkmm-tutorial-in.xml:5316(para)
+msgid ""
+"<application>gtkmm</application> provides an easy way to manage recently "
+"used documents. The classes involved in implementing this functionality are "
+"<classname>RecentManager</classname>, <classname>RecentChooserDialog</"
+"classname>, <classname>RecentChooserMenu</classname>, "
+"<classname>RecentChooserWidget</classname>, and <classname>RecentFilter</"
+"classname>."
+msgstr ""
+"<application>gtkmm</application> fournit un moyen simple pour gérer les "
+"documents récemment utilisés. Les classes impliquées dans cette "
+"fonctionnalité sont <classname>RecentManager</classname>, "
+"<classname>RecentChooserDialog</classname>, <classname>RecentChooserMenu</"
+"classname>, <classname>RecentChooserWidget</classname> et "
+"<classname>RecentFilter</classname>."
+
+#: C/gtkmm-tutorial-in.xml:5325(para)
+msgid ""
+"Each item in the list of recently used files is identified by its URI, and "
+"can have associated metadata. The metadata can be used to specify how the "
+"file should be displayed, a description of the file, its mime type, which "
+"application registered it, whether it's private to the registering "
+"application, and several other things."
+msgstr ""
+"Chaque élément, dans la liste des fichiers récemment utilisés, est identifié "
+"par son URI et peut posséder des métadonnées associées. Les métadonnées "
+"peuvent être utilisées pour définir la façon dont le fichier doit être "
+"affiché, une description du fichier, son type MIME, quelle application l'a "
+"enregistré, s'il appartient en propre à l'application qui l'a enregistré et "
+"diverses autres informations."
+
+#: C/gtkmm-tutorial-in.xml:5333(title)
+msgid "RecentManager"
+msgstr "La classe RecentManager"
+
+#: C/gtkmm-tutorial-in.xml:5334(para)
+msgid ""
+"<classname>RecentManager</classname> acts as the central database of "
+"recently used files. You use this class to register new files, remove files "
+"from the list, or look up recently used files."
+msgstr ""
+"La classe <classname>RecentManager</classname> joue le rôle de base de "
+"donnée centrale des fichiers récemment utilisés. Vous utilisez cette classe "
+"pour enregistrer de nouveaux fichiers, enlever des fichiers de la liste ou "
+"rechercher les fichiers récemment utilisés."
+
+#: C/gtkmm-tutorial-in.xml:5339(para)
+msgid ""
+"You can create a new <classname>RecentManager</classname>, but you'll most "
+"likely just want to use the default one. You can get a reference to the "
+"default <classname>RecentManager</classname> with <methodname>get_default()</"
+"methodname>."
+msgstr ""
+"Il est possible de créer une nouvelle classe <classname>RecentManager</"
+"classname>, mais il est plus vraisemblable que vous souhaiterez vous servir "
+"de celle par défaut. Vous obtiendrez une référence sur cette dernière avec "
+"<methodname>get_default()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:5346(title)
+msgid "Adding Items to the List of Recent Files"
+msgstr "Ajout d'éléments à la liste des fichiers récents"
+
+#: C/gtkmm-tutorial-in.xml:5347(para)
+msgid ""
+"To add a new file to the list of recent documents, in the simplest case, you "
+"only need to provide the URI. For example:"
+msgstr ""
+"Pour ajouter un nouveau fichier à la liste des documents récents, dans le "
+"cas le plus simple, vous n'avez besoin que de fournir l'URI. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:5351(programlisting)
+#, no-wrap
+msgid ""
+"Glib::RefPtr<Gtk::RecentManager> recent_manager = Gtk::RecentManager::get_default();\n"
+"recent_manager->add_item(uri);"
+msgstr ""
+"Glib::RefPtr<Gtk::RecentManager> recent_manager = Gtk::RecentManager::get_default();\n"
+"recent_manager->add_item(uri);"
+
+#: C/gtkmm-tutorial-in.xml:5353(para)
+msgid ""
+"If you want to register a file with metadata, you can pass a "
+"<classname>RecentManager::Data</classname> parameter to <methodname>add_item"
+"()</methodname>. The metadata that can be set on a particular file item is "
+"as follows:"
+msgstr ""
+"Si vous voulez enregistrer un fichier avec ses métadonnées, passez un "
+"paramètre <classname>RecentManager::Data</classname> à la fonction membre "
+"<methodname>add_item()</methodname>. Les métadonnées pouvant être définies "
+"sur un élément fichier donné sont :"
+
+#: C/gtkmm-tutorial-in.xml:5361(para)
+msgid ""
+"<varname>app_exec</varname>: The command line to be used to launch this "
+"resource. This string may contain the \"f\" and \"u\" escape characters "
+"which will be expanded to the resource file path and URI respectively"
+msgstr ""
+"<varname>app_exec</varname> : la ligne de commande à utiliser pour atteindre "
+"cette ressource. Cette chaîne peut comporter les caractères d'échappement "
+"« f » et « u » ; ils seront respectivement développés sous forme du chemin "
+"d'accès à la ressource et de l'URI."
+
+#: C/gtkmm-tutorial-in.xml:5367(para)
+msgid ""
+"<varname>app_name</varname>: The name of the application that registered the "
+"resource"
+msgstr ""
+"<varname>app_name</varname> : le nom de l'application qui a enregistré la "
+"ressource."
+
+#: C/gtkmm-tutorial-in.xml:5371(para)
+msgid ""
+"<varname>description</varname>: A short description of the resource as a UTF-"
+"8 encoded string"
+msgstr ""
+"<varname>description</varname>Â : une courte description de la ressource sous "
+"forme d'une chaîne UTF-8."
+
+#: C/gtkmm-tutorial-in.xml:5375(para)
+msgid ""
+"<varname>display_name</varname>: The name of the resource to be used for "
+"display as a UTF-8 encoded string"
+msgstr ""
+"<varname>display_name</varname> : le nom de la ressource à utiliser pour "
+"l'affichage sous forme d'une chaîne UTF-8."
+
+#: C/gtkmm-tutorial-in.xml:5379(para)
+msgid ""
+"<varname>groups</varname>: A list of groups associated with this item. "
+"Groups are essentially arbitrary strings associated with a particular "
+"resource. They can be thought of as 'categories' (such as \"email\", "
+"\"graphics\", etc) or tags for the resource."
+msgstr ""
+"<varname>groups</varname> : une liste des groupes associés à cet élément. "
+"Les groupes sont essentiellement des dénominations arbitraires associées à "
+"des ressources particulières. Ils peuvent être pensés en termes de "
+"« catégories » (telles que « courriel », « graphiques ») ou de marqueurs pour "
+"la ressource."
+
+#: C/gtkmm-tutorial-in.xml:5385(para)
+msgid ""
+"<varname>is_private</varname>: Whether this resource should be visible only "
+"to applications that have registered it or not"
+msgstr ""
+"<varname>is_private</varname> : indique si la ressource ne doit être visible "
+"que des applications qui l'ont enregistrée ou non."
+
+#: C/gtkmm-tutorial-in.xml:5389(para)
+msgid "<varname>mime_type</varname>: The MIME type of the resource"
+msgstr "<varname>mime_type</varname>Â : le type MIME de la ressource."
+
+#: C/gtkmm-tutorial-in.xml:5392(para)
+msgid ""
+"In addition to adding items to the list, you can also look up items from the "
+"list and modify or remove items."
+msgstr ""
+"En plus de la possibilité d'intégrer des éléments dans la liste, vous pouvez "
+"aussi faire une recherche d'éléments déjà présents dans la liste, les "
+"modifier ou les enlever."
+
+#: C/gtkmm-tutorial-in.xml:5398(title)
+msgid "Looking up Items in the List of Recent Files"
+msgstr "Examen des éléments de la liste des fichiers récents"
+
+#: C/gtkmm-tutorial-in.xml:5399(para)
+msgid ""
+"To look up recently used files, <classname>RecentManager</classname> "
+"provides several functions. To look up a specific item by its URI, you can "
+"use the <methodname>lookup_item()</methodname> function, which will return a "
+"<classname>RecentInfo</classname> class. If the specified URI did not exist "
+"in the list of recent files, the <classname>RecentInfo</classname> object "
+"will be invalid. <classname>RecentInfo</classname> provides an "
+"implementation for <methodname>operator bool()</methodname> which can be "
+"used to test for validity. For example:"
+msgstr ""
+"Pour chercher les fichiers récemment utilisés, <classname>RecentManager</"
+"classname> dispose de plusieurs fonctions. Pour chercher un élément donné "
+"par son URI, utilisez la fonction <methodname>lookup_item()</methodname> qui "
+"renvoie un objet de la classe <classname>RecentInfo</classname>. Si l'URI "
+"indiqué n'existe pas dans la liste des fichiers récents, l'objet "
+"<classname>RecentInfo</classname> sera non valide. <classname>RecentInfo</"
+"classname> implémente <methodname>operator bool()</methodname> que vous "
+"pouvez utiliser pour tester la validité. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:5410(programlisting)
+#, no-wrap
+msgid ""
+"Gtk::RecentInfo info = recent_manager->lookup_item(uri);\n"
+"if (info)\n"
+"{\n"
+" // item was found\n"
+"}"
+msgstr ""
+"Gtk::RecentInfo info = recent_manager->lookup_item(uri);\n"
+"if (info)\n"
+"{\n"
+" // l'élément a été trouvé\n"
+"}"
+
+#: C/gtkmm-tutorial-in.xml:5415(para)
+msgid ""
+"A <classname>RecentInfo</classname> object is essentially an object "
+"containing all of the metadata about a single recently-used file. You can "
+"use this object to look up any of the properties listed above. FIXME - add "
+"cross-reference."
+msgstr ""
+"Un objet <classname>RecentInfo</classname> est essentiellement un objet "
+"contenant toutes les métadonnées à propos d'un seul fichier récemment "
+"utilisé. Vous pouvez utiliser cet objet pour chercher l'une quelconque des "
+"propriétés listées ci-dessus. FIXME â?? ajouter les références croisées."
+
+#: C/gtkmm-tutorial-in.xml:5421(para)
+msgid ""
+"If you don't want to look for a specific URI, but instead want to get a list "
+"of all recently used items, <classname>RecentManager</classname> provides "
+"the <methodname>get_items()</methodname> function. The return value of this "
+"function can be assigned to any standard C++ container (e.g. <classname>std::"
+"vector</classname>, <classname>std::list</classname>, etc) and contains a "
+"list of all recently-used files up to a user-defined limit (FIXME: what's "
+"the default limit?). The following code demonstrates how you might get a "
+"list of recently-used files:"
+msgstr ""
+"Si vous ne voulez pas rechercher un URI donné, mais au lieu de cela, voulez "
+"obtenir la liste de tous les éléments récemment utilisés, "
+"<classname>RecentManager</classname> dispose de la fonction "
+"<methodname>get_items()</methodname>. La valeur renvoyée peut être assignée "
+"Ã n'importe quel conteneur standard C++ (par exemple, <classname>std::"
+"vector</classname>, <classname>std::list</classname>, etc)Â ; elle contient "
+"la liste de tous les fichiers récemment utilisés jusqu'à la limite indiquée "
+"par l'utilisateur [FIXME : quelle est la limite par défaut ?]. Le code ci-"
+"après montre comment obtenir une liste des fichiers récemment utilisés :"
+
+#: C/gtkmm-tutorial-in.xml:5432(programlisting)
+#, no-wrap
+msgid "std::vector<Gtk::RecentInfo> info_list = recent_manager->get_items();"
+msgstr "std::vector<Gtk::RecentInfo> info_list = recent_manager->get_items();"
+
+#: C/gtkmm-tutorial-in.xml:5433(para)
+msgid ""
+"The limit on the number of items returned can be set by <methodname>set_limit"
+"()</methodname>, and queried with <methodname>get_limit()</methodname>."
+msgstr ""
+"La fonction membre <methodname>set_limit()</methodname> fixe le nombre "
+"limite d'éléments renvoyés ; <methodname>get_limit()</methodname> permet "
+"d'en prendre connaissance."
+
+#: C/gtkmm-tutorial-in.xml:5440(title)
+msgid "Modifying the List of Recent Files"
+msgstr "Modification de la liste des fichiers récents"
+
+#: C/gtkmm-tutorial-in.xml:5441(para)
+msgid ""
+"There may be times when you need to modify the list of recent files. For "
+"instance, if a file is moved or renamed, you may need to update the file's "
+"location in the recent files list so that it doesn't point to an incorrect "
+"location. You can update an item's location by using <methodname>move_item()"
+"</methodname>."
+msgstr ""
+"Vous pouvez parfois avoir besoin de modifier la liste des fichiers récents. "
+"Par exemple, si un fichier est déplacé ou renommé, vous pouvez mettre à jour "
+"l'emplacement ou le nom du fichier dans la liste des fichiers récents pour "
+"éviter de pointer vers quelque chose d'incorrect. Vous pouvez mettre à jour "
+"l'emplacement d'un élément avec <methodname>move_item()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:5448(para)
+msgid ""
+"In addition to changing a file's URI, you can also remove items from the "
+"list, either one at a time or by clearint them all at once. The former is "
+"accomplished with <methodname>remove_item()</methodname>, the latter with "
+"<methodname>purge_items()</methodname>."
+msgstr ""
+"En plus de modifier l'URI d'un fichier, vous pouvez enlever des éléments de "
+"la liste, soit un à un, soit tous à la fois. La première opération "
+"s'effectue avec <methodname>remove_item()</methodname>, la dernière avec "
+"<methodname>purge_items()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:5455(para)
+msgid ""
+"The functions <methodname>move_item()</methodname>, <methodname>remove_item()"
+"</methodname> and <methodname>purge_items()</methodname> have no effect on "
+"the actual files that are referred to by the URIs, they only modify the list "
+"of recent files."
+msgstr ""
+"Les fonctions <methodname>move_item()</methodname>, <methodname>remove_item()"
+"</methodname> et <methodname>purge_items()</methodname> n'ont aucun effet "
+"concret sur les fichiers auxquels les URI se référent ; elles ne font que "
+"modifier la liste."
+
+#: C/gtkmm-tutorial-in.xml:5467(title)
+msgid "RecentChooser"
+msgstr "La classe RecentChooser"
+
+#: C/gtkmm-tutorial-in.xml:5472(para)
+msgid ""
+"<classname>RecentChooser</classname> is an interface that can be implemented "
+"by widgets displaying the list of recently used files. <application>gtkmm</"
+"application> provides three built-in implementations for choosing recent "
+"files: <classname>RecentChooserWidget</classname>, "
+"<classname>RecentChooserDialog</classname>, and "
+"<classname>RecentChooserMenu</classname>."
+msgstr ""
+"<classname>RecentChooser</classname> est une interface pouvant être "
+"implémentée par les éléments graphiques affichant la liste des fichiers "
+"récemment utilisés. <application>gtkmm</application> met à votre disposition "
+"trois implémentations intégrées pour le choix des fichiers récents : "
+"<classname>RecentChooserWidget</classname>, <classname>RecentChooserDialog</"
+"classname> et <classname>RecentChooserMenu</classname>."
+
+#: C/gtkmm-tutorial-in.xml:5480(para)
+msgid ""
+"<classname>RecentChooserWidget</classname> is a simple widget for displaying "
+"a list of recently used files. <classname>RecentChooserWidget</classname> is "
+"the basic building block for <classname>RecentChooserDialog</classname>, but "
+"you can embed it into your user interface if you want to."
+msgstr ""
+"<classname>RecentChooserWidget</classname> est un simple élément graphique "
+"pour un affichage de la liste des fichiers récemment utilisés. "
+"<classname>RecentChooserWidget</classname> est l'élément de base de la "
+"classe <classname>RecentChooserDialog</classname>, mais vous pouvez "
+"l'incorporer dans votre interface utilisateur si vous le souhaitez."
+
+#: C/gtkmm-tutorial-in.xml:5487(para)
+msgid ""
+"The last class that implements the <classname>RecentChooser</classname> "
+"interface is <classname>RecentChooserMenu</classname>. This class allows you "
+"to list recently used files as a menu."
+msgstr ""
+"La dernière classe implémentant l'interface <classname>RecentChooser</"
+"classname> est <classname>RecentChooserMenu</classname>. Cette classe vous "
+"permet de lister les fichiers récemment utilisés comme un menu."
+
+#: C/gtkmm-tutorial-in.xml:5493(title)
+msgid "Simple RecentChooserWidget example"
+msgstr "Exemple simple de l'utilisation de RecentChooserWidget"
+
+#: C/gtkmm-tutorial-in.xml:5494(para)
+msgid ""
+"Shown below is a simple example of how to use the "
+"<classname>RecentChooserDialog</classname> class in a program. This simple "
+"program has a menubar with a \"Recent Files Dialog\" menu item. When you "
+"select this menu item, a dialog pops up showing the list of recently used "
+"files."
+msgstr ""
+"Voici un exemple simple sur la manière d'utiliser la classe "
+"<classname>RecentChooserDialog</classname> dans un programme. Ce programme "
+"élémentaire a une barre de menus avec un élément de menu « Boîte de dialogue "
+"fichiers récents ». Quand vous choisissez cet élément de menu, une boîte "
+"apparaît : elle affiche les fichiers récemment utilisés."
+
+#: C/gtkmm-tutorial-in.xml:5502(para)
+msgid ""
+"If this is the first time you're using a program that uses the Recent Files "
+"framework, the dialog may be empty at first. Otherwise it should show the "
+"list of recently used documents registered by other applications."
+msgstr ""
+"� la première utilisation d'un programme se servant de la structure des "
+"Fichiers récents, la boîte de dialogue peut initialement être vide. Sinon, "
+"elle devrait afficher la liste des documents récemment utilisés enregistrés "
+"par d'autres applications."
+
+#: C/gtkmm-tutorial-in.xml:5509(para)
+msgid ""
+"After selecting the <guimenuitem>Recent Files Dialog</guimenuitem> menu "
+"item, you should see something similar to the following window."
+msgstr ""
+"Après avoir sélectionné l'élément de menu <guimenuitem>Boîte de dialogue "
+"fichiers récents</guimenuitem>, vous voyez quelque chose de semblable à la "
+"fenêtre ci-après."
+
+#: C/gtkmm-tutorial-in.xml:5518(para)
+msgid ""
+"The constructor for <classname>ExampleWindow</classname> creates the menu "
+"using <classname>UIManager</classname> (see <xref linkend=\"chapter-menus-"
+"and-toolbars\"/> for more information). It then adds the menu and the "
+"toolbar to the window."
+msgstr ""
+"Le constructeur de <classname>ExampleWindow</classname> crée le menu en "
+"utilisant <classname>UIManager</classname> (consultez le <xref linkend="
+"\"chapter-menus-and-toolbars\"/> pour plus d'informations). Ensuite il "
+"ajoute le menu et la barre d'outils à la fenêtre."
+
+#: C/gtkmm-tutorial-in.xml:5526(title)
+msgid "Filtering Recent Files"
+msgstr "Filtrage des fichiers récents"
+
+#: C/gtkmm-tutorial-in.xml:5527(para)
+msgid ""
+"For any of the <classname>RecentChooser</classname> classes, if you don't "
+"wish to display all of the items in the list of recent files, you can filter "
+"the list to show only those that you want. You can filter the list with the "
+"help of the <classname>RecentFilter</classname> class. This class allows you "
+"to filter recent files by their name (<methodname>add_pattern()</"
+"methodname>), their mime type (<methodname>add_mime_type()</methodname>), "
+"the application that registered them (<methodname>add_application()</"
+"methodname>), or by a custom filter function (<methodname>add_custom()</"
+"methodname>). It also provides the ability to filter based on how long ago "
+"the file was modified and which groups it belongs to."
+msgstr ""
+"Pour chacune des classes <classname>RecentChooser</classname>, si vous ne "
+"souhaitez pas afficher tous les éléments de la liste des fichiers récents, "
+"vous pouvez filtrer la liste pour ne montrer que ce que vous souhaitez. Vous "
+"pouvez filtrer la liste avec l'aide de la classe <classname>RecentFilter</"
+"classname>. Cette classe vous permet de filtrer les fichiers par le nom "
+"(<methodname>add_pattern()</methodname>), leur type MIME "
+"(<methodname>add_mime_type()</methodname>), l'application qui les a "
+"enregistrés (<methodname>add_application()</methodname>) ou par une fonction "
+"de filtrage personnalisée (<methodname>add_custom()</methodname>). Elle "
+"offre aussi la possibilité de filtrer sur la date de dernière modification "
+"et sur les groupes dont le fichier fait partie."
+
+#: C/gtkmm-tutorial-in.xml:5540(para)
+msgid ""
+"After you've created and set up the filter to match only the items you want, "
+"you can apply a filter to a chooser widget with the "
+"<methodname>RecentChooser::add_filter()</methodname> function."
+msgstr ""
+"Après avoir créé et réglé le filtre pour qu'il corresponde uniquement aux "
+"fichiers souhaités, vous pouvez appliquer le filtre à l'élément graphique de "
+"sélection avec la fonction <methodname>RecentChooser::add_filter()</"
+"methodname>."
+
+#: C/gtkmm-tutorial-in.xml:5550(title)
+msgid "Plugs and Sockets"
+msgstr "Greffons et connecteurs"
+
+#: C/gtkmm-tutorial-in.xml:5552(title)
+msgid "Overview"
+msgstr "Aperçu"
+
+#: C/gtkmm-tutorial-in.xml:5553(para)
+msgid ""
+"From time to time, it may be useful to be able to embed a widget from "
+"another application within your application. <application>gtkmm</"
+"application> allows you to do this with the <classname>Gtk::Socket</"
+"classname> and <classname>Gtk::Plug</classname> classes. It is not "
+"anticipated that very many applications will need this functionality, but in "
+"the rare case that you need to display a widget that is running in a "
+"completely different process, these classes can be very helpful."
+msgstr ""
+"Parfois, il peut se révéler utile de pouvoir incorporer un élément graphique "
+"d'une autre application dans votre propre application. <application>gtkmm</"
+"application> permet cela grâce aux classes <classname>Gtk::Socket</"
+"classname> et <classname>Gtk::Plug</classname>. Il est peu vraisemblable que "
+"beaucoup d'applications aient besoin de cette fonctionnalité, mais dans les "
+"rares cas où vous auriez besoin d'afficher un élément graphique fonctionnant "
+"dans un processus tout à fait différent, ces classes peuvent être d'une "
+"grande aide."
+
+#: C/gtkmm-tutorial-in.xml:5562(para)
+msgid ""
+"The communication between a <classname>Socket</classname> and a "
+"<classname>Plug</classname> follows the XEmbed protocol. This protocol has "
+"also been implemented in other toolkits (e.g. Qt), which allows the same "
+"level of integration when embedding a Qt widget in GTK+ or vice versa."
+msgstr ""
+"La communication entre un objet <classname>Socket</classname> et un objet "
+"<classname>Plug</classname> s'effectue suivant le protocole XEmbed. Ce "
+"protocole a aussi été implémenté dans d'autres boîtes à outils (par exemple, "
+"Qt) ; cela permet un niveau d'intégration identique lorsqu'on incorpore un "
+"élément graphique Qt dans GTK+ ou vice versa."
+
+#: C/gtkmm-tutorial-in.xml:5568(para)
+msgid ""
+"The way that <classname>Sockets</classname> and <classname>Plugs</classname> "
+"work together is through their window ids. Both a <classname>Socket</"
+"classname> and a <classname>Plug</classname> have IDs that can be retrieved "
+"with their <methodname>get_id()</methodname> member functions. The use of "
+"these IDs will be explained below in <xref linkend=\"sec-connecting-plugs-"
+"sockets\"/>."
+msgstr ""
+"Les <classname>Sockets</classname> et <classname>Plugs</classname> "
+"collaborent par l'intermédiaire des identifiants de leurs fenêtres. Un objet "
+"<classname>Socket</classname> et un objet <classname>Plug</classname> ont "
+"tous deux des ID que l'on peut retrouver avec leurs fonctions membres "
+"<methodname>get_id()</methodname>. L'utilisation de ces ID sera explicitée "
+"plus bas dans la <xref linkend=\"sec-connecting-plugs-sockets\"/>."
+
+#: C/gtkmm-tutorial-in.xml:5577(title)
+msgid "Sockets"
+msgstr "Connecteurs"
+
+#: C/gtkmm-tutorial-in.xml:5578(para)
+msgid ""
+"A <classname>Socket</classname> is a special kind of container widget that "
+"provides the ability to embed widgets from one process into another process "
+"in a way that is transparent to the user."
+msgstr ""
+"Un objet <classname>Socket</classname> est une sorte d'élément graphique "
+"conteneur spécial qui autorise la possibilité d'incorporer des éléments "
+"graphiques d'un processus dans un autre de manière totalement transparente "
+"pour l'utilisateur."
+
+#: C/gtkmm-tutorial-in.xml:5585(title)
+msgid "Plugs"
+msgstr "Greffons"
+
+#: C/gtkmm-tutorial-in.xml:5586(para)
+msgid ""
+"A <classname>Plug</classname> is a special kind of Window that can be "
+"plugged into a <classname>Socket</classname>. Besides the normal properties "
+"and methods of <classname>Gtk::Window</classname>, a <classname>Plug</"
+"classname> provides a constructor that takes the ID of a <classname>Socket</"
+"classname>, which will automatically embed the <classname>Plug</classname> "
+"into the <classname>Socket</classname> that matches that ID."
+msgstr ""
+"Un objet <classname>Plug</classname> est une variété de fenêtre particulière "
+"qu'il est possible de greffer dans un objet <classname>Socket</classname>. "
+"Outre les propriétés et les fonctions membres habituelles de la classe "
+"<classname>Gtk::Window</classname>, l'objet <classname>Plug</classname> "
+"fournit un constructeur qui prend comme paramètre l'ID d'un objet "
+"<classname>Socket</classname>Â ; l'objet <classname>Plug</classname> va "
+"automatiquement s'incorporer dans l'objet <classname>Socket</classname> qui "
+"a l'ID correspondant."
+
+#: C/gtkmm-tutorial-in.xml:5595(para)
+msgid ""
+"Since a <classname>Plug</classname> is just a special type of "
+"<classname>Gtk::Window</classname> class, you can add containers or widgets "
+"to it like you would to any other window."
+msgstr ""
+"Comme un objet <classname>Plug</classname> n'est qu'un type spécial de "
+"classe <classname>Gtk::Window</classname>, vous pouvez lui ajouter des "
+"conteneurs ou des éléments graphiques exactement comme vous auriez fait pour "
+"une autre fenêtre."
+
+#: C/gtkmm-tutorial-in.xml:5602(title)
+msgid "Connecting Plugs and Sockets"
+msgstr "Branchement des greffons et des connecteurs"
+
+#: C/gtkmm-tutorial-in.xml:5603(para)
+msgid ""
+"After a <classname>Socket</classname> or <classname>Plug</classname> object "
+"is realized, you can obtain its ID with its <methodname>get_id()</"
+"methodname> function. This ID can then be shared with other processes so "
+"that other processes know how to connect to eachother."
+msgstr ""
+"Après la création d'objets <classname>Socket</classname> ou <classname>Plug</"
+"classname>, vous pouvez obtenir leur ID avec la fonction <methodname>get_id()"
+"</methodname>. Cet ID peut ensuite être partagé avec d'autres processus afin "
+"que ces processus sachent comment se connecter les uns aux autres."
+
+#: C/gtkmm-tutorial-in.xml:5614(para)
+msgid ""
+"Create a <classname>Socket</classname> object in one process and pass the ID "
+"of that <classname>Socket</classname> to another process so that it can "
+"create a <classname>Plug</classname> object by specifying the given "
+"<classname>Socket</classname> ID in its constructor. There is no way to "
+"assign a <classname>Plug</classname> to a particular <classname>Socket</"
+"classname> after creation, so you must pass the <classname>Socket</"
+"classname> ID to the <classname>Plug</classname>'s constructor."
+msgstr ""
+"créer un objet <classname>Socket</classname> dans un processus et passer "
+"l'ID de ce <classname>Socket</classname> Ã un autre processus pour qu'il "
+"puisse créer un objet <classname>Plug</classname> en précisant ledit ID du "
+"<classname>Socket</classname> dans son constructeur. Il n'est pas possible "
+"d'attribuer un <classname>Plug</classname> Ã un <classname>Socket</"
+"classname> après sa création, il faut donc transmettre l'ID du "
+"<classname>Socket</classname> au constructeur du <classname>Plug</classname>."
+
+#: C/gtkmm-tutorial-in.xml:5627(para)
+msgid ""
+"Create a <classname>Plug</classname> independantly from any particular "
+"<classname>Socket</classname> and pass the ID of the <classname>Plug</"
+"classname> to other processes that need to use it. The ID of the "
+"<classname>Plug</classname> can be associated with a particular "
+"<classname>Socket</classname> object using the <methodname>Socket::add_id()</"
+"methodname> function. This is the approach used in the example below."
+msgstr ""
+"créer un objet <classname>Plug</classname> de manière indépendante de tout "
+"<classname>Socket</classname> particulier et passer l'ID du <classname>Plug</"
+"classname> aux processus qui souhaitent l'utiliser. L'ID de l'objet "
+"<classname>Plug</classname> peut être associé à un objet <classname>Socket</"
+"classname> donné avec la fonction <methodname>Socket::add_id()</methodname>. "
+"C'est l'approche utilisée dans l'exemple qui suit."
+
+#: C/gtkmm-tutorial-in.xml:5610(para)
+msgid "There are two basic strategies that can be used: <placeholder-1/>"
+msgstr "Il y a deux stratégies de base utilisables : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5642(title)
+msgid "Plugs and Sockets Example"
+msgstr "Exemple greffons et connecteurs"
+
+#: C/gtkmm-tutorial-in.xml:5643(para)
+msgid ""
+"The following is a simple example of using sockets and plugs. The method of "
+"communication between processes is deliberately kept very simple: The "
+"<classname>Plug</classname> writes its ID out to a text file named "
+"<filename>plug.id</filename> and the process with the socket reads the ID "
+"from this files. In a real program, you may want to use a more sophisticated "
+"method of inter-process communication."
+msgstr ""
+"L'exemple suivant est une utilisation simple de greffons et connecteurs. La "
+"fonction membre de communication entre processus est volontairement "
+"sommaire : l'objet <classname>Plug</classname> écrit son ID dans un fichier "
+"texte nommé <filename>plug.id</filename> et le processus avec le connecteur "
+"lit cet ID à partir de ce fichier. Dans un « vrai » programme, vous "
+"utiliseriez certainement des fonctions membres de communication entre "
+"processus plus perfectionnées."
+
+#: C/gtkmm-tutorial-in.xml:5652(para)
+msgid ""
+"This example creates two executable programs: <filename>socket</filename> "
+"and <filename>plug</filename>. The idea is that <filename>socket</filename> "
+"has an application window that will embed a widget from the <filename>plug</"
+"filename> program. The way this example is designed, <filename>plug</"
+"filename> must be running first before starting <filename>socket</filename>. "
+"To see the example in action, execute the following commands in order from "
+"within the example directory:"
+msgstr ""
+"Cet exemple crée deux exécutables : <filename>socket</filename> et "
+"<filename>plug</filename>. L'idée est que <filename>socket</filename> ait "
+"une fenêtre d'application qui accueille un élément graphique issu du "
+"programme <filename>plug</filename>. Compte tenu de la manière dont cet "
+"exemple est conçu, <filename>plug</filename> doit être lancé avant que "
+"<filename>socket</filename> ne démarre. Pour voir cet exemple en action, "
+"exécutez les commandes suivantes dans l'ordre indiqué à partir du répertoire "
+"de l'exemple :"
+
+#: C/gtkmm-tutorial-in.xml:5661(para)
+msgid ""
+"Start the <filename>plug</filename> program and send it to the background "
+"(or just use a different terminal)."
+msgstr ""
+"Lancez le programme <filename>plug</filename> et envoyez-le en arrière-plan "
+"(ou simplement utilisez un terminal différent) :"
+
+#: C/gtkmm-tutorial-in.xml:5665(screen)
+#, no-wrap
+msgid "$ ./plug &"
+msgstr "$ ./plug &"
+
+#: C/gtkmm-tutorial-in.xml:5666(para)
+msgid "After which you should see something like the following:"
+msgstr "Après cette action, vous devriez voir s'afficher :"
+
+#: C/gtkmm-tutorial-in.xml:5669(screen)
+#, no-wrap
+msgid "The window ID is: 69206019"
+msgstr "The window ID is: 69206019"
+
+#: C/gtkmm-tutorial-in.xml:5670(para)
+msgid "Then start the <filename>socket</filename> program:"
+msgstr "puis lancez le programme <filename>socket</filename>Â :"
+
+#: C/gtkmm-tutorial-in.xml:5671(screen)
+#, no-wrap
+msgid "$ ./socket"
+msgstr "$ ./socket"
+
+#: C/gtkmm-tutorial-in.xml:5672(para)
+msgid ""
+"After starting <filename>socket</filename>, you should see the following "
+"output in the terminal:"
+msgstr ""
+"Après avoir lancé <filename>socket</filename>, vous devriez voir les sorties "
+"suivantes sur le terminal :"
+
+#: C/gtkmm-tutorial-in.xml:5676(screen)
+#, no-wrap
+msgid ""
+"I've been embedded.\n"
+"A plug was added"
+msgstr ""
+"I've been embedded.\n"
+"A plug was added"
+
+#: C/gtkmm-tutorial-in.xml:5678(para)
+msgid ""
+"The first line of output is from <filename>plug</filename>, after it has "
+"been notified that it has been embedded inside of a <classname>Socket</"
+"classname>. The second line was emitted by <filename>socket</filename> in "
+"response to its <methodname>plug_added</methodname> signal. If everything "
+"was done as described above, the <filename>socket</filename> window should "
+"look roughly like the following:"
+msgstr ""
+"La première ligne correspond à la sortie du programme <filename>plug</"
+"filename>, après qu'il a reçu notification qu'il a été incorporé dans "
+"l'objet <classname>Socket</classname>. La deuxième ligne a été émise par "
+"l'objet <filename>socket</filename> en réponse au signal "
+"<methodname>plug_added</methodname>. Si tout a été effectuée comme indiqué "
+"ci-dessus, la fenêtre <filename>socket</filename> doit ressembler grosso "
+"modo à quelque chose comme :"
+
+#: C/gtkmm-tutorial-in.xml:5690(para)
+msgid ""
+"If for some reason the <classname>Socket</classname> couldn't attach the "
+"<classname>Plug</classname>, the window would look something like this:"
+msgstr ""
+"Si, pour une quelconque raison, l'objet <classname>Socket</classname> ne "
+"peut pas recevoir l'objet <classname>Plug</classname>, la fenêtre "
+"ressemblera à  :"
+
+#: C/gtkmm-tutorial-in.xml:5701(title)
+msgid "Timeouts, I/O and Idle Functions"
+msgstr "Fonctions à délai échu, d'entrées/sorties et de temporisation"
+
+#: C/gtkmm-tutorial-in.xml:5704(title)
+msgid "Timeouts"
+msgstr "Fonctions à délai échu"
+
+#: C/gtkmm-tutorial-in.xml:5706(para)
+msgid ""
+"You may be wondering how to make <application>gtkmm</application> do useful "
+"work while it's idling along (well, sleeping actually) in <methodname>Gtk::"
+"Main::run()</methodname>. Happily, you have several options. Using the "
+"following methods you can create a timeout method that will be called every "
+"few milliseconds."
+msgstr ""
+"Peut-être vous demandez-vous comment faire en sorte que <application>gtkmm</"
+"application> fasse un travail utile pendant sa période d'inactivité (disons, "
+"de sommeil en fait) dans la boucle <methodname>Gtk::Main::run()</"
+"methodname>. Il y a heureusement plusieurs possibilités pour cela. En "
+"utilisant les fonctions membres suivantes, vous pouvez créer une fonction à "
+"délai échu ; elle sera régulièrement appelée avec une périodicité de "
+"quelques millisecondes."
+
+#: C/gtkmm-tutorial-in.xml:5714(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"sigc::connection Glib::SignalTimeout::connect(const sigc::slot<bool>& slot, unsigned int interval, int priority = Glib::PRIORITY_DEFAULT);\n"
+msgstr ""
+"\n"
+"sigc::connection Glib::SignalTimeout::connect(\n"
+" const sigc::slot<bool>& slot,\n"
+" unsigned int interval,\n"
+" int priority = Glib::PRIORITY_DEFAULT);\n"
+
+#: C/gtkmm-tutorial-in.xml:5719(para)
+msgid ""
+"The first argument is a <classname>slot</classname> you wish to have called "
+"when the timeout occurs. The second argument is the number of milliseconds "
+"between calls to that method. You receive a <classname>sigc::connection</"
+"classname> object that can be used to deactivate the connection using its "
+"<methodname>disconnect()</methodname> method:"
+msgstr ""
+"Le premier paramètre est un objet <classname>slot</classname> appelé quand "
+"le délai est échu. Le deuxième argument est le nombre de millisecondes entre "
+"chaque appel de la fonction. Vous recevez en retour un objet "
+"<classname>sigc::connection</classname> qu'il est possible d'utiliser pour "
+"désactiver la connexion à l'aide de sa fonction membre <methodname>disconnect"
+"()</methodname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:5729(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"my_connection.disconnect();\n"
+msgstr ""
+"\n"
+"my_connection.disconnect();\n"
+
+#: C/gtkmm-tutorial-in.xml:5741(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"bool MyCallback() { std::cout << \"Hello World!\\n\" << std::endl; return true; }\n"
+msgstr ""
+"\n"
+"bool MyCallback() { std::cout << \"Hello World!\\n\" << std::endl; return true; }\n"
+
+#: C/gtkmm-tutorial-in.xml:5734(para)
+msgid ""
+"Another way of destroying the connection is your signal handler. It has to "
+"be of the type <classname>sigc::slot<bool></classname>. As you see "
+"from the definition your signal handler has to return a value of the type "
+"<literal>bool</literal>. A definition of a sample method might look like "
+"this: <placeholder-1/>"
+msgstr ""
+"L'autre façon d'interrompre la connexion est fournie par le gestionnaire de "
+"signal qui doit être du type <classname>sigc::slot<bool></classname>."
+"Comme vous le voyez dans la définition, le gestionnaire de signal doit "
+"renvoyer une valeur du type <literal>bool</literal>. Une définition d'une "
+"fonction exemple pourrait ressembler à quelque chose comme : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5747(para)
+msgid ""
+"You can stop the timeout method by returning <literal>false</literal> from "
+"your signal handler. Therefore, if you want your method to be called "
+"repeatedly, it should return <literal>true</literal>."
+msgstr ""
+"Vous pouvez arrêter l'appel périodique de la fonction en renvoyant "
+"<literal>false</literal> Ã partir du gestionnaire de signal. Mais si vous "
+"voulez que la fonction soit réitérée, il faut qu'elle renvoie <literal>true</"
+"literal>."
+
+#: C/gtkmm-tutorial-in.xml:5753(para)
+msgid "Here's an example of this technique:"
+msgstr "Voici un exemple de cette technique :"
+
+#: C/gtkmm-tutorial-in.xml:5762(title)
+msgid "Monitoring I/O"
+msgstr "Fonctions de contrôle des entrées/sorties"
+
+#: C/gtkmm-tutorial-in.xml:5764(para)
+msgid ""
+"A nifty feature of Glib (one of the libraries underlying <application>gtkmm</"
+"application>) is the ability to have it check for data on a file descriptor "
+"for you. This is especially useful for networking applications. The "
+"following method is used to do this:"
+msgstr ""
+"Une des caractéristiques intéressantes de GLib (une des bibliothèques sous-"
+"jacentes à <application>gtkmm</application>) est la possibilité de demander "
+"la vérification des données d'un descripteur de fichier à votre intention. "
+"La chose est particulièrement utile pour les applications réseau. Pour cette "
+"vérification, vous utilisez la fonction membre :"
+
+#: C/gtkmm-tutorial-in.xml:5772(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"sigc::connection Glib::SignalInput::connect(const sigc::slot<bool,Glib::IOCondition>& slot,\n"
+" int fd, Glib::IOCondition condition,\n"
+" int priority = Glib::PRIORITY_DEFAULT);\n"
+msgstr ""
+"\n"
+"sigc::connection Glib::SignalInput::connect(\n"
+" const sigc::slot<bool,Glib::IOCondition>& slot,\n"
+" int fd,\n"
+" Glib::IOCondition condition,\n"
+" int priority = Glib::PRIORITY_DEFAULT);\n"
+
+#: C/gtkmm-tutorial-in.xml:5779(para)
+msgid ""
+"The first argument is a slot you wish to have called when then the specified "
+"event (see argument 3) occurs on the file descriptor you specify using "
+"argument two. Argument three may be one or more (using <literal>|</literal>) "
+"of:"
+msgstr ""
+"Le premier paramètre est un connecteur qui est sollicité quand survient, sur "
+"le descripteur de fichier précisé en second paramètre, l'événement indiqué "
+"en troisième paramètre. Ce dernier définit une valeur ou plusieurs (liées "
+"avec <literal>|</literal>) parmi les suivantes :"
+
+#: C/gtkmm-tutorial-in.xml:5789(para)
+msgid ""
+"Glib::IO_IN - Call your method when there is data ready for reading on your "
+"file descriptor."
+msgstr ""
+"Glib::IO_IN - appelle la fonction membre quand il y a des données prêtes en "
+"lecture dans le descripteur de fichier."
+
+#: C/gtkmm-tutorial-in.xml:5797(para)
+msgid ""
+"Glib::IO_OUT - Call your method when the file descriptor is ready for "
+"writing."
+msgstr ""
+"Glib::IO_OUT - appelle la fonction membre quand le descripteur de fichier "
+"est prêt pour l'écriture."
+
+#: C/gtkmm-tutorial-in.xml:5805(para)
+msgid ""
+"Glib::IO_PRI - Call your method when the file descriptor has urgent data to "
+"be read."
+msgstr ""
+"Glib::IO_PRI - appelle la fonction membre quand le descripteur de fichier a "
+"des données à lire d'urgence."
+
+#: C/gtkmm-tutorial-in.xml:5812(para)
+msgid ""
+"Glib::IO_ERR - Call your method when an error has occurred on the file "
+"descriptor."
+msgstr ""
+"Glib::IO_ERR - appelle la fonction membre quand une erreur est arrivée sur "
+"le descripteur de fichier."
+
+#: C/gtkmm-tutorial-in.xml:5819(para)
+msgid ""
+"Glib::IO_HUP - Call your method when hung up (the connection has been broken "
+"usually for pipes and sockets)."
+msgstr ""
+"Glib::IO_HUP - appelle la fonction membre quand il y a une interruption (la "
+"connexion a été interrompue généralement pour les tubes et les connecteurs)."
+
+#: C/gtkmm-tutorial-in.xml:5826(para)
+msgid ""
+"The return value is a <classname>sigc::connection</classname> that may be "
+"used to stop monitoring this file descriptor using its <methodname>disconnect"
+"()</methodname> method. The <parameter>slot</parameter> signal handler "
+"should be declared as follows:"
+msgstr ""
+"La valeur de retour qui est du type <classname>sigc::connection</classname> "
+"peut être utilisée pour arrêter le contrôle sur ce descripteur de fichier "
+"avec la fonction membre <methodname>disconnect()</methodname>. Le "
+"gestionnaire de signal de <parameter>slot</parameter> doit être déclaré "
+"comme suit :"
+
+#: C/gtkmm-tutorial-in.xml:5833(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"bool input_callback(Glib::IOCondition condition);\n"
+msgstr ""
+"\n"
+"bool input_callback(Glib::IOCondition condition);\n"
+
+#: C/gtkmm-tutorial-in.xml:5838(para)
+msgid ""
+"where <parameter>condition</parameter> is as specified above. As usual the "
+"slot is created with <function>sigc::mem_fun()</function> (for a member "
+"method of an object.), or <function>sigc::ptr_fun()</function> (for a "
+"function)."
+msgstr ""
+"où le paramètre <parameter>condition</parameter> est tel que précisé ci-"
+"dessus. Comme d'habitude, le connecteur est créé avec <function>sigc::mem_fun"
+"()</function> (pour une fonction membre d'un objet) ou <function>sigc::"
+"ptr_fun()</function> (pour une fonction)."
+
+#: C/gtkmm-tutorial-in.xml:5845(para)
+msgid ""
+"A little example follows. To use the example just execute it from a "
+"terminal; it doesn't create a window. It will create a pipe named "
+"<literal>testfifo</literal> in the current directory. Then start another "
+"shell and execute <literal>echo \"Hello\" > testfifo</literal>. The "
+"example will print each line you enter until you execute <literal>echo \"Q\" "
+"> testfifo</literal>."
+msgstr ""
+"Un petit exemple suit. Pour vous servir de cet exemple, lancez-le à partir "
+"d'un terminal ; il ne crée pas de fenêtre. Il va créer un tube nommé "
+"<literal>testfifo</literal> dans le répertoire actuel. Puis, lancez un autre "
+"instance de terminal et saisissez <literal>echo \"Hello\" > testfifo</"
+"literal>. Le terminal de l'exemple affiche chaque ligne saisie dans l'autre "
+"instance jusqu'Ã ce que vous saisissiez <literal>echo \"Q\" > testfifo</"
+"literal>."
+
+#: C/gtkmm-tutorial-in.xml:5859(title)
+msgid "Idle Functions"
+msgstr "Fonctions de temporisation"
+
+#: C/gtkmm-tutorial-in.xml:5861(para)
+msgid ""
+"If you want to specify a method that gets called when nothing else is "
+"happening, use the following:"
+msgstr ""
+"Si vous voulez définir une fonction membre appelée quand il n'y aucune autre "
+"activité en cours, utilisez :"
+
+#: C/gtkmm-tutorial-in.xml:5866(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"sigc::connection Glib::SignalIdle::connect(const sigc::slot<bool>& slot, int priority = Glib::PRIORITY_DEFAULT_IDLE);\n"
+msgstr ""
+"\n"
+"sigc::connection Glib::SignalIdle::connect(\n"
+" const sigc::slot<bool>& slot,\n"
+" int priority = Glib::PRIORITY_DEFAULT_IDLE);\n"
+
+#: C/gtkmm-tutorial-in.xml:5871(para)
+msgid ""
+"This causes <application>gtkmm</application> to call the specified method "
+"whenever nothing else is happening. You can add a priority (lower numbers "
+"are higher priorities). There are two ways to remove the signal handler: "
+"calling <methodname>disconnect()</methodname> on the <classname>sigc::"
+"connection</classname> object, or returning <literal>false</literal> in the "
+"signal handler, which should be declared as follows:"
+msgstr ""
+"Cela demande à <application>gtkmm</application> d'appeler la fonction membre "
+"indiquée chaque fois qu'il ne se passe rien d'autre. Vous pouvez définir une "
+"priorité (les plus petits nombres correspondent aux priorités les plus "
+"élevées). Il y a deux manières de déconnecter le gestionnaire de signal : "
+"par l'appel de la fonction membre <methodname>disconnect()</methodname> sur "
+"l'objet <classname>sigc::connection</classname> ou en renvoyant "
+"<literal>false</literal> dans le gestionnaire du signal, qui doit être "
+"déclaré ainsi :"
+
+#: C/gtkmm-tutorial-in.xml:5881(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"bool idleFunc();\n"
+msgstr ""
+"\n"
+"bool idleFunc();\n"
+
+#: C/gtkmm-tutorial-in.xml:5886(para)
+msgid ""
+"Since this is very similar to the methods above this explanation should be "
+"sufficient to understand what's going on. However, here's a little example:"
+msgstr ""
+"Comme ceci est tout à fait semblable aux fonctions membres des paragraphes "
+"précédents, cette explication doit être suffisante pour comprendre comment "
+"cela se passe. Toutefois, voici un petit exemple :"
+
+#: C/gtkmm-tutorial-in.xml:5893(para)
+msgid ""
+"This example points out the difference of idle and timeout methods a little. "
+"If you need methods that are called periodically, and speed is not very "
+"important, then you want timeout methods. If you want methods that are "
+"called as often as possible (like calculating a fractal in background), then "
+"use idle methods."
+msgstr ""
+"Cet exemple souligne la différence entre fonctions membres de temporisation "
+"et fonctions membres à délai échu. Si vous avez besoin de fonctions appelées "
+"périodiquement et que la rapidité n'a pas grosse importance, alors servez-"
+"vous des fonctions membres à délai échu. Si vous voulez des fonctions "
+"membres appelées aussi souvent que possible (comme des fonctions membres de "
+"calcul de fractales en arrière-plan), alors utilisez les fonctions membres "
+"de temporisation."
+
+#: C/gtkmm-tutorial-in.xml:5901(para)
+msgid ""
+"Try executing the example and increasing the system load. The upper progress "
+"bar will increase steadily; the lower one will slow down."
+msgstr ""
+"Essayez d'exécuter l'exemple tout en augmentant la charge de votre système. "
+"La barre de progression supérieure doit avancer régulièrement ; l'inférieure "
+"devrait ralentir."
+
+#: C/gtkmm-tutorial-in.xml:5911(title)
+msgid "Memory management"
+msgstr "Gestion de la mémoire"
+
+#: C/gtkmm-tutorial-in.xml:5917(title)
+msgid "Normal C++ memory management"
+msgstr "Gestion classique de la mémoire en C++"
+
+#: C/gtkmm-tutorial-in.xml:5919(para)
+msgid ""
+"<application>gtkmm</application> allows the programmer to control the "
+"lifetime (that is, the construction and destruction) of any widget in the "
+"same manner as any other C++ object. This flexibility allows you to use "
+"<literal>new</literal> and <literal>delete</literal> to create and destroy "
+"objects dynamically or to use regular class members (that are destroyed "
+"automatically when the class is destroyed) or to use local instances (that "
+"are destroyed when the instance goes out of scope). This flexibility is not "
+"present in some C++ GUI toolkits, which restrict the programmer to only a "
+"subset of C++'s memory management features."
+msgstr ""
+"<application>gtkmm</application> autorise le programmeur à contrôler la "
+"durée de vie (c'est-à -dire, la construction et la destruction) de tout "
+"élément graphique de la même manière que celle de n'importe quel objet C++. "
+"Cette polyvalence autorise, soit l'utilisation des opérateurs <literal>new</"
+"literal> et <literal>delete</literal> pour créer et détruire les objets de "
+"manière dynamique, soit l'utilisation de données membres de classes "
+"régulières (qui sont détruites automatiquement quand la classe est "
+"détruite), soit l'utilisation d'instances locales (qui sont détruites dès "
+"que l'instance est hors de portée). Certaines boîtes à outils "
+"GUI C++ n'offrent pas cette souplesse : elles restreignent le programmeur à "
+"un sous-ensemble des fonctionnalités de gestion mémoire du C++."
+
+#: C/gtkmm-tutorial-in.xml:5931(para)
+msgid "Here are some examples of normal C++ memory management:"
+msgstr ""
+"Voici quelques exemples de gestion traditionnelle de la mémoire en C++ :"
+
+#: C/gtkmm-tutorial-in.xml:5934(title)
+msgid "Class Scope widgets"
+msgstr "�léments graphiques à portée de classe"
+
+#: C/gtkmm-tutorial-in.xml:5936(para)
+msgid ""
+"If a programmer does not need dynamic memory allocation, automatic widgets "
+"in class scope may be used. One advantage of automatic widgets in class "
+"scope is that memory management is grouped in one place. The programmer does "
+"not risk memory leaks from failing to <literal>delete</literal> a widget."
+msgstr ""
+"Si un programmeur n'a pas besoin d'allocation dynamique de mémoire, il peut "
+"se servir d'éléments graphiques automatiques à portée de classe. Un des "
+"avantages des éléments graphiques automatiques à portée de classe est que la "
+"gestion de la mémoire est regroupée en un seul endroit. Le programmeur ne "
+"risque pas de fuites de mémoire en oubliant un <literal>delete</literal> sur "
+"un élément graphique."
+
+#: C/gtkmm-tutorial-in.xml:5943(para)
+msgid ""
+"The primary disadvantages of using class scope widgets are revealing the "
+"class implementation rather than the class interface in the class header. "
+"Class scope widgets also require Automatic widgets in class scope suffer the "
+"same disadvantages as any other class scope automatic variable."
+msgstr ""
+"Les principaux inconvénients proviennent du fait que l'utilisation "
+"d'éléments graphiques à portée de classe sont en rapport avec "
+"l'implémentation de la classe plus que de son interfaçage dans l'en-tête de "
+"classe. Les éléments graphiques à portée de classe sont créés "
+"automatiquement et souffrent des mêmes inconvénients que n'importe quelle "
+"autre variable automatique à portée de classe."
+
+#: C/gtkmm-tutorial-in.xml:5951(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"#include <gtkmm/button.h>\n"
+"class Foo\n"
+"{\n"
+"private:\n"
+" Gtk::Button theButton;\n"
+" // will be destroyed when the Foo object is destroyed\n"
+"};\n"
+msgstr ""
+"\n"
+"#include <gtkmm/button.h>\n"
+"class Foo\n"
+"{\n"
+"private:\n"
+" Gtk::Button theButton;\n"
+" // sera détruit en même temps que l'objet Foo\n"
+"};\n"
+
+#: C/gtkmm-tutorial-in.xml:5964(title)
+msgid "Function scope widgets"
+msgstr "�léments graphiques à portée de fonction"
+
+#: C/gtkmm-tutorial-in.xml:5972(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"{\n"
+" Gtk::Button aButton;\n"
+" aButton.show();\n"
+" ...\n"
+" kit.run();\n"
+"}\n"
+msgstr ""
+"\n"
+"{\n"
+" Gtk::Button aButton;\n"
+" aButton.show();\n"
+" ...\n"
+" kit.run();\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:5966(para)
+msgid ""
+"If a programmer does not need a class scope widget, a function scope widget "
+"may also be used. The advantages to function scope over class scope are the "
+"increased data hiding and reduced dependencies. <placeholder-1/>"
+msgstr ""
+"Si un programmeur ne souhaite pas utiliser d'élément graphique à portée de "
+"classe, il peut aussi se servir d'éléments graphiques à portée de fonction. "
+"Les avantages de la portée de fonction par rapport à la portée de classe "
+"sont un masquage accru des données et une réduction des dépendances. "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:5984(title)
+msgid "Dynamic allocation with new and delete"
+msgstr "Allocation dynamique avec new et delete"
+
+#: C/gtkmm-tutorial-in.xml:5986(para)
+msgid ""
+"Although, in most cases, the programmer will prefer to allow containers to "
+"automatically destroy their children using <function>manage()</function> "
+"(see below), the programmer is not required to use <function>manage()</"
+"function>. The traditional <literal>new</literal> and <literal>delete</"
+"literal> operators may also be used."
+msgstr ""
+"Même si, dans la plupart des cas, le programmeur préfére allouer des "
+"conteneurs pour détruire automatiquement leur contenu avec la fonction "
+"<function>manage()</function> (voir ci-dessous), l'utilisation de cette "
+"fonction n'est pas obligatoire. Les opérateurs traditionnels <literal>new</"
+"literal> et <literal>delete</literal> peuvent également être utilisés."
+
+#: C/gtkmm-tutorial-in.xml:5996(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Gtk::Button* pButton = new Gtk::Button(\"Test\");\n"
+"\n"
+"// do something useful with pButton\n"
+"\n"
+"delete pButton;\n"
+msgstr ""
+"\n"
+"Gtk::Button* pButton = new Gtk::Button(\"Test\");\n"
+"\n"
+"// faire quelque chose d'utile avec pButton\n"
+"\n"
+"delete pButton;\n"
+
+#: C/gtkmm-tutorial-in.xml:5994(para)
+msgid ""
+"<placeholder-1/> Here, the programmer deletes pButton to prevent a memory "
+"leak."
+msgstr ""
+"<placeholder-1/> Ici, le programmeur détruit pButton pour prévenir une fuite "
+"de mémoire."
+
+#: C/gtkmm-tutorial-in.xml:6011(title)
+msgid "Managed Widgets"
+msgstr "�léments graphiques gérés"
+
+#: C/gtkmm-tutorial-in.xml:6013(para)
+msgid ""
+"Alternatively, you can let a widget's container control when the widget is "
+"destroyed. In most cases, you want a widget to last only as long as the "
+"container it is in. To delegate the management of a widget's lifetime to its "
+"container, first create it with <function>manage()</function> and pack it "
+"into its container with <methodname>add()</methodname>. Now, the widget will "
+"be destroyed whenever its container is destroyed."
+msgstr ""
+"Sinon, vous pouvez confier au conteneur d'élément graphique le contrôle du "
+"moment où il sera détruit. Dans la plupart des cas, vous voulez qu'un "
+"élément graphique dure aussi longtemps que son conteneur. Pour déléguer la "
+"gestion de la durée de vie d'un élément graphique à son conteneur, créez-le "
+"avec <function>manage()</function> et empaquetez-le dans son conteneur avec "
+"<methodname>add()</methodname>. Ainsi, l'élément graphique sera détruit au "
+"moment où son conteneur sera détruit."
+
+#: C/gtkmm-tutorial-in.xml:6023(title)
+msgid "Dynamic allocation with manage() and add()"
+msgstr "Allocation dynamique avec manage() et add()"
+
+#: C/gtkmm-tutorial-in.xml:6025(para)
+msgid ""
+"<application>gtkmm</application> provides the <function>manage()</function> "
+"function and <methodname>add()</methodname> methods to create and destroy "
+"widgets. Every widget except a top-level window must be added or packed into "
+"a container in order to be displayed. The <function>manage()</function> "
+"function marks a packed widget so that when the widget is added to a "
+"container, the container becomes responsible for deleting the widget."
+msgstr ""
+"<application>gtkmm</application> met à votre disposition les fonctions "
+"<function>manage()</function> et <methodname>add()</methodname> pour créer "
+"et détruire les éléments graphiques. Tout élément graphique, excepté la "
+"fenêtre principale, doit être ajouté ou empaqueté dans un conteneur pour "
+"être affiché. La fonction <function>manage()</function> marque l'élément "
+"graphique empaqueté de sorte que, lorsqu'il est ajouté dans un conteneur, ce "
+"conteneur devient responsable de sa destruction."
+
+#: C/gtkmm-tutorial-in.xml:6035(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"MyWidget::MyWidget()\n"
+"{\n"
+" Gtk::Button* pButton = manage(new Gtk::Button(\"Test\"));\n"
+" add(*pButton); //add aButton to MyWidget\n"
+"}\n"
+msgstr ""
+"\n"
+"MyWidget::MyWidget()\n"
+"{\n"
+" Gtk::Button* pButton = manage(new Gtk::Button(\"Test\"));\n"
+" add(*pButton); //ajoute aButton à MyWidget\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:6034(para)
+msgid ""
+"<placeholder-1/> Now, when objects of type <classname>MyWidget</classname> "
+"are destroyed, the button will also be deleted. It is no longer necessary to "
+"delete pButton to free the button's memory; its deletion has been delegated "
+"to the <classname>MyWidget</classname> object."
+msgstr ""
+"<placeholder-1/> Ainsi, quand des objets du type <classname>MyWidget</"
+"classname> sont détruits, le bouton est également détruit. Il n'est plus "
+"nécessaire à l'avenir de détruire pButton pour libérer la mémoire occupée "
+"par le bouton ; cette opération a été déléguée à l'objet "
+"<classname>MyWidget</classname>."
+
+#: C/gtkmm-tutorial-in.xml:6049(para)
+msgid ""
+"<application>gtkmm</application> also provides the <methodname>set_manage()</"
+"methodname> method for all widgets. This can be used to generate the same "
+"result as <function>manage()</function>, but is more tedious:"
+msgstr ""
+"<application>gtkmm</application> fournit également la fonction membre "
+"<methodname>set_manage()</methodname> pour tous les éléments graphiques. Il "
+"est possible de l'utiliser pour obtenir le même résultat qu'avec "
+"<function>manage()</function>, mais c'est plus délicat :"
+
+#: C/gtkmm-tutorial-in.xml:6055(para)
+msgid "foo.add( (w=new Gtk::Label(\"Hello\"), w->set_manage(), &w) );"
+msgstr "foo.add( (w=new Gtk::Label(\"Hello\"), w->set_manage(), &w) );"
+
+#: C/gtkmm-tutorial-in.xml:6059(para)
+msgid "is the same as"
+msgstr "est équivalent à "
+
+#: C/gtkmm-tutorial-in.xml:6063(para)
+msgid "foo.add( manage(new Gtk::Label(\"Hello\")) );"
+msgstr "foo.add( manage(new Gtk::Label(\"Hello\")) );"
+
+#: C/gtkmm-tutorial-in.xml:6067(para)
+msgid ""
+"Of course, a top level container will not be added to another container. The "
+"programmer is responsible for destroying the top level container using one "
+"of the traditional C++ techniques. For instance, your top-level Window might "
+"just be an instance in your <function>main()</function> function.."
+msgstr ""
+"Bien entendu, le conteneur de haut niveau n'est pas intégré dans un autre "
+"conteneur. Le programmeur est responsable de la destruction du conteneur de "
+"haut niveau en utilisant les techniques habituelles du C++. Ainsi, votre "
+"fenêtre principale ne peut être qu'une instance dans votre fonction "
+"<function>main()</function>."
+
+#: C/gtkmm-tutorial-in.xml:6079(title)
+msgid "Shared resources"
+msgstr "Ressources partagées"
+
+#: C/gtkmm-tutorial-in.xml:6081(para)
+msgid ""
+"Some objects, such as <classname>Gdk::Pixmap</classname>s and "
+"<classname>Pango::Font</classname>s, are obtained from a shared store. "
+"Therefore you cannot instantiate your own instances. These classes typically "
+"inherit from <classname>Glib::Object</classname>. Rather than requiring you "
+"to reference and unreference these objects, <application>gtkmm</application> "
+"uses the <classname>RefPtr<></classname> smartpointer."
+msgstr ""
+"Certains objets, tels que les <classname>Gdk::Pixmap</classname> et "
+"<classname>Pango::Font</classname>, s'obtiennent à partir d'un stockage "
+"partagé. Ainsi, vous ne pouvez pas créer vos propres exemplaires de ces "
+"classes. Elles héritent généralement de <classname>Glib::Object</classname>. "
+"Plutôt que vous demander de référencer et déréférencer ces objets, "
+"<application>gtkmm</application> utilise le « pointeur intelligent » "
+"<classname>RefPtr<></classname>."
+
+#: C/gtkmm-tutorial-in.xml:6093(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> bitmap = Gdk::Bitmap::create(window, data, width, height);\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> bitmap = Gdk::Bitmap::create(window, data, width, height);\n"
+
+#: C/gtkmm-tutorial-in.xml:6090(para)
+msgid ""
+"Objects such as <classname>Gdk::Bitmap</classname> can only be instantiated "
+"with a <methodname>create()</methodname> function. For instance, "
+"<placeholder-1/>"
+msgstr ""
+"Les objets du type <classname>Gdk::Bitmap</classname> ne peuvent être "
+"instanciés qu'avec la fonction <methodname>create()</methodname>. Par "
+"exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6102(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"if(bitmap)\n"
+"{\n"
+" int depth = bitmap->get_depth().\n"
+"}\n"
+msgstr ""
+"\n"
+"if(bitmap)\n"
+"{\n"
+" int depth = bitmap->get_depth().\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:6098(para)
+msgid ""
+"You have no way of getting a bare <classname>Gdk::Bitmap</classname>. In the "
+"example, <varname>bitmap</varname> is a smart pointer, so you can do this, "
+"much like a normal pointer: <placeholder-1/>"
+msgstr ""
+"Il n'y a pas de moyen d'obtenir un objet <classname>Gdk::Bitmap</classname> "
+"vide. Dans l'exemple, <varname>bitmap</varname> est un pointeur intelligent, "
+"vous pouvez donc faire ceci, tout comme avec un pointeur normal : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6110(para)
+msgid ""
+"When <varname>bitmap</varname> goes out of scope an <methodname>unref()</"
+"methodname> will happen in the background and you don't need to worry about "
+"it anymore. There's no <literal>new</literal> so there's no <literal>delete</"
+"literal>."
+msgstr ""
+"Quand le <varname>bitmap</varname> est hors de portée, une "
+"fonction <methodname>unref()</methodname> se produit en arrière-plan et vous "
+"n'avez pas besoin de vous en soucier plus longtemps. Il n'y a pas "
+"d'opérateur <literal>new</literal>, il n'est donc pas nécessaire d'appeler "
+"<literal>delete</literal>."
+
+#: C/gtkmm-tutorial-in.xml:6118(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> bitmap2 = bitmap.\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> bitmap2 = bitmap.\n"
+
+#: C/gtkmm-tutorial-in.xml:6116(para)
+msgid ""
+"If you copy a <classname>RefPtr</classname>, for instance <placeholder-1/> , "
+"or if you pass it as a method argument or a return type, then "
+"<classname>RefPtr</classname> will do any necessary referencing to ensure "
+"that the instance will not be destroyed until the last <classname>RefPtr</"
+"classname> has gone out of scope."
+msgstr ""
+"Si vous copiez un <classname>RefPtr</classname>, par exemple <placeholder-1/"
+"> ou si vous le passez en tant que paramètre de fonction ou en tant que type "
+"de retour, alors le pointeur <classname>RefPtr</classname> fera tout "
+"référencement nécessaire pour assurer que cette instance ne soit pas "
+"détruite avant que le <classname>RefPtr</classname> ne soit pas hors de "
+"portée."
+
+#: C/gtkmm-tutorial-in.xml:6126(para)
+msgid ""
+"See the <link linkend=\"chapter-refptr\">appendix</link> for detailed "
+"information about RefPtr."
+msgstr ""
+"Consultez cette <link linkend=\"chapter-refptr\">annexe</link> pour une "
+"information détaillée concernant les RefPtr."
+
+#: C/gtkmm-tutorial-in.xml:6131(para)
+msgid "Bjarne Stroustrup, \"The C++ Programming Language\" - section 14.4.2"
+msgstr "Bjarne Stroustrup, « The C++ Programming Language » - chapitre 14.4.2"
+
+#: C/gtkmm-tutorial-in.xml:6134(para)
+msgid "Nicolai M. Josuttis, \"The C++ Standard Library\" - section 4.2"
+msgstr "Nicolai M. Josuttis, « The C++ Standard Library » - chapitre 4.2"
+
+#: C/gtkmm-tutorial-in.xml:6127(para)
+msgid ""
+"If you wish to learn more about smartpointers, you might look in these "
+"books: <placeholder-1/>"
+msgstr ""
+"Si vous voulez en savoir plus à propos des pointeurs intelligents, vous "
+"pouvez consulter les ouvrages suivants : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6145(title)
+msgid "Glade and Gtk::Builder"
+msgstr "Glade et Gtk::Builder"
+
+#: C/gtkmm-tutorial-in.xml:6146(para)
+msgid ""
+"Although you can use C++ code to instantiate and arrange widgets, this can "
+"soon become tedious and repetitive. And it requires a recompilation to show "
+"changes. The <application>Glade</application> application allows you to "
+"layout widgets on screen and then save an XML description of the "
+"arrangement. Your application can then use the <application>Gtk::Builder</"
+"application> API to load that XML file at runtime and obtain a pointer to "
+"specifically named widget instances."
+msgstr ""
+"Même si vous pouvez utiliser du code C++ pour instancier et disposer les "
+"éléments graphiques, cela devient vite répétitif et fastidieux. De plus, il "
+"est nécessaire de compiler à nouveau pour voir les modifications. "
+"L'application <application>Glade</application> vous permet de disposer les "
+"éléments graphiques à l'écran et d'enregistrer une description XML de "
+"l'arrangement. Votre application peut alors utiliser l'API <application>Gtk::"
+"Builder</application> pour charger ce fichier XML au lancement de "
+"l'application et obtenir un pointeur sur les instances de l'élément "
+"graphique précisément désigné."
+
+#: C/gtkmm-tutorial-in.xml:6159(simpara)
+msgid "Less C++ code is required."
+msgstr "elle requiert moins de code C++,"
+
+#: C/gtkmm-tutorial-in.xml:6160(simpara)
+msgid "UI changes can be seen more quickly, so UIs are able to improve."
+msgstr ""
+"les modifications apportées à l'UI sont visibles plus rapidement, donc plus "
+"facilement améliorables,"
+
+#: C/gtkmm-tutorial-in.xml:6161(simpara)
+msgid "Designers without programming skills can create and edit UIs."
+msgstr ""
+"des concepteurs sans capacité particulière de programmation peuvent créer et "
+"modifier des UI."
+
+#: C/gtkmm-tutorial-in.xml:6156(para)
+msgid "This has the following advantages: <placeholder-1/>"
+msgstr ""
+"Cette fonction membre présente les avantages suivants : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6165(para)
+msgid ""
+"You still need C++ code to deal with User Interface changes triggered by "
+"user actions, but using <application>Gtk::Builder</application> for the "
+"widget layout allows you to focus on implementing that functionality."
+msgstr ""
+"Vous aurez encore besoin de code C++ pour gérer les transactions sur "
+"l'interface déclenchées par les actions de l'utilisateur, mais l'utilisation "
+"de <application>Gtk::Builder</application> pour la disposition des éléments "
+"graphiques vous permet de vous concentrer sur l'implémentation des "
+"fonctionnalités."
+
+#: C/gtkmm-tutorial-in.xml:6172(title)
+msgid "Loading the .glade file"
+msgstr "Chargement du fichier .glade"
+
+#: C/gtkmm-tutorial-in.xml:6177(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gtk::Builder> builder = Gtk::Builder::create_from_file(\"basic.glade\");\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gtk::Builder> builder = \n"
+" Gtk::Builder::create_from_file(\"basic.glade\");\n"
+
+#: C/gtkmm-tutorial-in.xml:6173(para)
+msgid ""
+"<classname>Gtk::Builder</classname> must be used via a <classname>Glib::"
+"RefPtr</classname>. Like all such classes, you need to use a "
+"<methodname>create()</methodname> method to instantiate it. For instance, "
+"<placeholder-1/> This will instantiate the windows defined in the .glade "
+"file, though they will not be shown immediately unless you have specified "
+"that via the <guilabel>Properties</guilabel> window in <application>Glade</"
+"application>."
+msgstr ""
+"<classname>Gtk::Builder</classname> doit être utilisé avec un pointeur "
+"<classname>Glib::RefPtr</classname>. Comme toutes les classes de ce type, "
+"vous aurez besoin de faire appel à la fonction membre <methodname>create()</"
+"methodname> pour en créer un exemplaire. Par exemple, <placeholder-1/> Ceci "
+"va initialiser la fenêtre définie dans le fichier .glade, même si elle n'est "
+"pas immédiatement affichée à moins que vous ayez défini cette action par "
+"l'intermédiaire de la fenêtre <guilabel>Propriétés</guilabel> dans "
+"<application>Glade</application>."
+
+#: C/gtkmm-tutorial-in.xml:6186(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gtk::Builder> builder = Gtk::Builder::create_from_file(\"basic.glade\", \"treeview_products\");\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gtk::Builder> builder = \n"
+" Gtk::Builder::create_from_file(\n"
+" \"basic.glade\",\n"
+" \"treeview_products\");\n"
+
+#: C/gtkmm-tutorial-in.xml:6185(para)
+msgid ""
+"To instantiate just one window, or just one of the child widgets, you can "
+"specify the name of a widget as the second parameter. For instance, "
+"<placeholder-1/>"
+msgstr ""
+"Pour créer juste un exemplaire d'une fenêtre ou d'un élément graphique "
+"enfant, vous pouvez indiquer le nom d'un élément graphique en tant que "
+"deuxième paramètre. Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6194(title)
+msgid "Accessing widgets"
+msgstr "Accès aux éléments graphiques"
+
+#: C/gtkmm-tutorial-in.xml:6202(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Gtk::Dialog* pDialog = 0;\n"
+"builder->get_widget(\"DialogBasic\", pDialog);\n"
+msgstr ""
+"\n"
+"Gtk::Dialog* pDialog = 0;\n"
+"builder->get_widget(\"DialogBasic\", pDialog);\n"
+
+#: C/gtkmm-tutorial-in.xml:6196(para)
+msgid ""
+"To access a widget, for instance to <methodname>show()</methodname> a "
+"dialog, use the <methodname>get_widget()</methodname> method, providing the "
+"widget's name. This name should be specified in the <application>Glade</"
+"application> Properties window. If the widget could not be found, or is of "
+"the wrong type, then the pointer will be set to 0. <placeholder-1/>"
+msgstr ""
+"Pour accéder à un élément graphique, par exemple pour appeler la fonction "
+"<methodname>show()</methodname> sur une boîte de dialogue, utilisez la "
+"fonction membre <methodname>get_widget()</methodname> en fournissant le nom "
+"de l'élément graphique en paramètre. Ce nom doit avoir été indiqué dans la "
+"fenêtre Propriétés de <application>Glade</application>. Si l'élément "
+"graphique est introuvable, ou n'est pas d'un type correct, le pointeur sera "
+"initialisé à 0. <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6208(para)
+msgid ""
+"<application>Gtk::Builder</application> checks for a null pointer, and "
+"checks that the widget is of the expected type, and will show warnings on "
+"the command line about these."
+msgstr ""
+"<application>Gtk::Builder</application> vérifie qu'il ne s'agit pas d'un "
+"pointeur NULL et que l'élément graphique est du type attendu ; il affiche "
+"des avertissements sur la ligne de commande s'il y a de telles anomalies."
+
+#: C/gtkmm-tutorial-in.xml:6214(para)
+msgid ""
+"Remember that you are not instantiating a widget with <methodname>get_widget"
+"()</methodname>, you are just obtaining a pointer to one that already "
+"exists. You will always receive a pointer to the same instance when you call "
+"<methodname>get_widget()</methodname> on the same <classname>Gtk::Builder</"
+"classname>, with the same widget name. The widgets are instantiated during "
+"<methodname>Gtk::Builder::create_from_file()</methodname>."
+msgstr ""
+"Souvenez-vous que <methodname>get_widget()</methodname> ne crée pas un "
+"nouvel exemplaire d'élément graphique ; avec cette fonction, vous obtenez "
+"simplement un pointeur sur un élément graphique qui existe déjà . Vous "
+"obtenez toujours un pointeur sur le même élément graphique quand vous "
+"appelez <methodname>get_widget()</methodname> sur le même <classname>Gtk::"
+"Builder</classname>, avec le même nom d'élément graphique. Les éléments "
+"graphiques sont créés pendant l'appel à <methodname>Gtk::Builder::"
+"create_from_file()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:6223(para)
+msgid ""
+"<methodname>get_widget()</methodname> returns child widgets that are "
+"<function>manage()</function>ed (see the <link linkend=\"chapter-memory"
+"\">Memory Management</link> chapter), so they will be deleted when their "
+"parent container is deleted. So, if you get only a child widget from "
+"<application>Gtk::Builder</application>, instead of a whole window, then you "
+"must either put it in a <classname>Container</classname> or delete it. "
+"<classname>Windows</classname> (such as <classname>Dialogs</classname>) "
+"cannot be managed because they have no parent container, so you must delete "
+"them at some point."
+msgstr ""
+"<methodname>get_widget()</methodname> renvoie des éléments graphiques "
+"enfants marqués (voir le chapitre sur la <link linkend=\"chapter-memory"
+"\">Gestion de la mémoire</link>) par la fonction <function>manage()</"
+"function> ; ils seront donc détruits quand leur conteneur parent sera "
+"détruit. Donc, si vous n'obtenez qu'un seul élément graphique de "
+"<application>Gtk::Builder</application>, au lieu de la totalité de la "
+"fenêtre, alors vous devez, soit le placer dans un objet "
+"<classname>Container</classname>, soit le détruire. Les objets "
+"<classname>Windows</classname> (tout comme les objets <classname>Dialogs</"
+"classname>) ne peuvent pas être gérés étant donné qu'ils n'ont pas de "
+"conteneur parent ; vous devez donc les détruire à un moment donné."
+
+#: C/gtkmm-tutorial-in.xml:6237(para)
+msgid ""
+"This simple example shows how to load a <application>Glade</application> "
+"file at runtime and access the widgets with <application>Gtk::Builder</"
+"application>."
+msgstr ""
+"Cet exemple simple montre comment charger un fichier <application>Glade</"
+"application> au cours de l'exécution et accéder aux éléments graphiques avec "
+"<application>Gtk::Builder</application>."
+
+#: C/gtkmm-tutorial-in.xml:6250(title)
+msgid "Using derived widgets"
+msgstr "Utilisation d'éléments graphiques dérivés"
+
+#: C/gtkmm-tutorial-in.xml:6251(para)
+msgid ""
+"You can use <application>Glade</application> to layout your own custom "
+"widgets derived from <application>gtkmm</application> widget classes. This "
+"keeps your code organized and encapsulated. Of course you won't see the "
+"exact appearance and properties of your derived widget in "
+"<application>Glade</application>, but you can specify its location and child "
+"widgets and the properties of its <application>gtkmm</application> base "
+"class."
+msgstr ""
+"Vous pouvez utilisez <application>Glade</application> pour placer vos "
+"propres éléments graphiques personnalisés, dérivés à partir d'une classe "
+"d'élément graphique <application>gtkmm</application>. Vous pouvez ainsi "
+"conserver votre code organisé et encapsulé. Bien entendu, vous ne voyez pas "
+"l'aspect exact et les propriétés de l'élément graphique dérivé dans "
+"<application>Glade</application>, mais vous pouvez indiquer son emplacement, "
+"ses éléments graphiques enfants et les propriétés de la classe "
+"<application>gtkmm</application> de base."
+
+#: C/gtkmm-tutorial-in.xml:6260(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"DerivedDialog* pDialog = 0;\n"
+"builder->get_widget_derived(\"DialogBasic\", pDialog);\n"
+msgstr ""
+"\n"
+"DerivedDialog* pDialog = 0;\n"
+"builder->get_widget_derived(\"DialogBasic\", pDialog);\n"
+
+#: C/gtkmm-tutorial-in.xml:6259(para)
+msgid ""
+"Use <methodname>Gtk::Builder::get_widget_derived()</methodname> like so: "
+"<placeholder-1/>"
+msgstr ""
+"Utilisez <methodname>Gtk::Builder::get_widget_derived()</methodname> ainsi : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6266(para)
+msgid ""
+"Your derived class must have a constructor that takes a pointer to the "
+"underlying C type, and the <classname>Gtk::Builder</classname> instance. All "
+"relevant classes of <application>gtkmm</application> typedef their "
+"underlying C type as <classname>BaseObjectType</classname> (<classname>Gtk::"
+"Dialog</classname> typedefs <classname>BaseObjectType</classname> as "
+"<type>GtkDialog</type>, for instance)."
+msgstr ""
+"Votre classe dérivée doit avoir un constructeur prenant comme paramètre un "
+"pointeur sur le type C sous-jacent et l'instance de <classname>Gtk::Builder</"
+"classname>. Toutes les classes <application>gtkmm</application> en rapport "
+"définissent leurs types C sous-jacents en tant qu'objets "
+"<classname>BaseObjectType</classname> (par exemple <classname>Gtk::Dialog</"
+"classname> défini son type <classname>BaseObjectType</classname> comme "
+"<literal>GtkDialog</literal>)."
+
+#: C/gtkmm-tutorial-in.xml:6276(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"DerivedDialog::DerivedDialog(BaseObjectType* cobject, const Glib::RefPtr<Gtk::Builder>& builder)\n"
+": Gtk::Dialog(cobject)\n"
+"{\n"
+"}\n"
+msgstr ""
+"\n"
+"DerivedDialog::DerivedDialog(BaseObjectType* cobject,\n"
+" const Glib::RefPtr<Gtk::Builder>& builder)\n"
+": Gtk::Dialog(cobject)\n"
+"{\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:6273(para)
+msgid ""
+"You must call the base class's constructor in the initialization list, "
+"providing the C pointer. For instance, <placeholder-1/>"
+msgstr ""
+"Vous devez faire appel au constructeur de la classe de base dans la liste "
+"d'initialisation, en fournissant le pointeur C. Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6288(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"DerivedDialog::DerivedDialog(BaseObjectType* cobject, const Glib::RefPtr<Gtk::Builder>& builder)\n"
+": Gtk::Dialog(cobject),\n"
+" m_builder(builder),\n"
+" m_pButton(0)\n"
+"{\n"
+" //Get the Glade-instantiated Button, and connect a signal handler:\n"
+" m_builder->get_widget(\"quit_button\", m_pButton);\n"
+" if(m_pButton)\n"
+" {\n"
+" m_pButton->signal_clicked().connect( sigc::mem_fun(*this, &DerivedDialog::on_button_quit) );\n"
+" }\n"
+"}\n"
+msgstr ""
+"\n"
+"DerivedDialog::DerivedDialog(BaseObjectType* cobject,\n"
+" const Glib::RefPtr<Gtk::Builder>& builder)\n"
+": Gtk::Dialog(cobject),\n"
+" m_builder(builder),\n"
+" m_pButton(0)\n"
+"{\n"
+" // Obtenir le bouton instancié par Glade \n"
+" // et le connecter au gestionnaire de signal :\n"
+" m_builder->get_widget(\"quit_button\", m_pButton);\n"
+" if(m_pButton)\n"
+" {\n"
+" m_pButton->signal_clicked().connect( sigc::mem_fun(*this,\n"
+" &DerivedDialog::on_button_quit) );\n"
+" }\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:6284(para)
+msgid ""
+"You could then encapsulate the manipulation of the child widgets in the "
+"constructor of the derived class, maybe using <methodname>get_widget()</"
+"methodname> or <methodname>get_widget_derived()</methodname> again. For "
+"instance, <placeholder-1/>"
+msgstr ""
+"Vous pouvez ensuite encapsuler les manipulations des éléments graphiques "
+"enfants dans le constructeur de la classe dérivée, avec peut-être "
+"<methodname>get_widget()</methodname> ou <methodname>get_widget_derived()</"
+"methodname> Ã nouveau. Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6306(para)
+msgid ""
+"This example shows how to load a <application>Glade</application> file at "
+"runtime and access the widgets via a derived class."
+msgstr ""
+"Cet exemple montre comment charger un fichier <application>Glade</"
+"application> au lancement et accéder aux éléments graphiques par "
+"l'intermédiaire d'une classe dérivée."
+
+#: C/gtkmm-tutorial-in.xml:6319(title)
+msgid "Internationalization and Localization"
+msgstr "Internationalisation et adaptation locale"
+
+#: C/gtkmm-tutorial-in.xml:6321(para)
+msgid ""
+"<application>gtkmm</application> applications can easily support multiple "
+"languages, including non-European languages such as Chinese and right-to-"
+"left languages such as Arabic. An appropriately-written and translated "
+"<application>gtkmm</application> application will use the appropriate "
+"language at runtime based on the user's environment."
+msgstr ""
+"Les applications <application>gtkmm</application> prennent facilement en "
+"charge plusieurs langues, y compris les langues non-européennes telles que "
+"le chinois et les langues s'écrivant de droite à gauche comme l'arabe. Une "
+"application <application>gtkmm</application> écrite et traduite de manière "
+"appropriée, utilise lors de son exécution la langue définie par "
+"l'environnement utilisateur."
+
+#: C/gtkmm-tutorial-in.xml:6327(para)
+msgid ""
+"You might not anticipate the need to support additional languages, but you "
+"can never rule it out. And it's easier to develop the application properly "
+"in the first place rather than retrofitting later."
+msgstr ""
+"Vous ne devez pas anticiper le besoin de prendre en charge telles ou telles "
+"autres langues, mais vous ne devez jamais en exclure l'utilisation. De plus, "
+"il est plus facile de développer une application correctement dès le début "
+"que de l'améliorer après coup."
+
+#: C/gtkmm-tutorial-in.xml:6333(para)
+msgid ""
+"The process of writing source code that allows for translation is called "
+"<literal>internationalization</literal>, often abbreviated to <literal>i18n</"
+"literal>. The <literal>Localization</literal> process, sometimes abbreviated "
+"as <literal>l10n</literal>, provides translated text for other languages, "
+"based on that source code."
+msgstr ""
+"Le processus consistant à écrire un code source autorisant la traduction "
+"s'appelle l'<literal>internationalisation</literal>, souvent abrégé en "
+"<literal>i18n</literal>. Le processus d'<literal>adaptation locale</literal> "
+"(localisation) quelquefois abrégé en <literal>l10n</literal>, met à "
+"disposition du texte, fondé sur ce code source, traduit dans d'autres "
+"langues."
+
+#: C/gtkmm-tutorial-in.xml:6341(para)
+msgid ""
+"The main activity in the internationalization process is finding strings "
+"seen by users and marking them for translation. You do not need to do it all "
+"at once - if you set up the necessary project infrastructure correctly then "
+"your application will work normally regardless of how many strings you've "
+"covered."
+msgstr ""
+"Le gros du travail dans le processus d'internationalisation est de "
+"rechercher les chaînes visibles par l'utilisateur et de les marquer comme "
+"traduisibles. Ce travail n'a pas besoin d'être réalisé en une seule fois "
+"- si vous réglez l'infrastructure du projet correctement, votre application "
+"fonctionnera normalement quel que soit le nombre de chaînes traîtées."
+
+#: C/gtkmm-tutorial-in.xml:6349(para)
+msgid ""
+"String literals should be typed in the source code in English, but "
+"surrounded by a macro. The <application>gettext</application> (or intltool) "
+"utility can then extract the marked strings for tramslation, and substitute "
+"the translated text at runtime."
+msgstr ""
+"Les chaînes littérales doivent être saisies en anglais dans le code source, "
+"mais englobées dans une macro. L'utilitaire <application>gettext</"
+"application> (ou intltool) extrait les chaînes marquées pour traduction et "
+"substitue le texte traduit lors de l'exécution."
+
+#: C/gtkmm-tutorial-in.xml:6357(title)
+msgid "Preparing your project"
+msgstr "Préparation du projet"
+
+#: C/gtkmm-tutorial-in.xml:6360(para)
+msgid ""
+"In the instructions below we will assume that you will not be using "
+"<application>gettext</application> directly, but <application>intltool</"
+"application>, which was written specifically for <literal>GNOME</literal>. "
+"<application>intltool</application> uses <function>gettext()</function>, "
+"which extracts strings from source code, but <application>intltool</"
+"application> can also combine strings from other files, for example from "
+"desktop menu details, and GUI resource files such as <application>Glade</"
+"application> files, into standard <application>gettext</"
+"application><filename>.pot/.po</filename> files."
+msgstr ""
+"Dans les directives ci-dessous, nous supposons que vous n'utilisez pas "
+"<application>gettext</application> directement, mais <application>intltool</"
+"application> qui a été spécialement écrit pour <literal>GNOME</literal>. "
+"<application>intltool</application> utilise <function>gettext()</function> "
+"pour extraire les chaînes du code source, mais <application>intltool</"
+"application> peut aussi combiner, dans les fichiers standards <filename>."
+"pot/.po</filename> de <application>gettext</application>, les chaînes "
+"provenant d'autres fichiers : par exemple, des détails de menu du bureau ou "
+"de ressources d'interface utilisateur comme les fichiers <application>Glade</"
+"application>."
+
+#: C/gtkmm-tutorial-in.xml:6371(para)
+msgid ""
+"We also assume that you are using autotools (e.g. <application>automake</"
+"application> and <application>autoconf</application>) to build your project, "
+"and that you are using <ulink url=\"http://svn.gnome.org/viewcvs/gnome-"
+"common/trunk/autogen.sh?view=markup\"><literal>./autogen.sh</literal> from "
+"<application>gnome-common</application></ulink>, which, among other things, "
+"takes care of some <application>intltool</application> initialization."
+msgstr ""
+"Nous supposons également que vous utilisez autotools (c'est-à -dire, "
+"<application>automake</application> et <application>autoconf</application>) "
+"pour construire le projet et que vous vous servez de <ulink url=\"http://svn."
+"gnome.org/viewcvs/gnome-common/trunk/autogen.sh?view=markup\"><literal>./"
+"autogen.sh</literal></ulink> de <application>gnome-common</application>, "
+"qui, entre autres choses, effectue certaines initialisations pour "
+"<application>intltool</application>."
+
+#: C/gtkmm-tutorial-in.xml:6384(para)
+msgid ""
+"Create a sub-directory named <literal>po</literal> in your project's root "
+"directory. This directory will eventually contain all of your translations. "
+"Within it, create a file named <literal>LINGUAS</literal> and a file named "
+"<literal>POTFILES.in</literal>. It is common practice to also create a "
+"<literal>ChangeLog</literal> file in the <literal>po</literal> directory so "
+"that translators can keep track of translation changes."
+msgstr ""
+"Créez un sous-répertoire nommé <literal>po</literal> dans le répertoire "
+"racine de votre projet. Ce répertoire contiendra en phase finale toutes les "
+"traductions. Dans celui-ci, créez un fichier nommé <literal>LINGUAS</"
+"literal> et un fichier nommé <literal>POTFILES.in</literal>. Il est aussi de "
+"pratique courante de créer un fichier <literal>ChangeLog</literal> dans le "
+"répertoire <literal>po</literal> pour que les traducteurs puissent garder "
+"trace des modifications de traduction."
+
+#: C/gtkmm-tutorial-in.xml:6394(para)
+msgid ""
+"<literal>LINGUAS</literal> contains an alphabetically sorted list of codes "
+"identifying the languages for which your program is translated (comment "
+"lines starting with a <literal>#</literal> are ignored). Each language code "
+"listed in the <literal>LINGUAS</literal> file must have a corresponding "
+"<literal>.po</literal> file. So, if your program has German and Japanese "
+"translations, your <literal>LINGUAS</literal> file would look like this:"
+msgstr ""
+"<literal>LINGUAS</literal> contient une liste triée alphabétiquement des "
+"codes identifiant toutes les langues dans lesquelles votre programme est "
+"traduit (les lignes de commentaires débutant par <literal>#</literal> sont "
+"ignorées). Chaque code de langue listé dans <literal>LINGUAS</literal> doit "
+"avoir un fichier <literal>.po</literal> correspondant. Ainsi, si votre "
+"programme a des traductions en allemand et en japonais, le fichier "
+"<literal>LINGUAS</literal> ressemblera à  :"
+
+#: C/gtkmm-tutorial-in.xml:6403(programlisting)
+#, no-wrap
+msgid ""
+"# keep this file sorted alphabetically, one language code per line\n"
+"de\n"
+"ja"
+msgstr ""
+"# keep this file sorted alphabetically, one language code per line\n"
+"de\n"
+"ja"
+
+#: C/gtkmm-tutorial-in.xml:6406(para)
+msgid ""
+"(In addition, you'd have the files <literal>ja.po</literal> and <literal>de."
+"po</literal> in your <literal>po</literal> directory which contain the "
+"German and Japanese translations, respectively.)"
+msgstr ""
+"(en outre, vous devez avoir dans le dossier <literal>po</literal> des "
+"fichiers <literal>ja.po</literal> et <literal>de.po</literal> contenant "
+"respectivement la traduction japonaise et allemande)."
+
+#: C/gtkmm-tutorial-in.xml:6413(para)
+msgid ""
+"<literal>POTFILES.in</literal> is a list of paths to all files which contain "
+"strings marked up for translation, starting from the project root directory. "
+"So for example, if your project sources were located in a subdirectory named "
+"<literal>src</literal>, and you had two files that contained strings that "
+"should be translated, your <literal>POTFILES.in</literal> file might look "
+"like this:"
+msgstr ""
+"<literal>POTFILES.in</literal> est une liste des chemins vers tous les "
+"fichiers contenant des chaînes marquées pour la traduction, à partir du "
+"répertoire racine du projet. Ainsi, par exemple, si les sources du projet "
+"sont situées dans un sous-répertoire nommé <literal>src</literal> et si vous "
+"avez deux fichiers contenant des chaînes à traduire, votre fichier "
+"<literal>POTFILES.in</literal> ressemble à quelque chose comme :"
+
+#: C/gtkmm-tutorial-in.xml:6422(programlisting)
+#, no-wrap
+msgid ""
+"src/main.cc\n"
+"src/other.cc"
+msgstr ""
+"src/main.cc\n"
+"src/other.cc"
+
+#: C/gtkmm-tutorial-in.xml:6425(para)
+msgid ""
+"If you are using <application>gettext</application> directly, you can only "
+"mark strings for translation if they are in source code file. However, if "
+"you use <application>intltool</application>, you can mark strings for "
+"translation in a variety of other file formats, including "
+"<application>Glade</application> UI files, xml, <ulink url=\"http://"
+"standards.freedesktop.org/desktop-entry-spec/latest/\">.desktop files</"
+"ulink> and several more. So, if you have designed some of the application UI "
+"in <application>Glade</application> then also add your <filename>.glade</"
+"filename> files to the list in <literal>POTFILES.in</literal>."
+msgstr ""
+"Si vous utilisez <application>gettext</application> directement, vous ne "
+"pouvez marquer pour traduction que les chaînes situées dans les fichiers de "
+"code source. Mais, si vous vous servez de <application>intltool</"
+"application>, vous pouvez marquer des chaînes pour traduction dans divers "
+"autres formats de fichier, y compris les fichiers d'interface utilisateur "
+"<application>Glade</application>, xml, <ulink url=\"http://standards."
+"freedesktop.org/desktop-entry-spec/latest/\">.desktop</ulink> et de nombreux "
+"autres. Donc si vous avez conçu une partie des interfaces utilisateur du "
+"projet à l'aide de <application>Glade</application>, ajoutez également vos "
+"fichiers <filename>.glade</filename> dans la liste du fichier "
+"<literal>POTFILES.in</literal>."
+
+#: C/gtkmm-tutorial-in.xml:6438(para)
+msgid ""
+"Now that there is a place to put your translations, you need to initialize "
+"<application>intltool</application> and <application>gettext</application>. "
+"Add the following code to your <literal>configure.ac</literal>, substituting "
+"'programname' with the name of your program:"
+msgstr ""
+"Maintenant que vous disposez d'un endroit où mettre vos traductions, il est "
+"nécessaire d'initialiser <application>intltool</application> et "
+"<application>gettext</application>. Ajoutez le code ci-après dans votre "
+"fichier <literal>configure.ac</literal>, en mettant le nom de votre "
+"programme à la place de « nom_programme » :"
+
+#: C/gtkmm-tutorial-in.xml:6445(programlisting)
+#, no-wrap
+msgid ""
+"IT_PROG_INTLTOOL([0.35.0])\n"
+"\n"
+"GETTEXT_PACKAGE=programname\n"
+"AC_SUBST(GETTEXT_PACKAGE)\n"
+"AC_DEFINE_UNQUOTED([GETTEXT_PACKAGE], [\"$GETTEXT_PACKAGE\"],\n"
+" [The domain to use with gettext])\n"
+"AM_GLIB_GNU_GETTEXT\n"
+"\n"
+"PROGRAMNAME_LOCALEDIR=[${datadir}/locale]\n"
+"AC_SUBST(PROGRAMNAME_LOCALEDIR)"
+msgstr ""
+"IT_PROG_INTLTOOL([0.35.0])\n"
+"\n"
+"GETTEXT_PACKAGE=nom_programme\n"
+"AC_SUBST(GETTEXT_PACKAGE)\n"
+"AC_DEFINE_UNQUOTED([GETTEXT_PACKAGE], [\"$GETTEXT_PACKAGE\"],\n"
+" [Domaine de portée de gettext])\n"
+"AM_GLIB_GNU_GETTEXT\n"
+"\n"
+"PROGRAMNAME_LOCALEDIR=[${datadir}/locale]\n"
+"AC_SUBST(PROGRAMNAME_LOCALEDIR)"
+
+#: C/gtkmm-tutorial-in.xml:6456(para)
+msgid ""
+"This <varname>PROGRAMNAME_LOCALEDIR</varname> variable will be used later in "
+"the <literal>Makefile.am</literal> file, to define a macro that will be used "
+"when you initialize <application>gettext</application> in your source code."
+msgstr ""
+"La variable <varname>PROGRAMNAME_LOCALEDIR</varname> sera utilisée plus tard "
+"dans le fichier <literal>Makefile.am</literal> pour définir une macro "
+"utilisée quand vous initialisez <application>gettext</application> dans "
+"votre code source."
+
+#: C/gtkmm-tutorial-in.xml:6467(para)
+msgid ""
+"Add <literal>po</literal> to the <literal>SUBDIRS</literal> variable. "
+"Without this, your translations won't get built and installed when you build "
+"the program"
+msgstr ""
+"ajoutez <literal>po</literal> Ã la variable <literal>SUBDIRS</literal>. Sans "
+"cela, vos traductions ne seraient pas construites et installées lors de la "
+"construction du programme."
+
+#: C/gtkmm-tutorial-in.xml:6474(programlisting)
+#, no-wrap
+msgid ""
+"INTLTOOL_FILES = intltool-extract.in \\\n"
+" intltool-merge.in \\\n"
+" intltool-update.in"
+msgstr ""
+"INTLTOOL_FILES = intltool-extract.in \\\n"
+" intltool-merge.in \\\n"
+" intltool-update.in"
+
+#: C/gtkmm-tutorial-in.xml:6472(para)
+msgid "Define <literal>INTLTOOL_FILES</literal> as: <placeholder-1/>"
+msgstr "définissez <literal>INTLTOOL_FILES</literal> égal à  : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6480(para)
+msgid ""
+"Add <literal>INTLTOOL_FILES</literal> to the <literal>EXTRA_DIST</literal> "
+"list of files. This ensures that when you do a <command>make dist</command>, "
+"these commands will be included in the source tarball."
+msgstr ""
+"ajoutez <literal>INTLTOOL_FILES</literal> Ã la liste <literal>EXTRA_DIST</"
+"literal> de fichiers. Ceci assure que ces commandes seront incluses dans "
+"l'archive source quand vous effectuerez <command>make dist</command>."
+
+#: C/gtkmm-tutorial-in.xml:6490(programlisting)
+#, no-wrap
+msgid ""
+"DISTCLEANFILES = ... intltool-extract \\\n"
+" intltool-merge \\\n"
+" intltool-update \\\n"
+" po/.intltool-merge-cache"
+msgstr ""
+"DISTCLEANFILES = ... intltool-extract \\\n"
+" intltool-merge \\\n"
+" intltool-update \\\n"
+" po/.intltool-merge-cache"
+
+#: C/gtkmm-tutorial-in.xml:6488(para)
+msgid "Update your <literal>DISTCLEANFILES</literal>: <placeholder-1/>"
+msgstr "mettez à jour vos <literal>DISTCLEANFILES</literal> : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6463(para)
+msgid "In the top-level Makefile.am: <placeholder-1/>"
+msgstr "Dans le fichier Makefile.am principal : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6499(para)
+msgid ""
+"In your <literal>src/Makefile.am</literal>, update your "
+"<literal>AM_CPPFLAGS</literal> to add the following preprocessor macro "
+"definition:"
+msgstr ""
+"Dans votre <literal>src/Makefile.am</literal>, mettez à jour votre variable "
+"<literal>AM_CPPFLAGS</literal> en ajoutant la définition de macro "
+"préprocesseur suivante :"
+
+#: C/gtkmm-tutorial-in.xml:6504(programlisting)
+#, no-wrap
+msgid "AM_CPPFLAGS = ... -DPROGRAMNAME_LOCALEDIR=\\\"${PROGRAMNAME_LOCALEDIR}\\\""
+msgstr "AM_CPPFLAGS = ... -DPROGRAMNAME_LOCALEDIR=\\\"${PROGRAMNAME_LOCALEDIR}\\\""
+
+#: C/gtkmm-tutorial-in.xml:6505(para)
+msgid ""
+"This macro will be used when you initialize <literal>gettext</literal> in "
+"your source code."
+msgstr ""
+"Cette macro sert quand vous initialisez <literal>gettext</literal> dans "
+"votre code source."
+
+#: C/gtkmm-tutorial-in.xml:6512(title)
+msgid "Marking strings for translation"
+msgstr "Marquage des chaînes à traduire"
+
+#: C/gtkmm-tutorial-in.xml:6514(para)
+msgid ""
+"String literals should be typed in the source code in English, but they "
+"should be surrounded by a call to the <function>gettext()</function> "
+"function. These strings will be extracted for translation and the "
+"translations may be used at runtime instead of the original English strings."
+msgstr ""
+"Les chaînes littérales doivent être saisies dans le code source en anglais, "
+"mais elles doivent être incorporées dans un appel à la fonction "
+"<function>gettext()</function>. Ces chaînes seront extraites pour traduction "
+"et les traductions utilisées lors de l'exécution au lieu des chaînes "
+"originelles en anglais."
+
+#: C/gtkmm-tutorial-in.xml:6522(para)
+msgid ""
+"The <application>GNU gettext</application> package allows you to mark "
+"strings in source code, extract those strings for translation, and use the "
+"translated strings in your application."
+msgstr ""
+"Le paquetage <application>GNU gettext</application> vous permet de marquer "
+"des chaînes dans le code source, de les extraire pour traduction et "
+"d'utiliser les chaînes traduites dans votre application."
+
+#: C/gtkmm-tutorial-in.xml:6534(programlisting)
+#, no-wrap
+msgid "display_message(\"Getting ready for i18n.\");"
+msgstr "display_message(\"Getting ready for i18n.\");"
+
+#: C/gtkmm-tutorial-in.xml:6536(programlisting)
+#, no-wrap
+msgid "display_message(_(\"Getting ready for i18n.\"));"
+msgstr "display_message(_(\"Getting ready for i18n.\"));"
+
+#: C/gtkmm-tutorial-in.xml:6528(para)
+msgid ""
+"However, <application>Glib</application> defines <function>gettext()</"
+"function> support macros which are shorter wrappers in an easy-to-use form. "
+"To use these macros, include <literal><glibmm/i18n.h></literal>, and "
+"then, for example, substitute: <placeholder-1/> with: <placeholder-2/>"
+msgstr ""
+"Toutefois, <application>Glib</application> définit des macros de prise en "
+"charge de <function>gettext()</function> qui sont des enveloppes plus brèves "
+"et de forme plus commode à utiliser. Pour utiliser ces macros, incluez "
+"<literal><glibmm/i18n.h></literal>, puis, par exemple, remplacez : "
+"<placeholder-1/> par : <placeholder-2/>"
+
+#: C/gtkmm-tutorial-in.xml:6547(programlisting)
+#, no-wrap
+msgid "xgettext -a -o my-strings --omit-header *.cc *.h"
+msgstr "xgettext -a -o my-strings --omit-header *.cc *.h"
+
+#: C/gtkmm-tutorial-in.xml:6539(para)
+msgid ""
+"For reference, it is possible to generate a file which contains all strings "
+"which appear in your code, even if they are not marked for translation, "
+"together with file name and line number references. To generate such a file "
+"named <literal>my-strings</literal>, execute the following command, within "
+"the source code directory: <placeholder-1/>"
+msgstr ""
+"� titre de référence, il est possible de générer un fichier qui contienne "
+"toutes les chaînes apparaissant dans votre code, même si elles ne sont pas "
+"marquées pour la traduction, avec le nom du fichier et le numéro de la ligne "
+"où elles se situent. Pour générer ce fichier que nous appelons <literal>my-"
+"strings</literal>, exécutez la commande suivante dans le répertoire du code "
+"source : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6554(programlisting)
+#, no-wrap
+msgid ""
+"bindtextdomain(GETTEXT_PACKAGE, PROGRAMNAME_LOCALEDIR);\n"
+"bind_textdomain_codeset(GETTEXT_PACKAGE, \"UTF-8\");\n"
+"textdomain(GETTEXT_PACKAGE);"
+msgstr ""
+"bindtextdomain(GETTEXT_PACKAGE, PROGRAMNAME_LOCALEDIR);\n"
+"bind_textdomain_codeset(GETTEXT_PACKAGE, \"UTF-8\");\n"
+"textdomain(GETTEXT_PACKAGE);"
+
+#: C/gtkmm-tutorial-in.xml:6550(para)
+msgid ""
+"Finally, to let you program use the translation for the current locale, add "
+"this code to the beginning of your <filename>main.cc</filename> file, to "
+"initialize gettext. <placeholder-1/>"
+msgstr ""
+"Pour terminer, pour permettre à votre programme d'utiliser la traduction "
+"pour l'adaptation locale en cours, ajoutez ce code au début de votre fichier "
+"<filename>main.cc</filename> pour initialiser gettext : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6560(title)
+msgid "How gettext works"
+msgstr "Comment fonctionne gettext"
+
+#: C/gtkmm-tutorial-in.xml:6562(para)
+msgid ""
+"<application>intltool</application> / <application>xgettext</application> "
+"script extracts the strings and puts them in a <filename>mypackage.pot</"
+"filename> file. The translators of your application create their "
+"translations by first copying this <filename>.pot</filename> file to a "
+"<filename>localename.po</filename> file. A locale identifies a language and "
+"an encoding for that language, including date and numerical formats. Later, "
+"when the text in your source code has changed, the <literal>msmerge</"
+"literal> script is used to update the <filename>localename.po</filename> "
+"files from the regenerated <filename>.pot</filename> file."
+msgstr ""
+"Le script <application>intltool</application> / <application>xgettext</"
+"application> extrait les chaînes et les place dans un fichier "
+"<filename>mon_paquet.pot</filename>. Les traducteurs de votre application "
+"créent leur traduction en faisant d'abord une copie du fichier <filename>."
+"pot</filename> dans un fichier <filename>nom_de_locale.po</filename>. Une "
+"« locale » identifie une langue et un codage pour cette langue, y compris les "
+"formats numériques et de date. Ultérieurement, si le texte de votre code "
+"source a été modifié, le script <literal>msmerge</literal> sera utilisé pour "
+"mettre à jour les fichiers <filename>nom_de_locale.po</filename> à partir "
+"d'une nouvelle génération du fichier <filename>.pot</filename>."
+
+#: C/gtkmm-tutorial-in.xml:6576(para)
+msgid ""
+"At install time, the <filename>.po</filename> files are converted to a "
+"binary format (with the extension <filename>.mo</filename>) and placed in a "
+"system-wide directory for locale files, for example <filename>/usr/share/"
+"locale/</filename>."
+msgstr ""
+"Au moment de l'installation, les fichiers <filename>.po</filename> sont "
+"convertis dans un format binaire (avec l'extension <filename>.mo</filename>) "
+"et placés dans un répertoire système pour les fichiers d'environnement "
+"linguistique, par exemple <filename>/usr/share/locale/</filename>."
+
+#: C/gtkmm-tutorial-in.xml:6583(para)
+msgid ""
+"When the application runs, the <application>gettext</application> library "
+"checks the system-wide directory to see if there is a <filename>.mo</"
+"filename> file for the user's locale environment (you can set the locale "
+"with, for instance, \"export LANG=de_DE.UTF-8\" from a bash console). Later, "
+"when the program reaches a <literal>gettext</literal> call, it looks for a "
+"translation of a particular string. If none is found, the original string is "
+"used."
+msgstr ""
+"Quand l'application est lancée, la bibliothèque <application>gettext</"
+"application> vérifie dans le répertoire système s'il y a un fichier "
+"<filename>.mo</filename> pour l'environnement linguistique de l'utilisateur "
+"(environnement que vous pouvez définir avec, par exemple, « export LANG=de_DE."
+"UTF-8 » à partir d'un terminal). Puis, quand le programme atteint un appel "
+"<literal>gettext</literal>, il examine s'il existe une traduction pour la "
+"chaîne donnée. Si aucune n'est trouvée, la chaîne d'origine est utilisée."
+
+#: C/gtkmm-tutorial-in.xml:6595(title)
+msgid "Testing and adding translations"
+msgstr "Vérification et ajout de traductions"
+
+#: C/gtkmm-tutorial-in.xml:6602(programlisting)
+#, no-wrap
+msgid "intltool-update --pot"
+msgstr "intltool-update --pot"
+
+#: C/gtkmm-tutorial-in.xml:6597(para)
+msgid ""
+"To convince yourself that you've done well, you may wish to add a "
+"translation for a new locale. In order to do that, go to the <filename>po</"
+"filename> subdirectory of your project and execute the following command: "
+"<placeholder-1/>"
+msgstr ""
+"Pour vérifier que vous avez bien opéré, peut-être voudrez-vous ajouter une "
+"traduction pour un nouvel environnement linguistique. Pour réaliser cela, "
+"allez dans le sous-répertoire <filename>po</filename> de votre projet et "
+"exécutez les commandes suivantes : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6605(para)
+msgid ""
+"That will create a file named <filename>programname.pot</filename>. Now copy "
+"that file to <filename>languagecode.po</filename>, such as <filename>de.po</"
+"filename> or <filename>hu.po</filename>. Also add that language code to "
+"<literal>LINGUAS</literal>. The <filename>.po</filename> file contains a "
+"header and a list of English strings, with space for the translated strings "
+"to be entered. Make sure you set the encoding of the <filename>.po</"
+"filename> file (specified in the header, but also as content) to "
+"<literal>UTF-8</literal>."
+msgstr ""
+"Cette commande crée un fichier nommé <filename>nom_du_programme.pot</"
+"filename>. Copiez ensuite ce fichier en lui donnant le nom "
+"<filename>code_langue.po</filename>, comme <filename>de.po</filename> ou "
+"<filename>hu.po</filename>. Ajoutez également ce code langue dans le fichier "
+"<literal>LINGUAS</literal>. Le fichier <filename>.po</filename> comporte un "
+"en-tête et une liste des chaînes en anglais, avec des emplacements pour les "
+"chaînes traduites à saisir. Assurez-vous que vous avez défini et utilisé "
+"<literal>UTF-8</literal> comme codage du fichier <filename>.po</filename> "
+"(comme défini dans l'en-tête, mais utilisé dans le contenu)."
+
+#: C/gtkmm-tutorial-in.xml:6618(para)
+msgid ""
+"It's possible that certain strings will be marked as <literal>fuzzy</"
+"literal> in the <filename>.po</filename> file. These translations will not "
+"substitute the original string. To make them appear, simply remove the "
+"<literal>fuzzy</literal> tag."
+msgstr ""
+"Il est possible que certaines chaînes soient marquées <literal>fuzzy</"
+"literal> (approximatives) dans le fichier <filename>.po</filename>. Les "
+"traductions ainsi marquées ne se substituent pas à la chaîne originelle. "
+"Pour qu'elles apparaissent, enlevez simplement la marque <literal>fuzzy</"
+"literal>."
+
+#: C/gtkmm-tutorial-in.xml:6628(title)
+msgid "Resources"
+msgstr "Ressources"
+
+#: C/gtkmm-tutorial-in.xml:6637(ulink)
+msgid "Internationalizing GNOME applications"
+msgstr "Internationalisation des applications GNOME"
+
+#: C/gtkmm-tutorial-in.xml:6644(ulink)
+msgid "Intltool README"
+msgstr "Fichier README de Intltool"
+
+#: C/gtkmm-tutorial-in.xml:6650(ulink)
+msgid "How to use GNOME CVS as a Translator"
+msgstr "Comment utiliser GNOME CVS pour traduire"
+
+#: C/gtkmm-tutorial-in.xml:6656(ulink)
+msgid "gettext manual"
+msgstr "Manuel gettext"
+
+#: C/gtkmm-tutorial-in.xml:6662(literal)
+msgid "gtkmm_hello"
+msgstr "gtkmm_hello"
+
+#: C/gtkmm-tutorial-in.xml:6662(ulink) C/gtkmm-tutorial-in.xml:6668(ulink)
+msgid "<placeholder-1/> example package"
+msgstr "Exemple de paquet logiciel <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6668(literal)
+msgid "gnomemm_hello"
+msgstr "gnomemm_hello"
+
+#: C/gtkmm-tutorial-in.xml:6630(para)
+msgid ""
+"More information about what lies behind the internationalization and "
+"localization process is presented and demonstrated in: <placeholder-1/>"
+msgstr ""
+"Des informations supplémentaires sur le processus d'internationalisation et "
+"de localisation sont présentées et commentées dans : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:6678(title)
+msgid "Expecting UTF8"
+msgstr "En attendant UTF8"
+
+#: C/gtkmm-tutorial-in.xml:6679(para)
+msgid ""
+"A properly internationalized application will not make assumptions about the "
+"number of bytes in a character. That means that you shouldn't use pointer "
+"arithmetic to step through the characters in a string, and it means you "
+"shouldn't use <classname>std::string</classname> or standard C functions "
+"such as <function>strlen()</function> because they make the same assumption."
+msgstr ""
+"Une application correctement internationalisée ne doit pas faire de "
+"suppositions sur le nombre d'octets par caractère. Cela signifie que vous ne "
+"devez pas faire d'arithmétique de pointeurs pour cheminer parmi les "
+"caractères d'une chaîne ; cela signifie aussi que vous ne devez pas vous "
+"servir d'objets <classname>std::string</classname> ou de fonctions C "
+"standard telles que <function>strlen()</function> car elle se fondent sur de "
+"telles suppositions pour effectuer leurs calculs."
+
+#: C/gtkmm-tutorial-in.xml:6686(para)
+msgid ""
+"However, you probably already avoid bare char* arrays and pointer arithmetic "
+"by using <classname>std::string</classname>, so you just need to start using "
+"<classname>Glib::ustring</classname> instead. See the <link linkend=\"sec-"
+"basics-ustring\">Basics</link> chapter about <classname>Glib::ustring</"
+"classname>."
+msgstr ""
+"Même si vous avez certainement déjà délaissé les tableaux de <literal>char*</"
+"literal> vides et l'arithmétique des pointeurs en vous servant de "
+"<classname>std::string</classname>, vous devez maintenant utiliser à la "
+"place des objets <classname>Glib::ustring</classname>. Voyez le chapitre "
+"concernant les <classname>Glib::ustring</classname> dans les <link linkend="
+"\"sec-basics-ustring\">Fondamentaux</link>."
+
+#: C/gtkmm-tutorial-in.xml:6694(title)
+msgid "Glib::ustring and std::iostreams"
+msgstr "Glib::ustring et std::iostreams"
+
+#: C/gtkmm-tutorial-in.xml:6711(programlisting)
+#, no-wrap
+msgid ""
+"std::ostringstream output;\n"
+"output.imbue(std::locale(\"\")); // use the user's locale for this stream\n"
+"output << percentage << \" % done\";\n"
+"label->set_text(Glib::locale_to_utf8(output.str()));"
+msgstr ""
+"std::ostringstream output;\n"
+"output.imbue(std::locale(\"\")); // utiliser la locale de l'utilisateur pour ce flux\n"
+"output << percentage << \" % done\";\n"
+"label->set_text(Glib::locale_to_utf8(output.str()));"
+
+#. <para>TODO: This section is not clear - it needs to spell things out more clearly and obviously.</para>
+#: C/gtkmm-tutorial-in.xml:6696(para)
+msgid ""
+"Unfortunately, the integration with the standard iostreams is not completely "
+"foolproof. <application>gtkmm</application> converts <classname>Glib::"
+"ustring</classname>s to a locale-specific encoding (which usually is not UTF-"
+"8) if you output them to an <classname>ostream</classname> with "
+"<function>operator<<</function>. Likewise, retrieving <classname>Glib::"
+"ustrings</classname> from <classname>istream</classname> with "
+"<function>operator>></function> causes a conversion in the opposite "
+"direction. But this scheme breaks down if you go through a <classname>std::"
+"string</classname>, e.g. by inputting text from a stream to a "
+"<classname>std::string</classname> and then implicitly converting it to a "
+"<classname>Glib::ustring</classname>. If the string contained non-ASCII "
+"characters and the current locale is not UTF-8 encoded, the result is a "
+"corrupted <classname>Glib::ustring</classname>. You can work around this "
+"with a manual conversion. For instance, to retrieve the <classname>std::"
+"string</classname> from a <classname>ostringstream</classname>: <placeholder-"
+"1/>"
+msgstr ""
+"Malheureusement, l'intégration avec les flux d'entrée-sortie standards n'est "
+"pas d'une utilisation très simple. Si vous dirigez la sortie du flux "
+"standard vers un <classname>ostream</classname> avec l'opérateur "
+"<function>operator<<</function>, <application>gtkmm</application> "
+"convertit les <classname>Glib::ustring</classname> dans un encodage "
+"spécifique à l'environnement linguistique (qui généralement n'est pas UTF-"
+"8). De la même façon, en récupérant des objets <classname>Glib::ustring</"
+"classname> Ã partir d'un flux <classname>istream</classname> avec "
+"l'opérateur <function>operator>></function>, vous déclenchez la "
+"conversion inverse. Mais ce schéma s'effondre si vous passez par un "
+"<classname>std::string</classname>, par exemple en dirigeant un flux de "
+"texte vers un <classname>std::string</classname> puis en le convertissant "
+"de manière implicite en <classname>Glib::ustring</classname>. Si la chaîne "
+"contenait des caractères non-ASCII et que l'environnement linguistique local "
+"n'est pas codé en UTF-8, il en résulte un objet <classname>Glib::ustring</"
+"classname> corrompu. Vous pouvez contourner ce problème avec une conversion "
+"manuelle. Par exemple, pour retrouver l'objet <classname>std::string</"
+"classname> Ã partir d'un <classname>ostringstream</classname>Â : <placeholder-"
+"1/>"
+
+#: C/gtkmm-tutorial-in.xml:6721(title)
+msgid "Pitfalls"
+msgstr "Embûches"
+
+#: C/gtkmm-tutorial-in.xml:6723(para)
+msgid ""
+"There are a few common mistakes that you would discover eventually yourself. "
+"But this section might help you to avoid them."
+msgstr ""
+"Voici quelques erreurs courantes que vous découvririez peut-être par vous-"
+"même. Mais il se peut que ce paragraphe vous aide à les éviter."
+
+#: C/gtkmm-tutorial-in.xml:6726(title)
+msgid "Same strings, different semantics"
+msgstr "Mêmes chaînes, sémantiques différentes"
+
+#: C/gtkmm-tutorial-in.xml:6728(para)
+msgid ""
+"Sometimes two english strings are identical but have different meanings in "
+"different contexts, so they would probably not be identical when translated. "
+"Since the English strings are used as look-up keys, this causes problems."
+msgstr ""
+"Quelquefois deux chaînes en anglais sont identiques, mais ont des "
+"significations différentes selon le contexte ; elles ne mériteraient donc "
+"probablement pas d'être traduites de la même façon. Comme les chaînes en "
+"anglais sont utilisées comme clés de recherche, cela pose problème."
+
+#: C/gtkmm-tutorial-in.xml:6732(para)
+msgid ""
+"In these cases, you should add extra characters to the strings. For "
+"instance, use <literal>\"jumps[noun]\"</literal> and <literal>\"jumps[verb]"
+"\"</literal> instead of just <literal>\"jumps\"</literal>) and strip them "
+"again outside the <function>gettext</function> call. If you add extra "
+"characters you should also add a comment for the translators before the "
+"<function>gettext</function> call. Such comments will be shown in the "
+"<filename>.po</filename> files. For instance:"
+msgstr ""
+"Dans ce cas, vous pouvez ajouter des caractères supplémentaires à la chaîne. "
+"Par exemple, écrivez <literal>\"jumps[noun]\"</literal> et <literal>\"jumps"
+"[verb]\"</literal> au lieu de <literal>\"jumps\"</literal> uniquement et "
+"extrayez-les à nouveau avec un appel à <function>gettext</function>. Si vous "
+"ajoutez des caractères supplémentaires, vous devez également ajouter un "
+"commentaire pour les traducteurs avant l'appel de <function>gettext</"
+"function>. De tels commentaires s'affichent dans les fichiers <filename>.po</"
+"filename>. Par exemple :"
+
+#: C/gtkmm-tutorial-in.xml:6742(programlisting)
+#, no-wrap
+msgid ""
+"// note to translators: don't translate the \"[noun]\" part - it is\n"
+"// just here to distinguish the string from another \"jumps\" string\n"
+"text = strip(gettext(\"jumps[noun]\"), \"[noun]\");"
+msgstr ""
+"// note to translators: don't translate the \"[noun]\" part - it is\n"
+"// just here to distinguish the string from another \"jumps\" string\n"
+"text = strip(gettext(\"jumps[noun]\"), \"[noun]\");"
+
+#: C/gtkmm-tutorial-in.xml:6748(title)
+msgid "Composition of strings"
+msgstr "Composition de chaînes"
+
+#: C/gtkmm-tutorial-in.xml:6750(para)
+msgid ""
+"C programmers use <function>sprintf()</function> to compose and concatenate "
+"strings. C++ favours streams, but unfortunately, this approach makes "
+"translation difficult, because each fragment of text is translated "
+"separately, without allowing the translators to rearrange them according to "
+"the grammar of the language."
+msgstr ""
+"Les programmeurs C se servent de la fonction <function>sprintf()</function> "
+"pour composer et concaténer des chaînes. Le C++ favorise les flux, mais "
+"malheureusement, cette approche rend la traduction difficile, parce que "
+"chaque fragment de texte est traduit séparément sans permettre aux "
+"traducteurs de les ré-agencer selon la grammaire de la langue."
+
+#: C/gtkmm-tutorial-in.xml:6757(para)
+msgid "For instance, this code would be problematic:"
+msgstr "Par exemple, ce code risque d'être sujet à problèmes :"
+
+#: C/gtkmm-tutorial-in.xml:6759(programlisting)
+#, no-wrap
+msgid ""
+"std::cout << _(\"Current amount: \") << amount\n"
+" << _(\" Future: \") << future << std::endl;\n"
+"\n"
+"label.set_text(_(\"Really delete \") + filename + _(\" now?\"));"
+msgstr ""
+"std::cout << _(\"Current amount: \") << amount\n"
+" << _(\" Future: \") << future << std::endl;\n"
+"\n"
+"label.set_text(_(\"Really delete \") + filename + _(\" now?\"));"
+
+#: C/gtkmm-tutorial-in.xml:6764(para)
+msgid ""
+"So you should either avoid this situation or revert to the C-style "
+"<function>sprintf()</function>. One possible solution is the <ulink url="
+"\"http://www.cs.auc.dk/~olau/compose/\">compose library</ulink> which "
+"supports syntax such as:"
+msgstr ""
+"Vous devez, soit éviter de tels cas, soit revenir à la fonction "
+"<function>sprintf()</function> du style C. Une autre solution possible est "
+"d'utiliser la <ulink url=\"http://www.cs.auc.dk/~olau/compose/"
+"\">bibliothèque compose</ulink> qui prend en charge des syntaxes telles que :"
+
+#: C/gtkmm-tutorial-in.xml:6771(programlisting)
+#, no-wrap
+msgid "label.set_text(compose(_(\"Really delete %1 now?\"), filename));"
+msgstr "label.set_text(compose(_(\"Really delete %1 now?\"), filename));"
+
+#: C/gtkmm-tutorial-in.xml:6775(title)
+msgid "Assuming the displayed size of strings"
+msgstr "Hypothèse concernant la taille d'affichage des chaînes"
+
+#: C/gtkmm-tutorial-in.xml:6777(para)
+msgid ""
+"You never know how much space a string will take on screen when translated. "
+"It might very possibly be twice the size of the original English string. "
+"Luckily, most <application>gtkmm</application> widgets will expand at "
+"runtime to the required size."
+msgstr ""
+"Vous ne savez jamais quel sera l'espace pris à l'écran par une chaîne après "
+"traduction. Il est tout à fait possible qu'elle soit deux fois plus longue "
+"que la chaîne originelle en anglais. Par chance, la plupart des éléments "
+"graphiques <application>gtkmm</application> se redimensionnent à la taille "
+"voulue lors de l'exécution."
+
+#: C/gtkmm-tutorial-in.xml:6781(title)
+msgid "Unusual words"
+msgstr "Mots inhabituels"
+
+#: C/gtkmm-tutorial-in.xml:6783(para)
+msgid ""
+"You should avoid cryptic abbreviations, slang, or jargon. They are usually "
+"difficult to translate, and are often difficult for even native speakers to "
+"understand. For instance, prefer \"application\" to \"app\""
+msgstr ""
+"Vous devez éviter les abréviations mystérieuses, l'argot ou du jargon de "
+"spécialiste. Ces termes sont généralement difficiles à traduire et souvent "
+"même à comprendre pour les autochtones. Par exemple, préférez « application » "
+"à « app »."
+
+#: C/gtkmm-tutorial-in.xml:6789(title)
+msgid "Using non-ASCII characters in strings"
+msgstr "Utilisation de caractères non-ASCII dans les chaînes"
+
+#: C/gtkmm-tutorial-in.xml:6791(para)
+msgid ""
+"Currently, <application>gettext</application> does not support non-ASCII "
+"characters (i.e. any characters with a code above 127) in source code. For "
+"instance, you cannot use the copyright sign (©)."
+msgstr ""
+"Actuellement, <application>gettext</application> ne prend pas en charge les "
+"caractères non-ASCII (c'est-à -dire tout caractère de code supérieur à 127) "
+"dans le code source. Par exemple, vous ne pouvez pas utiliser le signe de "
+"copyright (©)."
+
+#: C/gtkmm-tutorial-in.xml:6797(para)
+msgid ""
+"To work around this, you could write a comment in the source code just "
+"before the string, telling the translators to use the special character if "
+"it is available in their languages. For english, you could then make an "
+"American English <filename>en_US.po</filename> translation which used that "
+"special charactger."
+msgstr ""
+"Pour contourner ce problème, vous pouvez écrire un commentaire dans le code "
+"source juste avant la chaîne, indiquant au traducteur qu'il peut utiliser le "
+"caractère spécial s'il est disponible dans leur langue. Pour l'anglais, vous "
+"pouvez ensuite faire une traduction américain-anglais dans <filename>en_US."
+"po</filename> en utilisant ce caractère spécial."
+
+#: C/gtkmm-tutorial-in.xml:6805(title)
+msgid "Getting help with translations"
+msgstr "Obtenir de l'aide avec les traductions"
+
+#: C/gtkmm-tutorial-in.xml:6807(para)
+msgid ""
+"If your program is free software, there is a whole <literal>GNOME</literal> "
+"subproject devoted to helping you make translations, the <ulink url=\"http://"
+"developer.gnome.org/projects/gtp/\"><literal>GNOME</literal> Translation "
+"Project</ulink>."
+msgstr ""
+"Si votre programme est un logiciel libre, il existe un sous-projet complet "
+"<literal>GNOME</literal> dédié à l'aide à la traduction, le <ulink url="
+"\"http://developer.gnome.org/projects/gtp/\">Projet de traduction "
+"<literal>GNOME</literal></ulink> (GNOME Translation Project)."
+
+#: C/gtkmm-tutorial-in.xml:6812(para)
+msgid ""
+"The way it works is that you contact the gnome-i18n mailing list to find out "
+"how the translators can access your <filename>po/</filename> subdirectory, "
+"and to add your project to the big <ulink url=\"http://developer.gnome.org/"
+"projects/gtp/status/\">status tables</ulink>."
+msgstr ""
+"Voici comment il fonctionne : contactez la liste de diffusion gnome-i18n "
+"pour indiquer comment les traducteurs pourraient avoir accès à votre sous-"
+"répertoire <filename>po/</filename> et pour ajouter votre projet aux grands "
+"<ulink url=\"http://developer.gnome.org/projects/gtp/status/\">tableaux "
+"d'état</ulink>."
+
+#: C/gtkmm-tutorial-in.xml:6819(para)
+msgid ""
+"Then you make sure you update the file <filename>POTFILES.in</filename> in "
+"the <filename>po/</filename> subdirectory (<command>intltool-update -M</"
+"command> can help with this) so that the translators always access updated "
+"<filename>myprogram.pot</filename> files, and simply freeze the strings at "
+"least a couple of days before you make a new release, announcing it on gnome-"
+"i18n. Depending on the number of strings your program contains and how "
+"popular it is, the translations will then start to tick in as "
+"<filename>languagename.po</filename> files."
+msgstr ""
+"Assurez-vous que le fichier <filename>POTFILES.in</filename> dans le sous-"
+"répertoire <filename>po/</filename> est à jour (la commande "
+"<command>intltoolâ??update -M</command> peut vous aider pour cela) de façon à "
+"ce que les traducteurs aient toujours accès à des fichiers "
+"<filename>mon_programme.pot</filename> actualisés et gelez tout simplement "
+"les chaînes au moins quelques jours avant de téléverser une nouvelle version "
+"en l'annonçant sur gnome-i18n. Selon le nombre de chaînes que votre "
+"programme comporte et selon sa popularité, les traductions vont alors "
+"commencer à apparaître dans les fichiers <filename>nom_de_langue.po</"
+"filename>."
+
+#: C/gtkmm-tutorial-in.xml:6831(para)
+msgid ""
+"Note that most language teams only consist of 1-3 persons, so if your "
+"program contains a lot of strings, it might last a while before anyone has "
+"the time to look at it. Also, most translators do not want to waste their "
+"time (translating is a very time-consuming task) so if they do not assess "
+"your project as being really serious (in the sense that it is polished and "
+"being maintained) they may decide to spend their time on some other project."
+msgstr ""
+"Notez que la plupart des équipes de traducteurs ne sont constituées que de 1 "
+"à 3 personnes ; donc, si votre programme comporte beaucoup de chaînes, cela "
+"peut prendre beaucoup de temps avant que quelqu'un ait le temps d'y jeter un "
+"coup d'Å?il. De plus, pas mal de traducteurs ne souhaitent pas dilapider leur "
+"temps (la traduction est une tâche très consommatrice de temps) donc, il ne "
+"prendront en charge votre projet que s'il est vraiment sérieux (dans le "
+"sens, travaillé et maintenu) ; si ce n'est pas le cas il peuvent décider de "
+"s'occuper sur d'autres projets."
+
+#: C/gtkmm-tutorial-in.xml:6843(title) C/gtkmm-tutorial-in.xml:6932(title)
+msgid "Custom Widgets"
+msgstr "�léments graphiques personnalisés"
+
+#: C/gtkmm-tutorial-in.xml:6845(para)
+msgid ""
+"<application>gtkmm</application> makes it very easy to derive new widgets by "
+"inheriting from an existing widget class, either by deriving from a "
+"container and adding child widgets, or by deriving from a single-item "
+"widget, and changing its behaviour. But you might occasionally find that no "
+"suitable starting point already exists. In this case, you can implement a "
+"widget from scratch."
+msgstr ""
+"<application>gtkmm</application> facilite la dérivation de nouveaux éléments "
+"graphiques par héritage à partir d'une classe d'élément graphique existante, "
+"soit par dérivation à partir d'un conteneur et en y ajoutant des éléments "
+"graphiques enfants, soit par dérivation d'un élément graphique simple en "
+"modifiant son comportement. Mais vous pouvez parfois trouver qu'il n'y a "
+"aucun point de départ convenable. Dans ce cas, vous pouvez implémenter un "
+"élément graphique de A à Z."
+
+#: C/gtkmm-tutorial-in.xml:6847(title)
+msgid "Custom Containers"
+msgstr "Conteneurs personnalisés"
+
+#: C/gtkmm-tutorial-in.xml:6850(para)
+msgid ""
+"<methodname>on_size_request()</methodname>: Calculate the minimum height and "
+"width needed by the container."
+msgstr ""
+"<methodname>on_size_request()</methodname>Â : calcule la hauteur et la "
+"largeur minimale nécessaires au conteneur."
+
+#: C/gtkmm-tutorial-in.xml:6851(para)
+msgid ""
+"<methodname>on_size_allocate()</methodname>: Position the child widgets, "
+"given the height and width that the container has actually been given."
+msgstr ""
+"<methodname>on_size_allocate()</methodname> : place les éléments graphiques "
+"enfants, compte tenu de la hauteur et de la largeur réellement attribuées au "
+"conteneur."
+
+#: C/gtkmm-tutorial-in.xml:6852(para)
+msgid ""
+"<methodname>forall_vfunc()</methodname>: Call the same callback for each of "
+"the children."
+msgstr ""
+"<methodname>forall_vfunc()</methodname> : appelle la même fonction de rappel "
+"pour chaque enfant."
+
+#: C/gtkmm-tutorial-in.xml:6853(para)
+msgid "<methodname>on_add()</methodname>:"
+msgstr "<methodname>on_add()</methodname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:6854(para)
+msgid "<methodname>on_remove()</methodname>:"
+msgstr "<methodname>on_remove()</methodname>Â :"
+
+#: C/gtkmm-tutorial-in.xml:6855(para)
+msgid ""
+"<methodname>child_type_vfunc()</methodname>: Return what type of child can "
+"be added."
+msgstr ""
+"<methodname>child_type_vfunc()</methodname>Â : renvoie le type d'enfant "
+"pouvant être ajouté."
+
+#: C/gtkmm-tutorial-in.xml:6848(para)
+msgid ""
+"When deriving from <classname>Gtk::Container</classname>, you should "
+"override the following virtual methods: <placeholder-1/>"
+msgstr ""
+"Quand vous dérivez de la classe <classname>Gtk::Container</classname>, vous "
+"pouvez surdéfinir les fonctions membres virtuelles suivantes : <placeholder-"
+"1/>"
+
+#: C/gtkmm-tutorial-in.xml:6859(para)
+msgid ""
+"The <methodname>on_size_request()</methodname> and "
+"<methodname>on_size_allocate()</methodname> virtual methods control the "
+"layout of the child widgets. For instance, if your container has 2 child "
+"widgets, with one below the other, your <methodname>on_size_request()</"
+"methodname> might report the maximum of their widths and the sum of their "
+"heights. If you want padding between the child widgets then you would add "
+"that to the width and height too. Your widget's container will use this "
+"result to ensure that your widget gets enough space, and not less. By "
+"examining each widget's parent, and its parent, this logic will eventually "
+"decide the size of the top-level window."
+msgstr ""
+"Les fonctions membres virtuelles <methodname>on_size_request()</methodname> "
+"et <methodname>on_size_allocate()</methodname> contrôlent la disposition des "
+"éléments graphiques enfants. Par exemple, si votre conteneur possède deux "
+"éléments graphiques enfants, l'un au dessus de l'autre, votre fonction "
+"membre <methodname>on_size_request()</methodname> doit renvoyer la plus "
+"grande des deux largeurs et la somme des hauteurs. Si vous voulez de "
+"l'espace libre autour les éléments graphiques enfants, vous devez également "
+"l'additionner à la largeur et à la hauteur. Votre conteneur de widgets se "
+"sert de ces résultats pour s'assurer que vos widgets ont assez de place. En "
+"examinant chaque parent de l'élément graphique, et les parents de celui-ci, "
+"cela détermine logiquement la taille de la fenêtre de plus haut niveau."
+
+#: C/gtkmm-tutorial-in.xml:6871(para)
+msgid ""
+"<methodname>on_size_allocate()</methodname>, however, receives the actual "
+"height and width that the parent container has decided to give to your "
+"widget. This might be more than the minimum, for instance if the top-level "
+"window has been expanded. You might choose to ignore the extra space and "
+"leave a blank area, or you might choose to expand your child widgets to fill "
+"the space, or you might choose to expand the padding between your widgets. "
+"Its your container, so you decide. Don't forget to call "
+"<methodname>set_allocation()</methodname> inside your "
+"<methodname>on_size_allocate()</methodname> implementation to actually use "
+"the allocated space that has been offered by the parent container."
+msgstr ""
+"<methodname>on_size_allocate()</methodname>, toutefois, reçoit les vraies "
+"hauteur et largeur que le conteneur parent a décidé de donner à l'élément "
+"graphique. Cela peut être plus que le minimum, par exemple, si la fenêtre de "
+"haut niveau a été agrandie. Vous pouvez choisir d'ignorer l'espace "
+"supplémentaire et laisser la zone inoccupée, ou bien vous pouvez choisir "
+"d'agrandir vos éléments graphiques enfants pour remplir cet espace, ou bien "
+"encore vous pouvez choisir d'augmenter l'espace libre entre vos éléments "
+"graphiques. C'est votre conteneur, à vous de décider. N'oubliez pas "
+"d'appeler <methodname>set_allocation()</methodname> à l'intérieur de votre "
+"implémentation de <methodname>on_size_allocate()</methodname> pour utiliser "
+"effectivement l'espace alloué offert par le conteneur parent."
+
+#: C/gtkmm-tutorial-in.xml:6882(para)
+msgid ""
+"Unless your container is a top-level window that derives from "
+"<classname>Gtk::Window</classname>, you should also call <methodname>Gtk::"
+"Container::set_flags(Gtk::NO_WINDOW)</methodname> in your constructor. "
+"Otherwise, your container will appear in its own window, regardless of what "
+"container you put it in. And unless your container draws directly onto the "
+"underlying <classname>Gdk::Window</classname>, you should probably call "
+"<methodname>set_redraw_on_allocate(false)</methodname> to improve "
+"performance."
+msgstr ""
+"� moins que votre conteneur ne soit une fenêtre de haut niveau dérivée de "
+"<classname>Gtk::Window</classname>, vous devez également appeler "
+"<methodname>Gtk::Container::set_flags(Gtk::NO_WINDOW)</methodname> dans le "
+"constructeur. Sinon, votre conteneur serait affiché dans sa propre fenêtre, "
+"quel que soit le conteneur dans lequel il a été placé. Et, sauf si votre "
+"conteneur dessine directement dans la <classname>Gdk::Window</classname> "
+"sous-jacente, vous devrez probablement appeller "
+"<methodname>set_redraw_on_allocate(false)</methodname> pour améliorer les "
+"performances."
+
+#: C/gtkmm-tutorial-in.xml:6892(para)
+msgid ""
+"By overriding <methodname>forall_vfunc()</methodname> you can allow "
+"applications to operate on all of the container's child widgets. For "
+"instance, <methodname>show_all_children()</methodname> uses this to find all "
+"the child widgets and show them."
+msgstr ""
+"En surdéfinissant <methodname>forall_vfunc()</methodname> vous permettez "
+"aux applications d'opérer sur tous les éléments graphiques enfants du "
+"conteneur. Par exemple, <methodname>show_all_children()</methodname> utilise "
+"cette possibilité pour trouver tous les éléments graphiques enfants et les "
+"afficher."
+
+#: C/gtkmm-tutorial-in.xml:6897(para)
+msgid ""
+"Although your container might have its own method to set the child widgets, "
+"you should still provide an implementation for the virtual <methodname>on_add"
+"()</methodname> and <methodname>on_remove()</methodname> methods from the "
+"base class, so that the add() and remove() methods will do something "
+"appropriate if they are called."
+msgstr ""
+"Même si votre conteneur possède sa propre fonction membre pour définir ses "
+"éléments graphiques enfants, vous devez quand même fournir une "
+"implémentation des fonctions membres virtuelles <methodname>on_add()</"
+"methodname> et <methodname>on_remove()</methodname> de la classe de base de "
+"façon à ce que les fonctions membres add() et remove() fassent quelque chose "
+"d'approprié si elles sont appelées."
+
+#: C/gtkmm-tutorial-in.xml:6903(para)
+msgid ""
+"Your implementation of the <methodname>child_type_vfunc()</methodname> "
+"method should report the type of widget that may be added to your container, "
+"if it is not yet full. This is usually <methodname>Gtk::Widget::get_type()</"
+"methodname> to indicate that the container may contain any class derived "
+"from <classname>Gtk::Widget</classname>. If the container may not contain "
+"any more widgets, then this method should return <literal>G_TYPE_NONE</"
+"literal>."
+msgstr ""
+"Votre implémentation de la fonction membre <methodname>child_type_vfunc()</"
+"methodname> doit renvoyer le type d'élément graphique pouvant être ajouté à "
+"votre conteneur s'il n'est pas encore rempli. Généralement, c'est à "
+"<methodname>Gtk::Widget::get_type()</methodname> d'indiquer quelles sont les "
+"classes dérivées de <classname>Gtk::Widget</classname> acceptées. Si le "
+"conteneur ne peut plus contenir d'autres éléments graphiques, cette fonction membre doit "
+"renvoyer la valeur <literal>G_TYPE_NONE</literal>."
+
+#: C/gtkmm-tutorial-in.xml:6915(para)
+msgid ""
+"This example implements a container with two child widgets, one above the "
+"other. Of course, in this case it would be far simpler just to use a "
+"<classname>Gtk::VBox</classname>."
+msgstr ""
+"Cet exemple implémente un conteneur avec deux éléments graphiques enfants, "
+"l'un au dessus de l'autre. Bien entendu, dans ce cas il aurait été de loin "
+"beaucoup plus simple d'utiliser <classname>Gtk::VBox</classname>."
+
+#: C/gtkmm-tutorial-in.xml:6920(title)
+msgid "Custom Container"
+msgstr "Conteneur personnalisé"
+
+#: C/gtkmm-tutorial-in.xml:6933(para)
+msgid ""
+"By deriving directly from <classname>Gtk::Widget</classname> you can do all "
+"the drawing for your widget directly, instead of just arranging child "
+"widgets. For instance, a <classname>Gtk::Label</classname> draws the text of "
+"the label, but does not do this by using other widgets."
+msgstr ""
+"En dérivant directement de la classe <classname>Gtk::Widget</classname>, "
+"vous pouvez faire tous les dessins voulus directement dans votre élément "
+"graphique plutôt que seulement placer des éléments graphiques enfants. Par "
+"exemple, un objet <classname>Gtk::Label</classname> écrit directement le "
+"texte de l'étiquette sans passer par l'intermédiaire d'autres éléments "
+"graphiques."
+
+#: C/gtkmm-tutorial-in.xml:6941(para)
+msgid "This example implements a widget which draws a Penrose triangle."
+msgstr ""
+"Cet exemple implémente un élément graphique qui trace un triangle de Penrose."
+
+#: C/gtkmm-tutorial-in.xml:6944(title)
+msgid "Custom Widget"
+msgstr "�lément graphique personnalisé"
+
+#: C/gtkmm-tutorial-in.xml:6960(title)
+msgid "Recommended Techniques"
+msgstr "Techniques recommandées"
+
+#: C/gtkmm-tutorial-in.xml:6962(para)
+msgid ""
+"This section is simply a gathering of wisdom, general style guidelines and "
+"hints for creating <application>gtkmm</application> applications."
+msgstr ""
+"Ce chapitre est simplement un condensé de pratiques de bon sens, de lignes "
+"directrices générales, et de conseils pour créer des applications "
+"<application>gtkmm</application>."
+
+#: C/gtkmm-tutorial-in.xml:6966(para)
+msgid ""
+"Use GNU <application>autoconf</application> and <application>automake</"
+"application>! They are your friends :) <application>Automake</application> "
+"examines C files, determines how they depend on each other, and generates a "
+"<filename>Makefile</filename> so the files can be compiled in the correct "
+"order. <application>Autoconf</application> permits automatic configuration "
+"of software installation, handling a large number of system quirks to "
+"increase portability.."
+msgstr ""
+"Utilisez <application>autoconf</application> et <application>automake</"
+"application> de GNUÂ ! Ce sont des amis :) <application>Automake</"
+"application> examine les fichiers C, détermine leurs dépendances mutuelles "
+"et génère un <filename>Makefile</filename> ; ainsi les fichiers peuvent être "
+"compilés dans le bon ordre. <application>Autoconf</application> permet une "
+"configuration automatique de l'installation du logiciel en gérant un grand "
+"nombre de systèmes exotiques pour augmenter la portabilité."
+
+#: C/gtkmm-tutorial-in.xml:6976(para)
+msgid ""
+"Subclass Widgets to better organize your code. You should probably subclass "
+"your main <classname>Window</classname> at least. Then you can make your "
+"child Widgets and signal handlers members of that class."
+msgstr ""
+"Sous-classez vos éléments graphiques pour mieux organiser votre code. Vous "
+"devrez probablement sous-classer au moins votre fenêtre principale "
+"<classname>Window</classname>. Ensuite, vous pouvez faire des éléments "
+"graphiques enfants et des fonctions membres gestionnaires des signaux de "
+"cette classe."
+
+#: C/gtkmm-tutorial-in.xml:6981(para)
+msgid ""
+"Create your own signals instead of passing pointers around. Objects can "
+"communicate with each other via signals and signal handlers. This is much "
+"simpler than objects holding pointers to each other and calling each other's "
+"methods. <application>gtkmm</application>'s classes uses special versions of "
+"<classname>sigc::signal</classname>, but you should use normal "
+"<classname>sigc::signal</classname>s, as described in the "
+"<application>libsigc++</application> documentation."
+msgstr ""
+"Créez vos propres signaux au lieu de transmettre des pointeurs. Les objets "
+"peuvent communiquer entre eux par l'intermédiaire de signaux et de "
+"gestionnaires de signaux. C'est plus simple que des objets enregistrant des "
+"pointeurs vers d'autres objets, et vice versa, en appelant mutuellement "
+"leurs fonctions membres. Les classes de <application>gtkmm</application> "
+"utilisent une version spéciale de <classname>sigc::signal</classname>, mais "
+"vous pouvez utiliser les signaux normaux tels que décrits dans la "
+"documentation de <application>libsigc++</application>."
+
+#: C/gtkmm-tutorial-in.xml:6990(title)
+msgid "Application Lifetime"
+msgstr "Durée de vie d'une application"
+
+#: C/gtkmm-tutorial-in.xml:6991(para)
+msgid ""
+"Most applications will have only one <classname>Window</classname>, or only "
+"one main window. These applications can use the <methodname>Gtk::Main::run"
+"(Gtk::Window&)</methodname> overload. It shows the window and returns "
+"when the window has been hidden. This might happen when the user closes the "
+"window, or when your code decides to <methodname>hide()</methodname> the "
+"window. You can prevent the user from closing the window (for instance, if "
+"there are unsaved changes) by overriding <methodname>Gtk::Window::"
+"on_delete_event()</methodname>."
+msgstr ""
+"La plupart des applications ne disposent que d'une fenêtre de la classe "
+"<classname>Window</classname>, ou uniquement une fenêtre principale. Ces "
+"applications peuvent utiliser la surdéfinition de <methodname>Gtk::Main::run"
+"(Gtk::Window&)</methodname>. Elle affiche la fenêtre et rend la main "
+"quand la fenêtre a été cachée. Ceci se produit quand l'utilisateur ferme la "
+"fenêtre ou quand le code applique la fonction <methodname>hide()</"
+"methodname> sur la fenêtre. Vous pouvez empêcher l'utilisateur de fermer la "
+"fenêtre (par exemple, s'il y a des modifications non enregistrées) en "
+"surdéfinissant <methodname>Gtk::Window::on_delete_event()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:6999(para)
+msgid "Most of our examples use this technique."
+msgstr "La plupart de nos exemples utilisent cette technique."
+
+#: C/gtkmm-tutorial-in.xml:7003(title)
+msgid "Using a <application>gtkmm</application> widget"
+msgstr "Utilisation d'un élément graphique <application>gtkmm</application>"
+
+#: C/gtkmm-tutorial-in.xml:7005(para)
+msgid ""
+"Our examples all tend to have the same structure. They follow these steps "
+"for using a <classname>Widget</classname>:"
+msgstr ""
+"Nos exemples adoptent tous la même structure. Ils suivent ces étapes pour "
+"l'utilisation d'un <classname>�lément graphique</classname> :"
+
+#: C/gtkmm-tutorial-in.xml:7014(para)
+msgid ""
+"Declare a variable of the type of <classname>Widget</classname> you wish to "
+"use, generally as member variable of a derived container class. You could "
+"also declare a pointer to the widget type, and then create it with "
+"<literal>new</literal> in your code. Even when using the widget via a "
+"pointer, it's still probably best to make that pointer a member variable of "
+"a container class so that you can access it later."
+msgstr ""
+"Déclarer une variable du type de l'<classname>�lément graphique</classname> "
+"que vous souhaitez utiliser, généralement en tant que variable membre d'une "
+"classe conteneur dérivée. Vous pouvez également déclarer un pointeur sur le "
+"type de l'élément graphique et le créer avec <literal>new</literal> dans "
+"votre code. Même si vous utilisez l'élément graphique par l'intermédiaire "
+"d'un pointeur, ce sera probablement mieux de faire en sorte que ce pointeur "
+"soit une variable membre d'une classe conteneur ; vous pouvez ainsi y "
+"accéder ultérieurement."
+
+#: C/gtkmm-tutorial-in.xml:7025(para)
+msgid ""
+"Set the attributes of the widget. If the widget has no default constructor, "
+"then you will need to initialize the widget in the initalizer list of your "
+"container class's constructor."
+msgstr ""
+"Définissez les attributs de l'élément graphique. Si l'élément graphique n'a "
+"pas de constructeur par défaut, vous devez l'initialiser à l'aide de la "
+"liste d'initialisations du constructeur de la classe conteneur."
+
+#: C/gtkmm-tutorial-in.xml:7031(para)
+msgid "Connect any signals you wish to use to the appropriate handlers."
+msgstr ""
+"Connectez tout signal que vous souhaitez utiliser aux gestionnaires "
+"appropriés."
+
+#: C/gtkmm-tutorial-in.xml:7037(para)
+msgid ""
+"Pack the widget into a container using the appropriate call, e.g. "
+"<methodname>Gtk::Container::add()</methodname> or <methodname>pack_start()</"
+"methodname>."
+msgstr ""
+"Empaquetez l'élément graphique dans un conteneur par un appel approprié, par "
+"exemple <methodname>Gtk::Container::add()</methodname> ou "
+"<methodname>pack_start()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:7045(para)
+msgid "Call <methodname>show()</methodname> to display the widget."
+msgstr ""
+"Appelez <methodname>show()</methodname> pour afficher l'élément graphique."
+
+#: C/gtkmm-tutorial-in.xml:7054(para)
+msgid ""
+"<methodname>Gtk::Widget::show()</methodname> lets <application>gtkmm</"
+"application> know that we have finished setting the attributes of the "
+"widget, and that it is ready to be displayed. You can use <methodname>Gtk::"
+"Widget::hide()</methodname> to make it disappear again. The order in which "
+"you show the widgets is not important, but we do suggest that you show the "
+"top-level window last; this way, the whole window will appear with its "
+"contents already drawn. Otherwise, the user will first see a blank window, "
+"into which the widgets will be gradually drawn."
+msgstr ""
+"<methodname>Gtk::Widget::show()</methodname> fait savoir à "
+"<application>gtkmm</application> que vous avez terminé de définir les "
+"attributs de l'élément graphique et qu'il est prêt à être affiché. Vous "
+"pouvez utiliser <methodname>Gtk::Widget::hide()</methodname> pour le faire "
+"disparaître à nouveau. L'ordre dans lequel vous affichez les éléments "
+"graphiques n'a pas d'importance, mais nous suggérons de n'afficher qu'en "
+"dernier la fenêtre de plus haut niveau ; ainsi, la fenêtre globale apparaît "
+"en ayant tout son contenu déjà dessinée. Sinon, l'utilisateur voit d'abord "
+"une fenêtre vierge dans laquelle les éléments graphiques sont tracés "
+"progressivement."
+
+#: C/gtkmm-tutorial-in.xml:7068(title)
+msgid "Contributing"
+msgstr "Comment contribuer"
+
+#: C/gtkmm-tutorial-in.xml:7070(para)
+msgid ""
+"This document, like so much other great software out there, was created for "
+"free by volunteers. If you are at all knowledgeable about any aspect of "
+"<application>gtkmm</application> that does not already have documentation, "
+"please consider contributing to this document."
+msgstr ""
+"Ce document, comme beaucoup d'autres grands logiciels, a été créé "
+"gratuitement par des bénévoles. Si vous avez des compétences sur un des "
+"aspects de <application>gtkmm</application> qui ne serait pas déjà "
+"documenté, il serait aimable à vous d'envisager une contribution à ce "
+"document."
+
+#: C/gtkmm-tutorial-in.xml:7076(para)
+msgid ""
+"Ideally, we would like you to <ulink url=\"http://www.gtkmm.org/bugs.shtml"
+"\">provide a patch</ulink> to the <filename>docs/tutorial/C/gtkmm-tutorial-"
+"in.xml</filename> file. This file is currently in the <literal>gtkmm-"
+"documentation</literal> module in GNOME git."
+msgstr ""
+"L'idéal serait que vous <ulink url=\"http://www.gtkmm.org/bugs.shtml"
+"\">fournissiez un patch</ulink> pour le fichier <filename>docs/tutorial/C/"
+"gtkmm-tutorial-in.xml</filename>. Ce fichier est actuellement dans le module "
+"<literal>gtkmm-documentation</literal> du dépôt git de GNOME."
+
+#: C/gtkmm-tutorial-in.xml:7082(para)
+msgid ""
+"If you do decide to contribute, please post your contribution to the "
+"<application>gtkmm</application> mailing list at <ulink url=\"mailto:gtkmm-"
+"list gnome org\"><gtkmm-list gnome org></ulink>. Also, be aware that "
+"the entirety of this document is free, and any addition you provide must "
+"also be free. That is, people must be able to use any portion of your "
+"examples in their programs, and copies of this document (including your "
+"contribution) may be distributed freely."
+msgstr ""
+"Si vous décidez de contribuer, veuillez poster votre contribution sur la "
+"liste de diffusion de <application>gtkmm</application> Ã l'adresse <ulink "
+"url=\"mailto:gtkmm-list gnome org\"><gtkmm-list gnome org></ulink>. "
+"�galement, prenez note que la totalité de ce document est libre et que tout "
+"ajout que vous feriez doit également être libre. Ce qui signifie que "
+"quiconque peut se servir de tout ou partie de vos exemples dans ses "
+"programmes et que les copies de ce document (y compris votre contribution) "
+"peuvent être diffusées gratuitement."
+
+#: C/gtkmm-tutorial-in.xml:7094(title)
+msgid "The RefPtr smartpointer"
+msgstr "Le pointeur intelligent RefPtr"
+
+#: C/gtkmm-tutorial-in.xml:7095(para)
+msgid ""
+"<classname>Glib::RefPtr</classname> is a smartpointer. Specifically, it is a "
+"reference-counting smartpointer. You might be familiar with <literal>std::"
+"auto_ptr<></literal>, which is also a smartpointer, but <literal>Glib::"
+"RefPtr<></literal> is much simpler, and more useful. We expect a "
+"future version of the C++ Standard Library to contain a reference-counting "
+"shared smartpointer, and a future version of <application>gtkmm</"
+"application> might possibly use that instead."
+msgstr ""
+"<classname>Glib::RefPtr</classname> est un pointeur intelligent. Plus "
+"précisément, c'est un pointeur intelligent à décompte de références. Vous "
+"connaissez déjà peut-être le <literal>std::auto_ptr<></literal>, qui "
+"est aussi un pointeur intelligent, mais <literal>Glib::RefPtr<></"
+"literal> est plus simple et plus utile. Nous espérons qu'une future version "
+"de la Bibliothèque Standard C++ contiendra un pointeur partagé intelligent à "
+"décompte de références ; une future version de <application>gtkmm</"
+"application> pourrait alors l'utiliser à la place."
+
+#: C/gtkmm-tutorial-in.xml:7105(para)
+msgid ""
+"A smartpointer acts much like a normal pointer. Here are a few examples."
+msgstr ""
+"Un pointeur intelligent se comporte plus ou moins comme un pointeur normal. "
+"Voici quelques exemples."
+
+#: C/gtkmm-tutorial-in.xml:7108(title)
+msgid "Copying"
+msgstr "Copie"
+
+#: C/gtkmm-tutorial-in.xml:7109(para)
+msgid ""
+"You can copy <classname>RefPtr</classname>s, just like normal pointers. But "
+"unlike normal pointers, you don't need to worry about deleting the "
+"underlying instance."
+msgstr ""
+"Vous pouvez copier les <classname>RefPtr</classname>, tout comme des "
+"pointeurs normaux. Mais contrairement aux pointeurs normaux, vous n'avez pas "
+"Ã vous soucier de la destruction de l'instance sous-jacente."
+
+#: C/gtkmm-tutorial-in.xml:7115(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap = Gdk::Bitmap::create(window,\n"
+"data, width, height);\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap2 = refBitmap;\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap = Gdk::Bitmap::create(window,\n"
+"data, width, height);\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap2 = refBitmap;\n"
+
+#: C/gtkmm-tutorial-in.xml:7121(para)
+msgid ""
+"Of course this means that you can store <classname>RefPtrs</classname> in "
+"standard containers, such as <classname>std::vector</classname> or "
+"<classname>std::list</classname>."
+msgstr ""
+"Cela signifie bien sûr que vous pouvez stocker les <classname>RefPtrs</"
+"classname> dans des conteneurs standards tels que <classname>std::vector</"
+"classname> ou <classname>std::list</classname>."
+
+#: C/gtkmm-tutorial-in.xml:7126(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"std::list< Glib::RefPtr<Gdk::Pixmap> > listPixmaps;\n"
+"Glib::RefPtr<Gdk::Pixmap> refPixmap = Gdk::Pixmap::create(window,\n"
+"width, height, depth);\n"
+"listPixmaps.push_back(refPixmap);\n"
+msgstr ""
+"\n"
+"std::list< Glib::RefPtr<Gdk::Pixmap> > listPixmaps;\n"
+"Glib::RefPtr<Gdk::Pixmap> refPixmap = Gdk::Pixmap::create(window,\n"
+"width, height, depth);\n"
+"listPixmaps.push_back(refPixmap);\n"
+
+#: C/gtkmm-tutorial-in.xml:7135(title)
+msgid "Dereferencing"
+msgstr "Déréférencement"
+
+#: C/gtkmm-tutorial-in.xml:7136(para)
+msgid ""
+"You can dereference a smartpointer with the -> operator, to call the "
+"methods of the underlying instance, just like a normal pointer."
+msgstr ""
+"Vous pouvez déréférencer un pointeur intelligent avec l'opérateur <literal>-"
+"></literal> pour appeler des fonctions membres de l'instance subjacente, "
+"comme pour un pointeur normal."
+
+#: C/gtkmm-tutorial-in.xml:7140(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap = Gdk::Bitmap::create(window,\n"
+"data, width, height);\n"
+"int depth = refBitmap->get_depth();\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap = Gdk::Bitmap::create(window,\n"
+"data, width, height);\n"
+"int depth = refBitmap->get_depth();\n"
+
+# BUG : shouldn't it be "But unlike most pointers..."?
+#: C/gtkmm-tutorial-in.xml:7146(para)
+msgid ""
+"But unlike most smartpointers, you can't use the * operator to access the "
+"underlying instance."
+msgstr ""
+"Mais contrairement à la plupart des pointeurs, vous ne pouvez pas utiliser "
+"l'opérateur <literal>*</literal> pour avoir accès à l'instance sous-jacente."
+
+#: C/gtkmm-tutorial-in.xml:7150(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap = Gdk::Bitmap::create(window,\n"
+"data, width, height);\n"
+"Gdk::Bitmap* underlying = *refBitmap; //Syntax error - will not compile.\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gdk::Bitmap> refBitmap = Gdk::Bitmap::create(window,\n"
+"data, width, height);\n"
+"Gdk::Bitmap* underlying = *refBitmap; // Erreur de syntaxe - ne compilera pas.\n"
+
+#: C/gtkmm-tutorial-in.xml:7158(title)
+msgid "Casting"
+msgstr "Forçage de type"
+
+#: C/gtkmm-tutorial-in.xml:7159(para)
+msgid ""
+"You can cast <classname>RefPtrs</classname> to base types, just like normal "
+"pointers."
+msgstr ""
+"Vous pouvez forcer les <classname>RefPtrs</classname> Ã des types de base, "
+"comme des pointeurs normaux."
+
+#: C/gtkmm-tutorial-in.xml:7164(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gtk::TreeStore> refStore = Gtk::TreeStore::create(columns);\n"
+"Glib::RefPtr<Gtk::TreeModel> refModel = refStore;\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gtk::TreeStore> refStore = Gtk::TreeStore::create(columns);\n"
+"Glib::RefPtr<Gtk::TreeModel> refModel = refStore;\n"
+
+#: C/gtkmm-tutorial-in.xml:7169(para)
+msgid ""
+"This means that any method which takes a <type>const Glib::RefPtr<"
+"BaseType></type> argument can also take a <type>const Glib::RefPtr<"
+"DerivedType></type>. The cast is implicit, just as it would be for a "
+"normal pointer."
+msgstr ""
+"Cela signifie que toute fonction membre prenant en paramètre un "
+"<literal>const Glib::RefPtr<BaseType></literal> peut également prendre "
+"un <literal>const Glib::RefPtr<DerivedType></literal>. Le forçage est "
+"implicite, tout comme pour un pointeur normal."
+
+#: C/gtkmm-tutorial-in.xml:7173(para)
+msgid ""
+"You can also cast to a derived type, but the syntax is a little different "
+"than with a normal pointer."
+msgstr ""
+"Vous pouvez aussi faire un forçage sur un type dérivé, mais la syntaxe est "
+"alors différente de celle pour un pointeur normal."
+
+#: C/gtkmm-tutorial-in.xml:7177(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gtk::TreeStore> refStore =\n"
+"Glib::RefPtr<Gtk::TreeStore>::cast_dynamic(refModel);\n"
+"Glib::RefPtr<Gtk::TreeStore> refStore2 =\n"
+"Glib::RefPtr<Gtk::TreeStore>::cast_static(refModel);\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gtk::TreeStore> refStore =\n"
+"Glib::RefPtr<Gtk::TreeStore>::cast_dynamic(refModel);\n"
+"Glib::RefPtr<Gtk::TreeStore> refStore2 =\n"
+"Glib::RefPtr<Gtk::TreeStore>::cast_static(refModel);\n"
+
+#: C/gtkmm-tutorial-in.xml:7187(title)
+msgid "Checking for null"
+msgstr "Vérification du pointeur NULL "
+
+#: C/gtkmm-tutorial-in.xml:7188(para)
+msgid ""
+"Just like normal pointers, you can check whether a <classname>RefPtr</"
+"classname> points to anything."
+msgstr ""
+"Comme pour les pointeurs normaux, vous pouvez vérifier si un pointeur "
+"<classname>RefPtr</classname> ne pointe sur rien."
+
+#: C/gtkmm-tutorial-in.xml:7193(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::RefPtr<Gtk::TreeModel> refModel = m_TreeView.get_model();\n"
+"if(refModel)\n"
+"{\n"
+" int cols_count = refModel->get_n_columns();\n"
+" ...\n"
+"}\n"
+msgstr ""
+"\n"
+"Glib::RefPtr<Gtk::TreeModel> refModel = m_TreeView.get_model();\n"
+"if(refModel)\n"
+"{\n"
+" int cols_count = refModel->get_n_columns();\n"
+" ...\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:7202(para)
+msgid ""
+"But unlike normal pointers, <classname>RefPtr</classname>s are automatically "
+"initialized to null so you don't need to remember to do that yourself."
+msgstr ""
+"Mais contrairement aux pointeurs normaux, les <classname>RefPtr</classname> "
+"sont automatiquement initialisés à NULL ; vous n'avez pas à faire cela vous-"
+"même."
+
+#: C/gtkmm-tutorial-in.xml:7209(title)
+msgid "Constness"
+msgstr "Constance"
+
+#: C/gtkmm-tutorial-in.xml:7210(para)
+msgid ""
+"The use of the <literal>const</literal> keyword in C++ is not always clear. "
+"You might not realise that <type>const Something*</type> declares a pointer "
+"to a <type>const Something</type>, The pointer can be changed, but not the "
+"<type>Something</type> that it points to."
+msgstr ""
+"L'utilisation du mot clé <literal>const</literal> dans le C++ n'est pas "
+"toujours claire. Vous ne devez pas penser que <literal>const Quelquechose*</"
+"literal> déclare un pointeur sur un type <literal>const Quelquechose</"
+"literal> ; le pointeur peut être modifié, mais pas le <literal>Quelquechose</"
+"literal> sur lequel il pointe."
+
+#: C/gtkmm-tutorial-in.xml:7216(para)
+msgid ""
+"Therefore, the <classname>RefPtr</classname> equivalent of <type>Something*</"
+"type> for a method parameter is <type>const Glib::RefPtr<Something>"
+"&</type>, and the equivalent of <type>const Something*</type> is "
+"<type>const Glib::RefPtr<const Something>&</type>."
+msgstr ""
+"Ainsi, l'équivalent <classname>RefPtr</classname> de <literal>Quelquechose*</"
+"literal> pour un paramètre de fonction membre est <literal>const Glib::"
+"RefPtr<Quelquechose>&</literal> et l'équivalent de <literal>const "
+"Quelquechose*</literal> est <literal>const Glib::RefPtr<const "
+"Quelquechose>&</literal>."
+
+#: C/gtkmm-tutorial-in.xml:7223(para)
+msgid ""
+"The <literal>const ... &</literal> around both is just for efficiency, "
+"like using <classname>const std::string&</classname> instead of "
+"<classname>std::string</classname> for a method parameter to avoid "
+"unnecessary copying."
+msgstr ""
+"Le <literal>const ... &</literal> qui entoure les deux expressions est "
+"juste une question d'efficacité, c'est comme utiliser <classname>const std::"
+"string&</classname> Ã la place de <classname>std::string</classname> "
+"pour un paramètre de fonction pour éviter une recopie non nécessaire."
+
+#: C/gtkmm-tutorial-in.xml:7238(title)
+msgid "Connecting signal handlers"
+msgstr "Connexion aux gestionnaires de signal"
+
+#: C/gtkmm-tutorial-in.xml:7239(para)
+msgid ""
+"<application>gtkmm</application> widget classes have signal accessor "
+"methods, such as <methodname>Gtk::Button::signal_clicked()</methodname>, "
+"which allow you to connect your signal handler. Thanks to the flexibility of "
+"<application>libsigc++</application>, the callback library used by "
+"<application>gtkmm</application>, the signal handler can be almost any kind "
+"of function, but you will probably want to use a class method. Among "
+"<application>GTK+</application> C coders, these signal handlers are often "
+"named callbacks."
+msgstr ""
+"Les classes d'éléments graphiques <application>gtkmm</application> ont des "
+"fonctions membres d'accès aux signaux, comme <methodname>Gtk::Button::"
+"signal_clicked()</methodname>, qui permettent de se connecter au "
+"gestionnaire de signal. Grâce à la souplesse de <application>libsigc++</"
+"application>, la bibliothèque utilisée par <application>gtkmm</application>, "
+"le gestionnaire de signal peut être n'importe quel type de fonction, mais "
+"vous souhaiterez probablement utiliser une fonction membre de la classe. Les "
+"programmeurs C de <application>GTK+</application> nomment souvent ces "
+"gestionnaires de signal « fonctions de rappel » (callback)."
+
+#: C/gtkmm-tutorial-in.xml:7249(para)
+msgid "Here's an example of a signal handler being connected to a signal:"
+msgstr "Voici un exemple de gestionnaire de signal connecté à un signal :"
+
+#: C/gtkmm-tutorial-in.xml:7254(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"#include <gtkmm/button.h>\n"
+"\n"
+"void on_button_clicked()\n"
+"{\n"
+" std::cout << \"Hello World\" << std::endl;\n"
+"}\n"
+"\n"
+"main()\n"
+"{\n"
+" Gtk::Button button(\"Hello World\");\n"
+" button.signal_clicked().connect(sigc::ptr_fun(&on_button_clicked));\n"
+"}\n"
+msgstr ""
+"\n"
+"#include <gtkmm/button.h>\n"
+"\n"
+"void on_button_clicked()\n"
+"{\n"
+" std::cout << \"Hello World\" << std::endl;\n"
+"}\n"
+"\n"
+"main()\n"
+"{\n"
+" Gtk::Button button(\"Hello World\");\n"
+" button.signal_clicked().connect(sigc::ptr_fun(&on_button_clicked));\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:7270(para)
+msgid ""
+"There's rather a lot to think about in this (non-functional) code. First "
+"let's identify the parties involved:"
+msgstr ""
+"Il y a un certain nombre de choses à considérer à propos de ce code (non "
+"fonctionnel). D'abord identifions les parties concernées :"
+
+#: C/gtkmm-tutorial-in.xml:7278(para)
+msgid "The signal handler is <methodname>on_button_clicked()</methodname>."
+msgstr ""
+"Le gestionnaire de signal est <methodname>on_button_clicked()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:7284(para)
+msgid ""
+"We're hooking it up to the <classname>Gtk::Button</classname> object called "
+"<varname>button</varname>."
+msgstr ""
+"Nous le raccrochons à l'objet <classname>Gtk::Button</classname> nommé "
+"<varname>button</varname>."
+
+#: C/gtkmm-tutorial-in.xml:7291(para)
+msgid ""
+"When the Button emits its <literal>clicked</literal> signal, "
+"<methodname>on_button_clicked()</methodname> will be called."
+msgstr ""
+"Quand le bouton émet le signal <literal>clicked</literal>, "
+"<methodname>on_button_clicked()</methodname> est appelé."
+
+#: C/gtkmm-tutorial-in.xml:7299(para)
+msgid "Now let's look at the connection again:"
+msgstr "Maintenant ré-examinons la connexion :"
+
+#: C/gtkmm-tutorial-in.xml:7304(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+" ...\n"
+" button.signal_clicked().connect(sigc::ptr_fun(&on_button_clicked));\n"
+" ...\n"
+msgstr ""
+"\n"
+" ...\n"
+" button.signal_clicked().connect(sigc::ptr_fun(&on_button_clicked));\n"
+" ...\n"
+
+#: C/gtkmm-tutorial-in.xml:7311(para)
+msgid ""
+"Note that we don't pass a pointer to <methodname>on_button_clicked()</"
+"methodname> directly to the signal's <methodname>connect()</methodname> "
+"method. Instead, we call <function>sigc::ptr_fun()</function>, and pass the "
+"result to <methodname>connect()</methodname>."
+msgstr ""
+"Notez que nous ne passons pas directement un pointeur sur "
+"<methodname>on_button_clicked()</methodname> Ã la fonction membre "
+"<methodname>connect()</methodname> du signal. Ã? la place, nous faisons appel "
+"à <function>sigc::ptr_fun()</function> et passons le résultat à "
+"<methodname>connect()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:7318(para)
+msgid ""
+"<function>sigc::ptr_fun()</function> generates a <classname>sigc::slot</"
+"classname>. A slot is an object which looks and feels like a function, but "
+"is actually an object. These are also known as function objects, or "
+"functors. <function>sigc::ptr_fun()</function> generates a slot for a "
+"standalone function or static method. <function>sigc::mem_fun()</function> "
+"generates a slot for a member method of a particular instance."
+msgstr ""
+"<function>sigc::ptr_fun()</function> génère un objet <classname>sigc::slot</"
+"classname>. Un connecteur est un objet qui ressemble et réagit comme une "
+"fonction, mais qui, en réalité, est bien un objet. Il est également connu "
+"sous le nom d'objet fonction ou « functor ». <function>sigc::ptr_fun()</"
+"function> génère un connecteur pour une fonction autonome ou une fonction "
+"membre statique. <function>sigc::mem_fun()</function> génère un connecteur "
+"pour une fonction membre d'une instance donnée."
+
+#: C/gtkmm-tutorial-in.xml:7327(para)
+msgid "Here's a slightly larger example of slots in action:"
+msgstr "Voici un exemple un peu plus développé de connecteurs en action :"
+
+#: C/gtkmm-tutorial-in.xml:7332(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"void on_button_clicked();\n"
+"\n"
+"class some_class\n"
+"{\n"
+" void on_button_clicked();\n"
+"};\n"
+"\n"
+"some_class some_object;\n"
+"\n"
+"main()\n"
+"{\n"
+" Gtk::Button button;\n"
+" button.signal_clicked().connect( sigc::ptr_fun(&on_button_clicked) );\n"
+" button.signal_clicked().connect( sigc::mem_fun(some_object, &some_class::on_button_clicked) );\n"
+"}\n"
+msgstr ""
+"\n"
+"void on_button_clicked();\n"
+"\n"
+"class some_class\n"
+"{\n"
+" void on_button_clicked();\n"
+"};\n"
+"\n"
+"some_class some_object;\n"
+"\n"
+"main()\n"
+"{\n"
+" Gtk::Button button;\n"
+" button.signal_clicked().connect( sigc::ptr_fun(&on_button_clicked) );\n"
+" button.signal_clicked().connect( sigc::mem_fun(some_object,\n"
+" &some_class::on_button_clicked) );\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:7351(para)
+msgid ""
+"The first call to <methodname>connect()</methodname> is just like the one we "
+"saw last time; nothing new here."
+msgstr ""
+"Le premier appel à <methodname>connect()</methodname> est identique à celui "
+"que nous avons vu la fois précédente ; rien de plus à dire."
+
+#: C/gtkmm-tutorial-in.xml:7354(para)
+msgid ""
+"The next is more interesting. <function>sigc::mem_fun()</function> is called "
+"with two arguments. The first argument is <parameter>some_object</"
+"parameter>, which is the object that our new slot will be pointing at. The "
+"second argument is a pointer to one of its methods. This particular version "
+"of <function>sigc::mem_fun()</function> creates a slot which will, when "
+"\"called\", call the pointed-to method of the specified object, in this case "
+"<methodname>some_object.on_button_clicked()</methodname>."
+msgstr ""
+"Le suivant est plus intéressant. <function>sigc::mem_fun()</function> est "
+"appelé avec deux paramètres. Le premier paramètre est "
+"<parameter>some_object</parameter>, qui est l'objet sur lequel notre nouveau "
+"connecteur pointe. Le second paramètre est un pointeur sur une de ses "
+"fonctions membres. Cette version particulière de <function>sigc::mem_fun()</"
+"function> crée un connecteur qui, quand il sera « appelé », fera lui-même "
+"appel à la fonction membre pointée de l'objet désigné, dans ce cas "
+"<methodname>some_object.on_button_clicked()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:7364(para)
+msgid ""
+"Another thing to note about this example is that we made the call to "
+"<methodname>connect()</methodname> twice for the same signal object. This is "
+"perfectly fine - when the button is clicked, both signal handlers will be "
+"called."
+msgstr ""
+"Autre chose à noter dans cet exemple : nous appelons <methodname>connect()</"
+"methodname> deux fois pour le même objet signal. Cela est parfaitement "
+"correct â?? quand le bouton est cliqué, les deux gestionnaires de signal sont "
+"appelés."
+
+#: C/gtkmm-tutorial-in.xml:7371(para)
+msgid ""
+"We just told you that the button's <literal>clicked</literal> signal is "
+"expecting to call a method with no arguments. All signals have requirements "
+"like this - you can't hook a function with two arguments to a signal "
+"expecting none (unless you use an adapter, such as <function>sigc::bind()</"
+"function>, of course). Therefore, it's important to know what type of signal "
+"handler you'll be expected to connect to a given signal."
+msgstr ""
+"Nous venons de vous dire que le signal <literal>clicked</literal> d'un "
+"bouton s'attend à appeler une fonction membre sans paramètre d'entrée. Tous "
+"les signaux ont des exigences de ce type â?? vous ne pouvez pas accrocher une "
+"fonction avec deux paramètres à un signal n'en attendant aucun (sauf si vous "
+"utilisez un adaptateur, tels que <function>sigc::bind()</function>, bien "
+"entendu). C'est pourquoi il est important de savoir quel type de "
+"gestionnaire de signal vous devez connecter à un signal donné."
+
+#: C/gtkmm-tutorial-in.xml:7383(title)
+msgid "Writing signal handlers"
+msgstr "Ã?criture de gestionnaires de signal"
+
+#: C/gtkmm-tutorial-in.xml:7385(para)
+msgid ""
+"To find out what type of signal handler you can connect to a signal, you can "
+"look it up in the reference documentation or the header file. Here's an "
+"example of a signal declaration you might see in the <application>gtkmm</"
+"application> headers:"
+msgstr ""
+"Pour savoir quel type de gestionnaire de signal vous pouvez connecter, "
+"regardez dans la documentation de référence ou dans le fichier d'en-tête. "
+"Voici un exemple de déclaration de signal que vous pouvez voir dans les "
+"fichiers d'en-tête de <application>gtkmm</application> :"
+
+#: C/gtkmm-tutorial-in.xml:7392(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::SignalProxy1<bool, Gtk::DirectionType> signal_focus()\n"
+msgstr ""
+"\n"
+"Glib::SignalProxy1<bool, Gtk::DirectionType> signal_focus()\n"
+
+#: C/gtkmm-tutorial-in.xml:7397(para)
+msgid ""
+"Other than the signal's name (<literal>focus</literal>), two things are "
+"important to note here: the number following the word "
+"<classname>SignalProxy</classname> at the beginning (1, in this case), and "
+"the types in the list (<type>bool</type> and <type>Gtk::DirectionType</"
+"type>). The number indicates how many arguments the signal handler should "
+"have; the first type, <type>bool</type>, is the type that the signal handler "
+"should return; and the next type, <type>Gtk::DirectionType</type>, is the "
+"type of this signal's first, and only, argument. By looking at the reference "
+"documentation, you can see the names of the arguments too."
+msgstr ""
+"Outre le nom du signal (<literal>focus</literal>), deux choses sont "
+"importantes à noter ici : le nombre suivant le mot <classname>SignalProxy</"
+"classname> (1, dans notre cas), et les types de la liste (<literal>bool</"
+"literal> et <literal>Gtk::DirectionType</literal>). Le nombre indique le "
+"nombre de paramètres que le gestionnaire de signal doit posséder, le premier "
+"type, <literal>bool</literal>, est le type de retour du gestionnaire de "
+"signal et le suivant, <literal>Gtk::DirectionType</literal>, est le type du "
+"premier et unique paramètre de ce signal. En consultant la documentation de "
+"référence, vous pouvez également prendre connaissance des noms des arguments."
+
+#: C/gtkmm-tutorial-in.xml:7409(para)
+msgid ""
+"The same principles apply for signals which have more arguments. Here's one "
+"with three (taken from <filename><gtkmm/editable.h></filename>):"
+msgstr ""
+"Les mêmes principes s'appliquent aux signaux avec plus de paramètres, voici "
+"un exemple avec trois paramètres (pris dans le fichier <filename><gtkmm/"
+"editable.h></filename>)Â :"
+
+#: C/gtkmm-tutorial-in.xml:7415(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Glib::SignalProxy3<void, const Glib::ustring&, int, int*> signal_insert_text()\n"
+"\n"
+msgstr ""
+"\n"
+"Glib::SignalProxy3<void, const Glib::ustring&, int, int*> signal_insert_text()\n"
+"\n"
+
+#: C/gtkmm-tutorial-in.xml:7421(para)
+msgid ""
+"It follows the same form. The number 3 at the end of the type's name "
+"indicates that our signal handler will need three arguments. The first type "
+"in the type list is <type>void</type>, so that should be our signal "
+"handler's return type. The following three types are the argument types, in "
+"order. Our signal handler's prototype could look like this:"
+msgstr ""
+"Il est de la même forme. Le nombre 3 à la fin du nom du type indique que le "
+"gestionnaire de signal nécessite trois paramètres. Le premier type dans la "
+"liste des types est <literal>void</literal>, c'est le type de retour du "
+"gestionnaire de signal. Les trois types suivants sont les types des "
+"paramètres, dans l'ordre. Notre prototype de gestionnaire de signal "
+"ressemble à quelque chose comme :"
+
+#: C/gtkmm-tutorial-in.xml:7430(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"void on_insert_text(const Glib::ustring& text, int length, int* position);\n"
+msgstr ""
+"\n"
+"void on_insert_text(const Glib::ustring& text, int length, int* position);\n"
+
+#: C/gtkmm-tutorial-in.xml:7437(title)
+msgid "Disconnecting signal handlers"
+msgstr "Déconnexion des gestionnaires de signal"
+
+#: C/gtkmm-tutorial-in.xml:7439(para)
+msgid ""
+"Let's take another look at a Signal's <literal>connect</literal> method:"
+msgstr ""
+"Examinons à nouveau la fonction membre <literal>connect</literal> d'un "
+"signal :"
+
+#: C/gtkmm-tutorial-in.xml:7444(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"sigc::signal<void,int>::iterator signal<void,int>::connect( const sigc::slot<void,int>& );\n"
+msgstr ""
+"\n"
+"sigc::signal<void,int>::iterator signal<void,int>::connect( const sigc::slot<void,int>& );\n"
+
+#: C/gtkmm-tutorial-in.xml:7449(para)
+msgid ""
+"Notice that the return value is of type <classname>sigc::signal<void,"
+"int>::iterator</classname>. This can be implicitely converted into a "
+"<classname>sigc::connection</classname> which in turn can be used to control "
+"the connection. By keeping a connection object you can disconnect its "
+"associated signal handler using the method <methodname>sigc::connection::"
+"disconnect()</methodname>."
+msgstr ""
+"Notez que la valeur de retour est du type <classname>sigc::signal<void,"
+"int>::iterator</classname>. Celle-ci peut être implicitement convertie en "
+"<classname>sigc::connection</classname> qui peut, à son tour, être utilisée "
+"pour contrôler la connexion. En conservant un objet connexion, vous pouvez "
+"déconnecter son signal associé avec la fonction membre <methodname>sigc::"
+"connection::disconnect()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:7460(title)
+msgid "Overriding default signal handlers"
+msgstr "Surdéfinition du gestionnaire de signal par défaut"
+
+#: C/gtkmm-tutorial-in.xml:7462(para)
+msgid ""
+"So far we've told you to perform actions in response to button-presses and "
+"the like by handling signals. That's certainly a good way to do things, but "
+"it's not the only way."
+msgstr ""
+"Jusqu'ici nous vous avons montré la réalisation d'actions en réponse à une "
+"pression de bouton à l'aide d'un gestionnaire de signal. C'est assurément un "
+"bon moyen de réaliser les choses, mais ce n'est pas le seul."
+
+#: C/gtkmm-tutorial-in.xml:7469(para)
+msgid ""
+"Instead of laboriously connecting signal handlers to signals, you can simply "
+"make a new class which inherits from a widget - say, a Button - and then "
+"override the default signal handler, such as Button::on_clicked(). This can "
+"be a lot simpler than hooking up signal handlers for everything."
+msgstr ""
+"Au lieu de connecter laborieusement les gestionnaires de signal aux signaux, "
+"vous pouvez simplement créer une nouvelle classe qui hérite d'un élément "
+"graphique â?? disons, un bouton â??, puis surdéfinir le gestionnaire de signal "
+"par défaut, tel que Button::on_clicked(). Cela peut se révéler plus simple "
+"que d'accrocher des gestionnaires de signal pour chaque chose."
+
+#: C/gtkmm-tutorial-in.xml:7476(para)
+msgid ""
+"Subclassing isn't always the best way to accomplish things. It is only "
+"useful when you want the widget to handle its own signal by itself. If you "
+"want some other class to handle the signal then you'll need to connect a "
+"separate handler. This is even more true if you want several objects to "
+"handle the same signal, or if you want one signal handler to respond to the "
+"same signal from different objects."
+msgstr ""
+"Le sous-classement n'est pas toujours la meilleure façon de réaliser les "
+"choses. Il est uniquement utile quand vous souhaitez que l'élément graphique "
+"gère son propre signal par lui-même. Si vous souhaitez qu'une autre classe "
+"gère le signal, il faut se connecter à un gestionnaire séparé. C'est encore "
+"plus vrai si vous voulez que plusieurs objets gèrent le même signal ou si "
+"vous voulez qu'un seul gestionnaire de signal réponde au même signal à "
+"partir d'objets différents."
+
+#: C/gtkmm-tutorial-in.xml:7481(para)
+msgid ""
+"<application>gtkmm</application> classes are designed with overriding in "
+"mind; they contain virtual member methods specifically intended to be "
+"overridden."
+msgstr ""
+"Les classes <application>gtkmm</application> ont été conçues dans l'optique "
+"de surdéfinitions ; elles comportent des fonctions membres virtuelles "
+"spécialement pensées pour être surdéfinies."
+
+#: C/gtkmm-tutorial-in.xml:7486(para)
+msgid "Let's look at an example of overriding:"
+msgstr "Regardons un exemple de surdéfinition :"
+
+#: C/gtkmm-tutorial-in.xml:7491(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"#include <gtkmm/button.h>\n"
+"\n"
+"class OverriddenButton : public Gtk::Button\n"
+"{\n"
+"protected:\n"
+" virtual void on_clicked();\n"
+"}\n"
+"\n"
+"void OverriddenButton::on_clicked()\n"
+"{\n"
+" std::cout << \"Hello World\" << std::endl;\n"
+"\n"
+" // call the base class's version of the method:\n"
+" Gtk::Button::on_clicked();\n"
+"}\n"
+msgstr ""
+"\n"
+"#include <gtkmm/button.h>\n"
+"\n"
+"class OverriddenButton : public Gtk::Button\n"
+"{\n"
+"protected:\n"
+" virtual void on_clicked();\n"
+"}\n"
+"\n"
+"void OverriddenButton::on_clicked()\n"
+"{\n"
+" std::cout << \"Hello World\" << std::endl;\n"
+"\n"
+"// appeler la version de la classe de base de la fonction membre:\n"
+" Gtk::Button::on_clicked();\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:7510(para)
+msgid ""
+"Here we define a new class called <classname>OverriddenButton</classname>, "
+"which inherits from <classname>Gtk::Button</classname>. The only thing we "
+"change is the <methodname>on_clicked()</methodname> method, which is called "
+"whenever <classname>Gtk::Button</classname> emits the <literal>clicked</"
+"literal> signal. This method prints \"Hello World\" to <literal>stdout</"
+"literal>, and then calls the original, overridden method, to let "
+"<classname>Gtk::Button</classname> do what it would have done had we not "
+"overridden."
+msgstr ""
+"Ici nous définissons une nouvelle classe nommée <classname>OverriddenButton</"
+"classname> qui hérite de <classname>Gtk::Button</classname>. La seule chose "
+"que nous modifions est la fonction membre <methodname>on_clicked()</"
+"methodname> ; cette fonction membre est appelée chaque fois qu'un objet "
+"<classname>Gtk::Button</classname> émet le signal <literal>clicked</"
+"literal>. Elle affiche « Hello World » sur <literal>stdout</literal>, puis "
+"appelle la fonction membre originelle pour que <classname>Gtk::Button</"
+"classname> fasse ce qu'il a à faire quand il n'est pas surdéfini."
+
+#: C/gtkmm-tutorial-in.xml:7521(para)
+msgid ""
+"You don't always need to call the parent's method; there are times when you "
+"might not want to. Note that we called the parent method <emphasis>after</"
+"emphasis> writing \"Hello World\", but we could have called it before. In "
+"this simple example, it hardly matters much, but there are times when it "
+"will. With signals, it's not quite so easy to change details like this, and "
+"you can do something here which you can't do at all with connected signal "
+"handlers: you can call the parent method in the <emphasis>middle</emphasis> "
+"of your custom code."
+msgstr ""
+"Il n'est pas toujours nécessaire d'appeler la fonction membre du parent ; "
+"certaines fois vous ne le souhaiterez pas. Notez que nous avons appelé la "
+"fonction membre du parent <emphasis>après</emphasis> avoir écrit « Hello "
+"World », mais nous aurions pu l'appeler avant. Dans cet exemple simple, cela "
+"n'a pas beaucoup d'importance, mais parfois si. Avec les signaux, il n'est "
+"pas facile de modifier des détails de ce type, et vous pouvez ici faire des "
+"choses que vous ne pourrez absolument pas faire avec des gestionnaires de "
+"signal connectés : vous pouvez appeler la fonction membre du parent au "
+"<emphasis>milieu</emphasis> de votre code personnalisé."
+
+#: C/gtkmm-tutorial-in.xml:7535(title)
+msgid "Binding extra arguments"
+msgstr "Liaison avec des paramètres supplémentaires"
+
+#: C/gtkmm-tutorial-in.xml:7543(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"m_button1.signal_clicked().connect( sigc::bind<Glib::ustring>( sigc::mem_fun(*this, &HelloWorld::on_button_clicked), \"button 1\") );\n"
+msgstr ""
+"\n"
+"m_button1.signal_clicked().connect( \n"
+" sigc::bind<Glib::ustring>( \n"
+" sigc::mem_fun(\n"
+" *this, \n"
+" &HelloWorld::on_button_clicked\n"
+" ),\n"
+" \"bouton 1\")\n"
+" );\n"
+
+#: C/gtkmm-tutorial-in.xml:7550(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"virtual void on_button_clicked(Glib::ustring data);\n"
+msgstr ""
+"\n"
+"virtual void on_button_clicked(Glib::ustring data);\n"
+
+#: C/gtkmm-tutorial-in.xml:7536(para)
+msgid ""
+"If you use one signal handler to catch the same signal from several widgets, "
+"you might like that signal handler to receive some extra information. For "
+"instance, you might want to know which button was clicked. You can do this "
+"with <function>sigc::bind()</function>. Here's some code from the <link "
+"linkend=\"sec-helloworld2\">helloworld2</link> example, which you will "
+"encounter later. <placeholder-1/> This says that we want the signal to send "
+"an extra <classname>Glib::ustring</classname> argument to the signal "
+"handler, and that the value of that argument should be \"button 1\". Of "
+"course we will need to add that extra argument to the declaration of our "
+"signal handler: <placeholder-2/> Of course, a normal \"clicked\" signal "
+"handler would have no arguments."
+msgstr ""
+"Si vous utilisez un gestionnaire de signal pour capter le même signal à "
+"partir de plusieurs éléments graphiques, vous pouvez souhaiter que le "
+"gestionnaire de signal reçoive des informations supplémentaires. Par "
+"exemple, savoir quel bouton a été cliqué. Vous pouvez réaliser cela avec "
+"<function>sigc::bind()</function>. Voici du code extrait de l'exemple <link "
+"linkend=\"sec-helloworld2\">helloworld2</link> déjà rencontré plus haut. "
+"<placeholder-1/> Ce code indique que nous voulons que le signal envoie une "
+"valeur supplémentaire de type <classname>Glib::ustring</classname> au "
+"gestionnaire et que sa valeur soit égale à « bouton 1 ». Bien évidemment, "
+"nous devons ajouter ce paramètre supplémentaire dans la déclaration de "
+"fonction de notre gestionnaire de signal : <placeholder-2/> Bien évidemment "
+"encore, un gestionnaire normal de signal « clicked » ne comporterait pas de "
+"paramètre."
+
+#: C/gtkmm-tutorial-in.xml:7555(para)
+msgid ""
+"<function>sigc::bind()</function> is not commonly used, but you might find "
+"it helpful sometimes. If you are familiar with <application>GTK+</"
+"application> programming then you have probably noticed that this is similar "
+"to the extra <literal>gpointer data</literal> arguments which all GTK+ "
+"callbacks have. This is generally overused in <application>GTK+</"
+"application> to pass information that should be stored as member data in a "
+"derived widget, but widget derivation is very difficult in C. We have far "
+"less need of this hack in <application>gtkmm</application>."
+msgstr ""
+"<function>sigc::bind()</function> n'est pas d'usage courant, mais peut-être "
+"le trouverez-vous commode parfois. Si vous êtes un familier de la "
+"programmation avec <application>GTK+</application>, vous avez alors "
+"probablement noté la similitude avec les paramètres supplémentaires "
+"<literal>gpointer data</literal> que toutes les fonctions de rappel "
+"possèdent. Généralement, cette possibilité est utilisée à l'excès dans "
+"<application>GTK+</application> pour passer des informations qui devraient "
+"être stockées dans une donnée membre d'un élément graphique dérivé, mais la "
+"dérivation des éléments graphiques est très difficile en C. Nous avons "
+"beaucoup moins besoin de cette façon de faire dans <application>gtkmm</"
+"application>."
+
+#: C/gtkmm-tutorial-in.xml:7567(title)
+msgid "X Event signals"
+msgstr "Signaux des événements X"
+
+#: C/gtkmm-tutorial-in.xml:7568(para)
+msgid ""
+"The <classname>Widget</classname> class has some special signals which "
+"correspond to the underlying X-Windows events. These are suffixed by "
+"<literal>_event</literal>; for instance, <methodname>Widget::"
+"signal_button_pressed_event()</methodname>."
+msgstr ""
+"La classe <classname>Widget</classname> possède certains signaux spéciaux "
+"correspondant aux événements de la fenêtre X sous-jacente. Il possèdent le "
+"suffixe <literal>_event</literal>Â ; par exemple, <methodname>Widget::"
+"signal_button_pressed_event()</methodname>."
+
+#: C/gtkmm-tutorial-in.xml:7574(para)
+msgid ""
+"You might occasionally find it useful to handle X events when there's "
+"something you can't accomplish with normal signals. <classname>Gtk::Button</"
+"classname>, for example, does not send mouse-pointer coordinates with its "
+"<literal>clicked</literal> signal, but you could handle "
+"<literal>button_pressed_event</literal> if you needed this information. X "
+"events are also often used to handle key-presses."
+msgstr ""
+"Vous pouvez trouver occasionnellement utile de gérer les événements X quand "
+"il y a quelque chose que vous ne pouvez pas réaliser avec les signaux "
+"normaux. <classname>Gtk::Button</classname>, par exemple, ne renvoie pas les "
+"coordonnées du pointeur de souris avec le signal <literal>clicked</literal>, "
+"mais en gérant <literal>button_pressed_event</literal>, vous pouvez obtenir "
+"cette information. Les événements X sont également souvent utilisés pour "
+"gérer les touches pressées."
+
+#: C/gtkmm-tutorial-in.xml:7583(para)
+msgid ""
+"These signals behave slightly differently. The value returned from the "
+"signal handler indicates whether it has fully \"handled\" the event. If the "
+"value is <literal>false</literal> then <application>gtkmm</application> will "
+"pass the event on to the next signal handler. If the value is <literal>true</"
+"literal> then no other signal handlers will need to be called."
+msgstr ""
+"Ces signaux se comportent de façon légèrement différente. La valeur renvoyée "
+"par le gestionnaire de signal indique si l'événement a été pleinement "
+"« géré ». Si la valeur est <literal>false</literal>, alors "
+"<application>gtkmm</application> passe l'événement au gestionnaire de signal "
+"suivant. Si la valeur est <literal>true</literal>, aucun autre gestionnaire "
+"de signal n'est appelé."
+
+#: C/gtkmm-tutorial-in.xml:7588(para)
+msgid ""
+"Handling an X event doesn't affect the Widget's other signals. If you handle "
+"<literal>button_pressed_event</literal> for <classname>Gtk::Button</"
+"classname>, you'll still be able to get the <literal>clicked</literal> "
+"signal. They are emitted at (nearly) the same time."
+msgstr ""
+"La gestion des événements X n'affecte pas les autres signaux de l'élément "
+"graphique. Si vous gérez <literal>button_pressed_event</literal> pour "
+"<classname>Gtk::Button</classname>, vous serez encore en mesure de gérer le "
+"signal <literal>clicked</literal>. Ils sont émis (pratiquement) "
+"simultanément."
+
+#: C/gtkmm-tutorial-in.xml:7595(para)
+msgid ""
+"Note also that not all widgets receive all X events by default. To receive "
+"additional X events, you can use <methodname>Gtk::Widget::set_events()</"
+"methodname> before showing the widget, or <methodname>Gtk::Widget::add_events"
+"()</methodname> after showing the widget. However, some widgets must first "
+"be placed inside an <classname>EventBox</classname> widget. See the <link "
+"linkend=\"chapter-widgets-without-xwindows\">Widgets Without X-Windows</"
+"link> chapter."
+msgstr ""
+"Notez aussi que tous les éléments graphiques ne reçoivent pas tous les "
+"événements X par défaut. Pour recevoir des événements X supplémentaires, vous "
+"pouvez utiliser <methodname>Gtk::Widget::set_events()</methodname> avant "
+"d'afficher l'élément graphique ou <methodname>Gtk::Widget::add_events()</"
+"methodname> après. Toutefois, certains éléments graphiques doivent "
+"préalablement avoir été placés dans un élément graphique "
+"<classname>EventBox</classname>. Consultez le chapitre <link linkend="
+"\"chapter-widgets-without-xwindows\">�léments graphiques sans fenêtre-X</"
+"link>."
+
+#: C/gtkmm-tutorial-in.xml:7604(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"bool on_button_press(GdkEventButton* event);\n"
+"Gtk::Button button(\"label\");\n"
+"button.signal_button_press_event().connect( sigc::ptr_fun(&on_button_press) );\n"
+msgstr ""
+"\n"
+"bool on_button_press(GdkEventButton* event);\n"
+"Gtk::Button button(\"label\");\n"
+"button.signal_button_press_event().connect(\n"
+" sigc::ptr_fun(&on_button_press) \n"
+" );\n"
+
+#: C/gtkmm-tutorial-in.xml:7602(para)
+msgid "Here's a simple example: <placeholder-1/>"
+msgstr "Voici un exemple simple : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7610(para)
+msgid ""
+"When the mouse is over the button and a mouse button is pressed, "
+"<methodname>on_button_press()</methodname> will be called."
+msgstr ""
+"Quand la souris est au dessus du bouton et qu'un bouton de souris est "
+"pressé, <methodname>on_button_press()</methodname> est appelé."
+
+#: C/gtkmm-tutorial-in.xml:7615(para)
+msgid ""
+"<type>GdkEventButton</type> is a structure containing the event's "
+"parameters, such as the coordinates of the mouse pointer at the time the "
+"button was pressed. There are several different types of <type>GdkEvent</"
+"type> structures for the various events."
+msgstr ""
+"<literal>GdkEventButton</literal> est une structure contenant les paramètres "
+"de l'événement, tels que les coordonnées du pointeur de souris et l'heure où "
+"le bouton a été pressé. Les structures <literal>GdkEvent</literal> sont "
+"différentes selon les événements."
+
+#: C/gtkmm-tutorial-in.xml:7623(title)
+msgid "Signal Handler sequence"
+msgstr "Séquencement des gestionnaires de signaux"
+
+#: C/gtkmm-tutorial-in.xml:7625(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"button.signal_button_press_event().connect( sigc::ptr_fun(&on_mywindow_button_press), false );\n"
+msgstr ""
+"\n"
+"button.signal_button_press_event().connect( \n"
+" sigc::ptr_fun(&on_mywindow_button_press), \n"
+" false );\n"
+
+#: C/gtkmm-tutorial-in.xml:7624(para)
+msgid ""
+"By default, your signal handlers are called after any previously-connected "
+"signal handlers. However, this can be a problem with the X Event signals. "
+"For instance, the existing signal handlers, or the default signal handler, "
+"might return true to stop other signal handlers from being called. To "
+"specify that your signal handler should be called before the other signal "
+"handlers, so that will always be called, you can specify <literal>false</"
+"literal> for the optional <literal>after</literal> parameter. For instance, "
+"<placeholder-1/>"
+msgstr ""
+"Par défaut, les gestionnaires de signaux sont appelés successivement. "
+"Toutefois cela peut conduire à des difficultés avec les signaux des "
+"événements X. Par exemple, le gestionnaire de signal existant, ou le "
+"gestionnaire par défaut, peut renvoyer une valeur empêchant l'appel des "
+"autres gestionnaires de signal. Pour indiquer qu'un gestionnaire de signal "
+"doit être appelé avant les autres ou bien appelé dans tous les cas, vous "
+"pouvez indiquer <literal>false</literal> pour le paramètre optionnel "
+"<literal>after</literal>. Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7639(title)
+msgid "Creating your own signals"
+msgstr "Création de vos propres signaux"
+
+#: C/gtkmm-tutorial-in.xml:7640(para)
+msgid ""
+"Now that you've seen signals and signal handlers in <application>gtkmm</"
+"application>, you might like to use the same technique to allow interaction "
+"between your own classes. That's actually very simple by using the "
+"<application>libsigc++</application> library directly."
+msgstr ""
+"Maintenant que nous avons vu les signaux et les gestionnaires de signal dans "
+"<application>gtkmm</application>, vous aimeriez peut-être utiliser la même "
+"technique pour interagir entre vos propres classes. C'est vraiment très "
+"simple en utilisant directement la bibliothèque <application>libsigc++</"
+"application>."
+
+#: C/gtkmm-tutorial-in.xml:7646(para)
+msgid ""
+"This isn't purely a <application>gtkmm</application> or GUI issue. "
+"<application>gtkmm</application> uses <application>libsigc++</application> "
+"to implement its proxy wrappers for the <application>GTK+</application> "
+"signal system, but for new, non-GTK+ signals, you can create pure C++ "
+"signals, using the <classname>sigc::signal<></classname> template."
+msgstr ""
+"Ce n'est pas à proprement parler un problème <application>gtkmm</"
+"application> ou d'interface utilisateur. <application>gtkmm</application> "
+"utilise <application>libsigc++</application> pour implémenter ses habillages "
+"mandataires du système de signaux <application>GTK+</application>, mais pour "
+"des nouveaux signaux non GTK+, vous pouvez créer des signaux C++ purs en "
+"utilisant le modèle <classname>sigc::signal<></classname>."
+
+#: C/gtkmm-tutorial-in.xml:7657(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"sigc::signal<void, bool, int> signal_something;\n"
+msgstr ""
+"\n"
+"sigc::signal<void, bool, int> signal_something;\n"
+
+#: C/gtkmm-tutorial-in.xml:7653(para)
+msgid ""
+"For instance, to create a signal that sends 2 parameters, a <type>bool</"
+"type> and an <type>int</type>, just declare a <classname>sigc::signal</"
+"classname>, like so: <placeholder-1/>"
+msgstr ""
+"Par exemple, pour créer un signal qui envoie 2 paramètres, un de type "
+"<literal>bool</literal> et un de type <literal>int</literal>, déclarez juste "
+"un <classname>sigc::signal</classname>, ainsi : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7665(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"class Server\n"
+"{\n"
+"public:\n"
+" //signal accessor:\n"
+" typedef sigc::signal<void, bool, int> type_signal_something;\n"
+" type_signal_something signal_something();\n"
+"\n"
+"protected:\n"
+" type_signal_something m_signal_something;\n"
+"};\n"
+"\n"
+"Server::type_signal_something Server::signal_something()\n"
+"{\n"
+" return m_signal_something;\n"
+"}\n"
+msgstr ""
+"\n"
+"class Server\n"
+"{\n"
+"public:\n"
+" // mécanisme d'accès au signal :\n"
+" typedef sigc::signal<void, bool, int> type_signal_something;\n"
+" type_signal_something signal_something();\n"
+"\n"
+"protected:\n"
+" type_signal_something m_signal_something;\n"
+"};\n"
+"\n"
+"Server::type_signal_something Server::signal_something()\n"
+"{\n"
+" return m_signal_something;\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:7661(para)
+msgid ""
+"You could just declare that signal as a public member variable, but some "
+"people find that distasteful and prefer to make it available via an accessor "
+"method, like so: <placeholder-1/>"
+msgstr ""
+"Vous pouvez simplement déclarer ce signal comme une variable membre "
+"publique, mais certaines personnes trouvent cela détestable et préfèrent "
+"aménager son accessibilité via une fonction membre de mécanisme d'accès, "
+"ainsi : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7687(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"server.signal_something().connect(\n"
+" sigc::mem_fun(client, &Client::on_server_something) );\n"
+msgstr ""
+"\n"
+"server.signal_something().connect(\n"
+" sigc::mem_fun(client, &Client::on_server_something) );\n"
+
+#: C/gtkmm-tutorial-in.xml:7684(para)
+msgid ""
+"You can then connect to the signal using the same syntax used when "
+"connecting to <application>gtkmm</application> signals. For instance, "
+"<placeholder-1/>"
+msgstr ""
+"Vous pouvez ensuite connecter le signal en utilisant la même syntaxe que "
+"celle utilisée pour connecter les signaux <application>gtkmm</application>. "
+"Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7695(para)
+msgid "This is a full working example that defines and uses custom signal."
+msgstr ""
+"Voici un exemple pleinement fonctionnel définissant et utilisant un signal "
+"personnalisé."
+
+#: C/gtkmm-tutorial-in.xml:7709(title)
+msgid "Comparison with other signalling systems"
+msgstr "Comparaison avec les autres systèmes de signalisation"
+
+#: C/gtkmm-tutorial-in.xml:7710(para)
+msgid ""
+"(An aside: <application>GTK+</application> calls this scheme \"signalling\"; "
+"the sharp-eyed reader with GUI toolkit experience will note that this same "
+"design is often seen under the name of \"broadcaster-listener\" (e.g., in "
+"Metrowerks' PowerPlant framework for the Macintosh). It works in much the "
+"same way: one sets up <literal>broadcasters</literal>, and then connects "
+"<literal>listeners</literal> to them; the broadcaster keeps a list of the "
+"objects listening to it, and when someone gives the broadcaster a message, "
+"it calls all of its objects in its list with the message. In "
+"<application>gtkmm</application>, signal objects play the role of "
+"broadcasters, and slots play the role of listeners - sort of. More on this "
+"later.)"
+msgstr ""
+"(En aparté : <application>GTK+</application> appelle ce mécanisme "
+"« signalisation » ; le regard avisé du lecteur ayant un certaine expérience "
+"des boîtes à outils d'interfaces utilisateur ne manquera pas de noter que "
+"cette même conception est souvent rencontrée sous l'appellation de "
+"« broadcaster-listener » (émetteur-récepteur) (comme dans l'architecture "
+"PowerPlant de Metrowerks pour le Macintosh). Cela fonctionne tout à fait de "
+"la même façon : on met en place des <literal>broadcasters</literal> "
+"(émetteurs), puis on y connecte des <literal>listeners</literal> "
+"(récepteurs) ; l'émetteur conserve une liste des objets qui l'écoutent, et "
+"quand quelqu'un donne un message à l'émetteur, il appelle tous les objets de "
+"sa liste avec le message. Dans <application>gtkmm</application>, les objets "
+"signaux jouent le rôle d'émetteurs et les connecteurs celui de récepteurs "
+"â?? en quelque sorte. Plus à ce sujet plus tard.)"
+
+#: C/gtkmm-tutorial-in.xml:7724(para)
+msgid ""
+"<application>gtkmm</application> signal handlers are strongly-typed, whereas "
+"<application>GTK+</application> C code allows you to connect a callback with "
+"the wrong number and type of arguments, leading to a segfault at runtime. "
+"And, unlike <application>Qt</application>, <application>gtkmm</application> "
+"achieves this without modifying the C++ language."
+msgstr ""
+"Les gestionnaires de signaux <application>gtkmm</application> sont fortement "
+"typés, alors que le code C de <application>GTK+</application> vous autorise "
+"à connecter une fonction de rappel avec un nombre de paramètres erroné ou de "
+"mauvais type, déclenchant une erreur de segmentation lors de l'exécution. "
+"Et, contrairement à <application>Qt</application>, <application>gtkmm</"
+"application> réalise cela sans modifier le langage C++."
+
+#: C/gtkmm-tutorial-in.xml:7730(para)
+msgid ""
+"Re. Overriding signal handlers: You can do this in the straight-C world of "
+"GTK+ too; that's what GTK's object system is for. But in GTK+, you have to "
+"go through some complicated procedures to get object-oriented features like "
+"inheritance and overloading. In C++, it's simple, since those features are "
+"supported in the language itself; you can let the compiler do the dirty work."
+msgstr ""
+"Retour à propos de la surdéfinition des gestionnaires de signal : vous "
+"pouvez également réaliser cette surdéfinition en restant dans le domaine "
+"strict du C de GTK+ ; le système d'objets de GTK est fait pour cela. Mais "
+"dans GTK+, vous devez cheminer par des procédures complexes pour obtenir des "
+"fonctionnalités telle que l'héritage et la surdéfinition. En C++, c'est "
+"simple, car ces fonctionnalités sont prises en charge dans le langage lui-"
+"même ; vous pouvez déléguer au compilateur le soin de faire le « sale "
+"boulot »."
+
+#: C/gtkmm-tutorial-in.xml:7738(para)
+msgid ""
+"This is one of the places where the beauty of C++ really comes out. One "
+"wouldn't think of subclassing a GTK+ widget simply to override its action "
+"method; it's just too much trouble. In GTK+, you almost always use signals "
+"to get things done, unless you're writing a new widget. But because "
+"overriding methods is so easy in C++, it's entirely practical - and sensible "
+"- to subclass a button for that purpose."
+msgstr ""
+"C'est un des aspects où la beauté du C++ ressort vraiment. Quelqu'un "
+"songerait-il à sous-classer un élément graphique GTK+ uniquement pour "
+"surdéfinir ses fonctions membres d'action ? Ce serait s'exposer à trop "
+"d'ennuis. Dans GTK+, vous utilisez pratiquement toujours les signaux pour "
+"exécuter quelque chose, à moins que vous n'écriviez un nouvel élément "
+"graphique. Mais comme la surdéfinition des fonctions membres est si facile "
+"en C++, il est tout à fait pratique â?? et sensé â?? de sous-classer un bouton "
+"pour cette seule raison."
+
+#: C/gtkmm-tutorial-in.xml:7749(title)
+msgid "<application>gtkmm</application> and Win32"
+msgstr "<application>gtkmm</application> et Win32"
+
+#: C/gtkmm-tutorial-in.xml:7750(para)
+msgid ""
+"One of the major advantages of <application>gtkmm</application> is that it "
+"is crossplatform. <application>gtkmm</application> programs written on other "
+"platforms such as GNU/Linux can generally be transferred to Windows (and "
+"vice versa) with few modifications to the source."
+msgstr ""
+"Un des avantages majeurs de <application>gtkmm</application> est que "
+"<application>gtkmm</application> est multiplate-forme. Les programmes "
+"<application>gtkmm</application> écrits sur des plate-formes telles que GNU/"
+"Linux peuvent généralement être portées sur Windows (et vice versa) avec peu "
+"de modifications des sources."
+
+#: C/gtkmm-tutorial-in.xml:7755(para)
+msgid ""
+"<application>gtkmm</application> currently works with the <ulink url="
+"\"http://mingw.org/\">MingW/GCC3.4 compiler</ulink> and Microsoft Visual C++ "
+"2005 or later (including the freely available express editions) on the "
+"Windows platform. There is an <ulink url=\"ftp://ftp.gnome.org/pub/GNOME/"
+"binaries/win32/gtkmm\"> installer</ulink> available for gtkmm on Microsoft "
+"Windows. Refer to <ulink url=\"http://live.gnome.org/gtkmm/MSWindows/\"> "
+"http://live.gnome.org/gtkmm/MSWindows</ulink> for instructions how to use it."
+msgstr ""
+"<application>gtkmm</application> fonctionne actuellement avec le <ulink url="
+"\"http://mingw.org/\">compilateur MingW/GCC3.4</ulink> et Microsoft Visual C+"
+"+ 2005 ou supérieur (y compris l'édition express disponible gratuitement). "
+"Un <ulink url=\"ftp://ftp.gnome.org/pub/GNOME/binaries/win32/gtkmm"
+"\">installeur</ulink> de gtkmm est disponible pour Microsoft Windows. "
+"Consultez <ulink url=\"http://live.gnome.org/gtkmm/MSWindows/\"> http://live."
+"gnome.org/gtkmm/MSWindows</ulink> pour des instructions sur son utilisation."
+
+#: C/gtkmm-tutorial-in.xml:7767(title)
+msgid "Building <application>gtkmm</application> on Win32"
+msgstr "Construction de <application>gtkmm</application> sur Win32"
+
+#: C/gtkmm-tutorial-in.xml:7768(para)
+msgid ""
+"Please see <ulink url=\"http://live.gnome.org/gtkmm/MSWindows/BuildingGtkmm"
+"\">http://live.gnome.org/gtkmm/MSWindows/BuildingGtkmm</ulink> for "
+"instructions on how to build gtkmm on Windws."
+msgstr ""
+"Veuillez consulter <ulink url=\"http://live.gnome.org/gtkmm/MSWindows/"
+"BuildingGtkmm\">http://live.gnome.org/gtkmm/MSWindows/BuildingGtkmm</ulink> "
+"pour des instructions à propos de la construction de gtkmm sur Windows."
+
+#: C/gtkmm-tutorial-in.xml:7775(title)
+msgid "Working with gtkmm's Source Code"
+msgstr "Travail avec le code source de gtkmm"
+
+#: C/gtkmm-tutorial-in.xml:7776(para)
+msgid ""
+"If you are interested in helping out with the development of "
+"<application>gtkmm</application>, or fixing a bug in <application>gtkmm</"
+"application>, you'll probably need to build the development version of "
+"<application>gtkmm</application>. However, you should not to install a "
+"development version over your stable version. Instead, you should install it "
+"alongside your existing <application>gtkmm</application> installation, in a "
+"separate path."
+msgstr ""
+"Si vous êtes intéressé par une participation au développement de "
+"<application>gtkmm</application> ou par des corrections d'anomalies dans "
+"<application>gtkmm</application>, vous aurez certainement besoin de "
+"construire la version de développement de <application>gtkmm</application>. "
+"Toutefois, vous ne devez pas installer une version de développement sur "
+"votre version stable. Vous devez l'installer à côté de l'installation "
+"existante de <application>gtkmm</application> dans un dossier séparé."
+
+#: C/gtkmm-tutorial-in.xml:7783(para)
+msgid ""
+"The easiest way to do this is using <ulink url=\"http://library.gnome.org/"
+"devel/jhbuild/unstable/\">jhbuild</ulink>. <application>jhbuild</"
+"application> is a program that makes building GNOME software much easier by "
+"calculating dependencies and building things in the correct order. This "
+"section will give a brief explanation of how to set up jhbuild to build and "
+"install <application>gtkmm</application> from the source repository (git). "
+"For up-to-date information on <application>jhbuild</application>, please "
+"refer to the <ulink url=\"http://library.gnome.org/devel/jhbuild/unstable/"
+"\">jhbuild manual</ulink>. If you need assistance using "
+"<application>jhbuild</application>, you should ask for help on the <ulink "
+"url=\"http://mail.gnome.org/mailman/listinfo/gnome-love\">gnome-love mailing "
+"list</ulink>."
+msgstr ""
+"<ulink url=\"http://library.gnome.org/devel/jhbuild/unstable/\">jhbuild</"
+"ulink> facilite cette opération. <application>jhbuild</application> est un "
+"programme qui rend la construction des logiciels GNOME plus aisée en "
+"calculant les dépendances et en les construisant dans un ordre correct. Ce "
+"paragraphe vous donnera quelques explications sur la manière de paramétrer "
+"<application>jhbuild</application> pour construire et installer "
+"<application>gtkmm</application> à partir du dépôt des sources (git). Pour "
+"actualiser l'information concernant <application>jhbuild</application>, "
+"veuillez vous reporter au <ulink url=\"http://library.gnome.org/devel/"
+"jhbuild/unstable/\">manuel de jhbuild</ulink>. Si vous avez besoin d'aide "
+"pour utiliser <application>jhbuild</application>, adressez-vous à la <ulink "
+"url=\"http://mail.gnome.org/mailman/listinfo/gnome-love\">liste de diffusion "
+"gnome-love</ulink>."
+
+#: C/gtkmm-tutorial-in.xml:7798(para)
+msgid ""
+"Note that to build <application>gtkmm</application> from git, you'll often "
+"need to build all of its dependencies from git as well. "
+"<application>jhbuild</application> makes this easier than it would normally "
+"be, but it will take quite a while to build and install them all. You will "
+"probably encounter build problems, though these will usually be corrected "
+"quickly if you report them."
+msgstr ""
+"Notez que pour construire <application>gtkmm</application> à partir du dépôt "
+"git, il vous sera nécessaire de construire toutes ses dépendances à partir "
+"de git également. <application>jhbuild</application> facilite également "
+"cette opération par comparaison avec ce qu'elle représenterait normalement "
+"sans lui, mais la construction et l'installation du tout demande tout de "
+"même pas mal de temps. Vous serez probablement confrontés à des problèmes de "
+"construction, mais ils sont en règle générale rapidement corrigés si vous "
+"les rapportez."
+
+#: C/gtkmm-tutorial-in.xml:7806(title)
+msgid "Setting up jhbuild"
+msgstr "Paramétrage de jhbuild"
+
+#: C/gtkmm-tutorial-in.xml:7807(para)
+msgid ""
+"To set up <application>jhbuild</application>, follow the basic installation "
+"instructions from the <ulink url=\"http://library.gnome.org/devel/jhbuild/"
+"unstable/\">jhbuild manual</ulink>. After you've have installd "
+"<application>jhbuild</application>, you should copy the sample "
+"<application>jhbuild</application> configuration file into your home "
+"directory by executing the following command from the <application>jhbuild</"
+"application> directory: <command>$ cp sample.jhbuildrc ~/.jhbuildrc</command>"
+msgstr ""
+"Pour paramétrer <application>jhbuild</application>, suivez les instructions "
+"d'installation de base du <ulink url=\"http://library.gnome.org/devel/"
+"jhbuild/unstable/\">manuel de jhbuild</ulink>. Après avoir installé "
+"<application>jhbuild</application>, recopiez le fichier d'exemple de "
+"configuration de <application>jhbuild</application> dans votre répertoire "
+"personnel en lançant la commande suivante à partir du répertoire de "
+"<application>jhbuild</application>Â : <command>$ cp sample.jhbuildrc ~/."
+"jhbuildrc</command>"
+
+#: C/gtkmm-tutorial-in.xml:7822(programlisting)
+#, no-wrap
+msgid "moduleset = 'gnome-2.30'"
+msgstr "moduleset = 'gnome-2.30'"
+
+#: C/gtkmm-tutorial-in.xml:7817(para)
+msgid ""
+"The <application>gtkmm</application> module is defined in the GNOME "
+"moduleset (i.e. <filename>gnome-2.xx.modules</filename>, so edit your "
+"<filename>.jhbuildrc</filename> file and set your moduleset setting to the "
+"latest version of GNOME like so: <placeholder-1/>"
+msgstr ""
+"Le module de <application>gtkmm</application> est défini dans le jeu de "
+"modules GNOME (c'est-Ã -dire, <filename>gnome-2.xx.modules</filename>)Â ; "
+"modifiez votre fichier <filename>.jhbuildrc</filename> et fixez le "
+"paramétrage de votre module prédéfini à la dernière version de GNOME ainsi : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7828(programlisting)
+#, no-wrap
+msgid "modules = [ 'gtkmm', ]"
+msgstr "modules = [ 'gtkmm', ]"
+
+#: C/gtkmm-tutorial-in.xml:7824(para)
+msgid ""
+"After setting the correct moduleset, you need to tell <application>jhbuild</"
+"application> which module or modules to build. To build <application>gtkmm</"
+"application> and all of its dependencies, set <varname>modules</varname> "
+"like so: <placeholder-1/>"
+msgstr ""
+"Après avoir défini le module correct, vous devez indiquer à "
+"<application>jhbuild</application> quel est ou quels sont les modules à "
+"construire. Pour construire <application>gtkmm</application> et toutes ses "
+"dépendances, paramétrez la variable <varname>modules</varname> ainsi : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7830(para)
+msgid ""
+"You can build all GNOME C++ modules by setting the <varname>modules</"
+"varname> variable to the meta-package named <literal>meta-gnome-c++</"
+"literal> or build all of the core GNOME modules with <literal>meta-gnome-"
+"desktop</literal>. The <varname>modules</varname> variable specifies which "
+"modules that will be built when you don't explicitly specify anything on the "
+"command line. You can always build a different moduleset later by specifying "
+"it on the commandline (e.g. <command>jhbuild build gtkmm</command>)."
+msgstr ""
+"Vous pouvez construire tous les modules GNOME C++ en définissant la valeur "
+"de la variable <varname>modules</varname> à celle du méta-paquet nommé "
+"<literal>meta-gnome-c++</literal> ou construire tous les modules du noyau de "
+"GNOME avec <literal>meta-gnome-desktop</literal>. La variable "
+"<varname>modules</varname> indique quels sont les modules à construire quand "
+"vous ne précisez pas explicitement quelque chose en ligne de commande. Vous "
+"pouvez toujours construire plus tard un module prédéfini différent en le "
+"définissant sur la ligne de commande (par exemple, <command>jhbuild build "
+"gtkmm</command>)."
+
+#: C/gtkmm-tutorial-in.xml:7841(title)
+msgid "Setting a prefix"
+msgstr "Définition d'un préfixe"
+
+#: C/gtkmm-tutorial-in.xml:7842(para)
+msgid ""
+"By default, <application>jhbuild</application>'s configuration is configured "
+"to install all software built with <application>jhbuild</application> under "
+"the <filename>/opt/gnome2</filename> prefix. You can choose a different "
+"prefix, but it is recommended that you keep this prefix different from other "
+"software that you've installed (don't set it to <filename>/usr</filename>!) "
+"If you've followed the jhbuild instructions then this prefix belongs to your "
+"user, so you don't need to run jhbuild as <literal>root</literal>."
+msgstr ""
+"Par défaut, la configuration de <application>jhbuild</application> est "
+"déterminée pour installer tous les logiciels construits avec son aide avec "
+"le préfixe de dossier <filename>/opt/gnome2</filename>. Vous pouvez opter "
+"pour un préfixe différent, mais il est recommandé de le différencier de "
+"celui utilisé pour les autres logiciels installés (n'utilisez pas <filename>/"
+"usr</filename>Â !). Si vous avez suivi les instructions de jhbuild, ce "
+"préfixe vous appartient en tant qu'utilisateur ; vous n'aurez donc pas "
+"besoin d'être <literal>root</literal> pour lancer <application>jhbuild</"
+"application>."
+
+#: C/gtkmm-tutorial-in.xml:7856(title)
+msgid ""
+"Installing and Using the git version of <application>gtkmm</application>"
+msgstr ""
+"Installation et utilisation de la version git de <application>gtkmm</"
+"application>"
+
+#: C/gtkmm-tutorial-in.xml:7857(para)
+msgid ""
+"Once you've configured <application>jhbuild</application> as described "
+"above, building <application>gtkmm</application> should be relatively "
+"straightforward. The first time you run <application>jhbuild</application>, "
+"you should run the following sequence of commands to ensure that "
+"<application>jhbuild</application> has the required tools and verify that it "
+"is set up correctly: <screen>$ jhbuild bootstrap\n"
+"$ jhbuild sanitycheck</screen>"
+msgstr ""
+"Après avoir configuré <application>jhbuild</application> comme décrit plus "
+"haut, la construction de <application>gtkmm</application> devrait être "
+"relativement simple. Avant de lancer une première fois <application>jhbuild</"
+"application>, effectuez la séquence de commandes suivante pour vous assurer "
+"que <application>jhbuild</application> dispose bien des outils voulus et "
+"pour vérifier que <application>jhbuild</application> est correctement "
+"paramétré : <screen>$ jhbuild bootstrap\n"
+"$ jhbuild sanitycheck</screen>"
+
+#: C/gtkmm-tutorial-in.xml:7868(title)
+msgid ""
+"Installing <application>gtkmm</application> with <application>jhbuild</"
+"application>"
+msgstr ""
+"Installation de <application>gtkmm</application> avec <application>jhbuild</"
+"application>"
+
+#: C/gtkmm-tutorial-in.xml:7869(para)
+msgid ""
+"If everything worked correctly, you should be able to build "
+"<application>gtkmm</application> and all of its dependencies from git by "
+"executing <command>jhbuild build</command> (or, if you didn't specify "
+"<application>gtkmm</application> in the <varname>modules</varname> variable, "
+"with the command <command>jhbuild build gtkmm</command>)."
+msgstr ""
+"Si tout fonctionne correctement, vous devez être capable de construire "
+"<application>gtkmm</application> et toutes ses dépendances à partir du dépôt "
+"git en exécutant la commande <command>jhbuild build</command> (ou, si vous "
+"n'avez pas précisé <application>gtkmm</application> dans la variable "
+"<varname>modules</varname>, avec la commande <command>jhbuild build gtkmm</"
+"command>). "
+
+#: C/gtkmm-tutorial-in.xml:7876(para)
+msgid ""
+"This command will build and install a series of modules and will probably "
+"take quite a long time the first time through. After the first time, "
+"however, it should go quite a bit faster since it only needs to rebuild "
+"files than changed since the last build. Alternatively, after you've built "
+"and installed <application>gtkmm</application> the first time, you can "
+"rebuild <application>gtkmm</application> by itself (without rebuilding all "
+"of its dependencies) with the command <command>jhbuild buildone gtkmm</"
+"command>."
+msgstr ""
+"Cette commande construit et installe une série de modules ; cela prend très "
+"certainement beaucoup de temps la première fois. Les fois suivantes, "
+"toutefois, cela devrait aller un peu plus vite étant donné que vous n'aurez "
+"à reconstruire que les fichiers modifiés depuis la dernière opération de "
+"construction. Sinon, après avoir construit et installé <application>gtkmm</"
+"application> la première fois, vous pouvez construire à nouveau "
+"<application>gtkmm</application> lui-même (sans reconstruire toutes ses "
+"dépendances) avec la commande <command>jhbuild buildone gtkmm</command>."
+
+#: C/gtkmm-tutorial-in.xml:7887(title)
+msgid "Using the git version of <application>gtkmm</application>"
+msgstr "Utilisation de la version git de <application>gtkmm</application>"
+
+#: C/gtkmm-tutorial-in.xml:7888(para)
+msgid ""
+"After you've installed the git version of <application>gtkmm</application>, "
+"you're ready to start using and experimenting with it. In order to use the "
+"new version of <application>gtkmm</application> you've just installed, you "
+"need to set some environment variables so that your <filename>configure</"
+"filename> script knows where to find the new libraries. Fortunately, "
+"<application>jhbuild</application> offers an easy solution to this problem. "
+"Executing the command <command>jhbuild shell</command> will start a new "
+"shell with all of the correct environment variables set. Now if you re-"
+"configure and build your project just as you usually do, it should link "
+"against the newly installed libraries. To return to your previous "
+"environment, simply exit the <application>jhbuild</application> shell."
+msgstr ""
+"Après avoir installé la version git de <application>gtkmm</application>, "
+"vous êtes prêt à commencer à l'utiliser et le tester. Pour utiliser la "
+"nouvelle version de <application>gtkmm</application> que vous venez "
+"d'installer, il est nécessaire de paramétrer certaines variables "
+"d'environnement pour que le script <filename>configure</filename> sache où "
+"trouver les nouvelles librairies. Fort heureusement, <application>jhbuild</"
+"application> offre une solution élégante à ce problème. L'exécution de la "
+"commande <command>jhbuild shell</command> ouvre un nouveau shell avec toutes "
+"les variables d'environnement correctement fixées. Maintenant si vous re-"
+"configurez et construisez votre projet comme vous avez l'habitude de faire, "
+"il fera l'édition des liens avec les bibliothèques nouvellement installées. "
+"Pour revenir dans votre environnement précédent, sortez simplement du shell "
+"<application>jhbuild</application>."
+
+#: C/gtkmm-tutorial-in.xml:7902(para)
+msgid ""
+"Once you've built your software, you'll need to run your program within the "
+"jhbuild environment as well. To do this, you can again use the "
+"<command>jhbuild shell</command> command to start a new shell with the "
+"<application>jhbuild</application> environment set up. Alternatively, you "
+"can execute a one-off command in the <application>jhbuild</application> "
+"environment using the following command: <command>jhbuild run command-name</"
+"command>. In this case, the command will be run with the correct environment "
+"variables set, but will return to your previous environment after the "
+"program exits."
+msgstr ""
+"Après avoir construit votre logiciel, vous devez également le lancer dans "
+"l'environnement jhbuild. Pour ce faire, vous pouvez une nouvelle fois "
+"utiliser la commande <command>jhbuild shell</command> pour ouvrir un nouveau "
+"shell dans l'environnement <application>jhbuild</application>. Autrement, "
+"vous pouvez lancer une commande à effet unique dans l'environnement "
+"<application>jhbuild</application> avec la commande suivante : "
+"<command>jhbuild run command-name</command>. Dans ce cas, la commande se "
+"déroule avec les variables d'environnement correctement fixées, mais elle "
+"retourne dans l'environnement précédent à la sortie du programme."
+
+#: C/gtkmm-tutorial-in.xml:7919(title)
+msgid "Wrapping C Libraries with gmmproc"
+msgstr "Habillage des bibliothèques C avec gmmproc"
+
+#: C/gtkmm-tutorial-in.xml:7920(para)
+msgid ""
+"<application>gtkmm</application> uses the <command>gmmproc</command> tool to "
+"generate most of its source code, using .defs files that define the APIs of "
+"<classname>GObject</classname>-based libraries. So it's quite easy to create "
+"additional gtkmm-style wrappers of other glib/GObject-based libraries."
+msgstr ""
+"<application>gtkmm</application> se sert de l'utilitaire <command>gmmproc</"
+"command> pour générer la plus grande partie de son code source, en utilisant "
+"les fichiers .defs définissant les API des bibliothèques fondées sur "
+"<classname>GObject</classname>. Il est donc facile de créer des habillages "
+"supplémentaires dans le style gtkmm pour les autres bibliothèques fondées "
+"sur glib/GObject."
+
+#: C/gtkmm-tutorial-in.xml:7925(para)
+msgid ""
+"This involves a variety of tools, some of them crufty, but it does at least "
+"work, and has been used successfully by several projects."
+msgstr ""
+"Cela implique divers outils, dont certains sont retors, mais qui au moins "
+"fonctionnent ; ils ont été utilisés avec succès par plusieurs projets."
+
+#: C/gtkmm-tutorial-in.xml:7930(title)
+msgid "The build structure"
+msgstr "La structure de construction"
+
+#: C/gtkmm-tutorial-in.xml:7931(para)
+msgid ""
+"Generation of the source code for a gtkmm-style wrapper API requires use of "
+"tools such as <command>gmmproc</command> and <filename>generate_wrap_init."
+"pl</filename>. In theory you could write your own build files to use these "
+"appropriately, but a much better option is to make use of the build "
+"infrastructure provided by the mm-common module. To get started, it helps a "
+"lot to pick an existing binding module as an example to look at."
+msgstr ""
+"Générer du code source pour un habillage d'API dans le style gtkmm requiert "
+"l'utilisation d'outils tels que <command>gmmproc</command> et "
+"<filename>generate_wrap_init.pl</filename>. En théorie, vous pouvez écrire "
+"vos propres fichiers de construction pour utiliser ces outils de manière "
+"appropriée, mais l'utilisation de l'infrastructure de construction fournie "
+"par le module mm-common est un meilleur choix. Prendre un module de liaison "
+"existant à titre d'exemple et l'examiner est un bon début."
+
+#: C/gtkmm-tutorial-in.xml:7938(para)
+msgid ""
+"For instance, let's pretend that we are wrapping a C library called "
+"libexample. It provides a <classname>GObject</classname>-based API with "
+"types named, for instance, <classname>ExampleThing</classname> and "
+"<classname>ExampleStuff</classname>."
+msgstr ""
+"Par exemple, disons que nous habillons une bibliothèque C nommée libexample. "
+"Elle fournit une API fondée sur <classname>GObject</classname> dont les "
+"types sont nommés, par exemple, <classname>ExampleThing</classname> et "
+"<classname>ExampleStuff</classname>."
+
+#: C/gtkmm-tutorial-in.xml:7944(title)
+msgid "Copying the skeleton project"
+msgstr "Copie du squelette du projet"
+
+#: C/gtkmm-tutorial-in.xml:7949(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+" $ git clone git://git.gnome.org/mm-common\n"
+" $ cp -a mm-common/skeletonmm libsomethingmm\n"
+msgstr ""
+"\n"
+" $ git clone git://git.gnome.org/mm-common\n"
+" $ cp -a mm-common/skeletonmm libsomethingmm\n"
+
+#: C/gtkmm-tutorial-in.xml:7946(para)
+msgid ""
+"Typically our wrapper library would be called libsomethingmm. We can start "
+"by copying the <ulink url=\"http://git.gnome.org/cgit/mm-common/tree/"
+"skeletonmm\">skeleton source tree</ulink> from the mm-common module. "
+"<placeholder-1/>"
+msgstr ""
+"Selon la coutume, la librairie habillée s'appellera libsomethingmm. Nous "
+"commençons par copier <ulink url=\"http://git.gnome.org/cgit/mm-common/tree/"
+"skeletonmm\">l'arborescence des sources squelettes</ulink> Ã partir du "
+"module mm-common. <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7959(para)
+msgid "<filename>libsomethingmm</filename>: The top-level directory."
+msgstr ""
+"<filename>libsomethingmm</filename> : le répertoire de plus haut niveau."
+
+#: C/gtkmm-tutorial-in.xml:7961(para)
+msgid ""
+"<filename>libsomething</filename>: Contains the main include file and the "
+"pkg-config .pc file."
+msgstr ""
+"<filename>libsomething</filename>Â : contient le fichier include principal et "
+"le fichier pkg-config .pc."
+
+#: C/gtkmm-tutorial-in.xml:7963(para)
+msgid "<filename>src</filename>: Contains .hg and .ccg source files."
+msgstr "<filename>src</filename>Â : contient les fichiers source .hg et .ccg."
+
+#: C/gtkmm-tutorial-in.xml:7964(para)
+msgid ""
+"<filename>libsomethingmm</filename>: Contains generated and hand-written .h "
+"and .cc files."
+msgstr ""
+"<filename>libsomethingmm</filename>Â : contient les fichiers .h et .cc "
+"générés et écrits à la main."
+
+#: C/gtkmm-tutorial-in.xml:7966(para)
+msgid ""
+"<filename>private</filename>: Contains generated <filename>*_p.h</filename> "
+"files."
+msgstr ""
+"<filename>private</filename> : contient les fichiers générés <filename>*_p."
+"h</filename>."
+
+#: C/gtkmm-tutorial-in.xml:7954(para)
+msgid ""
+"This provides a directory structure for the source .hg and .ccg files and "
+"the generated .h and .cc files, with <filename>filelist.am</filename> "
+"Automake include files that can specify the various files in use, in terms "
+"of generic Automake variables. The directory structure usually looks like "
+"this, after we have renamed the directories appropriately: <placeholder-1/>"
+msgstr ""
+"Cet arbre fournit une structure de répertoires pour les fichiers sources .hg "
+"et .ccg et pour les fichiers générés .h and .cc ; à l'aide du fichier "
+"<filename>filelist.am</filename>, Automake inclut des fichiers qui peuvent "
+"indiquer les divers fichiers utilisés sous forme de variables génériques "
+"Automake. L'arborescence ressemble alors à quelque chose comme cela après "
+"avoir renommé les répertoires de façon appropriée : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:7978(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"$ for f in $(find libsomethingmm -depth -name '*skeleton*'); do \\\n"
+" d=\"${f%/*}\"; b=\"${f##*/}\"; mv \"$f\" \"$d/${b//skeleton/libsomething}\"; \\\n"
+" done\n"
+msgstr ""
+"\n"
+"$ for f in $(find libsomethingmm -depth -name '*skeleton*'); do \\\n"
+" d=\"${f%/*}\"; b=\"${f##*/}\"; mv \"$f\" \"$d/${b//skeleton/libsomething}\"; \\\n"
+" done\n"
+
+#: C/gtkmm-tutorial-in.xml:7976(para)
+msgid ""
+"As well as renaming the directories, we should rename some of the source "
+"files. For instance: <placeholder-1/> A number of the skeleton files must "
+"still be filled in with project-specific content later."
+msgstr ""
+"De la même manière que nous avons renommé les répertoires, nous devons "
+"renommer certains fichiers sources. Par exemple : <placeholder-1/> Un "
+"certain nombre de fichiers squelettes doivent être complétés plus tard avec "
+"les données spécifiques au contenu du projet."
+
+#: C/gtkmm-tutorial-in.xml:7985(para)
+msgid ""
+"Note that files ending in <filename>.in</filename> will be used to generate "
+"files with the same name but without the <filename>.in</filename> suffix, by "
+"replacing some variables with actual values during the configure stage."
+msgstr ""
+"Notez que les fichiers avec l'extension <filename>.in</filename> seront "
+"utilisés pour générer des fichiers de même nom, mais sans extension, en "
+"remplaçant certaines variables par leur vraie valeur pendant la phase de "
+"traitement par le script configure."
+
+#: C/gtkmm-tutorial-in.xml:7991(title)
+msgid "Modifying build files"
+msgstr "Modification des fichiers de construction"
+
+#: C/gtkmm-tutorial-in.xml:7993(para)
+msgid ""
+"Now we edit the files to adapt them to to our needs. You might prefer to use "
+"a multiple-file search-replace utility for this, such as <command>regexxer</"
+"command>. Note that nearly all of the files provided with the skeleton "
+"source tree contain placeholder text. Thus, the substitutions should be "
+"performed globally, and not be limited to the Automake and Autoconf files."
+msgstr ""
+"Maintenant nous modifions les fichiers pour les adapter à nos besoins. Il se "
+"peut que préfériez utiliser un utilitaire rechercher-remplacer agissant sur "
+"plusieurs fichiers pour cette opération, comme <command>regexxer</command>. "
+"Notez que pratiquement tous les fichiers fournis avec l'arborescence des "
+"sources squelettes contiennent du texte à substituer. Ainsi, les "
+"substitutions doivent être effectuées globalement et non pas être limitées "
+"aux fichiers Automake et Autoconf."
+
+#: C/gtkmm-tutorial-in.xml:7997(para)
+msgid ""
+"All mentions of <varname>skeleton</varname> should be replaced by the "
+"correct name of the C library you are wrapping, such as \"something\" or "
+"\"libsomething\". In the same manner, all instances of <varname>SKELETON</"
+"varname> should be replaced by \"SOMETHING\" or \"LIBSOMETHING\", and all "
+"occurrences of <varname>Skeleton</varname> changed to \"Something\"."
+msgstr ""
+"Toutes les mentions de <varname>skeleton</varname> doivent être remplacées "
+"par le nom adéquat de la bibliothèque C que vous habillez, comme "
+"« something » ou « libsomething ». De la même manière, toutes les occurrences "
+"de <varname>SKELETON</varname> doivent être remplacées par « SOMETHING » ou "
+"« LIBSOMETHING » et celles de <varname>Skeleton</varname> par « Something »."
+
+#: C/gtkmm-tutorial-in.xml:8001(para)
+msgid ""
+"Likewise, replace all instances of <varname>Joe Hacker</varname> by the name "
+"of the intended copyright holder, which is probably you. Do the same for the "
+"<varname>joe example com</varname> email address."
+msgstr ""
+"De même, remplacez toutes les occurrences de <varname>Joe Hacker</varname> "
+"par le nom du détenteur du copyright â?? vous, probablement. Faites de même "
+"pour l'adresse courriel <varname>joe example com</varname>."
+
+#: C/gtkmm-tutorial-in.xml:8006(title)
+msgid "configure.ac"
+msgstr "configure.ac"
+
+#: C/gtkmm-tutorial-in.xml:8009(para)
+msgid ""
+"The <function>AC_CONFIG_SRCDIR()</function> line must mention a file in our "
+"source tree. We can edit this later if we don't yet know the names of any of "
+"the files that we will create."
+msgstr ""
+"la ligne <function>AC_CONFIG_SRCDIR()</function> doit mentionner un fichier "
+"de votre arborescence source. Vous pouvez modifier cela plus tard si vous ne "
+"connaissez pas encore les noms de certains fichiers à créer."
+
+#: C/gtkmm-tutorial-in.xml:8012(para)
+msgid ""
+"It is common for binding modules to track the version number of the library "
+"they are wrapping. So, for instance, if the C library is at version 1.23.4, "
+"then the initial version of the binding module would be 1.23.0. However, "
+"avoid starting with an even minor version number as that usually indicates a "
+"stable release."
+msgstr ""
+"il est courant pour les modules de liaison de garder trace du numéro de "
+"version de la bibliothèque qu'ils habillent. Ainsi, par exemple, si la "
+"bibliothèque C est à la version 1.23.4, alors la version initiale du module "
+"de liaison sera 1.23.0. �vitez toutefois de démarrer avec un numéro de "
+"version mineur pair, car il indique traditionnellement une version stable."
+
+#: C/gtkmm-tutorial-in.xml:8017(para)
+msgid ""
+"The <function>AC_CONFIG_HEADERS()</function> line is used to generate two or "
+"more configuration header files. The first header file in the list contains "
+"all configuration macros which are set during the configure run. The "
+"remaining headers in the list contain only a subset of configuration macros "
+"and their corresponding <filename>configh.h.in</filename> file will not be "
+"autogenerated. The reason for this separation is that the namespaced "
+"configuration headers are installed with your library and define publically "
+"visible macros."
+msgstr ""
+"la ligne <function>AC_CONFIG_HEADERS()</function> est utilisée pour générer "
+"deux ou plusieurs fichier d'en-tête de configuration. Le premier fichier "
+"d'en-tête de la liste comporte toutes les macros de configuration définies "
+"pendant le lancement de configure. Les en-têtes restants de la liste ne "
+"contiennent qu'un sous-ensemble des macros de configuration et leur fichier "
+"<filename>configh.h.in</filename> correspondant ne sera pas généré "
+"automatiquement. La raison de cette séparation est que les en-têtes de "
+"configuration avec une espace dans le nom sont installées dans votre "
+"bibliothèque et définissent des macros visibles publiquement."
+
+#: C/gtkmm-tutorial-in.xml:8025(para)
+msgid ""
+"The <function>AC_SUBST([SOMETHINGMM_MODULES], ['...'])</function> line may "
+"need to be modified to check for the correct dependencies."
+msgstr ""
+"il se peut que la ligne <function>AC_SUBST([SOMETHINGMM_MODULES], ['...'])</"
+"function> ait besoin d'être modifiée pour vérifier les dépendances adéquates."
+
+#: C/gtkmm-tutorial-in.xml:8027(para)
+msgid ""
+"The <function>AC_CONFIG_FILES()</function> block must mention the correct "
+"directory names, as described above."
+msgstr ""
+"le bloc <function>AC_CONFIG_FILES()</function> doit mentionner les noms de "
+"répertoires corrects, tels que décrits ci-dessus."
+
+#: C/gtkmm-tutorial-in.xml:8007(para)
+msgid "In <filename>configure.ac</filename>, <placeholder-1/>"
+msgstr "Dans <filename>configure.ac</filename>, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8034(title)
+msgid "Makefile.am files"
+msgstr "Fichiers Makefile.am"
+
+#: C/gtkmm-tutorial-in.xml:8037(para)
+msgid ""
+"In <filename>skeleton/src/Makefile.am</filename> we must mention the correct "
+"values for the generic variables that are used elsewhere in the build system:"
+msgstr ""
+"dans <filename>skeleton/src/Makefile.am</filename>, nous devons mentionner "
+"des valeurs correctes pour les variables génériques utilisées autre part "
+"dans le système de construction :"
+
+#: C/gtkmm-tutorial-in.xml:8042(varname)
+msgid "binding_name"
+msgstr "binding_name"
+
+#: C/gtkmm-tutorial-in.xml:8043(para)
+msgid "The name of the library, such as libsomethingmm."
+msgstr "le nom de la bibliothèque, comme libsomethingmm."
+
+#: C/gtkmm-tutorial-in.xml:8047(varname)
+msgid "wrap_init_flags"
+msgstr "wrap_init_flags"
+
+#: C/gtkmm-tutorial-in.xml:8048(para)
+msgid ""
+"Additional command-line flags passed to the <filename>generate_wrap_init.pl</"
+"filename> script, such as the C++ namespace and the parent directory prefix "
+"of include files."
+msgstr ""
+"des marqueurs additionnels en ligne de commande passés au script "
+"<filename>generate_wrap_init.pl</filename>, tels que le nom de l'espace de "
+"noms C++ et le préfixe du répertoire parent des fichiers include."
+
+#: C/gtkmm-tutorial-in.xml:8055(para)
+msgid ""
+"In <filename>skeleton/skeletonmm/Makefile.am</filename> we must mention the "
+"correct values for the generic variables that are used elsewhere in the "
+"build system:"
+msgstr ""
+"dans <filename>skeleton/skeletonmm/Makefile.am</filename>, nous devons "
+"mentionner des valeurs correctes pour les variables génériques utilisées "
+"autre part dans le système de construction :"
+
+#: C/gtkmm-tutorial-in.xml:8060(varname)
+msgid "lib_LTLIBRARIES"
+msgstr "lib_LTLIBRARIES"
+
+#: C/gtkmm-tutorial-in.xml:8061(para)
+msgid ""
+"This variable must mention the correct library name, and this library name "
+"must be used to form the <varname>_SOURCES</varname>, <varname>_LDFLAGS</"
+"varname>, and <varname>_LIBADD</varname> variable names. It is permissible "
+"to use variables substituted by <filename>configure</filename> like "
+"<varname>@SOMETHINGMM_API_VERSION@</varname> as part of the variable names."
+msgstr ""
+"cette variable doit indiquer le nom correct de la bibliothèque, tel "
+"qu'utilisé par les noms de variables <varname>_SOURCES</varname>, "
+"<varname>_LDFLAGS</varname> et <varname>_LIBADD</varname>. Il est autorisé "
+"d'utiliser des variables substituées par <filename>configure</filename> "
+"comme <varname>@SOMETHINGMM_API_VERSION@</varname> en tant que partie de "
+"noms de variables."
+
+#: C/gtkmm-tutorial-in.xml:8070(varname)
+msgid "AM_CPPFLAGS"
+msgstr "AM_CPPFLAGS"
+
+#: C/gtkmm-tutorial-in.xml:8071(para)
+msgid "The command line options passed to the C preprocessor."
+msgstr "les options en ligne de commande passées au préprocesseur C."
+
+#: C/gtkmm-tutorial-in.xml:8075(varname)
+msgid "AM_CXXFLAGS"
+msgstr "AM_CXXFLAGS"
+
+#: C/gtkmm-tutorial-in.xml:8076(para)
+msgid "The command line options passed to the C++ compiler."
+msgstr "les options en ligne de commande passées au compilateur C++."
+
+#: C/gtkmm-tutorial-in.xml:8035(para)
+msgid ""
+"Next we must adapt the various <filename>Makefile.am</filename> files: "
+"<placeholder-1/>"
+msgstr ""
+"Ensuite nous devons adapter les divers fichiers <filename>Makefile.am</"
+"filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8086(title)
+msgid "Creating .hg and .ccg files"
+msgstr "Création des fichiers .hg et .ccg"
+
+#: C/gtkmm-tutorial-in.xml:8087(para)
+msgid ""
+"We should now create our first <filename>.hg</filename> and <filename>.ccg</"
+"filename> files, to wrap one of the objects in the C library. One pair of "
+"example source files already exists: <filename>skeleton.ccg</filename> and "
+"<filename>skeleton.hg</filename>. Create copies of these files as necessary."
+msgstr ""
+"Vous devez maintenant créer vos premiers fichiers <filename>.hg</filename> "
+"et <filename>.ccg</filename> pour habiller quelques objets dans la librairie "
+"C. Il y a une paire de fichiers sources à titre d'exemple : "
+"<filename>skeleton.ccg</filename> et <filename>skeleton.hg</filename>. "
+"Faites des copies de ces fichiers si nécessaire."
+
+#: C/gtkmm-tutorial-in.xml:8091(para)
+msgid ""
+"We must mention all of our <filename>.hg</filename> and <filename>.ccg</"
+"filename> files in the <filename>skeleton/src/filelist.am</filename> file, "
+"typically in the <varname>files_hg</varname> variable."
+msgstr ""
+"Il faut mentionner tous les fichiers <filename>.hg</filename> et <filename>."
+"ccg</filename> dans le fichier <filename>skeleton/src/filelist.am</"
+"filename>, traditionnellement dans la variable <varname>files_hg</varname>."
+
+#: C/gtkmm-tutorial-in.xml:8095(para)
+msgid ""
+"Any additional non-generated <filename>.h</filename> and <filename>.cc</"
+"filename> source files may be placed in <filename>skeleton/skeletonmm/</"
+"filename> and listed in <filename>skeleton/skeletonmm/filelist.am</"
+"filename>, typically in the <varname>files_extra_h</varname> and "
+"<varname>files_extra_cc</varname> variables."
+msgstr ""
+"Tout fichier source <filename>.h</filename> et <filename>.cc</filename> non "
+"généré automatiquement doit être placé dans <filename>skeleton/skeletonmm/</"
+"filename> et énuméré dans <filename>skeleton/skeletonmm/filelist.am</"
+"filename>, traditionnellement dans les variables <varname>files_extra_h</"
+"varname> et <varname>files_extra_cc</varname>."
+
+#: C/gtkmm-tutorial-in.xml:8101(para)
+msgid ""
+"In the <link linkend=\"sec-wrapping-hg-files\">.hg and .ccg files</link> "
+"section you can learn about the syntax used in these files."
+msgstr ""
+"Dans le paragraphe <link linkend=\"sec-wrapping-hg-files\">Fichiers .hg et ."
+"ccg</link> vous pouvez voir la syntaxe utilisée dans ces fichiers."
+
+#: C/gtkmm-tutorial-in.xml:8108(title)
+msgid "Generating the .defs files."
+msgstr "Génération des fichiers .defs"
+
+#: C/gtkmm-tutorial-in.xml:8112(para)
+msgid "objects (GObjects, widgets, interfaces, boxed-types and plain structs)"
+msgstr ""
+"objets (GObjects, éléments graphiques, interfaces, types de boîtes et "
+"structures brutes)"
+
+#: C/gtkmm-tutorial-in.xml:8113(para)
+msgid "functions"
+msgstr "fonctions"
+
+#: C/gtkmm-tutorial-in.xml:8114(para)
+msgid "enums"
+msgstr "énumérations"
+
+#: C/gtkmm-tutorial-in.xml:8115(para)
+msgid "signals"
+msgstr "signaux"
+
+#: C/gtkmm-tutorial-in.xml:8116(para)
+msgid "properties"
+msgstr "propriétés"
+
+#: C/gtkmm-tutorial-in.xml:8117(para)
+msgid "vfuncs"
+msgstr "fonctions virtuelles."
+
+#: C/gtkmm-tutorial-in.xml:8109(para)
+msgid ""
+"The <filename>.defs</filename> file are text files, in a lisp format, that "
+"describe the API of a C library, including its <placeholder-1/>"
+msgstr ""
+"Les fichiers <filename>.defs</filename> sont des fichiers texte, au format "
+"lisp, décrivant l'API de la bibliothèque C, y compris ses <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8126(filename)
+msgid "gtk.defs"
+msgstr "gtk.defs"
+
+#: C/gtkmm-tutorial-in.xml:8127(para)
+msgid "Includes the other files."
+msgstr "inclut les autres fichiers."
+
+#: C/gtkmm-tutorial-in.xml:8130(filename)
+msgid "gtk_methods.defs"
+msgstr "gtk_methods.defs"
+
+#: C/gtkmm-tutorial-in.xml:8131(para)
+msgid "Objects and functions."
+msgstr "objets et fonctions"
+
+#: C/gtkmm-tutorial-in.xml:8134(filename)
+msgid "gtk_enums.defs"
+msgstr "gtk_enums.defs"
+
+#: C/gtkmm-tutorial-in.xml:8135(para)
+msgid "Enumerations."
+msgstr "énumérations."
+
+#: C/gtkmm-tutorial-in.xml:8138(filename)
+msgid "gtk_signals.defs"
+msgstr "gtk_signals.defs"
+
+#: C/gtkmm-tutorial-in.xml:8139(para)
+msgid "Signals and properties."
+msgstr "signaux et propriétés"
+
+#: C/gtkmm-tutorial-in.xml:8142(filename)
+msgid "gtk_vfuncs.defs"
+msgstr "gtk_vfuncs.defs"
+
+#: C/gtkmm-tutorial-in.xml:8143(para)
+msgid "vfuncs (function pointer member fields in structs), written by hand."
+msgstr ""
+"fonctions virtuelles (champs de pointeurs membres de fonction dans des "
+"structures), écrites à la main."
+
+#: C/gtkmm-tutorial-in.xml:8120(para)
+msgid ""
+"At the moment, we have separate tools for generating different parts of "
+"these <filename>.defs</filename>, so we split them up into separate files. "
+"For instance, in the <filename>gtk/src</filename> directory of the "
+"<application>gtkmm</application> sources, you will find these files: "
+"<placeholder-1/>"
+msgstr ""
+"� ce moment, nous disposons d'outils séparés pour générer les diverses "
+"parties des fichiers <filename>.defs</filename>, nous les éclatons donc en "
+"fichiers séparés. Par exemple, dans le répertoire <filename>gtk/src</"
+"filename> des sources de <application>gtkmm</application>, vous trouvez ces "
+"fichiers : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8149(title)
+msgid "Generating the methods .defs"
+msgstr "Génération des .defs pour les fonctions membres"
+
+#: C/gtkmm-tutorial-in.xml:8153(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"$ ./h2def.py /usr/include/gtk-2.0/gtk/*.h > gtk_methods.defs\n"
+msgstr ""
+"\n"
+"$ ./h2def.py /usr/include/gtk-2.0/gtk/*.h > gtk_methods.defs\n"
+
+#: C/gtkmm-tutorial-in.xml:8150(para)
+msgid ""
+"This <filename>.defs</filename> file describes objects and their functions. "
+"It is generated by the <command>h2def.py</command> script which you can find "
+"in pygobject's <filename>codegen</filename> directory. For instance, "
+"<placeholder-1/>"
+msgstr ""
+"Ce fichier <filename>.defs</filename> décrit les objets et leurs fonctions. "
+"Il est généré par le script <command>h2def.py</command> que vous trouverez "
+"dans le répertoire <filename>codegen</filename> des pygobject. Par exemple, "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8160(title)
+msgid "Generating the enums .defs"
+msgstr "Génération des .defs pour les énumérations"
+
+#: C/gtkmm-tutorial-in.xml:8164(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"$ ./enum.pl /usr/include/gtk-2.0/gtk/*.h > gtk_enums.defs\n"
+msgstr ""
+"\n"
+"$ ./enum.pl /usr/include/gtk-2.0/gtk/*.h > gtk_enums.defs\n"
+
+#: C/gtkmm-tutorial-in.xml:8161(para)
+msgid ""
+"This <filename>.defs</filename> file describes enum types and their possible "
+"values. It is generated by the <filename>enum.pl</filename> script which you "
+"can find in glibmm's <filename>tools</filename> directory. For instance, "
+"<placeholder-1/>"
+msgstr ""
+"Ce fichier <filename>.defs</filename> décrit les types enum et leurs valeurs "
+"possibles. Il est généré par le script <filename>enum.pl</filename> que vous "
+"trouverez dans le répertoire <filename>tools</filename> de glibmm. Par "
+"exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8171(title)
+msgid "Generating the signals and properties .defs"
+msgstr "Génération des .defs pour les signaux et les propriétés"
+
+#: C/gtkmm-tutorial-in.xml:8176(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"$ cd tools/extra_defs_gen\n"
+"$ ./generate_extra_defs > gtk_signals.defs\n"
+msgstr ""
+"\n"
+"$ cd tools/extra_defs_gen\n"
+"$ ./generate_extra_defs > gtk_signals.defs\n"
+
+#: C/gtkmm-tutorial-in.xml:8172(para)
+msgid ""
+"This <filename>.defs</filename> file describes signals and properties. It is "
+"generated by the special <filename>extra_defs</filename> utility that is in "
+"every wrapping project, such as <filename>gtkmm/tools/extra_defs_gen/</"
+"filename>. For instance <placeholder-1/>"
+msgstr ""
+"Ce fichier <filename>.defs</filename> décrit les signaux et les propriétés. "
+"Il est généré par l'utilitaire spécial <filename>extra_defs</filename> qui "
+"se trouve dans tout projet d'habillage, tel que <filename>gtkmm/tools/"
+"extra_defs_gen/</filename>. Par exemple <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8181(para)
+msgid ""
+"You must edit the source code of your own <filename>generate_extra_defs</"
+"filename> tool in order to generate the <filename>.defs</filename> for the "
+"GObject C types that you wish to wrap. In the skeleton source tree, the "
+"source file is named <filename>codegen/extradefs/"
+"generate_extra_defs_skeleton.cc</filename>. If not done so already, the file "
+"should be renamed, with the basename of your new binding substituted for the "
+"<varname>skeleton</varname> placeholder. The <filename>codegen/Makefile.am</"
+"filename> file should also mention the new source filename."
+msgstr ""
+"Vous devez rédiger le code source de votre propre outil "
+"<filename>generate_extra_defs</filename> pour générer les fichiers "
+"<filename>.defs</filename> des types C GObject que vous souhaitez habiller. "
+"Dans l'arborescence des sources squelettes, le fichier source s'appelle "
+"<filename>codegen/extradefs/generate_extra_defs_skeleton.cc</filename>. Si "
+"ce n'est pas déjà fait, le fichier doit être renommé en remplaçant la "
+"variable de substitution <varname>skeleton</varname> par le nom de base de "
+"la nouvelle liaison. Le fichier <filename>codegen/Makefile.am</filename> "
+"doit également citer le nouveau nom du fichier source."
+
+#: C/gtkmm-tutorial-in.xml:8190(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"#include <libsomething.h>\n"
+"\n"
+"int main(int, char**)\n"
+"{\n"
+" something_init();\n"
+"\n"
+" std::cout << get_defs(EXAMPLE_TYPE_SOMETHING)\n"
+" << get_defs(EXAMPLE_TYPE_THING);\n"
+" return 0;\n"
+"}\n"
+msgstr ""
+"\n"
+"#include <libsomething.h>\n"
+"\n"
+"int main(int, char**)\n"
+"{\n"
+" something_init();\n"
+"\n"
+" std::cout << get_defs(EXAMPLE_TYPE_SOMETHING)\n"
+" << get_defs(EXAMPLE_TYPE_THING);\n"
+" return 0;\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:8188(para)
+msgid ""
+"Then edit the <filename>.cc</filename> file to specify the correct types. "
+"For instance, your <function>main()</function> function might look like "
+"this: <placeholder-1/>"
+msgstr ""
+"Ensuite, modifiez le fichier <filename>.cc</filename> pour définir les types "
+"corrects. Par exemple, il se peut que votre fonction <function>main()</"
+"function> ressemble à quelque chose comme ceci : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8206(title)
+msgid "Writing the vfuncs .defs"
+msgstr "Ã?criture des .defs pour les fonctions virtuelles"
+
+#: C/gtkmm-tutorial-in.xml:8216(title)
+msgid "The .hg and .ccg files"
+msgstr "Les fichiers .hg et .ccg"
+
+#: C/gtkmm-tutorial-in.xml:8217(para)
+msgid ""
+"The .hg and .ccg source files are very much like .h anc .cc C++ source "
+"files, but they contain extra macros, such as <function>_CLASS_GOBJECT()</"
+"function> and <function>_WRAP_METHOD()</function>, from which "
+"<command>gmmproc</command> generates appropriate C++ source code, usually at "
+"the same position in the header. Any additional C++ source code will be "
+"copied verbatim into the corresponding .h or .cc file."
+msgstr ""
+"Les fichiers sources .hg et .ccg ressemblent tout à fait aux fichiers "
+"sources .h et .cc, mais il comportent des macros supplémentaires, telles que "
+"<function>_CLASS_GOBJECT()</function> et <function>_WRAP_METHOD()</"
+"function>, à partir desquelles <command>gmmproc</command> génére le code "
+"source C++ approprié, habituellement à la même position dans l'en-tête. Tout "
+"code source C++ sera copié mot pour mot dans le fichier .h ou .cc "
+"correspondant."
+
+#: C/gtkmm-tutorial-in.xml:8230(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"#include <gtkmm/bin.h>\n"
+"#include <gtkmm/stockid.h>\n"
+"_DEFS(gtkmm,gtk)\n"
+"_PINCLUDE(gtkmm/private/bin_p.h)\n"
+"\n"
+"namespace Gtk\n"
+"{\n"
+"\n"
+"class Button : public Bin\n"
+"{\n"
+" _CLASS_GTKOBJECT(Button,GtkButton,GTK_BUTTON,Gtk::Bin,GtkBin)\n"
+"public:\n"
+"\n"
+" _CTOR_DEFAULT\n"
+" explicit Button(const Glib::ustring& label, bool mnemonic = false);\n"
+" explicit Button(const StockID& stock_id);\n"
+"\n"
+" _WRAP_METHOD(void set_label(const Glib::ustring& label), gtk_button_set_label)\n"
+"\n"
+" ...\n"
+"\n"
+" _WRAP_SIGNAL(void clicked(), \"clicked\")\n"
+"\n"
+" ...\n"
+"\n"
+" _WRAP_PROPERTY(\"label\", Glib::ustring)\n"
+"};\n"
+"\n"
+"} // namespace Gtk\n"
+msgstr ""
+"\n"
+"#include <gtkmm/bin.h>\n"
+"#include <gtkmm/stockid.h>\n"
+"_DEFS(gtkmm,gtk)\n"
+"_PINCLUDE(gtkmm/private/bin_p.h)\n"
+"\n"
+"namespace Gtk\n"
+"{\n"
+"\n"
+"class Button : public Bin\n"
+"{\n"
+" _CLASS_GTKOBJECT(Button,GtkButton,GTK_BUTTON,Gtk::Bin,GtkBin)\n"
+"public:\n"
+"\n"
+" _CTOR_DEFAULT\n"
+" explicit Button(const Glib::ustring& label, bool mnemonic = false);\n"
+" explicit Button(const StockID& stock_id);\n"
+"\n"
+" _WRAP_METHOD(void set_label(const Glib::ustring& label), gtk_button_set_label)\n"
+"\n"
+" ...\n"
+"\n"
+" _WRAP_SIGNAL(void clicked(), \"clicked\")\n"
+"\n"
+" ...\n"
+"\n"
+" _WRAP_PROPERTY(\"label\", Glib::ustring)\n"
+"};\n"
+"\n"
+"} // espace de nom Gtk\n"
+
+#: C/gtkmm-tutorial-in.xml:8225(para)
+msgid ""
+"A .hg file will typically include some headers and then declare a class, "
+"using some macros to add API or behaviour to this class. For instance, "
+"gtkmm's <filename>button.hg</filename> looks roughly like this: <placeholder-"
+"1/>"
+msgstr ""
+"Un fichier .hg inclut habituellement certains fichiers d'en-tête, puis "
+"déclare une classe en utilisant certaines macros pour ajouter l'API ou "
+"certains comportements pour cette classe. Par exemple, <filename>button.hg</"
+"filename> de gtkmm ressemble grossièrement à ceci : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8265(function)
+msgid "_DEFS()"
+msgstr "_DEFS()"
+
+#: C/gtkmm-tutorial-in.xml:8266(para)
+msgid ""
+"Specifies the destination directry for generated sources, and the name of "
+"the main .defs file that <command>gmmproc</command> should parse."
+msgstr ""
+"précise le répertoire de destination pour les sources générées et le nom des "
+"principaux fichiers .defs que <command>gmmproc</command> doit analyser."
+
+#: C/gtkmm-tutorial-in.xml:8269(function)
+msgid "_PINCLUDE()"
+msgstr "_PINCLUDE()"
+
+#: C/gtkmm-tutorial-in.xml:8270(para)
+msgid ""
+"Tells <command>gmmproc</command> to include a header from the generated "
+"private/button_p.h file."
+msgstr ""
+"indique à <command>gmmproc</command> d'inclure un en-tête à partir du "
+"fichier private/button_p.h."
+
+#: C/gtkmm-tutorial-in.xml:8273(function)
+msgid "_CLASS_GTKOBJECT()"
+msgstr "_CLASS_GTKOBJECT()"
+
+#: C/gtkmm-tutorial-in.xml:8274(para)
+msgid ""
+"Tells <command>gmmproc</command> to add some typedefs, constructors, and "
+"standard methods to this class, as appropriate when wrapping a GtkObject-"
+"derived type."
+msgstr ""
+"demande à <command>gmmproc</command> d'ajouter de manière appropriée "
+"quelques définitions de types, constructeurs et fonctions membres standard à "
+"cette classe lors de l'habillage d'un type dérivé de GtkObject."
+
+#: C/gtkmm-tutorial-in.xml:8277(term)
+msgid ""
+"<function>_WRAP_METHOD()</function>, <function>_WRAP_SIGNAL()</function>, "
+"and <function>_WRAP_PROPERTY()</function>"
+msgstr ""
+"<function>_WRAP_METHOD()</function>, <function>_WRAP_SIGNAL()</function> et "
+"<function>_WRAP_PROPERTY()</function>"
+
+#: C/gtkmm-tutorial-in.xml:8280(para)
+msgid "Add methods to wrap parts of the C API."
+msgstr "ajoute des fonctions membres pour habiller des parties de l'API C."
+
+#: C/gtkmm-tutorial-in.xml:8262(para)
+msgid "The macros in this example do the following: <placeholder-1/>"
+msgstr ""
+"Les macros employées dans cet exemple effectuent les tâches suivantes : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8287(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"$ cd gtk/src\n"
+"$ /usr/lib/glibmm-2.4/proc/gmmproc -I ../../tools/m4 --defs . button . ./../gtkmm\n"
+msgstr ""
+"\n"
+"$ cd gtk/src\n"
+"$ /usr/lib/glibmm-2.4/proc/gmmproc -I ../../tools/m4 --defs . button . ./../gtkmm\n"
+
+#: C/gtkmm-tutorial-in.xml:8284(para)
+msgid ""
+"The .h and .cc files will be generated from the .hg and .ccg files by "
+"processing them with <command>gmmproc</command> like so, though this happens "
+"automatically when using the above build structure: <placeholder-1/>"
+msgstr ""
+"Les fichiers .h et .cc sont générées à partir des fichiers .hg et .ccg en "
+"les traitant de la sorte avec <command>gmmproc</command>, bien que ceci se "
+"fasse automatiquement en utilisant la structure de construction suivante : "
+"<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8292(para)
+msgid ""
+"Notice that we provided <command>gmmproc</command> with the path to the .m4 "
+"convert files, the path to the .defs file, the name of a .hg file, the "
+"source directory, and the destination directory."
+msgstr ""
+"Notez que nous appelons <command>gmmproc</command> avec comme paramètre le "
+"chemin vers les fichiers .m4 convertis, le chemin vers les fichiers .defs, "
+"le nom du fichier .hg, le répertoire source et le répertoire destination."
+
+#: C/gtkmm-tutorial-in.xml:8295(para)
+msgid ""
+"You should avoid including the C header from your C++ header, to avoid "
+"polluting the global namespace, and to avoid exporting unnecessary public "
+"API. But you will need to include the necessary C headers from your .ccg "
+"file."
+msgstr ""
+"Nous nous abstenons d'inclure le fichier d'en-tête C à partir de l'en-tête C+"
+"+ pour éviter de polluer l'espace de noms global et pour éviter d'exporter "
+"des API publiques non nécessaires. Mais vous aurez besoin d'inclure les en-"
+"têtes C nécessaires à partir de votre fichier .ccg."
+
+#: C/gtkmm-tutorial-in.xml:8300(para)
+msgid "The macros are explained in more detail in the following sections."
+msgstr ""
+"Les macros sont expliquées plus en détail dans les paragraphes suivants."
+
+#: C/gtkmm-tutorial-in.xml:8303(title)
+msgid "m4 Conversions"
+msgstr "Conversions m4"
+
+#: C/gtkmm-tutorial-in.xml:8310(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CONVERSION(`GtkTreeView*',`TreeView*',`Glib::wrap($3)')\n"
+msgstr ""
+"\n"
+"_CONVERSION(`GtkTreeView*',`TreeView*',`Glib::wrap($3)')\n"
+
+#: C/gtkmm-tutorial-in.xml:8304(para)
+msgid ""
+"The macros that you use in the .hg and .ccg files often need to know how to "
+"convert a C++ type to a C type, or vice-versa. gmmproc takes this "
+"information from an .m4 file in your <literal>tools/m4/</literal> directory. "
+"This allows it to call a C function in the implementation of your C++ "
+"method, passing the appropriate parameters to that C functon. For instance, "
+"this tells gmmproc how to convert a GtkTreeView pointer to a Gtk::TreeView "
+"pointer: <placeholder-1/>"
+msgstr ""
+"Les macros utilisées dans les fichiers .hg et .ccg ont souvent besoin de "
+"savoir comment convertir un type C++ en type C ou vice-versa. gmmproc prend "
+"cette information dans un fichier .m4 du répertoire <literal>tools/m4/</"
+"literal>. Celle-ci lui permet d'appeler une fonction C dans l'implémentation "
+"de votre fonction membre C++, en passant les paramètres appropriés à cette "
+"fonction C. Par exemple, cette macro indique à gmmproc comment convertir un "
+"pointeur GtkTreeView en pointeur Gtk::TreeView : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8315(para)
+msgid ""
+"<literal>$3</literal> will be replaced by the parameter name when this "
+"conversion is used by gmmproc."
+msgstr ""
+"<literal>$3</literal> sera remplacé par le nom du paramètre lorsque cette "
+"conversion est utilisée par gmmproc."
+
+#: C/gtkmm-tutorial-in.xml:8322(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CONVERSION(`PrintSettings&',`GtkPrintSettings*',__FR2P)\n"
+"_CONVERSION(`const PrintSettings&',`GtkPrintSettings*',__FCR2P)\n"
+"_CONVERSION(`const Glib::RefPtr<Printer>&',`GtkPrinter*',__CONVERT_REFPTR_TO_P($3))\n"
+msgstr ""
+"\n"
+"_CONVERSION(`PrintSettings&',`GtkPrintSettings*',__FR2P)\n"
+"_CONVERSION(`const PrintSettings&',`GtkPrintSettings*',__FCR2P)\n"
+"_CONVERSION(`const Glib::RefPtr<Printer>&',`GtkPrinter*',__CONVERT_REFPTR_TO_P($3))\n"
+
+#: C/gtkmm-tutorial-in.xml:8319(para)
+msgid ""
+"Some extra macros make this easier and consistent. Look in gtkmm's .m4 files "
+"for examples. For instance: <placeholder-1/>"
+msgstr ""
+"Quelques macros supplémentaires rendent ceci plus facile et plus cohérent. "
+"Regardez dans les fichiers .m4 pour des exemples. Ainsi :<placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8332(title)
+msgid "Class macros"
+msgstr "Macros de classes"
+
+#: C/gtkmm-tutorial-in.xml:8333(para)
+msgid ""
+"The class macro declares the class itself and its relationship with the "
+"underlying C type. It generates some internal constructors, the member "
+"<varname>gobject_</varname>, typedefs, the <function>gobj()</function> "
+"accessors, type registration, and the <function>Glib::wrap()</function> "
+"method, among other things."
+msgstr ""
+"La macro de classe déclare la classe elle-même et ses relations avec le type "
+"C sous-jacent. Elle génère certains constructeurs internes, la variable "
+"membre <varname>gobject_</varname>, des définitions de types, les mécanismes "
+"d'accès aux <function>gobj()</function>, l'enregistrement du type et la "
+"fonction membre <function>Glib::wrap()</function>, entre autres choses."
+
+#: C/gtkmm-tutorial-in.xml:8338(para)
+msgid ""
+"Other macros, such as <function>_WRAP_METHOD()</function> and "
+"<function>_SIGNAL()</function> may only be used after a call to a "
+"<function>_CLASS_*</function> macro."
+msgstr ""
+"D'autres macros, telles que <function>_WRAP_METHOD()</function> et "
+"<function>_SIGNAL()</function> ne peuvent être utilisées qu'après un appel "
+"de la macro <function>_CLASS_*</function>."
+
+#: C/gtkmm-tutorial-in.xml:8343(title)
+msgid "_CLASS_GOBJECT"
+msgstr "_CLASS_GOBJECT"
+
+#: C/gtkmm-tutorial-in.xml:8344(para) C/gtkmm-tutorial-in.xml:8434(para)
+msgid ""
+"This macro declares a wrapper for a type that is derived from "
+"<classname>GObject</classname>, but which is not derived from "
+"<classname>GtkObject</classname>."
+msgstr ""
+"Cette macro déclare un habillage pour un type dérivé de <classname>GObject</"
+"classname>, mais non-dérivé de <classname>GtkObject</classname>."
+
+#: C/gtkmm-tutorial-in.xml:8347(function)
+msgid ""
+"_CLASS_GOBJECT( C++ class, C class, C casting macro, C++ base class, C base "
+"class )"
+msgstr ""
+"_CLASS_GOBJECT( C++ class, C class, C casting macro, C++ base class, C base "
+"class )"
+
+#: C/gtkmm-tutorial-in.xml:8349(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CLASS_GOBJECT(AccelGroup, GtkAccelGroup, GTK_ACCEL_GROUP, Glib::Object, GObject)\n"
+msgstr ""
+"\n"
+"_CLASS_GOBJECT(AccelGroup, GtkAccelGroup, GTK_ACCEL_GROUP, Glib::Object, GObject)\n"
+
+#: C/gtkmm-tutorial-in.xml:8348(para)
+msgid "For instance, from <filename>accelgroup.hg</filename>: <placeholder-1/>"
+msgstr ""
+"Par exemple, Ã partir de <filename>accelgroup.hg</filename>Â : <placeholder-1/"
+">"
+
+#: C/gtkmm-tutorial-in.xml:8356(title)
+msgid "_CLASS_GTKOBJECT"
+msgstr "_CLASS_GTKOBJECT"
+
+#: C/gtkmm-tutorial-in.xml:8357(para)
+msgid ""
+"This macro declares a wrapper for a type that is derived from "
+"<classname>GtkObject</classname>, such as a widget or dialog."
+msgstr ""
+"Cette macro déclare un habillage pour un type dérivé de "
+"<classname>GtkObject</classname>, tel un élément graphique ou une boîte de "
+"dialogue."
+
+#: C/gtkmm-tutorial-in.xml:8359(function)
+msgid ""
+"_CLASS_GTKOBJECT( C++ class, C class, C casting macro, C++ base class, C "
+"base class )"
+msgstr ""
+"_CLASS_GTKOBJECT( C++ class, C class, C casting macro, C++ base class, C "
+"base class )"
+
+#: C/gtkmm-tutorial-in.xml:8361(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CLASS_GTKOBJECT(Button, GtkButton, GTK_BUTTON, Gtk::Bin, GtkBin)\n"
+msgstr ""
+"\n"
+"_CLASS_GTKOBJECT(Button, GtkButton, GTK_BUTTON, Gtk::Bin, GtkBin)\n"
+
+#: C/gtkmm-tutorial-in.xml:8360(para) C/gtkmm-tutorial-in.xml:8648(para)
+#: C/gtkmm-tutorial-in.xml:8679(para)
+msgid "For instance, from <filename>button.hg</filename>: <placeholder-1/>"
+msgstr ""
+"Par exemple, Ã partir de <filename>button.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8368(title)
+msgid "_CLASS_BOXEDTYPE"
+msgstr "_CLASS_BOXEDTYPE"
+
+#: C/gtkmm-tutorial-in.xml:8369(para)
+msgid ""
+"This macro declares a wrapper for a non-<classname>GObject</classname> "
+"struct, registered with <function>g_boxed_type_register_static()</function>."
+msgstr ""
+"Cette macro déclare un habillage pour une structure non-<classname>GObject</"
+"classname>, enregistrée avec <function>g_boxed_type_register_static()</"
+"function>."
+
+#: C/gtkmm-tutorial-in.xml:8372(function)
+msgid ""
+"_CLASS_BOXEDTYPE( C++ class, C class, new function, copy function, free "
+"function )"
+msgstr ""
+"_CLASS_BOXEDTYPE( C++ class, C class, new function, copy function, free "
+"function )"
+
+#: C/gtkmm-tutorial-in.xml:8374(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CLASS_BOXEDTYPE(Color, GdkColor, NONE, gdk_color_copy, gdk_color_free)\n"
+msgstr ""
+"\n"
+"_CLASS_BOXEDTYPE(Color, GdkColor, NONE, gdk_color_copy, gdk_color_free)\n"
+
+#: C/gtkmm-tutorial-in.xml:8373(para)
+msgid "For instance, for <classname>Gdk::Color</classname>: <placeholder-1/>"
+msgstr "Par exemple, pour <classname>Gdk::Color</classname>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8381(title)
+msgid "_CLASS_BOXEDTYPE_STATIC"
+msgstr "_CLASS_BOXEDTYPE_STATIC"
+
+#: C/gtkmm-tutorial-in.xml:8382(para)
+msgid ""
+"This macro declares a wrapper for a simple assignable struct such as "
+"<classname>GdkRectangle</classname>. It is similar to "
+"<function>_CLASS_BOXEDTYPE</function>, but the C struct is not allocated "
+"dynamically."
+msgstr ""
+"Cette macro déclare un habillage pour une simple structure assignable comme "
+"un <classname>GdkRectangle</classname>. Elle est semblable à "
+"<function>_CLASS_BOXEDTYPE</function>, mais la structure C n'est pas allouée "
+"dynamiquement."
+
+#: C/gtkmm-tutorial-in.xml:8386(function)
+msgid "_CLASS_BOXEDTYPE_STATIC( C++ class, C class )"
+msgstr "_CLASS_BOXEDTYPE_STATIC( C++ class, C class )"
+
+#: C/gtkmm-tutorial-in.xml:8388(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CLASS_BOXEDTYPE_STATIC(Rectangle, GdkRectangle)\n"
+msgstr ""
+"\n"
+"_CLASS_BOXEDTYPE_STATIC(Rectangle, GdkRectangle)\n"
+
+#: C/gtkmm-tutorial-in.xml:8387(para)
+msgid ""
+"For instance, for <classname>Gdk::Rectangle</classname>: <placeholder-1/>"
+msgstr ""
+"Par exemple, pour <classname>Gdk::Rectangle</classname>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8395(title)
+msgid "_CLASS_OPAQUE_COPYABLE"
+msgstr "_CLASS_OPAQUE_COPYABLE"
+
+#: C/gtkmm-tutorial-in.xml:8396(para)
+msgid ""
+"This macro declares a wrapper for an opaque struct that has copy and free "
+"functions. The new, copy and free functions will be used to instantiate the "
+"default constructor, copy constructor and destructor."
+msgstr ""
+"Cette macro déclare un habillage pour une structure opaque possédant des "
+"fonctions de copie et de libération. Les fonctions new, copy et free seront "
+"utilisées pour instancier le constructeur par défaut, le constructeur de "
+"copie et le destructeur."
+
+#: C/gtkmm-tutorial-in.xml:8399(function)
+msgid ""
+"_CLASS_OPAQUE_COPYABLE( C++ class, C class, new function, copy function, "
+"free function )"
+msgstr ""
+"_CLASS_OPAQUE_COPYABLE( C++ class,\n"
+" C class,\n"
+" new function,\n"
+" copy function,\n"
+" free function )"
+
+#: C/gtkmm-tutorial-in.xml:8401(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CLASS_OPAQUE_COPYABLE(Region, GdkRegion, gdk_region_new, gdk_region_copy, gdk_region_destroy)\n"
+msgstr ""
+"\n"
+"_CLASS_OPAQUE_COPYABLE(Region, \n"
+" GdkRegion,\n"
+" gdk_region_new,\n"
+" gdk_region_copy,\n"
+" gdk_region_destroy)\n"
+
+#: C/gtkmm-tutorial-in.xml:8400(para)
+msgid "For instance, for <classname>Gdk::Region</classname>: <placeholder-1/>"
+msgstr ""
+"Par exemple, pour <classname>Gdk::Region</classname>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8408(title)
+msgid "_CLASS_OPAQUE_REFCOUNTED"
+msgstr "_CLASS_OPAQUE_REFCOUNTED"
+
+#: C/gtkmm-tutorial-in.xml:8409(para)
+msgid ""
+"This macro declares a wrapper for a reference-counted opaque struct. The C++ "
+"wrapper cannot be directly instantiated and can only be used with "
+"<classname>Glib::RefPtr</classname>."
+msgstr ""
+"Cette macro déclare un habillage pour une structure opaque à décompte de "
+"références. L'habillage C++ ne peut pas être directement instancié et ne "
+"peut être utilisé qu'avec un pointeur intelligent <classname>Glib::RefPtr</"
+"classname>."
+
+#: C/gtkmm-tutorial-in.xml:8412(function)
+msgid ""
+"_CLASS_OPAQUE_COPYABLE( C++ class, C class, new function, ref function, "
+"unref function )"
+msgstr ""
+"_CLASS_OPAQUE_COPYABLE( C++ class, C class, new function, ref function, "
+"unref function )"
+
+#: C/gtkmm-tutorial-in.xml:8414(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CLASS_OPAQUE_REFCOUNTED(Coverage, PangoCoverage, pango_coverage_new, pango_coverage_ref, pango_coverage_unref)\n"
+msgstr ""
+"\n"
+"_CLASS_OPAQUE_REFCOUNTED(Coverage, \n"
+" PangoCoverage, \n"
+" pango_coverage_new, \n"
+" pango_coverage_ref, \n"
+" pango_coverage_unref)\n"
+
+#: C/gtkmm-tutorial-in.xml:8413(para)
+msgid ""
+"For instance, for <classname>Pango::Coverage</classname>: <placeholder-1/>"
+msgstr ""
+"Par exemple, pour <classname>Pango::Coverage</classname>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8421(title)
+msgid "_CLASS_GENERIC"
+msgstr "_CLASS_GENERIC"
+
+#: C/gtkmm-tutorial-in.xml:8422(para)
+msgid ""
+"This macro can be used to wrap structs which don't fit into any specialized "
+"category."
+msgstr ""
+"Cette macro peut être utilisée pour habiller les structures n'entrant pas "
+"dans une catégorie particulière."
+
+#: C/gtkmm-tutorial-in.xml:8424(function)
+msgid "_CLASS_GENERIC( C++ class, C class )"
+msgstr "_CLASS_GENERIC( C++ class, C class )"
+
+#: C/gtkmm-tutorial-in.xml:8426(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_CLASS_GENERIC(AttrIter, PangoAttrIterator)\n"
+msgstr ""
+"\n"
+"_CLASS_GENERIC(AttrIter, PangoAttrIterator)\n"
+
+#: C/gtkmm-tutorial-in.xml:8425(para)
+msgid ""
+"For instance, for <classname>Pango::AttrIter</classname>: <placeholder-1/>"
+msgstr ""
+"Par exemple, pour <classname>Pango::AttrIter</classname>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8433(title)
+msgid "_CLASS_INTERFACE"
+msgstr "_CLASS_INTERFACE"
+
+#: C/gtkmm-tutorial-in.xml:8438(function)
+msgid ""
+"_CLASS_INTERFACE( C++ class, C class, C casting macro, C interface struct, "
+"Base C++ class (optional), Base C class (optional) )"
+msgstr ""
+"_CLASS_INTERFACE( C++ class, C class, C casting macro, C interface struct, "
+"Base C++ class (optional), Base C class (optional) )"
+
+#: C/gtkmm-tutorial-in.xml:8441(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+" _CLASS_INTERFACE(CellEditable, GtkCellEditable, GTK_CELL_EDITABLE, GtkCellEditableIface)\n"
+msgstr ""
+"\n"
+" _CLASS_INTERFACE(CellEditable,\n"
+" GtkCellEditable,\n"
+" GTK_CELL_EDITABLE,\n"
+" GtkCellEditableIface)\n"
+
+#: C/gtkmm-tutorial-in.xml:8439(para)
+msgid ""
+"For instance, from <filename>celleditable.hg</filename>: <placeholder-1/>"
+msgstr ""
+"Par exemple, pour <filename>celleditable.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8448(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+" _CLASS_INTERFACE(LoadableIcon, GLoadableIcon, G_LOADABLE_ICON, GLoadableIconIface, Icon, GIcon)\n"
+msgstr ""
+"\n"
+" _CLASS_INTERFACE(LoadableIcon,\n"
+" GLoadableIcon,\n"
+" G_LOADABLE_ICON,\n"
+" GLoadableIconIface,\n"
+" Icon,\n"
+" GIcon)\n"
+
+#: C/gtkmm-tutorial-in.xml:8445(para)
+msgid ""
+"Two extra parameters are optional, for the case that the interface derives "
+"from another interface, which should be the case when the GInterface has "
+"another GInterface as a prerequisitite. For instance, from "
+"<filename>loadableicon.hg</filename>: <placeholder-1/>"
+msgstr ""
+"Deux paramètres sont optionnels, dans le cas où l'interface dérive d'une "
+"autre interface, ce qui doit être le cas quand la GInterface a une autre "
+"GInterface prérequise. Par exemple, pour <filename>loadableicon.hg</"
+"filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8458(title)
+msgid "Constructor macros"
+msgstr "Macros de constructeurs"
+
+#: C/gtkmm-tutorial-in.xml:8459(para)
+msgid ""
+"The <function>_CTOR_DEFAULT()</function> and <function>_WRAP_CTOR()</"
+"function> macros add constructors, wrapping the specified <function>*_new()</"
+"function> C functions. These macros assume that the C object has properties "
+"with the same names as the function parameters, as is usually the case, so "
+"that it can supply the parameters directly to a <function>g_object_new()</"
+"function> call. These constructors never actually call the <function>*_new()"
+"</function> C functions, because gtkmm must actually instantiate derived "
+"GTypes, and the <function>*_new()</function> C functions are meant only as "
+"convenience functions for C programmers."
+msgstr ""
+"Les macros <function>_CTOR_DEFAULT()</function> et <function>_WRAP_CTOR()</"
+"function> ajoutent des constructeurs, habillant les fonctions C "
+"<function>*_new()</function> spécifiées. Ces macros supposent que l'objet C "
+"a des propriétés de même nom que les paramètres de la fonction, ce qui est "
+"habituellement le cas ; ainsi il peut fournir les paramètres directement "
+"pour l'appel de <function>g_object_new()</function>. Ces constructeurs en "
+"réalité n'appellent jamais les fonctions C <function>*_new()</function>, car "
+"gtkmm doit en fait instancier des types GTypes dérivés et les fonctions C "
+"<function>*_new()</function> ne sont conçues que comme fonctions de "
+"commodité pour les programmeurs C."
+
+#: C/gtkmm-tutorial-in.xml:8474(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"class ActionGroup : public Glib::Object\n"
+"{\n"
+" _CLASS_GOBJECT(ActionGroup, GtkActionGroup, GTK_ACTION_GROUP, Glib::Object, GObject)\n"
+"\n"
+"protected:\n"
+" _WRAP_CTOR(ActionGroup(const Glib::ustring& name = Glib::ustring()), gtk_action_group_new)\n"
+"\n"
+"public:\n"
+" _WRAP_CREATE(const Glib::ustring& name = Glib::ustring())\n"
+msgstr ""
+"\n"
+"class ActionGroup : public Glib::Object\n"
+"{\n"
+" _CLASS_GOBJECT(ActionGroup, GtkActionGroup,\n"
+" GTK_ACTION_GROUP, Glib::Object, GObject)\n"
+"\n"
+"protected:\n"
+" _WRAP_CTOR(ActionGroup(const Glib::ustring& name = Glib::ustring()),\n"
+" gtk_action_group_new)\n"
+"\n"
+"public:\n"
+" _WRAP_CREATE(const Glib::ustring& name = Glib::ustring())\n"
+
+#: C/gtkmm-tutorial-in.xml:8469(para)
+msgid ""
+"When using <function>_CLASS_GOBJECT()</function>, the constructors should be "
+"protected (rather than public) and each constructor should have a "
+"corresponding <function>_WRAP_CREATE()</function> in the public section. "
+"This prevents the class from being instantiated without using a "
+"<classname>RefPtr</classname>. For instance: <placeholder-1/>"
+msgstr ""
+"Quand on utilise <function>_CLASS_GOBJECT()</function>, il faut que les "
+"constructeurs soient protégés (plutôt que publics) et chaque constructeur "
+"doit posséder une fonction correspondante <function>_WRAP_CREATE()</"
+"function> dans la section public. Ceci empêche l'instanciation de la classe "
+"sans utiliser de <classname>RefPtr</classname>. Par exemple : <placeholder-1/"
+">"
+
+#: C/gtkmm-tutorial-in.xml:8488(title)
+msgid "_CTOR_DEFAULT"
+msgstr "_CTOR_DEFAULT"
+
+#: C/gtkmm-tutorial-in.xml:8489(para)
+msgid "This macro creates a default constructor with no arguments."
+msgstr "Cette macro crée un constructeur par défaut sans paramètre."
+
+#: C/gtkmm-tutorial-in.xml:8494(title)
+msgid "_WRAP_CTOR"
+msgstr "_WRAP_CTOR"
+
+#: C/gtkmm-tutorial-in.xml:8495(para)
+msgid ""
+"This macro creates a constructor with arguments, equivalent to a "
+"<function>*_new()</function> C function. It won't actually call the "
+"<function>*_new()</function> function, but will simply create an equivalent "
+"constructor with the same argument types. It takes a C++ constructor "
+"signature, and a C function name."
+msgstr ""
+"Cette macro crée un constructeur avec paramètres, équivalent à la fonction C "
+"<function>*_new()</function>. Elle n'appelle pas réellement la fonction "
+"<function>*_new()</function>, mais elle crée simplement un constructeur "
+"équivalent avec les mêmes types de paramètres. Elle prend en paramètres la "
+"signature d'un constructeur C++ et un nom de fonction C."
+
+#: C/gtkmm-tutorial-in.xml:8504(title)
+msgid "Hand-coding constructors"
+msgstr "Constructeurs codés à la main"
+
+#: C/gtkmm-tutorial-in.xml:8513(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"Button::Button(const Glib::ustring& label, bool mnemonic)\n"
+":\n"
+" _CONSTRUCT(\"label\", label.c_str(), \"use_underline\", gboolean(mnemonic))\n"
+"{}\n"
+msgstr ""
+"\n"
+"Button::Button(const Glib::ustring& label, bool mnemonic)\n"
+":\n"
+" _CONSTRUCT(\"label\", label.c_str(), \"use_underline\", gboolean(mnemonic))\n"
+"{}\n"
+
+#: C/gtkmm-tutorial-in.xml:8505(para)
+msgid ""
+"When a constructor must be partly hand written because, for instance, the "
+"<function>*_new()</function> C function's parameters do not correspond "
+"directly to object properties, or because the <function>*_new()</function> C "
+"function does more than call <function>g_object_new()</function>, the "
+"<function>_CONSTRUCT()</function> macro may be used in the .ccg file to save "
+"some work. The <function>_CONSTRUCT</function> macro takes a series of "
+"property names and values. For instance, from <filename>button.ccg</"
+"filename>: <placeholder-1/>"
+msgstr ""
+"Quand un constructeur doit être partiellement écrit à la main parce que, par "
+"exemple, les paramètres de la fonction C <function>*_new()</function> ne "
+"correspondent pas directement aux propriétés de l'objet ou parce que la "
+"fonction C <function>*_new()</function> fait plus qu'appeler "
+"<function>g_object_new()</function>, la macro <function>_CONSTRUCT()</"
+"function> peut s'utiliser dans le fichier .ccg pour s'économiser un peu de "
+"travail. La macro <function>_CONSTRUCT</function> prend comme paramètres une "
+"série de noms de propriétés et de valeurs. Par exemple, pour "
+"<filename>button.ccg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8525(title)
+msgid "Method macros"
+msgstr "Macros pour fonctions membres"
+
+#: C/gtkmm-tutorial-in.xml:8528(title)
+msgid "_WRAP_METHOD"
+msgstr "_WRAP_METHOD"
+
+#: C/gtkmm-tutorial-in.xml:8529(para)
+msgid "This macro generates the C++ method to wrap a C function."
+msgstr "Cette macro génère une fonction membre C++ habillant une fonction C."
+
+#: C/gtkmm-tutorial-in.xml:8530(function)
+msgid "_WRAP_METHOD( C++ method signature, C function name)"
+msgstr "_WRAP_METHOD( C++ method signature, C function name)"
+
+#: C/gtkmm-tutorial-in.xml:8532(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_WRAP_METHOD(void set_text(const Glib::ustring& text), gtk_entry_set_text)\n"
+msgstr ""
+"\n"
+"_WRAP_METHOD(void set_text(const Glib::ustring& text), gtk_entry_set_text)\n"
+
+#: C/gtkmm-tutorial-in.xml:8531(para)
+msgid "For instance, from <filename>entry.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, pour <filename>entry.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8536(para)
+msgid ""
+"The C function (e.g. <function>gtk_entry_set_text</function>) is described "
+"more fully in the .defs file, and the <filename>convert*.m4</filename> files "
+"contain the necessary conversion from the C++ parameter type to the C "
+"parameter type. This macro also generates doxygen documentation comments "
+"based on the <filename>*_docs.xml</filename> and <filename>*_docs_override."
+"xml</filename> files."
+msgstr ""
+"La fonction C (par exemple, <function>gtk_entry_set_text</function>) est "
+"décrite plus précisément dans les fichiers .defs et les fichiers "
+"<filename>convert*.m4</filename> contiennent la conversion nécessaire des "
+"types de paramètres C++ vers les paramètres de type C. Cette macro génère "
+"également des commentaires pour la documentation doxygen à partir des "
+"fichiers <filename>*_docs.xml</filename> et <filename>*_docs_override.xml</"
+"filename>."
+
+#: C/gtkmm-tutorial-in.xml:8545(term)
+msgid "refreturn"
+msgstr "refreturn"
+
+#: C/gtkmm-tutorial-in.xml:8547(para)
+msgid ""
+"Do an extra reference() on the return value, in case the C function does not "
+"provide a reference."
+msgstr ""
+"effectue un appel supplémentaire à reference() sur la valeur de retour au "
+"cas où la fonction C ne fournirait pas de référence."
+
+#: C/gtkmm-tutorial-in.xml:8552(term)
+msgid "errthrow"
+msgstr "errthrow"
+
+#: C/gtkmm-tutorial-in.xml:8554(para)
+msgid "Use the last GError* parameter of the C function to throw an exception."
+msgstr ""
+"utilise le dernier paramètre GError* de la fonction C pour déclencher une "
+"exception."
+
+#: C/gtkmm-tutorial-in.xml:8559(term)
+msgid "deprecated"
+msgstr "deprecated"
+
+#: C/gtkmm-tutorial-in.xml:8561(para)
+msgid ""
+"Puts the generated code in #ifdef blocks. Text about the deprecation can be "
+"specified as an optional parameter."
+msgstr ""
+"place le code généré dans un bloc #ifdef. Le texte concernant l'abandon "
+"peut être précisé en tant que paramètre optionnel."
+
+#: C/gtkmm-tutorial-in.xml:8567(term)
+msgid "constversion"
+msgstr "constversion"
+
+#: C/gtkmm-tutorial-in.xml:8569(para)
+msgid ""
+"Just call the non-const version of the same function, instead of generating "
+"almost duplicate code."
+msgstr ""
+"appelle simplement la version non-const de la même fonction au lieu de "
+"générer du code dupliqué."
+
+#: C/gtkmm-tutorial-in.xml:8542(para) C/gtkmm-tutorial-in.xml:8656(para)
+msgid "There are some optional extra arguments: <placeholder-1/>"
+msgstr ""
+"Il y a quelques paramètres optionnels supplémentaires : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8577(para)
+msgid ""
+"Objects used via <classname>RefPtr</classname>: Pass the <classname>RefPtr</"
+"classname> as a const reference. For instance, <code>const Glib::RefPtr<"
+"Gtk::Action>& action</code>."
+msgstr ""
+"Objets utilisés par l'intermédiaire d'un <classname>RefPtr</classname> : "
+"passez le <classname>RefPtr</classname> en tant que référence const, par "
+"exemple, <code>const Glib::RefPtr<Gtk::Action>& action</code>."
+
+#: C/gtkmm-tutorial-in.xml:8581(para)
+msgid ""
+"Const Objects used via <classname>RefPtr</classname>: If the object should "
+"not be changed by the function, then make sure that the object is const, "
+"even if the <classname>RefPtr</classname> is already const. For instance, "
+"<code>const Glib::RefPtr<const Gtk::Action>& action</code>."
+msgstr ""
+"Objets const utilisés par l'intermédiaire d'un <classname>RefPtr</"
+"classname> : si l'objet ne doit pas être modifié par la fonction, assurez-"
+"vous que l'objet est const, même si le <classname>RefPtr</classname> est "
+"déjà const, par exemple, <code>const Glib::RefPtr<const Gtk::Action>"
+"& action</code>."
+
+#: C/gtkmm-tutorial-in.xml:8586(para)
+msgid ""
+"Wrapping <classname>GList*</classname> and <classname>GSList*</classname> "
+"parameters: First, you need to discover what objects are contained in the "
+"list's data field for each item, usually by reading the documentation for "
+"the C function. The list can then be wrapped by an appropriate intermediate "
+"type, such as <classname>Glib::ListHandle</classname> or <classname>Glib::"
+"SListHandle</classname>. These are templates, so you can specify the item "
+"type. For instance, <code>Glib::ListHandle< Glib::RefPtr<Action> "
+"></code>. Existing typedefs exist for some common list types. You may "
+"need to define a Traits type to specify how the C and C++ types should be "
+"converted."
+msgstr ""
+"Habillage des paramètres <classname>GList*</classname> et "
+"<classname>GSList*</classname> : d'abord, vous devez découvrir quels objets "
+"sont contenus dans les champs des données de la liste pour chaque élément, "
+"généralement en lisant la documentation de la fonction C. La liste peut être "
+"habillée dans un type intermédiaire approprié, tel que <classname>Glib::"
+"ListHandle</classname> ou <classname>Glib::SListHandle</classname>. Ce sont "
+"des contenus génériques ; vous pouvez donc préciser le type d'élément, par "
+"exemple, <code>Glib::ListHandle< Glib::RefPtr<Action> ></code>. "
+"Il y a des définitions de type existantes pour quelques types de listes "
+"courants. Vous pouvez avoir besoin de définir un type Traits pour préciser "
+"comment les types C et C++ doivent être convertis."
+
+#: C/gtkmm-tutorial-in.xml:8605(programlisting)
+#, no-wrap
+msgid "#m4 _CONVERSION(`GSList*', `Glib::SListHandle<Widget*>', `$2($3, Glib::OWNERSHIP_NONE)')"
+msgstr "#m4 _CONVERSION(`GSList*', `Glib::SListHandle<Widget*>', `$2($3, Glib::OWNERSHIP_NONE)')"
+
+#: C/gtkmm-tutorial-in.xml:8597(para)
+msgid ""
+"Wrapping <classname>GList*</classname> and <classname>GSList*</classname> "
+"return types: You must discover whether the caller should free the list and "
+"whether it should release the items in the list, again by reading the "
+"documentation of the C function. With this information you can choose the "
+"ownership (none, shallow or deep) for the m4 conversion rule, which you "
+"should probably put directly into the .hg file because the ownership depends "
+"on the function rather than the type. For instance: <placeholder-1/>"
+msgstr ""
+"Habillage des types de retour des <classname>GList*</classname> et "
+"<classname>GSList*</classname> : vous devez découvrir comment l'appelant "
+"libère la liste et comment il libère les éléments de la liste, à nouveau en "
+"lisant la documentation de la fonction C. Avec ces informations vous pouvez "
+"choisir le type de propriété (aucun (none), superficiel (shallow), profond "
+"(deep)) pour la règle de conversion m4, règle que vous placerez probablement "
+"directement dans le fichier .hg parce que le type de propriété dépend plutôt "
+"de la fonction que du type, par exemple : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8575(para)
+msgid ""
+"Though it's usually obvious what C++ types should be used in the C++ method, "
+"here are some hints: <placeholder-1/>"
+msgstr ""
+"Même s'il est généralement évident que les types C++ devraient être utilisés "
+"dans les fonctions membres C++, voici quelques astuces : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8611(title)
+msgid "_WRAP_METHOD_DOCS_ONLY"
+msgstr "_WRAP_METHOD_DOCS_ONLY"
+
+#: C/gtkmm-tutorial-in.xml:8612(para)
+msgid ""
+"This macro is like <function>_WRAP_METHOD()</function>, but it generates "
+"only the documentation for a C++ method that wraps a C function. Use this "
+"when you must hand-code the method, but you want to use the documentation "
+"that would be generated if the method was generated."
+msgstr ""
+"Cette macro est comparable à la macro <function>_WRAP_METHOD()</function>, "
+"mais elle ne génère la documentation que dans le cas d'une fonction membre C+"
+"+ habillant une fonction C. Utilisez-la si vous devez coder à la main la "
+"fonction membre, mais vous voulez utiliser la documentation qui serait "
+"générée si la fonction membre était générée."
+
+#: C/gtkmm-tutorial-in.xml:8616(function)
+msgid "_WRAP_METHOD_DOCS_ONLY(C function name)"
+msgstr "_WRAP_METHOD_DOCS_ONLY(C function name)"
+
+#: C/gtkmm-tutorial-in.xml:8618(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_WRAP_METHOD_DOCS_ONLY(gtk_container_remove)\n"
+msgstr ""
+"\n"
+"_WRAP_METHOD_DOCS_ONLY(gtk_container_remove)\n"
+
+#: C/gtkmm-tutorial-in.xml:8617(para)
+msgid "For instance, from <filename>container.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, pour <filename>container.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8625(title)
+msgid "_IGNORE()"
+msgstr "_IGNORE()"
+
+#: C/gtkmm-tutorial-in.xml:8626(para)
+msgid ""
+"<command>gmmproc</command> will warn you on stdout about functions that you "
+"have forgotten to wrap, helping to ensure that you are wrapping the complete "
+"API. Buf if you don't want to wrap some functions or if you chose to hand-"
+"code some methods then you can use the _IGNORE() macro the make "
+"<command>gmmproc</command> stop complaining."
+msgstr ""
+"<command>gmmproc</command> émet un avertissement sur stdout à propos des "
+"fonctions que vous avez oubliées d'habiller, pour vous aider à être sûr "
+"d'avoir bien habillé la totalité de l'API. Mais si vous ne voulez pas "
+"habiller certaines fonctions ou si vous avez choisi de coder à la main "
+"certaines fonctions membres, vous pouvez alors utiliser la macro _IGNORE() "
+"pour que <command>gmmproc</command> arrête de se plaindre."
+
+#: C/gtkmm-tutorial-in.xml:8631(function)
+msgid "_IGNORE(C function name 1, C function name2, etc)"
+msgstr "_IGNORE(C function name 1, C function name2, etc)"
+
+#: C/gtkmm-tutorial-in.xml:8633(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_IGNORE(gtk_button_box_set_spacing, gtk_button_box_get_spacing,\n"
+msgstr ""
+"\n"
+"_IGNORE(gtk_button_box_set_spacing, gtk_button_box_get_spacing,\n"
+
+#: C/gtkmm-tutorial-in.xml:8632(para)
+msgid "For instance, from <filename>buttonbox.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, pour <filename>buttonbox.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8640(title)
+msgid "_WRAP_SIGNAL"
+msgstr "_WRAP_SIGNAL"
+
+#: C/gtkmm-tutorial-in.xml:8641(para)
+msgid ""
+"This macro generates the C++ libsigc++-style signal to wrap a C GObject "
+"signal. It actually generates a public accessor method, such as "
+"<function>signal_clicked()</function>, which returns a proxy object. "
+"<command>gmmproc</command> uses the .defs file to discover the C parameter "
+"types and the .m4 convert files to discover appropriate type conversions."
+msgstr ""
+"Cette macro génère le signal C++ de style libsigc++ habillant un signal C "
+"GObject. Il génère en fait un mécanisme d'accès public, comme "
+"<function>signal_clicked()</function>, qui renvoie un objet mandataire. "
+"<command>gmmproc</command> utilise le fichier .defs pour découvrir le type "
+"des paramètres du C et les fichiers de conversion .m4 pour découvrir les "
+"types de conversion appropriés."
+
+#: C/gtkmm-tutorial-in.xml:8647(function)
+msgid "_WRAP_SIGNAL( C++ signal handler signature, C signal name)"
+msgstr "_WRAP_SIGNAL( C++ signal handler signature, C signal name)"
+
+#: C/gtkmm-tutorial-in.xml:8649(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_WRAP_SIGNAL(void clicked(),\"clicked\")\n"
+msgstr ""
+"\n"
+"_WRAP_SIGNAL(void clicked(),\"clicked\")\n"
+
+#: C/gtkmm-tutorial-in.xml:8653(para)
+msgid ""
+"Signals usually have function pointers in the GTK struct, with a "
+"corresponding enum value. and a <function>g_signal_new()</function> in the ."
+"c file."
+msgstr ""
+"Les signaux ont généralement des pointeurs de fonction dans la structure "
+"GTK, avec une valeur d'énumération correspondante, et une fonction "
+"<function>g_signal_new()</function> dans le fichier .c."
+
+#: C/gtkmm-tutorial-in.xml:8659(term)
+msgid "no_default_handler"
+msgstr "no_default_handler"
+
+#: C/gtkmm-tutorial-in.xml:8661(para)
+msgid ""
+"Do not generate an <function>on_something()</function> virtual method to "
+"allow easy overriding of the default signal handler. Use this when adding a "
+"signal with a default signal handler would break the ABI by increasing the "
+"size of the class's virtual function table."
+msgstr ""
+"ne pas générer une fonction membre virtuelle <function>on_something()</"
+"function> pour faciliter la surdéfinition du gestionnaire de signal par "
+"défaut. Ce paramètre est à utiliser quand l'ajout d'un signal avec son "
+"gestionnaire par défaut casserait l'ABI (Application Binary Interface) en "
+"augmentant la taille de la table des fonctions virtuelles de la classe."
+
+#: C/gtkmm-tutorial-in.xml:8673(title)
+msgid "_WRAP_PROPERTY"
+msgstr "_WRAP_PROPERTY"
+
+#: C/gtkmm-tutorial-in.xml:8674(para)
+msgid ""
+"This macro generates the C++ method to wrap a C GObject property. You must "
+"specify the property name and the wanted C++ type for the property. "
+"<command>gmmproc</command> uses the .defs file to discover the C type and "
+"the .m4 convert files to discover appropriate type conversions."
+msgstr ""
+"Cette macro génère une fonction membre C++ habillant une propriété d'un "
+"GObject C. Vous devez indiquer le nom de la propriété et le type C++ "
+"souhaité pour la propriété. <command>gmmproc</command> utilise le fichier ."
+"defs pour connaître le type C et les fichiers de conversion .m4 pour "
+"découvrir les types appropriés de conversion."
+
+#: C/gtkmm-tutorial-in.xml:8678(function)
+msgid "_WRAP_PROPERTY(C property name, C++ type)"
+msgstr "_WRAP_PROPERTY(C property name, C++ type)"
+
+#: C/gtkmm-tutorial-in.xml:8680(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_WRAP_PROPERTY(\"label\", Glib::ustring)\n"
+msgstr ""
+"\n"
+"_WRAP_PROPERTY(\"label\", Glib::ustring)\n"
+
+#: C/gtkmm-tutorial-in.xml:8689(title)
+msgid "Other macros"
+msgstr "Autres macros :"
+
+#: C/gtkmm-tutorial-in.xml:8691(title)
+msgid "_WRAP_ENUM"
+msgstr "_WRAP_ENUM"
+
+#: C/gtkmm-tutorial-in.xml:8692(para)
+msgid ""
+"This macro generates a C++ enum to wrap a C enum. You must specify the "
+"desired C++ name and the name of the underlying C enum."
+msgstr ""
+"Cette macro génère une énumération C++ pour habiller une énumération C. Vous "
+"devez préciser le nom C++ et le nom de l'énumération C subjacente."
+
+#: C/gtkmm-tutorial-in.xml:8695(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_WRAP_ENUM(WindowType, GdkWindowType)\n"
+msgstr ""
+"\n"
+"_WRAP_ENUM(WindowType, GdkWindowType)\n"
+
+#: C/gtkmm-tutorial-in.xml:8694(para)
+msgid "For instance, from <filename>widget.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, pour <filename>widget.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8699(para)
+msgid ""
+"If the enum is not a <classname>GType</classname>, you must pass a third "
+"parameter NO_GTYPE. This is the case when there is no <function>*_get_type()"
+"</function> function for the C enum, but be careful that you don't just need "
+"to include an extra header for that function. You should also file a bug "
+"against the C API, because all enums should be registered as GTypes."
+msgstr ""
+"Si l'énumération n'est pas du type <classname>GType</classname>, vous devrez "
+"passer comme troisième paramètre NO_GTYPE. C'est le cas lorsqu'il n'existe "
+"pas de fonction <function>*_get_type()</function> pour l'énumération C ; "
+"mais, faites attention au fait qu'il n'est pas suffisant d'inclure un en-"
+"tête supplémentaire pour cette fonction. Vous devez également faire un "
+"rapport d'anomalie concernant l'API C étant donné que toutes les "
+"énumérations doivent être enregistrées en tant que GTypes."
+
+#: C/gtkmm-tutorial-in.xml:8704(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_WRAP_ENUM(IconLookupFlags, GtkIconLookupFlags)\n"
+msgstr ""
+"\n"
+"_WRAP_ENUM(IconLookupFlags, GtkIconLookupFlags)\n"
+
+#: C/gtkmm-tutorial-in.xml:8703(para)
+msgid "For example: <placeholder-1/>"
+msgstr "Par exemple : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8711(title)
+msgid "_WRAP_GERROR"
+msgstr "_WRAP_GERROR"
+
+#: C/gtkmm-tutorial-in.xml:8712(para)
+msgid ""
+"This macro generates a C++ exception class, derived from Glib::Error, with a "
+"Code enum and a code() method. You must specify the desired C++ name, the "
+"name of the corresponding C enum, and the prefix for the C enum values."
+msgstr ""
+"Cette macro génère une classe d'exception C++, dérivée de Glib::Error, avec "
+"un Code enum et une fonction membre code(). Vous devez préciser le nom C++ "
+"souhaité, le nom de l'énumération correspondante C et le préfixe pour les "
+"valeurs d'énumération C."
+
+#: C/gtkmm-tutorial-in.xml:8715(para)
+msgid ""
+"This exception can then be thrown by methods which are generated from "
+"_WRAP_METHOD() with the errthrow option."
+msgstr ""
+"Cette exception peut alors être déclenchée par des fonctions membres "
+"générées par _WRAP_METHOD() avec l'option errthrow."
+
+#: C/gtkmm-tutorial-in.xml:8717(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_WRAP_GERROR(PixbufError, GdkPixbufError, GDK_PIXBUF_ERROR)\n"
+msgstr ""
+"\n"
+"_WRAP_GERROR(PixbufError, GdkPixbufError, GDK_PIXBUF_ERROR)\n"
+
+#: C/gtkmm-tutorial-in.xml:8716(para)
+msgid "For instance, from <filename>pixbuf.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, pour <filename>pixbuf.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8724(title)
+msgid "_MEMBER_GET / _MEMBER_SET"
+msgstr "_MEMBER_GET / _MEMBER_SET"
+
+#: C/gtkmm-tutorial-in.xml:8725(para)
+msgid ""
+"Use these macro if you're wrapping a simple struct or boxed type that "
+"provides direct access to its data members, to create getters and setters "
+"for the data members."
+msgstr ""
+"Si vous habillez une simple structure ou un type de boîte qui autorise un "
+"accès direct à ses données membres, utilisez cette macro pour créer les "
+"obtenteurs (get) et mutateurs (set) des données membres."
+
+#: C/gtkmm-tutorial-in.xml:8729(function)
+msgid "_MEMBER_GET(C++ name, C name, C++ type, C type)"
+msgstr "_MEMBER_GET(C++ name, C name, C++ type, C type)"
+
+#: C/gtkmm-tutorial-in.xml:8730(function)
+msgid "_MEMBER_SET(C++ name, C name, C++ type, C type)"
+msgstr "_MEMBER_SET(C++ name, C name, C++ type, C type)"
+
+#: C/gtkmm-tutorial-in.xml:8733(programlisting)
+#, no-wrap
+msgid "_MEMBER_GET(x, x, int, int)"
+msgstr "_MEMBER_GET(x, x, int, int)"
+
+#: C/gtkmm-tutorial-in.xml:8731(para)
+msgid "For example, in <filename>rectangle.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, dans <filename>rectangle.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8737(title)
+msgid "_MEMBER_GET_PTR / _MEMBER_SET_PTR"
+msgstr "_MEMBER_GET_PTR / _MEMBER_SET_PTR"
+
+#: C/gtkmm-tutorial-in.xml:8738(para)
+msgid ""
+"Use these macros to automatically provide getters and setters for a data "
+"member that is a pointer type. For the getter function, it will create two "
+"methods, one const and one non-const."
+msgstr ""
+"Utilisez ces macros pour créer automatiquement des obtenteurs (get) et des "
+"mutateurs (set) pour une donnée membre du type pointeur. Pour le mécanisme "
+"d'obtention, elle créera deux fonctions membres, une qualifiée "
+"<literal>const</literal> et une non-<literal>const</literal>."
+
+#: C/gtkmm-tutorial-in.xml:8743(function)
+msgid "_MEMBER_GET_PTR(C++ name, C name, C++ type, C type)"
+msgstr "_MEMBER_GET_PTR(C++ name, C name, C++ type, C type)"
+
+#: C/gtkmm-tutorial-in.xml:8744(function)
+msgid "_MEMBER_SET_PTR(C++ name, C name, C++ type, C type)"
+msgstr "_MEMBER_SET_PTR(C++ name, C name, C++ type, C type)"
+
+#: C/gtkmm-tutorial-in.xml:8746(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_MEMBER_GET_PTR(vbox, vbox, VBox*, GtkWidget*)\n"
+msgstr ""
+"\n"
+"_MEMBER_GET_PTR(vbox, vbox, VBox*, GtkWidget*)\n"
+
+#: C/gtkmm-tutorial-in.xml:8745(para)
+msgid "For example, in <filename>dialog.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, dans <filename>dialog.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8752(title)
+msgid "_MEMBER_GET_GOBJECT / _MEMBER_SET_GOBJECT"
+msgstr "_MEMBER_GET_GOBJECT / _MEMBER_SET_GOBJECT"
+
+#: C/gtkmm-tutorial-in.xml:8753(para)
+msgid ""
+"Use this macro to provide getters and setters for a data member that is a "
+"<classname>GObject</classname> type that must be referenced before being "
+"returned."
+msgstr ""
+"Utilisez cette macro pour fournir des obtenteurs (get) et des mutateurs "
+"(set) pour une donnée membre du type <classname>GObject</classname> "
+"nécessitant un référencement avant renvoi."
+
+#: C/gtkmm-tutorial-in.xml:8758(function)
+msgid "_MEMBER_GET_GOBJECT(C++ name, C name, C++ type, C type)"
+msgstr "_MEMBER_GET_GOBJECT(C++ name, C name, C++ type, C type)"
+
+#: C/gtkmm-tutorial-in.xml:8759(function)
+msgid "_MEMBER_SET_GOBJECT(C++ name, C name, C++ type, C type)"
+msgstr "_MEMBER_SET_GOBJECT(C++ name, C name, C++ type, C type)"
+
+#: C/gtkmm-tutorial-in.xml:8761(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"_MEMBER_GET_GOBJECT(offscreen_pixmap, offscreen_pixmap, Gdk::Pixmap, GdkPixmap*)\n"
+msgstr ""
+"\n"
+"_MEMBER_GET_GOBJECT(offscreen_pixmap, offscreen_pixmap, Gdk::Pixmap, GdkPixmap*)\n"
+
+#: C/gtkmm-tutorial-in.xml:8760(para)
+msgid "For example, in <filename>progress.hg</filename>: <placeholder-1/>"
+msgstr "Par exemple, dans <filename>progress.hg</filename>Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8768(title)
+msgid "Basic Types"
+msgstr "Types de base"
+
+#: C/gtkmm-tutorial-in.xml:8769(para)
+msgid ""
+"Some of the basic types that are used in C APIs have better alternatives in C"
+"++. For example, there's no need for a <type>gboolean</type> type since C++ "
+"has <type>bool</type>. The following list shows some commonly-used types in "
+"C APIs and what you might convert them to in a C++ wrapper library."
+msgstr ""
+"Certains types de base utilisés dans les API C possèdent une meilleure "
+"typologie en C++. Par exemple, il n'est pas nécessaire d'avoir un type "
+"<literal>gboolean</literal> puisque le C++ dispose du type <literal>bool</"
+"literal>. La liste suivante montre quelques types couramment utilisés dans "
+"les API C, types que vous pouvez convertir dans la bibliothèque d'habillage C"
+"++."
+
+#: C/gtkmm-tutorial-in.xml:8774(title)
+msgid "Basic Type equivalents"
+msgstr "Ã?quivalents des types de base"
+
+#: C/gtkmm-tutorial-in.xml:8776(segtitle)
+msgid "C type"
+msgstr "Types C"
+
+#: C/gtkmm-tutorial-in.xml:8777(segtitle)
+msgid "C++ type"
+msgstr "Types C++"
+
+#: C/gtkmm-tutorial-in.xml:8778(type)
+msgid "gboolean"
+msgstr "gboolean"
+
+#: C/gtkmm-tutorial-in.xml:8778(type)
+msgid "bool"
+msgstr "bool"
+
+#: C/gtkmm-tutorial-in.xml:8779(type)
+msgid "gint"
+msgstr "gint"
+
+#: C/gtkmm-tutorial-in.xml:8779(type)
+msgid "int"
+msgstr "int"
+
+#: C/gtkmm-tutorial-in.xml:8780(type)
+msgid "guint"
+msgstr "guint"
+
+#: C/gtkmm-tutorial-in.xml:8781(type)
+msgid "gdouble"
+msgstr "gdouble"
+
+#: C/gtkmm-tutorial-in.xml:8781(type)
+msgid "double"
+msgstr "double"
+
+#: C/gtkmm-tutorial-in.xml:8782(type)
+msgid "gunichar"
+msgstr "gunichar"
+
+#: C/gtkmm-tutorial-in.xml:8783(type)
+msgid "gchar*"
+msgstr "gchar*"
+
+#: C/gtkmm-tutorial-in.xml:8783(classname)
+msgid "std::string"
+msgstr "std::string"
+
+#: C/gtkmm-tutorial-in.xml:8783(seg)
+msgid "<placeholder-1/> (or <placeholder-2/> for filenames)"
+msgstr "<placeholder-1/> (ou <placeholder-2/> pour les noms de fichiers)"
+
+#: C/gtkmm-tutorial-in.xml:8790(title)
+msgid "Hand-coded source files"
+msgstr "Fichiers sources codés à la main"
+
+#: C/gtkmm-tutorial-in.xml:8791(para)
+msgid ""
+"You might want to include additional source files that will not be generated "
+"by <command>gmmproc</command> from <filename>.hg</filename> and <filename>."
+"ccg</filename> files. You can simply place these in your "
+"<filename>libsomething/libsomethingmm</filename> directory and mention them "
+"in the <filename>Makefile.am</filename> in the <varname>files_extra_h</"
+"varname> and <varname>files_extra_cc</varname> variables."
+msgstr ""
+"Vous voudrez peut-être inclure des fichiers sources additionnels qui "
+"n'auraient pas été générés par <command>gmmproc</command> à partir des "
+"fichiers <filename>.hg</filename> et <filename>.ccg</filename>. Placez-les "
+"simplement dans le répertoire <filename>libsomething/libsomethingmm</"
+"filename> et mentionnez-les dans le fichier <filename>Makefile.am</filename> "
+"dans les variables <varname>files_extra_h</varname> et "
+"<varname>files_extra_cc</varname>."
+
+#: C/gtkmm-tutorial-in.xml:8801(title)
+msgid "Initialization"
+msgstr "Initialisation"
+
+#: C/gtkmm-tutorial-in.xml:8810(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"void init()\n"
+"{\n"
+" Gtk::Main::init_gtkmm_internals(); //Sets up the g type system and the Glib::wrap() table.\n"
+" wrap_init(); //Tells the Glib::wrap() table about the libsomethingmm classes.\n"
+"}\n"
+msgstr ""
+"\n"
+"void init()\n"
+"{\n"
+" // Définir le système des types g et la table Glib::wrap().\n"
+" Gtk::Main::init_gtkmm_internals();\n"
+" // Indiquer à la table Glib::wrap() les classes libsomethingmm.\n"
+" wrap_init();\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:8802(para)
+msgid ""
+"Your library must be initialized before it can be used, to register the new "
+"types that it makes available. Also, the C library that you are wrapping "
+"might have its own initialization function that you should call. You can do "
+"this in an <function>init()</function> function that you can place in hand-"
+"coded <filename>init.h</filename> and <filename>init.cc</filename> files. "
+"This function should initialize your dependencies (such as the C function, "
+"and <application>gtkmm</application>) and call your generated "
+"<function>wrap_init()</function> function. For instance: <placeholder-1/>"
+msgstr ""
+"Avant de pouvoir vous servir de votre bibliothèque, il faut l'initialiser "
+"pour enregistrer les nouveaux types à disposition. La bibliothèque C que "
+"vous habillez doit aussi avoir sa propre fonction d'initialisation ; vous "
+"devrez l'appeler. Vous pouvez effectuer cette opération dans une fonction "
+"<function>init()</function> placée dans des fichiers <filename>init.h</"
+"filename> et <filename>init.cc</filename> codés à la main. Cette fonction "
+"doit initialiser vos dépendances (comme la fonction C et <application>gtkmm</"
+"application>) et appeler la fonction <function>wrap_init()</function> "
+"générée. Par exemple : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8818(para)
+msgid ""
+"The implementation of the <function>wrap_init()</function> method in "
+"<filename>wrap_init.cc</filename> is generated by "
+"<filename>generate_wrap_init.pl</filename>, but the declaration in "
+"<filename>wrap_init.h</filename> is hand-coded, so you will need to adjust "
+"<filename>wrap_init.h</filename> so that the <function>init()</function> "
+"function appears in the correct C++ namespace."
+msgstr ""
+"L'implémentation de la fonction membre <function>wrap_init()</function> dans "
+"<filename>wrap_init.cc</filename> sera générée avec "
+"<filename>generate_wrap_init.pl</filename>, mais sa déclaration dans "
+"<filename>wrap_init.h</filename> doit être codée à la main ; vous avez "
+"besoin d'ajuster <filename>wrap_init.h</filename> de sorte que la fonction "
+"<function>init()</function> apparaisse dans un espace de noms C++ correct."
+
+#: C/gtkmm-tutorial-in.xml:8827(title)
+msgid "Problems in the C API."
+msgstr "Problèmes dans l'API C"
+
+#: C/gtkmm-tutorial-in.xml:8828(para)
+msgid ""
+"You are likely to encounter some problems in the library that you are "
+"wrapping, particularly if it is a new project. Here are some common "
+"problems, with solutions."
+msgstr ""
+"Vous allez vraisemblablement rencontrer des problèmes dans la bibliothèque "
+"en cours d'habillage, en particulier s'il s'agit d'un nouveau projet. Voici "
+"quelques problèmes courants et leurs solutions."
+
+#: C/gtkmm-tutorial-in.xml:8830(title)
+msgid "Unable to predeclare structs"
+msgstr "Impossibilité de pré-déclarer des structures"
+
+#: C/gtkmm-tutorial-in.xml:8832(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"typedef struct _ExampleWidget ExampleWidget;\n"
+"\n"
+"struct _ExampleWidget\n"
+"{\n"
+" ...\n"
+"};\n"
+msgstr ""
+"\n"
+"typedef struct _ExampleWidget ExampleWidget;\n"
+"\n"
+"struct _ExampleWidget\n"
+"{\n"
+" ...\n"
+"};\n"
+
+#: C/gtkmm-tutorial-in.xml:8831(para)
+msgid ""
+"By convention, structs are declared in glib/GTK+-style headers like so: "
+"<placeholder-1/>"
+msgstr ""
+"Par convention, les structures sont déclarées comme suit dans les en-têtes "
+"de style glib/GTK+Â : <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8841(para)
+msgid ""
+"The extra typedef allows the struct to be used in a header without including "
+"its full defintion, simply by predeclaring it, by repeating that typedef. "
+"This means that you don't have to include the C library's header in your C++ "
+"header, thus keeping it out of your public API. <command>gmmproc</command> "
+"assumes that this technique was used, so you will see compiler errors if "
+"that is not the case."
+msgstr ""
+"Le typedef préliminaire permet l'utilisation de cette structure dans un en-"
+"tête sans inclure sa définition complète, simplement en la pré-déclarant, "
+"par répétition de la définition de type. Cela signifie que vous n'avez pas à "
+"inclure les en-têtes de la bibliothèque C dans la bibliothèque C++ ; vous la "
+"gardez ainsi hors de votre API publique. <command>gmmproc</command> suppose "
+"qu'on utilise cette technique ; vous verrez donc des messages d'erreurs si "
+"ce n'est pas le cas."
+
+#: C/gtkmm-tutorial-in.xml:8844(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"example-widget.h:56: error: using typedef-name 'ExampleWidget' after 'struct'\n"
+"../../libexample/libexamplemm/example-widget.h:34: error: 'ExampleWidget' has a previous declaration here\n"
+"make[4]: *** [example-widget.lo] Error 1\n"
+msgstr ""
+"\n"
+"example-widget.h:56: error: using typedef-name 'ExampleWidget' after 'struct'\n"
+"../../libexample/libexamplemm/example-widget.h:34: error: \n"
+" 'ExampleWidget' has a previous declaration here\n"
+"make[4]: *** [example-widget.lo] Error 1\n"
+
+#: C/gtkmm-tutorial-in.xml:8850(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"example-widget.h:60: error: '_ExampleWidget ExampleWidget' redeclared as different kind of symbol\n"
+"../../libexample/libexamplemm/example-widget.h:34: error: previous declaration of 'typedef struct _ExampleWidget ExampleWidget'\n"
+msgstr ""
+"\n"
+"example-widget.h:60: error: '_ExampleWidget ExampleWidget' \n"
+" redeclared as different kind of symbol\n"
+"../../libexample/libexamplemm/example-widget.h:34: error: \n"
+"previous declaration of 'typedef struct _ExampleWidget ExampleWidget'\n"
+
+#: C/gtkmm-tutorial-in.xml:8842(para)
+msgid ""
+"This compiler error might look like this: <placeholder-1/> or this: "
+"<placeholder-2/>"
+msgstr ""
+"L'erreur de compilation ressemble à quelque chose comme : <placeholder-1/> "
+"ou bien encore : <placeholder-2/>"
+
+#: C/gtkmm-tutorial-in.xml:8855(para)
+msgid ""
+"This is easy to correct in the C library, so do send a patch to the relevant "
+"maintainer."
+msgstr ""
+"C'est facile à corriger dans la bibliothèque C ; n'envoyez pas de correctif "
+"au mainteneur concerné."
+
+#: C/gtkmm-tutorial-in.xml:8859(title)
+msgid "Lack of properties"
+msgstr "Perte de propriétés"
+
+#: C/gtkmm-tutorial-in.xml:8866(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"GtkWidget* example_widget_new(int something, const char* thing)\n"
+"{\n"
+" return g_object_new (EXAMPLE_TYPE_WIDGET, \"something\", something, \"thing\", thing, NULL);\n"
+"}\n"
+msgstr ""
+"\n"
+"GtkWidget* example_widget_new(int something, const char* thing)\n"
+"{\n"
+" return g_object_new (EXAMPLE_TYPE_WIDGET,\n"
+" \"something\", something, \n"
+" \"thing\", thing, NULL);\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:8860(para)
+msgid ""
+"By convention, glib/GTK+-style objects have <function>*_new()</function> "
+"functions, such as <function>example_widget_new()</function> that do nothing "
+"more than call <function>g_object_new()</function> and return the result. "
+"The input parameters are supplied to <function>g_object_new()</function> "
+"along with the names of the properties for which they are values. For "
+"instance, <placeholder-1/>"
+msgstr ""
+"Par convention, les objets de style glib/GTK+ possèdent des fonctions "
+"<function>*_new()</function>, comme par exemple <function>example_widget_new"
+"()</function>, qui ne font rien de plus qu'appeler <function>g_object_new()</"
+"function> et renvoyer le résultat. Les paramètres en entrée sont fournis à "
+"la fonction <function>g_object_new()</function> en même temps que les noms "
+"des propriétés dont elles sont les valeurs. Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8873(para)
+msgid ""
+"This allows language bindings to implement their own equivalents (such as C+"
+"+ constructors), without using the <function>*_new()</function> function. "
+"This is often necessary so that they can actually instantiate a derived "
+"GType, to add their own hooks for signal handlers and vfuncs."
+msgstr ""
+"Cette façon de procéder permet des liaisons de langage pour implémenter "
+"leurs propres équivalents (comme les constructeurs C++) sans utiliser les "
+"fonctions <function>*_new()</function>. Ceci est souvent nécessaire ; elles "
+"peuvent donc instancier en réalité un GType dérivé pour ajouter leurs "
+"propres accroches pour les gestionnaires de signal et les fonctions "
+"virtuelles."
+
+#: C/gtkmm-tutorial-in.xml:8877(para)
+msgid ""
+"At the least, the <function>_new()</function> function should not use any "
+"private API (functions that are only in a .c file). Even when there are no "
+"functions, we can sometimes reimplement 2 or 3 lines of code in a "
+"<function>_new()</function> function as long as those lines of code use API "
+"that is available to us."
+msgstr ""
+"Pour le moins, la fonction <function>_new()</function> ne doit pas utiliser "
+"une quelconque API privée (fonctions uniquement dans un fichier .c). Même "
+"s'il n'y a pas de fonctions, nous pouvons ré-implémenter 2 ou 3 lignes de "
+"code dans une fonction <function>_new()</function> pour autant que ces "
+"lignes de code utilisent une API disponible pour nous."
+
+#: C/gtkmm-tutorial-in.xml:8885(programlisting)
+#, no-wrap
+msgid ""
+"\n"
+"GtkWidget* example_widget_new(int something, const char* thing)\n"
+"{\n"
+" ExampleWidget* widget;\n"
+" widget = g_object_new (EXAMPLE_TYPE_WIDGET, NULL);\n"
+" example_widget_construct(widget, \"something\", something, \"thing\", thing);\n"
+"}\n"
+"\n"
+"void example_widget_construct(ExampleWidget* widget, int something, const char* thing)\n"
+"{\n"
+" //Do stuff that uses private API:\n"
+" widget->priv->thing = thing;\n"
+" do_something(something);\n"
+"}\n"
+msgstr ""
+"\n"
+"GtkWidget* example_widget_new(int something, const char* thing)\n"
+"{\n"
+" ExampleWidget* widget;\n"
+" widget = g_object_new (EXAMPLE_TYPE_WIDGET, NULL);\n"
+" example_widget_construct(widget, \n"
+" \"something\", something,\n"
+" \"thing\", thing);\n"
+"}\n"
+"\n"
+"void example_widget_construct(ExampleWidget* widget,\n"
+" int something,\n"
+" const char* thing)\n"
+"{\n"
+" //faire quelque chose qui utilise l'API privée:\n"
+" widget->priv->thing = thing;\n"
+" do_something(something);\n"
+"}\n"
+
+#: C/gtkmm-tutorial-in.xml:8882(para)
+msgid ""
+"Another workaround is to add a <function>*_construct()</function> function "
+"that the C++ constructor can call after instantiating its own type. For "
+"instance, <placeholder-1/>"
+msgstr ""
+"Une autre manière de contourner ce problème consiste à ajouter une fonction "
+"<function>*_construct()</function> que le constructeur C++ peut appeler "
+"après avoir instancié son propre type. Par exemple, <placeholder-1/>"
+
+#: C/gtkmm-tutorial-in.xml:8901(para)
+msgid ""
+"Adding properties, and ensuring that they interact properly with each other, "
+"is relatively difficult to correct in the C library, but it is possible, so "
+"do file a bug and try to send a patch to the relevant maintainer."
+msgstr ""
+"Ajouter des propriétés en s'assurant qu'elles interagissent proprement entre "
+"elles est relativement difficile à corriger dans une bibliothèque C, mais "
+"c'est possible ; faites remonter un rapport d'anomalie avec si possible un "
+"correctif au mainteneur concerné."
+
+#: C/gtkmm-tutorial-in.xml:8909(title)
+msgid "Documentation"
+msgstr "Documentation"
+
+#: C/gtkmm-tutorial-in.xml:8910(para)
+msgid ""
+"In general, gtkmm-style projects use Doxygen, which reads specially "
+"formatted C++ comments and generates HTML documentation. You may write these "
+"doxygen comments directly in the header files."
+msgstr ""
+"En règle générale, les projets du style gtkmm utilisent Doxygen, qui lit les "
+"commentaires dans un format particulier et génère une documentation HTML. "
+"Vous pouvez écrire ces commentaires doxygen directement dans les fichiers "
+"d'en-tête."
+
+#: C/gtkmm-tutorial-in.xml:8913(title)
+msgid "Reusing C documentation"
+msgstr "Réutilisation de la documentation C"
+
+#: C/gtkmm-tutorial-in.xml:8914(para)
+msgid ""
+"You might wish to reuse documentation that exists for the C library that you "
+"are wrapping. GTK-style C libraries typically use gtk-doc and therefore have "
+"source code comments formatted for gtk-doc and some extra documentation in ."
+"tmpl files. The docextract_to_xml.py script, from pygobject's codegen "
+"directory, can read these files and generate an .xml file that "
+"<command>gmmproc</command> can use to generate doxygen comments. "
+"<command>gmmproc</command> will even try to transform the documentation to "
+"make it more appropriate for a C++ API."
+msgstr ""
+"Vous pouvez souhaiter réutiliser la documentation existante de la "
+"bibliothèque C que vous êtes en train d'habiller. Les bibliothèques du style "
+"C GTK utilisent généralement gtk-doc ; les commentaires de leur code source "
+"est donc formaté pour gtk-doc avec de la documentation supplémentaire dans "
+"des fichiers .tmpl. Le script docextract_to_xml.py, situé dans le répertoire "
+"codegen de pygobject, est capable de lire ces fichiers et de générer un "
+"fichier .xml que <command>gmmproc</command> peut utiliser pour générer à son "
+"tour des commentaires doxygen. <command>gmmproc</command> essaye même de "
+"transformer la documentation pour mieux l'adapter à une API C++."
+
+#: C/gtkmm-tutorial-in.xml:8917(programlisting)
+#, no-wrap
+msgid "./docextract_to_xml.py -s /gnome/head/cvs/gtk+/gtk/ -s /gnome/head/cvs/gtk+/docs/reference/gtk/tmpl/ > gtk_docs.xml\n"
+msgstr ""
+"./docextract_to_xml.py -s /gnome/head/cvs/gtk+/gtk/ \\\n"
+"-s /gnome/head/cvs/gtk+/docs/reference/gtk/tmpl/ > gtk_docs.xml\n"
+
+#: C/gtkmm-tutorial-in.xml:8920(para)
+msgid ""
+"Because this automatic transformation is not always appropriate, you might "
+"want to provide hand-written text for a particular method. You can do this "
+"by copying the XML node for the function from your <filename>something_docs."
+"xml</filename> file to the <filename>something_docs_override.xml</filename> "
+"file and changing the contents."
+msgstr ""
+"Cette transformation automatique n'est pas toujours appropriée ; vous serez "
+"amené à rédiger un texte pour des fonctions membres particulières. Vous "
+"pouvez faire cela en copiant le nÅ?ud XML concernant la fonction du fichier "
+"<filename>something_docs.xml</filename> vers le fichier "
+"<filename>something_docs_override.xml</filename> et en modifiant son contenu."
+
+#: C/gtkmm-tutorial-in.xml:8929(title)
+msgid "Documentation build structure"
+msgstr "Structure de construction de la documentation"
+
+#: C/gtkmm-tutorial-in.xml:8930(para)
+msgid ""
+"If you copied the skeleton source tree in mm-common and substituted the "
+"placeholder text, then you will already have suitable <filename>Makefile.am</"
+"filename> and <filename>Doxyfile.in</filename> files. With the mm-common "
+"build setup, the list of Doxygen input files is not defined in the Doxygen "
+"configuration file, but passed along from <command>make</command> to the "
+"standard input of <command>doxygen</command>. The input file list is defined "
+"by the <varname>doc_input</varname> variable in the <filename>Makefile.am</"
+"filename> file."
+msgstr ""
+"Si vous avez copié l'arborescence des squelettes sources de mm-common et "
+"substitué le texte à remplacer, vous disposez déjà de fichiers "
+"<filename>Makefile.am</filename> et <filename>Doxyfile.in</filename> "
+"convenables. Avec le paramétrage de construction de mm-common, la liste des "
+"fichiers d'entrée Doxygen n'est pas définie dans le fichier de configuration "
+"Doxygen, mais passée de <command>make</command> à l'entrée standard de "
+"<command>doxygen</command>. La liste des fichiers en entrée est définie par "
+"la variable <varname>doc_input</varname> du fichier <filename>Makefile.am</"
+"filename>."
+
+#. Put one translator per line, in the form of NAME <EMAIL>, YEAR1, YEAR2
+#: C/gtkmm-tutorial-in.xml:0(None)
+msgid "translator-credits"
+msgstr "GéOde <Geodebay AT gmail DOT com>, 2010"
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]