2012-12-13 11:24:19 -05:00
|
|
|
;;; test-org-table.el --- tests for org-table.el
|
2011-01-11 16:07:33 -05:00
|
|
|
|
2012-12-13 11:24:19 -05:00
|
|
|
;; Copyright (c) David Maus
|
2012-12-28 09:00:54 -05:00
|
|
|
;; Authors: David Maus, Michael Brand
|
2011-01-11 16:07:33 -05:00
|
|
|
|
2012-12-13 11:24:19 -05:00
|
|
|
;; This file is not part of GNU Emacs.
|
|
|
|
|
|
|
|
;; This program 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.
|
|
|
|
|
|
|
|
;; This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
2011-01-11 16:07:33 -05:00
|
|
|
|
|
|
|
;;;; Comments:
|
|
|
|
|
2012-12-28 09:00:54 -05:00
|
|
|
;; Template test file for Org-mode tests. First the tests that are
|
|
|
|
;; also a howto example collection as a user documentation, more or
|
|
|
|
;; less all those using `org-test-table-target-expect'. Then the
|
|
|
|
;; internal and more abstract tests. See also the doc string of
|
|
|
|
;; `org-test-table-target-expect'.
|
2011-01-11 16:07:33 -05:00
|
|
|
|
|
|
|
;;; Code:
|
2012-12-28 08:59:17 -05:00
|
|
|
|
2012-12-28 09:00:54 -05:00
|
|
|
(require 'org-table) ; `org-table-make-reference'
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/simple-formula/no-grouping/no-title-row ()
|
|
|
|
"Simple sum without grouping rows, without title row."
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| 2 |
|
|
|
|
| 4 |
|
|
|
|
| 8 |
|
|
|
|
| replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| 2 |
|
|
|
|
| 4 |
|
|
|
|
| 8 |
|
|
|
|
| 14 |
|
|
|
|
"
|
|
|
|
1
|
|
|
|
;; Calc formula
|
|
|
|
"#+TBLFM: @>$1 = vsum(@<..@>>)"
|
|
|
|
;; Lisp formula
|
|
|
|
"#+TBLFM: @>$1 = '(+ @<..@>>); N"))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/simple-formula/no-grouping/with-title-row ()
|
|
|
|
"Simple sum without grouping rows, with title row."
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| foo |
|
|
|
|
|---------|
|
|
|
|
| 2 |
|
|
|
|
| 4 |
|
|
|
|
| 8 |
|
|
|
|
| replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| foo |
|
|
|
|
|-----|
|
|
|
|
| 2 |
|
|
|
|
| 4 |
|
|
|
|
| 8 |
|
|
|
|
| 14 |
|
|
|
|
"
|
|
|
|
1
|
|
|
|
;; Calc formula
|
|
|
|
"#+TBLFM: @>$1 = vsum(@I..@>>)"
|
|
|
|
;; Lisp formula
|
|
|
|
"#+TBLFM: @>$1 = '(+ @I..@>>); N"))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/simple-formula/with-grouping/no-title-row ()
|
|
|
|
"Simple sum with grouping rows, how not to do."
|
|
|
|
;; The first example has a problem, see the second example in this
|
|
|
|
;; ert-deftest.
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| 2 |
|
|
|
|
| 4 |
|
|
|
|
| 8 |
|
|
|
|
|---------|
|
|
|
|
| replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| 2 |
|
|
|
|
| 4 |
|
|
|
|
| 8 |
|
|
|
|
|----|
|
|
|
|
| 14 |
|
|
|
|
"
|
|
|
|
1
|
|
|
|
;; Calc formula
|
|
|
|
"#+TBLFM: $1 = vsum(@<..@>>)"
|
|
|
|
;; Lisp formula
|
|
|
|
"#+TBLFM: $1 = '(+ @<..@>>); N")
|
|
|
|
|
|
|
|
;; The problem is that the first three rows with the summands are
|
|
|
|
;; considered the header and therefore column formulas are not
|
|
|
|
;; applied on them as shown below. Also export behaves unexpected.
|
|
|
|
;; See next ert-deftest how to group rows right.
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| 2 | replace |
|
|
|
|
| 4 | replace |
|
|
|
|
| 8 | replace |
|
|
|
|
|---------+---------|
|
|
|
|
| replace | replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| 2 | replace |
|
|
|
|
| 4 | replace |
|
|
|
|
| 8 | replace |
|
|
|
|
|----+---------|
|
|
|
|
| 14 | 28 |
|
|
|
|
"
|
|
|
|
2
|
|
|
|
;; Calc formula
|
|
|
|
"#+TBLFM: @>$1 = vsum(@<..@>>) :: $2 = 2 * $1"
|
|
|
|
;; Lisp formula
|
|
|
|
"#+TBLFM: @>$1 = '(+ @<..@>>); N :: $2 = '(* 2 $1); N"))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/simple-formula/with-grouping/with-title-row ()
|
|
|
|
"Simple sum with grouping rows, how to do it right."
|
|
|
|
;; Always add a top row with the column names separated by hline to
|
|
|
|
;; get the desired header when you want to group rows.
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| foo | bar |
|
|
|
|
|---------+---------|
|
|
|
|
| 2 | replace |
|
|
|
|
| 4 | replace |
|
|
|
|
| 8 | replace |
|
|
|
|
|---------+---------|
|
|
|
|
| replace | replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| foo | bar |
|
|
|
|
|-----+-----|
|
|
|
|
| 2 | 4 |
|
|
|
|
| 4 | 8 |
|
|
|
|
| 8 | 16 |
|
|
|
|
|-----+-----|
|
|
|
|
| 14 | 28 |
|
|
|
|
"
|
|
|
|
2
|
|
|
|
;; Calc formula
|
|
|
|
"#+TBLFM: @>$1 = vsum(@I..@>>) :: $2 = 2 * $1"
|
|
|
|
;; Lisp formula
|
|
|
|
"#+TBLFM: @>$1 = '(+ @I..@>>); N :: $2 = '(* 2 $1); N"))
|
|
|
|
|
2012-12-28 08:59:17 -05:00
|
|
|
(ert-deftest test-org-table/align ()
|
|
|
|
"Align columns within Org buffer, depends on `org-table-number-regexp'."
|
|
|
|
(org-test-table-target-expect "
|
|
|
|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|
|
|
|
| ab | 12 | 12.2 | 2.4e-08 | 2x10^12 | 4.034+-0.02 | 2.7(10) | >3.5 |
|
|
|
|
| ab | ab | ab | ab | ab | ab | ab | ab |
|
|
|
|
")
|
|
|
|
(org-test-table-target-expect "
|
2012-12-28 09:00:03 -05:00
|
|
|
| 0 | 0 | 0 | 0 | 0 | 0 |
|
2012-12-28 08:59:17 -05:00
|
|
|
| <-0x0ab.cf | >-36#0vw.yz | nan | uinf | -inf | inf |
|
2012-12-28 09:00:03 -05:00
|
|
|
| ab | ab | ab | ab | ab | ab |
|
2012-12-28 08:59:17 -05:00
|
|
|
"))
|
|
|
|
|
2012-12-28 09:00:54 -05:00
|
|
|
(defconst references/target-normal "
|
|
|
|
| 0 | 1 | replace | replace | replace | replace | replace | replace |
|
|
|
|
| z | 1 | replace | replace | replace | replace | replace | replace |
|
|
|
|
| | 1 | replace | replace | replace | replace | replace | replace |
|
|
|
|
| | | replace | replace | replace | replace | replace | replace |
|
|
|
|
"
|
|
|
|
"Normal numbers and non-numbers for Lisp and Calc formula.")
|
|
|
|
|
|
|
|
(defconst references/target-special "
|
|
|
|
| nan | 1 | replace | replace | replace | replace | replace | replace |
|
|
|
|
| uinf | 1 | replace | replace | replace | replace | replace | replace |
|
|
|
|
| -inf | 1 | replace | replace | replace | replace | replace | replace |
|
|
|
|
| inf | 1 | replace | replace | replace | replace | replace | replace |
|
|
|
|
"
|
|
|
|
"Special numbers for Calc formula.")
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/references/format-specifier-EL ()
|
|
|
|
"Basic: Assign field reference, sum of field references, sum
|
|
|
|
and len of simple range reference (no row) and complex range
|
|
|
|
reference (with row). Format specifier EL."
|
|
|
|
;; Empty fields are kept during parsing field but lost as list
|
|
|
|
;; elements within Lisp formula syntactically when used literally
|
|
|
|
;; and not enclosed with " within fields, see last columns with len.
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
;; All the #ERROR show that for Lisp calculations N has to be used.
|
|
|
|
"
|
|
|
|
| 0 | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| z | 1 | z | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| | 1 | | 1 | 1 | 1 | 1 | 1 |
|
|
|
|
| | | | 0 | 0 | 0 | 0 | 0 |
|
|
|
|
"
|
|
|
|
1 (concat
|
|
|
|
"#+TBLFM: $3 = '(identity \"$1\"); EL :: $4 = '(+ $1 $2); EL :: "
|
|
|
|
"$5 = '(+ $1..$2); EL :: $6 = '(+ @0$1..@0$2); EL :: "
|
|
|
|
"$7 = '(length '($1..$2)); EL :: $8 = '(length '(@0$1..@0$2)); EL"))
|
|
|
|
|
|
|
|
;; Empty fields are kept during parsing field _and_ as list elements
|
|
|
|
;; within Lisp formula syntactically even when used literally when
|
|
|
|
;; enclosed with " within fields, see last columns with len.
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| \"0\" | \"1\" | repl | repl | repl | repl | repl | repl |
|
|
|
|
| \"z\" | \"1\" | repl | repl | repl | repl | repl | repl |
|
|
|
|
| \"\" | \"1\" | repl | repl | repl | repl | repl | repl |
|
|
|
|
| \"\" | \"\" | repl | repl | repl | repl | repl | repl |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| \"0\" | \"1\" | \"0\" | 1 | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| \"z\" | \"1\" | \"z\" | 1 | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| \"\" | \"1\" | \"\" | 1 | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| \"\" | \"\" | \"\" | 0 | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
"
|
|
|
|
1 (concat
|
|
|
|
"#+TBLFM: $3 = '(concat \"\\\"\" $1 \"\\\"\"); EL :: "
|
|
|
|
"$4 = '(+ (string-to-number $1) (string-to-number $2)); EL :: "
|
|
|
|
"$5 = '(+ $1..$2); EL :: $6 = '(+ @0$1..@0$2); EL :: "
|
|
|
|
"$7 = '(length '($1..$2)); EL :: $8 = '(length '(@0$1..@0$2)); EL")))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/references/format-specifier-E ()
|
|
|
|
"Basic: Assign field reference, sum of field references, sum
|
|
|
|
and len of simple range reference (no row) and complex range
|
|
|
|
reference (with row). Format specifier E."
|
|
|
|
(let ((lisp
|
|
|
|
(concat
|
|
|
|
"#+TBLFM: $3 = '(identity $1); E :: $4 = '(+ $1 $2); E :: "
|
|
|
|
"$5 = '(+ $1..$2); E :: $6 = '(+ @0$1..@0$2); E :: "
|
|
|
|
"$7 = '(length '($1..$2)); E :: $8 = '(length '(@0$1..@0$2)); E"))
|
|
|
|
(calc
|
|
|
|
(concat
|
|
|
|
"#+TBLFM: $3 = $1; E :: $4 = $1 + $2; E :: "
|
|
|
|
"$5 = vsum($1..$2); E :: $6 = vsum(@0$1..@0$2); E :: "
|
|
|
|
"$7 = vlen($1..$2); E :: $8 = vlen(@0$1..@0$2); E")))
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
;; All the #ERROR show that for Lisp calculations N has to be used.
|
|
|
|
"
|
|
|
|
| 0 | 1 | 0 | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| z | 1 | z | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| | 1 | | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| | | | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
"
|
|
|
|
1 lisp)
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
"
|
2012-12-28 09:03:10 -05:00
|
|
|
| 0 | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| z | 1 | z | z + 1 | z + 1 | z + 1 | 2 | 2 |
|
|
|
|
| | 1 | nan | nan | nan | nan | 2 | 2 |
|
|
|
|
| | | nan | nan | nan | nan | 2 | 2 |
|
2012-12-28 09:00:54 -05:00
|
|
|
"
|
|
|
|
1 calc)
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-special
|
|
|
|
"
|
|
|
|
| nan | 1 | nan | nan | nan | nan | 2 | 2 |
|
|
|
|
| uinf | 1 | uinf | uinf | uinf | uinf | 2 | 2 |
|
|
|
|
| -inf | 1 | -inf | -inf | -inf | -inf | 2 | 2 |
|
|
|
|
| inf | 1 | inf | inf | inf | inf | 2 | 2 |
|
|
|
|
"
|
|
|
|
1 calc)))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/references/format-specifier-EN ()
|
|
|
|
"Basic: Assign field reference, sum of field references, sum
|
|
|
|
and len of simple range reference (no row) and complex range
|
|
|
|
reference (with row). Format specifier EN."
|
|
|
|
(let ((lisp (concat
|
|
|
|
"#+TBLFM: $3 = '(identity $1); EN :: $4 = '(+ $1 $2); EN :: "
|
|
|
|
"$5 = '(+ $1..$2); EN :: $6 = '(+ @0$1..@0$2); EN :: "
|
|
|
|
"$7 = '(length '($1..$2)); EN :: "
|
|
|
|
"$8 = '(length '(@0$1..@0$2)); EN"))
|
|
|
|
(calc (concat
|
|
|
|
"#+TBLFM: $3 = $1; EN :: $4 = $1 + $2; EN :: "
|
|
|
|
"$5 = vsum($1..$2); EN :: $6 = vsum(@0$1..@0$2); EN :: "
|
|
|
|
"$7 = vlen($1..$2); EN :: $8 = vlen(@0$1..@0$2); EN")))
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
"
|
|
|
|
| 0 | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| z | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| | | 0 | 0 | 0 | 0 | 2 | 2 |
|
|
|
|
"
|
|
|
|
1 lisp calc)
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-special
|
|
|
|
"
|
|
|
|
| nan | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| uinf | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| -inf | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| inf | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
"
|
|
|
|
1 calc)))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/references/format-specifier-L ()
|
|
|
|
"Basic: Assign field reference, sum of field references, sum
|
|
|
|
and len of simple range reference (no row) and complex range
|
|
|
|
reference (with row). Format specifier L."
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
;; All the #ERROR show that for Lisp calculations N has to be used.
|
|
|
|
"
|
|
|
|
| 0 | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| z | 1 | z | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| | 1 | | 1 | 1 | 1 | 1 | 1 |
|
2012-12-28 09:02:01 -05:00
|
|
|
| | | | 0 | 0 | 0 | 0 | 0 |
|
2012-12-28 09:00:54 -05:00
|
|
|
"
|
|
|
|
1 (concat
|
|
|
|
"#+TBLFM: $3 = '(identity \"$1\"); L :: $4 = '(+ $1 $2); L :: "
|
|
|
|
"$5 = '(+ $1..$2); L :: $6 = '(+ @0$1..@0$2); L :: "
|
|
|
|
"$7 = '(length '($1..$2)); L :: $8 = '(length '(@0$1..@0$2)); L")))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/references/format-specifier-none ()
|
|
|
|
"Basic: Assign field reference, sum of field references, sum
|
|
|
|
and len of simple range reference (no row) and complex range
|
|
|
|
reference (with row). No format specifier."
|
|
|
|
(let ((lisp (concat
|
|
|
|
"#+TBLFM: $3 = '(identity $1) :: $4 = '(+ $1 $2) :: "
|
|
|
|
"$5 = '(+ $1..$2) :: $6 = '(+ @0$1..@0$2) :: "
|
|
|
|
"$7 = '(length '($1..$2)) :: $8 = '(length '(@0$1..@0$2))"))
|
|
|
|
(calc (concat
|
|
|
|
"#+TBLFM: $3 = $1 :: $4 = $1 + $2 :: "
|
|
|
|
"$5 = vsum($1..$2) :: $6 = vsum(@0$1..@0$2) :: "
|
|
|
|
"$7 = vlen($1..$2) :: $8 = vlen(@0$1..@0$2)")))
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
;; All the #ERROR show that for Lisp calculations N has to be used.
|
|
|
|
"
|
|
|
|
| 0 | 1 | 0 | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| z | 1 | z | #ERROR | #ERROR | #ERROR | 2 | 2 |
|
|
|
|
| | 1 | | #ERROR | #ERROR | #ERROR | 1 | 1 |
|
|
|
|
| | | | #ERROR | #ERROR | #ERROR | 1 | 1 |
|
|
|
|
"
|
|
|
|
1 lisp)
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
"
|
|
|
|
| 0 | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| z | 1 | z | z + 1 | z + 1 | z + 1 | 2 | 2 |
|
|
|
|
| | 1 | 0 | 1 | 1 | 1 | 1 | 1 |
|
|
|
|
| | | 0 | 0 | 0 | 0 | 1 | 1 |
|
|
|
|
"
|
|
|
|
1 calc)
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-special
|
|
|
|
"
|
|
|
|
| nan | 1 | nan | nan | nan | nan | 2 | 2 |
|
|
|
|
| uinf | 1 | uinf | uinf | uinf | uinf | 2 | 2 |
|
|
|
|
| -inf | 1 | -inf | -inf | -inf | -inf | 2 | 2 |
|
|
|
|
| inf | 1 | inf | inf | inf | inf | 2 | 2 |
|
|
|
|
"
|
|
|
|
1 calc)))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/references/format-specifier-N ()
|
|
|
|
"Basic: Assign field reference, sum of field references, sum
|
|
|
|
and len of simple range reference (no row) and complex range
|
|
|
|
reference (with row). Format specifier N."
|
|
|
|
(let ((lisp
|
|
|
|
(concat
|
|
|
|
"#+TBLFM: $3 = '(identity $1); N :: $4 = '(+ $1 $2); N :: "
|
|
|
|
"$5 = '(+ $1..$2); N :: $6 = '(+ @0$1..@0$2); N :: "
|
|
|
|
"$7 = '(length '($1..$2)); N :: $8 = '(length '(@0$1..@0$2)); N"))
|
|
|
|
(calc
|
|
|
|
(concat
|
|
|
|
"#+TBLFM: $3 = $1; N :: $4 = $1 + $2; N :: "
|
|
|
|
"$5 = vsum($1..$2); N :: $6 = vsum(@0$1..@0$2); N :: "
|
|
|
|
"$7 = vlen($1..$2); N :: $8 = vlen(@0$1..@0$2); N")))
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-normal
|
|
|
|
"
|
|
|
|
| 0 | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| z | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
2012-12-28 09:02:01 -05:00
|
|
|
| | 1 | 0 | 1 | 1 | 1 | 1 | 1 |
|
|
|
|
| | | 0 | 0 | 0 | 0 | 1 | 1 |
|
2012-12-28 09:00:54 -05:00
|
|
|
"
|
|
|
|
1 lisp calc)
|
|
|
|
(org-test-table-target-expect
|
|
|
|
references/target-special
|
|
|
|
"
|
|
|
|
| nan | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| uinf | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| -inf | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
| inf | 1 | 0 | 1 | 1 | 1 | 2 | 2 |
|
|
|
|
"
|
|
|
|
1 calc)))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/compare ()
|
|
|
|
"Basic: Compare field references in Calc."
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
2012-12-28 09:03:10 -05:00
|
|
|
| | 0 | z | | nan | uinf | -inf | inf |
|
|
|
|
|------+------+------+------+------+------+------+------|
|
|
|
|
| 0 | repl | repl | repl | repl | repl | repl | repl |
|
|
|
|
| z | repl | repl | repl | repl | repl | repl | repl |
|
|
|
|
| | repl | repl | repl | repl | repl | repl | repl |
|
|
|
|
| nan | repl | repl | repl | repl | repl | repl | repl |
|
|
|
|
| uinf | repl | repl | repl | repl | repl | repl | repl |
|
|
|
|
| -inf | repl | repl | repl | repl | repl | repl | repl |
|
|
|
|
| inf | repl | repl | repl | repl | repl | repl | repl |
|
2012-12-28 09:00:54 -05:00
|
|
|
"
|
|
|
|
"
|
2012-12-28 09:03:10 -05:00
|
|
|
| | 0 | z | | nan | uinf | -inf | inf |
|
|
|
|
|------+---+---+---+-----+------+------+-----|
|
|
|
|
| 0 | x | | | | | | |
|
|
|
|
| z | | x | | | | | |
|
|
|
|
| | | | x | | | | |
|
|
|
|
| nan | | | | x | | | |
|
|
|
|
| uinf | | | | | x | | |
|
|
|
|
| -inf | | | | | | x | |
|
|
|
|
| inf | | | | | | | x |
|
2012-12-28 09:00:54 -05:00
|
|
|
"
|
|
|
|
1
|
|
|
|
;; Compare field reference ($1) with field reference (@1)
|
|
|
|
"#+TBLFM: @I$<<..@>$> = if(\"$1\" = \"@1\", x, string(\"\")); E"
|
|
|
|
;; Compare field reference ($1) with absolute term
|
|
|
|
(concat "#+TBLFM: "
|
|
|
|
"$2 = if(\"$1\" = \"(0)\" , x, string(\"\")); E :: "
|
|
|
|
"$3 = if(\"$1\" = \"(z)\" , x, string(\"\")); E :: "
|
2012-12-28 09:03:10 -05:00
|
|
|
"$4 = if(\"$1\" = \"nan\" , x, string(\"\")); E :: "
|
|
|
|
"$5 = if(\"$1\" = \"(nan)\" , x, string(\"\")); E :: "
|
|
|
|
"$6 = if(\"$1\" = \"(uinf)\", x, string(\"\")); E :: "
|
|
|
|
"$7 = if(\"$1\" = \"(-inf)\", x, string(\"\")); E :: "
|
|
|
|
"$8 = if(\"$1\" = \"(inf)\" , x, string(\"\")); E"))
|
2012-12-28 09:00:54 -05:00
|
|
|
|
|
|
|
;; Check field reference converted from an empty field: Despite this
|
|
|
|
;; field reference will not end up in a result, Calc evaluates it.
|
|
|
|
;; Make sure that also then there is no Calc error.
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| 0 | replace |
|
|
|
|
| z | replace |
|
2012-12-28 09:03:10 -05:00
|
|
|
| | replace |
|
2012-12-28 09:00:54 -05:00
|
|
|
| nan | replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| 0 | 1 |
|
|
|
|
| z | z + 1 |
|
2012-12-28 09:03:10 -05:00
|
|
|
| | |
|
2012-12-28 09:00:54 -05:00
|
|
|
| nan | nan |
|
|
|
|
"
|
|
|
|
1 "#+TBLFM: $2 = if(\"$1\" = \"nan\", string(\"\"), $1 + 1); E"))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/empty-field ()
|
|
|
|
"Examples how to deal with empty fields."
|
|
|
|
;; Empty fields in simple and complex range reference: Suppress them
|
|
|
|
;; ($5 and $6) or keep them and use 0 ($7 and $8)
|
|
|
|
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"\n| | | 5 | 7 | replace | replace | replace | replace |\n"
|
|
|
|
"\n| | | 5 | 7 | 6 | 6 | 3 | 3 |\n"
|
|
|
|
1
|
2012-12-28 09:02:01 -05:00
|
|
|
;; Calc formula
|
2012-12-28 09:00:54 -05:00
|
|
|
(concat "#+TBLFM: "
|
|
|
|
"$5 = vmean($1..$4) :: $6 = vmean(@0$1..@0$4) :: "
|
2012-12-28 09:02:01 -05:00
|
|
|
"$7 = vmean($1..$4); EN :: $8 = vmean(@0$1..@0$4); EN")
|
|
|
|
;; Lisp formula
|
2012-12-28 09:00:54 -05:00
|
|
|
(concat "#+TBLFM: "
|
|
|
|
"$5 = '(/ (+ $1..$4 ) (length '( $1..$4 ))); N :: "
|
|
|
|
"$6 = '(/ (+ @0$1..@0$4) (length '(@0$1..@0$4))); N :: "
|
|
|
|
"$7 = '(/ (+ $1..$4 ) (length '( $1..$4 ))); EN :: "
|
2012-12-28 09:03:10 -05:00
|
|
|
"$8 = '(/ (+ @0$1..@0$4) (length '(@0$1..@0$4))); EN"))
|
|
|
|
|
|
|
|
;; Test if one field is empty, else do a calculation
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| -1 | replace |
|
|
|
|
| 0 | replace |
|
|
|
|
| | replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| -1 | 0 |
|
|
|
|
| 0 | 1 |
|
|
|
|
| | |
|
|
|
|
"
|
|
|
|
1
|
|
|
|
;; Calc formula
|
|
|
|
"#+TBLFM: $2 = if(\"$1\" = \"nan\", string(\"\"), $1 + 1); E"
|
|
|
|
;; Lisp formula
|
|
|
|
"#+TBLFM: $2 = '(if (eq \"$1\" \"\") \"\" (1+ $1)); L")
|
|
|
|
|
|
|
|
;; Test if several fields are empty, else do a calculation
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| 1 | 2 | replace |
|
|
|
|
| 4 | | replace |
|
|
|
|
| | 8 | replace |
|
|
|
|
| | | replace |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| 1 | 2 | 3 |
|
|
|
|
| 4 | | |
|
|
|
|
| | 8 | |
|
|
|
|
| | | |
|
|
|
|
"
|
|
|
|
1
|
|
|
|
;; Calc formula
|
|
|
|
(concat "#+TBLFM: $3 = if(\"$1\" = \"nan\" || \"$2\" = \"nan\", "
|
|
|
|
"string(\"\"), $1 + $2); E")
|
|
|
|
;; Lisp formula
|
|
|
|
(concat "#+TBLFM: $3 = '(if (or (eq \"$1\" \"\") (eq \"$2\" \"\")) "
|
|
|
|
"\"\" (+ $1 $2)); L"))
|
|
|
|
|
|
|
|
;; $2: Use $1 + 0.5 if $1 available, else only reformat $2 if $2 available
|
|
|
|
(org-test-table-target-expect
|
|
|
|
"
|
|
|
|
| 1.5 | 0 |
|
|
|
|
| 3.5 | |
|
|
|
|
| | 5 |
|
|
|
|
| | |
|
|
|
|
"
|
|
|
|
"
|
|
|
|
| 1.5 | 2.0 |
|
|
|
|
| 3.5 | 4.0 |
|
|
|
|
| | 5.0 |
|
|
|
|
| | |
|
|
|
|
"
|
|
|
|
1
|
|
|
|
;; Calc formula
|
|
|
|
(concat "#+TBLFM: $2 = if(\"$1\" = \"nan\", "
|
|
|
|
"if(\"$2\" = \"nan\", string(\"\"), $2 +.0), $1 + 0.5); E f-1")
|
|
|
|
;; Lisp formula not implemented yet
|
|
|
|
))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/copy-field ()
|
|
|
|
"Experiments on how to copy one field into another field."
|
|
|
|
(let ((target
|
|
|
|
"
|
|
|
|
| 0 | replace |
|
|
|
|
| a b | replace |
|
|
|
|
| c d | replace |
|
|
|
|
| | replace |
|
|
|
|
| 2012-12 | replace |
|
|
|
|
| [2012-12-31 Mon] | replace |
|
|
|
|
"))
|
|
|
|
;; Lisp formula to copy literally
|
|
|
|
(org-test-table-target-expect
|
|
|
|
target
|
|
|
|
"
|
|
|
|
| 0 | 0 |
|
|
|
|
| a b | a b |
|
|
|
|
| c d | c d |
|
|
|
|
| | |
|
|
|
|
| 2012-12 | 2012-12 |
|
|
|
|
| [2012-12-31 Mon] | [2012-12-31 Mon] |
|
|
|
|
"
|
|
|
|
1 "#+TBLFM: $2 = '(identity $1)")
|
|
|
|
|
|
|
|
;; Calc formula to copy quite literally
|
|
|
|
(org-test-table-target-expect
|
|
|
|
target
|
|
|
|
"
|
|
|
|
| 0 | 0 |
|
|
|
|
| a b | a b |
|
|
|
|
| c d | c d |
|
|
|
|
| | |
|
|
|
|
| 2012-12 | 2012-12 |
|
|
|
|
| [2012-12-31 Mon] | <2012-12-31 Mon> |
|
|
|
|
"
|
|
|
|
1 (concat "#+TBLFM: $2 = if(\"$1\" = \"nan\", "
|
|
|
|
"string(\"\"), string(subvec(\"$1\", 2, vlen(\"$1\")))); E"))
|
|
|
|
|
|
|
|
;; Calc formula simple
|
|
|
|
(org-test-table-target-expect
|
|
|
|
target
|
|
|
|
"
|
|
|
|
| 0 | 0 |
|
|
|
|
| a b | a b |
|
|
|
|
| c d | c d |
|
|
|
|
| | |
|
|
|
|
| 2012-12 | 2000 |
|
|
|
|
| [2012-12-31 Mon] | <2012-12-31 Mon> |
|
|
|
|
"
|
|
|
|
1 "#+TBLFM: $2 = if(\"$1\" = \"nan\", string(\"\"), $1); E")))
|
2012-12-28 09:00:54 -05:00
|
|
|
|
|
|
|
;; End of table examples and beginning of internal tests.
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-make-reference/format-specifier-EL ()
|
|
|
|
(fset 'f 'org-table-make-reference)
|
|
|
|
;; For Lisp formula only
|
|
|
|
(should (equal "0" (f "0" t nil 'literal)))
|
|
|
|
(should (equal "z" (f "z" t nil 'literal)))
|
|
|
|
(should (equal "" (f "" t nil 'literal)))
|
|
|
|
(should (equal "0 1" (f '("0" "1") t nil 'literal)))
|
|
|
|
(should (equal "z 1" (f '("z" "1") t nil 'literal)))
|
|
|
|
(should (equal " 1" (f '("" "1") t nil 'literal)))
|
|
|
|
(should (equal " " (f '("" "" ) t nil 'literal))))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-make-reference/format-specifier-E ()
|
|
|
|
(fset 'f 'org-table-make-reference)
|
|
|
|
;; For Lisp formula
|
|
|
|
(should (equal "\"0\"" (f "0" t nil t)))
|
|
|
|
(should (equal "\"z\"" (f "z" t nil t)))
|
|
|
|
(should (equal "\"\"" (f "" t nil t)))
|
|
|
|
(should (equal "\"0\" \"1\"" (f '("0" "1") t nil t)))
|
|
|
|
(should (equal "\"z\" \"1\"" (f '("z" "1") t nil t)))
|
|
|
|
(should (equal "\"\" \"1\"" (f '("" "1") t nil t)))
|
|
|
|
(should (equal "\"\" \"\"" (f '("" "" ) t nil t)))
|
|
|
|
;; For Calc formula
|
|
|
|
(should (equal "(0)" (f "0" t nil nil)))
|
|
|
|
(should (equal "(z)" (f "z" t nil nil)))
|
2012-12-28 09:03:10 -05:00
|
|
|
(should (equal "nan" (f "" t nil nil)))
|
2012-12-28 09:00:54 -05:00
|
|
|
(should (equal "[0,1]" (f '("0" "1") t nil nil)))
|
|
|
|
(should (equal "[z,1]" (f '("z" "1") t nil nil)))
|
2012-12-28 09:03:10 -05:00
|
|
|
(should (equal "[nan,1]" (f '("" "1") t nil nil)))
|
|
|
|
(should (equal "[nan,nan]" (f '("" "" ) t nil nil)))
|
2012-12-28 09:00:54 -05:00
|
|
|
;; For Calc formula, special numbers
|
|
|
|
(should (equal "(nan)" (f "nan" t nil nil)))
|
|
|
|
(should (equal "(uinf)" (f "uinf" t nil nil)))
|
|
|
|
(should (equal "(-inf)" (f "-inf" t nil nil)))
|
|
|
|
(should (equal "(inf)" (f "inf" t nil nil)))
|
|
|
|
(should (equal "[nan,1]" (f '( "nan" "1") t nil nil)))
|
|
|
|
(should (equal "[uinf,1]" (f '("uinf" "1") t nil nil)))
|
|
|
|
(should (equal "[-inf,1]" (f '("-inf" "1") t nil nil)))
|
|
|
|
(should (equal "[inf,1]" (f '( "inf" "1") t nil nil))))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-make-reference/format-specifier-EN ()
|
|
|
|
(fset 'f 'org-table-make-reference)
|
|
|
|
;; For Lisp formula
|
|
|
|
(should (equal "0" (f "0" t t t)))
|
|
|
|
(should (equal "0" (f "z" t t t)))
|
|
|
|
(should (equal "0" (f "" t t t)))
|
|
|
|
(should (equal "0 1" (f '("0" "1") t t t)))
|
|
|
|
(should (equal "0 1" (f '("z" "1") t t t)))
|
|
|
|
(should (equal "0 1" (f '("" "1") t t t)))
|
|
|
|
(should (equal "0 0" (f '("" "" ) t t t)))
|
|
|
|
;; For Calc formula
|
|
|
|
(should (equal "(0)" (f "0" t t nil)))
|
|
|
|
(should (equal "(0)" (f "z" t t nil)))
|
|
|
|
(should (equal "(0)" (f "" t t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("0" "1") t t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("z" "1") t t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("" "1") t t nil)))
|
|
|
|
(should (equal "[0,0]" (f '("" "" ) t t nil)))
|
|
|
|
;; For Calc formula, special numbers
|
|
|
|
(should (equal "(0)" (f "nan" t t nil)))
|
|
|
|
(should (equal "(0)" (f "uinf" t t nil)))
|
|
|
|
(should (equal "(0)" (f "-inf" t t nil)))
|
|
|
|
(should (equal "(0)" (f "inf" t t nil)))
|
|
|
|
(should (equal "[0,1]" (f '( "nan" "1") t t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("uinf" "1") t t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("-inf" "1") t t nil)))
|
|
|
|
(should (equal "[0,1]" (f '( "inf" "1") t t nil))))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-make-reference/format-specifier-L ()
|
|
|
|
(fset 'f 'org-table-make-reference)
|
|
|
|
;; For Lisp formula only
|
|
|
|
(should (equal "0" (f "0" nil nil 'literal)))
|
|
|
|
(should (equal "z" (f "z" nil nil 'literal)))
|
|
|
|
(should (equal "" (f "" nil nil 'literal)))
|
|
|
|
(should (equal "0 1" (f '("0" "1") nil nil 'literal)))
|
|
|
|
(should (equal "z 1" (f '("z" "1") nil nil 'literal)))
|
|
|
|
(should (equal "1" (f '("" "1") nil nil 'literal)))
|
2012-12-28 09:02:01 -05:00
|
|
|
(should (equal "" (f '("" "" ) nil nil 'literal))))
|
2012-12-28 09:00:54 -05:00
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-make-reference/format-specifier-none ()
|
|
|
|
(fset 'f 'org-table-make-reference)
|
|
|
|
;; For Lisp formula
|
|
|
|
(should (equal "\"0\"" (f "0" nil nil t)))
|
|
|
|
(should (equal "\"z\"" (f "z" nil nil t)))
|
|
|
|
(should (equal "\"\"" (f "" nil nil t)))
|
|
|
|
(should (equal "\"0\" \"1\"" (f '("0" "1") nil nil t)))
|
|
|
|
(should (equal "\"z\" \"1\"" (f '("z" "1") nil nil t)))
|
|
|
|
(should (equal "\"1\"" (f '("" "1") nil nil t)))
|
2012-12-28 09:02:01 -05:00
|
|
|
(should (equal "\"\"" (f '("" "" ) nil nil t)))
|
2012-12-28 09:00:54 -05:00
|
|
|
;; For Calc formula
|
|
|
|
(should (equal "(0)" (f "0" nil nil nil)))
|
|
|
|
(should (equal "(z)" (f "z" nil nil nil)))
|
|
|
|
(should (equal "(0)" (f "" nil nil nil)))
|
|
|
|
(should (equal "[0,1]" (f '("0" "1") nil nil nil)))
|
|
|
|
(should (equal "[z,1]" (f '("z" "1") nil nil nil)))
|
|
|
|
(should (equal "[1]" (f '("" "1") nil nil nil)))
|
|
|
|
(should (equal "[0]" (f '("" "" ) nil nil nil)))
|
|
|
|
;; For Calc formula, special numbers
|
|
|
|
(should (equal "(nan)" (f "nan" nil nil nil)))
|
|
|
|
(should (equal "(uinf)" (f "uinf" nil nil nil)))
|
|
|
|
(should (equal "(-inf)" (f "-inf" nil nil nil)))
|
|
|
|
(should (equal "(inf)" (f "inf" nil nil nil)))
|
|
|
|
(should (equal "[nan,1]" (f '( "nan" "1") nil nil nil)))
|
|
|
|
(should (equal "[uinf,1]" (f '("uinf" "1") nil nil nil)))
|
|
|
|
(should (equal "[-inf,1]" (f '("-inf" "1") nil nil nil)))
|
|
|
|
(should (equal "[inf,1]" (f '( "inf" "1") nil nil nil))))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-make-reference/format-specifier-N ()
|
|
|
|
(fset 'f 'org-table-make-reference)
|
|
|
|
;; For Lisp formula
|
|
|
|
(should (equal "0" (f "0" nil t t)))
|
|
|
|
(should (equal "0" (f "z" nil t t)))
|
|
|
|
(should (equal "0" (f "" nil t t)))
|
|
|
|
(should (equal "0 1" (f '("0" "1") nil t t)))
|
|
|
|
(should (equal "0 1" (f '("z" "1") nil t t)))
|
|
|
|
(should (equal "1" (f '("" "1") nil t t)))
|
|
|
|
(should (equal "0" (f '("" "" ) nil t t)))
|
|
|
|
;; For Calc formula
|
|
|
|
(should (equal "(0)" (f "0" nil t nil)))
|
|
|
|
(should (equal "(0)" (f "z" nil t nil)))
|
|
|
|
(should (equal "(0)" (f "" nil t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("0" "1") nil t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("z" "1") nil t nil)))
|
|
|
|
(should (equal "[1]" (f '("" "1") nil t nil)))
|
|
|
|
(should (equal "[0]" (f '("" "" ) nil t nil)))
|
|
|
|
;; For Calc formula, special numbers
|
|
|
|
(should (equal "(0)" (f "nan" nil t nil)))
|
|
|
|
(should (equal "(0)" (f "uinf" nil t nil)))
|
|
|
|
(should (equal "(0)" (f "-inf" nil t nil)))
|
|
|
|
(should (equal "(0)" (f "inf" nil t nil)))
|
|
|
|
(should (equal "[0,1]" (f '( "nan" "1") nil t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("uinf" "1") nil t nil)))
|
|
|
|
(should (equal "[0,1]" (f '("-inf" "1") nil t nil)))
|
|
|
|
(should (equal "[0,1]" (f '( "inf" "1") nil t nil))))
|
|
|
|
|
2011-01-11 16:07:33 -05:00
|
|
|
(ert-deftest test-org-table/org-table-convert-refs-to-an/1 ()
|
|
|
|
"Simple reference @1$1."
|
|
|
|
(should
|
|
|
|
(string= "A1" (org-table-convert-refs-to-an "@1$1"))))
|
|
|
|
|
2011-07-04 14:13:41 -04:00
|
|
|
;; TODO: Test broken
|
2011-03-02 13:07:15 -05:00
|
|
|
;; (ert-deftest test-org-table/org-table-convert-refs-to-an/2 ()
|
|
|
|
;; "Self reference @1$1."
|
|
|
|
;; (should
|
|
|
|
;; (string= "A1 = $0" (org-table-convert-refs-to-an "@1$1 = $0"))))
|
2011-01-11 16:07:33 -05:00
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-convert-refs-to-an/3 ()
|
|
|
|
"Remote reference."
|
|
|
|
(should
|
|
|
|
(string= "C& = remote(FOO, @@#B&)" (org-table-convert-refs-to-an "$3 = remote(FOO, @@#$2)"))))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-convert-refs-to-rc/1 ()
|
|
|
|
"Simple reference @1$1."
|
|
|
|
(should
|
|
|
|
(string= "@1$1" (org-table-convert-refs-to-rc "A1"))))
|
|
|
|
|
|
|
|
(ert-deftest test-org-table/org-table-convert-refs-to-rc/2 ()
|
|
|
|
"Self reference $0."
|
|
|
|
(should
|
|
|
|
(string= "@1$1 = $0" (org-table-convert-refs-to-rc "A1 = $0"))))
|
|
|
|
|
2011-07-04 14:13:41 -04:00
|
|
|
;; TODO: Test Broken
|
2011-03-02 13:07:15 -05:00
|
|
|
;; (ert-deftest test-org-table/org-table-convert-refs-to-rc/3 ()
|
|
|
|
;; "Remote reference."
|
|
|
|
;; (should
|
|
|
|
;; (string= "$3 = remote(FOO, @@#$2)" (org-table-convert-refs-to-rc "C& = remote(FOO, @@#B&)"))))
|
2011-01-11 16:07:33 -05:00
|
|
|
|
|
|
|
(provide 'test-org-table)
|
|
|
|
|
|
|
|
;;; test-org-table.el ends here
|