Ene 20 2011

AUCTeX

Tag: basicoverdrive @ 5:34 pm

Hace un tiempo escribi un articulo orientado a TeX y LaTeX en emacs. En el simplemente se especificaban un listado de keybindings para usar emacs escribiendo este tipo de documentos. Sin embargo, hay que decir que existe AUCTeX que es una extension que proporciona un entorno de desarrollo para TeX, LaTeX, Texinfo y ConTeXt. Permite ademas previsualizar LaTeX.

  • C-c C-c : previsualiza y realiza demas acciones.
  • C-c C-t C-p : permite cambiar la previsualizacion activando/desactivando pdflatex, dvi o pdf.
  • C-t C-l : [a documentar – investigando en ello]

Prerequisitos antes de instalar AUCTeX:

  • AUCTeX requiere instalar TeX, LaTeX y texinfo (podemos realizarlo a modo apt-get install, emerge, mediante tarball, etc).
    • # apt-get install tex-common tex-latex
  • Preview-latex requiere que instalemos dvips para las operaciones en DVI mode.
    • # apt-get install dvi2ps
  • Preview-latex requiere de la instalacion de ghostscript (podemos realizarlo a modo apt-get install, emerge, tarball, etc).
    • # apt-get install ghostscript
  • Se requiere texinfo; este paquete es interesante para construir el tarball (podemos realizarlo a modo apt-get install, emerge, tarball, etc).
    • # apt-get install texinfo

Recordemos que AUCTeX es una extension y no forma parte del paquete emacs, por lo que hay que descargarlo y compilarlo (tambien es posible descargar AUCTeX desde CVS si quereis tener la ultimisima version, que en mi caso no es fundamental aunque quiza muchos desarrolladores o gente que espere nuevas features si le pueda interesar):

  1. Para ello nos dirigimos a la web oficial de AuCTeX.
  2. En «downloads» tenemos distintas versiones segun el sistema operativo, en mi caso «UNIX-style«.
  3. Una vez descargado, descomprimimos el paquete con:
    • $ tar xvfz auctex-11.86.tar.gz (o la version que sea).
  4. Entramos en el directorio:
    • $ cd auctex-11.86/
  5. Lanzamos el configure:
    • $ ./configure
  6. Compilamos:
    • $ make

Nota: no es necesario lanzar el make install a no ser que queramos que otros usuarios tengan acceso al paquete instalado, en mi caso, no es asi, como en la mayoria de personas que usan ellos unicamente su ordenador. Ademas como nos va a tocar meter un load-path en nuestro .emacs es mucho mas interesante asi, para ir cambiando de versiones segun vayamos metiendo nuevas. Siempre es menos engorros que tener que buscar las ubicaciones y ficheros de donde se haya instalado nuestro paquete en el sistema.

Esta puede ser la configuracion basica para trabajar con AUCTeX (cortesia de David -gracias-) y que podemos anadir en nuestro .emacs:

(add-to-list ‘load-path «~/auctex-version/»)
(add-to-list ‘load-path «~/auctex-version/preview/»)
(load «auctex.el» nil t t)
(load «preview-latex.el» nil t t)
(setq-default TeX-PDF-mode t)

Tambien recomiendo incluir las siguientes lineas para evitar tener cada vez que cargamos un fichero .tex estar cada vez cargando M-x latex-mode:

(setq auto-mode-alist
‘((«\\.tex$» . LaTeX-mode)
(«\\.sty$» . LaTeX-mode)
(«\\.bbl$» . LaTeX-mode)
(«\\.bib$» . BibTeX-mode)
(«\\.cls$» . LaTeX-mode)
(«\\.clo$» . LaTeX-mode)))

Una vez hecho esto o bien podemos lanzar de nuevo emacs o bien simplemente hacer un M-x load-file y cargar de nuevo nuestro .emacs.

Un ejemplo de documento LaTeX en mi emacs

Despues de pulsar C-c C-c para compilar y generar los ficheros dvi, pdf, etc

Estos son los ficheros generados por C-c C-c (en mi caso queria pdf en lugar de DVI)

