• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Proof-automation
    • Macro-libraries
    • ACL2
    • Interfacing-tools
    • Hardware-verification
    • Software-verification
      • Kestrel-books
        • Crypto-hdwallet
        • Apt
        • Error-checking
        • Fty-extensions
          • Defbyte
          • Defresult
            • Reserr
            • Reserr-option
            • Patbind-ok
            • Reserrf-push
              • Defresult-macro-definition
              • Reserrf
              • Patbind-okf
            • Fold
            • Defsubtype
            • Defset
            • Specific-types
            • Defflatsum
            • Deflist-of-len
            • Pos-list
            • Defbytelist
            • Defomap
            • Defbyte-standard-instances
            • Deffixtype-alias
            • Defbytelist-standard-instances
            • Defunit
            • Byte-list
            • Byte
            • Database
            • Pos-option
            • Nibble
            • Nat-option
            • String-option
            • Byte-list20
            • Byte-list32
            • Byte-list64
            • Pseudo-event-form
            • Natoption/natoptionlist
            • Nati
            • Character-list
            • Nat/natlist
            • Maybe-string
            • Nibble-list
            • Natoption/natoptionlist-result
            • Nat/natlist-result
            • Nat-option-list-result
            • Set
            • String-result
            • String-list-result
            • Nat-result
            • Nat-option-result
            • Nat-list-result
            • Maybe-string-result
            • Integer-result
            • Character-result
            • Character-list-result
            • Boolean-result
            • Map
            • Bag
            • Pos-set
            • Hex-digit-char-list
            • Dec-digit-char-list
            • Pseudo-event-form-list
            • Nat-option-list
            • Symbol-set
            • String-set
            • Nat-set
            • Oct-digit-char-list
            • Bin-digit-char-list
            • Bit-list
          • Isar
          • Kestrel-utilities
          • Set
          • Soft
          • C
          • Bv
          • Imp-language
          • Event-macros
          • Java
          • Bitcoin
          • Ethereum
          • Yul
          • Zcash
          • ACL2-programming-language
          • Prime-fields
          • Json
          • Syntheto
          • File-io-light
          • Cryptography
          • Number-theory
          • Lists-light
          • Axe
          • Builtins
          • Solidity
          • Helpers
          • Htclient
          • Typed-lists-light
          • Arithmetic-light
        • X86isa
        • Axe
        • Execloader
      • Math
      • Testing-utilities
    • Defresult

    Reserrf-push

    Push the current function onto the stack of an error result, optionally with additional information.

    This is useful when receiving an error result from a called function, to add the caller to the stack, and possibly more information, before propagating the error. This addition is handled automatically when using patbind-okf, actually using nil as extra information; when that binder cannot be used for some reason, or when additional information must be pushed, then this reserrf-push macro may come handy.

    This assumes that __function__ is bound to the current function name, which is automatically the case when using define.

    Macro: reserrf-push

    (defmacro reserrf-push (error &optional info)
     (cons
      'b*
      (cons
       (cons (cons 'stack
                   (cons (cons 'reserr->info (cons error 'nil))
                         'nil))
             'nil)
       (cons
        (cons
          'reserr
          (cons (cons 'cons
                      (cons (cons 'list
                                  (cons '__function__ (cons info 'nil)))
                            '(stack)))
                'nil))
        'nil))))