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

Outils Discussion :

Détecter du code mort


Sujet :

Outils

  1. #1
    Membre éclairé

    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    467
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 467
    Par défaut Détecter du code mort
    Bonjour,

    Je reprends la gestion d'un site avec quelques bouts d'application javacript.
    L'outil a quelques années, basé à l'époque sur ce que je pense être un template.
    J'ai beaucoup de code inutile, qui charge l'application pour rien.
    J'aimerai essayer d'automatiser un peu cette détection, comme cela se fait avec des outils comme lui https://unused-css.com qui parse les pages à la recherche de CSS inutilisées.

    Connaissez vous de tels outils ?

    Merci.

  2. #2
    Expert confirmé
    Avatar de Marco46
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    4 419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 4 419
    Par défaut
    Quel type de modules utilises-tu ? IIFE ? CommonJS ? AMD ? Modules ES6 ?

    Si tu n'utilises pas de modules ou si tu utilises les ersatz de modules sous forme de IIFE ça va être compliqué.

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2018
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2018
    Messages : 41
    Par défaut rollup et tree shaking
    tu pourrais utiliser rollup + buble pour préparer tes bundles. C'est plus rapide que WebPack + Babel, plus simple aussi.

    Et pour ce qui se rapporte à ta question,, Rollup fait du "tree shaking" : c'est à dire qu'au moment de la compilation, l'arbre des syntaxe abstrait du programme est "secoué" pour ne garder que ce qui sera effectivement gardé dans l'exécutable final.

    Rollup gère bien les modules UMD et IIFE et supporte les variables globales assez bien.

    Pour ce qui est du nettoyage du code à proprement parler... à part un examen minutieux (et automatique) du code résultat du bundle, pour détecter tous lles "function X()" et les "var Y = function()" du code afin d'établir la liste X + Y de ce qui sert vraiment à la fin... et dégraisser manuellement lors de vastes opérations de refactoring !!!

    Bon courage !

  4. #4
    Expert confirmé
    Avatar de Watilin
    Homme Profil pro
    En recherche d'emploi
    Inscrit en
    Juin 2010
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Juin 2010
    Messages : 3 094
    Par défaut
    La question laisse quelques zones d’ombre. S’il s’agit de code au sein d’un fichier donné, par exemple du code PHP, on peut recourir à des outils d’analyse de flot de contrôle (en anglais CFG pour Control Flow Graph), j’ai trouvé par exemple php-cfg. Il y a aussi cette question StackOverflow qui a une réponse intéressante et détaillée.

    S’il s’agit de trouver les routes ou pages qui ne sont plus utilisées, wget a une fonction « aspirateur de site » qui peut (plus ou moins bien) cartographier un site, à la manière des robots de moteurs de recherche. Ensuite, il ne doit pas être difficile de bricoler un script avec find ou grep pour déterminer les routes / pages qui n’ont pas été atteintes.
    La FAQ JavaScript – Les cours JavaScript
    Touche F12 = la console → l’outil indispensable pour développer en JavaScript !

  5. #5
    Membre Expert
    Avatar de Doksuri
    Profil pro
    Développeur Web
    Inscrit en
    Juin 2006
    Messages
    2 494
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 494
    Par défaut
    avec chrome (je ne sais pas pour firefox) tu as l'onglet "coverage"
    qui, pour le CSS et le JS t'indique tout le code utilise du code non-utilise.

    => seul bemole : ca ne conserne que la page consultee. (du CSS ou du JS peut n'etre utilise que dans des pages et des cas specifiques)
    La forme des pyramides prouve que l'Homme a toujours tendance a en faire de moins en moins.

    Venez discuter sur le Chat de Développez !

Discussions similaires

  1. Détecter du code mort
    Par v4np13 dans le forum EDI et Outils pour Java
    Réponses: 11
    Dernier message: 23/08/2018, 11h54
  2. Réponses: 3
    Dernier message: 23/12/2008, 22h34
  3. Outils de détection de code mort
    Par maloups dans le forum JSF
    Réponses: 7
    Dernier message: 18/09/2007, 17h23
  4. Détection de code mort
    Par maloups dans le forum Eclipse Java
    Réponses: 0
    Dernier message: 18/09/2007, 17h18
  5. [Outil] Détecter le code inutilisé d'une webapp
    Par vallica dans le forum Développement Web en Java
    Réponses: 9
    Dernier message: 17/05/2006, 15h30

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