Jun 21 2010

Org-mode : TAGS (etiquetas)

Tag: basicoverdrive @ 3:37 am

Despues de un tiempo inactivo (unos 6 meses); algunos de ellos por estar viajando y sin conexion a Internet y otras veces por otras razones personales por fin vuelvo para continuar con este blog sobre GNU/Emacs, asi que pido disculpas a todos por este retraso y tiempo inactivo.

Tambien quiero pedir disculpas debido a que los ultimos articulos necesitan ser revisados, ya que contienen frases que no son del todo entendibles o con algunos ejemplos poco claros, asi que intentare revisarlos lo antes posible.

Por otro lado decir que hemos migrado a nuevos servidores de OVH (antes estaban en 1&1) con mejores servicios, asi pues, hemos instalado nuevas versiones de software mas modernas mas seguras y con mas funcionalidades. Gracias a |[TDP]| ya que ha cargado con la parte pesada y se ha encargado de todo ello. Sin mas dilacion, pasamos a la parte tecnica y especifica de GNU/Emacs, en el cual hablare de los TAGS (o etiquetas) en org-mode.

Una forma de relacionar informacion cruzada es usar TAGS en las lineas de cabecera. Cada linea de cabecera contiene una lista de TAGS (que deben tener un formato alfanumerico o bien ‘‘ o ‘_‘) por ejemplo:

* Reunion con el grupo Frances        :work:
** Sumario por Frank               :boss:notes:
*** TODO Preparar presentacion        :action:

Herencia

Para usar los TAGS definidos en un solo fichero podemos usar:

#+FILETAGS: :Peter:Boss:Secret:

Que ademas pueden usar herencia (o no) si se configuran las variables org-use-tag-inheritance y org-tags-exclude-from-inheritance.

Cuando una linea de cabecera coincide durante una busqueda de TAGS y la herencia esta activada (o habilitada), todos los subniveles del mismo nivel heredaran este mismo TAG, por lo que esto puede provocar muchos resultados en algunos casos, asi que si solo se quiere encontrar la primera coincidencia en un subarbol podemos configurar la variable org-tags-match-list-sublevels (aunque esto no se recomienda segun la web oficial de org-mode).

Creando TAGS

Generalmente los TAGS se escriben a mano despues de la linea de cabecera, aunque despues de pulsar ‘:‘ podemos usar M-TAB para autocompletion de TAGS, ademas existen algunos keystrokes interesantes relacionados:

C-c C-q ó C-c C-c : Crea TAGS para la linea de cabecera actual. Ademas despues de presionar INTRO el TAG sera alineado, pero con C-u INTRO todos los tags seran alineados respecto la variable org-tags-column.

Org soporta insercion basada en listas de TAGS, para ello debemos especificar de forma global org-tag-alist con una lista de TAGS o bien para un fichero especifico mediante:

#+TAGS: @work @home @tennisclub
#+TAGS: laptop car pc boat

En el caso de que la lista sea dinamica usando la variable org-tag-alist debemos dejar la lista de TAGS en blanco tal que asi:

#+TAGS:

Podemos especificar una lista de TAGS en la variable org-tag-persistent-alist, lo que usara automaticamente en cada fichero dicha lista de TAGS, a excepcion de si se anade esta linea:

#+STARTUP: noptag

Existe ademas un metodo de seleccion de TAGS ultrarapido llamado fast tag selection, que permite deseleccionar y seleccionar TAGS simplemente presionando una tecla, por lo que deberemos asignar teclas unicas a cada TAG. Tambien se pueden configurar de forma global configurando la variable org-tag-alist en nuestro .emacs:

(setq org-tag-alist ‘((«@work» . ?w) («@home» . ?h) («laptop» . ?l)))

Se puede configurar de manera local (solo relevante para un fichero) de la siguiente forma:

#+TAGS: @work(w) @home(h) @tennisclub(t) \n laptop(l) pc(p)

Especificando ‘\n‘ comenzara una nueva linea despues de un TAG especifico, que seria lo equivalente a:

#+TAGS: @work(w) @home(h) @tennisclub(t)
#+TAGS: laptop(l) pc(p)

Se pueden agrupar los TAGS mediante llaves, indicando asi que al menos uno de los 3 encerrado entre llaves debe ser seleccionado:

#+TAGS: { @work(w) @home(h) @tennisclub(t) } laptop(l) pc(p)

Para activar los cambios debemos pulsar C-c C-c.

Es posible crear TAGS de exclusion mutua configurando la variable org-tags-alist:

(setq org-tag-alist ‘((:startgroup . nil)
(«@work» . ?w) («@home» . ?h)
(«@tennisclub» . ?t)
(:endgroup . nil)
(«laptop» . ?l) («pc» . ?p)))

Presionando C-c C-c y cualquier tecla de las siguientes:

  • a-z ó ó _ : podremos anadir o eliminar un TAG de la linea actual (ademas tendra en cuenta tags de exclusion mutua).
  • TAB : Autocompletara un TAG.
  • SPC : Elimina todos los TAGS de la linea actual.
  • INTRO : Acepta el nuevo TAG modificado.
  • C-g : Cancela el nuevo TAG.
  • q : Si q no esta asignado como un TAG, abortara como C-g.
  • ! : Deshabilita todos los TAGS de exclusion mutua.
  • C-c : Hace toggle para auto-salida del siguiente cambio. En modo experto el primer C-c mostrara la ventana de seleccion.

Es posible modificar la variable org-fast-tag-selection-single-key para evitar tener que presionar INTRO para TAGS demasiado usados y asi tener el mismo efecto.

Busqueda en tags

Es posible extraer cierta informacion a partir de los TAGS. Por ejemplo:

  • C-c \ ó C-c / m : Crea un arbol con todas las lineas de cabecera que coincidan con dicho TAG.
  • C-u C-c \ ó C-u C-c / : Con el prefijo esta vez ignorara aquellas lineas de cabecera que no sean un TODO.
  • C-c a m : Crea una lista global de la agenda de todos los TAGS que coincidan.
  • C-c a M : Crea una lista global de la agenda de todos los TAGS que conicidan, pero solo buscara aquellos que sean TODO y forzara la busqueda en subtareas (ver variable org-tags-match-list-sublevels).

Estos comandos se pueden usar para buscar empleando logica booleana como por ejemplo ‘+boss+urgent-project1‘ para encontrar todas las cabeceras de linea que tengan el TAG de ‘jefe’ y el de ‘urgente’ pero no para el ‘proyecto1’.

Recordad que este articulo es interesante combinarlo con los anteriores referentes a org-mode (tablas, hiperenlaces y tareas).

Al principio el uso de org-mode puede resultar algo complejo (sobretodo si no estamos habituados o no lo hemos estado al antiguo outline-mode) pero con un poco de practica, ignorando aquellos comandos que usemos con menos frecuencia y usando solo aquellos que mas nos interesen en cada momento, al final conseguiremos dominar este modo de manera mecanica.


Dic 10 2009

Org-mode : TODO (Tareas)

Tag: basicoverdrive @ 4:01 am

En Org tenemos opcion para almacenar y manejar listas de cosas a realizar (aka TODO), como marcar y mostrar dichas entradas, asignaciones y flujos de trabajos, fechas y notas del progreso, marcar prioridades, division de tareas por partes, etc.

Cualquier headline (a partir de ahora lo llamaremos linea de cabecera) se convertira en una tarea a realizar si se le precede de la palabra TODO:

*** TODO Leer onLisp

Aqui podemos aplicar distintos tipos de keystrokes interesantes:

  • C-c C-t : Rota el estado de TODO (pasando por unmarked, TODO, DONE). La misma rotacion es aplicacada mediante buffers de agenda y lineas de tiempo presionando la tecla t.
  • C-u C-c C-t : selecciona una palabra especifica usando autocompletion. Despues necesitamos asignar teclas a estados de TODO.
  • S–> o S-<- : Selecciona el siguiente o anterior estado de TODO.
  • C-c C-v o C-c / t : Muestra la lista de elementos de TODO en un arbol. Carpetas muestran el buffer entero, y muestra todos los elementos con sus cabeceras de forma jerarquica sobre el mismo. Se puede usar argumentos de prefijo dando una lista tal como KWD1|KWD2|… para listar entradas relacionadas, con prefijos numericos, mostrara el arbol Nth. Con dos prefijos, buscara en todos los TODO y entradas marcadas como DONE.
  • C-c a t : Muestra la lista global de TODO.
  • S-M-INTRO : Inserta una nueva entrada debajo del TODO actual.

