• 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
        • C
        • Soft
        • Bv
        • Imp-language
        • Ethereum
        • Event-macros
        • Java
          • Atj
            • Atj-implementation
              • Atj-types
              • Atj-java-primitive-array-model
              • Atj-java-abstract-syntax
              • Atj-input-processing
              • Atj-java-pretty-printer
              • Atj-code-generation
                • Atj-gen-test-method
                • Atj-shallow-code-generation
                  • Atj-gen-shallow-term-fns
                  • String-jmethodlist-alistp
                  • Atj-gen-shallow-fndef-method
                  • String-jfieldlist-alistp
                  • Atj-gen-shallow-test-code
                  • Atj-adapt-expr-to-type
                  • Atj-gen-shallow-fn-call
                  • Atj-check-marked-annotated-mv-let-call
                  • Atj-gen-shallow-main-class
                  • Atj-gen-shallow-fnnative-method
                  • Atj-gen-shallow-synonym-method
                  • Atj-gen-shallow-if-call
                  • Atj-gen-shallow-and-call
                  • Atj-gen-shallow-pkg-methods
                  • Atj-convert-expr-to-jprim
                  • Atj-gen-shallow-or-call
                  • Atj-convert-expr-from-jprimarr-method
                  • Atj-adapt-expr-to-types
                  • Atj-gen-shallow-all-pkg-methods
                  • Atj-convert-expr-to-jprimarr-method
                  • Atj-gen-shallow-fndef-all-methods
                  • Atj-convert-expr-from-jprim
                  • Atj-gen-shallow-mv-class
                  • Atj-gen-shallow-main-cunit
                  • Atj-gen-shallow-fndef-methods
                  • Atj-gen-shallow-mv-class-name
                  • Atj-shallow-fns-that-may-throw
                  • Atj-gen-shallow-term
                  • Atj-gen-shallow-let-bindings
                  • Atj-gen-shallow-fn-methods
                  • Atj-gen-shallow-jprimarr-new-init-call
                  • Atj-gen-shallow-fnname
                  • Atj-gen-shallow-all-fn-methods
                  • Atj-gen-shallow-not-call
                  • Atj-fnnative-method-name
                  • Atj-gen-shallow-mv-let
                  • Atj-gen-shallow-jprim-constr-call
                  • Atj-gen-shallow-jprimarr-write-call
                  • Atj-gen-shallow-fnnative-all-methods
                  • Atj-gen-shallow-pkg-class
                  • Atj-gen-shallow-jprimarr-length-call
                  • Atj-gen-shallow-pkg-fields
                  • Atj-all-mv-output-types
                  • Atj-gen-shallow-mv-call
                  • Atj-gen-shallow-jprim-binop-call
                  • Atj-gen-shallow-jprim-conv-call
                  • Atj-gen-shallow-primarray-write-method
                    • Atj-gen-shallow-mv-fields
                    • Atj-gen-shallow-jprimarr-read-call
                    • Atj-gen-shallow-jprimarr-new-len-call
                    • Atj-gen-shallow-jprimarr-conv-tolist-call
                    • Atj-gen-shallow-jprimarr-conv-fromlist-call
                    • Atj-gen-shallow-synonym-all-methods
                    • Atj-gen-shallow-jprim-deconstr-call
                    • Atj-gen-shallow-all-pkg-fields
                    • Atj-gen-shallow-test-code-asgs
                    • Atj-gen-shallow-lambda
                    • Atj-gen-shallow-jprim-unop-call
                    • Atj-jprim-binop-fn-to-jbinop
                    • Atj-gen-shallow-mv-asgs
                    • Atj-gen-shallow-env-class
                    • Atj-gen-shallow-mv-params
                    • Atj-gen-shallow-fnnative-methods
                    • Atj-gen-shallow-pkg-classes
                    • Atj-gen-shallow-env-cunit
                    • Atj-gen-shallow-all-synonym-methods
                    • Atj-convert-expr-to-jprimarr
                    • Atj-convert-expr-from-jprimarr
                    • Atj-jprim-constr-fn-of-qconst-to-expr
                    • Atj-gen-shallow-test-code-mv-asgs
                    • Atj-gen-shallow-synonym-methods
                    • Atj-gen-shallow-synonym-method-params
                    • Atj-convert-expr-to-jprimarr-method-name
                    • Atj-convert-expr-from-jprimarr-method-name
                    • Atj-jexpr-list-to-3-jexprs
                    • Atj-jblock-list-to-3-jblocks
                    • Atj-gen-shallow-test-code-comps
                    • Atj-jprim-conv-fn-to-jtype
                    • Atj-gen-shallow-terms
                    • Atj-gen-shallow-mv-field-name
                    • Atj-adapt-exprs-to-types
                    • Atj-jblock-list-to-2-jblocks
                    • Atj-gen-shallow-primarray-write-methods
                    • Atj-gen-shallow-mv-classes
                    • Atj-gen-shallow-jtype
                    • Atj-gen-shallow-build-method
                    • Atj-jexpr-list-to-2-jexprs
                    • Atj-jprimarr-write-to-method-name
                    • Atj-gen-shallow-all-jprimarr-conv-methods
                    • Atj-jprimarr-new-len-fn-to-comp-jtype
                    • Atj-jprimarr-new-init-fn-to-comp-jtype
                    • Atj-jprim-unop-fn-to-junop
                    • *atj-gen-cond-exprs*
                    • Atj-primarray-write-method-name
                    • Atj-gen-shallow-jprimarr-fromlist-methods
                    • Atj-gen-shallow-jprimarr-tolist-methods
                    • Atj-gen-shallow-mv-classes-guard
                    • *atj-mv-singleton-field-name*
                    • *atj-mv-factory-method-name*
                  • Atj-common-code-generation
                  • Atj-shallow-quoted-constant-generation
                  • Atj-pre-translation
                  • Atj-gen-everything
                  • Atj-name-translation
                  • Atj-gen-test-cunit
                  • Atj-gen-test-class
                  • Atj-gen-main-file
                  • Atj-post-translation
                  • Atj-deep-code-generation
                  • Atj-gen-test-methods
                  • Atj-gen-test-file
                  • Atj-gen-env-file
                  • Atj-gen-output-subdir
                • Atj-java-primitives
                • Atj-java-primitive-arrays
                • Atj-type-macros
                • Atj-java-syntax-operations
                • Atj-fn
                • Atj-library-extensions
                • Atj-java-input-types
                • Atj-test-structures
                • Aij-notions
                • Atj-macro-definition
              • Atj-tutorial
            • Aij
            • Language
          • 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
    • Atj-shallow-code-generation

    Atj-gen-shallow-primarray-write-method

    Generate a Java method to write a primitive array component.

    Signature
    (atj-gen-shallow-primarray-write-method type) → method
    Arguments
    type — Guard (primitive-typep type).
    Returns
    method — Type (jmethodp method).

    In the translation step from ACL2 to Java, we turn calls of the ACL2 functions that model array writes into calls of one of eight methods, one for each primitive type, that destructively assign the array component and then return the array. (Calls of these methods are then removed by post-translation.) This function generates these methods, which are private because only code in the main class (including its nested classes) needs to call them.

    The generated method has this form:

    private static <type>[] <name>(<type>[] array,
                                   int index,
                                   <type> component) {
        array[index] = component;
        return array;
    }

    where <type> is the Java primitive type.

    Definitions and Theorems

    Function: atj-gen-shallow-primarray-write-method

    (defun atj-gen-shallow-primarray-write-method (type)
      (declare (xargs :guard (primitive-typep type)))
      (let ((__function__ 'atj-gen-shallow-primarray-write-method))
        (declare (ignorable __function__))
        (b* ((method-name (atj-primarray-write-method-name type))
             (array-type (jtype-array (jtype-prim type)))
             (index-type (jtype-int))
             (component-type (jtype-prim type))
             (array "array")
             (index "index")
             (component "component")
             (array[index] (jexpr-array (jexpr-name array)
                                        (jexpr-name index)))
             (array[index]=component
                  (jblock-asg array[index] (jexpr-name component)))
             (return-array (jblock-return (jexpr-name array)))
             (method-body (append array[index]=component return-array)))
          (make-jmethod
               :access (jaccess-private)
               :abstract? nil
               :static? t
               :final? nil
               :synchronized? nil
               :native? nil
               :strictfp? nil
               :result (jresult-type array-type)
               :name method-name
               :params (list (jparam nil array-type array)
                             (jparam nil index-type index)
                             (jparam nil component-type component))
               :throws nil
               :body method-body))))

    Theorem: jmethodp-of-atj-gen-shallow-primarray-write-method

    (defthm jmethodp-of-atj-gen-shallow-primarray-write-method
      (b* ((method (atj-gen-shallow-primarray-write-method type)))
        (jmethodp method))
      :rule-classes :rewrite)