Mercurial > hgbook
view es/template.tex @ 829:18131160f7ee submitted
New IDs
author | Bryan O'Sullivan <bos@serpentine.com> |
---|---|
date | Mon, 04 May 2009 23:53:21 -0700 |
parents | 801442e58e6d |
children |
line wrap: on
line source
\chapter{Personalizar los mensajes de Mercurial} \label{chap:template} Mercurial provee un poderoso mecanismo que permite controlar como despliega la información. El mecanismo se basa en plantillas. Puede usar plantillas para generar salida específica para una orden particular o para especificar la visualización completa de la interfaz web embebida. \section{Usar estilos que vienen con Mercurial} \label{sec:style} Hay ciertos estilos listos que vienen con Mercurial. Un estilo es simplemente una plantilla predeterminada que alguien escribió e instaló en un sitio en el cual Mercurial puede encontrarla. Antes de dar un vistazo a los estilos que trae Mercurial, revisemos su salida usual. \interaction{template.simple.normal} Es en cierta medida informativa, pero ocupa mucho espacio---cinco líneas de salida por cada conjunto de cambios. El estilo \texttt{compact} lo reduce a tres líneas, presentadas de forma suscinta. \interaction{template.simple.compact} El estilo de la \texttt{bitácora de cambios} vislumbra el poder expresivo del sistema de plantillas de Mercurial. Este estilo busca seguir los estándares de bitácora de cambios del proyecto GNU\cite{web:changelog}. \interaction{template.simple.changelog} No es una sorpresa que el estilo predeterminado de Mercurial se llame \texttt{default}\ndt{predeterminado}. \subsection{Especificar un estilo predeterminado} Puede modificar el estilo de presentación que Mercurial usará para toda orden vía el fichero \hgrc\, indicando el estilo que prefiere usar. \begin{codesample2} [ui] style = compact \end{codesample2} Si escribe un estilo, puede usarlo bien sea proveyendo la ruta a su fichero de estilo o copiando su fichero de estilo a un lugar en el cual Mercurial pueda encontrarlo (típicamente el subdirectorio \texttt{templates} de su directorio de instalación de Mercurial). \section{Órdenes que soportan estilos y plantillas} Todas las órdenes de Mercurial``relacionadas con \texttt{log}'' le permiten usar estilos y plantillas: \hgcmd{incoming}, \hgcmd{log}, \hgcmd{outgoing} y \hgcmd{tip}. Al momento de la escritura del manual estas son las únicas órdenes que soportan estilos y plantillas. Dado que son las órdenes más importantes que necesitan personalización, no ha habido muchas solicitudes desde la comunidad de usuarios de Mercurial para añadir soporte de plantillas y estilos a otras órdenes. \section{Cuestiones básicas de plantillas} Una plantilla de Mercurial es sencillamente una pieza de texto. Cierta porción nunca cambia, otras partes se \emph{expanden}, o reemplazan con texto nuevo cuando es necesario. Antes de continuar, veamos de nuevo un ejemplo sencillo de la salida usual de Mercurial: \interaction{template.simple.normal} Ahora, ejecutemos la misma orden, pero usemos una plantilla para modificar su salida: \interaction{template.simple.simplest} El ejemplo anterior ilustra la plantilla más sencilla posible; es solamente una porción estática de código que se imprime una vez por cada conjunto de cambios. La opción \hgopt{log}{--template} de la orden \hgcmd{log} indica a Mercurial usar el texto dado como la plantilla cuando se imprime cada conjunto de cambios. Observe que la cadena de plantilla anterior termina con el texto ``\Verb+\n+''. Es una \emph{secuencia de control}, que le indica a Mercurial imprimira una nueva línea al final de cada objeto de la plantilla. Si omite esta nueva línea, Mercurial colocará cada pieza de salida seguida. Si desea más detalles acerca de secuencias de control, vea la sección~\ref{sec:template:escape}. Una plantilla que imprime una cadena fija de texto siempre no es muy útil; intentemos algo un poco más complejo. \interaction{template.simple.simplesub} Como puede ver, la cadena ``\Verb+{desc}+'' en la plantilla ha sido reemplazada en la salida con la descricipción de cada conjunto de cambios. Cada vez que Mercurial encuentra texto encerrado entre corchetes (``\texttt{\{}'' y ``\texttt{\}}''), intentará reemplazar los corchetes y el texto con la expansión de lo que sea está adentro. Para imprimir un corchete de forma literal, debe escaparlo, como se describe en la sección~\ref{sec:template:escape}. \section{Palabras claves más comunes en las plantillas} \label{sec:template:keyword} Puede empezar a escribir plantillas sencillas rápidamente con las palabras claves descritas a continuación: \begin{itemize} \item[\tplkword{author}] Cadena. El autor NO modificado del conjunto de cambios. \item[\tplkword{branches}] Cadena. El nombre de la rama en la cual se consignó el conjunto de cambios. Será vacía si el nombre de la rama es \texttt{default}. \item[\tplkword{date}] Información de fecha. La fecha en la cual se consignó el conjunto de cambios. \emph{No} es legible por un humano, debe pasarla por un firltro que la desplegará apropiadamente. En la sección~\ref{sec:template:filter} hay más detalles acerca de filtros. La fecha se expresa como un par de números. El primer número corresponde a una marca de tiempo UNIX UTC (segundos desde el primero de enero de 1970); la segunda es el corrimiento horario de la zona horaria del UTC en la cual se encontraba quien hizo la consignación, en segundos. \item[\tplkword{desc}] Cadena. La descripción en texto del conjunto de cambios. \item[\tplkword{files}] Lista de cadenas. Todos los ficheros modificados, adicionados o eliminados por este conjunto de cambios. \item[\tplkword{file\_adds}] Lista de cadenas. Ficheros adicionados por este conjunto de cambios. \item[\tplkword{file\_dels}] Lista de cadenas. Ficheros eliminados por este conjunto de cambios. \item[\tplkword{node}] Cadena. El hash de identificación de este conjunto de cambios como una cadena hexadecimal de 40 caracteres. \item[\tplkword{parents}] Lista de cadenas. Los ancestros del conjunto de cambios. \item[\tplkword{rev}] Entero. El número de revisión del repositorio local. \item[\tplkword{tags}] Lista de cadenas. Todas las etiquetas asociadas al conjunto de cambios. \end{itemize} Unos experimentos sencillos nos mostrarán qué esperar cuando usamos estas palabras claves; puede ver los resultados en la figura~\ref{fig:template:keywords}. \begin{figure} \interaction{template.simple.keywords} \caption{Template keywords in use} \label{fig:template:keywords} \end{figure} Como mencionamos anteriormente, la palabra clave de fecha no produce salida legible por un humano, debemos tratarla de forma especial. Esto involucra usar un \emph{filtro}, acerca de lo cual hay más en la sección~\ref{sec:template:filter}. \interaction{template.simple.datekeyword} \section{Secuencias de Control} \label{sec:template:escape} El motor de plantillas de Mercurial reconoce las secuencias de control más comunmente usadas dentro de las cadenas. Cuando ve un backslash (``\Verb+\+''), ve el caracter siguiente y sustituye los dos caracteres con un reemplazo sencillo, como se describe a continuación: \begin{itemize} \item[\Verb+\textbackslash\textbackslash+] Backslash, ``\Verb+\+'', ASCII~134. \item[\Verb+\textbackslash n+] Nueva línea, ASCII~12. \item[\Verb+\textbackslash r+] Cambio de línea, ASCII~15. \item[\Verb+\textbackslash t+] Tab, ASCII~11. \item[\Verb+\textbackslash v+] Tab Vertical, ASCII~13. \item[\Verb+\textbackslash \{+] Corchete abierto, ``\Verb+{+'', ASCII~173. \item[\Verb+\textbackslash \}+] Corchete cerrado, ``\Verb+}+'', ASCII~175. \end{itemize} Como se indicó arriba, si desea que la expansión en una plantilla contenga un caracter literal ``\Verb+\+'', ``\Verb+{+'', o ``\Verb+{+'', debe escaparlo. \section{Uso de filtros con palabras claves} \label{sec:template:filter} Algunos de los resultados de la expansión de la plantilla no son fáciles de usar de inmediato. Mercurial le permite especificar una cadena de \emph{filtros} opcionales para modificar el resultado de expandir una palabra clave. Ya ha visto el filtro usual \tplkwfilt{date}{isodate} en acción con anterioridad para hacer legible la fecha. A continuación hay una lista de los filtros de Mercurial más comunmente usados. Ciertos filtros pueden aplicarse a cualquier texto, otros pueden usarse únicamente en circunstancias específicas. El nombre de cada filtro está seguido de la indicación de dónde puede ser usado y una descripción de su efecto. \begin{itemize} \item[\tplfilter{addbreaks}] Cualquier texto. Añade una etiqueta XHTML ``\Verb+<br/>+'' antes del final de cada línea excepto en la final. Por ejemplo, ``\Verb+foo\nbar+'' se convierte en ``\Verb+foo<br/>\nbar+''. \item[\tplkwfilt{date}{age}] palabra clave \tplkword{date}. Muestra la edad de la fecha, relativa al tiempo actual. Ofrece una cadena como ``\Verb+10 minutes+''. \item[\tplfilter{basename}] Cualquier texto, pero de utilidad sobre todo en palabras claves relativas a \tplkword{ficheros}. Trata el texto como una ruta, retornando el nombre base. Por ejemplo, ``\Verb+foo/bar/baz+'', se convierte en ``\Verb+baz+''. \item[\tplkwfilt{date}{date}] \tplkword{date} palabra clave. Mostrar la fecha en un formato similar a la orden \tplkword{date} de in a similar format to the Unix, pero con la zona horaria incluída. Una cadena como ``\Verb+Mon Sep 04 15:13:13 2006 -0700+''. \item[\tplkwfilt{author}{domain}] Cualquier texto, pero de mayor utilidad para la palabra clave \tplkword{author}. Encuentra la primera cadena que luce como una dirección de correo electrónico, y extrae solamente el componente del dominio. Por ejemplo, de ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' se extrae ``\Verb+serpentine.com+''. \item[\tplkwfilt{author}{email}] Cualquier texto, pero de mayor utilidad para la palabra clave \tplkword{author}. Extrae la primera cadena que luce como una dirección de correo. Por ejemplo, de ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' extrae ``\Verb+bos@serpentine.com+''. \item[\tplfilter{escape}] Cualquier texto. Reemplaza los caracteres especiales de XML/XHTML: ``\Verb+&+'', ``\Verb+<+'' y ``\Verb+>+'' con las entidades XML. \item[\tplfilter{fill68}] Cualquier texto. Lograr que el texto ocupe las primeras 68 columnas. Es útil emplearlo antes de pasar el texto por el filtro \tplfilter{tabindent}, y queremos que aún quepa en una ventana de fuente fija y 80 columnas. \item[\tplfilter{fill76}] Cualquier texto. Lograr que el texto quepa en 76 columnas. \item[\tplfilter{firstline}] Cualquier texto. Mostrar la primera línea de texto sin saltos de línea. \item[\tplkwfilt{date}{hgdate}] \tplkword{date} palabra clave. Mostrar la fecha como un par de números legibles. Muestra una cadena como ``\Verb+1157407993 25200+''. \item[\tplkwfilt{date}{isodate}] \tplkword{date} palabra clave. Mostrar la fecha como una cadena de texto en el formato. Muestra una cadena como ``\Verb+2006-09-04 15:13:13 -0700+''. \item[\tplfilter{obfuscate}] Cualquier texto, pero de mayor utilidad para la palabra clave \tplkword{author}. Muestra el campo de texto como una secuencia de entidades XML. Esto ayuda a eliminar ciertos robots estúpidos de adquisición de correo. \item[\tplkwfilt{author}{person}] Cualquier texto, útil sobre todo para la palabra clave \tplkword{author}. Muestra el texto que hay antes de la dirección de correo electrónico. Por ejemplo, ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' mostraría ``\Verb+Bryan O'Sullivan+''. \item[\tplkwfilt{date}{rfc822date}] \tplkword{date} palabra clave. Muestra una fecha con el mismo formato que se usa en los encabezados de correo. Mostraría una cadena como ``\Verb+Mon, 04 Sep 2006 15:13:13 -0700+''. \item[\tplkwfilt{node}{short}] Hash del conjunto de cambios. Muestra la forma corta de un hash de conjunto de cambios, of a changeset hash, p.e.~una cadena hexadecimal de 12 bytes. \item[\tplkwfilt{date}{shortdate}] \tplkword{date} palabra clave. Mostrar año, mes y día de una fecha. Muestrauna cadena como ``\Verb+2006-09-04+''. \item[\tplfilter{strip}] Cualquier texto. Elimina todos los espacios en blanco al principio y al final de la cadena. \item[\tplfilter{tabindent}] Cualquier texto. Muestra el texto con todas las líneas excepto la primera que comience con el caracter tab. \item[\tplfilter{urlescape}] Cualquier texto. Escapa todos los caracteres que se consideren como ``especiales'' por los parsers de URL. Por ejemplo, \Verb+foo bar+ se convierte en \Verb+foo%20bar+. \item[\tplkwfilt{author}{user}] Cualquier texto, útil sobre todo para la palabra clave \tplkword{author}. Retorna el ``usuario'' de una dirección de correo. Por ejemplo, ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' se convierte en ``\Verb+bos+''. \end{itemize} \begin{figure} \interaction{template.simple.manyfilters} \caption{Filtros de plantilla en acción} \label{fig:template:filters} \end{figure} \begin{note} Si trata de aplicar un filtro a una porción de datos que no puede procesarse, Mercurial fallará e imprimirá una excepción de Python. Por ejemplo, el tratar de usar la salida de la palabra clave \tplkword{desc} con el filtro \tplkwfilt{date}{isodate} no resultará algo útil. \end{note} \subsection{Combinar filtros} Combinar filtros es para generar una salida en la forma como usted lo desea es muy sencillo. La cadena de filtros siguientes arman una descripción, después aseguran que cabe limpiamente en 68 columnas, y las indenta con 8~caracteres (por lo menos en sistemas tipo Unix, en los que el tab por convención se extiende en 8~caracteres). \interaction{template.simple.combine} Observe el uso de ``\Verb+\t+'' (un caracter tab) en la plantilla para forzar que la primera línea se indente; esto es necesario para lograr que la primera línea luzca indentada; es necesario debido a que \tplkword{tabindent} indenta todas las líneas \emph{excepto} la primera. Tenga en cuenta que el orden de los filtros importa. El primer filtro se aplica primero al resultado de la palabra clave; el segundo al resultado de la aplicación del primer filtro y así sucesivamente. Por ejemplo, usar \Verb+fill68|tabindent+ es muy distinto al resultado de usar \Verb+tabindent|fill68+. \section{De plantillas a estilos} Una plantilla provee una forma rápida y sencilla para dar formato a una salida. Las plantillas pueden volvers verbosas, y es útil poder darle un nombre a una plantilla. Un fichero de estilo es una plantilla con un nombre, almacenado en un fichero. Más aún, al usar un fichero de estilo se dispara el poder del motor de plantillas en un nivel imposible de alcanzar usando las opción \hgopt{log}{--template} desde la línea de órdenes. \subsection{Los ficheros de estilo más sencillos} Nuestro fichero sencillo de estilo contiene una sola línea: \interaction{template.simple.rev} Se le indica a Mercurial, ``si está imprimiendo un conjunto de cambios, use el texto de la derecha como la plantilla''. \subsection{Sintaxis de ficheros de estilo} Las reglas de sintaxis para un fichero de estilo son sencillas: \begin{itemize} \item El fichero se procesa línea por línea. \item Se ignoran el espacio en blanco circundante. \item Se omiten las líneas en blanco. \item Si una línea comienza con los caracteres ``\texttt{\#}'' o ``\texttt{;}'', la línea completa se trata como un comentario, y se omite como si fuera vacía. \item Una línea comienza con una palabra clave. Esta debe comenzar con una caracter alfabético o una raya al piso, y puede contener subsecuentemente cualquier caracter alfanumérico o una raya al piso. (En notación de expresiones regulares debe coincidir con \Verb+[A-Za-z_][A-Za-z0-9_]*+.) \item El próximo elemento debe ser un caracter ``\texttt{=}'', que puede estar precedido o seguido por una cantidad arbitraria de espacio. \item Si el resto de la línea comienza y termina con caracteres encerrados entre caracteres de comillas (bien sea sencillas o dobles), se trata como cuerpo de la plantilla. \item Si el resto de la línea \emph{no} comienza con una comilla, se trata como el nombre de un fichero; los contenidos de este fichero se leerán y se usarán como cuerpo de la plantilla. \end{itemize} \section{Ejemplos de ficheros de estilos} Para ilustrar la creación de un fichero de estilo, construiremos algunos ejemplos. En lugar de ofrecer un fichero completo de estilo y analizarlo, replicaremos el proceso usual de desarrollo de un fichero de estilo comenzando con algo muy sencillo, y avanzando por una serie de ejemplos sucesivos más completos. \subsection{Identificar equivocaciones en ficheros de estilo} Si Mercurial encuentra un problema en un fichero de estilo en el cual usted está trabajando, imprime un mensaje de error suscinto, cuando usted identifique lo que significa, resulta muy útil. \interaction{template.svnstyle.syntax.input} Tenga en cuenta que \filename{broken.style} trata de definir la palabra clave \texttt{changeset}, pero omite dar un contenido para esta. Cuando se le indica a Mercurial que use este fichero de estilo, se queja inmediatamente. \interaction{template.svnstyle.syntax.error} Este mensaje de error luce intimidante, pero no es muy difícil de seguir: \begin{itemize} \item El primer componente es la forma como Mercurial dice ``me rindo''. \begin{codesample4} \textbf{abort:} broken.style:1: parse error \end{codesample4} \item A continuación viene el nombre del fichero que contiene el error. \begin{codesample4} abort: \textbf{broken.style}:1: parse error \end{codesample4} \item Siguendo el nombre del fichero viene el número de línea en la que se encontró el error. \begin{codesample4} abort: broken.style:\textbf{1}: parse error \end{codesample4} \item Finalmente, la descripción de lo que falló. \begin{codesample4} abort: broken.style:1: \textbf{parse error} \end{codesample4} La descripción del problema no siempre es clara (como en este caso), pero aunque sea críptica, casi siempre es trivial la inspección visual de la línea en el fichero de estilo y encontrar lo que está mal. \end{itemize} \subsection{Identificar de forma única un repositorio} Si desea identificar un repositorio de Mercurial ``de forma única'' con una cadena corta como identificador, puede usar la primera revisión en el repositorio. \interaction{template.svnstyle.id} No es garantía de unicidad, pero no es útill en ciertos casos: many cases. \begin{itemize} \item No funcionará en un repositorio completamente vacío, porque un repositorio así no tiene una revisión~zero. \item Tampoco funcionará en caso (muy raro) cuando el repositorio sea una fusión de dos repositorios independientes y tiene los dos directorios por ahí. \end{itemize} Hay ciertos casos en los cuales podría colocar el identificador: \begin{itemize} \item Como una llave en la tabla de una base de datos que administra repositorios en un servidor. \item Como una parte del par \{\emph{ID~repositorio}, \emph{ID~revisión}\}. Almacene esta información de forma independiente cuando ejecute construcciones automatizadas u otras actividades, de forma que pueda ``reconstruir'' posteriormente en caso de ser necesario. \end{itemize} \subsection{Mostrando salida parecida a Subversion} Intentemos emular la salida usual que usa otro sistema de control de revisiones, Subversion. \interaction{template.svnstyle.short} Dado que la salida de Subversion es sencilla, es fácil copiar y pegar una porción de su salida en un fichero, y reemplazar el texto producido previamente por Subversion con valores base que quisiéramos ver expandidos. \interaction{template.svnstyle.template} Esta plantilla difiere en algunos detalles de la salida producida por Subversion: \begin{itemize} \item Subversion imprime una fecha ``legible'' (el ``\texttt{Wed, 27 Sep 2006}'' en el ejemplo de salida anterior) en paréntesis. El motor de plantillas de Mercurial no ofrece una forma sencilla de desplegar una fecha en este formato sin imprimir también la hora y la zona horaria. \item Emulamos las líneas de ``separación'' de subversion con caracteres ``\texttt{-}'' en una línea. Usamos la palabra clave \tplkword{header} del motor de plantillas para imprimir una línea de separación como la primera línea de salida (ver más abajo), para lograr una salida similara a la de Subversion. \item La salida de subversion incluye un conteo en el encabezado del número de líneas en el mensaje de consinación. No podemos replicarlo en Mercurial; el motor de plantilla no ofrece en la actualidad un filtro que cuente la cantidad de objetos que se le pasen. \end{itemize} No me tomó más de un minuto o dos de trabajo para reemplazar texto literal de un ejemplo de salida de la salida de Subversion con ciertas palabras claves y filtros para ofrecer la plantilla anterior. El fichero de estilo se refiere sencillamente a la plantilla. \interaction{template.svnstyle.style} Podríamos haber incluído el texto del fichero plantilla directamente en el fichero de estilo encerrando entre comillas y reemplazando las nuevas líneas con secuencias ``\verb!\n!'', pero haría muy difícil de leer el fichero de estilos. La facilidad para leer es importante cuando está decidiendo si un texto pertenece a un fichero de estilo o a un fichero de plantilla incluído en el estilo. Si el fichero de estilo luce muy grande o complicado, si inserta una pieza de texto literal, mejor colóquelo en una plantilla. %%% Local Variables: %%% mode: latex %%% TeX-master: "00book" %%% End: