org-babel: results hashes are now hidden (for the most part)
[rgr-org-mode.git] / ORGWEBPAGE / Changes_old.org
blobbdcb6d5d52ea96a74f9f904534071b95e1a9524d
1 #   -*- mode: org; fill-column: 65 -*-
3 #+STARTUP: hidestars
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
10 #+LINK_UP: index.html
11 #+LINK_HOME: http://orgmode.org
14 * Version 6.29
15  :PROPERTIES:
16  :CUSTOM_ID: v6.29
17  :END:
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
34 #+begin_src org
35   ,#+STARTUP: indent
36 #+end_src
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
53 states to consider.
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
62 suggestion.
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
79 disappears.
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
97 =s= action).
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
106 insertion/deletion.
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.
128 ** Tables
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
135 right thing to do.
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
141 part.
143 See the variable =org-table-relative-ref-may-cross-hline=
144 for more details.
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.
151 ** Links
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
159 message.
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
165 links.
168 ** Agenda
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.
187 ** Export
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"
199 #+end_src
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
213 footnote label.
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
246 page title.
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.
261 A line like:
263 #+begin_src org
264   ,#+BIND: variable value
265 #+end_src
267 will bind the variable to value.  For example, the line
269 #+begin_src org
270   ,#+OPTIONS: toc:nil
271 #+end_src
273 can now equivalently be written as
275 #+begin_src org
276   ,#+BIND: org-export-with-toc nil
277 #+end_src
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.
285 ** Miscellaneous
287 *** Calendar for reading a date forced into current frame.
289 Separate-frame setup for calendar had caused problems in
290 AquaEmacs.
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
330 custom function.
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.
341 * Version 6.28
342  :PROPERTIES:
343  :CUSTOM_ID: v6.28
344  :END:
347 ** Agenda changes
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.
355 *** Bulk action
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.
372 *** Modified keys
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
385 *** Indented 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:
397 #+begin_src org
398   ,*** This is some headline
399   ,    #+begin_example
400   ,    here we have an example
401   ,    #+end_example
402   ,
403   ,    - a plain list
404   ,      - a sublist item
405   ,        - a second sublist item
407   ,          #+begin_center
408   ,           centering within the plain list item
409   ,          #+end_center
411   ,      #+begin_example
412   ,       This example does terminate the sublist,
413   ,       the indentation of the #+begin line counts.
414   ,      #+end_example
416   ,    - but the top level plain lists continues here
417 #+end_src
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.
435 *** Indented tables
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.
443 *** Protected blocks
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
454 already.
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
462 per-file basis.
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
484 export definitions).
486 Thanks to Wes Hardaker for this contribution with a lot of
487 potential.
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
518   over.
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
535   will go off.
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
546 to repeated tasks.
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
594 ones as well.
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
606         (cons '(if head
607                "<tr>"
608              (if (= (mod nline 2) 1)
609                  "<tr class=\"tr-odd\">"
610                "<tr class=\"tr-even\">"))
611           "</tr>"))
612 #+end_src
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
635 the definitions.
637 #+begin_src BSDmakefile
638 update:
639         git pull
640         ${MAKE} clean
641         ${MAKE} all
643 up2:    update
644         sudo ${MAKE} install
645 #+end_src
647 This was a request by Konstantin Antipin.
649 * Version 6.27
650   :PROPERTIES:
651   :CUSTOM_ID: v6.27
652   :END:
654 ** Details
656 *** Macros for export
658 Macro processing for export has been enhanced:
660 - You can use arguments in a macro, for example
661 #+begin_src org
662 #+macro hello Greet the $1: Hello $1
663 #+end_src
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
667   time of export:
669 #+begin_src org
670 ,#+macro: datetime (eval (format-time-string "$1"))
671 #+end_src
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
703 with
705 :  :publishing-function (org-publish-org-to-html org-publish-org-to-org)
706 :  :plain-source t
707 :  :htmlized-source t
709 to get both the plain org file and an htmlized version that
710 looks like your editing buffer published along with the HTML
711 exported version.
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
733 instead of a file.
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.
741 Setting the variable
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
759 export.
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
770 *** New reload key
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
785 lot faster.
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
820 character.
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.
831 * Version 6.26
832   :PROPERTIES:
833   :CUSTOM_ID: v6.26
834   :END:
836 ** Details
838 *** custom IDs
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
849 within a file.
851 Links written like =[[#my-target-name] ]= can be used to target a
852 custom ID.
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.
877 *** Refile verify
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.
892 * Version 6.25
893   :PROPERTIES:
894   :CUSTOM_ID: v6.25
895   :END:
897 ** Major new features
899 *** DocBook export
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
908 anything myself.
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.
937 *** Inline tasks
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
955 way.
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.
969 ** Export
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.
976 For example
978 : #+ATTR_HTML: border="2" rules="all" frame="all"
979 : #+CAPTION: Finally a table with lines!
980 : | a | b |
981 : |---|---|
982 : | 1 | 2 |
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
995 #+begin_src org
996 ,#+BEGIN_CENTER
997 ,Everything should be made as simple as possible, \\
998 ,but not any simpler
999 ,#+END_CENTER
1000 #+end_src
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
1016 this.
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.
1027 ** Agenda
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
1038 appointment.
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
1044 immediately.
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
1060 Bernt Hansen.
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.
1089 ** Miscellaneous
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
1096 #+begin_src org
1097 ,#+BIBLIOGRAPHY: bibbase style
1098 #+end_src
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
1109 range like
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
1122 with =C-c / b=.
1124 *** Cloning tasks
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
1135 around it:
1137 #+begin_src emacs-lisp
1138 (custom-set-faces
1139  (org-checkbox ((t (:background "#444444" :foreground "white"
1140                 :box (:line-width 1 :style released-button)))))
1141 #+end_src
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.
1175 * Version 6.24
1176   :PROPERTIES:
1177   :CUSTOM_ID: v6.24
1178   :END:
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
1207 exported again.
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.
1217 ** Details
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)
1241 #+end_src
1243 Or you can do this with the settings in a custom agenda view,
1244 for example
1246 #+begin_src emacs-lisp
1247 ("A" "" agenda ""
1248  ((org-agenda-ndays 1)
1249   (org-agenda-add-entry-text-maxlines 5))
1250  ("agenda-today.pdf"))
1251 #+end_src
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
1267 link export.
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
1280 ("A" "" agenda ""
1281  ((org-agenda-filter-preset '("-FLUFF" "-BLUFF"))))
1282 #+end_src
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
1286 Matt Lundin.
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
1297 Use something like
1299 #+begin_src org
1300 #+DESCRIPTION: This page is all about ....
1301 #+KEYWORDS: org-mode, indexing, publishing
1302 #+end_src
1304 To specify the content of the description and keywords meta tags
1305 for HTML output.
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
1317 Org.
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
1350 and annoying.
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))
1359 #+end_src
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
1383 an active region.
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:
1399 #+begin_src org
1400 ,#+MACRO: myaddress 41 Onestreet, 12345 New York, NY
1402 ,my address is {{{myaddress}}}, see you there.
1403 #+end_src
1405 Macro replacement is the very first thing that happens during
1406 export, and macros will be replaced even in source code and other
1407 protected regions.
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
1418 the menu as well.
1420 This new command was inspired by one written earlier by Bernt
1421 Hansen.
1423 *** Faces for priority cookies can now be set freely
1425 The new variable =org-priority-faces= can be used to set faces
1426 for each priority.
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=.
1466 * Version 6.23
1467   :PROPERTIES:
1468   :CUSTOM_ID: v6.23
1469   :END:
1470 ** Overview
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.
1490 ** 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
1496 this configuration:
1498 #+begin_src emacs-lisp
1499 (setq org-log-into-drawer "LOGBOOK")
1500 #+end_src
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")
1513 #+end_src
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:
1538 #+begin_src css
1539 .todo { font-weight:bold; }
1540 .done { font-weight:bold; }
1541 .TODO { color:red; }
1542 .WAITING { color:orange; }
1543 .DONE { color:green; }
1544 #+end_src
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
1561 into this category.
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
1602 visual feedback.
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
1617 #+begin_src org
1618 ,#+TAGS: aa(a) bb(b) cc(c)
1619 ,#+TAGS: dd(d) ee(e) ff(f)
1620 #+end_src
1622 then there will also be a line break after the "cc" tag in the
1623 fast tag selection interface.  You may also write
1625 #+begin_src org
1626 ,#+TAGS: aa(a) bb(b) cc(c) \n dd(d) ee(e) ff(f)
1627 #+end_src
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
1641 TODO list.
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
1647 of the task.
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.
1657 * Version 6.22
1658   :PROPERTIES:
1659   :CUSTOM_ID: v6.22
1660   :END:
1661 ** Details
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
1674 start.
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
1690 present.
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.
1714 * Version 6.21
1715   :PROPERTIES:
1716   :CUSTOM_ID: v6.21
1717   :END:
1719 ** Details
1721 *** Changes to some default values of variables:
1723 Here are the new default values:
1725 #+begin_example
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)))
1739 #+end_example
1741 *** Final cleanup for Emacs 21.1 pretest
1743 * Version 6.20
1744   :PROPERTIES:
1745   :CUSTOM_ID: v6.20
1746   :END:
1748 ** Details
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:
1767 #+begin_src org
1768 ,* TODO Blocked until (two) is done
1769 ,** DONE one
1770 ,** TODO two
1772 ,* Parent
1773 ,  :PROPERTIES:
1774 ,    :ORDERED: t
1775 ,  :END:
1776 ,** TODO a
1777 ,** TODO b, needs to wait for (a)
1778 ,** TODO c, needs to wait for (a) and (b)
1779 #+end_src
1781 The command =C-c C-x o= toggles the value of the =ORDERED=
1782 property.
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.
1807 * Version 6.19
1808   :PROPERTIES:
1809   :CUSTOM_ID: v6.19
1810   :END:
1812 ** Overview
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
1820 ** Details
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
1834          region:
1835          - if it is a item, turn all items in the region into
1836            normal lines.
1837          - if it is a headline, turn all headlines in the region
1838            into items.
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
1842            current list.
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
1846          region:
1847          - if it is a item, turn all items in the region into
1848            headlines.
1849          - if it is a headline, turn all headlines in the region
1850            into normal lines.
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
1875 #+begin_src org
1876 | a | b |
1877 |---+---|
1878 | 1 | 2 |
1879 | 3 | 4 |
1880 #+end_src
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.
1906 * Version 6.18
1907   :PROPERTIES:
1908   :CUSTOM_ID: v6.18
1909   :END:
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.
1920 ** Details
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
1930     supported.
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
1972     the line.
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
1989     property.
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.
2001 * Version 6.17
2002   :PROPERTIES:
2003   :CUSTOM_ID: v6.17
2004   :END:
2006 ** Overview
2008 - Footnote support
2009 - Line numbers and references in literal examples
2010 - New hooks for export preprocessing
2011 - Capture column view into a different file
2013 ** Details
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:
2026 #+begin_src org
2027 The Org homepage[fn:1] now looks a lot better than it used to.
2029 [fn:1] The link is: http://orgmode.org
2030 #+end_src
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
2036 references:
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,
2042      a number.
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
2098 =C-c f=.
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
2107 features.
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
2115 similar documents.
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
2131          example left off.
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.
2141 Here is an example:
2143 #+begin_example -k
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)))
2149 #+end_src
2150 [[(def)][Line (def)]] contains the macro name.  Later at line [[(back)]],
2151 backquoting is used.
2152 #+end_example
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)))
2160 #+end_src
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.
2202 * Version 6.16
2203   :PROPERTIES:
2204   :CUSTOM_ID: v6.16
2205   :END:
2206   Cleanup of many small bugs, and one new feature.
2208 ** Details
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.
2216 * Version 6.15f
2217   :PROPERTIES:
2218   :CUSTOM_ID: v6.15f
2219   :END:
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.
2225 * Version 6.15
2226   :PROPERTIES:
2227   :CUSTOM_ID: v6.15
2228   :END:
2229 ** Overview
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
2244 #+begin_example
2245 [[./img/a.jpg{{alt="an image"}}] ]
2246 #+end_example
2248 This syntax is not longer supported, use instead
2250 #+begin_src org
2251 ,#+ATTR_HTML: alt="an image"
2252 [[./img/a.jpg] ]
2253 #+end_src
2255 ** Details
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
2263 an active region.
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
2271 link.
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
2288      right format.
2290 - #+ATTR_LaTeX: :: Attributes for LaTeX export of images and
2291      tables.\\
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
2306 environment.
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:
2317 #+begin_example
2318 id:GLOBALLY-UNIQUE-IDENTIFIER
2319 #+end_example
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
2346 this system clean.
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
2375 Schulte.
2377 * Version 6.14
2378   :PROPERTIES:
2379   :CUSTOM_ID: v6.14
2380   :END:
2381 ** Overview
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'.
2411 ** Details
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.
2418     - =C-c C-x .= ::
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.
2423     - =C-c C-x -= ::
2424       Insert a description list item with the current relative
2425       time.  With a prefix argument, first reset the timer to 0.
2427     - =M-RET= ::
2428       Once the time list has been initiated, you can also use the
2429       normal item-creating command to insert the next timer item.
2431     - =C-c C-x 0= ::
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
2442       moment.
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
2503     under Org-mode.
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
2507     is turned on.
2509     Thanks for Richard Riley for the idea and to Andy Stewart for
2510     the implementation.
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
2516     this:
2518 #+begin_src emacs-lisp
2519 (setq org-use-property-inheritance '("LOCATION"))
2520 #+end_src
2522 * Version 6.13
2523   :PROPERTIES:
2524   :CUSTOM_ID: v6.13
2525   :END:
2527 ** Overview
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/
2535    - Link translation
2536    - BBDB links may use regular expressions.
2537    - Link abbreviations can use %h to insert a url-encoded target value
2538    - Improved XHTML compliance
2540 ** Details
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
2553     bindings like
2555 #+begin_src emacs-lisp
2556 (add-hook
2557  'org-remember-mode-hook
2558  (lambda ()
2559    (define-key org-remember-mode-map
2560      "\C-x\C-s" 'org-remember-finalize)))
2561 #+end_src
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:
2595 #+begin_src org
2596 ,# <<dummy>>
2597 ,*** a headline
2598 #+end_src
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
2638     this work
2640 #+begin_src emacs-lisp
2641 (setq org-link-translation-function
2642       'org-translate-link-from-planner)
2643 #+end_src
2645    I guess an inverse translator could be written and integrated
2646    into Planner.
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.
2669 * Version 6.12
2670   :PROPERTIES:
2671   :CUSTOM_ID: v6.12
2672   :END:
2673 ** Overview
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.
2681 ** Details
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
2700       =C-u C-y=.
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
2712     measured times.
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
2733     problems.
2735 * Version 6.11
2736   :PROPERTIES:
2737   :CUSTOM_ID: v6.11
2738   :END:
2740 ** Overview
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
2754 ** Details
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:
2771 #+begin_src org
2772 ,* Level one
2773 ,** Level two
2774 ,(1)
2775 ,(2)* Level one again
2776 #+end_src
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
2794     the agenda.
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)
2831 #+end_src
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)))
2868 #+end_src
2870     After this, a link like this will work
2872 #+BEGIN_EXAMPLE
2873      [[att:some-attached-file.txt]]
2874 #+END_EXAMPLE
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.
2890 * Version 6.10
2891   :PROPERTIES:
2892   :CUSTOM_ID: v6.10
2893   :END:
2895 ** Overview
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.
2905 ** Details
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
2913     agenda command.
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")))
2933 #+end_src
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
2938      estimates:
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
2950      default =<=.
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
2969      switched off.
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
2978       uses of =C-c C-c=.
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
3024     using pdflatex.
3026     : C-c C-e p     process to PDF.
3027     : C-c C-e d     process to PDF, and open the file.
3029 *** LaTeX export
3030     - \usepackage{graphicx} is now part of the standard class
3031       definitions.
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).
3041 * Version 6.09
3042   :PROPERTIES:
3043   :CUSTOM_ID: v6.09
3044   :END:
3045 ** Incompatible
3046 *** =org-file-apps= now uses regular expressions, see [[*%20org%20file%20apps%20now%20uses%20regular%20repressions%20instead%20of%20extensions][below]]
3048 ** Details
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
3061     visited in emacs.
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=.
3080 * Version 6.08
3081   :PROPERTIES:
3082   :CUSTOM_ID: v6.08
3083   :END:
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.
3091 ** 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
3107       which support it.
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
3122     information.
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
3138     task.
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
3149     lists below them.
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]].
3160 * Version 6.07
3161   :PROPERTIES:
3162   :CUSTOM_ID: v6.07
3163   :END:
3165 ** Overview
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
3214     this behavior.
3216     This was a request by Charles Philip Chan.
3218 ** Details
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
3264     fixed-width region.
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
3295     export buffer.
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
3301     up with the idea.
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
3327     =yank-pop= as well?
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
3338     table.
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
3368     Egli.
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
3387     this behavior.
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.
3405 * Version 6.06
3407 ** Overview
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
3428     place.
3430 ** Details
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
3438       anymore.
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=
3447       property.
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
3453       sequence.
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
3462     do this:
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
3475     internal link.
3477     So for example, a link to an image /A.jpg/ with a thumbnail
3478     /B.jpg/ can now be written like
3480 #+begin_src org
3481 [[./A.jpg][./B.jpg] ]
3482 #+end_src
3484 *** Changes in iCalendar export
3486     Deadline and scheduling time stamps are now treated
3487     differently in iCalendar export.  The default behavior is now
3488     the following:
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
3496       calendar.
3498     - a SCHEDULED timestamp in a TODO item will be used as the
3499       items DTSTART.  Therefore, such a timestamp will not show
3500       up in the calendar.
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
3517     done.  For example
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>"
3523     (date only).
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
3541     other lines.
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.
3564 * Version 6.05
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.
3570 ** Overview
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=.
3588 ** Details
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.
3614      
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
3632     API is:
3634 #+begin_example
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
3642      a list.
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
3648      the iteration.
3650      SCOPE determines the scope of this command, it can
3651      specify a file, all agenda files, the current tree and
3652      much more.
3654      The remaining args are treated as settings for the
3655      skipping facilities of the scanner.
3656 #+end_example
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
3665 (org-map-entries
3666    '(org-todo "UPCOMING")
3667    "+TOMORROW" 'file 'archive 'comment)
3668 #+end_src
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))
3675 #+end_src
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
3682      the template.
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
3689      proposal.
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.
3741 * Version 6.04
3743 ** Overview
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
3751   
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.
3760 ** Details
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
3780 implementation:
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)
3789 #+end_src
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:
3809 #+begin_src org
3810 ,#+HTML: this code can be edited in html-mode
3812 ,#+BEGIN_HTML
3813 ,Same here
3814 ,#+BEGIN_HTML
3816 ,#+LaTeX: this code can be edited in latex-mode
3818 ,#+BEGIN_LaTeX
3819 ,Same here
3820 ,#+BEGIN_LaTeX
3822 ,#+BEGIN_SRC fortran
3823 ,Here we can edit in fortran-mode
3824 ,#+END_SRC
3825 #+end_src
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
3839 this on.
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:
3866 #+begin_src org
3867 ,#+OPTIONS: skip:nil
3868 ,* Computer Tricks
3869 ,  :PROPERTIES:
3870 ,  :EXPORT_FILE_NAME: ct.html
3871 ,  :EXPORT_TITLE: Steve's collected computer tricks
3872 ,  :EXPORT_OPTIONS: h:2 toc:nil
3873 ,  :END:
3874 #+end_src
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.
3884 * Version 6.03
3886 ** Overview
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
3911 #+begin_src org
3912 #+OPTIONS: skip:t
3913 #+end_src
3915 ** Details
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.
3933     will be rendered as
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
3952 #+begin_src org
3953 ,#+BEGIN_QUOTE
3954 Everything should be made as simple as possible,
3955 but not any simpler -- Albert Einstein
3956 ,#+BEGIN_QUOTE
3957 #+end_src
3959     which will render as
3961 #+BEGIN_QUOTE
3962 Everything should be made as simple as possible,
3963 but not any simpler -- Albert Einstein
3964 #+BEGIN_QUOTE
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
3971     structure:
3973 #+begin_src org
3974 ,#+BEGIN_SRC emacs-lisp
3975 (defun org-xor (a b)
3976   "Exclusive or."
3977   (if a (not b) b))
3978 ,#+END_SRC
3979 #+end_src
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)
3988   "Exclusive or."
3989   (if a (not b) b))
3990 #+END_SRC
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
4005     A line like
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
4027     : #+OPTIONS: skip:t
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
4043     
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:
4056     : <s   #+begin_src
4057     : <e   #+begin_example
4058     : <q   #+begin_quote
4059     : <v   #+begin_verse
4060     : <l   #+begin_latex
4061     : <L   #+latex:
4062     : <h   #+begin_html
4063     : <H   #+html:
4064     : <a   #+begin_ascii
4065     : <i   #+include
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
4079     are:
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
4085       headline
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:
4094 #+begin_src org
4095 ,* Version 6.03
4096 ,  :PROPERTIES:
4097 ,    :VISIBILITY: content
4098 ,  :END:
4099 ,** Overview
4100 #+end_src
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
4121       tasks.
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 
4148          :#+BEGIN_EXAMPLE
4149          :...
4150          :#+END_EXAMPLE
4151          you can write
4152          :<example>
4153          :...
4154          :</example>
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
4163          inserted.
4165 *** Bug fixes
4166     Many bug fixes again.  Will this ever stop?
4168 * Version 6.02
4170 ** Overview
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.
4180 ** Details
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
4206     will count double.
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
4248     command =C-c a /=.
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!
4268 * Version 6.01
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.
4274 ** Overview
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.
4300 ** Details
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.
4311 *** Loading modules
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
4321     your load path).
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
4333     position in tact.
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
4346     commands.
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
4385       HTML file.
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
4402       of these:
4403       
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   |
4410       | today        | Today                 |
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
4472     it.
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
4481     
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".
4490 *** Misc
4491     
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.
4497       
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
4507       inheritance.
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.
4522       
4523       This was an omission in the earlier implementation, spotted
4524       by Wanrong Lin.  Thanks!
4525       
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:
4532       
4533       - =%c= - Now always insert the head of the kill ring, never
4534         the X clipboard.
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. 
4539         
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.  
4543         
4544       - =%^L= - Like =%^C=, but this inserts an org link using the
4545         selected value.
4546         
4547       Thanks to James TD Smith for this patch.
4548         
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:
4556      
4557       : :PROPERTIES:
4558       : :TABLE_EXPORT_FILE: ~/xx.txt
4559       : :TABLE_EXPORT_FORMAT: orgtbl-to-generic :splice t :sep "\t"
4560       : :END:
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 ^=.
4568       
4569       Thanks to James TD Smith for this patch.
4572 * Version 5.23
4574 ** Overview
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
4594    - New hooks
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,
4600      please do it again.
4602 ** Details
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=.
4628     
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),
4631     like this:
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
4662       any context.
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.
4670       
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))))
4674      
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
4726       :   today.
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
4734       original headlines.
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.
4750 *** Misc
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
4756      old line.
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
4761      tables.
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
4768      
4769 * Version 5.22
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.
4777 ** Details
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
4799       :              WAIT to TODO.
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.
4806 *** Other
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.
4816 * Version 5.21
4818   Bug fixes, in particular the long-hunted bug about wrong window
4819   positions after pressing SPACE in the agenda.  Hopefully this
4820   is really fixed.
4822 * Version 5.20
4824 ** Overview
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.
4832       
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.
4843 *** Misc
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.
4852       
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.
4861     - Bug fixes.
4863 ** Incompatible Changes
4864    
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.
4869 ** Details
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
4885         there.
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
4889         moved tree.
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. 
4894       
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
4903         location.  
4904       + `outline-path-completion': Use completion of an outline
4905         path to select a location.
4906       + `refile': Offer the `org-refile-targets' as possible
4907         targets.
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?
4930 *** Misc
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
4943         line.
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.
4958       
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
4975       Bernt.
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
4981       following hierarchy
4982       
4983       : * Tasks
4984       : ** HOME
4985       : *** Garage
4986       : **** Fix the door
4987       
4988       will file is with the following property
4989       
4990       : :ARCHIVE_PATH: Task/HOME/Garage
4991       
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
4998       links.
5000     - Bug fixes.
5002 * Version 5.19
5004 ** Overview
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.
5024 ** Details
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
5053      want this?
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
5062      fix this.
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
5067      Rainer Stengele.
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.
5085 * Version 5.18
5087   Minor fixes.
5089 * Version 5.17
5091 ** Details
5093 *** Whitespace
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
5111     that really count.
5113     This change was non-trivial, please give it a good test and
5114     let me know about any problems.
5116 *** Remember
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.
5145 *** Refile
5147     - `org-refile-targets' has a new parameter to specify a
5148       maximum level for target selection.  Thanks to Wanrong Lin
5149       for this proposal.
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.
5158 * Version 5.16
5160 ** Details
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
5172     projects.
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
5201       `org-imenu-depth'.
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.
5213 * Version 5.15
5215 ** Details
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
5224      idea.
5226    - Bug fixes.
5228 * Version 5.14
5230 ** Overview
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.
5257    + Export
5258      - You can now export some special strings in HTML, like "..."
5259      - #+EMAIL: may contain several email addresses
5261    + Agenda
5262      - In the agenda, a few keys have changed: `g', `G', and `e'.
5264    + Miscellaneous
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 ()
5282      :    (interactive)
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 ()
5289      :    (interactive)
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.
5295 ** Details
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
5313       targets.  And
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
5322       argument.
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
5347       equivalent to:
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
5384       again.
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
5396       during searches.
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
5416     the date prompt.
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 | &shy;    |
5448       | ~--~  | two dashes (minuses)               | &ndash;  |
5449       | ~---~ | three dashes (minuses)             | &mdash;  |
5450       | ~...~ | three dots                         | &hellip; |
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.
5461 *** Agenda
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
5479       this issue.
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
5490       possible.
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.
5497 * Version 5.13i
5499 ** Details
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
5514      files.
5516    - Bug fixes.
5518 * Version 5.13
5520 ** Overview
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
5539    - Other stuff
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.
5546 ** Details
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:
5564       : * Planning
5565       :   :PROPERTIES:
5566       :     :ID: planning-overview
5567       :   :END:
5568       :
5569       : [...]
5570       :
5571       : * The column view
5572       : #+BEGIN: columnview :hlines 1 :id "planning-overview"
5573       :
5574       : #+END:
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
5584       ITEM column.
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
5612       Adam Spiers.
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
5623       property.
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.
5646 *** Other stuff
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
5651       frame.
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.
5684 * Version 5.12
5686 ** Overview
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'.
5704 ** Details
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
5746      this proposal.
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.
5753    - Bug fixes
5755 * Version 5.11
5757 ** Overview
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.
5783    - The variable
5784      `org-insert-labeled-timestamps-before-properties-drawer'
5785      is now obsolete.
5787 ** Details
5789    - The LOGGING property allows to modify the settings for
5790      progress logging for a single entry.  For example:
5792      : :PROPERTIES:
5793      :   :LOGGING: nologging nologrepeat
5794      : :END:
5796      turns off all progress logging for the current entry and its
5797      children.
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
5849      with S-left/right.
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'.
5864    - Bug fixes
5866 * Version 5.10
5868 ** Overview
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'.
5879    - Bug fixes.
5881 ** Details
5883    - Both the category and the archive location in a (sub)tree of
5884      the buffer can now be specified using a property, for
5885      example:
5887      : * Tree with special properties
5888      :   :PROPERTIES:
5889      :     :CATEGORY: Examples
5890      :     :ARCHIVE:  /some/special/file::
5891      :   :END:
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
5906      values are:
5908      | value   | scope                                           |
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
5921      features.
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
5935      example:
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
5953      Bastien.
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.
5978    - Bug fixes.
5980 * Version 5.09
5982 ** Overview
5984    - Taking a note upon TODO state changes can be restricted to
5985      selected states.
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
6008      thing to do.
6010 ** Details
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
6019      and a note.
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
6046      Rick Moynihan.
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.
6066 * Version 5.08
6068 ** Incompatible changes
6070    - The default for `org-deadline-warning-days' is now 14.
6072 ** Details
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.
6123 * Version 5.07
6125 ** Overview
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.
6148 ** Details
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
6160      :                    :underline t))))
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
6185      example,
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
6206      an option.
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.
6213    - Bug fixes.
6215 * Version 5.06
6217 ** Overview
6219 ** Details
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
6229      for these ideas.
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
6242      region.
6244    - When Org-mode visits a file, it will initially hide all
6245      drawers.
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.
6255 * Version 5.05
6257 ** Overview
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.
6275    - Bug fixes.
6278 ** Details
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
6296      export/publishing.
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
6302      excellent idea.
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
6311      first:
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
6320      this direction.
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
6326      proposal.
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
6334      Wiegley.
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
6339      function.
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.
6359    - Bug fixes.
6361 * Version 5.04
6363 ** Details
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.
6383 * Version 5.03
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).
6391 ** Details
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.
6410   - Bug fixes.
6413 * Version 5.02
6415 ** Overview
6417    - The interfaces for properties and column view are finished
6418      now and work well.
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
6425      longer there.
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
6433      not column view.
6435 ** Details
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
6452        value to the next.
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
6458        checked.
6460      + There are interactive commands to add and remove columns,
6461        and to change the attributes of a column like the summary
6462        type.
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.
6478 * Version 5.01
6480 ** Overview
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
6493      now).
6495    - Formula evaluation in the spreadsheet is more consistent
6496      now.  Properties and per-file constants can be used during
6497      evaluation.
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.
6510 ** Details
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.
6533 *** Drawers
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,
6540     after setting
6542     :   (setq org-drawers '("PROPERTIES" "HIDDEN"))
6544     you can then create drawers like this:
6546     :   :HIDDEN:
6547     :     here is some stuff that remains hidden
6548     :     unless TAB is pressed directly in that line
6549     :   :END:
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
6571       properties drawer.
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,
6581       the search
6583       :   LEVEL=3+BOSS+ASSIGNED="Hans"/WAITING
6585       will find entries that
6586       - are level 3
6587       - have the tag BOSS
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:
6594         :       :PROPERTIES:
6595         :       :ASSIGNED: Hans
6596         :       :END:
6598         You may also use a regular expression to match against a
6599         property value.  For example, to find stuff assigned to Hans
6600         or Sarah, use
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:
6614       :   * People
6615       :     :PROPERTIES:
6616       :     :COLUMNS: %25ITEM %Name
6617       :     :END:
6618       :   ** Family
6619       :      :PROPERTIES:
6620       :      :COLUMNS: %25ITEM %Name %3Age
6621       :      :END:
6622       :   *** Sam
6623       :       Info about Sam, including a property list with Name and Age.
6624       :   *** Sarah
6625       :       Info about Sarah, including a property list with Name and Age.
6626       :   ** Office
6627       :      :PROPERTIES:
6628       :      :COLUMNS: %25ITEM %Name %Function %Salary
6629       :      :END:
6630       :   *** Boss
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
6640       /Name/.
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
6654       welcome!
6656       + How to deal with drawers and properties in HTML and ASCII
6657         export?
6658       + What key could be used to insert an empty property drawer
6659         into an entry?
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
6663         key?
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
6668         org-mouse.el?
6670 *** Spreadsheet
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
6679       formula.
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.
6687       Here is an example
6689       :   | 1 |
6690       :   | 2 |
6691       :   | 3 |
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
6700 *** Minor changes
6702     - When entries are archived, a timestamp for the moment of
6703       archiving is added to the line with planning information.
6704       It looks like this:
6706       : ARCHIVED: [2007-07-02 Mon 11:34]
6708       Thanks to J. David Boyd for constructive comments.
6710     - Bug fixes
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!
6718 * Version 4.79
6720 ** Details
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'.
6738    - Bug fixes:
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)
6746 * Version 4.78
6748 ** Overview
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.
6776 ** Details
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
6790      Michael.
6792    - You may specify clocking times by hand (i.e. without
6793      clocking in and out) using this syntax.
6795      : CLOCK: => 2:00
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
6834        : - item 1
6835        : - item 2
6836        : + item 2a
6837        : + item 2b
6838        : - item 3
6840        When using TAB on every line in this list, the structure
6841        will change to
6843        : - item 1
6844        : - item 2
6845        :   + item 2a
6846        :   + item 2b
6847        :     - item 3
6849        So you need to change the level of the last line by hand,
6850        using promotion and demotion functions.
6852 * Version 4.77
6854 ** Overview
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.
6863 ** Details
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
6886      groups.
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.
6918 * Version 4.76
6920 ** Overview
6922    - Exporting Footnotes to HTML
6924 ** Details
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
6937      started.
6939    - Bug fixes, lots of them again.
6941 * Version 4.75
6943 ** Overview
6945    - Cyclic time stamps that repeat after an interval.
6946    - Special timestamps for appointments like "every 2nd Thursday
6947      in a month".
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.
6958 ** Details
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
6981        #+CATEGORY: Holiday
6982        %%(org-calendar-holiday) ; special function for holiday names
6983        #+CATEGORY: Ann
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
7007      Bastien.
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
7013        #+PRIORITIES: 1 9 9
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
7024      your private setup:
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
7041      coming.
7043 * Version 4.74
7045 ** Overview
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'.
7056 ** Details
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
7062      manual.
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.
7084 * Version 4.73
7086   Minor bug fixes.
7088 * Version 4.72
7090 ** Overview
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.
7106    - Bug fixes.
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
7112      your customization.
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.
7123 ** Details
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
7168      changes.
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
7176      this.
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.
7191 * Version 4.71
7193 ** Overview
7195 ** Incompatible changes
7197 ** Details
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
7203     Scott Otterson.
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.
7216   - Many bug fixes.
7218 * Version 4.70
7220 ** Overview
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.
7230 ** Details
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.
7260            ))
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
7273       out this omission.
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 |
7300 * Version 4.69
7302 ** Overview
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.
7312    - Bug fixes.
7314 ** Incompatible changes
7316    - It used to be possible to spread the list of TODO keywords
7317      over several lines, like
7319      #+SEQ_TODO: TODO
7320      #+SEQ_TODO: PROGRESS
7321      #+SEQ_TODO: DONE
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
7331      the exported file.
7333 ** Details
7335    - You can now use multiple sets of TODO keywords in the same
7336      buffer.  For example, you may put the following three lines
7337      into a file:
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
7353      REPORT.
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
7368      #+OPTION: skip:nil
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 '{})
7382      or by using
7384            #+OPTIONS: ^:{}
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
7398      this proposal.
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.
7408 * Version 4.68
7410 ** Overview
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.
7416    - Bug fixes
7418 ** Details
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
7443        internal format.
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.
7460    - Bug fixes
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
7468        in tags....
7470 * Version 4.67
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.
7481    - Code cleanup
7483    - Bug fixes
7485 * Version 4.66
7487 ** Overview
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
7522      entry.
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
7531      first 3 levels.
7533    - Bug fixes.
7535 * Version 4.65
7537 ** Overview
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
7569      the compact form.
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.
7589 * Version 4.64
7591 ** Overview
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
7638          (Leo's idea).
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?
7668 * Version 4.63
7669    - Bug fixes
7671 * Version 4.62
7672    - Many changes to the spreadsheet functions in the table editor.
7673      For details, please re-read the manual section 3.4.
7674      + New Features
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.
7687    - Bug fixes.
7689 * Version 4.61
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.
7698    - More bug fixes.
7700 * Version 4.60
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.
7709    - Bug fixes.
7712 * Version 4.59
7713    - Cleanup code, bug fixes.
7715 * Version 4.58
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.
7724 * Version 4.57
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.
7738    - Bug fixes.
7740 * Version 4.56
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.
7744    - Bug fixes.
7746 * Version 4.55
7747    - Bug fixes.
7749 * Version 4.54
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'.
7755    - Bug fixes.
7757 * Version 4.53
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.
7762    - Bug fixes.
7764 * Version 4.52
7765    - TAG matches can also specify conditions on TODO keywords.
7766    - The fast tag interface allows setting tags that are not in the
7767      predefined list.
7768    - Bug fixes.
7770 * Version 4.51
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'.
7774    - Bug fixes.
7776 * Version 4.50
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.
7788    - Bug fixes.
7791 * Version 4.49
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.
7796    - Bug fixes.
7798 * Version 4.47
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.
7816 * Version 4.45
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.
7820    - Bux fixes.
7822 * Version 4.44
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.
7827 * Version 4.43
7828    - Bug fixes
7829    - `s' key in the agenda saves all org-mode buffers.
7831 * Version 4.41
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.
7835    - Bug fixes.
7837 * Version 4.40
7838    - Bug fixes.
7841 * Version 4.39
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.
7844    - Bug fixes.
7845    - CDLaTeX-mode features can be used in Org-mode to help inserting
7846      LaTeX environment and math.
7848 * Version 4.38
7849    - noutline.el is now required (important for XEmacs users only).
7850    - Dynamic blocks.
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.
7854    - Bug fixes.
7856 * Version 4.37
7857    - Clock-feature for measuring time spent on specific items.
7858    - Improved emphasizing allows configuration and stacking.
7860 * Version 4.36
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.
7865    - Bug fixes.
7867 * Version 4.35
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.
7876 * Version 4.34
7877    - Bug fixes.
7879 * Version 4.33
7880    - New commands to move through plain lists: S-up and S-down.
7881    - Bug fixes and documentation update.
7883 * Version 4.32
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'.
7891    - Bug fixes.
7893 * Version 4.31
7894    - Bug fixes.
7896 * Version 4.30
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.
7908 * Version 4.29
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 :-(
7919 * Version 4.28
7920    - Bug fixes.
7922 * Version 4.27
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.
7931 * Version 4.26
7932    - Bug fixes.
7934 * Version 4.25
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.
7940 * Version 4.24
7941    - Bug fixes.
7943 * Version 4.23
7944    - Bug fixes.
7946 * Version 4.22
7947    - Bug fixes.
7948    - In agenda buffer, mouse-1 no longer follows link.
7949      See `org-agenda-mouse-1-follows-link' and `org-mouse-1-follows-link'.
7951 * Version 4.20
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.
7959    - Bug fixes.
7962 * Version 4.13
7963    - The list of agenda files can be maintainted in an external file.
7964    - Bug fixes.
7966 * Version 4.12
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).
7973 [...]
7975 Version 4.00
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.
7982 * Version 3.24
7983    - Switching and item to DONE records a time stamp when the variable
7984      `org-log-done' is turned on.  Default is off.
7986 * Version 3.23
7987    - M-RET makes new items as well as new headings.
7988    - Various small bug fixes
7990 * Version 3.22
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).
8001 * Version 3.21
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
8007 * Version 3.20
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.
8022 * Version 3.19
8023    - Bug fixes
8025 * Version 3.18
8026    - Export of calendar information in the standard iCalendar format.
8027    - Some bug fixes.
8029 * Version 3.17
8030    - HTML export specifies character set depending on coding-system.
8032 * Version 3.16
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).
8043 * Version 3.15
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.
8050 * Version 3.14
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.
8056 * Version 3.13
8057    - Efficiency improvements:  Fewer table re-alignments needed.
8058    - New special lines in tables, for defining names for individual cells.
8060 * Version 3.12
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.
8067    - Bug fixes.
8069 * Version 3.11
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.
8081 * Version 3.10
8082    - Using `define-derived-mode' to derive `org-mode' from `outline-mode'.
8085 * Version 3.09
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
8088      day.
8090 * Version 3.08
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.
8093    - Cleanup.
8095 * Version 3.07
8096    - Some folding inconsistencies removed.
8097    - BBDB links to company-only entries.
8098    - Bug fixes and global cleanup.
8100 * Version 3.06
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'.
8107 * Version 3.05
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.
8115 * Version 3.04
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.
8124 * Version 3.03
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.
8128    - Table editor:
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)
8134    - Agenda:
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 `#-'.
8139    - Bug fixes.
8141 * Version 3.01
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.
8150 * Version 3.00
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
8159    - Minor bug fixes.
8162 * Version 2.10
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'.
8179 * Version 2.6
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'.
8193 * Version 2.4
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.
8205 * Version 2.0
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.
8218    - Timestamp changes
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
8225        is not recommended.
8226    - Picture mode enhancements have been removed from org.el
8229 * Version 1.4
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.
8234    - Calendar support.
8236 * Version 1.3
8237    - HTML exporter upgrade, in particular table of contents
8241