| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706 | 
							- ;;; org-capture.el --- Fast note taking in Org-mode
 
- ;; Copyright (C) 2010-2013 Free Software Foundation, Inc.
 
- ;; Author: Carsten Dominik <carsten at orgmode dot org>
 
- ;; Keywords: outlines, hypermedia, calendar, wp
 
- ;; Homepage: http://orgmode.org
 
- ;;
 
- ;; This file is part of GNU Emacs.
 
- ;;
 
- ;; GNU Emacs is free software: you can redistribute it and/or modify
 
- ;; it under the terms of the GNU General Public License as published by
 
- ;; the Free Software Foundation, either version 3 of the License, or
 
- ;; (at your option) any later version.
 
- ;; GNU Emacs is distributed in the hope that it will be useful,
 
- ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
 
- ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
- ;; GNU General Public License for more details.
 
- ;; You should have received a copy of the GNU General Public License
 
- ;; along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.
 
- ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 
- ;;
 
- ;;; Commentary:
 
- ;; This file contains an alternative implementation of the same functionality
 
- ;; that is also provided by org-remember.el.  The implementation is more
 
- ;; streamlined, can produce more target types (e.g. plain list items or
 
- ;; table lines).  Also, it does not use a temporary buffer for editing
 
- ;; the captured entry - instead it uses an indirect buffer that visits
 
- ;; the new entry already in the target buffer (this was an idea by Samuel
 
- ;; Wales).  John Wiegley's excellent `remember.el' is not needed for this
 
- ;; implementation, even though we borrow heavily from its ideas.
 
- ;; This implementation heavily draws on ideas by James TD Smith and
 
- ;; Samuel Wales, and, of cause, uses John Wiegley's remember.el as inspiration.
 
- ;;; TODO
 
- ;; - find a clever way to not always insert an annotation maybe a
 
- ;;   predicate function that can check for conditions for %a to be
 
- ;;   used.  This could be one of the properties.
 
- ;; - Should there be plist members that arrange for properties to be
 
- ;;   asked for, like James proposed in his RFC?
 
- ;;; Code:
 
