¡Se acabo el ‘copy-paste’!

Clone Detective for Visual Studio Screenshot El antipatrón ‘programación de corta y pega’ es un mal que aparece a menudo en muchos proyectos. Si bien es cierto que Ibon Landa logró hacer de ello un arte en nuestros tiempos en Panda Software, no todo el mundo tiene su capacidad. Los problemas que se derivan de este antipatrón son muy numerosos, sobre todo relacionados con la mantenibilidad del código. Básicamente se trata de una violación en toda regla un principio básico en el desarrollo de software, el principio DRY (Don’t repeat yourself). Las duplicidades en el código a menudo llevan a inconsistencias y son un indicador claro de que el código no se está refactorizando adecuadamente.


Si bien es cierto que todo desarrollador experimentado sabe que a la larga el copy-paste es dañino, también es cierto que es algo que todos hemos hecho en alguna ocasión y que muchos desarrolladores poco experimentados a menudo abusan del copy-paste. El problema viene de que cuando este abuso se detecta el mal ya esta hecho. Basta un desarrollador poco displicinado o poco experimentado que caiga en este error para que el proyecto sufra los problemas derivados del mismo. Having duplicates can easily lead to inconsistencies and often is an indicator for poorly factored code.


Conscientes de este problema ha nacido Clone Detective for Visual Studio, un addin perfectamente integrado en Visual Studio cuyo cometido es detectar donde se están introduciendos duplicidades en el código, bien por copy-paste o bien por errores de diseño que obligan a introducir código muy similar. De momento solo funciona para C#.


Yo de momento no lo he utilizado en ningún proyecto grande, pues estoy de vacaciones, pero puedo decir que si que lo he instalado y tiene bastante buena pinta. Si queréis ver como funciona antes de instalarlo visitad la sección de videos de la web del proyecto en Codeplex.

16 comentarios sobre “¡Se acabo el ‘copy-paste’!”

  1. «Having duplicates can easily lead to inconsistencies and often is an indicator for poorly factored code.»

    copy&translate&paste

    «Las duplicidades en el código a menudo llevan a inconsistencia y son un indicador claro de que el código no se está refactorizando adecuadamente.»

  2. Suena bien eso, como ayuda para la refactorizacion…. a ver si ayuda a solucionar el problema de darse cuenta luego de que ese «algo» hubiera estado mejor en una libreria compartida.

    Lo malo es que como de costumbre sigue pareciendo que los usuarios de Visual Basic son los «parientes pobres» en el mundo de .NET. Empezando con el hecho de que en la MSDN algunos ejemplos de metodos o propiedades solo estan en C#, o que las herramientas para SharePoint no salieron en VB…

  3. @Ernesto: Si, parece que cada vez más, C# es el lenguaje elegido… 🙁
    .Net prometia la libre elección de lenguaje… pero luego está la dura realidad.

  4. mmm …. interesante herramienta, espero ver como se comporta con un proyecto grande, porque con un «Hola Mundo» funciona de perlas !!!

    Saludos

  5. De momento solo está para VS2008 y para C#… no sé como evolucionará el proyecto, pero creo que sería ‘fácil’ añadir soporte para VB… al fin y al cabo ‘solo’ se trata de detectar duplicados… ¿no?

    El código es abierto, así que si alguno se anima a colaborar…

  6. Hay algo que me sorprendio entre los requisitios decia Java?
    La verdad que lo lei varias veces y no me creo aun… No tengo nada en contra de Java pero… 🙂

  7. Rodrigo eres un crack, vaya eso por delante, te sigo en charlas, leo los libros que recomiendas y sigo tu blog, así que espero que aceptes de buen agrado esto:

    «deribar»: los problemas o se derriban o se derivan, pero nunca se «deriban».

    Pásale un correcto a tus posts. No es admisible, por respeto a tu público, una falta de esas. 😉

    Sin acritud 🙂

Responder a anonymous Cancelar respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *