This file is indexed.

/usr/share/acl2-7.2dfsg/books/tools/with-arith5-help.lisp is in acl2-books-source 7.2dfsg-3.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
; Copyright (C) 2009-2015, Regents of the University of Texas
; Written by Matt Kaufmann
; License: A 3-clause BSD license.  See the LICENSE file distributed with ACL2.

; Authorship note: The above copyright/license info was added by Matt Kaufmann
; on 9/2/2015, after noticing "MattKaufmann authored on Mar 27, 2009" at
; https://github.com/acl2/acl2/commits/master/books/tools/with-arith5-help.lisp.
; Clearly it has been modified since then to add rulesets info.

(in-package "ACL2")


;; This is included so that this book will be considered dependent on
;; arith5-theory, so that any books that include this will be considered
;; dependent on arith5-theory.

(include-book "rulesets")

(defun check-for-arith5-rulesets (world)
  (let ((ruleset-alist (table-alist 'ruleset-table world)))
    (and (consp (assoc 'arith5-enable-ruleset ruleset-alist))
         (consp (assoc 'arith5-disable-ruleset ruleset-alist)))))

(defun allow-arith5-help-fn (world)
  (if (check-for-arith5-rulesets world)
      '(value-triple :redundant-allow-arith5-help)
    '(local
      (progn

        (defun before-including-arithmetic-5 () nil)

        (table pre-arith5-theory-invariants nil
               (table-alist 'theory-invariant-table world)
               :clear)

        (include-book "arithmetic-5/top" :dir :system)


        (def-ruleset! arith5-enable-ruleset (set-difference-theories
                                             (current-theory :here)
                                             (current-theory
                                              'before-including-arithmetic-5)))

        (def-ruleset! arith5-disable-ruleset (set-difference-theories
                                              (current-theory 'before-including-arithmetic-5)
                                              (current-theory :here)))


        (table post-arith5-theory-invariants nil
               (table-alist 'theory-invariant-table world)
               :clear)

        (table theory-invariant-table nil
               (table-alist 'pre-arith5-theory-invariants world)
               :clear)

        (in-theory (current-theory 'before-including-arithmetic-5))))))

(defmacro allow-arith5-help ()
  '(make-event (allow-arith5-help-fn (w state))))



(defmacro my-enable-arith5 (ctx)
  `(if (check-for-arith5-rulesets world)
       (e/d* ((:ruleset arith5-enable-ruleset))
             ((:ruleset arith5-disable-ruleset)))
     (er hard ,ctx
         "~
Run (ALLOW-ARITH5-HELP) in the current local scope before using ~x0.~%" ,ctx)))


(defmacro with-arith5-help (&rest stuff)
  `(encapsulate
     nil
     (local (in-theory (my-enable-arith5 'with-arith5-help)))
     (local (table theory-invariant-table nil
                   (table-alist 'post-arith5-theory-invariants world)
                   :clear))
     . ,stuff))

(defmacro with-arith5-nonlinear-help (&rest stuff)
  `(encapsulate
     nil
     (local (in-theory (my-enable-arith5 'with-arith5-nonlinear-help)))
     (local (set-default-hints '((nonlinearp-default-hint
                                  stable-under-simplificationp
                                  hist pspv))))
     (local (table theory-invariant-table nil
                   (table-alist 'post-arith5-theory-invariants world)
                   :clear))
     . ,stuff))

(defmacro with-arith5-nonlinear++-help (&rest stuff)
  `(encapsulate
     nil
     (local (in-theory (my-enable-arith5 'with-arith5-nonlinear++-help)))
     (local (set-default-hints '((nonlinearp-default-hint++
                                  id stable-under-simplificationp
                                  hist nil))))
     (local (table theory-invariant-table nil
                   (table-alist 'post-arith5-theory-invariants world)
                   :clear))
     . ,stuff))


(defmacro enable-arith5 ()
  '(my-enable-arith5 'enable-arith5))

;; Notes:

;; This book allows the arithmetic-5 library to be included locally within a book
;; while only affecting (i.e. arithmetically helping and slowing down proofs of)
;; forms that are surrounded by (with-arith5-help  ...).  To allow this:

;; (include-book "tools/with-arith5-help" :dir :system)

;; ;; Locally includes arithmetic-5, reverts to the pre-arithmetic-5 theory,
;; and defines the with-arith5-help macro.
;; (allow-arith5-help)