Mercurial > emacs
comparison lisp/org/org-compat.el @ 94414:d86cb59eea9f
2008-04-27 Carsten Dominik <dominik@science.uva.nl>
* org/org.el (org-html-level-start): Always have id's in HTML
(org-export-as-html): Use `org-link-protocols' to
retrieve the export form of the link.
(org-add-link-type): Final parameter renamed from PUBLISH. Better
documentation of how it is to be used. Avoid double entries for
the same link type.
(org-add-link-props): New function.
(org-modules-loaded): New variable.
(org-load-modules-maybe, org-set-modules): New function.
(org-modules): New option.
(org-mode, org-cycle, orgstruct-mode, org-run-like-in-org-mode)
(orgtbl-mode, org-store-link, org-insert-link-global)
(org-open-at-point): Call `org-load-modules-maybe'.
(org-search-view): Add more text properties.
(org-agenda-schedule, org-agenda-deadline): Allow also in
search-type agendas.
(org-search-view): Order of arguments has been changed.
Interpret prefix-arg as TODO-ONLY.
(org-agenda, org-run-agenda-series, org-agenda-manipulate-query):
Take new argument order of `org-search-view' into account.
(org-todo-only): New variable.
(org-search-syntax-table): New variable and function.
(org-search-view): Do the search with the special syntax table.
(define-obsolete-function-alias): Make work with XEmacs.
(org-add-planning-info): Use old date as default when modifying an
existing deadline or scheduled item.
(org-agenda-compute-time-span): Make argument N optional.
(org-agenda-format-date-aligned): Require `cal-iso'.
(org-agenda-list): Include week into into agenda heading, don't
list it at each date (only on Mondays).
(org-read-date-analyze): Define local variable `iso-date'.
(org-agenda-format-date-aligned): Remove dependency on
`calendar-time-from-absolute'.
(org-remember-apply-template, org-go-to-remember-target):
Interpret filenames relative to `org-directory'.
(org-complete): Silently fail when trying to complete
keywords that don't have a default value.
(org-get-current-options): Added a #+DATE: option.
(org-additional-option-like-keywords): Removed "DATE:" from the
list of additional keywords.
(org-export-as-html): Removed (current-time) as unnecessary second
argument of `format-time-string'.
(org-clock-find-position): Handle special case at end of
buffer.
(org-agenda-day-view): New argument DAY-OF-YEAR, pass it on to
`org-agenda-change-time-span'.
(org-agenda-week-view): New argument ISO-WEEK, pass it on to
`org-agenda-change-time-span'.
(org-agenda-month-view): New argument MONTH, pass it on to
`org-agenda-change-time-span'.
(org-agenda-year-view): New argument YEAR, pass it on to
`org-agenda-change-time-span'.
(org-agenda-change-time-span): New optional argument N, pass it on
to `org-agenda-compute-time-span'.
(org-agenda-compute-time-span): New argument N, interpret it by
changing the starting day.
(org-small-year-to-year): New function.
(org-scheduled-past-days): Respect
`org-scheduled-past-days'.
(org-auto-repeat-maybe): Make sure that repeating
dates are pushed into the future, and that the shift is at least
one interval, never 0.
(org-update-checkbox-count): Fix bug with checkbox
counting.
(org-add-note): New command.
(org-add-log-setup): Renamed from `org-add-log-maybe'.
(org-log-note-headings): New entry for plain notes (i.e. notes not
related to state changes or clocking).
(org-get-org-file): Check for availability of
`remember-data-file'.
(org-cached-entry-get): Allow a regexp value for
`org-use-property-inheritance'.
(org-use-property-inheritance): Allow regexp value. Fix bug in
customization type.
(org-use-tag-inheritance): Allow a list and a regexp value for
this variable.
(org-scan-tags, org-get-tags-at): Implement selective tag
inheritance.
(org-entry-get): Respect value `selective' for the INHERIT
argument.
(org-tag-inherit-p, org-property-inherit-p): New functions.
(org-agenda-format-date-aligned): Allow 10 characters for
weekday, to acomodate German locale.
(org-add-archive-files): New function.
(org-agenda-files): New argument `ext', to
get archive files as well.
(org-tbl-menu): Protect the use of variables that
are only available when org-table.el gets loaded.
(org-read-agenda-file-list): Error if `org-agenda-files' is a
single directory.
(org-open-file): Allow a batch process to trigger
waiting after executing a system command.
(org-store-link): Link to headline when there is not
target and no region in an org-mode buffer when creating a link.
(org-link-types-re): New variable.
(org-make-link-regexps): Compute `org-link-types-re'.
(org-make-link-description-function): New option.
(org-agenda-date, org-agenda-date-weekend): New faces.
(org-archive-sibling-heading): New option.
(org-archive-to-archive-sibling): New function.
(org-iswitchb): New command.
(org-buffer-list): New function.
(org-agenda-columns): Also try the #+COLUMNS line in
the buffer associated with the entry at point (or with the first
entry in the agenda view).
(org-modules): Add entry for org-bibtex.el.
(org-completion-fallback-command): Moved into `org-completion'
group.
(org-clock-heading-function): Moved to `org-progress' group.
(org-auto-repeat-maybe): Make sure that a note can
be enforces if `org-log-repeat' is `note'.
(org-modules): Allow additional symbols for external
packages.
(org-ctrl-c-ctrl-c): Allow for `org-clock-overlays' to be
undefined.
(org-clock-goto): Hide drawers after showing an
entry with `org-clock-goto.'
(org-shiftup, org-shiftdown, org-shiftright, org-shiftleft): Try
also a clocktable block shift.
(org-clocktable-try-shift): New function.
(org-columns-hscoll-title): New function.
(org-columns-previous-hscroll): New variable.
(org-columns-full-header-line-format): New variable.
(org-columns-display-here-title, org-columns-remove-overlays):
Install `org-columns-hscoll-title' in post-command-hook.
* org/org.el: Split into many small files.
* org/org-agenda.el: New file, split off from org.el.
* org/org-archive.el: New file, split off from org.el.
* org/org-bbdb.el: New file.
* org/org-bibtex.el: New file, split off from org.el.
* org/org-clock.el: New file, split off from org.el.
* org/org-colview.el: New file, split off from org.el.
* org/org-compat.el: New file, split off from org.el.
* org/org-exp.el: New file, split off from org.el.
* org/org-faces.el: New file, split off from org.el.
* org/org-gnus.el: New file, split off from org.el.
* org/org-info.el: New file, split off from org.el.
* org/org-infojs.el: New file.
* org/org-irc.el: New file.
* org/org-macs.el: New file, split off from org.el.
* org/org-mew.el: New file.
* org/org-mhe.el: New file, split off from org.el.
* org/org-publish.el: New file, split off from org.el.
* org/org-remember.el: New file, split off from org.el.
* org/org-rmail.el: New file, split off from org.el.
* org/org-table.el: New file, split off from org.el.
* org/org-vm.el: New file, split off from org.el.
* org/org-wl.el: New file, split off from org.el.
2008-04-27 Jason Riedy <jason@acm.org>
* lisp/org-table.el (orgtbl-to-generic): Add a :remove-nil-lines
parameter that supresses lines that evaluate to NIL.
(orgtbl-get-fmt): New inline function for
picking apart formats that may be lists.
(orgtbl-apply-fmt): New inline function for applying formats that
may be functions.
(orgtbl-eval-str): New inline function for strings that may be
functions.
(orgtbl-format-line, orgtbl-to-generic): Use and document.
(orgtbl-to-latex, orgtbl-to-texinfo): Document.
(*orgtbl-llfmt*, *orgtbl-llstart*)
(*orgtbl-llend*): Dynamic variables for last-line formatting.
(orgtbl-format-section): Shift formatting to support detecting the
last line and formatting it specially.
(orgtbl-to-generic): Document :ll* formats. Set to the non-ll
formats unless overridden.
(orgtbl-to-latex): Suggest using :llend to suppress the final \\.
(*orgtbl-table*, *orgtbl-rtn*): Dynamically
bound variables to hold the input collection of lines and output
formatted text.
(*orgtbl-hline*, *orgtbl-sep*, *orgtbl-fmt*, *orgtbl-efmt*,
(*orgtbl-lfmt*, *orgtbl-lstart*, *orgtbl-lend*): Dynamically bound
format parameters.
(orgtbl-format-line): New function encapsulating formatting for a
single line.
(orgtbl-format-section): Similar for each section. Rebinding the
dynamic vars customizes the formatting for each section.
(orgtbl-to-generic): Use orgtbl-format-line and
orgtbl-format-section.
(org-get-param): Now unused, so delete.
(orgtbl-gather-send-defs): New function to
gather all the SEND definitions before a table.
(orgtbl-send-replace-tbl): New function to find the RECEIVE
corresponding to the current name.
(orgtbl-send-table): Use the previous two functions and implement
multiple destinations for each table.
* doc/org.texi (A LaTeX example): Note that fmt may be a
one-argument function, and efmt may be a two-argument function.
(Radio tables): Document multiple destinations.
2008-04-27 Carsten Dominik <dominik@science.uva.nl>
* org/org-agenda.el (org-add-to-diary-list): New function.
(org-prefix-has-effort): New variable.
(org-sort-agenda-noeffort-is-high): New option.
(org-agenda-columns-show-summaries)
(org-agenda-columns-compute-summary-properties): New options.
(org-format-agenda-item): Compute the duration of the item.
(org-agenda-weekend-days): New variable.
(org-agenda-list, org-timeline): Use the proper faces for dates in
the agenda and timeline buffers.
(org-agenda-archive-to-archive-sibling): New command.
(org-agenda-start-with-clockreport-mode): New option.
(org-agenda-clockreport-parameter-plist): New option.
(org-agenda-clocktable-mode): New variable.
(org-agenda-deadline-leaders): Allow a function value for the
deadline leader.
(org-agenda-get-deadlines): Deal with new function value.
* lisp/org-clock.el (org-clock): New customization group.
(org-clock-into-drawer, org-clock-out-when-done)
(org-clock-in-switch-to-state, org-clock-heading-function): Moved
into the new group.
(org-clock-out-remove-zero-time-clocks): New option.
(org-clock-out): Use `org-clock-out-remove-zero-time-clocks'.
(org-dblock-write:clocktable): Allow a Lisp form for the scope
parameter.
(org-dblock-write:clocktable): Fixed bug with total time
calculation.
(org-dblock-write:clocktable): Request the unrestricted list of
files.
(org-get-clocktable): New function.
(org-dblock-write:clocktable): Make sure :tstart and :tend can not
only be strings but also integers (an absolute day number) and
lists (m d y).
* org/org-colview.el (org-columns-next-allowed-value)
(org-columns-edit-value): Limit the effort for updatig in the
agenda to recomputing a single file.
(org-columns-compute): Only write property value if it has
changed. This avoids raising the buffer-change-flag
unnecessarily.
(org-agenda-colview-summarize)
(org-agenda-colview-compute): New functions.
(org-agenda-columns): Call `org-agenda-colview-summarize'.
* org/org-exp.el (org-export-run-in-background): New option.
(org-export-icalendar): Allow a batch process to trigger waiting
after executing a system command.
(org-export-preprocess-string): Renamed-from
`org-cleaned-string-for-export'.
(org-export-html-style): Made target class look like normal text.
(org-export-as-html): Make use of the better proprocessing in
`org-cleaned-string-for-export'.
(org-cleaned-string-for-export): Better treatment of heuristic
targets, many more internal links will now work in HTML export.
(org-get-current-options): Incorporate LINK_UP, LINK_HOME, and
INFOJS.
(org-export-inbuffer-options-extra): New variable.
(org-export-options-filters): New hook.
(org-infile-export-plist): Find also the settings keywords in
`org-export-inbuffer-options-extra'.
(org-infile-export-plist): Allow multiple #+OPTIONS lines and
multiple #+INFOJS_OPT lines.
(org-export-html-handle-js-options): New function.
(org-export-html-infojs-setup): New option.
(org-export-as-html): Call `org-export-html-handle-js-options'.
Add autoload to all entry points.
(org-skip-comments): Function removed.
* org/org-table.el (org-table-make-reference): Extra parenthesis
around single fields, to make sure that algebraic formulas get
correctly interpreted by calc.
(org-table-current-column): No longer interactive.
* org/org-export-latex.el (org-export-latex-preprocess): Renamed
from `org-export-latex-cleaned-string'.
2008-04-27 Bastien Guerry <bzg@altern.org>
* org/org-publish.el (org-publish-get-base-files-1): New function.
(org-publish-get-base-files): Use it.
(org-publish-temp-files): New variable.
Don't require 'dired-aux anymore.
(org-publish-initial-buffer): New variable.
(org-publish-org-to, org-publish): Use it.
(org-publish-get-base-files-1): Bug fix: get
the proper list of files when recursing thru a directory.
(org-publish-get-base-files): Use the :exclude property to skip
both files and directories.
author | Carsten Dominik <dominik@science.uva.nl> |
---|---|
date | Sun, 27 Apr 2008 18:33:39 +0000 |
parents | |
children | da5141d2e8fc |
comparison
equal
deleted
inserted
replaced
94413:90289baecd6a | 94414:d86cb59eea9f |
---|---|
1 ;;; org-compat.el --- Compatibility code for Org-mode | |
2 | |
3 ;; Copyright (C) 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. | |
4 | |
5 ;; Author: Carsten Dominik <carsten at orgmode dot org> | |
6 ;; Keywords: outlines, hypermedia, calendar, wp | |
7 ;; Homepage: http://orgmode.org | |
8 ;; Version: 6.02b | |
9 ;; | |
10 ;; This file is part of GNU Emacs. | |
11 ;; | |
12 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
13 ;; it under the terms of the GNU General Public License as published by | |
14 ;; the Free Software Foundation; either version 3, or (at your option) | |
15 ;; any later version. | |
16 | |
17 ;; GNU Emacs is distributed in the hope that it will be useful, | |
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
20 ;; GNU General Public License for more details. | |
21 | |
22 ;; You should have received a copy of the GNU General Public License | |
23 ;; along with GNU Emacs; see the file COPYING. If not, write to the | |
24 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, | |
25 ;; Boston, MA 02110-1301, USA. | |
26 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | |
27 ;; | |
28 ;;; Commentary: | |
29 | |
30 ;; This file contains code needed for compatibility with XEmacs and older | |
31 ;; versions of GNU Emacs. | |
32 | |
33 ;;; Code: | |
34 | |
35 (defconst org-xemacs-p (featurep 'xemacs)) ; not used by org.el itself | |
36 (defconst org-format-transports-properties-p | |
37 (let ((x "a")) | |
38 (add-text-properties 0 1 '(test t) x) | |
39 (get-text-property 0 'test (format "%s" x))) | |
40 "Does format transport text properties?") | |
41 | |
42 (defun org-compatible-face (inherits specs) | |
43 "Make a compatible face specification. | |
44 If INHERITS is an existing face and if the Emacs version supports it, | |
45 just inherit the face. If not, use SPECS to define the face. | |
46 XEmacs and Emacs 21 do not know about the `min-colors' attribute. | |
47 For them we convert a (min-colors 8) entry to a `tty' entry and move it | |
48 to the top of the list. The `min-colors' attribute will be removed from | |
49 any other entries, and any resulting duplicates will be removed entirely." | |
50 (cond | |
51 ((and inherits (facep inherits) | |
52 (not (featurep 'xemacs)) (> emacs-major-version 22)) | |
53 ;; In Emacs 23, we use inheritance where possible. | |
54 ;; We only do this in Emacs 23, because only there the outline | |
55 ;; faces have been changed to the original org-mode-level-faces. | |
56 (list (list t :inherit inherits))) | |
57 ((or (featurep 'xemacs) (< emacs-major-version 22)) | |
58 ;; These do not understand the `min-colors' attribute. | |
59 (let (r e a) | |
60 (while (setq e (pop specs)) | |
61 (cond | |
62 ((memq (car e) '(t default)) (push e r)) | |
63 ((setq a (member '(min-colors 8) (car e))) | |
64 (nconc r (list (cons (cons '(type tty) (delq (car a) (car e))) | |
65 (cdr e))))) | |
66 ((setq a (assq 'min-colors (car e))) | |
67 (setq e (cons (delq a (car e)) (cdr e))) | |
68 (or (assoc (car e) r) (push e r))) | |
69 (t (or (assoc (car e) r) (push e r))))) | |
70 (nreverse r))) | |
71 (t specs))) | |
72 (put 'org-compatible-face 'lisp-indent-function 1) | |
73 | |
74 ;;;; Emacs/XEmacs compatibility | |
75 | |
76 ;; Overlay compatibility functions | |
77 (defun org-make-overlay (beg end &optional buffer) | |
78 (if (featurep 'xemacs) | |
79 (make-extent beg end buffer) | |
80 (make-overlay beg end buffer))) | |
81 (defun org-delete-overlay (ovl) | |
82 (if (featurep 'xemacs) (progn (delete-extent ovl) nil) (delete-overlay ovl))) | |
83 (defun org-detach-overlay (ovl) | |
84 (if (featurep 'xemacs) (detach-extent ovl) (delete-overlay ovl))) | |
85 (defun org-move-overlay (ovl beg end &optional buffer) | |
86 (if (featurep 'xemacs) | |
87 (set-extent-endpoints ovl beg end (or buffer (current-buffer))) | |
88 (move-overlay ovl beg end buffer))) | |
89 (defun org-overlay-put (ovl prop value) | |
90 (if (featurep 'xemacs) | |
91 (set-extent-property ovl prop value) | |
92 (overlay-put ovl prop value))) | |
93 (defun org-overlay-display (ovl text &optional face evap) | |
94 "Make overlay OVL display TEXT with face FACE." | |
95 (if (featurep 'xemacs) | |
96 (let ((gl (make-glyph text))) | |
97 (and face (set-glyph-face gl face)) | |
98 (set-extent-property ovl 'invisible t) | |
99 (set-extent-property ovl 'end-glyph gl)) | |
100 (overlay-put ovl 'display text) | |
101 (if face (overlay-put ovl 'face face)) | |
102 (if evap (overlay-put ovl 'evaporate t)))) | |
103 (defun org-overlay-before-string (ovl text &optional face evap) | |
104 "Make overlay OVL display TEXT with face FACE." | |
105 (if (featurep 'xemacs) | |
106 (let ((gl (make-glyph text))) | |
107 (and face (set-glyph-face gl face)) | |
108 (set-extent-property ovl 'begin-glyph gl)) | |
109 (if face (org-add-props text nil 'face face)) | |
110 (overlay-put ovl 'before-string text) | |
111 (if evap (overlay-put ovl 'evaporate t)))) | |
112 (defun org-overlay-get (ovl prop) | |
113 (if (featurep 'xemacs) | |
114 (extent-property ovl prop) | |
115 (overlay-get ovl prop))) | |
116 (defun org-overlays-at (pos) | |
117 (if (featurep 'xemacs) (extents-at pos) (overlays-at pos))) | |
118 (defun org-overlays-in (&optional start end) | |
119 (if (featurep 'xemacs) | |
120 (extent-list nil start end) | |
121 (overlays-in start end))) | |
122 (defun org-overlay-start (o) | |
123 (if (featurep 'xemacs) (extent-start-position o) (overlay-start o))) | |
124 (defun org-overlay-end (o) | |
125 (if (featurep 'xemacs) (extent-end-position o) (overlay-end o))) | |
126 (defun org-overlay-buffer (o) | |
127 (if (featurep 'xemacs) (extent-buffer o) (overlay-buffer o))) | |
128 (defun org-find-overlays (prop &optional pos delete) | |
129 "Find all overlays specifying PROP at POS or point. | |
130 If DELETE is non-nil, delete all those overlays." | |
131 (let ((overlays (org-overlays-at (or pos (point)))) | |
132 ov found) | |
133 (while (setq ov (pop overlays)) | |
134 (if (org-overlay-get ov prop) | |
135 (if delete (org-delete-overlay ov) (push ov found)))) | |
136 found)) | |
137 | |
138 (defun org-add-hook (hook function &optional append local) | |
139 "Add-hook, compatible with both Emacsen." | |
140 (if (and local (featurep 'xemacs)) | |
141 (add-local-hook hook function append) | |
142 (add-hook hook function append local))) | |
143 | |
144 (defun org-add-props (string plist &rest props) | |
145 "Add text properties to entire string, from beginning to end. | |
146 PLIST may be a list of properties, PROPS are individual properties and values | |
147 that will be added to PLIST. Returns the string that was modified." | |
148 (add-text-properties | |
149 0 (length string) (if props (append plist props) plist) string) | |
150 string) | |
151 (put 'org-add-props 'lisp-indent-function 2) | |
152 | |
153 ;; Region compatibility | |
154 | |
155 (defvar org-ignore-region nil | |
156 "To temporarily disable the active region.") | |
157 | |
158 (defun org-region-active-p () | |
159 "Is `transient-mark-mode' on and the region active? | |
160 Works on both Emacs and XEmacs." | |
161 (if org-ignore-region | |
162 nil | |
163 (if (featurep 'xemacs) | |
164 (and zmacs-regions (region-active-p)) | |
165 (if (fboundp 'use-region-p) | |
166 (use-region-p) | |
167 (and transient-mark-mode mark-active))))) ; Emacs 22 and before | |
168 | |
169 ;; Invisibility compatibility | |
170 | |
171 (defun org-add-to-invisibility-spec (arg) | |
172 "Add elements to `buffer-invisibility-spec'. | |
173 See documentation for `buffer-invisibility-spec' for the kind of elements | |
174 that can be added." | |
175 (cond | |
176 ((fboundp 'add-to-invisibility-spec) | |
177 (add-to-invisibility-spec arg)) | |
178 ((or (null buffer-invisibility-spec) (eq buffer-invisibility-spec t)) | |
179 (setq buffer-invisibility-spec (list arg))) | |
180 (t | |
181 (setq buffer-invisibility-spec | |
182 (cons arg buffer-invisibility-spec))))) | |
183 | |
184 (defun org-remove-from-invisibility-spec (arg) | |
185 "Remove elements from `buffer-invisibility-spec'." | |
186 (if (fboundp 'remove-from-invisibility-spec) | |
187 (remove-from-invisibility-spec arg) | |
188 (if (consp buffer-invisibility-spec) | |
189 (setq buffer-invisibility-spec | |
190 (delete arg buffer-invisibility-spec))))) | |
191 | |
192 (defun org-in-invisibility-spec-p (arg) | |
193 "Is ARG a member of `buffer-invisibility-spec'?" | |
194 (if (consp buffer-invisibility-spec) | |
195 (member arg buffer-invisibility-spec) | |
196 nil)) | |
197 | |
198 (defun org-indent-to-column (column &optional minimum buffer) | |
199 "Work around a bug with extents with invisibility in XEmacs." | |
200 (if (featurep 'xemacs) | |
201 (let ((ext-inv (extent-list | |
202 nil (point-at-bol) (point-at-eol) | |
203 'all-extents-closed-open 'invisible)) | |
204 ext-inv-specs) | |
205 (dolist (ext ext-inv) | |
206 (when (extent-property ext 'invisible) | |
207 (add-to-list 'ext-inv-specs (list ext (extent-property | |
208 ext 'invisible))) | |
209 (set-extent-property ext 'invisible nil))) | |
210 (indent-to-column column minimum buffer) | |
211 (dolist (ext-inv-spec ext-inv-specs) | |
212 (set-extent-property (car ext-inv-spec) 'invisible | |
213 (cadr ext-inv-spec)))) | |
214 (indent-to-column column minimum))) | |
215 | |
216 (defun org-indent-line-to (column) | |
217 "Work around a bug with extents with invisibility in XEmacs." | |
218 (if (featurep 'xemacs) | |
219 (let ((ext-inv (extent-list | |
220 nil (point-at-bol) (point-at-eol) | |
221 'all-extents-closed-open 'invisible)) | |
222 ext-inv-specs) | |
223 (dolist (ext ext-inv) | |
224 (when (extent-property ext 'invisible) | |
225 (add-to-list 'ext-inv-specs (list ext (extent-property | |
226 ext 'invisible))) | |
227 (set-extent-property ext 'invisible nil))) | |
228 (indent-line-to column) | |
229 (dolist (ext-inv-spec ext-inv-specs) | |
230 (set-extent-property (car ext-inv-spec) 'invisible | |
231 (cadr ext-inv-spec)))) | |
232 (indent-line-to column))) | |
233 | |
234 (defun org-move-to-column (column &optional force buffer) | |
235 (if (featurep 'xemacs) | |
236 (let ((ext-inv (extent-list | |
237 nil (point-at-bol) (point-at-eol) | |
238 'all-extents-closed-open 'invisible)) | |
239 ext-inv-specs) | |
240 (dolist (ext ext-inv) | |
241 (when (extent-property ext 'invisible) | |
242 (add-to-list 'ext-inv-specs (list ext (extent-property ext | |
243 'invisible))) | |
244 (set-extent-property ext 'invisible nil))) | |
245 (move-to-column column force buffer) | |
246 (dolist (ext-inv-spec ext-inv-specs) | |
247 (set-extent-property (car ext-inv-spec) 'invisible | |
248 (cadr ext-inv-spec)))) | |
249 (move-to-column column force))) | |
250 | |
251 | |
252 (provide 'org-compat) | |
253 | |
254 ;;; org-compat.el ends here |