/usr/share/acl2-8.0dfsg/books/tools/plev.lisp is in acl2-books-source 8.0dfsg-1.
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 | (in-package "ACL2")
(include-book "xdoc/top" :dir :system)
(set-state-ok t)
(defxdoc plev
:parents (print-control)
:short "Easy-to-use functions for controlling the printer."
:long "<p>Example:</p>
@({
(include-book \"tools/plev\" :dir :system)
(plev) ;; moderate abbreviations, a good default
(plev-max) ;; don't abbreviate anything, show everything
(plev-min) ;; heavily abbreviate things, usually too terse
(plev-mid) ;; somewhat similar to plev
})
<p>Each of these is actually a macro with keyword arguments like @(':length'),
@(':level'), @(':lines'), @(':circle'), @(':pretty'), and @(':readably'). You
can choose your own values for these arguments, or just use the above macros.</p>
<p>Note for Clozure Common Lisp users: you may wish to instead include</p>
@({
(include-book \"tools/plev-ccl\" :dir :system :ttags :all)
})
<p>for a version of plev that also updates the print levels used during
backtraces and error messages. CCL users can also use:</p>
@({
(plev-info)
})
<p>to see the current values of certain print-related variables.</p>")
(defpointer plev-max plev)
(defpointer plev-min plev)
(defpointer plev-mid plev)
(defpointer plev-info plev)
(defn plev-fn (length level lines circle pretty readably state)
(declare (xargs :mode :program))
(let* ((old-tuple (abbrev-evisc-tuple state))
(new-tuple (list (car old-tuple) level length
(cadddr old-tuple))))
(mv-let (flg val state)
(set-evisc-tuple new-tuple
:iprint t
:sites :all)
(declare (ignore val))
(mv flg
(list :length length
:level level
:lines lines
:circle circle
:readably readably
:pretty pretty)
state))))
(defmacro plev (&key (length '16)
(level '3)
(lines 'nil)
(circle 't)
(pretty 't)
(readably 'nil))
`(plev-fn ,length ,level ,lines ,circle ,pretty ,readably state))
(defmacro plev-max (&key (length 'nil)
(level 'nil)
(lines 'nil)
(circle 'nil)
(pretty 't)
(readably 'nil))
`(plev-fn ,length ,level ,lines ,circle ,pretty ,readably state))
(defmacro plev-mid (&key (length '10)
(level '5)
(lines '200)
(circle 't)
(pretty 't)
(readably 'nil))
`(plev-fn ,length ,level ,lines ,circle ,pretty ,readably state))
(defmacro plev-min (&key (length '3)
(level '3)
(lines '60)
(circle 't)
(pretty 'nil)
(readably 'nil))
`(plev-fn ,length ,level ,lines ,circle ,pretty ,readably state))
|