- (eval-when-compile
 
-   (require 'cl))
 
- (require 'org)
 
- (require 'org-mks)
 
- (declare-function org-datetree-find-date-create "org-datetree"
 
- 		  (date &optional keep-restriction))
 
- (declare-function org-table-get-specials "org-table" ())
 
- (declare-function org-table-goto-line "org-table" (N))
 
- (declare-function org-pop-to-buffer-same-window "org-compat"
 
- 		  (&optional buffer-or-name norecord label))
 
- (declare-function org-at-encrypted-entry-p "org-crypt" ())
 
- (declare-function org-encrypt-entry "org-crypt" ())
 
- (declare-function org-decrypt-entry "org-crypt" ())
 
- (defvar org-remember-default-headline)
 
- (defvar org-remember-templates)
 
- (defvar org-table-hlines)
 
- (defvar dired-buffers)
 
- (defvar org-capture-clock-was-started nil
 
-   "Internal flag, noting if the clock was started.")
 
- (defvar org-capture-last-stored-marker (make-marker)
 
-   "Marker pointing to the entry most recently stored with `org-capture'.")
 
- ;; The following variable is scoped dynamically by org-protocol
 
- ;; to indicate that the link properties have already been stored
 
- (defvar org-capture-link-is-already-stored nil)
 
- (defgroup org-capture nil
 
-   "Options concerning capturing new entries."
 
-   :tag "Org Capture"
 
-   :group 'org)
 
- (defcustom org-capture-templates nil
 
-   "Templates for the creation of new entries.
 
- Each entry is a list with the following items:
 
- keys         The keys that will select the template, as a string, characters
 
-              only, for example \"a\" for a template to be selected with a
 
-              single key, or \"bt\" for selection with two keys.  When using
 
-              several keys, keys using the same prefix key must be together
 
-              in the list and preceded by a 2-element entry explaining the
 
-              prefix key, for example
 
-                      (\"b\" \"Templates for marking stuff to buy\")
 
-              The \"C\" key is used by default for quick access to the
 
-              customization of the template variable.  But if you want to use
 
-              that key for a template, you can.
 
- description  A short string describing the template, will be shown during
 
-              selection.
 
- type         The type of entry.  Valid types are:
 
-                entry       an Org-mode node, with a headline.  Will be
 
-                            filed as the child of the target entry or as
 
-                            a top-level entry.
 
-                item        a plain list item, will be placed in the
 
-                            first plain list at the target
 
-                            location.
 
-                checkitem   a checkbox item.  This differs from the
 
-                            plain list item only is so far as it uses a
 
-                            different default template.
 
-                table-line  a new line in the first table at target location.
 
-                plain       text to be inserted as it is.
 
- target       Specification of where the captured item should be placed.
 
-              In Org-mode files, targets usually define a node.  Entries will
 
-              become children of this node, other types will be added to the
 
-              table or list in the body of this node.
 
-              Most target specifications contain a file name.  If that file
 
-              name is the empty string, it defaults to `org-default-notes-file'.
 
-              A file can also be given as a variable, function, or Emacs Lisp
 
-              form.
 
-              Valid values are:
 
-              (file \"path/to/file\")
 
-                  Text will be placed at the beginning or end of that file
 
-              (id \"id of existing org entry\")
 
-                  File as child of this entry, or in the body of the entry
 
-              (file+headline \"path/to/file\" \"node headline\")
 
-                  Fast configuration if the target heading is unique in the file
 
-              (file+olp \"path/to/file\" \"Level 1 heading\" \"Level 2\" ...)
 
-                  For non-unique headings, the full path is safer
 
-              (file+regexp  \"path/to/file\" \"regexp to find location\")
 
-                  File to the entry matching regexp
 
-              (file+datetree \"path/to/file\")
 
-                  Will create a heading in a date tree for today's date
 
-              (file+datetree+prompt \"path/to/file\")
 
-                  Will create a heading in a date tree, prompts for date
 
-              (file+function \"path/to/file\" function-finding-location)
 
-                  A function to find the right location in the file
 
-              (clock)
 
-                 File to the entry that is currently being clocked
 
-              (function function-finding-location)
 
-                 Most general way, write your own function to find both
 
-                 file and location
 
- template     The template for creating the capture item.  If you leave this
 
-              empty, an appropriate default template will be used.  See below
 
-              for more details.  Instead of a string, this may also be one of
 
-                  (file \"/path/to/template-file\")
 
-                  (function function-returning-the-template)
 
-              in order to get a template from a file, or dynamically
 
-              from a function.
 
- The rest of the entry is a property list of additional options.  Recognized
 
- properties are:
 
-  :prepend            Normally newly captured information will be appended at
 
-                      the target location (last child, last table line,
 
-                      last list item...).  Setting this property will
 
-                      change that.
 
-  :immediate-finish   When set, do not offer to edit the information, just
 
-                      file it away immediately.  This makes sense if the
 
-                      template only needs information that can be added
 
-                      automatically.
 
-  :empty-lines        Set this to the number of lines the should be inserted
 
-                      before and after the new item.  Default 0, only common
 
-                      other value is 1.
 
-  :empty-lines-before Set this to the number of lines the should be inserted
 
-                      before the new item.  Overrides :empty-lines for the
 
-                      number lines inserted before.
 
-  :empty-lines-after  Set this to the number of lines the should be inserted
 
-                      after the new item.  Overrides :empty-lines for the
 
-                      number of lines inserted after.
 
-  :clock-in           Start the clock in this item.
 
-  :clock-keep         Keep the clock running when filing the captured entry.
 
-  :clock-resume       Start the interrupted clock when finishing the capture.
 
-                      Note that :clock-keep has precedence over :clock-resume.
 
-                      When setting both to `t', the current clock will run and
 
-                      the previous one will not be resumed.
 
-  :unnarrowed         Do not narrow the target buffer, simply show the
 
-                      full buffer.  Default is to narrow it so that you
 
-                      only see the new stuff.
 
-  :table-line-pos     Specification of the location in the table where the
 
-                      new line should be inserted.  It should be a string like
 
-                      \"II-3\", meaning that the new line should become the
 
-                      third line before the second horizontal separator line.
 
-  :kill-buffer        If the target file was not yet visited by a buffer when
 
-                      capture was invoked, kill the buffer again after capture
 
-                      is finalized.
 
- The template defines the text to be inserted.  Often this is an
 
- org-mode entry (so the first line should start with a star) that
 
- will be filed as a child of the target headline.  It can also be
 
- freely formatted text.  Furthermore, the following %-escapes will
 
- be replaced with content and expanded in this order:
 
-   %[pathname] Insert the contents of the file given by `pathname'.
 
-   %(sexp)     Evaluate elisp `(sexp)' and replace it with the results.
 
-               For convenience, %:keyword (see below) placeholders within
 
-               the expression will be expanded prior to this.
 
-   %<...>      The result of format-time-string on the ... format specification.
 
-   %t          Time stamp, date only.
 
-   %T          Time stamp with date and time.
 
-   %u, %U      Like the above, but inactive time stamps.
 
-   %i          Initial content, copied from the active region.  If %i is
 
-               indented, the entire inserted text will be indented as well.
 
-   %a          Annotation, normally the link created with `org-store-link'.
 
-   %A          Like %a, but prompt for the description part.
 
-   %l          Like %a, but only insert the literal link.
 
-   %c          Current kill ring head.
 
-   %x          Content of the X clipboard.
 
-   %k          Title of currently clocked task.
 
-   %K          Link to currently clocked task.
 
-   %n          User name (taken from `user-full-name').
 
-   %f          File visited by current buffer when org-capture was called.
 
-   %F          Full path of the file or directory visited by current buffer.
 
-   %:keyword   Specific information for certain link types, see below.
 
-   %^g         Prompt for tags, with completion on tags in target file.
 
-   %^G         Prompt for tags, with completion on all tags in all agenda files.
 
-   %^t         Like %t, but prompt for date.  Similarly %^T, %^u, %^U.
 
-               You may define a prompt like: %^{Please specify birthday}t
 
-   %^C         Interactive selection of which kill or clip to use.
 
-   %^L         Like %^C, but insert as link.
 
-   %^{prop}p   Prompt the user for a value for property `prop'.
 
-   %^{prompt}  Prompt the user for a string and replace this sequence with it.
 
-               A default value and a completion table ca be specified like this:
 
-               %^{prompt|default|completion2|completion3|...}.
 
-   %?          After completing the template, position cursor here.
 
-   %\\n         Insert the text entered at the nth %^{prompt}, where `n' is
 
-               a number, starting from 1.
 
- Apart from these general escapes, you can access information specific to
 
- the link type that is created.  For example, calling `org-capture' in emails
 
- or in Gnus will record the author and the subject of the message, which you
 
- can access with \"%:from\" and \"%:subject\", respectively.  Here is a
 
- complete list of what is recorded for each link type.
 
- Link type               |  Available information
 
- ------------------------+------------------------------------------------------
 
- bbdb                    |  %:type %:name %:company
 
- vm, wl, mh, mew, rmail, |  %:type %:subject %:message-id
 
- gnus                    |  %:from %:fromname %:fromaddress
 
-                         |  %:to   %:toname   %:toaddress
 
-                         |  %:fromto (either \"to NAME\" or \"from NAME\")
 
-                         |  %:date %:date-timestamp (as active timestamp)
 
-                         |  %:date-timestamp-inactive (as inactive timestamp)
 
- gnus                    |  %:group, for messages also all email fields
 
- w3, w3m                 |  %:type %:url
 
- info                    |  %:type %:file %:node
 
- calendar                |  %:type %:date"
 
-   :group 'org-capture
 
-   :version "24.1"
 
-   :type
 
-   '(repeat
 
-     (choice :value ("" "" entry (file "~/org/notes.org") "")
 
- 	    (list :tag "Multikey description"
 
- 		  (string :tag "Keys       ")
 
- 		  (string :tag "Description"))
 
- 	    (list :tag "Template entry"
 
- 		  (string :tag "Keys           ")
 
- 		  (string :tag "Description    ")
 
- 		  (choice :tag "Capture Type   " :value entry
 
- 			  (const :tag "Org entry" entry)
 
- 			  (const :tag "Plain list item" item)
 
- 			  (const :tag "Checkbox item" checkitem)
 
- 			  (const :tag "Plain text" plain)
 
- 			  (const :tag "Table line" table-line))
 
- 		  (choice :tag "Target location"
 
- 			  (list :tag "File"
 
- 				(const :format "" file)
 
- 				(file :tag "  File"))
 
- 			  (list :tag "ID"
 
- 				(const :format "" id)
 
- 				(string :tag "  ID"))
 
- 			  (list :tag "File & Headline"
 
- 				(const :format "" file+headline)
 
- 				(file   :tag "  File    ")
 
- 				(string :tag "  Headline"))
 
- 			  (list :tag "File & Outline path"
 
- 				(const :format "" file+olp)
 
- 				(file   :tag "  File    ")
 
- 				(repeat :tag "Outline path" :inline t
 
- 					(string :tag "Headline")))
 
- 			  (list :tag "File & Regexp"
 
- 				(const :format "" file+regexp)
 
- 				(file   :tag "  File  ")
 
- 				(regexp :tag "  Regexp"))
 
- 			  (list :tag "File & Date tree"
 
- 				(const :format "" file+datetree)
 
- 				(file :tag "  File"))
 
- 			  (list :tag "File & Date tree, prompt for date"
 
- 				(const :format "" file+datetree+prompt)
 
- 				(file :tag "  File"))
 
- 			  (list :tag "File & function"
 
- 				(const :format "" file+function)
 
- 				(file :tag "  File    ")
 
- 				(sexp :tag "  Function"))
 
- 			  (list :tag "Current clocking task"
 
- 				(const :format "" clock))
 
- 			  (list :tag "Function"
 
- 				(const :format "" function)
 
- 				(sexp :tag "  Function")))
 
- 		  (choice :tag "Template"
 
- 			  (string)
 
- 			  (list :tag "File"
 
- 				(const :format "" file)
 
- 				(file :tag "Template file"))
 
- 			  (list :tag "Function"
 
- 				(const :format "" function)
 
- 				(function :tag "Template function")))
 
- 		  (plist :inline t
 
- 			 ;; Give the most common options as checkboxes
 
- 			 :options (((const :format "%v " :prepend) (const t))
 
- 				   ((const :format "%v " :immediate-finish) (const t))
 
- 				   ((const :format "%v " :empty-lines) (const 1))
 
- 				   ((const :format "%v " :clock-in) (const t))
 
- 				   ((const :format "%v " :clock-keep) (const t))
 
- 				   ((const :format "%v " :clock-resume) (const t))
 
- 				   ((const :format "%v " :unnarrowed) (const t))
 
- 				   ((const :format "%v " :kill-buffer) (const t))))))))
 
- (defcustom org-capture-before-finalize-hook nil
 
-   "Hook that is run right before a capture process is finalized.
 
- The capture buffer is still current when this hook runs and it is
 
- widened to the entire buffer."
 
-   :group 'org-capture
 
-   :version "24.1"
 
-   :type 'hook)
 
- (defcustom org-capture-after-finalize-hook nil
 
-   "Hook that is run right after a capture process is finalized.
 
- Suitable for window cleanup."
 
-   :group 'org-capture
 
-   :version "24.1"
 
-   :type 'hook)
 
- (defcustom org-capture-prepare-finalize-hook nil
 
-   "Hook that is run before the finalization starts.
 
- The capture buffer is current and still narrowed."
 
-   :group 'org-capture
 
-   :version "24.1"
 
-   :type 'hook)
 
- (defcustom org-capture-bookmark t
 
-   "When non-nil, add a bookmark pointing at the last stored
 
- position when capturing."
 
-   :group 'org-capture
 
-   :version "24.3"
 
-   :type 'boolean)
 
- ;;; The property list for keeping information about the capture process
 
- (defvar org-capture-plist nil
 
-   "Plist for the current capture process, global, to avoid having to pass it.")
 
- (defvar org-capture-current-plist nil
 
-   "Local variable holding the plist in a capture buffer.
 
- This is used to store the plist for use when finishing a capture process
 
- because another such process might have changed the global variable by then.
 
- Each time a new capture buffer has been set up, the global `org-capture-plist'
 
- is copied to this variable, which is local in the indirect buffer.")
 
- (defvar org-capture-clock-keep nil
 
-   "Local variable to store the value of the :clock-keep parameter.
 
- This is needed in case org-capture-finalize is called interactively.")
 
- (defun org-capture-put (&rest stuff)
 
-   "Add properties to the capture property list `org-capture-plist'."
 
-   (while stuff
 
-     (setq org-capture-plist (plist-put org-capture-plist
 
- 				       (pop stuff) (pop stuff)))))
 
- (defun org-capture-get (prop &optional local)
 
-   "Get properties from the capture property list `org-capture-plist'.
 
- When LOCAL is set, use the local variable `org-capture-current-plist',
 
- this is necessary after initialization of the capture process,
 
- to avoid conflicts with other active capture processes."
 
-   (plist-get (if local org-capture-current-plist org-capture-plist) prop))
 
- (defun org-capture-member (prop &optional local)
 
-   "Is PROP a property in `org-capture-plist'.
 
- When LOCAL is set, use the local variable `org-capture-current-plist',
 
- this is necessary after initialization of the capture process,
 
- to avoid conflicts with other active capture processes."
 
-   (plist-get (if local org-capture-current-plist org-capture-plist) prop))
 
- ;;; The minor mode
 
- (defvar org-capture-mode-map (make-sparse-keymap)
 
-   "Keymap for `org-capture-mode', a minor mode.
 
- Use this map to set additional keybindings for when Org-mode is used
 
- for a capture buffer.")
 
- (defvar org-capture-mode-hook nil
 
-   "Hook for the minor `org-capture-mode'.")
 
- (define-minor-mode org-capture-mode
 
-   "Minor mode for special key bindings in a capture buffer.
 
- Turning on this mode runs the normal hook `org-capture-mode-hook'."
 
-   nil " Rem" org-capture-mode-map
 
-   (org-set-local
 
-    'header-line-format
 
-    "Capture buffer.  Finish `C-c C-c', refile `C-c C-w', abort `C-c C-k'."))
 
- (define-key org-capture-mode-map "\C-c\C-c" 'org-capture-finalize)
 
- (define-key org-capture-mode-map "\C-c\C-k" 'org-capture-kill)
 
- (define-key org-capture-mode-map "\C-c\C-w" 'org-capture-refile)
 
- ;;; The main commands
 
- (defvar org-capture-initial nil)
 
- (defvar org-capture-entry nil)
 
- ;;;###autoload
 
- (defun org-capture-string (string &optional keys)
 
-   (interactive "sInitial text: \n")
 
-   (let ((org-capture-initial string)
 
- 	(org-capture-entry (org-capture-select-template keys)))
 
-     (org-capture)))
 
- (defcustom org-capture-templates-contexts nil
 
-   "Alist of capture templates and valid contexts.
 
- For example, if you have a capture template \"c\" and you want
 
- this template to be accessible only from `message-mode' buffers,
 
- use this:
 
-    '((\"c\" ((in-mode . \"message-mode\"))))
 
- Here are the available contexts definitions:
 
-       in-file: command displayed only in matching files
 
-       in-mode: command displayed only in matching modes
 
-   not-in-file: command not displayed in matching files
 
-   not-in-mode: command not displayed in matching modes
 
-     in-buffer: command displayed only in matching buffers
 
- not-in-buffer: command not displayed in matching buffers
 
-    [function]: a custom function taking no argument
 
- If you define several checks, the agenda command will be
 
- accessible if there is at least one valid check.
 
- You can also bind a key to another agenda custom command
 
- depending on contextual rules.
 
-     '((\"c\" \"d\" ((in-mode . \"message-mode\"))))
 
- Here it means: in `message-mode buffers', use \"c\" as the
 
- key for the capture template otherwise associated with \"d\".
 
- \(The template originally associated with \"d\" is not displayed
 
- to avoid duplicates.)"
 
-   :version "24.3"
 
-   :group 'org-capture
 
-   :type '(repeat (list :tag "Rule"
 
- 		       (string :tag "        Capture key")
 
- 		       (string :tag "Replace by template")
 
- 		       (repeat :tag "Available when"
 
- 			      (choice
 
- 			       (cons :tag "Condition"
 
- 				     (choice
 
- 				      (const :tag "In file" in-file)
 
- 				      (const :tag "Not in file" not-in-file)
 
- 				      (const :tag "In buffer" in-buffer)
 
- 				      (const :tag "Not in buffer" not-in-buffer)
 
- 				      (const :tag "In mode" in-mode)
 
- 				      (const :tag "Not in mode" not-in-mode))
 
- 				     (regexp))
 
- 			       (function :tag "Custom function"))))))
 
- (defcustom org-capture-use-agenda-date nil
 
-   "Non-nil means use the date at point when capturing from agendas.
 
- When nil, you can still capturing using the date at point with \\[org-agenda-capture]]."
 
-   :group 'org-capture
 
-   :version "24.3"
 
-   :type 'boolean)
 
- ;;;###autoload
 
- (defun org-capture (&optional goto keys)
 
-   "Capture something.
 
- \\<org-capture-mode-map>
 
- This will let you select a template from `org-capture-templates', and then
 
- file the newly captured information.  The text is immediately inserted
 
- at the target location, and an indirect buffer is shown where you can
 
- edit it.  Pressing \\[org-capture-finalize] brings you back to the previous state
 
- of Emacs, so that you can continue your work.
 
- When called interactively with a \\[universal-argument] prefix argument GOTO, don't capture
 
- anything, just go to the file/headline where the selected template
 
- stores its notes.  With a double prefix argument \
 
- \\[universal-argument] \\[universal-argument], go to the last note
 
- stored.
 
- When called with a `C-0' (zero) prefix, insert a template at point.
 
- ELisp programs can set KEYS to a string associated with a template
 
- in `org-capture-templates'.  In this case, interactive selection
 
- will be bypassed.
 
- If `org-capture-use-agenda-date' is non-nil, capturing from the
 
- agenda will use the date at point as the default date.  Then, a
 
- `C-1' prefix will tell the capture process to use the HH:MM time
 
- of the day at point (if any) or the current HH:MM time."
 
-   (interactive "P")
 
-   (when (and org-capture-use-agenda-date
 
- 	     (eq major-mode 'org-agenda-mode))
 
-     (setq org-overriding-default-time
 
- 	  (org-get-cursor-date (equal goto 1))))
 
-   (cond
 
-    ((equal goto '(4)) (org-capture-goto-target))
 
-    ((equal goto '(16)) (org-capture-goto-last-stored))
 
-    (t
 
-     ;; FIXME: Are these needed?
 
-     (let* ((orig-buf (current-buffer))
 
- 	   (annotation (if (and (boundp 'org-capture-link-is-already-stored)
 
- 				org-capture-link-is-already-stored)
 
- 			   (plist-get org-store-link-plist :annotation)
 
- 			 (ignore-errors (org-store-link nil))))
 
- 	   (entry (or org-capture-entry (org-capture-select-template keys)))
 
- 	   initial)
 
-       (setq initial (or org-capture-initial
 
- 			(and (org-region-active-p)
 
- 			     (buffer-substring (point) (mark)))))
 
-       (when (stringp initial)
 
- 	(remove-text-properties 0 (length initial) '(read-only t) initial))
 
-       (when (stringp annotation)
 
- 	(remove-text-properties 0 (length annotation)
 
- 				'(read-only t) annotation))
 
-       (cond
 
-        ((equal entry "C")
 
- 	(customize-variable 'org-capture-templates))
 
-        ((equal entry "q")
 
- 	(error "Abort"))
 
-        (t
 
- 	(org-capture-set-plist entry)
 
- 	(org-capture-get-template)
 
- 	(org-capture-put :original-buffer orig-buf
 
- 			 :original-file (or (buffer-file-name orig-buf)
 
- 					    (and (featurep 'dired)
 
- 						 (car (rassq orig-buf
 
- 							     dired-buffers))))
 
- 			 :original-file-nondirectory
 
- 			 (and (buffer-file-name orig-buf)
 
- 			      (file-name-nondirectory
 
- 			       (buffer-file-name orig-buf)))
 
- 			 :annotation annotation
 
- 			 :initial initial)
 
- 	(org-capture-put :default-time
 
- 			 (or org-overriding-default-time
 
- 			     (org-current-time)))
 
- 	(org-capture-set-target-location)
 
- 	(condition-case error
 
- 	    (org-capture-put :template (org-capture-fill-template))
 
- 	  ((error quit)
 
- 	   (if (get-buffer "*Capture*") (kill-buffer "*Capture*"))
 
- 	   (error "Capture abort: %s" error)))
 
- 	(setq org-capture-clock-keep (org-capture-get :clock-keep))
 
- 	(if (equal goto 0)
 
- 	    ;;insert at point
 
- 	    (org-capture-insert-template-here)
 
- 	  (condition-case error
 
- 	      (org-capture-place-template)
 
- 	    ((error quit)
 
- 	     (if (and (buffer-base-buffer (current-buffer))
 
- 		      (string-match "\\`CAPTURE-" (buffer-name)))
 
- 		 (kill-buffer (current-buffer)))
 
- 	     (set-window-configuration (org-capture-get :return-to-wconf))
 
- 	     (error "Capture template `%s': %s"
 
- 		    (org-capture-get :key)
 
- 		    (nth 1 error))))
 
- 	  (if (and (derived-mode-p 'org-mode)
 
- 		   (org-capture-get :clock-in))
 
- 	      (condition-case nil
 
- 		  (progn
 
- 		    (if (org-clock-is-active)
 
- 			(org-capture-put :interrupted-clock
 
- 					 (copy-marker org-clock-marker)))
 
- 		    (org-clock-in)
 
- 		    (org-set-local 'org-capture-clock-was-started t))
 
- 		(error
 
- 		 "Could not start the clock in this capture buffer")))
 
- 	  (if (org-capture-get :immediate-finish)
 
- 	      (org-capture-finalize nil)))))))))
 
- (defun org-capture-get-template ()
 
-   "Get the template from a file or a function if necessary."
 
-   (let ((txt (org-capture-get :template)) file)
 
-     (cond
 
-      ((and (listp txt) (eq (car txt) 'file))
 
-       (if (file-exists-p
 
- 	   (setq file (expand-file-name (nth 1 txt) org-directory)))
 
- 	  (setq txt (org-file-contents file))
 
- 	(setq txt (format "* Template file %s not found" (nth 1 txt)))))
 
-      ((and (listp txt) (eq (car txt) 'function))
 
-       (if (fboundp (nth 1 txt))
 
- 	  (setq txt (funcall (nth 1 txt)))
 
- 	(setq txt (format "* Template function %s not found" (nth 1 txt)))))
 
-      ((not txt) (setq txt ""))
 
-      ((stringp txt))
 
-      (t (setq txt "* Invalid capture template")))
 
-     (org-capture-put :template txt)))
 
- (defun org-capture-finalize (&optional stay-with-capture)
 
-   "Finalize the capture process.
 
- With prefix argument STAY-WITH-CAPTURE, jump to the location of the
 
- captured item after finalizing."
 
-   (interactive "P")
 
-   (unless (and org-capture-mode
 
- 	       (buffer-base-buffer (current-buffer)))
 
-     (error "This does not seem to be a capture buffer for Org-mode"))
 
-   (run-hooks 'org-capture-prepare-finalize-hook)
 
-   ;; Did we start the clock in this capture buffer?
 
-   (when (and org-capture-clock-was-started
 
- 	     org-clock-marker (marker-buffer org-clock-marker)
 
- 	     (equal (marker-buffer org-clock-marker) (buffer-base-buffer))
 
- 	     (> org-clock-marker (point-min))
 
- 	     (< org-clock-marker (point-max)))
 
-     ;; Looks like the clock we started is still running.  Clock out.
 
-     (when (not org-capture-clock-keep) (let (org-log-note-clock-out) (org-clock-out)))
 
-     (when (and (not org-capture-clock-keep)
 
- 	       (org-capture-get :clock-resume 'local)
 
- 	       (markerp (org-capture-get :interrupted-clock 'local))
 
- 	       (buffer-live-p (marker-buffer
 
- 			       (org-capture-get :interrupted-clock 'local))))
 
-       (let ((clock-in-task (org-capture-get :interrupted-clock 'local)))
 
- 	(org-with-point-at clock-in-task
 
- 	  (org-clock-in)))
 
-       (message "Interrupted clock has been resumed")))
 
-   (let ((beg (point-min))
 
- 	(end (point-max))
 
- 	(abort-note nil))
 
-     ;; Store the size of the capture buffer
 
-     (org-capture-put :captured-entry-size (- (point-max) (point-min)))
 
-     (widen)
 
-     ;; Store the insertion point in the target buffer
 
-     (org-capture-put :insertion-point (point))
 
-     (if org-note-abort
 
- 	(let ((m1 (org-capture-get :begin-marker 'local))
 
- 	      (m2 (org-capture-get :end-marker 'local)))
 
- 	  (if (and m1 m2 (= m1 beg) (= m2 end))
 
- 	      (progn
 
- 		(setq m2 (if (cdr (assoc 'heading org-blank-before-new-entry))
 
- 			     m2 (1+ m2))
 
- 		      m2 (if (< (point-max) m2) (point-max) m2))
 
- 		(setq abort-note 'clean)
 
- 		(kill-region m1 m2))
 
- 	    (setq abort-note 'dirty)))
 
-       ;; Make sure that the empty lines after are correct
 
-       (when (and (> (point-max) end) ; indeed, the buffer was still narrowed
 
- 		 (member (org-capture-get :type 'local)
 
- 			 '(entry item checkitem plain)))
 
- 	(save-excursion
 
- 	  (goto-char end)
 
- 	  (or (bolp) (newline))
 
- 	  (org-capture-empty-lines-after
 
- 	   (or (org-capture-get :empty-lines-after 'local)
 
- 	       (org-capture-get :empty-lines 'local) 0))))
 
-       ;; Postprocessing:  Update Statistics cookies, do the sorting
 
-       (when (derived-mode-p 'org-mode)
 
- 	(save-excursion
 
- 	  (when (ignore-errors (org-back-to-heading))
 
- 	    (org-update-parent-todo-statistics)
 
- 	    (org-update-checkbox-count)))
 
- 	;; FIXME Here we should do the sorting
 
- 	;; If we have added a table line, maybe recompute?
 
- 	(when (and (eq (org-capture-get :type 'local) 'table-line)
 
- 		   (org-at-table-p))
 
- 	  (if (org-table-get-stored-formulas)
 
- 	      (org-table-recalculate 'all) ;; FIXME: Should we iterate???
 
- 	    (org-table-align))))
 
-       ;; Store this place as the last one where we stored something
 
-       ;; Do the marking in the base buffer, so that it makes sense after
 
-       ;; the indirect buffer has been killed.
 
-       (when org-capture-bookmark
 
- 	(org-capture-bookmark-last-stored-position))
 
-       ;; Run the hook
 
-       (run-hooks 'org-capture-before-finalize-hook))
 
-     (when (org-capture-get :decrypted)
 
-       (save-excursion
 
- 	(goto-char (org-capture-get :decrypted))
 
- 	(org-encrypt-entry)))
 
-     ;; Kill the indirect buffer
 
-     (save-buffer)
 
-     (let ((return-wconf (org-capture-get :return-to-wconf 'local))
 
- 	  (new-buffer (org-capture-get :new-buffer 'local))
 
- 	  (kill-buffer (org-capture-get :kill-buffer 'local))
 
- 	  (base-buffer (buffer-base-buffer (current-buffer))))
 
-       ;; Kill the indirect buffer
 
-       (kill-buffer (current-buffer))
 
-       ;; Narrow back the target buffer to its previous state
 
-       (with-current-buffer (org-capture-get :buffer)
 
-         (let ((reg (org-capture-get :initial-target-region))
 
- 	      (pos (org-capture-get :initial-target-position))
 
- 	      (ipt (org-capture-get :insertion-point))
 
- 	      (size (org-capture-get :captured-entry-size)))
 
- 	  (when reg
 
- 	    (cond ((< ipt (car reg))
 
- 		   ;; insertion point is before the narrowed region
 
- 		   (narrow-to-region (+ size (car reg)) (+ size (cdr reg))))
 
- 		  ((> ipt (cdr reg))
 
- 		   ;; insertion point is after the narrowed region
 
- 		   (narrow-to-region (car reg) (cdr reg)))
 
- 		  (t
 
- 		   ;; insertion point is within the narrowed region
 
- 		   (narrow-to-region (car reg) (+ size (cdr reg)))))
 
- 	    ;; now place back the point at its original position
 
- 	    (if (< ipt (car reg))
 
- 		(goto-char (+ size pos))
 
- 	      (goto-char (if (< ipt pos) (+ size pos) pos))))))
 
-       ;; Kill the target buffer if that is desired
 
-       (when (and base-buffer new-buffer kill-buffer)
 
- 	(with-current-buffer base-buffer (save-buffer))
 
- 	(kill-buffer base-buffer))
 
-       ;; Restore the window configuration before capture
 
-       (set-window-configuration return-wconf))
 
-     (run-hooks 'org-capture-after-finalize-hook)
 
-     ;; Special cases
 
-     (cond
 
-      (abort-note
 
-       (cond
 
-        ((equal abort-note 'clean)
 
- 	(message "Capture process aborted and target buffer cleaned up"))
 
-        ((equal abort-note 'dirty)
 
- 	(error "Capture process aborted, but target buffer could not be cleaned up correctly"))))
 
-      (stay-with-capture
 
-       (org-capture-goto-last-stored)))
 
-     ;; Return if we did store something
 
-     (not abort-note)))
 
- (defun org-capture-refile ()
 
-   "Finalize the current capture and then refile the entry.
 
- Refiling is done from the base buffer, because the indirect buffer is then
 
- already gone.  Any prefix argument will be passed to the refile command."
 
-   (interactive)
 
-   (unless (eq (org-capture-get :type 'local) 'entry)
 
-     (error
 
-      "Refiling from a capture buffer makes only sense for `entry'-type templates"))
 
-   (let ((pos (point))
 
- 	(base (buffer-base-buffer (current-buffer)))
 
- 	(org-refile-for-capture t))
 
-     (org-capture-finalize)
 
-     (save-window-excursion
 
-       (with-current-buffer (or base (current-buffer))
 
- 	(save-excursion
 
- 	  (save-restriction
 
- 	    (widen)
 
- 	    (goto-char pos)
 
- 	    (call-interactively 'org-refile)))))))
 
- (defun org-capture-kill ()
 
-   "Abort the current capture process."
 
-   (interactive)
 
-   ;; FIXME: This does not do the right thing, we need to remove the
 
-   ;; new stuff by hand it is easy: undo, then kill the buffer
 
-   (let ((org-note-abort t)
 
- 	(org-capture-before-finalize-hook nil))
 
-     (org-capture-finalize)))
 
- (defun org-capture-goto-last-stored ()
 
-   "Go to the location where the last capture note was stored."
 
-   (interactive)
 
-   (org-goto-marker-or-bmk org-capture-last-stored-marker
 
- 			  "org-capture-last-stored")
 
-   (message "This is the last note stored by a capture process"))
 
- ;;; Supporting functions for handling the process
 
- (defun org-capture-put-target-region-and-position ()
 
-   "Store the initial region with `org-capture-put'."
 
-   (org-capture-put
 
-    :initial-target-region
 
-    ;; Check if the buffer is currently narrowed
 
-    (when (/= (buffer-size) (- (point-max) (point-min)))
 
-      (cons (point-min) (point-max))))
 
-   ;; store the current point
 
-   (org-capture-put :initial-target-position (point)))
 
- (defvar org-time-was-given) ; dynamically scoped parameter
 
- (defun org-capture-set-target-location (&optional target)
 
-   "Find TARGET buffer and position.
 
- Store them in the capture property list."
 
-   (let ((target-entry-p t) decrypted-hl-pos)
 
-     (setq target (or target (org-capture-get :target)))
 
-     (save-excursion
 
-       (cond
 
-        ((eq (car target) 'file)
 
- 	(set-buffer (org-capture-target-buffer (nth 1 target)))
 
- 	(org-capture-put-target-region-and-position)
 
- 	(widen)
 
- 	(setq target-entry-p nil))
 
-        ((eq (car target) 'id)
 
- 	(let ((loc (org-id-find (nth 1 target))))
 
- 	  (if (not loc)
 
- 	      (error "Cannot find target ID \"%s\"" (nth 1 target))
 
- 	    (set-buffer (org-capture-target-buffer (car loc)))
 
- 	    (widen)
 
- 	    (org-capture-put-target-region-and-position)
 
- 	    (goto-char (cdr loc)))))
 
-        ((eq (car target) 'file+headline)
 
- 	(set-buffer (org-capture-target-buffer (nth 1 target)))
 
- 	(org-capture-put-target-region-and-position)
 
- 	(widen)
 
- 	(let ((hd (nth 2 target)))
 
- 	  (goto-char (point-min))
 
- 	  (unless (derived-mode-p 'org-mode)
 
- 	    (error
 
- 	     "Target buffer \"%s\" for file+headline should be in Org mode"
 
- 	     (current-buffer)))
 
- 	  (if (re-search-forward
 
- 	       (format org-complex-heading-regexp-format (regexp-quote hd))
 
- 	       nil t)
 
- 	      (goto-char (point-at-bol))
 
- 	    (goto-char (point-max))
 
- 	    (or (bolp) (insert "\n"))
 
- 	    (insert "* " hd "\n")
 
- 	    (beginning-of-line 0))))
 
-        ((eq (car target) 'file+olp)
 
-  	(let ((m (org-find-olp
 
- 		  (cons (org-capture-expand-file (nth 1 target))
 
- 			(cddr target)))))
 
- 	  (set-buffer (marker-buffer m))
 
- 	  (org-capture-put-target-region-and-position)
 
- 	  (widen)
 
- 	  (goto-char m)))
 
-        ((eq (car target) 'file+regexp)
 
- 	(set-buffer (org-capture-target-buffer (nth 1 target)))
 
- 	(org-capture-put-target-region-and-position)
 
- 	(widen)
 
- 	(goto-char (point-min))
 
- 	(if (re-search-forward (nth 2 target) nil t)
 
- 	    (progn
 
- 	      (goto-char (if (org-capture-get :prepend)
 
- 			     (match-beginning 0) (match-end 0)))
 
- 	      (org-capture-put :exact-position (point))
 
- 	      (setq target-entry-p (and (derived-mode-p 'org-mode) (org-at-heading-p))))
 
- 	  (error "No match for target regexp in file %s" (nth 1 target))))
 
-        ((memq (car target) '(file+datetree file+datetree+prompt))
 
- 	(require 'org-datetree)
 
- 	(set-buffer (org-capture-target-buffer (nth 1 target)))
 
- 	(org-capture-put-target-region-and-position)
 
- 	(widen)
 
- 	;; Make a date tree entry, with the current date (or yesterday,
 
- 	;; if we are extending dates for a couple of hours)
 
- 	(org-datetree-find-date-create
 
- 	 (calendar-gregorian-from-absolute
 
- 	  (cond
 
- 	   (org-overriding-default-time
 
- 	    ;; use the overriding default time
 
- 	    (time-to-days org-overriding-default-time))
 
- 	   ((eq (car target) 'file+datetree+prompt)
 
- 	    ;; prompt for date
 
- 	    (let ((prompt-time (org-read-date
 
- 				nil t nil "Date for tree entry:"
 
- 				(current-time))))
 
- 	      (org-capture-put
 
- 	       :default-time
 
- 	       (cond ((and (not org-time-was-given)
 
- 			   (not (= (time-to-days prompt-time) (org-today))))
 
- 		      ;; Use 00:00 when no time is given for another date than today?
 
- 		      (apply 'encode-time (append '(0 0 0) (cdddr (decode-time prompt-time)))))
 
- 		     ((string-match "\\([^ ]+\\)--?[^ ]+[ ]+\\(.*\\)" org-read-date-final-answer)
 
- 		      ;; Replace any time range by its start
 
- 		      (apply 'encode-time
 
- 			     (org-read-date-analyze
 
- 			      (replace-match "\\1 \\2" nil nil org-read-date-final-answer)
 
- 			      prompt-time (decode-time prompt-time))))
 
- 		     (t prompt-time)))
 
- 	      (time-to-days prompt-time)))
 
- 	   (t
 
- 	    ;; current date, possibly corrected for late night workers
 
- 	    (org-today))))))
 
-        ((eq (car target) 'file+function)
 
- 	(set-buffer (org-capture-target-buffer (nth 1 target)))
 
- 	(org-capture-put-target-region-and-position)
 
- 	(widen)
 
- 	(funcall (nth 2 target))
 
- 	(org-capture-put :exact-position (point))
 
- 	(setq target-entry-p (and (derived-mode-p 'org-mode) (org-at-heading-p))))
 
-        ((eq (car target) 'function)
 
- 	(funcall (nth 1 target))
 
- 	(org-capture-put :exact-position (point))
 
- 	(setq target-entry-p (and (derived-mode-p 'org-mode) (org-at-heading-p))))
 
-        ((eq (car target) 'clock)
 
- 	(if (and (markerp org-clock-hd-marker)
 
- 		 (marker-buffer org-clock-hd-marker))
 
- 	    (progn (set-buffer (marker-buffer org-clock-hd-marker))
 
- 		   (org-capture-put-target-region-and-position)
 
- 		   (widen)
 
- 		   (goto-char org-clock-hd-marker))
 
- 	  (error "No running clock that could be used as capture target")))
 
-        (t (error "Invalid capture target specification")))
 
-       (when (and (featurep 'org-crypt) (org-at-encrypted-entry-p))
 
- 	(org-decrypt-entry)
 
- 	(setq decrypted-hl-pos
 
- 	      (save-excursion (and (org-back-to-heading t) (point)))))
 
-       (org-capture-put :buffer (current-buffer) :pos (point)
 
- 		       :target-entry-p target-entry-p
 
- 		       :decrypted decrypted-hl-pos))))
 
- (defun org-capture-expand-file (file)
 
-   "Expand functions and symbols for FILE.
 
- When FILE is a function, call it.  When it is a form, evaluate
 
- it.  When it is a variable, retrieve the value.  Return whatever we get."
 
-   (cond
 
-    ((org-string-nw-p file) file)
 
-    ((functionp file) (funcall file))
 
-    ((and (symbolp file) (boundp file)) (symbol-value file))
 
-    ((and file (consp file)) (eval file))
 
-    (t file)))
 
- (defun org-capture-target-buffer (file)
 
-   "Get a buffer for FILE."
 
-   (setq file (org-capture-expand-file file))
 
-   (setq file (or (org-string-nw-p file)
 
- 		 org-default-notes-file
 
- 		 (error "No notes file specified, and no default available")))
 
-   (or (org-find-base-buffer-visiting file)
 
-       (progn (org-capture-put :new-buffer t)
 
- 	     (find-file-noselect (expand-file-name file org-directory)))))
 
- (defun org-capture-steal-local-variables (buffer)
 
-   "Install Org-mode local variables."
 
-   (mapc (lambda (v)
 
- 	  (ignore-errors (org-set-local (car v) (cdr v))))
 
- 	(buffer-local-variables buffer)))
 
- (defun org-capture-place-template ()
 
-   "Insert the template at the target location, and display the buffer."
 
-   (org-capture-put :return-to-wconf (current-window-configuration))
 
-   (delete-other-windows)
 
-   (org-switch-to-buffer-other-window
 
-    (org-capture-get-indirect-buffer (org-capture-get :buffer) "CAPTURE"))
 
-   (widen)
 
-   (show-all)
 
-   (goto-char (org-capture-get :pos))
 
-   (org-set-local 'org-capture-target-marker
 
- 		 (point-marker))
 
-   (org-set-local 'outline-level 'org-outline-level)
 
-   (let* ((template (org-capture-get :template))
 
- 	 (type (org-capture-get :type)))
 
-     (case type
 
-       ((nil entry) (org-capture-place-entry))
 
-       (table-line (org-capture-place-table-line))
 
-       (plain (org-capture-place-plain-text))
 
-       (item (org-capture-place-item))
 
-       (checkitem (org-capture-place-item))))
 
-   (org-capture-mode 1)
 
-   (org-set-local 'org-capture-current-plist org-capture-plist))
 
- (defun org-capture-place-entry ()
 
-   "Place the template as a new Org entry."
 
-   (let* ((txt (org-capture-get :template))
 
- 	 (reversed (org-capture-get :prepend))
 
- 	 (target-entry-p (org-capture-get :target-entry-p))
 
- 	 level beg end file)
 
-     (cond
 
-      ((org-capture-get :exact-position)
 
-       (goto-char (org-capture-get :exact-position)))
 
-      ((not target-entry-p)
 
-       ;; Insert as top-level entry, either at beginning or at end of file
 
-       (setq level 1)
 
-       (if reversed
 
- 	  (progn (goto-char (point-min))
 
- 		 (or (org-at-heading-p)
 
- 		     (outline-next-heading)))
 
- 	(goto-char (point-max))
 
- 	(or (bolp) (insert "\n"))))
 
-      (t
 
-       ;; Insert as a child of the current entry
 
-       (and (looking-at "\\*+")
 
- 	   (setq level (- (match-end 0) (match-beginning 0))))
 
-       (setq level (org-get-valid-level (or level 1) 1))
 
-       (if reversed
 
- 	  (progn
 
- 	    (outline-next-heading)
 
- 	    (or (bolp) (insert "\n")))
 
- 	(org-end-of-subtree t nil)
 
- 	(or (bolp) (insert "\n")))))
 
-     (org-capture-empty-lines-before)
 
-     (setq beg (point))
 
-     (org-capture-verify-tree txt)
 
-     (org-paste-subtree level txt 'for-yank)
 
-     (org-capture-empty-lines-after 1)
 
-     (org-capture-position-for-last-stored beg)
 
-     (outline-next-heading)
 
-     (setq end (point))
 
-     (org-capture-mark-kill-region beg (1- end))
 
-     (org-capture-narrow beg (1- end))
 
-     (if (or (re-search-backward "%\\?" beg t)
 
- 	    (re-search-forward "%\\?" end t))
 
- 	(replace-match ""))))
 
- (defun org-capture-place-item ()
 
-   "Place the template as a new plain list item."
 
-   (let* ((txt (org-capture-get :template))
 
- 	 (target-entry-p (org-capture-get :target-entry-p))
 
- 	 (ind 0)
 
- 	 beg end)
 
-     (if (org-capture-get :exact-position)
 
- 	(goto-char (org-capture-get :exact-position))
 
-       (cond
 
-        ((not target-entry-p)
 
- 	;; Insert as top-level entry, either at beginning or at end of file
 
- 	(setq beg (point-min) end (point-max)))
 
-        (t
 
- 	(setq beg (1+ (point-at-eol))
 
- 	      end (save-excursion (outline-next-heading) (point)))))
 
-       (if (org-capture-get :prepend)
 
- 	  (progn
 
- 	    (goto-char beg)
 
- 	    (if (org-list-search-forward (org-item-beginning-re) end t)
 
- 		(progn
 
- 		  (goto-char (match-beginning 0))
 
- 		  (setq ind (org-get-indentation)))
 
- 	      (goto-char end)
 
- 	      (setq ind 0)))
 
- 	(goto-char end)
 
- 	(if (org-list-search-backward (org-item-beginning-re) beg t)
 
- 	    (progn
 
- 	      (setq ind (org-get-indentation))
 
- 	      (org-end-of-item))
 
- 	  (setq ind 0))))
 
-     ;; Remove common indentation
 
-     (setq txt (org-remove-indentation txt))
 
-     ;; Make sure this is indeed an item
 
-     (unless (string-match (concat "\\`" (org-item-re)) txt)
 
-       (setq txt (concat "- "
 
- 			(mapconcat 'identity (split-string txt "\n")
 
- 				   "\n  "))))
 
-     ;; Set the correct indentation, depending on context
 
-     (setq ind (make-string ind ?\ ))
 
-     (setq txt (concat ind
 
- 		      (mapconcat 'identity (split-string txt "\n")
 
- 				 (concat "\n" ind))
 
- 		      "\n"))
 
-     ;; Insert, with surrounding empty lines
 
-     (org-capture-empty-lines-before)
 
-     (setq beg (point))
 
-     (insert txt)
 
-     (or (bolp) (insert "\n"))
 
-     (org-capture-empty-lines-after 1)
 
-     (org-capture-position-for-last-stored beg)
 
-     (forward-char 1)
 
-     (setq end (point))
 
-     (org-capture-mark-kill-region beg (1- end))
 
-     (org-capture-narrow beg (1- end))
 
-     (if (or (re-search-backward "%\\?" beg t)
 
- 	    (re-search-forward "%\\?" end t))
 
- 	(replace-match ""))))
 
- (defun org-capture-place-table-line ()
 
-   "Place the template as a table line."
 
-   (require 'org-table)
 
-   (let* ((txt (org-capture-get :template))
 
- 	 (target-entry-p (org-capture-get :target-entry-p))
 
- 	 (table-line-pos (org-capture-get :table-line-pos))
 
- 	 ind beg end)
 
-     (cond
 
-      ((org-capture-get :exact-position)
 
-       (goto-char (org-capture-get :exact-position)))
 
-      ((not target-entry-p)
 
-       ;; Table is not necessarily under a heading
 
-       (setq beg (point-min) end (point-max)))
 
-      (t
 
-       ;; WE are at a heading, limit search to the body
 
-       (setq beg (1+ (point-at-eol))
 
- 	    end (save-excursion (outline-next-heading) (point)))))
 
-     (if (re-search-forward org-table-dataline-regexp end t)
 
- 	(let ((b (org-table-begin)) (e (org-table-end)) (case-fold-search t))
 
- 	  (goto-char e)
 
- 	  (if (looking-at "[ \t]*#\\+tblfm:")
 
- 	      (forward-line 1))
 
- 	  (narrow-to-region b (point)))
 
-       (goto-char end)
 
-       (insert "\n|   |\n|----|\n|    |\n")
 
-       (narrow-to-region (1+ end) (point)))
 
-     ;; We are narrowed to the table, or to an empty line if there was no table
 
-     ;; Check if the template is good
 
-     (if (not (string-match org-table-dataline-regexp txt))
 
- 	(setq txt "| %?Bad template |\n"))
 
-     (cond
 
-      ((and table-line-pos
 
- 	   (string-match "\\(I+\\)\\([-+][0-9]\\)" table-line-pos))
 
-       ;; we have a complex line specification
 
-       (goto-char (point-min))
 
-       (let ((nh (- (match-end 1) (match-beginning 1)))
 
- 	    (delta (string-to-number (match-string 2 table-line-pos)))
 
- 	    ll)
 
- 	;; The user wants a special position in the table
 
- 	(org-table-get-specials)
 
- 	(setq ll (ignore-errors (aref org-table-hlines nh)))
 
- 	(unless ll (error "Invalid table line specification \"%s\""
 
- 			  table-line-pos))
 
- 	(setq ll (+ ll delta (if (< delta 0) 0 -1)))
 
- 	(org-goto-line ll)
 
- 	(org-table-insert-row 'below)
 
- 	(beginning-of-line 1)
 
- 	(delete-region (point) (1+ (point-at-eol)))
 
- 	(setq beg (point))
 
- 	(insert txt)
 
- 	(setq end (point))))
 
-      ((org-capture-get :prepend)
 
-       (goto-char (point-min))
 
-       (re-search-forward org-table-hline-regexp nil t)
 
-       (beginning-of-line 1)
 
-       (re-search-forward org-table-dataline-regexp nil t)
 
-       (beginning-of-line 1)
 
-       (setq beg (point))
 
-       (org-table-insert-row)
 
-       (beginning-of-line 1)
 
-       (delete-region (point) (1+ (point-at-eol)))
 
-       (insert txt)
 
-       (setq end (point)))
 
-      (t
 
-       (goto-char (point-max))
 
-       (re-search-backward org-table-dataline-regexp nil t)
 
-       (beginning-of-line 1)
 
-       (org-table-insert-row 'below)
 
-       (beginning-of-line 1)
 
-       (delete-region (point) (1+ (point-at-eol)))
 
-       (setq beg (point))
 
-       (insert txt)
 
-       (setq end (point))))
 
-     (goto-char beg)
 
-     (org-capture-position-for-last-stored 'table-line)
 
-     (if (or (re-search-backward "%\\?" beg t)
 
- 	    (re-search-forward "%\\?" end t))
 
- 	(replace-match ""))
 
-     (org-table-align)))
 
- (defun org-capture-place-plain-text ()
 
-   "Place the template plainly.
 
- If the target locator points at an Org node, place the template into
 
- the text of the entry, before the first child.  If not, place the
 
- template at the beginning or end of the file.
 
- Of course, if exact position has been required, just put it there."
 
-   (let* ((txt (org-capture-get :template))
 
- 	 beg end)
 
-     (cond
 
-      ((org-capture-get :exact-position)
 
-       (goto-char (org-capture-get :exact-position)))
 
-      ((and (org-capture-get :target-entry-p)
 
- 	   (bolp)
 
- 	   (looking-at org-outline-regexp))
 
-       ;; we should place the text into this entry
 
-       (if (org-capture-get :prepend)
 
- 	  ;; Skip meta data and drawers
 
- 	  (org-end-of-meta-data-and-drawers)
 
- 	;; go to ent of the entry text, before the next headline
 
- 	(outline-next-heading)))
 
-      (t
 
-       ;; beginning or end of file
 
-       (goto-char (if (org-capture-get :prepend) (point-min) (point-max)))))
 
-     (or (bolp) (newline))
 
-     (org-capture-empty-lines-before)
 
-     (setq beg (point))
 
-     (insert txt)
 
-     (org-capture-empty-lines-after 1)
 
-     (org-capture-position-for-last-stored beg)
 
-     (setq end (point))
 
-     (org-capture-mark-kill-region beg (1- end))
 
-     (org-capture-narrow beg (1- end))
 
-     (if (or (re-search-backward "%\\?" beg t)
 
- 	    (re-search-forward "%\\?" end t))
 
- 	(replace-match ""))))
 
- (defun org-capture-mark-kill-region (beg end)
 
-   "Mark the region that will have to be killed when aborting capture."
 
-   (let ((m1 (move-marker (make-marker) beg))
 
- 	(m2 (move-marker (make-marker) end)))
 
-     (org-capture-put :begin-marker m1)
 
-     (org-capture-put :end-marker m2)))
 
- (defun org-capture-position-for-last-stored (where)
 
-   "Memorize the position that should later become the position of last capture."
 
-   (cond
 
-    ((integerp where)
 
-     (org-capture-put :position-for-last-stored
 
- 		     (move-marker (make-marker) where
 
- 				  (or (buffer-base-buffer (current-buffer))
 
- 				      (current-buffer)))))
 
-    ((eq where 'table-line)
 
-     (org-capture-put :position-for-last-stored
 
- 		     (list 'table-line
 
- 			   (org-table-current-dline))))
 
-    (t (error "This should not happen"))))
 
- (defun org-capture-bookmark-last-stored-position ()
 
-   "Bookmark the last-captured position."
 
-   (let* ((where (org-capture-get :position-for-last-stored 'local))
 
- 	 (pos (cond
 
- 	       ((markerp where)
 
- 		(prog1 (marker-position where)
 
- 		  (move-marker where nil)))
 
- 	       ((and (listp where) (eq (car where) 'table-line))
 
- 		(if (org-at-table-p)
 
- 		    (save-excursion
 
- 		      (org-table-goto-line (nth 1 where))
 
- 		      (point-at-bol))
 
- 		  (point))))))
 
-     (with-current-buffer (buffer-base-buffer (current-buffer))
 
-       (save-excursion
 
- 	(save-restriction
 
- 	  (widen)
 
- 	  (goto-char pos)
 
- 	  (with-demoted-errors
 
- 	    (bookmark-set "org-capture-last-stored"))
 
- 	  (move-marker org-capture-last-stored-marker (point)))))))
 
- (defun org-capture-narrow (beg end)
 
-   "Narrow, unless configuration says not to narrow."
 
-   (unless (org-capture-get :unnarrowed)
 
-     (narrow-to-region beg end)
 
-     (goto-char beg)))
 
- (defun org-capture-empty-lines-before (&optional n)
 
-   "Arrange for the correct number of empty lines before the insertion point.
 
- Point will be after the empty lines, so insertion can directly be done."
 
-   (setq n (or n (org-capture-get :empty-lines-before)
 
- 	      (org-capture-get :empty-lines) 0))
 
-   (let ((pos (point)))
 
-     (org-back-over-empty-lines)
 
-     (delete-region (point) pos)
 
-     (if (> n 0) (newline n))))
 
- (defun org-capture-empty-lines-after (&optional n)
 
-   "Arrange for the correct number of empty lines after the inserted string.
 
- Point will remain at the first line after the inserted text."
 
-   (setq n (or n (org-capture-get :empty-lines-after)
 
- 	      (org-capture-get :empty-lines) 0))
 
-   (org-back-over-empty-lines)
 
-   (while (looking-at "[ \t]*\n") (replace-match ""))
 
-   (let ((pos (point)))
 
-     (if (> n 0) (newline n))
 
-     (goto-char pos)))
 
- (defvar org-clock-marker) ; Defined in org.el
 
- (defun org-capture-insert-template-here ()
 
-   (let* ((template (org-capture-get :template))
 
- 	 (type  (org-capture-get :type))
 
- 	 beg end pp)
 
-     (or (bolp) (newline))
 
-     (setq beg (point))
 
-     (cond
 
-      ((and (eq type 'entry) (derived-mode-p 'org-mode))
 
-       (org-capture-verify-tree (org-capture-get :template))
 
-       (org-paste-subtree nil template t))
 
-      ((and (memq type '(item checkitem))
 
- 	   (derived-mode-p 'org-mode)
 
- 	   (save-excursion (skip-chars-backward " \t\n")
 
- 			   (setq pp (point))
 
- 			   (org-in-item-p)))
 
-       (goto-char pp)
 
-       (org-insert-item)
 
-       (skip-chars-backward " ")
 
-       (skip-chars-backward "-+*0123456789).")
 
-       (delete-region (point) (point-at-eol))
 
-       (setq beg (point))
 
-       (org-remove-indentation template)
 
-       (insert template)
 
-       (org-capture-empty-lines-after)
 
-       (goto-char beg)
 
-       (org-list-repair)
 
-       (org-end-of-item)
 
-       (setq end (point)))
 
-      (t (insert template)))
 
-     (setq end (point))
 
-     (goto-char beg)
 
-     (if (re-search-forward "%\\?" end t)
 
- 	(replace-match ""))))
 
- (defun org-capture-set-plist (entry)
 
-   "Initialize the property list from the template definition."
 
-   (setq org-capture-plist (copy-sequence (nthcdr 5 entry)))
 
-   (org-capture-put :key (car entry) :description (nth 1 entry)
 
- 		   :target (nth 3 entry))
 
-   (let ((txt (nth 4 entry)) (type (or (nth 2 entry) 'entry)))
 
-     (when (or (not txt) (and (stringp txt) (not (string-match "\\S-" txt))))
 
-       ;; The template may be empty or omitted for special types.
 
-       ;; Here we insert the default templates for such cases.
 
-       (cond
 
-        ((eq type 'item) (setq txt "- %?"))
 
-        ((eq type 'checkitem) (setq txt "- [ ] %?"))
 
-        ((eq type 'table-line) (setq txt "| %? |"))
 
-        ((member type '(nil entry)) (setq txt "* %?\n  %a"))))
 
-     (org-capture-put :template txt :type type)))
 
- (defun org-capture-goto-target (&optional template-key)
 
-   "Go to the target location of a capture template.
 
- The user is queried for the template."
 
-   (interactive)
 
-   (let* (org-select-template-temp-major-mode
 
- 	 (entry (org-capture-select-template template-key)))
 
-     (unless entry
 
-       (error "No capture template selected"))
 
-     (org-capture-set-plist entry)
 
-     (org-capture-set-target-location)
 
-     (org-pop-to-buffer-same-window (org-capture-get :buffer))
 
-     (goto-char (org-capture-get :pos))))
 
- (defun org-capture-get-indirect-buffer (&optional buffer prefix)
 
-   "Make an indirect buffer for a capture process.
 
- Use PREFIX as a prefix for the name of the indirect buffer."
 
-   (setq buffer (or buffer (current-buffer)))
 
-   (let ((n 1) (base (buffer-name buffer)) bname)
 
-     (setq bname (concat prefix "-" base))
 
-     (while (buffer-live-p (get-buffer bname))
 
-       (setq bname (concat prefix "-" (number-to-string (incf n)) "-" base)))
 
-     (condition-case nil
 
-         (make-indirect-buffer buffer bname 'clone)
 
-       (error
 
-        (let ((buf (make-indirect-buffer buffer bname)))
 
- 	 (with-current-buffer buf (org-mode))
 
- 	 buf)))))
 
- (defun org-capture-verify-tree (tree)
 
-   "Throw error if TREE is not a valid tree."
 
-   (unless (org-kill-is-subtree-p tree)
 
-     (error "Template is not a valid Org entry or tree")))
 
- ;;; The template code
 
- (defun org-capture-select-template (&optional keys)
 
-   "Select a capture template.
 
- Lisp programs can force the template by setting KEYS to a string."
 
-   (let ((org-capture-templates
 
- 	 (or (org-contextualize-keys
 
- 	      org-capture-templates org-capture-templates-contexts)
 
- 	     '(("t" "Task" entry (file+headline "" "Tasks")
 
- 		"* TODO %?\n  %u\n  %a")))))
 
-     (if keys
 
- 	(or (assoc keys org-capture-templates)
 
- 	    (error "No capture template referred to by \"%s\" keys" keys))
 
-       (org-mks org-capture-templates
 
- 	       "Select a capture template\n========================="
 
- 	       "Template key: "
 
- 	       '(("C" "Customize org-capture-templates")
 
- 		 ("q" "Abort"))))))
 
- (defun org-capture-fill-template (&optional template initial annotation)
 
-   "Fill a template and return the filled template as a string.
 
- The template may still contain \"%?\" for cursor positioning."
 
-   (setq template (or template (org-capture-get :template)))
 
-   (when (stringp initial)
 
-     (setq initial (org-no-properties initial)))
 
-   (let* ((buffer (org-capture-get :buffer))
 
- 	 (file (buffer-file-name (or (buffer-base-buffer buffer) buffer)))
 
- 	 (ct (org-capture-get :default-time))
 
- 	 (dct (decode-time ct))
 
- 	 (ct1
 
- 	  (if (< (nth 2 dct) org-extend-today-until)
 
- 	      (encode-time 0 59 23 (1- (nth 3 dct)) (nth 4 dct) (nth 5 dct))
 
- 	    ct))
 
- 	 (plist-p (if org-store-link-plist t nil))
 
- 	 (v-c (and (> (length kill-ring) 0) (current-kill 0)))
 
- 	 (v-x (or (org-get-x-clipboard 'PRIMARY)
 
- 		  (org-get-x-clipboard 'CLIPBOARD)
 
- 		  (org-get-x-clipboard 'SECONDARY)))
 
- 	 (v-t (format-time-string (car org-time-stamp-formats) ct))
 
- 	 (v-T (format-time-string (cdr org-time-stamp-formats) ct))
 
- 	 (v-u (concat "[" (substring v-t 1 -1) "]"))
 
- 	 (v-U (concat "[" (substring v-T 1 -1) "]"))
 
- 	 ;; `initial' and `annotation' might habe been passed.
 
- 	 ;; But if the property list has them, we prefer those values
 
- 	 (v-i (or (plist-get org-store-link-plist :initial)
 
- 		  initial
 
- 		  (org-capture-get :initial)
 
- 		  ""))
 
- 	 (v-a (or (plist-get org-store-link-plist :annotation)
 
- 		  annotation
 
- 		  (org-capture-get :annotation)
 
- 		  ""))
 
- 	 ;; Is the link empty?  Then we do not want it...
 
- 	 (v-a (if (equal v-a "[[]]") "" v-a))
 
- 	 (clipboards (remove nil (list v-i
 
- 				       (org-get-x-clipboard 'PRIMARY)
 
- 				       (org-get-x-clipboard 'CLIPBOARD)
 
- 				       (org-get-x-clipboard 'SECONDARY)
 
- 				       v-c)))
 
- 	 (l-re "\\[\\[\\(.*?\\)\\]\\(\\[.*?\\]\\)?\\]")
 
- 	 (v-A (if (and v-a (string-match l-re v-a))
 
- 		  (replace-match "[[\\1][%^{Link description}]]" nil nil v-a)
 
- 		v-a))
 
- 	 (v-l (if (and v-a (string-match l-re v-a))
 
- 		  (replace-match "\\1" nil nil v-a)
 
- 		v-a))
 
- 	 (v-n user-full-name)
 
- 	 (v-k (if (marker-buffer org-clock-marker)
 
- 		  (org-no-properties org-clock-heading)))
 
- 	 (v-K (if (marker-buffer org-clock-marker)
 
- 		  (org-make-link-string
 
- 		   (buffer-file-name (marker-buffer org-clock-marker))
 
- 		   org-clock-heading)))
 
- 	 (v-f (or (org-capture-get :original-file-nondirectory) ""))
 
- 	 (v-F (or (org-capture-get :original-file) ""))
 
- 	 v-I
 
- 	 (org-startup-folded nil)
 
- 	 (org-inhibit-startup t)
 
- 	 org-time-was-given org-end-time-was-given x
 
- 	 prompt completions char time pos default histvar strings)
 
-     (setq org-store-link-plist
 
- 	  (plist-put org-store-link-plist :annotation v-a)
 
- 	  org-store-link-plist
 
- 	  (plist-put org-store-link-plist :initial v-i))
 
-     (setq initial v-i)
 
-     (unless template (setq template "") (message "No template") (ding)
 
- 	    (sit-for 1))
 
-     (save-window-excursion
 
-       (delete-other-windows)
 
-       (org-pop-to-buffer-same-window (get-buffer-create "*Capture*"))
 
-       (erase-buffer)
 
-       (insert template)
 
-       (goto-char (point-min))
 
-       (org-capture-steal-local-variables buffer)
 
-       (setq buffer-file-name nil)
 
-       ;; %[] Insert contents of a file.
 
-       (goto-char (point-min))
 
-       (while (re-search-forward "%\\[\\(.+\\)\\]" nil t)
 
- 	(unless (org-capture-escaped-%)
 
- 	  (let ((start (match-beginning 0))
 
- 		(end (match-end 0))
 
- 		(filename (expand-file-name (match-string 1))))
 
- 	    (goto-char start)
 
- 	    (delete-region start end)
 
- 	    (condition-case error
 
- 		(insert-file-contents filename)
 
- 	      (error (insert (format "%%![Couldn't insert %s: %s]"
 
- 				     filename error)))))))
 
-       ;; %() embedded elisp
 
-       (org-capture-expand-embedded-elisp)
 
-       ;; The current time
 
-       (goto-char (point-min))
 
-       (while (re-search-forward "%<\\([^>\n]+\\)>" nil t)
 
- 	(replace-match (format-time-string (match-string 1)) t t))
 
-       ;; Simple %-escapes
 
-       (goto-char (point-min))
 
-       (while (re-search-forward "%\\([tTuUaliAcxkKInfF]\\)" nil t)
 
- 	(unless (org-capture-escaped-%)
 
- 	  (when (and initial (equal (match-string 0) "%i"))
 
- 	    (save-match-data
 
- 	      (let* ((lead (buffer-substring
 
- 			    (point-at-bol) (match-beginning 0))))
 
- 		(setq v-i (mapconcat 'identity
 
- 				     (org-split-string initial "\n")
 
- 				     (concat "\n" lead))))))
 
- 	  (replace-match (or (eval (intern (concat "v-" (match-string 1)))) "")
 
- 			 t t)))
 
-       ;; From the property list
 
-       (when plist-p
 
- 	(goto-char (point-min))
 
- 	(while (re-search-forward "%\\(:[-a-zA-Z]+\\)" nil t)
 
- 	  (unless (org-capture-escaped-%)
 
- 	    (and (setq x (or (plist-get org-store-link-plist
 
- 					(intern (match-string 1))) ""))
 
- 		 (replace-match x t t)))))
 
-       ;; Turn on org-mode in temp buffer, set local variables
 
-       ;; This is to support completion in interactive prompts
 
-       (let ((org-inhibit-startup t)) (org-mode))
 
-       ;; Interactive template entries
 
-       (goto-char (point-min))
 
-       (while (re-search-forward "%^\\({\\([^}]*\\)}\\)?\\([gGtTuUCLp]\\)?" nil t)
 
- 	(unless (org-capture-escaped-%)
 
- 	  (setq char (if (match-end 3) (match-string-no-properties 3))
 
- 		prompt (if (match-end 2) (match-string-no-properties 2)))
 
- 	  (goto-char (match-beginning 0))
 
- 	  (replace-match "")
 
- 	  (setq completions nil default nil)
 
- 	  (when prompt
 
- 	    (setq completions (org-split-string prompt "|")
 
- 		  prompt (pop completions)
 
- 		  default (car completions)
 
- 		  histvar (intern (concat
 
- 				   "org-capture-template-prompt-history::"
 
- 				   (or prompt "")))
 
- 		  completions (mapcar 'list completions)))
 
- 	  (unless (boundp histvar) (set histvar nil))
 
- 	  (cond
 
- 	   ((member char '("G" "g"))
 
- 	    (let* ((org-last-tags-completion-table
 
- 		    (org-global-tags-completion-table
 
- 		     (if (equal char "G")
 
- 			 (org-agenda-files)
 
- 		       (and file (list file)))))
 
- 		   (org-add-colon-after-tag-completion t)
 
- 		   (ins (org-icompleting-read
 
- 			 (if prompt (concat prompt ": ") "Tags: ")
 
- 			 'org-tags-completion-function nil nil nil
 
- 			 'org-tags-history)))
 
- 	      (setq ins (mapconcat 'identity
 
- 				   (org-split-string
 
- 				    ins (org-re "[^[:alnum:]_@#%]+"))
 
- 				   ":"))
 
- 	      (when (string-match "\\S-" ins)
 
- 		(or (equal (char-before) ?:) (insert ":"))
 
- 		(insert ins)
 
- 		(or (equal (char-after) ?:) (insert ":"))
 
- 		(and (org-at-heading-p) (org-set-tags nil 'align)))))
 
- 	   ((equal char "C")
 
- 	    (cond ((= (length clipboards) 1) (insert (car clipboards)))
 
- 		  ((> (length clipboards) 1)
 
- 		   (insert (read-string "Clipboard/kill value: "
 
- 					(car clipboards) '(clipboards . 1)
 
- 					(car clipboards))))))
 
- 	   ((equal char "L")
 
- 	    (cond ((= (length clipboards) 1)
 
- 		   (org-insert-link 0 (car clipboards)))
 
- 		  ((> (length clipboards) 1)
 
- 		   (org-insert-link 0 (read-string "Clipboard/kill value: "
 
- 						   (car clipboards)
 
- 						   '(clipboards . 1)
 
- 						   (car clipboards))))))
 
- 	   ((equal char "p")
 
- 	    (org-set-property (org-no-properties prompt) nil))
 
- 	   (char
 
- 	    ;; These are the date/time related ones
 
- 	    (setq org-time-was-given (equal (upcase char) char))
 
- 	    (setq time (org-read-date (equal (upcase char) char) t nil
 
- 				      prompt))
 
- 	    (if (equal (upcase char) char) (setq org-time-was-given t))
 
- 	    (org-insert-time-stamp time org-time-was-given
 
- 				   (member char '("u" "U"))
 
- 				   nil nil (list org-end-time-was-given)))
 
- 	   (t
 
- 	    (let (org-completion-use-ido)
 
- 	      (push (org-completing-read-no-i
 
- 		     (concat (if prompt prompt "Enter string")
 
- 			     (if default (concat " [" default "]"))
 
- 			     ": ")
 
- 		     completions nil nil nil histvar default)
 
- 		    strings)
 
- 	      (insert (car strings)))))))
 
-       ;; Replace %n escapes with nth %^{...} string
 
-       (setq strings (nreverse strings))
 
-       (goto-char (point-min))
 
-       (while (re-search-forward "%\\\\\\([1-9][0-9]*\\)" nil t)
 
- 	(unless (org-capture-escaped-%)
 
- 	  (replace-match
 
- 	   (nth (1- (string-to-number (match-string 1))) strings)
 
- 	   nil t)))
 
-       ;; Make sure there are no empty lines before the text, and that
 
-       ;; it ends with a newline character
 
-       (goto-char (point-min))
 
-       (while (looking-at "[ \t]*\n") (replace-match ""))
 
-       (if (re-search-forward "[ \t\n]*\\'" nil t) (replace-match "\n"))
 
-       ;; Return the expanded template and kill the temporary buffer
 
-       (untabify (point-min) (point-max))
 
-       (set-buffer-modified-p nil)
 
-       (prog1 (buffer-string) (kill-buffer (current-buffer))))))
 
- (defun org-capture-escaped-% ()
 
-   "Check if % was escaped - if yes, unescape it now."
 
-   (if (equal (char-before (match-beginning 0)) ?\\)
 
-       (progn
 
- 	(delete-region (1- (match-beginning 0)) (match-beginning 0))
 
- 	t)
 
-     nil))
 
- (defun org-capture-expand-embedded-elisp ()
 
-   "Evaluate embedded elisp %(sexp) and replace with the result."
 
-   (goto-char (point-min))
 
-   (while (re-search-forward "%(" nil t)
 
-     (unless (org-capture-escaped-%)
 
-       (goto-char (match-beginning 0))
 
-       (let ((template-start (point)))
 
- 	(forward-char 1)
 
- 	(let ((result (org-eval
 
- 		       (org-capture--expand-keyword-in-embedded-elisp
 
- 			(read (current-buffer))))))
 
- 	  (delete-region template-start (point))
 
- 	  (insert result))))))
 
- (defun org-capture--expand-keyword-in-embedded-elisp (attr)
 
-   "Recursively replace capture link keywords in ATTR sexp.
 
- Such keywords are prefixed with \"%:\".  See
 
- `org-capture-template' for more information."
 
-   (cond ((consp attr)
 
- 	 (mapcar 'org-capture--expand-keyword-in-embedded-elisp attr))
 
- 	((symbolp attr)
 
- 	 (let* ((attr-symbol (symbol-name attr))
 
- 		(key (and (string-match "%\\(:.*\\)" attr-symbol)
 
- 			  (intern (match-string 1 attr-symbol)))))
 
- 	   (or (plist-get org-store-link-plist key)
 
- 	       attr)))
 
- 	(t attr)))
 
- (defun org-capture-inside-embedded-elisp-p ()
 
-   "Return non-nil if point is inside of embedded elisp %(sexp)."
 
-   (let (beg end)
 
-     (with-syntax-table emacs-lisp-mode-syntax-table
 
-       (save-excursion
 
- 	;; `looking-at' and `search-backward' below do not match the "%(" if
 
- 	;; point is in its middle
 
- 	(when (equal (char-before) ?%)
 
- 	  (backward-char))
 
- 	(save-match-data
 
- 	  (when (or (looking-at "%(") (search-backward "%(" nil t))
 
- 	    (setq beg (point))
 
- 	    (setq end (progn (forward-char) (forward-sexp) (1- (point)))))))
 
-       (when (and beg end)
 
- 	(and (<= (point) end) (>= (point) beg))))))
 
- ;;;###autoload
 
- (defun org-capture-import-remember-templates ()
 
-   "Set org-capture-templates to be similar to `org-remember-templates'."
 
-   (interactive)
 
-   (when (and (yes-or-no-p
 
- 	      "Import old remember templates into org-capture-templates? ")
 
- 	     (yes-or-no-p
 
- 	      "Note that this will remove any templates currently defined in `org-capture-templates'.  Do you still want to go ahead? "))
 
-     (require 'org-remember)
 
-     (setq org-capture-templates
 
- 	  (mapcar
 
- 	   (lambda (entry)
 
- 	     (let ((desc (car entry))
 
- 		   (key (char-to-string (nth 1 entry)))
 
- 		   (template (nth 2 entry))
 
- 		   (file (or (nth 3 entry) org-default-notes-file))
 
- 		   (position (or (nth 4 entry) org-remember-default-headline))
 
- 		   (type 'entry)
 
- 		   (prepend org-reverse-note-order)
 
- 		   immediate target)
 
- 	       (cond
 
- 		((member position '(top bottom))
 
- 		 (setq target (list 'file file)
 
- 		       prepend (eq position 'top)))
 
- 		((eq position 'date-tree)
 
- 		 (setq target (list 'file+datetree file)
 
- 		       prepend nil))
 
- 		(t (setq target (list 'file+headline file position))))
 
- 	       (when (string-match "%!" template)
 
- 		 (setq template (replace-match "" t t template)
 
- 		       immediate t))
 
- 	       (append (list key desc type target template)
 
- 		       (if prepend '(:prepend t))
 
- 		       (if immediate '(:immediate-finish t)))))
 
- 	   org-remember-templates))))
 
- (provide 'org-capture)
 
- ;;; org-capture.el ends here
 
 
  |