• 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
        • Bv
        • Imp-language
        • Event-macros
        • Java
        • Bitcoin
        • Ethereum
        • Yul
          • Transformations
          • Language
            • Abstract-syntax
            • Dynamic-semantics
            • Concrete-syntax
              • Lexer
              • Parser
              • Grammar-old
                • Ocst-statement-conc?
                • Ocst-expression-conc?
                • Ocst-list-list-conc-matchp$
                • Ocst-numberliteral-conc?
                • Ocst-list-list-alt-matchp$
                • Ocst-list-rep-matchp$
                • Ocst-list-elem-matchp$
                • Ocst-matchp$
                • Ocst-statement-conc3-rep-elem
                • Ocst-statement-conc2-rep-elem
                • Ocst-statement-conc10-rep-elem
                • Ocst-numberliteral-conc2-rep-elem
                • Ocst-numberliteral-conc2-rep
                • Ocst-numberliteral-conc1-rep-elem
                • Ocst-numberliteral-conc1-rep
                • Ocst-expression-conc3-rep-elem
                • Ocst-expression-conc2-rep-elem
                • Ocst-expression-conc1-rep-elem
                • Ocst-variabledeclaration-conc
                • Ocst-uppercaseletter-conc-rep-elem
                • Ocst-uppercaseletter-conc-rep
                • Ocst-typedidentifierlist-conc
                • Ocst-trueliteral-conc-rep-elem
                • Ocst-statement-conc9-rep-elem
                • Ocst-statement-conc9-rep
                • Ocst-statement-conc8-rep-elem
                • Ocst-statement-conc8-rep
                • Ocst-statement-conc7-rep-elem
                • Ocst-statement-conc7-rep
                • Ocst-statement-conc6-rep-elem
                • Ocst-statement-conc6-rep
                • Ocst-statement-conc5-rep-elem
                • Ocst-statement-conc5-rep
                • Ocst-statement-conc4-rep-elem
                • Ocst-statement-conc4-rep
                • Ocst-statement-conc3-rep
                • Ocst-statement-conc2-rep
                • Ocst-statement-conc10-rep
                • Ocst-statement-conc10
                • Ocst-statement-conc1-rep-elem
                • Ocst-statement-conc1-rep
                • Ocst-numberliteral-conc2
                • Ocst-numberliteral-conc1
                • Ocst-lowercaseletter-conc-rep-elem
                • Ocst-lowercaseletter-conc-rep
                • Ocst-functiondefinition-conc
                • Ocst-falseliteral-conc-rep-elem
                • Ocst-expression-conc3-rep
                • Ocst-expression-conc3
                • Ocst-expression-conc2-rep
                • Ocst-expression-conc2
                • Ocst-expression-conc1-rep
                • Ocst-expression-conc1
                • Ocst-decimaldigit-conc-rep-elem
                • Ocst-uppercaseletter-conc
                • Ocst-typename-conc-rep-elem
                • Ocst-trueliteral-conc-rep
                • Ocst-stringliteral-conc
                • Ocst-statement-conc9
                • Ocst-statement-conc8
                • Ocst-statement-conc7
                • Ocst-statement-conc6
                • Ocst-statement-conc5
                • Ocst-statement-conc4
                • Ocst-statement-conc3
                • Ocst-statement-conc2
                • Ocst-statement-conc1
                • Ocst-lowercaseletter-conc
                • Ocst-identifierlist-conc
                • Ocst-functioncall-conc
                • Ocst-falseliteral-conc-rep
                • Ocst-falseliteral-conc
                • Ocst-dquote-conc-rep-elem
                • Ocst-decimalnumber-conc
                • Ocst-decimaldigit-conc-rep
                • Ocst-decimaldigit-conc
                • Ocst-typename-conc-rep
                • Ocst-typename-conc
                • Ocst-trueliteral-conc
                • Ocst-switch-conc
                • Ocst-literal-conc
                • Ocst-leave-conc-rep-elem
                • Ocst-leave-conc-rep
                • Ocst-identifier-conc
                • Ocst-hexnumber-conc
                • Ocst-forloop-conc
                • Ocst-dquote-conc-rep
                • Ocst-default-conc
                • Ocst-assignment-conc
                • Ocst-any-conc-rep-elem
                • *grammar-old*
                  • *grammar-old*-tree-operations
                • Ocst-leave-conc
                • Ocst-if-conc
                • Ocst-dquote-conc
                • Ocst-case-conc
                • Ocst-block-conc
                • Ocst-any-conc-rep
                • Ocst-any-conc
                • Ocst-%x5d-10ffff-nat
                • Ocst-%x0-10ffff-nat
                • Ocst-%xe-21-nat
                • Ocst-%xb-c-nat
                • Ocst-%x61-7a-nat
                • Ocst-%x41-5a-nat
                • Ocst-%x30-39-nat
                • Ocst-%x23-5b-nat
                • Ocst-%x0-9-nat
              • Grammar
              • Tokenizer
            • Static-soundness
            • Static-semantics
            • Errors
          • Yul-json
        • 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
  • Grammar-old

*grammar-old*

The parsed old ABNF grammar of Yul.

We parse the grammar file to obtain an ABNF grammar value.

We prove that the grammar is well-formed, is closed, and only generates terminals in the Unicode character set.

Definitions and Theorems

Function: untranslate-preprocess-*grammar-old*

(defun untranslate-preprocess-*grammar-old* (acl2::term acl2::wrld)
  (if (equal acl2::term (list 'quote *grammar-old*))
      '*grammar-old*
    (abnf::untranslate-preprocess-*grammar* acl2::term acl2::wrld)))

Theorem: rulelist-wfp-of-*grammar-old*

(defthm rulelist-wfp-of-*grammar-old*
  (abnf::rulelist-wfp *grammar-old*))

Theorem: rulelist-closedp-of-*grammar-old*

(defthm rulelist-closedp-of-*grammar-old*
  (abnf::rulelist-closedp *grammar-old*))

Theorem: unicode-only-*grammar-old*

(defthm unicode-only-*grammar-old*
  (abnf::rulelist-in-termset-p *grammar-old*
                               (integers-from-to 0 1114111)))

Subtopics

*grammar-old*-tree-operations
Tree operations specialized to *grammar-old*.