* test/src/comp-resources/comp-test-pure.el: Rename.
* test/src/comp-resources/comp-test-funcs.el: Likewise.
* test/src/comp-resources/comp-test-funcs-dyn.el: Likewise.
* test/src/comp-resources/comp-test-45603.el: Likewise.
* test/src/comp-tests.el (comp-test-src, comp-test-dyn-src): Use
`ert-resource-file'.
(comp-tests-bootstrap): Use ert-resource-directory.
(comp-tests-45603-1, comp-tests-pure): Use `ert-resource-file'.
--- /dev/null
+;;; -*- lexical-binding: t; -*-
+
+;; Reduced from ivy.el.
+
+(defvar comp-test-45603-last)
+(defvar comp-test-45603-mark-prefix)
+(defvar comp-test-45603-directory)
+(defvar comp-test-45603-marked-candidates)
+
+(defun comp-test-45603--call-marked (action)
+ (let* ((prefix-len (length comp-test-45603-mark-prefix))
+ (marked-candidates
+ (mapcar
+ (lambda (s)
+ (let ((cand (substring s prefix-len)))
+ (if comp-test-45603-directory
+ (expand-file-name cand comp-test-45603-directory)
+ cand)))
+ comp-test-45603-marked-candidates))
+ (multi-action (comp-test-45603--get-multi-action comp-test-45603-last)))))
+
+(defalias 'comp-test-45603--file-local-name
+ (if (fboundp 'file-local-name)
+ #'file-local-name
+ (lambda (file)
+ (or (file-remote-p file 'localname) file))))
+
+(provide 'comp-test-45603)
--- /dev/null
+;;; comp-test-funcs-dyn.el --- compilation unit tested by comp-tests.el -*- lexical-binding: nil; -*-
+
+;; Copyright (C) 2020-2021 Free Software Foundation, Inc.
+
+;; Author: Andrea Corallo <akrl@sdf.org>
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs 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.
+
+;; GNU Emacs 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 GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+
+;;; Code:
+
+(require 'cl-lib)
+
+(defun comp-tests-ffuncall-callee-dyn-f (a b)
+ (list a b))
+
+(defun comp-tests-ffuncall-callee-opt-dyn-f (a b &optional c d)
+ (list a b c d))
+
+(defun comp-tests-ffuncall-callee-rest-dyn-f (a b &rest c)
+ (list a b c))
+
+(defun comp-tests-ffuncall-callee-opt-rest-dyn-f (a b &optional c &rest d)
+ (list a b c d))
+
+(defun comp-tests-cl-macro-exp-f ()
+ (cl-loop for xxx in '(a b)
+ for yyy = xxx
+ collect xxx))
+
+(cl-defun comp-tests-cl-uninterned-arg-parse-f (a &optional b &aux)
+ (list a b))
+
+(provide 'comp-test-dyn-funcs)
+
+;;; comp-test-funcs-dyn.el ends here
--- /dev/null
+;;; comp-test-funcs.el --- compilation unit tested by comp-tests.el -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2019-2021 Free Software Foundation, Inc.
+
+;; Author: Andrea Corallo <akrl@sdf.org>
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs 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.
+
+;; GNU Emacs 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 GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+
+;;; Code:
+
+(defvar comp-tests-var1 3)
+
+(defun comp-tests-varref-f ()
+ comp-tests-var1)
+
+(defun comp-tests-list-f ()
+ (list 1 2 3))
+(defun comp-tests-list2-f (a b c)
+ (list a b c))
+(defun comp-tests-car-f (x)
+ ;; Bcar
+ (car x))
+(defun comp-tests-cdr-f (x)
+ ;; Bcdr
+ (cdr x))
+(defun comp-tests-car-safe-f (x)
+ ;; Bcar_safe
+ (car-safe x))
+(defun comp-tests-cdr-safe-f (x)
+ ;; Bcdr_safe
+ (cdr-safe x))
+
+(defun comp-tests-cons-car-f ()
+ (car (cons 1 2)))
+(defun comp-tests-cons-cdr-f (x)
+ (cdr (cons 'foo x)))
+
+(defun comp-tests-hint-fixnum-f (n)
+ (1+ (comp-hint-fixnum n)))
+
+(defun comp-tests-hint-cons-f (c)
+ (car (comp-hint-cons c)))
+
+(defun comp-tests-varset0-f ()
+ (setq comp-tests-var1 55))
+(defun comp-tests-varset1-f ()
+ (setq comp-tests-var1 66)
+ 4)
+
+(defun comp-tests-length-f ()
+ (length '(1 2 3)))
+
+(defun comp-tests-aref-aset-f ()
+ (let ((vec (make-vector 3 0)))
+ (aset vec 2 100)
+ (aref vec 2)))
+
+(defvar comp-tests-var2 3)
+(defun comp-tests-symbol-value-f ()
+ (symbol-value 'comp-tests-var2))
+
+(defun comp-tests-concat-f (x)
+ (concat "a" "b" "c" "d"
+ (concat "a" "b" "c" (concat "a" "b" (concat "foo" x)))))
+
+(defun comp-tests-ffuncall-callee-f (x y z)
+ (list x y z))
+
+(defun comp-tests-ffuncall-callee-optional-f (a b &optional c d)
+ (list a b c d))
+
+(defun comp-tests-ffuncall-callee-rest-f (a b &rest c)
+ (list a b c))
+
+(defun comp-tests-ffuncall-callee-more8-f (p1 p2 p3 p4 p5 p6 p7 p8 p9 p10)
+ ;; More then 8 args.
+ (list p1 p2 p3 p4 p5 p6 p7 p8 p9 p10))
+
+(defun comp-tests-ffuncall-callee-more8-rest-f (p1 p2 p3 p4 p5 p6 p7 p8 p9 &rest p10)
+ ;; More then 8 args.
+ (list p1 p2 p3 p4 p5 p6 p7 p8 p9 p10))
+
+(defun comp-tests-ffuncall-native-f ()
+ "Call a primitive with no dedicate op."
+ (make-vector 1 nil))
+
+(defun comp-tests-ffuncall-native-rest-f ()
+ "Call a primitive with no dedicate op with &rest."
+ (vector 1 2 3))
+
+(defun comp-tests-ffuncall-apply-many-f (x)
+ (apply #'list x))
+
+(defun comp-tests-ffuncall-lambda-f (x)
+ (let ((fun (lambda (x)
+ (1+ x))))
+ (funcall fun x)))
+
+(defun comp-tests-jump-table-1-f (x)
+ (pcase x
+ ('x 'a)
+ ('y 'b)
+ (_ 'c)))
+
+(defun comp-tests-jump-table-2-f (x)
+ (pcase x
+ ("aaa" 'a)
+ ("bbb" 'b)))
+
+(defun comp-tests-conditionals-1-f (x)
+ ;; Generate goto-if-nil
+ (if x 1 2))
+(defun comp-tests-conditionals-2-f (x)
+ ;; Generate goto-if-nil-else-pop
+ (when x
+ 1340))
+
+(defun comp-tests-fixnum-1-minus-f (x)
+ ;; Bsub1
+ (1- x))
+(defun comp-tests-fixnum-1-plus-f (x)
+ ;; Badd1
+ (1+ x))
+(defun comp-tests-fixnum-minus-f (x)
+ ;; Bnegate
+ (- x))
+
+(defun comp-tests-eqlsign-f (x y)
+ ;; Beqlsign
+ (= x y))
+(defun comp-tests-gtr-f (x y)
+ ;; Bgtr
+ (> x y))
+(defun comp-tests-lss-f (x y)
+ ;; Blss
+ (< x y))
+(defun comp-tests-les-f (x y)
+ ;; Bleq
+ (<= x y))
+(defun comp-tests-geq-f (x y)
+ ;; Bgeq
+ (>= x y))
+
+(defun comp-tests-setcar-f (x y)
+ (setcar x y)
+ x)
+(defun comp-tests-setcdr-f (x y)
+ (setcdr x y)
+ x)
+
+(defun comp-bubble-sort-f (list)
+ (let ((i (length list)))
+ (while (> i 1)
+ (let ((b list))
+ (while (cdr b)
+ (when (< (cadr b) (car b))
+ (setcar b (prog1 (cadr b)
+ (setcdr b (cons (car b) (cddr b))))))
+ (setq b (cdr b))))
+ (setq i (1- i)))
+ list))
+
+(defun comp-tests-consp-f (x)
+ ;; Bconsp
+ (consp x))
+(defun comp-tests-setcar2-f (x)
+ ;; Bsetcar
+ (setcar x 3))
+
+(defun comp-tests-integerp-f (x)
+ ;; Bintegerp
+ (integerp x))
+(defun comp-tests-numberp-f (x)
+ ;; Bnumberp
+ (numberp x))
+
+(defun comp-tests-discardn-f (x)
+ ;; BdiscardN
+ (1+ (let ((a 1)
+ (_b)
+ (_c))
+ a)))
+(defun comp-tests-insertn-f (a b c d)
+ ;; Binsert
+ (insert a b c d))
+
+(defun comp-tests-err-arith-f ()
+ (/ 1 0))
+(defun comp-tests-err-foo-f ()
+ (error "foo"))
+
+(defun comp-tests-condition-case-0-f ()
+ ;; Bpushhandler Bpophandler
+ (condition-case
+ err
+ (comp-tests-err-arith-f)
+ (arith-error (concat "arith-error "
+ (error-message-string err)
+ " catched"))
+ (error (concat "error "
+ (error-message-string err)
+ " catched"))))
+(defun comp-tests-condition-case-1-f ()
+ ;; Bpushhandler Bpophandler
+ (condition-case
+ err
+ (comp-tests-err-foo-f)
+ (arith-error (concat "arith-error "
+ (error-message-string err)
+ " catched"))
+ (error (concat "error "
+ (error-message-string err)
+ " catched"))))
+(defun comp-tests-catch-f (f)
+ (catch 'foo
+ (funcall f)))
+(defun comp-tests-throw-f (x)
+ (throw 'foo x))
+
+(defun comp-tests-buff0-f ()
+ (with-temp-buffer
+ (insert "foo")
+ (buffer-string)))
+
+(defun comp-tests-lambda-return-f ()
+ (lambda (x) (1+ x)))
+
+(defun comp-tests-fib-f (n)
+ (cond ((= n 0) 0)
+ ((= n 1) 1)
+ (t (+ (comp-tests-fib-f (- n 1))
+ (comp-tests-fib-f (- n 2))))))
+
+(defmacro comp-tests-macro-m (x)
+ x)
+
+(defun comp-tests-string-trim-f (url)
+ (string-trim url))
+
+(defun comp-tests-trampoline-removal-f ()
+ (make-hash-table))
+
+(defun comp-tests-signal-f ()
+ (signal 'foo t))
+
+(defun comp-tests-func-call-removal-f ()
+ (let ((a 10)
+ (b 3))
+ (% a b)))
+
+(defun comp-tests-doc-f ()
+ "A nice docstring"
+ t)
+
+(defun comp-test-interactive-form0-f (dir)
+ (interactive "D")
+ dir)
+
+(defun comp-test-interactive-form1-f (x y)
+ (interactive '(1 2))
+ (+ x y))
+
+(defun comp-test-interactive-form2-f ()
+ (interactive))
+
+(defun comp-test-40187-2-f ()
+ 'foo)
+
+(defalias 'comp-test-40187-1-f (symbol-function 'comp-test-40187-2-f))
+
+(defun comp-test-40187-2-f ()
+ 'bar)
+
+(defun comp-test-speed--1-f ()
+ (declare (speed -1))
+ 3)
+
+(defun comp-test-42360-f (str end-column
+ &optional start-column padding ellipsis
+ ellipsis-text-property)
+ ;; From `truncate-string-to-width'. A large enough function to
+ ;; potentially use all registers and that is modifying local
+ ;; variables inside condition-case.
+ (let ((str-len (length str))
+ (str-width 14)
+ (ellipsis-width 3)
+ (idx 0)
+ (column 0)
+ (head-padding "") (tail-padding "")
+ ch last-column last-idx from-idx)
+ (condition-case nil
+ (while (< column start-column)
+ (setq ch (aref str idx)
+ column (+ column (char-width ch))
+ idx (1+ idx)))
+ (args-out-of-range (setq idx str-len)))
+ (if (< column start-column)
+ (if padding (make-string end-column padding) "")
+ (when (and padding (> column start-column))
+ (setq head-padding (make-string (- column start-column) padding)))
+ (setq from-idx idx)
+ (when (>= end-column column)
+ (condition-case nil
+ (while (< column end-column)
+ (setq last-column column
+ last-idx idx
+ ch (aref str idx)
+ column (+ column (char-width ch))
+ idx (1+ idx)))
+ (args-out-of-range (setq idx str-len)))
+ (when (> column end-column)
+ (setq column last-column
+ idx last-idx))
+ (when (and padding (< column end-column))
+ (setq tail-padding (make-string (- end-column column) padding))))
+ (if (and ellipsis-text-property
+ (not (equal ellipsis ""))
+ idx)
+ (concat head-padding
+ (substring str from-idx idx)
+ (propertize (substring str idx) 'display (or ellipsis "")))
+ (concat head-padding (substring str from-idx idx)
+ tail-padding ellipsis)))))
+
+(defun comp-test-primitive-advice-f (x y)
+ (declare (speed 2))
+ (+ x y))
+
+(defun comp-test-primitive-redefine-f (x y)
+ (declare (speed 2))
+ (- x y))
+
+(defsubst comp-test-defsubst-f ()
+ t)
+
+(defvar comp-test-and-3-var 1)
+(defun comp-test-and-3-f (x)
+ (and (atom x)
+ comp-test-and-3-var
+ 2))
+
+(defun comp-test-copy-insn-f (insn)
+ ;; From `comp-copy-insn'.
+ (if (consp insn)
+ (let (result)
+ (while (consp insn)
+ (let ((newcar (car insn)))
+ (if (or (consp (car insn)) (comp-mvar-p (car insn)))
+ (setf newcar (comp-copy-insn (car insn))))
+ (push newcar result))
+ (setf insn (cdr insn)))
+ (nconc (nreverse result)
+ (if (comp-mvar-p insn) (comp-copy-insn insn) insn)))
+ (if (comp-mvar-p insn)
+ (copy-comp-mvar insn)
+ insn)))
+
+(defun comp-test-cond-rw-1-1-f ())
+
+(defun comp-test-cond-rw-1-2-f ()
+ (let ((it (comp-test-cond-rw-1-1-f))
+ (key 't))
+ (if (or (equal it key)
+ (eq key t))
+ it
+ nil)))
+
+(defun comp-test-44968-f (start end)
+ (let ((dirlist)
+ (dir (expand-file-name start))
+ (end (expand-file-name end)))
+ (while (not (or (equal dir (car dirlist))
+ (file-equal-p dir end)))
+ (push dir dirlist)
+ (setq dir (directory-file-name (file-name-directory dir))))
+ (nreverse dirlist)))
+
+(defun comp-test-45342-f (n)
+ (pcase n
+ (1 " ➊") (2 " ➋") (3 " ➌") (4 " ➍") (5 " ➎") (6 " ➏")
+ (7 " ➐") (8 " ➑") (9 " ➒") (10 " ➓") (_ "")))
+
+(defun comp-test-assume-double-neg-f (collection value)
+ ;; Reduced from `auth-source-search-collection'.
+ (when (atom collection)
+ (setq collection (list collection)))
+ (or (eq value t)
+ ;; value is (not (member t))
+ (eq collection value)
+ ;; collection is t, not (member t)!
+ (member value collection)))
+
+(defun comp-test-assume-in-loop-1-f (arg)
+ ;; Reduced from `comint-delim-arg'.
+ (let ((args nil)
+ (pos 0)
+ (len (length arg)))
+ (while (< pos len)
+ (let ((start pos))
+ (while (< pos len)
+ (setq pos (1+ pos)))
+ (setq args (cons (substring arg start pos) args))))
+ args))
+
+(defun comp-test-45376-1-f ()
+ ;; Reduced from `eshell-ls-find-column-lengths'.
+ (let* (res
+ (len 2)
+ (i 0)
+ (j 0))
+ (while (< j len)
+ (if (= i len)
+ (setq i 0))
+ (setq res (cons i res)
+ j (1+ j)
+ i (1+ i)))
+ res))
+
+(defun comp-test-45376-2-f ()
+ ;; Also reduced from `eshell-ls-find-column-lengths'.
+ (let* ((x 1)
+ res)
+ (while x
+ (let* ((y 4)
+ (i 0))
+ (while (> y 0)
+ (when (= i x)
+ (setq i 0))
+ (setf res (cons i res))
+ (setq y (1- y)
+ i (1+ i)))
+ (if (>= x 3)
+ (setq x nil)
+ (setq x (1+ x)))))
+ res))
+
+(defun comp-test-not-cons-f (x)
+ ;; Reduced from `cl-copy-list'.
+ (if (consp x)
+ (print x)
+ (car x)))
+
+(defun comp-test-45576-f ()
+ ;; Reduced from `eshell-find-alias-function'.
+ (let ((sym (intern-soft "eval")))
+ (if (and (functionp sym)
+ '(eshell-ls eshell-pred eshell-prompt eshell-script
+ eshell-term eshell-unix))
+ sym)))
+
+(defun comp-test-45635-f (&rest args)
+ ;; Reduced from `set-face-attribute'.
+ (let ((spec args)
+ family)
+ (while spec
+ (cond ((eq (car spec) :family)
+ (setq family (cadr spec))))
+ (setq spec (cddr spec)))
+ (when (and (stringp family)
+ (string-match "\\([^-]*\\)-\\([^-]*\\)" family))
+ (setq family (match-string 2 family)))
+ (when (or (stringp family)
+ (eq family 'unspecified))
+ family)))
+
+(defun comp-test-46670-1-f (_)
+ "foo")
+
+(defun comp-test-46670-2-f (s)
+ (and (equal (comp-test-46670-1-f (length s)) s)
+ s))
+
+(cl-defun comp-test-46824-1-f ()
+ (let ((next-repos '(1)))
+ (while t
+ (let ((recipe (car next-repos)))
+ (cl-block loop
+ (while t
+ (let ((err
+ (condition-case e
+ (progn
+ (setq next-repos
+ (cdr next-repos))
+ (cl-return-from loop))
+ (error e))))
+ (format "%S"
+ (error-message-string err))))))
+ (cl-return-from comp-test-46824-1-f))))
+
+(defun comp-test-47868-1-f ()
+ " ")
+
+(defun comp-test-47868-2-f ()
+ #(" " 0 1 (face font-lock-keyword-face)))
+
+(defun comp-test-47868-3-f ()
+ " ")
+
+(defun comp-test-47868-4-f ()
+ #(" " 0 1 (face font-lock-keyword-face)))
+
+
+\f
+;;;;;;;;;;;;;;;;;;;;
+;; Tromey's tests ;;
+;;;;;;;;;;;;;;;;;;;;
+
+;; Test Bconsp.
+(defun comp-test-consp (x) (consp x))
+
+;; Test Blistp.
+(defun comp-test-listp (x) (listp x))
+
+;; Test Bstringp.
+(defun comp-test-stringp (x) (stringp x))
+
+;; Test Bsymbolp.
+(defun comp-test-symbolp (x) (symbolp x))
+
+;; Test Bintegerp.
+(defun comp-test-integerp (x) (integerp x))
+
+;; Test Bnumberp.
+(defun comp-test-numberp (x) (numberp x))
+
+;; Test Badd1.
+(defun comp-test-add1 (x) (1+ x))
+
+;; Test Bsub1.
+(defun comp-test-sub1 (x) (1- x))
+
+;; Test Bneg.
+(defun comp-test-negate (x) (- x))
+
+;; Test Bnot.
+(defun comp-test-not (x) (not x))
+
+;; Test Bbobp, Beobp, Bpoint, Bpoint_min, Bpoint_max.
+(defun comp-test-bobp () (bobp))
+(defun comp-test-eobp () (eobp))
+(defun comp-test-point () (point))
+(defun comp-test-point-min () (point-min))
+(defun comp-test-point-max () (point-max))
+
+;; Test Bcar and Bcdr.
+(defun comp-test-car (x) (car x))
+(defun comp-test-cdr (x) (cdr x))
+
+;; Test Bcar_safe and Bcdr_safe.
+(defun comp-test-car-safe (x) (car-safe x))
+(defun comp-test-cdr-safe (x) (cdr-safe x))
+
+;; Test Beq.
+(defun comp-test-eq (x y) (eq x y))
+
+;; Test Bgotoifnil.
+(defun comp-test-if (x y) (if x x y))
+
+;; Test Bgotoifnilelsepop.
+(defun comp-test-and (x y) (and x y))
+
+;; Test Bgotoifnonnilelsepop.
+(defun comp-test-or (x y) (or x y))
+
+;; Test Bsave_excursion.
+(defun comp-test-save-excursion ()
+ (save-excursion
+ (insert "XYZ")))
+
+;; Test Bcurrent_buffer.
+(defun comp-test-current-buffer () (current-buffer))
+
+;; Test Bgtr.
+(defun comp-test-> (a b)
+ (> a b))
+
+;; Test Bpushcatch.
+(defun comp-test-catch (&rest l)
+ (catch 'done
+ (dolist (v l)
+ (when (> v 23)
+ (throw 'done v)))))
+
+;; Test Bmemq.
+(defun comp-test-memq (val list)
+ (memq val list))
+
+;; Test BlistN.
+(defun comp-test-listN (x)
+ (list x x x x x x x x x x x x x x x x))
+
+;; Test BconcatN.
+(defun comp-test-concatN (x)
+ (concat x x x x x x))
+
+;; Test optional and rest arguments.
+(defun comp-test-opt-rest (a &optional b &rest c)
+ (list a b c))
+
+;; Test for too many arguments.
+(defun comp-test-opt (a &optional b)
+ (cons a b))
+
+;; Test for unwind-protect.
+(defvar comp-test-up-val nil)
+(defun comp-test-unwind-protect (fun)
+ (setq comp-test-up-val nil)
+ (unwind-protect
+ (progn
+ (setq comp-test-up-val 23)
+ (funcall fun)
+ (setq comp-test-up-val 24))
+ (setq comp-test-up-val 999)))
+
+;; Non tested functions that proved just to be difficult to compile.
+
+(defun comp-test-callee (_ __) t)
+(defun comp-test-silly-frame1 (x)
+ ;; Check robustness against dead code.
+ (cl-case x
+ (0 (comp-test-callee
+ (pcase comp-tests-var1
+ (1 1)
+ (2 2))
+ 3))))
+
+(defun comp-test-silly-frame2 (token)
+ ;; Check robustness against dead code.
+ (while c
+ (cl-case c
+ (?< 1)
+ (?> 2))))
+
+(defun comp-test-big-interactive (filename &optional force arg load)
+ ;; Check non trivial interactive form using `byte-recompile-file'.
+ (interactive
+ (let ((file buffer-file-name)
+ (file-name nil)
+ (file-dir nil))
+ (and file
+ (derived-mode-p 'emacs-lisp-mode)
+ (setq file-name (file-name-nondirectory file)
+ file-dir (file-name-directory file)))
+ (list (read-file-name (if current-prefix-arg
+ "Byte compile file: "
+ "Byte recompile file: ")
+ file-dir file-name nil)
+ current-prefix-arg)))
+ (let ((dest (byte-compile-dest-file filename))
+ ;; Expand now so we get the current buffer's defaults
+ (filename (expand-file-name filename)))
+ (if (if (file-exists-p dest)
+ ;; File was already compiled
+ ;; Compile if forced to, or filename newer
+ (or force
+ (file-newer-than-file-p filename dest))
+ (and arg
+ (or (eq 0 arg)
+ (y-or-n-p (concat "Compile "
+ filename "? ")))))
+ (progn
+ (if (and noninteractive (not byte-compile-verbose))
+ (message "Compiling %s..." filename))
+ (byte-compile-file filename load))
+ (when load
+ (load (if (file-exists-p dest) dest filename)))
+ 'no-byte-compile)))
+
+(defun comp-test-no-return-1 (x)
+ (while x
+ (error "foo")))
+
+(defun comp-test-no-return-2 (x)
+ (cond
+ ((eql x '2) t)
+ ((error "bar") nil)))
+
+(defun comp-test-no-return-3 ())
+(defun comp-test-no-return-4 (x)
+ (when x
+ (error "foo")
+ (while (comp-test-no-return-3)
+ (comp-test-no-return-3))))
+
+(defun comp-test-=-nan (x)
+ (when (= x 0.0e+NaN)
+ x))
+
+(defun comp-test-=-infinity (x)
+ (when (= x 1.0e+INF)
+ x))
+
+(provide 'comp-test-funcs)
+
+;;; comp-test-funcs.el ends here
--- /dev/null
+;;; comp-test-pure.el --- compilation unit tested by comp-tests.el -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2020-2021 Free Software Foundation, Inc.
+
+;; Author: Andrea Corallo <akrl@sdf.org>
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs 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.
+
+;; GNU Emacs 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 GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+
+;;; Code:
+
+(defun comp-tests-pure-callee-f (x)
+ (1+ x))
+
+(defun comp-tests-pure-caller-f ()
+ (comp-tests-pure-callee-f 3))
+
+(defun comp-tests-pure-fibn-f (a b count)
+ (if (= count 0)
+ b
+ (comp-tests-pure-fibn-f (+ a b) a (- count 1))))
+
+(defun comp-tests-pure-fibn-entry-f ()
+ (comp-tests-pure-fibn-f 1 0 20))
+
+;;; comp-test-pure.el ends here
+++ /dev/null
-;;; -*- lexical-binding: t; -*-
-
-;; Reduced from ivy.el.
-
-(defvar comp-test-45603-last)
-(defvar comp-test-45603-mark-prefix)
-(defvar comp-test-45603-directory)
-(defvar comp-test-45603-marked-candidates)
-
-(defun comp-test-45603--call-marked (action)
- (let* ((prefix-len (length comp-test-45603-mark-prefix))
- (marked-candidates
- (mapcar
- (lambda (s)
- (let ((cand (substring s prefix-len)))
- (if comp-test-45603-directory
- (expand-file-name cand comp-test-45603-directory)
- cand)))
- comp-test-45603-marked-candidates))
- (multi-action (comp-test-45603--get-multi-action comp-test-45603-last)))))
-
-(defalias 'comp-test-45603--file-local-name
- (if (fboundp 'file-local-name)
- #'file-local-name
- (lambda (file)
- (or (file-remote-p file 'localname) file))))
-
-(provide 'comp-test-45603)
+++ /dev/null
-;;; comp-test-funcs-dyn.el --- compilation unit tested by comp-tests.el -*- lexical-binding: nil; -*-
-
-;; Copyright (C) 2020-2021 Free Software Foundation, Inc.
-
-;; Author: Andrea Corallo <akrl@sdf.org>
-
-;; This file is part of GNU Emacs.
-
-;; GNU Emacs 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.
-
-;; GNU Emacs 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 GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
-
-;;; Commentary:
-
-;;; Code:
-
-(require 'cl-lib)
-
-(defun comp-tests-ffuncall-callee-dyn-f (a b)
- (list a b))
-
-(defun comp-tests-ffuncall-callee-opt-dyn-f (a b &optional c d)
- (list a b c d))
-
-(defun comp-tests-ffuncall-callee-rest-dyn-f (a b &rest c)
- (list a b c))
-
-(defun comp-tests-ffuncall-callee-opt-rest-dyn-f (a b &optional c &rest d)
- (list a b c d))
-
-(defun comp-tests-cl-macro-exp-f ()
- (cl-loop for xxx in '(a b)
- for yyy = xxx
- collect xxx))
-
-(cl-defun comp-tests-cl-uninterned-arg-parse-f (a &optional b &aux)
- (list a b))
-
-(provide 'comp-test-dyn-funcs)
-
-;;; comp-test-funcs-dyn.el ends here
+++ /dev/null
-;;; comp-test-funcs.el --- compilation unit tested by comp-tests.el -*- lexical-binding: t; -*-
-
-;; Copyright (C) 2019-2021 Free Software Foundation, Inc.
-
-;; Author: Andrea Corallo <akrl@sdf.org>
-
-;; This file is part of GNU Emacs.
-
-;; GNU Emacs 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.
-
-;; GNU Emacs 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 GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
-
-;;; Commentary:
-
-;;; Code:
-
-(defvar comp-tests-var1 3)
-
-(defun comp-tests-varref-f ()
- comp-tests-var1)
-
-(defun comp-tests-list-f ()
- (list 1 2 3))
-(defun comp-tests-list2-f (a b c)
- (list a b c))
-(defun comp-tests-car-f (x)
- ;; Bcar
- (car x))
-(defun comp-tests-cdr-f (x)
- ;; Bcdr
- (cdr x))
-(defun comp-tests-car-safe-f (x)
- ;; Bcar_safe
- (car-safe x))
-(defun comp-tests-cdr-safe-f (x)
- ;; Bcdr_safe
- (cdr-safe x))
-
-(defun comp-tests-cons-car-f ()
- (car (cons 1 2)))
-(defun comp-tests-cons-cdr-f (x)
- (cdr (cons 'foo x)))
-
-(defun comp-tests-hint-fixnum-f (n)
- (1+ (comp-hint-fixnum n)))
-
-(defun comp-tests-hint-cons-f (c)
- (car (comp-hint-cons c)))
-
-(defun comp-tests-varset0-f ()
- (setq comp-tests-var1 55))
-(defun comp-tests-varset1-f ()
- (setq comp-tests-var1 66)
- 4)
-
-(defun comp-tests-length-f ()
- (length '(1 2 3)))
-
-(defun comp-tests-aref-aset-f ()
- (let ((vec (make-vector 3 0)))
- (aset vec 2 100)
- (aref vec 2)))
-
-(defvar comp-tests-var2 3)
-(defun comp-tests-symbol-value-f ()
- (symbol-value 'comp-tests-var2))
-
-(defun comp-tests-concat-f (x)
- (concat "a" "b" "c" "d"
- (concat "a" "b" "c" (concat "a" "b" (concat "foo" x)))))
-
-(defun comp-tests-ffuncall-callee-f (x y z)
- (list x y z))
-
-(defun comp-tests-ffuncall-callee-optional-f (a b &optional c d)
- (list a b c d))
-
-(defun comp-tests-ffuncall-callee-rest-f (a b &rest c)
- (list a b c))
-
-(defun comp-tests-ffuncall-callee-more8-f (p1 p2 p3 p4 p5 p6 p7 p8 p9 p10)
- ;; More then 8 args.
- (list p1 p2 p3 p4 p5 p6 p7 p8 p9 p10))
-
-(defun comp-tests-ffuncall-callee-more8-rest-f (p1 p2 p3 p4 p5 p6 p7 p8 p9 &rest p10)
- ;; More then 8 args.
- (list p1 p2 p3 p4 p5 p6 p7 p8 p9 p10))
-
-(defun comp-tests-ffuncall-native-f ()
- "Call a primitive with no dedicate op."
- (make-vector 1 nil))
-
-(defun comp-tests-ffuncall-native-rest-f ()
- "Call a primitive with no dedicate op with &rest."
- (vector 1 2 3))
-
-(defun comp-tests-ffuncall-apply-many-f (x)
- (apply #'list x))
-
-(defun comp-tests-ffuncall-lambda-f (x)
- (let ((fun (lambda (x)
- (1+ x))))
- (funcall fun x)))
-
-(defun comp-tests-jump-table-1-f (x)
- (pcase x
- ('x 'a)
- ('y 'b)
- (_ 'c)))
-
-(defun comp-tests-jump-table-2-f (x)
- (pcase x
- ("aaa" 'a)
- ("bbb" 'b)))
-
-(defun comp-tests-conditionals-1-f (x)
- ;; Generate goto-if-nil
- (if x 1 2))
-(defun comp-tests-conditionals-2-f (x)
- ;; Generate goto-if-nil-else-pop
- (when x
- 1340))
-
-(defun comp-tests-fixnum-1-minus-f (x)
- ;; Bsub1
- (1- x))
-(defun comp-tests-fixnum-1-plus-f (x)
- ;; Badd1
- (1+ x))
-(defun comp-tests-fixnum-minus-f (x)
- ;; Bnegate
- (- x))
-
-(defun comp-tests-eqlsign-f (x y)
- ;; Beqlsign
- (= x y))
-(defun comp-tests-gtr-f (x y)
- ;; Bgtr
- (> x y))
-(defun comp-tests-lss-f (x y)
- ;; Blss
- (< x y))
-(defun comp-tests-les-f (x y)
- ;; Bleq
- (<= x y))
-(defun comp-tests-geq-f (x y)
- ;; Bgeq
- (>= x y))
-
-(defun comp-tests-setcar-f (x y)
- (setcar x y)
- x)
-(defun comp-tests-setcdr-f (x y)
- (setcdr x y)
- x)
-
-(defun comp-bubble-sort-f (list)
- (let ((i (length list)))
- (while (> i 1)
- (let ((b list))
- (while (cdr b)
- (when (< (cadr b) (car b))
- (setcar b (prog1 (cadr b)
- (setcdr b (cons (car b) (cddr b))))))
- (setq b (cdr b))))
- (setq i (1- i)))
- list))
-
-(defun comp-tests-consp-f (x)
- ;; Bconsp
- (consp x))
-(defun comp-tests-setcar2-f (x)
- ;; Bsetcar
- (setcar x 3))
-
-(defun comp-tests-integerp-f (x)
- ;; Bintegerp
- (integerp x))
-(defun comp-tests-numberp-f (x)
- ;; Bnumberp
- (numberp x))
-
-(defun comp-tests-discardn-f (x)
- ;; BdiscardN
- (1+ (let ((a 1)
- (_b)
- (_c))
- a)))
-(defun comp-tests-insertn-f (a b c d)
- ;; Binsert
- (insert a b c d))
-
-(defun comp-tests-err-arith-f ()
- (/ 1 0))
-(defun comp-tests-err-foo-f ()
- (error "foo"))
-
-(defun comp-tests-condition-case-0-f ()
- ;; Bpushhandler Bpophandler
- (condition-case
- err
- (comp-tests-err-arith-f)
- (arith-error (concat "arith-error "
- (error-message-string err)
- " catched"))
- (error (concat "error "
- (error-message-string err)
- " catched"))))
-(defun comp-tests-condition-case-1-f ()
- ;; Bpushhandler Bpophandler
- (condition-case
- err
- (comp-tests-err-foo-f)
- (arith-error (concat "arith-error "
- (error-message-string err)
- " catched"))
- (error (concat "error "
- (error-message-string err)
- " catched"))))
-(defun comp-tests-catch-f (f)
- (catch 'foo
- (funcall f)))
-(defun comp-tests-throw-f (x)
- (throw 'foo x))
-
-(defun comp-tests-buff0-f ()
- (with-temp-buffer
- (insert "foo")
- (buffer-string)))
-
-(defun comp-tests-lambda-return-f ()
- (lambda (x) (1+ x)))
-
-(defun comp-tests-fib-f (n)
- (cond ((= n 0) 0)
- ((= n 1) 1)
- (t (+ (comp-tests-fib-f (- n 1))
- (comp-tests-fib-f (- n 2))))))
-
-(defmacro comp-tests-macro-m (x)
- x)
-
-(defun comp-tests-string-trim-f (url)
- (string-trim url))
-
-(defun comp-tests-trampoline-removal-f ()
- (make-hash-table))
-
-(defun comp-tests-signal-f ()
- (signal 'foo t))
-
-(defun comp-tests-func-call-removal-f ()
- (let ((a 10)
- (b 3))
- (% a b)))
-
-(defun comp-tests-doc-f ()
- "A nice docstring"
- t)
-
-(defun comp-test-interactive-form0-f (dir)
- (interactive "D")
- dir)
-
-(defun comp-test-interactive-form1-f (x y)
- (interactive '(1 2))
- (+ x y))
-
-(defun comp-test-interactive-form2-f ()
- (interactive))
-
-(defun comp-test-40187-2-f ()
- 'foo)
-
-(defalias 'comp-test-40187-1-f (symbol-function 'comp-test-40187-2-f))
-
-(defun comp-test-40187-2-f ()
- 'bar)
-
-(defun comp-test-speed--1-f ()
- (declare (speed -1))
- 3)
-
-(defun comp-test-42360-f (str end-column
- &optional start-column padding ellipsis
- ellipsis-text-property)
- ;; From `truncate-string-to-width'. A large enough function to
- ;; potentially use all registers and that is modifying local
- ;; variables inside condition-case.
- (let ((str-len (length str))
- (str-width 14)
- (ellipsis-width 3)
- (idx 0)
- (column 0)
- (head-padding "") (tail-padding "")
- ch last-column last-idx from-idx)
- (condition-case nil
- (while (< column start-column)
- (setq ch (aref str idx)
- column (+ column (char-width ch))
- idx (1+ idx)))
- (args-out-of-range (setq idx str-len)))
- (if (< column start-column)
- (if padding (make-string end-column padding) "")
- (when (and padding (> column start-column))
- (setq head-padding (make-string (- column start-column) padding)))
- (setq from-idx idx)
- (when (>= end-column column)
- (condition-case nil
- (while (< column end-column)
- (setq last-column column
- last-idx idx
- ch (aref str idx)
- column (+ column (char-width ch))
- idx (1+ idx)))
- (args-out-of-range (setq idx str-len)))
- (when (> column end-column)
- (setq column last-column
- idx last-idx))
- (when (and padding (< column end-column))
- (setq tail-padding (make-string (- end-column column) padding))))
- (if (and ellipsis-text-property
- (not (equal ellipsis ""))
- idx)
- (concat head-padding
- (substring str from-idx idx)
- (propertize (substring str idx) 'display (or ellipsis "")))
- (concat head-padding (substring str from-idx idx)
- tail-padding ellipsis)))))
-
-(defun comp-test-primitive-advice-f (x y)
- (declare (speed 2))
- (+ x y))
-
-(defun comp-test-primitive-redefine-f (x y)
- (declare (speed 2))
- (- x y))
-
-(defsubst comp-test-defsubst-f ()
- t)
-
-(defvar comp-test-and-3-var 1)
-(defun comp-test-and-3-f (x)
- (and (atom x)
- comp-test-and-3-var
- 2))
-
-(defun comp-test-copy-insn-f (insn)
- ;; From `comp-copy-insn'.
- (if (consp insn)
- (let (result)
- (while (consp insn)
- (let ((newcar (car insn)))
- (if (or (consp (car insn)) (comp-mvar-p (car insn)))
- (setf newcar (comp-copy-insn (car insn))))
- (push newcar result))
- (setf insn (cdr insn)))
- (nconc (nreverse result)
- (if (comp-mvar-p insn) (comp-copy-insn insn) insn)))
- (if (comp-mvar-p insn)
- (copy-comp-mvar insn)
- insn)))
-
-(defun comp-test-cond-rw-1-1-f ())
-
-(defun comp-test-cond-rw-1-2-f ()
- (let ((it (comp-test-cond-rw-1-1-f))
- (key 't))
- (if (or (equal it key)
- (eq key t))
- it
- nil)))
-
-(defun comp-test-44968-f (start end)
- (let ((dirlist)
- (dir (expand-file-name start))
- (end (expand-file-name end)))
- (while (not (or (equal dir (car dirlist))
- (file-equal-p dir end)))
- (push dir dirlist)
- (setq dir (directory-file-name (file-name-directory dir))))
- (nreverse dirlist)))
-
-(defun comp-test-45342-f (n)
- (pcase n
- (1 " ➊") (2 " ➋") (3 " ➌") (4 " ➍") (5 " ➎") (6 " ➏")
- (7 " ➐") (8 " ➑") (9 " ➒") (10 " ➓") (_ "")))
-
-(defun comp-test-assume-double-neg-f (collection value)
- ;; Reduced from `auth-source-search-collection'.
- (when (atom collection)
- (setq collection (list collection)))
- (or (eq value t)
- ;; value is (not (member t))
- (eq collection value)
- ;; collection is t, not (member t)!
- (member value collection)))
-
-(defun comp-test-assume-in-loop-1-f (arg)
- ;; Reduced from `comint-delim-arg'.
- (let ((args nil)
- (pos 0)
- (len (length arg)))
- (while (< pos len)
- (let ((start pos))
- (while (< pos len)
- (setq pos (1+ pos)))
- (setq args (cons (substring arg start pos) args))))
- args))
-
-(defun comp-test-45376-1-f ()
- ;; Reduced from `eshell-ls-find-column-lengths'.
- (let* (res
- (len 2)
- (i 0)
- (j 0))
- (while (< j len)
- (if (= i len)
- (setq i 0))
- (setq res (cons i res)
- j (1+ j)
- i (1+ i)))
- res))
-
-(defun comp-test-45376-2-f ()
- ;; Also reduced from `eshell-ls-find-column-lengths'.
- (let* ((x 1)
- res)
- (while x
- (let* ((y 4)
- (i 0))
- (while (> y 0)
- (when (= i x)
- (setq i 0))
- (setf res (cons i res))
- (setq y (1- y)
- i (1+ i)))
- (if (>= x 3)
- (setq x nil)
- (setq x (1+ x)))))
- res))
-
-(defun comp-test-not-cons-f (x)
- ;; Reduced from `cl-copy-list'.
- (if (consp x)
- (print x)
- (car x)))
-
-(defun comp-test-45576-f ()
- ;; Reduced from `eshell-find-alias-function'.
- (let ((sym (intern-soft "eval")))
- (if (and (functionp sym)
- '(eshell-ls eshell-pred eshell-prompt eshell-script
- eshell-term eshell-unix))
- sym)))
-
-(defun comp-test-45635-f (&rest args)
- ;; Reduced from `set-face-attribute'.
- (let ((spec args)
- family)
- (while spec
- (cond ((eq (car spec) :family)
- (setq family (cadr spec))))
- (setq spec (cddr spec)))
- (when (and (stringp family)
- (string-match "\\([^-]*\\)-\\([^-]*\\)" family))
- (setq family (match-string 2 family)))
- (when (or (stringp family)
- (eq family 'unspecified))
- family)))
-
-(defun comp-test-46670-1-f (_)
- "foo")
-
-(defun comp-test-46670-2-f (s)
- (and (equal (comp-test-46670-1-f (length s)) s)
- s))
-
-(cl-defun comp-test-46824-1-f ()
- (let ((next-repos '(1)))
- (while t
- (let ((recipe (car next-repos)))
- (cl-block loop
- (while t
- (let ((err
- (condition-case e
- (progn
- (setq next-repos
- (cdr next-repos))
- (cl-return-from loop))
- (error e))))
- (format "%S"
- (error-message-string err))))))
- (cl-return-from comp-test-46824-1-f))))
-
-(defun comp-test-47868-1-f ()
- " ")
-
-(defun comp-test-47868-2-f ()
- #(" " 0 1 (face font-lock-keyword-face)))
-
-(defun comp-test-47868-3-f ()
- " ")
-
-(defun comp-test-47868-4-f ()
- #(" " 0 1 (face font-lock-keyword-face)))
-
-
-\f
-;;;;;;;;;;;;;;;;;;;;
-;; Tromey's tests ;;
-;;;;;;;;;;;;;;;;;;;;
-
-;; Test Bconsp.
-(defun comp-test-consp (x) (consp x))
-
-;; Test Blistp.
-(defun comp-test-listp (x) (listp x))
-
-;; Test Bstringp.
-(defun comp-test-stringp (x) (stringp x))
-
-;; Test Bsymbolp.
-(defun comp-test-symbolp (x) (symbolp x))
-
-;; Test Bintegerp.
-(defun comp-test-integerp (x) (integerp x))
-
-;; Test Bnumberp.
-(defun comp-test-numberp (x) (numberp x))
-
-;; Test Badd1.
-(defun comp-test-add1 (x) (1+ x))
-
-;; Test Bsub1.
-(defun comp-test-sub1 (x) (1- x))
-
-;; Test Bneg.
-(defun comp-test-negate (x) (- x))
-
-;; Test Bnot.
-(defun comp-test-not (x) (not x))
-
-;; Test Bbobp, Beobp, Bpoint, Bpoint_min, Bpoint_max.
-(defun comp-test-bobp () (bobp))
-(defun comp-test-eobp () (eobp))
-(defun comp-test-point () (point))
-(defun comp-test-point-min () (point-min))
-(defun comp-test-point-max () (point-max))
-
-;; Test Bcar and Bcdr.
-(defun comp-test-car (x) (car x))
-(defun comp-test-cdr (x) (cdr x))
-
-;; Test Bcar_safe and Bcdr_safe.
-(defun comp-test-car-safe (x) (car-safe x))
-(defun comp-test-cdr-safe (x) (cdr-safe x))
-
-;; Test Beq.
-(defun comp-test-eq (x y) (eq x y))
-
-;; Test Bgotoifnil.
-(defun comp-test-if (x y) (if x x y))
-
-;; Test Bgotoifnilelsepop.
-(defun comp-test-and (x y) (and x y))
-
-;; Test Bgotoifnonnilelsepop.
-(defun comp-test-or (x y) (or x y))
-
-;; Test Bsave_excursion.
-(defun comp-test-save-excursion ()
- (save-excursion
- (insert "XYZ")))
-
-;; Test Bcurrent_buffer.
-(defun comp-test-current-buffer () (current-buffer))
-
-;; Test Bgtr.
-(defun comp-test-> (a b)
- (> a b))
-
-;; Test Bpushcatch.
-(defun comp-test-catch (&rest l)
- (catch 'done
- (dolist (v l)
- (when (> v 23)
- (throw 'done v)))))
-
-;; Test Bmemq.
-(defun comp-test-memq (val list)
- (memq val list))
-
-;; Test BlistN.
-(defun comp-test-listN (x)
- (list x x x x x x x x x x x x x x x x))
-
-;; Test BconcatN.
-(defun comp-test-concatN (x)
- (concat x x x x x x))
-
-;; Test optional and rest arguments.
-(defun comp-test-opt-rest (a &optional b &rest c)
- (list a b c))
-
-;; Test for too many arguments.
-(defun comp-test-opt (a &optional b)
- (cons a b))
-
-;; Test for unwind-protect.
-(defvar comp-test-up-val nil)
-(defun comp-test-unwind-protect (fun)
- (setq comp-test-up-val nil)
- (unwind-protect
- (progn
- (setq comp-test-up-val 23)
- (funcall fun)
- (setq comp-test-up-val 24))
- (setq comp-test-up-val 999)))
-
-;; Non tested functions that proved just to be difficult to compile.
-
-(defun comp-test-callee (_ __) t)
-(defun comp-test-silly-frame1 (x)
- ;; Check robustness against dead code.
- (cl-case x
- (0 (comp-test-callee
- (pcase comp-tests-var1
- (1 1)
- (2 2))
- 3))))
-
-(defun comp-test-silly-frame2 (token)
- ;; Check robustness against dead code.
- (while c
- (cl-case c
- (?< 1)
- (?> 2))))
-
-(defun comp-test-big-interactive (filename &optional force arg load)
- ;; Check non trivial interactive form using `byte-recompile-file'.
- (interactive
- (let ((file buffer-file-name)
- (file-name nil)
- (file-dir nil))
- (and file
- (derived-mode-p 'emacs-lisp-mode)
- (setq file-name (file-name-nondirectory file)
- file-dir (file-name-directory file)))
- (list (read-file-name (if current-prefix-arg
- "Byte compile file: "
- "Byte recompile file: ")
- file-dir file-name nil)
- current-prefix-arg)))
- (let ((dest (byte-compile-dest-file filename))
- ;; Expand now so we get the current buffer's defaults
- (filename (expand-file-name filename)))
- (if (if (file-exists-p dest)
- ;; File was already compiled
- ;; Compile if forced to, or filename newer
- (or force
- (file-newer-than-file-p filename dest))
- (and arg
- (or (eq 0 arg)
- (y-or-n-p (concat "Compile "
- filename "? ")))))
- (progn
- (if (and noninteractive (not byte-compile-verbose))
- (message "Compiling %s..." filename))
- (byte-compile-file filename load))
- (when load
- (load (if (file-exists-p dest) dest filename)))
- 'no-byte-compile)))
-
-(defun comp-test-no-return-1 (x)
- (while x
- (error "foo")))
-
-(defun comp-test-no-return-2 (x)
- (cond
- ((eql x '2) t)
- ((error "bar") nil)))
-
-(defun comp-test-no-return-3 ())
-(defun comp-test-no-return-4 (x)
- (when x
- (error "foo")
- (while (comp-test-no-return-3)
- (comp-test-no-return-3))))
-
-(defun comp-test-=-nan (x)
- (when (= x 0.0e+NaN)
- x))
-
-(defun comp-test-=-infinity (x)
- (when (= x 1.0e+INF)
- x))
-
-(provide 'comp-test-funcs)
-
-;;; comp-test-funcs.el ends here
+++ /dev/null
-;;; comp-test-pure.el --- compilation unit tested by comp-tests.el -*- lexical-binding: t; -*-
-
-;; Copyright (C) 2020-2021 Free Software Foundation, Inc.
-
-;; Author: Andrea Corallo <akrl@sdf.org>
-
-;; This file is part of GNU Emacs.
-
-;; GNU Emacs 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.
-
-;; GNU Emacs 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 GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
-
-;;; Commentary:
-
-;;; Code:
-
-(defun comp-tests-pure-callee-f (x)
- (1+ x))
-
-(defun comp-tests-pure-caller-f ()
- (comp-tests-pure-callee-f 3))
-
-(defun comp-tests-pure-fibn-f (a b count)
- (if (= count 0)
- b
- (comp-tests-pure-fibn-f (+ a b) a (- count 1))))
-
-(defun comp-tests-pure-fibn-entry-f ()
- (comp-tests-pure-fibn-f 1 0 20))
-
-;;; comp-test-pure.el ends here
;;; Code:
(require 'ert)
+(require 'ert-x)
(require 'cl-lib)
-(defconst comp-test-directory (concat (file-name-directory
- (or load-file-name
- buffer-file-name))
- "comp-tests-resources/"))
+(defconst comp-test-src (ert-resource-file "comp-test-funcs.el"))
-(defconst comp-test-src
- (expand-file-name "comp-test-funcs.el" comp-test-directory))
-
-(defconst comp-test-dyn-src
- (expand-file-name"comp-test-funcs-dyn.el" comp-test-directory))
+(defconst comp-test-dyn-src (ert-resource-file "comp-test-funcs-dyn.el"))
(when (featurep 'nativecomp)
(require 'comp)
:tags '(:expensive-test :nativecomp)
(let* ((byte-native-for-bootstrap t) ; FIXME HACK
(comp-src (expand-file-name "../../../lisp/emacs-lisp/comp.el"
- comp-test-directory))
+ (ert-resource-directory)))
(comp1-src (make-temp-file "stage1-" nil ".el"))
(comp2-src (make-temp-file "stage2-" nil ".el"))
;; Can't use debug symbols.
(comp-deftest 45603-1 ()
"<https://lists.gnu.org/archive/html/bug-gnu-emacs/2020-12/msg01994.html>"
- (load (native-compile (expand-file-name "comp-test-45603.el"
- comp-test-directory)))
+ (load (native-compile (ert-resource-file "comp-test-45603.el")))
(should (fboundp #'comp-test-45603--file-local-name)))
(comp-deftest 46670-1 ()
(let ((comp-speed 3)
(comp-post-pass-hooks '((comp-final comp-tests-pure-checker-1
comp-tests-pure-checker-2))))
- (load (native-compile (expand-file-name "comp-test-pure.el"
- comp-test-directory)))
+ (load (native-compile (ert-resource-file "comp-test-pure.el")))
(should (subr-native-elisp-p (symbol-function #'comp-tests-pure-caller-f)))
(should (= (comp-tests-pure-caller-f) 4))