IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Eclipse Java Discussion :

Expressions régulières pour rechercher dans le code


Sujet :

Eclipse Java

  1. #1
    Membre habitué Avatar de Davboc
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    266
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Novembre 2005
    Messages : 266
    Points : 168
    Points
    168
    Par défaut Expressions régulières pour rechercher dans le code
    Bonjour

    J'ai vu que dans l'utilitaire de recherche dans le code (find, ctrl+f) on peut utiliser des expressions régulières.

    J'ai approfondi un peu la chose et je suis tombé sur le détail des regexp qu'on peut utiliser :
    http://www.eclipse.org/tptp/monitori...f/rregexp.html

    Mais je n'arrive toujours pas à faire ce que je veux (faut dire que c'est un peu complexe ^^) :

    Je cherche à écrire une regexp me permettant de trouver dans mon code les catch(SQLException xx) qui n'ont pas de finally associé, afin de chasser les connexions pas fermées...

    J'ai créé ce petit fichier pour tester les regexp :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    /******************SQLException AVEC FINALLY**********************/	
    try {
    			conn = ds.getConnection();
    			ArrayList listeLien = new ArrayList();
    			/***/
    			switch (actionRecue) {
    				case Actions.ANNULER:
    					return JSPName.INDEX;
     
    				case Actions.DOWNLOAD:
    					List desLiens = (List) sm.getAttribute(LISTE_LIEN);
    					Fichier unFic = (Fichier) desLiens.get(Integer.parseInt(req.getParameter("NOFIC")));
    					break;
    				default:
    					break;
    			}
    		} catch (SQLException e1) {
    			e1.printStackTrace();
    		} finally {
    			ConnectionUtil.fermetureConnectionSimple(conn, null, null, null);
    		}
     
     
    /******************SQLException SANS FINALLY**********************/	
    try {
    			conn = ds.getConnection();
    			ArrayList listeLien = new ArrayList();
    			/***/
     
    			}
    		} catch (SQLException e1) {
    			e1.printStackTrace();
    J'ai testé des tonnes de solutions, sans succès. La dernière tentative a donné l'expression suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (?s)catch\s*\(SQLException.*\}.*(?!(finally)){0}.\s\{
    (?s) me permet d'ignorer les sauts à la ligne, d'après ce que j'ai compris (?!(finally)) désigne l'absence du mot 'finally'.

    Quand je ne met rien après ce (?!(finally)) ça me sélectionne tout depuis le catch jusque la fin de la page. J'aimerais que cette selection s'arrête a l'endroit ou je suis supposé trouver un finally, c'est à dire après le premier '}' trouvé...

    Si quelqu'un sait comment s'y prendre j'apprécierais vraiment un ptit coup de pouce

    Merci !

  2. #2
    Rédacteur
    Avatar de CyberChouan
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    2 752
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 752
    Points : 4 314
    Points
    4 314
    Par défaut
    Petite précision sur les expressions régulières: si tu ne précises rien, elles attrapent les groupes les plus grands possibles.

    Si tu cherches "{.*}" (pour un replaceAll par exemple) dans la chaîne "{a} {b}", elle ne trouvera qu'un seul groupe où .* vaut "a} {b".

    Pour palier à ce problème, il faut chercher "{.*?}". Cela t'aidera sans doute à ne pas attraper de groupes trop gros entre tes crochets

    Cependant, dans ton cas, je ne suis pas certain que ça soit faisable par une simple expression régulière... Imagine le code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    try {
       // ...
    } catch (SQLException e) {
       if(debugMode) { ecrireMsgDebug(); }
       else { faireAutreChose(); }
    } finally {
       fermerLaConnexionDansTousLesCas();
    }
    Tu as des blocs imbriqués dans ton "catch" qui risquent fort de tromper ton expression. Si tu veux vraiment traiter tous les cas, tu dois faire plus compliqué qu'une simple expression régulière: à partir du catch, il faut compter les crochets pour trouver celui qui va fermer le catch et vérifier que le mot-clé qui suit ce dernier crochet est bien un "finally".

    Bon courage
    Avant de poster, pensez à regarder la FAQ, les tutoriaux, la Javadoc (de la JRE que vous utilisez) et à faire une recherche
    Je ne réponds pas aux questions techniques par MP: les forums sont faits pour ça
    Mes articles et tutoriaux & Mon blog informatique

  3. #3
    Membre confirmé

    Homme Profil pro
    Consultant en technologies
    Inscrit en
    Juin 2004
    Messages
    332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en technologies

    Informations forums :
    Inscription : Juin 2004
    Messages : 332
    Points : 556
    Points
    556
    Par défaut
    Peut-etre tout simplement regarder du côté d'outils d'analyse statique de code (type CheckStyle ou Findbugs) ; pour détecter tous les catch sans finally ? A moins d'avoir des milliers de fichiers (ce qui est peut-être ton cas ) ; ça me paraît pas la mort de faire next, next, next, ... pour parcourir tous les bouts de code sans finally

  4. #4
    Membre habitué Avatar de Davboc
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    266
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Novembre 2005
    Messages : 266
    Points : 168
    Points
    168
    Par défaut
    Merci pour vos coups de main

    J'ai pas pensé à utiliser l'outil d'analyse de code, c'est vrai que ça pourrait être une solution Il n'y a pas des milliers de fichiers (enfin je pense pas), mais il y en a quand même quelques-uns..

    Je vous tiens au courant de l'avancée de ma problématique

  5. #5
    Membre actif Avatar de tnodev
    Profil pro
    SSSSS
    Inscrit en
    Mai 2005
    Messages
    182
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : SSSSS

    Informations forums :
    Inscription : Mai 2005
    Messages : 182
    Points : 231
    Points
    231
    Par défaut
    Salut

    J'utilise QuickRex, un plugin eclipse gratuit très pratique pour tester les expressions régulières

    http://www.bastian-bergerhoff.com/ec...ckREx/toc.html

Discussions similaires

  1. generateur de code java pour rechercher dans une base de donnees
    Par cdubet dans le forum EDI et Outils pour Java
    Réponses: 5
    Dernier message: 18/02/2017, 10h10
  2. Expression régulière pour redirection dans .htaccess
    Par Persilou dans le forum Apache
    Réponses: 6
    Dernier message: 29/12/2009, 16h04
  3. Réponses: 4
    Dernier message: 21/10/2009, 10h17
  4. Réponses: 4
    Dernier message: 14/11/2008, 21h00
  5. Expressions régulières pour filtrer du code HTML
    Par Junta dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 14/11/2006, 17h00

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo