1 # -*- mode: org; fill-column: 65 -*-
5 #+TITLE: Archive list of Org-mode user-visible changes
6 #+AUTHOR: Carsten Dominik
7 #+EMAIL: carsten at orgmode dot org
8 #+OPTIONS: H:3 num:nil toc:nil \n:nil @:t ::t |:t ^:{} *:t TeX:t LaTeX:nil
9 #+INFOJS_OPT: view:info toc:1 path:org-info.js tdepth:2 ftoc:t
11 #+LINK_HOME: http://orgmode.org
19 ** Structure editing and cycling
21 *** New minor mode =org-indent-mode=
23 This mode implements outline indentation similar to clean view,
24 but in a dynamic and virtual way, at display time. I have wanted
25 this functionality for years and tried several implementations,
26 all unworkable. Emacs 23 has finally made it possible. So this
27 solution is for Emacs 23 only, and I am not sure yet how stable
28 it really is. Time will tell.
30 Currently I do not recommend to turn it on globally using
31 the variable =org-startup-indented=. But you can turn it on
32 for a particular buffer using
38 Turning on this minor mode automatically turns on
39 =org-hide-leading-stars=, and it turns off
40 =org-adapt-indentation=.
42 *** Skip CHILDREN state if there are no children
44 When a subtree does not have any children, visibility
45 cycling now skips the CHILDREN state. You can customize
46 this behavior with the variable
47 =org-cycle-skip-children-state-if-no-children=.
49 *** Nodes without keyword can now be counted for statistics
51 See the variable =org-provide-todo-statistics= for details.
52 It can be the symbol =all-headings=, or a list of TODO
55 This was requested by David A. Gershman.
57 *** New function =org-list-make-subtree=
59 This function converts the plain list at point into a
60 subtree, preserving the list structure. The key for this
61 command is =C-c C-*=. Thanks to Ilya Shlyakhter for this
64 *** Headlines can be fontified to the right window border
66 Use the variable =org-fontify-whole-heading-line= to turn
67 this on. Then headline fontification will include the final
68 newline. If your setup for headline faces includes a
69 background different from the default background, this setup
70 creates a visual line across the window.
72 *** Inline tasks have become better citizens
74 The new key =C-c C-x t= inserts an inline task including an
75 END line. Inline tasks play along with (i,e, are ignored
76 by) link creation and footnotes. Inline tasks with an =END=
77 line can be refiled and archived. During the refile/archive
78 operation, the tasks become normal tasks and the =END= line
81 These improvements reflect reports and requests by Peter
82 Westlake and Matt Lundin.
84 *** Archive subtree and move to next visible task
86 When archiving a task, the cursor now ends up on the next
87 headline, so the repeated application of the archiving
88 command will archive successive tasks.
90 Thanks to Bernt Hansen for a patch to this effect.
92 *** Renumbering the fn:N-like footnotes
94 The new footnote action =r= will renumber simple =fn:N=
95 footnotes in the current document. The action =S= will
96 first do the renumbering and then sort the footnotes (the
99 This was a request by Andreas Röhler.
101 *** Automatic sorting and renumbering
103 Customize the new variable =org-footnote-auto-adjust= or use
104 the =#+STARTUP= option =fnadjust= to get automatic
105 renumbering and sorting of footnotes after each
108 This was a request by Andreas Röhler.
110 *** Improvements to plain-list-cycling with TAB.
112 TAB now by default cycles visibility in plain lists if the
113 cursor is at a plain list item. This corresponds to the new
114 default value =t= of =org-cycle-include-plain-lists=. If
115 you want to treat plain list items as part of the outline
116 hierarchy during cycling of outline headings (this is what a
117 =t= value used to mean), set this variable to =integrate=.
119 *** Force bullet type changes during plain list demotion
121 We now have a mechanism to force a particular bullet type
122 when demoting a plain list item. See the variable
123 =org-list-demote-modify-bullet= for details.
125 This was a request by Rainer Stengele.
130 *** Relative row references may now cross hlines
132 A relative row reference like @-1 in a table may now reach
133 across a horizontal separator line. I hope this will not
134 break any important tables out there, but I think it is the
137 The sole original reason for not allowing such crossing was
138 to implement running averages of one column in the next.
139 This can now be done using field formulas near the beginning
140 and end of the column, and a column formula for the central
143 See the variable =org-table-relative-ref-may-cross-hline=
146 *** Cut or copy single fields
148 =C-c C-x C-w= and =C-c C-x M-w= now act on single table
149 fields if there is no active region defined.
153 *** Find agenda files linking to the current location
155 The new command =org-occur-link-in-agenda-files= creates a
156 link like =org=store-link= would, and then searches all
157 agenda files for this link. So for example, you could be in
158 a GNUS message, trying to find tasks that have links to this
161 *** Include stored links into link completion
163 When inserting a link with =C-c C-l=, TAB completion will
164 now not only access link prefixes, but also the stored
170 *** Bulk commands: Add Schedule and Deadline processing
172 Agenda bulk commands on marked entries now can also set the
173 scheduling date or a deadline. Normally, all entries will
174 be set to the specified date. However, when writing the
175 change as "++5d" or "++2w", then each time stamp will
176 independently be shifted by that amount.
178 *** Tags-todo searches: No longer force to list sublevels
180 For historic reasons, =org-tags-match-list-sublevels= was
181 forced to =t= in tags-todo agenda searches. Now we no
182 longer do this and accept the user setting of this variable.
184 Thanks to Patrick Bahr for bringing this up.
189 *** Use file-source.org format instead of file.org-source
191 When publishing the source Org file to the source directory
192 (i.e. if the publishing directory is the same as the source
193 directory), then the file name will now look like
194 =file-source.org= and =file-source.org.html=. Note that if you
195 do use this kind of setup, you probably want to specify
197 #+begin_src emacs-lisp
198 :exclude "-source\.org"
201 in your publishing project, to avoid that a new generation of
202 =-source= files is created each time you publish the project.
204 *** LaTeX export: Skip title command when there is no title
206 Using =#+TITLE:= without a value makes the LaTeX export
207 ignore the value of =org-export-latex-title-command=.
209 *** New option =org-export-html-footnote-format=
211 This defines the format for footnote references. This
212 string must contain =%s= which will be replaced by the
215 *** More export options for source code examples
217 Allow whitespace in code references. Allow the =-r= switch
218 to remove the references in the source code even when the
219 lines are not numbered: the labels can be explicit enough.
220 Note that =-r -k= is the same as no switch at all.
222 Thanks to Ulf Stegemann for bring this up.
224 *** LaTeX export: Allow more environment for low-level headings
226 The user can now define a non-standard environment or macro
227 to handle export of low-level headings to LaTeX.
229 For details, see the variable =org-export-latex-low-levels=.
231 *** LaTeX export: Add postscript file extensions for images
233 Some people process LaTeX files not directly to pdf, but go
234 through dvi and then to ps or pdf. In that case, allowed
235 images are ps and eps files, not pdf and jpg.
237 This commit adds the two extensions, so that export using
238 that alternative path can be supported better. However, it
239 is up to the user to make sure that the images are actually
240 compatible with the backend.
242 *** HTML export: Show UP and HOME links
244 =org-export-html-link-up= and =org-export-html-link-home=
245 are now also inserted into normal HTML export, above the
248 *** General mechanism for local variable settings
250 Many different people want to set many different variables
251 in a buffer-local way for export. This cannot be done with
252 file variables, because the Org buffer is not current while
253 the exporter is running.
255 Lots of variables can be set with the =#+OPTIONS= lines, but
256 finding abbreviations goes only so far.
258 Therefore we have now a general mechanism that can be used
259 to bind variables during export operations.
264 ,#+BIND: variable value
267 will bind the variable to value. For example, the line
273 can now equivalently be written as
276 ,#+BIND: org-export-with-toc nil
279 *** Clean out publishing timestamp directory
281 When changing the publishing setup, old timestamp files can
282 be left behind. Forcing publishing of all projects with
283 =C-u C-c C-e E= will remove all existing timestamp files.
287 *** Calendar for reading a date forced into current frame.
289 Separate-frame setup for calendar had caused problems in
292 *** Set timers for headlines
294 You can now set a timer related to any headline, like an
295 alarm clock. Three new commands have been defined:
297 - org-timer-set-timer :: bound to =C-c C-x ;= in Org buffers
298 and to =;= in Org agenda buffers. This function sets a
299 timer for the headline the cursor is currently it. Up to
300 three timers can be used at any time.
302 - org-timer-show-remaining-time :: Show the remaining time
303 for the last timer set.
305 - org-timer-cancel-timers :: Cancel all timers.
307 This functionality was requested by Samuel Wales and
308 emulates that of /tea-time.el/ -- see the emacswiki doc at
310 http://www.emacswiki.org/emacs/tea-time
312 *** Clock reports may include a time stamp
314 Using =:timetamp t= as an option in a clock report now
315 allows insertion of the timestamp for the clocked entry.
316 Timestamps are searched for in this order: =SCHEDULING=,
317 =TIMESTAMP=, =DEADLINE= and =TIMESTAMP_IA=.
319 *** New option =org-id-uuid-program=
321 On some systems, =uuidgen= is named =uuid=.
323 *** Clock notification handler made configurable
325 See the variable =org-show-notification-handler=.
327 *** New option =org-tags-sort-function=.
329 This allows tags to be sorted by =string<=, =string>=, or a
332 Thanks to James TD Smith for a patch to this effect.
334 *** Improvements for org-feed.el
336 But fixes, and allowing to choose between =wget= and =curl=.
338 Thanks to Christopher League for a patch to this effect.
348 *** Refiling now works from the agenda
350 The command =C-c C-w= can be executed to refile an entry shown in
351 the agenda. After the command, the entry will no longer be shown
352 in the agenda. It it is still in an agenda file, refresh the
353 agenda to bring it up from it's new context.
357 You can now use the =m= key to mark entries in the agenda. =u=
358 will unmark the etry at point, and =U= will unmark everything.
359 When one or more entries have been selected, the =B= key will
360 execute an action on all selected entries. I believe this bulk
361 action makes mainly sense for the commands that require answering
362 interactive prompts. So far the supported actions are
364 - Refile all selected entries to a single destination
365 - Archive all selected entries
366 - Set the TODO state of all selected entries, bypassing any
367 blocking or note-taking.
368 - Add or remove a tag to/from all selected entries
370 We can add more actions, if you convince me they make sense.
374 To make room for the new Bulk action commands, some keys in the
375 agenda buffer had to move:
377 There is a new command bound to the =v= key, it dispatches
378 various view mode changes. Month and year view are now only
379 available as =v m= and =v y=, respectively. Turning on
380 inclusion of archive trees and files (unsed to be on =v=) is
381 now on =v a= and =v A=.
383 ** Improvements related to =#+begin= blocks
387 =#+begin_ ... +#end_...= blocks may now be indented along
388 with the structure of your document. So the =#+= lines no
389 longer need to start in column 0, these lines can be, along
390 with the block contents, indented arbitrarily. Org supports
391 this during editing with "C-c '", and now finally treats them
392 consistently during export across all backends. This makes
393 these blocks work much better with plain list structure
394 editing, and it also looks better if you like to indent text
395 under outline headings. For example:
398 ,*** This is some headline
400 , here we have an example
405 , - a second sublist item
408 , centering within the plain list item
412 , This example does terminate the sublist,
413 , the indentation of the #+begin line counts.
416 , - but the top level plain lists continues here
419 From now on, the indentation of such a block decides whether
420 it is part of a plain list item or if it is actually
421 terminating the list. This was so far inconsistent between
422 editing behavior and export, now it is consistent.
424 The content of the block, i.e. the text between the #+ lines
425 gets an extra indentation of two space characters, which I
426 find visually pleasing. You can change the amount of extra
427 indentation using the variable
428 =org-src-content-indentation=.
430 This was a pretty complex change, achieved in many small
431 steps over the last couple of weeks. It cleans up one of the
432 more annoying inconsistencies in Org. I hope it will work,
433 but I am sure you will let me know if not.
437 Also tables can be fully indented now. What is new here is
438 that the =#+TBLFM= line, and also things like =#+caption=,
439 =#+label=, =#+attr_...= etc can be indented along with the
440 table. Again, this makes the look of the document better and
441 allows for proper plain list structure editing.
445 Some =#+begin_ ... +#end_...= blocks contain text that should not
446 be processed like normal Org-mode text. =example= and =src=
447 block fall into this class, and so do =ditaa= blocks, for
448 example. The content in such blocks is now properly fontified in
449 a single face (called =org-block=). This was a frequently
450 requested feature. The list of blocks that should be protected
451 from normal Org-mode fontification is defined in the variable
452 =org-protecting-blocks=. Modules defining new blocks should add
453 to this variable when needed. =org-exp-blocks.el= does this
456 *** Hide and show the contents of blocks
458 Blocks can now be folded and unfolded with =TAB=. If you
459 want to have all blocks folded on startup, customize
460 =org-hide-block-startup= or use the =#+STARTUP= options
461 =hideblocks= or =showblocks= to overrule this variable on a
464 Thanks to Eric Schulte for a patch to this effect.
466 *** Moved Eric Schulte's org-exp-blocks.el into the core
468 This seems to be getting a lot of use now, so it is now part of
469 the core and loaded automatically. This package can now also be
470 used to define new blocks. Customize the variable
471 =org-export-blocks= or use the function
472 =org-export-blocks-add-block=.
475 ** New and updated contributed modules
476 *** org-export-generic.el is now a contributed package.
478 This new module allows users to export an Org page to any type of
479 output by constructing the output using a list of prefixes,
480 format specifications and suffixes for the various types of org
481 data (headlines, paragraphs, list bullets, etc). Use the
482 =org-set-generic-type= function to define your own export types
483 and have them bound to a key (use an upper-case letter for user
486 Thanks to Wes Hardaker for this contribution with a lot of
488 *** New contributed modules org-mac-iCal.el by Christopher Suckling
490 See the [[http://orgmode.org/worg/org-contrib/org-mac-iCal.php][documentation on Worg]].
492 *** org-jira.el: New file, by Jonathan Arkell
494 Links to Jira tickets.
496 *** org-R.el: Updated.
498 /org-R.el/ has been updated, thanks to Dan Davison for this.
500 *** =[ TABLE-OF-CONTENTS]= is now also used for LaTeX export
502 This cookie will mark the location of the =\tableofcontents=
503 macro. Triggered by a report by Yuva.
506 ** Changes to the clocking system
507 *** New option `org-clock-out-switch-to-state'.
509 Clocking out can now switch the task to a particular state.
511 This was a request by Manish.
513 *** More control about what time is shown in mode line while clocking
515 - If you have an =Effort= property defined, its value is also
516 shown in the mode line, and you can configure =org-clock-sound=
517 to get an alert when your planned time for a particular item is
520 - When an entry has been clocked earlier, the time shown in the
521 mode line while the item is being clocked is now the sum of all
522 previous, and the current clock.
524 - The exception to the previous rule are repeating entries: There
525 the clock time will only be clocking instances recorded since
526 the last time the entry when through a repeat event. The time
527 of that event is now recorded in the =LAST_REPEAT= property
529 - You can use the property CLOCK_MODELINE_TOTAL to get
530 control over what times are displayed in the mode line, see
531 the manual for more information.
533 - The new command =C-c C-x C-e= can be used to change the Effort
534 estimate and therefore to change the moment when the clock sound
537 - The clock string in the modeline now has a special font,
538 =org-mode-line-clock=. This was a proposal by Samuel Wales.
540 - Clicking on the mode line display of the clock now offers a
541 menu with important clock functions like clocking out, or
542 switching the clock to a different task.
544 Thanks to Konstantin Antipin for part of the implementation, and
545 thanks to Bernt Hansen for helping to iron out the issues related
549 ** Miscellaneous changes
551 *** Allow to specify the alignment in table columns by hand
553 Similar to the =<20>= cookies that allow to specify a maximum
554 width for a table column, you can now also specify the alignment
555 in order to overrule the automatic alignment choice based on the
556 dominance of number or non-number fields in a column. The
557 corresponding cookies are =<l>= and =<r>= for left and right side
558 alignment, respectively. These can be combined with maximum
559 width specification like this: =<r15>=.
561 This was a proposal by Michael Brand.
563 *** Stop logging and blocking when selecting a TODO state
565 Sometimes you want to quickly select or change a TODO state of an
566 item, without being bothered by your setup for blocking state
567 changes and logging entries. So in this case, you don't want the
568 change be seen as a true state change.
570 You can now set the variable
571 =org-treat-S-cursor-todo-selection-as-state-change= to nil.
572 Then, when you use =S-left= and =S-right= to quickly flip through
573 states, blocking and logging will be temporarily disabled.
575 *** Export BBDB anniversaries to iCalendar
577 See the variable `org-icalendar-include-bbdb-anniversaries'.
579 This was a request by Richard Riley, thanks to Thomas Baumann
580 for the prompt implementation.
582 *** Macro definitions can be collected in an #+SETUPFILE
584 If you want to use many macros in different files, collect the
585 =#+macro= lines into a file and link to them with
587 : #+SETUPFILE: path/to-file
589 *** Subtree cloning now also shifts inactive dates
591 When using the command =org-clone-subtree-with-time-shift=, time
592 stamps will be shifted for each clone. So far, this applied only
593 to active timestamps, but now it does apply to inactive
596 *** HTML table export: Assign alternating classes to rows
598 The new variable =org-export-table-row-tags= can now be set up in
599 a way so that different table lines get special CSS classes
600 assigned. This can be used for example to choose different
601 background colors for odd and even lines, respectively. The
602 docstring of the variable contains this example:
604 #+begin_src emacs-lisp
605 (setq org-export-table-row-tags
608 (if (= (mod nline 2) 1)
609 "<tr class=\"tr-odd\">"
610 "<tr class=\"tr-even\">"))
614 It makes use of the local variables =head= and =nline= which are
615 used to check whether the current line is a header line, and whether
616 it is an odd or an even line. Since this is fully programmable,
617 you can do other things as well.
619 This was a request by Xin Shi.
621 *** Remember: target headline may be a function
623 When setting up remember templates, the target headline may now
624 be a function, similarly to what is allowed for the target file.
625 The functions needs to return the headline that should be used.
627 *** Remove flyspell overlays in places where they are not wanted
629 We now keep flyspell from highlighting non-words in links.
631 *** Update targets in the Makefile
633 Some new targets in the default Makefile make it easier to update
634 through git to the latest version: =update= and =up2=. Here are
637 #+begin_src BSDmakefile
647 This was a request by Konstantin Antipin.
656 *** Macros for export
658 Macro processing for export has been enhanced:
660 - You can use arguments in a macro, for example
662 #+macro hello Greet the $1: Hello $1
664 which would turn ={{{hello(world)}}}= into =Greet the world: Hello world=
666 - The macro value can be an emacs-lisp for to be evaluated at the
670 ,#+macro: datetime (eval (format-time-string "$1"))
673 - More built-in default macros:
674 - date(FORMAT_TIME_STRING) :: Time/Date of export
675 - time(FORMAT_TIME_STRING) :: Same as date
676 - modification-time(FORMAT_TIME_STRING) :: Last modification of file
677 - input-file :: Name of the input file
679 The new built-in macros have been requested by Daniel Clemente.
681 *** Link completion for files and bbdb names
683 Org now has a general mechanism how modules can provide enhanced
684 support (for example through completion) when adding a link. For
685 example, when inserting a link with =C-c C-l=, you can now type
686 =file:= followed by =RET= to get completion support for inserting
687 a file. After entering =bbdb:= and =RET=, a completion interface
688 will allow to complete names in the BBDB database. These are the
689 only ones implemented right now, but modules that add a link type
690 =xyz:= can simple define =org-xyz-complete-link= that should
691 return the full link with prefix after aiding the used to create
692 the link. For example, if you have =http= links that you have to
693 insert very often, you could define a function
694 =org-http-complete-link= to help selecting the most common ones.
696 *** Source file publishing
698 It is now easy to publish the Org sources along with, for
699 example, HTML files. In your publishing project, replace
701 : :publishing-function org-publish-org-to-html
705 : :publishing-function (org-publish-org-to-html org-publish-org-to-org)
709 to get both the plain org file and an htmlized version that
710 looks like your editing buffer published along with the HTML
713 *** Push exported stuff to kill ring
715 All exporters now push the produced material onto the kill-ring
716 in Emacs, and also to the external clipboard and the primary
717 selection to make it easy to paste this under many circumstances.
719 *** Tables in LaTeX without centering
720 Set the variable `org-export-latex-tables-centered' to nil if you
721 prefer tables not to be horizontally centered. Note that
722 longtable tables are always centered.
724 *** LaTeX export: TODO markup configurable
726 The markup for TODO keywords in LaTeX export is now configurable
727 using the variable =org-export-latex-todo-keyword-markup=.
729 *** ASCII export to buffer
731 ASCII export has now the same command variations as the other
732 export backends, for example exporting to a temporary buffer
735 The was a request by Samuel Wales.
737 *** Accessibility improvements for HTTP tables
739 When exporting tables to HTML, Org now adds =scope= attributes to
740 all header fields, in order to support screen readers.
742 =org-export-html-table-use-header-tags-for-first-column= will
743 request using =<th>= instead of =<td>= also in the entire first
744 column, so that also row information can be scoped. This was
745 triggered by a request by Jan Buchal, and as usually Sebastian
746 Rose came up with the right implementation.
748 *** Timezone information in iCalendar files
750 The timezone information in iCalendar files is now written in the
751 correct format, and can be set in the variable
752 =org-ical-timezone=. This variable is initialized from the =TZ=
753 environment variable.
755 *** New contributed package /org-special-blocks.el/
757 The package turns any "undefined" =#+begin_...= blocks into LaTeX
758 environments for LaTeX export, and into =<div>= tags for HTML
761 Thanks to Chris Gray for this contribution.
763 *** More flexibility about placing logging notes.
765 Logging into a drawer can now also be set for individual
766 subtrees using the =LOG_INTO_DRAWER= property.
768 Requested by Daniel J. Sinder
772 Reloading Org has moved to a new key, =C-c C-x !=, and is now
773 also available in the agenda.
775 *** Start Agenda with log mode active
776 Set the new option =org-agenda-start-with-log-mode= to have
777 log mode turned on from the start. Or set this option for
778 specific custom commands.
780 Thanks to Benjamin Andresen for a patch to this effect.
782 *** Agenda speed optimizations
784 Depending on circumstances, construction the agenda has become a
787 Triggered by Eric S Fraga's reports about using Org on a slow
788 computer like a netbook.
790 *** New face for today in agenda
792 The date that is today can now be highlighted in the agenda by
793 customizing the face =org-agenda-date-today=.
795 Thanks to Dmitri Minaev for a patch to this effect.
797 *** Properties to disambiguate statistics
799 When an entry has both check boxes and TODO children, it is not
800 clear what kind of statistics a cookie should show You can now use
801 the =COOKIE_DATA= property to disambiguate, by giving it a value
802 "todo" or "checkbox".
804 Thanks to Ulf Stegeman, who was persistent enough to push this
805 change past my initial resistance.
807 *** Checkboxes and TODO items: recursive statistics
809 Setting the variable =org-hierarchical-checkbox-statistics= to
810 =nil= will make statistics cookies count all checkboxes in the
811 lit hierarchy below it.
813 Setting the variable =org-hierarchical-todo-statistics= to
814 =nil= will do the same for TODO items.
816 To turn on recursive statistics only for a single subtree, add the
817 word "recursive" to the =COOKIE_DATA= property. Note that you
818 can have such a property containing both "todo" or "checkbox" for
819 disambiguation, and the word "recursive", separated by a space
822 The change for checkboxes was a patch by Richard Klinda.
824 *** New operators for column view
826 Column view has new operators for computing the minimum,
827 maximum, and mean of property values.
829 Thanks to Mikael Fornius for a patch to this effect.
840 Entries can now define a =CUSTOM_ID= property. This property
841 must be a valid ID according to HTML rules, and it will be used
842 in HTML export as the main target ID for this entry. That means,
843 both the table of conents and other internal links will
844 automatically point to this ID instead of the automatic ID like
845 =sec-1.1=. This is useful to create humar-readable permanent
846 links to these location in a document.
848 The user is responsible to make sure that custom IDs are unique
851 Links written like =[[#my-target-name] ]= can be used to target a
854 When using =C-c l= to store a link to a headline that has a
855 custom ID, Org will now create two links at the same time. One
856 link will be to the custom ID. The other will be to the globaly
857 unique ID property. When inserting the line with =C-c C-l=, you
858 need to decide which one you want to use. Use the ID links for
859 entries that are expected to move from one file to the next. Use
860 custom ID links publishing projects, when you are sure that te
861 entry will stay in that file. See also the variable
862 =org-link-to-org-use-id=.
864 *** Remember to non-org files
866 If the target headline part of a remember template definition
867 entry is =top= or =bottom=, the target file may now be a
868 non-Org-mode file. In this case, the content of the remember
869 buffer will be added to that file without enforcing an Org-like
870 headline. Sorry, Russel, that this took so long.
872 *** New property to turn off todo dependencies locally
874 Setting the property =NOBLOCKING= will turn off TODO dependency
875 checking for this entry.
879 A new function is called to verify tasks that are about to be
880 selected as remember targets. See the new variable
881 =org-refile-target-verify-function=.
883 *** New version org ditaa.jar
885 Thanks to Stathis Sideris.
887 *** htmlize.el is now in the contrib directory
889 The latest version of htmlize.el is now the in the contrib
890 directory of Org. Thanks to Hrvoje Niksic for allowing this.
897 ** Major new features
901 We now do have a fully functional DocBook exporter, contributed by
902 Baoqiu Cui. Simple press =C-c e D= to export the current file to
903 DocBook format. You can also get direct conversion to PDF if you have
904 made the correct setup, please see the manual for details.
906 Kudos to Baoqiu for this fantastic addition, and my personal thanks
907 for doing this in a such a smooth way that I did not have to do
910 *** Protocols for external access to Emacs and Org
912 /org-protocol.el/ is a new module that supersedes both
913 /org-annotation-helper.el/ and /org-browser.el/ and replaces them
914 with a more abstracted interface. /org-protocol/ intercepts
915 calls from emacsclient to trigger custom actions without external
916 dependencies. Only one protocol has to be configured with your
917 external applications or the operating system, to trigger an
918 arbitrary number of custom actions. Just register your custom
919 sub-protocol and handler with the new variable
920 =org-protocol-protocol-alist=.
922 org-protocol comes the with three standard protocol handlers (in
923 parenthesis the name of the sub-protocol):
924 - =org-protocol-remember= (=remember=) :: Trigger remember
925 - =org-protocol-store-link= (=store-link=) :: Store a link
926 - =org-protocol-open-source= (=open-source=) :: Find the local
927 source of a remote web page.
929 Passing data to emacs is now as easy as calling
931 : emacsclient org-protocol://sub-protocol://data
933 For more information see the [[http://orgmode.org/worg/org-contrib/org-protocol.php][online documentation]]
935 Thanks to Sebastian Rose for this really beautiful module.
939 Inline tasks are tasks that have all the properties of normal
940 outline nodes, including the ability to store meta data like
941 scheduling dates, TODO state, tags and properties. But these
942 tasks are not meant to introduce additional outline structure, at
943 least as far as visibility cycling and export is concerned. They
944 are useful for adding tasks in extensive pieces of text where
945 interruption of the flow or restructuring is unwanted.
947 This feature is not turned on by default, you need to configure
948 =org-modules= to turn it on, or simply add to you .emacs file:
950 : (require 'org-inlinetask)
952 After that, tasks with level 15 (30 stars when using
953 org-odd-levels-only) will be treated as inline tasks, and
954 fontification will make obvious which tasks are treated in this
957 *** Input from RSS feeds
959 Org can now collect tasks from an RSS feed, a great method to get
960 stuff from online call and note-taking services into your trusted
961 system. You need to configure the feeds in the variable
962 =org-feed-alist=. The manual contains a short description, more
963 detailed information is [[http://orgmode.org/worg/org-contrib/org-feed.php][available on Worg]].
965 Full credit goes to Brad Bozarth who really [[http://thread.gmane.org/gmane.emacs.orgmode/12251][paved the way]] for this
966 exciting new feature.
971 *** Allow modification of table attributes in HTML export
973 The #+ATTR_HTML line can now be used to set attributes for a
974 table. Attributes listed in that line will replace existing
975 attributes in =org-export-html-table-tag=, or will add new ones.
978 : #+ATTR_HTML: border="2" rules="all" frame="all"
979 : #+CAPTION: Finally a table with lines!
984 *** LaTeX low levels are now exported as itemize lists
986 LaTeX export now treats hierarchy levels 4,5, etc as itemize
987 lists, not as description lists as before. This is more
988 consistent with the behavior of HTML export. You can configure
989 this behavior using the variable =org-export-latex-low-levels=.
991 *** Markup for centering.
993 Text can be exported centered with
997 ,Everything should be made as simple as possible, \\
1002 *** Sitemap file is now /sitemap.org/
1004 Org-publish can produce a list of all files in a project.
1005 Previously the file containing this list was called "index.org",
1006 really a brain-dead default because during publication it would
1007 overwrite the "index.html" file of the website.
1009 The default file name is now "sitemap.org"
1011 *** Protect explicit target links in HTML export
1013 If a link is =[[#name] [desc]]=, the href produced when exporting
1014 the file will be exactly href="#name". So starting a link target
1015 with # will indicate that there will be an explicit target for
1018 *** HTML export: Allow "- ___" to explicitly terminate a list
1020 If a list contains "- ___" (three underscores) as an item, this
1021 terminates the list, ignoring this item. This is an experimental
1022 feature, it may disappear again if we find other ways to deal
1023 with literal examples right after lists.
1025 See [[http://thread.gmane.org/gmane.emacs.orgmode/12299/focus%3D12312][this mailing list thread]] for context.
1029 *** Changing the time of an entry from the agenda
1031 We now have a way to change not only the date, but also the start
1032 time of an entry from the agenda. The date is normally changed
1033 with S-right/left. Now, if you add a C-u prefix, the hour will
1034 be changed. If you immediately press S-right/left again, hours
1035 will continue to be changed. A double prefix will do the same
1036 for minutes. If the entry has a time range like 14:40-16:00,
1037 then both times will change, preserving the length of the
1040 *** Show saved PDF agenda view with prefix arg
1042 When writing an agenda view to a PDF file, supplying a a prefix
1043 argument (=C-u C-x C-w=) will get the new file displayed
1046 This was a request by Alan E Davis.
1048 *** Filter for entries with no effort defined
1050 During secondary agenda filtering, pressing "?" now will install a
1051 filter that selects entries which do not have an effort defined.
1053 This new model was necessary because we needed to stop interpreting
1054 entries with no effort defines as 0 effort. This was inconsistent,
1055 because for normal agenda sorting, the treatment of these entries
1056 depends on the variable =org-sort-agenda-noeffort-is-high=. Now this
1057 variable is also respected during filtering.
1059 This new feature resulted from a [[http://thread.gmane.org/gmane.emacs.orgmode/12493][discussion]] with Matt Lundin and
1062 *** Introduce user-defined sorting operators
1064 The new variable =org-agenda-cmp-user-defined= can contain a
1065 function to test how two entries should be compared during
1066 sorting. The symbols =user-defined-up= and =user-defined-down=
1067 can then be part of any sorting strategy.
1069 This was a request by Samuel Wales.
1071 *** Indentation of subitems in the agenda
1073 When a tags/property match does match an entry and it's
1074 sublevels, the sublevels used to be indented by dots, to indicate
1075 that the matches likely result from tag inheritance. This is now
1076 no longer the default, so the subitems will not get special
1077 indentation. You can get this behavior back with
1079 : (setq org-tags-match-list-sublevels 'indented)
1081 *** Stuck projects search now searches subtrees of unstuck projects
1083 When, during a stuck-project search, a project tree is identified
1084 as not stuck, so far the search would continue after the end of
1085 the project tree. From now on, the search continues in the
1086 subtree, so that stuck subprojects can still be identified.
1091 *** Citations: Use RefTeX to insert citations
1093 RefTeX can now be used to create a citation in Org-mode buffers.
1094 Setup the buffer with
1097 ,#+BIBLIOGRAPHY: bibbase style
1100 and create citations with =C-c C-x [=.
1102 Together with org-exp-bibtex.el by Taru Karttunen (available as a
1103 contributed package), this provides a great environment for
1104 including citations into HTML and LaTeX documents.
1106 *** Changing time ranges as a block
1108 When using the S-cursor keys to change the first time in a time
1111 : <2009-04-01 Wed 14:40-16:40>
1113 then the end time will change along, so that the duration of the
1114 event will stay the same.
1116 This was a request by Anupam Sengupta.
1118 *** New sparse tree command
1120 A new sparse tree command shows entries with times after a certain
1121 date. Keys are =C-c / a=, this command is for symmetry
1126 A new command allows to create clone copies of the current entry,
1127 with shifted dates in all stamps in the entry. This is useful to
1128 create, for example, a series of entries for a limited time
1129 period. I am using it to prepare lectures, for example.
1131 *** New face for checkboxes
1133 Checkboxes now have their own face, =org-checkbox=. This can be
1134 used for nice effects, for example choosing a face with a box
1137 #+begin_src emacs-lisp
1139 (org-checkbox ((t (:background "#444444" :foreground "white"
1140 :box (:line-width 1 :style released-button)))))
1143 *** M-a and M-e for navigation in a table field
1145 In tables fields, the sentence commands =M-a= and =M-e= are
1146 redefined to jump to the beginning or end of the field.
1148 This was a request by Bastien Guerry.
1150 *** Backup files for remember buffers
1152 Sometimes users report that they lost data when not immediately
1153 storing a new remember note, and then later exiting Emacs or
1154 starting a new remember process.
1156 Now you can set the variable =org-remember-backup-directory=.
1157 Each remember buffer created will then get its own unique file
1158 name in that directory, and the file will be removed only if the
1159 storing of the note to an Org files was successful.
1161 *** org-mac-message.el: New functions to access flagged mail
1163 Christopher Suckling has added functionality to
1164 /org-mac-message.el/. In particular, you can now select a number
1165 of messages and easily get links to all of them with a single
1166 command. For details, see the [[http://orgmode.org/worg/org-contrib/org-mac-message.php][online documentation]].
1168 *** Read-date: New hook
1170 The new hook =org-read-date-minibuffer-setup-hook= is called when
1171 setting up the minibuffer for reading a date. If can be used to
1172 install new keys into the temporary keymap used there.
1180 ** Incompatible changes
1183 *** Tag searches are now case-sensitive
1185 From this release on, tag searches will be case sensitive. While
1186 I still think it would be nice to have them case-insensitive,
1187 this was both an inconsistency (TODO keyword searches have always
1188 been case-sensitive), and trouble for coding some efficient
1189 algorithms. So please make sure that you give the tags with
1190 correct casing when prompted for a match expression.
1192 *** New key for creating tags/property sparse trees
1194 The key to produce a sparse tree matching tags and properties is
1195 now =C-c / m= instead of =C-c a T=. This is also more consistent
1196 with the =C-c a m= key for the corresponding agenda view.
1197 =C-c / T= will still work for now, but it is no longer advertised
1198 in the documentation and may go away at any time in the future.
1200 *** IDs in HTML have "ID-" prefix when generated by uuidgen
1202 /uuidgen/ generates IDs that often start with a number, not a
1203 latter. However, IDs and names in XHTML must start with a letter.
1204 Therefore, IDs in HTML files will now get an "ID-" prefix if they
1205 have been generated by uuidgen. This means that id links from one
1206 file to another may stop working until all files have been
1209 *** In agenda, only priority cookies get the special face
1211 So far, an entire task would get a special face when
1212 =org-agenda-fontify-priorities= was set. Now, the default value
1213 for this variable is the symbol =cookies=, which means that on
1214 the cookie is fontified. Set it to =t= if you want the entire
1215 task headline to be fontified.
1219 *** PDF export of agenda views
1221 Agenda views can now be exported to PDF files by writing them to
1222 a file with extension ".pdf". Internally this works by first
1223 producing the postscript version and then converting that to PDF
1224 using the ghostview utility =ps2pdf=. Make sure that this
1225 utility is installed on your system.
1227 The postscript version will not be removed, it will stay around.
1229 *** Inline some entry text for Agenda View export
1231 When exporting an agenda view to HTML or PDF for printing or
1232 remote access, one of the problems can be that information stored
1233 in entries below the headline is not accessible in that format.
1235 You can now copy some of that information to the agenda view
1236 before exporting it. For this you need to set the variable
1237 =org-agenda-add-entry-text-maxlines= to a number greater than 0.
1239 #+begin_src emacs-lisp
1240 (setq org-agenda-add-entry-text-maxlines 20)
1243 Or you can do this with the settings in a custom agenda view,
1246 #+begin_src emacs-lisp
1248 ((org-agenda-ndays 1)
1249 (org-agenda-add-entry-text-maxlines 5))
1250 ("agenda-today.pdf"))
1253 *** Improved ASCII export of links
1255 ASCII export of links works now much better. If a link has a
1256 link and a description part which are different, then the
1257 description will remain in the text while the link part will be
1258 moved to the end of the current section, before the next heading,
1259 as a footnote-like construct.
1261 Configure the variable =org-export-ascii-links-to-notes= if you
1262 prefer the links to be shown in the text. In this case, Org will
1263 make an attempt to wrap the line which may have become
1264 significantly longer by showing the link.
1266 Thanks to Samuel Wales for pointing out the bad state of ASCII
1269 *** Custom agenda commands can specify a filter preset
1271 If a custom agenda command specifies a value for
1272 =org-agenda-filter-preset= in its options, the initial view of
1273 the agenda will be filterd by the specified tags. Applying a
1274 filter with =/= will then always add to that preset filter,
1275 clearing the filter with =/ /= will set it back to the preset.
1276 Here is an example of a custom agenda view that will display the
1277 agenda, but hide all entries with tags =FLUFF= or =BLUFF=:
1279 #+begin_src emacs-lisp
1281 ((org-agenda-filter-preset '("-FLUFF" "-BLUFF"))))
1284 This is in response to a [[http://thread.gmane.org/gmane.emacs.orgmode/11752][thread on the mailing list]], started by
1285 Daniel Clemente and with great contributions by Bernt Hansen and
1288 *** Exporting of citations to LaTeX and HTML, using BibTeX
1290 Citations can now me made using BibTeX, and will be exported to
1291 LaTeX and HTML. This is implemented in a contributed package by
1292 Taru Karttunen, /org-exp-bibtex.el/. Kudos to Taru for this
1293 really nice addition.
1295 *** Finally a way to specify keywords and description for HTML export
1300 #+DESCRIPTION: This page is all about ....
1301 #+KEYWORDS: org-mode, indexing, publishing
1304 To specify the content of the description and keywords meta tags
1307 *** org-collector.el is now a contributed package
1309 /org-collector.el/ provides functions to create tables by
1310 collecting and processing properties from entries in a specific
1311 scope like the current tree or file, or even from all agenda
1312 files. General lisp expressions can be used to manipulate the
1313 property values before they are inserted into an org-mode table,
1314 for example as a dynamic block that is easy to update.
1316 Thanks to Eric Schulte for yet another great contribution to
1319 *** Update of org2rem.el
1321 /org2rem.el/ has been updated significantly and now does a more
1322 comprehensive job of exporting Org events to remind.
1324 Thanks to Sharad Pratap for this update.
1326 *** New div around the entire page in HTMP export
1328 A new =<div id=content>= is wrapped around the entire page,
1329 everything that is inside =<body>=.
1331 This means that you need to update /org-info.js/ (if you have a
1332 local copy). It will be safe todo so, because the new
1333 org-info.js still handles older pages correctly. Thanks to
1334 Sebastian Rose for making these changes so quicky.
1336 *** Clustering characters for undo
1338 When typing in Org-mode, undo will now remove up to 20 characters
1339 at a time with a single undo command. This is how things work
1340 normally in Emacs, but the special binding of characters in
1341 Org-mode made this impossible until now.
1343 Thanks to Martin Pohlack for a patch which mimicks the behavior
1344 of the Emacs command loop for the Org version of
1345 =self-insert-command=. Note that this will not work in headlines
1346 and tables because typing there will do a lot of extra work.
1348 There might be a small typing performance hit resulting from this
1349 change - please report in the mailing list if this is noticeable
1352 *** Separate settings for special C-a and C-e
1354 The variable `org-special-ctrl-a/e' now allows separate settings
1355 for =C-a= and =C-e=. For example
1357 #+begin_src emacs-lisp
1358 (setq org-special-ctrl-a/e '(reversed . t))
1361 Thanks to Alan Davis for this proposal.
1363 *** orgstruct++-mode improvements
1365 In addition to =orgstruct-mode= which allows to use some Org-mode
1366 structure commands in other major modes, there is a more invasive
1367 version of this mode: =orgstruct++-mode=. This mode will import
1368 all paragraph and line wrapping variables into the major mode, so
1369 that, for example, during typing the auto-fill wrapping of items
1370 will work just like in Org-mode. This change is not reversible,
1371 so turning off =orgstruct++-mode= will not remove these settings
1372 again. =orgstruct++-mode= is most useful in text modes like
1373 message-mode or =magit-log-edit-mode=. Furthermore,
1374 =orgstruct++-mode= will recognize plain list context not only in
1375 the first line of an item, but also further down, so that =M-RET=
1376 will correctly insert new items.
1378 Thanks to Austin Frank for requesting some of these changes.
1380 *** Promotion and demotion works for regions now
1382 =M-right= and =M-left= now do demote and promote all headlines in
1385 *** Match syntax for tags/properties is now described in a single place
1387 The manual chapters about tags and about properties now only
1388 refer to the section about agenda views, where the general syntax
1389 of tag/property matches is described.
1391 *** Macro replacement
1393 A string like ={{{ title }}}= will be replaced by the title of
1394 the document, ={{{ email }}}= by the email setting of the author
1395 and similarly for other export settings given in =#+...= lines.
1396 In addition to that, you can define an arbitrary number of
1397 macros, for example:
1400 ,#+MACRO: myaddress 41 Onestreet, 12345 New York, NY
1402 ,my address is {{{myaddress}}}, see you there.
1405 Macro replacement is the very first thing that happens during
1406 export, and macros will be replaced even in source code and other
1409 *** New reload command, with keyboard access
1411 There is now a special command to reload all Org Lisp files, so
1412 that you can stay in your Emacs session while pulling and
1413 compiling changes to Org. The command to reload the compiled
1414 files (if available) is =C-c C-x r=. If no compiled files are
1415 found, uncompiled ones will be loaded. If you want to force
1416 loading of uncompiled code (great for producing backtraces), use
1417 a prefix arg: =C-u C-c C-x r=. Both commands are available in
1420 This new command was inspired by one written earlier by Bernt
1423 *** Faces for priority cookies can now be set freely
1425 The new variable =org-priority-faces= can be used to set faces
1428 *** New key for creating tags/property sparse trees
1430 The key to produce a sparse tree matching tags and properties is
1431 now =C-c / m= instead of =C-c a T=. This is more consistent with
1432 the =C-c a m= key for the corresponding agenda view. =C-c / T=
1433 will still work for now, but it is no longer advertised in the
1434 documentation and may go away at any time in the future.
1436 *** IDs in HTML have "ID-" prefix when generated by uuidgen
1438 /uuidgen/ generates IDs that often start with a number, not a
1439 letter. However, IDs and names in XHTML must start with a letter.
1440 Therefore, IDs in HTML files will now get an "ID-" prefix if they
1441 have been generated by /uuidgen/. This means that id links from one
1442 file to another may stop working until all files have been
1443 exported again, so that both links and targets have the new prefix.
1445 *** In agenda, only priority cookies get the special face
1447 So far, an entire task would get a special face when
1448 =org-agenda-fontify-priorities= was set. Now, the default value
1449 for this variable is the symbol =cookies=, which means that on
1450 the cookie is fontified. Set it to =t= if you want the entire
1451 task headline to be fontified.
1453 *** Turning off time-of-day search in headline
1455 Some people like to put a creation time stamp into a headline and
1456 then get confused if the time-of-day found in there shows up as
1457 the time-of-day of the deadline/scheduling entry for this
1458 headline. The reason for this is that Org searches the headline
1459 for a free-format time when trying to sort the entry into the
1460 agenda, and that search accidentally finds the time in the
1461 creation time stamp or something else that happens to look like a
1462 time. If this is more painful than useful for you, configure the
1463 new variable =org-agenda-search-headline-for-time=.
1472 - Capture state change notes into a drawer
1473 - Clock lines are now captured into the LOGBOOK drawer as well
1474 - Added org-R.el to contrib directory
1475 - Allow individual formatting of each TODO keyword in HTML export
1476 - New hooks for add-ons to tap into context-sensitive commands
1477 - Publishing files irrespective of extension
1478 - New variable index in the manual
1479 - The ORDERED property also influences checkboxes
1480 - The ORDERED property can be tracked with a tag
1481 - You may now specify line breaks in the fast tags interface
1482 - When a TODO is blocked by checkboxes, keep it visible in agenda
1483 - LaTeX can import Org's in-buffer definitions for TITLE, EMAIL etc.
1485 ** Incompatible changes
1487 - CLOCK lines will now be captured into the LOGBOOK drawer.
1488 See below for details.
1492 *** Capture state change notes into a drawer
1494 State change notes can now be captured into a drawer =LOGBOOK=,
1495 to keep the entry tidy. If this is what you want, you will need
1498 #+begin_src emacs-lisp
1499 (setq org-log-into-drawer "LOGBOOK")
1502 Thanks to Wanrong Lin for this proposal.
1504 *** Clock lines are now captured into the LOGBOOK drawer as well
1506 The =CLOCK= drawer will be abandoned, clock lines will now also
1507 end up in a drawer =LOGBOOK=. The reason for this is that it's a
1508 bit useless to have two different drawers for state change notes
1509 and clock lines. If you wish to keep the old way, use
1511 #+begin_src emacs-lisp
1512 (setq org-clock-into-drawer "CLOCK")
1515 *** Added org-R.el to contrib directory
1517 Dan Davison has contributed /org-R.el/ which is now in the
1518 contrib directory. Org-R performs numerical computations and
1519 generates graphics. Data can come from org tables, or from csv
1520 files; numerical output can be stored in the org buffer as org
1521 tables, and links are created to files containing graphical
1522 output. Although, behind the scenes, it uses R, you do not need
1523 to know anything about R. Common operations, such as tabulating
1524 discrete values in a column of an org table, are available "off
1525 the shelf" by specifying options on lines starting with =#+R:=.
1526 However, you can also provide raw R code to be evaluated. The
1527 documentation is currently the worg tutorial at
1528 http://orgmode.org/worg/org-tutorials/org-R/org-R.php
1530 Thanks to Dan for this great contribution.
1532 *** Allow individual formatting of TODO keyword and tags in HTML export
1534 TODO keywords in HTML export have the CSS class =todo= or =done=.
1535 Tags have the CSS class =tag=. In addition to this, each keyword
1536 has now itself as class, so you could do this in your CSS file:
1539 .todo { font-weight:bold; }
1540 .done { font-weight:bold; }
1541 .TODO { color:red; }
1542 .WAITING { color:orange; }
1543 .DONE { color:green; }
1546 If any of your keywords causes conflicts with CSS classes used
1547 for different purposes (for example a tag "title" would cause a
1548 conflict with the class used for formatting the document title),
1549 then you can use the variables =org-export-html-tag-class-prefix=
1550 and =org-export-html-todo-kwd-class-prefix= to define prefixes
1551 for the class names for keywords, for example "kwd-".
1553 Thanks to Wanrong Lin for this request, and to Sebastian Rose for
1554 help with the implementation.
1556 *** New hooks for add-ons to tap into context-sensitive commands
1558 Some commands in Org are context-sensitive, they will execute
1559 different functions depending on context. The most important
1560 example is of course =C-c C-c=, but also the =M-cursor= keys fall
1563 Org has now a system of hooks that can be used by add-on packages
1564 to install their own functionality into these keys. See the
1565 docstring of =org-ctrl-c-ctrl-c-hook= for details. The other
1566 hooks are named like =org-metaleft-hook= or
1567 =org-shiftmetaright-hook=.
1569 *** Publishing files irrespective of extension
1571 If you set the =:base-extension= property for a publishing
1572 project to the symbol =any=, all files in the directory will be
1573 published, irrespective of extension.
1575 Thanks to Richard Klinda for a patch to this effect.
1577 *** New variable index in the manual
1579 A new index in the manual lists all variables mentioned in the
1580 manual, about 200 variables in total.
1582 *** The ORDERED property also influences checkboxes
1584 When an entry has the ORDERED property set, checkboxes in
1585 the entry must be completed in order. This was already the case
1586 for children TODO items, now it also applies for checkboxes.
1588 Thanks to Rainer Stengele for this proposal.
1590 *** The ORDERED property can be tracked with a tag
1592 The =ORDERED= property is used to flag an entry so that subtasks
1593 (both children TODO items and checkboxes) must be completed in
1594 order. This property is most easily toggled with the command
1595 =C-c C-x o=. A property was chosen for this functionality,
1596 because this should be a behavior local to the current task, not
1597 inherited like tags. However, properties are normally
1598 invisible. If you would like visual feedback on the state of
1599 this property, configure the variable
1600 =org-track-ordered-property-with-tag=. If you then use =C-c C-x
1601 o= to toggle the property, a tag will be toggled as well, for
1604 Note that the tag itself has no meaning for the behavior of TODO
1605 items and checkboxes, and that changing the tag with the usual
1606 tag commands will not influence the property and therefore the
1607 behavior of TODO and checkbox commands.
1609 *** You may now specify line breaks in the fast tags interface
1611 Up to now, the fast tags interface tried to lump as many tags as
1612 possible into a single line, with the exception that groups would
1613 always be on a line by themselves.
1615 Now, if you use several lines to define your tags, like
1618 ,#+TAGS: aa(a) bb(b) cc(c)
1619 ,#+TAGS: dd(d) ee(e) ff(f)
1622 then there will also be a line break after the "cc" tag in the
1623 fast tag selection interface. You may also write
1626 ,#+TAGS: aa(a) bb(b) cc(c) \n dd(d) ee(e) ff(f)
1629 to achieve the same effect, and you can use =\n= several times in
1630 order to produce empty lines. In =org-tag-alist=, newlines are
1631 represented as =(:newline)=.
1633 Thanks to Christopher Suckling for a patch to this effect.
1635 *** When a TODO is blocked by checkboxes, keep it visible in agenda
1637 When the variable =org-agenda-dim-blocked-tasks= is set to
1638 =invisible=, tasks that are blocked will not be visible in the
1639 agenda. If the blocking is due to child TODO entries, this does
1640 make sense because the children themselves will show up in the
1643 However, as John Rakestraw has [[http://thread.gmane.org/gmane.emacs.orgmode/10939][pointed out]], if the blocking is
1644 done by checkboxes, no trace of these subtasks is left.
1645 Therefore, when the blocking is done by checkboxes, we now
1646 overrule the =invisible= setting and replace it with mere dimming
1649 *** LaTeX can import Org's in-buffer definitions for TITLE, EMAIL etc.
1651 If you configure =org-export-latex-import-inbuffer-stuff=,
1652 in-buffer definitions like #+TITLE will be made available in the
1653 LaTeX file as =\orgTITLE=.
1655 This was a request by Russel Adams.
1663 *** org-choose.el by Tom Breton is now included
1665 Org-choose helps documenting a decision-making process by using
1666 TODO keywords for different degrees of /chosenness/, and by
1667 automatically keeping a set of alternatives in a consistent state.
1669 Documentation for /org-choose.el/ is available [[http://orgmode.org/worg/org-contrib/org-choose.php][here]].
1671 This package inserts itself into Org using hooks, so if other
1672 people would like to do interesting stuff with TODO keywords for
1673 special purposes, looking at Tom's code might be a good way to
1676 Thanks to Tom for this interesting contribution!
1678 *** orgmode.org and Worg css works now better on IE
1680 Thanks to Sebastian Rose for making these changes.
1682 *** When exporting a subtree, headline levels are now relative to parent
1684 This was reported as a bug by William Henney and is fixed now.
1686 *** Inactive dates in tables can be used for sorting.
1688 When sorting table fields or entries by date, Org first tries to
1689 find an active date, and, if none exist, uses a passive date if
1692 This was a request by Hsui-Khuen Tang
1694 *** The default for =org-return-follows-link= is back to =nil=
1696 Setting it to =t= violates Emacs rules to some extent. The
1697 internal implementation of this has been improved, so setting it
1698 to =t= should now be pretty stable.
1700 *** Automatic scheduling of siblings with org-depend.el
1702 The sibling of a DONE task can now automatically be scheduled.
1704 This was a patch by Andrew Hyatt.
1706 *** New skipping conditions
1708 The functions =org-agenda-skip-entry-if= and
1709 =org-agenda-skip-subtree-if= now accept =timestamp= and
1710 =nottimestamp= as additional conditions.
1712 This was in response to a request by Saurabh Agrawal.
1721 *** Changes to some default values of variables:
1723 Here are the new default values:
1726 (setq org-return-follows-link t)
1728 (setq org-use-fast-todo-selection t)
1730 (setq org-yank-adjusted-subtrees nil)
1732 (setq org-tags-column -77)
1734 (setq org-agenda-sorting-strategy
1735 '((agenda time-up priority-down category-keep)
1736 (todo time-up priority-down category-keep)
1737 (tags time-up priority-down category-keep)
1738 (search category-keep)))
1741 *** Final cleanup for Emacs 21.1 pretest
1750 *** Support for simple TODO dependencies
1752 John Wiegley's code for enforcing simple TODO dependencies has
1753 been integrated into Org-mode. Thanks John!
1755 The structure of Org files (hierarchy and lists) makes it easy to
1756 define TODO dependencies. A parent TODO task should not be
1757 marked DONE until all subtasks (defined as children tasks) are
1758 marked as DONE. And sometimes there is a logical sequence to a
1759 number of (sub)tasks, so that one task cannot be acted upon
1760 before all siblings above it are done. If you customize the
1761 variable =org-enforce-todo-dependencies=, Org will block entries
1762 from changing state while they have children that are not DONE.
1763 Furthermore, if an entry has a property =ORDERED=, each of its
1764 children will be blocked until all earlier siblings are marked
1765 DONE. Here is an example:
1768 ,* TODO Blocked until (two) is done
1777 ,** TODO b, needs to wait for (a)
1778 ,** TODO c, needs to wait for (a) and (b)
1781 The command =C-c C-x o= toggles the value of the =ORDERED=
1784 The variable =org-agenda-dim-blocked-tasks= controls how blocked
1785 entries should appear in the agenda, where they can be dimmed or
1786 even made invisible.
1788 Furthermore, you can use the variable
1789 =org-enforce-todo-checkbox-dependencies= to block TODO entries
1790 from switching to DONE while any checkboxes are unchecked in the entry.
1792 *** Support for shift-selection in Emacs 23
1794 Customize the variable =org-support-shift-select= to use S-cursor
1795 key for selecting text. Make sure that you carefully read the
1796 docstring of that variable first.
1798 *** Adding and removing checkboxes from many lines
1800 The command =C-c C-x C-b= normally toggles checkbox status in the
1801 current line, or in all lines in the region. With prefix
1802 argument it now either adds or removes the checkbox.
1804 This was a requested by Daniel Clemente.
1814 - Improved behavior of conversion commands =C-c -= and =C-c *=
1815 - Table formulas may now reference fields in other tables
1816 - A final hline is imagined in each table, for the sake of references
1817 - A tags-todo search can now ignore timestamped items
1818 - =\par= can be used to force a paragraph break, also in footnotes
1823 *** Improved behavior of conversion commands =C-c -= and =C-c *=
1825 The conversion commands =C-c -= and =C-c *= are now better
1826 behaved and therefore more useful, I hope.
1828 If there is an active region, these commands will act on the
1829 region, otherwise on the current line.
1831 - C-c - :: This command turns headings or normal lines into
1832 items, or items into normal lines. When there is a
1833 region, everything depends on the first line of the
1835 - if it is a item, turn all items in the region into
1837 - if it is a headline, turn all headlines in the region
1839 - if it is a normal line, turn all lines into items.
1840 - special case: if there is no active region and the
1841 current line is an item, cycle the bullet type of the
1843 - C-c * :: This command turns items and normal lines into
1844 headings, or headings into normal lines. When there is
1845 a region, everything depends on the first line of the
1847 - if it is a item, turn all items in the region into
1849 - if it is a headline, turn all headlines in the region
1851 - if it is a normal line, turn all lines into headlines.
1853 *** Table formulas may now reference fields in other tables
1855 You may now reference constants, fields and ranges from a
1856 different table, either in the current file or even in a
1857 different file. The syntax is
1859 : remote(NAME-OR-ID,REF)
1861 where /NAME/ can be the name of a table in the current file as
1862 set by a =#+TBLNAME: NAME= line before the table. It can also be
1863 the ID of an entry, even in a different file, and the reference
1864 then refers to the first table in that entry. /REF/ is an
1865 absolute field or range reference, valid in the referenced table.
1866 Note that since there is no "current filed" for the remote table,
1867 all row and column references must be absolute, not relative.
1869 *** A final hline is imagined in each table, for the sake of references
1871 Even if a table does not end with a hline (mine never do because I
1872 think it is not pretty), for the sake of references you can
1873 assume there is one. So in the following table
1882 a reference like =@I$1..@II$2= will now work.
1884 *** A tags-todo search can now ignore timestamped items
1885 The variables =org-agenda-todo-ignore-with-date=,
1886 =org-agenda-todo-ignore-with-date=, and
1887 =org-agenda-todo-ignore-with-date= make it possible to
1888 exclude TODO entries which have this kind of planning info
1889 associated with them. This is most useful for people who
1890 schedule everything, and who use the TODO list mainly to find
1891 things that are not yet scheduled. Thomas Morgan pointed out
1892 that also the tags-todo search may serve exactly this
1893 purpose, and that it might be good to have a way to make
1894 these variables also apply to the tags-todo search. I can
1895 see that, but could not convince myself to make this the
1896 default. A new variable must be set to make this happen:
1897 =org-agenda-tags-todo-honor-ignore-options=.
1899 *** =\par= can be used to force a paragraph break, also in footnotes
1901 The LaTeX idiom =\par= will insert a paragraph break at that
1902 location. Normally you would simply leave an empty line to get
1903 such a break, but this is useful for footnotes whose
1904 definitions may not contain empty lines.
1910 ** Incompatible changes
1912 *** Short examples must have a space after the colon
1914 Short literal examples can be created by preceding lines
1915 with a colon. Such lines must now have a space after the
1916 colon. I believe this is already general practice, but now
1917 it must be like this. The only exception are lines that are
1918 empty except for the colon.
1922 *** Include files can now also process switches
1924 The example and src switches like =-n= can now also be added
1925 to include file statements:
1927 : #+INCLUDE "~/.emacs" src emacs-lisp -n -r
1929 Thanks to Manish for pointing out that this was not yet
1932 *** Examples can be exported to HTML as text areas
1934 You can now specify a =-t= switch to an example or src block,
1935 to make it export to HTML as a text area. To change the
1936 defaults for height (number of lines in the example) and
1937 width of this area (80), use the =-h= and =-w= switches.
1939 Thanks to Ulf Stegemann for driving this development.
1941 *** LaTeX_CLASS can be given as a property
1943 When exporting a single subtree by selecting it as a region
1944 before export, the LaTeX class for the export will be taken
1945 from the =LaTeX_CLASS= property of the entry if present.
1947 Thanks to Robert Goldman for this request.
1949 *** Better handling of inlined images in different backends
1951 Two new variables govern which kind of files can be inlined
1952 during export. These are
1953 =org-export-html-inline-image-extensions= and
1954 =org-export-latex-inline-image-extensions=. Remember that
1955 links are turned into an inline image if they are a pure link
1956 with no description. HTML files can inline /.png/, /.jpg/,
1957 and /.gif/ files, while LaTeX files, when processed with
1958 /pdflatex/, can inline /.png/, /.jpg/, and /.pdf/ files.
1959 These also represent the default settings for the new
1960 variables. Note that this means that pure links to /.pdf/
1961 files will be inlined - to avoid this for a particular link,
1962 make sure that the link has a description part which is not
1963 equal to the link part.
1965 *** Links by ID now continue to work in HTML exported files
1967 If you make links by ID, these links will now still work in
1968 HTML exported files, provided that you keep the relative path
1969 from link to target file the same.
1971 Thanks to Friedrich Delgado Friedrichs for pushing this over
1974 *** The relative timer can be paused
1976 The new command `C-c C-x ,' will pause the relative timer.
1977 When the relative timer is running, its value will be shown
1978 in the mode line. To get rid of this display, you need to
1979 really stop the timer with `C-u C-c C-x ,'.
1981 Thanks to Alan Davis for driving this change.
1983 *** The attachment directory may now be chosen by the user
1985 Instead of using the automatic, unique directory related to
1986 the entry ID, you can also use a chosen directory for the
1987 attachments of an entry. This directory is specified by the
1988 ATTACH_DIR property. You can use `C-c C-a s' to set this
1991 Thanks to Jason Jackson for this proposal.
1993 *** You can use a single attachment directory for a subtree
1995 By setting the property ATTACH_DIR_INHERIT, you can now tell
1996 Org that children of the entry should use the same directory
1997 for attachments, unless a child explicitly defines its own
1998 directory with the ATTACH_DIR property. You can use the
1999 command `C-c C-a i' to set this property in an entry.
2009 - Line numbers and references in literal examples
2010 - New hooks for export preprocessing
2011 - Capture column view into a different file
2015 *** Footnote support
2017 Org-mode now directly supports the creation of footnotes. In
2018 contrast to the /footnote.el/ package, Org-mode's footnotes are
2019 designed for work on a larger document, not only for one-off
2020 documents like emails. The basic syntax is similar to the one
2021 used by /footnote.el/, i.e. a footnote is defined in a paragraph
2022 that is started by a footnote marker in square brackets in column
2023 0, no indentation allowed. The footnote reference is simply the
2024 marker in square brackets inside text. For example:
2027 The Org homepage[fn:1] now looks a lot better than it used to.
2029 [fn:1] The link is: http://orgmode.org
2032 Org-mode extends the number-based syntax to /named/ footnotes and
2033 optional inline definition. Using plain numbers as markers is
2034 supported for backward compatibility, but not encouraged because
2035 of possible conflicts with LaTeX syntax. Here are the valid
2038 - [1] :: A plain numeric footnote marker.
2040 - [fn:name] :: A named footnote reference, where `name' is a
2041 unique label word or, for simplicity of automatic creation,
2044 - [fn:: This is the inline definition of this footnote] :: A
2045 LaTeX-like anonymous footnote where the definition is given
2046 directly at the reference point.
2048 - [fn:name: a definition] :: An inline definition of a footnote,
2049 which also specifies a name for the note. Since Org allows
2050 multiple references to the same note, you can then use use
2051 `[fn:name]' to create additional references.
2053 Footnote labels can be created automatically, or you create names
2054 yourself. This is handled by the variable
2055 =org-footnote-auto-label= and its corresponding =#+STARTUP=
2056 keywords, see the docstring of that variable for details.
2058 The following command handles footnotes:
2060 - C-c C-x f :: The footnote action command. When the cursor is
2061 on a footnote reference, jump to the definition. When it is
2062 at a definition, jump to the (first) reference. Otherwise,
2063 create a new footnote. Depending on the variable
2064 `org-footnote-define-inline' (with associated =#+STARTUP=
2065 options =fninline= and =nofninline=), the definitions will
2066 be placed right into the text as part of the reference, or
2067 separately into the location determined by the variable
2068 =org-footnote-section=.
2069 When this command is called with a prefix argument, a menu
2070 of additional options is offered:
2071 - s :: Sort the footnote definitions by reference sequence.
2072 During editing, Org makes no effort to sort footnote
2073 definitions into a particular sequence. If you want
2074 them sorted, use this command, which will also move
2075 entries according to =org-footnote-section=.
2076 - n :: Normalize the footnotes by collecting all
2077 definitions (including inline definitions) into a
2078 special section, and then numbering them in
2079 sequence. The references will then also be
2080 numbers. This is meant to be the final step before
2081 finishing a document (e.g. sending off an email).
2082 The exporters do this automatically, and so could
2083 something like `message-send-hook'.
2084 - d :: Delete the footnote at point, and all references to it.
2086 - C-c C-c :: If the cursor is on a footnote reference, jump to
2087 the definition. If it is a the definition, jump back to the
2088 reference. When called with a prefix argument at either
2089 location, offer the same menu as `C-u C-c C-x f'.
2091 - C-c C-o or mouse-1/2 :: Footnote labels are also links to the
2092 corresponding definition/reference, and you can use the
2093 usual commands to follow these links.
2095 Org-mode's footnote support is designed so that it should also
2096 work in buffers that are not in Org-mode, for example in email
2097 messages. Just bind =org-footnote-action= to a global key like
2100 The main trigger for this development came from a hook function
2101 written by Paul Rivier, to implement named footnotes and to
2102 convert them to numbered ones before export. Thanks, Paul!
2104 Thanks also to Scot Becker for a thoughtful post bringing this
2105 subject back onto the discussion table, and to Matt Lundin for
2106 the idea of named footnotes and his prompt testing of the new
2109 *** Line numbers and references in literal examples
2111 Literal examples introduced with =#+BEGIN_EXAMPLE= or =#+BEGIN_SRC=
2112 do now allow optional line numbering in the example.
2113 Furthermore, links to specific code lines are supported, greatly
2114 increasing Org-mode's utility for writing tutorials and other
2117 Code references use special labels embedded directly into the
2118 source code. Such labels look like "(ref:name)" and must be
2119 unique within a document. Org-mode links with "(name)" in the
2120 link part will be correctly interpreted, both while working with
2121 an Org file (internal links), and while exporting to the
2122 different backends. Line numbering and code references are
2123 supported for all three major backends, HTML, LaTeX, and ASCII.
2124 In the HTML backend, hovering the mouse over a link to a source
2125 line will remote-highlight the referenced code line.
2127 The options for the BEGIN lines are:
2129 - -n :: Number the lines in the example
2130 - +n :: Like -n, but continue numbering from where the previous
2132 - -r :: Remove the coderef cookies from the example, and replace
2133 links to this reference with line numbers. This option
2134 takes only effect if either -n or +n are given as well.
2135 If -r is not given, coderefs simply use the label name.
2136 - -l "fmt" :: Define a local format for coderef labels, see the
2137 variable =org-coderef-label-format= for details. Use this
2138 of the default syntax causes conflicts with the code in the
2139 code snippet you are using.
2144 #+begin_src emacs-lisp -n -r
2145 (defmacro org-unmodified (&rest body) (ref:def)
2146 "Execute body without changing `buffer-modified-p'."
2147 `(set-buffer-modified-p (ref:back)
2148 (prog1 (buffer-modified-p) ,@body)))
2150 [[(def)][Line (def)]] contains the macro name. Later at line [[(back)]],
2151 backquoting is used.
2154 When exported, this is translated to:
2155 #+begin_src emacs-lisp -n -r
2156 (defmacro org-unmodified (&rest body) (ref:def)
2157 "Execute body without changing `buffer-modified-p'."
2158 `(set-buffer-modified-p (ref:back)
2159 (prog1 (buffer-modified-p) ,@body)))
2161 [[(def)][Line (def)]] contains the macro name. Later at line [[(back)]],
2162 backquoting is used.
2164 Thanks to Ilya Shlyakhter for proposing this feature set. Thanks
2165 to Sebastian Rose for the key Javascript element that made the
2166 remote highlighting possible.
2168 *** New hooks for export preprocessing
2169 The export preprocessor now runs more hooks, to allow
2170 better-timed tweaking by user functions:
2172 - =org-export-preprocess-hook= ::
2173 Pretty much the first thing in the preprocessor. But org-mode
2174 is already active in the preprocessing buffer.
2176 - =org-export-preprocess-after-include-files-hook= ::
2177 This is run after the contents of included files have been inserted.
2179 - =org-export-preprocess-after-tree-selection-hook= ::
2180 This is run after selection of trees to be exported has
2181 happened. This selection includes tags-based selection, as
2182 well as removal of commented and archived trees.
2184 - =org-export-preprocess-before-backend-specifics-hook= ::
2185 Hook run before backend-specific functions are called during preprocessing.
2187 - =org-export-preprocess-final-hook= ::
2188 Hook for preprocessing an export buffer. This is run as the
2189 last thing in the preprocessing buffer, just before returning
2190 the buffer string to the backend.
2192 *** Capture column view into a different file
2194 The :id parameter for the dynamic block capturing column view
2195 can now truly be an ID that will also be found in a
2196 different file. Also, it can be like =file:path/to/file=, to
2197 capture the global column view from a different file.
2199 Thanks to Francois Lagarde for his report that IDs outside
2200 the current file would not work.
2206 Cleanup of many small bugs, and one new feature.
2210 *** References to last table row with special names
2212 Fields in the last row of a table can now be referenced with
2213 $LR1, $LR2, etc. These references can appear both on the
2214 left hand side and right hand side of a formula.
2221 This version reverses the introduction of @0 as a reference to
2222 the last rwo in a table, because of a conflict with the use of
2223 @0 for the current row.
2231 - All known LaTeX export issues fixed
2232 - Captions and attributes for figures and tables.
2233 - Better implementation for entry IDs
2234 - Spreadsheet references to the last table line.
2235 - Old syntax for link attributes abandoned
2237 ** Incompatible changes
2238 *** Old syntax for link attributes abandoned
2240 There used to be a syntax for setting link attributes for
2241 HTML export by enclosing the attributes into double braces
2242 and adding them to the link itself, like
2245 [[./img/a.jpg{{alt="an image"}}] ]
2248 This syntax is not longer supported, use instead
2251 ,#+ATTR_HTML: alt="an image"
2257 *** All known LaTeX export issues fixed
2259 All the remaining issues with the LaTeX exporter have hopefully
2260 been addressed in this release. In particular, this covers
2261 quoting of special characters in tables and problems with
2262 exporting files where the headline is in the first line, or with
2265 *** Captions and attributes for figures and tables.
2267 Tables, and Hyperlinks that represent inlined images, can now be
2268 equipped with additional information that will be used during
2269 export. The information will be taken from the following special
2270 lines in the buffer and apply to the first following table or
2273 - #+CAPTION: :: The caption of the image or table. This string
2274 should be processed according to the export backend, but
2275 this is not yet done.
2277 - #+LABEL: :: A label to identify the figure/table for cross
2278 references. For HTML export, this string will become the
2279 ID for the ~<div class="figure">~ element that encapsulates
2280 the image tag and the caption. For LaTeX export, this
2281 string will be used as the argument of a ~\label{...}~
2282 macro. These labels will be available for internal links
2283 like ~[[label][Table] ]~.
2285 - #+ATTR_HTML: :: Attributes for HTML export of image, to be
2286 added as attributes into the ~<img...>~ tag. This string
2287 will not be processed, so it should have immediately the
2290 - #+ATTR_LaTeX: :: Attributes for LaTeX export of images and
2292 For /images/, this string is directly inserted into
2293 the optional argument of the ~\includegraphics[...]{file}~
2294 command, to specify scaling, clipping and other options.
2295 This string will not be processed, so it should have
2296 immediately the right format, like =width=5cm,angle=90=.\\
2297 For /tables/, this can currently contain the keyword
2298 =longtable=, to request typesetting of the table using the
2299 longtable package, which automatically distributes the table
2300 over several pages if needed. Also, the attributes line may
2301 contain an alignment string for the tabular environment, like
2302 =longtable,align=l|lrl=
2304 For LaTeX export, if either a caption or a label is given, the element
2305 will be exported as a float, i.e. wrapped into a figure or table
2308 *** Better implementation for entry IDs
2310 Unique identifiers for entries can now be used more efficiently.
2311 Internally, a hash array has replaced the alist used so far to
2312 keep track of the files in which an ID is defined. This makes it
2313 quite fast to find an entry by ID.
2315 There is a new link type which looks like this:
2318 id:GLOBALLY-UNIQUE-IDENTIFIER
2321 This link points to a specific entry. When you move the entry to
2322 a different file, for example if you move it to an archive
2323 file, the link will continue to work.
2325 The file /org-id.el/ contains an API that can be used to write
2326 code using these identifiers, including creating IDs and finding
2327 them wherever they are.
2329 Org has its own method to create unique identifiers, but if the system
2330 has /uuidgen/ command installed (Mac's and Linux systems generally
2331 do), it will be used by default (a change compared to the earlier
2332 implmentation, where you explicitdly had to opt for uuidgen). You can
2333 also select the method by hand, using the variable =org-id-method=.
2335 If the ID system ever gets confused about where a certain ID is, it
2336 initiates a global scan of all agenda files with associated archives,
2337 all files previously known containing any IDs, and all currently
2338 visited Org-mode files to rebuild the hash. You can also initiate
2339 this by hand: =M-x org-id-update-id-locations=. Running this command
2340 will also dump into the =*Messages*= buffer information about any
2341 duplicate IDs. These should not exist, and Org will never /make/ the
2342 same ID twice, but if you /copy/ an entry with its properties,
2343 duplicate IDs will inevitably be produced. Unfortunately, this is
2344 unavoidable in a plain text system that allows you to edit the text in
2345 arbitrary ways, and a portion of care on your side is needed to keep
2348 The hash is stored in the file =~/.emacs.d/.org-id-locations=.
2349 This is also a change from previous versions where the file was
2350 =~/.org=id-locations=. Therefore, you can remove this old file
2351 if you have it. I am not sure what will happen if the =.emacs.d=
2352 directory does not exists in your setup, but in modern Emacsen, I
2353 believe it should exist. If you do not want to use IDs across
2354 files, you can avoid the overhead with tracking IDs by
2355 customizing the variable =org-id-track-globally=. IDs can then
2356 still be used for links inside a single file.
2358 IDs will also be used when you create a new link to an Org-mode
2359 buffer. If you use =org-store-link= (normally at =C-c l=) inside
2360 en entry in an Org-mode buffer, and ID property will be created
2361 if it does not exist, and the stored link will be an =id:= link.
2362 If you prefer the much less secure linking to headline text, you
2363 can configure the variable =org-link-to-org-use-id=. The default
2364 setting for this variable is =create-if-interactive=, meaning
2365 that an ID will be created when you store a link interactively,
2366 but not if you happen to be in an Org-mode file while you create
2367 a remember note (which usually has a link to the place where you
2368 were when starting remember).
2370 *** Spreadsheet references to the last table line.
2372 You may now use =@0= to reference the last dataline in a table
2373 in a stable way. This is useful in particular for automatically
2374 generated tables like the ones using /org-collector.el/ by Eric
2383 - New relative timer to support timed notes
2384 - Special faces can be set for individual tags
2385 - The agenda shows now all tags, including inherited ones.
2386 - Exclude some tags from inheritance.
2387 - More special values for time comparisons in property searches
2388 - Control for exporting meta data
2389 - Cut and Paste with hot links from w3m to Org
2390 - LOCATION can be inherited for iCalendar export
2391 - Relative row references crossing hlines now throw an error
2393 ** Incompatible Changes
2395 *** Relative row references crossing hlines now throw an error
2397 Relative row references in tables look like this: "@-4" which
2398 means the forth row above this one. These row references are
2399 not allowed to cross horizontal separator lines (hlines). So
2400 far, when a row reference violates this policy, Org would
2401 silently choose the field just next to the hline.
2403 Tassilo Horn pointed out that this kind of hidden magic is
2404 actually confusing and may cause incorrect formulas, and I do
2405 agree. Therefore, trying to cross a hline with a relative
2406 reference will now throw an error.
2408 If you need the old behavior, customize the variable
2409 `org-table-error-on-row-ref-crossing-hline'.
2413 *** New relative timer to support timed notes
2415 Org now supports taking timed notes, useful for example while
2416 watching a video, or during a meeting which is also recorded.
2419 Insert a relative time into the buffer. The first time
2420 you use this, the timer will be started. When called
2421 with a prefix argument, the timer is reset to 0.
2424 Insert a description list item with the current relative
2425 time. With a prefix argument, first reset the timer to 0.
2428 Once the time list has been initiated, you can also use the
2429 normal item-creating command to insert the next timer item.
2432 Reset the timer without inserting anything into the buffer.
2433 By default, the timer is reset to 0. When called with a
2434 =C-u= prefix, reset the timer to specific starting
2435 offset. The user is prompted for the offset, with a
2436 default taken from a timer string at point, if any, So this
2437 can be used to restart taking notes after a break in the
2438 process. When called with a double prefix argument
2439 =C-c C-u=, change all timer strings in the active
2440 region by a certain amount. This can be used to fix timer
2441 strings if the timer was not started at exactly the right
2444 Thanks to Alan Dove, Adam Spiers, and Alan Davis for
2445 contributions to this idea.
2447 *** Special faces can be set for individual tags
2449 You may now use the variable =org-tag-faces= to define the
2450 face used for specific tags, much in the same way as you can
2451 do for TODO keywords.
2453 Thanks to Samuel Wales for this proposal.
2455 *** The agenda shows now all tags, including inherited ones.
2457 This request has come up often, most recently it was
2458 formulated by Tassilo Horn.
2460 If you prefer the old behavior of only showing the local
2461 tags, customize the variable =org-agenda-show-inherited-tags=.
2463 *** Exclude some tags from inheritance.
2465 So far, the only way to select tags for inheritance was to
2466 allow it for all tags, or to do a positive selection using
2467 one of the more complex settings for
2468 `org-use-tag-inheritance'. It may actually be better to
2469 allow inheritance for all but a few tags, which was difficult
2470 to achieve with this methodology.
2472 A new option, `org-tags-exclude-from-inheritance', allows to
2473 specify an exclusion list for inherited tags.
2475 *** More special values for time comparisons in property searches
2477 In addition to =<now>=, =<today>=, =<yesterday>=, and
2478 =<tomorrow>=, there are more special values accepted now in
2479 time comparisons in property searches: You may use strings
2480 like =<+3d>= or =<-2w>=, with units d, w, m, and y for day,
2481 week, month, and year, respectively
2483 Thanks to Linday Todd for this proposal.
2485 *** Control for exporting meta data
2487 All the metadata in a headline, i.e. the TODO keyword, the
2488 priority cookie, and the tags, can now be excluded from
2489 export with appropriate options:
2491 | Variable | Publishing property | OPTIONS switch |
2492 |-------------------------------+---------------------+----------------|
2493 | org-export-with-todo-keywords | :todo-keywords | todo: |
2494 | org-export-with-tags | :tags | tags: |
2495 | org-export-with-priority | :priority | pri: |
2497 *** Cut and Paste with hot links from w3m to Org
2499 You can now use the key =C-c C-x M-w= in a w3m buffer with
2500 HTML content to copy either the region or the entire file in
2501 a special way. When you yank this text back into an Org-mode
2502 buffer, all links from the w3m buffer will continue to work
2505 For this to work you need to load the new file /org-w3m.el./
2506 Please check your org-modules variable to make sure that this
2509 Thanks for Richard Riley for the idea and to Andy Stewart for
2512 *** LOCATION can be inherited for iCalendar export
2514 The LOCATION property can now be inherited during iCalendar
2515 export if you configure =org-use-property-inheritance= like
2518 #+begin_src emacs-lisp
2519 (setq org-use-property-inheritance '("LOCATION"))
2529 - Keybindings in Remember buffers can be configured
2530 - Support for ido completion
2531 - New face for date lines in agenda column view
2532 - Invisible targets become now anchors in headlines.
2533 - New contributed file /org-exp-blocks.el/
2534 - New contributed file /org-eval-light.el/
2536 - BBDB links may use regular expressions.
2537 - Link abbreviations can use %h to insert a url-encoded target value
2538 - Improved XHTML compliance
2542 *** Keybindings in Remember buffers can be configured
2544 The remember buffers created with Org's extensions are in
2545 Org-mode, which is nice to prepare snippets that will
2546 actually be stored in Org-mode files. However, this makes it
2547 hard to configure key bindings without modifying the Org-mode
2548 keymap. There is now a minor mode active in these buffers,
2549 `org-remember-mode', and its keymap org-remember-mode-map can
2550 be used for key bindings. By default, this map only contains
2551 the bindings for =C-c C-c= to store the note, and =C-c C-k=
2552 to abort it. Use `org-remember-mode-hook' to define your own
2555 #+begin_src emacs-lisp
2557 'org-remember-mode-hook
2559 (define-key org-remember-mode-map
2560 "\C-x\C-s" 'org-remember-finalize)))
2563 If you wish, you can also use this to free the =C-c C-c=
2564 binding (by binding this key to nil in the minor mode map),
2565 so that you can use =C-c C-c= again to set tags.
2567 This modification is based on a request by Tim O'Callaghan.
2569 *** Support for ido completion
2571 You can now get the completion interface from /ido.el/ for
2572 many of Org's internal completion commands by turning on the
2573 variable =org-completion-use-ido=. =ido-mode= must also be
2574 active before you can use this.
2576 This change is based upon a request by Samuel Wales.
2578 *** New face for date lines in agenda column view
2580 When column view is active in the agenda, and when you have
2581 summarizing properties, the date lines become normal column
2582 lines and the separation between different days becomes
2583 harder to see. If this bothers you, you can now customize
2584 the face =org-agenda-column-dateline=.
2586 This is based on a request by George Pearson.
2588 *** Invisible targets become now anchors in headlines.
2590 These anchors can be used to jump to a directly with an HTML
2591 link, just like the =sec-xxx= IDs. For example, the
2592 following will make a http link
2593 =//domain/path-to-my-file.html#dummy= work:
2600 This is based on a request by Matt Lundin.
2602 *** New contributed file /org-exp-blocks.el/
2604 This new file implements special export behavior of
2605 user-defined blocks. The currently supported blocks are
2607 - comment :: Comment blocks with author-specific markup
2608 - ditaa :: conversion of ASCII art into pretty png files
2609 using Stathis Sideris' /ditaa.jar/ program
2610 - dot :: creation of graphs in the /dot/ language
2611 - R :: Sweave type exporting using the R program
2613 For more details and examples, see the file commentary in
2614 /org-exp-blocks.el/.
2616 Kudos to Eric Schulte for this new functionality, after
2617 /org-plot.el/ already his second major contribution. Thanks
2618 to Stathis for this excellent program, and for allowing us to
2619 bundle it with Org-mode.
2621 *** New contributed file /org-eval-light.el/
2623 This module gives control over execution Emacs Lisp code
2624 blocks included in a file.
2626 Thanks to Eric Schulte also for this file.
2628 *** Link translation
2630 You can now configure Org to understand many links created
2631 with the Emacs Planner package, so you can cut text from
2632 planner pages and paste them into Org-mode files without
2633 having to re-write the links. Among other things, this means
2634 that the command =org-open-at-point-global= which follows
2635 links not only in Org-mode, but in arbitrary files like
2636 source code files etc, will work also with links created by
2637 planner. The following customization is needed to make all of
2640 #+begin_src emacs-lisp
2641 (setq org-link-translation-function
2642 'org-translate-link-from-planner)
2645 I guess an inverse translator could be written and integrated
2648 *** BBDB links may use regular expressions.
2650 This did work all along, but only now I have documented it.
2652 *** =yank-pop= works again after yanking an outline tree
2654 Samuel Wales had noticed that =org-yank= did mess up this
2655 functionality. Now you can use =yank-pop= again, the only
2656 restriction is that the so-yanked text will not be
2657 pro/demoted or folded.
2659 *** Link abbreviations can use %h to insert a url-encoded target value
2661 Thanks to Steve Purcell for a patch to this effect.
2663 *** Improved XHTML compliance
2665 Thanks to Sebastian Rose for pushing this.
2667 *** Many bug fixes again.
2675 - A region of entries can now be refiled with a single command
2676 - Fine-tuning the behavior of `org-yank'
2677 - Formulas for clocktables
2678 - Better implementation of footnotes for HTML export
2679 - More languages for HTML export.
2683 *** A region of entries can now be refiled with a single command
2685 With =transient-make-mode= active (=zmacs-regions= under
2686 XEmacs), you can now select a region of entries and refile
2687 them all with a single =C-c C-w= command.
2689 Thanks to Samuel Wales for this useful proposal.
2691 *** Fine-tuning the behavior of =org-yank=
2693 The behavior of Org's yanking command has been further
2694 fine-tuned in order to avoid some of the small annoyances
2695 this command caused.
2697 - Calling =org-yank= with a prefix arg will stop any special
2698 treatment and directly pass through to the normal =yank=
2699 command. Therefore, you can now force a normal yank with
2702 - Subtrees will only be folded after a yank if doing so will
2703 now swallow any non-white characters after the yanked text.
2704 This is, I think a really important change to make the
2705 command work more sanely.
2707 *** Formulas for clocktables
2709 You can now add formulas to a clock table, either by hand, or
2710 with a =:formula= parameter. These formulas can be used to
2711 create additional columns with further analysis of the
2714 Thanks to Jurgen Defurne for triggering this addition.
2716 *** Better implementation of footnotes for HTML export
2718 The footnote export in 6.11 really was not good enough. Now
2719 it works fine. If you have customized
2720 =footnote-section-tag=, make sure that your customization is
2721 matched by =footnote-section-tag-regexp=.
2723 Thanks to Sebastian Rose for pushing this change.
2725 *** More languages for HTML export.
2727 More languages are supported during HTML export. This is
2728 only relevant for the few special words Org inserts, like
2729 "Table of Contents", or "Footnotes". Also the encoding
2730 issues with this feature seem to be solved now.
2732 Thanks to Sebastian Rose for pushing me to fix the encoding
2742 - Yanking subtree with =C-y= now adjusts the tree level
2743 - State changes can now be shown in the log mode in the agenda
2744 - Footnote in HTML export are now collected at the end of the document
2745 - HTML export now validates again as XHTML
2746 - The clock can now be resumed after exiting and re-starting Emacs
2747 - Clock-related data can be saved and resumed across Emacs sessions
2748 - Following file links can now use C-u C-u to force use of an external app
2749 - Inserting absolute files names now abbreviates links with "~"
2750 - Links to attachment files
2751 - Completed repeated tasks listed briefly in agenda
2752 - Remove buffers created during publishing are removed
2756 *** Yanking subtree with =C-y= now adjusts the tree level
2757 When yanking a cut/copied subtree or a series of trees, the
2758 normal yank key =C-y= now adjusts the level of the tree to
2759 make it fit into the current outline position, without losing
2760 its identity, and without swallowing other subtrees.
2762 This uses the command =org-past-subtree=. An additional
2763 change in that command has been implemented: Normally, this
2764 command picks the right outline level from the surrounding
2765 *visible* headlines, and uses the smaller one. So if the
2766 cursor is between a level 4 and a level 3 headline, the tree
2767 will be pasted as level 3. If the cursor is actually *at*
2768 the beginning of a headline, the level of that headline will
2769 be used. For example, lets say you have a tree like this:
2775 ,(2)* Level one again
2778 with (1) and (2) indicating possible cursor positions for the
2779 insertion. When at (1), the tree will be pasted as level 2.
2780 When at (2), it will be pasted as level 1.
2782 If you do not want =C-y= to behave like this, configure the
2783 variable =org-yank-adjusted-subtrees=.
2785 Thanks to Samuel Wales for this idea and a partial implementation.
2787 *** State changes can now be shown in the log mode in the agenda
2789 If you configure the variable =org-agenda-log-mode-items=,
2790 you can now request that all logged state changes be included
2791 in the agenda when log mode is active. If you find this too
2792 much for normal applications, you can also temporarily
2793 request the inclusion of state changes by pressing =C-u l= in
2796 This was a request by Hsiu-Khuern Tang.
2798 You can also press `C-u C-u l' to get *only* log items in the
2799 agenda, withour any timestamps/deadlines etc.
2801 *** Footnote in HTML export are now collected at the end of the document
2802 Previously, footnotes would be left in the document where
2803 they are defined, now they are all collected and put into a
2804 special =<div>= at the end of the document.
2806 Thanks to Sebastian Rose for this request.
2808 *** HTML export now validates again as XHTML.
2810 Thanks to Sebastian Rose for pushing this cleanup.
2812 *** The clock can now be resumed after exiting and re-starting Emacs
2814 If the option =org-clock-in-resume= is t, and the first clock
2815 line in an entry is unclosed, clocking into that task resumes
2816 the clock from that time.
2818 Thanks to James TD Smith for a patch to this effect.
2820 *** Clock-related data can be saved and resumed across Emacs sessions
2822 The data saved include the contents of =org-clock-history=,
2823 and the running clock, if there is one.
2825 To use this, you will need to add to your .emacs
2827 #+begin_src emacs-lisp
2828 (setq org-clock-persist t)
2829 (setq org-clock-in-resume t)
2830 (org-clock-persistence-insinuate)
2833 Thanks to James TD Smith for a patch to this effect.
2835 *** Following file links can now use C-u C-u to force use of an external app.
2837 So far you could only bypass your setup in `org-file-apps'
2838 and force opening a file link in Emacs by using a =C-u= prefix arg
2839 with =C-c C-o=. Now you can call =C-u C-u C-c C-o= to force
2840 an external application. Which external application depends
2841 on your system. On Mac OS X and Windows, =open= is used. On
2842 a GNU/Linux system, the mailcap settings are used.
2844 This was a proposal by Samuel Wales.
2846 *** Inserting absolute files names now abbreviates links with "~".
2848 Inserting file links with =C-u C-c C-l= was buggy if the
2849 setting of `org-link-file-path-type' was `adaptive' (the
2850 default). Absolute file paths were not abbreviated relative
2851 to the users home directory. This bug has been fixed.
2853 Thanks to Matt Lundin for the report.
2855 *** Links to attachment files
2857 Even though one of the purposes of entry attachments was to
2858 reduce the number of links in an entry, one might still want
2859 to have the occasional link to one of those files. You can
2860 now use link abbreviations to set up a special link type that
2861 points to attachments in the current entry. Note that such
2862 links will only work from within the same entry that has the
2863 attachment, because the directory path is entry specific.
2864 Here is the setup you need:
2866 #+begin_src emacs-lisp
2867 (setq org-link-abbrev-alist '(("att" . org-attach-expand-link)))
2870 After this, a link like this will work
2873 [[att:some-attached-file.txt]]
2875 This was a proposal by Lindsay Todd.
2877 *** Completed repeated tasks listed briefly in agenda
2879 When a repeating task, listed in the daily/weekly agenda under
2880 today's date, is completed from the agenda, it is listed as
2881 DONE in the agenda until the next update happens. After the
2882 next update, the task will have disappeared, of course,
2883 because the new date is no longer today.
2885 *** Remove buffers created during publishing are removed
2887 Buffers that are created during publishing are now deleted
2888 when the publishing is over. At least I hope it works like this.
2897 - Secondary agenda filtering is becoming a killer feature
2898 - Setting tags has now its own binding, =C-c C-q=
2899 - Todo state changes can trigger tag changes
2900 - C-RET will now always insert a new headline, never an item.
2901 - Customize org-mouse.el feature set to free up mouse events
2902 - New commands for export all the way to PDF (through LaTeX)
2903 - Some bug fixed for LaTeX export, more bugs remain.
2907 *** Enhancements to secondary agenda filtering
2909 This is, I believe, becoming a killer feature. It allows you
2910 to define fewer and more general custom agenda commands, and
2911 then to do the final narrowing to specific tasks you are
2912 looking for very quickly, much faster than calling a new
2915 If you have not tries this yet, you should!
2917 **** You can now refining the current filter by an additional criterion
2918 When filtering an existing agenda view with =/=, you can
2919 now narrow down the existing selection by an additional
2920 condition. Do do this, use =\= instead of =/= to add the
2921 additional criterion. You can also press =+= or =-= after
2922 =/= to add a positive or negative condition. A condition
2923 can be a TAG, or an effort estimate limit, see below.
2925 **** It is now possible to filter for effort estimates
2926 This means to filter the agenda for the value of the Effort
2927 property. For this you should best set up global allowed
2928 values for effort estimates, with
2930 #+begin_src emacs-lisp
2931 (setq org-global-properties
2932 '(("Effort_ALL" . "0 0:10 0:30 1:00 2:00 3:00 4:00")))
2935 You may then select effort limits with single keys in the
2936 filter. It works like this: After =/= or =\=, first select
2937 the operator which you want to use to compare effort
2940 : < Select entries with effort smaller than or equal to the limit
2941 : > Select entries with effort larger than or equal to the limit
2942 : = Select entries with effort equal to the limit
2944 After that, you can press a single digit number which is
2945 used as an index to the allowed effort estimates.
2947 If you do not use digits to fast-select tags, you can even
2948 skip the operator, which will then default to
2949 `org-agenda-filter-effort-default-operator', which is by
2952 Thanks to Manish for the great idea to include fast effort
2953 filtering into the agenda filtering process.
2955 **** The mode line will show the active filter
2956 For example, if there is a filter in place that does select
2957 for HOME tags, against EMAIL tags, and for tasks with an
2958 estimated effort smaller than 30 minutes, the mode-line with
2959 show =+HOME-EMAIL+<0:30=
2961 **** The filter now persists when the agenda view is refreshed
2962 All normal refresh commands, including those that move the
2963 weekly agenda from one week to the next, now keep the
2964 current filter in place.
2966 You need to press =/ /= to turn off the filter. However,
2967 when you run a new agenda command, for example going from
2968 the weekly agenda to the TODO list, the filter will be
2971 *** Setting tags has now its own binding, =C-c C-q=
2973 You can still use =C-c C-c= on a headline, but the new
2974 binding should be considered as the main binding for this
2975 command. The reasons for this change are:
2977 - Using =C-c C-c= for tags is really out of line with other
2980 - I hate it in Remember buffers when I try to set tags and I
2981 cannot, because =C-c C-c= exits the buffer :-(
2983 - =C-c C-q= will also work when the cursor is somewhere down
2984 in the entry, it does not have to be on the headline.
2986 *** Todo state changes can trigger tag changes
2988 The new option =org-todo-state-tags-triggers= can be used to
2989 define automatic changes to tags when a TODO state changes.
2990 For example, the setting
2992 : (setq org-todo-state-tags-triggers
2993 : '((done ("Today" . nil) ("NEXT" . nil))
2994 : ("WAITING" ("Today" . t))))
2996 will make sure that any change to any of the DONE states will
2997 remove tags "Today" and "NEXT", while switching to the
2998 "WAITING" state will trigger the tag "Today" to be added.
3000 I use this mostly to get rid of TODAY and NEXT tags which I
3001 apply to select an entry for execution in the near future,
3002 which I often prefer to specific time scheduling.
3004 *** C-RET will now always insert a new headline, never an item.
3005 The new headline is inserted after the current subtree.
3007 Thanks to Peter Jones for patches to fine-tune this behavior.
3009 *** Customize org-mouse.el feature set
3010 There is a new variable =org-mouse-features= which gives you
3011 some control about what features of org-mouse you want to
3012 use. Turning off some of the feature will free up the
3013 corresponding mouse events, or will avoid activating special
3014 regions for mouse clicks. By default I have urned off the
3015 feature to use drag mouse events to move or promote/demote
3016 entries. You can of course turn them back on if you wish.
3018 This variable may still change in the future, allowing more
3019 fine-grained control.
3021 *** New commands for export to PDF
3023 This is using LaTeX export, and then processes it to PDF
3026 : C-c C-e p process to PDF.
3027 : C-c C-e d process to PDF, and open the file.
3030 - \usepackage{graphicx} is now part of the standard class
3032 - Several bugs fixed, but definitely not all of them :-(
3034 *** New option `org-log-state-notes-insert-after-drawers'
3036 Set this to =t= if you want state change notes to be inserted
3037 after any initial drawers, i.e drawers the immediately follow
3038 the headline and the planning line (the one with
3039 DEADLINE/SCHEDULED/CLOSED information).
3046 *** =org-file-apps= now uses regular expressions, see [[*%20org%20file%20apps%20now%20uses%20regular%20repressions%20instead%20of%20extensions][below]]
3050 *** =org-file-apps= now uses regular repressions instead of extensions
3051 Just like in =auto-mode-alist=, car's in the variable
3052 =org-file-apps= that are strings are now interpreted as
3053 regular expressions that are matched against a file name. So
3054 instead of "txt", you should now write "\\.txt\\'" to make
3055 sure the matching is done correctly (even though "txt" will
3056 be recognized and still be interpreted as an extension).
3058 There is now a shortcut to get many file types visited by
3059 Emacs. If org-file-apps contains `(auto-mode . emacs)', then
3060 any files that are matched by `auto-mode-alist' will be
3063 *** Changes to the attachment system
3065 - The default method to attach a file is now to copy it
3066 instead of moving it.
3067 - You can modify the default method using the variable
3068 `org-attach-method'. I believe that most Unix people want
3069 to set it to `ln' to create hard links.
3070 - The keys =c=, =m=, and =l= specifically select =copy=,
3071 =move=, or =link=, respectively, as the attachment method
3072 for a file, overruling `org-attach-method'.
3073 - To create a new attachment as an Emacs buffer, you have not
3074 now use =n= instead of =c=.
3075 - The file list is now always retrieved from the directory
3076 itself, not from the "Attachments" property. We still
3077 keep this property by default, but you can turn it off, by
3078 customizing the variable =org-attach-file-list-property=.
3085 ** Incompatible changes
3087 - Changes in the structure of IDs, see [[*The%20default%20structure%20of%20IDs%20has%20changed][here]] for details.
3089 - C-c C-a has been redefined, see [[*%20C%20c%20C%20a%20no%20longer%20calls%20show%20all][here]] for details.
3093 *** The default structure of IDs has changed
3095 IDs created by Org have changed a bit:
3096 - By default, there is no prefix on the ID. There used to be
3097 an "Org" prefix, but I now think this is not necessary.
3098 - IDs use only lower-case letters, no upper-case letters
3099 anymore. The reason for this is that IDs are now also used
3100 as directory names for org-attach, and some systems do not
3101 distinguish upper and lower case in the file system.
3102 - The ID string derived from the current time is now
3103 /reversed/ to become an ID. This assures that the first
3104 two letters of the ID change fast, so hat it makes sense to
3105 split them off to create subdirectories to balance load.
3106 - You can now set the `org-id-method' to `uuidgen' on systems
3109 *** =C-c C-a= no longer calls `show-all'
3111 The reason for this is that =C-c C-a= is now used for the
3112 attachment system. On the rare occasions that this command
3113 is needed, use =M-x show-all=, or =C-u C-u C-u TAB=.
3115 *** New attachment system
3117 You can now attach files to each node in the outline tree.
3118 This works by creating special directories based on the ID of
3119 an entry, and storing files in these directories. Org can
3120 keep track of changes to the attachments by automatically
3121 committing changes to git. See the manual for more
3124 Thanks to John Wiegley who contributed this fantastic new
3125 concept and wrote org-attach.el to implement it.
3127 *** New remember template escapes
3129 : %^{prop}p to insert a property
3130 : %k the heading of the item currently being clocked
3131 : %K a link to the heading of the item currently being clocked
3133 Also, when you exit remember with =C-2 C-c C-c=, the item
3134 will be filed as a child of the item currently being
3135 clocked. So the idea is, if you are working on something and
3136 think of a new task related to this or a new note to be
3137 added, you can use this to quickly add information to that
3140 Thanks to James TD Smith for a patch to this effect.
3142 *** Clicking with mouse-2 on clock info in mode-line visits the clock.
3144 Thanks to James TD Smith for a patch to this effect.
3146 *** New file in contrib: lisp/org-checklist.el
3148 This module deals with repeated tasks that have checkbox
3151 Thanks to James TD Smith for this contribution.
3153 *** New in-buffer setting #+STYLE
3155 It can be used to locally set the variable
3156 `org-export-html-style-extra'. Several such lines are
3157 allowed-, they will all be concatenated. For an example on
3158 how to use it, see the [[http://orgmode.org/worg/org-tutorials/org-publish-html-tutorial.php][publishing tutorial]].
3167 - Filtering existing agenda views with respect to a tag
3168 - Editing fixed-width regions with picture or artist mode
3169 - /org-plot.el/ is now part of Org
3170 - Tags can be used to select the export part of a document
3171 - Prefix interpretation when storing remember notes
3172 - Yanking inserts folded subtrees
3173 - Column view capture tables can have formulas, plotting info
3174 - In column view, date stamps can be changed with S-cursor keys
3175 - The note buffer for clocking out now mentions the task
3176 - Sorting entries alphabetically ignores TODO keyword and priority
3177 - Agenda views can sort entries by TODO state
3178 - New face =org-scheduled= for entries scheduled in the future.
3179 - Remember templates for gnus links can use the :to escape.
3180 - The file specification in a remember template may be a function
3181 - Categories in iCalendar export include local tags
3182 - It is possible to define filters for column view
3183 - Disabling integer increment during table Field copy
3184 - Capturing column view is on `C-c C-x i'
3185 - And tons of bugs fixed.
3188 ** Incompatible changes
3190 *** Prefix interpretation when storing remember notes has changed
3192 The prefix argument to the `C-c C-c' command that finishes a
3193 remember process is now interpreted differently:
3195 : C-c C-c Store the note to predefined file and headline
3196 : C-u C-c C-c Like C-c C-c, but immediately visit the note
3197 : in its new location.
3198 : C-1 C-c C-c Select the storage location interactively
3199 : C-0 C-c C-c Re-use the last used location
3201 This was requested by John Wiegley.
3203 *** Capturing column view is now on `C-c C-x i'
3205 The reason for this change was that `C-c C-x r' is also used
3206 as a tty key replacement.
3208 *** Categories in iCalendar export now include local tags
3210 The locally defined tags are now listed as categories when
3211 exporting to iCalendar format. Org's traditional file/tree
3212 category is now the last category in this list. Configure
3213 the variable =org-icalendar-categories= to modify or revert
3216 This was a request by Charles Philip Chan.
3220 *** Secondary filtering of agenda views.
3222 You can now easily and interactively filter an existing
3223 agenda view with respect to a tag. This command is executed
3224 with the =/= key in the agenda. You will be prompted for a
3225 tag selection key, and all entries that do not contain or
3226 inherit the corresponding tag will be hidden. With a prefix
3227 argument, the opposite filter is applied: entries that
3228 do have the tag will be hidden.
3230 This operation only /hides/ lines in the agenda buffer, it
3231 does not remove them. Changing the secondary filtering does
3232 not require a new search and is very fast.
3234 If you press TAB at the tag selection prompt, you will be
3235 switched to a completion interface to select a tag. This is
3236 useful when you want to select a tag that does not have a
3237 direct access character.
3239 A double =/ /= will restore the original agenda view by
3240 unhiding any hidden lines.
3242 This functionality was John Wiegley's idea. It is a simpler
3243 implementation of some of the query-editing features proposed
3244 and implemented some time ago by Christopher League (see the
3245 file contrib/lisp/org-interactive-query.el).
3247 *** Editing fixed-width regions with picture or artist mode
3249 The command @<code>C-c '@</code> (that is =C-c= followed by a
3250 single quote) can now also be used to switch to a special
3251 editing mode for fixed-width sections. The default mode is
3252 =artist-mode= which allows you to create ASCII drawings.
3254 It works like this: Enter the editing mode with
3255 @<code>C-c '@</code>. An indirect buffer will be created and
3256 narrowed to the fixed-width region. Edit the drawing, and
3257 press @<code>C-c '@</code> again to exit.
3259 Lines in a fixed-width region should be preceded by a colon
3260 followed by at least one space. These will be removed during
3261 editing, and then added back when you exit the editing mode.
3263 Using the command in an empty line will create a new
3266 This new feature arose from a discussion involving Scott
3267 Otterson, Sebastian Rose and Will Henney.
3269 *** /org-plot.el/ is now part of Org.
3271 You can run it by simple calling org-plot/gnuplot.
3272 Documentation is not yet included with Org, please refer to
3273 http://github.com/eschulte/org-plot/tree/master until we have
3274 moved the docs into Org or Worg.
3276 Thanks to Eric Schulte for this great contribution.
3278 *** Tags can be used to select the export part of a document
3280 You may now use tags to select parts of a document for
3281 inclusion into the export, and to exclude other parts. This
3282 behavior is governed by two new variables:
3283 =org-export-select-tags= and =org-export-exclude-tags=.
3284 These default to =("export")= and =("noexport")=, but can be
3285 changed, even to include a list of several tags.
3287 Org first checks if any of the /select/ tags is present in
3288 the buffer. If yes, all trees that do not carry one of these
3289 tags will be excluded. If a selected tree is a subtree, the
3290 heading hierarchy above it will also be selected for export,
3291 but not the text below those headings. If none of the select
3292 tags is found anywhere in the buffer, the whole buffer will
3293 be selected for export. Finally, all subtrees that are
3294 marked by any of the /exclude/ tags will be removed from the
3297 You may set these tags with in-buffer options
3298 =EXPORT_SELECT_TAGS= and =EXPORT_EXCLUDE_TAGS=.
3300 I love this feature. Thanks to Richard G Riley for coming
3303 *** Prefix interpretation when storing remember notes
3305 The prefix argument to the `C-c C-c' command that finishes a
3306 remember process is now interpreted differently:
3308 : C-c C-c Store the note to predefined file and headline
3309 : C-u C-c C-c Like C-c C-c, but immediately visit the note
3310 : in its new location.
3311 : C-1 C-c C-c Select the storage location interactively
3312 : C-0 C-c C-c Re-use the last used location
3314 This was requested by John Wiegley.
3316 *** Yanking inserts folded subtrees
3318 If the kill is a subtree or a sequence of subtrees, yanking
3319 them with =C-y= will leave all the subtrees in a folded
3320 state. This basically means, that kill and yank are now
3321 much more useful in moving stuff around in your outline. If
3322 you do not like this, customize the variable
3323 =org-yank-folded-subtrees=.
3325 Right now, I am only binding =C-y= to this new function,
3326 should I modify all bindings of yank? Do we need to amend
3329 This feature was requested by John Wiegley.
3331 *** Column view capture tables can have formulas, plotting info
3333 If you attach formulas and plotting instructions to a table
3334 capturing column view, these extra lines will now survive an
3335 update of the column view capture, and any formulas will be
3336 re-applied to the captured table. This works by keeping any
3337 continuous block of comments before and after the actual
3340 *** In column view, date stamps can be changed with S-cursor keys
3342 If a property value is a time stamp, S-left and S-right can
3343 now be used to shift this date around while in column view.
3345 This was a request by Chris Randle.
3347 *** The note buffer for clocking out now mentions the task
3349 This was a request by Peter Frings.
3351 *** Sorting entries alphabetically ignores TODO keyword and priority
3353 Numerical and alphanumerical sorting now skips any TODO
3354 keyword or priority cookie when constructing the comparison
3355 string. This was a request by Wanrong Lin.
3357 *** Agenda views can sort entries by TODO state
3359 You can now define a sorting strategy for agenda entries that
3360 does look at the TODO state of the entries. Sorting by TODO
3361 entry does first separate the non-done from the done states.
3362 Within each class, the entries are sorted not alphabetically,
3363 but in definition order. So if you have a sequence of TODO
3364 entries defined, the entries will be sorted according to the
3365 position of the keyword in this sequence.
3367 This follows an idea and sample implementation by Christian
3370 *** New face =org-scheduled= for entries scheduled in the future.
3372 This was a request by Richard G Riley.
3374 *** Remember templates for gnus links can now use the :to escape.
3376 Thanks to Tommy Lindgren for a patch to this effect.
3377 *** The file specification in a remember template may now be a function
3379 Thanks to Gregory Sullivan for a patch to this effect.
3381 *** Categories in iCalendar export now include local tags
3383 The locally defined tags are now listed as categories when
3384 exporting to iCalendar format. Org's traditional file/tree
3385 category is now the last category in this list. Configure
3386 the variable =org-icalendar-categories= to modify or revert
3389 This was a request by Charles Philip Chan.
3391 *** It is now possible to define filters for column view
3393 The filter can modify the value that will be displayed in a
3394 column, for example it can cut out a part of a time stamp.
3395 For more information, look at the variable
3396 =org-columns-modify-value-for-display-function=.
3398 *** Disabling integer increment during table field copy
3400 Prefix arg 0 to S-RET does the trick.
3402 This was a request by Chris Randle.
3409 - New, more CSS-like setup for HTML style information
3410 - Attributes in hyperlinks, for example alt and title for images
3411 - Simplified way to specify file links
3412 - Modified behavior of time stamps in iCalendar export
3413 - New way to compare times during a property search
3414 - New option `org-open-directory-means-index'
3415 - New parameters :prefix and :prefix1 for include files
3416 - New option :index-style for org-publish
3417 - New structure for the timestamp directory for org-publish.
3419 ** Incompatible changes
3421 *** New structure for the timestamp directory for org-publish.
3423 The timestamp directory now uses SHA1 hashed versions of the
3424 path to each publishing file. This should be a consistent
3425 and system-independent way to handle things. The change
3426 means that your next publishing command will publish each and
3427 every file again, but just once, until new time stamps are in
3432 *** New setup for HTML style information
3434 In order to create a more CSS-like setup of the HTML style
3435 information, the following changes have been made:
3436 - The default style has moved to a constant,
3437 =org-export-html-style-default= and should not be changed
3439 - The default of the variable =org-export-html-style= is now
3440 just the empty string. This variable should receive
3441 settings that are Org-wide. When using org-publish, this
3442 variable is associated with the =:style= property and can
3443 be used to establish project-wide settings.
3444 - There is a new variable =org-export-html-style-extra= that
3445 should be used for file-local settings. Org-publish can, if
3446 necessary, access this variable with the =:style-extra=
3448 - When a file is published, the values of
3449 - org-export-html-style-default
3450 - org-export-html-style
3451 - org-export-html-style-extra
3452 are all inserted into the HTML header, in the given
3455 This follows a proposal by Rustom Mody.
3457 *** Attributes in hyperlinks
3459 You can now set attributes in hyperlinks that will be used
3460 when publishing to HTML. For example, if you want to use the
3461 ALT and TITLE attributes of an inlined image, here is who to
3464 : [[./img/a.jpg{{alt="This is image A" title="Image with no action"}}]]
3466 Thanks to Charles Chen for this idea.
3468 *** Simplified way to specify file links
3470 In a link, you can now leave out the "file:" prefix if you
3471 write an absolute file name like =/Users/dominik/.emacs= or
3472 =~/.emacs=, or if you write a relative file name by using
3473 =./= or =../= to start the file path. You cannot write a
3474 plain file name, because plain text is interpreted as an
3477 So for example, a link to an image /A.jpg/ with a thumbnail
3478 /B.jpg/ can now be written like
3481 [[./A.jpg][./B.jpg] ]
3484 *** Changes in iCalendar export
3486 Deadline and scheduling time stamps are now treated
3487 differently in iCalendar export. The default behavior is now
3490 - a DEADLINE that appears in an entry that is a TODO item is
3491 used as the item's DUE date. Therefore, such a deadline
3492 will no longer show up in the calendar.
3494 - a DEADLINE that appears in an item that is *not* a TODO
3495 item is exported as an EVENT and will show up in the
3498 - a SCHEDULED timestamp in a TODO item will be used as the
3499 items DTSTART. Therefore, such a timestamp will not show
3502 - a SCHEDULED timestamp in an item that is not a TODO has no
3503 effect on iCalendar export at all. It will be ignored.
3505 Of course this would not be Emacs if you could not configure
3506 exactly what you want. Take a look at the variables
3507 =org-icalendar-use-deadlines= and
3508 =org-icalendar-use-scheduled= if you want to go back to the
3509 old behavior or even do something completely different.
3511 Thanks to Karen Cooke for triggering this change.
3513 *** New way to compare times during a property search
3515 If the comparison value in a property search is a string that
3516 is enclosed in angular brackets, a time comparison will be
3519 : +DEADLINE>="<2008-12-24 15:20>"
3521 looks for entries with a deadline on or after that time.
3522 Special allowed values are "<now>" (with time) and "<today>"
3525 This is based on a request by Manish.
3527 *** New option `org-open-directory-means-index'
3529 When set, a link pointing to a directory will actually open
3530 the index.org file in that directory. This is a good setting
3531 inside a publishing project. When not set, you get a
3532 finder/explorer window for that directory, or dired,
3533 depending on system and setup.
3535 This follows a request by Richard Riley.
3537 *** New parameters :prefix and :prefix1 for include files
3539 These parameters specify prefixes for each line of included
3540 text. :prefix1 is only for the first line, :prefix for all
3543 This follows a proposal by Richard Riley.
3545 *** New option :index-style for org-publish
3547 This option can be used to switch the style of the index
3548 produced by org-publish. Can be `list' (index is just an
3549 itemized list of the titles of the files involved) or `tree'
3550 (the directory structure of the source files is reflected in
3551 the index). The default is `tree'.
3553 Thanks to Manuel Hermenegildo for the patch.
3555 *** In the Agenda, inclusion of archives can now be toggled
3556 - Pressing =v= will toggle inclusion of trees with the
3557 ARCHIVE tag, this includes obviously the archive sibling.
3558 - Pressing `C-u v' will include trees with ARCHIVE tag, and
3559 will also include all archive files that are currently
3560 associated with your agenda files.
3562 This was triggered by a proposal by Manuel Hermenegildo.
3566 If I were to name my releases, this one would be called "Adam".
3567 Adam, you definitely owe me a beer :-). And I owe you one, too -
3568 thanks for all the great ideas.
3572 - Use cursor position in agenda for remember, scheduling and deadlines
3573 - New API for mapping a function over all or selected entries
3574 - Remember templates can be filed to beginning/end of a file
3575 - Visiting a filed remember buffer immediately
3576 - BBDB anniversaries are now links
3577 - Column view in the agenda now cleans the ITEM field
3578 - The format of section numbers in exported files is configurable
3579 - Direct, single key access to allowed values in column view
3580 - New hook to hack exported iCalendar files
3581 - Log mode in agenda now shows end time for CLOCK line
3583 ** Incompatible changes
3585 *** `C-c C-x C-k' now calls `org-mark-entry-for-agenda-action'
3586 It used to call =org-cut-special=, but that is also at bound
3587 to the key =C-c C-x C-w=.
3590 *** Making use of the cursor position in the agenda
3592 The date at the cursor in the agenda (and also in the
3593 calendar) can now be used to schedule entries, or to set the
3594 date in a remember template correctly. It is also designed
3595 to make it easier to move an entry to a date picked in the
3596 agenda. Thanks to Thomas Baumann for starting the thread
3597 that led to this development.
3599 **** Calling remember with the cursor date in the agenda
3601 If you want to use the date at the agenda cursor in a
3602 remember template, start remember from the agenda with the
3603 keys =k r=. While the template is being filled in, the
3604 default date for all time stamps, and also for all
3605 interactive escapes like =%^t= is now the date at the cursor
3606 in the agenda. The exact same command can also be used from
3607 the calendar if you prefer that.
3609 **** Picking a date for scheduling/deadline in the agenda
3611 You may now pick the date for scheduling an item or for
3612 setting a deadline in the agenda, where you have the best
3613 overview over free time slots. This is a two step process.
3615 1. First you pick the entry that should be acted upon. In
3616 the agenda, you use the keys =k m=. In an org-mode file,
3617 this is on =C-c C-x C-k=.
3619 2. Then you find the agenda date you want to apply. When the
3620 cursor is anywhere in the block belonging to that date,
3621 press =k s= to schedule, or =k d= to put a deadline. The
3622 agenda is not updated immediately, press =r= if you want
3623 it to show the affected entry in the right place.
3625 *** New API for mapping a function over all or selected entries
3627 Org has sophisticated mapping capabilities to find all
3628 entries satisfying certain criteria. Internally, this
3629 functionality is used to produce agenda views, but there is
3630 also an API that can be used to execute arbitrary functions
3631 for each or selected entries. The main entry point for this
3635 -- Function: org-map-entries func &optional match scope &rest skip
3636 Call FUNC at each headline selected by MATCH in SCOPE.
3638 FUNC is a function or a lisp form. The function will be
3639 called without arguments, with the cursor positioned at
3640 the beginning of the headline. The return values of all
3641 calls to the function will be collected and returned as
3644 MATCH is a tags/property/todo match as it is used in the
3645 agenda tags view. Only headlines that are matched by
3646 this query will be considered during the iteration.
3647 When MATCH is nil or t, all headlines will be visited by
3650 SCOPE determines the scope of this command, it can
3651 specify a file, all agenda files, the current tree and
3654 The remaining args are treated as settings for the
3655 skipping facilities of the scanner.
3658 The function given to that mapping routine can really do anything
3659 you like. Here is a simple example that will turn all entries in
3660 the current file with a tag =TOMORROW= into TODO entries with the
3661 keyword =UPCOMING=. Entries in comment trees and in archive
3662 trees will be ignored.
3664 #+begin_src emacs-lisp
3666 '(org-todo "UPCOMING")
3667 "+TOMORROW" 'file 'archive 'comment)
3670 The following example counts the number of entries with TODO
3671 keyword =WAITING=, in all agenda files.
3673 #+begin_src emacs-lisp
3674 (length (org-map-entries t "/+WAITING" nil 'agenda))
3677 *** Changes in Remember templates
3679 **** Remember templates can now use the cursor date in the agenda
3680 Use =k r= to start remember from the agenda, with enforcing
3681 the cursor date as default for any time stamps created by
3684 **** Filing remember templates to the beginning or end of a file
3685 You may now set the heading part of a remember template
3686 definition to `top' or `bottom'. The template will then be
3687 filed as a level 1 entry to the beginning or end of the
3688 target file, respectively. Thanks to Adam Spiers for this
3691 **** You can jump to the location of a note immediately after filing it
3692 Just include the =%&= escape anywhere in the template. An
3693 interesting combination now is to use =%!%&=, which will
3694 immediately file and visit the note, which is equivalent to
3695 generating the note directly in the target location. Thanks
3696 to Adam Spiers for this proposal.
3698 *** BBDB anniversaries are now links.
3699 If you are using =%%(bbdb-anniversaries)= to list
3700 anniversaries in the agenda, you can now directly access the
3701 entry that triggered a listed anniversary from the agenda.
3702 Just click the anniversary - it is a link now. Thanks to
3703 Thomas Baumann for a patch to this effect.
3705 *** Column view in the agenda now cleans the ITEM field
3706 See the new variable
3707 =org-agenda-columns-remove-prefix-from-item=. Thanks to Adam
3708 Spiers for this proposal.
3710 *** The format of section number in exported files is configurable
3712 See the new variable `org-export-section-number-format'.
3713 Thanks to Adam Spiers for this proposal.
3715 *** Direct access to allowed values in column view
3717 In column view, if you press a key 1-9 or 0, the
3718 corresponding values from the list of allowed values for that
3719 field at point will be directly selected. Thanks to Levin Du
3720 for this proposal and a patch to this effect.
3722 *** New hook to hack exported iCalendar files
3723 The new hook `org-before-save-iCalendar-file-hook' runs just
3724 before the buffer with a created iCalendar export is saved.
3725 This is what I settled for after a long discussion with Adam
3726 Spiers about doing some special filtering automatically.
3728 *** Log mode in agenda now shows end time for CLOCK lines
3729 When turning on log mode in the agenda with =l=, clock lines
3730 will now also list the end time, not only the starting time.
3731 Thanks to Tian Qiu for bringing this up again.
3732 *** Fixes and additions for org-publish
3733 - the :include and :index-title properties in org-publish
3734 work now as advertized
3735 - the #+TITLE of a page will be used in the index
3736 - new :completion-function property can define a hook to be
3737 run after publishing a file.
3739 Thanks to Manuel Hermenegildo for a patch to this effect.
3745 - Statistics cookies [/] and [%] for TODO entries
3746 - Editing source code example in the proper mode
3747 - iCalendar now defines proper UIDs for entries
3748 - New properties for customizing subtree export
3750 ** Incompatible changes
3752 - The default of the variable `org-tags-match-list-sublevels' is
3753 now `t'. The main reason for this is that it is easier to
3754 explain in the manual and will lead to fewer surprises.
3756 - The former CONTRIB directory is now called "contrib". This was
3757 already the case in the git distribution, but the tar and zip
3758 archives still did this wrong.
3762 *** Statistics for TODO entries
3764 The [/] and [%] cookies have already provided statistics for
3765 checkboxes. Now they do the same also for TODO entries. If a
3766 headline contains either cookie, changing the TODO state of any
3767 direct child will trigger an update of this cookie. Children
3768 that are neither TODO nor DONE are ignored.
3770 There have already been requests to automatically switch the
3771 parent headline to DONE when all children are done. I am not
3772 making this a default feature, because one needs to make many
3773 decisions about which keyword to use, etc. Instead of a complex
3774 customization variable, I am providing a hook that can be used.
3775 This hook will be called each time a TODO statistics cookie is
3776 updated, with the cursor in the corresponding line. Each
3777 function in the hook will receive two arguments, the number of
3778 done entries, and the number of not-done entries, and you can use
3779 the hook to change the state of the headline. Here is an example
3782 #+begin_src emacs-lisp
3783 (defun org-summary-todo (n-done n-not-done)
3784 "Switch entry to DONE when all sub-entries are done, to TODO otherwise."
3785 (let (org-log-done org-log-states) ; turn off logging
3786 (org-todo (if (= n-not-done 0) "DONE" "TODO"))))
3788 (add-hook 'org-after-todo-statistics-hook 'org-summary-todo)
3791 *** Editing source code example in the proper mode
3793 If you are writing a document with source code examples, you can
3794 include these examples into a =#+BEGIN_SRC lang ... #+END_SRC= or
3795 (with the org-mtags module loaded) a =<src...= structure. =lang=
3796 stands for the Emacs mode used for editing the language, this
3797 could be =emacs-lisp= for Emacs Lisp mode examples, or =org= for
3798 Org mode examples. You can now use the key "C-c '" (that is C-c
3799 followed by the single quote) to edit the example in its native
3800 mode. This works by creating an indirect buffer, narrowing it to
3801 the example and setting the appropriate mode. You need to exit
3802 editing by pressing "C-c '" again. This is important, because
3803 lines that have syntactic meaning in Org will be quoted by
3804 calling this command.
3806 "C-c '" also edits include files, the setupfile in a =#+setufile=
3807 line, and all those little foreign snippets like:
3810 ,#+HTML: this code can be edited in html-mode
3816 ,#+LaTeX: this code can be edited in latex-mode
3822 ,#+BEGIN_SRC fortran
3823 ,Here we can edit in fortran-mode
3827 *** iCalendar now defines proper UIDs for entries
3829 This is necessary for synchronization services. The UIDs are
3830 created using the the org-id.el module which is now part of the
3831 Org core. If you set the variable
3833 : (setq org-icalendar-store-UID t)
3835 then all created UIDs will be stored in the entry as an =:ID:=
3836 property. This is off by default because it creates lots of
3837 property drawers even if you only play with iCalendar export.
3838 But if you plan to use synchronization, you really need to turn
3841 Diary sexp entries do not yet receive proper persistent UIDs,
3842 because they are transformed to iCalendar format by icalendar.el
3843 which creates fresh UIDs each time, based on the current time.
3845 An interesting aspect of Org is that a single outline node can
3846 give rise to multiple iCalendar entries (as a timestamp, a
3847 deadline, a scheduled item, and as a TODO item). Therefore, Org
3848 adds prefixes "TS-", "DL-" "CS-", and "TD-" to the UID during
3849 iCalendar export, depending on what triggered the inclusion of
3850 the entry. In this way the UID remains unique, but a
3851 synchronization program can still figure out from which entry all
3852 the different instances originate.
3854 *** New properties for customizing subtree export.
3856 When exporting a subtree by selecting it before calling the
3857 export command, you can now use the properties =EXPORT_TITLE=,
3858 =EXPORT_TEXT=, and =EXPORT_OPTIONS= to overrule the global
3859 =#+TITLE=, =#+TEXT=, and =#+OPTIONS= settings. You can also set
3860 an export file name with =EXPORT_FILE_NAME= that will overrule
3861 the file name derived from the buffer's file name. As far as the
3862 options are concerned, the global =#+OPTIONS= will still be read,
3863 and only the options you give in the property will be
3864 overwritten. For example:
3867 ,#+OPTIONS: skip:nil
3870 , :EXPORT_FILE_NAME: ct.html
3871 , :EXPORT_TITLE: Steve's collected computer tricks
3872 , :EXPORT_OPTIONS: h:2 toc:nil
3876 *** New way to define tags for an entire file.
3878 Tags that are defined in a line like
3879 : #+FILETAGS: work urgent
3880 are inherited by all entries in the file.
3882 Thanks to Manuel Hermenegildo for this proposal.
3888 - Description lists are now supported natively
3889 - Block quotes for export
3890 - Fontified code examples in HTML export
3891 - Include files for export
3892 - Text before the first headline is now exported by default
3893 - In-buffer options may now be collected in an external file
3894 - The in-buffer settings keywords may now be lower case
3895 - Completion of structure elements
3896 - Startup visibility can now be influenced by properties
3897 - Clock task history, moving entries with the running clock
3898 - BBDB anniversaries much faster
3899 - New contrib files: org-eval.el and org-mtags.el
3901 ** Incompatible changes
3903 - The text before the first headline is now exported by default
3905 Previously, the default was to not include text in an org-mode
3906 buffer before the first headline. From now on, the default it to
3907 include it. If you like the old default better, customize the
3908 variable =org-export-skip-text-before-1st-heading= or set the
3909 value on a per-file basis with
3917 *** Description lists are now supported natively
3919 A plain list will be exported as a description list if the
3920 first item in the list has a /term/ and the /description/,
3921 separated by " :: ". For example
3923 : Emacs software by Carsten Dominik
3924 : - RefTeX :: Support for LaTeX Labels, References, Citations
3925 : - CDLaTeX :: more LaTeX functionality for Emacs
3926 : - TeXmathp :: checking LaTeX buffers for Math mode.
3927 : - ORG :: An Emacs mode for notes and projet planning.
3928 : - CONSTANTS :: An Emacs package for inserting the definition of
3929 : natural constants and units into a buffer.
3930 : - IDLWAVE :: The Emacs modes for editing and
3931 : running IDL and WAVE CL files.
3935 Emacs software by Carsten Dominik
3936 - RefTeX :: Support for LaTeX Labels, References, Citations
3937 - CDLaTeX :: more LaTeX functionality for Emacs
3938 - TeXmathp :: checking LaTeX buffers for Math mode.
3939 - ORG :: An Emacs mode for notes and projet planning.
3940 - CONSTANTS :: An Emacs package for inserting the definition of
3941 natural constants and units into a buffer.
3942 - IDLWAVE :: The Emacs modes for editing and
3943 running IDL and WAVE CL files.
3945 This works now in the HTML exporter, we still need to supoort
3946 it with the LaTeX and ASCII exporters.
3948 *** Block quotes for export
3950 For quoting an entire paragraph as a citation, use
3954 Everything should be made as simple as possible,
3955 but not any simpler -- Albert Einstein
3959 which will render as
3962 Everything should be made as simple as possible,
3963 but not any simpler -- Albert Einstein
3966 *** Fontified code examples in HTML export
3968 You can now get code examples fontified like they would be
3969 fontified in an Emacs Buffer, and export the result to HTML.
3970 To do so, wrap the code examples into the following
3974 ,#+BEGIN_SRC emacs-lisp
3975 (defun org-xor (a b)
3981 In the export, this will then look like this (if you are now
3982 looking at the ASCII export and do not see anything
3983 interesting, go and check out the HTML version at
3984 http://orgmode.org/Changes.html).
3986 #+BEGIN_SRC emacs-lisp
3987 (defun org-xor (a b)
3992 The string after the =BEGIN_SRC= is the name of the major emacs
3993 mode that should be used to fontify the code example, without the
3994 "-mode" at the end of the mode name. For example, if you are
3995 writing an Org tutorial with Org examples included, you would use
3996 "org" as the language identifier - in fact, I have used just
3997 that in the example above.
3999 Currently this works only for HTML export, and requires the
4000 /htmlize.el/ package, version 1.34 or later. For other
4001 backends, such structures are simply exported as EXAMPLE.
4003 *** Include files for export
4007 : #+INCLUDE "file" markup lang
4009 will lead to the inclusion of the contents of FILE at the moment
4010 of publishing. FILE should be surrounded by double quotes, this
4011 is obligatory if it contains space characters. The parameters
4012 MARKUP and LANG are optional. MARKUP can be "example", "quote",
4013 or "src". If it is "src", LANG should be the name of the Emacs
4014 mode to be used for fontifying the code. For example:
4016 : Here is my /.emacs/ file:
4017 : #+INCLUDE "~/.emacs" src emacs-lisp
4019 *** The text before the first headline is now exported by default
4021 Previously, the default was to not include text in an org-mode
4022 buffer before the first headline. From now on, the default it to
4023 include it. If you like the old default better, customize the
4024 variable =org-export-skip-text-before-1st-heading= or set the
4025 value on a per-file basis with
4030 *** In-buffer options may now be collected in an external file
4032 If you would like to share the Org setup between a number of
4033 files, you can now store in-buffer setup in a file and simply
4034 point to that file from each file that should read it. If
4035 you write in a buffer
4037 : #+SETUPFILE: "path/to/setup.org"
4039 then this file will be scanned for in-buffer options like
4040 =#+STARTUP=, =#+TITLE=, or =#+OPTIONS=.
4042 *** The in-buffer settings keywords may now be upper or lower case
4044 From now on, it makes no difference is you write =#+STARTUP= or
4045 =#+startup=, to make these lines less imposing. Similarly for all
4046 other in-buffer keywords.
4048 *** Completion of structure elements
4049 As a new experimental feature, Org now supports completion of
4050 structural elements like =#+BEGIN_EXAMPLE= in a special way.
4051 It work by typing, for example "<e" and then pressing TAB, on
4052 an otherwise empty line. "<e" will expand into a complete
4053 EXAMPLE template, with the cursor positioned in the middle.
4054 Currently supported templates are:
4057 : <e #+begin_example
4067 This is an experimental feature, please comment! See also
4068 below under /org-mtags.el/.
4070 *** Startup visibility can now be influenced by properties
4072 When Emacs opens an Org mode buffer, the outline visibility
4073 is set to a startup value that is taken from the variable
4074 =org-startup-folded=, or from a =#+STARTUP= setting in the
4075 buffer. After this has happened, the buffer will now also be
4076 scanned for entries with a =VISIBILITY= property. Wherever
4077 such a property is found, the corresponding subtree will get
4078 its visibility adjusted. Allowed values for the property
4081 - folded :: Fold the subtree
4082 - children :: Show the text after the headline, and the
4083 headlines of all direct children
4084 - content :: Show all headlines in the tree, but no text below any
4086 - all :: Show the entire subtree
4088 For example, I am using this for the huge /Changes.org/ file that
4089 is the source for the list of visible changes you are reading
4090 right now. The top-most entry in this file always describes the
4091 changes in my current working version. The start of this section
4092 currently looks like this:
4097 , :VISIBILITY: content
4102 This was a proposal by Ben Alexander.
4104 The command =C-u C-u TAB= will switch back to the startup
4105 visibility of the buffer.
4107 *** Clock task history, and moving entries with the running clock
4109 Org now remembers the last 5 tasks that you clocked into, to
4110 make it easier to clock back into a task after interrupting
4111 it for another task.
4112 - =C-u C-u C-c C-x C-i= (or =C-u C-u I= from the agenda) will
4113 clock into that task and mark it as current default task.
4114 - =C-u C-c C-x C-i= (or =C-u I= from the agenda) will offer a
4115 list of recently clocked tasks, including the default task,
4116 for selection. =d= selects the default task, =i= selects
4117 the task that was interrupted by the task that is currently
4118 being clocked. =1=,... selects a recent task. When you
4119 select a task, you will be clocked into it.
4120 - You can use =C-u C-c C-x C-j= to jump to any of these
4123 When moving an entry using structure editing commands,
4124 archiving commands, or the special subtree cut-and-paste
4125 commands =C-c C-x C-w= and =C-c C-x C-y=, the running clock
4126 marker and all clock history markers will be moved with the
4127 subtree. Now you can start a clock in a remember buffer and
4128 keep the clock running while filing the note away. See also
4129 the variable `org-remember-clock-out-on-exit'.
4131 *** BBDB anniversaries much faster
4133 =bbdb-anniversaries= is now much faster, thanks to a new
4134 approach using a hash for birthdays. Thanks to Thomas
4135 Baumann for a patch to this effect.
4137 *** New files in the contrib directory
4139 Do people think any of these should become core?
4141 - org-eval.el :: This new module allows to include the result
4142 of the evaluation of Lisp code (and other scripting
4143 languages) into the buffer, similar to the =<lisp>= tag
4144 of [[http://mwolson.org/static/doc/emacs-wiki.html#Lisp-Tricks][Emacs Wiki]] and [[http://mwolson.org/static/doc/muse/Embedded-Lisp.html#Embedded-Lisp][Muse]].
4145 - org-mtags.el :: This new modules allows you to use
4146 Muse-like tags for some structure definitions in Org.
4147 For example, instead of
4155 In fact, I myself find these easier to type and to look
4156 at. Also, it will allow you to more easily move text
4157 and files back and forth between Org and Muse. For a
4158 list of supported structure elements, see the commentary
4159 in the file [[http://repo.or.cz/w/org-mode.git?a=blob_plain;f=contrib/lisp/org-mtags.el;hb=HEAD][commentary in the file org-mtags.el]].
4161 If you load this module and use the "<i" etc completion
4162 described above, the Muse form will automatically be
4166 Many bug fixes again. Will this ever stop?
4172 - Column view (mostly) works now in XEmacs
4173 - Summaries for columns in the agenda
4174 - The special property Effort can be used for effort estimates
4175 - New operators for property searches
4176 - Search commands can now include archive files.
4177 - Clock tables can include the archive files
4178 - Orgtbl radio tables generalized.
4182 *** Column view works now in XEmacs
4184 I had already given up on this, but Greg Chernev (who
4185 implemented noutline.el for XEmacs and in this way kept Org
4186 alive on XEmacs) has done it again and provided the patches
4187 to make column view work under XEmacs. There are still some
4188 problems, but the basics work and we will iron out the
4189 remaining issues, hopefully soon.
4191 *** Summaries for columns in the agenda
4193 If any of the columns has a summary type defined, turning on
4194 column view in the agenda will show summaries for these
4195 columns. Org will first visit all relevant agenda files and
4196 make sure that the computations of this property are up to
4197 date. This is also true for the special =CLOCKSUM= property.
4198 Org will then sum the values displayed in the agenda. In the
4199 daily/weekly agenda, the sums will cover a single day, in all
4200 other views they cover the entire block. It is vital to
4201 realize that the agenda may show the same entry multiple
4202 times (for example as scheduled and as a deadline), and it
4203 may show two entries from the same hierarchy (for example a
4204 /parent/ and it's /child/). In these cases, the summation in
4205 the agenda will lead to incorrect results because some values
4208 *** The special property Effort can be used for effort estimates
4210 If you want to plan your work in a very detailed way, or if
4211 you need to produce offers with quotations of the estimated
4212 work effort, you may want to assign effort estimates to
4213 entries. If you are also clocking your work, you may later
4214 want to compare the planned effort with the actual working
4215 time. Effort estimates can now be stored in a special
4216 property =Effort=, displayed side-to-side with clock sums,
4217 and also be summed over a day, in order to show the planned
4218 work load of a day. See the manual for more details.
4220 *** New operators for property searches
4222 Property searches can now choose a number of different
4223 operators for comparing values. These operators are `=',
4224 `<>', `<', `<=', `>', and `>='.
4226 When the search term uses the operator with plain number like
4227 =+Effort>=2.7=, then the property value is converted to a
4228 number and a numerical comparison takes place.
4230 When the search term uses a string on the right hand side of
4231 the operator, a string comparison is done: =+PRIORITY<"C".=
4233 Finally, if the right hand side is enclosed in curly braces,
4234 a regexp match is done: =aaa={regexp}=. In this case you
4235 should use only the `=' or `<>' operators, meaning "does
4236 match" or "does not match", respectively.
4238 This was a triggered with a request by Dan Davison.
4240 *** Search commands can now include archive files.
4242 If the value of the customization variable
4243 =org-agenda-text-search-extra-files= contains the symbol
4244 =agenda-archives= as the first element in the list, all
4245 archive files of all agenda files will be added to the list
4246 of files to search. This is relevant for the search view
4247 =C-c a s=, as well as for the agenda files multi-occur
4250 *** Clock tables can include the archive files
4252 There are new values for the =:scope= parameter of a clock
4253 table. This can now be =file-with-archives= and
4254 =agenda-with-archives=, in order to collect information not
4255 only from the current file or all agenda files, but also from
4256 all archive files that are currently used by these files.
4258 *** Orgtbl radio tables generalized.
4260 The options available for radio tables using orgtbl-mode have
4261 been expanded. You may use several reception points and
4262 formats for the same table, you may have special formatting
4263 in the last line of the table, and many table parameters may
4264 be functions, so that more general transformations are
4265 possible. Jason Riedy provided a patch for this, and he will
4266 hopefully come up with some examples. Thanks!
4270 This is a new major release, mostly because of structural changes
4271 in Org. However, since this took a while, there is also a long
4272 list of small improvements and some new significant features.
4276 - The Org distribution has a new structure
4277 - New system for selecting modules to load
4278 - New archiving mechanism: The Archive Sibling
4279 - Support for Sebastian Rose's JavaScript org-info.js.
4280 - Internal links work now better in HTML export
4281 - Export commands can be done in the background
4282 - Flexible setting of the time block shown by the clock table
4283 - Clock table can be included in the agenda
4284 - Support for ISO week dates (ISO 6801)
4285 - Tag inheritance can be limited to a subset of all tags
4286 - Entries can be sorted by TODO keyword
4287 - And some more small fixes and improvements
4289 ** Incompatible changes
4291 *** The Org distribution has a new structure
4293 In the distribution files as well as in the GIT repository,
4294 the lisp files are now located in a subdirectory "lisp", and
4295 the documentation files are located in a subdirectory "doc".
4296 If you are running Org directly from the unpacked
4297 distribution archive (zip or tar file, or GIT repository),
4298 you need to modify your settings for load-path accordingly.
4302 *** The Org distribution has a new structure
4304 In the distribution files as well as in the GIT repository,
4305 the lisp files are now located in a subdirectory "lisp", and
4306 the documentation files are located in a subdirectory "doc".
4307 If you are running Org directly from the unpacked
4308 distribution archive (zip or tar file, or GIT repository),
4309 you need to modify your settings for load-path accordingly.
4313 Org-mode has now a system for loading modules by simply
4314 configuring an option that lists all the modules you want to
4315 use. Customize the variable `org-modules'. That variable
4316 lists both modules that are part of the Org-mode core (and in
4317 this way part of Emacs), and modules that are contributed
4318 packages. Contributed modules will only be available when
4319 you have installed them properly (most likely by downloading
4320 the distribution and adding /path/to/orgdir/contrib/lisp to
4323 *** New archiving mechanism: The Archive Sibling
4325 There is a new method to archive entries in the current file:
4326 By moving it to a sibling called the /Archive Sibling/. That
4327 sibling has the heading "Archive" and also carries the
4328 ARCHIVE tag. This can be a great way to do archiving inside
4329 a project, to get parts of the project out of the way and to
4330 wait with true archiving (moving to another file) until the
4331 entire project is done. Archiving to a sibling keeps much of
4332 the context, for example inherited tags and approximate tree
4335 The key binding for the is "C-c C-x A", and from the agenda
4336 buffer you can simply use "A".
4338 Thanks to Ilya Shlyakhter for this rather clever idea.
4340 *** Support for Sebastian Rose's JavaScript org-info.js.
4342 This fascinating program allows a completely new viewing
4343 experience for web pages created from Org files. The same
4344 document can be viewed in different ways, and switching
4345 between the views as well as navigation uses single-key
4348 One of the view types is an /Info-like/ interface where you
4349 can jump through the sections of the document with the `n'
4350 and `p' keys (and others). There is also a /folding/
4351 interface where you can fold the document much like you can
4352 fold it in org-mode in Emacs, and cycle through the
4353 visibility both locally and globally.
4355 To set this up, all you need to do is to make sure that
4356 org-infojs.el gets loaded (customize the variable org-modules
4357 to check). Then add this line to the buffer:
4359 : #+INFOJS_OPT: view:info
4361 In that line, you can configure the initial view and other
4362 settings. Available views are =info= for the info-like
4363 interface, and =overview=, =content=, and =showall= for the
4364 folding interface. See the manual for more details. The
4365 JavaScript program is served from
4366 http://orgmode.org/org-info.js, and your exported HTML files
4367 will automatically get it from there. However, you may want
4368 to be independent of the existence and stability of
4369 orgmode.org and install a copy locally. Then you need to
4370 change the path from which the script is loaded, either by
4371 using something like
4373 : #+INFOJS_OPT: view:info path:../scripts/org-info.js
4375 or by configuring the variable =org-infojs-options=.
4377 For details see the documentation provided by Sebastian Rose
4378 together with org-info.js.
4380 *** Export improvements
4382 - The export of internal links to HTML now works a lot
4383 better. Most internal links that work while editing an Org
4384 file inside Emacs will now also work the the corresponding
4387 - You can run many of the export commands in the background
4388 by using `C-c C-u C-c C-e' in order to start the process.
4389 RIght now this will only work if "emacs" is the right
4390 command to get to your Emacs executable - I hope to make
4391 this less system dependent in the future.
4393 Both these are based on requests by Ilya Shlyakhter.
4395 *** Improvements to clocktable
4397 - The clocktable is now much more flexible and user friendly
4398 when trying to specify the time block that should be
4399 considered when constructing the table.
4401 The =:block= parameter to the table can now look like any
4404 | :block | meaning |
4405 |--------------+-----------------------|
4406 | 2008 | The entire year 2008 |
4407 | 2008-04 | The month April 2008 |
4408 | 2008-04-02 | The day April 2, 2008 |
4409 | 2008-W14 | ISO-Week 14 in 2008 |
4411 | today-5 | The day five days ago |
4412 | thisweek | The current week |
4413 | thisweek-2 | Two weeks ago |
4414 | thismonth | The current month |
4415 | thismonth-12 | Same month, last year |
4416 | lastmonth | Same as thismonth-1 |
4419 What is more, you can now use the =S-left= and =S-right=
4420 keys to shift the time block around. The cursor needs to
4421 be in the =#+BEGIN: clocktable= line for this to work. If
4422 the current block is =today=, =S-left= with switch to
4423 yesterday. If the current block is =2008-W14=, =S-right=
4424 will switch to the following week.
4426 - When the clocktable is collecting from several files, the
4427 total time for each file will now also be listed. This was
4428 a request from Bernt Hansen.
4430 - If you turn on the new clock report mode with the "R" key in
4431 the agenda, a clock table will be attached to the agenda,
4432 showing the clock report for the file scope and time
4433 interval of the agenda view. To turn this on permanently,
4434 configure the variable
4435 =org-agenda-start-with-clock report-mode=. To modify the
4436 properties of the table, in particular the =:maxlevel=
4437 depth, configure =org-agenda-clockreport-parameter-plist=.
4439 *** Support for ISO week dates (ISO 6801)
4441 The agenda now shows the ISO week for the displayed dates, in
4442 the form =W08= for week 8.
4444 The keys =d=, =w=, =m=, and =y= in the agenda view now accept
4445 prefix arguments. Remember that in the agenda, you can
4446 directly type a prefix argument by typing a number, no need
4447 to press =C-u= first. The prefix argument may be used to
4448 jump directly to a specific day of the year, ISO week, month,
4449 or year, respectively. For example, =32 d= jumps to February
4450 1st, =9 w= to ISO week number 9. When setting day, week, or
4451 month view, a year may be encoded in the prefix argument as
4452 well. For example, =200712 w= will jump to week 12 in the
4453 year 2007. If such a year specification has only one or two
4454 digits, it will be mapped to the interval 1938-2037.
4456 When entering a date at the date prompt, you may now also
4457 specify an ISO week. For example
4459 : w4 Monday of week 4
4460 : fri w4 Friday of week 4
4461 : w4-5 Same as above
4462 : 2012 w4 fri Friday of week 4 in 2012.
4463 : 2012-W04-5 Same as above
4465 So far I have not implemented the effect of
4466 `org-read-date-prefer-future' on this functionality, because
4467 it seemed too magic for me. I'd appreciate comments on this
4468 issue: Should `org-read-date-prefer-future' also push dates
4469 into the next year if the week you are entering has already
4470 passed in the current year? For consistency I guess this
4471 should be the case, but I cannot quite wrap my head around
4474 I hope but am not entirely convinced that this will behave
4475 sanely also during the first/last week of a year. Please
4476 test extensively and report back.
4478 This was a request by Thomas Baumann.
4480 *** Improvements in Search View
4482 - Calling search view with a C-u prefix will make it match
4483 only in TODO entries.
4485 - The single quote is no longer considered a word character
4486 during search, so that searching for the word "Nasim" will
4487 also match in "Nasim's".
4492 - Inheritance of tags can now be limited to a subset of all
4493 tags, using the variable =org-use-tag-inheritance=. This
4494 variable may now be a regular expression or a list to
4495 select the inherited tags. Thanks to Michael Ekstrand for
4496 this excellent proposal.
4498 The regexp option is also implemented for
4499 =org-use-property-inheritance=, so that you can now select
4500 properties for inheritance my name.
4502 - The INHERIT flag to the function =org-entry-get= can be set
4503 to the symbol =selective=. If this is the case, then the
4504 value of the property will be retrieved using inheritance
4505 if and only if the setting in
4506 =org-use-property-inheritance= selects the property for
4509 - There are now special faces for the date lines in the
4510 agenda/timeline buffers, and another special face for days
4511 that fall on a weekend: =org-agenda-date= and
4512 =org-agenda-date-weekend=. Both these faces are initially
4513 similar to the =org-agenda-structure= face, but you can
4514 customize them freely.
4516 - When an entry already has a scheduling or deadline time
4517 stamp, calling `C-c C-s' or `C-c C-d', respectively, will
4518 now use that old date as the default, and you can can use
4519 the "++4d" syntax to invoke shifts relative to that default
4520 date. Simply pressing RET at the prompt will keep the
4521 default date, not switch to today.
4523 This was an omission in the earlier implementation, spotted
4524 by Wanrong Lin. Thanks!
4526 - File names in remember templates can be relative, if they
4527 are, they will be interpreted relative to =org-directory=.
4529 - The handling of the clipboard when inserting into remember
4530 templates is now much better, and gives more control on what
4531 should be inserted with new %-escapes:
4533 - =%c= - Now always insert the head of the kill ring, never
4536 - =%x= - Insert the content of the X clipboard. This is the
4537 first non-empty value from the PRIMARY, SECONDARY and
4538 CLIPBOARD X clipboards.
4540 - =%^C= - This allows the user to choose between any of the
4541 clipboard values available, the kill ring head, and the
4542 initial region if set.
4544 - =%^L= - Like =%^C=, but this inserts an org link using the
4547 Thanks to James TD Smith for this patch.
4549 - Table export to an internal file can now use a format
4550 specification, similar to the formats that are used by
4551 orgtbl radio tables. The default format is in the variable
4552 =org-table-export-default-format=. You can use properties
4553 =TABLE_EXPORT_FILE= and =TABLE_EXPORT_FORMAT= to specify the
4554 file name to which the export should go, and a local
4555 format. For example:
4558 : :TABLE_EXPORT_FILE: ~/xx.txt
4559 : :TABLE_EXPORT_FORMAT: orgtbl-to-generic :splice t :sep "\t"
4562 Thanks to James TD Smith for this patch.
4564 - Entries can be sorted by TODO keyword, and the order is given
4565 by the definition sequence of the TODO keywords in the
4566 variable =org-todo-keywords=, or in the =#+TODO= line. Use
4567 the "o" key when sorting with =C-c ^=.
4569 Thanks to James TD Smith for this patch.
4576 - New keyword search agenda view
4578 - Many new extensions available in the CONTRIB directory
4580 - New remember template option: pre-selection contexts
4582 - Modifying list/headline status of a line
4584 - Granularity while editing time stamps
4586 - New repeaters mechanisms
4588 - New parameters for dynamic blocks ad the clock table
4590 - Limiting iCalendar export to fewer entries
4592 - =M-RET= splits lines again
4596 ** Incompatible changes
4598 - The variable `org-time-stamp-rounding-minutes' is now a list
4599 of two values - if you have configured this variable before,
4604 *** New keyword search agenda view
4606 `C-c a s' now invokes a special agenda view that can be used
4607 to search notes by keyword and regular expressions. In
4608 particular, it does not require a single regular expression
4609 or string to search for, but it can search for a number
4610 keywords or regexps that can occur in arbitrary sequence in
4611 the entry. The search knows the boundaries of an entry, can
4612 use simple Boolean logic and is reasonably fast. For
4613 example, the search string
4615 : +computer +wifi -ethernet -{8\.11[bg]}
4617 will search for note entries that contain the keywords
4618 =computer= and =wifi=, but not the keyword =ethernet=, and
4619 which are also not matched by the regular expression
4620 "8\.11[bg]", meaning to exclude both 8.11b and 8.11g. If the
4621 first character of the search string is an asterisk, the
4622 search will only look at headlines - otherwise it will look
4623 at the headine and the text below it, up to the next
4624 (possibly sub-) heading.
4626 The command searches all agenda files, and in addition the
4627 files listed in =org-agenda-text-search-extra-files=.
4629 I find it very useful to define a custom command to do such
4630 a search only in a limited number of files (my notes files),
4633 : ("N" "Search notes" search ""
4634 : ((org-agenda-files '("~/org/notes.org" "~/org/computer.org"))
4635 : (org-agenda-text-search-extra-files nil)))
4637 *** Many new extensions available in the CONTRIB directory
4639 - Phil Jackson's /org-irc.el/ is now part of the Org-mode
4640 core, which means it will become part of Emacs soon.
4642 - The new development model already starts to pay off, a
4643 number of interesting extensions are now part of the
4644 distribution. Check the file CONTRIB/README for a list.
4646 - There is a new variable `org-default-extensions'.
4647 Configuring this variable makes it *very* easy to load
4648 these default extensions - eventually this will be expanded
4649 to cover contributed extensions as well.
4651 *** New remember template option: pre-selection contexts
4653 - Remember template definitions now allow six elements. The
4654 last element defines the contexts in which the template
4655 should be offered. It can be a list of major modes, a
4656 function, =t= or =nil=. If it is a list of major-mode, the
4657 template will be available only when =org-remember= is
4658 called from a buffer in one of these modes. If it is a
4659 function, the template will be offered only if the function
4660 returns `t' when called in the current buffer. A value of
4661 =t= or =nil= for this element means select this template in
4664 One possible application for this would be to have several
4665 templates all using the same selection letter, and choosing
4666 the right one based on context. For example, think of
4667 tasks describing a bug in a source code file. With the
4668 following configuration we make sure that the bug reports
4669 are filed into the appropriate sections of the target file.
4671 : (setq org-remember-templates
4672 : '(("Elisp" ?b "* %a\n\n%i%?" "~/bugs.org" "Elisp bugs" (emacs-lisp-mode))
4673 : ("C Bugs" ?b "* %a\n\n%i%?" "~/bugs.org" "C bugs" (cc-mode))))
4675 See (info "(org)Remember templates") for details.
4677 *** Modifying list/headline status of a line
4679 - `C-c -' has now more functions:
4680 + In a table, add a hline as before
4681 + In an item list, cycle bullet type as before
4682 + In a normal line, turn it into an item
4683 + In a headline, turn it into an item
4684 + If there is an active region, turn each line into an item.
4685 But if the first region line is already an item, remove
4686 item markers from all lines.
4688 Based on proposals by Bastien.
4690 - `C-c *' has now more functions
4691 + in a table, recompute, as before
4692 + in a normal line, convert it to a sub heading.
4693 + at an item, convert it into a subheading
4694 + if there is an active region, convert all lines in the
4695 region to headlines. However, if the first lie already is
4696 a heading, remove the stars from all lines int he region.
4698 Based on proposals by Bastien.
4700 *** Changes related to time stamps
4702 - The value variable =org-time-stamp-rounding-minutes= is now
4703 a list of two values. The first applies when creating a new
4704 time stamp. The second applies when modifying a timestamp
4705 with S-up/down. The default for this new task is 5 minutes,
4706 but 15 may also be a very good value for many people. If
4707 S-up/down is used on a time stamp where the minute part is
4708 not compatible with this granularity it will be made so.
4709 You can bypass this by using a prefix argument to exactly
4710 specify the number of minutes to shift.
4712 This was a proposal by Adam Spiers.
4714 - New repeaters that shift a date relative to today, or that
4715 make sure that the next date is in the future. For example:
4717 :** TODO Call Father
4718 : DEADLINE: <2008-02-10 Sun ++1w>
4719 : Marking this DONE will shift the date by at least one week,
4720 : but also by as many weeks as it takes to get this date into
4721 : the future. However, it stays on a Sunday, even if you called
4722 : and marked it done on Saturday.
4723 :** TODO Check the batteries in the smoke detectors
4724 : DEADLINE: <2005-11-01 Tue .+1m>
4725 : Marking this DONE will shift the date to one month after
4728 Proposed by Wanrong Lin and Rainer Stengle.
4730 *** New parameters for dynamic blocks ad the clock table
4732 - There is a new =:link= parameter for the clocktable. When
4733 set, the headlines listed in the table will be links to the
4736 - There is a new =:content= parameter that is passed to the
4737 writer function of the dynamic block. Use this parameter
4738 to pass the previous content of the block to the writer
4739 function, in case you want to make the outcome dependent on
4740 the previous content.
4742 *** Limiting iCalendar export to fewer entries
4744 - New way to limit iCalendar export to the entries captured in
4745 an agenda view. This is done by "writing" the agenda view
4746 using `C-x C-w' to a file with extension .ics.
4748 This was a request by Kyle Sexton.
4752 - Due to a popular revolt shortly after the 5.22 release,
4753 =M-RET= can again be used to split a line so that the rest
4754 of the line becomes the new heading. However, if you do
4755 this in a heading containing tags, the tags will stay in the
4758 Customize the variable =org-M-RET-may-split-line= if you
4759 don't want this command to split a line in the middle. The
4760 same variable also influences line splitting in items and in
4763 - There are three new hooks:
4765 =org-follow-link-hook=: runs after following a link
4766 =org-publish-before-export-hook=: runs before export
4767 =org-publish-after-export-hook=: runs after export
4771 ** Incompatible changes
4773 - The variable `org-log-done' is now less complex.
4774 - The in-buffer settings for logging have changed. Some
4775 options no longer exists, some new ones have been added.
4779 *** Changes to logging progress
4781 There is now more control over which state changes are being
4782 logged in what way. Please read carefully the corresponding
4783 sections in the manual. Basically:
4785 - The variable `org-log-done' has been simplified, it no
4786 longer influences logging state changes and clocking out.
4787 - There is a new variable for triggering note-taking when
4788 clocking out an item: `org-log-note-clock-out'.
4789 - Logging of state changes now has to be configured on a
4790 pre-keyword basis, either in `org-todo-keywords' or in the
4791 #+TODO in-buffer setting.
4792 - These per-keyword settings allow more control. For example
4794 : WAIT(w@) Record a note when entering this state.
4795 : WAIT(w!) Record a timestamp when entering this state.
4796 : WAIT(w@/!) Recore a note when entering and timestamp
4797 : when leaving this state. This is great for
4798 : getting a record when switching *back* from
4800 : WAIT(/!) Record a timestamp when leaving this state.
4801 : Here we not even define a fast access
4802 : character, but just the logging stuff.
4804 This was triggered by requests from Wanrong Lin and Bernt Hansen.
4808 - M-RET no longer brakes a line in the middle, it will make a
4809 new line after the current or (if cursor is at the beginning
4810 of the line) before the current line.
4812 - RET, when executed in a headline after the main text and
4813 before the tags will leave the tags in the current line and
4814 create a new line below the current one.
4818 Bug fixes, in particular the long-hunted bug about wrong window
4819 positions after pressing SPACE in the agenda. Hopefully this
4826 *** Remember/Refile/Goto
4828 - The use of prefix arguments for the commands `org-remember'
4829 and `org-refile' has been normalized.
4831 - The clock can now safely be used in a remember buffer.
4833 - The variable `org-remember-use-refile-when-interactive'
4834 introduced only in 5.19 is already obsolete. Please use
4835 `org-remember-interactive-interface' instead.
4837 - It is no longer necessary to update the refiling targets.
4839 - Automatic isearch in `org-goto'.
4841 - Outline-path-completion as alternative org-goto interface.
4845 - Checkboxes now work hierarchically.
4847 - `C-k' can now behave specially in headlines.
4849 - Repeater for tasks in plain timestamps.
4851 - All clock intervals of an item show in agenda/timeline.
4853 - New parameter =:step= for clocktable, to get daily reports.
4855 - Never loose a repeaded scheduled item from the agenda.
4857 - Archiving a subtree now stores the outline path in a property.
4859 - Links to messages in Apple Mail.
4863 ** Incompatible Changes
4865 - The variable `org-remember-use-refile-when-interactive'
4866 introduced only in 5.19 is already obsolete. Please use
4867 `org-remember-interactive-interface' instead.
4871 *** Remember/Refile/Goto
4873 - The use of prefix arguments for the commands `org-remember'
4874 and `org-refile' has been normalized:
4876 + when called without prefix argument, the command does its
4877 normal job, starting a remember note or refiling a tree.
4879 + when called with a single C-u prefix, these commands can be
4880 used to select a target location and to jump there. In
4881 the case of `org-remember', you will be prompted for a
4882 template and then Emacs jumps to the default target
4883 location or this template. In the case of `org-refile',
4884 you select a location from the refile target list and jump
4887 + when called with two prefixes (`C-u C-u'), the command
4888 jumps to the location last used for storing a note or a
4891 - When the clock is running inside an remember buffer, storing
4892 the remember buffer with `C-c C-c' will automatically clock
4893 out. This was inspired by a request by Rainer Stengle.
4895 - The variable `org-remember-use-refile-when-interactive'
4896 introduced only in 5.19 is already obsolete. Please use
4897 `org-remember-interactive-interface' instead. This new
4898 variable does select the interface that is used to select
4899 the target for a remember note in an interactive way.
4900 Possible values are:
4902 + `outline': Use an outline of the document to select a
4904 + `outline-path-completion': Use completion of an outline
4905 path to select a location.
4906 + `refile': Offer the `org-refile-targets' as possible
4909 - It is no longer necessary to update the refiling targets -
4910 they are always current.
4912 - In `org-goto', typing characters now automatically starts
4913 isearch from the beginning of the buffer. The isearch is
4914 special also because it only matches in headline. This
4915 goes some way toward saving org-goto from being removed
4916 from Org-mode. Thanks to Piotr Zielinski for the code, and
4917 sorry that it took me so long to put it in. If you prefer
4918 to use single letters n,p,f,b,u,q for navigation as before,
4919 configure the variable `org-goto-auto-isearch'.
4921 - Outline-path-completion is now available as an alternative
4922 interface in the command `org-goto'. Please select the
4923 default interface you'd like to use with the new variable
4924 `org-goto-interface'. You can then select the alternative
4925 interface with a prefix argument to `C-c C-j' (org-goto). I
4926 am considering to make outline-path-completion the default
4927 interface. Comments?
4932 - Checkboxes now work hierarchically. When a plain-list item
4933 with a checkbox has children with checkboxes, the status of
4934 the item's checkbox is calculated from the children, each
4935 time a checkbox is toggled with C-c C-c. Thanks to Miguel
4936 A. Figueroa-Villanueva for a patch to this effect.
4938 - There is a new variable `org-special-ctrl-k'. When set,
4939 `C-k' will behave specially in headlines:
4941 + When the cursor is at the beginning of a headline, kill
4942 the entire line and possible the folded subtree below the
4944 + When in the middle of the headline text, kill the
4945 headline up to the tags.
4946 + When after the headline text, kill the tags.
4948 This is following a proposal by Piotr Zielinski.
4950 - You can now also have a plain (as opposed to deadline or
4951 scheduled) repeater timestamp in a task. Switching the task
4952 to DONE will now also shift a plain time stamp. This was a
4953 request by Austin Frank.
4955 - If an entry is clocked multiple times, it will now show up
4956 several times in the agenda and timeline buffers, when
4957 log-mode is on. This was a proposal by Jurgen Defurne.
4959 - The clock table accepts a new parameter =:step=. This
4960 parameter can be `day' or `week' and will result in separate
4961 tables for each day or week in the requested time interval.
4962 This was triggered by a proposal by Sacha Chua in her [[http://sachachua.com/wp/2007/12/30/clocking-time-with-emacs-org/][blog]].
4964 - A time-stamp with a repeater now no longer refers to the
4965 date *closest* to the current day. Instead, it means either
4966 today or the most recent match. This change makes sure that
4967 overdue scheduled or deadline items never disappear from the
4968 agenda. With the previous convention, an overdue scheduled
4969 item would disappear. For example, a weekly item scheduled
4970 for Sunday would appear as overdue until Wednesday, and the
4971 suddenly disappear until next Sunday. Now the item will
4972 show up as "Sched 7x" on Saturday. From Sunday on it will
4973 be in the list as "Scheduled", i.e. old sins will be
4974 forgiven. This follows a request by Warong, Dennis and
4977 - Archiving a subtree now creates an additional property,
4978 =ARCHIVE_OLPATH=. This property contains the "path" in the
4979 outline tree to the archived entry, as it was in the
4980 original file. For example, archiving =Fix the door= in the
4988 will file is with the following property
4990 : :ARCHIVE_PATH: Task/HOME/Garage
4992 Note that you can configure (i.e. limit) the information
4993 that gets stored upon archiving with the variable
4994 `org-archive-save-context-info'.
4996 - New file `org-mac-message.el' by John Wiegley to create
4997 links for messages in Apple Mail, and to follow these
5006 - Column view can list the clocked times of a subtree.
5008 - Storing remember notes can use the `org-refile' interface.
5010 - Storing remember notes no longer produced empty lines.
5012 - Moving subtrees now folds all siblings of the subtree.
5014 - New variable `org-agenda-todo-keyword-format'.
5016 - Hack to allow brackets in link descriptions.
5018 - Clocking into an entry can enforce a specific TODO state.
5020 - EXPORT_FILE_NAME may be an absolute file name with "~".
5022 - Bug fixes, lots of them.
5026 - A new special column definition lists the sum of all CLOCK
5027 entries in a subtree. For example
5029 : #+COLUMNS: %20ITEM %10Time_Estimate{:} %CLOCKSUM
5031 will allow you to compare estimated times (as given in the
5032 Time_Estimate property) with the clocked times. This was a
5033 request by Bernt Hansen.
5035 - Storing remember notes can now use the `org-refile'
5036 interface instead of the `org-goto' interface (see the
5037 variable `org-remember-use-refile-when-interactive').
5038 Nothing will change if the note is stored immediately after
5039 pressing `C-c C-c' in the =*Remember*= buffer. But if you
5040 have chosen (e.g. by pressing `C-u C-c C-c') to
5041 interactively select the filing location (file and
5042 headline), the refile interface will be used instead. I am
5043 excited about this change, because the `org-goto' interface
5044 is basically a failure, at least for this application. Note
5045 that in any case the refile interface has to be configured
5046 first by customizing `org-refile-targets'.
5048 - Notes inserted with remember now remove any whitespace
5049 before and after the note before being pasted, so that there
5050 will be no empty lines inserted together with the note. We
5051 could invent special syntax in remember templates to allow
5052 creating empty lines before a note - is there anyone who'd
5055 - Moving subtrees now folds all siblings of the subtree. This
5056 is the only reasonably simple way I could find to avoid the
5057 reported inconsistencies in the folding state of the outline
5058 tree after moving entries. There are reasons to like this
5059 new behavior, because it easily visualizes where the tree is
5060 located after the move. Still, not everyone might be happy
5061 with this. Massive complaining would be needed to make me
5064 - New variable `org-agenda-todo-keyword-format' to specify the
5065 width of the TODO keyword field in the agenda display. Use
5066 it to get things to line up better. This was a proposal by
5069 - If a link description inserted with `C-c C-l' contains
5070 brackets, the brackets will now be converted into curly
5071 braces. This looks similar enough. Supporting brackets in
5072 link descriptions is, for technical reasons too long to
5073 explain here, complex.
5075 - The new option `org-clock-in-switch-to-state' can be set to
5076 a TODO state that will be enforced when the clock is started
5077 on an entry. This follows an idea by Sacha Chua.
5079 - The EXPORT_FILE_NAME property may now also be an absolute
5080 file name, and it may contain abbreviations like "~" for the
5081 users home directory. This was requested by Adam Spiers.
5083 - Bug fixes, lots of them.
5095 - When cutting, pasting, or moving subtrees and items, the
5096 empty lines *before* the subtree/item now belong to the
5097 part and will be moved with it. There is one exception to
5098 this rule: If the first child is moved down (or,
5099 equivalently, the second is moved up), the amount of empty
5100 lines *above* the first child to be moved along with it is
5101 limited by the number of empty lines *below* it. This
5102 sounds complicated, but it allows to have extra empty space
5103 before the first child and still have good behavior of the
5104 subtree motion commands.
5106 - Plain lists items work the same.
5108 I believe we have finally nailed this one. Thanks to Daniel
5109 Pittman for bring this up again and to Eric Schulte for
5110 pointing out that it is the empty lines *before* an entry
5113 This change was non-trivial, please give it a good test and
5114 let me know about any problems.
5118 - The new command `org-remember-goto-last-stored' will jump
5119 to the location of the remember note stored most recently.
5120 If you have `org-remember' on a key like `C-c r', then you
5121 can go to the location with a double prefix arg: `C-u C-u
5122 C-c r'. This was a proposal by Rainer Stengele.
5124 - Template items that are being prompted for can now specify
5125 a default value and a completion table. Furthermore,
5126 previous inputs at a specific prompt are captured in a
5127 history variable. For example:
5129 : %^{Author|Roald Dahl|Thomas Mann|Larry Niven}
5131 will prompt for an author name. Pressing RET without
5132 typing anything will select "Roald Dahl". Completion will
5133 give you any of the three names. And a history will be
5134 kept, so you can use the arrow keys to get to previous
5135 input. The history is tied to the prompt. By using the
5136 same prompt in different templates, you can build a history
5137 across templates. The ideas for this came from proposals
5138 by Bastien and Adam.
5140 - When a remember template contains the string `%!', the note
5141 will be stored immediately after all template parts have
5142 been filled in, so you don't even have to press `C-c
5143 C-c'. The was a proposal by Adam Spiers.
5147 - `org-refile-targets' has a new parameter to specify a
5148 maximum level for target selection. Thanks to Wanrong Lin
5151 - When the new option `org-refile-use-outline-path' is set,
5152 refile targets will be presented like a file path to the
5153 completion interface: "level 1/level 2/level 3". This
5154 may be the fastest interface yet to get to a certain
5155 outline entry. Do we need to use this interface in other
5156 places? Thanks to Jose Ruiz for this proposal.
5162 *** Restriction lock on agenda scope
5164 You can now permanently lock the agenda construction to a
5165 certain scope, like a file or a subtree. So instead of
5166 pressing "<" for each command in the agenda dispatcher, you
5167 only once select a restriction scope. All subsequent agenda
5168 commands will than respect this restriction. For example,
5169 you can use this at work, to limit agendas to your work file
5170 or tree, and at home to limit to the home file or tree. Or
5171 you can use it during the day in order to focus in on certain
5174 You select a scope with the command `C-c C-x <', which
5175 restricts to the current subtree. When called with a `C-u'
5176 prefix, the restriction is to the current file. You can also
5177 make restrictions from the speedbar frame, see below.
5179 When making a new restriction and an agenda window is
5180 currently visible, it will immediately be updated to reflect
5181 the new scope. If you like you can display an agenda view
5182 and then watch it change in various scopes.
5184 To get rid of the restriction, use the command "C-c C-x >".
5185 Or press ">" in the agenda dispatcher. Also, and use of "<"
5186 in the dispatcher will disable the restriction lock and
5187 select a new restriction.
5189 Thanks to Rick Moynihan for triggering this development.
5191 *** Imenu and Speedbar support
5193 - Org-mode now supports Imenu. For example, with the setting
5195 : (add-hook 'org-mode-hook
5196 : (lambda () 'imenu-add-to-menubar "Imenu"))
5198 a menu will be created in each Org-mode buffer that
5199 provides access to all level 1 and level 2 headings. The
5200 depth of the menu can be set with the variable
5203 - org-mode now supports Speedbar. This means that you can
5204 drill into the first and second level headlines of an
5205 Org-mode file right from the speedbar frame.
5207 - You can set a restriction lock for the Org-mode agenda to a
5208 file or a subtree directly from the speedbar frame. Just
5209 press "<" with the cursor on an Org-mode file or subtree to
5210 set the lock and immediately update the agenda if it is
5211 visible. Use ">" to get rid of the lock again.
5217 - There are new special properties TIMESTAMP and TIMESTAMP_IA.
5218 These can be used to access the first keyword-less active
5219 and inactive timestamp in an entry, respectively.
5221 - New variable `org-clock-heading-function'. It can be set to
5222 a function that creates the string shown in the mode line
5223 when a clock is running. Thanks to Tom Weissmann for this
5232 + Remember and related stuff
5233 - New command `org-refile' to quickly move a note.
5234 - Easy way to jump to the target location of remember template.
5235 - New %-escapes in remember templates: %c %(...) and %[...]
5236 - `org-remember-insinuate' simplifies remember setup
5238 + Emphasis and Font-lock stuff
5239 - Stacked emphasis is no longer allowed.
5240 - You may finally emphasize a single character like ~*a*~.
5241 - Font-lock now can hide the emphasis markers
5242 - Text in the "=" emphasis is exported verbatim
5243 - There is a new emphasis marker "~" for verbatim text
5244 - Constructs treated specially by the exporters can be highlighted
5246 + Properties and Column view
5247 - More control over which properties use inheritance
5248 - CATEGORY="work" can now be used in a tags/property search
5249 - the {+} summary type can specify a printf-style output format
5250 - New currency summary type {$}
5252 + The date/time prompt
5253 - While entering data, watch live the current interpretation.
5254 - The date prompt now prefers to select the future
5255 - Easier modification of time in an existing time stamp.
5258 - You can now export some special strings in HTML, like "..."
5259 - #+EMAIL: may contain several email addresses
5262 - In the agenda, a few keys have changed: `g', `G', and `e'.
5265 - Class-dependent sectioning structures in LaTeX export.
5266 - Radio-lists modeled after the radio tables.
5267 - The default for `org-ellipsis' is back to nil
5268 - Support for pabbrev-mode
5269 - New variable `org-show-entry-below'.
5271 ** Incompatible changes
5273 - If you have customized the variable `org-emphasis-alist' or
5274 org-export-emphasis-alist', you need to do it again by first
5275 canceling your customization and then adding it again.
5277 - I know that some people have defined their own private helper
5278 functions to select a specific remember template, without being
5279 prompted, like this:
5281 : (defun my-remember-template-n ()
5283 : (org-remember ?n))
5285 You need to modify this. The character selecting the template
5286 must now be the /second/ argument to `org-remember':
5288 : (defun my-remember-template-n ()
5290 : (org-remember nil ?n))
5292 - `C-c C-w' now refiles an entry. To get a sparse tree of
5293 deadlines, use `C-c / d' instead.
5297 *** Remember and related stuff
5299 - New command `org-refile' to quickly move a note to a
5300 different place. It is bound to `C-c C-w'. The foremost
5301 application might be to put a note or task captured with
5302 `remember' into the proper list or project. The command
5303 offers a list of possible refiling targets for completion.
5304 These are headings under which the entry will be inserted
5305 as a subitem. By default, this will offer all top-level
5306 headings in the current buffer, but you can configure the
5307 variable `org-refile-targets' to get more complex
5308 definitions. For example:
5310 : (setq org-refile-targets '((nil . (:level . 2))))
5312 selects all level 2 headlines in the current buffer as
5315 : (setq org-refile-targets
5316 : '((org-agenda-files . (:tag . "refile"))))
5318 searches all agenda files and selects headlines that are
5319 explicitly marked with the tag :refile: . Note that the
5320 list of targets is built upon first use only, to rebuilt
5321 it, call the command `C-c C-w' with a double prefix
5324 This is based on an idea and example implementation by Max
5325 Mikhanosha. Many thanks Max.
5327 - You can now use a C-u prefix on `org-remember' to jump to
5328 the location where a specific templates stores its notes.
5329 For example, if you have `org-remember' bound to `C-c r',
5330 then `C-u C-c r n' will get you to the file and headline
5331 given in the template associated with the letter "n".
5333 This was proposed by someone, but I have lost track who.
5334 Sorry, and thanks anyway.
5336 - New %-escapes in remember templates:
5338 : %c insert the current clipboard, like C-y would do
5339 : %(..) evaluate Lisp expression and insert the result
5340 : %[..] include file
5342 Thanks to Adam Spiers and Tim O'Callaghan.
5344 - New function `org-remember-insinuate' that makes is easier
5345 to set Org-mode specific values for remember variables.
5346 Thanks to Michael Olson for this proposal. It is
5349 : (require 'remember)
5350 : (setq remember-annotation-functions '(org-remember-annotation))
5351 : (setq remember-handler-functions '(org-remember-handler))
5352 : (add-hook 'remember-mode-hook 'org-remember-apply-template))
5354 You might still want to set `org-default-notes-file' to
5355 provide a default for templates without a file, and
5356 `org-directory' to show where to find other org files.
5358 *** Emphasis and Font-lock stuff
5360 - Stacked emphasis like ~*/bold italic/*~ is no longer allowed.
5362 - You may finally emphasize a single character like ~*a*~.
5364 - Font-lock now can hide the emphasis markers, just like Muse
5365 does. Configure the variable `org-hide-emphasis-markers'
5366 if you want this. Showing the characters continues to be
5367 the default in Org-mode.
5369 - Text in the "=" emphasis is now exported verbatim, i.e. no
5370 further parsing and interpretation of this text takes place. So
5371 you can write ~=quoted *xxx* a_x = b=~. This and the following
5372 point implement a request by Daniel Clemente.
5374 - There is a new emphasis marker "~" which marks text to be
5375 exported verbatim, without special formatting. Inside an
5376 org-mode file, this text is highlighted with the org-verbatim
5377 face. I am not happy with the face yet (currently is is like
5378 org-code, but underlined), please suggest a better one.
5380 - Whether an emphasis environment is verbatim or not is now an
5381 extra flag in the variable `org-emphasis-alist'. If you have
5382 configured this variable, do it again by first canceling your
5383 customization to revert to the default, and then adding it
5386 - New variable `org-highlight-latex-fragments-and-specials'.
5387 When turned on, Org-mode will highlight all strings that
5388 are treated in a special way by the exporters. This is
5389 great for export-oriented writing, but maybe a bit noisy
5390 for note taking, so this feature is off by default.
5392 *** Properties and Column view
5394 - `org-use-property-inheritance' may now also be a list of
5395 property names that should be treated with inheritance
5398 - CATEGORY="work" can now be used in a tags/property search,
5399 even if the category is not specified as a property in the
5400 entry, but rather is inherited or derived from #+CATEGORY.
5401 Thanks to Adam, Tim, and Bastien for an interesting
5402 discussion around this issue.
5404 - Summary type improvements in column view.
5405 * The {+} summary type can specify a printf-style output
5406 format for computed values like this: {+;%5.2f}
5407 This was triggered by a report by Levin.
5408 * New currency summary type {$}, which so far is just a
5409 shorthand for {+;%.2f}. Do we need to have a currency
5410 symbol in front of each value. Scott Jaderholm asked for
5411 this, but I am not sure if this is already what he meant.
5413 *** The date/time prompt
5415 There have been several small but *very* useful additions to
5418 - While entering data at the date prompt, the current
5419 interpretation of your input is shown next to your input in
5420 the minibuffer. I find this great to understand how the
5421 input works. If you find the extra stuff in the minibuffer
5422 annoying, turn it off with `org-read-date-display-live'.
5424 - The date prompt now prefers to select the future. If you
5425 enter a date without a month, and the day number is before
5426 today (for example, on the 16th of the month you enter
5427 "9"), Org-mode will assume next month. Similarly, if you
5428 enter a month and no year, next year will be assumed if the
5429 entered month is before the current, for example if you
5430 enter "May" in September. Thanks to John Rakestraw for
5431 this great suggestion. If you find it confusing, turn it
5432 off with `org-read-date-prefer-future'.
5434 - When modifying an existing date using `C-c .' at the stamp,
5435 the time or time range in the stamp are now offered as
5436 default input at the prompt. This goes a long way to
5437 simplifying the modification of an existing date. Thanks
5438 to Adam Spiers for this proposal.
5440 *** Export (all implemented by Bastien...)
5442 - You can now export special strings in HTML. Here is the
5443 list of newly performed conversions:
5445 | Org | Description | HTML |
5446 |-----+------------------------------------+----------|
5447 | ~\\-~ | double backslash followed by minus | ­ |
5448 | ~--~ | two dashes (minuses) | – |
5449 | ~---~ | three dashes (minuses) | — |
5450 | ~...~ | three dots | … |
5452 You can turn this globally on or off with
5453 `org-export-with-special-strings' or locally with "-:t" or
5454 "-:nil" in the #+OPTIONS line. Thanks to Adam Spiers for
5455 starting the discussion, and thanks to Daniel Clemente and
5456 William Henney for relevant inputs.
5458 - Comma-separated emails in #+EMAIL: are correctly exported.
5459 Thanks to Raman for pointing out this omission.
5463 - In the agenda, a few keys have changed
5464 : g does now the same a "r", refresh current display,
5465 : because "g" is the Emacs standard for "refresh"
5466 : G toggle the time grid, used to be "g"
5467 : e Execute another agenda command, pretty much the same as
5468 : `C-c a', but shorter and keep the same agenda window.
5470 *** Miscellaneous (much of it from Bastien)
5472 - You can now select the sectioning structure of your LaTeX
5473 export by setting it either globally
5474 (`org-export-latex-default-class') or locally in each Org
5475 file (with #+LaTeX_CLASS: myclass). You can also customize
5476 the list of available classes and their sectioning
5477 structures through the new `org-export-latex-classes'
5478 option. Thanks to Daniel for discussions and suggestion on
5481 - You can send and receive radio lists in HTML,
5482 LaTeX or TeXInfo, just as you send and receive radio
5483 tables. Check the documentation for details and examples.
5485 - The default for `org-ellipsis' is back to nil, some people
5486 seem to have had problems with the face as a default.
5488 - Support for pabbrev-mode, needs pabbrev version 1.1. Thanks
5489 to Phillip Lord for adapting his package to make this
5492 - New variable `org-show-entry-below' to force context-showing
5493 commands to expose the body of a headline that is being
5494 shown. Thanks to Harald Weis for pointing out this omission.
5501 - On the date/time prompt, you can now also answer with
5502 something like +2tue to pick the second tuesday from today.
5503 This was a proposal by Sacha Chua.
5505 - When interpopating into Lisp formulas in the spreadsheet,
5506 the values of constants and properties are no longer
5507 enclosed into parenthesis. When interpolating for calc,
5508 this still happens in order to allow expressions in
5509 constants. This problem was reported by Eddward DeVilla.
5511 - When a directory is listed in `org-agenda-files', all files
5512 with extension matched by the new variable
5513 `org-agenda-file-regexp' in that directory will be agenda
5522 - Bug fixes and improvements in column view
5523 + All known bugs fixed.
5524 + A Column view can be captured into a dynamic block.
5525 + The ITEM column is formatted core compactly.
5526 + Also ITEM can be edited with `e'
5528 - The agenda dispatcher
5529 + `<' cycles through restriction states.
5530 + Multi-character access codes to commands (= sub-keymaps).
5532 - Sorting improvements
5533 + User-defined sorting keys.
5534 + Sorting by properties.
5535 + Sorting of plain lists.
5537 - HTML <div> structure
5540 + New variables, several of them.
5541 + Drawers can be set on a per-file basis.
5542 + Better control over priority fontification in agenda.
5543 + M-up and M-down now move the current line up and down.
5544 + Abort remember template selection with C-g.
5548 *** Bug fixes and improvements in column view
5550 - All the bugs described by Scott Jaderholm have been fixed
5551 (at least I hope so...).
5553 - You can now capture a column view into a dynamic block, for
5554 exporting or printing it. The column view can be
5556 + global, i.e. for the entire file
5557 + local, i.e. for the subtree where the dynamic block is
5558 + from an entry with a specific :ID: property.
5560 You can identify the entry whose column view you want to
5561 capture by assigning an :ID: property, and use that property
5562 in the dynamic block definition. For example:
5566 : :ID: planning-overview
5572 : #+BEGIN: columnview :hlines 1 :id "planning-overview"
5576 Use `C-c C-x r' to insert such a dynamic block, and you will
5577 be prompted for the ID.
5579 - When the current column format displays TODO keyword,
5580 priority or tags, these parts are stripped from the content
5581 of the ITEM column, making for more compact and readable
5582 entries. When any of these "properties" are not listed in
5583 the current column format, they are instead retained in the
5586 - You can now also edit the ITEM column with `e'.
5588 *** The agenda dispatcher
5590 - Instead of pressing `1' to restrict an agenda command to
5591 the current buffer, or `0' to restrict it to the current
5592 subtree or region, you can now also press `<' once or
5593 twice, respectively. This frees up `1' and `0' for user
5594 commands, a request by Bastien. In fact, "<" cycles
5595 through different restriction states. "1" and "0" are
5596 still available for backward compatibility, until you bind
5597 them to custom commands.
5599 - The access code to custom agenda commands can now contain
5600 several characters, effectively allowing to bundle several
5601 similar commands into a sub-keymap. This follows an
5602 excellent proposal by Adam Spiers. For example:
5604 : (setq org-agenda-custom-commands
5605 : '(("h" . "HOME + Name tag searches") ; describe prefix "h"
5606 : ("hl" tags "+HOME+Lisa")
5607 : ("hp" tags "+HOME+Peter")
5608 : ("hk" tags "+HOME+Kim")))
5610 - The user function option in org-agenda-custom-commands may
5611 now also be a lambda expression, following a request by
5614 *** Sorting improvements
5616 We are using a new routine for sorting entries, courtesy of
5617 John Wiegley. Many thanks to John.
5619 - You can define your own function to extract a sorting key
5620 and in this way sort entries by anything you like.
5622 - Entries can now be sorted according to the value of a
5625 - Plain lists can be sorted.
5627 *** HTML <div> structure
5629 There is now a <div>-based structure in exported HTML.
5631 - The table of context is wrapped into a div with a class
5632 "table-of-contents".
5634 - The outline structure is embedded in <div> elements with
5635 classes "outline-1", "outline-2" etc.
5637 - The postamble, containing the author information and the
5638 date is wrapped into a div with class "postamble".
5640 I am not sure if the class names are the best choice, let me
5641 know if there are more "canonical" choices.
5643 Thanks to Mike Newman and Cezar for input, and in particular
5644 to Mike for his clearly formulated specification.
5648 - New variable `org-agenda-window-frame-fractions' to
5649 customize the size limits of the agenda window in the case
5650 that you display the agenda window by reorganizing the
5653 - Drawers can be set on a per-file basis using
5655 : #+DRAWERS: HIDDEN STATE PROPERTIES
5657 This will define the drawers :HIDDEN: and :STATE:.
5658 The :PROPERTY: drawer should always be part of this list, or
5659 your properties will not be folded away.
5660 Thanks to Richard G. Riley for this proposal.
5662 - `org-agenda-fontify-priorities' may now also be an
5663 association list of priorities and faces, to specify the
5664 faces of priorities in the agenda individually.
5666 - The variable `org-export-with-property-drawer' no longer
5667 exists, please use `org-export-with-drawers' instead. Also,
5668 the corresponding switch in the #+OPTIONS line has changed
5669 from "p" to "d". Thanks to Bastien for pointing out that we
5670 needed to handle not only the property drawer.
5672 - M-up and M-down now move the current line up and down (if
5673 not at a headline, item or table). Among other things you
5674 can use this to re-order properties in the drawer. This was
5675 a proposal by Bastien.
5677 - New variable `org-agenda-todo-ignore-with-date', based on a
5678 request by Wanrong Lin.
5680 - Aborting remember template selection with C-g now kills the
5681 remember buffer and restores the old window configuration.
5682 This was a request by Nuutti Kotivuori.
5688 - Remember templates can now have name.
5689 - `C-c C-k' will abort taking a note (remember of log)
5690 - `C-c C-x C-w' and `C-c C-x M-w' now accept a prefix arg.
5691 - Lines in the agenda can be fontified according to priority.
5692 - New variable `org-scheduled-past-days'.
5693 - New variables `org-agenda-deadline-leaders' and
5694 `org-agenda-scheduled-leaders'.
5695 - New sparse tree function `org-sparse-tree'.
5696 - The variable `org-ellipsis' now defaults to `org-link'.
5697 - The #+OPTIONS line has a new option "tags".
5698 - New variable `org-use-property-inheritance'.
5700 ** Incompatible Changes
5702 - `C-c /' now calls `org-sparse-tree'.
5706 - Remember templates can now have a template name as the first
5707 element. The name will be listed along with the selection
5708 character when prompting for a template. It is best to have
5709 the name start with the selection character, for example if
5710 you use ("Note" "n"), you will be prompted like "[n]ote".
5711 Thanks to Matiyam for this proposal.
5713 - `C-c C-k' will abort taking a note. You can use this in remember
5714 buffers and when taking a logging note (e.g. for a state
5715 change). Thanks to Bastien.
5717 - `C-c C-x C-w' and `C-c C-x M-w' now accept a prefix arg to
5718 cut N sequential subtrees. This was a proposal by John.
5720 - Lines in the agenda are now bold if they have priority A and
5721 italic if they have priority C. You can turn this off using
5722 the variable `org-agenda-fontify-priorities'. Thanks to
5723 John Wiegley for the idea and code.
5725 - New variable `org-scheduled-past-days' to set the number a
5726 scheduled item will be listed after its date has passed.
5727 Default is 10000, i.e. indefinitely.
5729 - New variables `org-agenda-deadline-leaders' and
5730 `org-agenda-scheduled-leaders' to adjust the leading text o
5731 scheduled items and deadline in the agenda. Thanks to John
5732 Wiegley for a patch.
5734 - New sparse tree function `org-sparse-tree'. This is now the
5735 default binding for `C-c /'. It requires one additional
5736 keypress to select a command, but in return is provides a
5737 single interface to all the different sparse tree commands,
5738 with full completion support.
5740 - The variable `org-ellipsis' now defaults to the face
5741 `org-link' because the visibility of the dots is really bad
5742 and I have found this change very useful indeed.
5744 - The #+OPTIONS line has a new option "tags" which can be used
5745 to set `org-export-with-tags'. Thanks to Wanrong Lin for
5748 - New variable `org-use-property-inheritance'. Configure it
5749 to `t' if you want that searching for entries with certain
5750 properties always should assume inheritance. This is not
5751 well tested yet, please check it out.
5759 - SUMMARY, DESCRIPTION, LOCATION properties for iCalendar
5760 - Command to jump to the running clock
5761 - Clock entries can now have their own drawer
5762 - `C-c C-x C-r' only updates a clocktable at point
5763 - New way to assign a remember template to a single key
5764 - `C-n' and `C-p' are back to their default binding
5765 - `C-x C-s' in agenda buffer saves all org-mode buffers
5766 - Schedule/deadline leaves note in agenda buffer
5767 - Prefix argument for `C-c C-d/s' will remove date
5768 - New variable to make block aranda more compact
5769 - Better tag alignment in agenda
5771 ** Incompatible changes
5773 - If you have customized `org-drawers', you need to add
5774 "CLOCK" to the list of drawers.
5776 - The variable `org-agenda-align-tags-to-column' has been
5777 renamed to `org-agenda-tags-column'. The old name is still
5778 an alias, in Emacs 22 and in XEmacs, but not in Emacs 21.
5780 - The default value for both `org-tags-column' and
5781 `org-agenda-tags-column' is now -80.
5784 `org-insert-labeled-timestamps-before-properties-drawer'
5789 - The LOGGING property allows to modify the settings for
5790 progress logging for a single entry. For example:
5793 : :LOGGING: nologging nologrepeat
5796 turns off all progress logging for the current entry and its
5799 - The properties SUMMARY, DESCRIPTION and LOCATION have
5800 special meaning during iCalendar export, when they translate
5801 to the corresponding VEVENT and VTODO fields. If not given,
5802 Org-ode continues to use cleaned-up version of the headline
5803 and body as the summary and the description, respectively.
5805 - New function to go to the entry with the currently running
5806 clock. Bound to `C-c C-x C-j', in agenda also to "J". If
5807 you use this often, you might even want to assign a global
5808 key. Thanks to Bernt and Bastien.
5810 - Clock entries can now have their own drawer, the :CLOCK:
5811 drawer. Check out the variable `org-clock-into-drawer' for
5812 configuration of this feature. The default is to create a
5813 drawer when the second clocking line gets added to an entry.
5814 Note that "CLOCK" has been added to the default value of
5815 `org-drawers', but if you have configured that variable, you
5816 must go back and add "CLOCK" yourself to get this drawer
5817 folded away. Thanks to Tom Weissman for pointing out that
5818 too many clock entries are visually annoying.
5820 - `C-c C-x C-r' no longer tries to find the first clocktable
5821 in a buffer and then updates it. Instead, it will update
5822 the clocktable at point if there is one (same as C-c C-c
5823 will do if the cursor is in the "#+BEGIN" line of the
5824 table). If there is none at point, a new one will be
5825 inserted. This change was necessary because the new :scope
5826 parameter allows to have several clocktables in a buffer.
5827 Thanks to Bastien for pointing this out.
5828 To update all dynamic blocks in a file, use `C-u C-c C-x C-u'.
5830 - The function `org-remember' can now be called with a
5831 template selection key as argument. This helps to make key
5832 bindings that go directly to a specific template without
5833 being prompted for a template, like this:
5835 : (global-set-key [f5] (lambda () (interactive) (org-remember "j")))
5837 Thanks to Richard G Riley for bringing this up.
5839 - `C-n' and `C-p' are back to their default binding
5840 (next/previous line) in the agenda buffer. Enough people,
5841 including recently Denis Bueno, have complained about this,
5842 and I agree it is not good to break habits like that.
5844 - `C-x C-s' in an agenda buffer now saves all org-mode buffers
5845 (also `s' does this).
5847 - Setting schedule or deadline dates from the agenda now
5848 produces a note in the agenda, similarly to what happens
5851 - Using a prefix argument for `C-c C-d' or `C-c C-s' will
5852 remove the deadline or scheduling date from an item. Thanks
5853 to Wanrong Lin for this proposal.
5855 - New variable `org-agenda-compact-blocks'. When set, the
5856 space between blocks in a block agenda is reduced as much as
5857 possible, to show more items on a single screen.
5859 - The variable `org-agenda-tags-column' (renamed from
5860 `org-agenda-align-tags-to-column') can now also be negative,
5861 to mean alignment to the left. The new default is -80, just
5862 like it is now for `org-tags-column'.
5870 - Category and the archive location can be properties.
5871 - The clocktable has a new =:scope= parameter.
5872 - CSV support when importing a table.
5873 - Better defaults when modifying a time stamp.
5874 - New way to specify the duration of an appointment.
5875 - More aggressive version of orgstruct-mode improved wrapping.
5876 - Modifications to priority cycling.
5877 - Modifications to computations in column view.
5878 - New command `org-occur-in-agenda-files'.
5883 - Both the category and the archive location in a (sub)tree of
5884 the buffer can now be specified using a property, for
5887 : * Tree with special properties
5889 : :CATEGORY: Examples
5890 : :ARCHIVE: /some/special/file::
5893 This is a much cleaner way of dealing with multiple
5894 categories and archives in a single file. The preferred use
5895 of the =#+CATEGORY= and =#+ARCHIVE= lines is now to set a
5896 *single* default for the file which is then locally
5897 overruled by properties. This was a proposal from Bastien
5898 if I remember correctly. Multiple =#+= lines still work
5899 and I don't plan to remove this support soon, but I
5900 encourage you to stop using them.
5902 - The clocktable has a new =:scope= parameter that determines
5903 the range in the file from which clock entries should be
5904 taken. This can be anything from the local subtree to the
5905 entire buffer to even the full list of agenda files. Legal
5909 |---------+-------------------------------------------------|
5910 | nil | the current buffer or narrowed region |
5911 | file | the full current buffer |
5912 | subtree | the subtree where the clocktable is located |
5913 | treeN | the surrounding level N tree, for example tree3 |
5914 | tree | the surrounding level 1 tree |
5915 | agenda | all agenda files |
5917 Thanks to Jason F. McBrayer and Bernt Hansen for
5918 inspiration. Thanks to cranreuch (what is you full name?)
5919 for mentioning, at the right moment, that the clocktable is
5920 not so bad - that remark made it seem worthwhile to add
5923 - The commands to import a table and to convert a region to a
5924 table can now handle comma-separated values (CSV). The
5925 algorithm does not yet treat quoting correctly, but for
5926 basic input it works.
5928 - When modifying an existing time stamp, or when entering the
5929 second stamp of a range, the date prompt will now
5930 consistently default to the date/time in the existing stamp.
5931 This was triggered by Nuutti Kotivuori's request.
5933 - At the date/time prompt, there is a new way to specify a
5934 range of hours, by using "+DURATION" after the time. For
5937 : 14:00+2 means 14:00-16:00
5938 : 2pm+2:30 means 14:00-16:30
5940 Again, Nuutti Kotivuori's request.
5942 - When you use the function `turn-on-orgstruct++' to turn on
5943 orgstruct-mode, the special org-mode settings for
5944 auto-filling, indentation and paragraphs are exported into
5945 the buffer, so that typing list items with indentation works
5946 better. This was Bastien's idea and request.
5948 - New variable `org-priority-start-cycle-with-default'. When
5949 t (the default), priority cycling will initially set the
5950 default priority and then increase or decrease. When nil,
5951 the first priority set by cycling is already 1 different
5952 from the default priority. This was mostly driven by
5955 - In column view: When an entry has a property for a summary
5956 column defined, its value is normally overwritten by the sum
5957 of all the children's values each time you enter column
5958 view. Now there is an exception to this rule: If none of
5959 the children has that particular property defined, the
5960 parent's value stays. In this way you can still place TODO
5961 items under such an entry without getting the property value
5962 changed. Thanks to Russel Adams for pointing out that this
5963 is a better way of doing things.
5965 - In column view, computed values are now bold face, and
5966 trying to edit them is an error. I think this works, but
5967 testing is appreciated.
5969 - New command `org-occur-in-agenda-files', this is basically
5970 the quick command John Wiegley proposed the other day, but
5971 it also works when the agenda files are not yet in buffers.
5972 The key is `C-c C-x /', any better proposals?
5974 - Links containing a space will now be handled correctly when
5975 calling the browser. Note that you need to enclose such
5976 links in square or angular brackets.
5984 - Taking a note upon TODO state changes can be restricted to
5987 - The format in which dates are shown in the daily/weekly
5988 agenda can be configured.
5990 - The default for `org-remember-store-without-prompt' is now t.
5992 - `org-goto' has been made into a general lookup command.
5994 - Priority cycling goes back to the nil state.
5996 - You can store a remember note to the *last used* location.
5998 - On Emacs 23, the headline faces for org-mode are now
5999 inherited from the outline faces.
6001 ** Incompatible Changes
6003 - The default for `org-remember-store-without-prompt' is now
6004 t, in order to better match the original intent of
6005 remember.el (storing a note with minimum interruption of
6006 work flow). I expect that many people will be hit by this
6007 incompatible change - nevertheless I believe it is the right
6012 - You can now select specific states for recording a note when
6013 switching to that state. With the setting
6015 : #+SEQ_TODO: TODO(t) ORDERED(o@) INVOICE(i@) PAYED(p) | RECEIVED(r)
6016 : #+STARTUP: lognotestate
6018 only the states ORDERED and INVOICE will record a timestamp
6021 - You can now set the format of the string for each day in the
6022 agenda and timeline buffers. You can use a format string
6023 interpreted by `format-time-string', or you can write your
6024 own function. Configure the new variable
6025 `org-agenda-format-date'. Thanks to Levin for triggering
6026 this development with a patch.
6028 - The default for `org-remember-store-without-prompt' is now
6029 t, in order to better match the original intent of
6030 remember.el (storing a note with minimum interruption of
6031 work flow). Since we can assign files and headlines to
6032 templates, I guess this takes care of selecting a filing
6033 location in most cases. For interactive filing, you now
6034 need a prefix command when exiting `remember'.
6036 - `org-goto' (bound to `C-c C-j') now uses an indirect buffer
6037 and has additional commands enabled: Org-occur with `C-c /'
6038 or even faster with `/', and the commands needed to select
6039 and copy a region. This make `org-goto' a more general
6040 lookup command instead of only a jumping command. Remember
6041 that you can exit with `Q' to go back to the original
6042 location. Thanks to William Henney for this idea.
6044 - Setting the priority with S-up/down now cycles back to a
6045 state where no priority is specified. This was requested by
6048 - You can store a remember note to the *last used* location.
6049 So if you select a location interactively once, you can
6050 re-use it without having to find it again. For this, exit
6051 the remember buffer with `C-u C-u C-c C-c'. The leading
6052 comment in the remember buffer will tell exactly where the
6053 note goes if you exit with a particular command.
6054 Thanks to Maxim Loginov for this idea.
6056 - On Emacs 23, the headline faces for org-mode are now
6057 inherited from the outline faces. This is just a
6058 convenience, so that you only have to configure one set of
6059 faces, and that will then be outline-1 .. outline-8. You
6060 will actually not see any difference in org-mode, because
6061 Stefan Monnier has made the outline faces in Emacs 23 to
6062 match the current org-mode faces.
6064 This change does not effect XEmacs, nor Emacs 21 and 22.
6068 ** Incompatible changes
6070 - The default for `org-deadline-warning-days' is now 14.
6074 - There is now a separate interface for fast and directly
6075 setting a TODO keyword. This interface kicks in when you
6076 have configured keys for TODO keywords like
6078 : #+SEQ_TODO: TODO(t) WAITING(w) | DONE(d) CANCELED(c)
6080 C-c C-t still does the cycling thing, you need to use a
6081 prefix argument to get to the fast interface. Or configure
6082 the variable `org-use-fast-todo-selection' to t, then this
6083 will be the default and the prefix argument will make the
6084 command fall back to cycling.
6086 The tag selection no longer does include TODO keywords -
6087 Leo's arguments have convinced me that this is not a good
6088 idea. If you'd like to see the TODO keywords in the tags
6089 interface anyway, set the variable
6090 `org-fast-tag-selection-include-todo'. Thanks to Leo and
6091 others for input on this issue.
6093 - New variable `org-edit-timestamp-down-means-later'. When
6094 set, `S-down' on a timestamp will change the timestamp to
6095 later. Thanks to Raman for this idea.
6097 - Property names can now contain non-ascii word characters.
6098 This follows a request from Daniel Clemente.
6100 - For export, the date that should be given in the exported
6101 file can now be set to a specific value with a line like
6103 : #+DATE: 15 November 2003
6105 If you want to use the date/time when the file was created,
6106 use a format string that will be interpreted by
6107 `format-time-string', for example:
6109 : #+DATE: %Y/%m/%d %X
6111 - The default of `org-deadline-warning-days' has changed to 14
6112 days. 30 was really too much, I suspect most people (me
6113 included) have changed this.
6115 - When a deadline has an individual lead time, this lead time
6116 obviously overrules `org-deadline-warning-days'. However,
6117 if you bind `org-deadline-warning-days' to a number <=0, for
6118 example during a custom agenda command, then the absolute
6119 value of this number will be enforced also when a different
6120 lead time has been specified. This is useful to get a list
6121 of all deadlines coming up in the next N days.
6127 - Different faces for different TODO keywords.
6129 - Setting TODO states through the TAG setting interface.
6131 - Context information is stored when moving a tree to the archive.
6133 - Sorting can be done by priority.
6135 - `Org-ellipsis' can now also be a face.
6137 - Scheduling info is no longer removed entry is marked CLOSED.
6139 - Unavailable files in `org-agenda-files' can be skipped.
6141 ** Incompatible changes
6143 - The time of archiving is now stored as a property.
6144 ARCHIVED is no longer a special time keyword.
6146 - Scheduling info is no longer removed entry is marked CLOSED.
6150 - You can now define different faces for different TODO
6151 keywords. This request has come up frequently, so here it
6152 is: Use the variable `org-todo-keyword-faces'.
6154 A Here is a configuration example:
6156 : (setq org-todo-keyword-faces
6157 : '(("TODO" . org-warning)
6158 : ("DEFERRED" . shadow)
6159 : ("CANCELED" . (:foreground "blue" :weight bold
6162 Org-mode continue still use `org-todo' and `org-done' for
6163 keywords that have no specific face assigned.
6165 - Some People use TODO states more like tags. For them the
6166 TODO keywords mark special states and they like to quickly
6167 switch between states in arbitrary sequence. The standard
6168 TODO interface is not perfect for this, because it assumes
6169 that the states are reached in sequence. However, the fast
6170 tag setting interface is in fact perfect for this. You can
6171 now "misuse" the TAG selection interface to also set TODO
6172 states. All you need to do is to assign keys to the TODO
6173 states, just like you also do for tags.
6175 : #+SEQ_TODO: TODO(t) WAITING(w) | CANCELED(c) DONE(d)
6176 : #+TAGS: @HOME(h) @OFFICE(o) @SHOP(s)
6178 Next time you try to set tags with C-c C-c, the todo states
6179 will be offered as well, and the corresponding key will
6180 switch the entry to that state.
6182 - New variable `org-archive-save-context-info' governs if
6183 information that would be lost by moving a subtree to the
6184 archive file, should be stored as special properties. For
6187 : (setq org-archive-save-context-info '(itags category))
6189 will store the inherited tags and the category in properties
6190 ARCHIVE_ITAGS and ARCHIVE_CATEGORY, respectively. The
6191 default setting for this variable is to save everything that
6192 could be lost. This was a proposal by John Wiegley.
6194 - Sorting (`C-c ^') can use the use the priority to sort. Use
6195 the "p" and "P" keys at the prompt. John Wiegley, again.
6197 - `Org-ellipsis' can now also be a face to make the folding
6198 ellipsis more visible. This is based on a post by Tassilo
6199 Horn. Since `org-ellipsis' only works in Org-mode, you
6200 might want to use Tassilo Horn's hack directly in order to
6201 affect the folding ellipsis globally.
6203 - Scheduling info is no longer removed when an entry is marked
6204 CLOSED. This was a request by Brian van den Broek. Let me
6205 know if this breaks anything for you - then it will become
6208 - New option `org-agenda-skip-unavailable-files'. Currently,
6209 if a file does not exist, it will be removed from
6210 `org-agenda-files' after a query. When this option is set,
6211 the file will simply be skipped.
6221 - When exporting only a region and this region is a single
6222 (sub)tree (for example selected with `C-c @'), the title for
6223 the exported document is taken to be the heading of the
6224 subtree. The sublevels become top-level entries in the
6225 export. Furthermore, if the head entry of the tree has or
6226 inherits an EXPORT_FILE_NAME property, that file name (with
6227 appropriately substituted extension) will be used for the
6228 exported tree. Thanks to Patrick Drechsler and Jost Burkart
6231 - org-special-ctrl-a/e has a third allowed value, `reversed'.
6232 When it is set to this value, the first C-a or C-e command
6233 behaves normally, i.e. it goes to the true beginning or end
6234 of the line. Only when you press C-a or C-e immediately
6235 again, the the "special" position will be found. Additional
6236 presses of the same key jump between the two positions. I
6237 like this a lot better than the `t' setting, because now the
6238 keys behave more predictable and still give easy access to
6239 the special locations.
6241 - New command to set or remove a tag from all headlines in a
6244 - When Org-mode visits a file, it will initially hide all
6247 - The default of the variable `org-cycle-global-at-bob' is now
6248 nil, meaning that TAB no longer does global visibility
6249 cycling at the beginning of the buffer.
6251 - Bug fixes, in particular the problems with scheduling and
6252 deadlines introduced in 5.05. Please check carefully if
6253 this works correctly again, and complain if not.
6259 - LaTeX export, finally, thanks to Bastien.
6261 - Extension mechanism for the hyperlink system.
6263 - Global access to commands inserting and following links.
6265 - Individual lead-times for deadlines.
6267 - Option to show only the next instance of repeating timestamp.
6269 - Store remember notes with only 2 keys: C-c C-c
6271 - Appointment reminders from Org-mode.
6273 - Global values for selected properties.
6280 - Bastien's `org-export-latex.el' is now part of the org-mode
6281 distribution. You can export an Org-mode document to a
6282 LaTeX file with `C-c C-e l'. For more options, see the
6283 manual, and the commentary in the Lisp file. Kudos to
6284 Bastien for contributing this frequently requested feature.
6285 I am sure this has been tough because of the many different
6286 ways I have been allowing LaTeX snippets and environments to
6287 be incorporated in lazy free-format ways.
6289 - Org-mode has now an extension mechanism for the hyperlink
6290 system. This should clear the road for all those mairix and
6291 other ideas that have been floating around. Now it is on
6292 *you* to write and share new link types for Org-mode. The
6293 interface for adding a new link type is described in the
6294 appendix of the manual, section A2. The unsolved problem is
6295 currently how to handle the new link types for
6298 - New *global* commands `org-open-at-point-global' and
6299 `org-insert-link-global'. You can bind these commands to
6300 global keys and use them to insert and follow Org-mode-like
6301 links anywhere in Emacs. Thanks to Adam Spiers for this
6304 - Each deadline timestamp may now specify its own interval of
6305 lead-time display, given in days, weeks, months or years.
6306 The syntax is like this
6308 : DEADLINE: <2007-08-13 Mon -5d>
6310 When combined with a repeater, the repeater has to come
6313 : DEADLINE: <2007-08-13 Mon +2w -5d>
6315 You may now also customize the faces that are used in the
6316 agenda to indicate the distance of an approaching deadline.
6317 See the new option `org-agenda-deadline-faces'.
6319 Thanks to Pavel Chalmoviansky and John Wiegley proposals in
6322 - New option `org-agenda-repeating-timestamp-show-all'. When
6323 set to nil, repeating time stamps will only show up once in
6324 the agenda, either today or in the near future. Other
6325 matches will be ignored. Thanks to John Wiegley for this
6328 - New variable `org-remember-store-without-prompt'. When set,
6329 exiting the remember buffer with C-c C-c will store the note
6330 without further prompts to the default location, and `C-u
6331 C-c C-c' will get the prompts for file and location. So
6332 this variable reverses the prefix-argument functionality for
6333 storing remember notes. This follows a request from John
6336 - A new function `org-agenda-to-appt' activates all
6337 appointments for the current day so that Emacs will display
6338 reminders. This uses appt.el. Thanks to Bastien for this
6341 - You can now set default values for properties that can be
6342 inherited by all entries in a buffer, or by all entries
6343 globally. Global properties are set in the variable
6344 `org-global-properties', like this:
6346 (setq org-global-properties '(("NAME" "This is the value")))
6348 Buffer-local values are set like this:
6350 #+PROPERTY: NAME This is the value
6352 When using org-entry-get to get the value of a property with
6353 the `inherit' flag and the hierarchy above the entry does
6354 not contain this property, the buffer-local and global lists
6355 are checked as well. This is mostly useful (I think) to set
6356 the list of allowed values for a property. Thanks to Bernt
6357 Hansen and Bastien for these ideas.
6365 - New variables `org-export-author-info' and
6366 `org-export-time-stamp-file' to turn off inclusion of author
6367 and time information into exported files. Thank to Patrick
6368 Drechsler for pointing out that this would be useful.
6370 - New variable to avoid moving DEADLINE and SCHEDULED info
6371 into the property drawer. The default is now to not move
6372 this stuff into the drawer.
6373 `org-insert-labeled-timestamps-before-properties-drawer'
6375 - `org-archive-mark-done' can be a string now, to select a
6376 specific keyword that should be used for archived entries.
6378 - New command "j" in agenda to jump to an arbitrary date.
6379 Thanks to Bernt Hansen for the patch.
6381 - Lots of minor fixes.
6385 ** Incompatible Changes
6387 - The variable `org-special-ctrl-a' has been renamed to
6388 `org-special-ctrl-a/e'. The old one is still an alias (but
6389 not on Emacs 21 where variable aliases cannot be defined).
6393 - When the variable `org-special-ctrl-a/e' is set, C-e in a
6394 headline first goes to the end of the headline ignoring the
6395 tags. A second C-e then goes to after the tags.
6397 - Typing and removing single characters in a headline now
6398 keeps the tags in the headline aligned. This could have a
6399 little impact on performance while deleting stuff - let me
6400 know if we need to make this customizable.
6402 - New option `org-n-level-faces' can be used to set the number
6403 of different faces that are used for headlines. Default is
6404 all 8 faces Org-mode defines for this purpose, level 9 uses
6405 again the level-1 face. However, you can use fewer, and then
6406 the level-1 face will be reused already for level N+1, etc.
6408 - Column View and hidestars now work together.
6417 - The interfaces for properties and column view are finished
6420 - Properties can be summaries, i.e. the parent nodes can
6421 compute their value from the children's values.
6423 - Headlines finally require a space ofter the star(s). The
6424 conflict with bold text at the beginning of the line is no
6427 ** Incompatible Changes
6429 - Bad news. It looks like it is going to be really hard to
6430 make column view work on XEmacs and on Emacs 21. Emacs 22
6431 is currently the only Emacs where this works. If you are
6432 using Emacs 21 or XEmacs, you can still use properties, but
6437 - Improvements for properties:
6439 + There are interactive commands to insert and delete
6440 properties. Read the manual chapter 7 for details.
6442 + You can define /allowed values/ for a property. When
6443 these are defined, you can change the value of a property
6444 with S-left and S-right. And you may use completion when
6445 inserting the property. This goes a long way to prevent
6446 typos when entering properties.
6448 - Improvements for column view.
6450 + In column view, you may use the keys S-left/right (and
6451 also the keys `n' and `p') to switch from one allowed
6454 + You can define summaries for columns. For example,
6455 parents can contain the sum of all children values of a
6456 property, or the parent node can have a check box property
6457 that is automatically checked when all children's boxes are
6460 + There are interactive commands to add and remove columns,
6461 and to change the attributes of a column like the summary
6464 These additions lead to the exciting fact that the example
6465 from [[http://www.omnigroup.com/images/applications/omnioutliner/features/multicolumn.jpg][omni outliner]] posted by Scott Jaderholm can now be
6466 accurately [[file:omni-org.jpg][reproduced by Org-mode]].
6468 - The space after the stars is now required in a headline, in
6469 order to remove the conflict with bold words at the
6470 beginning of a line. So
6472 : * This is a level 1 headline
6473 : *this is bold text*
6475 - S-up and S-down to navigate plain item lists are now also
6476 available in orgstruct-mode.
6482 - A new minor mode, orgstruct-mode, exports the Org-mode
6483 structure editing commands into any other mode.
6485 - DRAWERS are a new level off folding for special sections
6486 that should stay closed during visibility cycling and only
6487 open if explicitly asked.
6489 - Entries can now have PROPERTIES.
6491 - A COLUMN VIEW implementation allows to easily view and edit
6492 the properties of a hierarchy of entries (Emacs only, for
6495 - Formula evaluation in the spreadsheet is more consistent
6496 now. Properties and per-file constants can be used during
6499 - Bug fixes and minor changes.
6501 ** Incompatible changes
6503 - When using LEVEL=N in a tags search, things have changed if
6504 you are also using `org-odd-levels-only'. If you are using
6505 only odd levels (i.e. 1 or 3 or 5... stars), LEVEL=2 will
6506 now refer to 3 stars, LEVEL=3 to 5 stars etc. Many thanks
6507 to Leo (or blame on him if you must) who has convinced me
6508 that this is the better convention.
6512 *** Orgstruct minor mode
6514 There is a new minor mode, orgstruct-mode. This modes works
6515 in a similar way as Orgtbl-mode. It can be used to export
6516 the Org-mode structure-editing commands into arbitrary major
6517 modes in Emacs. For example, you can use it in Mail-mode to
6518 easily create lists.
6520 The functionality in Orgstruct mode is only active, if the
6521 cursor is in a line that looks either like a headline, or
6522 like the first line of a plain list item. Then the commands
6523 `TAB', `M-cursor', `M-S-cursor', `M-RET', `M-S-RET', `C-c ^',
6524 `C-c C-c', and `C-c -' will do structure-related editing just
6525 like in Org-mode. If the cursor is not in such a line, all
6526 these keys will do whatever the major mode or other active
6527 minor modes have assigned to them.
6529 Orgstruct-mode is the result of a proposal by Raman, quite
6530 some time ago. It has taken a long time, but here is finally
6531 the promised implementation.
6535 The new concept of /drawers/ allows to create sections
6536 that remain folded during visibility cycling. Drawers need
6537 to be configured using the variable `org-drawers'. A drawer
6538 starts with a line containing only the name of the drawer
6539 bracketed by colons. It ends with :END:. For example,
6542 : (setq org-drawers '("PROPERTIES" "HIDDEN"))
6544 you can then create drawers like this:
6547 : here is some stuff that remains hidden
6548 : unless TAB is pressed directly in that line
6551 The PROPERTIES drawer has special meaning for ORG-mode, it
6552 contains properties of an entry (see below).
6554 *** Properties and Column View
6556 - Entries in Org-mode can now have arbitrary /properties/
6557 associated with them. Org-mode handles some default
6558 properties like the TODO state, the priority, the local
6559 tags, and planning information like DEADLINE and SCHEDULED.
6560 In addition, you can assign arbitrary properties by creating
6561 a property drawer and inserting a line like
6563 : :PROPNAME: This is the value of the property
6565 Org-mode has an API for properties, if you want to write a
6566 program using properties, use the functions
6567 `org-entry-properties', `org-entry-get', `org-entry-put',
6568 and `org-entry-delete'.
6570 - Planning information like DEADLINE can be hidden in the
6573 If the PROPERTIES drawer starts in the first line after a
6574 headline, also the DEADLINE, SCHEDULED and CLOCK information
6575 will be inserted inside the drawer. If no PROPERTIES drawer
6576 is present, or if it does not start in the line right after
6577 the headline, this information remains in the lines directly
6578 after the headline, outside the drawer.
6580 - TAGS searches can now also query properties. For example,
6583 : LEVEL=3+BOSS+ASSIGNED="Hans"/WAITING
6585 will find entries that
6588 - have an ASSIGNED property with the value "Hans"
6589 - are TODO status WAITING.
6591 So here is an entry that will match:
6593 : *** WAITING Clean up the factory :BOSS:
6598 You may also use a regular expression to match against a
6599 property value. For example, to find stuff assigned to Hans
6602 : ASSIGNED={^\(Hans\|Sarah\)$}
6604 - Column View is a special way to look at property values in
6605 tabular form. Column View can be used in any org-mode
6606 file, and also in any agenda buffer. It works by placing
6607 an overlay over each headline (or agenda line) that shows a
6608 table of selected properties. You can look at and edit
6609 properties from this view. Which properties are shown in
6610 the table must be set up using the COLUMNS property. You
6611 can set up different property columns on different levels
6612 of an outline tree. For example:
6616 : :COLUMNS: %25ITEM %Name
6620 : :COLUMNS: %25ITEM %Name %3Age
6623 : Info about Sam, including a property list with Name and Age.
6625 : Info about Sarah, including a property list with Name and Age.
6628 : :COLUMNS: %25ITEM %Name %Function %Salary
6631 : Info about the Boss, including a property list with Name,
6632 : Function and Salary (if only we knew....).
6634 Now we have defined three different sets of columns. If
6635 you switch to column view in the /Family/ section, you
6636 will get a different table than if you do it in the
6637 /Office/ section. However, if you switch to column
6638 view with the cursor on the /People/ section, the
6639 table will cover all entries, but contain only the
6642 Column view does, for the time being, only work on Emacs.
6643 The XEmacs implementation needs a bit of work.
6645 - Properties can be used in table formulas. To access the
6646 value of the property :XYZ:, use $PROP_XYZ. The property
6647 needs to be defined in the hierarchy above the table, not
6648 necessarily in the same entry as the table. This was a
6649 request by Eddward. File-wide constants can be defined with
6650 #+CONSTANTS, see below.
6652 - Things that still need to be sorted out about drawers,
6653 properties and column view - comments and suggestions
6656 + How to deal with drawers and properties in HTML and ASCII
6658 + What key could be used to insert an empty property drawer
6660 + Right now column view is invoked through the command C-c
6661 C-x C-c. It is too easy to type C-x C-c by mistake, and
6662 that causes Emacs to quit. Suggestions for a different
6664 + Fontification of drawers and properties is not good yet.
6665 Any suggestions for better defaults?
6666 + Mouse support for editing properties in column view would
6667 be nice - maybe Piotr is interested to add this to
6672 - In the spreadsheet, the evaluation of formulas has changed.
6673 Previously, first the column formulas would be evaluated
6674 everywhere, and then the field formulas would kick in, and
6675 in some cases overwrite the results of column formulas in
6676 the appropriate fields. This had the side effect that some
6677 formulas might always use the wrong, intermediate content of
6678 a field that is computed both by a column and a field
6681 From now on, column formulas will no longer temporarily
6682 overwrite field formulas. This gives much more consistent
6683 results. For example you can now finally have a column of
6684 increasing numbers by setting the first field to a fixed
6685 number, and let the rest follow from a column formula.
6692 : #+TBLFM: $1=@-1+1::@1$1=1
6694 - Constants for formulas in spreadsheets are globally defined
6695 with the variable `org-table-formula-constants'. File-local
6696 constants can now be set with a line like:
6698 : #+CONSTANTS: c=299792458. pi=3.14 eps=2.4e-6
6702 - When entries are archived, a timestamp for the moment of
6703 archiving is added to the line with planning information.
6706 : ARCHIVED: [2007-07-02 Mon 11:34]
6708 Thanks to J. David Boyd for constructive comments.
6712 Many bugs are fixed, as usually all the ones where I replied
6713 "fixed" on emacs-orgmode. If you reported one of these
6714 bugs, please check if it really has disappeared in the new
6715 version, and complain if not. Thanks!
6722 - We are back to a single file org.el that works both on Emacs
6723 and on XEmacs. Merging comes at a speed penalty for you as
6724 an XEmacs user, but *only if you do not compile* org.el.
6725 Compilation completely removes the penalty.
6727 - New L flag for literal interpolation in Lisp formulas.
6728 See manual section 3.5.3.
6730 - New options for turning off footnotes.
6731 This was a request from Ignotus.
6732 See the option `org-export-with-footnotes'.
6734 - Default length for Agenda entries, but this is off by
6735 default. This was a request from Micheal.
6736 See the option `org-agenda-default-appointment-duration'.
6740 + org-agenda-date-later (Juraj Kubelka)
6741 + letters off margin in orgcard.ps (Charles Cave)
6742 + TODO export problems on XEmacs (ignotus@freemail.hu)
6743 + args-out-of-range with table formulas (Cecil Westerhof)
6744 + problem with org-file without a heading (Tim O'Callaghan)
6750 - Time stamps with a time range *included*, like
6751 : <2007-06-18 Mon 17:33-18:23>
6753 - Clock times without clocking in/out: CLOCK: => 2:00
6755 - Language-specific characters allowed in TAGS (Emacs only).
6757 - Promotion and demotion of items gets the indentation right.
6759 - Indenting lines with TAB is more intelligent.
6761 ** Incompatible changes
6763 - There is now a special version of `org.el' for XEmacs.
6764 Before installation, as an XEmacs user you must rename the
6765 file org_xemacs.el to org.el, i.e. you must overwrite org.el
6766 with the xemacs version. For example:
6768 : mv org_xemacs.el org.el
6770 This is necessary so that I can make use of some features
6771 that would be cumbersome to support in a single file. The
6772 XEmacs version is derived from the Emacs version with a
6773 program, so no reason to fear that I might be dropping
6774 XEmacs support any time soon. Sorry for the trouble.
6778 - A time stamp may now contain a range of times. So you no
6779 longer need to use two separate stamps to indicate a time
6780 interval on a single day. For example
6782 : <2007-06-18 Mon 17:30-18:20>
6784 This is now fully supported, including changing the time
6785 with S-up/down while the cursor is on the end time. Also,
6786 da the date/time prompt, you can simply write your time like
6787 12:00-14:00 and the range will be inserted.
6789 This was proposed by Leo some time ago, and recently by
6792 - You may specify clocking times by hand (i.e. without
6793 clocking in and out) using this syntax.
6797 Thanks to Scott Jaderholm for this proposal.
6799 - TAGS may now contain language-specific word characters, as
6800 long as they are matched by the "[:alnum:]" regexp syntax.
6801 This is for Emacs only, the XEmacs version continues to use
6802 the character class "a-zA-Z0-9_@" for tag names. Thanks to
6803 David Smith for a patch to this effect (a modified version
6804 of that patch was applied). I am considering to make the
6805 same change for TODO keywords, but not yet. Note that files
6806 using localization features may not work correctly in the
6807 Emacs configuration of another user, so if you are sharing
6808 org-mode files with other users, it might still be best to
6809 stick to the ASCII characters.
6811 - Promotion and demotion of plain list items (commands M-left,
6812 M-right) no longer changes the indentation by just one
6813 space. Instead, it uses intelligence gathered from the
6814 surrounding list structure to do the right thing. Thanks to
6815 William Henney for starting the discussion about this.
6817 - TAB does now a better job of indenting lines.
6819 + After tables and code segments (lines starting with ":"),
6820 indentation goes back to what it was before (thanks to
6821 William Henney for suggesting this behavior).
6823 + When plain lists items are involved, we had a long
6824 discussion on emacs-orgmode where I tried to show that a
6825 too-sophisticated implementation will still be easily
6826 fooled. Here is what I have implemented now - lets see
6827 if we can agree on this:
6829 Indentation will flatten lists with the same bullet type,
6830 but indent another bullet type further. The time when
6831 this fails is in a nested list, when you want to get back
6832 out to a previous level. For example
6840 When using TAB on every line in this list, the structure
6849 So you need to change the level of the last line by hand,
6850 using promotion and demotion functions.
6856 - Vertical lines in exported tables.
6857 - New default for `org-show-following-heading'.
6859 ** Incompatible changes
6861 - The default for `org-show-following-heading' is now nil.
6865 - You can now specify column groups in tables, to the effect
6866 that the groups will be separated by vertical lines in HTML
6867 and ASCII output. Column groups are specified by the
6868 characters "<" and ">" in a special table row. "<" starts a
6869 group, ">" ends a group (in each case including the the
6870 column where the character is specified). You may also use
6871 "<>" to make a group a single column wide. For example:
6873 : | | N | N^2 | N^3 | N^4 | sqrt(n) | sqrt[4](N) |
6874 : |---+----+-----+-----+-----+---------+------------|
6875 : | / | <> | < | | > | < | > |
6876 : | # | 1 | 1 | 1 | 1 | 1 | 1 |
6877 : | # | 2 | 4 | 8 | 16 | 1.4142 | 1.1892 |
6878 : | # | 3 | 9 | 27 | 81 | 1.7321 | 1.3161 |
6879 : #+TBLFM: $3=$2^2::$4=$2^3::$5=$2^4::$6=sqrt($2)::$7=sqrt(sqrt(($2))
6881 A table row with with nothing but "/" in the first field is
6882 never exported, but can be used to place column group
6883 information into the table. In this table, we create a
6884 group for column 2, one for columns 3-5 and one for columns
6885 6-7. HTML export will render a vertical line between these
6888 Because HTML does not require closing <colgroup> tags with
6889 </colgroup>), you can also simply start a new column
6890 wherever you want a vertical line:
6892 : | N | N^2 | N^3 | N^4 | sqrt(n) | sqrt[4](N0 |
6893 : |---+-----+-----+-----+---------+------------|
6894 : | / | < | < | | < | |
6896 - Vertical lines are now also omitted in ASCII export, unless
6897 grouping explicitly requests these lines.
6899 - The default for `org-show-following-heading' is now nil,
6900 meaning that sparse trees will be more compact. This has
6901 become possible due to in important remark by Jason Dunsmore
6902 who pointed out that TAB should behave differently in the
6903 inconsistent trees produced by the sparse tree commands.
6904 TAB does now make sure that the heading after a freshly
6905 unfolded tree is made visible at all, removing the confusing
6906 behavior we had before.
6908 - Several bugs fixed. In particular:
6910 + Strings produced by agenda batch processing with
6911 `org-batch-agenda' and `org-batch-agenda-csv' are now
6912 properly encoded, so that you should be able to use
6913 special characters in other languages as along as your
6914 post-processing program handles them correctly. At least
6915 for Emacs this should work now, but have not yet figured
6916 out how to do this in XEmacs.
6922 - Exporting Footnotes to HTML
6926 - Footnotes like =here[1]= are now exported to HTML
6928 : [1]This is a footnote
6930 Thanks to Scott Jaderholm for this proposal and a detailed
6931 HTML example on how the exported text should look like.
6933 - Special version of the reference card, for letter paper.
6935 - Switching to OVERVIEW with S-TAB no loner moves the cursor,
6936 so after three `S-TAB' commands, you will be back where you
6939 - Bug fixes, lots of them again.
6945 - Cyclic time stamps that repeat after an interval.
6946 - Special timestamps for appointments like "every 2nd Thursday
6948 - Completion of link abbreviation prefixes inside `C-c C-l'.
6949 - Replacing a region of org-mode syntax with HTML.
6950 - iCalendar export now honors ARCHIVE etc.
6951 - New command to add/change emphasis markers.
6953 ** Incompatible Changes
6955 - The REPEAT(...) cookie is no longer supported, the repeater
6956 interval now goes directly into the time stamp.
6960 - Time stamps can contain a repeater code, like +1w for once
6961 every week, +2d for every two days, etc. For example,
6963 <2007-05-16 Wed 12:30 +1w>
6965 will apply to every Wednesday, starting from the date given.
6966 I believe this syntax was actually suggested by someone on
6967 the mailing list, but I cannot find the email back. To
6968 collect your credit, let me know!
6970 - You can use an sexp diary entry (with the syntax used by the
6971 Emacs calendar/diary) in a time stamp, like this:
6973 *** The nerd club meets on 2nd Thursday of every month
6974 <%%(diary-float t 4 2)>
6976 - You can put diary-style sexp entries directly into an
6977 org-mode file, where they will be interpreted just like they
6978 would in the diary. For example
6980 * Birthdays and similar stuff
6982 %%(org-calendar-holiday) ; special function for holiday names
6984 %%(diary-anniversary 14 5 1956) Artur Dent %d is years old
6985 %%(diary-anniversary 2 10 1869) Mahatma Gandhi
6987 These entries must start at column 0 to be evaluated.
6989 It turns out that evaluating the entries in an org-mode file
6990 is actually faster than in the diary itself, because using
6991 the diary has some overhead (creating fancy diary display,
6992 then reading and re-interpreting the entries). I have moved
6993 all the sexp entries from my diary into an org-mode file,
6994 put in a few categories, and then turned off
6995 `org-agenda-include-diary'. This has led to a noticeably
6996 faster agenda display.
6998 - New command `org-replace-region-by-html' that converts the
6999 current region from org-mode syntax into HTML. For example,
7000 you might write an itemized list in plain text in an HTML
7001 buffer, and then invoke this command to convert it. Thanks
7002 to Raman for this idea.
7004 - When inserting a link with `C-c C-l', completion will now
7005 fill in all valid link prefixes, like http or ftp, but also
7006 link abbreviation prefixes. This is based on an idea by
7009 - Highest, lowest, and default priority can be set on a
7010 per-file basis with #+PRIORITIES: H L D
7011 For example, to use priorities from 1 to 9, you could use
7015 Thanks to Dmitri Minaev for a patch to this effect.
7017 - iCalendar export now honors (i.e. skips) subtrees marked as
7018 ARCHIVE, COMMENT, or QUOTE.
7020 - There is a new command to add or change the emphasis (like
7021 bold or italic) of a piece of text. For lack of better
7022 available keys the command is at `C-c C-x C-f', but you may
7023 well want to choose a more convenient key like `C-c f' in
7026 (add-hook 'org-load-hook
7027 (lambda () (define-key org-mode-map "\C-cf" 'org-emphasize)))
7029 The command will prompt for an emphasis type, and you may
7030 reply either with the marker that triggers the emphasis, or
7031 with the first letter of the corresponding HTML tag. For
7032 example, to select italic, press either "/" or "i".
7034 If there is an active region, the emphasis of this region
7035 will be set or changed. If there is no region, only the
7036 emphasis markers will be inserted and the cursor positioned
7037 between them. Thanks to Bastien for proposing this feature.
7039 - Bug fixes, everything where I have replied "fixed" on the
7040 mailing list. Thanks to all of you for keeping these reports
7047 This release is about exporting agenda views, to HTML, to
7048 postscript for printing, and to a special format (CSV) for
7049 further processing in scripts.
7051 ** Incompatible Changes
7053 - The variable `org-agenda-remove-tags-when-in-prefix' has
7054 been renamed to `org-agenda-remove-tags'.
7058 - Agenda views can be exported as plain text, as HTML, and as
7059 Postscript(R). This can simply be done from the agenda
7060 buffer with `C-x C-w' and then specifying a filename like
7061 `myagenda.html' or `myagenda.ps'. See section 8.6.4 of the
7064 - Each custom agenda view can specify a list of associated
7065 files names. The command `C-c a e' then creates all views
7066 that have associated file names and exports the views to
7067 these files. This is great for producing paper versions of
7068 your views, to take with you when you don't have your
7069 computer. The manual has an example on how to do this, and
7070 in particular on how to customize the format of the printed
7071 version. See section 8.6.4 of the manual.
7073 - You can produce a CSV format of agenda information with an
7074 Emacs batch command. This is greate for further processing
7075 in scipts. Thanks to Jason F. McBrayer for this idea.
7076 See section 8.6.5 of the manual.
7078 - New variable `org-agenda-skip-deadline-if-done'. When set,
7079 a deadline associated with a DONE item will not be shown in
7080 the agenda. This is based upon a report by Denis Bueno.
7082 - Quite a few bug fixes.
7092 - Control over blank lines between trees in collapsed view.
7094 - Info about the running clock is shown in the modeline.
7096 - C-a can behave specially in headlines.
7098 - Better color and scaling defaults for LaTeX fragments.
7100 - Customizable list of keys in org-mode to be replaced.
7102 - Stuck project descriptions have been extended.
7104 - Emphasis code has been modified to fix some issues.
7108 ** Incompatible changes
7110 - The option `org-format-latex-options' has changed. If you
7111 have customized it, please revert to default and then redo
7114 - `org-CUA-compatible' no longer modifies S-RET by default,
7115 because newer versions of CUA don't use this key anymore.
7116 If you need this replacement, customize the variable
7117 `org-disputed-keys'.
7119 - The variable `org-CUA-compatible' is obsolete, please use
7120 `org-replace-disputed-keys' instead. `org-CUA-compatible'
7121 is still an alias for this new variable, though.
7125 - Better control over blank lines between trees in collapsed
7126 view. This has come up several times in the past and most
7127 recently by Scott Jaderholm. There is now a new variable
7128 `org-cycle-separator-lines' with default value 2. It says
7129 how many empty lines there need to be after the end of a
7130 subtree to get an empty line in collapsed view. So with the
7131 default, if you leave only one empty line it will disappear
7132 in collapsed view. If you leave two, one empty line will
7133 remain so that you can use double empty lines to structure
7134 the collapsed views of a file. I love it, so many thanks to
7135 Scott fro bringing this up again.
7137 One property of the new setup is that you will never get
7138 more than one blank line in collapsed view. We could do
7139 something special to allow *several* empty lines in
7140 collapsed view, but I think this is counter-productive.
7142 In Emacs 22, if you want to make full use of this, make sure
7143 that you have not set `outline-blank-line'.
7145 - When the clock is running, Org-mode will put info about it
7146 into the modeline. The info consists of the elapsed time
7147 and the heading of the clocked item. This was a proposal
7148 from Bastien who got the idea from Muse.
7150 - C-a can behave specially in headlines when you set the
7151 variable `org-special-ctrl-a'. It will bring the cursor
7152 first back only to the beginning of the headline *text*,
7153 i.e. after the stars and the TODO keyword, if any. A second
7154 C-a will then move the cursor to the beginning of the line.
7155 If the cursor is already at the beginning of the line, C-a
7156 will spring *forward* to the headline text. This was a
7157 proposal from Leo, based on a request from Scott Jaderholm.
7159 I have not turned this turned this on by default, should I?
7161 - When LaTeX fragments are processed into images, there is now
7162 more control and (hopefully) betters defaults for colors and
7163 scaling. Special values can be set for HTML export, so that
7164 these values can differ from what is used for display in an
7165 emacs buffer. The default foreground and background colors
7166 for images embedded in emacs are now taken from the default
7167 emacs face. Thanks to Xiao-Yong Jin for proposing these
7170 - There is now a much better mechanism to change some keys in
7171 org-mode if these keys clash with other modes you use. Turn
7172 this on by setting `org-replace-disputed-keys' (aliased to
7173 `org-CUA-compatible'). The list of keys to replace is now
7174 fully customizable, see the option `org-disputed-keys'.
7175 Many thanks to Meciej Katafiasz for a patch implementing
7178 - Stuck project descriptions have been extended. You can now
7179 use "*" as a TODO keyword or tag to say that *any* TODO
7180 keyword or TAG marks a project as non-stuck. You also can
7181 give an arbitrary regular expression that, if it matches,
7182 indicates a non-stuck project.
7184 - The code for emphasis like bold, italic etc has been
7185 modified - I might have broken something in the process,
7186 please let me know if you find problems.
7188 - A number of bugs have been fixed - those where I have
7189 replied "Fixed" on the mailing list.
7195 ** Incompatible changes
7199 - New variables to customize the header and data tags in
7200 exported HTML. These are the variables
7201 `org-export-table-header-tags' and
7202 `org-export-table-data-tags'. This follows a request from
7205 - New option `org-format-latex-header' for customizing the
7206 header of the LaTeX file used to convert embedded LaTeX to
7207 images. Thanks to `Matthieu Lemerre' for the suggestion.
7209 - The prefix version of `org-todo-list' works again. This
7210 means that `C-1 C-c a t' produces the list of TODO entries
7211 for the first TODO keyword. If you use different TODO setups
7212 in different agenda files, be careful: This number now
7213 refers to the list of *all* todo keywords used in files
7214 that are scanned for the agenda.
7222 - Dust settles after revamp of TODO keyword system.
7223 - The export title can be taken from the first text line.
7224 - TTY replacement keys have changed.
7226 ** Incompatible changes
7228 - Some TTY replacement keys are changed, see below.
7232 - Further development concerning TODO keywords.
7234 + You can now have several DONE states in a sequence, like
7236 #+SEQ_TODO: TODO VERIFY | DONE DELEGATED
7238 The difference to the proposal discussed on the mailing
7239 list (and which is also works!)
7241 #+SEQ_TODO: TODO VERIFY | DONE
7242 #+SEQ_TODO: | CANCELED
7244 is that in the first case, the extra DONE states will be
7245 reached with `C-c C-t' (or with `t' from the agenda), while
7246 in the second case you need S-<right> to get to the special
7247 states. I guess both ideas can be useful - I am leaning
7248 toward using the latter.
7250 + Setting up TODO keywords in Lisp previously used two
7251 separate variables: `org-todo-keywords' and
7252 `org-todo-interpretation'. The preferred way is now to use
7253 only `org-todo-keywords', with a new structure:
7255 (setq org-todo-keywords
7256 '((sequence "TODO" "|" "DONE")
7257 (sequence "BUG" "KNOWNCAUSE" "|" "FIXED" "IGNORED")
7258 (type "Fred" "Lisa" "Peter" "|" "DONE")
7259 (sequence "CANCELED") ; for things we decide to not do.
7262 If your setting has this new structure,
7263 `org-todo-interpretation' will be ignored. This change
7264 does not break backward compatibility. The old way of
7265 using a flat list in `org-todo-keywords' and taking the
7266 interpretation from the other variable still works.
7268 + When listing *specific* TODO entries via a sparse tree
7269 (`C-u C-c C-v') or via the agenda (`C-c a T' or `C-u C-c a
7270 t'), you can now specify several keywords to be selected,
7271 like "TODO|VERIFY|WAITING". This also works for custom
7272 agenda commands. Thanks to Jason F. McBrayer for pointing
7275 - If you have configured Org-mode to export also the text
7276 before the first headline (this is done by setting the
7277 variable `org-export-skip-text-before-1st-heading' to nil),
7278 then the first normal text line in the buffer becomes the
7279 title of the exported document. A title set with #+TITLE
7280 overules this default, and the first line then belongs to the
7281 normal text. Thanks to David House for this proposal.
7283 - TTY replacement keys. Some of the key bindings used by
7284 Org-mode do not work on a tty, so replacement key sequences
7285 are provided on ttys. In version 4.70, there are some
7286 changes in the tty replacements. Thanks to Jason F. McBrayer
7287 for coming up with the idea to use C-c <cursor> keys.
7289 | Command | | Old TTY | New TTY |
7290 | org-..... | Main Key | Replacement | Replacement |
7291 |-------------------+-----------+---------------+---------------|
7292 | shiftleft | S-left | C-c C-x left | C-c left |
7293 | shiftright | S-right | C-c C-x right | C-c right |
7294 | shiftup | S-up | C-c C-x up | C-c up |
7295 | shiftdown | S-down | C-c C-x down | C-c down |
7296 | shiftcontrolleft | C-S-left | | C-c C-x left |
7297 | shiftcontrolright | C-s-right | | C-c C-x right |
7304 This time the changes affect the following areas:
7306 - TODO keywords: Multiple sequences in a single file.
7307 - Export: More control over text before the first heading.
7308 - Export: More control over sub/superscript interpretation.
7309 - Plain lists: Option to let empty lines terminate lists.
7310 - Tables: New command to insert hline and move into line below.
7311 - REPEATing items: Turn of note taking.
7314 ** Incompatible changes
7316 - It used to be possible to spread the list of TODO keywords
7317 over several lines, like
7320 #+SEQ_TODO: PROGRESS
7323 This is no longer possible. Each such line now specifies an
7324 independent set of TODO keywords, with its own DONE state.
7325 See below for details.
7327 - The #+TEXT construct has been used to insert unchanged HTML
7328 into an exported file. This is no longer possible, the TEXT
7329 lines will be processed like any other lines. However,
7330 there are now much better ways of getting quoted HTML into
7335 - You can now use multiple sets of TODO keywords in the same
7336 buffer. For example, you may put the following three lines
7339 #+SEQ_TODO: TODO DONE
7340 #+SEQ_TODO: REPORT BUG KNOWNCAUSE RESOLVED
7341 #+TYP_TODO: Fred Laura Peter Me OK
7343 Each sub-sequence has its own DONE state. It is best to use
7344 different keywords in all sequences, to make sure Org-mode
7345 does not loose track in which specific sequence it is
7346 working. You could use the same word for all DONE states,
7347 but then cycling through to a TODO state might not bring you
7348 where you want to be.
7350 After initially setting a keyword, `C-c C-t' cycles through
7351 a sublist, i.e. is cycles from TODO to DONE or from
7352 KNOWNCAUSE to RESOLVED and further to (nothing) and back to
7355 S-right and S-left allow to select any keyword, so they move
7356 from DONE to REPORT and from RESOLVED to Fred.
7358 C-S-right and C-S-left jump from one sub-sequence to the
7359 next, for example from TODO or DONE to REPORT to Fred.
7361 Thanks to Rick Moynihan for triggering this development.
7363 - Text before the first headline can now be exported if you
7364 configure Org-mode accordingly. Either set the variable
7365 `org-export-skip-text-before-1st-heading' to nil, or use the
7366 new in-buffer option
7370 - Export content specified via the #+TEXT construct is now
7371 fully processed, i.e. links, emphasis etc. are all
7372 interpreted. #+TEXT lines may include
7373 #+BEGIN_HTML...#+END_HTML sections to embed literal HTML.
7375 - During HTML export, you can request to have a_{b}
7376 interpreted as a subscript, but to leave a_b as it is. This
7377 can be done by setting the variable
7378 org-export-sub-superscript to the symbol `{}' with
7380 (setq org-export-sub-superscript '{})
7386 Thanks to Eddward DeVilla for this idea.
7388 - New variable `org-empty-line-terminates-plain-lists'.
7389 Default is nil, meaning that empty lines are part of the
7390 previous list item, and that you can have several paragraphs
7391 in one such item. Set this to t if you want an empty line
7392 terminate all levels of plain list items.
7394 Thanks to Mike Newman for triggering this development.
7396 - C-c RET does insert a horizontal separator line and move the
7397 cursor into the table line below it. Thanks to Bastien for
7400 - Org-mode always offers you to record a note when a TODO item
7401 automatically repeats, even if you are not logging state
7402 changes. The new variable `org-log-repeat' allows to turn
7403 this off, so that notes are really only been taken if you
7404 are logging all state changes.
7406 - Various Bug fixes, thanks to everyone who reported.
7411 - Priority handling in the tags view
7412 - Date/time prompt follows the popup calender, and accepts AM/PM times.
7413 - Standard references like B4 in the spreadsheet.
7414 - Improvements to the formula editor.
7415 - C-j does better indentation.
7419 - Priority handling in the tags view
7421 + Agenda lists selected by tag are now sorted by priority.
7422 Thanks to Andrew Korty for reporting this omission.
7424 - Improvements to the date/time prompt.
7426 + When you move (using S-cursor keys) the cursor in the pop-up
7427 calendar window while responding to a date/time prompt, the
7428 prompt is updated with the new default date (Emacs only).
7430 + You can now enter AM/PM times at this prompt.
7432 - Changes in the spreadsheet
7434 + You can now also write B4 instead of @4$2 as a reference in
7435 formulas. The column references without specified row can be
7436 written as C& instead of $3. Such references make formulas
7437 easier to read and are now the default way how references are
7438 shown when you edit existing formulas. To get the old behavior
7439 back (i.e. only @row$col references), set the variable
7440 `org-table-use-standard-references' to nil.
7442 Relative references like @-3$-2 or @II..III continue to use the
7445 - Changes in the formula editor (the one you get with "C-c '")
7447 + The formulas are organized in a more logical way.
7449 + There is now a menu with commands.
7451 + When starting the formula editor with "C-c '", the cursor
7452 immediately moves to the formula for the current field.
7454 + With the cursor on a reference in the formula, you can use
7455 S-cursor keys to change the field being referenced.
7457 - C-j indents the following line correctly whe used in a headline
7458 or in aplain list item. Thanks to Leo for this suggestion.
7462 + Flyspell now knows about special org-mode commands.
7463 Thanks to Vinod Valsalam for reporting this problem, and to
7464 Andrew Korty for showing how to fix it.
7466 + Most other bugs discussed recently on emacs-orgmode@gnu.org
7467 should be fixed, except the problem with non-ASCII characters
7472 - Expert mode for fast tag selection.
7473 When org-fast-tag-selection-single-key is `expert', not even
7474 the selection window is shown, only the prompt. One more C-c
7475 gets you the window, another one goes to multiple selection mode.
7477 - Synchronized with Emacs once more: Emacs CVS has now org-mode
7478 4.67. At least until it causes a problem, then the Emacs people
7479 will switch back to 4.56. Lets hope there will be no problem.
7489 - Sorting of top-level entries works now if the region contains
7490 top-level entries, or if the cursor is before the first headline.
7491 Thanks to "redblue" for reporting this bug.
7493 - When entering date and time at the prompt, you can now mix
7494 entering text and selecting something in the calendar. For
7495 example, enter 22:15 at the prompt without pressing RET, and then
7496 click on a date in the calendar. Both pieces of information will
7497 be included in the resulting time stamp. You can also use
7498 S-curser to move the cursor in the calendar to the desired date
7499 and then enter 22:15 and press RET at the prompt.
7501 - When setting a deadline or a schedule, entering a time now
7502 automatically selects the time stamp format that includes the
7503 time. Bug report (by means of a question) from Bastre.
7505 - C-c C-l can be used to convert a plain link into a bracket link.
7507 - Internal links now match inside (the visible part of) other
7508 links. Thanks to Scott Otterson for reporting this bug.
7510 - iCalendar export of TODO items fixed, see also the variable
7511 `org-icalendar-include-todo'. Thanks to Philipp Raschdorf.
7513 - The number of levels in the table of contents of an exported
7514 document can now be set independently of the number of headline
7515 levels. For example:
7517 #+OPTIONS: H:4 toc:2
7519 - The command `C-c }' toggles the display of row and column numbers
7520 the the current table, to aid constructing formulas. To try it,
7521 move the cursor to a table and press `C-c }', or use the menu
7524 - Orgtbl translation functions (introduced in 4.65) have been
7525 simplified using a generic function `orgtbl-to-generic' that can
7526 be used for very general languanges. Writing your own translator
7527 should be very easy now. More info in the manual.
7529 - CONTENTS visibility can be limited to a certain level. The
7530 command `C-3 S-TAB' will switch to CONTENTS view and show the
7539 - Orgtbl can be used to maintain tables in LaTeX, and in any other mode
7540 - Editing Lisp formulas for tables improved.
7541 - Better structure for HTML exported tables.
7542 - New "calculation" marker "/" to mark lines that should not be exported.
7544 ** Detailed description of changes
7546 - You can use orgtbl mode to maintain a LaTeX table, or pretty much
7547 any table in any mode.
7549 This does *not* work by making Orgtbl aware of LaTeX syntax. That
7550 would be a box of Pandora I am not willing to open. Instead, you
7551 use a normal Orgtbl-mode table, and a converter program to
7552 automatically place a LaTeX version of the table into the correct
7553 spot in the LaTeX file. The orgtbl-mode table can be maintained
7554 inside the same file, in a block comment.
7556 I am providing translators for LaTeX, HTML, and TeXInfo. For
7557 other applications, you need to write one yourself - but that is
7558 not hard if you start from the LaTeX version and just modify it.
7559 Thanks to Thomas Baumann for triggering this development through
7560 a request for a table-to-LaTeX converter.
7562 - In the special buffer to edit the formulas of a table (created
7563 with "C-c '"), there is now better support for editing Lisp
7564 formulas. TAB and M-TAB work like in an Emacs Lisp buffer,
7565 indenting lines and completing lisp symbols. With the cursor on
7566 a line defining a complex Lisp formula, a first press on TAB will
7567 convert the formula into a pretty-printed version with proper
7568 linebreaks and indentation. A second TAB folds the line back to
7571 - Tables in HTML export have now additional structure elements
7572 defined. The header (before the first hline) is wrapped into
7573 <thead>..</thead>, and each part of the body (as separated in
7574 org-mode by hlines) is wrapped into <tbody>..</tbody> tags. I
7575 have also changed the CSS style for <td> fields and the value of
7576 `org-export-html-table-tag' to get cleaner tables. Basically,
7577 tables now have horizontal lines only where needed, and no
7578 vertical lines at all, as generally recommended for tables in
7579 printed text. I like the new look, but I am not sure if this
7580 change will find general approval, please throw in your view if
7581 you like. Thanks to Scott for driving this, and to goud-H for
7582 pointing me to the row grouping in tables.
7584 - In a table with calculation markers in the first column, you can
7585 now also put "/" into the first column. It indicates that this
7586 line should not be exported. The foremost application for this
7587 are lines containing only "<N>" markers for narrowing columns.
7593 - Email links get better, configurable descriptions
7594 - When inserting a link, selected text becomes the description
7595 - Easier access to the list of stored links.
7596 - Horizontal lines in HTML export.
7597 - Remember templates and storing of notes improved.
7599 ** Detailed description of changes
7601 - The descriptive part of links to email messages can be configured
7602 using the variable `org-email-link-description-format'. The new
7603 default is "Email %c: %.30s" and leads to
7605 Email from NAME: SUBJECT
7607 If you configure the variable `org-from-is-user-regexp'
7608 correctly, then for email you *sent* this will actually change to
7610 Email to NAME: SUBJECT
7612 The subject is limited to 30 characters. If you have become
7613 attached to the previous default (look twice, the new one is
7614 better), use "%f on: %s" as your format.
7616 - Selecting text before entering a new link with C-c C-l now really
7617 works, the selected text becomes the description part of the
7618 link. Requested by Scott, buggy 4.62 implementation is now fixed.
7620 - Stored links are part of the history list for C-c C-l, so to
7621 reach them, you can use up/down rather than completion. Thanks
7622 to Raman for this excellent idea.
7624 - A line consisting only of "-", and at least 5 of them, is
7625 exported into HTML as <hr/>, as proposed by Giovanni Ridolfi.
7627 - Several changes to org <-> remember integration
7629 - You can use `org-remember' as your default command to start
7630 remember. It will automatically detect if there is an active
7631 region and use it as initial content (we will probably make
7632 remember.el work like this as well).
7633 Also, when calling `org-remember' in a remember buffer that
7634 was created with a template, you will again be asked to
7635 select a template. The buffer is then re-created with the
7636 new template, but the old context information. This is
7637 useful if you change your mind about the template to use
7640 - Besides specifying a default *target* file for a note, you
7641 can also give a default *heading* of which the note should
7642 become a subitem. In many cases this avoids or speeds up
7643 navigating to the right location. Both file and heading can
7644 be different for each template. Both are non-binding, you
7645 can change them while storing the note. However, when you
7646 exit remember with C-u C-c C-c, these defaults will be used
7647 without interaction.
7649 - Templates can specify interactive fields. During expansion
7650 of the template, you will be prompted for the information in
7651 that field. For example %^t will pop up a calendar and ask
7652 you to select a date. This new feature follows a proposal
7653 from Leo, who in the mean time has said he does not need it
7654 anymore. But I liked it, so here it is :-)
7656 - Templates can access information specific to the link type
7657 created, for example the author and subject of an email.
7658 Syntax is %:fromname, %:fromaddress, %:subject etc, details
7659 in the manual. Proposed by Peder O. Klingenberg.
7661 - I have been considering to move, at some stage, the template
7662 functionality into remember.el itself - which would of course
7663 require consent of the remember.el maintainers. I am not
7664 sure how well this would work though, since some things like
7665 the interactive time stamps are org.el specific, so treating
7666 them would require special hooks. Comments?
7672 - Many changes to the spreadsheet functions in the table editor.
7673 For details, please re-read the manual section 3.4.
7675 - It is much easier to assign formulas to individual fields.
7676 - References to arbitrary fields and ranges.
7677 - Absolute references are modified in row-editing commands.
7678 - Formula editor that highlights referenced fields.
7679 + Incompatible changes
7680 - Empty fields are excluded in range references, see "E" mode flag.
7681 - &... ranges no longer supported, use new @... ranges.
7682 - Variable insertion into Lisp formulas work differently.
7683 - Selected text becomes the default description for C-c C-l links.(Scott)
7684 - The date format in the agenda/timeline views is now customizable.
7685 See the new option `org-agenda-date-format'. (request by Victor)
7686 - Link abbreviations no longer need a double colon, single colon is fine.
7690 - Avoiding keybinding clashes with flyspell
7691 - Archiving is now also on `C-C C-x C-s' (was just `C-c $')
7692 - Cycling through agenda files is now also on "C-'" (was just "C-,")
7693 - Colon is considered part of number, to align times in clock tables.
7694 - Fixed bug for list of stuck projects.
7695 - Fixed several bugs/problems concerning linking to gnus.
7696 - Block agendas can contain the list of stuck projects.
7697 - #+ARCHIVE may now appear several times in the buffer.
7701 - HTML export: inlining images, clickable images (manual 10.2.4).
7702 - Incremental search now shows proper context when exiting.
7703 - Tables calculation and Calc package.
7704 - Calc is no longer needed when using only elisp formulas.
7705 - Proper error messages when calc is needed and not available.
7706 - Tracking TODO state changes with time stamps and notes.
7707 - Empty entries go full circle.
7708 - Links in iCalendar export cleaned up.
7713 - Cleanup code, bug fixes.
7716 - Full undo support in the agenda buffer.
7717 - Listing stuck GTD projects (projects without any NEXT ACTIONS).
7718 Configure `org-stuck-projects' before using it.
7719 - C-c C-x b shows the current subtree in an indirect buffer, in
7720 another, dedicated frame.
7721 - Custom agenda commands take precedence over builtin commands.
7722 - auto-fill for comments works on the Emacs side, XEmacs not yet.
7725 - Sorting of outline items on same level.
7726 - Sorting tables automatically selects line range between hlines.
7727 - Changes in Agenda buffer
7728 - `C-c C-o' follows a link in the current line.
7729 - `C-c $' archives the subtree corresponding to the line.
7730 - Changing dates with S-left and S-right show new date in agenda,
7731 but still do not move the entry to the new date.
7732 - new option `org-agenda-skip-scheduled-if-done'.
7733 - Agenda and sparse tree construction using tag matches can now
7734 use regular expressions.
7735 - When prompted for a date/time, entering "+7" indicates a date
7736 7 days from now - but only this is the only thing you give.
7737 - Custom time formats also apply to exported html and ascii.
7741 - `C-k' in agenda kills current line and corresponding subtree in file.
7742 - XEmacs compatibility issues fixed, in particular tag alignment.
7743 - M-left/right now in/outdents plain list items, no Shift needed.
7750 - Improvements to fast tag selection
7751 + show status also in target line.
7752 + option to auto-exit after first change to tags list (see manual).
7753 - Tags sparse trees now also respect the settings in
7754 `org-show-hierarchy-above' and `org-show-following-heading'.
7758 - Custom time formats can be overlayed over time stamps.
7759 - New option `org-agenda-todo-ignore-deadlines'.
7760 - Work-around for flyspell bug (CVS Emacs has this fixed in flyspell.el).
7761 - Work-around for session.el problem with circular data structures.
7765 - TAG matches can also specify conditions on TODO keywords.
7766 - The fast tag interface allows setting tags that are not in the
7771 - Link abbreviations (manual section 4.5).
7772 - More control over how agenda is displayed. See the new variables
7773 `org-agenda-window-setup', `org-agenda-restore-windows-after-quit'.
7777 - Closing a TODO item can record an additional note.
7778 See variables `org-log-done' and `org-log-note-headings'.
7779 - Inserting headlines and bullets can leave an extra blank line.
7780 See variable `org-blank-before-new-entry'. (Ed Hirgelt patch)
7781 - [[bracket links]] in the agenda are active just as in org-mode buffers.
7782 - C-c C-o on a date range displays the agenda for exactly this range.
7783 - The default for `org-cycle-include-plain-lists' is back to nil.
7784 - Calls to `org-occur' can be stacked by using a prefix argument.
7785 - The options `org-show-hierarchy-above' and `org-show-following-heading'
7786 now always default to `t', but can be customized differently for
7787 different types of sparse trees or jump commands.
7792 - Agenda views can be made in batch mode from the command line.
7793 - `org-store-link' does the right thing in dired-mode.
7794 - File links can contain environment variables.
7795 - Full Emacs 21 compatibility has been restored.
7799 - Custom commands may produce an agenda which contains several blocks,
7800 each block created by a different agenda command.
7801 - Agenda commands can be restricted to the current file, region, subtree.
7802 - The timeline command must now be called through the agenda
7803 dispatcher (C-c a L). `C-c C-r' no longer works.
7804 - Agenda items can be sorted by tag. The *last* tag is used for this.
7805 - The prefix and the sorting strategy for agenda items can depend
7806 upon the agenda type.
7807 - The handling of `mailto:' links can be customized, see the new
7808 variable `org-link-mailto-program'.
7809 - `mailto' links can specify a subject after a double colon,
7810 like [[mailto:carsten@orgmode.org::Org-mode is buggy]].
7811 - In the #+STARTUP line, M-TAB completes valid keywords.
7812 - In the #+TAGS: line, M-TAB after ":" inserts all currently used tags.
7813 - Again full Emacs 21 support: Checkboxes and publishing are fixed.
7814 - More minor bug fixes.
7817 - Checkbox lists can show statistics about checked items.
7818 - C-TAB will cycle the visibility of archived subtrees.
7819 - Documentation about checkboxes has been moved to chapter 5.
7823 - Clock table can be done for a limited time interval.
7824 - Obsolete support for the old outline mode has been removed.
7825 - Bug fixes and code cleaning.
7829 - `s' key in the agenda saves all org-mode buffers.
7832 - Shift-curser keys can modify inactive time stamps (inactive time
7833 stamps are the ones in [...] brackets.
7834 - Toggle all checkboxes in a region/below a headline.
7842 - Special tag ARCHIVE keeps a subtree closed and away from agenda lists.
7843 - LaTeX code in Org-mode files can be converted to images for HTML.
7845 - CDLaTeX-mode features can be used in Org-mode to help inserting
7846 LaTeX environment and math.
7849 - noutline.el is now required (important for XEmacs users only).
7851 - Archiving of all level 1 trees without open TODO items.
7852 - Clock reports can be inserted into the file in a special section.
7853 - FAQ removed from the manual, now only on the web.
7857 - Clock-feature for measuring time spent on specific items.
7858 - Improved emphasizing allows configuration and stacking.
7861 - Improved indentation of ASCII export, when headlines become items.
7862 - Handling of 12am and 12pm fixed. Times beyond 24:00 can be used
7863 and will not lead to conflicts.
7864 - Support for mutually exclusive TAGS with the fast tags interface.
7868 - HTML export is now valid XHTML.
7869 - Timeline can also show dates without entries. See new option
7870 `org-timeline-show-empty-dates'.
7871 - The bullets created by the ASCII exporter can now be configured.
7872 See the new option `org-export-ascii-bullets'.
7873 - New face `org-upcoming-deadline' (was `org-scheduled-previously').
7874 - New function `org-context' to allow testing for local context.
7880 - New commands to move through plain lists: S-up and S-down.
7881 - Bug fixes and documentation update.
7884 - Fast (single-key-per-tag) interface for setting TAGS.
7885 - The list of legal tags can be configured globally and locally.
7886 - Elisp and Info links (thanks to Todd Neal).
7887 - `org-export-publishing-directory' can be an alist, with different
7888 directories for different export types.
7889 - All context-sensitive commands use `call-interactively' to dispatch.
7890 - `org-confirm-shell-links' renamed to `org-confirm-shell-link-function'.
7897 - Modified installation: Autoloads have been collected in org-install.el.
7898 - Logging (org-log-done) is now a #+STARTUP option.
7899 - Checkboxes in plain list items, following up on Frank Ruell's idea.
7900 - File links inserted with C-c C-l will use relative paths if the linked
7901 file is in the current directory or a subdirectory of it.
7902 - New variable `org-link-file-path-type' to specify preference for
7903 relative and absolute paths.
7904 - New CSS classes for tags, timestamps, timestamp keywords.
7905 - Bug and typo fixes.
7909 - Inlining images in HTML export now depends on wheather the link
7910 contains a description or not.
7911 - TODO items can be scheduled from the global TODO list using C-c C-s.
7912 - TODO items already scheduled can be made to disappear from the global
7913 todo list, see `org-agenda-todo-ignore-scheduled'.
7914 - In Tables, formulas may also be Lisp forms.
7915 - Exporting the visible part of an outline with `C-c C-x v' works now
7916 for all available exporters.
7917 - Bug fixes, lots of them :-(
7923 - HTML exporter generalized to receive external options.
7924 As part of the process, author, email and date have been moved to the
7925 end of the HTML file.
7926 - Support for customizable file search in file links.
7927 - BibTeX database links as first application of the above.
7928 - New option `org-agenda-todo-list-sublevels' to turn off listing TODO
7929 entries that are sublevels of another TODO entry.
7935 - Revision of the font-lock faces section, with better tty support.
7936 - TODO keywords in Agenda buffer are fontified.
7937 - Export converts links between .org files to links between .html files.
7938 - Better support for bold/italic/underline emphasis.
7948 - In agenda buffer, mouse-1 no longer follows link.
7949 See `org-agenda-mouse-1-follows-link' and `org-mouse-1-follows-link'.
7952 - Links use now the [[link][description]] format by default.
7953 When inserting links, the user is prompted for a description.
7954 - If a link has a description, only the description is displayed
7955 the link part is hidden. Use C-c C-l to edit the link part.
7956 - TAGS are now bold, but in the same color as the headline.
7957 - The width of a table column can be limited by using a field "<N>".
7958 - New structure for the customization tree.
7963 - The list of agenda files can be maintainted in an external file.
7967 - Templates for remember buffer. Note that the remember setup changes.
7968 To set up templates, see `org-remember-templates'.
7969 - The time in new time stamps can be rounded, see new option
7970 `org-time-stamp-rounding-minutes'.
7971 - Bug fixes (there are *always* more bugs).
7976 - Headlines can contain TAGS, and Org-mode can produced a list
7977 of matching headlines based on a TAG search expression.
7978 - `org-agenda' has now become a dispatcher that will produce the agenda
7979 and other views on org-mode data with an additional keypress.
7983 - Switching and item to DONE records a time stamp when the variable
7984 `org-log-done' is turned on. Default is off.
7987 - M-RET makes new items as well as new headings.
7988 - Various small bug fixes
7991 - CamelCase words link to other locations in the same file.
7992 - File links accept search options, to link to specific locations.
7993 - Plain list items can be folded with `org-cycle'. See new option
7994 `org-cycle-include-plain-lists'.
7995 - Sparse trees for specific TODO keywords through numeric prefix
7996 argument to `C-c C-v'.
7997 - Global TODO list, also for specific keywords.
7998 - Matches in sparse trees are highlighted (highlights disappear with
7999 next buffer change due to editing).
8002 - Improved CSS support for the HTML export. Thanks to Christian Egli.
8003 - Editing support for hand-formatted lists
8004 - M-S-cursor keys handle plain list items
8005 - C-c C-c renumbers ordered plain lists
8008 - There is finally an option to make TAB jump over horizontal lines
8009 in tables instead of creating a new line before that line.
8010 The option is `org-table-tab-jumps-over-hlines', default nil.
8011 - New command for sorting tables, on `C-c ^'.
8012 - Changes to the HTML exporter
8013 - hand-formatted lists are exported correctly, similar to
8014 markdown lists. Nested lists are possible. See the docstring
8015 of the variable `org-export-plain-list-max-depth'.
8016 - cleaned up to produce valid HTML 4.0 (transitional).
8017 - support for cascading style sheets.
8018 - New command to cycle through all agenda files, on C-,
8019 - C-c [ can now also be used to change the sequence of agenda files.
8026 - Export of calendar information in the standard iCalendar format.
8030 - HTML export specifies character set depending on coding-system.
8033 - In tables, directly after the field motion commands like TAB and RET,
8034 typing a character will blank the field. Can be turned off with
8035 variable `org-table-auto-blank-field'.
8036 - Inactive timestamps with `C-c !'. These do not trigger the agenda
8037 and are not linked to the calendar.
8038 - Additional key bindings to allow Org-mode to function on a tty emacs.
8039 - `C-c C-h' prefix key replaced by `C-c C-x', and `C-c C-x C-h' replaced
8040 by `C-c C-x b' (b=Browser). This was necessary to recover the
8041 standard meaning of C-h after a prefix key (show prefix bindings).
8044 - QUOTE keyword at the beginning of an entry causes fixed-width export
8045 of unmodified entry text. `C-c :' toggles this keyword.
8046 - New face `org-special-keyword' which is used for COMMENT, QUOTE,
8047 DEADLINE and SCHEDULED, and priority cookies. Default is only a weak
8048 color, to reduce the amount of aggressive color in the buffer.
8051 - Formulas for individual fields in table.
8052 - Automatic recalculation in calculating tables.
8053 - Named fields and columns in tables.
8054 - Fixed bug with calling `org-archive' several times in a row.
8057 - Efficiency improvements: Fewer table re-alignments needed.
8058 - New special lines in tables, for defining names for individual cells.
8061 - Tables can store formulas (one per column) and compute fields.
8062 Not quite like a full spreadsheet, but very powerful.
8063 - table.el keybinding is now `C-c ~'.
8064 - Numeric argument to org-cycle does `show-subtree' above on level ARG.
8065 - Small changes to keys in agenda buffer. Affected keys:
8066 [w] weekly view; [d] daily view; [D] toggle diary inclusion.
8070 - Links inserted with C-c C-l are now by default enclosed in angle
8071 brackets. See the new variable `org-link-format'.
8072 - ">" terminates a link, this is a way to have several links in a line.
8073 Both "<" and ">" are no longer allowed as characters in a link.
8074 - Archiving of finished tasks.
8075 - C-<up>/<down> bindings removed, to allow access to paragraph commands.
8076 - Compatibility with CUA-mode (see variable `org-CUA-compatible').
8077 - Compatibility problems with viper-mode fixed.
8078 - Improved html export of tables.
8079 - Various clean-up changes.
8082 - Using `define-derived-mode' to derive `org-mode' from `outline-mode'.
8086 - Time-of-day specifications in agenda are extracted and placed
8087 into the prefix. Timed entries can be placed into a time grid for
8091 - "|" no longer allowed as part of a link, to allow links in tables.
8092 - The prefix of items in the agenda buffer can be configured.
8096 - Some folding inconsistencies removed.
8097 - BBDB links to company-only entries.
8098 - Bug fixes and global cleanup.
8101 - M-S-RET inserts a new TODO heading.
8102 - New startup option `content'.
8103 - Better visual response when TODO items in agenda change status.
8104 - Window positioning after visibility state changes optimized and made
8105 configurable. See `org-cycle-hook' and `org-occur-hook'.
8108 - Agenda entries from the diary are linked to the diary file, so
8109 adding and editing diary entries can be done directly from the agenda.
8110 - Many calendar/diary commands available directly from agenda.
8111 - Field copying in tables with S-RET does increment.
8112 - C-c C-x C-v extracts the visible part of the buffer for printing.
8113 - Moving subtrees up and down preserves the whitespace at the tree end.
8116 - Table editor optimized to need fewer realignments, and to keep
8117 table shape when typing in fields.
8118 - A new minor mode, orgtbl-mode, introduces the Org-mode table editor
8119 into arbitrary major modes.
8120 - Fixed bug with realignment in XEmacs.
8121 - Startup options can be set with special #+STARTUP line.
8122 - Heading following a match in org-occur can be suppressed.
8125 - Copyright transfer to the FSF.
8126 - Effect of C-u and C-u C-u in org-timeline swapped.
8127 - Timeline now always contains today, and `.' jumps to it.
8129 - cut and paste of rectangular regions in tables
8130 - command to convert org-mode table to table.el table and back
8131 - command to treat several cells like a paragraph and fill it
8132 - command to convert a buffer region to a table
8133 - import/export tables as tab-separated files (exchange with Excel)
8135 - Sorting mechanism for agenda items rewritten from scratch.
8136 - Sorting fully configurable.
8137 - Entries specifying a time are sorted together.
8138 - Completion also covers option keywords after `#-'.
8142 - New reference card, thanks to Philip Rooke for creating it.
8143 - Single file agenda renamed to "Timeline". It no longer shows
8144 warnings about upcoming deadlines/overdue scheduled items.
8145 That functionality is now limited to the (multifile) agenda.
8146 - When reading a date, the calendar can be manipulated with keys.
8147 - Link support for RMAIL and Wanderlust (from planner.el, untested).
8148 - Minor bug fixes and documentation improvements.
8151 - Multifile Agenda shows current entries from many different files.
8152 - TeXInfo documentation (thanks to Christian Egli for the conversion).
8153 - Additional applications for TODO keywords, see documentation.
8154 Different files may have different TODO keywords etc.
8155 - Priorities for TODO items.
8156 - The browser mode used by `org-remember-handler' is improved.
8157 - Images get inlined in HTML export (thanks to Carsten Wimmer).
8158 - File links can contain line numbers, like file:/usr/etc/config:255
8163 - TODO entries can have additional states besides TODO and DONE.
8164 See new variable `org-todo-keywords'.
8165 - TODO keywords can be interpreted as categories. See variable
8166 `org-todo-interpretation'.
8167 - M-TAB completion on TODO keywords, TeX symbols, and normal words.
8168 - All keywords (like TODO, DEADLINE etc) are configurable.
8169 - Cursor positioning optimized after pro/demotion and TODO cycling.
8170 - Emphasizing in HTML works now for *bold*, /italic/ and _underline_.
8171 - New commands to kill, copy and yank entire subtrees. Yanking
8172 modifies the level of the tree before insertion.
8173 - New command `org-goto' (C-c C-j) to quickly move to other locations
8174 in the buffer without affecting outline visibility.
8175 - Hooks for John Wiegley's remember.el.
8176 - `org-read-date' pops up calendar for date selection with the mouse.
8177 See variable `org-popup-calendar-for-date-prompt'.
8180 - TODO items can be SCHEDULED to a certain date.
8181 - Expired DEADLINEs are ignored if in an entry marked DONE.
8182 - From the diary or time-sorted view (C-c C-r), C-c C-t can be used to
8183 change the TODO state of an item remotely.
8184 - Horizontal computations in table editor. See `org-table-eval-formula'.
8185 - Fixed bug with summing tables (command `org-table-sum', `C-c +').
8186 - Calendar window follows the timestamp when a timestamp is changed.
8187 New variable `org-calendar-follow-timestamp-change'.
8188 - Time-sorted view (`org-diary-view', C-c C-r) now uses the prefix
8189 argument to force inclusion of unscheduled TODO items.
8190 - New variable `org-confirm-shell-links' to turn of safety query.
8191 - New variable `org-open-non-existing-files'.
8194 - A time-sorted view on all time stamps can be created with C-c C-r.
8195 - Timestamps and Deadlines can be shown in the Emacs diary.
8196 - Date ranges introduced.
8197 - Time-string formats are no longer configurable.
8198 - Vertical lines in tables can be made invisible with `C-c |'.
8199 - New "link" type to execute shell commands, like "shell:ls *.org"
8200 - Upon export, "myfile.org" becomes "myfile.html" or "myfile.txt",
8201 instead of "myfile.org.html" or "myfile.org.txt".
8202 - When the cursor is in the white space at the beginning of a line,
8203 TAB removes the whitespace before indenting again.
8206 - Windows (NT/2000) support.
8207 - Works with both Emacs and XEmacs.
8208 - Fully automatic table editor.
8209 - New link types into Gnus, VM and BBDB.
8210 - Other link system changes
8211 - Time stamps are treated as links to the calendar.
8212 - Easy creation of links with global command `org-store-link'.
8213 - Insertion of links with `C-c C-l' works differently now.
8214 - Space characters allowed as part of a link.
8215 - Options in `org-file-apps' extended. The command may now be
8216 symbol 'emacs', or a lisp form.
8217 Please re-read the manual section about links.
8219 - `org-deadline' now prompts for a date.
8220 - A line can now contain several timestamps. Updating of a
8221 timestamp only happens if the cursor is at the timestamp.
8222 - Changed the time-stamp-format to ISO, to make sure it will
8223 always work (non-English month names had caused problems
8224 with `parse-time-string'.). Changing the time stamp format
8226 - Picture mode enhancements have been removed from org.el
8230 - Some option name changes, not backward compatible.
8231 - ASCII exporter upgrade: Table of contents.
8232 - HTML exporter upgrade: fixed-width regions, better
8233 sub/superscripts, many TeX symbols supported.
8237 - HTML exporter upgrade, in particular table of contents