• 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
        • Isar
        • Kestrel-utilities
        • Set
        • Soft
        • C
          • Syntax-for-tools
            • Disambiguator
            • Abstract-syntax
            • Parser
            • Validator
            • Printer
              • Print-exprs/decls/stmts
              • Print-expr
              • Pristate
              • Print-fileset
              • Print-dec/oct/hex-const
              • Priopt
              • Print-fundef
              • Print-s-char
              • Print-c-char
              • Print-typequal/attribspec-list-list
              • Print-ident
                • Print-ident-list
                • Print-hex-core-fconst
                • Print-dec-core-fconst
                • Print-oct-digit-achar
                • Print-hex-frac-const
                • Print-hex-digit-achar
                • Print-dec-frac-const
                • Print-dec-digit-achar
                • Print-strunispec
                • Print-file
                • Print-astring
                • Print-asm-name-spec
                • Print-asm-clobber-list
                • Print-stringlit-list
                • Print-inc/dec-op-list
                • Print-cprefix-option
                • Print-binop
                • Print-univ-char-name
                • Print-type-qual
                • Print-transunit
                • Print-simple-escape
                • Print-s-char-list
                • Print-isuffix-option
                • Print-indent
                • Print-fsuffix-option
                • Print-extdecl-list
                • Print-eprefix-option
                • Print-dec-expo-option
                • Print-char
                • Print-c-char-list
                • Print-attrib-name
                • Print-asm-qual-list
                • Print-stor-spec
                • Print-oct-escape
                • Print-escape
                • Print-dec-expo-prefix
                • Print-cconst
                • Print-bin-expo-prefix
                • Dec-pristate-indent
                • Print-stringlit
                • Print-sign-option
                • Print-isuffix
                • Print-fun-spec
                • Print-fconst
                • Print-extdecl
                • Print-dec-expo
                • Print-block
                • Print-bin-expo
                • Print-asm-qual
                • Print-asm-clobber
                • Print-new-line
                • Print-lsuffix
                • Print-inc/dec-op
                • Print-hex-quad
                • Print-fsuffix
                • Print-eprefix
                • Print-cprefix
                • Print-usuffix
                • Print-unop
                • Print-iconst
                • Print-hprefix
                • Print-const
                • Print-chars
                • Print-sign
                • Print-oct-digit-achars
                • Print-hex-digit-achars
                • Print-dec-digit-achars
                • Print-stmt
                • Print-expr-list
                • Init-pristate
                • Print-structdecl-list
                • Inc-pristate-indent
                • Print-param-declor
                • Print-dirdeclor
                • Default-priopt
                • Print-structdeclor
                • Print-initer
                • Print-decl-inline
                • Print-structdecl
                • Print-genassoc-list
                • Print-enumspec
                • Print-absdeclor
                • Print-typequal/attribspec-list
                • Print-desiniter-list
                • Print-const-expr
                • Print-attrib
                • Print-tyname
                • Print-structdeclor-list
                • Print-spec/qual-list
                • Print-param-declon-list
                • Print-param-declon
                • Print-initdeclor-list
                • Print-designor-list
                • Print-decl-spec-list
                • Print-decl-list
                • Print-attrib-spec-list
                • Print-asm-output-list
                • Print-asm-input-list
                • Print-typequal/attribspec
                • Print-statassert
                • Print-spec/qual
                • Print-member-designor
                • Print-initdeclor
                • Print-enumer-list
                • Print-dirabsdeclor
                • Print-desiniter
                • Print-decl-spec
                • Print-decl
                • Print-block-item-list
                • Print-attrib-spec
                • Print-attrib-list
                • Print-asm-output
                • Print-align-spec
                • Print-type-spec
                • Print-label
                • Print-genassoc
                • Print-enumer
                • Print-designor
                • Print-declor
                • Print-block-item
                • Print-asm-stmt
                • Print-asm-input
              • Formalized-subset
              • Mapping-to-language-definition
              • Input-files
              • Defpred
              • Output-files
              • Abstract-syntax-operations
              • Validation-information
              • Implementation-environments
              • Concrete-syntax
              • Unambiguity
              • Ascii-identifiers
              • Preprocessing
              • Abstraction-mapping
            • Atc
            • 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
    • Printer

    Print-ident

    Print an identifier.

    Signature
    (print-ident ident pstate) → new-pstate
    Arguments
    ident — Guard (identp ident).
    pstate — Guard (pristatep pstate).
    Returns
    new-pstate — Type (pristatep new-pstate).

    We check that the identifier is a non-empty ACL2 string whose character codes are all valid in our C grammar. This way we can call print-chars.

    This is a weaker check than ensuring that the string is in fact a valid C identifier in our concrete syntax. We plan to strengthen this in the future.

    Definitions and Theorems

    Function: print-ident

    (defun print-ident (ident pstate)
     (declare (xargs :guard (and (identp ident)
                                 (pristatep pstate))))
     (let ((__function__ 'print-ident))
      (declare (ignorable __function__))
      (b*
       ((string? (ident->unwrap ident))
        ((unless (stringp string?))
         (raise
          "Misusage error: ~
                    the identifier contains ~x0 instead of an ACL2 string."
          string?)
         (pristate-fix pstate))
        (chars (acl2::string=>nats string?))
        ((unless chars)
         (raise
           "Misusage error; ~
                    the identifier is empty.")
         (pristate-fix pstate))
        ((unless (grammar-character-listp chars))
         (raise
          "Misusage error: ~
                    the identifier consists of the character codes ~x0, ~
                    not all of which are allowed by the ABNF grammar."
          chars)
         (pristate-fix pstate)))
       (print-chars chars pstate))))

    Theorem: pristatep-of-print-ident

    (defthm pristatep-of-print-ident
      (b* ((new-pstate (print-ident ident pstate)))
        (pristatep new-pstate))
      :rule-classes :rewrite)

    Theorem: print-ident-of-ident-fix-ident

    (defthm print-ident-of-ident-fix-ident
      (equal (print-ident (ident-fix ident) pstate)
             (print-ident ident pstate)))

    Theorem: print-ident-ident-equiv-congruence-on-ident

    (defthm print-ident-ident-equiv-congruence-on-ident
      (implies (ident-equiv ident ident-equiv)
               (equal (print-ident ident pstate)
                      (print-ident ident-equiv pstate)))
      :rule-classes :congruence)

    Theorem: print-ident-of-pristate-fix-pstate

    (defthm print-ident-of-pristate-fix-pstate
      (equal (print-ident ident (pristate-fix pstate))
             (print-ident ident pstate)))

    Theorem: print-ident-pristate-equiv-congruence-on-pstate

    (defthm print-ident-pristate-equiv-congruence-on-pstate
      (implies (pristate-equiv pstate pstate-equiv)
               (equal (print-ident ident pstate)
                      (print-ident ident pstate-equiv)))
      :rule-classes :congruence)