• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Community
    • Proof-automation
    • Macro-libraries
      • B*
      • Defunc
      • Fty
      • Apt
      • Std/util
      • Defdata
      • Defrstobj
      • Seq
      • Match-tree
      • Defrstobj
      • With-supporters
      • Def-partial-measure
      • Template-subst
      • Soft
      • Defthm-domain
      • Event-macros
        • Evmac-input-hints-p
        • Evmac-input-print-p
        • Function-definedness
        • Event-macro-input-processing
        • Event-macro-screen-printing
        • Make-event-terse
        • Event-macro-applicability-conditions
        • Event-macro-results
        • Template-generators
        • Event-macro-event-generators
          • Evmac-generate-defun
          • Evmac-generate-soft-defun-sk2
            • Evmac-generate-soft-defun2
            • Evmac-generate-defthm
            • Evmac-generate-soft-defunvar
          • Event-macro-proof-preparation
          • Try-event
          • Restore-output?
          • Restore-output
          • Fail-event
          • Cw-event
          • Event-macro-xdoc-constructors
          • Event-macro-intro-macros
        • Def-universal-equiv
        • Def-saved-obligs
        • With-supporters-after
        • Definec
        • Sig
        • Outer-local
        • Data-structures
      • ACL2
      • Interfacing-tools
      • Hardware-verification
      • Software-verification
      • Math
      • Testing-utilities
    • Event-macro-event-generators

    Evmac-generate-soft-defun-sk2

    Generate a SOFT defun-sk2 or defund-sk2 function definition with the specified attributes.

    Signature
    (evmac-generate-soft-defun-sk2 name &key (formals ':absent) 
                                   (guard 't) 
                                   (body ':absent) 
                                   (verify-guards ':absent) 
                                   (enable ':absent) 
                                   (guard-hints 'nil) 
                                   (rewrite ':default)) 
     
      → 
    (mv loc-event event)
    Arguments
    name — Guard (symbolp name).
    formals — Guard (symbol-listp formals).
    guard — A term.
    body — A term.
    verify-guards — Guard (booleanp verify-guards).
    enable — Guard (booleanp enable).
    guard-hints — Guard (true-listp guard-hints).
    rewrite — A term or :direct or :default.
    Returns
    loc-event — Type (pseudo-event-formp loc-event).
    event — Type (pseudo-event-formp event).

    Definitions and Theorems

    Function: evmac-generate-soft-defun-sk2-fn

    (defun evmac-generate-soft-defun-sk2-fn
           (name formals guard body verify-guards
                 enable guard-hints rewrite)
     (declare (xargs :guard (and (symbolp name)
                                 (symbol-listp formals)
                                 (booleanp verify-guards)
                                 (booleanp enable)
                                 (true-listp guard-hints))))
     (let ((__function__ 'evmac-generate-soft-defun-sk2))
      (declare (ignorable __function__))
      (b*
       (((when (eq formals :absent))
         (raise "Internal error: :FORMALS not supplied.")
         (mv '(irrelevant) '(irrelevant)))
        ((when (eq body :absent))
         (raise "Internal error: :BODY not supplied.")
         (mv '(irrelevant) '(irrelevant)))
        ((when (eq verify-guards :absent))
         (raise "Internal error: :VERIFY-GUARDS not supplied.")
         (mv '(irrelevant) '(irrelevant)))
        ((when (eq enable :absent))
         (raise "Internal error: :ENABLE not supplied.")
         (mv '(irrelevant) '(irrelevant)))
        (macro (if enable 'soft::defun-sk2
                 'soft::defund-sk2))
        (guard-decl (list :guard guard))
        (verify-guards-decl (list :verify-guards verify-guards))
        (guard-hints-decl (and guard-hints
                               (list :guard-hints guard-hints)))
        (loc-event
         (cons
          'local
          (cons
           (cons
            macro
            (cons
             name
             (cons
              formals
              (cons
               (cons
                'declare
                (cons
                 (cons
                  'xargs
                  (append guard-decl
                          (append verify-guards-decl guard-hints-decl)))
                 'nil))
               (cons body
                     (cons ':rewrite
                           (cons rewrite 'nil)))))))
           'nil)))
        (event
         (cons
          macro
          (cons
           name
           (cons
            formals
            (cons
               (cons 'declare
                     (cons (cons 'xargs
                                 (append guard-decl verify-guards-decl))
                           'nil))
               (cons body
                     (cons ':rewrite
                           (cons rewrite 'nil)))))))))
       (mv loc-event event))))

    Theorem: pseudo-event-formp-of-evmac-generate-soft-defun-sk2.loc-event

    (defthm
          pseudo-event-formp-of-evmac-generate-soft-defun-sk2.loc-event
      (b* (((mv ?loc-event ?event)
            (evmac-generate-soft-defun-sk2-fn
                 name formals guard body verify-guards
                 enable guard-hints rewrite)))
        (pseudo-event-formp loc-event))
      :rule-classes :rewrite)

    Theorem: pseudo-event-formp-of-evmac-generate-soft-defun-sk2.event

    (defthm pseudo-event-formp-of-evmac-generate-soft-defun-sk2.event
      (b* (((mv ?loc-event ?event)
            (evmac-generate-soft-defun-sk2-fn
                 name formals guard body verify-guards
                 enable guard-hints rewrite)))
        (pseudo-event-formp event))
      :rule-classes :rewrite)