• 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-function-for-repetition

    Generate a parsing function for an ABNF repetition.

    Signature
    (defdefparse-gen-function-for-repetition 
         rep prefix group-table 
         option-table repetition-table) 
     
      → 
    event
    Arguments
    rep — Guard (repetitionp rep).
    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
    event — Type (acl2::maybe-pseudo-event-formp event).

    This is only used for repetitions whose repeat prefix is *, i.e. zero or more (i.e. this is all we support for now). The name is retrieved from the alist for repetition parsing functions. We generate a recursive function that repeatedly attempts to parse the underlying element. Note that we set the check-error-p flag to nil here, because we don't want the error to be returned, we just want to stop the recursion.

    Definitions and Theorems

    Function: defdefparse-gen-function-for-repetition

    (defun defdefparse-gen-function-for-repetition
           (rep prefix group-table
                option-table repetition-table)
     (declare
      (xargs
         :guard (and (repetitionp rep)
                     (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-function-for-repetition))
      (declare (ignorable __function__))
      (b* ((parse-repetition (cdr (assoc-equal rep repetition-table)))
           ((repetition rep) rep)
           ((unless (equal rep.range
                           (make-repeat-range :min 0
                                              :max (nati-infinity))))
            (raise "Repetition ~x0 currently not supported."
                   rep)))
       (cons
        'define
        (cons
         parse-repetition
         (cons
          '((input nat-listp))
          (cons
           ':returns
           (cons
            '(mv (trees tree-listp)
                 (rest-input nat-listp))
            (cons
             ':short
             (cons
              (str::cat "Parse a @('"
                        (pretty-print-repetition rep)
                        "').")
              (cons
               (cons
                'b*
                (cons
                 (append
                  (defdefparse-gen-code-for-element
                       rep.element
                       nil prefix group-table option-table)
                  (cons
                      '((when (reserrp tree)) (mv nil input))
                      (cons (cons '(mv trees input)
                                  (cons (cons parse-repetition '(input))
                                        'nil))
                            'nil)))
                 '((mv (cons tree trees) input))))
               (cons
                ':measure
                (cons
                 '(len input)
                 (cons
                  ':hints
                  (cons
                   '(("Goal" :in-theory (enable o< o-finp)))
                   (cons
                    ':hooks
                    (cons
                     '(:fix)
                     (cons
                      '///
                      (cons
                       (cons
                        'defret
                        (cons
                             (packn-pos (list 'len-of- parse-repetition)
                                        parse-repetition)
                             '((<= (len rest-input) (len input))
                               :rule-classes :linear
                               :hints (("Goal" :induct t)))))
                       'nil)))))))))))))))))))

    Theorem: maybe-pseudo-event-formp-of-defdefparse-gen-function-for-repetition

    (defthm
     maybe-pseudo-event-formp-of-defdefparse-gen-function-for-repetition
     (b* ((event (defdefparse-gen-function-for-repetition
                      rep prefix group-table
                      option-table repetition-table)))
       (acl2::maybe-pseudo-event-formp event))
     :rule-classes :rewrite)