Browse Source

Implement outline-path-completion in one go.

Carsten Dominik 17 years ago
parent
commit
74e7111a5f
3 changed files with 31 additions and 8 deletions
  1. 5 3
      doc/org.texi
  2. 6 0
      lisp/ChangeLog
  3. 20 5
      lisp/org.el

+ 5 - 3
doc/org.texi

@@ -868,6 +868,7 @@ u            @r{One level up.}
 0-9          @r{Digit argument.}
 0-9          @r{Digit argument.}
 q            @r{Quit}
 q            @r{Quit}
 @end example
 @end example
+See also the variable@code{org-goto-interface}.
 @end table
 @end table
 
 
 @node Structure editing, Archiving, Motion, Document Structure
 @node Structure editing, Archiving, Motion, Document Structure
@@ -5206,13 +5207,14 @@ special command:
 Refile the entry or region at point.  This command offers possible locations
 Refile the entry or region at point.  This command offers possible locations
 for refiling the entry and lets you select one with completion.  The item (or
 for refiling the entry and lets you select one with completion.  The item (or
 all items in the region) is filed below the target heading as a subitem.
 all items in the region) is filed below the target heading as a subitem.
-Depending on @code{org-reverse-note-order}, it will be either the first of
+Depending on @code{org-reverse-note-order}, it will be either the first or
 last subitem.@*
 last subitem.@*
 By default, all level 1 headlines in the current buffer are considered to be
 By default, all level 1 headlines in the current buffer are considered to be
 targets, but you can have more complex definitions across a number of files.
 targets, but you can have more complex definitions across a number of files.
 See the variable @code{org-refile-targets} for details.  If you would like to
 See the variable @code{org-refile-targets} for details.  If you would like to
-select a location via a file-pathlike completion along the outline path, see
-the variable @code{org-refile-use-outline-path}.
+select a location via a file-path-like completion along the outline path, see
+the variables @code{org-refile-use-outline-path} and
+@code{org-outline-path-complete-in-steps}.
 @kindex C-u C-c C-w
 @kindex C-u C-c C-w
 @item C-u C-c C-w
 @item C-u C-c C-w
 Use the refile interface to jump to a heading.
 Use the refile interface to jump to a heading.

+ 6 - 0
lisp/ChangeLog

@@ -1,3 +1,9 @@
+2008-11-24  Carsten Dominik  <carsten.dominik@gmail.com>
+
+	* org.el (org-outline-path-complete-in-steps): New option.
+	(org-refile-get-location): Honor
+	`org-outline-path-complete-in-steps'.
+
 2008-11-23  Carsten Dominik  <carsten.dominik@gmail.com>
 2008-11-23  Carsten Dominik  <carsten.dominik@gmail.com>
 
 
 	* org-clock.el (org-dblock-write:clocktable): Make sure the
 	* org-clock.el (org-dblock-write:clocktable): Make sure the

+ 20 - 5
lisp/org.el

@@ -1245,7 +1245,7 @@ For more examples, see the system specific constants
 
 
 (defgroup org-refile nil
 (defgroup org-refile nil
   "Options concerning refiling entries in Org-mode."
   "Options concerning refiling entries in Org-mode."
-  :tag "Org Remember"
+  :tag "Org Refile"
   :group 'org)
   :group 'org)
 
 
 (defcustom org-directory "~/org"
 (defcustom org-directory "~/org"
@@ -1275,7 +1275,8 @@ outline                  The interface shows an outline of the relevant file
                          and the correct heading is found by moving through
                          and the correct heading is found by moving through
                          the outline or by searching with incremental search.
                          the outline or by searching with incremental search.
 outline-path-completion  Headlines in the current buffer are offered via
 outline-path-completion  Headlines in the current buffer are offered via
-                         completion."
+                         completion.  This is the interface also used by
+                         the refile command."
   :group 'org-refile
   :group 'org-refile
   :type '(choice
   :type '(choice
 	  (const :tag "Outline" outline)
 	  (const :tag "Outline" outline)
@@ -1287,6 +1288,7 @@ When nil, new notes will be filed to the end of a file or entry.
 This can also be a list with cons cells of regular expressions that
 This can also be a list with cons cells of regular expressions that
 are matched against file names, and values."
 are matched against file names, and values."
   :group 'org-remember
   :group 'org-remember
+  :group 'org-refile
   :type '(choice
   :type '(choice
 	  (const :tag "Reverse always" t)
 	  (const :tag "Reverse always" t)
 	  (const :tag "Reverse never" nil)
 	  (const :tag "Reverse never" nil)
@@ -1314,7 +1316,7 @@ This is list of cons cells.  Each cell contains:
 
 
 When this variable is nil, all top-level headlines in the current buffer
 When this variable is nil, all top-level headlines in the current buffer
 are used, equivalent to the value `((nil . (:level . 1))'."
 are used, equivalent to the value `((nil . (:level . 1))'."
-  :group 'org-remember
+  :group 'org-refile
   :type '(repeat
   :type '(repeat
 	  (cons
 	  (cons
 	   (choice :value org-agenda-files
 	   (choice :value org-agenda-files
@@ -1333,13 +1335,25 @@ are used, equivalent to the value `((nil . (:level . 1))'."
 So a level 3 headline will be available as level1/level2/level3.
 So a level 3 headline will be available as level1/level2/level3.
 When the value is `file', also include the file name (without directory)
 When the value is `file', also include the file name (without directory)
 into the path.  When `full-file-path', include the full file path."
 into the path.  When `full-file-path', include the full file path."
-  :group 'org-remember
+  :group 'org-refile
   :type '(choice
   :type '(choice
 	  (const :tag "Not" nil)
 	  (const :tag "Not" nil)
 	  (const :tag "Yes" t)
 	  (const :tag "Yes" t)
 	  (const :tag "Start with file name" file)
 	  (const :tag "Start with file name" file)
 	  (const :tag "Start with full file path" full-file-path)))
 	  (const :tag "Start with full file path" full-file-path)))
 
 
+(defcustom org-outline-path-complete-in-steps t
+  "Non-nil means, complete the outline path in hierarchical steps.
+When Org-mode uses the refile interface to select an outline path
+\(see variable `org-refile-use-outline-path'), the completion of
+the path can be done is a single go, or if can be done in steps down
+the headline hierarchy.  Going in steps is probably the best if you
+do not use a special completion package like `ido' or `icicles'.
+However, when using these packages, going in one step can be very
+fast, while still showing the whole path to the entry."
+  :group 'org-refile
+  :type 'boolean)
+
 (defgroup org-todo nil
 (defgroup org-todo nil
   "Options concerning TODO items in Org-mode."
   "Options concerning TODO items in Org-mode."
   :tag "Org TODO"
   :tag "Org TODO"
@@ -7504,7 +7518,8 @@ operation has put the subtree."
   (unless org-refile-target-table
   (unless org-refile-target-table
     (error "No refile targets"))
     (error "No refile targets"))
   (let* ((cbuf (current-buffer))
   (let* ((cbuf (current-buffer))
-	 (cfunc (if org-refile-use-outline-path
+	 (cfunc (if (and org-refile-use-outline-path
+			 org-outline-path-complete-in-steps)
 		    'org-olpath-completing-read
 		    'org-olpath-completing-read
 		  'org-ido-completing-read))
 		  'org-ido-completing-read))
 	 (extra (if org-refile-use-outline-path "/" ""))
 	 (extra (if org-refile-use-outline-path "/" ""))