mirror of
git://git.sv.gnu.org/emacs.git
synced 2025-12-06 06:20:55 -08:00
* test/lisp/emacs-lisp/bytecomp-tests.el (bytecomp-reify-function): * test/lisp/emacs-lisp/cl-extra-tests.el (cl-getf): * test/lisp/emacs-lisp/cl-macs-tests.el (cl-macs-loop-for-as-arith-order-side-effects) (cl-macs-loop-for-as-equals-then, cl-macs-loop-do, cl-macs-loop-finally) (cl-macs-loop-in-ref, cl-macs-loop-being-elements-of-ref) (cl-macs-test--symbol-macrolet, cl-the): * test/lisp/emacs-lisp/cl-seq-tests.el (cl-lib-test-remove) (cl-lib-test-remove-if-not): * test/lisp/emacs-lisp/edebug-resources/edebug-test-code.el (edebug-test-code-range): * test/lisp/emacs-lisp/edebug-tests.el (edebug-tests-deduplicate): * test/lisp/emacs-lisp/generator-tests.el (cps-while-incf): (cps-test-iter-cleanup-once-only): * test/lisp/emacs-lisp/hierarchy-tests.el (hierarchy-labelfn-button-if-does-not-button-unless-condition) (hierarchy-labelfn-button-if-does-button-when-condition): * test/lisp/emacs-lisp/let-alist-tests.el (let-alist-evaluate-once): * test/lisp/emacs-lisp/lisp-mode-tests.el (indent-sexp, lisp-indent-region): * test/lisp/emacs-lisp/map-tests.el (test-map-elt-gv) (test-setf-map-with-function): * test/lisp/emacs-lisp/multisession-tests.el (multi-test-sqlite-simple) (multi-test-sqlite-busy, multi-test-files-simple) (multi-test-files-busy): * test/lisp/emacs-lisp/oclosure-tests.el (oclosure-test, oclosure-test-mutate): * test/lisp/emacs-lisp/track-changes-tests.el (track-changes-tests--random): * test/lisp/files-tests.el (files-tests--with-buffer-offer-save): * test/lisp/net/shr-tests.el (shr-test/zoom-image): * test/lisp/replace-tests.el (replace-tests-with-undo): * test/src/buffer-tests.el (test-overlay-randomly): * test/src/data-tests.el (test-bool-vector-bv-from-hex-string): * test/src/fns-tests.el (fns-tests-sort): * test/src/json-tests.el (json-insert/signal, json-insert/throw): * test/src/minibuf-tests.el (minibuf-tests--strings-to-symbol-alist) (minibuf-tests--strings-to-string-alist) (minibuf-tests--strings-to-string-hashtable) (minibuf-tests--strings-to-symbol-hashtable): * test/src/process-tests.el (make-process/file-handler/found): Prefer incf to cl-incf.
157 lines
5 KiB
EmacsLisp
157 lines
5 KiB
EmacsLisp
;;; edebug-test-code.el --- Sample code for the Edebug test suite -*- lexical-binding:t -*-
|
|
|
|
;; Copyright (C) 2017-2025 Free Software Foundation, Inc.
|
|
|
|
;; Author: Gemini Lasswell
|
|
|
|
;; 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:
|
|
|
|
;; This file contains sample code used by edebug-tests.el.
|
|
;; Before evaluation, it will be preprocessed by
|
|
;; `edebug-tests-setup-code-file' which will remove all tags
|
|
;; between !'s and save their positions for use by the tests.
|
|
|
|
;;; Code:
|
|
|
|
(defun edebug-test-code-fac (n)
|
|
!start!(if !step!(< 0 n)
|
|
(* n (edebug-test-code-fac (1- n)))!mult!
|
|
1))
|
|
|
|
(defun edebug-test-code-concat (a b flag)
|
|
!start!(if flag!flag!
|
|
!then-start!(concat a!then-a! b!then-b!)!then-concat!
|
|
!else-start!(concat b!else-b! a!else-a!)!else-concat!)!if!)
|
|
|
|
(defun edebug-test-code-range (num)
|
|
!start!(let ((index 0)
|
|
(result nil))
|
|
(while !lt!(< index num)!test!
|
|
(push index result)!loop!
|
|
(incf index))!end-loop!
|
|
(nreverse result)))
|
|
|
|
(defun edebug-test-code-choices (input)
|
|
!start!(cond
|
|
((eq input 0) "zero")
|
|
((eq input 7) 42)
|
|
(t !edebug!(edebug))))
|
|
|
|
(defvar edebug-test-code-total nil)
|
|
|
|
(defun edebug-test-code-multiply (times value)
|
|
!start!(setq edebug-test-code-total 0)
|
|
(cl-dotimes (index times)
|
|
(setq edebug-test-code-total (+ edebug-test-code-total value))!setq!)
|
|
edebug-test-code-total)
|
|
|
|
(defun edebug-test-code-format-vector-node (node)
|
|
!start!(concat "["
|
|
(apply #'concat (mapcar #'edebug-test-code-format-node node))!apply!
|
|
"]"))
|
|
|
|
(defun edebug-test-code-format-list-node (node)
|
|
!start!(concat "{"
|
|
(apply #'concat (mapcar #'edebug-test-code-format-node node))!apply!
|
|
"}"))
|
|
|
|
(defun edebug-test-code-format-node (node)
|
|
!start!(cond
|
|
(!vectorp!(vectorp node!vnode!)!vtest! !vbefore!(edebug-test-code-format-vector-node node))
|
|
((listp node) (edebug-test-code-format-list-node node))
|
|
(t (format "%s" node))))
|
|
|
|
(defvar edebug-test-code-flavor "strawberry")
|
|
|
|
(defmacro edebug-test-code-with-flavor (new-flavor &rest body)
|
|
(declare (debug (form body))
|
|
(indent 1))
|
|
`(let ((edebug-test-code-flavor ,new-flavor))
|
|
,@body))
|
|
|
|
(defun edebug-test-code-try-flavors ()
|
|
(let* (tried)
|
|
(push edebug-test-code-flavor tried)
|
|
!macro!(edebug-test-code-with-flavor "chocolate"
|
|
(push edebug-test-code-flavor tried))
|
|
tried)!end!)
|
|
|
|
(unless (featurep 'edebug-tests-nutty)!nutty!
|
|
!setq!(setq edebug-test-code-flavor (car (edebug-test-code-try-flavors)))!end-setq!)!end-unless!
|
|
|
|
(cl-defgeneric edebug-test-code-emphasize (x))
|
|
(cl-defmethod edebug-test-code-emphasize ((x integer))
|
|
!start!(format "The number is not %s or %s, but %s!"
|
|
(1+ x) (1- x) x))
|
|
(cl-defmethod edebug-test-code-emphasize ((x string))
|
|
!start!(format "***%s***" x))
|
|
|
|
(defun edebug-test-code-use-methods ()
|
|
(list
|
|
!number!(edebug-test-code-emphasize 100)
|
|
!string!(edebug-test-code-emphasize "yes")))
|
|
|
|
(defun edebug-test-code-make-lambda (n)
|
|
(lambda (x) (+ x!x! n)))
|
|
|
|
(defun edebug-test-code-use-lambda ()
|
|
!start!(mapcar (edebug-test-code-make-lambda 10) '(1 2 3)))
|
|
|
|
(defun edebug-test-code-circular-read-syntax ()
|
|
'(#1=a . #1#))
|
|
|
|
(defun edebug-test-code-hash-read-syntax ()
|
|
!start!(list #("abcd" 1 3 (face italic))
|
|
#x01ff))
|
|
|
|
(defun edebug-test-code-empty-string-list ()
|
|
!start!(list "")!step!)
|
|
|
|
(defun edebug-test-code-current-buffer ()
|
|
!start!(with-current-buffer (get-buffer-create "*edebug-test-code-buffer*")
|
|
!body!(format "current-buffer: %s" (current-buffer))))
|
|
|
|
(defun edebug-test-code-use-destructuring-bind ()
|
|
(let ((two 2) (three 3))
|
|
(cl-destructuring-bind (x . y) (cons two three) (+ x!x! y!y!))))
|
|
|
|
(defun edebug-test-code-use-cl-macrolet (x)
|
|
(cl-macrolet ((wrap (func &rest args)
|
|
`(format "The result of applying %s to %s is %S"
|
|
',func!func! ',args
|
|
,(cons func args))))
|
|
(wrap + 1 x)))
|
|
|
|
(defun edebug-test-code-cl-flet1 ()
|
|
(cl-flet
|
|
;; This `&rest' sexp head should not collide with
|
|
;; the Edebug spec elem of the same name.
|
|
((f (&rest x) x)
|
|
(gate (x) (+ x 5)))
|
|
;; This call to `gate' shouldn't collide with the Edebug spec elem
|
|
;; of the same name.
|
|
(message "Hi %s" (gate 7))))
|
|
|
|
(defun edebug-test-code-use-gv-expander (x)
|
|
(declare (gv-expander
|
|
(lambda (do)
|
|
(funcall do `(car ,x) (lambda (v) `(setcar ,x ,v))))))
|
|
(car x))
|
|
|
|
(provide 'edebug-test-code)
|
|
;;; edebug-test-code.el ends here
|