• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
      • Apt
      • Zfc
      • Acre
      • Milawa
      • Smtlink
      • Abnf
        • Deftreeops
        • Defdefparse
          • Defdefparse-implementation
            • Defdefparse-event-generation
              • Defdefparse-gen-function-for-rulename
              • Defdefparse-gen-code-for-alternation
              • Defdefparse-gen-code-for-repetition
              • Defdefparse-gen-function-for-group
              • Defdefparse-function-spec
              • Defdefparse-gen-code-for-element
              • Defdefparse-gen-*-group-macro
              • Defdefparse-gen-function-for-option
              • Defdefparse-gen-option-macro
              • Defdefparse-gen-group-macro
              • Defdefparse-gen-function-for-repetition
              • Defdefparse-gen-code-for-concatenation
                • Defdefparse-gen-*-rulename-macro
                • Defdefparse-gen-rulename-macro
                • Defdefparse-gen-repetition-alist
                • Defdefparse-gen-option-alist
                • Defdefparse-gen-group-alist
                • Defdefparse-gen-everything
                • Defdefparse-gen-repetition-table-macro
                • Defdefparse-gen-option-table-macro
                • Defdefparse-gen-group-table-macro
                • Defdefparse-gen-function-for-spec
                • Defdefparse-gen-repetition-table
                • Defdefparse-gen-option-table
                • Defdefparse-gen-group-table
                • Defdefparse-reorder-alternation
                • Defdefparse-order-permutationp
                • Defdefparse-gen-repetition-table-name
                • Defdefparse-gen-option-table-name
                • Defdefparse-gen-group-table-name
                • Defdefparse-alt-symbol-alist
                • Defdefparse-rep-symbol-alist
              • Defdefparse-fn
              • Defdefparse-input-processing
              • Defdefparse-table
              • Defdefparse-macro-definition
          • Defgrammar
          • Tree-utilities
          • Notation
          • Grammar-parser
          • Meta-circular-validation
          • Parsing-primitives-defresult
          • Parsing-primitives-seq
          • Operations
          • Examples
          • Differences-with-paper
          • Constructor-utilities
          • Grammar-printer
          • Parsing-tools
        • Vwsim
        • Isar
        • Wp-gen
        • Dimacs-reader
        • Pfcs
        • Legacy-defrstobj
        • C
        • Proof-checker-array
        • Soft
        • Farray
        • Rp-rewriter
        • Instant-runoff-voting
        • Imp-language
        • Sidekick
        • Ethereum
        • Leftist-trees
        • Java
        • Riscv
        • Taspi
        • Bitcoin
        • Zcash
        • Des
        • X86isa
        • Sha-2
        • Yul
        • Proof-checker-itp13
        • Regex
        • ACL2-programming-language
        • Json
        • Jfkr
        • Equational
        • Cryptography
        • Axe
        • Poseidon
        • Where-do-i-place-my-book
        • Aleo
        • Bigmems
        • Builtins
        • Execloader
        • Solidity
        • Paco
        • Concurrent-programs
        • Bls12-377-curves
      • Debugging
      • Community
      • Std
      • Proof-automation
      • Macro-libraries
      • ACL2
      • Interfacing-tools
      • Hardware-verification
      • Software-verification
      • Math
      • Testing-utilities
    • Defdefparse-event-generation

    Defdefparse-gen-code-for-concatenation

    Generate code to parse an instance of an ABNF concatenation.

    Signature
    (defdefparse-gen-code-for-concatenation 
         conc prefix group-table 
         option-table repetition-table) 
     
      → 
    code
    Arguments
    conc — Guard (concatenationp conc).
    prefix — Guard (common-lisp::symbolp prefix).
    group-table — Guard (defdefparse-alt-symbol-alistp group-table).
    option-table — Guard (defdefparse-alt-symbol-alistp option-table).
    repetition-table — Guard (defdefparse-rep-symbol-alistp repetition-table).
    Returns
    code — Type (true-listp code).

    A concatenation is parsed by parsing each repetition in order. We also generate a final b* binder that puts all the lists of trees from the repetiitons into a list of lists of trees for the concatenation.

    Definitions and Theorems

    Function: defdefparse-gen-code-for-concatenation-aux

    (defun defdefparse-gen-code-for-concatenation-aux
           (conc index prefix group-table
                 option-table repetition-table)
     (declare
      (xargs
         :guard (and (concatenationp conc)
                     (natp index)
                     (common-lisp::symbolp prefix)
                     (defdefparse-alt-symbol-alistp group-table)
                     (defdefparse-alt-symbol-alistp option-table)
                     (defdefparse-rep-symbol-alistp repetition-table))))
     (let ((__function__ 'defdefparse-gen-code-for-concatenation-aux))
       (declare (ignorable __function__))
       (b* (((when (endp conc)) (mv nil nil))
            ((mv code1 var)
             (defdefparse-gen-code-for-repetition
                  (car conc)
                  index prefix group-table
                  option-table repetition-table))
            ((mv code2 vars)
             (defdefparse-gen-code-for-concatenation-aux
                  (cdr conc)
                  (1+ index)
                  prefix group-table
                  option-table repetition-table)))
         (mv (append code1 code2)
             (cons var vars)))))

    Theorem: true-listp-of-defdefparse-gen-code-for-concatenation-aux.code

    (defthm
          true-listp-of-defdefparse-gen-code-for-concatenation-aux.code
      (b* (((mv ?code ?vars)
            (defdefparse-gen-code-for-concatenation-aux
                 conc index prefix group-table
                 option-table repetition-table)))
        (true-listp code))
      :rule-classes :rewrite)

    Theorem: symbol-listp-of-defdefparse-gen-code-for-concatenation-aux.vars

    (defthm
        symbol-listp-of-defdefparse-gen-code-for-concatenation-aux.vars
      (b* (((mv ?code ?vars)
            (defdefparse-gen-code-for-concatenation-aux
                 conc index prefix group-table
                 option-table repetition-table)))
        (symbol-listp vars))
      :rule-classes :rewrite)

    Function: defdefparse-gen-code-for-concatenation

    (defun defdefparse-gen-code-for-concatenation
           (conc prefix group-table
                 option-table repetition-table)
     (declare
      (xargs
         :guard (and (concatenationp conc)
                     (common-lisp::symbolp prefix)
                     (defdefparse-alt-symbol-alistp group-table)
                     (defdefparse-alt-symbol-alistp option-table)
                     (defdefparse-rep-symbol-alistp repetition-table))))
     (let ((__function__ 'defdefparse-gen-code-for-concatenation))
       (declare (ignorable __function__))
       (b* (((when (endp conc))
             (raise "Empty concatenation."))
            ((mv code vars)
             (defdefparse-gen-code-for-concatenation-aux
                  conc 1 prefix group-table
                  option-table repetition-table)))
         (append code
                 (cons (cons 'treess
                             (cons (cons 'list vars) 'nil))
                       'nil)))))

    Theorem: true-listp-of-defdefparse-gen-code-for-concatenation

    (defthm true-listp-of-defdefparse-gen-code-for-concatenation
      (b* ((code (defdefparse-gen-code-for-concatenation
                      conc prefix group-table
                      option-table repetition-table)))
        (true-listp code))
      :rule-classes :rewrite)