Existen algunos keystrokes que entran en conflicto con stumpwm (para mas informacion sobre este peculiar wm, ver mi articulo sobre stumpwm):

Troubleshooting

Solucion de algunos problemas que me han surgido con stumpwm:

En latex-mode y AucTeX combinandolo con stumpwm surge un conflicto entre keybindings, ya que C-t C-t en stumpwm hace toggle entre frames mientras que C-c C-t C-p en latex-mode con AucTeX sirve para invocar pdfLatex para especificar si la salida sera dvi o pdf. La forma de solucionarlo es empleando el comando de stumpwm C-t t, el cual generara un C-t que nos servira para poder usar el comando C-c C-t C-p en cualquier otro WM, pero que en este se realizara mediante C-c C-t t C-p.


Ene 18 2011

Servidor de emacs: emacsclient y emacsserver

Tag: basicoverdrive @ 9:05 pm

Algunos usuarios se quejan de la tardanza que tiene emacs al cargar comparado con otros. Sobre todo debido a la gran carga a medida que este se va configurando modificando funcionalidades en nuestro .emacs. Para ello existe una solucion; usar emacsclient, que nos permitira evitar toda esta carga cada vez que lancemos emacs. Para ello no hay que hacer realmente nada, ya que esta feature viene en el paquete emacs base y tampoco requiere de ninguna configuracion especial. Aunque aqui incluiremos algunas lineas que nos facilitaran las tareas.

Recomiendo poner en nuestro .bashrc las siguientes lineas:

Estos cambios tendran efecto o bien si nos logueamos en otra consola, o bien si nos deslogueamos y logueamos en la misma o bien si lanzamos el comando source ~/.bashrc :

export EDITOR=»emacsclient -c»
export VISUAL=»emacsclient -c»
export ALTERNATIVE_EDITOR=»emacs»
alias e=»emacsclient -c»
alias es=»emacs –daemon»
alias ec=»emacsclient -c»

Nota para aquellos que no quieran usar estos alias: si no quisieramos poner estas lineas y seguir con la configuracion de toda la vida: debemos lanzar emacs –daemon la primera vez y luego ir lanzando emacsclient -c cada vez para cada hilo de ese daemon o bien emacs para un proceso nuevo cada vez.

Nota para los que si habeis decidido modificar vuestro .bashrc: De esta forma podemos lanzar el comando «es» desde cualquier terminal o consola la primera vez, y luego lanzar emacs (si queremos un proceso cada vez) o simplemente teclear e (si queremos un hilo cada vez). Veremos que se queda emacs como daemon o proceso residente en memoria, de esa forma cada vez que lanzamos emacs, se estara lanzando un hilo de este proceso en lugar de un proceso cada vez, ademas esto permitira intercomunicar los distintos hilos, sin importar si lo lanzamos en una consola y ahora nos encontramos en las XWindow y lo abrimos con GTK o desde un terminal, podremos tener acceso a los distintos buffers, con toda la informacion. etc. (Aqui el comando fbgrab lo empleo para capturas de pantalla en consola, pero carece de interes para el fin de este articulo, el comando verdaderamente importante es el primero que lanzo: emacs –daemon):

Emacs como daemon

Es importante tener en cuenta, que cuando salgamos de emacs (emacsclients) realmente es como si estuviesemos cerrando frames, ya que emacsserver seguira corriendo con aquella informacion modificada, asi que debemos cercionarnos de no apagar o reiniciar (aunque no veamos un emacs (en este caso emacsclient) mostrado, ya que podemos cerrar todos los emacsclients sin haber guardado ningun fichero o las ultimas modificaciones, ya que esto se queda residente en memoria aunque no tenga ninguna representacion).

Ahora ya tenemos nuestro querido emacs, que carga en 0 segundos. El «real» es el tiempo que he tardado desde que pulse intro del comando «time emacsclient -c» hasta que presione «C-x c» para cerrar emacs (es decir el tiempo que tarde en abrir y cerrar emacs), pero el tiempo de carga real como podemos ver ni siquiera llega a 1 milesima de segundo (el comando fbi es el que uso para previsualizar capturas en consola que carece de importancia en este articulo, el comando time precediendo a cualquier comando es el que nos da los tiempos):

