File: dynamic-make-event-test.lisp

package info (click to toggle)
acl2 8.3dfsg-2
  • links: PTS
  • area: main
  • in suites: bullseye
  • size: 309,408 kB
  • sloc: lisp: 3,311,842; javascript: 22,569; cpp: 9,029; ansic: 7,872; perl: 6,501; xml: 3,838; java: 3,738; makefile: 3,383; ruby: 2,633; sh: 2,489; ml: 763; python: 741; yacc: 721; awk: 260; csh: 186; php: 171; lex: 154; tcl: 49; asm: 23; haskell: 17
file content (53 lines) | stat: -rw-r--r-- 1,287 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
(in-package "ACL2")

; Modification by Matt K. after v4-3: Removed :load-compiled-file :comp, which
; was part of all four include-book forms just below, in support of provisional
; certification.  Presumably the indicate books have already been compiled by
; now, anyhow.

(include-book "defcode" :ttags ((defcode)))
(include-book "rewrite-code")
(include-book "redefun")
(include-book "dynamic-make-event")

#|

dynamic-make-event-test.lisp
----------------------------

By Peter Dillinger, ca. 2009

This is a regression test for the dynamic-make-event book.

|#

(program)
(set-state-ok t)


(defttag dynamic-make-event-test) ; need to do some evil stuff

; Tweak defun so that if we try to defun THE-MAGIC-NAME, then it
; will instead expand to a definition of SOME-OTHER-NAME
(progn+touchable
 :all
 (redefun+rewrite
  defuns-fn
  (:carpat %body%
   :repl (if (eq (caar def-lst) 'the-magic-name)
           (dynamic-make-event-fn '(defun some-other-name (x) (1+ x))
				  event-form
				  state)
	   %body%)
   :vars (%body%))))

(defttag nil) ; end of evil stuff

; Now try it out ...

(defun the-magic-name (x) (1- x))
; should become (defun some-other-name (x) (1+ x))

; now we use some-other-name, to be sure it's now defined
(defun testing-function (x) (some-other-name x))