Estados

Podemos usar claves de forma *secuencial* para estados de un trabajo en proceso:

(setq org-todo-keywords ‘((sequence «TODO» «FEEDBACK» «VERIFY» «|» «DONE» «DELEGATED»)))

La barra vertical o pipe diferenciaria de estados que requieren accion de los que no necesitan futura accion. Si no se provee de dicho pipe, la tarea estara por defecto ‘terminada’. Aqui podriamos aplicar comandos como:

  • C-c C-t para rotar el estado como explicamos anteriormente, aunque podriamos usarlo con el prefijo para dejarlo en un estado directamente como:
  • C-3 C-c C-t : Rota el estado directamente al tercero

Podemos usar claves para indicar un tipo de trabajo que se realizara a quien se le asignara, y cuando este terminado marcada como DONE, aqui C-c C-t se usara para reasignar la tarea a otra persona, pero si se vuelve a lanzar C-c C-t pasara de cualquier persona directamente al estado DONE, tambien se pueden usar prefijos para saltar directamente a cualquier persona:

(setq org-todo-keywords ‘((type «Fred» «Sara» «Lucy» «|» «DONE»)))

En dicho tipo de lista, podremos ver que tareas tiene asignadas la tercera persona (Lucy) mediante C-3 C-c C-v de dicho buffer, si queremos verlo a modo global podemos usar C-3 C-c t.

Para tener distintas propiedades para una tarea, es decir multiples claves podemos hacer algo asi:

(setq org-todo-keywords
‘((sequence «TODO» «|» «DONE»)
(sequence «REPORT» «BUG» «KNOWNCAUSE» | «FIXED»)
(sequence «|» «CANCELLED»)))

En este caso C-c C-t solo operara entre subsecuencias. Mientras que C-u C-u C-c C-t ó C-S–> saltara entre estados dentro de una subsecuencia. S-<– y S–> se desplazara por todas las propiedades de todas las subsecuencias.

Acceso Rapido

Tambien podemos crear ‘acceso rapido’ o ‘acceso directo’ a los estados mediante el siguiente ejemplo:

(setq org-todo-keywords
‘((sequence «TODO(t)» «|» «DONE(d)»)
(sequence «REPORT(r)» «BUG(b)» «KNOWNCAUSE(k)» «|» «FIXED(f)»)
(sequence «|» «CANCELLED(c)»)))

Presionando C-c C-t <letra> saltara directamente a dicho estado. Con SPC directamente se eliminara cualquier clave TODO de la lista.

Estados espeficios para ficheros individuales

Para ello debemos dejar la primera linea del fichero tal que asi:

#+TODO: TODO FEEDBACK VERYFY | DONE CANCELED

Tambien podemos especificar el tipo de tarea a quien sera asignada de manera especifica asi:

#+TYPE_TODO Fred Sara Lucy Mike | DONE

O bien especificar distintas propiedades en paralelo para una tarea medianta:

#+TODO: TODO | DONE
#+TODO: REPORT BUG KNOWNCAUSE | FIXED
#+TODO: | CANCELED

Si usamos abbrev es decir (M-TAB) cuando escribamos #+ podemos usar el completion para asegurarnos de que lo escribimos correctamente.

Resaltado

Es posible resaltar los elementos dependiendo del estado del elemento. Por ejemplo:

(setq org-todo-keyword-faces
‘((«TODO»        . org-warning)
(«DEFERRED»    . shadow)
(«CANCELED»    . (:foreground «blue» :weight bold))))

Dependencias

