• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Proof-automation
    • Macro-libraries
    • ACL2
    • Interfacing-tools
    • Hardware-verification
      • Gl
      • Esim
      • Vl2014
      • Sv
      • Fgl
        • Fgl-rewrite-rules
        • Fgl-function-mode
        • Fgl-object
        • Fgl-solving
        • Fgl-handling-if-then-elses
        • Fgl-getting-bits-from-objects
        • Fgl-primitive-and-meta-rules
        • Fgl-counterexamples
        • Fgl-interpreter-overview
        • Fgl-correctness-of-binding-free-variables
        • Fgl-debugging
        • Fgl-testbenches
        • Def-fgl-boolean-constraint
        • Fgl-stack
          • Scratchobj
            • Scratchobj-fix
            • Scratchobj-case
            • Scratchobj-equiv
            • Scratchobj-p
            • Scratchobj-formals
            • Scratchobj-fnsym
            • Scratchobj-fgl-objlist
            • Scratchobj-fgl-obj
            • Scratchobj-cinstlist
            • Scratchobj-cinst
            • Scratchobj-bfrlist
            • Scratchobj-kind
              • Scratchobj-bfr
            • Minor-frame
            • Major-frame
            • Major-stack
            • Scratchlist
            • Minor-stack
          • Fgl-rewrite-tracing
          • Def-fgl-param-thm
          • Def-fgl-thm
          • Fgl-fast-alist-support
          • Fgl-array-support
          • Advanced-equivalence-checking-with-fgl
          • Fgl-fty-support
          • Fgl-internals
        • Vwsim
        • Vl
        • X86isa
        • Svl
        • Rtl
      • Software-verification
      • Math
      • Testing-utilities
    • Scratchobj

    Scratchobj-kind

    Get the kind (tag) of a scratchobj structure.

    Signature
    (scratchobj-kind x) → kind
    Arguments
    x — Guard (scratchobj-p x).

    Definitions and Theorems

    Function: scratchobj-kind$inline

    (defun scratchobj-kind$inline (x)
      (declare (xargs :guard (scratchobj-p x)))
      (let ((__function__ 'scratchobj-kind))
        (declare (ignorable __function__))
        (mbe :logic (cond ((or (atom x) (eq (car x) :fgl-obj))
                           :fgl-obj)
                          ((eq (car x) :fgl-objlist) :fgl-objlist)
                          ((eq (car x) :bfr) :bfr)
                          ((eq (car x) :bfrlist) :bfrlist)
                          ((eq (car x) :cinst) :cinst)
                          ((eq (car x) :cinstlist) :cinstlist)
                          ((eq (car x) :fnsym) :fnsym)
                          (t :formals))
             :exec (car x))))

    Theorem: scratchobj-kind-possibilities

    (defthm scratchobj-kind-possibilities
      (or (equal (scratchobj-kind x) :fgl-obj)
          (equal (scratchobj-kind x) :fgl-objlist)
          (equal (scratchobj-kind x) :bfr)
          (equal (scratchobj-kind x) :bfrlist)
          (equal (scratchobj-kind x) :cinst)
          (equal (scratchobj-kind x) :cinstlist)
          (equal (scratchobj-kind x) :fnsym)
          (equal (scratchobj-kind x) :formals))
      :rule-classes
      ((:forward-chaining :trigger-terms ((scratchobj-kind x)))))