aboutsummaryrefslogtreecommitdiffstats
path: root/test/src/alloc-tests.el
diff options
context:
space:
mode:
authorLars Brinkhoff2013-01-06 14:27:44 +0100
committerLars Brinkhoff2017-04-04 08:23:46 +0200
commita2c33430292c79ac520100b1d0e8e7c04dfe426a (patch)
treec14abd179a8646449c1430f24762db3e2359886a /test/src/alloc-tests.el
parent19b92cdfb04a025037d7388954b64468d6f54462 (diff)
downloademacs-a2c33430292c79ac520100b1d0e8e7c04dfe426a.tar.gz
emacs-a2c33430292c79ac520100b1d0e8e7c04dfe426a.zip
Add record objects with user-defined types.
* src/alloc.c (allocate_record): New function. (Fmake_record, Frecord, Fcopy_record): New functions. (syms_of_alloc): defsubr them. (purecopy): Work with records. * src/data.c (Ftype_of): Return slot 0 for record objects, or type name if record's type holds class. (Frecordp): New function. (syms_of_data): defsubr it. Define `Qrecordp'. (Faref, Faset): Work with records. * src/fns.c (Flength): Work with records. * src/lisp.h (prec_type): Add PVEC_RECORD. (RECORDP, CHECK_RECORD, CHECK_RECORD_TYPE): New functions. * src/lread.c (read1): Add syntax for records. * src/print.c (PRINT_CIRCLE_CANDIDATE_P): Add RECORDP. (print_object): Add syntax for records. * test/lisp/emacs-lisp/cl-print-tests.el (cl-print-tests-2): New test. * test/src/alloc-tests.el (record-1, record-2, record-3): New tests. * doc/lispref/elisp.texi, doc/lispref/objects.texi, doc/lispref/records.texi: Add documentation for records.
Diffstat (limited to 'test/src/alloc-tests.el')
-rw-r--r--test/src/alloc-tests.el20
1 files changed, 20 insertions, 0 deletions
diff --git a/test/src/alloc-tests.el b/test/src/alloc-tests.el
index af4ad6c6355..8b4ef8ce7d2 100644
--- a/test/src/alloc-tests.el
+++ b/test/src/alloc-tests.el
@@ -31,3 +31,23 @@
31 31
32(ert-deftest finalizer-object-type () 32(ert-deftest finalizer-object-type ()
33 (should (equal (type-of (make-finalizer nil)) 'finalizer))) 33 (should (equal (type-of (make-finalizer nil)) 'finalizer)))
34
35(ert-deftest record-1 ()
36 (let ((x (record 'foo 1 2 3)))
37 (should (recordp x))
38 (should (eq (type-of x) 'foo))
39 (should (eq (aref x 0) 'foo))
40 (should (eql (aref x 3) 3))
41 (should (eql (length x) 4))))
42
43(ert-deftest record-2 ()
44 (let ((x (make-record 'bar 1 0)))
45 (should (eql (length x) 2))
46 (should (eql (aref x 1) 0))))
47
48(ert-deftest record-3 ()
49 (let* ((x (record 'foo 1 2 3))
50 (y (copy-record x)))
51 (should-not (eq x y))
52 (dotimes (i 4)
53 (should (eql (aref x i) (aref y i))))))