• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
      • Apt
      • Zfc
      • Acre
      • Milawa
      • Smtlink
      • Abnf
      • Vwsim
      • Isar
      • Wp-gen
      • Dimacs-reader
      • Pfcs
      • Legacy-defrstobj
      • Proof-checker-array
      • Soft
      • C
        • Syntax-for-tools
        • Atc
        • Language
          • Abstract-syntax
          • Integer-ranges
          • Implementation-environments
            • Schar-format
              • Schar-format-fix
              • Schar-format-equiv
              • Make-schar-format
              • Schar-format->signed
              • Schar-formatp
              • Schar-format->trap
              • Change-schar-format
            • Uinteger-sinteger-bit-roles-wfp
            • Integer-format
            • Sinteger-format
            • Integer-format-llong-wfp
            • Integer-format-short-wfp
            • Integer-format-long-wfp
            • Integer-format-int-wfp
            • Uinteger-format
            • Schar-format->min
            • Char+short+int+long+llong-format
            • Uchar-format
            • Char-format->min
            • Integer-format-inc-sign-tcnpnt
            • Char-format->max
            • Sinteger-format->min
            • Sinteger-bit-role
            • Sinteger-bit-roles-wfp
            • Schar-format->max
            • Signed-format
            • Short-format-16tcnt
            • Llong-format-64tcnt
            • Ienv
            • Uinteger-bit-role
            • Long-format-32tcnt
            • Int-format-16tcnt
            • Uinteger-bit-roles-wfp
            • Uinteger+sinteger-format
            • Uinteger-bit-roles-value-count
            • Sinteger-bit-roles-value-count
            • Sinteger-bit-roles-inc-n-and-sign
            • Uinteger-bit-roles-inc-n
            • Sinteger-format-inc-sign-tcnpnt
            • Sinteger-bit-roles-inc-n
            • Uchar-format->max
            • Char+short+int+long+llong-format-wfp
            • Uinteger-bit-roles-exponents
            • Sinteger-bit-roles-exponents
            • Integer-format->bit-size
            • Char-format
            • Sinteger-bit-roles-sign-count
            • Ienv->char-min
            • Uinteger-format-inc-npnt
            • Ienv->schar-min
            • Ienv->char-size
            • Ienv->char-max
            • Uinteger-format->max
            • Sinteger-format->max
            • Ienv->schar-max
            • Ienv->uchar-max
            • Ienv->short-bit-size
            • Ienv->long-bit-size
            • Ienv->llong-bit-size
            • Schar-format-8tcnt
            • Ienv->int-bit-size
            • Ienv->sshort-min
            • Ienv->sllong-min
            • Char-format-8u
            • Ienv->ushort-max
            • Ienv->ulong-max
            • Ienv->ullong-max
            • Ienv->uint-max
            • Ienv->sshort-max
            • Ienv->slong-min
            • Ienv->slong-max
            • Ienv->sllong-max
            • Ienv->sint-min
            • Ienv->sint-max
            • Char8+short16+int16+long32+llong64-tcnt
            • Uchar-format-8
            • Uinteger-bit-role-list
            • Sinteger-bit-role-list
            • Uinteger-sinteger-bit-roles-wfp-of-inc-n-and-sign
          • 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
        • Representation
        • Transformation-tools
        • Insertion-sort
        • Pack
      • Farray
      • Rp-rewriter
      • Instant-runoff-voting
      • Imp-language
      • Sidekick
      • Leftist-trees
      • Java
      • Taspi
      • Bitcoin
      • Riscv
      • Des
      • Ethereum
      • X86isa
      • Sha-2
      • Yul
      • Zcash
      • Proof-checker-itp13
      • Regex
      • ACL2-programming-language
      • Json
      • Jfkr
      • Equational
      • Cryptography
      • Poseidon
      • Where-do-i-place-my-book
      • Axe
      • Bigmems
      • Builtins
      • Execloader
      • Aleo
      • Solidity
      • Paco
      • Concurrent-programs
      • Bls12-377-curves
    • Debugging
    • Std
    • Proof-automation
    • Macro-libraries
    • ACL2
    • Interfacing-tools
    • Hardware-verification
    • Software-verification
    • Math
    • Testing-utilities
  • Implementation-environments

Schar-format

Fixtype of formats of signed char objects.

This is a product type introduced by fty::defprod.

Fields
signed — signed-format
trap — booleanp

Values of the signed char type, like all the other values, must be represented as one or more bytes [ISO:6.2.6.1/4]. Objects of the signed char type, like all other signed integer objects, must have no more value bits than value bits of their unsigned counterpart [ISO:6.2.6.2/2], i.e. unsigned char objects in this case, which consist of exactly one byte (see uchar-format): therefore, signed char objects must take exactly one byte as well.

Since signed char objects must have one sign bit and no padding bits [ISO:6.2.6.2/2], they must have exactly \mathtt{CHAR\_BIT} - 1 value bits. Since the values of the value bits of a signed integer type must be equal to the value bits of the unsigned integer type counterpart [ISO:6.2.6.2/2], the value bits of signed char values are the low bits of the byte, and the sign is the high bit.

While the byte/bit format of signed char is thus set, the exact values represented by this byte/bit format depend on the signed format (when the sign bit is 1). Furthermore, [ISO:6.2.6.2/2] identifies one specific bit pattern, for each signed format, as a possible trap representation: it either is a trap representation or it is not. These two choices (i.e. the signed format, and whether the specific pattern is a trap representation), completely define the representation of signed char.

We formalize the format of signed char as consisting of a specification of signed format and a boolean flag saying whether the aforementioned pattern is a trap.

Subtopics

Schar-format-fix
Fixing function for schar-format structures.
Schar-format-equiv
Basic equivalence relation for schar-format structures.
Make-schar-format
Basic constructor macro for schar-format structures.
Schar-format->signed
Get the signed field from a schar-format.
Schar-formatp
Recognizer for schar-format structures.
Schar-format->trap
Get the trap field from a schar-format.
Change-schar-format
Modifying constructor for schar-format structures.