Podemos crear estructuras mas complejas con dependencias y con ello crear listas y herencias, creando subtareas (hijos) bloqueando asi la padre u otras hermanas, por ejemplo:

* TODO Blocked until (two) is done
** DONE one
** TODO two

* Parent
:PROPERTIES:
:ORDERED: t
:END:
** TODO a
** TODO b, needs to wait for (a)
** TODO c, needs to wait for (a) and (b)

Para que ello surta efecto es necesario configurar el valor de la variable org-enforce-todo-dependencies. Y con los siguientes keybindings podemos hacer:

  • C-c C-x o : hace toggle de la propiedad ORDERED de la entrada actual. Si se quiere trazar el valor de dicha propiedad con un tag para tener mejor visibilidad debemos configurar la variable org-track-ordered-property-with-tag.
  • C-u C-u C-u C-c C-t : Cambia el estado de la lista de tareas, de cualquier estado a blocante.

Ademas configurando la variable org-agenda-dim-blocked-tasks, la lista de tareas no podra ser cerrado debido a las dependencias y sera invisible o mostrando en la agenda.
Tambien se pueden usar checkboxes para bloquear dicha lista mediante la variable org-enforce-todo-checkbox-dependencies, por lo que bloqueara el poder cambiar el estado a DONE.

Para mas complejidad en dependencias se puede revisar el modulo org-depend.el.

Archivando trabajos por tiempo

Se puede archivar usando la fecha:

(setq org-log-done ‘time)

O bien mediante una nota con dicha fecha (se debe crear una entrada en la cabecera con Closing Note):

(setq org-log-done ‘note)

Trazando cambios de estado

A la hora de ver dichos cambios es posible modificar la vista modificando la variable org-log-into-drawer asignandole el valor LOGBOOK (recomendado) o en forma de subarbol dandole el valor de LOG_INTRO_DRAWER.

Se usan ‘marcas‘ especiales para acortar la configuracion de las tazas, como ‘!‘ para timestamp y ‘@‘ para notas, por ejemplo:

(setq org-todo-keywords
‘((sequence «TODO(t)» «WAIT(w@/!)» «|» «DONE(d!)» «CANCELED(c@)»)))

Tambien podemos usar las mismas preferencias locales a un buffer:

#+TODO: TODO(t) WAIT(w@/!) | DONE(d!) CANCELED(c@)

Para guardar todas estas transiciones podemos usar LOGGING, sin embargo una linea indicando :LOGGING: nil causara que no loguee ninguna transicion:

* TODO Loguear cada estado con su fecha y hora
:PROPERTIES:
:LOGGING: TODO(!) WAIT(!) DONE(!) CANCELED(!)
:END:
* TODO Solo loguear la transicion a WAIT y cuando se repita esta
:PROPERTIES:
:LOGGING: WAIT(@) logrepeat
:END:
* TODO No loguear nada
:PROPERTIES:
:LOGGING: nil
:END:

Tazando los habitos

Para trazar los habitos debemos primero configurar la variable org-modules, el habito es TODO, usando la palabra clave TODO representando el estado de la tarea abierta. La propiedad STYLE debe tener el valor habit. Cada tarea puede ser repetitiva como por ejemplo afeitarse y se puede realizar por ejemplo con un minimo de 2 dias pero no mas de 4, eso lo indicamos con la sintaxis ‘.+2d/4d‘ y ademas queremos guardar un logging cada vez que finalicemos la tarea de forma historica, por ejemplo quedaria asi:

** TODO Afeitarse
SCHEDULED: <2009-10-17 Sat .+2d/4d>
… aqui se iran anadiendo entradas automaticamente …
:PROPERTIES:
:STYLE:    habit
:LAST_REPEAT: [2009-10-19 Mon 00:36]
:END:

Esto usara los siguientes colores:

Azul -> si la tarea se finalizo otro dia
Verde -> Si la tarea se ha finalizado hoy
Amarillo -> Si la tarea es para manana como muy tarde
Rojo -> Si la tarea es para hoy como muy tarde