Emacs cargado en menos de 1 milesima de segundo

Por ultimo hacer mencion especial a la primera captura de pantalla, si os fijais bien, tengo algunas features externas al paquete emacs, por lo que nuestro $HOME se va llenando de estas, aqui entra la esencia de reorganizar y reordenar estas features para no mezclarlas con otros ficheros y que nuestro directorio de usuario se convierta en algo caotico. Lo ideal, es emplear un directorio para ello por ejemplo ‘emacs‘ o ‘elisp‘ (ya que emacs se suele emplear cuando se descarga emacs desde el cvs/svn/git) donde dentro esten estas features o bien ‘.emacs.d/elisp‘. Todo esto es opcional, pero son buenas practicas que hara que todo nuestro sistema de ficheros tenga mayor coherencia a la hora de buscar ficheros; en mi caso, segun el ordenador que utilice, lo tengo mas o menos desordenado ;-).


Ene 13 2011

Org-mode : Date and times (Fechas y tiempos)

Tag: basicoverdrive @ 11:20 pm

En org-mode es posible usar fechas y tiempos para la planificacion de proyectos y demas informacion que queramos asociar a un tiempo, una fecha, etc.

Timestamps (marcas de tiempo)

El concepto de timestamp o marca de tiempo es usado generalmente para la creacion o ultima modificacion de un fichero, pero en el mundo de org es usado para un abanico mucho mayor de posibilidades. Existen distintos formatos de timestamps, que son los siguientes:

‘<2003-09-16 Tue>’
‘<2003-09-16 Tue 09:39>’
‘<2003-09-16 Tue 12:00-12:30>’

Y un timestamp puede aparecer en cualquier lugar del una linea de titulo (headline), el cuerpo (body) o en una entrada del arbol org (tree entry) creando entradas en la agenda ya sea diaria o semanalmente. Existen distintos tipos de timestamp:

  • Timestamp plano: * Meet Peter at the movies <2006-11-01 Wed 19:15>
  • Timestamp de cita: * Discussion on climate change <2006-11-02 Thu 20:00-22:00>
  • Timestamp con intervalos de repeticion: * Pick up Sam at school <2007-05-16 Wed 12:30 +1w>
  • Timestamp diario: * The nerd meeting on every 2nd Thursday of the month <%%(diary-float t 4 2)>
  • Rango de fechas: ** Meeting in Amsterdam <2004-08-23 Mon>–<2004-08-26 Thu>
  • Timestamp inactivo: * Gillian comes late for the fifth time [2006-11-01 Wed]

Creando timestamps

  • C-c . : org-time-stamp‘; inserta un timestamp (va entre <>).
  • C-c ! : org-time-stamp-inactive‘; inserta un timestamp inactivo (va entre []).
  • C-u C-c . : Inserta un timestamp con formato alternativo (mirar org-time-stamp-rounding-minutes).
  • C-u C-c ! : Inserta un timestamp inactivo con formato alternativo (mirar org-time-stamp-rounding-minutes).
  • C-c < : org-date-from-calendar‘; Inserta un timestamp correspondiente al cursor actual del calendario.
  • C-c > :org-goto-calendar‘; Accede al cursor actual del calendario.
  • C-c C-o : org-open-at-point‘; Accede a la agenda dado un timestamp existente.
  • S-<flecha izquierda> : org-timestamp-up-day‘; Cambia la fecha del cursor al dia anterior.
  • S-<flecha derecha> : org-timestamp-down-day‘; ‘org-timestamp-down-day’; Cambia la fecha del cursor al dia siguiente.
  • S-<flecha abajo> : org-timestamp-down-down‘; Cambia (ano, mes, dia, hora, minuto) al anterior.
  • S-<flecha arriba> : org-timestamp-up‘; Cambia (ano, mes, dia, hora, minuto) al siguiente.
  • C-c C-y :org-evaluate-time-range‘; Evalua un rango de tiempo entre el final y el principio.
  • C-u C-c C-y: Inserta la evaluacion de un rango de tiempo entre el final y el principio.

