File: progn-bang-enh.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 (63 lines) | stat: -rw-r--r-- 1,874 bytes parent folder | download | duplicates (10)
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
54
55
56
57
58
59
60
61
62
63
(in-package "ACL2")

#|

This is a hack to add some special features to PROGN!:

(progn! :compile-only ...)  expands to the given forms ONLY for the raw
lisp compiler and not the ACL2 loop.

(progn! :loop-only ...) expands to the given forms ONLY for the ACL2 loop
and not the raw lisp compiler.

This is currently the basis for implementing DEFCODE, and may not be
in the future.

|#

(defttag defcode)

(progn!
 (set-ld-redefinition-action '(:doit! . :overwrite) state)
 (defmacro progn! (&rest r)
   (declare (xargs :guard (or (not (symbolp (car r)))
                              (member-eq (car r)
                                         '(:state-global-bindings
                                           :compile-only
                                           :loop-only)))))
   (cond
    ((not (consp r))
     '(progn!-fn nil nil state))
    ((eq (car r) :compile-only)
     `(progn!-fn nil nil state))
    ((eq (car r) :state-global-bindings)
     `(state-global-let* ,(cadr r)
                         (progn!-fn ',(cddr r) ',(cadr r) state)))
    ((eq (car r) :loop-only)
     `(progn!-fn ',(cdr r) nil state))
    (t
     `(progn!-fn ',r nil state))))
 (set-ld-redefinition-action nil state)
 (set-raw-mode t)
 (progn
  (defmacro progn! (&rest r)
    (let ((sym (gensym)))
      `(let ((state *the-live-state*)
             (,sym (f-get-global 'acl2-raw-mode-p *the-live-state*)))
         (declare (ignorable state))
         ,@(cond ((not (consp r))
                  (list nil))
                 ((eq (car r) :loop-only)
                  (list nil))
                 ((eq (car r) :compile-only)
                  (cdr r))
                 ((eq (car r) :state-global-bindings)
                  (cddr r))
                 (t r))
         (f-put-global 'acl2-raw-mode-p ,sym state)
         (value nil))))
  nil)
 (set-raw-mode nil))

;(reset-prehistory t)