• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Community
    • 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
        • C
          • Syntax-for-tools
          • Atc
          • Transformation-tools
            • Simpadd0
            • Proof-generation
            • Split-gso
            • Wrap-fn
              • Wrap-fn-implementation
                • Init-declor-list-wrap-fn-add-wrapper-def
                • Declor-wrap-fn-add-wrapper-def
                • Ext-declon-wrap-fn-add-wrapper-def
                • Fundef-wrap-fn-add-wrapper-def
                • Declon-wrap-fn-add-wrapper-def
                • Ext-declon-list-wrap-fn
                • Wrap-fn-process-param-declon-list-loop
                • Filepath-transunit-map-wrap-fn
                • Wrap-fn-process-param-declon-list
                • Transunit-wrap-fn
                • Transunit-ensemble-wrap-fn
                  • Code-ensemble-wrap-fn
                  • Code-ensemble-wrap-fn-multiple
                  • Declor-wrap-fn-make-wrapper
                  • Dirdeclor-wrap-fn-make-wrapper
                  • Wrap-fn-input-processing
                  • Wrap-fn-event-generation
              • Constant-propagation
              • Specialize
              • Split-fn
              • Split-fn-when
              • Split-all-gso
              • Copy-fn
              • Variables-in-computation-states
              • Rename
              • Utilities
              • Proof-generation-theorems
              • Input-processing
            • Language
            • Representation
            • Insertion-sort
            • Pack
          • Soft
          • Bv
          • Imp-language
          • Ethereum
          • Event-macros
          • Java
          • Riscv
          • Bitcoin
          • Zcash
          • Yul
          • ACL2-programming-language
          • Prime-fields
          • Json
          • Syntheto
          • File-io-light
          • Cryptography
          • Number-theory
          • Axe
          • Lists-light
          • Builtins
          • Solidity
          • Helpers
          • Htclient
          • Typed-lists-light
          • Arithmetic-light
        • X86isa
        • Axe
        • Execloader
      • Math
      • Testing-utilities
    • Wrap-fn-implementation

    Transunit-ensemble-wrap-fn

    Transform a translation unit ensemble.

    Signature
    (transunit-ensemble-wrap-fn transunits target-name wrapper-name?) 
      → 
    (mv er? transunits$)
    Arguments
    transunits — Guard (transunit-ensemblep transunits).
    target-name — Guard (identp target-name).
    wrapper-name? — Guard (ident-optionp wrapper-name?).
    Returns
    er? — Type (maybe-msgp er?).
    transunits$ — Type (transunit-ensemblep transunits$).

    Definitions and Theorems

    Function: transunit-ensemble-wrap-fn

    (defun transunit-ensemble-wrap-fn
           (transunits target-name wrapper-name?)
     (declare (xargs :guard (and (transunit-ensemblep transunits)
                                 (identp target-name)
                                 (ident-optionp wrapper-name?))))
     (declare (xargs :guard (transunit-ensemble-annop transunits)))
     (b* (((reterr)
           (c$::transunit-ensemble-fix transunits))
          ((transunit-ensemble transunits)
           transunits)
          (blacklist
               (filepath-transunit-map-collect-idents transunits.units))
          ((erp any-foundp map)
           (filepath-transunit-map-wrap-fn
                transunits.units
                target-name wrapper-name? blacklist))
          (- (if any-foundp nil
               (cw "Warning: No declaration found for ~x0.~%"
                   (ident->unwrap target-name)))))
       (retok (c$::change-transunit-ensemble transunits
                                             :units map))))

    Theorem: maybe-msgp-of-transunit-ensemble-wrap-fn.er?

    (defthm maybe-msgp-of-transunit-ensemble-wrap-fn.er?
      (b* (((mv ?er? ?transunits$)
            (transunit-ensemble-wrap-fn
                 transunits target-name wrapper-name?)))
        (maybe-msgp er?))
      :rule-classes :rewrite)

    Theorem: transunit-ensemblep-of-transunit-ensemble-wrap-fn.transunits$

    (defthm
          transunit-ensemblep-of-transunit-ensemble-wrap-fn.transunits$
      (b* (((mv ?er? ?transunits$)
            (transunit-ensemble-wrap-fn
                 transunits target-name wrapper-name?)))
        (transunit-ensemblep transunits$))
      :rule-classes :rewrite)

    Theorem: transunit-ensemble-wrap-fn-of-transunit-ensemble-fix-transunits

    (defthm
        transunit-ensemble-wrap-fn-of-transunit-ensemble-fix-transunits
      (equal (transunit-ensemble-wrap-fn
                  (c$::transunit-ensemble-fix transunits)
                  target-name wrapper-name?)
             (transunit-ensemble-wrap-fn
                  transunits target-name wrapper-name?)))

    Theorem: transunit-ensemble-wrap-fn-transunit-ensemble-equiv-congruence-on-transunits

    (defthm
     transunit-ensemble-wrap-fn-transunit-ensemble-equiv-congruence-on-transunits
     (implies
      (c$::transunit-ensemble-equiv transunits transunits-equiv)
      (equal
       (transunit-ensemble-wrap-fn transunits target-name wrapper-name?)
       (transunit-ensemble-wrap-fn transunits-equiv
                                   target-name wrapper-name?)))
     :rule-classes :congruence)

    Theorem: transunit-ensemble-wrap-fn-of-ident-fix-target-name

    (defthm transunit-ensemble-wrap-fn-of-ident-fix-target-name
     (equal
          (transunit-ensemble-wrap-fn transunits (ident-fix target-name)
                                      wrapper-name?)
          (transunit-ensemble-wrap-fn
               transunits target-name wrapper-name?)))

    Theorem: transunit-ensemble-wrap-fn-ident-equiv-congruence-on-target-name

    (defthm
       transunit-ensemble-wrap-fn-ident-equiv-congruence-on-target-name
     (implies
      (c$::ident-equiv target-name target-name-equiv)
      (equal
       (transunit-ensemble-wrap-fn transunits target-name wrapper-name?)
       (transunit-ensemble-wrap-fn transunits
                                   target-name-equiv wrapper-name?)))
     :rule-classes :congruence)

    Theorem: transunit-ensemble-wrap-fn-of-ident-option-fix-wrapper-name?

    (defthm transunit-ensemble-wrap-fn-of-ident-option-fix-wrapper-name?
      (equal
           (transunit-ensemble-wrap-fn transunits target-name
                                       (ident-option-fix wrapper-name?))
           (transunit-ensemble-wrap-fn
                transunits target-name wrapper-name?)))

    Theorem: transunit-ensemble-wrap-fn-ident-option-equiv-congruence-on-wrapper-name?

    (defthm
     transunit-ensemble-wrap-fn-ident-option-equiv-congruence-on-wrapper-name?
     (implies
      (c$::ident-option-equiv wrapper-name? wrapper-name?-equiv)
      (equal
       (transunit-ensemble-wrap-fn transunits target-name wrapper-name?)
       (transunit-ensemble-wrap-fn transunits
                                   target-name wrapper-name?-equiv)))
     :rule-classes :congruence)