Se pueden modificar algunas variables interesantes para mostrar los habitos en la agenda:

  • org-habit-graph-column : La columna del buffer con que consistencia debe ser grabado el grafico.
  • org-habit-preceding-days : El historial maximo.
  • org-habit-following-days : Numero de dias que debe seguir apareciendo una tarea despues de ser realizada.
  • org-habit-show-habits-only-for-today : Si no es nil, mostrara solo los habitos de la agenda de hoy.

Ademas presionando K en la agenda, desabilitaremos/habilitaremos temporalmente los habitos.

Prioridades

Es posible prioridad tareas mediante:

*** TODO [#A] Escribir una carta a Richard Stallman

Por defecto Org permite 3 prioridades (A, B y C) siendo A la maxima prioridad. Las prioridades se reflejan solo en la agenda, fuera de ella no tienen efecto.

  • C-c , : Le asigna la prioridad a la tarea actual (A, B o C). Si se pulsa SPC la prioridad es eliminada. Las prioridades tambien pueden ser modificadas remotamente desde la agenda.
  • S-flechaarriba : Incrementa la prioridad.
  • S-flechaabajo : Decrementa la prioridad.

Se pueden modificar la posibles prioridades modificando las variables org-highest-priority, org-lowest-priority y org-default-priority.

Para modificar las prioridades de una tarea de un buffer individual se puede hacer mediante:

#+PRIORITIES: A C B

Rompiendo una tarea en subtareas

Podemos coger una tarea compleja y dividirla en subtareas, viendo asi la progresion respecto al total, para ello usaremos [/] ó [%]. Estas cookies actualizaran su estado cuando una subtarea cambie de estado o bien cuando se pulse C-c C-c en la cookie:

* Organize Party [%]
** TODO Llamar a gente [/]
*** TODO Peter
*** DONE Sarah
** TODO Comprar comida
** DONE Hablar con el vecino

Si queremos guardar las estadisticas de un subarbol de tareas (no directamente del hijo) debemos configurar la variable org-hierarchical-todo-statistics. Para realizar esto en un subarbol simlpe debemos incluir la palabra ‘recursive‘ como valor de la propiedad COOKIE_DATA:

* Parent capturing statistics [/]
:PROPERTIES:
:COOKIE_DATA: todo recursive
:END:

Si queremos cambiar automaticamente a DONE la tarea cuando todas las tareas hijas hayan finalizado:

(defun org-summary-todo (n-done n-not-done)
«Switch entry to DONE when all subentries are done, to TODO otherwise.»
(let (org-log-done org-log-states)
(org-todo (if (= n-not-done 0) «DONE» «TODO»))))

En caso de tener muchas subtareas es conveniente usar checkboxes.

Checkboxes

Cada tarea puede ser mostrada usando un checkbox, tan solo debemos crear [ ]. Para hacer toggle en una tarea de checkbox debemos usar C-c C-c o directamente usar el raton ya que es clickable, aqui un ejemplo de checkbox:

* TODO Organizar fiesta [/]
– [ ] Llamar a gente [/]
– [ ] Peter
– [ ] Sarah
– [ ] Sam
– [ ] Pedir comida
– [ ] Preparar la musica
– [ ] Hablar con los vecinos

Si las tareas deben efectuarse en secuencia obligatoria, los checkboxes deben deshabilitarse para evitar problemas y comportamientos no deseados. Los siguientes comandos funcionan con checkboxes:

  • C-c C-c : Hace toggle de una tarea en checkbox (ademas las estadisticas del headline se actualizaran).
  • C-c C-x C-b : Hace toggle de una tarea en checkbox (tambien funciona para regiones, ademas puede usar argumentos/prefijo en dichas regiones).
  • M-S-RET : Inserta una nueva tarea de tipo checkbox. (realmente es M-Ret).
  • C-c C-x o : Hace toggle de ORDERED si deben ser las tareas ejecutadas en secuencia. Si queremos trazar estos tipos de tareas ademas debemos configurar la variable org-track-ordered-property-with-tag.
  • C-c # : Actualiza las estadisticas de la entrada actual. Si es ejecutada con argumentos/prefijo C-u, actualizara el fichero entero.
  • M-<flecha arriba> : Mueve un elemento de la lista hacia arriba.
  • M-<fleha abajo> : Mueve un elemento de la lista hacia abajo.
  • C-u C-c ! : Anadira un timestamp donde nos escontremos.
  • C-c C-t : Aplicara un timestamp para el headline si incluimos las siguiente linea en nuestro .emacs:

(setq org-log-done ‘time)


Dic 09 2009

Org-mode : Hiperenlaces

Tag: basicoverdrive @ 1:45 am

Org permite guardar enlaces y que sean accesibles de forma click-able. El formato general es:

[[link][descripcion]        alternativa          [[link]]

Una vez todos los corchetes esten presentes, la descripcion sera mostrada, asi como el enlace. La forma que se usa para resaltarlos es mediante la variable org-link, que por defecto es subrayado. Es posible modificar tanto el link como su descripcion pulsando las teclas C-c C-l. Para borrar el enlace tan solo debemos poner el cursor al principio de la linea y pulsar BACKSPACE.

Enlaces internos

El link puede ser interno (y no una URL) para ello debemos crear identificadores y ser responsables de mantener un unico identificador diferente para cada enlace interno, por ejemplo si anadimos esta linea:

# <<<Mi objetivo>>>

Podremos referenciar a dicho enlace interno creando lo siguiente:

[[Mi objetivo]]

o bien

[[Mi objetivo]][[Buscar mi objetivo]]

Para acceder a los enlaces debemos presionar C-c C-o o bien hacer click con el raton. Tambien es posible exportarlos como enlaces HTML mediante HTML export (el cual comentaremos mas adelante).

Si el enlace no existe como tal, org buscara enlaces que comiencen por el mismo patron (es decir *Mi objetivo) y mostrara los resultados solo si coincide completamente, pudiendo acceder a cada uno de ellos o bien volviendo atras mediante C-c &.

Es posible crear enlaces usando botones de radio mediante (solo seran cargados cuando se cargue el fichero org la primera vez o bien pulsando C-c C-c):

<<<Mi objetivo>>>

Enlaces externos

Org permite enlazar a ficheros, webs, usenet, mails, entradas de bases de datos, e incluso conversaciones de irc o sus logs. Todos los enlaces externos comienzan por la palabra clave que identifica el tipo de enlace externo seguido por los dos puntos y el propio enlace, por ejemplo:

http://www.blackhats.es/    Una web
file:/home/overdrive/org.txt    Un fichero con PATH absoluto
/home/overdrive/org.txt        Igual que arriba
file:documentos/ultimo.pdf    Un fichero con PATH relativo
./documentos/ultimo.pdf        Igual que arriba
file:alguntexto::NNN        Una linea donde saltar dentro de un fichero
file:projects.org        Enlace a otro fichero org
file:projects.org::foo bar    Busqueda de texto en un fichero org
file.projects.org::*task bar    Busqueda de cabecera en un fichero org
id:B742456-2EAS-4FGHDF-345BZ    Enlace a un identificador
news:comp.emacs            Enlace a usenet
mailto:zoom@blackhats.es    Enlace a un correo
vm:carpeta            Enlace VM a una carpeta
vm:carpeta#id            Enlace VM a un mensaje
vm://yo@al.site.org/carpeta#id     Enlace VM a un identificador de una maquina remota
wl:carpeta            Enlace WANDERLUST a una carpeta
wl:carpeta#id            Enlace WANDERLUST a un id de una carpeta
mhe:carpeta            Enlace MH-E a una carpeta
mhe:carpeta#id            Enlace ME-E a un id de una carpeta
rmail:carpeta            Enlace rmail a una carpeta
rmail:carpeta#id        Enlace rmail a un id de una carpeta
gnus:grupo            Enlace gnus a un grupo
gnus:grupo#id            Enlace gnus a un id de un grupo
bbdb:R.*Stallman        Enlace BBDB con expresion regular (regexp)
irc:/freenode.net/#emacs/over    Enlace IRC
shell:ls *.org            Enlace a un comando shell
elisp:org-agenda        Enlace a un comando interactivo Elisp
elisp:(find-file-other-frame «elisp.org»)   Enlace a un formulario lisp a evaluar

Los enlaces deben ser cerrados con doble corchete y deben contener un texto descriptivo en lugar de mostrar la URL:

[[http://www.gnu.org/software/emacs/][GNU Emacs]]

Es posible poner como descripcion una URL o una imagen que luego puede ser mostrada inline. Ademas para evitar problemas con espacios o ciertas palabras reservadas es posible mediante el entrecomillado simple por ejemplo:

‘bbdb:Richard Stallman’

Administracion

C-c l : Si queremos insertar un enlace (ya sea para buffers, VM, rmail, Wanderlust, MH-E, gnus, navegadores como W3 o W3M, contactos BBDB, irc, agenda u otros ficheros).
C-c C-l : Inserta un enlace de forma interactiva sobre el cursor (permitiendo usar autocompletion con TAB)
C-u C-c C-l : Inserta un enlace usando fichero que sera insertado.
C-c C-o ó RET : Abre un enlace.
C-u C-u C-c C-o : Abre un enlace evitando emacs.
C-c % : Mete la posicion actual en el mark-ring.
C-c & : Salta a una posicion guardada.
C-c C-x C-n : Se desplaza al siguiente enlace en el buffer.
C-c C-x C-p : Se desplaza al enlace anterior en el buffer.

Se puede bindear a C-n y C-p anadiendo las siguientes lineas en nuestro .emacs:

(add-hook ‘org-load-hook
(lambda ()
(define-key ‘org-mode-map «\C-n» ‘org-next-link)
(define-key ‘org-mode-map «\C-p» ‘org-previous-link)))

Usando enlaces

Se pueden insertar las siguientes lineas en nuestro .emacs para acceder a los enlaces fuera de org:

(global-set-key «\C-c L» ‘org-insert-link-global)
(global-set-key «\C-c o» ‘org-open-at-point-global)

Abreviaturas

Se pueden usar abreviaturas para evitar tener que escribir mas de la cuenta, por ejemplo:

[[linkword:tag][descripcion]]

Donde ‘tag‘ es opcional y linkword debe ser un caracter alfanumberico o ‘_‘ o ‘‘. En lugar de tener que repetir dicha linea muchas veces podemos hacer cosas como:

(setq org-link-abbrev-alist
‘((«bugzilla» . «http://10.1.2.9/bugzilla/show_bug.cgi?id=»)
(«google»   . «http://www.google.com/search?q=»)
(«ads»         . «http://adsabs.harvard.edu/cgi-bin/nph-abs_connect?author=%s&db_key=AST»)))

Para el primer caso podemos enlazar un bug con [[bugzilla:129]], para el segundo caso podriamos usar [[google:OrgMode]] y para el ultimo caso podriamos usar [[ads:Dominik,C]] que reemplazara el contenido la cadena ‘%s‘ por el tag.

Para realizar abreviaturas para un fichero especifico podemos usar:

#+LINK: bugzilla http://10.1.2.9/bugzilla/show_bug.cgi?id=
#+LINK: google     http://www.google.com/search?q=%s

Ademas es posible usar completion para abreviaturas despues de escribir ‘[‘.

Opciones de busqueda

Los enlaces pueden contener cierta informacion a la hora de saltar en un enlace particular, como por ejemplo el numero de linea, una expresion regular, etc… por ejemplo:

[[file:~/codigo/main.c::255]]
[[file:~/xx.org::My objetivo]]
[[file:~/xx.org::*My objetivo]]
[[file:~/xx.org::/expresion_regular/]]

Busquedas personalizadas

Es posible modificar y personalizar las busquedas para buscar enlaces en ficheros con una extension particular hookeando variables como org-create-file-search-functions y org-execute-file-search-functions, tambien es interesante ver el mecanismo que usa org-mode para buscar en bases de datos BibTeX, para ello es posible ver la implementacion en org-bibtex.el.


« Página anteriorPágina siguiente »