Académique Documents
Professionnel Documents
Culture Documents
iv
Version 0.30
du 04/01/2004
par JeanMichel DOUDOUX
Prambule
A propos de ce document
Ce document fait suite mon premier tutorial "Dveloppons en Java". C'est un didacticiel qui se propose de fournir des informations pratiques sur l'utilisation d'Eclipse. Je suis ouvert toutes ractions ou suggestions concernant ce document notamment le signalement des erreurs, les points claircir, les sujets ajouter, etc. ... N'hsitez pas me contacter : jeanmichel.doudoux@wanadoo.fr Ce document est disponible aux formats HTML et PDF l'adresse suivante : http://perso.wanadoo.fr/jm.doudoux/java/ Ce manuel est fourni en l'tat, sans aucune garantie. L'auteur ne peut tre tenu pour responsable des ventuels dommages causs par l'utilisation des informations fournies dans ce document. La version pdf de ce document est ralise grce l'outil HTMLDOC 1.8.23 de la socit Easy Software Products. Cet excellent outil freeware peut tre tlcharg l'adresse : http://www.easysw.com
Note de licence
Copyright (C) 20032004 DOUDOUX Jean Michel Vous pouvez copier, redistribuer et/ou modifier ce document selon les termes de la Licence de Documentation Libre GNU, Version 1.1 ou toute autre version ultrieure publie par la Free Software Foundation; les Sections Invariantes tant constitues des chapitres : Dveloppons en Java avec Eclipse Introduction Installation d'Eclipse Le workspace Le workbench Les fonctions pratiques du workbench d'Eclipse Le Java development tooling (JDT) d'Eclipse Deboguer du code java Le refactoring L'aide dans Eclipse Ant et Eclipse JUnit et Eclipse CVS et Eclipse Les autres perspectives d'Eclipse Les plugins La gestion de la plateforme Le dveloppement sans Java Le dveloppement d'interfaces graphiques Annexes aucun Texte de Premire de Couverture, et aucun Texte de Quatrime de Couverture. Une copie de la licence est incluse dans la section GNU FreeDocumentation Licence. La version la plus rcente de cette licence est disponible l'adresse : GNU Free Documentation Licence. Dveloppons en Java avec Eclipse 2
Marques dposes
Sun, Sun Microsystems, le logo Sun et Java sont des marques dposes de Sun Microsystems Inc. Les autres marques et les nom de produits cits dans ce document sont la proprit de leur diteur respectif.
0.10 bta 08/04/2003 1ere version diffuse sur le web. Ajout des chapitres Junit, Ant, Aide, Dboguer du code Java Ajout des sections : importation, exportation, gnration javadoc, informations sur les plugins, le plugin Jalopy 0.20 13/07/2003 Complments ajouts au chapitre JDT Application d'une feuille de styles CSS pour la version HTML Corrections et ajouts divers Ajout dans le chapitre "JDT", "deboguer du code Java" et "La gestion de la plateforme" Ajout du chapitre "le refactoring" , "le dveloppement sans java" et "Le 04/01/2004 dveloppement d'interfaces graphiques" Rduction de la taille des images : rduction de la taille et passage en niveau de gris pour la version PDF Corrections et ajouts divers
0.30
1. Introduction
Eclipse est un environnement de dveloppement intgr (Integrated Development Environment) dont le but est de fournir une plateforme modulaire pour permettre de raliser des dveloppements informatiques. I.B.M. est l'origine du dveloppement d'Eclipse qui est d'ailleurs toujours le coeur de son outil Websphere Studio Workbench (WSW), lui mme la base de la famille des derniers outils de dveloppement en Java d'I.B.M. Tout le code d'Eclipse a t donn la communaut par I.B.M afin de poursuivre son dveloppement. Eclipse utilise normment le concept de modules nomms "plugins" dans son architecture. D'ailleurs, hormis le noyau de la plateforme nomm "Runtime", tout le reste de la plateforme est dvelopp sous la forme de plugins. Ce concept permet de fournir un mcanisme pour l'extension de la plateforme et ainsi fournir la possiblit des tiers de dvelopper des fonctionnalits qui ne sont pas fournies en standard par Eclipse. Les principaux modules fournis en standard avec Eclipse concernent Java mais des modules sont en cours de dveloppement pour d'autres langages notamment C++, Cobol, mais aussi pour d'autres aspects du dveloppement (base de donnes, conception avec UML, ). Ils sont tous dvelopps en Java soit par le projet Eclipse soit par des tiers commerciaux ou en open source. Les modules agissent sur des fichiers qui sont inclus dans le workspace. Le workspace regroupe les projets qui contiennent une arborescence de fichiers. Bien que dvelopp en Java, les performances l'excution d'Eclipse sont trs bonnes car il n'utilise pas Swing pour l'interface hommemachine mais un toolkit particulier nomm SWT associ la bibliothque JFace. SWT (Standard Widget Toolkit) est dvelopp en Java par IBM en utilisant au maximum les composants natifs fournis par le systme d'exploitation sous jacent. JFace utilise SWT et propose une API pour faciliter le dveloppement d'interfaces graphiques. Eclipse ne peut donc fonctionner que sur les plateformes pour lesquelles SWT a t port. Ainsi, Eclipse 1.0 fonctionne uniquement sur les plateformes Windows 98/NT/2000/XP et Linux. SWT et JFace sont utiliss par Eclipse pour dvelopper le Workbench qui organise la structure de la plateforme et les intractions entre les outils et l'utilisateur. Cette structure repose sur trois concepts : la perspective, la vue et l'diteur. La perspective regoupe des vues et des diteurs pour offrir une vision particulire des dveloppements. En standard, Eclipse propose huit perspectives. Les vues permettent de visualiser et de slectionner des lments. Les diteurs permettent de visualiser et de modifier le contenu d'un lements du workspace.
Il existe quatre grandes catgories de versions. Chacune de ces catgories possde un nombre plus ou moins important de versions nommes "build" : "Nightly Builds" : version en cours de dveloppement cre de faon journalire contenant les modifications de la journe. "Integration Builds" : assemblage des sousprojets pour la ralisation de tests "Stable Builds" : version teste "Releases" : version diffuse et "fiable" Il existe plusieurs versions de type "Realease" d'Eclipse : Date Novembre 2003 Juillet 2003 Avril 2003 Novembre 2002 Septembre 2002 Juillet 2002 Novembre 2001 Version 2.1.2. 2.1.1. 2.1. 2.0.2 2.0.1. 2.0 1.0
La version 3.0 est en cours de dveloppement. Le projet Eclipse est divis en quatre grands projets : le projet "Eclipse" : ce projet dveloppe l'architecture et la structure de la plateforme Eclipse. le projet "Eclipse Tools" : ce projet dveloppe ou intgre des outils la plateforme pour permettre des tiers d'enrichir la plateforme. Il possde plusieurs sous projets tel que CDT (plug in pour le developpeemnt en C/C++), GEF (Graphical Editing Framework ), EMF (Eclipse Modeling Framework), Cobol (plug in pour le developpement en Cobol), ... le projet "Eclipse Technology" : ce projet, divis en trois catgories, propose d'effectuer des recherches sur des volutions de la plateforme et des technologies qu'elle met en oeuvre. le projet "Eclipse Web Tools Platform" : ce projet pour but d'enrichir la plateforme enfin de proposer un framework et des services pour la cration d'outils de dveloppement d'applications web.
2. Installation
Eclipse 1.0 peut tre install sur les plateformes Windows ( 98ME et SE / NT / 2000 / XP) et Linux. Eclipse 2.0 peut tre install sur les plateformes Windows ( 98ME et SE / NT / 2000 / XP), Linux, Solaris 8, QNX, AIX, HPUX. Eclipse 2.1 peut tre install sur toutes les plateformes sites prcdemment mais aussi sous MAC OS X. Quel que soit la plateforme, il faut obligatoirement qu'un JDK 1.3 minimum y soit install. La version 1.4 est fortement recommande pour amliorer les performances et pouvoir utiliser le remplacement de code lors du debogage (technologie JPDA). Lors de son premier lancement, Eclipse cr par dfaut un rpertoire nomm Workspace qui va contenir les projets.
Un clic sur "Oui" ouvre une bote de dialogue qui permet de slectionner la mise jour installer.
Il suffit de cocher la mise jour souhaite et de cliquer sur "Fin". Les mises jour sont tlcharges et installes. L'application doit tre redmarre.
Pour la version 2.1.1., il faut tlcharger le fichier correspondant au systme d'exploitation utilis sur la page : http://download.eclipse.org/downloads/drops/L2.1.x%20Translations200307021300/index.php La procdure d'installation est identique celle de la version 2.0. Pour la version 2.1.1., il existe aussi un patch pour les traductions tlchargeable l'url :
http://download2.eclipse.org/downloads/drops/L2.1.x%20Translations200307021300/eclipse2.1.1.1SDKLanguag Ce patch doit tre install aprs avoir install les traductions initiales de la version 2.1.1 en dzippant le contenu du fichier dans le rpertoire qui contient le rpertoire Eclipse. Dveloppons en Java avec Eclipse 8
Il faut ajouter le rpertoire bin du JDK la variable systme PATH pour permettre au systme de trouver les excutables ncessaires. PATH=$PATH:/opt/IBMJava213/bin Si les excutables ne sont pas touvs, une bote de dialogue affiche le message suivant :
Pour excuter Eclipse, il suffit de lancer eclipse dans un shell. Exemple : [jumbo@charlemagne eclipse]$ eclipse data workspace
Il existe deux versions pour Linux : une utilisant Motif et une autre utilisation GTK 2. Pour la version Motif, il faut tlcharger le fichier eclipseSDK2.1.1linuxmotif.zip. Il faut dzipper le fichier dans un rpertoire, par exemple /opt avec l'utilisateur root. Exemple :
[root@localhost opt]# unzip eclipseSDK2.1linuxmotif.zip Archive: eclipseSDK2.1linuxmotif.zip creating: eclipse/ inflating: eclipse/libXm.so.2.1 linking: eclipse/libXm.so > libXm.so.2.1 linking: eclipse/libXm.so.2 > libXm.so.2.1 creating: eclipse/plugins/ creating: eclipse/plugins/org.eclipse.core.boot_2.1.0/ inflating: eclipse/plugins/org.eclipse.core.boot_2.1.0/boot.jar inflating: eclipse/plugins/org.eclipse.core.boot_2.1.0/splash.bmp inflating: eclipse/plugins/org.eclipse.core.boot_2.1.0/boot.xml inflating: eclipse/plugins/org.eclipse.core.boot_2.1.0/plugin.properties inflating: eclipse/plugins/org.eclipse.core.boot_2.1.0/plugin.xml inflating: eclipse/plugins/org.eclipse.core.boot_2.1.0/.options inflating: eclipse/plugins/org.eclipse.core.boot_2.1.0/about.html ...
10
Pour utiliser excuter Eclipse avec un utilisateur sans privilge particulier, il faut dfinir la variable LD_LIBRAY_PATH et excuter Eclipse Exemple :
[java@localhost [java@localhost total 2004 drwxrwxrx 5 drwxrxrx 11 rwrwr 1 rwrwr 1 rwxrxrx 1 drwxrwxrx 10 rwrwr 1 rwrwr 1 lrwxrwxrwx 1 * lrwxrwxrwx 1 .1* rwxrxrx 1 rwrwr 1 drwxrwxrx 64 drwxrwxrx 2 rwrwr 1 [java@localhost [java@localhost java]$ cd /opt/eclipse eclipse]$ ll root root root root root root root root root root root root root root root root root root root root 4096 4096 59 15048 41003 4096 10489 619 12 Mar Jul Mar Mar Mar Mar Mar Mar Jul 27 10 27 27 27 27 27 27 10 22:11 00:12 22:11 22:11 22:11 22:11 22:11 22:11 00:11 ./ ../ .eclipseproduct cplv10.html eclipse* features/ icon.xpm install.ini libXm.so > libXm.so.2.1
root root 1915756 Mar 27 22:11 libXm.so.2.1* root root 4743 Mar 27 22:11 notice.html root root 4096 Mar 27 22:11 plugins/ root root 4096 Mar 27 22:11 readme/ root root 16549 Mar 27 22:11 startup.jar eclipse]$ LD_LIBRAY_PATH=/opt/eclipse:$LD_LIBRARY_PATH eclipse]$ /opt/eclipse/eclipse data $HOME/workspace
Si la variable LD_LIBRAY_PATH n'est correctement valorise, le message d'erreur suivant est affich et Eclipse ne peut pas se lancer. Exemple :
[java@localhost java]$ /opt/eclipse/eclipse data $HOME/workspace /opt/eclipse/eclipse: error while loading shared libraries: libXm.so.2: cannot l oad shared object file: No such file or directory
11
3. Le Workspace
Le workspace est l'entit qui permet de conserver les projets et leur contenu. Physiquement c'est un rpertoire du systme d'exploitation qui contient une hirarchie de fichiers et de rpertoires. Il y a d'ailleurs un rpertoire pour chaque projet la racine du workspace. Il est possible de parcourir cette arborescence et d'en modifier les fichiers avec des outils externes Eclipse. Le workspace contient tous les lments dvelopps pour le projet : il est possible de crer, de dupliquer, de renommer ou de supprimer des lments. Ces oprations de gestion sont ralises dans le vue Navigateur.
Il est ainsi possible de crer rapidement un projet, un rpertoire ou un fichier. Si le fichier est d'un type particulier, un clic sur "Autre" ouvre un assistant.
12
La cration se fait grce un assistant qui demande le nom du nouveau projet. Ce nom ne doit pas contenir de blanc ou des caractres non alphabtiques.
Un clic sur "Fin" dclenche la cration du projet. Le projet apparait dans la vue Navigateur.
Si le workspace contient dj plusieurs projets, il est possible d'associer un ou plusieurs de ceux ci avec le nouveau en cours de cration. Pour raliser cette association, il suffit de cliquer sur Next pour afficher le second volet de l'assistant. Il suffit de cocher les projets concerns.
13
Il est possible de crer des projets particuliers selon le type d'applications dvelopper.
Il suffit ensuite de saisir le nom sans espace ni caractre non alphabtique et de cliquer sur "Fin". Le nouveau rpertoire apparat dans la vue Navigateur.
14
Si un diteur est associ au type du nouveau fichier, l'diteur est affich sur le nouveau fichier.
15
Si le rpertoire de destination slectionn est identique au rpertoire d'origine du fichier, une message est affich.
3.6. Importation
Attention, l'importation ne peut se faire que dans un projet existant. Il faut utiliser le menu "Fichier/Importer"
Slectionner le type de la source d'importation et cliquer sur "Suivant" Dveloppons en Java avec Eclipse 17
Slectionner le rpertoire, puis cocher chacun des lments concerns. Il est trs important de vrifier et de modifier si ncessaire le rpertoire de destination qui doit tre l'un des projets du workspace. En cliquant sur "Filtrer les types ", une bote de dialogue permet de slectionner les fichiers concerns partir de leurs extensions.
Il suffit de slectionner les extensions parmi celles proposes et saisir d'autres extensions et cliquer sur "OK". Le filtre est alors directement appliqu sur la slection. Une fois la slection termine, il suffit de cliquer sur "Fin" pour lancer l'importation. Au cas ou une ressource existerait dj dans la destination, un message demande la confirmation du remplacement.
18
3.7. Exportation
Pour exporter tout ou partie du workspace, il faut utiliser le menu "Fichier/Exporter".
L'assistant demande de slectionner le format d'exportation. Si le format choisi est "Systme de fichiers", l'assistant demande les informations ncessaires : les fichiers exporter, le rpertoire de destination
19
Attention : pour que la structure des rpertoires soient conserves dans la cible, il faut obligatoirement que les rpertoires soient slectionns. Si le format choisi est "Javadoc", l'assistant demande les informations ncessaires : les fichiers exporter, le rpertoire de destination
Les deux pages suivantes permettent de prciser des options pour l'outil javadoc. Un clic sur "Fin" permet de gnrer la documentation. Si le format choisi est "Fichier Zip", l'assistant demande les informations ncessaires : les fichiers exporter, le fichier zip gnrer.
Un clic sur "Fin" permet de crer le fichier zip contenant tous les lments slectionns. Si le format est "Fichier Jar", l'assistant demande les informations ncessaires : le ou les projets exporter, le fichier jar crer. Dveloppons en Java avec Eclipse 20
Un clic sur "Suivant" affiche une nouvelle page de l'assistant pour prciser certaines options.
Un clic sur "Suivant" affiche une nouvelle page de l'assistant pour prciser le fichier manifest.
21
22
4. Le workbench
Au lancement d'Eclipse, une seule fentre s'ouvre contenant le "workbench". Le "workbench" est compos de perspectives dont plusieurs peuvent tre ouvertes mais une seule est affiche en mme temps. A l'ouverture, c'est la perspective "Ressource" qui est affiche.
Une perspective contient des sous fentres qui peuvent contenir des vues (views) et des diteurs (editors) La partie gauche du workbench est compose d'une barre qui contient une icne pour chaque perspective ouverte et une icne pour ouvrir une nouvelle perspective. L'icne enfonce est celle de la perspective affiche. Le titre de la fentre du workbench contient le nom de la perspective courante. Eclipse possde dans le workbench une barre de menu et une barre de tches. Elles sont toutes les deux dynamiques en fonction du type de la sous fentre active de la perspective courante. Eclipse propose de nombreux assistants pour faciliter la ralisation de certaines taches : cration d'entits
23
Eclipse version 2.00 possde les perspectives suivantes : Perspective Debug Java Java Browsing Java Type Hierarchy Plugin Development Resource Install/update CVS Cration de plugin Gestion du contenu du workspace Installation et mise jour de plug in via le web Gestion du travail collaboratif avec CVS Icne Rle Dbugueur Ecriture de code Java Navigation des la hirarchie et les lments des classes
Pour ouvrir une nouvelle perspective, il y a deux manires de procder : Cliquer sur l'icne dans la barre des perspectives Utiliser l'option "Ouvrir" du menu "Perspective" (Eclipse 1.0) ou l'option "Ouvrir la perspective" du menu "Fenttre" (eclipse 2.0) Lors d'un clic sur l'icne , un menu flottant s'ouvre pour permettre la slection de la perspective ouvrir. Si elle n'appartient pas la liste, elle est accessible en cliquant sur l'option Autre .
24
Eclipse 2.0 Un clic sur l'option Autre ouvre une boite de dialogue dans laquelle il est possible de slectionner la nouvelle perspective afficher.
Eclipse 1.0
Eclipse 1.0
Eclipse 2.0
La perspective par dfaut (celle qui est affiche l'ouverture de l'application) est indique. Il est possible d'ouvrir plusieurs perspectives d'un mme type en mme temps. Cependant une seule perspective, quelque soit son type est affiche un moment donn. Toutes les perspectives ouvertes possdent une icne dans la barre des perspectives. Pour en afficher une, il suffit de cliquer sur son icne. La perspective courante est celle dont l'icne est enfonce.
25
Dans une perspective, il ne peut y avoir qu'une seule sous fentre active contenant soit un diteur soit une vue. La barre de titre de cette sous fentre est colore. Pour activer une sous fentre, il suffit de cliquer dessus. Avec Eclipse 1.0 sous Windows, les vues peuvent tre extraites du workbench pour devenir des fentres indpendantes. Pour cela, il faut cliquer sur la barre de titre de la vue, en maintenant le bouton de la souris enfonc, effectuer un glissement avec la souris vers une zone non empilable (sur un diteur, les bords de l'cran ) et de relacher le bouton de la souris (le curseur de la souris prend la forme d'une petite fentre aux endroits adquats).
Pour raliser l'opration inverse, il faut faire glisser la fentre au dessus d'une vue existante : elles seront alors empiles.
Pour fermer l'diteur contenant l'lment en cours, il suffit de cliquer sur l'icne de l'onglet. Une confirmation sera demande en cas de fermeture alors que l'lment a t modifi sans sauvegarde. Il est aussi possible d'utiliser l'option "Fermer" et "Fermer tout" du menu "Fichier" du workbench pour fermer le fichier en cours ou tous les fichiers. Dveloppons en Java avec Eclipse 26
Si l'lment dit ne possde pas d'diteur ddi dans Eclipse, il tente d'ouvrir un outil associ au type de la ressource dans le systme d'exploitation.
Les vues possdent deux menus : un menu associ la sous fentre activable en cliquant sur la petite icne en haut gauche. Les options de ce menu concerne la sous fentre elle mme.
le second menu est activable en cliquant sur l'icne en forme de triangle dont la base est en haut options de ce menu concerne le contenu de la vue notamment le tri ou le filtre.
. Les
Avec Eclipse 1.0, l'option "Show View" du menu "Perspective" permet de visualiser une vue particulire qu'il suffit de slectionner dans le sous menu.
Avec Eclipse 2.0, l'opration quivalente est effectue en slectionnant l'option "Afficher la vue" du menu "Fentre".
28
29
Eclipse fournit dans le workbench plusieurs outils trs pratiques qui permettent : d'effectuer des recherches de grer une liste de tches faire de grer une liste de signets d'lments de comparer des lments
L'onglet "Recherche d'un fichier" permet de faire une recherche de fichiers contenant un texte respectant un motif. Ce motif peut tre saisi ou slectionn dans la liste droulante partir des prcdents motifs recherchs. Dveloppons en Java avec Eclipse 30
Il est possible de saisir les caractres recherchs et d'utiliser trois caractres dont la signification est particulire : * : reprsente zro ou plusieurs caractres quelconques ? : reprsente un caractre quelconque \ : permet de dspcialiser le caractre *, ? et \ Il est possible de vouloir tenir compte de la casse en cochant la case "Respect maj/min". Il est aussi possible de restreindre la recherche certains fichiers en prcisant un motif particulier. Un clic sur bouton "Parcourir" ouvre une boite de dialogue qui permet de slectionner un ou plusieurs types prdfinis.
Une barre de progression indique l'volution de la recherche et le nombre de fois ou le motif est trouv. Un clic sur "Annuler" permet d'interrompre la recherche.
31
Le bouton permet de passer l'occurence suivante quelque soit l'lment qui la contienne. Lors du changement de l'lment qui contient l'occurence, celui ci est ouvert dans l'diteur. Il est possible de supprimer une ou plusieurs occurences dans la vue "Recherche". Le menu contextuel propose plusieurs options en fonction de la situation actuelle : "Supprimer l'occurence slectionne" : cette option permet de supprimer l'occurence courante de l'lment en cours "Supprimer les occurences en cours" : permet de supprimer toute les occurences de l'lment et l'lement de la liste "Supprimer toutes les occurences" : permet de supprimer tous les lments La vue "Recherche" affiche le rsultat de la recherche courante mais elle mmorise aussi les prcdentes recherches. Pour afficher les rsultats des prcdentes recherches, il suffit de slectioner la recherche en utilisant le bouton . Un menu affiche la liste des prcdents motifs de recherche et le nombre d'occurences trouves. La recherche courante est coche.
Il est toujours possible de ritrer la recherche en utilisant l'option "Nouvelle recherche" du menu contextuel de la vue.
Lorsqu'une tche est associe un lement, le nom de cet lment apparait dans la colonne ressource et sa localisation dans le workspace dans la colonne "Dans le dossier".
Il est possible d'accder l'lment associ la tche en double cliquant sur la tche ou en slectionnant l'option "Accder " du menu contextuel de la tche. L'lment est ouvert dans l'diteur avec le curseur positionn sur la ligne associe la tche.
33
Un clic sur "OK" cre la tche et une marque particulire apparait sur la ligne concerne dans la barre de gauche de l'diteur.
Cette marque reste associe la ligne mme si la position de la ligne dans le fichier change (par ajout ou suppression de lignes).
34
A partir de la vue "Signets", pour ouvrir un lment dans l'diteur, il y a trois possibilits : double cliquer sur le signet slectionner l'option "Accder " du menu contextuel associ au signet cliquer sur le bouton une fois le signet slectionn Il est aussi possible partir d'un signet de slectionner l'lment dans la vue "Navigateur" en utilisant l'option "Afficher dans le navigateur" du menu contextuel.
Le signet est ajout dans la liste des signets et une marque est affiche dans la barre de gauche de l'diteur sur la ligne concerne.
35
Si les deux fichiers possdent des diffrences, un diteur particulier s'ouvre. Cet diteur spcial pour les comparaisons, affiche chaque ligne des deux fichiers dans deux colonnes. Une colonne centrale permet de voir de faon graphique les diffrences grce des lignes.
Dans la barre centrale, les lignes en gris fonc sont identiques, les lignes en blanc sont des diffrences entre les deux fichiers.
La vue de comparaison de fichier contient une barre d'outils qui permet de naviguer dans les diffrences et de les reporter pour effectuer une synchronisation slective.
36
La flche vers le haut et le bas permet de naviguer dans les diffrences respectivement la suivante et la prcdente. Les quatre premiers boutons permettent respectivement : copier tout le document de gauche dans le document de droite copier tout le document de droite dans le document de gauche reporter la diffrence courante de gauche dans le document de droite reporter la diffrence courante de droite dans le document de gauche
37
Le JDT est inclus dans Eclipse pour fournir des outils de dveloppement en Java. Il inclus plusieurs plugins et apporte : les perspectives "Java" et "Navigation Java" les vues "Packages" et "Hierarchie" les diteurs "Java" et "Scrapbook" les assistants : pour crer de nouveaux projets, packages, classes, interfaces, ... Dans le workspace, il dfinit un projet de type particulier pour les projets Java. L'arborescence de ces projets contient un fichier particulier nomm .classpath qui contient la localisation des bibliothques utiles la compilation et l'excution du code.
38
Pour demander directement la cration d'un projet "Java", il suffit de cliquer sur l'cone d'outils. L'assistant demande le nom du projet.
de la barre
Ce nom de projet ne doit pas dj tre utilis dans le workspace courant sinon un message d'erreur est affich.
En cliquant sur "Fin", le projet est cr avec des paramtres par dfaut. Pour modifier certains paramtres avant la cration du projet, suffit de cliquer sur le bouton "Suivant" :
La modification de ces paramtres sera dtaille dans la section suivante. Une fois les paramtres modifies, cliquer sur "Fin".
39
Les proprits "chemin de compilation Java" sont regroupes dans quatres onglets : Onglet Source Projets Bibliothques Ordre et exportation Rle Permet de prciser le rpertoire qui va contenir les sources Permet d'utiliser d'autre projet avec le projet courant Permet d'ajouter des bibliothques au projet Permet de prciser l'ordre des ressources dans la classpath
L'onglet "Source" permet de prciser le rpertoire qui va contenir les sources : par dfaut, c'est le rpertoire du projet lui mme (l'option "utiliser le dossier projet en tant que dossier source" est slectionn). Pour stocker les ressources dans un rpertoire ddi, il faut slectionner l'option "Utiliser les dossiers sources contenus dans le projet". La liste permet de slectionner le ou les rpertoires. Le bouton "Crer un dossier" ouvre une bote de dialogue qui demande le nom du rpertoire.
40
Il suffit de saisir le nom, par exemple "sources" et cliquer sur "OK" Par dfaut, ds qu'un premier rpertoire contenant les sources est slectionn, Eclipse propose de crer un rpertoire bin qui va contenir le rsultat des diffrentes compilations.
La rponse la question est libre mais il est prfrable de rpondre "Oui". L'onglet "Projets" permet d'ajouter des projets contenus dans le workspace au classpath.
Il suffit de cocher les projets inclure dans le classpath. L'onglet "Bibliothques" permet d'ajouter des bibliothques externes au projet notamment des fichiers .jar.
Les bibliothques incluses dans le classpath du projet courant sont affiches dans la liste. Pour ajouter sur une nouvelle bibliothque contenue dans le workspace, il suffit de cliquer sur "Ajouter des fichiers jar". Pour ajouter des fichiers jar qui ne sont pas contenus dans le workspace, il suffit de cliquer sur "Ajouter des fichiers jar externes".
41
Une boite de dialogue permet de slectionner le fichier jar. En cliquant sur "Ouvrir", le fichier jar est ajout dans la liste. Le bouton "Avances" permet d'ajouter d'autres entits au classpath notamment des rpertoires qui contiennent des fichiers compils.
Le bouton "Editer" permet de modifier les caractristiques de la bibliothque (son chemin d'accs dans le cas d'un fichier jar). Le bouton "Supprimer" permet de supprimer une bibliothque du classpath. L'onglet "Ordre et exportation" permet de modifier l'ordre des bibliothques dans le classpath, de prciser la cible des lments gnrs (le rpertoire qui va les contenirs) et de dfinir les ressources qui seront utilisables par les autres projets du workspace lorsque le projet sera li avec eux.
42
Cliquer sur "Fin", pour crer le nouveau package. Le package apparait dans la vue "Packages".
43
L'assistant demande de renseigner les diffrentes caractristiques de la nouvelle classe : le projet et le package d'appartenance, le nom, les modificateurs, la classe mre, les interfaces implmentes. Enfin, il est possible de demander l'assistant de gnrer certaines mthodes. Si un projet ou un package est slectionn dans la vue package, celui ci est automatiquement repris par l'assistant. L'ajout d'une interface implmente se fait en la slectionnant dans une liste.
Pour ajouter une interface, il suffit de double cliquer dessus ou de la slectionner et d'appuyer sur le bouton "Ajouter". Une fois toutes les interfaces ajoutes, il suffit de cliquer sur le bouton "Ok". Toutes les mthodes dfinies dans la ou les interfaces slectionnes seront prsentes dans le code source de la classe gnre. Si le package saisi n'existe pas dans le projet, celui ci sera cr en mme temps que la classe. Dveloppons en Java avec Eclipse 44
Une fois toutes les donnes utiles renseignes, il suffit de cliquer sur " Fin " pour que la classe soit gnre et que l'diteur s'ouvre avec le contenu de son code source.
L'assistant demande de renseigner les diffrentes caractristiques de la nouvelle interface : le projet et le package d'appartenance, le nom, les modificateurs. Une fois toutes les donnes utiles renseignes, il suffit de cliquer sur " Fin " pour que l'interface soit gnre et que l'diteur s'ouvre avec le contenu de son code source.
45
Pour les lments contenant du code source, l'arborescence sous jacente permet de voir les diffrents membres qui composent l'lment. Un double clic sur des lments de l'arborescence, permet d'ouvrir l'diteur directement sur l'lment slectionn.
Chaque lment de l'arborescence possde une petite icne en fonction en son type : Icne Type de l'lment Projet de type Java Package Elment Java : classe ou interface Interface Java Classe public Java Classe Java pouvant tre excute (possdant une mthode main()) Classe protected Classe package friendly Classe private Champ public Champ private Champ protected Champ package friendly Mthode public Mthode private Mthode protected Mthode package friendly Le bouton Le bouton Le bouton permet de masquer les champs dfinis dans les lments java. permet de masquer les membres statiques. permet de masquer tous les membres qui ne sont pas publics.
46
Il est possible de restreindre les entits affiches dans la vue package. Il suffit de cliquer sur bouton slectionner l'option " Filtres ".
et de
Il suffit de cocher les filtres qui doivent tre appliqus. A partir de l'diteur, il est possible de slectionner dans la vue "Package", l'lment en cours d'dition en utilisant l'option "Afficher dans la vue package" du menu contextuel.
47
Le bouton
Il suffit de slectionner l'lment concern et de cliquer sur "OK". Le bouton permet d'afficher la hirarchie des classes mres et des interfaces qu'elles implmentent de l'lment courant.
Le bouton menu permet de changer la prsentation de la vue : Le bouton Le bouton Le bouton : les deux parties sont affiches horizontalement : les deux parties sont affiches verticalement : n'affiche que la partie qui prsente la hirarchie permet de masquer les champs permet de masquer les membres statiques. permet de masquer tous les membres qui ne sont pas publics.
48
De chaque ct de la zone d'dition, il y a une colonne qui peut contenir de petites icnes pour fournir des informations l'utilisateur. Par exemple, si l'on fait hriter une classe d'une classe dont le package n'est pas import, un clic sur la petite ampoule jaune permet d'obtenir des propositions de corrections.
Il suffit de slectionner une des actions proposes dans la liste pour que celle ci soit automatiquement mise en oeuvre. Un aperu des modifications impliques par l'action slectionne est affich dans une bulle d'aide.
Le bouton
de la barre d'outils permet, s'il est slectionn, d'afficher une bulle d'aide contenant des 49
Une description plus dtaille peut tre obtenue en positionnant le curseur sur l'lment et en appuyant sur la touche F2 ou en slectionnant l'option " Afficher une description de type infobulles " du menu " Editer ".
Cette fonction peut tre appele alors qu'aucune ou une partie du code complter est saisie.
La compltion de code s'adapte au contexte dans lequel elle est appele. Par exemple, elle peut tre appele pour complter une clause d'importation. Dans ce cas, elle propose une liste de packages en tenant compte du code dj saisi.
50
L'diteur peut gnrer la structure d'un commentaire javadoc dans le source. Par exemple, avant une mthode, il suffit de saisir /** puis d'appuyer sur la touche " Entre ".
L'appel de la compltion de code en appuyant sur les touches " Ctrl " + " Espace " permet aussi de faciliter la saisie des commentaires de type java.
51
Si la mthode est surcharge, alors Eclipse demande de choisir la mthode utiliser pour ainsi dterminer avec prcision les paramtres afficher dans la bulle d'aide.
Les lignes concernant le membre slectionn sont marqus par une partie grise dans la colonne de gauche de l'diteur. Les modifications apportes dans le code source (ajout, modification ou suppression de membres) sont automatiquement rpercutes dans la vue "Structure". Le bouton de la barre d'outils permet de limiter l'affichage dans l'diteur du membre slectionn dans la vue "Structure".
52
Il est possible de modifier ces couleurs par dfaut dans les prfrences (menu Fentres/Prfrence) Il faut slectionner l'lment Java/Editeur dans l'arborescence. Cet lment possde quatre onglets. L'onglet syntaxe permet de modifier les couleurs.
Il suffit de slectionner l'lment concern dans la liste droulante et de slectionner la couleur qui lui est associe en cliquant sur le bouton couleur. Une bote de dialogue permet de slectionner la nouvelle couleur utiliser.
53
Il suffit de slectionner le modle insrer pour qu'il soit immdiatement insrer dans le code. Il est possible d'ajouter, de modifier ou de supprimer un modle en utilisant les prfrences (menu Fentre/Prfrences). Il suffit de slectionner dans l'arborescence "Java/Modles"
54
55
La fonctionnalit "Organisation des importations" est trs pratique car elle permet d'insrer automatiquement les clauses imports avec les package requis par le code. Par exemple : une variable de type Socket est dclare, sans que le package java.net ne soit import
Pour ajouter automatiquement la clause d'importation, il suffit d'utiliser l'option "Source/Organiser les importations" du menu contextuel.
La clause import est insre dans le code. Si un lment est contenu dans plusieurs packages, une bote de dialogue demande la slection du type importer.
Cette fonctionnalit supprime aussi automatiquement les importations qui sont inutiles car aucune classe incluse dans ces packages n'est utilise dans le code. Certains rglages de cette fonctionnalit peuvent tre effectus dans les prfrences (menu "Fentre/Prfrences"). Il suffit de slectionner " Java/Organisation des importations " dans l'arborescence.
56
Il suffit de slectionner les mthodes ncessaires pour qu'une gnration par dfaut soit effectue dans le code.
Puis, il faut utiliser l'option " Source / Mettre en commentaires " du menu contextuel de l'diteur.
Pour supprimer les commentaires sur une portion de code, il suffit de slectionner la portion de code et d'utiliser l'option " Source / Supprimer la mise en commentaire " du menu contextuel.
58
Puis utiliser l'option " Source / Entourer d'un bloc try / catch ". L'diteur analyse le code et gnre la cause try / catch qui va capturer toutes les exceptions qui peuvent tre leves dans le bloc de code slectionn.
Chacune des instructions catch est marque avec une tache " bloc catch autognr " pour indiquer au dveloppeur d'ajouter le code ncessaire au traitement de l'exception. Si le bloc de code ne contient aucun appel de mthode susceptible de lever une exception, une bote de dialogue demande si l'instruction catch doit capturer une exception de type RuntimeException.
59
Les erreurs sont signales par une cone ronde rouge contenant une croix blanche dans les vues suivantes : dans l'diteur, la ou les lignes contenant une ou plusieurs erreurs sont marques avec cette icne dans la vue "Tches", une entre pour chaque erreur est cre pour faciliter leur recencement et leur accs dans la vue "Packages", tous les lments allant du fichier source au projet, sont marqus de la petite icne Dans l'diteur, le simple fait de laisser le pointeur de la souris sur la petite icne permet d'afficher une bulle d'aide qui prcise l'erreur.
et
60
Ce menu droulant propose diffrentes options : relancer les prcdentes excutions listes dans la premire partie du menu l'option "Excuter en tant que" permet de lancer l'application dans trois modes diffrents (Application java, Test JUnit et plan de travail d'excution) l'option "Excuter" ouvre une bote de dialogue pour paramtrer prcisment les options d'excution L'option "Excuter en tant que / Application Java" lance la mthode main() d'une application. L'option "Excuter" ouvre une bote de dialogue qui permet de saisir tous les paramtres d'xcution.
La boite de dialogue se compose de six onglets. L'onglet "Main" permet de slectionner le projet et la classe de ce projet qui contient la mthode main() excuter. L'onglet "Arguments" permet de prciser les arguments passs l'application et la machine virtuelle. L'onglet "JRE" permet de slectionner le JRE utiliser lors de l'excution. L'onglet "Chemin d'accs aux classes" permet de modifier la liste et l'ordre des bibliothques utilises lors de l'excution. Cet onglet permet de modifier la liste dfinie dans le projet qui est celle utilise par dfaut. L'onglet "Commun" permet de prciser le type de lancement et le mode d'excution et de dbogage. Une fois tous les paramtres voulus renseigns, il suffit de cliquer sur le bouton " Excuter " pour lancer l'application.
61
La vue " Console " permet de voir les donnes qui sont envoyes dans le flux standard de sortie et d'erreurs.
Les messages ayant pour origine une exception sont aussi envoys dans cette vue.
Pour rsoudre le problme, il faut aller dans l'arborescence java/javadoc des prfrences, cliquer sur le bouton "Parcourir" et slectionner le fichier javadoc.exe du JDK utiliser.
62
Cliquer sur "OK" pour valider les modifications. La gnration de la documentation au format javadoc se fait avec un assistant. Il faut lui indiquer : le ou les projets concerns, la visibilit des membres inclure, le doclet utiliser et le rpertoire de destination.
Cliquer sur "Suivant" La page suivante de l'assistant permet de prciser des options pour l'outil javadoc.
63
Une fois les options configures, cliquer sur "Suivant" La page suivante de l'assistant permet de prciser d'autres options.
En cliquant sur "Fin", la gnration de la documentation est effectue. L'assistant demande si l'emplacement javadoc du projet doit tre mis jour.
64
Il est conseill de rpondre "Oui" pour permettre d'avoir accs cette documentation partir de l'diteur en appuyant sur les touches "Shift" + "F2". Le dtails de la gnration est affich dans le vue "Console".
Un clic sur le bouton "Editer" permet de modifier les donnes du JRE dfini dans Eclipse.
65
L'option "Historique local" du menu contextuel propose 4 options : " Comparer ... "
Cette option permet de comparer la version contenue dans l'diteur avec celles contenues dans l'historique. Il n'est pas possible de reporter les modifications avec cette option. " Remplacer par l'lment prcdent " Cette option permet de remplacer la version de l'diteur par la dernire contenue dans l'historique : elle correspond la dernire sauvegarde. " Remplacer par ... "
Il suffit de slectionner la version dsire et de cliquer sur " Remplacer ". " Restaurer partir de ... " Cette option permet de restaurer des lments contenus dans l'historique mais qui ne sont plus prsents dans l'diteur de code.
66
Il suffit de cocher le ou les lments et de slectionner la version de l'historique restaurer et de cliquer sur le bouton "Restaurer".
Dans la vue " Package ", il faut slectionner le fichier source puis utiliser l'option " Source / Externaliser les chanes " du menu contextuel. Eclipse analyse le code source la cherche de chanes de caractres et affiche l'assistant " Externalisation des chanes ".
67
La premire page de l'assistant permet de slectionner les chanes de caractres traiter dtectes par Eclipse. Pour chaque chane, il est possible de changer le nom de la cl associe la chane de caractres et de prciser si la chane doit tre traite ou non. Pour modifier la cl, il est possible de cliquer sur la cl et de saisir le nouveau nom ou de slectionner la ligne de la chane et de cliquer sur le bouton " Editer la cl "
Pour indiquer si la chane doit tre traite, il est possible de cliquer plusieurs fois sur la case cocher de la ligne correspondante pour obtenir le symbole correspondant la valeur voulue ou de cliquer sur le bouton " Convertir ", " Jamais convertir " ou " Ignorer " aprs avoir slectionn la ligne dsire. Un clic sur le bouton " Suivant " permet de prciser des informations sur le fichier de ressource qui sera gnr.
68
Un clic sur " Suivant " affiche une liste des problmes dtects.
Un clic sur " Suivant " permet d'afficher une page qui prvisualise les modifications qui vont tre apportes.
69
Il est possible de slectionner tout ou partie des modifications en les cochant. Un clic sur le bouton " Fin " met en oeuvre les modifications.
Il suffit de saisir le dbut du nom de la classe ou de l'interface pour que la liste des entits rpondant au critre se construise de faon incrmentale.
70
Il est aussi possible de saisir un motif l'aide des caractres ? pour reprsenter un caractre quelconque unique et * pour reprsenter aucun ou plusieurs caractres quelconques. La zone qualificatif affiche le ou les packages ou l'entit est dfinie. Ce nom de package est suivi du nom du projet si l'entit est dfinie dans le workspace ou du nom fichier qui contient la version compile pour une entit externe. Une fois l'lment voulu slectionn, un clic sur " OK " ouvre l'diteur avec cette entit.
Une "page de testeur de code" est physiquement un fichier contenant du code java et ayant une extension .jpage La seule page de l'assistant permet de slectionner le rpertoire qui va contenir le fichier ainsi que son nom. Par dfaut, l'extension .jpage est ajoute. Un clic sur "Fin" permet de gnrer le fichier et d'ouvrir l'diteur avec son contenu. Le grand avantage est de pouvoir tester des morceaux de code sans avoir crer une classe et une mthode main() et de bnficier de fonctionnalits particulires pour tester ce code.
71
Exemple :
Lors de l'dition du code contenu dans le scrapbook, la barre d'outils est enrichie de plusieurs boutons qui permettent d'utiliser les principales fonctionnalits du scrapbook. Bouton Rle Permet d'excuter un morceau de code et d'valuer le rsultat de l'excution Permet d'afficher dans l'diteur de code, le rsultat de l'excution d'un morceau de code Permet d'excuter un morceau de code et d'afficher le rsultat dans la console Permet d'arrter l'excution dans la machine virtuelle Permet de dfinir les importations Les trois premiers boutons ne sont utilisables que si un morceau de code est slectionn dans le scrapbook. Le quatrime bouton n'est utilisable que si une machine virtuelle excute du code du scrapbook. La fonction " Inspecter " permet de visualiser, dans la vue " Expressions ", les valeurs des objets contenus dans le code slectionn. Pour la mettre en oeuvre, il suffit de slectionner un morceau de code dans l'diteur du scrapbook et de cliquer sur le bouton ou d'utiliser l'option " Inspecter " du menu contextuel.
La fonction " Affichage du rsultat de l'excution " permet d'excuter un morceau de code et d'afficher le rsultat de l'excution dans l'diteur juste aprs la fin de la slection du morceau de code. Pour mettre en oeuvre cette fonctionnalit, il faut slectionner un morceaux de code dans l'diteur du scrapbook.
72
L'affichage insre le type entre parenthse et la valeur du rsultat dans l'diteur. La fonction " Excuter " permet d'excuter d'un morceau de code et d'afficher le rsultat dans la vue " Console ". Pour mettre en oeuvre cette fonctionnalit, il faut slectionner un morceau de code dans l'diteur du scrapbook.
Lors de l'excution de code dans le scrapbook, une machine virtuelle ddie est lance pour cette excution. Pour pouvoir relancer une excution, il faut arrter le machine virtuelle prcdemment lance. L'arrt de cette machine virtuelle peut se faire en cliquant sur le bouton . Lors de l'excution de code dans le scrapbook, si une erreur de syntaxe est dtecte, celle ci est signale directement dans le code de l'diteur Exemple :
73
Lors de l'excution de ce morceau de code, l'erreur suivante est affiche dans l'diteur
La structure d'un fichier java classique n'tant pas respecter dans le scrapbook, la gestion des clauses d'import est gre de faon particulire. Exemple :
Pour ajouter une clause import, il cliquer sur le bouton menu contextuel.
74
Un clic sur le bouton " Ajouter un type " permet d'importer une classe ou une interface dans le scrapbook. .
La zone de saisie du type permet une recherche incrmentale dans toutes les entits dfinies dans le chemin de compilation du projet. Un clic sur le bouton " Ajouter un Package " permet d'importer un package
La zone de saisie du package permet une recherche incrmentale du package dsir parmi tous ceux dfinis dans le chemin de compilation du projet. Enfin pour supprimer l'importation d'une entit, il suffit de la slectionner et de cliquer sur le bouton " Supprimer ". L'assistant de code, est bien sre disponible dans l'diteur du scrapbook toujours en utilisant la combinaison de touches "Ctrl" + "Espace".
75
76
Par dfaut, la perspective "dbogage" affiche quelques vues aussi prsentes dans la perspective Java (les vues "Structure" et "Console") ainsi que l'diteur de code Java. Elle affiche aussi plusieurs vues particulirement ddies au dbogage.
Cette vue possde plusieurs icnes qui permettent d'agir sur les lments affichs. Icne Rle Reprendre l'excution prcdemment interrompue Interrompre l'excution du processus Permet de mettre fin au processus
Execute la ligne courante et arrte l'excution sur la premire ligne de code incluse dans la premire mthode de la ligne courante (raccourci : F5) Exccute la ligne courante et arrte l'excution avant la ligne suivante (raccourci : F6) Excute le code de la ligne courante jusqu' la prochaine instruction return de la mthode (raccourci : F7) Affiche ou non le nom pleinement qualifis des objets
L'excution d'un processus est automatiquement suspendu dans les cas suivants : un point d'arrt est rencontr une exception non capture est propage jusqu'au sommet de la pile d'appel
Un double clic sur un des points d'arrts permet d'ouvrir l'diteur de code directement sur la ligne ou le point d'arrt est dfini. Cette action est identique l'utilisation de l'option "Accder au fichier" du menu contextuel ou un clic sur le bouton de la barre de titre. Il est possible grce au menu contextuel de contrler les points d'arrts. L'option "Nombres d'occurences" permet de prciser le nombre fois ou le points d'arrts excuts sera ignors avant qu'il n'intrrompe l'excution. Ceci est particulirement pratique lorsqu'on dbogue du code contenu dans une boucle et que l'on connait l'itration qui pose problme. Lors du clic sur l'option "Nombres d'occurences", une bote de dialogue permet de prciser le nombre de passage sur le point d'arrt ignorer.
Ce nombre est indiqu dans la vue "Points d'arrts", prcd du libell "nombre d'accs".
79
Il est possible d'activer ou de dsactiver le point d'arrt slectionn respectivement grace l'option "Activer" ou "Dsactiver". L'option "Supprimer" permet de supprimer le point d'arrt slectionn. Il est aussi possible d'utiliser le bouton de la barre de titre de la vue. L'option "Supprimer tout" permet de supprimer tous les points d'arrts dfinis. Il est aussi possible d'utiliser le bouton de la barre de titre de la vue. L'option "Proprits ..." permet d'ouvrir une bote de dialogue pour rgler les diffrents paramtres du point d'arrt slectionn.
Un de ces paramtres les plus intressants est la possibilit de mettre une condition d'activation du point d'arrt. Il suffit pour cela de cocher la case "Activer la condition" et de la saisir dans la zone de texte prvu cet effet. Dans cette zone de texte, l'assistant de compltion de code est utilisable.
Dans cette vue, il est aussi possible de demander l'arrt de l'excution non pas l'excution d'une ligne de code mais la lever d'une exception particulire. Pour cela, il suffit de cliquer sur le bouton . Dveloppons en Java avec Eclipse 80
Il est possible de prciser si l'arrt se fait sur une exception intercepte, non intercept ou dans les deux cas. Ce type de point d'arrt possde les mmes proprits que les points d'arrts lis une ligne de code.
Pour ajouter une nouvelle expression, il suffit d'utiliser l'option du menu contextuel. Une boite de dialogue permet de saisir l'expression.
81
L'option "Rvaluer l'expression de contrle" permet de recalculer la valeur de l'expression. L'option "Editer l'expression de contrle" permet de modifier l'expression.
Il est aussi possible d'ajouter directement une expression dans la vue en utilisant l'option "Assistant de contenu" du menu contextuel.
82
Il faut slectionner le membre ou la variable concern. Pour obtenir des informations sur sa valeur, il suffit de slectionner l'expression dans la vue. Diverses actions sont alors disponibles avec les boutons dans la barre de titre de la vue ou dans les options du menu contextuel : inspecter : excution et valuation dans la vue "Expressions" afficher : afficher le rsultat dans la vue vue "Affichage" excuter : executer l'expression slectionne. Il est ainsi possible de modifier la valeur d'une variable
83
Le plus simple pour lancer le dbogage d'une application est de slectionner l'option Dboguer en tant que / Application Java L'option "Dboguer ... " permet de fournir des paramtres prcis en vue de l'excution d'une application sous le dbogueur. Un assistant permet de slectionner la classe et de prciser les paramtres.
Il ne reste plus qu' mettre en oeuvre les diffrentes fonctionnalits proposes par les vues de la perpective pour dboguer le code.
84
8. Le refactoring
Eclipse intgre de puissantes fonctionnalits pour faciliter le refactoring. Le refactoring consiste modifier la structure d'un fichier source et si ncessaire propager ces modifications dans les autres fichiers sources pour maintenir autant que possible l'intgrit du code. Un menu nomm Propager les modifications permet d'utiliser certaines de ces fonctionnalits : il est prsent dans le menu principal et dans de nombreux menus contextuels. Avant de pouvoir utiliser ces fonctionnalits, il faut sauvegarder l'lment qui sera modifi sinon un message d'erreur est affich.
L'usage de ces fonctions utilise toujours le mme principe de fonctionnement : 1. slection de l'lment concern par la fonction de refactoring 2. appel de la fonction en utilisant l'option du menu Propager les modifications 3. renseigner les informations utiles la fonction dans la bote de dialogue 4. prvisualiser et valider individuellement les modifications qui seront apportes 5. demander la mise en oeuvre des modifications en cliquant sur Ok (ceci peut tre fait sans demander la prvisualisation) Le bouton Apercu > permet d'ouvrir une bote de dialogue qui permet de prvisualiser chacune des modifications rsultant de l'usage de la fonction.
85
Une arborescence permet d'afficher chacun des lments qui sera modifi ainsi que toutes les modifications pour ces lments. Il est possible de cocher tout ou partie des modifications pour qu'elles soient appliques. La partie infrieure prsente, pour l'lment slectionn, le code source actuel gauche et le code source tel qu'il sera aprs l'application de la fonction droite. Un clic sur le bouton OK permet de mettre en oeuvre toutes les modifications qui sont coches.
Il faut slectionner l'option Extraire la mthode du menu principal ou du menu contextuel Propager les modifications . Une boite de dialogue permet de saisir le nom de la mthode et de slectionner le modificateur d'accs.
86
Dans le cas ou le code slectionn contient une ou plusieurs variables, la bote de dialogue contient en plus la liste des variables dtectes dans le code.
87
Il faut saisir le nom de la mthode et slectionner son modificateur d'accs. La liste des variables dtectes dans le code est affiche dans la liste des paramtres. Pour modifier le nom d'un des paramtres, il suffit de le slectionner et de cliquer sur le bouton Editer .
Le bouton Aperu permet de voir et de valider les modifications qui seront apportes.
88
8.2. Intgrer
L'intgration permet de remplacer l'appel d'une mthode par le code contenu dans cette mthode.
Puis il faut utiliser l'option Propager les modifications/Intgrer du menu principal ou contextuel.
89
En fonction du contexte d'appel, une bote de dialogue permet de slectionner la porte des modifications. Si le code slectionn ne correspond pas une mthode, un message d'erreur est affich.
8.3. Renommer
La fonction renommer permet d'attribuer un nouveau nom une entit prsente dans le workspace. Les exemples de cette section utilisent les deux classes suivantes :
90
Le renommage concerne l'entit slectionne dans une vue ou sous le curseur dans l'diteur. Par exemple, pour renommer une mthode, il suffit de positioner le curseur sur le nom de la dclaration d'une mthode dans le code source et slectionner l'option Propager les modifications / Renommer du menu contextuel.
Il suffit alors de saisir le nouveau nom. Eclipse permet de renommer la mthode dans sa classe de dfinition mais remplace aussi tous les appels de la mthode contenue dans le workspace.
Pour renommer une classe, il y a deux possibilits : selectionner la classe dans la vue Packages ou positionner le curseur sur la dfinition du nom de la classe dans l'diteur. Puis il faut utiliser l'option Renommer du menu contextuel Propager les modifications .
91
Il est possible de prciser les types d'entits qui doivent tre mise jour. A la validation, Eclipse effectue toutes les modifications ncessaires suite au renommage de la classe, notamment le remplacement tous les endroits dans le workspace ou la classe est utilise.
92
Si Eclipse dtecte des problmes potenciels lors de l'analyse de la demande, il affiche dans une boite de dialogue la liste de ces problmes et demande un confirmation avant de poursuivre les traitements.
8.4. Dplacer
93
Cette section sera dveloppe dans une version future de ce document Si le code slectionn ne correspond pas une entit concerne par cet action, un message d'erreur est affich.
Si le code slectionn ne correspond pas une entit concerne par cet action, un message d'erreur est affich.
94
Si le code slectionn ne correspond pas une entit concerne par cet action, un message d'erreur est affich.
Si le code slectionn ne correspond pas une entit concerne par cet action, un message d'erreur est affich.
8.8. Extraire
8.9. Transferer
95
Si la partie slectionne ne correspond pas un nom de classe, un message d'erreur est affich.
Il suffit ensuite d'utiliser l'option Extraire une interface du menu Propager les modifications . Une boite de dialogue permet de prciser le nom de l'interface et de slectionner les membres dclarer dans l'interface.
96
Pour respecter les spcifications du langage Java, les membres qu'il est possible d'intgrer dans l'interface sont des mthodes et des constantes publiques.
97
Puis utiliser l'option Convertir la variable locale en zone du menu Propager les modifications . Si la slection ne correspond pas une variable locale, un message d'erreur est affich.
Une bote de dialogue permet de prciser le nom du champ, le modificateur d'accs et l'endroit dans le code ou le champ sera initialis.
Il faut ensuite utiliser l'option Encapsuler la zone du menu Propager les modifications . Si la slection dans le code ne correspond pas un champ de la classe, un message d'erreur est affich.
Une boite de dialogue permet de prciser les options pour la gnration du getter et du setter
99
Le rsultat de l'excution gnre le getter et le setter et remplace l'utilisation du champ par ces mthodes.
En slectionnant l'option conserver les rfrences de zones , ces mthodes ne sont pas utilises dans la classe.
100
Puis utiliser l'option Extraire la variable locale du menu Propager les modifications .
Une bote de dialogue permet de saisir le nom de la variable, de prciser si toutes les occurrences doivent tre modifies et si la variable doit tre une constante. Si la slection dans le code source est incorecte, un message d'erreur est affich.
101
Puis d'utiliser l'option Extraire une constante du menu Propager les modifications . Une boite de dialogue apparat pour prciser le nom de la constante crer et son modificateur d'accs.
Il est possible de prciser si toutes les occurrences de la valeur doivent tre remplaces dans le code source. Il est aussi possible de prciser l'utilisation de la qualification de la constante avec le nom de la classe dans laquelle elle est dfinie.
102
103
Pour configurer l'IDE, il faut slectionner la ressource qui contient l'lment dans la vue "Packages" : un projet un fichier .jar Exemple : associer la doc du JDK avec le fichier rt.jar Il faut slectionner le fichier rt.jar du projet dans la vue "Packages" et slectionner le menu contextuel "Proprits". Il faut slectionner "Emplacement Javadoc" puis cliquer sur parcourir pour slectionner le rpertoire qui contient le fichier packagelist de la documentation.
Enfin, il faut cliquer sur "OK" pour valider les changements. Si le chemin n'est pas correct, un message d'erreur est affich.
Il est alors possible dans l'diteur de code Java de positionner le curseur sur un lment contenu dans un des emplacements Javadoc pour que l'aide en ligne affiche la page concerne par l'lment dans la documentation javadoc. Ce processus est applicable toutes les API dont la documentation Javadoc est disponible.
Ce plug in cre une entre nomme "Essentials Java Docs" dans la table des matire de l'aide en ligne. Cette documentation regroupe les API essentielles.
Ce plug in est tlchargeable sur le site de Crionics (environ 30 Mo): http://www.crionics.com/products/opensource/eclipse/com.crionics.java.doc.zip Pour l'installer, il suffit de dzipper son contenu dans le rpertoire plug in d'intallation d'Eclipse.
105
Ant est un projet du groupe ApacheJakarta. Son but est de fournir un outil crit en java pour permettre la construction d'applications (compilation, excution de taches post et pr compilation ... ). Ces processus de construction d'applications sont trs importants car ils permettent d'automatiser des oprations rptitives tout au long du cycle de vie de l'application (dveloppement, tests, recettes, mises en production ... ). Le site officiel de ant est http://jakarta.apache.org/ant/index.html. Ant pourrait tre compar au clbre outil make sous Unix. Il a t dvelopp pour fournir un outil de construction indpendant de toute plateforme car crit avec et pour java. Il repose sur un fichier de configuration XML qui dcrit les diffrentes tches qui devront tre excutes par l'outil. Ant fournit un certain nombre de tches courantes qui sont codes sous forme d'objets dvelopps en java. Le fichier de configuration contient un ensemble de cible (target). Chaque cible contient une ou plusieurs tches. Chaque cible peut avoir une dpendance envers une ou plusieurs autres cibles pour pouvoir tre excute. Pour obtenir plus de dtails sur l'utilisation de Ant, il est possible de consulter la documentation de la version courante l'url suivante : http://jakarta.apache.org/ant/manual/index.html
106
Cliquer sur le bouton "Create New Folder". Il faut saisir le nom du rpertoire qui va contenir les sources (par exemple src) et cliquer sur "OK".
En cliquant sur "Yes", Eclipse va automatiquement crer un rpertoire bin qui va contenir le rsultat des compilations des sources.
107
Cliquer sur "Yes". Il faut ensuite dplacer les fichiers .java existant dans le rpertoire src en effectuant un copier/coller dans la vue "Navigateur". Il faut ensuite crer un rpertoire build contenant deux sous dossiers : lib et doc. Ces dossiers vont contenir respectivement les fichiers de distribution gnrs (.jar, .war, .ear selon le type d'application) et la documentation des classes au format javadoc.
Le fichier est automatiquement reconnu comme tant un fichier de configuration pour Ant : une icne particulire contenant une fourmi est associe au fichier. Il suffit ensuite d'diter le fichier pour insrer les paramtres d'excution.
108
Un diteur particulier est ddi l'dition du fichier build.xml de Ant. Il propose notamment un achvement du code pour les tags en utilisant Ctrl + espace.
109
Par dfaut, la tche dfinie par dfaut dans le fichier build.xml est slectionne. Pour lancer l'excution, il suffit de cliquer sur le bouton "Excuter". Le rsultat de l'excution s'affiche dans la vue "Console" Exemple :
Buildfile: I:\eclipse 2.1\workspace\test_junit\build.xml bonjour: [echo] Premier test avec Ant! BUILD SUCCESSFUL Total time: 401 milliseconds
110
Il faut ajouter l'attribut encoding avec le jeux de caractres utiliss dans le prologue du fichier build.xml. Exemple :
<?xml version="1.0" encoding="ISO88591" ?>
Exemple :
Buildfile: I:\eclipse 2.1\workspace\test_junit\build.xml
111
init: [echo] Generation numero : 7 du July 2 2003 compil: doc: [javadoc] Generating Javadoc [javadoc] Javadoc execution [javadoc] BUILD FAILED: file:I:/eclipse 2.1/workspace/test_junit/build.xml:37: Javadoc failed: java.io.IOException: CreateProcess: javadoc.exe d "I:\eclipse 2.1\workspace\test_junit\build\doc" use package classpath "I:\eclipse 2.1\s tartup.jar;I:\eclipse 2.1\workspace\test_junit\junit.jar" version author "I:\eclipse 2.1\workspace\test_junit\src\MaClasse.java" "I:\eclipse 2.1\workspace\test_junit\src\MaClasse2.java" error=2 Total time: 681 milliseconds
Il faut vrifier la prsence de l'outil dans les rpertoires dsigns par la variable d'environnement PATH du systme d'exploitation. Dans le cas de javadoc sous Windows, il faut s'assurer que %JAVA_HOME%\bin soit insrer dans la variable PATH. Si cette dernire doit tre modifie, il faut arrter et relancer Eclipse aprs la modification pour que celle ci soit prise en compte.
Dans les prfrences, il faut rajouter le fichier junit.jar dans l'onglet "Classpath" de l'arborescence "Ant/Runtime"
112
</description> <property <property <property <property <property <property name="bin" location="bin"/> name="src" location="src"/> name="build" location="build"/> name="doc" location="${build}/doc"/> name="lib" location="${build}/lib"/> name="junit_path" value="junit.jar"/>
<target name="init" description="Initialisation"> <tstamp/> <buildnumber file="numerobuild.txt" /> <echo message="Generation numero : ${build.number} du ${TODAY}"/> </target> <target name="compil" depends="init" description="Compilation"> <javac srcdir="${src}" destdir="${bin}"> <classpath> <pathelement path="${java.class.path}"/> <pathelement location="${junit_path}"/> </classpath> </javac> </target> <target name="all" depends="init, compil, test, doc" description="Generation complete"> <echo message="Generation complete."/> </target> <target name="doc" depends="compil" description="Generation de la documentation"> <javadoc destdir="${doc}" author="true" version="true" use="true" package="true"> <fileset dir = "${src}"> <include name="**/*.java"/> <exclude name="**/*Test*"/> </fileset> <classpath> <pathelement path="${java.class.path}"/> <pathelement location="${junit_path}"/> </classpath> </javadoc> </target> <target name="test" depends="compil" description="Executer les tests avec JUnit"> <junit fork="yes" haltonerror="true" printsummary="on"> <formatter type="plain" usefile="false" /> <test name="ExecuterLesTests"/> <classpath> <pathelement location="${bin}"/> <pathelement location="${junit_path}"/> </classpath> </junit> </target> </project>
Rsultat de l'excution :
Buildfile: I:\eclipse 2.1\workspace\test_junit\build.xml init: [echo] Generation numero : 16 du July 2 2003 compil: test: [junit] Running ExecuterLesTests [junit] Tests run: 3, Failures: 0, Errors: 0, Time elapsed: 0,02 sec [junit] Testsuite: ExecuterLesTests [junit] Tests run: 3, Failures: 0, Errors: 0, Time elapsed: 0,02 sec [junit] [junit] Testcase: testCalculer took 0,01 sec [junit] Testcase: testCalculer took 0 sec [junit] Testcase: testSommer took 0 sec
113
doc: [javadoc] [javadoc] [javadoc] [javadoc] [javadoc] [javadoc] [javadoc] [javadoc] [javadoc] [javadoc] all: [echo] Generation complete. BUILD SUCCESSFUL Total time: 4 seconds Generating Javadoc Javadoc execution Loading source file I:\eclipse 2.1\workspace\test_junit\src\MaClasse.java... Loading source file I:\eclipse 2.1\workspace\test_junit\src\MaClasse2.java... Constructing Javadoc information... Standard Doclet version 1.4.1 Building tree for all the packages and classes... Building index for all the packages and classes... Building index for all classes...
114
La version 2.1 d'Eclipse intgre la possibilit d'utiliser JUnit directement dans l'IDE. JUnit est un framework open source pour raliser des tests unitaires sur du code Java. Le principal intrt est de s'assurer que le code rpond toujours au besoin mme aprs d'ventuelles modifications. Le but est d'automatiser les tests. Ceux ci sont exprims dans des classes sous la forme de cas de tests avec leurs rsultats attendus. JUnit excute ces tests et les comparent avec ces rsultats. Avec Junit, l'unit de test est une classe ddie qui regroupe des cas de tests. Ces cas de tests excutent les tches suivantes : cration d'une instance de la classe et de tout autre objet necessaire aux tests appel de la mthode tester avec les paramtres du cas de test comparaison du rsultat obtenu avec le rsultat attendu : en cas d'chec, une exception est leve
115
La classe suivante est utilise comme classe tester avec JUnit. Exemple :
package com.moi.test.junit; public class MaClasse { public int additioner(int a, int b) { return a + b; } }
Pour utiliser JUnit, il faut crer une classe qui va contenir les cas de test. Il faut crer une nouvelle entit de type Java/JUnit/TestCase
116
Si le fichier junit.jar n'est pas inclus dans le classpath du projet, un message d'erreur est affich et il est impossible de poursuivre l'excution de l'assistant.
117
Il faut complter la classe gnre selon les besoins : par exemple, ajouter un attribut qui va contenir une instance de la classe tester, ajouter l'instanciation de cette classe dans la mthode setUp() et librer cette instance dans la mthode tearDown(). Il faut ajouter les traitements ncessaires dans les mthodes testXXX() en utilisant l'API de JUnit. Exemple :
package com.moi.test.junit; import junit.framework.TestCase; public class MaClasseTest extends TestCase { private MaClasse maClasse = null; public MaClasseTest(String arg0) { super(arg0); } public static void main(String[] args) { junit.swingui.TestRunner.run(MaClasseTest.class); } protected void setUp() throws Exception { super.setUp(); maClasse = new MaClasse(); } protected void tearDown() throws Exception { super.tearDown(); maClasse = null; }
118
JUnit utilise l'instrospection pour excuter les mthodes commenant par test.
Eclipse excute les tests et affiche le rsultat dans une vue ddie.
119
Si tous les cas de tests ont t excuts avec succs, une ligne verte est affiche. Cette vue contient deux onglets : Failures : contient la liste des cas de tests qui ont chous Hierarchy : contient une arborescence des cas de tests Dans le cas o un ou plusieurs tests chouent, la ligne est rouge. Exemple : si le cas test suivant est ajout :
public void testAdditioner() { assertTrue(maClasse.additioner(2,2) == 4); assertTrue(maClasse.additioner(2,3) == 4); }
120
121
CVS (Concurrent Versions System) est un outil libre de gestion des versions. Initialement dvelopp pour Unix, une version pour windows NT/2000 de CVS peut tre tlcharge l'url http://www.cvsnt.org/ Toutes les donnes sont stockes dans un rfrentiel (repository). Chaque modification d'une ressource gre par CVS associe cette entit un numro de rvision unique. Une version contient un ensemble de ressource, chacune ayant une rvision particulire pour la version correspondante. CVS ne verrouille pas ces ressources. Deux dveloppeurs peuvent crer chacun une rvision d'une mme ressource. La fusion des deux versions est la charge d'un des dveloppeurs. Eclipse propose une perspective pour utiliser CVS dans un projet.
122
123
124
Une fois l'installation termine, cliquer sur Finish. Excuter le service control panel en cliquant sur l'icne dans le menu
125
Cliquer sur Repository prefix et slectionner le rpertoire cvsrepo prcdemment cr. Cliquer sur Add
126
127
Cliquer sur Ok
128
Une boite de dialogue s'ouvre pour dfinir un nouvel emplacement. Un emplacement contient uniquement les informations sur une connexion.
129
Renseigner le nom de la machine, le chemin du rfrentiel, le nom du user, son mot de passe (celui de windows) et le type de connexion (utiliser pserver). Cliquer sur "Fin"
Il faut slectionner un projet dans une vue et slectionner l'option "Equipe/Partager le projet".
130
Cette tape permet de donner un nom au module: celui du projet Eclipse ou un nom spcifique. Cliquer sur "Suivant".
Cliquer sur "Fin". La vue "Synchronisation Mode sortant" affiche les fichiers qui ont t modifis
131
Dans cette vue, slectionner le projet et activer l'option "Ajouter au contrle de version" du menu contextuel.
Une fois le traitement effectu, activer l'option "Valider" du menu contextuel Une boite de dialogue demande la saisie d'un commentaire
132
Remarque : si l'arborescence du projet n'est pas affiche, il suffit de cliquer sur le bouton l'option "Afficher les dossiers".
et de cocher
Dans cette vue, il suffit de slectionner la ressource et d'activer l'option "Valider". Il est possible de saisir un commentaire. La vue "Synchronisation" permet la synchronisation entre les ressources locales (dans le workspace) et celles contenues dans CVS. Les trois premiers boutons permettent de prciser le sens de la synchronisation : mode entrant : modifications contenues dans le rfrentiel intgrer dans le workspace mode sortant : modifications contenues dans le workspace intgrer dans le rfrentiel mode entrant/sortant : modifications dans le workspace et le rfrentiel intgrer dans l'un et l'autre
133
La rvision courante est prcde d'une petite toile. Pour remplacer la ressource par celle correspondant une autre rvision, il suffit de slectionner la rvision et d'activer l'option "Obtenir une rvision avec des marqueurs" du menu contextuel. Il faut ensuite cliquer sur "Ok" lors du message d'avertissement et la rvision courante est modifie. Il est possible de comparer le contenu de deux rvisions. Pour cela, il suffit de slectionner les deux rvisions en maintenant la touche Ctrl enfonce et d'activer l'option "Comparer" du menu contextuel.
134
Il suffit de saisir le nom et de cliquer sur le bouton "Ok" La version apparat dans la vue "Rfrentiels CVS"
135
A partir du Navigateur, il est possible d'ouvrir le fichier slectionn dans un diteur : avec l'diteur par dfaut associ au type du fichier, il suffit de double cliquer sur le fichier dans le navigateur ou d'utiliser l'option "Ouvrir" du menu contextuel. avec un autre diteur en utilisant l'option "Ouvrir Avec" du menu contextuel L'association d'un type de fichier avec un diteur peut tre faite dans les prfrences. La vue "Navigateur" contient une option particulirement pratique pour retrouver une ressource : l'outil"Accder ". Cet outil permet partir d'un motif (Pattern) de retrouver les ressources qui respectent le Dveloppons en Java avec Eclipse 136
motif dans leur nom. L'option "Accder / Ressource" du menu contextuel de la vue navigator permet d'ouvrir une bote de dialogue contenant l'outil.
Au fur et mesure de la saisie du motif, la liste des fichiers correspondant s'affiche. Il suffit de choisir le fichier et de cliquer sur "OK" pour fermer la bote de dialogue et slectionner le fichier dans la vue "Navigateur". Par dfaut, la vue "Navigateur" affiche tous les projets contenus dans le workspace. Il est possible de limiter la vue la hirarchie d'un projet ou d'un dossier en le slectionnant et en utilisant l'option "Suivant" du menu contextuel. Ces boutons permettent de passer d'un mode l'autre.
Le menu contextuel propose aussi des options pour copier, dplacer, renommer et supprimer une ressource.
137
Eclipse est conu pour tre un outil modulaire. De nombreux modules (plugins) sont fournis avec Eclipse mais il est aussi trs facile d'en ajouter d'autres dvelopps par la communaut ou des socits commerciales. L'installation d'un plugin est souvent trs simple car elle consiste essentiellement dzipper l'archive qui contient le plugin pour que le contenu soit insrer dans le rpertoire plugins o est install Eclipse.
Cette bote de dialogue affiche des informations gnrales sur Eclipse et permet de slectionner le type d'informations supplmentaires souhaites. Cliquer sur Dtails des plug in
138
Un clic sur le bouton "Dtails de la configuration" affiche un fichier dans la vue diteur contenant des informations dtailles sur la configuration en cours d'utilisation.
Un clic sur le bouton "Dtails des dispositifs", permet d'avoir des informations sur les lments de base d'Eclipse.
139
Le module est parfaitement intgr dans Eclipse : les options du module sont modifiables dans l'arborescence "Java / Jadclipse" des prfrences (menu "Window / Preferences").
140
Il permet notamment : d'indenter le code de gnrer des modles de commentaires javadoc dynamique en fonction des l'lments du code documenter (par exemple gnrer un tag @param pour chaque paramtre d'un mthode) d'organiser l'ordre des clauses import d'organiser l'ordre des membres d'une classe selon leur modificateur de vrifier l'application de normes de codage, Il existe des plug in pour plusieurs IDE dont un pour Eclipse : il suffit de tlcharger le fichier jalopyeclipse0.2.6.zip sur le site http://jalopy.sourceforge.net/download.html Pour installer le plug in, il faut dzipper le contenu de l'archive dans un rperoire temporaire et copier le rpertoire de.hunsicker.jalopy.plugin.eclipse_0.2.6 dans le rpertoire plugins d'Eclipse. L'option Jalopy preferences du menu "Fenetre" permet de paramtrer Jalopy
Pour la mise en oeuvre, il suffit d'utiliser le menu contextuel "Format with Jalopy" de l'diteur de code Java. Exemple :
package com.moi.test; public class TestJalopy { public static void main(String[] args) {} public void maMethode(int a, int b) {} private int maMethode2(int a) { return a; } public void maMethode3() {} }
Rsultat :
package com.moi.test; /** * DOCUMENT ME! * * @author $author$ * @version $Revision$ */
141
public class TestJalopy { /** * DOCUMENT ME! * * @param args DOCUMENT ME! */ public static void main(String[] args) { } /** * DOCUMENT * * @param a * @param b */ public void }
/** * DOCUMENT ME! */ public void maMethode3() { } /** * DOCUMENT ME! * * @param a DOCUMENT ME! * * @return DOCUMENT ME! */ private int maMethode2(int a) { return a; } }
Le formattage du code source est ralis en tenant compte des nombreux paramtres dfinis dans Jalopy. Il est galement possible de demander le formattage de l'ensemble des fichiers source Java contenus dans un ou plusieurs packages ou rpertoires. Il suffit de slectionner le ou les packages ou rpertoire et de slectionner l'option "Format" du menu contextuel.
142
Eclipse 2.0 propose une fonctionnalit qui permet d'installer ou de mettre jour des plugins via le web. La perspective Installation / Mise jour permet la gestion de ces mises jour. Pour l'afficher, il suffit de slectionner cette perspective ou de slectionner l'option Mise jour des logiciels / Gestionnaire des mises jour du menu "Aide".
La vue "Mises jour des dispositifs" recence la liste des sources d'o peuvent tre tlcharges les mises jour.
143
L'exemple ci dessous illustre la mise jour d'une version 2.1 d'Eclipse avec la version 2.1.1.
144
Cliquez sur le bouton "Installer". Une fois l'installation termine, il faut relancer Eclipse.
145
Il faut saisir le nom et l'url du fichier site.xml dsir puis cliquer sur le bouton "Fin".
L'application va lire le fichier et affiche les plugins disponibles dans l'arbrescence. Il suffit de slectionner la version dsire. La vue "Aperu" affiche le details du plugin slectionn. Pour installer la version slectionne, cliquer sur le bouton "Install" dans la vue Aperu .
146
Cliquer sur "Next". Lire et accepter la licence, puis cliquer sur le bouton Next
147
Confirmer l'installation, car le package n'est pas sign, en cliquant sur le bouton Install Le plug est tlcharg et install. L'assistant propose de redmarrer le workbench pour que les modifications soient prises en compte. Cliquer sur le bouton "Yes".
Il peut tre intressant d'ajouter le site officielle d'Eclipse pour ajouter des plugins qui ne sont pas fournis en standard.
Un fois le nouveau signet configur, il suffit de naviguer dans l'arborescence en fonction de la version de la plateforme pour pouvoir installer un ou plusieurs plugins parmis ceux proposs.
148
149
Pour restaurer une configuration, il suffit de slectionner dans la vue Configuration de linstallation le sauvegarde automatique (dans historique de la configuration) ou la sauvegarde manuelle (dans Configuration sauvegardes).
150
Pour avoir plus dinformations, il suffit de slectionner la mise jour et de cliquer sur le bouton Dtails de lerreur .
Dans lexemple cidessus, il manque un plug in ou la version installe nest pas correcte. Pour rsoudre le problme, il suffit de quitter Eclipse, dinstaller le plug in (en le dzippant dans le bon rpertoire) et de relancer Eclipse.
Il suffit alors de dcocher la mise jour posant problme et de cliquer sur le bouton Fin afin de mettre jour le plug in manquant. Cette opration ncessite le redmarrage dEclipse.
151
Suite ce redmarrage, le plug in erron napparat plus en erreur et peut tre install en cliquant sur le bouton Fin .
152
Eclipse est un outils de dveloppement, crit en Java, dont un des buts initiaux est de pouvoir dvelopper non seulement en Java mais aussi avec d'autres langages grce des plug in spcifique. Il existe dj plusieurs plug in plus ou moins avancs pour raliser des dveloppements en C/C++ et Cobol dvelopp par Eclipse mais aussi C# ou PHP dvelopps par des tiers.
153
Dans la vue mise jour des dispositifs, utiliser loption Nouveau / Signet du site du menu contextuel. Il faut saisir un nom par exemple "Eclipse CDT" et saisir l'url "http://update.eclipse.org/tools/cdt/updates/release".
Cliquer sur le bouton "Fin" pour permettre Eclipse de rechercher les mises jour. La vue "Mise jour des dispositifs" affiche celles disponibles.
154
La vue "Aperu" affiche des informations sur le plugin. Cliquez sur le bouton Installer Maintenant
155
Lisez et si vous acceptez les termes du contrat, cliquez sur le bouton Suivant
156
Cliquez sur le bouton Oui . Faites la mme opration avec la mise jour Eclipse C/C++ development tools CppUnit support 1.1.0. Si vous installez cette mise jour avant la prcdente, le message derreur suivant est affich.
157
Une fois l'installation termine, l'diteur de la prespective ressource affiche des informations sur le CDT.
158
Pour un projet en C++, slectionnez "C++" dans la liste de gauche puis "Standard Make C++ Project" dans la liste de droite et enfin cliquez sur le bouton "Suivant"
Sous Windows, dans longlet Binary Parser , cliquez sur PE Windows Parser puis sur le bouton Fin .
159
Il faut ensuite crer un fichier nomm makefile pour automatiser la gnration de l'excutable grce l'outils make.
160
161
L'assistant d'installation se compose de plusieurs pages : Sur la page d'accueil, cliquez sur le bouton "Next". La page "License Agreement" apparait : lisez la licence et cliquez sur le bouton "Yes" pour accepter les termes de la licence et poursuivre l'installation. La page "Information" apaprait : lisez le texte et cliquez sur le bouton "Next". La page "Select destination directory" apparait : slectionnez le rpertoire ou sera installer MinGW et cliquez sur le bouton "Next". La page "Ready to install" apparait : cliquez sur le bouton "Install". Lancez l'excution de MinSys. Un script permet de configurer l'environnement.
162
Il faut dcocher "use default" et saisir "make f makefile" dans le champ "build command".
Il faut ajouter les rpertoire suivants dans la variable denvironnement path : C:\msys\1.0\bin;C:\MinGW\bin; Attention : aprs la modification, il faut relancer Eclipse si celui ci tait en cours dexcution. Si les outils make et gcc ne sont pas trouvs, alors le message suivant est afficher dans la vue CBuild Exemple :
Build Error (Exec error:Launching failed)
Attention : il est important que le bon programme makefile soit le premier trouv dans le classpath. Il est par exemple possible davoir des problmes avec loutils Delphi de Borland qui ajoute dans le classpath un rpertoire qui contient un programme Makefile.
163
Dans ce cas, il suffit de dplacer ou de supprimer la rfrecence sur le rpertoire C:\Program Files\Borland\Delphi7\Bin; dans la variable classpath. (il faut le remettre en cas de suppression pour une utilisation correcte de Delphi). Si la gnration se passe bien, le vue CBuild affiche les tapes de le gnration. Exemple :
make f makefile gcc c premierTest.cpp gcc o premierTest premierTest.o L C:/MinGW/lib/gcclib/mingw32/3.2.3/ lstdc++
Lancer lexcution, il suffit de slectionner le fichier premierTest.exe et dutiliser l'option Ouvrir du menu contextuel.
164
Sur longlet Arguments , saisir Djava.library.path="chemin_complet_du_fichier" et cliquez sur le bouton Appliquer puis sur le bouton Excuter
Linconvnient de cette mthode est que cette configuration doit tre effectue pour chaque configuration de lancement. 2. Ajouter le rpertoire qui contient la bibliothque la variable PATH sous Windows ou LD_LIBRAY_PATH sous Unix. 3. Il est possible de copier la bibliothque dans un rpertoire contenu dans la variable java.library.path. Linconvnient de cette mthode est quil faut recopier la bibliothque chaque nouvelle version de SWT utilise. 4. Il est possible de copier la bibliothque dans le rpertoire racine de lapplication. Linconvnient de cette mthode est quil faut recopier la bibliothque dans chaque projet qui utilise SWT.
Lors de lexcution si la bibliothque ne peut tre accde par lapplication, une exception est leve. Exemple :
java.lang.UnsatisfiedLinkError: no swtwin322135 in java.library.path
166
button.setBounds(10, 60, 100, 25); composite.setSize(140,140); shell.pack(); shell.open(); while (!shell.isDisposed()) if (!display.readAndDispatch()) display.sleep(); couleur.dispose(); display.dispose(); } }
Si l'environnement est correctement configur comme expliqu dans la section prcdente, l'excution de l'application se fait comme tout autre application.
17.2.1. Installation
V4All require linstallation du plug in GEF (Graphical Editing Framework) en excutant les tapes suivantes : tlcharger le fichier http://download.eclipse.org/tools/gef/downloads/drops/R2.1.1200306180934/GEFruntimeI20030618.zip sur le site dEclipse dzippez ce fichier dans le rpertoire qui contient Eclipse. relancez Eclipse et cliquer sur le bouton Fin pour valider les modifications apportes par le plugin cliquez sur le bouton Oui lors de la demande de relance de lapplication. Pour installer V4All, il faut suivre les tapes suivantes : tlchargez le fichier v4all_2_1_1_9.zip sur le site http://sourceforge.net/projects/v4all dzippez son contenu dans le rpertoire qui contient Eclipse. relancez Eclipse et cliquer sur le bouton Fin pour valider les modifications apportes par le plugin cliquez sur le bouton Oui lors de la demande de relance de lapplication. Dveloppons en Java avec Eclipse 167
17.2.2. Utilisation
Pour utiliser v4all, il faut crer ou utiliser un projet Java existant, puis il faut crer un nouveau projet de type V4E editor .
Un assistant permet de slectionner le projet Java qui va contenir le code, de saisir le nom du fichier qui va contenir les informations, et de slectionner lAPI utiliser Il suffit de cliquer sur le bouton Fin pour que la perspective ddie V4All saffiche.
168
V4All propose son propre diteur pour raliser de manire WYSIWYG des interfaces graphiques. Cet diteur se compose de deux parties : une barre latrale qui permet de dfinir une action et de slectionner un composant une zone de travail sur laquelle les composants sont dposs par cliquer/glisser Par dfaut, chacun des lments de la barre est ouvert, ce qui les rend peu visibles. Pour ouvrir un seul lment, il suffit de double cliquer sur son titre.
169
Lapparence de la barre peut tre configure pour faciliter son utilisation : le menu contextuel de la barre propose plusieurs options intressantes :
Lutilisation de loption Use large Icons amliore la visibilit des icnes. Loption Layout permet de slectionner le mode daffichage des composants : lutilisation de loption Details permet davoir un libell associ licne.
Pour ajouter un bouton, il suffit de faire un cliquer/glisser du composant sur la Frame : le conteneur qui va recevoir le composant change de couleur.
170
Chaque composant possde de nombreuses proprits quil est possible de modifier dans la vue proprits. Cette vue affiche les proprits du composant slectionn dans lditeur. Pour un bouton, il est par exemple possible de modifier le nom du composant avec la proprit Basic / Bean Name , le texte du bouton avec Component / Text , Procder de la mme faon pour ajouter une zone de texte (composant de type TextField).
171
18. Annexes
Annexe A : GNU Free Documentation License
Version 1.1, March 2000
Copyright (C) 2000 Free Software Foundation, Inc. 59 Temple Place, Suite 330, Boston, MA 021111307 USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. 0. PREAMBLE The purpose of this License is to make a manual, textbook, or other written document "free" in the sense of freedom: to assure everyone the effective freedom to copy and redistribute it, with or without modifying it, either commercially or noncommercially. Secondarily, this License preserves for the author and publisher a way to get credit for their work, while not being considered responsible for modifications made by others. This License is a kind of "copyleft", which means that derivative works of the document must themselves be free in the same sense. It complements the GNU General Public License, which is a copyleft license designed for free software. We have designed this License in order to use it for manuals for free software, because free software needs free documentation: a free program should come with manuals providing the same freedoms that the software does. But this License is not limited to software manuals; it can be used for any textual work, regardless of subject matter or whether it is published as a printed book. We recommend this License principally for works whose purpose is instruction or reference. 1. APPLICABILITY AND dfiniTIONS This License applies to any manual or other work that contains a notice placed by the copyright holder saying it can be distributed under the terms of this License. The "Document", below, refers to any such manual or work. Any member of the public is a licensee, and is addressed as "you". A "Modified Version" of the Document means any work containing the Document or a portion of it, either copied verbatim, or with modifications and/or translated into another language. A "Secondary Section" is a named appendix or a frontmatter section of the Document that deals exclusively with the relationship of the publishers or authors of the Document to the Document's overall subject (or to related matters) and contains nothing that could fall directly within that overall subject. (For example, if the Document is in part a textbook of mathematics, a Secondary Section may not explain any mathematics.) The relationship could be a matter of historical connection with the subject or with related matters, or of legal, commercial, philosophical, ethical or political position regarding them. The "Invariant Sections" are certain Secondary Sections whose titles are designated, as being those of Invariant Sections, in the notice that says that the Document is released under this License. The "Cover Texts" are certain short passages of text that are listed, as FrontCover Texts or BackCover Texts, in the notice that says that the Document is released under this License. A "Transparent" copy of the Document means a machinereadable copy, represented in a format whose specification is available to the general public, whose contents can be viewed and edited directly and Dveloppons en Java avec Eclipse 172
straightforwardly with generic text editors or (for images composed of pixels) generic paint programs or (for drawings) some widely available drawing editor, and that is suitable for input to text formatters or for automatic translation to a variety of formats suitable for input to text formatters. A copy made in an otherwise Transparent file format whose markup has been designed to thwart or discourage subsequent modification by readers is not Transparent. A copy that is not "Transparent" is called "Opaque". Examples of suitable formats for Transparent copies include plain ASCII without markup, Texinfo input format, LaTeX input format, SGML or XML using a publicly available DTD, and standardconforming simple HTML designed for human modification. Opaque formats include PostScript, PDF, proprietary formats that can be read and edited only by proprietary word processors, SGML or XML for which the DTD and/or processing tools are not generally available, and the machinegenerated HTML produced by some word processors for output purposes only. The "Title Page" means, for a printed book, the title page itself, plus such following pages as are needed to hold, legibly, the material this License requires to appear in the title page. For works in formats which do not have any title page as such, "Title Page" means the text near the most prominent appearance of the work's title, preceding the beginning of the body of the text. 2. VERBATIM COPYING You may copy and distribute the Document in any medium, either commercially or noncommercially, provided that this License, the copyright notices, and the license notice saying this License applies to the Document are reproduced in all copies, and that you add no other conditions whatsoever to those of this License. You may not use technical measures to obstruct or control the reading or further copying of the copies you make or distribute. However, you may accept compensation in exchange for copies. If you distribute a large enough number of copies you must also follow the conditions in section 3. You may also lend copies, under the same conditions stated above, and you may publicly display copies. 3. COPYING IN QUANTITY If you publish printed copies of the Document numbering more than 100, and the Document's license notice requires Cover Texts, you must enclose the copies in covers that carry, clearly and legibly, all these Cover Texts: FrontCover Texts on the front cover, and BackCover Texts on the back cover. Both covers must also clearly and legibly identify you as the publisher of these copies. The front cover must present the full title with all words of the title equally prominent and visible. You may add other material on the covers in addition. Copying with changes limited to the covers, as long as they preserve the title of the Document and satisfy these conditions, can be treated as verbatim copying in other respects. If the required texts for either cover are too voluminous to fit legibly, you should put the first ones listed (as many as fit reasonably) on the actual cover, and continue the rest onto adjacent pages. If you publish or distribute Opaque copies of the Document numbering more than 100, you must either include a machinereadable Transparent copy along with each Opaque copy, or state in or with each Opaque copy a publiclyaccessible computernetwork location containing a complete Transparent copy of the Document, free of added material, which the general networkusing public has access to download anonymously at no charge using publicstandard network protocols. If you use the latter option, you must take reasonably prudent steps, when you begin distribution of Opaque copies in quantity, to ensure that this Transparent copy will remain thus accessible at the stated location until at least one year after the last time you distribute an Opaque copy (directly or through your agents or retailers) of that edition to the public. It is requested, but not required, that you contact the authors of the Document well before redistributing any large number of copies, to give them a chance to provide you with an updated version of the Document. 4. MODIFICATIONS You may copy and distribute a Modified Version of the Document under the conditions of sections 2 and 3 Dveloppons en Java avec Eclipse 173
above, provided that you release the Modified Version under precisely this License, with the Modified Version filling the role of the Document, thus licensing distribution and modification of the Modified Version to whoever possesses a copy of it. In addition, you must do these things in the Modified Version:
A. Use in the Title Page (and on the covers, if any) a title distinct from that of the Document, and from those of previous versions (which should, if there were any, be listed in the History section of the Document). You may use the same title as a previous version if the original publisher of that version gives permission. B. List on the Title Page, as authors, one or more persons or entities responsible for authorship of the modifications in the Modified Version, together with at least five of the principal authors of the Document (all of its principal authors, if it has less than five). C. State on the Title page the name of the publisher of the Modified Version, as the publisher. D. Preserve all the copyright notices of the Document. E. Add an appropriate copyright notice for your modifications adjacent to the other copyright notices. F. Include, immediately after the copyright notices, a license notice giving the public permission to use the Modified Version under the terms of this License, in the form shown in the Addendum below. G. Preserve in that license notice the full lists of Invariant Sections and required Cover Texts given in the Document's license notice. H. Include an unaltered copy of this License. I. Preserve the section entitled "History", and its title, and add to it an item stating at least the title, year, new authors, and publisher of the Modified Version as given on the Title Page. If there is no section entitled "History" in the Document, create one stating the title, year, authors, and publisher of the Document as given on its Title Page, then add an item describing the Modified Version as stated in the previous sentence. J. Preserve the network location, if any, given in the Document for public access to a Transparent copy of the Document, and likewise the network locations given in the Document for previous versions it was based on. These may be placed in the "History" section. You may omit a network location for a work that was published at least four years before the Document itself, or if the original publisher of the version it refers to gives permission. K. In any section entitled "Acknowledgements" or "Dedications", preserve the section's title, and preserve in the section all the substance and tone of each of the contributor acknowledgements and/or dedications given therein. L. Preserve all the Invariant Sections of the Document, unaltered in their text and in their titles. Section numbers or the equivalent are not considered part of the section titles. M. Delete any section entitled "Endorsements". Such a section may not be included in the Modified Version. N. Do not retitle any existing section as "Endorsements" or to conflict in title with any Invariant Section. If the Modified Version includes new frontmatter sections or appendices that qualify as Secondary Sections and contain no material copied from the Document, you may at your option designate some or all of these sections as invariant. To do this, add their titles to the list of Invariant Sections in the Modified Version's license notice. These titles must be distinct from any other section titles. You may add a section entitled "Endorsements", provided it contains nothing but endorsements of your Modified Version by various partiesfor example, statements of peer review or that the text has been Dveloppons en Java avec Eclipse 174
approved by an organization as the authoritative dfinition of a standard. You may add a passage of up to five words as a FrontCover Text, and a passage of up to 25 words as a BackCover Text, to the end of the list of Cover Texts in the Modified Version. Only one passage of FrontCover Text and one of BackCover Text may be added by (or through arrangements made by) any one entity. If the Document already includes a cover text for the same cover, previously added by you or by arrangement made by the same entity you are acting on behalf of, you may not add another; but you may replace the old one, on explicit permission from the previous publisher that added the old one. The author(s) and publisher(s) of the Document do not by this License give permission to use their names for publicity for or to assert or imply endorsement of any Modified Version. 5. COMBINING DOCUMENTS You may combine the Document with other documents released under this License, under the terms defined in section 4 above for modified versions, provided that you include in the combination all of the Invariant Sections of all of the original documents, unmodified, and list them all as Invariant Sections of your combined work in its license notice. The combined work need only contain one copy of this License, and multiple identical Invariant Sections may be replaced with a single copy. If there are multiple Invariant Sections with the same name but different contents, make the title of each such section unique by adding at the end of it, in parentheses, the name of the original author or publisher of that section if known, or else a unique number. Make the same adjustment to the section titles in the list of Invariant Sections in the license notice of the combined work. In the combination, you must combine any sections entitled "History" in the various original documents, forming one section entitled "History"; likewise combine any sections entitled "Acknowledgements", and any sections entitled "Dedications". You must delete all sections entitled "Endorsements." 6. COLLECTIONS OF DOCUMENTS You may make a collection consisting of the Document and other documents released under this License, and replace the individual copies of this License in the various documents with a single copy that is included in the collection, provided that you follow the rules of this License for verbatim copying of each of the documents in all other respects. You may extract a single document from such a collection, and distribute it individually under this License, provided you insert a copy of this License into the extracted document, and follow this License in all other respects regarding verbatim copying of that document. 7. AGGREGATION WITH INDEPENDENT WORKS A compilation of the Document or its derivatives with other separate and independent documents or works, in or on a volume of a storage or distribution medium, does not as a whole count as a Modified Version of the Document, provided no compilation copyright is claimed for the compilation. Such a compilation is called an "aggregate", and this License does not apply to the other selfcontained works thus compiled with the Document, on account of their being thus compiled, if they are not themselves derivative works of the Document. If the Cover Text requirement of section 3 is applicable to these copies of the Document, then if the Document is less than one quarter of the entire aggregate, the Document's Cover Texts may be placed on covers that surround only the Document within the aggregate. Otherwise they must appear on covers around the whole aggregate. 8. TRANSLATION Translation is considered a kind of modification, so you may distribute translations of the Document under the Dveloppons en Java avec Eclipse 175
terms of section 4. Replacing Invariant Sections with translations requires special permission from their copyright holders, but you may include translations of some or all Invariant Sections in addition to the original versions of these Invariant Sections. You may include a translation of this License provided that you also include the original English version of this License. In case of a disagreement between the translation and the original English version of this License, the original English version will prevail. 9. TERMINATION You may not copy, modify, sublicense, or distribute the Document except as expressly provided for under this License. Any other attempt to copy, modify, sublicense or distribute the Document is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. 10. FUTURE REVISIONS OF THIS LICENSE The Free Software Foundation may publish new, revised versions of the GNU Free Documentation License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. See http://www.gnu.org/copyleft/. Each version of the License is given a distinguishing version number. If the Document specifies that a particular numbered version of this License "or any later version" applies to it, you have the option of following the terms and conditions either of that specified version or of any later version that has been published (not as a draft) by the Free Software Foundation. If the Document does not specify a version number of this License, you may choose any version ever published (not as a draft) by the Free Software Foundation.
Annexe B : Webographie
http://www.eclipse.org/ le site officiel d'Eclipse http://www.eclipse.org/downloads/index.php la page officielle pour le tlchargement d'Eclipse http://www.eclipsetotale.com/index.html portail en franais consacr au projet Eclipse et aux outils WebSphere Studio d'IBM
http://eclipseplugins.2y.net/eclipse/index.jsp
http://eclipsewiki.swiki.net/ http://www.sysdeo.com/eclipse/tomcatPluginFR.html plugin pour utiliser Tomcat dans Eclipse http://www.eclipseworkbench.com/jsp/ portail en anglais
176
177