• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Community
    • Proof-automation
    • ACL2
    • Macro-libraries
      • B*
      • Defunc
      • Fty
      • Apt
      • Std/util
      • Defdata
      • Defrstobj
      • Seq
      • Match-tree
      • Defrstobj
      • With-supporters
      • Def-partial-measure
      • Template-subst
      • Soft
        • Soft-future-work
        • Soft-macros
          • Defun-inst
          • Defequal
            • Defequal-implementation
              • Defequal-fn
              • Defequal-event-generation
              • Defequal-input-processing
                • Defequal-process-inputs
                  • Defequal-process-left-and-right
                  • Defequal-process-vars
                  • Defequal-process-right-to-left-name
                  • Defequal-process-left-to-right-name
                  • Defequal-process-vars-aux
                  • Defequal-process-name
                • Defequal-table
                • Defequal-macro-definition
            • Defsoft
            • Defthm-inst
            • Defun2
            • Defunvar
            • Defun-sk2
            • Defchoose2
            • Defthm-2nd-order
            • Define-sk2
            • Defund-sk2
            • Define2
            • Defund2
          • Updates-to-workshop-material
          • Soft-implementation
          • Soft-notions
        • Defthm-domain
        • Event-macros
        • Def-universal-equiv
        • Def-saved-obligs
        • With-supporters-after
        • Definec
        • Sig
        • Outer-local
        • Data-structures
      • Interfacing-tools
      • Hardware-verification
      • Software-verification
      • Math
      • Testing-utilities
    • Defequal-input-processing

    Defequal-process-inputs

    Process all the inputs.

    Signature
    (defequal-process-inputs name left left-present right 
                             right-present vars enable verify-guards 
                             left-to-right-name left-to-right-enable 
                             right-to-left-name right-to-left-enable 
                             print show-only ctx state) 
     
      → 
    (mv erp result state)
    Arguments
    left-present — Guard (booleanp left-present).
    right-present — Guard (booleanp right-present).
    Returns
    result — A tuple (x1...xn left-to-right right-to-left updated-names-to-avoid) satisfying (typed-tuplep symbol-listp symbol-listp symbolp symbolp symbol-listp result).

    Definitions and Theorems

    Function: defequal-process-inputs

    (defun defequal-process-inputs
           (name left left-present right
                 right-present vars enable verify-guards
                 left-to-right-name left-to-right-enable
                 right-to-left-name right-to-left-enable
                 print show-only ctx state)
     (declare (xargs :stobjs (state)))
     (declare (xargs :guard (and (booleanp left-present)
                                 (booleanp right-present))))
     (let ((__function__ 'defequal-process-inputs))
      (declare (ignorable __function__))
      (b*
       ((names-to-avoid nil)
        ((er names-to-avoid)
         (defequal-process-name name names-to-avoid ctx state))
        ((er n)
         (defequal-process-left-and-right
              left left-present right
              right-present verify-guards ctx state))
        ((er x1...xn)
         (defequal-process-vars vars name left right n ctx state))
        ((er &)
         (ensure-value-is-boolean$ enable "The :ENABLE input" t nil))
        ((er &)
         (ensure-value-is-boolean$ verify-guards
                                   "The :VERIFY-GUARDS input" t nil))
        ((er (list left-to-right names-to-avoid))
         (defequal-process-left-to-right-name
              left-to-right-name name
              left right names-to-avoid ctx state))
        ((er &)
         (ensure-value-is-boolean$ left-to-right-enable
                                   "The :LEFT-TO-RIGHT-ENABLE input"
                                   t nil))
        ((er (list right-to-left names-to-avoid))
         (defequal-process-right-to-left-name
              right-to-left-name name
              left right names-to-avoid ctx state))
        ((er &)
         (ensure-value-is-boolean$ right-to-left-enable
                                   "The :RIGHT-TO-LEFT-ENABLE input"
                                   t nil))
        ((when (and left-to-right-enable
                    right-to-left-enable))
         (er-soft+
          ctx t nil
          "The :LEFT-TO-RIGHT-ENABLE and :RIGHT-TO-LEFT-ENABLE inputs ~
                       are both T; this is disallowed."))
        ((er &)
         (evmac-process-input-print print ctx state))
        ((er &)
         (evmac-process-input-show-only show-only ctx state)))
       (value (list x1...xn left-to-right
                    right-to-left names-to-avoid)))))