• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
      • Apt
      • Zfc
      • Acre
      • Milawa
      • Smtlink
      • Abnf
      • Vwsim
      • Isar
      • Wp-gen
      • Dimacs-reader
      • Pfcs
      • Legacy-defrstobj
      • Proof-checker-array
      • Soft
      • C
        • Syntax-for-tools
        • Atc
          • Atc-implementation
            • Atc-abstract-syntax
            • Atc-pretty-printer
              • Pprint-expressions
              • Pprint-expr
                • Pprint-expr-list
              • Expr-grade
              • Pprint-obj-declor
              • Expr-grade-<=
              • Binop-expected-grades
              • Pprint-obj-declon
              • Expr->grade
              • Pprint-tyspecseq
              • Pprint-tag-declon
              • Pprint-struct-declon-list
              • Pprint-fun-declor
              • Pprint-file
              • Pprint-stmt
              • Pprint-struct-declon
              • Pprint-obj-adeclor
              • Pprint-initer
              • Pprint-fun-declon
              • Pprint-indent
              • Pprint-hex-const
              • Pprint-fileset
              • Pprint-dec-const
              • Pprinted-lines-to-file
              • Pprint-tyname
              • Pprint-param-declon-list
              • Pprint-oct-const
              • Pprint-iconst-length
              • Pprint-iconst
              • Pprint-const
              • Expr-grade-index
              • Pprint-param-declon
              • Pprint-label
              • Pprint-ident-list
              • Pprint-binop
              • Pprint-fundef
              • Pprint-file-to-filesystem
              • Pprint-ext-declon-list
              • Pprint-unop
              • Pprint-line
              • Pprint-ident
              • Pprint-ext-declon
              • Pprint-comma-sep
              • Pprint-transunit
              • Pprint-one-line
              • Pprinted-lines-to-channel
              • Pprint-one-line-blank
              • Pprint-line-blank
            • Atc-event-and-code-generation
            • Fty-pseudo-term-utilities
            • Atc-term-recognizers
            • Atc-input-processing
            • Atc-shallow-embedding
            • Atc-process-inputs-and-gen-everything
            • Atc-table
            • Atc-fn
            • Atc-pretty-printing-options
            • Atc-types
            • Atc-macro-definition
          • Atc-tutorial
        • Language
        • Representation
        • Transformation-tools
        • Insertion-sort
        • Pack
      • Farray
      • Rp-rewriter
      • Instant-runoff-voting
      • Imp-language
      • Sidekick
      • Leftist-trees
      • Java
      • Taspi
      • Bitcoin
      • Riscv
      • Des
      • Ethereum
      • X86isa
      • Sha-2
      • Yul
      • Zcash
      • Proof-checker-itp13
      • Regex
      • ACL2-programming-language
      • Json
      • Jfkr
      • Equational
      • Cryptography
      • Poseidon
      • Where-do-i-place-my-book
      • Axe
      • Bigmems
      • Builtins
      • Execloader
      • Aleo
      • Solidity
      • Paco
      • Concurrent-programs
      • Bls12-377-curves
    • Debugging
    • Std
    • Proof-automation
    • Macro-libraries
    • ACL2
    • Interfacing-tools
    • Hardware-verification
    • Software-verification
    • Math
    • Testing-utilities
  • Atc-pretty-printer

Pprint-expr

Pretty-print an expression.

Signature
(pprint-expr expr expected-grade options) → part
Arguments
expr — Guard (exprp expr).
expected-grade — Guard (expr-gradep expected-grade).
options — Guard (pprint-options-p options).
Returns
part — Type (msgp part).

See pprint-expressions for background.

We first pretty-print the expression, and then we wrap it in parentheses if the expected grade is smaller than the actual grade.

When recursively pretty-printing subexpressions, the grade arguments passed for the subexpressions are determined by the relevant grammar rules.

The function to pretty-print lists of expressions takes a single grade argument, because we only need to pretty-print lists of expressions that all have the same required grade.

When printing unary expressions, we need to be careful about not printing two nested - expressions as -- or two nested + expressions ad ++, otherwise they are interpreted as predecrement or postincrement by the C compiler. Thus, we interpose a space when these two situations occur.