Prompt de horas y fechas (formatos y abreviaturas)

Existen distintos tipos de formatos, abreviaturas y demas para cuando trabajemos con org-mode, a continuacion las mostramos y mas adelante (sin preocuparnos ahora de ello, explicado en la seccion «Configuracion del formato del tiempo») donde explicaremos como emplear unas u otras (extraido del propio manual de orgmode):

Formatos para fechas:

     3-2-5         --> 2003-02-05
     2/5/3         --> 2003-02-05
     14            --> 2006-06-14
     12            --> 2006-07-12
     2/5           --> 2007-02-05
     Fri           --> el mas cercano Friday (Viernes) (fecha por defecto o siguiente)
     sep 15        --> 2006-09-15
     feb 15        --> 2007-02-15
     sep 12 9      --> 2009-09-12
     12:45         --> 2006-06-13 12:45
     22 sept 0:34  --> 2006-09-22 0:34
     w4            --> ISO semana para el ano actual 2006
     2012 w4 fri   --> Friday (viernes del ISO de la 4a semana en 2012)
     2012-w04-5    --> Mismo caso que arriba

Nota: para usar abreviaturas no listadas o de otros idiomas e.g. en lugar de Fri -> Vie o en lugar de Feb -> Ene deberemos configurar las variables parse-time-monthsparse-time-weekdays.

Formatos relativo al dia actual:

     +0            --> Hoy
     .             --> Hoy
     +4d           --> 4 dias desde hoy
     +4            --> 4 dias desde hoy
     +2w           --> Dos semanas desde hoy
     ++5           --> 5 dias desde la fecha por defecto
     +2tue         --> segundo Tuesday (Martes) desde hoy.

Formatos para rangos:

     11am-1:15pm    --> 11:00-13:15
     11am--1:15pm   --> same as above
     11am+2:15      --> same as above

Desplazamiento y seleccion por el calendario

  • <Intro> : Selecciona la fecha sobre la que esta el cursor en el calendario.
  • Click boton izquierdo del raton : Selecciona una fecha haciendo click en ella.
  • S-<flecha izquierda> : Se desplaza un dia hacia atras.
  • S-<flecha derecha> : Se desplaza un dia hacia adelante.
  • S-<flecha abajo> : Se desplaza una semana hacia adelante.
  • S-<flecha arriba> : Se desplaza una semana hacia atras.
  • M-S-<flecha izquierda> : Se desplaza un mes hacia atras.
  • M-S-<flecha derecha> : Se desplaza un mes hacia adelante.
  • > : Hace scroll del calendario en un mes hacia adelante.
  • < : Hace scroll del calendario en un mes hacia atras.
  • M-v : Hace scroll del calendario en 3 meses hacia atras.
  • C-v : Hace scroll del calendario en 3 meses hacia adelante.

Configuracion de formato del tiempo

Org-mode usa notacion estandar ISO 8601, esta puede ser modificada mediante la configuracion de variables org-display-custom-times y org-time-stamp-custom-formats, ademas con:

  • C-c C-x C-t : ‘org-toggle-time-stamp-overlays‘; Hace toggle entre este estandar y la configuracion que nosotros hayamos definido.

Org-mode necesita usar un estandar para poder parsear el fichero org y evitar futuros conflictos y problemas, por lo que de una manera u otra org-mode guardara el fichero en formato estandar aunque pueda ser visualizado de otra forma. Sin embargo si se emplea un formato especifico puede que algunas acciones efectuadas sobre los mismos timestamps tengan problemas, por lo que aconsejamos emplear el estandar en la medida de lo posible.


Deadlines (fechas limite) y Scheduling (Planificaciones)

Un timestamp puede venir precedido por palabras especiales para facilitar la planificacion:

  • DEADLINE (fecha limite donde la tarea debera ser terminada)
 *** TODO escribir articulo sobre la Tierra para el guia
