• 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
          • Isodata
          • Simplify-defun
          • Tailrec
          • Schemalg
          • Restrict
          • Expdata
          • Casesplit
          • Simplify-term
          • Simplify-defun-sk
          • Parteval
          • Solve
          • Wrap-output
          • Propagate-iso
          • Simplify
          • Finite-difference
          • Drop-irrelevant-params
          • Copy-function
          • Lift-iso
          • Rename-params
          • Utilities
            • Defaults-table
              • Set-default-input-wrapper-to-old-name
              • Set-default-input-old-to-wrapper-name
              • Set-default-input-old-to-new-name
              • Set-default-input-new-to-old-name
              • Set-default-input-old-if-new-name
              • Set-default-input-wrapper-to-old-enable
              • Set-default-input-old-to-wrapper-enable
              • Set-default-input-old-to-new-enable
              • Set-default-input-new-to-old-enable
                • Set-default-input-wrapper-enable
                • Set-default-input-old-if-new-enable
                • Get-default-input-wrapper-to-old-name
                • Get-default-input-wrapper-to-old-enable
                • Get-default-input-old-to-wrapper-name
                • Get-default-input-old-to-wrapper-enable
                • Get-default-input-old-to-new-name
                • Get-default-input-old-to-new-enable
                • Get-default-input-old-if-new-name
                • Get-default-input-old-if-new-enable
                • Get-default-input-new-to-old-name
                • Get-default-input-new-to-old-enable
                • Get-default-input-wrapper-enable
                • *defaults-table-name*
              • Xdoc::apt-constructors
              • Input-processors
              • Transformation-table
              • Find-base-cases
              • Untranslate-specifier-utilities
              • Print-specifier-utilities
              • Hints-specifier-utilities
            • Simplify-term-programmatic
            • Simplify-defun-sk-programmatic
            • Simplify-defun-programmatic
            • Simplify-defun+
            • Common-options
            • Common-concepts
          • Error-checking
          • Fty-extensions
          • Isar
          • Kestrel-utilities
          • Set
          • C
          • 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
    • Defaults-table

    Set-default-input-new-to-old-enable

    Set the default :new-to-old-enable input of APT transformations.

    Some APT transformations include a :new-to-old-enable input that specifies whether to enable the generated theorem that rewrites (a term involving) a call of the old function to (a term involving) a call of the new function.

    This macro sets an entry in the APT defaults table that provides the default value of the :new-to-old-enable input. It must be a boolean. It cannot be t if the default :old-to-new-enable is currently t.

    The initial value of this default is nil.

    Macro: set-default-input-new-to-old-enable

    (defmacro set-default-input-new-to-old-enable (bool)
      (declare (xargs :guard (booleanp bool)))
      (b* ((ctx (cons 'set-default-input-new-to-old-enable
                      bool)))
        (cons 'make-event-terse
              (cons (cons 'set-default-input-new-to-old-enable-fn
                          (cons bool
                                (cons (cons 'quote (cons ctx 'nil))
                                      '(state))))
                    'nil))))

    Definitions and Theorems

    Function: set-default-input-new-to-old-enable-fn

    (defun set-default-input-new-to-old-enable-fn (bool ctx state)
     (declare (xargs :stobjs (state)))
     (declare (xargs :guard (booleanp bool)))
     (let ((__function__ 'set-default-input-new-to-old-enable-fn))
      (declare (ignorable __function__))
      (b* ((table (table-alist+ *defaults-table-name* (w state))
    )
           (pair (assoc-eq :old-to-new-enable table)))
       (if
        (and (consp pair) (cdr pair) bool)
        (er-soft+
         ctx t nil
         "Since the :OLD-TO-NEW-ENABLE default is T, ~
                         the :NEW-TO-OLD-ENABLE default cannot be set to T. ~
                         At most one of these two defaults may be T at any time.")
        (value (cons 'table
                     (cons *defaults-table-name*
                           (cons ':new-to-old-enable
                                 (cons bool 'nil)))))))))