mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-21 18:23:59 +00:00
8d64207425
* org.el (org-set-tags-to): New command. * org-latex.el (org-export-latex-set-initial-vars): Also check in the plist. * org.el (org-additional-option-like-keywords): Add LATEX_CLASS keyword. * org-exp.el (org-infile-export-plist): Add LATEX_CLASS keyword. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-inlinetask.el (org-inlinetask-export): Option removed. (org-inlinetask-export-handler): Better export. * org-xoxo.el (org-export-xoxo-final-hook): New hook. (org-export-as-xoxo): Run the new hook. * org-html.el (org-export-html-final-hook): New hook. (org-export-as-html): Run the new hook. * org-docbook.el (org-export-docbook-final-hook): New hook. (org-export-as-docbook): Run the new hook. * org-ascii.el (org-export-ascii-final-hook): New hook. (org-export-as-ascii): Run the new hook. * org-latex.el (org-export-latex-treat-sub-super-char): Allow a space character as the character before the ^/_. (org-export-latex-final-hook): New hook. (org-export-as-latex): Run `org-export-latex-final-hook'. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-macs.el (org-if-unprotected-at): Fix docstring. * org-agenda.el (org-agenda-change-all-lines): Handle invisible text in the prefix (if category is a link). * org-latex.el (org-export-latex-preprocess): Deal properly with empty lines in verse environments. * org.el (org-format-latex-header): Inline fullpage.sty. * org-footnote.el (org-footnote-create-definition): Reveal context to add a new footnote definition. * org.el (org-ctrl-c-ctrl-c): Pass prefix arg to org-table-recalculate when cursor is in TBLFM line. * org-list.el (org-renumber-ordered-list): Fix cursor position when bullet length has changed. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org.el (org-format-latex): Mention `org-format-latex-options' in the docstring. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org.el (org-agenda-get): New function. * org-agenda.el (org-agenda-post-command-hook): No longer move point away from end of line. (org-agenda-add-entry-text, org-agenda-collect-markers) (org-finalize-agenda, org-agenda-mark-clocking-task) (org-agenda-dim-blocked-tasks, org-agenda-entry-text-show-here) (org-agenda-entry-text-show, org-agenda-highlight-todo) (org-agenda-compare-effort, org-agenda-filter-apply) (org-agenda-later, org-agenda-change-time-span) (org-agenda-post-command-hook, org-agenda-show-priority) (org-agenda-show-tags, org-agenda-goto, org-agenda-kill) (org-agenda-archive, org-agenda-archive-to-archive-sibling) (org-remove-subtree-entries-from-agenda, org-agenda-refile) (org-agenda-open-link, org-agenda-copy-local-variable) (org-agenda-switch-to, org-agenda-check-no-diary) (org-agenda-tree-to-indirect-buffer, org-agenda-todo) (org-agenda-add-note, org-agenda-change-all-lines) (org-agenda-priority, org-agenda-set-tags) (org-agenda-set-property, org-agenda-set-effort) (org-agenda-toggle-archive-tag, org-agenda-date-later) (org-agenda-show-new-time, org-agenda-date-prompt) (org-agenda-schedule, org-agenda-deadline, org-agenda-action) (org-agenda-clock-in, org-agenda-bulk-mark) (org-agenda-bulk-unmark, org-agenda-show-the-flagging-note): Use `org-get-at-bol'. * org-colview.el (org-columns-display-here) (org-columns-edit-allowed, org-agenda-columns): Use `org-get-at-bol'. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org.el (org-special-ctrl-a/e): Improve documentation and customize type. (org-end-of-line): Don't jump to after the ellipsis. (org-mode-map): Bind <home> and <end> as well. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org.el (org-fontify-meta-lines-and-blocks): Treat lines with a space after #+ as comments. (org-open-at-point): Run `org-follow-link-hook' always. * org-latex.el (org-export-latex-emph-format): Use better commands to insert special characters in verbatim snippets. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-faces.el (org-copy-face): New function. Use it to create various faces formerly created by using `copy-face'. * org-agenda.el (org-prepare-agenda): Don't officially mark this window dedicated. (org-agenda-quit): Kill the frame containing the agenda window if that frame was created for the agenda. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-agenda.el (org-agenda-date-prompt): Mark the changed time stamp in the agenda. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-agenda.el (org-prepare-agenda): Reset `org-drawers-for-agenda'. (org-prepare-agenda): Uniquify list of drawers. * org.el (org-complex-heading-regexp-format): New variable. (org-set-regexps-and-options): Define `org-complex-heading-regexp-format'. (org-drawers-for-agenda): New variable. (org-map-entries): Bind `org-drawers-for-agenda'. (org-prepare-agenda-buffers): Add to `org-drawers-for-agenda'. * org-remember.el (org-go-to-remember-target) (org-remember-handler): Use `org-complex-heading-regexp-format'. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-agenda.el (org-agenda-highlight-todo): Fix text property problem. * org.el (org-on-heading-p, org-at-heading-p): Make sure these are always with `invisible-ok'. (org-store-link): No error when there is nothing to link to in the agenda. * org-list.el (org-update-checkbox-count): Insert changed cookie before the old, to avoid problems with invisibility at the end of the line. (org-update-checkbox-count): Insert changed cookie before the old, to avoid problems with invisibility at the end of the line. * org.el (org-sort-entries-or-items): Include the final newline. (org-fontify-meta-lines-and-blocks): Add indented dynamic block lines for fontification. (org-dblock-start-re, org-dblock-end-re): Allow indentation. (org-prepare-dblock): Store the current indentation of the BEGIN line. (org-update-dblock): Apply the indentation of the begin line to the rest of the block. (org-ctrl-c-ctrl-c): Also find indented dblock lines. (org-startup-folded): New allowed value `showeverything'. (org-startup-options): Add STARTUP keyword `showeverything'. (org-set-startup-visibility): Respect value `showeverything' in org-startup-folded. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org.el (org-closest-date): Fix issue with past preference. * org-archive.el (org-archive-set-tag) (org-archive-subtree-default): New commands. * org-clock.el (org-clock-clocktable-default-properties): New option. (org-clock-report): Use `org-clock-clocktable-default-properties'. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org.el (org-iswitchb-completing-read): Fix typo. * org-crypt.el: New file. * org.el: Add an entry for org-crypt. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-agenda.el (org-agenda-menu): Reorganize the menu for more consistency. (org-batch-store-agenda-views): New function. (org-agenda-title-append): Define variable. (org-write-agenda): New export to Org files. (org-agenda-get-some-entry-text): New arguments INDENT and KEEP. (org-agenda): Allow to keep the restricted file list if a special variable is bound to t. (org-agenda): Define a special agenda view for working on flagged entries. (org-agenda-get-restriction-and-command): List the new agenda view. (org-agenda-show-the-flagging-note): New command. (org-agenda-mode-map): New key `?' for looking at the flagging note. * org.el (org-autoload): Autoload org-mobile.el. (org-org-menu): Add menu commands for MobileOrg in the Org menu. * org-mobile.el: New file. * org-id.el (org-id-get): Fix bug with forcing ID on an item. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-table.el (orgtbl-line-start-regexp): Match also TBLNAME statements. (org-table-get-remote-range): Match indented #+TBLNAME statements. * org.el (org-convert-to-odd-levels) (org-convert-to-oddeven-levels): Work also correctly if the file is in outline-mode. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org.el (org-store-link): When in agenda buffer, link to referenced entry. (org-add-planning-info): Remove spaces at eol. * org-macs.el (org-with-point-at): Add a `lisp-indent-function' property. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-latex.el (org-export-latex-first-lines): Fix problem with LaTeX export of first line and selected subtree. * org.el (org-shifttab): Interpret arg differently when using only odd levels. 2009-10-01 Bastien Guerry <bzg@altern.org> * org.el (org-check-agenda-file): Use a more explicit message 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-exp.el (org-export-remove-special-table-lines): Don't remove normal lines. 2009-10-01 Bastien Guerry <bzg@altern.org> * org.el (org-offer-links-in-entry): Don't use "Select link" as a prompt in the temporary window. * org-agenda.el (org-agenda-bulk-mark): Use a slightly soberer prefix for marked entries in the agenda view. 2009-10-01 Andreas Burtzlaff <andy13@gmx.net> (tiny change) * org.el (outline-end-of-subtree): Bugfix: advise this function in a way that prevents any trailing character from being displayed. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-agenda.el (org-agenda-menu): Fix bugs in the bulk action menu. * org-exp.el (org-export-remove-special-table-lines): Remove bad slow regexp match. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-latex.el (org-export-latex-preprocess): Do not protect in the LaTeX header. * org-src.el (org-edit-src-save): Save window setup while saving. (org-edit-src-code): Use new buffer name construction scheme. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-agenda.el (org-agenda-entry-text-exclude-regexps): New variable. (org-agenda-entry-text-cleanup-hook): New hook. (org-agenda-get-some-entry-text): Remove matches of `org-agenda-entry-text-exclude-regexps' and run the hook `org-agenda-entry-text-cleanup-hook'. * org.el (org-offer-links-in-entry): New argument ZERO to implement a link with index zero. (org-cycle-show-empty-lines): Not keep empty line under header hidden. (org-iswitchb-completing-read): Bind `switchb-use-virtual-buffers' to nil for special completion. (org-store-link): Don't error before the first heading. * org-agenda.el (org-agenda-open-link): Pass the prefix to `org-offer-links-in-entry'. 2009-10-01 Carsten Dominik <carsten.dominik@gmail.com> * org-agenda.el (org-agenda-quit): Provide the window argument for `window-dedicated-p', Emacs 22 needs it. (org-format-agenda-item): If the category is a link, arrange for invisible text to replaced with spaces. (org-compile-prefix-format): Add the extra space. (org-prefix-category-length): New variable. * org-exp.el (org-export-cleanup-toc-line): Remove footnote references from TOC lines. * org.el (org-selected-window): New variable. * org-table.el (org-table-edit-formulas): Remember the selected window. (org-table-fedit-finish, org-table-fedit-abort): Select the window that was originally selected. * org-exp.el (org-export-preprocess-apply-macros): Scan the expansion of a macro for more macro definitions. * org-agenda.el (org-agenda-dim-blocked-tasks): Make sure the invisibility overlay starts on the newline.
511 lines
19 KiB
EmacsLisp
511 lines
19 KiB
EmacsLisp
;;; org-src.el --- Source code examples in Org
|
|
;;
|
|
;; Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009
|
|
;; Free Software Foundation, Inc.
|
|
;;
|
|
;; Author: Carsten Dominik <carsten at orgmode dot org>
|
|
;; Bastien Guerry <bzg AT altern DOT org>
|
|
;; Keywords: outlines, hypermedia, calendar, wp
|
|
;; Homepage: http://orgmode.org
|
|
;; Version: 6.31a
|
|
;;
|
|
;; 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 the code dealing with source code examples in Org-mode.
|
|
|
|
;;; Code:
|
|
|
|
(require 'org-macs)
|
|
(require 'org-compat)
|
|
|
|
(declare-function org-do-remove-indentation "org" (&optional n))
|
|
(declare-function org-get-indentation "org" (&optional line))
|
|
|
|
(defcustom org-edit-src-region-extra nil
|
|
"Additional regexps to identify regions for editing with `org-edit-src-code'.
|
|
For examples see the function `org-edit-src-find-region-and-lang'.
|
|
The regular expression identifying the begin marker should end with a newline,
|
|
and the regexp marking the end line should start with a newline, to make sure
|
|
there are kept outside the narrowed region."
|
|
:group 'org-edit-structure
|
|
:type '(repeat
|
|
(list
|
|
(regexp :tag "begin regexp")
|
|
(regexp :tag "end regexp")
|
|
(choice :tag "language"
|
|
(string :tag "specify")
|
|
(integer :tag "from match group")
|
|
(const :tag "from `lang' element")
|
|
(const :tag "from `style' element")))))
|
|
|
|
(defcustom org-coderef-label-format "(ref:%s)"
|
|
"The default coderef format.
|
|
This format string will be used to search for coderef labels in literal
|
|
examples (EXAMPLE and SRC blocks). The format can be overwritten in
|
|
an individual literal example with the -f option, like
|
|
|
|
#+BEGIN_SRC pascal +n -r -l \"((%s))\"
|
|
...
|
|
#+END_SRC
|
|
|
|
If you want to use this for HTML export, make sure that the format does
|
|
not introduce special font-locking, and avoid the HTML special
|
|
characters `<', `>', and `&'. The reason for this restriction is that
|
|
the labels are searched for only after htmlize has done its job."
|
|
:group 'org-edit-structure ; FIXME this is not in the right group
|
|
:type 'string)
|
|
|
|
(defcustom org-edit-fixed-width-region-mode 'artist-mode
|
|
"The mode that should be used to edit fixed-width regions.
|
|
These are the regions where each line starts with a colon."
|
|
:group 'org-edit-structure
|
|
:type '(choice
|
|
(const artist-mode)
|
|
(const picture-mode)
|
|
(const fundamental-mode)
|
|
(function :tag "Other (specify)")))
|
|
|
|
(defcustom org-edit-src-content-indentation 2
|
|
"Indentation for the content is a source code block.
|
|
This should be the number of spaces added to the indentation of the #+begin
|
|
line in order to compute the indentation of the block content after
|
|
editing it with \\[org-edit-src-code]."
|
|
:group 'org-edit-structure
|
|
:type 'integer)
|
|
|
|
(defcustom org-edit-src-persistent-message t
|
|
"Non-nil means show persistent exit help message while editing src examples.
|
|
The message is shown in the header-line, which will be created in the
|
|
first line of the window showing the editing buffer.
|
|
When nil, the message will only be shown intermittently in the echo area."
|
|
:group 'org-edit-structure
|
|
:type 'boolean)
|
|
|
|
|
|
(defvar org-src-mode-hook nil
|
|
"Hook run after Org switched a source code snippet to its Emacs mode.
|
|
This hook will run
|
|
|
|
- when editing a source code snippet with \"C-c '\".
|
|
- When formatting a source code snippet for export with htmlize.
|
|
|
|
You may want to use this hook for example to turn off `outline-minor-mode'
|
|
or similar things which you want to have when editing a source code file,
|
|
but which mess up the display of a snippet in Org exported files.")
|
|
|
|
(defcustom org-src-lang-modes
|
|
'(("ocaml" . tuareg) ("elisp" . emacs-lisp) ("ditaa" . artist)
|
|
("asymptote" . asy))
|
|
"Alist mapping languages to their major mode.
|
|
The key is the language name, the value is the string that should
|
|
be inserted as the name of the major mode. For many languages this is
|
|
simple, but for language where this is not the case, this variable
|
|
provides a way to simplify things on the user side.
|
|
For example, there is no ocaml-mode in Emacs, but the mode to use is
|
|
`tuareg-mode'."
|
|
:group 'org-edit-structure
|
|
:type '(repeat
|
|
(cons
|
|
(string "Language name")
|
|
(symbol "Major mode"))))
|
|
|
|
;;; Editing source examples
|
|
|
|
(defvar org-src-mode-map (make-sparse-keymap))
|
|
(define-key org-src-mode-map "\C-c'" 'org-edit-src-exit)
|
|
(defvar org-edit-src-force-single-line nil)
|
|
(defvar org-edit-src-from-org-mode nil)
|
|
(defvar org-edit-src-picture nil)
|
|
(defvar org-edit-src-beg-marker nil)
|
|
(defvar org-edit-src-end-marker nil)
|
|
(defvar org-edit-src-overlay nil)
|
|
(defvar org-edit-src-nindent nil)
|
|
|
|
(define-minor-mode org-src-mode
|
|
"Minor mode for language major mode buffers generated by org.
|
|
This minor mode is turned on in two situations:
|
|
- when editing a source code snippet with \"C-c '\".
|
|
- When formatting a source code snippet for export with htmlize.
|
|
There is a mode hook, and keybindings for `org-edit-src-exit' and
|
|
`org-edit-src-save'")
|
|
|
|
(defun org-edit-src-code ()
|
|
"Edit the source code example at point.
|
|
The example is copied to a separate buffer, and that buffer is switched
|
|
to the correct language mode. When done, exit with \\[org-edit-src-exit].
|
|
This will remove the original code in the Org buffer, and replace it with
|
|
the edited version."
|
|
(interactive)
|
|
(let ((line (org-current-line))
|
|
(case-fold-search t)
|
|
(msg (substitute-command-keys
|
|
"Edit, then exit with C-c ' (C-c and single quote)"))
|
|
(info (org-edit-src-find-region-and-lang))
|
|
(org-mode-p (eq major-mode 'org-mode))
|
|
(beg (make-marker))
|
|
(end (make-marker))
|
|
nindent ovl lang lang-f single lfmt code begline buffer)
|
|
(if (not info)
|
|
nil
|
|
(setq beg (move-marker beg (nth 0 info))
|
|
end (move-marker end (nth 1 info))
|
|
code (buffer-substring-no-properties beg end)
|
|
lang (or (cdr (assoc (nth 2 info) org-src-lang-modes))
|
|
(nth 2 info))
|
|
lang (if (symbolp lang) (symbol-name lang) lang)
|
|
single (nth 3 info)
|
|
lfmt (nth 4 info)
|
|
nindent (nth 5 info)
|
|
lang-f (intern (concat lang "-mode"))
|
|
begline (save-excursion (goto-char beg) (org-current-line)))
|
|
(unless (functionp lang-f)
|
|
(error "No such language mode: %s" lang-f))
|
|
(org-goto-line line)
|
|
(if (and (setq buffer (org-edit-src-find-buffer beg end))
|
|
(y-or-n-p "Return to existing edit buffer? [n] will revert changes: "))
|
|
(switch-to-buffer buffer)
|
|
(when buffer
|
|
(with-current-buffer buffer
|
|
(if (boundp 'org-edit-src-overlay)
|
|
(org-delete-overlay org-edit-src-overlay)))
|
|
(kill-buffer buffer))
|
|
(setq buffer (generate-new-buffer
|
|
(org-src-construct-edit-buffer-name (buffer-name) lang)))
|
|
(setq ovl (org-make-overlay beg end))
|
|
(org-overlay-put ovl 'face 'secondary-selection)
|
|
(org-overlay-put ovl 'edit-buffer buffer)
|
|
(org-overlay-put ovl 'help-echo "Click with mouse-1 to switch to buffer editing this segment")
|
|
(org-overlay-put ovl 'face 'secondary-selection)
|
|
(org-overlay-put ovl
|
|
'keymap
|
|
(let ((map (make-sparse-keymap)))
|
|
(define-key map [mouse-1] 'org-edit-src-continue)
|
|
map))
|
|
(org-overlay-put ovl :read-only "Leave me alone")
|
|
(switch-to-buffer buffer)
|
|
(insert code)
|
|
(remove-text-properties (point-min) (point-max)
|
|
'(display nil invisible nil intangible nil))
|
|
(org-do-remove-indentation)
|
|
(let ((org-inhibit-startup t))
|
|
(funcall lang-f))
|
|
(set (make-local-variable 'org-edit-src-force-single-line) single)
|
|
(set (make-local-variable 'org-edit-src-from-org-mode) org-mode-p)
|
|
(when lfmt
|
|
(set (make-local-variable 'org-coderef-label-format) lfmt))
|
|
(when org-mode-p
|
|
(goto-char (point-min))
|
|
(while (re-search-forward "^," nil t)
|
|
(replace-match "")))
|
|
(org-goto-line (1+ (- line begline)))
|
|
(org-set-local 'org-edit-src-beg-marker beg)
|
|
(org-set-local 'org-edit-src-end-marker end)
|
|
(org-set-local 'org-edit-src-overlay ovl)
|
|
(org-set-local 'org-edit-src-nindent nindent)
|
|
(org-src-mode)
|
|
(set-buffer-modified-p nil)
|
|
(and org-edit-src-persistent-message
|
|
(org-set-local 'header-line-format msg)))
|
|
(message "%s" msg)
|
|
t)))
|
|
|
|
(defun org-edit-src-continue (e)
|
|
(interactive "e")
|
|
(mouse-set-point e)
|
|
(let ((buf (get-char-property (point) 'edit-buffer)))
|
|
(if buf (switch-to-buffer buf)
|
|
(error "Something is wrong here"))))
|
|
|
|
(defun org-src-construct-edit-buffer-name (org-buffer-name lang)
|
|
"Construct the buffer name for a source editing buffer"
|
|
(concat "*Org Src " org-buffer-name "[ " lang " ]*"))
|
|
|
|
(defun org-edit-src-find-buffer (beg end)
|
|
"Find a source editing buffer that is already editing the region BEG to END."
|
|
(catch 'exit
|
|
(mapc
|
|
(lambda (b)
|
|
(with-current-buffer b
|
|
(if (and (string-match "\\`*Org Src " (buffer-name))
|
|
(local-variable-p 'org-edit-src-beg-marker (current-buffer))
|
|
(local-variable-p 'org-edit-src-end-marker (current-buffer))
|
|
(equal beg org-edit-src-beg-marker)
|
|
(equal end org-edit-src-end-marker))
|
|
(throw 'exit (current-buffer)))))
|
|
(buffer-list))
|
|
nil))
|
|
|
|
(defun org-edit-fixed-width-region ()
|
|
"Edit the fixed-width ascii drawing at point.
|
|
This must be a region where each line starts with a colon followed by
|
|
a space character.
|
|
An new buffer is created and the fixed-width region is copied into it,
|
|
and the buffer is switched into `artist-mode' for editing. When done,
|
|
exit with \\[org-edit-src-exit]. The edited text will then replace
|
|
the fragment in the Org-mode buffer."
|
|
(interactive)
|
|
(let ((line (org-current-line))
|
|
(case-fold-search t)
|
|
(msg (substitute-command-keys
|
|
"Edit, then exit with C-c ' (C-c and single quote)"))
|
|
(org-mode-p (eq major-mode 'org-mode))
|
|
(beg (make-marker))
|
|
(end (make-marker))
|
|
nindent ovl beg1 end1 code begline buffer)
|
|
(beginning-of-line 1)
|
|
(if (looking-at "[ \t]*[^:\n \t]")
|
|
nil
|
|
(if (looking-at "[ \t]*\\(\n\\|\\'\\)")
|
|
(setq beg1 (point) end1 beg1)
|
|
(save-excursion
|
|
(if (re-search-backward "^[ \t]*[^: \t]" nil 'move)
|
|
(setq beg1 (point-at-bol 2))
|
|
(setq beg1 (point))))
|
|
(save-excursion
|
|
(if (re-search-forward "^[ \t]*[^: \t]" nil 'move)
|
|
(setq end1 (1- (match-beginning 0)))
|
|
(setq end1 (point))))
|
|
(org-goto-line line))
|
|
(setq beg (move-marker beg beg1)
|
|
end (move-marker end end1)
|
|
code (buffer-substring-no-properties beg end)
|
|
begline (save-excursion (goto-char beg) (org-current-line)))
|
|
(if (and (setq buffer (org-edit-src-find-buffer beg end))
|
|
(y-or-n-p "Return to existing edit buffer? [n] will revert changes: "))
|
|
(switch-to-buffer buffer)
|
|
(when buffer
|
|
(with-current-buffer buffer
|
|
(if (boundp 'org-edit-src-overlay)
|
|
(org-delete-overlay org-edit-src-overlay)))
|
|
(kill-buffer buffer))
|
|
(setq buffer (generate-new-buffer
|
|
(org-src-construct-edit-buffer-name
|
|
(buffer-name) "Fixed Width")))
|
|
(setq ovl (org-make-overlay beg end))
|
|
(org-overlay-put ovl 'face 'secondary-selection)
|
|
(org-overlay-put ovl 'edit-buffer buffer)
|
|
(org-overlay-put ovl 'help-echo "Click with mouse-1 to switch to buffer editing this segment")
|
|
(org-overlay-put ovl 'face 'secondary-selection)
|
|
(org-overlay-put ovl
|
|
'keymap
|
|
(let ((map (make-sparse-keymap)))
|
|
(define-key map [mouse-1] 'org-edit-src-continue)
|
|
map))
|
|
(org-overlay-put ovl :read-only "Leave me alone")
|
|
(switch-to-buffer buffer)
|
|
(insert code)
|
|
(remove-text-properties (point-min) (point-max)
|
|
'(display nil invisible nil intangible nil))
|
|
(setq nindent (org-do-remove-indentation))
|
|
(cond
|
|
((eq org-edit-fixed-width-region-mode 'artist-mode)
|
|
(fundamental-mode)
|
|
(artist-mode 1))
|
|
(t (funcall org-edit-fixed-width-region-mode)))
|
|
(set (make-local-variable 'org-edit-src-force-single-line) nil)
|
|
(set (make-local-variable 'org-edit-src-from-org-mode) org-mode-p)
|
|
(set (make-local-variable 'org-edit-src-picture) t)
|
|
(goto-char (point-min))
|
|
(while (re-search-forward "^[ \t]*: ?" nil t)
|
|
(replace-match ""))
|
|
(org-goto-line (1+ (- line begline)))
|
|
(org-set-local 'org-edit-src-beg-marker beg)
|
|
(org-set-local 'org-edit-src-end-marker end)
|
|
(org-set-local 'org-edit-src-overlay ovl)
|
|
(org-set-local 'org-edit-src-nindent nindent)
|
|
(org-src-mode)
|
|
(set-buffer-modified-p nil)
|
|
(and org-edit-src-persistent-message
|
|
(org-set-local 'header-line-format msg)))
|
|
(message "%s" msg)
|
|
t)))
|
|
|
|
(defun org-edit-src-find-region-and-lang ()
|
|
"Find the region and language for a local edit.
|
|
Return a list with beginning and end of the region, a string representing
|
|
the language, a switch telling of the content should be in a single line."
|
|
(let ((re-list
|
|
(append
|
|
org-edit-src-region-extra
|
|
'(
|
|
("<src\\>[^<]*>[ \t]*\n?" "\n?[ \t]*</src>" lang)
|
|
("<literal\\>[^<]*>[ \t]*\n?" "\n?[ \t]*</literal>" style)
|
|
("<example>[ \t]*\n?" "\n?[ \t]*</example>" "fundamental")
|
|
("<lisp>[ \t]*\n?" "\n?[ \t]*</lisp>" "emacs-lisp")
|
|
("<perl>[ \t]*\n?" "\n?[ \t]*</perl>" "perl")
|
|
("<python>[ \t]*\n?" "\n?[ \t]*</python>" "python")
|
|
("<ruby>[ \t]*\n?" "\n?[ \t]*</ruby>" "ruby")
|
|
("^[ \t]*#\\+begin_src\\( \\([^ \t\n]+\\)\\)?.*\n" "\n[ \t]*#\\+end_src" 2)
|
|
("^[ \t]*#\\+begin_example.*\n" "\n[ \t]*#\\+end_example" "fundamental")
|
|
("^[ \t]*#\\+html:" "\n" "html" single-line)
|
|
("^[ \t]*#\\+begin_html.*\n" "\n[ \t]*#\\+end_html" "html")
|
|
("^[ \t]*#\\+latex:" "\n" "latex" single-line)
|
|
("^[ \t]*#\\+begin_latex.*\n" "\n[ \t]*#\\+end_latex" "latex")
|
|
("^[ \t]*#\\+ascii:" "\n" "fundamental" single-line)
|
|
("^[ \t]*#\\+begin_ascii.*\n" "\n[ \t]*#\\+end_ascii" "fundamental")
|
|
("^[ \t]*#\\+docbook:" "\n" "xml" single-line)
|
|
("^[ \t]*#\\+begin_docbook.*\n" "\n[ \t]*#\\+end_docbook" "xml")
|
|
)))
|
|
(pos (point))
|
|
re1 re2 single beg end lang lfmt match-re1 ind entry)
|
|
(catch 'exit
|
|
(while (setq entry (pop re-list))
|
|
(setq re1 (car entry) re2 (nth 1 entry) lang (nth 2 entry)
|
|
single (nth 3 entry))
|
|
(save-excursion
|
|
(if (or (looking-at re1)
|
|
(re-search-backward re1 nil t))
|
|
(progn
|
|
(setq match-re1 (match-string 0))
|
|
(setq beg (match-end 0)
|
|
lang (org-edit-src-get-lang lang)
|
|
lfmt (org-edit-src-get-label-format match-re1)
|
|
ind (org-edit-src-get-indentation (match-beginning 0)))
|
|
(if (and (re-search-forward re2 nil t)
|
|
(>= (match-end 0) pos))
|
|
(throw 'exit (list beg (match-beginning 0)
|
|
lang single lfmt ind))))
|
|
(if (or (looking-at re2)
|
|
(re-search-forward re2 nil t))
|
|
(progn
|
|
(setq end (match-beginning 0))
|
|
(if (and (re-search-backward re1 nil t)
|
|
(<= (match-beginning 0) pos))
|
|
(progn
|
|
(setq lfmt (org-edit-src-get-label-format
|
|
(match-string 0))
|
|
ind (org-edit-src-get-indentation
|
|
(match-beginning 0)))
|
|
(throw 'exit
|
|
(list (match-end 0) end
|
|
(org-edit-src-get-lang lang)
|
|
single lfmt ind))))))))))))
|
|
|
|
(defun org-edit-src-get-lang (lang)
|
|
"Extract the src language."
|
|
(let ((m (match-string 0)))
|
|
(cond
|
|
((stringp lang) lang)
|
|
((integerp lang) (match-string lang))
|
|
((and (eq lang 'lang)
|
|
(string-match "\\<lang=\"\\([^ \t\n\"]+\\)\"" m))
|
|
(match-string 1 m))
|
|
((and (eq lang 'style)
|
|
(string-match "\\<style=\"\\([^ \t\n\"]+\\)\"" m))
|
|
(match-string 1 m))
|
|
(t "fundamental"))))
|
|
|
|
(defun org-edit-src-get-label-format (s)
|
|
"Extract the label format."
|
|
(save-match-data
|
|
(if (string-match "-l[ \t]+\\\\?\"\\([^\t\r\n\"]+\\)\\\\?\"" s)
|
|
(match-string 1 s))))
|
|
|
|
(defun org-edit-src-get-indentation (pos)
|
|
"Extract the label format."
|
|
(save-match-data
|
|
(goto-char pos)
|
|
(org-get-indentation)))
|
|
|
|
(defun org-edit-src-exit ()
|
|
"Exit special edit and protect problematic lines."
|
|
(interactive)
|
|
(unless org-edit-src-from-org-mode
|
|
(error "This is not a sub-editing buffer, something is wrong..."))
|
|
(let ((beg org-edit-src-beg-marker)
|
|
(end org-edit-src-end-marker)
|
|
(ovl org-edit-src-overlay)
|
|
(buffer (current-buffer))
|
|
(nindent org-edit-src-nindent)
|
|
code line)
|
|
(untabify (point-min) (point-max))
|
|
(save-excursion
|
|
(goto-char (point-min))
|
|
(if (looking-at "[ \t\n]*\n") (replace-match ""))
|
|
(if (re-search-forward "\n[ \t\n]*\\'" nil t) (replace-match "")))
|
|
(setq line (if (org-bound-and-true-p org-edit-src-force-single-line)
|
|
1
|
|
(org-current-line)))
|
|
(when (org-bound-and-true-p org-edit-src-force-single-line)
|
|
(goto-char (point-min))
|
|
(while (re-search-forward "\n" nil t)
|
|
(replace-match " "))
|
|
(goto-char (point-min))
|
|
(if (looking-at "\\s-*") (replace-match " "))
|
|
(if (re-search-forward "\\s-+\\'" nil t)
|
|
(replace-match "")))
|
|
(when (org-bound-and-true-p org-edit-src-from-org-mode)
|
|
(goto-char (point-min))
|
|
(while (re-search-forward
|
|
(if (org-mode-p) "^\\(.\\)" "^\\([*]\\|[ \t]*#\\+\\)") nil t)
|
|
(replace-match ",\\1")))
|
|
(when (org-bound-and-true-p org-edit-src-picture)
|
|
(untabify (point-min) (point-max))
|
|
(goto-char (point-min))
|
|
(while (re-search-forward "^" nil t)
|
|
(replace-match ": ")))
|
|
(when nindent
|
|
(setq nindent (make-string (+ org-edit-src-content-indentation nindent)
|
|
?\ ))
|
|
(goto-char (point-min))
|
|
(while (re-search-forward "^" nil t)
|
|
(replace-match nindent)))
|
|
(setq code (buffer-string))
|
|
(set-buffer-modified-p nil)
|
|
(switch-to-buffer (marker-buffer beg))
|
|
(kill-buffer buffer)
|
|
(goto-char beg)
|
|
(delete-region beg end)
|
|
(insert code)
|
|
(goto-char beg)
|
|
(org-goto-line (1- (+ (org-current-line) line)))
|
|
(move-marker beg nil)
|
|
(move-marker end nil)))
|
|
|
|
(defun org-edit-src-save ()
|
|
"Save parent buffer with current state source-code buffer."
|
|
(interactive)
|
|
(save-window-excursion
|
|
(let ((p (point)) (m (mark)) msg)
|
|
(org-edit-src-exit)
|
|
(save-buffer)
|
|
(setq msg (current-message))
|
|
(org-edit-src-code)
|
|
(push-mark m 'nomessage)
|
|
(goto-char (min p (point-max)))
|
|
(message (or msg "")))))
|
|
|
|
(defun org-src-mode-configure-edit-buffer ()
|
|
(when org-edit-src-from-org-mode
|
|
(setq buffer-offer-save t)
|
|
(setq buffer-file-name
|
|
(concat (buffer-file-name (marker-buffer org-edit-src-beg-marker))
|
|
"[" (buffer-name) "]"))
|
|
(set (if (featurep 'xemacs) 'write-contents-hooks 'write-contents-functions)
|
|
'(org-edit-src-save))
|
|
(org-add-hook 'kill-buffer-hook
|
|
'(lambda () (org-delete-overlay org-edit-src-overlay)) nil 'local)))
|
|
|
|
(org-add-hook 'org-src-mode-hook 'org-src-mode-configure-edit-buffer)
|
|
|
|
(provide 'org-src)
|
|
|
|
;; arch-tag: 6a1fc84f-dec7-47be-a416-64be56bea5d8
|
|
;;; org-src.el ends here
|