hgbook

annotate es/template.tex @ 930:71e726b7f70d

Hum, i don't think that Fink on mac is actually apt-get :)
author Romain PELISSE <romain.pelisse@atosorigin.com>
date Sun Feb 08 22:08:47 2009 +0100 (2009-02-08)
parents bbc5db74bd77
children
rev   line source
igor@470 1 \chapter{Personalizar los mensajes de Mercurial}
igor@402 2 \label{chap:template}
igor@402 3
igor@470 4 Mercurial provee un poderoso mecanismo que permite controlar como
igor@470 5 despliega la información. El mecanismo se basa en plantillas. Puede
igor@470 6 usar plantillas para generar salida específica para una orden
igor@470 7 particular o para especificar la visualización completa de la interfaz
igor@470 8 web embebida.
igor@470 9
igor@470 10 \section{Usar estilos que vienen con Mercurial}
igor@402 11 \label{sec:style}
igor@402 12
igor@470 13 Hay ciertos estilos listos que vienen con Mercurial. Un estilo es
igor@470 14 simplemente una plantilla predeterminada que alguien escribió e
igor@470 15 instaló en un sitio en el cual Mercurial puede encontrarla.
igor@470 16
igor@470 17 Antes de dar un vistazo a los estilos que trae Mercurial, revisemos su
igor@470 18 salida usual.
igor@402 19
igor@402 20 \interaction{template.simple.normal}
igor@402 21
igor@470 22 Es en cierta medida informativa, pero ocupa mucho espacio---cinco
igor@470 23 líneas de salida por cada conjunto de cambios. El estilo
igor@470 24 \texttt{compact} lo reduce a tres líneas, presentadas de forma
igor@470 25 suscinta.
igor@402 26
igor@402 27 \interaction{template.simple.compact}
igor@402 28
igor@470 29 El estilo de la \texttt{bitácora de cambios} vislumbra el poder
igor@470 30 expresivo del sistema de plantillas de Mercurial. Este estilo busca
igor@470 31 seguir los estándares de bitácora de cambios del proyecto
igor@470 32 GNU\cite{web:changelog}.
igor@402 33
igor@402 34 \interaction{template.simple.changelog}
igor@402 35
igor@470 36 No es una sorpresa que el estilo predeterminado de Mercurial se llame
igor@470 37 \texttt{default}\ndt{predeterminado}.
igor@470 38
igor@470 39 \subsection{Especificar un estilo predeterminado}
igor@470 40
igor@470 41 Puede modificar el estilo de presentación que Mercurial usará para
igor@470 42 toda orden vía el fichero \hgrc\, indicando el estilo que prefiere
igor@470 43 usar.
igor@402 44
igor@402 45 \begin{codesample2}
igor@402 46 [ui]
igor@402 47 style = compact
igor@402 48 \end{codesample2}
igor@402 49
igor@470 50 Si escribe un estilo, puede usarlo bien sea proveyendo la ruta a su
igor@470 51 fichero de estilo o copiando su fichero de estilo a un lugar en el
jerojasro@520 52 cual Mercurial pueda encontrarlo (típicamente el subdirectorio
igor@470 53 \texttt{templates} de su directorio de instalación de Mercurial).
igor@470 54
igor@470 55 \section{Órdenes que soportan estilos y plantillas}
igor@470 56
igor@470 57 Todas las órdenes de Mercurial``relacionadas con \texttt{log}'' le
igor@470 58 permiten usar estilos y plantillas: \hgcmd{incoming}, \hgcmd{log},
igor@470 59 \hgcmd{outgoing} y \hgcmd{tip}.
igor@470 60
igor@470 61 Al momento de la escritura del manual estas son las únicas órdenes que
igor@470 62 soportan estilos y plantillas. Dado que son las órdenes más
igor@470 63 importantes que necesitan personalización, no ha habido muchas
igor@470 64 solicitudes desde la comunidad de usuarios de Mercurial para añadir
igor@470 65 soporte de plantillas y estilos a otras órdenes.
igor@470 66
igor@470 67 \section{Cuestiones básicas de plantillas}
igor@470 68
igor@470 69 Una plantilla de Mercurial es sencillamente una pieza de texto.
igor@470 70 Cierta porción nunca cambia, otras partes se \emph{expanden}, o
igor@470 71 reemplazan con texto nuevo cuando es necesario.
igor@470 72
igor@470 73 Antes de continuar, veamos de nuevo un ejemplo sencillo de la salida
igor@470 74 usual de Mercurial:
igor@402 75
igor@402 76 \interaction{template.simple.normal}
igor@402 77
igor@470 78 Ahora, ejecutemos la misma orden, pero usemos una plantilla para
igor@470 79 modificar su salida:
igor@402 80
igor@402 81 \interaction{template.simple.simplest}
igor@402 82
igor@470 83 El ejemplo anterior ilustra la plantilla más sencilla posible; es
igor@470 84 solamente una porción estática de código que se imprime una vez por
igor@470 85 cada conjunto de cambios. La opción \hgopt{log}{--template} de la
igor@470 86 orden \hgcmd{log} indica a Mercurial usar el texto dado como la
igor@470 87 plantilla cuando se imprime cada conjunto de cambios.
igor@470 88
igor@470 89 Observe que la cadena de plantilla anterior termina con el texto
igor@470 90 ``\Verb+\n+''. Es una \emph{secuencia de control}, que le indica a
igor@470 91 Mercurial imprimira una nueva línea al final de cada objeto de la
igor@470 92 plantilla. Si omite esta nueva línea, Mercurial colocará cada pieza
igor@470 93 de salida seguida. Si desea más detalles acerca de secuencias de
igor@470 94 control, vea la sección~\ref{sec:template:escape}.
igor@470 95
igor@470 96 Una plantilla que imprime una cadena fija de texto siempre no es muy
igor@470 97 útil; intentemos algo un poco más complejo.
igor@402 98
igor@402 99 \interaction{template.simple.simplesub}
igor@402 100
igor@470 101 Como puede ver, la cadena ``\Verb+{desc}+'' en la plantilla ha sido
igor@470 102 reemplazada en la salida con la descricipción de cada conjunto de
igor@470 103 cambios. Cada vez que Mercurial encuentra texto encerrado entre
jerojasro@520 104 corchetes (``\texttt{\{}'' y ``\texttt{\}}''), intentará reemplazar los
igor@470 105 corchetes y el texto con la expansión de lo que sea está adentro.
igor@470 106 Para imprimir un corchete de forma literal, debe escaparlo, como se
igor@470 107 describe en la sección~\ref{sec:template:escape}.
igor@470 108
igor@470 109 \section{Palabras claves más comunes en las plantillas}
igor@402 110 \label{sec:template:keyword}
igor@402 111
igor@470 112 Puede empezar a escribir plantillas sencillas rápidamente con las
igor@470 113 palabras claves descritas a continuación:
igor@470 114
igor@470 115 \begin{itemize}
igor@470 116 \item[\tplkword{author}] Cadena. El autor NO modificado del conjunto
igor@470 117 de cambios.
igor@470 118 \item[\tplkword{branches}] Cadena. El nombre de la rama en la cual se
igor@470 119 consignó el conjunto de cambios. Será vacía si el nombre de la rama es
igor@402 120 \texttt{default}.
igor@470 121 \item[\tplkword{date}] Información de fecha. La fecha en la cual se
igor@470 122 consignó el conjunto de cambios. \emph{No} es legible por un
igor@470 123 humano, debe pasarla por un firltro que la desplegará
igor@470 124 apropiadamente. En la sección~\ref{sec:template:filter} hay más
igor@470 125 detalles acerca de filtros. La fecha se expresa como un par de
igor@470 126 números. El primer número corresponde a una marca de tiempo UNIX
jerojasro@520 127 UTC (segundos desde el primero de enero de 1970); la segunda es el
igor@470 128 corrimiento horario de la zona horaria del UTC en la cual se encontraba
igor@470 129 quien hizo la consignación, en segundos.
igor@470 130 \item[\tplkword{desc}] Cadena. La descripción en texto del conjunto
igor@470 131 de cambios.
igor@470 132 \item[\tplkword{files}] Lista de cadenas. Todos los ficheros
igor@470 133 modificados, adicionados o eliminados por este conjunto de cambios.
igor@470 134 \item[\tplkword{file\_adds}] Lista de cadenas. Ficheros adicionados
igor@470 135 por este conjunto de cambios.
igor@470 136 \item[\tplkword{file\_dels}] Lista de cadenas. Ficheros eliminados
igor@470 137 por este conjunto de cambios.
igor@470 138 \item[\tplkword{node}] Cadena. El hash de identificación de este
igor@470 139 conjunto de cambios como una cadena hexadecimal de 40 caracteres.
igor@470 140 \item[\tplkword{parents}] Lista de cadenas. Los ancestros del
igor@470 141 conjunto de cambios.
igor@470 142 \item[\tplkword{rev}] Entero. El número de revisión del repositorio
igor@470 143 local.
igor@470 144 \item[\tplkword{tags}] Lista de cadenas. Todas las etiquetas
igor@470 145 asociadas al conjunto de cambios.
igor@470 146 \end{itemize}
igor@470 147
igor@470 148 Unos experimentos sencillos nos mostrarán qué esperar cuando usamos
igor@470 149 estas palabras claves; puede ver los resultados en la
igor@470 150 figura~\ref{fig:template:keywords}.
igor@402 151
igor@402 152 \begin{figure}
igor@402 153 \interaction{template.simple.keywords}
igor@402 154 \caption{Template keywords in use}
igor@402 155 \label{fig:template:keywords}
igor@402 156 \end{figure}
igor@402 157
igor@470 158 Como mencionamos anteriormente, la palabra clave de fecha no produce
igor@470 159 salida legible por un humano, debemos tratarla de forma especial.
igor@470 160 Esto involucra usar un \emph{filtro}, acerca de lo cual hay más en la
igor@470 161 sección~\ref{sec:template:filter}.
igor@402 162
igor@402 163 \interaction{template.simple.datekeyword}
igor@402 164
igor@470 165 \section{Secuencias de Control}
igor@402 166 \label{sec:template:escape}
igor@402 167
igor@470 168 El motor de plantillas de Mercurial reconoce las secuencias de control
igor@470 169 más comunmente usadas dentro de las cadenas. Cuando ve un backslash
igor@470 170 (``\Verb+\+''), ve el caracter siguiente y sustituye los dos
igor@470 171 caracteres con un reemplazo sencillo, como se describe a continuación:
igor@402 172
igor@402 173 \begin{itemize}
igor@402 174 \item[\Verb+\textbackslash\textbackslash+] Backslash, ``\Verb+\+'',
igor@402 175 ASCII~134.
igor@470 176 \item[\Verb+\textbackslash n+] Nueva línea, ASCII~12.
igor@470 177 \item[\Verb+\textbackslash r+] Cambio de línea, ASCII~15.
igor@402 178 \item[\Verb+\textbackslash t+] Tab, ASCII~11.
igor@470 179 \item[\Verb+\textbackslash v+] Tab Vertical, ASCII~13.
igor@470 180 \item[\Verb+\textbackslash \{+] Corchete abierto, ``\Verb+{+'', ASCII~173.
igor@470 181 \item[\Verb+\textbackslash \}+] Corchete cerrado, ``\Verb+}+'', ASCII~175.
igor@470 182 \end{itemize}
igor@470 183
igor@470 184 Como se indicó arriba, si desea que la expansión en una plantilla
igor@470 185 contenga un caracter literal ``\Verb+\+'', ``\Verb+{+'', o
igor@470 186 ``\Verb+{+'', debe escaparlo.
igor@470 187
igor@470 188 \section{Uso de filtros con palabras claves}
igor@402 189 \label{sec:template:filter}
igor@402 190
igor@470 191 Algunos de los resultados de la expansión de la plantilla no son
igor@470 192 fáciles de usar de inmediato. Mercurial le permite especificar una
igor@470 193 cadena de \emph{filtros} opcionales para modificar el resultado de
igor@470 194 expandir una palabra clave. Ya ha visto el filtro usual
igor@470 195 \tplkwfilt{date}{isodate} en acción con anterioridad para hacer
igor@470 196 legible la fecha.
igor@470 197
igor@470 198 A continuación hay una lista de los filtros de Mercurial más
igor@470 199 comunmente usados. Ciertos filtros pueden aplicarse a cualquier
igor@470 200 texto, otros pueden usarse únicamente en circunstancias específicas.
igor@470 201 El nombre de cada filtro está seguido de la indicación de dónde puede
igor@470 202 ser usado y una descripción de su efecto.
igor@470 203
igor@470 204 \begin{itemize}
igor@470 205 \item[\tplfilter{addbreaks}] Cualquier texto. Añade una etiqueta XHTML
igor@470 206 ``\Verb+<br/>+'' antes del final de cada línea excepto en la final.
igor@470 207 Por ejemplo, ``\Verb+foo\nbar+'' se convierte en ``\Verb+foo<br/>\nbar+''.
igor@470 208 \item[\tplkwfilt{date}{age}] palabra clave \tplkword{date}. Muestra
igor@470 209 la edad de la fecha, relativa al tiempo actual. Ofrece una cadena como
igor@402 210 ``\Verb+10 minutes+''.
igor@470 211 \item[\tplfilter{basename}] Cualquier texto, pero de utilidad sobre
igor@470 212 todo en palabras claves relativas a \tplkword{ficheros}. Trata el
igor@470 213 texto como una ruta, retornando el nombre base. Por ejemplo,
igor@470 214 ``\Verb+foo/bar/baz+'', se convierte en ``\Verb+baz+''.
igor@473 215 \item[\tplkwfilt{date}{date}] \tplkword{date} palabra clave. Mostrar
igor@473 216 la fecha en un formato similar a la orden \tplkword{date} de
igor@473 217 in a similar format to the Unix, pero con la zona horaria incluída.
igor@473 218 Una cadena como ``\Verb+Mon Sep 04 15:13:13 2006 -0700+''.
igor@473 219 \item[\tplkwfilt{author}{domain}] Cualquier texto, pero de mayor
igor@473 220 utilidad para la palabra clave \tplkword{author}. Encuentra la
igor@473 221 primera cadena que luce como una dirección de correo electrónico, y
igor@473 222 extrae solamente el componente del dominio. Por ejemplo, de
igor@473 223 ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' se extrae
igor@402 224 ``\Verb+serpentine.com+''.
igor@473 225 \item[\tplkwfilt{author}{email}] Cualquier texto, pero de mayor
igor@473 226 utilidad para la palabra clave \tplkword{author}. Extrae la primera
igor@473 227 cadena que luce como una dirección de correo. Por ejemplo, de
igor@473 228 ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' extrae
igor@402 229 ``\Verb+bos@serpentine.com+''.
igor@473 230 \item[\tplfilter{escape}] Cualquier texto. Reemplaza los caracteres
igor@473 231 especiales de XML/XHTML: ``\Verb+&+'', ``\Verb+<+'' y ``\Verb+>+''
igor@473 232 con las entidades XML.
jerojasro@525 233 \item[\tplfilter{fill68}] Cualquier texto. Lograr que el texto ocupe
igor@473 234 las primeras 68 columnas. Es útil emplearlo antes de pasar el texto
igor@473 235 por el filtro \tplfilter{tabindent}, y queremos que aún quepa en una
igor@473 236 ventana de fuente fija y 80 columnas.
igor@473 237 \item[\tplfilter{fill76}] Cualquier texto. Lograr que el texto quepa
igor@473 238 en 76 columnas.
igor@473 239 \item[\tplfilter{firstline}] Cualquier texto. Mostrar la primera
igor@473 240 línea de texto sin saltos de línea.
igor@473 241 \item[\tplkwfilt{date}{hgdate}] \tplkword{date} palabra clave.
igor@473 242 Mostrar la fecha como un par de números legibles. Muestra una
igor@473 243 cadena como ``\Verb+1157407993 25200+''.
igor@473 244 \item[\tplkwfilt{date}{isodate}] \tplkword{date} palabra clave.
igor@473 245 Mostrar la fecha como una cadena de texto en el formato. Muestra
igor@473 246 una cadena como ``\Verb+2006-09-04 15:13:13 -0700+''.
igor@473 247 \item[\tplfilter{obfuscate}] Cualquier texto, pero de mayor utilidad
igor@473 248 para la palabra clave \tplkword{author}. Muestra el campo de texto
igor@473 249 como una secuencia de entidades XML. Esto ayuda a eliminar ciertos
igor@473 250 robots estúpidos de adquisición de correo.
igor@473 251 \item[\tplkwfilt{author}{person}] Cualquier texto, útil sobre todo
igor@473 252 para la palabra clave \tplkword{author}. Muestra el texto que hay
igor@473 253 antes de la dirección de correo electrónico. Por ejemplo,
igor@473 254 ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' mostraría
igor@473 255 ``\Verb+Bryan O'Sullivan+''.
igor@473 256 \item[\tplkwfilt{date}{rfc822date}] \tplkword{date} palabra clave.
igor@473 257 Muestra una fecha con el mismo formato que se usa en los encabezados
igor@473 258 de correo. Mostraría una cadena como
igor@473 259 ``\Verb+Mon, 04 Sep 2006 15:13:13 -0700+''.
igor@473 260 \item[\tplkwfilt{node}{short}] Hash del conjunto de cambios. Muestra
igor@473 261 la forma corta de un hash de conjunto de cambios,
igor@473 262 of a changeset hash, p.e.~una cadena hexadecimal de 12 bytes.
igor@473 263 \item[\tplkwfilt{date}{shortdate}] \tplkword{date} palabra clave.
igor@473 264 Mostrar año, mes y día de una fecha. Muestrauna cadena como
igor@402 265 ``\Verb+2006-09-04+''.
igor@473 266 \item[\tplfilter{strip}] Cualquier texto. Elimina todos los espacios
igor@473 267 en blanco al principio y al final de la cadena.
igor@473 268 \item[\tplfilter{tabindent}] Cualquier texto. Muestra el texto con
igor@473 269 todas las líneas excepto la primera que comience con el caracter tab.
igor@473 270 \item[\tplfilter{urlescape}] Cualquier texto. Escapa todos los
igor@473 271 caracteres que se consideren como ``especiales'' por los parsers de
igor@473 272 URL. Por ejemplo, \Verb+foo bar+ se convierte en \Verb+foo%20bar+.
igor@473 273 \item[\tplkwfilt{author}{user}] Cualquier texto, útil sobre todo para
igor@473 274 la palabra clave \tplkword{author}. Retorna el ``usuario'' de una
igor@473 275 dirección de correo. Por ejemplo,
igor@473 276 ``\Verb+Bryan O'Sullivan <bos@serpentine.com>+'' se convierte en
igor@402 277 ``\Verb+bos+''.
igor@402 278 \end{itemize}
igor@402 279
igor@402 280 \begin{figure}
igor@402 281 \interaction{template.simple.manyfilters}
igor@473 282 \caption{Filtros de plantilla en acción}
igor@402 283 \label{fig:template:filters}
igor@402 284 \end{figure}
igor@402 285
igor@402 286 \begin{note}
igor@473 287 Si trata de aplicar un filtro a una porción de datos que no puede
igor@473 288 procesarse, Mercurial fallará e imprimirá una excepción de Python.
igor@473 289 Por ejemplo, el tratar de usar la salida de la palabra clave
igor@473 290 \tplkword{desc} con el filtro \tplkwfilt{date}{isodate} no resultará
igor@473 291 algo útil.
igor@402 292 \end{note}
igor@402 293
igor@473 294 \subsection{Combinar filtros}
igor@473 295
igor@473 296 Combinar filtros es para generar una salida en la forma como usted lo
igor@473 297 desea es muy sencillo. La cadena de filtros siguientes arman una
igor@473 298 descripción, después aseguran que cabe limpiamente en 68 columnas, y
igor@473 299 las indenta con 8~caracteres (por lo menos en sistemas tipo Unix, en
igor@473 300 los que el tab por convención se extiende en 8~caracteres).
igor@402 301
igor@402 302 \interaction{template.simple.combine}
igor@402 303
igor@473 304 Observe el uso de ``\Verb+\t+'' (un caracter tab) en la plantilla para
igor@473 305 forzar que la primera línea se indente; esto es necesario para lograr
igor@473 306 que la primera línea luzca indentada; es necesario debido a que
igor@473 307 \tplkword{tabindent} indenta todas las líneas \emph{excepto} la primera.
igor@473 308
igor@473 309 Tenga en cuenta que el orden de los filtros importa. El primer filtro
igor@473 310 se aplica primero al resultado de la palabra clave; el segundo al
igor@473 311 resultado de la aplicación del primer filtro y así sucesivamente. Por
igor@473 312 ejemplo, usar \Verb+fill68|tabindent+ es muy distinto al resultado de
igor@473 313 usar \Verb+tabindent|fill68+.
igor@473 314
igor@473 315
igor@473 316 \section{De plantillas a estilos}
igor@473 317
igor@473 318 Una plantilla provee una forma rápida y sencilla para dar formato a
igor@473 319 una salida. Las plantillas pueden volvers verbosas, y es útil poder
igor@473 320 darle un nombre a una plantilla. Un fichero de estilo es una
igor@473 321 plantilla con un nombre, almacenado en un fichero.
igor@473 322
igor@473 323 Más aún, al usar un fichero de estilo se dispara el poder del motor de
igor@473 324 plantillas en un nivel imposible de alcanzar usando las opción
igor@473 325 \hgopt{log}{--template} desde la línea de órdenes.
igor@473 326
igor@473 327
igor@473 328 \subsection{Los ficheros de estilo más sencillos}
igor@473 329
igor@473 330 Nuestro fichero sencillo de estilo contiene una sola línea:
igor@402 331
igor@402 332 \interaction{template.simple.rev}
igor@402 333
igor@473 334 Se le indica a Mercurial, ``si está imprimiendo un conjunto de
igor@473 335 cambios, use el texto de la derecha como la plantilla''.
igor@473 336
igor@473 337 \subsection{Sintaxis de ficheros de estilo}
igor@473 338
igor@473 339 Las reglas de sintaxis para un fichero de estilo son sencillas:
igor@473 340
igor@473 341 \begin{itemize}
igor@473 342 \item El fichero se procesa línea por línea.
igor@473 343
igor@473 344 \item Se ignoran el espacio en blanco circundante.
igor@473 345
igor@473 346 \item Se omiten las líneas en blanco.
igor@473 347
igor@473 348 \item Si una línea comienza con los caracteres ``\texttt{\#}'' o
igor@473 349 ``\texttt{;}'', la línea completa se trata como un comentario, y se
igor@473 350 omite como si fuera vacía.
igor@473 351
igor@473 352 \item Una línea comienza con una palabra clave. Esta debe comenzar
igor@473 353 con una caracter alfabético o una raya al piso, y puede contener
igor@473 354 subsecuentemente cualquier caracter alfanumérico o una raya al
igor@473 355 piso. (En notación de expresiones regulares debe coincidir con
igor@473 356 \Verb+[A-Za-z_][A-Za-z0-9_]*+.)
igor@473 357
igor@473 358 \item El próximo elemento debe ser un caracter ``\texttt{=}'', que
igor@473 359 puede estar precedido o seguido por una cantidad arbitraria de
igor@473 360 espacio.
igor@473 361
igor@473 362 \item Si el resto de la línea comienza y termina con caracteres
jerojasro@520 363 encerrados entre caracteres de comillas (bien sea sencillas o
igor@473 364 dobles), se trata como cuerpo de la plantilla.
igor@473 365
igor@473 366 \item Si el resto de la línea \emph{no} comienza con una comilla, se
igor@473 367 trata como el nombre de un fichero; los contenidos de este fichero
igor@473 368 se leerán y se usarán como cuerpo de la plantilla.
igor@473 369 \end{itemize}
igor@473 370
igor@473 371 \section{Ejemplos de ficheros de estilos}
igor@473 372
igor@473 373 Para ilustrar la creación de un fichero de estilo, construiremos
igor@473 374 algunos ejemplos. En lugar de ofrecer un fichero completo de estilo y
igor@473 375 analizarlo, replicaremos el proceso usual de desarrollo de un fichero
igor@473 376 de estilo comenzando con algo muy sencillo, y avanzando por una serie
igor@473 377 de ejemplos sucesivos más completos.
igor@473 378
igor@473 379 \subsection{Identificar equivocaciones en ficheros de estilo}
igor@473 380
igor@473 381 Si Mercurial encuentra un problema en un fichero de estilo en el cual
igor@473 382 usted está trabajando, imprime un mensaje de error suscinto, cuando
igor@473 383 usted identifique lo que significa, resulta muy útil.
igor@402 384
igor@402 385 \interaction{template.svnstyle.syntax.input}
igor@402 386
igor@473 387 Tenga en cuenta que \filename{broken.style} trata de definir la
igor@473 388 palabra clave \texttt{changeset}, pero omite dar un contenido para esta.
igor@473 389 Cuando se le indica a Mercurial que use este fichero de estilo, se
igor@473 390 queja inmediatamente.
igor@402 391
igor@402 392 \interaction{template.svnstyle.syntax.error}
igor@402 393
igor@473 394 Este mensaje de error luce intimidante, pero no es muy difícil de
igor@473 395 seguir:
igor@473 396
igor@473 397 \begin{itemize}
igor@473 398 \item El primer componente es la forma como Mercurial dice ``me rindo''.
igor@402 399 \begin{codesample4}
igor@402 400 \textbf{abort:} broken.style:1: parse error
igor@402 401 \end{codesample4}
igor@402 402
igor@473 403 \item A continuación viene el nombre del fichero que contiene el error.
igor@402 404 \begin{codesample4}
igor@402 405 abort: \textbf{broken.style}:1: parse error
igor@402 406 \end{codesample4}
igor@402 407
igor@473 408 \item Siguendo el nombre del fichero viene el número de línea en la
igor@473 409 que se encontró el error.
igor@402 410 \begin{codesample4}
igor@402 411 abort: broken.style:\textbf{1}: parse error
igor@402 412 \end{codesample4}
igor@402 413
igor@473 414 \item Finalmente, la descripción de lo que falló.
igor@402 415 \begin{codesample4}
igor@402 416 abort: broken.style:1: \textbf{parse error}
igor@402 417 \end{codesample4}
jerojasro@520 418 La descripción del problema no siempre es clara (como en este caso),
igor@473 419 pero aunque sea críptica, casi siempre es trivial la inspección
igor@473 420 visual de la línea en el fichero de estilo y encontrar lo que está
igor@473 421 mal.
igor@473 422 \end{itemize}
igor@473 423
igor@473 424 \subsection{Identificar de forma única un repositorio}
igor@473 425
igor@473 426 Si desea identificar un repositorio de Mercurial ``de forma única''
igor@473 427 con una cadena corta como identificador, puede usar la primera
igor@473 428 revisión en el repositorio.
igor@402 429 \interaction{template.svnstyle.id}
igor@473 430 No es garantía de unicidad, pero no es útill en ciertos casos:
igor@402 431 many cases.
igor@402 432 \begin{itemize}
igor@473 433 \item No funcionará en un repositorio completamente vacío, porque un
igor@473 434 repositorio así no tiene una revisión~zero.
jerojasro@520 435 \item Tampoco funcionará en caso (muy raro) cuando el repositorio sea
igor@473 436 una fusión de dos repositorios independientes y tiene los dos
igor@473 437 directorios por ahí.
igor@473 438 \end{itemize}
igor@473 439 Hay ciertos casos en los cuales podría colocar el identificador:
igor@473 440 \begin{itemize}
igor@473 441 \item Como una llave en la tabla de una base de datos que administra
igor@473 442 repositorios en un servidor.
igor@473 443 \item Como una parte del par \{\emph{ID~repositorio}, \emph{ID~revisión}\}.
igor@473 444 Almacene esta información de forma independiente cuando ejecute
igor@473 445 construcciones automatizadas u otras actividades, de forma que pueda
igor@473 446 ``reconstruir'' posteriormente en caso de ser necesario.
igor@473 447 \end{itemize}
igor@473 448
igor@473 449 \subsection{Mostrando salida parecida a Subversion}
igor@473 450
igor@473 451 Intentemos emular la salida usual que usa otro sistema de control de
igor@473 452 revisiones, Subversion.
igor@402 453 \interaction{template.svnstyle.short}
igor@402 454
igor@473 455 Dado que la salida de Subversion es sencilla, es fácil copiar y pegar
igor@473 456 una porción de su salida en un fichero, y reemplazar el texto
igor@473 457 producido previamente por Subversion con valores base que quisiéramos
igor@473 458 ver expandidos.
igor@402 459 \interaction{template.svnstyle.template}
igor@402 460
igor@473 461 Esta plantilla difiere en algunos detalles de la salida producida por
igor@473 462 Subversion:
igor@473 463 \begin{itemize}
igor@473 464 \item Subversion imprime una fecha ``legible'' (el ``\texttt{Wed, 27 Sep
igor@473 465 2006}'' en el ejemplo de salida anterior) en paréntesis. El motor
igor@473 466 de plantillas de Mercurial no ofrece una forma sencilla de desplegar
igor@473 467 una fecha en este formato sin imprimir también la hora y la zona horaria.
igor@473 468 \item Emulamos las líneas de ``separación'' de subversion con caracteres
igor@473 469 ``\texttt{-}'' en una línea. Usamos la palabra clave
igor@473 470 \tplkword{header} del motor de plantillas para imprimir una línea de
jerojasro@520 471 separación como la primera línea de salida (ver más abajo), para
igor@473 472 lograr una salida similara a la de Subversion.
igor@473 473 \item La salida de subversion incluye un conteo en el encabezado del
igor@473 474 número de líneas en el mensaje de consinación. No podemos
igor@473 475 replicarlo en Mercurial; el motor de plantilla no ofrece en la
igor@473 476 actualidad un filtro que cuente la cantidad de objetos que se le
igor@473 477 pasen.
igor@473 478 \end{itemize}
igor@473 479 No me tomó más de un minuto o dos de trabajo para reemplazar texto
igor@473 480 literal de un ejemplo de salida de la salida de Subversion con ciertas
igor@473 481 palabras claves y filtros para ofrecer la plantilla anterior. El
igor@473 482 fichero de estilo se refiere sencillamente a la plantilla.
igor@402 483 \interaction{template.svnstyle.style}
igor@402 484
igor@473 485 Podríamos haber incluído el texto del fichero plantilla directamente
igor@473 486 en el fichero de estilo encerrando entre comillas y reemplazando las
igor@473 487 nuevas líneas con secuencias ``\verb!\n!'', pero haría muy difícil de
jerojasro@516 488 leer el fichero de estilos. La facilidad para leer es importante
igor@473 489 cuando está decidiendo si un texto pertenece a un fichero de estilo o
igor@473 490 a un fichero de plantilla incluído en el estilo. Si el fichero de
igor@473 491 estilo luce muy grande o complicado, si inserta una pieza de texto
igor@473 492 literal, mejor colóquelo en una plantilla.
igor@402 493
igor@402 494 %%% Local Variables:
igor@402 495 %%% mode: latex
igor@402 496 %%% TeX-master: "00book"
igor@402 497 %%% End: