Merge branch 'master' of git+ssh://repo.or.cz/srv/git/org-mode
This commit is contained in:
commit
a5d5f4c9f3
66
Makefile
66
Makefile
|
@ -18,6 +18,8 @@ prefix=/usr/local
|
|||
|
||||
# Where local lisp files go.
|
||||
lispdir = $(prefix)/share/emacs/site-lisp
|
||||
lispbdir = $(lispdir)/babel
|
||||
lispbldir = $(lispbdir)/langs
|
||||
|
||||
# Where info files go.
|
||||
infodir = $(prefix)/share/info
|
||||
|
@ -118,21 +120,47 @@ LISPF = org.el \
|
|||
org-vm.el \
|
||||
org-w3m.el \
|
||||
org-wl.el \
|
||||
org-xoxo.el \
|
||||
babel/ob.el \
|
||||
babel/ob-table.el \
|
||||
babel/ob-lob.el \
|
||||
babel/ob-ref.el \
|
||||
babel/ob-exp.el \
|
||||
babel/ob-tangle.el \
|
||||
babel/ob-comint.el \
|
||||
babel/ob-keys.el \
|
||||
babel/langs/ob-emacs-lisp.el
|
||||
org-xoxo.el
|
||||
|
||||
LISPBF = ob.el \
|
||||
ob-table.el \
|
||||
ob-lob.el \
|
||||
ob-ref.el \
|
||||
ob-exp.el \
|
||||
ob-tangle.el \
|
||||
ob-comint.el \
|
||||
ob-keys.el
|
||||
|
||||
LISPBLF = ob-C.el \
|
||||
ob-ditaa.el \
|
||||
ob-haskell.el \
|
||||
ob-perl.el \
|
||||
ob-sh.el \
|
||||
ob-R.el \
|
||||
ob-dot.el \
|
||||
ob-latex.el \
|
||||
ob-python.el \
|
||||
ob-sql.el \
|
||||
ob-asymptote.el \
|
||||
ob-emacs-lisp.el \
|
||||
ob-matlab.el \
|
||||
ob-ruby.el \
|
||||
ob-sqlite.el \
|
||||
ob-clojure.el \
|
||||
ob-ocaml.el \
|
||||
ob-sass.el \
|
||||
ob-css.el \
|
||||
ob-gnuplot.el \
|
||||
ob-octave.el \
|
||||
ob-screen.el
|
||||
|
||||
LISPFILES0 = $(LISPF:%=lisp/%)
|
||||
LISPFILES = $(LISPFILES0) lisp/org-install.el
|
||||
LISPBFILES = $(LISPBF:%=lisp/babel/%)
|
||||
LISPBLFILES = $(LISPBLF:%=lisp/babel/langs/%)
|
||||
ELCFILES0 = $(LISPFILES0:.el=.elc)
|
||||
ELCFILES = $(LISPFILES:.el=.elc)
|
||||
ELCBFILES = $(LISPBFILES:.el=.elc)
|
||||
DOCFILES = doc/org.texi doc/org.pdf doc/org doc/dir \
|
||||
doc/pdflayout.sty doc/.nosearch \
|
||||
doc/orgguide.texi doc/orgguide.pdf
|
||||
|
@ -148,9 +176,9 @@ SHELL = /bin/sh
|
|||
DISTFILES_extra= Makefile ChangeLog request-assign-future.txt contrib
|
||||
DISTFILES_xemacs= xemacs/noutline.el xemacs/ps-print-invisible.el xemacs/README
|
||||
|
||||
default: $(ELCFILES)
|
||||
default: $(ELCFILES) $(ELCBFILES)
|
||||
|
||||
all: $(ELCFILES) $(INFOFILES)
|
||||
all: $(ELCFILES) $(ELCBFILES) $(INFOFILES)
|
||||
|
||||
up2: update
|
||||
sudo ${MAKE} install
|
||||
|
@ -160,7 +188,7 @@ update:
|
|||
${MAKE} clean
|
||||
${MAKE} all
|
||||
|
||||
compile: $(ELCFILES0)
|
||||
compile: $(ELCFILES0) $(ELCBFILES)
|
||||
|
||||
install: install-lisp
|
||||
|
||||
|
@ -172,10 +200,15 @@ p:
|
|||
g:
|
||||
${MAKE} pdf && open doc/orgguide.pdf
|
||||
|
||||
install-lisp: $(LISPFILES) $(ELCFILES)
|
||||
install-lisp: $(LISPFILES) $(LISPBFILES) $(ELCFILES)
|
||||
if [ ! -d $(lispdir) ]; then $(MKDIR) $(lispdir); else true; fi ;
|
||||
if [ ! -d $(lispbdir) ]; then $(MKDIR) $(lispbdir); else true; fi ;
|
||||
if [ ! -d $(lispbldir) ]; then $(MKDIR) $(lispbldir); else true; fi ;
|
||||
$(CP) $(LISPFILES) $(lispdir)
|
||||
$(CP) $(ELCFILES) $(lispdir)
|
||||
$(CP) $(LISPBFILES) $(lispbdir)
|
||||
$(CP) $(ELCBFILES) $(lispbdir)
|
||||
$(CP) $(LISPBLFILES) $(lispbldir)
|
||||
|
||||
install-info: $(INFOFILES)
|
||||
if [ ! -d $(infodir) ]; then $(MKDIR) $(infodir); else true; fi ;
|
||||
|
@ -191,11 +224,11 @@ install-noutline: xemacs/noutline.elc
|
|||
|
||||
autoloads: lisp/org-install.el
|
||||
|
||||
lisp/org-install.el: $(LISPFILES0) Makefile
|
||||
lisp/org-install.el: $(LISPFILES0) $(LISPBFILES) Makefile
|
||||
$(BATCH) --eval "(require 'autoload)" \
|
||||
--eval '(find-file "org-install.el")' \
|
||||
--eval '(erase-buffer)' \
|
||||
--eval '(mapc (lambda (x) (generate-file-autoloads (symbol-name x))) (quote ($(LISPFILES0))))' \
|
||||
--eval '(mapc (lambda (x) (generate-file-autoloads (symbol-name x))) (quote ($(LISPFILES0) $(LISPBFILES))))' \
|
||||
--eval "(insert \"(add-to-list 'load-path (expand-file-name \\\"babel\\\" (file-name-directory (or load-file-name (buffer-file-name)))))\")" \
|
||||
--eval "(insert \"\n(add-to-list 'load-path (expand-file-name \\\"langs\\\" (expand-file-name \\\"babel\\\" (file-name-directory (or load-file-name (buffer-file-name))))))\")\n" \
|
||||
--eval '(insert "\n(provide (quote org-install))\n")' \
|
||||
|
@ -268,6 +301,7 @@ distfile:
|
|||
$(MKDIR) org-$(TAG)/doc
|
||||
$(MKDIR) org-$(TAG)/lisp
|
||||
cp -r $(LISPFILES) org-$(TAG)/lisp
|
||||
cp -r $(LISPBFILES) org-$(TAG)/lisp/babel
|
||||
cp -r $(DOCFILES) $(CARDFILES) org-$(TAG)/doc
|
||||
cp -r $(DISTFILES_extra) org-$(TAG)/
|
||||
cp -r README_DIST org-$(TAG)/README
|
||||
|
|
|
@ -98,6 +98,50 @@ plot(data)
|
|||
|
||||
* Tables
|
||||
** LaTeX Table export
|
||||
*** booktabs
|
||||
This block can be used to wrap a table in the latex =booktabs=
|
||||
environment, it takes the following arguments -- all but the first two
|
||||
are optional.
|
||||
| arg | description |
|
||||
|-------+--------------------------------------------|
|
||||
| table | a reference to the table |
|
||||
| align | optional alignment string |
|
||||
| env | optional environment, default to "tabular" |
|
||||
| width | optional width specification string |
|
||||
|
||||
#+srcname: booktabs
|
||||
#+begin_src emacs-lisp :var table='((:head) hline (:body)) :var align='() :var env="tabular" :var width='() :noweb yes :results latex
|
||||
(flet ((to-tab (tab)
|
||||
(orgtbl-to-generic
|
||||
(mapcar (lambda (lis)
|
||||
(if (listp lis)
|
||||
(mapcar (lambda (el)
|
||||
(if (stringp el)
|
||||
el
|
||||
(format "%S" el))) lis)
|
||||
lis)) tab)
|
||||
(list :lend " \\\\" :sep " & " :hline "\\hline"))))
|
||||
(org-fill-template
|
||||
"
|
||||
\\begin{%env}%width%align
|
||||
\\toprule
|
||||
%table
|
||||
\\bottomrule
|
||||
\\end{%env}\n"
|
||||
(list
|
||||
(cons "env" (or env "table"))
|
||||
(cons "width" (if width (format "{%s}" width) ""))
|
||||
(cons "align" (if align (format "{%s}" align) ""))
|
||||
(cons "table"
|
||||
;; only use \midrule if it looks like there are column headers
|
||||
(if (equal 'hline (second table))
|
||||
(concat (to-tab (list (first table)))
|
||||
"\n\\midrule\n"
|
||||
(to-tab (cddr table)))
|
||||
(to-tab table))))))
|
||||
#+end_src
|
||||
|
||||
*** longtable
|
||||
This block can be used to wrap a table in the latex =longtable=
|
||||
environment, it takes the following arguments -- all but the first two
|
||||
are optional.
|
||||
|
@ -113,7 +157,7 @@ are optional.
|
|||
| lastfoot | optional "lastfoot" string |
|
||||
|
||||
#+srcname: longtable
|
||||
#+begin_src emacs-lisp :var table='((:table)) :var env="table" :var align='() :var width='() :var hline="\\hline" :var firsthead='() :var head='() :var foot='() :var lastfoot='() :noweb yes :results latex
|
||||
#+begin_src emacs-lisp :var table='((:table)) :var align='() :var width='() :var hline="\\hline" :var firsthead='() :var head='() :var foot='() :var lastfoot='() :noweb yes :results latex
|
||||
(org-fill-template
|
||||
"
|
||||
\\begin{longtable}%width%align
|
||||
|
|
|
@ -1161,6 +1161,9 @@ on this string to produce the exported version."
|
|||
;; Remove or replace comments
|
||||
(org-export-handle-comments (plist-get parameters :comments))
|
||||
|
||||
;; Remove #+TBLFM and #+TBLNAME lines
|
||||
(org-export-handle-table-metalines)
|
||||
|
||||
;; Run the final hook
|
||||
(run-hooks 'org-export-preprocess-final-hook)
|
||||
|
||||
|
@ -1526,15 +1529,25 @@ from the buffer."
|
|||
|
||||
(while formatters
|
||||
(setq fmt (pop formatters))
|
||||
(when (eq (car fmt) backend)
|
||||
;; This is selected code, put it into the file for real
|
||||
;; Handle #+Backend: stuff
|
||||
(goto-char (point-min))
|
||||
(while (re-search-forward (concat "^\\([ \t]*\\)#\\+" (cadr fmt)
|
||||
":[ \t]*\\(.*\\)") nil t)
|
||||
(if (not (eq (car fmt) backend))
|
||||
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))
|
||||
(replace-match "\\1\\2" t)
|
||||
(add-text-properties
|
||||
(point-at-bol) (min (1+ (point-at-eol)) (point-max))
|
||||
'(org-protected t))))
|
||||
;; Delete #+attr_Backend: stuff of another backend. Those
|
||||
;; matching the current backend will be taken care of by
|
||||
;; `org-export-attach-captions-and-attributes'
|
||||
(goto-char (point-min))
|
||||
(while (re-search-forward (concat "^\\([ \t]*\\)#\\+attr_" (cadr fmt)
|
||||
":[ \t]*\\(.*\\)") nil t)
|
||||
(when (not (eq (car fmt) backend))
|
||||
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))))
|
||||
;; Handle #+begin_Backend and #+end_Backend stuff
|
||||
(goto-char (point-min))
|
||||
(while (re-search-forward (concat "^[ \t]*#\\+" (caddr fmt) "\\>.*\n?")
|
||||
nil t)
|
||||
|
@ -1598,11 +1611,17 @@ table line. If it is a link, add it to the line containing the link."
|
|||
(while (re-search-forward re nil t)
|
||||
(cond
|
||||
((match-end 1)
|
||||
(setq cap (concat cap (if cap " " "") (org-trim (match-string 1)))))
|
||||
(progn
|
||||
(setq cap (concat cap (if cap " " "") (org-trim (match-string 1))))
|
||||
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))))
|
||||
((match-end 2)
|
||||
(setq attr (concat attr (if attr " " "") (org-trim (match-string 2)))))
|
||||
(progn
|
||||
(setq attr (concat attr (if attr " " "") (org-trim (match-string 2))))
|
||||
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))))
|
||||
((match-end 3)
|
||||
(setq label (org-trim (match-string 3))))
|
||||
(progn
|
||||
(setq label (org-trim (match-string 3)))
|
||||
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))))
|
||||
(t
|
||||
(setq end (if (match-end 4)
|
||||
(let ((ee (org-table-end)))
|
||||
|
@ -1655,6 +1674,19 @@ When it is nil, all comments will be removed."
|
|||
(replace-match "")
|
||||
(goto-char (max (point-min) (1- pos))))))))
|
||||
|
||||
(defun org-export-handle-table-metalines ()
|
||||
"Remove table specific metalines #+TBLNAME: and #+TBLFM:."
|
||||
(let ((re "^[ \t]*#\\+TBL\\(NAME\\|FM\\):\\(.*\n?\\)")
|
||||
pos)
|
||||
(goto-char (point-min))
|
||||
(while (or (looking-at re)
|
||||
(re-search-forward re nil t))
|
||||
(setq pos (match-beginning 0))
|
||||
(if (get-text-property (point) 'org-protected)
|
||||
(goto-char (1+ pos))
|
||||
(goto-char (1+ pos))
|
||||
(replace-match "")
|
||||
(goto-char (max (point-min) (1- pos)))))))
|
||||
|
||||
(defun org-export-mark-radio-links ()
|
||||
"Find all matches for radio targets and turn them into internal links."
|
||||
|
|
Loading…
Reference in New Issue