• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Community
    • 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
            • Atc-implementation
              • Atc-abstract-syntax
              • Atc-pretty-printer
              • Atc-event-and-code-generation
              • Fty-pseudo-term-utilities
              • Atc-term-recognizers
              • Atc-input-processing
              • Atc-shallow-embedding
                • Defstruct
                  • Defstruct-implementation
                    • Defstruct-info
                    • Defstruct-gen-recognizer
                    • Defstruct-gen-integer-member-ops
                    • Defstruct-gen-constructor
                    • Defstruct-gen-array-member-ops
                    • Defstruct-gen-recognizer-conjuncts
                    • Defstruct-member-info
                    • Defstruct-member-info-list->memtype-list
                    • Defstruct-process-members
                    • Defstruct-gen-fixer
                    • Defstruct-gen-member-ops
                      • Defstruct-process-inputs
                      • Defstruct-gen-fixing-term
                      • Defstruct-info-option
                      • Defstruct-gen-everything
                      • Defstruct-gen-all-member-ops
                      • Defstruct-gen-recognizer-all-conjuncts
                      • Defstruct-info->writer-element-list
                      • Defstruct-info->reader-element-list
                      • Defstruct-gen-fixtype
                      • Defstruct-info->writer-list
                      • Defstruct-info->reader-list
                      • Defstruct-fn
                      • Defstruct-table-record-event
                      • Defstruct-table-lookup
                      • Irr-defstruct-info
                      • Defstruct-info->writer-element-list-aux
                      • Defstruct-info->reader-element-list-aux
                      • Defstruct-info->writer-list-aux
                      • Defstruct-info->reader-list-aux
                      • Defstruct-member-info-list
                      • Defstruct-table-definition
                      • *defstruct-table*
                      • Defstruct-macro-implementtion
                  • Defobject
                  • Atc-let-designations
                  • Pointer-types
                  • Atc-conditional-expressions
                • Atc-process-inputs-and-gen-everything
                • Atc-table
                • Atc-fn
                • Atc-pretty-printing-options
                • Atc-types
                • Atc-macro-definition
              • Atc-tutorial
            • Language
            • Representation
            • Transformation-tools
            • Insertion-sort
            • Pack
          • 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
    • Defstruct-implementation

    Defstruct-gen-member-ops

    Generate the operations for a member of the structures defined by the defstruct.

    Signature
    (defstruct-gen-member-ops struct-tag struct-tag-p struct-tag-fix 
                              value-kind-when-struct-tag-p 
                              valuep-when-struct-tag-p member) 
     
      → 
    (mv event info)
    Arguments
    struct-tag — Guard (symbolp struct-tag).
    struct-tag-p — Guard (symbolp struct-tag-p).
    struct-tag-fix — Guard (symbolp struct-tag-fix).
    value-kind-when-struct-tag-p — Guard (symbolp value-kind-when-struct-tag-p).
    valuep-when-struct-tag-p — Guard (symbolp valuep-when-struct-tag-p).
    member — Guard (member-typep member).
    Returns
    event — Type (pseudo-event-formp event).
    info — Type (defstruct-member-infop info).

    Definitions and Theorems

    Function: defstruct-gen-member-ops

    (defun defstruct-gen-member-ops
           (struct-tag struct-tag-p struct-tag-fix
                       value-kind-when-struct-tag-p
                       valuep-when-struct-tag-p member)
     (declare (xargs :guard (and (symbolp struct-tag)
                                 (symbolp struct-tag-p)
                                 (symbolp struct-tag-fix)
                                 (symbolp value-kind-when-struct-tag-p)
                                 (symbolp valuep-when-struct-tag-p)
                                 (member-typep member))))
     (let ((__function__ 'defstruct-gen-member-ops))
      (declare (ignorable __function__))
      (b*
       ((name (member-type->name member))
        (type (member-type->type member))
        ((when (type-nonchar-integerp type))
         (b* (((mv event reader writer
                   reader-return-thm writer-return-thm)
               (defstruct-gen-integer-member-ops
                    struct-tag struct-tag-p struct-tag-fix
                    value-kind-when-struct-tag-p
                    valuep-when-struct-tag-p name type))
              (info (make-defstruct-member-info
                         :memtype member
                         :reader reader
                         :reader-element nil
                         :writer writer
                         :writer-element nil
                         :checker nil
                         :length nil
                         :reader-return-thm reader-return-thm
                         :reader-element-return-thm nil
                         :writer-return-thm writer-return-thm
                         :writer-element-return-thm nil)))
           (mv event info)))
        ((unless (type-case type :array))
         (raise "Internal error: member type ~x0." type)
         (mv '(_)
             (make-defstruct-member-info :memtype member)))
        (elem-type (type-array->of type))
        ((unless (type-nonchar-integerp elem-type))
         (raise "Internal error: member type ~x0." type)
         (mv '(_)
             (make-defstruct-member-info :memtype member)))
        (size? (type-array->size type))
        ((mv event
             length checker reader reader-element
             writer writer-element reader-return-thm
             reader-element-return-thm
             writer-return-thm
             writer-element-return-thm)
         (defstruct-gen-array-member-ops
              struct-tag struct-tag-p
              struct-tag-fix name elem-type size?))
        (info
            (make-defstruct-member-info
                 :memtype member
                 :reader reader
                 :reader-element reader-element
                 :writer writer
                 :writer-element writer-element
                 :checker checker
                 :length length
                 :reader-return-thm reader-return-thm
                 :reader-element-return-thm reader-element-return-thm
                 :writer-return-thm writer-return-thm
                 :writer-element-return-thm writer-element-return-thm)))
       (mv event info))))

    Theorem: pseudo-event-formp-of-defstruct-gen-member-ops.event

    (defthm pseudo-event-formp-of-defstruct-gen-member-ops.event
     (b*
      (((mv acl2::?event ?info)
        (defstruct-gen-member-ops struct-tag struct-tag-p struct-tag-fix
                                  value-kind-when-struct-tag-p
                                  valuep-when-struct-tag-p member)))
      (pseudo-event-formp event))
     :rule-classes :rewrite)

    Theorem: defstruct-member-infop-of-defstruct-gen-member-ops.info

    (defthm defstruct-member-infop-of-defstruct-gen-member-ops.info
     (b*
      (((mv acl2::?event ?info)
        (defstruct-gen-member-ops struct-tag struct-tag-p struct-tag-fix
                                  value-kind-when-struct-tag-p
                                  valuep-when-struct-tag-p member)))
      (defstruct-member-infop info))
     :rule-classes :rewrite)