File: dynamic-make-event-test.lisp

package info (click to toggle)
acl2 8.6%2Bdfsg-3
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 1,138,276 kB
  • sloc: lisp: 17,818,294; java: 125,359; python: 28,122; javascript: 23,458; cpp: 18,851; ansic: 11,569; perl: 7,678; xml: 5,591; sh: 3,978; makefile: 3,840; ruby: 2,633; yacc: 1,126; ml: 763; awk: 295; csh: 233; lex: 197; php: 178; 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))