Está en: | Inicio >> ISDirValidator >> Presentacion de ISDirValidator | Lunes 19 de Mayo de 2025 |
![]() | ![]() |
|
ISDirValidatorISDirValidator es una utilidad y tarea de Ant para realizar validaciones de estructuras de directorio en discos permitiendo definir que directorios y ficheros pueden y/o deben existir. La situación que pretende manejar esta utilidad es la del cumplimiento de normativas sobre el contenido de directorios y ficheros que pueden tener que cumplir los desarrolladores e implantadores de aplicativos. Un ejemplo de uso:<taskdef name="isdirectory" classname="com.inigoserrano.isdirvalidator.ISDirectory"/> <taskdef name="isfile" classname="com.inigoserrano.isdirvalidator.ISFile"/> <taskdef name="isfilepatterm" classname="com.inigoserrano.isdirvalidator.ISFilePatterm"/> <taskdef name="issubdirectorypatterm" classname="com.inigoserrano.isdirvalidator.ISSubDirectoryPatterm"/> <isdirectory dir="folder" /> <isdirectory dir="..\ISDirCheck\" recursive="yes" > <isfile file="build.xml" required="yes" /> <isfile file="Definition.txt" required="no" /> <isfilePatterm filePatterm="^[a-z]+\.txt$" /> <isfilePatterm filePatterm=".*\.xml$" /> <issubdirectoryPatterm directoryPatterm="^[a-zA-Z]+$" /> </isdirectory> La primera tarea es la forma más sencilla y comprueba que exista el directorio "folder" tomando como referencia el basedir del projecto de Ant La segunda tarea comprueba que exista el directorio "ISDirCheck" tomando como referencia el directorio padre del basedir del proyecto. Así mismo comprueba que se cumplan unas determinadas condiciones:
Cualquier fichero que se encuentre en el directorio ISDirCheck y no cumpla almenos una de las condiciones se considerará un error. El hecho de incluir al attributo recursive, implica que tambien se comprobaran con las mismas condicionies los subdirectorios que cuelgan de este. Por ejemplo si existen los ficheros:
Si no existe el fichero "build.xml" tambien se considerará un error. Para las expresiones regulares se utiliza el paquete regExp en su version 1.2 de http://jakarta.apache.org. Se puede consultar la documentacion de este paquete para conocer las diferentes posibilidades a la hora de construir la expresion regular. Un ejemplo de uso puede ser la definición de la estructura de un WAR de Java (Este ejemplo no está completo, debe ajustarse a las necesidades concretas). <isdirectory dir="${path}"> <isfilePatterm filePatterm="^[a-zA-Z]+\.jsp$" /> <isfilePatterm filePatterm="^[a-zA-Z]+\.html$" /> </isdirectory> <isdirectory dir="${path}/META-INF"> <isfile file="MANIFEST.MF" required="yes" /> </isdirectory> <isdirectory dir="${path}/WEB-INF"> <isfile file="web.xml" required="yes" /> <isfilePatterm filePatterm="^[a-zA-Z-]+\.tld$" /> </isdirectory> <isdirectory dir="${path}/WEB-INF/classes" recursive="yes" > <isfilePatterm filePatterm="^[:alnum:]+\.properties$" /> <isfilePatterm filePatterm="^[:alnum:]+\.class$" /> <issubdirectoryPatterm directoryPatterm="^[a-zA-Z]+$" /> </isdirectory> Versión 2La versión 2 del paquete ISDirValidator incorpora algunas mejoras sobre la versión 1, como el soporte de la recursividad, la comprobación de los subdirectorios, asi como una serie de pequeñas correcciones de errores y adaptacionies a la herramieta Ant (substitución de los valores Y en los attributos required y recursive por los estandares de Ant que son: yes, true y on) InstalaciónPara instalar esta herramienta debe tener en su CLASSPATH el paquete IsDirValidator y el regExp DownloadPuede descargar ISDirValidator en la página general de Download |
|