• 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
        • Soft
        • C
          • Syntax-for-tools
          • Atc
          • Language
            • Abstract-syntax
              • Tyspecseq
              • Expr
                • Exprp
                • Expr-case
                  • Expr-binary
                  • Expr-equiv
                  • Expr-cond
                  • Expr-unary
                  • Expr-memberp
                  • Expr-member
                  • Expr-cast
                  • Expr-call
                  • Expr-arrsub
                  • Expr-kind
                  • Expr-preinc
                  • Expr-predec
                  • Expr-postinc
                  • Expr-postdec
                  • Expr-ident
                  • Expr-const
                  • Expr-fix
                  • Expr-count
                • Binop
                • Fileset
                • Obj-declor
                • Ident
                • Iconst
                • Obj-adeclor
                • Abstract-syntax-operations
                • Const
                • Fundef
                • Unop
                • File
                • Tag-declon
                • Fun-declor
                • Obj-declon
                • Iconst-length
                • Label
                • Struct-declon
                • Initer
                • Ext-declon
                • Fun-adeclor
                • Expr-option
                • Iconst-base
                • Initer-option
                • Iconst-option
                • Tyspecseq-option
                • Stmt-option
                • Scspecseq
                • Param-declon
                • Obj-declon-option
                • File-option
                • Tyname
                • Transunit
                • Fun-declon
                • Transunit-result
                • Param-declon-list
                • Struct-declon-list
                • Expr-list
                • Tyspecseq-list
                • Ident-set
                • Ident-list
                • Ext-declon-list
                • Unop-list
                • Tyname-list
                • Fundef-list
                • Fun-declon-list
                • Binop-list
                • Stmt-fixtypes
                • Expr-fixtypes
                  • Expr
                    • Exprp
                    • Expr-case
                      • Expr-binary
                      • Expr-equiv
                      • Expr-cond
                      • Expr-unary
                      • Expr-memberp
                      • Expr-member
                      • Expr-cast
                      • Expr-call
                      • Expr-arrsub
                      • Expr-kind
                      • Expr-preinc
                      • Expr-predec
                      • Expr-postinc
                      • Expr-postdec
                      • Expr-ident
                      • Expr-const
                      • Expr-fix
                      • Expr-count
                    • Expr-list
                • Integer-ranges
                • Implementation-environments
                • Dynamic-semantics
                • Static-semantics
                • Grammar
                • Integer-formats
                • Types
                • Portable-ascii-identifiers
                • Values
                • Integer-operations
                • Computation-states
                • Object-designators
                • Operations
                • Errors
                • Tag-environments
                • Function-environments
                • Character-sets
                • Flexible-array-member-removal
                • Arithmetic-operations
                • Pointer-operations
                • Bytes
                • Keywords
                • Real-operations
                • Array-operations
                • Scalar-operations
                • Structure-operations
              • Transformation-tools
              • Representation
              • Insertion-sort
              • Pack
            • Bv
            • Imp-language
            • Event-macros
            • Java
            • Riscv
            • 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
      • Expr

      Expr-case

      Case macro for the different kinds of expr structures.

      This is an ACL2::fty sum-type case macro, typically introduced by fty::defflexsum or fty::deftagsum. It allows you to safely check the type of a expr structure, or to split into cases based on its type.

      Short Form

      In its short form, expr-case allows you to safely check the type of a expr structure. For example:

      (expr-case x :ident)

      is essentially just a safer alternative to writing:

      (equal (expr-kind x) :ident)

      Why is using expr-case safer? When we directly inspect the kind with equal, there is no static checking being done to ensure that, e.g., :ident is a valid kind of expr structure. That means there is nothing to save you if, later, you change the kind keyword for this type from :ident to something else. It also means you get no help if you just make a typo when writing the :ident symbol. Over the course of developing VL, we found that such issues were very frequent sources of errors!

      Long Form

      In its longer form, expr-case allows you to split into cases based on the kind of structure you are looking at. A typical example would be:

      (expr-case x
        :ident ...
        :const ...
        :arrsub ...
        :call ...
        :member ...
        :memberp ...
        :postinc ...
        :postdec ...
        :preinc ...
        :predec ...
        :unary ...
        :cast ...
        :binary ...
        :cond ...)

      It is also possible to consolidate ``uninteresting'' cases using :otherwise.

      For convenience, the case macro automatically binds the fields of x for you, as appropriate for each case. That is, in the :ident case, you can use fty::defprod-style foo.bar style accessors for x without having to explicitly add a ident b* binder.