El editor en cargar es [[bbdb:Ford Prefect]]
DEADLINE: <2004-02-29 Sun>
  • SCHEDULED (fecha donde se debera comenzar la tarea)
*** TODO Llamar a Pedro para su cumpleanos.
SCHEDULED: <2004-12-25 Sat>

Para insertar ‘deadlines’ o ‘scheduleds’ tendremos el siguiente juego de keybindings:

  • C-c C-d : ‘org-deadline‘; Inserta un deadline con un timestamp.
  • C-u C-c C-d : Elimina un deadline de la entrada.
  • C-c C-s : ‘org-schedule‘; Inserta un scheduled con un timestamp. (dependiendo de la variable org-log-reschedule una nota sera tomada cuando se modifique un scheduled existente) .
  • C-u C-c C-s : Elimina un scheduled de la entrada.
  • C-c C-x C-k : ‘org-mark-entry-for-agenda-action‘; Marca la entrada actual para una accion en la agenda. Despues de ello se puede abrir la agenda o el calendario para marcar la fecha apropiada; con k s o k d dependiendo de si es scheduled o deadline.
  • C-c / d : ‘org-check-deadlines‘; Crea un arbol con todas las deadlines pendientes o las que estan ‘al caer’ invocando org-deadline-warning-days.
  • C-u C-c / d : Muestra todas las deadlines en un fichero.
  • C-1 C-c / d : Muestra las deadlines del dia siguiente en un fichero.
  • C-c / b : ‘org-check-before-date‘; Crea un arbol con los deadlines y los scheduled antes de una fecha marcada.
  • C- c / a : ‘org-check-after-date‘; Crea un arbol con los deadlines y los scheduled despues de una fecha marcada.

Tareas repetitivas

Algunas tareas necesitan ser repetidas una y otra vez (un buen ejemplo es leer todos los dias 1 hora, hacer deporte cada 2 dias o pagar el piso todos los meses). Para ello se usa el siguiente formato:

     ** TODO Pagar el alquiler
        DEADLINE: <2005-10-01 Sat +1m>

La parte del +1m es la repeticion (que se puede interpretar como y otra vez dentro de 1 mes). Tambien se podria especificar una indicacion de advertencia durante unos dias antes, por ejemplo mediante +1m -3d (notese el espacio que hay entre la m y el -).

Como estas tareas son repetitivas existe un problema, y es que cuando la realizamos, si las marcamos como hechas mediante C-c C-t indicaria que no deberiamos a volverlas hacer, por lo que org-mode resuelve esto marcando la tarea de este mes como finalizada y anadiendo una mas sin hacer replica de esta primera pero con la siguiente fecha.

Existe otro caso especifico, por ejemplo si debiamos llamar a nuestros padres 1 vez por semana (tarea repetitiva) y sin embargo nos hemos olvidado durante 3 semanas seguidas, careceria de sentido llamarle ese mismo dia 3 veces para cumplimentar estas tareas, para ello, hay casos especiales mediante ‘++’ y  ‘.+’. Cuando se marque una tarea con ‘++‘ (por ej. ++1w) no importara si se ha finalizado la tarea semanal un Miercoles, si debiamos llamar a nuestro padre todos los Sabados, marcara como tarea pendiente el siguiente sabado. Mientras que si empleamos ‘.+’ lo marcaria a partir del dia que haya sido realizada la tarea, es decir el siguiente Miercoles.

Una alternativa para crear tareas repetitivas es realizar un numero especifico de copias de la tarea original, y cambiar las fechas de cada una de ellas de forma rapida mediante C-c C-x c.

Reloj

