1 @c English version 2011-06-06
3 * Depuración del código fuente::
4 * Claves de depuración::
5 * Funciones y variables para depurado::
8 @node Depuración del código fuente, Claves de depuración, , Depurado
9 @section Depuración del código fuente
11 Maxima es capaz de dar asistencia en la depuración del código fuente. Un usuario puede establecer un punto de referencia dentro del código de una función a partir del cual se siga la ejecución línea a línea. La compliación puede ser posteriormente examinada, conjuntamente con los valores que se han ido asignando a las variables.
13 La instrucción @code{:help}, o @code{:h}, muestra la lista de comandos para la depuración. (En general, los comandos pueden abreviarse; en algunos casos la lista de alternativas podrá ser listada.) Dentro del depurador, el usuario podrá examinar también cualquier función propia de Maxima, definirla y manipular variables y expresiones.
15 El punto de referencia se establecerá con la instrucción @code{:br}. Ya dentro del depurador, el usuario podrá avanzar una línea de cada vez utilizando la instrucción @code{:n} (de ``next'', en inglés). La orden @code{:bt} (de ``backtrace'') muestra la lista de la pila. Finalmente, con el comando @code{:r} (``resume'') se abandona el depurador continuando con la ejecución. El uso de estas instrucciones se muestra en el siguiente ejemplo.
18 (%i1) load ("/tmp/foobar.mac");
23 Turning on debugging debugmode(true)
24 Bkpt 0 for foo (in /tmp/foobar.mac line 1)
30 (dbm:1) :bt <-- pulsando :bt se retrocede
31 #0: foo(y=5)(foobar.mac line 1)
32 #1: bar(x=2,y=3)(foobar.mac line 9)
34 (dbm:1) :n <-- pulsando :n se avanza una línea
38 (dbm:1) :n <-- pulsando :n se avanza otra línea
42 (dbm:1) u; <-- se pide el valor de u
45 (dbm:1) u: 33; <-- se cambia el valor de u a 33
48 (dbm:1) :r <-- pulsando :r se termina la depuración
53 El fichero @code{/tmp/foobar.mac} contiene lo siguiente:
56 foo(y) := block ([u:y^2],
68 USO DEL DEPURADOR EN EMACS
70 Si el usuario está corriendo el código bajo GNU emacs en un entorno de texto (dbl shell), o está ejecutando el entorno gráfico @code{xmaxima}, entonces cuando una función pare en el punto de referencia, podrá observar su
71 posición actual en el archivo fuente, el cual será mostrado en la otra mitad de la ventana, bien resaltada en rojo, o con una pequeña flecha apuntando a la línea correcta. El usuario puede avanzar líneas simples
72 tecleando M-n (Alt-n).
74 Bajo Emacs se debe ejecutar el programa en una ventana de texto @code{dbl}, la cual requiere el archivo @code{dbl.el} que está en el directorio elisp. El usuario debe instalar los archivos elisp o agregar el directorio elisp de Maxima a la ruta de búsqueda: por ejemplo, se puede añadir lo siguiente al archivo @file{.emacs} o al @code{site-init.el}
77 (setq load-path (cons "/usr/share/maxima/5.9.1/emacs" load-path))
87 debería abrir una ventana del sistema en la cual se pueden ejecutar programas, por ejemplo
88 Maxima, gcl, gdb, etc. En esta ventana también se puede ejecutar el depurador, mostrando el código fuente en la otra ventana.
90 El usuario puede colocar un punto de referencia en una línea determinada sin más que teclear @code{C-x space}. Con esto se le hace saber al depurador en qué función está el cursor y en qué línea del mismo. Si el cursor está en la línea 2 de @code{foo}, entonces insertará en la otra ventana la instrucción ``@code{:br foo 2}'', a fin de detener @code{foo} justo en la segunda línea. Para tener esto operativo, el usuario debe tener activo maxima-mode.el (modo-maxima.el) en la ventana en la que está @code{foobar.mac}. Hay otros comandos disponibles en la ventana, como evaluar la función dentro de Maxima tecleando @code{Alt-Control-x}.
93 @node Claves de depuración, Funciones y variables para depurado, Depuración del código fuente, Depurado
94 @section Claves de depuración
96 Las claves de depuración son palabras que no son interpretadas como expresiones de Maxima. Una clave de depuración puede introducirse dentro de Maxima o del depurador. Las claves de depuración comienzan con dos puntos, ':'. Por ejemplo, para evaluar una expresión Lisp, se puede teclear @code{:lisp} seguido de la expresión a ser evaluada.
103 El número de argumentos depende del comando en particular. Además, tampoco es necesario teclear el nombre completo de la instrucción, tan solo lo justo para diferenciarla de las otras instrucciones. Así, @code{:br} sería suficiente para @code{:break}.
105 Las claves de depuración se listan a continuación.
109 Establece un punto de referencia en la función @code{F} en la línea @code{n} contando a partir del comienzo de la función. Si @code{F} es una cadena, entonces se entiende que se trata de un fichero, siendo entonces @code{n} el número de línea a partir del comienzo del fichero. El valor @code{n} es opcional; en caso de no ser suministrado, se entenderá que vale cero (primera línea de la función o fichero).
111 Retrocede en la pila.
113 Continua el cómputo de la función.
115 Borra los punto de referencia especificados, o todos si no se especifica ninguno.
117 Deshabilita los puntos de referencia especificados, o todos si no se especifica ninguno.
119 Habilita los puntos de referencia especificados, o todos si no se especifica ninguno.
121 Imprime el elemento @code{n} de la pila, o el actualmente activo si no se especifica ninguno.
123 Imprime la ayuda sobre un comando del depurador, o de todos los comandos si no se especifica ninguno.
125 Imprime información sobre un elemento.
126 @item :lisp expresión
127 Evalúa la @code{expresión} Lisp.
128 @item :lisp-quiet expresión
129 Evalúa la @code{expresión} Lisp sin devolver el resultado.
131 Como @code{:step}, excepto que @code{:next} se salta las llamadas a funciones.
133 Sale del nivel actual del depurador sin completar el cómputo.
135 Continúa con el cómputo.
137 Sigue con el cómputo de la función o fichero hasta que alcance una nueva línea fuente.
139 Retorna a Maxima desde cualquier nivel del depurador sin completar el cómputo.
143 @node Funciones y variables para depurado, , Claves de depuración, Depurado
144 @section Funciones y variables para depurado
147 @defvr {Variable opcional} debugmode
148 Valor por defecto: @code{false}
150 Cuando en Maxima ocurre un error, Maxima inicializará el depurador si @code{debugmode} tiene el valor @code{true}.
151 El usuario puede ingresar comandos para examinar la pila de llamadas, los puntos de interrupción; en pocas palabras ir a través del código de Maxima. Vea @code{debugging} para una lista de los comandos del depurador.
153 Habilitando @code{debugmode} no se capturarán los errores tipo Lisp.
155 @c DO WE WANT TO SAY MORE ABOUT DEBUGGING LISP ERRORS ???
156 @c I'M NOT CONVINCED WE WANT TO OPEN THAT CAN OF WORMS !!!
161 @defvr {Variable opcional} refcheck
162 Valor por defecto: @code{false}
164 Cuando @code{refcheck} vale @code{true}, Maxima imprime un mensaje cada vez que una variable es utilizada por vez primera en un cálculo.
168 @defvr {Variable opcional} setcheck
169 Valor por defecto: @code{false}
171 Cuando el valor de @code{setcheck} es una lista de variables (se admite que tengan subíndices) Maxima devuelve un mensaje indicando si los valores que han sido asignados a las variables lo han sido con el operador ordinario @code{:}, o con el operador de asignación @code{::} o como resultado de haberse realizado una llamada de función, pero en ningún caso cuando la asignación haya sido hecha mediante los operadores @code{:=} o @code{::=}. El mensaje contiene el nombre de la variable y su valor.
173 La variable @code{setcheck} admite también los valores @code{all} o @code{true} con lo que el informe incluirá todas las variables.
175 Cada nueva asignación de @code{setcheck} establece una nueva lista de variables a ser monitorizada, de forma que cualquier otra variable previamente asignada a @code{setcheck} es olvidada.
177 Los nombres asignados a @code{setcheck} deben estar precedidos del apóstrofo @code{'} a fin de evitar que las variables sean evaluadas antes de ser almacenadas en @code{setcheck}. Por ejemplo, si @code{x}, @code{y} y @code{z} ya guardan algún valor entoces se hará
180 setcheck: ['x, 'y, 'z]$
183 para colocarlas en la lista de variables a monitorizar.
185 No se generará ninguna salida cuando una variable de la lista @code{setcheck} sea asignada a ella misma, como en @code{X: 'X}.
189 @defvr {Variable opcional} setcheckbreak
190 Valor por defecto: @code{false}
192 Si @code{setcheckbreak} es igual @code{true}, Maxima se detendrá siempre que a una variable de la lista @code{setcheck} se le asigne un nuevo valor. La detención tendrá lugar justo antes de hacerse la asignación. En ese momento @code{setval} guarda el valor que se le va a dar a la variable. Entonces el usuario podrá darle un valor diferente pasándoselo a la variable @code{setval}.
194 Véanse también @code{setcheck} y @code{setval}.
198 @defvr {Variable del sistema} setval
200 Guarda el valor que va a ser asignado a una variable cuando @code{setcheckbreak} realiza una detención. Entonces se podrá asignarle otro valor pasándoselo previamente a @code{setval}.
202 Véanse también @code{setcheck} y @code{setcheckbreak}.
206 @deffn {Función} timer (@var{f_1}, ..., @var{f_n})
207 @deffnx {Función} timer (all)
208 @deffnx {Función} timer ()
209 Dadas las funciones @var{f_1}, ..., @var{f_n}, @code{timer} coloca cada una de ellas en la lista de funciones para las cuales se generarán estadísticas relativas al tiempo de cómputo. Así, @code{timer(f)$ timer(g)$} coloca a @code{f} y luego a @code{g} en dicha lista de forma acumulativa.
211 La sentencia @code{timer(all)} coloca todas las funciones de usuario
212 (las referenciadas por la variable global @code{functions}) en la lista
213 de funciones cuyos tiempos de ejecución se quieren monitorizar.
215 Si no se le pasan argumentos a @code{timer} se obtendrá la lista de funciones cuyos tiempos de ejecución se quieren monitorizar.
217 Maxima almacena la duración del cómputo de cada función de la lista, de forma que @code{timer_info} devolverá las estadísticas correspondientes, incluyendo el tiempo medio de cada llamada a la función, el número de llamadas realizadas y el tiempo total transcurrido. La instrucción @code{untimer} borra las funciones de la lista.
219 La función @code{timer} no evalúa sus argumentos, de forma que @code{f(x) := x^2$ g:f$ timer(g)$} no coloca a @code{f} en la lista.
221 Si @code{trace(f)} está activada, entonces @code{timer(f)} está desactivada; @code{trace} y @code{timer} no pueden estar operativas al mismo tiempo.
223 Véase también @code{timer_devalue}.
227 @deffn {Función} untimer (@var{f_1}, ..., @var{f_n})
228 @deffnx {Función} untimer ()
229 Dadas las funciones @var{f_1}, ..., @var{f_n}, @code{untimer} las elimina de la lista de funciones cuyos tiempos de ejecución se quiere monitorizar.
231 Si no se le suministran argumentos, @code{untimer} borra completamente la lista.
233 Tras la ejecución de @code{untimer (f)}, @code{timer_info (f)} aún devuelve las estadísticas de tiempo previamente registradas, pero @code{timer_info()} (sin argumentos) no devuelve información sobre aquellas funciones que ya no están en la lista. La ejecución de @code{timer (f)} inicializa todas las estadísticas a cero y coloca @code{f} nuevamente en la lista.
237 @defvr {Variable opcional} timer_devalue
238 Valor por defecto: @code{false}
240 Si @code{timer_devalue} es igual a @code{true}, Maxima le resta a cada función cuyos tiempos de ejecución se quiere monitorizar el tiempo gastado en llamadas a otras funciones presentes también en la lista de monitorización. En caso contrario, los tiempos que se obtienen para cada función incluyen también los consumidos en otras funciones. Nótese que el tiempo consumido en llamadas a otras funciones que no están en la lista de monitorización no se resta del tiempo total.
242 Véanse también @code{timer} y @code{timer_info}.
246 @deffn {Función} timer_info (@var{f_1}, ..., @var{f_n})
247 @deffnx {Función} timer_info ()
248 Dadas las funciones @var{f_1}, ..., @var{f_n}, @code{timer_info} devuelve una matriz con información relativa a los tiempos de ejecución de cada una de estas funciones. Sin argumentos, @code{timer_info} devuelve la información asociada a todas las funciones cuyos tiempos de ejecución se quiere monitorizar.
250 La matriz devuelta por @code{timer_info} incluye los nombres de las funciones, tiempo de ejecución en cada llamada, número de veces que ha sido llamada, tiempo total de ejecución y tiempo consumido en la recolección de basura, @code{gctime} (del inglés, "garbage collection time") en la versión original de Macsyma, aunque ahora toma el valor constante cero.
252 Los datos con los que @code{timer_info} construye su respuesta pueden obtenerse también con la función @code{get}:
255 get(f, 'calls); get(f, 'runtime); get(f, 'gctime);
258 Véase también @code{timer}.
263 @deffn {Función} trace (@var{f_1}, ..., @var{f_n})
264 @deffnx {Función} trace (all)
265 @deffnx {Función} trace ()
267 Dadas las funciones @var{f_1}, ..., @var{f_n}, @code{trace} imprime información sobre depuración cada vez que estas funciones son llamadas; @code{trace(f)$ trace(g)$} coloca de forma acumulativa a @code{f} y luego a @code{g} en la lista de funciones a ser rastradas.
269 La sentencia @code{trace(all)} coloca todas las funciones de usuario
270 (las referenciadas por la variable global @code{functions}) en la lista
271 de funciones a ser rastreadas.
273 Si no se suministran argumentos, @code{trace} devuelve una lista con todas las funciones a ser rastreadas.
275 La función @code{untrace} desactiva el rastreo. Véase también @code{trace_options}.
277 La función @code{trace} no evalúa sus argumentos, de forma que @code{f(x) := x^2$ g:f$ trace(g)$} no coloca a @code{f} en la lista de rastreo.
279 Cuando una función se redefine es eliminada de la lista de rastreo. Así, tras @code{timer(f)$ f(x) := x^2$}, la función @code{f} dejará de estar en dicha lista.
281 Si @code{timer (f)} está activado, entonces @code{trace (f)} está desactivado, ya que @code{trace} y @code{timer} no pueden estar ambos activos para la misma función.
285 @deffn {Función} trace_options (@var{f}, @var{option_1}, ..., @var{option_n})
286 @deffnx {Función} trace_options (@var{f})
288 Establece las opciones de rastreo para la función @var{f}. Cualquier otra opción previamente especificada queda reemplazada por las nuevas. La ejecución de @code{trace_options (@var{f}, ...)} no tiene ningún efecto, a menos que se haya invocado previamente a @code{trace (@var{f})} (es indiferente que esta invocación sea anterior o posterior a @code{trace_options}).
290 @code{trace_options (@var{f})} inicializa todas las opciones a sus valores por defecto.
292 Las claves de opciones son:
297 No se imprime mensaje alguno ni a la entrada ni a la salida de la función.
300 Coloca un punto de referencia antes de que la función comience a ejecutarse y otro después de que termine su ejecución. Véase @code{break}.
303 Muestra los argumentos y valores retornados como objetos de Lisp.
306 Imprime @code{-> true} tanto a la entrada como a la salida de la función.
309 Detecta errores, otorgando la posibilidad de marcar un error, reintentar la llamada a la función o especificar un valor de retorno.
312 Las opciones de rastreo se especifican de dos formas. La única presencia de la clave de opción ya activa la opción. (Nótese que la opción @var{foo} no se activa mediante @code{@var{foo}: true} u otra forma similar; se tendrá en cuenta también que las claves no necesitan ir precedidas del apóstrofo.) Especificando la clave de opción junto con una función de predicado se hace que la opción quede condicionada al predicado.
314 La lista de argumentos para las funciones de predicado es siempre @code{[level, direction, function, item]} donde @code{level} es el nivel de recursión para la función, @code{direction} puede ser tanto @code{enter} como @code{exit}, @code{function} es el nombre de la función y @code{item} es la lista de argumentos (a la entrada) o el valor de retorno (a la salida).
316 A continuación un ejemplo de opciones de rastreo no condicionales:
319 (%i1) ff(n) := if equal(n, 0) then 1 else n * ff(n - 1)$
323 (%i3) trace_options (ff, lisp_print, break)$
328 Para la misma función, con la opción @code{break} condicionada a un predicado:
331 (%i5) trace_options (ff, break(pp))$
333 (%i6) pp (level, direction, function, item) := block (print (item),
334 return (function = 'ff and level = 3 and direction = exit))$
341 @deffn {Función} untrace (@var{f_1}, ..., @var{f_n})
342 @deffnx {Función} untrace ()
343 Dadas las funciones @var{f_1}, ..., @var{f_n},
344 @code{untrace} desactiva el rastreo previamente activado por la función @code{trace}. Si no se aportan argumentos, @code{untrace} desactiva el rastreo de todas las funciones.
346 La llamada a @code{untrace} devuelve una lista con las funciones para las que el rastreo se ha desactivado.