We treat the pretty-printing of conditional expressions slightly differently based on the pretty-printing option about parenthesizing nested conditional expressions. The difference is in the expected grades used for the `then' and `else' subexpressions. If that flag is not set, we print things with minimal parentheses, and therefore we use the top grade for `then' and the conditional grade for `else', consistently with the grammar rule for conditional expressions. This means that if the `then' and/or `else' is a conditional expression, it is not parenthesized. If instead the flag is set, then we use a lower grade for both `then' and `else', precisely the grade just one lower than conditional expressions, namely the grade of logical disjunction. This means that if the `then' and/or `else' is a conditional expression, it is parenthesized, in order to lower its grade.

Theorem: return-type-of-pprint-expr.part

(defthm return-type-of-pprint-expr.part
  (b* ((?part (pprint-expr expr expected-grade options)))
    (msgp part))
  :rule-classes :rewrite)

Theorem: return-type-of-pprint-expr-list.parts

(defthm return-type-of-pprint-expr-list.parts
  (b* ((?parts (pprint-expr-list exprs expected-grade options)))
    (msg-listp parts))
  :rule-classes :rewrite)

Theorem: pprint-expr-of-expr-fix-expr

(defthm pprint-expr-of-expr-fix-expr
  (equal (pprint-expr (expr-fix expr)
                      expected-grade options)
         (pprint-expr expr expected-grade options)))

Theorem: pprint-expr-of-expr-grade-fix-expected-grade

(defthm pprint-expr-of-expr-grade-fix-expected-grade
  (equal (pprint-expr expr (expr-grade-fix expected-grade)
                      options)
         (pprint-expr expr expected-grade options)))

Theorem: pprint-expr-of-pprint-options-fix-options

(defthm pprint-expr-of-pprint-options-fix-options
  (equal (pprint-expr expr expected-grade
                      (pprint-options-fix options))
         (pprint-expr expr expected-grade options)))

Theorem: pprint-expr-list-of-expr-list-fix-exprs

(defthm pprint-expr-list-of-expr-list-fix-exprs
  (equal (pprint-expr-list (expr-list-fix exprs)
                           expected-grade options)
         (pprint-expr-list exprs expected-grade options)))

Theorem: pprint-expr-list-of-expr-grade-fix-expected-grade

(defthm pprint-expr-list-of-expr-grade-fix-expected-grade
  (equal (pprint-expr-list exprs (expr-grade-fix expected-grade)
                           options)
         (pprint-expr-list exprs expected-grade options)))

Theorem: pprint-expr-list-of-pprint-options-fix-options

(defthm pprint-expr-list-of-pprint-options-fix-options
  (equal (pprint-expr-list exprs expected-grade
                           (pprint-options-fix options))
         (pprint-expr-list exprs expected-grade options)))

Theorem: pprint-expr-expr-equiv-congruence-on-expr

(defthm pprint-expr-expr-equiv-congruence-on-expr
  (implies (expr-equiv expr expr-equiv)
           (equal (pprint-expr expr expected-grade options)
                  (pprint-expr expr-equiv expected-grade options)))
  :rule-classes :congruence)

Theorem: pprint-expr-expr-grade-equiv-congruence-on-expected-grade

(defthm pprint-expr-expr-grade-equiv-congruence-on-expected-grade
  (implies (expr-grade-equiv expected-grade expected-grade-equiv)
           (equal (pprint-expr expr expected-grade options)
                  (pprint-expr expr expected-grade-equiv options)))
  :rule-classes :congruence)

Theorem: pprint-expr-pprint-options-equiv-congruence-on-options

(defthm pprint-expr-pprint-options-equiv-congruence-on-options
  (implies (pprint-options-equiv options options-equiv)
           (equal (pprint-expr expr expected-grade options)
                  (pprint-expr expr expected-grade options-equiv)))
  :rule-classes :congruence)

Theorem: pprint-expr-list-expr-list-equiv-congruence-on-exprs

(defthm pprint-expr-list-expr-list-equiv-congruence-on-exprs
 (implies
      (expr-list-equiv exprs exprs-equiv)
      (equal (pprint-expr-list exprs expected-grade options)
             (pprint-expr-list exprs-equiv expected-grade options)))
 :rule-classes :congruence)

Theorem: pprint-expr-list-expr-grade-equiv-congruence-on-expected-grade

(defthm
     pprint-expr-list-expr-grade-equiv-congruence-on-expected-grade
 (implies
      (expr-grade-equiv expected-grade expected-grade-equiv)
      (equal (pprint-expr-list exprs expected-grade options)
             (pprint-expr-list exprs expected-grade-equiv options)))
 :rule-classes :congruence)

Theorem: pprint-expr-list-pprint-options-equiv-congruence-on-options

(defthm pprint-expr-list-pprint-options-equiv-congruence-on-options
 (implies
      (pprint-options-equiv options options-equiv)
      (equal (pprint-expr-list exprs expected-grade options)
             (pprint-expr-list exprs expected-grade options-equiv)))
 :rule-classes :congruence)

Subtopics

Pprint-expr-list