Org-mode permite iniciar el reloj cuando comience una tarea y pararlo, de esa forma podemos estimar el tiempo y esfuerzo realizado en una tarea. Incluso permite hacerlo entre distintas sesiones de emacs, de esa manera no importa cuantas veces hayamos parado e iniciado dicho reloj. Para ello hay que introducir las siguientes lineas en nuestro .emacs:

     (setq org-clock-persist 'history)
     (org-clock-persistence-insinuate)

Los keybindings que tenemos en nuestro poder para trabajar con el reloj son los siguientes:

  • C-c C-x C-i : ‘org-clock-in‘; Comienza a contar el reloj actual, insertando la palabra CLOCK junto al timestamp. Las lineas pueden ir envueltas en un wrapper llamado  para :LOGBOOK: ello hay que configurar la variable org-clock-into-drawer.
  • C-u C-c C-x C-i : Selecciona una tarea de una lista de tareas cronometradas.
  • C-c C-x C-o : ‘org-clock-out‘; Detiene el contador de un reloj anadiendo un timestamp frente a la tarea detenida. Ademas permite agregar informacion como nota adicional configurando la variable org-log-note-clock-out.
  • C-c C-x C-e : ‘org-clock-modify-effort-estimate‘; Actualiza el esfuerzo estimado para la tarea actual.
  • C-c C-c ó C-c C-y : ‘org-evaluate-time-range‘; Recomputa el intervalo de tiempo despues de cambiar uno de los timestamps (requerido si se modifican ‘directamente’ los timestamps, si se modifican mediante S-<cursor> es automatico).
  • C-c C-t : ‘org-todo‘; Cambia el estado de una tarea, por lo que el reloj en caso de existir para dicha tarea se detendra.
  • C-c C-x C-x : ‘org-clock-cancel‘; Cancela el reloj actual (util cuando se inicia el reloj por error para alguna tarea).
  • C-c C-x C-j : ‘org-clock-goto‘; Salta al headline (linea de titulo) de la tarea usada en el reloj actual.
  • C-c C-x C-d : ‘org-clock-display‘; Muestra el sumario de tiempos para cada subarbol del buffer actual. Al cambiar de buffer se borrara esta informacion, por lo que si se requiere de una configuracion distinta se debera tratar la variable org-remove-highlights-with-change.

Org-mode puede producir reportes bastante complejos basandose en la informacion recolectada del uso del reloj, veamos algunos comandos interesantes:

  • C-c C-x C-r : ‘org-clock-report‘; Inserta un bloqueo dinamico, manteniendo una tabla sobre el fichero actual, la cual es parcialmente actualizada cuando el cursor se encuentra encima de una tarea.
  • C-u C-c C-x C-r : Salta al primer reloj del reporte del documento actual y lo actualiza.
  • C-c C-c ó C-c C-x C-u : ‘org-dblock-update‘; Actualiza un bloqueo dinamico en el punto (el cursor debera estar en la linea de #+BEGIN del bloque dinamico).
  • C-u C-c C-x C-u : Actualiza todos los bloques dinamicos.
  • S-<flecha izquierda> : ‘org-clocktable-try-shift‘; Hace un desplazamiento hacia la izquierda del :block actual y actualiza la tabla.
  • S-<flecha derecha> : ‘org-clocktable-try-shift‘; Hace un desplazamiento hacia la derecha del :block actual y actualiza la tabla. (Requiere que el cursor se encuentre en la linea de #+BEGIN clocktable.

Un ejemplo:

#+BEGIN: clocktable :maxlevel 2 :emphasize nil :scope file
#+END: clocktable

Despues de la palabra reservada clocktable existen una serie de opciones de ambito, estructura y formato del reporte (que puede ser modificado su valor por defecto tratando la variable org-clocktable-defaults):

     :maxlevel    Maximo nivel de profundidad listado en la tabla.
                  Los relojes que esten en niveles mas profundos se sumaran a los de sus niveles superior.
     :scope       El ambito a considerar. Puede ser uno de los siguientes:
                  nil        El buffer actual o una region
                  file       El buffer completo
                  subtree    El subarbol donde se encuentra el reloj
                  treeN      El rodeo de arboles al nivel N, por ejemplo tree3
                  tree       El rodeo del arbol 1 tree
                  agenda     Todos los ficheros agenda
                  ("file"..) Escanea estos ficheros
                  file-with-archives    Fichero actual y sus archivos
                  agenda-with-archives  Todos los ficheros de agenda incluyendo sus archivos
     :block       El bloqueo de tiempo a considerar.  Puede tomar los siguientes valores:
                  absolute, o relative al tiempo actual y puede ser uno de los siguientes formatos:
                  2007-12-31    Nuevo ano eve 2007
                  2007-12       Diciembre 2007
                  2007-W50      ISO-semana 50 en 2007
                  2007-Q2       2o cuarto en 2007
                  2007          El ano 2007
                  today, yesterday, today-N          Un dia relativo
                  thisweek, lastweek, thisweek-N     Una semana relativa
                  thismonth, lastmonth, thismonth-N  Un mes relativo
                  thisyear, lastyear, thisyear-N     Un ano relativo
                  Usad S-<derecha>/<izquierda> para desplazar los intervalos de tiempo
     :tstart      Cadena de tiempo especificando cuando empiezan a considerarse los tiempos
     :tend        Cadena de tiempo especificando cuando se considera detener los tiempos
     :step        week o day, (semana o dia) a separar en la tabla en pedazos
                  Para usar esto, :block or :tstart, es requerido :tend
     :stepskip0   No mostrar pasos que tienen 0 de tiempo
     :fileskip0   No mostrar secciones de la table de ficheros los cuales no contriuyeron
     :tags        Los tags que coinciden para seleccionar entradas que deben contribuir

Hay opciones que pueden determinar el formato de la tabla. Estas opciones son interpretadas por la funcion org-clocktable-write-default, aunque se puede usar una funcion propia especificando el parametro :formatter:

     :emphasize   Cuando t, recalca el nivel 1 y 2 items.
     :link        Enlace a la cabecera del item en la tabla de sus origenes.
     :narrow      Un entero para limitar el ancho de la linea de cabecer en la columna en la tabla org.
                  Si se escribe '50!', entonces la cabecera tambien sera acortada al exportar.
     :indent      Identa cada campo de linea de cabecera de acuerdo con su nivel.
     :tcolumns    Numero de columnas a ser usados para los tiempos
                  Si es mas pequeno que :maxlevel, los niveles inferiores seran agrupados en una columna.
     :level       Debe ser mostrado el nivel de numero de columna?
     :compact     Abreviacion para :level nil :indent t :narrow 40! :tcolumns 1
                  Todos seran sobreescritos si esta implicita la opcion :narrow
     :timestamp   Un timestamp para la entrada, cuando este disponible.  Buscar SCHEDULED,
                  DEADLINE, TIMESTAMP y TIMESTAMP_IA, por dicho orden.
     :formula     Contenido de una linea #+TBLFM a ser anadida y evaluada.
                  Como caso especial, ‘:formula %’ anade una columna con % tiempo.
                  Si no se especifica aqui una formula, una formula existente
                  debajo de la tabla del reloj se mantendra con las actualizaciones y sera evaluada
     :formatter   Una funcion de los datos del formato del reloj e insercion de este en un buffer.

Algunos ejemplos de uso de todos estos formatos que hemos dicho son (tiempo para un rango especifico):

#+BEGIN: clocktable :tstart "<2006-08-10 Thu 10:00>"
                    :tend "<2006-08-10 Thu 12:00>"
#+END: clocktable

o (resumen de un reloj del nivel actual 1 del arbol, para el dia actual)

     #+BEGIN: clocktable :maxlevel 2 :block today :scope tree1 :link t
     #+END: clocktable

Tiempo inactivo (idle)

Si se emplea el reloj para un item de trabajo y por alguna razon se deja el ordenador de lado (por ejemplo una llamada telefonica) se necesita solucionar eso para ignorar este tiempo, una manera sencilla de solucionarlo es mediante la configuracion de la variable org-clock-idle-time, en el cual emacs avisara del tiempo de idle. Con este tiempo orgmode preguntara que accion se desea tomar:

  • k : para mantener algunos o todos los minutos dentro del reloj. Org preguntara cuantos minutos desean mantenerse o bien presionando RET directamente para mantenerlos todos.
  • K : se preguntara cuantos minutos se requirio para la tarea.
  • s : para no mantener ningun minuto.
  • S : para no mantener ningun minuto desde que comenzo el tiempo de away.
  • C : para cancelar el reloj (se perdera el tiempo anterior al away dedicado a la tarea tambien).

Estimacion de esfuerzo

Es posible estimar el esfuerzo del trabajo de forma muy detallada, esto puede servir para mejorar o ver en que tareas se dedica una ingente cantidad de tiempo, etc. Para ello se empleara la propiedad especial ‘Effort’ mediante los siguientes comandos:

  • C-c C-x e : ‘org-set-effort‘; Activa la propiedad ‘Effort’ para la entrada actual.
  • C-c C-x C-e : ‘org-clock-modify-effort-estimate‘; Modifica la estimacion de esfuerzo del item actual que es cronometrado.

Un ejemplo para el buffer actual podria ser:

     #+PROPERTY: Effort_ALL 0 0:10 0:30 1:00 2:00 3:00 4:00 5:00 6:00 7:00 8:00
     #+COLUMNS: %40ITEM(Task) %17Effort(Estimated Effort){:} %CLOCKSUM

o modificando las variables org-global-properties y org-columns-default-format. Para tener una vista general de la parte entera del dia que ha sido consignada se puede configurar la variable org-agenda-columns-add-appointments-to-effort-sum.

Tomando notas con temporizadores relativos

Cuando se toman notas, por ejemplo en una reunion o cuando se ve un video, etc. Puede ser util tener acceso a tiempos del inicio, para ello org provee un modo sencillo para tratar esto:

  • C-c C-x . : ‘org-timer‘; Inserta un tiempo relativo en el buffer. La primera vez, el reloj es creado, la siguiente iniciado.
  • C-u C-c C-x . : Reinicia el reloj de tiempo relativo.
  • C-c C-x – : ‘org-timer-item‘; Inserta una descripcion para un item con el actual tiempo relativo.
  • C-u C-c C-x – : Resetea el cronometro o tiempo relativo a 0.
  • M-<Intro> : ‘org-insert-heading‘; Cuando el reloj esta iniciado, se puede emplear para iniciar nuevos relojes relativos.
  • C-c C-x , : ‘org-timer-pause-or-continue‘; Pausa un reloj o reanuda un reloj parado.
  • C-u C-c C-x , : Para el reloj. Despues de esto, solo se puede iniciar un nuevo reloj.
  • C-c C-x 0 : ‘org-timer-start‘; Resetea un reloj sin insertar nada en el buffer. Por defecto comienza en 0, pero es posible utilizar argumentos (en lugar de 0, 4 por ej. para darle un offset (desplazamiento) al timer).

Despues de recibir un mail de un ‘emacser’, creo que es conveniente incluir su sugerencia (cortesia de Igor). Propone incluir en nuestro .emacs (modificando el valor de una variable) para que cuando un headline este marcado como DONE, se detenga el contador:

;; Clock out when moving task to a done state
(setq org-clock-out-when-done t)

Por otra parte, Igor tambien propone las siguientes lineas para que los contadores esten en un draw diferente de los logs:

;; Separate drawers for clocking and logs
(setq org-drawers (quote («PROPERTIES» «LOGBOOK» «CLOCK»)))
;; Save clock data in the CLOCK drawer and state changes and notes in the LOGBOOK drawer
(setq org-clock-into-drawer «CLOCK»)

Cuenta atras

Llamando a org-timer-set-timer se ejecuta un cronometro cuenta atras. Emplear ; para la agenda y C-c C-x ; en cualquier otra parte (debe ser un tema de conflictos). La cuenta atras, aparece en el modeline, con org-timer-default-timer especifica el valor por defecto desde el cual iniciar. Modificandolo se permite especificar un valor que no sea el de por defecto.

<;> from agenda buffers, <C-c C-x ;> everwhere else.org-timer-set-timer prompts the user for a duration and displays a countdown timer in the modeline. org-timer-default-timer sets the default countdown value. Giving a prefix numeric argument overrides this default value.


« Página anteriorPágina siguiente »