Merge branch 'master' of orgmode.org:org-mode
This commit is contained in:
commit
901121ac45
|
@ -2986,20 +2986,24 @@ when a line/row is swaped out of that privileged position. So for
|
|||
formulas that use a range of rows or columns, it may often be better
|
||||
to anchor the formula with \"I\" row markers, or to offset from the
|
||||
borders of the table using the @< @> $< $> makers."
|
||||
(let (n nmax len char)
|
||||
(while (string-match "\\([@$]\\)\\(<+\\|>+\\)" s)
|
||||
(setq nmax (if (equal (match-string 1 s) "@")
|
||||
(1- (length org-table-dlines))
|
||||
org-table-current-ncol)
|
||||
len (- (match-end 2) (match-beginning 2))
|
||||
char (string-to-char (match-string 2 s))
|
||||
n (if (= char ?<)
|
||||
len
|
||||
(- nmax len -1)))
|
||||
(if (or (< n 1) (> n nmax))
|
||||
(error "Reference \"%s\" in expression \"%s\" points outside table"
|
||||
(match-string 0 s) s))
|
||||
(setq s (replace-match (format "%s%d" (match-string 1 s) n) t t s))))
|
||||
(let (n nmax len char (start 0))
|
||||
(while (string-match "\\([@$]\\)\\(<+\\|>+\\)\\|\\(remote([^\)]+)\\)"
|
||||
s start)
|
||||
(if (match-end 3)
|
||||
(setq start (match-end 3))
|
||||
(setq nmax (if (equal (match-string 1 s) "@")
|
||||
(1- (length org-table-dlines))
|
||||
org-table-current-ncol)
|
||||
len (- (match-end 2) (match-beginning 2))
|
||||
char (string-to-char (match-string 2 s))
|
||||
n (if (= char ?<)
|
||||
len
|
||||
(- nmax len -1)))
|
||||
(if (or (< n 1) (> n nmax))
|
||||
(error "Reference \"%s\" in expression \"%s\" points outside table"
|
||||
(match-string 0 s) s))
|
||||
(setq start (match-beginning 0))
|
||||
(setq s (replace-match (format "%s%d" (match-string 1 s) n) t t s)))))
|
||||
s)
|
||||
|
||||
(defun org-table-formula-substitute-names (f)
|
||||
|
@ -4668,6 +4672,8 @@ The return value is either a single string for a single field, or a
|
|||
list of the fields in the rectangle ."
|
||||
(save-match-data
|
||||
(let ((id-loc nil)
|
||||
;; Protect a bunch of variables from being overwritten
|
||||
;; by the context of the remote table
|
||||
org-table-column-names org-table-column-name-regexp
|
||||
org-table-local-parameters org-table-named-field-locations
|
||||
org-table-current-line-types org-table-current-begin-line
|
||||
|
@ -4704,7 +4710,8 @@ list of the fields in the rectangle ."
|
|||
(error "Cannot find a table at NAME or ID %s" name-or-id))
|
||||
(setq tbeg (point-at-bol))
|
||||
(org-table-get-specials)
|
||||
(setq form (org-table-formula-substitute-names form))
|
||||
(setq form (org-table-formula-substitute-names
|
||||
(org-table-formula-handle-first/last-rc form)))
|
||||
(if (and (string-match org-table-range-regexp form)
|
||||
(> (length (match-string 0 form)) 1))
|
||||
(save-match-data
|
||||
|
|
Loading…
Reference in New Issue