• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Proof-automation
    • Macro-libraries
    • ACL2
    • Interfacing-tools
    • Hardware-verification
    • Software-verification
      • Kestrel-books
        • Crypto-hdwallet
        • Apt
        • Error-checking
        • Fty-extensions
        • Isar
        • Kestrel-utilities
        • Set
        • 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
        • Bv
        • Imp-language
        • Event-macros
        • Java
        • Bitcoin
        • Ethereum
        • Yul
        • Zcash
        • ACL2-programming-language
        • Prime-fields
        • Json
        • Syntheto
        • File-io-light
        • Cryptography
        • Number-theory
        • Lists-light
        • Axe
        • Builtins
        • Solidity
        • Helpers
        • Htclient
        • Typed-lists-light
        • Arithmetic-light
      • X86isa
      • Axe
      • Execloader
    • 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