mirror of
				https://github.com/pragma-/pbot.git
				synced 2025-10-20 18:17:26 +02:00 
			
		
		
		
	 9ddd38038a
			
		
	
	
		9ddd38038a
		
	
	
	
	
		
			
			I really, really need to clean this mess up and combine c99std.pl, c11std.pl and c23std.pl into one script!
		
			
				
	
	
		
			48811 lines
		
	
	
		
			2.2 MiB
		
	
	
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			48811 lines
		
	
	
		
			2.2 MiB
		
	
	
	
	
	
		
			Vendored
		
	
	
	
| <html>
 | |
| <body>
 | |
| <h2>N3047 working draft — August 4, 2022 ISO/IEC 9899:2023 (E)</h2>
 | |
| <a name='ABSTRACT.'></a>
 | |
| <hr>
 | |
| <h3>ABSTRACT. [Abstract]</h3>
 | |
| <pre>(This cover sheet to be replaced by ISO.)
 | |
| 
 | |
| This document specifies the form and establishes the interpretation of programs expressed in the
 | |
| programming language C. Its purpose is to promote portability, reliability, maintainability, and
 | |
| efficient execution of C language programs on a variety of computing systems.
 | |
| 
 | |
| Clauses are included that detail the C language itself and the contents of the C language execution
 | |
| library. Annexes summarize aspects of both of them, and enumerate factors that influence the
 | |
| portability of C programs.
 | |
| 
 | |
| Although this document is intended to guide knowledgeable C language programmers as well as
 | |
| implementors of C language translation systems, the document itself is not designed to serve as a
 | |
| tutorial.
 | |
| 
 | |
| Recipients of this draft are invited to submit, with their comments, notification of any relevant
 | |
| patent rights of which they are aware and to provide supporting documentation.
 | |
| 
 | |
| The following documents, for all intents and purposes, have been applied to this draft from before
 | |
| and during the October 2019 Meeting:
 | |
| 
 | |
| DR 476      volatile semantics for lvalues
 | |
| DR 488      c16rtomb() on wide characters encoded as multiple char16_t
 | |
| DR 494      Part 1: Alignment specifier expression evaluation
 | |
| DR 496      offsetof and subobjects (with editorial modification)
 | |
| DR 497      "white-space character" defined in two places
 | |
| DR 499      Anonymous structure in union behavior
 | |
| DR 500      Ambiguous specification for FLT_EVAL_METHOD
 | |
| DR 501      make DECIMAL_DIG obsolescent
 | |
| FP DR 13    totalorder parameters
 | |
| FP DR 20    changes for obsolescing DECIMAL_DIG
 | |
| FP DR 21    printf of one-digit character string
 | |
| FP DR 22    changes for obsolescing DECIMAL_DIG, Part 2
 | |
| FP DR 23    llquantexp invalid case
 | |
| FP DR 24    remainder NaN case
 | |
| FP DR 25    totalorder parameters
 | |
| N2124 and N2319 rounding direction macro FE_TONEARESTFROMZERO
 | |
| N2186       Alternative to N2166
 | |
| N2212       type generic cbrt (with editorial changes)
 | |
| N2260      Clarifying the restrict Keyword v2
 | |
| N2265      Harmonizing static_assert with C++
 | |
| N2267      nodiscard attribute
 | |
| N2270      maybe_unused attribute
 | |
| N2271      CR for pow divide-by-zero case
 | |
| N2293      Alignment requirements for memory management functions
 | |
| N2314      TS 18661-1 plus CR/DRs for C2X
 | |
| N2322      preprocessor line numbers unspecified
 | |
| N2325      DBL_NORM_MAX etc
 | |
| N2326      floating-point zero and other normalization
 | |
| N2334      deprecated attribute
 | |
| N2335      attributes
 | |
| N2337      strftime, with ’b’ and ’B’ swapped
 | |
| N2338      error indicator for encoding errors in fgetwc
 | |
| N2341      TS 18661-2 plus CR/DRs for C2X
 | |
| N2345      editors, resolve ambiguity of a semicolon
 | |
| N2349      the memccpy function
 | |
| N2350      defining new types in offsetof
 | |
| N2353      the strdup and strndup functions
 | |
| N2356      update for payload functions
 | |
| N2358      no internal state for mblen
 | |
| N2359      part 2 (remove WANT macros from numbered clauses) and part 3 (version macros for
 | |
|            changed library clauses)
 | |
| N2401      TS 18661-4a for C2X
 | |
| N2408      The fallthrough attribute
 | |
| N2412      Two’s complement sign representation for C2x
 | |
| N2417      Section 6: Add time conversion functions that are relatively thread-safe
 | |
| N2418      Adding the u8 character prefix
 | |
| N2432      Remove support for function definitions with identifier lists
 | |
| N2508      Free Positioning of Labels Inside Compound Statements
 | |
| N2554      Minor attribute wording cleanups
 | |
| 
 | |
| The following documents have been applied to this draft from the October 2019 Meeting:
 | |
| 
 | |
| N2379      *_IS_IEC_60559 Feature Test Macros.
 | |
| N2416      Floating Point Negation and Conversion.
 | |
| N2384      Annex <a href='#F.8'>F.8</a> Update for Implementation Extensions and Rounding.
 | |
| N2424      Why logp1 as a Function Name.
 | |
| N2406      Signaling NaN Initializers.
 | |
| N2393      _Bool Definitions For true and false.
 | |
| 
 | |
| The following documents have been applied to this draft from the March/April 2020 Virtual
 | |
| Meeting:
 | |
| 
 | |
| N2444      More optionally per-thread state for the library.
 | |
| N2446      printf of NAN().
 | |
| N2448      [[Nodiscard("should have a reason")]].
 | |
| N2459      Add an interface to query resolution of time bases, v3.
 | |
| N2464      Zero-size Reallocations are Undefined Behavior.
 | |
| N2476      Names and Locations of Floating Point Entities.
 | |
| N2480      Allowing unnamed parameters in function definitions.
 | |
| N2490      Why no wide string strfrom functions.
 | |
| 
 | |
| The following documents have been applied to this draft from the August 2020 Virtual Meeting:
 | |
| 
 | |
| N2491      powr justification
 | |
| N2492      Note About Math Function Properties.
 | |
| N2506      Range Errors in Math Functions.
 | |
| N2508      Free Positioning of Labels.
 | |
| N2517      Clarification Request for C17 Example of Undefined Behavior.
 | |
| N2532      Min-max Functions.
 | |
| N2553      Querying Attribute Support.
 | |
| N2554      Minor Attribute Wording Cleanup.
 | |
| 
 | |
| The following documents have been applied to this draft from the October and November 2020
 | |
| Virtual Meetings:
 | |
| 
 | |
| N2546      Missing DEC_EVAL_METHOD
 | |
| N2547      Missing const in decimal getpayload functions
 | |
| N2548      intmax_t removal from FP functions
 | |
| N2549      Binary Literals
 | |
| N2552      Editorial cleanup for rounding macros
 | |
| N2557      Allow Duplicate Attributes
 | |
| N2560      FP hex formatting precision
 | |
| N2562      Unclear type relationship between a format specifier and its argument
 | |
| N2563      Character encoding of diagnostic text
 | |
| N2564      Range errors and math functions (updated previous version, N2506)
 | |
| N2570      Feature and WANT macros for Annex F functions
 | |
| N2571      snprintf nonnegative clarification
 | |
| N2572      What We Think We Reserve
 | |
| N2580      Decimal Floating Point Triples
 | |
| N2586      Sufficient Formatting Precision
 | |
| N2594      Remove Mixed Wide String Literal Concatenation
 | |
| N2559      Update to IEC 60559:2020
 | |
| N2600      Update to IEC 60559:2020 (updates previous version, N2559)
 | |
| N2602      Infinity/NAN Macros, Editorial Fixes
 | |
| N2607      Compatibility of Pointers to Arrays with Qualifiers
 | |
| 
 | |
| The following documents have been applied to this draft from the March/April 2021 Virtual
 | |
| Meeting:
 | |
| 
 | |
| N2524      String Functions for Freestanding Implementations
 | |
| N2626      Digit Separators
 | |
| N2630      Formatting Input/Output of Binary Integer Numbers
 | |
| N2640      Missing DEC_EVAL_METHOD, Take 2
 | |
| N2641      Missing +(x) in Table
 | |
| N2643      Negative vs. Less Than Zero
 | |
| N2645      Add Support for Preprocessing Directives #elifdef and #elifndef
 | |
| N2680      Specific Width Length Modifier for Formatting
 | |
| The following documents have been applied to this draft from the June 2021 Virtual Meeting:
 | |
| 
 | |
| N2651      fabs and copysign Cleanup
 | |
| N2662      [[maybe_unused]] for Labels
 | |
| N2665      Zero-size Reallocations Are No Longer an Obsolescent Feature
 | |
| N2670      Zeros Compare Equal
 | |
| N2671      Negative Values
 | |
| N2672      §<a href='#5.2.4.2.2'>5.2.4.2.2</a> Cleanup
 | |
| N2683      Towards Integer Safety
 | |
| N2751      signbit Cleanup
 | |
| N2763      Adding a Fundamental Type for N-bit Integers
 | |
| 
 | |
| The following documents have been applied to this draft from the August/September 2021 Virtual
 | |
| Meeting:
 | |
| 
 | |
| N2686      #warning Directive
 | |
| N2688      Sterile Characters
 | |
| N2710      SNAN Fixes
 | |
| N2711      fmin, fmax
 | |
| N2713      Integer Constant Expressions
 | |
| N2714      hypot Changes
 | |
| N2715      cr_ Prefix Potentially Reserved for Identifiers
 | |
| N2716      Fix "numerically"/"numerically equal" Usage
 | |
| N2726      _Imaginary_I and _Complex_I Qualifiers
 | |
| 
 | |
| N2728      char16_t & char32_t String Literals Shall be UTF-16 & UTF-32
 | |
| N2745      Range Error Definition
 | |
| N2748      Effects of fenv Exception Functions
 | |
| N2749      IEC 60559 Bindings
 | |
| N2755      Static Initialization of Decimal Floating Point
 | |
| N2776      ckd_* Identifiers Should be Potentially Reserved Identifiers
 | |
| N2799      __has_include for C
 | |
| 
 | |
| The following documents have been applied to this draft from the November/December 2021
 | |
| Virtual Meeting:
 | |
| 
 | |
| N2747      Annex F Overflow and Underflow
 | |
| N2770      Remove UB from Incomplete Types in Function Parameters
 | |
| N2778      Require Variably-Modified Types
 | |
| N2781      Types do not have Types (with meeting-agreed changes plus some editorial changes)
 | |
| N2790      "remquo" Changes
 | |
| N2805      Overflow and Underflow Definitions
 | |
| N2806      §<a href='#5.2.4.2.2'>5.2.4.2.2</a> Cleanup, Again
 | |
| N2808      Allow 16-bit ptrdiff_t
 | |
| N2823      Freestanding CFP Functions
 | |
| N2838      Types and Sizes
 | |
| N2837      Clarifying Integer Terms (also, delete Annex H and replace with the Floating Point TS
 | |
|            / Annex merge)
 | |
| N2842      Normal and Subnormal Classification
 | |
| N2843      Clarification of Max Exponent Macros
 | |
| N2845      feraiseexcept Update
 | |
| N2846      Clarification about Expression Transformations
 | |
| N2848      INFINITY Macro Contradictions (Wording 1 only!)
 | |
| N2872      Require Exact-Width Integer Type Interfaces, Part I (Change from proposal’s §<a href='#3.1'>3.1</a> only)
 | |
| 
 | |
| The following documents have been applied to this draft from the January/February 2022 Virtual
 | |
| Meeting, Parts 1 and 2:
 | |
| 
 | |
| N2653      char8_t: A type for UTF-8 characters and strings
 | |
| N2701      @, $, and ‘ in the source/execution character set
 | |
| N2754      Decimal Floating Point: Quantum Exponent of NaN
 | |
| N2762      Fixes for Potentially Reserved Identifiers
 | |
| N2764      The _Noreturn Attribute
 | |
| N2775      Literal Suffixes for Bit-Precise Integers
 | |
| N2797      *_HAS_SUBNORM == 0 Implies What?
 | |
| N2810      calloc Overflow Handling
 | |
| N2819      Disambiguate the Storage Class of Some Compound Literals
 | |
| N2826      unreachable()
 | |
| N2828      Unicode Sequences More Than 21 Bits are a Constraint Violation
 | |
| N2829      Make assert() user friendly in C
 | |
| N2836      Unicode Syntax Identifiers for C
 | |
| N2840      Make call_once() Mandatory
 | |
| N2841      No Function Declarators without Prototypes
 | |
| N2844      Remove default promotions for _FloatN Types
 | |
| N2847      Revised Suggestions of Change for Numerically Equal / Equivalent
 | |
| N2879      <a href='#5.2.4.2.2'>5.2.4.2.2</a> Cleanup, Again Again
 | |
| N2880      Overflow and Underflow Definitions Update
 | |
| N2881      Normal and Subnormal Classification Update
 | |
| N2882      Clarification for the Max Exponent Macros
 | |
| N2900      Consistent, Warningless, and Intuitive Initialization with {}
 | |
| N2927      Not-So-Magic: typeof(...)
 | |
| N2931      Macros and Macro Spellings from C Floating Point Integration
 | |
| N2934      Revised Spelling of Keywords
 | |
| N2935      Make false and true Language Features
 | |
| N2937      Properly Define Blocks in the Grammar
 | |
| 
 | |
| The following documents have been applied to this draft from the May 2022 Virtual Meeting:
 | |
| 
 | |
| N2601      Annex X (replacing Annex H) for IEC 60599 Interchange (ratified early 2021 but
 | |
|            integrated over a long period of time).
 | |
| N2861      Indeterminate Values and Trap Representations
 | |
| N2867      Checked N-Bit Integers? (Not Now)
 | |
| N2886      Remove ATOMIC_VAR_INIT
 | |
| N2888      Require Exact-width Integer Type Interfaces, Part II
 | |
| N2897      memset_explicit
 | |
| N2992      Wording Clarification for Variably-Modified Types
 | |
| 
 | |
| The following documents have been applied to this draft from the July 2022 Virtual Meeting:
 | |
| 
 | |
| N2930      Change remove_quals to typeof_unqual
 | |
| N2939      Identifier Syntax Fixes
 | |
| N2940       Remove Trigraphs??!
 | |
| N2969 (nice) Bit-Precise Bit Fields
 | |
| N2974       Queryable Pointer Alignment
 | |
| N3029       Improved Normal Enumerations
 | |
| N2975       Relax requirements for va_start
 | |
| N2993       Make *_HAS_SUBNORM Obsolete
 | |
| N3011       Oops, Empty Initializers in Compound Literals
 | |
| N3030       Enhanced Enumerations
 | |
| N2951       Freestanding C and IEC 60559 Conformance Scope Reduction
 | |
| N2956       Unsequenced Functions
 | |
| N3033       Comma Ommission and Deletion (__VA_OPT__ and Preprocessor Wording Improve-
 | |
|             ments)
 | |
| N3035       _BitInt(...) Fixes
 | |
| 
 | |
| N3006       Underspecified Object Declarations
 | |
| N3007       Type Inference for Object Declarations
 | |
| N3018       constexpr for Object Definitions
 | |
| N3038       Introduce Storage Class Specifiers for Compound Literals
 | |
| N3034       Identifier Primary Expressions
 | |
| N3042       Introduce the nullptr_t constant, nullptr
 | |
| N2929       Memory Layout of union s
 | |
| N3037       Improved Tag Compatibility
 | |
| N3020       Qualifier-preserving Standard Functions
 | |
| N3022       Modern Bit Utilities - without Rotate Left/Right, Memory Reversal ("byteswap"), or
 | |
|             Endian-Aware Load/Store
 | |
| N3017       #embed
 | |
| N2957       New Optional Time Bases
 | |
| 
 | |
| In addition to these, the document has undergone some editorial changes, including the following.
 | |
| 
 | |
|   — The synopsis lists in Annex B are now generated automatically and classified according to
 | |
|     the feature test or WANT macros that are required to make them available.
 | |
|   — A new non-normative clause <a href='#J.6'>J.6</a> added to Annex J categorizes identifiers used by this
 | |
|     document.
 | |
|   — Renaming of the syntax term "struct declaration", "struct declaration list" "struct declarator",
 | |
|     and "struct declarator list" to the more appropriate "member declaration", "member declaration
 | |
|     list", "member declarator" and "member declarator list", respectively.
 | |
|   — Misspelling of "invokation" fixed to "invocation".
 | |
|   — A positional reference to a table was changed to be a more direct reference due to unfortunate
 | |
|     page breaks.
 | |
|   — Missing macros were added to from <float.h> and <limits.h>.
 | |
|   — A footnote added for simple atomic assignment (<a href='#6.5.16'>6.5.16</a>).
 | |
|   — The _Bool expansion macros were properly defined and fixed for true and false.
 | |
|   — An issue with "modifying object" being removed from an earlier draft was fixed. This was a
 | |
|     mistake: side effects do include modifying an object.
 | |
|   — The Decimal Floating Point Initialization text was not well-worded. It was fixed after the
 | |
|     paper adding the wording was integrated.
 | |
|   — Examples using poor phrasing for objects and their types were fixed to say "object(s) of type
 | |
|     int" and similar.
 | |
|   — The terms "floating-point type" and "floating-point constant" were changed to just be
 | |
|     "floating type" and "floating constant", as are defined in the standard, respectively.
 | |
| — The wording "thread-local storage" was normalized to be "thread storage" everywhere, as
 | |
|   intended (this is the word defined by the standard, the other just fell naturally out of casual
 | |
|   usage and thought).
 | |
| — A footnote clarifying the role for valid pointers with zero size was added to the library
 | |
|   frontmatter, specifically concerning functions like memcpy and memset.
 | |
| — Various duplicate spellings (e.g. "function functions" and similar) were removed and typos
 | |
|   were fixed (e.g., "stirng" and similar).
 | |
| — The pp-number production was incorrect for digit separators. Adjusted and fixed.
 | |
| — The wording for freestanding heads for <string.h> were very poorly done. It was changed
 | |
|   to have better wording.
 | |
| — The introductory sentence for the implementation limits was very wordy and deeply confus-
 | |
|   ing to normal users. The sentence was adjusted to read much better and more clearly.
 | |
| — In a sentence using "respectively" for fmin and fmax descriptions, the order of the respective
 | |
|   items was swapped. This gave the wrong definitions to each item. They were put in the
 | |
|   proper order.
 | |
| — A missing closing parenthesis in Annex J was fixed.
 | |
| — The term "floating-point multiply add" was changed to "fused multiply add", matching
 | |
|   naming conventions in reality.
 | |
| 
 | |
| </pre>
 | |
| <a name='CONTENTS.'></a>
 | |
| <hr>
 | |
| <h3>CONTENTS. [Contents]</h3>
 | |
| <pre><a href='#FOREWORD.'>Foreword</a>
 | |
| 
 | |
| <a href='#INTRO.'>Introduction</a>
 | |
| 
 | |
| <a href='#1.'>1.</a>   Scope
 | |
| 
 | |
| <a href='#2.'>2.</a>   Normative references
 | |
| 
 | |
| <a href='#3.'>3.</a>   Terms, definitions, and symbols
 | |
| 
 | |
| <a href='#4.'>4.</a>   Conformance
 | |
| 
 | |
| <a href='#5.'>5.</a>   Environment
 | |
|     <a href='#5.1'>5.1</a>   Conceptual models
 | |
|           <a href='#5.1.1'>5.1.1</a>   Translation environment
 | |
|           <a href='#5.1.2'>5.1.2</a>   Execution environments
 | |
|     <a href='#5.2'>5.2</a>   Environmental considerations
 | |
|           <a href='#5.2.1'>5.2.1</a>   Character sets
 | |
|           <a href='#5.2.2'>5.2.2</a>   Character display semantics
 | |
|           <a href='#5.2.3'>5.2.3</a>   Signals and interrupts
 | |
|           <a href='#5.2.4'>5.2.4</a>   Environmental limits
 | |
| 
 | |
| 
 | |
|     <a href='#6.1'>6.1</a>   Notation
 | |
|     <a href='#6.2'>6.2</a>   Concepts
 | |
|           <a href='#6.2.1'>6.2.1</a>   Scopes of identifiers
 | |
|           <a href='#6.2.2'>6.2.2</a>   Linkages of identifiers
 | |
|           <a href='#6.2.3'>6.2.3</a>   Name spaces of identifiers
 | |
|           <a href='#6.2.4'>6.2.4</a>   Storage durations of objects
 | |
|           <a href='#6.2.5'>6.2.5</a>   Types
 | |
|           <a href='#6.2.6'>6.2.6</a>   Representations of types
 | |
|           <a href='#6.2.7'>6.2.7</a>   Compatible type and composite type
 | |
|           <a href='#6.2.8'>6.2.8</a>   Alignment of objects
 | |
|           <a href='#6.2.9'>6.2.9</a>   Encodings
 | |
|     <a href='#6.3'>6.3</a>   Conversions
 | |
|           <a href='#6.3.1'>6.3.1</a>   Arithmetic operands
 | |
|           <a href='#6.3.2'>6.3.2</a>   Other operands
 | |
|     <a href='#6.4'>6.4</a>   Lexical elements
 | |
|           <a href='#6.4.1'>6.4.1</a>   Keywords
 | |
|          <a href='#6.4.2'>6.4.2</a>    Identifiers
 | |
|          <a href='#6.4.3'>6.4.3</a>    Universal character names
 | |
|          <a href='#6.4.4'>6.4.4</a>    Constants
 | |
|          <a href='#6.4.5'>6.4.5</a>    String literals
 | |
|          <a href='#6.4.6'>6.4.6</a>    Punctuators
 | |
|          <a href='#6.4.7'>6.4.7</a>    Header names
 | |
|          <a href='#6.4.8'>6.4.8</a>    Preprocessing numbers
 | |
|          <a href='#6.4.9'>6.4.9</a>    Comments
 | |
|    <a href='#6.5'>6.5</a>   Expressions
 | |
|          <a href='#6.5.1'>6.5.1</a>    Primary expressions
 | |
|          <a href='#6.5.2'>6.5.2</a>    Postfix operators
 | |
|          <a href='#6.5.3'>6.5.3</a>    Unary operators
 | |
|          <a href='#6.5.4'>6.5.4</a>    Cast operators
 | |
|          <a href='#6.5.5'>6.5.5</a>    Multiplicative operators
 | |
|          <a href='#6.5.6'>6.5.6</a>    Additive operators
 | |
|          <a href='#6.5.7'>6.5.7</a>    Bitwise shift operators
 | |
|          <a href='#6.5.8'>6.5.8</a>    Relational operators
 | |
|          <a href='#6.5.9'>6.5.9</a>    Equality operators
 | |
|          <a href='#6.5.10'>6.5.10</a>   Bitwise AND operator
 | |
|          <a href='#6.5.11'>6.5.11</a>   Bitwise exclusive OR operator
 | |
|          <a href='#6.5.12'>6.5.12</a>   Bitwise inclusive OR operator
 | |
|          <a href='#6.5.13'>6.5.13</a>   Logical AND operator
 | |
|          <a href='#6.5.14'>6.5.14</a>   Logical OR operator
 | |
|          <a href='#6.5.15'>6.5.15</a>   Conditional operator
 | |
|          <a href='#6.5.16'>6.5.16</a>   Assignment operators
 | |
|          <a href='#6.5.17'>6.5.17</a>   Comma operator
 | |
|    <a href='#6.6'>6.6</a>   Constant expressions
 | |
|    <a href='#6.7'>6.7</a>   Declarations
 | |
|          <a href='#6.7.1'>6.7.1</a>   Storage-class specifiers
 | |
|          <a href='#6.7.2'>6.7.2</a>   Type specifiers
 | |
|          <a href='#6.7.3'>6.7.3</a>   Type qualifiers
 | |
|          <a href='#6.7.4'>6.7.4</a>   Function specifiers
 | |
|          <a href='#6.7.5'>6.7.5</a>   Alignment specifier
 | |
|          <a href='#6.7.6'>6.7.6</a>   Declarators
 | |
|          <a href='#6.7.7'>6.7.7</a>   Type names
 | |
|          <a href='#6.7.8'>6.7.8</a>   Type definitions
 | |
|          <a href='#6.7.9'>6.7.9</a>   Type inference
 | |
|          <a href='#6.7.10'>6.7.10</a>  Initialization
 | |
|          <a href='#6.7.11'>6.7.11</a>  Static assertions
 | |
|          <a href='#6.7.12'>6.7.12</a>  Attributes
 | |
|    <a href='#6.8'>6.8</a>   Statements and blocks
 | |
|          <a href='#6.8.1'>6.8.1</a>   Labeled statements
 | |
|          <a href='#6.8.2'>6.8.2</a>   Compound statement
 | |
|          <a href='#6.8.3'>6.8.3</a>   Expression and null statements
 | |
|          <a href='#6.8.4'>6.8.4</a>   Selection statements
 | |
|          <a href='#6.8.5'>6.8.5</a>   Iteration statements
 | |
|          <a href='#6.8.6'>6.8.6</a>   Jump statements
 | |
|    <a href='#6.9'>6.9</a>   External definitions
 | |
|          <a href='#6.9.1'>6.9.1</a>   Function definitions
 | |
|          <a href='#6.9.2'>6.9.2</a>   External object definitions
 | |
|    <a href='#6.10'>6.10</a> Preprocessing directives
 | |
|          <a href='#6.10.1'>6.10.1</a> Conditional inclusion
 | |
|          <a href='#6.10.2'>6.10.2</a> Source file inclusion
 | |
|          <a href='#6.10.3'>6.10.3</a> Binary resource inclusion
 | |
|          <a href='#6.10.4'>6.10.4</a> Macro replacement
 | |
|          <a href='#6.10.5'>6.10.5</a> Line control
 | |
|          <a href='#6.10.6'>6.10.6</a> Diagnostic directives
 | |
|          <a href='#6.10.7'>6.10.7</a> Pragma directive
 | |
|          <a href='#6.10.8'>6.10.8</a> Null directive
 | |
|          <a href='#6.10.9'>6.10.9</a> Predefined macro names
 | |
|          <a href='#6.10.10'>6.10.10</a> Pragma operator
 | |
|    <a href='#6.11'>6.11</a> Future language directions
 | |
|          <a href='#6.11.1'>6.11.1</a> Floating types
 | |
|          <a href='#6.11.2'>6.11.2</a> Linkages of identifiers
 | |
|          <a href='#6.11.3'>6.11.3</a> External names
 | |
|          <a href='#6.11.4'>6.11.4</a> Character escape sequences
 | |
|          <a href='#6.11.5'>6.11.5</a> Storage-class specifiers
 | |
|          <a href='#6.11.6'>6.11.6</a> Pragma directives
 | |
|          <a href='#6.11.7'>6.11.7</a> Predefined macro names
 | |
| 
 | |
| 
 | |
|    <a href='#7.1'>7.1</a>   Introduction
 | |
|          <a href='#7.1.1'>7.1.1</a>   Definitions of terms
 | |
|          <a href='#7.1.2'>7.1.2</a>   Standard headers
 | |
|          <a href='#7.1.3'>7.1.3</a>   Reserved identifiers
 | |
|          <a href='#7.1.4'>7.1.4</a>   Use of library functions
 | |
|    <a href='#7.2'>7.2</a>   Diagnostics <assert.h>
 | |
|          <a href='#7.2.1'>7.2.1</a>   Program diagnostics
 | |
|    <a href='#7.3'>7.3</a>   Complex arithmetic <complex.h>
 | |
|          <a href='#7.3.1'>7.3.1</a>   Introduction
 | |
|          <a href='#7.3.2'>7.3.2</a>   Conventions
 | |
|          <a href='#7.3.3'>7.3.3</a>   Branch cuts
 | |
|          <a href='#7.3.4'>7.3.4</a>   The CX_LIMITED_RANGE pragma
 | |
|          <a href='#7.3.5'>7.3.5</a>   Trigonometric functions
 | |
|          <a href='#7.3.6'>7.3.6</a>   Hyperbolic functions
 | |
|          <a href='#7.3.7'>7.3.7</a>   Exponential and logarithmic functions
 | |
|          <a href='#7.3.8'>7.3.8</a>   Power and absolute-value functions
 | |
|          <a href='#7.3.9'>7.3.9</a>   Manipulation functions
 | |
|    <a href='#7.4'>7.4</a>   Character handling <ctype.h>
 | |
|          <a href='#7.4.1'>7.4.1</a>   Character classification functions
 | |
|          <a href='#7.4.2'>7.4.2</a>   Character case mapping functions
 | |
|    <a href='#7.5'>7.5</a>   Errors <errno.h>
 | |
|    <a href='#7.6'>7.6</a>   Floating-point environment <fenv.h>
 | |
|          <a href='#7.6.1'>7.6.1</a>   The FENV_ACCESS pragma
 | |
|          <a href='#7.6.2'>7.6.2</a>   The FENV_ROUND pragma
 | |
|          <a href='#7.6.3'>7.6.3</a>   The FENV_DEC_ROUND pragma
 | |
|          <a href='#7.6.4'>7.6.4</a>   Floating-point exceptions
 | |
|          <a href='#7.6.5'>7.6.5</a>   Rounding and other control modes
 | |
|          <a href='#7.6.6'>7.6.6</a>   Environment
 | |
|    <a href='#7.7'>7.7</a>   Characteristics of floating types <float.h>
 | |
|    <a href='#7.8'>7.8</a>   Format conversion of integer types <inttypes.h>
 | |
|          <a href='#7.8.1'>7.8.1</a>   Macros for format specifiers
 | |
|          <a href='#7.8.2'>7.8.2</a>   Functions for greatest-width integer types
 | |
|    <a href='#7.9'>7.9</a>   Alternative spellings <iso646.h>
 | |
|    <a href='#7.10'>7.10</a> Characteristics of integer types <limits.h>
 | |
|    <a href='#7.11'>7.11</a> Localization <locale.h>
 | |
|          <a href='#7.11.1'>7.11.1</a> Locale control
 | |
|          <a href='#7.11.2'>7.11.2</a> Numeric formatting convention inquiry
 | |
|    <a href='#7.12'>7.12</a> Mathematics <math.h>
 | |
|          <a href='#7.12.1'>7.12.1</a> Treatment of error conditions
 | |
|          <a href='#7.12.2'>7.12.2</a> The FP_CONTRACT pragma
 | |
|          <a href='#7.12.3'>7.12.3</a> Classification macros
 | |
|          <a href='#7.12.4'>7.12.4</a> Trigonometric functions
 | |
|          <a href='#7.12.5'>7.12.5</a> Hyperbolic functions
 | |
|          <a href='#7.12.6'>7.12.6</a> Exponential and logarithmic functions
 | |
|          <a href='#7.12.7'>7.12.7</a> Power and absolute-value functions
 | |
|          <a href='#7.12.8'>7.12.8</a> Error and gamma functions
 | |
|          <a href='#7.12.9'>7.12.9</a> Nearest integer functions
 | |
|          <a href='#7.12.10'>7.12.10</a> Remainder functions
 | |
|          <a href='#7.12.11'>7.12.11</a> Manipulation functions
 | |
|         <a href='#7.12.12'>7.12.12</a> Maximum, minimum, and positive difference functions
 | |
|         <a href='#7.12.13'>7.12.13</a> Fused multiply-add
 | |
|         <a href='#7.12.14'>7.12.14</a> Functions that round result to narrower type
 | |
|         <a href='#7.12.15'>7.12.15</a> Quantum and quantum exponent functions
 | |
|         <a href='#7.12.16'>7.12.16</a> Decimal re-encoding functions
 | |
|         <a href='#7.12.17'>7.12.17</a> Comparison macros
 | |
|    <a href='#7.13'>7.13</a> Non-local jumps <setjmp.h>
 | |
|         <a href='#7.13.1'>7.13.1</a> Save calling environment
 | |
|         <a href='#7.13.2'>7.13.2</a> Restore calling environment
 | |
|    <a href='#7.14'>7.14</a> Signal handling <signal.h>
 | |
|         <a href='#7.14.1'>7.14.1</a> Specify signal handling
 | |
|         <a href='#7.14.2'>7.14.2</a> Send signal
 | |
|    <a href='#7.15'>7.15</a> Alignment <stdalign.h>
 | |
|    <a href='#7.16'>7.16</a> Variable arguments <stdarg.h>
 | |
|         <a href='#7.16.1'>7.16.1</a> Variable argument list access macros
 | |
|    <a href='#7.17'>7.17</a> Atomics <stdatomic.h>
 | |
|         <a href='#7.17.1'>7.17.1</a> Introduction
 | |
|         <a href='#7.17.2'>7.17.2</a> Initialization
 | |
|         <a href='#7.17.3'>7.17.3</a> Order and consistency
 | |
|         <a href='#7.17.4'>7.17.4</a> Fences
 | |
|         <a href='#7.17.5'>7.17.5</a> Lock-free property
 | |
|         <a href='#7.17.6'>7.17.6</a> Atomic integer types
 | |
|         <a href='#7.17.7'>7.17.7</a> Operations on atomic types
 | |
|         <a href='#7.17.8'>7.17.8</a> Atomic flag type and operations
 | |
|    <a href='#7.18'>7.18</a> Bit and byte utilities <stdbit.h>
 | |
|         <a href='#7.18.1'>7.18.1</a> General
 | |
|         <a href='#7.18.2'>7.18.2</a> Endian
 | |
|         <a href='#7.18.3'>7.18.3</a> Count Leading Zeros
 | |
|         <a href='#7.18.4'>7.18.4</a> Count Leading Ones
 | |
|         <a href='#7.18.5'>7.18.5</a> Count Trailing Zeros
 | |
|         <a href='#7.18.6'>7.18.6</a> Count Trailing Ones
 | |
|         <a href='#7.18.7'>7.18.7</a> First Leading Zero
 | |
|         <a href='#7.18.8'>7.18.8</a> First Leading One
 | |
|         <a href='#7.18.9'>7.18.9</a> First Trailing Zero
 | |
|         <a href='#7.18.10'>7.18.10</a> First Trailing One
 | |
|         <a href='#7.18.11'>7.18.11</a> Count Ones
 | |
|         <a href='#7.18.12'>7.18.12</a> Count Zeros
 | |
|         <a href='#7.18.13'>7.18.13</a> Single-bit Check
 | |
|         <a href='#7.18.14'>7.18.14</a> Bit Width
 | |
|         <a href='#7.18.15'>7.18.15</a> Bit Floor
 | |
|         <a href='#7.18.16'>7.18.16</a> Bit Ceiling
 | |
|    <a href='#7.19'>7.19</a> Boolean type and values <stdbool.h>
 | |
|    <a href='#7.20'>7.20</a> Checked Integer Arithmetic <stdckdint.h>
 | |
|         <a href='#7.20.1'>7.20.1</a> The ckd_ Checked Integer Operation Macros
 | |
|    <a href='#7.21'>7.21</a> Common definitions <stddef.h>
 | |
|         <a href='#7.21.1'>7.21.1</a> The unreachable macro
 | |
|         <a href='#7.21.2'>7.21.2</a> The nullptr_t type
 | |
|    <a href='#7.22'>7.22</a> Integer types <stdint.h>
 | |
|         <a href='#7.22.1'>7.22.1</a> Integer types
 | |
|         <a href='#7.22.2'>7.22.2</a> Widths of specified-width integer types
 | |
|         <a href='#7.22.3'>7.22.3</a> Width of other integer types
 | |
|         <a href='#7.22.4'>7.22.4</a> Macros for integer constants
 | |
|         <a href='#7.22.5'>7.22.5</a> Maximal and minimal values of integer types
 | |
|    <a href='#7.23'>7.23</a> Input/output <stdio.h>
 | |
|         <a href='#7.23.1'>7.23.1</a> Introduction
 | |
|         <a href='#7.23.2'>7.23.2</a> Streams
 | |
|         <a href='#7.23.3'>7.23.3</a> Files
 | |
|         <a href='#7.23.4'>7.23.4</a> Operations on files
 | |
|         <a href='#7.23.5'>7.23.5</a> File access functions
 | |
|         <a href='#7.23.6'>7.23.6</a> Formatted input/output functions
 | |
|         <a href='#7.23.7'>7.23.7</a> Character input/output functions
 | |
|         <a href='#7.23.8'>7.23.8</a> Direct input/output functions
 | |
|         <a href='#7.23.9'>7.23.9</a> File positioning functions
 | |
|         <a href='#7.23.10'>7.23.10</a> Error-handling functions
 | |
|    <a href='#7.24'>7.24</a> General utilities <stdlib.h>
 | |
|         <a href='#7.24.1'>7.24.1</a> Numeric conversion functions
 | |
|         <a href='#7.24.2'>7.24.2</a> Pseudo-random sequence generation functions
 | |
|         <a href='#7.24.3'>7.24.3</a> Memory management functions
 | |
|         <a href='#7.24.4'>7.24.4</a> Communication with the environment
 | |
|         <a href='#7.24.5'>7.24.5</a> Searching and sorting utilities
 | |
|         <a href='#7.24.6'>7.24.6</a> Integer arithmetic functions
 | |
|         <a href='#7.24.7'>7.24.7</a> Multibyte/wide character conversion functions
 | |
|         <a href='#7.24.8'>7.24.8</a> Multibyte/wide string conversion functions
 | |
|         <a href='#7.24.9'>7.24.9</a> Alignment of memory
 | |
|    <a href='#7.25'>7.25</a> _Noreturn <stdnoreturn.h>
 | |
|    <a href='#7.26'>7.26</a> String handling <string.h>
 | |
|         <a href='#7.26.1'>7.26.1</a> String function conventions
 | |
|         <a href='#7.26.2'>7.26.2</a> Copying functions
 | |
|         <a href='#7.26.3'>7.26.3</a> Concatenation functions
 | |
|         <a href='#7.26.4'>7.26.4</a> Comparison functions
 | |
|         <a href='#7.26.5'>7.26.5</a> Search functions
 | |
|         <a href='#7.26.6'>7.26.6</a> Miscellaneous functions
 | |
|    <a href='#7.27'>7.27</a> Type-generic math <tgmath.h>
 | |
|    <a href='#7.28'>7.28</a> Threads <threads.h>
 | |
|         <a href='#7.28.1'>7.28.1</a> Introduction
 | |
|         <a href='#7.28.2'>7.28.2</a> Initialization functions
 | |
|         <a href='#7.28.3'>7.28.3</a> Condition variable functions
 | |
|         <a href='#7.28.4'>7.28.4</a> Mutex functions
 | |
|         <a href='#7.28.5'>7.28.5</a> Thread functions
 | |
|         <a href='#7.28.6'>7.28.6</a> Thread-specific storage functions
 | |
|    <a href='#7.29'>7.29</a> Date and time <time.h>
 | |
|         <a href='#7.29.1'>7.29.1</a> Components of time
 | |
|         <a href='#7.29.2'>7.29.2</a> Time manipulation functions
 | |
|         <a href='#7.29.3'>7.29.3</a> Time conversion functions
 | |
|    <a href='#7.30'>7.30</a> Unicode utilities <uchar.h>
 | |
|         <a href='#7.30.1'>7.30.1</a> Restartable multibyte/wide character conversion functions
 | |
|    <a href='#7.31'>7.31</a> Extended multibyte and wide character utilities <wchar.h>
 | |
|         <a href='#7.31.1'>7.31.1</a> Introduction
 | |
|         <a href='#7.31.2'>7.31.2</a> Formatted wide character input/output functions
 | |
|         <a href='#7.31.3'>7.31.3</a> Wide character input/output functions
 | |
|         <a href='#7.31.4'>7.31.4</a> General wide string utilities
 | |
|         <a href='#7.31.4.1'>7.31.4.1</a> Wide string numeric conversion functions
 | |
|         <a href='#7.31.4.2'>7.31.4.2</a> Wide string copying functions
 | |
|         <a href='#7.31.4.3'>7.31.4.3</a> Wide string concatenation functions
 | |
|         <a href='#7.31.4.4'>7.31.4.4</a> Wide string comparison functions
 | |
|         <a href='#7.31.4.5'>7.31.4.5</a> Wide string search functions
 | |
|         <a href='#7.31.4.6'>7.31.4.6</a> Introduction
 | |
|         <a href='#7.31.4.7'>7.31.4.7</a> Miscellaneous functions
 | |
|         <a href='#7.31.5'>7.31.5</a> Wide character time conversion functions
 | |
|         <a href='#7.31.6'>7.31.6</a> Extended multibyte/wide character conversion utilities
 | |
|         <a href='#7.31.6.1'>7.31.6.1</a> Single-byte/wide character conversion functions
 | |
|         <a href='#7.31.6.2'>7.31.6.2</a> Conversion state functions
 | |
|         <a href='#7.31.6.3'>7.31.6.3</a> Restartable multibyte/wide character conversion functions
 | |
|         <a href='#7.31.6.4'>7.31.6.4</a> Restartable multibyte/wide string conversion functions
 | |
|    <a href='#7.32'>7.32</a> Wide character classification and mapping utilities <wctype.h>
 | |
|         <a href='#7.32.1'>7.32.1</a> Introduction
 | |
|         <a href='#7.32.2'>7.32.2</a> Wide character classification utilities
 | |
|         <a href='#7.32.2.1'>7.32.2.1</a> Wide character classification functions
 | |
|         <a href='#7.32.2.2'>7.32.2.2</a> Extensible wide character classification functions
 | |
|         <a href='#7.32.3'>7.32.3</a> Wide character case mapping utilities
 | |
|         <a href='#7.32.3.1'>7.32.3.1</a> Wide character case mapping functions
 | |
|         <a href='#7.32.3.2'>7.32.3.2</a> Extensible wide character case mapping functions
 | |
|    <a href='#7.33'>7.33</a> Future library directions
 | |
|         <a href='#7.33.1'>7.33.1</a> Complex arithmetic <complex.h>
 | |
|         <a href='#7.33.2'>7.33.2</a> Character handling <ctype.h>
 | |
|         <a href='#7.33.3'>7.33.3</a> Errors <errno.h>
 | |
|         <a href='#7.33.4'>7.33.4</a> Floating-point environment <fenv.h>
 | |
|         <a href='#7.33.5'>7.33.5</a> Characteristics of floating types <float.h>
 | |
|         <a href='#7.33.6'>7.33.6</a> Format conversion of integer types <inttypes.h>
 | |
|         <a href='#7.33.7'>7.33.7</a> Localization <locale.h>
 | |
|         <a href='#7.33.8'>7.33.8</a> Mathematics <math.h>
 | |
|         <a href='#7.33.9'>7.33.9</a> Signal handling <signal.h>
 | |
|         <a href='#7.33.10'>7.33.10</a> Atomics <stdatomic.h>
 | |
|         <a href='#7.33.11'>7.33.11</a> Boolean type and values <stdbool.h>
 | |
|         <a href='#7.33.12'>7.33.12</a> Bit and byte utilities <stdbit.h>
 | |
|         <a href='#7.33.13'>7.33.13</a> Checked Arithmetic Functions <stdckdint.h>
 | |
|         <a href='#7.33.14'>7.33.14</a> Integer types <stdint.h>
 | |
|         <a href='#7.33.15'>7.33.15</a> Input/output <stdio.h>
 | |
|         <a href='#7.33.16'>7.33.16</a> General utilities <stdlib.h>
 | |
|         <a href='#7.33.17'>7.33.17</a> String handling <string.h>
 | |
|         <a href='#7.33.18'>7.33.18</a> Date and time <time.h>
 | |
|         <a href='#7.33.19'>7.33.19</a> Threads <threads.h>
 | |
|         <a href='#7.33.20'>7.33.20</a> Extended multibyte and wide character utilities <wchar.h>
 | |
|         <a href='#7.33.21'>7.33.21</a> Wide character classification and mapping utilities <wctype.h>
 | |
| 
 | |
| <a href='#A.'>Annex A</a> (informative) Language syntax summary
 | |
| 
 | |
| <a href='#B.'>Annex B</a> (informative) Library summary
 | |
| 
 | |
| <a href='#C.'>Annex C</a> (informative) Sequence points
 | |
| 
 | |
| <a href='#D.'>Annex D</a> (informative) Universal character names for identifiers
 | |
| 
 | |
| <a href='#E.'>Annex E</a> (informative) Implementation limits
 | |
| 
 | |
| <a href='#F.'>Annex F</a> (normative) IEC 60559 floating-point arithmetic
 | |
| 
 | |
| <a href='#G.'>Annex G</a> (normative) IEC 60559-compatible complex arithmetic
 | |
| 
 | |
| <a href='#H.'>Annex H</a> (normative) IEC 60559 interchange and extended types
 | |
| 
 | |
| <a href='#I.'>Annex I</a> (informative) Common warnings
 | |
| 
 | |
| <a href='#J.'>Annex J</a> (informative) Portability issues
 | |
| <a href='#K.'>Annex K</a> (normative) Bounds-checking interfaces
 | |
| 
 | |
| <a href='#L.'>Annex L</a> (normative) Analyzability
 | |
| 
 | |
| <a href='#M.'>Annex M</a> (informative) Change History
 | |
| 
 | |
| </pre>
 | |
| <a name='FOREWORD.'></a>
 | |
| <hr>
 | |
| <h3>FOREWORD. [Foreword]</h3>
 | |
| <a name='FOREWORD.p1'></a>
 | |
| <pre>1   ISO (the International Organization for Standardization) and IEC (the International Electrotechnical
 | |
|     Commission) form the specialized system for worldwide standardization. National bodies that
 | |
|     are member of ISO or IEC participate in the development of International Standards through
 | |
|     technical committees established by the respective organization to deal with particular fields of
 | |
|     technical activity. ISO and IEC technical committees collaborate in fields of mutual interest. Other
 | |
|     international organizations, governmental and non-governmental, in liaison with ISO and IEC, also
 | |
|     take part in the work. In the field of information technology, ISO and IEC have established a joint
 | |
|     technical committee, ISO/IEC JTC 1.
 | |
| </pre>
 | |
| <a name='FOREWORD.p2'></a>
 | |
| <pre>2   The procedures used to develop this document and those intended for its further maintenance are
 | |
|     described in the ISO/IEC Directives, Part 1. In particular, the different approval criteria needed for
 | |
|     the different types of document should be noted. This document was drafted in accordance with the
 | |
|     editorial rules of the ISO/IEC Directives, Part 2 (see www.iso.org/directives).
 | |
| </pre>
 | |
| <a name='FOREWORD.p3'></a>
 | |
| <pre>3   Attention is drawn to the possibility that some of the elements of this document may be the subject
 | |
|     of patent rights. ISO and IEC shall not be held responsible for identifying any or all such patent
 | |
|     rights. Details of any patent rights identified during the development of the document will be in the
 | |
|     Introduction and/or on the ISO list of patent declarations received (see www.iso.org/patents).
 | |
| </pre>
 | |
| <a name='FOREWORD.p4'></a>
 | |
| <pre>4   Any trade name used in this document is information given for the convenience of users and does
 | |
|     not constitute an endorsement.
 | |
| </pre>
 | |
| <a name='FOREWORD.p5'></a>
 | |
| <pre>5   For an explanation of the voluntary nature of standards, the meaning of ISO specific terms and
 | |
|     expressions related to conformity assessment, as well as information about ISO’s adherence to
 | |
|     the World Trade Organization (WTO) principles in the Technical Barriers to Trade (TBT), see the
 | |
|     following URL: www.iso.org/iso/foreword.html.
 | |
| </pre>
 | |
| <a name='FOREWORD.p6'></a>
 | |
| <pre>6   This document was prepared by Technical Committee ISO/IEC JTC 1, Information technology, Sub-
 | |
|     committee SC 22, Programming languages, their environments and system software interfaces.
 | |
| </pre>
 | |
| <a name='FOREWORD.p7'></a>
 | |
| <pre>7   This fifth edition cancels and replaces the fourth edition, ISO/IEC 9899:2018. A complete change
 | |
|     history can be found in Annex M.
 | |
| </pre>
 | |
| <a name='INTRO.'></a>
 | |
| <hr>
 | |
| <h3>INTRO. [Introduction]</h3>
 | |
| <a name='INTRO.p1'></a>
 | |
| <pre>1   With the introduction of new devices and extended character sets, new features could be added to
 | |
|     this document. Subclauses in the language and library clauses warn implementors and programmers
 | |
|     of usages which, though valid in themselves, could conflict with future additions.
 | |
| </pre>
 | |
| <a name='INTRO.p2'></a>
 | |
| <pre>2   Certain features are obsolescent, which means that they could be considered for withdrawal in future
 | |
|     revisions of this document. They are retained because of their widespread use, but their use in
 | |
|     new implementations (for implementation features) or new programs (for language [<a href='#6.11'>6.11</a>] or library
 | |
|     features [<a href='#7.33'>7.33</a>]) is discouraged.
 | |
| </pre>
 | |
| <a name='INTRO.p3'></a>
 | |
| <pre>3   This document is divided into four major subdivisions:
 | |
| 
 | |
|       — preliminary elements (Clauses 1–4);
 | |
|       — the characteristics of environments that translate and execute C programs (Clause 5);
 | |
|       — the language syntax, constraints, and semantics (Clause 6);
 | |
| 
 | |
|       — the library facilities (Clause 7).
 | |
| 
 | |
| </pre>
 | |
| <a name='INTRO.p4'></a>
 | |
| <pre>4   Examples are provided to illustrate possible forms of the constructions described. Footnotes are
 | |
|     provided to emphasize consequences of the rules described in that subclause or elsewhere in this
 | |
|     document. References are used to refer to other related subclauses. Recommendations are provided
 | |
|     to give advice or guidance to implementors. Annexes define optional features, provide additional
 | |
|     information and summarize the information contained in this document. A bibliography lists
 | |
|     documents that were referred to during the preparation of this document.
 | |
| </pre>
 | |
| <a name='INTRO.p5'></a>
 | |
| <pre>5   The language clause (Clause 6) is derived from "The C Reference Manual".
 | |
| </pre>
 | |
| <a name='INTRO.p6'></a>
 | |
| <pre>6   The library clause (Clause 7) is based on the 1984 /usr/group Standard.
 | |
| </pre>
 | |
| <a name='INTRO.p7'></a>
 | |
| <pre>7   The Working Group responsible for this document (WG 14) maintains a site on the World Wide Web
 | |
|     at http://www.open-std.org/JTC1/SC22/WG14/ containing ancillary information that may be of
 | |
|     interest to some readers such as a Rationale for many of the decisions made during its preparation
 | |
|     and a log of Defect Reports and Responses.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='1.'></a>
 | |
| <hr>
 | |
| <h3>1. [Scope]</h3>
 | |
| <a name='1.p1'></a>
 | |
| <pre>1   This document specifies the form and establishes the interpretation of programs written in the C
 | |
|     programming language.<a href='#FOOTNOTE.1'><sup>[1]</sup></a> It specifies
 | |
| 
 | |
|       — the representation of C programs;
 | |
|       — the syntax and constraints of the C language;
 | |
|       — the semantic rules for interpreting C programs;
 | |
| 
 | |
|       — the representation of input data to be processed by C programs;
 | |
|       — the representation of output data produced by C programs;
 | |
|       — the restrictions and limits imposed by a conforming implementation of C.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.1'>
 | |
| <pre><i><b>Footnote 1)</b> This document is designed to promote the portability of C programs among a variety of data-processing systems. It is
 | |
|     intended for use by implementors and programmers. Annex J gives an overview of portability issues that a C program might
 | |
|     encounter.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='1.p2'></a>
 | |
| <pre>2   This document does not specify
 | |
| 
 | |
|       — the mechanism by which C programs are transformed for use by a data-processing system;
 | |
| 
 | |
|       — the mechanism by which C programs are invoked for use by a data-processing system;
 | |
|       — the mechanism by which input data are transformed for use by a C program;
 | |
|       — the mechanism by which output data are transformed after being produced by a C program;
 | |
|       — the size or complexity of a program and its data that will exceed the capacity of any specific
 | |
|         data-processing system or the capacity of a particular processor;
 | |
|       — all minimal requirements of a data-processing system that is capable of supporting a conform-
 | |
|         ing implementation.
 | |
| </pre>
 | |
| <a name='2.'></a>
 | |
| <hr>
 | |
| <h3>2. [Normative references]</h3>
 | |
| <a name='2.p1'></a>
 | |
| <pre>1   The following documents are referred to in the text in such a way that some or all of their content
 | |
|     constitutes requirements of this document. For dated references, only the edition cited applies.
 | |
|     For undated references, the latest edition of the referenced document (including any amendments)
 | |
|     applies.
 | |
| </pre>
 | |
| <a name='2.p2'></a>
 | |
| <pre>2   ISO/IEC 2382:2015, Information technology — Vocabulary. Available from the ISO online browsing
 | |
|     platform at http://www.iso.org/obp.
 | |
| </pre>
 | |
| <a name='2.p3'></a>
 | |
| <pre>3   ISO 4217, Codes for the representation of currencies and funds.
 | |
| </pre>
 | |
| <a name='2.p4'></a>
 | |
| <pre>4   ISO 8601, Data elements and interchange formats — Information interchange — Representation of dates and
 | |
|     times.
 | |
| </pre>
 | |
| <a name='2.p5'></a>
 | |
| <pre>5   ISO/IEC 10646, Information technology —Universal Coded Character Set (UCS). Available from the
 | |
|     ISO/IEC Information Technology Task Force (ITTF) web site at http://isotc.iso.org/livelink/
 | |
|     livelink/fetch/2000/2489/Ittf_Home/PubliclyAvailableStandards.htm.
 | |
| </pre>
 | |
| <a name='2.p6'></a>
 | |
| <pre>6   ISO/IEC 60559:2020, Floating-point arithmetic.
 | |
| </pre>
 | |
| <a name='2.p7'></a>
 | |
| <pre>7   ISO 80000–2, Quantities and units — Part 2: Mathematical signs and symbols to be used in the natural
 | |
|     sciences and technology.
 | |
| </pre>
 | |
| <a name='2.p8'></a>
 | |
| <pre>8   The Unicode Consortium. Unicode Standard Annex, UAX #44, Unicode Character Database [online].
 | |
|     Edited by Ken Whistler and Laurentiu Iancu. Available at http://www.unicode.org/reports/
 | |
|     tr44.
 | |
| </pre>
 | |
| <a name='2.p9'></a>
 | |
| <pre>9   The Unicode Consortium. The Unicode Standard, Derived Core Properties. Available at https:
 | |
|     //www.unicode.org/Public/UCD/latest/ucd/DerivedCoreProperties.txt.
 | |
| </pre>
 | |
| <a name='3.'></a>
 | |
| <hr>
 | |
| <h3>3. [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.p1'></a>
 | |
| <pre>1   For the purposes of this document, the terms and definitions given in ISO/IEC 2382, ISO 80000–2,
 | |
|     and the following apply.
 | |
| </pre>
 | |
| <a name='3.p2'></a>
 | |
| <pre>2   ISO and IEC maintain terminological databases for use in standardization at the following addresses:
 | |
| 
 | |
|       — ISO Online browsing platform: available at https://www.iso.org/obp
 | |
| 
 | |
|       — IEC Electropedia: available at http://www.electropedia.org/
 | |
| 
 | |
| </pre>
 | |
| <a name='3.p3'></a>
 | |
| <pre>3   Additional terms are defined where they appear in italic type or on the left side of a syntax rule.
 | |
|     Terms explicitly defined in this document are not to be presumed to refer implicitly to similar terms
 | |
|     defined elsewhere.
 | |
| 
 | |
| </pre>
 | |
| <a name='3.1'></a>
 | |
| <hr>
 | |
| <h3>3.1 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.1p1'></a>
 | |
| <pre>1   access (verb)
 | |
|     ⟨execution-time action⟩ to read or modify the value of an object
 | |
| </pre>
 | |
| <a name='3.1p2'></a>
 | |
| <pre>2   Note 1 to entry: Where only one of these two actions is meant, "read" or "modify" is used.
 | |
| </pre>
 | |
| <a name='3.1p3'></a>
 | |
| <pre>3   Note 2 to entry: "Modify" includes the case where the new value being stored is the same as the previous value.
 | |
| </pre>
 | |
| <a name='3.1p4'></a>
 | |
| <pre>4   Note 3 to entry: Expressions that are not evaluated do not access objects.
 | |
| 
 | |
| </pre>
 | |
| <a name='3.2'></a>
 | |
| <hr>
 | |
| <h3>3.2 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.2p1'></a>
 | |
| <pre>1   alignment
 | |
|     requirement that objects of a particular type be located on storage boundaries with addresses that
 | |
|     are particular multiples of a byte address
 | |
| 
 | |
| </pre>
 | |
| <a name='3.3'></a>
 | |
| <hr>
 | |
| <h3>3.3 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.3p1'></a>
 | |
| <pre>1   argument
 | |
|     actual argument (DEPRECATED: actual parameter)
 | |
|     expression in the comma-separated list bounded by the parentheses in a function call expression, or
 | |
|     a sequence of preprocessing tokens in the comma-separated list bounded by the parentheses in a
 | |
|     function-like macro invocation
 | |
| 
 | |
| </pre>
 | |
| <a name='3.4'></a>
 | |
| <hr>
 | |
| <h3>3.4 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.4p1'></a>
 | |
| <pre>1   behavior
 | |
|     external appearance or action
 | |
| 
 | |
| </pre>
 | |
| <a name='3.4.1'></a>
 | |
| <hr>
 | |
| <h3>3.4.1 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.4.1p1'></a>
 | |
| <pre>1   implementation-defined behavior
 | |
|     unspecified behavior where each implementation documents how the choice is made
 | |
| </pre>
 | |
| <a name='3.4.1p2'></a>
 | |
| <pre>2   Note 1 to entry: <a href='#J.3'>J.3</a> gives an overview over properties of C programs that lead to implementation-defined behavior.
 | |
| </pre>
 | |
| <a name='3.4.1p3'></a>
 | |
| <pre>3   EXAMPLE An example of implementation-defined behavior is the propagation of the high-order bit when a signed integer
 | |
|     is shifted right.
 | |
| 
 | |
| </pre>
 | |
| <a name='3.4.2'></a>
 | |
| <hr>
 | |
| <h3>3.4.2 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.4.2p1'></a>
 | |
| <pre>1   locale-specific behavior
 | |
|     behavior that depends on local conventions of nationality, culture, and language that each implemen-
 | |
|     tation documents
 | |
| </pre>
 | |
| <a name='3.4.2p2'></a>
 | |
| <pre>2   Note 1 to entry: <a href='#J.4'>J.4</a> gives an overview over properties of C programs that lead to locale-specific behavior.
 | |
| </pre>
 | |
| <a name='3.4.2p3'></a>
 | |
| <pre>3   EXAMPLE An example of locale-specific behavior is whether the islower function returns true for characters other than
 | |
|     the 26 lowercase Latin letters.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.4.3'></a>
 | |
| <hr>
 | |
| <h3>3.4.3 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.4.3p1'></a>
 | |
| <pre>1   undefined behavior
 | |
|     behavior, upon use of a nonportable or erroneous program construct or of erroneous data, for which
 | |
|     this document imposes no requirements
 | |
| </pre>
 | |
| <a name='3.4.3p2'></a>
 | |
| <pre>2   Note 1 to entry: Possible undefined behavior ranges from ignoring the situation completely with unpredictable results,
 | |
|     to behaving during translation or program execution in a documented manner characteristic of the environment (with or
 | |
|     without the issuance of a diagnostic message), to terminating a translation or execution (with the issuance of a diagnostic
 | |
|     message).
 | |
| </pre>
 | |
| <a name='3.4.3p3'></a>
 | |
| <pre>3   Note 2 to entry: <a href='#J.2'>J.2</a> gives an overview over properties of C programs that lead to undefined behavior.
 | |
| </pre>
 | |
| <a name='3.4.3p4'></a>
 | |
| <pre>4   EXAMPLE An example of undefined behavior is the behavior on dereferencing a null pointer.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.4.4'></a>
 | |
| <hr>
 | |
| <h3>3.4.4 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.4.4p1'></a>
 | |
| <pre>1   unspecified behavior
 | |
|     behavior, that results from the use of an unspecified value, or other behavior upon which this
 | |
|     document provides two or more possibilities and imposes no further requirements on which is
 | |
|     chosen in any instance
 | |
| </pre>
 | |
| <a name='3.4.4p2'></a>
 | |
| <pre>2   Note 1 to entry: <a href='#J.1'>J.1</a> gives an overview over properties of C programs that lead to unspecified behavior.
 | |
| </pre>
 | |
| <a name='3.4.4p3'></a>
 | |
| <pre>3   EXAMPLE An example of unspecified behavior is the order in which the arguments to a function are evaluated.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.5'></a>
 | |
| <hr>
 | |
| <h3>3.5 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.5p1'></a>
 | |
| <pre>1   bit
 | |
|     unit of data storage in the execution environment large enough to hold an object that can have one
 | |
|     of two values
 | |
| </pre>
 | |
| <a name='3.5p2'></a>
 | |
| <pre>2   Note 1 to entry: It need not be possible to express the address of each individual bit of an object.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.6'></a>
 | |
| <hr>
 | |
| <h3>3.6 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.6p1'></a>
 | |
| <pre>1   byte
 | |
|     addressable unit of data storage large enough to hold any member of the basic character set of the
 | |
|     execution environment
 | |
| </pre>
 | |
| <a name='3.6p2'></a>
 | |
| <pre>2   Note 1 to entry: It is possible to express the address of each individual byte of an object uniquely.
 | |
| </pre>
 | |
| <a name='3.6p3'></a>
 | |
| <pre>3   Note 2 to entry: A byte is composed of a contiguous sequence of bits, the number of which is implementation-defined. The
 | |
|     least significant bit is called the low-order bit; the most significant bit is called the high-order bit.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.7'></a>
 | |
| <hr>
 | |
| <h3>3.7 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.7p1'></a>
 | |
| <pre>1   character
 | |
|     ⟨abstract⟩ member of a set of elements used for the organization, control, or representation of data
 | |
| 
 | |
| </pre>
 | |
| <a name='3.7.1'></a>
 | |
| <hr>
 | |
| <h3>3.7.1 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.7.1p1'></a>
 | |
| <pre>1   character
 | |
|     single-byte character
 | |
|     ⟨C⟩ bit representation that fits in a byte
 | |
| 
 | |
| </pre>
 | |
| <a name='3.7.2'></a>
 | |
| <hr>
 | |
| <h3>3.7.2 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.7.2p1'></a>
 | |
| <pre>1   multibyte character
 | |
|     sequence of one or more bytes representing a member of the extended character set of either the
 | |
|     source or the execution environment
 | |
| </pre>
 | |
| <a name='3.7.2p2'></a>
 | |
| <pre>2   Note 1 to entry: The extended character set is a superset of the basic character set.
 | |
| </pre>
 | |
| <a name='3.7.3'></a>
 | |
| <hr>
 | |
| <h3>3.7.3 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.7.3p1'></a>
 | |
| <pre>1   wide character
 | |
|     value representable by an object of type wchar_t, capable of representing any character in the
 | |
|     current locale
 | |
| 
 | |
| </pre>
 | |
| <a name='3.8'></a>
 | |
| <hr>
 | |
| <h3>3.8 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.8p1'></a>
 | |
| <pre>1   constraint
 | |
|     restriction, either syntactic or semantic, by which the exposition of language elements is to be
 | |
|     interpreted
 | |
| 
 | |
| </pre>
 | |
| <a name='3.9'></a>
 | |
| <hr>
 | |
| <h3>3.9 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.9p1'></a>
 | |
| <pre>1   correctly rounded result
 | |
|     representation in the result format that is nearest in value, subject to the current rounding mode, to
 | |
|     what the result would be given unlimited range and precision
 | |
| </pre>
 | |
| <a name='3.9p2'></a>
 | |
| <pre>2   Note 1 to entry: In this document, when the words "correctly rounded" are not immediately followed by "result", this is the
 | |
|     intended usage.
 | |
| </pre>
 | |
| <a name='3.9p3'></a>
 | |
| <pre>3   Note 2 to entry: IEC 60559 or implementation-defined rules apply for extreme magnitude results if the result format contains
 | |
|     infinity.
 | |
| 
 | |
| </pre>
 | |
| <a name='3.10'></a>
 | |
| <hr>
 | |
| <h3>3.10 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.10p1'></a>
 | |
| <pre>1   diagnostic message
 | |
|     message belonging to an implementation-defined subset of the implementation’s message output
 | |
| 
 | |
| </pre>
 | |
| <a name='3.11'></a>
 | |
| <hr>
 | |
| <h3>3.11 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.11p1'></a>
 | |
| <pre>1   forward reference
 | |
|     reference to a later subclause of this document that contains additional information relevant to this
 | |
|     subclause
 | |
| 
 | |
| </pre>
 | |
| <a name='3.12'></a>
 | |
| <hr>
 | |
| <h3>3.12 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.12p1'></a>
 | |
| <pre>1   implementation
 | |
|     particular set of software, running in a particular translation environment under particular con-
 | |
|     trol options, that performs translation of programs for, and supports execution of functions in, a
 | |
|     particular execution environment
 | |
| 
 | |
| </pre>
 | |
| <a name='3.13'></a>
 | |
| <hr>
 | |
| <h3>3.13 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.13p1'></a>
 | |
| <pre>1   implementation limit
 | |
|     restriction imposed upon programs by the implementation
 | |
| 
 | |
| </pre>
 | |
| <a name='3.14'></a>
 | |
| <hr>
 | |
| <h3>3.14 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.14p1'></a>
 | |
| <pre>1   memory location
 | |
|     either an object of scalar type, or a maximal sequence of adjacent bit-fields all having nonzero width
 | |
| </pre>
 | |
| <a name='3.14p2'></a>
 | |
| <pre>2   Note 1 to entry: Two threads of execution can update and access separate memory locations without interfering with each
 | |
|     other.
 | |
| </pre>
 | |
| <a name='3.14p3'></a>
 | |
| <pre>3   Note 2 to entry: A bit-field and an adjacent non-bit-field member are in separate memory locations. The same applies to
 | |
|     two bit-fields, if one is declared inside a nested structure declaration and the other is not, or if the two are separated by a
 | |
|     zero-length bit-field declaration, or if they are separated by a non-bit-field member declaration. It is not safe to concurrently
 | |
|     update two non-atomic bit-fields in the same structure if all members declared between them are also (nonzero-length)
 | |
|     bit-fields, no matter what the sizes of those intervening bit-fields happen to be.
 | |
| </pre>
 | |
| <a name='3.14p4'></a>
 | |
| <pre>4   EXAMPLE A structure declared as
 | |
| 
 | |
|               struct {
 | |
|                     char a;
 | |
|                     int b:5, c:11,:0, d:8;
 | |
|                        struct { int ee:8; } e;
 | |
|               }
 | |
| 
 | |
| 
 | |
|     contains four separate memory locations: The member a, and bit-fields d and e.ee are each separate memory locations,
 | |
|     and can be modified concurrently without interfering with each other. The bit-fields b and c together constitute the fourth
 | |
|     memory location. The bit-fields b and c cannot be concurrently modified, but b and a, for example, can be.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.15'></a>
 | |
| <hr>
 | |
| <h3>3.15 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.15p1'></a>
 | |
| <pre>1   object
 | |
|     region of data storage in the execution environment, the contents of which can represent values
 | |
| </pre>
 | |
| <a name='3.15p2'></a>
 | |
| <pre>2   Note 1 to entry: When referenced, an object can be interpreted as having a particular type; see <a href='#6.3.2.1'>6.3.2.1</a>.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.16'></a>
 | |
| <hr>
 | |
| <h3>3.16 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.16p1'></a>
 | |
| <pre>1   parameter
 | |
|     formal parameter
 | |
|     DEPRECATED: formal argument
 | |
|     object declared as part of a function declaration or definition that acquires a value on entry to the
 | |
|     function, or an identifier from the comma-separated list bounded by the parentheses immediately
 | |
|     following the macro name in a function-like macro definition
 | |
| 
 | |
| </pre>
 | |
| <a name='3.17'></a>
 | |
| <hr>
 | |
| <h3>3.17 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.17p1'></a>
 | |
| <pre>1   recommended practice
 | |
|     specification that is strongly recommended as being in keeping with the intent of the standard, but
 | |
|     that might be impractical for some implementations
 | |
| 
 | |
| </pre>
 | |
| <a name='3.18'></a>
 | |
| <hr>
 | |
| <h3>3.18 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.18p1'></a>
 | |
| <pre>1   runtime-constraint
 | |
|     requirement on a program when calling a library function
 | |
| </pre>
 | |
| <a name='3.18p2'></a>
 | |
| <pre>2   Note 1 to entry: Despite the similar terms, a runtime-constraint is not a kind of constraint as defined by <a href='#3.8'>3.8</a>, and need not be
 | |
|     diagnosed at translation time.
 | |
| </pre>
 | |
| <a name='3.18p3'></a>
 | |
| <pre>3   Note 2 to entry: Implementations that support the extensions in Annex K are required to verify that the runtime-constraints
 | |
|     for a library function are not violated by the program; see <a href='#K.3.1.4'>K.3.1.4</a>.
 | |
| </pre>
 | |
| <a name='3.18p4'></a>
 | |
| <pre>4   Note 3 to entry: Implementations that support Annex L are permitted to invoke a runtime-constraint handler when they
 | |
|     perform a trap.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='3.19'></a>
 | |
| <hr>
 | |
| <h3>3.19 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.19p1'></a>
 | |
| <pre>1   value
 | |
|     precise meaning of the contents of an object when interpreted as having a specific type
 | |
| 
 | |
| </pre>
 | |
| <a name='3.19.1'></a>
 | |
| <hr>
 | |
| <h3>3.19.1 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.19.1p1'></a>
 | |
| <pre>1   implementation-defined value
 | |
|     unspecified value where each implementation documents how the choice is made
 | |
| 
 | |
| </pre>
 | |
| <a name='3.19.2'></a>
 | |
| <hr>
 | |
| <h3>3.19.2 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.19.2p1'></a>
 | |
| <pre>1   indeterminate representation
 | |
|     object representation that either represents an unspecified value or is a non-value representation
 | |
| 
 | |
| </pre>
 | |
| <a name='3.19.3'></a>
 | |
| <hr>
 | |
| <h3>3.19.3 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.19.3p1'></a>
 | |
| <pre>1   unspecified value
 | |
|     valid value of the relevant type where this document imposes no requirements on which value is
 | |
|     chosen in any instance
 | |
| </pre>
 | |
| <a name='3.19.4'></a>
 | |
| <hr>
 | |
| <h3>3.19.4 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.19.4p1'></a>
 | |
| <pre>1   non-value representation
 | |
|     an object representation that does not represent a value of the object type
 | |
| 
 | |
| </pre>
 | |
| <a name='3.19.5'></a>
 | |
| <hr>
 | |
| <h3>3.19.5 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.19.5p1'></a>
 | |
| <pre>1   perform a trap
 | |
|     interrupt execution of the program such that no further operations are performed<a href='#FOOTNOTE.2'><sup>[2]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.2'>
 | |
| <pre><i><b>Footnote 2)</b> Note that fetching a non-value representation might perform a trap but is not required to (see <a href='#6.2.6.1'>6.2.6.1</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='3.19.5p2'></a>
 | |
| <pre>2   Note 1 to entry: Implementations that support Annex L are permitted to invoke a runtime-constraint handler when they
 | |
|     perform a trap.
 | |
| 
 | |
| </pre>
 | |
| <a name='3.20'></a>
 | |
| <hr>
 | |
| <h3>3.20 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.20p1'></a>
 | |
| <pre>1   ⌈x⌉
 | |
|     ceiling of x
 | |
|     the least integer greater than or equal to x
 | |
| </pre>
 | |
| <a name='3.20p2'></a>
 | |
| <pre>2   EXAMPLE ⌈2.4⌉ is 3, ⌈−2.4⌉ is −2.
 | |
| 
 | |
| </pre>
 | |
| <a name='3.21'></a>
 | |
| <hr>
 | |
| <h3>3.21 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.21p1'></a>
 | |
| <pre>1   ⌊x⌋
 | |
|     floor of x
 | |
|     the greatest integer less than or equal to x
 | |
| </pre>
 | |
| <a name='3.21p2'></a>
 | |
| <pre>2   EXAMPLE ⌊2.4⌋ is 2, ⌊−2.4⌋ is −3.
 | |
| 
 | |
| </pre>
 | |
| <a name='3.22'></a>
 | |
| <hr>
 | |
| <h3>3.22 [Terms, definitions, and symbols]</h3>
 | |
| <a name='3.22p1'></a>
 | |
| <pre>1   wraparound
 | |
|     the process by which a value is reduced modulo 2N , where N is the width of the resulting type
 | |
| </pre>
 | |
| <a name='4.'></a>
 | |
| <hr>
 | |
| <h3>4. [Conformance]</h3>
 | |
| <a name='4.p1'></a>
 | |
| <pre>1   In this document, "shall" is to be interpreted as a requirement on an implementation or on a program;
 | |
|     conversely, "shall not" is to be interpreted as a prohibition.
 | |
| </pre>
 | |
| <a name='4.p2'></a>
 | |
| <pre>2   If a "shall" or "shall not" requirement that appears outside of a constraint or runtime-constraint is
 | |
|     violated, the behavior is undefined. Undefined behavior is otherwise indicated in this document by
 | |
|     the words "undefined behavior" or by the omission of any explicit definition of behavior. There is
 | |
|     no difference in emphasis among these three; they all describe "behavior that is undefined".
 | |
| </pre>
 | |
| <a name='4.p3'></a>
 | |
| <pre>3   A program that is correct in all other aspects, operating on correct data, containing unspecified
 | |
|     behavior shall be a correct program and act in accordance with <a href='#5.1.2.3'>5.1.2.3</a>.
 | |
| </pre>
 | |
| <a name='4.p4'></a>
 | |
| <pre>4   The implementation shall not successfully translate a preprocessing translation unit containing a
 | |
|     #error preprocessing directive unless it is part of a group skipped by conditional inclusion.
 | |
| </pre>
 | |
| <a name='4.p5'></a>
 | |
| <pre>5   A strictly conforming program shall use only those features of the language and library specified
 | |
|     in this document.<a href='#FOOTNOTE.3'><sup>[3]</sup></a> It shall not produce output dependent on any unspecified, undefined, or
 | |
|     implementation-defined behavior, and shall not exceed any minimum implementation limit.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.3'>
 | |
| <pre><i><b>Footnote 3)</b> A strictly conforming program can use conditional features (see <a href='#6.10.9.3'>6.10.9.3</a>) provided the use is guarded by an appropriate
 | |
|     conditional inclusion preprocessing directive using the related macro. For example:
 | |
|               #ifdef __STDC_IEC_60559_BFP__ /* FE_UPWARD defined */
 | |
|                  /* ... */
 | |
|                  fesetround(FE_UPWARD);
 | |
|                  /* ... */
 | |
|               #endif
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='4.p6'></a>
 | |
| <pre>6   The two forms of conforming implementation are hosted and freestanding. A conforming hosted
 | |
|     implementation shall accept any strictly conforming program. A conforming freestanding implementation
 | |
|     shall accept any strictly conforming program in which the use of the features specified in the library
 | |
|     clause (Clause 7) is confined to the contents of the standard headers <float.h>, <iso646.h>,
 | |
|     <limits.h>, <stdalign.h>, <stdarg.h>, <stdbit.h>, <stdbool.h>, <stddef.h>, <stdint.h>,
 | |
|     and <stdnoreturn.h>. Additionally, a conforming freestanding implementation shall accept any
 | |
|     strictly conforming program where:
 | |
| 
 | |
|       — the features specified in the header <string.h> are used, except the following functions:
 | |
|         strdup, strndup, strcoll, strxfrm, strerror; and/or,
 | |
| 
 | |
|            the selected function memalignment from <stdlib.h> is used.
 | |
| 
 | |
|     A conforming implementation may have extensions (including additional library functions), pro-
 | |
|     vided they do not alter the behavior of any strictly conforming program<a href='#FOOTNOTE.4'><sup>[4]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.4'>
 | |
| <pre><i><b>Footnote 4)</b> This implies that a conforming implementation reserves no identifiers other than those explicitly reserved in this
 | |
|     document.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='4.p7'></a>
 | |
| <pre>7   The strictly conforming programs that shall be accepted by a conforming freestanding implementa-
 | |
|     tion that defines __STDC_IEC_60559_BFP__ or __STDC_IEC_60559_DFP__ may also use features in
 | |
|     the contents of the standard headers <fenv.h>, <math.h>, and the strto * floating-point numeric
 | |
|     conversion functions (<a href='#7.24.1'>7.24.1</a>) of the standard header <stdlib.h>, provided the program does not
 | |
|     set the state of the FENV_ACCESS pragma to "ON".
 | |
|     All identifiers that are reserved when <stdlib.h> is included in a hosted implementation are
 | |
|     reserved when it is included in a freestanding implementation.
 | |
| </pre>
 | |
| <a name='4.p8'></a>
 | |
| <pre>8   A conforming program is one that is acceptable to a conforming implementation. <a href='#FOOTNOTE.5'><sup>[5]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.5'>
 | |
| <pre><i><b>Footnote 5)</b> Strictly conforming programs are intended to be maximally portable among conforming implementations. Conforming
 | |
|     programs can depend upon nonportable features of a conforming implementation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='4.p9'></a>
 | |
| <pre>9   An implementation shall be accompanied by a document that defines all implementation-defined
 | |
|     and locale-specific characteristics and all extensions.
 | |
|     Forward references: conditional inclusion (<a href='#6.10.1'>6.10.1</a>), error directive (<a href='#6.10.6'>6.10.6</a>), characteristics of floating
 | |
|     types <float.h> (<a href='#7.7'>7.7</a>), alternative spellings <iso646.h> (<a href='#7.9'>7.9</a>), sizes of integer types <limits.h>
 | |
|     (<a href='#7.10'>7.10</a>), alignment <stdalign.h> (<a href='#7.15'>7.15</a>), variable arguments <stdarg.h> (<a href='#7.16'>7.16</a>), boolean type and
 | |
|     values <stdbool.h> (<a href='#7.19'>7.19</a>), common definitions <stddef.h> (<a href='#7.21'>7.21</a>), integer types <stdint.h> (<a href='#7.22'>7.22</a>),
 | |
|     <stdnoreturn.h> (<a href='#7.25'>7.25</a>).
 | |
| </pre>
 | |
| <a name='5.'></a>
 | |
| <hr>
 | |
| <h3>5. [Environment]</h3>
 | |
| <a name='5.p1'></a>
 | |
| <pre>1   An implementation translates C source files and executes C programs in two data-processing-system
 | |
|     environments, which will be called the translation environment and the execution environment in this
 | |
|     document. Their characteristics define and constrain the results of executing conforming C programs
 | |
|     constructed according to the syntactic and semantic rules for conforming implementations.
 | |
|     Forward references: In this clause, only a few of many possible forward references have been
 | |
|     noted.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1'></a>
 | |
| <hr>
 | |
| <h3>5.1 [Conceptual models]</h3>
 | |
| <a name='5.1.1'></a>
 | |
| <hr>
 | |
| <h3>5.1.1 [Translation environment]</h3>
 | |
| <a name='5.1.1.1'></a>
 | |
| <hr>
 | |
| <h3>5.1.1.1 [Program structure]</h3>
 | |
| <a name='5.1.1.1p1'></a>
 | |
| <pre>1   A C program need not all be translated at the same time. The text of the program is kept in units
 | |
|     called source files, (or preprocessing files) in this document. A source file together with all the headers
 | |
|     and source files included via the preprocessing directive #include is known as a preprocessing
 | |
|     translation unit. After preprocessing, a preprocessing translation unit is called a translation unit.
 | |
|     Previously translated translation units may be preserved individually or in libraries. The separate
 | |
|     translation units of a program communicate by (for example) calls to functions whose identifiers have
 | |
|     external linkage, manipulation of objects whose identifiers have external linkage, or manipulation
 | |
|     of data files. Translation units may be separately translated and then later linked to produce an
 | |
|     executable program.
 | |
|     Forward references: linkages of identifiers (<a href='#6.2.2'>6.2.2</a>), external definitions (<a href='#6.9'>6.9</a>), preprocessing direc-
 | |
|     tives (<a href='#6.10'>6.10</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.1.2'></a>
 | |
| <hr>
 | |
| <h3>5.1.1.2 [Translation phases]</h3>
 | |
| <a name='5.1.1.2p1'></a>
 | |
| <pre>1   The precedence among the syntax rules of translation is specified by the following phases.<a href='#FOOTNOTE.6'><sup>[6]</sup></a>
 | |
| 
 | |
|        1. Physical source file multibyte characters are mapped, in an implementation-defined manner, to
 | |
|           the source character set (introducing new-line characters for end-of-line indicators) if necessary.
 | |
| 
 | |
|        2. Each instance of a backslash character (\ ) immediately followed by a new-line character is
 | |
|           deleted, splicing physical source lines to form logical source lines. Only the last backslash on
 | |
|           any physical source line shall be eligible for being part of such a splice. A source file that is
 | |
|           not empty shall end in a new-line character, which shall not be immediately preceded by a
 | |
|           backslash character before any such splicing takes place.
 | |
| 
 | |
|        3. The source file is decomposed into preprocessing tokens<a href='#FOOTNOTE.7'><sup>[7]</sup></a> and sequences of white-space
 | |
|           characters (including comments). A source file shall not end in a partial preprocessing token or
 | |
|           in a partial comment. Each comment is replaced by one space character. New-line characters
 | |
|           are retained. Whether each nonempty sequence of white-space characters other than new-line
 | |
|           is retained or replaced by one space character is implementation-defined.
 | |
| 
 | |
|        4. Preprocessing directives are executed, macro invocations are expanded, and _Pragma unary
 | |
|           operator expressions are executed. If a character sequence that matches the syntax of a univer-
 | |
|           sal character name is produced by token concatenation (<a href='#6.10.4.3'>6.10.4.3</a>), the behavior is undefined. A
 | |
|           #include preprocessing directive causes the named header or source file to be processed from
 | |
|           phase 1 through phase 4, recursively. All preprocessing directives are then deleted.
 | |
|        5. Each source character set member and escape sequence in character constants and string
 | |
|           literals is converted to the corresponding member of the execution character set. Each instance
 | |
|           of a source character or escape sequence for which there is no corresponding member is
 | |
|           converted in an implementation-defined manner to some member of the execution character
 | |
|           set other than the null (wide) character.<a href='#FOOTNOTE.8'><sup>[8]</sup></a>
 | |
| 
 | |
|        6. Adjacent string literal tokens are concatenated.
 | |
| 
 | |
|        7. White-space characters separating tokens are no longer significant. Each preprocessing token
 | |
|           is converted into a token. The resulting tokens are syntactically and semantically analyzed
 | |
|           and translated as a translation unit.
 | |
| 
 | |
|        8. All external object and function references are resolved. Library components are linked to
 | |
|           satisfy external references to functions and objects not defined in the current translation. All
 | |
|           such translator output is collected into a program image which contains information needed
 | |
|           for execution in its execution environment.
 | |
| 
 | |
|     Forward references: universal character names (<a href='#6.4.3'>6.4.3</a>), lexical elements (<a href='#6.4'>6.4</a>), preprocessing direc-
 | |
|     tives (<a href='#6.10'>6.10</a>), external definitions (<a href='#6.9'>6.9</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.6'>
 | |
| <pre><i><b>Footnote 6)</b> This requires implementations to behave as if these separate phases occur, even though many are typically folded
 | |
|     together in practice. Source files, translation units, and translated translation units need not necessarily be stored as files,
 | |
|     nor need there be any one-to-one correspondence between these entities and any external representation. The description is
 | |
|     conceptual only, and does not specify any particular implementation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.7'>
 | |
| <pre><i><b>Footnote 7)</b> As described in <a href='#6.4'>6.4</a>, the process of dividing a source file’s characters into preprocessing tokens is context-dependent. For
 | |
|     example, see the handling of < within a #include preprocessing directive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.8'>
 | |
| <pre><i><b>Footnote 8)</b> An implementation may convert each instance of the same non-corresponding source character to a different member of
 | |
|     the execution character set.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.1.3'></a>
 | |
| <hr>
 | |
| <h3>5.1.1.3 [Diagnostics]</h3>
 | |
| <a name='5.1.1.3p1'></a>
 | |
| <pre>1   A conforming implementation shall produce at least one diagnostic message (identified in an
 | |
|     implementation-defined manner) if a preprocessing translation unit or translation unit contains a
 | |
|     violation of any syntax rule or constraint, even if the behavior is also explicitly specified as undefined
 | |
|     or implementation-defined. Diagnostic messages need not be produced in other circumstances.<a href='#FOOTNOTE.9'><sup>[9]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.9'>
 | |
| <pre><i><b>Footnote 9)</b> An implementation is encouraged to identify the nature of, and where possible localize, each violation. Of course, an
 | |
|     implementation is free to produce any number of diagnostic messages, often referred to as warnings, as long as a valid
 | |
|     program is still correctly translated. It can also successfully translate an invalid program. Annex I lists a few of the more
 | |
|     common warnings.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.1.3p2'></a>
 | |
| <pre>2   EXAMPLE An implementation is required to issue a diagnostic for the translation unit:
 | |
| 
 | |
|               char i;
 | |
|               int i;
 | |
| 
 | |
| 
 | |
|     because in those cases where wording in this document describes the behavior for a construct as being both a constraint error
 | |
|     and resulting in undefined behavior, the constraint error is still required to be diagnosed.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2'></a>
 | |
| <hr>
 | |
| <h3>5.1.2 [Execution environments]</h3>
 | |
| <a name='5.1.2p1'></a>
 | |
| <pre>1   Two execution environments are defined: freestanding and hosted. In both cases, program startup
 | |
|     occurs when a designated C function is called by the execution environment. All objects with static
 | |
|     storage duration shall be initialized (set to their initial values) before program startup. The manner
 | |
|     and timing of such initialization are otherwise unspecified. Program termination returns control to
 | |
|     the execution environment.
 | |
|     Forward references: storage durations of objects (<a href='#6.2.4'>6.2.4</a>), initialization (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.1'></a>
 | |
| <hr>
 | |
| <h3>5.1.2.1 [Freestanding environment]</h3>
 | |
| <a name='5.1.2.1p1'></a>
 | |
| <pre>1   In a freestanding environment (in which C program execution may take place without any ben-
 | |
|     efit of an operating system), the name and type of the function called at program startup are
 | |
|     implementation-defined. Any library facilities available to a freestanding program, other than the
 | |
|     minimal set required by Clause 4, are implementation-defined.
 | |
| </pre>
 | |
| <a name='5.1.2.1p2'></a>
 | |
| <pre>2   The effect of program termination in a freestanding environment is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.2'></a>
 | |
| <hr>
 | |
| <h3>5.1.2.2 [Hosted environment]</h3>
 | |
| <a name='5.1.2.2p1'></a>
 | |
| <pre>1   A hosted environment need not be provided, but shall conform to the following specifications if
 | |
|     present.
 | |
| </pre>
 | |
| <a name='5.1.2.2.1'></a>
 | |
| <hr>
 | |
| <h3>5.1.2.2.1 [Program startup]</h3>
 | |
| <a name='5.1.2.2.1p1'></a>
 | |
| <pre>1   The function called at program startup is named main. The implementation declares no prototype
 | |
|     for this function. It shall be defined with a return type of int and with no parameters:
 | |
| 
 | |
|               int main(void) { /* ... */ }
 | |
| 
 | |
| 
 | |
|     or with two parameters (referred to here as argc and argv, though any names may be used, as they
 | |
|     are local to the function in which they are declared):
 | |
| 
 | |
|               int main(int argc, char *argv[]) { /* ... */ }
 | |
| 
 | |
| 
 | |
|     or equivalent<a href='#FOOTNOTE.10'><sup>[10]</sup></a> ; or in some other implementation-defined manner.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.10'>
 | |
| <pre><i><b>Footnote 10)</b> Thus, int can be replaced by a typedef name defined as int, or the type of argv can be written as char
 | |
|                                                                                                                    ** argv, and so
 | |
|     on.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.2.2.1p2'></a>
 | |
| <pre>2   If they are declared, the parameters to the main function shall obey the following constraints:
 | |
| 
 | |
|       — The value of argc shall be nonnegative.
 | |
| 
 | |
|       — argv[argc] shall be a null pointer.
 | |
| 
 | |
|       — If the value of argc is greater than zero, the array members argv[0] through argv[argc-1]
 | |
|         inclusive shall contain pointers to strings, which are given implementation-defined values
 | |
|         by the host environment prior to program startup. The intent is to supply to the program
 | |
|         information determined prior to program startup from elsewhere in the hosted environment.
 | |
|         If the host environment is not capable of supplying strings with letters in both uppercase and
 | |
|         lowercase, the implementation shall ensure that the strings are received in lowercase.
 | |
| 
 | |
|       — If the value of argc is greater than zero, the string pointed to by argv[0] represents the
 | |
|         program name; argv[0][0] shall be the null character if the program name is not available
 | |
|         from the host environment. If the value of argc is greater than one, the strings pointed to by
 | |
|         argv[1] through argv[argc-1] represent the program parameters.
 | |
| 
 | |
|       — The parameters argc and argv and the strings pointed to by the argv array shall be modifiable
 | |
|         by the program, and retain their last-stored values between program startup and program
 | |
|         termination.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.2.2'></a>
 | |
| <hr>
 | |
| <h3>5.1.2.2.2 [Program execution]</h3>
 | |
| <a name='5.1.2.2.2p1'></a>
 | |
| <pre>1   In a hosted environment, a program may use all the functions, macros, type definitions, and objects
 | |
|     described in the library clause (Clause 7).
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.2.3'></a>
 | |
| <hr>
 | |
| <h3>5.1.2.2.3 [Program termination]</h3>
 | |
| <a name='5.1.2.2.3p1'></a>
 | |
| <pre>1   If the return type of the main function is a type compatible with int, a return from the initial call
 | |
|     to the main function is equivalent to calling the exit function with the value returned by the main
 | |
|     function as its argument;<a href='#FOOTNOTE.11'><sup>[11]</sup></a> reaching the } that terminates the main function returns a value of 0. If
 | |
|     the return type is not compatible with int, the termination status returned to the host environment
 | |
|     is unspecified.
 | |
|     Forward references: definition of terms (<a href='#7.1.1'>7.1.1</a>), the exit function (<a href='#7.24.4.4'>7.24.4.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.11'>
 | |
| <pre><i><b>Footnote 11)</b> In accordance with <a href='#6.2.4'>6.2.4</a>, the lifetimes of objects with automatic storage duration declared in main will have ended in the
 | |
|     former case, even where they would not have in the latter.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.2.3'></a>
 | |
| <hr>
 | |
| <h3>5.1.2.3 [Program execution]</h3>
 | |
| <a name='5.1.2.3p1'></a>
 | |
| <pre>1   The semantic descriptions in this document describe the behavior of an abstract machine in which
 | |
|     issues of optimization are irrelevant.
 | |
| </pre>
 | |
| <a name='5.1.2.3p2'></a>
 | |
| <pre>2   An access to an object through the use of an lvalue of volatile-qualified type is a volatile access. A
 | |
|     volatile access to an object, modifying an object, modifying a file, or calling a function that does any
 | |
|         of those operations are all side effects<a href='#FOOTNOTE.12'><sup>[12]</sup></a> , which are changes in the state of the execution environment.
 | |
|         Evaluation of an expression in general includes both value computations and initiation of side effects.
 | |
|         Value computation for an lvalue expression includes determining the identity of the designated
 | |
|         object.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.12'>
 | |
| <pre><i><b>Footnote 12)</b> The IEC 60559 standard for binary floating-point arithmetic requires certain user-accessible status flags and control
 | |
|     modes. Floating-point operations implicitly set the status flags; modes affect result values of floating-point operations.
 | |
|     Implementations that support such floating-point state are required to regard changes to it as side effects — see Annex F for
 | |
|     details. The floating-point environment library <fenv.h> provides a programming facility for indicating when these side
 | |
|     effects matter, freeing the implementations in other cases.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.2.3p3'></a>
 | |
| <pre>3       Sequenced before is an asymmetric, transitive, pair-wise relation between evaluations executed by a
 | |
|         single thread, which induces a partial order among those evaluations. Given any two evaluations
 | |
|         A and B, if A is sequenced before B, then the execution of A shall precede the execution of B.
 | |
|         (Conversely, if A is sequenced before B, then B is sequenced after A.) If A is not sequenced before or
 | |
|         after B, then A and B are unsequenced. Evaluations A and B are indeterminately sequenced when A is
 | |
|         sequenced either before or after B, but it is unspecified which.<a href='#FOOTNOTE.13'><sup>[13]</sup></a> The presence of a sequence point
 | |
|         between the evaluation of expressions A and B implies that every value computation and side effect
 | |
|         associated with A is sequenced before every value computation and side effect associated with B. (A
 | |
|         summary of the sequence points is given in Annex C.)
 | |
| </pre>
 | |
| <a name='FOOTNOTE.13'>
 | |
| <pre><i><b>Footnote 13)</b> The executions of unsequenced evaluations can interleave. Indeterminately sequenced evaluations cannot interleave, but
 | |
|         can be executed in any order.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.2.3p4'></a>
 | |
| <pre>4       In the abstract machine, all expressions are evaluated as specified by the semantics. An actual
 | |
|         implementation need not evaluate part of an expression if it can deduce that its value is not used
 | |
|         and that no needed side effects are produced (including any caused by calling a function or through
 | |
|         volatile access to an object).
 | |
| </pre>
 | |
| <a name='5.1.2.3p5'></a>
 | |
| <pre>5       When the processing of the abstract machine is interrupted by receipt of a signal, the values of objects
 | |
|         that are neither lock-free atomic objects nor of type volatile sig_atomic_t are unspecified, as is
 | |
|         the state of the dynamic floating-point environment. The representation of any object modified by
 | |
|         the handler that is neither a lock-free atomic object nor of type volatile sig_atomic_t becomes
 | |
|         indeterminate when the handler exits, as does the state of the dynamic floating-point environment if
 | |
|         it is modified by the handler and not restored to its original state.
 | |
| </pre>
 | |
| <a name='5.1.2.3p6'></a>
 | |
| <pre>6       The least requirements on a conforming implementation are:
 | |
| 
 | |
|            — Volatile accesses to objects are evaluated strictly according to the rules of the abstract machine.
 | |
|            — At program termination, all data written into files shall be identical to the result that execution
 | |
|              of the program according to the abstract semantics would have produced.
 | |
|            — The input and output dynamics of interactive devices shall take place as specified in <a href='#7.23.3'>7.23.3</a>.
 | |
|              The intent of these requirements is that unbuffered or line-buffered output appear as soon as
 | |
|              possible, to ensure that prompting messages actually appear prior to a program waiting for
 | |
|              input.
 | |
| 
 | |
|         This is the observable behavior of the program.
 | |
| </pre>
 | |
| <a name='5.1.2.3p7'></a>
 | |
| <pre>7       What constitutes an interactive device is implementation-defined.
 | |
| </pre>
 | |
| <a name='5.1.2.3p8'></a>
 | |
| <pre>8       More stringent correspondences between abstract and actual semantics may be defined by each
 | |
|         implementation.
 | |
| </pre>
 | |
| <a name='5.1.2.3p9'></a>
 | |
| <pre>9       EXAMPLE 1 An implementation might define a one-to-one correspondence between abstract and actual semantics: at every
 | |
|         sequence point, the values of the actual objects would agree with those specified by the abstract semantics. The keyword
 | |
|         volatile would then be redundant.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.3p10'></a>
 | |
| <pre>10 Alternatively, an implementation might perform various optimizations within each translation unit, such that the actual
 | |
|    semantics would agree with the abstract semantics only when making function calls across translation unit boundaries. In
 | |
|    such an implementation, at the time of each function entry and function return where the calling function and the called
 | |
|    function are in different translation units, the values of all externally linked objects and of all objects accessible via pointers
 | |
|    therein would agree with the abstract semantics. Furthermore, at the time of each such function entry the values of the
 | |
|    parameters of the called function and of all objects accessible via pointers therein would agree with the abstract semantics. In
 | |
|    this type of implementation, objects referred to by interrupt service routines activated by the signal function would require
 | |
|    explicit specification of volatile storage, as well as other implementation-defined restrictions.
 | |
| </pre>
 | |
| <a name='5.1.2.3p11'></a>
 | |
| <pre>11   EXAMPLE 2 In executing the fragment
 | |
| 
 | |
|                char c1, c2;
 | |
|                /* ... */
 | |
|                c1 = c1 + c2;
 | |
| 
 | |
| 
 | |
|      the "integer promotions" require that the abstract machine promote the value of each variable to int size and then add the
 | |
|      two ints and truncate the sum. Provided the addition of two chars can be done without integer overflow, or with integer
 | |
|      overflow wrapping silently to produce the correct result, the actual execution need only produce the same result, possibly
 | |
|      omitting the promotions.
 | |
| </pre>
 | |
| <a name='5.1.2.3p12'></a>
 | |
| <pre>12   EXAMPLE 3 Similarly, in the fragment
 | |
| 
 | |
|                float f1, f2;
 | |
|                double d;
 | |
|                /* ... */
 | |
|                f1 = f2 * d;
 | |
| 
 | |
| 
 | |
|      the multiplication can be executed using single-precision arithmetic if the implementation can ascertain that the result would
 | |
|      be the same as if it were executed using double-precision arithmetic (for example, if d were replaced by the constant 2.0,
 | |
|      which has type double).
 | |
| </pre>
 | |
| <a name='5.1.2.3p13'></a>
 | |
| <pre>13   EXAMPLE 4 Implementations employing wide registers have to take care to honor appropriate semantics. Values are
 | |
|      independent of whether they are represented in a register or in memory. For example, an implicit spilling of a register is
 | |
|      not permitted to alter the value. Also, an explicit store and load is required to round to the precision of the storage type. In
 | |
|      particular, casts and assignments are required to perform their specified conversion. For the fragment
 | |
| 
 | |
|                double d1, d2;
 | |
|                float f;
 | |
|                d1 = f = expression;
 | |
|                d2 = (float) expression;
 | |
| 
 | |
| 
 | |
|      the values assigned to d1 and d2 are required to have been converted to float.
 | |
| </pre>
 | |
| <a name='5.1.2.3p14'></a>
 | |
| <pre>14   EXAMPLE 5 Rearrangement for floating-point expressions is often restricted because of limitations in precision as well as
 | |
|      range. The implementation cannot generally apply the mathematical associative rules for addition or multiplication, nor
 | |
|      the distributive rule, because of roundoff error, even in the absence of overflow and underflow. Likewise, implementations
 | |
|      cannot generally replace decimal constants in order to rearrange expressions. In the following fragment, rearrangements
 | |
|      suggested by mathematical rules for real numbers are often not valid (see <a href='#F.9'>F.9</a>).
 | |
| 
 | |
|                double x, y, z;
 | |
|                /* ... */
 | |
|                x = (x * y) * z;          // not equivalent to x *= y * z;
 | |
|                z = (x - y) + y;          // not equivalent to z = x;
 | |
|                z = x + x * y;            // not equivalent to z = x * (1.0 + y);
 | |
|                y = x / 5.0;              // not equivalent to y = x * 0.2;
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.3p15'></a>
 | |
| <pre>15   EXAMPLE 6 To illustrate the grouping behavior of expressions, in the following fragment
 | |
| 
 | |
|                int a, b;
 | |
|                /* ... */
 | |
|                a = a + 32760 + b + 5;
 | |
| 
 | |
| 
 | |
|      the expression statement behaves exactly the same as
 | |
| 
 | |
|                a = (((a + 32760) + b) + 5);
 | |
| 
 | |
| 
 | |
|      due to the associativity and precedence of these operators. Thus, the result of the sum (a + 32760) is next added to b, and
 | |
|      that result is then added to 5 which results in the value assigned to a. On a machine in which integer overflows produce
 | |
|      an explicit trap and in which the range of values representable by an int is [−32768, +32767], the implementation cannot
 | |
|      rewrite this expression as
 | |
| 
 | |
|                a = ((a + b) + 32765);
 | |
| 
 | |
| 
 | |
|      since if the values for a and b were, respectively, −32754 and −15, the sum a + b would produce a trap while the original
 | |
|      expression would not; nor can the expression be rewritten either as
 | |
|                a = ((a + 32765) + b);
 | |
| 
 | |
| 
 | |
|      or
 | |
| 
 | |
|                a = (a + (b + 32765));
 | |
| 
 | |
| 
 | |
|      since the values for a and b might have been, respectively, 4 and −8 or −17 and 12. However, on a machine in which integer
 | |
|      overflow silently generates some value and where positive and negative integer overflows cancel, the above expression
 | |
|      statement can be rewritten by the implementation in any of the above ways because the same result will occur.
 | |
| </pre>
 | |
| <a name='5.1.2.3p16'></a>
 | |
| <pre>16   EXAMPLE 7 The grouping of an expression does not completely determine its evaluation. In the following fragment
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                int sum;
 | |
|                char *p;
 | |
|                /* ... */
 | |
|                sum = sum * 10 - ’0’ + (*p++ = getchar());
 | |
| 
 | |
| 
 | |
|      the expression statement is grouped as if it were written as
 | |
| 
 | |
|                sum = (((sum * 10) - ’0’) + ((*(p++)) = (getchar())));
 | |
| 
 | |
| 
 | |
|      but the actual increment of p can occur at any time between the previous sequence point and the next sequence point (the ;),
 | |
|      and the call to getchar can occur at any point prior to the need of its returned value.
 | |
| 
 | |
|      Forward references: expressions (<a href='#6.5'>6.5</a>), type qualifiers (<a href='#6.7.3'>6.7.3</a>), statements (<a href='#6.8'>6.8</a>), floating-point envi-
 | |
|      ronment <fenv.h> (<a href='#7.6'>7.6</a>), the signal function (<a href='#7.14'>7.14</a>), files (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4'></a>
 | |
| <hr>
 | |
| <h3>5.1.2.4 [Multi-threaded executions and data races]</h3>
 | |
| <a name='5.1.2.4p1'></a>
 | |
| <pre>1    Under a hosted implementation, a program can have more than one thread of execution (or thread)
 | |
|      running concurrently. The execution of each thread proceeds as defined by the remainder of this
 | |
|      document. The execution of the entire program consists of an execution of all of its threads.<a href='#FOOTNOTE.14'><sup>[14]</sup></a>
 | |
|      Under a freestanding implementation, it is implementation-defined whether a program can have
 | |
|      more than one thread of execution.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.14'>
 | |
| <pre><i><b>Footnote 14)</b> The execution can usually be viewed as an interleaving of all of the threads. However, some kinds of atomic operations,
 | |
|      for example, allow executions inconsistent with a simple interleaving as described below.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.2.4p2'></a>
 | |
| <pre>2    The value of an object visible to a thread T at a particular point is the initial value of the object, a
 | |
|      value stored in the object by T , or a value stored in the object by another thread, according to the
 | |
|      rules below.
 | |
| </pre>
 | |
| <a name='5.1.2.4p3'></a>
 | |
| <pre>3    NOTE 1 In some cases, there could instead be undefined behavior. Much of this section is motivated by the desire to support
 | |
|      atomic operations with explicit and detailed visibility constraints. However, it also implicitly supports a simpler view for
 | |
|      more restricted programs.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p4'></a>
 | |
| <pre>4    Two expression evaluations conflict if one of them modifies a memory location and the other one
 | |
|      reads or modifies the same memory location.
 | |
| </pre>
 | |
| <a name='5.1.2.4p5'></a>
 | |
| <pre>5    The library defines a number of atomic operations (<a href='#7.17'>7.17</a>) and operations on mutexes (<a href='#7.28.4'>7.28.4</a>) that are
 | |
|      specially identified as synchronization operations. These operations play a special role in making
 | |
|      assignments in one thread visible to another. A synchronization operation on one or more memory
 | |
|      locations is one of an acquire operation, a release operation, both an acquire and release operation, or a
 | |
|      consume operation. A synchronization operation without an associated memory location is a fence and
 | |
|      can be either an acquire fence, a release fence, or both an acquire and release fence. In addition, there
 | |
|      are relaxed atomic operations, which are not synchronization operations, and atomic read-modify-write
 | |
|      operations, which have special characteristics.
 | |
| </pre>
 | |
| <a name='5.1.2.4p6'></a>
 | |
| <pre>6    NOTE 2 For example, a call that acquires a mutex will perform an acquire operation on the locations composing the mutex.
 | |
|      Correspondingly, a call that releases the same mutex will perform a release operation on those same locations. Informally,
 | |
|      performing a release operation on A forces prior side effects on other memory locations to become visible to other threads
 | |
|      that later perform an acquire or consume operation on A. Relaxed atomic operations are not included as synchronization
 | |
|      operations although, like synchronization operations, they cannot contribute to data races.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p7'></a>
 | |
| <pre>7    All modifications to a particular atomic object M occur in some particular total order, called the
 | |
|      modification order of M . If A and B are modifications of an atomic object M , and A happens before B,
 | |
|      then A shall precede B in the modification order of M , which is defined below.
 | |
| </pre>
 | |
| <a name='5.1.2.4p8'></a>
 | |
| <pre>8    NOTE 3 This states that the modification orders are expected to respect the "happens before" relation.
 | |
| </pre>
 | |
| <a name='5.1.2.4p9'></a>
 | |
| <pre>9    NOTE 4 There is a separate order for each atomic object. There is no requirement that these can be combined into a single
 | |
|      total order for all objects. In general this will be impossible since different threads can observe modifications to different
 | |
|      variables in inconsistent orders.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p10'></a>
 | |
| <pre>10   A release sequence headed by a release operation A on an atomic object M is a maximal contiguous
 | |
|      sub-sequence of side effects in the modification order of M , where the first operation is A and every
 | |
|      subsequent operation either is performed by the same thread that performed the release or is an
 | |
|      atomic read-modify-write operation.
 | |
| </pre>
 | |
| <a name='5.1.2.4p11'></a>
 | |
| <pre>11   Certain library calls synchronize with other library calls performed by another thread. In particular,
 | |
|      an atomic operation A that performs a release operation on an object M synchronizes with an atomic
 | |
|      operation B that performs an acquire operation on M and reads a value written by any side effect in
 | |
|      the release sequence headed by A.
 | |
| </pre>
 | |
| <a name='5.1.2.4p12'></a>
 | |
| <pre>12   NOTE 5 Except in the specified cases, reading a later value does not necessarily ensure visibility as described below. Such a
 | |
|      requirement would sometimes interfere with efficient implementation.
 | |
| </pre>
 | |
| <a name='5.1.2.4p13'></a>
 | |
| <pre>13   NOTE 6 The specifications of the synchronization operations define when one reads the value written by another. For atomic
 | |
|      variables, the definition is clear. All operations on a given mutex occur in a single total order. Each mutex acquisition "reads
 | |
|      the value written" by the last mutex release.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p14'></a>
 | |
| <pre>14   An evaluation A carries a dependency<a href='#FOOTNOTE.15'><sup>[15]</sup></a> to an evaluation B if:
 | |
| 
 | |
|         — the value of A is used as an operand of B, unless:
 | |
| 
 | |
|                  • B is an invocation of the kill_dependency macro,
 | |
|                  • A is the left operand of a && or || operator,
 | |
|                  • A is the left operand of a ?: operator, or
 | |
|                  • A is the left operand of a , operator;
 | |
| 
 | |
|             or
 | |
| 
 | |
|         — A writes a scalar object or bit-field M , B reads from M the value written by A, and A is
 | |
|           sequenced before B, or
 | |
| 
 | |
|         — for some evaluation X, A carries a dependency to X and X carries a dependency to B.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.15'>
 | |
| <pre><i><b>Footnote 15)</b> The "carries a dependency" relation is a subset of the "sequenced before" relation, and is similarly strictly intra-thread.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.2.4p15'></a>
 | |
| <pre>15   An evaluation A is dependency-ordered before<a href='#FOOTNOTE.16'><sup>[16]</sup></a> an evaluation B if:
 | |
| 
 | |
|         — A performs a release operation on an atomic object M , and, in another thread, B performs a
 | |
|           consume operation on M and reads a value written by any side effect in the release sequence
 | |
|           headed by A, or
 | |
| 
 | |
|         — for some evaluation X, A is dependency-ordered before X and X carries a dependency to B.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.16'>
 | |
| <pre><i><b>Footnote 16)</b> The "dependency-ordered before" relation is analogous to the "synchronizes with" relation, but uses release/consume in
 | |
|      place of release/acquire.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.1.2.4p16'></a>
 | |
| <pre>16   An evaluation A inter-thread happens before an evaluation B if A synchronizes with B, A is
 | |
|      dependency-ordered before B, or, for some evaluation X:
 | |
| 
 | |
|         — A synchronizes with X and X is sequenced before B,
 | |
| 
 | |
|         — A is sequenced before X and X inter-thread happens before B, or
 | |
| 
 | |
|         — A inter-thread happens before X and X inter-thread happens before B.
 | |
| </pre>
 | |
| <a name='5.1.2.4p17'></a>
 | |
| <pre>17   NOTE 7 The "inter-thread happens before" relation describes arbitrary concatenations of "sequenced before", "synchronizes
 | |
|      with", and "dependency-ordered before" relationships, with two exceptions. The first exception is that a concatenation is
 | |
|      not permitted to end with "dependency-ordered before" followed by "sequenced before". The reason for this limitation is
 | |
|      that a consume operation participating in a "dependency-ordered before" relationship provides ordering only with respect
 | |
|      to operations to which this consume operation actually carries a dependency. The reason that this limitation applies only
 | |
|      to the end of such a concatenation is that any subsequent release operation will provide the required ordering for a prior
 | |
|      consume operation. The second exception is that a concatenation is not permitted to consist entirely of "sequenced before".
 | |
|      The reasons for this limitation are (1) to permit "inter-thread happens before" to be transitively closed and (2) the "happens
 | |
|      before" relation, defined below, provides for relationships consisting entirely of "sequenced before".
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p18'></a>
 | |
| <pre>18   An evaluation A happens before an evaluation B if A is sequenced before B or A inter-thread happens
 | |
|      before B. The implementation shall ensure that no program execution demonstrates a cycle in the
 | |
|      "happens before" relation.
 | |
| </pre>
 | |
| <a name='5.1.2.4p19'></a>
 | |
| <pre>19   NOTE 8 This cycle would otherwise be possible only through the use of consume operations.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p20'></a>
 | |
| <pre>20   A visible side effect A on an object M with respect to a value computation B of M satisfies the
 | |
|      conditions:
 | |
| 
 | |
|         — A happens before B, and
 | |
| 
 | |
|         — there is no other side effect X to M such that A happens before X and X happens before B.
 | |
| 
 | |
|      The value of a non-atomic scalar object M , as determined by evaluation B, shall be the value stored
 | |
|      by the visible side effect A.
 | |
| </pre>
 | |
| <a name='5.1.2.4p21'></a>
 | |
| <pre>21   NOTE 9 If there is ambiguity about which side effect to a non-atomic object is visible, then there is a data race and the
 | |
|      behavior is undefined.
 | |
| </pre>
 | |
| <a name='5.1.2.4p22'></a>
 | |
| <pre>22   NOTE 10 This states that operations on ordinary variables are not visibly reordered. This is not actually detectable without
 | |
|      data races, but it is necessary to ensure that data races, as defined here, and with suitable restrictions on the use of atomics,
 | |
|      correspond to data races in a simple interleaved (sequentially consistent) execution.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p23'></a>
 | |
| <pre>23   The value of an atomic object M , as determined by evaluation B, shall be the value stored by some
 | |
|      side effect A that modifies M , where B does not happen before A.
 | |
| </pre>
 | |
| <a name='5.1.2.4p24'></a>
 | |
| <pre>24   NOTE 11 The set of side effects from which a given evaluation might take its value is also restricted by the rest of the rules
 | |
|      described here, and in particular, by the coherence requirements below.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p25'></a>
 | |
| <pre>25   If an operation A that modifies an atomic object M happens before an operation B that modifies M ,
 | |
|      then A shall be earlier than B in the modification order of M .
 | |
| </pre>
 | |
| <a name='5.1.2.4p26'></a>
 | |
| <pre>26   NOTE 12 The requirement above is known as "write-write coherence".
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p27'></a>
 | |
| <pre>27   If a value computation A of an atomic object M happens before a value computation B of M , and A
 | |
|      takes its value from a side effect X on M , then the value computed by B shall either be the value
 | |
|      stored by X or the value stored by a side effect Y on M , where Y follows X in the modification
 | |
|      order of M .
 | |
| </pre>
 | |
| <a name='5.1.2.4p28'></a>
 | |
| <pre>28   NOTE 13 The requirement above is known as "read-read coherence".
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p29'></a>
 | |
| <pre>29   If a value computation A of an atomic object M happens before an operation B on M , then A shall
 | |
|      take its value from a side effect X on M , where X precedes B in the modification order of M .
 | |
| </pre>
 | |
| <a name='5.1.2.4p30'></a>
 | |
| <pre>30   NOTE 14 The requirement above is known as "read-write coherence".
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p31'></a>
 | |
| <pre>31   If a side effect X on an atomic object M happens before a value computation B of M , then the
 | |
|      evaluation B shall take its value from X or from a side effect Y that follows X in the modification
 | |
|      order of M .
 | |
| </pre>
 | |
| <a name='5.1.2.4p32'></a>
 | |
| <pre>32   NOTE 15 The requirement above is known as "write-read coherence".
 | |
| </pre>
 | |
| <a name='5.1.2.4p33'></a>
 | |
| <pre>33   NOTE 16 This effectively disallows compiler reordering of atomic operations to a single object, even if both operations are
 | |
|      "relaxed" loads. By doing so, it effectively makes the "cache coherence" guarantee provided by most hardware available to C
 | |
|      atomic operations.
 | |
| </pre>
 | |
| <a name='5.1.2.4p34'></a>
 | |
| <pre>34   NOTE 17 The value observed by a load of an atomic object depends on the "happens before" relation, which in turn depends
 | |
|      on the values observed by loads of atomic objects. The intended reading is that there exists an association of atomic loads
 | |
|      with modifications they observe that, together with suitably chosen modification orders and the "happens before" relation
 | |
|      derived as described above, satisfy the resulting constraints as imposed here.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.1.2.4p35'></a>
 | |
| <pre>35   The execution of a program contains a data race if it contains two conflicting actions in different
 | |
|      threads, at least one of which is not atomic, and neither happens before the other. Any such data
 | |
|      race results in undefined behavior.
 | |
| </pre>
 | |
| <a name='5.1.2.4p36'></a>
 | |
| <pre>36   NOTE 18 It can be shown that programs that correctly use simple mutexes and memory_order_seq_cst operations to
 | |
|      prevent all data races, and use no other synchronization operations, behave as though the operations executed by their
 | |
|      constituent threads were simply interleaved, with each value computation of an object being the last value stored in that
 | |
|      interleaving. This is normally referred to as "sequential consistency". However, this applies only to data-race-free programs,
 | |
|      and data-race-free programs cannot observe most program transformations that do not change single-threaded program
 | |
|      semantics. In fact, most single-threaded program transformations continue to be allowed, since any program that behaves
 | |
|      differently as a result necessarily has undefined behavior even before such a transformation is applied.
 | |
| </pre>
 | |
| <a name='5.1.2.4p37'></a>
 | |
| <pre>37   NOTE 19 Compiler transformations that introduce assignments to a potentially shared memory location that would not
 | |
|      be modified by the abstract machine are generally precluded by this document, since such an assignment might overwrite
 | |
|      another assignment by a different thread in cases in which an abstract machine execution would not have encountered a
 | |
|      data race. This includes implementations of data member assignment that overwrite adjacent members in separate memory
 | |
|      locations. Reordering of atomic loads in cases in which the atomics in question might alias is also generally precluded, since
 | |
|      this could violate the coherence requirements.
 | |
| </pre>
 | |
| <a name='5.1.2.4p38'></a>
 | |
| <pre>38   NOTE 20 Transformations that introduce a speculative read of a potentially shared memory location might not preserve
 | |
|      the semantics of the program as defined in this document, since they potentially introduce a data race. However, they are
 | |
|      typically valid in the context of an optimizing compiler that targets a specific machine with well-defined semantics for data
 | |
|      races. They would be invalid for a hypothetical machine that is not tolerant of races or provides hardware race detection.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2'></a>
 | |
| <hr>
 | |
| <h3>5.2 [Environmental considerations]</h3>
 | |
| <a name='5.2.1'></a>
 | |
| <hr>
 | |
| <h3>5.2.1 [Character sets]</h3>
 | |
| <a name='5.2.1p1'></a>
 | |
| <pre>1    Two sets of characters and their associated collating sequences shall be defined: the set in which source
 | |
|      files are written (the source character set), and the set interpreted in the execution environment (the
 | |
|      execution character set). Each set is further divided into a basic character set, whose contents are given
 | |
|      by this subclause, and a set of zero or more locale-specific members (which are not members of the
 | |
|      basic character set) called extended characters. The combined set is also called the extended character
 | |
|      set. The values of the members of the execution character set are implementation-defined.
 | |
| </pre>
 | |
| <a name='5.2.1p2'></a>
 | |
| <pre>2    In a character constant or string literal, members of the execution character set shall be represented by
 | |
|      corresponding members of the source character set or by escape sequences consisting of the backslash
 | |
|      \ followed by one or more characters. A byte with all bits set to 0, called the null character, shall exist
 | |
|      in the basic execution character set; it is used to terminate a character string.
 | |
|      Both the basic source and basic execution character sets shall have the following members: the 26
 | |
|      uppercase letters of the Latin alphabet
 | |
| </pre>
 | |
| <a name='5.2.1p3'></a>
 | |
| <pre>3                A   B   C    D   E   F   G    H   I   J   K    L   M
 | |
|                N   O   P    Q   R   S   T    U   V   W   X    Y   Z
 | |
| 
 | |
|      the 26 lowercase letters of the Latin alphabet
 | |
| 
 | |
|                a   b   c    d   e   f   g    h   i   j   k    l   m
 | |
|                n   o   p    q   r   s   t    u   v   w   x    y   z
 | |
| 
 | |
|      the 10 decimal digits
 | |
| 
 | |
|                0   1   2    3   4   5   6    7   8   9
 | |
| 
 | |
|      the following 29 graphic characters
 | |
|                !   "   #    %   &   ’   (    )   *   +   ,    -   .   /   :
 | |
|                ;   <   =    >   ?   [   \    ]   ^   _   {    |   }   ~
 | |
| 
 | |
|      the space character, and control characters representing horizontal tab, vertical tab, and form feed.
 | |
|      The representation of each member of the source and execution basic character sets shall fit in a
 | |
|      byte. In both the source and execution basic character sets, the value of each character after 0 in
 | |
|      the above list of decimal digits shall be one greater than the value of the previous. In source files,
 | |
|      there shall be some way of indicating the end of each line of text; this document treats such an
 | |
|      end-of-line indicator as if it were a single new-line character. In the basic execution character set,
 | |
|      there shall be control characters representing alert, backspace, carriage return, and new line. If any
 | |
|      other characters are encountered in a source file (except in an identifier, a character constant, a string
 | |
|      literal, a header name, a comment, or a preprocessing token that is never converted to a token), the
 | |
|     behavior is undefined.
 | |
| </pre>
 | |
| <a name='5.2.1p4'></a>
 | |
| <pre>4   A letter is an uppercase letter or a lowercase letter as defined above; in this document the term does
 | |
|     not include other characters that are letters in other alphabets.
 | |
| </pre>
 | |
| <a name='5.2.1p5'></a>
 | |
| <pre>5   The universal character name construct provides a way to name other characters.
 | |
|     Forward references: universal character names (<a href='#6.4.3'>6.4.3</a>), character constants (<a href='#6.4.4.4'>6.4.4.4</a>), preprocessing
 | |
|     directives (<a href='#6.10'>6.10</a>), string literals (<a href='#6.4.5'>6.4.5</a>), comments (<a href='#6.4.9'>6.4.9</a>), string (<a href='#7.1.1'>7.1.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.1.1'></a>
 | |
| <hr>
 | |
| <h3>5.2.1.1 [Multibyte characters]</h3>
 | |
| <a name='5.2.1.1p1'></a>
 | |
| <pre>1   The source character set may contain multibyte characters, used to represent members of the
 | |
|     extended character set. The execution character set may also contain multibyte characters, which
 | |
|     need not have the same encoding as for the source character set. For both character sets, the following
 | |
|     shall hold:
 | |
| 
 | |
|       — The basic character set, @, $, and ` shall be present and each character shall be encoded as a
 | |
|         single byte.
 | |
|       — The presence, meaning, and representation of any additional members is locale-specific.
 | |
|       — A multibyte character set may have a state-dependent encoding, wherein each sequence of
 | |
|         multibyte characters begins in an initial shift state and enters other locale-specific shift states
 | |
|         when specific multibyte characters are encountered in the sequence. While in the initial shift
 | |
|         state, all single-byte characters retain their usual interpretation and do not alter the shift state.
 | |
|         The interpretation for subsequent bytes in the sequence is a function of the current shift state.
 | |
|       — A byte with all bits zero shall be interpreted as a null character independent of shift state. Such
 | |
|         a byte shall not occur as part of any other multibyte character.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.1.1p2'></a>
 | |
| <pre>2   For source files, the following shall hold:
 | |
| 
 | |
|       — An identifier, comment, string literal, character constant, or header name shall begin and end
 | |
|         in the initial shift state.
 | |
|       — An identifier, comment, string literal, character constant, or header name shall consist of a
 | |
|         sequence of valid multibyte characters.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.2'></a>
 | |
| <hr>
 | |
| <h3>5.2.2 [Character display semantics]</h3>
 | |
| <a name='5.2.2p1'></a>
 | |
| <pre>1   The active position is that location on a display device where the next character output by the
 | |
|     fputc function would appear. The intent of writing a printing character (as defined by the isprint
 | |
|     function) to a display device is to display a graphic representation of that character at the active
 | |
|     position and then advance the active position to the next position on the current line. The direction
 | |
|     of writing is locale-specific. If the active position is at the final position of a line (if there is one), the
 | |
|     behavior of the display device is unspecified.
 | |
| </pre>
 | |
| <a name='5.2.2p2'></a>
 | |
| <pre>2   Alphabetic escape sequences representing non-graphic characters in the execution character set are
 | |
|     intended to produce actions on display devices as follows:
 | |
| 
 | |
|     \a (alert) Produces an audible or visible alert without changing the active position.
 | |
| 
 | |
|     \b (backspace) Moves the active position to the previous position on the current line. If the active
 | |
|         position is at the initial position of a line, the behavior of the display device is unspecified.
 | |
|     \f (form feed) Moves the active position to the initial position at the start of the next logical page.
 | |
| 
 | |
|     \n (new line) Moves the active position to the initial position of the next line.
 | |
| 
 | |
|     \r (carriage return) Moves the active position to the initial position of the current line.
 | |
| 
 | |
|     \t (horizontal tab) Moves the active position to the next horizontal tabulation position on the current
 | |
|         line. If the active position is at or past the last defined horizontal tabulation position, the behavior
 | |
|         of the display device is unspecified.
 | |
|     \v (vertical tab) Moves the active position to the initial position of the next vertical tabulation
 | |
|         position. If the active position is at or past the last defined vertical tabulation position, the
 | |
|         behavior of the display device is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.2p3'></a>
 | |
| <pre>3   Each of these escape sequences shall produce a unique implementation-defined value which can be
 | |
|     stored in a single char object. The external representations in a text file need not be identical to the
 | |
|     internal representations, and are outside the scope of this document.
 | |
|     Forward references: the isprint function (<a href='#7.4.1.8'>7.4.1.8</a>), the fputc function (<a href='#7.23.7.3'>7.23.7.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.3'></a>
 | |
| <hr>
 | |
| <h3>5.2.3 [Signals and interrupts]</h3>
 | |
| <a name='5.2.3p1'></a>
 | |
| <pre>1   Functions shall be implemented such that they may be interrupted at any time by a signal, or may be
 | |
|     called by a signal handler, or both, with no alteration to earlier, but still active, invocations’ control
 | |
|     flow (after the interruption), function return values, or objects with automatic storage duration.
 | |
|     All such objects shall be maintained outside the function image (the instructions that compose the
 | |
|     executable representation of a function) on a per-invocation basis.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4'></a>
 | |
| <hr>
 | |
| <h3>5.2.4 [Environmental limits]</h3>
 | |
| <a name='5.2.4p1'></a>
 | |
| <pre>1   Both the translation and execution environments constrain the implementation of language trans-
 | |
|     lators and libraries. The following summarizes the language-related environmental limits on a
 | |
|     conforming implementation; the library-related limits are discussed in Clause 7.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.1'></a>
 | |
| <hr>
 | |
| <h3>5.2.4.1 [Translation limits]</h3>
 | |
| <a name='5.2.4.1p1'></a>
 | |
| <pre>1   The implementation shall be able to translate and execute a program that uses but does not exceed
 | |
|     the following limitations for these constructs and entities<a href='#FOOTNOTE.17'><sup>[17]</sup></a> :
 | |
| 
 | |
|       — 127 nesting levels of blocks
 | |
| 
 | |
|       — 63 nesting levels of conditional inclusion
 | |
| 
 | |
|       — 12 pointer, array, and function declarators (in any combinations) modifying an arithmetic,
 | |
|         structure, union, or void type in a declaration
 | |
| 
 | |
|       — 63 nesting levels of parenthesized declarators within a full declarator
 | |
| 
 | |
|       — 63 nesting levels of parenthesized expressions within a full expression
 | |
| 
 | |
|       — 63 significant initial characters in an internal identifier or a macro name(each universal charac-
 | |
|         ter name or extended source character is considered a single character)
 | |
| 
 | |
|       — 31 significant initial characters in an external identifier (each universal character name specify-
 | |
|         ing a short identifier of 0000FFFF or less is considered 6 characters, each universal character
 | |
|         name specifying a short identifier of 00010000 or more is considered 10 characters, and each
 | |
|         extended source character is considered the same number of characters as the corresponding
 | |
|         universal character name, if any)<a href='#FOOTNOTE.18'><sup>[18]</sup></a>
 | |
| 
 | |
|       — 4095 external identifiers in one translation unit
 | |
| 
 | |
|       — 511 identifiers with block scope declared in one block
 | |
| 
 | |
|       — 4095 macro identifiers simultaneously defined in one preprocessing translation unit
 | |
| 
 | |
|       — 127 parameters in one function definition
 | |
| 
 | |
|       — 127 arguments in one function call
 | |
| 
 | |
|       — 127 parameters in one macro definition
 | |
| 
 | |
|       — 127 arguments in one macro invocation
 | |
|       — 4095 characters in a logical source line
 | |
| 
 | |
|       — 4095 characters in a string literal (after concatenation)
 | |
| 
 | |
|       — 32767 bytes in an object (in a hosted environment only)
 | |
| 
 | |
|       — 15 nesting levels for #included files
 | |
| 
 | |
|       — 1023 case labels for a switch statement (excluding those for any nested switch statements)
 | |
| 
 | |
|       — 1023 members in a single structure or union
 | |
| 
 | |
|       — 1023 enumeration constants in a single enumeration
 | |
| 
 | |
|       — 63 levels of nested structure or union definitions in a single member declaration list
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.17'>
 | |
| <pre><i><b>Footnote 17)</b> Implementations are encouraged to avoid imposing fixed translation limits whenever possible.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.18'>
 | |
| <pre><i><b>Footnote 18)</b> See "future language directions" (<a href='#6.11.3'>6.11.3</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2'></a>
 | |
| <hr>
 | |
| <h3>5.2.4.2 [Numerical limits]</h3>
 | |
| <a name='5.2.4.2p1'></a>
 | |
| <pre>1   An implementation is required to document all the limits specified in this subclause, which are
 | |
|     specified in the headers <limits.h> and <float.h>. Additional limits are specified in <stdint.h>.
 | |
|     Forward references: integer types <stdint.h> (<a href='#7.22'>7.22</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.1'></a>
 | |
| <hr>
 | |
| <h3>5.2.4.2.1 [Characteristics of integer types <limits.h>]</h3>
 | |
| <a name='5.2.4.2.1p1'></a>
 | |
| <pre>1   The values given below shall be replaced by constant expressions suitable for use in #if preprocess-
 | |
|     ing directives. Their implementation-defined values shall be equal or greater to those shown.
 | |
| 
 | |
|       — width for an object of type bool<a href='#FOOTNOTE.19'><sup>[19]</sup></a>
 | |
| 
 | |
|              BOOL_WIDTH                          1
 | |
| 
 | |
| 
 | |
|       — number of bits for smallest object that is not a bit-field (byte)
 | |
| 
 | |
|              CHAR_BIT                            8
 | |
| 
 | |
| 
 | |
|            The macros CHAR_WIDTH, SCHAR_WIDTH, and UCHAR_WIDTH that represent the width of the
 | |
|            types char, signed char and unsigned char shall expand to the same value as CHAR_BIT.
 | |
| 
 | |
|       — width for an object of type unsigned short int
 | |
| 
 | |
|              USHRT_WIDTH                        16
 | |
| 
 | |
| 
 | |
|            The macro SHRT_WIDTH represents the width of the type short int and shall expand to the
 | |
|            same value as USHRT_WIDTH.
 | |
| 
 | |
|       — width for an object of type unsigned int
 | |
| 
 | |
|              UINT_WIDTH                         16
 | |
| 
 | |
| 
 | |
|            The macro INT_WIDTH represents the width of the type int and shall expand to the same value
 | |
|            as UINT_WIDTH.
 | |
| 
 | |
|       — width for an object of type unsigned long int
 | |
| 
 | |
|              ULONG_WIDTH                         32
 | |
| 
 | |
| 
 | |
|            The macro LONG_WIDTH represents the width of the type long int and shall expand to the
 | |
|            same value as ULONG_WIDTH.
 | |
| 
 | |
|       — width for an object of type unsigned long long int
 | |
|               ULLONG_WIDTH                                  64
 | |
| 
 | |
| 
 | |
|            The macro LLONG_WIDTH represents the width of the type long long int and shall expand to
 | |
|            the same value as ULLONG_WIDTH.
 | |
|       — maximum width for an object of type _BitInt or unsigned _BitInt
 | |
| 
 | |
|               BITINT_MAXWIDTH             /* see below */
 | |
| 
 | |
| 
 | |
|            The macro BITINT_MAXWIDTH represents the maximum width N supported by the declaration
 | |
|            of a bit-precise integer (<a href='#6.2.5'>6.2.5</a>) in the type specifier _BitInt( N). The value BITINT_MAXWIDTH
 | |
|            shall expand to a value that is greater than or equal to the value of ULLONG_WIDTH.
 | |
|       — maximum number of bytes in a multibyte character, for any supported locale
 | |
| 
 | |
|               MB_LEN_MAX                                    1
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.19'>
 | |
| <pre><i><b>Footnote 19)</b> This value is exact.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.1p2'></a>
 | |
| <pre>2   For all unsigned integer types for which <limits.h> or <stdint.h> define a macro with suffix
 | |
|     _WIDTH holding its width N , there is a macro with suffix _MAX holding the maximal value 2N − 1
 | |
|     that is representable by the type and that has the same type as would an expression that is an object
 | |
|     of the corresponding type converted according to the integer promotions. If the value is in the range
 | |
|     of the type uintmax_t (<a href='#7.22.1.5'>7.22.1.5</a>) the macro is suitable for use in #if preprocessing directives.
 | |
| </pre>
 | |
| <a name='5.2.4.2.1p3'></a>
 | |
| <pre>3   For all signed integer types for which <limits.h> or <stdint.h> define a macro with suffix _WIDTH
 | |
|     holding its width N , there are macros with suffix _MIN and _MAX holding the minimal and maximal
 | |
|     values −2N −1 and 2N −1 − 1 that are representable by the type and that have the same type as
 | |
|     would an expression that is an object of the corresponding type converted according to the integer
 | |
|     promotions. If the values are in the range of the type intmax_t (<a href='#7.22.1.5'>7.22.1.5</a>) the macros are suitable for
 | |
|     use in #if preprocessing directives.
 | |
| </pre>
 | |
| <a name='5.2.4.2.1p4'></a>
 | |
| <pre>4   If an object of type char can hold negative values, the value of CHAR_MIN shall be the same as that of
 | |
|     SCHAR_MIN and the value of CHAR_MAX shall be the same as that of SCHAR_MAX. Otherwise, the value
 | |
|     of CHAR_MIN shall be 0 and the value of CHAR_MAX shall be the same as that of UCHAR_MAX.<a href='#FOOTNOTE.20'><sup>[20]</sup></a>
 | |
|     Forward references: representations of types (<a href='#6.2.6'>6.2.6</a>), conditional inclusion (<a href='#6.10.1'>6.10.1</a>), integer types
 | |
|     <stdint.h> (<a href='#7.22'>7.22</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.20'>
 | |
| <pre><i><b>Footnote 20)</b> See <a href='#6.2.5'>6.2.5</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.2'></a>
 | |
| <hr>
 | |
| <h3>5.2.4.2.2 [Characteristics of floating types <float.h>]</h3>
 | |
| <a name='5.2.4.2.2p1'></a>
 | |
| <pre>1   The characteristics of floating types are defined in terms of a model that describes a repre-
 | |
|     sentation of floating-point numbers and allows other values. The characteristics provide in-
 | |
|     formation about an implementation’s floating-point arithmetic<a href='#FOOTNOTE.21'><sup>[21]</sup></a> . An implementation that de-
 | |
|     fines __STDC_IEC_60559_BFP__ or __STDC_IEC_559__ shall implement floating-point types and
 | |
|     arithmetic conforming to IEC 60559 as specified in Annex F. An implementation that defines
 | |
|     __STDC_IEC_60559_COMPLEX__ or __STDC_IEC_559_COMPLEX__ shall implement complex types
 | |
|     and arithmetic conforming to IEC 60559 as specified in Annex G.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.21'>
 | |
| <pre><i><b>Footnote 21)</b> The floating-point model is intended to clarify the description of each floating-point characteristic and does not require
 | |
|     the floating-point arithmetic of the implementation to be identical.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.2p2'></a>
 | |
| <pre>2   The following parameters are used to define the model for each floating type:
 | |
|            s          sign (±1)
 | |
|            b          base or radix of exponent representation (an integer > 1)
 | |
|            e          exponent (an integer between a minimum emin and a maximum emax )
 | |
|            p          precision (the number of base-b digits in the significand)
 | |
|            fk         nonnegative integers less than b (the significand digits)
 | |
|     For each floating type, the parameters b, p, emin , and emax are fixed constants.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p3'></a>
 | |
| <pre>3   For each floating type, a floating-point number (x) is defined by the following model:
 | |
|                       p
 | |
|             x = sbe         fk b−k ,
 | |
|                      SIGMA
 | |
|                                        emin ≤ e ≤ emax
 | |
|                       k=1
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p4'></a>
 | |
| <pre>4    Model floating-point numbers x with f1 > 0 are called normalized floating-point numbers.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p5'></a>
 | |
| <pre>5    Model floating-point numbers x ̸= 0 with f1 = 0 and e = emin are called subnormal floating-point
 | |
|      numbers.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p6'></a>
 | |
| <pre>6    Model floating-point numbers x ̸= 0 with f1 = 0 and e > emin are called unnormalized floating-point
 | |
|      numbers.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p7'></a>
 | |
| <pre>7    Model floating-point numbers x with all fk = 0 are zeros.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p8'></a>
 | |
| <pre>8    Floating types shall be able to represent signed zeros or an unsigned zero and all normalized floating-
 | |
|      point numbers. In addition, floating types may be able to contain other kinds of floating-point
 | |
|      numbers<a href='#FOOTNOTE.22'><sup>[22]</sup></a> , such as subnormal floating-point numbers and unnormalized floating-point numbers,
 | |
|      and values that are not floating-point numbers, such as NaNs and (signed and unsigned) infinities.
 | |
|      A NaN is a value signifying Not-a-Number. A quiet NaN propagates through almost every arithmetic
 | |
|      operation without raising a floating-point exception; a signaling NaN generally raises a floating-point
 | |
|      exception when occurring as an arithmetic operand<a href='#FOOTNOTE.23'><sup>[23]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.22'>
 | |
| <pre><i><b>Footnote 22)</b> Some implementations have types that include finite numbers with range and/or precision that are not covered by the
 | |
|      model.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.23'>
 | |
| <pre><i><b>Footnote 23)</b> IEC 60559 specifies quiet and signaling NaNs. For implementations that do not support IEC 60559, the terms quiet NaN
 | |
|      and signaling NaN are intended to apply to values with similar behavior.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.2p9'></a>
 | |
| <pre>9    Wherever values are unsigned, any requirement in this document to get the sign shall produce an
 | |
|      unspecified sign, and any requirement to set the sign shall be ignored, unless otherwise specified<a href='#FOOTNOTE.24'><sup>[24]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.24'>
 | |
| <pre><i><b>Footnote 24)</b> Bit representations of floating-point values might include a sign bit, even if the values can be regarded as unsigned.
 | |
|      IEC 60559 NaNs are such values.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.2p10'></a>
 | |
| <pre>10   Whether and in what cases subnormal numbers are treated as zeros is implementation-defined.
 | |
|      Subnormal numbers that in some cases are treated by arithmetic operations as zeros are properly
 | |
|      classified as subnormal. However, object representations that could represent subnormal numbers
 | |
|      but that are always treated by arithmetic operations as zeros are non-canonical zeros, and the
 | |
|      values are properly classified as zero, not subnormal. IEC 60559 arithmetic (with default exception
 | |
|      handling) always treats subnormal numbers as nonzero.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p11'></a>
 | |
| <pre>11   A value is negative if and only if it compares less than 0. Thus, negative zeros and NaNs are not
 | |
|      negative values.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p12'></a>
 | |
| <pre>12   An implementation may prefer particular representations of values that have multiple representa-
 | |
|      tions in a floating type, <a href='#6.2.6.1'>6.2.6.1</a> not withstanding.<a href='#FOOTNOTE.25'><sup>[25]</sup></a> The preferred representations of a floating type,
 | |
|      including unique representations of values in the type, are called canonical. A floating type may also
 | |
|      contain non-canonical representations, for example, redundant representations of some or all of its
 | |
|      values, or representations that are extraneous to the floating-point model.<a href='#FOOTNOTE.26'><sup>[26]</sup></a> Typically, floating-point
 | |
|      operations deliver results with canonical representations. IEC 60559 operations deliver results with
 | |
|      canonical representations, unless specified otherwise.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.25'>
 | |
| <pre><i><b>Footnote 25)</b> The library operations iscanonical and canonicalize distinguish canonical (preferred) representations, but this
 | |
|      distinction alone does not imply that canonical and non-canonical representations are of different values.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.26'>
 | |
| <pre><i><b>Footnote 26)</b> Some of the values in the IEC 60559 decimal formats have non-canonical representations (as well as a canonical
 | |
|      representation).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.2p13'></a>
 | |
| <pre>13   The minimum range of representable values for a floating type is the most negative finite floating-
 | |
|      point number representable in that type through the most positive finite floating-point number
 | |
|      representable in that type. In addition, if negative infinity is representable in a type, the range of
 | |
|      that type is extended to all negative real numbers; likewise, if positive infinity is representable in a
 | |
|      type, the range of that type is extended to all positive real numbers.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p14'></a>
 | |
| <pre>14   The accuracy of the floating-point operations (+ ,- , * , / ) and of the library functions in <math.h>
 | |
|      and <complex.h> that return floating-point results is implementation-defined, as is the accuracy of
 | |
|      the conversion between floating-point internal representations and string representations performed
 | |
|      by the library functions in <stdio.h>, <stdlib.h>, and <wchar.h>. The implementation may state
 | |
|      that the accuracy is unknown. Decimal floating-point operations have stricter requirements.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p15'></a>
 | |
| <pre>15   All integer values in the <float.h> header, except FLT_ROUNDS, shall be constant expressions
 | |
|      suitable for use in #if preprocessing directives; all floating values shall be constant expressions.
 | |
|      All except CR_DECIMAL_DIG (<a href='#F.5'>F.5</a>), DECIMAL_DIG, DEC_EVAL_METHOD, FLT_EVAL_METHOD, FLT_RADIX,
 | |
|      and FLT_ROUNDS have separate names for all floating types. The floating-point model representation
 | |
|      is provided for all values except DEC_EVAL_METHOD, FLT_EVAL_METHOD and FLT_ROUNDS.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p16'></a>
 | |
| <pre>16   The remainder of this subclause specifies characteristics of standard floating types.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p17'></a>
 | |
| <pre>17   The rounding mode for floating-point addition for standard floating types is characterized by the
 | |
|      implementation-defined value of FLT_ROUNDS. Evaluation of FLT_ROUNDS correctly reflects any
 | |
|      execution-time change of rounding mode through the function fesetround in <fenv.h>.
 | |
| 
 | |
|      −1      indeterminable
 | |
|       0      toward zero
 | |
|       1      to nearest, ties to even
 | |
|       2      toward positive infinity
 | |
|       3      toward negative infinity
 | |
|       4      to nearest, ties away from zero
 | |
| 
 | |
|      All other values for FLT_ROUNDS characterize implementation-defined rounding behavior.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p18'></a>
 | |
| <pre>18   Whether a type matches an IEC 60559 format (and perhaps, operations) is characterized
 | |
|      by the implementation-defined values of FLT_IS_IEC_60559, DBL_IS_IEC_60559, and
 | |
|      LDBL_IS_IEC_60559 (this does not imply conformance to Annex F):
 | |
| 
 | |
|      0 type does not match an IEC 60559 format
 | |
|      1 type matches an IEC 60559 format
 | |
|      2 type matches an IEC 60559 format and operations
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p19'></a>
 | |
| <pre>19   The values of floating type yielded by operators subject to the usual arithmetic conversions, including
 | |
|      the values yielded by the implicit conversion of operands, and the values of floating constants are
 | |
|      evaluated to a format whose range and precision may be greater than required by the type. Such a
 | |
|      format is called an evaluation format. In all cases, assignment and cast operators yield values in the
 | |
|      format of the type. The extent to which evaluation formats are used is characterized by the value of
 | |
|      FLT_EVAL_METHOD:<a href='#FOOTNOTE.27'><sup>[27]</sup></a>
 | |
| 
 | |
|      −1      indeterminable;
 | |
|       0      evaluate all operations and constants just to the range and precision of the type;
 | |
|       1      evaluate operations and constants of type float and double to the range and precision of
 | |
|              the double type, evaluate long double operations and constants to the range and precision
 | |
|              of the long double type;
 | |
|       2      evaluate all operations and constants to the range and precision of the long double type.
 | |
| 
 | |
|      All other negative values for FLT_EVAL_METHOD characterize implementation-defined behavior. The
 | |
|      value of FLT_EVAL_METHOD does not characterize values returned by function calls (see <a href='#6.8.6.4'>6.8.6.4</a>, <a href='#F.6'>F.6</a>).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.27'>
 | |
| <pre><i><b>Footnote 27)</b> The evaluation method determines evaluation formats of expressions involving all floating types, not just real
 | |
|      types. For example, if FLT_EVAL_METHOD is 1, then the product of two float _Complex operands is represented in the
 | |
|      double _Complex format, and its parts are evaluated to double.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.2p20'></a>
 | |
| <pre>20   The presence or absence of subnormal numbers is characterized by the implementation-defined
 | |
|      values of FLT_HAS_SUBNORM, DBL_HAS_SUBNORM, and LDBL_HAS_SUBNORM:
 | |
| 
 | |
|      −1      indeterminable
 | |
|       0     absent (type does not support subnormal numbers)
 | |
| 
 | |
|       1     present (type does support subnormal numbers)
 | |
| 
 | |
|      The use of FLT_HAS_SUBNORM, DBL_HAS_SUBNORM, and LDBL_HAS_SUBNORM macros is an obsolescent
 | |
|      feature.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p21'></a>
 | |
| <pre>21   The signaling NaN macros
 | |
| 
 | |
|              FLT_SNAN
 | |
|              DBL_SNAN
 | |
|              LDBL_SNAN
 | |
| 
 | |
| 
 | |
|      each is defined if and only if the respective type contains signaling NaNs. They expand to a constant
 | |
|      expression of the respective type representing a signaling NaN. If an optional unary + or - operator
 | |
|      followed by a signaling NaN macro is used as the initializer for initializing an object of the same
 | |
|      type that has static or thread storage duration, the object is initialized with a signaling NaN value.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p22'></a>
 | |
| <pre>22   The macro
 | |
| 
 | |
|              INFINITY
 | |
| 
 | |
| 
 | |
|      is defined if and only if the implementation supports an infinity for the type float. It expands to a
 | |
|      constant expression of type float representing positive or unsigned infinity.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p23'></a>
 | |
| <pre>23   The macro
 | |
| 
 | |
|              NAN
 | |
| 
 | |
| 
 | |
|      is defined if and only if the implementation supports quiet NaNs for the float type. It expands to a
 | |
|      constant expression of type float representing a quiet NaN.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p24'></a>
 | |
| <pre>24   The values given in the following list shall be replaced by constant expressions with implementation-
 | |
|      defined values that are greater or equal in magnitude (absolute value) to those shown, with the
 | |
|      same sign:
 | |
| 
 | |
|        — radix of exponent representation, b
 | |
| 
 | |
|             FLT_RADIX                             2
 | |
| 
 | |
| 
 | |
| 
 | |
|        — number of base-FLT_RADIX digits in the floating-point significand, p
 | |
| 
 | |
|             FLT_MANT_DIG
 | |
|             DBL_MANT_DIG
 | |
|             LDBL_MANT_DIG
 | |
| 
 | |
| 
 | |
| 
 | |
|        — number of decimal digits, n, such that any floating-point number with p radix b digits can be
 | |
|          rounded to a floating-point number with n decimal digits and back again without change to
 | |
|          the value,
 | |
|                (
 | |
|                  p log10 b       if b is a power of 10
 | |
|                  ⌈1 + p log10 b⌉ otherwise
 | |
| 
 | |
| 
 | |
|             FLT_DECIMAL_DIG                        6
 | |
|             DBL_DECIMAL_DIG                       10
 | |
|             LDBL_DECIMAL_DIG                      10
 | |
|        — number of decimal digits, n, such that any floating-point number in the widest of the supported
 | |
|          floating types and the supported IEC 60559 encodings with pmax radix b digits can be rounded
 | |
|          to a floating-point number with n decimal digits and back again without change to the value,
 | |
|                 (
 | |
|                   pmax log10 b       if b is a power of 10
 | |
|                   ⌈1 + pmax log10 b⌉ otherwise
 | |
| 
 | |
|             DECIMAL_DIG                          10
 | |
| 
 | |
|           This is an obsolescent feature, see <a href='#7.33.8'>7.33.8</a>.
 | |
|        — number of decimal digits, q, such that any floating-point number with q decimal digits can be
 | |
|          rounded into a floating-point number with p radix b digits and back again without change to
 | |
|          the q decimal digits,
 | |
|                (
 | |
|                  p log10 b         if b is a power of 10
 | |
|                  ⌊(p − 1) log10 b⌋ otherwise
 | |
| 
 | |
|             FLT_DIG                               6
 | |
|             DBL_DIG                              10
 | |
|             LDBL_DIG                             10
 | |
| 
 | |
| 
 | |
|        — minimum negative integer such that FLT_RADIX raised to one less than that power is a normal-
 | |
|          ized floating-point number, emin
 | |
| 
 | |
|             FLT_MIN_EXP
 | |
|             DBL_MIN_EXP
 | |
|             LDBL_MIN_EXP
 | |
| 
 | |
| 
 | |
|        — minimum negative integer
 | |
|                                  such that10 raised to that power is in the range of normalized
 | |
|          floating-point numbers, log10 bemin −1
 | |
| 
 | |
|             FLT_MIN_10_EXP                      -37
 | |
|             DBL_MIN_10_EXP                      -37
 | |
|             LDBL_MIN_10_EXP                     -37
 | |
| 
 | |
| 
 | |
|        — maximum integer such that FLT_RADIX raised to one less than that power is a representable
 | |
|          finite floating-point number; if that representable finite floating-point number is normalized,
 | |
|          the value of the macro is emax
 | |
| 
 | |
|             FLT_MAX_EXP
 | |
|             DBL_MAX_EXP
 | |
|             LDBL_MAX_EXP
 | |
| 
 | |
| 
 | |
|        — maximum integer such that 10 raised to that power is in the range of representable finite
 | |
|          floating-point numbers, ⌊log10 ((1 − b−p )bemax )⌋
 | |
| 
 | |
|             FLT_MAX_10_EXP                      +37
 | |
|             DBL_MAX_10_EXP                      +37
 | |
|             LDBL_MAX_10_EXP                     +37
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p25'></a>
 | |
| <pre>25   The values given in the following list shall be replaced by constant expressions with implementation-
 | |
|      defined values that are greater than or equal to those shown:
 | |
| 
 | |
|        — maximum representable finite floating-point number; if that number is normalized, its value is
 | |
|          (1 − b−p )bemax
 | |
|              FLT_MAX                                    1E+37
 | |
|              DBL_MAX                                    1E+37
 | |
|              LDBL_MAX                                   1E+37
 | |
| 
 | |
| 
 | |
|        — maximum normalized floating-point number, (1 − b−p )bemax
 | |
| 
 | |
|              FLT_NORM_MAX                               1E+37
 | |
|              DBL_NORM_MAX                               1E+37
 | |
|              LDBL_NORM_MAX                              1E+37
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p26'></a>
 | |
| <pre>26   The values given in the following list shall be replaced by constant expressions with implementation-
 | |
|      defined (positive) values that are less than or equal to those shown:
 | |
| 
 | |
|        — the difference between 1 and the least normalized value greater than 1 that is representable in
 | |
|          the given floating type, b1−p
 | |
| 
 | |
|              FLT_EPSILON                                1E-5
 | |
|              DBL_EPSILON                                1E-9
 | |
|              LDBL_EPSILON                               1E-9
 | |
| 
 | |
| 
 | |
|        — minimum normalized positive floating-point number, bemin −1
 | |
| 
 | |
|              FLT_MIN                                    1E-37
 | |
|              DBL_MIN                                    1E-37
 | |
|              LDBL_MIN                                   1E-37
 | |
| 
 | |
| 
 | |
|        — minimum positive floating-point number<a href='#FOOTNOTE.28'><sup>[28]</sup></a>
 | |
| 
 | |
|              FLT_TRUE_MIN                               1E-37
 | |
|              DBL_TRUE_MIN                               1E-37
 | |
|              LDBL_TRUE_MIN                              1E-37
 | |
| 
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.28'>
 | |
| <pre><i><b>Footnote 28)</b> If the presence or absence of subnormal numbers is indeterminable, then the value is intended to be a positive number
 | |
|      no greater than the minimum normalized positive number for the type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.2p27'></a>
 | |
| <pre>27   Conversion between real floating type and decimal character sequence with at most T_DECIMAL_DIG
 | |
|      digits should be correctly rounded, where T is the macro prefix for the type. This assures conversion
 | |
|      from real floating type to decimal character sequence with T_DECIMAL_DIG digits and back, using
 | |
|      to-nearest rounding, is the identity function.
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p28'></a>
 | |
| <pre>28   EXAMPLE 1 The following describes an artificial floating-point representation that meets the minimum requirements of this
 | |
|      document, and the appropriate values in a <float.h> header for type float:
 | |
|                       6
 | |
|            x = s16e         fk 16−k ,
 | |
|                       P
 | |
|                                         −31 ≤ e ≤ +32
 | |
|                       k=1
 | |
| 
 | |
| 
 | |
| 
 | |
|                FLT_RADIX                                  16
 | |
|                FLT_MANT_DIG                                6
 | |
|                FLT_EPSILON                   9.53674316E-07F
 | |
|                FLT_DECIMAL_DIG                             9
 | |
|                FLT_DIG                                     6
 | |
|                FLT_MIN_EXP                               -31
 | |
|                FLT_MIN                       <a href='#2.'>2.</a>93873588E-39F
 | |
|                FLT_MIN_10_EXP                            -38
 | |
|                FLT_MAX_EXP                               +32
 | |
|                FLT_MAX                       <a href='#3.'>3.</a>40282347E+38F
 | |
|                FLT_MAX_10_EXP                            +38
 | |
| </pre>
 | |
| <a name='5.2.4.2.2p29'></a>
 | |
| <pre>29   EXAMPLE 2 The following describes floating-point representations that also meet the requirements for single-precision and
 | |
|      double-precision numbers in IEC 60559,<a href='#FOOTNOTE.29'><sup>[29]</sup></a> and the appropriate values in a <float.h> header for types float and double:
 | |
|                       24
 | |
|            xf = s2e         fk 2−k ,
 | |
|                       P
 | |
|                                        −125 ≤ e ≤ +128
 | |
|                       k=1
 | |
| 
 | |
|                       53
 | |
|            xd = s2e         fk 2−k ,
 | |
|                       P
 | |
|                                        −1021 ≤ e ≤ +1024
 | |
|                       k=1
 | |
| 
 | |
| 
 | |
| 
 | |
|                FLT_IS_IEC_60559                   2
 | |
|                FLT_RADIX                          2
 | |
|                FLT_MANT_DIG                      24
 | |
|                FLT_EPSILON          <a href='#1.'>1.</a>19209290E-07F // decimal constant
 | |
|                FLT_EPSILON                 0X1P-23F // hex constant
 | |
|                FLT_DECIMAL_DIG                    9
 | |
|                FLT_DIG                            6
 | |
|                FLT_MIN_EXP                     -125
 | |
|                FLT_MIN              <a href='#1.'>1.</a>17549435E-38F // decimal constant
 | |
|                FLT_MIN                    0X1P-126F // hex constant
 | |
|                FLT_TRUE_MIN         <a href='#1.'>1.</a>40129846E-45F // decimal constant
 | |
|                FLT_TRUE_MIN               0X1P-149F // hex constant
 | |
|                FLT_HAS_SUBNORM                    1
 | |
|                FLT_MIN_10_EXP                   -37
 | |
|                FLT_MAX_EXP                     +128
 | |
|                FLT_MAX              <a href='#3.'>3.</a>40282347E+38F // decimal constant
 | |
|                FLT_MAX              0X1.fffffeP127F // hex constant
 | |
|                FLT_MAX_10_EXP                   +38
 | |
|                DBL_MANT_DIG                      53
 | |
|                DBL_IS_IEC_60559                   2
 | |
|                DBL_EPSILON   <a href='#2.'>2.</a>2204460492503131E-16 // decimal constant
 | |
|                DBL_EPSILON                  0X1P-52 // hex constant
 | |
|                DBL_DECIMAL_DIG                   17
 | |
|                DBL_DIG                           15
 | |
|                DBL_MIN_EXP                    -1021
 | |
|                DBL_MIN      <a href='#2.'>2.</a>2250738585072014E-308 // decimal constant
 | |
|                DBL_MIN                    0X1P-1022 // hex constant
 | |
|                DBL_TRUE_MIN <a href='#4.'>4.</a>9406564584124654E-324 // decimal constant
 | |
|                DBL_TRUE_MIN               0X1P-1074 // hex constant
 | |
|                DBL_HAS_SUBNORM                    1
 | |
|                DBL_MIN_10_EXP                  -307
 | |
|                DBL_MAX_EXP                    +1024
 | |
|                DBL_MAX      <a href='#1.'>1.</a>7976931348623157E+308 // decimal constant
 | |
|                DBL_MAX       0X1.fffffffffffffP1023 // hex constant
 | |
|                DBL_MAX_10_EXP                  +308
 | |
| 
 | |
| 
 | |
|      Forward references: conditional inclusion (<a href='#6.10.1'>6.10.1</a>), predefined macro names (<a href='#6.10.9'>6.10.9</a>), complex arith-
 | |
|      metic <complex.h> (<a href='#7.3'>7.3</a>), extended multibyte and wide character utilities <wchar.h> (<a href='#7.31'>7.31</a>), floating-
 | |
|      point environment <fenv.h> (<a href='#7.6'>7.6</a>), general utilities <stdlib.h> (<a href='#7.24'>7.24</a>), input/output <stdio.h>
 | |
|      (<a href='#7.23'>7.23</a>), mathematics <math.h> (<a href='#7.12'>7.12</a>), IEC 60559 floating-point arithmetic (Annex F), IEC 60559-
 | |
|      compatible complex arithmetic (Annex G).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.29'>
 | |
| <pre><i><b>Footnote 29)</b> The floating-point model in that standard sums powers of b from zero, so the values of the exponent limits are one less
 | |
|      than shown here.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='5.2.4.2.3'></a>
 | |
| <hr>
 | |
| <h3>5.2.4.2.3 [Characteristics of decimal floating types in <float.h>]</h3>
 | |
| <a name='5.2.4.2.3p1'></a>
 | |
| <pre>1    This subclause specifies macros in <float.h> that provide characteristics of decimal floating types
 | |
|      (an optional feature) in terms of the model presented in <a href='#5.2.4.2.2'>5.2.4.2.2</a>. An implementation that does not
 | |
|      support decimal floating types shall not provide these macros. The prefixes DEC32_, DEC64_, and
 | |
|      DEC128_ denote the types _Decimal32 , _Decimal64 , and _Decimal128 respectively.
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p2'></a>
 | |
| <pre>2    DEC_EVAL_METHOD is the decimal floating-point analog of FLT_EVAL_METHOD (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). Its
 | |
|      implementation-defined value characterizes the use of evaluation formats for decimal floating
 | |
|     types:
 | |
| 
 | |
|     −1       indeterminable;
 | |
| 
 | |
|     0        evaluate all operations and constants just to the range and precision of the type;
 | |
| 
 | |
|     1        evaluate operations and constants of type _Decimal32 and _Decimal64 to the range and
 | |
|              precision of the _Decimal64 type, evaluate _Decimal128 operations and constants to the
 | |
|              range and precision of the _Decimal128 type;
 | |
| 
 | |
|     2        evaluate all operations and constants to the range and precision of the _Decimal128 type.
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p3'></a>
 | |
| <pre>3   Each of the decimal signaling NaN macros
 | |
| 
 | |
|               DEC32_SNAN
 | |
|               DEC64_SNAN
 | |
|               DEC128_SNAN
 | |
| 
 | |
| 
 | |
|     expands to a constant expression of the respective decimal floating type representing a signaling
 | |
|     NaN. If an optional unary + or - operator followed by a signaling NaN macro is used for initializing
 | |
|     an object of the same type that has static or thread storage duration, the object is initialized with a
 | |
|     signaling NaN value.
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p4'></a>
 | |
| <pre>4   The macro
 | |
| 
 | |
|               DEC_INFINITY
 | |
| 
 | |
| 
 | |
|     expands to a constant expression of type _Decimal32 representing positive infinity.
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p5'></a>
 | |
| <pre>5   The macro
 | |
| 
 | |
|               DEC_NAN
 | |
| 
 | |
| 
 | |
|     expands to a constant expression of type _Decimal32 representing a quiet NaN.
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p6'></a>
 | |
| <pre>6   The integer values given in the following lists shall be replaced by constant expressions suitable for
 | |
|     use in #if preprocessing directives:
 | |
| 
 | |
|         — radix of exponent representation, b(=10)
 | |
|            For the standard floating types, this value is implementation-defined and is specified by the
 | |
|            macro FLT_RADIX. For the decimal floating types there is no corresponding macro, since the
 | |
|            value 10 is an inherent property of the types. Wherever FLT_RADIX appears in a description
 | |
|            of a function that has versions that operate on decimal floating types, it is noted that for the
 | |
|            decimal floating-point versions the value used is implicitly 10, rather than FLT_RADIX.
 | |
| 
 | |
|         — number of digits in the coefficient
 | |
| 
 | |
|              DEC32_MANT_DIG       7
 | |
|              DEC64_MANT_DIG       16
 | |
|              DEC128_MANT_DIG      34
 | |
| 
 | |
| 
 | |
|         — minimum exponent
 | |
| 
 | |
|              DEC32_MIN_EXP        -94
 | |
|              DEC64_MIN_EXP        -382
 | |
|              DEC128_MIN_EXP       -6142
 | |
| 
 | |
| 
 | |
|         — maximum exponent
 | |
|            DEC32_MAX_EXP                 97
 | |
|            DEC64_MAX_EXP                 385
 | |
|            DEC128_MAX_EXP                6145
 | |
| 
 | |
| 
 | |
|       — maximum representable finite decimal floating-point number (there are 6, 15 and 33 9’s after
 | |
|         the decimal points respectively)
 | |
| 
 | |
|            DEC32_MAX                     9.999999E96DF
 | |
|            DEC64_MAX                     9.999999999999999E384DD
 | |
|            DEC128_MAX                    9.999999999999999999999999999999999E6144DL
 | |
| 
 | |
| 
 | |
|       — the difference between 1 and the least value greater than 1 that is representable in the given
 | |
|         floating type
 | |
| 
 | |
|            DEC32_EPSILON                 1E-6DF
 | |
|            DEC64_EPSILON                 1E-15DD
 | |
|            DEC128_EPSILON                1E-33DL
 | |
| 
 | |
| 
 | |
|       — minimum normalized positive decimal floating-point number
 | |
| 
 | |
|            DEC32_MIN                     1E-95DF
 | |
|            DEC64_MIN                     1E-383DD
 | |
|            DEC128_MIN                    1E-6143DL
 | |
| 
 | |
| 
 | |
|       — minimum positive subnormal decimal floating-point number
 | |
| 
 | |
|            DEC32_TRUE_MIN                0.000001E-95DF
 | |
|            DEC64_TRUE_MIN                0.000000000000001E-383DD
 | |
|            DEC128_TRUE_MIN               0.000000000000000000000000000000001E-6143DL
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p7'></a>
 | |
| <pre>7   For decimal floating-point arithmetic, it is often convenient to consider an alternate equivalent
 | |
|     model where the significand is represented with integer rather than fraction digits. With s, b, e, p,
 | |
|     and fk as defined in <a href='#5.2.4.2.2'>5.2.4.2.2</a>, a floating-point number x is defined by the model:
 | |
|                            p
 | |
|                            X
 | |
|                   (e−p)
 | |
|           x=s·b                  fk · b(p−k)
 | |
|                            k=1
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p8'></a>
 | |
| <pre>8   With b fixed to 10, a decimal floating-point number x is thus:
 | |
|                                p
 | |
|                                X
 | |
|                        (e−p)
 | |
|           x = s · 10                 fk · 10(p−k)
 | |
|                                k=1
 | |
| 
 | |
|     The quantum exponent is q = e − p and the coefficient is c = f1 f2 · · · fp , which is an integer between
 | |
|     0 and 10(p−1) , inclusive. Thus, x = s · c · 10q is represented by the triple of integers (s, c, q). The
 | |
|     quantum of x is 10q , which is the value of a unit in the last place of the coefficient.
 | |
| 
 | |
|                                                     Quantum exponent ranges
 | |
| 
 | |
|            Type                                               _Decimal32   _Decimal64   _Decimal128
 | |
|            Maximum Quantum Exponent (qmax )                       90          369          6111
 | |
|            Minimum Quantum Exponent (qmin )                      −101         −398         −6176
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p9'></a>
 | |
| <pre>9   For binary floating-point arithmetic following IEC 60559, representations in the model described
 | |
|     in <a href='#5.2.4.2.2'>5.2.4.2.2</a> that have the same numerical value are indistinguishable in the arithmetic. However, for
 | |
|      decimal floating-point arithmetic, representations that have the same numerical value but different
 | |
|      quantum exponents, e.g., (+1, 10, −1) representing 1.0 and (+1, 100, −2) representing 1.00, are
 | |
|      distinguishable. To facilitate exact fixed-point calculation, operation results that are of decimal
 | |
|      floating type have a preferred quantum exponent, as specified in IEC 60559, which is determined
 | |
|      by the quantum exponents of the operands if they have decimal floating types (or by specific
 | |
|      rules for conversions from other types). The table below gives rules for determining preferred
 | |
|      quantum exponents for results of IEC 60559 operations, and for other operations specified in
 | |
|      this document. When exact, these operations produce a result with their preferred quantum
 | |
|      exponent, or as close to it as possible within the limitations of the type. When inexact, these
 | |
|      operations produce a result with the least possible quantum exponent. For example, the preferred
 | |
|      quantum exponent for addition is the minimum of the quantum exponents of the operands. Hence
 | |
|      (+1, 123, −2) + (+1, 4000, −3) = (+1, 5230, −3) or 1.23 + 4.000 = 5.230.
 | |
| </pre>
 | |
| <a name='5.2.4.2.3p10'></a>
 | |
| <pre>10   The following table shows, for each operation delivering a result in decimal floating-point format,
 | |
|      how the preferred quantum exponents of the operands, Q(x), Q(y), etc., determine the preferred
 | |
|      quantum exponent of the operation result, provided the table formula is defined for the arguments.
 | |
|      For the cases where the formula is undefined and the function result is ±∞, the preferred quantum
 | |
|      exponent is immaterial because the quantum exponent of ±∞ is defined to be infinity. For the
 | |
|      other cases where the formula is undefined and the function result is finite, the preferred quantum
 | |
|      exponent is unspecified<a href='#FOOTNOTE.30'><sup>[30]</sup></a> .
 | |
| 
 | |
|                                                      Preferred quantum exponents
 | |
| 
 | |
|             Operation                                                 Preferred quantum exponent of result
 | |
|             roundeven, round, trunc, ceil, floor,                     max(Q(x), 0)
 | |
|             rint, nearbyint
 | |
|             nextup, nextdown, nextafter, nexttoward                   least possible
 | |
|             remainder                                                 min(Q(x), Q(y))
 | |
|             fmin,    fmax,    fminimum,    fmaximum,                  Q(x) if x gives the result, Q(y) if y gives the result
 | |
|             fminimum_mag,             fmaximum_mag,
 | |
|             fminimum_num,             fmaximum_num,
 | |
|             fminimum_mag_num, fmaximum_mag_num
 | |
|             scalbn, scalbln                                           Q(x) + n
 | |
|             ldexp                                                     Q(x) + p
 | |
|             logb                                                      0
 | |
|            + , d32add, d64add                                         min(Q(x), Q(y))
 | |
|            - , d32sub, d64sub                                         min(Q(x), Q(y))
 | |
|            * , d32mul, d64mul                                         Q(x) + Q(y)
 | |
|            / , d32div, d64div                                         Q(x) − Q(y)
 | |
|             sqrt, d32sqrt, d64sqrt                                    ⌊Q(x)/2⌋
 | |
|             fma, d32fma, d64fma                                       min(Q(x) + Q(y), Q(z))
 | |
|             conversion from integer type                              0
 | |
|             exact conversion from non-decimal floating                0
 | |
|             type
 | |
|             inexact conversion from non-decimal floating              least possible
 | |
|             type
 | |
|             conversion between decimal floating types                 Q(x)
 | |
|            *cx returned by canonicalize                               Q(*x )
 | |
|             strto, wcsto, scanf, floating constants of                see <a href='#7.24.1.6'>7.24.1.6</a>
 | |
|             decimal floating type
 | |
|            -(x) , +(x)                                                Q(x)
 | |
|             fabs                                                      Q(x)
 | |
|             copysign                                                  Q(x)
 | |
|             quantize                                                  Q(y)
 | |
|       quantum                                        Q(x)
 | |
|      *encptr returned by encodedec, encodebin        Q(*xptr )
 | |
|      *xptr returned by decodedec, decodebin          Q(*encptr )
 | |
|      fmod                                            min(Q(x), Q(y))
 | |
|      fdim                                            min((Q(x), Q(y)) if x > y, 0 if x ≤ y
 | |
|      cbrt                                            ⌊Q(x)/3⌋
 | |
|      hypot                                           min(Q(x), Q(y))
 | |
|      pow                                             ⌊y × Q(x)⌋
 | |
|      modf                                            Q(value)
 | |
|      *iptr returned by modf                          max(Q(value), 0)
 | |
|      frexp                                           Q(value) if value = 0, –(length of coefficient of
 | |
|                                                      value) otherwise
 | |
|      *res    returned         by      setpayload,    0 if pl does not represent a valid payload, not
 | |
|      setpayloadsig                                   applicable otherwise (NaN returned)
 | |
|      getpayload                                      0 if *x is a NaN, unspecified otherwise
 | |
|      compoundn                                       ⌊n × min(0, Q(x))⌋
 | |
|      pown                                            ⌊n × Q(x)⌋
 | |
|      powr                                            ⌊y × Q(x)⌋
 | |
|      rootn                                           ⌊Q(x)/n⌋
 | |
|      rsqrt                                           −⌊Q(x)/2⌋
 | |
|       transcendental functions                       0
 | |
| 
 | |
| 
 | |
| A function family listed in the table above indicates the functions for all decimal floating types,
 | |
| where the function family is represented by the name of the functions without a suffix. For example,
 | |
| ceil indicates the functions ceild32, ceild64, and ceild128.
 | |
| Forward references: extended multibyte and wide character utilities <wchar.h> (<a href='#7.31'>7.31</a>), floating-
 | |
| point environment <fenv.h> (<a href='#7.6'>7.6</a>), general utilities <stdlib.h> (<a href='#7.24'>7.24</a>), input/output <stdio.h>
 | |
| (<a href='#7.23'>7.23</a>), mathematics <math.h> (<a href='#7.12'>7.12</a>), type-generic mathematics <tgmath.h> (<a href='#7.27'>7.27</a>), IEC 60559
 | |
| floating-point arithmetic (Annex F).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.30'>
 | |
| <pre><i><b>Footnote 30)</b> Although unspecified in IEC 60559, a preferred quantum exponent of 0 for these cases would be a reasonable implemen-
 | |
|      tation choice.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.'></a>
 | |
| <hr>
 | |
| <h3>6. [Language]</h3>
 | |
| <a name='6.1'></a>
 | |
| <hr>
 | |
| <h3>6.1 [Notation]</h3>
 | |
| <a name='6.1p1'></a>
 | |
| <pre>1   In the syntax notation used in this clause, syntactic categories (nonterminals) are indicated by italic
 | |
|     type, and literal words and character set members (terminals) by bold type. A colon (:) following
 | |
|     a nonterminal introduces its definition. Alternative definitions are listed on separate lines, except
 | |
|     when prefaced by the words "one of". An optional symbol is indicated by the subscript "opt", so
 | |
|     that
 | |
|               { expressionopt }
 | |
|     indicates an optional expression enclosed in braces.
 | |
| </pre>
 | |
| <a name='6.1p2'></a>
 | |
| <pre>2   When syntactic categories are referred to in the main text, they are not italicized and words are
 | |
|     separated by spaces instead of hyphens.
 | |
| </pre>
 | |
| <a name='6.1p3'></a>
 | |
| <pre>3   A summary of the language syntax is given in Annex A.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2'></a>
 | |
| <hr>
 | |
| <h3>6.2 [Concepts]</h3>
 | |
| <a name='6.2.1'></a>
 | |
| <hr>
 | |
| <h3>6.2.1 [Scopes of identifiers]</h3>
 | |
| <a name='6.2.1p1'></a>
 | |
| <pre>1   An identifier can denote:
 | |
| 
 | |
|       — an object; a function;
 | |
|       — a tag or a member of a structure, union, or enumeration;
 | |
|       — a typedef name;
 | |
|       — a label name;
 | |
|       — a macro name;
 | |
|       — or, a macro parameter.
 | |
| 
 | |
|     The same identifier can denote different entities at different points in the program. A member
 | |
|     of an enumeration is called an enumeration constant. Macro names and macro parameters are not
 | |
|     considered further here, because prior to the semantic phase of program translation any occurrences
 | |
|     of macro names in the source file are replaced by the preprocessing token sequences that constitute
 | |
|     their macro definitions.
 | |
| </pre>
 | |
| <a name='6.2.1p2'></a>
 | |
| <pre>2   For each different entity that an identifier designates, the identifier is visible (i.e., can be used) only
 | |
|     within a region of program text called its scope. Different entities designated by the same identifier
 | |
|     either have different scopes, or are in different name spaces. There are four kinds of scopes: function,
 | |
|     file, block, and function prototype. (A function prototype is a declaration of a function.)
 | |
| </pre>
 | |
| <a name='6.2.1p3'></a>
 | |
| <pre>3   A label name is the only kind of identifier that has function scope. It can be used (in a goto statement)
 | |
|     anywhere in the function in which it appears, and is declared implicitly by its syntactic appearance
 | |
|     (followed by a : and a statement).
 | |
| </pre>
 | |
| <a name='6.2.1p4'></a>
 | |
| <pre>4   Every other identifier has scope determined by the placement of its declaration (in a declarator or
 | |
|     type specifier). If the declarator or type specifier that declares the identifier appears outside of any
 | |
|     block or list of parameters, the identifier has file scope, which terminates at the end of the translation
 | |
|     unit. If the declarator or type specifier that declares the identifier appears inside a block or within the
 | |
|     list of parameter declarations in a function definition, the identifier has block scope, which terminates
 | |
|     at the end of the associated block. If the declarator or type specifier that declares the identifier
 | |
|     appears within the list of parameter declarations in a function prototype (not part of a function
 | |
|     definition), the identifier has function prototype scope, which terminates at the end of the function
 | |
|     declarator. If an identifier designates two different entities in the same name space, the scopes might
 | |
|     overlap. If so, the scope of one entity (the inner scope) will end strictly before the scope of the other
 | |
|     entity (the outer scope). Within the inner scope, the identifier designates the entity declared in the
 | |
|     inner scope; the entity declared in the outer scope is hidden (and not visible) within the inner scope.
 | |
| </pre>
 | |
| <a name='6.2.1p5'></a>
 | |
| <pre>5   Unless explicitly stated otherwise, where this document uses the term "identifier" to refer to some
 | |
|     entity (as opposed to the syntactic construct), it refers to the entity in the relevant name space whose
 | |
|     declaration is visible at the point the identifier occurs.
 | |
| </pre>
 | |
| <a name='6.2.1p6'></a>
 | |
| <pre>6   Two identifiers have the same scope if and only if their scopes terminate at the same point.
 | |
| </pre>
 | |
| <a name='6.2.1p7'></a>
 | |
| <pre>7   Structure, union, and enumeration tags have scope that begins just after the appearance of the tag
 | |
|     in a type specifier that declares the tag. Each enumeration constant has scope that begins just after
 | |
|     the appearance of its defining enumerator in an enumerator list. An ordinary identifier that has an
 | |
|     underspecified definition has scope that starts when the definition is completed; if the same ordinary
 | |
|     identifier declares another entity with a scope that encloses the current block, that declaration is
 | |
|     hidden as soon as the inner declarator is completed<a href='#FOOTNOTE.31'><sup>[31]</sup></a> . Any other identifier has scope that begins
 | |
|     just after the completion of its declarator.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.31'>
 | |
| <pre><i><b>Footnote 31)</b> That means, that the outer declaration is not visible for the initializer
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.1p8'></a>
 | |
| <pre>8   As a special case, a type name (which is not a declaration of an identifier) is considered to have
 | |
|     a scope that begins just after the place within the type name where the omitted identifier would
 | |
|     appear were it not omitted.
 | |
|     Forward references: declarations (<a href='#6.7'>6.7</a>), function calls (<a href='#6.5.2.2'>6.5.2.2</a>), function definitions (<a href='#6.9.1'>6.9.1</a>), identifiers
 | |
|     (<a href='#6.4.2'>6.4.2</a>), macro replacement (<a href='#6.10.4'>6.10.4</a>), name spaces of identifiers (<a href='#6.2.3'>6.2.3</a>), source file inclusion (<a href='#6.10.2'>6.10.2</a>),
 | |
|     statements and blocks (<a href='#6.8'>6.8</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.2'></a>
 | |
| <hr>
 | |
| <h3>6.2.2 [Linkages of identifiers]</h3>
 | |
| <a name='6.2.2p1'></a>
 | |
| <pre>1   An identifier declared in different scopes or in the same scope more than once can be made to refer
 | |
|     to the same object or function by a process called linkage<a href='#FOOTNOTE.32'><sup>[32]</sup></a> . There are three kinds of linkage: external,
 | |
|     internal, and none.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.32'>
 | |
| <pre><i><b>Footnote 32)</b> There is no linkage between different identifiers.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.2p2'></a>
 | |
| <pre>2   In the set of translation units and libraries that constitutes an entire program, each declaration of a
 | |
|     particular identifier with external linkage denotes the same object or function. Within one translation
 | |
|     unit, each declaration of an identifier with internal linkage denotes the same object or function. Each
 | |
|     declaration of an identifier with no linkage denotes a unique entity.
 | |
| </pre>
 | |
| <a name='6.2.2p3'></a>
 | |
| <pre>3   If the declaration of a file scope identifier for:
 | |
| 
 | |
|       — an object contains any of the storage-class specifiers static or constexpr;
 | |
|       — or, a function contains the storage-class specifier static,
 | |
| 
 | |
|     then the identifier has internal linkage<a href='#FOOTNOTE.33'><sup>[33]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.33'>
 | |
| <pre><i><b>Footnote 33)</b> A function declaration can contain the storage-class specifier static only if it is at file scope; see <a href='#6.7.1'>6.7.1</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.2p4'></a>
 | |
| <pre>4   For an identifier declared with the storage-class specifier extern in a scope in which a prior dec-
 | |
|     laration of that identifier is visible<a href='#FOOTNOTE.34'><sup>[34]</sup></a> , if the prior declaration specifies internal or external linkage,
 | |
|     the linkage of the identifier at the later declaration is the same as the linkage specified at the prior
 | |
|     declaration. If no prior declaration is visible, or if the prior declaration specifies no linkage, then the
 | |
|     identifier has external linkage.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.34'>
 | |
| <pre><i><b>Footnote 34)</b> As specified in <a href='#6.2.1'>6.2.1</a>, the later declaration might hide the prior declaration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.2p5'></a>
 | |
| <pre>5   If the declaration of an identifier for a function has no storage-class specifier, its linkage is determined
 | |
|     exactly as if it were declared with the storage-class specifier extern. If the declaration of an identifier
 | |
|     for an object has file scope and no storage-class specifier or only the specifier auto, its linkage is
 | |
|     external.
 | |
| </pre>
 | |
| <a name='6.2.2p6'></a>
 | |
| <pre>6   The following identifiers have no linkage: an identifier declared to be anything other than an object
 | |
|     or a function; an identifier declared to be a function parameter; a block scope identifier for an object
 | |
|     declared without the storage-class specifier extern.
 | |
| </pre>
 | |
| <a name='6.2.2p7'></a>
 | |
| <pre>7   If, within a translation unit, the same identifier appears with both internal and external linkage, the
 | |
|     behavior is undefined.
 | |
|     Forward references: declarations (<a href='#6.7'>6.7</a>), expressions (<a href='#6.5'>6.5</a>), external definitions (<a href='#6.9'>6.9</a>), statements (<a href='#6.8'>6.8</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.3'></a>
 | |
| <hr>
 | |
| <h3>6.2.3 [Name spaces of identifiers]</h3>
 | |
| <a name='6.2.3p1'></a>
 | |
| <pre>1   If more than one declaration of a particular identifier is visible at any point in a translation unit, the
 | |
|     syntactic context disambiguates uses that refer to different entities. Thus, there are separate name
 | |
|     spaces for various categories of identifiers, as follows:
 | |
| 
 | |
|       — label names (disambiguated by the syntax of the label declaration and use);
 | |
| 
 | |
|       — the tags of structures, unions, and enumerations (disambiguated by following any35) of the
 | |
|         keywords struct, union, or enum);
 | |
| 
 | |
|       — the members of structures or unions; each structure or union has a separate name space for its
 | |
|         members (disambiguated by the type of the expression used to access the member via the . or
 | |
|        -> operator);
 | |
| 
 | |
|       — standard attributes and attribute prefixes (disambiguated by the syntax of the attribute specifier
 | |
|         and name of the attribute token) (<a href='#6.7.12'>6.7.12</a>);
 | |
| 
 | |
|       — the trailing identifier in an attribute prefixed token; each attribute prefix has a separate name
 | |
|         space for the implementation-defined attributes that it introduces (disambiguated by the
 | |
|         attribute prefix and the trailing identifier token);
 | |
| 
 | |
|       — all other identifiers, called ordinary identifiers (declared in ordinary declarators or as enumera-
 | |
|         tion constants).
 | |
| 
 | |
|     Forward references: enumeration specifiers (<a href='#6.7.2.2'>6.7.2.2</a>), labeled statements (<a href='#6.8.1'>6.8.1</a>), structure and union
 | |
|     specifiers (<a href='#6.7.2.1'>6.7.2.1</a>), structure and union members (<a href='#6.5.2.3'>6.5.2.3</a>), tags (<a href='#6.7.2.3'>6.7.2.3</a>), the goto statement (<a href='#6.8.6.1'>6.8.6.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.4'></a>
 | |
| <hr>
 | |
| <h3>6.2.4 [Storage durations of objects]</h3>
 | |
| <a name='6.2.4p1'></a>
 | |
| <pre>1   An object has a storage duration that determines its lifetime. There are four storage durations: static,
 | |
|     thread, automatic, and allocated. Allocated storage is described in <a href='#7.24.3'>7.24.3</a>.
 | |
| </pre>
 | |
| <a name='6.2.4p2'></a>
 | |
| <pre>2   The lifetime of an object is the portion of program execution during which storage is guaranteed
 | |
|     to be reserved for it. An object exists, has a constant address<a href='#FOOTNOTE.36'><sup>[36]</sup></a> , and retains its last-stored value
 | |
|     throughout its lifetime<a href='#FOOTNOTE.37'><sup>[37]</sup></a> . If an object is referred to outside of its lifetime, the behavior is undefined.
 | |
|     If a pointer value is used in an evaluation after the object the pointer points to (or just past) reaches
 | |
|     the end of its lifetime, the behavior is undefined. The representation of a pointer object becomes
 | |
|     indeterminate when the object the pointer points to (or just past) reaches the end of its lifetime.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.36'>
 | |
| <pre><i><b>Footnote 36)</b> The term "constant address" means that two pointers to the object constructed at possibly different times will compare
 | |
|     equal. The address can be different during two different executions of the same program.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.37'>
 | |
| <pre><i><b>Footnote 37)</b> In the case of a volatile object, the last store need not be explicit in the program.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.4p3'></a>
 | |
| <pre>3   An object whose identifier is declared without the storage-class specifier thread_local, and either
 | |
|     with external or internal linkage or with the storage-class specifier static, has static storage duration.
 | |
|     Its lifetime is the entire execution of the program and its stored value is initialized only once, prior
 | |
|     to program startup.
 | |
| </pre>
 | |
| <a name='6.2.4p4'></a>
 | |
| <pre>4   An object whose identifier is declared with the storage-class specifier thread_local has thread
 | |
|     storage duration. Its lifetime is the entire execution of the thread for which it is created, and its
 | |
|     stored value is initialized when the thread is started. There is a distinct object per thread, and use of
 | |
|     the declared name in an expression refers to the object associated with the thread evaluating the
 | |
|     expression. The result of attempting to indirectly access an object with thread storage duration from
 | |
|     a thread other than the one with which the object is associated is implementation-defined.
 | |
| </pre>
 | |
| <a name='6.2.4p5'></a>
 | |
| <pre>5   An object whose identifier is declared with no linkage and without the storage-class specifier static
 | |
|     has automatic storage duration, as do some compound literals. The result of attempting to indirectly
 | |
|     access an object with automatic storage duration from a thread other than the one with which the
 | |
|     object is associated is implementation-defined.
 | |
| </pre>
 | |
| <a name='6.2.4p6'></a>
 | |
| <pre>6   For such an object that does not have a variable length array type, its lifetime extends from entry
 | |
|     into the block with which it is associated until execution of that block ends in any way. (Entering
 | |
|     an enclosed block or calling a function suspends, but does not end, execution of the current block.)
 | |
|     If the block is entered recursively, a new instance of the object is created each time. The initial
 | |
|     representation of the object is indeterminate. If an initialization is specified for the object, it is
 | |
|     performed each time the declaration or compound literal is reached in the execution of the block;
 | |
|     otherwise, the representation of the object becomes indeterminate each time the declaration is
 | |
|     reached.
 | |
| </pre>
 | |
| <a name='6.2.4p7'></a>
 | |
| <pre>7   For such an object that does have a variable length array type, its lifetime extends from the declaration
 | |
|     of the object until execution of the program leaves the scope of the declaration<a href='#FOOTNOTE.38'><sup>[38]</sup></a> . If the scope is
 | |
|     entered recursively, a new instance of the object is created each time. The initial representation of
 | |
|     the object is indeterminate.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.38'>
 | |
| <pre><i><b>Footnote 38)</b> Leaving the innermost block containing the declaration, or jumping to a point in that block or an embedded block prior
 | |
|     to the declaration, leaves the scope of the declaration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.4p8'></a>
 | |
| <pre>8   A non-lvalue expression with structure or union type, where the structure or union contains a
 | |
|     member with array type (including, recursively, members of all contained structures and unions)
 | |
|     refers to an object with automatic storage duration and temporary lifetime.<a href='#FOOTNOTE.39'><sup>[39]</sup></a> Its lifetime begins
 | |
|     when the expression is evaluated and its initial value is the value of the expression. Its lifetime ends
 | |
|     when the evaluation of the containing full expression ends. Any attempt to modify an object with
 | |
|     temporary lifetime results in undefined behavior. An object with temporary lifetime behaves as if it
 | |
|     were declared with the type of its value for the purposes of effective type. Such an object need not
 | |
|     have a unique address.
 | |
|     Forward references: array declarators (<a href='#6.7.6.2'>6.7.6.2</a>), compound literals (<a href='#6.5.2.5'>6.5.2.5</a>), declarators (<a href='#6.7.6'>6.7.6</a>),
 | |
|     function calls (<a href='#6.5.2.2'>6.5.2.2</a>), initialization (<a href='#6.7.10'>6.7.10</a>), statements (<a href='#6.8'>6.8</a>), effective type (<a href='#6.5'>6.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.39'>
 | |
| <pre><i><b>Footnote 39)</b> The address of such an object is taken implicitly when an array member is accessed.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5'></a>
 | |
| <hr>
 | |
| <h3>6.2.5 [Types]</h3>
 | |
| <a name='6.2.5p1'></a>
 | |
| <pre>1   The meaning of a value stored in an object or returned by a function is determined by the type of the
 | |
|     expression used to access it. (An identifier declared to be an object is the simplest such expression;
 | |
|     the type is specified in the declaration of the identifier.) Types are partitioned into object types (types
 | |
|     that describe objects) and function types (types that describe functions). At various points within a
 | |
|     translation unit an object type may be incomplete<a href='#FOOTNOTE.40'><sup>[40]</sup></a> (lacking sufficient information to determine the
 | |
|     size of objects of that type) or complete (having sufficient information)41) .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.40'>
 | |
| <pre><i><b>Footnote 40)</b> An incomplete type can only be used when the size of an object of that type is not needed. It is not needed, for example,
 | |
|     when a typedef name is declared to be a specifier for a structure or union, or when a pointer to or a function returning a
 | |
|     structure or union is being declared. The specification has to be complete before such a function is called or defined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p2'></a>
 | |
| <pre>2   An object declared as type bool is large enough to store the values false and true.
 | |
| </pre>
 | |
| <a name='6.2.5p3'></a>
 | |
| <pre>3   An object declared as type char is large enough to store any member of the basic execution char-
 | |
|     acter set. If a member of the basic execution character set is stored in a char object, its value is
 | |
|     guaranteed to be nonnegative. If any other character is stored in a char object, the resulting value is
 | |
|     implementation-defined but shall be within the range of values that can be represented in that type.
 | |
| </pre>
 | |
| <a name='6.2.5p4'></a>
 | |
| <pre>4   There are five standard signed integer types, designated as signed char, short int, int, long int,
 | |
|     and long long int. (These and other types may be designated in several additional ways, as
 | |
|     described in <a href='#6.7.2'>6.7.2</a>.)
 | |
| </pre>
 | |
| <a name='6.2.5p5'></a>
 | |
| <pre>5   A bit-precise signed integer type is designated as _BitInt( N) where N is an integer constant expression
 | |
|     that specifies the number of bits that are used to represent the type, including the sign bit. Each
 | |
|     value of N designates a distinct type<a href='#FOOTNOTE.42'><sup>[42]</sup></a> . There may also be implementation-defined extended signed
 | |
|     integer types <a href='#FOOTNOTE.43'><sup>[43]</sup></a> . The standard signed integer types, bit-precise signed integer types, and extended
 | |
|     signed integer types are collectively called signed integer types. <a href='#FOOTNOTE.44'><sup>[44]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.42'>
 | |
| <pre><i><b>Footnote 42)</b> Thus, _BitInt(3) is not the same type as _BitInt(4) .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.43'>
 | |
| <pre><i><b>Footnote 43)</b> Implementation-defined keywords have the form of an identifier reserved for any use as described in <a href='#7.1.3'>7.1.3</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.44'>
 | |
| <pre><i><b>Footnote 44)</b> Any statement in this document about signed integer types also applies to the bit-precise signed integer types and the
 | |
|     extended signed integer types, unless otherwise noted.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p6'></a>
 | |
| <pre>6    An object declared as type signed char occupies the same amount of storage as a "plain" char
 | |
|      object. A "plain" int object has the natural size suggested by the architecture of the execution
 | |
|      environment (large enough to contain any value in the range INT_MIN to INT_MAX as defined in the
 | |
|      header <limits.h>).
 | |
| </pre>
 | |
| <a name='6.2.5p7'></a>
 | |
| <pre>7    For each of the signed integer types, there is a corresponding (but different) unsigned integer type
 | |
|      (designated with the keyword unsigned) that uses the same amount of storage (including sign
 | |
|      information) and has the same alignment requirements. The type bool and the unsigned integer
 | |
|      types that correspond to the standard signed integer types are the standard unsigned integer types. The
 | |
|      unsigned integer types that correspond to the extended signed integer types are the extended unsigned
 | |
|      integer types. The unsigned integer types that correspond to the bit-precise signed integer types
 | |
|      are the bit-precise unsigned integer types. The standard unsigned integer types, bit-precise unsigned
 | |
|      integer types, and extended unsigned integer types are collectively called unsigned integer types.<a href='#FOOTNOTE.45'><sup>[45]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.45'>
 | |
| <pre><i><b>Footnote 45)</b> Any statement in this document about unsigned integer types also applies to the bit-precise unsigned integer types and
 | |
|      the extended unsigned integer types, unless otherwise specified.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p8'></a>
 | |
| <pre>8    The standard signed integer types and standard unsigned integer types are collectively called the
 | |
|      standard integer types; the bit-precise signed integer types and bit-precise unsigned integer types
 | |
|      are collectively called the bit-precise integer types the extended signed integer types and extended
 | |
|      unsigned integer types are collectively called the extended integer types.
 | |
| </pre>
 | |
| <a name='6.2.5p9'></a>
 | |
| <pre>9    For any two integer types with the same signedness and different integer conversion rank (see
 | |
|      <a href='#6.3.1.1'>6.3.1.1</a>), the range of values of the type with smaller integer conversion rank is a subrange of the
 | |
|      values of the other type.
 | |
| </pre>
 | |
| <a name='6.2.5p10'></a>
 | |
| <pre>10   The range of nonnegative values of a signed integer type is a subrange of the corresponding unsigned
 | |
|      integer type, and the representation of the same value in each type is the same.<a href='#FOOTNOTE.46'><sup>[46]</sup></a> The range of
 | |
|      representable values for the unsigned type is 0 to 2N − 1 (inclusive). A computation involving
 | |
|      unsigned operands can never produce an overflow, because arithmetic for the unsigned type is
 | |
|      performed modulo 2N .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.46'>
 | |
| <pre><i><b>Footnote 46)</b> The same representation and alignment requirements are meant to imply interchangeability as arguments to functions,
 | |
|      return values from functions, and members of unions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p11'></a>
 | |
| <pre>11   There are three standard floating types, designated as float, double, and long double. <a href='#FOOTNOTE.47'><sup>[47]</sup></a> The set
 | |
|      of values of the type float is a subset of the set of values of the type double; the set of values of the
 | |
|      type double is a subset of the set of values of the type long double.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.47'>
 | |
| <pre><i><b>Footnote 47)</b> See "future language directions" (<a href='#6.11.1'>6.11.1</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p12'></a>
 | |
| <pre>12   There are three decimal floating types, designated as _Decimal32 , _Decimal64 , and _Decimal128 .
 | |
|      Respectively, they have the IEC 60559 formats: decimal32,<a href='#FOOTNOTE.48'><sup>[48]</sup></a> decimal64, and decimal128. Decimal
 | |
|      floating types are real floating types.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.48'>
 | |
| <pre><i><b>Footnote 48)</b> IEC 60559 specifies decimal32 as a data-interchange format that does not require arithmetic support; however,
 | |
|      _Decimal32 is a fully supported arithmetic type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p13'></a>
 | |
| <pre>13   The standard floating types and the decimal floating types are collectively called the real floating
 | |
|      types.
 | |
| </pre>
 | |
| <a name='6.2.5p14'></a>
 | |
| <pre>14   There are three complex types, designated as float _Complex, double _Complex, and long double
 | |
|      _Complex .<a href='#FOOTNOTE.49'><sup>[49]</sup></a> (Complex types are a conditional feature that implementations need not support; see
 | |
|      <a href='#6.10.9.3'>6.10.9.3</a>.) The real floating and complex types are collectively called the floating types.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.49'>
 | |
| <pre><i><b>Footnote 49)</b> A specification for imaginary types is in Annex G.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p15'></a>
 | |
| <pre>15   For each floating type there is a corresponding real type, which is always a real floating type. For real
 | |
|      floating types, it is the same type. For complex types, it is the type given by deleting the keyword
 | |
|      _Complex from the type name.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.5p16'></a>
 | |
| <pre>16   Each complex type has the same representation and alignment requirements as an array type
 | |
|      containing exactly two elements of the corresponding real type; the first element is equal to the real
 | |
|      part, and the second element to the imaginary part, of the complex number.
 | |
| </pre>
 | |
| <a name='6.2.5p17'></a>
 | |
| <pre>17   The type char, the signed and unsigned integer types, and the floating types are collectively called
 | |
|      the basic types. The basic types are complete object types. Even if the implementation defines two or
 | |
|      more basic types to have the same representation, they are nevertheless different types.<a href='#FOOTNOTE.50'><sup>[50]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.50'>
 | |
| <pre><i><b>Footnote 50)</b> An implementation can define new keywords that provide alternative ways to designate a basic (or any other) type; this
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p18'></a>
 | |
| <pre>18   The three types char, signed char, and unsigned char are collectively called the character types.
 | |
|      The implementation shall define char to have the same range, representation, and behavior as either
 | |
|      signed char or unsigned char.<a href='#FOOTNOTE.51'><sup>[51]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.51'>
 | |
| <pre><i><b>Footnote 51)</b> CHAR_MIN, defined in <limits.h>, will have one of the values 0 or SCHAR_MIN, and this can be used to distinguish the
 | |
|      two options. Irrespective of the choice made, char is a separate type from the other two and is not compatible with either.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p19'></a>
 | |
| <pre>19   An enumeration comprises a set of named integer constant values. Each distinct enumeration
 | |
|      constitutes a different enumerated type.
 | |
| </pre>
 | |
| <a name='6.2.5p20'></a>
 | |
| <pre>20   The type char, the signed and unsigned integer types, and the enumerated types are collectively
 | |
|      called integer types. The integer and real floating types are collectively called real types.
 | |
| </pre>
 | |
| <a name='6.2.5p21'></a>
 | |
| <pre>21   Integer and floating types are collectively called arithmetic types. Each arithmetic type belongs to
 | |
|      one type domain: the real type domain comprises the real types, the complex type domain comprises the
 | |
|      complex types.
 | |
| </pre>
 | |
| <a name='6.2.5p22'></a>
 | |
| <pre>22   The void type comprises an empty set of values; it is an incomplete object type that cannot be
 | |
|      completed.
 | |
| </pre>
 | |
| <a name='6.2.5p23'></a>
 | |
| <pre>23   Any number of derived types can be constructed from the object and function types, as follows:
 | |
| 
 | |
|        — An array type describes a contiguously allocated nonempty set of objects with a particular
 | |
|          member object type, called the element type. The element type shall be complete whenever the
 | |
|          array type is specified. Array types are characterized by their element type and by the number
 | |
|          of elements in the array. An array type is said to be derived from its element type, and if its
 | |
|          element type is T, the array type is sometimes called "array of T". The construction of an array
 | |
|          type from an element type is called "array type derivation".
 | |
| 
 | |
|        — A structure type describes a sequentially allocated nonempty set of member objects (and, in
 | |
|          certain circumstances, an incomplete array), each of which has an optionally specified name
 | |
|          and possibly distinct type.
 | |
| 
 | |
|        — A union type describes an overlapping nonempty set of member objects, each of which has an
 | |
|          optionally specified name and possibly distinct type.
 | |
| 
 | |
|        — A function type describes a function with specified return type. A function type is characterized
 | |
|          by its return type and the number and types of its parameters. A function type is said to
 | |
|          be derived from its return type, and if its return type is T, the function type is sometimes
 | |
|          called "function returning T". The construction of a function type from a return type is called
 | |
|          "function type derivation".
 | |
| 
 | |
|        — A pointer type may be derived from a function type or an object type, called the referenced type. A
 | |
|          pointer type describes an object whose value provides a reference to an entity of the referenced
 | |
|          type. A pointer type derived from the referenced type T is sometimes called "pointer to T".
 | |
|          The construction of a pointer type from a referenced type is called "pointer type derivation".
 | |
|          A pointer type is a complete object type.
 | |
| 
 | |
|        — An atomic type describes the type designated by the construct _Atomic (type-name). (Atomic
 | |
|          types are a conditional feature that implementations need not support; see <a href='#6.10.9.3'>6.10.9.3</a>.)
 | |
| 
 | |
|      These methods of constructing derived types can be applied recursively.
 | |
| </pre>
 | |
| <a name='6.2.5p24'></a>
 | |
| <pre>24   Arithmetic types, pointer types, and the nullptr_t type are collectively called scalar types. Array
 | |
|      and structure types are collectively called aggregate types<a href='#FOOTNOTE.52'><sup>[52]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.52'>
 | |
| <pre><i><b>Footnote 52)</b> Note that aggregate type does not include union type because an object with union type can only contain one member at
 | |
|      a time.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p25'></a>
 | |
| <pre>25   An array type of unknown size is an incomplete type. It is completed, for an identifier of that type,
 | |
|      by specifying the size in a later declaration (with internal or external linkage). A structure or union
 | |
|      type of unknown content (as described in <a href='#6.7.2.3'>6.7.2.3</a>) is an incomplete type. It is completed, for all
 | |
|      does not violate the requirement that all basic types be different. Implementation-defined keywords have the form of an
 | |
|      identifier reserved for any use as described in <a href='#7.1.3'>7.1.3</a>.
 | |
|      declarations of that type, by declaring the same structure or union tag with its defining content later
 | |
|      in the same scope.
 | |
| </pre>
 | |
| <a name='6.2.5p26'></a>
 | |
| <pre>26   A complete type shall have a size that is less than or equal to SIZE_MAX. A type has known constant
 | |
|      size if it is complete and is not a variable length array type.
 | |
| </pre>
 | |
| <a name='6.2.5p27'></a>
 | |
| <pre>27   Array, function, and pointer types are collectively called derived declarator types. A declarator type
 | |
|      derivation from a type T is the construction of a derived declarator type from T by the application of
 | |
|      an array-type, a function-type, or a pointer-type derivation to T.
 | |
| </pre>
 | |
| <a name='6.2.5p28'></a>
 | |
| <pre>28   A type is characterized by its type category, which is either the outermost derivation of a derived
 | |
|      type (as noted above in the construction of derived types), or the type itself if the type consists of no
 | |
|      derived types.
 | |
| </pre>
 | |
| <a name='6.2.5p29'></a>
 | |
| <pre>29   Any type so far mentioned is an unqualified type. Each unqualified type has several qualified versions
 | |
|      of its type<a href='#FOOTNOTE.53'><sup>[53]</sup></a> , corresponding to the combinations of one, two, or all three of the const, volatile, and
 | |
|      restrict qualifiers. The qualified or unqualified versions of a type are distinct types that belong to
 | |
|      the same type category and have the same representation and alignment requirements.<a href='#FOOTNOTE.54'><sup>[54]</sup></a> An array
 | |
|      and its element type are always considered to be identically qualified<a href='#FOOTNOTE.55'><sup>[55]</sup></a> . Any other derived type is
 | |
|      not qualified by the qualifiers (if any) of the type from which it is derived.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.53'>
 | |
| <pre><i><b>Footnote 53)</b> See <a href='#6.7.3'>6.7.3</a> regarding qualified array and function types.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.54'>
 | |
| <pre><i><b>Footnote 54)</b> The same representation and alignment requirements are meant to imply interchangeability as arguments to functions,
 | |
|      return values from functions, and members of unions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.55'>
 | |
| <pre><i><b>Footnote 55)</b> This does not apply to the _Atomic qualifier. Note that qualifiers do not have any direct effect on the array type itself,
 | |
|      but affect conversion rules for pointer types that reference an array type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p30'></a>
 | |
| <pre>30   Further, there is the _Atomic qualifier. The presence of the _Atomic qualifier designates an atomic
 | |
|      type. The size, representation, and alignment of an atomic type need not be the same as those of
 | |
|      the corresponding unqualified type. Therefore, this document explicitly uses the phrase "atomic,
 | |
|      qualified, or unqualified type" whenever the atomic version of a type is permitted along with the
 | |
|      other qualified versions of a type. The phrase "qualified or unqualified type", without specific
 | |
|      mention of atomic, does not include the atomic types.
 | |
| </pre>
 | |
| <a name='6.2.5p31'></a>
 | |
| <pre>31   A pointer to void shall have the same representation and alignment requirements as a pointer to a
 | |
|      character type.<a href='#FOOTNOTE.54'><sup>[54]</sup></a> Similarly, pointers to qualified or unqualified versions of compatible types shall
 | |
|      have the same representation and alignment requirements. All pointers to structure types shall have
 | |
|      the same representation and alignment requirements as each other. All pointers to union types shall
 | |
|      have the same representation and alignment requirements as each other. Pointers to other types
 | |
|      need not have the same representation or alignment requirements.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.54'>
 | |
| <pre><i><b>Footnote 54)</b> The same representation and alignment requirements are meant to imply interchangeability as arguments to functions,
 | |
|      return values from functions, and members of unions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.5p32'></a>
 | |
| <pre>32   EXAMPLE 1 The type designated as "float *" has type "pointer to float". Its type category is pointer, not a floating type.
 | |
|      The const-qualified version of this type is designated as "float * const" whereas the type designated as "const float *"
 | |
|      is not a qualified type — its type is "pointer to const-qualified float" and is a pointer to a qualified type.
 | |
| </pre>
 | |
| <a name='6.2.5p33'></a>
 | |
| <pre>33   EXAMPLE 2 The type designated as "struct tag (*[5])(float)" has type "array of pointer to function returning
 | |
|      struct tag". The array has length five and the function has a single parameter of type float. Its type category is array.
 | |
| 
 | |
|      Forward references: compatible type and composite type (<a href='#6.2.7'>6.2.7</a>), declarations (<a href='#6.7'>6.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.6'></a>
 | |
| <hr>
 | |
| <h3>6.2.6 [Representations of types]</h3>
 | |
| <a name='6.2.6.1'></a>
 | |
| <hr>
 | |
| <h3>6.2.6.1 [General]</h3>
 | |
| <a name='6.2.6.1p1'></a>
 | |
| <pre>1    The representations of all types are unspecified except as stated in this subclause.
 | |
| </pre>
 | |
| <a name='6.2.6.1p2'></a>
 | |
| <pre>2    Except for bit-fields, objects are composed of contiguous sequences of one or more bytes, the number,
 | |
|      order, and encoding of which are either explicitly specified or implementation-defined.
 | |
| </pre>
 | |
| <a name='6.2.6.1p3'></a>
 | |
| <pre>3    Values stored in unsigned bit-fields and objects of type unsigned char shall be represented using a
 | |
|      pure binary notation.<a href='#FOOTNOTE.56'><sup>[56]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.56'>
 | |
| <pre><i><b>Footnote 56)</b> A positional representation for integers that uses the binary digits 0 and 1, in which the values represented by successive
 | |
|      bits are additive, begin with 1, and are multiplied by successive integral powers of 2, except perhaps the bit with the highest
 | |
|      position. (Adapted from the American National Dictionary for Information Processing Systems.) A byte contains CHAR_BIT bits,
 | |
|                                                                       _
 | |
|      and the values of type unsigned char range from 0 to 2CHAR BIT − 1.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.6.1p4'></a>
 | |
| <pre>4    Values stored in non-bit-field objects of any other object type are represented using n× CHAR_BIT bits,
 | |
|      where n is the size of an object of that type, in bytes. An object that has the value may be copied into
 | |
|     an object of type unsigned char [n] (e.g., by memcpy); the resulting set of bytes is called the object
 | |
|     representation of the value. Values stored in bit-fields consist of m bits, where m is the size specified
 | |
|     for the bit-field. The object representation is the set of m bits the bit-field comprises in the addressable
 | |
|     storage unit holding it. Two values (other than NaNs) with the same object representation compare
 | |
|     equal, but values that compare equal may have different object representations.
 | |
| </pre>
 | |
| <a name='6.2.6.1p5'></a>
 | |
| <pre>5   Certain object representations need not represent a value of the object type. If such a representation
 | |
|     is read by an lvalue expression that does not have character type, the behavior is undefined. If such
 | |
|     a representation is produced by a side effect that modifies all or any part of the object by an lvalue
 | |
|     expression that does not have character type, the behavior is undefined<a href='#FOOTNOTE.57'><sup>[57]</sup></a> . Such a representation is
 | |
|     called a non-value representation.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.57'>
 | |
| <pre><i><b>Footnote 57)</b> Thus, an automatic variable can be initialized to a non-value representation without causing undefined behavior, but the
 | |
|     value of the variable cannot be used until a proper value is stored in it.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.6.1p6'></a>
 | |
| <pre>6   When a value is stored in an object of structure or union type, including in a member object, the bytes
 | |
|     of the object representation that correspond to any padding bytes take unspecified values<a href='#FOOTNOTE.58'><sup>[58]</sup></a> . The
 | |
|     object representation of a structure or union object is never a non-value representation, even though
 | |
|     the byte range corresponding to a member of the structure or union object may be a non-value
 | |
|     representation for that member.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.58'>
 | |
| <pre><i><b>Footnote 58)</b> Thus, for example, structure assignment need not copy any padding bits.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.6.1p7'></a>
 | |
| <pre>7   When a value is stored in a member of an object of union type, the bytes of the object representation
 | |
|     that do not correspond to that member but do correspond to other members take unspecified values.
 | |
| </pre>
 | |
| <a name='6.2.6.1p8'></a>
 | |
| <pre>8   Where an operator is applied to a value that has more than one object representation, which object
 | |
|     representation is used shall not affect the value of the result.<a href='#FOOTNOTE.59'><sup>[59]</sup></a> Where a value is stored in an object
 | |
|     using a type that has more than one object representation for that value, it is unspecified which
 | |
|     representation is used, but a non-value representation shall not be generated.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.59'>
 | |
| <pre><i><b>Footnote 59)</b> It is possible for objects x and y with the same effective type T to have the same value when they are accessed as objects
 | |
|     of type T, but to have different values in other contexts. In particular, if == is defined for type T, then x == y does not imply
 | |
|     that memcmp(&x, &y, sizeof (T))== 0. Furthermore, x == y does not necessarily imply that x and y have the same value;
 | |
|     other operations on values of type T might distinguish between them.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.6.1p9'></a>
 | |
| <pre>9   Loads and stores of objects with atomic types are done with memory_order_seq_cst semantics.
 | |
|     Forward references: declarations (<a href='#6.7'>6.7</a>), expressions (<a href='#6.5'>6.5</a>), lvalues, arrays, and function designators
 | |
|     (<a href='#6.3.2.1'>6.3.2.1</a>), order and consistency (<a href='#7.17.3'>7.17.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.6.2'></a>
 | |
| <hr>
 | |
| <h3>6.2.6.2 [Integer types]</h3>
 | |
| <a name='6.2.6.2p1'></a>
 | |
| <pre>1   For unsigned integer types the bits of the object representation shall be divided into two groups:
 | |
|     value bits and padding bits. If there are N value bits, each bit shall represent a different power of
 | |
|     2 between 1 and 2N −1 , so that objects of that type shall be capable of representing values from 0
 | |
|     to 2N − 1 using a pure binary representation; this shall be known as the value representation. The
 | |
|     values of any padding bits are unspecified. The number of value bits N is called the width of the
 | |
|     unsigned integer type. The type bool shall have one value bit and (sizeof(bool)*CHAR_BIT)- 1
 | |
|     padding bits. Otherwise, there need not be any padding bits; unsigned char shall not have any
 | |
|     padding bits.
 | |
| </pre>
 | |
| <a name='6.2.6.2p2'></a>
 | |
| <pre>2   For signed integer types, the bits of the object representation shall be divided into three groups:
 | |
|     value bits, padding bits, and the sign bit. If the corresponding unsigned type has width N , the
 | |
|     signed type uses the same number of N bits, its width, as value bits and sign bit. N − 1 are value
 | |
|     bits and the remaining bit is the sign bit. Each bit that is a value bit shall have the same value as the
 | |
|     same bit in the object representation of the corresponding unsigned type. If the sign bit is zero, it
 | |
|     shall not affect the resulting value. If the sign bit is one, it has value −(2N −1 ). There need not be any
 | |
|     padding bits; signed char shall not have any padding bits.
 | |
| </pre>
 | |
| <a name='6.2.6.2p3'></a>
 | |
| <pre>3   The values of any padding bits are unspecified. A valid object representation of a signed integer
 | |
|     type where the sign bit is zero is a valid object representation of the corresponding unsigned type,
 | |
|     and shall represent the same value. For any integer type, the object representation where all the bits
 | |
|     are zero shall be a representation of the value zero in that type.
 | |
| </pre>
 | |
| <a name='6.2.6.2p4'></a>
 | |
| <pre>4   The precision of an integer type is the number of value bits.
 | |
| </pre>
 | |
| <a name='6.2.6.2p5'></a>
 | |
| <pre>5   NOTE 1 Some combinations of padding bits might generate non-value representations, for example, if one padding bit is a
 | |
|     parity bit. Regardless, no arithmetic operation on valid values can generate a non-value representation other than as part of
 | |
|     an exceptional condition such as an integer overflow, and this cannot occur with unsigned types. All other combinations of
 | |
|     padding bits are alternative object representations of the value specified by the value bits.
 | |
| </pre>
 | |
| <a name='6.2.6.2p6'></a>
 | |
| <pre>6   NOTE 2 The sign representation defined in this document is called two’s complement. Previous revisions of this document
 | |
|     additionally allowed other sign representations.
 | |
| </pre>
 | |
| <a name='6.2.6.2p7'></a>
 | |
| <pre>7   NOTE 3 For unsigned integer types the width and precision are the same, while for signed integer types the width is one
 | |
|     greater than the precision.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.7'></a>
 | |
| <hr>
 | |
| <h3>6.2.7 [Compatible type and composite type]</h3>
 | |
| <a name='6.2.7p1'></a>
 | |
| <pre>1   Two types are compatible types if they are the same. Additional rules for determining whether two
 | |
|     types are compatible are described in <a href='#6.7.2'>6.7.2</a> for type specifiers, in <a href='#6.7.3'>6.7.3</a> for type qualifiers, and in <a href='#6.7.6'>6.7.6</a>
 | |
|     for declarators<a href='#FOOTNOTE.60'><sup>[60]</sup></a> . Moreover, two complete structure, union, or enumerated types declared with the
 | |
|     same tag are compatible if members satisfy the following requirements:
 | |
| 
 | |
|       — there shall be a one-to-one correspondence between their members such that each pair of
 | |
|         corresponding members are declared with compatible types;
 | |
|       — if one member of the pair is declared with an alignment specifier, the other is declared with an
 | |
|         equivalent alignment specifier;
 | |
|       — and, if one member of the pair is declared with a name, the other is declared with the same
 | |
|         name.
 | |
| 
 | |
|     For two structures, corresponding members shall be declared in the same order. For two structures or
 | |
|     unions, corresponding bit-fields shall have the same widths. For two enumerations, corresponding
 | |
|     members shall have the same values; if one has a fixed underlying type, then the other shall have a
 | |
|     compatible fixed underlying type. For determining type compatibility, anonymous structures and
 | |
|     unions are considered a regular member of the containing structure or union type, and the type
 | |
|     of an anonymous structure or union is considered compatible to the type of another anonymous
 | |
|     structure or union, respectively, if their members fulfill the above requirements.
 | |
|     Furthermore, two structure, union, or enumerated types declared in separate translation units are
 | |
|     compatible in the following cases:
 | |
| 
 | |
|       — both are declared without tags and they fulfill the requirements above;
 | |
|       — both have the same tag and are completed somewhere in their respective translation units and
 | |
|         they fulfill the requirements above;
 | |
|       — both have the same tag and at least one of the two types is not completed in its translation unit.
 | |
| 
 | |
|     Otherwise, the structure, union, or enumerated types are incompatible<a href='#FOOTNOTE.61'><sup>[61]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.60'>
 | |
| <pre><i><b>Footnote 60)</b> Two types need not be identical to be compatible.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.61'>
 | |
| <pre><i><b>Footnote 61)</b> A structure, union, or enumerated type without a tag or an incomplete structure, union or enumerated type is not
 | |
|     compatible with any other structure, union or enum type declared in the same translation unit.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.7p2'></a>
 | |
| <pre>2   All declarations that refer to the same object or function shall have compatible type; otherwise, the
 | |
|     behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.2.7p3'></a>
 | |
| <pre>3   A composite type can be constructed from two types that are compatible; it is a type that is compatible
 | |
|     with both of the two types and satisfies the following conditions:
 | |
| 
 | |
|       — If both types are array types, the following rules are applied:
 | |
|               • If one type is an array of known constant size, the composite type is an array of that size.
 | |
|               • Otherwise, if one type is a variable length array whose size is specified by an expression
 | |
|                 that is not evaluated, the behavior is undefined.
 | |
|               • Otherwise, if one type is a variable length array whose size is specified, the composite
 | |
|                 type is a variable length array of that size.
 | |
|               • Otherwise, if one type is a variable length array of unspecified size, the composite type is
 | |
|                 a variable length array of unspecified size.
 | |
|               • Otherwise, both types are arrays of unknown size and the composite type is an array of
 | |
|                 unknown size.
 | |
| 
 | |
|             The element type of the composite type is the composite type of the two element types.
 | |
| 
 | |
|       — If both types are function types, the type of each parameter in the composite parameter type
 | |
|         list is the composite type of the corresponding parameters.
 | |
| 
 | |
|       — If one of the types has a standard attribute, the composite type also has that attribute.
 | |
| 
 | |
|     These rules apply recursively to the types from which the two types are derived.
 | |
| </pre>
 | |
| <a name='6.2.7p4'></a>
 | |
| <pre>4   For an identifier with internal or external linkage declared in a scope in which a prior declaration of
 | |
|     that identifier is visible<a href='#FOOTNOTE.62'><sup>[62]</sup></a> , if the prior declaration specifies internal or external linkage, the type of
 | |
|     the identifier at the later declaration becomes the composite type.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.62'>
 | |
| <pre><i><b>Footnote 62)</b> As specified in <a href='#6.2.1'>6.2.1</a>, the later declaration might hide the prior declaration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.7p5'></a>
 | |
| <pre>5   EXAMPLE Given the following two file scope declarations:
 | |
| 
 | |
|               int f(int (*)(char *), double (*)[3]);
 | |
|               int f(int (*)(char *), double (*)[]);
 | |
| 
 | |
|     The resulting composite type for the function is:
 | |
| 
 | |
|               int f(int (*)(char *), double (*)[3]);
 | |
| 
 | |
| 
 | |
|     Forward references: array declarators (<a href='#6.7.6.2'>6.7.6.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.8'></a>
 | |
| <hr>
 | |
| <h3>6.2.8 [Alignment of objects]</h3>
 | |
| <a name='6.2.8p1'></a>
 | |
| <pre>1   Complete object types have alignment requirements which place restrictions on the addresses at
 | |
|     which objects of that type may be allocated. An alignment is an implementation-defined integer
 | |
|     value representing the number of bytes between successive addresses at which a given object can be
 | |
|     allocated. An object type imposes an alignment requirement on every object of that type: stricter
 | |
|     alignment can be requested using the alignas keyword.
 | |
| </pre>
 | |
| <a name='6.2.8p2'></a>
 | |
| <pre>2   A fundamental alignment is a valid alignment less than or equal to alignof (max_align_t). Funda-
 | |
|     mental alignments shall be supported by the implementation for objects of all storage durations.
 | |
|     The alignment requirements of the following types shall be fundamental alignments:
 | |
| 
 | |
|       — all atomic, qualified, or unqualified basic types;
 | |
| 
 | |
|       — all atomic, qualified, or unqualified enumerated types;
 | |
| 
 | |
|       — all atomic, qualified, or unqualified pointer types;
 | |
| 
 | |
|       — all array types whose element type has a fundamental alignment requirement;
 | |
| 
 | |
|       — all types specified in Clause 7 as complete object types;
 | |
| 
 | |
|       — all structure or union types all of whose elements have types with fundamental alignment
 | |
|         requirements and none of whose elements have an alignment specifier specifying an alignment
 | |
|         that is not a fundamental alignment.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.8p3'></a>
 | |
| <pre>3   An extended alignment is represented by an alignment greater than alignof (max_align_t). It is
 | |
|     implementation-defined whether any extended alignments are supported and the storage durations
 | |
|     for which they are supported. A type having an extended alignment requirement is an over-aligned
 | |
|     type.<a href='#FOOTNOTE.63'><sup>[63]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.63'>
 | |
| <pre><i><b>Footnote 63)</b> Every over-aligned type is, or contains, a structure or union type with a member to which an extended alignment has
 | |
|     been applied.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.2.8p4'></a>
 | |
| <pre>4   Alignments are represented as values of the type size_t. Valid alignments include only fundamental
 | |
|     alignments, plus an additional implementation-defined set of values, which may be empty. Every
 | |
|     valid alignment value shall be a nonnegative integral power of two.
 | |
| </pre>
 | |
| <a name='6.2.8p5'></a>
 | |
| <pre>5   Alignments have an order from weaker to stronger or stricter alignments. Stricter alignments have
 | |
|     larger alignment values. An address that satisfies an alignment requirement also satisfies any weaker
 | |
|     valid alignment requirement.
 | |
| </pre>
 | |
| <a name='6.2.8p6'></a>
 | |
| <pre>6   The alignment requirement of a complete type can be queried using an alignof expression. The
 | |
|     types char, signed char, and unsigned char shall have the weakest alignment requirement.
 | |
| </pre>
 | |
| <a name='6.2.8p7'></a>
 | |
| <pre>7   Comparing alignments is meaningful and provides the obvious results:
 | |
| 
 | |
|       — Two alignments are equal when their numeric values are equal.
 | |
|       — Two alignments are different when their numeric values are not equal.
 | |
|       — When an alignment is larger than another it represents a stricter alignment.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.2.9'></a>
 | |
| <hr>
 | |
| <h3>6.2.9 [Encodings]</h3>
 | |
| <a name='6.2.9p1'></a>
 | |
| <pre>1   The literal encoding is an implementation-defined mapping of the characters of the execution character
 | |
|     set to the values in a character constant (<a href='#6.4.4.4'>6.4.4.4</a>) or string literal (<a href='#6.4.5'>6.4.5</a>). It shall support a mapping
 | |
|     from all the basic execution character set values into the implementation-defined encoding. It may
 | |
|     contain multibyte character sequences (<a href='#5.2.1.1'>5.2.1.1</a>).
 | |
| </pre>
 | |
| <a name='6.2.9p2'></a>
 | |
| <pre>2   The wide literal encoding is an implementation-defined mapping of the characters of the execution
 | |
|     character set to the values in a wchar_t character constant (<a href='#6.4.4.4'>6.4.4.4</a>) or a wchar_t string literal (<a href='#6.4.5'>6.4.5</a>).
 | |
|     It shall support a mapping from all the basic execution character set values into the implementation-
 | |
|     defined encoding. The mapping shall produce values identical to the literal encoding for all the basic
 | |
|     execution character set values if an implementation does not define __STDC_MB_MIGHT_NEQ_WC__ .
 | |
|     One or more values may map to one or more values of the extended execution character set.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3'></a>
 | |
| <hr>
 | |
| <h3>6.3 [Conversions]</h3>
 | |
| <a name='6.3p1'></a>
 | |
| <pre>1   Several operators convert operand values from one type to another automatically. This subclause
 | |
|     specifies the result required from such an implicit conversion, as well as those that result from a cast
 | |
|     operation (an explicit conversion). The list in <a href='#6.3.1.8'>6.3.1.8</a> summarizes the conversions performed by most
 | |
|     ordinary operators; it is supplemented as required by the discussion of each operator in <a href='#6.5'>6.5</a>.
 | |
| </pre>
 | |
| <a name='6.3p2'></a>
 | |
| <pre>2   Unless explicitly stated otherwise, conversion of an operand value to a compatible type causes no
 | |
|     change to the value or the representation.
 | |
|     Forward references: cast operators (<a href='#6.5.4'>6.5.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.1'></a>
 | |
| <hr>
 | |
| <h3>6.3.1 [Arithmetic operands]</h3>
 | |
| <a name='6.3.1.1'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.1 [Boolean, characters, and integers]</h3>
 | |
| <a name='6.3.1.1p1'></a>
 | |
| <pre>1   Every integer type has an integer conversion rank defined as follows:
 | |
| 
 | |
|       — No two signed integer types shall have the same rank, even if they have the same representa-
 | |
|         tion.
 | |
|       — The rank of a signed integer type shall be greater than the rank of any signed integer type with
 | |
|         less precision.
 | |
|       — The rank of long long int shall be greater than the rank of long int, which shall be greater
 | |
|         than the rank of int, which shall be greater than the rank of short int, which shall be greater
 | |
|         than the rank of signed char.
 | |
|       — The rank of a bit-precise signed integer type shall be greater than the rank of any standard
 | |
|         integer type with less width or any bit-precise integer type with less width.
 | |
|       — The rank of any unsigned integer type shall equal the rank of the corresponding signed integer
 | |
|         type, if any.
 | |
|       — The rank of any standard integer type shall be greater than the rank of any extended integer
 | |
|         type with the same width or bit-precise integer type with the same width.
 | |
| 
 | |
|       — The rank of any bit-precise integer type relative to an extended integer type of the same width
 | |
|         is implementation-defined.
 | |
| 
 | |
|       — The rank of char shall equal the rank of signed char and unsigned char.
 | |
| 
 | |
|       — The rank of bool shall be less than the rank of all other standard integer types.
 | |
| 
 | |
|       — The rank of any enumerated type shall equal the rank of the compatible integer type (see
 | |
|         <a href='#6.7.2.2'>6.7.2.2</a>).
 | |
| 
 | |
|       — The rank of any extended signed integer type relative to another extended signed integer
 | |
|         type with the same precision is implementation-defined, but still subject to the other rules for
 | |
|         determining the integer conversion rank.
 | |
| 
 | |
|       — For all integer types T1, T2, and T3, if T1 has greater rank than T2 and T2 has greater rank than
 | |
|         T3 , then T1 has greater rank than T3.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.1.1p2'></a>
 | |
| <pre>2   The following may be used in an expression wherever an int or unsigned int may be used:
 | |
| 
 | |
|       — An object or expression with an integer type (other than int or unsigned int) whose integer
 | |
|         conversion rank is less than or equal to the rank of int and unsigned int.
 | |
| 
 | |
|       — A bit-field of type bool, int, signed int, or unsigned int.
 | |
| 
 | |
|     The value from a bit-field of a bit-precise integer type is converted to the corresponding bit-precise
 | |
|     type. If the original type is not a bit-precise integer type (<a href='#6.2.5'>6.2.5</a>) and if an int can represent all values
 | |
|     of the original type (as restricted by the width, for a bit-field), the value is converted to an int<a href='#FOOTNOTE.64'><sup>[64]</sup></a> ;
 | |
|     otherwise, it is converted to an unsigned int. These are called the integer promotions<a href='#FOOTNOTE.65'><sup>[65]</sup></a> . All other
 | |
|     types are unchanged by the integer promotions.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.64'>
 | |
| <pre><i><b>Footnote 64)</b> <a href='#E.'>E.</a>g.,
 | |
|             unsigned _BitInt(7): 2 is a bit-field that can hold the values −2, −1, 0, 1, and converts to
 | |
|     unsigned _BitInt(7).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.65'>
 | |
| <pre><i><b>Footnote 65)</b> The integer promotions are applied only: as part of the usual arithmetic conversions, to certain argument expressions, to
 | |
|     the operands of the unary + ,- , and ~ operators, and to both operands of the shift operators, as specified by their respective
 | |
|     subclauses.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.1.1p3'></a>
 | |
| <pre>3   The integer promotions preserve value including sign. As discussed earlier, whether a "plain" char
 | |
|     can hold negative values is implementation-defined.
 | |
|     Forward references: enumeration specifiers (<a href='#6.7.2.2'>6.7.2.2</a>), structure and union specifiers (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.1.2'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.2 [Boolean type]</h3>
 | |
| <a name='6.3.1.2p1'></a>
 | |
| <pre>1   When any scalar value is converted to bool, the result is false if the value is a zero (for arithmetic
 | |
|     types), null (for pointer types), or the scalar has type nullptr_t; otherwise, the result is true.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.1.3'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.3 [Signed and unsigned integers]</h3>
 | |
| <a name='6.3.1.3p1'></a>
 | |
| <pre>1   When a value with integer type is converted to another integer type other than bool, if the value
 | |
|     can be represented by the new type, it is unchanged.
 | |
| </pre>
 | |
| <a name='6.3.1.3p2'></a>
 | |
| <pre>2   Otherwise, if the new type is unsigned, the value is converted by repeatedly adding or subtracting
 | |
|     one more than the maximum value that can be represented in the new type until the value is in the
 | |
|     range of the new type.<a href='#FOOTNOTE.66'><sup>[66]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.66'>
 | |
| <pre><i><b>Footnote 66)</b> The rules describe arithmetic on the mathematical value, not the value of a given type of expression.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.1.3p3'></a>
 | |
| <pre>3   Otherwise, the new type is signed and the value cannot be represented in it; either the result is
 | |
|     implementation-defined or an implementation-defined signal is raised.
 | |
| </pre>
 | |
| <a name='6.3.1.4'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.4 [Real floating and integer]</h3>
 | |
| <a name='6.3.1.4p1'></a>
 | |
| <pre>1   When a finite value of standard floating type is converted to an integer type other than bool, the
 | |
|     fractional part is discarded (i.e., the value is truncated toward zero). If the value of the integral part
 | |
|     cannot be represented by the integer type, the behavior is undefined.<a href='#FOOTNOTE.67'><sup>[67]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.67'>
 | |
| <pre><i><b>Footnote 67)</b> The remaindering operation performed when a value of integer type is converted to unsigned type need not be
 | |
|     performed when a value of real floating type is converted to unsigned type. Thus, the range of portable real floating values is
 | |
|     (−1, Utype_MAX + 1).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.1.4p2'></a>
 | |
| <pre>2   When a finite value of decimal floating type is converted to an integer type other than bool, the
 | |
|     fractional part is discarded (i.e., the value is truncated toward zero). If the value of the integral part
 | |
|     cannot be represented by the integer type, the "invalid" floating-point exception shall be raised and
 | |
|     the result of the conversion is unspecified.
 | |
| </pre>
 | |
| <a name='6.3.1.4p3'></a>
 | |
| <pre>3   When a value of integer type is converted to a standard floating type, if the value being converted
 | |
|     can be represented exactly in the new type, it is unchanged. If the value being converted is in the
 | |
|     range of values that can be represented but cannot be represented exactly, the result is either the
 | |
|     nearest higher or nearest lower representable value, chosen in an implementation-defined manner.
 | |
|     If the value being converted is outside the range of values that can be represented, the behavior is
 | |
|     undefined. Results of some implicit conversions may be represented in greater range and precision
 | |
|     than that required by the new type (see <a href='#6.3.1.8'>6.3.1.8</a> and <a href='#6.8.6.4'>6.8.6.4</a>).
 | |
| </pre>
 | |
| <a name='6.3.1.4p4'></a>
 | |
| <pre>4   When a value of integer type is converted to a decimal floating type, if the value being converted
 | |
|     can be represented exactly in the new type, it is unchanged. If the value being converted cannot
 | |
|     be represented exactly, the result shall be correctly rounded with exceptions raised as specified in
 | |
|     IEC 60559.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.1.5'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.5 [Real floating types]</h3>
 | |
| <a name='6.3.1.5p1'></a>
 | |
| <pre>1   When a value of real floating type is converted to a real floating type, if the value being converted
 | |
|     can be represented exactly in the new type, it is unchanged.
 | |
| </pre>
 | |
| <a name='6.3.1.5p2'></a>
 | |
| <pre>2   When a value of real floating type is converted to a standard floating type, if the value being
 | |
|     converted is in the range of values that can be represented but cannot be represented exactly, the
 | |
|     result is either the nearest higher or nearest lower representable value, chosen in an implementation-
 | |
|     defined manner. If the value being converted is outside the range of values that can be represented,
 | |
|     the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.3.1.5p3'></a>
 | |
| <pre>3   When a value of real floating type is converted to a decimal floating type, if the value being converted
 | |
|     cannot be represented exactly, the result is correctly rounded with exceptions raised as specified in
 | |
|     IEC 60559.
 | |
| </pre>
 | |
| <a name='6.3.1.5p4'></a>
 | |
| <pre>4   Results of some implicit conversions may be represented in greater range and precision than that
 | |
|     required by the new type (see <a href='#6.3.1.8'>6.3.1.8</a> and <a href='#6.8.6.4'>6.8.6.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.1.6'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.6 [Complex types]</h3>
 | |
| <a name='6.3.1.6p1'></a>
 | |
| <pre>1   When a value of complex type is converted to another complex type, both the real and imaginary
 | |
|     parts follow the conversion rules for the corresponding real types.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.1.7'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.7 [Real and complex]</h3>
 | |
| <a name='6.3.1.7p1'></a>
 | |
| <pre>1   When a value of real type is converted to a complex type, the real part of the complex result value is
 | |
|     determined by the rules of conversion to the corresponding real type and the imaginary part of the
 | |
|     complex result value is a positive zero or an unsigned zero.
 | |
| </pre>
 | |
| <a name='6.3.1.7p2'></a>
 | |
| <pre>2   When a value of complex type is converted to a real type other than bool,<a href='#FOOTNOTE.68'><sup>[68]</sup></a> the imaginary part of
 | |
|     the complex value is discarded and the value of the real part is converted according to the conversion
 | |
|     rules for the corresponding real type.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.68'>
 | |
| <pre><i><b>Footnote 68)</b> See <a href='#6.3.1.2'>6.3.1.2</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.1.8'></a>
 | |
| <hr>
 | |
| <h3>6.3.1.8 [Usual arithmetic conversions]</h3>
 | |
| <a name='6.3.1.8p1'></a>
 | |
| <pre>1   Many operators that expect operands of arithmetic type cause conversions and yield result types in
 | |
|     a similar way. The purpose is to determine a common real type for the operands and result. For the
 | |
|     specified operands, each operand is converted, without change of type domain, to a type whose
 | |
|     corresponding real type is the common real type. Unless explicitly stated otherwise, the common
 | |
|     real type is also the corresponding real type of the result, whose type domain is the type domain of
 | |
|     the operands if they are the same, and complex otherwise. This pattern is called the usual arithmetic
 | |
|     conversions:
 | |
| 
 | |
|            If one operand has decimal floating type, the other operand shall not have standard floating,
 | |
|            complex, or imaginary type.
 | |
|            First, if the type of either operand is _Decimal128 , the other operand is converted to
 | |
|           _Decimal128 .
 | |
| 
 | |
|            Otherwise, if the type of either operand is _Decimal64 , the other operand is converted to
 | |
|           _Decimal64 .
 | |
| 
 | |
|            Otherwise, if the type of either operand is _Decimal32 , the other operand is converted to
 | |
|           _Decimal32 .
 | |
| 
 | |
|            Otherwise, if the corresponding real type of either operand is long double, the other operand
 | |
|            is converted, without change of type domain, to a type whose corresponding real type is
 | |
|            long double.
 | |
| 
 | |
|            Otherwise, if the corresponding real type of either operand is double, the other operand is
 | |
|            converted, without change of type domain, to a type whose corresponding real type is double.
 | |
|            Otherwise, if the corresponding real type of either operand is float, the other operand is
 | |
|            converted, without change of type domain, to a type whose corresponding real type is float.<a href='#FOOTNOTE.69'><sup>[69]</sup></a>
 | |
|            Otherwise, the integer promotions are performed on both operands. Then the following rules
 | |
|            are applied to the promoted operands:
 | |
|                  If both operands have the same type, then no further conversion is needed.
 | |
|                  Otherwise, if both operands have signed integer types or both have unsigned integer
 | |
|                  types, the operand with the type of lesser integer conversion rank is converted to the type
 | |
|                  of the operand with greater rank.
 | |
|                  Otherwise, if the operand that has unsigned integer type has rank greater or equal to
 | |
|                  the rank of the type of the other operand, then the operand with signed integer type is
 | |
|                  converted to the type of the operand with unsigned integer type.
 | |
|                  Otherwise, if the type of the operand with signed integer type can represent all of the
 | |
|                  values of the type of the operand with unsigned integer type, then the operand with
 | |
|                  unsigned integer type is converted to the type of the operand with signed integer type.
 | |
|                  Otherwise, both operands are converted to the unsigned integer type corresponding to
 | |
|                  the type of the operand with signed integer type.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.69'>
 | |
| <pre><i><b>Footnote 69)</b> For example, addition of a double _Complex and a float entails just the conversion of the float operand to double
 | |
|     (and yields a double _Complex result).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.1.8p2'></a>
 | |
| <pre>2   The values of floating operands and of the results of floating expressions may be represented in
 | |
|     greater range and precision than that required by the type; the types are not changed thereby.
 | |
|     See <a href='#5.2.4.2.2'>5.2.4.2.2</a> regarding evaluation formats.
 | |
| </pre>
 | |
| <a name='6.3.1.8p3'></a>
 | |
| <pre>3   EXAMPLE 1 One consequence of _BitInt being exempt from the integer promotion rules (<a href='#6.3.1'>6.3.1</a>) is that a _BitInt operand
 | |
|     of a binary operator is not always promoted to an int or unsigned int as part of the usual arithmetic conversions. Instead,
 | |
|     a lower-ranked operand is converted to the higher-rank operand type and the result of the operation is the higher-ranked
 | |
|     type.
 | |
| 
 | |
|               _BitInt(2) a2 = 1;
 | |
|               _BitInt(3) a3 = 2;
 | |
|               _BitInt(33) a33 = 1;
 | |
|               char c = 3;
 | |
| 
 | |
|               a2 * a3 /* As part of the multiplication, a2 is converted to
 | |
|                           _BitInt(3) and the result type is _BitInt(3). */
 | |
|               a2 * c /* As part of the multiplication, c is promoted to int,
 | |
|                           a2 is converted to int and the result type is int. */
 | |
|               a33 * c /* As part of the multiplication, c is promoted to int,
 | |
|                           then converted to _BitInt(33) and the result type
 | |
|                           is _BitInt(33). */
 | |
| 
 | |
|               void func(_BitInt(8) a1, _BitInt(24) a2) {
 | |
|                     /* Cast one of the operands to 32-bits to guarantee the
 | |
|                        result of the multiplication can contain all possible
 | |
|                        values. */
 | |
|                     _BitInt(32) a3 = a1 * (_BitInt(32))a2;
 | |
|               }
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.2'></a>
 | |
| <hr>
 | |
| <h3>6.3.2 [Other operands]</h3>
 | |
| <a name='6.3.2.1'></a>
 | |
| <hr>
 | |
| <h3>6.3.2.1 [Lvalues, arrays, and function designators]</h3>
 | |
| <a name='6.3.2.1p1'></a>
 | |
| <pre>1   An lvalue is an expression (with an object type other than void) that potentially designates an
 | |
|     object;<a href='#FOOTNOTE.70'><sup>[70]</sup></a> if an lvalue does not designate an object when it is evaluated, the behavior is undefined.
 | |
|     When an object is said to have a particular type, the type is specified by the lvalue used to designate
 | |
|     the object. A modifiable lvalue is an lvalue that does not have array type, does not have an incomplete
 | |
|     type, does not have a const-qualified type, and if it is a structure or union, does not have any
 | |
|     member (including, recursively, any member or element of all contained aggregates or unions) with
 | |
|     a const-qualified type.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.70'>
 | |
| <pre><i><b>Footnote 70)</b> The name "lvalue" comes originally from the assignment expression E1 = E2, in which the left operand E1 is required to
 | |
|     be a (modifiable) lvalue. It is perhaps better considered as representing an object "locator value". What is sometimes called
 | |
|     "rvalue" is in this document described as the "value of an expression".
 | |
|        An obvious example of an lvalue is an identifier of an object. As a further example, if E is a unary expression that is a
 | |
|     pointer to an object, *E is an lvalue that designates the object to which E points.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.2.1p2'></a>
 | |
| <pre>2   Except when it is the operand of the sizeof operator, or the typeof operators, the unary & operator,
 | |
|     the ++ operator, the-- operator, or the left operand of the . operator or an assignment operator, an
 | |
|     lvalue that does not have array type is converted to the value stored in the designated object (and is
 | |
|     no longer an lvalue); this is called lvalue conversion. If the lvalue has qualified type, the value has the
 | |
|     unqualified version of the type of the lvalue; additionally, if the lvalue has atomic type, the value has
 | |
|     the non-atomic version of the type of the lvalue; otherwise, the value has the type of the lvalue. If the
 | |
|     lvalue has an incomplete type and does not have array type, the behavior is undefined. If the lvalue
 | |
|     designates an object of automatic storage duration that could have been declared with the register
 | |
|     storage class (never had its address taken), and that object is uninitialized (not declared with an
 | |
|     initializer and no assignment to it has been performed prior to use), the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.3.2.1p3'></a>
 | |
| <pre>3   Except when it is the operand of the sizeof operator, or typeof operators, or the unary & operator,
 | |
|     or is a string literal used to initialize an array, an expression that has type "array of type" is converted
 | |
|     to an expression with type "pointer to type" that points to the initial element of the array object and
 | |
|     is not an lvalue. If the array object has register storage class, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.3.2.1p4'></a>
 | |
| <pre>4   A function designator is an expression that has function type. Except when it is the operand of the
 | |
|     sizeof operator<a href='#FOOTNOTE.71'><sup>[71]</sup></a> , a typeof operator, or the unary & operator, a function designator with type
 | |
|     "function returning type" is converted to an expression that has type "pointer to function returning
 | |
|     type".
 | |
|     Forward references: address and indirection operators (<a href='#6.5.3.2'>6.5.3.2</a>), assignment operators (<a href='#6.5.16'>6.5.16</a>),
 | |
|     common definitions <stddef.h> (<a href='#7.21'>7.21</a>), initialization (<a href='#6.7.10'>6.7.10</a>), postfix increment and decrement
 | |
|     operators (<a href='#6.5.2.4'>6.5.2.4</a>), prefix increment and decrement operators (<a href='#6.5.3.1'>6.5.3.1</a>), the sizeof and alignof
 | |
|     operators (<a href='#6.5.3.4'>6.5.3.4</a>), structure and union members (<a href='#6.5.2.3'>6.5.2.3</a>).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.71'>
 | |
| <pre><i><b>Footnote 71)</b> Because this conversion does not occur, the operand of the sizeof operator remains a function designator and violates
 | |
|     the constraints in <a href='#6.5.3.4'>6.5.3.4</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.2.2'></a>
 | |
| <hr>
 | |
| <h3>6.3.2.2 [void]</h3>
 | |
| <a name='6.3.2.2p1'></a>
 | |
| <pre>1   The (nonexistent) value of a void expression (an expression that has type void) shall not be used in any
 | |
|     way, and implicit or explicit conversions (except to void) shall not be applied to such an expression.
 | |
|     If an expression of any other type is evaluated as a void expression, its value or designator is
 | |
|     discarded. (A void expression is evaluated for its side effects.)
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.2.3'></a>
 | |
| <hr>
 | |
| <h3>6.3.2.3 [Pointers]</h3>
 | |
| <a name='6.3.2.3p1'></a>
 | |
| <pre>1   A pointer to void may be converted to or from a pointer to any object type. A pointer to any object
 | |
|     type may be converted to a pointer to void and back again; the result shall compare equal to the
 | |
|     original pointer.
 | |
| </pre>
 | |
| <a name='6.3.2.3p2'></a>
 | |
| <pre>2   For any qualifier q, a pointer to a non-q-qualified type may be converted to a pointer to the q-qualified
 | |
|     version of the type; the values stored in the original and converted pointers shall compare equal.
 | |
| </pre>
 | |
| <a name='6.3.2.3p3'></a>
 | |
| <pre>3   An integer constant expression with the value 0, such an expression cast to type void *, or the
 | |
|     predefined constant nullptr is called a null pointer constant<a href='#FOOTNOTE.72'><sup>[72]</sup></a> . If a null pointer constant or a value
 | |
|     of the type nullptr_t (which is necessarily the value nullptr) is converted to a pointer type, the
 | |
|     resulting pointer, called a null pointer, is guaranteed to compare unequal to a pointer to any object or
 | |
|     function.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.72'>
 | |
| <pre><i><b>Footnote 72)</b> The macro NULL is defined in <stddef.h> (and other headers) as a null pointer constant; see <a href='#7.21'>7.21</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.2.3p4'></a>
 | |
| <pre>4   Conversion of a null pointer to another pointer type yields a null pointer of that type. Any two null
 | |
|     pointers shall compare equal.
 | |
| </pre>
 | |
| <a name='6.3.2.3p5'></a>
 | |
| <pre>5   An integer may be converted to any pointer type. Except as previously specified, the result is
 | |
|     implementation-defined, might not be correctly aligned, might not point to an entity of the referenced
 | |
|     type, and might produce an indeterminate representation when stored into an object<a href='#FOOTNOTE.73'><sup>[73]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.73'>
 | |
| <pre><i><b>Footnote 73)</b> The mapping functions for converting a pointer to an integer or an integer to a pointer are intended to be consistent with
 | |
|     the addressing structure of the execution environment.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.2.3p6'></a>
 | |
| <pre>6   Any pointer type may be converted to an integer type. Except as previously specified, the result
 | |
|     is implementation-defined. If the result cannot be represented in the integer type, the behavior is
 | |
|     undefined. The result need not be in the range of values of any integer type.
 | |
| </pre>
 | |
| <a name='6.3.2.3p7'></a>
 | |
| <pre>7   A pointer to an object type may be converted to a pointer to a different object type. If the resulting
 | |
|     pointer is not correctly aligned<a href='#FOOTNOTE.74'><sup>[74]</sup></a> for the referenced type, the behavior is undefined. Otherwise,
 | |
|     when converted back again, the result shall compare equal to the original pointer. When a pointer to
 | |
|     an object is converted to a pointer to a character type, the result points to the lowest addressed byte
 | |
|     of the object. Successive increments of the result, up to the size of the object, yield pointers to the
 | |
|     remaining bytes of the object.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.74'>
 | |
| <pre><i><b>Footnote 74)</b> In general, the concept "correctly aligned" is transitive: if a pointer to type A is correctly aligned for a pointer to type B,
 | |
|     which in turn is correctly aligned for a pointer to type C, then a pointer to type A is correctly aligned for a pointer to type C.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.3.2.3p8'></a>
 | |
| <pre>8   A pointer to a function of one type may be converted to a pointer to a function of another type and
 | |
|     back again; the result shall compare equal to the original pointer. If a converted pointer is used to
 | |
|     call a function whose type is not compatible with the referenced type, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.3.2.4'></a>
 | |
| <hr>
 | |
| <h3>6.3.2.4 [nullptr_t]</h3>
 | |
| <a name='6.3.2.4p1'></a>
 | |
| <pre>1   The type nullptr_t may be converted to bool or to a pointer type. The result is false or the null
 | |
|     pointer value, respectively.
 | |
| </pre>
 | |
| <a name='6.3.2.4p2'></a>
 | |
| <pre>2   The type nullptr_t may be converted to itself.
 | |
|     Forward references: cast operators (<a href='#6.5.4'>6.5.4</a>), equality operators (<a href='#6.5.9'>6.5.9</a>), integer types capable of
 | |
|     holding object pointers (<a href='#7.22.1.4'>7.22.1.4</a>), simple assignment (<a href='#6.5.16.1'>6.5.16.1</a>).
 | |
| </pre>
 | |
| <a name='6.4'></a>
 | |
| <hr>
 | |
| <h3>6.4 [Lexical elements]</h3>
 | |
| <a name='6.4p1'></a>
 | |
| <pre>1 Syntax
 | |
|     token:
 | |
|                             keyword
 | |
|                             identifier
 | |
|                             constant
 | |
|                             string-literal
 | |
|                             punctuator
 | |
| 
 | |
|      preprocessing-token:
 | |
|                         header-name
 | |
|                         identifier
 | |
|                         pp-number
 | |
|                         character-constant
 | |
|                         string-literal
 | |
|                         punctuator
 | |
|                        each universal-character-name that cannot be one of the above
 | |
|                        each non-white-space character that cannot be one of the above
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.4p2'></a>
 | |
| <pre>2   Each preprocessing token that is converted to a token shall have the lexical form of a keyword, an
 | |
|     identifier, a constant, a string literal, or a punctuator. A single universal character name shall match
 | |
|     one of the other preprocessing token categories.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4p3'></a>
 | |
| <pre>3   A token is the minimal lexical element of the language in translation phases 7 and 8. The categories of
 | |
|     tokens are: keywords, identifiers, constants, string literals, and punctuators. A preprocessing token
 | |
|     is the minimal lexical element of the language in translation phases 3 through 6. The categories of
 | |
|     preprocessing tokens are: header names, identifiers, preprocessing numbers, character constants,
 | |
|     string literals, punctuators, and both single universal character names as well as single non-white-
 | |
|     space characters that do not lexically match the other preprocessing token categories.<a href='#FOOTNOTE.75'><sup>[75]</sup></a> If a ’ or a "
 | |
|     character matches the last category, the behavior is undefined. Preprocessing tokens can be separated
 | |
|     by white space; this consists of comments (described later), or white-space characters (space, horizontal
 | |
|     tab, new-line, vertical tab, and form-feed), or both. As described in <a href='#6.10'>6.10</a>, in certain circumstances
 | |
|     during translation phase 4, white space (or the absence thereof) serves as more than preprocessing
 | |
|     token separation. White space may appear within a preprocessing token only as part of a header
 | |
|     name or between the quotation characters in a character constant or string literal.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.75'>
 | |
| <pre><i><b>Footnote 75)</b> An additional category, placemarkers, is used internally in translation phase 4 (see <a href='#6.10.4.3'>6.10.4.3</a>); it cannot occur in source
 | |
|     files.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4p4'></a>
 | |
| <pre>4   If the input stream has been parsed into preprocessing tokens up to a given character, the next
 | |
|     preprocessing token is the longest sequence of characters that could constitute a preprocessing token.
 | |
|     There is one exception to this rule: header name preprocessing tokens are recognized only within
 | |
|     #include and #embed preprocessing directives, in __has_include and __has_embed expressions,
 | |
|     as well as in implementation-defined locations within #pragma directives. In such contexts, a
 | |
|     sequence of characters that could be either a header name or a string literal is recognized as the
 | |
|     former.
 | |
| </pre>
 | |
| <a name='6.4p5'></a>
 | |
| <pre>5   EXAMPLE 1 The program fragment 1Ex is parsed as a preprocessing number token (one that is not a valid floating or integer
 | |
|     constant token), even though a parse as the pair of preprocessing tokens 1 and Ex might produce a valid expression (for
 | |
|     example, if Ex were a macro defined as +1 ). Similarly, the program fragment 1E1 is parsed as a preprocessing number (one
 | |
|     that is a valid floating constant token), whether or not E is a macro name.
 | |
| </pre>
 | |
| <a name='6.4p6'></a>
 | |
| <pre>6   EXAMPLE 2 The program fragment x+++++y is parsed as x ++ ++ + y, which violates a constraint on increment operators,
 | |
|     even though the parse x ++ + ++ y might yield a correct expression.
 | |
| 
 | |
|     Forward references: character constants (<a href='#6.4.4.4'>6.4.4.4</a>), comments (<a href='#6.4.9'>6.4.9</a>), expressions (<a href='#6.5'>6.5</a>), floating
 | |
| constants (<a href='#6.4.4.2'>6.4.4.2</a>), header names (<a href='#6.4.7'>6.4.7</a>), macro replacement (<a href='#6.10.4'>6.10.4</a>), postfix increment and decrement
 | |
| operators (<a href='#6.5.2.4'>6.5.2.4</a>), prefix increment and decrement operators (<a href='#6.5.3.1'>6.5.3.1</a>), preprocessing directives (<a href='#6.10'>6.10</a>),
 | |
| preprocessing numbers (<a href='#6.4.8'>6.4.8</a>), string literals (<a href='#6.4.5'>6.4.5</a>).
 | |
| </pre>
 | |
| <a name='6.4.1'></a>
 | |
| <hr>
 | |
| <h3>6.4.1 [Keywords]</h3>
 | |
| <a name='6.4.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     keyword: one of
 | |
|                            alignas                   enum                      short                     void
 | |
|                            alignof                   extern                    signed                    volatile
 | |
|                            auto                      false                     sizeof                    while
 | |
|                            bool                      float                     static                    _Atomic
 | |
|                            break                     for                       static_assert             _BitInt
 | |
|                            case                      goto                      struct                    _Complex
 | |
|                            char                      if                        switch                    _Decimal128
 | |
|                            const                     inline                    thread_local              _Decimal32
 | |
|                            constexpr                 int                       true                      _Decimal64
 | |
|                            continue                  long                      typedef                   _Generic
 | |
|                            default                   nullptr                   typeof                    _Imaginary
 | |
|                            do                        register                  typeof_unqual             _Noreturn
 | |
|                            double                    restrict                  union
 | |
|                            else                      return                    unsigned
 | |
| 
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.1p2'></a>
 | |
| <pre>2   The above tokens (case sensitive) are reserved (in translation phases 7 and 8) for use as keywords
 | |
|     except in an attribute token, and shall not be used otherwise. The keyword _Imaginary is reserved
 | |
|     for specifying imaginary types.<a href='#FOOTNOTE.76'><sup>[76]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.76'>
 | |
| <pre><i><b>Footnote 76)</b> One possible specification for imaginary types appears in Annex G.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.1p3'></a>
 | |
| <pre>3   The following table provides alternate spellings for certain keywords. These can be used wherever
 | |
|     the keyword can<a href='#FOOTNOTE.77'><sup>[77]</sup></a> .
 | |
|          Keyword             Alternative Spelling
 | |
|         alignas                    _Alignas
 | |
|          alignof                   _Alignof
 | |
|           bool                      _Bool
 | |
|      static_assert             _Static_assert
 | |
|       thread_local              _Thread_local
 | |
| 
 | |
|     The spelling of these keywords, their alternate forms, and of false and true inside expressions that
 | |
|     are subject to the # and ## preprocessing operators is unspecified<a href='#FOOTNOTE.78'><sup>[78]</sup></a> .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.77'>
 | |
| <pre><i><b>Footnote 77)</b> These alternative keywords are obsolescent features and should not be used for new code and development.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.78'>
 | |
| <pre><i><b>Footnote 78)</b> The intent of this specification is to allow but not force the implementation of the corresponding feature by means of a
 | |
|     predefined macro.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.2'></a>
 | |
| <hr>
 | |
| <h3>6.4.2 [Identifiers]</h3>
 | |
| <a name='6.4.2.1'></a>
 | |
| <hr>
 | |
| <h3>6.4.2.1 [General]</h3>
 | |
| <a name='6.4.2.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     identifier:
 | |
|                            identifier-start
 | |
|                            identifier identifier-continue
 | |
| 
 | |
| 
 | |
| 
 | |
|     identifier-start:
 | |
|                            nondigit
 | |
|                            XID_Start character
 | |
|                            universal-character-name of class XID_Start
 | |
|     identifier-continue:
 | |
|                            digit
 | |
|                            nondigit
 | |
|                            XID_Continue character
 | |
|                            universal-character-name of class XID_Continue
 | |
| 
 | |
| 
 | |
| 
 | |
|     nondigit: one of
 | |
|                            _ a b c d e f g h i j k l m
 | |
|                               n o p q r s t u v w x y z
 | |
|                               A B C D E F G H I J K L M
 | |
|                               N O P Q R S T U V W X Y Z
 | |
| 
 | |
| 
 | |
| 
 | |
|     digit: one of
 | |
|                            0 1 2 3 4 5 6 7 8 9
 | |
| 
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.2.1p2'></a>
 | |
| <pre>2   An XID_Start character is an implementation-defined character whose corresponding code point
 | |
|     in ISO/IEC 10646 has the XID_Start property. An XID_Continue character is an implementation-
 | |
|     defined character whose corresponding code point in ISO/IEC 10646 has the XID_Continue property.
 | |
|     An identifier is a sequence of one identifier start character followed by 0 or more identifier continue
 | |
|     characters, which designates one or more entities as described in <a href='#6.2.1'>6.2.1</a>. Lowercase and uppercase
 | |
|     letters are distinct. There is no specific limit on the maximum length of an identifier.
 | |
| </pre>
 | |
| <a name='6.4.2.1p3'></a>
 | |
| <pre>3   The character classes XID_Start and XID_Continue are Derived Core Properties as described by
 | |
|     UAX #4479) . Each character and universal character name in an identifier shall designate a character
 | |
|     whose encoding in ISO/IEC 10646 has the XID_Continue property. The initial character (which
 | |
|     may be a universal character name) shall designate a character whose encoding in ISO/IEC 10646
 | |
|     has the XID_Start property. An identifier shall conform to Normalization Form C as specified in
 | |
|     ISO/IEC 10646. Annex D provides an overview of the conforming identifiers.
 | |
| </pre>
 | |
| <a name='6.4.2.1p4'></a>
 | |
| <pre>4   NOTE 1 Uppercase and lowercase letters are considered different for all identifiers.
 | |
| </pre>
 | |
| <a name='6.4.2.1p5'></a>
 | |
| <pre>5   NOTE 2 In translation phase 4 (4), the term identifier also includes those preprocessing tokens (<a href='#6.4.8'>6.4.8</a>) differentiated as
 | |
|     keywords (<a href='#6.4.1'>6.4.1</a>) in the later translation phase 7 (7).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.2.1p6'></a>
 | |
| <pre>6   When preprocessing tokens are converted to tokens during translation phase 7, if a preprocessing
 | |
|     token could be converted to either a keyword or an identifier, it is converted to a keyword except in
 | |
|     an attribute token.
 | |
| </pre>
 | |
| <a name='6.4.2.1p7'></a>
 | |
| <pre>7   Some identifiers are reserved.
 | |
| 
 | |
|       — All identifiers that begin with a double underscore (__ ) or begin with an underscore (_ )
 | |
|         followed by an uppercase letter are reserved for any use, except those identifiers which are
 | |
|         lexically identical to keywords<a href='#FOOTNOTE.80'><sup>[80]</sup></a> .
 | |
| 
 | |
|       — All identifiers that begin with an underscore are reserved for use as identifiers with file scope
 | |
|         in both the ordinary and tag name spaces.
 | |
| 
 | |
|     Other identifiers may be reserved, see <a href='#7.1.3'>7.1.3</a>.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.80'>
 | |
| <pre><i><b>Footnote 80)</b> This allows a reserved identifier that matches the spelling of a keyword to be used as a macro name by the program.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.2.1p8'></a>
 | |
| <pre>8   If the program declares or defines an identifier in a context in which it is reserved (other than as
 | |
|     allowed by <a href='#7.1.4'>7.1.4</a>), the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.4.2.1p9'></a>
 | |
| <pre>9    If the program defines a reserved identifier or attribute token described in <a href='#6.7.12.1'>6.7.12.1</a> as a macro name,
 | |
|      or removes (with #undef) any macro definition of an identifier in the first group listed above or
 | |
|      attribute token described in <a href='#6.7.12.1'>6.7.12.1</a>, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.4.2.1p10'></a>
 | |
| <pre>10   Some identifiers may be potentially reserved. A potentially reserved identifier is an identifier which is
 | |
|      not reserved unless made so by an implementation providing the identifier (<a href='#7.1.3'>7.1.3</a>) but is anticipated
 | |
|      to become reserved by an implementation or a future version of this document.
 | |
| 
 | |
|      Recommended Practice
 | |
| </pre>
 | |
| <a name='6.4.2.1p11'></a>
 | |
| <pre>11   Implementations are encouraged to issue a diagnostic message when a potentially reserved identifier
 | |
|      is declared or defined for any use that is not implementation-compatible (see below) in a context
 | |
|      where the potentially reserved identifier may be reserved under a conforming implementation. This
 | |
|      brings attention to a potential conflict when porting a program to a future revision of this document.
 | |
| </pre>
 | |
| <a name='6.4.2.1p12'></a>
 | |
| <pre>12   An implementation-compatible use of a potentially reserved identifier is a declaration of an external
 | |
|      name where the name is provided by the implementation as an external name and where the
 | |
|      declaration declares an object or function with a type that is compatible with the type of the object
 | |
|      or function provided by the implementation under that name.
 | |
| 
 | |
|      Implementation limits
 | |
| </pre>
 | |
| <a name='6.4.2.1p13'></a>
 | |
| <pre>13   As discussed in <a href='#5.2.4.1'>5.2.4.1</a>, an implementation may limit the number of significant initial characters
 | |
|      in an identifier; the limit for an external name (an identifier that has external linkage) may be more
 | |
|      restrictive than that for an internal name (a macro name or an identifier that does not have external
 | |
|      linkage). The number of significant characters in an identifier is implementation-defined.
 | |
| </pre>
 | |
| <a name='6.4.2.1p14'></a>
 | |
| <pre>14   Any identifiers that differ in a significant character are different identifiers. If two identifiers differ
 | |
|      only in nonsignificant characters, the behavior is undefined.
 | |
|      Forward references: universal character names (<a href='#6.4.3'>6.4.3</a>), macro replacement (<a href='#6.10.4'>6.10.4</a>), reserved library
 | |
|      identifiers (<a href='#7.1.3'>7.1.3</a>), use of library functions (<a href='#7.1.4'>7.1.4</a>), attributes (<a href='#6.7.12.1'>6.7.12.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.2.2'></a>
 | |
| <hr>
 | |
| <h3>6.4.2.2 [Predefined identifiers]</h3>
 | |
| <a name='6.4.2.2p1'></a>
 | |
| <pre>1 Semantics
 | |
|     The identifier __func__ shall be implicitly declared by the translator as if, immediately following
 | |
|      the opening brace of each function definition, the declaration
 | |
| 
 | |
|                static const char __func__[] = "function-name";
 | |
| 
 | |
| 
 | |
|      appeared, where function-name is the name of the lexically-enclosing function.<a href='#FOOTNOTE.81'><sup>[81]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.81'>
 | |
| <pre><i><b>Footnote 81)</b> Since the name __func__ is reserved for any use by the implementation (<a href='#7.1.3'>7.1.3</a>), if any other identifier is explicitly declared
 | |
|      using the name __func__ , the behavior is undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.2.2p2'></a>
 | |
| <pre>2    This name is encoded as if the implicit declaration had been written in the source character set and
 | |
|      then translated into the execution character set as indicated in translation phase 5.
 | |
| </pre>
 | |
| <a name='6.4.2.2p3'></a>
 | |
| <pre>3    EXAMPLE Consider the code fragment:
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                void myfunc(void)
 | |
|                {
 | |
|                      printf("%s\n", __func__);
 | |
|                      /* ... */
 | |
|                }
 | |
| 
 | |
| 
 | |
|      Each time the function is called, it will print to the standard output stream:
 | |
| 
 | |
|                myfunc
 | |
| 
 | |
| 
 | |
|      Forward references: function definitions (<a href='#6.9.1'>6.9.1</a>).
 | |
| </pre>
 | |
| <a name='6.4.3'></a>
 | |
| <hr>
 | |
| <h3>6.4.3 [Universal character names]</h3>
 | |
| <a name='6.4.3p1'></a>
 | |
| <pre>1 Syntax
 | |
|     universal-character-name:
 | |
|                         \u hex-quad
 | |
|                         \U hex-quad hex-quad
 | |
| 
 | |
|      hex-quad:
 | |
|                            hexadecimal-digit hexadecimal-digit hexadecimal-digit hexadecimal-digit
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.4.3p2'></a>
 | |
| <pre>2   A universal character name shall not designate a code point where the hexadecimal value is:
 | |
| 
 | |
|       — less than 00A0 other than 0024 ($), 0040 (@), or 0060 (` );
 | |
| 
 | |
|       — in the range D800 through DFFF inclusive; or
 | |
|       — greater than 10FFFF<a href='#FOOTNOTE.82'><sup>[82]</sup></a> .
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='FOOTNOTE.82'>
 | |
| <pre><i><b>Footnote 82)</b> The disallowed characters are the characters in the basic character set and the code positions reserved by ISO/IEC 10646
 | |
|     for control characters, the character DELETE, the S-zone (reserved for use by UTF-16), and characters too large to be encoded
 | |
|     by ISO/IEC 10646. Disallowed universal character escape sequences can still be specified with hexadecimal and octal escape
 | |
|     sequences (<a href='#6.4.4.4'>6.4.4.4</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.3p3'></a>
 | |
| <pre>3   Universal character names may be used in identifiers, character constants, and string literals to
 | |
|     designate characters that are not in the basic character set.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.3p4'></a>
 | |
| <pre>4   The universal character name \U nnnnnnnn designates the character whose eight-digit short identifier
 | |
|     (as specified by ISO/IEC 10646) is nnnnnnnn.<a href='#FOOTNOTE.83'><sup>[83]</sup></a> Similarly, the universal character name \u nnnn
 | |
|     designates the character whose four-digit short identifier is nnnn (and whose eight-digit short
 | |
|     identifier is 0000nnnn).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.83'>
 | |
| <pre><i><b>Footnote 83)</b> Short identifiers for characters were first specified in ISO/IEC 10646–1:1993/Amd 9:1997.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4'></a>
 | |
| <hr>
 | |
| <h3>6.4.4 [Constants]</h3>
 | |
| <a name='6.4.4p1'></a>
 | |
| <pre>1 Syntax
 | |
|     constant:
 | |
|                         integer-constant
 | |
|                         floating-constant
 | |
|                         enumeration-constant
 | |
|                         character-constant
 | |
|                         predefined-constant
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.4.4p2'></a>
 | |
| <pre>2   Each constant shall have a type and the value of a constant shall be in the range of representable
 | |
|     values for its type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.4p3'></a>
 | |
| <pre>3   Each constant has a type, determined by its form and value, as detailed later.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.1'></a>
 | |
| <hr>
 | |
| <h3>6.4.4.1 [Integer constants]</h3>
 | |
| <a name='6.4.4.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     integer-constant:
 | |
|                        decimal-constant integer-suffixopt
 | |
|                        octal-constant integer-suffixopt
 | |
|                        hexadecimal-constant integer-suffixopt
 | |
|                        binary-constant integer-suffixopt
 | |
| 
 | |
| 
 | |
| 
 | |
|     decimal-constant:
 | |
|                         nonzero-digit
 | |
|                         decimal-constant ’opt digit
 | |
| 
 | |
| 
 | |
| 
 | |
|     octal-constant:
 | |
|                         0
 | |
|                         octal-constant ’opt octal-digit
 | |
| 
 | |
| 
 | |
| 
 | |
|     hexadecimal-constant:
 | |
|                       hexadecimal-prefix hexadecimal-digit-sequence
 | |
| 
 | |
|     binary-constant:
 | |
|                         binary-prefix binary-digit
 | |
|                         binary-constant ’opt binary-digit
 | |
| 
 | |
| 
 | |
| 
 | |
|     hexadecimal-prefix: one of
 | |
|                         0x 0X
 | |
| 
 | |
| 
 | |
| 
 | |
|     binary-prefix: one of
 | |
|                         0b 0B
 | |
|     nonzero-digit: one of
 | |
|                           1 2 3 4 5 6 7 8 9
 | |
| 
 | |
| 
 | |
| 
 | |
|     octal-digit: one of
 | |
|                           0 1 2 3 4 5 6 7
 | |
| 
 | |
| 
 | |
| 
 | |
|     hexadecimal-digit-sequence:
 | |
|                        hexadecimal-digit
 | |
|                        hexadecimal-digit-sequence ’opt hexadecimal-digit
 | |
| 
 | |
|     hexadecimal-digit: one of
 | |
|                           0 1 2 3 4 5 6 7 8 9
 | |
|                           a b c d e f
 | |
|                           A B C D E F
 | |
| 
 | |
| 
 | |
| 
 | |
|     binary-digit: one of
 | |
|                           0 1
 | |
| 
 | |
| 
 | |
| 
 | |
|     integer-suffix:
 | |
|                           unsigned-suffix long-suffixopt
 | |
|                           unsigned-suffix long-long-suffix
 | |
|                           unsigned-suffix bit-precise-int-suffix
 | |
|                           long-suffix unsigned-suffixopt
 | |
|                           long-long-suffix unsigned-suffixopt
 | |
|                           bit-precise-int-suffix unsigned-suffixopt
 | |
| 
 | |
| 
 | |
| 
 | |
|     bit-precise-int-suffix: one of
 | |
|                            wb WB
 | |
| 
 | |
| 
 | |
| 
 | |
|     unsigned-suffix: one of
 | |
|                           u U
 | |
| 
 | |
| 
 | |
| 
 | |
|     long-suffix: one of
 | |
|                           l L
 | |
| 
 | |
| 
 | |
| 
 | |
|     long-long-suffix: one of
 | |
|                           ll LL
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.4.4.1p2'></a>
 | |
| <pre>2   An integer constant begins with a digit, but has no period or exponent part. It may have a prefix that
 | |
|     specifies its base and a suffix that specifies its type. An optional separating single quote character (
 | |
|     ’ ) in an integer or floating constant is called a digit separator. Digit separators are ignored when
 | |
|     determining the value of the constant.
 | |
| </pre>
 | |
| <a name='6.4.4.1p3'></a>
 | |
| <pre>3   EXAMPLE
 | |
| 
 | |
|      0b11’10’11’01 /* 0b11101101 */
 | |
|      ’1’2 /* character constant ’1’ followed by integer constant 2,
 | |
|               not the integer constant 12 */
 | |
|      11’22 /* 1122 */
 | |
|      0x’FFFF’FFFF /* invalid hexadecimal constant (’ cannot appear after 0x) */
 | |
|      0x1’2’3’4AB’C’D /* 0x1234ABCD */
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.1p4'></a>
 | |
| <pre>4   A decimal constant begins with a nonzero digit and consists of a sequence of decimal digits. An
 | |
|     octal constant consists of the prefix 0 optionally followed by a sequence of the digits 0 through 7
 | |
|     only. A hexadecimal constant consists of the prefix 0x or 0X followed by a sequence of the decimal
 | |
|     digits and the letters a (or A) through f (or F) with values 10 through 15 respectively. A binary
 | |
|     constant consists of the prefix 0b or 0B followed by a sequence of the digits 0 or 1.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.4.1p5'></a>
 | |
| <pre>5   The value of a decimal constant is computed base 10; that of an octal constant, base 8; that of a
 | |
|     hexadecimal constant, base 16; that of a binary constant, base 2. The lexically first digit is the most
 | |
|     significant.
 | |
| </pre>
 | |
| <a name='6.4.4.1p6'></a>
 | |
| <pre>6   The type of an integer constant is the first of the corresponding list in which its value can be
 | |
|     represented.
 | |
|                                                                      Octal, Hexadecimal or Binary
 | |
|           Suffix             Decimal Constant                        Constant
 | |
|           none               int                                     int
 | |
|                              long int                                unsigned int
 | |
|                              long long int                           long int
 | |
|                                                                      unsigned long int
 | |
|                                                                      long long int
 | |
|                                                                      unsigned long long int
 | |
|            u or U            unsigned int                            unsigned int
 | |
|                              unsigned long int                       unsigned long int
 | |
|                              unsigned long long int                  unsigned long long int
 | |
|            l or L            long int                                long int
 | |
|                              long long int                           unsigned long int
 | |
|                                                                      long long int
 | |
|                                                                      unsigned long long int
 | |
|           Both u or U        unsigned long int                       unsigned long int
 | |
|           and l or L         unsigned long long int                  unsigned long long int
 | |
|           ll or LL           long long int                           long long int
 | |
|                                                                      unsigned long long int
 | |
|           Both u or U        unsigned long long int                  unsigned long long int
 | |
|           and ll or LL
 | |
|           wb or WB           _BitInt(N) where the width N            _BitInt(N) where the width N
 | |
|                              is the smallest N greater than          is the smallest N greater than
 | |
|                              1 which can accommodate                 1 which can accommodate
 | |
|                              the value and the sign bit.             the value and the sign bit.
 | |
|           Both u or U        unsigned _BitInt(N) where the           unsigned _BitInt(N) where the
 | |
|           and wb or WB       width N is the smallest N               width N is the smallest N
 | |
|                              greater than 0 which can                greater than 0 which can
 | |
|                              accommodate the value.                  accommodate the value.
 | |
| </pre>
 | |
| <a name='6.4.4.1p7'></a>
 | |
| <pre>7   If an integer constant cannot be represented by any type in its list, it may have an extended integer
 | |
|     type, if the extended integer type can represent its value. If all of the types in the list for the constant
 | |
|     are signed, the extended integer type shall be signed. If all of the types in the list for the constant
 | |
|     are unsigned, the extended integer type shall be unsigned. If the list contains both signed and
 | |
|     unsigned types, the extended integer type may be signed or unsigned. If an integer constant cannot
 | |
|     be represented by any type in its list and has no extended integer type, then the integer constant has
 | |
|     no type.
 | |
| </pre>
 | |
| <a name='6.4.4.1p8'></a>
 | |
| <pre>8   EXAMPLE 1 The wb suffix results in an _BitInt that includes space for the sign bit even if the value of the constant is
 | |
|     positive or was specified in hexadecimal or octal notation.
 | |
| 
 | |
|      -3wb /* Yields an _BitInt(3) that is then negated; two value
 | |
|              bits, one sign bit */
 | |
|      -0x3wb /* Yields an _BitInt(3) that is then negated; two value
 | |
|                bits, one sign bit */
 | |
|      3wb /* Yields an _BitInt(3); two value bits, one sign bit */
 | |
|      3uwb /* Yields an unsigned _BitInt(2) */
 | |
|      -3uwb /* Yields an unsigned _BitInt(2) that is then negated,
 | |
|               resulting in wrap-around */
 | |
| 
 | |
| 
 | |
| 
 | |
|     Forward references: preprocessing numbers (<a href='#6.4.8'>6.4.8</a>), numeric conversion functions (<a href='#7.24.1'>7.24.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.2'></a>
 | |
| <hr>
 | |
| <h3>6.4.4.2 [Floating constants]</h3>
 | |
| <a name='6.4.4.2p1'></a>
 | |
| <pre>1 Syntax
 | |
|     floating-constant:
 | |
|                         decimal-floating-constant
 | |
|                         hexadecimal-floating-constant
 | |
| 
 | |
| 
 | |
| 
 | |
|     decimal-floating-constant:
 | |
|                         fractional-constant exponent-partopt floating-suffixopt
 | |
|                         digit-sequence exponent-part floating-suffixopt
 | |
| 
 | |
| 
 | |
| 
 | |
|     hexadecimal-floating-constant:
 | |
|                        hexadecimal-prefix hexadecimal-fractional-constant
 | |
|                                           binary-exponent-part floating-suffixopt
 | |
|                        hexadecimal-prefix hexadecimal-digit-sequence
 | |
|                                           binary-exponent-part floating-suffixopt
 | |
| 
 | |
| 
 | |
| 
 | |
|     fractional-constant:
 | |
|                            digit-sequenceopt . digit-sequence
 | |
|                            digit-sequence .
 | |
| 
 | |
| 
 | |
| 
 | |
|     exponent-part:
 | |
|                            e signopt digit-sequence
 | |
|                            E signopt digit-sequence
 | |
| 
 | |
| 
 | |
| 
 | |
|     sign: one of
 | |
|                            + -
 | |
| 
 | |
| 
 | |
| 
 | |
|     digit-sequence:
 | |
|                            digit
 | |
|                            digit-sequence ’opt digit
 | |
|     hexadecimal-fractional-constant:
 | |
|                        hexadecimal-digit-sequenceopt . hexadecimal-digit-sequence
 | |
|                        hexadecimal-digit-sequence .
 | |
| 
 | |
| 
 | |
| 
 | |
|     binary-exponent-part:
 | |
|                           p signopt digit-sequence
 | |
|                           P signopt digit-sequence
 | |
| 
 | |
| 
 | |
| 
 | |
|     floating-suffix: one of
 | |
|                           f l F L df dd dl DF DD DL
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.4.4.2p2'></a>
 | |
| <pre>2   A floating suffix df, dd, dl, DF, DD, or DL shall not be used in a hexadecimal floating constant.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.4.4.2p3'></a>
 | |
| <pre>3   A floating constant has a significand part that may be followed by an exponent part and a suffix that
 | |
|     specifies its type. The components of the significand part may include a digit sequence representing
 | |
|     the whole-number part, followed by a period ( .), followed by a digit sequence representing the
 | |
|     fraction part. Digit separators (<a href='#6.4.4.1'>6.4.4.1</a>) are ignored when determining the value of the constant. The
 | |
|     components of the exponent part are an e, E, p, or P followed by an exponent consisting of an
 | |
|     optionally signed digit sequence. Either the whole-number part or the fraction part has to be present;
 | |
|     for decimal floating constants, either the period or the exponent part has to be present.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.4.2p4'></a>
 | |
| <pre>4   The significand part is interpreted as a (decimal or hexadecimal) rational number; the digit sequence
 | |
|     in the exponent part is interpreted as a decimal integer. For decimal floating constants, the exponent
 | |
|     indicates the power of 10 by which the significand part is to be scaled. For hexadecimal floating
 | |
|     constants, the exponent indicates the power of 2 by which the significand part is to be scaled. For
 | |
|     decimal floating constants, and also for hexadecimal floating constants when FLT_RADIX is not a
 | |
|     power of 2, the result is either the nearest representable value, or the larger or smaller representable
 | |
|     value immediately adjacent to the nearest representable value, chosen in an implementation-defined
 | |
|     manner. For hexadecimal floating constants when FLT_RADIX is a power of 2, the result is correctly
 | |
|     rounded.
 | |
| </pre>
 | |
| <a name='6.4.4.2p5'></a>
 | |
| <pre>5   An unsuffixed floating constant has type double. If suffixed by a floating suffix it has a type
 | |
|     according to the following table:
 | |
| 
 | |
|                                              Suffixes for floating constants
 | |
| 
 | |
|                                               Suffix      Type
 | |
|                                               f, F        float
 | |
|                                               l, L        long double
 | |
|                                               df, DF      _Decimal32
 | |
|                                               dd, DD      _Decimal64
 | |
|                                               dl, DL      _Decimal128
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.2p6'></a>
 | |
| <pre>6   The values of floating constants may be represented in greater range and precision than that required
 | |
|     by the type (determined by the suffix); the types are not changed thereby. See <a href='#5.2.4.2.2'>5.2.4.2.2</a> regarding
 | |
|     evaluation formats. <a href='#FOOTNOTE.84'><sup>[84]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.84'>
 | |
| <pre><i><b>Footnote 84)</b> Hexadecimal floating constants can be used to obtain exact values in the semantic type that are independent of the
 | |
|     evaluation format. Casts produce values in the semantic type, though depend on the rounding mode and may raise the
 | |
|     inexact floating-point exception.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4.2p7'></a>
 | |
| <pre>7   Floating constants of decimal floating type that have the same numerical value but different quantum
 | |
|     exponents have distinguishable internal representations. The value shall be correctly rounded as
 | |
|     specified in IEC 60559. The coefficient c and the quantum exponent q of a finite converted decimal
 | |
|     floating-point number (see <a href='#5.2.4.2.3'>5.2.4.2.3</a>) are determined as follows:
 | |
| 
 | |
|       — q is set to the value of signopt digit-sequence in the exponent part, if any, or to 0, otherwise.
 | |
| 
 | |
|       — If there is a fractional constant, q is decreased by the number of digits to the right of the period
 | |
|         and the period is removed to form a digit sequence.
 | |
|       — c is set to the value of the digit sequence (after any period has been removed).
 | |
|       — Rounding required because of insufficient precision or range in the type of the result will
 | |
|         round c to the full precision available in the type, and will adjust q accordingly within the
 | |
|         limits of the type, provided the rounding does not yield an infinity (in which case the result
 | |
|         is an appropriately signed internal representation of infinity). If the full precision of the type
 | |
|         would require q to be smaller than the minimum for the type, then q is pinned at the minimum
 | |
|         and c is adjusted through the subnormal range accordingly, perhaps to zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.2p8'></a>
 | |
| <pre>8   Floating constants are converted to internal format as if at translation-time. The conversion of a
 | |
|     floating constant shall not raise an exceptional condition or a floating-point exception at execution
 | |
|     time. All floating constants of the same source form <a href='#FOOTNOTE.85'><sup>[85]</sup></a> shall convert to the same internal format
 | |
|     with the same value.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.85'>
 | |
| <pre><i><b>Footnote 85)</b> 1.23 , 1.230 , 123e-2 , 123e-02 , and <a href='#1.'>1.</a>23L are all different source forms and thus need not convert to the same internal
 | |
|     format and value.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4.2p9'></a>
 | |
| <pre>9   EXAMPLE Following are floating constants of type _Decimal64 and their values as triples (s, c, q). Note that for
 | |
|     _Decimal64 , the precision (maximum coefficient length) is 16 and the quantum exponent range is −398 ≤ q ≤ 369.
 | |
| 
 | |
| 
 | |
|            0.dd                             (+1, 0, 0)
 | |
|            0.00dd                           (+1, 0, −2)
 | |
|            123.dd                           (+1, 123, 0)
 | |
|            <a href='#1.'>1.</a>23E3dd                         (+1, 123, 1)
 | |
|            <a href='#1.'>1.</a>23E+3dd                        (+1, 123, 1)
 | |
|            12.3E+7dd                        (+1, 123, 6)
 | |
|            12.0dd                           (+1, 120, −1)
 | |
|            12.3dd                           (+1, 123, −1)
 | |
|            0.00123dd                        (+1, 123, −5)
 | |
|            <a href='#1.'>1.</a>23E-12dd                       (+1, 123, −14)
 | |
|            1234.5E-4dd                      (+1, 12345, −5)
 | |
|            0E+7dd                           (+1, 0, 7)
 | |
|            12345678901234567890.dd          (+1, 1234567890123457, 4) assuming default rounding and DEC_EVAL_METHOD is 0
 | |
|                                             or <a href='#FOOTNOTE.186'><sup>[186]</sup></a>
 | |
|            1234E-400dd                      (+1, 12, −398) assuming default rounding and DEC_EVAL_METHOD is 0 or 1
 | |
|            1234E-402dd                      (+1, 0, −398) assuming default rounding and DEC_EVAL_METHOD is 0 or 1
 | |
|            1000.dd                          (+1, 1000, 0)
 | |
|            .0001dd                          (+1, 1, −4)
 | |
|            1000.e0dd                        (+1, 1000, 0)
 | |
|            .0001e0dd                        (+1, 1, −4)
 | |
|            1000.0dd                         (+1, 10000, −1)
 | |
|            0.0001dd                         (+1, 1, −4)
 | |
|            1000.00dd                        (+1, 100000, −2)
 | |
|            00.0001dd                        (+1, 1, −4)
 | |
|            001000.dd                        (+1, 1000, 0)
 | |
|            001000.0dd                       (+1, 10000, −1)
 | |
|            001000.00dd                      (+1, 100000, −2)
 | |
|            00.00dd                          (+1, 0, −2)
 | |
|            00.dd                            (+1, 0, 0)
 | |
|            .00dd                            (+1, 0, −2)
 | |
|            00.00e-5dd                       (+1, 0, −7)
 | |
|            00.e-5dd                         (+1, 0, −5)
 | |
|            .00e-5dd                         (+1, 0, −7)
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.186'>
 | |
| <pre><i><b>Footnote 186)</b> Thus, the attributes [[nodiscard]] and [[__nodiscard__]] can be freely interchanged. Implementations are encour-
 | |
|     aged to behave similarly for attribute tokens (including attribute prefixed tokens) they provide.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4.2p10'></a>
 | |
| <pre>10   The implementation should produce a diagnostic message if a hexadecimal constant cannot be
 | |
|      represented exactly in its evaluation format; the implementation should then proceed with the
 | |
|      translation of the program.
 | |
| </pre>
 | |
| <a name='6.4.4.2p11'></a>
 | |
| <pre>11   The translation-time conversion of floating constants should match the execution-time conversion
 | |
|      of character strings by library functions, such as strtod, given matching inputs suitable for both
 | |
|      conversions, the same result format, and default execution-time rounding. <a href='#FOOTNOTE.87'><sup>[87]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.87'>
 | |
| <pre><i><b>Footnote 87)</b> The specification for the library functions recommends more accurate conversion than required for floating constants
 | |
|      (see <a href='#7.24.1.5'>7.24.1.5</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4.2p12'></a>
 | |
| <pre>12   NOTE Floating constants do not include a sign and are negated by the unary - operator (<a href='#6.5.3.3'>6.5.3.3</a>) which negates the rounded
 | |
|      value of the constant. In contrast, the numeric conversion functions in the strto family (<a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.24.1.6'>7.24.1.6</a>) include the sign as
 | |
|      part of the input value and convert and round the negated input. Negating before rounding and negating after rounding
 | |
|      might yield different results, depending on the rounding direction and whether the results are correctly rounded. For
 | |
|      example, the results are the same when both are correctly rounded using rounding to nearest or rounding toward zero, but
 | |
|      the results are different when they are inexact and correctly rounded using rounding toward positive infinity or rounding
 | |
|      toward negative infinity.
 | |
|      Conversions yielding exact results require no rounding, so are not affected by the order of negating and rounding. For
 | |
|      types with radix 10, decimal floating constants expressed within the precision and range of the evaluation format convert
 | |
|      exactly. For types whose radix is a power of 2, hexadecimal floating constants expressed within the precision and range of the
 | |
|      evaluation format convert exactly.
 | |
| 
 | |
|      Forward references: preprocessing numbers (<a href='#6.4.8'>6.4.8</a>), numeric conversion functions (<a href='#7.24.1'>7.24.1</a>), the
 | |
|      strto function family (<a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.24.1.6'>7.24.1.6</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.3'></a>
 | |
| <hr>
 | |
| <h3>6.4.4.3 [Enumeration constants]</h3>
 | |
| <a name='6.4.4.3p1'></a>
 | |
| <pre>1 Syntax
 | |
|      enumeration-constant:
 | |
|                        identifier
 | |
| 
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.4.4.3p2'></a>
 | |
| <pre>2    An identifier declared as an enumeration constant for an enumeration without a fixed underlying
 | |
|      type has either type int or the enumerated type, as defined in <a href='#6.7.2.2'>6.7.2.2</a>. An identifier declared
 | |
|      as an enumeration constant for an enumeration with a fixed underlying type has the associated
 | |
|      enumeration type.
 | |
| </pre>
 | |
| <a name='6.4.4.3p3'></a>
 | |
| <pre>3    An enumeration constant may be used in an expression (or constant expression) wherever a value
 | |
|      of an integer type may be used.
 | |
|      Forward references: enumeration specifiers (<a href='#6.7.2.2'>6.7.2.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.4'></a>
 | |
| <hr>
 | |
| <h3>6.4.4.4 [Character constants]</h3>
 | |
| <a name='6.4.4.4p1'></a>
 | |
| <pre>1 Syntax
 | |
|      character-constant:
 | |
|                           encoding-prefixopt ’ c-char-sequence ’
 | |
| 
 | |
|      encoding-prefix:
 | |
|                             u8
 | |
|                             u
 | |
|                             U
 | |
|                             L
 | |
| 
 | |
| 
 | |
| 
 | |
|      c-char-sequence:
 | |
|                              c-char
 | |
|                              c-char-sequence c-char
 | |
|     c-char:
 | |
|                        any member of the source character set except
 | |
|                                         the single-quote ’, backslash \ , or new-line character
 | |
|                         escape-sequence
 | |
| 
 | |
| 
 | |
| 
 | |
|     escape-sequence:
 | |
|                         simple-escape-sequence
 | |
|                         octal-escape-sequence
 | |
|                         hexadecimal-escape-sequence
 | |
|                         universal-character-name
 | |
| 
 | |
| 
 | |
| 
 | |
|     simple-escape-sequence: one of
 | |
|                        \’ \" \? \\
 | |
|                        \a \b \f \n \r \t \v
 | |
| 
 | |
| 
 | |
| 
 | |
|     octal-escape-sequence:
 | |
|                        \ octal-digit
 | |
|                        \ octal-digit octal-digit
 | |
|                        \ octal-digit octal-digit octal-digit
 | |
| 
 | |
| 
 | |
| 
 | |
|     hexadecimal-escape-sequence:
 | |
|                       \x hexadecimal-digit
 | |
|                        hexadecimal-escape-sequence hexadecimal-digit
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.4.4.4p2'></a>
 | |
| <pre>2   An integer character constant is a sequence of one or more multibyte characters enclosed in single-
 | |
|     quotes, as in ’x’ . A UTF-8 character constant is the same, except prefixed by u8. A wchar_t character
 | |
|     constant is prefixed by the letter L. A UTF-16 character constant is prefixed by the letter u. A UTF-32
 | |
|     character constant is prefixed by the letter U. Collectively, wchar_t, UTF-16, and UTF-32 character
 | |
|     constants are called wide character constants. With a few exceptions detailed later, the elements of
 | |
|     the sequence are any members of the source character set; they are mapped in an implementation-
 | |
|     defined manner to members of the execution character set.
 | |
| </pre>
 | |
| <a name='6.4.4.4p3'></a>
 | |
| <pre>3   The single-quote ’, the double-quote ", the question-mark ?, the backslash \, and arbitrary integer
 | |
|     values are representable according to the following table of escape sequences:
 | |
|           single quote ’             \’
 | |
|           double quote "             \"
 | |
|           question mark ?            \?
 | |
|           backslash \                \\
 | |
|           octal character            \ octal digits
 | |
|           hexadecimal character      \x hexadecimal digits
 | |
| </pre>
 | |
| <a name='6.4.4.4p4'></a>
 | |
| <pre>4   The double-quote " and question-mark ? are representable either by themselves or by the escape
 | |
|     sequences \" and \?, respectively, but the single-quote ’ and the backslash \ shall be represented,
 | |
|     respectively, by the escape sequences \’ and \\ .
 | |
| </pre>
 | |
| <a name='6.4.4.4p5'></a>
 | |
| <pre>5   The octal digits that follow the backslash in an octal escape sequence are taken to be part of the
 | |
|     construction of a single character for an integer character constant or of a single wide character for a
 | |
|     wide character constant. The numerical value of the octal integer so formed specifies the value of
 | |
|     the desired character or wide character.
 | |
| </pre>
 | |
| <a name='6.4.4.4p6'></a>
 | |
| <pre>6    The hexadecimal digits that follow the backslash and the letter x in a hexadecimal escape sequence
 | |
|      are taken to be part of the construction of a single character for an integer character constant or of a
 | |
|      single wide character for a wide character constant. The numerical value of the hexadecimal integer
 | |
|      so formed specifies the value of the desired character or wide character.
 | |
| </pre>
 | |
| <a name='6.4.4.4p7'></a>
 | |
| <pre>7    Each octal or hexadecimal escape sequence is the longest sequence of characters that can constitute
 | |
|      the escape sequence.
 | |
| </pre>
 | |
| <a name='6.4.4.4p8'></a>
 | |
| <pre>8    In addition, characters not in the basic character set are representable by universal character names
 | |
|      and certain non-graphic characters are representable by escape sequences consisting of the back-
 | |
|      slash \ followed by a lowercase letter: \a, \b, \f, \n, \r, \t, and \v.<a href='#FOOTNOTE.88'><sup>[88]</sup></a>
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='FOOTNOTE.88'>
 | |
| <pre><i><b>Footnote 88)</b> The semantics of these characters were discussed in <a href='#5.2.2'>5.2.2</a>. If any other character follows a backslash, the result is not a
 | |
|      token and a diagnostic is required. See "future language directions" (<a href='#6.11.4'>6.11.4</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4.4p9'></a>
 | |
| <pre>9    The value of an octal or hexadecimal escape sequence shall be in the range of representable values
 | |
|      for the corresponding type:
 | |
|             Prefix     Corresponding Type
 | |
|             none       unsigned char
 | |
|             u8         char8_t
 | |
|             L          the unsigned type corresponding to wchar_t
 | |
|             u          char16_t
 | |
|             U          char32_t
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.4p10'></a>
 | |
| <pre>10   A UTF-8, UTF-16, or UTF-32 character constant shall not contain more than one character.<a href='#FOOTNOTE.89'><sup>[89]</sup></a> The
 | |
|      value shall be representable with a single UTF-8, UTF-16, or UTF-32 code unit.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.89'>
 | |
| <pre><i><b>Footnote 89)</b> For example u8’ab’ violates this constraint.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4.4p11'></a>
 | |
| <pre>11   An integer character constant has type int. The value of an integer character constant containing
 | |
|      a single character that maps to a single value in the literal encoding (<a href='#6.2.9'>6.2.9</a>) is the numerical value
 | |
|      of the representation of the mapped character in the literal encoding interpreted as an integer.
 | |
|      The value of an integer character constant containing more than one character (e.g., ’ab’ ), or
 | |
|      containing a character or escape sequence that does not map to a single value in the literal encoding,
 | |
|      is implementation-defined. If an integer character constant contains a single character or escape
 | |
|      sequence, its value is the one that results when an object with type char whose value is that of the
 | |
|      single character or escape sequence is converted to type int.
 | |
| </pre>
 | |
| <a name='6.4.4.4p12'></a>
 | |
| <pre>12   A UTF-8 character constant has type char8_t. If the UTF8 character constant is not produced
 | |
|      through a hexadecimal or octal escape sequence, the value of a UTF-8 character constant is equal to
 | |
|      its ISO/IEC 10646 code point value, provided that the code point value can be encoded as a single
 | |
|      UTF-8 code unit. Otherwise, the value of the UTF8 character constant is the numeric value specified
 | |
|      in the hexadecimal or octal escape sequence.
 | |
| </pre>
 | |
| <a name='6.4.4.4p13'></a>
 | |
| <pre>13   A UTF-16 character constant has type char16_t which is an unsigned integer types defined in the
 | |
|      <uchar.h> header. If the UTF-16 character constant is not produced through a hexadecimal or octal
 | |
|      escape sequence, the value of a UTF-16 character constant is equal to its ISO/IEC 10646 code point
 | |
|      value, provided that the code point value can be encoded as a single UTF-16 code unit. Otherwise,
 | |
|      the value of the UTF-16 character constant is the numeric value specified in the hexadecimal or octal
 | |
|      escape sequence.
 | |
| </pre>
 | |
| <a name='6.4.4.4p14'></a>
 | |
| <pre>14   A UTF-32 character constant has type char32_t which is an unsigned integer types defined in the
 | |
|      <uchar.h> header. If the UTF-32 character constant is not produced through a hexadecimal or octal
 | |
|      escape sequence, the value of a UTF-32 character constant is equal to its ISO/IEC 10646 code point
 | |
|      value, provided that the code point value can be encoded as a single UTF-32 code unit. Otherwise,
 | |
|      the value of the UTF-32 character constant is the numeric value specified in the hexadecimal or octal
 | |
|      escape sequence.
 | |
| </pre>
 | |
| <a name='6.4.4.4p15'></a>
 | |
| <pre>15   A wchar_t character constant prefixed by the letter L has type wchar_t, an integer type defined in
 | |
|      the <stddef.h> header. The value of a wchar_t character constant containing a single multibyte
 | |
|      character that maps to a single member of the extended execution character set is the wide character
 | |
|      corresponding to that multibyte character in the implementation-defined wide literal encoding
 | |
|      (<a href='#6.2.9'>6.2.9</a>). The value of a wchar_t character constant containing more than one multibyte character or a
 | |
|      single multibyte character that maps to multiple members of the extended execution character set,
 | |
|      or containing a multibyte character or escape sequence not represented in the extended execution
 | |
|      character set, is implementation-defined.
 | |
| </pre>
 | |
| <a name='6.4.4.4p16'></a>
 | |
| <pre>16   EXAMPLE 1 The construction ’\0’ is commonly used to represent the null character.
 | |
| </pre>
 | |
| <a name='6.4.4.4p17'></a>
 | |
| <pre>17   EXAMPLE 2 Consider implementations that use eight bits for objects that have type char. In an implementation in which
 | |
|      type char has the same range of values as signed char, the integer character constant ’\xFF’ has the value −1; if type
 | |
|      char has the same range of values as unsigned char, the character constant ’\xFF’ has the value +255.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.4p18'></a>
 | |
| <pre>18   EXAMPLE 3 Even if eight bits are used for objects that have type char, the construction ’\x123’ specifies an integer character
 | |
|      constant containing only one character, since a hexadecimal escape sequence is terminated only by a non-hexadecimal
 | |
|      character. To specify an integer character constant containing the two characters whose values are ’\x12’ and ’3’ , the
 | |
|      construction ’\0223’ can be used, since an octal escape sequence is terminated after three octal digits. (The value of this
 | |
|      two-character integer character constant is implementation-defined.)
 | |
| </pre>
 | |
| <a name='6.4.4.4p19'></a>
 | |
| <pre>19   EXAMPLE 4 Even if 12 or more bits are used for objects that have type wchar_t, the construction L’\1234’ specifies the
 | |
|      implementation-defined value that results from the combination of the values 0123 and ’4’ .
 | |
| 
 | |
|      Forward references: common definitions <stddef.h> (<a href='#7.21'>7.21</a>), the mbtowc function (<a href='#7.24.7.2'>7.24.7.2</a>), Uni-
 | |
|      code utilities <uchar.h> (<a href='#7.30'>7.30</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.4.5'></a>
 | |
| <hr>
 | |
| <h3>6.4.4.5 [Predefined constants]</h3>
 | |
| <a name='6.4.4.5p1'></a>
 | |
| <pre>1 Syntax
 | |
|      predefined-constant:
 | |
|                              false
 | |
|                              true
 | |
|                              nullptr
 | |
| 
 | |
| 
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='6.4.4.5p2'></a>
 | |
| <pre>2    Some keywords represent constants of a specific value and type.
 | |
| </pre>
 | |
| <a name='6.4.4.5p3'></a>
 | |
| <pre>3    The keywords false and true are constants of type bool with a value of 0 for false and 1 for
 | |
|      true<a href='#FOOTNOTE.90'><sup>[90]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.90'>
 | |
| <pre><i><b>Footnote 90)</b> The constants false and true promote to type int, see <a href='#6.3.1.1'>6.3.1.1</a>. When used for arithmetic, in translation phase 4, they are
 | |
|      signed values and the result of such arithmetic is consistent with the results of later translation phases.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.4.5p4'></a>
 | |
| <pre>4    The keyword nullptr represents a null pointer constant. Details of its type are described in <a href='#7.21.2'>7.21.2</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.5'></a>
 | |
| <hr>
 | |
| <h3>6.4.5 [String literals]</h3>
 | |
| <a name='6.4.5p1'></a>
 | |
| <pre>1 Syntax
 | |
|      string-literal:
 | |
|                              encoding-prefixopt " s-char-sequenceopt "
 | |
| 
 | |
|      s-char-sequence:
 | |
|                              s-char
 | |
|                              s-char-sequence s-char
 | |
| 
 | |
| 
 | |
| 
 | |
|      s-char:
 | |
|                             any member of the source character set except
 | |
|                                              the double-quote ", backslash \, or new-line character
 | |
|                              escape-sequence
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.4.5p2'></a>
 | |
| <pre>2   If a sequence of adjacent string literal tokens includes prefixed string literal tokens, the prefixed
 | |
|     tokens shall all have the same prefix.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.4.5p3'></a>
 | |
| <pre>3   A character string literal is a sequence of zero or more multibyte characters enclosed in double-quotes,
 | |
|     as in "xyz". A UTF-8 string literal is the same, except prefixed by u8. A wchar_t string literal is the
 | |
|     same, except prefixed by L. A UTF-16 string literal is the same, except prefixed by u. A UTF-32 string
 | |
|     literal is the same, except prefixed by U. Collectively, wchar_t, UTF-16, and UTF-32 string literals are
 | |
|     called wide string literals.
 | |
| </pre>
 | |
| <a name='6.4.5p4'></a>
 | |
| <pre>4   The same considerations apply to each element of the sequence in a string literal as if it were in an
 | |
|     integer character constant (for a character or UTF-8 string literal) or a wide character constant (for a
 | |
|     wide string literal), except that the single-quote ’ is representable either by itself or by the escape
 | |
|     sequence \’, but the double-quote " shall be represented by the escape sequence \".
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.5p5'></a>
 | |
| <pre>5   In translation phase 6, the multibyte character sequences specified by any sequence of adjacent
 | |
|     character and identically-prefixed string literal tokens are concatenated into a single multibyte
 | |
|     character sequence. If any of the tokens has an encoding prefix, the resulting multibyte character
 | |
|     sequence is treated as having the same prefix; otherwise, it is treated as a character string literal.
 | |
| </pre>
 | |
| <a name='6.4.5p6'></a>
 | |
| <pre>6   In translation phase 7, a byte or code of value zero is appended to each multibyte character sequence
 | |
|     that results from a string literal or literals. <a href='#FOOTNOTE.91'><sup>[91]</sup></a> The multibyte character sequence is then used to
 | |
|     initialize an array of static storage duration and length just sufficient to contain the sequence. For
 | |
|     character string literals, the array elements have type char, and are initialized with the individual
 | |
|     bytes of the multibyte character sequence corresponding to the literal encoding (<a href='#6.2.9'>6.2.9</a>). For UTF-8
 | |
|     string literals, the array elements have type char8_t, and are initialized with the characters of the
 | |
|     multibyte character sequence, as encoded in UTF-8. For wide string literals prefixed by the letter
 | |
|     L, the array elements have type wchar_t and are initialized with the sequence of wide characters
 | |
|     corresponding to the wide literal encoding. For wide string literals prefixed by the letter u or U,
 | |
|     the array elements have type char16_t or char32_t, respectively, and are initialized sequence of
 | |
|     wide characters corresponding to UTF-16 and UTF-32 encoded text, respectively. The value of a
 | |
|     string literal containing a multibyte character or escape sequence not represented in the execution
 | |
|     character set is implementation-defined. Any hexadecimal escape sequence or octal escape sequence
 | |
|     specified in a u8, u, or U string specifies a single char8_t, char16_t, or char32_t value and may
 | |
|     result in the full character sequence not being valid UTF-8, UTF-16, or UTF-32.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.91'>
 | |
| <pre><i><b>Footnote 91)</b> A string literal might not be a string (see <a href='#7.1.1'>7.1.1</a>), because a null character can be embedded in it by a \0 escape sequence.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.5p7'></a>
 | |
| <pre>7   It is unspecified whether these arrays are distinct provided their elements have the appropriate
 | |
|     values. If the program attempts to modify such an array, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.4.5p8'></a>
 | |
| <pre>8   EXAMPLE 1 This pair of adjacent character string literals
 | |
| 
 | |
|                "\x12" "3"
 | |
| 
 | |
|     produces a single character string literal containing the two characters whose values are ’\x12’ and ’3’ , because escape
 | |
|     sequences are converted into single members of the execution character set just prior to adjacent string literal concatenation.
 | |
| </pre>
 | |
| <a name='6.4.5p9'></a>
 | |
| <pre>9   EXAMPLE 2 Each of the sequences of adjacent string literal tokens
 | |
| 
 | |
|                "a" "b" L"c"
 | |
|                "a" L"b" "c"
 | |
|                L"a" "b" L"c"
 | |
|                L"a" L"b" L"c"
 | |
| 
 | |
|     is equivalent to the string literal
 | |
| 
 | |
|                L"abc"
 | |
| 
 | |
|     Likewise, each of the sequences
 | |
|               "a" "b" u"c"
 | |
|               "a" u"b" "c"
 | |
|               u"a" "b" u"c"
 | |
|               u"a" u"b" u"c"
 | |
| 
 | |
|     is equivalent to
 | |
| 
 | |
|               u"abc"
 | |
| 
 | |
| 
 | |
|     Forward references: common definitions <stddef.h> (<a href='#7.21'>7.21</a>), the mbstowcs function (<a href='#7.24.8.1'>7.24.8.1</a>),
 | |
|     Unicode utilities <uchar.h> (<a href='#7.30'>7.30</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.6'></a>
 | |
| <hr>
 | |
| <h3>6.4.6 [Punctuators]</h3>
 | |
| <a name='6.4.6p1'></a>
 | |
| <pre>1 Syntax
 | |
|     punctuator: one of
 | |
|                            [ ] ( ) { } .   ->
 | |
|                            ++ -- & * + - ~ !
 | |
|                            / % << >> < > <= >=                       ==    !=     ^    |   &&    ||
 | |
|                            ?  :   :: ; ...
 | |
|                            = *= /= %= += -= <<=                      >>=     &=       ^=   |=
 | |
|                            , # ##
 | |
|                            <:  :> <% %> %:  %:%:
 | |
| 
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.6p2'></a>
 | |
| <pre>2   A punctuator is a symbol that has independent syntactic and semantic significance. Depending on
 | |
|     context, it may specify an operation to be performed (which in turn may yield a value or a function
 | |
|     designator, produce a side effect, or some combination thereof) in which case it is known as an
 | |
|     operator (other forms of operator also exist in some contexts). An operand is an entity on which an
 | |
|     operator acts.
 | |
| </pre>
 | |
| <a name='6.4.6p3'></a>
 | |
| <pre>3   In all aspects of the language, the six tokens<a href='#FOOTNOTE.92'><sup>[92]</sup></a>
 | |
|                 <:     :>    <%    %>    %:      %:%:
 | |
|     behave, respectively, the same as the six tokens
 | |
|                 [      ]    {     }     #     ##
 | |
|     except for their spelling.<a href='#FOOTNOTE.93'><sup>[93]</sup></a>
 | |
|     Forward references: expressions (<a href='#6.5'>6.5</a>), declarations (<a href='#6.7'>6.7</a>), preprocessing directives (<a href='#6.10'>6.10</a>), statements
 | |
|     (<a href='#6.8'>6.8</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.92'>
 | |
| <pre><i><b>Footnote 92)</b> These tokens are sometimes called "digraphs".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.93'>
 | |
| <pre><i><b>Footnote 93)</b> Thus [ and <: behave differently when "stringized" (see <a href='#6.10.4.2'>6.10.4.2</a>), but can otherwise be freely interchanged.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.7'></a>
 | |
| <hr>
 | |
| <h3>6.4.7 [Header names]</h3>
 | |
| <a name='6.4.7p1'></a>
 | |
| <pre>1 Syntax
 | |
|     header-name:
 | |
|                             < h-char-sequence >
 | |
|                             " q-char-sequence "
 | |
| 
 | |
| 
 | |
| 
 | |
|     h-char-sequence:
 | |
|                             h-char
 | |
|                             h-char-sequence h-char
 | |
|     h-char:
 | |
|                           any member of the source character set except
 | |
|                                           the new-line character and >
 | |
| 
 | |
| 
 | |
| 
 | |
|     q-char-sequence:
 | |
|                            q-char
 | |
|                            q-char-sequence q-char
 | |
| 
 | |
| 
 | |
| 
 | |
|     q-char:
 | |
|                           any member of the source character set except
 | |
|                                           the new-line character and "
 | |
| 
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.7p2'></a>
 | |
| <pre>2   The sequences in both forms of header names are mapped in an implementation-defined manner to
 | |
|     headers or external source file names as specified in <a href='#6.10.2'>6.10.2</a>.
 | |
| </pre>
 | |
| <a name='6.4.7p3'></a>
 | |
| <pre>3   If the characters ’ , \ , ", // , or /* occur in the sequence between the < and > delimiters, the behavior
 | |
|     is undefined. Similarly, if the characters ’ , \ , // , or /* occur in the sequence between the "
 | |
|     delimiters, the behavior is undefined.<a href='#FOOTNOTE.94'><sup>[94]</sup></a> Header name preprocessing tokens are recognized only
 | |
|     within #include preprocessing directives and in implementation-defined locations within #pragma
 | |
|     directives.<a href='#FOOTNOTE.95'><sup>[95]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.94'>
 | |
| <pre><i><b>Footnote 94)</b> Thus, sequences of characters that resemble escape sequences cause undefined behavior.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.95'>
 | |
| <pre><i><b>Footnote 95)</b> For an example of a header name preprocessing token used in a #pragma directive, see <a href='#6.10.10'>6.10.10</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.7p4'></a>
 | |
| <pre>4   EXAMPLE The following sequence of characters:
 | |
| 
 | |
|               0x3<1/a.h>1e2
 | |
|               #include <1/a.h>
 | |
|               #define const.member@$
 | |
| 
 | |
|     forms the following sequence of preprocessing tokens (with each individual preprocessing token delimited by a { on the left
 | |
|     and a } on the right).
 | |
| 
 | |
|               {0x3}{<}{1}{/}{a}{.}{h}{>}{1e2}
 | |
|               {#}{include} {<1/a.h>}
 | |
|               {#}{define} {const}{.}{member}{@}{$}
 | |
| 
 | |
| 
 | |
|     Forward references: source file inclusion (<a href='#6.10.2'>6.10.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.8'></a>
 | |
| <hr>
 | |
| <h3>6.4.8 [Preprocessing numbers]</h3>
 | |
| <a name='6.4.8p1'></a>
 | |
| <pre>1 Syntax
 | |
|     pp-number:
 | |
|                            digit
 | |
|                            . digit
 | |
|                            pp-number identifier-continue
 | |
|                            pp-number ’ digit
 | |
|                            pp-number ’ nondigit
 | |
|                            pp-number e sign
 | |
|                            pp-number E sign
 | |
|                            pp-number p sign
 | |
|                            pp-number P sign
 | |
|                            pp-number .
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.4.8p2'></a>
 | |
| <pre>2   A preprocessing number begins with a digit optionally preceded by a period (.) and may be followed
 | |
|     by valid identifier characters and the character sequences e+, e-, E+, E-, p+, p-, P+, or P-.
 | |
| </pre>
 | |
| <a name='6.4.8p3'></a>
 | |
| <pre>3   Preprocessing number tokens lexically include all floating and integer constant tokens.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.4.8p4'></a>
 | |
| <pre>4   A preprocessing number does not have type or a value; it acquires both after a successful conversion
 | |
|     (as part of translation phase 7) to a floating constant token or an integer constant token.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.4.9'></a>
 | |
| <hr>
 | |
| <h3>6.4.9 [Comments]</h3>
 | |
| <a name='6.4.9p1'></a>
 | |
| <pre>1   Except within a character constant, a string literal, or a comment, the characters /* introduce a
 | |
|     comment. The contents of such a comment are examined only to identify multibyte characters and
 | |
|     to find the characters */ that terminate it.<a href='#FOOTNOTE.96'><sup>[96]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.96'>
 | |
| <pre><i><b>Footnote 96)</b> Thus, /
 | |
|                    * . . . */ comments do not nest.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.4.9p2'></a>
 | |
| <pre>2   Except within a character constant, a string literal, or a comment, the characters // introduce a
 | |
|     comment that includes all multibyte characters up to, but not including, the next new-line character.
 | |
|     The contents of such a comment are examined only to identify multibyte characters and to find the
 | |
|     terminating new-line character.
 | |
| </pre>
 | |
| <a name='6.4.9p3'></a>
 | |
| <pre>3   EXAMPLE
 | |
| 
 | |
|               "a//b"                                  // four-character string literal
 | |
|               #include "//e"                          // undefined behavior
 | |
|               // */                                   // comment, not syntax error
 | |
|               f = g/**//h;                            // equivalent to f = g / h;
 | |
|               //\
 | |
|               i();                                    // part of a two-line comment
 | |
|               /\
 | |
|               / j();                                  // part of a two-line comment
 | |
|               #define glue(x,y) x##y
 | |
|               glue(/,/) k();                          // syntax error, not comment
 | |
|               /*//*/ l();                             // equivalent to l();
 | |
|               m = n//**/o
 | |
|                 + p;                                  // equivalent to m = n + p;
 | |
| </pre>
 | |
| <a name='6.5'></a>
 | |
| <hr>
 | |
| <h3>6.5 [Expressions]</h3>
 | |
| <a name='6.5p1'></a>
 | |
| <pre>1   An expression is a sequence of operators and operands that specifies computation of a value, or that
 | |
|     designates an object or a function, or that generates side effects, or that performs a combination
 | |
|     thereof. The value computations of the operands of an operator are sequenced before the value
 | |
|     computation of the result of the operator.
 | |
| </pre>
 | |
| <a name='6.5p2'></a>
 | |
| <pre>2   If a side effect on a scalar object is unsequenced relative to either a different side effect on the
 | |
|     same scalar object or a value computation using the value of the same scalar object, the behavior
 | |
|     is undefined. If there are multiple allowable orderings of the subexpressions of an expression, the
 | |
|     behavior is undefined if such an unsequenced side effect occurs in any of the orderings.<a href='#FOOTNOTE.97'><sup>[97]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.97'>
 | |
| <pre><i><b>Footnote 97)</b> This paragraph renders undefined statement expressions such as
 | |
|               i = ++i + 1;
 | |
|               a[i++] = i;
 | |
|     while allowing
 | |
|               i = i + 1;
 | |
|               a[i] = i;
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5p3'></a>
 | |
| <pre>3   The grouping of operators and operands is indicated by the syntax.<a href='#FOOTNOTE.98'><sup>[98]</sup></a> Except as specified later, side
 | |
|     effects and value computations of subexpressions are unsequenced.<a href='#FOOTNOTE.99'><sup>[99]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.98'>
 | |
| <pre><i><b>Footnote 98)</b> The syntax specifies the precedence of operators in the evaluation of an expression, which is the same as the order of the
 | |
|     major subclauses of this subclause, highest precedence first. Thus, for example, the expressions allowed as the operands
 | |
|     of the binary + operator (<a href='#6.5.6'>6.5.6</a>) are those expressions defined in <a href='#6.5.1'>6.5.1</a> through <a href='#6.5.6'>6.5.6</a>. The exceptions are cast expressions
 | |
|     (<a href='#6.5.4'>6.5.4</a>) as operands of unary operators (<a href='#6.5.3'>6.5.3</a>), and an operand contained between any of the following pairs of operators:
 | |
|     grouping parentheses () (<a href='#6.5.1'>6.5.1</a>), subscripting brackets [] (<a href='#6.5.2.1'>6.5.2.1</a>), function-call parentheses () (<a href='#6.5.2.2'>6.5.2.2</a>), and the conditional
 | |
|     operator ?: (<a href='#6.5.15'>6.5.15</a>).
 | |
|        Within each major subclause, the operators have the same precedence. Left- or right-associativity is indicated in each
 | |
|     subclause by the syntax for the expressions discussed therein.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.99'>
 | |
| <pre><i><b>Footnote 99)</b> In an expression that is evaluated more than once during the execution of a program, unsequenced and indeterminately
 | |
|     sequenced evaluations of its subexpressions need not be performed consistently in different evaluations.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5p4'></a>
 | |
| <pre>4   Some operators (the unary operator ~ , and the binary operators << , >> , &, ^, and |, collectively
 | |
|     described as bitwise operators) are required to have operands that have integer type. These operators
 | |
|     yield values that depend on the internal representations of integers, and have implementation-
 | |
|     defined and undefined aspects for signed types.
 | |
| </pre>
 | |
| <a name='6.5p5'></a>
 | |
| <pre>5   If an exceptional condition occurs during the evaluation of an expression (that is, if the result is not
 | |
|     mathematically defined or not in the range of representable values for its type), the behavior is
 | |
|     undefined.
 | |
| </pre>
 | |
| <a name='6.5p6'></a>
 | |
| <pre>6   The effective type of an object for an access to its stored value is the declared type of the object, if
 | |
|     any.<a href='#FOOTNOTE.100'><sup>[100]</sup></a> If a value is stored into an object having no declared type through an lvalue having a type
 | |
|     that is not a non-atomic character type, then the type of the lvalue becomes the effective type of the
 | |
|     object for that access and for subsequent accesses that do not modify the stored value. If a value
 | |
|     is copied into an object having no declared type using memcpy or memmove, or is copied as an array
 | |
|     of character type, then the effective type of the modified object for that access and for subsequent
 | |
|     accesses that do not modify the value is the effective type of the object from which the value is
 | |
|     copied, if it has one. For all other accesses to an object having no declared type, the effective type of
 | |
|     the object is simply the type of the lvalue used for the access.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.100'>
 | |
| <pre><i><b>Footnote 100)</b> Allocated objects have no declared type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5p7'></a>
 | |
| <pre>7   An object shall have its stored value accessed only by an lvalue expression that has one of the
 | |
|     following types:<a href='#FOOTNOTE.101'><sup>[101]</sup></a>
 | |
| 
 | |
|        — a type compatible with the effective type of the object,
 | |
| 
 | |
|        — a qualified version of a type compatible with the effective type of the object,
 | |
| 
 | |
|        — a type that is the signed or unsigned type corresponding to the effective type of the object,
 | |
|       — a type that is the signed or unsigned type corresponding to a qualified version of the effective
 | |
|         type of the object,
 | |
|       — an aggregate or union type that includes one of the aforementioned types among its members
 | |
|         (including, recursively, a member of a subaggregate or contained union), or
 | |
|       — a character type.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.101'>
 | |
| <pre><i><b>Footnote 101)</b> The intent of this list is to specify those circumstances in which an object can or cannot be aliased.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5p8'></a>
 | |
| <pre>8   A floating expression may be contracted, that is, evaluated as though it were a single opera-
 | |
|     tion, thereby omitting rounding errors implied by the source code and the expression evalua-
 | |
|     tion method.<a href='#FOOTNOTE.102'><sup>[102]</sup></a> The FP_CONTRACT pragma in <math.h> provides a way to disallow contracted
 | |
|     expressions. Otherwise, whether and how expressions are contracted is implementation-defined.<a href='#FOOTNOTE.103'><sup>[103]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.102'>
 | |
| <pre><i><b>Footnote 102)</b> The intermediate operations in the contracted expression are evaluated as if to infinite range and precision, while the
 | |
|     final operation is rounded to the format determined by the expression evaluation method. A contracted expression might
 | |
|     also omit the raising of floating-point exceptions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.103'>
 | |
| <pre><i><b>Footnote 103)</b> This license is specifically intended to allow implementations to exploit fast machine instructions that combine multiple
 | |
|     C operators. As contractions potentially undermine predictability, and can even decrease accuracy for containing expressions,
 | |
|     their use needs to be well-defined and clearly documented.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5p9'></a>
 | |
| <pre>9   Operators involving decimal floating types are evaluated according to the semantics of IEC 60559,
 | |
|     including production of results with the preferred quantum exponent as specified in IEC 60559.
 | |
|     Forward references: the FP_CONTRACT pragma (<a href='#7.12.2'>7.12.2</a>), copying functions (<a href='#7.26.2'>7.26.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.1'></a>
 | |
| <hr>
 | |
| <h3>6.5.1 [Primary expressions]</h3>
 | |
| <a name='6.5.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     primary-expression:
 | |
|                        identifier
 | |
|                        constant
 | |
|                        string-literal
 | |
|                        ( expression )
 | |
|                        generic-selection
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
|     The identifier in an identifier primary expression shall have a visible declaration as an ordinary
 | |
|     identifier that declares an object or a function<a href='#FOOTNOTE.104'><sup>[104]</sup></a> .
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.104'>
 | |
| <pre><i><b>Footnote 104)</b> An identifier designating an enumeration constant is a primary expression through the constant production, not the
 | |
|     identifier production.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.1p2'></a>
 | |
| <pre>2   An identifier primary expression designating an object is an lvalue. An identifier primary expression
 | |
|     designating a function is a function designator.
 | |
| </pre>
 | |
| <a name='6.5.1p3'></a>
 | |
| <pre>3   A constant is a primary expression. Its type depends on its form and value, as detailed in <a href='#6.4.4'>6.4.4</a>.
 | |
| </pre>
 | |
| <a name='6.5.1p4'></a>
 | |
| <pre>4   A string literal is a primary expression. It is an lvalue with type as detailed in <a href='#6.4.5'>6.4.5</a>.
 | |
| </pre>
 | |
| <a name='6.5.1p5'></a>
 | |
| <pre>5   A parenthesized expression is a primary expression. Its type, value, and semantics are identical to
 | |
|     those of the unparenthesized expression.
 | |
| </pre>
 | |
| <a name='6.5.1p6'></a>
 | |
| <pre>6   A generic selection is a primary expression. Its type, value, and semantics depend on the selected
 | |
|     generic association, as detailed in the following subclause.
 | |
|     Forward references: declarations (<a href='#6.7'>6.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.1.1'></a>
 | |
| <hr>
 | |
| <h3>6.5.1.1 [Generic selection]</h3>
 | |
| <a name='6.5.1.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     generic-selection:
 | |
|                            _Generic ( assignment-expression , generic-assoc-list )
 | |
|      generic-assoc-list:
 | |
|                             generic-association
 | |
|                         generic-assoc-list , generic-association
 | |
|      generic-association:
 | |
|                         type-name : assignment-expression
 | |
|                         default : assignment-expression
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.1.1p2'></a>
 | |
| <pre>2   A generic selection shall have no more than one default generic association. The type name in a
 | |
|     generic association shall specify a complete object type other than a variably modified type. No two
 | |
|     generic associations in the same generic selection shall specify compatible types. The type of the
 | |
|     controlling expression is the type of the expression as if it had undergone an lvalue conversion,<a href='#FOOTNOTE.105'><sup>[105]</sup></a>
 | |
|     array to pointer conversion, or function to pointer conversion. That type shall be compatible with at
 | |
|     most one of the types named in the generic association list. If a generic selection has no default
 | |
|     generic association, its controlling expression shall have type compatible with exactly one of the
 | |
|     types named in its generic association list.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.105'>
 | |
| <pre><i><b>Footnote 105)</b> An lvalue conversion drops type qualifiers.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.1.1p3'></a>
 | |
| <pre>3   The controlling expression of a generic selection is not evaluated. If a generic selection has a generic
 | |
|     association with a type name that is compatible with the type of the controlling expression, then the
 | |
|     result expression of the generic selection is the expression in that generic association. Otherwise, the
 | |
|     result expression of the generic selection is the expression in the default generic association. None
 | |
|     of the expressions from any other generic association of the generic selection is evaluated.
 | |
| </pre>
 | |
| <a name='6.5.1.1p4'></a>
 | |
| <pre>4   The type and value of a generic selection are identical to those of its result expression. It is an
 | |
|     lvalue, a function designator, or a void expression if its result expression is, respectively, an lvalue, a
 | |
|     function designator, or a void expression.
 | |
| </pre>
 | |
| <a name='6.5.1.1p5'></a>
 | |
| <pre>5   EXAMPLE The cbrt type-generic macro could be implemented as follows:
 | |
| 
 | |
|              #define cbrt(X) _Generic((X),                                  \
 | |
|                                      long double: cbrtl,                    \
 | |
|                                      default: cbrt,                         \
 | |
|                                      float: cbrtf                           \
 | |
|                                      )(X)
 | |
| 
 | |
| 
 | |
| 
 | |
|     See <a href='#7.27'>7.27</a> how such a macro could be implemented with the required rounding properties.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2'></a>
 | |
| <hr>
 | |
| <h3>6.5.2 [Postfix operators]</h3>
 | |
| <a name='6.5.2p1'></a>
 | |
| <pre>1 Syntax
 | |
|     postfix-expression:
 | |
|                            primary-expression
 | |
|                            postfix-expression [ expression ]
 | |
|                            postfix-expression ( argument-expression-listopt )
 | |
|                            postfix-expression . identifier
 | |
|                            postfix-expression -> identifier
 | |
|                            postfix-expression ++
 | |
|                            postfix-expression --
 | |
|                            compound-literal
 | |
| 
 | |
|      argument-expression-list:
 | |
|                        assignment-expression
 | |
|                        argument-expression-list , assignment-expression
 | |
| </pre>
 | |
| <a name='6.5.2.1'></a>
 | |
| <hr>
 | |
| <h3>6.5.2.1 [Array subscripting]</h3>
 | |
| <a name='6.5.2.1p1'></a>
 | |
| <pre>1 Constraints
 | |
|    One of the expressions shall have type "pointer to complete object type", the other expression shall
 | |
|     have integer type, and the result has type "type".
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.2.1p2'></a>
 | |
| <pre>2   A postfix expression followed by an expression in square brackets [] is a subscripted designation of
 | |
|     an element of an array object. The definition of the subscript operator [] is that E1[E2] is identical
 | |
|     to (*((E1)+(E2))) . Because of the conversion rules that apply to the binary + operator, if E1 is an
 | |
|     array object (equivalently, a pointer to the initial element of an array object) and E2 is an integer,
 | |
|     E1[E2] designates the E2 -th element of E1 (counting from zero).
 | |
| </pre>
 | |
| <a name='6.5.2.1p3'></a>
 | |
| <pre>3   Successive subscript operators designate an element of a multidimensional array object. If E is an
 | |
|     n-dimensional array (n ≥ 2) with dimensions i × j × · · · × k, then E (used as other than an lvalue) is
 | |
|     converted to a pointer to an (n − 1)-dimensional array with dimensions j × · · · × k. If the unary *
 | |
|     operator is applied to this pointer explicitly, or implicitly as a result of subscripting, the result is the
 | |
|     referenced (n − 1)-dimensional array, which itself is converted into a pointer if used as other than an
 | |
|     lvalue. It follows from this that arrays are stored in row-major order (last subscript varies fastest).
 | |
| </pre>
 | |
| <a name='6.5.2.1p4'></a>
 | |
| <pre>4   EXAMPLE Consider the array object defined by the declaration
 | |
| 
 | |
|                int x[3][5];
 | |
| 
 | |
|     Here x is a 3 × 5 array of objects of type int; more precisely, x is an array of three element objects, each of which is an array of
 | |
|     five objects of type int. In the expression x[i], which is equivalent to (*((x)+(i))) , x is first converted to a pointer to the
 | |
|     initial array of five objects of type int. Then i is adjusted according to the type of x, which conceptually entails multiplying i
 | |
|     by the size of the object to which the pointer points, namely an array of five int objects. The results are added and indirection
 | |
|     is applied to yield an array of five objects of type int. When used in the expression x[i][j], that array is in turn converted
 | |
|     to a pointer to the first of the objects of type int, so x[i][j] yields an int.
 | |
| 
 | |
|     Forward references: additive operators (<a href='#6.5.6'>6.5.6</a>), address and indirection operators (<a href='#6.5.3.2'>6.5.3.2</a>), array
 | |
|     declarators (<a href='#6.7.6.2'>6.7.6.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.2'></a>
 | |
| <hr>
 | |
| <h3>6.5.2.2 [Function calls]</h3>
 | |
| <a name='6.5.2.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The expression that denotes the called function<a href='#FOOTNOTE.106'><sup>[106]</sup></a> shall have type pointer to function returning
 | |
|     void or returning a complete object type other than an array type.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.106'>
 | |
| <pre><i><b>Footnote 106)</b> Most often, this is the result of converting an identifier that is a function designator.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.2p2'></a>
 | |
| <pre>2   The number of arguments shall agree with the number of parameters. Each argument shall have a
 | |
|     type such that its value may be assigned to an object with the unqualified version of the type of its
 | |
|     corresponding parameter
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.2.2p3'></a>
 | |
| <pre>3   A postfix expression followed by parentheses () containing a possibly empty, comma-separated
 | |
|     list of expressions is a function call. The postfix expression denotes the called function. The list of
 | |
|     expressions specifies the arguments to the function.
 | |
| </pre>
 | |
| <a name='6.5.2.2p4'></a>
 | |
| <pre>4   An argument may be an expression of any complete object type. In preparing for the call to a
 | |
|     function, the arguments are evaluated, and each parameter is assigned the value of the corresponding
 | |
|     argument.<a href='#FOOTNOTE.107'><sup>[107]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.107'>
 | |
| <pre><i><b>Footnote 107)</b> A function can change the values of its parameters, but these changes cannot affect the values of the arguments. On the
 | |
|     other hand, it is possible to pass a pointer to an object, and the function can then change the value of the object pointed to. A
 | |
|     parameter declared to have array or function type is adjusted to have a pointer type as described in <a href='#6.7.6.3'>6.7.6.3</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.2p5'></a>
 | |
| <pre>5   If the expression that denotes the called function has type pointer to function returning an object
 | |
|     type, the function call expression has the same type as that object type, and has the value determined
 | |
|     as specified in <a href='#6.8.6.4'>6.8.6.4</a>. Otherwise, the function call has type void.
 | |
| </pre>
 | |
| <a name='6.5.2.2p6'></a>
 | |
| <pre>6   The arguments are implicitly converted, as if by assignment, to the types of the corresponding
 | |
|     parameters, taking the type of each parameter to be the unqualified version of its declared type. The
 | |
|     ellipsis notation in a function prototype declarator causes argument type conversion to stop after the
 | |
|      last declared parameter, if present. The integer promotions are performed on each trailing argument,
 | |
|      and trailing arguments that have type float are promoted to double. These are called the default
 | |
|      argument promotions. No other conversions are performed implicitly.
 | |
| </pre>
 | |
| <a name='6.5.2.2p7'></a>
 | |
| <pre>7    If the function is defined with a type that is not compatible with the type (of the expression) pointed
 | |
|      to by the expression that denotes the called function, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.5.2.2p8'></a>
 | |
| <pre>8    There is a sequence point after the evaluations of the function designator and the actual arguments
 | |
|      but before the actual call. Every evaluation in the calling function (including other function calls)
 | |
|      that is not otherwise specifically sequenced before or after the execution of the body of the called
 | |
|      function is indeterminately sequenced with respect to the execution of the called function.<a href='#FOOTNOTE.108'><sup>[108]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.108'>
 | |
| <pre><i><b>Footnote 108)</b> In other words, function executions do not "interleave" with each other.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.2p9'></a>
 | |
| <pre>9    Recursive function calls shall be permitted, both directly and indirectly through any chain of other
 | |
|      functions.
 | |
| </pre>
 | |
| <a name='6.5.2.2p10'></a>
 | |
| <pre>10   EXAMPLE In the function call
 | |
| 
 | |
|                (*pf[f1()]) (f2(), f3() + f4())
 | |
| 
 | |
|      the functions f1, f2, f3, and f4 can be called in any order. All side effects have to be completed before the function pointed
 | |
|      to by pf[f1()] is called.
 | |
| 
 | |
|      Forward references: function declarators (<a href='#6.7.6.3'>6.7.6.3</a>), function definitions (<a href='#6.9.1'>6.9.1</a>), the return statement
 | |
|      (<a href='#6.8.6.4'>6.8.6.4</a>), simple assignment (<a href='#6.5.16.1'>6.5.16.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.3'></a>
 | |
| <hr>
 | |
| <h3>6.5.2.3 [Structure and union members]</h3>
 | |
| <a name='6.5.2.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|     The first operand of the . operator shall have an atomic, qualified, or unqualified structure or union
 | |
|      type, and the second operand shall name a member of that type.
 | |
| </pre>
 | |
| <a name='6.5.2.3p2'></a>
 | |
| <pre>2    The first operand of the-> operator shall have type "pointer to atomic, qualified, or unqualified
 | |
|      structure" or "pointer to atomic, qualified, or unqualified union", and the second operand shall
 | |
|      name a member of the type pointed to.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.5.2.3p3'></a>
 | |
| <pre>3    A postfix expression followed by the . operator and an identifier designates a member of a structure
 | |
|      or union object. The value is that of the named member,<a href='#FOOTNOTE.109'><sup>[109]</sup></a> and is an lvalue if the first expression is
 | |
|      an lvalue. If the first expression has qualified type, the result has the so-qualified version of the type
 | |
|      of the designated member.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.109'>
 | |
| <pre><i><b>Footnote 109)</b> If the member used to read the contents of a union object is not the same as the member last used to store a value in the
 | |
|      object, the appropriate part of the object representation of the value is reinterpreted as an object representation in the new
 | |
|      type as described in <a href='#6.2.6'>6.2.6</a> (a process sometimes called "type punning"). This might be a non-value representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.3p4'></a>
 | |
| <pre>4    A postfix expression followed by the-> operator and an identifier designates a member of a structure
 | |
|      or union object. The value is that of the named member of the object to which the first expression
 | |
|      points, and is an lvalue.<a href='#FOOTNOTE.110'><sup>[110]</sup></a> If the first expression is a pointer to a qualified type, the result has the
 | |
|      so-qualified version of the type of the designated member.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.110'>
 | |
| <pre><i><b>Footnote 110)</b> If &E is a valid pointer expression (where & is the "address-of" operator, which generates a pointer to its operand), the
 | |
|      expression (&E)->MOS is the same as <a href='#E.'>E.</a>MOS.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.3p5'></a>
 | |
| <pre>5    Accessing a member of an atomic structure or union object results in undefined behavior.<a href='#FOOTNOTE.111'><sup>[111]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.111'>
 | |
| <pre><i><b>Footnote 111)</b> For example, a data race would occur if access to the entire structure or union in one thread conflicts with access to a
 | |
|      member from another thread, where at least one access is a modification. Members can be safely accessed using a non-atomic
 | |
|      object which is assigned to or from the atomic object.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.3p6'></a>
 | |
| <pre>6    One special guarantee is made in order to simplify the use of unions: if a union contains several
 | |
|      structures that share a common initial sequence (see below), and if the union object currently contains
 | |
|      one of these structures, it is permitted to inspect the common initial part of any of them anywhere
 | |
|      that a declaration of the completed type of the union is visible. Two structures share a common initial
 | |
|      sequence if corresponding members have compatible types (and, for bit-fields, the same widths) for a
 | |
|      sequence of one or more initial members.
 | |
| </pre>
 | |
| <a name='6.5.2.3p7'></a>
 | |
| <pre>7    EXAMPLE 1 If f is a function returning a structure or union, and x is a member of that structure or union, f().x is a valid
 | |
|      postfix expression but is not an lvalue.
 | |
| </pre>
 | |
| <a name='6.5.2.3p8'></a>
 | |
| <pre>8   EXAMPLE 2 In:
 | |
| 
 | |
|               struct s { int i; const int ci; };
 | |
|               struct s s;
 | |
|               const struct s cs;
 | |
|               volatile struct s vs;
 | |
| 
 | |
| 
 | |
| 
 | |
|     the various members have the types:
 | |
|           s.i       int
 | |
|           s.ci      const int
 | |
|           cs.i      const int
 | |
|           cs.ci     const int
 | |
|           vs.i      volatile int
 | |
|           vs.ci     volatile const int
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.3p9'></a>
 | |
| <pre>9   EXAMPLE 3 The following is a valid fragment:
 | |
| 
 | |
|               union {
 | |
|                     struct {
 | |
|                           int    alltypes;
 | |
|                     } n;
 | |
|                     struct {
 | |
|                           int    type;
 | |
|                           int    intnode;
 | |
|                     } ni;
 | |
|                     struct {
 | |
|                           int    type;
 | |
|                           double doublenode;
 | |
|                     } nf;
 | |
|               } u;
 | |
|               u.nf.type = 1;
 | |
|               u.nf.doublenode = <a href='#3.14'>3.14</a>;
 | |
|               /* ... */
 | |
|               if (u.n.alltypes == 1)
 | |
|                     if (sin(u.nf.doublenode) == 0.0)
 | |
|                           /* ... */
 | |
| 
 | |
| 
 | |
| 
 | |
|     The following is not a valid fragment (because the union type is not visible within function f):
 | |
| 
 | |
|               struct t1 { int m; };
 | |
|               struct t2 { int m; };
 | |
|               int f(struct t1 *p1, struct t2 *p2)
 | |
|               {
 | |
|                     if (p1->m < 0)
 | |
|                           p2->m = -p2->m;
 | |
|                     return p1->m;
 | |
|               }
 | |
|               int g()
 | |
|               {
 | |
|                     union {
 | |
|                           struct t1 s1;
 | |
|                           struct t2 s2;
 | |
|                     } u;
 | |
|                     /* ... */
 | |
|                     return f(&u.s1, &u.s2);
 | |
|               }
 | |
| 
 | |
| 
 | |
| 
 | |
|     Forward references: address and indirection operators (<a href='#6.5.3.2'>6.5.3.2</a>), structure and union specifiers
 | |
|     (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
| </pre>
 | |
| <a name='6.5.2.4'></a>
 | |
| <hr>
 | |
| <h3>6.5.2.4 [Postfix increment and decrement operators]</h3>
 | |
| <a name='6.5.2.4p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The operand of the postfix increment or decrement operator shall have atomic, qualified, or unquali-
 | |
|     fied real or pointer type, and shall be a modifiable lvalue.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.2.4p2'></a>
 | |
| <pre>2   The result of the postfix ++ operator is the value of the operand. As a side effect, the value of the
 | |
|     operand object is incremented (that is, the value 1 of the appropriate type is added to it). See the
 | |
|     discussions of additive operators and compound assignment for information on constraints, types,
 | |
|     and conversions and the effects of operations on pointers. The value computation of the result is
 | |
|     sequenced before the side effect of updating the stored value of the operand. With respect to an
 | |
|     indeterminately-sequenced function call, the operation of postfix ++ is a single evaluation. Postfix
 | |
|     ++ on an object with atomic type is a read-modify-write operation with memory_order_seq_cst
 | |
|     memory order semantics.<a href='#FOOTNOTE.112'><sup>[112]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.112'>
 | |
| <pre><i><b>Footnote 112)</b> Where a pointer to an atomic object can be formed and E has integer type, E++ is equivalent to the following code
 | |
|     sequence where T is the type of E:
 | |
|                T *addr = &E;
 | |
|                T old = *addr;
 | |
|                T new;
 | |
|                do {
 | |
|                      new = old + 1;
 | |
|                } while (!atomic_compare_exchange_strong(addr, &old, new));
 | |
|     with old being the result of the operation.
 | |
|       Special care is necessary if E has floating type; see <a href='#6.5.16.2'>6.5.16.2</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.4p3'></a>
 | |
| <pre>3   The postfix-- operator is analogous to the postfix ++ operator, except that the value of the operand
 | |
|     is decremented (that is, the value 1 of the appropriate type is subtracted from it).
 | |
|     Forward references: additive operators (<a href='#6.5.6'>6.5.6</a>), compound assignment (<a href='#6.5.16.2'>6.5.16.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.5'></a>
 | |
| <hr>
 | |
| <h3>6.5.2.5 [Compound literals]</h3>
 | |
| <a name='6.5.2.5p1'></a>
 | |
| <pre>1 Syntax
 | |
|             compound-literal:
 | |
|                     ( storage-class-specifiersopt type-name ) braced-initializer
 | |
| 
 | |
| 
 | |
|                 storage-class-specifiers:
 | |
|                           storage-class-specifier
 | |
|                           storage-class-specifiers storage-class-specifier
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.2.5p2'></a>
 | |
| <pre>2   The type name shall specify a complete object type or an array of unknown size, but not a variable
 | |
|     length array type.
 | |
| </pre>
 | |
| <a name='6.5.2.5p3'></a>
 | |
| <pre>3   All the constraints for initializer lists in <a href='#6.7.10'>6.7.10</a> also apply to compound literals.
 | |
| </pre>
 | |
| <a name='6.5.2.5p4'></a>
 | |
| <pre>4   If the compound literal is evaluated outside the body of a function and outside of any parameter list,
 | |
|     it is associated with file scope; otherwise, it is associated with the enclosing block. Depending on
 | |
|     this association, the storage-class specifiers SC (possibly empty)<a href='#FOOTNOTE.113'><sup>[113]</sup></a> , type name T, and initializer list,
 | |
|     if any, shall be such that they are valid specifiers for an object definition in file scope or block scope,
 | |
|     respectively, of the following form,
 | |
| 
 | |
|                SC typeof(T) ID = { IL };
 | |
| 
 | |
| 
 | |
|     where ID is an identifier that is unique for the whole program and where IL is a (possibly empty)
 | |
|      initializer list with nested structure, designators, values and types as the initializer list of the
 | |
|      compound literal. All the constraints for storage class specifiers in <a href='#6.7.1'>6.7.1</a> also apply correspondingly
 | |
|      to compound literals.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.113'>
 | |
| <pre><i><b>Footnote 113)</b> If the storage-class specifiers contain the same storage-class specifier more than once, the following constraint is violated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.5p5'></a>
 | |
| <pre>5    A compound literal provides an unnamed object whose value, type, storage duration and other
 | |
|      properties are as if given by the definition syntax in the constraints; if the storage duration is
 | |
|      automatic, the lifetime of the instance of the unnamed object is the current execution of the enclosing
 | |
|      block<a href='#FOOTNOTE.114'><sup>[114]</sup></a> . If the storage-class specifiers contain other specifiers than constexpr, static, register,
 | |
|      or thread_local the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.114'>
 | |
| <pre><i><b>Footnote 114)</b> Note that this differs from a cast expression. For example, a cast specifies a conversion to scalar types or void only, and
 | |
|      the result of a cast expression is not an lvalue.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.5p6'></a>
 | |
| <pre>6    The value of the compound literal is that of an lvalue corresponding to the unnamed object.
 | |
| </pre>
 | |
| <a name='6.5.2.5p7'></a>
 | |
| <pre>7    All the semantic rules for initializer lists in <a href='#6.7.10'>6.7.10</a> also apply to compound literals<a href='#FOOTNOTE.115'><sup>[115]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.115'>
 | |
| <pre><i><b>Footnote 115)</b> For example, subobjects without explicit initializers are initialized to zero.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.5p8'></a>
 | |
| <pre>8    EXAMPLE 1 Consider the following 2 functions:
 | |
| 
 | |
|        int f(int*);
 | |
|        int g(char * para[f((int[27]){ 0, })]) {
 | |
|              /* ... */
 | |
|              return 0;
 | |
|        }
 | |
| 
 | |
|      Here, each call to g creates an unnamed object of type int[27] to determine the variably-modified type of para for the
 | |
|      duration of the call. During that determination, a pointer to the object is passed into a call to the function f. If a pointer to the
 | |
|      object is kept by f, access to that object is possible during the whole execution of the call to g. The lifetime of the object ends
 | |
|      with the end of the call to g; for any access after that, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.5p9'></a>
 | |
| <pre>9    String literals, and compound literals with const-qualified types, need not designate distinct ob-
 | |
|      jects.<a href='#FOOTNOTE.116'><sup>[116]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.116'>
 | |
| <pre><i><b>Footnote 116)</b> This allows implementations to share storage for string literals and constant compound literals with the same or
 | |
|      overlapping representations.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.2.5p10'></a>
 | |
| <pre>10   EXAMPLE 2 The file scope definition
 | |
| 
 | |
|                 int *p = (int []){2, 4};
 | |
| 
 | |
|      initializes p to point to the first element of an array of two ints, the first having the value two and the second, four. The
 | |
|      expressions in this compound literal are required to be constant. The unnamed object has static storage duration.
 | |
| </pre>
 | |
| <a name='6.5.2.5p11'></a>
 | |
| <pre>11   EXAMPLE 3 In contrast, in
 | |
| 
 | |
|                 void f(void)
 | |
|                 {
 | |
|                       int *p;
 | |
|                       /*...*/
 | |
|                       p = (int [2]){*p};
 | |
|                       /*...*/
 | |
|                 }
 | |
| 
 | |
|      p is assigned the address of the first element of an array of two ints, the first having the value previously pointed to by p and
 | |
|      the second, zero. The expressions in this compound literal need not be constant. The unnamed object has automatic storage
 | |
|      duration.
 | |
| </pre>
 | |
| <a name='6.5.2.5p12'></a>
 | |
| <pre>12   EXAMPLE 4 Initializers with designations can be combined with compound literals. Structure objects created using
 | |
|      compound literals can be passed to functions without depending on member order:
 | |
| 
 | |
|                 drawline((struct point){.x=1, .y=1},
 | |
|                       (struct point){.x=3, .y=4});
 | |
| 
 | |
|      Or, if drawline instead expected pointers to struct point:
 | |
| 
 | |
|                 drawline(&(struct point){.x=1, .y=1},
 | |
|                          &(struct point){.x=3, .y=4});
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.5p13'></a>
 | |
| <pre>13   EXAMPLE 5 A read-only compound literal can be specified through constructions like:
 | |
| 
 | |
|                 (const float []){1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6}
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.5p14'></a>
 | |
| <pre>14   EXAMPLE 6 The following three expressions have different meanings:
 | |
| 
 | |
|                 "/tmp/fileXXXXXX"
 | |
|                 (char []){"/tmp/fileXXXXXX"}
 | |
|                 (const char []){"/tmp/fileXXXXXX"}
 | |
| 
 | |
|      The first always has static storage duration and has type array of char, but need not be modifiable; the last two have
 | |
|      automatic storage duration when they occur within the body of a function, and the first of these two is modifiable.
 | |
| </pre>
 | |
| <a name='6.5.2.5p15'></a>
 | |
| <pre>15   EXAMPLE 7 Like string literals, const-qualified compound literals can be placed into read-only memory and can even be
 | |
|      shared. For example,
 | |
| 
 | |
|                 (const char []){"abc"} == "abc"
 | |
| 
 | |
|      might yield 1 if the literals’ storage is shared.
 | |
| </pre>
 | |
| <a name='6.5.2.5p16'></a>
 | |
| <pre>16   EXAMPLE 8 Since compound literals are unnamed, a single compound literal cannot specify a circularly linked object. For
 | |
|      example, there is no way to write a self-referential compound literal that could be used as the function argument in place of
 | |
|      the named object endless_zeros below:
 | |
| 
 | |
|                 struct int_list { int car; struct int_list *cdr; };
 | |
|                 struct int_list endless_zeros = {0, &endless_zeros};
 | |
|                 eval(endless_zeros);
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.2.5p17'></a>
 | |
| <pre>17   EXAMPLE 9 Each compound literal creates only a single object in a given scope:
 | |
| 
 | |
|                 struct s { int i; };
 | |
| 
 | |
|                 int f (void)
 | |
|                 {
 | |
|                       struct s *p = 0, *q;
 | |
|                       int j = 0;
 | |
| 
 | |
|                 again:
 | |
|                       q = p, p = &((struct s){ j++ });
 | |
|                       if (j < 2) goto again;
 | |
| 
 | |
|                          return p == q && q->i == 1;
 | |
|                 }
 | |
| 
 | |
|      The function f() always returns the value 1.
 | |
|  18 Note that if an iteration statement were used instead of an explicit goto and a label, the lifetime of the unnamed object would
 | |
|     be the body of the loop only, and on entry next time around p would have indeterminate representation, which would result
 | |
|     in undefined behavior.
 | |
| 
 | |
|      Forward references: type names (<a href='#6.7.7'>6.7.7</a>), initialization (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.3'></a>
 | |
| <hr>
 | |
| <h3>6.5.3 [Unary operators]</h3>
 | |
| <a name='6.5.3p1'></a>
 | |
| <pre>1 Syntax
 | |
|      unary-expression:
 | |
|                               postfix-expression
 | |
|                               ++ unary-expression
 | |
|                               -- unary-expression
 | |
|                               unary-operator cast-expression
 | |
|                               sizeof unary-expression
 | |
|                               sizeof ( type-name )
 | |
|                               alignof ( type-name )
 | |
|      unary-operator: one of
 | |
|                            &   *    +    -    ~    !
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.3.1'></a>
 | |
| <hr>
 | |
| <h3>6.5.3.1 [Prefix increment and decrement operators]</h3>
 | |
| <a name='6.5.3.1p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The operand of the prefix increment or decrement operator shall have atomic, qualified, or unquali-
 | |
|     fied real or pointer type, and shall be a modifiable lvalue.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.3.1p2'></a>
 | |
| <pre>2   The value of the operand of the prefix ++ operator is incremented. The result is the new value of the
 | |
|     operand after incrementation. The expression ++E is equivalent to (E+=1) . See the discussions of
 | |
|     additive operators and compound assignment for information on constraints, types, side effects,
 | |
|     and conversions and the effects of operations on pointers.
 | |
| </pre>
 | |
| <a name='6.5.3.1p3'></a>
 | |
| <pre>3   The prefix-- operator is analogous to the prefix ++ operator, except that the value of the operand is
 | |
|     decremented.
 | |
|     Forward references: additive operators (<a href='#6.5.6'>6.5.6</a>), compound assignment (<a href='#6.5.16.2'>6.5.16.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.3.2'></a>
 | |
| <hr>
 | |
| <h3>6.5.3.2 [Address and indirection operators]</h3>
 | |
| <a name='6.5.3.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The operand of the unary & operator shall be either a function designator, the result of a [] or unary
 | |
|     * operator, or an lvalue that designates an object that is not a bit-field and is not declared with the
 | |
|     register storage-class specifier.
 | |
| </pre>
 | |
| <a name='6.5.3.2p2'></a>
 | |
| <pre>2   The operand of the unary * operator shall have pointer type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.3.2p3'></a>
 | |
| <pre>3   The unary & operator yields the address of its operand. If the operand has type "type", the result has
 | |
|     type "pointer to type". If the operand is the result of a unary * operator, neither that operator nor
 | |
|     the & operator is evaluated and the result is as if both were omitted, except that the constraints on
 | |
|     the operators still apply and the result is not an lvalue. Similarly, if the operand is the result of a []
 | |
|     operator, neither the & operator nor the unary * that is implied by the [] is evaluated and the result
 | |
|     is as if the & operator were removed and the [] operator were changed to a + operator. Otherwise,
 | |
|     the result is a pointer to the object or function designated by its operand.
 | |
| </pre>
 | |
| <a name='6.5.3.2p4'></a>
 | |
| <pre>4   The unary * operator denotes indirection. If the operand points to a function, the result is a function
 | |
|     designator; if it points to an object, the result is an lvalue designating the object. If the operand has
 | |
|     type "pointer to type", the result has type "type". If an invalid value has been assigned to the pointer,
 | |
|     the behavior of the unary * operator is undefined.<a href='#FOOTNOTE.117'><sup>[117]</sup></a>
 | |
|     Forward references: storage-class specifiers (<a href='#6.7.1'>6.7.1</a>), structure and union specifiers (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.117'>
 | |
| <pre><i><b>Footnote 117)</b> Thus, & E is equivalent to E (even if E is a null pointer), and &(E1[E2]) to ((E1)+(E2)) . It is always true that if E is a
 | |
|                  *
 | |
|     function designator or an lvalue that is a valid operand of the unary & operator, *&E is a function designator or an lvalue
 | |
|     equal to E. If *P is an lvalue and T is the name of an object pointer type, *(T)P is an lvalue that has a type compatible with
 | |
|     that to which T points.
 | |
|        Among the invalid values for dereferencing a pointer by the unary * operator are a null pointer, an address inappropriately
 | |
|     aligned for the type of object pointed to, and the address of an object after the end of its lifetime.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.3.3'></a>
 | |
| <hr>
 | |
| <h3>6.5.3.3 [Unary arithmetic operators]</h3>
 | |
| <a name='6.5.3.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The operand of the unary + or- operator shall have arithmetic type; of the ~ operator, integer type;
 | |
|     of the ! operator, scalar type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.3.3p2'></a>
 | |
| <pre>2   The result of the unary + operator is the value of its (promoted) operand. The integer promotions
 | |
|     are performed on the operand, and the result has the promoted type.
 | |
| </pre>
 | |
| <a name='6.5.3.3p3'></a>
 | |
| <pre>3   The result of the unary- operator is the negative of its (promoted) operand. The integer promotions
 | |
|     are performed on the operand, and the result has the promoted type.
 | |
| </pre>
 | |
| <a name='6.5.3.3p4'></a>
 | |
| <pre>4   The result of the ~ operator is the bitwise complement of its (promoted) operand (that is, each bit in
 | |
|     the result is set if and only if the corresponding bit in the converted operand is not set). The integer
 | |
|     promotions are performed on the operand, and the result has the promoted type. If the promoted
 | |
|     type is an unsigned type, the expression ~E is equivalent to the maximum value representable in
 | |
|     that type minus E.
 | |
| </pre>
 | |
| <a name='6.5.3.3p5'></a>
 | |
| <pre>5   The result of the logical negation operator ! is 0 if the value of its operand compares unequal to
 | |
|     0, 1 if the value of its operand compares equal to 0. The result has type int. The expression !E is
 | |
|     equivalent to (0==E) .
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.3.4'></a>
 | |
| <hr>
 | |
| <h3>6.5.3.4 [The sizeof and alignof operators]</h3>
 | |
| <a name='6.5.3.4p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The sizeof operator shall not be applied to an expression that has function type or an incomplete
 | |
|     type, to the parenthesized name of such a type, or to an expression that designates a bit-field member.
 | |
|     The alignof operator shall not be applied to a function type or an incomplete type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.3.4p2'></a>
 | |
| <pre>2   The sizeof operator yields the size (in bytes) of its operand, which may be an expression or the
 | |
|     parenthesized name of a type. The size is determined from the type of the operand. The result
 | |
|     is an integer. If the type of the operand is a variable length array type, the operand is evaluated;
 | |
|     otherwise, the operand is not evaluated and the result is an integer constant.
 | |
| </pre>
 | |
| <a name='6.5.3.4p3'></a>
 | |
| <pre>3   The alignof operator yields the alignment requirement of its operand type. The operand is not
 | |
|     evaluated and the result is an integer constant expression. When applied to an array type, the result
 | |
|     is the alignment requirement of the element type.
 | |
| </pre>
 | |
| <a name='6.5.3.4p4'></a>
 | |
| <pre>4   When sizeof is applied to an operand that has type char, unsigned char, or signed char, (or
 | |
|     a qualified version thereof) the result is 1. When applied to an operand that has array type, the
 | |
|     result is the total number of bytes in the array.<a href='#FOOTNOTE.118'><sup>[118]</sup></a> When applied to an operand that has structure or
 | |
|     union type, the result is the total number of bytes in such an object, including internal and trailing
 | |
|     padding.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.118'>
 | |
| <pre><i><b>Footnote 118)</b> When applied to a parameter declared to have array or function type, the sizeof operator yields the size of the adjusted
 | |
|     (pointer) type (see <a href='#6.9.1'>6.9.1</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.3.4p5'></a>
 | |
| <pre>5   The value of the result of both operators is implementation-defined, and its type (an unsigned
 | |
|     integer type) is size_t, defined in <stddef.h> (and other headers).
 | |
| </pre>
 | |
| <a name='6.5.3.4p6'></a>
 | |
| <pre>6   EXAMPLE 1 A principal use of the sizeof operator is in communication with routines such as storage allocators and I/O
 | |
|     systems. A storage-allocation function might accept a size (in bytes) of an object to allocate and return a pointer to void. For
 | |
|     example:
 | |
| 
 | |
|               extern void *alloc(size_t);
 | |
|               double *dp = alloc(sizeof *dp);
 | |
| 
 | |
|     The implementation of the alloc function presumably ensures that its return value is aligned suitably for conversion to a
 | |
|     pointer to double.
 | |
| </pre>
 | |
| <a name='6.5.3.4p7'></a>
 | |
| <pre>7   EXAMPLE 2 Another use of the sizeof operator is to compute the number of elements in an array:
 | |
| 
 | |
|               sizeof array / sizeof array[0]
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.3.4p8'></a>
 | |
| <pre>8   EXAMPLE 3 In this example, the size of a variable length array is computed and returned from a function:
 | |
| 
 | |
|               #include <stddef.h>
 | |
| 
 | |
|               size_t fsize3(int n)
 | |
|               {
 | |
|                     char b[n+3];                  // variable length array
 | |
|                     return sizeof b;              // execution time sizeof
 | |
|               }
 | |
|               int main()
 | |
|               {
 | |
|                     size_t size;
 | |
|                     size = fsize3(10); // fsize3 returns 13
 | |
|                     return 0;
 | |
|               }
 | |
| 
 | |
| 
 | |
|     Forward references: common definitions <stddef.h> (<a href='#7.21'>7.21</a>), declarations (<a href='#6.7'>6.7</a>), structure and union
 | |
|     specifiers (<a href='#6.7.2.1'>6.7.2.1</a>), type names (<a href='#6.7.7'>6.7.7</a>), array declarators (<a href='#6.7.6.2'>6.7.6.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.4'></a>
 | |
| <hr>
 | |
| <h3>6.5.4 [Cast operators]</h3>
 | |
| <a name='6.5.4p1'></a>
 | |
| <pre>1 Syntax
 | |
|     cast-expression:
 | |
|                             unary-expression
 | |
|                             ( type-name ) cast-expression
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.4p2'></a>
 | |
| <pre>2   Unless the type name specifies a void type, the type name shall specify atomic, qualified, or
 | |
|     unqualified scalar type, and the operand shall have scalar type.
 | |
| </pre>
 | |
| <a name='6.5.4p3'></a>
 | |
| <pre>3   Conversions that involve pointers, other than where permitted by the constraints of <a href='#6.5.16.1'>6.5.16.1</a>, shall be
 | |
|     specified by means of an explicit cast.
 | |
| </pre>
 | |
| <a name='6.5.4p4'></a>
 | |
| <pre>4   A pointer type shall not be converted to any floating type. A floating type shall not be converted to
 | |
|     any pointer type. The type nullptr_t shall not be converted to any type other than void, bool or a
 | |
|     pointer type. No type other than nullptr_t shall be converted to nullptr_t.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.4p5'></a>
 | |
| <pre>5   Preceding an expression by a parenthesized type name converts the value of the expression to the
 | |
|     unqualified version of the named type. This construction is called a cast<a href='#FOOTNOTE.119'><sup>[119]</sup></a> . A cast that specifies no
 | |
|     conversion has no effect on the type or value of an expression.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.119'>
 | |
| <pre><i><b>Footnote 119)</b> A cast does not yield an lvalue.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.4p6'></a>
 | |
| <pre>6   If the value of the expression is represented with greater range or precision than required by the type
 | |
|     named by the cast (<a href='#6.3.1.8'>6.3.1.8</a>), then the cast specifies a conversion even if the type of the expression is
 | |
|     the same as the named type and removes any extra range and precision.
 | |
|     Forward references: equality operators (<a href='#6.5.9'>6.5.9</a>), function declarators (<a href='#6.7.6.3'>6.7.6.3</a>), simple assignment
 | |
|     (<a href='#6.5.16.1'>6.5.16.1</a>), type names (<a href='#6.7.7'>6.7.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.5'></a>
 | |
| <hr>
 | |
| <h3>6.5.5 [Multiplicative operators]</h3>
 | |
| <a name='6.5.5p1'></a>
 | |
| <pre>1 Syntax
 | |
|     multiplicative-expression:
 | |
|                         cast-expression
 | |
|                         multiplicative-expression * cast-expression
 | |
|                         multiplicative-expression / cast-expression
 | |
|                         multiplicative-expression % cast-expression
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.5p2'></a>
 | |
| <pre>2   Each of the operands shall have arithmetic type. The operands of the % operator shall have integer
 | |
|     type.
 | |
| </pre>
 | |
| <a name='6.5.5p3'></a>
 | |
| <pre>3   If either operand has decimal floating type, the other operand shall not have standard floating type,
 | |
|     complex type, or imaginary type.
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.5p4'></a>
 | |
| <pre>4   The usual arithmetic conversions are performed on the operands.
 | |
| </pre>
 | |
| <a name='6.5.5p5'></a>
 | |
| <pre>5   The result of the binary * operator is the product of the operands.
 | |
| </pre>
 | |
| <a name='6.5.5p6'></a>
 | |
| <pre>6   The result of the / operator is the quotient from the division of the first operand by the second; the
 | |
|     result of the % operator is the remainder. In both operations, if the value of the second operand is
 | |
|     zero, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.5.5p7'></a>
 | |
| <pre>7   When integers are divided, the result of the / operator is the algebraic quotient with any fractional
 | |
|     part discarded.<a href='#FOOTNOTE.120'><sup>[120]</sup></a> If the quotient a/b is representable, the expression (a/b)*b + a%b shall equal a;
 | |
|     otherwise, the behavior of both a/b and a%b is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.120'>
 | |
| <pre><i><b>Footnote 120)</b> This is often called "truncation toward zero".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.6'></a>
 | |
| <hr>
 | |
| <h3>6.5.6 [Additive operators]</h3>
 | |
| <a name='6.5.6p1'></a>
 | |
| <pre>1 Syntax
 | |
|     additive-expression:
 | |
|                         multiplicative-expression
 | |
|                         additive-expression + multiplicative-expression
 | |
|                         additive-expression - multiplicative-expression
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.6p2'></a>
 | |
| <pre>2   For addition, either both operands shall have arithmetic type, or one operand shall be a pointer to a
 | |
|     complete object type and the other shall have integer type. (Incrementing is equivalent to adding 1.)
 | |
| </pre>
 | |
| <a name='6.5.6p3'></a>
 | |
| <pre>3   For subtraction, one of the following shall hold:
 | |
| 
 | |
|       — both operands have arithmetic type;
 | |
| 
 | |
|       — both operands are pointers to qualified or unqualified versions of compatible complete object
 | |
|         types; or
 | |
| 
 | |
|       — the left operand is a pointer to a complete object type and the right operand has integer type.
 | |
| 
 | |
|     (Decrementing is equivalent to subtracting 1.)
 | |
| </pre>
 | |
| <a name='6.5.6p4'></a>
 | |
| <pre>4   If either operand has decimal floating type, the other operand shall not have standard floating type,
 | |
|     complex type, or imaginary type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.6p5'></a>
 | |
| <pre>5   If both operands have arithmetic type, the usual arithmetic conversions are performed on them.
 | |
| </pre>
 | |
| <a name='6.5.6p6'></a>
 | |
| <pre>6   The result of the binary + operator is the sum of the operands.
 | |
| </pre>
 | |
| <a name='6.5.6p7'></a>
 | |
| <pre>7   The result of the binary- operator is the difference resulting from the subtraction of the second
 | |
|     operand from the first.
 | |
| </pre>
 | |
| <a name='6.5.6p8'></a>
 | |
| <pre>8   For the purposes of these operators, a pointer to an object that is not an element of an array behaves
 | |
|     the same as a pointer to the first element of an array of length one with the type of the object as its
 | |
|     element type.
 | |
| </pre>
 | |
| <a name='6.5.6p9'></a>
 | |
| <pre>9   When an expression that has integer type is added to or subtracted from a pointer, the result has the
 | |
|     type of the pointer operand. If the pointer operand points to an element of an array object, and the
 | |
|     array is large enough, the result points to an element offset from the original element such that the
 | |
|     difference of the subscripts of the resulting and original array elements equals the integer expression.
 | |
|     In other words, if the expression P points to the i-th element of an array object, the expressions
 | |
|     (P)+N (equivalently, N+(P)) and (P)-N (where N has the value n) point to, respectively, the i + n-th
 | |
|     and i − n-th elements of the array object, provided they exist. Moreover, if the expression P points to
 | |
|     the last element of an array object, the expression (P)+1 points one past the last element of the array
 | |
|      object, and if the expression Q points one past the last element of an array object, the expression
 | |
|      (Q)-1 points to the last element of the array object. If the pointer operand and the result do not point
 | |
|      to elements of the same array object or one past the last element of the array object, the behavior is
 | |
|      undefined. If the addition or subtraction produces an overflow, the behavior is undefined. If the
 | |
|      result points one past the last element of the array object, it shall not be used as the operand of a
 | |
|      unary * operator that is evaluated.
 | |
| </pre>
 | |
| <a name='6.5.6p10'></a>
 | |
| <pre>10   When two pointers are subtracted, both shall point to elements of the same array object, or one past
 | |
|      the last element of the array object; the result is the difference of the subscripts of the two array
 | |
|      elements. The size of the result is implementation-defined, and its type (a signed integer type) is
 | |
|      ptrdiff_t defined in the <stddef.h> header. If the result is not representable in an object of that
 | |
|      type, the behavior is undefined. In other words, if the expressions P and Q point to, respectively, the
 | |
|      i-th and j-th elements of an array object, the expression (P)-(Q) has the value i − j provided the
 | |
|      value fits in an object of type ptrdiff_t. Moreover, if the expression P points either to an element of
 | |
|      an array object or one past the last element of an array object, and the expression Q points to the last
 | |
|      element of the same array object, the expression ((Q)+1)-(P) has the same value as ((Q)-(P))+1
 | |
|      and as-((P)-((Q)+1)) , and has the value zero if the expression P points one past the last element
 | |
|      of the array object, even though the expression (Q)+1 does not point to an element of the array
 | |
|      object.<a href='#FOOTNOTE.121'><sup>[121]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.121'>
 | |
| <pre><i><b>Footnote 121)</b> Another way to approach pointer arithmetic is first to convert the pointer(s) to character pointer(s): In this scheme the
 | |
|      integer expression added to or subtracted from the converted pointer is first multiplied by the size of the object originally
 | |
|      pointed to, and the resulting pointer is converted back to the original type. For pointer subtraction, the result of the difference
 | |
|      between the character pointers is similarly divided by the size of the object originally pointed to.
 | |
|         When viewed in this way, an implementation need only provide one extra byte (which can overlap another object in the
 | |
|      program) just after the end of the object in order to satisfy the "one past the last element" requirements.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.6p11'></a>
 | |
| <pre>11   EXAMPLE Pointer arithmetic is well defined with pointers to variable length array types.
 | |
| 
 | |
|                {
 | |
|                         int n = 4, m = 3;
 | |
|                         int a[n][m];
 | |
|                         int (*p)[m] = a; // p == &a[0]
 | |
|                         p += 1;           // p == &a[1]
 | |
|                         (*p)[2] = 99;     // a[1][2] == 99
 | |
|                         n = p - a;        // n == 1
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.6p12'></a>
 | |
| <pre>12 If array a in the above example were declared to be an array of known constant size, and pointer p were declared to be a
 | |
|    pointer to an array of the same known constant size (pointing to a), the results would be the same.
 | |
| 
 | |
|      Forward references: array declarators (<a href='#6.7.6.2'>6.7.6.2</a>), common definitions <stddef.h> (<a href='#7.21'>7.21</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.7'></a>
 | |
| <hr>
 | |
| <h3>6.5.7 [Bitwise shift operators]</h3>
 | |
| <a name='6.5.7p1'></a>
 | |
| <pre>1 Syntax
 | |
|      shift-expression:
 | |
|                              additive-expression
 | |
|                              shift-expression << additive-expression
 | |
|                              shift-expression >> additive-expression
 | |
| 
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.5.7p2'></a>
 | |
| <pre>2    Each of the operands shall have integer type.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.5.7p3'></a>
 | |
| <pre>3    The integer promotions are performed on each of the operands. The type of the result is that of the
 | |
|      promoted left operand. If the value of the right operand is negative or is greater than or equal to the
 | |
|      width of the promoted left operand, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.5.7p4'></a>
 | |
| <pre>4    The result of E1 << E2 is E1 left-shifted E2 bit positions; vacated bits are filled with zeros. If E1 has
 | |
|      an unsigned type, the value of the result is E1 × 2E2 , wrapped around. If E1 has a signed type and
 | |
|     nonnegative value, and E1 × 2E2 is representable in the result type, then that is the resulting value;
 | |
|     otherwise, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.5.7p5'></a>
 | |
| <pre>5   The result of E1 >> E2 is E1 right-shifted E2 bit positions. If E1 has an unsigned type or if E1 has a
 | |
|     signed type and a nonnegative value, the value of the result is the integral part of the quotient of
 | |
|     E1/2E2 . If E1 has a signed type and a negative value, the resulting value is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.8'></a>
 | |
| <hr>
 | |
| <h3>6.5.8 [Relational operators]</h3>
 | |
| <a name='6.5.8p1'></a>
 | |
| <pre>1 Syntax
 | |
|     relational-expression:
 | |
|                          shift-expression
 | |
|                          relational-expression < shift-expression
 | |
|                          relational-expression > shift-expression
 | |
|                          relational-expression <= shift-expression
 | |
|                          relational-expression >= shift-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.8p2'></a>
 | |
| <pre>2   One of the following shall hold:
 | |
| 
 | |
|       — both operands have real type; or
 | |
| 
 | |
|       — both operands are pointers to qualified or unqualified versions of compatible object types.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.8p3'></a>
 | |
| <pre>3   If either operand has decimal floating type, the other operand shall not have standard floating type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.8p4'></a>
 | |
| <pre>4   If both of the operands have arithmetic type, the usual arithmetic conversions are performed.
 | |
|     Positive zeros compare equal to negative zeros.
 | |
| </pre>
 | |
| <a name='6.5.8p5'></a>
 | |
| <pre>5   For the purposes of these operators, a pointer to an object that is not an element of an array behaves
 | |
|     the same as a pointer to the first element of an array of length one with the type of the object as its
 | |
|     element type.
 | |
| </pre>
 | |
| <a name='6.5.8p6'></a>
 | |
| <pre>6   When two pointers are compared, the result depends on the relative locations in the address space
 | |
|     of the objects pointed to. If two pointers to object types both point to the same object, or both point
 | |
|     one past the last element of the same array object, they compare equal. If the objects pointed to
 | |
|     are members of the same aggregate object, pointers to structure members declared later compare
 | |
|     greater than pointers to members declared earlier in the structure, and pointers to array elements
 | |
|     with larger subscript values compare greater than pointers to elements of the same array with lower
 | |
|     subscript values. All pointers to members of the same union object compare equal. If the expression
 | |
|     P points to an element of an array object and the expression Q points to the last element of the same
 | |
|     array object, the pointer expression Q+1 compares greater than P. In all other cases, the behavior is
 | |
|     undefined.
 | |
| </pre>
 | |
| <a name='6.5.8p7'></a>
 | |
| <pre>7   Each of the operators < (less than), > (greater than), <= (less than or equal to), and >= (greater than or
 | |
|     equal to) shall yield 1 if the specified relation is true and 0 if it is false.<a href='#FOOTNOTE.122'><sup>[122]</sup></a> . The result has type int.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.122'>
 | |
| <pre><i><b>Footnote 122)</b> The expression a<b<c is not interpreted as in ordinary mathematics. As the syntax indicates, it means (a<b)<c ; in other
 | |
|     words, "if a is less than b, compare 1 to c; otherwise, compare 0 to c".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.9'></a>
 | |
| <hr>
 | |
| <h3>6.5.9 [Equality operators]</h3>
 | |
| <a name='6.5.9p1'></a>
 | |
| <pre>1 Syntax
 | |
|     equality-expression:
 | |
|                         relational-expression
 | |
|                         equality-expression == relational-expression
 | |
|                         equality-expression != relational-expression
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.9p2'></a>
 | |
| <pre>2   One of the following shall hold:
 | |
| 
 | |
|       — both operands have arithmetic type;
 | |
|       — both operands are pointers to qualified or unqualified versions of compatible types;
 | |
|       — one operand is a pointer to an object type and the other is a pointer to a qualified or unqualified
 | |
|         version of void;
 | |
|       — both operands have type nullptr_t;
 | |
|       — one operand has type nullptr_t and the other is a null pointer constant; or,
 | |
|       — one operand is a pointer and the other is a null pointer constant.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.9p3'></a>
 | |
| <pre>3   If either operand has decimal floating type, the other operand shall not have standard floating type,
 | |
|     complex type, or imaginary type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.9p4'></a>
 | |
| <pre>4   The == (equal to) and != (not equal to) operators are analogous to the relational operators except for
 | |
|     their lower precedence<a href='#FOOTNOTE.123'><sup>[123]</sup></a> Each of the operators yields 1 if the specified relation is true and 0 if it is
 | |
|     false. The result has type int. For any pair of operands, exactly one of the relations is true.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.123'>
 | |
| <pre><i><b>Footnote 123)</b> Because of the precedences, a<b == c<d is 1 whenever a<b and c<d have the same truth-value.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.9p5'></a>
 | |
| <pre>5   If both of the operands have arithmetic type, the usual arithmetic conversions are performed.
 | |
|     Positive zeros compare equal to negative zeros. Values of complex types are equal if and only if both
 | |
|     their real parts are equal and also their imaginary parts are equal. Any two values of arithmetic
 | |
|     types from different type domains are equal if and only if the results of their conversions to the
 | |
|     (complex) result type determined by the usual arithmetic conversions are equal. If both operands
 | |
|     have type nullptr_t or one operand has type nullptr_t and the other is a null pointer constant,
 | |
|     they compare equal.
 | |
| </pre>
 | |
| <a name='6.5.9p6'></a>
 | |
| <pre>6   Otherwise, at least one operand is a pointer. If one operand is a pointer and the other is a null
 | |
|     pointer constant, the null pointer constant is converted to the type of the pointer. If one operand is a
 | |
|     pointer to an object type and the other is a pointer to a qualified or unqualified version of void, the
 | |
|     former is converted to the type of the latter.
 | |
| </pre>
 | |
| <a name='6.5.9p7'></a>
 | |
| <pre>7   Two pointers compare equal if and only if both are null pointers, both are pointers to the same object
 | |
|     (including a pointer to an object and a subobject at its beginning) or function, both are pointers to
 | |
|     one past the last element of the same array object, or one is a pointer to one past the end of one array
 | |
|     object and the other is a pointer to the start of a different array object that happens to immediately
 | |
|     follow the first array object in the address space<a href='#FOOTNOTE.124'><sup>[124]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.124'>
 | |
| <pre><i><b>Footnote 124)</b> Two objects can be adjacent in memory because they are adjacent elements of a larger array or adjacent members
 | |
|     of a structure with no padding between them, or because the implementation chose to place them so, even though they
 | |
|     are unrelated. If prior invalid pointer operations (such as accesses outside array bounds) produced undefined behavior,
 | |
|     subsequent comparisons also produce undefined behavior.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.9p8'></a>
 | |
| <pre>8   For the purposes of these operators, a pointer to an object that is not an element of an array behaves
 | |
|     the same as a pointer to the first element of an array of length one with the type of the object as its
 | |
|     element type.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.10'></a>
 | |
| <hr>
 | |
| <h3>6.5.10 [Bitwise AND operator]</h3>
 | |
| <a name='6.5.10p1'></a>
 | |
| <pre>1 Syntax
 | |
|     AND-expression:
 | |
|                          equality-expression
 | |
|                          AND-expression & equality-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.10p2'></a>
 | |
| <pre>2   Each of the operands shall have integer type.
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.10p3'></a>
 | |
| <pre>3   The usual arithmetic conversions are performed on the operands.
 | |
| </pre>
 | |
| <a name='6.5.10p4'></a>
 | |
| <pre>4   The result of the binary & operator is the bitwise AND of the operands (that is, each bit in the result
 | |
|     is set if and only if each of the corresponding bits in the converted operands is set).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.11'></a>
 | |
| <hr>
 | |
| <h3>6.5.11 [Bitwise exclusive OR operator]</h3>
 | |
| <a name='6.5.11p1'></a>
 | |
| <pre>1 Syntax
 | |
|     exclusive-OR-expression:
 | |
|                       AND-expression
 | |
|                       exclusive-OR-expression ^ AND-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.11p2'></a>
 | |
| <pre>2   Each of the operands shall have integer type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.11p3'></a>
 | |
| <pre>3   The usual arithmetic conversions are performed on the operands.
 | |
| </pre>
 | |
| <a name='6.5.11p4'></a>
 | |
| <pre>4   The result of the ^ operator is the bitwise exclusive OR of the operands (that is, each bit in the result
 | |
|     is set if and only if exactly one of the corresponding bits in the converted operands is set).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.12'></a>
 | |
| <hr>
 | |
| <h3>6.5.12 [Bitwise inclusive OR operator]</h3>
 | |
| <a name='6.5.12p1'></a>
 | |
| <pre>1 Syntax
 | |
|     inclusive-OR-expression:
 | |
|                        exclusive-OR-expression
 | |
|                        inclusive-OR-expression | exclusive-OR-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.12p2'></a>
 | |
| <pre>2   Each of the operands shall have integer type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.12p3'></a>
 | |
| <pre>3   The usual arithmetic conversions are performed on the operands.
 | |
| </pre>
 | |
| <a name='6.5.12p4'></a>
 | |
| <pre>4   The result of the | operator is the bitwise inclusive OR of the operands (that is, each bit in the result
 | |
|     is set if and only if at least one of the corresponding bits in the converted operands is set).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.13'></a>
 | |
| <hr>
 | |
| <h3>6.5.13 [Logical AND operator]</h3>
 | |
| <a name='6.5.13p1'></a>
 | |
| <pre>1 Syntax
 | |
|     logical-AND-expression:
 | |
|                       inclusive-OR-expression
 | |
|                       logical-AND-expression && inclusive-OR-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.13p2'></a>
 | |
| <pre>2   Each of the operands shall have scalar type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.13p3'></a>
 | |
| <pre>3   The && operator shall yield 1 if both of its operands compare unequal to 0; otherwise, it yields 0. The
 | |
|     result has type int.
 | |
| </pre>
 | |
| <a name='6.5.13p4'></a>
 | |
| <pre>4   Unlike the bitwise binary & operator, the && operator guarantees left-to-right evaluation; if the
 | |
|     second operand is evaluated, there is a sequence point between the evaluations of the first and
 | |
|     second operands. If the first operand compares equal to 0, the second operand is not evaluated.
 | |
| </pre>
 | |
| <a name='6.5.14'></a>
 | |
| <hr>
 | |
| <h3>6.5.14 [Logical OR operator]</h3>
 | |
| <a name='6.5.14p1'></a>
 | |
| <pre>1 Syntax
 | |
|     logical-OR-expression:
 | |
|                        logical-AND-expression
 | |
|                        logical-OR-expression || logical-AND-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.14p2'></a>
 | |
| <pre>2   Each of the operands shall have scalar type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.14p3'></a>
 | |
| <pre>3   The || operator shall yield 1 if either of its operands compare unequal to 0; otherwise, it yields 0.
 | |
|     The result has type int.
 | |
| </pre>
 | |
| <a name='6.5.14p4'></a>
 | |
| <pre>4   Unlike the bitwise | operator, the || operator guarantees left-to-right evaluation; if the second
 | |
|     operand is evaluated, there is a sequence point between the evaluations of the first and second
 | |
|     operands. If the first operand compares unequal to 0, the second operand is not evaluated.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.15'></a>
 | |
| <hr>
 | |
| <h3>6.5.15 [Conditional operator]</h3>
 | |
| <a name='6.5.15p1'></a>
 | |
| <pre>1 Syntax
 | |
|     conditional-expression:
 | |
|                         logical-OR-expression
 | |
|                         logical-OR-expression ? expression : conditional-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.5.15p2'></a>
 | |
| <pre>2   The first operand shall have scalar type.
 | |
| </pre>
 | |
| <a name='6.5.15p3'></a>
 | |
| <pre>3   One of the following shall hold for the second and third operands<a href='#FOOTNOTE.125'><sup>[125]</sup></a> :
 | |
| 
 | |
|       — both operands have arithmetic type;
 | |
| 
 | |
|       — both operands have the same structure or union type;
 | |
| 
 | |
|       — both operands have void type;
 | |
| 
 | |
|       — both operands are pointers to qualified or unqualified versions of compatible types;
 | |
| 
 | |
|       — both operands have nullptr_t type;
 | |
| 
 | |
|       — one operand is a pointer and the other is a null pointer constant or has type nullptr_t; or
 | |
| 
 | |
|       — one operand is a pointer to an object type and the other is a pointer to a qualified or unqualified
 | |
|         version of void.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.125'>
 | |
| <pre><i><b>Footnote 125)</b> If a second or third operand of type nullptr_t is used that is not a null pointer constant and the other operand is not a
 | |
|     pointer or does not have type nullptr_t itself, a constraint is violated even if that other operand is a null pointer constant
 | |
|     such as 0.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.15p4'></a>
 | |
| <pre>4   If either of the second or third operands has decimal floating type, the other operand shall not have
 | |
|     standard floating type, complex type, or imaginary type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.15p5'></a>
 | |
| <pre>5   The first operand is evaluated; there is a sequence point between its evaluation and the evaluation
 | |
|     of the second or third operand (whichever is evaluated). The second operand is evaluated only if
 | |
|     the first compares unequal to 0; the third operand is evaluated only if the first compares equal to 0;
 | |
|     the result is the value of the second or third operand (whichever is evaluated), converted to the type
 | |
|     described below<a href='#FOOTNOTE.126'><sup>[126]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.126'>
 | |
| <pre><i><b>Footnote 126)</b> A conditional expression does not yield an lvalue.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.15p6'></a>
 | |
| <pre>6       If both the second and third operands have arithmetic type, the result type that would be determined
 | |
|         by the usual arithmetic conversions, were they applied to those two operands, is the type of the
 | |
|         result. If both the operands have structure or union type, the result has that type. If both operands
 | |
|         have void type, the result has void type.
 | |
| </pre>
 | |
| <a name='6.5.15p7'></a>
 | |
| <pre>7       If both the second and third operands are pointers, the result type is a pointer to a type qualified
 | |
|         with all the type qualifiers of the types referenced by both operands; if one is a null pointer constant
 | |
|         (other than a pointer) or has type nullptr_t type, the result also has that type. Furthermore, if
 | |
|         both operands are pointers to compatible types or to differently qualified versions of compatible
 | |
|         types, the result type is a pointer to an appropriately qualified version of the composite type; if
 | |
|         one operand is a null pointer constant, the result has the type of the other operand; otherwise, one
 | |
|         operand is a pointer to void or a qualified version of void, in which case the result type is a pointer
 | |
|         to an appropriately qualified version of void.
 | |
| </pre>
 | |
| <a name='6.5.15p8'></a>
 | |
| <pre>8       EXAMPLE The common type that results when the second and third operands are pointers is determined in two independent
 | |
|         stages. The appropriate qualifiers, for example, do not depend on whether the two pointers have compatible types.
 | |
| </pre>
 | |
| <a name='6.5.15p9'></a>
 | |
| <pre>9   Given the declarations
 | |
| 
 | |
|               const void *c_vp;
 | |
|               void *vp;
 | |
|               const int *c_ip;
 | |
|               volatile int *v_ip;
 | |
|               int *ip;
 | |
|               const char *c_cp;
 | |
| 
 | |
| 
 | |
| 
 | |
|     the third column in the following table is the common type that is the result of a conditional expression in which the first two
 | |
|     columns are the second and third operands (in either order):
 | |
|           c_vp     c_ip      const void *
 | |
|           v_ip     0         volatile int *
 | |
|           c_ip     v_ip      const volatile int *
 | |
|           vp       c_cp      const void *
 | |
|           ip       c_ip      const int *
 | |
|           vp       ip        void *
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.16'></a>
 | |
| <hr>
 | |
| <h3>6.5.16 [Assignment operators]</h3>
 | |
| <a name='6.5.16p1'></a>
 | |
| <pre>1 Syntax
 | |
|         assignment-expression:
 | |
|                            conditional-expression
 | |
|                            unary-expression assignment-operator assignment-expression
 | |
| 
 | |
|          assignment-operator: one of
 | |
|                               =     *=    /=    %=    +=     -=    <<=     >>=     &=     ^=    |=
 | |
| 
 | |
| 
 | |
| 
 | |
|         Constraints
 | |
| </pre>
 | |
| <a name='6.5.16p2'></a>
 | |
| <pre>2       An assignment operator shall have a modifiable lvalue as its left operand.
 | |
| 
 | |
|         Semantics
 | |
| </pre>
 | |
| <a name='6.5.16p3'></a>
 | |
| <pre>3       An assignment operator stores a value in the object designated by the left operand. An assignment
 | |
|         expression has the value of the left operand after the assignment,<a href='#FOOTNOTE.127'><sup>[127]</sup></a> but is not an lvalue. The type of
 | |
|         an assignment expression is the type the left operand would have after lvalue conversion. The side
 | |
|         effect of updating the stored value of the left operand is sequenced after the value computations of
 | |
|         the left and right operands. The evaluations of the operands are unsequenced.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.127'>
 | |
| <pre><i><b>Footnote 127)</b> The implementation is permitted to read the object to determine the value but is not required to, even when the object
 | |
|         has volatile-qualified type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.16.1'></a>
 | |
| <hr>
 | |
| <h3>6.5.16.1 [Simple assignment]</h3>
 | |
| <a name='6.5.16.1p1'></a>
 | |
| <pre>1 Constraints
 | |
|    One of the following shall hold<a href='#FOOTNOTE.128'><sup>[128]</sup></a> :
 | |
| 
 | |
|       — the left operand has atomic, qualified, or unqualified arithmetic type, and the right has
 | |
|         arithmetic type;
 | |
| 
 | |
|       — the left operand has an atomic, qualified, or unqualified version of a structure or union type
 | |
|         compatible with the type of the right;
 | |
| 
 | |
|       — the left operand has atomic, qualified, or unqualified pointer type, and (considering the type
 | |
|         the left operand would have after lvalue conversion) both operands are pointers to qualified
 | |
|         or unqualified versions of compatible types, and the type pointed to by the left has all the
 | |
|         qualifiers of the type pointed to by the right;
 | |
| 
 | |
|       — the left operand has atomic, qualified, or unqualified pointer type, and (considering the type
 | |
|         the left operand would have after lvalue conversion) one operand is a pointer to an object type,
 | |
|         and the other is a pointer to a qualified or unqualified version of void, and the type pointed to
 | |
|         by the left has all the qualifiers of the type pointed to by the right;
 | |
| 
 | |
|       — the left operand has an atomic, qualified, or unqualified version of the nullptr_t type and
 | |
|         the type of the right is nullptr_t<a href='#FOOTNOTE.129'><sup>[129]</sup></a> ;
 | |
| 
 | |
|       — the left operand is an atomic, qualified, or unqualified pointer, and the type of the right is
 | |
|            nullptr_t
 | |
| 
 | |
|       — the left operand is an atomic, qualified, or unqualified bool, and the type of the right is
 | |
|         nullptr_t;
 | |
| 
 | |
|       — the left operand is an atomic, qualified, or unqualified pointer, and the right is a null pointer
 | |
|         constant; or
 | |
| 
 | |
|       — the left operand has type atomic, qualified, or unqualified bool, and the right is a pointer.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.128'>
 | |
| <pre><i><b>Footnote 128)</b> The asymmetric appearance of these constraints with respect to type qualifiers is due to the conversion (specified
 | |
|     in <a href='#6.3.2.1'>6.3.2.1</a>) that changes lvalues to "the value of the expression" and thus removes any type qualifiers that were applied to the
 | |
|     type category of the expression (for example, it removes const but not volatile from the type int volatile * const).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.129'>
 | |
| <pre><i><b>Footnote 129)</b> The assignment of an object of type nullptr_t with a value of another type, even if the value is a null pointer constant,
 | |
|     is a constraint violation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.16.1p2'></a>
 | |
| <pre>2   In simple assignment (=), the value of the right operand is converted to the type of the assignment
 | |
|     expression and replaces the value stored in the object designated by the left operand. <a href='#FOOTNOTE.130'><sup>[130]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.130'>
 | |
| <pre><i><b>Footnote 130)</b> As described in <a href='#6.2.6.1'>6.2.6.1</a>, a store to an object with atomic type is done with memory_order_seq_cst semantics.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.16.1p3'></a>
 | |
| <pre>3   If the value being stored in an object is read from another object that overlaps in any way the
 | |
|     storage of the first object, then the overlap shall be exact and the two objects shall have qualified or
 | |
|     unqualified versions of a compatible type; otherwise, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.5.16.1p4'></a>
 | |
| <pre>4   EXAMPLE 1 In the program fragment
 | |
| 
 | |
|               int f(void);
 | |
|               char c;
 | |
|               /* ... */
 | |
|               if ((c = f()) == -1)
 | |
|                     /* ... */
 | |
| 
 | |
|     the int value returned by the function could be truncated when stored in the char, and then converted back to int width
 | |
|     prior to the comparison. In an implementation in which "plain" char has the same range of values as unsigned char (and
 | |
|     char is narrower than int), the result of the conversion cannot be negative, so the operands of the comparison can never
 | |
|     compare equal. Therefore, for full portability, the variable c would be declared as int.
 | |
| </pre>
 | |
| <a name='6.5.16.1p5'></a>
 | |
| <pre>5   EXAMPLE 2 In the fragment:
 | |
|               char c;
 | |
|               int i;
 | |
|               long l;
 | |
| 
 | |
|               l = (c = i);
 | |
| 
 | |
|     the value of i is converted to the type of the assignment expression c = i, that is, char type. The value of the expression
 | |
|     enclosed in parentheses is then converted to the type of the outer assignment expression, that is, long int type.
 | |
| </pre>
 | |
| <a name='6.5.16.1p6'></a>
 | |
| <pre>6   EXAMPLE 3 Consider the fragment:
 | |
| 
 | |
|               const char **cpp;
 | |
|               char *p;
 | |
|               const char c = ’A’;
 | |
| 
 | |
|               cpp = &p;              // constraint violation
 | |
|               *cpp = &c;             // valid
 | |
|               *p = 0;                // valid
 | |
| 
 | |
|     The first assignment is unsafe because it would allow the following valid code to attempt to change the value of the const
 | |
|     object c.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.16.2'></a>
 | |
| <hr>
 | |
| <h3>6.5.16.2 [Compound assignment]</h3>
 | |
| <a name='6.5.16.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    For the operators += and-= only, either the left operand shall be an atomic, qualified, or unqualified
 | |
|     pointer to a complete object type, and the right shall have integer type; or the left operand shall have
 | |
|     atomic, qualified, or unqualified arithmetic type, and the right shall have arithmetic type.
 | |
| </pre>
 | |
| <a name='6.5.16.2p2'></a>
 | |
| <pre>2   For the other operators, the left operand shall have atomic, qualified, or unqualified arithmetic type,
 | |
|     and (considering the type the left operand would have after lvalue conversion) each operand shall
 | |
|     have arithmetic type consistent with those allowed by the corresponding binary operator.
 | |
| </pre>
 | |
| <a name='6.5.16.2p3'></a>
 | |
| <pre>3   If either operand has decimal floating type, the other operand shall not have standard floating type,
 | |
|     complex type, or imaginary type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.16.2p4'></a>
 | |
| <pre>4   A compound assignment of the form E1 op= E2 is equivalent to the simple assignment expression
 | |
|     E1 = E1 op (E2) , except that the lvalue E1 is evaluated only once, and with respect to an inde-
 | |
|     terminately-sequenced function call, the operation of a compound assignment is a single evalu-
 | |
|     ation. If E1 has an atomic type, compound assignment is a read-modify-write operation with
 | |
|     memory_order_seq_cst memory order semantics.
 | |
| </pre>
 | |
| <a name='6.5.16.2p5'></a>
 | |
| <pre>5   NOTE Where a pointer to an atomic object can be formed and E1 and E2 have integer type, this is equivalent to the following
 | |
|     code sequence where T1 is the type of E1 and T2 is the type of E2:
 | |
| 
 | |
|               T1 *addr = &E1;
 | |
|               T2 val = (E2);
 | |
|               T1 old = *addr;
 | |
|               T1 new;
 | |
|               do {
 | |
|                     new = old op val;
 | |
|               } while (!atomic_compare_exchange_strong(addr, &old, new));
 | |
| 
 | |
|     with new being the result of the operation.
 | |
|     If E1 or E2 has floating type, then exceptional conditions or floating-point exceptions encountered during discarded
 | |
|     evaluations of new would also be discarded in order to satisfy the equivalence of E1 op= E2 and E1 = E1 op (E2) . For
 | |
|     example, if Annex F is in effect, the floating types involved have IEC 60559 binary formats, and FLT_EVAL_METHOD is 0, the
 | |
|     equivalent code would be:
 | |
| 
 | |
|               #include <fenv.h>
 | |
|               #pragma STDC FENV_ACCESS ON
 | |
|               /* ... */
 | |
|                     fenv_t fenv;
 | |
|                        T1 *addr = &E1;
 | |
|                        T2 val = E2;
 | |
|                        T1 old = *addr;
 | |
|                        T1 new;
 | |
|                        feholdexcept(&fenv);
 | |
|                        for (;;) {
 | |
|                              new = old op val;
 | |
|                              if (atomic_compare_exchange_strong(addr, &old, new))
 | |
|                                          break;
 | |
|                              feclearexcept(FE_ALL_EXCEPT);
 | |
|                        }
 | |
|                        feupdateenv(&fenv);
 | |
| 
 | |
|     If FLT_EVAL_METHOD is not 0, then T2 is expected to be a type with the range and precision to which E2 is evaluated in order
 | |
|     to satisfy the equivalence.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.5.17'></a>
 | |
| <hr>
 | |
| <h3>6.5.17 [Comma operator]</h3>
 | |
| <a name='6.5.17p1'></a>
 | |
| <pre>1 Syntax
 | |
|     expression:
 | |
|                             assignment-expression
 | |
|                             expression , assignment-expression
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.5.17p2'></a>
 | |
| <pre>2   The left operand of a comma operator is evaluated as a void expression; there is a sequence point
 | |
|     between its evaluation and that of the right operand. Then the right operand is evaluated; the result
 | |
|     has its type and value.<a href='#FOOTNOTE.131'><sup>[131]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.131'>
 | |
| <pre><i><b>Footnote 131)</b> A comma operator does not yield an lvalue.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.5.17p3'></a>
 | |
| <pre>3   EXAMPLE As indicated by the syntax, the comma operator (as described in this subclause) cannot appear in contexts where
 | |
|     a comma is used to separate items in a list (such as arguments to functions or lists of initializers). On the other hand, it can be
 | |
|     used within a parenthesized expression or within the second expression of a conditional operator in such contexts. In the
 | |
|     function call
 | |
| 
 | |
|               f(a, (t=3, t+2), c)
 | |
| 
 | |
|     the function has three arguments, the second of which has the value 5.
 | |
| 
 | |
|     Forward references: initialization (<a href='#6.7.10'>6.7.10</a>).
 | |
| </pre>
 | |
| <a name='6.6'></a>
 | |
| <hr>
 | |
| <h3>6.6 [Constant expressions]</h3>
 | |
| <a name='6.6p1'></a>
 | |
| <pre>1 Syntax
 | |
|     constant-expression:
 | |
|                         conditional-expression
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.6p2'></a>
 | |
| <pre>2   A constant expression can be evaluated during translation rather than runtime, and accordingly
 | |
|     may be used in any place that a constant may be.
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.6p3'></a>
 | |
| <pre>3   Constant expressions shall not contain assignment, increment, decrement, function-call, or comma
 | |
|     operators, except when they are contained within a subexpression that is not evaluated<a href='#FOOTNOTE.132'><sup>[132]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.132'>
 | |
| <pre><i><b>Footnote 132)</b> The operand of a the typeof <a href='#6.7.2.5'>6.7.2.5</a>, sizeof, or alignof operator is usually not evaluated (<a href='#6.5.3.4'>6.5.3.4</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.6p4'></a>
 | |
| <pre>4   Each constant expression shall evaluate to a constant that is in the range of representable values for
 | |
|     its type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.6p5'></a>
 | |
| <pre>5   An expression that evaluates to a constant is required in several contexts. If a floating expression
 | |
|     is evaluated in the translation environment, the arithmetic range and precision shall be at least as
 | |
|     great as if the expression were being evaluated in the execution environment. <a href='#FOOTNOTE.133'><sup>[133]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.133'>
 | |
| <pre><i><b>Footnote 133)</b> The use of evaluation formats as characterized by FLT_EVAL_METHOD and DEC_EVAL_METHOD also applies to evaluation in
 | |
|     the translation environment.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.6p6'></a>
 | |
| <pre>6   A compound literal with storage-class specifier constexpr is a compound literal constant. A com-
 | |
|     pound literal constant is a constant expression with the type and value of the unnamed object.
 | |
| </pre>
 | |
| <a name='6.6p7'></a>
 | |
| <pre>7   An identifier that is:
 | |
| 
 | |
|       — an enumeration constant;
 | |
| 
 | |
|       — a predefined constant;
 | |
| 
 | |
|       — or, declared with storage-class specifier constexpr and has an object type,
 | |
| 
 | |
|     is a named constant, as is a postfix expression that applies the . member access operator to a named
 | |
|     constant of structure or union type, even recursively. For enumeration and predefined constants,
 | |
|     their value and type are defined in the respective clauses; for constexpr objects, such a named
 | |
|     constant is a constant expression with the type and value of the declared object.
 | |
| </pre>
 | |
| <a name='6.6p8'></a>
 | |
| <pre>8   An integer constant expression<a href='#FOOTNOTE.134'><sup>[134]</sup></a> shall have integer type and shall only have operands that are
 | |
|     integer constants, named and compound literal constants of integer type, character constants,
 | |
|     sizeof expressions whose results are integer constants, alignof expressions, and floating, named,
 | |
|     or compound literal constants of arithmetic type that are the immediate operands of casts. Cast
 | |
|     operators in an integer constant expression shall only convert arithmetic types to integer types,
 | |
|     except as part of an operand to the typeof operators, sizeof operator, or alignof operator.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.134'>
 | |
| <pre><i><b>Footnote 134)</b> An integer constant expression is required in a number of contexts such as the size of a bit-field member of a structure,
 | |
|     the value of an enumeration constant, and the size of a non-variable length array. Further constraints that apply to the integer
 | |
|     constant expressions used in conditional-inclusion preprocessing directives are discussed in <a href='#6.10.1'>6.10.1</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.6p9'></a>
 | |
| <pre>9   More latitude is permitted for constant expressions in initializers. Such a constant expression shall
 | |
|     be, or evaluate to, one of the following:
 | |
| 
 | |
|       — a named constant,
 | |
| 
 | |
|       — a compound literal constant,
 | |
| 
 | |
|       — an arithmetic constant expression,
 | |
|         — a null pointer constant,
 | |
|         — an address constant, or
 | |
|         — an address constant for a complete object type plus or minus an integer constant expression.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.6p10'></a>
 | |
| <pre>10   An arithmetic constant expression shall have arithmetic type and shall only have operands that are
 | |
|      integer constants, floating constants, named or compound literal constants of arithmetic type, char-
 | |
|      acter constants, sizeof expressions whose results are integer constants, and alignof expressions.
 | |
|      Cast operators in an arithmetic constant expression shall only convert arithmetic types to arithmetic
 | |
|      types, except as part of an operand to the typeof operators, sizeof operator, or alignof operator.
 | |
| </pre>
 | |
| <a name='6.6p11'></a>
 | |
| <pre>11   An address constant is a null pointer<a href='#FOOTNOTE.135'><sup>[135]</sup></a> , a pointer to an lvalue designating an object of static storage
 | |
|      duration, or a pointer to a function designator; it shall be created explicitly using the unary &
 | |
|      operator or an integer constant cast to pointer type, or implicitly by the use of an expression of array
 | |
|      or function type.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.135'>
 | |
| <pre><i><b>Footnote 135)</b> A named constant or compound literal constant of integer type and value zero is a null pointer constant. A named
 | |
|      constant or compound literal constant with a pointer type and a value null is a null pointer but not a null pointer constant; it
 | |
|      may only be used to initialize a pointer object if its type implicitly converts to the target type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.6p12'></a>
 | |
| <pre>12   The array-subscript [] and member-access -> operator, the address & and indirection * unary
 | |
|      operators, and pointer casts may be used in the creation of an address constant, but the value of an
 | |
|      object shall not be accessed by use of these operators<a href='#FOOTNOTE.136'><sup>[136]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.136'>
 | |
| <pre><i><b>Footnote 136)</b> Named constant or compound literal constants with arithmetic type, including names of constexpr objects, are valid in
 | |
|      offset computations such as array subscripts or int pointer casts, as long as the expression in which they occur form integer
 | |
|      constant expressions. In contrast, names of other objects, even if const-qualified and with static storage duration, are not
 | |
|      valid.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.6p13'></a>
 | |
| <pre>13   A structure or union constant is a named constant or compound literal constant with structure or
 | |
|      union type, respectively.
 | |
| </pre>
 | |
| <a name='6.6p14'></a>
 | |
| <pre>14   An implementation may accept other forms of constant expressions, however, they are not an integer
 | |
|      constant expression.<a href='#FOOTNOTE.137'><sup>[137]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.137'>
 | |
| <pre><i><b>Footnote 137)</b> For example, in the statement int arr_or_vla[(int)+1.0];, while possible to be computed by some implementations
 | |
|      as an array with a size of one, still results in a variable length array declaration of automatic storage duration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.6p15'></a>
 | |
| <pre>15   Starting from a structure or union constant, the member-access . operator may be used to form a
 | |
|      named constant or compound literal constant as described above.
 | |
| </pre>
 | |
| <a name='6.6p16'></a>
 | |
| <pre>16   If the member-access operator . accesses a member of a union constant, the access member shall be
 | |
|      the same as the member that is initialized by the union constant’s initializer.
 | |
| </pre>
 | |
| <a name='6.6p17'></a>
 | |
| <pre>17   The semantic rules for the evaluation of a constant expression are the same as for nonconstant
 | |
|      expressions<a href='#FOOTNOTE.138'><sup>[138]</sup></a> .
 | |
|      Forward references: array declarators (<a href='#6.7.6.2'>6.7.6.2</a>), initialization (<a href='#6.7.10'>6.7.10</a>).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.138'>
 | |
| <pre><i><b>Footnote 138)</b> Thus, in the following initialization,
 | |
|                static int i = 2 || 1 / 0;
 | |
|      the expression is a valid integer constant expression with value one.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7'></a>
 | |
| <hr>
 | |
| <h3>6.7 [Declarations]</h3>
 | |
| <a name='6.7p1'></a>
 | |
| <pre>1 Syntax
 | |
|     declaration:
 | |
|                            declaration-specifiers init-declarator-listopt ;
 | |
|                            attribute-specifier-sequence declaration-specifiers init-declarator-list ;
 | |
|                            static_assert-declaration
 | |
|                            attribute-declaration
 | |
|      declaration-specifiers:
 | |
|                            declaration-specifier attribute-specifier-sequenceopt
 | |
|                            declaration-specifier declaration-specifiers
 | |
|      declaration-specifier:
 | |
|                            storage-class-specifier
 | |
|                            type-specifier-qualifier
 | |
|                            function-specifier
 | |
|      init-declarator-list:
 | |
|                            init-declarator
 | |
|                            init-declarator-list , init-declarator
 | |
|      init-declarator:
 | |
|                            declarator
 | |
|                            declarator = initializer
 | |
|      attribute-declaration:
 | |
|                            attribute-specifier-sequence ;
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.7p2'></a>
 | |
| <pre>2   A declaration other than a static_assert or attribute declaration shall declare at least a declarator
 | |
|     (other than the parameters of a function or the members of a structure or union), a tag, or the
 | |
|     members of an enumeration.
 | |
| </pre>
 | |
| <a name='6.7p3'></a>
 | |
| <pre>3   If an identifier has no linkage, there shall be no more than one declaration of the identifier (in a
 | |
|     declarator or type specifier) with the same scope and in the same name space, except that:
 | |
| 
 | |
|       — a typedef name may be redefined to denote the same type as it currently does, provided that
 | |
|         type is not a variably modified type;
 | |
|       — enumeration constants and tags may be redeclared as specified in <a href='#6.7.2.2'>6.7.2.2</a> <a href='#6.7.2.3'>6.7.2.3</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7p4'></a>
 | |
| <pre>4   All declarations in the same scope that refer to the same object or function shall specify compatible
 | |
|     types.
 | |
| </pre>
 | |
| <a name='6.7p5'></a>
 | |
| <pre>5   In an underspecified declaration all declared identifiers that do not have a prior declaration shall be
 | |
|     ordinary identifiers.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7p6'></a>
 | |
| <pre>6   A declaration specifies the interpretation and properties of a set of identifiers. A definition of an
 | |
|     identifier is a declaration for that identifier that:
 | |
| 
 | |
|       — for an object, causes storage to be reserved for that object;
 | |
|       — for a function, includes the function body<a href='#FOOTNOTE.139'><sup>[139]</sup></a> ;
 | |
|       — for an enumeration constant, is the (only) declaration of the identifier;
 | |
|       — for a typedef name, is the first (or only) declaration of the identifier.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.139'>
 | |
| <pre><i><b>Footnote 139)</b> Function definitions have a different syntax, described in <a href='#6.9.1'>6.9.1</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7p7'></a>
 | |
| <pre>7   The declaration specifiers consist of a sequence of specifiers, followed by an optional attribute
 | |
|     specifier sequence, that indicate the linkage, storage duration, and part of the type of the entities that
 | |
|      the declarators denote. The init declarator list is a comma-separated sequence of declarators, each
 | |
|      of which may have additional type information, or an initializer, or both. The declarators contain
 | |
|      the identifiers (if any) being declared. The optional attribute specifier sequence in a declaration
 | |
|      appertains to each of the entities declared by the declarators of the init declarator list.
 | |
| </pre>
 | |
| <a name='6.7p8'></a>
 | |
| <pre>8    If an identifier for an object is declared with no linkage, the type for the object shall be complete
 | |
|      by the end of its declarator, or by the end of its init-declarator if it has an initializer; in the case of
 | |
|      function parameters, it is the adjusted type (see <a href='#6.7.6.3'>6.7.6.3</a>) that is required to be complete.
 | |
| </pre>
 | |
| <a name='6.7p9'></a>
 | |
| <pre>9    The optional attribute specifier sequence terminating a sequence of declaration specifiers appertains
 | |
|      to the type determined by the preceding sequence of declaration specifiers. The attribute specifier
 | |
|      sequence affects the type only for the declaration it appears in, not other declarations involving the
 | |
|      same type.
 | |
| </pre>
 | |
| <a name='6.7p10'></a>
 | |
| <pre>10   Except where specified otherwise, the meaning of an attribute declaration is implementation-defined.
 | |
| </pre>
 | |
| <a name='6.7p11'></a>
 | |
| <pre>11   EXAMPLE In the declaration for an entity, attributes appertaining to that entity may appear at the start of the declaration
 | |
|      and after the identifier for that declaration.
 | |
| 
 | |
|                [[deprecated]] void f [[deprecated]] (void); // valid
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7p12'></a>
 | |
| <pre>12   A declaration such that the declaration specifiers contain no type specifier or that is declared with
 | |
|      constexpr is said to be underspecified. If such a declaration is not a definition, if it declares no or more
 | |
|      than one ordinary identifier, if the declared identifier already has a declaration in the same scope, or
 | |
|      if the declared entity is not an object, the behavior is undefined.
 | |
|      Forward references: declarators (<a href='#6.7.6'>6.7.6</a>), enumeration specifiers (<a href='#6.7.2.2'>6.7.2.2</a>), initialization (<a href='#6.7.10'>6.7.10</a>), type
 | |
|      names (<a href='#6.7.7'>6.7.7</a>), type qualifiers (<a href='#6.7.3'>6.7.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.1'></a>
 | |
| <hr>
 | |
| <h3>6.7.1 [Storage-class specifiers]</h3>
 | |
| <a name='6.7.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|      storage-class-specifier:
 | |
|                             auto
 | |
|                             constexpr
 | |
|                             extern
 | |
|                             register
 | |
|                             static
 | |
|                             thread_local
 | |
|                             typedef
 | |
| 
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.7.1p2'></a>
 | |
| <pre>2    At most, one storage-class specifier may be given in the declaration specifiers in a declaration, except
 | |
|      that:
 | |
| 
 | |
|        — thread_local may appear with static or extern;
 | |
| 
 | |
|        — auto may appear with all the others except typedef<a href='#FOOTNOTE.140'><sup>[140]</sup></a> ;
 | |
| 
 | |
|        — and, constexpr may appear with auto, register, or static.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.140'>
 | |
| <pre><i><b>Footnote 140)</b> See "future language directions" (<a href='#6.11.5'>6.11.5</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.1p3'></a>
 | |
| <pre>3    In the declaration of an object with block scope, if the declaration specifiers include thread_local,
 | |
|      they shall also include either static or extern. If thread_local appears in any declaration of an
 | |
|      object, it shall be present in every declaration of that object.
 | |
| </pre>
 | |
| <a name='6.7.1p4'></a>
 | |
| <pre>4    thread_local shall not appear in the declaration specifiers of a function declaration. auto shall
 | |
|      only appear in the declaration specifiers of an identifier with file scope or along with other storage
 | |
|      class specifiers if the type is to be inferred from an initializer.
 | |
| </pre>
 | |
| <a name='6.7.1p5'></a>
 | |
| <pre>5    An object declared with storage-class specifier constexpr or any of its members, even recursively,
 | |
|      shall not have an atomic type, or a variably modified type, or a type that is volatile or restrict
 | |
|      qualified. The declaration shall be a definition and shall have an initializer<a href='#FOOTNOTE.141'><sup>[141]</sup></a> . The value of
 | |
|      any constant expressions or of any character in a string literal of the initializer shall be exactly
 | |
|      representable in the corresponding target type; no change of value shall be applied<a href='#FOOTNOTE.142'><sup>[142]</sup></a> . If an object
 | |
|      or subobject declared with storage-class specifier constexpr has pointer, integer, or arithmetic type,
 | |
|      the implicit or explicit initializer value for it shall be a null pointer constant<a href='#FOOTNOTE.143'><sup>[143]</sup></a> , an integer constant
 | |
|      expression, or an arithmetic constant expression, respectively.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.141'>
 | |
| <pre><i><b>Footnote 141)</b> The right operand of all assignment expressions of such an initializer, if any, are constant expressions or string literals,
 | |
|      see <a href='#6.7.10'>6.7.10</a>
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.142'>
 | |
| <pre><i><b>Footnote 142)</b> In the context of arithmetic conversions, <a href='#6.3.1'>6.3.1</a> describes the details of changes of value that occur if values of arithmetic
 | |
|      expressions are stored in the objects that for example have a different signedness, excess precision or quantum exponent.
 | |
|      Whenever such a change of value is necessary, the constraint is violated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.143'>
 | |
| <pre><i><b>Footnote 143)</b> The named constant or compound literal constant corresponding to an object declared with storage-class specifier
 | |
|      constexpr and pointer type is a constant expression with a value null, and thus a null pointer and an address constant.
 | |
|      However, even if it has type void* it is not a null pointer constant.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.1p6'></a>
 | |
| <pre>6    Storage-class specifiers specify various properties of identifiers and declared features; storage
 | |
|      duration (static in block scope, thread_local, auto, register), linkage (extern, static and
 | |
|      constexpr in file scope, typedef), value (constexpr), and type (typedef). The meanings of the
 | |
|      various linkages and storage durations were discussed in <a href='#6.2.2'>6.2.2</a> and <a href='#6.2.4'>6.2.4</a>, typedef is discussed in
 | |
|      <a href='#6.7.8'>6.7.8</a>, and type inference is discussed in <a href='#6.7.9'>6.7.9</a>.
 | |
| </pre>
 | |
| <a name='6.7.1p7'></a>
 | |
| <pre>7    A declaration of an identifier for an object with storage-class specifier register suggests that
 | |
|      access to the object be as fast as possible. The extent to which such suggestions are effective is
 | |
|      implementation-defined<a href='#FOOTNOTE.144'><sup>[144]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.144'>
 | |
| <pre><i><b>Footnote 144)</b> The implementation can treat any register declaration simply as an auto declaration. However, whether or not
 | |
|      addressable storage is actually used, the address of any part of an object declared with storage-class specifier register
 | |
|      cannot be computed, either explicitly (by use of the unary & operator as discussed in <a href='#6.5.3.2'>6.5.3.2</a>) or implicitly (by converting
 | |
|      an array name to a pointer as discussed in <a href='#6.3.2.1'>6.3.2.1</a>). Thus, the only operator that can be applied to an array declared with
 | |
|      storage-class specifier register is sizeof and the typeof operators.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.1p8'></a>
 | |
| <pre>8    The declaration of an identifier for a function that has block scope shall have no explicit storage-class
 | |
|      specifier other than extern.
 | |
| </pre>
 | |
| <a name='6.7.1p9'></a>
 | |
| <pre>9    If an aggregate or union object is declared with a storage-class specifier other than typedef, the
 | |
|      properties resulting from the storage-class specifier, except with respect to linkage, also apply to the
 | |
|      members of the object, and so on recursively for any aggregate or union member objects.
 | |
| </pre>
 | |
| <a name='6.7.1p10'></a>
 | |
| <pre>10   If auto appears with another storage-class specifier, or if it appears in a declaration at file scope, it is
 | |
|      ignored for the purposes of determining a storage duration of linkage. It then only indicates that the
 | |
|      declared type may be inferred.
 | |
| </pre>
 | |
| <a name='6.7.1p11'></a>
 | |
| <pre>11   An object declared with a storage-class specifier constexpr has its value permanently fixed at
 | |
|      translation-time; if not yet present, a const-qualification is implicitly added to the object’s type. The
 | |
|      declared identifier is considered a constant expression of the respective kind, see ??.
 | |
| </pre>
 | |
| <a name='6.7.1p12'></a>
 | |
| <pre>12   NOTE An object declared in block scope with a storage-class specifier constexpr and without static has automatic storage
 | |
|      duration, the identifier has no linkage, and each instance of the object has a unique address obtainable with & (if it is not
 | |
|      declared with the register specifier), if any. Such an object in file scope has static storage duration, the corresponding identifier
 | |
|      has internal linkage, and each translation unit that sees the same textual definition implements a separate object with a
 | |
|      distinct address.
 | |
| </pre>
 | |
| <a name='6.7.1p13'></a>
 | |
| <pre>13   NOTE The constraints for constexpr objects are intended to enforce checks for portability at translation time.
 | |
| 
 | |
|                 constexpr unsigned int minusOne    = -1;                                             // constraint violation
 | |
|                 constexpr unsigned int uint_max    = -1U;                                            // ok
 | |
|                 constexpr char string[]            = { "\xFF", };                                    // possible constraint
 | |
|                     violation
 | |
|                 constexpr unsigned char unstring[] = { "\xFF", };                                    // ok
 | |
|                 constexpr char8_t u8string[]       = { u8"\xFF", };                                  // ok
 | |
|                 constexpr double onethird          = 1.0/3.0;                                        // possible constraint
 | |
|                     violation
 | |
|                 constexpr double onethirdtrunc     = (double)(1.0/3.0);                              // ok
 | |
|                constexpr _Decimal32 small                         = DEC64_TRUE_MIN * 0; // constraint violation
 | |
| 
 | |
|      Using an octal or hexadecimal escape character sequence with a value greater than the largest representable value of the target
 | |
|      character type (such as for unstring) possibly violates a constraint. Equally, an implementation that uses excess precision for
 | |
|      floating-point constants violates the constraint for onethird; a diagnostic is required if a truncation of the mantissa occurs.
 | |
|      In contrast to that, the explicit conversion in the initializer for onethirdtrunc ensures that the definition is valid. Similarly,
 | |
|      the initializer of small has a quantum exponent that is larger than the largest possible quantum exponent for _Decimal32 .
 | |
| </pre>
 | |
| <a name='6.7.1p14'></a>
 | |
| <pre>14   EXAMPLE 1 An identifier declared with the constexpr specifier may have its value used in constant expressions:
 | |
| 
 | |
|                constexpr int K = 47;
 | |
|                enum {
 | |
|                      A = K,              // valid, constant initialization
 | |
|                };
 | |
|                constexpr int L = K;     // valid, constexpr initialization
 | |
|                static int b    = K + 1; // valid, static initialization
 | |
|                int array[K];            // not a VLA
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.1p15'></a>
 | |
| <pre>15   EXAMPLE 2 An object declared with the constexpr specifier stores the exact value of its initializer, no implicit value change
 | |
|      is applied:
 | |
| 
 | |
|                #include <float.h>
 | |
| 
 | |
|                constexpr int A          = 42LL;                               // valid, 42 always fits in an int
 | |
|                constexpr signed short B = ULLONG_MAX;                         // constraint violation, value never
 | |
|                                                                               // fits
 | |
|                constexpr float C                    = 47u;                    // valid, exactly representable
 | |
|                                                                               // in single precision
 | |
| 
 | |
|                #if FLT_MANT_DIG > 24
 | |
|                constexpr float D = 432000000;                                 // constraint violation if float is
 | |
|                                                                               // 32-bit single-precision IEC 60559
 | |
|                #endif
 | |
| 
 | |
|                #if (FLT_MANT_DIG == DBL_MANT_DIG) && (0 <= FLT_EVAL_METHOD) && (FLT_EVAL_METHOD
 | |
|                    <= 1)
 | |
|                constexpr float E = 1.0 / 3.0;             // only valid if double expressions
 | |
|                                                           // and float objects have the same
 | |
|                                                               precision
 | |
|                #endif
 | |
| 
 | |
|                #if FLT_EVAL_METHOD == 0
 | |
|                constexpr float F = <a href='#1.'>1.</a>0f / <a href='#3.'>3.</a>0f;                               // valid, same type and precision
 | |
|                #else
 | |
|                constexpr float F = (float)(<a href='#1.'>1.</a>0f / <a href='#3.'>3.</a>0f);                      // needs cast to truncate the
 | |
|                                                                               // excess precision
 | |
|                #endif
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.1p16'></a>
 | |
| <pre>16   EXAMPLE 3 EXAMPLE 3 This recursively applies to initializers for all elements of an aggregate object declared with the
 | |
|      constexpr specifier:
 | |
| 
 | |
|                constexpr static unsigned short array[] = {
 | |
|                      3000,    // valid, fits in unsigned short range
 | |
|                      300000, // constraint violation if short is 16-bit
 | |
|                      -1       // constraint violation, target type is unsigned
 | |
|                };
 | |
| 
 | |
|                struct S {
 | |
|                      int x, y;
 | |
|                };
 | |
|                constexpr struct S s = {
 | |
|                      .x = INT_MAX,                      // valid
 | |
|                      .y = UINT_MAX,                     // constraint violation
 | |
|                };
 | |
|     Forward references: type definitions (<a href='#6.7.8'>6.7.8</a>), type definitions (<a href='#6.7.9'>6.7.9</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2'></a>
 | |
| <hr>
 | |
| <h3>6.7.2 [Type specifiers]</h3>
 | |
| <a name='6.7.2p1'></a>
 | |
| <pre>1 Syntax
 | |
|     type-specifier:
 | |
|                        void
 | |
|                        char
 | |
|                        short
 | |
|                        int
 | |
|                        long
 | |
|                        float
 | |
|                        double
 | |
|                        signed
 | |
|                        unsigned
 | |
|                        _BitInt ( constant-expression )
 | |
|                        bool
 | |
|                        _Complex
 | |
|                        _Decimal32
 | |
|                        _Decimal64
 | |
|                        _Decimal128
 | |
|                        atomic-type-specifier
 | |
|                        struct-or-union-specifier
 | |
|                        enum-specifier
 | |
|                        typedef-name
 | |
|                        typeof-specifier
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.7.2p2'></a>
 | |
| <pre>2   Except where the type is inferred (<a href='#6.7.9'>6.7.9</a>), at least one type specifier shall be given in the declaration
 | |
|     specifiers in each declaration, and in the specifier-qualifier list in each member declaration and type
 | |
|     name. Each list of type specifiers shall be one of the following multisets (delimited by commas,
 | |
|     when there is more than one multiset per item); the type specifiers may occur in any order, possibly
 | |
|     intermixed with the other declaration specifiers.
 | |
| 
 | |
|       — void
 | |
|       — char
 | |
|       — signed char
 | |
|       — unsigned char
 | |
|       — short, signed short, short int, or signed short int
 | |
|       — unsigned short, or unsigned short int
 | |
|       — int, signed, or signed int
 | |
|       — unsigned, or unsigned int
 | |
|       — long, signed long, long int, or signed long int
 | |
|       — unsigned long, or unsigned long int
 | |
|       — long long, signed long long, long long int, or signed long long int
 | |
|       — unsigned long long, or unsigned long long int
 | |
|       — _BitInt( constant-expression), or signed _BitInt( constant-expression)
 | |
|       — unsigned _BitInt( constant-expression)
 | |
|       — float
 | |
|       — double
 | |
|       — long double
 | |
|       — _Decimal32
 | |
|       — _Decimal64
 | |
|       — _Decimal128
 | |
|       — bool
 | |
|       — float _Complex
 | |
|       — double _Complex
 | |
|       — long double _Complex
 | |
|       — atomic type specifier
 | |
|       — struct or union specifier
 | |
|       — enum specifier
 | |
|       — typedef name
 | |
|       — typeof specifier
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2p3'></a>
 | |
| <pre>3   The type specifier _Complex shall not be used if the implementation does not support complex
 | |
|     types, and the type specifiers _Decimal32 , _Decimal64 , and _Decimal128 shall not be used if the
 | |
|     implementation does not support decimal floating types (see <a href='#6.10.9.3'>6.10.9.3</a>).
 | |
| </pre>
 | |
| <a name='6.7.2p4'></a>
 | |
| <pre>4   The parenthesized constant expression that follows the _BitInt keyword shall be an integer constant
 | |
|     expression N that specifies the width (<a href='#6.2.6.2'>6.2.6.2</a>) of the type. The value of N for unsigned _BitInt
 | |
|     shall be greater than or equal to 1. The value of N for _BitInt shall be greater than or equal to 2.
 | |
|     The value of N shall be less than or equal to the value of BITINT_MAXWIDTH (see <a href='#5.2.4.2.1'>5.2.4.2.1</a>).
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.2p5'></a>
 | |
| <pre>5   Specifiers for structures, unions, enumerations, atomic types, and typeof specifiers are discussed
 | |
|     in <a href='#6.7.2.1'>6.7.2.1</a> through <a href='#6.7.2.5'>6.7.2.5</a>. Declarations of typedef names are discussed in <a href='#6.7.8'>6.7.8</a>. The characteristics of
 | |
|     the other types are discussed in <a href='#6.2.5'>6.2.5</a>.
 | |
| </pre>
 | |
| <a name='6.7.2p6'></a>
 | |
| <pre>6   For a declaration such that the declaration specifiers contain no type specifier a mechanism to infer
 | |
|     the type from an initializer is discussed in <a href='#6.7.9'>6.7.9</a>. In such a declaration, optional elements, if any,
 | |
|     of a sequence of declaration specifiers appertain to the inferred type (for qualifiers and attribute
 | |
|     specifiers) or to the declared objects (for alignment specifiers).
 | |
| </pre>
 | |
| <a name='6.7.2p7'></a>
 | |
| <pre>7   Each of the comma-separated multisets designates the same type, except that for bit-fields, it is
 | |
|     implementation-defined whether the specifier int designates the same type as signed int or the
 | |
|     same type as unsigned int.
 | |
|     Forward references: atomic type specifiers (<a href='#6.7.2.4'>6.7.2.4</a>), enumeration specifiers (<a href='#6.7.2.2'>6.7.2.2</a>), structure and
 | |
|     union specifiers (<a href='#6.7.2.1'>6.7.2.1</a>), tags (<a href='#6.7.2.3'>6.7.2.3</a>), type definitions (<a href='#6.7.8'>6.7.8</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.1'></a>
 | |
| <hr>
 | |
| <h3>6.7.2.1 [Structure and union specifiers]</h3>
 | |
| <a name='6.7.2.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     struct-or-union-specifier:
 | |
|                         struct-or-union attribute-specifier-sequenceopt identifieropt { member-declaration-list }
 | |
|                         struct-or-union attribute-specifier-sequenceopt identifier
 | |
| 
 | |
|     struct-or-union:
 | |
|                         struct
 | |
|                         union
 | |
| 
 | |
| 
 | |
|     member-declaration-list:
 | |
|                       member-declaration
 | |
|                            member-declaration-list member-declaration
 | |
| 
 | |
|     member-declaration:
 | |
|                       attribute-specifier-sequenceopt specifier-qualifier-list member-declarator-listopt ;
 | |
|                       static_assert-declaration
 | |
| 
 | |
|     specifier-qualifier-list:
 | |
|                           type-specifier-qualifier attribute-specifier-sequenceopt
 | |
|                           type-specifier-qualifier specifier-qualifier-list
 | |
| 
 | |
|     type-specifier-qualifier:
 | |
|                          type-specifier
 | |
|                          type-qualifier
 | |
|                          alignment-specifier
 | |
| 
 | |
| 
 | |
| 
 | |
|     member-declarator-list:
 | |
|                       member-declarator
 | |
|                       member-declarator-list , member-declarator
 | |
| 
 | |
|     member-declarator:
 | |
|                            declarator
 | |
|                            declaratoropt : constant-expression
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.7.2.1p2'></a>
 | |
| <pre>2   A member declaration that does not declare an anonymous structure or anonymous union shall
 | |
|     contain a member declarator list.
 | |
| </pre>
 | |
| <a name='6.7.2.1p3'></a>
 | |
| <pre>3   A structure or union shall not contain a member with incomplete or function type (hence, a structure
 | |
|     shall not contain an instance of itself, but may contain a pointer to an instance of itself), except that
 | |
|     the last member of a structure with more than one named member may have incomplete array type;
 | |
|     such a structure (and any union containing, possibly recursively, a member that is such a structure)
 | |
|     shall not be a member of a structure or an element of an array.
 | |
| </pre>
 | |
| <a name='6.7.2.1p4'></a>
 | |
| <pre>4   The expression that specifies the width of a bit-field shall be an integer constant expression with a
 | |
|     nonnegative value that does not exceed the width of an object of the type that would be specified
 | |
|     were the colon and expression omitted<a href='#FOOTNOTE.145'><sup>[145]</sup></a> . If the value is zero, the declaration shall have no
 | |
|     declarator.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.145'>
 | |
| <pre><i><b>Footnote 145)</b> While the number of bits in a bool object is at least CHAR_BIT, the width of a bool can be just 1 bit.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.1p5'></a>
 | |
| <pre>5   A bit-field shall have a type that is a qualified or unqualified version of bool, signed int, unsigned
 | |
|     int, a bit-precise integer type, or some other implementation-defined type. It is implementation-
 | |
|     defined whether atomic types are permitted.
 | |
| </pre>
 | |
| <a name='6.7.2.1p6'></a>
 | |
| <pre>6   An attribute specifier sequence shall not appear in a struct-or-union specifier without a member
 | |
|     declaration list, except in a declaration of the form:
 | |
|                struct-or-union attribute-specifier-sequence identifier ;
 | |
|     The attributes in the attribute specifier sequence, if any, are thereafter considered attributes of the
 | |
|     struct or union whenever it is named.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.2.1p7'></a>
 | |
| <pre>7   As discussed in <a href='#6.2.5'>6.2.5</a>, a structure is a type consisting of a sequence of members, whose storage is
 | |
|     allocated in an ordered sequence, and a union is a type consisting of a sequence of members whose
 | |
|     storage overlap.
 | |
| </pre>
 | |
| <a name='6.7.2.1p8'></a>
 | |
| <pre>8    Structure and union specifiers have the same form. The keywords struct and union indicate that
 | |
|      the type being specified is, respectively, a structure type or a union type.
 | |
| </pre>
 | |
| <a name='6.7.2.1p9'></a>
 | |
| <pre>9    The optional attribute specifier sequence in a struct-or-union specifier appertains to the structure
 | |
|      or union type being declared. The optional attribute specifier sequence in a member declaration
 | |
|      appertains to each of the members declared by the member declarator list; it shall not appear if the
 | |
|      optional member declarator list is omitted. The optional attribute specifier sequence in a specifier
 | |
|      qualifier list appertains to the type denoted by the preceding type specifier qualifiers. The attribute
 | |
|      specifier sequence affects the type only for the member declaration or type name it appears in, not
 | |
|      other types or declarations involving the same type.
 | |
| </pre>
 | |
| <a name='6.7.2.1p10'></a>
 | |
| <pre>10   The member declaration list is a sequence of declarations for the members of the structure or union.
 | |
|      If the member declaration list does not contain any named members, either directly or via an
 | |
|      anonymous structure or anonymous union, the behavior is undefined<a href='#FOOTNOTE.146'><sup>[146]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.146'>
 | |
| <pre><i><b>Footnote 146)</b> For further rules affecting compatibility and completeness of structure or union types, see <a href='#6.2.7'>6.2.7</a> and <a href='#6.7.2.3'>6.7.2.3</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.1p11'></a>
 | |
| <pre>11   A member of a structure or union may have any complete object type other than a variably modified
 | |
|      type<a href='#FOOTNOTE.147'><sup>[147]</sup></a> . In addition, a member may be declared to consist of a specified number of bits (including a
 | |
|      sign bit, if any). Such a member is called a bit-field 148) ; its width is preceded by a colon.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.147'>
 | |
| <pre><i><b>Footnote 147)</b> A structure or union cannot contain a member with a variably modified type because member names are not ordinary
 | |
|      identifiers as defined in <a href='#6.2.3'>6.2.3</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.1p12'></a>
 | |
| <pre>12   A bit-field is interpreted as having a signed or unsigned integer type consisting of the specified
 | |
|      number of bits<a href='#FOOTNOTE.149'><sup>[149]</sup></a> . If the value 0 or 1 is stored into a nonzero-width bit-field of type bool, the value
 | |
|      of the bit-field shall compare equal to the value stored; a bool bit-field has the semantics of a bool.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.149'>
 | |
| <pre><i><b>Footnote 149)</b> As specified in <a href='#6.7.2'>6.7.2</a> above, if the actual type specifier used is int or a typedef-name defined as int, then it is
 | |
|      implementation-defined whether the bit-field is signed or unsigned. This includes an int type specifier produced by
 | |
|      the use of the typeof specifier (<a href='#6.7.2.5'>6.7.2.5</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.1p13'></a>
 | |
| <pre>13   An implementation may allocate any addressable storage unit large enough to hold a bit-field. If
 | |
|      enough space remains, a bit-field that immediately follows another bit-field in a structure shall be
 | |
|      packed into adjacent bits of the same unit. If insufficient space remains, whether a bit-field that
 | |
|      does not fit is put into the next unit or overlaps adjacent units is implementation-defined. The
 | |
|      order of allocation of bit-fields within a unit (high-order to low-order or low-order to high-order) is
 | |
|      implementation-defined. The alignment of the addressable storage unit is unspecified.
 | |
| </pre>
 | |
| <a name='6.7.2.1p14'></a>
 | |
| <pre>14   A bit-field declaration with no declarator, but only a colon and a width, indicates an unnamed
 | |
|      bit-field.<a href='#FOOTNOTE.150'><sup>[150]</sup></a> As a special case, a bit-field structure member with a width of 0 indicates that no
 | |
|      further bit-field is to be packed into the unit in which the previous bit-field, if any, was placed.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.150'>
 | |
| <pre><i><b>Footnote 150)</b> An unnamed bit-field structure member is useful for padding to conform to externally imposed layouts.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.1p15'></a>
 | |
| <pre>15   An unnamed member whose type specifier is a structure specifier with no tag is called an anonymous
 | |
|      structure; an unnamed member whose type specifier is a union specifier with no tag is called an
 | |
|      anonymous union. The members of an anonymous structure or union are considered to be members
 | |
|      of the containing structure or union, keeping their structure or union layout. This applies recursively
 | |
|      if the containing structure or union is also anonymous.
 | |
| </pre>
 | |
| <a name='6.7.2.1p16'></a>
 | |
| <pre>16   Each non-bit-field member of a structure or union object is aligned in an implementation-defined
 | |
|      manner appropriate to its type.
 | |
| </pre>
 | |
| <a name='6.7.2.1p17'></a>
 | |
| <pre>17   Within a structure object, the non-bit-field members and the units in which bit-fields reside have
 | |
|      addresses that increase in the order in which they are declared. A pointer to a structure object,
 | |
|      suitably converted, points to its initial member (or if that member is a bit-field, then to the unit in
 | |
|      which it resides), and vice versa. There may be unnamed padding within a structure object, but not
 | |
|      at its beginning.
 | |
| </pre>
 | |
| <a name='6.7.2.1p18'></a>
 | |
| <pre>18   The size of a union is sufficient to contain the largest of its members. The value of at most one of the
 | |
|      members can be stored in a union object at any time. A pointer to a union object, suitably converted,
 | |
|      points to each of its members (or if a member is a bit-field, then to the unit in which it resides),
 | |
|      and vice versa. The members of a union object overlap in such a way that pointers to them when
 | |
|      converted to pointers to character types point to the same byte. There may be unnamed padding at
 | |
|       the end of a union object, but not at its beginning.
 | |
| </pre>
 | |
| <a name='6.7.2.1p19'></a>
 | |
| <pre>19    There may be unnamed padding at the end of a structure or union.
 | |
| </pre>
 | |
| <a name='6.7.2.1p20'></a>
 | |
| <pre>20    As a special case, the last member of a structure with more than one named member may have an
 | |
|       incomplete array type; this is called a flexible array member. In most situations, the flexible array
 | |
|       member is ignored. In particular, the size of the structure is as if the flexible array member were
 | |
|       omitted except that it may have more trailing padding than the omission would imply. However,
 | |
|       when a . (or-> ) operator has a left operand that is (a pointer to) a structure with a flexible array
 | |
|       member and the right operand names that member, it behaves as if that member were replaced with
 | |
|       the longest array (with the same element type) that would not make the structure larger than the
 | |
|       object being accessed; the offset of the array shall remain that of the flexible array member, even if
 | |
|       this would differ from that of the replacement array. If this array would have no elements, it behaves
 | |
|       as if it had one element but the behavior is undefined if any attempt is made to access that element
 | |
|       or to generate a pointer one past it.
 | |
| </pre>
 | |
| <a name='6.7.2.1p21'></a>
 | |
| <pre>21    EXAMPLE 1 The following declarations illustrate the behavior when an attribute is written on a tag declaration:
 | |
| 
 | |
|                 struct [[deprecated]] S; // valid, [[deprecated]] appertains to struct S
 | |
|                 void f(struct S *s);     // valid, the struct S type has the [[deprecated]]
 | |
|                                          // attribute
 | |
|                 struct S {               // valid, struct S inherits the [[deprecated]] attribute
 | |
|                       int a;             // from the previous declaration
 | |
|                 };
 | |
|                 void g(struct [[deprecated]] S s); // invalid
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.1p22'></a>
 | |
| <pre>22    EXAMPLE 2 The following illustrates anonymous structures and unions:
 | |
| 
 | |
|                 struct v {
 | |
|                       union {     // anonymous union
 | |
|                             struct { int i, j; };   // anonymous structure
 | |
|                             struct { long k, l; } w;
 | |
|                       };
 | |
|                       int m;
 | |
|                 } v1;
 | |
| 
 | |
|                 v1.i = 2;   // valid
 | |
|                 v1.k = 3;   // invalid:            inner structure is not anonymous
 | |
|                 v1.w.k = 5; // valid
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.1p23'></a>
 | |
| <pre>23    EXAMPLE 3 After the declaration:
 | |
| 
 | |
|                 struct s { int n; double d[]; };
 | |
| 
 | |
| 
 | |
|       the structure struct s has a flexible array member d. A typical way to use this is:
 | |
| 
 | |
|                 int m = /* some value */;
 | |
|                 struct s *p = malloc(sizeof (struct s) + sizeof (double [m]));
 | |
| 
 | |
| 
 | |
|       and assuming that the call to malloc succeeds, the object pointed to by p behaves, for most purposes, as if p had been
 | |
|       declared as:
 | |
| 
 | |
|                 struct { int n; double d[m]; } *p;
 | |
| 
 | |
| 
 | |
|       (there are circumstances in which this equivalence is broken; in particular, the offsets of member d might not be the same).
 | |
| </pre>
 | |
| <a name='6.7.2.1p24'></a>
 | |
| <pre>24   Following the above declaration:
 | |
| 
 | |
|                 struct s t1 = { 0 };                      // valid
 | |
|                 struct s t2 = { 1, { 4.2 }};              // invalid
 | |
|                 t1.n = 4;                                 // valid
 | |
|                 t1.d[0] = 4.2;                            // might be undefined behavior
 | |
|      The initialization of t2 is invalid (and violates a constraint) because struct s is treated as if it did not contain member d.
 | |
|      The assignment to t1.d[0] is probably undefined behavior, but it is possible that
 | |
| 
 | |
|                sizeof (struct s) >= offsetof(struct s, d) + sizeof (double)
 | |
| 
 | |
|      in which case the assignment would be legitimate. Nevertheless, it cannot appear in strictly conforming code.
 | |
| </pre>
 | |
| <a name='6.7.2.1p25'></a>
 | |
| <pre>25   After the further declaration:
 | |
| 
 | |
|                struct ss { int n; };
 | |
| 
 | |
|      the expressions:
 | |
| 
 | |
|                sizeof (struct s) >= sizeof (struct ss)
 | |
|                sizeof (struct s) >= offsetof(struct s, d)
 | |
| 
 | |
|      are always equal to 1.
 | |
| </pre>
 | |
| <a name='6.7.2.1p26'></a>
 | |
| <pre>26   If sizeof (double) is 8, then after the following code is executed:
 | |
| 
 | |
|                struct s *s1;
 | |
|                struct s *s2;
 | |
|                s1 = malloc(sizeof (struct s) + 64);
 | |
|                s2 = malloc(sizeof (struct s) + 46);
 | |
| 
 | |
|      and assuming that the calls to malloc succeed, the objects pointed to by s1 and s2 behave, for most purposes, as if the
 | |
|      identifiers had been declared as:
 | |
| 
 | |
|                struct { int n; double d[8]; } *s1;
 | |
|                struct { int n; double d[5]; } *s2;
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.1p27'></a>
 | |
| <pre>27   Following the further successful assignments:
 | |
| 
 | |
|                s1 = malloc(sizeof (struct s) + 10);
 | |
|                s2 = malloc(sizeof (struct s) + 6);
 | |
| 
 | |
|      they then behave as if the declarations were:
 | |
| 
 | |
|                struct { int n; double d[1]; } *s1, *s2;
 | |
| 
 | |
|      and:
 | |
| 
 | |
|                double *dp;
 | |
|                dp = &(s1->d[0]); // valid
 | |
|                *dp = 42;         // valid
 | |
|                dp = &(s2->d[0]); // valid
 | |
|                *dp = 42;         // undefined behavior
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.1p28'></a>
 | |
| <pre>28   The assignment:
 | |
| 
 | |
|                *s1 = *s2;
 | |
| 
 | |
|      only copies the member n; if any of the array elements are within the first sizeof (struct s) bytes of the structure, they
 | |
|      are set to an indeterminate representation, that may or may not coincide with a copy of the representation of the elements of
 | |
|      the source array.
 | |
| </pre>
 | |
| <a name='6.7.2.1p29'></a>
 | |
| <pre>29   EXAMPLE 4 Because members of anonymous structures and unions are considered to be members of the containing
 | |
|      structure or union, struct s in the following example has more than one named member and thus the use of a flexible array
 | |
|      member is valid:
 | |
| 
 | |
|                struct s {
 | |
|                      struct { int i; };
 | |
|                      int a[];
 | |
|                };
 | |
| 
 | |
| 
 | |
|      Forward references: declarators (<a href='#6.7.6'>6.7.6</a>), tags (<a href='#6.7.2.3'>6.7.2.3</a>).
 | |
| </pre>
 | |
| <a name='6.7.2.2'></a>
 | |
| <hr>
 | |
| <h3>6.7.2.2 [Enumeration specifiers]</h3>
 | |
| <a name='6.7.2.2p1'></a>
 | |
| <pre>1 Syntax
 | |
|      enum-specifier:
 | |
|                         enum attribute-specifier-sequenceopt identifieropt enum-type-specifieropt
 | |
|                                              { enumerator-list }
 | |
|                         enum attribute-specifier-sequenceopt identifieropt enum-type-specifieropt
 | |
|                                              { enumerator-list , }
 | |
|                         enum identifier enum-type-specifieropt
 | |
|       enumerator-list:
 | |
|                         enumerator
 | |
|                         enumerator-list , enumerator
 | |
|       enumerator:
 | |
|                         enumeration-constant attribute-specifier-sequenceopt
 | |
|                         enumeration-constant attribute-specifier-sequenceopt = constant-expression
 | |
|      enum-type-specifier:
 | |
|                         : specifier-qualifier-list
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.2p2'></a>
 | |
| <pre>2   All enumerations have an underlying type. The underlying type can be explicitly specified using an
 | |
|     enum type specifier and is its fixed underlying type. If it is not explicitly specified, the underlying type
 | |
|     is the enumeration’s compatible type, which is either a signed or unsigned integer type (excluding
 | |
|     the bit-precise integer types), or char.
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.7.2.2p3'></a>
 | |
| <pre>3   For an enumeration with a fixed underlying type, the integer constant expression defining the value
 | |
|     of the enumeration constant shall be representable in that fixed underlying type. The definition of an
 | |
|     enumeration constant without a defining constant expression shall neither overflow nor wraparound
 | |
|     the fixed underlying type by adding 1 to the previous enumeration constant.
 | |
| </pre>
 | |
| <a name='6.7.2.2p4'></a>
 | |
| <pre>4   For an enumeration without a fixed underlying type, the expression that defines the value of an
 | |
|     enumeration constant shall be an integer constant expression. For all the integer constant expressions
 | |
|     which make up the values of the enumeration constants, there shall be a signed or unsigned integer
 | |
|     type (excluding the bit-precise integer types) capable of representing all of the values.
 | |
| </pre>
 | |
| <a name='6.7.2.2p5'></a>
 | |
| <pre>5   If an enum type specifier is present, then the longest possible sequence of tokens that can be
 | |
|     interpreted as a specifier qualifier list is interpreted as part of the enum type specifier. It shall name
 | |
|     an integer type that is neither an enumeration nor a bit-precise integer type.
 | |
| </pre>
 | |
| <a name='6.7.2.2p6'></a>
 | |
| <pre>6   An enum specifier of the form
 | |
|                          enum identifier enum-type-specifier
 | |
| 
 | |
| 
 | |
|     may not appear except in a declaration of the form
 | |
|                          enum identifier enum-type-specifier ;
 | |
| 
 | |
| 
 | |
|     unless it is immediately followed by an opening brace, an enumerator list (with an optional ending
 | |
|     comma), and a closing brace.
 | |
| </pre>
 | |
| <a name='6.7.2.2p7'></a>
 | |
| <pre>7   If two enum specifiers that include an enum type specifier declare the same type, the underlying
 | |
|     types shall be compatible.
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.2.2p8'></a>
 | |
| <pre>8   The optional attribute specifier sequence in the enum specifier appertains to the enumeration; the
 | |
|     attributes in that attribute specifier sequence are thereafter considered attributes of the enumeration
 | |
|     whenever it is named. The optional attribute specifier sequence in the enumerator appertains to that
 | |
|     enumerator.
 | |
| </pre>
 | |
| <a name='6.7.2.2p9'></a>
 | |
| <pre>9   The identifiers in an enumerator list are declared as constants of the types specified below and may
 | |
|      appear wherever such are permitted<a href='#FOOTNOTE.151'><sup>[151]</sup></a> . An enumerator with = defines its enumeration constant as
 | |
|      the value of the constant expression. If the first enumerator has no =, the value of its enumeration
 | |
|      constant is 0. Each subsequent enumerator with no = defines its enumeration constant as the value
 | |
|      of the constant expression obtained by adding 1 to the value of the previous enumeration constant.
 | |
|      (The use of enumerators with = may produce enumeration constants with values that duplicate
 | |
|      other values in the same enumeration.) The enumerators of an enumeration are also known as its
 | |
|      members.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.151'>
 | |
| <pre><i><b>Footnote 151)</b> Thus, the identifiers of enumeration constants declared in the same scope are all required to be distinct from each other
 | |
|      and from other identifiers declared in ordinary declarators.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.2p10'></a>
 | |
| <pre>10   The type for the members of an enumeration is called the enumeration member type.
 | |
| </pre>
 | |
| <a name='6.7.2.2p11'></a>
 | |
| <pre>11   During the processing of each enumeration constant in the enumerator list, the type of the enumera-
 | |
|      tion constant shall be:
 | |
| 
 | |
|        — the previously declared type, if it is a redeclaration of the same enumeration constant; or,
 | |
|        — the enumerated type, for an enumeration with fixed underlying type; or,
 | |
|        — int, if there are no previous enumeration constants in the enumerator list and no explicit =
 | |
|          with a defining integer constant expression; or,
 | |
|        — int, if given explicitly with = and the value of the integer constant expression is representable
 | |
|          by an int; or,
 | |
|        — the type of the integer constant expression, if given explicitly with = and if the value of the
 | |
|          integer constant expression is not representable by int; or,
 | |
|        — the type of the value from the previous enumeration constant with 1 added to it. If such
 | |
|          an integer constant expression would overflow or wraparound the value of the previous
 | |
|          enumeration constant from the addition of 1, the type takes on either:
 | |
|               — a suitably sized signed integer type (excluding the bit-precise signed integer types)
 | |
|                 capable of representing the value of the previous enumeration constant plus 1; or,
 | |
|               — a suitably sized unsigned integer type (excluding the bit-precise unsigned integer types)
 | |
|                 capable of representing the value of the previous enumeration constant plus 1.
 | |
|             A signed integer type is chosen if the previous enumeration constant being added is of signed
 | |
|             integer type. An unsigned integer type is chosen if the previous enumeration constant is of
 | |
|             unsigned integer type. If there is no suitably sized integer type described previously which can
 | |
|             represent the new value, then the enumeration has no type which is capable of representing
 | |
|             all of its values<a href='#FOOTNOTE.152'><sup>[152]</sup></a> .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.152'>
 | |
| <pre><i><b>Footnote 152)</b> Therefore, a constraint has been violated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.2p12'></a>
 | |
| <pre>12   For all enumerations without a fixed underlying type, each enumerated type shall be compatible
 | |
|      with char, a signed integer type, or an unsigned integer type (excluding the bit-precise integer
 | |
|      types). The choice of type is implementation-defined<a href='#FOOTNOTE.153'><sup>[153]</sup></a> , but shall be capable of representing the
 | |
|      values of all the members of the enumeration<a href='#FOOTNOTE.154'><sup>[154]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.153'>
 | |
| <pre><i><b>Footnote 153)</b> An implementation can delay the choice of which integer type until all enumeration constants have been seen.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.154'>
 | |
| <pre><i><b>Footnote 154)</b> For further rules affecting compatibility and completeness of enumerated types see <a href='#6.2.7'>6.2.7</a> and <a href='#6.7.2.3'>6.7.2.3</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.2p13'></a>
 | |
| <pre>13   Enumeration constants can be redefined in the same scope with the same value as part of a redecla-
 | |
|      ration of the same enumerated type.
 | |
| </pre>
 | |
| <a name='6.7.2.2p14'></a>
 | |
| <pre>14   The enumeration member type for an enumerated type without fixed underlying type upon comple-
 | |
|      tion is:
 | |
| 
 | |
|        — int if all the values of the enumeration are representable as an int; or,
 | |
|        — the enumerated type<a href='#FOOTNOTE.155'><sup>[155]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.155'>
 | |
| <pre><i><b>Footnote 155)</b> The integer type selected during processing of the enumerator list (before completion) of the enumeration may not be the
 | |
|      same as the compatible implementation-defined integer type selected for the completed enumeration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.2p15'></a>
 | |
| <pre>15   The enumeration member type for an enumerated type with fixed underlying type is the enumerated
 | |
|      type. The enumerated type is compatible with the underlying type of the enumeration. After possible
 | |
|      lvalue conversion a value of the enumerated type behaves the same as the value with the underlying
 | |
|      type, in particularly with all aspects of promotion, conversion, and arithmetic<a href='#FOOTNOTE.156'><sup>[156]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.156'>
 | |
| <pre><i><b>Footnote 156)</b> This means in particular that if the compatible type is bool, values of the enumerated type behave in all aspects the
 | |
|      same as bool and the members only have values 0 and 1. If it is a signed integer type and the constant expression of an
 | |
|      enumeration constant overflows, a constraint for constant expressions (<a href='#6.6'>6.6</a>) is violated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.2p16'></a>
 | |
| <pre>16   EXAMPLE The following fragment:
 | |
| 
 | |
|                enum hue { chartreuse, burgundy, claret=20, winedark };
 | |
|                enum hue col, *cp;
 | |
|                col = claret;
 | |
|                cp = &col;
 | |
|                if (*cp != burgundy)
 | |
|                      /* ... */
 | |
| 
 | |
|      makes hue the tag of an enumeration, and then declares col as an object that has that type and cp as a pointer to an object
 | |
|      that has that type. The enumerated values are in the set {0, 1, 20, 21}.
 | |
| </pre>
 | |
| <a name='6.7.2.2p17'></a>
 | |
| <pre>17   EXAMPLE Even if the value of an enumeration constant is generated by the implicit addition of 1, an enumeration with a
 | |
|      fixed underlying type does not exhibit typical overflow behavior:
 | |
| 
 | |
|                #include <limits.h>
 | |
| 
 | |
|                enum us : unsigned short {
 | |
|                      us_max = USHRT_MAX,
 | |
|                      us_violation, /* Constraint violation:
 | |
|                                       USHRT_MAX + 1 would wraparound. */
 | |
|                      us_violation_2 = us_max + 1, /* Maybe constraint violation:
 | |
|                                                      USHRT_MAX + 1 may be promoted to "int", and
 | |
|                                                      result is too wide for the
 | |
|                                                      underlying type. */
 | |
|                      us_wrap_around_to_zero = (unsigned short)(USHRT_MAX + 1) /* Okay:
 | |
|                                                conversion done in constant expression
 | |
|                                                before conversion to underlying type:
 | |
|                                                unsigned semantics okay. */
 | |
|                };
 | |
| 
 | |
|                enum ui : unsigned int {
 | |
|                      ui_max = UINT_MAX,
 | |
|                      ui_violation, /* Constraint violation:
 | |
|                                       UINT_MAX + 1 would wraparound. */
 | |
|                      ui no violation = ui_max + 1, /* Okay: Arithmetic performed as typical
 | |
|                        _  _
 | |
|                                                       unsigned integer arithmetic: conversion
 | |
|                                                       from a value that is already 0 to 0. */
 | |
|                      ui_wrap_around_to_zero = (unsigned int)(UINT_MAX + 1) /* Okay: conversion
 | |
|                                                done in constant expression before conversion to
 | |
|                                                underlying type: unsigned semantics okay. */
 | |
|                };
 | |
| 
 | |
|                int main () {
 | |
|                      // Same as return 0;
 | |
|                      return ui_wrap_around_to_zero
 | |
|                             + us_wrap_around_to_zero;
 | |
|                }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.2p18'></a>
 | |
| <pre>18   EXAMPLE The following fragment:
 | |
| 
 | |
|                #include <limits.h>
 | |
| 
 | |
|                enum E1: short;
 | |
|                enum E2: short;
 | |
|                enum E3; /* Constraint violation: E3 forward declaration. */
 | |
|                enum E4 : unsigned long long;
 | |
| 
 | |
|                enum E1 : short { m11, m12 };
 | |
|                enum E1 x = m11;
 | |
| 
 | |
|                enum E2 : long { m21, m22 }; /* Constraint violation: different underlying types
 | |
|                    */
 | |
| 
 | |
|                enum E3 {
 | |
|                      m31,
 | |
|                      m32,
 | |
|                      m33 = sizeof(enum E3) /* Constraint violation: E3 is not complete here. */
 | |
|                };
 | |
|                enum E3 : int; /* Constraint violation: E3 previously had no underlying type */
 | |
| 
 | |
|                enum E4 : unsigned long long {
 | |
|                      m40 = sizeof(enum E4),
 | |
|                      m41 = ULLONG_MAX,
 | |
|                      m42 /* Constraint violation: unrepresentable value (wraparound) */
 | |
|                };
 | |
| 
 | |
|                enum E5 y; /* Constraint violation: incomplete type */
 | |
|                enum E6 : long int z; /* Constraint violation: enum-type-specifier
 | |
|                                         with identifier in declarator */
 | |
|                enum E7 : long int = 0; /* Syntax violation:
 | |
|                                           enum-type-specifier with initializer */
 | |
| 
 | |
| 
 | |
|      demonstrates many of the properties of multiple declarations of enumerations with underlying types. Particularly, enum E3
 | |
|      is declared and defined without an underlying type first, therefore a redeclaration with an underlying type second is a
 | |
|      violation. Because it not complete at that time within its enumerator list, sizeof(enum E3) is a constraint violation within
 | |
|      the enum E3 definition. enum E4 is complete as it is being defined, therefore sizeof(enum E4) is not a constraint violation.
 | |
| </pre>
 | |
| <a name='6.7.2.2p19'></a>
 | |
| <pre>19   EXAMPLE The following fragment:
 | |
| 
 | |
|                enum no_underlying {
 | |
|                      a0
 | |
|                };
 | |
| 
 | |
|                int main () {
 | |
|                      int a = _Generic(a0,
 | |
|                            int: 2,
 | |
|                            unsigned char: 1,
 | |
|                            default: 0
 | |
|                      );
 | |
|                      int b = _Generic((enum no_underlying)a0,
 | |
|                            int: 2,
 | |
|                            unsigned char: 1,
 | |
|                            default: 0
 | |
|                      );
 | |
|                      return a + b;
 | |
|                }
 | |
| 
 | |
| 
 | |
|      demonstrates the implementation-defined nature of the underlying type of enumerations using generic selection (<a href='#6.5.1.1'>6.5.1.1</a>).
 | |
|      The value of a after its initialization is 2. The value of b after its initialization is implementation-defined: the enumeration
 | |
|      must be compatible with a type large enough to fit the values of its enumeration constants. Since the only value is 0 for a0, b
 | |
|      may hold any of 2, 1, or 0.
 | |
|      Now, consider a similar fragment, but using a fixed underlying type:
 | |
| 
 | |
|                enum underlying : unsigned char {
 | |
|                      b0
 | |
|                };
 | |
|                int main () {
 | |
|                      int a = _Generic(b0,
 | |
|                            int: 2,
 | |
|                            unsigned char: 1,
 | |
|                            default: 0
 | |
|                      );
 | |
|                      int b = _Generic((enum underlying)b0,
 | |
|                            int: 2,
 | |
|                            unsigned char: 1,
 | |
|                            default: 0
 | |
|                      );
 | |
|                      return 0;
 | |
|                }
 | |
| 
 | |
| 
 | |
|      Here, we are guaranteed that a and b are both initialized to 1. This makes enumerations with a fixed underlying type more
 | |
|      portable.
 | |
| </pre>
 | |
| <a name='6.7.2.2p20'></a>
 | |
| <pre>20   EXAMPLE Enumerations with a fixed underlying type must have their braces and the enumerator list specified as part of
 | |
|      their declaration if they are not a standalone declaration:
 | |
| 
 | |
|                void f1 (enum a : long b); /* Constraint violation */
 | |
|                void f2 (enum c : long { x } d);
 | |
|                enum e : int f3(); /* Constraint violation */
 | |
| 
 | |
|                typedef enum t u; /* Constraint violation: forward declaration of t. */
 | |
|                typedef enum v : short W; /* Constraint violation */
 | |
|                typedef enum q : short { s } R;
 | |
| 
 | |
|                struct s1 {
 | |
|                      int x;
 | |
|                      enum e : int : 1; /* Constraint violation */
 | |
|                      int y;
 | |
|                };
 | |
| 
 | |
|                enum forward; /* Constraint violation */
 | |
|                extern enum forward fwd_val0; /* Constraint violation: incomplete type */
 | |
|                extern enum forward* fwd_ptr0; /* Constraint violation: enums cannot be
 | |
|                                                    used like other incomplete types */
 | |
|                extern int* fwd_ptr0; /* Constraint violation: incompatible
 | |
|                                         with incomplete type. */
 | |
| 
 | |
|                enum forward1 : int;
 | |
|                extern enum forward1 fwd_val1;
 | |
|                extern int fwd_val1;
 | |
|                extern enum forward1* fwd_ptr1;
 | |
|                extern int* fwd_ptr1;
 | |
| 
 | |
|                int main () {
 | |
|                      enum e : short;
 | |
|                      enum e : short f = 0; /* Constraint violation */
 | |
|                      enum g : short { y } h = y;
 | |
|                      return 0;
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.2p21'></a>
 | |
| <pre>21   EXAMPLE Enumerations with a fixed underlying type are complete when the enum type specifier for that specific
 | |
|      enumeration is complete. The enumeration e in this snippet:
 | |
| 
 | |
|                enum e : typeof ((enum e : short { A })0, (short)0);
 | |
| 
 | |
| 
 | |
|      enum e is considered complete by the first opening brace within the typeof in this snippet.
 | |
| 
 | |
|      Forward references: generic selection (<a href='#6.5.1.1'>6.5.1.1</a>), tags (<a href='#6.7.2.3'>6.7.2.3</a>), declarations (<a href='#6.7'>6.7</a>), declarators (<a href='#6.7.6'>6.7.6</a>),
 | |
|      function declarators (<a href='#6.7.6.3'>6.7.6.3</a>), type names (<a href='#6.7.7'>6.7.7</a>).
 | |
| </pre>
 | |
| <a name='6.7.2.3'></a>
 | |
| <hr>
 | |
| <h3>6.7.2.3 [Tags]</h3>
 | |
| <a name='6.7.2.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|    Where two declarations that use the same tag declare the same type, they shall both use the same
 | |
|     choice of struct, union, or enum. If two declarations of the same type have a member-declaration
 | |
|     or enumerator-list, one shall not be nested within the other and both declarations shall fulfill
 | |
|     all requirements of compatible types (<a href='#6.2.7'>6.2.7</a>) with the additional requirement that corresponding
 | |
|     members of structure or union types shall have the same (and not merely compatible) types.
 | |
| </pre>
 | |
| <a name='6.7.2.3p2'></a>
 | |
| <pre>2   A type specifier of the form
 | |
|                enum identifier
 | |
|     without an enumerator list shall only appear after the type it specifies is complete.
 | |
| </pre>
 | |
| <a name='6.7.2.3p3'></a>
 | |
| <pre>3   A type specifier of the form
 | |
|                 struct-or-union attribute-specifier-sequenceopt identifier
 | |
|     shall not contain an attribute specifier sequence<a href='#FOOTNOTE.157'><sup>[157]</sup></a> .
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.157'>
 | |
| <pre><i><b>Footnote 157)</b> As specified in <a href='#6.7.2.1'>6.7.2.1</a> above, the type specifier may be followed by a ; or a member declaration list.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.3p4'></a>
 | |
| <pre>4   All declarations of structure, union, or enumerated types that have the same scope and use the same
 | |
|     tag declare the same type.
 | |
| </pre>
 | |
| <a name='6.7.2.3p5'></a>
 | |
| <pre>5   Irrespective of whether there is a tag or what other declarations of the type are in the same translation
 | |
|     unit, a type (except enumerated types with a fixed underlying type) is incomplete from the beginning
 | |
|     of the specifier until immediately after the closing brace of the list defining the content for the first
 | |
|     time, and complete thereafter until the beginning of the next specifier that redeclares the same type
 | |
|     later in the same translation unit (if any) or otherwise until the end of the translation unit.
 | |
| </pre>
 | |
| <a name='6.7.2.3p6'></a>
 | |
| <pre>6   Enumerated types with fixed underlying type (<a href='#6.7.2.2'>6.7.2.2</a>) are complete immediately after their first
 | |
|     associated enum type specifier ends.
 | |
| </pre>
 | |
| <a name='6.7.2.3p7'></a>
 | |
| <pre>7   EXAMPLE 1 The following example shows allowed redeclarations of the same structure, union, or enumerated type in the
 | |
|     same scope:
 | |
| 
 | |
|              struct foo { struct { int x; }; };
 | |
|              struct foo { struct { int x; }; };
 | |
|              union bar { int x; float y; };
 | |
|              union bar { float y; int x; };
 | |
|              typedef struct q { int x; } q_t;
 | |
|              typedef struct q { int x; } q_t;
 | |
|              void foo(void)
 | |
|              {
 | |
|              struct S { int x; };
 | |
|              struct T { struct S s; };
 | |
|              struct S { int x; };
 | |
|              struct T { struct S s; };
 | |
|              }
 | |
|              enum X { A = 1, B = 1 + 1 };
 | |
|              enum X { B = 2, A = 1 };
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.3p8'></a>
 | |
| <pre>8   EXAMPLE 2 The following example shows invalid redeclarations of the same structure, union, or enumerated type in the
 | |
|     same scope:
 | |
| 
 | |
|              struct foo { int (*p)[3]; };
 | |
|              struct foo { int (*p)[]; };                  // member has different type
 | |
| 
 | |
|              union bar { int x; float y; };
 | |
|              union bar { int z; float y; }; // member has different name
 | |
| 
 | |
|              typedef struct { int x; } q_t;
 | |
|              typedef struct { int x; } q_t; // not the same type
 | |
|                 struct S { int x; };
 | |
| 
 | |
|                 void foo(void)
 | |
|                 {
 | |
|                       struct T { struct S s; };
 | |
|                       struct S { int x; };
 | |
|                       struct T { struct S s; }; // struct S not the same type
 | |
|                 }
 | |
| 
 | |
|                 enum X { A = 1, B = 2 };
 | |
|                 enum X { A = 1, B = 3 };                       // different enumeration constant
 | |
| 
 | |
|                 enum R { C = 1 };
 | |
|                 enum Q { C = 1 };                              // conflicting enumeration constant
 | |
|                 enum Q { C = C };                              // ok!
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.3p9'></a>
 | |
| <pre>9    Two declarations of structure, union, or enumerated types which are in different scopes or use
 | |
|      different tags declare distinct types. Each declaration of a structure, union, or enumerated type
 | |
|      which does not include a tag declares a distinct type.
 | |
| </pre>
 | |
| <a name='6.7.2.3p10'></a>
 | |
| <pre>10   A type specifier of the form
 | |
|                   struct-or-union attribute-specifier-sequenceopt identifieropt { member-declaration-list }
 | |
|      or
 | |
|                   enum attribute-specifier-sequenceopt identifieropt { enumerator-list }
 | |
|      or
 | |
|                   enum attribute-specifier-sequenceopt identifieropt { enumerator-list , }
 | |
|      declares a structure, union, or enumerated type. The list defines the structure content, union content,
 | |
|      or enumeration content. If an identifier is provided<a href='#FOOTNOTE.158'><sup>[158]</sup></a> , the type specifier also declares the identifier to
 | |
|      be the tag of that type. The optional attribute specifier sequence appertains to the structure, union,
 | |
|      or enumeration type being declared; the attributes in that attribute specifier sequence are thereafter
 | |
|      considered attributes of the structure, union, or enumeration type whenever it is named.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.158'>
 | |
| <pre><i><b>Footnote 158)</b> If there is no identifier, the type can, within the translation unit, only be referred to by the declaration of which it is a part.
 | |
|      Of course, when the declaration is of a typedef name, subsequent declarations can make use of that typedef name to declare
 | |
|      objects having the specified structure, union, or enumerated type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.3p11'></a>
 | |
| <pre>11   A declaration of the form
 | |
|                   struct-or-union attribute-specifier-sequenceopt identifier ;
 | |
|      specifies a structure or union type and declares the identifier as a tag of that type<a href='#FOOTNOTE.159'><sup>[159]</sup></a> . The optional
 | |
|      attribute specifier sequence appertains to the structure or union type being declared; the attributes
 | |
|      in that attribute specifier sequence are thereafter considered attributes of the structure or union type
 | |
|      whenever it is named.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.159'>
 | |
| <pre><i><b>Footnote 159)</b> A similar construction with enum does not exist.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.3p12'></a>
 | |
| <pre>12   If a type specifier of the form
 | |
|                   struct-or-union attribute-specifier-sequenceopt identifier
 | |
|      occurs other than as part of one of the above forms, and no other declaration of the identifier as a
 | |
|      tag is visible, then it declares an incomplete structure or union type, and declares the identifier as
 | |
|      the tag of that type.<a href='#FOOTNOTE.159'><sup>[159]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.159'>
 | |
| <pre><i><b>Footnote 159)</b> A similar construction with enum does not exist.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.3p13'></a>
 | |
| <pre>13   If a type specifier of the form
 | |
|                   struct-or-union attribute-specifier-sequenceopt identifier
 | |
|      or
 | |
|                   enum identifier
 | |
|      occurs other than as part of one of the above forms, and a declaration of the identifier as a tag is
 | |
|      visible, then it specifies the same type as that other declaration, and does not redeclare the tag.
 | |
| </pre>
 | |
| <a name='6.7.2.3p14'></a>
 | |
| <pre>14   EXAMPLE 3 This mechanism allows declaration of a self-referential structure.
 | |
| 
 | |
|                struct tnode {
 | |
|                      int count;
 | |
|                      struct tnode *left, *right;
 | |
|                };
 | |
| 
 | |
| 
 | |
|      specifies a structure that contains an integer and two pointers to objects of the same type. Once this declaration has been
 | |
|      given, the declaration
 | |
| 
 | |
|                struct tnode s, *sp;
 | |
| 
 | |
| 
 | |
|      declares s to be an object of the given type and sp to be a pointer to an object of the given type. With these declarations, the
 | |
|      expression sp->left refers to the left struct tnode pointer of the object to which sp points; the expression s.right->count
 | |
|      designates the count member of the right struct tnode pointed to from s.
 | |
| </pre>
 | |
| <a name='6.7.2.3p15'></a>
 | |
| <pre>15   The following alternative formulation uses the typedef mechanism:
 | |
| 
 | |
|                typedef struct tnode TNODE;
 | |
|                struct tnode {
 | |
|                      int count;
 | |
|                      TNODE *left, *right;
 | |
|                };
 | |
|                TNODE s, *sp;
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.3p16'></a>
 | |
| <pre>16   EXAMPLE 4 To illustrate the use of prior declaration of a tag to specify a pair of mutually referential structures, the
 | |
|      declarations
 | |
| 
 | |
|                struct s1 { struct s2 *s2p; /* ... */ }; // D1
 | |
|                struct s2 { struct s1 *s1p; /* ... */ }; // D2
 | |
| 
 | |
| 
 | |
|      specify a pair of structures that contain pointers to each other. Note, however, that if s2 were already declared as a tag in an
 | |
|      enclosing scope, the declaration D1 would refer to it, not to the tag s2 declared in D2. To eliminate this context sensitivity, the
 | |
|      declaration
 | |
| 
 | |
|                struct s2;
 | |
| 
 | |
| 
 | |
|      can be inserted ahead of D1. This declares a new tag s2 in the inner scope; the declaration D2 then completes the specification
 | |
|      of the new type.
 | |
| 
 | |
|      Forward references: declarators (<a href='#6.7.6'>6.7.6</a>), type definitions (<a href='#6.7.8'>6.7.8</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.4'></a>
 | |
| <hr>
 | |
| <h3>6.7.2.4 [Atomic type specifiers]</h3>
 | |
| <a name='6.7.2.4p1'></a>
 | |
| <pre>1 Syntax
 | |
|      atomic-type-specifier:
 | |
|                          _Atomic ( type-name )
 | |
| 
 | |
| 
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.7.2.4p2'></a>
 | |
| <pre>2    Atomic type specifiers shall not be used if the implementation does not support atomic types (see
 | |
|      <a href='#6.10.9.3'>6.10.9.3</a>).
 | |
| </pre>
 | |
| <a name='6.7.2.4p3'></a>
 | |
| <pre>3    The type name in an atomic type specifier shall not refer to an array type, a function type, an atomic
 | |
|      type, or a qualified type.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.7.2.4p4'></a>
 | |
| <pre>4    The properties associated with atomic types are meaningful only for expressions that are lvalues.
 | |
|      If the _Atomic keyword is immediately followed by a left parenthesis, it is interpreted as a type
 | |
|      specifier (with a type name), not as a type qualifier.
 | |
| </pre>
 | |
| <a name='6.7.2.5'></a>
 | |
| <hr>
 | |
| <h3>6.7.2.5 [Typeof specifiers]</h3>
 | |
| <a name='6.7.2.5p1'></a>
 | |
| <pre>1 Syntax
 | |
|     typeof-specifier:
 | |
|                             typeof ( typeof-specifier-argument )
 | |
|                             typeof_unqual ( typeof-specifier-argument )
 | |
|     typeof-specifier-argument:
 | |
|                          expression
 | |
|                          type-name
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.5p2'></a>
 | |
| <pre>2   The typeof and typeof_unqual tokens are collectively called the typeof operators.
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.7.2.5p3'></a>
 | |
| <pre>3   The typeof operators shall not be applied to an expression that designates a bit-field member.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.2.5p4'></a>
 | |
| <pre>4   The typeof specifier applies the typeof operators to an expression (<a href='#6.5'>6.5</a>) or a type name. If the typeof
 | |
|     operators are applied to an expression, they yield the type-name representing the type of their
 | |
|     operand<a href='#FOOTNOTE.160'><sup>[160]</sup></a> . Otherwise, they produce the type name with any nested typeof specifier evaluated<a href='#FOOTNOTE.161'><sup>[161]</sup></a> .
 | |
|     If the type of the operand is a variably modified type, the operand is evaluated; otherwise, the
 | |
|     operand is not evaluated.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.160'>
 | |
| <pre><i><b>Footnote 160)</b> When applied to a parameter declared to have array or function type, the typeof operators yield the adjusted (pointer)
 | |
|     type (see <a href='#6.9.1'>6.9.1</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.161'>
 | |
| <pre><i><b>Footnote 161)</b> If the typeof specifier argument is itself a typeof specifier, the operand will be evaluated before evaluating the current
 | |
|     typeof operation. This happens recursively until a typeof specifier is no longer the operand.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.5p5'></a>
 | |
| <pre>5   All qualifiers (<a href='#6.7.3'>6.7.3</a>) on the type from the result of a typeof_unqual operation are removed, including
 | |
|     the _Atomic qualifier<a href='#FOOTNOTE.162'><sup>[162]</sup></a> . Otherwise, for typeof operations, all qualifiers are preserved.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.162'>
 | |
| <pre><i><b>Footnote 162)</b> _Atomic ( type-name ) , with parentheses, is considered an _Atomic -qualified type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.2.5p6'></a>
 | |
| <pre>6   EXAMPLE 1 Type of an expression.
 | |
| 
 | |
|       typeof(1+1) main () {
 | |
|             return 0;
 | |
|       }
 | |
| 
 | |
| 
 | |
|     is equivalent to this program:
 | |
| 
 | |
|       int main () {
 | |
|             return 0;
 | |
|       }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.5p7'></a>
 | |
| <pre>7   EXAMPLE 2 The following program:
 | |
| 
 | |
|       const _Atomic int purr = 0;
 | |
|       const int meow = 1;
 | |
|       const char* const mew[] = {
 | |
|             "aardvark",
 | |
|             "bluejay",
 | |
|             "catte",
 | |
|       };
 | |
| 
 | |
|       typeof_unqual(meow) main (int argc, char* argv[]) {
 | |
|             typeof_unqual(purr)          plain_purr;
 | |
|             typeof( Atomic typeof(meow)) atomic_meow;
 | |
|                    _
 | |
|             typeof(mew)                  mew_array;
 | |
|             typeof_unqual(mew)           mew2_array;
 | |
|             return 0;
 | |
|       }
 | |
|      is equivalent to this program:
 | |
| 
 | |
|        const _Atomic int purr = 0;
 | |
|        const int meow = 1;
 | |
|        const char* const mew[] = {
 | |
|              "aardvark",
 | |
|              "bluejay",
 | |
|              "catte",
 | |
|        };
 | |
| 
 | |
|        int main (int argc, char* argv[]) {
 | |
|              int               plain_purr;
 | |
|              const _Atomic int atomic_meow;
 | |
|              const char* const mew_array[3];
 | |
|              const char*       mew2_array[3];
 | |
|              return 0;
 | |
|        }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.5p8'></a>
 | |
| <pre>8    EXAMPLE 3 The equivalence between sizeof and typeof’s deduction of the type means this program has no constraint
 | |
|      violations:
 | |
| 
 | |
|        int main (int argc, char* argv[]) {
 | |
|              static_assert(sizeof(typeof(’p’)) == sizeof(int));
 | |
|              static_assert(sizeof(typeof(’p’)) == sizeof(’p’));
 | |
|              static_assert(sizeof(typeof((char)’p’)) == sizeof(char));
 | |
|              static_assert(sizeof(typeof((char)’p’)) == sizeof((char)’p’));
 | |
|              static_assert(sizeof(typeof("meow")) == sizeof(char[5]));
 | |
|              static_assert(sizeof(typeof("meow")) == sizeof("meow"));
 | |
|              static_assert(sizeof(typeof(argc)) == sizeof(int));
 | |
|              static_assert(sizeof(typeof(argc)) == sizeof(argc));
 | |
|              static_assert(sizeof(typeof(argv)) == sizeof(char**));
 | |
|              static_assert(sizeof(typeof(argv)) == sizeof(argv));
 | |
| 
 | |
|                static_assert(sizeof(typeof_unqual(’p’)) == sizeof(int));
 | |
|                static_assert(sizeof(typeof_unqual(’p’)) == sizeof(’p’));
 | |
|                static_assert(sizeof(typeof_unqual((char)’p’)) == sizeof(char));
 | |
|                static_assert(sizeof(typeof_unqual((char)’p’)) == sizeof((char)’p’));
 | |
|                static_assert(sizeof(typeof_unqual("meow")) == sizeof(char[5]));
 | |
|                static_assert(sizeof(typeof_unqual("meow")) == sizeof("meow"));
 | |
|                static_assert(sizeof(typeof_unqual(argc)) == sizeof(int));
 | |
|                static_assert(sizeof(typeof_unqual(argc)) == sizeof(argc));
 | |
|                static_assert(sizeof(typeof_unqual(argv)) == sizeof(char**));
 | |
|                static_assert(sizeof(typeof_unqual(argv)) == sizeof(argv));
 | |
|                return 0;
 | |
|        }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.5p9'></a>
 | |
| <pre>9    EXAMPLE 4 The following program with nested typeof(...):
 | |
| 
 | |
|        int main (int argc, char*[]) {
 | |
|              float val = <a href='#6.'>6.</a>0f;
 | |
|              return (typeof(typeof_unqual(typeof(argc))))val;
 | |
|        }
 | |
| 
 | |
| 
 | |
|      is equivalent to this program:
 | |
| 
 | |
|        int main (int argc, char*[]) {
 | |
|              float val = <a href='#6.'>6.</a>0f;
 | |
|              return (int)val;
 | |
|        }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.5p10'></a>
 | |
| <pre>10   EXAMPLE 5 Variable length arrays with typeof operators performs the operation at execution time rather than translation
 | |
|      time.
 | |
|       #include <stddef.h>
 | |
| 
 | |
|       size_t vla_size (int n) {
 | |
|             typedef char vla_type[n + 3];
 | |
|             vla_type b; // variable length array
 | |
|             return sizeof(
 | |
|                   typeof_unqual(b)
 | |
|             ); // execution-time sizeof, translation-time typeof operation
 | |
|       }
 | |
| 
 | |
|       int main () {
 | |
|             return (int)vla_size(10); // vla_size returns 13
 | |
|       }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.5p11'></a>
 | |
| <pre>11   EXAMPLE 6 Nested typeof operators, arrays, and pointers do not perform array to pointer decay.
 | |
| 
 | |
|       int main () {
 | |
|             typeof(typeof(const char*)[4]) y = {
 | |
|                   "a",
 | |
|                   "b",
 | |
|                   "c",
 | |
|                   "d"
 | |
|             }; // 4-element array of "pointer to const char"
 | |
|             return 0;
 | |
|       }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.2.5p12'></a>
 | |
| <pre>12   EXAMPLE 7 Function, pointer, and array types may be substituted with typeof operations.
 | |
| 
 | |
|       void f(int);
 | |
| 
 | |
|       typeof(f(5)) g(double x) {                    // g has type "void(double)"
 | |
|             printf("value %g\n", x);
 | |
|       }
 | |
| 
 | |
|       typeof(g)* h;                                 // h has type "void(*)(double)"
 | |
|       typeof(true ? g : NULL) k;                    // k has type "void(*)(double)"
 | |
| 
 | |
|       void j(double A[5], typeof(A)* B); // j has type "void(double*, double**)"
 | |
| 
 | |
|       extern typeof(double[]) D;                    // D has an incomplete type
 | |
|       typeof(D) C = { 0.7, 99 };                    // C has type "double[2]"
 | |
| 
 | |
|       typeof(D) D = { 5, 8.9, 0.1, 99 }; // D is now completed to "double[4]"
 | |
|       typeof(D) E;                       // E has type "double[4]" from D’s completed type
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.3'></a>
 | |
| <hr>
 | |
| <h3>6.7.3 [Type qualifiers]</h3>
 | |
| <a name='6.7.3p1'></a>
 | |
| <pre>1 Syntax
 | |
|      type-qualifier:
 | |
|                            const
 | |
|                            restrict
 | |
|                            volatile
 | |
|                            _Atomic
 | |
| 
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.7.3p2'></a>
 | |
| <pre>2    Types other than pointer types whose referenced type is an object type and (possibly multi-
 | |
|      dimensional) array types with such pointer types as element type shall not be restrict-qualified.
 | |
| </pre>
 | |
| <a name='6.7.3p3'></a>
 | |
| <pre>3    The _Atomic qualifier shall not be used if the implementation does not support atomic types
 | |
|      (see <a href='#6.10.9.3'>6.10.9.3</a>).
 | |
| </pre>
 | |
| <a name='6.7.3p4'></a>
 | |
| <pre>4    The type modified by the _Atomic qualifier shall not be an array type or a function type.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.7.3p5'></a>
 | |
| <pre>5    The properties associated with qualified types are meaningful only for expressions that are lval-
 | |
|      ues.<a href='#FOOTNOTE.163'><sup>[163]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.163'>
 | |
| <pre><i><b>Footnote 163)</b> The implementation can place a const object that is not volatile in a read-only region of storage. Moreover, the
 | |
|      implementation need not allocate storage for such an object if its address is never used.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.3p6'></a>
 | |
| <pre>6    If the same qualifier appears more than once in the same specifier-qualifier list or as declaration
 | |
|      specifiers, either directly, via one or more typeof specifiers, or via one or more typedefs, the behavior
 | |
|      is the same as if it appeared only once. If other qualifiers appear along with the _Atomic qualifier
 | |
|      the resulting type is the so-qualified atomic type.
 | |
| </pre>
 | |
| <a name='6.7.3p7'></a>
 | |
| <pre>7    If an attempt is made to modify an object defined with a const-qualified type through use of an
 | |
|      lvalue with non-const-qualified type, the behavior is undefined. If an attempt is made to refer to an
 | |
|      object defined with a volatile-qualified type through use of an lvalue with non-volatile-qualified
 | |
|      type, the behavior is undefined<a href='#FOOTNOTE.164'><sup>[164]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.164'>
 | |
| <pre><i><b>Footnote 164)</b> This applies to those objects that behave as if they were defined with qualified types, even if they are never actually
 | |
|      defined as objects in the program (such as an object at a memory-mapped input/output address).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.3p8'></a>
 | |
| <pre>8    An object that has volatile-qualified type may be modified in ways unknown to the implementation
 | |
|      or have other unknown side effects. Therefore any expression referring to such an object shall be
 | |
|      evaluated strictly according to the rules of the abstract machine, as described in <a href='#5.1.2.3'>5.1.2.3</a>. Furthermore,
 | |
|      at every sequence point the value last stored in the object shall agree with that prescribed by the
 | |
|      abstract machine, except as modified by the unknown factors mentioned previously.<a href='#FOOTNOTE.165'><sup>[165]</sup></a> What
 | |
|      constitutes an access to an object that has volatile-qualified type is implementation-defined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.165'>
 | |
| <pre><i><b>Footnote 165)</b> A volatile declaration can be used to describe an object corresponding to a memory-mapped input/output port or an
 | |
|      object accessed by an asynchronously interrupting function. Actions on objects so declared are not allowed to be "optimized
 | |
|      out" by an implementation or reordered except as permitted by the rules for evaluating expressions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.3p9'></a>
 | |
| <pre>9    An object that is accessed through a restrict-qualified pointer has a special association with that
 | |
|      pointer. This association, defined in <a href='#6.7.3.1'>6.7.3.1</a> below, requires that all accesses to that object use, directly
 | |
|      or indirectly, the value of that particular pointer.<a href='#FOOTNOTE.166'><sup>[166]</sup></a> The intended use of the restrict qualifier (like
 | |
|      the register storage class) is to promote optimization, and deleting all instances of the qualifier
 | |
|      from all preprocessing translation units composing a conforming program does not change its
 | |
|      meaning (i.e., observable behavior).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.166'>
 | |
| <pre><i><b>Footnote 166)</b> For example, a statement that assigns a value returned by malloc to a single pointer establishes this association between
 | |
|      the allocated object and the pointer.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.3p10'></a>
 | |
| <pre>10   If the specification of an array type includes any type qualifiers, both the array and the element type
 | |
|      is so-qualified. If the specification of a function type includes any type qualifiers, the behavior is
 | |
|      undefined.<a href='#FOOTNOTE.167'><sup>[167]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.167'>
 | |
| <pre><i><b>Footnote 167)</b> This can occur through the use of typedef s. Note that this rule does not apply to the _Atomic qualifier, and that
 | |
|      qualifiers do not have any direct effect on the array type itself, but affect conversion rules for pointer types that reference an
 | |
|      array type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.3p11'></a>
 | |
| <pre>11   For two qualified types to be compatible, both shall have the identically qualified version of a
 | |
|      compatible type; the order of type qualifiers within a list of specifiers or qualifiers does not affect the
 | |
|      specified type.
 | |
| </pre>
 | |
| <a name='6.7.3p12'></a>
 | |
| <pre>12   EXAMPLE 1 An object declared
 | |
| 
 | |
|                extern const volatile int real_time_clock;
 | |
| 
 | |
| 
 | |
|      might be modifiable by hardware, but cannot be assigned to, incremented, or decremented.
 | |
| </pre>
 | |
| <a name='6.7.3p13'></a>
 | |
| <pre>13   EXAMPLE 2 The following declarations and expressions illustrate the behavior when type qualifiers modify an aggregate
 | |
|      type:
 | |
| 
 | |
|                const struct s { int mem; } cs = { 1 };
 | |
|                struct s ncs; // the object ncs is modifiable
 | |
|                typedef int A[2][3];
 | |
|                const A a = {{4, 5, 6}, {7, 8, 9}}; // array of array of const int
 | |
|                int *pi;
 | |
|                const int *pci;
 | |
| 
 | |
|                ncs = cs;      // valid
 | |
|                cs = ncs;      // violates modifiable lvalue constraint for =
 | |
|                pi = &ncs.mem; // valid
 | |
|                pi = &cs.mem; // violates type constraints for =
 | |
|                pci = &cs.mem; // valid
 | |
|                pi = a[0];     // invalid: a[0] has type "const int *"
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.3p14'></a>
 | |
| <pre>14   EXAMPLE 3 The declaration
 | |
| 
 | |
|                _Atomic volatile int *p;
 | |
| 
 | |
| 
 | |
|      specifies that p has the type "pointer to volatile atomic int", a pointer to a volatile-qualified atomic type.
 | |
| </pre>
 | |
| <a name='6.7.3.1'></a>
 | |
| <hr>
 | |
| <h3>6.7.3.1 [Formal definition of restrict]</h3>
 | |
| <a name='6.7.3.1p1'></a>
 | |
| <pre>1   Let D be a declaration of an ordinary identifier that provides a means of designating an object P as a
 | |
|     restrict-qualified pointer to type T.
 | |
| </pre>
 | |
| <a name='6.7.3.1p2'></a>
 | |
| <pre>2   If D appears inside a block and does not have storage class extern, let B denote the block. If D
 | |
|     appears in the list of parameter declarations of a function definition, let B denote the associated block.
 | |
|     Otherwise, let B denote the block of main (or the block of whatever function is called at program
 | |
|     startup in a freestanding environment).
 | |
| </pre>
 | |
| <a name='6.7.3.1p3'></a>
 | |
| <pre>3   In what follows, a pointer expression E is said to be based on object P if (at some sequence point in
 | |
|     the execution of B prior to the evaluation of E) modifying P to point to a copy of the array object into
 | |
|     which it formerly pointed would change the value of E.<a href='#FOOTNOTE.168'><sup>[168]</sup></a> Note that "based" is defined only for
 | |
|     expressions with pointer types.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.168'>
 | |
| <pre><i><b>Footnote 168)</b> In other words, E depends on the value of P itself rather than on the value of an object referenced indirectly through P.
 | |
|     For example, if identifier p has type (int **restrict) , then the pointer expressions p and p+1 are based on the restricted
 | |
|     pointer object designated by p, but the pointer expressions *p and p[1] are not.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.3.1p4'></a>
 | |
| <pre>4   During each execution of B, let L be any lvalue that has &L based on P. If L is used to access the
 | |
|     value of the object X that it designates, and X is also modified (by any means), then the following
 | |
|     requirements apply: T shall not be const-qualified. Every other lvalue used to access the value of
 | |
|     X shall also have its address based on P. Every access that modifies X shall be considered also to
 | |
|     modify P, for the purposes of this subclause. If P is assigned the value of a pointer expression E that
 | |
|     is based on another restricted pointer object P2, associated with block B2, then either the execution
 | |
|     of B2 shall begin before the execution of B, or the execution of B2 shall end prior to the assignment.
 | |
|     If these requirements are not met, then the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.7.3.1p5'></a>
 | |
| <pre>5   Here an execution of B means that portion of the execution of the program that would correspond to
 | |
|     the lifetime of an object with scalar type and automatic storage duration associated with B.
 | |
| </pre>
 | |
| <a name='6.7.3.1p6'></a>
 | |
| <pre>6   A translator is free to ignore any or all aliasing implications of uses of restrict.
 | |
| </pre>
 | |
| <a name='6.7.3.1p7'></a>
 | |
| <pre>7   EXAMPLE 1 The file scope declarations
 | |
| 
 | |
|               int * restrict a;
 | |
|               int * restrict b;
 | |
|               extern int c[];
 | |
| 
 | |
|     assert that if an object is accessed using one of a, b, or c, and that object is modified anywhere in the program, then it is never
 | |
|     accessed using either of the other two.
 | |
| </pre>
 | |
| <a name='6.7.3.1p8'></a>
 | |
| <pre>8   EXAMPLE 2 The function parameter declarations in the following example
 | |
| 
 | |
|               void f(int n, int * restrict p, int * restrict q)
 | |
|               {
 | |
|                     while (n-- > 0)
 | |
|                           *p++ = *q++;
 | |
|               }
 | |
| 
 | |
|     assert that, during each execution of the function, if an object is accessed through one of the pointer parameters, then it is not
 | |
|     also accessed through the other. The translator can make this no-aliasing inference based on the parameter declarations alone,
 | |
|     without analyzing the function body.
 | |
| </pre>
 | |
| <a name='6.7.3.1p9'></a>
 | |
| <pre>9   The benefit of the restrict qualifiers is that they enable a translator to make an effective dependence analysis of function f
 | |
|     without examining any of the calls of f in the program. The cost is that the programmer has to examine all of those calls to
 | |
|     ensure that none give undefined behavior. For example, the second call of f in g has undefined behavior because each of
 | |
|     d[1] through d[49] is accessed through both p and q.
 | |
| 
 | |
|               void g(void)
 | |
|               {
 | |
|                     extern int d[100];
 | |
|                     f(50, d + 50, d); // valid
 | |
|                     f(50, d + 1, d); // undefined behavior
 | |
|               }
 | |
| </pre>
 | |
| <a name='6.7.3.1p10'></a>
 | |
| <pre>10   EXAMPLE 3 The function parameter declarations
 | |
| 
 | |
|                void h(int n, int * restrict p, int * restrict q, int * restrict r)
 | |
|                {
 | |
|                      int i;
 | |
|                      for (i = 0; i < n; i++)
 | |
|                            p[i] = q[i] + r[i];
 | |
|                }
 | |
| 
 | |
|      illustrate how an unmodified object can be aliased through two restricted pointers. In particular, if a and b are disjoint arrays,
 | |
|      a call of the form h(100, a, b, b) has defined behavior, because array b is not modified within function h.
 | |
| </pre>
 | |
| <a name='6.7.3.1p11'></a>
 | |
| <pre>11   EXAMPLE 4 The rule limiting assignments between restricted pointers does not distinguish between a function call and
 | |
|      an equivalent nested block. With one exception, only "outer-to-inner" assignments between restricted pointers declared in
 | |
|      nested blocks have defined behavior.
 | |
| 
 | |
|                {
 | |
|                         int * restrict p1;
 | |
|                         int * restrict q1;
 | |
|                         p1 = q1; // undefined behavior
 | |
|                         {
 | |
|                               int * restrict p2 = p1; // valid
 | |
|                               int * restrict q2 = q1; // valid
 | |
|                               p1 = q2;                // undefined behavior
 | |
|                               p2 = q2;                // undefined behavior
 | |
|                         }
 | |
|                }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.3.1p12'></a>
 | |
| <pre>12 The one exception allows the value of a restricted pointer to be carried out of the block in which it (or, more precisely, the
 | |
|     ordinary identifier used to designate it) is declared when that block finishes execution. For example, this permits new_vector
 | |
|     to return a vector.
 | |
| 
 | |
|                typedef struct { int n; float * restrict v; } vector;
 | |
|                vector new_vector(int n)
 | |
|                {
 | |
|                      vector t;
 | |
|                      t.n = n;
 | |
|                      t.v = malloc(n * sizeof (float));
 | |
|                      return t;
 | |
|                }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.3.1p13'></a>
 | |
| <pre>13   EXAMPLE 5 Suppose that a programmer knows that references of the form p[i] and q[j] are never aliases in the body of a
 | |
|      function:
 | |
| 
 | |
|                void f(int n, int *p, int *q) { /* ... */ }
 | |
| 
 | |
|      There are several ways that this information could be conveyed to a translator using the restrict qualifier. Example 2 shows
 | |
|      the most effective way, qualifying all pointer parameters, and can be used provided that neither p nor q becomes based on
 | |
|      the other in the function body. A potentially effective alternative is:
 | |
| 
 | |
|                void f(int n, int * restrict p, int * const q) { /* ... */ }
 | |
| 
 | |
|      Again it is possible for a translator to make the no-aliasing inference based on the parameter declarations alone, though now
 | |
|      it must use subtler reasoning: that the const-qualification of q precludes it becoming based on p. There is also a requirement
 | |
|      that q is not modified, so this alternative cannot be used for the function in Example 2, as written.
 | |
| </pre>
 | |
| <a name='6.7.3.1p14'></a>
 | |
| <pre>14   EXAMPLE 6 Another potentially effective alternative is:
 | |
| 
 | |
|                void f(int n, int *p, int const * restrict q) { /* ... */ }
 | |
| 
 | |
|      Again it is possible for a translator to make the no-aliasing inference based on the parameter declarations alone, though
 | |
|      now it must use even subtler reasoning: that this combination of restrict and const means that objects referenced using q
 | |
|      cannot be modified, and so no modified object can be referenced using both p and q.
 | |
| </pre>
 | |
| <a name='6.7.3.1p15'></a>
 | |
| <pre>15   EXAMPLE 7 The least effective alternative is:
 | |
| 
 | |
|                void f(int n, int * restrict p, int *q) { /* ... */ }
 | |
| 
 | |
|      Here the translator can make the no-aliasing inference only by analyzing the body of the function and proving that q cannot
 | |
|      become based on p. Some translator designs may choose to exclude this analysis, given availability of the more effective
 | |
|      alternatives above. Such a translator is required to assume that aliases are present because assuming that aliases are not
 | |
|      present may result in an incorrect translation. Also, a translator that attempts the analysis may not succeed in all cases and
 | |
|      thus need to conservatively assume that aliases are present.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.4'></a>
 | |
| <hr>
 | |
| <h3>6.7.4 [Function specifiers]</h3>
 | |
| <a name='6.7.4p1'></a>
 | |
| <pre>1 Syntax
 | |
|      function-specifier:
 | |
|                              inline
 | |
|                              _Noreturn
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.7.4p2'></a>
 | |
| <pre>2    Function specifiers shall be used only in the declaration of an identifier for a function.
 | |
| </pre>
 | |
| <a name='6.7.4p3'></a>
 | |
| <pre>3    An inline definition of a function with external linkage shall not contain a definition of a modifiable
 | |
|      object with static or thread storage duration, and shall not contain a reference to an identifier with
 | |
|      internal linkage.
 | |
| </pre>
 | |
| <a name='6.7.4p4'></a>
 | |
| <pre>4    In a hosted environment, no function specifier(s) shall appear in a declaration of main.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.7.4p5'></a>
 | |
| <pre>5    A function specifier may appear more than once; the behavior is the same as if it appeared only
 | |
|      once.
 | |
| </pre>
 | |
| <a name='6.7.4p6'></a>
 | |
| <pre>6    A function declared with an inline function specifier is an inline function. Making a function an
 | |
|      inline function suggests that calls to the function be as fast as possible.<a href='#FOOTNOTE.169'><sup>[169]</sup></a> The extent to which such
 | |
|      suggestions are effective is implementation-defined.<a href='#FOOTNOTE.170'><sup>[170]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.169'>
 | |
| <pre><i><b>Footnote 169)</b> By using, for example, an alternative to the usual function call mechanism, such as "inline substitution". Inline
 | |
|      substitution is not textual substitution, nor does it create a new function. Therefore, for example, the expansion of a macro
 | |
|      used within the body of the function uses the definition it had at the point the function body appears, and not where the
 | |
|      function is called; and identifiers refer to the declarations in scope where the body occurs. Likewise, the function has a single
 | |
|      address, regardless of the number of inline definitions that occur in addition to the external definition.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.170'>
 | |
| <pre><i><b>Footnote 170)</b> For example, an implementation might never perform inline substitution, or might only perform inline substitutions to
 | |
|      calls in the scope of an inline declaration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.4p7'></a>
 | |
| <pre>7    Any function with internal linkage can be an inline function. For a function with external linkage,
 | |
|      the following restrictions apply: If a function is declared with an inline function specifier, then it
 | |
|      shall also be defined in the same translation unit. If all of the file scope declarations for a function in
 | |
|      a translation unit include the inline function specifier without extern, then the definition in that
 | |
|      translation unit is an inline definition. An inline definition does not provide an external definition
 | |
|      for the function, and does not forbid an external definition in another translation unit. An inline
 | |
|      definition provides an alternative to an external definition, which a translator may use to implement
 | |
|      any call to the function in the same translation unit. It is unspecified whether a call to the function
 | |
|      uses the inline definition or the external definition.<a href='#FOOTNOTE.171'><sup>[171]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.171'>
 | |
| <pre><i><b>Footnote 171)</b> Since an inline definition is distinct from the corresponding external definition and from any other corresponding inline
 | |
|      definitions in other translation units, all corresponding objects with static storage duration are also distinct in each of the
 | |
|      definitions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.4p8'></a>
 | |
| <pre>8    A function declared with a _Noreturn function specifier shall not return to its caller. The _Noreturn
 | |
|      function specifier is an obsolescent feature (<a href='#6.7.12.6'>6.7.12.6</a>).
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='6.7.4p9'></a>
 | |
| <pre>9    The implementation should produce a diagnostic message for a function declared with a _Noreturn
 | |
|      function specifier that appears to be capable of returning to its caller.
 | |
| </pre>
 | |
| <a name='6.7.4p10'></a>
 | |
| <pre>10   EXAMPLE 1 The declaration of an inline function with external linkage can result in either an external definition, or a
 | |
|      definition available for use only within the translation unit. A file scope declaration with extern creates an external definition.
 | |
|      The following example shows an entire translation unit.
 | |
|                    inline double fahr(double t)
 | |
|                    {
 | |
|                          return (9.0 * t) / 5.0 + 32.0;
 | |
|                    }
 | |
| 
 | |
|                    inline double cels(double t)
 | |
|                    {
 | |
|                          return (5.0 * (t - 32.0)) / 9.0;
 | |
|                    }
 | |
| 
 | |
|                    extern double fahr(double);               // creates an external definition
 | |
| 
 | |
|                    double convert(int is_fahr, double temp)
 | |
|                    {
 | |
|                          /* A translator may perform inline substitutions */
 | |
|                          return is_fahr ? cels(temp): fahr(temp);
 | |
|                    }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.4p11'></a>
 | |
| <pre>11 Note that the definition of fahr is an external definition because fahr is also declared with extern, but the definition of cels
 | |
|    is an inline definition. Because cels has external linkage and is referenced, an external definition has to appear in another
 | |
|    translation unit (see <a href='#6.9'>6.9</a>); the inline definition and the external definition are distinct and either can be used for the call.
 | |
| 
 | |
|     Forward references: function definitions (<a href='#6.9.1'>6.9.1</a>).
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.5'></a>
 | |
| <hr>
 | |
| <h3>6.7.5 [Alignment specifier]</h3>
 | |
| <a name='6.7.5p1'></a>
 | |
| <pre>1 Syntax
 | |
|         alignment-specifier:
 | |
|                                 alignas ( type-name )
 | |
|                                 alignas ( constant-expression )
 | |
| 
 | |
| 
 | |
|         Constraints
 | |
| </pre>
 | |
| <a name='6.7.5p2'></a>
 | |
| <pre>2       An alignment specifier shall appear only in the declaration specifiers of a declaration, or in the
 | |
|         specifier-qualifier list of a member declaration, or in the type name of a compound literal. An
 | |
|         alignment specifier shall not be used in conjunction with either of the storage-class specifiers
 | |
|         typedef or register, nor in a declaration of a function or bit-field.
 | |
| </pre>
 | |
| <a name='6.7.5p3'></a>
 | |
| <pre>3       The constant expression shall be an integer constant expression. It shall evaluate to a valid funda-
 | |
|         mental alignment, or to a valid extended alignment supported by the implementation for an object
 | |
|         of the storage duration (if any) being declared, or to zero.
 | |
| </pre>
 | |
| <a name='6.7.5p4'></a>
 | |
| <pre>4       An object shall not be declared with an over-aligned type with an extended alignment requirement
 | |
|         not supported by the implementation for an object of that storage duration.
 | |
| </pre>
 | |
| <a name='6.7.5p5'></a>
 | |
| <pre>5       The combined effect of all alignment specifiers in a declaration shall not specify an alignment that is
 | |
|         less strict than the alignment that would otherwise be required for the type of the object or member
 | |
|         being declared.
 | |
| 
 | |
|         Semantics
 | |
| </pre>
 | |
| <a name='6.7.5p6'></a>
 | |
| <pre>6       The first form is equivalent to alignas(alignof( type-name)).
 | |
| </pre>
 | |
| <a name='6.7.5p7'></a>
 | |
| <pre>7       The alignment requirement of the declared object or member is taken to be the specified alignment.
 | |
|         An alignment specification of zero has no effect.<a href='#FOOTNOTE.172'><sup>[172]</sup></a> When multiple alignment specifiers occur in a
 | |
|         declaration, the effective alignment requirement is the strictest specified alignment.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.172'>
 | |
| <pre><i><b>Footnote 172)</b> An alignment specification of zero also does not affect other alignment specifications in the same declaration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.5p8'></a>
 | |
| <pre>8       If the definition of an object has an alignment specifier, any other declaration of that object shall
 | |
|         either specify equivalent alignment or have no alignment specifier. If the definition of an object does
 | |
|         not have an alignment specifier, any other declaration of that object shall also have no alignment
 | |
|         specifier. If declarations of an object in different translation units have different alignment specifiers,
 | |
|     the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.6'></a>
 | |
| <hr>
 | |
| <h3>6.7.6 [Declarators]</h3>
 | |
| <a name='6.7.6p1'></a>
 | |
| <pre>1 Syntax
 | |
|     declarator:
 | |
|                             pointeropt direct-declarator
 | |
| 
 | |
|      direct-declarator:
 | |
|                             identifier attribute-specifier-sequenceopt
 | |
|                             ( declarator )
 | |
|                             array-declarator attribute-specifier-sequenceopt
 | |
|                             function-declarator attribute-specifier-sequenceopt
 | |
| 
 | |
|      array-declarator:
 | |
|                             direct-declarator [ type-qualifier-listopt assignment-expressionopt ]
 | |
|                             direct-declarator [ static type-qualifier-listopt assignment-expression ]
 | |
|                             direct-declarator [ type-qualifier-list static assignment-expression ]
 | |
|                             direct-declarator [ type-qualifier-listopt * ]
 | |
| 
 | |
|      function-declarator:
 | |
|                         direct-declarator ( parameter-type-listopt )
 | |
| 
 | |
|      pointer:
 | |
|                             * attribute-specifier-sequenceopt type-qualifier-listopt
 | |
|                             * attribute-specifier-sequenceopt type-qualifier-listopt pointer
 | |
|      type-qualifier-list:
 | |
|                         type-qualifier
 | |
|                         type-qualifier-list type-qualifier
 | |
|      parameter-type-list:
 | |
|                         parameter-list
 | |
|                         parameter-list , ...
 | |
|                             ...
 | |
|      parameter-list:
 | |
|                         parameter-declaration
 | |
|                         parameter-list , parameter-declaration
 | |
|      parameter-declaration:
 | |
|                         attribute-specifier-sequenceopt declaration-specifiers declarator
 | |
|                         attribute-specifier-sequenceopt declaration-specifiers abstract-declaratoropt
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.6p2'></a>
 | |
| <pre>2   Each declarator declares one identifier, and asserts that when an operand of the same form as
 | |
|     the declarator appears in an expression, it designates a function or object with the scope, storage
 | |
|     duration, and type indicated by the declaration specifiers.
 | |
| </pre>
 | |
| <a name='6.7.6p3'></a>
 | |
| <pre>3   A full declarator is a declarator that is not part of another declarator. If, in the nested sequence of
 | |
|     declarators in a full declarator, there is a declarator specifying a variable length array type, the type
 | |
|     specified by the full declarator is said to be variably modified. Furthermore, any type derived by
 | |
|     declarator type derivation from a variably modified type is itself variably modified.
 | |
| </pre>
 | |
| <a name='6.7.6p4'></a>
 | |
| <pre>4   In the following subclauses, consider a declaration
 | |
|                 T D1
 | |
|     where T contains the declaration specifiers that specify a type T (such as int) and D1 is a declarator
 | |
|     that contains an identifier ident. The type specified for the identifier ident in the various forms of
 | |
|     declarator is described inductively using this notation.
 | |
| </pre>
 | |
| <a name='6.7.6p5'></a>
 | |
| <pre>5   If, in the declaration "T D1", D1 has the form
 | |
|                     identifier attribute-specifier-sequenceopt
 | |
|         then the type specified for ident is T and the optional attribute specifier sequence appertains to the
 | |
|         entity that is declared.
 | |
| </pre>
 | |
| <a name='6.7.6p6'></a>
 | |
| <pre>6       If, in the declaration "T D1", D1 has the form
 | |
|                     (D )
 | |
|         then ident has the type specified by the declaration "T D". Thus, a declarator in parentheses is
 | |
|         identical to the unparenthesized declarator, but the binding of complicated declarators may be
 | |
|         altered by parentheses.
 | |
| 
 | |
|         Implementation limits
 | |
| </pre>
 | |
| <a name='6.7.6p7'></a>
 | |
| <pre>7       As discussed in <a href='#5.2.4.1'>5.2.4.1</a>, an implementation may limit the number of pointer, array, and function
 | |
|         declarators that modify an arithmetic, structure, union, or void type, either directly or via one or
 | |
|         more typedef s.
 | |
|         Forward references: array declarators (<a href='#6.7.6.2'>6.7.6.2</a>), type definitions (<a href='#6.7.8'>6.7.8</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.6.1'></a>
 | |
| <hr>
 | |
| <h3>6.7.6.1 [Pointer declarators]</h3>
 | |
| <a name='6.7.6.1p1'></a>
 | |
| <pre>1 Semantics
 | |
|        If, in the declaration "T D1", D1 has the form
 | |
|                     * attribute-specifier-sequenceopt type-qualifier-listopt D
 | |
|         and the type specified for ident in the declaration "T D" is "derived-declarator-type-list T", then the
 | |
|         type specified for ident is "derived-declarator-type-list type-qualifier-list pointer to T". For each type
 | |
|         qualifier in the list, ident is a so-qualified pointer. The optional attribute specifier sequence appertains
 | |
|         to the pointer and not the object pointed to.
 | |
| </pre>
 | |
| <a name='6.7.6.1p2'></a>
 | |
| <pre>2       For two pointer types to be compatible, both shall be identically qualified and both shall be pointers
 | |
|         to compatible types.
 | |
| </pre>
 | |
| <a name='6.7.6.1p3'></a>
 | |
| <pre>3       EXAMPLE The following pair of declarations demonstrates the difference between a "variable pointer to a constant value"
 | |
|         and a "constant pointer to a variable value".
 | |
| 
 | |
|                   const int *ptr_to_constant;
 | |
|                   int *const constant_ptr;
 | |
| 
 | |
| 
 | |
|         The contents of any object pointed to by ptr_to_constant cannot be modified through that pointer, but ptr_to_constant
 | |
|         itself can be changed to point to another object. Similarly, the contents of the int pointed to by constant_ptr can be
 | |
|         modified, but constant_ptr itself always points to the same location.
 | |
|     4   The declaration of the constant pointer constant_ptr can be clarified by including a definition for the type "pointer to int".
 | |
| 
 | |
|                   typedef int *int_ptr;
 | |
|                   const int_ptr constant_ptr;
 | |
| 
 | |
| 
 | |
|         declares constant_ptr as an object that has type "const-qualified pointer to int".
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.6.2'></a>
 | |
| <hr>
 | |
| <h3>6.7.6.2 [Array declarators]</h3>
 | |
| <a name='6.7.6.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|        In addition to optional type qualifiers and the keyword static, the [ and ] may delimit an expres-
 | |
|         sion or * . If they delimit an expression (which specifies the size of an array), the expression shall
 | |
|         have an integer type. If the expression is a constant expression, it shall have a value greater than
 | |
|         zero. The element type shall not be an incomplete or function type. The optional type qualifiers and
 | |
|         the keyword static shall appear only in a declaration of a function parameter with an array type,
 | |
|         and then only in the outermost array type derivation.
 | |
| </pre>
 | |
| <a name='6.7.6.2p2'></a>
 | |
| <pre>2       If an identifier is declared as having a variably modified type, it shall be an ordinary identifier (as
 | |
|         defined in <a href='#6.2.3'>6.2.3</a>), have no linkage, and have either block scope or function prototype scope. If an
 | |
|         identifier is declared to be an object with static or thread storage duration, it shall not have a variable
 | |
|         length array type.
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.6.2p3'></a>
 | |
| <pre>3   If, in the declaration "T D1", D1 has one of the forms:
 | |
|                   D [ type-qualifier-listopt assignment-expressionopt ] attribute-specifier-sequenceopt
 | |
|                   D [ static type-qualifier-listopt assignment-expression ] attribute-specifier-sequenceopt
 | |
|                   D [ type-qualifier-list static assignment-expression         ] attribute-specifier-sequenceopt
 | |
|                   D [ type-qualifier-listopt * ] attribute-specifier-sequenceopt
 | |
|     and the type specified for ident in the declaration "T D" is "derived-declarator-type-list T", then the
 | |
|     type specified for ident is "derived-declarator-type-list array of T".<a href='#FOOTNOTE.173'><sup>[173]</sup></a><a href='#FOOTNOTE.174'><sup>[174]</sup></a> The optional attribute specifier
 | |
|     sequence appertains to the array. (See <a href='#6.7.6.3'>6.7.6.3</a> for the meaning of the optional type qualifiers and the
 | |
|     keyword static.)
 | |
| </pre>
 | |
| <a name='FOOTNOTE.173'>
 | |
| <pre><i><b>Footnote 173)</b> When several "array of" specifications are adjacent, a multidimensional array is declared.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.174'>
 | |
| <pre><i><b>Footnote 174)</b> The array is considered identically qualified to T according to <a href='#6.2.5'>6.2.5</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.6.2p4'></a>
 | |
| <pre>4   If the size is not present, the array type is an incomplete type. If the size is * instead of being an
 | |
|     expression, the array type is a variable length array type of unspecified size, which can only be used in
 | |
|     declarations or type names with function prototype scope<a href='#FOOTNOTE.175'><sup>[175]</sup></a> ; such arrays are nonetheless complete
 | |
|     types. If the size is an integer constant expression and the element type has a known constant
 | |
|     size, the array type is not a variable length array type; otherwise, the array type is a variable length
 | |
|     array type. (Variable length arrays with automatic storage duration are a conditional feature that
 | |
|     implementations need not support; see <a href='#6.10.9.3'>6.10.9.3</a>.)
 | |
| </pre>
 | |
| <a name='FOOTNOTE.175'>
 | |
| <pre><i><b>Footnote 175)</b> Thus,
 | |
|                  * can be used only in function declarations that are not definitions (see <a href='#6.7.6.3'>6.7.6.3</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.6.2p5'></a>
 | |
| <pre>5   If the size is an expression that is not an integer constant expression: if it occurs in a declaration at
 | |
|     function prototype scope, it is treated as if it were replaced by * ; otherwise, each time it is evaluated
 | |
|     it shall have a value greater than zero. The size of each instance of a variable length array type does
 | |
|     not change during its lifetime. Where a size expression is part of the operand of a typeof or sizeof
 | |
|     operator and changing the value of the size expression would not affect the result of the operator, it
 | |
|     is unspecified whether or not the size expression is evaluated. Where a size expression is part of the
 | |
|     operand of an alignof operator, that expression is not evaluated.
 | |
| </pre>
 | |
| <a name='6.7.6.2p6'></a>
 | |
| <pre>6   For two array types to be compatible, both shall have compatible element types, and if both size
 | |
|     specifiers are present, and are integer constant expressions, then both size specifiers shall have
 | |
|     the same constant value. If the two array types are used in a context which requires them to be
 | |
|     compatible, it is undefined behavior if the two size specifiers evaluate to unequal values.
 | |
| </pre>
 | |
| <a name='6.7.6.2p7'></a>
 | |
| <pre>7   EXAMPLE 1
 | |
| 
 | |
|                  float fa[11], *afp[17];
 | |
| 
 | |
|     declares an array of float numbers and an array of pointers to float numbers.
 | |
| </pre>
 | |
| <a name='6.7.6.2p8'></a>
 | |
| <pre>8   EXAMPLE 2 Note the distinction between the declarations
 | |
| 
 | |
|                  extern int *x;
 | |
|                  extern int y[];
 | |
| 
 | |
|     The first declares x to be a pointer to int; the second declares y to be an array of int of unspecified size (an incomplete type),
 | |
|     the storage for which is defined elsewhere.
 | |
| </pre>
 | |
| <a name='6.7.6.2p9'></a>
 | |
| <pre>9   EXAMPLE 3 The following declarations demonstrate the compatibility rules for variably modified types.
 | |
| 
 | |
|                  extern int n;
 | |
|                  extern int m;
 | |
| 
 | |
|                  void fcompat(void)
 | |
|                  {
 | |
|                        int a[n][6][m];
 | |
|                        int (*p)[4][n+1];
 | |
|                        int c[n][n][6][m];
 | |
|                        int (*r)[n][n][n+1];
 | |
|                        p = a;      // invalid: not compatible because 4 != 6
 | |
|                        r = c;      // compatible, but defined behavior only if
 | |
|                                         // n == 6 and m == n+1
 | |
|                }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.6.2p10'></a>
 | |
| <pre>10   EXAMPLE 4 All declarations of variably modified (VM) types have to be at either block scope or function prototype scope.
 | |
|      Array objects declared with the thread_local, static, or extern storage-class specifier cannot have a variable length array
 | |
|      (VLA) type. However, an object declared with the static storage-class specifier can have a VM type (that is, a pointer to a
 | |
|      VLA type). Finally, all identifiers declared with a VM type have to be ordinary identifiers and cannot, therefore, be members
 | |
|      of structures or unions.
 | |
| 
 | |
|                extern int n;
 | |
|                int A[n];                                         // invalid: file scope VLA
 | |
|                extern int (*p2)[n];                              // invalid: file scope VM
 | |
|                int B[100];                                       // valid: file scope but not VM
 | |
| 
 | |
|                void fvla(int m, int C[m][m]);                    // valid:       VLA with prototype scope
 | |
| 
 | |
|                void fvla(int m, int C[m][m])                     // valid:       adjusted to auto pointer to VLA
 | |
|                {
 | |
|                      typedef int VLA[m][m];                      // valid:       block scope typedef VLA
 | |
| 
 | |
|                        struct tag {
 | |
|                              int (*y)[n];                        // invalid:       y not ordinary identifier
 | |
|                              int z[n];                           // invalid:       z not ordinary identifier
 | |
|                        };
 | |
|                        int D[m];                                 // valid: auto VLA
 | |
|                        static int E[m];                          // invalid: static block scope VLA
 | |
|                        extern int F[m];                          // invalid: F has linkage and is VLA
 | |
|                        int (*s)[m];                              // valid: auto pointer to VLA
 | |
|                        extern int (*r)[m];                       // invalid: r has linkage and points to VLA
 | |
|                        static int (*q)[m] = &B;                  // valid: q is a static block pointer to VLA
 | |
|                }
 | |
| 
 | |
| 
 | |
|      Forward references: function declarators (<a href='#6.7.6.3'>6.7.6.3</a>), function definitions (<a href='#6.9.1'>6.9.1</a>), initialization (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.6.3'></a>
 | |
| <hr>
 | |
| <h3>6.7.6.3 [Function declarators]</h3>
 | |
| <a name='6.7.6.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|     A function declarator shall not specify a return type that is a function type or an array type.
 | |
| </pre>
 | |
| <a name='6.7.6.3p2'></a>
 | |
| <pre>2    The only storage-class specifier that shall occur in a parameter declaration is register.
 | |
| </pre>
 | |
| <a name='6.7.6.3p3'></a>
 | |
| <pre>3    After adjustment, the parameters in a parameter type list in a function declarator that is part of a
 | |
|      definition of that function shall not have incomplete type.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.7.6.3p4'></a>
 | |
| <pre>4    If, in the declaration "T D1", D1 has the form
 | |
|               D ( parameter-type-listopt ) attribute-specifier-sequenceopt
 | |
|      and the type specified for ident in the declaration "T D" is "derived-declarator-type-list T", then the
 | |
|      type specified for ident is "derived-declarator-type-list function returning the unqualified version of T".
 | |
|      The optional attribute specifier sequence appertains to the function type.
 | |
| </pre>
 | |
| <a name='6.7.6.3p5'></a>
 | |
| <pre>5    A parameter type list specifies the types of, and may declare identifiers for, the parameters of the
 | |
|      function.
 | |
| </pre>
 | |
| <a name='6.7.6.3p6'></a>
 | |
| <pre>6    A declaration of a parameter as "array of type" shall be adjusted to "qualified pointer to type", where
 | |
|      the type qualifiers (if any) are those specified within the [ and ] of the array type derivation. If the
 | |
|      keyword static also appears within the [ and ] of the array type derivation, then for each call to
 | |
|      the function, the value of the corresponding actual argument shall provide access to the first element
 | |
|      of an array with at least as many elements as specified by the size expression.
 | |
| </pre>
 | |
| <a name='6.7.6.3p7'></a>
 | |
| <pre>7    A declaration of a parameter as "function returning type" shall be adjusted to "pointer to function
 | |
|      returning type", as in <a href='#6.3.2.1'>6.3.2.1</a>.
 | |
| </pre>
 | |
| <a name='6.7.6.3p8'></a>
 | |
| <pre>8    If the list terminates with an ellipsis (...), no information about the number or types of the
 | |
|      parameters after the comma is supplied. <a href='#FOOTNOTE.176'><sup>[176]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.176'>
 | |
| <pre><i><b>Footnote 176)</b> The macros defined in the <stdarg.h> header (<a href='#7.16'>7.16</a>) can be used to access arguments that correspond to the ellipsis.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.6.3p9'></a>
 | |
| <pre>9    The special case of an unnamed parameter of type void as the only item in the list specifies that the
 | |
|      function has no parameters.
 | |
| </pre>
 | |
| <a name='6.7.6.3p10'></a>
 | |
| <pre>10   If, in a parameter declaration, an identifier can be treated either as a typedef name or as a parameter
 | |
|      name, it shall be taken as a typedef name.
 | |
| </pre>
 | |
| <a name='6.7.6.3p11'></a>
 | |
| <pre>11   If the function declarator is not part of a definition of that function, parameters may have incomplete
 | |
|      type and may use the [*] notation in their sequences of declarator specifiers to specify variable
 | |
|      length array types.
 | |
| </pre>
 | |
| <a name='6.7.6.3p12'></a>
 | |
| <pre>12   The storage class specifier in the declaration specifiers for a parameter declaration, if present, is
 | |
|      ignored unless the declared parameter is one of the members of the parameter type list for a function
 | |
|      definition. The optional attribute specifier sequence in a parameter declaration appertains to the
 | |
|      parameter.
 | |
| </pre>
 | |
| <a name='6.7.6.3p13'></a>
 | |
| <pre>13   For a function declarator without a parameter type list: the effect is as if it were declared with a
 | |
|      parameter type list consisting of the keyword void. A function declarator provides a prototype for
 | |
|      the function<a href='#FOOTNOTE.177'><sup>[177]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.177'>
 | |
| <pre><i><b>Footnote 177)</b> This implies that a function definition without a parameter list provides a prototype, and that subsequent calls to that
 | |
|      function in the same translation unit are constrained not to provide any argument to the function call. Thus a definition of a
 | |
|      function without parameter list and one that has such a list consisting of the keyword void are fully equivalent.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.6.3p14'></a>
 | |
| <pre>14   For two function types to be compatible, both shall specify compatible return types. Moreover,
 | |
|      the parameter type lists shall agree in the number of parameters and in use of the final ellipsis;
 | |
|      corresponding parameters shall have compatible types. In the determination of type compatibility
 | |
|      and of a composite type, each parameter declared with function or array type is taken as having the
 | |
|      adjusted type and each parameter declared with qualified type is taken as having the unqualified
 | |
|      version of its declared type.
 | |
| </pre>
 | |
| <a name='6.7.6.3p15'></a>
 | |
| <pre>15   EXAMPLE 1 The declaration
 | |
| 
 | |
|                int f(void), *fip(), (*pfi)();
 | |
| 
 | |
| 
 | |
|      declares a function f with no parameters returning an int, a function fip with no parameters returning a pointer to an int,
 | |
|      and a pointer pfi to a function with no parameters returning an int. It is especially useful to compare the last two. The
 | |
|      binding of *fip() is *(fip()) , so that the declaration suggests, and the same construction in an expression requires, the
 | |
|      calling of a function fip, and then using indirection through the pointer result to yield an int. In the declarator (*pfi)() ,
 | |
|      the extra parentheses are necessary to indicate that indirection through a pointer to a function yields a function designator,
 | |
|      which is then used to call the function; it returns an int.
 | |
| </pre>
 | |
| <a name='6.7.6.3p16'></a>
 | |
| <pre>16 If the declaration occurs outside of any function, the identifiers have file scope and external linkage. If the declaration
 | |
|    occurs inside a function, the identifiers of the functions f and fip have block scope and either internal or external linkage
 | |
|    (depending on what file scope declarations for these identifiers are visible), and the identifier of the pointer pfi has block
 | |
|    scope and no linkage.
 | |
| </pre>
 | |
| <a name='6.7.6.3p17'></a>
 | |
| <pre>17   EXAMPLE 2 The declaration
 | |
| 
 | |
|                int (*apfi[3])(int *x, int *y);
 | |
| 
 | |
| 
 | |
|      declares an array apfi of three pointers to functions returning int. Each of these functions has two parameters that are
 | |
|      pointers to int. The identifiers x and y are declared for descriptive purposes only and go out of scope at the end of the
 | |
|      declaration of apfi.
 | |
| </pre>
 | |
| <a name='6.7.6.3p18'></a>
 | |
| <pre>18   EXAMPLE 3 The declaration
 | |
| 
 | |
|                int (*fpfi(int (*)(long), int))(int, ...);
 | |
| 
 | |
| 
 | |
|      declares a function fpfi that returns a pointer to a function returning an int. The function fpfi has two parameters: a
 | |
|      pointer to a function returning an int (with one parameter of type long int), and an int. The pointer returned by fpfi
 | |
|      points to a function that has one int parameter and accepts zero or more additional arguments of any type.
 | |
| </pre>
 | |
| <a name='6.7.6.3p19'></a>
 | |
| <pre>19   EXAMPLE 4 The following prototype has a variably modified parameter.
 | |
| 
 | |
|                void addscalar(int n, int m,
 | |
|                      double a[n][n*m+300], double x);
 | |
|                int main()
 | |
|                {
 | |
|                      double b[4][308];
 | |
|                      addscalar(4, 2, b, 2.17);
 | |
|                      return 0;
 | |
|                }
 | |
| 
 | |
|                void addscalar(int n, int m,
 | |
|                      double a[n][n*m+300], double x)
 | |
|                {
 | |
|                      for (int i = 0; i < n; i++)
 | |
|                            for (int j = 0, k = n*m+300; j < k; j++)
 | |
|                                  // a is a pointer to a VLA with n*m+300 elements
 | |
|                                  a[i][j] += x;
 | |
|                }
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.6.3p20'></a>
 | |
| <pre>20   EXAMPLE 5 The following are all compatible function prototype declarators.
 | |
| 
 | |
|                double maximum(int n, int m, double a[n][m]);
 | |
|                double maximum(int n, int m, double a[*][*]);
 | |
|                double maximum(int n, int m, double a[ ][*]);
 | |
|                double maximum(int n, int m, double a[ ][m]);
 | |
| 
 | |
| 
 | |
| 
 | |
|      as are:
 | |
| 
 | |
|                void f(double (* restrict a)[5]);
 | |
|                void f(double a[restrict][5]);
 | |
|                void f(double a[restrict 3][5]);
 | |
|                void f(double a[restrict static 3][5]);
 | |
| 
 | |
| 
 | |
| 
 | |
|      (Note that the last declaration also specifies that the argument corresponding to a in any call to f can be expected to be a
 | |
|      non-null pointer to the first of at least three arrays of 5 doubles, which the others do not.)
 | |
| 
 | |
|      Forward references: function definitions (<a href='#6.9.1'>6.9.1</a>), type names (<a href='#6.7.7'>6.7.7</a>).
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.7'></a>
 | |
| <hr>
 | |
| <h3>6.7.7 [Type names]</h3>
 | |
| <a name='6.7.7p1'></a>
 | |
| <pre>1 Syntax
 | |
|      type-name:
 | |
|                           specifier-qualifier-list abstract-declaratoropt
 | |
|       abstract-declarator:
 | |
|                           pointer
 | |
|                           pointeropt direct-abstract-declarator
 | |
|       direct-abstract-declarator:
 | |
|                           ( abstract-declarator )
 | |
|                           array-abstract-declarator attribute-specifier-sequenceopt
 | |
|                           function-abstract-declarator attribute-specifier-sequenceopt
 | |
|       array-abstract-declarator:
 | |
|                           direct-abstract-declaratoropt [ type-qualifier-listopt assignment-expressionopt ]
 | |
|                           direct-abstract-declaratoropt [ static type-qualifier-listopt assignment-expression ]
 | |
|                           direct-abstract-declaratoropt [ type-qualifier-list static assignment-expression ]
 | |
|                           direct-abstract-declaratoropt [ * ]
 | |
| 
 | |
|       function-abstract-declarator:
 | |
|                          direct-abstract-declaratoropt ( parameter-type-listopt )
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.7p2'></a>
 | |
| <pre>2   In several contexts, it is necessary to specify a type. This is accomplished using a type name, which is
 | |
|     syntactically a declaration for a function or an object of that type that omits the identifier.<a href='#FOOTNOTE.178'><sup>[178]</sup></a> The
 | |
|     optional attribute specifier sequence in a direct abstract declarator appertains to the preceding array
 | |
|     or function type. The attribute specifier sequence affects the type only for the declaration it appears
 | |
|     in, not other declarations involving the same type.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.178'>
 | |
| <pre><i><b>Footnote 178)</b> As indicated by the syntax, empty parentheses in a type name are interpreted as "function with no parameter specifica-
 | |
|     tion", rather than redundant parentheses around the omitted identifier.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.7p3'></a>
 | |
| <pre>3   EXAMPLE The constructions
 | |
| 
 | |
|               (a)           int
 | |
|               (b)           int *
 | |
|               (c)           int *[3]
 | |
|               (d)           int (*)[3]
 | |
|               (e)           int (*)[*]
 | |
|               (f)           int *()
 | |
|               (g)           int (*)(void)
 | |
|               (h)           int (*const [])(unsigned int, ...)
 | |
| 
 | |
|     name respectively the types (a) int, (b) pointer to int, (c) array of three pointers to int, (d) pointer to an array of three
 | |
|     int s, (e) pointer to a variable length array of an unspecified number of int s, (f) function with no parameters returning
 | |
|     a pointer to int, (g) pointer to function with no parameters returning an int, and (h) array of an unspecified number of
 | |
|     constant pointers to functions, each with one parameter that has type unsigned int and an unspecified number of other
 | |
|     parameters, returning an int.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.8'></a>
 | |
| <hr>
 | |
| <h3>6.7.8 [Type definitions]</h3>
 | |
| <a name='6.7.8p1'></a>
 | |
| <pre>1 Syntax
 | |
|     typedef-name:
 | |
|                            identifier
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.7.8p2'></a>
 | |
| <pre>2   If a typedef name specifies a variably modified type then it shall have block scope.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.8p3'></a>
 | |
| <pre>3   In a declaration whose storage-class specifier is typedef, each declarator defines an identifier to
 | |
|     be a typedef name that denotes the type specified for the identifier in the way described in <a href='#6.7.6'>6.7.6</a>.
 | |
|     Any array size expressions associated with variable length array declarators are evaluated each time
 | |
|     the declaration of the typedef name is reached in the order of execution. A typedef declaration
 | |
|     does not introduce a new type, only a synonym for the type so specified. That is, in the following
 | |
|     declarations:
 | |
| 
 | |
|               typedef T type_ident;
 | |
|               type_ident D;
 | |
| 
 | |
| 
 | |
|     type_ident is defined as a typedef name with the type specified by the declaration specifiers in T
 | |
|     (known as T), and the identifier in D has the type "derived-declarator-type-list T" where the derived-
 | |
|     declarator-type-list is specified by the declarators of D. A typedef name shares the same name space
 | |
|     as other identifiers declared in ordinary declarators. If the identifier is redeclared in an enclosed
 | |
|     block the inner declaration shall not be such that the type is inferred (<a href='#6.7.9'>6.7.9</a>).
 | |
| </pre>
 | |
| <a name='6.7.8p4'></a>
 | |
| <pre>4   EXAMPLE 1 After
 | |
| 
 | |
|               typedef int MILES, KLICKSP();
 | |
|               typedef struct { double hi, lo; } range;
 | |
| 
 | |
|     the constructions
 | |
|               MILES distance;
 | |
|               extern KLICKSP *metricp;
 | |
|               range x;
 | |
|               range z, *zp;
 | |
| 
 | |
| 
 | |
|     are all valid declarations. The type of distance is int, that of metricp is "pointer to function with no parameters returning
 | |
|     int", and that of x and z is the specified structure; zp is a pointer to such a structure. The object distance has a type
 | |
|     compatible with any other int object.
 | |
| </pre>
 | |
| <a name='6.7.8p5'></a>
 | |
| <pre>5   EXAMPLE 2 After the declarations
 | |
| 
 | |
|               typedef struct s1 { int x; } t1, *tp1;
 | |
|               typedef struct s2 { int x; } t2, *tp2;
 | |
| 
 | |
| 
 | |
|     type t1 and the type pointed to by tp1 are compatible. Type t1 is also compatible with type struct s1, but not compatible
 | |
|     with the types struct s2, t2, the type pointed to by tp2, or int.
 | |
| </pre>
 | |
| <a name='6.7.8p6'></a>
 | |
| <pre>6   EXAMPLE 3 The following obscure constructions
 | |
| 
 | |
|               typedef signed int t;
 | |
|               typedef int plain;
 | |
|               struct tag {
 | |
|                     unsigned t:4;
 | |
|                     const t:5;
 | |
|                     plain r:5;
 | |
|               };
 | |
| 
 | |
| 
 | |
|     declare a typedef name t with type signed int, a typedef name plain with type int, and a structure with three bit-field
 | |
|     members, one named t that contains values in the range [0, 15], an unnamed const-qualified bit-field which (if it could
 | |
|     be accessed) would contain values in either the range [−15, +15] or [−16, +15], and one named r that contains values in
 | |
|     one of the ranges [0, 31], [−15, +15], or [−16, +15]. (The choice of range is implementation-defined.) The first two bit-field
 | |
|     declarations differ in that unsigned is a type specifier (which forces t to be the name of a structure member), while const is
 | |
|     a type qualifier (which modifies t which is still visible as a typedef name). If these declarations are followed in an inner scope
 | |
|     by
 | |
| 
 | |
|               t f(t (t));
 | |
|               long t;
 | |
| 
 | |
| 
 | |
|     then a function f is declared with type "function returning signed int with one unnamed parameter with type pointer
 | |
|     to function returning signed int with one unnamed parameter with type signed int", and an identifier t with type
 | |
|     long int.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.8p7'></a>
 | |
| <pre>7   EXAMPLE 4 On the other hand, typedef names can be used to improve code readability. All three of the following
 | |
|     declarations of the signal function specify exactly the same type, the first without making use of any typedef names.
 | |
| 
 | |
|               typedef void fv(int), (*pfv)(int);
 | |
| 
 | |
|               void (*signal(int, void (*)(int)))(int);
 | |
|               fv *signal(int, fv *);
 | |
|               pfv signal(int, pfv);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.8p8'></a>
 | |
| <pre>8   EXAMPLE 5 If a typedef name denotes a variable length array type, the length of the array is fixed at the time the typedef
 | |
|     name is defined, not each time it is used:
 | |
| 
 | |
|               void copyt(int n)
 | |
|               {
 | |
|                     typedef int B[n];   // B is n ints, n evaluated now
 | |
|                     n += 1;
 | |
|                     B a;                // a is n ints, n without += 1
 | |
|                     int b[n];           // a and b are different sizes
 | |
|                     for (int i = 1; i < n; i++)
 | |
|                           a[i-1] = b[i];
 | |
|               }
 | |
| </pre>
 | |
| <a name='6.7.9'></a>
 | |
| <hr>
 | |
| <h3>6.7.9 [Type inference]</h3>
 | |
| <a name='6.7.9p1'></a>
 | |
| <pre>1 Constraints
 | |
|    A declaration for which the type is inferred shall contain the storage-class specifier auto.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.7.9p2'></a>
 | |
| <pre>2   For such a declaration that is the definition of an object the init-declarator shall have one of the forms
 | |
|                   direct-declarator = assignment-expression
 | |
|                   direct-declarator = { assignment-expression }
 | |
|                   direct-declarator = { assignment-expression , }
 | |
| 
 | |
|     The declared type is the type of the assignment expression after lvalue, array to pointer or function
 | |
|     to pointer conversion, additionally qualified by qualifiers and amended by attributes as they appear
 | |
|     in the declaration specifiers, if any<a href='#FOOTNOTE.179'><sup>[179]</sup></a> . If the direct declarator is not of the form
 | |
|                   identifier attribute-specifier-sequenceopt
 | |
|     , possibly enclosed in balanced pairs of parentheses, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.179'>
 | |
| <pre><i><b>Footnote 179)</b> The scope rules as described in <a href='#6.2.1'>6.2.1</a> also prohibit the use of the identifier of the declarator within the assignment
 | |
|     expression.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.9p3'></a>
 | |
| <pre>3   NOTE Such a declaration that also defines a structure or union type violates a constraint. Here, the identifier a which is not
 | |
|     ordinary but in the name space of the structure type is declared.
 | |
| 
 | |
|               auto p = (struct { int a; } *)0;
 | |
| 
 | |
|     Even a forward declaration of a structure tag
 | |
| 
 | |
|               struct s;
 | |
|               auto p = (struct s { int a; } *)0;
 | |
| 
 | |
|     would not change that situation. A direct use of the structure definition as the type specifier ensures the validity of the
 | |
|     declaration.
 | |
| 
 | |
|               struct s { int a; } * p = 0;
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.9p4'></a>
 | |
| <pre>4   EXAMPLE 1 Consider the following file scope definitions:
 | |
| 
 | |
|               static auto a = <a href='#3.5'>3.5</a>;
 | |
|               auto p = &a;
 | |
| 
 | |
|     They are interpreted as if they had been written as:
 | |
| 
 | |
|               static double a = <a href='#3.5'>3.5</a>;
 | |
|               double * p = &a;
 | |
| 
 | |
|     So effectively a is a double and p is a double*. Note that the restrictions on the syntax of such declarations does not allow the
 | |
|     declarator to be *p , but that the final type here nevertheless is a pointer type.
 | |
| </pre>
 | |
| <a name='6.7.9p5'></a>
 | |
| <pre>5   EXAMPLE 2 The scope of the identifier for which the type is inferred only starts after the end of the initializer (<a href='#6.2.1'>6.2.1</a>), so
 | |
|     the assignment expression cannot use the identifier to refer to the object or function that is declared, for example to take its
 | |
|     address. Any use of the identifier in the initializer is invalid, even if an entity with the same name exists in an outer scope.
 | |
| 
 | |
|               {
 | |
|                        double a = 7;
 | |
|                        double b = 9;
 | |
|                        {
 | |
|                              double b = b * b;     // undefined, uses uninitialized
 | |
|                                                    // variable without address
 | |
|                                 printf("%g\n", a); // valid, uses "a" from outer scope, prints 7
 | |
|                                 auto a   = a * a; // invalid, "a" from outer scope is already
 | |
|                                     shadowed
 | |
|                        }
 | |
|                          {
 | |
|                                 auto b   = a * a; // valid, uses "a" from outer scope
 | |
|                                 auto a   = b;      // valid, shadows "a" from outer scope
 | |
|                                 // ...
 | |
|                                 printf("%g\n", a); // valid, uses "a" from inner scope, prints 49
 | |
|                          }
 | |
|                          // ...
 | |
|               }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.9p6'></a>
 | |
| <pre>6   EXAMPLE 3 In the following, declarations of pA and qA are valid. The type of A after array-to-pointer conversion is a pointer
 | |
|     type, and qA is a pointer to array.
 | |
| 
 | |
|               double A[3] = { 0 };
 | |
|               auto pA = A;
 | |
|               auto qA = &A;
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.9p7'></a>
 | |
| <pre>7   EXAMPLE 4 Type inference can be used to capture the type of a call to a type-generic function. It ensures that the same type
 | |
|     as the argument x is used.
 | |
| 
 | |
|                          #include <tgmath.h>
 | |
|                          auto y = cos(x);
 | |
| 
 | |
|     If instead the type of y is explicitly specified to a different type than x, a diagnosis of the mismatch is not enforced.
 | |
| </pre>
 | |
| <a name='6.7.9p8'></a>
 | |
| <pre>8   EXAMPLE 5 A type-generic macro that generalizes the div functions (<a href='#7.24.6.2'>7.24.6.2</a>) is defined and used as follows.
 | |
| 
 | |
|               #define div(X, Y) _Generic((X)+(Y), int: div, long: ldiv, long long: lldiv)((X),
 | |
|                   (Y))
 | |
|               auto z = div(x, y);
 | |
|               auto q = z.quot;
 | |
|               auto r = z.rem;
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.9p9'></a>
 | |
| <pre>9   EXAMPLE 6 Definitions of objects with inferred type are valid in all contexts that allow the initializer syntax as described.
 | |
|     In particular they can be used to ensure type safety of for-loop controlling expressions.
 | |
| 
 | |
|               for (auto i = j; i < 2*j; ++i) {
 | |
|                     // ...
 | |
|               }
 | |
| 
 | |
|     Here, regardless of the integer rank or signedness of the type of j, i will have the non-atomic unqualified type of j. So, after
 | |
|     lvalue conversion and possible promotion, the two operands of the < operator in the controlling expression are guaranteed to
 | |
|     have the same type, and, in particular, the same signedness.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.10'></a>
 | |
| <hr>
 | |
| <h3>6.7.10 [Initialization]</h3>
 | |
| <a name='6.7.10p1'></a>
 | |
| <pre>1 Syntax
 | |
|     braced-initializer:
 | |
|                              { }
 | |
|                              { initializer-list }
 | |
|                              { initializer-list , }
 | |
| 
 | |
| 
 | |
|     initializer:
 | |
|                              assignment-expression
 | |
|                              braced-initializer
 | |
| 
 | |
|      initializer-list:
 | |
|                              designationopt initializer
 | |
|                              initializer-list , designationopt initializer
 | |
| 
 | |
|      designation:
 | |
|                              designator-list =
 | |
|       designator-list:
 | |
|                             designator
 | |
|                             designator-list designator
 | |
|       designator:
 | |
|                             [ constant-expression ]
 | |
|                             . identifier
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.10p2'></a>
 | |
| <pre>2    An empty brace pair ({}) is called an empty initializer and is referred to as empty initialization.
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.7.10p3'></a>
 | |
| <pre>3    No initializer shall attempt to provide a value for an object not contained within the entity being
 | |
|      initialized.
 | |
| </pre>
 | |
| <a name='6.7.10p4'></a>
 | |
| <pre>4    The type of the entity to be initialized shall be an array of unknown size or a complete object type.
 | |
|      An entity of variable length array type shall not be initialized except by an empty initializer. An
 | |
|      array of unknown size shall not be initialized by an empty initializer.
 | |
| </pre>
 | |
| <a name='6.7.10p5'></a>
 | |
| <pre>5    All the expressions in an initializer for an object that has static or thread storage duration or is
 | |
|      declared with the constexpr storage-class specifier shall be constant expressions or string literals.
 | |
| </pre>
 | |
| <a name='6.7.10p6'></a>
 | |
| <pre>6    If the declaration of an identifier has block scope, and the identifier has external or internal linkage,
 | |
|      the declaration shall have no initializer for the identifier.
 | |
| </pre>
 | |
| <a name='6.7.10p7'></a>
 | |
| <pre>7    If a designator has the form
 | |
|                 [ constant-expression ]
 | |
|      then the current object (defined below) shall have array type and the expression shall be an integer
 | |
|      constant expression. If the array is of unknown size, any nonnegative value is valid.
 | |
| </pre>
 | |
| <a name='6.7.10p8'></a>
 | |
| <pre>8    If a designator has the form
 | |
|                 . identifier
 | |
|      then the current object (defined below) shall have structure or union type and the identifier shall be
 | |
|      the name of a member of that type.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.7.10p9'></a>
 | |
| <pre>9    An initializer specifies the initial value stored in an object. For objects with atomic type additional
 | |
|      restrictions apply, see <a href='#7.17.2'>7.17.2</a> and <a href='#7.17.8'>7.17.8</a>.
 | |
| </pre>
 | |
| <a name='6.7.10p10'></a>
 | |
| <pre>10   Except where explicitly stated otherwise, for the purposes of this subclause unnamed members
 | |
|      of objects of structure and union type do not participate in initialization. Unnamed members of
 | |
|      structure objects have indeterminate representation even after initialization.
 | |
| </pre>
 | |
| <a name='6.7.10p11'></a>
 | |
| <pre>11   If an object that has automatic storage duration is initialized with an empty initializer, its value
 | |
|      is the same as the initialization of a static storage duration object. Otherwise, if an object that has
 | |
|      automatic storage duration is not initialized explicitly, its representation is indeterminate. If an
 | |
|      object that has static or thread storage duration is not initialized explicitly, or is initialized with an
 | |
|      empty initializer, then default initialization:
 | |
| 
 | |
|        — if it has pointer type, it is initialized to a null pointer;
 | |
| 
 | |
|        — if it has decimal floating type, it is initialized to (positive or unsigned) zero, and the quantum
 | |
|          exponent is implementation-defined<a href='#FOOTNOTE.180'><sup>[180]</sup></a> ;
 | |
| 
 | |
|        — if it has arithmetic type, and it does not have decimal floating type, it is initialized to (positive
 | |
|          or unsigned) zero;
 | |
| 
 | |
|        — if it is an aggregate, every member is initialized (recursively) according to these rules, and any
 | |
|          padding is initialized to zero bits;
 | |
|         — if it is a union, the first named member is initialized (recursively) according to these rules, and
 | |
|           any padding is initialized to zero bits;
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.180'>
 | |
| <pre><i><b>Footnote 180)</b> A representation with all bits zero results in a decimal floating-point zero with the most negative exponent.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.10p12'></a>
 | |
| <pre>12   The initializer for a scalar shall be a single expression, optionally enclosed in braces, or it shall be
 | |
|      an empty initializer. If the initializer is the empty initializer, the initial value is the same as the
 | |
|      initialization of a static storage duration object. Otherwise, the initial value of the object is that of the
 | |
|      expression (after conversion); the same type constraints and conversions as for simple assignment
 | |
|      apply, taking the type of the scalar to be the unqualified version of its declared type.
 | |
| </pre>
 | |
| <a name='6.7.10p13'></a>
 | |
| <pre>13   The rest of this subclause deals with initializers for objects that have aggregate or union type.
 | |
| </pre>
 | |
| <a name='6.7.10p14'></a>
 | |
| <pre>14   The initializer for a structure or union object that has automatic storage duration shall be either
 | |
|      an initializer list as described below, or a single expression that has compatible structure or union
 | |
|      type. In the latter case, the initial value of the object, including unnamed members, is that of the
 | |
|      expression.
 | |
| </pre>
 | |
| <a name='6.7.10p15'></a>
 | |
| <pre>15   An array of character type may be initialized by a character string literal or UTF-8 string literal,
 | |
|      optionally enclosed in braces. Successive bytes of the string literal (including the terminating null
 | |
|      character if there is room or if the array is of unknown size) initialize the elements of the array.
 | |
| </pre>
 | |
| <a name='6.7.10p16'></a>
 | |
| <pre>16   An array with element type compatible with a qualified or unqualified version of wchar_t, char16_t,
 | |
|      or char32_t may be initialized by a wide string literal with the corresponding encoding prefix (L,
 | |
|      u, or U, respectively), optionally enclosed in braces. Successive wide characters of the wide string
 | |
|      literal (including the terminating null wide character if there is room or if the array is of unknown
 | |
|      size) initialize the elements of the array.
 | |
| </pre>
 | |
| <a name='6.7.10p17'></a>
 | |
| <pre>17   Otherwise, the initializer for an object that has aggregate or union type shall be a brace-enclosed list
 | |
|      of initializers for the elements or named members.
 | |
| </pre>
 | |
| <a name='6.7.10p18'></a>
 | |
| <pre>18   Each brace-enclosed initializer list has an associated current object. When no designations are present,
 | |
|      subobjects of the current object are initialized in order according to the type of the current object:
 | |
|      array elements in increasing subscript order, structure members in declaration order, and the first
 | |
|      named member of a union.<a href='#FOOTNOTE.181'><sup>[181]</sup></a> In contrast, a designation causes the following initializer to begin
 | |
|      initialization of the subobject described by the designator. Initialization then continues forward in
 | |
|      order, beginning with the next subobject after that described by the designator.<a href='#FOOTNOTE.182'><sup>[182]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.181'>
 | |
| <pre><i><b>Footnote 181)</b> If the initializer list for a subaggregate or contained union does not begin with a left brace, its subobjects are initialized as
 | |
|      usual, but the subaggregate or contained union does not become the current object: current objects are associated only with
 | |
|      brace-enclosed initializer lists.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.182'>
 | |
| <pre><i><b>Footnote 182)</b> After a union member is initialized, the next object is not the next member of the union; instead, it is the next subobject of
 | |
|      an object containing the union.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.10p19'></a>
 | |
| <pre>19   Each designator list begins its description with the current object associated with the closest sur-
 | |
|      rounding brace pair. Each item in the designator list (in order) specifies a particular member of its
 | |
|      current object and changes the current object for the next designator (if any) to be that member.<a href='#FOOTNOTE.183'><sup>[183]</sup></a>
 | |
|      The current object that results at the end of the designator list is the subobject to be initialized by the
 | |
|      following initializer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.183'>
 | |
| <pre><i><b>Footnote 183)</b> Thus, a designator can only specify a strict subobject of the aggregate or union that is associated with the surrounding
 | |
|      brace pair. Note, too, that each separate designator list is independent.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.10p20'></a>
 | |
| <pre>20   The initialization shall occur in initializer list order, each initializer provided for a particular subobject
 | |
|      overriding any previously listed initializer for the same subobject;<a href='#FOOTNOTE.184'><sup>[184]</sup></a> all subobjects that are not
 | |
|      initialized explicitly shall be initialized implicitly the same as objects that have static storage duration.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.184'>
 | |
| <pre><i><b>Footnote 184)</b> Any initializer for the subobject which is overridden and so not used to initialize that subobject might not be evaluated at
 | |
|      all.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.10p21'></a>
 | |
| <pre>21   If the aggregate or union contains elements or members that are aggregates or unions, these rules
 | |
|      apply recursively to the subaggregates or contained unions. If the initializer of a subaggregate or
 | |
|      contained union begins with a left brace, the initializers enclosed by that brace and its matching right
 | |
|      brace initialize the elements or members of the subaggregate or the contained union. Otherwise, only
 | |
|      enough initializers from the list are taken to account for the elements or members of the subaggregate
 | |
|      or the first member of the contained union; any remaining initializers are left to initialize the next
 | |
|      element or member of the aggregate of which the current subaggregate or contained union is a part.
 | |
| </pre>
 | |
| <a name='6.7.10p22'></a>
 | |
| <pre>22   If there are fewer initializers in a brace-enclosed list than there are elements or members of an
 | |
|      aggregate, or fewer characters in a string literal used to initialize an array of known size than there
 | |
|      are elements in the array, the remainder of the aggregate shall be initialized implicitly the same as
 | |
|      objects that have static storage duration.
 | |
| </pre>
 | |
| <a name='6.7.10p23'></a>
 | |
| <pre>23   If an array of unknown size is initialized, its size is determined by the largest indexed element with
 | |
|      an explicit initializer. The array type is completed at the end of its initializer list.
 | |
| </pre>
 | |
| <a name='6.7.10p24'></a>
 | |
| <pre>24   The evaluations of the initialization list expressions are indeterminately sequenced with respect to
 | |
|      one another and thus the order in which any side effects occur is unspecified.<a href='#FOOTNOTE.185'><sup>[185]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.185'>
 | |
| <pre><i><b>Footnote 185)</b> In particular, the evaluation order need not be the same as the order of subobject initialization.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.10p25'></a>
 | |
| <pre>25   EXAMPLE 1 Provided that <complex.h> has been #included, the declarations
 | |
| 
 | |
|                 int i = <a href='#3.5'>3.5</a>;
 | |
|                 double complex c = 5 + 3 * I;
 | |
| 
 | |
| 
 | |
|      define and initialize i with the value 3 and c with the value 5.0 + i3.0.
 | |
| </pre>
 | |
| <a name='6.7.10p26'></a>
 | |
| <pre>26   EXAMPLE 2 The declaration
 | |
| 
 | |
|                 int x[] = { 1, 3, 5 };
 | |
| 
 | |
| 
 | |
|      defines and initializes x as a one-dimensional array object that has three elements, as no size was specified and there are three
 | |
|      initializers.
 | |
| </pre>
 | |
| <a name='6.7.10p27'></a>
 | |
| <pre>27   EXAMPLE 3 The declaration
 | |
| 
 | |
|                 int y[4][3] = {
 | |
|                       { 1, 3, 5 },
 | |
|                       { 2, 4, 6 },
 | |
|                       { 3, 5, 7 },
 | |
|                 };
 | |
| 
 | |
| 
 | |
|      is a definition with a fully bracketed initialization: 1, 3, and 5 initialize the first row of y (the array object y[0]), namely
 | |
|      y[0][0], y[0][1], and y[0][2]. Likewise the next two lines initialize y[1] and y[2]. The initializer ends early, so y[3] is
 | |
|      initialized with zeros. Precisely the same effect could have been achieved by
 | |
| 
 | |
|                 int y[4][3] = {
 | |
|                       1, 3, 5, 2, 4, 6, 3, 5, 7
 | |
|                 };
 | |
| 
 | |
| 
 | |
|      The initializer for y[0] does not begin with a left brace, so three items from the list are used. Likewise the next three are
 | |
|      taken successively for y[1] and y[2].
 | |
| </pre>
 | |
| <a name='6.7.10p28'></a>
 | |
| <pre>28   EXAMPLE 4 The declaration
 | |
| 
 | |
|                 int z[4][3] = {
 | |
|                       { 1 }, { 2 }, { 3 }, { 4 }
 | |
|                 };
 | |
| 
 | |
| 
 | |
|      initializes the first column of z as specified and initializes the rest with zeros.
 | |
| </pre>
 | |
| <a name='6.7.10p29'></a>
 | |
| <pre>29   EXAMPLE 5 The declaration
 | |
| 
 | |
|                 struct { int a[3], b; } w[] = { { 1 }, 2 };
 | |
| 
 | |
| 
 | |
|      is a definition with an inconsistently bracketed initialization. It defines an array with two element structures: w[0].a[0] is 1
 | |
|      and w[1].a[0] is 2; all the other elements are zero.
 | |
| </pre>
 | |
| <a name='6.7.10p30'></a>
 | |
| <pre>30   EXAMPLE 6 The declaration
 | |
| 
 | |
|                 short q[4][3][2] = {
 | |
|                       { 1 },
 | |
|                       { 2, 3 },
 | |
|                       { 4, 5, 6 }
 | |
|                 };
 | |
|       contains an incompletely but consistently bracketed initialization. It defines a three-dimensional array object: q[0][0][0]
 | |
|       is 1, q[1][0][0] is 2, q[1][0][1] is 3, and 4, 5, and 6 initialize q[2][0][0], q[2][0][1], and q[2][1][0], respectively;
 | |
|       all the rest are zero. The initializer for q[0][0] does not begin with a left brace, so up to six items from the current list
 | |
|       could be used. There is only one, so the values for the remaining five elements are initialized with zero. Likewise, the
 | |
|       initializers for q[1][0] and q[2][0] do not begin with a left brace, so each uses up to six items, initializing their respective
 | |
|       two-dimensional subaggregates. If there had been more than six items in any of the lists, a diagnostic message would have
 | |
|       been issued. The same initialization result could have been achieved by:
 | |
| 
 | |
|                  short q[4][3][2] = {
 | |
|                        1, 0, 0, 0, 0, 0,
 | |
|                        2, 3, 0, 0, 0, 0,
 | |
|                        4, 5, 6
 | |
|                  };
 | |
| 
 | |
|       or by:
 | |
| 
 | |
|                  short q[4][3][2] = {
 | |
|                        {
 | |
|                              { 1 },
 | |
|                        },
 | |
|                        {
 | |
|                              { 2, 3 },
 | |
|                        },
 | |
|                        {
 | |
|                              { 4, 5 },
 | |
|                              { 6 },
 | |
|                        }
 | |
|                  };
 | |
| 
 | |
|       in a fully bracketed form.
 | |
| </pre>
 | |
| <a name='6.7.10p31'></a>
 | |
| <pre>31   Note that the fully bracketed and minimally bracketed forms of initialization are, in general, less likely to cause confusion.
 | |
| </pre>
 | |
| <a name='6.7.10p32'></a>
 | |
| <pre>32    EXAMPLE 7 One form of initialization that completes array types involves typedef names. Given the declaration
 | |
| 
 | |
|                  typedef int A[];         // OK - declared with block scope
 | |
| 
 | |
|       the declaration
 | |
| 
 | |
|                  A a = { 1, 2 }, b = { 3, 4, 5 };
 | |
| 
 | |
|       is identical to
 | |
| 
 | |
|                  int a[] = { 1, 2 }, b[] = { 3, 4, 5 };
 | |
| 
 | |
|       due to the rules for incomplete types.
 | |
| </pre>
 | |
| <a name='6.7.10p33'></a>
 | |
| <pre>33    EXAMPLE 8 The declaration
 | |
| 
 | |
|                  char s[] = "abc", t[3] = "abc";
 | |
| 
 | |
|       defines "plain" char array objects s and t whose elements are initialized with character string literals. This declaration is
 | |
|       identical to
 | |
| 
 | |
|                  char s[] = { ’a’, ’b’, ’c’, ’\0’ },
 | |
|                       t[] = { ’a’, ’b’, ’c’ };
 | |
| 
 | |
|       The contents of the arrays are modifiable. On the other hand, the declaration
 | |
| 
 | |
|                  char *p = "abc";
 | |
| 
 | |
|       defines p with type "pointer to char" and initializes it to point to an object with type "array of char" with length 4 whose
 | |
|       elements are initialized with a character string literal. If an attempt is made to use p to modify the contents of the array, the
 | |
|       behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.7.10p34'></a>
 | |
| <pre>34    EXAMPLE 9 Arrays can be initialized to correspond to the elements of an enumeration by using designators:
 | |
|                enum { member_one, member_two };
 | |
|                const char *nm[] = {
 | |
|                      [member_two] = "member two",
 | |
|                      [member_one] = "member one",
 | |
|                };
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.10p35'></a>
 | |
| <pre>35   EXAMPLE 10 Structure members can be initialized to nonzero values without depending on their order:
 | |
| 
 | |
|                div_t answer = {.quot = 2, .rem = -1 };
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.10p36'></a>
 | |
| <pre>36   EXAMPLE 11 Designators can be used to provide explicit initialization when unadorned initializer lists might be misunder-
 | |
|      stood:
 | |
| 
 | |
|                struct { int a[3], b; } w[] =
 | |
|                      { [0].a = {1}, [1].a[0] = 2 };
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.10p37'></a>
 | |
| <pre>37   EXAMPLE 12
 | |
| 
 | |
|                struct T {
 | |
|                      int k;
 | |
|                      int l;
 | |
|                };
 | |
| 
 | |
|                struct S {
 | |
|                      int i;
 | |
|                      struct T t;
 | |
|                };
 | |
| 
 | |
|                struct T x = {.l = 43, .k = 42, };
 | |
| 
 | |
|                void f(void)
 | |
|                {
 | |
|                      struct S l = { 1, .t = x, .t.l = 41, };
 | |
|                }
 | |
| 
 | |
| 
 | |
|      The value of l.t.k is 42, because implicit initialization does not override explicit initialization.
 | |
| </pre>
 | |
| <a name='6.7.10p38'></a>
 | |
| <pre>38   EXAMPLE 13 Space can be "allocated" from both ends of an array by using a single designator:
 | |
| 
 | |
|                int a[MAX] = {
 | |
|                      1, 3, 5, 7, 9, [MAX-5] = 8, 6, 4, 2, 0
 | |
|                };
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.10p39'></a>
 | |
| <pre>39 In the above, if MAX is greater than ten, there will be some zero-valued elements in the middle; if it is less than ten, some of
 | |
|    the values provided by the first five initializers will be overridden by the second five.
 | |
| </pre>
 | |
| <a name='6.7.10p40'></a>
 | |
| <pre>40   EXAMPLE 14 Any member of a union can be initialized:
 | |
| 
 | |
|                union { /* ... */ } u = {.any_member = 42 };
 | |
| 
 | |
| 
 | |
|      Forward references: common definitions <stddef.h> (<a href='#7.21'>7.21</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.11'></a>
 | |
| <hr>
 | |
| <h3>6.7.11 [Static assertions]</h3>
 | |
| <a name='6.7.11p1'></a>
 | |
| <pre>1 Syntax
 | |
|      static_assert-declaration:
 | |
|                              static_assert ( constant-expression , string-literal ) ;
 | |
|                              static_assert ( constant-expression ) ;
 | |
| 
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.7.11p2'></a>
 | |
| <pre>2    The constant expression shall compare unequal to 0.
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.11p3'></a>
 | |
| <pre>3   The constant expression shall be an integer constant expression. If the value of the constant expres-
 | |
|     sion compares unequal to 0, the declaration has no effect. Otherwise, the constraint is violated and
 | |
|     the implementation shall produce a diagnostic message which should include the text of the string
 | |
|     literal, if present.
 | |
|     Forward references: diagnostics (<a href='#7.2'>7.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12'></a>
 | |
| <hr>
 | |
| <h3>6.7.12 [Attributes]</h3>
 | |
| <a name='6.7.12p1'></a>
 | |
| <pre>1   Attributes specify additional information for various source constructs such as types, variables,
 | |
|     identifiers, or blocks. They are identified by an attribute token, which can either be a attribute prefixed
 | |
|     token (for implementation-specific attributes) or a standard attribute specified by an identifier (for
 | |
|     attributes specified in this document).
 | |
| </pre>
 | |
| <a name='6.7.12p2'></a>
 | |
| <pre>2   Support for any of the standard attributes specified in this document is implementation-defined
 | |
|     and optional. For an attribute token (including an attribute prefixed token) not specified in this
 | |
|     document, the behavior is implementation-defined. Any attribute token that is not supported by the
 | |
|     implementation is ignored.
 | |
| </pre>
 | |
| <a name='6.7.12p3'></a>
 | |
| <pre>3   Attributes are said to appertain to some source construct, identified by the syntactic context where
 | |
|     they appear, and for each individual attribute, the corresponding clause constrains the syntactic
 | |
|     context in which this appertainance is valid. The attribute specifier sequence appertaining to some
 | |
|     source construct shall contain only attributes that are allowed to apply to that source construct.
 | |
| </pre>
 | |
| <a name='6.7.12p4'></a>
 | |
| <pre>4   In all aspects of the language, a standard attribute specified by this document as an identifier attr
 | |
|     and an identifier of the form __attr__ shall behave the same when used as an attribute token,
 | |
|     except for the spelling.<a href='#FOOTNOTE.186'><sup>[186]</sup></a>
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.186'>
 | |
| <pre><i><b>Footnote 186)</b> Thus, the attributes [[nodiscard]] and [[__nodiscard__]] can be freely interchanged. Implementations are encour-
 | |
|     aged to behave similarly for attribute tokens (including attribute prefixed tokens) they provide.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12p5'></a>
 | |
| <pre>5   It is recommended that implementations support all standard attributes as defined in this document.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.1'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.1 [General]</h3>
 | |
| <a name='6.7.12.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     attribute-specifier-sequence:
 | |
|                           attribute-specifier-sequenceopt attribute-specifier
 | |
|      attribute-specifier:
 | |
|                           [ [ attribute-list ] ]
 | |
|      attribute-list:
 | |
|                           attributeopt
 | |
|                           attribute-list , attributeopt
 | |
|      attribute:
 | |
|                           attribute-token attribute-argument-clauseopt
 | |
|      attribute-token:
 | |
|                           standard-attribute
 | |
|                           attribute-prefixed-token
 | |
|      standard-attribute:
 | |
|                           identifier
 | |
| 
 | |
|      attribute-prefixed-token:
 | |
|                          attribute-prefix :: identifier
 | |
|      attribute-prefix:
 | |
|                          identifier
 | |
|      attribute-argument-clause:
 | |
|                          ( balanced-token-sequenceopt )
 | |
|      balanced-token-sequence:
 | |
|                          balanced-token
 | |
|                             balanced-token-sequence balanced-token
 | |
|      balanced-token:
 | |
|                             ( balanced-token-sequenceopt )
 | |
|                             [ balanced-token-sequenceopt ]
 | |
|                             { balanced-token-sequenceopt }
 | |
|                            any token other than a parenthesis, a bracket, or a brace
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.7.12.1p2'></a>
 | |
| <pre>2   The identifier in a standard attribute shall be one of:
 | |
| 
 | |
|     deprecated                      maybe_unused                     noreturn                         unsequenced
 | |
|     fallthrough                     nodiscard                        _Noreturn                        reproducible
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.12.1p3'></a>
 | |
| <pre>3   An attribute specifier that contains no attributes has no effect. The order in which attribute tokens
 | |
|     appear in an attribute list is not significant. If a keyword (<a href='#6.4.1'>6.4.1</a>) that satisfies the syntactic require-
 | |
|     ments of an identifier (<a href='#6.4.2'>6.4.2</a>) is contained in an attribute token, it is considered an identifier. A strictly
 | |
|     conforming program using a standard attribute remains strictly conforming in the absence of that
 | |
|     attribute. <a href='#FOOTNOTE.187'><sup>[187]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.187'>
 | |
| <pre><i><b>Footnote 187)</b> Standard attributes specified by this document can be parsed but ignored by an implementation without changing the
 | |
|     semantics of a correct program; the same is not true for attributes not specified by this document.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.1p4'></a>
 | |
| <pre>4   NOTE For each standard attribute, the form of the balanced token sequence, if any, will be specified.
 | |
| 
 | |
|     Recommended Practice
 | |
| </pre>
 | |
| <a name='6.7.12.1p5'></a>
 | |
| <pre>5   Each implementation should choose a distinctive name for the attribute prefix in an attribute
 | |
|     prefixed token. Implementations should not define attributes without an attribute prefix unless it is
 | |
|     a standard attribute as specified in this document.
 | |
| </pre>
 | |
| <a name='6.7.12.1p6'></a>
 | |
| <pre>6   EXAMPLE 1 Suppose that an implementation chooses the attribute prefix hal and provides specific attributes named daisy
 | |
|     and rosie.
 | |
| 
 | |
|       [[deprecated, hal::daisy]] double nine1000(double);
 | |
|       [[deprecated]] [[hal::daisy]] double nine1000(double);
 | |
|       [[deprecated]] double nine1000 [[hal::daisy]] (double);
 | |
| 
 | |
| 
 | |
|     Then all the following declarations should be equivalent aside from the spelling:
 | |
| 
 | |
|       [[__deprecated__, __hal__::__daisy__]] double nine1000(double);
 | |
|       [[__deprecated__]] [[__hal__::__daisy__]] double nine1000(double);
 | |
|       [[__deprecated__]] double nine1000 [[__hal__::__daisy__]] (double);
 | |
| 
 | |
| 
 | |
|     These use the alternate spelling that is required for all standard attributes and recommended for prefixed attributes. These
 | |
|     may be better-suited for use in header files, where the use of the alternate spelling avoids naming conflicts with user-provided
 | |
|     macros.
 | |
| </pre>
 | |
| <a name='6.7.12.1p7'></a>
 | |
| <pre>7   EXAMPLE 2 For the same implementation, the following two declarations are equivalent, because the ordering inside
 | |
|     attribute lists is not important.
 | |
| 
 | |
|       [[hal::daisy, hal::rosie]] double nine999(double);
 | |
|       [[hal::rosie, hal::daisy]] double nine999(double);
 | |
| 
 | |
| 
 | |
|     On the other hand the following two declarations are not equivalent, because the ordering of different attribute specifiers
 | |
|     may affect the semantics.
 | |
| 
 | |
|       [[hal::daisy]] [[hal::rosie]] double nine999(double);
 | |
|       [[hal::rosie]] [[hal::daisy]] double nine999(double); // may have different semantics
 | |
| </pre>
 | |
| <a name='6.7.12.2'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.2 [The nodiscard attribute]</h3>
 | |
| <a name='6.7.12.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The nodiscard attribute shall be applied to the identifier in a function declaration or to the definition
 | |
|     of a structure, union, or enumeration type. If an attribute argument clause is present, it shall have
 | |
|     the form:
 | |
|                ( string-literal )
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.12.2p2'></a>
 | |
| <pre>2   The __has_c_attribute conditional inclusion expression (<a href='#6.10.1'>6.10.1</a>) shall return the value 202003L
 | |
|     when given nodiscard as the pp-tokens operand.
 | |
| </pre>
 | |
| <a name='6.7.12.2p3'></a>
 | |
| <pre>3   A name or entity declared without the nodiscard attribute can later be redeclared with the attribute
 | |
|     and vice versa. An entity is considered marked after the first declaration that marks it.
 | |
| 
 | |
|     Recommended Practice
 | |
| </pre>
 | |
| <a name='6.7.12.2p4'></a>
 | |
| <pre>4   A nodiscard call is a function call expression that calls a function previously declared with attribute
 | |
|     nodiscard, or whose return type is a structure, union, or enumeration type marked with attribute
 | |
|     nodiscard. Evaluation of a nodiscard call as a void expression (<a href='#6.8.3'>6.8.3</a>) is discouraged unless explicitly
 | |
|     cast to void. Implementations are encouraged to issue a diagnostic in such cases. This is typically
 | |
|     because immediately discarding the return value of a nodiscard call has surprising consequences.
 | |
| </pre>
 | |
| <a name='6.7.12.2p5'></a>
 | |
| <pre>5   The diagnostic message should include text provided by the string literal within the attribute
 | |
|     argument clause of any nodiscard attribute applied to the name or entity.
 | |
| </pre>
 | |
| <a name='6.7.12.2p6'></a>
 | |
| <pre>6   EXAMPLE 1
 | |
| 
 | |
|       struct [[nodiscard]] error_info { /*...*/ };
 | |
|       struct error_info enable_missile_safety_mode(void);
 | |
|       void launch_missiles(void);
 | |
|       void test_missiles(void) {
 | |
|             enable_missile_safety_mode();
 | |
|             launch_missiles();
 | |
|       }
 | |
| 
 | |
|     A diagnostic for the call to enable_missile_safety_mode is encouraged.
 | |
| </pre>
 | |
| <a name='6.7.12.2p7'></a>
 | |
| <pre>7   EXAMPLE 2
 | |
| 
 | |
|       [[nodiscard]] int important_func(void);
 | |
|       void call(void) {
 | |
|             int i = important_func();
 | |
|       }
 | |
| 
 | |
|     No diagnostic for the call to important_func is encouraged despite the value of i not being used.
 | |
| </pre>
 | |
| <a name='6.7.12.2p8'></a>
 | |
| <pre>8   EXAMPLE 3
 | |
| 
 | |
|               [[nodiscard("must check armed state")]]
 | |
|               bool arm_detonator(int);
 | |
| 
 | |
|               void call(void) {
 | |
|                     arm_detonator(3);
 | |
|                     detonate();
 | |
|               }
 | |
| 
 | |
|     A diagnostic for the call toarm_detonator using the string literal "must check armed state" from the attribute argument
 | |
|     clause is encouraged.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.3'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.3 [The maybe_unused attribute]</h3>
 | |
| <a name='6.7.12.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The maybe_unused attribute shall be applied to the declaration of a structure, a union, a typedef
 | |
|     name, a variable, a structure or union member, a function, an enumeration, an enumerator, or a label.
 | |
|     No attribute argument clause shall be present.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.12.3p2'></a>
 | |
| <pre>2   The maybe_unused attribute indicates that a name or entity is possibly intentionally unused.
 | |
| </pre>
 | |
| <a name='6.7.12.3p3'></a>
 | |
| <pre>3   The __has_c_attribute conditional inclusion expression (<a href='#6.10.1'>6.10.1</a>) shall return the value 202106L
 | |
|     when given maybe_unused as the pp-tokens operand.
 | |
|     A name or entity declared without the maybe_unused attribute can later be redeclared with the
 | |
|     attribute and vice versa. An entity is considered marked with the attribute after the first declaration
 | |
|     that marks it.
 | |
| 
 | |
|     Recommended Practice
 | |
| </pre>
 | |
| <a name='6.7.12.3p4'></a>
 | |
| <pre>4   For an entity marked maybe_unused, implementations are encouraged not to emit a diagnostic that
 | |
|     the entity is unused, or that the entity is used despite the presence of the attribute.
 | |
| </pre>
 | |
| <a name='6.7.12.3p5'></a>
 | |
| <pre>5   EXAMPLE
 | |
| 
 | |
|       [[maybe_unused]] void f([[maybe_unused]] int i) {
 | |
|             [[maybe_unused]] int j = i + 100;
 | |
|             assert(j);
 | |
|       }
 | |
| 
 | |
|     Implementations are encouraged not to diagnose that j is unused, whether or not NDEBUG is defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.4'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.4 [The deprecated attribute]</h3>
 | |
| <a name='6.7.12.4p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The deprecated attribute shall be applied to the declaration of a structure, a union, a typedef name,
 | |
|     a variable, a structure or union member, a function, an enumeration, or an enumerator.
 | |
| </pre>
 | |
| <a name='6.7.12.4p2'></a>
 | |
| <pre>2   If an attribute argument clause is present, it shall have the form:
 | |
|                 ( string-literal )
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.12.4p3'></a>
 | |
| <pre>3   The deprecated attribute can be used to mark names and entities whose use is still allowed, but is
 | |
|     discouraged for some reason. <a href='#FOOTNOTE.188'><sup>[188]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.188'>
 | |
| <pre><i><b>Footnote 188)</b> In particular, deprecated is appropriate for names and entities that are obsolescent, insecure, unsafe, or otherwise unfit
 | |
|     for purpose.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.4p4'></a>
 | |
| <pre>4   The __has_c_attribute conditional inclusion expression (<a href='#6.10.1'>6.10.1</a>) shall return the value 201904L
 | |
|     when given deprecated as the pp-tokens operand.
 | |
| </pre>
 | |
| <a name='6.7.12.4p5'></a>
 | |
| <pre>5   A name or entity declared without the deprecated attribute can later be redeclared with the attribute
 | |
|     and vice versa. An entity is considered marked with the attribute after the first declaration that
 | |
|     marks it.
 | |
| 
 | |
|     Recommended Practice
 | |
| </pre>
 | |
| <a name='6.7.12.4p6'></a>
 | |
| <pre>6   Implementations should use the deprecated attribute to produce a diagnostic message in case the
 | |
|     program refers to a name or entity other than to declare it, after a declaration that specifies the
 | |
|     attribute, when the reference to the name or entity is not within the context of a related deprecated
 | |
|     entity. The diagnostic message should include text provided by the string literal within the attribute
 | |
|     argument clause of any deprecated attribute applied to the name or entity.
 | |
| </pre>
 | |
| <a name='6.7.12.4p7'></a>
 | |
| <pre>7   EXAMPLE
 | |
| 
 | |
|       struct [[deprecated]] S {
 | |
|             int a;
 | |
|       };
 | |
| 
 | |
|       enum [[deprecated]] E1 {
 | |
|             one
 | |
|       };
 | |
|       enum E2 {
 | |
|             two [[deprecated("use ’three’ instead")]],
 | |
|             three
 | |
|       };
 | |
| 
 | |
|       [[deprecated]] typedef int Foo;
 | |
| 
 | |
|       void f1(struct S s) { // Diagnose use of S
 | |
|             int i = one; // Diagnose use of E1
 | |
|             int j = two; // Diagnose use of two: "use ’three’ instead"
 | |
|             int k = three;
 | |
|             Foo f; // Diagnose use of Foo
 | |
|       }
 | |
| 
 | |
|       [[deprecated]] void f2(struct S s) {
 | |
|             int i = one;
 | |
|             int j = two;
 | |
|             int k = three;
 | |
|             Foo f;
 | |
|       }
 | |
| 
 | |
|       struct [[deprecated]] T {
 | |
|             Foo f;
 | |
|             struct S s;
 | |
|       };
 | |
| 
 | |
| 
 | |
|     Implementations are encouraged to diagnose the use of deprecated entities within a context which is not itself deprecated, as
 | |
|     indicated for function f1, but not to diagnose within function f2 and struct T, as they are themselves deprecated.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.5'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.5 [The fallthrough attribute]</h3>
 | |
| <a name='6.7.12.5p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The attribute token fallthrough shall only appear in an attribute declaration (<a href='#6.7'>6.7</a>); such a declara-
 | |
|     tion is a fallthrough declaration. No attribute argument clause shall be present. A fallthrough decla-
 | |
|     ration may only appear within an enclosing switch statement (<a href='#6.8.4.2'>6.8.4.2</a>). The next block item(<a href='#6.8.2'>6.8.2</a>)
 | |
|     that would be encountered after a fallthrough declaration shall be a case label or default label
 | |
|     associated with the smallest enclosing switch statement.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.12.5p2'></a>
 | |
| <pre>2   The __has_c_attribute conditional inclusion expression (<a href='#6.10.1'>6.10.1</a>) shall return the value 201904L
 | |
|     when given fallthrough as the pp-tokens operand.
 | |
| 
 | |
|     Recommended Practice
 | |
| </pre>
 | |
| <a name='6.7.12.5p3'></a>
 | |
| <pre>3   The use of a fallthrough declaration is intended to suppress a diagnostic that an implementation
 | |
|     might otherwise issue for a case or default label that is reachable from another case or default
 | |
|     label along some path of execution. Implementations are encouraged to issue a diagnostic if a
 | |
|     fallthrough declaration is not dynamically reachable.
 | |
| </pre>
 | |
| <a name='6.7.12.5p4'></a>
 | |
| <pre>4   EXAMPLE
 | |
| 
 | |
|       void f(int n) {
 | |
|             void g(void), h(void), i(void);
 | |
|             switch (n) {
 | |
|             case 1: /* diagnostic on fallthrough discouraged */
 | |
|             case 2:
 | |
|                   g();
 | |
|                   [[fallthrough]];
 | |
|             case 3: /* diagnostic on fallthrough discouraged */
 | |
|                   h();
 | |
|             case 4: /* fallthrough diagnostic encouraged */
 | |
|                   i();
 | |
|                         [[fallthrough]]; /* constraint violation */
 | |
|                }
 | |
|       }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.6'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.6 [The noreturn and _Noreturn attributes]</h3>
 | |
| <a name='6.7.12.6p1'></a>
 | |
| <pre>1 Description
 | |
|    When _Noreturn is used as an attribute token (instead of a function specifier), the constraints and
 | |
|     semantics are identical to that of the noreturn attribute token. Use of _Noreturn as an attribute
 | |
|     token is an obsolescent feature<a href='#FOOTNOTE.189'><sup>[189]</sup></a> .
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='FOOTNOTE.189'>
 | |
| <pre><i><b>Footnote 189)</b> [[_Noreturn]] and [[noreturn]] are equivalent attributes to support code that includes <stdnoreturn.h>, because
 | |
|     that header defines noreturn as a macro that expands to _Noreturn .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.6p2'></a>
 | |
| <pre>2   The noreturn attribute shall be applied to the identifier in a function declaration. No attribute
 | |
|     argument clause shall be present.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.7.12.6p3'></a>
 | |
| <pre>3   The first declaration of a function shall specify the noreturn attribute if any declaration of that
 | |
|     function specifies the noreturn attribute. If a function is declared with the noreturn attribute in
 | |
|     one translation unit and the same function is declared without the noreturn attribute in another
 | |
|     translation unit, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.7.12.6p4'></a>
 | |
| <pre>4   If a function f is called where f was previously declared with the noreturn attribute and f eventually
 | |
|     returns, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.7.12.6p5'></a>
 | |
| <pre>5   The __has_c_attribute conditional inclusion expression (<a href='#6.10.1'>6.10.1</a>) shall return the value 202202L
 | |
|     when given noreturn as the pp-tokens operand.
 | |
| 
 | |
|     Recommended Practice
 | |
| </pre>
 | |
| <a name='6.7.12.6p6'></a>
 | |
| <pre>6   The implementation should produce a diagnostic message for a function declared with a noreturn
 | |
|     attribute that appears to be capable of returning to its caller.
 | |
| </pre>
 | |
| <a name='6.7.12.6p7'></a>
 | |
| <pre>7   EXAMPLE
 | |
| 
 | |
|       [[noreturn]] void f(void) {
 | |
|             abort(); // ok
 | |
|       }
 | |
| 
 | |
|       [[noreturn]] void g(int i) { // causes undefined behavior if i <= 0
 | |
|             if (i > 0) abort();
 | |
|       }
 | |
| 
 | |
|       [[noreturn]] int h(void);
 | |
| 
 | |
|     Implementations are encouraged to diagnose the definition of g() because it is capable of returning to its caller. Implementa-
 | |
|     tions are similarly encouraged to diagnose the declaration of h() because it appears capable of returning to its caller due to
 | |
|     the non-void return type.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.7'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.7 [Standard attributes for function types]</h3>
 | |
| <a name='6.7.12.7p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The identifier in a standard function type attribute shall be one of:
 | |
| 
 | |
|     unsequenced                       reproducible
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.7p2'></a>
 | |
| <pre>2   An attribute for a function type shall be applied to a function declarator<a href='#FOOTNOTE.190'><sup>[190]</sup></a> or to a type specifier that
 | |
|     has a function type. The corresponding attribute is a property of the referred function type<a href='#FOOTNOTE.191'><sup>[191]</sup></a> . No
 | |
|     attribute argument clause shall be present.
 | |
|     Description
 | |
| </pre>
 | |
| <a name='FOOTNOTE.190'>
 | |
| <pre><i><b>Footnote 190)</b> That is, they appear in the attributes right after the closing parenthesis of the parameter list, independently if the function
 | |
|     type is, for example, used directly to declare a function or if it is used in a pointer to function type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.191'>
 | |
| <pre><i><b>Footnote 191)</b> If several declarations of the same function or function pointer are visible, regardless whether an attribute is present
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.7p3'></a>
 | |
| <pre>3   The main purpose of the function type properties and attributes defined in this clause is to provide
 | |
|     the translator with information about the access of objects by a function such that certain properties
 | |
|     of function calls can be deduced; the properties distinguish read operations (stateless and inde-
 | |
|     pendent) and write operations (effectless, idempotent and reproducible) or a combination of both
 | |
|     (unsequenced). Although semantically attached to a function type, the attributes described are not
 | |
|     part of the prototype of a such annotated function, and redeclarations and conversions that drop
 | |
|     such an attribute are valid and constitute compatible types. Conversely, if a definition that does not
 | |
|     have the asserted property is accessed by a function declaration or a function pointer with a type
 | |
|     that has the attribute, the behavior is undefined<a href='#FOOTNOTE.192'><sup>[192]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.192'>
 | |
| <pre><i><b>Footnote 192)</b> That is, the fact that a function has one of these properties is in general not determined by the specification of the
 | |
|     translation unit in which it is found; other translation units and specific run time conditions also condition the possible
 | |
|     assertion of the properties.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.7p4'></a>
 | |
| <pre>4   To allow reordering of calls to functions as they are described here, possible access to objects with a
 | |
|     lifetime that starts before or ends after a call has to be restricted; effects on all objects that are accessed
 | |
|     during a function call are restricted to the same thread as the call and the based-on relation between
 | |
|     pointer parameters and lvalues (<a href='#6.7.3.1'>6.7.3.1</a>) models the fact that objects do not change inadvertently
 | |
|     during the call. In the following, an operation is said to be sequenced during a function call if it is
 | |
|     sequenced after the start of the function call<a href='#FOOTNOTE.193'><sup>[193]</sup></a> and before the call terminates. An object definition
 | |
|     of an object X in a function f escapes if an access to X happens while no call to f is active. An
 | |
|     object is local to a call to a function f if its lifetime starts and ends during the call or if it is defined
 | |
|     by f but does not escape. A function call and an object X synchronize if all accesses to X that are
 | |
|     not sequenced during the call happen before or after the call. Execution state that is described in
 | |
|     the library clause, such as the floating-point environment, conversion state, locale, input/output
 | |
|     streams, external files or errno account as objects; operations that allow to query this state, even
 | |
|     indirectly, account as lvalue conversions, and operations that allow to change this state account as
 | |
|     store operations.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.193'>
 | |
| <pre><i><b>Footnote 193)</b> The initializations of the parameters is sequenced during the function call.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.7p5'></a>
 | |
| <pre>5   A function definition f is stateless if any definition of an object of static or thread storage duration in
 | |
|     f or in a function that is called by f is const but not volatile qualified.
 | |
| </pre>
 | |
| <a name='6.7.12.7p6'></a>
 | |
| <pre>6   An object X is observed by a function call if both synchronize, if X is not local to the call, if X has a
 | |
|     lifetime that starts before the function call and if an access of X is sequenced during the call; the last
 | |
|     value of X, if any, that is stored before the call is said to be the value of X that is observed by the
 | |
|     call. A function pointer value f is independent if for any object X that is observed by some call to f
 | |
|     through an lvalue that is not based on a parameter of the call, then all accesses to X in all calls to
 | |
|     f during the same program execution observe the same value; otherwise if the access is based on
 | |
|     a pointer parameter, there shall be a unique such pointer parameter P such that any access to X
 | |
|     shall be to an lvalue that is based on P . A function definition is independent if the derived function
 | |
|     pointer value is independent.
 | |
| </pre>
 | |
| <a name='6.7.12.7p7'></a>
 | |
| <pre>7   A store operation to an object X that is sequenced during a function call such that both synchronize
 | |
|     is said to be observable if X is not local to the call, if the lifetime of X ends after the call, if the stored
 | |
|     value is different from the value observed by the call, if any, and if it is the last value written before
 | |
|     the termination of the call. An evaluation of a function call<a href='#FOOTNOTE.194'><sup>[194]</sup></a> is effectless if any store operation
 | |
|     that is sequenced during the call is the modification of an object that synchronizes with the call; if
 | |
|     additionally the operation is observable, there shall be a unique pointer parameter P of the function
 | |
|     such that any access to X shall be to an lvalue that is based on P . A function pointer value f is
 | |
|     effectless if any evaluation of a function call that calls f is effectless. A function definition is effectless
 | |
|     if the derived function pointer value is effectless.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.194'>
 | |
| <pre><i><b>Footnote 194)</b> This considers the evaluation of the function call itself, not the evaluation of a full function call expression. Such an
 | |
|     evaluation is sequenced after all evaluations that determine f and the call arguments, if any, have been performed.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.7p8'></a>
 | |
| <pre>8   An evaluation E is idempotent if a second evaluation of E can be sequenced immediately after the
 | |
|     original one without changing the resulting value, if any, or the observable state of the execution.
 | |
| 
 | |
| 
 | |
|     at several or just one of the declarators, it is attached to the type of the corresponding function definition, function pointer
 | |
|     object, or function pointer value.
 | |
|      A function pointer value f is idempotent if any evaluation of a function call<a href='#FOOTNOTE.195'><sup>[195]</sup></a> that calls f is
 | |
|      idempotent. A function definition is idempotent if the derived function pointer value is idempotent.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.195'>
 | |
| <pre><i><b>Footnote 195)</b> This considers the evaluation of the function call itself, not the evaluation of a full function call expression. Such an
 | |
|      evaluated is sequenced after all evaluations that determine f and the call arguments, if any, have been performed.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.7p9'></a>
 | |
| <pre>9    A function is reproducible if it is effectless and idempotent; it is unsequenced if it is stateless, effectless,
 | |
|      idempotent and independent<a href='#FOOTNOTE.196'><sup>[196]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.196'>
 | |
| <pre><i><b>Footnote 196)</b> A function call of an unsequenced function can be executed as early as the function pointer value, the values of the
 | |
|      arguments and all objects that are accessible through them, and all values of globally accessible state have been determined,
 | |
|      and it can be executed as late as the arguments and the objects they possibly target are unchanged and as any of its return
 | |
|      value or modified pointed-to arguments are accessed.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.7.12.7p10'></a>
 | |
| <pre>10   NOTE The synchronization requirements with respect to any accessed object X for the independence of functions provide
 | |
|      boundaries up to which a function call may safely be reordered without changing the semantics of the program. If X is
 | |
|      const but not volatile qualified the reordering is unconstrained. If it is an object that is conditioned in an initialization
 | |
|      phase, for a single threaded program a synchronization is provided by the sequenced before relation and the reordering
 | |
|      may, in principle, move the call just after the initialization. For a multi-threaded program, synchronization guarantees can be
 | |
|      given by calls to synchronizing functions of the <threads.h> header or by an appropriate call to atomic_thread_fence at
 | |
|      the end of the initialization phase. If a function is known to be independent or effectless, adding restrict qualifications to
 | |
|      the declarations of all pointer parameters does not change the semantics of any call. Similarly, changing the memory order to
 | |
|      memory_order_relaxed for all atomic operations during a call to such a function preserves semantics.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.7p11'></a>
 | |
| <pre>11   NOTE In general the functions provided by the <math.h> header do not have the properties that are defined above; many
 | |
|      of them change the floating-point state or errno when they encounter an error (so they have observable side effects) and the
 | |
|      results of most of them depend on execution wide state such as the rounding direction mode (so they are not independent).
 | |
|      Whether a particular C library function is reproducible or unsequenced additionally often depends on properties of the
 | |
|      implementation, such as implementation-defined behavior for certain error conditions.
 | |
| 
 | |
|      Recommended Practice
 | |
| </pre>
 | |
| <a name='6.7.12.7p12'></a>
 | |
| <pre>12   If possible, it is recommended that implementations diagnose if an attribute of this clause is applied
 | |
|      to a function definition that does not have the corresponding property. It is recommended that appli-
 | |
|      cations that assert the independent or effectless properties for functions qualify pointer parameters
 | |
|      with restrict.
 | |
|      Forward references: errors <errno.h> (<a href='#7.5'>7.5</a>), floating-point environment <fenv.h> (<a href='#7.6'>7.6</a>), localiza-
 | |
|      tion <locale.h> (<a href='#7.11'>7.11</a>), mathematics <math.h> (<a href='#7.12'>7.12</a>), fences (<a href='#7.17.4'>7.17.4</a>), input/output <stdio.h>
 | |
|      (<a href='#7.23'>7.23</a>), threads <threads.h> (<a href='#7.28'>7.28</a>), extended multibyte and wide character utilities <wchar.h>
 | |
|      (<a href='#7.31'>7.31</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.7.1'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.7.1 [The reproducible type attribute]</h3>
 | |
| <a name='6.7.12.7.1p1'></a>
 | |
| <pre>1 Description
 | |
|     The reproducible type attribute asserts that a function or pointed-to function with that type is
 | |
|      reproducible.
 | |
| </pre>
 | |
| <a name='6.7.12.7.1p2'></a>
 | |
| <pre>2    The __has_c_attribute conditional inclusion expression (<a href='#6.10.1'>6.10.1</a>) shall return the value 202207L
 | |
|      when given reproducible as the pp-tokens operand.
 | |
| </pre>
 | |
| <a name='6.7.12.7.1p3'></a>
 | |
| <pre>3    EXAMPLE 1 The attribute in the following function declaration asserts that two consecutive calls to the function will result
 | |
|      in the same return value. Changes to the abstract state during the call are possible as long as they are not observable, but
 | |
|      no other side effects will occur. Thus the function definition may for example use local objects of static or thread storage
 | |
|      duration to keep track of the arguments for which the function has been called and cache their computed return values.
 | |
| 
 | |
|                         size_t hash(char const[static 32]) [[reproducible]];
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.7.2'></a>
 | |
| <hr>
 | |
| <h3>6.7.12.7.2 [The unsequenced type attribute]</h3>
 | |
| <a name='6.7.12.7.2p1'></a>
 | |
| <pre>1 Description
 | |
|     The unsequenced type attribute asserts that a function or pointed-to function with that type is
 | |
|      unsequenced.
 | |
| </pre>
 | |
| <a name='6.7.12.7.2p2'></a>
 | |
| <pre>2    The __has_c_attribute conditional inclusion expression (<a href='#6.10.1'>6.10.1</a>) shall return the value 202207L
 | |
|      when given unsequenced as the pp-tokens operand.
 | |
| </pre>
 | |
| <a name='6.7.12.7.2p3'></a>
 | |
| <pre>3    NOTE The unsequenced type attribute asserts strong properties for the such typed function, in particular that certain
 | |
|      sequencing requirements for function calls can be relaxed without affecting the state of the abstract machine. Thereby, calls
 | |
|      to such functions are natural candidates for optimization techniques such as common subexpression elimination, local
 | |
|      memoization or lazy evaluation.
 | |
| </pre>
 | |
| <a name='6.7.12.7.2p4'></a>
 | |
| <pre>4   NOTE A proof of validity of the annotation of a function type with the unsequenced attribute may depend on the property
 | |
|     if a derived function pointer escapes the translation unit or not. For a function with internal linkage where no function
 | |
|     pointer escapes the translation unit, all calling contexts are known and it is possible, in principle, to prove that no control flow
 | |
|     exists such that a library function is called with arguments that trigger an exceptional condition. For a function with external
 | |
|     linkage such a proof may not be possible and the use of such a function then has to ensure that no exceptional condition
 | |
|     results from the provided arguments.
 | |
| </pre>
 | |
| <a name='6.7.12.7.2p5'></a>
 | |
| <pre>5   NOTE The unsequenced property does not necessarily imply that the function is reentrant or that calls can be executed
 | |
|     concurrently. This is because an unsequenced function can read from and write to objects of static storage duration, as long
 | |
|     as no change is observable after a call terminates.
 | |
| </pre>
 | |
| <a name='6.7.12.7.2p6'></a>
 | |
| <pre>6   EXAMPLE 1 The attribute in the following function declaration asserts that it doesn’t depend on any modifiable state of the
 | |
|     abstract machine. Calls to the function can be executed out of sequence before the return value is needed and two calls to the
 | |
|     function with the same argument value will result in the same return value.
 | |
| 
 | |
|                        bool tendency(signed char) [[unsequenced]];
 | |
| 
 | |
|     Therefore such a call for a given argument value needs only to be executed once and the returned value can be reused when
 | |
|     appropriate. For example, calls for all possible argument values can be executed during program startup and tabulated.
 | |
| </pre>
 | |
| <a name='6.7.12.7.2p7'></a>
 | |
| <pre>7   EXAMPLE 2 The attribute in the following function declaration asserts that it doesn’t depend on any modifiable state of
 | |
|     the abstract machine. Within the same thread, calls to the function can be executed out of sequence before the return value
 | |
|     is needed and two calls to the function will result in the same pointer return value. Therefore such a call needs only to be
 | |
|     executed once in a given thread and the returned pointer value can be reused when appropriate. For example, a single
 | |
|     call can be executed during thread startup and the return value p and the value of the object *p of type toto const can be
 | |
|     cached.
 | |
| 
 | |
|                        typedef struct toto toto;
 | |
|                        toto const* toto_zero(void) [[unsequenced]];
 | |
| 
 | |
| </pre>
 | |
| <a name='6.7.12.7.2p8'></a>
 | |
| <pre>8   EXAMPLE 3 The unsequenced property of a function f can be locally asserted within a function g that uses it. For example
 | |
|     the library function sqrt is in generally not unsequenced because a negative argument will raise a domain error and because
 | |
|     the result may depend on the rounding mode. Nevertheless in contexts similar to the following function a user can prove
 | |
|     that it will not be called with invalid arguments, and, that the floating-point environment has the same value for all calls.
 | |
| 
 | |
|                        #include <math.h>
 | |
|                        #include <fenv.h>
 | |
| 
 | |
|                        inline double distance (double const x[static 2]) [[reproducible]] {
 | |
|                              #pragma FP_CONTRACT OFF
 | |
|                              #pragma FENV_ROUND FE_TONEAREST
 | |
|                              // We assert that sqrt will not be called with invalid arguments
 | |
|                              // and the result only depends on the argument value.
 | |
|                              extern typeof(sqrt) [[unsequenced]] sqrt;
 | |
|                              return sqrt(x[0]*x[0] + x[1]*x[1]);
 | |
|                        }
 | |
| 
 | |
|     The function distance potentially has the side effect of changing the floating-point environment. Nevertheless the floating
 | |
|     environment is thread local, thus a change to that state outside the function is sequenced with the change within and
 | |
|     additionally the observed value is restored when the function returns. Thus this side effect is not observable for a caller.
 | |
|     Overall the function distance is stateless, effectless and idempotent and in particular it is reproducible as the attribute
 | |
|     indicates. Because the function can be called in a context where the floating-point environment has different state, distance
 | |
|     is not independent and thus it is also not unsequenced. Nevertheless, adding an unsequenced attribute where this is justified
 | |
|     may introduce optimization opportunities.
 | |
| 
 | |
|                        double g (double y[static 1], double const x[static 2]) {
 | |
|                        // We assert that distance will not see different states of the floating
 | |
|                        // point environment.
 | |
|                        extern double distance (double const x[static 2]) [[unsequenced]];
 | |
|                        y[0] = distance(x);
 | |
|                        ...
 | |
|                        return distance(x);   // replacement by y[0] is valid
 | |
|                }
 | |
| </pre>
 | |
| <a name='6.8'></a>
 | |
| <hr>
 | |
| <h3>6.8 [Statements and blocks]</h3>
 | |
| <a name='6.8p1'></a>
 | |
| <pre>1 Syntax
 | |
|     statement:
 | |
|                        labeled-statement
 | |
|                        unlabeled-statement
 | |
|      unlabeled-statement:
 | |
|                        expression-statement
 | |
|                        attribute-specifier-sequenceopt primary-block
 | |
|                        attribute-specifier-sequenceopt jump-statement
 | |
|      primary-block:
 | |
|                        compound-statement
 | |
|                        selection-statement
 | |
|                        iteration-statement
 | |
| 
 | |
| 
 | |
| 
 | |
|     secondary-block:
 | |
|                            statement
 | |
| 
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8p2'></a>
 | |
| <pre>2   A statement specifies an action to be performed. Except as indicated, statements are executed in
 | |
|     sequence. The optional attribute specifier sequence appertains to the respective statement.
 | |
| </pre>
 | |
| <a name='6.8p3'></a>
 | |
| <pre>3   A block is either a primary block, a secondary block, or the block associated with a function definition;
 | |
|     it allows a set of declarations and statements to be grouped into one syntactic unit. Whenever a
 | |
|     block B appears in the syntax production as part of the definition of an enclosing block A, scopes of
 | |
|     identifiers and lifetimes of objects that are associated with B do not extend to the parts of A that are
 | |
|     outside of B. The initializers of objects that have automatic storage duration, and the variable length
 | |
|     array declarators of ordinary identifiers with block scope, are evaluated and the values are stored in
 | |
|     the objects (the representation of objects without an initializer becomes indeterminate) each time the
 | |
|     declaration is reached in the order of execution, as if it were a statement, and within each declaration
 | |
|     in the order that declarators appear.
 | |
| </pre>
 | |
| <a name='6.8p4'></a>
 | |
| <pre>4   A full expression is an expression that is not part of another expression, nor part of a declarator
 | |
|     or abstract declarator. There is also an implicit full expression in which the non-constant size
 | |
|     expressions for a variably modified type are evaluated; within that full expression, the evaluation of
 | |
|     different size expressions are unsequenced with respect to one another. There is a sequence point
 | |
|     between the evaluation of a full expression and the evaluation of the next full expression to be
 | |
|     evaluated.
 | |
| </pre>
 | |
| <a name='6.8p5'></a>
 | |
| <pre>5   NOTE Each of the following is a full expression:
 | |
| 
 | |
|        — a full declarator for a variably modified type,
 | |
| 
 | |
|        — an initializer that is not part of a compound literal,
 | |
| 
 | |
|        — the expression in an expression statement,
 | |
| 
 | |
|        — the controlling expression of a selection statement (if or switch),
 | |
| 
 | |
|        — the controlling expression of a while or do statement,
 | |
| 
 | |
|        — each of the (optional) expressions of a for statement,
 | |
| 
 | |
|        — the (optional) expression in a return statement.
 | |
| 
 | |
|     While a constant expression satisfies the definition of a full expression, evaluating it does not depend on nor produce any
 | |
|     side effects, so the sequencing implications of being a full expression are not relevant to a constant expression.
 | |
| 
 | |
|     Forward references: expression and null statements (<a href='#6.8.3'>6.8.3</a>), selection statements (<a href='#6.8.4'>6.8.4</a>), iteration
 | |
|     statements (<a href='#6.8.5'>6.8.5</a>), the return statement (<a href='#6.8.6.4'>6.8.6.4</a>).
 | |
| </pre>
 | |
| <a name='6.8.1'></a>
 | |
| <hr>
 | |
| <h3>6.8.1 [Labeled statements]</h3>
 | |
| <a name='6.8.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     label:
 | |
|                             attribute-specifier-sequenceopt identifier :
 | |
|                             attribute-specifier-sequenceopt case constant-expression :
 | |
|                             attribute-specifier-sequenceopt default :
 | |
|      labeled-statement:
 | |
|                             label statement
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.8.1p2'></a>
 | |
| <pre>2   A case or default label shall appear only in a switch statement. Further constraints on such labels
 | |
|     are discussed under the switch statement.
 | |
| </pre>
 | |
| <a name='6.8.1p3'></a>
 | |
| <pre>3   Label names shall be unique within a function.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.1p4'></a>
 | |
| <pre>4   Any statement may be preceded by a prefix that declares an identifier as a label name. The optional
 | |
|     attribute specifier sequence appertains to the label. Labels in themselves do not alter the flow of
 | |
|     control, which continues unimpeded across them.
 | |
|     Forward references: the goto statement (<a href='#6.8.6.1'>6.8.6.1</a>), the switch statement (<a href='#6.8.4.2'>6.8.4.2</a>) .
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.2'></a>
 | |
| <hr>
 | |
| <h3>6.8.2 [Compound statement]</h3>
 | |
| <a name='6.8.2p1'></a>
 | |
| <pre>1 Syntax
 | |
|     compound-statement:
 | |
|                             { block-item-listopt }
 | |
|      block-item-list:
 | |
|                             block-item
 | |
|                             block-item-list block-item
 | |
|      block-item:
 | |
|                             declaration
 | |
|                             unlabeled-statement
 | |
|                             label
 | |
| 
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.2p2'></a>
 | |
| <pre>2   A compound statement that is a function body together with the parameter type list and the optional
 | |
|     attribute specifier sequence between them forms the block associated with the function definition
 | |
|     in which it appears. Otherwise, it is a block that is different from any other block. A label shall be
 | |
|     translated as if it were followed by a null statement.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.3'></a>
 | |
| <hr>
 | |
| <h3>6.8.3 [Expression and null statements]</h3>
 | |
| <a name='6.8.3p1'></a>
 | |
| <pre>1 Syntax
 | |
|     expression-statement:
 | |
|                        expressionopt ;
 | |
|                        attribute-specifier-sequence expression ;
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.3p2'></a>
 | |
| <pre>2   The attribute specifier sequence appertains to the expression. The expression in an expression
 | |
|     statement is evaluated as a void expression for its side effects.<a href='#FOOTNOTE.197'><sup>[197]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.197'>
 | |
| <pre><i><b>Footnote 197)</b> Such as assignments, and function calls which have side effects.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.8.3p3'></a>
 | |
| <pre>3   A null statement (consisting of just a semicolon) performs no operations.
 | |
| </pre>
 | |
| <a name='6.8.3p4'></a>
 | |
| <pre>4   EXAMPLE 1 If a function call is evaluated as an expression statement for its side effects only, the discarding of its value can
 | |
|     be made explicit by converting the expression to a void expression by means of a cast:
 | |
|               int p(int);
 | |
|               /* ... */
 | |
|               (void)p(0);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.3p5'></a>
 | |
| <pre>5   EXAMPLE 2 In the program fragment
 | |
| 
 | |
|               char *s;
 | |
|               /* ... */
 | |
|               while (*s++ != ’\0’)
 | |
|                     ;
 | |
| 
 | |
| 
 | |
|     a null statement is used to supply an empty loop body to the iteration statement.
 | |
| 
 | |
|     Forward references: iteration statements (<a href='#6.8.5'>6.8.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.4'></a>
 | |
| <hr>
 | |
| <h3>6.8.4 [Selection statements]</h3>
 | |
| <a name='6.8.4p1'></a>
 | |
| <pre>1 Syntax
 | |
|     selection-statement:
 | |
|                             if ( expression ) secondary-block
 | |
|                             if ( expression ) secondary-block else secondary-block
 | |
|                             switch ( expression ) secondary-block
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.4p2'></a>
 | |
| <pre>2   A selection statement selects among a set of secondary blocks depending on the value of a controlling
 | |
|     expression.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.4.1'></a>
 | |
| <hr>
 | |
| <h3>6.8.4.1 [The if statement]</h3>
 | |
| <a name='6.8.4.1p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The controlling expression of an if statement shall have scalar type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.4.1p2'></a>
 | |
| <pre>2   In both forms, the first substatement is executed if the expression compares unequal to 0. In the
 | |
|     else form, the second substatement is executed if the expression compares equal to 0. If the first
 | |
|     substatement is reached via a label, the second substatement is not executed.
 | |
| </pre>
 | |
| <a name='6.8.4.1p3'></a>
 | |
| <pre>3   An else is associated with the lexically nearest preceding if that is allowed by the syntax.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.4.2'></a>
 | |
| <hr>
 | |
| <h3>6.8.4.2 [The switch statement]</h3>
 | |
| <a name='6.8.4.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The controlling expression of a switch statement shall have integer type.
 | |
| </pre>
 | |
| <a name='6.8.4.2p2'></a>
 | |
| <pre>2   If a switch statement has an associated case or default label within the scope of an identifier with
 | |
|     a variably modified type, the entire switch statement shall be within the scope of that identifier.<a href='#FOOTNOTE.198'><sup>[198]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.198'>
 | |
| <pre><i><b>Footnote 198)</b> That is, the declaration either precedes the switch statement, or it follows the last case or default label associated with
 | |
|     the switch that is in the block containing the declaration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.8.4.2p3'></a>
 | |
| <pre>3   The expression of each case label shall be an integer constant expression and no two of the case
 | |
|     constant expressions in the same switch statement shall have the same value after conversion.
 | |
|     There may be at most one default label in a switch statement. (Any enclosed switch statement
 | |
|     may have a default label or case constant expressions with values that duplicate case constant
 | |
|     expressions in the enclosing switch statement.)
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.4.2p4'></a>
 | |
| <pre>4   A switch statement causes control to jump to, into, or past the statement that is the switch body,
 | |
|     depending on the value of a controlling expression, and on the presence of a default label and the
 | |
|     values of any case labels on or in the switch body. A case or default label is accessible only within
 | |
|     the closest enclosing switch statement.
 | |
| </pre>
 | |
| <a name='6.8.4.2p5'></a>
 | |
| <pre>5   The integer promotions are performed on the controlling expression. The constant expression in
 | |
|     each case label is converted to the promoted type of the controlling expression. If a converted value
 | |
|     matches that of the promoted controlling expression, control jumps to the statement following the
 | |
|     matched case label. Otherwise, if there is a default label, control jumps to the statement following
 | |
|     the default label. If no converted case constant expression matches and there is no default label,
 | |
|     no part of the switch body is executed.
 | |
| 
 | |
|     Implementation limits
 | |
| </pre>
 | |
| <a name='6.8.4.2p6'></a>
 | |
| <pre>6   As discussed in <a href='#5.2.4.1'>5.2.4.1</a>, the implementation may limit the number of case values in a switch
 | |
|     statement.
 | |
| </pre>
 | |
| <a name='6.8.4.2p7'></a>
 | |
| <pre>7   EXAMPLE In the artificial program fragment
 | |
| 
 | |
|               switch (expr)
 | |
|               {
 | |
|                     int i = 4;
 | |
|                     f(i);
 | |
|               case 0:
 | |
|                     i = 17;
 | |
|                     /* falls through into default code */
 | |
|               default:
 | |
|                     printf("%d\n", i);
 | |
|               }
 | |
| 
 | |
| 
 | |
|     the object whose identifier is i exists with automatic storage duration (within the block) but is never initialized, and thus if
 | |
|     the controlling expression has a nonzero value, the call to the printf function will access an object with an indeterminate
 | |
|     representation. Similarly, the call to the function f cannot be reached.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.5'></a>
 | |
| <hr>
 | |
| <h3>6.8.5 [Iteration statements]</h3>
 | |
| <a name='6.8.5p1'></a>
 | |
| <pre>1 Syntax
 | |
|     iteration-statement:
 | |
|                             while ( expression ) secondary-block
 | |
|                             do secondary-block while ( expression ) ;
 | |
|                             for ( expressionopt ; expressionopt ; expressionopt ) secondary-block
 | |
|                             for ( declaration expressionopt ; expressionopt ) secondary-block
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.8.5p2'></a>
 | |
| <pre>2   The controlling expression of an iteration statement shall have scalar type.
 | |
| </pre>
 | |
| <a name='6.8.5p3'></a>
 | |
| <pre>3   The declaration part of a for statement shall only declare identifiers for objects having storage class
 | |
|     auto or register.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.5p4'></a>
 | |
| <pre>4   An iteration statement causes a secondary block called the loop body to be executed repeatedly until
 | |
|     the controlling expression compares equal to 0. The repetition occurs regardless of whether the loop
 | |
|     body is entered from the iteration statement or by a jump<a href='#FOOTNOTE.199'><sup>[199]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.199'>
 | |
| <pre><i><b>Footnote 199)</b> Code jumped over is not executed. In particular, the controlling expression of a for or while statement is not evaluated
 | |
|     before entering the loop body, nor is clause-1 of a for statement.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.8.5p5'></a>
 | |
| <pre>5   An iteration statement may be assumed by the implementation to terminate if its controlling
 | |
|     expression is not a constant expression<a href='#FOOTNOTE.200'><sup>[200]</sup></a> , and none of the following operations are performed in its
 | |
|     body, controlling expression or (in the case of a for statement) its expression-3201) :
 | |
| 
 | |
|       — input/output operations
 | |
| 
 | |
|       — accessing a volatile object
 | |
| 
 | |
|       — synchronization or atomic operations.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.200'>
 | |
| <pre><i><b>Footnote 200)</b> An omitted controlling expression is replaced by a nonzero constant, which is a constant expression.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.8.5.1'></a>
 | |
| <hr>
 | |
| <h3>6.8.5.1 [The while statement]</h3>
 | |
| <a name='6.8.5.1p1'></a>
 | |
| <pre>1   The evaluation of the controlling expression takes place before each execution of the loop body.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.5.2'></a>
 | |
| <hr>
 | |
| <h3>6.8.5.2 [The do statement]</h3>
 | |
| <a name='6.8.5.2p1'></a>
 | |
| <pre>1   The evaluation of the controlling expression takes place after each execution of the loop body.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.5.3'></a>
 | |
| <hr>
 | |
| <h3>6.8.5.3 [The for statement]</h3>
 | |
| <a name='6.8.5.3p1'></a>
 | |
| <pre>1   The statement
 | |
|               for (clause-1; expression-2; expression-3) statement
 | |
| 
 | |
| 
 | |
|     behaves as follows: The expression expression-2 is the controlling expression that is evaluated before
 | |
|     each execution of the loop body. The expression expression-3 is evaluated as a void expression after
 | |
|     each execution of the loop body. If clause-1 is a declaration, the scope of any identifiers it declares
 | |
|     is the remainder of the declaration and the entire loop, including the other two expressions; it is
 | |
|     reached in the order of execution before the first evaluation of the controlling expression. If clause-1
 | |
|     is an expression, it is evaluated as a void expression before the first evaluation of the controlling
 | |
|     expression.<a href='#FOOTNOTE.202'><sup>[202]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.202'>
 | |
| <pre><i><b>Footnote 202)</b> Thus, clause-1 specifies initialization for the loop, possibly declaring one or more variables for use in the loop; the
 | |
|     controlling expression, expression-2, specifies an evaluation made before each iteration, such that execution of the loop
 | |
|     continues until the expression compares equal to 0; and expression-3 specifies an operation (such as incrementing) that is
 | |
|     performed after each iteration.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.8.5.3p2'></a>
 | |
| <pre>2   Both clause-1 and expression-3 can be omitted. An omitted expression-2 is replaced by a nonzero
 | |
|     constant.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.6'></a>
 | |
| <hr>
 | |
| <h3>6.8.6 [Jump statements]</h3>
 | |
| <a name='6.8.6p1'></a>
 | |
| <pre>1 Syntax
 | |
|     jump-statement:
 | |
|                             goto identifier ;
 | |
|                             continue ;
 | |
|                             break ;
 | |
|                             return expressionopt ;
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.6p2'></a>
 | |
| <pre>2   A jump statement causes an unconditional jump to another place.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.6.1'></a>
 | |
| <hr>
 | |
| <h3>6.8.6.1 [The goto statement]</h3>
 | |
| <a name='6.8.6.1p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The identifier in a goto statement shall name a label located somewhere in the enclosing function. A
 | |
|     goto statement shall not jump from outside the scope of an identifier having a variably modified
 | |
|     type to inside the scope of that identifier.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.6.1p2'></a>
 | |
| <pre>2   A goto statement causes an unconditional jump to the statement prefixed by the named label in the
 | |
|     enclosing function.
 | |
| </pre>
 | |
| <a name='6.8.6.1p3'></a>
 | |
| <pre>3   EXAMPLE 1 It is sometimes convenient to jump into the middle of a complicated set of statements. The following outline
 | |
|     presents one possible approach to a problem based on these three assumptions:
 | |
| 
 | |
|         1. The general initialization code accesses objects only visible to the current function.
 | |
|         2. The general initialization code is too large to warrant duplication.
 | |
|         3. The code to determine the next operation is at the head of the loop. (To allow it to be reached by continue statements,
 | |
|            for example.)
 | |
| 
 | |
|               /* ... */
 | |
|               goto first_time;
 | |
|               for (;;) {
 | |
|                     // determine next operation
 | |
|                     /* ... */
 | |
|                     if (need to reinitialize) {
 | |
|                           // reinitialize-only code
 | |
|                           /* ... */
 | |
|                     first_time:
 | |
|                           // general initialization code
 | |
|                           /* ... */
 | |
|                           continue;
 | |
|                     }
 | |
|                       // handle other operations
 | |
|                       /* ... */
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.6.1p4'></a>
 | |
| <pre>4   EXAMPLE 2 A goto statement is not allowed to jump past any declarations of objects with variably modified types. A jump
 | |
|     within the scope, however, is permitted.
 | |
| 
 | |
|               goto lab3;                        // invalid:       going INTO scope of VLA.
 | |
|               {
 | |
|                     double a[n];
 | |
|                     a[j] = 4.4;
 | |
|               lab3:
 | |
|                     a[j] = <a href='#3.3'>3.3</a>;
 | |
|                     goto lab4;                  // valid:      going WITHIN scope of VLA.
 | |
|                     a[j] = 5.5;
 | |
|               lab4:
 | |
|                     a[j] = <a href='#6.6'>6.6</a>;
 | |
|               }
 | |
|               goto lab4;                        // invalid:       going INTO scope of VLA.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.6.2'></a>
 | |
| <hr>
 | |
| <h3>6.8.6.2 [The continue statement]</h3>
 | |
| <a name='6.8.6.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    A continue statement shall appear only in or as a loop body.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.6.2p2'></a>
 | |
| <pre>2   A continue statement causes a jump to the loop-continuation portion of the smallest enclosing
 | |
|     iteration statement; that is, to the end of the loop body. More precisely, in each of the statements
 | |
| 
 | |
| 
 | |
|            while (/* ...        */) {             do {                                  for (/* ... */) {
 | |
|               /* ... */                              /* ... */                             /* ... */
 | |
|               continue;                              continue;                             continue;
 | |
|               /* ... */                              /* ... */                             /* ... */
 | |
|            contin:                                contin:                               contin:
 | |
|            }                                      } while (/* ...         */);          }
 | |
| 
 | |
| 
 | |
| 
 | |
|     unless the continue statement shown is in an enclosed iteration statement (in which case it is
 | |
|     interpreted within that statement), it is equivalent to goto contin;.<a href='#FOOTNOTE.203'><sup>[203]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.203'>
 | |
| <pre><i><b>Footnote 203)</b> Following the contin: label in the 2nd example is a null statement. The null statement in the first and third example is
 | |
|     implied by the label (<a href='#6.8.2'>6.8.2</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.8.6.3'></a>
 | |
| <hr>
 | |
| <h3>6.8.6.3 [The break statement]</h3>
 | |
| <a name='6.8.6.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|    A break statement shall appear only in or as a switch body or loop body.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.6.3p2'></a>
 | |
| <pre>2   A break statement terminates execution of the smallest enclosing switch or iteration statement.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.8.6.4'></a>
 | |
| <hr>
 | |
| <h3>6.8.6.4 [The return statement]</h3>
 | |
| <a name='6.8.6.4p1'></a>
 | |
| <pre>1 Constraints
 | |
|    A return statement with an expression shall not appear in a function whose return type is void. A
 | |
|     return statement without an expression shall only appear in a function whose return type is void .
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.8.6.4p2'></a>
 | |
| <pre>2   A return statement terminates execution of the current function and returns control to its caller. A
 | |
|     function may have any number of return statements.
 | |
| </pre>
 | |
| <a name='6.8.6.4p3'></a>
 | |
| <pre>3   If a return statement with an expression is executed, the value of the expression is returned to the
 | |
|     caller as the value of the function call expression. If the expression has a type different from the
 | |
|     return type of the function in which it appears, the value is converted as if by assignment to an
 | |
|     object having the return type of the function.<a href='#FOOTNOTE.204'><sup>[204]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.204'>
 | |
| <pre><i><b>Footnote 204)</b> The return statement is not an assignment. The overlap restriction of <a href='#6.5.16.1'>6.5.16.1</a> does not apply to the case of function
 | |
|     return. The representation of floating-point values can have wider range or precision than implied by the type; a cast can be
 | |
|     used to remove this extra range and precision.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.8.6.4p4'></a>
 | |
| <pre>4   EXAMPLE In:
 | |
| 
 | |
|               struct s { double i; } f(void);
 | |
|               union {
 | |
|                     struct {
 | |
|                           int f1;
 | |
|                           struct s f2;
 | |
|                     } u1;
 | |
|                     struct {
 | |
|                           struct s f3;
 | |
|                           int f4;
 | |
|                     } u2;
 | |
|               } g;
 | |
| 
 | |
|               struct s f(void)
 | |
|               {
 | |
|                     return g.u1.f2;
 | |
|               }
 | |
| 
 | |
|               /* ... */
 | |
|               g.u2.f3 = f();
 | |
| 
 | |
|     there is no undefined behavior, although there would be if the assignment were done directly (without using a function call
 | |
|     to fetch the value).
 | |
| </pre>
 | |
| <a name='6.9'></a>
 | |
| <hr>
 | |
| <h3>6.9 [External definitions]</h3>
 | |
| <a name='6.9p1'></a>
 | |
| <pre>1 Syntax
 | |
|     translation-unit:
 | |
|                             external-declaration
 | |
|                             translation-unit external-declaration
 | |
| 
 | |
|       external-declaration:
 | |
|                          function-definition
 | |
|                          declaration
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.9p2'></a>
 | |
| <pre>2   The storage-class specifier register shall not appear in the declaration specifiers in an external
 | |
|     declaration.
 | |
| </pre>
 | |
| <a name='6.9p3'></a>
 | |
| <pre>3   There shall be no more than one external definition for each identifier declared with internal linkage
 | |
|     in a translation unit. Moreover, if an identifier declared with internal linkage is used in an expression
 | |
|     there shall be exactly one external definition for the identifier in the translation unit, unless it is:
 | |
| 
 | |
|           — part of the operand of a sizeof operator whose result is an integer constant;
 | |
| 
 | |
|           — part of the operand of an alignof operator whose result is an integer constant;
 | |
| 
 | |
|           — or, part of the operand of any typeof operator whose result is not a variably modified type.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.9p4'></a>
 | |
| <pre>4   As discussed in <a href='#5.1.1.1'>5.1.1.1</a>, the unit of program text after preprocessing is a translation unit, which
 | |
|     consists of a sequence of external declarations. These are described as "external" because they
 | |
|     appear outside any function (and hence have file scope). As discussed in <a href='#6.7'>6.7</a>, a declaration that also
 | |
|     causes storage to be reserved for an object or a function named by the identifier is a definition.
 | |
| </pre>
 | |
| <a name='6.9p5'></a>
 | |
| <pre>5   An external definition is an external declaration that is also a definition of a function (other than an
 | |
|     inline definition) or an object. If an identifier declared with external linkage is used in an expression
 | |
|     (other than as part of the operand of a typeof operator whose result is not a variably modified type,
 | |
|     or a sizeof or alignof operator whose result is an integer constant expression), somewhere in the
 | |
|     entire program there shall be exactly one external definition for the identifier; otherwise, there shall
 | |
|     be no more than one<a href='#FOOTNOTE.205'><sup>[205]</sup></a> .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.205'>
 | |
| <pre><i><b>Footnote 205)</b> Thus, if an identifier declared with external linkage is not used in an expression, there need be no external definition for
 | |
|     it.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.9.1'></a>
 | |
| <hr>
 | |
| <h3>6.9.1 [Function definitions]</h3>
 | |
| <a name='6.9.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     function-definition:
 | |
|                          attribute-specifier-sequenceopt declaration-specifiers declarator function-body
 | |
| 
 | |
|       function-body:
 | |
|                             compound-statement
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.9.1p2'></a>
 | |
| <pre>2   The identifier declared in a function definition (which is the name of the function) shall have a
 | |
|     function type, as specified by the declarator portion of the function definition.
 | |
| </pre>
 | |
| <a name='6.9.1p3'></a>
 | |
| <pre>3   The return type of a function shall be void or a complete object type other than array type.
 | |
| </pre>
 | |
| <a name='6.9.1p4'></a>
 | |
| <pre>4   The storage-class specifier, if any, in the declaration specifiers shall be either extern or static.
 | |
| </pre>
 | |
| <a name='6.9.1p5'></a>
 | |
| <pre>5    If the parameter list consists of a single parameter of type void, the parameter declarator shall not
 | |
|      include an identifier.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.9.1p6'></a>
 | |
| <pre>6    The optional attribute specifier sequence in a function definition appertains to the function.
 | |
| </pre>
 | |
| <a name='6.9.1p7'></a>
 | |
| <pre>7    The declarator in a function definition specifies the name of the function being defined and the
 | |
|      types (and optionally the names) of all the parameters; the declarator also serves as a function
 | |
|      prototype for later calls to the same function in the same translation unit. The type of each parameter
 | |
|      is adjusted as described in <a href='#6.7.6.3'>6.7.6.3</a>.
 | |
| </pre>
 | |
| <a name='6.9.1p8'></a>
 | |
| <pre>8    If a function that accepts a variable number of arguments is defined without a parameter type list
 | |
|      that ends with the ellipsis notation, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.9.1p9'></a>
 | |
| <pre>9    The parameter type list, the attribute specifier sequence of the declarator that follows the parameter
 | |
|      type list, and the compound statement of the function body form a single block<a href='#FOOTNOTE.206'><sup>[206]</sup></a> . Each parameter
 | |
|      has automatic storage duration; its identifier, if any<a href='#FOOTNOTE.207'><sup>[207]</sup></a> , is an lvalue<a href='#FOOTNOTE.208'><sup>[208]</sup></a> . The layout of the storage for
 | |
|      parameters is unspecified.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.206'>
 | |
| <pre><i><b>Footnote 206)</b> The visibility scope of a parameter in a function definition starts when its declaration is completed, extends to following
 | |
|      parameter declarations, to possible attributes that follow the parameter type list, and then to the entire function body. The
 | |
|      lifetime of each instance of a parameter starts when the declaration is evaluated starting a call and ends when that call
 | |
|      terminates.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.207'>
 | |
| <pre><i><b>Footnote 207)</b> A parameter that has no declared name is inaccessible within the function body.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.208'>
 | |
| <pre><i><b>Footnote 208)</b> A parameter identifier cannot be redeclared in the function body except in an enclosed block.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.9.1p10'></a>
 | |
| <pre>10   On entry to the function, the size expressions of each variably modified parameter are evaluated
 | |
|      and the value of each argument expression is converted to the type of the corresponding parameter
 | |
|      as if by assignment. (Array expressions and function designators as arguments were converted to
 | |
|      pointers before the call.)
 | |
| </pre>
 | |
| <a name='6.9.1p11'></a>
 | |
| <pre>11   After all parameters have been assigned, the compound statement of the function body is executed.
 | |
| </pre>
 | |
| <a name='6.9.1p12'></a>
 | |
| <pre>12   Unless otherwise specified, if the } that terminates the function body is reached, and the value of the
 | |
|      function call is used by the caller, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='6.9.1p13'></a>
 | |
| <pre>13   NOTE In a function definition, the type of the function and its prototype cannot be inherited from a typedef:
 | |
| 
 | |
|                typedef int F(void);                          // type F is "function with no parameters
 | |
|                                                              // returning int"
 | |
|                F f, g;                                       // f and g both have type compatible with F
 | |
|                F f { /* ... */ }                             // WRONG: syntax/constraint error
 | |
|                F g() { /* ... */ }                           // WRONG: declares that g returns a function
 | |
|                int f(void) { /* ... */ }                     // RIGHT: f has type compatible with F
 | |
|                int g() { /* ... */ }                         // RIGHT: g has type compatible with F
 | |
|                F *e(void) { /* ... */ }                      // e returns a pointer to a function
 | |
|                F *((e))(void) { /* ... */ }                  // same: parentheses irrelevant
 | |
|                int (*fp)(void);                              // fp points to a function that has type F
 | |
|                F *Fp;                                        // Fp points to a function that has type F
 | |
| 
 | |
| </pre>
 | |
| <a name='6.9.1p14'></a>
 | |
| <pre>14   EXAMPLE 1 In the following:
 | |
| 
 | |
|                extern int max(int a, int b)
 | |
|                {
 | |
|                      return a > b ? a: b;
 | |
|                }
 | |
| 
 | |
|      extern is the storage-class specifier and int is the type specifier; max(int a, int b) is the function declarator; and
 | |
| 
 | |
|                { return a       >   b ? a: b; }
 | |
| 
 | |
|      is the function body.
 | |
| </pre>
 | |
| <a name='6.9.1p15'></a>
 | |
| <pre>15   EXAMPLE 2 To pass one function to another, one might say
 | |
| 
 | |
|                         int f(void);
 | |
|                         /* ... */
 | |
|                         g(f);
 | |
| 
 | |
|     Then the definition of g might read
 | |
| 
 | |
|               void g(int (*funcp)(void))
 | |
|               {
 | |
|                     /* ... */
 | |
|                     (*funcp)(); /* or funcp(); ...*/
 | |
|               }
 | |
| 
 | |
|     or, equivalently,
 | |
| 
 | |
|               void g(int func(void))
 | |
|               {
 | |
|                     /* ... */
 | |
|                     func(); /* or (*func)(); ...*/
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.9.2'></a>
 | |
| <hr>
 | |
| <h3>6.9.2 [External object definitions]</h3>
 | |
| <a name='6.9.2p1'></a>
 | |
| <pre>1 Semantics
 | |
|    If the declaration of an identifier for an object has file scope and an initializer, the declaration is an
 | |
|     external definition for the identifier.
 | |
| </pre>
 | |
| <a name='6.9.2p2'></a>
 | |
| <pre>2   A declaration of an identifier for an object that has file scope without an initializer, and without a
 | |
|     storage-class specifier or with the storage-class specifier static, constitutes a tentative definition. If a
 | |
|     translation unit contains one or more tentative definitions for an identifier, and the translation unit
 | |
|     contains no external definition for that identifier, then the behavior is exactly as if the translation
 | |
|     unit contains a file scope declaration of that identifier, with the composite type as of the end of the
 | |
|     translation unit, with an initializer equal to { 0 } .
 | |
| </pre>
 | |
| <a name='6.9.2p3'></a>
 | |
| <pre>3   If the declaration of an identifier for an object is a tentative definition and has internal linkage, the
 | |
|     declared type shall not be an incomplete type.
 | |
| </pre>
 | |
| <a name='6.9.2p4'></a>
 | |
| <pre>4   EXAMPLE 1
 | |
| 
 | |
|               int i1 = 1;                 // definition, external linkage
 | |
|               static int i2 = 2;          // definition, internal linkage
 | |
|               extern int i3 = 3;          // definition, external linkage
 | |
|               int i4;                     // tentative definition, external linkage
 | |
|               static int i5;              // tentative definition, internal linkage
 | |
| 
 | |
|               int i1;                     // valid tentative definition, refers to previous
 | |
|               int i2;                     // <a href='#6.2.2'>6.2.2</a> renders undefined, linkage disagreement
 | |
|               int i3;                     // valid tentative definition, refers to previous
 | |
|               int i4;                     // valid tentative definition, refers to previous
 | |
|               int i5;                     // <a href='#6.2.2'>6.2.2</a> renders undefined, linkage disagreement
 | |
| 
 | |
|               extern int i1;              // refers to previous, whose linkage is external
 | |
|               extern int i2;              // refers to previous, whose linkage is internal
 | |
|               extern int i3;              // refers to previous, whose linkage is external
 | |
|               extern int i4;              // refers to previous, whose linkage is external
 | |
|               extern int i5;              // refers to previous, whose linkage is internal
 | |
| 
 | |
| </pre>
 | |
| <a name='6.9.2p5'></a>
 | |
| <pre>5   EXAMPLE 2 If at the end of the translation unit containing
 | |
| 
 | |
|               int i[];
 | |
| 
 | |
|     the array i still has incomplete type, the implicit initializer causes it to have one element, which is set to zero on program
 | |
|     startup.
 | |
| </pre>
 | |
| <a name='6.10'></a>
 | |
| <hr>
 | |
| <h3>6.10 [Preprocessing directives]</h3>
 | |
| <a name='6.10p1'></a>
 | |
| <pre>1 Syntax
 | |
|    preprocessing-file:
 | |
|                           groupopt
 | |
|     group:
 | |
|                           group-part
 | |
|                           group group-part
 | |
|     group-part:
 | |
|                           if-section
 | |
|                           control-line
 | |
|                           text-line
 | |
|                           # non-directive
 | |
|     if-section:
 | |
|                           if-group elif-groupsopt else-groupopt endif-line
 | |
|     if-group:
 | |
|                           # if constant-expression new-line groupopt
 | |
|                           # ifdef identifier new-line groupopt
 | |
|                           # ifndef identifier new-line groupopt
 | |
|     elif-groups:
 | |
|                           elif-group
 | |
|                           elif-groups elif-group
 | |
|     elif-group:
 | |
|                           # elif constant-expression new-line groupopt
 | |
|                           # elifdef identifier new-line groupopt
 | |
|                           # elifndef identifier new-line groupopt
 | |
|     else-group:
 | |
|                           # else new-line groupopt
 | |
|     endif-line:
 | |
|                           # endif new-line
 | |
|     control-line:
 | |
|                           # include pp-tokens new-line
 | |
|                           # embed pp-tokens new-line
 | |
|                           # define identifier replacement-list new-line
 | |
|                           # define identifier lparen identifier-listopt ) replacement-list new-line
 | |
|                           # define identifier lparen ... ) replacement-list new-line
 | |
|                           # define identifier lparen identifier-list , ... ) replacement-list new-line
 | |
|                           # undef identifier new-line
 | |
|                           # line pp-tokens new-line
 | |
|                           # error pp-tokensopt new-line
 | |
|                           # warning pp-tokensopt new-line
 | |
|                           # pragma pp-tokensopt new-line
 | |
|                           # new-line
 | |
| 
 | |
| 
 | |
|     text-line:
 | |
|                           pp-tokensopt new-line
 | |
| 
 | |
|     non-directive:
 | |
|                           pp-tokens new-line
 | |
| 
 | |
|     lparen:
 | |
|                           a ( character not immediately preceded by white space
 | |
| 
 | |
|     replacement-list:
 | |
|                           pp-tokensopt
 | |
|     pp-tokens:
 | |
|                             preprocessing-token
 | |
|                             pp-tokens preprocessing-token
 | |
| 
 | |
|     new-line:
 | |
|                            the new-line character
 | |
| 
 | |
|     identifier-list:
 | |
|                             identifier
 | |
|                             identifier-list , identifier
 | |
| 
 | |
|     pp-parameter:
 | |
|                             pp-parameter-name pp-parameter-clauseopt
 | |
| 
 | |
|     pp-parameter-name:
 | |
|                      pp-standard-parameter
 | |
|                      pp-prefixed-parameter
 | |
| 
 | |
|     pp-standard-parameter:
 | |
|                       identifier
 | |
| 
 | |
|     pp-prefixed-parameter:
 | |
|                        identifier :: identifier
 | |
| 
 | |
|     pp-parameter-clause:
 | |
|                             ( pp-balanced-token-sequenceopt )
 | |
| 
 | |
| 
 | |
|     pp-balanced-token-sequence:
 | |
|                         pp-balanced-token
 | |
|     pp-balanced-token-sequence pp-balanced-token
 | |
| 
 | |
|     pp-balanced-token:
 | |
|                             ( pp-balanced-token-sequenceopt )
 | |
|                             [ pp-balanced-token-sequenceopt ]
 | |
|                             { pp-balanced-token-sequenceopt }
 | |
|                             any pp-token other than a parenthesis, a bracket, or a brace
 | |
| 
 | |
|     embed-parameter-sequence:
 | |
|                       pp-parameter
 | |
|                       embed-parameter-sequence pp-parameter
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.10p2'></a>
 | |
| <pre>2   A preprocessing directive consists of a sequence of preprocessing tokens that satisfies the following
 | |
|     constraints: The first token in the sequence is a # preprocessing token that (at the start of translation
 | |
|     phase 4) is either the first character in the source file (optionally after white space containing no
 | |
|     new-line characters) or that follows white space containing at least one new-line character. The last
 | |
|     token in the sequence is the first new-line character that follows the first token in the sequence. <a href='#FOOTNOTE.209'><sup>[209]</sup></a>
 | |
|      A new-line character ends the preprocessing directive even if it occurs within what would otherwise
 | |
|      be an invocation of a function-like macro.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.209'>
 | |
| <pre><i><b>Footnote 209)</b> Thus, preprocessing directives are commonly called "lines". These "lines" have no other syntactic significance, as all
 | |
|     white space is equivalent except in certain situations during preprocessing (see the # character string literal creation operator
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10p3'></a>
 | |
| <pre>3    A text line shall not begin with a # preprocessing token. A non-directive shall not begin with any of
 | |
|      the directive names appearing in the syntax.
 | |
| </pre>
 | |
| <a name='6.10p4'></a>
 | |
| <pre>4    Some preprocessing directives take additional information by the use of preprocessor parameters.
 | |
|      A preprocessing parameter (pp-parameter) shall be either a preprocessor prefixed parameter (identified
 | |
|      by a pp-prefixed-parameter, for implementation-defined preprocessor parameters) or a preprocessor
 | |
|      standard parameter (identified with a pp-standard-parameter, for pp-parameters specified by this
 | |
|      document).
 | |
| </pre>
 | |
| <a name='6.10p5'></a>
 | |
| <pre>5    In all aspects, a preprocessor standard parameter specified by this document as an identifier pp_param
 | |
|      and an identifier of the form __pp_param__ shall behave the same when used as a preprocessor
 | |
|      parameter, except for the spelling.
 | |
| </pre>
 | |
| <a name='6.10p6'></a>
 | |
| <pre>6    EXAMPLE 1 Thus, the preprocessor parameters on the two binary resource inclusion directives (<a href='#6.10.3.1'>6.10.3.1</a>):
 | |
| 
 | |
|                #embed "boop.h" limit(5)
 | |
|                #embed "boop.h" __limit__(5)
 | |
| 
 | |
|      behave the same, and can be freely interchanged. Implementations are encouraged to behave similarly for preprocessor
 | |
|      parameters (including preprocessor prefixed parameters) they provide.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10p7'></a>
 | |
| <pre>7    When in a group that is skipped (<a href='#6.10.1'>6.10.1</a>), the directive syntax is relaxed to allow any sequence of
 | |
|      preprocessing tokens to occur between the directive name and the following new-line character.
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.10p8'></a>
 | |
| <pre>8    The only white-space characters that shall appear between preprocessing tokens within a prepro-
 | |
|      cessing directive (from just after the introducing # preprocessing token through just before the
 | |
|      terminating new-line character) are space and horizontal-tab (including spaces that have replaced
 | |
|      comments or possibly other white-space characters in translation phase 3).
 | |
| </pre>
 | |
| <a name='6.10p9'></a>
 | |
| <pre>9    A preprocessor parameter shall be either a preprocessor standard parameter, or an implementation-
 | |
|      defined preprocessor prefixed parameter<a href='#FOOTNOTE.210'><sup>[210]</sup></a> .
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.210'>
 | |
| <pre><i><b>Footnote 210)</b> An unrecognized preprocessor prefixed parameter is a constraint violation, except within has_embed expressions (<a href='#6.10.1'>6.10.1</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10p10'></a>
 | |
| <pre>10   The implementation can process and skip sections of source files conditionally, include other source
 | |
|      files, and replace macros. These capabilities are called preprocessing, because conceptually they occur
 | |
|      before translation of the resulting translation unit.
 | |
| </pre>
 | |
| <a name='6.10p11'></a>
 | |
| <pre>11   The preprocessing tokens within a preprocessing directive are not subject to macro expansion unless
 | |
|      otherwise stated.
 | |
| </pre>
 | |
| <a name='6.10p12'></a>
 | |
| <pre>12   EXAMPLE In:
 | |
| 
 | |
|                         #define EMPTY
 | |
|                         EMPTY # include <file.h>
 | |
| 
 | |
|      the sequence of preprocessing tokens on the second line is not a preprocessing directive, because it does not begin with a # at
 | |
|      the start of translation phase 4, even though it will do so after the macro EMPTY has been replaced.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10p13'></a>
 | |
| <pre>13   The execution of a non-directive preprocessing directive results in undefined behavior.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1'></a>
 | |
| <hr>
 | |
| <h3>6.10.1 [Conditional inclusion]</h3>
 | |
| <a name='6.10.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|      defined-macro-expression:
 | |
|                              defined identifier
 | |
|                              defined ( identifier )
 | |
|      h-preprocessing-token:
 | |
|                         any preprocessing-token other than >
 | |
|      in <a href='#6.10.4.2'>6.10.4.2</a>, for example).
 | |
|     h-pp-tokens:
 | |
|                             h-preprocessing-token
 | |
|                             h-pp-tokens h-preprocessing-token
 | |
|     header-name-tokens:
 | |
|                         string-literal
 | |
|                         < h-pp-tokens >
 | |
|     has-include-expression:
 | |
|                             __has_include ( header-name )
 | |
|                             __has_include ( header-name-tokens )
 | |
|     has-embed-expression:
 | |
|                             __has_embed ( header-name embed-parameter-sequenceopt )
 | |
|                             __has_embed ( header-name-tokens pp-balanced-token-sequenceopt )
 | |
|     has-c-attribute-express:
 | |
|                             __has_c_attribute ( pp-tokens )
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.10.1p2'></a>
 | |
| <pre>2   The expression that controls conditional inclusion shall be an integer constant expression except that:
 | |
|     identifiers (including those lexically identical to keywords) are interpreted as described below<a href='#FOOTNOTE.211'><sup>[211]</sup></a>
 | |
|     and it may contain zero or more defined macro expressions, has_include expressions, has_embed
 | |
|     expressions, and/or has_c_attribute expressions as unary operator expressions.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.211'>
 | |
| <pre><i><b>Footnote 211)</b> Because the controlling constant expression is evaluated during translation phase 4, all identifiers either are or are not
 | |
|     macro names — there simply are no keywords, enumeration constants, etc.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.1p3'></a>
 | |
| <pre>3   A defined macro expression evaluates to 1 if the identifier is currently defined as a macro name (that
 | |
|     is, if it is predefined or if it has been the subject of a #define preprocessing directive without an
 | |
|     intervening #undef directive with the same subject identifier), 0 if it is not.
 | |
| </pre>
 | |
| <a name='6.10.1p4'></a>
 | |
| <pre>4   The second form of the has_include expression and has_embed expression is considered only if the
 | |
|     first form does not match, in which case the preprocessing tokens are processed just as in normal
 | |
|     text.
 | |
| </pre>
 | |
| <a name='6.10.1p5'></a>
 | |
| <pre>5   The header or source file identified by the parenthesized preprocessing token sequence in each
 | |
|     contained has_include expression is searched for as if that preprocessing token were the pp-tokens
 | |
|     in a #include directive, except that no further macro expansion is performed. Such a directive shall
 | |
|     satisfy the syntactic requirements of a #include directive. The has_include expression evaluates to
 | |
|     1 if the search for the source file succeeds, and to 0 if the search fails.
 | |
| </pre>
 | |
| <a name='6.10.1p6'></a>
 | |
| <pre>6   The resource (<a href='#6.10.3.1'>6.10.3.1</a>) identified by the header-name preprocessing token sequence in each contained
 | |
|     has_embed expression is searched for as if those preprocessing token were the pp-tokens in a #embed
 | |
|     directive, except that no further macro expansion is performed. Such a directive shall satisfy the
 | |
|     syntactic requirements of a #embed directive. The has_embed expression evaluates to:
 | |
| 
 | |
|       — 0 if the search fails or if any of the embed parameters in the embed parameter sequence
 | |
|         specified are not supported by the implementation for the #embed directive; or,
 | |
| 
 | |
|       — 1 if the search for the resource succeeds and all embed parameters in the embed parameter
 | |
|         sequence specified are supported by the implementation for the #embed directive and the
 | |
|         resource is not empty; or,
 | |
| 
 | |
|       — 2 if the search for the resource succeeds and all embed parameters in the embed parameter
 | |
|         sequence specified are supported by the implementation for the #embed directive and the
 | |
|         resource is empty.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1p7'></a>
 | |
| <pre>7   NOTE Unrecognized preprocessor prefixed parameters in has_embed expressions is not a constraint violation and instead
 | |
|     causes the expression to be evaluate to 0, as specified above.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1p8'></a>
 | |
| <pre>8   Each has_c_attribute expression is replaced by a nonzero pp-number matching the form of an integer
 | |
|     constant if the implementation supports an attribute with the name specified by interpreting the
 | |
|      pp-tokens as an attribute token, and by 0 otherwise. The pp-tokens shall match the form of an
 | |
|      attribute token.
 | |
| </pre>
 | |
| <a name='6.10.1p9'></a>
 | |
| <pre>9    Each preprocessing token that remains (in the list of preprocessing tokens that will become the
 | |
|      controlling expression) after all macro replacements have occurred shall be in the lexical form of a
 | |
|      token (<a href='#6.4'>6.4</a>).
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.10.1p10'></a>
 | |
| <pre>10   The #ifdef, #ifndef, #elifdef, and #elifndef, and the defined conditional inclusion operator,
 | |
|      shall treat __has_include and __has_c_attribute as if they were the name of defined macros.
 | |
|      The identifiers __has_include , __has_embed , and __has_c_attribute shall not appear in any
 | |
|      context not mentioned in this subclause.
 | |
| </pre>
 | |
| <a name='6.10.1p11'></a>
 | |
| <pre>11   Preprocessing directives of the forms
 | |
|                             # if   constant-expression new-line groupopt
 | |
|                             # elif constant-expression new-line groupopt
 | |
|      check whether the controlling constant expression evaluates to nonzero.
 | |
| </pre>
 | |
| <a name='6.10.1p12'></a>
 | |
| <pre>12   Prior to evaluation, macro invocations in the list of preprocessing tokens that will become the control-
 | |
|      ling constant expression are replaced (except for those macro names modified by the defined unary
 | |
|      operator), just as in normal text. If the token defined is generated as a result of this replacement
 | |
|      process or use of the defined unary operator does not match one of the two specified forms prior to
 | |
|      macro replacement, the behavior is undefined. After all replacements due to macro expansion and
 | |
|      evaluations of defined macro expressions, has_include expressions, and has_c_attribute expressions
 | |
|      have been performed, all remaining identifiers other than true (including those lexically identical
 | |
|      to keywords such as false) are replaced with the pp-number 0, true is replaced with pp-number
 | |
|      1 , and then each preprocessing token is converted into a token. The resulting tokens compose the
 | |
|      controlling constant expression which is evaluated according to the rules of <a href='#6.6'>6.6</a>. For the purposes of
 | |
|      this token conversion and evaluation, all signed integer types and all unsigned integer types act as
 | |
|      if they have the same representation as, respectively, the types intmax_t and uintmax_t defined
 | |
|      in the header <stdint.h>. <a href='#FOOTNOTE.212'><sup>[212]</sup></a> This includes interpreting character constants, which may involve
 | |
|      converting escape sequences into execution character set members. Whether the numeric value for
 | |
|      these character constants matches the value obtained when an identical character constant occurs in
 | |
|      an expression (other than within a #if or #elif directive) is implementation-defined<a href='#FOOTNOTE.213'><sup>[213]</sup></a> .
 | |
|      Also, whether a single-character character constant may have a negative value is implementation-
 | |
|      defined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.212'>
 | |
| <pre><i><b>Footnote 212)</b> Thus, on an implementation where INT_MAX is 0x7FFF and UINT_MAX is 0xFFFF, the constant 0x8000 is signed and
 | |
|      positive within a #if expression even though it would be unsigned in translation phase 7.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.213'>
 | |
| <pre><i><b>Footnote 213)</b> Thus, the constant expression in the following #if directive and if statement is not guaranteed to evaluate to the same
 | |
|      value in these two contexts.
 | |
|        #if ’z’ - ’a’ == 25
 | |
|        if (’z’ - ’a’ == 25)
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.1p13'></a>
 | |
| <pre>13   Preprocessing directives of the forms
 | |
|                             # ifdef identifier new-line groupopt
 | |
|                             # ifndef identifier new-line groupopt
 | |
|                             # elifdef identifier new-line groupopt
 | |
|                             # elifndef identifier new-line groupopt
 | |
|      check whether the identifier is or is not currently defined as a macro name. Their conditions
 | |
|      are equivalent to #if defined identifier, #if !defined identifier, #elif defined identifier, and
 | |
|      #elif !defined identifier respectively.
 | |
| </pre>
 | |
| <a name='6.10.1p14'></a>
 | |
| <pre>14   Each directive’s condition is checked in order. If it evaluates to false (zero), the group that it
 | |
|      controls is skipped: directives are processed only through the name that determines the directive
 | |
|      in order to keep track of the level of nested conditionals; the rest of the directives’ preprocessing
 | |
|      tokens are ignored, as are the other preprocessing tokens in the group. Only the first group whose
 | |
|      control condition evaluates to true (nonzero) is processed; any following groups are skipped and
 | |
|      their controlling directives are processed as if they were in a group that is skipped. If none of the
 | |
|      conditions evaluates to true, and there is a #else directive, the group controlled by the #else is
 | |
|      processed; lacking a #else directive, all the groups until the #endif are skipped. <a href='#FOOTNOTE.214'><sup>[214]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.214'>
 | |
| <pre><i><b>Footnote 214)</b> As indicated by the syntax, no preprocessing tokens are allowed to follow a #else or #endif directive before the
 | |
|      terminating new-line character. However, comments can appear anywhere in a source file, including within a preprocessing
 | |
|      directive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.1p15'></a>
 | |
| <pre>15   EXAMPLE This demonstrates a way to include a header file only if it is available.
 | |
| 
 | |
|       #if __has_include(<optional.h>)
 | |
|       #     include <optional.h>
 | |
|       #     define have_optional 1
 | |
|       #elif __has_include(<experimental/optional.h>)
 | |
|       #     include <experimental/optional.h>
 | |
|       #     define have_optional 1
 | |
|       #     define have_experimental_optional 1
 | |
|       #endif
 | |
|       #ifndef have_optional
 | |
|       #     define have_optional 0
 | |
|       #endif
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1p16'></a>
 | |
| <pre>16   EXAMPLE
 | |
| 
 | |
|       /* Fallback for compilers not yet implementing this feature. */
 | |
|       #ifndef __has_c_attribute
 | |
|       #define __has_c_attribute(x) 0
 | |
|       #endif /* __has_c_attribute */
 | |
| 
 | |
|       #if __has_c_attribute(fallthrough)
 | |
|       /* Standard attribute is available, use it. */
 | |
|       #define FALLTHROUGH [[fallthrough]]
 | |
|       #elif __has_c_attribute(vendor::fallthrough)
 | |
|       /* Vendor attribute is available, use it. */
 | |
|       #define FALLTHROUGH [[vendor::fallthrough]]
 | |
|       #else
 | |
|       /* Fallback implementation. */
 | |
|       #define FALLTHROUGH
 | |
|       #endif
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1p17'></a>
 | |
| <pre>17   EXAMPLE
 | |
| 
 | |
|       #ifdef __STDC__
 | |
|       #define TITLE "ISO C Compilation"
 | |
|       #elifndef __cplusplus
 | |
|       #define TITLE "Non-ISO C Compilation"
 | |
|       #else
 | |
|       /* C++ */
 | |
|       #define TITLE "C++ Compilation"
 | |
|       #endif
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1p18'></a>
 | |
| <pre>18   EXAMPLE 1 A combination of __FILE__ (<a href='#6.10.9.1'>6.10.9.1</a>) and __has_embed could be used to check for support of specific implemen-
 | |
|      tation extensions for the #embed (<a href='#6.10.3.1'>6.10.3.1</a>) directive’s parameters.
 | |
| 
 | |
|                #if __has_embed(__FILE__ ext::token(0xB055))
 | |
|                #define DESCRIPTION "Supports extended token embed"
 | |
|                #else
 | |
|                #define DESCRIPTION "Does not support extended token embed"
 | |
|                #endif
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1p19'></a>
 | |
| <pre>19   EXAMPLE 2 The below snippet uses __has_embed to check for support of a specific implementation-defined embed
 | |
|      parameter, and otherwise uses standard behavior to produce the same effect.
 | |
|               void parse_into_s(short* ptr, unsigned char* ptr_bytes, unsigned long long size);
 | |
| 
 | |
|               int main () {
 | |
|               #if __has_embed ("bits.bin" ds9000::element_type(short))
 | |
|                     /* Implementation extension: create short integers from the */
 | |
|                     /* translation environment resource into */
 | |
|                     /* a sequence of integer constants */
 | |
|                     short meow[] = {
 | |
|               #embed "bits.bin" ds9000::element_type(short)
 | |
|                     };
 | |
|               #elif __has_embed ("bits.bin")
 | |
|                     /* no support for implementation-specific */
 | |
|                     /* ds9000::element_type(short) parameter */
 | |
|                     const unsigned char meow_bytes[] = {
 | |
|               #embed "bits.bin"
 | |
|                     };
 | |
|                     short meow[sizeof(meow_bytes) / sizeof(short)] = {};
 | |
|                     /* parse meow_bytes into short values by-hand! */
 | |
|                     parse_into_s(meow, meow_bytes, sizeof(meow_bytes));
 | |
|               #else
 | |
|               #error "cannot find bits.bin resource"
 | |
|               #endif
 | |
|                     return (int)(meow[0] + meow[(sizeof(meow) / sizeof(*meow)) - 1]);
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.1p20'></a>
 | |
| <pre>20   EXAMPLE 3 This resource is considered empty due to the limit(0) embed parameter, always, including in __has_embed
 | |
|      expressions.
 | |
| 
 | |
|               int main () {
 | |
|               #if __has_embed(</owo/uwurandom> limit(0)) == 2
 | |
|                     // if </owo/uwurandom> exits, this
 | |
|                     // token sequence is always taken.
 | |
|                     return 0;
 | |
|               #else
 | |
|                     // the resource does not exist
 | |
|                     #error "The resource does not exist"
 | |
|               #endif
 | |
|               }
 | |
| 
 | |
| 
 | |
|      Forward references: macro replacement (<a href='#6.10.4'>6.10.4</a>), source file inclusion (<a href='#6.10.2'>6.10.2</a>), mandatory macros
 | |
|      (<a href='#6.10.9.1'>6.10.9.1</a>), largest integer types (<a href='#7.22.1.5'>7.22.1.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.2'></a>
 | |
| <hr>
 | |
| <h3>6.10.2 [Source file inclusion]</h3>
 | |
| <a name='6.10.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|     A #include directive shall identify a header or source file that can be processed by the implementa-
 | |
|      tion.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.10.2p2'></a>
 | |
| <pre>2    A preprocessing directive of the form
 | |
| 
 | |
| 
 | |
|                           # include < h-char-sequence > new-line
 | |
|      searches a sequence of implementation-defined places for a header identified uniquely by the
 | |
|      specified sequence between the < and > delimiters, and causes the replacement of that directive
 | |
|      by the entire contents of the header. How the places are specified or the header identified is
 | |
|      implementation-defined.
 | |
| </pre>
 | |
| <a name='6.10.2p3'></a>
 | |
| <pre>3    A preprocessing directive of the form
 | |
|                             # include " q-char-sequence " new-line
 | |
|     causes the replacement of that directive by the entire contents of the source file identified by
 | |
|     the specified sequence between the " delimiters. The named source file is searched for in an
 | |
|     implementation-defined manner. If this search is not supported, or if the search fails, the directive is
 | |
|     reprocessed as if it read
 | |
|                             # include < h-char-sequence > new-line
 | |
|     with the identical contained sequence (including > characters, if any) from the original directive.
 | |
| </pre>
 | |
| <a name='6.10.2p4'></a>
 | |
| <pre>4   A preprocessing directive of the form
 | |
|                             # include pp-tokens new-line
 | |
|     (that does not match one of the two previous forms) is permitted. The preprocessing tokens after
 | |
|     include in the directive are processed just as in normal text. (Each identifier currently defined as a
 | |
|     macro name is replaced by its replacement list of preprocessing tokens.) The directive resulting after
 | |
|     all replacements shall match one of the two previous forms.<a href='#FOOTNOTE.215'><sup>[215]</sup></a> The method by which a sequence
 | |
|     of preprocessing tokens between a < and a > preprocessing token pair or a pair of " characters is
 | |
|     combined into a single header name preprocessing token is implementation-defined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.215'>
 | |
| <pre><i><b>Footnote 215)</b> Note that adjacent string literals are not concatenated into a single string literal (see the translation phases in <a href='#5.1.1.2'>5.1.1.2</a>);
 | |
|     thus, an expansion that results in two string literals is an invalid directive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.2p5'></a>
 | |
| <pre>5   The implementation shall provide unique mappings for sequences consisting of one or more nondig-
 | |
|     its or digits (<a href='#6.4.2.1'>6.4.2.1</a>) followed by a period (.) and a single nondigit. The first character shall not be a
 | |
|     digit. The implementation may ignore distinctions of alphabetical case and restrict the mapping to
 | |
|     eight significant characters before the period.
 | |
| </pre>
 | |
| <a name='6.10.2p6'></a>
 | |
| <pre>6   A #include preprocessing directive may appear in a source file that has been read because of a
 | |
|     #include directive in another file, up to an implementation-defined nesting limit (see <a href='#5.2.4.1'>5.2.4.1</a>).
 | |
| </pre>
 | |
| <a name='6.10.2p7'></a>
 | |
| <pre>7   EXAMPLE 1 The most common uses of #include preprocessing directives are as in the following:
 | |
| 
 | |
|               #include <stdio.h>
 | |
|               #include "myprog.h"
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.2p8'></a>
 | |
| <pre>8   EXAMPLE 2 This illustrates macro-replaced #include directives:
 | |
| 
 | |
|               #if VERSION == 1
 | |
|                     #define INCFILE             "vers1.h"
 | |
|               #elif VERSION == 2
 | |
|                     #define INCFILE             "vers2.h"         // and so on
 | |
|               #else
 | |
|                     #define INCFILE             "versN.h"
 | |
|               #endif
 | |
|               #include INCFILE
 | |
| 
 | |
| 
 | |
|     Forward references: macro replacement (<a href='#6.10.4'>6.10.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3'></a>
 | |
| <hr>
 | |
| <h3>6.10.3 [Binary resource inclusion]</h3>
 | |
| <a name='6.10.3.1'></a>
 | |
| <hr>
 | |
| <h3>6.10.3.1 [#embed preprocessing directive]</h3>
 | |
| <a name='6.10.3.1p1'></a>
 | |
| <pre>1 Description
 | |
|    A resource is a source of data accessible from the translation environment. An embed parameter is a
 | |
|     single preprocessor parameter in the embed parameter sequence. It has an implementation resource
 | |
|     width, which is the implementation-defined size in bits of the located resource. It also has a resource
 | |
|     width, which is either:
 | |
| 
 | |
|        — the number of bits as computed from the optionally-provided limit embed parameter (??), if
 | |
|          present; or,
 | |
|        — the implementation resource width.
 | |
| </pre>
 | |
| <a name='6.10.3.1p2'></a>
 | |
| <pre>2    An embed parameter sequence is a whitespace-delimited list of preprocessor parameters which may
 | |
|      modify the result of the replacement for the #embed preprocessing directive.
 | |
| 
 | |
|      Constraints
 | |
| </pre>
 | |
| <a name='6.10.3.1p3'></a>
 | |
| <pre>3    An #embed directive shall identify a resource that can be processed by the implementation as a
 | |
|      binary data sequence given the provided embed parameters.
 | |
| </pre>
 | |
| <a name='6.10.3.1p4'></a>
 | |
| <pre>4    Embed parameters not specified in this document shall be implementation-defined. Implementation-
 | |
|      defined embed parameters may change the below-defined semantics of the directive; otherwise,
 | |
|      #embed directives which do not contain implementation-defined embed parameters shall behave as
 | |
|      described in this document.
 | |
| </pre>
 | |
| <a name='6.10.3.1p5'></a>
 | |
| <pre>5    A resource is considered empty when its resource width is zero.
 | |
| </pre>
 | |
| <a name='6.10.3.1p6'></a>
 | |
| <pre>6    Let embed element width be either:
 | |
| 
 | |
|        — an integer constant expression greater than zero determined by an implementation-defined
 | |
|          embed parameter; or,
 | |
|        — CHAR_BIT (<a href='#5.2.4.2.1'>5.2.4.2.1</a>).
 | |
| 
 | |
|      The result of (resource width) % (embed element width) shall be zero<a href='#FOOTNOTE.216'><sup>[216]</sup></a> .
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='FOOTNOTE.216'>
 | |
| <pre><i><b>Footnote 216)</b> This constraint helps ensure data is neither filled with padding values nor truncated in a given environment, and helps
 | |
|      ensure the data is portable with respect to usages of memcpy (<a href='#7.26.2.1'>7.26.2.1</a>) with character type arrays initialized from the data.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.3.1p7'></a>
 | |
| <pre>7    The expansion of a #embed directive is a token sequence formed from the list of integer constant
 | |
|      expressions described below. The group of tokens for each integer constant expression in the list
 | |
|      is separated in the token sequence from the group of tokens for the previous integer constant
 | |
|      expression in the list by a comma. The sequence neither begins nor ends in a comma. If the list of
 | |
|      integer constant expressions is empty, the token sequence is empty. The directive is replaced by its
 | |
|      expansion and, with the presence of certain embed parameters, additional or replacement token
 | |
|      sequences.
 | |
| </pre>
 | |
| <a name='6.10.3.1p8'></a>
 | |
| <pre>8    A preprocessing directive of the form
 | |
|                             # embed < h-char-sequence > embed-parameter-sequenceopt new-line
 | |
|      searches a sequence of implementation-defined places for a resource identified uniquely by the spec-
 | |
|      ified sequence between the < and > . The search for the named resource is done in an implementation-
 | |
|      defined manner.
 | |
| </pre>
 | |
| <a name='6.10.3.1p9'></a>
 | |
| <pre>9    A preprocessing directive of the form
 | |
|                             # embed " q-char-sequence " embed-parameter-sequenceopt new-line
 | |
|      searches a sequence of implementation-defined places for a resource identified uniquely by the
 | |
|      specified sequence between the " delimiters. The search for the named resource is done in an
 | |
|      implementation-defined manner. If this search is not supported, or if the search fails, the directive is
 | |
|      reprocessed as if it read
 | |
|                              # embed < h-char-sequence > embed-parameter-sequenceopt new-line
 | |
|      with the identical contained q-char-sequence (including > characters, if any) from the original
 | |
|      directive.
 | |
| </pre>
 | |
| <a name='6.10.3.1p10'></a>
 | |
| <pre>10   Either form of the #embed directive specified previously behave as specified below. The values of the
 | |
|      integer constant expressions in the expanded sequence is determined by an implementation-defined
 | |
|      mapping of the resource’s data. Each integer constant expression’s value is in the range from 0 to
 | |
|      (2embed element width ) − 1, inclusive<a href='#FOOTNOTE.217'><sup>[217]</sup></a> . If the list of integer constant expressions:
 | |
| 
 | |
|        — is used to initialize an array of a type compatible with unsigned char, or compatible with
 | |
|          char if char cannot hold negative values; or,
 | |
|         — the embed element width is equal to CHAR_BIT (??env-consider-characteristics-of-integer-
 | |
|           types-limits-h)),
 | |
| 
 | |
|      then the contents of the initialized elements of the array are as-if the resource’s binary data is fread
 | |
|      (<a href='#7.23.8.1'>7.23.8.1</a>) into the array at translation time.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.217'>
 | |
| <pre><i><b>Footnote 217)</b> For example, an embed element width of 8 will yield a range of values from 0 to 255, inclusive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.3.1p11'></a>
 | |
| <pre>11   A preprocessing directive of the form
 | |
|                              # embed pp-tokens new-line
 | |
|      (that does not match one of the two previous forms) is permitted. The preprocessing tokens after
 | |
|      embed in the directive are processed just as in normal text. (Each identifier currently defined as a
 | |
|      macro name is replaced by its replacement list of preprocessing tokens.) The directive resulting after
 | |
|      all replacements shall match one of the two previous forms<a href='#FOOTNOTE.218'><sup>[218]</sup></a> . The method by which a sequence
 | |
|      of preprocessing tokens between a < and a > preprocessing token pair or a pair of " characters is
 | |
|      combined into a single resource name preprocessing token is implementation-defined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.218'>
 | |
| <pre><i><b>Footnote 218)</b> Note that adjacent string literals are not concatenated into a single string literal (see the translation phases in <a href='#5.1.1.2'>5.1.1.2</a>);
 | |
|      thus, an expansion that results in two string literals is an invalid directive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.3.1p12'></a>
 | |
| <pre>12   An embed parameter with a preprocessor parameter token that is one of the following is a standard
 | |
|      embed parameter:
 | |
| 
 | |
|      limit                            prefix                           suffix                            if_empty
 | |
| 
 | |
| 
 | |
|      The significance of these standard embed parameters is specified below.
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='6.10.3.1p13'></a>
 | |
| <pre>13   The #embed directive is meant to translate binary data in resources to sequence of integer constant
 | |
|      expressions in a way that preserves the value of the resource’s bit stream where possible.
 | |
| </pre>
 | |
| <a name='6.10.3.1p14'></a>
 | |
| <pre>14   A mechanism similar to, but distinct from, the implementation-defined search paths used for source
 | |
|      file inclusion (<a href='#6.10.2'>6.10.2</a>) is encouraged.
 | |
| </pre>
 | |
| <a name='6.10.3.1p15'></a>
 | |
| <pre>15   Implementations should take into account translation-time bit and byte orders as well as execution
 | |
|      time bit and byte orders to more appropriately represent the resource’s binary data from the directive.
 | |
|      This maximizes the chance that, if the resource referenced at translation time through the #embed
 | |
|      directive is the same one accessed through execution-time means, the data that is e.g. fread or
 | |
|      similar into contiguous storage will compare bit-for-bit equal to an array of character type initialized
 | |
|      from an #embed directive’s expanded contents.
 | |
| </pre>
 | |
| <a name='6.10.3.1p16'></a>
 | |
| <pre>16   EXAMPLE 1 Placing a small image resource.
 | |
| 
 | |
|                #include <stddef.h>
 | |
| 
 | |
|                void have_you_any_wool(const unsigned char*, size_t);
 | |
| 
 | |
|                int main (int, char*[]) {
 | |
|                      static const unsigned char baa_baa[] = {
 | |
|                #embed "black_sheep.ico"
 | |
|                      };
 | |
| 
 | |
|                         have_you_any_wool(baa_baa, sizeof(baa_baa));
 | |
| 
 | |
|                         return 0;
 | |
|                }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.1p17'></a>
 | |
| <pre>17   EXAMPLE 2 This snippet:
 | |
| 
 | |
|                int main (int, char*[]) {
 | |
|                      static const unsigned char coefficients[] = {
 | |
|                #embed "only_8_bits.bin" // potential constraint violation
 | |
|                      };
 | |
|                         return 0;
 | |
|                }
 | |
| 
 | |
|      may violate the constraint that (resource width) % (embed element width) must be 0. The 8 bits might not be evenly
 | |
|      divisible by the embed element width (e.g., on a system where CHAR_BIT is 16). Issuing a diagnostic in this case may aid in
 | |
|      portability by calling attention to potentially incompatible expectations between implementations and their resources.
 | |
| </pre>
 | |
| <a name='6.10.3.1p18'></a>
 | |
| <pre>18   EXAMPLE 3 Initialization of non-arrays.
 | |
| 
 | |
|                int main () {
 | |
|                      /* Braces may be kept or elided as per normal initialization rules */
 | |
|                      int i = {
 | |
|                #embed "i.dat"
 | |
|                      }; /* i value is [0, 2^(embed element width)) first entry */
 | |
|                      int i2 =
 | |
|                #embed "i.dat"
 | |
|                      ; /* valid if i.dat produces 1 value,
 | |
|                            i2 value is [0, 2^(embed element width)) */
 | |
|                      struct s {
 | |
|                            double a, b, c;
 | |
|                            struct { double e, f, g; };
 | |
|                            double h, i, j;
 | |
|                      };
 | |
|                      struct s x = {
 | |
|                      /* initializes each element in
 | |
|                      order according to initialization rules with
 | |
|                      comma-separated list of integer constant expressions
 | |
|                      inside of braces */
 | |
|                #embed "s.dat"
 | |
|                      };
 | |
|                      return 0;
 | |
|                }
 | |
| 
 | |
|      Non-array types can still be initialized since the directive produces a comma-delimited lists of integer constant expressions, a
 | |
|      single integer constant expression, or nothing.
 | |
| </pre>
 | |
| <a name='6.10.3.1p19'></a>
 | |
| <pre>19   EXAMPLE 4 Equivalency of bit sequence and bit order between a translation-time read and an execution-time read of the
 | |
|      same resource/file.
 | |
| 
 | |
|                #include <string.h>
 | |
|                #include <stddef.h>
 | |
|                #include <stdio.h>
 | |
| 
 | |
|                int main() {
 | |
|                      static const unsigned char embed_data[] = {
 | |
|                #embed <data.dat>
 | |
|                      };
 | |
| 
 | |
|                         const size_t f_size = sizeof(embed_data);
 | |
|                         unsigned char f_data[f_size];
 | |
|                         FILE* f_source = fopen("data.dat", "rb");
 | |
|                         if (f_source == NULL);
 | |
|                               return 1;
 | |
|                         char* f_ptr = (char*)&f_data[0];
 | |
|                         if (fread(f_ptr, 1, f_size, f_source) != f_size) {
 | |
|                               fclose(f_source);
 | |
|                               return 1;
 | |
|                         }
 | |
|                         fclose(f_source);
 | |
| 
 | |
|                         int is_same = memcmp(&embed_data[0], f_ptr, f_size);
 | |
|                         // if both operations refers to the same resource/file at
 | |
|                         // execution time and translation time, "is_same" should be 0
 | |
|                      return is_same == 0 ? 0 : 1;
 | |
|              }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.2'></a>
 | |
| <hr>
 | |
| <h3>6.10.3.2 [limit parameter]</h3>
 | |
| <a name='6.10.3.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The limit standard embed parameter may appear zero times or one time in the embed parameter
 | |
|     sequence. Its preprocessor argument clause shall be present and have the form:
 | |
|                           ( constant-expression )
 | |
|     and shall be an integer constant expression. The integer constant expression shall not evaluate to a
 | |
|     value less than 0.
 | |
| </pre>
 | |
| <a name='6.10.3.2p2'></a>
 | |
| <pre>2   The token defined shall not appear within the constant expression.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.10.3.2p3'></a>
 | |
| <pre>3   The embed parameter with a preprocessor parameter token limit denotes a balanced preprocessing
 | |
|     token sequence that will be used to compute the resource width. Independently of any macro
 | |
|     replacement done previously (e.g. when matching the form of #embed), the constant expression is
 | |
|     evaluated after the balanced preprocessing token sequence is processed as in normal text, using
 | |
|     the rules specified for conditional inclusion (<a href='#6.10.1'>6.10.1</a>), with the exception that any defined macro
 | |
|     expressions are not permitted.
 | |
| </pre>
 | |
| <a name='6.10.3.2p4'></a>
 | |
| <pre>4   The resource width is:
 | |
| 
 | |
|       — 0, if the integer constant expression evaluates to 0; or,
 | |
| 
 | |
|       — the implementation resource width if it is less than the embed element width multiplied by
 | |
|         the integer constant expression; or,
 | |
| 
 | |
|       — the embed element width multiplied by the integer constant expression, if it is less than or
 | |
|         equal to the implementation resource width.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.2p5'></a>
 | |
| <pre>5   EXAMPLE 1 Checking the first 4 elements of a sound resource.
 | |
| 
 | |
|              #include <assert.h>
 | |
| 
 | |
|              int main (int, char*[]) {
 | |
|                    static const char sound_signature[] = {
 | |
|              #embed <sdk/jump.wav> limit(2+2)
 | |
|                    };
 | |
|                    static_assert((sizeof(sound_signature) / sizeof(*sound_signature)) == 4,
 | |
|                          "There should only be 4 elements in this array.");
 | |
| 
 | |
|                      // verify PCM WAV resource
 | |
|                      assert(sound_signature[0] == ’R’);
 | |
|                      assert(sound_signature[1] == ’I’);
 | |
|                      assert(sound_signature[2] == ’F’);
 | |
|                      assert(sound_signature[3] == ’F’);
 | |
|                      assert(sizeof(sound_signature) == 4);
 | |
| 
 | |
|                      return 0;
 | |
|              }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.2p6'></a>
 | |
| <pre>6   EXAMPLE 2 Similar to a previous example, except it illustrates macro expansion specifically done for the limit(...)
 | |
|     parameter.
 | |
| 
 | |
|              #include <assert.h>
 | |
| 
 | |
|              #define TWO_PLUS_TWO 2+2
 | |
|              int main (int, char*[]) {
 | |
|                    const char sound_signature[] = {
 | |
|                    /* the token sequence within the parentheses
 | |
|                    for the "limit" parameter undergoes macro
 | |
|                    expansion, at least once, resulting in
 | |
|              #embed <sdk/jump.wav> limit(2+2)
 | |
|                    */
 | |
|              #embed <sdk/jump.wav> limit(TWO_PLUS_TWO)
 | |
|                    };
 | |
|                    static_assert((sizeof(sound_signature) / sizeof(*sound_signature)) == 4,
 | |
|                          "There should only be 4 elements in this array.");
 | |
| 
 | |
|                      // verify PCM WAV resource
 | |
|                      assert(sound_signature[0] == ’R’);
 | |
|                      assert(sound_signature[1] == ’I’);
 | |
|                      assert(sound_signature[2] == ’F’);
 | |
|                      assert(sound_signature[3] == ’F’);
 | |
|                      assert(sizeof(sound_signature) == 4);
 | |
| 
 | |
|                      return 0;
 | |
|              }
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.2p7'></a>
 | |
| <pre>7   EXAMPLE 3 A potential constraint violation from a resource that may not have enough information in an environment that
 | |
|     has a CHAR_BIT greater than 24.
 | |
| 
 | |
|              int main (int, char*[]) {
 | |
|                    const unsigned char arr[] = {
 | |
|              #embed "24_bits.bin" limit(1) // may be a constraint violation
 | |
|                    };
 | |
| 
 | |
|                      return 0;
 | |
|              }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.3'></a>
 | |
| <hr>
 | |
| <h3>6.10.3.3 [suffix parameter]</h3>
 | |
| <a name='6.10.3.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|     The suffix standard embed parameter may appear zero times or one time in the embed parameter
 | |
|     sequence. Its preprocessor argument clause shall be present and have the form:
 | |
|                           ( pp-balanced-token-sequenceopt )
 | |
| 
 | |
|     Semantics
 | |
|    The embed parameter with a preprocessing parameter token suffix denotes a balanced preprocess-
 | |
|     ing token sequence within its preprocessor argument clause that will be placed immediately after
 | |
|     the result of the associated #embed directive’s expansion.
 | |
| </pre>
 | |
| <a name='6.10.3.3p2'></a>
 | |
| <pre>2   If the resource is empty, then suffix has no effect and is ignored.
 | |
| </pre>
 | |
| <a name='6.10.3.3p3'></a>
 | |
| <pre>3   EXAMPLE 1 Extra elements added to array initializer.
 | |
| 
 | |
|              #include <string.h>
 | |
| 
 | |
|              #ifndef SHADER_TARGET
 | |
|              #define SHADER_TARGET "edith-impl.glsl"
 | |
|              #endif
 | |
| 
 | |
|              extern char* null_term_shader_data;
 | |
| 
 | |
|              void fill_in_data () {
 | |
|                    const char internal_data[] = {
 | |
|              #embed SHADER_TARGET \
 | |
|                          suffix(,)
 | |
|                          0
 | |
|                      };
 | |
| 
 | |
|                      strcpy(null_term_shader_data, internal_data);
 | |
|              }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.4'></a>
 | |
| <hr>
 | |
| <h3>6.10.3.4 [prefix parameter]</h3>
 | |
| <a name='6.10.3.4p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The prefix standard embed parameter may appear zero times or one time in the embed parameter
 | |
|     sequence. Its preprocessor parameter clause shall be present and have the form:
 | |
|                           ( pp-balanced-token-sequenceopt )
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.10.3.4p2'></a>
 | |
| <pre>2   The embed parameter with a preprocessor parameter token prefix denotes a balanced preprocessing
 | |
|     token sequence within its preprocessor argument clause that will be placed immediately before the
 | |
|     result of the associated #embed directive’s expansion, if any.
 | |
| </pre>
 | |
| <a name='6.10.3.4p3'></a>
 | |
| <pre>3   If the resource is empty, then prefix has no effect and is ignored.
 | |
| </pre>
 | |
| <a name='6.10.3.4p4'></a>
 | |
| <pre>4   EXAMPLE 1 A null-terminated character array with prefixed and suffixed tokens of additional tokens when the resource is
 | |
|     not empty, providing null termination and a byte order mark.
 | |
| 
 | |
|              #include <string.h>
 | |
|              #include <assert.h>
 | |
| 
 | |
|              #ifndef SHADER_TARGET
 | |
|              #define SHADER_TARGET "ches.glsl"
 | |
|              #endif
 | |
| 
 | |
|              extern char* merp;
 | |
| 
 | |
|              void init_data () {
 | |
|                    const char whl[] = {
 | |
|              #embed SHADER_TARGET \
 | |
|                          prefix(0xEF, 0xBB, 0xBF, ) /* UTF-8 BOM */ \
 | |
|                          suffix(,)
 | |
|                          0
 | |
|                    };
 | |
|                    // always null terminated,
 | |
|                    // contains BOM if not-empty
 | |
|                    int is_good = (sizeof(whl) == 1 && whl[0] == ’\0’)
 | |
|                    || (whl[0] == ’\xEF’ && whl[1] == ’\xBB’
 | |
|                    && whl[2] == ’\xBF’ && whl[sizeof(whl) - 1] == ’\0’);
 | |
|                    assert(is_good);
 | |
|                    strcpy(merp, whl);
 | |
|              }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.5'></a>
 | |
| <hr>
 | |
| <h3>6.10.3.5 [if_empty parameter]</h3>
 | |
| <a name='6.10.3.5p1'></a>
 | |
| <pre>1 Constraints
 | |
|     The if_empty standard embed parameter may appear zero times or one time in the embed parameter
 | |
|     sequence. Its preprocessor argument clause shall be present and have the form:
 | |
|                           ( pp-balanced-token-sequenceopt )
 | |
| 
 | |
|     Semantics
 | |
|    The embed parameter with a preprocessing parameter token if_empty denotes a balanced pre-
 | |
|     processing token sequence within its preprocessor argument clause that will replace the #embed
 | |
|     directive entirely.
 | |
|     If the resource is not empty, then if_empty has no effect and is ignored.
 | |
| </pre>
 | |
| <a name='6.10.3.5p2'></a>
 | |
| <pre>2   EXAMPLE 1 This resource is considered empty due to the limit(0) embed parameter, always. This program always returns 0,
 | |
|     even if the resource is searched for and found successfully by the implementation.
 | |
| 
 | |
|                int main () {
 | |
|                      return
 | |
|                #embed </owo/uwurandom> limit(0) prefix(1) if_empty(0)
 | |
|                      ;
 | |
|                      // becomes:
 | |
|                      // return 0;
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.5p3'></a>
 | |
| <pre>3   EXAMPLE 2 An example similar to using the suffix embed parameter, but changed slightly.
 | |
| 
 | |
|                #include <string.h>
 | |
| 
 | |
|                #ifndef SHADER_TARGET
 | |
|                #define SHADER_TARGET "edith-impl.glsl"
 | |
|                #endif
 | |
| 
 | |
|                extern char* null_term_shader_data;
 | |
| 
 | |
|                void fill_in_data () {
 | |
|                      const char internal_data[] = {
 | |
|                #embed SHADER_TARGET \
 | |
|                            suffix(, 0) \
 | |
|                            if_empty(0)
 | |
|                      };
 | |
| 
 | |
|                       strcpy(null_term_shader_data, internal_data);
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.3.5p4'></a>
 | |
| <pre>4   EXAMPLE 3 This resource is considered empty due to the limit(0) embed parameter, always, which means any if_empty
 | |
|     expressions replace the directive as specified above.
 | |
| 
 | |
|                int main () {
 | |
|                      return
 | |
|                            #include </owo/uwurandom> limit(0) if_empty(45540)
 | |
|                      ;
 | |
|                }
 | |
| 
 | |
| 
 | |
|     becomes:
 | |
| 
 | |
|                int main () {
 | |
|                      return 45540;
 | |
|                }
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4'></a>
 | |
| <hr>
 | |
| <h3>6.10.4 [Macro replacement]</h3>
 | |
| <a name='6.10.4p1'></a>
 | |
| <pre>1 Constraints
 | |
|    Two replacement lists are identical if and only if the preprocessing tokens in both have the same
 | |
|     number, ordering, spelling, and white-space separation, where all white-space separations are
 | |
|     considered identical.
 | |
| </pre>
 | |
| <a name='6.10.4p2'></a>
 | |
| <pre>2   An identifier currently defined as an object-like macro shall not be redefined by another #define
 | |
|     preprocessing directive unless the second definition is an object-like macro definition and the two
 | |
|     replacement lists are identical. Likewise, an identifier currently defined as a function-like macro
 | |
|     shall not be redefined by another #define preprocessing directive unless the second definition is a
 | |
|     function-like macro definition that has the same number and spelling of parameters, and the two
 | |
|     replacement lists are identical.
 | |
| </pre>
 | |
| <a name='6.10.4p3'></a>
 | |
| <pre>3   There shall be white space between the identifier and the replacement list in the definition of an
 | |
|     object-like macro.
 | |
| </pre>
 | |
| <a name='6.10.4p4'></a>
 | |
| <pre>4    If the identifier-list in the macro definition does not end with an ellipsis, the number of arguments
 | |
|      (including those arguments consisting of no preprocessing tokens) in an invocation of a function-like
 | |
|      macro shall equal the number of parameters in the macro definition. Otherwise, there shall be at
 | |
|      least as many arguments in the invocation as there are parameters in the macro definition (excluding
 | |
|      the ...). There shall exist a ) preprocessing token that terminates the invocation.
 | |
| </pre>
 | |
| <a name='6.10.4p5'></a>
 | |
| <pre>5    The identifiers __VA_ARGS__ and __VA_OPT__ shall occur only in the replacement-list of a function-
 | |
|      like macro that uses the ellipsis notation in the parameters.
 | |
| </pre>
 | |
| <a name='6.10.4p6'></a>
 | |
| <pre>6    A parameter identifier in a function-like macro shall be uniquely declared within its scope.
 | |
| 
 | |
|      Semantics
 | |
| </pre>
 | |
| <a name='6.10.4p7'></a>
 | |
| <pre>7    The identifier immediately following the define is called the macro name. There is one name
 | |
|      space for macro names. Any white-space characters preceding or following the replacement list of
 | |
|      preprocessing tokens are not considered part of the replacement list for either form of macro.
 | |
| </pre>
 | |
| <a name='6.10.4p8'></a>
 | |
| <pre>8    If a # preprocessing token, followed by an identifier, occurs lexically at the point at which a prepro-
 | |
|      cessing directive could begin, the identifier is not subject to macro replacement.
 | |
| </pre>
 | |
| <a name='6.10.4p9'></a>
 | |
| <pre>9    A preprocessing directive of the form
 | |
|                             # define identifier replacement-list new-line
 | |
|      defines an object-like macro that causes each subsequent instance of the macro name<a href='#FOOTNOTE.219'><sup>[219]</sup></a> to be replaced
 | |
|      by the replacement list of preprocessing tokens that constitute the remainder of the directive. The
 | |
|      replacement list is then rescanned for more macro names as specified below.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.219'>
 | |
| <pre><i><b>Footnote 219)</b> Since, by macro-replacement time, all character constants and string literals are preprocessing tokens, not sequences
 | |
|      possibly containing identifier-like subsequences (see <a href='#5.1.1.2'>5.1.1.2</a>, translation phases), they are never scanned for macro names or
 | |
|      parameters.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.4p10'></a>
 | |
| <pre>10   A preprocessing directive of the form
 | |
|                             # define identifier lparen identifier-listopt ) replacement-list new-line
 | |
|                             # define identifier lparen ... ) replacement-list new-line
 | |
|                             # define identifier lparen identifier-list , ... ) replacement-list new-line
 | |
|      defines a function-like macro with parameters, whose use is similar syntactically to a function call. The
 | |
|      parameters are specified by the optional list of identifiers, whose scope extends from their declaration
 | |
|      in the identifier list until the new-line character that terminates the #define preprocessing directive.
 | |
|      Each subsequent instance of the function-like macro name followed by a ( as the next preprocessing
 | |
|      token introduces the sequence of preprocessing tokens that is replaced by the replacement list
 | |
|      in the definition (an invocation of the macro). The replaced sequence of preprocessing tokens is
 | |
|      terminated by the matching ) preprocessing token, skipping intervening matched pairs of left and
 | |
|      right parenthesis preprocessing tokens. Within the sequence of preprocessing tokens making up an
 | |
|      invocation of a function-like macro, new-line is considered a normal white-space character.
 | |
| </pre>
 | |
| <a name='6.10.4p11'></a>
 | |
| <pre>11   The sequence of preprocessing tokens bounded by the outside-most matching parentheses forms
 | |
|      the list of arguments for the function-like macro. The individual arguments within the list are
 | |
|      separated by comma preprocessing tokens, but comma preprocessing tokens between matching
 | |
|      inner parentheses do not separate arguments. If there are sequences of preprocessing tokens within
 | |
|      the list of arguments that would otherwise act as preprocessing directives,<a href='#FOOTNOTE.220'><sup>[220]</sup></a> the behavior is
 | |
|      undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.220'>
 | |
| <pre><i><b>Footnote 220)</b> Despite the name, a non-directive is a preprocessing directive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.4p12'></a>
 | |
| <pre>12   If there is a ... in the identifier-list in the macro definition, then the trailing arguments (if any),
 | |
|      including any separating comma preprocessing tokens, are merged to form a single item: the variable
 | |
|      arguments. The number of arguments so combined is such that, following merger, the number of
 | |
|      arguments is one more than the number of parameters in the macro definition (excluding the ...),
 | |
|      except that if there are as many arguments as named parameters, the macro invocation behaves as if
 | |
|      a comma token has been appended to the argument list such that variable arguments are formed
 | |
|      that contain no pp-tokens.
 | |
| </pre>
 | |
| <a name='6.10.4.1'></a>
 | |
| <hr>
 | |
| <h3>6.10.4.1 [Argument substitution]</h3>
 | |
| <a name='6.10.4.1p1'></a>
 | |
| <pre>1 Syntax
 | |
|     va-opt-replacement:
 | |
|                           __VA_OPT__ ( pp-tokensopt )
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='6.10.4.1p2'></a>
 | |
| <pre>2   Argument substitution is a process during macro expansion in which identifiers corresponding to
 | |
|     the parameters of the macro definition and the special constructs __VA_ARGS__ and __VA_OPT__
 | |
|     are replaced with token sequences from the arguments of the macro invocation and possibly of the
 | |
|     argument of the feature __VA_OPT__ . The latter process allows to control a substitute token sequence
 | |
|     that is only expanded if the argument list that corresponds to a trailing ... of the parameter list is
 | |
|     present and has a non-empty substitution.
 | |
| 
 | |
|     Constraints
 | |
| </pre>
 | |
| <a name='6.10.4.1p3'></a>
 | |
| <pre>3   The identifier __VA_OPT__ shall always occur as part of the preprocessing token sequence va-opt-
 | |
|     replacement; its closing ) is determined by skipping intervening pairs of matching left and right
 | |
|     parentheses in its pp-tokens. The pp-tokens of a va-opt-replacement shall not contain __VA_OPT__ .
 | |
|     The pp-tokens shall form a valid replacement list for the current function-like macro.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.10.4.1p4'></a>
 | |
| <pre>4   After the arguments for the invocation of a function-like macro have been identified, argument
 | |
|     substitution takes place. A va-opt-replacement is treated as if it were a parameter. For each parameter
 | |
|     in the replacement list that is neither preceded by a # or ## preprocessing token nor followed by a
 | |
|     ## preprocessing token, the preprocessing tokens naming the parameter are replaced by a token
 | |
|     sequence determined as follows:
 | |
| 
 | |
|       — If the parameter is of the form va-opt-replacement, the replacement preprocessing tokens are
 | |
|         the preprocessing token sequence for the corresponding argument, as specified below.
 | |
|       — Otherwise, the replacement preprocessing tokens are the preprocessing tokens of the corre-
 | |
|         sponding argument after all macros contained therein have been expanded. The argument’s
 | |
|         preprocessing tokens are completely macro replaced before being substituted as if they formed
 | |
|         the rest of the preprocessing file with no other preprocessing tokens being available.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.1p5'></a>
 | |
| <pre>5   EXAMPLE 1
 | |
| 
 | |
|              #define LPAREN() (
 | |
|              #define G(Q) 42
 | |
|              #define F(R, X, ...) __VA_OPT__(G R X) )
 | |
|              int x = F(LPAREN(), 0, <:-);    // replaced by int x = 42;
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.1p6'></a>
 | |
| <pre>6   An identifier __VA_ARGS__ that occurs in the replacement list is treated as if it were a parameter,
 | |
|     and the variable arguments form the preprocessing tokens used to replace it.
 | |
| </pre>
 | |
| <a name='6.10.4.1p7'></a>
 | |
| <pre>7   The preprocessing token sequence for the corresponding argument of a va-opt-replacement is
 | |
|     defined as follows. If a (hypothetical) substitution of __VA_ARGS__ as neither an operand of # nor
 | |
|     ## consists of no preprocessing tokens, the argument consists of a single placemarker preprocessing
 | |
|     token (<a href='#6.10.4.3'>6.10.4.3</a>, <a href='#6.10.4.4'>6.10.4.4</a>). Otherwise, the argument consists of the results of the expansion of the
 | |
|     contained pp-tokens as the replacement list of the current function-like macro before removal of
 | |
|     placemarker tokens, rescanning, and further replacement.
 | |
| </pre>
 | |
| <a name='6.10.4.1p8'></a>
 | |
| <pre>8   NOTE The placemarker tokens are removed before stringization (<a href='#6.10.4.2'>6.10.4.2</a>), and can be removed by rescanning and further
 | |
|     replacement (<a href='#6.10.4.4'>6.10.4.4</a>).
 | |
| </pre>
 | |
| <a name='6.10.4.1p9'></a>
 | |
| <pre>9   EXAMPLE 2
 | |
| 
 | |
|              #define F(...)                   f(0 __VA_OPT__(,) __VA_ARGS__)
 | |
|              #define G(X, ...)                f(0, X __VA_OPT__(,) __VA_ARGS__)
 | |
|             #define SDEF(sname, ...) S sname __VA_OPT__(= { __VA_ARGS__ })
 | |
|             #define EMP
 | |
| 
 | |
|             F(a, b, c)           // replaced by f(0, a, b, c)
 | |
|             F()                  // replaced by f(0)
 | |
|             F(EMP)               // replaced by f(0)
 | |
| 
 | |
|             G(a, b, c)           // replaced by f(0, a, b, c)
 | |
|             G(a, )               // replaced by f(0, a)
 | |
|             G(a)                 // replaced by f(0, a)
 | |
| 
 | |
|             SDEF(foo);           // replaced by S foo;
 | |
|             SDEF(bar, 1, 2);     // replaced by S bar = { 1, 2 };
 | |
| 
 | |
|             #define H1(X, ...)    X __VA_OPT__(##) __VA_ARGS__
 | |
|                               // error: ## on line above
 | |
|                               // may not appear at the beginning of a replacement
 | |
|                               // list (<a href='#6.10.4.3'>6.10.4.3</a>)
 | |
| 
 | |
|             #define H2(X, Y, ...) __VA_OPT__(X ## Y,) __VA_ARGS__
 | |
| 
 | |
|             H2(a, b, c, d)       // replaced by ab, c, d
 | |
| 
 | |
|             #define H3(X, ...)    #__VA_OPT__(X##X X##X)
 | |
|             H3(, 0)           // replaced by ""
 | |
| 
 | |
|             #define H4(X, ...)    __VA_OPT__(a X ## X) ## b
 | |
|             H4(, 1)           // replaced by a b
 | |
| 
 | |
|             #define H5A(...)         __VA_OPT__()/**/__VA_OPT__()
 | |
|             #define H5B(X)           a ## X ## b
 | |
|             #define H5C(X)           H5B(X)
 | |
|             H5C(H5A())           // replaced by ab
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.2'></a>
 | |
| <hr>
 | |
| <h3>6.10.4.2 [The # operator]</h3>
 | |
| <a name='6.10.4.2p1'></a>
 | |
| <pre>1 Constraints
 | |
|    Each # preprocessing token in the replacement list for a function-like macro shall be followed by a
 | |
|     parameter as the next preprocessing token in the replacement list.
 | |
| 
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.10.4.2p2'></a>
 | |
| <pre>2   If, in the replacement list, a parameter is immediately preceded by a # preprocessing token, both
 | |
|     are replaced by a single character string literal preprocessing token that contains the spelling of the
 | |
|     preprocessing token sequence for the corresponding argument (excluding placemarker tokens). Let
 | |
|     the stringizing argument be the preprocessing token sequence for the corresponding argument with
 | |
|     placemarker tokens removed. Each occurrence of white space between the stringizing argument’s
 | |
|     preprocessing tokens becomes a single space character in the character string literal. White space
 | |
|     before the first preprocessing token and after the last preprocessing token composing the stringizing
 | |
|     argument is deleted. Otherwise, the original spelling of each preprocessing token in the stringizing
 | |
|     argument is retained in the character string literal, except for special handling for producing the
 | |
|     spelling of string literals and character constants: a \ character is inserted before each " and \
 | |
|     character of a character constant or string literal (including the delimiting " characters), except that
 | |
|     it is implementation-defined whether a \ character is inserted before the \ character beginning a
 | |
|     universal character name. If the replacement that results is not a valid character string literal, the
 | |
|     behavior is undefined. The character string literal corresponding to an empty stringizing argument
 | |
|     is "". The order of evaluation of # and ## operators is unspecified.
 | |
| </pre>
 | |
| <a name='6.10.4.3'></a>
 | |
| <hr>
 | |
| <h3>6.10.4.3 [The ## operator]</h3>
 | |
| <a name='6.10.4.3p1'></a>
 | |
| <pre>1 Constraints
 | |
|    A ## preprocessing token shall not occur at the beginning or at the end of a replacement list for
 | |
|     either form of macro definition.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.10.4.3p2'></a>
 | |
| <pre>2   If, in the replacement list of a function-like macro, a parameter is immediately preceded or followed
 | |
|     by a ## preprocessing token, the parameter is replaced by the corresponding argument’s preprocess-
 | |
|     ing token sequence; however, if an argument consists of no preprocessing tokens, the parameter is
 | |
|     replaced by a placemarker preprocessing token instead.<a href='#FOOTNOTE.221'><sup>[221]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.221'>
 | |
| <pre><i><b>Footnote 221)</b> Placemarker preprocessing tokens do not appear in the syntax because they are temporary entities that exist only within
 | |
|     translation phase 4.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.4.3p3'></a>
 | |
| <pre>3   For both object-like and function-like macro invocations, before the replacement list is reexamined
 | |
|     for more macro names to replace, each instance of a ## preprocessing token in the replacement list
 | |
|     (not from an argument) is deleted and the preceding preprocessing token is concatenated with the
 | |
|     following preprocessing token. Placemarker preprocessing tokens are handled specially: concatena-
 | |
|     tion of two placemarkers results in a single placemarker preprocessing token, and concatenation
 | |
|     of a placemarker with a non-placemarker preprocessing token results in the non-placemarker pre-
 | |
|     processing token. If the result is not a valid preprocessing token, the behavior is undefined. The
 | |
|     resulting token is available for further macro replacement. The order of evaluation of ## operators is
 | |
|     unspecified.
 | |
| </pre>
 | |
| <a name='6.10.4.3p4'></a>
 | |
| <pre>4   EXAMPLE In the following fragment:
 | |
| 
 | |
|               #define hash_hash # ## #
 | |
|               #define mkstr(a) # a
 | |
|               #define in_between(a) mkstr(a)
 | |
|               #define join(c, d) in_between(c hash_hash d)
 | |
| 
 | |
|               char p[] = join(x, y); // equivalent to
 | |
|                                      // char p[] = "x ## y";
 | |
| 
 | |
| 
 | |
|     The expansion produces, at various stages:
 | |
| 
 | |
|               join(x, y)
 | |
| 
 | |
|               in_between(x hash_hash y)
 | |
| 
 | |
|               in_between(x ## y)
 | |
| 
 | |
|               mkstr(x ## y)
 | |
| 
 | |
|               "x ## y"
 | |
| 
 | |
| 
 | |
|     In other words, expanding hash_hash produces a new token, consisting of two adjacent sharp signs, but this new token is
 | |
|     not the ## operator.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.4'></a>
 | |
| <hr>
 | |
| <h3>6.10.4.4 [Rescanning and further replacement]</h3>
 | |
| <a name='6.10.4.4p1'></a>
 | |
| <pre>1   After all parameters in the replacement list have been substituted and # and ## processing has
 | |
|     taken place, all placemarker preprocessing tokens are removed. The resulting preprocessing token
 | |
|     sequence is then rescanned, along with all subsequent preprocessing tokens of the source file, for
 | |
|     more macro names to replace.
 | |
| </pre>
 | |
| <a name='6.10.4.4p2'></a>
 | |
| <pre>2   If the name of the macro being replaced is found during this scan of the replacement list (not
 | |
|     including the rest of the source file’s preprocessing tokens), it is not replaced. Furthermore, if any
 | |
|     nested replacements encounter the name of the macro being replaced, it is not replaced. These
 | |
|     nonreplaced macro name preprocessing tokens are no longer available for further replacement even
 | |
|     if they are later (re)examined in contexts in which that macro name preprocessing token would
 | |
|     otherwise have been replaced.
 | |
| </pre>
 | |
| <a name='6.10.4.4p3'></a>
 | |
| <pre>3   The resulting completely macro-replaced preprocessing token sequence is not processed as a prepro-
 | |
|     cessing directive even if it resembles one, but all pragma unary operator expressions within it are
 | |
|     then processed as specified in <a href='#6.10.10'>6.10.10</a> below.
 | |
| </pre>
 | |
| <a name='6.10.4.4p4'></a>
 | |
| <pre>4   EXAMPLE There are cases where it is not clear whether a replacement is nested or not. For example, given the following
 | |
|     macro definitions:
 | |
| 
 | |
|               #define f(a) a*g
 | |
|               #define g(a) f(a)
 | |
| 
 | |
|     the invocation
 | |
| 
 | |
|               f(2)(9)
 | |
| 
 | |
|     could expand to either
 | |
| 
 | |
|               2*f(9)
 | |
| 
 | |
|     or
 | |
| 
 | |
|               2*9*g
 | |
| 
 | |
|     Strictly conforming programs are not permitted to depend on such unspecified behavior.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.5'></a>
 | |
| <hr>
 | |
| <h3>6.10.4.5 [Scope of macro definitions]</h3>
 | |
| <a name='6.10.4.5p1'></a>
 | |
| <pre>1   A macro definition lasts (independent of block structure) until a corresponding #undef directive is
 | |
|     encountered or (if none is encountered) until the end of the preprocessing translation unit. Macro
 | |
|     definitions have no significance after translation phase 4.
 | |
| </pre>
 | |
| <a name='6.10.4.5p2'></a>
 | |
| <pre>2   A preprocessing directive of the form
 | |
|                              # undef identifier new-line
 | |
|     causes the specified identifier no longer to be defined as a macro name. It is ignored if the specified
 | |
|     identifier is not currently defined as a macro name.
 | |
| </pre>
 | |
| <a name='6.10.4.5p3'></a>
 | |
| <pre>3   EXAMPLE 1 The simplest use of this facility is to define a "manifest constant", as in
 | |
| 
 | |
|               #define TABSIZE 100
 | |
| 
 | |
|               int table[TABSIZE];
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.5p4'></a>
 | |
| <pre>4   EXAMPLE 2 The following defines a function-like macro whose value is the maximum of its arguments. It has the advantages
 | |
|     of working for any compatible types of the arguments and of generating in-line code without the overhead of function calling.
 | |
|     It has the disadvantages of evaluating one or the other of its arguments a second time (including side effects) and generating
 | |
|     more code than a function if invoked several times. It also cannot have its address taken, as it has none.
 | |
| 
 | |
|               #define max(a, b) ((a)            >   (b) ? (a): (b))
 | |
| 
 | |
|     The parentheses ensure that the arguments and the resulting expression are bound properly.
 | |
| </pre>
 | |
| <a name='6.10.4.5p5'></a>
 | |
| <pre>5   EXAMPLE 3 To illustrate the rules for redefinition and reexamination, the sequence
 | |
| 
 | |
|               #define x      3
 | |
|               #define f(a)   f(x * (a))
 | |
|               #undef x
 | |
|               #define x      2
 | |
|               #define g      f
 | |
|               #define z      z[0]
 | |
|               #define h      g(\~{ }
 | |
|               #define m(a)   a(w)
 | |
|               #define w      0,1
 | |
|               #define t(a)   a
 | |
|               #define p()    int
 | |
|               #define q(x)   x
 | |
|               #define r(x,y) x ## y
 | |
|              #define str(x) # x
 | |
| 
 | |
|              f(y+1) + f(f(z)) % t(t(g)(0) + t)(1);
 | |
|              g(x+(3,4)-w) | h 5) & m
 | |
|                    (f)^m(m);
 | |
|              p() i[q()] = { q(1), r(2,3), r(4,), r(,5), r(,) };
 | |
|              char c[2][6] = { str(hello), str() };
 | |
| 
 | |
| results in
 | |
| 
 | |
|              f(2 * (y+1)) + f(2 * (f(2 * (z[0])))) % f(2 * (0)) + t(1);
 | |
|              f(2 * (2+(3,4)-0,1)) | f(2 * (\~{ } 5)) & f(2 * (0,1))^m(0,1);
 | |
|              int i[] = { 1, 23, 4, 5, };
 | |
|              char c[2][6] = { "hello", "" };
 | |
| </pre>
 | |
| <a name='6.10.4.5p6'></a>
 | |
| <pre>6   EXAMPLE 4 To illustrate the rules for creating character string literals and concatenating tokens, the sequence
 | |
| 
 | |
|                  #define str(s)      # s
 | |
|                  #define xstr(s)     str(s)
 | |
|                  #define debug(s, t) printf("x" # s "= %d, x" # t "= %s", \
 | |
|                                          x ## s, x ## t)
 | |
|                  #define INCFILE(n) vers ## n
 | |
|                  #define glue(a, b) a ## b
 | |
|                  #define xglue(a, b) glue(a, b)
 | |
|                  #define HIGHLOW     "hello"
 | |
|                  #define LOW         LOW ", world"
 | |
| 
 | |
|                  debug(1, 2);
 | |
|                  fputs(str(strncmp("abc\0d", "abc", ’\4’) // this goes away
 | |
|                        == 0) str(: @\n), s);
 | |
|                  #include xstr(INCFILE(2).h)
 | |
|                  glue(HIGH, LOW);
 | |
|                  xglue(HIGH, LOW)
 | |
| 
 | |
|     results in
 | |
| 
 | |
|                  printf("x" "1" "= %d, x" "2" "= %s", x1, x2);
 | |
|                  fputs(
 | |
|                    "strncmp(\"abc\\0d\", \"abc\", ’\\4’) == 0" ": @\n",
 | |
|                    s);
 | |
|                  #include "vers2.h"    (after macro replacement, before file access)
 | |
|                  "hello";
 | |
|                  "hello" ", world"
 | |
| 
 | |
|     or, after concatenation of the character string literals,
 | |
| 
 | |
|                  printf("x1= %d, x2= %s", x1, x2);
 | |
|                  fputs(
 | |
|                    "strncmp(\"abc\\0d\", \"abc\", ’\\4’) == 0: @\n",
 | |
|                    s);
 | |
|                  #include "vers2.h"    (after macro replacement, before file access)
 | |
|                  "hello";
 | |
|                  "hello, world"
 | |
| 
 | |
|     Space around the # and ## tokens in the macro definition is optional.
 | |
| </pre>
 | |
| <a name='6.10.4.5p7'></a>
 | |
| <pre>7   EXAMPLE 5 To illustrate the rules for placemarker preprocessing tokens, the sequence
 | |
| 
 | |
|                  #define t(x,y,z) x ## y ## z
 | |
|                  int j[] = { t(+1,2,3), t(,4,5), t(6,,7), t(8,9,),
 | |
|                             t(10,,), t(,11,), t(,,12), t(,,) };
 | |
| 
 | |
|     results in
 | |
| 
 | |
|                  int j[] = { 123, 45, 67, 89,
 | |
|                              10, 11, 12, };
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.5p8'></a>
 | |
| <pre>8   EXAMPLE 6 To demonstrate the redefinition rules, the following sequence is valid.
 | |
| 
 | |
|                  #define OBJ_LIKE      (1-1)
 | |
|                  #define OBJ_LIKE      /* white space */ (1-1) /* other */
 | |
|                  #define FUNC_LIKE(a)   (a)
 | |
|                  #define FUNC_LIKE(a)(   /* note the white space */ \
 | |
|                                          a /* other stuff on this line
 | |
|                                             */)
 | |
| 
 | |
|     But the following redefinitions are invalid:
 | |
|                  #define OBJ_LIKE    (0)     // different token sequence
 | |
|                  #define OBJ_LIKE    (1 - 1) // different white space
 | |
|                  #define FUNC_LIKE(b) (a)    // different parameter usage
 | |
|                  #define FUNC_LIKE(b) (b)    // different parameter spelling
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.4.5p9'></a>
 | |
| <pre>9   EXAMPLE 7 Finally, to show the variable argument list macro facilities:
 | |
| 
 | |
|                  #define debug(...)      fprintf(stderr, __VA_ARGS__)
 | |
|                  #define showlist(...)   puts(#__VA_ARGS__)
 | |
|                  #define report(test, ...) ((test)?puts(#test):\
 | |
|                              printf(__VA_ARGS__))
 | |
|                  debug("Flag");
 | |
|                  debug("X = %d\n", x);
 | |
|                  showlist(The first, second, and third items.);
 | |
|                  report(x>y, "x is %d but y is %d", x, y);
 | |
| 
 | |
| 
 | |
|     results in
 | |
| 
 | |
|                  fprintf(stderr, "Flag");
 | |
|                  fprintf(stderr, "X = %d\n", x);
 | |
|                  puts("The first, second, and third items.");
 | |
|                  ((x>y)?puts("x>y"):
 | |
|                              printf("x is %d but y is %d", x, y));
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.5'></a>
 | |
| <hr>
 | |
| <h3>6.10.5 [Line control]</h3>
 | |
| <a name='6.10.5p1'></a>
 | |
| <pre>1 Constraints
 | |
|    The string literal of a #line directive, if present, shall be a character string literal.
 | |
| 
 | |
|     Semantics
 | |
| </pre>
 | |
| <a name='6.10.5p2'></a>
 | |
| <pre>2   The line number of the current source line is one greater than the number of new-line characters read
 | |
|     or introduced in translation phase 1 (<a href='#5.1.1.2'>5.1.1.2</a>) while processing the source file to the current token.
 | |
| </pre>
 | |
| <a name='6.10.5p3'></a>
 | |
| <pre>3   If a preprocessing token (in particular __LINE__ ) spans two or more physical lines, it is unspecified
 | |
|     which of those line numbers is associated with that token. If a preprocessing directive spans two or
 | |
|     more physical lines, it is unspecified which of those line numbers is associated with the preprocessing
 | |
|     directive. If a macro invocation spans multiple physical or logical lines, it is unspecified which of
 | |
|     those line numbers is associated with that invocation. The line number of a preprocessing token is
 | |
|     independent of the context (in particular, as a macro argument or in a preprocessing directive). The
 | |
|     line number of a __LINE__ in a macro body is the line number of the macro invocation.
 | |
| </pre>
 | |
| <a name='6.10.5p4'></a>
 | |
| <pre>4   A preprocessing directive of the form
 | |
|                           # line digit-sequence new-line
 | |
|     causes the implementation to behave as if the following sequence of source lines begins with a
 | |
|     source line that has a line number as specified by the digit sequence (interpreted as a decimal integer,
 | |
|     ignoring any optional digit separators (<a href='#6.4.4.1'>6.4.4.1</a>) in the digit sequence). The digit sequence shall not
 | |
|     specify zero, nor a number greater than 2147483647.
 | |
| </pre>
 | |
| <a name='6.10.5p5'></a>
 | |
| <pre>5   A preprocessing directive of the form
 | |
|                           # line digit-sequence " s-char-sequenceopt " new-line
 | |
|     sets the presumed line number similarly and changes the presumed name of the source file to be the
 | |
|     contents of the character string literal.
 | |
| </pre>
 | |
| <a name='6.10.5p6'></a>
 | |
| <pre>6   A preprocessing directive of the form
 | |
|                           # line pp-tokens new-line
 | |
|     (that does not match one of the two previous forms) is permitted. The preprocessing tokens after
 | |
|     line on the directive are processed just as in normal text (each identifier currently defined as a
 | |
|     macro name is replaced by its replacement list of preprocessing tokens). The directive resulting after
 | |
|     all replacements shall match one of the two previous forms and is then processed as appropriate.<a href='#FOOTNOTE.222'><sup>[222]</sup></a>
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.222'>
 | |
| <pre><i><b>Footnote 222)</b> Because a new-line is explicitly included as part of the #line directive, the number of new-line characters read while
 | |
|     processing to the first pp-token can be different depending on whether or not the implementation uses a one-pass preprocessor.
 | |
|     Therefore, there are two possible values for the line number following a directive of the form #line __LINE__ new-line.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.5p7'></a>
 | |
| <pre>7   The line number associated with a pp-token should be the line number of the first character of the
 | |
|     pp-token. The line number associated with a preprocessing directive should be the line number of
 | |
|     the line with the first # token. The line number associated with a macro invocation should be the
 | |
|     line number of the first character of the macro name in the invocation.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.6'></a>
 | |
| <hr>
 | |
| <h3>6.10.6 [Diagnostic directives]</h3>
 | |
| <a name='6.10.6p1'></a>
 | |
| <pre>1 Semantics
 | |
|    A preprocessing directive of either form
 | |
|                            # error pp-tokensopt new-line                                 # warning pp-tokensopt new-line
 | |
|     causes the implementation to produce a diagnostic message that includes the specified sequence of
 | |
|     preprocessing tokens.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.7'></a>
 | |
| <hr>
 | |
| <h3>6.10.7 [Pragma directive]</h3>
 | |
| <a name='6.10.7p1'></a>
 | |
| <pre>1 Semantics
 | |
|    A preprocessing directive of the form
 | |
|                            # pragma pp-tokensopt new-line
 | |
|     where the preprocessing token STDC does not immediately follow pragma in the directive (prior to
 | |
|     any macro replacement)<a href='#FOOTNOTE.223'><sup>[223]</sup></a> causes the implementation to behave in an implementation-defined man-
 | |
|     ner. The behavior might cause translation to fail or cause the translator or the resulting program to
 | |
|     behave in a non-conforming manner. Any such pragma that is not recognized by the implementation
 | |
|     is ignored.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.223'>
 | |
| <pre><i><b>Footnote 223)</b> An implementation is not required to perform macro replacement in pragmas, but it is permitted except for in standard
 | |
|     pragmas (where STDC immediately follows pragma). If the result of macro replacement in a non-standard pragma has the
 | |
|     same form as a standard pragma, the behavior is still implementation-defined; an implementation is permitted to behave as
 | |
|     if it were the standard pragma, but is not required to.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.7p2'></a>
 | |
| <pre>2   If the preprocessing token STDC does immediately follow pragma in the directive (prior to any macro
 | |
|     replacement), then no macro replacement is performed on the directive, and the directive shall have
 | |
|     one of the following forms<a href='#FOOTNOTE.224'><sup>[224]</sup></a> whose meanings are described elsewhere:
 | |
|     standard-pragma:
 | |
|                            # pragma STDC FP_CONTRACT on-off-switch
 | |
|                            # pragma STDC FENV_ACCESS on-off-switch
 | |
|                            # pragma STDC FENV_DEC_ROUND dec-direction
 | |
|                            # pragma STDC FENV_ROUND direction
 | |
|                            # pragma STDC CX_LIMITED_RANGE on-off-switch
 | |
| 
 | |
|      on-off-switch: one of
 | |
|                            ON       OFF       DEFAULT
 | |
| 
 | |
|      direction: one of
 | |
|                            FE_DOWNWARD            FE_TONEAREST            FE_TONEARESTFROMZERO
 | |
|                            FE_TOWARDZERO            FE_UPWARD            FE_DYNAMIC
 | |
| 
 | |
|      dec-direction: one of
 | |
|                            FE_DEC_DOWNWARD              FE_DEC_TONEAREST              FE_DEC_TONEARESTFROMZERO
 | |
|                            FE_DEC_TOWARDZERO              FE_DEC_UPWARD              FE_DEC_DYNAMIC
 | |
|     Forward references:   the FP_CONTRACT pragma (<a href='#7.12.2'>7.12.2</a>), the FENV_ACCESS pragma
 | |
|     (<a href='#7.6.1'>7.6.1</a>), the FENV_DEC_ROUND pragma (<a href='#7.6.3'>7.6.3</a>), the FENV_ROUND pragma (<a href='#7.6.2'>7.6.2</a>), the
 | |
|     CX_LIMITED_RANGE pragma (<a href='#7.3.4'>7.3.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.224'>
 | |
| <pre><i><b>Footnote 224)</b> See "future language directions" (<a href='#6.11.6'>6.11.6</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.8'></a>
 | |
| <hr>
 | |
| <h3>6.10.8 [Null directive]</h3>
 | |
| <a name='6.10.8p1'></a>
 | |
| <pre>1 Semantics
 | |
|    A preprocessing directive of the form
 | |
|                            # new-line
 | |
|     has no effect.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.9'></a>
 | |
| <hr>
 | |
| <h3>6.10.9 [Predefined macro names]</h3>
 | |
| <a name='6.10.9p1'></a>
 | |
| <pre>1   The values of the predefined macros listed in the following subclauses<a href='#FOOTNOTE.225'><sup>[225]</sup></a> (except for __FILE__ and
 | |
|     __LINE__ ) remain constant throughout the translation unit.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.225'>
 | |
| <pre><i><b>Footnote 225)</b> See "future language directions" (<a href='#6.11.7'>6.11.7</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.9p2'></a>
 | |
| <pre>2   None of these macro names, nor the identifiers defined or __has_c_attribute , shall be the subject
 | |
|     of a #define or a #undef preprocessing directive. Any other predefined macro names: shall begin
 | |
|     with a leading underscore followed by an uppercase letter; or, a second underscore; or, shall be any
 | |
|     of the identifiers alignas, alignof, bool, false, static_assert, thread_local, or true.
 | |
| </pre>
 | |
| <a name='6.10.9p3'></a>
 | |
| <pre>3   The implementation shall not predefine the macro __cplusplus , nor shall it define it in any standard
 | |
|     header.
 | |
|     Forward references: standard headers (<a href='#7.1.2'>7.1.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.9.1'></a>
 | |
| <hr>
 | |
| <h3>6.10.9.1 [Mandatory macros]</h3>
 | |
| <a name='6.10.9.1p1'></a>
 | |
| <pre>1   The following macro names shall be defined by the implementation:
 | |
| 
 | |
|     __DATE__ The date of translation of the preprocessing translation unit: a character string literal of
 | |
|              the form "Mmm dd yyyy", where the names of the months are the same as those generated
 | |
|              by the asctime function, and the first character of dd is a space character if the value is
 | |
|                  less than 10. If the date of translation is not available, an implementation-defined valid
 | |
|                  date shall be supplied.
 | |
|     __FILE__ The presumed name of the current source file (a character string literal).<a href='#FOOTNOTE.226'><sup>[226]</sup></a>
 | |
| 
 | |
|     __LINE__ The presumed line number (within the current source file) of the current source line (an
 | |
|                  integer constant).<a href='#FOOTNOTE.226'><sup>[226]</sup></a>
 | |
|     __STDC__ The integer constant 1 , intended to indicate a conforming implementation.
 | |
| 
 | |
|     __STDC_HOSTED__ The integer constant 1 if the implementation is a hosted implementation or the
 | |
|              integer constant 0 if it is not.
 | |
|     __STDC_UTF_16__ The integer constant 1 , intended to indicate that values of type char16_t are
 | |
|                  UTF–16 encoded.
 | |
|     __STDC_UTF_32__ The integer constant 1 , intended to indicate that values of type char32_t are
 | |
|                  UTF–32 encoded.
 | |
|     __STDC_VERSION__ The integer constant 202311L.<a href='#FOOTNOTE.227'><sup>[227]</sup></a>
 | |
| 
 | |
|     __TIME__ The time of translation of the preprocessing translation unit: a character string literal of
 | |
|              the form "hh:mm:ss" as in the time generated by the asctime functions. If the time of
 | |
|                  translation is not available, an implementation-defined valid time shall be supplied.
 | |
| 
 | |
|     Forward references: the asctime functions (<a href='#7.29.3.1'>7.29.3.1</a>).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.226'>
 | |
| <pre><i><b>Footnote 226)</b> The presumed source file name and line number can be changed by the #line directive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.226'>
 | |
| <pre><i><b>Footnote 226)</b> The presumed source file name and line number can be changed by the #line directive.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.227'>
 | |
| <pre><i><b>Footnote 227)</b> See Annex M for the values in previous revisions. The intention is that this will remain an integer constant of type
 | |
|     long int that is increased with each revision of this document.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.9.2'></a>
 | |
| <hr>
 | |
| <h3>6.10.9.2 [Environment macros]</h3>
 | |
| <a name='6.10.9.2p1'></a>
 | |
| <pre>1   The following macro names are conditionally defined by the implementation:
 | |
| 
 | |
|     __STDC_ISO_10646__ An integer constant of the form yyyymmL (for example, 199712L ). If this
 | |
|                   symbol is defined, then every character in the Unicode required set, when stored in an
 | |
|                   object of type wchar_t, has the same value as the short identifier of that character. The
 | |
|                   Unicode required set consists of all the characters that are defined by ISO/IEC 10646, along
 | |
|                   with all amendments and technical corrigenda, as of the specified year and month. If
 | |
|                   some other encoding is used, the macro shall not be defined and the actual encoding
 | |
|                   used is implementation-defined.
 | |
|     __STDC_MB_MIGHT_NEQ_WC__ The integer constant 1 , intended to indicate that, in the encoding for
 | |
|              wchar_t , a member of the basic character set need not have a code value equal to its
 | |
|                   value when used as the lone character in an integer character constant.
 | |
| 
 | |
|     Forward references: common definitions (<a href='#7.21'>7.21</a>), Unicode utilities (<a href='#7.30'>7.30</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.9.3'></a>
 | |
| <hr>
 | |
| <h3>6.10.9.3 [Conditional feature macros]</h3>
 | |
| <a name='6.10.9.3p1'></a>
 | |
| <pre>1   The following macro names are conditionally defined by the implementation:
 | |
| 
 | |
|     __STDC_ANALYZABLE__ The integer constant 1 , intended to indicate conformance to the specifica-
 | |
|                   tions in Annex L (Analyzability).
 | |
|     __STDC_IEC_60559_BFP__ The integer constant 202311L, intended to indicate conformance to
 | |
|                   Annex F (IEC 60559 floating-point arithmetic) for binary floating-point arithmetic.
 | |
|     __STDC_IEC_559__ The integer constant 1 , intended to indicate conformance to the specifications
 | |
|                   in Annex F (IEC 60559 floating-point arithmetic) for binary floating-point arithmetic. Use
 | |
|                   of this macro is an obsolescent feature.
 | |
|     __STDC_IEC_60559_DFP__ The integer constant 202311L, intended to indicate support of decimal
 | |
|                   floating types and conformance to Annex F (IEC 60559 floating-point arithmetic) for
 | |
|                   decimal floating-point arithmetic.
 | |
|     __STDC_IEC_60559_COMPLEX__ The integer constant 202311L, intended to indicate conformance
 | |
|                   to the specifications in Annex G (IEC 60559 compatible complex arithmetic).
 | |
|     __STDC_IEC_60559_TYPES__ The integer constant 202311L, intended to indicate conformance to
 | |
|                   the specification in Annex H (IEC 60559 interchange and extended types).
 | |
|     __STDC_IEC_559_COMPLEX__ The integer constant 1 , intended to indicate adherence to the specifi-
 | |
|                   cations in Annex G (IEC 60559 compatible complex arithmetic). Use of this macro is an
 | |
|                   obsolescent feature.
 | |
|     __STDC_LIB_EXT1__ The integer constant 202311L, intended to indicate support for the extensions
 | |
|                   defined in Annex K (Bounds-checking interfaces)<a href='#FOOTNOTE.228'><sup>[228]</sup></a> .
 | |
|     __STDC_NO_ATOMICS__ The integer constant 1, intended to indicate that the implementation does
 | |
|              not support atomic types (including the _Atomic type qualifier) and the <stdatomic.h>
 | |
|                   header.
 | |
|     __STDC_NO_COMPLEX__ The integer constant 1, intended to indicate that the implementation does
 | |
|              not support complex types or the <complex.h> header.
 | |
|     __STDC_NO_THREADS__ The integer constant 1, intended to indicate that the implementation does
 | |
|              not support the <threads.h> header.
 | |
|     __STDC_NO_VLA__ The integer constant 1 , intended to indicate that the implementation does not
 | |
|                  support variable length arrays with automatic storage duration. Parameters declared
 | |
|                  with variable length array types are adjusted and then define objects of automatic storage
 | |
|                  duration with pointer types. Thus, support for such declarations is mandatory.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.228'>
 | |
| <pre><i><b>Footnote 228)</b> The intention is that this will remain an integer constant of type long int that is increased with each revision of this
 | |
|     document.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='6.10.9.3p2'></a>
 | |
| <pre>2   An implementation that defines __STDC_NO_COMPLEX__ shall not define __STDC_IEC_60559_COMPLEX__
 | |
|     or __STDC_IEC_559_COMPLEX__ .
 | |
| 
 | |
| </pre>
 | |
| <a name='6.10.10'></a>
 | |
| <hr>
 | |
| <h3>6.10.10 [Pragma operator]</h3>
 | |
| <a name='6.10.10p1'></a>
 | |
| <pre>1 Semantics
 | |
|    A unary operator expression of the form:
 | |
|                            _Pragma ( string-literal )
 | |
| 
 | |
|     is processed as follows: The string literal is destringized by deleting any encoding prefix, deleting
 | |
|     the leading and trailing double-quotes, replacing each escape sequence \" by a double-quote, and
 | |
|     replacing each escape sequence \\ by a single backslash. The resulting sequence of characters
 | |
|     is processed through translation phase 3 to produce preprocessing tokens that are executed as if
 | |
|     they were the pp-tokens in a pragma directive. The original four preprocessing tokens in the unary
 | |
|     operator expression are removed.
 | |
| </pre>
 | |
| <a name='6.10.10p2'></a>
 | |
| <pre>2   EXAMPLE A directive of the form:
 | |
| 
 | |
|               #pragma listing on "..\listing.dir"
 | |
| 
 | |
|     can also be expressed as:
 | |
| 
 | |
|               _Pragma ("listing on \"..\\listing.dir\"")
 | |
| 
 | |
| 
 | |
|     The latter form is processed in the same way whether it appears literally as shown, or results from macro replacement, as in:
 | |
| 
 | |
|               #define LISTING(x) PRAGMA(listing on #x)
 | |
|               #define PRAGMA(x) _Pragma(#x)
 | |
| 
 | |
|               LISTING (..\listing.dir)
 | |
| </pre>
 | |
| <a name='6.11'></a>
 | |
| <hr>
 | |
| <h3>6.11 [Future language directions]</h3>
 | |
| <a name='6.11.1'></a>
 | |
| <hr>
 | |
| <h3>6.11.1 [Floating types]</h3>
 | |
| <a name='6.11.1p1'></a>
 | |
| <pre>1   Future standardization may include additional floating types, including those with greater range,
 | |
|     precision, or both than long double.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.11.2'></a>
 | |
| <hr>
 | |
| <h3>6.11.2 [Linkages of identifiers]</h3>
 | |
| <a name='6.11.2p1'></a>
 | |
| <pre>1   Declaring an identifier with internal linkage at file scope without the static storage-class specifier
 | |
|     is an obsolescent feature.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.11.3'></a>
 | |
| <hr>
 | |
| <h3>6.11.3 [External names]</h3>
 | |
| <a name='6.11.3p1'></a>
 | |
| <pre>1   Restriction of the significance of an external name to fewer than 255 characters (considering each
 | |
|     universal character name or extended source character as a single character) is an obsolescent feature
 | |
|     that is a concession to existing implementations.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.11.4'></a>
 | |
| <hr>
 | |
| <h3>6.11.4 [Character escape sequences]</h3>
 | |
| <a name='6.11.4p1'></a>
 | |
| <pre>1   Lowercase letters as escape sequences are reserved for future standardization. Other characters may
 | |
|     be used in extensions.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.11.5'></a>
 | |
| <hr>
 | |
| <h3>6.11.5 [Storage-class specifiers]</h3>
 | |
| <a name='6.11.5p1'></a>
 | |
| <pre>1   The placement of a storage-class specifier other than at the beginning of the declaration specifiers in
 | |
|     a declaration is an obsolescent feature.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.11.6'></a>
 | |
| <hr>
 | |
| <h3>6.11.6 [Pragma directives]</h3>
 | |
| <a name='6.11.6p1'></a>
 | |
| <pre>1   Pragmas whose first preprocessing token is STDC are reserved for future standardization.
 | |
| 
 | |
| </pre>
 | |
| <a name='6.11.7'></a>
 | |
| <hr>
 | |
| <h3>6.11.7 [Predefined macro names]</h3>
 | |
| <a name='6.11.7p1'></a>
 | |
| <pre>1   Macro names beginning with __STDC_ are reserved for future standardization.
 | |
| </pre>
 | |
| <a name='6.11.7p2'></a>
 | |
| <pre>2   Uses of the __STDC_IEC_559__ and __STDC_IEC_559_COMPLEX__ macros are obsolescent features.
 | |
| </pre>
 | |
| <a name='7.'></a>
 | |
| <hr>
 | |
| <h3>7. [Library]</h3>
 | |
| <a name='7.1'></a>
 | |
| <hr>
 | |
| <h3>7.1 [Introduction]</h3>
 | |
| <a name='7.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.1.1 [Definitions of terms]</h3>
 | |
| <a name='7.1.1p1'></a>
 | |
| <pre>1   A string is a contiguous sequence of characters terminated by and including the first null character.
 | |
|     The term multibyte string is sometimes used instead to emphasize special processing given to
 | |
|     multibyte characters contained in the string or to avoid confusion with a wide string. A pointer to
 | |
|     a string is a pointer to its initial (lowest addressed) character. The length of a string is the number
 | |
|     of bytes preceding the null character and the value of a string is the sequence of the values of the
 | |
|     contained characters, in order.
 | |
| </pre>
 | |
| <a name='7.1.1p2'></a>
 | |
| <pre>2   The decimal-point character is the character used by functions that convert floating-point numbers
 | |
|     to or from character sequences to denote the beginning of the fractional part of such character
 | |
|     sequences.<a href='#FOOTNOTE.229'><sup>[229]</sup></a> It is represented in the text and examples by a period, but may be changed by the
 | |
|     setlocale function.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.229'>
 | |
| <pre><i><b>Footnote 229)</b> The functions that make use of the decimal-point character are the numeric conversion functions (<a href='#7.24.1'>7.24.1</a>, <a href='#7.31.4.1'>7.31.4.1</a>) and the
 | |
|     formatted input/output functions (<a href='#7.23.6'>7.23.6</a>, <a href='#7.31.2'>7.31.2</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.1p3'></a>
 | |
| <pre>3   A null wide character is a wide character with code value zero.
 | |
| </pre>
 | |
| <a name='7.1.1p4'></a>
 | |
| <pre>4   A wide string is a contiguous sequence of wide characters terminated by and including the first null
 | |
|     wide character. A pointer to a wide string is a pointer to its initial (lowest addressed) wide character.
 | |
|     The length of a wide string is the number of wide characters preceding the null wide character and the
 | |
|     value of a wide string is the sequence of code values of the contained wide characters, in order.
 | |
| </pre>
 | |
| <a name='7.1.1p5'></a>
 | |
| <pre>5   A shift sequence is a contiguous sequence of bytes within a multibyte string that (potentially) causes
 | |
|     a change in shift state (see <a href='#5.2.1.1'>5.2.1.1</a>). A shift sequence shall not have a corresponding wide character;
 | |
|     it is instead taken to be an adjunct to an adjacent multibyte character.<a href='#FOOTNOTE.230'><sup>[230]</sup></a> In this clause, references to
 | |
|     "white-space character" refer to (execution) white-space character as defined by isspace. References to
 | |
|     "white-space wide character" refer to (execution) white-space wide character as defined by iswspace.
 | |
|     Forward references: character handling (<a href='#7.4'>7.4</a>), the setlocale function (<a href='#7.11.1.1'>7.11.1.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.230'>
 | |
| <pre><i><b>Footnote 230)</b> For state-dependent encodings, the values for MB_CUR_MAX and MB_LEN_MAX are thus required to be large enough to
 | |
|     count all the bytes in any complete multibyte character plus at least one adjacent shift sequence of maximum length. Whether
 | |
|     these counts provide for more than one shift sequence is the implementation’s choice.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.1.2 [Standard headers]</h3>
 | |
| <a name='7.1.2p1'></a>
 | |
| <pre>1   Each library function is declared in a header,<a href='#FOOTNOTE.231'><sup>[231]</sup></a> whose contents are made available by the #include
 | |
|     preprocessing directive. The header declares a set of related functions, plus any necessary types
 | |
|     and additional macros needed to facilitate their use. In addition to the provisions given in this
 | |
|     clause, an implementation that defines __STDC_LIB_EXT1__ shall conform to the specifications in
 | |
|     Annex K and Subclause <a href='#K.3'>K.3</a> should be read as if it were merged into the parallel structure of named
 | |
|     subclauses of this clause. Declarations of types described here or in Annex K shall not include type
 | |
|     qualifiers, unless explicitly stated otherwise.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.231'>
 | |
| <pre><i><b>Footnote 231)</b> A header is not necessarily a source file, nor are the < and > delimited sequences in header names necessarily valid source
 | |
|     file names.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.2p2'></a>
 | |
| <pre>2   An implementation that does not support decimal floating types (<a href='#6.10.9.3'>6.10.9.3</a>) need not support inter-
 | |
|     faces or aspects of interfaces that are specific to these types.
 | |
| </pre>
 | |
| <a name='7.1.2p3'></a>
 | |
| <pre>3   The standard headers are<a href='#FOOTNOTE.232'><sup>[232]</sup></a>
 | |
| 
 | |
|     <assert.h>                                 <fenv.h>                                    <limits.h>
 | |
|     <complex.h>                                <float.h>                                   <locale.h>
 | |
|     <ctype.h>                                  <inttypes.h>                                <math.h>
 | |
|     <errno.h>                                  <iso646.h>                                  <setjmp.h>
 | |
|     <signal.h>                              <stddef.h>                               <tgmath.h>
 | |
|     <stdalign.h>                            <stdint.h>                               <threads.h>
 | |
|     <stdarg.h>                              <stdio.h>                                <time.h>
 | |
|     <stdatomic.h>                           <stdlib.h>                               <uchar.h>
 | |
|     <stdbool.h>                             <stdnoreturn.h>                          <wchar.h>
 | |
|     <stdckdint.h>                           <string.h>                               <wctype.h>
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.232'>
 | |
| <pre><i><b>Footnote 232)</b> The headers <complex.h>, <stdatomic.h>, and <threads.h> are conditional features that implementations need not
 | |
|     support; see <a href='#6.10.9.3'>6.10.9.3</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.2p4'></a>
 | |
| <pre>4   If a file with the same name as one of the above < and > delimited sequences, not provided as part of
 | |
|     the implementation, is placed in any of the standard places that are searched for included source
 | |
|     files, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.1.2p5'></a>
 | |
| <pre>5   Standard headers may be included in any order; each may be included more than once in a given
 | |
|     scope, with no effect different from being included only once, except that the effect of including
 | |
|     <assert.h> depends on the definition of NDEBUG (see <a href='#7.2'>7.2</a>). If used, a header shall be included outside
 | |
|     of any external declaration or definition, and it shall first be included before the first reference to
 | |
|     any of the functions or objects it declares, or to any of the types or macros it defines. However, if
 | |
|     an identifier is declared or defined in more than one header, the second and subsequent associated
 | |
|     headers may be included after the initial reference to the identifier. The program shall not have any
 | |
|     macros with names lexically identical to keywords currently defined prior to the inclusion of the
 | |
|     header or when any macro defined in the header is expanded.
 | |
| </pre>
 | |
| <a name='7.1.2p6'></a>
 | |
| <pre>6   Some standard headers define or declare identifiers that had not been present in previous versions
 | |
|     of this document. To allow implementations and users to adapt to that situation, they also define a
 | |
|     version macro for feature test of the form __STDC_VERSION_XXXX_H__ which expands to 202311L,
 | |
|     where XXXX is the all-caps spelling of the corresponding header <xxxx.h>.
 | |
| </pre>
 | |
| <a name='7.1.2p7'></a>
 | |
| <pre>7   Any definition of an object-like macro described in this clause or Annex K shall expand to code that
 | |
|     is fully protected by parentheses where necessary, so that it groups in an arbitrary expression as if it
 | |
|     were a single identifier.
 | |
| </pre>
 | |
| <a name='7.1.2p8'></a>
 | |
| <pre>8   Any declaration of a library function shall have external linkage.
 | |
| </pre>
 | |
| <a name='7.1.2p9'></a>
 | |
| <pre>9   A summary of the contents of the standard headers is given in Annex B.
 | |
|     Forward references: diagnostics (<a href='#7.2'>7.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.1.3 [Reserved identifiers]</h3>
 | |
| <a name='7.1.3p1'></a>
 | |
| <pre>1   Each header declares or defines all identifiers listed in its associated subclause, and optionally
 | |
|     declares or defines identifiers listed in its associated future library directions subclause and identifiers
 | |
|     which are always reserved either for any use or for use as file scope identifiers.
 | |
| 
 | |
|       — All potentially reserved identifiers (including ones listed in the future library directions) that
 | |
|         are provided by an implementation with an external definition are reserved for any use. An
 | |
|         implementation shall not provide an external definition of a potentially reserved identifier
 | |
|         unless that identifier is reserved for a use where it would have external linkage. All other
 | |
|         potentially reserved identifiers that are provided by an implementation (including in the
 | |
|         form of a macro) are reserved for any use when the associated header is included. No other
 | |
|         potentially reserved identifiers are reserved.<a href='#FOOTNOTE.233'><sup>[233]</sup></a>
 | |
| 
 | |
|       — Each macro name in any of the following subclauses (including the future library directions)
 | |
|         is reserved for use as specified if any of its associated headers is included; unless explicitly
 | |
|         stated otherwise (see <a href='#7.1.4'>7.1.4</a>).
 | |
| 
 | |
|       — All identifiers with external linkage in any of the following subclauses (including the future
 | |
|         library directions) and errno are always reserved for use as identifiers with external linkage<a href='#FOOTNOTE.234'><sup>[234]</sup></a> .
 | |
| 
 | |
|       — Each identifier with file scope listed in any of the following subclauses (including the future
 | |
|             library directions) is reserved for use as a macro name and as an identifier with file scope in
 | |
|             the same name space if any of its associated headers is included.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.233'>
 | |
| <pre><i><b>Footnote 233)</b> A potentially reserved identifier becomes a reserved identifier when an implementation begins using it or a future
 | |
|     standard reserves it, but is otherwise available for use by the programmer.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.234'>
 | |
| <pre><i><b>Footnote 234)</b> The list of reserved identifiers with external linkage includes math_errhandling, setjmp, va_copy , and va_end .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.1.4 [Use of library functions]</h3>
 | |
| <a name='7.1.4p1'></a>
 | |
| <pre>1   Each of the following statements applies unless explicitly stated otherwise in the detailed descrip-
 | |
|     tions that follow:
 | |
| 
 | |
|       — If an argument to a function has an invalid value (such as a value outside the domain of the
 | |
|         function, or a pointer outside the address space of the program, or a null pointer, or a pointer
 | |
|         to non-modifiable storage when the corresponding parameter is not const-qualified) or a type
 | |
|         (after default argument promotion) not expected by a function with a variable number of
 | |
|         arguments, the behavior is undefined.
 | |
|       — If a function argument is described as being an array, the pointer actually passed to the function
 | |
|         shall have a value such that all address computations and accesses to objects (that would be
 | |
|         valid if the pointer did point to the first element of such an array) are in fact valid.<a href='#FOOTNOTE.235'><sup>[235]</sup></a>
 | |
|       — Any function declared in a header may be additionally implemented as a function-like macro
 | |
|         defined in the header, so if a library function is declared explicitly when its header is included,
 | |
|         one of the techniques shown below can be used to ensure the declaration is not affected by
 | |
|         such a macro. Any macro definition of a function can be suppressed locally by enclosing
 | |
|         the name of the function in parentheses, because the name is then not followed by the left
 | |
|         parenthesis that indicates expansion of a macro function name. For the same syntactic reason,
 | |
|         it is permitted to take the address of a library function even if it is also defined as a macro.<a href='#FOOTNOTE.236'><sup>[236]</sup></a>
 | |
|         The use of #undef to remove any macro definition will also ensure that an actual function is
 | |
|         referred to.
 | |
|       — Any invocation of a library function that is implemented as a macro shall expand to code that
 | |
|         evaluates each of its arguments exactly once, fully protected by parentheses where necessary,
 | |
|         so it is generally safe to use arbitrary expressions as arguments.<a href='#FOOTNOTE.237'><sup>[237]</sup></a>
 | |
|       — Likewise, those function-like macros described in the following subclauses may be invoked in
 | |
|         an expression anywhere a function with a compatible return type could be called. <a href='#FOOTNOTE.238'><sup>[238]</sup></a>
 | |
|       — All object-like macros listed as expanding to integer constant expressions shall additionally be
 | |
|         suitable for use in #if preprocessing directives.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.235'>
 | |
| <pre><i><b>Footnote 235)</b> This includes, for example, passing a valid pointer that points one-past-the-end of an array along with a size of 0, or
 | |
|     using any valid pointer with a size of 0.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.236'>
 | |
| <pre><i><b>Footnote 236)</b> This means that an implementation is required to provide an actual function for each library function, even if it also
 | |
|     provides a macro for that function.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.237'>
 | |
| <pre><i><b>Footnote 237)</b> Such macros might not contain the sequence points that the corresponding function calls do.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.238'>
 | |
| <pre><i><b>Footnote 238)</b> Because external identifiers and some macro names beginning with an underscore are reserved, implementations can
 | |
|     provide special semantics for such names. For example, the identifier _BUILTIN_abs could be used to indicate generation of
 | |
|     in-line code for the abs function. Thus, the appropriate header could specify
 | |
|                       #define abs(x) _BUILTIN_abs(x)
 | |
|     for a compiler whose code generator will accept it.
 | |
|       In this manner, a user desiring to guarantee that a given library function such as abs will be a genuine function can write
 | |
|                       #undef abs
 | |
|     whether the implementation’s header provides a macro implementation of abs or a built-in implementation. The prototype
 | |
|     for the function, which precedes and is hidden by any macro definition, is thereby revealed also.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.4p2'></a>
 | |
| <pre>2   Provided that a library function can be declared without reference to any type defined in a header, it
 | |
|     is also permissible to declare the function and use it without including its associated header.
 | |
| </pre>
 | |
| <a name='7.1.4p3'></a>
 | |
| <pre>3   There is a sequence point immediately before a library function returns.
 | |
| </pre>
 | |
| <a name='7.1.4p4'></a>
 | |
| <pre>4   The functions in the standard library are not guaranteed to be reentrant and may modify objects
 | |
|     with static or thread storage duration. <a href='#FOOTNOTE.239'><sup>[239]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.239'>
 | |
| <pre><i><b>Footnote 239)</b> Thus, a signal handler cannot, in general, call standard library functions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.4p5'></a>
 | |
| <pre>5   Unless explicitly stated otherwise in the detailed descriptions that follow, library functions shall
 | |
|     prevent data races as follows: A library function shall not directly or indirectly access objects
 | |
|     accessible by threads other than the current thread unless the objects are accessed directly or
 | |
|     indirectly via the function’s arguments. A library function shall not directly or indirectly modify
 | |
|     objects accessible by threads other than the current thread unless the objects are accessed directly
 | |
|     or indirectly via the function’s non-const arguments. <a href='#FOOTNOTE.240'><sup>[240]</sup></a> Implementations may share their own
 | |
|     internal objects between threads if the objects are not visible to users and are protected against data
 | |
|     races.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.240'>
 | |
| <pre><i><b>Footnote 240)</b> This means, for example, that an implementation is not permitted to use a static object for internal purposes without
 | |
|     synchronization because it could cause a data race even in programs that do not explicitly share objects between threads.
 | |
|     Similarly, an implementation of memcpy is not permitted to copy bytes beyond the specified length of the destination object
 | |
|     and then restore the original values because it could cause a data race if the program shared those bytes between threads.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.4p6'></a>
 | |
| <pre>6   Unless otherwise specified, library functions shall perform all operations solely within the current
 | |
|     thread if those operations have effects that are visible to users.<a href='#FOOTNOTE.241'><sup>[241]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.241'>
 | |
| <pre><i><b>Footnote 241)</b> This allows implementations to parallelize operations if there are no visible side effects.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.1.4p7'></a>
 | |
| <pre>7   EXAMPLE The function atoi can be used in any of several ways:
 | |
| 
 | |
|        — by use of its associated header (possibly generating a macro expansion)
 | |
| 
 | |
|                                      #include <stdlib.h>
 | |
|                                      const char *str;
 | |
|                                      /* ... */
 | |
|                                      i = atoi(str);
 | |
| 
 | |
|        — by use of its associated header (assuredly generating a true function reference)
 | |
| 
 | |
|                                      #include <stdlib.h>
 | |
|                                      #undef atoi
 | |
|                                      const char *str;
 | |
|                                      /* ... */
 | |
|                                      i = atoi(str);
 | |
| 
 | |
|            or
 | |
| 
 | |
|                                      #include <stdlib.h>
 | |
|                                      const char *str;
 | |
|                                      /* ... */
 | |
|                                      i = (atoi)(str);
 | |
| 
 | |
|        — by explicit declaration
 | |
| 
 | |
|                                      extern int atoi(const char *);
 | |
|                                      const char *str;
 | |
|                                      /* ... */
 | |
|                                      i = atoi(str);
 | |
| </pre>
 | |
| <a name='7.2'></a>
 | |
| <hr>
 | |
| <h3>7.2 [Diagnostics <assert.h>]</h3>
 | |
| <a name='7.2p1'></a>
 | |
| <pre>1   The header <assert.h> defines the assert and static_assert macros and refers to another
 | |
|     macro,
 | |
| 
 | |
|               NDEBUG
 | |
| 
 | |
| 
 | |
|     which is not defined by <assert.h>. If NDEBUG is defined as a macro name at the point in the source
 | |
|     file where <assert.h> is included, the assert macro is defined simply as
 | |
| 
 | |
|               #define assert(...) ((void)0)
 | |
| 
 | |
| 
 | |
|     The assert macro is redefined according to the current state of NDEBUG each time that <assert.h>
 | |
|     is included.
 | |
| </pre>
 | |
| <a name='7.2p2'></a>
 | |
| <pre>2   The assert macro shall be implemented as a macro with an ellipsis parameter, not as an actual
 | |
|     function. If the macro definition is suppressed in order to access an actual function, the behavior is
 | |
|     undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.2.1 [Program diagnostics]</h3>
 | |
| <a name='7.2.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.2.1.1 [The assert macro]</h3>
 | |
| <a name='7.2.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <assert.h>
 | |
|               void assert(scalar expression);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.2.1.1p2'></a>
 | |
| <pre>2   The assert macro puts diagnostic tests into programs; it expands to a void expression. When it
 | |
|     is executed, if expression (which shall have a scalar type) is false (that is, compares equal to 0),
 | |
|     the assert macro writes information about the particular call that failed (including the text of the
 | |
|     argument, the name of the source file, the source line number, and the name of the enclosing function
 | |
|     — the latter are respectively the values of the preprocessing macros __FILE__ and __LINE__ and of
 | |
|     the identifier __func__ ) on the standard error stream in an implementation-defined format.<a href='#FOOTNOTE.242'><sup>[242]</sup></a>
 | |
|     It then calls the abort function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.242'>
 | |
| <pre><i><b>Footnote 242)</b> The message written might be of the form:
 | |
|       Assertion failed:         expression, function abc, file xyz, line nnn.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.2.1.1p3'></a>
 | |
| <pre>3   The assert macro returns no value.
 | |
|     Forward references: the abort function (<a href='#7.24.4.1'>7.24.4.1</a>).
 | |
| </pre>
 | |
| <a name='7.3'></a>
 | |
| <hr>
 | |
| <h3>7.3 [Complex arithmetic <complex.h>]</h3>
 | |
| <a name='7.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.3.1 [Introduction]</h3>
 | |
| <a name='7.3.1p1'></a>
 | |
| <pre>1   The header <complex.h> defines macros and declares functions that support complex arithmetic.<a href='#FOOTNOTE.243'><sup>[243]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.243'>
 | |
| <pre><i><b>Footnote 243)</b> See "future library directions" (<a href='#7.33.1'>7.33.1</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.3.1p2'></a>
 | |
| <pre>2   Implementations that define the macro __STDC_NO_COMPLEX__ need not provide this header nor
 | |
|     support any of its facilities.
 | |
| </pre>
 | |
| <a name='7.3.1p3'></a>
 | |
| <pre>3   Each synopsis, other than for the CMPLX macros, specifies a family of functions consisting of a princi-
 | |
|     pal function with one or more double complex parameters and a double complex or double return
 | |
|     value; and other functions with the same name but with f and l suffixes which are corresponding
 | |
|     functions with float and long double parameters and return values.
 | |
| </pre>
 | |
| <a name='7.3.1p4'></a>
 | |
| <pre>4   The macro
 | |
| 
 | |
|               complex
 | |
| 
 | |
| 
 | |
|     expands to _Complex ; the macro
 | |
|               _Complex_I
 | |
| 
 | |
| 
 | |
|     expands to a constant expression of type float _Complex, with the value of the imaginary unit.<a href='#FOOTNOTE.244'><sup>[244]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.244'>
 | |
| <pre><i><b>Footnote 244)</b> The imaginary unit is a number i such that i2 = −1.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.3.1p5'></a>
 | |
| <pre>5   The macros
 | |
| 
 | |
|               imaginary
 | |
| 
 | |
| 
 | |
|     and
 | |
|               _Imaginary_I
 | |
| 
 | |
| 
 | |
|     are defined if and only if the implementation supports imaginary types;<a href='#FOOTNOTE.245'><sup>[245]</sup></a> if defined, they expand
 | |
|     to _Imaginary and a constant expression of type float _Imaginary with the value of the imaginary
 | |
|     unit.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.245'>
 | |
| <pre><i><b>Footnote 245)</b> A specification for imaginary types is in Annex G.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.3.1p6'></a>
 | |
| <pre>6   The macro
 | |
| 
 | |
|               I
 | |
| 
 | |
| 
 | |
|     expands to either _Imaginary_I or _Complex_I . If _Imaginary_I is not defined, I shall expand to
 | |
|     _Complex_I .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.1p7'></a>
 | |
| <pre>7   Notwithstanding the provisions of <a href='#7.1.3'>7.1.3</a>, a program may undefine and perhaps then redefine the
 | |
|     macros complex, imaginary, and I.
 | |
|     Forward references: the CMPLX macros (<a href='#7.3.9.3'>7.3.9.3</a>), IEC 60559-compatible complex arithmetic (An-
 | |
|     nex G).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.3.2 [Conventions]</h3>
 | |
| <a name='7.3.2p1'></a>
 | |
| <pre>1   Values are interpreted as radians, not degrees. An implementation may set errno but is not required
 | |
|     to.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.3.3 [Branch cuts]</h3>
 | |
| <a name='7.3.3p1'></a>
 | |
| <pre>1   Some of the functions below have branch cuts, across which the function is discontinuous. For
 | |
|     implementations with a signed zero (including all IEC 60559 implementations) that follow the
 | |
|     specifications of Annex G, the sign of zero distinguishes one side of a cut from another so the
 | |
|     function is continuous (except for format limitations) as the cut is approached from either side. For
 | |
|     example, for the square root function, which has a branch cut along the negative real axis, the top of
 | |
|     the cut, with imaginary part +0 , maps to the positive imaginary axis, and the bottom of the cut, with
 | |
|     imaginary part-0 , maps to the negative imaginary axis.
 | |
| </pre>
 | |
| <a name='7.3.3p2'></a>
 | |
| <pre>2   Implementations that do not support a signed zero (see Annex F) cannot distinguish the sides of
 | |
|     branch cuts. These implementations shall map a cut so the function is continuous as the cut is
 | |
|     approached coming around the finite endpoint of the cut in a counter clockwise direction. (Branch
 | |
|     cuts for the functions specified here have just one finite endpoint.) For example, for the square root
 | |
|     function, coming counter clockwise around the finite endpoint of the cut along the negative real axis
 | |
|     approaches the cut from above, so the cut maps to the positive imaginary axis.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.4'></a>
 | |
| <hr>
 | |
| <h3>7.3.4 [The CX_LIMITED_RANGE pragma]</h3>
 | |
| <a name='7.3.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <complex.h>
 | |
|                #pragma STDC CX_LIMITED_RANGE on-off-switch
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.4p2'></a>
 | |
| <pre>2   The usual mathematical formulas for complex multiply, divide, and absolute value are problem-
 | |
|     atic because of their treatment of infinities and because of undue overflow and underflow. The
 | |
|     CX_LIMITED_RANGE pragma can be used to inform the implementation that (where the state is "on")
 | |
|     the usual mathematical formulas are acceptable.<a href='#FOOTNOTE.246'><sup>[246]</sup></a> The pragma can occur either outside external
 | |
|     declarations or preceding all explicit declarations and statements inside a compound statement.
 | |
|     When outside external declarations, the pragma takes effect from its occurrence until another
 | |
|     CX_LIMITED_RANGE pragma is encountered, or until the end of the translation unit. When inside a
 | |
|     compound statement, the pragma takes effect from its occurrence until another CX_LIMITED_RANGE
 | |
|     pragma is encountered (including within a nested compound statement), or until the end of the
 | |
|     compound statement; at the end of a compound statement the state for the pragma is restored to
 | |
|     its condition just before the compound statement. If this pragma is used in any other context, the
 | |
|     behavior is undefined. The default state for the pragma is "off".
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.246'>
 | |
| <pre><i><b>Footnote 246)</b> The purpose of the pragma is to allow the implementation to use the formulas:
 | |
|             (x + iy) × (u + iv)   =   (xu − yv) + i(yu + xv)
 | |
|             (x + iy) / (u + iv)   =   [(xu + yv) + i(yu − xv)]/(u2 + v 2 )
 | |
|                                       p
 | |
|                        |x + iy|   =      x2 + y 2
 | |
|     where the programmer can determine they are safe.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.3.5'></a>
 | |
| <hr>
 | |
| <h3>7.3.5 [Trigonometric functions]</h3>
 | |
| <a name='7.3.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.3.5.1 [The cacos functions]</h3>
 | |
| <a name='7.3.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <complex.h>
 | |
|                double complex cacos(double complex z);
 | |
|                float complex cacosf(float complex z);
 | |
|                long double complex cacosl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.5.1p2'></a>
 | |
| <pre>2   The cacos functions compute the complex arc cosine of z, with branch cuts outside the interval
 | |
|     [−1, +1] along the real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.5.1p3'></a>
 | |
| <pre>3   The cacos functions return the complex arc cosine value, in the range of a strip mathematically
 | |
|     unbounded along the imaginary axis and in the interval [0, π] along the real axis.
 | |
| </pre>
 | |
| <a name='7.3.5.2'></a>
 | |
| <hr>
 | |
| <h3>7.3.5.2 [The casin functions]</h3>
 | |
| <a name='7.3.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|           #include <complex.h>
 | |
|            double complex casin(double complex z);
 | |
|            float complex casinf(float complex z);
 | |
|            long double complex casinl(long double complex z);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.5.2p2'></a>
 | |
| <pre>2   The casin functions compute the complex arc sine of z, with branch cuts outside the interval
 | |
|     [−1, +1] along the real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.5.2p3'></a>
 | |
| <pre>3   The casin functions return the complex arc sine value, in the range of a strip mathematically
 | |
|     unbounded along the imaginary axis and in the interval [− π2 , + π2 ] along the real axis.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.5.3'></a>
 | |
| <hr>
 | |
| <h3>7.3.5.3 [The catan functions]</h3>
 | |
| <a name='7.3.5.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|           #include <complex.h>
 | |
|            double complex catan(double complex z);
 | |
|            float complex catanf(float complex z);
 | |
|            long double complex catanl(long double complex z);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.5.3p2'></a>
 | |
| <pre>2   The catan functions compute the complex arc tangent of z, with branch cuts outside the interval
 | |
|     [−i, +i] along the imaginary axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.5.3p3'></a>
 | |
| <pre>3   The catan functions return the complex arc tangent value, in the range of a strip mathematically
 | |
|     unbounded along the imaginary axis and in the interval [− π2 , + π2 ] along the real axis.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.5.4'></a>
 | |
| <hr>
 | |
| <h3>7.3.5.4 [The ccos functions]</h3>
 | |
| <a name='7.3.5.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|           #include <complex.h>
 | |
|            double complex ccos(double complex z);
 | |
|            float complex ccosf(float complex z);
 | |
|            long double complex ccosl(long double complex z);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.5.4p2'></a>
 | |
| <pre>2   The ccos functions compute the complex cosine of z.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.5.4p3'></a>
 | |
| <pre>3   The ccos functions return the complex cosine value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.5.5'></a>
 | |
| <hr>
 | |
| <h3>7.3.5.5 [The csin functions]</h3>
 | |
| <a name='7.3.5.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|           #include <complex.h>
 | |
|            double complex csin(double complex z);
 | |
|            float complex csinf(float complex z);
 | |
|            long double complex csinl(long double complex z);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.5.5p2'></a>
 | |
| <pre>2   The csin functions compute the complex sine of z.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.5.5p3'></a>
 | |
| <pre>3   The csin functions return the complex sine value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.5.6'></a>
 | |
| <hr>
 | |
| <h3>7.3.5.6 [The ctan functions]</h3>
 | |
| <a name='7.3.5.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex ctan(double complex z);
 | |
|             float complex ctanf(float complex z);
 | |
|             long double complex ctanl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.5.6p2'></a>
 | |
| <pre>2   The ctan functions compute the complex tangent of z.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.5.6p3'></a>
 | |
| <pre>3   The ctan functions return the complex tangent value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.6'></a>
 | |
| <hr>
 | |
| <h3>7.3.6 [Hyperbolic functions]</h3>
 | |
| <a name='7.3.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.3.6.1 [The cacosh functions]</h3>
 | |
| <a name='7.3.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex cacosh(double complex z);
 | |
|             float complex cacoshf(float complex z);
 | |
|             long double complex cacoshl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.6.1p2'></a>
 | |
| <pre>2   The cacosh functions compute the complex arc hyperbolic cosine of z, with a branch cut at values
 | |
|     less than 1 along the real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.6.1p3'></a>
 | |
| <pre>3   The cacosh functions return the complex arc hyperbolic cosine value, in the range of a half-strip of
 | |
|     nonnegative values along the real axis and in the interval [−iπ, +iπ] along the imaginary axis.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.3.6.2 [The casinh functions]</h3>
 | |
| <a name='7.3.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex casinh(double complex z);
 | |
|             float complex casinhf(float complex z);
 | |
|             long double complex casinhl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.6.2p2'></a>
 | |
| <pre>2   The casinh functions compute the complex arc hyperbolic sine of z, with branch cuts outside the
 | |
|     interval [−i, +i] along the imaginary axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.6.2p3'></a>
 | |
| <pre>3   The casinh functions return the complex arc hyperbolic sine value, in the range of a strip mathe-
 | |
|     matically unbounded along the real axis and in the interval [− iπ    iπ
 | |
|                                                                     2 , + 2 ] along the imaginary axis.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.3.6.3 [The catanh functions]</h3>
 | |
| <a name='7.3.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex catanh(double complex z);
 | |
|             float complex catanhf(float complex z);
 | |
|             long double complex catanhl(long double complex z);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.6.3p2'></a>
 | |
| <pre>2   The catanh functions compute the complex arc hyperbolic tangent of z, with branch cuts outside
 | |
|     the interval [−1, +1] along the real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.6.3p3'></a>
 | |
| <pre>3   The catanh functions return the complex arc hyperbolic tangent value, in the range of a strip
 | |
|     mathematically unbounded along the real axis and in the interval [− iπ    iπ
 | |
|                                                                          2 , + 2 ] along the imaginary
 | |
|     axis.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.3.6.4 [The ccosh functions]</h3>
 | |
| <a name='7.3.6.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex ccosh(double complex z);
 | |
|             float complex ccoshf(float complex z);
 | |
|             long double complex ccoshl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.6.4p2'></a>
 | |
| <pre>2   The ccosh functions compute the complex hyperbolic cosine of z.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.6.4p3'></a>
 | |
| <pre>3   The ccosh functions return the complex hyperbolic cosine value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.6.5'></a>
 | |
| <hr>
 | |
| <h3>7.3.6.5 [The csinh functions]</h3>
 | |
| <a name='7.3.6.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex csinh(double complex z);
 | |
|             float complex csinhf(float complex z);
 | |
|             long double complex csinhl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.6.5p2'></a>
 | |
| <pre>2   The csinh functions compute the complex hyperbolic sine of z.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.6.5p3'></a>
 | |
| <pre>3   The csinh functions return the complex hyperbolic sine value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.6.6'></a>
 | |
| <hr>
 | |
| <h3>7.3.6.6 [The ctanh functions]</h3>
 | |
| <a name='7.3.6.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex ctanh(double complex z);
 | |
|             float complex ctanhf(float complex z);
 | |
|             long double complex ctanhl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.6.6p2'></a>
 | |
| <pre>2   The ctanh functions compute the complex hyperbolic tangent of z.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.6.6p3'></a>
 | |
| <pre>3   The ctanh functions return the complex hyperbolic tangent value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.7'></a>
 | |
| <hr>
 | |
| <h3>7.3.7 [Exponential and logarithmic functions]</h3>
 | |
| <a name='7.3.7.1'></a>
 | |
| <hr>
 | |
| <h3>7.3.7.1 [The cexp functions]</h3>
 | |
| <a name='7.3.7.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex cexp(double complex z);
 | |
|             float complex cexpf(float complex z);
 | |
|             long double complex cexpl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.7.1p2'></a>
 | |
| <pre>2   The cexp functions compute the complex base-e exponential of z.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.7.1p3'></a>
 | |
| <pre>3   The cexp functions return the complex base-e exponential value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.7.2'></a>
 | |
| <hr>
 | |
| <h3>7.3.7.2 [The clog functions]</h3>
 | |
| <a name='7.3.7.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex clog(double complex z);
 | |
|             float complex clogf(float complex z);
 | |
|             long double complex clogl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.7.2p2'></a>
 | |
| <pre>2   The clog functions compute the complex natural (base-e) logarithm of z, with a branch cut along
 | |
|     the negative real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.7.2p3'></a>
 | |
| <pre>3   The clog functions return the complex natural logarithm value, in the range of a strip mathematically
 | |
|     unbounded along the real axis and in the interval [−iπ, +iπ] along the imaginary axis.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.8'></a>
 | |
| <hr>
 | |
| <h3>7.3.8 [Power and absolute-value functions]</h3>
 | |
| <a name='7.3.8.1'></a>
 | |
| <hr>
 | |
| <h3>7.3.8.1 [The cabs functions]</h3>
 | |
| <a name='7.3.8.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double cabs(double complex z);
 | |
|             float cabsf(float complex z);
 | |
|             long double cabsl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.8.1p2'></a>
 | |
| <pre>2   The cabs functions compute the complex absolute value (also called norm, modulus, or magnitude)
 | |
|     of z.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.8.1p3'></a>
 | |
| <pre>3   The cabs functions return the complex absolute value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.8.2'></a>
 | |
| <hr>
 | |
| <h3>7.3.8.2 [The cpow functions]</h3>
 | |
| <a name='7.3.8.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <complex.h>
 | |
|             double complex cpow(double complex x, double complex y);
 | |
|             float complex cpowf(float complex x, float complex y);
 | |
|             long double complex cpowl(long double complex x, long double complex y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.8.2p2'></a>
 | |
| <pre>2   The cpow functions compute the complex power function xy , with a branch cut for the first parameter
 | |
|     along the negative real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.8.2p3'></a>
 | |
| <pre>3   The cpow functions return the complex power function value.
 | |
| </pre>
 | |
| <a name='7.3.8.3'></a>
 | |
| <hr>
 | |
| <h3>7.3.8.3 [The csqrt functions]</h3>
 | |
| <a name='7.3.8.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <complex.h>
 | |
|              double complex csqrt(double complex z);
 | |
|              float complex csqrtf(float complex z);
 | |
|              long double complex csqrtl(long double complex z);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.8.3p2'></a>
 | |
| <pre>2   The csqrt functions compute the complex square root of z, with a branch cut along the negative
 | |
|     real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.8.3p3'></a>
 | |
| <pre>3   The csqrt functions return the complex square root value, in the range of the right half-plane
 | |
|     (including the imaginary axis).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.9'></a>
 | |
| <hr>
 | |
| <h3>7.3.9 [Manipulation functions]</h3>
 | |
| <a name='7.3.9.1'></a>
 | |
| <hr>
 | |
| <h3>7.3.9.1 [The carg functions]</h3>
 | |
| <a name='7.3.9.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <complex.h>
 | |
|              double carg(double complex z);
 | |
|              float cargf(float complex z);
 | |
|              long double cargl(long double complex z);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.9.1p2'></a>
 | |
| <pre>2   The carg functions compute the argument (also called phase angle) of z, with a branch cut along
 | |
|     the negative real axis.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.9.1p3'></a>
 | |
| <pre>3   The carg functions return the value of the argument in the interval [−π, +π].
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.9.2'></a>
 | |
| <hr>
 | |
| <h3>7.3.9.2 [The cimag functions]</h3>
 | |
| <a name='7.3.9.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <complex.h>
 | |
|              double cimag(double complex z);
 | |
|              float cimagf(float complex z);
 | |
|              long double cimagl(long double complex z);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.9.2p2'></a>
 | |
| <pre>2   The cimag functions compute the imaginary part of z.<a href='#FOOTNOTE.247'><sup>[247]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.247'>
 | |
| <pre><i><b>Footnote 247)</b> For a variable z of complex type, z == creal(z)+cimag(z) I.
 | |
|                                                                  *
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.3.9.2p3'></a>
 | |
| <pre>3   The cimag functions return the imaginary part value (as a real).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.9.3'></a>
 | |
| <hr>
 | |
| <h3>7.3.9.3 [The CMPLX macros]</h3>
 | |
| <a name='7.3.9.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <complex.h>
 | |
|              double complex CMPLX(double x, double y);
 | |
|              float complex CMPLXF(float x, float y);
 | |
|              long double complex CMPLXL(long double x, long double y);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.9.3p2'></a>
 | |
| <pre>2   The CMPLX macros expand to an expression of the specified complex type, with the real part having
 | |
|     the (converted) value of x and the imaginary part having the (converted) value of y. The resulting
 | |
|     expression shall be suitable for use as an initializer for an object with static or thread storage duration,
 | |
|     provided both arguments are likewise suitable.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.9.3p3'></a>
 | |
| <pre>3   The CMPLX macros return the complex value x + iy.
 | |
| </pre>
 | |
| <a name='7.3.9.3p4'></a>
 | |
| <pre>4   NOTE These macros act as if the implementation supported imaginary types and the definitions were:
 | |
| 
 | |
|      #define CMPLX(x, y)  ((double complex)((double)(x) + \
 | |
|                                    _Imaginary_I * (double)(y)))
 | |
|      #define CMPLXF(x, y) ((float complex)((float)(x) + \
 | |
|                                    _Imaginary_I * (float)(y)))
 | |
|      #define CMPLXL(x, y) ((long double complex)((long double)(x) + \
 | |
|                                    _Imaginary_I * (long double)(y)))
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.9.4'></a>
 | |
| <hr>
 | |
| <h3>7.3.9.4 [The conj functions]</h3>
 | |
| <a name='7.3.9.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <complex.h>
 | |
|              double complex conj(double complex z);
 | |
|              float complex conjf(float complex z);
 | |
|              long double complex conjl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.9.4p2'></a>
 | |
| <pre>2   The conj functions compute the complex conjugate of z, by reversing the sign of its imaginary part.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.9.4p3'></a>
 | |
| <pre>3   The conj functions return the complex conjugate value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.9.5'></a>
 | |
| <hr>
 | |
| <h3>7.3.9.5 [The cproj functions]</h3>
 | |
| <a name='7.3.9.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <complex.h>
 | |
|              double complex cproj(double complex z);
 | |
|              float complex cprojf(float complex z);
 | |
|              long double complex cprojl(long double complex z);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.9.5p2'></a>
 | |
| <pre>2   The cproj functions compute a projection of z onto the Riemann sphere: z projects to z except that
 | |
|     all complex infinities (even those with one infinite part and one NaN part) project to positive infinity
 | |
|     on the real axis. If z has an infinite part, then cproj(z) is equivalent to
 | |
| 
 | |
|              INFINITY + I * copysign(0.0, cimag(z))
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.3.9.5p3'></a>
 | |
| <pre>3   The cproj functions return the value of the projection onto the Riemann sphere.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.3.9.6'></a>
 | |
| <hr>
 | |
| <h3>7.3.9.6 [The creal functions]</h3>
 | |
| <a name='7.3.9.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <complex.h>
 | |
|              double creal(double complex z);
 | |
|              float crealf(float complex z);
 | |
|              long double creall(long double complex z);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.3.9.6p2'></a>
 | |
| <pre>2   The creal functions compute the real part of z.<a href='#FOOTNOTE.248'><sup>[248]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.248'>
 | |
| <pre><i><b>Footnote 248)</b> For a variable z of complex type, z == creal(z)+cimag(z) I.
 | |
|                                                                  *
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.3.9.6p3'></a>
 | |
| <pre>3   The creal functions return the real part value.
 | |
| </pre>
 | |
| <a name='7.4'></a>
 | |
| <hr>
 | |
| <h3>7.4 [Character handling <ctype.h>]</h3>
 | |
| <a name='7.4p1'></a>
 | |
| <pre>1   The header <ctype.h> declares several functions useful for classifying and mapping characters.<a href='#FOOTNOTE.249'><sup>[249]</sup></a>
 | |
|     In all cases the argument is an int, the value of which shall be representable as an unsigned char
 | |
|     or shall equal the value of the macro EOF. If the argument has any other value, the behavior is
 | |
|     undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.249'>
 | |
| <pre><i><b>Footnote 249)</b> See "future library directions" (<a href='#7.33.2'>7.33.2</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.4p2'></a>
 | |
| <pre>2   The behavior of these functions is affected by the current locale. Those functions that have locale-
 | |
|     specific aspects only when not in the "C" locale are noted below.
 | |
| </pre>
 | |
| <a name='7.4p3'></a>
 | |
| <pre>3   The term printing character refers to a member of a locale-specific set of characters, each of which
 | |
|     occupies one printing position on a display device; the term control character refers to a member of a
 | |
|     locale-specific set of characters that are not printing characters.<a href='#FOOTNOTE.250'><sup>[250]</sup></a> All letters and digits are printing
 | |
|     characters.
 | |
|     Forward references: EOF (<a href='#7.23.1'>7.23.1</a>), localization (<a href='#7.11'>7.11</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.250'>
 | |
| <pre><i><b>Footnote 250)</b> In an implementation that uses the seven-bit US ASCII character set, the printing characters are those whose values lie
 | |
|     from 0x20 (space) through 0x7E (tilde); the control characters are those whose values lie from 0 (NUL) through 0x1F (US),
 | |
|     and the character 0x7F (DEL).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.4.1 [Character classification functions]</h3>
 | |
| <a name='7.4.1p1'></a>
 | |
| <pre>1   The functions in this subclause return nonzero (true) if and only if the value of the argument c
 | |
|     conforms to that in the description of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.1 [The isalnum function]</h3>
 | |
| <a name='7.4.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <ctype.h>
 | |
|               int isalnum(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.1p2'></a>
 | |
| <pre>2   The isalnum function tests for any character for which isalpha or isdigit is true.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.2 [The isalpha function]</h3>
 | |
| <a name='7.4.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <ctype.h>
 | |
|               int isalpha(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.2p2'></a>
 | |
| <pre>2   The isalpha function tests for any character for which isupper or islower is true, or any character
 | |
|     that is one of a locale-specific set of alphabetic characters for which none of iscntrl, isdigit,
 | |
|     ispunct, or isspace is true.<a href='#FOOTNOTE.251'><sup>[251]</sup></a> In the "C" locale, isalpha returns true only for the characters for
 | |
|     which isupper or islower is true.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.251'>
 | |
| <pre><i><b>Footnote 251)</b> The functions islower and isupper test true or false separately for each of these additional characters; all four combina-
 | |
|     tions are possible.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.4.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.3 [The isblank function]</h3>
 | |
| <a name='7.4.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <ctype.h>
 | |
|               int isblank(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.3p2'></a>
 | |
| <pre>2   The isblank function tests for any character that is a standard blank character or is one of a locale-
 | |
|     specific set of characters for which isspace is true and that is used to separate words within a line
 | |
|     of text. The standard blank characters are the following: space (’ ’ ), and horizontal tab (’\t’ ). In
 | |
|     the "C" locale, isblank returns true only for the standard blank characters.
 | |
| </pre>
 | |
| <a name='7.4.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.4 [The iscntrl function]</h3>
 | |
| <a name='7.4.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int iscntrl(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.4p2'></a>
 | |
| <pre>2   The iscntrl function tests for any control character.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.5'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.5 [The isdigit function]</h3>
 | |
| <a name='7.4.1.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int isdigit(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.5p2'></a>
 | |
| <pre>2   The isdigit function tests for any decimal-digit character (as defined in <a href='#5.2.1'>5.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.6'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.6 [The isgraph function]</h3>
 | |
| <a name='7.4.1.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int isgraph(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.6p2'></a>
 | |
| <pre>2   The isgraph function tests for any printing character except space (’ ’ ).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.7'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.7 [The islower function]</h3>
 | |
| <a name='7.4.1.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int islower(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.7p2'></a>
 | |
| <pre>2   The islower function tests for any character that is a lowercase letter or is one of a locale-specific set
 | |
|     of characters for which none of iscntrl, isdigit, ispunct, or isspace is true. In the "C" locale,
 | |
|     islower returns true only for the lowercase letters (as defined in <a href='#5.2.1'>5.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.8'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.8 [The isprint function]</h3>
 | |
| <a name='7.4.1.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int isprint(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.8p2'></a>
 | |
| <pre>2   The isprint function tests for any printing character including space (’ ’ ).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.9'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.9 [The ispunct function]</h3>
 | |
| <a name='7.4.1.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int ispunct(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.9p2'></a>
 | |
| <pre>2   The ispunct function tests for any printing character that is one of a locale-specific set of punctuation
 | |
|     characters for which neither isspace nor isalnum is true. In the "C" locale, ispunct returns true
 | |
|     for every printing character for which neither isspace nor isalnum is true.
 | |
| </pre>
 | |
| <a name='7.4.1.10'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.10 [The isspace function]</h3>
 | |
| <a name='7.4.1.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int isspace(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.10p2'></a>
 | |
| <pre>2   The isspace function tests for any character that is a standard white-space character or is one of
 | |
|     a locale-specific set of characters for which isalnum is false. The standard white-space characters
 | |
|     are the following: space (’ ’ ), form feed (’\f’ ), new-line (’\n’ ), carriage return (’\r’ ), horizontal
 | |
|     tab (’\t’ ), and vertical tab (’\v’ ). In the "C" locale, isspace returns true only for the standard
 | |
|     white-space characters.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.11'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.11 [The isupper function]</h3>
 | |
| <a name='7.4.1.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int isupper(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.11p2'></a>
 | |
| <pre>2   The isupper function tests for any character that is an uppercase letter or is one of a locale-specific
 | |
|     set of characters for which none of iscntrl, isdigit, ispunct, or isspace is true. In the "C" locale,
 | |
|     isupper returns true only for the uppercase letters (as defined in <a href='#5.2.1'>5.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.1.12'></a>
 | |
| <hr>
 | |
| <h3>7.4.1.12 [The isxdigit function]</h3>
 | |
| <a name='7.4.1.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int isxdigit(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.1.12p2'></a>
 | |
| <pre>2   The isxdigit function tests for any hexadecimal-digit character (as defined in <a href='#6.4.4.1'>6.4.4.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.4.2 [Character case mapping functions]</h3>
 | |
| <a name='7.4.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.4.2.1 [The tolower function]</h3>
 | |
| <a name='7.4.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int tolower(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.2.1p2'></a>
 | |
| <pre>2   The tolower function converts an uppercase letter to a corresponding lowercase letter.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.4.2.1p3'></a>
 | |
| <pre>3   If the argument is a character for which isupper is true and there are one or more corresponding
 | |
|     characters, as specified by the current locale, for which islower is true, the tolower function returns
 | |
|     one of the corresponding characters (always the same one for any given locale); otherwise, the
 | |
|     argument is returned unchanged.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.4.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.4.2.2 [The toupper function]</h3>
 | |
| <a name='7.4.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <ctype.h>
 | |
|             int toupper(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.4.2.2p2'></a>
 | |
| <pre>2   The toupper function converts a lowercase letter to a corresponding uppercase letter.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.4.2.2p3'></a>
 | |
| <pre>3   If the argument is a character for which islower is true and there are one or more corresponding
 | |
|     characters, as specified by the current locale, for which isupper is true, the toupper function returns
 | |
|     one of the corresponding characters (always the same one for any given locale); otherwise, the
 | |
|     argument is returned unchanged.
 | |
| </pre>
 | |
| <a name='7.5'></a>
 | |
| <hr>
 | |
| <h3>7.5 [Errors <errno.h>]</h3>
 | |
| <a name='7.5p1'></a>
 | |
| <pre>1   The header <errno.h> defines several macros, all relating to the reporting of error conditions.
 | |
| </pre>
 | |
| <a name='7.5p2'></a>
 | |
| <pre>2   The macros are
 | |
| 
 | |
|               EDOM
 | |
|               EILSEQ
 | |
|               ERANGE
 | |
| 
 | |
| 
 | |
|     which expand to integer constant expressions with type int, distinct positive values, and which are
 | |
|     suitable for use in #if preprocessing directives; and
 | |
| 
 | |
|               errno
 | |
| 
 | |
| 
 | |
|     which expands to a modifiable lvalue<a href='#FOOTNOTE.252'><sup>[252]</sup></a> that has type int and thread storage duration, the value
 | |
|     of which is set to a positive error number by several library functions. If a macro definition is
 | |
|     suppressed in order to access an actual object, or a program defines an identifier with the name
 | |
|     errno, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.252'>
 | |
| <pre><i><b>Footnote 252)</b> The macro errno need not be the identifier of an object. It might expand to a modifiable lvalue resulting from a function
 | |
|     call (for example, *errno() ).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.5p3'></a>
 | |
| <pre>3   The value of errno in the initial thread is zero at program startup (the initial representation of the
 | |
|     object designated by errno in other threads is indeterminate), but is never set to zero by any library
 | |
|     function<a href='#FOOTNOTE.253'><sup>[253]</sup></a> . The value of errno may be set to nonzero by a library function call whether or not there
 | |
|     is an error, provided the use of errno is not documented in the description of the function in this
 | |
|     document.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.253'>
 | |
| <pre><i><b>Footnote 253)</b> Thus, a program that uses errno for error checking would set it to zero before a library function call, then inspect it
 | |
|     before a subsequent library function call. Of course, a library function can save the value of errno on entry and then set it to
 | |
|     zero, as long as the original value is restored if errno’s value is still zero just before the return.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.5p4'></a>
 | |
| <pre>4   Additional macro definitions, beginning with E and a digit or E and an uppercase letter,<a href='#FOOTNOTE.254'><sup>[254]</sup></a> may also
 | |
|     be specified by the implementation.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.254'>
 | |
| <pre><i><b>Footnote 254)</b> See "future library directions" (<a href='#7.33.3'>7.33.3</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6'></a>
 | |
| <hr>
 | |
| <h3>7.6 [Floating-point environment <fenv.h>]</h3>
 | |
| <a name='7.6p1'></a>
 | |
| <pre>1   The header <fenv.h> defines several macros, and declares types and functions that provide access to
 | |
|     the floating-point environment. The floating-point environment refers collectively to any floating-point
 | |
|     status flags and control modes supported by the implementation.<a href='#FOOTNOTE.255'><sup>[255]</sup></a>
 | |
|     A floating-point status flag is a system variable whose value is set (but never cleared) when a floating-
 | |
|     point exception is raised, which occurs as a side effect of exceptional floating-point arithmetic to
 | |
|     provide auxiliary information.<a href='#FOOTNOTE.256'><sup>[256]</sup></a> A floating-point control mode is a system variable whose value may
 | |
|     be set by the user to affect the subsequent behavior of floating-point arithmetic.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.255'>
 | |
| <pre><i><b>Footnote 255)</b> This header is designed to support the floating-point exception status flags and rounding-direction control modes
 | |
|     required by IEC 60559, and other similar floating-point state information. It is also designed to facilitate code portability
 | |
|     among all systems.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.256'>
 | |
| <pre><i><b>Footnote 256)</b> A floating-point status flag is not an object and can be set more than once within an expression.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6p2'></a>
 | |
| <pre>2   A floating-point control mode may be constant (<a href='#7.6.2'>7.6.2</a>) or dynamic. The dynamic floating-point en-
 | |
|     vironment includes the dynamic floating-point control modes and the floating-point status flags.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6p3'></a>
 | |
| <pre>3   The dynamic floating-point environment has thread storage duration. The initial state for a thread’s
 | |
|     dynamic floating-point environment is the current state of the dynamic floating-point environment
 | |
|     of the thread that creates it at the time of creation.
 | |
| </pre>
 | |
| <a name='7.6p4'></a>
 | |
| <pre>4   Certain programming conventions support the intended model of use for the dynamic floating-point
 | |
|     environment:<a href='#FOOTNOTE.257'><sup>[257]</sup></a>
 | |
| 
 | |
|       — a function call does not alter its caller’s floating-point control modes, clear its caller’s floating-
 | |
|         point status flags, nor depend on the state of its caller’s floating-point status flags unless the
 | |
|         function is so documented;
 | |
| 
 | |
|       — a function call is assumed to require default floating-point control modes, unless its documen-
 | |
|         tation promises otherwise;
 | |
| 
 | |
|       — a function call is assumed to have the potential for raising floating-point exceptions, unless its
 | |
|         documentation promises otherwise.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.257'>
 | |
| <pre><i><b>Footnote 257)</b> With these conventions, a programmer can safely assume default floating-point control modes (or be unaware of them).
 | |
|     The responsibilities associated with accessing the floating-point environment fall on the programmer or program that does so
 | |
|     explicitly.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6p5'></a>
 | |
| <pre>5   The feature test macro __STDC_VERSION_FENV_H__ expands to the token 202311L.
 | |
| </pre>
 | |
| <a name='7.6p6'></a>
 | |
| <pre>6   The type
 | |
| 
 | |
|               fenv_t
 | |
| 
 | |
| 
 | |
|     represents the entire dynamic floating-point environment.
 | |
| </pre>
 | |
| <a name='7.6p7'></a>
 | |
| <pre>7   The type
 | |
| 
 | |
|               femode_t
 | |
| 
 | |
| 
 | |
|     represents the collection of dynamic floating-point control modes supported by the implementation,
 | |
|     including the dynamic rounding direction mode.
 | |
| </pre>
 | |
| <a name='7.6p8'></a>
 | |
| <pre>8   The type
 | |
| 
 | |
|               fexcept_t
 | |
| 
 | |
| 
 | |
|     represents the floating-point status flags collectively, including any status the implementation
 | |
|     associates with the flags.
 | |
| </pre>
 | |
| <a name='7.6p9'></a>
 | |
| <pre>9   Each of the macros
 | |
|                FE_DIVBYZERO
 | |
|                FE_INEXACT
 | |
|                FE_INVALID
 | |
|                FE_OVERFLOW
 | |
|                FE_UNDERFLOW
 | |
| 
 | |
| 
 | |
|      is defined if and only if the implementation supports the floating-point exception by means of
 | |
|      the functions in <a href='#7.6.4'>7.6.4</a>.<a href='#FOOTNOTE.258'><sup>[258]</sup></a> Additional implementation-defined floating-point exceptions, with
 | |
|      macro definitions beginning with FE_ and an uppercase letter,<a href='#FOOTNOTE.259'><sup>[259]</sup></a> may also be specified by the
 | |
|      implementation. The defined macros expand to integer constant expressions with values such that
 | |
|      bitwise ORs of all combinations of the macros result in distinct values, and furthermore, bitwise
 | |
|      ANDs of all combinations of the macros result in zero.<a href='#FOOTNOTE.260'><sup>[260]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.258'>
 | |
| <pre><i><b>Footnote 258)</b> The implementation supports a floating-point exception if there are circumstances where a call to at least one of the
 | |
|      functions in <a href='#7.6.4'>7.6.4</a>, using the macro as the appropriate argument, will succeed. It is not necessary for all the functions to
 | |
|      succeed all the time.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.259'>
 | |
| <pre><i><b>Footnote 259)</b> See "future library directions" (<a href='#7.33.4'>7.33.4</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.260'>
 | |
| <pre><i><b>Footnote 260)</b> The macros are typically distinct powers of two.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6p10'></a>
 | |
| <pre>10   Decimal floating-point operations and IEC 60559 binary floating-point operations (Annex F) access
 | |
|      the same floating-point exception status flags.
 | |
| </pre>
 | |
| <a name='7.6p11'></a>
 | |
| <pre>11   The macro
 | |
| 
 | |
|                FE_DFL_MODE
 | |
| 
 | |
| 
 | |
|      represents the default state for the collection of dynamic floating-point control modes sup-
 | |
|      ported by the implementation – and has type "pointer to const-qualified femode_t". Additional
 | |
|      implementation-defined states for the dynamic mode collection, with macro definitions beginning
 | |
|      with FE_ and an uppercase letter, and having type "pointer to const-qualified femode_t", may also
 | |
|      be specified by the implementation.
 | |
| </pre>
 | |
| <a name='7.6p12'></a>
 | |
| <pre>12   The macro
 | |
| 
 | |
|                FE_ALL_EXCEPT
 | |
| 
 | |
| 
 | |
|      is simply the bitwise OR of all floating-point exception macros defined by the implementation. If no
 | |
|      such macros are defined, FE_ALL_EXCEPT shall be defined as 0.
 | |
| </pre>
 | |
| <a name='7.6p13'></a>
 | |
| <pre>13   Each of the macros
 | |
| 
 | |
|                FE_DOWNWARD
 | |
|                FE_TONEAREST
 | |
|                FE_TONEARESTFROMZERO
 | |
|                FE_TOWARDZERO
 | |
|                FE_UPWARD
 | |
| 
 | |
| 
 | |
|      is defined if and only if the implementation supports getting and setting the represented rounding
 | |
|      direction by means of the fegetround and fesetround functions. Additional implementation-
 | |
|      defined rounding directions, with macro definitions beginning with FE_ and an uppercase letter,<a href='#FOOTNOTE.261'><sup>[261]</sup></a>
 | |
|      may also be specified by the implementation.<a href='#FOOTNOTE.262'><sup>[262]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.261'>
 | |
| <pre><i><b>Footnote 261)</b> See "future library directions" (<a href='#7.33.4'>7.33.4</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.262'>
 | |
| <pre><i><b>Footnote 262)</b> Even though the rounding direction macros might expand to constants corresponding to the values of FLT_ROUNDS, they
 | |
|      are not required to do so.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6p14'></a>
 | |
| <pre>14   If the implementation supports decimal floating types, each of the macros
 | |
| 
 | |
|                FE_DEC_DOWNWARD
 | |
|                FE_DEC_TONEAREST
 | |
|                FE_DEC_TONEARESTFROMZERO
 | |
|                FE_DEC_TOWARDZERO
 | |
|                FE_DEC_UPWARD
 | |
|      is defined for use with the fe_dec_getround and fe_dec_setround functions for getting and
 | |
|      setting the dynamic rounding direction mode, and with the FENV_DEC_ROUND rounding control
 | |
|      pragma (<a href='#7.6.3'>7.6.3</a>) for specifying a constant rounding direction, for decimal floating-point operations.
 | |
|      The decimal rounding direction affects all (inexact) operations that produce a result of decimal
 | |
|      floating type and all operations that produce an integer or character sequence result and have an
 | |
|      operand of decimal floating type, unless stated otherwise. The macros expand to integer constant
 | |
|      expressions whose values are distinct nonnegative values.
 | |
| </pre>
 | |
| <a name='7.6p15'></a>
 | |
| <pre>15   During translation, constant rounding direction modes for decimal floating-point arithmetic are
 | |
|      in effect where specified. Elsewhere, during translation the decimal rounding direction mode is
 | |
|      FE_DEC_TONEAREST.
 | |
| </pre>
 | |
| <a name='7.6p16'></a>
 | |
| <pre>16   At program startup the dynamic rounding direction mode for decimal floating-point arithmetic is
 | |
|      initialized to FE_DEC_TONEAREST.
 | |
| </pre>
 | |
| <a name='7.6p17'></a>
 | |
| <pre>17   The macro
 | |
| 
 | |
|                 FE_DFL_ENV
 | |
| 
 | |
| 
 | |
|      represents the default dynamic floating-point environment — the one installed at program startup
 | |
|      — and has type "pointer to const-qualified fenv_t". It can be used as an argument to <fenv.h>
 | |
|      functions that manage the dynamic floating-point environment.
 | |
| </pre>
 | |
| <a name='7.6p18'></a>
 | |
| <pre>18   Additional implementation-defined environments, with macro definitions beginning with FE_ and
 | |
|      an uppercase letter,<a href='#FOOTNOTE.263'><sup>[263]</sup></a> and having type "pointer to const-qualified fenv_t", may also be specified
 | |
|      by the implementation.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.263'>
 | |
| <pre><i><b>Footnote 263)</b> See "future library directions" (<a href='#7.33.4'>7.33.4</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.6.1 [The FENV_ACCESS pragma]</h3>
 | |
| <a name='7.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|                #include <fenv.h>
 | |
|                 #pragma STDC FENV_ACCESS on-off-switch
 | |
| 
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='7.6.1p2'></a>
 | |
| <pre>2    The FENV_ACCESS pragma provides a means to inform the implementation when a program might
 | |
|      access the floating-point environment to test floating-point status flags or run under non-default
 | |
|      floating-point control modes.<a href='#FOOTNOTE.264'><sup>[264]</sup></a> The pragma shall occur either outside external declarations or
 | |
|      preceding all explicit declarations and statements inside a compound statement. When outside
 | |
|      external declarations, the pragma takes effect from its occurrence until another FENV_ACCESS pragma
 | |
|      is encountered, or until the end of the translation unit. When inside a compound statement, the
 | |
|      pragma takes effect from its occurrence until another FENV_ACCESS pragma is encountered (including
 | |
|      within a nested compound statement), or until the end of the compound statement; at the end of a
 | |
|      compound statement the state for the pragma is restored to its condition just before the compound
 | |
|      statement. If this pragma is used in any other context, the behavior is undefined. If part of a
 | |
|      program tests floating-point status flags or establishes non-default floating-point mode settings
 | |
|      using any means other than the FENV_ROUND pragmas, but was translated with the state for the
 | |
|      FENV_ACCESS pragma "off", the behavior is undefined. The default state ("on" or "off") for the
 | |
|      pragma is implementation-defined. (When execution passes from a part of the program translated
 | |
|      with FENV_ACCESS "off" to a part translated with FENV_ACCESS "on", the state of the floating-point
 | |
|      status flags is unspecified and the floating-point control modes have their default settings.)
 | |
| </pre>
 | |
| <a name='FOOTNOTE.264'>
 | |
| <pre><i><b>Footnote 264)</b> The purpose of the FENV_ACCESS pragma is to allow certain optimizations that could subvert flag tests and mode changes
 | |
|      (e.g., global common subexpression elimination, code motion, and constant folding). In general, if the state of FENV_ACCESS
 | |
|      is "off", the translator can assume that the flags are not tested, and that default modes are in effect, except where specified
 | |
|      otherwise by an FENV_ROUND pragma.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.1p3'></a>
 | |
| <pre>3    EXAMPLE
 | |
| 
 | |
|                 #include <fenv.h>
 | |
|                 void f(double x)
 | |
|               {
 | |
|                        #pragma STDC FENV_ACCESS ON
 | |
|                        void g(double);
 | |
|                        void h(double);
 | |
|                        /* ... */
 | |
|                        g(x + 1);
 | |
|                        h(x + 1);
 | |
|                        /* ... */
 | |
|               }
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.1p4'></a>
 | |
| <pre>4   If the function g might depend on status flags set as a side effect of the first x + 1, or if the second x + 1 might depend on
 | |
|     control modes set as a side effect of the call to function g, then the program has to contain an appropriately placed invocation
 | |
|     of #pragma STDC FENV_ACCESS ON as shown.<a href='#FOOTNOTE.265'><sup>[265]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.265'>
 | |
| <pre><i><b>Footnote 265)</b> The side effects impose a temporal ordering that requires two evaluations of x + 1 . On the other hand, without the
 | |
|     #pragma STDC FENV_ACCESS ON pragma, and assuming the default state is "off", just one evaluation of x + 1 would suffice.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.6.2 [The FENV_ROUND pragma]</h3>
 | |
| <a name='7.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               #pragma STDC FENV_ROUND direction
 | |
|               #pragma STDC FENV_ROUND FE_DYNAMIC
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.2p2'></a>
 | |
| <pre>2   The FENV_ROUND pragma provides a means to specify a constant rounding direction for floating-
 | |
|     point operations for standard floating types within a translation unit or compound statement. The
 | |
|     pragma shall occur either outside external declarations or preceding all explicit declarations and
 | |
|     statements inside a compound statement. When outside external declarations, the pragma takes
 | |
|     effect from its occurrence until another FENV_ROUND pragma is encountered, or until the end of the
 | |
|     translation unit. When inside a compound statement, the pragma takes effect from its occurrence
 | |
|     until another FENV_ROUND pragma is encountered (including within a nested compound statement),
 | |
|     or until the end of the compound statement; at the end of a compound statement the static rounding
 | |
|     mode is restored to its condition just before the compound statement. If this pragma is used in any
 | |
|     other context, its behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.6.2p3'></a>
 | |
| <pre>3   direction shall be one of the names of the supported rounding direction macros for operations for
 | |
|     standard floating types (<a href='#7.6'>7.6</a>), or FE_DYNAMIC. If any other value is specified, the behavior is unde-
 | |
|     fined. If no FENV_ROUND pragma is in effect, or the specified constant rounding mode is FE_DYNAMIC,
 | |
|     rounding is according to the mode specified by the dynamic floating-point environment, which is the
 | |
|     dynamic rounding mode that was established either at thread creation or by a call to fesetround,
 | |
|     fesetmode, fesetenv, or feupdateenv. If the FE_DYNAMIC mode is specified and FENV_ACCESS is
 | |
|     "off", the translator may assume that the default rounding mode is in effect.
 | |
| </pre>
 | |
| <a name='7.6.2p4'></a>
 | |
| <pre>4   The FENV_ROUND pragma affects operations for standard floating types. Within the scope of an
 | |
|     FENV_ROUND pragma establishing a mode other than FE_DYNAMIC, floating-point operators, implicit
 | |
|     conversions (including the conversion of a value represented in a format wider than its semantic
 | |
|     types to its semantic type, as done by classification macros), and invocations of functions indicated
 | |
|     in the table below, for which macro replacement has not been suppressed (<a href='#7.1.4'>7.1.4</a>), shall be evaluated
 | |
|     according to the specified constant rounding mode (as though no constant mode was specified
 | |
|     and the corresponding dynamic rounding mode had been established by a call to fesetround).
 | |
|     Invocations of functions for which macro replacement has been suppressed and invocations of
 | |
|     functions other than those indicated in the table below shall not be affected by constant rounding
 | |
|     modes – they are affected by (and affect) only the dynamic mode. Floating constants (<a href='#6.4.4.2'>6.4.4.2</a>) of
 | |
|     a standard floating type that occur in the scope of a constant rounding mode shall be interpreted
 | |
|     according to that mode.
 | |
|                         Functions affected by constant rounding modes – for standard
 | |
|                         floating types
 | |
| 
 | |
|             Header          Function families
 | |
|             <math.h>        acos, acospi, asin, asinpi, atan, atan2, atan2pi, atanpi
 | |
|             <math.h>        cos, cospi, sin, sinpi, tan, tanpi
 | |
|             <math.h>        acosh, asinh, atanh
 | |
|             <math.h>        cosh, sinh, tanh
 | |
|             <math.h>        exp, exp10, exp10m1, exp2, exp2m1, expm1
 | |
|             <math.h>        log, log10, log10p1, log1p, log2, log2p1, logp1
 | |
|             <math.h>        scalbn, scalbln, ldexp
 | |
|             <math.h>        cbrt, compoundn, hypot, pow, pown, powr, rootn, rsqrt, sqrt
 | |
|             <math.h>        erf, erfc
 | |
|             <math.h>        lgamma, tgamma
 | |
|             <math.h>        rint, nearbyint, lrint, llrint
 | |
|             <math.h>        fdim
 | |
|             <math.h>        fma
 | |
|             <math.h>        fadd, dadd, fsub, dsub, fmul, dmul, fdiv, ddiv, ffma, dfma, fsqrt, dsqrt
 | |
|             <stdlib.h>      atof, strfrom, strto
 | |
|             <wchar.h>       wcsto
 | |
|             <stdio.h>       printf and scanf families
 | |
|             <wchar.h>       wprintf and wscanf families
 | |
| 
 | |
| 
 | |
|     A function family listed in the table above indicates the functions for all standard floating types,
 | |
|     where the function family is represented by the name of the functions without a suffix. For example,
 | |
|     acos indicates the functions acos, acosf, and acosl.
 | |
| </pre>
 | |
| <a name='7.6.2p5'></a>
 | |
| <pre>5   NOTE Constant rounding modes (other than FE_DYNAMIC) could be implemented using dynamic rounding modes as
 | |
|     illustrated in the following example:
 | |
| 
 | |
|              {
 | |
|                      #pragma STDC FENV_ROUND direction
 | |
|                      // compiler inserts:
 | |
|                      // #pragma STDC FENV_ACCESS ON
 | |
|                      // int __savedrnd;
 | |
|                      // __savedrnd = __swapround(direction);
 | |
|                      ... operations affected by constant rounding mode ...
 | |
|                      // compiler inserts:
 | |
|                      // __savedrnd = __swapround(__savedrnd);
 | |
|                      ... operations not affected by constant rounding mode ...
 | |
|                      // compiler inserts:
 | |
|                      // __savedrnd = __swapround(__savedrnd);
 | |
|                      ... operations affected by constant rounding mode ...
 | |
|                      // compiler inserts:
 | |
|                      // __swapround(__savedrnd);
 | |
|              }
 | |
| 
 | |
|     where __swapround is defined by:
 | |
| 
 | |
|              static inline int __swapround(const int new) {
 | |
|                    const int old = fegetround();
 | |
|                    fesetround(new);
 | |
|                    return old;
 | |
|              }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.6.3 [The FENV_DEC_ROUND pragma]</h3>
 | |
| <a name='7.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <fenv.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               #pragma STDC FENV_DEC_ROUND dec-direction
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.3p2'></a>
 | |
| <pre>2   The FENV_DEC_ROUND pragma is a decimal floating-point analog of the FENV_ROUND pragma. If
 | |
|     FLT_RADIX is not 10, the FENV_DEC_ROUND pragma affects operators, functions, and floating con-
 | |
|     stants only for decimal floating types. The affected functions are listed in the table below. If
 | |
|     FLT_RADIX is 10, whether the FENV_ROUND and FENV_DEC_ROUND pragmas alter the rounding direc-
 | |
|     tion of both standard and decimal floating-point operations is implementation-defined. dec-direction
 | |
|     shall be one of the decimal rounding direction macro names (FE_DEC_DOWNWARD, FE_DEC_TONEAREST,
 | |
|     FE_DEC_TONEARESTFROMZERO, FE_DEC_TOWARDZERO, and FE_DEC_UPWARD) defined in <a href='#7.6'>7.6</a>, to specify
 | |
|     a constant rounding mode, or FE_DEC_DYNAMIC, to specify dynamic rounding. The corresponding
 | |
|     dynamic rounding mode can be established by a call to fe_dec_setround.
 | |
| 
 | |
|                          Functions affected by constant rounding modes – for decimal float-
 | |
|                          ing types
 | |
| 
 | |
|             Header           Function families
 | |
|             <math.h>         acos, acospi, asin, asinpi, atan, atan2, atan2pi, atanpi
 | |
|             <math.h>         cos, cospi, sin, sinpi, tan, tanpi
 | |
|             <math.h>         acosh, asinh, atanh
 | |
|             <math.h>         cosh, sinh, tanh
 | |
|             <math.h>         exp, exp10, exp10m1, exp2, exp2m1, expm1
 | |
|             <math.h>         log, log10, log10p1, log1p, log2, log2p1, logp1
 | |
|             <math.h>         scalbn, scalbln, ldexp
 | |
|             <math.h>         cbrt, compoundn, hypot, pow, pown, powr, rootn, rsqrt, sqrt
 | |
|             <math.h>         erf, erfc
 | |
|             <math.h>         lgamma, tgamma
 | |
|             <math.h>         rint, nearbyint, lrint, llrint
 | |
|             <math.h>         quantize
 | |
|             <math.h>         fdim
 | |
|             <math.h>         fma
 | |
|             <math.h>         d32add, d64add, d32sub, d64sub, d32mul, d64mul, d32div, d64div,
 | |
|                              d32fma, d64fma, d32sqrt, d64sqrt
 | |
|             <stdlib.h>       strfrom, strto
 | |
|             <wchar.h>        wcsto
 | |
|             <stdio.h>        printf and scanf families
 | |
|             <wchar.h>        wprintf and wscanf families
 | |
| 
 | |
| 
 | |
|     A function family listed in the table above indicates the functions for all decimal floating types,
 | |
|     where the function family is represented by the name of the functions without a suffix. For example,
 | |
|     acos indicates the functions acosd32, acosd64, and acosd128.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.6.4 [Floating-point exceptions]</h3>
 | |
| <a name='7.6.4p1'></a>
 | |
| <pre>1   The following functions provide access to the floating-point status flags.<a href='#FOOTNOTE.266'><sup>[266]</sup></a> The int input argument
 | |
|     for the functions represents a subset of floating-point exceptions, and can be zero or the bitwise
 | |
|     OR of one or more floating-point exception macros, for example FE_OVERFLOW | FE_INEXACT. For
 | |
|     other argument values, the behavior of these functions is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.266'>
 | |
| <pre><i><b>Footnote 266)</b> The functions fetestexcept, feraiseexcept, and feclearexcept support the basic abstraction of flags that are either
 | |
|     set or clear. An implementation can endow floating-point status flags with more information — for example, the address of
 | |
|     the code which first raised the floating-point exception; the functions fegetexceptflag and fesetexceptflag deal with
 | |
|     the full content of flags.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.6.4.1 [The feclearexcept function]</h3>
 | |
| <a name='7.6.4.1p1'></a>
 | |
| <pre>1     Synopsis
 | |
|              #include <fenv.h>
 | |
|               int feclearexcept(int excepts);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.4.1p2'></a>
 | |
| <pre>2   The feclearexcept function attempts to clear the supported floating-point exceptions represented
 | |
|     by its argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.4.1p3'></a>
 | |
| <pre>3   The feclearexcept function returns zero if the excepts argument is zero or if all the specified
 | |
|     exceptions were successfully cleared. Otherwise, it returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.6.4.2 [The fegetexceptflag function]</h3>
 | |
| <a name='7.6.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int fegetexceptflag(fexcept_t *flagp, int excepts);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.4.2p2'></a>
 | |
| <pre>2   The fegetexceptflag function attempts to store an implementation-defined representation of the
 | |
|     states of the floating-point status flags indicated by the argument excepts in the object pointed to
 | |
|     by the argument flagp.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.4.2p3'></a>
 | |
| <pre>3   The fegetexceptflag function returns zero if the representation was successfully stored. Otherwise,
 | |
|     it returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.6.4.3 [The feraiseexcept function]</h3>
 | |
| <a name='7.6.4.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int feraiseexcept(int excepts);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.4.3p2'></a>
 | |
| <pre>2   The feraiseexcept function attempts to raise the supported floating-point exceptions represented
 | |
|     by its argument. <a href='#FOOTNOTE.267'><sup>[267]</sup></a> The order in which these floating-point exceptions are raised is unspecified,
 | |
|     except as stated in <a href='#F.8.6'>F.8.6</a>. Whether the feraiseexcept function additionally raises the "inexact"
 | |
|     floating-point exception whenever it raises the "overflow" or "underflow" floating-point exception
 | |
|     is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.267'>
 | |
| <pre><i><b>Footnote 267)</b> The effect is intended to be similar to that of floating-point exceptions raised by arithmetic operations. Hence, implemen-
 | |
|     tation extensions associated with raising a floating-point exception (for example, enabled traps or IEC 60559 alternate
 | |
|     exception handling) should be honored. The specification in <a href='#F.8.6'>F.8.6</a> is in the same spirit.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.4.3p3'></a>
 | |
| <pre>3   The feraiseexcept function returns zero if the excepts argument is zero or if all the specified
 | |
|     exceptions were successfully raised. Otherwise, it returns a nonzero value.
 | |
| 
 | |
|     Recommended Practice
 | |
|     Implementation extensions associated with raising a floating-point exception (for example, enabled
 | |
|     traps or IEC 60559 alternate exception handling) should be honored by this function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.6.4.4 [The fesetexcept function]</h3>
 | |
| <a name='7.6.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int fesetexcept(int excepts);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.4.4p2'></a>
 | |
| <pre>2   The fesetexcept function attempts to set the supported floating-point exception flags represented
 | |
|     by its argument. This function does not clear any floating-point exception flags. This function
 | |
|     changes the state of the floating-point exception flags, but does not cause any other side effects that
 | |
|     might be associated with raising floating-point exceptions. <a href='#FOOTNOTE.268'><sup>[268]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.268'>
 | |
| <pre><i><b>Footnote 268)</b> Implementation extensions like traps for floating-point exceptions and IEC 60559 exception handling do not occur.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.4.4p3'></a>
 | |
| <pre>3   The fesetexcept function returns zero if all the specified exceptions were successfully set or if the
 | |
|     excepts argument is zero. Otherwise, it returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.4.5'></a>
 | |
| <hr>
 | |
| <h3>7.6.4.5 [The fesetexceptflag function]</h3>
 | |
| <a name='7.6.4.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <fenv.h>
 | |
|              int fesetexceptflag(const fexcept_t *flagp, int excepts);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.4.5p2'></a>
 | |
| <pre>2   The fesetexceptflag function attempts to set the floating-point status flags indicated by the
 | |
|     argument excepts to the states stored in the object pointed to by flagp. The value of *flagp
 | |
|     shall have been set by a previous call to fegetexceptflag whose second argument represented at
 | |
|     least those floating-point exceptions represented by the argument excepts. Like fesetexcept, this
 | |
|     function does not raise floating-point exceptions, but only sets the state of the flags.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.4.5p3'></a>
 | |
| <pre>3   The fesetexceptflag function returns zero if the excepts argument is zero or if all the specified
 | |
|     flags were successfully set to the appropriate state. Otherwise, it returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.4.6'></a>
 | |
| <hr>
 | |
| <h3>7.6.4.6 [The fetestexceptflag function]</h3>
 | |
| <a name='7.6.4.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <fenv.h>
 | |
|              int fetestexceptflag(const fexcept_t * flagp, int excepts);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.4.6p2'></a>
 | |
| <pre>2   The fetestexceptflag function determines which of a specified subset of the floating-point excep-
 | |
|     tion flags are set in the object pointed to by flagp. The value of *flagp shall have been set by a
 | |
|     previous call to fegetexceptflag whose second argument represented at least those floating-point
 | |
|     exceptions represented by the argument excepts. The excepts argument specifies the floating-point
 | |
|     status flags to be queried.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.4.6p3'></a>
 | |
| <pre>3   The fetestexceptflag function returns the value of the bitwise OR of the floating-point exception
 | |
|     macros included in excepts corresponding to the floating-point exceptions set in *flagp .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.4.7'></a>
 | |
| <hr>
 | |
| <h3>7.6.4.7 [The fetestexcept function]</h3>
 | |
| <a name='7.6.4.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <fenv.h>
 | |
|              int fetestexcept(int excepts);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.4.7p2'></a>
 | |
| <pre>2   The fetestexcept function determines which of a specified subset of the floating-point excep-
 | |
|     tion flags are currently set. The excepts argument specifies the floating-point status flags to be
 | |
|     queried.<a href='#FOOTNOTE.269'><sup>[269]</sup></a>
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.269'>
 | |
| <pre><i><b>Footnote 269)</b> This mechanism allows testing several floating-point exceptions with just one function call.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.4.7p3'></a>
 | |
| <pre>3   The fetestexcept function returns the value of the bitwise OR of the floating-point exception
 | |
|     macros corresponding to the currently set floating-point exceptions included in excepts.
 | |
| </pre>
 | |
| <a name='7.6.4.7p4'></a>
 | |
| <pre>4   EXAMPLE Call f if "invalid" is set, then g if "overflow" is set:
 | |
| 
 | |
|               #include <fenv.h>
 | |
|               /* ... */
 | |
|               {
 | |
|                     #pragma STDC FENV_ACCESS ON
 | |
|                     int set_excepts;
 | |
|                     feclearexcept(FE_INVALID | FE_OVERFLOW);
 | |
|                     // maybe raise exceptions
 | |
|                     set_excepts = fetestexcept(FE_INVALID | FE_OVERFLOW);
 | |
|                     if (set_excepts & FE_INVALID) f();
 | |
|                     if (set_excepts & FE_OVERFLOW) g();
 | |
|                     /* ... */
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.5'></a>
 | |
| <hr>
 | |
| <h3>7.6.5 [Rounding and other control modes]</h3>
 | |
| <a name='7.6.5p1'></a>
 | |
| <pre>1   The fegetround and fesetround functions provide control of rounding direction modes. The
 | |
|     fegetmode and fesetmode functions manage all the implementation’s dynamic floating-point
 | |
|     control modes collectively.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.6.5.1 [The fegetmode function]</h3>
 | |
| <a name='7.6.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int fegetmode(femode_t *modep);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.5.1p2'></a>
 | |
| <pre>2   The fegetmode function attempts to store all the dynamic floating-point control modes in the object
 | |
|     pointed to by modep.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.5.1p3'></a>
 | |
| <pre>3   The fegetmode function returns zero if the modes were successfully stored. Otherwise, it returns a
 | |
|     nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.5.2'></a>
 | |
| <hr>
 | |
| <h3>7.6.5.2 [The fegetround function]</h3>
 | |
| <a name='7.6.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int fegetround(void);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.5.2p2'></a>
 | |
| <pre>2   The fegetround function gets the current value of the dynamic rounding direction mode.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.5.2p3'></a>
 | |
| <pre>3   The fegetround function returns the value of the rounding direction macro representing the current
 | |
|     dynamic rounding direction or a negative value if there is no such rounding direction macro or the
 | |
|     current dynamic rounding direction is not determinable.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.5.3'></a>
 | |
| <hr>
 | |
| <h3>7.6.5.3 [The fe_dec_getround function]</h3>
 | |
| <a name='7.6.5.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               int fe_dec_getround(void);
 | |
|               #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.5.3p2'></a>
 | |
| <pre>2   The fe_dec_getround function gets the current value of the dynamic rounding direction mode for
 | |
|     decimal floating-point operations.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.5.3p3'></a>
 | |
| <pre>3   The fe_dec_getround function returns the value of the rounding direction macro representing the
 | |
|     current dynamic rounding direction for decimal floating-point operations, or a negative value if
 | |
|     there is no such rounding macro or the current rounding direction is not determinable.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.5.4'></a>
 | |
| <hr>
 | |
| <h3>7.6.5.4 [The fesetmode function]</h3>
 | |
| <a name='7.6.5.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int fesetmode(const femode_t *modep);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.5.4p2'></a>
 | |
| <pre>2   The fesetmode function attempts to establish the dynamic floating-point modes represented by the
 | |
|     object pointed to by modep. The argument modep shall point to an object set by a call to fegetmode,
 | |
|     or equal FE_DFL_MODE or a dynamic floating-point mode state macro defined by the implementation.
 | |
| 
 | |
|     Returns
 | |
|     The fesetmode fesetmode function returns zero if the modes were successfully established. Other-
 | |
|     wise, it returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.5.5'></a>
 | |
| <hr>
 | |
| <h3>7.6.5.5 [The fesetround function]</h3>
 | |
| <a name='7.6.5.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int fesetround(int rnd);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.5.5p2'></a>
 | |
| <pre>2   The fesetround function establishes the rounding direction represented by its argument rnd. If
 | |
|     the argument is not equal to the value of a rounding direction macro, the rounding direction is not
 | |
|     changed.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.5.5p3'></a>
 | |
| <pre>3   The fesetround function returns zero if and only if the dynamic rounding direction mode was set
 | |
|     to the requested rounding direction.
 | |
| </pre>
 | |
| <a name='7.6.5.5p4'></a>
 | |
| <pre>4   EXAMPLE Save, set, and restore the rounding direction. Report an error and abort if setting the rounding direction fails.
 | |
| 
 | |
|               #include <fenv.h>
 | |
|               #include <assert.h>
 | |
| 
 | |
|               void f(int rnd_dir)
 | |
|               {
 | |
|                     #pragma STDC FENV_ACCESS ON
 | |
|                     int save_round;
 | |
|                     int setround_ok;
 | |
|                     save_round = fegetround();
 | |
|                     setround_ok = fesetround(rnd_dir);
 | |
|                     assert(setround_ok == 0);
 | |
|                     /* ... */
 | |
|                     fesetround(save_round);
 | |
|                     /* ... */
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.5.6'></a>
 | |
| <hr>
 | |
| <h3>7.6.5.6 [The fe_dec_setround function]</h3>
 | |
| <a name='7.6.5.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               int fe_dec_setround(int rnd);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.5.6p2'></a>
 | |
| <pre>2   The fe_dec_setround function sets the dynamic rounding direction mode for decimal floating-
 | |
|     point operations to be the rounding direction represented by its argument rnd. If the argument is
 | |
|     not equal to the value of a decimal rounding direction macro, the rounding direction is not changed.
 | |
| </pre>
 | |
| <a name='7.6.5.6p3'></a>
 | |
| <pre>3   If FLT_RADIX is not 10, the rounding direction altered by the fesetround function is independent
 | |
|     of the rounding direction altered by the fe_dec_setround function; otherwise if FLT_RADIX is
 | |
|     10, whether the fesetround and fe_dec_setround functions alter the rounding direction of both
 | |
|     standard and decimal floating-point operations is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.5.6p4'></a>
 | |
| <pre>4   The fe_dec_setround function returns a zero value if and only if the argument is equal to a decimal
 | |
|     rounding direction macro (that is, if and only if the dynamic rounding direction mode for decimal
 | |
|     floating-point operations was set to the requested rounding direction).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.6'></a>
 | |
| <hr>
 | |
| <h3>7.6.6 [Environment]</h3>
 | |
| <a name='7.6.6p1'></a>
 | |
| <pre>1   The functions in this section manage the floating-point environment — status flags and control
 | |
|     modes — as one entity.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.6.6.1 [The fegetenv function]</h3>
 | |
| <a name='7.6.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int fegetenv(fenv_t *envp);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.6.1p2'></a>
 | |
| <pre>2   The fegetenv function attempts to store the current dynamic floating-point environment in the
 | |
|     object pointed to by envp.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.6.1p3'></a>
 | |
| <pre>3   The fegetenv function returns zero if the environment was successfully stored. Otherwise, it returns
 | |
|     a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.6.6.2 [The feholdexcept function]</h3>
 | |
| <a name='7.6.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <fenv.h>
 | |
|               int feholdexcept(fenv_t *envp);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.6.2p2'></a>
 | |
| <pre>2   The feholdexcept function saves the current dynamic floating-point environment in the object
 | |
|     pointed to by envp, clears the floating-point status flags, and then installs a non-stop (continue on
 | |
|     floating-point exceptions) mode, if available, for all floating-point exceptions.<a href='#FOOTNOTE.270'><sup>[270]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.270'>
 | |
| <pre><i><b>Footnote 270)</b> IEC 60559 systems have a default non-stop mode, and typically at least one other mode for trap handling or aborting; if
 | |
|     the system provides only the non-stop mode then installing it is trivial. For such systems, the feholdexcept function can be
 | |
|     used in conjunction with the feupdateenv function to write routines that hide spurious floating-point exceptions from their
 | |
|     callers.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.6.6.2p3'></a>
 | |
| <pre>3   The feholdexcept function returns zero if and only if non-stop floating-point exception handling
 | |
|     was successfully installed.
 | |
| </pre>
 | |
| <a name='7.6.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.6.6.3 [The fesetenv function]</h3>
 | |
| <a name='7.6.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <fenv.h>
 | |
|              int fesetenv(const fenv_t *envp);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.6.3p2'></a>
 | |
| <pre>2   The fesetenv function attempts to establish the dynamic floating-point environment represented by
 | |
|     the object pointed to by envp. The argument envp shall point to an object set by a call to fegetenv or
 | |
|     feholdexcept, or equal a dynamic floating-point environment macro. Note that fesetenv merely
 | |
|     installs the state of the floating-point status flags represented through its argument, and does not
 | |
|     raise these floating-point exceptions.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.6.3p3'></a>
 | |
| <pre>3   The fesetenv function returns zero if the environment was successfully established. Otherwise, it
 | |
|     returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.6.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.6.6.4 [The feupdateenv function]</h3>
 | |
| <a name='7.6.6.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <fenv.h>
 | |
|              int feupdateenv(const fenv_t *envp);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.6.6.4p2'></a>
 | |
| <pre>2   The feupdateenv function attempts to save the currently raised floating-point exceptions in its
 | |
|     automatic storage, install the dynamic floating-point environment represented by the object pointed
 | |
|     to by envp, and then raise the saved floating-point exceptions. The argument envp shall point to an
 | |
|     object set by a call to feholdexcept or fegetenv, or equal a dynamic floating-point environment
 | |
|     macro.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.6.6.4p3'></a>
 | |
| <pre>3   The feupdateenv function returns zero if all the actions were successfully carried out. Otherwise, it
 | |
|     returns a nonzero value.
 | |
| </pre>
 | |
| <a name='7.6.6.4p4'></a>
 | |
| <pre>4   EXAMPLE Hide spurious underflow floating-point exceptions:
 | |
| 
 | |
|              #include <fenv.h>
 | |
|              double f(double x)
 | |
|              {
 | |
|                    #pragma STDC FENV_ACCESS ON
 | |
|                    double result;
 | |
|                    fenv_t save_env;
 | |
|                    if (feholdexcept(&save_env))
 | |
|                          return /* indication of an environmental problem */;
 | |
|                    // compute result
 | |
|                    if (/* test spurious underflow */)
 | |
|                          if (feclearexcept(FE_UNDERFLOW))
 | |
|                                return /* indication of an environmental problem */;
 | |
|                    if (feupdateenv(&save_env))
 | |
|                          return /* indication of an environmental problem */;
 | |
|                    return result;
 | |
|              }
 | |
| </pre>
 | |
| <a name='7.7'></a>
 | |
| <hr>
 | |
| <h3>7.7 [Characteristics of floating types <float.h>]</h3>
 | |
| <a name='7.7p1'></a>
 | |
| <pre>1   The header <float.h> defines several macros that expand to various limits and parameters of the
 | |
|     real floating types.
 | |
| </pre>
 | |
| <a name='7.7p2'></a>
 | |
| <pre>2   The macros, their meanings, and the constraints (or restrictions) on their values are listed in <a href='#5.2.4.2.2'>5.2.4.2.2</a>
 | |
|     and <a href='#5.2.4.2.3'>5.2.4.2.3</a>. A summary is given in Annex E.
 | |
| </pre>
 | |
| <a name='7.8'></a>
 | |
| <hr>
 | |
| <h3>7.8 [Format conversion of integer types <inttypes.h>]</h3>
 | |
| <a name='7.8p1'></a>
 | |
| <pre>1   The header <inttypes.h> includes the header <stdint.h> and extends it with additional facilities
 | |
|     provided by hosted implementations.
 | |
| </pre>
 | |
| <a name='7.8p2'></a>
 | |
| <pre>2   It declares functions for manipulating greatest-width integers and converting numeric character
 | |
|     strings to greatest-width integers, and it declares the type
 | |
| 
 | |
|               imaxdiv_t
 | |
| 
 | |
| 
 | |
|     which is a structure type that is the type of the value returned by the imaxdiv function. For each
 | |
|     type declared in <stdint.h>, it defines corresponding macros for conversion specifiers for use with
 | |
|     the formatted input/output functions.<a href='#FOOTNOTE.271'><sup>[271]</sup></a>
 | |
|     Forward references: integer types <stdint.h> (<a href='#7.22'>7.22</a>), formatted input/output functions (<a href='#7.23.6'>7.23.6</a>),
 | |
|     formatted wide character input/output functions (<a href='#7.31.2'>7.31.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.271'>
 | |
| <pre><i><b>Footnote 271)</b> See "future library directions" (<a href='#7.33.6'>7.33.6</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.8.1'></a>
 | |
| <hr>
 | |
| <h3>7.8.1 [Macros for format specifiers]</h3>
 | |
| <a name='7.8.1p1'></a>
 | |
| <pre>1   Each of the following object-like macros expands to a character string literal containing a conversion
 | |
|     specifier, possibly modified by a length modifier, suitable for use within the format argument of a
 | |
|     formatted input/output function when converting the corresponding integer type. These macro
 | |
|     names have the general form of PRI (character string literals for the fprintf and fwprintf family)
 | |
|     or SCN (character string literals for the fscanf and fwscanf family),<a href='#FOOTNOTE.272'><sup>[272]</sup></a> followed by the conversion
 | |
|     specifier, followed by a name corresponding to a similar type name in <a href='#7.22.1'>7.22.1</a>. In these names, N
 | |
|     represents the width of the type as described in <a href='#7.22.1'>7.22.1</a>. For example, PRIdFAST32 can be used in a
 | |
|     format string to print the value of an integer of type int_fast32_t.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.272'>
 | |
| <pre><i><b>Footnote 272)</b> Separate macros are given for use with fprintf and fscanf functions because, in the general case, different format
 | |
|     specifiers might be required for fprintf and fscanf, even when the type is the same.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.8.1p2'></a>
 | |
| <pre>2   The fprintf macros for signed integers are:
 | |
|             PRIdN       PRIdLEASTN           PRIdFASTN     PRIdMAX       PRIdPTR
 | |
|             PRIiN       PRIiLEASTN           PRIiFASTN     PRIiMAX       PRIiPTR
 | |
| </pre>
 | |
| <a name='7.8.1p3'></a>
 | |
| <pre>3   The fprintf macros for unsigned integers are:
 | |
|             PRIoN       PRIoLEASTN           PRIoFASTN     PRIoMAX       PRIoPTR
 | |
|             PRIuN       PRIuLEASTN           PRIuFASTN     PRIuMAX       PRIuPTR
 | |
|             PRIxN       PRIxLEASTN           PRIxFASTN     PRIxMAX       PRIxPTR
 | |
|             PRIXN       PRIXLEASTN           PRIXFASTN     PRIXMAX       PRIXPTR
 | |
| </pre>
 | |
| <a name='7.8.1p4'></a>
 | |
| <pre>4   The fscanf macros for signed integers are:
 | |
|             SCNdN       SCNdLEASTN           SCNdFASTN     SCNdMAX       SCNdPTR
 | |
|             SCNiN       SCNiLEASTN           SCNiFASTN     SCNiMAX       SCNiPTR
 | |
| </pre>
 | |
| <a name='7.8.1p5'></a>
 | |
| <pre>5   The fscanf macros for unsigned integers are:
 | |
|             SCNoN       SCNoLEASTN           SCNoFASTN     SCNoMAX       SCNoPTR
 | |
|             SCNuN       SCNuLEASTN           SCNuFASTN     SCNuMAX       SCNuPTR
 | |
|             SCNxN       SCNxLEASTN           SCNxFASTN     SCNxMAX       SCNxPTR
 | |
| </pre>
 | |
| <a name='7.8.1p6'></a>
 | |
| <pre>6   For each type that the implementation provides in <stdint.h>, the corresponding fprintf macros
 | |
|     shall be defined and the corresponding fscanf macros shall be defined unless the implementation
 | |
|     does not have a suitable fscanf length modifier for the type.
 | |
| </pre>
 | |
| <a name='7.8.1p7'></a>
 | |
| <pre>7   EXAMPLE
 | |
| 
 | |
|               #include <inttypes.h>
 | |
|               #include <wchar.h>
 | |
|               int main(void)
 | |
|               {
 | |
|                     uintmax_t i = UINTMAX_MAX;    // this type always exists
 | |
|                     wprintf(L"The largest integer value is %020"
 | |
|                            PRIxMAX "\n", i);
 | |
|                      return 0;
 | |
|               }
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.8.2'></a>
 | |
| <hr>
 | |
| <h3>7.8.2 [Functions for greatest-width integer types]</h3>
 | |
| <a name='7.8.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.8.2.1 [The imaxabs function]</h3>
 | |
| <a name='7.8.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|     #include <inttypes.h>
 | |
|      intmax_t imaxabs(intmax_t j);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.8.2.1p2'></a>
 | |
| <pre>2   The imaxabs function computes the absolute value of an integer j. If the result cannot be represented,
 | |
|     the behavior is undefined.<a href='#FOOTNOTE.273'><sup>[273]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.273'>
 | |
| <pre><i><b>Footnote 273)</b> The absolute value of the most negative number may not be representable.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.8.2.1p3'></a>
 | |
| <pre>3   The imaxabs function returns the absolute value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.8.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.8.2.2 [The imaxdiv function]</h3>
 | |
| <a name='7.8.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|     #include <inttypes.h>
 | |
|      imaxdiv_t imaxdiv(intmax_t numer, intmax_t denom);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.8.2.2p2'></a>
 | |
| <pre>2   The imaxdiv function computes numer / denom and numer % denom in a single operation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.8.2.2p3'></a>
 | |
| <pre>3   The imaxdiv function returns a structure of type imaxdiv_t comprising both the quotient and the
 | |
|     remainder. The structure shall contain (in either order) the members quot (the quotient) and rem
 | |
|     (the remainder), each of which has type intmax_t. If either part of the result cannot be represented,
 | |
|     the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.8.2.3'></a>
 | |
| <hr>
 | |
| <h3>7.8.2.3 [The strtoimax and strtoumax functions]</h3>
 | |
| <a name='7.8.2.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|     #include <inttypes.h>
 | |
|      intmax_t strtoimax(const char * restrict nptr, char ** restrict endptr, int base);
 | |
|      uintmax_t strtoumax(const char * restrict nptr, char ** restrict endptr, int base);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.8.2.3p2'></a>
 | |
| <pre>2   The strtoimax and strtoumax functions are equivalent to the strtol, strtoll, strtoul, and
 | |
|     strtoull functions, except that the initial portion of the string is converted to intmax_t and
 | |
|     uintmax_t representation, respectively.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.8.2.3p3'></a>
 | |
| <pre>3   The strtoimax and strtoumax functions return the converted value, if any. If no conversion could
 | |
|     be performed, zero is returned. If the correct value is outside the range of representable values,
 | |
|     INTMAX_MAX, INTMAX_MIN, or UINTMAX_MAX is returned (according to the return type and sign of the
 | |
|     value, if any), and the value of the macro ERANGE is stored in errno.
 | |
|     Forward references: the strtol, strtoll, strtoul, and strtoull functions (<a href='#7.24.1.7'>7.24.1.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.8.2.4'></a>
 | |
| <hr>
 | |
| <h3>7.8.2.4 [The wcstoimax and wcstoumax functions]</h3>
 | |
| <a name='7.8.2.4p1'></a>
 | |
| <pre>1     Synopsis
 | |
|     #include <stddef.h>            // for wchar_t
 | |
|      #include <inttypes.h>
 | |
|      intmax_t wcstoimax(const wchar_t *restrict nptr, wchar_t **restrict endptr, int base);
 | |
|      uintmax_t wcstoumax(const wchar_t *restrict nptr, wchar_t **restrict endptr, int base);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.8.2.4p2'></a>
 | |
| <pre>2   The wcstoimax and wcstoumax functions are equivalent to the wcstol, wcstoll, wcstoul, and
 | |
|     wcstoull functions except that the initial portion of the wide string is converted to intmax_t and
 | |
|     uintmax_t representation, respectively.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.8.2.4p3'></a>
 | |
| <pre>3   The wcstoimax function returns the converted value, if any. If no conversion could be performed,
 | |
|     zero is returned. If the correct value is outside the range of representable values, INTMAX_MAX,
 | |
|     INTMAX_MIN, or UINTMAX_MAX is returned (according to the return type and sign of the value, if any),
 | |
|     and the value of the macro ERANGE is stored in errno.
 | |
|     Forward references: the wcstol, wcstoll, wcstoul, and wcstoull functions (<a href='#7.31.4.1.4'>7.31.4.1.4</a>).
 | |
| </pre>
 | |
| <a name='7.9'></a>
 | |
| <hr>
 | |
| <h3>7.9 [Alternative spellings <iso646.h>]</h3>
 | |
| <a name='7.9p1'></a>
 | |
| <pre>1   The header <iso646.h> defines the following eleven macros (on the left) that expand to the corre-
 | |
|     sponding tokens (on the right):
 | |
| 
 | |
|             and      &&
 | |
|             and_eq   &=
 | |
|             bitand   &
 | |
|             bitor    |
 | |
|             compl    ~
 | |
|             not      !
 | |
|             not_eq   !=
 | |
|             or       ||
 | |
|             or_eq    |=
 | |
|             xor      ^
 | |
|             xor_eq   ^=
 | |
| </pre>
 | |
| <a name='7.10'></a>
 | |
| <hr>
 | |
| <h3>7.10 [Characteristics of integer types <limits.h>]</h3>
 | |
| <a name='7.10p1'></a>
 | |
| <pre>1   The header <limits.h> defines several macros that expand to various limits and parameters of the
 | |
|     standard integer types.
 | |
| </pre>
 | |
| <a name='7.10p2'></a>
 | |
| <pre>2   The macros, their meanings, and the constraints (or restrictions) on their values are listed in <a href='#5.2.4.2.1'>5.2.4.2.1</a>.
 | |
|     A summary is given in Annex E.
 | |
| </pre>
 | |
| <a name='7.11'></a>
 | |
| <hr>
 | |
| <h3>7.11 [Localization <locale.h>]</h3>
 | |
| <a name='7.11p1'></a>
 | |
| <pre>1   The header <locale.h> declares two functions, one type, and defines several macros.
 | |
| </pre>
 | |
| <a name='7.11p2'></a>
 | |
| <pre>2   The type is
 | |
| 
 | |
|               struct lconv
 | |
| 
 | |
| 
 | |
|     which contains members related to the formatting of numeric values. The structure shall contain
 | |
|     at least the following members, in any order. The semantics of the members and their normal
 | |
|     ranges are explained in <a href='#7.11.2.1'>7.11.2.1</a>. In the "C" locale, the members shall have the values specified in the
 | |
|     comments.
 | |
| 
 | |
|               char *decimal_point;                   // "."
 | |
|               char *thousands_sep;                   // ""
 | |
|               char *grouping;                        // ""
 | |
|               char *mon_decimal_point;               // ""
 | |
|               char *mon_thousands_sep;               // ""
 | |
|               char *mon_grouping;                    // ""
 | |
|               char *positive_sign;                   // ""
 | |
|               char *negative_sign;                   // ""
 | |
|               char *currency_symbol;                 // ""
 | |
|               char frac_digits;                      // CHAR_MAX
 | |
|               char p_cs_precedes;                    // CHAR_MAX
 | |
|               char n_cs_precedes;                    // CHAR_MAX
 | |
|               char p_sep_by_space;                   // CHAR_MAX
 | |
|               char n_sep_by_space;                   // CHAR_MAX
 | |
|               char p_sign_posn;                      // CHAR_MAX
 | |
|               char n_sign_posn;                      // CHAR_MAX
 | |
|               char *int_curr_symbol;                 // ""
 | |
|               char int_frac_digits;                  // CHAR_MAX
 | |
|               char int_p_cs_precedes;                // CHAR_MAX
 | |
|               char int_n_cs_precedes;                // CHAR_MAX
 | |
|               char int_p_sep_by_space;               // CHAR_MAX
 | |
|               char int_n_sep_by_space;               // CHAR_MAX
 | |
|               char int_p_sign_posn;                  // CHAR_MAX
 | |
|               char int_n_sign_posn;                  // CHAR_MAX
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.11p3'></a>
 | |
| <pre>3   The macros defined are NULL (described in <a href='#7.21'>7.21</a>); and
 | |
| 
 | |
|               LC_ALL
 | |
|               LC_COLLATE
 | |
|               LC_CTYPE
 | |
|               LC_MONETARY
 | |
|               LC_NUMERIC
 | |
|               LC_TIME
 | |
| 
 | |
| 
 | |
|     which expand to integer constant expressions with distinct values, suitable for use as the first argu-
 | |
|     ment to the setlocale function.<a href='#FOOTNOTE.274'><sup>[274]</sup></a> Additional macro definitions, beginning with the characters
 | |
|     LC_ and an uppercase letter,<a href='#FOOTNOTE.275'><sup>[275]</sup></a> may also be specified by the implementation.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.274'>
 | |
| <pre><i><b>Footnote 274)</b> ISO/IEC 9945–2 specifies locale and charmap formats that can be used to specify locales for C.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.275'>
 | |
| <pre><i><b>Footnote 275)</b> See "future library directions" (<a href='#7.33.7'>7.33.7</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.11.1'></a>
 | |
| <hr>
 | |
| <h3>7.11.1 [Locale control]</h3>
 | |
| <a name='7.11.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.11.1.1 [The setlocale function]</h3>
 | |
| <a name='7.11.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <locale.h>
 | |
|               char *setlocale(int category, const char *locale);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.11.1.1p2'></a>
 | |
| <pre>2   The setlocale function selects the appropriate portion of the program’s locale as specified by
 | |
|     the category and locale arguments. The setlocale function may be used to change or query
 | |
|     the program’s entire current locale or portions thereof. The value LC_ALL for category names
 | |
|     the program’s entire locale; the other values for category name only a portion of the program’s
 | |
|     locale. LC_COLLATE affects the behavior of the strcoll and strxfrm functions. LC_CTYPE affects
 | |
|     the behavior of the character handling functions<a href='#FOOTNOTE.276'><sup>[276]</sup></a> and the multibyte and wide character functions.
 | |
|     LC_MONETARY affects the monetary formatting information returned by the localeconv function.
 | |
|     LC_NUMERIC affects the decimal-point character for the formatted input/output functions and the
 | |
|     string conversion functions, as well as the nonmonetary formatting information returned by the
 | |
|     localeconv function. LC_TIME affects the behavior of the strftime and wcsftime functions.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.276'>
 | |
| <pre><i><b>Footnote 276)</b> The only functions in <a href='#7.4'>7.4</a> whose behavior is not affected by the current locale are isdigit and isxdigit.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.11.1.1p3'></a>
 | |
| <pre>3   A value of "C" for locale specifies the minimal environment for C translation; a value of "" for
 | |
|     locale specifies the locale-specific native environment. Other implementation-defined strings may
 | |
|     be passed as the second argument to setlocale.
 | |
| </pre>
 | |
| <a name='7.11.1.1p4'></a>
 | |
| <pre>4   At program startup, the equivalent of
 | |
| 
 | |
|              setlocale(LC_ALL, "C");
 | |
| 
 | |
| 
 | |
|     is executed.
 | |
| </pre>
 | |
| <a name='7.11.1.1p5'></a>
 | |
| <pre>5   A call to the setlocale function may introduce a data race with other calls to the setlocale
 | |
|     function or with calls to functions that are affected by the current locale. The implementation shall
 | |
|     behave as if no library function calls the setlocale function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.11.1.1p6'></a>
 | |
| <pre>6   If a pointer to a string is given for locale and the selection can be honored, the setlocale function
 | |
|     returns a pointer to the string associated with the specified category for the new locale. If the
 | |
|     selection cannot be honored, the setlocale function returns a null pointer and the program’s locale
 | |
|     is not changed.
 | |
| </pre>
 | |
| <a name='7.11.1.1p7'></a>
 | |
| <pre>7   A null pointer for locale causes the setlocale function to return a pointer to the string associated
 | |
|     with the category for the program’s current locale; the program’s locale is not changed.<a href='#FOOTNOTE.277'><sup>[277]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.277'>
 | |
| <pre><i><b>Footnote 277)</b> The implementation is thus required to arrange to encode in a string the various categories due to a heterogeneous locale
 | |
|     when category has the value LC_ALL.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.11.1.1p8'></a>
 | |
| <pre>8   The pointer to string returned by the setlocale function is such that a subsequent call with that
 | |
|     string value and its associated category will restore that part of the program’s locale. The string
 | |
|     pointed to shall not be modified by the program. The behavior is undefined if the returned value
 | |
|     is used after a subsequent call to the setlocale function, or after the thread which called the
 | |
|     setlocale function to obtain the returned value has exited.
 | |
|     Forward references: formatted input/output functions (<a href='#7.23.6'>7.23.6</a>), multibyte/wide character conver-
 | |
|     sion functions (<a href='#7.24.7'>7.24.7</a>), multibyte/wide string conversion functions (<a href='#7.24.8'>7.24.8</a>), numeric conversion
 | |
|     functions (<a href='#7.24.1'>7.24.1</a>), the strcoll function (<a href='#7.26.4.3'>7.26.4.3</a>), the strftime function (<a href='#7.29.3.5'>7.29.3.5</a>), the strxfrm
 | |
|     function (<a href='#7.26.4.5'>7.26.4.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.11.2'></a>
 | |
| <hr>
 | |
| <h3>7.11.2 [Numeric formatting convention inquiry]</h3>
 | |
| <a name='7.11.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.11.2.1 [The localeconv function]</h3>
 | |
| <a name='7.11.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <locale.h>
 | |
|              struct lconv *localeconv(void);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.11.2.1p2'></a>
 | |
| <pre>2   The localeconv function sets the components of an object with type struct lconv with values
 | |
|     appropriate for the formatting of numeric quantities (monetary and otherwise) according to the
 | |
|     rules of the current locale.
 | |
| </pre>
 | |
| <a name='7.11.2.1p3'></a>
 | |
| <pre>3   The members of the structure with type char * are pointers to strings, any of which (except
 | |
|     decimal_point) can point to "", to indicate that the value is not available in the current locale or is
 | |
|     of zero length. Apart from grouping and mon_grouping, the strings shall start and end in the initial
 | |
|     shift state. The members with type char are nonnegative numbers, any of which can be CHAR_MAX
 | |
|     to indicate that the value is not available in the current locale. The members include the following:
 | |
| 
 | |
|     char *decimal_point
 | |
|                  The decimal-point character used to format nonmonetary quantities.
 | |
|     char *thousands_sep
 | |
|                  The character used to separate groups of digits before the decimal-point character in
 | |
|                  formatted nonmonetary quantities.
 | |
|     char *grouping
 | |
|                  A string whose elements indicate the size of each group of digits in formatted nonmon-
 | |
|                  etary quantities.
 | |
|     char *mon_decimal_point
 | |
|                  The decimal-point used to format monetary quantities.
 | |
|     char *mon_thousands_sep
 | |
|                  The separator for groups of digits before the decimal-point in formatted monetary
 | |
|                  quantities.
 | |
|     char *mon_grouping
 | |
|                  A string whose elements indicate the size of each group of digits in formatted monetary
 | |
|                  quantities.
 | |
|     char *positive_sign
 | |
|                  The string used to indicate a nonnegative-valued formatted monetary quantity.
 | |
|     char *negative_sign
 | |
|                  The string used to indicate a negative-valued formatted monetary quantity.
 | |
|     char *currency_symbol
 | |
|                  The local currency symbol applicable to the current locale.
 | |
|     char frac_digits
 | |
|                  The number of fractional digits (those after the decimal-point) to be displayed in a
 | |
|                  locally formatted monetary quantity.
 | |
|     char p_cs_precedes
 | |
|                  Set to 1 or 0 if the currency_symbol respectively precedes or succeeds the value for a
 | |
|                  nonnegative locally formatted monetary quantity.
 | |
|     char n_cs_precedes
 | |
|                  Set to 1 or 0 if the currency_symbol respectively precedes or succeeds the value for a
 | |
|                  negative locally formatted monetary quantity.
 | |
|     char p_sep_by_space
 | |
|                  Set to a value indicating the separation of the currency_symbol, the sign string, and
 | |
|                  the value for a nonnegative locally formatted monetary quantity.
 | |
|     char n_sep_by_space
 | |
|                  Set to a value indicating the separation of the currency_symbol, the sign string, and
 | |
|                  the value for a negative locally formatted monetary quantity.
 | |
|     char p_sign_posn
 | |
|                  Set to a value indicating the positioning of the positive_sign for a nonnegative locally
 | |
|                  formatted monetary quantity.
 | |
|     char n_sign_posn
 | |
|                  Set to a value indicating the positioning of the negative_sign for a negative locally
 | |
|                  formatted monetary quantity.
 | |
| 
 | |
|     char *int_curr_symbol
 | |
|                  The international currency symbol applicable to the current locale. The first three
 | |
|                  characters contain the alphabetic international currency symbol in accordance with
 | |
|                  those specified in ISO 4217. The fourth character (immediately preceding the null
 | |
|                  character) is the character used to separate the international currency symbol from the
 | |
|                  monetary quantity.
 | |
| 
 | |
|     char int_frac_digits
 | |
|                  The number of fractional digits (those after the decimal-point) to be displayed in an
 | |
|                  internationally formatted monetary quantity.
 | |
| 
 | |
|     char int_p_cs_precedes
 | |
|                  Set to 1 or 0 if the int_curr_symbol respectively precedes or succeeds the value for a
 | |
|                  nonnegative internationally formatted monetary quantity.
 | |
| 
 | |
|     char int_n_cs_precedes
 | |
|                  Set to 1 or 0 if the int_curr_symbol respectively precedes or succeeds the value for a
 | |
|                  negative internationally formatted monetary quantity.
 | |
| 
 | |
|     char int_p_sep_by_space
 | |
|                  Set to a value indicating the separation of the int_curr_symbol, the sign string, and
 | |
|                  the value for a nonnegative internationally formatted monetary quantity.
 | |
| 
 | |
|     char int_n_sep_by_space
 | |
|                  Set to a value indicating the separation of the int_curr_symbol, the sign string, and
 | |
|                  the value for a negative internationally formatted monetary quantity.
 | |
| 
 | |
|     char int_p_sign_posn
 | |
|                  Set to a value indicating the positioning of the positive_sign for a nonnegative
 | |
|                  internationally formatted monetary quantity.
 | |
| 
 | |
|     char int_n_sign_posn
 | |
|                  Set to a value indicating the positioning of the negative_sign for a negative interna-
 | |
|                  tionally formatted monetary quantity.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.11.2.1p4'></a>
 | |
| <pre>4   The elements of grouping and mon_grouping are interpreted according to the following:
 | |
| 
 | |
|     CHAR_MAX    No further grouping is to be performed.
 | |
| 
 | |
|     0           The previous element is to be repeatedly used for the remainder of the digits.
 | |
| 
 | |
|     other       The integer value is the number of digits that compose the current group. The next
 | |
|                 element is examined to determine the size of the next group of digits before the current
 | |
|                 group.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.11.2.1p5'></a>
 | |
| <pre>5   The   values of p_sep_by_space,         n_sep_by_space,       int_p_sep_by_space,            and
 | |
|     int_n_sep_by_space are interpreted according to the following:
 | |
| 
 | |
|     0   No space separates the currency symbol and value.
 | |
| 
 | |
|     1   If the currency symbol and sign string are adjacent, a space separates them from the value;
 | |
|         otherwise, a space separates the currency symbol from the value.
 | |
| 
 | |
|     2   If the currency symbol and sign string are adjacent, a space separates them; otherwise, a space
 | |
|         separates the sign string from the value.
 | |
|         For int_p_sep_by_space and int_n_sep_by_space, the fourth character of int_curr_symbol is
 | |
|         used instead of a space.
 | |
| </pre>
 | |
| <a name='7.11.2.1p6'></a>
 | |
| <pre>6       The values of p_sign_posn, n_sign_posn, int_p_sign_posn, and int_n_sign_posn are inter-
 | |
|         preted according to the following:
 | |
| 
 | |
| 
 | |
|         0   Parentheses surround the quantity and currency symbol.
 | |
| 
 | |
| 
 | |
| 
 | |
|         1   The sign string precedes the quantity and currency symbol.
 | |
| 
 | |
| 
 | |
| 
 | |
|         2   The sign string succeeds the quantity and currency symbol.
 | |
| 
 | |
| 
 | |
| 
 | |
|         3   The sign string immediately precedes the currency symbol.
 | |
| 
 | |
| 
 | |
| 
 | |
|         4   The sign string immediately succeeds the currency symbol.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.11.2.1p7'></a>
 | |
| <pre>7       The implementation shall behave as if no library function calls the localeconv function.
 | |
| 
 | |
|         Returns
 | |
| </pre>
 | |
| <a name='7.11.2.1p8'></a>
 | |
| <pre>8       The localeconv function returns a pointer to the filled-in object. The structure pointed to by the
 | |
|         return value shall not be modified by the program, but may be overwritten by a subsequent call
 | |
|         to the localeconv function. In addition, calls to the setlocale function with categories LC_ALL,
 | |
|         LC_MONETARY, or LC_NUMERIC may overwrite the contents of the structure.
 | |
| </pre>
 | |
| <a name='7.11.2.1p9'></a>
 | |
| <pre>9       EXAMPLE 1 The following table illustrates rules which might well be used by four countries to format monetary quantities.
 | |
|                                        Local format                       International format
 | |
|               Country       Positive           Negative            Positive          Negative
 | |
|               Country1      1.234,56 mk        -1.234,56 mk        FIM 1.234,56      FIM -1.234,56
 | |
|               Country2      L.1.234            -L.1.234            ITL 1.234         -ITL 1.234
 | |
|               Country3      ƒ 1.234,56         ƒ -1.234,56         NLG 1.234,56      NLG -1.234,56
 | |
|               Country4      SFrs.1,234.56      SFrs.1,234.56C      CHF 1,234.56      CHF 1,234.56C
 | |
| 
 | |
| </pre>
 | |
| <a name='7.11.2.1p10'></a>
 | |
| <pre>10 For these four countries, the respective values for the monetary members of the structure returned by localeconv could be:
 | |
|                                     Country1     Country2     Country3     Country4
 | |
|           mon_decimal_point         ","          ""           ","          "."
 | |
|           mon_thousands_sep         "."          "."          "."          ","
 | |
|           mon_grouping              "\3"         "\3"         "\3"         "\3"
 | |
|           positive_sign             ""           ""           ""           ""
 | |
|           negative_sign             "-"          "-"          "-"          "C"
 | |
|           currency_symbol           "mk"         "L."         "\u0192"     "SFrs."
 | |
|           frac_digits               2            0            2            2
 | |
|           p_cs_precedes             0            1            1            1
 | |
|           n_cs_precedes             0            1            1            1
 | |
|           p_sep_by_space            1            0            1            0
 | |
|           n_sep_by_space            1            0            2            0
 | |
|           p_sign_posn               1            1            1            1
 | |
|           n_sign_posn               1            1            4            2
 | |
|           int_curr_symbol           "FIM "       "ITL "       "NLG "       "CHF "
 | |
|           int_frac_digits           2            0            2            2
 | |
|           int_p_cs_precedes         1            1            1            1
 | |
|           int_n_cs_precedes         1            1            1            1
 | |
|           int_p_sep_by_space        1            1            1            1
 | |
|           int_n_sep_by_space        2            1            2            1
 | |
|           int_p_sign_posn           1            1            1            1
 | |
|           int_n_sign_posn           4            1            4            2
 | |
| </pre>
 | |
| <a name='7.11.2.1p11'></a>
 | |
| <pre>11   EXAMPLE 2 The following table illustrates how the cs_precedes, sep_by_space, and sign_posn members affect the
 | |
|      formatted value.
 | |
|                                                   p_sep_by_space
 | |
|           p_cs_precedes    p_sign_posn     0         1          2
 | |
|                        0              0    (1.25$)   (1.25 $)    (1.25$)
 | |
|                                       1    +1.25$    +1.25 $     + 1.25$
 | |
|                                       2    1.25$+    1.25 $+     1.25$ +
 | |
|                                       3    1.25+$    1.25 +$     1.25+ $
 | |
|                                       4    1.25$+    1.25 $+     1.25$ +
 | |
|                        1              0    ($1.25)   ($ 1.25)    ($1.25)
 | |
|                                       1    +$1.25    +$ 1.25     + $1.25
 | |
|                                       2    $1.25+    $ 1.25+     $1.25 +
 | |
|                                       3    +$1.25    +$ 1.25     + $1.25
 | |
|                                       4    $+1.25    $+ 1.25     $ +1.25
 | |
| </pre>
 | |
| <a name='7.12'></a>
 | |
| <hr>
 | |
| <h3>7.12 [Mathematics <math.h>]</h3>
 | |
| <a name='7.12p1'></a>
 | |
| <pre>1   The header <math.h> declares two types and many mathematical functions and defines several
 | |
|     macros. Most synopses specify a family of functions consisting of a principal function with one
 | |
|     or more double parameters, a double return value, or both; and other functions with the same
 | |
|     name but with f and l suffixes, which are corresponding functions with float and long double
 | |
|     parameters, return values, or both.<a href='#FOOTNOTE.278'><sup>[278]</sup></a> Integer arithmetic functions and conversion functions are
 | |
|     discussed later.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.278'>
 | |
| <pre><i><b>Footnote 278)</b> Particularly on systems with wide expression evaluation, a <math.h> function might pass arguments and return values
 | |
|     in wider format than the synopsis prototype indicates.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12p2'></a>
 | |
| <pre>2   The feature test macro __STDC_VERSION_MATH_H__ expands to the token 202311L.
 | |
| </pre>
 | |
| <a name='7.12p3'></a>
 | |
| <pre>3   The types
 | |
| 
 | |
|               float_t
 | |
|               double_t
 | |
| 
 | |
| 
 | |
|     are floating types at least as wide as float and double, respectively, and such that double_t is
 | |
|     at least as wide as float_t. If FLT_EVAL_METHOD equals 0, float_t and double_t are float and
 | |
|     double, respectively; if FLT_EVAL_METHOD equals 1, they are both double; if FLT_EVAL_METHOD
 | |
|     equals 2, they are both long double; and for other values of FLT_EVAL_METHOD, they are otherwise
 | |
|     implementation-defined.<a href='#FOOTNOTE.279'><sup>[279]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.279'>
 | |
| <pre><i><b>Footnote 279)</b> The types float_t and double_t are intended to be the implementation’s most efficient types at least as wide as
 | |
|     float and double, respectively. For FLT_EVAL_METHOD equal 0, 1, or 2, the type float_t is the narrowest type used by the
 | |
|     implementation to evaluate floating expressions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12p4'></a>
 | |
| <pre>4   The types
 | |
|               _Decimal32_t
 | |
|               _Decimal64_t
 | |
| 
 | |
| 
 | |
|     are decimal floating types at least as wide as _Decimal32 and _Decimal64 , respectively,
 | |
|     and such that _Decimal64_t is at least as wide as _Decimal32_t . If DEC_EVAL_METHOD
 | |
|     equals 0, _Decimal32_t and _Decimal64_t are _Decimal32 and _Decimal64 , respectively; if
 | |
|     DEC_EVAL_METHOD equals 1, they are both _Decimal64 ; if DEC_EVAL_METHOD equals 2, they are
 | |
|     both _Decimal128 ; and for other values of DEC_EVAL_METHOD, they are otherwise implementation-
 | |
|     defined.
 | |
| </pre>
 | |
| <a name='7.12p5'></a>
 | |
| <pre>5   The macro
 | |
| 
 | |
|               HUGE_VAL
 | |
| 
 | |
| 
 | |
|     expands to a double constant expression, not necessarily representable as a float, whose value is
 | |
|     the maximum value returned by library functions when a floating result of type double overflows
 | |
|     under the default rounding mode, either maximum finite number in the type or positive or unsigned
 | |
|     infinity. The macros
 | |
| 
 | |
|               HUGE_VALF
 | |
|               HUGE_VALL
 | |
| 
 | |
| 
 | |
|     are respectively float and long double analogs of HUGE_VAL<a href='#FOOTNOTE.280'><sup>[280]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.280'>
 | |
| <pre><i><b>Footnote 280)</b> HUGE_VAL, HUGE_VALF, and HUGE_VALL can be positive infinities in an implementation that supports infinities.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12p6'></a>
 | |
| <pre>6   The macro
 | |
| 
 | |
|               HUGE_VAL_D32
 | |
| 
 | |
| 
 | |
|     expands to a constant expression of type _Decimal32 representing positive infinity. The macros
 | |
| 
 | |
|               HUGE_VAL_D64
 | |
|              HUGE_VAL_D128
 | |
| 
 | |
| 
 | |
|      are respectively _Decimal64 and _Decimal128 analogs of HUGE_VAL_D32.
 | |
| </pre>
 | |
| <a name='7.12p7'></a>
 | |
| <pre>7    The macro
 | |
| 
 | |
|              INFINITY
 | |
| 
 | |
| 
 | |
|      is defined if and only if the implementation supports an infinity for the type float. It expands to a
 | |
|      constant expression of type float representing positive or unsigned infinity.
 | |
| </pre>
 | |
| <a name='7.12p8'></a>
 | |
| <pre>8    The macro
 | |
| 
 | |
|              DEC_INFINITY
 | |
| 
 | |
| 
 | |
|      expands to a constant expression of type _Decimal32 representing positive infinity.
 | |
| </pre>
 | |
| <a name='7.12p9'></a>
 | |
| <pre>9    The macro
 | |
| 
 | |
|              NAN
 | |
| 
 | |
| 
 | |
|      is defined if and only if the implementation supports quiet NaNs for the float type. It expands to a
 | |
|      constant expression of type float representing a quiet NaN.
 | |
| </pre>
 | |
| <a name='7.12p10'></a>
 | |
| <pre>10   The macro
 | |
| 
 | |
|              DEC_NAN
 | |
| 
 | |
| 
 | |
|      expands to a constant expression of type _Decimal32 representing a quiet NaN.
 | |
| </pre>
 | |
| <a name='7.12p11'></a>
 | |
| <pre>11   Use of the macros INFINITY, DEC_INFINITY, NAN, and DEC_NAN in <math.h> is an obsolescent
 | |
|      feature. Instead, use the same macros in <float.h>.
 | |
| </pre>
 | |
| <a name='7.12p12'></a>
 | |
| <pre>12   The number classification macros
 | |
| 
 | |
|              FP_INFINITE
 | |
|              FP_NAN
 | |
|              FP_NORMAL
 | |
|              FP_SUBNORMAL
 | |
|              FP_ZERO
 | |
| 
 | |
| 
 | |
|      represent mutually exclusive kinds of floating-point values. They expand to integer constant
 | |
|      expressions with distinct values. Additional implementation-defined floating-point classifications,
 | |
|      with macro definitions beginning with FP_ and an uppercase letter, may also be specified by the
 | |
|      implementation.
 | |
| </pre>
 | |
| <a name='7.12p13'></a>
 | |
| <pre>13   The math rounding direction macros
 | |
| 
 | |
|              FP_INT_UPWARD
 | |
|              FP_INT_DOWNWARD
 | |
|              FP_INT_TOWARDZERO
 | |
|              FP_INT_TONEARESTFROMZERO
 | |
|              FP_INT_TONEAREST
 | |
| 
 | |
| 
 | |
|      represent the rounding directions of the functions ceil, floor, trunc, round, and roundeven,
 | |
|      respectively, that convert to integral values in floating-point formats. They expand to integer
 | |
|      constant expressions with distinct values suitable for use as the second argument to the fromfp,
 | |
|      ufromfp, fromfpx, and ufromfpx functions.
 | |
| </pre>
 | |
| <a name='7.12p14'></a>
 | |
| <pre>14   The macro
 | |
| 
 | |
|              FP_FAST_FMA
 | |
|      is optionally defined. If defined, it indicates that the fma function generally executes about as fast as,
 | |
|      or faster than, a multiply and an add of double operands.<a href='#FOOTNOTE.281'><sup>[281]</sup></a> The macros
 | |
| 
 | |
|                FP_FAST_FMAF
 | |
|                FP_FAST_FMAL
 | |
| 
 | |
| 
 | |
|      are, respectively, float and long double analogs of FP_FAST_FMA. If defined, these macros expand
 | |
|      to the integer constant 1.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.281'>
 | |
| <pre><i><b>Footnote 281)</b> Typically, the FP_FAST_FMA macro is defined if and only if the fma function is implemented directly with a hardware
 | |
|      multiply-add instruction. Software implementations are expected to be substantially slower.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12p15'></a>
 | |
| <pre>15   The macros
 | |
| 
 | |
|                FP_FAST_FMAD32
 | |
|                FP_FAST_FMAD64
 | |
|                FP_FAST_FMAD128
 | |
| 
 | |
| 
 | |
|      are, respectively, _Decimal32 , _Decimal64 , and _Decimal128 analogs of FP_FAST_FMA.
 | |
| </pre>
 | |
| <a name='7.12p16'></a>
 | |
| <pre>16   Each of the macros
 | |
| 
 | |
|      FP_FAST_FADD                  FP_FAST_DSUBL                  FP_FAST_FDIVL                  FP_FAST_FFMA
 | |
|      FP_FAST_FADDL                 FP_FAST_FMUL                   FP_FAST_DDIVL                  FP_FAST_FFMAL
 | |
|      FP_FAST_DADDL                 FP_FAST_FMULL                  FP_FAST_FSQRT                  FP_FAST_DFMAL
 | |
|      FP_FAST_FSUB                  FP_FAST_DMULL                  FP_FAST_FSQRTL
 | |
|      FP_FAST_FSUBL                 FP_FAST_FDIV                   FP_FAST_DSQRTL
 | |
| 
 | |
| 
 | |
|      is optionally defined. If defined, it indicates that the corresponding function generally executes
 | |
|      about as fast, or faster, than the corresponding operation or function of the argument type with
 | |
|      result type the same as the argument type followed by conversion to the narrower type. For
 | |
|      FP_FAST_FFMA, FP_FAST_FFMAL, and FP_FAST_DFMAL, the comparison is to a call to fma or fmal
 | |
|      followed by a conversion, not to separate multiply, add, and conversion. If defined, these macros
 | |
|      expand to the integer constant 1.
 | |
| </pre>
 | |
| <a name='7.12p17'></a>
 | |
| <pre>17   The macros
 | |
| 
 | |
|      FP_FAST_D32ADDD64                       FP_FAST_D32MULD64                        FP_FAST_D32FMAD64
 | |
|      FP_FAST_D32ADDD128                      FP_FAST_D32MULD128                       FP_FAST_D32FMAD128
 | |
|      FP_FAST_D64ADDD128                      FP_FAST_D64MULD128                       FP_FAST_D64FMAD128
 | |
|      FP_FAST_D32SUBD64                       FP_FAST_D32DIVD64                        FP_FAST_D32SQRTD64
 | |
|      FP_FAST_D32SUBD128                      FP_FAST_D32DIVD128                       FP_FAST_D32SQRTD128
 | |
|      FP_FAST_D64SUBD128                      FP_FAST_D64DIVD128                       FP_FAST_D64SQRTD128
 | |
| 
 | |
| 
 | |
|      are analogs of FP_FAST_FADD, FP_FAST_FADDL, FP_FAST_DADDL, etc., for decimal floating types.
 | |
| </pre>
 | |
| <a name='7.12p18'></a>
 | |
| <pre>18   The macros
 | |
| 
 | |
|                FP_ILOGB0
 | |
|                FP_ILOGBNAN
 | |
| 
 | |
| 
 | |
|      expand to integer constant expressions whose values are returned by ilogb(x) if x is zero or
 | |
|      NaN, respectively. The value of FP_ILOGB0 shall be either INT_MIN or -INT_MAX . The value of
 | |
|      FP_ILOGBNAN shall be either INT_MAX or INT_MIN.
 | |
| </pre>
 | |
| <a name='7.12p19'></a>
 | |
| <pre>19   The macros
 | |
| 
 | |
|                FP_LLOGB0
 | |
|                FP_LLOGBNAN
 | |
|      expand to integer constant expressions whose values are returned by llogb(x) if x is zero or NaN, re-
 | |
|      spectively. The value of FP_LLOGB0 shall be LONG_MIN if the value of FP_ILOGB0 is INT_MIN, and shall
 | |
|      be-LONG_MAX if the value of FP_ILOGB0 is-INT_MAX . The value of FP_LLOGBNAN shall be LONG_MAX
 | |
|      if the value of FP_ILOGBNAN is INT_MAX, and shall be LONG_MIN if the value of FP_ILOGBNAN is
 | |
|      INT_MIN.
 | |
| </pre>
 | |
| <a name='7.12p20'></a>
 | |
| <pre>20   The macros
 | |
| 
 | |
|                MATH_ERRNO
 | |
|                MATH_ERREXCEPT
 | |
| 
 | |
| 
 | |
|      expand to the integer constants 1 and 2, respectively; the macro
 | |
| 
 | |
|                math_errhandling
 | |
| 
 | |
| 
 | |
|      expands to an expression that has type int and the value MATH_ERRNO, MATH_ERREXCEPT, the
 | |
|      bitwise OR of both, or 0; the value shall not be 0 in a hosted implementation. The value
 | |
|      of math_errhandling is constant for the duration of the program. It is unspecified whether
 | |
|      math_errhandling is a macro or an identifier with external linkage. If a macro definition is sup-
 | |
|      pressed or a program defines an identifier with the name math_errhandling, the behavior is
 | |
|      undefined. If the expression math_errhandling & MATH_ERREXCEPT can be nonzero, the implemen-
 | |
|      tation shall define the macros FE_DIVBYZERO, FE_INVALID, and FE_OVERFLOW in <fenv.h>.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.1 [Treatment of error conditions]</h3>
 | |
| <a name='7.12.1p1'></a>
 | |
| <pre>1    The behavior of each of the functions in <math.h> is specified for all representable values of its
 | |
|      input arguments, except where explicitly stated otherwise. Each function shall execute as if it were a
 | |
|      single operation without raising SIGFPE and without generating any of the floating-point exceptions
 | |
|      "invalid", "divide-by-zero", or "overflow" except to reflect the result of the function.
 | |
| </pre>
 | |
| <a name='7.12.1p2'></a>
 | |
| <pre>2    For all functions, a domain error occurs if and only if an input argument is outside the domain over
 | |
|      which the mathematical function is defined. The description of each function lists any required
 | |
|      domain errors; an implementation may define additional domain errors, provided that such errors
 | |
|      are consistent with the mathematical definition of the function.<a href='#FOOTNOTE.282'><sup>[282]</sup></a> Whether a signaling NaN
 | |
|      input causes a domain error is implementation-defined. On a domain error, the function returns
 | |
|      an implementation-defined value; if the integer expression math_errhandling & MATH_ERRNO
 | |
|      is nonzero, the integer expression errno acquires the value EDOM; if the integer expression
 | |
|      math_errhandling & MATH_ERREXCEPT is nonzero, the "invalid" floating-point exception is raised.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.282'>
 | |
| <pre><i><b>Footnote 282)</b> In an implementation that supports infinities, this allows an infinity as an argument to be a domain error if the
 | |
|      mathematical domain of the function does not include the infinity.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.1p3'></a>
 | |
| <pre>3    Similarly, a pole error (also known as a singularity or infinitary) occurs if and only if the mathematical
 | |
|      function has an exact infinite result as the finite input argument(s) are approached in the limit (for ex-
 | |
|      ample, log(0.0)). The description of each function lists any required pole errors; an implementation
 | |
|      may define additional pole errors, provided that such errors are consistent with the mathematical
 | |
|      definition of the function. On a pole error, the function returns an implementation-defined value;
 | |
|      if the integer expression math_errhandling & MATH_ERRNO is nonzero, the integer expression
 | |
|      errno acquires the value ERANGE; if the integer expression math_errhandling & MATH_ERREXCEPT
 | |
|      is nonzero, the "divide-by-zero" floating-point exception is raised.
 | |
| </pre>
 | |
| <a name='7.12.1p4'></a>
 | |
| <pre>4    Likewise, a range error occurs if and only if the result overflows or underflows, as defined below.
 | |
|      The description of each function lists any required range errors; an implementation may define
 | |
|      additional range errors, provided that such errors are consistent with the mathematical definition of
 | |
|      the function and are the result of either overflow or underflow<a href='#FOOTNOTE.283'><sup>[283]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.283'>
 | |
| <pre><i><b>Footnote 283)</b> Range errors that are required or implementation-defined shall or may be reported, as specified in this subclause.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.1p5'></a>
 | |
| <pre>5    A floating result overflows if a finite result value with ordinary accuracy<a href='#FOOTNOTE.284'><sup>[284]</sup></a> would have magnitude
 | |
|      (absolute value) too large for the representation with full precision in the specified type. A result
 | |
|      that is exactly an infinity does not overflow. If a floating result overflows and default rounding
 | |
|     is in effect, then the function returns the value of the macro HUGE_VAL, HUGE_VALF, or HUGE_VALL
 | |
|     according to the return type, with the same sign as the correct value of the function; however, for
 | |
|     the types with reduced-precision representations of numbers beyond the overflow threshold, the
 | |
|     function may return a representation of the result with less than full precision for the type. If a
 | |
|     floating result overflows and the integer expression math_errhandling & MATH_ERRNO is nonzero,
 | |
|     the integer expression errno acquires the value ERANGE. If a floating result overflows and the
 | |
|     integer expression math_errhandling & MATH_ERREXCEPT is nonzero, the "overflow" floating-
 | |
|     point exception is raised.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.284'>
 | |
| <pre><i><b>Footnote 284)</b> Ordinary accuracy is determined by the implementation. It refers to the accuracy of the function where results are not
 | |
|      compromised by extreme magnitude.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.1p6'></a>
 | |
| <pre>6   The result underflows if a nonzero result value with ordinary accuracy would have magnitude (abso-
 | |
|     lute value) less than the minimum normalized number in the type; however a zero result that is spec-
 | |
|     ified to be an exact zero does not underflow. Also, a result with ordinary accuracy and the magnitude
 | |
|     of the minimum normalized number may underflow<a href='#FOOTNOTE.285'><sup>[285]</sup></a> . If the result underflows, the function re-
 | |
|     turns an implementation-defined value whose magnitude is no greater than the smallest normalized
 | |
|     positive number in the specified type; if the integer expression math_errhandling & MATH_ERRNO is
 | |
|     nonzero, whether errno acquires the value ERANGE is implementation-defined; if the integer expres-
 | |
|     sion math_errhandling & MATH_ERREXCEPT is nonzero, whether the "underflow" floating-point
 | |
|     exception is raised is implementation-defined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.285'>
 | |
| <pre><i><b>Footnote 285)</b> The term underflow here is intended to encompass both "gradual underflow" as in IEC 60559 and also "flush-to-zero"
 | |
|      underflow. IEC 60559 underflow can occur in cases where the magnitude of the rounded result (accurate to the full precision
 | |
|     of the type) equals the minimum normalized number in the format.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.1p7'></a>
 | |
| <pre>7   If a domain, pole, or range error occurs and the integer expression math_errhandling & MATH_ERRNO
 | |
|     is zero,<a href='#FOOTNOTE.286'><sup>[286]</sup></a> then errno shall either be set to the value corresponding to the error or left unmodified. If
 | |
|     no such error occurs, errno shall be left unmodified regardless of the setting of math_errhandling.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.286'>
 | |
| <pre><i><b>Footnote 286)</b> Math errors are being indicated by the floating-point exception flags rather than by errno.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.2 [The FP_CONTRACT pragma]</h3>
 | |
| <a name='7.12.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               #pragma STDC FP_CONTRACT on-off-switch
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.2p2'></a>
 | |
| <pre>2   The FP_CONTRACT pragma can be used to allow (if the state is "on") or disallow (if the state is
 | |
|     "off") the implementation to contract expressions (<a href='#6.5'>6.5</a>). Each pragma can occur either outside
 | |
|     external declarations or preceding all explicit declarations and statements inside a compound
 | |
|     statement. When outside external declarations, the pragma takes effect from its occurrence until
 | |
|     another FP_CONTRACT pragma is encountered, or until the end of the translation unit. When inside
 | |
|     a compound statement, the pragma takes effect from its occurrence until another FP_CONTRACT
 | |
|     pragma is encountered (including within a nested compound statement), or until the end of the
 | |
|     compound statement; at the end of a compound statement the state for the pragma is restored to
 | |
|     its condition just before the compound statement. If this pragma is used in any other context, the
 | |
|     behavior is undefined. The default state ("on" or "off") for the pragma is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.3 [Classification macros]</h3>
 | |
| <a name='7.12.3p1'></a>
 | |
| <pre>1   Floating-point values can be classified as NaN, infinite, normal, subnormal, or zero, or into other
 | |
|     implementation-defined categories. Numbers whose magnitude is at least bemin −1 (the minimum
 | |
|     magnitude of normalized floating-point numbers in the type) and at most (1 − b−p )bemax (the
 | |
|     maximum magnitude of normalized floating-point numbers in the type), where b, p, emin , and emax
 | |
|     are as in <a href='#5.2.4.2.2'>5.2.4.2.2</a>, are classified as normal. Larger magnitude finite numbers represented with full
 | |
|     precision in the type may also be classified as normal. Nonzero numbers whose magnitude is less
 | |
|     than bemin −1 are classified as subnormal.
 | |
| </pre>
 | |
| <a name='7.12.3p2'></a>
 | |
| <pre>2   In the synopses in this subclause, real-floating indicates that the argument shall be an expression of
 | |
|     real floating type.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.1 [The fpclassify macro]</h3>
 | |
| <a name='7.12.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <math.h>
 | |
|               int fpclassify(real-floating x);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.1p2'></a>
 | |
| <pre>2   The fpclassify macro classifies its argument value as NaN, infinite, normal, subnormal, zero, or
 | |
|     into another implementation-defined category. First, an argument represented in a format wider
 | |
|     than its semantic type is converted to its semantic type. Then classification is based on the type of
 | |
|     the argument.<a href='#FOOTNOTE.287'><sup>[287]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.287'>
 | |
| <pre><i><b>Footnote 287)</b> Since an expression can be evaluated with more range and precision than its type has, it is important to know the type
 | |
|     that classification is based on. For example, a normal long double value might become subnormal when converted to
 | |
|     double, and zero when converted to float.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.3.1p3'></a>
 | |
| <pre>3   The fpclassify macro returns the value of the number classification macro appropriate to the value
 | |
|     of its argument.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.2 [The iscanonical macro]</h3>
 | |
| <a name='7.12.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int iscanonical(real-floating x);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.2p2'></a>
 | |
| <pre>2   The iscanonical macro determines whether its argument value is canonical (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). First, an
 | |
|     argument represented in a format wider than its semantic type is converted to its semantic type.
 | |
|     Then, determination is based on the type of the argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.3.2p3'></a>
 | |
| <pre>3   The iscanonical macro returns a nonzero value if and only if its argument is canonical.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.3 [The isfinite macro]</h3>
 | |
| <a name='7.12.3.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int isfinite(real-floating x);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.3p2'></a>
 | |
| <pre>2   The isfinite macro determines whether its argument has a finite value (zero, subnormal, or
 | |
|     normal, and not infinite or NaN). First, an argument represented in a format wider than its semantic
 | |
|     type is converted to its semantic type. Then determination is based on the type of the argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.3.3p3'></a>
 | |
| <pre>3   The isfinite macro returns a nonzero value if and only if its argument has a finite value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.4 [The isinf macro]</h3>
 | |
| <a name='7.12.3.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int isinf(real-floating x);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.4p2'></a>
 | |
| <pre>2   The isinf macro determines whether its argument value is (positive or negative) infinity. First, an
 | |
|     argument represented in a format wider than its semantic type is converted to its semantic type.
 | |
|     Then determination is based on the type of the argument.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.3.4p3'></a>
 | |
| <pre>3   The isinf macro returns a nonzero value if and only if its argument has an infinite value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.5 [The isnan macro]</h3>
 | |
| <a name='7.12.3.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              int isnan(real-floating x);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.5p2'></a>
 | |
| <pre>2   The isnan macro determines whether its argument value is a NaN. First, an argument represented
 | |
|     in a format wider than its semantic type is converted to its semantic type. Then determination is
 | |
|     based on the type of the argument.<a href='#FOOTNOTE.288'><sup>[288]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.288'>
 | |
| <pre><i><b>Footnote 288)</b> For the isnan macro, the type for determination does not matter unless the implementation supports NaNs in the
 | |
|     evaluation type but not in the semantic type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.3.5p3'></a>
 | |
| <pre>3   The isnan macro returns a nonzero value if and only if its argument has a NaN value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.6 [The isnormal macro]</h3>
 | |
| <a name='7.12.3.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              int isnormal(real-floating x);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.6p2'></a>
 | |
| <pre>2   The isnormal macro determines whether its argument value is normal (neither zero, subnormal,
 | |
|     infinite, nor NaN). First, an argument represented in a format wider than its semantic type is
 | |
|     converted to its semantic type. Then determination is based on the type of the argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.3.6p3'></a>
 | |
| <pre>3   The isnormal macro returns a nonzero value if and only if its argument has a normal value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.7 [The signbit macro]</h3>
 | |
| <a name='7.12.3.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              int signbit(real-floating x);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.7p2'></a>
 | |
| <pre>2   The signbit macro determines whether the sign of its argument value is negative<a href='#FOOTNOTE.289'><sup>[289]</sup></a> . If the
 | |
|     argument value is an unsigned zero, its sign is regarded as positive. Otherwise, if the argument
 | |
|     value is unsigned, the result value (zero or nonzero) is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.289'>
 | |
| <pre><i><b>Footnote 289)</b> The signbit macro determines the sign of all values, including infinities, zeros, and NaNs.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.3.7p3'></a>
 | |
| <pre>3   The signbit macro returns a nonzero value if and only if the sign of its argument value is determined
 | |
|     to be negative.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.8'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.8 [The issignaling macro]</h3>
 | |
| <a name='7.12.3.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              int issignaling(real-floating x);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.8p2'></a>
 | |
| <pre>2   The issignaling macro determines whether its argument value is a signaling NaN.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.3.8p3'></a>
 | |
| <pre>3   The issignaling macro returns a nonzero value if and only if its argument is a signaling NaN.<a href='#FOOTNOTE.290'><sup>[290]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.290'>
 | |
| <pre><i><b>Footnote 290)</b> <a href='#F.3'>F.3</a> specifies that issignaling (and all the other classification macros), raise no floating-point exception if the argument
 | |
|     is a variable, or any other expression whose value is represented in the format of its semantic type, even if the value is a
 | |
|     signaling NaN.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.3.9'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.9 [The issubnormal macro]</h3>
 | |
| <a name='7.12.3.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int issubnormal(real-floating x);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.9p2'></a>
 | |
| <pre>2   The issubnormal macro determines whether its argument value is subnormal. First, an argument
 | |
|     represented in a format wider than its semantic type is converted to its semantic type. Then
 | |
|     determination is based on the type of the argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.3.9p3'></a>
 | |
| <pre>3   The issubnormal macro returns a nonzero value if and only if its argument is subnormal.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.3.10'></a>
 | |
| <hr>
 | |
| <h3>7.12.3.10 [The iszero macro]</h3>
 | |
| <a name='7.12.3.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int iszero(real-floating x);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.3.10p2'></a>
 | |
| <pre>2   The iszero macro determines whether its argument value is (positive, negative, or unsigned) zero.
 | |
|     First, an argument represented in a format wider than its semantic type is converted to its semantic
 | |
|     type. Then, determination is based on the type of the argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.3.10p3'></a>
 | |
| <pre>3   The iszero macro returns a nonzero value if and only if its argument is zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.4 [Trigonometric functions]</h3>
 | |
| <a name='7.12.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.1 [The acos functions]</h3>
 | |
| <a name='7.12.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double acos(double x);
 | |
|               float acosf(float x);
 | |
|               long double acosl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 acosd32(_Decimal32 x);
 | |
|               _Decimal64 acosd64(_Decimal64 x);
 | |
|               _Decimal128 acosd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.1p2'></a>
 | |
| <pre>2   The acos functions compute the principal value of the arc cosine of x. A domain error occurs for
 | |
|     arguments not in the interval [−1, +1].
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.1p3'></a>
 | |
| <pre>3   The acos functions return arccos x in the interval [0, π] radians.
 | |
| </pre>
 | |
| <a name='7.12.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.2 [The asin functions]</h3>
 | |
| <a name='7.12.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double asin(double x);
 | |
|              float asinf(float x);
 | |
|              long double asinl(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 asind32(_Decimal32 x);
 | |
|              _Decimal64 asind64(_Decimal64 x);
 | |
|              _Decimal128 asind128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.2p2'></a>
 | |
| <pre>2   The asin functions compute the principal value of the arc sine of x. A domain error occurs for
 | |
|     arguments not in the interval [−1, +1]. A range error occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.2p3'></a>
 | |
| <pre>3   The asin functions return arcsin x in the interval [− π2 , + π2 ] radians.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.3 [The atan functions]</h3>
 | |
| <a name='7.12.4.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double atan(double x);
 | |
|              float atanf(float x);
 | |
|              long double atanl(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 atand32(_Decimal32 x);
 | |
|              _Decimal64 atand64(_Decimal64 x);
 | |
|              _Decimal128 atand128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.3p2'></a>
 | |
| <pre>2   The atan functions compute the principal value of the arc tangent of x. A range error occurs if
 | |
|     nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.3p3'></a>
 | |
| <pre>3   The atan functions return arctan x in the interval [− π2 , + π2 ] radians.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.4 [The atan2 functions]</h3>
 | |
| <a name='7.12.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double atan2(double y, double x);
 | |
|              float atan2f(float y, float x);
 | |
|              long double atan2l(long double y, long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 atan2d32(_Decimal32 y, _Decimal32 x);
 | |
|              _Decimal64 atan2d64(_Decimal64 y, _Decimal64 x);
 | |
|              _Decimal128 atan2d128(_Decimal128 y, _Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.4p2'></a>
 | |
| <pre>2   The atan2 functions compute the value of the arc tangent of y/x, using the signs of both arguments
 | |
|     to determine the quadrant of the return value. A domain error may occur if both arguments are zero.
 | |
|     A range error occurs if x is positive and nonzero xy is too close to zero.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.4p3'></a>
 | |
| <pre>3   The atan2 functions return arctan(y/x) in the interval [−π, +π] radians.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.5 [The cos functions]</h3>
 | |
| <a name='7.12.4.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double cos(double x);
 | |
|             float cosf(float x);
 | |
|             long double cosl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 cosd32(_Decimal32 x);
 | |
|             _Decimal64 cosd64(_Decimal64 x);
 | |
|             _Decimal128 cosd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.5p2'></a>
 | |
| <pre>2   The cos functions compute the cosine of x (measured in radians).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.5p3'></a>
 | |
| <pre>3   The cos functions return cos x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.6 [The sin functions]</h3>
 | |
| <a name='7.12.4.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double sin(double x);
 | |
|             float sinf(float x);
 | |
|             long double sinl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 sind32(_Decimal32 x);
 | |
|             _Decimal64 sind64(_Decimal64 x);
 | |
|             _Decimal128 sind128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.6p2'></a>
 | |
| <pre>2   The sin functions compute the sine of x (measured in radians). A range error occurs if nonzero x is
 | |
|     too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.6p3'></a>
 | |
| <pre>3   The sin functions return sin x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.7 [The tan functions]</h3>
 | |
| <a name='7.12.4.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double tan(double x);
 | |
|             float tanf(float x);
 | |
|             long double tanl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 tand32(_Decimal32 x);
 | |
|             _Decimal64 tand64(_Decimal64 x);
 | |
|             _Decimal128 tand128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.7p2'></a>
 | |
| <pre>2   The tan functions return the tangent of x (measured in radians). A range error occurs if nonzero x is
 | |
|     too close to zero.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.7p3'></a>
 | |
| <pre>3   The tan functions return tan x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.8'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.8 [The acospi functions]</h3>
 | |
| <a name='7.12.4.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double acospi(double x);
 | |
|               float acospif(float x);
 | |
|               long double acospil(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 acospid32(_Decimal32 x);
 | |
|               _Decimal64 acospid64(_Decimal64 x);
 | |
|               _Decimal128 acospid128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.8p2'></a>
 | |
| <pre>2   The acospi functions compute the principal value of the arc cosine of x, divided by π, thus measur-
 | |
|     ing the angle in half-revolutions. A domain error occurs for arguments not in the interval [−1, +1].
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.8p3'></a>
 | |
| <pre>3   The acospi functions return arccos(x)/π in the interval [0, 1].
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.9'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.9 [The asinpi functions]</h3>
 | |
| <a name='7.12.4.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double asinpi(double x);
 | |
|               float asinpif(float x);
 | |
|               long double asinpil(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 asinpid32(_Decimal32 x);
 | |
|               _Decimal64 asinpid64(_Decimal64 x);
 | |
|               _Decimal128 asinpid128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.9p2'></a>
 | |
| <pre>2   The asinpi functions compute the principal value of the arc sine of x, divided by π, thus measuring
 | |
|     the angle in half-revolutions. A domain error occurs for arguments not in the interval [−1, +1]. A
 | |
|     range error occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.9p3'></a>
 | |
| <pre>3   The asinpi functions return arcsin(x)/π in the interval [− 12 , + 12 ].
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.10'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.10 [The atanpi functions]</h3>
 | |
| <a name='7.12.4.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double atanpi(double x);
 | |
|               float atanpif(float x);
 | |
|               long double atanpil(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 atanpid32(_Decimal32 x);
 | |
|               _Decimal64 atanpid64(_Decimal64 x);
 | |
|               _Decimal128 atanpid128(_Decimal128 x);
 | |
|               #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.10p2'></a>
 | |
| <pre>2   The atanpi functions compute the principal value of the arc tangent of x, divided by π, thus
 | |
|     measuring the angle in half-revolutions. A range error occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.10p3'></a>
 | |
| <pre>3   The atanpi functions return arctan(x)/π. in the interval [− 12 , + 12 ].
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.11'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.11 [The atan2pi functions]</h3>
 | |
| <a name='7.12.4.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double atan2pi(double y, double x);
 | |
|               float atan2pif(float y, float x);
 | |
|               long double atan2pil(long double y, long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 atan2pid32(_Decimal32 y, _Decimal32 x);
 | |
|               _Decimal64 atan2pid64(_Decimal64 y, _Decimal64 x);
 | |
|               _Decimal128 atan2pid128(_Decimal128 y, _Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.11p2'></a>
 | |
| <pre>2   The atan2pi functions compute the angle, measured in half-revolutions, subtended at the origin by
 | |
|     the point (x, y) and the positive x-axis. Thus, the atan2pi functions compute arctan( xy )/π, in the
 | |
|     range [−1, +1]. A domain error may occur if both arguments are zero. A range error occurs if x is
 | |
|     positive and nonzero xy is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.11p3'></a>
 | |
| <pre>3   The atan2pi functions return the computed angle, in the interval [−1, +1].
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.12'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.12 [The cospi functions]</h3>
 | |
| <a name='7.12.4.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double cospi(double x);
 | |
|               float cospif(float x);
 | |
|               long double cospil(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 cospid32(_Decimal32 x);
 | |
|               _Decimal64 cospid64(_Decimal64 x);
 | |
|               _Decimal128 cospid128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.12p2'></a>
 | |
| <pre>2   The cospi functions compute the cosine of π × x, thus regarding x as a measurement in half-
 | |
|     revolutions.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.12p3'></a>
 | |
| <pre>3   The cospi functions return cos(π × x).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.13'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.13 [The sinpi functions]</h3>
 | |
| <a name='7.12.4.13p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double sinpi(double x);
 | |
|               float sinpif(float x);
 | |
|               long double sinpil(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 sinpid32(_Decimal32 x);
 | |
|               _Decimal64 sinpid64(_Decimal64 x);
 | |
|              _Decimal128 sinpid128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.13p2'></a>
 | |
| <pre>2   The sinpi functions compute the sine of π× x, thus regarding x as a measurement in half-revolutions.
 | |
|     A range error occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.13p3'></a>
 | |
| <pre>3   The sinpi functions return sin(π × x).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.4.14'></a>
 | |
| <hr>
 | |
| <h3>7.12.4.14 [The tanpi functions]</h3>
 | |
| <a name='7.12.4.14p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double tanpi(double x);
 | |
|              float tanpif(float x);
 | |
|              long double tanpil(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 tanpid32(_Decimal32 x);
 | |
|              _Decimal64 tanpid64(_Decimal64 x);
 | |
|              _Decimal128 tanpid128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.4.14p2'></a>
 | |
| <pre>2   The tanpi functions compute the tagent of π × x, thus regarding x as a measurement in half-
 | |
|     revolutions. A range error occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.4.14p3'></a>
 | |
| <pre>3   The tanpi functions return tan(π × x).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.5 [Hyperbolic functions]</h3>
 | |
| <a name='7.12.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.5.1 [The acosh functions]</h3>
 | |
| <a name='7.12.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double acosh(double x);
 | |
|              float acoshf(float x);
 | |
|              long double acoshl(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 acoshd32(_Decimal32 x);
 | |
|              _Decimal64 acoshd64(_Decimal64 x);
 | |
|              _Decimal128 acoshd128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.5.1p2'></a>
 | |
| <pre>2   The acosh functions compute the (nonnegative) arc hyperbolic cosine of x. A domain error occurs
 | |
|     for arguments less than 1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.5.1p3'></a>
 | |
| <pre>3   The acosh functions return arcosh x in the interval [0, +∞].
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.5.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.5.2 [The asinh functions]</h3>
 | |
| <a name='7.12.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double asinh(double x);
 | |
|              float asinhf(float x);
 | |
|              long double asinhl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 asinhd32(_Decimal32 x);
 | |
|             _Decimal64 asinhd64(_Decimal64 x);
 | |
|             _Decimal128 asinhd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.5.2p2'></a>
 | |
| <pre>2   The asinh functions compute the arc hyperbolic sine of x. A range error occurs if nonzero x is too
 | |
|     close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.5.2p3'></a>
 | |
| <pre>3   The asinh functions return arsinh x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.5.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.5.3 [The atanh functions]</h3>
 | |
| <a name='7.12.5.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double atanh(double x);
 | |
|             float atanhf(float x);
 | |
|             long double atanhl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 atanhd32(_Decimal32 x);
 | |
|             _Decimal64 atanhd64(_Decimal64 x);
 | |
|             _Decimal128 atanhd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.5.3p2'></a>
 | |
| <pre>2   The atanh functions compute the arc hyperbolic tangent of x. A domain error occurs for arguments
 | |
|     not in the interval [−1, +1]. A pole error may occur if the argument equals-1 or +1 . A range error
 | |
|     occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.5.3p3'></a>
 | |
| <pre>3   The atanh functions return artanh x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.5.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.5.4 [The cosh functions]</h3>
 | |
| <a name='7.12.5.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double cosh(double x);
 | |
|             float coshf(float x);
 | |
|             long double coshl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 coshd32(_Decimal32 x);
 | |
|             _Decimal64 coshd64(_Decimal64 x);
 | |
|             _Decimal128 coshd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.5.4p2'></a>
 | |
| <pre>2   The cosh functions compute the hyperbolic cosine of x. A range error occurs if the magnitude of
 | |
|     finite x is too large.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.5.4p3'></a>
 | |
| <pre>3   The cosh functions return cosh x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.5.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.5.5 [The sinh functions]</h3>
 | |
| <a name='7.12.5.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|                double sinh(double x);
 | |
|                float sinhf(float x);
 | |
|                long double sinhl(long double x);
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 sinhd32(_Decimal32 x);
 | |
|                _Decimal64 sinhd64(_Decimal64 x);
 | |
|                _Decimal128 sinhd128(_Decimal128 x);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.5.5p2'></a>
 | |
| <pre>2   The sinh functions compute the hyperbolic sine of x. A range error occurs if the magnitude of finite
 | |
|     x is too large or if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.5.5p3'></a>
 | |
| <pre>3   The sinh functions return sinh x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.5.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.5.6 [The tanh functions]</h3>
 | |
| <a name='7.12.5.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <math.h>
 | |
|                double tanh(double x);
 | |
|                float tanhf(float x);
 | |
|                long double tanhl(long double x);
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 tanhd32(_Decimal32 x);
 | |
|                _Decimal64 tanhd64(_Decimal64 x);
 | |
|                _Decimal128 tanhd128(_Decimal128 x);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.5.6p2'></a>
 | |
| <pre>2   The tanh functions compute the hyperbolic tangent of x. A range error occurs if nonzero x is too
 | |
|     close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.5.6p3'></a>
 | |
| <pre>3   The tanh functions return tanh x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.6 [Exponential and logarithmic functions]</h3>
 | |
| <a name='7.12.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.1 [The exp functions]</h3>
 | |
| <a name='7.12.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <math.h>
 | |
|                double exp(double x);
 | |
|                float expf(float x);
 | |
|                long double expl(long double x);
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 expd32(_Decimal32 x);
 | |
|                _Decimal64 expd64(_Decimal64 x);
 | |
|                _Decimal128 expd128(_Decimal128 x);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.1p2'></a>
 | |
| <pre>2   The exp functions compute the base-e exponential of x. A range error occurs if the magnitude of
 | |
|     finite x is too large.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.1p3'></a>
 | |
| <pre>3   The exp functions return ex .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.2 [The exp10 functions]</h3>
 | |
| <a name='7.12.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double exp10(double x);
 | |
|             float exp10f(float x);
 | |
|             long double exp10l(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 exp10d32(_Decimal32 x);
 | |
|             _Decimal64 exp10d64(_Decimal64 x);
 | |
|             _Decimal128 exp10d128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.2p2'></a>
 | |
| <pre>2   The exp10 functions compute the base-10 exponential of x. A range error occurs if the magnitude of
 | |
|     finite x is too large.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.2p3'></a>
 | |
| <pre>3   The exp10 functions return 10x .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.3 [The exp10m1 functions]</h3>
 | |
| <a name='7.12.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double exp10m1(double x);
 | |
|             float exp10m1f(float x);
 | |
|             long double exp10m1l(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 exp10m1d32(_Decimal32 x);
 | |
|             _Decimal64 exp10m1d64(_Decimal64 x);
 | |
|             _Decimal128 exp10m1d128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.3p2'></a>
 | |
| <pre>2   The exp10m1 functions compute the base-10 exponential of the argument, minus 1. A range error
 | |
|     occurs if positive finite x is too large or if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.3p3'></a>
 | |
| <pre>3   The exp10m1 functions return 10x − 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.4 [The exp2 functions]</h3>
 | |
| <a name='7.12.6.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double exp2(double x);
 | |
|             float exp2f(float x);
 | |
|             long double exp2l(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 exp2d32(_Decimal32 x);
 | |
|             _Decimal64 exp2d64(_Decimal64 x);
 | |
|             _Decimal128 exp2d128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.4p2'></a>
 | |
| <pre>2   The exp2 functions compute the base-2 exponential of x. A range error occurs if the magnitude of
 | |
|     finite x is too large.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.4p3'></a>
 | |
| <pre>3   The exp2 functions return 2x .
 | |
| </pre>
 | |
| <a name='7.12.6.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.5 [The exp2m1 functions]</h3>
 | |
| <a name='7.12.6.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double exp2m1(double x);
 | |
|              float exp2m1f(float x);
 | |
|              long double exp2m1l(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 exp2m1d32(_Decimal32 x);
 | |
|              _Decimal64 exp2m1d64(_Decimal64 x);
 | |
|              _Decimal128 exp2m1d128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.5p2'></a>
 | |
| <pre>2   The exp2m1 functions compute the base-2 exponential of the argument, minus 1. A range error
 | |
|     occurs if positive finite x is too large or if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.5p3'></a>
 | |
| <pre>3   The exp2m1 functions return 2x − 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.6 [The expm1 functions]</h3>
 | |
| <a name='7.12.6.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double expm1(double x);
 | |
|              float expm1f(float x);
 | |
|              long double expm1l(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 expm1d32(_Decimal32 x);
 | |
|              _Decimal64 expm1d64(_Decimal64 x);
 | |
|              _Decimal128 expm1d128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.6p2'></a>
 | |
| <pre>2   The expm1 functions compute the base-e exponential of the argument, minus 1. A range error occurs
 | |
|     if positive finite x is too large or if nonzero x is too close to zero. <a href='#FOOTNOTE.291'><sup>[291]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.291'>
 | |
| <pre><i><b>Footnote 291)</b> For small magnitude x , expm1(x) is expected to be more accurate than exp(x)-1.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.6.6p3'></a>
 | |
| <pre>3   The expm1 functions return ex − 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.7 [The frexp functions]</h3>
 | |
| <a name='7.12.6.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double frexp(double value, int *p);
 | |
|              float frexpf(float value, int *p);
 | |
|              long double frexpl(long double value, int *p);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 frexpd32(_Decimal32 value, int *p);
 | |
|              _Decimal64 frexpd64(_Decimal64 value, int *p);
 | |
|              _Decimal128 frexpd128(_Decimal128 value, int *p);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.7p2'></a>
 | |
| <pre>2   The frexp functions break a floating-point number into a normalized fraction and an integer
 | |
|     exponent. They store the integer in the int object pointed to by p. If the type of the function is a
 | |
|     standard floating type, the exponent is an integral power of 2. If the type of the function is a decimal
 | |
|     floating type, the exponent is an integral power of 10.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.7p3'></a>
 | |
| <pre>3   If value is not a floating-point number or if the integral power is outside the range of int, the results
 | |
|     are unspecified. Otherwise, the frexp functions return the value x, such that x has a magnitude
 | |
|     in the interval [ 12 , <a href='#FOOTNOTE.1'><sup>[1]</sup></a> or zero, and value equals x × 2*p , when the type of the function is a standard
 | |
|     floating type; or x has a magnitude in the interval [1/10, <a href='#FOOTNOTE.1'><sup>[1]</sup></a> or zero, and value equals x × 10*p , when
 | |
|     the type of the function is a decimal floating type. If value is zero, both parts of the result are zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.1'>
 | |
| <pre><i><b>Footnote 1)</b> This document is designed to promote the portability of C programs among a variety of data-processing systems. It is
 | |
|     intended for use by implementors and programmers. Annex J gives an overview of portability issues that a C program might
 | |
|     encounter.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.1'>
 | |
| <pre><i><b>Footnote 1)</b> This document is designed to promote the portability of C programs among a variety of data-processing systems. It is
 | |
|     intended for use by implementors and programmers. Annex J gives an overview of portability issues that a C program might
 | |
|     encounter.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.6.8'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.8 [The ilogb functions]</h3>
 | |
| <a name='7.12.6.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             int ilogb(double x);
 | |
|             int ilogbf(float x);
 | |
|             int ilogbl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             int ilogbd32(_Decimal32 x);
 | |
|             int ilogbd64(_Decimal64 x);
 | |
|             int ilogbd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.8p2'></a>
 | |
| <pre>2   The ilogb functions extract the exponent of x as a signed int value. If x is zero they compute the
 | |
|     value FP_ILOGB0; if x is infinite they compute the value INT_MAX; if x is a NaN they compute the
 | |
|     value FP_ILOGBNAN; otherwise, they are equivalent to calling the corresponding logb function and
 | |
|     converting the returned value to type int. A domain error or range error may occur if x is zero,
 | |
|     infinite, or NaN. If the correct value is outside the range of the return type, the numeric result is
 | |
|     unspecified and a domain error or range error may occur.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.8p3'></a>
 | |
| <pre>3   The ilogb functions return the exponent of x as a signed int value.
 | |
|     Forward references: the logb functions (<a href='#7.12.6.17'>7.12.6.17</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.9'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.9 [The ldexp functions]</h3>
 | |
| <a name='7.12.6.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double ldexp(double x, int p);
 | |
|             float ldexpf(float x, int p);
 | |
|             long double ldexpl(long double x, int p);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 ldexpd32(_Decimal32 x, int p);
 | |
|             _Decimal64 ldexpd64(_Decimal64 x, int p);
 | |
|             _Decimal128 ldexpd128(_Decimal128 x, int p);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.9p2'></a>
 | |
| <pre>2   The ldexp functions multiply a floating-point number by an integral power of 2 when the type of
 | |
|     the function is a standard floating type, or by an integral power of 10 when the type of the function
 | |
|     is a decimal floating type. A range error occurs for some finite x, depending on p.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.9p3'></a>
 | |
| <pre>3   The ldexp functions return x × 2p when the type of the function is a standard floating type, or return
 | |
|     x × 10p when the type of the function is a decimal floating type.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.10'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.10 [The llogb functions]</h3>
 | |
| <a name='7.12.6.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             long int llogb(double x);
 | |
|             long int llogbf(float x);
 | |
|             long int llogbl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             long int llogbd32(_Decimal32 x);
 | |
|             long int llogbd64(_Decimal64 x);
 | |
|             long int llogbd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.10p2'></a>
 | |
| <pre>2   The llogb functions extract the exponent of x as a signed long int value. If x is zero they compute
 | |
|     the value FP_LLOGB0; if x is infinite they compute the value LONG_MAX; if x is a NaN they compute
 | |
|     the value FP_LLOGBNAN; otherwise, they are equivalent to calling the corresponding logb function
 | |
|     and converting the returned value to type long int. A domain error or range error may occur if x is
 | |
|     zero, infinite, or NaN. If the correct value is outside the range of the return type, the numeric result
 | |
|     is unspecified.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.10p3'></a>
 | |
| <pre>3   The llogb functions return the exponent of x as a signed long int value.
 | |
|     Forward references: the logb functions (<a href='#7.12.6.17'>7.12.6.17</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.11'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.11 [The log functions]</h3>
 | |
| <a name='7.12.6.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double log(double x);
 | |
|             float logf(float x);
 | |
|             long double logl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 logd32(_Decimal32 x);
 | |
|             _Decimal64 logd64(_Decimal64 x);
 | |
|             _Decimal128 logd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.11p2'></a>
 | |
| <pre>2   The log functions compute the base-e (natural) logarithm of x. A domain error occurs if the
 | |
|     argument is less than zero. A pole error may occur if the argument is zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.11p3'></a>
 | |
| <pre>3   The log functions return loge x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.12'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.12 [The log10 functions]</h3>
 | |
| <a name='7.12.6.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double log10(double x);
 | |
|             float log10f(float x);
 | |
|             long double log10l(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 log10d32(_Decimal32 x);
 | |
|             _Decimal64 log10d64(_Decimal64 x);
 | |
|             _Decimal128 log10d128(_Decimal128 x);
 | |
|             #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.12p2'></a>
 | |
| <pre>2   The log10 functions compute the base-10 (common) logarithm of x. A domain error occurs if the
 | |
|     argument is less than zero. A pole error may occur if the argument is zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.12p3'></a>
 | |
| <pre>3   The log10 functions return log10 x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.13'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.13 [The log10p1 functions]</h3>
 | |
| <a name='7.12.6.13p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double log10p1(double x);
 | |
|              float log10p1f(float x);
 | |
|              long double log10p1l(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 log10p1d32(_Decimal32 x);
 | |
|              _Decimal64 log10p1d64(_Decimal64 x);
 | |
|              _Decimal128 log10p1d128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.13p2'></a>
 | |
| <pre>2   The log10p1 functions compute the base-10 logarithm of 1 plus the argument. A domain error
 | |
|     occurs if the argument is less than −1. A pole error may occur if the argument equals −1. A range
 | |
|     error occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.13p3'></a>
 | |
| <pre>3   The log10p1 functions return log10 (1 + x).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.14'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.14 [The log1p and logp1 functions]</h3>
 | |
| <a name='7.12.6.14p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double log1p(double x);
 | |
|              float log1pf(float x);
 | |
|              long double log1pl(long double x);
 | |
|              double logp1(double x);
 | |
|              float logp1f(float x);
 | |
|              long double logp1l(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 log1pd32(_Decimal32 x);
 | |
|              _Decimal64 log1pd64(_Decimal64 x);
 | |
|              _Decimal128 log1pd128(_Decimal128 x);
 | |
|              _Decimal32 logp1d32(_Decimal32 x);
 | |
|              _Decimal64 logp1d64(_Decimal64 x);
 | |
|              _Decimal128 logp1d128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.14p2'></a>
 | |
| <pre>2   The log1p functions are equivalent to the logp1 functions.<a href='#FOOTNOTE.292'><sup>[292]</sup></a> These functions compute the base-e
 | |
|     (natural) logarithm of 1 plus the argument.<a href='#FOOTNOTE.293'><sup>[293]</sup></a> A domain error occurs if the argument is less than
 | |
|     −1. A pole error may occur if the argument equals −1. A range error occurs if nonzero x is too close
 | |
|     to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.292'>
 | |
| <pre><i><b>Footnote 292)</b> The logp1 functions are preferred for name consistency with the log10p1 and log2p1 functions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.293'>
 | |
| <pre><i><b>Footnote 293)</b> For small magnitude x , logp1(x) is expected to be more accurate than log(1 + x).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.6.14p3'></a>
 | |
| <pre>3   The log1p and logp1 functions return loge (1 + x).
 | |
| </pre>
 | |
| <a name='7.12.6.15'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.15 [The log2 functions]</h3>
 | |
| <a name='7.12.6.15p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double log2(double x);
 | |
|             float log2f(float x);
 | |
|             long double log2l(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 log2d32(_Decimal32 x);
 | |
|             _Decimal64 log2d64(_Decimal64 x);
 | |
|             _Decimal128 log2d128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.15p2'></a>
 | |
| <pre>2   The log2 functions compute the base-2 logarithm of x. A domain error occurs if the argument is less
 | |
|     than zero. A pole error may occur if the argument is zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.15p3'></a>
 | |
| <pre>3   The log2 functions return log2 x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.16'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.16 [The log2p1 functions]</h3>
 | |
| <a name='7.12.6.16p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double log2p1(double x);
 | |
|             float log2p1f(float x);
 | |
|             long double log2p1l(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 log2p1d32(_Decimal32 x);
 | |
|             _Decimal64 log2p1d64(_Decimal64 x);
 | |
|             _Decimal128 log2p1d128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.16p2'></a>
 | |
| <pre>2   The log2p1 functions compute the base-2 logarithm of 1 plus the argument. A domain error occurs
 | |
|     if the argument is less than −1. A pole error may occur if the argument equals −1. A range error
 | |
|     occurs if nonzero x is too close to zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.16p3'></a>
 | |
| <pre>3   The log2p1 functions return log2 (1+x).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.17'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.17 [The logb functions]</h3>
 | |
| <a name='7.12.6.17p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double logb(double x);
 | |
|             float logbf(float x);
 | |
|             long double logbl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 logbd32(_Decimal32 x);
 | |
|             _Decimal64 logbd64(_Decimal64 x);
 | |
|             _Decimal128 logbd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.17p2'></a>
 | |
| <pre>2   The logb functions extract the exponent of x, as a signed integer value in floating-point format. If x
 | |
|     is subnormal it is treated as though it were normalized; thus, for positive finite x,
 | |
| 
 | |
|          1 ≤ x × b−logb(x) < b
 | |
|     where b = FLT_RADIX if the type of the function is a standard floating type, or b = 10 if the type of
 | |
|     the function is a decimal floating type. A domain error or pole error may occur if the argument is
 | |
|     zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.17p3'></a>
 | |
| <pre>3   The logb functions return the signed exponent of x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.18'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.18 [The modf functions]</h3>
 | |
| <a name='7.12.6.18p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double modf(double value, double *iptr);
 | |
|              float modff(float value, float *iptr);
 | |
|              long double modfl(long double value, long double *iptr);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 modfd32(_Decimal32 x, _Decimal32 *iptr);
 | |
|              _Decimal64 modfd64(_Decimal64 x, _Decimal64 *iptr);
 | |
|              _Decimal128 modfd128(_Decimal128 x, _Decimal128 *iptr);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.18p2'></a>
 | |
| <pre>2   The modf functions break the argument value into integral and fractional parts, each of which has
 | |
|     the same type and sign as the argument. They store the integral part (in floating-point format) in the
 | |
|     object pointed to by iptr.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.18p3'></a>
 | |
| <pre>3   The modf functions return the signed fractional part of value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.6.19'></a>
 | |
| <hr>
 | |
| <h3>7.12.6.19 [The scalbn and scalbln functions]</h3>
 | |
| <a name='7.12.6.19p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double scalbn(double x, int n);
 | |
|              float scalbnf(float x, int n);
 | |
|              long double scalbnl(long double x, int n);
 | |
|              double scalbln(double x, long int n);
 | |
|              float scalblnf(float x, long int n);
 | |
|              long double scalblnl(long double x, long int n);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 scalbnd32(_Decimal32 x, int n);
 | |
|              _Decimal64 scalbnd64(_Decimal64 x, int n);
 | |
|              _Decimal128 scalbnd128(_Decimal128 x, int n);
 | |
|              _Decimal32 scalblnd32(_Decimal32 x, long int n);
 | |
|              _Decimal64 scalblnd64(_Decimal64 x, long int n);
 | |
|              _Decimal128 scalblnd128(_Decimal128 x, long int n);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.6.19p2'></a>
 | |
| <pre>2   The scalbn and scalbln functions compute x × bn , where b = FLT_RADIX if the type of the function
 | |
|     is a standard floating type, or b = 10 if the type of the function is a decimal floating type. A range
 | |
|     error occurs for some finite x, depending on n.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.6.19p3'></a>
 | |
| <pre>3   The scalbn and scalbln functions return x × bn .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.7 [Power and absolute-value functions]</h3>
 | |
| <a name='7.12.7.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.1 [The cbrt functions]</h3>
 | |
| <a name='7.12.7.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
| 
 | |
|               #include <math.h>
 | |
|                double cbrt(double x);
 | |
|                float cbrtf(float x);
 | |
|                long double cbrtl(long double x);
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 cbrtd32(_Decimal32 x);
 | |
|                _Decimal64 cbrtd64(_Decimal64 x);
 | |
|                _Decimal128 cbrtd128(_Decimal128 x);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.1p2'></a>
 | |
| <pre>2   The cbrt functions compute the real cube root of x.
 | |
| 
 | |
|     Returns
 | |
|                                  1
 | |
| </pre>
 | |
| <a name='7.12.7.1p3'></a>
 | |
| <pre>3   The cbrt functions return x 3 .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.2 [The compoundn functions]</h3>
 | |
| <a name='7.12.7.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdint.h>
 | |
|                #include <math.h>
 | |
|                double compoundn(double x, long long int n);
 | |
|                float compoundnf(float x, long long int n);
 | |
|                long double compoundnl(long double x, long long int n);
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 compoundnd32(_Decimal32 x, long long int n);
 | |
|                _Decimal64 compoundnd64(_Decimal64 x, long long int n);
 | |
|                _Decimal128 compoundnd128(_Decimal128 x, long long int n);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.2p2'></a>
 | |
| <pre>2   The compoundn functions compute 1 plus x, raised to the power n. A domain error occurs if x < −1.
 | |
|     Depending on n, a range error occurs if either positive finite x is too large or if x is too near but not
 | |
|     equal to-1 . A pole error may occur if x equals −1 and n < 0.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.7.2p3'></a>
 | |
| <pre>3   The compoundn functions return (1 + x)n .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.3 [The fabs functions]</h3>
 | |
| <a name='7.12.7.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <math.h>
 | |
|                double fabs(double x);
 | |
|                float fabsf(float x);
 | |
|                long double fabsl(long double x);
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 fabsd32(_Decimal32 x);
 | |
|                _Decimal64 fabsd64(_Decimal64 x);
 | |
|                _Decimal128 fabsd128(_Decimal128 x);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.3p2'></a>
 | |
| <pre>2   The fabs functions compute the absolute value of x.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.7.3p3'></a>
 | |
| <pre>3   The fabs functions return |x|.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.4 [The hypot functions]</h3>
 | |
| <a name='7.12.7.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double hypot(double x, double y);
 | |
|               float hypotf(float x, float y);
 | |
|               long double hypotl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 hypotd32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 hypotd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 hypotd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.4p2'></a>
 | |
| <pre>2   The hypot functions compute the square root of the sum of the squares of x and y, without undue
 | |
|     overflow or underflow. A range error occurs for some finite arguments.
 | |
| </pre>
 | |
| <a name='7.12.7.4p3'></a>
 | |
| <pre>3
 | |
|     Returns
 | |
|                                  p
 | |
| </pre>
 | |
| <a name='7.12.7.4p4'></a>
 | |
| <pre>4   The hypot functions return      x 2 + y2 .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.5 [The pow functions]</h3>
 | |
| <a name='7.12.7.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double pow(double x, double y);
 | |
|               float powf(float x, float y);
 | |
|               long double powl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 powd32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 powd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 powd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.5p2'></a>
 | |
| <pre>2   The pow functions compute x raised to the power y. A domain error occurs if x is finite and less than
 | |
|     zero and y is finite and not an integer value. A domain error may occur if x is zero and y is zero.
 | |
|     Depending on y, a range error occurs if either the magnitude of nonzero finite x is too large or too
 | |
|     near zero. A domain error or pole error may occur if x is zero and y is less than zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.7.5p3'></a>
 | |
| <pre>3   The pow functions return xy .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.6 [The pown functions]</h3>
 | |
| <a name='7.12.7.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdint.h>
 | |
|               #include <math.h>
 | |
|               double pown(double x, long long int n);
 | |
|               float pownf(float x, long long int n);
 | |
|               long double pownl(long double x, long long int n);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 pownd32(_Decimal32 x, long long int n);
 | |
|               _Decimal64 pownd64(_Decimal64 x, long long int n);
 | |
|               _Decimal128 pownd128(_Decimal128 x, long long int n);
 | |
|               #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.6p2'></a>
 | |
| <pre>2   The pown functions compute x raised to the nth power. A pole error may occur if x equals 0 and
 | |
|     n < 0. Depending on n, a range error occurs if either the magnitude of nonzero finite x is too large
 | |
|     or too near zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.7.6p3'></a>
 | |
| <pre>3   The pown functions return xn .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.7 [The powr functions]</h3>
 | |
| <a name='7.12.7.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double powr(double y, double x);
 | |
|               float powrf(float y, float x);
 | |
|               long double powrl(long double y, long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 powrd32(_Decimal32 y, _Decimal32 x);
 | |
|               _Decimal64 powrd64(_Decimal64 y, _Decimal64 x);
 | |
|               _Decimal128 powrd128(_Decimal128 y, _Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.7p2'></a>
 | |
| <pre>2   The powr functions compute x raised to the power y as ey loge x .<a href='#FOOTNOTE.294'><sup>[294]</sup></a> A domain error occurs if x < 0
 | |
|     or if x and y are both zero. Depending on y, a range error occurs if either positive nonzero finite x is
 | |
|     too large or too near zero. A pole error may occur if x equals zero and finite y < 0.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.294'>
 | |
| <pre><i><b>Footnote 294)</b> Restricting the domain to that of the formula ey loge x is intended to better meet expectations for a continuous power
 | |
|     function and to allow implementations with fewer tests for special cases.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.7.7p3'></a>
 | |
| <pre>3   The powr functions return ey loge x .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.8'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.8 [The rootn functions]</h3>
 | |
| <a name='7.12.7.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdint.h>
 | |
|               #include <math.h>
 | |
|               double rootn(double x, long long int n);
 | |
|               float rootnf(float x, long long int n);
 | |
|               long double rootnl(long double x, long long int n);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 rootnd32(_Decimal32 x, long long int n);
 | |
|               _Decimal64 rootnd64(_Decimal64 x, long long int n);
 | |
|               _Decimal128 rootnd128(_Decimal128 x, long long int n);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.8p2'></a>
 | |
| <pre>2   The rootn functions compute the principal nth root of x. A domain error occurs if n is 0 or if x < 0
 | |
|     and n is even. If n is −1, a range error occurs if either the magnitude of nonzero finite x is too large
 | |
|     or too near zero. A pole error may occur if x equals zero and n < 0.
 | |
| 
 | |
|     Returns
 | |
|                                         1
 | |
| </pre>
 | |
| <a name='7.12.7.8p3'></a>
 | |
| <pre>3   The rootn functions return x n .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.9'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.9 [The rsqrt functions]</h3>
 | |
| <a name='7.12.7.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double rsqrt(double x);
 | |
|               float rsqrtf(float x);
 | |
|               long double rsqrtl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 rsqrtd32(_Decimal32 x);
 | |
|               _Decimal64 rsqrtd64(_Decimal64 x);
 | |
|               _Decimal128 rsqrtd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.9p2'></a>
 | |
| <pre>2   The rsqrt functions compute the reciprocal of the nonnegative square root of the argument. A
 | |
|     domain error occurs if the argument is less than zero. A pole error may occur if the argument equals
 | |
|     zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.7.9p3'></a>
 | |
| <pre>3   The rsqrt functions return √1x .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.7.10'></a>
 | |
| <hr>
 | |
| <h3>7.12.7.10 [The sqrt functions]</h3>
 | |
| <a name='7.12.7.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double sqrt(double x);
 | |
|               float sqrtf(float x);
 | |
|               long double sqrtl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 sqrtd32(_Decimal32 x);
 | |
|               _Decimal64 sqrtd64(_Decimal64 x);
 | |
|               _Decimal128 sqrtd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.7.10p2'></a>
 | |
| <pre>2   The sqrt functions compute the nonnegative square root of x. A domain error occurs if the argument
 | |
|     is less than zero.
 | |
| 
 | |
|     Returns
 | |
|                              √
 | |
| </pre>
 | |
| <a name='7.12.7.10p3'></a>
 | |
| <pre>3   The sqrt functions return x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.8'></a>
 | |
| <hr>
 | |
| <h3>7.12.8 [Error and gamma functions]</h3>
 | |
| <a name='7.12.8.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.8.1 [The erf functions]</h3>
 | |
| <a name='7.12.8.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double erf(double x);
 | |
|               float erff(float x);
 | |
|               long double erfl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 erfd32(_Decimal32 x);
 | |
|               _Decimal64 erfd64(_Decimal64 x);
 | |
|               _Decimal128 erfd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.8.1p2'></a>
 | |
| <pre>2   The erf functions compute the error function of x. A range error occurs if nonzero x is too close to
 | |
|     zero.
 | |
| 
 | |
|     Returns
 | |
|                                            Rx −t2
 | |
| </pre>
 | |
| <a name='7.12.8.1p3'></a>
 | |
| <pre>3   The erf functions return erf x = √2π     e dt.
 | |
|                                            0
 | |
| </pre>
 | |
| <a name='7.12.8.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.8.2 [The erfc functions]</h3>
 | |
| <a name='7.12.8.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double erfc(double x);
 | |
|               float erfcf(float x);
 | |
|               long double erfcl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 erfcd32(_Decimal32 x);
 | |
|               _Decimal64 erfcd64(_Decimal64 x);
 | |
|               _Decimal128 erfcd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.8.2p2'></a>
 | |
| <pre>2   The erfc functions compute the complementary error function of x. A range error occurs if positive
 | |
|     finite x is too large.
 | |
| 
 | |
|     Returns
 | |
|                                                          R∞ −t2
 | |
| </pre>
 | |
| <a name='7.12.8.2p3'></a>
 | |
| <pre>3   The erfc functions return erfc x = 1 − erf x = √2π     e dt.
 | |
|                                                          x
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.8.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.8.3 [The lgamma functions]</h3>
 | |
| <a name='7.12.8.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double lgamma(double x);
 | |
|               float lgammaf(float x);
 | |
|               long double lgammal(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 lgammad32(_Decimal32 x);
 | |
|               _Decimal64 lgammad64(_Decimal64 x);
 | |
|               _Decimal128 lgammad128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.8.3p2'></a>
 | |
| <pre>2   The lgamma functions compute the natural logarithm of the absolute value of gamma of x. A range
 | |
|     error occurs if positive finite x is too large. A pole error may occur if x is a negative integer or zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.8.3p3'></a>
 | |
| <pre>3   The lgamma functions return loge |Γ(x)|.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.8.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.8.4 [The tgamma functions]</h3>
 | |
| <a name='7.12.8.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double tgamma(double x);
 | |
|               float tgammaf(float x);
 | |
|               long double tgammal(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 tgammad32(_Decimal32 x);
 | |
|               _Decimal64 tgammad64(_Decimal64 x);
 | |
|               _Decimal128 tgammad128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.8.4p2'></a>
 | |
| <pre>2   The tgamma functions compute the gamma function of x. A domain error or pole error may occur
 | |
|     if x is a negative integer or zero. A range error occurs for some negative finite x less than zero, if
 | |
|     positive finite x is too large, or nonzero x is too close to zero.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.8.4p3'></a>
 | |
| <pre>3   The tgamma functions return Γ(x).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9'></a>
 | |
| <hr>
 | |
| <h3>7.12.9 [Nearest integer functions]</h3>
 | |
| <a name='7.12.9.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.1 [The ceil functions]</h3>
 | |
| <a name='7.12.9.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double ceil(double x);
 | |
|              float ceilf(float x);
 | |
|              long double ceill(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 ceild32(_Decimal32 x);
 | |
|              _Decimal64 ceild64(_Decimal64 x);
 | |
|              _Decimal128 ceild128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.1p2'></a>
 | |
| <pre>2   The ceil functions compute the smallest integer value not less than x.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.1p3'></a>
 | |
| <pre>3   The ceil functions return ⌈x⌉, expressed as a floating-point number.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.2 [The floor functions]</h3>
 | |
| <a name='7.12.9.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double floor(double x);
 | |
|              float floorf(float x);
 | |
|              long double floorl(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 floord32(_Decimal32 x);
 | |
|              _Decimal64 floord64(_Decimal64 x);
 | |
|              _Decimal128 floord128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.2p2'></a>
 | |
| <pre>2   The floor functions compute the largest integer value not greater than x.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.2p3'></a>
 | |
| <pre>3   The floor functions return ⌊x⌋, expressed as a floating-point number.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.3 [The nearbyint functions]</h3>
 | |
| <a name='7.12.9.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <math.h>
 | |
|              double nearbyint(double x);
 | |
|              float nearbyintf(float x);
 | |
|              long double nearbyintl(long double x);
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 nearbyintd32(_Decimal32 x);
 | |
|              _Decimal64 nearbyintd64(_Decimal64 x);
 | |
|              _Decimal128 nearbyintd128(_Decimal128 x);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.3p2'></a>
 | |
| <pre>2   The nearbyint functions round their argument to an integer value in floating-point format, using
 | |
|     the current rounding direction and without raising the "inexact" floating-point exception.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.3p3'></a>
 | |
| <pre>3   The nearbyint functions return the rounded integer value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.4 [The rint functions]</h3>
 | |
| <a name='7.12.9.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double rint(double x);
 | |
|             float rintf(float x);
 | |
|             long double rintl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 rintd32(_Decimal32 x);
 | |
|             _Decimal64 rintd64(_Decimal64 x);
 | |
|             _Decimal128 rintd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.4p2'></a>
 | |
| <pre>2   The rint functions differ from the nearbyint functions (<a href='#7.12.9.3'>7.12.9.3</a>) only in that the rint functions
 | |
|     may raise the "inexact" floating-point exception if the result differs in value from the argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.4p3'></a>
 | |
| <pre>3   The rint functions return the rounded integer value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.5 [The lrint and llrint functions]</h3>
 | |
| <a name='7.12.9.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             long int lrint(double x);
 | |
|             long int lrintf(float x);
 | |
|             long int lrintl(long double x);
 | |
|             long long int llrint(double x);
 | |
|             long long int llrintf(float x);
 | |
|             long long int llrintl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             long int lrintd32(_Decimal32 x);
 | |
|             long int lrintd64(_Decimal64 x);
 | |
|             long int lrintd128(_Decimal128 x);
 | |
|             long long int llrintd32(_Decimal32 x);
 | |
|             long long int llrintd64(_Decimal64 x);
 | |
|             long long int llrintd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.5p2'></a>
 | |
| <pre>2   The lrint and llrint functions round their argument to the nearest integer value, rounding
 | |
|     according to the current rounding direction. If the rounded value is outside the range of the return
 | |
|     type, the numeric result is unspecified and a domain error or range error may occur.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.5p3'></a>
 | |
| <pre>3   The lrint and llrint functions return the rounded integer value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.6 [The round functions]</h3>
 | |
| <a name='7.12.9.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double round(double x);
 | |
|             float roundf(float x);
 | |
|             long double roundl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 roundd32(_Decimal32 x);
 | |
|             _Decimal64 roundd64(_Decimal64 x);
 | |
|             _Decimal128 roundd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.6p2'></a>
 | |
| <pre>2   The round functions round their argument to the nearest integer value in floating-point format,
 | |
|     rounding halfway cases away from zero, regardless of the current rounding direction.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.6p3'></a>
 | |
| <pre>3   The round functions return the rounded integer value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.7 [The lround and llround functions]</h3>
 | |
| <a name='7.12.9.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             long int lround(double x);
 | |
|             long int lroundf(float x);
 | |
|             long int lroundl(long double x);
 | |
|             long long int llround(double x);
 | |
|             long long int llroundf(float x);
 | |
|             long long int llroundl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             long int lroundd32(_Decimal32 x);
 | |
|             long int lroundd64(_Decimal64 x);
 | |
|             long int lroundd128(_Decimal128 x);
 | |
|             long long int llroundd32(_Decimal32 x);
 | |
|             long long int llroundd64(_Decimal64 x);
 | |
|             long long int llroundd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.7p2'></a>
 | |
| <pre>2   The lround and llround functions round their argument to the nearest integer value, rounding
 | |
|     halfway cases away from zero, regardless of the current rounding direction. If the rounded value is
 | |
|     outside the range of the return type, the numeric result is unspecified and a domain error or range
 | |
|     error may occur.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.7p3'></a>
 | |
| <pre>3   The lround and llround functions return the rounded integer value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.8'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.8 [The roundeven functions]</h3>
 | |
| <a name='7.12.9.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double roundeven(double x);
 | |
|             float roundevenf(float x);
 | |
|             long double roundevenl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 roundevend32(_Decimal32 x);
 | |
|             _Decimal64 roundevend64(_Decimal64 x);
 | |
|             _Decimal128 roundevend128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.8p2'></a>
 | |
| <pre>2   The roundeven functions round their argument to the nearest integer value in floating-point format,
 | |
|     rounding halfway cases to even (that is, to the nearest value that is an even integer), regardless of
 | |
|     the current rounding direction.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.8p3'></a>
 | |
| <pre>3   The roundeven functions return the rounded integer value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.9'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.9 [The trunc functions]</h3>
 | |
| <a name='7.12.9.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double trunc(double x);
 | |
|             float truncf(float x);
 | |
|             long double truncl(long double x);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 truncd32(_Decimal32 x);
 | |
|             _Decimal64 truncd64(_Decimal64 x);
 | |
|             _Decimal128 truncd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.9p2'></a>
 | |
| <pre>2   The trunc functions round their argument to the integer value, in floating format, nearest to but no
 | |
|     larger in magnitude than the argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.9p3'></a>
 | |
| <pre>3   The trunc functions return the truncated integer value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.10'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.10 [The fromfp and ufromfp functions]</h3>
 | |
| <a name='7.12.9.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdint.h>
 | |
|             #include <math.h>
 | |
|             double fromfp(double x, int rnd, unsigned int width);
 | |
|             float fromfpf(float x, int rnd, unsigned int width);
 | |
|             long double fromfpl(long double x, int rnd, unsigned int width);
 | |
|             double ufromfp(double x, int rnd, unsigned int width);
 | |
|             float ufromfpf(float x, int rnd, unsigned int width);
 | |
|             long double ufromfpl(long double x, int rnd, unsigned int width);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 fromfpd32(_Decimal32 x, int rnd, unsigned int width);
 | |
|             _Decimal64 fromfpd64(_Decimal64 x, int rnd, unsigned int width);
 | |
|             _Decimal128 fromfpd128(_Decimal128 x, int rnd, unsigned int width);
 | |
|             _Decimal32 ufromfpd32(_Decimal32 x, int rnd, unsigned int width);
 | |
|             _Decimal64 ufromfpd64(_Decimal64 x, int rnd, unsigned int width);
 | |
|             _Decimal128 ufromfpd128(_Decimal128 x, int rnd, unsigned int width);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.10p2'></a>
 | |
| <pre>2   The fromfp and ufromfp functions round x, using the math rounding direction indicated by rnd, to
 | |
|     a signed or unsigned integer, respectively. If width is nonzero and the resulting integer is within the
 | |
|     range
 | |
| 
 | |
|       — [−2(width−1) , 2(width−1) − 1], for signed
 | |
| 
 | |
|       — [0, 2width − 1], for unsigned
 | |
| 
 | |
|     then the functions return the integer value (represented in floating type). Otherwise, if width is
 | |
|     zero or x does not round to an integer within the range, the functions return a NaN (of the type of
 | |
|     the x argument, if available), else the value of x, and a domain error occurs. If the value of the
 | |
|     rnd argument is not equal to the value of a math rounding direction macro (<a href='#7.12'>7.12</a>), the direction of
 | |
|     rounding is unspecified. The fromfp and ufromfp functions do not raise the "inexact" floating-point
 | |
|     exception.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.10p3'></a>
 | |
| <pre>3   The fromfp and ufromfp functions return the rounded integer value.
 | |
| </pre>
 | |
| <a name='7.12.9.10p4'></a>
 | |
| <pre>4   EXAMPLE Upward rounding of double x to type int, without raising the "inexact" floating-point exception, is achieved by
 | |
| 
 | |
|               (int)fromfp(x, FP_INT_UPWARD, INT_WIDTH)
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.10p5'></a>
 | |
| <pre>5   EXAMPLE Unsigned integer wrapping is not performed in
 | |
| 
 | |
|               ufromfp(-3.0, FP_INT_UPWARD, UINT_WIDTH) /* domain error */
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.9.11'></a>
 | |
| <hr>
 | |
| <h3>7.12.9.11 [The fromfpx and ufromfpx functions]</h3>
 | |
| <a name='7.12.9.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdint.h>
 | |
|               #include <math.h>
 | |
|               double fromfpx(double x, int rnd, unsigned int width);
 | |
|               float fromfpxf(float x, int rnd, unsigned int width);
 | |
|               long double fromfpxl(long double x, int rnd, unsigned int width);
 | |
|               double ufromfpx(double x, int rnd, unsigned int width);
 | |
|               float ufromfpxf(float x, int rnd, unsigned int width);
 | |
|               long double ufromfpxl(long double x, int rnd, unsigned int width);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fromfpxd32(_Decimal32 x, int rnd, unsigned int width);
 | |
|               _Decimal64 fromfpxd64(_Decimal64 x, int rnd, unsigned int width);
 | |
|               _Decimal128 fromfpxd128(_Decimal128 x, int rnd, unsigned int width);
 | |
|               _Decimal32 ufromfpxd32(_Decimal32 x, int rnd, unsigned int width);
 | |
|               _Decimal64 ufromfpxd64(_Decimal64 x, int rnd, unsigned int width);
 | |
|               _Decimal128 ufromfpxd128(_Decimal128 x, int rnd, unsigned int width);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.9.11p2'></a>
 | |
| <pre>2   The fromfpx and ufromfpx functions differ from the fromfp and ufromfp functions, respectively,
 | |
|     only in that the fromfpx and ufromfpx functions raise the "inexact" floating-point exception if a
 | |
|     rounded result not exceeding the specified width differs in value from the argument x.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.9.11p3'></a>
 | |
| <pre>3   The fromfpx and ufromfpx functions return the rounded integer value.
 | |
| </pre>
 | |
| <a name='7.12.9.11p4'></a>
 | |
| <pre>4   NOTE Conversions to integer types that are not required to raise the inexact exception can be done simply by rounding to
 | |
|     integral value in floating type and then converting to the target integer type. For example, the conversion of long double x
 | |
|     to uint64_t, using upward rounding, is done by
 | |
| 
 | |
|               (uint64_t)ceill(x)
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.10'></a>
 | |
| <hr>
 | |
| <h3>7.12.10 [Remainder functions]</h3>
 | |
| <a name='7.12.10.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.10.1 [The fmod functions]</h3>
 | |
| <a name='7.12.10.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double fmod(double x, double y);
 | |
|               float fmodf(float x, float y);
 | |
|               long double fmodl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fmodd32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 fmodd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 fmodd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.10.1p2'></a>
 | |
| <pre>2   The fmod functions compute the floating-point remainder of x/y.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.10.1p3'></a>
 | |
| <pre>3   The fmod functions return the value x − ny, for some integer n such that, if y is nonzero, the result
 | |
|     has the same sign as x and magnitude less than the magnitude of y. If y is zero, whether a domain
 | |
|     error occurs or the fmod functions return zero is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.10.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.10.2 [The remainder functions]</h3>
 | |
| <a name='7.12.10.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <math.h>
 | |
|                double remainder(double x, double y);
 | |
|                float remainderf(float x, float y);
 | |
|                long double remainderl(long double x, long double y);
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 remainderd32(_Decimal32 x, _Decimal32 y);
 | |
|                _Decimal64 remainderd64(_Decimal64 x, _Decimal64 y);
 | |
|                _Decimal128 remainderd128(_Decimal128 x, _Decimal128 y);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.10.2p2'></a>
 | |
| <pre>2   The remainder functions compute the remainder x REM y required by IEC 60559. <a href='#FOOTNOTE.295'><sup>[295]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.295'>
 | |
| <pre><i><b>Footnote 295)</b> "When y ̸= 0, the remainder r = x REM y is defined regardless of the rounding mode by the mathematical relation
 | |
|     r = x − ny, where n is the integer nearest the exact value of xy
 | |
|                                                                      ; whenever |n − x
 | |
|                                                                                      y
 | |
|                                                                                        | = 12 , then n is even. If r = 0, its sign shall
 | |
|     be that of x." This definition is applicable for all implementations.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.10.2p3'></a>
 | |
| <pre>3   The remainder functions return x REM y. If y is zero, whether a domain error occurs or the functions
 | |
|     return zero is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.10.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.10.3 [The remquo functions]</h3>
 | |
| <a name='7.12.10.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <math.h>
 | |
|                double remquo(double x, double y, int *quo);
 | |
|                float remquof(float x, float y, int *quo);
 | |
|                long double remquol(long double x, long double y, int *quo);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.10.3p2'></a>
 | |
| <pre>2   The remquo functions compute the same remainder as the remainder functions. In the object pointed
 | |
|     to by quo they store a value whose sign is the sign of x/y and whose magnitude is congruent modulo
 | |
|     2n to the magnitude of the integral quotient of x/y, where n is an implementation-defined integer
 | |
|     greater than or equal to 3.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.10.3p3'></a>
 | |
| <pre>3   The remquo functions return x REM y. If y is zero, the value stored in the object pointed to by quo
 | |
|     is unspecified and whether a domain error occurs or the functions return zero is implementation-
 | |
|     defined.
 | |
| </pre>
 | |
| <a name='7.12.10.3p4'></a>
 | |
| <pre>4   NOTE There are no decimal floating-point versions of the remquo functions.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.11'></a>
 | |
| <hr>
 | |
| <h3>7.12.11 [Manipulation functions]</h3>
 | |
| <a name='7.12.11.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.11.1 [The copysign functions]</h3>
 | |
| <a name='7.12.11.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <math.h>
 | |
|                double copysign(double x, double y);
 | |
|             float copysignf(float x, float y);
 | |
|             long double copysignl(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 copysignd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 copysignd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 copysignd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.11.1p2'></a>
 | |
| <pre>2   The copysign functions produce a value with the magnitude of x and the sign of y. If x or y is an
 | |
|     unsigned value, the sign (if any) of the result is implementation-defined. On implementations that
 | |
|     represent a signed zero but do not treat negative zero consistently in arithmetic operations, the
 | |
|     copysign functions should regard the sign of zero as positive.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.11.1p3'></a>
 | |
| <pre>3   The copysign functions return a value with the magnitude of x and the sign of y.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.11.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.11.2 [The nan functions]</h3>
 | |
| <a name='7.12.11.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double nan(const char *tagp);
 | |
|             float nanf(const char *tagp);
 | |
|             long double nanl(const char *tagp);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 nand32(const char *tagp);
 | |
|             _Decimal64 nand64(const char *tagp);
 | |
|             _Decimal128 nand128(const char *tagp);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.11.2p2'></a>
 | |
| <pre>2   The nan, nanf, and nanl functions convert the string pointed to by tagp according to the following
 | |
|     rules. The call nan("n-char-sequence") is equivalent to strtod("NAN(n-char-sequence)", nullptr);
 | |
|     the call nan("") is equivalent to strtod("NAN()", nullptr). If tagp does not point to an empty
 | |
|     string or an n-char sequence, the call is equivalent to strtod("NAN", nullptr). Calls to nanf and
 | |
|     nanl are equivalent to the corresponding calls to strtof and strtold.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.11.2p3'></a>
 | |
| <pre>3   The nan functions return a quiet NaN, if available, with content indicated through tagp. If the
 | |
|     implementation does not support quiet NaNs, the functions return zero.
 | |
|     Forward references: the strtod, strtof, and strtold functions (<a href='#7.24.1.5'>7.24.1.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.11.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.11.3 [The nextafter functions]</h3>
 | |
| <a name='7.12.11.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double nextafter(double x, double y);
 | |
|             float nextafterf(float x, float y);
 | |
|             long double nextafterl(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 nextafterd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 nextafterd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 nextafterd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.11.3p2'></a>
 | |
| <pre>2   The nextafter functions determine the next representable value, in the type of the function, after x
 | |
|     in the direction of y, where x and y are first converted to the type of the function<a href='#FOOTNOTE.296'><sup>[296]</sup></a> . The nextafter
 | |
|     functions return y if x equals y.
 | |
|     A range error occurs if the magnitude of x is the largest finite value representable in the type and the
 | |
|     result is infinite or not representable in the type.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.296'>
 | |
| <pre><i><b>Footnote 296)</b> The argument values are converted to the type of the function, even by a macro implementation of the function.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.11.3p3'></a>
 | |
| <pre>3   The nextafter functions return the next representable value in the specified format after x in the
 | |
|     direction of y.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.11.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.11.4 [The nexttoward functions]</h3>
 | |
| <a name='7.12.11.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double nexttoward(double x, long double y);
 | |
|               float nexttowardf(float x, long double y);
 | |
|               long double nexttowardl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 nexttowardd32(_Decimal32 x, _Decimal128 y);
 | |
|               _Decimal64 nexttowardd64(_Decimal64 x, _Decimal128 y);
 | |
|               _Decimal128 nexttowardd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.11.4p2'></a>
 | |
| <pre>2   The nexttoward functions are equivalent to the nextafter functions except that the second param-
 | |
|     eter has type long double or _Decimal128 and the functions return y converted to the type of the
 | |
|     function if x equals y.<a href='#FOOTNOTE.297'><sup>[297]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.297'>
 | |
| <pre><i><b>Footnote 297)</b> The result of the nexttoward functions is determined in the type of the function, without loss of range or precision in a
 | |
|     floating second argument.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.11.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.11.5 [The nextup functions]</h3>
 | |
| <a name='7.12.11.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double nextup(double x);
 | |
|               float nextupf(float x);
 | |
|               long double nextupl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 nextupd32(_Decimal32 x);
 | |
|               _Decimal64 nextupd64(_Decimal64 x);
 | |
|               _Decimal128 nextupd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.11.5p2'></a>
 | |
| <pre>2   The nextup functions determine the next representable value, in the type of the function, greater
 | |
|     than x. If x is the negative number of least magnitude in the type of x, nextup(x) is −0 if the
 | |
|     type has signed zeros and is 0 otherwise. If x is zero, nextup(x) is the positive number of least
 | |
|     magnitude in the type of x. If x is the positive number (finite or infinite) or maximum magnitude in
 | |
|     the type, nextup(x) is x.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.11.5p3'></a>
 | |
| <pre>3   The nextup functions return the next representable value in the specified type greater than x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.11.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.11.6 [The nextdown functions]</h3>
 | |
| <a name='7.12.11.6p1'></a>
 | |
| <pre>1     Synopsis
 | |
|              #include <math.h>
 | |
|               double nextdown(double x);
 | |
|               float nextdownf(float x);
 | |
|               long double nextdownl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 nextdownd32(_Decimal32 x);
 | |
|               _Decimal64 nextdownd64(_Decimal64 x);
 | |
|               _Decimal128 nextdownd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.11.6p2'></a>
 | |
| <pre>2   The nextdown functions determine the next representable value, in the type of the function, less than
 | |
|     x . If x is the positive number of least magnitude in the type of x , nextdown(x) is +0 if the type has
 | |
|     signed zeros and is 0 otherwise. If x is zero, nextdown(x) is the negative number of least magnitude
 | |
|     in the type of x. If x is the negative number (finite or infinite) of maximum magnitude in the type,
 | |
|     nextdown(x) is x .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.11.6p3'></a>
 | |
| <pre>3   The nextdown functions return the next representable value in the specified type less than x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.11.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.11.7 [The canonicalize functions]</h3>
 | |
| <a name='7.12.11.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int canonicalize(double * cx, const double * x);
 | |
|               int canonicalizef(float * cx, const float * x);
 | |
|               int canonicalizel(long double * cx, const long double * x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               int canonicalized32(_Decimal32 cx, const _Decimal32 * x);
 | |
|               int canonicalized64(_Decimal64 cx, const _Decimal64 * x);
 | |
|               int canonicalized128(_Decimal128 cx, const _Decimal128 * x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.11.7p2'></a>
 | |
| <pre>2   The canonicalize functions attempt to produce a canonical version of the floating-point repre-
 | |
|     sentation in the object pointed to by the argument x, as if to a temporary object of the specified
 | |
|     type, and store the canonical result in the object pointed to by the argument cx.<a href='#FOOTNOTE.298'><sup>[298]</sup></a> If the input *x
 | |
|     is a signaling NaN, the canonicalize functions are intended to store a canonical quiet NaN. If a
 | |
|     canonical result is not produced the object pointed to by cx is unchanged.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.298'>
 | |
| <pre><i><b>Footnote 298)</b> Arguments x and cx may point to the same object.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.11.7p3'></a>
 | |
| <pre>3   The canonicalize functions return zero if a canonical result is stored in the object pointed to by cx.
 | |
|     Otherwise they return a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12'></a>
 | |
| <hr>
 | |
| <h3>7.12.12 [Maximum, minimum, and positive difference functions]</h3>
 | |
| <a name='7.12.12.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.1 [The fdim functions]</h3>
 | |
| <a name='7.12.12.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double fdim(double x, double y);
 | |
|               float fdimf(float x, float y);
 | |
|               long double fdiml(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fdimd32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 fdimd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 fdimd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.1p2'></a>
 | |
| <pre>2   The fdim functions determine the positive difference between their arguments:
 | |
|          (
 | |
|            x − y if x > y
 | |
|            +0     if x ≤ y
 | |
| 
 | |
|     A range error may occur.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.1p3'></a>
 | |
| <pre>3   The fdim functions return the positive difference value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.2 [The fmax functions]</h3>
 | |
| <a name='7.12.12.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double fmax(double x, double y);
 | |
|               float fmaxf(float x, float y);
 | |
|               long double fmaxl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fmaxd32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 fmaxd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 fmaxd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.2p2'></a>
 | |
| <pre>2   The fmax functions determine the maximum numeric value of their arguments.<a href='#FOOTNOTE.299'><sup>[299]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.299'>
 | |
| <pre><i><b>Footnote 299)</b> Quiet NaN arguments are treated as missing data: if one argument is a quiet NaN and the other numeric, then the fmax
 | |
|     functions choose the numeric value. See <a href='#F.10.9.2'>F.10.9.2</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.12.2p3'></a>
 | |
| <pre>3   The fmax functions return the maximum numeric value of their arguments.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.3 [The fmin functions]</h3>
 | |
| <a name='7.12.12.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double fmin(double x, double y);
 | |
|               float fminf(float x, float y);
 | |
|               long double fminl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fmind32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 fmind64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 fmind128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.3p2'></a>
 | |
| <pre>2   The fmin functions determine the minimum numeric value of their arguments. <a href='#FOOTNOTE.300'><sup>[300]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.300'>
 | |
| <pre><i><b>Footnote 300)</b> The fmin functions are analogous to the fmax functions in their treatment of quiet NaNs.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.12.3p3'></a>
 | |
| <pre>3   The fmin functions return the minimum numeric value of their arguments.
 | |
| </pre>
 | |
| <a name='7.12.12.3p4'></a>
 | |
| <pre>4   NOTE 1 The fmax and fmin functions are similar to the fmaximum_num and fminimum_num functions, though may differ in
 | |
|     which signed zero is returned when the arguments are differently signed zeros and in their treatment of signaling NaNs
 | |
|     (see <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| </pre>
 | |
| <a name='7.12.12.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.4 [The fmaximum functions]</h3>
 | |
| <a name='7.12.12.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double fmaximum(double x, double y);
 | |
|             float fmaximumf(float x, float y);
 | |
|             long double fmaximuml(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 fmaximumd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 fmaximumd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 fmaximumd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.4p2'></a>
 | |
| <pre>2   The fmaximum functions determine the maximum value of their arguments. For these functions, +0
 | |
|     is considered greater than −0. These functions differ from the fmaximum_num functions only in their
 | |
|     treatment of NaN arguments (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.4p3'></a>
 | |
| <pre>3   The fmaximum functions return the maximum value of their arguments.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.5 [The fminimum functions]</h3>
 | |
| <a name='7.12.12.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double fminimum(double x, double y);
 | |
|             float fminimumf(float x, float y);
 | |
|             long double fminimuml(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 fminimumd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 fminimumd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 fminimumd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.5p2'></a>
 | |
| <pre>2   The fminimum functions determine the minimum value of their arguments. For these functions, −0
 | |
|     is considered less than +0. These functions differ from the fminimum_num functions only in their
 | |
|     treatment of NaN arguments (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.5p3'></a>
 | |
| <pre>3   The fminimum functions return the minimum value of their arguments.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.6 [The fmaximum_mag functions]</h3>
 | |
| <a name='7.12.12.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double fmaximum_mag(double x, double y);
 | |
|             float fmaximum_magf(float x, float y);
 | |
|             long double fmaximum_magl(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 fmaximum_magd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 fmaximum_magd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 fmaximum_magd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.6p2'></a>
 | |
| <pre>2   The fmaximum_mag functions determine the value of the argument of maximum magnitude:
 | |
|     x if |x | > |y|, y if |y| > |x |, and fmaximum(x, y) otherwise. These functions differ from the
 | |
|     fmaximum_mag_num functions only in their treatment of NaN arguments (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.6p3'></a>
 | |
| <pre>3   The fmaximum_mag functions return the value of the argument of maximum magnitude.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.7 [The fminimum_mag functions]</h3>
 | |
| <a name='7.12.12.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double fminimum_mag(double x, double y);
 | |
|             float fminimum_magf(float x, float y);
 | |
|             long double fminimum_magl(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 fminimum_magd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 fminimum_magd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 fminimum_magd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.7p2'></a>
 | |
| <pre>2   The fminimum_mag functions determine the value of the argument of minimum magnitude:
 | |
|     x if |x | < |y|, y if |y| < |x |, and fminimum(x, y) otherwise. These functions differ from the
 | |
|     fminimum_mag_num functions only in their treatment of NaN arguments (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.7p3'></a>
 | |
| <pre>3   The fminimum_mag functions return the value of the argument of minimum magnitude.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.8'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.8 [The fmaximum_num functions]</h3>
 | |
| <a name='7.12.12.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double fmaximum_num(double x, double y);
 | |
|             float fmaximum_numf(float x, float y);
 | |
|             long double fmaximum_numl(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 fmaximum_numd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 fmaximum_numd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 fmaximum_numd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.8p2'></a>
 | |
| <pre>2   The fmaximum_num functions determine the maximum value of their numeric arguments. They
 | |
|     determine the number if one argument is a number and the other is a NaN. These functions differ
 | |
|     from the fmaximum functions only in their treatment of NaN arguments (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.8p3'></a>
 | |
| <pre>3   The fmaximum_num functions return the maximum value of their numeric arguments.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.9'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.9 [The fminimum_num functions]</h3>
 | |
| <a name='7.12.12.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             double fminimum_num(double x, double y);
 | |
|             float fminimum_numf(float x, float y);
 | |
|             long double fminimum_numl(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 fminimum_numd32(_Decimal32 x, _Decimal32 y);
 | |
|             _Decimal64 fminimum_numd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal128 fminimum_numd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.9p2'></a>
 | |
| <pre>2   The fminimum_num functions determine the minimum value of their numeric arguments. They
 | |
|     determine the number if one argument is a number and the other is a NaN. These functions differ
 | |
|     from the fminimum functions only in their treatment of NaN arguments (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.9p3'></a>
 | |
| <pre>3   The fminimum_num functions return the minimum value of their numeric arguments.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.10'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.10 [The fmaximum_mag_num functions]</h3>
 | |
| <a name='7.12.12.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double fmaximum_mag_num(double x, double y);
 | |
|               float fmaximum_mag_numf(float x, float y);
 | |
|               long double fmaximum_mag_numl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fmaximum_mag_numd32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 fmaximum_mag_numd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 fmaximum_mag_numd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.10p2'></a>
 | |
| <pre>2   The fmaximum_mag_num functions determine the value of a numeric argument of maximum mag-
 | |
|     nitude. They determine the number if one argument is a number and the other is a NaN. These
 | |
|     functions differ from the fmaximum_mag functions only in their treatment of NaN arguments
 | |
|     (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.10p3'></a>
 | |
| <pre>3   The fmaximum_mag_num functions return the value of a numeric argument of maximum magnitude.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.12.11'></a>
 | |
| <hr>
 | |
| <h3>7.12.12.11 [The fminimum_mag_num functions]</h3>
 | |
| <a name='7.12.12.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double fminimum_mag_num(double x, double y);
 | |
|               float fminimum_mag_numf(float x, float y);
 | |
|               long double fminimum_mag_numl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fminimum_mag_numd32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 fminimum_mag_numd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 fminimum_mag_numd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.12.11p2'></a>
 | |
| <pre>2   The fminimum_mag_num functions determine the value of a numeric argument of minimum mag-
 | |
|     nitude. They determine the number if one argument is a number and the other is a NaN. These
 | |
|     functions differ from the fminimum_mag functions only in their treatment of NaN arguments
 | |
|     (see <a href='#F.10.9.4'>F.10.9.4</a>, <a href='#F.10.9.5'>F.10.9.5</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.12.11p3'></a>
 | |
| <pre>3   The fminimum_mag_num functions return the value of a numeric argument of mimum minagnitude.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.13'></a>
 | |
| <hr>
 | |
| <h3>7.12.13 [Fused multiply-add]</h3>
 | |
| <a name='7.12.13.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.13.1 [The fma functions]</h3>
 | |
| <a name='7.12.13.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               double fma(double x, double y, double z);
 | |
|               float fmaf(float x, float y, float z);
 | |
|               long double fmal(long double x, long double y, long double z);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 fmad32(_Decimal32 x, _Decimal32 y, _Decimal32 z);
 | |
|               _Decimal64 fmad64(_Decimal64 x, _Decimal64 y, _Decimal64 z);
 | |
|               _Decimal128 fmad128(_Decimal128 x, _Decimal128 y, _Decimal128 z);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.13.1p2'></a>
 | |
| <pre>2   The fma functions compute (x × y) + z, rounded as one ternary operation: they compute the value
 | |
|     (as if) to infinite precision and round once to the result format, according to the current rounding
 | |
|     mode. A range error occurs for some finite arguments.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.13.1p3'></a>
 | |
| <pre>3   The fma functions return (x × y) + z, rounded as one ternary operation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.14'></a>
 | |
| <hr>
 | |
| <h3>7.12.14 [Functions that round result to narrower type]</h3>
 | |
| <a name='7.12.14p1'></a>
 | |
| <pre>1   The functions in this subclause round their results to a type typically narrower<a href='#FOOTNOTE.301'><sup>[301]</sup></a> than the parameter
 | |
|     types.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.301'>
 | |
| <pre><i><b>Footnote 301)</b> In some cases the destination type might not be narrower than the parameter types. For example, double might not be
 | |
|     narrower than long double.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.14.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.14.1 [Add and round to narrower type]</h3>
 | |
| <a name='7.12.14.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               float fadd(double x, double y);
 | |
|               float faddl(long double x, long double y);
 | |
|               double daddl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 d32addd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal32 d32addd128(_Decimal128 x, _Decimal128 y);
 | |
|               _Decimal64 d64addd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.14.1p2'></a>
 | |
| <pre>2   These functions compute the sum of x + y, rounded to the type of the function. They compute
 | |
|     the sum (as if) to infinite precision and round once to the result format, according to the current
 | |
|     rounding mode. A range error occurs for some finite arguments. A domain error may occur for
 | |
|     infinite arguments.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.14.1p3'></a>
 | |
| <pre>3   These functions return the sum of x + y, rounded to the type of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.14.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.14.2 [Subtract and round to narrower type]</h3>
 | |
| <a name='7.12.14.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               float fsub(double x, double y);
 | |
|               float fsubl(long double x, long double y);
 | |
|               double dsubl(long double x, long double y);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 d32subd64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal32 d32subd128(_Decimal128 x, _Decimal128 y);
 | |
|               _Decimal64 d64subd128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.14.2p2'></a>
 | |
| <pre>2   These functions compute the difference of x − y, rounded to the type of the function. They compute
 | |
|     the difference (as if) to infinite precision and round once to the result format, according to the current
 | |
|     rounding mode. A range error occurs for some finite arguments. A domain error may occur for
 | |
|     infinite arguments.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.14.2p3'></a>
 | |
| <pre>3   These functions return the difference of x − y, rounded to the type of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.14.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.14.3 [Multiply and round to narrower type]</h3>
 | |
| <a name='7.12.14.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             float fmul(double x, double y);
 | |
|             float fmull(long double x, long double y);
 | |
|             double dmull(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 d32muld64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal32 d32muld128(_Decimal128 x, _Decimal128 y);
 | |
|             _Decimal64 d64muld128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.14.3p2'></a>
 | |
| <pre>2   These functions compute the product x × y, rounded to the type of the function. They compute the
 | |
|     product (as if) to infinite precision and round once to the result format, according to the current
 | |
|     rounding mode. A range error occurs for some finite arguments. A domain error occurs for one
 | |
|     infinite argument and one zero argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.14.3p3'></a>
 | |
| <pre>3   These functions return the product of x × y, rounded to the type of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.14.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.14.4 [Divide and round to narrower type]</h3>
 | |
| <a name='7.12.14.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             float fdiv(double x, double y);
 | |
|             float fdivl(long double x, long double y);
 | |
|             double ddivl(long double x, long double y);
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 d32divd64(_Decimal64 x, _Decimal64 y);
 | |
|             _Decimal32 d32divd128(_Decimal128 x, _Decimal128 y);
 | |
|             _Decimal64 d64divd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.14.4p2'></a>
 | |
| <pre>2   These functions compute the quotient x ÷ y, rounded to the type of the function. They compute the
 | |
|     quotient (as if) to infinite precision and round once to the result format, according to the current
 | |
|     rounding mode. A range error occurs for some finite arguments. A domain error occurs for either
 | |
|     both arguments infinite or both arguments zero. A pole error occurs for a finite x and a zero y.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.14.4p3'></a>
 | |
| <pre>3   These functions return the quotient x ÷ y, rounded to the type of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.14.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.14.5 [Fused multiply-add and round to narrower type]</h3>
 | |
| <a name='7.12.14.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             float ffma(double x, double y, double z);
 | |
|             float ffmal(long double x, long double y, long double z);
 | |
|               double dfmal(long double x, long double y, long double z);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 d32fmad64(_Decimal64 x, _Decimal64 y, _Decimal64 z);
 | |
|               _Decimal32 d32fmad128(_Decimal128 x, _Decimal128 y, _Decimal128 z);
 | |
|               _Decimal64 d64fmad128(_Decimal128 x, _Decimal128 y, _Decimal128 z);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.14.5p2'></a>
 | |
| <pre>2   These functions compute (x × y) + z, rounded to the type of the function. They compute (x × y) + z
 | |
|     (as if) to infinite precision and round once to the result format, according to the current rounding
 | |
|     mode. A range error occurs for some finite arguments. A domain error may occur for an infinite
 | |
|     argument.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.14.5p3'></a>
 | |
| <pre>3   These functions return (x × y) + z, rounded to the type of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.14.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.14.6 [Square root rounded to narrower type]</h3>
 | |
| <a name='7.12.14.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               float fsqrt(double x);
 | |
|               float fsqrtl(long double x);
 | |
|               double dsqrtl(long double x);
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 d32sqrtd64(_Decimal64 x);
 | |
|               _Decimal32 d32sqrtd128(_Decimal128 x);
 | |
|               _Decimal64 d64sqrtd128(_Decimal128 x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.14.6p2'></a>
 | |
| <pre>2   These functions compute the square root of x, rounded to the type of the function. They compute the
 | |
|     square root (as if) to infinite precision and round once to the result format, according to the current
 | |
|     rounding mode. A range error occurs for some finite positive arguments. A domain error occurs if
 | |
|     the argument is less than zero.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.14.6p3'></a>
 | |
| <pre>3   These functions return the nonnegative square root of x, rounded to the type of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.15'></a>
 | |
| <hr>
 | |
| <h3>7.12.15 [Quantum and quantum exponent functions]</h3>
 | |
| <a name='7.12.15.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.15.1 [The quantizedN functions]</h3>
 | |
| <a name='7.12.15.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 quantized32(_Decimal32 x, _Decimal32 y);
 | |
|               _Decimal64 quantized64(_Decimal64 x, _Decimal64 y);
 | |
|               _Decimal128 quantized128(_Decimal128 x, _Decimal128 y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.15.1p2'></a>
 | |
| <pre>2   The quantizedN functions compute, if possible, a value with the numerical value of x and the
 | |
|     quantum exponent of y. If the quantum exponent is being increased, the value shall be correctly
 | |
|     rounded; if the result does not have the same value as x, the "inexact" floating-point exception shall
 | |
|     be raised. If the quantum exponent is being decreased and the significand of the result has more
 | |
|     digits than the type would allow, the result is NaN, the "invalid" floating-point exception is raised,
 | |
|     and a domain error occurs. If one or both operands are NaN the result is NaN. Otherwise if only one
 | |
|     operand is infinite, the result is NaN, the "invalid" floating-point exception is raised, and a domain
 | |
|     error occurs. If both operands are infinite, the result is DEC_INFINITY with the sign of x, converted
 | |
|     to the type of the function. The quantizedN functions do not raise the "overflow" and "underflow"
 | |
|     floating-point exceptions.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.15.1p3'></a>
 | |
| <pre>3   The quantizedN functions return a value with the numerical value of x (except for any rounding)
 | |
|     and the quantum exponent of y.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.15.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.15.2 [The samequantumdN functions]</h3>
 | |
| <a name='7.12.15.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             bool samequantumd32(_Decimal32 x, _Decimal32 y);
 | |
|             bool samequantumd64(_Decimal64 x, _Decimal64 y);
 | |
|             bool samequantumd128(_Decimal128 x, _Decimal128 y);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.15.2p2'></a>
 | |
| <pre>2   The samequantumdN functions determine if the quantum exponents of x and y are the same. If both
 | |
|     x and y are NaN, or both infinite, they have the same quantum exponents; if exactly one operand
 | |
|     is infinite or exactly one operand is NaN, they do not have the same quantum exponents. The
 | |
|     samequantumdN functions raise no floating-point exception.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.15.2p3'></a>
 | |
| <pre>3   The samequantumdN functions return nonzero (true) when x and y have the same quantum expo-
 | |
|     nents, zero (false) otherwise.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.15.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.15.3 [The quantumdN functions]</h3>
 | |
| <a name='7.12.15.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             _Decimal32 quantumd32(_Decimal32 x);
 | |
|             _Decimal64 quantumd64(_Decimal64 x);
 | |
|             _Decimal128 quantumd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.15.3p2'></a>
 | |
| <pre>2   The quantumdN functions compute the quantum (<a href='#5.2.4.2.3'>5.2.4.2.3</a>) of a finite argument. If x is infinite, the
 | |
|     result is +∞.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.15.3p3'></a>
 | |
| <pre>3   The quantumdN functions return the quantum of x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.15.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.15.4 [The llquantexpdN functions]</h3>
 | |
| <a name='7.12.15.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             long long int llquantexpd32(_Decimal32 x);
 | |
|             long long int llquantexpd64(_Decimal64 x);
 | |
|             long long int llquantexpd128(_Decimal128 x);
 | |
|             #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.15.4p2'></a>
 | |
| <pre>2   The llquantexpdN functions compute the quantum exponent (<a href='#5.2.4.2.3'>5.2.4.2.3</a>) of a finite argument. If x is
 | |
|     infinite or NaN, they compute LLONG_MIN, the "invalid" floating-point exception is raised, and a
 | |
|     domain error occurs.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.15.4p3'></a>
 | |
| <pre>3   The llquantexpdN functions return the quantum exponent of x.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.16'></a>
 | |
| <hr>
 | |
| <h3>7.12.16 [Decimal re-encoding functions]</h3>
 | |
| <a name='7.12.16p1'></a>
 | |
| <pre>1   IEC 60559 specifies two different schemes to encode significands in the object representation of a
 | |
|     decimal floating-point object: one based on decimal encoding (which packs three decimal digits
 | |
|     into 10 bits), the other based on binary encoding (as a binary integer). An implementation may use
 | |
|     either of these encoding schemes for its decimal floating types. The re-encoding functions in this
 | |
|     subclause provide conversions between external decimal data with a given encoding scheme and
 | |
|     the implementation’s corresponding decimal floating type.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.16.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.16.1 [The encodedecdN functions]</h3>
 | |
| <a name='7.12.16.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               void encodedecd32(unsigned char encptr[restrict static 4],
 | |
|                     const _Decimal32*restrict xptr);
 | |
|               void encodedecd64(unsigned char encptr[restrict static 8],
 | |
|                     const _Decimal64*restrict xptr);
 | |
|               void encodedecd128(unsigned char encptr[restrict static 16],
 | |
|                     const _Decimal128*restrict xptr);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.16.1p2'></a>
 | |
| <pre>2   The encodedecdN functions convert *xptr into an IEC 60559 decimalN encoding in the encoding
 | |
|     scheme based on decimal encoding of the significand and store the resulting encoding as an N/8
 | |
|     element array, with 8 bits per array element, in the object pointed to by encptr. The order of bytes
 | |
|     in the array is implementation-defined. These functions preserve the value of *xptr and raise no
 | |
|     floating-point exceptions. If *xptr is non-canonical, these functions may or may not produce a
 | |
|     canonical encoding.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.16.1p3'></a>
 | |
| <pre>3   The encodedecdN functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.16.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.16.2 [The decodedecdN functions]</h3>
 | |
| <a name='7.12.16.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               void decodedecd32(_Decimal32 * restrict xptr,
 | |
|                     const unsigned char encptr[restrict static 4]);
 | |
|               void decodedecd64(_Decimal64 * restrict xptr,
 | |
|                     const unsigned char encptr[restrict static 8]);
 | |
|               void decodedecd128(_Decimal128 * restrict xptr,
 | |
|                     const unsigned char encptr[restrict static 16]);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
|     15
 | |
| </pre>
 | |
| <a name='7.12.16.2p2'></a>
 | |
| <pre>2   The decodedecdN functions interpret the N/8 element array pointed to by encptr as an IEC 60559
 | |
|     decimalN encoding, with 8 bits per array element, in the encoding scheme based on decimal
 | |
|     encoding of the significand. The order of bytes in the array is implementation-defined. These
 | |
|     functions convert the given encoding into a value of the decimal floating type, and store the result in
 | |
|     the object pointed to by xptr. These functions preserve the encoded value and raise no floating-point
 | |
|     exceptions. If the encoding is non-canonical, these functions may or may not produce a canonical
 | |
|     representation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.16.2p3'></a>
 | |
| <pre>3   The decodedecdN functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.16.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.16.3 [The encodebindN functions]</h3>
 | |
| <a name='7.12.16.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               void encodebind32(unsigned char encptr[restrict static 4],
 | |
|                     const _Decimal32 * restrict xptr);
 | |
|               void encodebind64(unsigned char encptr[restrict static 8],
 | |
|                     const _Decimal64 * restrict xptr);
 | |
|               void encodebind128(unsigned char encptr[restrict static 16],
 | |
|                     const _Decimal128 * restrict xptr);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.16.3p2'></a>
 | |
| <pre>2   The encodebindN functions convert *xptr into an IEC 60559 decimalN encoding in the encoding
 | |
|     scheme based on binary encoding of the significand and store the resulting encoding as an N/8
 | |
|     element array, with 8 bits per array element, in the object pointed to by encptr. The order of bytes
 | |
|     in the array is implementation-defined. These functions preserve the value of *xptr and raise no
 | |
|     floating-point exceptions. If *xptr is non-canonical, these functions may or may not produce a
 | |
|     canonical encoding.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.16.3p3'></a>
 | |
| <pre>3   The encodebindN functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.16.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.16.4 [The decodebindN functions]</h3>
 | |
| <a name='7.12.16.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               void decodebind32(_Decimal32 * restrict xptr,
 | |
|                     const unsigned char encptr[restrict static 4]);
 | |
|               void decodebind64(_Decimal64 * restrict xptr,
 | |
|                     const unsigned char encptr[restrict static 8]);
 | |
|               void decodebind128(_Decimal128 * restrict xptr,
 | |
|                     const unsigned char encptr[restrict static 16]);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.16.4p2'></a>
 | |
| <pre>2   The decodebindN functions interpret the N/8 element array pointed to by encptr as an IEC 60559
 | |
|     decimalN encoding, with 8 bits per array element, in the encoding scheme based on binary encoding
 | |
|     of the significand. The order of bytes in the array is implementation-defined. These functions convert
 | |
|     the given encoding into a value of decimal floating type, and store the result in the object pointed to
 | |
|     by xptr. These functions preserve the encoded value and raise no floating-point exceptions. If the
 | |
|     encoding is non-canonical, these functions may or may not produce a canonical representation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.16.4p3'></a>
 | |
| <pre>3   The decodebindN functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.17'></a>
 | |
| <hr>
 | |
| <h3>7.12.17 [Comparison macros]</h3>
 | |
| <a name='7.12.17p1'></a>
 | |
| <pre>1   The relational and equality operators support the usual mathematical relationships between numeric
 | |
|     values. For any ordered pair of numeric values exactly one of the relationships — less, greater, and
 | |
|     equal — is true. Relational operators may raise the "invalid" floating-point exception when argument
 | |
|     values are NaNs. For a NaN and a numeric value, or for two NaNs, just the unordered relationship
 | |
|     is true.<a href='#FOOTNOTE.302'><sup>[302]</sup></a> Subclauses <a href='#7.12.17.1'>7.12.17.1</a> through <a href='#7.12.17.6'>7.12.17.6</a> provide macros that are quiet versions of the
 | |
|     relational operators: the macros do not raise the "invalid" floating-point exception as an effect
 | |
|     of quiet NaN arguments. The comparison macros facilitate writing efficient code that accounts
 | |
|     for quiet NaNs without suffering the "invalid" floating-point exception. In the synopses in this
 | |
|     subclause, real-floating indicates that the argument shall be an expression of real floating type<a href='#FOOTNOTE.303'><sup>[303]</sup></a>
 | |
|     (both arguments need not have the same type).<a href='#FOOTNOTE.304'><sup>[304]</sup></a> If either argument has decimal floating type, the
 | |
|     other argument shall have decimal floating type as well.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.302'>
 | |
| <pre><i><b>Footnote 302)</b> IEC 60559 requires that the built-in relational operators raise the "invalid" floating-point exception if the operands
 | |
|     compare unordered, as an error indicator for programs written without consideration of NaNs; the result in these cases is
 | |
|     false.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.303'>
 | |
| <pre><i><b>Footnote 303)</b> If any argument is of integer type, or any other type that is not a real floating type, the behavior is undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.304'>
 | |
| <pre><i><b>Footnote 304)</b> Whether an argument represented in a format wider than its semantic type is converted to the semantic type is unspecified.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.12.17.1'></a>
 | |
| <hr>
 | |
| <h3>7.12.17.1 [The isgreater macro]</h3>
 | |
| <a name='7.12.17.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int isgreater(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.17.1p2'></a>
 | |
| <pre>2   The isgreater macro determines whether its first argument is greater than its second argu-
 | |
|     ment. The value of isgreater(x,y) is always equal to (x)> (y) ; however, unlike (x)> (y) ,
 | |
|     isgreater(x,y) does not raise the "invalid" floating-point exception when x and y are unordered
 | |
|     and neither is a signaling NaN.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.17.1p3'></a>
 | |
| <pre>3   The isgreater macro returns the value of (x)> (y) .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.17.2'></a>
 | |
| <hr>
 | |
| <h3>7.12.17.2 [The isgreaterequal macro]</h3>
 | |
| <a name='7.12.17.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int isgreaterequal(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.17.2p2'></a>
 | |
| <pre>2   The isgreaterequal macro determines whether its first argument is greater than or equal to its
 | |
|     second argument. The value of isgreaterequal(x,y) is always equal to (x)>= (y) ; however,
 | |
|     unlike (x)>= (y) , isgreaterequal(x,y) does not raise the "invalid" floating-point exception
 | |
|     when x and y are unordered and neither is a signaling NaN.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.17.2p3'></a>
 | |
| <pre>3   The isgreaterequal macro returns the value of (x)>= (y) .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.17.3'></a>
 | |
| <hr>
 | |
| <h3>7.12.17.3 [The isless macro]</h3>
 | |
| <a name='7.12.17.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <math.h>
 | |
|               int isless(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.17.3p2'></a>
 | |
| <pre>2   The isless macro determines whether its first argument is less than its second argument. The value
 | |
|     of isless(x,y) is always equal to (x)< (y) ; however, unlike (x)< (y) , isless(x,y) does not
 | |
|     raise the "invalid" floating-point exception when x and y are unordered and neither is a signaling
 | |
|     NaN.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.17.3p3'></a>
 | |
| <pre>3   The isless macro returns the value of (x) < (y).
 | |
| </pre>
 | |
| <a name='7.12.17.4'></a>
 | |
| <hr>
 | |
| <h3>7.12.17.4 [The islessequal macro]</h3>
 | |
| <a name='7.12.17.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             int islessequal(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.17.4p2'></a>
 | |
| <pre>2   The islessequal macro determines whether its first argument is less than or equal to its sec-
 | |
|     ond argument. The value of islessequal(x,y) is always equal to (x)<= (y) ; however, unlike
 | |
|     (x)<= (y) , islessequal(x,y) does not raise the "invalid" floating-point exception when x and y
 | |
|     are unordered and neither is a signaling NaN.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.17.4p3'></a>
 | |
| <pre>3   The islessequal macro returns the value of (x)<= (y) .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.17.5'></a>
 | |
| <hr>
 | |
| <h3>7.12.17.5 [The islessgreater macro]</h3>
 | |
| <a name='7.12.17.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             int islessgreater(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.17.5p2'></a>
 | |
| <pre>2   The islessgreater macro determines whether its first argument is less than or greater than its
 | |
|     second argument. The islessgreater(x,y) macro is similar to (x)< (y)|| (x)> (y) ; however,
 | |
|     islessgreater(x,y) does not raise the "invalid" floating-point exception when x and y are un-
 | |
|     ordered and neither is a signaling NaN (nor does it evaluate x and y twice).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.17.5p3'></a>
 | |
| <pre>3   The islessgreater macro returns the value of (x)< (y)|| (x)> (y) .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.17.6'></a>
 | |
| <hr>
 | |
| <h3>7.12.17.6 [The isunordered macro]</h3>
 | |
| <a name='7.12.17.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             int isunordered(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.17.6p2'></a>
 | |
| <pre>2   The isunordered macro determines whether its arguments are unordered. It raises no floating-point
 | |
|     exceptions if neither argument is a signaling NaN.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.17.6p3'></a>
 | |
| <pre>3   The isunordered macro returns 1 if its arguments are unordered and 0 otherwise.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.12.17.7'></a>
 | |
| <hr>
 | |
| <h3>7.12.17.7 [The iseqsig macro]</h3>
 | |
| <a name='7.12.17.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <math.h>
 | |
|             int iseqsig(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.12.17.7p2'></a>
 | |
| <pre>2   The iseqsig macro determines whether its arguments are equal. If an argument is a NaN, a domain
 | |
|     error occurs for the macro, as if a domain error occurred for a function (<a href='#7.12.1'>7.12.1</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.12.17.7p3'></a>
 | |
| <pre>3   The iseqsig macro returns 1 if its arguments are equal and 0 otherwise.
 | |
| </pre>
 | |
| <a name='7.13'></a>
 | |
| <hr>
 | |
| <h3>7.13 [Non-local jumps <setjmp.h>]</h3>
 | |
| <a name='7.13p1'></a>
 | |
| <pre>1   The header <setjmp.h> defines the macro setjmp, and declares one function and one type, for
 | |
|     bypassing the normal function call and return discipline.<a href='#FOOTNOTE.305'><sup>[305]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.305'>
 | |
| <pre><i><b>Footnote 305)</b> These functions are useful for dealing with unusual conditions encountered in a low-level function of a program.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.13p2'></a>
 | |
| <pre>2   The type declared is
 | |
| 
 | |
|              jmp_buf
 | |
| 
 | |
| 
 | |
|     which is an array type suitable for holding the information needed to restore a calling environment.
 | |
|     The environment of a call to the setjmp macro consists of information sufficient for a call to the
 | |
|     longjmp function to return execution to the correct block and invocation of that block, were it called
 | |
|     recursively. It does not include the state of the floating-point status flags, of open files, or of any
 | |
|     other component of the abstract machine.
 | |
| </pre>
 | |
| <a name='7.13p3'></a>
 | |
| <pre>3   It is unspecified whether setjmp is a macro or an identifier declared with external linkage. If a
 | |
|     macro definition is suppressed in order to access an actual function, or a program defines an external
 | |
|     identifier with the name setjmp, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.13.1'></a>
 | |
| <hr>
 | |
| <h3>7.13.1 [Save calling environment]</h3>
 | |
| <a name='7.13.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.13.1.1 [The setjmp macro]</h3>
 | |
| <a name='7.13.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <setjmp.h>
 | |
|              int setjmp(jmp_buf env);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.13.1.1p2'></a>
 | |
| <pre>2   The setjmp macro saves its calling environment in its jmp_buf argument for later use by the
 | |
|     longjmp function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.13.1.1p3'></a>
 | |
| <pre>3   If the return is from a direct invocation, the setjmp macro returns the value zero. If the return is
 | |
|     from a call to the longjmp function, the setjmp macro returns a nonzero value.
 | |
| 
 | |
|     Environmental limits
 | |
| </pre>
 | |
| <a name='7.13.1.1p4'></a>
 | |
| <pre>4   An invocation of the setjmp macro shall appear only in one of the following contexts:
 | |
| 
 | |
|       — the entire controlling expression of a selection or iteration statement;
 | |
| 
 | |
|       — one operand of a relational or equality operator with the other operand an integer constant
 | |
|         expression, with the resulting expression being the entire controlling expression of a selection
 | |
|         or iteration statement;
 | |
| 
 | |
|       — the operand of a unary ! operator with the resulting expression being the entire controlling
 | |
|         expression of a selection or iteration statement; or
 | |
| 
 | |
|       — the entire expression of an expression statement (possibly cast to void).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.13.1.1p5'></a>
 | |
| <pre>5   If the invocation appears in any other context, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.13.2'></a>
 | |
| <hr>
 | |
| <h3>7.13.2 [Restore calling environment]</h3>
 | |
| <a name='7.13.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.13.2.1 [The longjmp function]</h3>
 | |
| <a name='7.13.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <setjmp.h>
 | |
|              [[noreturn]] void longjmp(jmp_buf env, int val);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.13.2.1p2'></a>
 | |
| <pre>2   The longjmp function restores the environment saved by the most recent invocation of the setjmp
 | |
|     macro in the same invocation of the program with the corresponding jmp_buf argument. If there
 | |
|     has been no such invocation, or if the invocation was from another thread of execution, or if the
 | |
|     function containing the invocation of the setjmp macro has terminated execution<a href='#FOOTNOTE.306'><sup>[306]</sup></a> in the interim,
 | |
|     or if the invocation of the setjmp macro was within the scope of an identifier with variably modified
 | |
|     type and execution has left that scope in the interim, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.306'>
 | |
| <pre><i><b>Footnote 306)</b> For example, by executing a return statement or because another longjmp call has caused a transfer to a setjmp
 | |
|     invocation in a function earlier in the set of nested calls.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.13.2.1p3'></a>
 | |
| <pre>3   All accessible objects have values, and all other components of the abstract machine<a href='#FOOTNOTE.307'><sup>[307]</sup></a> have state,
 | |
|     as of the time the longjmp function was called, except that the representation of objects of automatic
 | |
|     storage duration that are local to the function containing the invocation of the corresponding
 | |
|     setjmp macro that do not have volatile-qualified type and have been changed between the setjmp
 | |
|     invocation and longjmp call is indeterminate.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.307'>
 | |
| <pre><i><b>Footnote 307)</b> This includes, but is not limited to, the floating-point status flags and the state of open files.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.13.2.1p4'></a>
 | |
| <pre>4   After longjmp is completed, thread execution continues as if the corresponding invocation of the
 | |
|     setjmp macro had just returned the value specified by val. The longjmp function cannot cause the
 | |
|     setjmp macro to return the value 0; if val is 0, the setjmp macro returns the value 1.
 | |
| </pre>
 | |
| <a name='7.13.2.1p5'></a>
 | |
| <pre>5   EXAMPLE The longjmp function that returns control back to the point of the setjmp invocation might cause memory
 | |
|     associated with a variable length array object to be squandered.
 | |
| 
 | |
|              #include <setjmp.h>
 | |
|              jmp_buf buf;
 | |
|              void g(int n);
 | |
|              void h(int n);
 | |
|              int n = 6;
 | |
| 
 | |
|              void f(void)
 | |
|              {
 | |
|                    int x[n];                  // valid:     f is not terminated
 | |
|                    setjmp(buf);
 | |
|                    g(n);
 | |
|              }
 | |
| 
 | |
|              void g(int n)
 | |
|              {
 | |
|                    int a[n];                  // a may remain allocated
 | |
|                    h(n);
 | |
|              }
 | |
| 
 | |
|              void h(int n)
 | |
|              {
 | |
|                    int b[n];                  // b may remain allocated
 | |
|                    longjmp(buf, 2);           // might cause memory loss
 | |
|              }
 | |
| </pre>
 | |
| <a name='7.14'></a>
 | |
| <hr>
 | |
| <h3>7.14 [Signal handling <signal.h>]</h3>
 | |
| <a name='7.14p1'></a>
 | |
| <pre>1   The header <signal.h> declares a type and two functions and defines several macros, for handling
 | |
|     various signals (conditions that may be reported during program execution).
 | |
| </pre>
 | |
| <a name='7.14p2'></a>
 | |
| <pre>2   The type defined is
 | |
| 
 | |
|               sig_atomic_t
 | |
| 
 | |
| 
 | |
|     which is the (possibly volatile-qualified) integer type of an object that can be accessed as an atomic
 | |
|     entity, even in the presence of asynchronous interrupts.
 | |
| </pre>
 | |
| <a name='7.14p3'></a>
 | |
| <pre>3   The macros defined are
 | |
| 
 | |
|               SIG_DFL
 | |
|               SIG_ERR
 | |
|               SIG_IGN
 | |
| 
 | |
| 
 | |
|     which expand to constant expressions with distinct values that have type compatible with the second
 | |
|     argument to, and the return value of, the signal function, and whose values compare unequal to
 | |
|     the address of any declarable function; and the following, which expand to positive integer constant
 | |
|     expressions with type int and distinct values that are the signal numbers, each corresponding to
 | |
|     the specified condition:
 | |
| 
 | |
|     SIGABRT abnormal termination, such as is initiated by the abort function
 | |
| 
 | |
|     SIGFPE       an erroneous arithmetic operation, such as zero divide or an operation resulting in
 | |
|                  overflow
 | |
|     SIGILL       detection of an invalid function image, such as an invalid instruction
 | |
|     SIGINT       receipt of an interactive attention signal
 | |
|     SIGSEGV an invalid access to storage
 | |
| 
 | |
|     SIGTERM a termination request sent to the program
 | |
| 
 | |
| </pre>
 | |
| <a name='7.14p4'></a>
 | |
| <pre>4   An implementation need not generate any of these signals, except as a result of explicit calls to the
 | |
|     raise function. Additional signals and pointers to undeclarable functions, with macro definitions
 | |
|     beginning, respectively, with the letters SIG and an uppercase letter or with SIG_ and an uppercase
 | |
|     letter,<a href='#FOOTNOTE.308'><sup>[308]</sup></a> may also be specified by the implementation. The complete set of signals, their semantics,
 | |
|     and their default handling is implementation-defined; all signal numbers shall be positive.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.308'>
 | |
| <pre><i><b>Footnote 308)</b> See "future library directions" (<a href='#7.33.9'>7.33.9</a>). The names of the signal numbers reflect the following terms (respectively): abort,
 | |
|     floating-point exception, illegal instruction, interrupt, segmentation violation, and termination.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.14.1'></a>
 | |
| <hr>
 | |
| <h3>7.14.1 [Specify signal handling]</h3>
 | |
| <a name='7.14.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.14.1.1 [The signal function]</h3>
 | |
| <a name='7.14.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <signal.h>
 | |
|               void (*signal(int sig, void (*func)(int)))(int);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.14.1.1p2'></a>
 | |
| <pre>2   The signal function chooses one of three ways in which receipt of the signal number sig is to
 | |
|     be subsequently handled. If the value of func is SIG_DFL, default handling for that signal will
 | |
|     occur. If the value of func is SIG_IGN, the signal will be ignored. Otherwise, func shall point to a
 | |
|     function to be called when that signal occurs. An invocation of such a function because of a signal, or
 | |
|     (recursively) of any further functions called by that invocation (other than functions in the standard
 | |
|     library),<a href='#FOOTNOTE.309'><sup>[309]</sup></a> is called a signal handler.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.309'>
 | |
| <pre><i><b>Footnote 309)</b> This includes functions called indirectly via standard library functions (e.g., a SIGABRT handler called via the abort
 | |
|     function).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.14.1.1p3'></a>
 | |
| <pre>3   When a signal occurs and func points to a function, it is implementation-defined whether the equiva-
 | |
|     lent of signal(sig, SIG_DFL); is executed or the implementation prevents some implementation-
 | |
|     defined set of signals (at least including sig) from occurring until the current signal handling has
 | |
|     completed; in the case of SIGILL, the implementation may alternatively define that no action is taken.
 | |
|     Then the equivalent of (*func)(sig); is executed. If and when the function returns, if the value
 | |
|     of sig is SIGFPE, SIGILL, SIGSEGV, or any other implementation-defined value corresponding to a
 | |
|     computational exception, the behavior is undefined; otherwise the program will resume execution
 | |
|     at the point it was interrupted.
 | |
| </pre>
 | |
| <a name='7.14.1.1p4'></a>
 | |
| <pre>4   If the signal occurs as the result of calling the abort or raise function, the signal handler shall not
 | |
|     call the raise function.
 | |
| </pre>
 | |
| <a name='7.14.1.1p5'></a>
 | |
| <pre>5   If the signal occurs other than as the result of calling the abort or raise function, the behavior is
 | |
|     undefined if the signal handler refers to any object with static or thread storage duration that is
 | |
|     not a lock-free atomic object other than by assigning a value to an object declared as volatile
 | |
|     sig_atomic_t, or the signal handler calls any function in the standard library other than
 | |
| 
 | |
|       — the abort function,
 | |
|       — the _Exit function,
 | |
|       — the quick_exit function,
 | |
|       — the functions in <stdatomic.h> (except where explicitly stated otherwise) when the atomic
 | |
|         arguments are lock-free,
 | |
|       — the atomic_is_lock_free function with any atomic argument, or
 | |
|       — the signal function with the first argument equal to the signal number corresponding to the
 | |
|         signal that caused the invocation of the handler. Furthermore, if such a call to the signal
 | |
|         function results in a SIG_ERR return, the object designated by errno has an indeterminate
 | |
|         representation<a href='#FOOTNOTE.310'><sup>[310]</sup></a> .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.310'>
 | |
| <pre><i><b>Footnote 310)</b> If any signal is generated by an asynchronous signal handler, the behavior is undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.14.1.1p6'></a>
 | |
| <pre>6   At program startup, the equivalent of
 | |
| 
 | |
|              signal(sig, SIG_IGN);
 | |
| 
 | |
| 
 | |
|     may be executed for some signals selected in an implementation-defined manner; the equivalent of
 | |
| 
 | |
|              signal(sig, SIG_DFL);
 | |
| 
 | |
| 
 | |
|     is executed for all other signals defined by the implementation.
 | |
| </pre>
 | |
| <a name='7.14.1.1p7'></a>
 | |
| <pre>7   Use of this function in a multi-threaded program results in undefined behavior. The implementation
 | |
|     shall behave as if no library function calls the signal function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.14.1.1p8'></a>
 | |
| <pre>8   If the request can be honored, the signal function returns the value of func for the most recent
 | |
|     successful call to signal for the specified signal sig. Otherwise, a value of SIG_ERR is returned and
 | |
|     a positive value is stored in errno.
 | |
|     Forward references: the abort function (<a href='#7.24.4.1'>7.24.4.1</a>), the exit function (<a href='#7.24.4.4'>7.24.4.4</a>), the _Exit function
 | |
|     (<a href='#7.24.4.5'>7.24.4.5</a>), the quick_exit function (<a href='#7.24.4.7'>7.24.4.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.14.2'></a>
 | |
| <hr>
 | |
| <h3>7.14.2 [Send signal]</h3>
 | |
| <a name='7.14.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.14.2.1 [The raise function]</h3>
 | |
| <a name='7.14.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <signal.h>
 | |
|              int raise(int sig);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.14.2.1p2'></a>
 | |
| <pre>2   The raise function carries out the actions described in <a href='#7.14.1.1'>7.14.1.1</a> for the signal sig. If a signal handler
 | |
|     is called, the raise function shall not return until after the signal handler does.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.14.2.1p3'></a>
 | |
| <pre>3   The raise function returns zero if successful, nonzero if unsuccessful.
 | |
| </pre>
 | |
| <a name='7.15'></a>
 | |
| <hr>
 | |
| <h3>7.15 [Alignment <stdalign.h>]</h3>
 | |
| <a name='7.15p1'></a>
 | |
| <pre>1   The header <stdalign.h> provides no content.
 | |
| </pre>
 | |
| <a name='7.16'></a>
 | |
| <hr>
 | |
| <h3>7.16 [Variable arguments <stdarg.h>]</h3>
 | |
| <a name='7.16p1'></a>
 | |
| <pre>1   The header <stdarg.h> declares a type and defines four macros, for advancing through a list of
 | |
|     arguments whose number and types are not known to the called function when it is translated.
 | |
| </pre>
 | |
| <a name='7.16p2'></a>
 | |
| <pre>2   A function may be called with a variable number of arguments of varying types if its parameter
 | |
|     type list ends with an ellipsis.
 | |
| </pre>
 | |
| <a name='7.16p3'></a>
 | |
| <pre>3   The type declared is
 | |
| 
 | |
|               va_list
 | |
| 
 | |
| 
 | |
|     which is a complete object type suitable for holding information needed by the macros va_start,
 | |
|     va_arg, va_end, and va_copy . If access to the varying arguments is desired, the called function
 | |
|     shall declare an object (generally referred to as ap in this subclause) having type va_list. The object
 | |
|     ap may be passed as an argument to another function; if that function invokes the va_arg macro
 | |
|     with parameter ap, the representation of ap in the calling function is indeterminate and shall be
 | |
|     passed to the va_end macro prior to any further reference to ap<a href='#FOOTNOTE.311'><sup>[311]</sup></a> .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.311'>
 | |
| <pre><i><b>Footnote 311)</b> It is permitted to create a pointer to a va_list and pass that pointer to another function, in which case the original
 | |
|     function can make further use of the original list after the other function returns.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.16.1'></a>
 | |
| <hr>
 | |
| <h3>7.16.1 [Variable argument list access macros]</h3>
 | |
| <a name='7.16.1p1'></a>
 | |
| <pre>1   The va_start and va_arg macros described in this subclause shall be implemented as macros,
 | |
|     not functions. It is unspecified whether va_copy and va_end are macros or identifiers declared
 | |
|     with external linkage. If a macro definition is suppressed in order to access an actual function,
 | |
|     or a program defines an external identifier with the same name, the behavior is undefined. Each
 | |
|     invocation of the va_start and va_copy macros shall be matched by a corresponding invocation of
 | |
|     the va_end macro in the same function.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.16.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.16.1.1 [The va_arg macro]</h3>
 | |
| <a name='7.16.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               type va_arg(va_list ap, type);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.16.1.1p2'></a>
 | |
| <pre>2   The va_arg macro expands to an expression that has the specified type and the value of the next
 | |
|     argument in the call. The parameter ap shall have been initialized by the va_start or va_copy
 | |
|     macro (without an intervening invocation of the va_end macro for the same ap). Each invocation
 | |
|     of the va_arg macro modifies ap so that the values of successive arguments are returned in turn.
 | |
|     The behavior is undefined if there is no actual next argument. The parameter type shall be a type
 | |
|     name specified such that the type of a pointer to an object that has the specified type can be obtained
 | |
|     simply by postfixing a * to type. If type is not compatible with the type of the actual next argument
 | |
|     (as promoted according to the default argument promotions), the behavior is undefined, except for
 | |
|     the following cases:
 | |
| 
 | |
| 
 | |
|       — both types are pointers to qualified or unqualified versions of compatible types;
 | |
| 
 | |
|       — one type is a signed integer type, the other type is the corresponding unsigned integer type,
 | |
|         and the value is representable in both types;
 | |
| 
 | |
|       — one type is pointer to qualified or unqualified void and the other is a pointer to a qualified or
 | |
|         unqualified character type;
 | |
| 
 | |
|       — or, the type of the next argument is nullptr_t and type is a pointer type that has the same
 | |
|         representation and alignment requirements as a pointer to a character type<a href='#FOOTNOTE.312'><sup>[312]</sup></a> .
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.312'>
 | |
| <pre><i><b>Footnote 312)</b> Such types are in particular pointers to qualified or unqualified versions of void .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.16.1.1p3'></a>
 | |
| <pre>3   The first invocation of the va_arg macro after that of the va_start macro returns the value of
 | |
|     the first argument without an explicitly parameter, which matches the position of the ... in the
 | |
|     parameter list. Successive invocations return the values of the remaining arguments in succession.
 | |
| </pre>
 | |
| <a name='7.16.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.16.1.2 [The va_copy macro]</h3>
 | |
| <a name='7.16.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               void va_copy(va_list dest, va_list src);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.16.1.2p2'></a>
 | |
| <pre>2   The va_copy macro initializes dest as a copy of src, as if the va_start macro had been applied
 | |
|     to dest followed by the same sequence of uses of the va_arg macro as had previously been used
 | |
|     to reach the present state of src. Neither the va_copy nor va_start macro shall be invoked to
 | |
|     reinitialize dest without an intervening invocation of the va_end macro for the same dest.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.16.1.2p3'></a>
 | |
| <pre>3   The va_copy macro returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.16.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.16.1.3 [The va_end macro]</h3>
 | |
| <a name='7.16.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               void va_end(va_list ap);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.16.1.3p2'></a>
 | |
| <pre>2   The va_end macro facilitates a normal return from the function whose variable argument list was
 | |
|     referred to by the expansion of the va_start macro, or the function containing the expansion of
 | |
|     the va_copy macro, that initialized the va_list ap. The va_end macro may modify ap so that it
 | |
|     is no longer usable (without being reinitialized by the va_start or va_copy macro). If there is no
 | |
|     corresponding invocation of the va_start or va_copy macro, or if the va_end macro is not invoked
 | |
|     before the return, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.16.1.3p3'></a>
 | |
| <pre>3   The va_end macro returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.16.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.16.1.4 [The va_start macro]</h3>
 | |
| <a name='7.16.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               void va_start(va_list ap, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.16.1.4p2'></a>
 | |
| <pre>2   The va_start macro shall be invoked before any access to the unnamed arguments.
 | |
| </pre>
 | |
| <a name='7.16.1.4p3'></a>
 | |
| <pre>3   The va_start macro initializes ap for subsequent use by the va_arg and va_end macros. Neither the
 | |
|     va_start nor va_copy macro shall be invoked to reinitialize ap without an intervening invocation
 | |
|     of the va_end macro for the same ap.
 | |
| </pre>
 | |
| <a name='7.16.1.4p4'></a>
 | |
| <pre>4   Only the first argument passed to va_start is evaluated. Any additional arguments are not used by
 | |
|     the macro and will not be expanded or evaluated for any reason.
 | |
| </pre>
 | |
| <a name='7.16.1.4p5'></a>
 | |
| <pre>5   NOTE The macro allows additional arguments to be passed for va_start for compatibility with older versions of the library
 | |
|     only.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.16.1.4p6'></a>
 | |
| <pre>6   The va_start macro returns no value.
 | |
| </pre>
 | |
| <a name='7.16.1.4p7'></a>
 | |
| <pre>7   EXAMPLE 1 The function f1 gathers into an array a list of arguments that are pointers to strings (but not more than MAXARGS
 | |
|     arguments), then passes the array as a single argument to function f2. The number of pointers is specified by the first
 | |
|     argument to f1.
 | |
|               #include <stdarg.h>
 | |
|               #define MAXARGS   31
 | |
| 
 | |
|               void f1(int n_ptrs, ...)
 | |
|               {
 | |
|                     va_list ap;
 | |
|                     char *array[MAXARGS];
 | |
|                     int ptr_no = 0;
 | |
| 
 | |
|                        if (n_ptrs > MAXARGS)
 | |
|                              n_ptrs = MAXARGS;
 | |
|                        va_start(ap);
 | |
|                        while (ptr_no < n_ptrs)
 | |
|                              array[ptr_no++] = va_arg(ap, char *);
 | |
|                        va_end(ap);
 | |
|                        f2(n_ptrs, array);
 | |
|               }
 | |
| 
 | |
|     Each call to f1 is required to have visible the definition of the function or a declaration such as
 | |
| 
 | |
|               void f1(int, ...);
 | |
| 
 | |
| </pre>
 | |
| <a name='7.16.1.4p8'></a>
 | |
| <pre>8   EXAMPLE 2 The function f3 is similar, but saves the status of the variable argument list after the indicated number of
 | |
|     arguments; after f2 has been called once with the whole list, the trailing part of the list is gathered again and passed to
 | |
|     function f4.
 | |
| 
 | |
|               #include <stdarg.h>
 | |
|               #define MAXARGS 31
 | |
| 
 | |
|               void f3(int n_ptrs, int f4_after, ...)
 | |
|               {
 | |
|                     va_list ap, ap_save;
 | |
|                     char *array[MAXARGS];
 | |
|                     int ptr_no = 0;
 | |
|                     if (n_ptrs > MAXARGS)
 | |
|                           n_ptrs = MAXARGS;
 | |
|                       _
 | |
|                     va start(ap);
 | |
|                     while (ptr_no < n_ptrs) {
 | |
|                           array[ptr_no++] = va_arg(ap, char *);
 | |
|                           if (ptr_no == f4_after)
 | |
|                                 va_copy(ap_save, ap);
 | |
|                     }
 | |
|                     va_end(ap);
 | |
|                     f2(n_ptrs, array);
 | |
| 
 | |
|                        // Now process the saved copy.
 | |
| 
 | |
|                        n_ptrs -= f4_after;
 | |
|                        ptr_no = 0;
 | |
|                        while (ptr_no < n_ptrs)
 | |
|                              array[ptr_no++] = va_arg(ap_save, char *);
 | |
|                        va end(ap_save);
 | |
|                          _
 | |
|                        f4(n_ptrs, array);
 | |
|               }
 | |
| 
 | |
| </pre>
 | |
| <a name='7.16.1.4p9'></a>
 | |
| <pre>9   EXAMPLE 3 The function f5 is similar to f1, but instead of passing an explicit number of strings as the first argument, the
 | |
|     argument list is terminated with a null pointer.
 | |
| 
 | |
|               #include <stdarg.h>
 | |
| 
 | |
|               #define MAXARGS 31
 | |
|           void f5(...)
 | |
|           {
 | |
|                 va_list ap;
 | |
|                 char *array[MAXARGS];
 | |
|                 int ptr_no = 0;
 | |
|                 va_start(ap);
 | |
|                 while (ptr_no < MAXARGS)
 | |
|                 {
 | |
|                       char *ptr = va_arg(ap, char *);
 | |
|                       if (!ptr)
 | |
|                             break;
 | |
|                       array[ptr_no++] = ptr;
 | |
|                 }
 | |
|                 va_end(ap);
 | |
|                 f6(ptr_no, array);
 | |
|           }
 | |
| 
 | |
| Each call to f5 is required to have visible the definition of the function or a declaration such as
 | |
| 
 | |
|           void f5(...);
 | |
| 
 | |
| and implicitly requires the last argument to be a null pointer.
 | |
| </pre>
 | |
| <a name='7.17'></a>
 | |
| <hr>
 | |
| <h3>7.17 [Atomics <stdatomic.h>]</h3>
 | |
| <a name='7.17.1'></a>
 | |
| <hr>
 | |
| <h3>7.17.1 [Introduction]</h3>
 | |
| <a name='7.17.1p1'></a>
 | |
| <pre>1   The header <stdatomic.h> defines several macros and declares several types and functions for
 | |
|     performing atomic operations on data shared between threads.<a href='#FOOTNOTE.313'><sup>[313]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.313'>
 | |
| <pre><i><b>Footnote 313)</b> See "future library directions" (<a href='#7.33.10'>7.33.10</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.17.1p2'></a>
 | |
| <pre>2   Implementations that define the macro __STDC_NO_ATOMICS__ need not provide this header nor
 | |
|     support any of its facilities.
 | |
| </pre>
 | |
| <a name='7.17.1p3'></a>
 | |
| <pre>3   The macros defined are the atomic lock-free macros
 | |
| 
 | |
|               ATOMIC_BOOL_LOCK_FREE
 | |
|               ATOMIC_CHAR_LOCK_FREE
 | |
|               ATOMIC_CHAR8_T_LOCK_FREE
 | |
|               ATOMIC_CHAR16_T_LOCK_FREE
 | |
|               ATOMIC_CHAR32_T_LOCK_FREE
 | |
|               ATOMIC_WCHAR_T_LOCK_FREE
 | |
|               ATOMIC_SHORT_LOCK_FREE
 | |
|               ATOMIC_INT_LOCK_FREE
 | |
|               ATOMIC_LONG_LOCK_FREE
 | |
|               ATOMIC_LLONG_LOCK_FREE
 | |
|               ATOMIC_POINTER_LOCK_FREE
 | |
| 
 | |
| 
 | |
|     which expand to constant expressions suitable for use in #if preprocessing directives and which
 | |
|     indicate the lock-free property of the corresponding atomic types (both signed and unsigned); and
 | |
| 
 | |
|               ATOMIC_FLAG_INIT
 | |
| 
 | |
| 
 | |
|     which expands to an initializer for an object of type atomic_flag.
 | |
| </pre>
 | |
| <a name='7.17.1p4'></a>
 | |
| <pre>4   The types include
 | |
| 
 | |
|               memory_order
 | |
| 
 | |
| 
 | |
|     which is an enumerated type whose enumerators identify memory ordering constraints;
 | |
| 
 | |
|               atomic_flag
 | |
| 
 | |
| 
 | |
|     which is a structure type representing a lock-free, primitive atomic flag; and several atomic analogs
 | |
|     of integer types.
 | |
| </pre>
 | |
| <a name='7.17.1p5'></a>
 | |
| <pre>5   In the following synopses:
 | |
| 
 | |
|       — An A refers to an atomic type.
 | |
| 
 | |
|       — A C refers to its corresponding non-atomic type.
 | |
| 
 | |
|       — An M refers to the type of the other argument for arithmetic operations. For atomic integer
 | |
|         types, M is C. For atomic pointer types, M is ptrdiff_t.
 | |
| 
 | |
|       — The functions not ending in _explicit have the same semantics as the corresponding
 | |
|         _explicit function with memory_order_seq_cst for the memory_order argument.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.1p6'></a>
 | |
| <pre>6   It is unspecified whether any generic function declared in <stdatomic.h> is a macro or an identifier
 | |
|     declared with external linkage. If a macro definition is suppressed in order to access an actual
 | |
|     function, or a program defines an external identifier with the name of a generic function, the
 | |
|     behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.17.1p7'></a>
 | |
| <pre>7   NOTE Many operations are volatile-qualified. The "volatile as device register" semantics have not changed in the standard.
 | |
|     This qualification means that volatility is preserved when applying these operations to volatile objects.
 | |
| </pre>
 | |
| <a name='7.17.2'></a>
 | |
| <hr>
 | |
| <h3>7.17.2 [Initialization]</h3>
 | |
| <a name='7.17.2p1'></a>
 | |
| <pre>1   An atomic object with automatic storage duration that is not initialized or such an object with
 | |
|     allocated storage duration initially has an indeterminate representation; equally, a non-atomic store
 | |
|     to any byte of the representation (either directly or, for example, by calls to memcpy or memset) makes
 | |
|     any atomic object have an indeterminate representation. Explicit or default initialization for atomic
 | |
|     objects with static or thread storage duration that do not have the type atomic_flag is guaranteed
 | |
|     to produce a valid state.<a href='#FOOTNOTE.314'><sup>[314]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.314'>
 | |
| <pre><i><b>Footnote 314)</b> See "future library directions" (<a href='#7.33.10'>7.33.10</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.17.2p2'></a>
 | |
| <pre>2   Concurrent access to an atomic object before it is set to a valid state, even via an atomic operation,
 | |
|     constitutes a data race. If a signal occurs other than as the result of calling the abort or raise
 | |
|     functions, the behavior is undefined if the signal handler reads or modifies an atomic object that has
 | |
|     an indeterminate representation.
 | |
| </pre>
 | |
| <a name='7.17.2p3'></a>
 | |
| <pre>3   EXAMPLE The following definition ensure valid states for guide and head regardless if these are found in file scope or
 | |
|     block scope. Thus any atomic operation that is performed on them after their initialization has been met is well defined.
 | |
| 
 | |
|               _Atomic int guide = 42;
 | |
|               static _Atomic(void*) head;
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.17.2.1 [The atomic_init generic function]</h3>
 | |
| <a name='7.17.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdatomic.h>
 | |
|               void atomic_init(volatile A *obj, C value);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.2.1p2'></a>
 | |
| <pre>2   The atomic_init generic function initializes the atomic object pointed to by obj to the value value,
 | |
|     while also initializing any additional state that the implementation might need to carry for the
 | |
|     atomic object. If the object has no declared type, after the call the effective type is the atomic type A.
 | |
| </pre>
 | |
| <a name='7.17.2.1p3'></a>
 | |
| <pre>3   Although this function initializes an atomic object, it does not avoid data races; concurrent access to
 | |
|     the variable being initialized, even via an atomic operation, constitutes a data race.
 | |
| </pre>
 | |
| <a name='7.17.2.1p4'></a>
 | |
| <pre>4   If a signal occurs other than as the result of calling the abort or raise functions, the behavior is
 | |
|     undefined if the signal handler calls the atomic_init generic function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.2.1p5'></a>
 | |
| <pre>5   The atomic_init generic function returns no value.
 | |
| </pre>
 | |
| <a name='7.17.2.1p6'></a>
 | |
| <pre>6   EXAMPLE
 | |
| 
 | |
|               atomic_int guide;
 | |
|               atomic_init(&guide, 42);
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.3'></a>
 | |
| <hr>
 | |
| <h3>7.17.3 [Order and consistency]</h3>
 | |
| <a name='7.17.3p1'></a>
 | |
| <pre>1   The enumerated type memory_order specifies the detailed regular (non-atomic) memory synchro-
 | |
|     nization operations as defined in <a href='#5.1.2.4'>5.1.2.4</a> and may provide for operation ordering. Its enumeration
 | |
|     constants are as follows:<a href='#FOOTNOTE.315'><sup>[315]</sup></a>
 | |
| 
 | |
|               memory_order_relaxed
 | |
|               memory_order_consume
 | |
|               memory_order_acquire
 | |
|               memory_order_release
 | |
|               memory_order_acq_rel
 | |
|               memory_order_seq_cst
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.315'>
 | |
| <pre><i><b>Footnote 315)</b> See "future library directions" (<a href='#7.33.10'>7.33.10</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.17.3p2'></a>
 | |
| <pre>2   For memory_order_relaxed, no operation orders memory.
 | |
| </pre>
 | |
| <a name='7.17.3p3'></a>
 | |
| <pre>3    For memory_order_release, memory_order_acq_rel, and memory_order_seq_cst, a store opera-
 | |
|      tion performs a release operation on the affected memory location.
 | |
| </pre>
 | |
| <a name='7.17.3p4'></a>
 | |
| <pre>4    For memory_order_acquire, memory_order_acq_rel, and memory_order_seq_cst, a load opera-
 | |
|      tion performs an acquire operation on the affected memory location.
 | |
| </pre>
 | |
| <a name='7.17.3p5'></a>
 | |
| <pre>5    For memory_order_consume, a load operation performs a consume operation on the affected mem-
 | |
|      ory location.
 | |
| </pre>
 | |
| <a name='7.17.3p6'></a>
 | |
| <pre>6    There shall be a single total order S on all memory_order_seq_cst operations, consistent with the
 | |
|      "happens before" order and modification orders for all affected locations, such that each
 | |
|      memory_order_seq_cst operation B that loads a value from an atomic object M observes one of
 | |
|      the following values:
 | |
| 
 | |
|        — the result of the last modification A of M that precedes B in S, if it exists, or
 | |
|        — if A exists, the result of some modification of M that is not memory_order_seq_cst and that
 | |
|          does not happen before A, or
 | |
|        — if A does not exist, the result of some modification of M that is not memory_order_seq_cst.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.3p7'></a>
 | |
| <pre>7    NOTE 1 Although it is not explicitly required that S include lock operations, it can always be extended to an order that does
 | |
|      include lock and unlock operations, since the ordering between those is already included in the "happens before" ordering.
 | |
| </pre>
 | |
| <a name='7.17.3p8'></a>
 | |
| <pre>8    NOTE 2 Atomic operations specifying memory_order_relaxed are relaxed only with respect to memory ordering. Imple-
 | |
|      mentations still guarantee that any given atomic access to a particular atomic object is indivisible with respect to all other
 | |
|      atomic accesses to that object.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.3p9'></a>
 | |
| <pre>9    For an atomic operation B that reads the value of an atomic object M , if there is a
 | |
|      memory_order_seq_cst fence X sequenced before B, then B observes either the last
 | |
|      memory_order_seq_cst modification of M preceding X in the total order S or a later mod-
 | |
|      ification of M in its modification order.
 | |
| </pre>
 | |
| <a name='7.17.3p10'></a>
 | |
| <pre>10   For atomic operations A and B on an atomic object M , where A modifies M and B takes its value, if
 | |
|      there is a memory_order_seq_cst fence X such that A is sequenced before X and B follows X in S,
 | |
|      then B observes either the effects of A or a later modification of M in its modification order.
 | |
| </pre>
 | |
| <a name='7.17.3p11'></a>
 | |
| <pre>11   For atomic modifications A and B of an atomic object M , B occurs later than A in the modification
 | |
|      order of M if:
 | |
| 
 | |
|        — there is a memory_order_seq_cst fence X such that A is sequenced before X, and X precedes
 | |
|          B in S, or
 | |
|        — there is a memory_order_seq_cst fence Y such that Y is sequenced before B, and A precedes
 | |
|          Y in S, or
 | |
|        — there are memory_order_seq_cst fences X and Y such that A is sequenced before X, Y is
 | |
|          sequenced before B, and X precedes Y in S.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.3p12'></a>
 | |
| <pre>12   Atomic read-modify-write operations shall always read the last value (in the modification order)
 | |
|      stored before the write associated with the read-modify-write operation.
 | |
| </pre>
 | |
| <a name='7.17.3p13'></a>
 | |
| <pre>13   An atomic store shall only store a value that has been computed from constants and program input
 | |
|      values by a finite sequence of program evaluations, such that each evaluation observes the values of
 | |
|      variables as computed by the last prior assignment in the sequence. The ordering of evaluations in
 | |
|      this sequence shall be such that
 | |
| 
 | |
|        — If an evaluation B observes a value computed by A in a different thread, then B does not
 | |
|          happen before A.
 | |
|        — If an evaluation A is included in the sequence, then all evaluations that assign to the same
 | |
|          variable and happen before A are also included.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.3p14'></a>
 | |
| <pre>14   NOTE 3 The second requirement disallows "out-of-thin-air", or "speculative" stores of atomics when relaxed atomics are
 | |
|      used. Since unordered operations are involved, evaluations can appear in this sequence out of thread order. For example,
 | |
|      with x and y initially zero,
 | |
|                // Thread 1:
 | |
|                r1 = atomic_load_explicit(&y, memory_order_relaxed);
 | |
|                atomic_store_explicit(&x, r1, memory_order_relaxed);
 | |
| 
 | |
|                // Thread 2:
 | |
|                r2 = atomic_load_explicit(&x, memory_order_relaxed);
 | |
|                atomic_store_explicit(&y, 42, memory_order_relaxed);
 | |
| 
 | |
|      is allowed to produce r1 == 42 && r2 == 42. The sequence of evaluations justifying this consists of:
 | |
| 
 | |
|                atomic_store_explicit(&y, 42, memory_order_relaxed);
 | |
|                r1 = atomic_load_explicit(&y, memory_order_relaxed);
 | |
|                atomic_store_explicit(&x, r1, memory_order_relaxed);
 | |
|                r2 = atomic_load_explicit(&x, memory_order_relaxed);
 | |
| 
 | |
|      On the other hand,
 | |
| 
 | |
|                // Thread 1:
 | |
|                r1 = atomic_load_explicit(&y, memory_order_relaxed);
 | |
|                atomic_store_explicit(&x, r1, memory_order_relaxed);
 | |
| 
 | |
|                // Thread 2:
 | |
|                r2 = atomic_load_explicit(&x, memory_order_relaxed);
 | |
|                atomic_store_explicit(&y, r2, memory_order_relaxed);
 | |
| 
 | |
|      is not allowed to produce r1 == 42 && r2 == 42, since there is no sequence of evaluations that results in the computation
 | |
|      of 42. In the absence of "relaxed" operations and read-modify-write operations with weaker than memory_order_acq_rel
 | |
|      ordering, the second requirement has no impact.
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='7.17.3p15'></a>
 | |
| <pre>15   The requirements do not forbid r1 == 42 && r2 == 42 in the following example, with x and y
 | |
|      initially zero:
 | |
| 
 | |
|                // Thread 1:
 | |
|                r1 = atomic_load_explicit(&x, memory_order_relaxed);
 | |
|                if (r1 == 42)
 | |
|                      atomic_store_explicit(&y, r1, memory_order_relaxed);
 | |
| 
 | |
|                // Thread 2:
 | |
|                r2 = atomic_load_explicit(&y, memory_order_relaxed);
 | |
|                if (r2 == 42)
 | |
|                      atomic_store_explicit(&x, 42, memory_order_relaxed);
 | |
| 
 | |
| 
 | |
|      However, this is not useful behavior, and implementations should not allow it.
 | |
| </pre>
 | |
| <a name='7.17.3p16'></a>
 | |
| <pre>16   Implementations should make atomic stores visible to atomic loads within a reasonable amount of
 | |
|      time.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.17.3.1 [The kill_dependency macro]</h3>
 | |
| <a name='7.17.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdatomic.h>
 | |
|                type kill_dependency(type y);
 | |
| 
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='7.17.3.1p2'></a>
 | |
| <pre>2    The kill_dependency macro terminates a dependency chain; the argument does not carry a depen-
 | |
|      dency to the return value.
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='7.17.3.1p3'></a>
 | |
| <pre>3    The kill_dependency macro returns the value of y.
 | |
| </pre>
 | |
| <a name='7.17.4'></a>
 | |
| <hr>
 | |
| <h3>7.17.4 [Fences]</h3>
 | |
| <a name='7.17.4p1'></a>
 | |
| <pre>1   This subclause introduces synchronization primitives called fences. Fences can have acquire seman-
 | |
|     tics, release semantics, or both. A fence with acquire semantics is called an acquire fence; a fence with
 | |
|     release semantics is called a release fence.
 | |
| </pre>
 | |
| <a name='7.17.4p2'></a>
 | |
| <pre>2   A release fence A synchronizes with an acquire fence B if there exist atomic operations X and Y ,
 | |
|     both operating on some atomic object M , such that A is sequenced before X, X modifies M , Y is
 | |
|     sequenced before B, and Y reads the value written by X or a value written by any side effect in the
 | |
|     hypothetical release sequence X would head if it were a release operation.
 | |
| </pre>
 | |
| <a name='7.17.4p3'></a>
 | |
| <pre>3   A release fence A synchronizes with an atomic operation B that performs an acquire operation on an
 | |
|     atomic object M if there exists an atomic operation X such that A is sequenced before X, X modifies
 | |
|     M , and B reads the value written by X or a value written by any side effect in the hypothetical
 | |
|     release sequence X would head if it were a release operation.
 | |
| </pre>
 | |
| <a name='7.17.4p4'></a>
 | |
| <pre>4   An atomic operation A that is a release operation on an atomic object M synchronizes with an
 | |
|     acquire fence B if there exists some atomic operation X on M such that X is sequenced before B
 | |
|     and reads the value written by A or a value written by any side effect in the release sequence headed
 | |
|     by A.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.17.4.1 [The atomic_thread_fence function]</h3>
 | |
| <a name='7.17.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdatomic.h>
 | |
|              void atomic_thread_fence(memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.4.1p2'></a>
 | |
| <pre>2   Depending on the value of order, this operation:
 | |
| 
 | |
|       — has no effects, if order == memory_order_relaxed;
 | |
| 
 | |
|       — is an acquire fence, if order == memory_order_acquire or order == memory_order_consume;
 | |
| 
 | |
|       — is a release fence, if order == memory_order_release;
 | |
| 
 | |
|       — is both an acquire fence and a release fence, if order == memory_order_acq_rel;
 | |
| 
 | |
|       — is a sequentially consistent acquire and release fence, if order == memory_order_seq_cst.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.4.1p3'></a>
 | |
| <pre>3   The atomic_thread_fence function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.17.4.2 [The atomic_signal_fence function]</h3>
 | |
| <a name='7.17.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdatomic.h>
 | |
|              void atomic_signal_fence(memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.4.2p2'></a>
 | |
| <pre>2   Equivalent to atomic_thread_fence(order), except that the resulting ordering constraints are
 | |
|     established only between a thread and a signal handler executed in the same thread.
 | |
| </pre>
 | |
| <a name='7.17.4.2p3'></a>
 | |
| <pre>3   NOTE 1 The atomic_signal_fence function can be used to specify the order in which actions performed by the thread
 | |
|     become visible to the signal handler.
 | |
| </pre>
 | |
| <a name='7.17.4.2p4'></a>
 | |
| <pre>4   NOTE 2 Compiler optimizations and reorderings of loads and stores are inhibited in the same way as with
 | |
|     atomic_thread_fence, but the hardware fence instructions that atomic_thread_fence would have inserted are not
 | |
|     emitted.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.4.2p5'></a>
 | |
| <pre>5   The atomic_signal_fence function returns no value.
 | |
| </pre>
 | |
| <a name='7.17.5'></a>
 | |
| <hr>
 | |
| <h3>7.17.5 [Lock-free property]</h3>
 | |
| <a name='7.17.5p1'></a>
 | |
| <pre>1   The atomic lock-free macros indicate the lock-free property of integer and address atomic types. A
 | |
|     value of 0 indicates that the type is never lock-free; a value of 1 indicates that the type is sometimes
 | |
|     lock-free; a value of 2 indicates that the type is always lock-free.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.17.5p2'></a>
 | |
| <pre>2   Operations that are lock-free should also be address-free. That is, atomic operations on the same
 | |
|     memory location via two different addresses will communicate atomically. The implementation
 | |
|     should not depend on any per-process state. This restriction enables communication via memory
 | |
|     mapped into a process more than once and memory shared between two processes.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.17.5.1 [The atomic_is_lock_free generic function]</h3>
 | |
| <a name='7.17.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdatomic.h>
 | |
|               bool atomic_is_lock_free(const volatile A *obj);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.5.1p2'></a>
 | |
| <pre>2   The atomic_is_lock_free generic function indicates whether or not atomic operations on objects
 | |
|     of the type pointed to by obj are lock-free.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.5.1p3'></a>
 | |
| <pre>3   The atomic_is_lock_free generic function returns nonzero (true) if and only if atomic operations
 | |
|     on objects of the type pointed to by the argument are lock-free. In any given program execution, the
 | |
|     result of the lock-free query shall be consistent for all pointers of the same type.<a href='#FOOTNOTE.316'><sup>[316]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.316'>
 | |
| <pre><i><b>Footnote 316)</b> obj can be a null pointer.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.17.6'></a>
 | |
| <hr>
 | |
| <h3>7.17.6 [Atomic integer types]</h3>
 | |
| <a name='7.17.6p1'></a>
 | |
| <pre>1   For each line in the following table,<a href='#FOOTNOTE.317'><sup>[317]</sup></a> the atomic type name is declared as a type that has the same
 | |
|     representation and alignment requirements as the corresponding direct type.<a href='#FOOTNOTE.318'><sup>[318]</sup></a>
 | |
| 
 | |
|            Atomic type name                       Direct type
 | |
|            atomic_bool                            _Atomic bool
 | |
|            atomic_char                            _Atomic char
 | |
|            atomic_schar                           _Atomic signed char
 | |
|            atomic_uchar                           _Atomic unsigned char
 | |
|            atomic_short                           _Atomic short
 | |
|            atomic_ushort                          _Atomic unsigned short
 | |
|            atomic_int                             _Atomic int
 | |
|            atomic_uint                            _Atomic unsigned int
 | |
|            atomic_long                            _Atomic long
 | |
|            atomic_ulong                           _Atomic unsigned long
 | |
|            atomic_llong                           _Atomic long long
 | |
|            atomic_ullong                          _Atomic unsigned long long
 | |
|            atomic_char8_t                         _Atomic char8_t
 | |
|            atomic_char16_t                        _Atomic char16_t
 | |
|            atomic_char32_t                        _Atomic char32_t
 | |
|            atomic_wchar_t                         _Atomic wchar_t
 | |
|            atomic_int_least8_t                    _Atomic int_least8_t
 | |
|            atomic_uint_least8_t                   _Atomic uint_least8_t
 | |
|            atomic_int_least16_t                   _Atomic int_least16_t
 | |
|            atomic_uint_least16_t                  _Atomic uint_least16_t
 | |
|            atomic_int_least32_t                   _Atomic int_least32_t
 | |
|           Atomic type name             Direct type
 | |
|           atomic_uint_least32_t        _Atomic uint_least32_t
 | |
|           atomic_int_least64_t         _Atomic int_least64_t
 | |
|           atomic_uint_least64_t        _Atomic uint_least64_t
 | |
|           atomic_int_fast8_t           _Atomic int_fast8_t
 | |
|           atomic_uint_fast8_t          _Atomic uint_fast8_t
 | |
|           atomic_int_fast16_t          _Atomic int_fast16_t
 | |
|           atomic_uint_fast16_t         _Atomic uint_fast16_t
 | |
|           atomic_int_fast32_t          _Atomic int_fast32_t
 | |
|           atomic_uint_fast32_t         _Atomic uint_fast32_t
 | |
|           atomic_int_fast64_t          _Atomic int_fast64_t
 | |
|           atomic_uint_fast64_t         _Atomic uint_fast64_t
 | |
|           atomic_intptr_t              _Atomic intptr_t
 | |
|           atomic_uintptr_t             _Atomic uintptr_t
 | |
|           atomic_size_t                _Atomic size_t
 | |
|           atomic_ptrdiff_t             _Atomic ptrdiff_t
 | |
|           atomic_intmax_t              _Atomic intmax_t
 | |
|           atomic_uintmax_t             _Atomic uintmax_t
 | |
| 
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.317'>
 | |
| <pre><i><b>Footnote 317)</b> See "future library directions" (<a href='#7.33.10'>7.33.10</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.318'>
 | |
| <pre><i><b>Footnote 318)</b> The same representation and alignment requirements are meant to imply interchangeability as arguments to functions,
 | |
|     return values from functions, and members of unions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.17.6p2'></a>
 | |
| <pre>2   The representation of an atomic integer type is not required to have the same size as the correspond-
 | |
|     ing regular type but it should have the same size whenever possible, as it eases effort required to
 | |
|     port existing code.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.7'></a>
 | |
| <hr>
 | |
| <h3>7.17.7 [Operations on atomic types]</h3>
 | |
| <a name='7.17.7p1'></a>
 | |
| <pre>1   There are only a few kinds of operations on atomic types, though there are many instances of those
 | |
|     kinds. This subclause specifies each general kind.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.7.1'></a>
 | |
| <hr>
 | |
| <h3>7.17.7.1 [The atomic_store generic functions]</h3>
 | |
| <a name='7.17.7.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdatomic.h>
 | |
|              void atomic_store(volatile A *object, C desired);
 | |
|              void atomic_store_explicit(volatile A *object, C desired, memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.7.1p2'></a>
 | |
| <pre>2   The order argument shall not be memory_order_acquire, memory_order_consume, nor
 | |
|     memory_order_acq_rel. Atomically replace the value pointed to by object with the value of
 | |
|     desired. Memory is affected according to the value of order.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.7.1p3'></a>
 | |
| <pre>3   The atomic_store generic functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.7.2'></a>
 | |
| <hr>
 | |
| <h3>7.17.7.2 [The atomic_load generic functions]</h3>
 | |
| <a name='7.17.7.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdatomic.h>
 | |
|              C atomic_load(const volatile A *object);
 | |
|              C atomic_load_explicit(const volatile A *object, memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.7.2p2'></a>
 | |
| <pre>2   The order argument shall not be memory_order_release nor memory_order_acq_rel. Memory is
 | |
|     affected according to the value of order.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.7.2p3'></a>
 | |
| <pre>3   Atomically returns the value pointed to by object.
 | |
| </pre>
 | |
| <a name='7.17.7.3'></a>
 | |
| <hr>
 | |
| <h3>7.17.7.3 [The atomic_exchange generic functions]</h3>
 | |
| <a name='7.17.7.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdatomic.h>
 | |
|              C atomic_exchange(volatile A *object, C desired);
 | |
|              C atomic_exchange_explicit(volatile A *object, C desired, memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.7.3p2'></a>
 | |
| <pre>2   Atomically replace the value pointed to by object with desired. Memory is affected according to
 | |
|     the value of order. These operations are read-modify-write operations (<a href='#5.1.2.4'>5.1.2.4</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.7.3p3'></a>
 | |
| <pre>3   Atomically returns the value pointed to by object immediately before the effects.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.7.4'></a>
 | |
| <hr>
 | |
| <h3>7.17.7.4 [The atomic_compare_exchange generic functions]</h3>
 | |
| <a name='7.17.7.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdatomic.h>
 | |
|              bool atomic_compare_exchange_strong(volatile A *object, C *expected, C desired);
 | |
|              bool atomic_compare_exchange_strong_explicit(volatile A *object, C *expected,
 | |
|                    C desired, memory_order success, memory_order failure);
 | |
|              bool atomic_compare_exchange_weak(volatile A *object, C *expected, C desired);
 | |
|              bool atomic_compare_exchange_weak_explicit(volatile A *object, C *expected,
 | |
|                    C desired, memory_order success, memory_order failure);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.7.4p2'></a>
 | |
| <pre>2   The failure argument shall not be memory_order_release nor memory_order_acq_rel. The
 | |
|     failure argument shall be no stronger than the success argument.
 | |
| </pre>
 | |
| <a name='7.17.7.4p3'></a>
 | |
| <pre>3   Atomically, compares the contents of the memory pointed to by object for equality with that
 | |
|     pointed to by expected, and if true, replaces the contents of the memory pointed to by object
 | |
|     with desired, and if false, updates the contents of the memory pointed to by expected with that
 | |
|     pointed to by object. Further, if the comparison is true, memory is affected according to the value
 | |
|     of success, and if the comparison is false, memory is affected according to the value of failure.
 | |
|     These operations are atomic read-modify-write operations (<a href='#5.1.2.4'>5.1.2.4</a>).
 | |
| </pre>
 | |
| <a name='7.17.7.4p4'></a>
 | |
| <pre>4   NOTE 1 For example, the effect of atomic_compare_exchange_strong is
 | |
| 
 | |
|              if (memcmp(object, expected, sizeof (*object)) == 0)
 | |
|                    memcpy(object, &desired, sizeof (*object));
 | |
|              else
 | |
|                    memcpy(expected, object, sizeof (*object));
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.7.4p5'></a>
 | |
| <pre>5   A weak compare-and-exchange operation may fail spuriously. That is, even when the contents
 | |
|     of memory referred to by expected and object are equal, it may return zero and store back to
 | |
|     expected the same memory contents that were originally there.
 | |
| </pre>
 | |
| <a name='7.17.7.4p6'></a>
 | |
| <pre>6   NOTE 2 This spurious failure enables implementation of compare-and-exchange on a broader class of machines, e.g.
 | |
|     load-locked store-conditional machines.
 | |
| </pre>
 | |
| <a name='7.17.7.4p7'></a>
 | |
| <pre>7   EXAMPLE A consequence of spurious failure is that nearly all uses of weak compare-and-exchange will be in a loop.
 | |
| 
 | |
|               exp = atomic_load(&cur);
 | |
|               do {
 | |
|                     des = function(exp);
 | |
|               } while (!atomic_compare_exchange_weak(&cur, &exp, des));
 | |
| 
 | |
|     When a compare-and-exchange is in a loop, the weak version will yield better performance on some platforms. When a weak
 | |
|     compare-and-exchange would require a loop and a strong one would not, the strong one is preferable.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.7.4p8'></a>
 | |
| <pre>8   The result of the comparison.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.7.5'></a>
 | |
| <hr>
 | |
| <h3>7.17.7.5 [The atomic_fetch and modify generic functions]</h3>
 | |
| <a name='7.17.7.5p1'></a>
 | |
| <pre>1   The following operations perform arithmetic and bitwise computations. All of these operations
 | |
|     are applicable to an object of any atomic integer type. None of these operations is applicable to
 | |
|     atomic_bool. The key, operator, and computation correspondence is:
 | |
| 
 | |
| 
 | |
|      key op         computation
 | |
|      add +          addition
 | |
|      sub -          subtraction
 | |
|      or   |         bitwise inclusive or
 | |
|      xor ^          bitwise exclusive or
 | |
|      and &          bitwise and
 | |
| 
 | |
|     Synopsis
 | |
| </pre>
 | |
| <a name='7.17.7.5p2'></a>
 | |
| <pre>2             #include <stdatomic.h>
 | |
|               C atomic_fetch_key(volatile A *object, M operand);
 | |
|               C atomic_fetch_key_explicit(volatile A *object, M operand, memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.7.5p3'></a>
 | |
| <pre>3   Atomically replaces the value pointed to by object with the result of the computation applied to
 | |
|     the value pointed to by object and the given operand. Memory is affected according to the value
 | |
|     of order. These operations are atomic read-modify-write operations (<a href='#5.1.2.4'>5.1.2.4</a>). For signed integer
 | |
|     types, arithmetic performs silent wraparound on integer overflow; there are no undefined results.
 | |
|     For address types, the result may be an undefined address, but the operations otherwise have no
 | |
|     undefined behavior.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.7.5p4'></a>
 | |
| <pre>4   Atomically, the value pointed to by object immediately before the effects.
 | |
| </pre>
 | |
| <a name='7.17.7.5p5'></a>
 | |
| <pre>5   NOTE The operation of the atomic_fetch and modify generic functions are nearly equivalent to the operation of the
 | |
|     corresponding op= compound assignment operators. The only differences are that the compound assignment operators are
 | |
|     not guaranteed to operate atomically, and the value yielded by a compound assignment operator is the updated value of the
 | |
|     object, whereas the value returned by the atomic_fetch and modify generic functions is the previous value of the atomic
 | |
|     object.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.8'></a>
 | |
| <hr>
 | |
| <h3>7.17.8 [Atomic flag type and operations]</h3>
 | |
| <a name='7.17.8p1'></a>
 | |
| <pre>1   The atomic_flag type provides the classic test-and-set functionality. It has two states, set and clear.
 | |
| </pre>
 | |
| <a name='7.17.8p2'></a>
 | |
| <pre>2   Operations on an object of type atomic_flag shall be lock free.
 | |
| </pre>
 | |
| <a name='7.17.8p3'></a>
 | |
| <pre>3   NOTE Hence, as per <a href='#7.17.5'>7.17.5</a>, the operations should also be address-free. No other type requires lock-free operations, so the
 | |
|     atomic_flag type is the minimum hardware-implemented type needed to conform to this document. The remaining types
 | |
|     can be emulated with atomic_flag, though with less than ideal properties.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.8p4'></a>
 | |
| <pre>4   The macro ATOMIC_FLAG_INIT may be used to initialize an atomic_flag to the clear state. An
 | |
|     atomic_flag that is not explicitly initialized with ATOMIC_FLAG_INIT has initially an indeterminate
 | |
|     representation.
 | |
| </pre>
 | |
| <a name='7.17.8p5'></a>
 | |
| <pre>5   EXAMPLE
 | |
|             atomic_flag guard = ATOMIC_FLAG_INIT;
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.8.1'></a>
 | |
| <hr>
 | |
| <h3>7.17.8.1 [The atomic_flag_test_and_set functions]</h3>
 | |
| <a name='7.17.8.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|     #include <stdatomic.h>
 | |
|            bool atomic_flag_test_and_set(volatile atomic_flag *object);
 | |
|            bool atomic_flag_test_and_set_explicit(volatile atomic_flag *object,
 | |
|                  memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.8.1p2'></a>
 | |
| <pre>2   Atomically places the atomic flag pointed to by object in the set state and returns the value
 | |
|     corresponding to the immediately preceding state. Memory is affected according to the value of
 | |
|     order. These operations are atomic read-modify-write operations (<a href='#5.1.2.4'>5.1.2.4</a>).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.8.1p3'></a>
 | |
| <pre>3   The atomic_flag_test_and_set functions return the value that corresponds to the state of the
 | |
|     atomic flag immediately before the effects. The return value true corresponds to the set state and the
 | |
|     return value false corresponds to the clear state.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.17.8.2'></a>
 | |
| <hr>
 | |
| <h3>7.17.8.2 [The atomic_flag_clear functions]</h3>
 | |
| <a name='7.17.8.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdatomic.h>
 | |
|             void atomic_flag_clear(volatile atomic_flag *object);
 | |
|             void atomic_flag_clear_explicit(volatile atomic_flag *object,
 | |
|                   memory_order order);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.17.8.2p2'></a>
 | |
| <pre>2   The order argument shall not be memory_order_acquire nor memory_order_acq_rel. Atomically
 | |
|     places the atomic flag pointed to by object into the clear state. Memory is affected according to the
 | |
|     value of order.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.17.8.2p3'></a>
 | |
| <pre>3   The atomic_flag_clear functions return no value.
 | |
| </pre>
 | |
| <a name='7.18'></a>
 | |
| <hr>
 | |
| <h3>7.18 [Bit and byte utilities <stdbit.h>]</h3>
 | |
| <a name='7.18.1'></a>
 | |
| <hr>
 | |
| <h3>7.18.1 [General]</h3>
 | |
| <a name='7.18.1p1'></a>
 | |
| <pre>1   The header <stdbit.h> defines the following macros, types, and functions, to work with the byte
 | |
|     and bit representation of many types, typically integer types. This header makes available the
 | |
|     size_t type name (<a href='#7.21'>7.21</a>) and any uintN_t, intN_t, uint_leastN_t, or int_leastN_t type names
 | |
|     defined by the implementation (<a href='#7.22'>7.22</a>).
 | |
| </pre>
 | |
| <a name='7.18.1p2'></a>
 | |
| <pre>2   The most significant index is the 0-based index counting from the most significant bit, 0, to the
 | |
|     least significant bit, w − 1, where w is the width of the type that is having its most significant index
 | |
|     computed.
 | |
| </pre>
 | |
| <a name='7.18.1p3'></a>
 | |
| <pre>3   The least significant index is the 0-based index counting from the least significant bit, 0, to the
 | |
|     most significant bit, w − 1, where w is the width of the type that is having its least significant index
 | |
|     computed.
 | |
| </pre>
 | |
| <a name='7.18.1p4'></a>
 | |
| <pre>4   It is unspecified whether any generic function declared in <stdbit.h> is a macro or an identifier
 | |
|     declared with external linkage. If a macro definition is suppressed in order to access an actual
 | |
|     function, or a program defines an external identifier with the name of a generic function, the
 | |
|     behavior is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.2'></a>
 | |
| <hr>
 | |
| <h3>7.18.2 [Endian]</h3>
 | |
| <a name='7.18.2p1'></a>
 | |
| <pre>1   Two common methods of byte ordering in multi-byte scalar types are little-endian and big-endian.
 | |
|     Little-endian is a format for storage of binary data in which the least significant byte is placed
 | |
|     first, with the rest in ascending order. Or, that the least significant byte is stored at the smallest
 | |
|     memory address. Big-endian is a format for storage or transmission of binary data in which the
 | |
|     most significant byte is placed first, with the rest in descending order. Or, that the most significant
 | |
|     byte is stored at the smallest memory address. Other byte orderings are also possible.
 | |
| </pre>
 | |
| <a name='7.18.2p2'></a>
 | |
| <pre>2   The macros are:
 | |
|              __STDC_ENDIAN_LITTLE__
 | |
| 
 | |
| 
 | |
|     which represents a method of byte order storage least significant byte is placed first and the rest are
 | |
|     in ascending order, and is an integer constant expression;
 | |
|              __STDC_ENDIAN_BIG__
 | |
| 
 | |
| 
 | |
|     which represents a method of byte order storage most significant byte is placed first and the rest are
 | |
|     in descending order, and is an integer constant expression;
 | |
|              __STDC_ENDIAN_NATIVE__ /* see below */
 | |
| 
 | |
| 
 | |
|     which represents the method of byte order storage for the execution environment and is an integer
 | |
|     constant expression.
 | |
| </pre>
 | |
| <a name='7.18.2p3'></a>
 | |
| <pre>3   __STDC_ENDIAN_NATIVE__ shall expand to an integer constant expression whose value is equiv-
 | |
|     alent to the value of __STDC_ENDIAN_LITTLE__ if the execution environment is little-endian.
 | |
|     Otherwise, __STDC_ENDIAN_NATIVE__ shall expand to an integer constant expression whose
 | |
|     value is equivalent to the value of __STDC_ENDIAN_BIG__ if the execution environment is big-
 | |
|     endian. If __STDC_ENDIAN_NATIVE__ is not equivalent to either, then the byte order for the exe-
 | |
|     cution environment is implementation-defined. The value of the integer constant expression for
 | |
|     __STDC_ENDIAN_LITTLE__ and __STDC_ENDIAN_BIG__ are not equal.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.3'></a>
 | |
| <hr>
 | |
| <h3>7.18.3 [Count Leading Zeros]</h3>
 | |
| <a name='7.18.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdbit.h>
 | |
|              int stdc_leading_zerosuc(unsigned char value);
 | |
|              int stdc_leading_zerosus(unsigned short value);
 | |
|              int stdc_leading_zerosui(unsigned int value);
 | |
|              int stdc_leading_zerosul(unsigned long value);
 | |
|              int stdc_leading_zerosull(unsigned long long value);
 | |
|              generic_return_type stdc_leading_zeros(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the number of consecutive 0 bits in value, starting from the most significant bit.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
| 
 | |
|       — extended unsigned integer type;
 | |
| 
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.4'></a>
 | |
| <hr>
 | |
| <h3>7.18.4 [Count Leading Ones]</h3>
 | |
| <a name='7.18.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdbit.h>
 | |
|              int stdc_leading_onesuc(unsigned char value);
 | |
|              int stdc_leading_onesus(unsigned short value);
 | |
|              int stdc_leading_onesui(unsigned int value);
 | |
|              int stdc_leading_onesul(unsigned long value);
 | |
|              int stdc_leading_onesull(unsigned long long value);
 | |
|              generic_return_type stdc_leading_ones(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the number of consecutive 1 bits in value, starting from the most significant bit.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
| 
 | |
|       — extended unsigned integer type;
 | |
| 
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.5'></a>
 | |
| <hr>
 | |
| <h3>7.18.5 [Count Trailing Zeros]</h3>
 | |
| <a name='7.18.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdbit.h>
 | |
|              int stdc_trailing_zerosuc(unsigned char value);
 | |
|              int stdc_trailing_zerosus(unsigned short value);
 | |
|              int stdc_trailing_zerosui(unsigned int value);
 | |
|              int stdc_trailing_zerosul(unsigned long value);
 | |
|              int stdc_trailing_zerosull(unsigned long long value);
 | |
|              generic_return_type stdc_trailing_zeros(generic_value_type value);
 | |
|     Returns
 | |
|     Returns the number of consecutive 0 bits in value, starting from the least significant bit.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
|       — extended unsigned integer type;
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.6'></a>
 | |
| <hr>
 | |
| <h3>7.18.6 [Count Trailing Ones]</h3>
 | |
| <a name='7.18.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdbit.h>
 | |
|              int stdc_trailing_onesuc(unsigned char value);
 | |
|              int stdc_trailing_onesus(unsigned short value);
 | |
|              int stdc_trailing_onesui(unsigned int value);
 | |
|              int stdc_trailing_onesul(unsigned long value);
 | |
|              int stdc_trailing_onesull(unsigned long long value);
 | |
|              generic_return_type stdc_trailing_ones(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the number of consecutive 1 bits in value, starting from the least significant bit.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
|       — extended unsigned integer type;
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.7'></a>
 | |
| <hr>
 | |
| <h3>7.18.7 [First Leading Zero]</h3>
 | |
| <a name='7.18.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdbit.h>
 | |
|              int stdc_first_leading_zerouc(unsigned char value);
 | |
|              int stdc_first_leading_zerous(unsigned short value);
 | |
|              int stdc_first_leading_zeroui(unsigned int value);
 | |
|              int stdc_first_leading_zeroul(unsigned long value);
 | |
|              int stdc_first_leading_zeroull(unsigned long long value);
 | |
|              generic_return_type stdc_first_leading_zero(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the most significant index of the first 0 bit in value, plus 1. If it is not found, this function
 | |
|     returns 0.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
|       — standard unsigned integer type, excluding bool;
 | |
| 
 | |
|       — extended unsigned integer type;
 | |
| 
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.8'></a>
 | |
| <hr>
 | |
| <h3>7.18.8 [First Leading One]</h3>
 | |
| <a name='7.18.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdbit.h>
 | |
|              int stdc_first_leading_oneuc(unsigned char value);
 | |
|              int stdc_first_leading_oneus(unsigned short value);
 | |
|              int stdc_first_leading_oneui(unsigned int value);
 | |
|              int stdc_first_leading_oneul(unsigned long value);
 | |
|              int stdc_first_leading_oneull(unsigned long long value);
 | |
|              generic_return_type stdc_first_leading_one(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the most significant index of the first 1 bit in value, plus 1. If it is not found, this function
 | |
|     returns 0.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
| 
 | |
|       — extended unsigned integer type;
 | |
| 
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.9'></a>
 | |
| <hr>
 | |
| <h3>7.18.9 [First Trailing Zero]</h3>
 | |
| <a name='7.18.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdbit.h>
 | |
|              int stdc_first_trailing_zerouc(unsigned char value);
 | |
|              int stdc_first_trailing_zerous(unsigned short value);
 | |
|              int stdc_first_trailing_zeroui(unsigned int value);
 | |
|              int stdc_first_trailing_zeroul(unsigned long value);
 | |
|              int stdc_first_trailing_zeroull(unsigned long long value);
 | |
|              generic_return_type stdc_first_trailing_zero(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the least significant index of the first 0 bit in value, plus 1. If it is not found, this function
 | |
|     returns 0.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
| 
 | |
|       — extended unsigned integer type;
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.10'></a>
 | |
| <hr>
 | |
| <h3>7.18.10 [First Trailing One]</h3>
 | |
| <a name='7.18.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdbit.h>
 | |
|               int stdc_first_trailing_oneuc(unsigned char value);
 | |
|               int stdc_first_trailing_oneus(unsigned short value);
 | |
|               int stdc_first_trailing_oneui(unsigned int value);
 | |
|               int stdc_first_trailing_oneul(unsigned long value);
 | |
|               int stdc_first_trailing_oneull(unsigned long long value);
 | |
|               generic_return_type stdc_first_trailing_one(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the least significant index of the first 1 bit in value, plus 1. If it is not found, this function
 | |
|     returns 0.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the appropriate
 | |
|     value based on the type of the input value, so long as it is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
|       — extended unsigned integer type;
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.11'></a>
 | |
| <hr>
 | |
| <h3>7.18.11 [Count Ones]</h3>
 | |
| <a name='7.18.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdbit.h>
 | |
|               int stdc_count_onesuc(unsigned char value);
 | |
|               int stdc_count_onesus(unsigned short value);
 | |
|               int stdc_count_onesui(unsigned int value);
 | |
|               int stdc_count_onesul(unsigned long value);
 | |
|               int stdc_count_onesull(unsigned long long value);
 | |
|               generic_return_type stdc_count_ones(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the total number of 1 bits within the given value.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the previously
 | |
|     described result for a given input value so long as the generic_value_type is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
|       — extended unsigned integer type;
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type shall be a suitably large signed integer type capable of representing
 | |
|     the computed result.
 | |
| </pre>
 | |
| <a name='7.18.12'></a>
 | |
| <hr>
 | |
| <h3>7.18.12 [Count Zeros]</h3>
 | |
| <a name='7.18.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdbit.h>
 | |
|               int stdc_count_zerosuc(unsigned char value);
 | |
|               int stdc_count_zerosus(unsigned short value);
 | |
|               int stdc_count_zerosui(unsigned int value);
 | |
|               int stdc_count_zerosul(unsigned long value);
 | |
|               int stdc_count_zerosull(unsigned long long value);
 | |
|               generic_return_type stdc_count_zeros(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     Returns the total number of 0 bits within the given value.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the previously
 | |
|     described result for a given input value so long as the generic_value_type is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
|       — extended unsigned integer type;
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type for the type-generic function need not be the same as the type of
 | |
|     value. It shall be suitably large unsigned integer type capable of representing the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.13'></a>
 | |
| <hr>
 | |
| <h3>7.18.13 [Single-bit Check]</h3>
 | |
| <a name='7.18.13p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdbit.h>
 | |
|               bool stdc_has_single_bituc(unsigned char value);
 | |
|               bool stdc_has_single_bitus(unsigned short value);
 | |
|               bool stdc_has_single_bitui(unsigned int value);
 | |
|               bool stdc_has_single_bitul(unsigned long value);
 | |
|               bool stdc_has_single_bitull(unsigned long long value);
 | |
|               bool stdc_has_single_bit(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
|     The stdc_has_single_bit functions returns true if and only if there is a single 1 bit in value.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the previously
 | |
|     described result for a given input value so long as the generic_value_type is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
|       — extended unsigned integer type;
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.14'></a>
 | |
| <hr>
 | |
| <h3>7.18.14 [Bit Width]</h3>
 | |
| <a name='7.18.14p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdbit.h>
 | |
|               int stdc_bit_widthuc(unsigned char value);
 | |
|               int stdc_bit_widthus(unsigned short value);
 | |
|               int stdc_bit_widthui(unsigned int value);
 | |
|               int stdc_bit_widthul(unsigned long value);
 | |
|               int stdc_bit_widthull(unsigned long long value);
 | |
|               generic_return_type stdc_bit_width(generic_value_type value);
 | |
|     Description
 | |
|     The stdc_bit_width functions compute the smallest number of bits needed to store value.
 | |
| 
 | |
|     Returns
 | |
|     The stdc_bit_width functions return 0 if value is 0. Otherwise, they return 1 + ⌊log2(value)⌋.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the previously
 | |
|     described result for a given input value so long as the generic_value_type is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
| 
 | |
|       — extended unsigned integer type;
 | |
| 
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
|     The generic_return_type type for the type-generic function need not be the same as the type of
 | |
|     value. It shall be suitably large signed integer type capable of representing the computed result.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.15'></a>
 | |
| <hr>
 | |
| <h3>7.18.15 [Bit Floor]</h3>
 | |
| <a name='7.18.15p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdbit.h>
 | |
|               unsigned char stdc_bit_flooruc(unsigned char value);
 | |
|               unsigned short stdc_bit_floorus(unsigned short value);
 | |
|               unsigned int stdc_bit_floorui(unsigned int value);
 | |
|               unsigned long stdc_bit_floorul(unsigned long value);
 | |
|               unsigned long long stdc_bit_floorull(unsigned long long value);
 | |
|               generic_value_type stdc_bit_floor(generic_value_type value);
 | |
| 
 | |
| 
 | |
|     Description
 | |
|     The stdc_bit_floor functions compute the largest integral power of 2 that is not greater than
 | |
|     value.
 | |
| 
 | |
|     Returns
 | |
|     The stdc_bit_floor functions return 0 if value is 0. Otherwise, they return the largest integral
 | |
|     power of 2 that is not greater than value.
 | |
|     The type-generic function (marked by its generic_value_type argument) returns the previously
 | |
|     described result for a given input value so long as the generic_value_type is an:
 | |
| 
 | |
|       — standard unsigned integer type, excluding bool;
 | |
| 
 | |
|       — extended unsigned integer type;
 | |
| 
 | |
|       — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|         type, excluding bool.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.18.16'></a>
 | |
| <hr>
 | |
| <h3>7.18.16 [Bit Ceiling]</h3>
 | |
| <a name='7.18.16p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdbit.h>
 | |
|               unsigned char stdc_bit_ceiluc(unsigned char value);
 | |
|               unsigned short stdc_bit_ceilus(unsigned short value);
 | |
|               unsigned int stdc_bit_ceilui(unsigned int value);
 | |
|               unsigned long stdc_bit_ceilul(unsigned long value);
 | |
|               unsigned long long stdc_bit_ceilull(unsigned long long value);
 | |
|               generic_value_type stdc_bit_ceil(generic_value_type value);
 | |
| Description
 | |
| The stdc_bit_ceil functions compute the smallest integral power of 2 that is not less than value.
 | |
| If the computation does not fit in the given return type, the behavior is undefined.
 | |
| 
 | |
| Returns
 | |
| The stdc_bit_ceil functions return the smallest integral power of 2 that is not less than value.
 | |
| The type-generic function (marked by its generic_value_type argument) returns the previously
 | |
| described result for a given input value so long as the generic_value_type is an:
 | |
| 
 | |
|   — standard unsigned integer type, excluding bool;
 | |
|   — extended unsigned integer type;
 | |
| 
 | |
|   — or, bit-precise unsigned integer type whose width matches a standard or extended integer
 | |
|     type, excluding bool.
 | |
| </pre>
 | |
| <a name='7.19'></a>
 | |
| <hr>
 | |
| <h3>7.19 [Boolean type and values <stdbool.h>]</h3>
 | |
| <a name='7.19p1'></a>
 | |
| <pre>1   The header <stdbool.h> provides the obsolescent macro __bool_true_false_are_defined which
 | |
|     expands to the integer constant 1.
 | |
| </pre>
 | |
| <a name='7.20'></a>
 | |
| <hr>
 | |
| <h3>7.20 [Checked Integer Arithmetic <stdckdint.h>]</h3>
 | |
| <a name='7.20p1'></a>
 | |
| <pre>1   The header <stdckdint.h> defines several macros for performing checked integer arithmetic.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.20.1'></a>
 | |
| <hr>
 | |
| <h3>7.20.1 [The ckd_ Checked Integer Operation Macros]</h3>
 | |
| <a name='7.20.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdckdint.h>
 | |
|               bool ckd_add(type1 *result, type2 a, type3 b);
 | |
|               bool ckd_sub(type1 *result, type2 a, type3 b);
 | |
|               bool ckd_mul(type1 *result, type2 a, type3 b);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.20.1p2'></a>
 | |
| <pre>2   These macros perform addition, subtraction, or multiplication of the mathematical values of a and b,
 | |
|     storing the result of the operation in *result , (that is, *result is assigned the result of computing
 | |
|     a + b, a - b, or a * b). Each operation is performed as if both operands were represented in a
 | |
|     signed integer type with infinite range, and the result was then converted from this integer type to
 | |
|     type1.
 | |
| </pre>
 | |
| <a name='7.20.1p3'></a>
 | |
| <pre>3   Both type2 and type3 shall be any integer type other than plain char, bool, a bit-precise integer
 | |
|     type, or an enumeration type, and they need not be the same. *result shall be a modifiable lvalue
 | |
|     of any integer type other than plain char, bool, a bit-precise integer type, or an enumeration type.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.20.1p4'></a>
 | |
| <pre>4   It is recommended to produce a diagnostic message if type2 or type3 are not suitable integer types,
 | |
|     or if *result is not a modifiable lvalue of a suitable integer type.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.20.1p5'></a>
 | |
| <pre>5   If these macros return false, the value assigned to *result correctly represents the mathematical
 | |
|     result of the operation. Otherwise, these macros return true. In this case, the value assigned to
 | |
|     *result is the mathematical result of the operation wrapped around to the width of *result .
 | |
| </pre>
 | |
| <a name='7.20.1p6'></a>
 | |
| <pre>6   EXAMPLE 1 If a and b are values of type signed int, and result is a signed long, then
 | |
| 
 | |
|                       ckd_sub(&result, a, b);
 | |
| 
 | |
|     will indicate if a - b can be expressed as a signed long. If signed long has a greater width than signed int, this will
 | |
|     always be possible and this macro will return false.
 | |
| </pre>
 | |
| <a name='7.21'></a>
 | |
| <hr>
 | |
| <h3>7.21 [Common definitions <stddef.h>]</h3>
 | |
| <a name='7.21p1'></a>
 | |
| <pre>1   The header <stddef.h> defines the following macros and declares the following types. Some are
 | |
|     also defined in other headers, as noted in their respective subclauses.
 | |
| </pre>
 | |
| <a name='7.21p2'></a>
 | |
| <pre>2   The types are
 | |
| 
 | |
|              ptrdiff_t
 | |
| 
 | |
| 
 | |
|     which is the signed integer type of the result of subtracting two pointers;
 | |
| 
 | |
|              size_t
 | |
| 
 | |
| 
 | |
|     which is the unsigned integer type of the result of the sizeof operator;
 | |
| 
 | |
|              max_align_t
 | |
| 
 | |
| 
 | |
|     which is an object type whose alignment is the greatest fundamental alignment;
 | |
| 
 | |
|              wchar_t
 | |
| 
 | |
| 
 | |
|     which is an integer type whose range of values can represent distinct codes for all members of the
 | |
|     largest extended character set specified among the supported locales; the null character shall have
 | |
|     the code value zero. Each member of the basic character set shall have a code value equal to its
 | |
|     value when used as the lone character in an integer character constant if an implementation does
 | |
|     not define __STDC_MB_MIGHT_NEQ_WC__ ; and,
 | |
| 
 | |
|              nullptr_t
 | |
| 
 | |
| 
 | |
|     which is the type of the nullptr predefined constant, see below.
 | |
| </pre>
 | |
| <a name='7.21p3'></a>
 | |
| <pre>3   The macros are
 | |
| 
 | |
|              NULL
 | |
| 
 | |
| 
 | |
|     which expands to an implementation-defined null pointer constant;
 | |
| 
 | |
|              unreachable()
 | |
| 
 | |
| 
 | |
|     which expands to a void expression that invokes undefined behavior if it is reached during execution;
 | |
|     and
 | |
| 
 | |
|              offsetof(type, member-designator)
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that has type size_t, the value of which is the
 | |
|     offset in bytes, to the subobject (designated by member-designator), from the beginning of any object
 | |
|     of type type. The type and member designator shall be such that given
 | |
| 
 | |
|              static type t;
 | |
| 
 | |
| 
 | |
|     then the expression &(t. member-designator) evaluates to an address constant. If the specified type
 | |
|     defines a new type or if the specified member is a bit-field, the behavior is undefined.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.21p4'></a>
 | |
| <pre>4   The types used for size_t and ptrdiff_t should not have an integer conversion rank greater than
 | |
|     that of signed long int unless the implementation supports objects large enough to make this
 | |
|     necessary.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.21.1'></a>
 | |
| <hr>
 | |
| <h3>7.21.1 [The unreachable macro]</h3>
 | |
| <a name='7.21.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|                #include <stddef.h>
 | |
|                 void unreachable(void);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.21.1p2'></a>
 | |
| <pre>2   A call to the function-like macro unreachable indicates that the particular flow control that leads to
 | |
|     the call will never be taken; it receives no arguments and expands to a void expression. The program
 | |
|     execution shall not reach such a call.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.21.1p3'></a>
 | |
| <pre>3   If a macro call unreachable() is reached during execution, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.21.1p4'></a>
 | |
| <pre>4   EXAMPLE 1 The following program assumes that each execution is provided with at least one command line argument.
 | |
|     The behavior of an execution with no arguments is undefined.
 | |
| 
 | |
|       #include <stddef.h>
 | |
|       #include <stdio.h>
 | |
| 
 | |
|       int main (int argc, char* argv[static argc + 1]) {
 | |
|             if (argc <= 2)
 | |
|                   unreachable();
 | |
|             else
 | |
|                   return printf("%s: we see %s", argv[0], argv[1]);
 | |
| 
 | |
|                 return puts("this should never be reached");
 | |
|       }
 | |
| 
 | |
|     Here, the static array size expression and the annotation of the control flow with unreachable indicates that the pointed-to
 | |
|     parameter array argv will hold at least three elements, regardless of the circumstances. A possible optimization is that the
 | |
|     resulting executable never performs the comparison and unconditionally executes a tail call to printf that never returns to
 | |
|     the main function. In particular, the entire call and reference to puts can be omitted from the executable. No diagnostic is
 | |
|     expected.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.21.2'></a>
 | |
| <hr>
 | |
| <h3>7.21.2 [The nullptr_t type]</h3>
 | |
| <a name='7.21.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|                #include <stddef.h>
 | |
|                 typedef typeof_unqual(nullptr) nullptr_t;
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.21.2p2'></a>
 | |
| <pre>2   The nullptr_t type is the type of the nullptr predefined constant. It has only a very limited use
 | |
|     in contexts where this type is needed to distinguish nullptr from other expression types. It is an
 | |
|     unqualified complete scalar type that is different from all pointer or arithmetic types and is neither
 | |
|     an atomic or array type and has exactly one value, nullptr. Default initialization of an object of this
 | |
|     type is equivalent to an initialization by nullptr.
 | |
| </pre>
 | |
| <a name='7.21.2p3'></a>
 | |
| <pre>3   The size and alignment of nullptr_t is the same as for a pointer to character type. An object
 | |
|     representation of the value nullptr is the same as the object representation of a null pointer value of
 | |
|     type void*. An lvalue conversion of an object of type nullptr_t with such an object representation
 | |
|     has the value nullptr; if the object representation is different, the behavior is undefined<a href='#FOOTNOTE.319'><sup>[319]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.319'>
 | |
| <pre><i><b>Footnote 319)</b> Thus, during the whole program execution an object of type nullptr_t evaluates to the assumed value nullptr.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.21.2p4'></a>
 | |
| <pre>4   NOTE Because it is considered to be a scalar type, nullptr_t may appear in many context where (void*)0 would be valid,
 | |
|     for example,
 | |
| 
 | |
|           — as the operand of alignas, sizeof or typeof operators,
 | |
|           — as the operand of an implicit or explicit conversion to a pointer type,
 | |
|           — as the assignment expression in an assignment or initialization of an object of type nullptr_t,
 | |
|           — as an argument to a parameter of type nullptr_t or in a variable argument list,
 | |
|           — as a void expression,
 | |
| — as the operand of an implicit or explicit conversion to bool,
 | |
| — as an operand of a _Generic primary expression,
 | |
| — as an operand of the !, &&, || or conditional operators, or
 | |
| — as the controlling expression of an if or iteration statement.
 | |
| </pre>
 | |
| <a name='7.22'></a>
 | |
| <hr>
 | |
| <h3>7.22 [Integer types <stdint.h>]</h3>
 | |
| <a name='7.22p1'></a>
 | |
| <pre>1   The header <stdint.h> declares sets of integer types having specified widths, and defines corre-
 | |
|     sponding sets of macros.<a href='#FOOTNOTE.320'><sup>[320]</sup></a> It also defines macros that specify limits of integer types corresponding
 | |
|     to types defined in other standard headers.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.320'>
 | |
| <pre><i><b>Footnote 320)</b> See "future library directions" (<a href='#7.33.14'>7.33.14</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.22p2'></a>
 | |
| <pre>2   Types are defined in the following categories:
 | |
| 
 | |
|       — integer types having certain exact widths;
 | |
|       — integer types having at least certain specified widths;
 | |
|       — fastest integer types having at least certain specified widths;
 | |
|       — integer types wide enough to hold pointers to objects;
 | |
| 
 | |
|       — integer types having greatest width.
 | |
| 
 | |
|     (Some of these types may denote the same type.)
 | |
| </pre>
 | |
| <a name='7.22p3'></a>
 | |
| <pre>3   Corresponding macros specify limits of the declared types and construct suitable constants.
 | |
| </pre>
 | |
| <a name='7.22p4'></a>
 | |
| <pre>4   For each type described herein that the implementation provides,<a href='#FOOTNOTE.321'><sup>[321]</sup></a> <stdint.h> shall declare that
 | |
|     typedef name and define the associated macros. Conversely, for each type described herein that
 | |
|     the implementation does not provide, <stdint.h> shall not declare that typedef name nor shall it
 | |
|     define the associated macros. An implementation shall provide those types described as "required",
 | |
|     but need not provide any of the others (described as "optional"). None of the types shall be defined
 | |
|     as a synonym for a bit-precise integer type.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.321'>
 | |
| <pre><i><b>Footnote 321)</b> Some of these types might denote implementation-defined extended integer types.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.22p5'></a>
 | |
| <pre>5   The feature test macro __STDC_VERSION_STDINT_H__ expands to the token 202311L.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.1'></a>
 | |
| <hr>
 | |
| <h3>7.22.1 [Integer types]</h3>
 | |
| <a name='7.22.1p1'></a>
 | |
| <pre>1   When typedef names differing only in the absence or presence of the initial u are defined, they shall
 | |
|     denote corresponding signed and unsigned types as described in <a href='#6.2.5'>6.2.5</a>; an implementation providing
 | |
|     one of these corresponding types shall also provide the other.
 | |
| </pre>
 | |
| <a name='7.22.1p2'></a>
 | |
| <pre>2   In the following descriptions, the symbol N represents an unsigned decimal integer with no leading
 | |
|     zeros (e.g., 8 or 24, but not 04 or 048).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.22.1.1 [Exact-width integer types]</h3>
 | |
| <a name='7.22.1.1p1'></a>
 | |
| <pre>1   The typedef name intN_t designates a signed integer type with width N and no padding bits. Thus,
 | |
|     int8_t denotes such a signed integer type with a width of exactly 8 bits.
 | |
| </pre>
 | |
| <a name='7.22.1.1p2'></a>
 | |
| <pre>2   The typedef name uintN_t designates an unsigned integer type with width N and no padding bits.
 | |
|     Thus, uint24_t denotes such an unsigned integer type with a width of exactly 24 bits.
 | |
| </pre>
 | |
| <a name='7.22.1.1p3'></a>
 | |
| <pre>3   If an implementation provides standard or extended integer types with a particular width and no
 | |
|     padding bits, it shall define the corresponding typedef names.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.22.1.2 [Minimum-width integer types]</h3>
 | |
| <a name='7.22.1.2p1'></a>
 | |
| <pre>1   The typedef name int_leastN_t designates a signed integer type with a width of at least N, such
 | |
|     that no signed integer type with lesser size has at least the specified width. Thus, int_least32_t
 | |
|     denotes a signed integer type with a width of at least 32 bits.
 | |
| </pre>
 | |
| <a name='7.22.1.2p2'></a>
 | |
| <pre>2   The typedef name uint_leastN_t designates an unsigned integer type with a width of at least
 | |
|     N, such that no unsigned integer type with lesser size has at least the specified width. Thus,
 | |
|     uint_least16_t denotes an unsigned integer type with a width of at least 16 bits.
 | |
| </pre>
 | |
| <a name='7.22.1.2p3'></a>
 | |
| <pre>3   If the typedef name intN_t is defined, int_leastN_t designates the same type. If the typedef
 | |
|     name uintN_t is defined, uint_leastN_t designates the same type.
 | |
| </pre>
 | |
| <a name='7.22.1.2p4'></a>
 | |
| <pre>4   The following types are required:
 | |
|     int_least8_t                                                     uint_least8_t
 | |
|     int_least16_t                                                    uint_least16_t
 | |
|     int_least32_t                                                    uint_least32_t
 | |
|     int_least64_t                                                    uint_least64_t
 | |
| 
 | |
| 
 | |
|     All other types of this form are optional.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.22.1.3 [Fastest minimum-width integer types]</h3>
 | |
| <a name='7.22.1.3p1'></a>
 | |
| <pre>1   Each of the following types designates an integer type that is usually fastest<a href='#FOOTNOTE.322'><sup>[322]</sup></a> to operate with
 | |
|     among all integer types that have at least the specified width.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.322'>
 | |
| <pre><i><b>Footnote 322)</b> The designated type is not guaranteed to be fastest for all purposes; if the implementation has no clear grounds for
 | |
|     choosing one type over another, it will simply pick some integer type satisfying the signedness and width requirements.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.22.1.3p2'></a>
 | |
| <pre>2   The typedef name int_fastN_t designates the fastest signed integer type with a width of at least N.
 | |
|     The typedef name uint_fastN_t designates the fastest unsigned integer type with a width of at
 | |
|     least N.
 | |
| </pre>
 | |
| <a name='7.22.1.3p3'></a>
 | |
| <pre>3   The following types are required:
 | |
| 
 | |
|     int_fast8_t                                                      uint_fast8_t
 | |
|     int_fast16_t                                                     uint_fast16_t
 | |
|     int_fast32_t                                                     uint_fast32_t
 | |
|     int_fast64_t                                                     uint_fast64_t
 | |
| 
 | |
| 
 | |
|     All other types of this form are optional.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.22.1.4 [Integer types capable of holding object pointers]</h3>
 | |
| <a name='7.22.1.4p1'></a>
 | |
| <pre>1   The following type designates a signed integer type, other than a bit-precise integer type, with the
 | |
|     property that any valid pointer to void can be converted to this type, then converted back to pointer
 | |
|     to void, and the result will compare equal to the original pointer:
 | |
| 
 | |
|                intptr_t
 | |
| 
 | |
| 
 | |
|     The following type designates an unsigned integer type, other than a bit-precise integer type, with
 | |
|     the property that any valid pointer to void can be converted to this type, then converted back to
 | |
|     pointer to void, and the result will compare equal to the original pointer:
 | |
| 
 | |
|                uintptr_t
 | |
| 
 | |
| 
 | |
|     These types are optional.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.1.5'></a>
 | |
| <hr>
 | |
| <h3>7.22.1.5 [Greatest-width integer types]</h3>
 | |
| <a name='7.22.1.5p1'></a>
 | |
| <pre>1   The following type designates a signed integer type, other than a bit-precise integer type, capable of
 | |
|     representing any value of any signed integer type with the possible exceptions of signed bit-precise
 | |
|     integer types and of signed extended integer types that are wider than long long and that are
 | |
|     referred by the type definition for an exact width integer type:
 | |
| 
 | |
|                intmax_t
 | |
| 
 | |
| 
 | |
|     The following type designates the unsigned integer type that corresponds to intmax_t<a href='#FOOTNOTE.323'><sup>[323]</sup></a> :
 | |
| 
 | |
|                uintmax_t
 | |
| 
 | |
| 
 | |
|     These types are required.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.323'>
 | |
| <pre><i><b>Footnote 323)</b> Thus this type is capable of representing any value of any unsigned integer type with the possible exception of particular
 | |
|     extended integer types that are wider than unsigned long long.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.22.2'></a>
 | |
| <hr>
 | |
| <h3>7.22.2 [Widths of specified-width integer types]</h3>
 | |
| <a name='7.22.2p1'></a>
 | |
| <pre>1   The following object-like macros specify the width of the types declared in <stdint.h>. Each macro
 | |
|     name corresponds to a similar type name in <a href='#7.22.1'>7.22.1</a>.
 | |
| </pre>
 | |
| <a name='7.22.2p2'></a>
 | |
| <pre>2   Each instance of any defined macro shall be replaced by a constant expression suitable for use in
 | |
|     #if preprocessing directives. Its implementation-defined value shall be equal to or greater than
 | |
|     the value given below, except where stated to be exactly the given value. An implementation shall
 | |
|     define only the macros corresponding to those typedef names it actually provides.<a href='#FOOTNOTE.324'><sup>[324]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.324'>
 | |
| <pre><i><b>Footnote 324)</b> The exact-width and pointer-holding integer types are optional.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.22.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.22.2.1 [Width of exact-width integer types]</h3>
 | |
| <a name='7.22.2.1p1'></a>
 | |
| <pre>1    INTN_WIDTH                                     exactly N
 | |
|      UINTN_WIDTH                                    exactly N
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.22.2.2 [Width of minimum-width integer types]</h3>
 | |
| <a name='7.22.2.2p1'></a>
 | |
| <pre>1    INT_LEASTN_WIDTH                               exactly UINT_LEASTN_WIDTH
 | |
|      UINT_LEASTN_WIDTH                              N
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.2.3'></a>
 | |
| <hr>
 | |
| <h3>7.22.2.3 [Width of fastest minimum-width integer types]</h3>
 | |
| <a name='7.22.2.3p1'></a>
 | |
| <pre>1    INT_FASTN_WIDTH                                exactly UINT_FASTN_WIDTH
 | |
|      UINT_FASTN_WIDTH                               N
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.2.4'></a>
 | |
| <hr>
 | |
| <h3>7.22.2.4 [Width of integer types capable of holding object pointers]</h3>
 | |
| <a name='7.22.2.4p1'></a>
 | |
| <pre>1    INTPTR_WIDTH                                   exactly UINTPTR_WIDTH
 | |
|      UINTPTR_WIDTH                                  16
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.2.5'></a>
 | |
| <hr>
 | |
| <h3>7.22.2.5 [Width of greatest-width integer types]</h3>
 | |
| <a name='7.22.2.5p1'></a>
 | |
| <pre>1    INTMAX_WIDTH                                      exactly UINTMAX_WIDTH
 | |
|      UINTMAX_WIDTH                                     64
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.3'></a>
 | |
| <hr>
 | |
| <h3>7.22.3 [Width of other integer types]</h3>
 | |
| <a name='7.22.3p1'></a>
 | |
| <pre>1   The following object-like macros specify the width of integer types corresponding to types defined
 | |
|     in other standard headers.
 | |
| </pre>
 | |
| <a name='7.22.3p2'></a>
 | |
| <pre>2   Each instance of these macros shall be replaced by a constant expression suitable for use in #if
 | |
|     preprocessing directives. Its implementation-defined value shall be equal to or greater than the
 | |
|     corresponding value given below. An implementation shall define only the macros corresponding
 | |
|     to those typedef names it actually provides.<a href='#FOOTNOTE.325'><sup>[325]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.325'>
 | |
| <pre><i><b>Footnote 325)</b> A freestanding implementation need not provide all of these types.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.22.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.22.3.1 [Width of ptrdiff_t]</h3>
 | |
| <a name='7.22.3.1p1'></a>
 | |
| <pre>1    PTRDIFF_WIDTH                                  16
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.22.3.2 [Width of sig_atomic_t]</h3>
 | |
| <a name='7.22.3.2p1'></a>
 | |
| <pre>1    SIG_ATOMIC_WIDTH                                 8
 | |
| </pre>
 | |
| <a name='7.22.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.22.3.3 [Width of size_t]</h3>
 | |
| <a name='7.22.3.3p1'></a>
 | |
| <pre>1    SIZE_WIDTH                             16
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.3.4'></a>
 | |
| <hr>
 | |
| <h3>7.22.3.4 [Width of wchar_t]</h3>
 | |
| <a name='7.22.3.4p1'></a>
 | |
| <pre>1    WCHAR_WIDTH                            8
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.3.5'></a>
 | |
| <hr>
 | |
| <h3>7.22.3.5 [Width of wint_t]</h3>
 | |
| <a name='7.22.3.5p1'></a>
 | |
| <pre>1    WINT_WIDTH                           16
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.4'></a>
 | |
| <hr>
 | |
| <h3>7.22.4 [Macros for integer constants]</h3>
 | |
| <a name='7.22.4p1'></a>
 | |
| <pre>1   The following function-like macros expand to integer constants suitable for initializing objects that
 | |
|     have integer types corresponding to types defined in <stdint.h>. Each macro name corresponds to
 | |
|     a similar type name in <a href='#7.22.1.2'>7.22.1.2</a> or <a href='#7.22.1.5'>7.22.1.5</a>.
 | |
| </pre>
 | |
| <a name='7.22.4p2'></a>
 | |
| <pre>2   The argument in any instance of these macros shall be an unsuffixed integer constant (as defined
 | |
|     in <a href='#6.4.4.1'>6.4.4.1</a>) with a value that does not exceed the limits for the corresponding type.
 | |
| </pre>
 | |
| <a name='7.22.4p3'></a>
 | |
| <pre>3   Each invocation of one of these macros shall expand to an integer constant expression. The type of
 | |
|     the expression shall have the same type as would an expression of the corresponding type converted
 | |
|     according to the integer promotions. The value of the expression shall be that of the argument. If
 | |
|     the value is in the range of the type intmax_t (for a signed type) or the type uintmax_t (for an
 | |
|     unsigned type), see <a href='#7.22.1.5'>7.22.1.5</a>, the expression is suitable for use in #if preprocessing directives.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.22.4.1 [Macros for minimum-width integer constants]</h3>
 | |
| <a name='7.22.4.1p1'></a>
 | |
| <pre>1   The macro INTN_C( value) expands to an integer constant expression corresponding to the type
 | |
|     int_leastN_t . The macro UINTN_C( value) expands to an integer constant expression corre-
 | |
|     sponding to the type uint_leastN_t . For example, if uint_least64_t is a name for the type
 | |
|     unsigned long long int, then UINT64_C(0x123) might expand to the integer constant 0x123ULL.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.22.4.2 [Macros for greatest-width integer constants]</h3>
 | |
| <a name='7.22.4.2p1'></a>
 | |
| <pre>1   The following macro expands to an integer constant expression having the value specified by its
 | |
|     argument and the type intmax_t:
 | |
| 
 | |
|                INTMAX_C(value)
 | |
| 
 | |
| 
 | |
|     The following macro expands to an integer constant expression having the value specified by its
 | |
|     argument and the type uintmax_t:
 | |
| 
 | |
|                UINTMAX_C(value)
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.22.5'></a>
 | |
| <hr>
 | |
| <h3>7.22.5 [Maximal and minimal values of integer types]</h3>
 | |
| <a name='7.22.5p1'></a>
 | |
| <pre>1   For all integer types for which there is a macro with suffix _WIDTH holding the width, maximum
 | |
|     macros with suffix _MAX and, for all signed types, minimum macros with suffix _MIN are defined as
 | |
|     by <a href='#5.2.4.2'>5.2.4.2</a>. If it is unspecified if a type is signed or unsigned and the implementation has it as an
 | |
|     unsigned type, a minimum macro with extension _MIN , and value 0 of the corresponding type is
 | |
|     defined.
 | |
| </pre>
 | |
| <a name='7.23'></a>
 | |
| <hr>
 | |
| <h3>7.23 [Input/output <stdio.h>]</h3>
 | |
| <a name='7.23.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.1 [Introduction]</h3>
 | |
| <a name='7.23.1p1'></a>
 | |
| <pre>1   The header <stdio.h> defines several macros, and declares three types and many functions for
 | |
|     performing input and output.
 | |
| </pre>
 | |
| <a name='7.23.1p2'></a>
 | |
| <pre>2   The types declared are size_t (described in <a href='#7.21'>7.21</a>);
 | |
| 
 | |
|               FILE
 | |
| 
 | |
| 
 | |
|     which is an object type capable of recording all the information needed to control a stream, including
 | |
|     its file position indicator, a pointer to its associated buffer (if any), an error indicator that records
 | |
|     whether a read/write error has occurred, and an end-of-file indicator that records whether the end of
 | |
|     the file has been reached; and
 | |
| 
 | |
|               fpos_t
 | |
| 
 | |
| 
 | |
|     which is a complete object type other than an array type capable of recording all the information
 | |
|     needed to specify uniquely every position within a file.
 | |
| </pre>
 | |
| <a name='7.23.1p3'></a>
 | |
| <pre>3   The macros are NULL (described in <a href='#7.21'>7.21</a>);
 | |
|               _IOFBF
 | |
|               _IOLBF
 | |
|               _IONBF
 | |
| 
 | |
| 
 | |
|     which expand to integer constant expressions with distinct values, suitable for use as the third
 | |
|     argument to the setvbuf function;
 | |
| 
 | |
|               BUFSIZ
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the size of the buffer used by the setbuf
 | |
|     function;
 | |
| 
 | |
|               EOF
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression, with type int and a negative value, that is returned
 | |
|     by several functions to indicate end-of-file, that is, no more input from a stream;
 | |
| 
 | |
|               FOPEN_MAX
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the minimum number of files that the
 | |
|     implementation guarantees can be open simultaneously;
 | |
| 
 | |
|               FILENAME_MAX
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the size needed for an array of char large
 | |
|     enough to hold the longest file name string that the implementation guarantees can be opened or, if
 | |
|     the implementation imposes no practical limit on the length of file name strings, the recommended
 | |
|     size of an array intended to hold a file name string<a href='#FOOTNOTE.326'><sup>[326]</sup></a> ;
 | |
|              _PRINTF_NAN_LEN_MAX
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression (suitable for use in #if preprocessing directives)
 | |
|     that is the maximum number of characters output for any
 | |
|     [-]NAN(n-char-sequence)
 | |
|     sequence.<a href='#FOOTNOTE.327'><sup>[327]</sup></a> If an implementation has no support for NaNs, it shall be 0. _PRINTF_NAN_LEN_MAX
 | |
|     shall be less than 64;
 | |
| 
 | |
|              L_tmpnam
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the size needed for an array of char large
 | |
|     enough to hold a temporary file name string generated by the tmpnam function;
 | |
| 
 | |
|              SEEK_CUR
 | |
|              SEEK_END
 | |
|              SEEK_SET
 | |
| 
 | |
| 
 | |
|     which expand to integer constant expressions with distinct values, suitable for use as the third
 | |
|     argument to the fseek function;
 | |
| 
 | |
|              TMP_MAX
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the minimum number of unique file names
 | |
|     that can be generated by the tmpnam function;
 | |
| 
 | |
|              stderr
 | |
|              stdin
 | |
|              stdout
 | |
| 
 | |
| 
 | |
|     which are expressions of type "pointer to FILE" that point to the FILE objects associated, respectively,
 | |
|     with the standard error, input, and output streams.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.326'>
 | |
| <pre><i><b>Footnote 326)</b> Of course, file name string contents are subject to other system-specific constraints; therefore all possible strings of length
 | |
|     FILENAME_MAX cannot be expected to be opened successfully.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.327'>
 | |
| <pre><i><b>Footnote 327)</b> If the implementation only uses the [-]NAN style, then _PRINTF_NAN_LEN_MAX would have the value 4.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.1p4'></a>
 | |
| <pre>4   The header <wchar.h> declares a number of functions useful for wide character input and output.
 | |
|     The wide character input/output functions described in that subclause provide operations analogous
 | |
|     to most of those described here, except that the fundamental units internal to the program are
 | |
|     wide characters. The external representation (in the file) is a sequence of "generalized" multibyte
 | |
|     characters, as described further in <a href='#7.23.3'>7.23.3</a>.
 | |
| </pre>
 | |
| <a name='7.23.1p5'></a>
 | |
| <pre>5   The input/output functions are given the following collective terms:
 | |
| 
 | |
|       — The wide character input functions — those functions described in <a href='#7.31'>7.31</a> that perform input
 | |
|         into wide characters and wide strings: fgetwc, fgetws, getwc, getwchar, fwscanf, wscanf,
 | |
|         vfwscanf , and vwscanf .
 | |
| 
 | |
|       — The wide character output functions — those functions described in <a href='#7.31'>7.31</a> that perform output from
 | |
|         wide characters and wide strings: fputwc, fputws, putwc, putwchar, fwprintf, wprintf,
 | |
|         vfwprintf , and vwprintf.
 | |
| 
 | |
|       — The wide character input/output functions — the union of the ungetwc function, the wide charac-
 | |
|         ter input functions, and the wide character output functions.
 | |
|       — The byte input/output functions — those functions described in this subclause that perform
 | |
|         input/output: fgetc, fgets, fprintf, fputc, fputs, fread, fscanf, fwrite, getc, getchar,
 | |
|         printf, putc, putchar, puts, scanf, ungetc, vfprintf , vfscanf , vprintf , and vscanf.
 | |
| 
 | |
|     Forward references: files (<a href='#7.23.3'>7.23.3</a>), the fseek function (<a href='#7.23.9.2'>7.23.9.2</a>), streams (<a href='#7.23.2'>7.23.2</a>), the tmpnam func-
 | |
|     tion (<a href='#7.23.4.4'>7.23.4.4</a>), <wchar.h> (<a href='#7.31'>7.31</a>).
 | |
| </pre>
 | |
| <a name='7.23.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.2 [Streams]</h3>
 | |
| <a name='7.23.2p1'></a>
 | |
| <pre>1   Input and output, whether to or from physical devices such as terminals and tape drives, or whether
 | |
|     to or from files supported on structured storage devices, are mapped into logical data streams, whose
 | |
|     properties are more uniform than their various inputs and outputs. Two forms of mapping are
 | |
|     supported, for text streams and for binary streams.<a href='#FOOTNOTE.328'><sup>[328]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.328'>
 | |
| <pre><i><b>Footnote 328)</b> An implementation need not distinguish between text streams and binary streams. In such an implementation, there
 | |
|     need be no new-line characters in a text stream nor any limit to the length of a line.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.2p2'></a>
 | |
| <pre>2   A text stream is an ordered sequence of characters composed into lines, each line consisting of
 | |
|     zero or more characters plus a terminating new-line character. Whether the last line requires a
 | |
|     terminating new-line character is implementation-defined. Characters may have to be added, altered,
 | |
|     or deleted on input and output to conform to differing conventions for representing text in the host
 | |
|     environment. Thus, there need not be a one-to-one correspondence between the characters in a
 | |
|     stream and those in the external representation. Data read in from a text stream will necessarily
 | |
|     compare equal to the data that were earlier written out to that stream only if: the data consist only
 | |
|     of printing characters and the control characters horizontal tab and new-line; no new-line character
 | |
|     is immediately preceded by space characters; and the last character is a new-line character. Whether
 | |
|     space characters that are written out immediately before a new-line character appear when read in
 | |
|     is implementation-defined.
 | |
| </pre>
 | |
| <a name='7.23.2p3'></a>
 | |
| <pre>3   A binary stream is an ordered sequence of characters that can transparently record internal data.
 | |
|     Data read in from a binary stream shall compare equal to the data that were earlier written out to
 | |
|     that stream, under the same implementation. Such a stream may, however, have an implementation-
 | |
|     defined number of null characters appended to the end of the stream.
 | |
| </pre>
 | |
| <a name='7.23.2p4'></a>
 | |
| <pre>4   Each stream has an orientation. After a stream is associated with an external file, but before any
 | |
|     operations are performed on it, the stream is without orientation. Once a wide character input/out-
 | |
|     put function has been applied to a stream without orientation, the stream becomes a wide-oriented
 | |
|     stream. Similarly, once a byte input/output function has been applied to a stream without orien-
 | |
|     tation, the stream becomes a byte-oriented stream. Only a call to the freopen function or the fwide
 | |
|     function can otherwise alter the orientation of a stream. (A successful call to freopen removes any
 | |
|     orientation.)<a href='#FOOTNOTE.329'><sup>[329]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.329'>
 | |
| <pre><i><b>Footnote 329)</b> The three predefined streams stdin, stdout, and stderr are unoriented at program startup.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.2p5'></a>
 | |
| <pre>5   Byte input/output functions shall not be applied to a wide-oriented stream and wide character
 | |
|     input/output functions shall not be applied to a byte-oriented stream. The remaining stream
 | |
|     operations do not affect, and are not affected by, a stream’s orientation, except for the following
 | |
|     additional restrictions:
 | |
| 
 | |
|       — Binary wide-oriented streams have the file-positioning restrictions ascribed to both text and
 | |
|         binary streams.
 | |
| 
 | |
|       — For wide-oriented streams, after a successful call to a file-positioning function that leaves the
 | |
|         file position indicator prior to the end-of-file, a wide character output function can overwrite a
 | |
|         partial multibyte character; any file contents beyond the byte(s) written may henceforth not
 | |
|         consist of valid multibyte characters.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.2p6'></a>
 | |
| <pre>6   Each wide-oriented stream has an associated mbstate_t object that stores the current parse state
 | |
|     of the stream. A successful call to fgetpos stores a representation of the value of this mbstate_t
 | |
|     object as part of the value of the fpos_t object. A later successful call to fsetpos using the same
 | |
|     stored fpos_t value restores the value of the associated mbstate_t object as well as the position
 | |
|     within the controlled stream.
 | |
| </pre>
 | |
| <a name='7.23.2p7'></a>
 | |
| <pre>7   Each stream has an associated lock that is used to prevent data races when multiple threads of
 | |
|     execution access a stream, and to restrict the interleaving of stream operations performed by multiple
 | |
|     threads. Only one thread may hold this lock at a time. The lock is reentrant: a single thread may
 | |
|     hold the lock multiple times at a given time.
 | |
| </pre>
 | |
| <a name='7.23.2p8'></a>
 | |
| <pre>8   All functions that read, write, position, or query the position of a stream lock the stream before
 | |
|     accessing it. They release the lock associated with the stream when the access is complete.
 | |
|     Environmental limits
 | |
| </pre>
 | |
| <a name='7.23.2p9'></a>
 | |
| <pre>9   An implementation shall support text files with lines containing at least 254 characters, including
 | |
|     the terminating new-line character. The value of the macro BUFSIZ shall be at least 256.
 | |
|     Forward references: the freopen function (<a href='#7.23.5.4'>7.23.5.4</a>), the fwide function (<a href='#7.31.3.5'>7.31.3.5</a>), mbstate_t
 | |
|     (<a href='#7.31.1'>7.31.1</a>), the fgetpos function (<a href='#7.23.9.1'>7.23.9.1</a>), the fsetpos function (<a href='#7.23.9.3'>7.23.9.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.3'></a>
 | |
| <hr>
 | |
| <h3>7.23.3 [Files]</h3>
 | |
| <a name='7.23.3p1'></a>
 | |
| <pre>1   A stream is associated with an external file (which may be a physical device) by opening a file, which
 | |
|     may involve creating a new file. Creating an existing file causes its former contents to be discarded,
 | |
|     if necessary. If a file can support positioning requests (such as a disk file, as opposed to a terminal),
 | |
|     then a file position indicator associated with the stream is positioned at the start (character number
 | |
|     zero) of the file, unless the file is opened with append mode in which case it is implementation-
 | |
|     defined whether the file position indicator is initially positioned at the beginning or the end of the
 | |
|     file. The file position indicator is maintained by subsequent reads, writes, and positioning requests,
 | |
|     to facilitate an orderly progression through the file.
 | |
| </pre>
 | |
| <a name='7.23.3p2'></a>
 | |
| <pre>2   Binary files are not truncated, except as defined in <a href='#7.23.5.3'>7.23.5.3</a>. Whether a write on a text stream causes
 | |
|     the associated file to be truncated beyond that point is implementation-defined.
 | |
| </pre>
 | |
| <a name='7.23.3p3'></a>
 | |
| <pre>3   When a stream is unbuffered, characters are intended to appear from the source or at the destination
 | |
|     as soon as possible. Otherwise characters may be accumulated and transmitted to or from the host
 | |
|     environment as a block. When a stream is fully buffered, characters are intended to be transmitted
 | |
|     to or from the host environment as a block when a buffer is filled. When a stream is line buffered,
 | |
|     characters are intended to be transmitted to or from the host environment as a block when a new-line
 | |
|     character is encountered. Furthermore, characters are intended to be transmitted as a block to the
 | |
|     host environment when a buffer is filled, when input is requested on an unbuffered stream, or when
 | |
|     input is requested on a line buffered stream that requires the transmission of characters from the
 | |
|     host environment. Support for these characteristics is implementation-defined, and may be affected
 | |
|     via the setbuf and setvbuf functions.
 | |
| </pre>
 | |
| <a name='7.23.3p4'></a>
 | |
| <pre>4   A file may be disassociated from a controlling stream by closing the file. Output streams are
 | |
|     flushed (any unwritten buffer contents are transmitted to the host environment) before the stream
 | |
|     is disassociated from the file. The lifetime of a FILE object ends when the associated file is closed
 | |
|     (including the standard text streams). Whether a file of zero length (on which no characters have
 | |
|     been written by an output stream) actually exists is implementation-defined.
 | |
| </pre>
 | |
| <a name='7.23.3p5'></a>
 | |
| <pre>5   The file may be subsequently reopened, by the same or another program execution, and its contents
 | |
|     reclaimed or modified (if it can be repositioned at its start). If the main function returns to its original
 | |
|     caller, or if the exit function is called, all open files are closed (hence all output streams are flushed)
 | |
|     before program termination. Other paths to program termination, such as calling the abort function,
 | |
|     need not close all files properly.
 | |
| </pre>
 | |
| <a name='7.23.3p6'></a>
 | |
| <pre>6   The address of the FILE object used to control a stream may be significant; a copy of a FILE object
 | |
|     need not serve in place of the original.
 | |
| </pre>
 | |
| <a name='7.23.3p7'></a>
 | |
| <pre>7   At program startup, three text streams are predefined and need not be opened explicitly — standard
 | |
|     input (for reading conventional input), standard output (for writing conventional output), and standard
 | |
|     error (for writing diagnostic output). As initially opened, the standard error stream is not fully
 | |
|     buffered; the standard input and standard output streams are fully buffered if and only if the stream
 | |
|     can be determined not to refer to an interactive device.
 | |
| </pre>
 | |
| <a name='7.23.3p8'></a>
 | |
| <pre>8   Functions that open additional (nontemporary) files require a file name, which is a string. The
 | |
|     rules for composing valid file names are implementation-defined. Whether the same file can be
 | |
|     simultaneously open multiple times is also implementation-defined.
 | |
| </pre>
 | |
| <a name='7.23.3p9'></a>
 | |
| <pre>9   Although both text and binary wide-oriented streams are conceptually sequences of wide characters,
 | |
|     the external file associated with a wide-oriented stream is a sequence of multibyte characters,
 | |
|     generalized as follows:
 | |
| 
 | |
|       — Multibyte encodings within files may contain embedded null bytes (unlike multibyte encod-
 | |
|         ings valid for use internal to the program).
 | |
|        — A file need not begin nor end in the initial shift state.<a href='#FOOTNOTE.330'><sup>[330]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.330'>
 | |
| <pre><i><b>Footnote 330)</b> Setting the file position indicator to end-of-file, as with fseek(file, 0, SEEK_END), has undefined behavior for a
 | |
|      binary stream (because of possible trailing null characters) or for any stream with state-dependent encoding that does not
 | |
|      assuredly end in the initial shift state.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.3p10'></a>
 | |
| <pre>10   Moreover, the encodings used for multibyte characters may differ among files. Both the nature and
 | |
|      choice of such encodings are implementation-defined.
 | |
| </pre>
 | |
| <a name='7.23.3p11'></a>
 | |
| <pre>11   The wide character input functions read multibyte characters from the stream and convert them
 | |
|      to wide characters as if they were read by successive calls to the fgetwc function. Each conversion
 | |
|      occurs as if by a call to the mbrtowc function, with the conversion state described by the stream’s
 | |
|      own mbstate_t object. The byte input functions read characters from the stream as if by successive
 | |
|      calls to the fgetc function.
 | |
| </pre>
 | |
| <a name='7.23.3p12'></a>
 | |
| <pre>12   The wide character output functions convert wide characters to multibyte characters and write them
 | |
|      to the stream as if they were written by successive calls to the fputwc function. Each conversion
 | |
|      occurs as if by a call to the wcrtomb function, with the conversion state described by the stream’s
 | |
|      own mbstate_t object. The byte output functions write characters to the stream as if by successive
 | |
|      calls to the fputc function.
 | |
| </pre>
 | |
| <a name='7.23.3p13'></a>
 | |
| <pre>13   In some cases, some of the byte input/output functions also perform conversions between multibyte
 | |
|      characters and wide characters. These conversions also occur as if by calls to the mbrtowc and
 | |
|      wcrtomb functions.
 | |
| </pre>
 | |
| <a name='7.23.3p14'></a>
 | |
| <pre>14   An encoding error occurs if the character sequence presented to the underlying mbrtowc function
 | |
|      does not form a valid (generalized) multibyte character, or if the code value passed to the underlying
 | |
|      wcrtomb does not correspond to a valid (generalized) multibyte character. The wide character
 | |
|      input/output functions and the byte input/output functions store the value of the macro EILSEQ in
 | |
|      errno if and only if an encoding error occurs.
 | |
| 
 | |
|      Environmental limits
 | |
| </pre>
 | |
| <a name='7.23.3p15'></a>
 | |
| <pre>15   The value of FOPEN_MAX shall be at least eight, including the three standard text streams.
 | |
|      Forward references: the exit function (<a href='#7.24.4.4'>7.24.4.4</a>), the fgetc function (<a href='#7.23.7.1'>7.23.7.1</a>), the fopen function
 | |
|      (<a href='#7.23.5.3'>7.23.5.3</a>), the fputc function (<a href='#7.23.7.3'>7.23.7.3</a>), the setbuf function (<a href='#7.23.5.5'>7.23.5.5</a>), the setvbuf function (<a href='#7.23.5.6'>7.23.5.6</a>),
 | |
|      the fgetwc function (<a href='#7.31.3.1'>7.31.3.1</a>), the fputwc function (<a href='#7.31.3.3'>7.31.3.3</a>), conversion state (<a href='#7.31.6'>7.31.6</a>), the mbrtowc
 | |
|      function (<a href='#7.31.6.3.2'>7.31.6.3.2</a>), the wcrtomb function (<a href='#7.31.6.3.3'>7.31.6.3.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.4'></a>
 | |
| <hr>
 | |
| <h3>7.23.4 [Operations on files]</h3>
 | |
| <a name='7.23.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.4.1 [The remove function]</h3>
 | |
| <a name='7.23.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                int remove(const char *filename);
 | |
| 
 | |
| 
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='7.23.4.1p2'></a>
 | |
| <pre>2    The remove function causes the file whose name is the string pointed to by filename to be no longer
 | |
|      accessible by that name. A subsequent attempt to open that file using that name will fail, unless it is
 | |
|      created anew. If the file is open, the behavior of the remove function is implementation-defined.
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='7.23.4.1p3'></a>
 | |
| <pre>3    The remove function returns zero if the operation succeeds, nonzero if it fails.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.4.2 [The rename function]</h3>
 | |
| <a name='7.23.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                int rename(const char *old, const char *new);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.4.2p2'></a>
 | |
| <pre>2   The rename function causes the file whose name is the string pointed to by old to be henceforth
 | |
|     known by the name given by the string pointed to by new. The file named old is no longer accessible
 | |
|     by that name. If a file named by the string pointed to by new exists prior to the call to the rename
 | |
|     function, the behavior is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.4.2p3'></a>
 | |
| <pre>3   The rename function returns zero if the operation succeeds, nonzero if it fails,<a href='#FOOTNOTE.331'><sup>[331]</sup></a> in which case if the
 | |
|     file existed previously it is still known by its original name.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.331'>
 | |
| <pre><i><b>Footnote 331)</b> Among the reasons the implementation could cause the rename function to fail are that the file is open or that it is
 | |
|     necessary to copy its contents to effectuate its renaming.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.23.4.3 [The tmpfile function]</h3>
 | |
| <a name='7.23.4.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               FILE *tmpfile(void);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.4.3p2'></a>
 | |
| <pre>2   The tmpfile function creates a temporary binary file that is different from any other existing file
 | |
|     and that will automatically be removed when it is closed or at program termination. If the program
 | |
|     terminates abnormally, whether an open temporary file is removed is implementation-defined. The
 | |
|     file is opened for update with "wb+" mode.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.23.4.3p3'></a>
 | |
| <pre>3   It should be possible to open at least TMP_MAX temporary files during the lifetime of the program
 | |
|     (this limit may be shared with tmpnam) and there should be no limit on the number simultaneously
 | |
|     open other than this limit and any limit on the number of open files (FOPEN_MAX).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.4.3p4'></a>
 | |
| <pre>4   The tmpfile function returns a pointer to the stream of the file that it created. If the file cannot be
 | |
|     created, the tmpfile function returns a null pointer.
 | |
|     Forward references: the fopen function (<a href='#7.23.5.3'>7.23.5.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.23.4.4 [The tmpnam function]</h3>
 | |
| <a name='7.23.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               char *tmpnam(char *s);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.4.4p2'></a>
 | |
| <pre>2   The tmpnam function generates a string that is a valid file name and that is not the same as the name
 | |
|     of an existing file.<a href='#FOOTNOTE.332'><sup>[332]</sup></a> The function is potentially capable of generating at least TMP_MAX different
 | |
|     strings, but any or all of them may already be in use by existing files and thus not be suitable return
 | |
|     values.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.332'>
 | |
| <pre><i><b>Footnote 332)</b> Files created using strings generated by the tmpnam function are temporary only in the sense that their names are not
 | |
|     expected to collide with those generated by conventional naming rules for the implementation. It is still necessary to use the
 | |
|     remove function to remove such files when their use is ended, and before program termination.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.4.4p3'></a>
 | |
| <pre>3   The tmpnam function generates a different string each time it is called.
 | |
| </pre>
 | |
| <a name='7.23.4.4p4'></a>
 | |
| <pre>4   Calls to the tmpnam function with a null pointer argument may introduce data races with each other.
 | |
|     The implementation shall behave as if no library function calls the tmpnam function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.4.4p5'></a>
 | |
| <pre>5   If no suitable string can be generated, the tmpnam function returns a null pointer. Otherwise, if
 | |
|     the argument is a null pointer, the tmpnam function leaves its result in an internal static object and
 | |
|     returns a pointer to that object (subsequent calls to the tmpnam function may modify the same object).
 | |
|     If the argument is not a null pointer, it is assumed to point to an array of at least L_tmpnam chars;
 | |
|     the tmpnam function writes its result in that array and returns the argument as its value.
 | |
| 
 | |
|     Environmental limits
 | |
| </pre>
 | |
| <a name='7.23.4.4p6'></a>
 | |
| <pre>6   The value of the macro TMP_MAX shall be at least 25.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.5'></a>
 | |
| <hr>
 | |
| <h3>7.23.5 [File access functions]</h3>
 | |
| <a name='7.23.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.5.1 [The fclose function]</h3>
 | |
| <a name='7.23.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int fclose(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.5.1p2'></a>
 | |
| <pre>2   A successful call to the fclose function causes the stream pointed to by stream to be flushed and
 | |
|     the associated file to be closed. Any unwritten buffered data for the stream are delivered to the host
 | |
|     environment to be written to the file; any unread buffered data are discarded. Whether or not the
 | |
|     call succeeds, the stream is disassociated from the file and any buffer set by the setbuf or setvbuf
 | |
|     function is disassociated from the stream (and deallocated if it was automatically allocated).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.5.1p3'></a>
 | |
| <pre>3   The fclose function returns zero if the stream was successfully closed, or EOF if any errors were
 | |
|     detected.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.5.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.5.2 [The fflush function]</h3>
 | |
| <a name='7.23.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int fflush(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.5.2p2'></a>
 | |
| <pre>2   If stream points to an output stream or an update stream in which the most recent operation was
 | |
|     not input, the fflush function causes any unwritten data for that stream to be delivered to the host
 | |
|     environment to be written to the file; otherwise, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.23.5.2p3'></a>
 | |
| <pre>3   If stream is a null pointer, the fflush function performs this flushing action on all streams for which
 | |
|     the behavior is defined above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.5.2p4'></a>
 | |
| <pre>4   The fflush function sets the error indicator for the stream and returns EOF if a write error occurs,
 | |
|     otherwise it returns zero.
 | |
|     Forward references: the fopen function (<a href='#7.23.5.3'>7.23.5.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.5.3'></a>
 | |
| <hr>
 | |
| <h3>7.23.5.3 [The fopen function]</h3>
 | |
| <a name='7.23.5.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               FILE *fopen(const char * restrict filename, const char * restrict mode);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.5.3p2'></a>
 | |
| <pre>2   The fopen function opens the file whose name is the string pointed to by filename, and associates
 | |
|     a stream with it.
 | |
| </pre>
 | |
| <a name='7.23.5.3p3'></a>
 | |
| <pre>3   The argument mode points to a string. If the string is one of the following, the file is open in the
 | |
|     indicated mode. Otherwise, the behavior is undefined.<a href='#FOOTNOTE.333'><sup>[333]</sup></a>
 | |
|     r               open text file for reading
 | |
|     w               truncate to zero length or create text file for writing
 | |
|     wx              create text file for writing
 | |
|     a               append; open or create text file for writing at end-of-file
 | |
|     rb              open binary file for reading
 | |
|     wb              truncate to zero length or create binary file for writing
 | |
|     wbx             create binary file for writing
 | |
|     ab              append; open or create binary file for writing at end-of-file
 | |
|     r+              open text file for update (reading and writing)
 | |
|     w+              truncate to zero length or create text file for update
 | |
|     w+x             create text file for update
 | |
|     a+              append; open or create text file for update, writing at end-of-file
 | |
|     r+b or rb+      open binary file for update (reading and writing)
 | |
|     w+b or wb+      truncate to zero length or create binary file for update
 | |
|     w+bx or wb+x    create binary file for update
 | |
|     a+b or ab+      append; open or create binary file for update, writing at end-of-file
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.333'>
 | |
| <pre><i><b>Footnote 333)</b> If the string begins with one of the listed mode sequences, the implementation might choose to ignore the remaining
 | |
|     characters, or it might use them to select different kinds of a file (some of which might not conform to the properties in <a href='#7.23.2'>7.23.2</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.5.3p4'></a>
 | |
| <pre>4   Opening a file with read mode (’r’ as the first character in the mode argument) fails if the file does
 | |
|     not exist or cannot be read.
 | |
| </pre>
 | |
| <a name='7.23.5.3p5'></a>
 | |
| <pre>5   Opening a file with exclusive mode (’x’ as the last character in the mode argument) fails if the file
 | |
|     already exists or cannot be created. Otherwise, the file is created with exclusive (also known as
 | |
|     non-shared) access to the extent that the underlying system supports exclusive access.
 | |
| </pre>
 | |
| <a name='7.23.5.3p6'></a>
 | |
| <pre>6   Opening a file with append mode (’a’ as the first character in the mode argument) causes all
 | |
|     subsequent writes to the file to be forced to the then current end-of-file, regardless of intervening
 | |
|     calls to the fseek function. In some implementations, opening a binary file with append mode (’b’
 | |
|     as the second or third character in the above list of mode argument values) may initially position the
 | |
|     file position indicator for the stream beyond the last data written, because of null character padding.
 | |
| </pre>
 | |
| <a name='7.23.5.3p7'></a>
 | |
| <pre>7   When a file is opened with update mode (’+’ as the second or third character in the above list
 | |
|     of mode argument values), both input and output may be performed on the associated stream.
 | |
|     However, output shall not be directly followed by input without an intervening call to the fflush
 | |
|     function or to a file positioning function (fseek, fsetpos, or rewind), and input shall not be directly
 | |
|     followed by output without an intervening call to a file positioning function, unless the input
 | |
|     operation encounters end-of-file. Opening (or creating) a text file with update mode may instead
 | |
|     open (or create) a binary stream in some implementations.
 | |
| </pre>
 | |
| <a name='7.23.5.3p8'></a>
 | |
| <pre>8   When opened, a stream is fully buffered if and only if it can be determined not to refer to an
 | |
|     interactive device. The error and end-of-file indicators for the stream are cleared.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.5.3p9'></a>
 | |
| <pre>9   The fopen function returns a pointer to the object controlling the stream. If the open operation fails,
 | |
|     fopen returns a null pointer.
 | |
|     Forward references: file positioning functions (<a href='#7.23.9'>7.23.9</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.5.4'></a>
 | |
| <hr>
 | |
| <h3>7.23.5.4 [The freopen function]</h3>
 | |
| <a name='7.23.5.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             FILE *freopen(const char * restrict filename, const char * restrict mode,
 | |
|                   FILE * restrict stream);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.5.4p2'></a>
 | |
| <pre>2   The freopen function opens the file whose name is the string pointed to by filename and associates
 | |
|     the stream pointed to by stream with it. The mode argument is used just as in the fopen function.<a href='#FOOTNOTE.334'><sup>[334]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.334'>
 | |
| <pre><i><b>Footnote 334)</b> The primary use of the freopen function is to change the file associated with a standard text stream (stderr, stdin,
 | |
|     or stdout), as those identifiers need not be modifiable lvalues to which the value returned by the fopen function could be
 | |
|     assigned.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.5.4p3'></a>
 | |
| <pre>3   If filename is a null pointer, the freopen function attempts to change the mode of the stream to
 | |
|     that specified by mode, as if the name of the file currently associated with the stream had been
 | |
|     used. It is implementation-defined which changes of mode are permitted (if any), and under what
 | |
|     circumstances.
 | |
| </pre>
 | |
| <a name='7.23.5.4p4'></a>
 | |
| <pre>4   The freopen function first attempts to close any file that is associated with the specified stream.
 | |
|     Failure to close the file is ignored. The error and end-of-file indicators for the stream are cleared.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.5.4p5'></a>
 | |
| <pre>5   The freopen function returns a null pointer if the open operation fails. Otherwise, freopen returns
 | |
|     the value of stream.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.5.5'></a>
 | |
| <hr>
 | |
| <h3>7.23.5.5 [The setbuf function]</h3>
 | |
| <a name='7.23.5.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               void setbuf(FILE * restrict stream, char * restrict buf);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.5.5p2'></a>
 | |
| <pre>2   Except that it returns no value, the setbuf function is equivalent to the setvbuf function invoked
 | |
|     with the values _IOFBF for mode and BUFSIZ for size, or (if buf is a null pointer), with the value
 | |
|     _IONBF for mode.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.5.5p3'></a>
 | |
| <pre>3   The setbuf function returns no value.
 | |
|     Forward references: the setvbuf function (<a href='#7.23.5.6'>7.23.5.6</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.5.6'></a>
 | |
| <hr>
 | |
| <h3>7.23.5.6 [The setvbuf function]</h3>
 | |
| <a name='7.23.5.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int setvbuf(FILE * restrict stream, char * restrict buf, int mode, size_t size);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.5.6p2'></a>
 | |
| <pre>2   The setvbuf function may be used only after the stream pointed to by stream has been associated
 | |
|     with an open file and before any other operation (other than an unsuccessful call to setvbuf) is
 | |
|     performed on the stream. The argument mode determines how stream will be buffered, as follows:
 | |
| 
 | |
|     _IOFBF         causes input/output to be fully buffered;
 | |
| 
 | |
|     _IOLBF         causes input/output to be line buffered;
 | |
| 
 | |
|     _IONBF         causes input/output to be unbuffered.
 | |
| 
 | |
|     If buf is not a null pointer, the array it points to may be used instead of a buffer allocated by the
 | |
|     setvbuf function<a href='#FOOTNOTE.335'><sup>[335]</sup></a> and the argument size specifies the size of the array; otherwise, size may
 | |
|     determine the size of a buffer allocated by the setvbuf function. The members of the array at any
 | |
|     time have unspecified values.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.335'>
 | |
| <pre><i><b>Footnote 335)</b> The buffer has to have a lifetime at least as great as the open stream, so not closing the stream before a buffer that has
 | |
|     automatic storage duration is deallocated upon block exit results in undefined behavior.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.5.6p3'></a>
 | |
| <pre>3   The setvbuf function returns zero on success, or nonzero if an invalid value is given for mode or if
 | |
|     the request cannot be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6'></a>
 | |
| <hr>
 | |
| <h3>7.23.6 [Formatted input/output functions]</h3>
 | |
| <a name='7.23.6p1'></a>
 | |
| <pre>1   The formatted input/output functions shall behave as if there is a sequence point after the actions
 | |
|     associated with each specifier.<a href='#FOOTNOTE.336'><sup>[336]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.336'>
 | |
| <pre><i><b>Footnote 336)</b> The fprintf functions perform writes to memory for the %n specifier.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.1 [The fprintf function]</h3>
 | |
| <a name='7.23.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int fprintf(FILE * restrict stream, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.1p2'></a>
 | |
| <pre>2   The fprintf function writes output to the stream pointed to by stream, under control of the string
 | |
|     pointed to by format that specifies how subsequent arguments are converted for output. If there are
 | |
|     insufficient arguments for the format, the behavior is undefined. If the format is exhausted while
 | |
|     arguments remain, the excess arguments are evaluated (as always) but are otherwise ignored. The
 | |
|     fprintf function returns when the end of the format string is encountered.
 | |
| </pre>
 | |
| <a name='7.23.6.1p3'></a>
 | |
| <pre>3   The format shall be a multibyte character sequence, beginning and ending in its initial shift state.
 | |
|     The format is composed of zero or more directives: ordinary multibyte characters (not %), which
 | |
|     are copied unchanged to the output stream; and conversion specifications, each of which results
 | |
|     in fetching zero or more subsequent arguments, converting them, if applicable, according to the
 | |
|     corresponding conversion specifier, and then writing the result to the output stream.
 | |
| </pre>
 | |
| <a name='7.23.6.1p4'></a>
 | |
| <pre>4   Each conversion specification is introduced by the character %. After the %, the following appear in
 | |
|     sequence:
 | |
| 
 | |
|       — Zero or more flags (in any order) that modify the meaning of the conversion specification.
 | |
| 
 | |
|       — An optional minimum field width. If the converted value has fewer characters than the field
 | |
|         width, it is padded with spaces (by default) on the left (or right, if the left adjustment flag,
 | |
|         described later, has been given) to the field width. The field width takes the form of an asterisk
 | |
|         * (described later) or a nonnegative decimal integer.<a href='#FOOTNOTE.337'><sup>[337]</sup></a>
 | |
| 
 | |
|       — An optional precision that gives the minimum number of digits to appear for the b, d, i, o, u, x,
 | |
|         and X conversions, the number of digits to appear after the decimal-point character for a, A, e,
 | |
|         E, f, and F conversions, the maximum number of significant digits for the g and G conversions,
 | |
|         or the maximum number of bytes to be written for s conversions. The precision takes the form
 | |
|         of a period (.) followed either by an asterisk * (described later) or by an optional nonnegative
 | |
|         decimal integer; if only the period is specified, the precision is taken as zero. If a precision
 | |
|         appears with any other conversion specifier, the behavior is undefined.
 | |
| 
 | |
|       — An optional length modifier that specifies the size of the argument.
 | |
| 
 | |
|       — A conversion specifier character that specifies the type of conversion to be applied.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.337'>
 | |
| <pre><i><b>Footnote 337)</b> Note that 0 is taken as a flag, not as the beginning of a field width.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.1p5'></a>
 | |
| <pre>5   As noted above, a field width, or precision, or both, may be indicated by an asterisk. In this case,
 | |
|     an int argument supplies the field width or precision. The arguments specifying field width, or
 | |
|     precision, or both, shall appear (in that order) before the argument (if any) to be converted. A
 | |
|     negative field width argument is taken as a - flag followed by a positive field width. A negative
 | |
|     precision argument is taken as if the precision were omitted.
 | |
| </pre>
 | |
| <a name='7.23.6.1p6'></a>
 | |
| <pre>6   The flag characters and their meanings are:
 | |
|     -           The result of the conversion is left-justified within the field. (It is right-justified if this flag is
 | |
|                 not specified.)
 | |
| 
 | |
|     +           The result of a signed conversion always begins with a plus or minus sign. (It begins with a
 | |
|                 sign only when a value with a negative sign is converted if this flag is not specified.) <a href='#FOOTNOTE.338'><sup>[338]</sup></a>
 | |
| 
 | |
|     space If the first character of a signed conversion is not a sign, or if a signed conversion results in
 | |
|           no characters, a space is prefixed to the result. If the space and + flags both appear, the space
 | |
|           flag is ignored.
 | |
| 
 | |
|     #           The result is converted to an "alternative form". For o conversion, it increases the precision, if
 | |
|                 and only if necessary, to force the first digit of the result to be a zero (if the value and precision
 | |
|                 are both 0, a single 0 is printed). For b conversion, a nonzero result has 0b prefixed to it. For
 | |
|                 x (or X) conversion, a nonzero result has 0x (or 0X) prefixed to it. For a, A, e, E, f, F, g, and G
 | |
|                 conversions, the result of converting a floating-point number always contains a decimal-point
 | |
|                 character, even if no digits follow it. (Normally, a decimal-point character appears in the
 | |
|                 result of these conversions only if a digit follows it.) For g and G conversions, trailing zeros
 | |
|                 are not removed from the result. For other conversions, the behavior is undefined.
 | |
| 
 | |
|     0           For b, d, i, o, u, x, X, a, A, e, E, f, F, g, and G conversions, leading zeros (following any
 | |
|                 indication of sign or base) are used to pad to the field width rather than performing space
 | |
|                 padding, except when converting an infinity or NaN. If the 0 and - flags both appear, the
 | |
|                 0 flag is ignored. For d, i, o, u, x, and X conversions, if a precision is specified, the 0 flag is
 | |
|                 ignored. For other conversions, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.338'>
 | |
| <pre><i><b>Footnote 338)</b> The results of all floating conversions of a negative zero, and of negative values that round to zero, include a minus sign.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.1p7'></a>
 | |
| <pre>7   The length modifiers and their meanings are:
 | |
| 
 | |
|     hh                 Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a
 | |
|                        signed char or unsigned char argument (the argument will have been promoted
 | |
|                        according to the integer promotions, but its value shall be converted to signed char or
 | |
|                        unsigned char before printing); or that a following n conversion specifier applies to a
 | |
|                        pointer to a signed char argument.
 | |
| 
 | |
|     h                  Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a short int
 | |
|                        or unsigned short int argument (the argument will have been promoted accord-
 | |
|                        ing to the integer promotions, but its value shall be converted to short int or
 | |
|                        unsigned short int before printing); or that a following n conversion specifier applies
 | |
|                        to a pointer to a short int argument.
 | |
| 
 | |
|     l (ell)            Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a long int
 | |
|                        or unsigned long int argument; that a following n conversion specifier applies to
 | |
|                        a pointer to a long int argument; that a following c conversion specifier applies to
 | |
|                        a wint_t argument; that a following s conversion specifier applies to a pointer to a
 | |
|                        wchar_t argument; or has no effect on a following a, A, e, E, f, F, g, or G conversion
 | |
|                        specifier.
 | |
| 
 | |
|     ll (ell-ell) Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a
 | |
|                  long long int or unsigned long long int argument; or that a following n con-
 | |
|                  version specifier applies to a pointer to a long long int argument.
 | |
| 
 | |
|     j                  Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to an intmax_t
 | |
|                        or uintmax_t argument; or that a following n conversion specifier applies to a pointer
 | |
|                        to an intmax_t argument.
 | |
| 
 | |
|     z                  Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a size_t
 | |
|                        or the corresponding signed integer type argument; or that a following n conversion
 | |
|                        specifier applies to a pointer to a signed integer type corresponding to size_t argument.
 | |
|     t           Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a ptrdiff_t
 | |
|                 or the corresponding unsigned integer type argument; or that a following n conversion
 | |
|                 specifier applies to a pointer to a ptrdiff_t argument.
 | |
| 
 | |
|     wN          Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to an integer
 | |
|                 argument with a specific width where N is a positive decimal integer with no leading
 | |
|                 zeros (the argument will have been promoted according to the integer promotions, but
 | |
|                 its value shall be converted to the unpromoted type); or that a following n conversion
 | |
|                 specifier applies to a pointer to an integer type argument with a width of N bits. All
 | |
|                 minimum-width integer types (<a href='#7.22.1.2'>7.22.1.2</a>) and exact-width integer types (<a href='#7.22.1.1'>7.22.1.1</a>) de-
 | |
|                 fined in the header <stdint.h> shall be supported. Other supported values of N are
 | |
|                 implementation-defined.
 | |
| 
 | |
|     wfN         Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a fastest
 | |
|                 minimum-width integer argument with a specific width where N is a positive decimal
 | |
|                 integer with no leading zeros (the argument will have been promoted according to
 | |
|                 the integer promotions, but its value shall be converted to the unpromoted type); or
 | |
|                 that a following n conversion specifier applies to a pointer to a fastest minimum-width
 | |
|                 integer type argument with a width of N bits. All fastest minimum-width integer types
 | |
|                 (<a href='#7.22.1.3'>7.22.1.3</a>) defined in the header <stdint.h> shall be supported. Other supported values
 | |
|                 of N are implementation-defined.
 | |
| 
 | |
|     L           Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                 long double argument.
 | |
| 
 | |
|     H           Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                 _Decimal32 argument.
 | |
| 
 | |
|     D           Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                 _Decimal64 argument.
 | |
| 
 | |
|     DD          Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                 _Decimal128 argument.
 | |
| 
 | |
| 
 | |
|     If a length modifier appears with any conversion specifier other than as specified above, the behavior
 | |
|     is undefined.
 | |
| </pre>
 | |
| <a name='7.23.6.1p8'></a>
 | |
| <pre>8   The conversion specifiers and their meanings are:
 | |
| 
 | |
|     d,i       The int argument is converted to signed decimal in the style [-]dddd. The precision
 | |
|               specifies the minimum number of digits to appear; if the value being converted can be
 | |
|               represented in fewer digits, it is expanded with leading zeros. The default precision is 1.
 | |
|               The result of converting a zero value with a precision of zero is no characters.
 | |
|     b, o,u,x,X The unsigned int argument is converted to unsigned binary (b), unsigned octal (o),
 | |
|             unsigned decimal (u), or unsigned hexadecimal notation (x or X) in the style dddd; the
 | |
|             letters abcdef are used for x conversion and the letters ABCDEF for X conversion. The
 | |
|               precision specifies the minimum number of digits to appear; if the value being converted
 | |
|               can be represented in fewer digits, it is expanded with leading zeros. The default precision
 | |
|               is 1. The result of converting a zero value with a precision of zero is no characters.
 | |
|     f,F       A double argument representing a floating-point number is converted to decimal notation
 | |
|               in the style [-]ddd.ddd, where the number of digits after the decimal-point character is
 | |
|               equal to the precision specification. If the precision is missing, it is taken as 6; if the
 | |
|               precision is zero and the # flag is not specified, no decimal-point character appears. If a
 | |
|               decimal-point character appears, at least one digit appears before it. The value is rounded
 | |
|               to the appropriate number of digits.
 | |
|               A double argument representing an infinity is converted in one of the styles [-]inf or
 | |
|               [-]infinity — which style is implementation-defined. A double argument representing a
 | |
|               NaN is converted in one of the styles [-]nan or [-]nan(n-char-sequence) — which style, and
 | |
|             the meaning of any n-char-sequence, is implementation-defined. The F conversion specifier
 | |
|             produces INF, INFINITY, or NAN instead of inf, infinity, or nan, respectively.<a href='#FOOTNOTE.339'><sup>[339]</sup></a>
 | |
| e,E         A double argument representing a floating-point number is converted in the style
 | |
|             [-]d.ddde±dd, where there is one digit (which is nonzero if the argument is nonzero) before
 | |
|             the decimal-point character and the number of digits after it is equal to the precision; if the
 | |
|             precision is missing, it is taken as 6; if the precision is zero and the # flag is not specified,
 | |
|             no decimal-point character appears. The value is rounded to the appropriate number of
 | |
|             digits. The E conversion specifier produces a number with E instead of e introducing the
 | |
|             exponent. The exponent always contains at least two digits, and only as many more digits
 | |
|             as necessary to represent the exponent. If the value is zero, the exponent is zero.
 | |
|             A double argument representing an infinity or NaN is converted in the style of an f or F
 | |
|             conversion specifier.
 | |
| g,G         A double argument representing a floating-point number is converted in style f or e (or
 | |
|             in style F or E in the case of a G conversion specifier), depending on the value converted
 | |
|             and the precision. Let P equal the precision if nonzero, 6 if the precision is omitted, or 1 if
 | |
|             the precision is zero. Then, if a conversion with style E would have an exponent of X:
 | |
|                   if P > X ≥ −4, the conversion is with style f (or F) and precision P − (X + 1).
 | |
|                   otherwise, the conversion is with style e (or E) and precision P − 1.
 | |
|             Finally, unless the # flag is used, any trailing zeros are removed from the fractional portion
 | |
|             of the result and the decimal-point character is removed if there is no fractional portion
 | |
|             remaining.
 | |
|             A double argument representing an infinity or NaN is converted in the style of an f or F
 | |
|             conversion specifier.
 | |
| a,A         A double argument representing a floating-point number is converted in the style
 | |
|             [-]0xh.hhhhp±d, where there is one hexadecimal digit (which is nonzero if the argument is a
 | |
|             normalized floating-point number and is otherwise unspecified) before the decimal-point
 | |
|             character<a href='#FOOTNOTE.340'><sup>[340]</sup></a> and the number of hexadecimal digits after it is equal to the precision; if the
 | |
|             precision is missing and FLT_RADIX is a power of 2, then the precision is sufficient for an
 | |
|             exact representation of the value; if the precision is missing and FLT_RADIX is not a power
 | |
|             of 2, then the precision is sufficient to distinguish<a href='#FOOTNOTE.341'><sup>[341]</sup></a> values of type double, except that
 | |
|             trailing zeros may be omitted; if the precision is zero and the # flag is not specified, no
 | |
|             decimal-point character appears. The letters abcdef are used for a conversion and the
 | |
|             letters ABCDEF for A conversion. The A conversion specifier produces a number with X and
 | |
|             P instead of x and p. The exponent always contains at least one digit, and only as many
 | |
|             more digits as necessary to represent the decimal exponent of 2. If the value is zero, the
 | |
|             exponent is zero.
 | |
|             A double argument representing an infinity or NaN is converted in the style of an f or F
 | |
|             conversion specifier.
 | |
|  <a href='#FOOTNOTE.339'><sup>[339]</sup></a> When applied to infinite and NaN values, the -, +, and space flag characters have their usual meaning; the # and 0 flag
 | |
| 
 | |
| characters have no effect.
 | |
|  <a href='#FOOTNOTE.340'><sup>[340]</sup></a> Binary implementations can choose the hexadecimal digit to the left of the decimal-point character so that subsequent
 | |
| 
 | |
| digits align to nibble (4-bit) boundaries. This implementation choice affects numerical values printed with a precision P
 | |
| that is insufficient to represent all values exactly. Implementations with different conventions about the most significant
 | |
| hexadecimal digit will round at different places, affecting the numerical value of the hexadecimal result. For example,
 | |
| possible printed output for the code
 | |
| 
 | |
|           #include <stdio.h>
 | |
|           /* ... */
 | |
|           double x = 123.0;
 | |
|           printf("%.1a", x);
 | |
| 
 | |
| include "0x1.fp+6 " and "0xf.6p+3 " whose numerical values are 124 and 123, respectively. Portable code seeking identical
 | |
| numerical results on different platforms should avoid precisions P that require rounding.
 | |
|  <a href='#FOOTNOTE.341'><sup>[341]</sup></a> The formatting precision P is sufficient to distinguish values of the source type if 16P > bp where b (not a power of 2)
 | |
| 
 | |
| and p are the base and precision of the source type (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). A smaller P might suffice depending on the implementation’s
 | |
| scheme for determining the digit to the left of the decimal-point character.
 | |
|            If an H, D, or DD modifier is present and the precision is missing, then for a decimal
 | |
|            floating type argument represented by a triple of integers (s, c, q), where n is the number
 | |
|            of significant digits in the coefficient c,
 | |
| 
 | |
|              — if −(n + 5) ≤ q ≤ 0, use style f (or style F in the case of an A conversion specifier)
 | |
|                with formatting precision equal to −q,
 | |
|              — otherwise, use style e (or style E in the case of an A conversion specifier) with format-
 | |
|                ting precision equal to n − 1, with the exceptions that if c = 0 then the digit-sequence
 | |
|                in the exponent-part shall have the value q (rather than 0), and that the exponent is
 | |
|                always expressed with the minimum number of digits required to represent its value
 | |
|                (the exponent never contains a leading zero).
 | |
| 
 | |
|            If the precision P is present (in the conversion specification) and is zero or at least as
 | |
|            large as the precision p (<a href='#5.2.4.2.2'>5.2.4.2.2</a>) of the decimal floating type, the conversion is as if the
 | |
|            precision were missing. If the precision P is present (and nonzero) and less than the
 | |
|            precision p of the decimal floating type, the conversion first obtains an intermediate result
 | |
|            as follows, where n is the number of significant digits in the coefficient:
 | |
| 
 | |
|              — If n ≤ P , set the intermediate result to the input.
 | |
|              — If n > P , round the input value, according to the current rounding direction for
 | |
|                decimal floating-point operations, to P decimal digits, with unbounded exponent
 | |
|                range, representing the result with a P -digit integer coefficient when in the form
 | |
|                (s, c, q).
 | |
| 
 | |
|            Convert the intermediate result in the manner described above for the case where the
 | |
|            precision is missing.
 | |
| c          If no l length modifier is present, the int argument is converted to an unsigned char,
 | |
|            and the resulting character is written.
 | |
|            If an l length modifier is present, the wint_t argument is converted as if by an ls
 | |
|            conversion specification with no precision and an argument that points to storage suitably
 | |
|            sized for at least two wchar_t elements, the first element containing the wint_t argument
 | |
|            to the lc conversion specification and the second a null wide character.
 | |
| s          If no l length modifier is present, the argument shall be a pointer to storage of character
 | |
|            type.<a href='#FOOTNOTE.342'><sup>[342]</sup></a> Characters from the storage are written up to (but not including) the terminating
 | |
|            null character. If the precision is specified, no more than that many bytes are written. If
 | |
|            the precision is not specified or is greater than the size of the storage, the storage shall
 | |
|            contain a null character.
 | |
|            If an l length modifier is present, the argument shall be a pointer to storage of wchar_t
 | |
|            type. Wide characters from the storage are converted to multibyte characters (each as if
 | |
|            by a call to the wcrtomb function, with the conversion state described by an mbstate_t
 | |
|            object initialized to zero before the first wide character is converted) up to and including
 | |
|            a terminating null wide character. The resulting multibyte characters are written up to
 | |
|            (but not including) the terminating null character (byte). If no precision is specified, the
 | |
|            storage shall contain a null wide character. If a precision is specified, no more than that
 | |
|            many bytes are written (including shift sequences, if any), and the storage shall contain
 | |
|            a null wide character if, to equal the multibyte character sequence length given by the
 | |
|            precision, the function would need to access a wide character one past the end of the array.
 | |
|            In no case is a partial multibyte character written.<a href='#FOOTNOTE.343'><sup>[343]</sup></a>
 | |
| p          The argument shall be a pointer to void or a pointer to a character type. The value of the
 | |
|            pointer is converted to a sequence of printing characters, in an implementation-defined
 | |
|            manner.
 | |
|      n           The argument shall be a pointer to signed integer whose type is specified by the length
 | |
|                  modifiers, if any, for the conversion specification, or shall be int if no length modifiers are
 | |
|                  specified for the conversion specification. The number of characters written to the output
 | |
|                  stream so far by this call to fprintf is stored into the integer object pointed to by the
 | |
|                  argument. No argument is converted, but one is consumed. If the conversion specification
 | |
|                  includes any flags, a field width, or a precision, the behavior is undefined.
 | |
|      %           A % character is written. No argument is converted. The complete conversion specification
 | |
|                  shall be %%.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.339'>
 | |
| <pre><i><b>Footnote 339)</b> When applied to infinite and NaN values, the -, +, and space flag characters have their usual meaning; the # and 0 flag
 | |
| characters have no effect.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.340'>
 | |
| <pre><i><b>Footnote 340)</b> Binary implementations can choose the hexadecimal digit to the left of the decimal-point character so that subsequent
 | |
| digits align to nibble (4-bit) boundaries. This implementation choice affects numerical values printed with a precision P
 | |
| that is insufficient to represent all values exactly. Implementations with different conventions about the most significant
 | |
| hexadecimal digit will round at different places, affecting the numerical value of the hexadecimal result. For example,
 | |
| possible printed output for the code
 | |
|           #include <stdio.h>
 | |
|           /* ... */
 | |
|           double x = 123.0;
 | |
|           printf("%.1a", x);
 | |
| include "0x1.fp+6 " and "0xf.6p+3 " whose numerical values are 124 and 123, respectively. Portable code seeking identical
 | |
| numerical results on different platforms should avoid precisions P that require rounding.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.341'>
 | |
| <pre><i><b>Footnote 341)</b> The formatting precision P is sufficient to distinguish values of the source type if 16P > bp where b (not a power of 2)
 | |
| and p are the base and precision of the source type (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). A smaller P might suffice depending on the implementation’s
 | |
| scheme for determining the digit to the left of the decimal-point character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.339'>
 | |
| <pre><i><b>Footnote 339)</b> When applied to infinite and NaN values, the -, +, and space flag characters have their usual meaning; the # and 0 flag
 | |
| characters have no effect.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.340'>
 | |
| <pre><i><b>Footnote 340)</b> Binary implementations can choose the hexadecimal digit to the left of the decimal-point character so that subsequent
 | |
| digits align to nibble (4-bit) boundaries. This implementation choice affects numerical values printed with a precision P
 | |
| that is insufficient to represent all values exactly. Implementations with different conventions about the most significant
 | |
| hexadecimal digit will round at different places, affecting the numerical value of the hexadecimal result. For example,
 | |
| possible printed output for the code
 | |
|           #include <stdio.h>
 | |
|           /* ... */
 | |
|           double x = 123.0;
 | |
|           printf("%.1a", x);
 | |
| include "0x1.fp+6 " and "0xf.6p+3 " whose numerical values are 124 and 123, respectively. Portable code seeking identical
 | |
| numerical results on different platforms should avoid precisions P that require rounding.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.341'>
 | |
| <pre><i><b>Footnote 341)</b> The formatting precision P is sufficient to distinguish values of the source type if 16P > bp where b (not a power of 2)
 | |
| and p are the base and precision of the source type (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). A smaller P might suffice depending on the implementation’s
 | |
| scheme for determining the digit to the left of the decimal-point character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.342'>
 | |
| <pre><i><b>Footnote 342)</b> No special provisions are made for multibyte characters.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.343'>
 | |
| <pre><i><b>Footnote 343)</b> Redundant shift sequences can result if multibyte characters have a state-dependent encoding.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.1p9'></a>
 | |
| <pre>9    If a conversion specification is invalid, the behavior is undefined.<a href='#FOOTNOTE.344'><sup>[344]</sup></a> fprintf shall behave as if it
 | |
|      uses va_arg with a type argument naming the type resulting from applying the default argument
 | |
|      promotions to the type corresponding to the conversion specification and then converting the result
 | |
|      of the va_arg expansion to the type corresponding to the conversion specification.<a href='#FOOTNOTE.345'><sup>[345]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.344'>
 | |
| <pre><i><b>Footnote 344)</b> See "future library directions" (<a href='#7.33.15'>7.33.15</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.345'>
 | |
| <pre><i><b>Footnote 345)</b> The behavior is undefined when the types differ as specified for va_arg <a href='#7.16.1.1'>7.16.1.1</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.1p10'></a>
 | |
| <pre>10   In no case does a nonexistent or small field width cause truncation of a field; if the result of a
 | |
|      conversion is wider than the field width, the field is expanded to contain the conversion result.
 | |
| </pre>
 | |
| <a name='7.23.6.1p11'></a>
 | |
| <pre>11   For a and A conversions, if FLT_RADIX is a power of 2, the value is correctly rounded to a hexadecimal
 | |
|      floating number with the given precision.
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='7.23.6.1p12'></a>
 | |
| <pre>12   For a and A conversions, if FLT_RADIX is not a power of 2 and the result is not exactly representable
 | |
|      in the given precision, the result should be one of the two adjacent numbers in hexadecimal floating
 | |
|      style with the given precision, with the extra stipulation that the error should have a correct sign for
 | |
|      the current rounding direction.
 | |
| </pre>
 | |
| <a name='7.23.6.1p13'></a>
 | |
| <pre>13   For e, E, f, F, g, and G conversions, if the number of significant decimal digits is at most the maximum
 | |
|      value M of the T_DECIMAL_DIG macros (defined in <float.h>), then the result should be correctly
 | |
|      rounded.<a href='#FOOTNOTE.346'><sup>[346]</sup></a> If the number of significant decimal digits is more than M but the source value is
 | |
|      exactly representable with M digits, then the result should be an exact representation with trailing
 | |
|      zeros. Otherwise, the source value is bounded by two adjacent decimal strings L < U, both having
 | |
|      M significant digits; the value of the resultant decimal string D should satisfy L ≤ D ≤ U, with the
 | |
|      extra stipulation that the error should have a correct sign for the current rounding direction.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.346'>
 | |
| <pre><i><b>Footnote 346)</b> For binary-to-decimal conversion, the result format’s values are the numbers representable with the given format specifier.
 | |
|      The number of significant digits is determined by the format specifier, and in the case of fixed-point conversion by the source
 | |
|      value as well.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.1p14'></a>
 | |
| <pre>14   An uppercase B format specifier is not covered by the description above, because it used to be
 | |
|      available for extensions in previous versions of this standard.
 | |
|      Implementations that did not use an uppercase B as their own extension before are encouraged to
 | |
|      implement it similar to conversion specifier b as standardized above, with the alternative form (#B)
 | |
|      generating 0B as prefix for nonzero values.
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='7.23.6.1p15'></a>
 | |
| <pre>15   The fprintf function returns the number of characters transmitted, or a negative value if an output
 | |
|      or encoding error occurred or if the implementation does not support a specified width length
 | |
|      modifier.
 | |
| 
 | |
|      Environmental limits
 | |
| </pre>
 | |
| <a name='7.23.6.1p16'></a>
 | |
| <pre>16   The number of characters that can be produced by any single conversion shall be at least 4095.
 | |
| </pre>
 | |
| <a name='7.23.6.1p17'></a>
 | |
| <pre>17   EXAMPLE 1 To print a date and time in the form "Sunday, July 3, 10:02" followed by π to five decimal places:
 | |
| 
 | |
|                #include <math.h>
 | |
|                #include <stdio.h>
 | |
|                /* ... */
 | |
|                char *weekday, *month;                  // pointers to strings
 | |
|                int day, hour, min;
 | |
|                 fprintf(stdout, "%s, %s %d, %.2d:%.2d\n",
 | |
|                       weekday, month, day, hour, min);
 | |
|                 fprintf(stdout, "pi = %.5f\n", 4 * atan(1.0));
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.1p18'></a>
 | |
| <pre>18   EXAMPLE 2 In this example, multibyte characters do not have a state-dependent encoding, and the members of the extended
 | |
|      character set that consist of more than one byte each consist of exactly two bytes, the first of which is denoted here by a □
 | |
|      and the second by an uppercase letter.
 | |
| </pre>
 | |
| <a name='7.23.6.1p19'></a>
 | |
| <pre>19   Given the following wide string with length seven,
 | |
| 
 | |
|                 static wchar_t wstr[] = L"□X□Yabc□Z□W";
 | |
| 
 | |
|      the seven calls
 | |
| 
 | |
|                 fprintf(stdout, "|1234567890123|\n");
 | |
|                 fprintf(stdout, "|%13ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%-13.9ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%13.10ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%13.11ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%13.15ls|\n", &wstr[2]);
 | |
|                 fprintf(stdout, "|%13lc|\n", (wint_t) wstr[5]);
 | |
| 
 | |
|      will print the following seven lines:
 | |
| 
 | |
|                  |1234567890123|
 | |
|                  | □X□Yabc□Z□W|
 | |
|                  |□X□Yabc□Z    |
 | |
|                  |    □X□Yabc□Z|
 | |
|                  | □X□Yabc□Z□W|
 | |
|                  |      abc□Z□W|
 | |
|                  |           □Z|
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.1p20'></a>
 | |
| <pre>20   EXAMPLE 3 Following are representations of _Decimal64 arguments as triples (s, c, q) and the corresponding character
 | |
|      sequences fprintf produces with "%Da":
 | |
|       (+1, 123, 0)                        123
 | |
|       (−1, 123, 0)                        -123
 | |
|       (+1, 123, −2)                       1.23
 | |
|       (+1, 123, 1)                        <a href='#1.'>1.</a>23e+3
 | |
|       (−1, 123, 1)                        -<a href='#1.'>1.</a>23e+3
 | |
|       (+1, 123, −8)                       0.00000123
 | |
|       (+1, 123, −9)                       <a href='#1.'>1.</a>23e-7
 | |
|       (+1, 120, −8)                       0.00000120
 | |
|       (+1, 120, −9)                       <a href='#1.'>1.</a>20e-7
 | |
|       (+1, 1234567890123456, 0)           1234567890123456
 | |
|       (+1, 1234567890123456, 1)           <a href='#1.'>1.</a>234567890123456e+16
 | |
|       (+1, 1234567890123456, −1)          123456789012345.6
 | |
|       (+1, 1234567890123456, −21)         0.000001234567890123456
 | |
|       (+1, 1234567890123456, −22)         <a href='#1.'>1.</a>234567890123456e-7
 | |
|       (+1, 0, 0)                          0
 | |
|       (−1, 0, 0)                          -0
 | |
|       (+1, 0, −6)                         0.000000
 | |
|       (+1, 0, −7)                         0e-7
 | |
|       (+1, 0, 2)                          0e+2
 | |
|       (+1, 5, −6)                         0.000005
 | |
|       (+1, 50, −7)                        0.0000050
 | |
|       (+1, 5, −7)                         5e-7
 | |
| 
 | |
|      To illustrate the effects of a precision specification, the sequence:
 | |
| 
 | |
|                 _Decimal32 x = 6543.00DF;                       // (+1, 654300, -2)
 | |
|                 fprintf(stdout, "%Ha\n", x);
 | |
|                 fprintf(stdout, "%.6Ha\n", x);
 | |
|                 fprintf(stdout, "%.5Ha\n", x);
 | |
|                 fprintf(stdout, "%.4Ha\n", x);
 | |
|                 fprintf(stdout, "%.3Ha\n", x);
 | |
|                 fprintf(stdout, "%.2Ha\n", x);
 | |
|               fprintf(stdout, "%.1Ha\n", x);
 | |
|               fprintf(stdout, "%.0Ha\n", x);
 | |
| 
 | |
|     assuming default rounding, results in:
 | |
|      6543.00
 | |
|      6543.00
 | |
|      6543.0
 | |
|      6543
 | |
|      <a href='#6.'>6.</a>54e+3
 | |
|      <a href='#6.'>6.</a>5e+3
 | |
|      7e+3
 | |
|      6543.00
 | |
| 
 | |
|     To illustrate the effects of the exponent range, the sequence:
 | |
| 
 | |
|               _Decimal32 x = 9543210e87DF;                  // (+1, 9543210, 87)
 | |
|               _Decimal32 y = 9500000e90DF;                  // (+1, 9500000, 90)
 | |
|               fprintf(stdout, "%.6Ha\n", x);
 | |
|               fprintf(stdout, "%.5Ha\n", x);
 | |
|               fprintf(stdout, "%.4Ha\n", x);
 | |
|               fprintf(stdout, "%.3Ha\n", x);
 | |
|               fprintf(stdout, "%.2Ha\n", x);
 | |
|               fprintf(stdout, "%.1Ha\n", x);
 | |
|               fprintf(stdout, "%.1Ha\n", y);
 | |
| 
 | |
|     assuming default rounding, results in:
 | |
|      9.54321e+93
 | |
|      9.5432e+93
 | |
|      9.543e+93
 | |
|      9.54e+93
 | |
|      9.5e+93
 | |
|      1e+94
 | |
|      1e+97
 | |
| 
 | |
|     To further illustrate the effects of the exponent range, the sequence:
 | |
| 
 | |
|               _Decimal32 x = 9512345e90DF;                    // (+1, 9512345, 90)
 | |
|               _Decimal32 y = 9512345e86DF;                    // (+1, 9512345, 86)
 | |
|               fprintf(stdout, "%.3Ha\n", x);
 | |
|               fprintf(stdout, "%.2Ha\n", x);
 | |
|               fprintf(stdout, "%.1Ha\n", x);
 | |
|               fprintf(stdout, "%.2Ha\n", y);
 | |
| 
 | |
|     assuming default rounding, results in:
 | |
|      9.51e+96
 | |
|      9.5e+96
 | |
|      1e+97
 | |
|      9.5e+92
 | |
| 
 | |
|     Forward references: conversion state (<a href='#7.31.6'>7.31.6</a>), the wcrtomb function (<a href='#7.31.6.3.3'>7.31.6.3.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.2 [The fscanf function]</h3>
 | |
| <a name='7.23.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int fscanf(FILE * restrict stream, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.2p2'></a>
 | |
| <pre>2   The fscanf function reads input from the stream pointed to by stream, under control of the string
 | |
|     pointed to by format that specifies the admissible input sequences and how they are to be converted
 | |
|     for assignment, using subsequent arguments as pointers to the objects to receive the converted
 | |
|     input. If there are insufficient arguments for the format, the behavior is undefined. If the format
 | |
|     is exhausted while arguments remain, the excess arguments are evaluated (as always) but are
 | |
|     otherwise ignored.
 | |
| </pre>
 | |
| <a name='7.23.6.2p3'></a>
 | |
| <pre>3    The format shall be a multibyte character sequence, beginning and ending in its initial shift state.The
 | |
|      format is composed of zero or more directives: one or more white-space characters, an ordinary
 | |
|      multibyte character (neither % nor a white-space character), or a conversion specification. Each
 | |
|      conversion specification is introduced by the character %. After the %, the following appear in
 | |
|      sequence:
 | |
| 
 | |
|          — An optional assignment-suppressing character *.
 | |
| 
 | |
|          — An optional decimal integer greater than zero that specifies the maximum field width (in
 | |
|            characters).
 | |
| 
 | |
|          — An optional length modifier that specifies the size of the receiving object.
 | |
| 
 | |
|          — A conversion specifier character that specifies the type of conversion to be applied.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.2p4'></a>
 | |
| <pre>4    The fscanf function executes each directive of the format in turn. When all directives have been
 | |
|      executed, or if a directive fails (as detailed below), the function returns. Failures are described as
 | |
|      input failures (due to the occurrence of an encoding error or the unavailability of input characters),
 | |
|      or matching failures (due to inappropriate input).
 | |
| </pre>
 | |
| <a name='7.23.6.2p5'></a>
 | |
| <pre>5    A directive composed of white-space character(s) is executed by reading input up to the first non-
 | |
|      white-space character (which remains unread), or until no more characters can be read. The directive
 | |
|      never fails.
 | |
| </pre>
 | |
| <a name='7.23.6.2p6'></a>
 | |
| <pre>6    A directive that is an ordinary multibyte character is executed by reading the next characters of the
 | |
|      stream. If any of those characters differ from the ones composing the directive,the directive fails and
 | |
|      the differing and subsequent characters remain unread. Similarly, if end-of-file, an encoding error,
 | |
|      or a read error prevents a character from being read, the directive fails.
 | |
| </pre>
 | |
| <a name='7.23.6.2p7'></a>
 | |
| <pre>7    A directive that is a conversion specification defines a set of matching input sequences, as described
 | |
|      below for each specifier. A conversion specification is executed in the following steps:
 | |
| </pre>
 | |
| <a name='7.23.6.2p8'></a>
 | |
| <pre>8    Input white-space characters are skipped, unless the specification includes a [, c, or n specifier.<a href='#FOOTNOTE.347'><sup>[347]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.347'>
 | |
| <pre><i><b>Footnote 347)</b> These white-space characters are not counted against a specified field width.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.2p9'></a>
 | |
| <pre>9    An input item is read from the stream, unless the specification includes an n specifier. An input
 | |
|      item is defined as the longest sequence of input characters which does not exceed any specified
 | |
|      field width and which is, or is a prefix of, a matching input sequence.<a href='#FOOTNOTE.348'><sup>[348]</sup></a> The first character, if any,
 | |
|      after the input item remains unread. If the length of the input item is zero, the execution of the
 | |
|      directive fails; this condition is a matching failure unless end-of-file, an encoding error, or a read
 | |
|      error prevented input from the stream, in which case it is an input failure.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.348'>
 | |
| <pre><i><b>Footnote 348)</b> fscanf pushes back at most one input character onto the input stream. Therefore, some sequences that are acceptable to
 | |
|      strtod, strtol, etc., are unacceptable to fscanf.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.2p10'></a>
 | |
| <pre>10   Except in the case of a % specifier, the input item (or, in the case of a %n directive, the count of input
 | |
|      characters) is converted to a type appropriate to the conversion specifier. If the input item is not a
 | |
|      matching sequence, the execution of the directive fails: this condition is a matching failure. Unless
 | |
|      assignment suppression was indicated by a *, the result of the conversion is placed in the object
 | |
|      pointed to by the first argument following the format argument that has not already received a
 | |
|      conversion result. If this object does not have an appropriate type, or if the result of the conversion
 | |
|      cannot be represented in the object, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.23.6.2p11'></a>
 | |
| <pre>11   The length modifiers and their meanings are:
 | |
| 
 | |
|      hh           Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                   with type pointer to signed char or unsigned char.
 | |
| 
 | |
|      h            Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                   with type pointer to short int or unsigned short int.
 | |
| 
 | |
|      l (ell)      Specifies that a following d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                   with type pointer to long int or unsigned long int; that a following a, A, e, E, f, F,
 | |
|                 g, or G conversion specifier applies to an argument with type pointer to double; or that
 | |
|                 a following c, s, or [ conversion specifier applies to an argument with type pointer to
 | |
|                 wchar_t .
 | |
| 
 | |
|      ll (ell-ell) Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                   with type pointer to long long int or unsigned long long int.
 | |
| 
 | |
|      j          Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                 with type pointer to intmax_t or uintmax_t.
 | |
| 
 | |
|      z          Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                 with type pointer to size_t or the corresponding signed integer type.
 | |
| 
 | |
|      t          Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                 with type pointer to ptrdiff_t or the corresponding unsigned integer type.
 | |
| 
 | |
|      wN          Specifies that a following b, d, i, o, u, x, or X, or n conversion specifier applies to an
 | |
|                  argument which is a pointer to an integer with a specific width where N is a positive
 | |
|                  decimal integer with no leading zeros. All minimum-width integer types (<a href='#7.22.1.2'>7.22.1.2</a>) and
 | |
|                  exact-width integer types (<a href='#7.22.1.1'>7.22.1.1</a>) defined in the header <stdint.h> shall be supported.
 | |
|                  Other supported values of N are implementation-defined.
 | |
| 
 | |
|      wfN        Specifies that a following b, d, i, o, u, x, or X, or n conversion specifier applies to an
 | |
|                 argument which is a pointer to a fastest minimum-width integer with a specific width
 | |
|                 where N is a positive decimal integer with no leading zeros. All fastest minimum-width
 | |
|                 integer types (<a href='#7.22.1.3'>7.22.1.3</a>) defined in the header <stdint.h> shall be supported. Other
 | |
|                 supported values of N are implementation-defined.
 | |
| 
 | |
|      L          Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to long double.
 | |
| 
 | |
|      H          Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to _Decimal32 .
 | |
| 
 | |
|      D          Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to _Decimal64 .
 | |
| 
 | |
|      DD         Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to _Decimal128 .
 | |
| 
 | |
|      If a length modifier appears with any conversion specifier other than as specified above, the behavior
 | |
|      is undefined.
 | |
| </pre>
 | |
| <a name='7.23.6.2p12'></a>
 | |
| <pre>12   In the following, the type of the corresponding argument for a conversion specifier shall be a pointer
 | |
|      to a type determined by the length modifiers, if any, or specified by the conversion specifier. The
 | |
|      conversion specifiers and their meanings are:
 | |
| 
 | |
|      d         Matches an optionally signed decimal integer, whose format is the same as expected for
 | |
|                the subject sequence of the strtol function with the value 10 for the base argument.
 | |
|                Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|                int.
 | |
| 
 | |
|      b         Matches an optionally signed binary integer, whose format is the same as expected for the
 | |
|                subject sequence of the strtol function with the value 2 for the base argument. Unless a
 | |
|                length modifier is specified, the corresponding argument shall be a pointer to unsigned
 | |
|                int.
 | |
| 
 | |
|      i         Matches an optionally signed integer, whose format is the same as expected for the subject
 | |
|                sequence of the strtol function with the value 0 for the base argument. Unless a length
 | |
|                modifier is specified, the corresponding argument shall be a pointer to int.
 | |
| o            Matches an optionally signed octal integer, whose format is the same as expected for
 | |
|              the subject sequence of the strtoul function with the value 8 for the base argument.
 | |
|              Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|              unsigned int.
 | |
| 
 | |
| u            Matches an optionally signed decimal integer, whose format is the same as expected for
 | |
|              the subject sequence of the strtoul function with the value 10 for the base argument.
 | |
|              Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|              unsigned int.
 | |
| 
 | |
| x            Matches an optionally signed hexadecimal integer, whose format is the same as expected
 | |
|              for the subject sequence of the strtoul function with the value 16 for the base argument.
 | |
|              Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|              unsigned int.
 | |
| 
 | |
| a,e,f,g Matches an optionally signed floating-point number, infinity, or NaN, whose format is
 | |
|         the same as expected for the subject sequence of the strtod function. Unless a length
 | |
|         modifier is specified, the corresponding argument shall be a pointer to float.
 | |
| 
 | |
| c            Matches a sequence of characters of exactly the number specified by the field width (1 if
 | |
|              no field width is present in the directive).<a href='#FOOTNOTE.349'><sup>[349]</sup></a>
 | |
| 
 | |
|              If no l length modifier is present, the corresponding argument shall be a pointer to char,
 | |
|              signed char, unsigned char, or void that points to storage large enough to accept the
 | |
|              sequence. No null character is added.
 | |
|              If an l length modifier is present, the input shall be a sequence of multibyte characters that
 | |
|              begins in the initial shift state. Each multibyte character in the sequence is converted to a
 | |
|              wide character as if by a call to the mbrtowc function, with the conversion state described
 | |
|              by an mbstate_t object initialized to zero before the first multibyte character is converted.
 | |
|              The corresponding argument shall be a pointer to storage of wchar_t large enough to
 | |
|              accept the resulting sequence of wide characters.No null wide character is added.
 | |
| 
 | |
| s            Matches a sequence of non-white-space characters.<a href='#FOOTNOTE.349'><sup>[349]</sup></a>
 | |
|              If no l length modifier is present, the corresponding argument shall be a pointer to char,
 | |
|              signed char, unsigned char, or void that points to storage large enough to accept the
 | |
|              sequence and a terminating null character, which will be added automatically.
 | |
|              If an l length modifier is present, the input shall be a sequence of multibyte characters
 | |
|              that begins in the initial shift state. Each multibyte character is converted to a wide
 | |
|              character as if by a call to the mbrtowc function, with the conversion state described by an
 | |
|              mbstate_t object initialized to zero before the first multibyte character is converted. The
 | |
|              corresponding argument shall be a pointer to storage of wchar_t large enough to accept
 | |
|              the sequence and the terminating null wide character, which will be added automatically.
 | |
| 
 | |
| [            Matches a nonempty sequence of characters from a set of expected characters (the
 | |
|              scanset).<a href='#FOOTNOTE.349'><sup>[349]</sup></a>
 | |
|              If no l length modifier is present, the corresponding argument shall be a pointer to char,
 | |
|              signed char, unsigned char, or void that points to storage large enough to accept the
 | |
|              sequence and a terminating null character, which will be added automatically.
 | |
|              If an l length modifier is present, the input shall be a sequence of multibyte characters
 | |
|              that begins in the initial shift state. Each multibyte character is converted to a wide
 | |
|              character as if by a call to the mbrtowc function, with the conversion state described by
 | |
|              an mbstate_t object initialized to zero before the first multibyte character is converted.
 | |
|              The corresponding argument shall be a pointer that points to storage of wchar_t large
 | |
|  <a href='#FOOTNOTE.349'><sup>[349]</sup></a> No special provisions are made for multibyte characters in the matching rules used by the c, s, and [ conversion specifiers
 | |
| 
 | |
| — the extent of the input field is determined on a byte-by-byte basis. The resulting field is nevertheless a sequence of multibyte
 | |
| characters that begins in the initial shift state.
 | |
|                  enough to accept the sequence and the terminating null wide character, which will be
 | |
|                  added automatically.
 | |
|                  The conversion specifier includes all subsequent characters in the format string, up to
 | |
|                  and including the matching right bracket (]). The characters between the brackets (the
 | |
|                  scanlist) compose the scanset, unless the character after the left bracket is a circumflex (^),
 | |
|                  in which case the scanset contains all characters that do not appear in the scanlist between
 | |
|                  the circumflex and the right bracket. If the conversion specifier begins with [] or [^], the
 | |
|                  right bracket character is in the scanlist and the next following right bracket character is
 | |
|                  the matching right bracket that ends the specification; otherwise the first following right
 | |
|                  bracket character is the one that ends the specification. If a - character is in the scanlist
 | |
|                  and is not the first, nor the second where the first character is a ^, nor the last character,
 | |
|                  the behavior is implementation-defined.
 | |
|      p           Matches an implementation-defined set of sequences, which should be the same as the
 | |
|                  set of sequences that may be produced by the %p conversion of the fprintf function.
 | |
|                  The corresponding argument shall be a pointer to a pointer of void. The input item is
 | |
|                  converted to a pointer value in an implementation-defined manner. If the input item is a
 | |
|                  value converted earlier during the same program execution, the pointer that results shall
 | |
|                  compare equal to that value; otherwise the behavior of the %p conversion is undefined.
 | |
|      n           No input is consumed. The corresponding argument shall be a pointer of a signed integer
 | |
|                  type. The number of characters read from the input stream so far by this call to the fscanf
 | |
|                  function is stored into the integer object pointed to by the argument. Execution of a %n
 | |
|                  directive does not increment the assignment count returned at the completion of execution
 | |
|                  of the fscanf function. No argument is converted, but one is consumed. If the conversion
 | |
|                  specification includes an assignment-suppressing character or a field width, the behavior
 | |
|                  is undefined.
 | |
|      %           Matches a single % character; no conversion or assignment occurs. The complete conversion
 | |
|                  specification shall be %%.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.349'>
 | |
| <pre><i><b>Footnote 349)</b> No special provisions are made for multibyte characters in the matching rules used by the c, s, and [ conversion specifiers
 | |
| — the extent of the input field is determined on a byte-by-byte basis. The resulting field is nevertheless a sequence of multibyte
 | |
| characters that begins in the initial shift state.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.349'>
 | |
| <pre><i><b>Footnote 349)</b> No special provisions are made for multibyte characters in the matching rules used by the c, s, and [ conversion specifiers
 | |
| — the extent of the input field is determined on a byte-by-byte basis. The resulting field is nevertheless a sequence of multibyte
 | |
| characters that begins in the initial shift state.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.349'>
 | |
| <pre><i><b>Footnote 349)</b> No special provisions are made for multibyte characters in the matching rules used by the c, s, and [ conversion specifiers
 | |
| — the extent of the input field is determined on a byte-by-byte basis. The resulting field is nevertheless a sequence of multibyte
 | |
| characters that begins in the initial shift state.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.349'>
 | |
| <pre><i><b>Footnote 349)</b> No special provisions are made for multibyte characters in the matching rules used by the c, s, and [ conversion specifiers
 | |
| — the extent of the input field is determined on a byte-by-byte basis. The resulting field is nevertheless a sequence of multibyte
 | |
| characters that begins in the initial shift state.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.2p13'></a>
 | |
| <pre>13   If a conversion specification is invalid, the behavior is undefined.<a href='#FOOTNOTE.350'><sup>[350]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.350'>
 | |
| <pre><i><b>Footnote 350)</b> See "future library directions" (<a href='#7.33.15'>7.33.15</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.2p14'></a>
 | |
| <pre>14   The conversion specifiers A, E, F, G, and X are also valid and behave the same as, respectively, a, e, f,
 | |
|      g, and x.
 | |
| </pre>
 | |
| <a name='7.23.6.2p15'></a>
 | |
| <pre>15   Trailing white-space characters(including new-line characters) are left unread unless matched by a
 | |
|      directive. The success of literal matches and suppressed assignments is not directly determinable
 | |
|      other than via the %n directive.
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='7.23.6.2p16'></a>
 | |
| <pre>16   The fscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|      conversion (if any) has completed. Otherwise, the function returns the number of input items
 | |
|      assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|      failure or if the implementation does not support a specific width length modifier.
 | |
| </pre>
 | |
| <a name='7.23.6.2p17'></a>
 | |
| <pre>17   EXAMPLE 1 The call:
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                /* ... */
 | |
|                int n, i; float x; char name[50];
 | |
|                n = fscanf(stdin, "%d%f%s", &i, &x, name);
 | |
| 
 | |
|      with the input line:
 | |
| 
 | |
|               25 54.32E-1 thompson
 | |
| 
 | |
| 
 | |
|      will assign to n the value 3, to i the value 25, to x the value 5.432, and to name the sequence thompson\0.
 | |
| </pre>
 | |
| <a name='7.23.6.2p18'></a>
 | |
| <pre>18   EXAMPLE 2 The call:
 | |
|                #include <stdio.h>
 | |
|                /* ... */
 | |
|                int i; float x; char name[50];
 | |
|                fscanf(stdin, "%2d%f%*d %[0123456789]", &i, &x, name);
 | |
| 
 | |
|      with input:
 | |
| 
 | |
|               56789 0123 56a72
 | |
| 
 | |
| 
 | |
|      will assign to i the value 56 and to x the value 789.0, will skip 0123, and will assign to name the sequence 56\0. The next
 | |
|      character read from the input stream will be a.
 | |
| </pre>
 | |
| <a name='7.23.6.2p19'></a>
 | |
| <pre>19   EXAMPLE 3 To accept repeatedly from stdin a quantity, a unit of measure, and an item name:
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                /* ... */
 | |
|                int count; float quant; char units[21], item[21];
 | |
|                do {
 | |
|                      count = fscanf(stdin, "%f%20s of %20s", &quant, units, item);
 | |
|                      fscanf(stdin,"%*[^\n]");
 | |
|                } while (!feof(stdin) && !ferror(stdin));
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.2p20'></a>
 | |
| <pre>20   If the stdin stream contains the following lines:
 | |
| 
 | |
|               2 quarts of oil
 | |
|               -12.8degrees Celsius
 | |
|               lots of luck
 | |
|               10.0LBS     of
 | |
|               dirt
 | |
|               100ergs of energy
 | |
| 
 | |
| 
 | |
|      the execution of the above example will be analogous to the following assignments:
 | |
| 
 | |
|                quant = 2; strcpy(units, "quarts"); strcpy(item, "oil");
 | |
|                count = 3;
 | |
|                quant = -12.8; strcpy(units, "degrees");
 | |
|                count = 2; // "C" fails to match "o"
 | |
|                count = 0; // "l" fails to match "%f"
 | |
|                quant = 10.0; strcpy(units, "LBS"); strcpy(item, "dirt");
 | |
|                count = 3;
 | |
|                count = 0; // "100e" fails to match "%f"
 | |
|                count = EOF;
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.2p21'></a>
 | |
| <pre>21   EXAMPLE 4 In:
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                /* ... */
 | |
|                int d1, d2, n1, n2, i;
 | |
|                i = sscanf("123", "%d%n%n%d", &d1, &n1, &n2, &d2);
 | |
| 
 | |
|      the value 123 is assigned to d1 and the value 3 to n1. Because %n can never get an input failure, the value of 3 is also assigned
 | |
|      to n2. The value of d2 is not affected. The value 1 is assigned to i.
 | |
| </pre>
 | |
| <a name='7.23.6.2p22'></a>
 | |
| <pre>22   EXAMPLE 5 The call:
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                /* ... */
 | |
|                int n, i;
 | |
|                n = sscanf("foo %bar              42", "foo%%bar%d", &i);
 | |
| 
 | |
|      will assign to n the value 1 and to i the value 42 because input white-space characters are skipped for both the % and d
 | |
|      conversion specifiers.
 | |
| </pre>
 | |
| <a name='7.23.6.2p23'></a>
 | |
| <pre>23   EXAMPLE 6 In these examples, multibyte characters do have a state-dependent encoding, and the members of the extended
 | |
|      character set that consist of more than one byte each consist of exactly two bytes, the first of which is denoted here by a □
 | |
|          and the second by an uppercase letter, but are only recognized as such when in the alternate shift state. The shift sequences
 | |
|          are denoted by ↑ and ↓, in which the first causes entry into the alternate shift state.
 | |
| </pre>
 | |
| <a name='7.23.6.2p24'></a>
 | |
| <pre>24   After the call:
 | |
| 
 | |
|                 #include <stdio.h>
 | |
|                 /* ... */
 | |
|                 char str[50];
 | |
|                 fscanf(stdin, "a%s", str);
 | |
| 
 | |
| 
 | |
|      with the input line:
 | |
| 
 | |
|                a↑□X□Y↓ bc
 | |
| 
 | |
| 
 | |
| 
 | |
|      str will contain ↑□X□Y↓\\0 assuming that none of the bytes of the shift sequences (or of the multibyte characters, in the
 | |
|      more general case) appears to be a single-byte white-space character.
 | |
| </pre>
 | |
| <a name='7.23.6.2p25'></a>
 | |
| <pre>25   In contrast, after the call:
 | |
| 
 | |
|                 #include <stdio.h>
 | |
|                 #include <stddef.h>
 | |
|                 /* ... */
 | |
|                 wchar_t wstr[50];
 | |
|                 fscanf(stdin, "a%ls", wstr);
 | |
| 
 | |
| 
 | |
|      with the same input line, wstr will contain the two wide characters that correspond to □X and □Y and a terminating null
 | |
|      wide character.
 | |
| </pre>
 | |
| <a name='7.23.6.2p26'></a>
 | |
| <pre>26   However, the call:
 | |
| 
 | |
|                 #include <stdio.h>
 | |
|                 #include <stddef.h>
 | |
|                 /* ... */
 | |
|                 wchar_t wstr[50];
 | |
|                 fscanf(stdin, "a↑□X↓%ls", wstr);
 | |
| 
 | |
| 
 | |
|      with the same input line will return zero due to a matching failure against the ↓ sequence in the format string.
 | |
| </pre>
 | |
| <a name='7.23.6.2p27'></a>
 | |
| <pre>27 Assuming that the first byte of the multibyte character □X is the same as the first byte of the multibyte character □Y, after the
 | |
|    call:
 | |
| 
 | |
|                 #include <stdio.h>
 | |
|                 #include <stddef.h>
 | |
|                 /* ... */
 | |
|                 wchar_t wstr[50];
 | |
|                 fscanf(stdin, "a↑□Y↓%ls", wstr);
 | |
| 
 | |
| 
 | |
|      with the same input line, zero will again be returned, but stdin will be left with a partially consumed multibyte character.
 | |
| 
 | |
|      Forward references: the strtod, strtof, and strtold functions (<a href='#7.24.1.5'>7.24.1.5</a>), the strtol, strtoll,
 | |
|      strtoul, and strtoull functions (<a href='#7.24.1.7'>7.24.1.7</a>), conversion state (<a href='#7.31.6'>7.31.6</a>), the wcrtomb function
 | |
|      (<a href='#7.31.6.3.3'>7.31.6.3.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.3 [The printf function]</h3>
 | |
| <a name='7.23.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|                    #include <stdio.h>
 | |
|                     int printf(const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
| 
 | |
|          Description
 | |
| </pre>
 | |
| <a name='7.23.6.3p2'></a>
 | |
| <pre>2        The printf function is equivalent to fprintf with the argument stdout interposed before the
 | |
|          arguments to printf.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.6.3p3'></a>
 | |
| <pre>3   The printf function returns the number of characters transmitted, or a negative value if an output
 | |
|     or encoding error occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.4 [The scanf function]</h3>
 | |
| <a name='7.23.6.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                int scanf(const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.4p2'></a>
 | |
| <pre>2   The scanf function is equivalent to fscanf with the argument stdin interposed before the argu-
 | |
|     ments to scanf.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.6.4p3'></a>
 | |
| <pre>3   The scanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the scanf function returns the number of input items
 | |
|     assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.5'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.5 [The snprintf function]</h3>
 | |
| <a name='7.23.6.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                int snprintf(char * restrict s, size_t n, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.5p2'></a>
 | |
| <pre>2   The snprintf function is equivalent to fprintf, except that the output is written into an array
 | |
|     (specified by argument s) rather than to a stream. If n is zero, nothing is written, and s may be a
 | |
|     null pointer. Otherwise, output characters beyond the n-1st are discarded rather than being written
 | |
|     to the array, and a null character is written at the end of the characters actually written into the array.
 | |
|     If copying takes place between objects that overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.6.5p3'></a>
 | |
| <pre>3   The snprintf function returns the number of characters that would have been written had n been
 | |
|     sufficiently large, not counting the terminating null character, or a negative value if an encoding
 | |
|     error occurred. Thus, the null-terminated output has been completely written if and only if the
 | |
|     returned value is both nonnegative and less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.6'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.6 [The sprintf function]</h3>
 | |
| <a name='7.23.6.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                int sprintf(char * restrict s, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.6p2'></a>
 | |
| <pre>2   The sprintf function is equivalent to fprintf, except that the output is written into an array
 | |
|     (specified by the argument s) rather than to a stream. A null character is written at the end of the
 | |
|     characters written; it is not counted as part of the returned value. If copying takes place between
 | |
|     objects that overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.6.6p3'></a>
 | |
| <pre>3   The sprintf function returns the number of characters written in the array, not counting the
 | |
|     terminating null character, or a negative value if an encoding error occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.7'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.7 [The sscanf function]</h3>
 | |
| <a name='7.23.6.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int sscanf(const char * restrict s, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.7p2'></a>
 | |
| <pre>2   The sscanf function is equivalent to fscanf, except that input is obtained from a string (specified
 | |
|     by the argument s) rather than from a stream. Reaching the end of the string is equivalent to
 | |
|     encountering end-of-file for the fscanf function. If copying takes place between objects that overlap,
 | |
|     the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.6.7p3'></a>
 | |
| <pre>3   The sscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the sscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.8'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.8 [The vfprintf function]</h3>
 | |
| <a name='7.23.6.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vfprintf(FILE * restrict stream, const char * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.8p2'></a>
 | |
| <pre>2   The vfprintf function is equivalent to fprintf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vfprintf function does not invoke the va_end macro<a href='#FOOTNOTE.351'><sup>[351]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.351'>
 | |
| <pre><i><b>Footnote 351)</b> As the functions vfprintf , vfscanf , vprintf , vscanf , vsnprintf , vsprintf , and vsscanf invoke the va_arg macro,
 | |
|     arg after the return has an indeterminate representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.8p3'></a>
 | |
| <pre>3   The vfprintf function returns the number of characters transmitted, or a negative value if an
 | |
|     output or encoding error occurred.
 | |
| </pre>
 | |
| <a name='7.23.6.8p4'></a>
 | |
| <pre>4   EXAMPLE The following shows the use of the vfprintf function in a general error-reporting routine.
 | |
| 
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
| 
 | |
|               void error(char *function_name, char *format, ...)
 | |
|               {
 | |
|                     va_list args;
 | |
| 
 | |
|                       va_start(args, format);
 | |
|                       // print out name of function causing error
 | |
|                       fprintf(stderr, "ERROR in %s: ", function_name);
 | |
|                       // print out remainder of message
 | |
|                       vfprintf(stderr, format, args);
 | |
|                       va_end(args);
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.9'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.9 [The vfscanf function]</h3>
 | |
| <a name='7.23.6.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vfscanf(FILE * restrict stream, const char * restrict format, va_list arg);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.9p2'></a>
 | |
| <pre>2   The vfscanf function is equivalent to fscanf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vfscanf function does not invoke the va_end macro.<a href='#FOOTNOTE.351'><sup>[351]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.351'>
 | |
| <pre><i><b>Footnote 351)</b> As the functions vfprintf , vfscanf , vprintf , vscanf , vsnprintf , vsprintf , and vsscanf invoke the va_arg macro,
 | |
|     arg after the return has an indeterminate representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.9p3'></a>
 | |
| <pre>3   The vfscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the vfscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.10'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.10 [The vprintf function]</h3>
 | |
| <a name='7.23.6.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdarg.h>
 | |
|             #include <stdio.h>
 | |
|             int vprintf(const char * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.10p2'></a>
 | |
| <pre>2   The vprintf function is equivalent to printf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vprintf function does not invoke the va_end macro.<a href='#FOOTNOTE.351'><sup>[351]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.351'>
 | |
| <pre><i><b>Footnote 351)</b> As the functions vfprintf , vfscanf , vprintf , vscanf , vsnprintf , vsprintf , and vsscanf invoke the va_arg macro,
 | |
|     arg after the return has an indeterminate representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.10p3'></a>
 | |
| <pre>3   The vprintf function returns the number of characters transmitted, or a negative value if an output
 | |
|     or encoding error occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.11'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.11 [The vscanf function]</h3>
 | |
| <a name='7.23.6.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdarg.h>
 | |
|             #include <stdio.h>
 | |
|             int vscanf(const char * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.11p2'></a>
 | |
| <pre>2   The vscanf function is equivalent to scanf, with the variable argument list replaced by arg, which
 | |
|     shall have been initialized by the va_start macro (and possibly subsequent va_arg calls). The
 | |
|     vscanf function does not invoke the va_end macro.<a href='#FOOTNOTE.351'><sup>[351]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.351'>
 | |
| <pre><i><b>Footnote 351)</b> As the functions vfprintf , vfscanf , vprintf , vscanf , vsnprintf , vsprintf , and vsscanf invoke the va_arg macro,
 | |
|     arg after the return has an indeterminate representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.11p3'></a>
 | |
| <pre>3   The vscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the vscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.12'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.12 [The vsnprintf function]</h3>
 | |
| <a name='7.23.6.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdarg.h>
 | |
|             #include <stdio.h>
 | |
|             int vsnprintf(char * restrict s, size_t n, const char * restrict format, va_list
 | |
|                 arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.12p2'></a>
 | |
| <pre>2   The vsnprintf function is equivalent to snprintf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vsnprintf function does not invoke the va_end macro.<a href='#FOOTNOTE.351'><sup>[351]</sup></a> If copying takes place between
 | |
|     objects that overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.351'>
 | |
| <pre><i><b>Footnote 351)</b> As the functions vfprintf , vfscanf , vprintf , vscanf , vsnprintf , vsprintf , and vsscanf invoke the va_arg macro,
 | |
|     arg after the return has an indeterminate representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.12p3'></a>
 | |
| <pre>3   The vsnprintf function returns the number of characters that would have been written had n been
 | |
|     sufficiently large, not counting the terminating null character, or a negative value if an encoding
 | |
|     error occurred. Thus, the null-terminated output has been completely written if and only if the
 | |
|     returned value is both nonnegative and less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.13'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.13 [The vsprintf function]</h3>
 | |
| <a name='7.23.6.13p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdarg.h>
 | |
|              #include <stdio.h>
 | |
|              int vsprintf(char * restrict s, const char * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.13p2'></a>
 | |
| <pre>2   The vsprintf function is equivalent to sprintf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vsprintf function does not invoke the va_end macro.<a href='#FOOTNOTE.351'><sup>[351]</sup></a> If copying takes place between objects
 | |
|     that overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.351'>
 | |
| <pre><i><b>Footnote 351)</b> As the functions vfprintf , vfscanf , vprintf , vscanf , vsnprintf , vsprintf , and vsscanf invoke the va_arg macro,
 | |
|     arg after the return has an indeterminate representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.13p3'></a>
 | |
| <pre>3   The vsprintf function returns the number of characters written in the array, not counting the
 | |
|     terminating null character, or a negative value if an encoding error occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.6.14'></a>
 | |
| <hr>
 | |
| <h3>7.23.6.14 [The vsscanf function]</h3>
 | |
| <a name='7.23.6.14p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdarg.h>
 | |
|              #include <stdio.h>
 | |
|              int vsscanf(const char * restrict s, const char * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.6.14p2'></a>
 | |
| <pre>2   The vsscanf function is equivalent to sscanf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vsscanf function does not invoke the va_end macro.<a href='#FOOTNOTE.351'><sup>[351]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.351'>
 | |
| <pre><i><b>Footnote 351)</b> As the functions vfprintf , vfscanf , vprintf , vscanf , vsnprintf , vsprintf , and vsscanf invoke the va_arg macro,
 | |
|     arg after the return has an indeterminate representation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.6.14p3'></a>
 | |
| <pre>3   The vsscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the vsscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7'></a>
 | |
| <hr>
 | |
| <h3>7.23.7 [Character input/output functions]</h3>
 | |
| <a name='7.23.7.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.1 [The fgetc function]</h3>
 | |
| <a name='7.23.7.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdio.h>
 | |
|              int fgetc(FILE *stream);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.1p2'></a>
 | |
| <pre>2   If the end-of-file indicator for the input stream pointed to by stream is not set and a next character
 | |
|     is present, the fgetc function obtains that character as an unsigned char converted to an int and
 | |
|     advances the associated file position indicator for the stream (if defined).
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.1p3'></a>
 | |
| <pre>3   If the end-of-file indicator for the stream is set, or if the stream is at end-of-file, the end-of-file
 | |
|     indicator for the stream is set and the fgetc function returns EOF. Otherwise, the fgetc function
 | |
|     returns the next character from the input stream pointed to by stream. If a read error occurs, the
 | |
|     error indicator for the stream is set and the fgetc function returns EOF.<a href='#FOOTNOTE.352'><sup>[352]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.352'>
 | |
| <pre><i><b>Footnote 352)</b> An end-of-file and a read error can be distinguished by use of the feof and ferror functions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.7.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.2 [The fgets function]</h3>
 | |
| <a name='7.23.7.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                char *fgets(char * restrict s, int n, FILE * restrict stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.2p2'></a>
 | |
| <pre>2   The fgets function reads at most one less than the number of characters specified by n from the
 | |
|     stream pointed to by stream into the array pointed to by s. No additional characters are read after a
 | |
|     new-line character (which is retained) or after end-of-file. A null character is written immediately
 | |
|     after the last character read into the array.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.2p3'></a>
 | |
| <pre>3   The fgets function returns s if successful. If end-of-file is encountered and no characters have been
 | |
|     read into the array, the contents of the array remain unchanged and a null pointer is returned. If a
 | |
|     read error occurs during the operation, the members of the array have unspecified values and a null
 | |
|     pointer is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7.3'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.3 [The fputc function]</h3>
 | |
| <a name='7.23.7.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                int fputc(int c, FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.3p2'></a>
 | |
| <pre>2   The fputc function writes the character specified by c (converted to an unsigned char) to the
 | |
|     output stream pointed to by stream, at the position indicated by the associated file position indicator
 | |
|     for the stream (if defined), and advances the indicator appropriately. If the file cannot support
 | |
|     positioning requests, or if the stream was opened with append mode, the character is appended to
 | |
|     the output stream.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.3p3'></a>
 | |
| <pre>3   The fputc function returns the character written. If a write error occurs, the error indicator for the
 | |
|     stream is set and fputc returns EOF.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7.4'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.4 [The fputs function]</h3>
 | |
| <a name='7.23.7.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                int fputs(const char * restrict s, FILE * restrict stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.4p2'></a>
 | |
| <pre>2   The fputs function writes the string pointed to by s to the stream pointed to by stream. The
 | |
|     terminating null character is not written.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.4p3'></a>
 | |
| <pre>3   The fputs function returns EOF if a write error occurs; otherwise it returns a nonnegative value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7.5'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.5 [The getc function]</h3>
 | |
| <a name='7.23.7.5p1'></a>
 | |
| <pre>1     Synopsis
 | |
|            #include <stdio.h>
 | |
|             int getc(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.5p2'></a>
 | |
| <pre>2   The getc function is equivalent to fgetc, except that if it is implemented as a macro, it may evaluate
 | |
|     stream more than once, so the argument should never be an expression with side effects.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.5p3'></a>
 | |
| <pre>3   The getc function returns the next character from the input stream pointed to by stream. If the
 | |
|     stream is at end-of-file, the end-of-file indicator for the stream is set and getc returns EOF. If a read
 | |
|     error occurs, the error indicator for the stream is set and getc returns EOF.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7.6'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.6 [The getchar function]</h3>
 | |
| <a name='7.23.7.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             int getchar(void);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.6p2'></a>
 | |
| <pre>2   The getchar function is equivalent to getc with the argument stdin.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.6p3'></a>
 | |
| <pre>3   The getchar function returns the next character from the input stream pointed to by stdin. If the
 | |
|     stream is at end-of-file, the end-of-file indicator for the stream is set and getchar returns EOF. If a
 | |
|     read error occurs, the error indicator for the stream is set and getchar returns EOF.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7.7'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.7 [The putc function]</h3>
 | |
| <a name='7.23.7.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             int putc(int c, FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.7p2'></a>
 | |
| <pre>2   The putc function is equivalent to fputc, except that if it is implemented as a macro, it may evaluate
 | |
|     stream more than once, so that argument should never be an expression with side effects.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.7p3'></a>
 | |
| <pre>3   The putc function returns the character written. If a write error occurs, the error indicator for the
 | |
|     stream is set and putc returns EOF.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7.8'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.8 [The putchar function]</h3>
 | |
| <a name='7.23.7.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             int putchar(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.8p2'></a>
 | |
| <pre>2   The putchar function is equivalent to putc with the second argument stdout.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.8p3'></a>
 | |
| <pre>3   The putchar function returns the character written. If a write error occurs, the error indicator for
 | |
|     the stream is set and putchar returns EOF.
 | |
| </pre>
 | |
| <a name='7.23.7.9'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.9 [The puts function]</h3>
 | |
| <a name='7.23.7.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int puts(const char *s);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.9p2'></a>
 | |
| <pre>2   The puts function writes the string pointed to by s to the stream pointed to by stdout, and appends
 | |
|     a new-line character to the output. The terminating null character is not written.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.7.9p3'></a>
 | |
| <pre>3   The puts function returns EOF if a write error occurs; otherwise it returns a nonnegative value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.7.10'></a>
 | |
| <hr>
 | |
| <h3>7.23.7.10 [The ungetc function]</h3>
 | |
| <a name='7.23.7.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int ungetc(int c, FILE *stream);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.7.10p2'></a>
 | |
| <pre>2   The ungetc function pushes the character specified by c (converted to an unsigned char) back
 | |
|     onto the input stream pointed to by stream. Pushed-back characters will be returned by subsequent
 | |
|     reads on that stream in the reverse order of their pushing. A successful intervening call (with the
 | |
|     stream pointed to by stream) to a file positioning function (fseek, fsetpos, or rewind) discards
 | |
|     any pushed-back characters for the stream. The external storage corresponding to the stream is
 | |
|     unchanged.
 | |
| </pre>
 | |
| <a name='7.23.7.10p3'></a>
 | |
| <pre>3   One character of pushback is guaranteed. If the ungetc function is called too many times on the
 | |
|     same stream without an intervening read or file positioning operation on that stream, the operation
 | |
|     may fail.
 | |
| </pre>
 | |
| <a name='7.23.7.10p4'></a>
 | |
| <pre>4   If the value of c equals that of the macro EOF, the operation fails and the input stream is unchanged.
 | |
| </pre>
 | |
| <a name='7.23.7.10p5'></a>
 | |
| <pre>5   A successful call to the ungetc function clears the end-of-file indicator for the stream. The value
 | |
|     of the file position indicator for the stream after reading or discarding all pushed-back characters
 | |
|     shall be the same as it was before the characters were pushed back.<a href='#FOOTNOTE.353'><sup>[353]</sup></a> For a text stream, the value
 | |
|     of its file position indicator after a successful call to the ungetc function is unspecified until all
 | |
|     pushed-back characters are read or discarded. For a binary stream, its file position indicator is
 | |
|     decremented by each successful call to the ungetc function; if its value was zero before a call, it has
 | |
|     an indeterminate representation after the call<a href='#FOOTNOTE.354'><sup>[354]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.353'>
 | |
| <pre><i><b>Footnote 353)</b> Note that a file positioning function could further modify the file position indicator after discarding any pushed-back
 | |
|     characters.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.354'>
 | |
| <pre><i><b>Footnote 354)</b> See "future library directions" (<a href='#7.33.15'>7.33.15</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.23.7.10p6'></a>
 | |
| <pre>6   The ungetc function returns the character pushed back after conversion, or EOF if the operation
 | |
|     fails.
 | |
|     Forward references: file positioning functions (<a href='#7.23.9'>7.23.9</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.8'></a>
 | |
| <hr>
 | |
| <h3>7.23.8 [Direct input/output functions]</h3>
 | |
| <a name='7.23.8.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.8.1 [The fread function]</h3>
 | |
| <a name='7.23.8.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               size_t fread(void * restrict ptr, size_t size, size_t nmemb,
 | |
|                     FILE * restrict stream);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.8.1p2'></a>
 | |
| <pre>2   The fread function reads, into the array pointed to by ptr, up to nmemb elements whose size is
 | |
|     specified by size, from the stream pointed to by stream. For each object, size calls are made to
 | |
|     the fgetc function and the results stored, in the order read, in an array of unsigned char exactly
 | |
|     overlaying the object. The file position indicator for the stream (if defined) is advanced by the
 | |
|     number of characters successfully read. If an error occurs, the resulting representation of the file
 | |
|     position indicator for the stream is indeterminate. If a partial element is read, its representation is
 | |
|     indeterminate.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.8.1p3'></a>
 | |
| <pre>3   The fread function returns the number of elements successfully read, which may be less than nmemb
 | |
|     if a read error or end-of-file is encountered. If size or nmemb is zero, fread returns zero and the
 | |
|     contents of the array and the state of the stream remain unchanged.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.8.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.8.2 [The fwrite function]</h3>
 | |
| <a name='7.23.8.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdio.h>
 | |
|              size_t fwrite(const void * restrict ptr, size_t size, size_t nmemb,
 | |
|                    FILE * restrict stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.8.2p2'></a>
 | |
| <pre>2   The fwrite function writes, from the array pointed to by ptr, up to nmemb elements whose size is
 | |
|     specified by size, to the stream pointed to by stream. For each object, size calls are made to the
 | |
|     fputc function, taking the values (in order) from an array of unsigned char exactly overlaying the
 | |
|     object. The file position indicator for the stream (if defined) is advanced by the number of characters
 | |
|     successfully written. If an error occurs, the resulting representation of the file position indicator for
 | |
|     the stream is indeterminate.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.8.2p3'></a>
 | |
| <pre>3   The fwrite function returns the number of elements successfully written, which will be less than
 | |
|     nmemb only if a write error is encountered. If size or nmemb is zero, fwrite returns zero and the
 | |
|     state of the stream remains unchanged.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.9'></a>
 | |
| <hr>
 | |
| <h3>7.23.9 [File positioning functions]</h3>
 | |
| <a name='7.23.9.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.9.1 [The fgetpos function]</h3>
 | |
| <a name='7.23.9.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdio.h>
 | |
|              int fgetpos(FILE * restrict stream, fpos_t * restrict pos);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.9.1p2'></a>
 | |
| <pre>2   The fgetpos function stores the current values of the parse state (if any) and file position indicator
 | |
|     for the stream pointed to by stream in the object pointed to by pos. The values stored contain
 | |
|     unspecified information usable by the fsetpos function for repositioning the stream to its position
 | |
|     at the time of the call to the fgetpos function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.9.1p3'></a>
 | |
| <pre>3   If successful, the fgetpos function returns zero; on failure, the fgetpos function returns nonzero
 | |
|     and stores an implementation-defined positive value in errno.
 | |
|     Forward references: the fsetpos function (<a href='#7.23.9.3'>7.23.9.3</a>).
 | |
| </pre>
 | |
| <a name='7.23.9.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.9.2 [The fseek function]</h3>
 | |
| <a name='7.23.9.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             int fseek(FILE *stream, long int offset, int whence);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.9.2p2'></a>
 | |
| <pre>2   The fseek function sets the file position indicator for the stream pointed to by stream. If a read or
 | |
|     write error occurs, the error indicator for the stream is set and fseek fails.
 | |
| </pre>
 | |
| <a name='7.23.9.2p3'></a>
 | |
| <pre>3   For a binary stream, the new position, measured in characters from the beginning of the file, is
 | |
|     obtained by adding offset to the position specified by whence. The specified position is the
 | |
|     beginning of the file if whence is SEEK_SET, the current value of the file position indicator if
 | |
|     SEEK_CUR, or end-of-file if SEEK_END. A binary stream need not meaningfully support fseek calls
 | |
|     with a whence value of SEEK_END.
 | |
| </pre>
 | |
| <a name='7.23.9.2p4'></a>
 | |
| <pre>4   For a text stream, either offset shall be zero, or offset shall be a value returned by an earlier
 | |
|     successful call to the ftell function on a stream associated with the same file and whence shall be
 | |
|     SEEK_SET.
 | |
| </pre>
 | |
| <a name='7.23.9.2p5'></a>
 | |
| <pre>5   After determining the new position, a successful call to the fseek function undoes any effects of the
 | |
|     ungetc function on the stream, clears the end-of-file indicator for the stream, and then establishes
 | |
|     the new position. After a successful fseek call, the next operation on an update stream may be
 | |
|     either input or output.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.9.2p6'></a>
 | |
| <pre>6   The fseek function returns nonzero only for a request that cannot be satisfied.
 | |
|     Forward references: the ftell function (<a href='#7.23.9.4'>7.23.9.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.9.3'></a>
 | |
| <hr>
 | |
| <h3>7.23.9.3 [The fsetpos function]</h3>
 | |
| <a name='7.23.9.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             int fsetpos(FILE *stream, const fpos_t *pos);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.9.3p2'></a>
 | |
| <pre>2   The fsetpos function sets the mbstate_t object (if any) and file position indicator for the stream
 | |
|     pointed to by stream according to the value of the object pointed to by pos, which shall be a value
 | |
|     obtained from an earlier successful call to the fgetpos function on a stream associated with the
 | |
|     same file. If a read or write error occurs, the error indicator for the stream is set and fsetpos fails.
 | |
| </pre>
 | |
| <a name='7.23.9.3p3'></a>
 | |
| <pre>3   A successful call to the fsetpos function undoes any effects of the ungetc function on the stream,
 | |
|     clears the end-of-file indicator for the stream, and then establishes the new parse state and position.
 | |
|     After a successful fsetpos call, the next operation on an update stream may be either input or
 | |
|     output.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.9.3p4'></a>
 | |
| <pre>4   If successful, the fsetpos function returns zero; on failure, the fsetpos function returns nonzero
 | |
|     and stores an implementation-defined positive value in errno.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.9.4'></a>
 | |
| <hr>
 | |
| <h3>7.23.9.4 [The ftell function]</h3>
 | |
| <a name='7.23.9.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             long int ftell(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.9.4p2'></a>
 | |
| <pre>2   The ftell function obtains the current value of the file position indicator for the stream pointed to
 | |
|     by stream. For a binary stream, the value is the number of characters from the beginning of the file.
 | |
|     For a text stream, its file position indicator contains unspecified information, usable by the fseek
 | |
|     function for returning the file position indicator for the stream to its position at the time of the ftell
 | |
|     call; the difference between two such return values is not necessarily a meaningful measure of the
 | |
|     number of characters written or read.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.9.4p3'></a>
 | |
| <pre>3   If successful, the ftell function returns the current value of the file position indicator for the stream.
 | |
|     On failure, the ftell function returns −1L and stores an implementation-defined positive value in
 | |
|     errno.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.9.5'></a>
 | |
| <hr>
 | |
| <h3>7.23.9.5 [The rewind function]</h3>
 | |
| <a name='7.23.9.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               void rewind(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.9.5p2'></a>
 | |
| <pre>2   The rewind function sets the file position indicator for the stream pointed to by stream to the
 | |
|     beginning of the file. It is equivalent to
 | |
| 
 | |
|               (void)fseek(stream, 0L, SEEK_SET)
 | |
| 
 | |
| 
 | |
|     except that the error indicator for the stream is also cleared.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.9.5p3'></a>
 | |
| <pre>3   The rewind function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.10'></a>
 | |
| <hr>
 | |
| <h3>7.23.10 [Error-handling functions]</h3>
 | |
| <a name='7.23.10.1'></a>
 | |
| <hr>
 | |
| <h3>7.23.10.1 [The clearerr function]</h3>
 | |
| <a name='7.23.10.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               void clearerr(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.10.1p2'></a>
 | |
| <pre>2   The clearerr function clears the end-of-file and error indicators for the stream pointed to by
 | |
|     stream.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.10.1p3'></a>
 | |
| <pre>3   The clearerr function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.10.2'></a>
 | |
| <hr>
 | |
| <h3>7.23.10.2 [The feof function]</h3>
 | |
| <a name='7.23.10.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               int feof(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.10.2p2'></a>
 | |
| <pre>2   The feof function tests the end-of-file indicator for the stream pointed to by stream.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.10.2p3'></a>
 | |
| <pre>3   The feof function returns nonzero if and only if the end-of-file indicator is set for stream.
 | |
| </pre>
 | |
| <a name='7.23.10.3'></a>
 | |
| <hr>
 | |
| <h3>7.23.10.3 [The ferror function]</h3>
 | |
| <a name='7.23.10.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             int ferror(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.10.3p2'></a>
 | |
| <pre>2   The ferror function tests the error indicator for the stream pointed to by stream.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.10.3p3'></a>
 | |
| <pre>3   The ferror function returns nonzero if and only if the error indicator is set for stream.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.23.10.4'></a>
 | |
| <hr>
 | |
| <h3>7.23.10.4 [The perror function]</h3>
 | |
| <a name='7.23.10.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdio.h>
 | |
|             void perror(const char *s);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.23.10.4p2'></a>
 | |
| <pre>2   The perror function maps the error number in the integer expression errno to an error message.
 | |
|     It writes a sequence of characters to the standard error stream thus: first (if s is not a null pointer
 | |
|     and the character pointed to by s is not the null character), the string pointed to by s followed by a
 | |
|     colon (:) and a space; then an appropriate error message string followed by a new-line character.
 | |
|     The contents of the error message strings are the same as those returned by the strerror function
 | |
|     with argument errno.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.23.10.4p3'></a>
 | |
| <pre>3   The perror function returns no value.
 | |
|     Forward references: the strerror function (<a href='#7.26.6.3'>7.26.6.3</a>).
 | |
| </pre>
 | |
| <a name='7.24'></a>
 | |
| <hr>
 | |
| <h3>7.24 [General utilities <stdlib.h>]</h3>
 | |
| <a name='7.24p1'></a>
 | |
| <pre>1   The header <stdlib.h> declares five types and several functions of general utility, and defines
 | |
|     several macros.<a href='#FOOTNOTE.355'><sup>[355]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.355'>
 | |
| <pre><i><b>Footnote 355)</b> See "future library directions" (<a href='#7.33.16'>7.33.16</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24p2'></a>
 | |
| <pre>2   The feature test macro __STDC_VERSION_STDLIB_H__ expands to the token 202311L.
 | |
| </pre>
 | |
| <a name='7.24p3'></a>
 | |
| <pre>3   The types declared are size_t and wchar_t (both described in <a href='#7.21'>7.21</a>), once_flag (described in <a href='#7.28'>7.28</a>),
 | |
| 
 | |
|               div_t
 | |
| 
 | |
| 
 | |
|     which is a structure type that is the type of the value returned by the div function,
 | |
| 
 | |
|               ldiv_t
 | |
| 
 | |
| 
 | |
|     which is a structure type that is the type of the value returned by the ldiv function, and
 | |
| 
 | |
|               lldiv_t
 | |
| 
 | |
| 
 | |
|     which is a structure type that is the type of the value returned by the lldiv function.
 | |
| </pre>
 | |
| <a name='7.24p4'></a>
 | |
| <pre>4   The macros defined are NULL (described in <a href='#7.21'>7.21</a>); ONCE_FLAG_INIT (described in <a href='#7.28'>7.28</a>);
 | |
| 
 | |
|               EXIT_FAILURE
 | |
| 
 | |
| 
 | |
|     and
 | |
| 
 | |
|               EXIT_SUCCESS
 | |
| 
 | |
| 
 | |
|     which expand to integer constant expressions that can be used as the argument to the exit function
 | |
|     to return unsuccessful or successful termination status, respectively, to the host environment;
 | |
| 
 | |
|               RAND_MAX
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the maximum value returned by the rand
 | |
|     function; and
 | |
| 
 | |
|               MB_CUR_MAX
 | |
| 
 | |
| 
 | |
|     which expands to a positive integer expression with type size_t that is the maximum number of
 | |
|     bytes in a multibyte character for the extended character set specified by the current locale (category
 | |
|     LC_CTYPE), which is never greater than MB_LEN_MAX.
 | |
| </pre>
 | |
| <a name='7.24p5'></a>
 | |
| <pre>5   The function
 | |
| 
 | |
|      #include <stdlib.h>
 | |
|      void call_once(once_flag *flag, void (*func)(void));
 | |
| 
 | |
| 
 | |
|     is described in <a href='#7.28.2'>7.28.2</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.1 [Numeric conversion functions]</h3>
 | |
| <a name='7.24.1p1'></a>
 | |
| <pre>1   The functions atof, atoi, atol, and atoll need not affect the value of the integer expression errno
 | |
|     on an error. If the value of the result cannot be represented, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.1.1 [The atof function]</h3>
 | |
| <a name='7.24.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               double atof(const char *nptr);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.1.1p2'></a>
 | |
| <pre>2   The atof function converts the initial portion of the string pointed to by nptr to double representa-
 | |
|     tion. Except for the behavior on error, it is equivalent to
 | |
| 
 | |
|             strtod(nptr, nullptr)
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.1.1p3'></a>
 | |
| <pre>3   The atof function returns the converted value.
 | |
|     Forward references: the strtod, strtof, and strtold functions (<a href='#7.24.1.5'>7.24.1.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.1.2 [The atoi, atol, and atoll functions]</h3>
 | |
| <a name='7.24.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdlib.h>
 | |
|             int atoi(const char *nptr);
 | |
|             long int atol(const char *nptr);
 | |
|             long long int atoll(const char *nptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.1.2p2'></a>
 | |
| <pre>2   The atoi, atol, and atoll functions convert the initial portion of the string pointed to by nptr to
 | |
|     int, long int, and long long int representation, respectively. Except for the behavior on error,
 | |
|     they are equivalent to
 | |
| 
 | |
|             atoi: (int)strtol(nptr, nullptr, 10)
 | |
|             atol: strtol(nptr, nullptr, 10)
 | |
|             atoll: strtoll(nptr, nullptr, 10)
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.1.2p3'></a>
 | |
| <pre>3   The atoi, atol, and atoll functions return the converted value.
 | |
|     Forward references: the strtol, strtoll, strtoul, and strtoull functions (<a href='#7.24.1.7'>7.24.1.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.24.1.3 [The strfromd, strfromf, and strfroml functions]</h3>
 | |
| <a name='7.24.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|     #include <stdlib.h>
 | |
|      int strfromd(char *restrict s, size_t n, const char *restrict format, double fp);
 | |
|      int strfromf(char *restrict s, size_t n, const char *restrict format, float fp);
 | |
|      int strfroml(char *restrict s, size_t n, const char *restrict format, long double fp);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.1.3p2'></a>
 | |
| <pre>2   The strfromd, strfromf, and strfroml functions are equivalent to snprintf(s, n, format, fp)
 | |
|     (<a href='#7.23.6.5'>7.23.6.5</a>), except that the format string shall only contain the character %, an optional precision that
 | |
|     does not contain an asterisk *, and one of the conversion specifiers a, A, e, E, f, F, g, or G, which
 | |
|     applies to the type (double, float, or long double) indicated by the function suffix (rather than by
 | |
|     a length modifier).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.1.3p3'></a>
 | |
| <pre>3   The strfromd, strfromf, and strfroml functions return the number of characters that would
 | |
|     have been written had n been sufficiently large, not counting the terminating null character. Thus,
 | |
|     the null-terminated output has been completely written if and only if the returned value is both
 | |
|     nonnegative and less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.24.1.4 [The strfromdN functions]</h3>
 | |
| <a name='7.24.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|     #include <stdlib.h>
 | |
|      #ifdef __STDC_IEC_60559_DFP__
 | |
|      int strfromd32(char*restrict s, size_t n, const char*restrict format, _Decimal32 fp);
 | |
|      int strfromd64(char*restrict s, size_t n, const char*restrict format, _Decimal64 fp);
 | |
|      int strfromd128(char*restrict s, size_t n, const char*restrict format, _Decimal128 fp);
 | |
|      #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.1.4p2'></a>
 | |
| <pre>2   The strfromdN functions are equivalent to snprintf(s, n, format, fp) (<a href='#7.23.6.5'>7.23.6.5</a>), except the
 | |
|     format string contains only the character %, an optional precision that does not contain an asterisk *,
 | |
|     and one of the conversion specifiers a, A, e, E, f, F, g, or G, which applies to the type (_Decimal32 ,
 | |
|     _Decimal64 , or _Decimal128 ) indicated by the function suffix (rather than by a length modifier).
 | |
|     Use of these functions with any other format string results in undefined behavior.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.1.4p3'></a>
 | |
| <pre>3   The strfromdN functions return the number of characters that would have been written had n been
 | |
|     sufficiently large, not counting the terminating null character. Thus, the null-terminated output has
 | |
|     been completely written if and only if the returned value is less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.1.5'></a>
 | |
| <hr>
 | |
| <h3>7.24.1.5 [The strtod, strtof, and strtold functions]</h3>
 | |
| <a name='7.24.1.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdlib.h>
 | |
|             double strtod(const char *restrict nptr, char **restrict endptr);
 | |
|             float strtof(const char *restrict nptr, char **restrict endptr);
 | |
|             long double strtold(const char *restrict nptr, char **restrict endptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.1.5p2'></a>
 | |
| <pre>2   The strtod, strtof, and strtold functions convert the initial portion of the string pointed to by
 | |
|     nptr to double, float, and long double representation, respectively. First, they decompose the
 | |
|     input string into three parts: an initial, possibly empty, sequence of white-space characters, a subject
 | |
|     sequence resembling a floating constant or representing an infinity or NaN; and a final string of one
 | |
|     or more unrecognized characters, including the terminating null character of the input string. Then,
 | |
|     they attempt to convert the subject sequence to a floating-point number, and return the result.
 | |
| </pre>
 | |
| <a name='7.24.1.5p3'></a>
 | |
| <pre>3   The expected form of the subject sequence is an optional plus or minus sign, then one of the
 | |
|     following:
 | |
| 
 | |
|       — a nonempty sequence of decimal digits optionally containing a decimal-point character, then
 | |
|         an optional exponent part as defined in <a href='#6.4.4.2'>6.4.4.2</a>, excluding any digit separators (<a href='#6.4.4.1'>6.4.4.1</a>);
 | |
|       — a 0x or 0X, then a nonempty sequence of hexadecimal digits optionally containing a decimal-
 | |
|         point character, then an optional binary exponent part as defined in <a href='#6.4.4.2'>6.4.4.2</a>, excluding any digit
 | |
|         separators;
 | |
|       — INF or INFINITY, ignoring case
 | |
|       — NAN or NAN(n-char-sequenceopt ), ignoring case in the NAN part, where:              n-char-sequence:
 | |
|                           digit
 | |
|                           nondigit
 | |
|                           n-char-sequence digit
 | |
|                           n-char-sequence nondigit
 | |
| 
 | |
| 
 | |
|     The subject sequence is defined as the longest initial subsequence of the input string, starting with
 | |
|     the first non-white-space character, that is of the expected form. The subject sequence contains no
 | |
|     characters if the input string is not of the expected form.
 | |
| </pre>
 | |
| <a name='7.24.1.5p4'></a>
 | |
| <pre>4   If the subject sequence has the expected form for a floating-point number, the sequence of characters
 | |
|     starting with the first digit or the decimal-point character (whichever occurs first) is interpreted as a
 | |
|      floating constant according to the rules of <a href='#6.4.4.2'>6.4.4.2</a>, except that the decimal-point character is used
 | |
|      in place of a period, and that if neither an exponent part nor a decimal-point character appears in
 | |
|      a decimal floating-point number, or if a binary exponent part does not appear in a hexadecimal
 | |
|      floating-point number, an exponent part of the appropriate type with value zero is assumed to
 | |
|      follow the last digit in the string. If the subject sequence begins with a minus sign, the sequence is
 | |
|      interpreted as negated.<a href='#FOOTNOTE.356'><sup>[356]</sup></a>
 | |
| 
 | |
|      A character sequence INF or INFINITY is interpreted as an infinity, if representable in the return type,
 | |
|      else like a floating constant that is too large for the range of the return type. A character sequence
 | |
|      NAN or NAN(n-char-sequenceopt ) is interpreted as a quiet NaN, if supported in the return type, else like
 | |
|      a subject sequence part that does not have the expected form; the meaning of the n-char sequence
 | |
|      is implementation-defined.<a href='#FOOTNOTE.357'><sup>[357]</sup></a> A pointer to the final string is stored in the object pointed to by
 | |
|      endptr, provided that endptr is not a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.356'>
 | |
| <pre><i><b>Footnote 356)</b> It is unspecified whether a minus-signed sequence is converted to a negative number directly or by negating the value
 | |
|      resulting from converting the corresponding unsigned sequence (see <a href='#F.5'>F.5</a>); the two methods could yield different results if
 | |
|      rounding is toward positive or negative infinity. In either case, the functions honor the sign of zero if floating-point arithmetic
 | |
|      supports signed zeros.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.357'>
 | |
| <pre><i><b>Footnote 357)</b> An implementation can use the n-char sequence to determine extra information to be represented in the NaN’s significand.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.1.5p5'></a>
 | |
| <pre>5    If the subject sequence has the hexadecimal form and FLT_RADIX is a power of 2, the value resulting
 | |
|      from the conversion is correctly rounded.
 | |
| </pre>
 | |
| <a name='7.24.1.5p6'></a>
 | |
| <pre>6    In other than the "C" locale, additional locale-specific subject sequence forms may be accepted.
 | |
| </pre>
 | |
| <a name='7.24.1.5p7'></a>
 | |
| <pre>7    If the subject sequence is empty or does not have the expected form, no conversion is performed; the
 | |
|      value of nptr is stored in the object pointed to by endptr, provided that endptr is not a null pointer.
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='7.24.1.5p8'></a>
 | |
| <pre>8    If the subject sequence has the hexadecimal form, FLT_RADIX is not a power of 2, and the result is
 | |
|      not exactly representable, the result should be one of the two numbers in the appropriate internal
 | |
|      format that are adjacent to the hexadecimal floating source value, with the extra stipulation that the
 | |
|      error should have a correct sign for the current rounding direction.
 | |
| </pre>
 | |
| <a name='7.24.1.5p9'></a>
 | |
| <pre>9    If the subject sequence has the decimal form and at most M significant digits, where M is the
 | |
|      maximum value of the T_DECIMAL_DIG macros (defined in <float.h>), the result should be correctly
 | |
|      rounded. If the subject sequence D has the decimal form and more than M significant digits, consider
 | |
|      the two bounding, adjacent decimal strings L and U, both having M significant digits, such that the
 | |
|      values of L, D, and U satisfy L ≤ D ≤ U. The result should be one of the (equal or adjacent) values
 | |
|      that would be obtained by correctly rounding L and U according to the current rounding direction,
 | |
|      with the extra stipulation that the error with respect to D should have a correct sign for the current
 | |
|      rounding direction.<a href='#FOOTNOTE.358'><sup>[358]</sup></a>
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.358'>
 | |
| <pre><i><b>Footnote 358)</b> M is sufficiently large that L and U will usually correctly round to the same internal floating value, but if not will correctly
 | |
|      round to adjacent values.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.1.5p10'></a>
 | |
| <pre>10   The functions return the converted value, if any. If no conversion could be performed, zero is
 | |
|      returned.
 | |
|      If the correct value overflows and default rounding is in effect (<a href='#7.12.1'>7.12.1</a>), plus or minus HUGE_VAL,
 | |
|      HUGE_VALF, or HUGE_VALL is returned (according to the return type and sign of the value); if the
 | |
|      integer expression math_errhandling & MATH_ERRNO is nonzero, the integer expression errno
 | |
|      acquires the value of ERANGE; if the integer expression math_errhandling & MATH_ERREXCEPT is
 | |
|      nonzero, the "overflow" floating-point exception is raised.
 | |
|      If the result underflows (<a href='#7.12.1'>7.12.1</a>), the functions return a value whose magnitude is no greater
 | |
|      than the smallest normalized positive number in the return type; if the integer expression
 | |
|      math_errhandling & MATH_ERRNO is nonzero, whether errno acquires the value ERANGE is
 | |
|      implementation-defined; if the integer expression math_errhandling & MATH_ERREXCEPT is
 | |
|      nonzero, whether the "underflow" floating-point exception is raised is implementation-defined.
 | |
| </pre>
 | |
| <a name='7.24.1.6'></a>
 | |
| <hr>
 | |
| <h3>7.24.1.6 [The strtodN functions]</h3>
 | |
| <a name='7.24.1.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              #ifdef __STDC_IEC_60559_DFP__
 | |
|              _Decimal32 strtod32(const char * restrict nptr, char ** restrict endptr);
 | |
|              _Decimal64 strtod64(const char * restrict nptr,char ** restrict endptr);
 | |
|              _Decimal128 strtod128(const char * restrict nptr,char ** restrict endptr);
 | |
|              #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.1.6p2'></a>
 | |
| <pre>2   The strtodN functions convert the initial portion of the string pointed to by nptr to decimal floating
 | |
|     type representation. First, they decompose the input string into three parts: an initial, possibly
 | |
|     empty, sequence of white-space characters; a subject sequence resembling a floating constant or
 | |
|     representing an infinity or NaN; and a final string of one or more unrecognized characters, including
 | |
|     the terminating null character of the input string. Then, they attempt to convert the subject sequence
 | |
|     to a floating-point number, and return the result.
 | |
| </pre>
 | |
| <a name='7.24.1.6p3'></a>
 | |
| <pre>3   The expected form of the subject sequence is an optional plus or minus sign, then one of the
 | |
|     following:
 | |
| 
 | |
|       — a nonempty sequence of decimal digits optionally containing a decimal-point character, then
 | |
|         an optional exponent part as defined in <a href='#6.4.4.2'>6.4.4.2</a>, excluding any digit separators (<a href='#6.4.4.1'>6.4.4.1</a>)
 | |
|       — INF or INFINITY, ignoring case
 | |
|       — NAN or NAN(d-char-sequenceopt ), ignoring case in the NAN part, where:                     d-char-sequence:
 | |
|                           digit
 | |
|                           nondigit
 | |
|                           d-char-sequence digit
 | |
|                           d-char-sequence nondigit
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     The subject sequence is defined as the longest initial subsequence of the input string, starting with
 | |
|     the first non-white-space character, that is of the expected form. The subject sequence contains no
 | |
|     characters if the input string is not of the expected form.
 | |
| </pre>
 | |
| <a name='7.24.1.6p4'></a>
 | |
| <pre>4   If the subject sequence has the expected form for a floating-point number, the sequence of characters
 | |
|     starting with the first digit or the decimal-point character (whichever occurs first) is interpreted as a
 | |
|     floating constant according to the rules of <a href='#6.4.4.2'>6.4.4.2</a>, including correct rounding and determination of
 | |
|     the coefficient c and the quantum exponent q, with the following exceptions:
 | |
| 
 | |
|       — It is not a hexadecimal floating number.
 | |
|       — The decimal-point character is used in place of a period.
 | |
|       — If neither an exponent part nor a decimal-point character appears in a decimal floating-point
 | |
|         number, an exponent part of the appropriate type with value zero is assumed to follow the
 | |
|         last digit in the string.
 | |
| 
 | |
|     If the subject sequence begins with a minus sign, the sequence is interpreted as negated (before
 | |
|     rounding) and the sign s is set to −1, else s is set to 1. A character sequence INF or INFINITY is
 | |
|     interpreted as an infinity. A character sequence NAN or NAN(d-char-sequenceopt ), is interpreted as a
 | |
|     quiet NaN; the meaning of the d-char sequence is implementation-defined.<a href='#FOOTNOTE.359'><sup>[359]</sup></a> A pointer to the final
 | |
|     string is stored in the object pointed to by endptr, provided that endptr is not a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.359'>
 | |
| <pre><i><b>Footnote 359)</b> An implementation may use the d-char sequence to determine extra information to be represented in the NaN’s
 | |
|     significand.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.1.6p5'></a>
 | |
| <pre>5   In other than the "C" locale, additional locale-specific subject sequence forms may be accepted.
 | |
| </pre>
 | |
| <a name='7.24.1.6p6'></a>
 | |
| <pre>6   If the subject sequence is empty or does not have the expected form, no conversion is performed; the
 | |
|     value of nptr is stored in the object pointed to by endptr, provided that endptr is not a null pointer.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.1.6p7'></a>
 | |
| <pre>7   The strtodN functions return the correctly rounded converted value, if any. If no conversion could
 | |
|     be performed, the value of the triple (+1, 0, 0) is returned. If the correct value overflows:
 | |
| 
 | |
|       — the value of the macro ERANGE is stored in errno if the integer expression
 | |
|         math_errhandling & MATH_ERRNO is nonzero;
 | |
| 
 | |
|       — the      "overflow"       floating-point      exception       is   raised     if   the    integer     expression
 | |
|           math_errhandling & MATH_ERREXCEPT is nonzero.
 | |
| 
 | |
|     If the result underflows (<a href='#7.12.1'>7.12.1</a>), whether errno acquires the value ERANGE if the integer expression
 | |
|     math_errhandling & MATH_ERRNO is nonzero is implementation-defined; if the integer expres-
 | |
|     sion math_errhandling & MATH_ERREXCEPT is nonzero, whether the "underflow" floating-point
 | |
|     exception is raised is implementation-defined.
 | |
| </pre>
 | |
| <a name='7.24.1.6p8'></a>
 | |
| <pre>8   EXAMPLE Following are subject sequences of the decimal form and the resulting triples (s, c, q) produced by strtod64.
 | |
|     Note that for _Decimal64 , the precision (maximum coefficient length) is 16 and the quantum exponent range is −398 ≤ q ≤ 369.
 | |
| 
 | |
|            "0"                          (+1, 0, 0)
 | |
|            "0.00"                       (+1, 0, −2)
 | |
|            "123"                        (+1, 123, 0)
 | |
|            "-123"                       (−1, 123, 0)
 | |
|            "<a href='#1.'>1.</a>23E3"                     (+1, 123, 1)
 | |
|            "<a href='#1.'>1.</a>23E+3"                    (+1, 123, 1)
 | |
|            "12.3E+7"                    (+1, 123, 6)
 | |
|            "12.0"                       (+1, 120, −1)
 | |
|            "12.3"                       (+1, 123, −1)
 | |
|            "0.00123"                    (+1, 123, −5)
 | |
|            "-<a href='#1.'>1.</a>23E-12"                  (−1, 123, −14)
 | |
|            "1234.5E-4"                  (+1, 12345, −5)
 | |
|            "-0"                         (−1, 0, 0)
 | |
|            "-0.00"                      (−1, 0, −2)
 | |
|            "0E+7"                       (+1, 0, 7)
 | |
|            "-0E-7"                      (−1, 0, −7)
 | |
|            "12345678901234567890"       (+1, 1234567890123457, 4) or (+1, 1234567890123456, 4) depending on rounding
 | |
|                                         mode
 | |
|            "1234E-400"                  (+1, 12, −398) or (+1, 13, −398) depending on rounding mode
 | |
|            "1234E-402"                  (+1, 0, −398) or (+1, 1, −398) depending on rounding mode
 | |
|            "1000."                      (+1, 1000, 0)
 | |
|            ".0001"                      (+1, 1, −4)
 | |
|            "1000.e0"                    (+1, 1000, 0)
 | |
|            ".0001e0"                    (+1, 1, −4)
 | |
|            "1000.0"                     (+1, 10000, −1)
 | |
|            "0.0001"                     (+1, 1, −4)
 | |
|            "1000.00"                    (+1, 100000, −2)
 | |
|            "00.0001"                    (+1, 1, −4)
 | |
|            "001000."                    (+1, 1000, 0)
 | |
|            "001000.0"                   (+1, 10000, −1)
 | |
|            "001000.00"                  (+1, 100000, −2)
 | |
|            "00.00"                      (+1, 0, −2)
 | |
|            "00."                        (+1, 0, 0)
 | |
|            ".00"                        (+1, 0, −2)
 | |
|            "00.00e-5"                   (+1, 0, −7)
 | |
|            "00.e-5"                     (+1, 0, −5)
 | |
|            ".00e-5"                     (+1, 0, −7)
 | |
|            "0x1.8p+4"                   (+1, 0, 0), and a pointer to "x1.8p+4" is stored in the object pointed to by endptr,
 | |
|                                         provided endptr is not a null pointer
 | |
|            "infinite"                   infinity, and a pointer to "inite" is stored in the object pointed to by endptr, provided
 | |
|                                         endptr is not a null pointer
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.1.7'></a>
 | |
| <hr>
 | |
| <h3>7.24.1.7 [The strtol, strtoll, strtoul, and strtoull functions]</h3>
 | |
| <a name='7.24.1.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|     #include <stdlib.h>
 | |
|      long int strtol(const char *restrict nptr, char **restrict endptr, int base);
 | |
|      long long int strtoll(const char *restrict nptr, char **restrict endptr, int base);
 | |
|      unsigned long int strtoul(const char *restrict nptr, char **restrict endptr, int base);
 | |
|      unsigned long long int strtoull(const char *restrict nptr, char **restrict endptr, int
 | |
|          base);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.1.7p2'></a>
 | |
| <pre>2   The strtol, strtoll, strtoul, and strtoull functions convert the initial portion of
 | |
|     the string pointed to by nptr to long int, long long int, unsigned long int, and
 | |
|     unsigned long long int representation, respectively.          First, they decompose the input
 | |
|     string into three parts: an initial, possibly empty, sequence of white-space characters, a subject
 | |
|     sequence resembling an integer represented in some radix determined by the value of base, and a
 | |
|     final string of one or more unrecognized characters, including the terminating null character of the
 | |
|     input string. Then, they attempt to convert the subject sequence to an integer, and return the result.
 | |
| </pre>
 | |
| <a name='7.24.1.7p3'></a>
 | |
| <pre>3   If the value of base is zero, the expected form of the subject sequence is that of an integer constant as
 | |
|     described in <a href='#6.4.4.1'>6.4.4.1</a>, optionally preceded by a plus or minus sign, but not including an integer suffix
 | |
|     or any optional digit separators. If the value of base is between 2 and 36 (inclusive), the expected
 | |
|     form of the subject sequence is a sequence of letters and digits representing an integer with the radix
 | |
|     specified by base, optionally preceded by a plus or minus sign, but not including an integer suffix
 | |
|     or any optional digit separators. The letters from a (or A) through z (or Z) are ascribed the values 10
 | |
|     through 35; only letters and digits whose ascribed values are less than that of base are permitted. If
 | |
|     the value of base is 2, the characters 0b or 0B may optionally precede the sequence of letters and
 | |
|     digits, following the sign if present. If the value of base is 16, the characters 0x or 0X may optionally
 | |
|     precede the sequence of letters and digits, following the sign if present.
 | |
| </pre>
 | |
| <a name='7.24.1.7p4'></a>
 | |
| <pre>4   The subject sequence is defined as the longest initial subsequence of the input string, starting with
 | |
|     the first non-white-space character, that is of the expected form. The subject sequence contains no
 | |
|     characters if the input string is empty or consists entirely of white-space characters, or if the first
 | |
|     non-white-space character is other than a sign or a permissible letter or digit.
 | |
| </pre>
 | |
| <a name='7.24.1.7p5'></a>
 | |
| <pre>5   If the subject sequence has the expected form and the value of base is zero, the sequence of characters
 | |
|     starting with the first digit is interpreted as an integer constant according to the rules of <a href='#6.4.4.1'>6.4.4.1</a>. If
 | |
|     the subject sequence has the expected form and the value of base is between 2 and 36, it is used as
 | |
|     the base for conversion, ascribing to each letter its value as given above. If the subject sequence
 | |
|     begins with a minus sign, the value resulting from the conversion is negated (in the return type). A
 | |
|     pointer to the final string is stored in the object pointed to by endptr, provided that endptr is not a
 | |
|     null pointer.
 | |
| </pre>
 | |
| <a name='7.24.1.7p6'></a>
 | |
| <pre>6   In other than the "C" locale, additional locale-specific subject sequence forms may be accepted.
 | |
| </pre>
 | |
| <a name='7.24.1.7p7'></a>
 | |
| <pre>7   If the subject sequence is empty or does not have the expected form, no conversion is performed; the
 | |
|     value of nptr is stored in the object pointed to by endptr, provided that endptr is not a null pointer.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.1.7p8'></a>
 | |
| <pre>8   The strtol, strtoll, strtoul, and strtoull functions return the converted value, if any. If
 | |
|     no conversion could be performed, zero is returned. If the correct value is outside the range of
 | |
|     representable values, LONG_MIN, LONG_MAX, LLONG_MIN, LLONG_MAX, ULONG_MAX, or ULLONG_MAX is
 | |
|     returned (according to the return type and sign of the value, if any), and the value of the macro
 | |
|     ERANGE is stored in errno.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.2 [Pseudo-random sequence generation functions]</h3>
 | |
| <a name='7.24.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.2.1 [The rand function]</h3>
 | |
| <a name='7.24.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              int rand(void);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.2.1p2'></a>
 | |
| <pre>2   The rand function computes a sequence of pseudo-random integers in the range 0 to RAND_MAX
 | |
|     inclusive.
 | |
| </pre>
 | |
| <a name='7.24.2.1p3'></a>
 | |
| <pre>3   The rand function is not required to avoid data races with other calls to pseudo-random sequence
 | |
|     generation functions. The implementation shall behave as if no library function calls the rand
 | |
|     function.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.24.2.1p4'></a>
 | |
| <pre>4   There are no guarantees as to the quality of the random sequence produced and some implementa-
 | |
|     tions are known to produce sequences with distressingly non-random low-order bits. Applications
 | |
|     with particular requirements should use a generator that is known to be sufficient for their needs.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.2.1p5'></a>
 | |
| <pre>5   The rand function returns a pseudo-random integer.
 | |
| 
 | |
|     Environmental limits
 | |
| </pre>
 | |
| <a name='7.24.2.1p6'></a>
 | |
| <pre>6   The value of the RAND_MAX macro shall be at least 32767.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.2.2 [The srand function]</h3>
 | |
| <a name='7.24.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void srand(unsigned int seed);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.2.2p2'></a>
 | |
| <pre>2   The srand function uses the argument as a seed for a new sequence of pseudo-random numbers
 | |
|     to be returned by subsequent calls to rand. If srand is then called with the same seed value, the
 | |
|     sequence of pseudo-random numbers shall be repeated. If rand is called before any calls to srand
 | |
|     have been made, the same sequence shall be generated as when srand is first called with a seed
 | |
|     value of 1.
 | |
| </pre>
 | |
| <a name='7.24.2.2p3'></a>
 | |
| <pre>3   The srand function is not required to avoid data races with other calls to pseudo-random sequence
 | |
|     generation functions. The implementation shall behave as if no library function calls the srand
 | |
|     function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.2.2p4'></a>
 | |
| <pre>4   The srand function returns no value.
 | |
| </pre>
 | |
| <a name='7.24.2.2p5'></a>
 | |
| <pre>5   EXAMPLE The following functions define a portable implementation of rand and srand.
 | |
| 
 | |
|              static unsigned long int next = 1;
 | |
| 
 | |
|              int rand(void)   // RAND_MAX assumed to be 32767
 | |
|              {
 | |
|                    next = next * 1103515245 + 12345;
 | |
|                    return (unsigned int)(next/65536) % 32768;
 | |
|              }
 | |
| 
 | |
|              void srand(unsigned int seed)
 | |
|              {
 | |
|                    next = seed;
 | |
|              }
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3'></a>
 | |
| <hr>
 | |
| <h3>7.24.3 [Memory management functions]</h3>
 | |
| <a name='7.24.3p1'></a>
 | |
| <pre>1   The order and contiguity of storage allocated by successive calls to the aligned_alloc, calloc,
 | |
|     malloc, and realloc functions is unspecified. The pointer returned if the allocation succeeds is
 | |
|     suitably aligned so that it may be assigned to a pointer to any type of object with a fundamental
 | |
|     alignment requirement and size less than or equal to the size requested. It may then be used to
 | |
|     access such an object or an array of such objects in the space allocated (until the space is explicitly
 | |
|     deallocated). The lifetime of an allocated object extends from the allocation until the deallocation.
 | |
|     Each such allocation shall yield a pointer to an object disjoint from any other object. The pointer
 | |
|     returned points to the start (lowest byte address) of the allocated space. If the space cannot be
 | |
|     allocated, a null pointer is returned. If the size of the space requested is zero, the behavior is
 | |
|     implementation-defined: either a null pointer is returned to indicate an error, or the behavior is as if
 | |
|     the size were some nonzero value, except that the returned pointer shall not be used to access an
 | |
|     object.
 | |
| </pre>
 | |
| <a name='7.24.3p2'></a>
 | |
| <pre>2   For purposes of determining the existence of a data race, memory allocation functions behave as
 | |
|     though they accessed only memory locations accessible through their arguments and not other
 | |
|     static duration storage. These functions may, however, visibly modify the storage that they allocate
 | |
|     or deallocate. Calls to these functions that allocate or deallocate a particular region of memory
 | |
|     shall occur in a single total order, and each such deallocation call shall synchronize with the next
 | |
|     allocation (if any) in this order.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.3.1 [The aligned_alloc function]</h3>
 | |
| <a name='7.24.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void *aligned_alloc(size_t alignment, size_t size);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.3.1p2'></a>
 | |
| <pre>2   The aligned_alloc function allocates space for an object whose alignment is specified by
 | |
|     alignment, whose size is specified by size, and whose representation is indeterminate. If the
 | |
|     value of alignment is not a valid alignment supported by the implementation the function shall fail
 | |
|     by returning a null pointer.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.3.1p3'></a>
 | |
| <pre>3   The aligned_alloc function returns either a null pointer or a pointer to the allocated space.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.3.2 [The calloc function]</h3>
 | |
| <a name='7.24.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void *calloc(size_t nmemb, size_t size);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.3.2p2'></a>
 | |
| <pre>2   The calloc function allocates space for an array of nmemb objects, each of whose size is size. The
 | |
|     space is initialized to all bits zero<a href='#FOOTNOTE.360'><sup>[360]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.360'>
 | |
| <pre><i><b>Footnote 360)</b> Note that this need not be the same as the representation of floating-point zero or a null pointer constant.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.3.2p3'></a>
 | |
| <pre>3   The calloc function returns either a pointer to the allocated space or a null pointer if the space
 | |
|     cannot be allocated or if the mathematical product nmemb * size is not representable as a value of
 | |
|     type size_t.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.24.3.3 [The free function]</h3>
 | |
| <a name='7.24.3.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void free(void *ptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.3.3p2'></a>
 | |
| <pre>2   The free function causes the space pointed to by ptr to be deallocated, that is, made available
 | |
|     for further allocation. If ptr is a null pointer, no action occurs. Otherwise, if the argument does
 | |
|     not match a pointer earlier returned by a memory management function, or if the space has been
 | |
|     deallocated by a call to free or realloc, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.3.3p3'></a>
 | |
| <pre>3   The free function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3.4'></a>
 | |
| <hr>
 | |
| <h3>7.24.3.4 [The free_sized function]</h3>
 | |
| <a name='7.24.3.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void free_sized(void *ptr, size_t size);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.3.4p2'></a>
 | |
| <pre>2   If ptr is a null pointer or the result obtained from a call to malloc, realloc, or calloc, where size
 | |
|     size is equal to the requested allocation size, this function is equivalent to free(ptr). Otherwise,
 | |
|     the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.24.3.4p3'></a>
 | |
| <pre>3   NOTE 1 A conforming implementation may ignore size and call free.
 | |
| </pre>
 | |
| <a name='7.24.3.4p4'></a>
 | |
| <pre>4   NOTE 2 The result of an aligned_alloc call may not be passed to free_sized.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.24.3.4p5'></a>
 | |
| <pre>5   Implementations may provide extensions to query the usable size of an allocation, or to determine
 | |
|     the usable size of the allocation that would result if a request for some other size were to succeed.
 | |
|     Such implementations should allow passing the resulting usable size as the size parameter, and
 | |
|     provide functionality equivalent to free in such cases.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.3.4p6'></a>
 | |
| <pre>6   The free_sized function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3.5'></a>
 | |
| <hr>
 | |
| <h3>7.24.3.5 [The free_aligned_sized function]</h3>
 | |
| <a name='7.24.3.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void free_aligned_sized(void *ptr, size_t alignment, size_t size);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.3.5p2'></a>
 | |
| <pre>2   If ptr is a null pointer or the result obtained from a call to aligned_alloc, where alignment is
 | |
|     equal to the requested allocation alignment and size is equal to the requested allocation size, this
 | |
|     function is equivalent to free(ptr). Otherwise, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.24.3.5p3'></a>
 | |
| <pre>3   NOTE 1 A conforming implementation may ignore alignment and size and call free.
 | |
| </pre>
 | |
| <a name='7.24.3.5p4'></a>
 | |
| <pre>4   NOTE 2 The result of an malloc, calloc, or realloc call may not be passed to free_aligned_sized.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.24.3.5p5'></a>
 | |
| <pre>5   Implementations may provide extensions to query the usable size of an allocation, or to determine
 | |
|     the usable size of the allocation that would result if a request for some other size were to succeed.
 | |
|     Such implementations should allow passing the resulting usable size as the size parameter, and
 | |
|     provide functionality equivalent to free in such cases.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.3.5p6'></a>
 | |
| <pre>6   The free_aligned_sized function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3.6'></a>
 | |
| <hr>
 | |
| <h3>7.24.3.6 [The malloc function]</h3>
 | |
| <a name='7.24.3.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void *malloc(size_t size);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.3.6p2'></a>
 | |
| <pre>2   The malloc function allocates space for an object whose size is specified by size and whose
 | |
|     representation is indeterminate.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.3.6p3'></a>
 | |
| <pre>3   The malloc function returns either a null pointer or a pointer to the allocated space.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.3.7'></a>
 | |
| <hr>
 | |
| <h3>7.24.3.7 [The realloc function]</h3>
 | |
| <a name='7.24.3.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               void *realloc(void *ptr, size_t size);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.3.7p2'></a>
 | |
| <pre>2   The realloc function deallocates the old object pointed to by ptr and returns a pointer to a new
 | |
|     object that has the size specified by size. The contents of the new object shall be the same as that of
 | |
|     the old object prior to deallocation, up to the lesser of the new and old sizes. Any bytes in the new
 | |
|     object beyond the size of the old object have unspecified values.
 | |
| </pre>
 | |
| <a name='7.24.3.7p3'></a>
 | |
| <pre>3   If ptr is a null pointer, the realloc function behaves like the malloc function for the specified size.
 | |
|     Otherwise, if ptr does not match a pointer earlier returned by a memory management function, or
 | |
|     if the space has been deallocated by a call to the free or realloc function, or if the size is zero, the
 | |
|     behavior is undefined. If memory for the new object is not allocated, the old object is not deallocated
 | |
|     and its value is unchanged.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.3.7p4'></a>
 | |
| <pre>4   The realloc function returns a pointer to the new object (which may have the same value as a
 | |
|     pointer to the old object), or a null pointer if the new object has not been allocated.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.4'></a>
 | |
| <hr>
 | |
| <h3>7.24.4 [Communication with the environment]</h3>
 | |
| <a name='7.24.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.1 [The abort function]</h3>
 | |
| <a name='7.24.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               [[noreturn]] void abort(void);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.1p2'></a>
 | |
| <pre>2   The abort function causes abnormal program termination to occur, unless the signal SIGABRT is
 | |
|     being caught and the signal handler does not return. Whether open streams with unwritten buffered
 | |
|     data are flushed, open streams are closed, or temporary files are removed is implementation-
 | |
|     defined. An implementation-defined form of the status unsuccessful termination is returned to the
 | |
|     host environment by means of the function call raise(SIGABRT).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.1p3'></a>
 | |
| <pre>3   The abort function does not return to its caller.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.2 [The atexit function]</h3>
 | |
| <a name='7.24.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               int atexit(void (*func)(void));
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.2p2'></a>
 | |
| <pre>2   The atexit function registers the function pointed to by func, to be called without arguments at
 | |
|     normal program termination.<a href='#FOOTNOTE.361'><sup>[361]</sup></a> It is unspecified whether a call to the atexit function that does
 | |
|     not happen before the exit function is called will succeed.
 | |
| 
 | |
|     Environmental limits
 | |
| </pre>
 | |
| <a name='FOOTNOTE.361'>
 | |
| <pre><i><b>Footnote 361)</b> The atexit function registrations are distinct from the at_quick_exit registrations, so applications might need to call
 | |
|     both registration functions with the same argument.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.4.2p3'></a>
 | |
| <pre>3   The implementation shall support the registration of at least 32 functions.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.2p4'></a>
 | |
| <pre>4   The atexit function returns zero if the registration succeeds, nonzero if it fails.
 | |
|     Forward references: the at_quick_exit function (<a href='#7.24.4.3'>7.24.4.3</a>), the exit function (<a href='#7.24.4.4'>7.24.4.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.3 [The at_quick_exit function]</h3>
 | |
| <a name='7.24.4.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               int at_quick_exit(void (*func)(void));
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.3p2'></a>
 | |
| <pre>2   The at_quick_exit function registers the function pointed to by func, to be called without argu-
 | |
|     ments should quick_exit be called.<a href='#FOOTNOTE.362'><sup>[362]</sup></a> It is unspecified whether a call to the at_quick_exit
 | |
|     function that does not happen before the quick_exit function is called will succeed.
 | |
| 
 | |
|     Environmental limits
 | |
| </pre>
 | |
| <a name='FOOTNOTE.362'>
 | |
| <pre><i><b>Footnote 362)</b> The at_quick_exit function registrations are distinct from the atexit registrations, so applications might need to call
 | |
|     both registration functions with the same argument.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.4.3p3'></a>
 | |
| <pre>3   The implementation shall support the registration of at least 32 functions.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.3p4'></a>
 | |
| <pre>4   The at_quick_exit function returns zero if the registration succeeds, nonzero if it fails.
 | |
|     Forward references: the quick_exit function (<a href='#7.24.4.7'>7.24.4.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.4 [The exit function]</h3>
 | |
| <a name='7.24.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               [[noreturn]] void exit(int status);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.4p2'></a>
 | |
| <pre>2   The exit function causes normal program termination to occur. No functions registered by the
 | |
|     at_quick_exit function are called. If a program calls the exit function more than once, or calls the
 | |
|     quick_exit function in addition to the exit function, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.24.4.4p3'></a>
 | |
| <pre>3   First, all functions registered by the atexit function are called, in the reverse order of their registra-
 | |
|     tion,<a href='#FOOTNOTE.363'><sup>[363]</sup></a> except that a function is called after any previously registered functions that had already
 | |
|     been called at the time it was registered. If, during the call to any such function, a call to the longjmp
 | |
|     function is made that would terminate the call to the registered function, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.363'>
 | |
| <pre><i><b>Footnote 363)</b> Each function is called as many times as it was registered, and in the correct order with respect to other registered
 | |
|     functions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.4.4p4'></a>
 | |
| <pre>4   Next, all open streams with unwritten buffered data are flushed, all open streams are closed, and all
 | |
|     files created by the tmpfile function are removed.
 | |
| </pre>
 | |
| <a name='7.24.4.4p5'></a>
 | |
| <pre>5   Finally, control is returned to the host environment. If the value of status is zero or EXIT_SUCCESS,
 | |
|     an implementation-defined form of the status successful termination is returned. If the value of
 | |
|     status is EXIT_FAILURE, an implementation-defined form of the status unsuccessful termination is
 | |
|     returned. Otherwise the status returned is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.4p6'></a>
 | |
| <pre>6   The exit function cannot return to its caller.
 | |
| </pre>
 | |
| <a name='7.24.4.5'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.5 [The _Exit function]</h3>
 | |
| <a name='7.24.4.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               [[noreturn]] void _Exit(int status);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.5p2'></a>
 | |
| <pre>2   The _Exit function causes normal program termination to occur and control to be returned to the
 | |
|     host environment. No functions registered by the atexit function, the at_quick_exit function,
 | |
|     or signal handlers registered by the signal function are called. The status returned to the host
 | |
|     environment is determined in the same way as for the exit function (<a href='#7.24.4.4'>7.24.4.4</a>). Whether open
 | |
|     streams with unwritten buffered data are flushed, open streams are closed, or temporary files are
 | |
|     removed is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.5p3'></a>
 | |
| <pre>3   The _Exit function cannot return to its caller.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.4.6'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.6 [The getenv function]</h3>
 | |
| <a name='7.24.4.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               char *getenv(const char *name);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.6p2'></a>
 | |
| <pre>2   The getenv function searches an environment list, provided by the host environment, for a string that
 | |
|     matches the string pointed to by name. The set of environment names and the method for altering
 | |
|     the environment list are implementation-defined. The getenv function need not avoid data races
 | |
|     with other threads of execution that modify the environment list.<a href='#FOOTNOTE.364'><sup>[364]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.364'>
 | |
| <pre><i><b>Footnote 364)</b> Many implementations provide non-standard functions that modify the environment list.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.4.6p3'></a>
 | |
| <pre>3   The implementation shall behave as if no library function calls the getenv function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.6p4'></a>
 | |
| <pre>4   The getenv function returns a pointer to a string associated with the matched list member. The
 | |
|     string pointed to shall not be modified by the program, but may be overwritten by a subsequent call
 | |
|     to the getenv function. If the specified name cannot be found, a null pointer is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.4.7'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.7 [The quick_exit function]</h3>
 | |
| <a name='7.24.4.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               [[noreturn]] void quick_exit(int status);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.7p2'></a>
 | |
| <pre>2   The quick_exit function causes normal program termination to occur. No functions registered by
 | |
|     the atexit function or signal handlers registered by the signal function are called. If a program calls
 | |
|     the quick_exit function more than once, or calls the exit function in addition to the quick_exit
 | |
|     function, the behavior is undefined. If a signal is raised while the quick_exit function is executing,
 | |
|     the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.24.4.7p3'></a>
 | |
| <pre>3   The quick_exit function first calls all functions registered by the at_quick_exit function, in the
 | |
|     reverse order of their registration,<a href='#FOOTNOTE.365'><sup>[365]</sup></a> except that a function is called after any previously registered
 | |
|     functions that had already been called at the time it was registered. If, during the call to any such
 | |
|     function, a call to the longjmp function is made that would terminate the call to the registered
 | |
|     function, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.365'>
 | |
| <pre><i><b>Footnote 365)</b> Each function is called as many times as it was registered, and in the correct order with respect to other registered
 | |
|     functions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.4.7p4'></a>
 | |
| <pre>4   Then control is returned to the host environment by means of the function call _Exit(status) .
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.7p5'></a>
 | |
| <pre>5   The quick_exit function cannot return to its caller.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.4.8'></a>
 | |
| <hr>
 | |
| <h3>7.24.4.8 [The system function]</h3>
 | |
| <a name='7.24.4.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              int system(const char *string);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.4.8p2'></a>
 | |
| <pre>2   If string is a null pointer, the system function determines whether the host environment has a
 | |
|     command processor. If string is not a null pointer, the system function passes the string pointed to
 | |
|     by string to that command processor to be executed in a manner which the implementation shall
 | |
|     document; this might then cause the program calling system to behave in a non-conforming manner
 | |
|     or to terminate.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.4.8p3'></a>
 | |
| <pre>3   If the argument is a null pointer, the system function returns nonzero only if a command processor
 | |
|     is available. If the argument is not a null pointer, and the system function does return, it returns an
 | |
|     implementation-defined value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.5'></a>
 | |
| <hr>
 | |
| <h3>7.24.5 [Searching and sorting utilities]</h3>
 | |
| <a name='7.24.5p1'></a>
 | |
| <pre>1   These utilities make use of a comparison function to search or sort arrays of unspecified type. Where
 | |
|     an argument declared as size_t nmemb specifies the length of the array for a function, nmemb can
 | |
|     have the value zero on a call to that function; the comparison function is not called, a search finds no
 | |
|     matching element, and sorting performs no rearrangement. Pointer arguments on such a call shall
 | |
|     still have valid values, as described in <a href='#7.1.4'>7.1.4</a>.
 | |
| </pre>
 | |
| <a name='7.24.5p2'></a>
 | |
| <pre>2   The implementation shall ensure that the second argument of the comparison function (when called
 | |
|     from bsearch), or both arguments (when called from qsort), are pointers to elements of the array.<a href='#FOOTNOTE.366'><sup>[366]</sup></a>
 | |
|     The first argument when called from bsearch shall equal key.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.366'>
 | |
| <pre><i><b>Footnote 366)</b> That is, if the value passed is p, then the following expressions are always nonzero:
 | |
|              ((char *)p - (char *)base) % size == 0
 | |
|              (char *)p >= (char *)base
 | |
|              (char *)p < (char *)base + nmemb * size
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.5p3'></a>
 | |
| <pre>3   The comparison function shall not alter the contents of the array. The implementation may reorder
 | |
|     elements of the array between calls to the comparison function, but shall not alter the contents of
 | |
|     any individual element.
 | |
| </pre>
 | |
| <a name='7.24.5p4'></a>
 | |
| <pre>4   When the same objects (consisting of size bytes, irrespective of their current positions in the array)
 | |
|     are passed more than once to the comparison function, the results shall be consistent with one
 | |
|     another. That is, for qsort they shall define a total ordering on the array, and for bsearch the same
 | |
|     object shall always compare the same way with the key.
 | |
| </pre>
 | |
| <a name='7.24.5p5'></a>
 | |
| <pre>5   A sequence point occurs immediately before and immediately after each call to the comparison
 | |
|     function, and also between any call to the comparison function and any movement of the objects
 | |
|     passed as arguments to that call.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.5.1 [The bsearch generic function]</h3>
 | |
| <a name='7.24.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void *bsearch(const void *key, const void *base, size_t nmemb, size_t size,
 | |
|                    int (*compar)(const void *, const void *));
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.5.1p2'></a>
 | |
| <pre>2   The bsearch generic function searches an array of nmemb objects, the initial element of which is
 | |
|     pointed to by base, for an element that matches the object pointed to by key. The size of each
 | |
|     element of the array is specified by size.
 | |
| </pre>
 | |
| <a name='7.24.5.1p3'></a>
 | |
| <pre>3   The comparison function pointed to by compar is called with two arguments that point to the key
 | |
|     object and to an array element, in that order. The function shall return an integer less than, equal to,
 | |
|     or greater than zero if the key object is considered, respectively, to be less than, to match, or to be
 | |
|     greater than the array element. The array shall consist of: all the elements that compare less than, all
 | |
|     the elements that compare equal to, and all the elements that compare greater than the key object, in
 | |
|     that order.<a href='#FOOTNOTE.367'><sup>[367]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.367'>
 | |
| <pre><i><b>Footnote 367)</b> In practice, the entire array is sorted according to the comparison function.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.5.1p4'></a>
 | |
| <pre>4   The bsearch generic function returns a pointer to a matching element of the array, or a null pointer
 | |
|     if no match is found. If two elements compare as equal, which element is matched is unspecified.
 | |
| </pre>
 | |
| <a name='7.24.5.1p5'></a>
 | |
| <pre>5   The bsearch function is generic in the qualification of the type pointed to by the argument to base.
 | |
|     If this argument is a pointer to a const-qualified object type, the returned pointer will be a pointer
 | |
|     to const-qualified void. Otherwise, the argument shall be a pointer to an unqualified object type or
 | |
|     a null pointer constant<a href='#FOOTNOTE.368'><sup>[368]</sup></a> , and the returned pointer will be a pointer to unqualified void.
 | |
|     The external declaration of bsearch has the concrete type:
 | |
| 
 | |
|               void * (const void *, const void *, size_t, size_t, int (*) (const void *, const
 | |
|                   void *))
 | |
| 
 | |
| 
 | |
|     , which supports all correct uses. If a macro definition of this generic function is suppressed in order
 | |
|     to access an actual function, the external declaration with this concrete type is visible<a href='#FOOTNOTE.369'><sup>[369]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.368'>
 | |
| <pre><i><b>Footnote 368)</b> If the argument is a null pointer and the call is executed, the behavior is undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.369'>
 | |
| <pre><i><b>Footnote 369)</b> This is an obsolescent feature.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.5.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.5.2 [The qsort function]</h3>
 | |
| <a name='7.24.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              void qsort(void *base, size_t nmemb, size_t size,
 | |
|                    int (*compar)(const void *, const void *));
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.5.2p2'></a>
 | |
| <pre>2   The qsort function sorts an array of nmemb objects, the initial element of which is pointed to by
 | |
|     base. The size of each object is specified by size.
 | |
| </pre>
 | |
| <a name='7.24.5.2p3'></a>
 | |
| <pre>3   The contents of the array are sorted into ascending order according to a comparison function pointed
 | |
|     to by compar, which is called with two arguments that point to the objects being compared. The
 | |
|     function shall return an integer less than, equal to, or greater than zero if the first argument is
 | |
|     considered to be respectively less than, equal to, or greater than the second.
 | |
| </pre>
 | |
| <a name='7.24.5.2p4'></a>
 | |
| <pre>4   If two elements compare as equal, their order in the resulting sorted array is unspecified.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.5.2p5'></a>
 | |
| <pre>5   The qsort function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.6'></a>
 | |
| <hr>
 | |
| <h3>7.24.6 [Integer arithmetic functions]</h3>
 | |
| <a name='7.24.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.6.1 [The abs, labs, and llabs functions]</h3>
 | |
| <a name='7.24.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              int abs(int j);
 | |
|              long int labs(long int j);
 | |
|              long long int llabs(long long int j);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.6.1p2'></a>
 | |
| <pre>2   The abs, labs, and llabs functions compute the absolute value of an integer j. If the result cannot
 | |
|     be represented, the behavior is undefined<a href='#FOOTNOTE.370'><sup>[370]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.370'>
 | |
| <pre><i><b>Footnote 370)</b> The absolute value of the most negative number may not be representable.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.6.1p3'></a>
 | |
| <pre>3   The abs, labs, and llabs, functions return the absolute value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.6.2 [The div, ldiv, and lldiv functions]</h3>
 | |
| <a name='7.24.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              div_t div(int numer, int denom);
 | |
|              ldiv_t ldiv(long int numer, long int denom);
 | |
|              lldiv_t lldiv(long long int numer, long long int denom);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.6.2p2'></a>
 | |
| <pre>2   The div, ldiv, and lldiv, functions compute numer/denom and numer%denom in a single operation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.6.2p3'></a>
 | |
| <pre>3   The div, ldiv, and lldiv functions return a structure of type div_t, ldiv_t, and lldiv_t, respec-
 | |
|     tively, comprising both the quotient and the remainder. The structures shall contain (in either order)
 | |
|     the members quot (the quotient) and rem (the remainder), each of which has the same type as
 | |
|     the arguments numer and denom. If either part of the result cannot be represented, the behavior is
 | |
|     undefined.
 | |
| </pre>
 | |
| <a name='7.24.7'></a>
 | |
| <hr>
 | |
| <h3>7.24.7 [Multibyte/wide character conversion functions]</h3>
 | |
| <a name='7.24.7p1'></a>
 | |
| <pre>1   The behavior of the multibyte character functions is affected by the LC_CTYPE category of the current
 | |
|     locale. For a state-dependent encoding, each of the mbtowc and wctomb functions is placed into its
 | |
|     initial conversion state prior to the first call to the function and can be returned to that state by a
 | |
|     call for which its character pointer argument, s, is a null pointer. Subsequent calls with s as other
 | |
|     than a null pointer cause the internal conversion state of the function to be altered as necessary. It is
 | |
|     implementation-defined whether internal conversion state has thread storage duration, and whether
 | |
|     a newly created thread has the same state as the current thread at the time of creation, or the initial
 | |
|     conversion state. A call with s as a null pointer causes these functions to return a nonzero value if
 | |
|     encodings have state dependency, and zero otherwise.
 | |
|     Changing the LC_CTYPE category causes the internal object describing the conversion state of the
 | |
|     mbtowc and wctomb functions to have an indeterminate representation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.7.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.7.1 [The mblen function]</h3>
 | |
| <a name='7.24.7.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              int mblen(const char *s, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.7.1p2'></a>
 | |
| <pre>2   If s is not a null pointer, the mblen function determines the number of bytes contained in the
 | |
|     multibyte character pointed to by s. Except that the conversion state of the mbtowc function is not
 | |
|     affected, it is equivalent to
 | |
| 
 | |
|              mbtowc((wchar_t *)0, (const char *)0, 0);
 | |
|              mbtowc((wchar_t *)0, s, n);
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.7.1p3'></a>
 | |
| <pre>3   If s is a null pointer, the mblen function returns a nonzero or zero value, if multibyte character
 | |
|     encodings, respectively, do or do not have state-dependent encodings. If s is not a null pointer, the
 | |
|     mblen function either returns 0 (if s points to the null character), or returns the number of bytes
 | |
|     that are contained in the multibyte character (if the next n or fewer bytes form a valid multibyte
 | |
|     character), or returns-1 (if they do not form a valid multibyte character).
 | |
|     Forward references: the mbtowc function (<a href='#7.24.7.2'>7.24.7.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.7.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.7.2 [The mbtowc function]</h3>
 | |
| <a name='7.24.7.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              int mbtowc(wchar_t * restrict pwc, const char * restrict s, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.7.2p2'></a>
 | |
| <pre>2   If s is not a null pointer, the mbtowc function inspects at most n bytes beginning with the byte
 | |
|     pointed to by s to determine the number of bytes needed to complete the next multibyte character
 | |
|     (including any shift sequences). If the function determines that the next multibyte character is
 | |
|     complete and valid, it determines the value of the corresponding wide character and then, if pwc
 | |
|     is not a null pointer, stores that value in the object pointed to by pwc. If the corresponding wide
 | |
|     character is the null wide character, the function is left in the initial conversion state.
 | |
| </pre>
 | |
| <a name='7.24.7.2p3'></a>
 | |
| <pre>3   The implementation shall behave as if no library function calls the mbtowc function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.7.2p4'></a>
 | |
| <pre>4   If s is a null pointer, the mbtowc function returns a nonzero or zero value, if multibyte character
 | |
|     encodings, respectively, do or do not have state-dependent encodings. If s is not a null pointer, the
 | |
|     mbtowc function either returns 0 (if s points to the null character), or returns the number of bytes
 | |
|     that are contained in the converted multibyte character (if the next n or fewer bytes form a valid
 | |
|     multibyte character), or returns-1 (if they do not form a valid multibyte character).
 | |
| </pre>
 | |
| <a name='7.24.7.2p5'></a>
 | |
| <pre>5   In no case will the value returned be greater than n or the value of the MB_CUR_MAX macro.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.7.3'></a>
 | |
| <hr>
 | |
| <h3>7.24.7.3 [The wctomb function]</h3>
 | |
| <a name='7.24.7.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              int wctomb(char *s, wchar_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.7.3p2'></a>
 | |
| <pre>2   The wctomb function determines the number of bytes needed to represent the multibyte character
 | |
|     corresponding to the wide character given by wc (including any shift sequences), and stores the
 | |
|     multibyte character representation in the array whose first element is pointed to by s (if s is not a
 | |
|     null pointer). At most MB_CUR_MAX characters are stored. If wc is a null wide character, a null byte is
 | |
|     stored, preceded by any shift sequence needed to restore the initial shift state, and the function is
 | |
|     left in the initial conversion state.
 | |
| </pre>
 | |
| <a name='7.24.7.3p3'></a>
 | |
| <pre>3   The implementation shall behave as if no library function calls the wctomb function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.7.3p4'></a>
 | |
| <pre>4   If s is a null pointer, the wctomb function returns a nonzero or zero value, if multibyte character
 | |
|     encodings, respectively, do or do not have state-dependent encodings. If s is not a null pointer, the
 | |
|     wctomb function returns-1 if the value of wc does not correspond to a valid multibyte character, or
 | |
|     returns the number of bytes that are contained in the multibyte character corresponding to the value
 | |
|     of wc.
 | |
| </pre>
 | |
| <a name='7.24.7.3p5'></a>
 | |
| <pre>5   In no case will the value returned be greater than the value of the MB_CUR_MAX macro.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.8'></a>
 | |
| <hr>
 | |
| <h3>7.24.8 [Multibyte/wide string conversion functions]</h3>
 | |
| <a name='7.24.8p1'></a>
 | |
| <pre>1   The behavior of the multibyte string functions is affected by the LC_CTYPE category of the current
 | |
|     locale.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.24.8.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.8.1 [The mbstowcs function]</h3>
 | |
| <a name='7.24.8.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdlib.h>
 | |
|              size_t mbstowcs(wchar_t * restrict pwcs, const char * restrict s, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.8.1p2'></a>
 | |
| <pre>2   The mbstowcs function converts a sequence of multibyte characters that begins in the initial shift
 | |
|     state from the array pointed to by s into a sequence of corresponding wide characters and stores not
 | |
|     more than n wide characters into the array pointed to by pwcs. No multibyte characters that follow
 | |
|     a null character (which is converted into a null wide character) will be examined or converted. Each
 | |
|     multibyte character is converted as if by a call to the mbtowc function, except that the conversion
 | |
|     state of the mbtowc function is not affected.
 | |
| </pre>
 | |
| <a name='7.24.8.1p3'></a>
 | |
| <pre>3   No more than n elements will be modified in the array pointed to by pwcs. If copying takes place
 | |
|     between objects that overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.8.1p4'></a>
 | |
| <pre>4   If an invalid multibyte character is encountered, the mbstowcs function returns (size_t)(-1) .
 | |
|     Otherwise, the mbstowcs function returns the number of array elements modified, not including a
 | |
|     terminating null wide character, if any.<a href='#FOOTNOTE.371'><sup>[371]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.371'>
 | |
| <pre><i><b>Footnote 371)</b> The array will not be null-terminated if the value returned is n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.8.2'></a>
 | |
| <hr>
 | |
| <h3>7.24.8.2 [The wcstombs function]</h3>
 | |
| <a name='7.24.8.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               size_t wcstombs(char * restrict s, const wchar_t * restrict pwcs, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.8.2p2'></a>
 | |
| <pre>2   The wcstombs function converts a sequence of wide characters from the array pointed to by pwcs
 | |
|     into a sequence of corresponding multibyte characters that begins in the initial shift state, and stores
 | |
|     these multibyte characters into the array pointed to by s, stopping if a multibyte character would
 | |
|     exceed the limit of n total bytes or if a null character is stored. Each wide character is converted
 | |
|     as if by a call to the wctomb function, except that the conversion state of the wctomb function is not
 | |
|     affected.
 | |
| </pre>
 | |
| <a name='7.24.8.2p3'></a>
 | |
| <pre>3   No more than n bytes will be modified in the array pointed to by s. If copying takes place between
 | |
|     objects that overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.24.8.2p4'></a>
 | |
| <pre>4   If a wide character is encountered that does not correspond to a valid multibyte character, the
 | |
|     wcstombs function returns (size_t)(-1) . Otherwise, the wcstombs function returns the number
 | |
|     of bytes modified, not including a terminating null character, if any.<a href='#FOOTNOTE.371'><sup>[371]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.371'>
 | |
| <pre><i><b>Footnote 371)</b> The array will not be null-terminated if the value returned is n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.9'></a>
 | |
| <hr>
 | |
| <h3>7.24.9 [Alignment of memory]</h3>
 | |
| <a name='7.24.9.1'></a>
 | |
| <hr>
 | |
| <h3>7.24.9.1 [The memalignment function]</h3>
 | |
| <a name='7.24.9.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               size_t memalignment(const void * p);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.24.9.1p2'></a>
 | |
| <pre>2   The memalignment function accepts a pointer to any object and returns the maximum alignment
 | |
|     satisfied by its address value. The alignment may be an extended alignment and may also be beyond
 | |
|     the range supported by the implementation for explicit use by alignas<a href='#FOOTNOTE.372'><sup>[372]</sup></a> . If so, it will satisfy all
 | |
|     alignments usable by the implementation. The value returned can be compared to the result of
 | |
|     alignof, and if it is greater or equal, the alignment requirement for the type operand is satisfied.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.372'>
 | |
| <pre><i><b>Footnote 372)</b> The actual alignment of an object may be stricter than the alignment requested for an object by alignas or (implicitly) by
 | |
|     an allocation function, but will always satisfy it.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.24.9.1p3'></a>
 | |
| <pre>3   The alignment of the pointer p, which is a power of two. If p is a null pointer, an alignment of zero is
 | |
|     returned.
 | |
| </pre>
 | |
| <a name='7.24.9.1p4'></a>
 | |
| <pre>4   NOTE An alignment of zero indicates that the tested pointer cannot be used to access an object of any type.
 | |
| </pre>
 | |
| <a name='7.25'></a>
 | |
| <hr>
 | |
| <h3>7.25 [_Noreturn <stdnoreturn.h>]</h3>
 | |
| <a name='7.25p1'></a>
 | |
| <pre>1   The header <stdnoreturn.h> defines the macro
 | |
| 
 | |
|            noreturn
 | |
| 
 | |
| 
 | |
|     which expands to _Noreturn .
 | |
| </pre>
 | |
| <a name='7.25p2'></a>
 | |
| <pre>2   The noreturn macro and the <stdnoreturn.h> header are obsolescent features.
 | |
| </pre>
 | |
| <a name='7.26'></a>
 | |
| <hr>
 | |
| <h3>7.26 [String handling <string.h>]</h3>
 | |
| <a name='7.26.1'></a>
 | |
| <hr>
 | |
| <h3>7.26.1 [String function conventions]</h3>
 | |
| <a name='7.26.1p1'></a>
 | |
| <pre>1   The header <string.h> declares one type and several functions, and defines one macro useful
 | |
|     for manipulating arrays of character type and other objects treated as arrays of character type.<a href='#FOOTNOTE.373'><sup>[373]</sup></a>
 | |
|     The type is size_t and the macro is NULL (both described in <a href='#7.21'>7.21</a>). Various methods are used for
 | |
|     determining the lengths of the arrays, but in all cases a char * or void * argument points to the
 | |
|     initial (lowest addressed) character of the array. If an array is accessed beyond the end of an object,
 | |
|     the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.373'>
 | |
| <pre><i><b>Footnote 373)</b> See "future library directions" (<a href='#7.33.17'>7.33.17</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.1p2'></a>
 | |
| <pre>2   Where an argument declared as size_t n specifies the length of the array for a function, n can have
 | |
|     the value zero on a call to that function. Unless explicitly stated otherwise in the description of a
 | |
|     particular function in this subclause, pointer arguments on such a call shall still have valid values, as
 | |
|     described in <a href='#7.1.4'>7.1.4</a>. On such a call, a function that locates a character finds no occurrence, a function
 | |
|     that compares two character sequences returns zero, and a function that copies characters copies
 | |
|     zero characters.
 | |
| </pre>
 | |
| <a name='7.26.1p3'></a>
 | |
| <pre>3   For all functions in this subclause, each character shall be interpreted as if it had the type
 | |
|     unsigned char (and therefore every possible object representation is valid and has a different
 | |
|     value).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.2'></a>
 | |
| <hr>
 | |
| <h3>7.26.2 [Copying functions]</h3>
 | |
| <a name='7.26.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.26.2.1 [The memcpy function]</h3>
 | |
| <a name='7.26.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               void *memcpy(void * restrict s1, const void * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.2.1p2'></a>
 | |
| <pre>2   The memcpy function copies n characters from the object pointed to by s2 into the object pointed to
 | |
|     by s1. If copying takes place between objects that overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.2.1p3'></a>
 | |
| <pre>3   The memcpy function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.26.2.2 [The memccpy function]</h3>
 | |
| <a name='7.26.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               void *memccpy(void * restrict s1, const void * restrict s2, int c, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.2.2p2'></a>
 | |
| <pre>2   The memccpy function copies characters from the object pointed to by s2 into the object pointed to
 | |
|     by s1, stopping after the first occurrence of character c (converted to an unsigned char) is copied,
 | |
|     or after n characters are copied, whichever comes first. If copying takes place between objects that
 | |
|     overlap, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.2.2p3'></a>
 | |
| <pre>3   The memccpy function returns a pointer to the character after the copy of c in s1, or a null pointer if
 | |
|     c was not found in the first n characters of s2.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.2.3'></a>
 | |
| <hr>
 | |
| <h3>7.26.2.3 [The memmove function]</h3>
 | |
| <a name='7.26.2.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               void *memmove(void *s1, const void *s2, size_t n);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.2.3p2'></a>
 | |
| <pre>2   The memmove function copies n characters from the object pointed to by s2 into the object pointed to
 | |
|     by s1. Copying takes place as if the n characters from the object pointed to by s2 are first copied
 | |
|     into a temporary array of n characters that does not overlap the objects pointed to by s1 and s2, and
 | |
|     then the n characters from the temporary array are copied into the object pointed to by s1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.2.3p3'></a>
 | |
| <pre>3   The memmove function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.2.4'></a>
 | |
| <hr>
 | |
| <h3>7.26.2.4 [The strcpy function]</h3>
 | |
| <a name='7.26.2.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <string.h>
 | |
|                char *strcpy(char * restrict s1, const char * restrict s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.2.4p2'></a>
 | |
| <pre>2   The strcpy function copies the string pointed to by s2 (including the terminating null character)
 | |
|     into the array pointed to by s1. If copying takes place between objects that overlap, the behavior is
 | |
|     undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.2.4p3'></a>
 | |
| <pre>3   The strcpy function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.2.5'></a>
 | |
| <hr>
 | |
| <h3>7.26.2.5 [The strncpy function]</h3>
 | |
| <a name='7.26.2.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <string.h>
 | |
|                char *strncpy(char * restrict s1, const char * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.2.5p2'></a>
 | |
| <pre>2   The strncpy function copies not more than n characters (characters that follow a null character are
 | |
|     not copied) from the array pointed to by s2 to the array pointed to by s1.<a href='#FOOTNOTE.374'><sup>[374]</sup></a> If copying takes place
 | |
|     between objects that overlap, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.374'>
 | |
| <pre><i><b>Footnote 374)</b> Thus, if there is no null character in the first n characters of the array pointed to by s2, the result will not be null-
 | |
|     terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.2.5p3'></a>
 | |
| <pre>3   If the array pointed to by s2 is a string that is shorter than n characters, null characters are appended
 | |
|     to the copy in the array pointed to by s1, until n characters in all have been written.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.2.5p4'></a>
 | |
| <pre>4   The strncpy function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.2.6'></a>
 | |
| <hr>
 | |
| <h3>7.26.2.6 [The strdup function]</h3>
 | |
| <a name='7.26.2.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <string.h>
 | |
|                char *strdup(const char *s);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.2.6p2'></a>
 | |
| <pre>2   The strdup function creates a copy of the string pointed to by s in a space allocated as if by a call to
 | |
|     malloc.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.2.6p3'></a>
 | |
| <pre>3   The strdup function returns a pointer to the first character of the duplicate string. The returned
 | |
|     pointer can be passed to free. If no space can be allocated the strdup function returns a null pointer.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.2.7'></a>
 | |
| <hr>
 | |
| <h3>7.26.2.7 [The strndup function]</h3>
 | |
| <a name='7.26.2.7p1'></a>
 | |
| <pre>1     Synopsis
 | |
|               #include <string.h>
 | |
|                char *strndup(const char *s, size_t size);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.2.7p2'></a>
 | |
| <pre>2   The strndup function creates a string initialized with no more than size initial characters of the
 | |
|     array pointed to by s and up to the first null character, whichever comes first, in a space allocated
 | |
|     as if by a call to malloc. If the array pointed to by s does not contain a null within the first size
 | |
|     characters, a null is appended to the copy of the array.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.2.7p3'></a>
 | |
| <pre>3   The strndup function returns a pointer to the first character of the created string. The returned
 | |
|     pointer can be passed to free. If space cannot be allocated the strndup function returns a null
 | |
|     pointer.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.3'></a>
 | |
| <hr>
 | |
| <h3>7.26.3 [Concatenation functions]</h3>
 | |
| <a name='7.26.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.26.3.1 [The strcat function]</h3>
 | |
| <a name='7.26.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <string.h>
 | |
|                char *strcat(char * restrict s1, const char * restrict s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.3.1p2'></a>
 | |
| <pre>2   The strcat function appends a copy of the string pointed to by s2 (including the terminating null
 | |
|     character) to the end of the string pointed to by s1. The initial character of s2 overwrites the null
 | |
|     character at the end of s1. If copying takes place between objects that overlap, the behavior is
 | |
|     undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.3.1p3'></a>
 | |
| <pre>3   The strcat function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.26.3.2 [The strncat function]</h3>
 | |
| <a name='7.26.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <string.h>
 | |
|                char *strncat(char * restrict s1, const char * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.3.2p2'></a>
 | |
| <pre>2   The strncat function appends not more than n characters (a null character and characters that
 | |
|     follow it are not appended) from the array pointed to by s2 to the end of the string pointed to by
 | |
|     s1. The initial character of s2 overwrites the null character at the end of s1. A terminating null
 | |
|     character is always appended to the result.<a href='#FOOTNOTE.375'><sup>[375]</sup></a> If copying takes place between objects that overlap,
 | |
|     the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.375'>
 | |
| <pre><i><b>Footnote 375)</b> Thus, the maximum number of characters that can end up in the array pointed to by s1 is strlen(s1)+n+1.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.3.2p3'></a>
 | |
| <pre>3   The strncat function returns the value of s1.
 | |
|     Forward references: the strlen function (<a href='#7.26.6.4'>7.26.6.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.4'></a>
 | |
| <hr>
 | |
| <h3>7.26.4 [Comparison functions]</h3>
 | |
| <a name='7.26.4p1'></a>
 | |
| <pre>1   The sign of a nonzero value returned by the comparison functions memcmp, strcmp, and strncmp
 | |
|     is determined by the sign of the difference between the values of the first pair of characters (both
 | |
|     interpreted as unsigned char) that differ in the objects being compared.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.26.4.1 [The memcmp function]</h3>
 | |
| <a name='7.26.4.1p1'></a>
 | |
| <pre>1     Synopsis
 | |
|              #include <string.h>
 | |
|               int memcmp(const void *s1, const void *s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.4.1p2'></a>
 | |
| <pre>2   The memcmp function compares the first n characters of the object pointed to by s1 to the first n
 | |
|     characters of the object pointed to by s2376) .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.4.1p3'></a>
 | |
| <pre>3   The memcmp function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     object pointed to by s1 is greater than, equal to, or less than the object pointed to by s2.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.26.4.2 [The strcmp function]</h3>
 | |
| <a name='7.26.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               int strcmp(const char *s1, const char *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.4.2p2'></a>
 | |
| <pre>2   The strcmp function compares the string pointed to by s1 to the string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.4.2p3'></a>
 | |
| <pre>3   The strcmp function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     string pointed to by s1 is greater than, equal to, or less than the string pointed to by s2.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.26.4.3 [The strcoll function]</h3>
 | |
| <a name='7.26.4.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               int strcoll(const char *s1, const char *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.4.3p2'></a>
 | |
| <pre>2   The strcoll function compares the string pointed to by s1 to the string pointed to by s2, both
 | |
|     interpreted as appropriate to the LC_COLLATE category of the current locale.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.4.3p3'></a>
 | |
| <pre>3   The strcoll function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     string pointed to by s1 is greater than, equal to, or less than the string pointed to by s2 when both
 | |
|     are interpreted as appropriate to the current locale.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.26.4.4 [The strncmp function]</h3>
 | |
| <a name='7.26.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               int strncmp(const char *s1, const char *s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.4.4p2'></a>
 | |
| <pre>2   The strncmp function compares not more than n characters (characters that follow a null character
 | |
|     are not compared) from the array pointed to by s1 to the array pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.4.4p3'></a>
 | |
| <pre>3   The strncmp function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     possibly null-terminated array pointed to by s1 is greater than, equal to, or less than the possibly
 | |
|     null-terminated array pointed to by s2.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.4.5'></a>
 | |
| <hr>
 | |
| <h3>7.26.4.5 [The strxfrm function]</h3>
 | |
| <a name='7.26.4.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               size_t strxfrm(char * restrict s1, const char * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.4.5p2'></a>
 | |
| <pre>2   The strxfrm function transforms the string pointed to by s2 and places the resulting string into
 | |
|     the array pointed to by s1. The transformation is such that if the strcmp function is applied to two
 | |
|     transformed strings, it returns a value greater than, equal to, or less than zero, corresponding to the
 | |
|     result of the strcoll function applied to the same two original strings. No more than n characters
 | |
|     are placed into the resulting array pointed to by s1, including the terminating null character. If n is
 | |
|     zero, s1 is permitted to be a null pointer. If copying takes place between objects that overlap, the
 | |
|     behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.4.5p3'></a>
 | |
| <pre>3   The strxfrm function returns the length of the transformed string (not including the terminating
 | |
|     null character). If the value returned is n or more, the members of the array pointed to by s1 have
 | |
|     an indeterminate representation.
 | |
| </pre>
 | |
| <a name='7.26.4.5p4'></a>
 | |
| <pre>4   EXAMPLE The value of the following expression is the size of the array needed to hold the transformation of the string
 | |
|     pointed to by s.
 | |
| 
 | |
|               1 + strxfrm(NULL, s, 0)
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5'></a>
 | |
| <hr>
 | |
| <h3>7.26.5 [Search functions]</h3>
 | |
| <a name='7.26.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.1 [Introduction]</h3>
 | |
| <a name='7.26.5.1p1'></a>
 | |
| <pre>1   The stateless search functions in this section (memchr, strchr, strpbrk, strrchr, strstr) are
 | |
|     generic functions. These functions are generic in the qualification of the array to be searched and
 | |
|     will return a result pointer to an element with the same qualification as the passed array. If the array
 | |
|     to be searched is const- qualified, the result pointer will be to a const-qualified element. If the array
 | |
|     to be searched is not const-qualified<a href='#FOOTNOTE.377'><sup>[377]</sup></a> , the result pointer will be to an unqualified element.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.377'>
 | |
| <pre><i><b>Footnote 377)</b> The null pointer constant is not a pointer to a const-qualified type, and therefore the result expression has the type of a
 | |
|     pointer to an unqualified element; however, evaluating such a call is undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.5.1p2'></a>
 | |
| <pre>2   The external declarations of these generic functions have a concrete function type that returns a
 | |
|     pointer to an unqualified element (of type char when specified as QChar, and void when specified
 | |
|     as QVoid), and accepts a pointer to a const-qualified array of the same type to search. This signature
 | |
|     supports all correct uses. If a macro definition of any of these generic functions is suppressed in
 | |
|     order to access an actual function, the external declaration with the corresponding concrete type is
 | |
|     visible<a href='#FOOTNOTE.378'><sup>[378]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.378'>
 | |
| <pre><i><b>Footnote 378)</b> This is an obsolescent feature.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.5.1p3'></a>
 | |
| <pre>3   The volatile and restrict qualifiers are not accepted on the elements of the array to search.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.2'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.2 [The memchr generic function]</h3>
 | |
| <a name='7.26.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               QVoid *memchr(QVoid *s, int c, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.2p2'></a>
 | |
| <pre>2   The memchr generic function locates the first occurrence of c (converted to an unsigned char)
 | |
|     in the initial n characters (each interpreted as unsigned char) of the object pointed to by s. The
 | |
|     implementation shall behave as if it reads the characters sequentially and stops as soon as a matching
 | |
|     character is found.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.5.2p3'></a>
 | |
| <pre>3   The memchr generic function returns a pointer to the located character, or a null pointer if the
 | |
|     character does not occur in the object.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.3'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.3 [The strchr generic function]</h3>
 | |
| <a name='7.26.5.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             QChar *strchr(QChar *s, int c);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.3p2'></a>
 | |
| <pre>2   The strchr generic function locates the first occurrence of c (converted to a char) in the string
 | |
|     pointed to by s. The terminating null character is considered to be part of the string.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.5.3p3'></a>
 | |
| <pre>3   The strchr generic function returns a pointer to the located character, or a null pointer if the
 | |
|     character does not occur in the string.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.4'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.4 [The strcspn function]</h3>
 | |
| <a name='7.26.5.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             size_t strcspn(const char *s1, const char *s2);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.4p2'></a>
 | |
| <pre>2   The strcspn function computes the length of the maximum initial segment of the string pointed to
 | |
|     by s1 which consists entirely of characters not from the string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.5.4p3'></a>
 | |
| <pre>3   The strcspn function returns the length of the segment.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.5'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.5 [The strpbrk generic function]</h3>
 | |
| <a name='7.26.5.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             QChar *strpbrk(QChar *s1, const char *s2);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.5p2'></a>
 | |
| <pre>2   The strpbrk generic function locates the first occurrence in the string pointed to by s1 of any
 | |
|     character from the string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.5.5p3'></a>
 | |
| <pre>3   The
 | |
|     tcodestrpbrk generic function returns a pointer to the character, or a null pointer if no character from
 | |
|     s2 occurs in s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.6'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.6 [The strrchr generic function]</h3>
 | |
| <a name='7.26.5.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             QChar *strrchr(QChar *s, int c);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.6p2'></a>
 | |
| <pre>2   The strrchr generic function locates the last occurrence of c (converted to a char) in the string
 | |
|     pointed to by s. The terminating null character is considered to be part of the string.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.5.6p3'></a>
 | |
| <pre>3   The strrchr generic function returns a pointer to the character, or a null pointer if c does not occur
 | |
|     in the string.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.7'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.7 [The strspn function]</h3>
 | |
| <a name='7.26.5.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             size_t strspn(const char *s1, const char *s2);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.7p2'></a>
 | |
| <pre>2   The strspn function computes the length of the maximum initial segment of the string pointed to
 | |
|     by s1 which consists entirely of characters from the string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.5.7p3'></a>
 | |
| <pre>3   The strspn function returns the length of the segment.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.8'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.8 [The strstr generic function]</h3>
 | |
| <a name='7.26.5.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             QChar *strstr(QChar *s1, const char *s2);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.8p2'></a>
 | |
| <pre>2   The strstr generic function locates the first occurrence in the string pointed to by s1 of the sequence
 | |
|     of characters (excluding the terminating null character) in the string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.5.8p3'></a>
 | |
| <pre>3   The strstr generic function returns a pointer to the located string, or a null pointer if the string is
 | |
|     not found. If s2 points to a string with zero length, the function returns s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.5.9'></a>
 | |
| <hr>
 | |
| <h3>7.26.5.9 [The strtok function]</h3>
 | |
| <a name='7.26.5.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             char *strtok(char * restrict s1, const char * restrict s2);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.5.9p2'></a>
 | |
| <pre>2   A sequence of calls to the strtok function breaks the string pointed to by s1 into a sequence of
 | |
|     tokens, each of which is delimited by a character from the string pointed to by s2. The first call
 | |
|     in the sequence has a non-null first argument; subsequent calls in the sequence have a null first
 | |
|     argument. If any of the subsequent calls in the sequence is made by a different thread than the first,
 | |
|     the behavior is undefined. The separator string pointed to by s2 may be different from call to call.
 | |
| </pre>
 | |
| <a name='7.26.5.9p3'></a>
 | |
| <pre>3   The first call in the sequence searches the string pointed to by s1 for the first character that is not
 | |
|     contained in the current separator string pointed to by s2. If no such character is found, then there
 | |
|     are no tokens in the string pointed to by s1 and the strtok function returns a null pointer. If such a
 | |
|     character is found, it is the start of the first token.
 | |
| </pre>
 | |
| <a name='7.26.5.9p4'></a>
 | |
| <pre>4   The strtok function then searches from there for a character that is contained in the current separator
 | |
|     string. If no such character is found, the current token extends to the end of the string pointed to by
 | |
|     s1, and subsequent searches for a token will return a null pointer. If such a character is found, it is
 | |
|     overwritten by a null character, which terminates the current token. The strtok function saves a
 | |
|     pointer to the following character, from which the next search for a token will start.
 | |
| </pre>
 | |
| <a name='7.26.5.9p5'></a>
 | |
| <pre>5   Each subsequent call, with a null pointer as the value of the first argument, starts searching from the
 | |
|     saved pointer and behaves as described above.
 | |
| </pre>
 | |
| <a name='7.26.5.9p6'></a>
 | |
| <pre>6   The strtok function is not required to avoid data races with other calls to the strtok function.<a href='#FOOTNOTE.379'><sup>[379]</sup></a>
 | |
|     The implementation shall behave as if no library function calls the strtok function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.379'>
 | |
| <pre><i><b>Footnote 379)</b> The strtok_s function can be used instead to avoid data races.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.5.9p7'></a>
 | |
| <pre>7   The strtok function returns a pointer to the first character of a token, or a null pointer if there is no
 | |
|     token.
 | |
| </pre>
 | |
| <a name='7.26.5.9p8'></a>
 | |
| <pre>8   EXAMPLE
 | |
| 
 | |
|               #include <string.h>
 | |
|               static char str[] = "?a???b,,,#c";
 | |
|               char *t;
 | |
| 
 | |
|               t = strtok(str, "?");   // t points to the token "a"
 | |
|               t = strtok(NULL, ","); // t points to the token "??b"
 | |
|               t = strtok(NULL, "#,"); // t points to the token "c"
 | |
|               t = strtok(NULL, "?"); // t is a null pointer
 | |
| 
 | |
| 
 | |
|     Forward references: The strtok_s function (<a href='#K.3.7.3.1'>K.3.7.3.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.6'></a>
 | |
| <hr>
 | |
| <h3>7.26.6 [Miscellaneous functions]</h3>
 | |
| <a name='7.26.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.26.6.1 [The memset function]</h3>
 | |
| <a name='7.26.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               void *memset(void *s, int c, size_t n);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.6.1p2'></a>
 | |
| <pre>2   The memset function copies the value of c (converted to an unsigned char) into each of the first n
 | |
|     characters of the object pointed to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.6.1p3'></a>
 | |
| <pre>3   The memset function returns the value of s.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.26.6.2 [The memset_explicit function]</h3>
 | |
| <a name='7.26.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               void *memset_explicit(void *s, int c, size_t n);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.6.2p2'></a>
 | |
| <pre>2   The memset_explicit function copies the value of c (converted to an unsigned char) into each of
 | |
|     the first n characters of the object pointed to by s. The purpose of this function is to make sensitive
 | |
|     information stored in the object inaccessible<a href='#FOOTNOTE.380'><sup>[380]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.380'>
 | |
| <pre><i><b>Footnote 380)</b> The intention is that the memory store is always performed (i.e., never elided), regardless of optimizations. This is in
 | |
|     contrast to calls to the memset function (<a href='#7.26.6.1'>7.26.6.1</a>)
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.6.2p3'></a>
 | |
| <pre>3   The memset_explicit function returns the value of s.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.26.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.26.6.3 [The strerror function]</h3>
 | |
| <a name='7.26.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <string.h>
 | |
|               char *strerror(int errnum);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.6.3p2'></a>
 | |
| <pre>2   The strerror function maps the number in errnum to a message string. Typically, the values for
 | |
|     errnum come from errno, but strerror shall map any value of type int to a message.
 | |
| </pre>
 | |
| <a name='7.26.6.3p3'></a>
 | |
| <pre>3   The strerror function is not required to avoid data races with other calls to the strerror func-
 | |
|     tion.<a href='#FOOTNOTE.381'><sup>[381]</sup></a> The implementation shall behave as if no library function calls the strerror function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.381'>
 | |
| <pre><i><b>Footnote 381)</b> The strerror_s function can be used instead to avoid data races.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.26.6.3p4'></a>
 | |
| <pre>4   The strerror function returns a pointer to the string, the contents of which are locale-specific. The
 | |
|     array pointed to shall not be modified by the program. The behavior is undefined if the returned
 | |
|     value is used after a subsequent call to the strerror function, or after the thread which called the
 | |
|     function to obtain the returned value has exited.
 | |
|     Forward references: The strerror_s function (<a href='#K.3.7.4.2'>K.3.7.4.2</a>).
 | |
| </pre>
 | |
| <a name='7.26.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.26.6.4 [The strlen function]</h3>
 | |
| <a name='7.26.6.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <string.h>
 | |
|             size_t strlen(const char *s);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.26.6.4p2'></a>
 | |
| <pre>2   The strlen function computes the length of the string pointed to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.26.6.4p3'></a>
 | |
| <pre>3   The strlen function returns the number of characters that precede the terminating null character.
 | |
| </pre>
 | |
| <a name='7.27'></a>
 | |
| <hr>
 | |
| <h3>7.27 [Type-generic math <tgmath.h>]</h3>
 | |
| <a name='7.27p1'></a>
 | |
| <pre>1   The header <tgmath.h> includes the headers <math.h> and <complex.h> and defines several
 | |
|     type-generic macros.
 | |
| </pre>
 | |
| <a name='7.27p2'></a>
 | |
| <pre>2   The feature test macro __STDC_VERSION_TGMATH_H__ expands to the token 202311L.
 | |
| </pre>
 | |
| <a name='7.27p3'></a>
 | |
| <pre>3   This clause specifies a many-to-one correspondence of functions in <math.h> and <complex.h> with
 | |
|     type-generic macros.<a href='#FOOTNOTE.382'><sup>[382]</sup></a> Use of a type-generic macro invokes a corresponding function whose type is
 | |
|     determined by the types of the arguments for particular parameters called the generic parameters.<a href='#FOOTNOTE.383'><sup>[383]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.382'>
 | |
| <pre><i><b>Footnote 382)</b> Like other function-like macros in standard libraries, each type-generic macro can be suppressed to make available the
 | |
|     corresponding ordinary function.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.383'>
 | |
| <pre><i><b>Footnote 383)</b> If the type of the argument is not compatible with the type of the parameter for the selected function, the behavior is
 | |
|     undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.27p4'></a>
 | |
| <pre>4   Of the <math.h> and <complex.h> functions without an f (float) or l (long double) suffix, several
 | |
|     have one or more parameters whose corresponding real type is double. For each such function,
 | |
|     except the functions that round result to narrower type (<a href='#7.12.14'>7.12.14</a>) (which are covered below) and
 | |
|     modf,
 | |
|     there is a corresponding type-generic macro. The parameters whose corresponding real type is
 | |
|     double in the function synopsis are generic parameters.
 | |
| </pre>
 | |
| <a name='7.27p5'></a>
 | |
| <pre>5   Some of the <math.h> functions for decimal floating types have no unsuffixed counterpart. Of these
 | |
|     functions with a d64 suffix, some have one or more parameters whose type is _Decimal64 . For each
 | |
|     such function, except decodedecd64, encodedecd64, decodebind64, and encodebind64, there is a
 | |
|     corresponding type-generic macro. The parameters whose real type is _Decimal64 in the function
 | |
|     synopsis are generic parameters.
 | |
| </pre>
 | |
| <a name='7.27p6'></a>
 | |
| <pre>6   If arguments for generic parameters of a type-generic macro are such that some argument has a
 | |
|     corresponding real type that is of standard floating type and another argument is of decimal floating
 | |
|     type, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.27p7'></a>
 | |
| <pre>7   Except for the macros for functions that round result to a narrower type (<a href='#7.12.14'>7.12.14</a>), use of a type-
 | |
|     generic macro invokes a function whose generic parameters have the corresponding real type
 | |
|     determined by the types of the arguments for the generic parameters as follows:
 | |
| 
 | |
| 
 | |
|       — Arguments of integer type are regarded as having type _Decimal64 if any argument has
 | |
|         decimal floating type, and as having type double otherwise.
 | |
| 
 | |
|       — If the function has exactly one generic parameter, the type determined is the corresponding
 | |
|         real type of the argument for the generic parameter.
 | |
| 
 | |
|       — If the function has exactly two generic parameters, the type determined is the corresponding
 | |
|         real type determined by the usual arithmetic conversions (<a href='#6.3.1.8'>6.3.1.8</a>) applied to the arguments for
 | |
|         the generic parameters.
 | |
| 
 | |
|       — If the function has more than two generic parameters, the type determined is the corresponding
 | |
|         real type determined by repeatedly applying the usual arithmetic conversions, first to the first
 | |
|         two arguments for generic parameters, then to that result type and the next argument for a
 | |
|         generic parameter, and so forth until the usual arithmetic conversions have been applied to
 | |
|         the last argument for a generic parameter.
 | |
| 
 | |
| 
 | |
|     If neither <math.h> and <complex.h> define a function whose generic parameters have the deter-
 | |
|     mined corresponding real type, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.27p8'></a>
 | |
| <pre>8   For each unsuffixed function in <math.h> for which there is a function in <complex.h> with the
 | |
|     same name except for a c prefix, the corresponding type-generic macro (for both functions) has the
 | |
|     same name as the function in <math.h>. The corresponding type-generic macro for fabs and cabs
 | |
|     is fabs.
 | |
|             <math.h>    <complex.h>     type-generic
 | |
|             function    function        macro
 | |
|             acos        cacos           acos
 | |
|             asin        casin           asin
 | |
|             atan        catan           atan
 | |
|             acosh       cacosh          acosh
 | |
|             asinh       casinh          asinh
 | |
|             atanh       catanh          atanh
 | |
|             cos         ccos            cos
 | |
|             sin         csin            sin
 | |
|             tan         ctan            tan
 | |
|             cosh        ccosh           cosh
 | |
|             sinh        csinh           sinh
 | |
|             tanh        ctanh           tanh
 | |
|             exp         cexp            exp
 | |
|             log         clog            log
 | |
|             pow         cpow            pow
 | |
|             sqrt        csqrt           sqrt
 | |
|             fabs        cabs            fabs
 | |
|      If at least one argument for a generic parameter is complex, then use of the macro invokes a complex
 | |
|      function; otherwise, use of the macro invokes a real function.
 | |
| </pre>
 | |
| <a name='7.27p9'></a>
 | |
| <pre>9    For each unsuffixed function in <math.h> without a c-prefixed counterpart in <complex.h> (except
 | |
|      functions that round result to narrower type, modf, and canonicalize), the corresponding type-
 | |
|      generic macro has the same name as the function. These type-generic macros are:
 | |
| 
 | |
|      acospi              exp2             fmod                    log2                rootn
 | |
|      asinpi              expm1            frexp                   logb                roundeven
 | |
|      atan2pi             fdim             fromfpx                 logp1               round
 | |
|      atan2               floor            fromfp                  lrint               rsqrt
 | |
|      atanpi              fmax             hypot                   lround              scalbln
 | |
|      cbrt                fmaximum         ilogb                   nearbyint           scalbn
 | |
|      ceil                fmaximum_mag     ldexp                   nextafter           sinpi
 | |
|      compoundn           fmaximum_num     lgamma                  nextdown            tanpi
 | |
|      copysign            fmaximum_mag_num llogb                   nexttoward          tgamma
 | |
|      cospi               fma              llrint                  nextup              trunc
 | |
|      erfc                fmin             llround                 pown                ufromfpx
 | |
|      erf                 fminimum         log10p1                 powr                ufromfp
 | |
|      exp10m1             fminimum_mag     log10                   remainder
 | |
|      exp10               fminimum_num     log1p                   remquo
 | |
|      exp2m1              fminimum_mag_num log2p1                  rint
 | |
| 
 | |
| 
 | |
|      If all arguments for generic parameters are real, then use of the macro invokes a real function
 | |
|      (provided <math.h> defines a function of the determined type); otherwise, use of the macro is
 | |
|      undefined.
 | |
| </pre>
 | |
| <a name='7.27p10'></a>
 | |
| <pre>10   For each unsuffixed function in <complex.h> that is not a c-prefixed counterpart to a function
 | |
|      in <math.h>, the corresponding type-generic macro has the same name as the function. These
 | |
|      type-generic macros are:
 | |
| 
 | |
|      carg              cimag           conj             cproj            creal
 | |
| 
 | |
| 
 | |
|      Use of the macro with any argument of standard floating or complex type invokes a complex
 | |
|      function. Use of the macro with an argument of decimal floating type is undefined.
 | |
| </pre>
 | |
| <a name='7.27p11'></a>
 | |
| <pre>11   The functions that round result to a narrower type have type-generic macros whose names are
 | |
|      obtained by omitting any suffix from the function names. Thus, the macros with f or d prefix are:
 | |
|      fadd               fsub                fmul                fdiv                ffma                fsqrt
 | |
|      dadd               dsub                dmul                ddiv                dfma                dsqrt
 | |
| 
 | |
| 
 | |
|      and the macros with d32 or d64 prefix are:
 | |
| 
 | |
|      d32add             d32sub              d32mul              d32div              d32fma              d32sqrt
 | |
|      d64add             d64sub              d64mul              d64div              d64fma              d64sqrt
 | |
| 
 | |
| 
 | |
|      All arguments shall be real. If the macro prefix is f or d, use of an argument of decimal floating
 | |
|      type is undefined. If the macro prefix is d32 or d64, use of an argument of standard floating type is
 | |
|      undefined. The function invoked is determined as follows:
 | |
| 
 | |
|        — If any argument has type _Decimal128 , or if the macro prefix is d64, the function invoked has
 | |
|          the name of the macro, with a d128 suffix.
 | |
|        — Otherwise, if the macro prefix is d32, the function invoked has the name of the macro, with a
 | |
|          d64 suffix.
 | |
| 
 | |
|        — Otherwise, if any argument has type long double, or if the macro prefix is d, the function
 | |
|          invoked has the name of the macro, with an l suffix.
 | |
|        — Otherwise, the function invoked has the name of the macro (with no suffix).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.27p12'></a>
 | |
| <pre>12   For each d64-suffixed function in <math.h>, except decodedecd64, encodedecd64, decodebind64,
 | |
|      and encodebind64, that does not have an unsuffixed counterpart, the corresponding type-generic
 | |
|      macro has the name of the function, but without the suffix. These type-generic macros are:
 | |
|             <math.h>              type-generic
 | |
|             function              macro
 | |
|             quantizedN            quantize
 | |
|             samequantumdN         samequantum
 | |
|             quantumdN             quantum
 | |
|             llquantexpdN          llquantexp
 | |
|      Use of the macro with an argument of standard floating or complex type or with only integer type
 | |
|      arguments is undefined.
 | |
| </pre>
 | |
| <a name='7.27p13'></a>
 | |
| <pre>13   A type-generic macro corresponding to a function indicated in the table in <a href='#7.6.2'>7.6.2</a> is affected by
 | |
|      constant rounding modes (<a href='#7.6.4'>7.6.4</a>).
 | |
| </pre>
 | |
| <a name='7.27p14'></a>
 | |
| <pre>14   NOTE The type-generic macro definition in the example in <a href='#6.5.1.1'>6.5.1.1</a> does not conform to this specification. A conforming
 | |
|      macro could be implemented as follows:
 | |
| 
 | |
|       #define cbrt(X)                       \
 | |
|           _Generic((X),                     \
 | |
|              long double: _Roundwise_cbrtl, \
 | |
|              default:     _Roundwise_cbrt, \
 | |
|              float:       _Roundwise_cbrtf \
 | |
|           )(X)
 | |
| 
 | |
|      where where _Roundwise_cbrtl , _Roundwise_cbrt , and _Roundwise_cbrtf are pointers to functions that are equivalent
 | |
|      to cbrtl, cbrt, and cbrtf, respectively, but that are guaranteed to be affected by constant rounding modes (<a href='#7.6.2'>7.6.2</a>).
 | |
| </pre>
 | |
| <a name='7.27p15'></a>
 | |
| <pre>15   EXAMPLE With the declarations
 | |
| 
 | |
|                #include <tgmath.h>
 | |
|                int n;
 | |
|                float f;
 | |
|                double d;
 | |
|                long double ld;
 | |
|                float complex fc;
 | |
|                double complex dc;
 | |
|                long double complex ldc;
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 d32;
 | |
|                _Decimal64 d64;
 | |
|                _Decimal128 d128;
 | |
|                #endif
 | |
| 
 | |
|      functions invoked by use of type-generic macros are shown in the following table:
 | |
| 
 | |
| 
 | |
| 
 | |
|             macro use                     invocation
 | |
|             exp(n)                        exp(n) , the function
 | |
|             acosh(f)                      acoshf(f)
 | |
|             sin(d)                        sin(d) , the function
 | |
|             atan(ld)                      atanl(ld)
 | |
|             log(fc)                       clogf(fc)
 | |
|             sqrt(dc)                      csqrt(dc)
 | |
|             pow(ldc, f)                   cpowl(ldc, f)
 | |
|             remainder(n, n)               remainder(n, n) , the function
 | |
|             nextafter(d, f)               nextafter(d, f) , the function
 | |
|             nexttoward(f, ld)             nexttowardf(f, ld)
 | |
|             copysign(n, ld)               copysignl(n, ld)
 | |
|             ceil(fc)                      undefined
 | |
|             rint(dc)                      undefined
 | |
|             fmaximum(ldc, ld)             undefined
 | |
|             carg(n)                       carg(n) , the function
 | |
|             cproj(f)                      cprojf(f)
 | |
|             creal(d)                      creal(d) , the function
 | |
|             cimag(ld)                     cimagl(ld)
 | |
|             fabs(fc)                      cabsf(fc)
 | |
|             carg(dc)                      carg(dc) , the function
 | |
|             cproj(ldc)                    cprojl(ldc)
 | |
|             fsub(f, ld)                   fsubl(f, ld)
 | |
|             fdiv(d, n)                    fdiv(d, n) , the function
 | |
|             dfma(f, d, ld)                dfmal(f, d, ld)
 | |
|             dadd(f, f)                    daddl(f, f)
 | |
|             dsqrt(dc)                     undefined
 | |
|             exp(d64)                      expd64(d64)
 | |
|             sqrt(d32)                     sqrtd32(d32)
 | |
|             fmaximum(d64, d128)           fmaximumd128(d64, d128)
 | |
|             pow(d32, n)                   powd64(d32, n)
 | |
|             remainder(d64, d)             undefined
 | |
|             creal(d64)                    undefined
 | |
|             remquo(d32, d32, &n)          undefined
 | |
|             llquantexp(d)                 undefined
 | |
|             quantize(dc)                  undefined
 | |
|             samequantum(n, n)             undefined
 | |
|             d32sub(d32, d128)             d32subd128(d32, d128)
 | |
|             d32div(d64, n)                d32divd64(d64, n)
 | |
|             d64fma(d32, d64, d128)        d64fmad128(d32, d64, d128)
 | |
|             d64add(d32, d32)              d64addd128(d32, d32)
 | |
|             d64sqrt(d)                    undefined
 | |
|             dadd(n, d64)                  undefined
 | |
| 
 | |
| 
 | |
| 
 | |
|      acospi
 | |
|      asinpi
 | |
|      atan2pi
 | |
| atan2
 | |
| atanpi
 | |
| cbrt
 | |
| ceil
 | |
| compoundn
 | |
| copysign
 | |
| cospi
 | |
| erfc
 | |
| erf
 | |
| exp10m1
 | |
| exp10
 | |
| exp2m1
 | |
| exp2
 | |
| expm1
 | |
| fdim
 | |
| floor
 | |
| fmax
 | |
| fmaximum
 | |
| fmaximum_mag
 | |
| fmaximum_num
 | |
| fmaximum_mag_num
 | |
| fma
 | |
| fmin
 | |
| fminimum
 | |
| fminimum_mag
 | |
| fminimum_num
 | |
| fminimum_mag_num
 | |
| fmod
 | |
| frexp
 | |
| fromfpx
 | |
| fromfp
 | |
| hypot
 | |
| ilogb
 | |
| ldexp
 | |
| lgamma
 | |
| llogb
 | |
| llrint
 | |
| llround
 | |
| log10p1
 | |
| log10
 | |
| log1p
 | |
| log2p1
 | |
| log2
 | |
| logb
 | |
| logp1
 | |
| lrint
 | |
| lround
 | |
| nearbyint
 | |
| nextafter
 | |
| nextdown
 | |
| nexttoward
 | |
| nextup
 | |
| pown
 | |
| powr
 | |
| remainder
 | |
| remquo
 | |
| rint
 | |
| rootn
 | |
| roundeven
 | |
| round
 | |
| rsqrt
 | |
| scalbln
 | |
| scalbn
 | |
| sinpi
 | |
| tanpi
 | |
| tgamma
 | |
| trunc
 | |
| ufromfpx
 | |
| ufromfp carg
 | |
| cimag
 | |
| conj
 | |
| cproj
 | |
| creal d32add
 | |
| d64add
 | |
| d32sub
 | |
| d64sub
 | |
| d32mul
 | |
| d64mul
 | |
| d32div
 | |
| d64div
 | |
| d32fma
 | |
| d64fma
 | |
| d32sqrt
 | |
| d64sqrt fadd
 | |
| dadd
 | |
| fsub
 | |
| dsub
 | |
| fmul
 | |
| dmul
 | |
| fdiv
 | |
| ddiv
 | |
| ffma
 | |
| dfma
 | |
| fsqrt
 | |
| dsqrt
 | |
| </pre>
 | |
| <a name='7.28'></a>
 | |
| <hr>
 | |
| <h3>7.28 [Threads <threads.h>]</h3>
 | |
| <a name='7.28.1'></a>
 | |
| <hr>
 | |
| <h3>7.28.1 [Introduction]</h3>
 | |
| <a name='7.28.1p1'></a>
 | |
| <pre>1   The header <threads.h> includes the header <time.h>, defines macros, and declares types, enu-
 | |
|     meration constants, and functions that support multiple threads of execution<a href='#FOOTNOTE.384'><sup>[384]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.384'>
 | |
| <pre><i><b>Footnote 384)</b> See "future library directions" (<a href='#7.33.19'>7.33.19</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.28.1p2'></a>
 | |
| <pre>2   Implementations that define the macro __STDC_NO_THREADS__ need not provide this header nor
 | |
|     support any of its facilities.
 | |
| </pre>
 | |
| <a name='7.28.1p3'></a>
 | |
| <pre>3   The macros are
 | |
| 
 | |
|               ONCE_FLAG_INIT
 | |
| 
 | |
| 
 | |
|     which expands to a value that can be used to initialize an object of type once_flag; and
 | |
| 
 | |
|               TSS_DTOR_ITERATIONS
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression representing the maximum number of times that
 | |
|     destructors will be called when a thread terminates.
 | |
| </pre>
 | |
| <a name='7.28.1p4'></a>
 | |
| <pre>4   The types are
 | |
| 
 | |
|               cnd_t
 | |
| 
 | |
| 
 | |
|     which is a complete object type that holds an identifier for a condition variable;
 | |
| 
 | |
|               thrd_t
 | |
| 
 | |
| 
 | |
|     which is a complete object type that holds an identifier for a thread;
 | |
| 
 | |
|               tss_t
 | |
| 
 | |
| 
 | |
|     which is a complete object type that holds an identifier for a thread-specific storage pointer;
 | |
| 
 | |
|               mtx_t
 | |
| 
 | |
| 
 | |
|     which is a complete object type that holds an identifier for a mutex;
 | |
| 
 | |
|               tss_dtor_t
 | |
| 
 | |
| 
 | |
|     which is the function pointer type void (*)(void*), used for a destructor for a thread-specific
 | |
|     storage pointer;
 | |
| 
 | |
|               thrd_start_t
 | |
| 
 | |
| 
 | |
|     which is the function pointer type int (*)(void*) that is passed to thrd_create to create a new
 | |
|     thread; and
 | |
| 
 | |
|               once_flag
 | |
| 
 | |
| 
 | |
|     which is a complete object type that holds a flag for use by call_once.
 | |
| </pre>
 | |
| <a name='7.28.1p5'></a>
 | |
| <pre>5   The enumeration constants are
 | |
| 
 | |
|               mtx_plain
 | |
| 
 | |
| 
 | |
|     which is passed to mtx_init to create a mutex object that does not support timeout;
 | |
| 
 | |
|               mtx_recursive
 | |
|     which is passed to mtx_init to create a mutex object that supports recursive locking;
 | |
| 
 | |
|              mtx_timed
 | |
| 
 | |
| 
 | |
|     which is passed to mtx_init to create a mutex object that supports timeout;
 | |
| 
 | |
|              thrd_timedout
 | |
| 
 | |
| 
 | |
|     which is returned by a timed wait function to indicate that the time specified in the call was reached
 | |
|     without acquiring the requested resource;
 | |
| 
 | |
|              thrd_success
 | |
| 
 | |
| 
 | |
|     which is returned by a function to indicate that the requested operation succeeded;
 | |
| 
 | |
|              thrd_busy
 | |
| 
 | |
| 
 | |
|     which is returned by a function to indicate that the requested operation failed because a resource
 | |
|     requested by a test and return function is already in use;
 | |
| 
 | |
|              thrd_error
 | |
| 
 | |
| 
 | |
|     which is returned by a function to indicate that the requested operation failed; and
 | |
| 
 | |
|              thrd_nomem
 | |
| 
 | |
| 
 | |
|     which is returned by a function to indicate that the requested operation failed because it was unable
 | |
|     to allocate memory.
 | |
|     Forward references: date and time (<a href='#7.29'>7.29</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.2'></a>
 | |
| <hr>
 | |
| <h3>7.28.2 [Initialization functions]</h3>
 | |
| <a name='7.28.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.28.2.1 [The call_once function]</h3>
 | |
| <a name='7.28.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              void call_once(once_flag *flag, void (*func)(void));
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.2.1p2'></a>
 | |
| <pre>2   The call_once function uses the once_flag pointed to by flag to ensure that func is called exactly
 | |
|     once, the first time the call_once function is called with that value of flag. Completion of an
 | |
|     effective call to the call_once function synchronizes with all subsequent calls to the call_once
 | |
|     function with the same value of flag.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.2.1p3'></a>
 | |
| <pre>3   The call_once function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.3'></a>
 | |
| <hr>
 | |
| <h3>7.28.3 [Condition variable functions]</h3>
 | |
| <a name='7.28.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.28.3.1 [The cnd_broadcast function]</h3>
 | |
| <a name='7.28.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              int cnd_broadcast(cnd_t *cond);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.3.1p2'></a>
 | |
| <pre>2   The cnd_broadcast function unblocks all of the threads that are blocked on the condition variable
 | |
|     pointed to by cond at the time of the call. If no threads are blocked on the condition variable pointed
 | |
|     to by cond at the time of the call, the function does nothing.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.3.1p3'></a>
 | |
| <pre>3   The cnd_broadcast function returns thrd_success on success, or thrd_error if the request could
 | |
|     not be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.28.3.2 [The cnd_destroy function]</h3>
 | |
| <a name='7.28.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             void cnd_destroy(cnd_t *cond);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.3.2p2'></a>
 | |
| <pre>2   The cnd_destroy function releases all resources used by the condition variable pointed to by cond.
 | |
|     The cnd_destroy function requires that no threads be blocked waiting for the condition variable
 | |
|     pointed to by cond.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.3.2p3'></a>
 | |
| <pre>3   The cnd_destroy function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.28.3.3 [The cnd_init function]</h3>
 | |
| <a name='7.28.3.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int cnd_init(cnd_t *cond);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.3.3p2'></a>
 | |
| <pre>2   The cnd_init function creates a condition variable. If it succeeds it sets the variable pointed to by
 | |
|     cond to a value that uniquely identifies the newly created condition variable. A thread that calls
 | |
|     cnd_wait on a newly created condition variable will block.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.3.3p3'></a>
 | |
| <pre>3   The cnd_init function returns thrd_success on success, or thrd_nomem if no memory could be
 | |
|     allocated for the newly created condition, or thrd_error if the request could not be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.3.4'></a>
 | |
| <hr>
 | |
| <h3>7.28.3.4 [The cnd_signal function]</h3>
 | |
| <a name='7.28.3.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int cnd_signal(cnd_t *cond);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.3.4p2'></a>
 | |
| <pre>2   The cnd_signal function unblocks one of the threads that are blocked on the condition variable
 | |
|     pointed to by cond at the time of the call. If no threads are blocked on the condition variable at the
 | |
|     time of the call, the function does nothing and returns success.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.3.4p3'></a>
 | |
| <pre>3   The cnd_signal function returns thrd_success on success or thrd_error if the request could not
 | |
|     be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.3.5'></a>
 | |
| <hr>
 | |
| <h3>7.28.3.5 [The cnd_timedwait function]</h3>
 | |
| <a name='7.28.3.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int cnd_timedwait(cnd_t *restrict cond, mtx_t *restrict mtx,
 | |
|                   const struct timespec *restrict ts);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.3.5p2'></a>
 | |
| <pre>2   The cnd_timedwait function atomically unlocks the mutex pointed to by mtx and blocks until the
 | |
|     condition variable pointed to by cond is signaled by a call to cnd_signal or to cnd_broadcast, or
 | |
|     until after the TIME_UTC-based calendar time pointed to by ts, or until it is unblocked due to an
 | |
|     unspecified reason. When the calling thread becomes unblocked it locks the variable pointed to by
 | |
|     mtx before it returns. The cnd_timedwait function requires that the mutex pointed to by mtx be
 | |
|     locked by the calling thread.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.3.5p3'></a>
 | |
| <pre>3   The cnd_timedwait function returns thrd_success upon success, or thrd_timedout if the time
 | |
|     specified in the call was reached without acquiring the requested resource, or thrd_error if the
 | |
|     request could not be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.3.6'></a>
 | |
| <hr>
 | |
| <h3>7.28.3.6 [The cnd_wait function]</h3>
 | |
| <a name='7.28.3.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              int cnd_wait(cnd_t *cond, mtx_t *mtx);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.3.6p2'></a>
 | |
| <pre>2   The cnd_wait function atomically unlocks the mutex pointed to by mtx and blocks until the condi-
 | |
|     tion variable pointed to by cond is signaled by a call to cnd_signal or to cnd_broadcast, or until it
 | |
|     is unblocked due to an unspecified reason. When the calling thread becomes unblocked it locks the
 | |
|     mutex pointed to by mtx before it returns. The cnd_wait function requires that the mutex pointed
 | |
|     to by mtx be locked by the calling thread.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.3.6p3'></a>
 | |
| <pre>3   The cnd_wait function returns thrd_success on success or thrd_error if the request could not be
 | |
|     honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4'></a>
 | |
| <hr>
 | |
| <h3>7.28.4 [Mutex functions]</h3>
 | |
| <a name='7.28.4p1'></a>
 | |
| <pre>1   For purposes of determining the existence of a data race, lock and unlock operations behave as
 | |
|     atomic operations. All lock and unlock operations on a particular mutex occur in some particular
 | |
|     total order.
 | |
| </pre>
 | |
| <a name='7.28.4p2'></a>
 | |
| <pre>2   NOTE This total order can be viewed as the modification order of the mutex.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.28.4.1 [The mtx_destroy function]</h3>
 | |
| <a name='7.28.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              void mtx_destroy(mtx_t *mtx);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.4.1p2'></a>
 | |
| <pre>2   The mtx_destroy function releases any resources used by the mutex pointed to by mtx. No threads
 | |
|     can be blocked waiting for the mutex pointed to by mtx.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.4.1p3'></a>
 | |
| <pre>3   The mtx_destroy function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.28.4.2 [The mtx_init function]</h3>
 | |
| <a name='7.28.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              int mtx_init(mtx_t *mtx, int type);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.4.2p2'></a>
 | |
| <pre>2   The mtx_init function creates a mutex object with properties indicated by type, which shall have
 | |
|     one of these values:
 | |
| 
 | |
|     mtx_plain for a simple non-recursive mutex,
 | |
| 
 | |
|     mtx_timed for a non-recursive mutex that supports timeout,
 | |
| 
 | |
|     mtx_plain | mtx_recursive for a simple recursive mutex, or
 | |
| 
 | |
|     mtx_timed | mtx_recursive for a recursive mutex that supports timeout.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4.2p3'></a>
 | |
| <pre>3   If the mtx_init function succeeds, it sets the mutex pointed to by mtx to a value that uniquely
 | |
|     identifies the newly created mutex.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.4.2p4'></a>
 | |
| <pre>4   The mtx_init function returns thrd_success on success, or thrd_error if the request could not
 | |
|     be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.28.4.3 [The mtx_lock function]</h3>
 | |
| <a name='7.28.4.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int mtx_lock(mtx_t *mtx);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.4.3p2'></a>
 | |
| <pre>2   The mtx_lock function blocks until it locks the mutex pointed to by mtx. If the mutex is non-
 | |
|     recursive, it shall not be locked by the calling thread. Prior calls to mtx_unlock on the same mutex
 | |
|     synchronize with this operation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.4.3p3'></a>
 | |
| <pre>3   The mtx_lock function returns thrd_success on success, or thrd_error if the request could not
 | |
|     be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.28.4.4 [The mtx_timedlock function]</h3>
 | |
| <a name='7.28.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int mtx_timedlock(mtx_t *restrict mtx, const struct timespec *restrict ts);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.4.4p2'></a>
 | |
| <pre>2   The mtx_timedlock function endeavors to block until it locks the mutex pointed to by mtx or
 | |
|     until after the TIME_UTC-based calendar time pointed to by ts. The specified mutex shall support
 | |
|     timeout. If the operation succeeds, prior calls to mtx_unlock on the same mutex synchronize with
 | |
|     this operation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.4.4p3'></a>
 | |
| <pre>3   The mtx_timedlock function returns thrd_success on success, or thrd_timedout if the time
 | |
|     specified was reached without acquiring the requested resource, or thrd_error if the request could
 | |
|     not be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4.5'></a>
 | |
| <hr>
 | |
| <h3>7.28.4.5 [The mtx_trylock function]</h3>
 | |
| <a name='7.28.4.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int mtx_trylock(mtx_t *mtx);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.4.5p2'></a>
 | |
| <pre>2   The mtx_trylock function endeavors to lock the mutex pointed to by mtx. If the mutex is already
 | |
|     locked, the function returns without blocking. If the operation succeeds, prior calls to mtx_unlock
 | |
|     on the same mutex synchronize with this operation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.4.5p3'></a>
 | |
| <pre>3   The mtx_trylock function returns thrd_success on success, or thrd_busy if the resource requested
 | |
|     is already in use, or thrd_error if the request could not be honored. mtx_trylock may spuriously
 | |
|     fail to lock an unused resource, in which case it returns thrd_busy.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.4.6'></a>
 | |
| <hr>
 | |
| <h3>7.28.4.6 [The mtx_unlock function]</h3>
 | |
| <a name='7.28.4.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              int mtx_unlock(mtx_t *mtx);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.4.6p2'></a>
 | |
| <pre>2   The mtx_unlock function unlocks the mutex pointed to by mtx. The mutex pointed to by mtx shall
 | |
|     be locked by the calling thread.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.4.6p3'></a>
 | |
| <pre>3   The mtx_unlock function returns thrd_success on success or thrd_error if the request could not
 | |
|     be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.5'></a>
 | |
| <hr>
 | |
| <h3>7.28.5 [Thread functions]</h3>
 | |
| <a name='7.28.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.1 [The thrd_create function]</h3>
 | |
| <a name='7.28.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              int thrd_create(thrd_t *thr, thrd_start_t func, void *arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.1p2'></a>
 | |
| <pre>2   The thrd_create function creates a new thread executing func(arg). If the thrd_create function
 | |
|     succeeds, it sets the object pointed to by thr to the identifier of the newly created thread. (A thread’s
 | |
|     identifier may be reused for a different thread once the original thread has exited and either been
 | |
|     detached or joined to another thread.) The completion of the thrd_create function synchronizes
 | |
|     with the beginning of the execution of the new thread.
 | |
| </pre>
 | |
| <a name='7.28.5.1p3'></a>
 | |
| <pre>3   Returning from func has the same behavior as invoking thrd_exit with the value returned from
 | |
|     func.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.1p4'></a>
 | |
| <pre>4   The thrd_create function returns thrd_success on success, or thrd_nomem if no memory could
 | |
|     be allocated for the thread requested, or thrd_error if the request could not be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.5.2'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.2 [The thrd_current function]</h3>
 | |
| <a name='7.28.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              thrd_t thrd_current(void);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.2p2'></a>
 | |
| <pre>2   The thrd_current function identifies the thread that called it.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.2p3'></a>
 | |
| <pre>3   The thrd_current function returns the identifier of the thread that called it.
 | |
| </pre>
 | |
| <a name='7.28.5.3'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.3 [The thrd_detach function]</h3>
 | |
| <a name='7.28.5.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int thrd_detach(thrd_t thr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.3p2'></a>
 | |
| <pre>2   The thrd_detach function tells the operating system to dispose of any resources allocated to the
 | |
|     thread identified by thr when that thread terminates. The thread identified by thr shall not have
 | |
|     been previously detached or joined with another thread.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.3p3'></a>
 | |
| <pre>3   The thrd_detach function returns thrd_success on success or thrd_error if the request could
 | |
|     not be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.5.4'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.4 [The thrd_equal function]</h3>
 | |
| <a name='7.28.5.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int thrd_equal(thrd_t thr0, thrd_t thr1);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.4p2'></a>
 | |
| <pre>2   The thrd_equal function will determine whether the thread identified by thr0 refers to the thread
 | |
|     identified by thr1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.4p3'></a>
 | |
| <pre>3   The thrd_equal function returns zero if the thread thr0 and the thread thr1 refer to different
 | |
|     threads. Otherwise the thrd_equal function returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.5.5'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.5 [The thrd_exit function]</h3>
 | |
| <a name='7.28.5.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             [[noreturn]] void thrd_exit(int res);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.5p2'></a>
 | |
| <pre>2   For every thread-specific storage key which was created with a non-null destructor and for which
 | |
|     the value is non-null, thrd_exit sets the value associated with the key to a null pointer value and
 | |
|     then invokes the destructor with its previous value. The order in which destructors are invoked is
 | |
|     unspecified.
 | |
| </pre>
 | |
| <a name='7.28.5.5p3'></a>
 | |
| <pre>3   If after this process there remain keys with both non-null destructors and values, the implementation
 | |
|     repeats this process up to TSS_DTOR_ITERATIONS times.
 | |
| </pre>
 | |
| <a name='7.28.5.5p4'></a>
 | |
| <pre>4   Following this, the thrd_exit function terminates execution of the calling thread and sets its result
 | |
|     code to res.
 | |
| </pre>
 | |
| <a name='7.28.5.5p5'></a>
 | |
| <pre>5   The program terminates normally after the last thread has been terminated. The behavior is as if the
 | |
|     program called the exit function with the status EXIT_SUCCESS at thread termination time.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.5p6'></a>
 | |
| <pre>6   The thrd_exit function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.5.6'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.6 [The thrd_join function]</h3>
 | |
| <a name='7.28.5.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int thrd_join(thrd_t thr, int *res);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.6p2'></a>
 | |
| <pre>2   The thrd_join function joins the thread identified by thr with the current thread by blocking until
 | |
|     the other thread has terminated. If the parameter res is not a null pointer, it stores the thread’s result
 | |
|     code in the integer pointed to by res. The termination of the other thread synchronizes with the
 | |
|     completion of the thrd_join function. The thread identified by thr shall not have been previously
 | |
|     detached or joined with another thread.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.6p3'></a>
 | |
| <pre>3   The thrd_join function returns thrd_success on success or thrd_error if the request could not
 | |
|     be honored.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.5.7'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.7 [The thrd_sleep function]</h3>
 | |
| <a name='7.28.5.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              int thrd_sleep(const struct timespec *duration, struct timespec *remaining);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.7p2'></a>
 | |
| <pre>2   The thrd_sleep function suspends execution of the calling thread until either the interval specified
 | |
|     by duration has elapsed or a signal which is not being ignored is received. If interrupted by a signal
 | |
|     and the remaining argument is not null, the amount of time remaining (the requested interval
 | |
|     minus the time actually slept) is stored in the interval it points to. The duration and remaining
 | |
|     arguments may point to the same object.
 | |
| </pre>
 | |
| <a name='7.28.5.7p3'></a>
 | |
| <pre>3   The suspension time may be longer than requested because the interval is rounded up to an integer
 | |
|     multiple of the sleep resolution or because of the scheduling of other activity by the system. But,
 | |
|     except for the case of being interrupted by a signal, the suspension time will not be less than that
 | |
|     specified, as measured by the system clock TIME_UTC.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.7p4'></a>
 | |
| <pre>4   The thrd_sleep function returns zero if the requested time has elapsed, −1 if it has been interrupted
 | |
|     by a signal, or a negative value (which may also be −1) if it fails.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.5.8'></a>
 | |
| <hr>
 | |
| <h3>7.28.5.8 [The thrd_yield function]</h3>
 | |
| <a name='7.28.5.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              void thrd_yield(void);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.5.8p2'></a>
 | |
| <pre>2   The thrd_yield function endeavors to permit other threads to run, even if the current thread would
 | |
|     ordinarily continue to run.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.5.8p3'></a>
 | |
| <pre>3   The thrd_yield function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.6'></a>
 | |
| <hr>
 | |
| <h3>7.28.6 [Thread-specific storage functions]</h3>
 | |
| <a name='7.28.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.28.6.1 [The tss_create function]</h3>
 | |
| <a name='7.28.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <threads.h>
 | |
|              int tss_create(tss_t *key, tss_dtor_t dtor);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.6.1p2'></a>
 | |
| <pre>2   The tss_create function creates a thread-specific storage pointer with destructor dtor, which may
 | |
|     be null.
 | |
| </pre>
 | |
| <a name='7.28.6.1p3'></a>
 | |
| <pre>3   A null pointer value is associated with the newly created key in all existing threads. Upon subsequent
 | |
|     thread creation, the value associated with all keys is initialized to a null pointer value in the new
 | |
|     thread.
 | |
| </pre>
 | |
| <a name='7.28.6.1p4'></a>
 | |
| <pre>4   Destructors associated with thread-specific storage are not invoked at program termination.
 | |
| </pre>
 | |
| <a name='7.28.6.1p5'></a>
 | |
| <pre>5   The tss_create function shall not be called from within a destructor.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.6.1p6'></a>
 | |
| <pre>6   If the tss_create function is successful, it sets the thread-specific storage pointed to by key to a
 | |
|     value that uniquely identifies the newly created pointer and returns thrd_success; otherwise,
 | |
|     thrd_error is returned and the thread-specific storage pointed to by key is set to an indeterminate
 | |
|     representation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.28.6.2 [The tss_delete function]</h3>
 | |
| <a name='7.28.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             void tss_delete(tss_t key);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.6.2p2'></a>
 | |
| <pre>2   The tss_delete function releases any resources used by the thread-specific storage identified by
 | |
|     key. The tss_delete function shall only be called with a value for key that was returned by a call
 | |
|     to tss_create before the thread commenced executing destructors.
 | |
| </pre>
 | |
| <a name='7.28.6.2p3'></a>
 | |
| <pre>3   If tss_delete is called while another thread is executing destructors, whether this will affect the
 | |
|     number of invocations of the destructor associated with key on that thread is unspecified.
 | |
| </pre>
 | |
| <a name='7.28.6.2p4'></a>
 | |
| <pre>4   Calling tss_delete will not result in the invocation of any destructors.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.6.2p5'></a>
 | |
| <pre>5   The tss_delete function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.28.6.3 [The tss_get function]</h3>
 | |
| <a name='7.28.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             void *tss_get(tss_t key);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.6.3p2'></a>
 | |
| <pre>2   The tss_get function returns the value for the current thread held in the thread-specific storage
 | |
|     identified by key. The tss_get function shall only be called with a value for key that was returned
 | |
|     by a call to tss_create before the thread commenced executing destructors.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.6.3p3'></a>
 | |
| <pre>3   The tss_get function returns the value for the current thread if successful, or zero if unsuccessful.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.28.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.28.6.4 [The tss_set function]</h3>
 | |
| <a name='7.28.6.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <threads.h>
 | |
|             int tss_set(tss_t key, void *val);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.28.6.4p2'></a>
 | |
| <pre>2   The tss_set function sets the value for the current thread held in the thread-specific storage
 | |
|     identified by key to val. The tss_set function shall only be called with a value for key that was
 | |
|     returned by a call to tss_create before the thread commenced executing destructors.
 | |
| </pre>
 | |
| <a name='7.28.6.4p3'></a>
 | |
| <pre>3   This action will not invoke the destructor associated with the key on the value being replaced.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.28.6.4p4'></a>
 | |
| <pre>4   The tss_set function returns thrd_success on success or thrd_error if the request could not be
 | |
|     honored.
 | |
| </pre>
 | |
| <a name='7.29'></a>
 | |
| <hr>
 | |
| <h3>7.29 [Date and time <time.h>]</h3>
 | |
| <a name='7.29.1'></a>
 | |
| <hr>
 | |
| <h3>7.29.1 [Components of time]</h3>
 | |
| <a name='7.29.1p1'></a>
 | |
| <pre>1   The header <time.h> defines several macros, and declares types and functions for manipulating
 | |
|     time. Many functions deal with a calendar time that represents the current date (according to the
 | |
|     Gregorian calendar) and time. Some functions deal with local time, which is the calendar time
 | |
|     expressed for some specific time zone, and with Daylight Saving Time, which is a temporary change
 | |
|     in the algorithm for determining local time. The local time zone and Daylight Saving Time are
 | |
|     implementation-defined.
 | |
| </pre>
 | |
| <a name='7.29.1p2'></a>
 | |
| <pre>2   The feature test macro __STDC_VERSION_TIME_H__ expands to the token 202311L. The other macros
 | |
|     defined are NULL (described in <a href='#7.21'>7.21</a>);
 | |
| 
 | |
|               CLOCKS_PER_SEC
 | |
| 
 | |
| 
 | |
|     which expands to an expression with type clock_t (described below) that is the number per second
 | |
|     of the value returned by the clock function;
 | |
| 
 | |
|               TIME_UTC
 | |
|               TIME_MONOTONIC
 | |
| 
 | |
| 
 | |
|     which expand to integer constants greater than 0 that designates the calendar time and monotonic
 | |
|     time bases, respectively. Additional time base macro definitions, beginning with TIME_ and an
 | |
|     uppercase letter, may also be specified by the implementation<a href='#FOOTNOTE.385'><sup>[385]</sup></a> ; and,
 | |
| 
 | |
|               TIME_ACTIVE
 | |
|               TIME_THREAD_ACTIVE
 | |
| 
 | |
| 
 | |
|     which, if defined, expand to integer values, designating overall execution and thread-specific active
 | |
|     processing time bases, respectively.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.385'>
 | |
| <pre><i><b>Footnote 385)</b> See future library directions (<a href='#7.33'>7.33</a>). Implementations can define additional time bases, but are only required to support a
 | |
|     real time clock based on UTC.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.29.1p3'></a>
 | |
| <pre>3   The definition of macros for time bases other than TIME_UTC are optional. If defined, the correspond-
 | |
|     ing time bases are supported by timespec_get and timespec_getres, and their values are positive.
 | |
|     If defined, the value of the optional macro TIME_ACTIVE shall be different from the constants
 | |
|     TIME_UTC and TIME_MONOTONIC and shall not change during the same program invocation. The
 | |
|     optional macro TIME_THREAD_ACTIVE shall not be defined if the implementation does not support
 | |
|     threads; its value shall be different from TIME_UTC, TIME_MONOTONIC, and TIME_ACTIVE, it shall be
 | |
|     the same for all expansions of the macro for the same thread, and the value provided for one thread
 | |
|     shall not be used by a different thread as the base argument of timespec_get or timespec_getres.
 | |
| </pre>
 | |
| <a name='7.29.1p4'></a>
 | |
| <pre>4   The types declared are size_t (described in <a href='#7.21'>7.21</a>);
 | |
| 
 | |
|               clock_t
 | |
| 
 | |
| 
 | |
|     and
 | |
| 
 | |
|               time_t
 | |
| 
 | |
| 
 | |
|     which are real types capable of representing times;
 | |
| 
 | |
|               struct timespec
 | |
| 
 | |
| 
 | |
|     which holds an interval specified in seconds and nanoseconds (which may represent a calendar time
 | |
|     based on a particular epoch); and
 | |
| 
 | |
|               struct tm
 | |
|     which holds the components of a calendar time, called the broken-down time.
 | |
| </pre>
 | |
| <a name='7.29.1p5'></a>
 | |
| <pre>5   The range and precision of times representable in clock_t and time_t are implementation-defined.
 | |
|     The timespec structure shall contain at least the following members, in any order. The semantics of
 | |
|     the members and their normal ranges are expressed in the comments.<a href='#FOOTNOTE.386'><sup>[386]</sup></a>
 | |
| 
 | |
|              time_t tv_sec; // whole seconds -- ≥ 0
 | |
|              long   tv_nsec; // nanoseconds -- [0, 999999999]
 | |
| 
 | |
| 
 | |
|     The tm structure shall contain at least the following members, in any order. The semantics of the
 | |
|     members and their normal ranges are expressed in the comments.<a href='#FOOTNOTE.387'><sup>[387]</sup></a>
 | |
| 
 | |
|              int tm_sec;   // seconds after the minute -- [0, 60]
 | |
|              int tm_min;   // minutes after the hour -- [0, 59]
 | |
|              int tm_hour; // hours since midnight -- [0, 23]
 | |
|              int tm_mday; // day of the month -- [1, 31]
 | |
|              int tm_mon;   // months since January -- [0, 11]
 | |
|              int tm_year; // years since 1900
 | |
|              int tm_wday; // days since Sunday -- [0, 6]
 | |
|              int tm_yday; // days since January 1 -- [0, 365]
 | |
|              int tm_isdst; // Daylight Saving Time flag
 | |
| 
 | |
| 
 | |
|     The value of tm_isdst is positive if Daylight Saving Time is in effect, zero if Daylight Saving Time
 | |
|     is not in effect, and negative if the information is not available.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.386'>
 | |
| <pre><i><b>Footnote 386)</b> The tv_sec member is a linear count of seconds and might not have the normal semantics of a time_t.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.387'>
 | |
| <pre><i><b>Footnote 387)</b> The range [0, 60] for tm_sec allows for a positive leap second.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.29.2'></a>
 | |
| <hr>
 | |
| <h3>7.29.2 [Time manipulation functions]</h3>
 | |
| <a name='7.29.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.29.2.1 [The clock function]</h3>
 | |
| <a name='7.29.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <time.h>
 | |
|              clock_t clock(void);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.2.1p2'></a>
 | |
| <pre>2   The clock function determines the processor time used.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.2.1p3'></a>
 | |
| <pre>3   The clock function returns the implementation’s best approximation of the active processing time
 | |
|     associated with the program execution since the beginning of an implementation-defined era related
 | |
|     only to the program invocation. To determine the time in seconds, the value returned by the clock
 | |
|     function should be divided by the value of the macro CLOCKS_PER_SEC. If the processor time used
 | |
|     is not available, the function returns the value (clock_t) (−1). If the value cannot be represented,
 | |
|     the function returns an unspecified value<a href='#FOOTNOTE.388'><sup>[388]</sup></a> .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.388'>
 | |
| <pre><i><b>Footnote 388)</b> This could be due to overflow of the clock_t type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.29.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.29.2.2 [The difftime function]</h3>
 | |
| <a name='7.29.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <time.h>
 | |
|              double difftime(time_t time1, time_t time0);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.2.2p2'></a>
 | |
| <pre>2   The difftime function computes the difference between two calendar times: time1 - time0.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.2.2p3'></a>
 | |
| <pre>3   The difftime function returns the difference expressed in seconds as a double.
 | |
| </pre>
 | |
| <a name='7.29.2.3'></a>
 | |
| <hr>
 | |
| <h3>7.29.2.3 [The mktime function]</h3>
 | |
| <a name='7.29.2.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <time.h>
 | |
|               time_t mktime(struct tm *timeptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.2.3p2'></a>
 | |
| <pre>2   The mktime function converts the broken-down time, expressed as local time, in the structure
 | |
|     pointed to by timeptr into a calendar time value with the same encoding as that of the values
 | |
|     returned by the time function. The original values of the tm_wday and tm_yday components of the
 | |
|     structure are ignored, and the original values of the other components are not restricted to the ranges
 | |
|     indicated above. <a href='#FOOTNOTE.389'><sup>[389]</sup></a> On successful completion, the values of the tm_wday and tm_yday components
 | |
|     of the structure are set appropriately, and the other components are set to represent the specified
 | |
|     calendar time, but with their values forced to the ranges indicated above; the final value of tm_mday
 | |
|     is not set until tm_mon and tm_year are determined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.389'>
 | |
| <pre><i><b>Footnote 389)</b> Thus, a positive or zero value for tm_isdst causes the mktime function to presume initially that Daylight Saving Time,
 | |
|     respectively, is or is not in effect for the specified time. A negative value causes it to attempt to determine whether Daylight
 | |
|     Saving Time is in effect for the specified time.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.29.2.3p3'></a>
 | |
| <pre>3   The mktime function returns the specified calendar time encoded as a value of type time_t. If the
 | |
|     calendar time cannot be represented, the function returns the value (time_t) (−1).
 | |
| </pre>
 | |
| <a name='7.29.2.3p4'></a>
 | |
| <pre>4   EXAMPLE What day of the week is July 4, 2001?
 | |
| 
 | |
|               #include <stdio.h>
 | |
|               #include <time.h>
 | |
|               static const char *const wday[] = {
 | |
|                     "Sunday", "Monday", "Tuesday", "Wednesday",
 | |
|                     "Thursday", "Friday", "Saturday", "-unknown-"
 | |
|               };
 | |
|               struct tm time_str;
 | |
|               /* ... */
 | |
| 
 | |
|               time_str.tm_year   = 2001 - 1900;
 | |
|               time_str.tm_mon    = 7 - 1;
 | |
|               time_str.tm_mday   = 4;
 | |
|               time_str.tm_hour   = 0;
 | |
|               time_str.tm_min    = 0;
 | |
|               time_str.tm_sec    = 1;
 | |
|               time_str.tm_isdst = -1;
 | |
|               if (mktime(&time_str) == (time_t)(-1))
 | |
|                     time_str.tm_wday = 7;
 | |
|               printf("%s\n", wday[time_str.tm_wday]);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.2.4'></a>
 | |
| <hr>
 | |
| <h3>7.29.2.4 [The timegm function]</h3>
 | |
| <a name='7.29.2.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <time.h>
 | |
|               time_t timegm(struct tm *timeptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.2.4p2'></a>
 | |
| <pre>2   The timegm function converts the broken-down time, expressed as UTC time, in the structure
 | |
|     pointed to by timeptr into a calendar time value with the same encoding as that of the values
 | |
|     returned by the time function. The original values of the tm_wday and tm_yday components of the
 | |
|     structure are ignored, and the original values of the other components are not restricted to the ranges
 | |
|     indicated above. On successful completion, the values of the tm_wday and tm_yday components
 | |
|     of the structure are set appropriately, and the other components are set to represent the specified
 | |
|     calendar time, but with their values forced to the ranges indicated above; the final value of tm_mday
 | |
|     is not set until tm_mon and tm_year are determined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.2.4p3'></a>
 | |
| <pre>3   The timegm function returns the specified calendar time encoded as a value of type time_t. If the
 | |
|     calendar time cannot be represented, the function returns the value (time_t)(-1) .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.2.5'></a>
 | |
| <hr>
 | |
| <h3>7.29.2.5 [The time function]</h3>
 | |
| <a name='7.29.2.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <time.h>
 | |
|               time_t time(time_t *timer);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.2.5p2'></a>
 | |
| <pre>2   The time function determines the current calendar time. The encoding of the value is unspecified.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.2.5p3'></a>
 | |
| <pre>3   The time function returns the implementation’s best approximation to the current calendar time.
 | |
|     The value (time_t) (−1) is returned if the calendar time is not available. If timer is not a null
 | |
|     pointer, the return value is also assigned to the object it points to.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.2.6'></a>
 | |
| <hr>
 | |
| <h3>7.29.2.6 [The timespec_get function]</h3>
 | |
| <a name='7.29.2.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <time.h>
 | |
|               int timespec_get(struct timespec *ts, int base);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.2.6p2'></a>
 | |
| <pre>2   The timespec_get function sets the interval pointed to by ts to hold the current calendar time
 | |
|     based on the specified time base.
 | |
| </pre>
 | |
| <a name='7.29.2.6p3'></a>
 | |
| <pre>3   If base is TIME_UTC, the tv_sec member is set to the number of seconds since an implementation-
 | |
|     defined epoch, truncated to a whole value and the tv_nsec member is set to the integral num-
 | |
|     ber of nanoseconds, rounded to the resolution of the system clock<a href='#FOOTNOTE.390'><sup>[390]</sup></a> . The optional time base
 | |
|     TIME_MONOTONIC is the same, but the reference point is an implementation-defined time point;
 | |
|     different program invocations need not refer to the same reference points<a href='#FOOTNOTE.391'><sup>[391]</sup></a> . For the same program
 | |
|     invocation, the results of two calls to timespec_get with TIME_MONOTONIC such that the first hap-
 | |
|     pens before the second shall not be decreasing. It is implementation-defined if TIME_MONOTONIC
 | |
|     accounts for time during which the execution environment is suspended<a href='#FOOTNOTE.392'><sup>[392]</sup></a> . For the optional time
 | |
|     bases TIME_ACTIVE and TIME_THREAD_ACTIVE the result is similar, but the call measures the amount
 | |
|     of active processing time associated with the whole program invocation or with the calling thread,
 | |
|     respectively.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.390'>
 | |
| <pre><i><b>Footnote 390)</b> Although a struct timespec object describes times with nanosecond resolution, the available resolution is system
 | |
|     dependent and could even be greater than 1 second.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.391'>
 | |
| <pre><i><b>Footnote 391)</b> Commonly, this reference point is the boot time of the execution environment or the start of the execution.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.392'>
 | |
| <pre><i><b>Footnote 392)</b> The execution environment may, for example, not be able to track physical time that elapsed during suspension in a low
 | |
|     power consumption mode.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.29.2.6p4'></a>
 | |
| <pre>4   If the timespec_get function is successful it returns the nonzero value base; otherwise, it returns
 | |
|     zero.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.29.2.6p5'></a>
 | |
| <pre>5   It is recommended practice that timing results of calls to timespec_get with TIME_ACTIVE, if
 | |
|     defined, and of calls to clock are as close to each other as their types, value ranges, and resolutions
 | |
|     (obtained with timespec_getres and CLOCKS_PER_SEC, respectively) allow. Because of its wider
 | |
|     value range and improved indications on error, timespec_get with time base TIME_ACTIVE should
 | |
|     be used instead of clock by new code whenever possible.
 | |
| </pre>
 | |
| <a name='7.29.2.7'></a>
 | |
| <hr>
 | |
| <h3>7.29.2.7 [The timespec_getres function]</h3>
 | |
| <a name='7.29.2.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <time.h>
 | |
|               int timespec_getres(struct timespec *ts, int base);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.2.7p2'></a>
 | |
| <pre>2   If ts is non-null and base is supported by the timespec_get function, the timespec_getres
 | |
|     function returns the resolution of the time provided by the timespec_get function for base
 | |
|     in the timespec structure pointed to by ts. For each supported base, multiple calls to the
 | |
|     timespec_getres function during the same program execution shall have identical results.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.2.7p3'></a>
 | |
| <pre>3   If the value base is supported by the timespec_get function, the timespec_getres function returns
 | |
|     the nonzero value base; otherwise, it returns zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3'></a>
 | |
| <hr>
 | |
| <h3>7.29.3 [Time conversion functions]</h3>
 | |
| <a name='7.29.3p1'></a>
 | |
| <pre>1   Functions with a _r suffix place the result of the conversion into the buffer referred by buf and
 | |
|     return that pointer. These functions and the function strftime shall not be subject to data races,
 | |
|     unless the time or calendar state is changed in a multi-thread execution.<a href='#FOOTNOTE.393'><sup>[393]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.393'>
 | |
| <pre><i><b>Footnote 393)</b> This does not mean that these functions may not read global state that describes the time and calendar settings of the
 | |
|     execution, such as the LC_TIME locale or the implementation-defined specification of the local time zone. Only the setting of
 | |
|     that state by setlocale or by means of implementation-defined functions may constitute races.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.29.3p2'></a>
 | |
| <pre>2   Functions asctime, ctime, gmtime, and localtime are the same as their counterparts suffixed with
 | |
|     _r. In place of the parameter buf, these functions use a pointer to an object and return it: one or two
 | |
|     broken-down time structures (for gmtime and localtime) or an array of char (commonly used by
 | |
|     asctime and ctime). Execution of any of the functions that return a pointer to one of these static
 | |
|     objects may overwrite the information returned from any previous call to one of these functions that
 | |
|     uses the same object. These functions are not reentrant and are not required to avoid data races with
 | |
|     each other. Accessing the returned pointer after the thread that called the function that returned
 | |
|     it has exited results in undefined behavior. The implementation shall behave as if no other library
 | |
|     functions call these functions.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.29.3.1 [The asctime function]</h3>
 | |
| <a name='7.29.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <time.h>
 | |
|               [[deprecated]] char *asctime(const struct tm *timeptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.3.1p2'></a>
 | |
| <pre>2   This function is obsolescent and should be avoided in new code.
 | |
| </pre>
 | |
| <a name='7.29.3.1p3'></a>
 | |
| <pre>3   The asctime function converts the broken-down time in the structure pointed to by timeptr into a
 | |
|     string in the form
 | |
| 
 | |
|               Sun Sep 16 01:03:52 1973\n\0
 | |
| 
 | |
| 
 | |
|     using the equivalent of the following algorithm.
 | |
| 
 | |
|       [[deprecated]] char *asctime(const struct tm *timeptr)
 | |
|       {
 | |
|             static const char wday_name[7][3] = {
 | |
|                   "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"
 | |
|             };
 | |
|             static const char mon_name[12][3] = {
 | |
|                   "Jan", "Feb", "Mar", "Apr", "May", "Jun",
 | |
|                   "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"
 | |
|                };
 | |
|                static char result[26];
 | |
| 
 | |
|                snprintf(result, 26, "%.3s %.3s%3d %.2d:%.2d:%.2d %d\n",
 | |
|                      wday_name[timeptr->tm_wday],
 | |
|                      mon_name[timeptr->tm_mon],
 | |
|                      timeptr->tm_mday, timeptr->tm_hour,
 | |
|                      timeptr->tm_min, timeptr->tm_sec,
 | |
|                      1900 + timeptr->tm_year);
 | |
|                return result;
 | |
|      }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.1p4'></a>
 | |
| <pre>4   If any of the members of the broken-down time contain values that are outside their normal ranges<a href='#FOOTNOTE.394'><sup>[394]</sup></a> ,
 | |
|     the behavior of the asctime function is undefined. Likewise, if the calculated year exceeds four
 | |
|     digits or is less than the year 1000, the behavior is undefined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.394'>
 | |
| <pre><i><b>Footnote 394)</b> See <a href='#7.29.1'>7.29.1</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.29.3.1p5'></a>
 | |
| <pre>5   The asctime function returns a pointer to the string.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.29.3.2 [The ctime function]</h3>
 | |
| <a name='7.29.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <time.h>
 | |
|                [[deprecated]] char *ctime(const time_t *timer);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.3.2p2'></a>
 | |
| <pre>2   This function is obsolescent and should be avoided in new code.
 | |
| </pre>
 | |
| <a name='7.29.3.2p3'></a>
 | |
| <pre>3   The ctime function converts the calendar time pointed to by timer to local time in the form of a
 | |
|     string. They are equivalent to:
 | |
| 
 | |
|                asctime(localtime(timer))
 | |
| 
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.3.2p4'></a>
 | |
| <pre>4   The ctime function returns the pointer returned by the asctime functions with that broken-down
 | |
|     time as argument.
 | |
|     Forward references: the localtime functions (<a href='#7.29.3.4'>7.29.3.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.29.3.3 [The gmtime functions]</h3>
 | |
| <a name='7.29.3.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <time.h>
 | |
|                struct tm *gmtime(const time_t *timer);
 | |
|                struct tm *gmtime_r(const time_t *timer, struct tm *buf);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.3.3p2'></a>
 | |
| <pre>2   The gmtime functions convert the calendar time pointed to by timer into a broken-down time,
 | |
|     expressed as UTC.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.3.3p3'></a>
 | |
| <pre>3   The gmtime functions return a pointer to the broken-down time, or a null pointer if the specified
 | |
|     time cannot be converted to UTC.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.4'></a>
 | |
| <hr>
 | |
| <h3>7.29.3.4 [The localtime functions]</h3>
 | |
| <a name='7.29.3.4p1'></a>
 | |
| <pre>1     Synopsis
 | |
|            #include <time.h>
 | |
|             struct tm *localtime(const time_t *timer);
 | |
|             struct tm *localtime_r(const time_t *timer, struct tm *buf);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.3.4p2'></a>
 | |
| <pre>2   The localtime functions converts the calendar time pointed to by timer into a broken-down time,
 | |
|     expressed as local time.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.3.4p3'></a>
 | |
| <pre>3   The localtime functions return a pointer to the broken-down time, or a null pointer if the specified
 | |
|     time cannot be converted to local time.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.5'></a>
 | |
| <hr>
 | |
| <h3>7.29.3.5 [The strftime function]</h3>
 | |
| <a name='7.29.3.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <time.h>
 | |
|             size_t strftime(char * restrict s, size_t maxsize, const char * restrict format,
 | |
|                   const struct tm * restrict timeptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.29.3.5p2'></a>
 | |
| <pre>2   The strftime function places characters into the array pointed to by s as controlled by the string
 | |
|     pointed to by format. The format shall be a multibyte character sequence, beginning and ending in
 | |
|     its initial shift state. The format string consists of zero or more conversion specifiers and ordinary
 | |
|     multibyte characters. A conversion specifier consists of a % character, possibly followed by an E or O
 | |
|     modifier character (described below), followed by a character that determines the behavior of the
 | |
|     conversion specifier. All ordinary multibyte characters (including the terminating null character) are
 | |
|     copied unchanged into the array. If copying takes place between objects that overlap, the behavior is
 | |
|     undefined. No more than maxsize characters are placed into the array.
 | |
| </pre>
 | |
| <a name='7.29.3.5p3'></a>
 | |
| <pre>3   Each conversion specifier shall be replaced by appropriate characters as described in the following
 | |
|     list. The appropriate characters shall be determined using the LC_TIME category of the current
 | |
|     locale and by the values of zero or more members of the broken-down time structure pointed to
 | |
|     by timeptr, as specified in brackets in the description. If any of the specified values is outside the
 | |
|     normal range, the characters stored are unspecified.
 | |
| 
 | |
|     %a   is replaced by the locale’s abbreviated weekday name. [tm_wday]
 | |
|     %A   is replaced by the locale’s full weekday name. [tm_wday]
 | |
|     %b   is replaced by the locale’s abbreviated month name. [tm_mon]
 | |
|     %B   is replaced by the locale’s full month name. [tm_mon]
 | |
|     %c   is replaced by the locale’s appropriate date and time representation. [all specified in <a href='#7.29.1'>7.29.1</a>]
 | |
|     %C   is replaced by the year divided by 100 and truncated to an integer, as a decimal number (00–99).
 | |
|          [tm_year]
 | |
|     %d   is replaced by the day of the month as a decimal number (01–31). [tm_mday]
 | |
|     %D   is equivalent to "%m/%d/%y". [tm_mon, tm_mday, tm_year]
 | |
|     %e   is replaced by the day of the month as a decimal number (1–31); a single digit is preceded by a
 | |
|          space. [tm_mday]
 | |
|     %F   is equivalent to "%Y-%m-%d" (the ISO 8601 date format). [tm_year, tm_mon, tm_mday]
 | |
|     %g   is replaced by the last 2 digits of the week-based year (see below) as a decimal number (00–99).
 | |
|          [tm_year, tm_wday, tm_yday]
 | |
|     %G   is replaced by the week-based year (see below) as a decimal number (e.g., 1997). [tm_year,
 | |
|          tm_wday, tm_yday]
 | |
|     %h   is equivalent to "%b". [tm_mon]
 | |
|     %H    is replaced by the hour (24-hour clock) as a decimal number (00–23). [tm_hour]
 | |
|     %I    is replaced by the hour (12-hour clock) as a decimal number (01–12). [tm_hour]
 | |
|     %j    is replaced by the day of the year as a decimal number (001–366). [tm_yday]
 | |
|     %m    is replaced by the month as a decimal number (01–12). [tm_mon]
 | |
|     %M    is replaced by the minute as a decimal number (00–59). [tm_min]
 | |
|     %n    is replaced by a new-line character.
 | |
|     %p    is replaced by the locale’s equivalent of the AM/PM designations associated with a 12-hour
 | |
|           clock. [tm_hour]
 | |
|     %r    is replaced by the locale’s 12-hour clock time. [tm_hour, tm_min, tm_sec]
 | |
|     %R    is equivalent to "%H:%M". [tm_hour, tm_min ]
 | |
|     %S    is replaced by the second as a decimal number (00–60). [tm_sec]
 | |
|     %t    is replaced by a horizontal-tab character.
 | |
|     %T    is equivalent to "%H:%M:%S" (the ISO 8601 time format). [tm_hour, tm_min, tm_sec]
 | |
|     %u    is replaced by the ISO 8601 weekday as a decimal number (1–7), where Monday is 1. [tm_wday]
 | |
|     %U    is replaced by the week number of the year (the first Sunday as the first day of week 1) as a
 | |
|           decimal number (00–53). [tm_year, tm_wday, tm_yday]
 | |
|     %V    is replaced by the ISO 8601 week number (see below) as a decimal number (01–53). [tm_year,
 | |
|           tm_wday, tm_yday]
 | |
|     %w    is replaced by the weekday as a decimal number (0–6), where Sunday is 0. [tm_wday]
 | |
|     %W    is replaced by the week number of the year (the first Monday as the first day of week 1) as a
 | |
|           decimal number (00–53). [tm_year, tm_wday, tm_yday]
 | |
|     %x    is replaced by the locale’s appropriate date representation. [all specified in <a href='#7.29.1'>7.29.1</a>]
 | |
|     %X    is replaced by the locale’s appropriate time representation. [all specified in <a href='#7.29.1'>7.29.1</a>]
 | |
|     %y    is replaced by the last 2 digits of the year as a decimal number (00–99). [tm_year]
 | |
|     %Y    is replaced by the year as a decimal number (e.g., 1997). [tm_year]
 | |
|     %z    is replaced by the offset from UTC in the ISO 8601 format "-0430" (meaning 4 hours 30
 | |
|           minutes behind UTC, west of Greenwich), or by no characters if no time zone is determinable.
 | |
|           [tm_isdst]
 | |
|     %Z    is replaced by the locale’s time zone name or abbreviation, or by no characters if no time zone is
 | |
|           determinable. [tm_isdst]
 | |
|     %%    is replaced by %.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.5p4'></a>
 | |
| <pre>4   Some conversion specifiers can be modified by the inclusion of an E or O modifier character to
 | |
|     indicate an alternative format or specification. If the alternative format or specification does not
 | |
|     exist for the current locale, the modifier is ignored.
 | |
| 
 | |
|     %Ec       is replaced by the locale’s alternative date and time representation.
 | |
|     %EC       is replaced by the name of the base year (period) in the locale’s alternative representation.
 | |
|     %Ex       is replaced by the locale’s alternative date representation.
 | |
|     %EX       is replaced by the locale’s alternative time representation.
 | |
|     %Ey       is replaced by the offset from %EC (year only) in the locale’s alternative representation.
 | |
|     %EY       is replaced by the locale’s full alternative year representation.
 | |
|     %Ob       is replaced by the locale’s abbreviated alternative month name.
 | |
|     %OB       is replaced by the locale’s alternative appropriate full month name.
 | |
|     %Od       is replaced by the day of the month, using the locale’s alternative numeric symbols (filled as
 | |
|               needed with leading zeros, or with leading spaces if there is no alternative symbol for zero).
 | |
|     %Oe     is replaced by the day of the month, using the locale’s alternative numeric symbols (filled as
 | |
|             needed with leading spaces).
 | |
|     %OH     is replaced by the hour (24-hour clock), using the locale’s alternative numeric symbols.
 | |
|     %OI     is replaced by the hour (12-hour clock), using the locale’s alternative numeric symbols.
 | |
|     %Om     is replaced by the month, using the locale’s alternative numeric symbols.
 | |
|     %OM     is replaced by the minutes, using the locale’s alternative numeric symbols.
 | |
|     %OS     is replaced by the seconds, using the locale’s alternative numeric symbols.
 | |
|     %Ou     is replaced by the ISO 8601 weekday as a number in the locale’s alternative representation,
 | |
|             where Monday is 1.
 | |
|     %OU     is replaced by the week number, using the locale’s alternative numeric symbols.
 | |
|     %OV     is replaced by the ISO 8601 week number, using the locale’s alternative numeric symbols.
 | |
|     %Ow     is replaced by the weekday as a number, using the locale’s alternative numeric symbols.
 | |
|     %OW     is replaced by the week number of the year, using the locale’s alternative numeric symbols.
 | |
|     %Oy     is replaced by the last 2 digits of the year, using the locale’s alternative numeric symbols.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.29.3.5p5'></a>
 | |
| <pre>5   %g, %G, and %V give values according to the ISO 8601 week-based year. In this system, weeks begin
 | |
|     on a Monday and week 1 of the year is the week that includes January 4th, which is also the week
 | |
|     that includes the first Thursday of the year, and is also the first week that contains at least four days
 | |
|     in the year. If the first Monday of January is the 2nd, 3rd, or 4th, the preceding days are part of the
 | |
|     last week of the preceding year; thus, for Saturday 2nd January 1999, %G is replaced by 1998 and %V
 | |
|     is replaced by 53. If December 29th, 30th, or 31st is a Monday, it and any following days are part of
 | |
|     week 1 of the following year. Thus, for Tuesday 30th December 1997, %G is replaced by 1998 and %V
 | |
|     is replaced by 01.
 | |
| </pre>
 | |
| <a name='7.29.3.5p6'></a>
 | |
| <pre>6   If a conversion specifier is not one of the above, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.29.3.5p7'></a>
 | |
| <pre>7   In the "C" locale, the E and O modifiers are ignored and the replacement strings for the following
 | |
|     specifiers are:
 | |
| 
 | |
|     %a      the first three characters of %A.
 | |
|     %A      one of "Sunday", "Monday", . . . , "Saturday".
 | |
|     %b      the first three characters of %B.
 | |
|     %B      one of "January", "February", . . . , "December".
 | |
|     %c      equivalent to "%a %b %e %T %Y".
 | |
|     %p      one of "AM" or "PM".
 | |
|     %r      equivalent to "%I:%M:%S %p".
 | |
|     %x      equivalent to "%m/%d/%y".
 | |
|     %X      equivalent to %T.
 | |
|     %Z      implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.29.3.5p8'></a>
 | |
| <pre>8   If the total number of resulting characters including the terminating null character is not more than
 | |
|     maxsize, the strftime function returns the number of characters placed into the array pointed to
 | |
|     by s not including the terminating null character. Otherwise, zero is returned and the members of
 | |
|     the array have an indeterminate representation.
 | |
| </pre>
 | |
| <a name='7.30'></a>
 | |
| <hr>
 | |
| <h3>7.30 [Unicode utilities <uchar.h>]</h3>
 | |
| <a name='7.30p1'></a>
 | |
| <pre>1   The header <uchar.h> declares types and functions for manipulating Unicode characters.
 | |
| </pre>
 | |
| <a name='7.30p2'></a>
 | |
| <pre>2   The types declared are mbstate_t (described in <a href='#7.31.1'>7.31.1</a>) and size_t (described in <a href='#7.21'>7.21</a>);
 | |
| 
 | |
|              char8_t
 | |
| 
 | |
| 
 | |
|     which is an unsigned integer type used for 8-bit characters and is the same type as unsigned char;
 | |
| 
 | |
|              char16_t
 | |
| 
 | |
| 
 | |
|     which is an unsigned integer type used for 16-bit characters and is the same type as uint_least16_t
 | |
|     (described in <a href='#7.22.1.2'>7.22.1.2</a>); and
 | |
| 
 | |
|              char32_t
 | |
| 
 | |
| 
 | |
|     which is an unsigned integer type used for 32-bit characters and is the same type as uint_least32_t
 | |
|     (also described in <a href='#7.22.1.2'>7.22.1.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.30.1'></a>
 | |
| <hr>
 | |
| <h3>7.30.1 [Restartable multibyte/wide character conversion functions]</h3>
 | |
| <a name='7.30.1p1'></a>
 | |
| <pre>1   These functions have a parameter, ps, of type pointer to mbstate_t that points to an object that can
 | |
|     completely describe the current conversion state of the associated multibyte character sequence,
 | |
|     which the functions alter as necessary. If ps is a null pointer, each function uses its own internal
 | |
|     mbstate_t object instead, which is initialized prior to the first call to the function to the initial
 | |
|     conversion state; the functions are not required to avoid data races with other calls to the same
 | |
|     function in this case. It is implementation-defined whether the internal mbstate_t object has thread
 | |
|     storage duration; if it has thread storage duration, it is initialized to the initial conversion state
 | |
|     prior to the first call to the function on the new thread. The implementation behaves as if no library
 | |
|     function calls these functions with a null pointer for ps.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.30.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.30.1.1 [The mbrtoc8 function]</h3>
 | |
| <a name='7.30.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <uchar.h>
 | |
|              size_t mbrtoc8(char8_t * restrict pc8, const char * restrict s, size_t n,
 | |
|                    mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.30.1.1p2'></a>
 | |
| <pre>2   If s is a null pointer, the mbrtoc8 function is equivalent to the call:
 | |
| 
 | |
|                     mbrtoc8(NULL, "", 1, ps)
 | |
| 
 | |
| 
 | |
|     In this case, the values of the parameters pc8 and n are ignored.
 | |
| </pre>
 | |
| <a name='7.30.1.1p3'></a>
 | |
| <pre>3   If s is not a null pointer, the mbrtoc8 function function inspects at most n bytes beginning with
 | |
|     the byte pointed to by s to determine the number of bytes needed to complete the next multibyte
 | |
|     character (including any shift sequences). If the function determines that the next multibyte character
 | |
|     is complete and valid, it determines the values of the corresponding characters and then, if pc8 is
 | |
|     not a null pointer, stores the value of the first (or only) such character in the object pointed to by pc8.
 | |
|     Subsequent calls will store successive characters without consuming any additional input until all
 | |
|     the characters have been stored. If the corresponding character is the null character, the resulting
 | |
|     state described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.30.1.1p4'></a>
 | |
| <pre>4   The mbrtoc8 function returns the first of the following that applies (given the current conversion
 | |
|     state):
 | |
| 
 | |
|     0                  if the next n or fewer bytes complete the multibyte character that corresponds to
 | |
|                        the null character (which is the value stored).
 | |
|     between 1 and n inclusive if the next n or fewer bytes complete a valid multibyte character (which
 | |
|                      is the value stored); the value returned is the number of bytes that complete the
 | |
|                      multibyte character.
 | |
| 
 | |
|     (size_t) (−3) if the next character resulting from a previous call has been stored (no bytes from
 | |
|                         the input have been consumed by this call).
 | |
| 
 | |
|     (size_t) (−2) if the next n bytes contribute to an incomplete (but potentially valid) multibyte
 | |
|                   character, and all n bytes have been processed (no value is stored).<a href='#FOOTNOTE.395'><sup>[395]</sup></a>
 | |
| 
 | |
|     (size_t) (−1) if an encoding error occurs, in which case the next n or fewer bytes do not contribute
 | |
|                         to a complete and valid multibyte character (no value is stored); the value of the
 | |
|                         macro EILSEQ is stored in errno, and the conversion state is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.395'>
 | |
| <pre><i><b>Footnote 395)</b> When n has at least the value of the MB_CUR_MAX macro, this case can only occur if s points at a sequence of redundant
 | |
|     shift sequences (for implementations with state-dependent encodings).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.30.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.30.1.2 [The c8rtomb function]</h3>
 | |
| <a name='7.30.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <uchar.h>
 | |
|               size_t c8rtomb(char * restrict s, char8_t c8, mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.30.1.2p2'></a>
 | |
| <pre>2   If s is a null pointer, the c8rtomb function is equivalent to the call
 | |
| 
 | |
|                       c8rtomb(buf, u8’\0’, ps)
 | |
| 
 | |
| 
 | |
|     where buf is an internal buffer.
 | |
| </pre>
 | |
| <a name='7.30.1.2p3'></a>
 | |
| <pre>3   If s is not a null pointer, the c8rtomb function determines the number of bytes needed to represent
 | |
|     the multibyte character that corresponds to the character given or completed by c8 (including any
 | |
|     shift sequences), and stores the multibyte character representation in the array whose first element is
 | |
|     pointed to by s, or stores nothing if c8 does not represent a complete character. At most MB_CUR_MAX
 | |
|     bytes are stored. If c8 is a null character, a null byte is stored, preceded by any shift sequence needed
 | |
|     to restore the initial shift state; the resulting state described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.30.1.2p4'></a>
 | |
| <pre>4   The c8rtomb function returns the number of bytes stored in the array object (including any shift
 | |
|     sequences). When c8 is not a valid character, an encoding error occurs: the function stores the value
 | |
|     of the macro EILSEQ in errno and returns (size_t) (−1); the conversion state is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.30.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.30.1.3 [The mbrtoc16 function]</h3>
 | |
| <a name='7.30.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <uchar.h>
 | |
|               size_t mbrtoc16(char16_t * restrict pc16, const char * restrict s, size_t n,
 | |
|                     mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.30.1.3p2'></a>
 | |
| <pre>2   If s is a null pointer, the mbrtoc16 function is equivalent to the call:
 | |
| 
 | |
|                       mbrtoc16(NULL, "", 1, ps)
 | |
| 
 | |
| 
 | |
|     In this case, the values of the parameters pc16 and n are ignored.
 | |
| </pre>
 | |
| <a name='7.30.1.3p3'></a>
 | |
| <pre>3   If s is not a null pointer, the mbrtoc16 function inspects at most n bytes beginning with the byte
 | |
|     pointed to by s to determine the number of bytes needed to complete the next multibyte character
 | |
|     (including any shift sequences). If the function determines that the next multibyte character is
 | |
|     complete and valid, it determines the values of the corresponding wide characters and then, if pc16
 | |
|     is not a null pointer, stores the value of the first (or only) such character in the object pointed to by
 | |
|     pc16. Subsequent calls will store successive wide characters without consuming any additional
 | |
|     input until all the characters have been stored. If the corresponding wide character is the null wide
 | |
|     character, the resulting state described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.30.1.3p4'></a>
 | |
| <pre>4   The mbrtoc16 function returns the first of the following that applies (given the current conversion
 | |
|     state):
 | |
| 
 | |
|     0                   if the next n or fewer bytes complete the multibyte character that corresponds to
 | |
|                         the null wide character (which is the value stored).
 | |
| 
 | |
|     between 1 and n inclusive if the next n or fewer bytes complete a valid multibyte character (which
 | |
|                      is the value stored); the value returned is the number of bytes that complete the
 | |
|                      multibyte character.
 | |
| 
 | |
|     (size_t) (−3) if the next character resulting from a previous call has been stored (no bytes from
 | |
|                         the input have been consumed by this call).
 | |
| 
 | |
|     (size_t) (−2) if the next n bytes contribute to an incomplete (but potentially valid) multibyte
 | |
|                   character, and all n bytes have been processed (no value is stored).<a href='#FOOTNOTE.396'><sup>[396]</sup></a>
 | |
| 
 | |
|     (size_t) (−1) if an encoding error occurs, in which case the next n or fewer bytes do not contribute
 | |
|                         to a complete and valid multibyte character (no value is stored); the value of the
 | |
|                         macro EILSEQ is stored in errno, and the conversion state is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.396'>
 | |
| <pre><i><b>Footnote 396)</b> When n has at least the value of the MB_CUR_MAX macro, this case can only occur if s points at a sequence of redundant
 | |
|     shift sequences (for implementations with state-dependent encodings).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.30.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.30.1.4 [The c16rtomb function]</h3>
 | |
| <a name='7.30.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <uchar.h>
 | |
|                size_t c16rtomb(char * restrict s, char16_t c16, mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.30.1.4p2'></a>
 | |
| <pre>2   If s is a null pointer, the c16rtomb function is equivalent to the call
 | |
| 
 | |
|                       c16rtomb(buf, u’\0’, ps)
 | |
| 
 | |
| 
 | |
|     where buf is an internal buffer.
 | |
| </pre>
 | |
| <a name='7.30.1.4p3'></a>
 | |
| <pre>3   If s is not a null pointer, the c16rtomb function determines the number of bytes needed to represent
 | |
|     the multibyte character that corresponds to the wide character given or completed by c16 (including
 | |
|     any shift sequences), and stores the multibyte character representation in the array whose first
 | |
|     element is pointed to by s, or stores nothing if c16 does not represent a complete character. At
 | |
|     most MB_CUR_MAX bytes are stored. If c16 is a null wide character, a null byte is stored, preceded by
 | |
|     any shift sequence needed to restore the initial shift state; the resulting state described is the initial
 | |
|     conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.30.1.4p4'></a>
 | |
| <pre>4   The c16rtomb function returns the number of bytes stored in the array object (including any shift
 | |
|     sequences). When c16 is not a valid wide character, an encoding error occurs: the function stores the
 | |
|     value of the macro EILSEQ in errno and returns (size_t) (−1); the conversion state is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.30.1.5'></a>
 | |
| <hr>
 | |
| <h3>7.30.1.5 [The mbrtoc32 function]</h3>
 | |
| <a name='7.30.1.5p1'></a>
 | |
| <pre>1     Synopsis
 | |
|              #include <uchar.h>
 | |
|               size_t mbrtoc32(char32_t * restrict pc32, const char * restrict s, size_t n,
 | |
|                     mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.30.1.5p2'></a>
 | |
| <pre>2   If s is a null pointer, the mbrtoc32 function is equivalent to the call:
 | |
| 
 | |
|                       mbrtoc32(NULL, "", 1, ps)
 | |
| 
 | |
| 
 | |
|     In this case, the values of the parameters pc32 and n are ignored.
 | |
| </pre>
 | |
| <a name='7.30.1.5p3'></a>
 | |
| <pre>3   If s is not a null pointer, the mbrtoc32 function inspects at most n bytes beginning with the byte
 | |
|     pointed to by s to determine the number of bytes needed to complete the next multibyte character
 | |
|     (including any shift sequences). If the function determines that the next multibyte character is
 | |
|     complete and valid, it determines the values of the corresponding wide characters and then, if pc32
 | |
|     is not a null pointer, stores the value of the first (or only) such character in the object pointed to by
 | |
|     pc32. Subsequent calls will store successive wide characters without consuming any additional
 | |
|     input until all the characters have been stored. If the corresponding wide character is the null wide
 | |
|     character, the resulting state described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.30.1.5p4'></a>
 | |
| <pre>4   The mbrtoc32 function returns the first of the following that applies (given the current conversion
 | |
|     state):
 | |
| 
 | |
|     0                   if the next n or fewer bytes complete the multibyte character that corresponds to
 | |
|                         the null wide character (which is the value stored).
 | |
| 
 | |
|     between 1 and n inclusive if the next n or fewer bytes complete a valid multibyte character (which
 | |
|                      is the value stored); the value returned is the number of bytes that complete the
 | |
|                      multibyte character.
 | |
| 
 | |
|     (size_t) (−3) if the next character resulting from a previous call has been stored (no bytes from
 | |
|                         the input have been consumed by this call).
 | |
| 
 | |
|     (size_t) (−2) if the next n bytes contribute to an incomplete (but potentially valid) multibyte
 | |
|                   character, and all n bytes have been processed (no value is stored).<a href='#FOOTNOTE.397'><sup>[397]</sup></a>
 | |
| 
 | |
|     (size_t) (−1) if an encoding error occurs, in which case the next n or fewer bytes do not contribute
 | |
|                         to a complete and valid multibyte character (no value is stored); the value of the
 | |
|                         macro EILSEQ is stored in errno, and the conversion state is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.397'>
 | |
| <pre><i><b>Footnote 397)</b> When n has at least the value of the MB_CUR_MAX macro, this case can only occur if s points at a sequence of redundant
 | |
|     shift sequences (for implementations with state-dependent encodings).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.30.1.6'></a>
 | |
| <hr>
 | |
| <h3>7.30.1.6 [The c32rtomb function]</h3>
 | |
| <a name='7.30.1.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <uchar.h>
 | |
|               size_t c32rtomb(char * restrict s, char32_t c32, mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.30.1.6p2'></a>
 | |
| <pre>2   If s is a null pointer, the c32rtomb function is equivalent to the call
 | |
| 
 | |
|                       c32rtomb(buf, U’\0’, ps)
 | |
| 
 | |
| 
 | |
|     where buf is an internal buffer.
 | |
| </pre>
 | |
| <a name='7.30.1.6p3'></a>
 | |
| <pre>3   If s is not a null pointer, the c32rtomb function determines the number of bytes needed to represent
 | |
|     the multibyte character that corresponds to the wide character given by c32 (including any shift
 | |
|     sequences), and stores the multibyte character representation in the array whose first element is
 | |
|     pointed to by s. At most MB_CUR_MAX bytes are stored. If c32 is a null wide character, a null byte is
 | |
|     stored, preceded by any shift sequence needed to restore the initial shift state; the resulting state
 | |
|     described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.30.1.6p4'></a>
 | |
| <pre>4   The c32rtomb function returns the number of bytes stored in the array object (including any shift
 | |
|     sequences). When c32 is not a valid wide character, an encoding error occurs: the function stores the
 | |
|     value of the macro EILSEQ in errno and returns (size_t) (−1);the conversion state is unspecified.
 | |
| </pre>
 | |
| <a name='7.31'></a>
 | |
| <hr>
 | |
| <h3>7.31 [Extended multibyte and wide character utilities <wchar.h>]</h3>
 | |
| <a name='7.31.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.1 [Introduction]</h3>
 | |
| <a name='7.31.1p1'></a>
 | |
| <pre>1   The header <wchar.h> defines four macros, and declares four data types, one tag, and many
 | |
|     functions.<a href='#FOOTNOTE.398'><sup>[398]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.398'>
 | |
| <pre><i><b>Footnote 398)</b> See "future library directions" (<a href='#7.33.20'>7.33.20</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.1p2'></a>
 | |
| <pre>2   The types declared are wchar_t and size_t (both described in <a href='#7.21'>7.21</a>);
 | |
| 
 | |
|               mbstate_t
 | |
| 
 | |
| 
 | |
|     which is a complete object type other than an array type that can hold the conversion state informa-
 | |
|     tion necessary to convert between sequences of multibyte characters and wide characters;
 | |
| 
 | |
|               wint_t
 | |
| 
 | |
| 
 | |
|     which is an integer type unchanged by default argument promotions that can hold any value
 | |
|     corresponding to members of the extended character set, as well as at least one value that does not
 | |
|     correspond to any member of the extended character set (see WEOF below);<a href='#FOOTNOTE.399'><sup>[399]</sup></a> and
 | |
| 
 | |
|               struct tm
 | |
| 
 | |
| 
 | |
|     which is declared as an incomplete structure type (the contents are described in <a href='#7.29.1'>7.29.1</a>).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.399'>
 | |
| <pre><i><b>Footnote 399)</b> wchar_t and wint_t can be the same integer type.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.1p3'></a>
 | |
| <pre>3   The macros defined are NULL (described in <a href='#7.21'>7.21</a>); WCHAR_MIN, WCHAR_MAX, and WCHAR_WIDTH (de-
 | |
|     scribed in <a href='#7.22'>7.22</a>); and
 | |
| 
 | |
|               WEOF
 | |
| 
 | |
| 
 | |
|     which expands to a constant expression of type wint_t whose value does not correspond to any
 | |
|     member of the extended character set.<a href='#FOOTNOTE.400'><sup>[400]</sup></a> It is accepted (and returned) by several functions in
 | |
|     this subclause to indicate end-of-file, that is, no more input from a stream. It is also used as a wide
 | |
|     character value that does not correspond to any member of the extended character set.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.400'>
 | |
| <pre><i><b>Footnote 400)</b> The value of the macro WEOF can differ from that of EOF and need not be negative.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.1p4'></a>
 | |
| <pre>4   The functions declared are grouped as follows:
 | |
| 
 | |
|       — Functions that perform input and output of wide characters, or multibyte characters, or both;
 | |
|       — Functions that provide wide string numeric conversion;
 | |
|       — Functions that perform general wide string manipulation;
 | |
|       — Functions for wide string date and time conversion; and
 | |
|       — Functions that provide extended capabilities for conversion between multibyte and wide
 | |
|         character sequences.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.1p5'></a>
 | |
| <pre>5   Arguments to the functions in this subclause may point to arrays containing wchar_t values that do
 | |
|     not correspond to members of the extended character set. Such values shall be processed according
 | |
|     to the specified semantics, except that it is unspecified whether an encoding error occurs if such a
 | |
|     value appears in the format string for a function in <a href='#7.31.2'>7.31.2</a> or <a href='#7.31.5'>7.31.5</a> and the specified semantics do
 | |
|     not require that value to be processed by wcrtomb.
 | |
| </pre>
 | |
| <a name='7.31.1p6'></a>
 | |
| <pre>6   Unless explicitly stated otherwise, if the execution of a function described in this subclause causes
 | |
|     copying to take place between objects that overlap, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.2 [Formatted wide character input/output functions]</h3>
 | |
| <a name='7.31.2p1'></a>
 | |
| <pre>1   The formatted wide character input/output functions shall behave as if there is a sequence point
 | |
|     after the actions associated with each specifier.<a href='#FOOTNOTE.401'><sup>[401]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.401'>
 | |
| <pre><i><b>Footnote 401)</b> The fwprintf functions perform writes to memory for the %n specifier.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.1 [The fwprintf function]</h3>
 | |
| <a name='7.31.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|                  #include <stdio.h>
 | |
|                   #include <wchar.h>
 | |
|                   int fwprintf(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.1p2'></a>
 | |
| <pre>2   The fwprintf function writes output to the stream pointed to by stream, under control of the wide
 | |
|     string pointed to by format that specifies how subsequent arguments are converted for output. If
 | |
|     there are insufficient arguments for the format, the behavior is undefined. If the format is exhausted
 | |
|     while arguments remain, the excess arguments are evaluated (as always) but are otherwise ignored.
 | |
|     The fwprintf function returns when the end of the format string is encountered.
 | |
| </pre>
 | |
| <a name='7.31.2.1p3'></a>
 | |
| <pre>3   The format is composed of zero or more directives: ordinary wide characters (not %), which are
 | |
|     copied unchanged to the output stream; and conversion specifications, each of which results in
 | |
|     fetching zero or more subsequent arguments, converting them, if applicable, according to the
 | |
|     corresponding conversion specifier, and then writing the result to the output stream.
 | |
| </pre>
 | |
| <a name='7.31.2.1p4'></a>
 | |
| <pre>4   Each conversion specification is introduced by the wide character %. After the %, the following
 | |
|     appear in sequence:
 | |
| 
 | |
|           — Zero or more flags (in any order) that modify the meaning of the conversion specification.
 | |
|           — An optional minimum field width. If the converted value has fewer wide characters than the
 | |
|             field width, it is padded with spaces (by default) on the left (or right, if the left adjustment flag,
 | |
|             described later, has been given) to the field width. The field width takes the form of an asterisk
 | |
|             * (described later) or a nonnegative decimal integer.<a href='#FOOTNOTE.402'><sup>[402]</sup></a>
 | |
|           — An optional precision that gives the minimum number of digits to appear for the b, d, i, o, u,
 | |
|             x, and X conversions, the number of digits to appear after the decimal-point wide character
 | |
|             for a, A, e, E, f, and F conversions, the maximum number of significant digits for the g and G
 | |
|             conversions, or the maximum number of wide characters to be written for s conversions. The
 | |
|             precision takes the form of a period (.) followed either by an asterisk * (described later) or by
 | |
|             an optional nonnegative decimal integer; if only the period is specified, the precision is taken
 | |
|             as zero. If a precision appears with any other conversion specifier, the behavior is undefined.
 | |
|           — An optional length modifier that specifies the size of the argument.
 | |
|           — A conversion specifier wide character that specifies the type of conversion to be applied.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.402'>
 | |
| <pre><i><b>Footnote 402)</b> Note that 0 is taken as a flag, not as the beginning of a field width.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.1p5'></a>
 | |
| <pre>5   As noted above, a field width, or precision, or both, may be indicated by an asterisk. In this case,
 | |
|     an int argument supplies the field width or precision. The arguments specifying field width, or
 | |
|     precision, or both, shall appear (in that order) before the argument (if any) to be converted. A
 | |
|     negative field width argument is taken as a - flag followed by a positive field width. A negative
 | |
|     precision argument is taken as if the precision were omitted.
 | |
| </pre>
 | |
| <a name='7.31.2.1p6'></a>
 | |
| <pre>6   The flag wide characters and their meanings are:
 | |
| 
 | |
|     -           The result of the conversion is left-justified within the field. (It is right-justified if this flag is
 | |
|                 not specified.)
 | |
|     +           The result of a signed conversion always begins with a plus or minus sign. (It begins with a
 | |
|                 sign only when a value with a negative sign is converted if this flag is not specified.) <a href='#FOOTNOTE.403'><sup>[403]</sup></a>
 | |
|     space If the first wide character of a signed conversion is not a sign, or if a signed conversion results
 | |
|           in no wide characters, a space is prefixed to the result. If the space and + flags both appear,
 | |
|           the space flag is ignored.
 | |
|     #         The result is converted to an "alternative form". For o conversion, it increases the precision, if
 | |
|               and only if necessary, to force the first digit of the result to be a zero (if the value and precision
 | |
|               are both 0, a single 0 is printed). For b conversion, a nonzero result has 0b prefixed to it. For
 | |
|               x (or X) conversion, a nonzero result has 0x (or 0X) prefixed to it. For a, A, e, E, f, F, g, and G
 | |
|               conversions, the result of converting a floating-point number always contains a decimal-point
 | |
|               wide character, even if no digits follow it. (Normally, a decimal-point wide character appears
 | |
|               in the result of these conversions only if a digit follows it.) For g and G conversions, trailing
 | |
|               zeros are not removed from the result. For other conversions, the behavior is undefined.
 | |
|     0         For b, d, i, o, u, x, X, a, A, e, E, f, F, g, and G conversions, leading zeros (following any
 | |
|               indication of sign or base) are used to pad to the field width rather than performing space
 | |
|               padding, except when converting an infinity or NaN. If the 0 and - flags both appear, the
 | |
|               0 flag is ignored. For d, i, o, u, x, and X conversions, if a precision is specified, the 0 flag is
 | |
|               ignored. For other conversions, the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.403'>
 | |
| <pre><i><b>Footnote 403)</b> The results of all floating conversions of a negative zero, and of negative values that round to zero, include a minus sign.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.1p7'></a>
 | |
| <pre>7   The length modifiers and their meanings are:
 | |
| 
 | |
|     hh             Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a
 | |
|                    signed char or unsigned char argument (the argument will have been promoted
 | |
|                    according to the integer promotions, but its value shall be converted to signed char or
 | |
|                    unsigned char before printing); or that a following n conversion specifier applies to a
 | |
|                    pointer to a signed char argument.
 | |
|     h              Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a short int
 | |
|                    or unsigned short int argument (the argument will have been promoted accord-
 | |
|                    ing to the integer promotions, but its value shall be converted to short int or
 | |
|                    unsigned short int before printing); or that a following n conversion specifier applies
 | |
|                    to a pointer to a short int argument.
 | |
|     l (ell)        Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a long int
 | |
|                    or unsigned long int argument; that a following n conversion specifier applies to
 | |
|                    a pointer to a long int argument; that a following c conversion specifier applies to
 | |
|                    a wint_t argument; that a following s conversion specifier applies to a pointer to a
 | |
|                    wchar_t argument; or has no effect on a following a, A, e, E, f, F, g, or G conversion
 | |
|                    specifier.
 | |
|     ll (ell-ell) Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a
 | |
|                  long long int or unsigned long long int argument; or that a following n con-
 | |
|                  version specifier applies to a pointer to a long long int argument.
 | |
|     j              Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to an intmax_t
 | |
|                    or uintmax_t argument; or that a following n conversion specifier applies to a pointer
 | |
|                    to an intmax_t argument.
 | |
|     z              Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a size_t
 | |
|                    or the corresponding signed integer type argument; or that a following n conversion
 | |
|                    specifier applies to a pointer to a signed integer type corresponding to size_t argument.
 | |
|     t              Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a ptrdiff_t
 | |
|                    or the corresponding unsigned integer type argument; or that a following n conversion
 | |
|                    specifier applies to a pointer to a ptrdiff_t argument.
 | |
|     wN             Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to an integer
 | |
|                    argument with a specific width where N is a positive decimal integer with no leading
 | |
|                    zeros (the argument will have been promoted according to the integer promotions, but
 | |
|                    its value shall be converted to the unpromoted type); or that a following n conversion
 | |
|                    specifier applies to a pointer to an integer type argument with a width of N bits. All
 | |
|                    minimum-width integer types (<a href='#7.22.1.2'>7.22.1.2</a>) and exact-width integer types (<a href='#7.22.1.1'>7.22.1.1</a>) de-
 | |
|                    fined in the header <stdint.h> shall be supported. Other supported values of N are
 | |
|                    implementation-defined.
 | |
|     wfN            Specifies that a following b, d, i, o, u, x, or X conversion specifier applies to a fastest
 | |
|                    minimum-width integer argument with a specific width where N is a positive decimal
 | |
|                    integer with no leading zeros (the argument will have been promoted according to
 | |
|                    the integer promotions, but its value shall be converted to the unpromoted type); or
 | |
|                    that a following n conversion specifier applies to a pointer to a fastest minimum-width
 | |
|                    integer type argument with a width of N bits. All fastest minimum-width integer types
 | |
|                    (<a href='#7.22.1.3'>7.22.1.3</a>) defined in the header <stdint.h> shall be supported. Other supported values
 | |
|                    of N are implementation-defined.
 | |
| 
 | |
|     L              Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                    long double argument.
 | |
| 
 | |
|     H              Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                    _Decimal32 argument.
 | |
| 
 | |
|     D              Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                    _Decimal64 argument.
 | |
| 
 | |
|     DD             Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to a
 | |
|                    _Decimal128 argument.
 | |
| 
 | |
| 
 | |
|     If a length modifier appears with any conversion specifier other than as specified above, the behavior
 | |
|     is undefined.
 | |
| </pre>
 | |
| <a name='7.31.2.1p8'></a>
 | |
| <pre>8   The conversion specifiers and their meanings are:
 | |
| 
 | |
|     d,i         The int argument is converted to signed decimal in the style [-]dddd. The precision
 | |
|                 specifies the minimum number of digits to appear; if the value being converted can be
 | |
|                 represented in fewer digits, it is expanded with leading zeros. The default precision is 1.
 | |
|                 The result of converting a zero value with a precision of zero is no wide characters.
 | |
|     b, o,u,x,X The unsigned int argument is converted to unsigned binary (b), unsigned octal (o),
 | |
|             unsigned decimal (u), or unsigned hexadecimal notation (x or X) in the style dddd; the
 | |
|             letters abcdef are used for x conversion and the letters ABCDEF for X conversion. The
 | |
|                 precision specifies the minimum number of digits to appear; if the value being converted
 | |
|                 can be represented in fewer digits, it is expanded with leading zeros. The default precision
 | |
|                 is 1. The result of converting a zero value with a precision of zero is no wide characters.
 | |
|     f,F         A double argument representing a floating-point number is converted to decimal notation
 | |
|                 in the style [-]ddd.ddd, where the number of digits after the decimal-point wide character
 | |
|                 is equal to the precision specification. If the precision is missing, it is taken as 6; if the
 | |
|                 precision is zero and the # flag is not specified, no decimal-point wide character appears.
 | |
|                 If a decimal-point wide character appears, at least one digit appears before it. The value is
 | |
|                 rounded to the appropriate number of digits.
 | |
|                 A double argument representing an infinity is converted in one of the styles [-]inf or
 | |
|                 [-]infinity — which style is implementation-defined. A double argument representing
 | |
|                 a NaN is converted in one of the styles [-]nan or [-]nan(n-wchar-sequence) — which style,
 | |
|                 and the meaning of any n-wchar-sequence, is implementation-defined. The F conversion
 | |
|                 specifier produces INF, INFINITY, or NAN instead of inf, infinity, or nan, respectively.<a href='#FOOTNOTE.404'><sup>[404]</sup></a>
 | |
|     e,E         A double argument representing a floating-point number is converted in the style
 | |
|                 [-]d.ddde±dd, where there is one digit (which is nonzero if the argument is nonzero)
 | |
|                 before the decimal-point wide character and the number of digits after it is equal to the
 | |
|                 precision; if the precision is missing, it is taken as 6; if the precision is zero and the #
 | |
|                 flag is not specified, no decimal-point wide character appears. The value is rounded to
 | |
|                 the appropriate number of digits. The E conversion specifier produces a number with E
 | |
|                 instead of e introducing the exponent. The exponent always contains at least two digits,
 | |
|             and only as many more digits as necessary to represent the exponent. If the value is zero,
 | |
|             the exponent is zero.
 | |
|             A double argument representing an infinity or NaN is converted in the style of an f or F
 | |
|             conversion specifier.
 | |
| g,G         A double argument representing a floating-point number is converted in style f or e (or
 | |
|             in style F or E in the case of a G conversion specifier), depending on the value converted
 | |
|             and the precision. Let P equal the precision if nonzero, 6 if the precision is omitted, or 1 if
 | |
|             the precision is zero. Then, if a conversion with style E would have an exponent of X:
 | |
| 
 | |
|                    if P > X ≥ −4, the conversion is with style f (or F) and precision P − (X + 1).
 | |
|                    otherwise, the conversion is with style e (or E) and precision P − 1.
 | |
| 
 | |
|             Finally, unless the # flag is used, any trailing zeros are removed from the fractional portion
 | |
|             of the result and the decimal-point wide character is removed if there is no fractional
 | |
|             portion remaining.
 | |
|             A double argument representing an infinity or NaN is converted in the style of an f or F
 | |
|             conversion specifier.
 | |
| a,A         A double argument representing a floating-point number is converted in the style
 | |
|             [-]0xh.hhhhp±d, where there is one hexadecimal digit (which is nonzero if the argument is a
 | |
|             normalized floating-point number and is otherwise unspecified) before the decimal-point
 | |
|             wide character<a href='#FOOTNOTE.405'><sup>[405]</sup></a> and the number of hexadecimal digits after it is equal to the precision;
 | |
|             if the precision is missing and FLT_RADIX is a power of 2, then the precision is sufficient
 | |
|             for an exact representation of the value; if the precision is missing and FLT_RADIX is not a
 | |
|             power of 2, then the precision is sufficient to distinguish<a href='#FOOTNOTE.406'><sup>[406]</sup></a> values of type double, except
 | |
|             that trailing zeros may be omitted; if the precision is zero and the # flag is not specified, no
 | |
|             decimal-point wide character appears. The letters abcdef are used for a conversion and
 | |
|             the letters ABCDEF for A conversion. The A conversion specifier produces a number with
 | |
|             X and P instead of x and p. The exponent always contains at least one digit, and only as
 | |
|             many more digits as necessary to represent the decimal exponent of 2. If the value is zero,
 | |
|             the exponent is zero.
 | |
|             A double argument representing an infinity or NaN is converted in the style of an f or F
 | |
|             conversion specifier.
 | |
|             If an H, D, or DD modifier is present and the precision is missing, then for a decimal
 | |
|             floating type argument represented by a triple of integers (s, c, q), where n is the number
 | |
|             of significant digits in the coefficient c,
 | |
| 
 | |
|               — if −(n + 5) ≤ q ≤ 0, use style f (or style F in the case of an A conversion specifier)
 | |
|                 with formatting precision equal to −q,
 | |
|               — otherwise, use style e (or style E in the case of an A conversion specifier) with format-
 | |
|                 ting precision equal to n − 1, with the exceptions that if c = 0 then the digit-sequence
 | |
|                 in the exponent-part shall have the value q (rather than 0), and that the exponent is
 | |
|  <a href='#FOOTNOTE.405'><sup>[405]</sup></a> Binary implementations can choose the hexadecimal digit to the left of the decimal-point wide character so that subsequent
 | |
| 
 | |
| digits align to nibble (4-bit) boundaries. This implementation choice affects numerical values printed with a precision P
 | |
| that is insufficient to represent all values exactly. Implementations with different conventions about the most significant
 | |
| hexadecimal digit will round at different places, affecting the numerical value of the hexadecimal result. For example,
 | |
| possible printed output for the code
 | |
| 
 | |
|           #include <stdio.h>
 | |
|           /* ... */
 | |
|           double x = 123.0;
 | |
|           printf("%.1a", x);
 | |
| 
 | |
| include "0x1.fp+6 " and "0xf.6p+3 " whose numerical values are 124 and 123, respectively. Portable code seeking identical
 | |
| numerical results on different platforms should avoid precisions P that require rounding.
 | |
|  <a href='#FOOTNOTE.406'><sup>[406]</sup></a> The formatting precision P is sufficient to distinguish values of the source type if 16P > bp where b (not a power of 2)
 | |
| 
 | |
| and p are the base and precision of the source type (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). A smaller P might suffice depending on the implementation’s
 | |
| scheme for determining the digit to the left of the decimal-point wide character.
 | |
|                         always expressed with the minimum number of digits required to represent its value
 | |
|                         (the exponent never contains a leading zero).
 | |
| 
 | |
|                  If the precision P is present (in the conversion specification) and is zero or at least as
 | |
|                  large as the precision p (<a href='#5.2.4.2.2'>5.2.4.2.2</a>) of the decimal floating type, the conversion is as if the
 | |
|                  precision were missing. If the precision P is present (and nonzero) and less than the
 | |
|                  precision p of the decimal floating type, the conversion first obtains an intermediate result
 | |
|                  as follows, where n is the number of significant digits in the coefficient:
 | |
| 
 | |
|                    — If n ≤ P , set the intermediate result to the input.
 | |
|                    — If n > P , round the input value, according to the current rounding direction for
 | |
|                      decimal floating-point operations, to P decimal digits, with unbounded exponent
 | |
|                      range, representing the result with a P -digit integer coefficient when in the form
 | |
|                      (s, c, q).
 | |
| 
 | |
|                  Convert the intermediate result in the manner described above for the case where the
 | |
|                  precision is missing.
 | |
|      c           If no l length modifier is present, the int argument is converted to a wide character as if
 | |
|                  by calling btowc and the resulting wide character is written.
 | |
|                  If an l length modifier is present, the wint_t argument is converted to wchar_t and
 | |
|                  written.
 | |
|      s           If no l length modifier is present, the argument shall be a pointer to storage of character
 | |
|                  type containing a multibyte character sequence beginning in the initial shift state. Charac-
 | |
|                  ters from the storage are converted as if by repeated calls to the mbrtowc function, with
 | |
|                  the conversion state described by an mbstate_t object initialized to zero before the first
 | |
|                  multibyte character is converted, and written up to (but not including) the terminating
 | |
|                  null wide character. If the precision is specified, no more than that many wide characters
 | |
|                  are written. If the precision is not specified or is greater than the size of the converted
 | |
|                  storage, the converted storage shall contain a null wide character.
 | |
|                  If an l length modifier is present, the argument shall be a pointer to storage of wchar_t
 | |
|                  type. Wide characters from the storage are written up to (but not including) a terminating
 | |
|                  null wide character. If the precision is specified, no more than that many wide characters
 | |
|                  are written. If the precision is not specified or is greater than the size of the array, the
 | |
|                  storage shall contain a null wide character.
 | |
|      p           The argument shall be a pointer to void or a pointer to a character type. The value of
 | |
|                  the pointer is converted to a sequence of printing wide characters, in an implementation-
 | |
|                  defined manner.
 | |
|      n           The argument shall be a pointer to signed integer whose type is specified by the length
 | |
|                  modifiers, if any, for the conversion specification, or shall be int if no length modifiers
 | |
|                  are specified for the conversion specification. The number of wide characters written to
 | |
|                  the output stream so far by this call to fwprintf is stored into the integer object pointed
 | |
|                  to by the argument. No argument is converted, but one is consumed. If the conversion
 | |
|                  specification includes any flags, a field width, or a precision, the behavior is undefined.
 | |
|      %           A % wide character is written. No argument is converted. The complete conversion
 | |
|                  specification shall be %%.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.404'>
 | |
| <pre><i><b>Footnote 404)</b> When applied to infinite and NaN values, the -, +, and space flag wide characters have their usual meaning; the # and 0
 | |
|     flag wide characters have no effect.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.405'>
 | |
| <pre><i><b>Footnote 405)</b> Binary implementations can choose the hexadecimal digit to the left of the decimal-point wide character so that subsequent
 | |
| digits align to nibble (4-bit) boundaries. This implementation choice affects numerical values printed with a precision P
 | |
| that is insufficient to represent all values exactly. Implementations with different conventions about the most significant
 | |
| hexadecimal digit will round at different places, affecting the numerical value of the hexadecimal result. For example,
 | |
| possible printed output for the code
 | |
|           #include <stdio.h>
 | |
|           /* ... */
 | |
|           double x = 123.0;
 | |
|           printf("%.1a", x);
 | |
| include "0x1.fp+6 " and "0xf.6p+3 " whose numerical values are 124 and 123, respectively. Portable code seeking identical
 | |
| numerical results on different platforms should avoid precisions P that require rounding.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.406'>
 | |
| <pre><i><b>Footnote 406)</b> The formatting precision P is sufficient to distinguish values of the source type if 16P > bp where b (not a power of 2)
 | |
| and p are the base and precision of the source type (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). A smaller P might suffice depending on the implementation’s
 | |
| scheme for determining the digit to the left of the decimal-point wide character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.405'>
 | |
| <pre><i><b>Footnote 405)</b> Binary implementations can choose the hexadecimal digit to the left of the decimal-point wide character so that subsequent
 | |
| digits align to nibble (4-bit) boundaries. This implementation choice affects numerical values printed with a precision P
 | |
| that is insufficient to represent all values exactly. Implementations with different conventions about the most significant
 | |
| hexadecimal digit will round at different places, affecting the numerical value of the hexadecimal result. For example,
 | |
| possible printed output for the code
 | |
|           #include <stdio.h>
 | |
|           /* ... */
 | |
|           double x = 123.0;
 | |
|           printf("%.1a", x);
 | |
| include "0x1.fp+6 " and "0xf.6p+3 " whose numerical values are 124 and 123, respectively. Portable code seeking identical
 | |
| numerical results on different platforms should avoid precisions P that require rounding.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.406'>
 | |
| <pre><i><b>Footnote 406)</b> The formatting precision P is sufficient to distinguish values of the source type if 16P > bp where b (not a power of 2)
 | |
| and p are the base and precision of the source type (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). A smaller P might suffice depending on the implementation’s
 | |
| scheme for determining the digit to the left of the decimal-point wide character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.1p9'></a>
 | |
| <pre>9    If a conversion specification is invalid, the behavior is undefined.<a href='#FOOTNOTE.407'><sup>[407]</sup></a> fwprintf shall behave as if it
 | |
|      uses va_arg with a type argument naming the type resulting from applying the default argument
 | |
|      promotions to the type corresponding to the conversion specification and then converting the result
 | |
|      of the va_arg expansion to the type corresponding to the conversion specification.<a href='#FOOTNOTE.408'><sup>[408]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.407'>
 | |
| <pre><i><b>Footnote 407)</b> See "future library directions" (<a href='#7.33.20'>7.33.20</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.408'>
 | |
| <pre><i><b>Footnote 408)</b> The behavior is undefined when the types differ as specified for va_arg <a href='#7.16.1.1'>7.16.1.1</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.1p10'></a>
 | |
| <pre>10   In no case does a nonexistent or small field width cause truncation of a field; if the result of a
 | |
|      conversion is wider than the field width, the field is expanded to contain the conversion result.
 | |
| </pre>
 | |
| <a name='7.31.2.1p11'></a>
 | |
| <pre>11    For a and A conversions, if FLT_RADIX is a power of 2, the value is correctly rounded to a hexadecimal
 | |
|       floating number with the given precision.
 | |
| 
 | |
|       Recommended practice
 | |
| </pre>
 | |
| <a name='7.31.2.1p12'></a>
 | |
| <pre>12    For a and A conversions, if FLT_RADIX is not a power of 2 and the result is not exactly representable
 | |
|       in the given precision, the result should be one of the two adjacent numbers in hexadecimal floating
 | |
|       style with the given precision, with the extra stipulation that the error should have a correct sign for
 | |
|       the current rounding direction.
 | |
| </pre>
 | |
| <a name='7.31.2.1p13'></a>
 | |
| <pre>13    For e, E, f, F, g, and G conversions, if the number of significant decimal digits is at most the maximum
 | |
|       value M of the T_DECIMAL_DIG macros (defined in <float.h>), then the result should be correctly
 | |
|       rounded.<a href='#FOOTNOTE.409'><sup>[409]</sup></a> If the number of significant decimal digits is more than M but the source value is
 | |
|       exactly representable with M digits, then the result should be an exact representation with trailing
 | |
|       zeros. Otherwise, the source value is bounded by two adjacent decimal strings L < U, both having
 | |
|       M significant digits; the value of the resultant decimal string D should satisfy L ≤ D ≤ U, with the
 | |
|       extra stipulation that the error should have a correct sign for the current rounding direction.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.409'>
 | |
| <pre><i><b>Footnote 409)</b> For binary-to-decimal conversion, the result format’s values are the numbers representable with the given format specifier.
 | |
|       The number of significant digits is determined by the format specifier, and in the case of fixed-point conversion by the source
 | |
|       value as well.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.1p14'></a>
 | |
| <pre>14    An uppercase B format specifier is not covered by the description above, because it used to be
 | |
|       available for extensions in previous versions of this standard.
 | |
|       Implementations that did not use an uppercase B as their own extension before are encouraged to
 | |
|       implement it similar to conversion specifier b as standardized above, with the alternative form (#B)
 | |
|       generating 0B as prefix for nonzero values.
 | |
| 
 | |
|       Returns
 | |
| </pre>
 | |
| <a name='7.31.2.1p15'></a>
 | |
| <pre>15    The fwprintf function returns the number of wide characters transmitted, or a negative value if
 | |
|       an output or encoding error occurred or if the implementation does not support a specified width
 | |
|       length modifier.
 | |
| 
 | |
|       Environmental limits
 | |
| </pre>
 | |
| <a name='7.31.2.1p16'></a>
 | |
| <pre>16    The number of wide characters that can be produced by any single conversion shall be at least 4095.
 | |
| </pre>
 | |
| <a name='7.31.2.1p17'></a>
 | |
| <pre>17    EXAMPLE To print a date and time in the form "Sunday, July 3, 10:02" followed by π to five decimal places:
 | |
| 
 | |
|                 #include <math.h>
 | |
|                 #include <stdio.h>
 | |
|                 #include <wchar.h>
 | |
|                 /* ... */
 | |
|                 wchar_t *weekday, *month; // pointers to wide strings
 | |
|                 int day, hour, min;
 | |
|                 fwprintf(stdout, L"%ls, %ls %d, %.2d:%.2d\n",
 | |
|                       weekday, month, day, hour, min);
 | |
|                 fwprintf(stdout, L"pi = %.5f\n", 4 * atan(1.0));
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.1p18'></a>
 | |
| <pre>18    EXAMPLE 1 In this example, multibyte characters do not have a state-dependent encoding, and the members of the extended
 | |
|       character set that consist of more than one byte each consist of exactly two bytes, the first of which is denoted here by a □
 | |
|       and the second by an uppercase letter.
 | |
| </pre>
 | |
| <a name='7.31.2.1p19'></a>
 | |
| <pre>19   Given the following wide string with length seven,
 | |
| 
 | |
|                 static wchar_t wstr[] = L"□X□Yabc□Z□W";
 | |
| 
 | |
|       the seven calls
 | |
| 
 | |
|                 fprintf(stdout, "|1234567890123|\n");
 | |
|                 fprintf(stdout, "|%13ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%-13.9ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%13.10ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%13.11ls|\n", wstr);
 | |
|                 fprintf(stdout, "|%13.15ls|\n", &wstr[2]);
 | |
|                 fprintf(stdout, "|%13lc|\n", (wint_t) wstr[5]);
 | |
| 
 | |
|      will print the following seven lines:
 | |
| 
 | |
|                  |1234567890123|
 | |
|                  | □X□Yabc□Z□W|
 | |
|                  |□X□Yabc□Z    |
 | |
|                  |    □X□Yabc□Z|
 | |
|                  | □X□Yabc□Z□W|
 | |
|                  |      abc□Z□W|
 | |
|                  |           □Z|
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.1p20'></a>
 | |
| <pre>20   EXAMPLE 2 Following are representations of _Decimal64 arguments as triples (s, c, q) and the corresponding character
 | |
|      sequences fprintf produces with "%Da":
 | |
|       (+1, 123, 0)                        123
 | |
|       (−1, 123, 0)                        -123
 | |
|       (+1, 123, −2)                       1.23
 | |
|       (+1, 123, 1)                        <a href='#1.'>1.</a>23e+3
 | |
|       (−1, 123, 1)                        -<a href='#1.'>1.</a>23e+3
 | |
|       (+1, 123, −8)                       0.00000123
 | |
|       (+1, 123, −9)                       <a href='#1.'>1.</a>23e-7
 | |
|       (+1, 120, −8)                       0.00000120
 | |
|       (+1, 120, −9)                       <a href='#1.'>1.</a>20e-7
 | |
|       (+1, 1234567890123456, 0)           1234567890123456
 | |
|       (+1, 1234567890123456, 1)           <a href='#1.'>1.</a>234567890123456e+16
 | |
|       (+1, 1234567890123456, −1)          123456789012345.6
 | |
|       (+1, 1234567890123456, −21)         0.000001234567890123456
 | |
|       (+1, 1234567890123456, −22)         <a href='#1.'>1.</a>234567890123456e-7
 | |
|       (+1, 0, 0)                          0
 | |
|       (−1, 0, 0)                          -0
 | |
|       (+1, 0, −6)                         0.000000
 | |
|       (+1, 0, −7)                         0e-7
 | |
|       (+1, 0, 2)                          0e+2
 | |
|       (+1, 5, −6)                         0.000005
 | |
|       (+1, 50, −7)                        0.0000050
 | |
|       (+1, 5, −7)                         5e-7
 | |
| 
 | |
|      To illustrate the effects of a precision specification, the sequence:
 | |
| 
 | |
|                 _Decimal32 x = 6543.00DF;                       // (+1, 654300, -2)
 | |
|                 fprintf(stdout, "%Ha\n", x);
 | |
|                 fprintf(stdout, "%.6Ha\n", x);
 | |
|                 fprintf(stdout, "%.5Ha\n", x);
 | |
|                 fprintf(stdout, "%.4Ha\n", x);
 | |
|                 fprintf(stdout, "%.3Ha\n", x);
 | |
|                 fprintf(stdout, "%.2Ha\n", x);
 | |
|                 fprintf(stdout, "%.1Ha\n", x);
 | |
|                 fprintf(stdout, "%.0Ha\n", x);
 | |
| 
 | |
|      assuming default rounding, results in:
 | |
|       6543.00
 | |
|       6543.00
 | |
|       6543.0
 | |
|       6543
 | |
|       <a href='#6.'>6.</a>54e+3
 | |
|       <a href='#6.'>6.</a>5e+3
 | |
|       7e+3
 | |
|       6543.00
 | |
| 
 | |
|      To illustrate the effects of the exponent range, the sequence:
 | |
| 
 | |
|                 _Decimal32 x = 9543210e87DF;                   // (+1, 9543210, 87)
 | |
|                 _Decimal32 y = 9500000e90DF;                   // (+1, 9500000, 90)
 | |
|                 fprintf(stdout, "%.6Ha\n", x);
 | |
|                 fprintf(stdout, "%.5Ha\n", x);
 | |
|                 fprintf(stdout, "%.4Ha\n", x);
 | |
|               fprintf(stdout, "%.3Ha\n", x);
 | |
|               fprintf(stdout, "%.2Ha\n", x);
 | |
|               fprintf(stdout, "%.1Ha\n", x);
 | |
|               fprintf(stdout, "%.1Ha\n", y);
 | |
| 
 | |
|     assuming default rounding, results in:
 | |
|      9.54321e+93
 | |
|      9.5432e+93
 | |
|      9.543e+93
 | |
|      9.54e+93
 | |
|      9.5e+93
 | |
|      1e+94
 | |
|      1e+97
 | |
| 
 | |
|     To further illustrate the effects of the exponent range, the sequence:
 | |
| 
 | |
|               _Decimal32 x = 9512345e90DF;                    // (+1, 9512345, 90)
 | |
|               _Decimal32 y = 9512345e86DF;                    // (+1, 9512345, 86)
 | |
|               fprintf(stdout, "%.3Ha\n", x);
 | |
|               fprintf(stdout, "%.2Ha\n", x);
 | |
|               fprintf(stdout, "%.1Ha\n", x);
 | |
|               fprintf(stdout, "%.2Ha\n", y);
 | |
| 
 | |
|     assuming default rounding, results in:
 | |
|      9.51e+96
 | |
|      9.5e+96
 | |
|      1e+97
 | |
|      9.5e+92
 | |
| 
 | |
|     Forward references: the btowc function (<a href='#7.31.6.1.1'>7.31.6.1.1</a>), the mbrtowc function (<a href='#7.31.6.3.2'>7.31.6.3.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.2 [The fwscanf function]</h3>
 | |
| <a name='7.31.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               int fwscanf(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.2p2'></a>
 | |
| <pre>2   The fwscanf function reads input from the stream pointed to by stream, under control of the wide
 | |
|     string pointed to by format that specifies the admissible input sequences and how they are to be
 | |
|     converted for assignment, using subsequent arguments as pointers to the objects to receive the
 | |
|     converted input. If there are insufficient arguments for the format, the behavior is undefined. If the
 | |
|     format is exhausted while arguments remain, the excess arguments are evaluated (as always) but
 | |
|     are otherwise ignored.
 | |
| </pre>
 | |
| <a name='7.31.2.2p3'></a>
 | |
| <pre>3   The format is composed of zero or more directives: one or more white-space wide characters, an
 | |
|     ordinary wide character (neither % nor a white-space wide character), or a conversion specification.
 | |
|     Each conversion specification is introduced by the wide character %. After the %, the following
 | |
|     appear in sequence:
 | |
| 
 | |
|        — An optional assignment-suppressing wide character *.
 | |
| 
 | |
|        — An optional decimal integer greater than zero that specifies the maximum field width (in wide
 | |
|          characters).
 | |
| 
 | |
|        — An optional length modifier that specifies the size of the receiving object.
 | |
| 
 | |
|        — A conversion specifier wide character that specifies the type of conversion to be applied.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.2p4'></a>
 | |
| <pre>4   The fwscanf function executes each directive of the format in turn. When all directives have been
 | |
|     executed, or if a directive fails (as detailed below), the function returns. Failures are described as
 | |
|      input failures (due to the occurrence of an encoding error or the unavailability of input characters),
 | |
|      or matching failures (due to inappropriate input).
 | |
| </pre>
 | |
| <a name='7.31.2.2p5'></a>
 | |
| <pre>5    A directive composed of white-space wide character(s) is executed by reading input up to the first
 | |
|      non-white-space wide character (which remains unread), or until no more wide characters can be
 | |
|      read. The directive never fails.
 | |
| </pre>
 | |
| <a name='7.31.2.2p6'></a>
 | |
| <pre>6    A directive that is an ordinary wide character is executed by reading the next wide character of
 | |
|      the stream. If that wide character differs from the directive,the directive fails and the differing and
 | |
|      subsequent wide characters remain unread. Similarly, if end-of-file, an encoding error, or a read
 | |
|      error prevents a wide character from being read, the directive fails.
 | |
| </pre>
 | |
| <a name='7.31.2.2p7'></a>
 | |
| <pre>7    A directive that is a conversion specification defines a set of matching input sequences, as described
 | |
|      below for each specifier. A conversion specification is executed in the following steps:
 | |
| </pre>
 | |
| <a name='7.31.2.2p8'></a>
 | |
| <pre>8    Input white-space wide characters are skipped, unless the specification includes a [, c, or n speci-
 | |
|      fier.<a href='#FOOTNOTE.410'><sup>[410]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.410'>
 | |
| <pre><i><b>Footnote 410)</b> These white-space wide characters are not counted against a specified field width.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.2p9'></a>
 | |
| <pre>9    An input item is read from the stream, unless the specification includes an n specifier. An input item
 | |
|      is defined as the longest sequence of input wide characters which does not exceed any specified
 | |
|      field width and which is, or is a prefix of, a matching input sequence.<a href='#FOOTNOTE.411'><sup>[411]</sup></a> The first wide character, if
 | |
|      any, after the input item remains unread. If the length of the input item is zero, the execution of the
 | |
|      directive fails; this condition is a matching failure unless end-of-file, an encoding error, or a read
 | |
|      error prevented input from the stream, in which case it is an input failure.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.411'>
 | |
| <pre><i><b>Footnote 411)</b> fwscanf pushes back at most one input wide character onto the input stream. Therefore, some sequences that are
 | |
|      acceptable to wcstod, wcstol, etc., are unacceptable to fwscanf.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.2p10'></a>
 | |
| <pre>10   Except in the case of a % specifier, the input item (or, in the case of a %n directive, the count of input
 | |
|      wide characters) is converted to a type appropriate to the conversion specifier. If the input item is
 | |
|      not a matching sequence, the execution of the directive fails: this condition is a matching failure.
 | |
|      Unless assignment suppression was indicated by a *, the result of the conversion is placed in the
 | |
|      object pointed to by the first argument following the format argument that has not already received
 | |
|      a conversion result. If this object does not have an appropriate type, or if the result of the conversion
 | |
|      cannot be represented in the object, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.31.2.2p11'></a>
 | |
| <pre>11   The length modifiers and their meanings are:
 | |
| 
 | |
|      hh          Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                  with type pointer to signed char or unsigned char.
 | |
| 
 | |
|      h           Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                  with type pointer to short int or unsigned short int.
 | |
| 
 | |
|      l (ell)     Specifies that a following d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                  with type pointer to long int or unsigned long int; that a following a, A, e, E, f, F,
 | |
|                  g, or G conversion specifier applies to an argument with type pointer to double; or that
 | |
|                  a following c, s, or [ conversion specifier applies to an argument with type pointer to
 | |
|                  wchar_t .
 | |
| 
 | |
|      ll (ell-ell) Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                   with type pointer to long long int or unsigned long long int.
 | |
| 
 | |
|      j           Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                  with type pointer to intmax_t or uintmax_t.
 | |
| 
 | |
|      z           Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                  with type pointer to size_t or the corresponding signed integer type.
 | |
| 
 | |
|      t           Specifies that a following b, d, i, o, u, x, X, or n conversion specifier applies to an argument
 | |
|                  with type pointer to ptrdiff_t or the corresponding unsigned integer type.
 | |
|      wN         Specifies that a following b, d, i, o, u, x, or X, or n conversion specifier applies to an
 | |
|                 argument which is a pointer to an integer with a specific width where N is a positive
 | |
|                 decimal integer with no leading zeros. All minimum-width integer types (<a href='#7.22.1.2'>7.22.1.2</a>) and
 | |
|                 exact-width integer types (<a href='#7.22.1.1'>7.22.1.1</a>) defined in the header <stdint.h> shall be supported.
 | |
|                 Other supported values of N are implementation-defined.
 | |
| 
 | |
|      wfN        Specifies that a following b, d, i, o, u, x, or X, or n conversion specifier applies to an
 | |
|                 argument which is a pointer to a fastest minimum-width integer with a specific width
 | |
|                 where N is a positive decimal integer with no leading zeros. All fastest minimum-width
 | |
|                 integer types (<a href='#7.22.1.3'>7.22.1.3</a>) defined in the header <stdint.h> shall be supported. Other
 | |
|                 supported values of N are implementation-defined.
 | |
| 
 | |
|      L          Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to long double.
 | |
| 
 | |
|      H          Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to _Decimal32 .
 | |
| 
 | |
|      D          Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to _Decimal64 .
 | |
| 
 | |
|      DD         Specifies that a following a, A, e, E, f, F, g, or G conversion specifier applies to an argument
 | |
|                 with type pointer to _Decimal128 .
 | |
| 
 | |
|      If a length modifier appears with any conversion specifier other than as specified above, the behavior
 | |
|      is undefined.
 | |
| </pre>
 | |
| <a name='7.31.2.2p12'></a>
 | |
| <pre>12   In the following, the type of the corresponding argument for a conversion specifier shall be a pointer
 | |
|      to a type determined by the length modifiers, if any, or specified by the conversion specifier. The
 | |
|      conversion specifiers and their meanings are:
 | |
| 
 | |
|      d         Matches an optionally signed decimal integer, whose format is the same as expected for
 | |
|                the subject sequence of the wcstol function with the value 10 for the base argument.
 | |
|                Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|                int.
 | |
| 
 | |
|      b         Matches an optionally signed binary integer, whose format is the same as expected for the
 | |
|                subject sequence of the wcstol function with the value 2 for the base argument. Unless a
 | |
|                length modifier is specified, the corresponding argument shall be a pointer to unsigned
 | |
|                int.
 | |
| 
 | |
|      i         Matches an optionally signed integer, whose format is the same as expected for the subject
 | |
|                sequence of the wcstol function with the value 0 for the base argument. Unless a length
 | |
|                modifier is specified, the corresponding argument shall be a pointer to int.
 | |
| 
 | |
|      o         Matches an optionally signed octal integer, whose format is the same as expected for
 | |
|                the subject sequence of the wcstoul function with the value 8 for the base argument.
 | |
|                Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|                unsigned int.
 | |
| 
 | |
|      u         Matches an optionally signed decimal integer, whose format is the same as expected for
 | |
|                the subject sequence of the wcstoul function with the value 10 for the base argument.
 | |
|                Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|                unsigned int.
 | |
| 
 | |
|      x         Matches an optionally signed hexadecimal integer, whose format is the same as expected
 | |
|                for the subject sequence of the wcstoul function with the value 16 for the base argument.
 | |
|                Unless a length modifier is specified, the corresponding argument shall be a pointer to
 | |
|                unsigned int.
 | |
| a,e,f,g Matches an optionally signed floating-point number, infinity, or NaN, whose format is
 | |
|         the same as expected for the subject sequence of the wcstod function. Unless a length
 | |
|         modifier is specified, the corresponding argument shall be a pointer to float.
 | |
| 
 | |
| c        Matches a sequence of wide characters of exactly the number specified by the field width
 | |
|          (1 if no field width is present in the directive).
 | |
|          If no l length modifier is present, characters from the input field are converted as if
 | |
|          by repeated calls to the wcrtomb function, with the conversion state described by an
 | |
|          mbstate_t object initialized to zero before the first wide character is converted. The
 | |
|          corresponding argument shall be a pointer to char, signed char, unsigned char, or
 | |
|          void that points to storage large enough to accept the sequence. No null character is
 | |
|          added.
 | |
|          If an l length modifier is present, the corresponding argument shall be a pointer to storage
 | |
|          of wchar_t large enough to accept the sequence.No null wide character is added.
 | |
| 
 | |
| s        Matches a sequence of non-white-space wide characters.
 | |
|          If no l length modifier is present, characters from the input field are converted as if
 | |
|          by repeated calls to the wcrtomb function, with the conversion state described by an
 | |
|          mbstate_t object initialized to zero before the first wide character is converted. The
 | |
|          corresponding argument shall be a pointer to char, signed char, unsigned char, or
 | |
|          void that points to storage large enough to accept the sequence and a terminating null
 | |
|          character, which will be added automatically.
 | |
|          If an l length modifier is present, the corresponding argument shall be a pointer to storage
 | |
|          of wchar_t large enough to accept the sequence and the terminating null wide character,
 | |
|          which will be added automatically.
 | |
| 
 | |
| [        Matches a nonempty sequence of wide characters from a set of expected characters (the
 | |
|          scanset).
 | |
|          If no l length modifier is present, characters from the input field are converted as if
 | |
|          by repeated calls to the wcrtomb function, with the conversion state described by an
 | |
|          mbstate_t object initialized to zero before the first wide character is converted. The
 | |
|          corresponding argument shall be a pointer to char, signed char, unsigned char, or
 | |
|          void that points to storage large enough to accept the sequence and a terminating null
 | |
|          character, which will be added automatically.
 | |
|          If an l length modifier is present, the corresponding argument shall be a pointer that
 | |
|          points to storage of wchar_t large enough to accept the sequence and the terminating null
 | |
|          wide character, which will be added automatically.
 | |
|          The conversion specifier includes all subsequent wide characters in the format string,
 | |
|          up to and including the matching right bracket (]). The wide characters between the
 | |
|          brackets (the scanlist) compose the scanset, unless the wide character after the left bracket
 | |
|          is a circumflex (^), in which case the scanset contains all wide characters that do not
 | |
|          appear in the scanlist between the circumflex and the right bracket. If the conversion
 | |
|          specifier begins with [] or [^], the right bracket wide character is in the scanlist and
 | |
|          the next following right bracket wide character is the matching right bracket that ends
 | |
|          the specification; otherwise the first following right bracket wide character is the one
 | |
|          that ends the specification. If a - wide character is in the scanlist and is not the first, nor
 | |
|          the second where the first wide character is a ^, nor the last character, the behavior is
 | |
|          implementation-defined.
 | |
| 
 | |
| p        Matches an implementation-defined set of sequences, which should be the same as the
 | |
|          set of sequences that may be produced by the %p conversion of the fwprintf function.
 | |
|          The corresponding argument shall be a pointer to a pointer of void. The input item is
 | |
|          converted to a pointer value in an implementation-defined manner. If the input item is a
 | |
|          value converted earlier during the same program execution, the pointer that results shall
 | |
|          compare equal to that value; otherwise the behavior of the %p conversion is undefined.
 | |
|      n           No input is consumed. The corresponding argument shall be a pointer of a signed integer
 | |
|                  type. The number of wide characters read from the input stream so far by this call to the
 | |
|                  fwscanf function is stored into the integer object pointed to by the argument. Execution
 | |
|                  of a %n directive does not increment the assignment count returned at the completion of
 | |
|                  execution of the fwscanf function. No argument is converted, but one is consumed. If
 | |
|                  the conversion specification includes an assignment-suppressing wide character or a field
 | |
|                  width, the behavior is undefined.
 | |
|      %           Matches a single % wide character; no conversion or assignment occurs. The complete
 | |
|                  conversion specification shall be %%.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.2p13'></a>
 | |
| <pre>13   If a conversion specification is invalid, the behavior is undefined.<a href='#FOOTNOTE.412'><sup>[412]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.412'>
 | |
| <pre><i><b>Footnote 412)</b> See "future library directions" (<a href='#7.33.20'>7.33.20</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.2p14'></a>
 | |
| <pre>14   The conversion specifiers A, E, F, G, and X are also valid and behave the same as, respectively, a, e, f,
 | |
|      g, and x.
 | |
| </pre>
 | |
| <a name='7.31.2.2p15'></a>
 | |
| <pre>15   Trailing white-space wide characters(including new-line wide characters) are left unread unless
 | |
|      matched by a directive. The success of literal matches and suppressed assignments is not directly
 | |
|      determinable other than via the %n directive.
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='7.31.2.2p16'></a>
 | |
| <pre>16   The fwscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|      conversion (if any) has completed. Otherwise, the function returns the number of input items
 | |
|      assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|      failure or if the implementation does not support a specific width length modifier.
 | |
| </pre>
 | |
| <a name='7.31.2.2p17'></a>
 | |
| <pre>17   EXAMPLE 1 The call:
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                #include <wchar.h>
 | |
|                /* ... */
 | |
|                int n, i; float x; wchar_t name[50];
 | |
|                n = fwscanf(stdin, L"%d%f%ls", &i, &x, name);
 | |
| 
 | |
| 
 | |
|      with the input line:
 | |
| 
 | |
|               25 54.32E-1 thompson
 | |
| 
 | |
| 
 | |
|      will assign to n the value 3, to i the value 25, to x the value 5.432, and to name the sequence thompson\0.
 | |
| </pre>
 | |
| <a name='7.31.2.2p18'></a>
 | |
| <pre>18   EXAMPLE 2 The call:
 | |
| 
 | |
|                #include <stdio.h>
 | |
|                #include <wchar.h>
 | |
|                /* ... */
 | |
|                int i; float x; double y;
 | |
|                fwscanf(stdin, L"%2d%f%*d %lf", &i, &x, &y);
 | |
| 
 | |
| 
 | |
|      with input:
 | |
| 
 | |
|               56789 0123 56a72
 | |
| 
 | |
| 
 | |
|      will assign to i the value 56 and to x the value 789.0, will skip past 0123, and will assign to y the value 56.0. The next wide
 | |
|      character read from the input stream will be a.
 | |
| 
 | |
|      Forward references: the wcstod, wcstof, and wcstold functions (<a href='#7.31.4.1.2'>7.31.4.1.2</a>), the wcstol, wcstoll,
 | |
|      wcstoul , and wcstoull functions (<a href='#7.31.4.1.4'>7.31.4.1.4</a>), the wcrtomb function (<a href='#7.31.6.3.3'>7.31.6.3.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.3 [The swprintf function]</h3>
 | |
| <a name='7.31.2.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <wchar.h>
 | |
|                int swprintf(wchar_t * restrict s, size_t n, const wchar_t * restrict format,
 | |
|                      ...);
 | |
| 
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='7.31.2.3p2'></a>
 | |
| <pre>2    The swprintf function is equivalent to fwprintf, except that the argument s specifies an array of
 | |
|      wide characters into which the generated output is to be written, rather than written to a stream.
 | |
|      No more than n wide characters are written, including a terminating null wide character, which is
 | |
|      always added (unless n is zero).
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='7.31.2.3p3'></a>
 | |
| <pre>3    The swprintf function returns the number of wide characters written in the array, not counting the
 | |
|      terminating null wide character, or a negative value if an encoding error occurred or if n or more
 | |
|      wide characters were requested to be written.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.4 [The swscanf function]</h3>
 | |
| <a name='7.31.2.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <wchar.h>
 | |
|                int swscanf(const wchar_t * restrict s, const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='7.31.2.4p2'></a>
 | |
| <pre>2    The swscanf function is equivalent to fwscanf, except that the argument s specifies a wide string
 | |
|      from which the input is to be obtained, rather than from a stream. Reaching the end of the wide
 | |
|      string is equivalent to encountering end-of-file for the fwscanf function.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.2.4p3'></a>
 | |
| <pre>3   The swscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the swscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.5'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.5 [The vfwprintf function]</h3>
 | |
| <a name='7.31.2.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               int vfwprintf(FILE * restrict stream, const wchar_t * restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.5p2'></a>
 | |
| <pre>2   The vfwprintf function is equivalent to fwprintf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vfwprintf function does not invoke the va_end macro<a href='#FOOTNOTE.413'><sup>[413]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.413'>
 | |
| <pre><i><b>Footnote 413)</b> As the functions vfwprintf , vswprintf , vfwscanf , vwprintf , vwscanf , and vswscanf invoke the va_arg macro, the
 | |
|     representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.5p3'></a>
 | |
| <pre>3   The vfwprintf function returns the number of wide characters transmitted, or a negative value if
 | |
|     an output or encoding error occurred.
 | |
| </pre>
 | |
| <a name='7.31.2.5p4'></a>
 | |
| <pre>4   EXAMPLE The following shows the use of the vfwprintf function in a general error-reporting routine.
 | |
| 
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
| 
 | |
|               void error(char *function_name, wchar_t *format, ...)
 | |
|               {
 | |
|                     va_list args;
 | |
| 
 | |
|                       va_start(args, format);
 | |
|                       // print out name of function causing error
 | |
|                       fwprintf(stderr, L"ERROR in %s: ", function_name);
 | |
|                       // print out remainder of message
 | |
|                       vfwprintf(stderr, format, args);
 | |
|                       va_end(args);
 | |
|               }
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.6'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.6 [The vfwscanf function]</h3>
 | |
| <a name='7.31.2.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               int vfwscanf(FILE * restrict stream, const wchar_t * restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.6p2'></a>
 | |
| <pre>2   The vfwscanf function is equivalent to fwscanf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vfwscanf function does not invoke the va_end macro.<a href='#FOOTNOTE.413'><sup>[413]</sup></a>
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.413'>
 | |
| <pre><i><b>Footnote 413)</b> As the functions vfwprintf , vswprintf , vfwscanf , vwprintf , vwscanf , and vswscanf invoke the va_arg macro, the
 | |
|     representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.6p3'></a>
 | |
| <pre>3   The vfwscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the vfwscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.7'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.7 [The vswprintf function]</h3>
 | |
| <a name='7.31.2.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdarg.h>
 | |
|             #include <wchar.h>
 | |
|             int vswprintf(wchar_t * restrict s, size_t n, const wchar_t * restrict format,
 | |
|                   va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.7p2'></a>
 | |
| <pre>2   The vswprintf function is equivalent to swprintf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vswprintf function does not invoke the va_end macro.<a href='#FOOTNOTE.413'><sup>[413]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.413'>
 | |
| <pre><i><b>Footnote 413)</b> As the functions vfwprintf , vswprintf , vfwscanf , vwprintf , vwscanf , and vswscanf invoke the va_arg macro, the
 | |
|     representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.7p3'></a>
 | |
| <pre>3   The vswprintf function returns the number of wide characters written in the array, not counting
 | |
|     the terminating null wide character, or a negative value if an encoding error occurred or if n or more
 | |
|     wide characters were requested to be generated.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.8'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.8 [The vswscanf function]</h3>
 | |
| <a name='7.31.2.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdarg.h>
 | |
|             #include <wchar.h>
 | |
|             int vswscanf(const wchar_t * restrict s, const wchar_t * restrict format,
 | |
|                   va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.8p2'></a>
 | |
| <pre>2   The vswscanf function is equivalent to swscanf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vswscanf function does not invoke the va_end macro.<a href='#FOOTNOTE.413'><sup>[413]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.413'>
 | |
| <pre><i><b>Footnote 413)</b> As the functions vfwprintf , vswprintf , vfwscanf , vwprintf , vwscanf , and vswscanf invoke the va_arg macro, the
 | |
|     representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.8p3'></a>
 | |
| <pre>3   The vswscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the vswscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.9'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.9 [The vwprintf function]</h3>
 | |
| <a name='7.31.2.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <stdarg.h>
 | |
|             #include <wchar.h>
 | |
|             int vwprintf(const wchar_t * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.9p2'></a>
 | |
| <pre>2   The vwprintf function is equivalent to wprintf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vwprintf function does not invoke the va_end macro.<a href='#FOOTNOTE.413'><sup>[413]</sup></a>
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.413'>
 | |
| <pre><i><b>Footnote 413)</b> As the functions vfwprintf , vswprintf , vfwscanf , vwprintf , vwscanf , and vswscanf invoke the va_arg macro, the
 | |
|     representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.9p3'></a>
 | |
| <pre>3   The vwprintf function returns the number of wide characters transmitted, or a negative value if an
 | |
|     output or encoding error occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.10'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.10 [The vwscanf function]</h3>
 | |
| <a name='7.31.2.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdarg.h>
 | |
|              #include <wchar.h>
 | |
|              int vwscanf(const wchar_t * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.10p2'></a>
 | |
| <pre>2   The vwscanf function is equivalent to wscanf, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vwscanf function does not invoke the va_end macro.<a href='#FOOTNOTE.413'><sup>[413]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.413'>
 | |
| <pre><i><b>Footnote 413)</b> As the functions vfwprintf , vswprintf , vfwscanf , vwprintf , vwscanf , and vswscanf invoke the va_arg macro, the
 | |
|     representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.2.10p3'></a>
 | |
| <pre>3   The vwscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the vwscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.11'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.11 [The wprintf function]</h3>
 | |
| <a name='7.31.2.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              int wprintf(const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.11p2'></a>
 | |
| <pre>2   The wprintf function is equivalent to fwprintf with the argument stdout interposed before the
 | |
|     arguments to wprintf.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.2.11p3'></a>
 | |
| <pre>3   The wprintf function returns the number of wide characters transmitted, or a negative value if an
 | |
|     output or encoding error occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.2.12'></a>
 | |
| <hr>
 | |
| <h3>7.31.2.12 [The wscanf function]</h3>
 | |
| <a name='7.31.2.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              int wscanf(const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.2.12p2'></a>
 | |
| <pre>2   The wscanf function is equivalent to fwscanf with the argument stdin interposed before the
 | |
|     arguments to wscanf.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.2.12p3'></a>
 | |
| <pre>3   The wscanf function returns the value of the macro EOF if an input failure occurs before the first
 | |
|     conversion (if any) has completed. Otherwise, the wscanf function returns the number of input
 | |
|     items assigned, which can be fewer than provided for, or even zero, in the event of an early matching
 | |
|     failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.3 [Wide character input/output functions]</h3>
 | |
| <a name='7.31.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.1 [The fgetwc function]</h3>
 | |
| <a name='7.31.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdio.h>
 | |
|                #include <wchar.h>
 | |
|                wint_t fgetwc(FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.1p2'></a>
 | |
| <pre>2   If the end-of-file indicator for the input stream pointed to by stream is not set and a next wide
 | |
|     character is present, the fgetwc function obtains that wide character as a wchar_t converted to a
 | |
|     wint_t and advances the associated file position indicator for the stream (if defined).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.1p3'></a>
 | |
| <pre>3   If the end-of-file indicator for the stream is set, or if the stream is at end-of-file, the end-of-file
 | |
|     indicator for the stream is set and the fgetwc function returns WEOF. Otherwise, the fgetwc function
 | |
|     returns the next wide character from the input stream pointed to by stream. If a read error occurs,
 | |
|     the error indicator for the stream is set and the fgetwc function returns WEOF. If an encoding error
 | |
|     occurs (including too few bytes), the error indicator for the stream is set and the value of the macro
 | |
|     EILSEQ is stored in errno and the fgetwc function returns WEOF.<a href='#FOOTNOTE.414'><sup>[414]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.414'>
 | |
| <pre><i><b>Footnote 414)</b> An end-of-file and a read error can be distinguished by use of the feof and ferror functions. Also, errno will be set to
 | |
|     EILSEQ by input/output functions only if an encoding error occurs.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.2 [The fgetws function]</h3>
 | |
| <a name='7.31.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                #include <wchar.h>
 | |
|                wchar_t *fgetws(wchar_t * restrict s, int n, FILE * restrict stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.2p2'></a>
 | |
| <pre>2   The fgetws function reads at most one less than the number of wide characters specified by n from
 | |
|     the stream pointed to by stream into the array pointed to by s. No additional wide characters are
 | |
|     read after a new-line wide character (which is retained) or after end-of-file. A null wide character is
 | |
|     written immediately after the last wide character read into the array.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.2p3'></a>
 | |
| <pre>3   The fgetws function returns s if successful. If end-of-file is encountered and no characters have
 | |
|     been read into the array, the contents of the array remain unchanged and a null pointer is returned.
 | |
|     If a read or encoding error occurs during the operation, the array members have an indeterminate
 | |
|     representation and a null pointer is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.3 [The fputwc function]</h3>
 | |
| <a name='7.31.3.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdio.h>
 | |
|                #include <wchar.h>
 | |
|                wint_t fputwc(wchar_t c, FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.3p2'></a>
 | |
| <pre>2   The fputwc function writes the wide character specified by c to the output stream pointed to by
 | |
|     stream, at the position indicated by the associated file position indicator for the stream (if defined),
 | |
|     and advances the indicator appropriately. If the file cannot support positioning requests, or if the
 | |
|     stream was opened with append mode, the character is appended to the output stream.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.3p3'></a>
 | |
| <pre>3   The fputwc function returns the wide character written. If a write error occurs, the error indicator
 | |
|     for the stream is set and fputwc returns WEOF. If an encoding error occurs, the value of the macro
 | |
|     EILSEQ is stored in errno and fputwc returns WEOF .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.4 [The fputws function]</h3>
 | |
| <a name='7.31.3.4p1'></a>
 | |
| <pre>1     Synopsis
 | |
|             #include <stdio.h>
 | |
|              #include <wchar.h>
 | |
|              int fputws(const wchar_t * restrict s, FILE * restrict stream);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.4p2'></a>
 | |
| <pre>2   The fputws function writes the wide string pointed to by s to the stream pointed to by stream. The
 | |
|     terminating null wide character is not written.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.4p3'></a>
 | |
| <pre>3   The fputws function returns EOF if a write or encoding error occurs; otherwise, it returns a nonnega-
 | |
|     tive value.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.5'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.5 [The fwide function]</h3>
 | |
| <a name='7.31.3.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdio.h>
 | |
|              #include <wchar.h>
 | |
|              int fwide(FILE *stream, int mode);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.5p2'></a>
 | |
| <pre>2   The fwide function determines the orientation of the stream pointed to by stream. If mode is greater
 | |
|     than zero, the function first attempts to make the stream wide oriented. If mode is less than zero,
 | |
|     the function first attempts to make the stream byte oriented.<a href='#FOOTNOTE.415'><sup>[415]</sup></a> Otherwise, mode is zero and the
 | |
|     function does not alter the orientation of the stream.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.415'>
 | |
| <pre><i><b>Footnote 415)</b> If the orientation of the stream has already been determined, fwide does not change it.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.3.5p3'></a>
 | |
| <pre>3   The fwide function returns a value greater than zero if, after the call, the stream has wide orientation,
 | |
|     a value less than zero if the stream has byte orientation, or zero if the stream has no orientation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.6'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.6 [The getwc function]</h3>
 | |
| <a name='7.31.3.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <stdio.h>
 | |
|              #include <wchar.h>
 | |
|              wint_t getwc(FILE *stream);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.6p2'></a>
 | |
| <pre>2   The getwc function is equivalent to fgetwc, except that if it is implemented as a macro, it may
 | |
|     evaluate stream more than once, so the argument should never be an expression with side effects.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.6p3'></a>
 | |
| <pre>3   The getwc function returns the next wide character from the input stream pointed to by stream, or
 | |
|     WEOF .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.7'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.7 [The getwchar function]</h3>
 | |
| <a name='7.31.3.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              wint_t getwchar(void);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.7p2'></a>
 | |
| <pre>2   The getwchar function is equivalent to getwc with the argument stdin.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.7p3'></a>
 | |
| <pre>3   The getwchar function returns the next wide character from the input stream pointed to by stdin,
 | |
|     or WEOF.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.8'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.8 [The putwc function]</h3>
 | |
| <a name='7.31.3.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               wint_t putwc(wchar_t c, FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.8p2'></a>
 | |
| <pre>2   The putwc function is equivalent to fputwc, except that if it is implemented as a macro, it may
 | |
|     evaluate stream more than once, so that argument should never be an expression with side effects.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.8p3'></a>
 | |
| <pre>3   The putwc function returns the wide character written, or WEOF.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.9'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.9 [The putwchar function]</h3>
 | |
| <a name='7.31.3.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               wint_t putwchar(wchar_t c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.9p2'></a>
 | |
| <pre>2   The putwchar function is equivalent to putwc with the second argument stdout.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.3.9p3'></a>
 | |
| <pre>3   The putwchar function returns the character written, or WEOF.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.3.10'></a>
 | |
| <hr>
 | |
| <h3>7.31.3.10 [The ungetwc function]</h3>
 | |
| <a name='7.31.3.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               wint_t ungetwc(wint_t c, FILE *stream);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.3.10p2'></a>
 | |
| <pre>2   The ungetwc function pushes the wide character specified by c back onto the input stream pointed
 | |
|     to by stream. Pushed-back wide characters will be returned by subsequent reads on that stream
 | |
|     in the reverse order of their pushing. A successful intervening call (with the stream pointed to by
 | |
|     stream) to a file positioning function (fseek, fsetpos, or rewind) discards any pushed-back wide
 | |
|     characters for the stream. The external storage corresponding to the stream is unchanged.
 | |
| </pre>
 | |
| <a name='7.31.3.10p3'></a>
 | |
| <pre>3   One wide character of pushback is guaranteed, even if the call to the ungetwc function follows just
 | |
|     after a call to a formatted wide character input function fwscanf, vfwscanf, vwscanf, or wscanf. If
 | |
|     the ungetwc function is called too many times on the same stream without an intervening read or
 | |
|     file positioning operation on that stream, the operation may fail.
 | |
| </pre>
 | |
| <a name='7.31.3.10p4'></a>
 | |
| <pre>4   If the value of c equals that of the macro WEOF, the operation fails and the input stream is unchanged.
 | |
| </pre>
 | |
| <a name='7.31.3.10p5'></a>
 | |
| <pre>5   A successful call to the ungetwc function clears the end-of-file indicator for the stream. The value of
 | |
|     the file position indicator for the stream after reading or discarding all pushed-back wide characters
 | |
|     is the same as it was before the wide characters were pushed back.<a href='#FOOTNOTE.416'><sup>[416]</sup></a> For a text or binary stream,
 | |
|     the value of its file position indicator after a successful call to the ungetwc function is unspecified
 | |
|     until all pushed-back wide characters are read or discarded.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.416'>
 | |
| <pre><i><b>Footnote 416)</b> Note that a file positioning function could further modify the file position indicator after discarding any pushed-back
 | |
|     wide characters.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.3.10p6'></a>
 | |
| <pre>6   The ungetwc function returns the wide character pushed back, or WEOF if the operation fails.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.4 [General wide string utilities]</h3>
 | |
| <a name='7.31.4p1'></a>
 | |
| <pre>1   The header <wchar.h> declares a number of functions useful for wide string manipulation. Various
 | |
|     methods are used for determining the lengths of the arrays, but in all cases a wchar_t* argument
 | |
|     points to the initial (lowest addressed) element of the array. If an array is accessed beyond the end
 | |
|     of an object, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.31.4p2'></a>
 | |
| <pre>2   Where an argument declared as size_t n determines the length of the array for a function, n can
 | |
|     have the value zero on a call to that function. Unless explicitly stated otherwise in the description of
 | |
|     a particular function in this subclause, pointer arguments on such a call shall still have valid values,
 | |
|     as described in <a href='#7.1.4'>7.1.4</a>. On such a call, a function that locates a wide character finds no occurrence, a
 | |
|     function that compares two wide character sequences returns zero, and a function that copies wide
 | |
|     characters copies zero wide characters.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.1 [Wide string numeric conversion functions]</h3>
 | |
| <a name='7.31.4.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.1.1 [General]</h3>
 | |
| <pre>This subclause describes wide string analogs of the strtod family of functions (<a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.24.1.6'>7.24.1.6</a>)417) .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.1.2 [The wcstod, wcstof, and wcstold functions]</h3>
 | |
| <a name='7.31.4.1.2p1'></a>
 | |
| <pre>1 #include <wchar.h>
 | |
|               double wcstod(const wchar_t * restrict nptr, wchar_t ** restrict endptr);
 | |
|               float wcstof(const wchar_t * restrict nptr, wchar_t ** restrict endptr);
 | |
|               long double wcstold(const wchar_t * restrict nptr, wchar_t ** restrict endptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
|    The wcstod, wcstof, and wcstold functions convert the initial portion of the wide string pointed to
 | |
|     by nptr to double, float, and long double representation, respectively. First, they decompose the
 | |
|     input string into three parts: an initial, possibly empty, sequence of white-space wide characters, a
 | |
|     subject sequence resembling a floating constant or representing an infinity or NaN; and a final wide
 | |
|     string of one or more unrecognized wide characters, including the terminating null wide character
 | |
|     of the input wide string. Then, they attempt to convert the subject sequence to a floating-point
 | |
|     number, and return the result.
 | |
| </pre>
 | |
| <a name='7.31.4.1.2p2'></a>
 | |
| <pre>2   The expected form of the subject sequence is an optional plus or minus sign, then one of the
 | |
|     following:
 | |
| 
 | |
|       — a nonempty sequence of decimal digits optionally containing a decimal-point wide character,
 | |
|            then an optional exponent part as defined for the corresponding single-byte characters in
 | |
|            <a href='#6.4.4.2'>6.4.4.2</a>, excluding any digit separators (<a href='#6.4.4.1'>6.4.4.1</a>);
 | |
|        — a 0x or 0X, then a nonempty sequence of hexadecimal digits optionally containing a decimal-
 | |
|          point wide character, then an optional binary exponent part as defined in <a href='#6.4.4.2'>6.4.4.2</a>, excluding
 | |
|          any digit separators (<a href='#6.4.4.1'>6.4.4.1</a>);
 | |
|        — INF or INFINITY, or any other wide string equivalent except for case
 | |
|        — NAN or NAN(n-wchar-sequenceopt ), or any other wide string equivalent except for case in the NAN
 | |
|          part, where:
 | |
|                    n-wchar-sequence:
 | |
|                            digit
 | |
|                            nondigit
 | |
|                            n-wchar-sequence digit
 | |
|                            n-wchar-sequence nondigit
 | |
| 
 | |
| 
 | |
|     The subject sequence is defined as the longest initial subsequence of the input wide string, starting
 | |
|     with the first non-white-space wide character, that is of the expected form. The subject sequence
 | |
|     contains no wide characters if the input wide string is not of the expected form.
 | |
| </pre>
 | |
| <a name='7.31.4.1.2p3'></a>
 | |
| <pre>3   If the subject sequence has the expected form for a floating-point number, the sequence of wide
 | |
|     characters starting with the first digit or the decimal-point wide character (whichever occurs first) is
 | |
|     interpreted as a floating constant according to the rules of <a href='#6.4.4.2'>6.4.4.2</a>, except that the decimal-point wide
 | |
|     character is used in place of a period, and that if neither an exponent part nor a decimal-point wide
 | |
|     character appears in a decimal floating-point number, or if a binary exponent part does not appear
 | |
|     in a hexadecimal floating-point number, an exponent part of the appropriate type with value zero is
 | |
|     assumed to follow the last digit in the string.
 | |
|     If the subject sequence begins with a minus sign, the sequence is interpreted as negated.<a href='#FOOTNOTE.418'><sup>[418]</sup></a>
 | |
|     A wide character sequence INF or INFINITY is interpreted as an infinity, if representable in the
 | |
|     return type, else like a floating constant that is too large for the range of the return type. A wide
 | |
|     character sequence NAN or NAN(n-wchar-sequenceopt ) is interpreted as a quiet NaN, if supported in
 | |
|     the return type, else like a subject sequence part that does not have the expected form; the meaning
 | |
|     of the n-wchar sequence is implementation-defined.<a href='#FOOTNOTE.419'><sup>[419]</sup></a>
 | |
|     A pointer to the final wide string is stored in the object pointed to by endptr, provided that endptr
 | |
|     is not a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.418'>
 | |
| <pre><i><b>Footnote 418)</b> It is unspecified whether a minus-signed sequence is converted to a negative number directly or by negating the value
 | |
|     resulting from converting the corresponding unsigned sequence (see <a href='#F.5'>F.5</a>); the two methods could yield different results if
 | |
|     rounding is toward positive or negative infinity. In either case, the functions honor the sign of zero if floating-point arithmetic
 | |
|     supports signed zeros.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.419'>
 | |
| <pre><i><b>Footnote 419)</b> An implementation can use the n-wchar sequence to determine extra information to be represented in the NaN’s
 | |
|     significand.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.4.1.2p4'></a>
 | |
| <pre>4   If the subject sequence has the hexadecimal form and FLT_RADIX is a power of 2, the value resulting
 | |
|     from the conversion is correctly rounded.
 | |
| </pre>
 | |
| <a name='7.31.4.1.2p5'></a>
 | |
| <pre>5   In other than the "C" locale, additional locale-specific subject sequence forms may be accepted.
 | |
| </pre>
 | |
| <a name='7.31.4.1.2p6'></a>
 | |
| <pre>6   If the subject sequence is empty or does not have the expected form, no conversion is performed; the
 | |
|     value of nptr is stored in the object pointed to by endptr, provided that endptr is not a null pointer.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='7.31.4.1.2p7'></a>
 | |
| <pre>7   If the subject sequence has the hexadecimal form, FLT_RADIX is not a power of 2, and the result is
 | |
|     not exactly representable, the result should be one of the two numbers in the appropriate internal
 | |
|     format that are adjacent to the hexadecimal floating source value, with the extra stipulation that the
 | |
|     error should have a correct sign for the current rounding direction.
 | |
| </pre>
 | |
| <a name='7.31.4.1.2p8'></a>
 | |
| <pre>8   If the subject sequence has the decimal form and at most M significant digits, where M is the
 | |
|     maximum value of the T_DECIMAL_DIG macros (defined in <float.h>), the result should be correctly
 | |
|     rounded. If the subject sequence D has the decimal form and more than M significant digits, consider
 | |
|     the two bounding, adjacent decimal strings L and U, both having M significant digits, such that the
 | |
|     values of L, D, and U satisfy L ≤ D ≤ U. The result should be one of the (equal or adjacent) values
 | |
|     that would be obtained by correctly rounding L and U according to the current rounding direction,
 | |
|     with the extra stipulation that the error with respect to D should have a correct sign for the current
 | |
|     rounding direction.<a href='#FOOTNOTE.420'><sup>[420]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.420'>
 | |
| <pre><i><b>Footnote 420)</b> M is sufficiently large that L and U will usually correctly round to the same internal floating value, but if not will correctly
 | |
|     round to adjacent values.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.4.1.2p9'></a>
 | |
| <pre>9   The functions return the converted value, if any. If no conversion could be performed, zero is
 | |
|     returned.
 | |
|     If the correct value overflows and default rounding is in effect (<a href='#7.12.1'>7.12.1</a>), plus or minus HUGE_VAL,
 | |
|     HUGE_VALF, or HUGE_VALL is returned (according to the return type and sign of the value); if the
 | |
|     integer expression math_errhandling & MATH_ERRNO is nonzero, the integer expression errno
 | |
|     acquires the value of ERANGE; if the integer expression math_errhandling & MATH_ERREXCEPT is
 | |
|     nonzero, the "overflow" floating-point exception is raised.
 | |
|     If the result underflows (<a href='#7.12.1'>7.12.1</a>), the functions return a value whose magnitude is no greater
 | |
|     than the smallest normalized positive number in the return type; if the integer expression
 | |
|     math_errhandling & MATH_ERRNO is nonzero, whether errno acquires the value ERANGE is
 | |
|     implementation-defined; if the integer expression math_errhandling & MATH_ERREXCEPT is
 | |
|     nonzero, whether the "underflow" floating-point exception is raised is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.1.3 [The wcstodN functions]</h3>
 | |
| <a name='7.31.4.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <wchar.h>
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                _Decimal32 wcstod32(const wchar_t * restrict nptr, char ** restrict endptr);
 | |
|                _Decimal64 wcstod64(const wchar_t * restrict nptr,char ** restrict endptr);
 | |
|                _Decimal128 wcstod128(const wchar_t * restrict nptr,char ** restrict endptr);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.1.3p2'></a>
 | |
| <pre>2   The wcstodN functions convert the initial portion of the wide string pointed to by nptr to decimal
 | |
|     floating type representation. First, they decompose the input wide string into three parts: an initial,
 | |
|     possibly empty, sequence of white-space wide characters; a subject sequence resembling a floating
 | |
|     constant or representing an infinity or NaN; and a final wide string of one or more unrecognized
 | |
|     wide characters, including the terminating null wide character of the input wide string. Then, they
 | |
|     attempt to convert the subject sequence to a floating-point number, and return the result.
 | |
| </pre>
 | |
| <a name='7.31.4.1.3p3'></a>
 | |
| <pre>3   The expected form of the subject sequence is an optional plus or minus sign, then one of the
 | |
|     following:
 | |
| 
 | |
|        — a nonempty sequence of decimal digits optionally containing a decimal-point wide character,
 | |
|          then an optional exponent part as defined in <a href='#6.4.4.2'>6.4.4.2</a>, excluding any digit separators (<a href='#6.4.4.1'>6.4.4.1</a>)
 | |
| 
 | |
|        — INF or INFINITY, ignoring case
 | |
| 
 | |
|        — NAN or NAN(d-wchar-sequenceopt ), ignoring case in the NAN part, where:                                              d-wchar-
 | |
|          sequence:
 | |
|                           digit
 | |
|                           nondigit
 | |
|                           d-wchar-sequence digit
 | |
|                           d-wchar-sequence nondigit
 | |
|     The subject sequence is defined as the longest initial subsequence of the input wide string, starting
 | |
|     with the first non-white-space wide character, that is of the expected form. The subject sequence
 | |
|     contains no wide characters if the input wide string is not of the expected form.
 | |
| </pre>
 | |
| <a name='7.31.4.1.3p4'></a>
 | |
| <pre>4   If the subject sequence has the expected form for a floating-point number, the sequence of wide
 | |
|     characters starting with the first digit or the decimal-point wide character (whichever occurs first) is
 | |
|     interpreted as a floating constant according to the rules of <a href='#6.4.4.2'>6.4.4.2</a>, including correct rounding and
 | |
|     determination of the coefficient c and the quantum exponent q, with the following exceptions:
 | |
| 
 | |
|       — It is not a hexadecimal floating number.
 | |
|       — The decimal-point wide character is used in place of a period.
 | |
|       — If neither an exponent part nor a decimal-point wide character appears in a decimal floating-
 | |
|         point number, an exponent part of the appropriate type with value zero is assumed to follow
 | |
|         the last digit in the wide string.
 | |
| 
 | |
|     If the subject sequence begins with a minus sign, the sequence is interpreted as negated (before
 | |
|     rounding) and the sign s is set to −1, else s is set to 1. A wide character sequence INF or INFINITY is
 | |
|     interpreted as an infinity. A wide character sequence NAN or NAN(d-wchar-sequenceopt ), is interpreted
 | |
|     as a quiet NaN; the meaning of the d-wchar sequence is implementation-defined.<a href='#FOOTNOTE.421'><sup>[421]</sup></a> A pointer to
 | |
|     the final wide string is stored in the object pointed to by endptr, provided that endptr is not a null
 | |
|     pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.421'>
 | |
| <pre><i><b>Footnote 421)</b> An implementation may use the d-wchar sequence to determine extra information to be represented in the NaN’s
 | |
|     significand.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.4.1.3p5'></a>
 | |
| <pre>5   In other than the "C" locale, additional locale-specific subject sequence forms may be accepted.
 | |
| </pre>
 | |
| <a name='7.31.4.1.3p6'></a>
 | |
| <pre>6   If the subject sequence is empty or does not have the expected form, no conversion is performed; the
 | |
|     value of nptr is stored in the object pointed to by endptr, provided that endptr is not a null pointer.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.1.3p7'></a>
 | |
| <pre>7   The wcstodN functions return the correctly rounded converted value, if any. If no conversion could
 | |
|     be performed, the value of the triple (+1, 0, 0) is returned. If the correct value overflows:
 | |
| 
 | |
|       — the value of the macro ERANGE is stored in errno if the integer expression
 | |
|         math_errhandling & MATH_ERRNO is nonzero;
 | |
| 
 | |
|       — the      "overflow"      floating-point     exception     is   raised   if   the   integer    expression
 | |
|           math_errhandling & MATH_ERREXCEPT is nonzero.
 | |
| 
 | |
|     If the result underflows (<a href='#7.12.1'>7.12.1</a>), whether errno acquires the value ERANGE if the integer expression
 | |
|     math_errhandling & MATH_ERRNO is nonzero is implementation-defined; if the integer expres-
 | |
|     sion math_errhandling & MATH_ERREXCEPT is nonzero, whether the "underflow" floating-point
 | |
|     exception is raised is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.1.4 [The wcstol, wcstoll, wcstoul, and wcstoull functions]</h3>
 | |
| <a name='7.31.4.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              long int wcstol(const wchar_t * restrict nptr, wchar_t ** restrict endptr,
 | |
|                    int base);
 | |
|              long long int wcstoll(const wchar_t * restrict nptr, wchar_t ** restrict endptr,
 | |
|                    int base);
 | |
|              unsigned long int wcstoul(const wchar_t * restrict nptr,
 | |
|                    wchar_t ** restrict endptr, int base);
 | |
|              unsigned long long int wcstoull(const wchar_t * restrict nptr,
 | |
|                    wchar_t ** restrict endptr, int base);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.1.4p2'></a>
 | |
| <pre>2   The wcstol, wcstoll, wcstoul, and wcstoull functions convert the initial portion of the
 | |
|     wide string pointed to by nptr to long int, long long int, unsigned long int, and
 | |
|     unsigned long long int representation, respectively. First, they decompose the input string into
 | |
|     three parts: an initial, possibly empty, sequence of white-space wide characters, a subject sequence
 | |
|     resembling an integer represented in some radix determined by the value of base, and a final wide
 | |
|     string of one or more unrecognized wide characters, including the terminating null wide character
 | |
|     of the input wide string. Then, they attempt to convert the subject sequence to an integer, and return
 | |
|     the result.
 | |
| </pre>
 | |
| <a name='7.31.4.1.4p3'></a>
 | |
| <pre>3   If the value of base is zero, the expected form of the subject sequence is that of an integer constant
 | |
|     as described for the corresponding single-byte characters in <a href='#6.4.4.1'>6.4.4.1</a>, optionally preceded by a plus or
 | |
|     minus sign, but not including an integer suffix or any optional digit separators (<a href='#6.4.4.1'>6.4.4.1</a>). If the value
 | |
|     of base is between 2 and 36 (inclusive), the expected form of the subject sequence is a sequence of
 | |
|     letters and digits representing an integer with the radix specified by base, optionally preceded by a
 | |
|     plus or minus sign, but not including an integer suffix or any optional digit separators. The letters
 | |
|     from a (or A) through z (or Z) are ascribed the values 10 through 35; only letters and digits whose
 | |
|     ascribed values are less than that of base are permitted. If the value of base is 2, the characters 0b or
 | |
|     0B may optionally precede the sequence of letters and digits, following the sign if present. If the
 | |
|     value of base is 16, the wide characters 0x or 0X may optionally precede the sequence of letters and
 | |
|     digits, following the sign if present.
 | |
| </pre>
 | |
| <a name='7.31.4.1.4p4'></a>
 | |
| <pre>4   The subject sequence is defined as the longest initial subsequence of the input wide string, starting
 | |
|     with the first non-white-space wide character, that is of the expected form. The subject sequence
 | |
|     contains no wide characters if the input wide string is empty or consists entirely of white-space
 | |
|     wide characters, or if the first non-white-space wide character is other than a sign or a permissible
 | |
|     letter or digit.
 | |
| </pre>
 | |
| <a name='7.31.4.1.4p5'></a>
 | |
| <pre>5   If the subject sequence has the expected form and the value of base is zero, the sequence of wide
 | |
|     characters starting with the first digit is interpreted as an integer constant according to the rules
 | |
|     of <a href='#6.4.4.1'>6.4.4.1</a>. If the subject sequence has the expected form and the value of base is between 2 and 36, it
 | |
|     is used as the base for conversion, ascribing to each letter its value as given above. If the subject
 | |
|     sequence begins with a minus sign, the value resulting from the conversion is negated (in the return
 | |
|     type). A pointer to the final wide string is stored in the object pointed to by endptr, provided that
 | |
|     endptr is not a null pointer.
 | |
| </pre>
 | |
| <a name='7.31.4.1.4p6'></a>
 | |
| <pre>6   In other than the "C" locale, additional locale-specific subject sequence forms may be accepted.
 | |
| </pre>
 | |
| <a name='7.31.4.1.4p7'></a>
 | |
| <pre>7   If the subject sequence is empty or does not have the expected form, no conversion is performed; the
 | |
|     value of nptr is stored in the object pointed to by endptr, provided that endptr is not a null pointer.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.1.4p8'></a>
 | |
| <pre>8   The wcstol, wcstoll, wcstoul, and wcstoull functions return the converted value, if any. If
 | |
|     no conversion could be performed, zero is returned. If the correct value is outside the range of
 | |
|     representable values, LONG_MIN, LONG_MAX, LLONG_MIN, LLONG_MAX, ULONG_MAX, or ULLONG_MAX is
 | |
|     returned (according to the return type sign of the value, if any), and the value of the macro ERANGE
 | |
|     is stored in errno.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.2 [Wide string copying functions]</h3>
 | |
| <a name='7.31.4.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.2.1 [The wcscpy function]</h3>
 | |
| <a name='7.31.4.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             wchar_t *wcscpy(wchar_t * restrict s1, const wchar_t * restrict s2);
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.2.1p2'></a>
 | |
| <pre>2   The wcscpy function copies the wide string pointed to by s2 (including the terminating null wide
 | |
|     character) into the array pointed to by s1.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.2.1p3'></a>
 | |
| <pre>3   The wcscpy function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.2.2 [The wcsncpy function]</h3>
 | |
| <a name='7.31.4.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               wchar_t *wcsncpy(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.2.2p2'></a>
 | |
| <pre>2   The wcsncpy function copies not more than n wide characters (those that follow a null wide character
 | |
|     are not copied) from the array pointed to by s2 to the array pointed to by s1.<a href='#FOOTNOTE.422'><sup>[422]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.422'>
 | |
| <pre><i><b>Footnote 422)</b> Thus, if there is no null wide character in the first n wide characters of the array pointed to by s2, the result will not be
 | |
|     null-terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.4.2.2p3'></a>
 | |
| <pre>3   If the array pointed to by s2 is a wide string that is shorter than n wide characters, null wide
 | |
|     characters are appended to the copy in the array pointed to by s1, until n wide characters in all have
 | |
|     been written.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.2.2p4'></a>
 | |
| <pre>4   The wcsncpy function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.2.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.2.3 [The wmemcpy function]</h3>
 | |
| <a name='7.31.4.2.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               wchar_t *wmemcpy(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.2.3p2'></a>
 | |
| <pre>2   The wmemcpy function copies n wide characters from the object pointed to by s2 to the object pointed
 | |
|     to by s1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.2.3p3'></a>
 | |
| <pre>3   The wmemcpy function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.2.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.2.4 [The wmemmove function]</h3>
 | |
| <a name='7.31.4.2.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               wchar_t *wmemmove(wchar_t *s1, const wchar_t *s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.2.4p2'></a>
 | |
| <pre>2   The wmemmove function copies n wide characters from the object pointed to by s2 to the object
 | |
|     pointed to by s1. Copying takes place as if the n wide characters from the object pointed to by s2
 | |
|     are first copied into a temporary array of n wide characters that does not overlap the objects pointed
 | |
|     to by s1 or s2, and then the n wide characters from the temporary array are copied into the object
 | |
|     pointed to by s1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.2.4p3'></a>
 | |
| <pre>3   The wmemmove function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.3 [Wide string concatenation functions]</h3>
 | |
| <a name='7.31.4.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.3.1 [The wcscat function]</h3>
 | |
| <a name='7.31.4.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               wchar_t *wcscat(wchar_t * restrict s1, const wchar_t * restrict s2);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.3.1p2'></a>
 | |
| <pre>2   The wcscat function appends a copy of the wide string pointed to by s2 (including the terminating
 | |
|     null wide character) to the end of the wide string pointed to by s1. The initial wide character of s2
 | |
|     overwrites the null wide character at the end of s1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.3.1p3'></a>
 | |
| <pre>3   The wcscat function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.3.2 [The wcsncat function]</h3>
 | |
| <a name='7.31.4.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              wchar_t *wcsncat(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.3.2p2'></a>
 | |
| <pre>2   The wcsncat function appends not more than n wide characters (a null wide character and those
 | |
|     that follow it are not appended) from the array pointed to by s2 to the end of the wide string pointed
 | |
|     to by s1. The initial wide character of s2 overwrites the null wide character at the end of s1. A
 | |
|     terminating null wide character is always appended to the result.<a href='#FOOTNOTE.423'><sup>[423]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.423'>
 | |
| <pre><i><b>Footnote 423)</b> Thus, the maximum number of wide characters that can end up in the array pointed to by s1 is wcslen(s1)+n+1 .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.4.3.2p3'></a>
 | |
| <pre>3   The wcsncat function returns the value of s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.4 [Wide string comparison functions]</h3>
 | |
| <a name='7.31.4.4p1'></a>
 | |
| <pre>1   Unless explicitly stated otherwise, the functions described in this subclause order two wide charac-
 | |
|     ters the same way as two integers of the underlying integer type designated by wchar_t.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.4.1 [The wcscmp function]</h3>
 | |
| <a name='7.31.4.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              int wcscmp(const wchar_t *s1, const wchar_t *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.4.1p2'></a>
 | |
| <pre>2   The wcscmp function compares the wide string pointed to by s1 to the wide string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.4.1p3'></a>
 | |
| <pre>3   The wcscmp function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     wide string pointed to by s1 is greater than, equal to, or less than the wide string pointed to by s2.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.4.2 [The wcscoll function]</h3>
 | |
| <a name='7.31.4.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              int wcscoll(const wchar_t *s1, const wchar_t *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.4.2p2'></a>
 | |
| <pre>2   The wcscoll function compares the wide string pointed to by s1 to the wide string pointed to by
 | |
|     s2, both interpreted as appropriate to the LC_COLLATE category of the current locale.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.4.2p3'></a>
 | |
| <pre>3   The wcscoll function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     wide string pointed to by s1 is greater than, equal to, or less than the wide string pointed to by s2
 | |
|     when both are interpreted as appropriate to the current locale.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.4.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.4.3 [The wcsncmp function]</h3>
 | |
| <a name='7.31.4.4.3p1'></a>
 | |
| <pre>1     Synopsis
 | |
|             #include <wchar.h>
 | |
|              int wcsncmp(const wchar_t *s1, const wchar_t *s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.4.3p2'></a>
 | |
| <pre>2   The wcsncmp function compares not more than n wide characters (those that follow a null wide
 | |
|     character are not compared) from the array pointed to by s1 to the array pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.4.3p3'></a>
 | |
| <pre>3   The wcsncmp function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     possibly null-terminated array pointed to by s1 is greater than, equal to, or less than the possibly
 | |
|     null-terminated array pointed to by s2.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.4.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.4.4 [The wcsxfrm function]</h3>
 | |
| <a name='7.31.4.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              size_t wcsxfrm(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.4.4p2'></a>
 | |
| <pre>2   The wcsxfrm function transforms the wide string pointed to by s2 and places the resulting wide
 | |
|     string into the array pointed to by s1. The transformation is such that if the wcscmp function is
 | |
|     applied to two transformed wide strings, it returns a value greater than, equal to, or less than zero,
 | |
|     corresponding to the result of the wcscoll function applied to the same two original wide strings.
 | |
|     No more than n wide characters are placed into the resulting array pointed to by s1, including the
 | |
|     terminating null wide character. If n is zero, s1 is permitted to be a null pointer.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.4.4p3'></a>
 | |
| <pre>3   The wcsxfrm function returns the length of the transformed wide string (not including the terminat-
 | |
|     ing null wide character). If the value returned is n or greater, the members of the array pointed to by
 | |
|     s1 have an indeterminate representation.
 | |
| </pre>
 | |
| <a name='7.31.4.4.4p4'></a>
 | |
| <pre>4   EXAMPLE The value of the following expression is the length of the array needed to hold the transformation of the wide
 | |
|     string pointed to by s:
 | |
| 
 | |
|              1 + wcsxfrm(NULL, s, 0)
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.4.5'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.4.5 [The wmemcmp function]</h3>
 | |
| <a name='7.31.4.4.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              int wmemcmp(const wchar_t *s1, const wchar_t *s2, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.4.5p2'></a>
 | |
| <pre>2   The wmemcmp function compares the first n wide characters of the object pointed to by s1 to the first
 | |
|     n wide characters of the object pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.4.5p3'></a>
 | |
| <pre>3   The wmemcmp function returns an integer greater than, equal to, or less than zero, accordingly as the
 | |
|     object pointed to by s1 is greater than, equal to, or less than the object pointed to by s2.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.5'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.5 [Wide string search functions]</h3>
 | |
| <a name='7.31.4.6'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6 [Introduction]</h3>
 | |
| <a name='7.31.4.6p1'></a>
 | |
| <pre>1   The stateless search functions in this section (wcschr, wcspbrk, wcsrchr, wmemchr, wcsstr) are
 | |
|     generic functions. These functions are generic in the qualification of the array to be searched and
 | |
|     will return a result pointer to an element with the same qualification as the passed array. If the array
 | |
|     to be searched is const-qualified, the result pointer will be to a const-qualified element. If the array
 | |
|     to be searched is not const-qualified<a href='#FOOTNOTE.424'><sup>[424]</sup></a> , the result pointer will be to an unqualified element.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.424'>
 | |
| <pre><i><b>Footnote 424)</b> The null pointer constant is not a pointer to a const-qualified type, and therefore the result expression has the type of a
 | |
|     pointer to an unqualified element; however, evaluating such a call is undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.4.6p2'></a>
 | |
| <pre>2   The external declarations of these generic functions have a concrete function type that returns a
 | |
|     pointer to an unqualified element of type wchar_t (named QWchar_t), and accepts a pointer to a
 | |
|     const-qualified array of the same type to search. This signature supports all correct uses. If a macro
 | |
|     definition of any of these generic functions is suppressed in order to access an actual function, the
 | |
|     external declaration with this concrete type is visible<a href='#FOOTNOTE.425'><sup>[425]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.425'>
 | |
| <pre><i><b>Footnote 425)</b> This is an obsolescent feature.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.4.6p3'></a>
 | |
| <pre>3   The volatile and restrict qualifiers are not accepted on the elements of the array to search.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.1 [The wcschr generic function]</h3>
 | |
| <a name='7.31.4.6.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               QWchar_t *wcschr(QWchar_t *s, wchar_t c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.1p2'></a>
 | |
| <pre>2   The wcschr generic function locates the first occurrence of c in the wide string pointed to by s. The
 | |
|     terminating null wide character is considered to be part of the wide string.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.1p3'></a>
 | |
| <pre>3   The wcschr generic function returns a pointer to the located wide character, or a null pointer if the
 | |
|     wide character does not occur in the wide string.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.2 [The wcscspn function]</h3>
 | |
| <a name='7.31.4.6.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               size_t wcscspn(const wchar_t *s1, const wchar_t *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.2p2'></a>
 | |
| <pre>2   The wcscspn function computes the length of the maximum initial segment of the wide string
 | |
|     pointed to by s1 which consists entirely of wide characters not from the wide string pointed to by
 | |
|     s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.2p3'></a>
 | |
| <pre>3   The wcscspn function returns the length of the segment.
 | |
| </pre>
 | |
| <a name='7.31.4.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.3 [The wcspbrk generic function]</h3>
 | |
| <a name='7.31.4.6.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             QWchar_t *wcspbrk(QWchar_t *s1, const wchar_t *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.3p2'></a>
 | |
| <pre>2   The wcspbrk generic function locates the first occurrence in the wide string pointed to by s1 of any
 | |
|     wide character from the wide string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.3p3'></a>
 | |
| <pre>3   The wcspbrk generic function returns a pointer to the wide character in s1, or a null pointer if no
 | |
|     wide character from s2 occurs in s1.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.4 [The wcsrchr generic function]</h3>
 | |
| <a name='7.31.4.6.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             QWchar_t *wcsrchr(const wchar_t *s, wchar_t c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.4p2'></a>
 | |
| <pre>2   The wcsrchr generic function locates the last occurrence of c in the wide string pointed to by s. The
 | |
|     terminating null wide character is considered to be part of the wide string.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.4p3'></a>
 | |
| <pre>3   The wcsrchr generic function returns a pointer to the wide character, or a null pointer if c does not
 | |
|     occur in the wide string.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.6.5'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.5 [The wcsspn function]</h3>
 | |
| <a name='7.31.4.6.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             size_t wcsspn(const wchar_t *s1, const wchar_t *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.5p2'></a>
 | |
| <pre>2   The wcsspn function computes the length of the maximum initial segment of the wide string pointed
 | |
|     to by s1 which consists entirely of wide characters from the wide string pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.5p3'></a>
 | |
| <pre>3   The wcsspn function returns the length of the segment.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.6.6'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.6 [The wcsstr generic function]</h3>
 | |
| <a name='7.31.4.6.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             QWchar_t *wcsstr(QWchar_t *s1, const wchar_t *s2);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.6p2'></a>
 | |
| <pre>2   The wcsstr generic function locates the first occurrence in the wide string pointed to by s1 of the
 | |
|     sequence of wide characters (excluding the terminating null wide character) in the wide string
 | |
|     pointed to by s2.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.6p3'></a>
 | |
| <pre>3   The wcsstr generic function returns a pointer to the located wide string, or a null pointer if the
 | |
|     wide string is not found. If s2 points to a wide string with zero length, the function returns s1.
 | |
| </pre>
 | |
| <a name='7.31.4.6.7'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.7 [The wcstok function]</h3>
 | |
| <a name='7.31.4.6.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             wchar_t *wcstok(wchar_t * restrict s1, const wchar_t * restrict s2,
 | |
|                   wchar_t ** restrict ptr);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.7p2'></a>
 | |
| <pre>2   A sequence of calls to the wcstok function breaks the wide string pointed to by s1 into a sequence
 | |
|     of tokens, each of which is delimited by a wide character from the wide string pointed to by s2. The
 | |
|     third argument points to a caller-provided wchar_t pointer into which the wcstok function stores
 | |
|     information necessary for it to continue scanning the same wide string.
 | |
| </pre>
 | |
| <a name='7.31.4.6.7p3'></a>
 | |
| <pre>3   The first call in a sequence has a non-null first argument and stores an initial value in the object
 | |
|     pointed to by ptr. Subsequent calls in the sequence have a null first argument and the object pointed
 | |
|     to by ptr is required to have the value stored by the previous call in the sequence, which is then
 | |
|     updated. The separator wide string pointed to by s2 may be different from call to call.
 | |
| </pre>
 | |
| <a name='7.31.4.6.7p4'></a>
 | |
| <pre>4   The first call in the sequence searches the wide string pointed to by s1 for the first wide character
 | |
|     that is not contained in the current separator wide string pointed to by s2. If no such wide character
 | |
|     is found, then there are no tokens in the wide string pointed to by s1 and the wcstok function
 | |
|     returns a null pointer. If such a wide character is found, it is the start of the first token.
 | |
| </pre>
 | |
| <a name='7.31.4.6.7p5'></a>
 | |
| <pre>5   The wcstok function then searches from there for a wide character that is contained in the current
 | |
|     separator wide string. If no such wide character is found, the current token extends to the end of the
 | |
|     wide string pointed to by s1, and subsequent searches in the same wide string for a token return
 | |
|     a null pointer. If such a wide character is found, it is overwritten by a null wide character, which
 | |
|     terminates the current token.
 | |
| </pre>
 | |
| <a name='7.31.4.6.7p6'></a>
 | |
| <pre>6   In all cases, the wcstok function stores sufficient information in the pointer pointed to by ptr so
 | |
|     that subsequent calls, with a null pointer for s1 and the unmodified pointer value for ptr, shall start
 | |
|     searching just past the element overwritten by a null wide character (if any).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.7p7'></a>
 | |
| <pre>7   The wcstok function returns a pointer to the first wide character of a token, or a null pointer if there
 | |
|     is no token.
 | |
| </pre>
 | |
| <a name='7.31.4.6.7p8'></a>
 | |
| <pre>8   EXAMPLE
 | |
| 
 | |
|             #include <wchar.h>
 | |
|             static wchar_t str1[] = L"?a???b,,,#c";
 | |
|             static wchar_t str2[] = L"\t \t";
 | |
|             wchar_t *t, *ptr1, *ptr2;
 | |
| 
 | |
|             t = wcstok(str1, L"?", &ptr1);            // t points to the token L"a"
 | |
|             t = wcstok(NULL, L",", &ptr1);            // t points to the token L"??b"
 | |
|             t = wcstok(str2, L" \t", &ptr2);          // t is a null pointer
 | |
|             t = wcstok(NULL, L"#,", &ptr1);           // t points to the token L"c"
 | |
|             t = wcstok(NULL, L"?", &ptr1);            // t is a null pointer
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.6.8'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.6.8 [The wmemchr generic function]</h3>
 | |
| <a name='7.31.4.6.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             QWchar_t *wmemchr(QWchar_t *s, wchar_t c, size_t n);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.6.8p2'></a>
 | |
| <pre>2   The wmemchr generic function locates the first occurrence of c in the initial n wide characters of the
 | |
|     object pointed to by s.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.6.8p3'></a>
 | |
| <pre>3   The wmemchr generic function returns a pointer to the located wide character, or a null pointer if the
 | |
|     wide character does not occur in the object.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.7'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.7 [Miscellaneous functions]</h3>
 | |
| <a name='7.31.4.7.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.7.1 [The wcslen function]</h3>
 | |
| <a name='7.31.4.7.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              size_t wcslen(const wchar_t *s);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.7.1p2'></a>
 | |
| <pre>2   The wcslen function computes the length of the wide string pointed to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.7.1p3'></a>
 | |
| <pre>3   The wcslen function returns the number of wide characters that precede the terminating null wide
 | |
|     character.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.4.7.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.4.7.2 [The wmemset function]</h3>
 | |
| <a name='7.31.4.7.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wchar.h>
 | |
|              wchar_t *wmemset(wchar_t *s, wchar_t c, size_t n);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.4.7.2p2'></a>
 | |
| <pre>2   The wmemset function copies the value of c into each of the first n wide characters of the object
 | |
|     pointed to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.4.7.2p3'></a>
 | |
| <pre>3   The wmemset function returns the value of s.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.5'></a>
 | |
| <hr>
 | |
| <h3>7.31.5 [Wide character time conversion functions]</h3>
 | |
| <a name='7.31.5.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.5.1 [The wcsftime function]</h3>
 | |
| <a name='7.31.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <time.h>
 | |
|              #include <wchar.h>
 | |
|              size_t wcsftime(wchar_t * restrict s, size_t maxsize,
 | |
|                    const wchar_t * restrict format, const struct tm * restrict timeptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.5.1p2'></a>
 | |
| <pre>2   The wcsftime function is equivalent to the strftime function, except that:
 | |
| 
 | |
|       — The argument s points to the initial element of an array of wide characters into which the
 | |
|         generated output is to be placed.
 | |
|       — The argument maxsize indicates the limiting number of wide characters.
 | |
|       — The argument format is a wide string and the conversion specifiers are replaced by corre-
 | |
|         sponding sequences of wide characters.
 | |
|       — The return value indicates the number of wide characters.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.5.1p3'></a>
 | |
| <pre>3   If the total number of resulting wide characters including the terminating null wide character is not
 | |
|     more than maxsize, the wcsftime function returns the number of wide characters placed into the
 | |
|     array pointed to by s not including the terminating null wide character. Otherwise, zero is returned
 | |
|     and the members of the array have an indeterminate representation.
 | |
| </pre>
 | |
| <a name='7.31.6'></a>
 | |
| <hr>
 | |
| <h3>7.31.6 [Extended multibyte/wide character conversion utilities]</h3>
 | |
| <a name='7.31.6p1'></a>
 | |
| <pre>1   The header <wchar.h> declares an extended set of functions useful for conversion between multibyte
 | |
|     characters and wide characters.
 | |
| </pre>
 | |
| <a name='7.31.6p2'></a>
 | |
| <pre>2   Most of the following functions — those that are listed as "restartable", <a href='#7.31.6.3'>7.31.6.3</a> and <a href='#7.31.6.4'>7.31.6.4</a> — take
 | |
|     as a last argument a pointer to an object of type mbstate_t that is used to describe the current
 | |
|     conversion state from a particular multibyte character sequence to a wide character sequence (or the
 | |
|     reverse) under the rules of a particular setting for the LC_CTYPE category of the current locale.
 | |
| </pre>
 | |
| <a name='7.31.6p3'></a>
 | |
| <pre>3   The initial conversion state corresponds, for a conversion in either direction, to the beginning of a
 | |
|     new multibyte character in the initial shift state. A zero-valued mbstate_t object is (at least) one
 | |
|     way to describe an initial conversion state. A zero-valued mbstate_t object can be used to initiate
 | |
|     conversion involving any multibyte character sequence, in any LC_CTYPE category setting. If an
 | |
|     mbstate_t object has been altered by any of the functions described in this subclause, and is then
 | |
|     used with a different multibyte character sequence, or in the other conversion direction, or with a
 | |
|     different LC_CTYPE category setting than on earlier function calls, the behavior is undefined.<a href='#FOOTNOTE.426'><sup>[426]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.426'>
 | |
| <pre><i><b>Footnote 426)</b> Thus, a particular mbstate_t object can be used, for example, with both the mbrtowc and mbsrtowcs functions as long
 | |
|     as they are used to step sequentially through the same multibyte character string.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.6p4'></a>
 | |
| <pre>4   On entry, each function takes the described conversion state (either internal or pointed to by an
 | |
|     argument) as current. The conversion state described by the referenced object is altered as needed
 | |
|     to track the shift state, and the position within a multibyte character, for the associated multibyte
 | |
|     character sequence.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.1 [Single-byte/wide character conversion functions]</h3>
 | |
| <a name='7.31.6.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.1.1 [The btowc function]</h3>
 | |
| <a name='7.31.6.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               wint_t btowc(int c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.1.1p2'></a>
 | |
| <pre>2   The btowc function determines whether c constitutes a valid single-byte character in the initial shift
 | |
|     state.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.1.1p3'></a>
 | |
| <pre>3   The btowc function returns WEOF if c has the value EOF or if (unsigned char)c does not constitute
 | |
|     a valid single-byte character in the initial shift state. Otherwise, it returns the wide character
 | |
|     representation of that character.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.1.2 [The wctob function]</h3>
 | |
| <a name='7.31.6.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               int wctob(wint_t c);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.1.2p2'></a>
 | |
| <pre>2   The wctob function determines whether c corresponds to a member of the extended character set
 | |
|     whose multibyte character representation is a single byte when in the initial shift state.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.1.2p3'></a>
 | |
| <pre>3   The wctob function returns EOF if c does not correspond to a multibyte character with length one
 | |
|     in the initial shift state. Otherwise, it returns the single-byte representation of that character as an
 | |
|     unsigned char converted to an int.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.2 [Conversion state functions]</h3>
 | |
| <a name='7.31.6.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.2.1 [The mbsinit function]</h3>
 | |
| <a name='7.31.6.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|             int mbsinit(const mbstate_t *ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.2.1p2'></a>
 | |
| <pre>2   If ps is not a null pointer, the mbsinit function determines whether the referenced mbstate_t object
 | |
|     describes an initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.2.1p3'></a>
 | |
| <pre>3   The mbsinit function returns nonzero if ps is a null pointer or if the referenced object describes an
 | |
|     initial conversion state; otherwise, it returns zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.3 [Restartable multibyte/wide character conversion functions]</h3>
 | |
| <a name='7.31.6.3p1'></a>
 | |
| <pre>1   These functions differ from the corresponding multibyte character functions of <a href='#7.24.7'>7.24.7</a> (mblen, mbtowc,
 | |
|     and wctomb) in that they have an extra parameter, ps, of type pointer to mbstate_t that points
 | |
|     to an object that can completely describe the current conversion state of the associated multibyte
 | |
|     character sequence. If ps is a null pointer, each function uses its own internal mbstate_t object
 | |
|     instead, which is initialized prior to the first call to the function to the initial conversion state; the
 | |
|     functions are not required to avoid data races with other calls to the same function in this case. It
 | |
|     is implementation-defined whether the internal mbstate_t object has thread storage duration; if
 | |
|     it has thread storage duration, it is initialized to the initial conversion state prior to the first call to
 | |
|     the function on the new thread. The implementation behaves as if no library function calls these
 | |
|     functions with a null pointer for ps.
 | |
| </pre>
 | |
| <a name='7.31.6.3p2'></a>
 | |
| <pre>2   Also unlike their corresponding functions, the return value does not represent whether the encoding
 | |
|     is state-dependent.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.3.1 [The mbrlen function]</h3>
 | |
| <a name='7.31.6.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             size_t mbrlen(const char * restrict s, size_t n, mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.3.1p2'></a>
 | |
| <pre>2   The mbrlen function is equivalent to the call:
 | |
| 
 | |
|             mbrtowc(NULL, s, n, ps != NULL ? ps: &internal)
 | |
| 
 | |
| 
 | |
|     where internal is the mbstate_t object for the mbrlen function, except that the expression desig-
 | |
|     nated by ps is evaluated only once.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.3.1p3'></a>
 | |
| <pre>3   The mbrlen function returns a value between zero and n, inclusive, (size_t) (−2), or (size_t) (−1).
 | |
|     Forward references: the mbrtowc function (<a href='#7.31.6.3.2'>7.31.6.3.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.3.2 [The mbrtowc function]</h3>
 | |
| <a name='7.31.6.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wchar.h>
 | |
|             size_t mbrtowc(wchar_t * restrict pwc, const char * restrict s, size_t n,
 | |
|                   mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.3.2p2'></a>
 | |
| <pre>2   If s is a null pointer, the mbrtowc function is equivalent to the call:
 | |
| 
 | |
|                     mbrtowc(NULL, "", 1, ps)
 | |
| 
 | |
| 
 | |
|     In this case, the values of the parameters pwc and n are ignored.
 | |
| </pre>
 | |
| <a name='7.31.6.3.2p3'></a>
 | |
| <pre>3   If s is not a null pointer, the mbrtowc function inspects at most n bytes beginning with the byte
 | |
|     pointed to by s to determine the number of bytes needed to complete the next multibyte character
 | |
|     (including any shift sequences). If the function determines that the next multibyte character is
 | |
|     complete and valid, it determines the value of the corresponding wide character and then, if pwc
 | |
|     is not a null pointer, stores that value in the object pointed to by pwc. If the corresponding wide
 | |
|     character is the null wide character, the resulting state described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.3.2p4'></a>
 | |
| <pre>4   The mbrtowc function returns the first of the following that applies (given the current conversion
 | |
|     state):
 | |
| 
 | |
|     0                   if the next n or fewer bytes complete the multibyte character that corresponds to
 | |
|                         the null wide character (which is the value stored).
 | |
|     between 1 and n inclusive if the next n or fewer bytes complete a valid multibyte character (which
 | |
|                      is the value stored); the value returned is the number of bytes that complete the
 | |
|                      multibyte character.
 | |
|     (size_t) (−2) if the next n bytes contribute to an incomplete (but potentially valid) multibyte
 | |
|                   character, and all n bytes have been processed (no value is stored).<a href='#FOOTNOTE.427'><sup>[427]</sup></a>
 | |
|     (size_t)(-1) if an encoding error occurs, in which case the next n or fewer bytes do not contribute
 | |
|                         to a complete and valid multibyte character (no value is stored); the value of the
 | |
|                         macro EILSEQ is stored in errno, and the conversion state is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.427'>
 | |
| <pre><i><b>Footnote 427)</b> When n has at least the value of the MB_CUR_MAX macro, this case can only occur if s points at a sequence of redundant
 | |
|     shift sequences (for implementations with state-dependent encodings).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.6.3.3'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.3.3 [The wcrtomb function]</h3>
 | |
| <a name='7.31.6.3.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               size_t wcrtomb(char * restrict s, wchar_t wc, mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.3.3p2'></a>
 | |
| <pre>2   If s is a null pointer, the wcrtomb function is equivalent to the call
 | |
| 
 | |
|                       wcrtomb(buf, L’\0’, ps)
 | |
| 
 | |
| 
 | |
|     where buf is an internal buffer.
 | |
| </pre>
 | |
| <a name='7.31.6.3.3p3'></a>
 | |
| <pre>3   If s is not a null pointer, the wcrtomb function determines the number of bytes needed to represent
 | |
|     the multibyte character that corresponds to the wide character given by wc (including any shift
 | |
|     sequences), and stores the multibyte character representation in the array whose first element is
 | |
|     pointed to by s. At most MB_CUR_MAX bytes are stored. If wc is a null wide character, a null byte is
 | |
|     stored, preceded by any shift sequence needed to restore the initial shift state; the resulting state
 | |
|     described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.3.3p4'></a>
 | |
| <pre>4   The wcrtomb function returns the number of bytes stored in the array object (including any shift
 | |
|     sequences). When wc is not a valid wide character, an encoding error occurs: the function stores the
 | |
|     value of the macro EILSEQ in errno and returns (size_t) (−1); the conversion state is unspecified.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.4'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.4 [Restartable multibyte/wide string conversion functions]</h3>
 | |
| <a name='7.31.6.4p1'></a>
 | |
| <pre>1   These functions differ from the corresponding multibyte string functions of <a href='#7.24.8'>7.24.8</a> (mbstowcs and
 | |
|     wcstombs) in that they have an extra parameter, ps, of type pointer to mbstate_t that points to
 | |
|     an object that can completely describe the current conversion state of the associated multibyte
 | |
|     character sequence. If ps is a null pointer, each function uses its own internal mbstate_t object
 | |
|     instead, which is initialized prior to the first call to the function to the initial conversion state; the
 | |
|     functions are not required to avoid data races with other calls to the same function in this case. It
 | |
|     is implementation-defined whether the internal mbstate_t object has thread storage duration; if
 | |
|     it has thread storage duration, it is initialized to the initial conversion state prior to the first call to
 | |
|     the function on the new thread. The implementation behaves as if no library function calls these
 | |
|     functions with a null pointer for ps.
 | |
| </pre>
 | |
| <a name='7.31.6.4p2'></a>
 | |
| <pre>2   Also unlike their corresponding functions, the conversion source parameter, src, has a pointer-to-
 | |
|     pointer type. When the function is storing the results of conversions (that is, when dst is not a null
 | |
|     pointer), the pointer object pointed to by this parameter is updated to reflect the amount of the
 | |
|     source processed by that invocation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.4.1'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.4.1 [The mbsrtowcs function]</h3>
 | |
| <a name='7.31.6.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               size_t mbsrtowcs(wchar_t * restrict dst, const char ** restrict src, size_t len,
 | |
|                     mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.4.1p2'></a>
 | |
| <pre>2   The mbsrtowcs function converts a sequence of multibyte characters that begins in the conversion
 | |
|     state described by the object pointed to by ps, from the array indirectly pointed to by src into a
 | |
|     sequence of corresponding wide characters. If dst is not a null pointer, the converted characters are
 | |
|     stored into the array pointed to by dst. Conversion continues up to and including a terminating
 | |
|     null character, which is also stored. Conversion stops earlier in two cases: when a sequence of bytes
 | |
|     is encountered that does not form a valid multibyte character, or (if dst is not a null pointer) when
 | |
|     len wide characters have been stored into the array pointed to by dst.<a href='#FOOTNOTE.428'><sup>[428]</sup></a> Each conversion takes
 | |
|     place as if by a call to the mbrtowc function.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.428'>
 | |
| <pre><i><b>Footnote 428)</b> Thus, the value of len is ignored if dst is a null pointer.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.6.4.1p3'></a>
 | |
| <pre>3   If dst is not a null pointer, the pointer object pointed to by src is assigned either a null pointer (if
 | |
|     conversion stopped due to reaching a terminating null character) or the address just past the last
 | |
|     multibyte character converted (if any). If conversion stopped due to reaching a terminating null
 | |
|     character and if dst is not a null pointer, the resulting state described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.4.1p4'></a>
 | |
| <pre>4   If the input conversion encounters a sequence of bytes that do not form a valid multibyte character,
 | |
|     an encoding error occurs: the mbsrtowcs function stores the value of the macro EILSEQ in errno
 | |
|     and returns (size_t)(-1) ; the conversion state is unspecified. Otherwise, it returns the number of
 | |
|     multibyte characters successfully converted, not including the terminating null character (if any).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.31.6.4.2'></a>
 | |
| <hr>
 | |
| <h3>7.31.6.4.2 [The wcsrtombs function]</h3>
 | |
| <a name='7.31.6.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               size_t wcsrtombs(char * restrict dst, const wchar_t ** restrict src, size_t len,
 | |
|                     mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.31.6.4.2p2'></a>
 | |
| <pre>2   The wcsrtombs function converts a sequence of wide characters from the array indirectly pointed to
 | |
|     by src into a sequence of corresponding multibyte characters that begins in the conversion state
 | |
|     described by the object pointed to by ps. If dst is not a null pointer, the converted characters are then
 | |
|     stored into the array pointed to by dst. Conversion continues up to and including a terminating null
 | |
|     wide character, which is also stored. Conversion stops earlier in two cases: when a wide character
 | |
|     is reached that does not correspond to a valid multibyte character, or (if dst is not a null pointer)
 | |
|     when the next multibyte character would exceed the limit of len total bytes to be stored into the
 | |
|     array pointed to by dst. Each conversion takes place as if by a call to the wcrtomb function.<a href='#FOOTNOTE.429'><sup>[429]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.429'>
 | |
| <pre><i><b>Footnote 429)</b> If conversion stops because a terminating null wide character has been reached, the bytes stored include those necessary
 | |
|     to reach the initial shift state immediately before the null byte.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.31.6.4.2p3'></a>
 | |
| <pre>3   If dst is not a null pointer, the pointer object pointed to by src is assigned either a null pointer (if
 | |
|     conversion stopped due to reaching a terminating null wide character) or the address just past the
 | |
|     last wide character converted (if any). If conversion stopped due to reaching a terminating null wide
 | |
|     character, the resulting state described is the initial conversion state.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.31.6.4.2p4'></a>
 | |
| <pre>4   If conversion stops because a wide character is reached that does not correspond to a valid multibyte
 | |
|     character, an encoding error occurs: the wcsrtombs function stores the value of the macro EILSEQ
 | |
|     in errno and returns (size_t) (−1); the conversion state is unspecified. Otherwise, it returns the
 | |
|     number of bytes in the resulting multibyte character sequence, not including the terminating null
 | |
|     character (if any).
 | |
| </pre>
 | |
| <a name='7.32'></a>
 | |
| <hr>
 | |
| <h3>7.32 [Wide character classification and mapping utilities <wctype.h>]</h3>
 | |
| <a name='7.32.1'></a>
 | |
| <hr>
 | |
| <h3>7.32.1 [Introduction]</h3>
 | |
| <a name='7.32.1p1'></a>
 | |
| <pre>1   The header <wctype.h> defines one macro, and declares three data types and many functions.<a href='#FOOTNOTE.430'><sup>[430]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.430'>
 | |
| <pre><i><b>Footnote 430)</b> See "future library directions" (<a href='#7.33.21'>7.33.21</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.32.1p2'></a>
 | |
| <pre>2   The types declared are wint_t described in <a href='#7.31.1'>7.31.1</a>;
 | |
| 
 | |
|               wctrans_t
 | |
| 
 | |
| 
 | |
|     which is a scalar type that can hold values which represent locale-specific character mappings; and
 | |
| 
 | |
|               wctype_t
 | |
| 
 | |
| 
 | |
|     which is a scalar type that can hold values which represent locale-specific character classifications.
 | |
| </pre>
 | |
| <a name='7.32.1p3'></a>
 | |
| <pre>3   The macro defined is WEOF (described in <a href='#7.31.1'>7.31.1</a>).
 | |
| </pre>
 | |
| <a name='7.32.1p4'></a>
 | |
| <pre>4   The functions declared are grouped as follows:
 | |
| 
 | |
|       — Functions that provide wide character classification;
 | |
|       — Extensible functions that provide wide character classification;
 | |
| 
 | |
|       — Functions that provide wide character case mapping;
 | |
|       — Extensible functions that provide wide character mapping.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.1p5'></a>
 | |
| <pre>5   For all functions described in this subclause that accept an argument of type wint_t, the value shall
 | |
|     be representable as a wchar_t or shall equal the value of the macro WEOF. If this argument has any
 | |
|     other value, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='7.32.1p6'></a>
 | |
| <pre>6   The behavior of these functions is affected by the LC_CTYPE category of the current locale.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2'></a>
 | |
| <hr>
 | |
| <h3>7.32.2 [Wide character classification utilities]</h3>
 | |
| <a name='7.32.2p1'></a>
 | |
| <pre>1   The header <wctype.h> declares several functions useful for classifying wide characters.
 | |
| </pre>
 | |
| <a name='7.32.2p2'></a>
 | |
| <pre>2   The term printing wide character refers to a member of a locale-specific set of wide characters, each of
 | |
|     which occupies at least one printing position on a display device. The term control wide character
 | |
|     refers to a member of a locale-specific set of wide characters that are not printing wide characters.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1 [Wide character classification functions]</h3>
 | |
| <a name='7.32.2.1p1'></a>
 | |
| <pre>1   The functions in this subclause return nonzero (true) if and only if the value of the argument wc
 | |
|     conforms to that in the description of the function.
 | |
| </pre>
 | |
| <a name='7.32.2.1p2'></a>
 | |
| <pre>2   Each of the following functions returns true for each wide character that corresponds (as if by a call
 | |
|     to the wctob function) to a single-byte character for which the corresponding character classification
 | |
|     function from <a href='#7.4.1'>7.4.1</a> returns true, except that the iswgraph and iswpunct functions may differ with
 | |
|     respect to wide characters other than L’ ’ that are both printing and white-space wide characters.<a href='#FOOTNOTE.431'><sup>[431]</sup></a>
 | |
|     Forward references: the wctob function (<a href='#7.31.6.1.2'>7.31.6.1.2</a>).
 | |
| </pre>
 | |
| <a name='FOOTNOTE.431'>
 | |
| <pre><i><b>Footnote 431)</b> For example, if the expression isalpha(wctob(wc)) evaluates to true, then the call iswalpha(wc) also returns true.
 | |
|     But, if the expression isgraph(wctob(wc)) evaluates to true (which cannot occur for wc == L’’ of course), then either
 | |
|     iswgraph(wc) or iswprint(wc)&& iswspace(wc) is true, but not both.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.32.2.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.1 [The iswalnum function]</h3>
 | |
| <a name='7.32.2.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswalnum(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.1p2'></a>
 | |
| <pre>2   The iswalnum function tests for any wide character for which iswalpha or iswdigit is true.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.2 [The iswalpha function]</h3>
 | |
| <a name='7.32.2.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswalpha(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.2p2'></a>
 | |
| <pre>2   The iswalpha function tests for any wide character for which iswupper or iswlower is true, or any
 | |
|     wide character that is one of a locale-specific set of alphabetic wide characters for which none of
 | |
|     iswcntrl, iswdigit, iswpunct, or iswspace is true.<a href='#FOOTNOTE.432'><sup>[432]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.432'>
 | |
| <pre><i><b>Footnote 432)</b> The functions iswlower and iswupper test true or false separately for each of these additional wide characters; all four
 | |
|     combinations are possible.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.32.2.1.3'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.3 [The iswblank function]</h3>
 | |
| <a name='7.32.2.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswblank(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.3p2'></a>
 | |
| <pre>2   The iswblank function tests for any wide character that is a standard blank wide character or is one
 | |
|     of a locale-specific set of wide characters for which iswspace is true and that is used to separate
 | |
|     words within a line of text. The standard blank wide characters are the following: space (L’ ’),
 | |
|     and horizontal tab (L’\t’). In the "C" locale, iswblank returns true only for the standard blank
 | |
|     characters.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1.4'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.4 [The iswcntrl function]</h3>
 | |
| <a name='7.32.2.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswcntrl(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.4p2'></a>
 | |
| <pre>2   The iswcntrl function tests for any control wide character.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1.5'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.5 [The iswdigit function]</h3>
 | |
| <a name='7.32.2.1.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswdigit(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.5p2'></a>
 | |
| <pre>2   The iswdigit function tests for any wide character that corresponds to a decimal-digit character (as
 | |
|     defined in <a href='#5.2.1'>5.2.1</a>).
 | |
| </pre>
 | |
| <a name='7.32.2.1.6'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.6 [The iswgraph function]</h3>
 | |
| <a name='7.32.2.1.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswgraph(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.6p2'></a>
 | |
| <pre>2   The iswgraph function tests for any wide character for which iswprint is true and iswspace is
 | |
|     false.<a href='#FOOTNOTE.433'><sup>[433]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.433'>
 | |
| <pre><i><b>Footnote 433)</b> Note that the behavior of the iswgraph and iswpunct functions can differ from their corresponding functions in <a href='#7.4.1'>7.4.1</a>
 | |
|     with respect to printing, white-space, single-byte execution characters other than ’ ’ .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.32.2.1.7'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.7 [The iswlower function]</h3>
 | |
| <a name='7.32.2.1.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswlower(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.7p2'></a>
 | |
| <pre>2   The iswlower function tests for any wide character that corresponds to a lowercase letter or is one
 | |
|     of a locale-specific set of wide characters for which none of iswcntrl, iswdigit, iswpunct, or
 | |
|     iswspace is true.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1.8'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.8 [The iswprint function]</h3>
 | |
| <a name='7.32.2.1.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswprint(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.8p2'></a>
 | |
| <pre>2   The iswprint function tests for any printing wide character.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1.9'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.9 [The iswpunct function]</h3>
 | |
| <a name='7.32.2.1.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswpunct(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.9p2'></a>
 | |
| <pre>2   The iswpunct function tests for any printing wide character that is one of a locale-specific set of
 | |
|     punctuation wide characters for which neither iswspace nor iswalnum is true.<a href='#FOOTNOTE.433'><sup>[433]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.433'>
 | |
| <pre><i><b>Footnote 433)</b> Note that the behavior of the iswgraph and iswpunct functions can differ from their corresponding functions in <a href='#7.4.1'>7.4.1</a>
 | |
|     with respect to printing, white-space, single-byte execution characters other than ’ ’ .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='7.32.2.1.10'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.10 [The iswspace function]</h3>
 | |
| <a name='7.32.2.1.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswspace(wint_t wc);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.10p2'></a>
 | |
| <pre>2   The iswspace function tests for any wide character that corresponds to a locale-specific set of
 | |
|     white-space wide characters for which none of iswalnum, iswgraph, or iswpunct is true.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1.11'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.11 [The iswupper function]</h3>
 | |
| <a name='7.32.2.1.11p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wctype.h>
 | |
|               int iswupper(wint_t wc);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.11p2'></a>
 | |
| <pre>2   The iswupper function tests for any wide character that corresponds to an uppercase letter or is
 | |
|     one of a locale-specific set of wide characters for which none of iswcntrl, iswdigit, iswpunct, or
 | |
|     iswspace is true.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.1.12'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.1.12 [The iswxdigit function]</h3>
 | |
| <a name='7.32.2.1.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wctype.h>
 | |
|             int iswxdigit(wint_t wc);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.1.12p2'></a>
 | |
| <pre>2   The iswxdigit function tests for any wide character that corresponds to a hexadecimal-digit
 | |
|     character (as defined in <a href='#6.4.4.1'>6.4.4.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.2 [Extensible wide character classification functions]</h3>
 | |
| <a name='7.32.2.2p1'></a>
 | |
| <pre>1   The functions wctype and iswctype provide extensible wide character classification as well as
 | |
|     testing equivalent to that performed by the functions described in the previous subclause (<a href='#7.32.2.1'>7.32.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.2.1 [The iswctype function]</h3>
 | |
| <a name='7.32.2.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wctype.h>
 | |
|             int iswctype(wint_t wc, wctype_t desc);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.2.1p2'></a>
 | |
| <pre>2   The iswctype function determines whether the wide character wc has the property described by
 | |
|     desc. The current setting of the LC_CTYPE category shall be the same as during the call to wctype
 | |
|     that returned the value desc.
 | |
| </pre>
 | |
| <a name='7.32.2.2.1p3'></a>
 | |
| <pre>3   Each of the following expressions has a truth-value equivalent to the call to the wide character
 | |
|     classification function (<a href='#7.32.2.1'>7.32.2.1</a>) in the comment that follows the expression:
 | |
| 
 | |
|             iswctype(wc, wctype("alnum"))        // iswalnum(wc)
 | |
|             iswctype(wc, wctype("alpha"))        // iswalpha(wc)
 | |
|             iswctype(wc, wctype("blank"))        // iswblank(wc)
 | |
|             iswctype(wc, wctype("cntrl"))        // iswcntrl(wc)
 | |
|             iswctype(wc, wctype("digit"))        // iswdigit(wc)
 | |
|             iswctype(wc, wctype("graph"))        // iswgraph(wc)
 | |
|             iswctype(wc, wctype("lower"))        // iswlower(wc)
 | |
|             iswctype(wc, wctype("print"))        // iswprint(wc)
 | |
|             iswctype(wc, wctype("punct"))        // iswpunct(wc)
 | |
|             iswctype(wc, wctype("space"))        // iswspace(wc)
 | |
|             iswctype(wc, wctype("upper"))        // iswupper(wc)
 | |
|             iswctype(wc, wctype("xdigit"))       // iswxdigit(wc)
 | |
| 
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.32.2.2.1p4'></a>
 | |
| <pre>4   The iswctype function returns nonzero (true) if and only if the value of the wide character wc has
 | |
|     the property described by desc. If desc is zero, the iswctype function returns zero (false).
 | |
|     Forward references: the wctype function (<a href='#7.32.2.2.2'>7.32.2.2.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.2.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.32.2.2.2 [The wctype function]</h3>
 | |
| <a name='7.32.2.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wctype.h>
 | |
|             wctype_t wctype(const char *property);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.2.2.2p2'></a>
 | |
| <pre>2   The wctype function constructs a value with type wctype_t that describes a class of wide characters
 | |
|     identified by the string argument property.
 | |
| </pre>
 | |
| <a name='7.32.2.2.2p3'></a>
 | |
| <pre>3   The strings listed in the description of the iswctype function shall be valid in all locales as property
 | |
|     arguments to the wctype function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.32.2.2.2p4'></a>
 | |
| <pre>4   If property identifies a valid class of wide characters according to the LC_CTYPE category of the
 | |
|     current locale, the wctype function returns a nonzero value that is valid as the second argument to
 | |
|     the iswctype function; otherwise, it returns zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.3'></a>
 | |
| <hr>
 | |
| <h3>7.32.3 [Wide character case mapping utilities]</h3>
 | |
| <a name='7.32.3p1'></a>
 | |
| <pre>1   The header <wctype.h> declares several functions useful for mapping wide characters.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.3.1'></a>
 | |
| <hr>
 | |
| <h3>7.32.3.1 [Wide character case mapping functions]</h3>
 | |
| <a name='7.32.3.1.1'></a>
 | |
| <hr>
 | |
| <h3>7.32.3.1.1 [The towlower function]</h3>
 | |
| <a name='7.32.3.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wctype.h>
 | |
|              wint_t towlower(wint_t wc);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.3.1.1p2'></a>
 | |
| <pre>2   The towlower function converts an uppercase letter to a corresponding lowercase letter.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.32.3.1.1p3'></a>
 | |
| <pre>3   If the argument is a wide character for which iswupper is true and there are one or more correspond-
 | |
|     ing wide characters, as specified by the current locale, for which iswlower is true, the towlower
 | |
|     function returns one of the corresponding wide characters (always the same one for any given
 | |
|     locale); otherwise, the argument is returned unchanged.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.3.1.2'></a>
 | |
| <hr>
 | |
| <h3>7.32.3.1.2 [The towupper function]</h3>
 | |
| <a name='7.32.3.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wctype.h>
 | |
|              wint_t towupper(wint_t wc);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.3.1.2p2'></a>
 | |
| <pre>2   The towupper function converts a lowercase letter to a corresponding uppercase letter.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.32.3.1.2p3'></a>
 | |
| <pre>3   If the argument is a wide character for which iswlower is true and there are one or more correspond-
 | |
|     ing wide characters, as specified by the current locale, for which iswupper is true, the towupper
 | |
|     function returns one of the corresponding wide characters (always the same one for any given
 | |
|     locale); otherwise, the argument is returned unchanged.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.3.2'></a>
 | |
| <hr>
 | |
| <h3>7.32.3.2 [Extensible wide character case mapping functions]</h3>
 | |
| <a name='7.32.3.2p1'></a>
 | |
| <pre>1   The functions wctrans and towctrans provide extensible wide character mapping as well as case
 | |
|     mapping equivalent to that performed by the functions described in the previous subclause (<a href='#7.32.3.1'>7.32.3.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.3.2.1'></a>
 | |
| <hr>
 | |
| <h3>7.32.3.2.1 [The towctrans function]</h3>
 | |
| <a name='7.32.3.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #include <wctype.h>
 | |
|              wint_t towctrans(wint_t wc, wctrans_t desc);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.3.2.1p2'></a>
 | |
| <pre>2   The towctrans function maps the wide character wc using the mapping described by desc. The
 | |
|     current setting of the LC_CTYPE category shall be the same as during the call to wctrans that returned
 | |
|     the value desc.
 | |
| </pre>
 | |
| <a name='7.32.3.2.1p3'></a>
 | |
| <pre>3   Each of the following expressions behaves the same as the call to the wide character case mapping
 | |
|     function (<a href='#7.32.3.1'>7.32.3.1</a>) in the comment that follows the expression:
 | |
| 
 | |
|             towctrans(wc, wctrans("tolower"))         // towlower(wc)
 | |
|             towctrans(wc, wctrans("toupper"))         // towupper(wc)
 | |
| 
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.32.3.2.1p4'></a>
 | |
| <pre>4   The towctrans function returns the mapped value of wc using the mapping described by desc. If
 | |
|     desc is zero, the towctrans function returns the value of wc .
 | |
| 
 | |
| </pre>
 | |
| <a name='7.32.3.2.2'></a>
 | |
| <hr>
 | |
| <h3>7.32.3.2.2 [The wctrans function]</h3>
 | |
| <a name='7.32.3.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #include <wctype.h>
 | |
|             wctrans_t wctrans(const char *property);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='7.32.3.2.2p2'></a>
 | |
| <pre>2   The wctrans function constructs a value with type wctrans_t that describes a mapping between
 | |
|     wide characters identified by the string argument property.
 | |
| </pre>
 | |
| <a name='7.32.3.2.2p3'></a>
 | |
| <pre>3   The strings listed in the description of the towctrans function shall be valid in all locales as
 | |
|     property arguments to the wctrans function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='7.32.3.2.2p4'></a>
 | |
| <pre>4   If property identifies a valid mapping of wide characters according to the LC_CTYPE category of the
 | |
|     current locale, the wctrans function returns a nonzero value that is valid as the second argument to
 | |
|     the towctrans function; otherwise, it returns zero.
 | |
| </pre>
 | |
| <a name='7.33'></a>
 | |
| <hr>
 | |
| <h3>7.33 [Future library directions]</h3>
 | |
| <a name='7.33p1'></a>
 | |
| <pre>1   Although grouped under individual headers, all of the external names identified as reserved
 | |
|     identifiers or potentially reserved identifiers in this subclause remain so regardless of which headers
 | |
|     are included in the program.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.1'></a>
 | |
| <hr>
 | |
| <h3>7.33.1 [Complex arithmetic <complex.h>]</h3>
 | |
| <a name='7.33.1p1'></a>
 | |
| <pre>1   The function names
 | |
| 
 | |
|     cacospi                   cexp10m1                  clog10                     crootn
 | |
|     casinpi                   cexp10                    clog1p                     crsqrt
 | |
|     catanpi                   cexp2m1                   clog2p1                    csinpi
 | |
|     ccompoundn                cexp2                     clog2                      ctanpi
 | |
|     ccospi                    cexpm1                    clogp1                     ctgamma
 | |
|     cerfc                     clgamma                   cpown
 | |
|     cerf                      clog10p1                  cpowr
 | |
| 
 | |
| 
 | |
|     and the same names suffixed with f or l are potentially reserved identifiers and may be added to
 | |
|     the declarations in the <complex.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.2'></a>
 | |
| <hr>
 | |
| <h3>7.33.2 [Character handling <ctype.h>]</h3>
 | |
| <a name='7.33.2p1'></a>
 | |
| <pre>1   Function names that begin with either is or to, and a lowercase letter are potentially reserved
 | |
|     identifiers and may be added to the declarations in the <ctype.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.3'></a>
 | |
| <hr>
 | |
| <h3>7.33.3 [Errors <errno.h>]</h3>
 | |
| <a name='7.33.3p1'></a>
 | |
| <pre>1   Macros that begin with E and a digit or E and an uppercase letter may be added to the macros
 | |
|     defined in the <errno.h> header by a future revision of this document or by an implementation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.4'></a>
 | |
| <hr>
 | |
| <h3>7.33.4 [Floating-point environment <fenv.h>]</h3>
 | |
| <a name='7.33.4p1'></a>
 | |
| <pre>1   Macros that begin with FE_ and an uppercase letter may be added to the macros defined in the
 | |
|     <fenv.h> header by a future revision of this document.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.5'></a>
 | |
| <hr>
 | |
| <h3>7.33.5 [Characteristics of floating types <float.h>]</h3>
 | |
| <a name='7.33.5p1'></a>
 | |
| <pre>1   Macros that begin with DBL_, DEC32_, DEC64_, DEC128_, DEC_, FLT_, or LDBL_ and an uppercase
 | |
|     letter are potentially reserved identifiers and may be added to the macros defined in the <float.h>
 | |
|     header.
 | |
| </pre>
 | |
| <a name='7.33.5p2'></a>
 | |
| <pre>2   Use of the DECIMAL_DIG macro is an obsolescent feature. A similar type-specific macro, such as
 | |
|     LDBL_DECIMAL_DIG, can be used instead.
 | |
| </pre>
 | |
| <a name='7.33.5p3'></a>
 | |
| <pre>3   The use of FLT_HAS_SUBNORM, DBL_HAS_SUBNORM, and LDBL_HAS_SUBNORM macros is an obsolescent
 | |
|     feature.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.6'></a>
 | |
| <hr>
 | |
| <h3>7.33.6 [Format conversion of integer types <inttypes.h>]</h3>
 | |
| <a name='7.33.6p1'></a>
 | |
| <pre>1   Macros that begin with either PRI or SCN, and either a lowercase letter or X are potentially reserved
 | |
|     identifiers and may be added to the macros defined in the <inttypes.h> header.
 | |
| </pre>
 | |
| <a name='7.33.6p2'></a>
 | |
| <pre>2   Function names that begin with str, or wcs and a lowercase letter are potentially reserved identifiers
 | |
|     may be added to the declarations in the <inttypes.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.7'></a>
 | |
| <hr>
 | |
| <h3>7.33.7 [Localization <locale.h>]</h3>
 | |
| <a name='7.33.7p1'></a>
 | |
| <pre>1   Macros that begin with LC_ and an uppercase letter may be added to the macros defined in the
 | |
|     <locale.h> header by a future revision of this document or by an implementation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.8'></a>
 | |
| <hr>
 | |
| <h3>7.33.8 [Mathematics <math.h>]</h3>
 | |
| <a name='7.33.8p1'></a>
 | |
| <pre>1   Macros that begin with FP_ or MATH_ and an uppercase letter may be added to the macros defined
 | |
|     in the <math.h> header by a future revision of this document or by an implementation.
 | |
| </pre>
 | |
| <a name='7.33.8p2'></a>
 | |
| <pre>2   Macros that begin with MATH_ and an uppercase letter are potentially reserved identifiers and may
 | |
|     be added to the macros in the <math.h> header.
 | |
| </pre>
 | |
| <a name='7.33.8p3'></a>
 | |
| <pre>3   Function names that begin with is and a lowercase letter are potentially reserved identifiers and
 | |
|     may be added to the declarations in the <math.h> header.
 | |
| </pre>
 | |
| <a name='7.33.8p4'></a>
 | |
| <pre>4   Function names that begin with cr_ are potentially reserved identifiers and may be added to the
 | |
|     <math.h> header. The cr_ prefix is intended to indicate a correctly rounded version of the function.
 | |
| </pre>
 | |
| <a name='7.33.8p5'></a>
 | |
| <pre>5   Use of the macros INFINITY, DEC_INFINITY, NAN, and DEC_NAN in <math.h> is an obsolescent
 | |
|     feature. Instead, use the same macros in <float.h>.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.9'></a>
 | |
| <hr>
 | |
| <h3>7.33.9 [Signal handling <signal.h>]</h3>
 | |
| <a name='7.33.9p1'></a>
 | |
| <pre>1   Macros that begin with either SIG and an uppercase letter or SIG_ and an uppercase letter may be
 | |
|     added to the macros defined in the <signal.h> header by a fture revision of this document or by an
 | |
|     implementation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.10'></a>
 | |
| <hr>
 | |
| <h3>7.33.10 [Atomics <stdatomic.h>]</h3>
 | |
| <a name='7.33.10p1'></a>
 | |
| <pre>1   Macros that begin with ATOMIC_ and an uppercase letter are potentially reserved identifiers and
 | |
|     may be added to the macros defined in the <stdatomic.h> header. Typedef names that begin with
 | |
|     either atomic_ or memory_, and a lowercase letter are potentially reserved identifiers and may be
 | |
|     added to the declarations in the <stdatomic.h> header. Enumeration constants that begin with
 | |
|     memory_order_ and a lowercase letter are potentially reserved identifiers and may be added to
 | |
|     the definition of the memory_order type in the <stdatomic.h> header. Function names that begin
 | |
|     with atomic_ and a lowercase letter are potentially reserved identifiers and may be added to the
 | |
|     declarations in the <stdatomic.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.11'></a>
 | |
| <hr>
 | |
| <h3>7.33.11 [Boolean type and values <stdbool.h>]</h3>
 | |
| <a name='7.33.11p1'></a>
 | |
| <pre>1   The macro __bool_true_false_are_defined is an obsolescent feature.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.12'></a>
 | |
| <hr>
 | |
| <h3>7.33.12 [Bit and byte utilities <stdbit.h>]</h3>
 | |
| <a name='7.33.12p1'></a>
 | |
| <pre>1   Type and function names that begin with stdc_ are potentially reserved identifiers and may be
 | |
|     added to the declarations in the <stdbit.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.13'></a>
 | |
| <hr>
 | |
| <h3>7.33.13 [Checked Arithmetic Functions <stdckdint.h>]</h3>
 | |
| <a name='7.33.13p1'></a>
 | |
| <pre>1   Type and function names that begin with ckd_ are potentially reserved identifiers and may be added
 | |
|     to the declarations in the <stdckdint.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.14'></a>
 | |
| <hr>
 | |
| <h3>7.33.14 [Integer types <stdint.h>]</h3>
 | |
| <a name='7.33.14p1'></a>
 | |
| <pre>1   Typedef names beginning with int or uint and ending with _t are potentially reserved identifiers
 | |
|     and may be added to the types defined in the <stdint.h> header. Macro names beginning with
 | |
|     INT or UINT and ending with _MAX , _MIN , _WIDTH , or _C are potentially reserved identifiers and may
 | |
|     be added to the macros defined in the <stdint.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.15'></a>
 | |
| <hr>
 | |
| <h3>7.33.15 [Input/output <stdio.h>]</h3>
 | |
| <a name='7.33.15p1'></a>
 | |
| <pre>1   Lowercase letters may be added to the conversion specifiers and length modifiers in fprintf and
 | |
|     fscanf. Other characters may be used in extensions.
 | |
| </pre>
 | |
| <a name='7.33.15p2'></a>
 | |
| <pre>2   The use of ungetc on a binary stream where the file position indicator is zero prior to the call is an
 | |
|     obsolescent feature.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.16'></a>
 | |
| <hr>
 | |
| <h3>7.33.16 [General utilities <stdlib.h>]</h3>
 | |
| <a name='7.33.16p1'></a>
 | |
| <pre>1   Function names that begin with str or wcs and a lowercase letter are potentially reserved identifiers
 | |
|     and may be added to the declarations in the <stdlib.h> header.
 | |
| </pre>
 | |
| <a name='7.33.16p2'></a>
 | |
| <pre>2   Suppressing the macro definition of bsearch in order to access the actual function is an obsolescent
 | |
|     feature.
 | |
| </pre>
 | |
| <a name='7.33.17'></a>
 | |
| <hr>
 | |
| <h3>7.33.17 [String handling <string.h>]</h3>
 | |
| <a name='7.33.17p1'></a>
 | |
| <pre>1   Function names that begin with str, mem, or wcs and a lowercase letter are potentially reserved
 | |
|     identifiers and may be added to the declarations in the <string.h> header.
 | |
| </pre>
 | |
| <a name='7.33.17p2'></a>
 | |
| <pre>2   Suppressing the macro definitions of memchr, strchr, strpbrk, strrchr, or strstr in order to
 | |
|     access the corresponding actual function is an obsolescent feature.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.18'></a>
 | |
| <hr>
 | |
| <h3>7.33.18 [Date and time <time.h>]</h3>
 | |
| <pre>Macros beginning with TIME_ and an uppercase letter may be added to the macros in the <time.h>
 | |
|     header by a future revision of this document or by an implementation.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.19'></a>
 | |
| <hr>
 | |
| <h3>7.33.19 [Threads <threads.h>]</h3>
 | |
| <a name='7.33.19p1'></a>
 | |
| <pre>1   Function names, type names, and enumeration constants that begin with either cnd_, mtx_, thrd_, or
 | |
|     tss_, and a lowercase letter are potentially reserved identifiers and may be added to the declarations
 | |
|     in the <threads.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.20'></a>
 | |
| <hr>
 | |
| <h3>7.33.20 [Extended multibyte and wide character utilities <wchar.h>]</h3>
 | |
| <a name='7.33.20p1'></a>
 | |
| <pre>1   Function names that begin with wcs and a lowercase letter are potentially reserved identifiers and
 | |
|     may be added to the declarations in the <wchar.h> header.
 | |
| </pre>
 | |
| <a name='7.33.20p2'></a>
 | |
| <pre>2   Lowercase letters may be added to the conversion specifiers and length modifiers in fwprintf and
 | |
|     fwscanf. Other characters may be used in extensions.
 | |
| </pre>
 | |
| <a name='7.33.20p3'></a>
 | |
| <pre>3   Suppressing the macro definitions of wcschr, wcspbrk, wcsrchr, wmemchr, or wcsstr in order to
 | |
|     access the corresponding actual function is an obsolescent feature.
 | |
| 
 | |
| </pre>
 | |
| <a name='7.33.21'></a>
 | |
| <hr>
 | |
| <h3>7.33.21 [Wide character classification and mapping utilities <wctype.h>]</h3>
 | |
| <a name='7.33.21p1'></a>
 | |
| <pre>1   Function names that begin with is or to and a lowercase letter are potentially reserved identifiers
 | |
|     and may be added to the declarations in the <wctype.h> header.
 | |
| 
 | |
| </pre>
 | |
| <a name='A.'></a>
 | |
| <hr>
 | |
| <h3>A. [Annex A (informative) Language syntax summary]</h3>
 | |
| <a name='A.p1'></a>
 | |
| <pre>1   NOTE The notation is described in <a href='#6.1'>6.1</a>.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.1'></a>
 | |
| <hr>
 | |
| <h3>A.1 [Lexical grammar]</h3>
 | |
| <a name='A.1.1'></a>
 | |
| <hr>
 | |
| <h3>A.1.1 [Lexical elements]</h3>
 | |
| <pre>(<a href='#6.4'>6.4</a>) token:
 | |
|                             keyword
 | |
|                             identifier
 | |
|                             constant
 | |
|                             string-literal
 | |
|                             punctuator
 | |
| 
 | |
|     (<a href='#6.4'>6.4</a>) preprocessing-token:
 | |
|                          header-name
 | |
|                          identifier
 | |
|                          pp-number
 | |
|                          character-constant
 | |
|                          string-literal
 | |
|                          punctuator
 | |
|                         each universal-character-name that cannot be one of the above
 | |
|                         each non-white-space character that cannot be one of the above
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.1.2'></a>
 | |
| <hr>
 | |
| <h3>A.1.2 [Keywords]</h3>
 | |
| <pre>(<a href='#6.4.1'>6.4.1</a>) keyword: one of
 | |
|                             alignas               enum                 short           void
 | |
|                             alignof               extern               signed          volatile
 | |
|                             auto                  false                sizeof          while
 | |
|                             bool                  float                static          _Atomic
 | |
|                             break                 for                  static_assert   _BitInt
 | |
|                             case                  goto                 struct          _Complex
 | |
|                             char                  if                   switch          _Decimal128
 | |
|                             const                 inline               thread_local    _Decimal32
 | |
|                             constexpr             int                  true            _Decimal64
 | |
|                             continue              long                 typedef         _Generic
 | |
|                             default               nullptr              typeof          _Imaginary
 | |
|                             do                    register             typeof_unqual   _Noreturn
 | |
|                             double                restrict             union
 | |
|                             else                  return               unsigned
 | |
| 
 | |
| </pre>
 | |
| <a name='A.1.3'></a>
 | |
| <hr>
 | |
| <h3>A.1.3 [Identifiers]</h3>
 | |
| <pre>(<a href='#6.4.2.1'>6.4.2.1</a>) identifier:
 | |
|                             identifier-start
 | |
|                             identifier identifier-continue
 | |
| 
 | |
|     (<a href='#6.4.2.1'>6.4.2.1</a>) identifier-start:
 | |
|                            nondigit
 | |
|                           XID_Start character
 | |
|                           universal-character-name of class XID_Start
 | |
| (<a href='#6.4.2.1'>6.4.2.1</a>) identifier-continue:
 | |
|                        digit
 | |
|                        nondigit
 | |
|                       XID_Continue character
 | |
|                       universal-character-name of class XID_Continue
 | |
| 
 | |
| (<a href='#6.4.2.1'>6.4.2.1</a>) nondigit: one of
 | |
|                      _ a b c d e f g h i j k l m
 | |
|                           n o p q r s t u v w x y z
 | |
|                           A B C D E F G H I J K L M
 | |
|                           N O P Q R S T U V W X Y Z
 | |
| 
 | |
| (<a href='#6.4.2.1'>6.4.2.1</a>) digit: one of
 | |
|                      0 1 2 3 4 5 6 7 8 9
 | |
| </pre>
 | |
| <a name='A.1.4'></a>
 | |
| <hr>
 | |
| <h3>A.1.4 [Universal character names]</h3>
 | |
| <pre>(<a href='#6.4.3'>6.4.3</a>) universal-character-name:
 | |
|                      \u hex-quad
 | |
|                      \U hex-quad hex-quad
 | |
| 
 | |
| (<a href='#6.4.3'>6.4.3</a>) hex-quad:
 | |
|                      hexadecimal-digit hexadecimal-digit hexadecimal-digit hexadecimal-digit
 | |
| </pre>
 | |
| <a name='A.1.5'></a>
 | |
| <hr>
 | |
| <h3>A.1.5 [Constants]</h3>
 | |
| <pre>(<a href='#6.4.4'>6.4.4</a>) constant:
 | |
|                      integer-constant
 | |
|                      floating-constant
 | |
|                      enumeration-constant
 | |
|                      character-constant
 | |
|                      predefined-constant
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) integer-constant:
 | |
|                      decimal-constant integer-suffixopt
 | |
|                      octal-constant integer-suffixopt
 | |
|                      hexadecimal-constant integer-suffixopt
 | |
|                      binary-constant integer-suffixopt
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) decimal-constant:
 | |
|                      nonzero-digit
 | |
|                      decimal-constant ’opt digit
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) octal-constant:
 | |
|                      0
 | |
|                      octal-constant ’opt octal-digit
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) hexadecimal-constant:
 | |
|                      hexadecimal-prefix hexadecimal-digit-sequence
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) binary-constant:
 | |
|                      binary-prefix binary-digit
 | |
|                      binary-constant ’opt binary-digit
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) hexadecimal-prefix: one of
 | |
|                      0x 0X
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) binary-prefix: one of
 | |
|                      0b 0B
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) nonzero-digit: one of
 | |
|                      1 2 3 4 5 6 7 8 9
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) octal-digit: one of
 | |
|                      0 1 2 3 4 5 6 7
 | |
| 
 | |
|  hexadecimal-digit-sequence:
 | |
|                     hexadecimal-digit
 | |
|                     hexadecimal-digit-sequence ’opt hexadecimal-digit
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) hexadecimal-digit: one of
 | |
|                      0 1 2 3 4 5 6 7 8 9
 | |
|                      a b c d e f
 | |
|                      A B C D E F
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) binary-digit: one of
 | |
|                      0 1
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) integer-suffix:
 | |
|                       unsigned-suffix long-suffixopt
 | |
|                       unsigned-suffix long-long-suffix
 | |
|                       unsigned-suffix bit-precise-int-suffix
 | |
|                       long-suffix unsigned-suffixopt
 | |
|                       long-long-suffix unsigned-suffixopt
 | |
|                       bit-precise-int-suffix unsigned-suffixopt
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) bit-precise-int-suffix: one of
 | |
|                       wb WB
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) unsigned-suffix: one of
 | |
|                      u U
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) long-suffix: one of
 | |
|                      l L
 | |
| 
 | |
| (<a href='#6.4.4.1'>6.4.4.1</a>) long-long-suffix: one of
 | |
|                      ll LL
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) floating-constant:
 | |
|                       decimal-floating-constant
 | |
|                       hexadecimal-floating-constant
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) decimal-floating-constant:
 | |
|                       fractional-constant exponent-partopt floating-suffixopt
 | |
|                       digit-sequence exponent-part floating-suffixopt
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) hexadecimal-floating-constant:
 | |
|                     hexadecimal-prefix hexadecimal-fractional-constant
 | |
|                                          binary-exponent-part floating-suffixopt
 | |
|                     hexadecimal-prefix hexadecimal-digit-sequence
 | |
|                                          binary-exponent-part floating-suffixopt
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) fractional-constant:
 | |
|                       digit-sequenceopt . digit-sequence
 | |
|                       digit-sequence .
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) exponent-part:
 | |
|                     e signopt digit-sequence
 | |
|                     E signopt digit-sequence
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) sign: one of
 | |
|                      + -
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) digit-sequence:
 | |
|                      digit
 | |
|                      digit-sequence ’opt digit
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) hexadecimal-fractional-constant:
 | |
|                     hexadecimal-digit-sequenceopt . hexadecimal-digit-sequence
 | |
|                     hexadecimal-digit-sequence .
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) binary-exponent-part:
 | |
|                      p signopt digit-sequence
 | |
|                      P signopt digit-sequence
 | |
| 
 | |
| (<a href='#6.4.4.2'>6.4.4.2</a>) floating-suffix: one of
 | |
|                      f l F L df dd dl DF DD DL
 | |
| (<a href='#6.4.4.3'>6.4.4.3</a>) enumeration-constant:
 | |
|                      identifier
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) character-constant:
 | |
|                      encoding-prefixopt ’ c-char-sequence ’
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) encoding-prefix:
 | |
|                      u8
 | |
|                      u
 | |
|                      U
 | |
|                      L
 | |
| 
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) c-char-sequence:
 | |
|                       c-char
 | |
|                       c-char-sequence c-char
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) c-char:
 | |
|                      any member of the source character set except
 | |
|                                         the single-quote ’, backslash \ , or new-line character
 | |
|                       escape-sequence
 | |
| 
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) escape-sequence:
 | |
|                      simple-escape-sequence
 | |
|                      octal-escape-sequence
 | |
|                      hexadecimal-escape-sequence
 | |
|                      universal-character-name
 | |
| 
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) simple-escape-sequence: one of
 | |
|                      \’ \" \? \\
 | |
|                      \a \b \f \n \r \t \v
 | |
| 
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) octal-escape-sequence:
 | |
|                      \ octal-digit
 | |
|                      \ octal-digit octal-digit
 | |
|                      \ octal-digit octal-digit octal-digit
 | |
| 
 | |
| (<a href='#6.4.4.4'>6.4.4.4</a>) hexadecimal-escape-sequence:
 | |
|                    \x hexadecimal-digit
 | |
|                     hexadecimal-escape-sequence hexadecimal-digit
 | |
| (<a href='#6.4.4.5'>6.4.4.5</a>) predefined-constant:
 | |
|                        false
 | |
|                        true
 | |
|                        nullptr
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.1.6'></a>
 | |
| <hr>
 | |
| <h3>A.1.6 [String literals]</h3>
 | |
| <pre>(<a href='#6.4.5'>6.4.5</a>) string-literal:
 | |
|                        encoding-prefixopt " s-char-sequenceopt "
 | |
| (<a href='#6.4.5'>6.4.5</a>) s-char-sequence:
 | |
|                        s-char
 | |
|                        s-char-sequence s-char
 | |
| 
 | |
| (<a href='#6.4.5'>6.4.5</a>) s-char:
 | |
|                     any member of the source character set except
 | |
|                                      the double-quote ", backslash \, or new-line character
 | |
|                      escape-sequence
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.1.7'></a>
 | |
| <hr>
 | |
| <h3>A.1.7 [Punctuators]</h3>
 | |
| <pre>(<a href='#6.4.6'>6.4.6</a>) punctuator: one of
 | |
|                    [ ] ( ) { } .   ->
 | |
|                    ++ -- & * + - ~ !
 | |
|                    / % << >> < > <= >=                    ==    !=      ^    |   &&   ||
 | |
|                    ?  :   :: ; ...
 | |
|                    = *= /= %= += -= <<=                   >>=      &=       ^=   |=
 | |
|                    , # ##
 | |
|                    <:  :> <% %> %:  %:%:
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.1.8'></a>
 | |
| <hr>
 | |
| <h3>A.1.8 [Header names]</h3>
 | |
| <pre>(<a href='#6.4.7'>6.4.7</a>) header-name:
 | |
|                        < h-char-sequence >
 | |
|                        " q-char-sequence "
 | |
| 
 | |
| (<a href='#6.4.7'>6.4.7</a>) h-char-sequence:
 | |
|                      h-char
 | |
|                      h-char-sequence h-char
 | |
| 
 | |
| (<a href='#6.4.7'>6.4.7</a>) h-char:
 | |
|                     any member of the source character set except
 | |
|                                     the new-line character and >
 | |
| 
 | |
| (<a href='#6.4.7'>6.4.7</a>) q-char-sequence:
 | |
|                      q-char
 | |
|                      q-char-sequence q-char
 | |
| 
 | |
| (<a href='#6.4.7'>6.4.7</a>) q-char:
 | |
|                     any member of the source character set except
 | |
|                                     the new-line character and "
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.1.9'></a>
 | |
| <hr>
 | |
| <h3>A.1.9 [Preprocessing numbers]</h3>
 | |
| <pre>(<a href='#6.4.8'>6.4.8</a>) pp-number:
 | |
|                       digit
 | |
|                       . digit
 | |
|                       pp-number identifier-continue
 | |
|                       pp-number ’ digit
 | |
|                       pp-number ’ nondigit
 | |
|                       pp-number e sign
 | |
|                       pp-number E sign
 | |
|                       pp-number p sign
 | |
|                       pp-number P sign
 | |
|                       pp-number .
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| (<a href='#6.5.1'>6.5.1</a>) primary-expression:
 | |
| </pre>
 | |
| <a name='A.2'></a>
 | |
| <hr>
 | |
| <h3>A.2 [Phrase structure grammar]</h3>
 | |
| <a name='A.2.1'></a>
 | |
| <hr>
 | |
| <h3>A.2.1 [Expressions]</h3>
 | |
| <pre>identifier
 | |
|                       constant
 | |
|                       string-literal
 | |
|                       ( expression )
 | |
|                       generic-selection
 | |
| (<a href='#6.5.1.1'>6.5.1.1</a>) generic-selection:
 | |
|                       _Generic ( assignment-expression , generic-assoc-list )
 | |
| (<a href='#6.5.1.1'>6.5.1.1</a>) generic-assoc-list:
 | |
|                       generic-association
 | |
|                       generic-assoc-list , generic-association
 | |
| (<a href='#6.5.1.1'>6.5.1.1</a>) generic-association:
 | |
|                       type-name : assignment-expression
 | |
|                       default : assignment-expression
 | |
| (<a href='#6.5.2'>6.5.2</a>) postfix-expression:
 | |
|                       primary-expression
 | |
|                       postfix-expression [ expression ]
 | |
|                       postfix-expression ( argument-expression-listopt )
 | |
|                       postfix-expression . identifier
 | |
|                       postfix-expression -> identifier
 | |
|                       postfix-expression ++
 | |
|                       postfix-expression --
 | |
|                       compound-literal
 | |
| 
 | |
| (<a href='#6.5.2'>6.5.2</a>) argument-expression-list:
 | |
|                     assignment-expression
 | |
|                     argument-expression-list , assignment-expression
 | |
| 
 | |
| (<a href='#6.5.2.5'>6.5.2.5</a>)            compound-literal:
 | |
|                        ( storage-class-specifiersopt type-name ) braced-initializer
 | |
| 
 | |
| (<a href='#6.5.2.5'>6.5.2.5</a>)            storage-class-specifiers:
 | |
|                        storage-class-specifier
 | |
|                        storage-class-specifiers storage-class-specifier
 | |
| (<a href='#6.5.3'>6.5.3</a>) unary-expression:
 | |
|                     postfix-expression
 | |
|                     ++ unary-expression
 | |
|                     -- unary-expression
 | |
|                     unary-operator cast-expression
 | |
|                     sizeof unary-expression
 | |
|                     sizeof ( type-name )
 | |
|                     alignof ( type-name )
 | |
| 
 | |
| (<a href='#6.5.3'>6.5.3</a>) unary-operator: one of
 | |
|                    &   *   +     -   ~   !
 | |
| 
 | |
| (<a href='#6.5.4'>6.5.4</a>) cast-expression:
 | |
|                       unary-expression
 | |
|                       ( type-name ) cast-expression
 | |
| 
 | |
| (<a href='#6.5.5'>6.5.5</a>) multiplicative-expression:
 | |
|                      cast-expression
 | |
|                      multiplicative-expression * cast-expression
 | |
|                      multiplicative-expression / cast-expression
 | |
|                      multiplicative-expression % cast-expression
 | |
| 
 | |
| (<a href='#6.5.6'>6.5.6</a>) additive-expression:
 | |
|                      multiplicative-expression
 | |
|                      additive-expression + multiplicative-expression
 | |
|                      additive-expression - multiplicative-expression
 | |
| 
 | |
| (<a href='#6.5.7'>6.5.7</a>) shift-expression:
 | |
|                       additive-expression
 | |
|                       shift-expression << additive-expression
 | |
|                       shift-expression >> additive-expression
 | |
| (<a href='#6.5.8'>6.5.8</a>) relational-expression:
 | |
|                       shift-expression
 | |
|                       relational-expression < shift-expression
 | |
|                       relational-expression > shift-expression
 | |
|                       relational-expression <= shift-expression
 | |
|                       relational-expression >= shift-expression
 | |
| (<a href='#6.5.9'>6.5.9</a>) equality-expression:
 | |
|                       relational-expression
 | |
|                       equality-expression == relational-expression
 | |
|                       equality-expression != relational-expression
 | |
| 
 | |
| (<a href='#6.5.10'>6.5.10</a>) AND-expression:
 | |
|                     equality-expression
 | |
|                     AND-expression & equality-expression
 | |
| (<a href='#6.5.11'>6.5.11</a>) exclusive-OR-expression:
 | |
|                     AND-expression
 | |
|                     exclusive-OR-expression ^ AND-expression
 | |
| (<a href='#6.5.12'>6.5.12</a>) inclusive-OR-expression:
 | |
|                     exclusive-OR-expression
 | |
|                     inclusive-OR-expression | exclusive-OR-expression
 | |
| (<a href='#6.5.13'>6.5.13</a>) logical-AND-expression:
 | |
|                     inclusive-OR-expression
 | |
|                     logical-AND-expression && inclusive-OR-expression
 | |
| (<a href='#6.5.14'>6.5.14</a>) logical-OR-expression:
 | |
|                     logical-AND-expression
 | |
|                     logical-OR-expression || logical-AND-expression
 | |
| (<a href='#6.5.15'>6.5.15</a>) conditional-expression:
 | |
|                      logical-OR-expression
 | |
|                      logical-OR-expression ? expression : conditional-expression
 | |
| (<a href='#6.5.16'>6.5.16</a>) assignment-expression:
 | |
|                      conditional-expression
 | |
|                      unary-expression assignment-operator assignment-expression
 | |
| 
 | |
| (<a href='#6.5.16'>6.5.16</a>) assignment-operator: one of
 | |
|                      =   *=   /=    %=    +=   -=    <<=    >>=    &=    ^=    |=
 | |
| (<a href='#6.5.17'>6.5.17</a>) expression:
 | |
|                      assignment-expression
 | |
|                      expression , assignment-expression
 | |
| (<a href='#6.6'>6.6</a>) constant-expression:
 | |
|                      conditional-expression
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| (<a href='#6.7'>6.7</a>) declaration:
 | |
| </pre>
 | |
| <a name='A.2.2'></a>
 | |
| <hr>
 | |
| <h3>A.2.2 [declaration-specifiers init-declarator-listopt ;]</h3>
 | |
| <pre>Declarations
 | |
|                        attribute-specifier-sequence declaration-specifiers init-declarator-list ;
 | |
|                        static_assert-declaration
 | |
|                        attribute-declaration
 | |
| (<a href='#6.7'>6.7</a>) declaration-specifiers:
 | |
|                        declaration-specifier attribute-specifier-sequenceopt
 | |
|                        declaration-specifier declaration-specifiers
 | |
| (<a href='#6.7'>6.7</a>) declaration-specifier:
 | |
|                        storage-class-specifier
 | |
|                        type-specifier-qualifier
 | |
|                        function-specifier
 | |
| (<a href='#6.7'>6.7</a>) init-declarator-list:
 | |
|                        init-declarator
 | |
|                        init-declarator-list , init-declarator
 | |
| (<a href='#6.7'>6.7</a>) init-declarator:
 | |
|                        declarator
 | |
|                        declarator = initializer
 | |
| (<a href='#6.7'>6.7</a>) attribute-declaration:
 | |
|                        attribute-specifier-sequence ;
 | |
| (<a href='#6.7.1'>6.7.1</a>) storage-class-specifier:
 | |
|                        auto
 | |
|                        constexpr
 | |
|                        extern
 | |
|                        register
 | |
|                        static
 | |
|                        thread_local
 | |
|                        typedef
 | |
| (<a href='#6.7.2'>6.7.2</a>) type-specifier:
 | |
|                       void
 | |
|                       char
 | |
|                       short
 | |
|                       int
 | |
|                       long
 | |
|                       float
 | |
|                       double
 | |
|                       signed
 | |
|                       unsigned
 | |
|                       _BitInt ( constant-expression )
 | |
|                       bool
 | |
|                       _Complex
 | |
|                       _Decimal32
 | |
|                       _Decimal64
 | |
|                       _Decimal128
 | |
|                       atomic-type-specifier
 | |
|                       struct-or-union-specifier
 | |
|                       enum-specifier
 | |
|                       typedef-name
 | |
|                       typeof-specifier
 | |
| 
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) struct-or-union-specifier:
 | |
|                      struct-or-union attribute-specifier-sequenceopt identifieropt { member-declaration-list }
 | |
|                      struct-or-union attribute-specifier-sequenceopt identifier
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) struct-or-union:
 | |
|                       struct
 | |
|                       union
 | |
| 
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) member-declaration-list:
 | |
|                       member-declaration
 | |
|                       member-declaration-list member-declaration
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) member-declaration:
 | |
|                       attribute-specifier-sequenceopt specifier-qualifier-list member-declarator-listopt ;
 | |
|                       static_assert-declaration
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) specifier-qualifier-list:
 | |
|                       type-specifier-qualifier attribute-specifier-sequenceopt
 | |
|                       type-specifier-qualifier specifier-qualifier-list
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) type-specifier-qualifier:
 | |
|                       type-specifier
 | |
|                       type-qualifier
 | |
|                       alignment-specifier
 | |
| 
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) member-declarator-list:
 | |
|                     member-declarator
 | |
|                     member-declarator-list , member-declarator
 | |
| (<a href='#6.7.2.1'>6.7.2.1</a>) member-declarator:
 | |
|                     declarator
 | |
|                     declaratoropt : constant-expression
 | |
| (<a href='#6.7.2.2'>6.7.2.2</a>) enum-specifier:
 | |
|                     enum attribute-specifier-sequenceopt identifieropt enum-type-specifieropt
 | |
|                                        { enumerator-list }
 | |
|                     enum attribute-specifier-sequenceopt identifieropt enum-type-specifieropt
 | |
|                                        { enumerator-list , }
 | |
|                     enum identifier enum-type-specifieropt
 | |
| (<a href='#6.7.2.2'>6.7.2.2</a>) enumerator-list:
 | |
|                     enumerator
 | |
|                     enumerator-list , enumerator
 | |
| (<a href='#6.7.2.2'>6.7.2.2</a>) enumerator:
 | |
|                       enumeration-constant attribute-specifier-sequenceopt
 | |
|                       enumeration-constant attribute-specifier-sequenceopt = constant-expression
 | |
| (<a href='#6.7.2.2'>6.7.2.2</a>) enum-type-specifier:
 | |
|                       : specifier-qualifier-list
 | |
| (<a href='#6.7.2.4'>6.7.2.4</a>) atomic-type-specifier:
 | |
|                      _Atomic ( type-name )
 | |
| (<a href='#6.7.2.5'>6.7.2.5</a>) typeof-specifier:
 | |
|                       typeof ( typeof-specifier-argument )
 | |
|                       typeof_unqual ( typeof-specifier-argument )
 | |
| (<a href='#6.7.2.5'>6.7.2.5</a>) typeof-specifier-argument:
 | |
|                       expression
 | |
|                       type-name
 | |
| 
 | |
| (<a href='#6.7.3'>6.7.3</a>) type-qualifier:
 | |
|                       const
 | |
|                       restrict
 | |
|                       volatile
 | |
|                       _Atomic
 | |
| (<a href='#6.7.4'>6.7.4</a>) function-specifier:
 | |
|                       inline
 | |
|                       _Noreturn
 | |
| 
 | |
| (<a href='#6.7.5'>6.7.5</a>) alignment-specifier:
 | |
|                       alignas ( type-name )
 | |
|                       alignas ( constant-expression )
 | |
| (<a href='#6.7.6'>6.7.6</a>) declarator:
 | |
|                       pointeropt direct-declarator
 | |
| 
 | |
| (<a href='#6.7.6'>6.7.6</a>) direct-declarator:
 | |
|                       identifier attribute-specifier-sequenceopt
 | |
|                       ( declarator )
 | |
|                       array-declarator attribute-specifier-sequenceopt
 | |
|                       function-declarator attribute-specifier-sequenceopt
 | |
| 
 | |
| (<a href='#6.7.6'>6.7.6</a>) array-declarator:
 | |
|                      direct-declarator [ type-qualifier-listopt assignment-expressionopt ]
 | |
|                      direct-declarator [ static type-qualifier-listopt assignment-expression ]
 | |
|                      direct-declarator [ type-qualifier-list static assignment-expression ]
 | |
|                      direct-declarator [ type-qualifier-listopt * ]
 | |
| 
 | |
| (<a href='#6.7.6'>6.7.6</a>) function-declarator:
 | |
|                      direct-declarator ( parameter-type-listopt )
 | |
| 
 | |
| (<a href='#6.7.6'>6.7.6</a>) pointer:
 | |
|                       * attribute-specifier-sequenceopt type-qualifier-listopt
 | |
|                       * attribute-specifier-sequenceopt type-qualifier-listopt pointer
 | |
| (<a href='#6.7.6'>6.7.6</a>) type-qualifier-list:
 | |
|                       type-qualifier
 | |
|                       type-qualifier-list type-qualifier
 | |
| (<a href='#6.7.6'>6.7.6</a>) parameter-type-list:
 | |
|                       parameter-list
 | |
|                       parameter-list , ...
 | |
|                       ...
 | |
| (<a href='#6.7.6'>6.7.6</a>) parameter-list:
 | |
|                      parameter-declaration
 | |
|                      parameter-list , parameter-declaration
 | |
| (<a href='#6.7.6'>6.7.6</a>) parameter-declaration:
 | |
|                       attribute-specifier-sequenceopt declaration-specifiers declarator
 | |
|                       attribute-specifier-sequenceopt declaration-specifiers abstract-declaratoropt
 | |
| (<a href='#6.7.7'>6.7.7</a>) type-name:
 | |
|                       specifier-qualifier-list abstract-declaratoropt
 | |
| (<a href='#6.7.7'>6.7.7</a>) abstract-declarator:
 | |
|                       pointer
 | |
|                       pointeropt direct-abstract-declarator
 | |
| (<a href='#6.7.7'>6.7.7</a>) direct-abstract-declarator:
 | |
|                       ( abstract-declarator )
 | |
|                       array-abstract-declarator attribute-specifier-sequenceopt
 | |
|                       function-abstract-declarator attribute-specifier-sequenceopt
 | |
| (<a href='#6.7.7'>6.7.7</a>) array-abstract-declarator:
 | |
|                       direct-abstract-declaratoropt [ type-qualifier-listopt assignment-expressionopt ]
 | |
|                       direct-abstract-declaratoropt [ static type-qualifier-listopt assignment-expression ]
 | |
|                       direct-abstract-declaratoropt [ type-qualifier-list static assignment-expression ]
 | |
|                       direct-abstract-declaratoropt [ * ]
 | |
| 
 | |
| (<a href='#6.7.7'>6.7.7</a>) function-abstract-declarator:
 | |
|                      direct-abstract-declaratoropt ( parameter-type-listopt )
 | |
| (<a href='#6.7.8'>6.7.8</a>) typedef-name:
 | |
|                      identifier
 | |
| 
 | |
| (<a href='#6.7.10'>6.7.10</a>) braced-initializer:
 | |
|                         { }
 | |
|                         { initializer-list }
 | |
|                         { initializer-list , }
 | |
| 
 | |
| (<a href='#6.7.10'>6.7.10</a>) initializer:
 | |
|                         assignment-expression
 | |
|                         braced-initializer
 | |
| 
 | |
| (<a href='#6.7.10'>6.7.10</a>) initializer-list:
 | |
|                        designationopt initializer
 | |
|                        initializer-list , designationopt initializer
 | |
| 
 | |
| (<a href='#6.7.10'>6.7.10</a>) designation:
 | |
|                      designator-list =
 | |
| 
 | |
| (<a href='#6.7.10'>6.7.10</a>) designator-list:
 | |
|                       designator
 | |
|                       designator-list designator
 | |
| (<a href='#6.7.10'>6.7.10</a>) designator:
 | |
|                       [ constant-expression ]
 | |
|                       . identifier
 | |
| (<a href='#6.7.11'>6.7.11</a>) static_assert-declaration:
 | |
|                       static_assert ( constant-expression , string-literal ) ;
 | |
|                       static_assert ( constant-expression ) ;
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute-specifier-sequence:
 | |
|                       attribute-specifier-sequenceopt attribute-specifier
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute-specifier:
 | |
|                       [ [ attribute-list ] ]
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute-list:
 | |
|                       attributeopt
 | |
|                       attribute-list , attributeopt
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute:
 | |
|                       attribute-token attribute-argument-clauseopt
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute-token:
 | |
|                       standard-attribute
 | |
|                       attribute-prefixed-token
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) standard-attribute:
 | |
|                       identifier
 | |
| 
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute-prefixed-token:
 | |
|                       attribute-prefix :: identifier
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute-prefix:
 | |
|                       identifier
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) attribute-argument-clause:
 | |
|                       ( balanced-token-sequenceopt )
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) balanced-token-sequence:
 | |
|                       balanced-token
 | |
|                       balanced-token-sequence balanced-token
 | |
| (<a href='#6.7.12.1'>6.7.12.1</a>) balanced-token:
 | |
|                       ( balanced-token-sequenceopt )
 | |
|                       [ balanced-token-sequenceopt ]
 | |
|                       { balanced-token-sequenceopt }
 | |
|                      any token other than a parenthesis, a bracket, or a brace
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.2.3'></a>
 | |
| <hr>
 | |
| <h3>A.2.3 [Statements]</h3>
 | |
| <pre>(<a href='#6.8'>6.8</a>) statement:
 | |
|                      labeled-statement
 | |
|                      unlabeled-statement
 | |
| (<a href='#6.8'>6.8</a>) unlabeled-statement:
 | |
|                      expression-statement
 | |
|                      attribute-specifier-sequenceopt primary-block
 | |
|                      attribute-specifier-sequenceopt jump-statement
 | |
| (<a href='#6.8'>6.8</a>) primary-block:
 | |
|                      compound-statement
 | |
|                      selection-statement
 | |
|                      iteration-statement
 | |
| 
 | |
| (<a href='#6.8'>6.8</a>) secondary-block:
 | |
|                     statement
 | |
| 
 | |
| (<a href='#6.8.1'>6.8.1</a>) label:
 | |
|                       attribute-specifier-sequenceopt identifier :
 | |
|                       attribute-specifier-sequenceopt case constant-expression :
 | |
|                       attribute-specifier-sequenceopt default :
 | |
| (<a href='#6.8.1'>6.8.1</a>) labeled-statement:
 | |
|                       label statement
 | |
| (<a href='#6.8.2'>6.8.2</a>) compound-statement:
 | |
|                       { block-item-listopt }
 | |
| (<a href='#6.8.2'>6.8.2</a>) block-item-list:
 | |
|                       block-item
 | |
|                       block-item-list block-item
 | |
| (<a href='#6.8.2'>6.8.2</a>) block-item:
 | |
|                       declaration
 | |
|                       unlabeled-statement
 | |
|                       label
 | |
| (<a href='#6.8.3'>6.8.3</a>) expression-statement:
 | |
|                      expressionopt ;
 | |
|                      attribute-specifier-sequence expression ;
 | |
| 
 | |
| (<a href='#6.8.4'>6.8.4</a>) selection-statement:
 | |
|                       if ( expression ) secondary-block
 | |
|                       if ( expression ) secondary-block else secondary-block
 | |
|                       switch ( expression ) secondary-block
 | |
| 
 | |
| (<a href='#6.8.5'>6.8.5</a>) iteration-statement:
 | |
|                      while ( expression ) secondary-block
 | |
|                      do secondary-block while ( expression ) ;
 | |
|                      for ( expressionopt ; expressionopt ; expressionopt ) secondary-block
 | |
|                      for ( declaration expressionopt ; expressionopt ) secondary-block
 | |
| 
 | |
| (<a href='#6.8.6'>6.8.6</a>) jump-statement:
 | |
|                      goto identifier ;
 | |
|                      continue ;
 | |
|                      break ;
 | |
|                      return expressionopt ;
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.2.4'></a>
 | |
| <hr>
 | |
| <h3>A.2.4 [External definitions]</h3>
 | |
| <pre>(<a href='#6.9'>6.9</a>) translation-unit:
 | |
|                      external-declaration
 | |
|                      translation-unit external-declaration
 | |
| 
 | |
| (<a href='#6.9'>6.9</a>) external-declaration:
 | |
|                      function-definition
 | |
|                      declaration
 | |
| 
 | |
| (<a href='#6.9.1'>6.9.1</a>) function-definition:
 | |
|                      attribute-specifier-sequenceopt declaration-specifiers declarator function-body
 | |
| 
 | |
| (<a href='#6.9.1'>6.9.1</a>) function-body:
 | |
|                      compound-statement
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.3'></a>
 | |
| <hr>
 | |
| <h3>A.3 [Preprocessing directives]</h3>
 | |
| <pre>(<a href='#6.10'>6.10</a>) preprocessing-file:
 | |
|                      groupopt
 | |
| (<a href='#6.10'>6.10</a>) group:
 | |
|                      group-part
 | |
|                      group group-part
 | |
| (<a href='#6.10'>6.10</a>) group-part:
 | |
|                      if-section
 | |
|                      control-line
 | |
|                      text-line
 | |
|                      # non-directive
 | |
| (<a href='#6.10'>6.10</a>) if-section:
 | |
|                      if-group elif-groupsopt else-groupopt endif-line
 | |
| (<a href='#6.10'>6.10</a>) if-group:
 | |
|                      # if constant-expression new-line groupopt
 | |
|                      # ifdef identifier new-line groupopt
 | |
|                      # ifndef identifier new-line groupopt
 | |
| (<a href='#6.10'>6.10</a>) elif-groups:
 | |
|                         elif-group
 | |
|                         elif-groups elif-group
 | |
| (<a href='#6.10'>6.10</a>) elif-group:
 | |
|                         # elif constant-expression new-line groupopt
 | |
|                         # elifdef identifier new-line groupopt
 | |
|                         # elifndef identifier new-line groupopt
 | |
| (<a href='#6.10'>6.10</a>) else-group:
 | |
|                         # else new-line groupopt
 | |
| (<a href='#6.10'>6.10</a>) endif-line:
 | |
|                         # endif new-line
 | |
| (<a href='#6.10'>6.10</a>) control-line:
 | |
|                         # include pp-tokens new-line
 | |
|                         # embed pp-tokens new-line
 | |
|                         # define identifier replacement-list new-line
 | |
|                         # define identifier lparen identifier-listopt ) replacement-list new-line
 | |
|                         # define identifier lparen ... ) replacement-list new-line
 | |
|                         # define identifier lparen identifier-list , ... ) replacement-list new-line
 | |
|                         # undef identifier new-line
 | |
|                         # line pp-tokens new-line
 | |
|                         # error pp-tokensopt new-line
 | |
|                         # warning pp-tokensopt new-line
 | |
|                         # pragma pp-tokensopt new-line
 | |
|                         # new-line
 | |
| (<a href='#6.10'>6.10</a>) text-line:
 | |
|                         pp-tokensopt new-line
 | |
| (<a href='#6.10'>6.10</a>) non-directive:
 | |
|                         pp-tokens new-line
 | |
| (<a href='#6.10'>6.10</a>) lparen:
 | |
|                        a ( character not immediately preceded by white space
 | |
| (<a href='#6.10'>6.10</a>) replacement-list:
 | |
|                         pp-tokensopt
 | |
| (<a href='#6.10'>6.10</a>) pp-tokens:
 | |
|                         preprocessing-token
 | |
|                         pp-tokens preprocessing-token
 | |
| (<a href='#6.10'>6.10</a>) new-line:
 | |
|                        the new-line character
 | |
| (<a href='#6.10'>6.10</a>) identifier-list:
 | |
|                         identifier
 | |
|                         identifier-list , identifier
 | |
| (<a href='#6.10'>6.10</a>) pp-parameter:
 | |
|                         pp-parameter-name pp-parameter-clauseopt
 | |
| (<a href='#6.10'>6.10</a>) pp-parameter-name:
 | |
|                         pp-standard-parameter
 | |
|                         pp-prefixed-parameter
 | |
| (<a href='#6.10'>6.10</a>) pp-standard-parameter:
 | |
|                         identifier
 | |
| (<a href='#6.10'>6.10</a>) pp-prefixed-parameter:
 | |
|                         identifier :: identifier
 | |
| (<a href='#6.10'>6.10</a>) pp-parameter-clause:
 | |
|                         ( pp-balanced-token-sequenceopt )
 | |
| (<a href='#6.10'>6.10</a>) pp-balanced-token-sequence:
 | |
|                         pp-balanced-token
 | |
| pp-balanced-token-sequence pp-balanced-token
 | |
| (<a href='#6.10'>6.10</a>) pp-balanced-token:
 | |
|                     ( pp-balanced-token-sequenceopt )
 | |
|                     [ pp-balanced-token-sequenceopt ]
 | |
|                     { pp-balanced-token-sequenceopt }
 | |
|                     any pp-token other than a parenthesis, a bracket, or a brace
 | |
| (<a href='#6.10'>6.10</a>) embed-parameter-sequence:
 | |
|                     pp-parameter
 | |
|                     embed-parameter-sequence pp-parameter
 | |
| 
 | |
| defined-macro-expression:
 | |
|                       defined identifier
 | |
|                       defined ( identifier )
 | |
| h-preprocessing-token:
 | |
|                     any preprocessing-token other than >
 | |
| h-pp-tokens:
 | |
|                      h-preprocessing-token
 | |
|                      h-pp-tokens h-preprocessing-token
 | |
| header-name-tokens:
 | |
|                      string-literal
 | |
|                      < h-pp-tokens >
 | |
| has-include-expression:
 | |
|                      __has_include ( header-name )
 | |
|                      __has_include ( header-name-tokens )
 | |
| has-embed-expression:
 | |
|                      __has_embed ( header-name embed-parameter-sequenceopt )
 | |
|                      __has_embed ( header-name-tokens pp-balanced-token-sequenceopt )
 | |
| has-c-attribute-express:
 | |
|                      __has_c_attribute ( pp-tokens )
 | |
| 
 | |
| va-opt-replacement:
 | |
|                     __VA_OPT__ ( pp-tokensopt )
 | |
| 
 | |
| (<a href='#6.10.7'>6.10.7</a>) standard-pragma:
 | |
|                       # pragma STDC FP_CONTRACT on-off-switch
 | |
|                       # pragma STDC FENV_ACCESS on-off-switch
 | |
|                       # pragma STDC FENV_DEC_ROUND dec-direction
 | |
|                       # pragma STDC FENV_ROUND direction
 | |
|                       # pragma STDC CX_LIMITED_RANGE on-off-switch
 | |
| 
 | |
| (<a href='#6.10.7'>6.10.7</a>) on-off-switch: one of
 | |
|                     ON       OFF     DEFAULT
 | |
| 
 | |
| (<a href='#6.10.7'>6.10.7</a>) direction: one of
 | |
|                     FE_DOWNWARD         FE_TONEAREST         FE_TONEARESTFROMZERO
 | |
|                     FE_TOWARDZERO         FE_UPWARD         FE_DYNAMIC
 | |
| 
 | |
| (<a href='#6.10.7'>6.10.7</a>) dec-direction: one of
 | |
|                     FE_DEC_DOWNWARD          FE_DEC_TONEAREST           FE_DEC_TONEARESTFROMZERO
 | |
|                     FE_DEC_TOWARDZERO          FE_DEC_UPWARD           FE_DEC_DYNAMIC
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='A.4'></a>
 | |
| <hr>
 | |
| <h3>A.4 [Floating-point subject sequence]</h3>
 | |
| <a name='A.4.1'></a>
 | |
| <hr>
 | |
| <h3>A.4.1 [NaN char sequence]</h3>
 | |
| <pre>(<a href='#7.24.1.5'>7.24.1.5</a>)         n-char-sequence:
 | |
|                    digit
 | |
|                    nondigit
 | |
|                    n-char-sequence digit
 | |
|                    n-char-sequence nondigit
 | |
| 
 | |
| </pre>
 | |
| <a name='A.4.2'></a>
 | |
| <hr>
 | |
| <h3>A.4.2 [NaN wchar_t sequence]</h3>
 | |
| <pre>(<a href='#7.31.4.1.2'>7.31.4.1.2</a>)         n-wchar-sequence:
 | |
|                    digit
 | |
|                    nondigit
 | |
|                    n-wchar-sequence digit
 | |
|                    n-wchar-sequence nondigit
 | |
| 
 | |
| </pre>
 | |
| <a name='A.5'></a>
 | |
| <hr>
 | |
| <h3>A.5 [Decimal floating-point subject sequence]</h3>
 | |
| <a name='A.5.1'></a>
 | |
| <hr>
 | |
| <h3>A.5.1 [NaN decimal char sequence]</h3>
 | |
| <pre>(<a href='#7.24.1.6'>7.24.1.6</a>)         d-char-sequence:
 | |
|                    digit
 | |
|                    nondigit
 | |
|                    d-char-sequence digit
 | |
|                    d-char-sequence nondigit
 | |
| 
 | |
| </pre>
 | |
| <a name='A.5.2'></a>
 | |
| <hr>
 | |
| <h3>A.5.2 [NaN decimal wchar_t sequence]</h3>
 | |
| <pre>(<a href='#7.31.4.1.3'>7.31.4.1.3</a>)        d-wchar-sequence:
 | |
|                    digit
 | |
|                    nondigit
 | |
|                    d-wchar-sequence digit
 | |
|                    d-wchar-sequence nondigit
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.'></a>
 | |
| <hr>
 | |
| <h3>B. [Annex B (informative) Library summary]</h3>
 | |
| <a name='B.1'></a>
 | |
| <hr>
 | |
| <h3>B.1 [Diagnostics <assert.h>]</h3>
 | |
| <pre>NDEBUG
 | |
| 
 | |
| 
 | |
|  void assert(scalar expression);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.2'></a>
 | |
| <hr>
 | |
| <h3>B.2 [Complex <complex.h>]</h3>
 | |
| <pre>__STDC_NO_COMPLEX__                          imaginary
 | |
| complex                                      _Imaginary_I
 | |
| _Complex_I                                   I
 | |
| 
 | |
| 
 | |
|  #pragma STDC CX_LIMITED_RANGE on-off-switch
 | |
|  double complex cacos(double complex z);
 | |
|  float complex cacosf(float complex z);
 | |
|  long double complex cacosl(long double complex z);
 | |
|  double complex casin(double complex z);
 | |
|  float complex casinf(float complex z);
 | |
|  long double complex casinl(long double complex z);
 | |
|  double complex catan(double complex z);
 | |
|  float complex catanf(float complex z);
 | |
|  long double complex catanl(long double complex z);
 | |
|  double complex ccos(double complex z);
 | |
|  float complex ccosf(float complex z);
 | |
|  long double complex ccosl(long double complex z);
 | |
|  double complex csin(double complex z);
 | |
|  float complex csinf(float complex z);
 | |
|  long double complex csinl(long double complex z);
 | |
|  double complex ctan(double complex z);
 | |
|  float complex ctanf(float complex z);
 | |
|  long double complex ctanl(long double complex z);
 | |
|  double complex cacosh(double complex z);
 | |
|  float complex cacoshf(float complex z);
 | |
|  long double complex cacoshl(long double complex z);
 | |
|  double complex casinh(double complex z);
 | |
|  float complex casinhf(float complex z);
 | |
|  long double complex casinhl(long double complex z);
 | |
|  double complex catanh(double complex z);
 | |
|  float complex catanhf(float complex z);
 | |
|  long double complex catanhl(long double complex z);
 | |
|  double complex ccosh(double complex z);
 | |
|  float complex ccoshf(float complex z);
 | |
|  long double complex ccoshl(long double complex z);
 | |
|  double complex csinh(double complex z);
 | |
|  float complex csinhf(float complex z);
 | |
|  long double complex csinhl(long double complex z);
 | |
|  double complex ctanh(double complex z);
 | |
|  float complex ctanhf(float complex z);
 | |
|  long double complex ctanhl(long double complex z);
 | |
|  double complex cexp(double complex z);
 | |
|  float complex cexpf(float complex z);
 | |
|  long double complex cexpl(long double complex z);
 | |
|  double complex clog(double complex z);
 | |
|  float complex clogf(float complex z);
 | |
|  long double complex clogl(long double complex z);
 | |
|  double cabs(double complex z);
 | |
|  float cabsf(float complex z);
 | |
|  long double cabsl(long double complex z);
 | |
|  double complex cpow(double complex x, double complex y);
 | |
|  float complex cpowf(float complex x, float complex y);
 | |
|  long double complex cpowl(long double complex x, long double complex y);
 | |
|  double complex csqrt(double complex z);
 | |
|  float complex csqrtf(float complex z);
 | |
|  long double complex csqrtl(long double complex z);
 | |
|  double carg(double complex z);
 | |
|  float cargf(float complex z);
 | |
|  long double cargl(long double complex z);
 | |
|  double cimag(double complex z);
 | |
|  float cimagf(float complex z);
 | |
|  long double cimagl(long double complex z);
 | |
|  double complex CMPLX(double x, double y);
 | |
|  float complex CMPLXF(float x, float y);
 | |
|  long double complex CMPLXL(long double x, long double y);
 | |
|  double complex conj(double complex z);
 | |
|  float complex conjf(float complex z);
 | |
|  long double complex conjl(long double complex z);
 | |
|  double complex cproj(double complex z);
 | |
|  float complex cprojf(float complex z);
 | |
|  long double complex cprojl(long double complex z);
 | |
|  double creal(double complex z);
 | |
|  float crealf(float complex z);
 | |
|  long double creall(long double complex z);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.3'></a>
 | |
| <hr>
 | |
| <h3>B.3 [Character handling <ctype.h>]</h3>
 | |
| <pre>int isalnum(int c);
 | |
|  int isalpha(int c);
 | |
|  int isblank(int c);
 | |
|  int iscntrl(int c);
 | |
|  int isdigit(int c);
 | |
|  int isgraph(int c);
 | |
|  int islower(int c);
 | |
|  int isprint(int c);
 | |
|  int ispunct(int c);
 | |
|  int isspace(int c);
 | |
|  int isupper(int c);
 | |
|  int isxdigit(int c);
 | |
|  int tolower(int c);
 | |
|  int toupper(int c);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.4'></a>
 | |
| <hr>
 | |
| <h3>B.4 [Errors <errno.h>]</h3>
 | |
| <pre>EDOM                    EILSEQ                ERANGE                  errno
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <errno.h>:
 | |
| 
 | |
| errno_t
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.5'></a>
 | |
| <hr>
 | |
| <h3>B.5 [Floating-point environment <fenv.h>]</h3>
 | |
| <pre>fenv_t                         FE_OVERFLOW                     FE_TOWARDZERO
 | |
| fexcept_t                      FE_UNDERFLOW                    FE_UPWARD
 | |
| FE_DIVBYZERO                   FE_ALL_EXCEPT                   FE_DFL_ENV
 | |
| FE_INEXACT                     FE_DOWNWARD
 | |
| FE_INVALID                     FE_TONEAREST
 | |
| 
 | |
| 
 | |
| 
 | |
|  #pragma STDC FENV_ACCESS on-off-switch
 | |
|  #pragma STDC FENV_ROUND direction
 | |
|  #pragma STDC FENV_ROUND FE_DYNAMIC
 | |
|  int feclearexcept(int excepts);
 | |
|  int fegetexceptflag(fexcept_t *flagp, int excepts);
 | |
|  int feraiseexcept(int excepts);
 | |
|  int fesetexcept(int excepts);
 | |
|  int fesetexceptflag(const fexcept_t *flagp, int excepts);
 | |
|  int fetestexceptflag(const fexcept_t * flagp, int excepts);
 | |
|  int fetestexcept(int excepts);
 | |
|  int fegetmode(femode_t *modep);
 | |
|  int fegetround(void);
 | |
|  int fesetmode(const femode_t *modep);
 | |
|  int fesetround(int rnd);
 | |
|  int fegetenv(fenv_t *envp);
 | |
|  int feholdexcept(fenv_t *envp);
 | |
|  int fesetenv(const fenv_t *envp);
 | |
|  int feupdateenv(const fenv_t *envp);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_IEC_60559_DFP__ :
 | |
| 
 | |
| 
 | |
| FE_DEC_DOWNWARD                FE_DEC_TONEARESTFROMZERO        FE_DEC_UPWARD
 | |
| FE_DEC_TONEAREST               FE_DEC_TOWARDZERO
 | |
| 
 | |
| 
 | |
| 
 | |
|  #pragma STDC FENV_DEC_ROUND dec-direction
 | |
|  int fe_dec_getround(void);
 | |
|  int fe_dec_setround(int rnd);
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.6'></a>
 | |
| <hr>
 | |
| <h3>B.6 [Characteristics of floating types <float.h>]</h3>
 | |
| <pre>FLT_ROUNDS                     LDBL_DIG                        DBL_NORM_MAX
 | |
| FLT_EVAL_METHOD                FLT_MIN_EXP                     LDBL_NORM_MAX
 | |
| FLT_HAS_SUBNORM                DBL_MIN_EXP                     FLT_EPSILON
 | |
| DBL_HAS_SUBNORM                LDBL_MIN_EXP                    DBL_EPSILON
 | |
| LDBL_HAS_SUBNORM               FLT_MIN_10_EXP                  LDBL_EPSILON
 | |
| FLT_RADIX                      DBL_MIN_10_EXP                  FLT_MIN
 | |
| FLT_MANT_DIG                   LDBL_MIN_10_EXP                 DBL_MIN
 | |
| DBL_MANT_DIG                   FLT_MAX_EXP                     LDBL_MIN
 | |
| LDBL_MANT_DIG                  DBL_MAX_EXP                     FLT_SNAN
 | |
| FLT_DECIMAL_DIG                LDBL_MAX_EXP                    DBL_SNAN
 | |
| DBL_DECIMAL_DIG                FLT_MAX_10_EXP                  LDBL_SNAN
 | |
| LDBL_DECIMAL_DIG               DBL_MAX_10_EXP                  FLT_TRUE_MIN
 | |
| DECIMAL_DIG                    LDBL_MAX_10_EXP                 DBL_TRUE_MIN
 | |
| FLT_IS_IEC_60559               FLT_MAX                         LDBL_TRUE_MIN
 | |
| DBL_IS_IEC_60559               DBL_MAX                         INFINITY
 | |
| FLT_DIG                        LDBL_MAX                        NAN
 | |
| DBL_DIG                        FLT_NORM_MAX
 | |
| </pre>
 | |
| <a name='B.6.1'></a>
 | |
| <hr>
 | |
| <h3>B.6.1 [Characteristics of decimal floating types]</h3>
 | |
| <a name='B.6.1p1'></a>
 | |
| <pre>1   The following macros are provided only if the implementation defines __STDC_IEC_60559_DFP__ .
 | |
|     N is 32, 64 and 128.
 | |
| 
 | |
|     DEC_INFINITY           DECN_MANT_DIG           DECN_MIN_EXP            DECN_SNAN
 | |
|     DEC_NAN                DECN_MAX_EXP            DECN_MIN
 | |
|     DECN_EPSILON           DECN_MAX                DECN_TRUE_MIN
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.7'></a>
 | |
| <hr>
 | |
| <h3>B.7 [Format conversion of integer types <inttypes.h>]</h3>
 | |
| <pre>imaxdiv_t
 | |
| 
 | |
|      PRIdN        PRIdLEASTN   PRIdFASTN      PRIdMAX       PRIdPTR
 | |
|      PRIiN        PRIiLEASTN   PRIiFASTN      PRIiMAX       PRIiPTR
 | |
|      PRIoN        PRIoLEASTN   PRIoFASTN      PRIoMAX       PRIoPTR
 | |
|      PRIuN        PRIuLEASTN   PRIuFASTN      PRIuMAX       PRIuPTR
 | |
|      PRIxN        PRIxLEASTN   PRIxFASTN      PRIxMAX       PRIxPTR
 | |
|      PRIXN        PRIXLEASTN   PRIXFASTN      PRIXMAX       PRIXPTR
 | |
|      SCNdN        SCNdLEASTN   SCNdFASTN      SCNdMAX       SCNdPTR
 | |
|      SCNiN        SCNiLEASTN   SCNiFASTN      SCNiMAX       SCNiPTR
 | |
|      SCNoN        SCNoLEASTN   SCNoFASTN      SCNoMAX       SCNoPTR
 | |
|      SCNuN        SCNuLEASTN   SCNuFASTN      SCNuMAX       SCNuPTR
 | |
|      SCNxN        SCNxLEASTN   SCNxFASTN      SCNxMAX       SCNxPTR
 | |
| 
 | |
|      intmax_t imaxabs(intmax_t j);
 | |
|      imaxdiv_t imaxdiv(intmax_t numer, intmax_t denom);
 | |
|      intmax_t strtoimax(const char * restrict nptr, char ** restrict endptr, int base);
 | |
|      uintmax_t strtoumax(const char * restrict nptr, char ** restrict endptr, int base);
 | |
|      intmax_t wcstoimax(const wchar_t *restrict nptr, wchar_t **restrict endptr, int base);
 | |
|      uintmax_t wcstoumax(const wchar_t *restrict nptr, wchar_t **restrict endptr, int base);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.8'></a>
 | |
| <hr>
 | |
| <h3>B.8 [Alternative spellings <iso646.h>]</h3>
 | |
| <pre>and                    bitor                   not_eq                  xor
 | |
|     and_eq                 compl                   or                      xor_eq
 | |
|     bitand                 not                     or_eq
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.9'></a>
 | |
| <hr>
 | |
| <h3>B.9 [Sizes of integer types <limits.h>]</h3>
 | |
| <pre>BOOL_WIDTH             UINT_WIDTH              UCHAR_MAX               INT_MAX
 | |
|     CHAR_BIT               LONG_WIDTH              CHAR_MIN                UINT_MAX
 | |
|     CHAR_WIDTH             ULONG_WIDTH             CHAR_MAX                LONG_MIN
 | |
|     SCHAR_WIDTH            LLONG_WIDTH             MB_LEN_MAX              LONG_MAX
 | |
|     UCHAR_WIDTH            ULLONG_WIDTH            SHRT_MIN                ULONG_MAX
 | |
|     SHRT_WIDTH             BOOL_MAX                SHRT_MAX                LLONG_MIN
 | |
|     USHRT_WIDTH            SCHAR_MIN               USHRT_MAX               LLONG_MAX
 | |
|     INT_WIDTH              SCHAR_MAX               INT_MIN                 ULLONG_MAX
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.10'></a>
 | |
| <hr>
 | |
| <h3>B.10 [Localization <locale.h>]</h3>
 | |
| <pre>struct lconv           LC_ALL                  LC_CTYPE                LC_NUMERIC
 | |
|     NULL                   LC_COLLATE              LC_MONETARY             LC_TIME
 | |
| 
 | |
| 
 | |
|      char *setlocale(int category, const char *locale);
 | |
|      struct lconv *localeconv(void);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.11'></a>
 | |
| <hr>
 | |
| <h3>B.11 [Mathematics <math.h>]</h3>
 | |
| <pre>float_t                      FP_INFINITE               FP_FAST_FMAL
 | |
| double_t                     FP_NAN                    FP_ILOGB0
 | |
| HUGE_VAL                     FP_NORMAL                 FP_ILOGBNAN
 | |
| HUGE_VALF                    FP_SUBNORMAL              MATH_ERRNO
 | |
| HUGE_VALL                    FP_ZERO                   MATH_ERREXCEPT
 | |
| INFINITY                     FP_FAST_FMA               math_errhandling
 | |
| NAN                          FP_FAST_FMAF
 | |
| 
 | |
| 
 | |
| 
 | |
|  #pragma STDC FP_CONTRACT on-off-switch
 | |
|  int fpclassify(real-floating x);
 | |
|  int iscanonical(real-floating x);
 | |
|  int isfinite(real-floating x);
 | |
|  int isinf(real-floating x);
 | |
|  int isnan(real-floating x);
 | |
|  int isnormal(real-floating x);
 | |
|  int signbit(real-floating x);
 | |
|  int issignaling(real-floating x);
 | |
|  int issubnormal(real-floating x);
 | |
|  int iszero(real-floating x);
 | |
|  double acos(double x);
 | |
|  float acosf(float x);
 | |
|  long double acosl(long double x);
 | |
|  double asin(double x);
 | |
|  float asinf(float x);
 | |
|  long double asinl(long double x);
 | |
|  double atan(double x);
 | |
|  float atanf(float x);
 | |
|  long double atanl(long double x);
 | |
|  double atan2(double y, double x);
 | |
|  float atan2f(float y, float x);
 | |
|  long double atan2l(long double y, long double x);
 | |
|  double cos(double x);
 | |
|  float cosf(float x);
 | |
|  long double cosl(long double x);
 | |
|  double sin(double x);
 | |
|  float sinf(float x);
 | |
|  long double sinl(long double x);
 | |
|  double tan(double x);
 | |
|  float tanf(float x);
 | |
|  long double tanl(long double x);
 | |
|  double acospi(double x);
 | |
|  float acospif(float x);
 | |
|  long double acospil(long double x);
 | |
|  double asinpi(double x);
 | |
|  float asinpif(float x);
 | |
|  long double asinpil(long double x);
 | |
|  double atanpi(double x);
 | |
|  float atanpif(float x);
 | |
|  long double atanpil(long double x);
 | |
|  double atan2pi(double y, double x);
 | |
|  float atan2pif(float y, float x);
 | |
|  long double atan2pil(long double y, long double x);
 | |
|  double cospi(double x);
 | |
|  float cospif(float x);
 | |
|  long double cospil(long double x);
 | |
|  double sinpi(double x);
 | |
|  float sinpif(float x);
 | |
|  long double sinpil(long double x);
 | |
|  double tanpi(double x);
 | |
|  float tanpif(float x);
 | |
| long double tanpil(long double x);
 | |
| double acosh(double x);
 | |
| float acoshf(float x);
 | |
| long double acoshl(long double x);
 | |
| double asinh(double x);
 | |
| float asinhf(float x);
 | |
| long double asinhl(long double x);
 | |
| double atanh(double x);
 | |
| float atanhf(float x);
 | |
| long double atanhl(long double x);
 | |
| double cosh(double x);
 | |
| float coshf(float x);
 | |
| long double coshl(long double x);
 | |
| double sinh(double x);
 | |
| float sinhf(float x);
 | |
| long double sinhl(long double x);
 | |
| double tanh(double x);
 | |
| float tanhf(float x);
 | |
| long double tanhl(long double x);
 | |
| double exp(double x);
 | |
| float expf(float x);
 | |
| long double expl(long double x);
 | |
| double exp10(double x);
 | |
| float exp10f(float x);
 | |
| long double exp10l(long double x);
 | |
| double exp10m1(double x);
 | |
| float exp10m1f(float x);
 | |
| long double exp10m1l(long double x);
 | |
| double exp2(double x);
 | |
| float exp2f(float x);
 | |
| long double exp2l(long double x);
 | |
| double exp2m1(double x);
 | |
| float exp2m1f(float x);
 | |
| long double exp2m1l(long double x);
 | |
| double expm1(double x);
 | |
| float expm1f(float x);
 | |
| long double expm1l(long double x);
 | |
| double frexp(double value, int *p);
 | |
| float frexpf(float value, int *p);
 | |
| long double frexpl(long double value, int *p);
 | |
| int ilogb(double x);
 | |
| int ilogbf(float x);
 | |
| int ilogbl(long double x);
 | |
| double ldexp(double x, int p);
 | |
| float ldexpf(float x, int p);
 | |
| long double ldexpl(long double x, int p);
 | |
| long int llogb(double x);
 | |
| long int llogbf(float x);
 | |
| long int llogbl(long double x);
 | |
| double log(double x);
 | |
| float logf(float x);
 | |
| long double logl(long double x);
 | |
| double log10(double x);
 | |
| float log10f(float x);
 | |
| long double log10l(long double x);
 | |
| double log10p1(double x);
 | |
| float log10p1f(float x);
 | |
| long double log10p1l(long double x);
 | |
| double log1p(double x);
 | |
| float log1pf(float x);
 | |
| long double log1pl(long double x);
 | |
| double logp1(double x);
 | |
| float logp1f(float x);
 | |
| long double logp1l(long double x);
 | |
| double log2(double x);
 | |
| float log2f(float x);
 | |
| long double log2l(long double x);
 | |
| double log2p1(double x);
 | |
| float log2p1f(float x);
 | |
| long double log2p1l(long double x);
 | |
| double logb(double x);
 | |
| float logbf(float x);
 | |
| long double logbl(long double x);
 | |
| double modf(double value, double *iptr);
 | |
| float modff(float value, float *iptr);
 | |
| long double modfl(long double value, long double *iptr);
 | |
| double scalbn(double x, int n);
 | |
| float scalbnf(float x, int n);
 | |
| long double scalbnl(long double x, int n);
 | |
| double scalbln(double x, long int n);
 | |
| float scalblnf(float x, long int n);
 | |
| long double scalblnl(long double x, long int n);
 | |
| double cbrt(double x);
 | |
| float cbrtf(float x);
 | |
| long double cbrtl(long double x);
 | |
| double compoundn(double x, long long int n);
 | |
| float compoundnf(float x, long long int n);
 | |
| long double compoundnl(long double x, long long int n);
 | |
| double fabs(double x);
 | |
| float fabsf(float x);
 | |
| long double fabsl(long double x);
 | |
| double hypot(double x, double y);
 | |
| float hypotf(float x, float y);
 | |
| long double hypotl(long double x, long double y);
 | |
| double pow(double x, double y);
 | |
| float powf(float x, float y);
 | |
| long double powl(long double x, long double y);
 | |
| double pown(double x, long long int n);
 | |
| float pownf(float x, long long int n);
 | |
| long double pownl(long double x, long long int n);
 | |
| double powr(double y, double x);
 | |
| float powrf(float y, float x);
 | |
| long double powrl(long double y, long double x);
 | |
| double rootn(double x, long long int n);
 | |
| float rootnf(float x, long long int n);
 | |
| long double rootnl(long double x, long long int n);
 | |
| double rsqrt(double x);
 | |
| float rsqrtf(float x);
 | |
| long double rsqrtl(long double x);
 | |
| double sqrt(double x);
 | |
| float sqrtf(float x);
 | |
| long double sqrtl(long double x);
 | |
| double erf(double x);
 | |
| float erff(float x);
 | |
| long double erfl(long double x);
 | |
| double erfc(double x);
 | |
| float erfcf(float x);
 | |
| long double erfcl(long double x);
 | |
| double lgamma(double x);
 | |
| float lgammaf(float x);
 | |
| long double lgammal(long double x);
 | |
| double tgamma(double x);
 | |
| float tgammaf(float x);
 | |
| long double tgammal(long double x);
 | |
| double ceil(double x);
 | |
| float ceilf(float x);
 | |
| long double ceill(long double x);
 | |
| double floor(double x);
 | |
| float floorf(float x);
 | |
| long double floorl(long double x);
 | |
| double nearbyint(double x);
 | |
| float nearbyintf(float x);
 | |
| long double nearbyintl(long double x);
 | |
| double rint(double x);
 | |
| float rintf(float x);
 | |
| long double rintl(long double x);
 | |
| long int lrint(double x);
 | |
| long int lrintf(float x);
 | |
| long int lrintl(long double x);
 | |
| long long int llrint(double x);
 | |
| long long int llrintf(float x);
 | |
| long long int llrintl(long double x);
 | |
| double round(double x);
 | |
| float roundf(float x);
 | |
| long double roundl(long double x);
 | |
| long int lround(double x);
 | |
| long int lroundf(float x);
 | |
| long int lroundl(long double x);
 | |
| long long int llround(double x);
 | |
| long long int llroundf(float x);
 | |
| long long int llroundl(long double x);
 | |
| double roundeven(double x);
 | |
| float roundevenf(float x);
 | |
| long double roundevenl(long double x);
 | |
| double trunc(double x);
 | |
| float truncf(float x);
 | |
| long double truncl(long double x);
 | |
| double fromfp(double x, int rnd, unsigned int width);
 | |
| float fromfpf(float x, int rnd, unsigned int width);
 | |
| long double fromfpl(long double x, int rnd, unsigned int width);
 | |
| double ufromfp(double x, int rnd, unsigned int width);
 | |
| float ufromfpf(float x, int rnd, unsigned int width);
 | |
| long double ufromfpl(long double x, int rnd, unsigned int width);
 | |
| double fromfpx(double x, int rnd, unsigned int width);
 | |
| float fromfpxf(float x, int rnd, unsigned int width);
 | |
| long double fromfpxl(long double x, int rnd, unsigned int width);
 | |
| double ufromfpx(double x, int rnd, unsigned int width);
 | |
| float ufromfpxf(float x, int rnd, unsigned int width);
 | |
| long double ufromfpxl(long double x, int rnd, unsigned int width);
 | |
| double fmod(double x, double y);
 | |
| float fmodf(float x, float y);
 | |
| long double fmodl(long double x, long double y);
 | |
| double remainder(double x, double y);
 | |
| float remainderf(float x, float y);
 | |
| long double remainderl(long double x, long double y);
 | |
| double remquo(double x, double y, int *quo);
 | |
| float remquof(float x, float y, int *quo);
 | |
| long double remquol(long double x, long double y, int *quo);
 | |
| double copysign(double x, double y);
 | |
| float copysignf(float x, float y);
 | |
| long double copysignl(long double x, long double y);
 | |
| double nan(const char *tagp);
 | |
| float nanf(const char *tagp);
 | |
| long double nanl(const char *tagp);
 | |
| double nextafter(double x, double y);
 | |
| float nextafterf(float x, float y);
 | |
| long double nextafterl(long double x, long double y);
 | |
| double nexttoward(double x, long double y);
 | |
| float nexttowardf(float x, long double y);
 | |
| long double nexttowardl(long double x, long double y);
 | |
| double nextup(double x);
 | |
| float nextupf(float x);
 | |
| long double nextupl(long double x);
 | |
| double nextdown(double x);
 | |
| float nextdownf(float x);
 | |
| long double nextdownl(long double x);
 | |
| int canonicalize(double * cx, const double * x);
 | |
| int canonicalizef(float * cx, const float * x);
 | |
| int canonicalizel(long double * cx, const long double * x);
 | |
| double fdim(double x, double y);
 | |
| float fdimf(float x, float y);
 | |
| long double fdiml(long double x, long double y);
 | |
| double fmax(double x, double y);
 | |
| float fmaxf(float x, float y);
 | |
| long double fmaxl(long double x, long double y);
 | |
| double fmin(double x, double y);
 | |
| float fminf(float x, float y);
 | |
| long double fminl(long double x, long double y);
 | |
| double fmaximum(double x, double y);
 | |
| float fmaximumf(float x, float y);
 | |
| long double fmaximuml(long double x, long double y);
 | |
| double fminimum(double x, double y);
 | |
| float fminimumf(float x, float y);
 | |
| long double fminimuml(long double x, long double y);
 | |
| double fmaximum_mag(double x, double y);
 | |
| float fmaximum_magf(float x, float y);
 | |
| long double fmaximum_magl(long double x, long double y);
 | |
| double fminimum_mag(double x, double y);
 | |
| float fminimum_magf(float x, float y);
 | |
| long double fminimum_magl(long double x, long double y);
 | |
| double fmaximum_num(double x, double y);
 | |
| float fmaximum_numf(float x, float y);
 | |
| long double fmaximum_numl(long double x, long double y);
 | |
| double fminimum_num(double x, double y);
 | |
| float fminimum_numf(float x, float y);
 | |
| long double fminimum_numl(long double x, long double y);
 | |
| double fmaximum_mag_num(double x, double y);
 | |
| float fmaximum_mag_numf(float x, float y);
 | |
| long double fmaximum_mag_numl(long double x, long double y);
 | |
| double fminimum_mag_num(double x, double y);
 | |
| float fminimum_mag_numf(float x, float y);
 | |
| long double fminimum_mag_numl(long double x, long double y);
 | |
| double fma(double x, double y, double z);
 | |
| float fmaf(float x, float y, float z);
 | |
| long double fmal(long double x, long double y, long double z);
 | |
| float fadd(double x, double y);
 | |
| float faddl(long double x, long double y);
 | |
| double daddl(long double x, long double y);
 | |
| float fsub(double x, double y);
 | |
| float fsubl(long double x, long double y);
 | |
| double dsubl(long double x, long double y);
 | |
| float fmul(double x, double y);
 | |
| float fmull(long double x, long double y);
 | |
| double dmull(long double x, long double y);
 | |
|  float fdiv(double x, double y);
 | |
|  float fdivl(long double x, long double y);
 | |
|  double ddivl(long double x, long double y);
 | |
|  float ffma(double x, double y, double z);
 | |
|  float ffmal(long double x, long double y, long double z);
 | |
|  double dfmal(long double x, long double y, long double z);
 | |
|  float fsqrt(double x);
 | |
|  float fsqrtl(long double x);
 | |
|  double dsqrtl(long double x);
 | |
|  int isgreater(real-floating x, real-floating y);
 | |
|  int isgreaterequal(real-floating x, real-floating y);
 | |
|  int isless(real-floating x, real-floating y);
 | |
|  int islessequal(real-floating x, real-floating y);
 | |
|  int islessgreater(real-floating x, real-floating y);
 | |
|  int isunordered(real-floating x, real-floating y);
 | |
|  int iseqsig(real-floating x, real-floating y);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_IEC_60559_DFP__ :
 | |
|  _Decimal32 acosd32(_Decimal32 x);
 | |
|  _Decimal64 acosd64(_Decimal64 x);
 | |
|  _Decimal128 acosd128(_Decimal128 x);
 | |
|  _Decimal32 asind32(_Decimal32 x);
 | |
|  _Decimal64 asind64(_Decimal64 x);
 | |
|  _Decimal128 asind128(_Decimal128 x);
 | |
|  _Decimal32 atand32(_Decimal32 x);
 | |
|  _Decimal64 atand64(_Decimal64 x);
 | |
|  _Decimal128 atand128(_Decimal128 x);
 | |
|  _Decimal32 atan2d32(_Decimal32 y, _Decimal32 x);
 | |
|  _Decimal64 atan2d64(_Decimal64 y, _Decimal64 x);
 | |
|  _Decimal128 atan2d128(_Decimal128 y, _Decimal128 x);
 | |
|  _Decimal32 cosd32(_Decimal32 x);
 | |
|  _Decimal64 cosd64(_Decimal64 x);
 | |
|  _Decimal128 cosd128(_Decimal128 x);
 | |
|  _Decimal32 sind32(_Decimal32 x);
 | |
|  _Decimal64 sind64(_Decimal64 x);
 | |
|  _Decimal128 sind128(_Decimal128 x);
 | |
|  _Decimal32 tand32(_Decimal32 x);
 | |
|  _Decimal64 tand64(_Decimal64 x);
 | |
|  _Decimal128 tand128(_Decimal128 x);
 | |
|  _Decimal32 acospid32(_Decimal32 x);
 | |
|  _Decimal64 acospid64(_Decimal64 x);
 | |
|  _Decimal128 acospid128(_Decimal128 x);
 | |
|  _Decimal32 asinpid32(_Decimal32 x);
 | |
|  _Decimal64 asinpid64(_Decimal64 x);
 | |
|  _Decimal128 asinpid128(_Decimal128 x);
 | |
|  _Decimal32 atanpid32(_Decimal32 x);
 | |
|  _Decimal64 atanpid64(_Decimal64 x);
 | |
|  _Decimal128 atanpid128(_Decimal128 x);
 | |
|  _Decimal32 atan2pid32(_Decimal32 y, _Decimal32 x);
 | |
|  _Decimal64 atan2pid64(_Decimal64 y, _Decimal64 x);
 | |
|  _Decimal128 atan2pid128(_Decimal128 y, _Decimal128 x);
 | |
|  _Decimal32 cospid32(_Decimal32 x);
 | |
|  _Decimal64 cospid64(_Decimal64 x);
 | |
|  _Decimal128 cospid128(_Decimal128 x);
 | |
|  _Decimal32 sinpid32(_Decimal32 x);
 | |
|  _Decimal64 sinpid64(_Decimal64 x);
 | |
|  _Decimal128 sinpid128(_Decimal128 x);
 | |
|  _Decimal32 tanpid32(_Decimal32 x);
 | |
|  _Decimal64 tanpid64(_Decimal64 x);
 | |
|  _Decimal128 tanpid128(_Decimal128 x);
 | |
| _Decimal32 acoshd32(_Decimal32 x);
 | |
| _Decimal64 acoshd64(_Decimal64 x);
 | |
| _Decimal128 acoshd128(_Decimal128 x);
 | |
| _Decimal32 asinhd32(_Decimal32 x);
 | |
| _Decimal64 asinhd64(_Decimal64 x);
 | |
| _Decimal128 asinhd128(_Decimal128 x);
 | |
| _Decimal32 atanhd32(_Decimal32 x);
 | |
| _Decimal64 atanhd64(_Decimal64 x);
 | |
| _Decimal128 atanhd128(_Decimal128 x);
 | |
| _Decimal32 coshd32(_Decimal32 x);
 | |
| _Decimal64 coshd64(_Decimal64 x);
 | |
| _Decimal128 coshd128(_Decimal128 x);
 | |
| _Decimal32 sinhd32(_Decimal32 x);
 | |
| _Decimal64 sinhd64(_Decimal64 x);
 | |
| _Decimal128 sinhd128(_Decimal128 x);
 | |
| _Decimal32 tanhd32(_Decimal32 x);
 | |
| _Decimal64 tanhd64(_Decimal64 x);
 | |
| _Decimal128 tanhd128(_Decimal128 x);
 | |
| _Decimal32 expd32(_Decimal32 x);
 | |
| _Decimal64 expd64(_Decimal64 x);
 | |
| _Decimal128 expd128(_Decimal128 x);
 | |
| _Decimal32 exp10d32(_Decimal32 x);
 | |
| _Decimal64 exp10d64(_Decimal64 x);
 | |
| _Decimal128 exp10d128(_Decimal128 x);
 | |
| _Decimal32 exp10m1d32(_Decimal32 x);
 | |
| _Decimal64 exp10m1d64(_Decimal64 x);
 | |
| _Decimal128 exp10m1d128(_Decimal128 x);
 | |
| _Decimal32 exp2d32(_Decimal32 x);
 | |
| _Decimal64 exp2d64(_Decimal64 x);
 | |
| _Decimal128 exp2d128(_Decimal128 x);
 | |
| _Decimal32 exp2m1d32(_Decimal32 x);
 | |
| _Decimal64 exp2m1d64(_Decimal64 x);
 | |
| _Decimal128 exp2m1d128(_Decimal128 x);
 | |
| _Decimal32 expm1d32(_Decimal32 x);
 | |
| _Decimal64 expm1d64(_Decimal64 x);
 | |
| _Decimal128 expm1d128(_Decimal128 x);
 | |
| _Decimal32 frexpd32(_Decimal32 value, int *p);
 | |
| _Decimal64 frexpd64(_Decimal64 value, int *p);
 | |
| _Decimal128 frexpd128(_Decimal128 value, int *p);
 | |
| int ilogbd32(_Decimal32 x);
 | |
| int ilogbd64(_Decimal64 x);
 | |
| int ilogbd128(_Decimal128 x);
 | |
| _Decimal32 ldexpd32(_Decimal32 x, int p);
 | |
| _Decimal64 ldexpd64(_Decimal64 x, int p);
 | |
| _Decimal128 ldexpd128(_Decimal128 x, int p);
 | |
| long int llogbd32(_Decimal32 x);
 | |
| long int llogbd64(_Decimal64 x);
 | |
| long int llogbd128(_Decimal128 x);
 | |
| _Decimal32 logd32(_Decimal32 x);
 | |
| _Decimal64 logd64(_Decimal64 x);
 | |
| _Decimal128 logd128(_Decimal128 x);
 | |
| _Decimal32 log10d32(_Decimal32 x);
 | |
| _Decimal64 log10d64(_Decimal64 x);
 | |
| _Decimal128 log10d128(_Decimal128 x);
 | |
| _Decimal32 log10p1d32(_Decimal32 x);
 | |
| _Decimal64 log10p1d64(_Decimal64 x);
 | |
| _Decimal128 log10p1d128(_Decimal128 x);
 | |
| _Decimal32 log1pd32(_Decimal32 x);
 | |
| _Decimal64 log1pd64(_Decimal64 x);
 | |
| _Decimal128 log1pd128(_Decimal128 x);
 | |
| _Decimal32 logp1d32(_Decimal32 x);
 | |
| _Decimal64 logp1d64(_Decimal64 x);
 | |
| _Decimal128 logp1d128(_Decimal128 x);
 | |
| _Decimal32 log2d32(_Decimal32 x);
 | |
| _Decimal64 log2d64(_Decimal64 x);
 | |
| _Decimal128 log2d128(_Decimal128 x);
 | |
| _Decimal32 log2p1d32(_Decimal32 x);
 | |
| _Decimal64 log2p1d64(_Decimal64 x);
 | |
| _Decimal128 log2p1d128(_Decimal128 x);
 | |
| _Decimal32 logbd32(_Decimal32 x);
 | |
| _Decimal64 logbd64(_Decimal64 x);
 | |
| _Decimal128 logbd128(_Decimal128 x);
 | |
| _Decimal32 modfd32(_Decimal32 x, _Decimal32 *iptr);
 | |
| _Decimal64 modfd64(_Decimal64 x, _Decimal64 *iptr);
 | |
| _Decimal128 modfd128(_Decimal128 x, _Decimal128 *iptr);
 | |
| _Decimal32 scalbnd32(_Decimal32 x, int n);
 | |
| _Decimal64 scalbnd64(_Decimal64 x, int n);
 | |
| _Decimal128 scalbnd128(_Decimal128 x, int n);
 | |
| _Decimal32 scalblnd32(_Decimal32 x, long int n);
 | |
| _Decimal64 scalblnd64(_Decimal64 x, long int n);
 | |
| _Decimal128 scalblnd128(_Decimal128 x, long int n);
 | |
| _Decimal32 cbrtd32(_Decimal32 x);
 | |
| _Decimal64 cbrtd64(_Decimal64 x);
 | |
| _Decimal128 cbrtd128(_Decimal128 x);
 | |
| _Decimal32 compoundnd32(_Decimal32 x, long long int n);
 | |
| _Decimal64 compoundnd64(_Decimal64 x, long long int n);
 | |
| _Decimal128 compoundnd128(_Decimal128 x, long long int n);
 | |
| _Decimal32 fabsd32(_Decimal32 x);
 | |
| _Decimal64 fabsd64(_Decimal64 x);
 | |
| _Decimal128 fabsd128(_Decimal128 x);
 | |
| _Decimal32 hypotd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 hypotd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 hypotd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 powd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 powd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 powd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 pownd32(_Decimal32 x, long long int n);
 | |
| _Decimal64 pownd64(_Decimal64 x, long long int n);
 | |
| _Decimal128 pownd128(_Decimal128 x, long long int n);
 | |
| _Decimal32 powrd32(_Decimal32 y, _Decimal32 x);
 | |
| _Decimal64 powrd64(_Decimal64 y, _Decimal64 x);
 | |
| _Decimal128 powrd128(_Decimal128 y, _Decimal128 x);
 | |
| _Decimal32 rootnd32(_Decimal32 x, long long int n);
 | |
| _Decimal64 rootnd64(_Decimal64 x, long long int n);
 | |
| _Decimal128 rootnd128(_Decimal128 x, long long int n);
 | |
| _Decimal32 rsqrtd32(_Decimal32 x);
 | |
| _Decimal64 rsqrtd64(_Decimal64 x);
 | |
| _Decimal128 rsqrtd128(_Decimal128 x);
 | |
| _Decimal32 sqrtd32(_Decimal32 x);
 | |
| _Decimal64 sqrtd64(_Decimal64 x);
 | |
| _Decimal128 sqrtd128(_Decimal128 x);
 | |
| _Decimal32 erfd32(_Decimal32 x);
 | |
| _Decimal64 erfd64(_Decimal64 x);
 | |
| _Decimal128 erfd128(_Decimal128 x);
 | |
| _Decimal32 erfcd32(_Decimal32 x);
 | |
| _Decimal64 erfcd64(_Decimal64 x);
 | |
| _Decimal128 erfcd128(_Decimal128 x);
 | |
| _Decimal32 lgammad32(_Decimal32 x);
 | |
| _Decimal64 lgammad64(_Decimal64 x);
 | |
| _Decimal128 lgammad128(_Decimal128 x);
 | |
| _Decimal32 tgammad32(_Decimal32 x);
 | |
| _Decimal64 tgammad64(_Decimal64 x);
 | |
| _Decimal128 tgammad128(_Decimal128 x);
 | |
| _Decimal32 ceild32(_Decimal32 x);
 | |
| _Decimal64 ceild64(_Decimal64 x);
 | |
| _Decimal128 ceild128(_Decimal128 x);
 | |
| _Decimal32 floord32(_Decimal32 x);
 | |
| _Decimal64 floord64(_Decimal64 x);
 | |
| _Decimal128 floord128(_Decimal128 x);
 | |
| _Decimal32 nearbyintd32(_Decimal32 x);
 | |
| _Decimal64 nearbyintd64(_Decimal64 x);
 | |
| _Decimal128 nearbyintd128(_Decimal128 x);
 | |
| _Decimal32 rintd32(_Decimal32 x);
 | |
| _Decimal64 rintd64(_Decimal64 x);
 | |
| _Decimal128 rintd128(_Decimal128 x);
 | |
| long int lrintd32(_Decimal32 x);
 | |
| long int lrintd64(_Decimal64 x);
 | |
| long int lrintd128(_Decimal128 x);
 | |
| long long int llrintd32(_Decimal32 x);
 | |
| long long int llrintd64(_Decimal64 x);
 | |
| long long int llrintd128(_Decimal128 x);
 | |
| _Decimal32 roundd32(_Decimal32 x);
 | |
| _Decimal64 roundd64(_Decimal64 x);
 | |
| _Decimal128 roundd128(_Decimal128 x);
 | |
| long int lroundd32(_Decimal32 x);
 | |
| long int lroundd64(_Decimal64 x);
 | |
| long int lroundd128(_Decimal128 x);
 | |
| long long int llroundd32(_Decimal32 x);
 | |
| long long int llroundd64(_Decimal64 x);
 | |
| long long int llroundd128(_Decimal128 x);
 | |
| _Decimal32 roundevend32(_Decimal32 x);
 | |
| _Decimal64 roundevend64(_Decimal64 x);
 | |
| _Decimal128 roundevend128(_Decimal128 x);
 | |
| _Decimal32 truncd32(_Decimal32 x);
 | |
| _Decimal64 truncd64(_Decimal64 x);
 | |
| _Decimal128 truncd128(_Decimal128 x);
 | |
| _Decimal32 fromfpd32(_Decimal32 x, int rnd, unsigned int width);
 | |
| _Decimal64 fromfpd64(_Decimal64 x, int rnd, unsigned int width);
 | |
| _Decimal128 fromfpd128(_Decimal128 x, int rnd, unsigned int width);
 | |
| _Decimal32 ufromfpd32(_Decimal32 x, int rnd, unsigned int width);
 | |
| _Decimal64 ufromfpd64(_Decimal64 x, int rnd, unsigned int width);
 | |
| _Decimal128 ufromfpd128(_Decimal128 x, int rnd, unsigned int width);
 | |
| _Decimal32 fromfpxd32(_Decimal32 x, int rnd, unsigned int width);
 | |
| _Decimal64 fromfpxd64(_Decimal64 x, int rnd, unsigned int width);
 | |
| _Decimal128 fromfpxd128(_Decimal128 x, int rnd, unsigned int width);
 | |
| _Decimal32 ufromfpxd32(_Decimal32 x, int rnd, unsigned int width);
 | |
| _Decimal64 ufromfpxd64(_Decimal64 x, int rnd, unsigned int width);
 | |
| _Decimal128 ufromfpxd128(_Decimal128 x, int rnd, unsigned int width);
 | |
| _Decimal32 fmodd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fmodd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fmodd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 remainderd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 remainderd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 remainderd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 copysignd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 copysignd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 copysignd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 nand32(const char *tagp);
 | |
| _Decimal64 nand64(const char *tagp);
 | |
| _Decimal128 nand128(const char *tagp);
 | |
| _Decimal32 nextafterd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 nextafterd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 nextafterd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 nexttowardd32(_Decimal32 x, _Decimal128 y);
 | |
| _Decimal64 nexttowardd64(_Decimal64 x, _Decimal128 y);
 | |
| _Decimal128 nexttowardd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 nextupd32(_Decimal32 x);
 | |
| _Decimal64 nextupd64(_Decimal64 x);
 | |
| _Decimal128 nextupd128(_Decimal128 x);
 | |
| _Decimal32 nextdownd32(_Decimal32 x);
 | |
| _Decimal64 nextdownd64(_Decimal64 x);
 | |
| _Decimal128 nextdownd128(_Decimal128 x);
 | |
| int canonicalized32(_Decimal32 cx, const _Decimal32 * x);
 | |
| int canonicalized64(_Decimal64 cx, const _Decimal64 * x);
 | |
| int canonicalized128(_Decimal128 cx, const _Decimal128 * x);
 | |
| _Decimal32 fdimd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fdimd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fdimd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fmaxd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fmaxd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fmaxd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fmind32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fmind64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fmind128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fmaximumd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fmaximumd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fmaximumd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fminimumd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fminimumd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fminimumd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fmaximum_magd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fmaximum_magd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fmaximum_magd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fminimum_magd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fminimum_magd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fminimum_magd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fmaximum_numd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fmaximum_numd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fmaximum_numd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fminimum_numd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fminimum_numd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fminimum_numd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fmaximum_mag_numd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fmaximum_mag_numd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fmaximum_mag_numd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fminimum_mag_numd32(_Decimal32 x, _Decimal32 y);
 | |
| _Decimal64 fminimum_mag_numd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal128 fminimum_mag_numd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 fmad32(_Decimal32 x, _Decimal32 y, _Decimal32 z);
 | |
| _Decimal64 fmad64(_Decimal64 x, _Decimal64 y, _Decimal64 z);
 | |
| _Decimal128 fmad128(_Decimal128 x, _Decimal128 y, _Decimal128 z);
 | |
| _Decimal32 d32addd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal32 d32addd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal64 d64addd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 d32subd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal32 d32subd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal64 d64subd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 d32muld64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal32 d32muld128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal64 d64muld128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 d32divd64(_Decimal64 x, _Decimal64 y);
 | |
| _Decimal32 d32divd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal64 d64divd128(_Decimal128 x, _Decimal128 y);
 | |
| _Decimal32 d32fmad64(_Decimal64 x, _Decimal64 y, _Decimal64 z);
 | |
|  _Decimal32 d32fmad128(_Decimal128 x, _Decimal128 y, _Decimal128 z);
 | |
|  _Decimal64 d64fmad128(_Decimal128 x, _Decimal128 y, _Decimal128 z);
 | |
|  _Decimal32 d32sqrtd64(_Decimal64 x);
 | |
|  _Decimal32 d32sqrtd128(_Decimal128 x);
 | |
|  _Decimal64 d64sqrtd128(_Decimal128 x);
 | |
|  _Decimal32 quantized32(_Decimal32 x, _Decimal32 y);
 | |
|  _Decimal64 quantized64(_Decimal64 x, _Decimal64 y);
 | |
|  _Decimal128 quantized128(_Decimal128 x, _Decimal128 y);
 | |
|  bool samequantumd32(_Decimal32 x, _Decimal32 y);
 | |
|  bool samequantumd64(_Decimal64 x, _Decimal64 y);
 | |
|  bool samequantumd128(_Decimal128 x, _Decimal128 y);
 | |
|  _Decimal32 quantumd32(_Decimal32 x);
 | |
|  _Decimal64 quantumd64(_Decimal64 x);
 | |
|  _Decimal128 quantumd128(_Decimal128 x);
 | |
|  long long int llquantexpd32(_Decimal32 x);
 | |
|  long long int llquantexpd64(_Decimal64 x);
 | |
|  long long int llquantexpd128(_Decimal128 x);
 | |
|  void encodedecd32(unsigned char encptr[restrict static 4],
 | |
|        const _Decimal32*restrict xptr);
 | |
|  void encodedecd64(unsigned char encptr[restrict static 8],
 | |
|        const _Decimal64*restrict xptr);
 | |
|  void encodedecd128(unsigned char encptr[restrict static 16],
 | |
|        const _Decimal128*restrict xptr);
 | |
|  void decodedecd32(_Decimal32 * restrict xptr,
 | |
|        const unsigned char encptr[restrict static 4]);
 | |
|  void decodedecd64(_Decimal64 * restrict xptr,
 | |
|        const unsigned char encptr[restrict static 8]);
 | |
|  void decodedecd128(_Decimal128 * restrict xptr,
 | |
|        const unsigned char encptr[restrict static 16]);
 | |
|  void encodebind32(unsigned char encptr[restrict static 4],
 | |
|        const _Decimal32 * restrict xptr);
 | |
|  void encodebind64(unsigned char encptr[restrict static 8],
 | |
|        const _Decimal64 * restrict xptr);
 | |
|  void encodebind128(unsigned char encptr[restrict static 16],
 | |
|        const _Decimal128 * restrict xptr);
 | |
|  void decodebind32(_Decimal32 * restrict xptr,
 | |
|        const unsigned char encptr[restrict static 4]);
 | |
|  void decodebind64(_Decimal64 * restrict xptr,
 | |
|        const unsigned char encptr[restrict static 8]);
 | |
|  void decodebind128(_Decimal128 * restrict xptr,
 | |
|        const unsigned char encptr[restrict static 16]);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_IEC_60559_BFP__ or __STDC_IEC_559__ and addition-
 | |
| ally the user code defines __STDC_WANT_IEC_60559_EXT__ before any inclusion of <math.h>:
 | |
| 
 | |
|  int totalorder(const double *x, const double *y);
 | |
|  int totalorderf(const float *x, const float *y);
 | |
|  int totalorderl(const long double *x, const long double *y);
 | |
|  int totalordermag(const double *x, const double *y);
 | |
|  int totalordermagf(const float *x, const float *y);
 | |
|  int totalordermagl(const long double *x, const long double *y);
 | |
|  double getpayload(const double *x);
 | |
|  float getpayloadf(const float *x);
 | |
|  long double getpayloadl(const long double *x);
 | |
|  int setpayload(double *res, double pl);
 | |
|  int setpayloadf(float *res, float pl);
 | |
|  int setpayloadl(long double *res, long double pl);
 | |
|  int setpayloadsig(double *res, double pl);
 | |
|  int setpayloadsigf(float *res, float pl);
 | |
|  int setpayloadsigl(long double *res, long double pl);
 | |
| Only if the implementation defines __STDC_IEC_60559_DFP__ and additionally the user code
 | |
| defines __STDC_WANT_IEC_60559_EXT__ before any inclusion of <math.h>:
 | |
| 
 | |
| _Decimal32_t      _Decimal64_t       HUGE_VAL_D32        HUGE_VAL_D64       HUGE_VAL_D128
 | |
| 
 | |
| 
 | |
|  int totalorderd32(const _Decimal32 *x, const _Decimal32 *y);
 | |
|  int totalorderd64(const _Decimal64 *x, const _Decimal64 *y);
 | |
|  int totalorderd128(const _Decimal128 *x, const _Decimal128 *y);
 | |
|  int totalordermagd32(const _Decimal32 *x, const _Decimal32 *y);
 | |
|  int totalordermagd64(const _Decimal64 *x, const _Decimal64 *y);
 | |
|  int totalordermagd128(const _Decimal128 *x, const _Decimal128 *y);
 | |
|  _Decimal32 getpayloadd32(const _Decimal32 *x);
 | |
|  _Decimal64 getpayloadd64(const _Decimal64 *x);
 | |
|  _Decimal128 getpayloadd128(const _Decimal128 *x);
 | |
|  int setpayloadd32(_Decimal32 *res, _Decimal32 pl);
 | |
|  int setpayloadd64(_Decimal64 *res, _Decimal64 pl);
 | |
|  int setpayloadd128(_Decimal128 *res, _Decimal128 pl);
 | |
|  int setpayloadsigd32(_Decimal32 *res, _Decimal32 pl);
 | |
|  int setpayloadsigd64(_Decimal64 *res, _Decimal64 pl);
 | |
|  int setpayloadsigd128(_Decimal128 *res, _Decimal128 pl);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.12'></a>
 | |
| <hr>
 | |
| <h3>B.12 [Non-local jumps <setjmp.h>]</h3>
 | |
| <pre>jmp_buf
 | |
| 
 | |
| 
 | |
|  int setjmp(jmp_buf env);
 | |
|  [[noreturn]] void longjmp(jmp_buf env, int val);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.13'></a>
 | |
| <hr>
 | |
| <h3>B.13 [Signal handling <signal.h>]</h3>
 | |
| <pre>sig_atomic_t           SIG_IGN                 SIGILL                   SIGTERM
 | |
| SIG_DFL                SIGABRT                 SIGINT
 | |
| SIG_ERR                SIGFPE                  SIGSEGV
 | |
| 
 | |
| 
 | |
|  void (*signal(int sig, void (*func)(int)))(int);
 | |
|  int raise(int sig);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.14'></a>
 | |
| <hr>
 | |
| <h3>B.14 [Alignment <stdalign.h>]</h3>
 | |
| <pre>The header <stdalign.h> provides no content.
 | |
| 
 | |
| </pre>
 | |
| <a name='B.15'></a>
 | |
| <hr>
 | |
| <h3>B.15 [Variable arguments <stdarg.h>]</h3>
 | |
| <pre>va_list
 | |
| 
 | |
|  type va_arg(va_list ap, type);
 | |
|  void va_copy(va_list dest, va_list src);
 | |
|  void va_end(va_list ap);
 | |
|  void va_start(va_list ap, ...);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.16'></a>
 | |
| <hr>
 | |
| <h3>B.16 [Atomics <stdatomic.h>]</h3>
 | |
| <pre>__STDC_NO_ATOMICS__           ATOMIC_CHAR16_T_LOCK_FREE       ATOMIC_SHORT_LOCK_FREE
 | |
| ATOMIC_BOOL_LOCK_FREE         ATOMIC_CHAR32_T_LOCK_FREE       ATOMIC_INT_LOCK_FREE
 | |
| ATOMIC_CHAR_LOCK_FREE         ATOMIC_WCHAR_T_LOCK_FREE        ATOMIC_LONG_LOCK_FREE
 | |
| ATOMIC_LLONG_LOCK_FREE       atomic_ushort                  atomic_int_least64_t
 | |
| ATOMIC_POINTER_LOCK_FREE     atomic_int                     atomic_uint_least64_t
 | |
| ATOMIC_FLAG_INIT             atomic_uint                    atomic_int_fast8_t
 | |
| memory_order                 atomic_long                    atomic_uint_fast8_t
 | |
| atomic_flag                  atomic_ulong                   atomic_int_fast16_t
 | |
| memory_order_relaxed         atomic_llong                   atomic_uint_fast16_t
 | |
| memory_order_consume         atomic_ullong                  atomic_int_fast32_t
 | |
| memory_order_acquire         atomic_char16_t                atomic_uint_fast32_t
 | |
| memory_order_release         atomic_char32_t                atomic_int_fast64_t
 | |
| memory_order_acq_rel         atomic_wchar_t                 atomic_uint_fast64_t
 | |
| memory_order_seq_cst         atomic_int_least8_t            atomic_intptr_t
 | |
| atomic_bool                  atomic_uint_least8_t           atomic_uintptr_t
 | |
| atomic_char                  atomic_int_least16_t           atomic_size_t
 | |
| atomic_schar                 atomic_uint_least16_t          atomic_ptrdiff_t
 | |
| atomic_uchar                 atomic_int_least32_t           atomic_intmax_t
 | |
| atomic_short                 atomic_uint_least32_t          atomic_uintmax_t
 | |
| 
 | |
| 
 | |
|  void atomic_init(volatile A *obj, C value);
 | |
|  type kill_dependency(type y);
 | |
|  void atomic_thread_fence(memory_order order);
 | |
|  void atomic_signal_fence(memory_order order);
 | |
|  bool atomic_is_lock_free(const volatile A *obj);
 | |
|  void atomic_store(volatile A *object, C desired);
 | |
|  void atomic_store_explicit(volatile A *object, C desired, memory_order order);
 | |
|  C atomic_load(const volatile A *object);
 | |
|  C atomic_load_explicit(const volatile A *object, memory_order order);
 | |
|  C atomic_exchange(volatile A *object, C desired);
 | |
|  C atomic_exchange_explicit(volatile A *object, C desired, memory_order order);
 | |
|  bool atomic_compare_exchange_strong(volatile A *object, C *expected, C desired);
 | |
|  bool atomic_compare_exchange_strong_explicit(volatile A *object, C *expected,
 | |
|        C desired, memory_order success, memory_order failure);
 | |
|  bool atomic_compare_exchange_weak(volatile A *object, C *expected, C desired);
 | |
|  bool atomic_compare_exchange_weak_explicit(volatile A *object, C *expected,
 | |
|        C desired, memory_order success, memory_order failure);
 | |
|  C atomic_fetch_key(volatile A *object, M operand);
 | |
|  C atomic_fetch_key_explicit(volatile A *object, M operand, memory_order order);
 | |
|  bool atomic_flag_test_and_set(volatile atomic_flag *object);
 | |
|  bool atomic_flag_test_and_set_explicit(volatile atomic_flag *object,
 | |
|        memory_order order);
 | |
|  void atomic_flag_clear(volatile atomic_flag *object);
 | |
|  void atomic_flag_clear_explicit(volatile atomic_flag *object,
 | |
|        memory_order order);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.17'></a>
 | |
| <hr>
 | |
| <h3>B.17 [Bit and byte utilities <stdbit.h>]</h3>
 | |
| <pre>__STDC_ENDIAN_BIG__          __STDC_ENDIAN_LITTLE__         __STDC_ENDIAN_NATIVE__
 | |
| 
 | |
| 
 | |
|  int stdc_leading_zerosuc(unsigned char value);
 | |
|  int stdc_leading_zerosus(unsigned short value);
 | |
|  int stdc_leading_zerosui(unsigned int value);
 | |
|  int stdc_leading_zerosul(unsigned long value);
 | |
|  int stdc_leading_zerosull(unsigned long long value);
 | |
|  generic_return_type stdc_leading_zeros(generic_value_type value);
 | |
|  int stdc_leading_onesuc(unsigned char value);
 | |
|  int stdc_leading_onesus(unsigned short value);
 | |
|  int stdc_leading_onesui(unsigned int value);
 | |
|  int stdc_leading_onesul(unsigned long value);
 | |
|  int stdc_leading_onesull(unsigned long long value);
 | |
| generic_return_type stdc_leading_ones(generic_value_type value);
 | |
| int stdc_trailing_zerosuc(unsigned char value);
 | |
| int stdc_trailing_zerosus(unsigned short value);
 | |
| int stdc_trailing_zerosui(unsigned int value);
 | |
| int stdc_trailing_zerosul(unsigned long value);
 | |
| int stdc_trailing_zerosull(unsigned long long value);
 | |
| generic_return_type stdc_trailing_zeros(generic_value_type value);
 | |
| int stdc_trailing_onesuc(unsigned char value);
 | |
| int stdc_trailing_onesus(unsigned short value);
 | |
| int stdc_trailing_onesui(unsigned int value);
 | |
| int stdc_trailing_onesul(unsigned long value);
 | |
| int stdc_trailing_onesull(unsigned long long value);
 | |
| generic_return_type stdc_trailing_ones(generic_value_type value);
 | |
| int stdc_first_leading_zerouc(unsigned char value);
 | |
| int stdc_first_leading_zerous(unsigned short value);
 | |
| int stdc_first_leading_zeroui(unsigned int value);
 | |
| int stdc_first_leading_zeroul(unsigned long value);
 | |
| int stdc_first_leading_zeroull(unsigned long long value);
 | |
| generic_return_type stdc_first_leading_zero(generic_value_type value);
 | |
| int stdc_first_leading_oneuc(unsigned char value);
 | |
| int stdc_first_leading_oneus(unsigned short value);
 | |
| int stdc_first_leading_oneui(unsigned int value);
 | |
| int stdc_first_leading_oneul(unsigned long value);
 | |
| int stdc_first_leading_oneull(unsigned long long value);
 | |
| generic_return_type stdc_first_leading_one(generic_value_type value);
 | |
| int stdc_first_trailing_zerouc(unsigned char value);
 | |
| int stdc_first_trailing_zerous(unsigned short value);
 | |
| int stdc_first_trailing_zeroui(unsigned int value);
 | |
| int stdc_first_trailing_zeroul(unsigned long value);
 | |
| int stdc_first_trailing_zeroull(unsigned long long value);
 | |
| generic_return_type stdc_first_trailing_zero(generic_value_type value);
 | |
| int stdc_first_trailing_oneuc(unsigned char value);
 | |
| int stdc_first_trailing_oneus(unsigned short value);
 | |
| int stdc_first_trailing_oneui(unsigned int value);
 | |
| int stdc_first_trailing_oneul(unsigned long value);
 | |
| int stdc_first_trailing_oneull(unsigned long long value);
 | |
| generic_return_type stdc_first_trailing_one(generic_value_type value);
 | |
| int stdc_count_onesuc(unsigned char value);
 | |
| int stdc_count_onesus(unsigned short value);
 | |
| int stdc_count_onesui(unsigned int value);
 | |
| int stdc_count_onesul(unsigned long value);
 | |
| int stdc_count_onesull(unsigned long long value);
 | |
| generic_return_type stdc_count_ones(generic_value_type value);
 | |
| int stdc_count_zerosuc(unsigned char value);
 | |
| int stdc_count_zerosus(unsigned short value);
 | |
| int stdc_count_zerosui(unsigned int value);
 | |
| int stdc_count_zerosul(unsigned long value);
 | |
| int stdc_count_zerosull(unsigned long long value);
 | |
| generic_return_type stdc_count_zeros(generic_value_type value);
 | |
| bool stdc_has_single_bituc(unsigned char value);
 | |
| bool stdc_has_single_bitus(unsigned short value);
 | |
| bool stdc_has_single_bitui(unsigned int value);
 | |
| bool stdc_has_single_bitul(unsigned long value);
 | |
| bool stdc_has_single_bitull(unsigned long long value);
 | |
| bool stdc_has_single_bit(generic_value_type value);
 | |
| int stdc_bit_widthuc(unsigned char value);
 | |
| int stdc_bit_widthus(unsigned short value);
 | |
| int stdc_bit_widthui(unsigned int value);
 | |
| int stdc_bit_widthul(unsigned long value);
 | |
| int stdc_bit_widthull(unsigned long long value);
 | |
| generic_return_type stdc_bit_width(generic_value_type value);
 | |
|  unsigned char stdc_bit_flooruc(unsigned char value);
 | |
|  unsigned short stdc_bit_floorus(unsigned short value);
 | |
|  unsigned int stdc_bit_floorui(unsigned int value);
 | |
|  unsigned long stdc_bit_floorul(unsigned long value);
 | |
|  unsigned long long stdc_bit_floorull(unsigned long long value);
 | |
|  generic_value_type stdc_bit_floor(generic_value_type value);
 | |
|  unsigned char stdc_bit_ceiluc(unsigned char value);
 | |
|  unsigned short stdc_bit_ceilus(unsigned short value);
 | |
|  unsigned int stdc_bit_ceilui(unsigned int value);
 | |
|  unsigned long stdc_bit_ceilul(unsigned long value);
 | |
|  unsigned long long stdc_bit_ceilull(unsigned long long value);
 | |
|  generic_value_type stdc_bit_ceil(generic_value_type value);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.18'></a>
 | |
| <hr>
 | |
| <h3>B.18 [Boolean type and values <stdbool.h>]</h3>
 | |
| <pre>__bool_true_false_are_defined
 | |
| 
 | |
| </pre>
 | |
| <a name='B.19'></a>
 | |
| <hr>
 | |
| <h3>B.19 [Common definitions <stddef.h>]</h3>
 | |
| <pre>ptrdiff_t         size_t             wchar_t
 | |
| nullptr_t         max_align_t        NULL
 | |
| 
 | |
| 
 | |
|        offsetof(type, member-designator)
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <stddef.h>:
 | |
| 
 | |
| rsize_t
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.20'></a>
 | |
| <hr>
 | |
| <h3>B.20 [Integer types <stdint.h>]</h3>
 | |
| <pre>intN_t                         UINT_LEASTN_MAX                PTRDIFF_MAX
 | |
| uintN_t                        UINT_LEASTN_WIDTH              SIG_ATOMIC_MIN
 | |
| int_leastN_t                   INT_FASTN_MIN                  SIG_ATOMIC_MAX
 | |
| uint_leastN_t                  INT_FASTN_MAX                  SIG_ATOMIC_WIDTH
 | |
| int_fastN_t                    INT_FASTN_WIDTH                SIZE_MAX
 | |
| uint_fastN_t                   UINT_FASTN_MAX                 SIZE_WIDTH
 | |
| intptr_t                       UINT_FASTN_WIDTH               WCHAR_MIN
 | |
| uintptr_t                      INTPTR_MIN                     WCHAR_MAX
 | |
| intmax_t                       INTPTR_MAX                     WCHAR_WIDTH
 | |
| uintmax_t                      INTPTR_WIDTH                   WINT_MIN
 | |
| INTN_MIN                       UINTPTR_MAX                    WINT_MAX
 | |
| INTN_MAX                       UINTPTR_WIDTH                  WINT_WIDTH
 | |
| INTN_WIDTH                     INTMAX_MIN                     INTN_C( value )
 | |
| UINTN_MAX                      INTMAX_MAX                     UINTN_C( value )
 | |
| UINTN_WIDTH                    INTMAX_WIDTH                   INTMAX_C( value )
 | |
| INT_LEASTN_MIN                 UINTMAX_MAX                    UINTMAX_C( value )
 | |
| INT_LEASTN_MAX                 UINTMAX_WIDTH
 | |
| INT_LEASTN_WIDTH               PTRDIFF_MIN
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <stdint.h>:
 | |
| 
 | |
| RSIZE_MAX
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.21'></a>
 | |
| <hr>
 | |
| <h3>B.21 [Input/output <stdio.h>]</h3>
 | |
| <pre>size_t                 _IONBF                 SEEK_CUR                stdout
 | |
|                                                                       _PRINTF_NAN_LEN_MAX
 | |
| FILE                   BUFSIZ                 SEEK_END
 | |
| fpos_t                 EOF                    SEEK_SET
 | |
| NULL                   FOPEN_MAX              TMP_MAX
 | |
| _IOFBF                 FILENAME_MAX           stderr
 | |
| _IOLBF                 L_tmpnam               stdin
 | |
| 
 | |
| 
 | |
|  int remove(const char *filename);
 | |
|  int rename(const char *old, const char *new);
 | |
|  FILE *tmpfile(void);
 | |
|  char *tmpnam(char *s);
 | |
|  int fclose(FILE *stream);
 | |
|  int fflush(FILE *stream);
 | |
|  FILE *fopen(const char * restrict filename, const char * restrict mode);
 | |
|  FILE *freopen(const char * restrict filename, const char * restrict mode,
 | |
|        FILE * restrict stream);
 | |
|  void setbuf(FILE * restrict stream, char * restrict buf);
 | |
|  int setvbuf(FILE * restrict stream, char * restrict buf, int mode, size_t size);
 | |
|  int printf(const char * restrict format, ...);
 | |
|  int scanf(const char * restrict format, ...);
 | |
|  int snprintf(char * restrict s, size_t n, const char * restrict format, ...);
 | |
|  int sprintf(char * restrict s, const char * restrict format, ...);
 | |
|  int sscanf(const char * restrict s, const char * restrict format, ...);
 | |
|  int vfprintf(FILE * restrict stream, const char * restrict format, va_list arg);
 | |
|  int vfscanf(FILE * restrict stream, const char * restrict format, va_list arg);
 | |
|  int vprintf(const char * restrict format, va_list arg);
 | |
|  int vscanf(const char * restrict format, va_list arg);
 | |
|  int vsnprintf(char * restrict s, size_t n, const char * restrict format, va_list arg);
 | |
|  int vsprintf(char * restrict s, const char * restrict format, va_list arg);
 | |
|  int vsscanf(const char * restrict s, const char * restrict format, va_list arg);
 | |
|  int fgetc(FILE *stream);
 | |
|  char *fgets(char * restrict s, int n, FILE * restrict stream);
 | |
|  int fputc(int c, FILE *stream);
 | |
|  int fputs(const char * restrict s, FILE * restrict stream);
 | |
|  int getc(FILE *stream);
 | |
|  int getchar(void);
 | |
|  int putc(int c, FILE *stream);
 | |
|  int putchar(int c);
 | |
|  int puts(const char *s);
 | |
|  int ungetc(int c, FILE *stream);
 | |
|  size_t fread(void * restrict ptr, size_t size, size_t nmemb,
 | |
|        FILE * restrict stream);
 | |
|  size_t fwrite(const void * restrict ptr, size_t size, size_t nmemb,
 | |
|        FILE * restrict stream);
 | |
|  int fgetpos(FILE * restrict stream, fpos_t * restrict pos);
 | |
|  int fseek(FILE *stream, long int offset, int whence);
 | |
|  int fsetpos(FILE *stream, const fpos_t *pos);
 | |
|  long int ftell(FILE *stream);
 | |
|  void rewind(FILE *stream);
 | |
|  void clearerr(FILE *stream);
 | |
|  int feof(FILE *stream);
 | |
|  int ferror(FILE *stream);
 | |
|  void perror(const char *s);
 | |
|  int fprintf(FILE * restrict stream, const char * restrict format, ...);
 | |
|  int fscanf(FILE * restrict stream, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <stdio.h>:
 | |
| L_tmpnam_s            TMP_MAX_S               errno_t                  rsize_t
 | |
| 
 | |
| 
 | |
|  errno_t tmpfile_s(FILE * restrict * restrict streamptr);
 | |
|  errno_t tmpnam_s(char *s, rsize_t maxsize);
 | |
|  errno_t fopen_s(FILE * restrict * restrict streamptr,
 | |
|        const char * restrict filename, const char * restrict mode);
 | |
|  errno_t freopen_s(FILE * restrict * restrict newstreamptr,
 | |
|        const char * restrict filename, const char * restrict mode,
 | |
|        FILE * restrict stream);
 | |
|  int fprintf_s(FILE * restrict stream, const char * restrict format, ...);
 | |
|  int fscanf_s(FILE * restrict stream, const char * restrict format, ...);
 | |
|  int printf_s(const char * restrict format, ...);
 | |
|  int scanf_s(const char * restrict format, ...);
 | |
|  int snprintf_s(char * restrict s, rsize_t n, const char * restrict format, ...);
 | |
|  int sprintf_s(char * restrict s, rsize_t n, const char * restrict format, ...);
 | |
|  int sscanf_s(const char * restrict s, const char * restrict format, ...);
 | |
|  int vfprintf_s(FILE *restrict stream, const char *restrict format, va_list arg);
 | |
|  int vfscanf_s(FILE *restrict stream, const char *restrict format, va_list arg);
 | |
|  int vprintf_s(const char * restrict format, va_list arg);
 | |
|  int vscanf_s(const char * restrict format, va_list arg);
 | |
|  int vsnprintf_s(char *restrict s, rsize_t n, const char *restrict format,
 | |
|        va_list arg);
 | |
|  int vsprintf_s(char * restrict s, rsize_t n, const char * restrict format,
 | |
|        va_list arg);
 | |
|  int vsscanf_s(const char *restrict s, const char *restrict format, va_list arg);
 | |
|  char *gets_s(char *s, rsize_t n);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.22'></a>
 | |
| <hr>
 | |
| <h3>B.22 [General utilities <stdlib.h>]</h3>
 | |
| <pre>size_t           div_t              lldiv_t             EXIT_FAILURE       RAND_MAX
 | |
| wchar_t          ldiv_t             NULL                EXIT_SUCCESS       MB_CUR_MAX
 | |
| 
 | |
| 
 | |
|  double atof(const char *nptr);
 | |
|  int atoi(const char *nptr);
 | |
|  long int atol(const char *nptr);
 | |
|  long long int atoll(const char *nptr);
 | |
|  int strfromd(char *restrict s, size_t n, const char *restrict format, double fp);
 | |
|  int strfromf(char *restrict s, size_t n, const char *restrict format, float fp);
 | |
|  int strfroml(char *restrict s, size_t n, const char *restrict format, long double fp);
 | |
| 
 | |
|  double strtod(const char *restrict nptr, char **restrict endptr);
 | |
|  float strtof(const char *restrict nptr, char **restrict endptr);
 | |
|  long double strtold(const char *restrict nptr, char **restrict endptr);
 | |
|  long int strtol(const char *restrict nptr, char **restrict endptr, int base);
 | |
|  long long int strtoll(const char *restrict nptr, char **restrict endptr, int base);
 | |
|  unsigned long int strtoul(const char *restrict nptr, char **restrict endptr, int base);
 | |
|  unsigned long long int strtoull(const char *restrict nptr, char **restrict endptr, int
 | |
|      base);
 | |
|  int rand(void);
 | |
|  void srand(unsigned int seed);
 | |
|  void *aligned_alloc(size_t alignment, size_t size);
 | |
|  void *calloc(size_t nmemb, size_t size);
 | |
|  void free(void *ptr);
 | |
|  void free_sized(void *ptr, size_t size);
 | |
|  void free_aligned_sized(void *ptr, size_t alignment, size_t size);
 | |
|  void *malloc(size_t size);
 | |
|  void *realloc(void *ptr, size_t size);
 | |
|  [[noreturn]] void abort(void);
 | |
|  int atexit(void (*func)(void));
 | |
|  int at_quick_exit(void (*func)(void));
 | |
|  [[noreturn]] void exit(int status);
 | |
|  [[noreturn]] void _Exit(int status);
 | |
|  char *getenv(const char *name);
 | |
|  [[noreturn]] void quick_exit(int status);
 | |
|  int system(const char *string);
 | |
|  void *bsearch(const void *key, const void *base, size_t nmemb, size_t size,
 | |
|        int (*compar)(const void *, const void *));
 | |
|  void qsort(void *base, size_t nmemb, size_t size,
 | |
|        int (*compar)(const void *, const void *));
 | |
|  int abs(int j);
 | |
|  long int labs(long int j);
 | |
|  long long int llabs(long long int j);
 | |
|  div_t div(int numer, int denom);
 | |
|  ldiv_t ldiv(long int numer, long int denom);
 | |
|  lldiv_t lldiv(long long int numer, long long int denom);
 | |
|  int mblen(const char *s, size_t n);
 | |
|  int mbtowc(wchar_t * restrict pwc, const char * restrict s, size_t n);
 | |
|  int wctomb(char *s, wchar_t wc);
 | |
|  size_t mbstowcs(wchar_t * restrict pwcs, const char * restrict s, size_t n);
 | |
|  size_t wcstombs(char * restrict s, const wchar_t * restrict pwcs, size_t n);
 | |
|  size_t memalignment(const void * p);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_IEC_60559_DFP__ :
 | |
| 
 | |
|  int strfromd32(char*restrict s, size_t n, const char*restrict format, _Decimal32 fp);
 | |
|  int strfromd64(char*restrict s, size_t n, const char*restrict format, _Decimal64 fp);
 | |
|  int strfromd128(char*restrict s, size_t n, const char*restrict format, _Decimal128 fp);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <stdlib.h>:
 | |
| 
 | |
| errno_t                        rsize_t                        constraint_handler_t
 | |
| 
 | |
| 
 | |
|  constraint_handler_t set_constraint_handler_s(constraint_handler_t handler);
 | |
|  void abort_handler_s(const char * restrict msg, void * restrict ptr,
 | |
|        errno_t error);
 | |
|  void ignore_handler_s(const char * restrict msg, void * restrict ptr,
 | |
|        errno_t error);
 | |
|  errno_t getenv_s(size_t * restrict len, char * restrict value, rsize_t maxsize,
 | |
|        const char * restrict name);
 | |
|  void *bsearch_s(const void *key, QVoid *base, rsize_t nmemb, rsize_t size,
 | |
|        int (*compar)(const void *k, const void *y, void *context),
 | |
|        void *context);
 | |
|  errno_t qsort_s(void *base, rsize_t nmemb, rsize_t size,
 | |
|        int (*compar)(const void *x, const void *y, void *context),
 | |
|        void *context);
 | |
|  errno_t wctomb_s(int *restrict status, char *restrict s, rsize_t smax,
 | |
|        wchar_t wc);
 | |
|  errno_t mbstowcs_s(size_t *restrict retval, wchar_t *restrict dst,
 | |
|        rsize_t dstmax, const char * restrict src, rsize_t len);
 | |
|  errno_t wcstombs_s(size_t * restrict retval, char * restrict dst, rsize_t dstmax,
 | |
|        const wchar_t * restrict src, rsize_t len);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.23'></a>
 | |
| <hr>
 | |
| <h3>B.23 [_Noreturn <stdnoreturn.h>]</h3>
 | |
| <pre>noreturn
 | |
| 
 | |
| </pre>
 | |
| <a name='B.24'></a>
 | |
| <hr>
 | |
| <h3>B.24 [ckd_ Checked Integer Operations <stdckdint.h>]</h3>
 | |
| <pre>bool ckd_add(type1 *result, type2 a, type3 b);
 | |
|  bool ckd_sub(type1 *result, type2 a, type3 b);
 | |
|  bool ckd_mul(type1 *result, type2 a, type3 b);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.25'></a>
 | |
| <hr>
 | |
| <h3>B.25 [String handling <string.h>]</h3>
 | |
| <pre>size_t                                        NULL
 | |
| 
 | |
| 
 | |
|  void *memcpy(void * restrict s1, const void * restrict s2, size_t n);
 | |
|  void *memccpy(void * restrict s1, const void * restrict s2, int c, size_t n);
 | |
|  void *memmove(void *s1, const void *s2, size_t n);
 | |
|  char *strcpy(char * restrict s1, const char * restrict s2);
 | |
|  char *strncpy(char * restrict s1, const char * restrict s2, size_t n);
 | |
|  char *strdup(const char *s);
 | |
|  char *strndup(const char *s, size_t size);
 | |
|  char *strcat(char * restrict s1, const char * restrict s2);
 | |
|  char *strncat(char * restrict s1, const char * restrict s2, size_t n);
 | |
|  int memcmp(const void *s1, const void *s2, size_t n);
 | |
|  int strcmp(const char *s1, const char *s2);
 | |
|  int strcoll(const char *s1, const char *s2);
 | |
|  int strncmp(const char *s1, const char *s2, size_t n);
 | |
|  size_t strxfrm(char * restrict s1, const char * restrict s2, size_t n);
 | |
|  QVoid *memchr(QVoid *s, int c, size_t n);
 | |
|  QChar *strchr(QChar *s, int c);
 | |
|  size_t strcspn(const char *s1, const char *s2);
 | |
|  QChar *strpbrk(QChar *s1, const char *s2);
 | |
|  QChar *strrchr(QChar *s, int c);
 | |
|  size_t strspn(const char *s1, const char *s2);
 | |
|  QChar *strstr(QChar *s1, const char *s2);
 | |
|  char *strtok(char * restrict s1, const char * restrict s2);
 | |
|  void *memset(void *s, int c, size_t n);
 | |
|  void *memset_explicit(void *s, int c, size_t n);
 | |
|  char *strerror(int errnum);
 | |
|  size_t strlen(const char *s);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <string.h>:
 | |
| 
 | |
| errno_t                                       rsize_t
 | |
| 
 | |
| 
 | |
|  errno_t memcpy_s(void * restrict s1, rsize_t s1max, const void * restrict s2,
 | |
|        rsize_t n);
 | |
|  errno_t memmove_s(void *s1, rsize_t s1max, const void *s2, rsize_t n);
 | |
|  errno_t strcpy_s(char * restrict s1, rsize_t s1max, const char * restrict s2);
 | |
|  errno_t strncpy_s(char * restrict s1, rsize_t s1max, const char * restrict s2,
 | |
|        rsize_t n);
 | |
|  errno_t strcat_s(char * restrict s1, rsize_t s1max, const char * restrict s2);
 | |
|  errno_t strncat_s(char * restrict s1, rsize_t s1max, const char * restrict s2,
 | |
|        rsize_t n);
 | |
|  char *strtok_s(char * restrict s1, rsize_t * restrict s1max,
 | |
|        const char * restrict s2, char ** restrict ptr);
 | |
|  errno_t memset_s(void *s, rsize_t smax, int c, rsize_t n)
 | |
|  errno_t strerror_s(char *s, rsize_t maxsize, errno_t errnum);
 | |
|  size_t strerrorlen_s(errno_t errnum);
 | |
|  size_t strnlen_s(const char *s, size_t maxsize);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.26'></a>
 | |
| <hr>
 | |
| <h3>B.26 [Type-generic math <tgmath.h>]</h3>
 | |
| <pre>acos               atanpi           fmin             logb                  tanpi
 | |
| asin               cbrt             fminimum         logp1                 tgamma
 | |
| atan               ceil             fminimum_mag     lrint                 trunc
 | |
| acosh              compoundn        fminimum_num     lround                ufromfpx
 | |
| asinh              copysign         fminimum_mag_num nearbyint             ufromfp
 | |
| atanh              cospi            fmod             nextafter             fadd
 | |
| cos                erfc             frexp            nextdown              dadd
 | |
| sin                erf              fromfpx          nexttoward            fsub
 | |
| tan                exp10m1          fromfp           nextup                dsub
 | |
| cosh               exp10            hypot            pown                  fmul
 | |
| sinh               exp2m1           ilogb            powr                  dmul
 | |
| tanh               exp2             ldexp            remainder             fdiv
 | |
| exp                expm1            lgamma           remquo                ddiv
 | |
| log                fdim             llogb            rint                  ffma
 | |
| pow                floor            llrint           rootn                 dfma
 | |
| sqrt               fmax             llround          roundeven             fsqrt
 | |
| fabs               fmaximum         log10p1          round                 dsqrt
 | |
| acospi             fmaximum_mag     log10            rsqrt
 | |
| asinpi             fmaximum_num     log1p            scalbln
 | |
| atan2pi            fmaximum_mag_num log2p1           scalbn
 | |
| atan2              fma                log2               sinpi
 | |
| 
 | |
| 
 | |
| Only if the implementation does not define __STDC_NO_COMPLEX__ :
 | |
| 
 | |
| carg           cimag           conj            cproj             creal
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_IEC_60559_DFP__ :
 | |
| 
 | |
| d32add         d64sub          d32div          d64fma            quantize        llquantexp
 | |
| d64add         d32mul          d64div          d32sqrt           samequantum
 | |
| d32sub         d64mul          d32fma          d64sqrt           quantum
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.27'></a>
 | |
| <hr>
 | |
| <h3>B.27 [Threads <threads.h>]</h3>
 | |
| <pre>__STDC_NO_THREADS__            mtx_t                             thrd_timedout
 | |
| thread_local                   tss_dtor_t                        thrd_success
 | |
| ONCE_FLAG_INIT                 thrd_start_t                      thrd_busy
 | |
| TSS_DTOR_ITERATIONS            once_flag                         thrd_error
 | |
| cnd_t                          mtx_plain                         thrd_nomem
 | |
| thrd_t                         mtx_recursive
 | |
| tss_t                          mtx_timed
 | |
| 
 | |
| 
 | |
|  void call_once(once_flag *flag, void (*func)(void));
 | |
|  int cnd_broadcast(cnd_t *cond);
 | |
|  void cnd_destroy(cnd_t *cond);
 | |
|  int cnd_init(cnd_t *cond);
 | |
|  int cnd_signal(cnd_t *cond);
 | |
|  int cnd_timedwait(cnd_t *restrict cond, mtx_t *restrict mtx,
 | |
|        const struct timespec *restrict ts);
 | |
|  int cnd_wait(cnd_t *cond, mtx_t *mtx);
 | |
|  void mtx_destroy(mtx_t *mtx);
 | |
|  int mtx_init(mtx_t *mtx, int type);
 | |
|  int mtx_lock(mtx_t *mtx);
 | |
|  int mtx_timedlock(mtx_t *restrict mtx, const struct timespec *restrict ts);
 | |
|  int mtx_trylock(mtx_t *mtx);
 | |
|  int mtx_unlock(mtx_t *mtx);
 | |
|  int thrd_create(thrd_t *thr, thrd_start_t func, void *arg);
 | |
|  thrd_t thrd_current(void);
 | |
|  int thrd_detach(thrd_t thr);
 | |
|  int thrd_equal(thrd_t thr0, thrd_t thr1);
 | |
|  [[noreturn]] void thrd_exit(int res);
 | |
|  int thrd_join(thrd_t thr, int *res);
 | |
|  int thrd_sleep(const struct timespec *duration, struct timespec *remaining);
 | |
|  void thrd_yield(void);
 | |
|  int tss_create(tss_t *key, tss_dtor_t dtor);
 | |
|  void tss_delete(tss_t key);
 | |
|  void *tss_get(tss_t key);
 | |
|  int tss_set(tss_t key, void *val);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.28'></a>
 | |
| <hr>
 | |
| <h3>B.28 [Date and time <time.h>]</h3>
 | |
| <pre>NULL                             size_t                           struct timespec
 | |
| CLOCKS_PER_SEC                   clock_t                          struct tm
 | |
| TIME_UTC                         time_t
 | |
| 
 | |
| 
 | |
|  clock_t clock(void);
 | |
|  double difftime(time_t time1, time_t time0);
 | |
|  time_t mktime(struct tm *timeptr);
 | |
|  time_t timegm(struct tm *timeptr);
 | |
|  time_t time(time_t *timer);
 | |
|  int timespec_get(struct timespec *ts, int base);
 | |
|  int timespec_getres(struct timespec *ts, int base);
 | |
|  [[deprecated]] char *asctime(const struct tm *timeptr);
 | |
|  [[deprecated]] char *ctime(const time_t *timer);
 | |
|  struct tm *gmtime(const time_t *timer);
 | |
|  struct tm *gmtime_r(const time_t *timer, struct tm *buf);
 | |
|  struct tm *localtime(const time_t *timer);
 | |
|  struct tm *localtime_r(const time_t *timer, struct tm *buf);
 | |
|  size_t strftime(char * restrict s, size_t maxsize, const char * restrict format,
 | |
|        const struct tm * restrict timeptr);
 | |
| 
 | |
| 
 | |
| Only if supported by the implementation:
 | |
| 
 | |
| TIME_MONOTONIC
 | |
| TIME_ACTIVE
 | |
| 
 | |
| 
 | |
| Only if threads are supported and it is supported by the implementation:
 | |
| 
 | |
| TIME_THREAD_ACTIVE
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <time.h>:
 | |
| 
 | |
| errno_t                                          rsize_t
 | |
| 
 | |
| 
 | |
|  errno_t asctime_s(char *s, rsize_t maxsize, const struct tm *timeptr);
 | |
|  errno_t ctime_s(char *s, rsize_t maxsize, const time_t *timer);
 | |
|  struct tm *gmtime_s(const time_t * restrict timer, struct tm * restrict result);
 | |
|  struct tm *localtime_s(const time_t *restrict timer, struct tm *restrict result);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.29'></a>
 | |
| <hr>
 | |
| <h3>B.29 [Unicode utilities <uchar.h>]</h3>
 | |
| <pre>mbstate_t             size_t                 char16_t               char32_t
 | |
| 
 | |
| 
 | |
|  size_t mbrtoc8(char8_t * restrict pc8, const char * restrict s, size_t n,
 | |
|        mbstate_t * restrict ps);
 | |
|  size_t c8rtomb(char * restrict s, char8_t c8, mbstate_t * restrict ps);
 | |
|  size_t mbrtoc16(char16_t * restrict pc16, const char * restrict s, size_t n,
 | |
|        mbstate_t * restrict ps);
 | |
|  size_t c16rtomb(char * restrict s, char16_t c16, mbstate_t * restrict ps);
 | |
|  size_t mbrtoc32(char32_t * restrict pc32, const char * restrict s, size_t n,
 | |
|        mbstate_t * restrict ps);
 | |
|  size t c32rtomb(char * restrict s, char32_t c32, mbstate_t * restrict ps);
 | |
|      _
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.30'></a>
 | |
| <hr>
 | |
| <h3>B.30 [Extended multibyte/wide character utilities <wchar.h>]</h3>
 | |
| <pre>wchar_t                        wint_t                       WCHAR_MAX
 | |
| size_t                         struct tm                    WCHAR_MIN
 | |
| mbstate_t                      NULL                         WEOF
 | |
| 
 | |
| 
 | |
|  int fwprintf(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
|  int fwscanf(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
|  int swprintf(wchar_t * restrict s, size_t n, const wchar_t * restrict format,
 | |
|        ...);
 | |
|  int swscanf(const wchar_t * restrict s, const wchar_t * restrict format, ...);
 | |
|  int vfwprintf(FILE * restrict stream, const wchar_t * restrict format,
 | |
|        va_list arg);
 | |
|  int vfwscanf(FILE * restrict stream, const wchar_t * restrict format,
 | |
|        va_list arg);
 | |
|  int vswprintf(wchar_t * restrict s, size_t n, const wchar_t * restrict format,
 | |
|        va_list arg);
 | |
|  int vswscanf(const wchar_t * restrict s, const wchar_t * restrict format,
 | |
|        va_list arg);
 | |
|  int vwprintf(const wchar_t * restrict format, va_list arg);
 | |
|  int vwscanf(const wchar_t * restrict format, va_list arg);
 | |
|  int wprintf(const wchar_t * restrict format, ...);
 | |
|  int wscanf(const wchar_t * restrict format, ...);
 | |
|  wint_t fgetwc(FILE *stream);
 | |
|  wchar_t *fgetws(wchar_t * restrict s, int n, FILE * restrict stream);
 | |
|  wint_t fputwc(wchar_t c, FILE *stream);
 | |
|  int fputws(const wchar_t * restrict s, FILE * restrict stream);
 | |
|  int fwide(FILE *stream, int mode);
 | |
|  wint_t getwc(FILE *stream);
 | |
|  wint_t getwchar(void);
 | |
|  wint_t putwc(wchar_t c, FILE *stream);
 | |
|  wint_t putwchar(wchar_t c);
 | |
|  wint_t ungetwc(wint_t c, FILE *stream);
 | |
|  long int wcstol(const wchar_t * restrict nptr, wchar_t ** restrict endptr,
 | |
|        int base);
 | |
|  long long int wcstoll(const wchar_t * restrict nptr, wchar_t ** restrict endptr,
 | |
|        int base);
 | |
|  unsigned long int wcstoul(const wchar_t * restrict nptr,
 | |
|        wchar_t ** restrict endptr, int base);
 | |
|  unsigned long long int wcstoull(const wchar_t * restrict nptr,
 | |
|        wchar_t ** restrict endptr, int base);
 | |
|  wchar t *wcscpy(wchar_t * restrict s1, const wchar_t * restrict s2);
 | |
|       _
 | |
|  wchar_t *wcsncpy(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
|  wchar_t *wmemcpy(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
|  wchar_t *wmemmove(wchar_t *s1, const wchar_t *s2, size_t n);
 | |
|  wchar_t *wcscat(wchar_t * restrict s1, const wchar_t * restrict s2);
 | |
|  wchar_t *wcsncat(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
|  int wcscmp(const wchar_t *s1, const wchar_t *s2);
 | |
|  int wcscoll(const wchar_t *s1, const wchar_t *s2);
 | |
|  int wcsncmp(const wchar_t *s1, const wchar_t *s2, size_t n);
 | |
|  size_t wcsxfrm(wchar_t * restrict s1, const wchar_t * restrict s2, size_t n);
 | |
|  int wmemcmp(const wchar_t *s1, const wchar_t *s2, size_t n);
 | |
|  QWchar_t *wcschr(QWchar_t *s, wchar_t c);
 | |
|  size_t wcscspn(const wchar_t *s1, const wchar_t *s2);
 | |
|  QWchar_t *wcspbrk(QWchar_t *s1, const wchar_t *s2);
 | |
|  QWchar_t *wcsrchr(const wchar_t *s, wchar_t c);
 | |
|  size_t wcsspn(const wchar_t *s1, const wchar_t *s2);
 | |
|  QWchar_t *wcsstr(QWchar_t *s1, const wchar_t *s2);
 | |
|  wchar_t *wcstok(wchar_t * restrict s1, const wchar_t * restrict s2,
 | |
|        wchar_t ** restrict ptr);
 | |
|  QWchar_t *wmemchr(QWchar_t *s, wchar_t c, size_t n);
 | |
|  size_t wcslen(const wchar_t *s);
 | |
|  wchar_t *wmemset(wchar_t *s, wchar_t c, size_t n);
 | |
|  size_t wcsftime(wchar_t * restrict s, size_t maxsize,
 | |
|        const wchar_t * restrict format, const struct tm * restrict timeptr);
 | |
|  wint_t btowc(int c);
 | |
|  int wctob(wint_t c);
 | |
|  int mbsinit(const mbstate_t *ps);
 | |
|  size_t mbrlen(const char * restrict s, size_t n, mbstate_t * restrict ps);
 | |
|  size_t mbrtowc(wchar_t * restrict pwc, const char * restrict s, size_t n,
 | |
|        mbstate_t * restrict ps);
 | |
|  size_t wcrtomb(char * restrict s, wchar_t wc, mbstate_t * restrict ps);
 | |
|  size_t mbsrtowcs(wchar_t * restrict dst, const char ** restrict src, size_t len,
 | |
|        mbstate_t * restrict ps);
 | |
|  size_t wcsrtombs(char * restrict dst, const wchar_t ** restrict src, size_t len,
 | |
|        mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
| Only if the implementation defines __STDC_LIB_EXT1__ and additionally the user code defines
 | |
| __STDC_WANT_LIB_EXT1__ before any inclusion of <wchar.h>:
 | |
| 
 | |
| errno_t                                       rsize_t
 | |
| 
 | |
| 
 | |
|  int fwprintf_s(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
|  int fwscanf_s(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
|  int snwprintf_s(wchar_t * restrict s, rsize_t n, const wchar_t * restrict format,
 | |
|        ...);
 | |
|  int swprintf_s(wchar_t * restrict s, rsize_t n, const wchar_t * restrict format,
 | |
|        ...);
 | |
|  int swscanf_s(const wchar_t * restrict s, const wchar_t * restrict format, ...);
 | |
|  int vfwprintf_s(FILE * restrict stream, const wchar_t * restrict format,
 | |
|        va_list arg);
 | |
|  int vfwscanf_s(FILE * restrict stream, const wchar_t * restrict format,
 | |
|        va_list arg);
 | |
|  int vsnwprintf_s(wchar_t *restrict s, rsize_t n, const wchar_t *restrict format,
 | |
|        va_list arg);
 | |
|  int vswprintf_s(wchar_t *restrict s, rsize_t n, const wchar_t *restrict format,
 | |
|        va_list arg);
 | |
|  int vswscanf_s(const wchar_t * restrict s, const wchar_t * restrict format,
 | |
|        va_list arg);
 | |
|  int vwprintf_s(const wchar_t * restrict format, va_list arg);
 | |
|  int vwscanf_s(const wchar_t * restrict format, va_list arg);
 | |
|  int wprintf_s(const wchar_t * restrict format, ...);
 | |
|  int wscanf_s(const wchar_t * restrict format, ...);
 | |
|  errno_t wcscpy_s(wchar_t *restrict s1, rsize_t s1max,
 | |
|        const wchar_t *restrict s2);
 | |
|  errno t wcsncpy_s(wchar_t * restrict s1, rsize_t s1max,
 | |
|       _
 | |
|        const wchar_t * restrict s2, rsize_t n);
 | |
|  errno_t wmemcpy_s(wchar_t *restrict s1, rsize_t s1max,
 | |
|        const wchar_t *restrict s2, rsize_t n);
 | |
|  errno_t wmemmove_s(wchar_t *s1, rsize_t s1max, const wchar_t *s2, rsize_t n);
 | |
|  errno_t wcscat_s(wchar_t * restrict s1, rsize_t s1max,
 | |
|        const wchar_t * restrict s2);
 | |
|  errno_t wcsncat_s(wchar_t * restrict s1, rsize_t s1max,
 | |
|        const wchar_t * restrict s2, rsize_t n);
 | |
|  wchar t *wcstok_s(wchar_t * restrict s1, rsize_t * restrict s1max,
 | |
|       _
 | |
|        const wchar_t * restrict s2, wchar_t ** restrict ptr);
 | |
|  size_t wcsnlen_s(const wchar_t *s, size_t maxsize);
 | |
|  errno_t wcrtomb_s(size_t * restrict retval, char * restrict s, rsize_t smax,
 | |
|        wchar_t wc, mbstate_t * restrict ps);
 | |
|  errno_t mbsrtowcs_s(size_t * restrict retval, wchar_t * restrict dst,
 | |
|        rsize_t dstmax, const char ** restrict src, rsize_t len,
 | |
|        mbstate_t * restrict ps);
 | |
|  errno_t wcsrtombs_s(size_t * restrict retval, char * restrict dst,
 | |
|        rsize_t dstmax, const wchar_t ** restrict src, rsize_t len,
 | |
|        mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='B.31'></a>
 | |
| <hr>
 | |
| <h3>B.31 [Wide character classification and mapping utilities <wctype.h>]</h3>
 | |
| <pre>wint_t                wctrans_t                 wctype_t           WEOF
 | |
| 
 | |
| 
 | |
|  int iswalnum(wint_t wc);
 | |
|  int iswalpha(wint_t wc);
 | |
|  int iswblank(wint_t wc);
 | |
|  int iswcntrl(wint_t wc);
 | |
|  int iswdigit(wint_t wc);
 | |
|  int iswgraph(wint_t wc);
 | |
|  int iswlower(wint_t wc);
 | |
|  int iswprint(wint_t wc);
 | |
|  int iswpunct(wint_t wc);
 | |
|  int iswspace(wint_t wc);
 | |
|  int iswupper(wint_t wc);
 | |
|  int iswxdigit(wint_t wc);
 | |
|  int iswctype(wint_t wc, wctype_t desc);
 | |
|  wctype_t wctype(const char *property);
 | |
|  wint_t towlower(wint_t wc);
 | |
|  wint_t towupper(wint_t wc);
 | |
|  wint_t towctrans(wint_t wc, wctrans_t desc);
 | |
|  wctrans_t wctrans(const char *property);
 | |
| 
 | |
| </pre>
 | |
| <a name='C.'></a>
 | |
| <hr>
 | |
| <h3>C. [Annex C (informative) Sequence points]</h3>
 | |
| <a name='C.p1'></a>
 | |
| <pre>1   The following are the sequence points described in <a href='#5.1.2.3'>5.1.2.3</a>:
 | |
| 
 | |
|       — Between the evaluations of the function designator and actual arguments in a function call
 | |
|         and the actual call. (<a href='#6.5.2.2'>6.5.2.2</a>).
 | |
|       — Between the evaluations of the first and second operands of the following operators: logical
 | |
|         AND && (<a href='#6.5.13'>6.5.13</a>); logical OR || (<a href='#6.5.14'>6.5.14</a>); comma , (<a href='#6.5.17'>6.5.17</a>).
 | |
|       — Between the evaluations of the first operand of the conditional ?: operator and whichever of
 | |
|         the second and third operands is evaluated (<a href='#6.5.15'>6.5.15</a>).
 | |
|       — Between the evaluation of a full expression and the next full expression to be evaluated. The
 | |
|         following are full expressions: a full declarator for a variably modified type; an initializer that
 | |
|         is not part of a compound literal (<a href='#6.7.10'>6.7.10</a>); the expression in an expression statement (<a href='#6.8.3'>6.8.3</a>); the
 | |
|         controlling expression of a selection statement (if or switch) (<a href='#6.8.4'>6.8.4</a>); the controlling expression
 | |
|         of a while or do statement (<a href='#6.8.5'>6.8.5</a>); each of the (optional) expressions of a for statement (<a href='#6.8.5.3'>6.8.5.3</a>);
 | |
|         the (optional) expression in a return statement (<a href='#6.8.6.4'>6.8.6.4</a>).
 | |
|       — Immediately before a library function returns (<a href='#7.1.4'>7.1.4</a>).
 | |
| 
 | |
|       — After the actions associated with each formatted input/output function conversion specifier
 | |
|         (<a href='#7.23.6'>7.23.6</a>, <a href='#7.31.2'>7.31.2</a>).
 | |
|       — Immediately before and immediately after each call to a comparison function, and also between
 | |
|         any call to a comparison function and any movement of the objects passed as arguments to
 | |
|         that call (<a href='#7.24.5'>7.24.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='D.'></a>
 | |
| <hr>
 | |
| <h3>D. [Annex D (informative) Universal character names for identifiers]</h3>
 | |
| <a name='D.p1'></a>
 | |
| <pre>1   This subclause describes the choices made in application of UAX #31 ("Unicode Identifier and
 | |
|     Pattern Syntax") to C of the requirements from UAX #31 and how they do or do not apply to C.
 | |
|     For UAX #31, C conforms by meeting the requirements "Default Identifiers" (<a href='#D.1'>D.1</a>) and "Equivalent
 | |
|     Normalized Identifiers" (<a href='#D.1'>D.1</a>). The other requirements, also listed below, are either alternatives not
 | |
|     taken or do not apply to C.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.1'></a>
 | |
| <hr>
 | |
| <h3>D.1 [Default Identifiers]</h3>
 | |
| <a name='D.1p1'></a>
 | |
| <pre>1   UAX #31 specifies a default syntax for identifiers based on properties from the Unicode Character
 | |
|     Database, UAX #44. The general syntax is
 | |
| 
 | |
|              <Identifier> := <Start> <Continue>* (<Medial> <Continue>+)*
 | |
| 
 | |
| 
 | |
|     where <Start> has the XID_Start property, <Continue> has the XID_Continue property, and
 | |
|     <Medial> is a list of characters permitted between continue characters. For C we add the character
 | |
|     U+005F, LOW LINE, or _, to the set of permitted Start characters, the Medial set is empty, and the
 | |
|     Continue characters are unmodified. In the grammar used in UAX #31, this is
 | |
| 
 | |
|              <Identifier> := <Start> <Continue>*
 | |
|              <Start> := XID_Start + U+005F
 | |
|              <Continue> := <Start> + XID_Continue
 | |
| 
 | |
| 
 | |
|     This is described in the C grammar (<a href='#6.4.2.1'>6.4.2.1</a>), where identifier is formed from identifier-start or identifier
 | |
|     followed by identifier-continue.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.1.1'></a>
 | |
| <hr>
 | |
| <h3>D.1.1 [Restricted Format Characters]</h3>
 | |
| <a name='D.1.1p1'></a>
 | |
| <pre>1   If an implementation of UAX #31 wishes to allow format characters such as ZERO WIDTH JOINER
 | |
|     or ZERO WIDTH NON-JOINER it must define a profile allowing them, or describe precisely which
 | |
|     combinations are permitted.
 | |
| </pre>
 | |
| <a name='D.1.1p2'></a>
 | |
| <pre>2   C does not allow format characters in identifiers, so this does not apply.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.1.2'></a>
 | |
| <hr>
 | |
| <h3>D.1.2 [Stable Identifiers]</h3>
 | |
| <a name='D.1.2p1'></a>
 | |
| <pre>1   An implementation of UAX #31 may choose to guarantee that identifiers are stable across versions
 | |
|     of the Unicode Standard. Once a string qualifies as an identifier it does so in all future versions.
 | |
|     C does not make this guarantee, except to the extent that UAX #31 guarantees the stability of the
 | |
|     XID_Start and XID_Continue properties.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.2'></a>
 | |
| <hr>
 | |
| <h3>D.2 [Immutable Identifiers]</h3>
 | |
| <a name='D.2p1'></a>
 | |
| <pre>1   An implementation may choose to guarantee that the set of identifiers will never change by fixing
 | |
|     the set of code points allowed in identifiers forever.
 | |
| </pre>
 | |
| <a name='D.2p2'></a>
 | |
| <pre>2   C does not choose to make this guarantee. As scripts are added to Unicode, additional characters in
 | |
|     those scripts may become available for use in identifiers.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.3'></a>
 | |
| <hr>
 | |
| <h3>D.3 [Pattern_White_Space and Pattern_Syntax Characters]</h3>
 | |
| <a name='D.3p1'></a>
 | |
| <pre>1   UAX #31 describes how languages that use or interpret patterns of characters, such as regular
 | |
|     expressions or number formats, may describe that syntax with Unicode properties.
 | |
| </pre>
 | |
| <a name='D.3p2'></a>
 | |
| <pre>2   C does not do this as part of the language, deferring to library components for such usage of patterns.
 | |
|     This requirement does not apply to C.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.4'></a>
 | |
| <hr>
 | |
| <h3>D.4 [Equivalent Normalized Identifiers]</h3>
 | |
| <a name='D.4p1'></a>
 | |
| <pre>1   UAX #31 requires that implementations describe how identifiers are compared and considered
 | |
|     equivalent.
 | |
| </pre>
 | |
| <a name='D.4p2'></a>
 | |
| <pre>2   C requires that identifiers be in Normalization Form C and therefore identifiers that compare the
 | |
|     same under NFC are equivalent. This is described in subclause <a href='#6.4.2'>6.4.2</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.5'></a>
 | |
| <hr>
 | |
| <h3>D.5 [Equivalent Case-Insensitive Identifiers]</h3>
 | |
| <a name='D.5p1'></a>
 | |
| <pre>1   C considers case to be significant in identifier comparison, and does not do any case folding. This
 | |
|     requirement does not apply to C
 | |
| 
 | |
| </pre>
 | |
| <a name='D.6'></a>
 | |
| <hr>
 | |
| <h3>D.6 [Filtered Normalized Identifiers]</h3>
 | |
| <a name='D.6p1'></a>
 | |
| <pre>1   If any characters are excluded from normalization, UAX #31 requires a precise specification of those
 | |
|     exclusions.
 | |
| </pre>
 | |
| <a name='D.6p2'></a>
 | |
| <pre>2   C does not make any such exclusions.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.7'></a>
 | |
| <hr>
 | |
| <h3>D.7 [Filtered Case-Insensitive Identifiers]</h3>
 | |
| <a name='D.7p1'></a>
 | |
| <pre>1   C identifiers are case sensitive, and therefore this requirement does not apply.
 | |
| 
 | |
| </pre>
 | |
| <a name='D.8'></a>
 | |
| <hr>
 | |
| <h3>D.8 [Hashtag Identifiers]</h3>
 | |
| <a name='D.8p1'></a>
 | |
| <pre>1   There are no hashtags in C, so this requirement does not apply.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='E.'></a>
 | |
| <hr>
 | |
| <h3>E. [Annex E (informative) Implementation limits]</h3>
 | |
| <a name='E.p1'></a>
 | |
| <pre>1   The contents of the header <limits.h> are given below. The values shall all be constant expressions
 | |
|     suitable for use in #if preprocessing directives. The components are described further in <a href='#5.2.4.2.1'>5.2.4.2.1</a>.
 | |
| </pre>
 | |
| <a name='E.p2'></a>
 | |
| <pre>2   For the following macros, the minimum values shown shall be replaced by implementation-defined
 | |
|     values.
 | |
| 
 | |
|               #define BOOL_WIDTH                                        1
 | |
|               #define CHAR_BIT                                          8
 | |
|               #define USHRT_WIDTH                                      16
 | |
|               #define UINT_WIDTH                                       16
 | |
|               #define ULONG_WIDTH                                      32
 | |
|               #define ULLONG_WIDTH                                     64
 | |
|               #define BITINT_MAXWIDTH                                  64 // ULLONG_WIDTH
 | |
|               #define MB_LEN_MAX                                        1
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='E.p3'></a>
 | |
| <pre>3   For the following macros, the minimum magnitudes shown shall be replaced by implementation-
 | |
|     defined magnitudes with the same sign that are deduced from the macros above as indicated.<a href='#FOOTNOTE.434'><sup>[434]</sup></a>
 | |
|                                                                                       _
 | |
|               #define BOOL_MAX                         1                     // 2BOOL WIDTH − 1
 | |
|               #define CHAR_MAX    UCHAR_MAX or SCHAR_MAX
 | |
|               #define CHAR_MIN            0 or SCHAR_MIN
 | |
|                           _
 | |
|               #define CHAR WIDTH                       8                     // CHAR_BIT
 | |
|                                                                                      _
 | |
|               #define INT_MAX                     +32767                     // 2INT WIDTH−1 − 1
 | |
|                                                                                     INT_WIDTH−1
 | |
|               #define INT_MIN                     -32768                     // −2
 | |
|               #define INT_WIDTH                       16                     // UINT_WIDTH
 | |
|                                                                                       _
 | |
|               #define LONG_MAX               +2147483647                     // 2LONG WIDTH−1 − 1
 | |
|                                                                                           _
 | |
|               #define LONG_MIN               -2147483648                     // −2LONG WIDTH−1
 | |
|               #define LONG_WIDTH                      32                     // ULONG_WIDTH
 | |
|                                                                                         _
 | |
|               #define LLONG_MAX     +9223372036854775807                     // 2LLONG WIDTH−1 − 1
 | |
|                                                                                     LLONG_WIDTH−1
 | |
|               #define LLONG_MIN     -9223372036854775808                     // −2
 | |
|               #define LLONG_WIDTH                     64                     // ULLONG_WIDTH
 | |
|                                                                                         _
 | |
|               #define SCHAR_MAX                     +127                     // 2SCHAR WIDTH−1 − 1
 | |
|                                                                                     SCHAR_WIDTH−1
 | |
|               #define SCHAR_MIN                     -128                     // −2
 | |
|               #define SCHAR_WIDTH                      8                     // CHAR_BIT
 | |
|                                                                                       _
 | |
|               #define SHRT_MAX                    +32767                     // 2SHRT WIDTH−1 − 1
 | |
|                                                                                     SHRT_WIDTH−1
 | |
|               #define SHRT_MIN                    -32768                     // −2
 | |
|                                                                                         _
 | |
|               #define UCHAR_MAX                      255                     // 2UCHAR WIDTH − 1
 | |
|               #define UCHAR_WIDTH                      8                               _
 | |
|                                                                              // CHAR BIT
 | |
|                                                                                         _
 | |
|               #define USHRT_MAX                    65535                     // 2USHRT WIDTH − 1
 | |
|                                                                                       _
 | |
|               #define UINT_MAX                     65535                     // 2UINT WIDTH − 1
 | |
|                                                                                         _
 | |
|               #define ULONG_MAX               4294967295                     // 2ULONG WIDTH − 1
 | |
|                                                                                   ULLONG_WIDTH
 | |
|               #define ULLONG_MAX    18446744073709551615                     // 2              −1
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.434'>
 | |
| <pre><i><b>Footnote 434)</b> For the minimum value of a signed integer type there is no expression consisting of a minus sign and a decimal literal of
 | |
|     that same type. The numbers in the table are only given as indications for the values and do not represent suitable expressions
 | |
|     to be used for these macros.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='E.p4'></a>
 | |
| <pre>4   The contents of the header <float.h> are given below. All integer values, except FLT_ROUNDS, shall
 | |
|     be constant expressions suitable for use in #if preprocessing directives; all floating values shall be
 | |
|     constant expressions. The components are described further in <a href='#5.2.4.2.2'>5.2.4.2.2</a> and <a href='#5.2.4.2.3'>5.2.4.2.3</a>.
 | |
| </pre>
 | |
| <a name='E.p5'></a>
 | |
| <pre>5   The values given in the following list shall be replaced by implementation-defined expressions:
 | |
| 
 | |
|               #define FLT_EVAL_METHOD
 | |
|               #define FLT_ROUNDS
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               #define DEC_EVAL_METHOD
 | |
|             #endif
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='E.p6'></a>
 | |
| <pre>6   The values given in the following list shall be replaced by implementation-defined constant ex-
 | |
|     pressions that are greater or equal in magnitude (absolute value) to those shown, with the same
 | |
|     sign:
 | |
| 
 | |
|             #define DBL_DECIMAL_DIG                     10
 | |
|             #define DBL_DIG                             10
 | |
|             #define DBL_MANT_DIG
 | |
|             #define DBL_MAX_10_EXP                     +37
 | |
|             #define DBL_MAX_EXP
 | |
|             #define DBL_MIN_10_EXP                     -37
 | |
|             #define DBL_MIN_EXP
 | |
|             #define DECIMAL_DIG                         10
 | |
|             #define FLT_DECIMAL_DIG                      6
 | |
|             #define FLT_DIG                              6
 | |
|             #define FLT_MANT_DIG
 | |
|             #define FLT_MAX_10_EXP                     +37
 | |
|             #define FLT_MAX_EXP
 | |
|             #define FLT_MIN_10_EXP                     -37
 | |
|             #define FLT_MIN_EXP
 | |
|             #define FLT_RADIX                            2
 | |
|             #define LDBL_DECIMAL_DIG                    10
 | |
|             #define LDBL_DIG                            10
 | |
|             #define LDBL_MANT_DIG
 | |
|             #define LDBL_MAX_10_EXP                    +37
 | |
|             #define LDBL_MAX_EXP
 | |
|             #define LDBL_MIN_10_EXP                    -37
 | |
|             #define LDBL_MIN_EXP
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='E.p7'></a>
 | |
| <pre>7   The values given in the following list shall be replaced by implementation-defined constant expres-
 | |
|     sions with values that are greater than or equal to those shown:
 | |
| 
 | |
|             #define DBL_MAX                          1E+37
 | |
|             #define DBL_NORM_MAX                     1E+37
 | |
|             #define FLT_MAX                          1E+37
 | |
|             #define FLT_NORM_MAX                     1E+37
 | |
|             #define LDBL_MAX                         1E+37
 | |
|             #define LDBL_NORM_MAX                    1E+37
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='E.p8'></a>
 | |
| <pre>8   The values given in the following list shall be replaced by implementation-defined constant expres-
 | |
|     sions with (positive) values that are less than or equal to those shown:
 | |
| 
 | |
|             #define DBL_EPSILON                       1E-9
 | |
|             #define DBL_MIN                          1E-37
 | |
|             #define FLT_EPSILON                       1E-5
 | |
|             #define FLT_MIN                          1E-37
 | |
|             #define LDBL_EPSILON                      1E-9
 | |
|             #define LDBL_MIN                         1E-37
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='E.p9'></a>
 | |
| <pre>9   If the implementation supports decimal floating types, the following macros provide the parameters
 | |
|     of these types as exact values.
 | |
| 
 | |
|             #ifdef __STDC_IEC_60559_DFP__
 | |
|             #define DEC32_EPSILON      1E-6DF
 | |
|             #define DEC32_MANT_DIG     7
 | |
|             #define DEC32_MAX          9.999999E96DF
 | |
|             #define DEC32_MAX_EXP      97
 | |
|             #define DEC32_MIN          1E-95DF
 | |
|             #define DEC32_MIN_EXP      -94
 | |
| #define DEC32_TRUE_MIN    0.000001E-95DF
 | |
| #define DEC64_EPSILON     1E-15DD
 | |
| #define DEC64_MANT_DIG    16
 | |
| #define DEC64_MAX         9.999999999999999E384DD
 | |
| #define DEC64_MAX_EXP     385
 | |
| #define DEC64_MIN         1E-383DD
 | |
| #define DEC64_MIN_EXP     -382
 | |
| #define DEC64_TRUE_MIN    0.000000000000001E-383DD
 | |
| #define DEC128_EPSILON    1E-33DL
 | |
| #define DEC128_MANT_DIG   34
 | |
| #define DEC128_MAX        9.999999999999999999999999999999999E6144DL
 | |
| #define DEC128_MAX_EXP    6145
 | |
| #define DEC128_MIN        1E-6143DL
 | |
| #define DEC128_MIN_EXP    -6142
 | |
| #define DEC128_TRUE_MIN   0.000000000000000000000000000000001E-6143DL
 | |
| #endif
 | |
| 
 | |
| </pre>
 | |
| <a name='F.'></a>
 | |
| <hr>
 | |
| <h3>F. [Annex F (normative) IEC 60559 floating-point arithmetic]</h3>
 | |
| <a name='F.1'></a>
 | |
| <hr>
 | |
| <h3>F.1 [Introduction]</h3>
 | |
| <a name='F.1p1'></a>
 | |
| <pre>1   This annex specifies C language support for the IEC 60559 floating-point standard. The IEC 60559
 | |
|     floating-point standard is specifically Floating-point arithmetic (ISO/IEC 60559:2020), also designated
 | |
|     as IEEE Standard for Floating-Point Arithmetic (IEEE 754–2019). IEC 60559 generally refers to the
 | |
|     floating-point standard, as in IEC 60559 operation, IEC 60559 format, etc.
 | |
| </pre>
 | |
| <a name='F.1p2'></a>
 | |
| <pre>2   The IEC 60559 floating-point standard specifies decimal, as well as binary, floating-point arithmetic.
 | |
|     It supersedes IEEE Standard for Radix-Independent Floating-Point Arithmetic (ANSI/IEEE 854–1987)
 | |
|     which generalized the binary arithmetic standard (IEEE 754-1985) to remove dependencies on radix
 | |
|     and word length.
 | |
| </pre>
 | |
| <a name='F.1p3'></a>
 | |
| <pre>3   An implementation that defines __STDC_IEC_60559_BFP__ to 202311L shall conform to the specifi-
 | |
|     cations in this annex for binary floating-point arithmetic and shall also define __STDC_IEC_559__
 | |
|     to 1.<a href='#FOOTNOTE.435'><sup>[435]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.435'>
 | |
| <pre><i><b>Footnote 435)</b> Implementations that do not define either of __STDC_IEC_60559_BFP__ and __STDC_IEC_559__ are not required to
 | |
|     conform to these specifications. New code should not use the obsolescent macro __STDC_IEC_559__ to test for conformance
 | |
|     to this annex.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.1p4'></a>
 | |
| <pre>4   An implementation that defines __STDC_IEC_60559_DFP__ to 202311L shall conform to the
 | |
|     specifications for decimal floating-point arithmetic in the following subclauses of this annex:
 | |
| 
 | |
| 
 | |
|            —     <a href='#F.2.1'>F.2.1</a>    Infinities and NaNs
 | |
|            —     <a href='#F.3'>F.3</a>      Operations
 | |
|            —     <a href='#F.4'>F.4</a>      Floating to integer conversions
 | |
|            —     <a href='#F.6'>F.6</a>      The return statement
 | |
|            —     <a href='#F.7'>F.7</a>      Contracted expressions
 | |
|            —     <a href='#F.8'>F.8</a>      Floating-point environment
 | |
|            —     <a href='#F.9'>F.9</a>      Optimization
 | |
|            —     <a href='#F.10'>F.10</a>     Mathematics <math.h> and <tgmath.h>
 | |
| 
 | |
| 
 | |
|     For the purpose of specifying these conformance requirements, the macros, functions, and values
 | |
|     mentioned in the subclauses listed above are understood to refer to the corresponding macros,
 | |
|     functions, and values for decimal floating types. Likewise, the "rounding direction mode" is
 | |
|     understood to refer to the rounding direction mode for decimal floating-point arithmetic.
 | |
| </pre>
 | |
| <a name='F.1p5'></a>
 | |
| <pre>5   Where a binding between the C language and IEC 60559 is indicated, the IEC 60559-specified
 | |
|     behavior is adopted by reference, unless stated otherwise.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.2'></a>
 | |
| <hr>
 | |
| <h3>F.2 [Types]</h3>
 | |
| <a name='F.2p1'></a>
 | |
| <pre>1   The C floating types match the IEC 60559 formats as follows:
 | |
| 
 | |
|       — The float type matches the IEC 60559 binary32 format.
 | |
| 
 | |
|       — The double type matches the IEC 60559 binary64 format.
 | |
| 
 | |
|       — The long double type matches the IEC 60559 binary128 format, else an IEC 60559 binary64-
 | |
|         extended format, <a href='#FOOTNOTE.436'><sup>[436]</sup></a> else a non-IEC 60559 extended format, else the IEC 60559 binary64
 | |
|         format.
 | |
| 
 | |
|     Any non-IEC 60559 extended format used for the long double type shall have more precision than
 | |
|     IEC 60559 binary64 and at least the range of IEC 60559 binary64.<a href='#FOOTNOTE.437'><sup>[437]</sup></a> The value of FLT_ROUNDS
 | |
|     applies to all IEC 60559 types supported by the implementation, but need not apply to non-IEC 60559
 | |
|     types.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.436'>
 | |
| <pre><i><b>Footnote 436)</b> IEC 60559 binary64-extended formats include the common 80-bit IEC 60559 format.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.437'>
 | |
| <pre><i><b>Footnote 437)</b> A non-IEC 60559 long double type is required to provide infinity and NaNs, as its values include all double values.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.2p2'></a>
 | |
| <pre>2   The long double type should match the IEC 60559 binary128 format, else an IEC 60559 binary64-
 | |
|     extended format.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.2.1'></a>
 | |
| <hr>
 | |
| <h3>F.2.1 [Infinities and NaNs]</h3>
 | |
| <a name='F.2.1p1'></a>
 | |
| <pre>1   Since negative and positive infinity are representable in IEC 60559 formats, all real numbers lie
 | |
|     within the range of representable values (<a href='#5.2.4.2.2'>5.2.4.2.2</a>).
 | |
| </pre>
 | |
| <a name='F.2.1p2'></a>
 | |
| <pre>2   The NAN and INFINITY macros in <float.h> and the nan functions in <math.h> provide designa-
 | |
|     tions for IEC 60559 quiet NaNs and infinities. The FLT_SNAN, DBL_SNAN, and LDBL_SNAN macros in
 | |
|     <float.h> provide designations for IEC 60559 signaling NaNs.
 | |
| </pre>
 | |
| <a name='F.2.1p3'></a>
 | |
| <pre>3   This annex does not require the full support for signaling NaNs specified in IEC 60559. This
 | |
|     annex uses the term NaN, unless explicitly qualified, to denote quiet NaNs. Where specification of
 | |
|     signaling NaNs is not provided, the behavior of signaling NaNs is implementation-defined (either
 | |
|     treated as an IEC 60559 quiet NaN or treated as an IEC 60559 signaling NaN). <a href='#FOOTNOTE.438'><sup>[438]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.438'>
 | |
| <pre><i><b>Footnote 438)</b> Since NaNs created by IEC 60559 arithmetic operations are always quiet, quiet NaNs (along with infinities) are sufficient
 | |
|     for closure of the arithmetic.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.2.1p4'></a>
 | |
| <pre>4   Any operator or <math.h> function that raises an "invalid" floating-point exception, if delivering a
 | |
|     floating type result, shall return a quiet NaN, unless explicitly specified otherwise.
 | |
| </pre>
 | |
| <a name='F.2.1p5'></a>
 | |
| <pre>5   In order to support signaling NaNs as specified in IEC 60559, an implementation should adhere to
 | |
|     the following recommended practice.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='F.2.1p6'></a>
 | |
| <pre>6   Any floating-point operator or <math.h> function or macro with a signaling NaN input, unless
 | |
|     explicitly specified otherwise, raises an "invalid" floating-point exception.
 | |
| </pre>
 | |
| <a name='F.2.1p7'></a>
 | |
| <pre>7   NOTE Some functions do not propagate quiet NaN arguments. For example, hypot(x, y) returns infinity if x or y is
 | |
|     infinite and the other is a quiet NaN. The recommended practice in this subclause specifies that such functions (and others)
 | |
|     raise the "invalid" floating-point exception if an argument is a signaling NaN, which also implies they return a quiet NaN in
 | |
|     these cases.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.2.1p8'></a>
 | |
| <pre>8   The <fenv.h> header defines the macro FE_SNANS_ALWAYS_SIGNAL if and only if the implemen-
 | |
|     tation follows the recommended practice in this subclause. If defined, FE_SNANS_ALWAYS_SIGNAL
 | |
|     expands to the integer constant 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.3'></a>
 | |
| <hr>
 | |
| <h3>F.3 [Operations]</h3>
 | |
| <a name='F.3p1'></a>
 | |
| <pre>1   C operators, functions, and function-like macros provide operations specified by IEC 60559 as shown
 | |
|     in the following table. In the table, C functions are represented by the function name without a type
 | |
|     suffix. Specifications for the C facilities are provided in the listed clauses. The C specifications are
 | |
|     intended to match IEC 60559, unless stated otherwise.
 | |
| 
 | |
|                                                                Operation binding
 | |
| 
 | |
|             IEC 60559 operation                                   C operation                                     Clause
 | |
|             roundToIntegralTiesToEven                             roundeven                                       <a href='#7.12.9.8'>7.12.9.8</a>, <a href='#F.10.6.8'>F.10.6.8</a>
 | |
|             roundToIntegralTiesAway                               round                                           <a href='#7.12.9.6'>7.12.9.6</a>, <a href='#F.10.6.6'>F.10.6.6</a>
 | |
|             roundToIntegralTowardZero                             trunc                                           <a href='#7.12.9.9'>7.12.9.9</a>, <a href='#F.10.6.9'>F.10.6.9</a>
 | |
|             roundToIntegralTowardPositive                         ceil                                            <a href='#7.12.9.1'>7.12.9.1</a>, <a href='#F.10.6.1'>F.10.6.1</a>
 | |
|             roundToIntegralTowardNegative                         floor                                           <a href='#7.12.9.2'>7.12.9.2</a>, <a href='#F.10.6.2'>F.10.6.2</a>
 | |
|             roundToIntegralExact                                  rint                                            <a href='#7.12.9.4'>7.12.9.4</a>, <a href='#F.10.6.4'>F.10.6.4</a>
 | |
|             nextUp                                                nextup                                          <a href='#7.12.11.5'>7.12.11.5</a>, <a href='#F.10.8.5'>F.10.8.5</a>
 | |
|             nextDown                                              nextdown                                        <a href='#7.12.11.6'>7.12.11.6</a>, <a href='#F.10.8.6'>F.10.8.6</a>
 | |
|             getPayload                                            getpayload                                      <a href='#F.10.13.1'>F.10.13.1</a>
 | |
|             setPayload                                            setpayload                                      <a href='#F.10.13.2'>F.10.13.2</a>
 | |
| setPayloadSignaling                   setpayloadsig                      <a href='#F.10.13.3'>F.10.13.3</a>
 | |
| quantize                              quantize                           <a href='#7.12.15.1'>7.12.15.1</a>
 | |
| sameQuantum                           samequantum                        <a href='#7.12.15.2'>7.12.15.2</a>
 | |
| quantum                               quantum                            <a href='#7.12.15.3'>7.12.15.3</a>
 | |
| encodeDecimal                         encodedec                          <a href='#7.12.16.1'>7.12.16.1</a>
 | |
| decodeDecimal                         decodedec                          <a href='#7.12.16.2'>7.12.16.2</a>
 | |
| encodeBinary                          encodebin                          <a href='#7.12.16.3'>7.12.16.3</a>
 | |
| decodeBinary                          decodebin                          <a href='#7.12.16.4'>7.12.16.4</a>
 | |
| remainder                             remainder, remquo                  <a href='#7.12.10.2'>7.12.10.2</a>, <a href='#F.10.7.2'>F.10.7.2</a>,
 | |
|                                                                          <a href='#7.12.10.3'>7.12.10.3</a>, <a href='#F.10.7.3'>F.10.7.3</a>
 | |
| maximum                               fmaximum                           <a href='#7.12.12.4'>7.12.12.4</a>, <a href='#F.10.9.4'>F.10.9.4</a>
 | |
| minimum                               fminimum                           <a href='#7.12.12.5'>7.12.12.5</a>, <a href='#F.10.9.4'>F.10.9.4</a>
 | |
| maximumMagnitude                      fmaximum_mag                       <a href='#7.12.12.6'>7.12.12.6</a>, <a href='#F.10.9.4'>F.10.9.4</a>
 | |
| minimumMagnitude                      fminimum_mag                       <a href='#7.12.12.7'>7.12.12.7</a>, <a href='#F.10.9.4'>F.10.9.4</a>
 | |
| maximumNumber                         fmaximum_num                       <a href='#7.12.12.8'>7.12.12.8</a>, <a href='#F.10.9.5'>F.10.9.5</a>
 | |
| minimumNumber                         fminimum_num                       <a href='#7.12.12.9'>7.12.12.9</a>, <a href='#F.10.9.5'>F.10.9.5</a>
 | |
| maximumMagnitudeNumber                fmaximum_mag_num                   <a href='#7.12.12.10'>7.12.12.10</a>, <a href='#F.10.9.5'>F.10.9.5</a>
 | |
| minimumMagnitudeNumber                fminimum_mag_num                   <a href='#7.12.12.11'>7.12.12.11</a>, <a href='#F.10.9.5'>F.10.9.5</a>
 | |
| scaleB                                scalbn, scalbln                    <a href='#7.12.6.19'>7.12.6.19</a>, <a href='#F.10.3.19'>F.10.3.19</a>
 | |
| logB                                  logb, ilogb, llogb                 <a href='#7.12.6.17'>7.12.6.17</a>, <a href='#F.10.3.17'>F.10.3.17</a>,
 | |
|                                                                          <a href='#7.12.6.8'>7.12.6.8</a>,      <a href='#F.10.3.8'>F.10.3.8</a>,
 | |
|                                                                          <a href='#7.12.6.10'>7.12.6.10</a>, <a href='#F.10.3.10'>F.10.3.10</a>
 | |
| addition                              + , fadd, faddl, daddl             <a href='#6.5.6'>6.5.6</a>,       <a href='#7.12.14.1'>7.12.14.1</a>,
 | |
|                                                                          <a href='#F.10.11'>F.10.11</a>
 | |
| subtraction                           - , fsub, fsubl, dsubl             <a href='#6.5.6'>6.5.6</a>,       <a href='#7.12.14.2'>7.12.14.2</a>,
 | |
|                                                                          <a href='#F.10.11'>F.10.11</a>
 | |
| multiplication                        * , fmul, fmull, dmull             <a href='#6.5.5'>6.5.5</a>,       <a href='#7.12.14.3'>7.12.14.3</a>,
 | |
|                                                                          <a href='#F.10.11'>F.10.11</a>
 | |
| division                              / , fdiv, fdivl, ddivl             <a href='#6.5.5'>6.5.5</a>,       <a href='#7.12.14.4'>7.12.14.4</a>,
 | |
|                                                                          <a href='#F.10.11'>F.10.11</a>
 | |
| squareRoot                            sqrt, fsqrt, fsqrtl, dsqrtl        <a href='#7.12.7.10'>7.12.7.10</a>, <a href='#F.10.4.10'>F.10.4.10</a>,
 | |
|                                                                          <a href='#7.12.14.6'>7.12.14.6</a>, <a href='#F.10.11'>F.10.11</a>
 | |
| fusedMultiplyAdd                      fma, ffma, ffmal, dfmal            <a href='#7.12.13.1'>7.12.13.1</a>, <a href='#F.10.10.1'>F.10.10.1</a>,
 | |
|                                                                          <a href='#7.12.14.5'>7.12.14.5</a>, <a href='#F.10.11'>F.10.11</a>
 | |
| convertFromInt                        cast and implicit conversion       <a href='#6.3.1.4'>6.3.1.4</a>, <a href='#6.5.4'>6.5.4</a>
 | |
| convertToIntegerTiesToEven            fromfp, ufromfp                    <a href='#7.12.9.10'>7.12.9.10</a>, <a href='#F.10.6.10'>F.10.6.10</a>
 | |
| convertToIntegerTowardZero
 | |
| convertToIntegerTowardPositive
 | |
| convertToIntegerTowardNegative
 | |
| convertToIntegerTiesToAway            fromfp,   ufromfp,       lround,   <a href='#7.12.9.10'>7.12.9.10</a>, <a href='#F.10.6.10'>F.10.6.10</a>,
 | |
|                                       llround                            <a href='#7.12.9.7'>7.12.9.7</a>, <a href='#F.10.6.7'>F.10.6.7</a>
 | |
| convertToIntegerExactTiesToEven       fromfpx, ufromfpx                  <a href='#7.12.9.11'>7.12.9.11</a>, <a href='#F.10.6.11'>F.10.6.11</a>
 | |
| convertToIntegerExactTowardZero
 | |
| convertToIntegerExactTowardPositive
 | |
| convertToIntegerExactTowardNegative
 | |
| convertToIntegerExactTiesToAway
 | |
| convertFormat - different formats     cast and implicit conversions      <a href='#6.3.1.5'>6.3.1.5</a>, <a href='#6.5.4'>6.5.4</a>
 | |
| convertFormat - same format           canonicalize                       <a href='#7.12.11.7'>7.12.11.7</a>, <a href='#F.10.8.7'>F.10.8.7</a>
 | |
| convertFromDecimalCharacter           strtod, wcstod, scanf, wscanf ,    <a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.31.4.1.2'>7.31.4.1.2</a>,
 | |
|                                       decimal floating constants         <a href='#7.23.6.4'>7.23.6.4</a>, <a href='#7.31.2.12'>7.31.2.12</a>,
 | |
|                                                                          <a href='#F.5'>F.5</a>
 | |
| convertToDecimalCharacter             printf, wprintf , strfromd         <a href='#7.23.6.3'>7.23.6.3</a>, <a href='#7.31.2.11'>7.31.2.11</a>,
 | |
|                                                                          <a href='#7.24.1.3'>7.24.1.3</a>, <a href='#F.5'>F.5</a>
 | |
| convertFromHexCharacter            strtod, wcstod, scanf, wscanf ,   <a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.31.4.1.2'>7.31.4.1.2</a>,
 | |
|                                    hexadecimal floating constants    <a href='#7.23.6.4'>7.23.6.4</a>, <a href='#7.31.2.12'>7.31.2.12</a>,
 | |
|                                                                      <a href='#F.5'>F.5</a>
 | |
| convertToHexCharacter              printf, wprintf , strfromd        <a href='#7.23.6.3'>7.23.6.3</a>, <a href='#7.31.2.11'>7.31.2.11</a>,
 | |
|                                                                      <a href='#7.24.1.3'>7.24.1.3</a>, <a href='#F.5'>F.5</a>
 | |
| copy                                memcpy, memmove, +(x)            <a href='#7.26.2.1'>7.26.2.1</a>, <a href='#7.26.2.3'>7.26.2.3</a>
 | |
| negate                             -(x)                              <a href='#6.5.3.3'>6.5.3.3</a>
 | |
| abs                                 fabs                             <a href='#7.12.7.3'>7.12.7.3</a>, <a href='#F.10.4.3'>F.10.4.3</a>
 | |
| copySign                            copysign                         <a href='#7.12.11.1'>7.12.11.1</a>, <a href='#F.10.8.1'>F.10.8.1</a>
 | |
| compareQuietEqual                   ==                               <a href='#6.5.9'>6.5.9</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareQuietNotEqual                !=                               <a href='#6.5.9'>6.5.9</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingEqual               iseqsig                          <a href='#7.12.17.7'>7.12.17.7</a>, <a href='#F.10.14.1'>F.10.14.1</a>
 | |
| compareSignalingGreater            >                                 <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingGreaterEqual       >=                                <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingLess               <                                 <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingLessEqual          <=                                <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingNotEqual            ! iseqsig(x)                     <a href='#7.12.17.7'>7.12.17.7</a>, <a href='#F.10.14.1'>F.10.14.1</a>
 | |
| compareSignalingNotGreater          ! (x > y)                        <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingLessUnordered       ! (x >= y)                       <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingNotLess             ! (x < y)                        <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareSignalingGreaterUnordered    ! (x <= y)                       <a href='#6.5.8'>6.5.8</a>, <a href='#F.9.3'>F.9.3</a>
 | |
| compareQuietGreater                 isgreater                        <a href='#7.12.17.1'>7.12.17.1</a>
 | |
| compareQuietGreaterEqual            isgreaterequal                   <a href='#7.12.17.2'>7.12.17.2</a>
 | |
| compareQuietLess                    isless                           <a href='#7.12.17.3'>7.12.17.3</a>
 | |
| compareQuietLessEqual               islessequal                      <a href='#7.12.17.4'>7.12.17.4</a>
 | |
| compareQuietUnordered               isunordered                      <a href='#7.12.17.6'>7.12.17.6</a>
 | |
| compareQuietNotGreater              ! isgreater(x, y)                <a href='#7.12.17.1'>7.12.17.1</a>
 | |
| compareQuietLessUnordered           ! isgreaterequal(x, y)           <a href='#7.12.17.2'>7.12.17.2</a>
 | |
| compareQuietNotLess                 ! isless(x, y)                   <a href='#7.12.17.3'>7.12.17.3</a>
 | |
| compareQuietGreaterUnordered        ! islessequal(x, y)              <a href='#7.12.17.4'>7.12.17.4</a>
 | |
| compareQuietOrdered                 ! isunordered(x, y)              <a href='#7.12.17.6'>7.12.17.6</a>
 | |
| class                               fpclassify,       signbit,       <a href='#7.12.3.1'>7.12.3.1</a>,     <a href='#7.12.3.7'>7.12.3.7</a>,
 | |
|                                     issignaling                      <a href='#7.12.3.8'>7.12.3.8</a>
 | |
| isSignMinus                         signbit                          <a href='#7.12.3.7'>7.12.3.7</a>
 | |
| isNormal                            isnormal                         <a href='#7.12.3.6'>7.12.3.6</a>
 | |
| isFinite                            isfinite                         <a href='#7.12.3.3'>7.12.3.3</a>
 | |
| isZero                              iszero                           <a href='#7.12.3.10'>7.12.3.10</a>
 | |
| isSubnormal                         issubnormal                      <a href='#7.12.3.9'>7.12.3.9</a>
 | |
| isInfinite                          isinf                            <a href='#7.12.3.4'>7.12.3.4</a>
 | |
| isNaN                               isnan                            <a href='#7.12.3.5'>7.12.3.5</a>
 | |
| isSignaling                         issignaling                      <a href='#7.12.3.8'>7.12.3.8</a>
 | |
| isCanonical                         iscanonical                      <a href='#7.12.3.2'>7.12.3.2</a>
 | |
| radix                               FLT_RADIX                        <a href='#5.2.4.2.2'>5.2.4.2.2</a>
 | |
| totalOrder                          totalorder                       <a href='#F.10.12.1'>F.10.12.1</a>
 | |
| totalOrderMag                       totalordermag                    <a href='#F.10.12.2'>F.10.12.2</a>
 | |
| lowerFlags                          feclearexcept                    <a href='#7.6.4.1'>7.6.4.1</a>
 | |
| raiseFlags                          fesetexcept                      <a href='#7.6.4.4'>7.6.4.4</a>
 | |
| testFlags                           fetestexcept                     <a href='#7.6.4.7'>7.6.4.7</a>
 | |
| testSavedFlags                      fetestexceptflag                 <a href='#7.6.4.6'>7.6.4.6</a>
 | |
| restoreFlags                        fesetexceptflag                  <a href='#7.6.4.5'>7.6.4.5</a>
 | |
| saveAllFlags                        fegetexceptflag                  <a href='#7.6.4.2'>7.6.4.2</a>
 | |
| getBinaryRoundingDirection          fegetround                       <a href='#7.6.5.2'>7.6.5.2</a>
 | |
| setBinaryRoundingDirection          fesetround                       <a href='#7.6.5.5'>7.6.5.5</a>
 | |
| saveModes                           fegetmode                        <a href='#7.6.5.1'>7.6.5.1</a>
 | |
|             restoreModes                                       fesetmode                                    <a href='#7.6.5.4'>7.6.5.4</a>
 | |
|             defaultModes                                       fesetmode(FE_DFL_MODE)                       <a href='#7.6.5.4'>7.6.5.4</a>, <a href='#7.6'>7.6</a>
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.3p2'></a>
 | |
| <pre>2    The IEC 60559 requirement that certain of its operations be provided for operands of different
 | |
|      formats (of the same radix) is satisfied by C’s usual arithmetic conversions (<a href='#6.3.1.8'>6.3.1.8</a>) and function-call
 | |
|      argument conversions (<a href='#6.5.2.2'>6.5.2.2</a>). For example, the following operations take float f and double d
 | |
|      inputs and produce a long double result:
 | |
| 
 | |
|               (long double)f * d
 | |
|               powl(f, d)
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.3p3'></a>
 | |
| <pre>3    The functions fmin and fmax have been superseded by fminimum_num and fmaximum_num. The fmin
 | |
|      and fmax functions provide the minNum and maxNum operations specified in (the superseded)
 | |
|      IEC 60559:2011.
 | |
| </pre>
 | |
| <a name='F.3p4'></a>
 | |
| <pre>4    Whether C assignment (<a href='#6.5.16'>6.5.16</a>) (and conversion as if by assignment) to the same format is an
 | |
|      IEC 60559 convertFormat or copy operation<a href='#FOOTNOTE.439'><sup>[439]</sup></a> is implementation-defined, even if <fenv.h> defines
 | |
|      the macro FE_SNANS_ALWAYS_SIGNAL (<a href='#F.2.1'>F.2.1</a>). If the return expression of a return statement is
 | |
|      evaluated to the floating-point format of the return type, it is implementation-defined whether a
 | |
|      convertFormat operation is applied to the result of the return expression.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.439'>
 | |
| <pre><i><b>Footnote 439)</b> Where the source and destination formats are the same, convertFormat operations differ from copy operations in
 | |
|      that convertFormat operations raise the "invalid" floating-point exception on signaling NaN inputs and do not propagate
 | |
|      non-canonical encodings.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.3p5'></a>
 | |
| <pre>5    The unary + and - operators raises no floating-point exceptions, even if the operand is a signaling
 | |
|      NaN.
 | |
| </pre>
 | |
| <a name='F.3p6'></a>
 | |
| <pre>6    The C classification macros fpclassify, iscanonical, isfinite, isinf, isnan, isnormal,
 | |
|      issignaling, issubnormal, iszero, and signbit provide the IEC 60559 operations indicated
 | |
|      in the table above provided their arguments are in the format of their semantic type. Then these
 | |
|      macros raise no floating-point exceptions, even if an argument is a signaling NaN.
 | |
| </pre>
 | |
| <a name='F.3p7'></a>
 | |
| <pre>7    The signbit macro, providing the IEC 60559 isSignMinus operation, determines the sign of its
 | |
|      argument value as the sign bit of the value’s representation. This applies to all values, including
 | |
|      NaNs whose sign bit is not generally interpreted by IEC 60559.
 | |
| </pre>
 | |
| <a name='F.3p8'></a>
 | |
| <pre>8    The C nearbyint functions (<a href='#7.12.9.3'>7.12.9.3</a>, <a href='#F.10.6.3'>F.10.6.3</a>) provide the nearbyinteger function recommended in
 | |
|      the Appendix to (superseded) ANSI/IEEE 854.
 | |
| </pre>
 | |
| <a name='F.3p9'></a>
 | |
| <pre>9    The C nextafter (<a href='#7.12.11.3'>7.12.11.3</a>, <a href='#F.10.8.3'>F.10.8.3</a>) and nexttoward (<a href='#7.12.11.4'>7.12.11.4</a>, <a href='#F.10.8.4'>F.10.8.4</a>) functions provide the
 | |
|      nextafter function recommended in the Appendix to (superseded) IEC 60559:1989 (but with a
 | |
|      minor change to better handle signed zeros).
 | |
| </pre>
 | |
| <a name='F.3p10'></a>
 | |
| <pre>10   The macros (<a href='#7.6'>7.6</a>) FE_DOWNWARD, FE_TONEAREST, FE_TONEARESTFROMZERO, FE_TOWARDZERO, and
 | |
|      FE_UPWARD, which are used in conjunction with the fegetround and fesetround functions and the
 | |
|      FENV_ROUND pragma, represent the IEC 60559 rounding-direction attributes roundTowardNegative,
 | |
|      roundTiesToEven, roundTiesToAway, roundTowardZero, and roundTowardPositive, respectively,
 | |
|      for binary floating-point arithmetic. Support for the roundTiesToAway attribute for binary floating-
 | |
|      point arithmetic, and hence for the FE_TONEARESTFROMZERO macro, is optional.
 | |
| </pre>
 | |
| <a name='F.3p11'></a>
 | |
| <pre>11   The C fegetenv (<a href='#7.6.6.1'>7.6.6.1</a>), feholdexcept (<a href='#7.6.6.2'>7.6.6.2</a>), fesetenv (<a href='#7.6.6.3'>7.6.6.3</a>) and feupdateenv (<a href='#7.6.6.4'>7.6.6.4</a>)
 | |
|      functions provide a facility to manage the dynamic floating-point environment, comprising the
 | |
|      IEC 60559 status flags and dynamic control modes.
 | |
| </pre>
 | |
| <a name='F.3p12'></a>
 | |
| <pre>12   IEC 60559 requires operations with specified operand and result formats. Therefore, math functions
 | |
|      that are bound to IEC 60559 operations (see table above) must remove any extra range and precision
 | |
|      from arguments or results.
 | |
| </pre>
 | |
| <a name='F.3p13'></a>
 | |
| <pre>13   IEC 60559 requires operations that round their result to formats the same as and wider than the
 | |
|      operands, in addition to the operations that round their result to narrower formats (see <a href='#7.12.14'>7.12.14</a>).
 | |
|      Operators (+ , - , * , and / ) whose evaluation formats are wider than the semantic type (<a href='#5.2.4.2.2'>5.2.4.2.2</a>)
 | |
|      might not support some of the IEEE 60559 operations, because getting a result in a given format
 | |
|      might require a cast that could introduce an extra rounding error. The functions that round result to
 | |
|      narrower type (<a href='#7.12.14'>7.12.14</a>) provide the IEC 60559 operations that round result to same and wider (as
 | |
|      well as narrower) formats, in those cases where built-in operators and casts do not. For example,
 | |
|      ddivl(x, y) computes a correctly rounded double divide of float x by float y, regardless of
 | |
|      the evaluation method.
 | |
| </pre>
 | |
| <a name='F.3p14'></a>
 | |
| <pre>14   Decimal versions of the remquo library function are not provided. (The decimal remainder functions
 | |
|      provide the remainder operation defined by IEC 60559.)
 | |
| </pre>
 | |
| <a name='F.3p15'></a>
 | |
| <pre>15   The binding for the convertFormat operation applies to all conversions among IEC 60559 formats.
 | |
|      Therefore, for implementations that conform to Annex F, conversions between decimal floating types
 | |
|      and standard floating types with IEC 60559 formats are correctly rounded and raise floating-point
 | |
|      exceptions as specified in IEC 60559.
 | |
| </pre>
 | |
| <a name='F.3p16'></a>
 | |
| <pre>16   IEC 60559 specifies the convertFromHexCharacter and convertToHexCharacter operations only for
 | |
|      binary floating-point arithmetic.
 | |
| </pre>
 | |
| <a name='F.3p17'></a>
 | |
| <pre>17   The integer constant 10 provides the radix operation defined in IEC 60559 for decimal floating-point
 | |
|      arithmetic.
 | |
| </pre>
 | |
| <a name='F.3p18'></a>
 | |
| <pre>18   The fe_dec_getround (<a href='#7.6.5.3'>7.6.5.3</a>) and fe_dec_setround (<a href='#7.6.5.6'>7.6.5.6</a>) functions provide the getDeci-
 | |
|      malRoundingDirection and setDecimalRoundingDirection operations defined in IEC 60559 for
 | |
|      decimal floating-point arithmetic. The macros (<a href='#7.6'>7.6</a>) FE_DEC_DOWNWARD, FE_DEC_TONEAREST,
 | |
|      FE_DEC_TONEARESTFROMZERO, FE_DEC_TOWARDZERO, and FE_DEC_UPWARD, which are used in con-
 | |
|      junction with the fe_dec_getround and fe_dec_setround functions and the FENV_DEC_ROUND
 | |
|      pragma, represent the IEC 60559 rounding-direction attributes roundTowardNegative, roundTiesTo-
 | |
|      Even, roundTiesToAway, roundTowardZero, and roundTowardPositive, respectively, for decimal
 | |
|      floating-point arithmetic.
 | |
| </pre>
 | |
| <a name='F.3p19'></a>
 | |
| <pre>19   The llquantexpdN (<a href='#7.12.15.4'>7.12.15.4</a>) functions compute the (quantum) exponent q defined in IEC 60559
 | |
|      for decimal numbers viewed as having integer significands.
 | |
| </pre>
 | |
| <a name='F.3p20'></a>
 | |
| <pre>20   The C functions in the following table correspond to mathematical operations recommended by
 | |
|      IEC 60559. However, correct rounding, which IEC 60559 specifies for its operations, is not required
 | |
|      for the C functions in the table. <a href='#7.33.8'>7.33.8</a> (potentially) reserves cr_ prefixed names for functions fully
 | |
|      matching the IEC 60559 mathematical operations. In the table, the C functions are represented by
 | |
|      the function name without a type suffix.
 | |
| 
 | |
|            IEC 60559 operation     C function        Clause
 | |
|            exp                     exp               <a href='#7.12.6.1'>7.12.6.1</a>, <a href='#F.10.3.1'>F.10.3.1</a>
 | |
|            expm1                   expm1             <a href='#7.12.6.6'>7.12.6.6</a>, <a href='#F.10.3.6'>F.10.3.6</a>
 | |
|            exp2                    exp2              <a href='#7.12.6.4'>7.12.6.4</a>, <a href='#F.10.3.4'>F.10.3.4</a>
 | |
|            exp2m1                  exp2m1            <a href='#7.12.6.5'>7.12.6.5</a>, <a href='#F.10.3.5'>F.10.3.5</a>
 | |
|            exp10                   exp10             <a href='#7.12.6.2'>7.12.6.2</a>, <a href='#F.10.3.2'>F.10.3.2</a>
 | |
|            exp10m1                 exp10m1           <a href='#7.12.6.3'>7.12.6.3</a>, <a href='#F.10.3.3'>F.10.3.3</a>
 | |
|            log                     log               <a href='#7.12.6.11'>7.12.6.11</a>, <a href='#F.10.3.11'>F.10.3.11</a>
 | |
|            log2                    log2              <a href='#7.12.6.15'>7.12.6.15</a>, <a href='#F.10.3.15'>F.10.3.15</a>
 | |
|            log10                   log10             <a href='#7.12.6.12'>7.12.6.12</a>, <a href='#F.10.3.12'>F.10.3.12</a>
 | |
|            logp1                   log1p, logp1      <a href='#7.12.6.14'>7.12.6.14</a>, <a href='#F.10.3.14'>F.10.3.14</a>
 | |
|            log2p1                  log2p1            <a href='#7.12.6.16'>7.12.6.16</a>, <a href='#F.10.3.16'>F.10.3.16</a>
 | |
|            log10p1                 log10p1           <a href='#7.12.6.13'>7.12.6.13</a>, <a href='#F.10.3.13'>F.10.3.13</a>
 | |
|            hypot                   hypot             <a href='#7.12.7.4'>7.12.7.4</a>, <a href='#F.10.4.4'>F.10.4.4</a>
 | |
|            rSqrt                   rsqrt             <a href='#7.12.7.9'>7.12.7.9</a>, <a href='#F.10.4.9'>F.10.4.9</a>
 | |
|            compound                compoundn         <a href='#7.12.7.2'>7.12.7.2</a>, <a href='#F.10.4.2'>F.10.4.2</a>
 | |
|            rootn                   rootn             <a href='#7.12.7.8'>7.12.7.8</a>, <a href='#F.10.4.8'>F.10.4.8</a>
 | |
|            pown                    pown              <a href='#7.12.7.6'>7.12.7.6</a>, <a href='#F.10.4.6'>F.10.4.6</a>
 | |
|            pow                     pow               <a href='#7.12.7.5'>7.12.7.5</a>, <a href='#F.10.4.5'>F.10.4.5</a>
 | |
|            powr                    powr              <a href='#7.12.7.7'>7.12.7.7</a>, <a href='#F.10.4.7'>F.10.4.7</a>
 | |
|            sin                     sin               <a href='#7.12.4.6'>7.12.4.6</a>, <a href='#F.10.1.6'>F.10.1.6</a>
 | |
|                                  ... continued ...
 | |
|                                       ... continued ...
 | |
|            IEC 60559 operation           C function           Clause
 | |
|            cos                           cos                  <a href='#7.12.4.5'>7.12.4.5</a>, <a href='#F.10.1.5'>F.10.1.5</a>
 | |
|            tan                           tan                  <a href='#7.12.4.7'>7.12.4.7</a>, <a href='#F.10.1.7'>F.10.1.7</a>
 | |
|            sinPi                         sinpi                <a href='#7.12.4.13'>7.12.4.13</a>, <a href='#F.10.1.13'>F.10.1.13</a>
 | |
|            cosPi                         cospi                <a href='#7.12.4.12'>7.12.4.12</a>, <a href='#F.10.1.12'>F.10.1.12</a>
 | |
|            tanPi                         tanpi                <a href='#7.12.4.14'>7.12.4.14</a>, <a href='#F.10.1.14'>F.10.1.14</a>
 | |
|            asinPi                        asinpi               <a href='#7.12.4.9'>7.12.4.9</a>, <a href='#F.10.1.9'>F.10.1.9</a>
 | |
|            acosPi                        acospi               <a href='#7.12.4.8'>7.12.4.8</a>, <a href='#F.10.1.8'>F.10.1.8</a>
 | |
|            atanPi                        atanpi               <a href='#7.12.4.10'>7.12.4.10</a>, <a href='#F.10.1.10'>F.10.1.10</a>
 | |
|            atan2Pi                       atan2pi              <a href='#7.12.4.11'>7.12.4.11</a>, <a href='#F.10.1.11'>F.10.1.11</a>
 | |
|            asin                          asin                 <a href='#7.12.4.2'>7.12.4.2</a>, <a href='#F.10.1.2'>F.10.1.2</a>
 | |
|            acos                          acos                 <a href='#7.12.4.1'>7.12.4.1</a>, <a href='#F.10.1.1'>F.10.1.1</a>
 | |
|            atan                          atan                 <a href='#7.12.4.3'>7.12.4.3</a>, <a href='#F.10.1.3'>F.10.1.3</a>
 | |
|            atan2                         atan2                <a href='#7.12.4.4'>7.12.4.4</a>, <a href='#F.10.1.4'>F.10.1.4</a>
 | |
|            sinh                          sinh                 <a href='#7.12.5.5'>7.12.5.5</a>, <a href='#F.10.2.5'>F.10.2.5</a>
 | |
|            cosh                          cosh                 <a href='#7.12.5.4'>7.12.5.4</a>, <a href='#F.10.2.4'>F.10.2.4</a>
 | |
|            tanh                          tanh                 <a href='#7.12.5.6'>7.12.5.6</a>, <a href='#F.10.2.6'>F.10.2.6</a>
 | |
|            asinh                         asinh                <a href='#7.12.5.2'>7.12.5.2</a>, <a href='#F.10.2.2'>F.10.2.2</a>
 | |
|            acosh                         acosh                <a href='#7.12.5.1'>7.12.5.1</a>, <a href='#F.10.2.1'>F.10.2.1</a>
 | |
|            atanh                         atanh                <a href='#7.12.5.3'>7.12.5.3</a>, <a href='#F.10.2.3'>F.10.2.3</a>
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.4'></a>
 | |
| <hr>
 | |
| <h3>F.4 [Floating to integer conversion]</h3>
 | |
| <a name='F.4p1'></a>
 | |
| <pre>1   If the integer type is bool, <a href='#6.3.1.2'>6.3.1.2</a> applies and the conversion raises no floating-point exceptions if
 | |
|     the floating-point value is not a signaling NaN. Otherwise, if the floating value is infinite or NaN
 | |
|     or if the integral part of the floating value exceeds the range of the integer type, then the "invalid"
 | |
|     floating-point exception is raised and the resulting value is unspecified. Otherwise, the resulting
 | |
|     value is determined by <a href='#6.3.1.4'>6.3.1.4</a>. Conversion of an integral floating value that does not exceed the
 | |
|     range of the integer type raises no floating-point exceptions; whether conversion of a non-integral
 | |
|     floating value raises the "inexact" floating-point exception is unspecified.<a href='#FOOTNOTE.440'><sup>[440]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.440'>
 | |
| <pre><i><b>Footnote 440)</b> IEC 60559 recommends that implicit floating-to-integer conversions raise the "inexact" floating-point exception for
 | |
|     non-integer in-range values. In those cases where it matters, library functions can be used to effect such conversions with or
 | |
|     without raising the "inexact" floating- point exception. See fromfp, ufromfp, fromfpx, ufromfpx, rint, lrint, llrint, and
 | |
|     nearbyint in <math.h>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.5'></a>
 | |
| <hr>
 | |
| <h3>F.5 [Conversions between binary floating types and decimal character se-]</h3>
 | |
| <a name='F.5p1'></a>
 | |
| <pre>1 quences
 | |
|    The <float.h> header defines the macro
 | |
| 
 | |
|               CR_DECIMAL_DIG
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression suitable for use in #if preprocessing directives
 | |
|     whose value is a number such that conversions between all supported IEC 60559 binary formats and
 | |
|     character sequences with at most CR_DECIMAL_DIG significant decimal digits are correctly rounded.
 | |
|     The value of CR_DECIMAL_DIG shall be at least M + 3, where M is the maximum value of the
 | |
|     T_DECIMAL_DIG macros for IEC 60559 binary formats. If the implementation correctly rounds for
 | |
|     all numbers of significant decimal digits, then CR_DECIMAL_DIG shall have the value of the macro
 | |
|     UINTMAX_MAX.
 | |
| </pre>
 | |
| <a name='F.5p2'></a>
 | |
| <pre>2   Conversions of types with IEC 60559 binary formats to character sequences with more than
 | |
|     CR_DECIMAL_DIG significant decimal digits shall correctly round to CR_DECIMAL_DIG significant
 | |
|     digits and pad zeros on the right.
 | |
| </pre>
 | |
| <a name='F.5p3'></a>
 | |
| <pre>3   Conversions from character sequences with more than CR_DECIMAL_DIG significant decimal digits
 | |
|     to types with IEC 60559 binary formats shall correctly round to an intermediate character sequence
 | |
|     with CR_DECIMAL_DIG significant decimal digits, according to the applicable rounding direction,
 | |
|     and correctly round the intermediate result (having CR_DECIMAL_DIG significant decimal digits) to
 | |
|     the destination type. The "inexact" floating-point exception is raised (once) if either conversion
 | |
|     is inexact.<a href='#FOOTNOTE.441'><sup>[441]</sup></a> (The second conversion may raise the "overflow" or "underflow" floating-point
 | |
|     exception.)
 | |
| </pre>
 | |
| <a name='FOOTNOTE.441'>
 | |
| <pre><i><b>Footnote 441)</b> The intermediate conversion is exact only if all input digits after the first CR_DECIMAL_DIG digits are 0.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.5p4'></a>
 | |
| <pre>4   The specification in this subclause assures conversion between IEC 60559 binary format and decimal
 | |
|     character sequence follows all pertinent recommended practice. It also assures conversion from
 | |
|     IEC 60559 format to decimal character sequence with at least T_DECIMAL_DIG digits and back, using
 | |
|     to-nearest rounding, is the identity function, where T is the macro prefix for the format.
 | |
| </pre>
 | |
| <a name='F.5p5'></a>
 | |
| <pre>5   Functions such as strtod that convert character sequences to floating types honor the rounding
 | |
|     direction. Hence, if the rounding direction might be upward or downward, the implementation
 | |
|     cannot convert a minus-signed sequence by negating the converted unsigned sequence.
 | |
| </pre>
 | |
| <a name='F.5p6'></a>
 | |
| <pre>6   NOTE IEC 60559 specifies that conversion to one-digit character strings using roundTiesToEven when both choices have
 | |
|     an odd least significant digit, shall produce the value with the larger magnitude. For example, this can happen with 9.5e2
 | |
|     whose nearest neighbors are 9.e2 and <a href='#1.'>1.</a>e3, both of which have a single odd digit in the significand part.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.6'></a>
 | |
| <hr>
 | |
| <h3>F.6 [The return statement]</h3>
 | |
| <pre>If the return expression is evaluated in a floating-point format different from the return type, the
 | |
|     expression is converted as if by assignment<a href='#FOOTNOTE.442'><sup>[442]</sup></a> to the return type of the function and the resulting
 | |
|     value is returned to the caller.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.442'>
 | |
| <pre><i><b>Footnote 442)</b> Assignment removes any extra range and precision.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.7'></a>
 | |
| <hr>
 | |
| <h3>F.7 [Contracted expressions]</h3>
 | |
| <a name='F.7p1'></a>
 | |
| <pre>1   A contracted expression is correctly rounded (once) and treats infinities, NaNs, signed zeros, sub-
 | |
|     normals, and the rounding directions in a manner consistent with the basic arithmetic operations
 | |
|     covered by IEC 60559.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='F.7p2'></a>
 | |
| <pre>2   A contracted expression should raise floating-point exceptions in a manner generally consistent
 | |
|     with the basic arithmetic operations.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.8'></a>
 | |
| <hr>
 | |
| <h3>F.8 [Floating-point environment]</h3>
 | |
| <a name='F.8p1'></a>
 | |
| <pre>1   The floating-point environment defined in <fenv.h> includes the IEC 60559 floating-point exception
 | |
|     status flags and rounding-direction control modes. It may also include other floating-point status or
 | |
|     modes that the implementation provides as extensions.<a href='#FOOTNOTE.443'><sup>[443]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.443'>
 | |
| <pre><i><b>Footnote 443)</b> Dynamic rounding precision and trap enablement modes are examples of such extensions.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.8p2'></a>
 | |
| <pre>2   This annex does not include support for IEC 60559’s optional alternate exception handling. The
 | |
|     specification in this annex assumes IEC 60559 default exception handling: the flag is set, a default
 | |
|     result is delivered, and execution continues. Implementations might provide alternate exception
 | |
|     handling as an extension.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.8.1'></a>
 | |
| <hr>
 | |
| <h3>F.8.1 [Environment management]</h3>
 | |
| <a name='F.8.1p1'></a>
 | |
| <pre>1   IEC 60559 requires that floating-point operations implicitly raise floating-point exception status
 | |
|     flags, and that rounding control modes can be set explicitly to affect result values of floating-point
 | |
|     operations. These changes to the floating-point state are treated as side effects which respect
 | |
|     sequence points.<a href='#FOOTNOTE.444'><sup>[444]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.444'>
 | |
| <pre><i><b>Footnote 444)</b> If the state for the FENV_ACCESS pragma is "off", the implementation is free to assume the dynamic floating-point control
 | |
|     modes will be the default ones and the floating-point status flags will not be tested, which allows certain optimizations
 | |
|     (see <a href='#F.9'>F.9</a>).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.8.2'></a>
 | |
| <hr>
 | |
| <h3>F.8.2 [Translation]</h3>
 | |
| <a name='F.8.2p1'></a>
 | |
| <pre>1   During translation, constant rounding direction modes (<a href='#7.6.2'>7.6.2</a>) are in effect where specified. Else-
 | |
|     where, during translation the IEC 60559 default modes are in effect:
 | |
| 
 | |
|       — The rounding direction mode is rounding to nearest.
 | |
|       — The rounding precision mode (if supported) is set so that results are not shortened.
 | |
|            — Trapping or stopping (if supported) is disabled on all floating-point exceptions.
 | |
| 
 | |
|         Recommended practice
 | |
| </pre>
 | |
| <a name='F.8.2p2'></a>
 | |
| <pre>2       The implementation should produce a diagnostic message for each translation-time floating-point
 | |
|         exception, other than "inexact";<a href='#FOOTNOTE.445'><sup>[445]</sup></a> the implementation should then proceed with the translation of
 | |
|         the program.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.445'>
 | |
| <pre><i><b>Footnote 445)</b> As floating constants are converted to appropriate internal representations at translation time, their conversion is subject
 | |
|         to constant or default rounding modes and raises no execution-time floating-point exceptions (even where the state of the
 | |
|         FENV_ACCESS pragma is "on"). Library functions, for example strtod, provide execution-time conversion of numeric strings.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.8.3'></a>
 | |
| <hr>
 | |
| <h3>F.8.3 [Execution]</h3>
 | |
| <a name='F.8.3p1'></a>
 | |
| <pre>1       At program startup the dynamic floating-point environment is initialized as prescribed by IEC 60559:
 | |
| 
 | |
|            — All floating-point exception status flags are cleared.
 | |
| 
 | |
|            — The dynamic rounding direction mode is rounding to nearest.
 | |
| 
 | |
|            — The dynamic rounding precision mode (if supported) is set so that results are not shortened.
 | |
| 
 | |
|            — Trapping or stopping (if supported) is disabled on all floating-point exceptions.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.8.4'></a>
 | |
| <hr>
 | |
| <h3>F.8.4 [Constant expressions]</h3>
 | |
| <a name='F.8.4p1'></a>
 | |
| <pre>1       An arithmetic constant expression of floating type, other than one in an initializer for an object that
 | |
|         has static or thread storage duration, is evaluated (as if) during execution; thus, it is affected by any
 | |
|         operative floating-point control modes and raises floating-point exceptions as required by IEC 60559
 | |
|         (provided the state for the FENV_ACCESS pragma is "on").<a href='#FOOTNOTE.446'><sup>[446]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.446'>
 | |
| <pre><i><b>Footnote 446)</b> Where the state for the FENV_ACCESS pragma is "on", results of inexact expressions like 1.0/3.0 are affected by rounding
 | |
|         modes set at execution time, and expressions such as 0.0/0.0 and 1.0/0.0 generate execution-time floating-point exceptions.
 | |
|         The programmer can achieve the efficiency of translation-time evaluation through static initialization, such as
 | |
|                   const static double one_third = 1.0/3.0;
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.8.4p2'></a>
 | |
| <pre>2       EXAMPLE
 | |
| 
 | |
|                   #include <fenv.h>
 | |
|                   #pragma STDC FENV_ACCESS ON
 | |
|                   void f(void)
 | |
|                   {
 | |
|                         float w[] = { 0.0/0.0 }; // raises an exception
 | |
|                         static float x = 0.0/0.0; // does not raise an exception
 | |
|                         float y = 0.0/0.0;        // raises an exception
 | |
|                         double z = 0.0/0.0;       // raises an exception
 | |
|                         /* ... */
 | |
|                   }
 | |
| 
 | |
| </pre>
 | |
| <a name='F.8.4p3'></a>
 | |
| <pre>3   For the static initialization, the division is done at translation time, raising no (execution-time) floating-point exceptions. On
 | |
|     the other hand, for the three automatic initializations the invalid division occurs at execution time.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.8.5'></a>
 | |
| <hr>
 | |
| <h3>F.8.5 [Initialization]</h3>
 | |
| <a name='F.8.5p1'></a>
 | |
| <pre>1       All computation for automatic initialization is done (as if) at execution time; thus, it is affected by
 | |
|         any operative modes and raises floating-point exceptions as required by IEC 60559 (provided the
 | |
|         state for the FENV_ACCESS pragma is "on"). All computation for initialization of objects that have
 | |
|         static or thread storage duration is done (as if) at translation time.
 | |
| </pre>
 | |
| <a name='F.8.5p2'></a>
 | |
| <pre>2       EXAMPLE
 | |
| 
 | |
|                   #include <fenv.h>
 | |
|                   #pragma STDC FENV_ACCESS ON
 | |
|                   void f(void)
 | |
|               {
 | |
|                        float u[] = { <a href='#1.'>1.</a>1e75 }; // raises exceptions
 | |
|                        static float v = <a href='#1.'>1.</a>1e75; // does not raise exceptions
 | |
|                        float w = <a href='#1.'>1.</a>1e75;        // raises exceptions
 | |
|                        double x = <a href='#1.'>1.</a>1e75;       // may raise exceptions
 | |
|                        float y = <a href='#1.'>1.</a>1e75f;       // may raise exceptions
 | |
|                        long double z = <a href='#1.'>1.</a>1e75; // does not raise exceptions
 | |
|                        /* ... */
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.8.5p3'></a>
 | |
| <pre>3   The static initialization of v raises no (execution-time) floating-point exceptions because its computation is done at translation
 | |
|     time. The automatic initialization of u and w require an execution-time conversion to float of the wider value <a href='#1.'>1.</a>1e75,
 | |
|     which raises floating-point exceptions. The automatic initializations of x and y entail execution-time conversion; however, in
 | |
|     some expression evaluation methods, the conversions is not to a narrower format, in which case no floating-point exception
 | |
|     is raised.<a href='#FOOTNOTE.447'><sup>[447]</sup></a> The automatic initialization of z entails execution-time conversion, but not to a narrower format, so no
 | |
|     floating-point exception is raised. Note that the conversions of the floating constants <a href='#1.'>1.</a>1e75 and <a href='#1.'>1.</a>1e75f to their internal
 | |
|     representations occur at translation time in all cases.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.447'>
 | |
| <pre><i><b>Footnote 447)</b> Use of float_t and double_t variables increases the likelihood of translation-time computation. For example, the
 | |
|     automatic initialization
 | |
|               double_t x = <a href='#1.'>1.</a>1e75;
 | |
|     could be done at translation time, regardless of the expression evaluation method.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.8.6'></a>
 | |
| <hr>
 | |
| <h3>F.8.6 [Changing the environment]</h3>
 | |
| <a name='F.8.6p1'></a>
 | |
| <pre>1   Operations defined in <a href='#6.5'>6.5</a> and functions and macros defined for the standard libraries change
 | |
|     floating-point status flags and control modes just as indicated by their specifications (including
 | |
|     conformance to IEC 60559). They do not change flags or modes (so as to be detectable by the user) in
 | |
|     any other cases.
 | |
| </pre>
 | |
| <a name='F.8.6p2'></a>
 | |
| <pre>2   If the floating-point exceptions represented by the argument to the feraiseexcept function in
 | |
|     <fenv.h> include both "overflow" and "inexect", then "overflow" is raised before "inexact". Simi-
 | |
|     larly, if the represented exceptions include both "underflow" and "inexact", then "underflow" is
 | |
|     raised before "inexact".
 | |
| 
 | |
| </pre>
 | |
| <a name='F.9'></a>
 | |
| <hr>
 | |
| <h3>F.9 [Optimization]</h3>
 | |
| <a name='F.9p1'></a>
 | |
| <pre>1   This section identifies code transformations that might subvert IEC 60559-specified behavior, and
 | |
|     others that do not.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.9.1'></a>
 | |
| <hr>
 | |
| <h3>F.9.1 [Global transformations]</h3>
 | |
| <a name='F.9.1p1'></a>
 | |
| <pre>1   Floating-point arithmetic operations and external function calls may entail side effects which
 | |
|     optimization shall honor, at least where the state of the FENV_ACCESS pragma is "on". The flags
 | |
|     and modes in the floating-point environment may be regarded as global variables; floating-point
 | |
|     operations (+ , * , etc.) implicitly read the modes and write the flags.
 | |
| </pre>
 | |
| <a name='F.9.1p2'></a>
 | |
| <pre>2   Concern about side effects may inhibit code motion and removal of seemingly useless code. For
 | |
|     example, in
 | |
| 
 | |
|               #include <fenv.h>
 | |
|               #pragma STDC FENV_ACCESS ON
 | |
|               void f(double x)
 | |
|               {
 | |
|                     /* ... */
 | |
|                     for (i = 0; i < n; i++) x + 1;
 | |
|                     /* ... */
 | |
|               }
 | |
| 
 | |
| 
 | |
|     x+1 might raise floating-point exceptions, so cannot be removed. And since the loop body might not
 | |
|     execute (maybe 0 ≥ n), x+1 cannot be moved out of the loop. (Of course these optimizations are
 | |
|     valid if the implementation can rule out the nettlesome cases.)
 | |
| </pre>
 | |
| <a name='F.9.1p3'></a>
 | |
| <pre>3   This specification does not require support for trap handlers that maintain information about
 | |
|     the order or count of floating-point exceptions. Therefore, between function calls, floating-point
 | |
|     exceptions need not be precise: the actual order and number of occurrences of floating-point
 | |
|     exceptions (> 1) may vary from what the source code expresses. Thus, the preceding loop could be
 | |
|     treated as
 | |
| 
 | |
|               if (0     <   n) x + 1;
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.9.2'></a>
 | |
| <hr>
 | |
| <h3>F.9.2 [Expression transformations]</h3>
 | |
| <a name='F.9.2p1'></a>
 | |
| <pre>1   Valid expression transformations must preserve numerical values.
 | |
| </pre>
 | |
| <a name='F.9.2p2'></a>
 | |
| <pre>2   The equivalences noted below apply to expressions of standard floating types.
 | |
| 
 | |
|     x/2 ↔ x × 0.5               Although similar transformations involving inexact constants generally do not
 | |
|                                 yield equivalent expressions, if the constants are exact then such transforma-
 | |
|                                 tions can be made on IEC 60559 machines and others that round perfectly.
 | |
| 
 | |
|     1 × x and x/1 → x The expressions 1 × x, x/1, and x may be regarded as equivalent (on IEC 60559
 | |
|                       machines, among others).<a href='#FOOTNOTE.448'><sup>[448]</sup></a>
 | |
| 
 | |
|     x/x → 1.0                   The expressions x/x and 1.0 are not equivalent if x can be zero, infinite, or NaN.
 | |
| 
 | |
|     x − y ↔ x + (−y)            The expressions x − y, x + (−y), and (−y) + x are equivalent (on IEC 60559
 | |
|                                 machines, among others).
 | |
| 
 | |
|     x − y ↔ −(y − x)            The expressions x − y and −(y − x) are not equivalent because 1 − 1 is +0 but
 | |
|                                 −(1 − 1) is −0 (in the default rounding direction).<a href='#FOOTNOTE.449'><sup>[449]</sup></a>
 | |
| 
 | |
|     x − x → 0.0                 The expressions x − x and 0.0 are not equivalent if x is a NaN or infinite.
 | |
| 
 | |
|     0 × x → 0.0                 The expressions 0 × x and 0.0 are not equivalent if x is a NaN, infinite, or −0.
 | |
| 
 | |
|     x+0→x                       The expressions x + 0 and x are not equivalent if x is −0, because (−0) + (+0)
 | |
|                                 yields +0 (in the default rounding direction), not −0.
 | |
| 
 | |
|     x−0→x                       (+0) − (+0) yields −0 when rounding is downward (toward −∞), but +0
 | |
|                                 otherwise, and (−0)−(+0) always yields −0; so, if the state of the FENV_ACCESS
 | |
|                                 pragma is "off", promising default rounding, then the implementation can
 | |
|                                 replace x − 0 by x, even if x might be zero.
 | |
| 
 | |
|     −x ↔ 0 − x                  The expressions −x and 0−x are not equivalent if x is +0, because −(+0) yields
 | |
|                                 −0, but 0 − (+0) yields +0 (unless rounding is downward).
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.448'>
 | |
| <pre><i><b>Footnote 448)</b> Implementations might have non-required features that invalidate these and other transformations that remove arithmetic
 | |
|     operators. Examples include strict support for signaling NaNs (an optional feature) and alternate exception handling (not
 | |
|     included in this specification).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.449'>
 | |
| <pre><i><b>Footnote 449)</b> IEC 60559 prescribes a signed zero to preserve mathematical identities across certain discontinuities. Examples include:
 | |
|              1/(1/±∞) is ±∞
 | |
|     and
 | |
|              conj(csqrt(z)) is csqrt(conj(z)),
 | |
|     for complex z.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.9.2p3'></a>
 | |
| <pre>3   For expressions of decimal floating types, transformations must preserve quantum exponents, as
 | |
|     well as numerical values (<a href='#5.2.4.2.3'>5.2.4.2.3</a>).
 | |
| </pre>
 | |
| <a name='F.9.2p4'></a>
 | |
| <pre>4   EXAMPLE 1. × x → x is valid for decimal floating-point expressions x, but 1.0 × x → x is not:
 | |
| 
 | |
|             1. × 12.34      =    (+1, 1, 0) × (+1, 1234, −2)      yields   (+1, 1234, −2)      =    12.34
 | |
|             1.0 × 12.34     =    (+1, 10, −1) × (+1, 1234, −2)    yields   (+1, 12340, −3)     =    12.340
 | |
| 
 | |
|     In the second case, the factor 12.34 and the result 12.340 have different quantum exponents, demonstrating that 1.0 × x and
 | |
|     x are not equivalent expressions.
 | |
| </pre>
 | |
| <a name='F.9.3'></a>
 | |
| <hr>
 | |
| <h3>F.9.3 [Relational operators]</h3>
 | |
| <a name='F.9.3p1'></a>
 | |
| <pre>1   x ̸= x → false               The expression x ̸= x is true if x is a NaN.
 | |
|     x = x → true                 The expression x = x is false if x is a NaN.
 | |
|     x < y → isless(x, y) (and similarly for ≤, >, ≥) Though equal, these expressions are not equiv-
 | |
|                          alent because of side effects when x or y is a NaN and the state of the
 | |
|                          FENV_ACCESS pragma is "on". This transformation, which would be de-
 | |
|                          sirable if extra code were required to cause the "invalid" floating-point
 | |
|                          exception for unordered cases, could be performed provided the state of the
 | |
|                          FENV_ACCESS pragma is "off".
 | |
| 
 | |
|     The sense of relational operators shall be maintained. This includes handling unordered cases as
 | |
|     expressed by the source code.
 | |
| </pre>
 | |
| <a name='F.9.3p2'></a>
 | |
| <pre>2   EXAMPLE
 | |
| 
 | |
|               // calls g and raises "invalid" if a and b are unordered
 | |
|               if (a < b)
 | |
|                     f();
 | |
|               else
 | |
|                     g();
 | |
| 
 | |
|     is not equivalent to
 | |
| 
 | |
|               // calls f and raises "invalid" if a and b are unordered
 | |
|               if (a >= b)
 | |
|                     g();
 | |
|               else
 | |
|                     f();
 | |
| 
 | |
|     nor to
 | |
| 
 | |
|               // calls f without raising "invalid" if a and b are unordered
 | |
|               if (isgreaterequal(a,b))
 | |
|                     g();
 | |
|               else
 | |
|                     f();
 | |
| 
 | |
|     nor, unless the state of the FENV_ACCESS pragma is "off", to
 | |
| 
 | |
|               // calls g without raising "invalid" if a and b are unordered
 | |
|               if (isless(a,b))
 | |
|                     f();
 | |
|               else
 | |
|                     g();
 | |
| 
 | |
|     but is equivalent to
 | |
| 
 | |
|               if (!(a <        b))
 | |
|                     g();
 | |
|               else
 | |
|                     f();
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.9.4'></a>
 | |
| <hr>
 | |
| <h3>F.9.4 [Constant arithmetic]</h3>
 | |
| <a name='F.9.4p1'></a>
 | |
| <pre>1   The implementation shall honor floating-point exceptions raised by execution-time constant arith-
 | |
|     metic wherever the state of the FENV_ACCESS pragma is "on". (See <a href='#F.8.4'>F.8.4</a> and <a href='#F.8.5'>F.8.5</a>.) An operation
 | |
|     on constants that raises no floating-point exception can be folded during translation, except, if the
 | |
|     state of the FENV_ACCESS pragma is "on", a further check is required to assure that changing the
 | |
|     rounding direction to downward does not alter the sign of the result,<a href='#FOOTNOTE.450'><sup>[450]</sup></a> and implementations that
 | |
|      support dynamic rounding precision modes shall assure further that the result of the operation
 | |
|      raises no floating-point exception when converted to the semantic type of the operation.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.450'>
 | |
| <pre><i><b>Footnote 450)</b> 0-0 yields-0 instead of +0 just when the rounding direction is downward.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10'></a>
 | |
| <hr>
 | |
| <h3>F.10 [Mathematics <math.h> and <tgmath.h>]</h3>
 | |
| <a name='F.10p1'></a>
 | |
| <pre>1    This subclause contains specifications of <math.h> and <tgmath.h> facilities that are particularly
 | |
|      suited for IEC 60559 implementations.
 | |
| </pre>
 | |
| <a name='F.10p2'></a>
 | |
| <pre>2    The Standard C macro HUGE_VAL and its float and long double analogs, HUGE_VALF and
 | |
|      HUGE_VALL, expand to expressions whose values are positive infinities.
 | |
| </pre>
 | |
| <a name='F.10p3'></a>
 | |
| <pre>3    For each single-argument function f in <math.h> whose mathematical counterpart is symmetric
 | |
|      (even), f(-x) is f(x) for all rounding modes and for all x in the (valid) domain of the function. For
 | |
|      each single-argument function f in <math.h> whose mathematical counterpart is antisymmetric
 | |
|      (odd), f(-x) is-f(x) for the IEC 60559 rounding modes roundTiesToEven, roundTiesToAway, and
 | |
|      roundTowardZero, and for all x in the (valid) domain of the function. The atan2 and atan2pi
 | |
|      functions are odd in their first argument.
 | |
| </pre>
 | |
| <a name='F.10p4'></a>
 | |
| <pre>4    Special cases for functions in <math.h> are covered directly or indirectly by IEC 60559. The functions
 | |
|      that IEC 60559 specifies directly are identified in <a href='#F.3'>F.3</a>. The other functions in <math.h> treat infinities,
 | |
|      NaNs, signed zeros, subnormals, and (provided the state of the FENV_ACCESS pragma is "on") the
 | |
|      floating-point status flags in a manner consistent with IEC 60559 operations.
 | |
| </pre>
 | |
| <a name='F.10p5'></a>
 | |
| <pre>5    The expression math_errhandling & MATH_ERREXCEPT shall evaluate to a nonzero value.
 | |
| </pre>
 | |
| <a name='F.10p6'></a>
 | |
| <pre>6    The functions bound to operations in IEC 60559 (<a href='#F.3'>F.3</a>) are fully specified by IEC 60559, including
 | |
|      rounding behaviors and floating-point exceptions.
 | |
| </pre>
 | |
| <a name='F.10p7'></a>
 | |
| <pre>7    The "invalid" and "divide-by-zero" floating-point exceptions are raised as specified in subsequent
 | |
|      subclauses of this annex.
 | |
| </pre>
 | |
| <a name='F.10p8'></a>
 | |
| <pre>8    The "overflow" floating-point exception is raised whenever an infinity — or, because of rounding di-
 | |
|      rection, a maximal-magnitude finite number — is returned in lieu of a finite value whose magnitude
 | |
|      is too large.
 | |
| </pre>
 | |
| <a name='F.10p9'></a>
 | |
| <pre>9    The "underflow" floating-point exception is raised whenever a computed result is tiny<a href='#FOOTNOTE.451'><sup>[451]</sup></a> and the
 | |
|      returned result is inexact.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.451'>
 | |
| <pre><i><b>Footnote 451)</b> Tiny generally indicates having a magnitude in the subnormal range. See IEC 60559 for details about detecting tininess.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10p10'></a>
 | |
| <pre>10   Whether or when library functions not listed in the "Operation binding" table in <a href='#F.3'>F.3</a> raise the
 | |
|      "inexact" floating-point exception is unspecified, unless stated otherwise.
 | |
| </pre>
 | |
| <a name='F.10p11'></a>
 | |
| <pre>11   Whether or when library functions not listed in the "Operation binding" table in <a href='#F.3'>F.3</a> raise a spurious
 | |
|      "underflow" floating-point exception is not specified by this annex.<a href='#FOOTNOTE.452'><sup>[452]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.452'>
 | |
| <pre><i><b>Footnote 452)</b> It is intended that spurious "underflow" and "inexact" floating-point exceptions are raised only if avoiding them would
 | |
|      be too costly. <a href='#7.12.1'>7.12.1</a> specifies that if math_errhandling & MATH_ERREXCEPT is nonzero, then an "underflow" floating-point
 | |
|      exception shall not be raised unless an underflow range error occurs.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10p12'></a>
 | |
| <pre>12   As implied by <a href='#F.8.6'>F.8.6</a>, library functions do not raise spurious "invalid", "overflow", or "divide-by-zero"
 | |
|      floating-point exceptions (detectable by the user).
 | |
| </pre>
 | |
| <a name='F.10p13'></a>
 | |
| <pre>13   Whether the functions not listed in the "Operation binding" table in <a href='#F.3'>F.3</a> honor the rounding direction
 | |
|      mode is implementation-defined, unless explicitly specified otherwise.
 | |
| </pre>
 | |
| <a name='F.10p14'></a>
 | |
| <pre>14   Functions with a NaN argument return a NaN result and raise no floating-point exception, except
 | |
|      where explicitly stated otherwise.
 | |
| </pre>
 | |
| <a name='F.10p15'></a>
 | |
| <pre>15   The specifications in the following subclauses append to the definitions in <math.h>. For families of
 | |
|      functions, the specifications apply to all of the functions even though only the principal function
 | |
|      is shown. Unless otherwise specified, where the symbol "±" occurs in both an argument and the
 | |
|      result, the result has the same sign as the argument.
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='F.10p16'></a>
 | |
| <pre>16   IEC 60559 specifies correct rounding for the operations in the <a href='#F.3'>F.3</a> table of operations recommended
 | |
|      by IEC 60559, and thereby preserves useful mathematical properties such as symmetry, monotonicity,
 | |
|      and periodicity. The corresponding functions with (potentially) reserved cr_-prefixed names (<a href='#7.33.8'>7.33.8</a>)
 | |
|      do the same. The C functions in the table, however, are not required to be correctly rounded, but
 | |
|      implementations should still preserve as many of these useful mathematical properties as possible.
 | |
| </pre>
 | |
| <a name='F.10p17'></a>
 | |
| <pre>17   If a function with one or more NaN arguments returns a NaN result, the result should be the same
 | |
|      as one of the NaN arguments (after possible type conversion), except perhaps for the sign.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.1 [Trigonometric functions]</h3>
 | |
| <a name='F.10.1.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.1 [The acos functions]</h3>
 | |
| <a name='F.10.1.1p1'></a>
 | |
| <pre>1      — acos(1) returns +0.
 | |
|        — acos(x) returns a NaN and raises the "invalid" floating-point exception for |x| > 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.2 [The asin functions]</h3>
 | |
| <a name='F.10.1.2p1'></a>
 | |
| <pre>1      — asin(±0) returns ±0.
 | |
|        — asin(x) returns a NaN and raises the "invalid" floating-point exception for |x| > 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.3 [The atan functions]</h3>
 | |
| <a name='F.10.1.3p1'></a>
 | |
| <pre>1      — atan(±0) returns ±0.
 | |
|        — atan(±∞) returns ± π2 .
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.4 [The atan2 functions]</h3>
 | |
| <a name='F.10.1.4p1'></a>
 | |
| <pre>1      — atan2(±0, −0) returns ±π.<a href='#FOOTNOTE.453'><sup>[453]</sup></a>
 | |
|        — atan2(±0, +0) returns ±0.
 | |
|        — atan2(±0, x) returns ±π for x < 0.
 | |
|        — atan2(±0, x) returns ±0 for x > 0.
 | |
|        — atan2(y, ±0) returns − π2 for y < 0.
 | |
|        — atan2(y, ±0) returns π2 for y > 0.
 | |
|        — atan2(±y, −∞) returns ±π for finite y > 0.
 | |
|        — atan2(±y, +∞) returns ±0 for finite y > 0.
 | |
|        — atan2(±∞, x) returns ± π2 for finite x.
 | |
|        — atan2(±∞, −∞) returns ± 3π
 | |
|                                   4 .
 | |
| 
 | |
|        — atan2(±∞, +∞) returns ± π4 .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.453'>
 | |
| <pre><i><b>Footnote 453)</b> atan2(0, 0) does not raise the "invalid" floating-point exception, nor does atan2(y, 0) raise the "divide-by-zero" floating-
 | |
|      point exception.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10.1.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.5 [The cos functions]</h3>
 | |
| <a name='F.10.1.5p1'></a>
 | |
| <pre>1      — cos(±0) returns 1.
 | |
|        — cos(±∞) returns a NaN and raises the "invalid" floating-point exception.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.6'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.6 [The sin functions]</h3>
 | |
| <a name='F.10.1.6p1'></a>
 | |
| <pre>1      — sin(±0) returns ±0.
 | |
|        — sin(±∞) returns a NaN and raises the "invalid" floating-point exception.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.7'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.7 [The tan functions]</h3>
 | |
| <a name='F.10.1.7p1'></a>
 | |
| <pre>1      — tan(±0) returns ±0.
 | |
|        — tan(±∞) returns a NaN and raises the "invalid" floating-point exception.
 | |
| </pre>
 | |
| <a name='F.10.1.8'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.8 [The acospi functions]</h3>
 | |
| <a name='F.10.1.8p1'></a>
 | |
| <pre>1     — acospi(+1) returns +0.
 | |
| 
 | |
|       — acospi(x) returns a NaN and raises the "invalid" floating-point exception for |x| > 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.9'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.9 [The asinpi functions]</h3>
 | |
| <a name='F.10.1.9p1'></a>
 | |
| <pre>1     — asinpi(±0) returns ±0.
 | |
| 
 | |
|       — asinpi(x) returns a NaN and raises the "invalid" floating-point exception for |x| > 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.10'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.10 [The atanpi functions]</h3>
 | |
| <a name='F.10.1.10p1'></a>
 | |
| <pre>1     — atanpi(±0) returns ±0.
 | |
| 
 | |
|       — atanpi(±∞) returns ± 21 .
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.11'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.11 [The atan2pi functions]</h3>
 | |
| <a name='F.10.1.11p1'></a>
 | |
| <pre>1     — atan2pi(±0, −0) returns ±1.<a href='#FOOTNOTE.454'><sup>[454]</sup></a>
 | |
| 
 | |
|       — atan2pi(±0, +0) returns ±0.
 | |
| 
 | |
|       — atan2pi(±0, x) returns ±1 for x < 0.
 | |
| 
 | |
|       — atan2pi(±0, x) returns ±0 for x > 0.
 | |
| 
 | |
|       — atan2pi(y, ±0) returns − 12 for y < 0.
 | |
| 
 | |
|       — atan2pi(y, ±0) returns + 12 for y > 0.
 | |
| 
 | |
|       — atan2pi(±y, −∞) returns ±1 for finite y > 0.
 | |
| 
 | |
|       — atan2pi(±y, +∞) returns ±0 for finite y > 0.
 | |
| 
 | |
|       — atan2pi(±∞, x) returns ± 12 for finite x.
 | |
| 
 | |
|       — atan2pi(±∞, −∞) returns ± 43 .
 | |
| 
 | |
|       — atan2pi(±∞, +∞) returns ± 14 .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.454'>
 | |
| <pre><i><b>Footnote 454)</b> atan2pi(0, 0) does not raise the "invalid" floating-point exception, nor does atan2pi(y, 0) raise the "divide-by-zero"
 | |
|     floating-point exception.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10.1.12'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.12 [The cospi functions]</h3>
 | |
| <a name='F.10.1.12p1'></a>
 | |
| <pre>1     — cospi(±0) returns 1.
 | |
| 
 | |
|       — cospi(n + 12 ) returns +0, for integers n.
 | |
| 
 | |
|       — cospi(±∞) returns a NaN and raises the "invalid" floating-point exception.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.1.13'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.13 [The sinpi functions]</h3>
 | |
| <a name='F.10.1.13p1'></a>
 | |
| <pre>1     — sinpi(±0) returns ±0.
 | |
| 
 | |
|       — sinpi(±n) returns ±0, for positive integers n.
 | |
| 
 | |
|       — sinpi(±∞) returns a NaN and raises the "invalid" floating-point exception.
 | |
| </pre>
 | |
| <a name='F.10.1.14'></a>
 | |
| <hr>
 | |
| <h3>F.10.1.14 [The tanpi functions]</h3>
 | |
| <a name='F.10.1.14p1'></a>
 | |
| <pre>1     — tanpi(±0) returns ±0.
 | |
| 
 | |
|       — tanpi(n) returns +0, for positive even and negative odd integers n.
 | |
| 
 | |
|       — tanpi(n) returns −0, for positive odd and negative even integers n.
 | |
| 
 | |
|       — tanpi(n + 12 ) returns +∞ and raises the "divide-by-zero" floating-point exception, for even
 | |
|         integers n.
 | |
| 
 | |
|       — tanpi(n + 12 ) returns −∞ and raises the "divide-by-zero" floating-point exception, for odd
 | |
|         integers n.
 | |
| 
 | |
|       — tanpi(±∞) returns a NaN and raises the "invalid" floating-point exception.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.2 [Hyperbolic functions]</h3>
 | |
| <a name='F.10.2.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.2.1 [The acosh functions]</h3>
 | |
| <a name='F.10.2.1p1'></a>
 | |
| <pre>1     — acosh(1) returns +0.
 | |
| 
 | |
|       — acosh(x) returns a NaN and raises the "invalid" floating-point exception for x < 1.
 | |
| 
 | |
|       — acosh(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.2.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.2.2 [The asinh functions]</h3>
 | |
| <a name='F.10.2.2p1'></a>
 | |
| <pre>1     — asinh(±0) returns ±0.
 | |
| 
 | |
|       — asinh(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.2.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.2.3 [The atanh functions]</h3>
 | |
| <a name='F.10.2.3p1'></a>
 | |
| <pre>1     — atanh(±0) returns ±0.
 | |
| 
 | |
|       — atanh(±1) returns ±∞ and raises the "divide-by-zero" floating-point exception.
 | |
| 
 | |
|       — atanh(x) returns a NaN and raises the "invalid" floating-point exception for |x| > 1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.2.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.2.4 [The cosh functions]</h3>
 | |
| <a name='F.10.2.4p1'></a>
 | |
| <pre>1     — cosh(±0) returns 1.
 | |
| 
 | |
|       — cosh(±∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.2.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.2.5 [The sinh functions]</h3>
 | |
| <a name='F.10.2.5p1'></a>
 | |
| <pre>1     — sinh(±0) returns ±0.
 | |
| 
 | |
|       — sinh(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.2.6'></a>
 | |
| <hr>
 | |
| <h3>F.10.2.6 [The tanh functions]</h3>
 | |
| <a name='F.10.2.6p1'></a>
 | |
| <pre>1     — tanh(±0) returns ±0.
 | |
| 
 | |
|       — tanh(±∞) returns ±1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.3 [Exponential and logarithmic functions]</h3>
 | |
| <a name='F.10.3.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.1 [The exp functions]</h3>
 | |
| <a name='F.10.3.1p1'></a>
 | |
| <pre>1     — exp(±0) returns 1.
 | |
| 
 | |
|       — exp(−∞) returns +0.
 | |
| 
 | |
|       — exp(+∞) returns +∞.
 | |
| </pre>
 | |
| <a name='F.10.3.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.2 [The exp10 functions]</h3>
 | |
| <a name='F.10.3.2p1'></a>
 | |
| <pre>1      — exp10(±0) returns 1.
 | |
|       — exp10(−∞) returns +0.
 | |
|       — exp10(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.3 [The exp10m1 functions]</h3>
 | |
| <a name='F.10.3.3p1'></a>
 | |
| <pre>1      — exp10m1(±0) returns ±0.
 | |
|       — exp10m1(−∞) returns −1.
 | |
|       — exp10m1(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.4 [The exp2 functions]</h3>
 | |
| <a name='F.10.3.4p1'></a>
 | |
| <pre>1      — exp2(±0) returns 1.
 | |
|       — exp2(−∞) returns +0.
 | |
|       — exp2(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.5 [The exp2m1 functions]</h3>
 | |
| <a name='F.10.3.5p1'></a>
 | |
| <pre>1      — exp2m1(±0) returns ±0.
 | |
|       — exp2m1(−∞) returns −1.
 | |
|       — exp2m1(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.6'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.6 [The expm1 functions]</h3>
 | |
| <a name='F.10.3.6p1'></a>
 | |
| <pre>1      — expm1(±0) returns ±0.
 | |
|       — expm1(−∞) returns −1.
 | |
|       — expm1(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.7'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.7 [The frexp functions]</h3>
 | |
| <a name='F.10.3.7p1'></a>
 | |
| <pre>1      — frexp(±0, exp) returns ±0, and stores 0 in the object pointed to by exp.
 | |
|       — frexp(±∞, exp) returns ±∞, and stores an unspecified value in the object pointed to by exp.
 | |
|       — frexp(NaN, exp) stores an unspecified value in the object pointed to by exp (and returns a
 | |
|         NaN).
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.7p2'></a>
 | |
| <pre>2   frexp raises no floating-point exceptions if value is not a signaling NaN.
 | |
| </pre>
 | |
| <a name='F.10.3.7p3'></a>
 | |
| <pre>3   The returned value is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.3.7p4'></a>
 | |
| <pre>4   On a binary system, the body of the frexp function might be
 | |
| 
 | |
|             {
 | |
|                    *exp = (value == 0) ? 0: (int)(1 + logb(value));
 | |
|                    return scalbn(value, -(*exp));
 | |
|             }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.8'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.8 [The ilogb functions]</h3>
 | |
| <a name='F.10.3.8p1'></a>
 | |
| <pre>1   When the correct result is representable in the range of the return type, the returned value is exact
 | |
|     and is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.3.8p2'></a>
 | |
| <pre>2   If the correct result is outside the range of the return type, the numeric result is unspecified and the
 | |
|     "invalid" floating-point exception is raised.
 | |
| </pre>
 | |
| <a name='F.10.3.8p3'></a>
 | |
| <pre>3   ilogb(x), for x zero, infinite, or NaN, raises the "invalid" floating-point exception and returns the
 | |
|     value specified in <a href='#7.12.6.8'>7.12.6.8</a>.
 | |
| </pre>
 | |
| <a name='F.10.3.9'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.9 [The ldexp functions]</h3>
 | |
| <a name='F.10.3.9p1'></a>
 | |
| <pre>1   On a binary system, ldexp(x, exp) is equivalent to scalbn(x, exp).
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.10'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.10 [The llogb functions]</h3>
 | |
| <a name='F.10.3.10p1'></a>
 | |
| <pre>1   The llogb functions are equivalent to the ilogb functions, except that the llogb functions determine
 | |
|     a result in the long int type.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.11'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.11 [The log functions]</h3>
 | |
| <a name='F.10.3.11p1'></a>
 | |
| <pre>1     — log(±0) returns −∞ and raises the "divide-by-zero" floating-point exception.
 | |
|       — log(1) returns +0.
 | |
|       — log(x) returns a NaN and raises the "invalid" floating-point exception for x < 0.
 | |
|       — log(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.12'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.12 [The log10 functions]</h3>
 | |
| <a name='F.10.3.12p1'></a>
 | |
| <pre>1     — log10(±0) returns −∞ and raises the "divide-by-zero" floating-point exception.
 | |
|       — log10(1) returns +0.
 | |
|       — log10(x) returns a NaN and raises the "invalid" floating-point exception for x < 0.
 | |
|       — log10(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.13'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.13 [The log10p1 functions]</h3>
 | |
| <a name='F.10.3.13p1'></a>
 | |
| <pre>1     — log10p1(±0) returns ±0.
 | |
|       — log10p1(−1) returns −∞ and raises the "divide-by-zero" floating-point exception.
 | |
|       — log10p1(x) returns a NaN and raises the "invalid" floating-point exception for x < −1.
 | |
|       — log10p1(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.14'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.14 [The log1p and logp1 functions]</h3>
 | |
| <a name='F.10.3.14p1'></a>
 | |
| <pre>1     — logp1(±0) returns ±0.
 | |
|       — logp1(−1) returns −∞ and raises the "divide-by-zero" floating-point exception.
 | |
|       — logp1(x) returns a NaN and raises the "invalid" floating-point exception for x < −1.
 | |
|       — logp1(+∞) returns +∞.
 | |
| 
 | |
|     The log1p functions are equivalent to the logp1 functions.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.15'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.15 [The log2 functions]</h3>
 | |
| <a name='F.10.3.15p1'></a>
 | |
| <pre>1     — log2(±0) returns −∞ and raises the "divide-by-zero" floating-point exception.
 | |
|       — log2(1) returns +0.
 | |
|       — log2(x) returns a NaN and raises the "invalid" floating-point exception for x < 0.
 | |
|       — log2(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.16'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.16 [The log2p1 functions]</h3>
 | |
| <a name='F.10.3.16p1'></a>
 | |
| <pre>1     — log2p1(±0) returns ±0.
 | |
|       — log2p1(−1) returns −∞ and raises the "divide-by-zero" floating-point exception.
 | |
|       — log2p1(x) returns a NaN and raises the "invalid" floating-point exception for x < −1.
 | |
|       — log2p1(+∞) returns +∞.
 | |
| </pre>
 | |
| <a name='F.10.3.17'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.17 [The logb functions]</h3>
 | |
| <a name='F.10.3.17p1'></a>
 | |
| <pre>1     — logb(±0) returns −∞ and raises the "divide-by-zero" floating-point exception.
 | |
| 
 | |
|       — logb(±∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.17p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.18'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.18 [The modf functions]</h3>
 | |
| <a name='F.10.3.18p1'></a>
 | |
| <pre>1     — modf(±x, iptr) returns a result with the same sign as x.
 | |
| 
 | |
|       — modf(±∞, iptr) returns ±0 and stores ±∞ in the object pointed to by iptr.
 | |
| 
 | |
|       — modf(NaN, iptr) stores a NaN in the object pointed to by iptr (and returns a NaN).
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.18p2'></a>
 | |
| <pre>2   The returned values are exact and are independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.3.18p3'></a>
 | |
| <pre>3   modf behaves as though implemented by
 | |
| 
 | |
|                #include <math.h>
 | |
|                #include <fenv.h>
 | |
|                #pragma STDC FENV_ACCESS ON
 | |
|                double modf(double value, double *iptr)
 | |
|                {
 | |
|                      int save_round = fegetround();
 | |
|                      fesetround(FE_TOWARDZERO);
 | |
|                      *iptr = nearbyint(value);
 | |
|                      fesetround(save_round);
 | |
|                      return copysign(
 | |
|                            isinf(value) ? 0.0:
 | |
|                                  value - (*iptr), value);
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.19'></a>
 | |
| <hr>
 | |
| <h3>F.10.3.19 [The scalbn and scalbln functions]</h3>
 | |
| <a name='F.10.3.19p1'></a>
 | |
| <pre>1     — scalbn(±0, n) returns ±0.
 | |
| 
 | |
|       — scalbn(x, 0) returns x.
 | |
| 
 | |
|       — scalbn(±∞, n) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.3.19p2'></a>
 | |
| <pre>2   If the calculation does not overflow or underflow, the returned value is exact and independent of
 | |
|     the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.4 [Power and absolute value functions]</h3>
 | |
| <a name='F.10.4.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.1 [The cbrt functions]</h3>
 | |
| <a name='F.10.4.1p1'></a>
 | |
| <pre>1     — cbrt(±0) returns ±0.
 | |
| 
 | |
|       — cbrt(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.2 [The compoundn functions]</h3>
 | |
| <a name='F.10.4.2p1'></a>
 | |
| <pre>1     — compoundn(x, 0) returns 1 for x ≥ −1 or x a NaN.
 | |
| 
 | |
|       — compoundn(x, n) returns a NaN and raises the "invalid" floating-point exception for x < −1.
 | |
| 
 | |
|       — compoundn(−1, n) returns +∞ and raises the divide-by-zero floating-point exception for n < 0.
 | |
| 
 | |
|       — compoundn(−1, n) returns +0 for n > 0.
 | |
| </pre>
 | |
| <a name='F.10.4.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.3 [The fabs functions]</h3>
 | |
| <a name='F.10.4.3p1'></a>
 | |
| <pre>1   fabs(x) returns a value with the same bit representation as x, except with the sign bit set to 0
 | |
|     (positive), for all values of x (even quiet and signaling NaNs).
 | |
| </pre>
 | |
| <a name='F.10.4.3p2'></a>
 | |
| <pre>2     — fabs(±0) returns +0.
 | |
| 
 | |
|       — fabs(±∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.3p3'></a>
 | |
| <pre>3   fabs(x) raises no floating-point exceptions, even if x is a signaling NaN. The returned value is
 | |
|     independent of the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.4 [The hypot functions]</h3>
 | |
| <a name='F.10.4.4p1'></a>
 | |
| <pre>1     — hypot(x, y), hypot(y, x), and hypot(x, −y) are equivalent.
 | |
| 
 | |
|       — hypot(x, ±0) returns the absolute value of x, if x is not a NaN.
 | |
| 
 | |
|       — hypot(±∞, y) returns +∞, even if y is a NaN.
 | |
| 
 | |
|       — hypot(x, NaN) returns a NaN, if x is not ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.5 [The pow functions]</h3>
 | |
| <a name='F.10.4.5p1'></a>
 | |
| <pre>1     — pow(±0, y) returns ±∞ and raises the "divide-by-zero" floating-point exception for y an odd
 | |
|         integer < 0.
 | |
| 
 | |
|       — pow(±0, y) returns +∞ and raises the "divide-by-zero" floating-point exception for y < 0,
 | |
|         finite, and not an odd integer.
 | |
| 
 | |
|       — pow(±0, −∞) returns +∞.
 | |
| 
 | |
|       — pow(±0, y) returns ±0 for y an odd integer > 0.
 | |
| 
 | |
|       — pow(±0, y) returns +0 for y > 0 and not an odd integer.
 | |
| 
 | |
|       — pow(−1, ±∞) returns 1.
 | |
| 
 | |
|       — pow(+1, y) returns 1 for any y, even a NaN.
 | |
| 
 | |
|       — pow(x, ±0) returns 1 for any x, even a NaN.
 | |
| 
 | |
|       — pow(x, y) returns a NaN and raises the "invalid" floating-point exception for finite x < 0 and
 | |
|         finite non-integer y.
 | |
| 
 | |
|       — pow(x, −∞) returns +∞ for |x| < 1.
 | |
| 
 | |
|       — pow(x, −∞) returns +0 for |x| > 1.
 | |
| 
 | |
|       — pow(x, +∞) returns +0 for |x| < 1.
 | |
| 
 | |
|       — pow(x, +∞) returns +∞ for |x| > 1.
 | |
| 
 | |
|       — pow(−∞, y) returns −0 for y an odd integer < 0.
 | |
| 
 | |
|       — pow(−∞, y) returns +0 for y < 0 and not an odd integer.
 | |
| 
 | |
|       — pow(−∞, y) returns −∞ for y an odd integer > 0.
 | |
| 
 | |
|       — pow(−∞, y) returns +∞ for y > 0 and not an odd integer.
 | |
| 
 | |
|       — pow(+∞, y) returns +0 for y < 0.
 | |
| 
 | |
|       — pow(+∞, y) returns +∞ for y > 0.
 | |
| </pre>
 | |
| <a name='F.10.4.6'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.6 [The pown functions]</h3>
 | |
| <a name='F.10.4.6p1'></a>
 | |
| <pre>1     — pown(x, 0) returns 1 for all x not a signalling NaN.
 | |
|       — pown(±0, n) returns ±∞ and raises the "divide-by-zero" floating-point exception for odd
 | |
|         n < 0.
 | |
|       — pown(±0, n) returns +∞ and raises the "divide-by-zero" floating-point exception for even
 | |
|         n < 0.
 | |
|       — pown(±0, n) returns +0 for even n > 0.
 | |
|       — pown(±0, n) returns ±0 for odd n > 0.
 | |
|       — pown(±∞, n) is equivalent to pown(±0, −n) for n not 0, except that the "divide-by-zero"
 | |
|         floating-point exception is not raised.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.7'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.7 [The powr functions]</h3>
 | |
| <a name='F.10.4.7p1'></a>
 | |
| <pre>1     — powr(x, ±0) returns 1 for finite x > 0.
 | |
|       — powr(±0, y) returns +∞ and raises the "divide-by-zero" floating-point exception for finite
 | |
|         y < 0.
 | |
|       — powr(±0, −∞) returns +∞.
 | |
|       — powr(±0, y) returns +0 for y > 0.
 | |
|       — powr(+1, y) returns 1 for finite y.
 | |
|       — powr(+1, y)
 | |
|       — powr(x, y) returns a NaN and raises the "invalid" floating-point exception for x < 0.
 | |
|       — powr(±0, ±0) returns a NaN and raises the "invalid" floating-point exception.
 | |
|       — powr(+∞, ±0) returns a NaN and raises the "invalid" floating-point exception.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.8'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.8 [The rootn functions]</h3>
 | |
| <a name='F.10.4.8p1'></a>
 | |
| <pre>1     — rootn(±0, n) returns ±∞ and raises the "divide-by-zero" floating-point exception for odd
 | |
|         n < 0.
 | |
|       — rootn(±0, n) returns +∞ and raises the "divide-by-zero" floating-point exception for even
 | |
|         n < 0.
 | |
|       — rootn(±0, n) returns +0 for even n > 0.
 | |
|       — rootn(±0, n) returns ±0 for odd n > 0.
 | |
|       — rootn(+∞, n) returns +∞ for n > 0.
 | |
|       — rootn(−∞, n) returns −∞ for odd n > 0.
 | |
|       — rootn(−∞, n) returns a NaN and raises the "invalid" floating-point exception for even n > 0.
 | |
|       — rootn(+∞, n) returns +0 for n < 0.
 | |
|       — rootn(−∞, n) returns −0 for odd n < 0.
 | |
|       — rootn(−∞, n) returns a NaN and raises the "invalid" floating-point exception for even n < 0.
 | |
|       — rootn(x, 0) returns a NaN and raises the "invalid" floating-point exception for all x (including
 | |
|         NaN).
 | |
|       — rootn(x, n) returns a NaN and raises the "invalid" floating-point exception for x < 0 and n
 | |
|         even.
 | |
| </pre>
 | |
| <a name='F.10.4.9'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.9 [The rsqrt functions]</h3>
 | |
| <a name='F.10.4.9p1'></a>
 | |
| <pre>1     — rsqrt(±0) returns ±∞ and raises the "divide-by-zero" floating-point exception.
 | |
| 
 | |
|       — rsqrt(x) returns a NaN and raises the "invalid" floating-point exception for x < 0.
 | |
| 
 | |
|       — rsqrt(+∞) returns +0.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.10'></a>
 | |
| <hr>
 | |
| <h3>F.10.4.10 [The sqrt functions]</h3>
 | |
| <a name='F.10.4.10p1'></a>
 | |
| <pre>1     — sqrt(±0) returns ±0.
 | |
| 
 | |
|       — sqrt(+∞) returns +∞.
 | |
| 
 | |
|       — sqrt(x) returns a NaN and raises the "invalid" floating-point exception for x < 0.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.4.10p2'></a>
 | |
| <pre>2   The returned value is dependent on the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.5 [Error and gamma functions]</h3>
 | |
| <a name='F.10.5.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.5.1 [The erf functions]</h3>
 | |
| <a name='F.10.5.1p1'></a>
 | |
| <pre>1     — erf(±0) returns ±0.
 | |
| 
 | |
|       — erf(±∞) returns ±1.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.5.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.5.2 [The erfc functions]</h3>
 | |
| <a name='F.10.5.2p1'></a>
 | |
| <pre>1     — erfc(−∞) returns 2.
 | |
| 
 | |
|       — erfc(+∞) returns +0.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.5.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.5.3 [The lgamma functions]</h3>
 | |
| <a name='F.10.5.3p1'></a>
 | |
| <pre>1     — lgamma(1) returns +0.
 | |
| 
 | |
|       — lgamma(2) returns +0.
 | |
| 
 | |
|       — lgamma(x) returns +∞ and raises the "divide-by-zero" floating-point exception for x a negative
 | |
|         integer or zero.
 | |
| 
 | |
|       — lgamma(−∞) returns +∞.
 | |
| 
 | |
|       — lgamma(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.5.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.5.4 [The tgamma functions]</h3>
 | |
| <a name='F.10.5.4p1'></a>
 | |
| <pre>1     — tgamma(±0) returns ±∞ and raises the "divide-by-zero" floating-point exception.
 | |
| 
 | |
|       — tgamma(x) returns a NaN and raises the "invalid" floating-point exception for x a negative
 | |
|         integer.
 | |
| 
 | |
|       — tgamma(−∞) returns a NaN and raises the "invalid" floating-point exception.
 | |
| 
 | |
|       — tgamma(+∞) returns +∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6'></a>
 | |
| <hr>
 | |
| <h3>F.10.6 [Nearest integer functions]</h3>
 | |
| <a name='F.10.6.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.1 [The ceil functions]</h3>
 | |
| <a name='F.10.6.1p1'></a>
 | |
| <pre>1     — ceil(±0) returns ±0.
 | |
| 
 | |
|       — ceil(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.1p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.6.1p3'></a>
 | |
| <pre>3   The double version of ceil behaves as though implemented by
 | |
|                #include <math.h>
 | |
|                #include <fenv.h>
 | |
|                #pragma STDC FENV_ACCESS ON
 | |
|                double ceil(double x)
 | |
|                {
 | |
|                      double result;
 | |
|                      int save_round = fegetround();
 | |
|                      fesetround(FE_UPWARD);
 | |
|                      result = nearbyint(x);
 | |
|                      fesetround(save_round);
 | |
|                      return result;
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.2 [The floor functions]</h3>
 | |
| <a name='F.10.6.2p1'></a>
 | |
| <pre>1     — floor(±0) returns ±0.
 | |
|       — floor(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.2p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.6.2p3'></a>
 | |
| <pre>3   See the sample implementation for ceil in <a href='#F.10.6.1'>F.10.6.1</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.3 [The nearbyint functions]</h3>
 | |
| <a name='F.10.6.3p1'></a>
 | |
| <pre>1   The nearbyint functions use IEC 60559 rounding according to the current rounding direction. They
 | |
|     do not raise the "inexact" floating-point exception if the result differs in value from the argument.
 | |
| 
 | |
|       — nearbyint(±0) returns ±0 (for all rounding directions).
 | |
|       — nearbyint(±∞) returns ±∞ (for all rounding directions).
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.4 [The rint functions]</h3>
 | |
| <a name='F.10.6.4p1'></a>
 | |
| <pre>1   The rint functions differ from the nearbyint functions only in that they do raise the "inexact"
 | |
|     floating-point exception if the result differs in value from the argument.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.5 [The lrint and llrint functions]</h3>
 | |
| <a name='F.10.6.5p1'></a>
 | |
| <pre>1   The lrint and llrint functions provide floating-to-integer conversion as prescribed by IEC 60559.
 | |
|     They round according to the current rounding direction. If the rounded value is outside the range of
 | |
|     the return type, the numeric result is unspecified and the "invalid" floating-point exception is raised.
 | |
|     When they raise no other floating-point exception and the result differs from the argument, they
 | |
|     raise the "inexact" floating-point exception.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.6'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.6 [The round functions]</h3>
 | |
| <a name='F.10.6.6p1'></a>
 | |
| <pre>1     — round(±0) returns ±0.
 | |
|       — round(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.6p2'></a>
 | |
| <pre>2   The returned value is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.6.6p3'></a>
 | |
| <pre>3   The double version of round behaves as though implemented by<a href='#FOOTNOTE.455'><sup>[455]</sup></a>
 | |
| 
 | |
|                #include <math.h>
 | |
|                #include <fenv.h>
 | |
|                  #pragma STDC FENV_ACCESS ON
 | |
|                  double round(double x)
 | |
|                  {
 | |
|                      double result;
 | |
|                      fenv_t save_env;
 | |
|                    feholdexcept(&save_env);
 | |
|                    result = rint(x);
 | |
|                    if (fetestexcept(FE_INEXACT)) {
 | |
|                        fesetround(FE_TOWARDZERO);
 | |
|                        result = rint(copysign(0.5 + fabs(x), x));
 | |
|                        feclearexcept(FE_INEXACT);
 | |
|                    }
 | |
|                    feupdateenv(&save_env);
 | |
|                    return result;
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.455'>
 | |
| <pre><i><b>Footnote 455)</b> This code does not handle signaling NaNs as required of implementations that define FE_SNANS_ALWAYS_SIGNAL.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10.6.7'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.7 [The lround and llround functions]</h3>
 | |
| <a name='F.10.6.7p1'></a>
 | |
| <pre>1   The lround and llround functions differ from the lrint and llrint functions with the default
 | |
|     rounding direction just in that the lround and llround functions round halfway cases away from
 | |
|     zero and need not raise the "inexact" floating-point exception for non-integer arguments that round
 | |
|     to within the range of the return type.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.8'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.8 [The roundeven functions]</h3>
 | |
| <a name='F.10.6.8p1'></a>
 | |
| <pre>1
 | |
| 
 | |
|       — roundeven(±0) returns ±0.
 | |
|       — roundeven(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.8p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.6.8p3'></a>
 | |
| <pre>3   See the sample implementation for ceil in <a href='#F.10.6.1'>F.10.6.1</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.9'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.9 [The trunc functions]</h3>
 | |
| <a name='F.10.6.9p1'></a>
 | |
| <pre>1   The trunc functions use IEC 60559 rounding toward zero (regardless of the current rounding
 | |
|     direction).
 | |
| 
 | |
|       — trunc(±0) returns ±0.
 | |
|       — trunc(±∞) returns ±∞.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.9p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.10'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.10 [The fromfp and ufromfp functions]</h3>
 | |
| <a name='F.10.6.10p1'></a>
 | |
| <pre>1   The fromfp and ufromfp functions raise the "invalid" floating-point exception and return a NaN
 | |
|     if the argument width is zero or if the floating-point argument x is infinite or NaN or rounds to an
 | |
|     integral value that is outside the range determined by the argument width (see <a href='#7.12.9.10'>7.12.9.10</a>).
 | |
| </pre>
 | |
| <a name='F.10.6.10p2'></a>
 | |
| <pre>2   These functions do not raise the "inexact" floating-point exception.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.6.11'></a>
 | |
| <hr>
 | |
| <h3>F.10.6.11 [The fromfpx and ufromfpx functions]</h3>
 | |
| <a name='F.10.6.11p1'></a>
 | |
| <pre>1   The fromfpx and ufromfpx functions raise the "invalid" floating-point exception and return a NaN
 | |
|     if the argument width is zero or if the floating-point argument x is infinite or NaN or rounds to an
 | |
|     integral value that is outside the range determined by the argument width (see <a href='#7.12.9.11'>7.12.9.11</a>).
 | |
| </pre>
 | |
| <a name='F.10.6.11p2'></a>
 | |
| <pre>2   These functions raise the "inexact" floating-point exception if a valid result differs in value from the
 | |
|     floating-point argument x.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.7'></a>
 | |
| <hr>
 | |
| <h3>F.10.7 [Remainder functions]</h3>
 | |
| <a name='F.10.7.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.7.1 [The fmod functions]</h3>
 | |
| <a name='F.10.7.1p1'></a>
 | |
| <pre>1     — fmod(±0, y) returns ±0 for y not zero.
 | |
|       — fmod(x, y) returns a NaN and raises the "invalid" floating-point exception for x infinite or y
 | |
|         zero (and neither is a NaN).
 | |
|       — fmod(x, ±∞) returns x for x finite x.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.7.1p2'></a>
 | |
| <pre>2   When subnormal results are supported, the returned value is exact and is independent of the current
 | |
|     rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.7.1p3'></a>
 | |
| <pre>3   The double version of fmod behaves as though implemented by
 | |
| 
 | |
|                #include <math.h>
 | |
|                #include <fenv.h>
 | |
|                #pragma STDC FENV_ACCESS ON
 | |
|                double fmod(double x, double y)
 | |
|                {
 | |
|                      double result;
 | |
|                      result = remainder(fabs(x), (y = fabs(y)));
 | |
|                      if (signbit(result)) result += y;
 | |
|                      return copysign(result, x);
 | |
|                }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.7.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.7.2 [The remainder functions]</h3>
 | |
| <a name='F.10.7.2p1'></a>
 | |
| <pre>1     — remainder(±0, y) returns ±0 for y not zero.
 | |
| 
 | |
|       — remainder(x, y) returns a NaN and raises the "invalid" floating-point exception for x infinite
 | |
|         or y zero (and neither is a NaN).
 | |
| 
 | |
|       — remainder(x, ±∞) returns x for finite x.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.7.2p2'></a>
 | |
| <pre>2   When subnormal results are supported, the returned value is exact and is independent of the current
 | |
|     rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.7.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.7.3 [The remquo functions]</h3>
 | |
| <a name='F.10.7.3p1'></a>
 | |
| <pre>1   The remquo functions follow the specifications for the remainder functions.
 | |
| </pre>
 | |
| <a name='F.10.7.3p2'></a>
 | |
| <pre>2   If a NaN is returned, the value stored in the object pointed to by quo is unspecified.
 | |
| </pre>
 | |
| <a name='F.10.7.3p3'></a>
 | |
| <pre>3   When subnormal results are supported, the returned value is exact and is independent of the current
 | |
|     rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8'></a>
 | |
| <hr>
 | |
| <h3>F.10.8 [Manipulation functions]</h3>
 | |
| <a name='F.10.8.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.8.1 [The copysign functions]</h3>
 | |
| <a name='F.10.8.1p1'></a>
 | |
| <pre>1   copysign(x, y) returns a value with the bit representation of x , except with the sign bit of y, for all
 | |
|     values x and y (even quiet and signaling NaNs).
 | |
| </pre>
 | |
| <a name='F.10.8.1p2'></a>
 | |
| <pre>2   copysign(x, y) raises no floating-point exceptions, even if x or y is a signaling NaN. The returned
 | |
|     value is independent of the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.8.2 [The nan functions]</h3>
 | |
| <a name='F.10.8.2p1'></a>
 | |
| <pre>1   All IEC 60559 implementations support quiet NaNs, in all floating formats.
 | |
| </pre>
 | |
| <a name='F.10.8.2p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.8.3 [The nextafter functions]</h3>
 | |
| <a name='F.10.8.3p1'></a>
 | |
| <pre>1     — nextafter(x, y) raises the "overflow" and "inexact" floating-point exceptions for x finite and
 | |
|         the function value infinite.
 | |
| 
 | |
|       — nextafter(x, y) raises the "underflow" and "inexact" floating-point exceptions for the func-
 | |
|         tion value subnormal or zero and x ̸= y.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.3p2'></a>
 | |
| <pre>2   Even though underflow or overflow can occur, the returned value is independent of the current
 | |
|     rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.8.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.8.4 [The nexttoward functions]</h3>
 | |
| <a name='F.10.8.4p1'></a>
 | |
| <pre>1   No additional requirements beyond those on nextafter.
 | |
| </pre>
 | |
| <a name='F.10.8.4p2'></a>
 | |
| <pre>2   Even though underflow or overflow can occur, the returned value is independent of the current
 | |
|     rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.8.5 [The nextup functions]</h3>
 | |
| <a name='F.10.8.5p1'></a>
 | |
| <pre>1       — nextup(+∞) returns +∞.
 | |
| 
 | |
|       — nextup(−∞) returns the largest-magnitude negative finite number in the type of the function.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.5p2'></a>
 | |
| <pre>2   nextup(x) raises no floating-point exceptions if x is not a signaling NaN. The returned value is
 | |
|     independent of the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.6'></a>
 | |
| <hr>
 | |
| <h3>F.10.8.6 [The nextdown functions]</h3>
 | |
| <a name='F.10.8.6p1'></a>
 | |
| <pre>1       — nextdown(−∞) returns −∞.
 | |
| 
 | |
|       — nextdown(+∞) returns the largest-magnitude positive finite number in the type of the func-
 | |
|         tion.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.6p2'></a>
 | |
| <pre>2   nextdown(x) raises no floating-point exceptions if x is not a signaling NaN. The returned value is
 | |
|     independent of the current rounding direction mode.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.8.7'></a>
 | |
| <hr>
 | |
| <h3>F.10.8.7 [The canonicalize functions]</h3>
 | |
| <a name='F.10.8.7p1'></a>
 | |
| <pre>1   The canonicalize functions produce<a href='#FOOTNOTE.456'><sup>[456]</sup></a> the canonical version of the representation in the object
 | |
|     pointed to by the argument x. If the input *x is a signaling NaN, the "invalid" floating-point
 | |
|     exception is raised and a (canonical) quiet NaN (which should be the canonical version of that
 | |
|     signaling NaN made quiet) is produced. For quiet NaN, infinity, and finite inputs, the functions
 | |
|     raise no floating-point exceptions.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.456'>
 | |
| <pre><i><b>Footnote 456)</b> As if *x * 1e0 were computed. Note also that this implementation does not handle signaling NaNs as required of
 | |
|     implementations that define FE_SNANS_ALWAYS_SIGNAL.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10.9'></a>
 | |
| <hr>
 | |
| <h3>F.10.9 [Maximum, minimum, and positive difference functions]</h3>
 | |
| <a name='F.10.9.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.9.1 [The fdim functions]</h3>
 | |
| <a name='F.10.9.1p1'></a>
 | |
| <pre>1   No additional requirements.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.9.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.9.2 [The fmax functions]</h3>
 | |
| <a name='F.10.9.2p1'></a>
 | |
| <pre>1   If just one argument is a NaN, the fmax functions return the other argument (if both arguments are
 | |
|     NaNs, the functions return a NaN).
 | |
| </pre>
 | |
| <a name='F.10.9.2p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.9.2p3'></a>
 | |
| <pre>3   The body of the fmax function might be<a href='#FOOTNOTE.457'><sup>[457]</sup></a>
 | |
| 
 | |
|                {
 | |
|                        double r = (isgreaterequal(x, y) || isnan(y)) ? x : y;
 | |
|                        (void) canonicalize(&r, &r);
 | |
|                        return r;
 | |
|                }
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.457'>
 | |
| <pre><i><b>Footnote 457)</b> Ideally, fmax would be sensitive to the sign of zero, for example fmax(−0.0, +0.0) would return +0; however, implemen-
 | |
|     tation in software might be impractical.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='F.10.9.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.9.3 [The fmin functions]</h3>
 | |
| <a name='F.10.9.3p1'></a>
 | |
| <pre>1   The fmin functions are analogous to the fmax functions (see <a href='#F.10.9.2'>F.10.9.2</a>).
 | |
| </pre>
 | |
| <a name='F.10.9.3p2'></a>
 | |
| <pre>2   The returned value is exact and is independent of the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.9.4'></a>
 | |
| <hr>
 | |
| <h3>F.10.9.4 [The fmaximum, fminimum, fmaximum_mag, and fminimum_mag functions]</h3>
 | |
| <a name='F.10.9.4p1'></a>
 | |
| <pre>1   These functions treat NaNs like other functions in <math.h> (see <a href='#F.10'>F.10</a>). They differ from the cor-
 | |
|     responding fmaximum_num, fminimum_num, fmaximum_mag_num, and fminimum_mag_num functions
 | |
|     only in their treatment of NaNs.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.9.5'></a>
 | |
| <hr>
 | |
| <h3>F.10.9.5 [The fmaximum_num, fminimum_num, fmaximum_mag_num, and fminimum_mag_num func-]</h3>
 | |
| <a name='F.10.9.5p1'></a>
 | |
| <pre>1 tions
 | |
|    These functions return the number if one argument is a number and the other is a quiet or signaling
 | |
|     NaN. If both arguments are NaNs, a quiet NaN is returned. If an argument is a signaling NaN, the
 | |
|     "invalid" floating-point exception is raised (even though the function returns the number when the
 | |
|     other argument is a number).
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.10'></a>
 | |
| <hr>
 | |
| <h3>F.10.10 [Fused multiply-add]</h3>
 | |
| <a name='F.10.10.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.10.1 [The fma functions]</h3>
 | |
| <a name='F.10.10.1p1'></a>
 | |
| <pre>1     — fma(x, y, z) computes xy + z, correctly rounded once.
 | |
|       — fma(x, y, z) returns a NaN and optionally raises the "invalid" floating-point exception if one
 | |
|         of x and y is infinite, the other is zero, and z is a NaN.
 | |
|       — fma(x, y, z) returns a NaN and raises the "invalid" floating-point exception if one of x and y is
 | |
|         infinite, the other is zero, and z is not a NaN.
 | |
|       — fma(x, y, z) returns a NaN and raises the "invalid" floating-point exception if x times y is an
 | |
|         exact infinity and z is also an infinity but with the opposite sign.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.11'></a>
 | |
| <hr>
 | |
| <h3>F.10.11 [Functions that round result to narrower type]</h3>
 | |
| <a name='F.10.11p1'></a>
 | |
| <pre>1   The functions that round their result to narrower type (<a href='#7.12.14'>7.12.14</a>) are fully specified in IEC 60559. The
 | |
|     returned value is dependent on the current rounding direction mode.
 | |
| </pre>
 | |
| <a name='F.10.11p2'></a>
 | |
| <pre>2   These functions treat zero and infinite arguments like the corresponding operation or function: + ,- ,
 | |
|     * , / , fma, or sqrt.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.12'></a>
 | |
| <hr>
 | |
| <h3>F.10.12 [Total order functions]</h3>
 | |
| <a name='F.10.12p1'></a>
 | |
| <pre>1   This subclause specifies the total order functions required by IEC 60559.
 | |
| </pre>
 | |
| <a name='F.10.12p2'></a>
 | |
| <pre>2   NOTE These functions are specified only in Annex F because they depend on details of IEC 60559 formats that might not be
 | |
|     supported if __STDC_IEC_60559_BFP__ is not defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.12.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.12.1 [The totalorder functions]</h3>
 | |
| <a name='F.10.12.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #define __STDC_WANT_IEC_60559_EXT__
 | |
|                #include <math.h>
 | |
|                #ifdef __STDC_IEC_60559_BFP__
 | |
|                int totalorder(const double *x, const double *y);
 | |
|                int totalorderf(const float *x, const float *y);
 | |
|                int totalorderl(const long double *x, const long double *y);
 | |
|                #endif
 | |
|                #ifdef __STDC_IEC_60559_DFP__
 | |
|                int totalorderd32(const _Decimal32 *x, const _Decimal32 *y);
 | |
|                int totalorderd64(const _Decimal64 *x, const _Decimal64 *y);
 | |
|                int totalorderd128(const _Decimal128 *x, const _Decimal128 *y);
 | |
|                #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='F.10.12.1p2'></a>
 | |
| <pre>2   The totalorder functions determine whether the total order relationship, defined by IEC 60559, is
 | |
|     true for the ordered pair of *x , *y . These functions are fully specified in IEC 60559. These functions
 | |
|     are independent of the current rounding direction mode and raise no floating-point exceptions, even
 | |
|     if *x or *y is a signaling NaN.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='F.10.12.1p3'></a>
 | |
| <pre>3   The totalorder functions return nonzero if and only if the total order relation is true for the ordered
 | |
|     pair of *x , *y .
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.12.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.12.2 [The totalordermag functions]</h3>
 | |
| <a name='F.10.12.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_IEC_60559_EXT__
 | |
|               #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_BFP__
 | |
|               int totalordermag(const double *x, const double *y);
 | |
|               int totalordermagf(const float *x, const float *y);
 | |
|               int totalordermagl(const long double *x, const long double *y);
 | |
|               #endif
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               int totalordermagd32(const _Decimal32 *x, const _Decimal32 *y);
 | |
|               int totalordermagd64(const _Decimal64 *x, const _Decimal64 *y);
 | |
|               int totalordermagd128(const _Decimal128 *x, const _Decimal128 *y);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='F.10.12.2p2'></a>
 | |
| <pre>2   The totalordermag functions determine whether the total order relationship, defined by IEC 60559,
 | |
|     is true for the ordered pair of the magnitudes of *x , *y . These functions are fully specified in
 | |
|     IEC 60559. These functions are independent of the current rounding direction mode and raise no
 | |
|     floating-point exceptions, even if *x or *y is a signaling NaN.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='F.10.12.2p3'></a>
 | |
| <pre>3   The totalordermag functions return nonzero if and only if the total order relation is true for the
 | |
|     ordered pair of the magnitudes of *x , *y .
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.13'></a>
 | |
| <hr>
 | |
| <h3>F.10.13 [Payload functions]</h3>
 | |
| <a name='F.10.13p1'></a>
 | |
| <pre>1   IEC 60559 defines the payload to be information contained in a quiet or signaling NaN. The payload
 | |
|     is intended for implementation-defined diagnostic information about the NaN, such as where or
 | |
|     how the NaN was created. The implementation interprets the payload as a nonnegative integer
 | |
|     suitable for use with the functions in this subclause, which get and set payloads. The implementation
 | |
|     may restrict which payloads are admissible for the user to set.
 | |
| </pre>
 | |
| <a name='F.10.13p2'></a>
 | |
| <pre>2   NOTE These functions are specified only in Annex F because they depend on details of IEC 60559 formats that might not be
 | |
|     supported if __STDC_IEC_60559_BFP__ is not defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.13.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.13.1 [The getpayload functions]</h3>
 | |
| <a name='F.10.13.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_IEC_60559_EXT__
 | |
|               #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_BFP__
 | |
|               double getpayload(const double *x);
 | |
|               float getpayloadf(const float *x);
 | |
|               long double getpayloadl(const long double *x);
 | |
|               #endif
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               _Decimal32 getpayloadd32(const _Decimal32 *x);
 | |
|               _Decimal64 getpayloadd64(const _Decimal64 *x);
 | |
|               _Decimal128 getpayloadd128(const _Decimal128 *x);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='F.10.13.1p2'></a>
 | |
| <pre>2   The getpayload functions extract the payload of a quiet or signaling NaN input and return it as a
 | |
|     positive-signed floating-point integer. If *x is not a NaN, the return result is −1. These functions
 | |
|     raise no floating-point exceptions, even if *x is a signaling NaN.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='F.10.13.1p3'></a>
 | |
| <pre>3   The getpayload functions return the payload of the NaN input as a positive-signed floating-point
 | |
|     integer.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.13.2'></a>
 | |
| <hr>
 | |
| <h3>F.10.13.2 [The setpayload functions]</h3>
 | |
| <a name='F.10.13.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_IEC_60559_EXT__
 | |
|               #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_BFP__
 | |
|               int setpayload(double *res, double pl);
 | |
|               int setpayloadf(float *res, float pl);
 | |
|               int setpayloadl(long double *res, long double pl);
 | |
|               #endif
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               int setpayloadd32(_Decimal32 *res, _Decimal32 pl);
 | |
|               int setpayloadd64(_Decimal64 *res, _Decimal64 pl);
 | |
|               int setpayloadd128(_Decimal128 *res, _Decimal128 pl);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='F.10.13.2p2'></a>
 | |
| <pre>2   The setpayload functions create a quiet NaN with the payload specified by pl and a zero sign bit
 | |
|     and store that NaN in the object pointed to by *res . If pl is not a floating-point integer representing
 | |
|     an admissible payload, *res is set to +0.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='F.10.13.2p3'></a>
 | |
| <pre>3   If the setpayload functions stored the specified NaN, they return a zero value, otherwise a nonzero
 | |
|     value (and *res is set to +0).
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.13.3'></a>
 | |
| <hr>
 | |
| <h3>F.10.13.3 [The setpayloadsig functions]</h3>
 | |
| <a name='F.10.13.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_IEC_60559_EXT__
 | |
|               #include <math.h>
 | |
|               #ifdef __STDC_IEC_60559_BFP__
 | |
|               int setpayloadsig(double *res, double pl);
 | |
|               int setpayloadsigf(float *res, float pl);
 | |
|               int setpayloadsigl(long double *res, long double pl);
 | |
|               #endif
 | |
|               #ifdef __STDC_IEC_60559_DFP__
 | |
|               int setpayloadsigd32(_Decimal32 *res, _Decimal32 pl);
 | |
|               int setpayloadsigd64(_Decimal64 *res, _Decimal64 pl);
 | |
|               int setpayloadsigd128(_Decimal128 *res, _Decimal128 pl);
 | |
|               #endif
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='F.10.13.3p2'></a>
 | |
| <pre>2   The setpayloadsig functions create a signaling NaN with the payload specified by pl and a zero
 | |
|     sign bit and store that NaN in the object pointed to by *res . If pl is not a floating-point integer
 | |
|     representing an admissible payload, *res is set to +0.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='F.10.13.3p3'></a>
 | |
| <pre>3   If the setpayloadsig functions stored the specified NaN, they return a zero value, otherwise a
 | |
|     nonzero value (and *res is set to +0).
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.14'></a>
 | |
| <hr>
 | |
| <h3>F.10.14 [Comparison macros]</h3>
 | |
| <a name='F.10.14p1'></a>
 | |
| <pre>1   Relational operators and their corresponding comparison macros (<a href='#7.12.17'>7.12.17</a>) produce equivalent result
 | |
|     values, even if argument values are represented in wider formats. Thus, comparison macro argu-
 | |
|     ments represented in formats wider than their semantic types are not converted to the semantic types,
 | |
|     unless the wide evaluation method converts operands of relational operators to their semantic types.
 | |
|     The standard wide evaluation methods characterized by FLT_EVAL_METHOD and DEC_EVAL_METHOD
 | |
|     equal to 1 or 2 (<a href='#5.2.4.2.2'>5.2.4.2.2</a>, <a href='#5.2.4.2.3'>5.2.4.2.3</a>), do not convert operands of relational operators to their semantic
 | |
|     types.
 | |
| 
 | |
| </pre>
 | |
| <a name='F.10.14.1'></a>
 | |
| <hr>
 | |
| <h3>F.10.14.1 [The iseqsig macro]</h3>
 | |
| <a name='F.10.14.1p1'></a>
 | |
| <pre>1   The equality operator == and the iseqsig macro produce equivalent results, except that the iseqsig
 | |
|     macro raises the "invalid" floating-point exception if an argument is a NaN.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.'></a>
 | |
| <hr>
 | |
| <h3>G. [Annex G (normative) IEC 60559-compatible complex arithmetic]</h3>
 | |
| <a name='G.1'></a>
 | |
| <hr>
 | |
| <h3>G.1 [Introduction]</h3>
 | |
| <a name='G.1p1'></a>
 | |
| <pre>1   This annex supplements Annex F to specify complex arithmetic for compatibility with IEC 60559
 | |
|     real floating-point arithmetic. An implementation that defines __STDC_IEC_60559_COMPLEX__ or
 | |
|     __STDC_IEC_559_COMPLEX__ shall conform to the specifications in this annex.<a href='#FOOTNOTE.458'><sup>[458]</sup></a>
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.458'>
 | |
| <pre><i><b>Footnote 458)</b> Implementations that do not define __STDC_IEC_60559_COMPLEX__ or __STDC_IEC_559_COMPLEX__ are not required
 | |
|     to conform to these specifications. The use of __STDC_IEC_559_COMPLEX__ for this purpose is obsolescent and should be
 | |
|     avoided in new code.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='G.2'></a>
 | |
| <hr>
 | |
| <h3>G.2 [Types]</h3>
 | |
| <a name='G.2p1'></a>
 | |
| <pre>1   There is a new keyword _Imaginary , which is used to specify imaginary types. It is used as a type
 | |
|     specifier within declaration specifiers in the same way as _Complex is (thus, _Imaginary float is a
 | |
|     valid type name).
 | |
| </pre>
 | |
| <a name='G.2p2'></a>
 | |
| <pre>2   There are three imaginary types, designated as float _Imaginary, double _Imaginary, and
 | |
|     long double _Imaginary . The imaginary types (along with the real floating and complex types)
 | |
|     are floating types.
 | |
| </pre>
 | |
| <a name='G.2p3'></a>
 | |
| <pre>3   For imaginary types, the corresponding real type is given by deleting the keyword _Imaginary
 | |
|     from the type name.
 | |
| </pre>
 | |
| <a name='G.2p4'></a>
 | |
| <pre>4   Each imaginary type has the same representation and alignment requirements as the corresponding
 | |
|     real type. The value of an object of imaginary type is the value of the real representation times the
 | |
|     imaginary unit.
 | |
| </pre>
 | |
| <a name='G.2p5'></a>
 | |
| <pre>5   The imaginary type domain comprises the imaginary types.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.3'></a>
 | |
| <hr>
 | |
| <h3>G.3 [Conventions]</h3>
 | |
| <a name='G.3p1'></a>
 | |
| <pre>1   A complex or imaginary value with at least one infinite part is regarded as an infinity (even if its
 | |
|     other part is a quiet NaN). A complex or imaginary value is a finite number if each of its parts is a
 | |
|     finite number (neither infinite nor NaN). A complex or imaginary value is a zero if each of its parts is
 | |
|     a zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.4'></a>
 | |
| <hr>
 | |
| <h3>G.4 [Conversions]</h3>
 | |
| <a name='G.4.1'></a>
 | |
| <hr>
 | |
| <h3>G.4.1 [Imaginary types]</h3>
 | |
| <a name='G.4.1p1'></a>
 | |
| <pre>1   Conversions among imaginary types follow rules analogous to those for real floating types.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.4.2'></a>
 | |
| <hr>
 | |
| <h3>G.4.2 [Real and imaginary]</h3>
 | |
| <a name='G.4.2p1'></a>
 | |
| <pre>1   When a value of imaginary type is converted to a real type other than bool,<a href='#FOOTNOTE.459'><sup>[459]</sup></a> the result is a positive
 | |
|     zero.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.459'>
 | |
| <pre><i><b>Footnote 459)</b> See <a href='#6.3.1.2'>6.3.1.2</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='G.4.2p2'></a>
 | |
| <pre>2   When a value of real type is converted to an imaginary type, the result is a positive imaginary zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.4.3'></a>
 | |
| <hr>
 | |
| <h3>G.4.3 [Imaginary and complex]</h3>
 | |
| <a name='G.4.3p1'></a>
 | |
| <pre>1   When a value of imaginary type is converted to a complex type, the real part of the complex result
 | |
|     value is a positive zero and the imaginary part of the complex result value is determined by the
 | |
|     conversion rules for the corresponding real types.
 | |
| </pre>
 | |
| <a name='G.4.3p2'></a>
 | |
| <pre>2   When a value of complex type is converted to an imaginary type, the real part of the complex value
 | |
|     is discarded and the value of the imaginary part is converted according to the conversion rules for
 | |
|     the corresponding real types.
 | |
| </pre>
 | |
| <a name='G.5'></a>
 | |
| <hr>
 | |
| <h3>G.5 [Binary operators]</h3>
 | |
| <a name='G.5p1'></a>
 | |
| <pre>1   The following subclauses supplement <a href='#6.5'>6.5</a> in order to specify the type of the result for an operation
 | |
|     with an imaginary operand.
 | |
| </pre>
 | |
| <a name='G.5p2'></a>
 | |
| <pre>2   For most operand types, the value of the result of a binary operator with an imaginary or complex
 | |
|     operand is completely determined, with reference to real arithmetic, by the usual mathematical
 | |
|     formula. For some operand types, the usual mathematical formula is problematic because of its
 | |
|     treatment of infinities and because of undue overflow or underflow; in these cases the result satisfies
 | |
|     certain properties (specified in <a href='#G.5.1'>G.5.1</a>), but is not completely determined.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.5.1'></a>
 | |
| <hr>
 | |
| <h3>G.5.1 [Multiplicative operators]</h3>
 | |
| <a name='G.5.1p1'></a>
 | |
| <pre>1 Semantics
 | |
|    If one operand has real type and the other operand has imaginary type, then the result has imaginary
 | |
|     type. If both operands have imaginary type, then the result has real type. (If either operand has
 | |
|     complex type, then the result has complex type.)
 | |
| </pre>
 | |
| <a name='G.5.1p2'></a>
 | |
| <pre>2   If the operands are not both complex, then the result and floating-point exception behavior of the *
 | |
|     operator is defined by the usual mathematical formula:
 | |
|            *                  u                    iv                     u + iv
 | |
|            x                 xu                  i(xv)                 (xu) + i(xv)
 | |
|            iy              i(yu)                (−y)v                ((−y)v) + i(yu)
 | |
|            x + iy       (xu) + i(yu)        ((−y)v) + i(xv)
 | |
| </pre>
 | |
| <a name='G.5.1p3'></a>
 | |
| <pre>3   If the second operand is not complex, then the result and floating-point exception behavior of the /
 | |
|     operator is defined by the usual mathematical formula:
 | |
|            /                   u                       iv
 | |
|            x                 x/u                   i((−x)/v)
 | |
|            iy               i(y/u)                    y/v
 | |
|            x + iy       (x/u) + i(y/u)         (y/v) + i((−x)/v)
 | |
| </pre>
 | |
| <a name='G.5.1p4'></a>
 | |
| <pre>4   The * and / operators satisfy the following infinity properties for all real, imaginary, and complex
 | |
|     operands:<a href='#FOOTNOTE.460'><sup>[460]</sup></a>
 | |
| 
 | |
|        — if one operand is an infinity and the other operand is a nonzero finite number or an infinity,
 | |
|          then the result of the * operator is an infinity;
 | |
| 
 | |
|        — if the first operand is an infinity and the second operand is a finite number, then the result of
 | |
|          the / operator is an infinity;
 | |
| 
 | |
|        — if the first operand is a finite number and the second operand is an infinity, then the result of
 | |
|          the / operator is a zero;
 | |
| 
 | |
|        — if the first operand is a nonzero finite number or an infinity and the second operand is a zero,
 | |
|          then the result of the / operator is an infinity.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.460'>
 | |
| <pre><i><b>Footnote 460)</b> These properties are already implied for those cases covered in the tables, but are required for all cases (at least where the
 | |
|     state for CX_LIMITED_RANGE is "off").
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='G.5.1p5'></a>
 | |
| <pre>5   If both operands of the * operator are complex or if the second operand of the / operator is complex,
 | |
|     the operator raises floating-point exceptions if appropriate for the calculation of the parts of the
 | |
|     result, and may raise spurious floating-point exceptions.
 | |
| </pre>
 | |
| <a name='G.5.1p6'></a>
 | |
| <pre>6   EXAMPLE 1 Multiplication of double _Complex operands could be implemented as follows. Note that the imaginary unit
 | |
|     I has imaginary type (see <a href='#G.6'>G.6</a>).
 | |
| 
 | |
|                #include <math.h>
 | |
|                #include <complex.h>
 | |
| 
 | |
|                /* Multiply z * w ...*/
 | |
|                double complex _Cmultd(double complex z, double complex w)
 | |
|                   {
 | |
|                            #pragma STDC FP_CONTRACT OFF
 | |
|                            double a, b, c, d, ac, bd, ad, bc, x, y;
 | |
|                            a = creal(z); b = cimag(z);
 | |
|                            c = creal(w); d = cimag(w);
 | |
|                            ac = a * c;    bd = b * d;
 | |
|                            ad = a * d;    bc = b * c;
 | |
|                            x = ac - bd; y = ad + bc;
 | |
|                            if (isnan(x) && isnan(y)) {
 | |
|                                  /* Recover infinities that computed as NaN+iNaN ... */
 | |
|                                  int recalc = 0;
 | |
|                                  if (isinf(a) || isinf(b)) { // z is infinite
 | |
|                                        /* "Box" the infinity and change NaNs in the other factor to 0 */
 | |
|                                        a = copysign(isinf(a) ? 1.0: 0.0, a);
 | |
|                                        b = copysign(isinf(b) ? 1.0: 0.0, b);
 | |
|                                        if (isnan(c)) c = copysign(0.0, c);
 | |
|                                        if (isnan(d)) d = copysign(0.0, d);
 | |
|                                        recalc = 1;
 | |
|                                  }
 | |
|                                  if (isinf(c) || isinf(d)) { // w is infinite
 | |
|                                        /* "Box" the infinity and change NaNs in the other factor to 0 */
 | |
|                                        c = copysign(isinf(c) ? 1.0: 0.0, c);
 | |
|                                        d = copysign(isinf(d) ? 1.0: 0.0, d);
 | |
|                                        if (isnan(a)) a = copysign(0.0, a);
 | |
|                                        if (isnan(b)) b = copysign(0.0, b);
 | |
|                                        recalc = 1;
 | |
|                                  }
 | |
|                                  if (!recalc && (isinf(ac) || isinf(bd) ||
 | |
|                                                    isinf(ad) || isinf(bc))) {
 | |
|                                        /* Recover infinities from overflow by changing NaNs to 0 ... */
 | |
|                                        if (isnan(a)) a = copysign(0.0, a);
 | |
|                                        if (isnan(b)) b = copysign(0.0, b);
 | |
|                                        if (isnan(c)) c = copysign(0.0, c);
 | |
|                                        if (isnan(d)) d = copysign(0.0, d);
 | |
|                                        recalc = 1;
 | |
|                                  }
 | |
|                                  if (recalc) {
 | |
|                                        x = INFINITY * (a * c - b * d);
 | |
|                                        y = INFINITY * (a * d + b * c);
 | |
|                                  }
 | |
|                            }
 | |
|                            return x + I * y;
 | |
|                   }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='G.5.1p7'></a>
 | |
| <pre>7   This implementation achieves the required treatment of infinities at the cost of only one isnan test in ordinary (finite) cases.
 | |
|     It is less than ideal in that undue overflow and underflow could occur.
 | |
| </pre>
 | |
| <a name='G.5.1p8'></a>
 | |
| <pre>8       EXAMPLE 2 Division of two double _Complex operands could be implemented as follows.
 | |
| 
 | |
|                   #include <math.h>
 | |
|                   #include <complex.h>
 | |
| 
 | |
|                   /* Divide z / w ... */
 | |
|                   double complex _Cdivd(double complex z, double complex w)
 | |
|                   {
 | |
|                         #pragma STDC FP_CONTRACT OFF
 | |
|                         double a, b, c, d, logbw, denom, x, y;
 | |
|                         int ilogbw = 0;
 | |
|                         a = creal(z); b = cimag(z);
 | |
|                         c = creal(w); d = cimag(w);
 | |
|                         logbw = logb(fmaximum_num(fabs(c), fabs(d)));
 | |
|                         if (isfinite(logbw)) {
 | |
|                                ilogbw = (int)logbw;
 | |
|                                c = scalbn(c, -ilogbw); d = scalbn(d, -ilogbw);
 | |
|                       }
 | |
|                       denom = c * c + d * d;
 | |
|                       x = scalbn((a * c + b * d) / denom, -ilogbw);
 | |
|                       y = scalbn((b * c - a * d) / denom, -ilogbw);
 | |
| 
 | |
|                       /* Recover infinities and zeros that computed as NaN+iNaN;           */
 | |
|                       /* the only cases are nonzero/zero, infinite/finite, and finite/infinite, ...                          */
 | |
| 
 | |
|                       if (isnan(x) && isnan(y)) {
 | |
|                             if ((denom == 0.0) &&
 | |
|                                   (!isnan(a) || !isnan(b))) {
 | |
|                                   x = copysign(INFINITY, c) * a;
 | |
|                                   y = copysign(INFINITY, c) * b;
 | |
|                             }
 | |
|                             else if ((isinf(a) || isinf(b)) &&
 | |
|                                   isfinite(c) && isfinite(d)) {
 | |
|                                   a = copysign(isinf(a) ? 1.0: 0.0, a);
 | |
|                                   b = copysign(isinf(b) ? 1.0: 0.0, b);
 | |
|                                   x = INFINITY * (a * c + b * d);
 | |
|                                   y = INFINITY * (b * c - a * d);
 | |
|                             }
 | |
|                             else if ((logbw == INFINITY) &&
 | |
|                                   isfinite(a) && isfinite(b)) {
 | |
|                                   c = copysign(isinf(c) ? 1.0: 0.0, c);
 | |
|                                   d = copysign(isinf(d) ? 1.0: 0.0, d);
 | |
|                                   x = 0.0 * (a * c + b * d);
 | |
|                                   y = 0.0 * (b * c - a * d);
 | |
|                             }
 | |
|                       }
 | |
|                       return x + I * y;
 | |
|               }
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='G.5.1p9'></a>
 | |
| <pre>9   Scaling the denominator alleviates the main overflow and underflow problem, which is more serious than for multiplication.
 | |
|     In the spirit of the multiplication example above, this code does not defend against overflow and underflow in the calculation
 | |
|     of the numerator. Scaling with the scalbn function, instead of with division, provides better roundoff characteristics.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.5.2'></a>
 | |
| <hr>
 | |
| <h3>G.5.2 [Additive operators]</h3>
 | |
| <a name='G.5.2p1'></a>
 | |
| <pre>1 Semantics
 | |
|    If both operands have imaginary type, then the result has imaginary type. (If one operand has real
 | |
|     type and the other operand has imaginary type, or if either operand has complex type, then the
 | |
|     result has complex type.)
 | |
| </pre>
 | |
| <a name='G.5.2p2'></a>
 | |
| <pre>2   In all cases the result and floating-point exception behavior of a + or- operator is defined by the
 | |
|     usual mathematical formula:
 | |
|            + or-         u              iv           u + iv
 | |
|            x            x±u           x±iv         (x±u)±iv
 | |
|            iy          ±u + iy       i(y±v)       ±u + i(y±v)
 | |
|            x + iy    (x±u) + iy x + i(y±v) (x±u) + i(y±v)
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6'></a>
 | |
| <hr>
 | |
| <h3>G.6 [Complex arithmetic <complex.h>]</h3>
 | |
| <a name='G.6p1'></a>
 | |
| <pre>1   The macros
 | |
| 
 | |
|               imaginary
 | |
| 
 | |
| 
 | |
|     and
 | |
|               _Imaginary_I
 | |
|      are defined, respectively, as _Imaginary and a constant expression of type float _Imaginary with
 | |
|      the value of the imaginary unit. The macro
 | |
| 
 | |
|                I
 | |
| 
 | |
| 
 | |
|      is defined to be _Imaginary_I (not _Complex_I as stated in <a href='#7.3'>7.3</a>). Notwithstanding the provisions of
 | |
|      <a href='#7.1.3'>7.1.3</a>, a program may undefine and then perhaps redefine the macro imaginary.
 | |
| </pre>
 | |
| <a name='G.6p2'></a>
 | |
| <pre>2    This subclause contains specifications for the <complex.h> functions that are particularly suited to
 | |
|      IEC 60559 implementations. For families of functions, the specifications apply to all of the functions
 | |
|      even though only the principal function is shown. Unless otherwise specified, where the symbol "±"
 | |
|      occurs in both an argument and the result, the result has the same sign as the argument.
 | |
| </pre>
 | |
| <a name='G.6p3'></a>
 | |
| <pre>3    The functions are continuous onto both√sides of their branch cuts, taking into account the sign of
 | |
|      zero. For example, csqrt(−2±i0) = ±i 2.
 | |
| </pre>
 | |
| <a name='G.6p4'></a>
 | |
| <pre>4    Since complex and imaginary values are composed of real values, each function may be regarded as
 | |
|      computing real values from real values. Except as noted, the functions treat real infinities, NaNs,
 | |
|      signed zeros, subnormals, and the floating-point exception flags in a manner consistent with the
 | |
|      specifications for real functions in <a href='#F.10'>F.10</a>.<a href='#FOOTNOTE.461'><sup>[461]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.461'>
 | |
| <pre><i><b>Footnote 461)</b> As noted in <a href='#G.3'>G.3</a>, a complex value with at least one infinite part is regarded as an infinity even if its other part is a quiet
 | |
|      NaN.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='G.6p5'></a>
 | |
| <pre>5    In subsequent subclauses in <a href='#G.6'>G.6</a> "NaN" refers to a quiet NaN. The behavior of signaling NaNs
 | |
|      in Annex G is implementation-defined.
 | |
| </pre>
 | |
| <a name='G.6p6'></a>
 | |
| <pre>6    The functions cimag, conj, cproj, and creal are fully specified for all implementations, including
 | |
|      IEC 60559 ones, in <a href='#7.3.9'>7.3.9</a>. These functions raise no floating-point exceptions.
 | |
| </pre>
 | |
| <a name='G.6p7'></a>
 | |
| <pre>7    Each of the functions cabs and carg is specified by a formula in terms of a real function (whose
 | |
|      special cases are covered in Annex F):
 | |
| 
 | |
|                cabs(x + iy ) = hypot(x, y )
 | |
|                carg(x + iy ) = atan2(y , x)
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6p8'></a>
 | |
| <pre>8    Each of the functions casin, catan, ccos, csin, and ctan is specified implicitly by a formula in
 | |
|      terms of other complex functions (whose special cases are specified below):
 | |
| 
 | |
|                casin(z ) = −i casinh(iz )
 | |
|                catan(z ) = −i catanh(iz )
 | |
|                ccos(z ) = ccosh(iz )
 | |
|                csin(z ) = −i csinh(iz )
 | |
|                ctan(z ) = −i ctanh(iz )
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6p9'></a>
 | |
| <pre>9    For the other functions, the following subclauses specify behavior for special cases, including
 | |
|      treatment of the "invalid" and "divide-by-zero" floating-point exceptions. For families of functions,
 | |
|      the specifications apply to all of the functions even though only the principal function is shown. For
 | |
|      a function f satisfying f (conj(z)) = conj(f (z)), the specifications for the upper half-plane imply the
 | |
|      specifications for the lower half-plane; if the function f is also either even, f (−z) = f (z), or odd,
 | |
|      f (−z) = −f (z), then the specifications for the first quadrant imply the specifications for the other
 | |
|      three quadrants.
 | |
| </pre>
 | |
| <a name='G.6p10'></a>
 | |
| <pre>10   In the following subclauses, cis(y) is defined as cos(y) + i sin(y).
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6.1'></a>
 | |
| <hr>
 | |
| <h3>G.6.1 [Trigonometric functions]</h3>
 | |
| <a name='G.6.1.1'></a>
 | |
| <hr>
 | |
| <h3>G.6.1.1 [The cacos functions]</h3>
 | |
| <a name='G.6.1.1p1'></a>
 | |
| <pre>1      — cacos(conj(z)) = conj(cacos(z)).
 | |
| 
 | |
|        — cacos(±0 + i0) returns π2 − i0.
 | |
| 
 | |
|        — cacos(±0 + iNaN) returns π2 + iNaN.
 | |
|       — cacos(x + i∞) returns π2 − i∞, for finite x.
 | |
| 
 | |
|       — cacos(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for nonzero finite x.
 | |
| 
 | |
|       — cacos(−∞ + iy) returns pi − i∞, for positive-signed finite y.
 | |
| 
 | |
|       — cacos(+∞ + iy) returns +0 − i∞, for positive-signed finite y.
 | |
| 
 | |
|       — cacos(−∞ + i∞) returns 3 π4 − i∞.
 | |
| 
 | |
|       — cacos(+∞ + i∞) returns π4 − i∞.
 | |
| 
 | |
|       — cacos(±∞ + iNaN) returns NaN±i∞ (where the sign of the imaginary part of the result is
 | |
|         unspecified).
 | |
| 
 | |
|       — cacos(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite y.
 | |
| 
 | |
|       — cacos(NaN + i∞) returns NaN − i∞.
 | |
| 
 | |
|       — cacos(NaN + iNaN) returns NaN + iNaN.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6.2'></a>
 | |
| <hr>
 | |
| <h3>G.6.2 [Hyperbolic functions]</h3>
 | |
| <a name='G.6.2.1'></a>
 | |
| <hr>
 | |
| <h3>G.6.2.1 [The cacosh functions]</h3>
 | |
| <a name='G.6.2.1p1'></a>
 | |
| <pre>1       — cacosh(conj(z)) = conj(cacosh(z)).
 | |
| 
 | |
|       — cacosh(±0 + i0) returns +0 + iπ
 | |
|                                       2 .
 | |
| 
 | |
| 
 | |
|       — cacosh(x + i∞) returns +∞ + iπ
 | |
|                                      2 , for finite x.
 | |
| 
 | |
| 
 | |
|       — cacosh(0 + iNaN) returns NaN± iπ
 | |
|                                        2 (where the sign of the imaginary part of the result is
 | |
|         unspecified).
 | |
| 
 | |
|       — cacosh(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite nonzero x.
 | |
| 
 | |
|       — cacosh(−∞ + iy) returns +∞ + iπ, for positive-signed finite y.
 | |
| 
 | |
|       — cacosh(+∞ + iy) returns +∞ + i0, for positive-signed finite y.
 | |
| 
 | |
|       — cacosh(−∞ + i∞) returns +∞ + i 3π
 | |
|                                         4 .
 | |
| 
 | |
| 
 | |
|       — cacosh(+∞ + i∞) returns +∞ + iπ
 | |
|                                       4 .
 | |
| 
 | |
| 
 | |
|       — cacosh(±∞ + iNaN) returns +∞ + iNaN.
 | |
| 
 | |
|       — cacosh(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite y.
 | |
| 
 | |
|       — cacosh(NaN + i∞) returns +∞ + iNaN.
 | |
| 
 | |
|       — cacosh(NaN + iNaN) returns NaN + iNaN.
 | |
| </pre>
 | |
| <a name='G.6.2.2'></a>
 | |
| <hr>
 | |
| <h3>G.6.2.2 [The casinh functions]</h3>
 | |
| <a name='G.6.2.2p1'></a>
 | |
| <pre>1     — casinh(conj(z)) = conj(casinh(z)). and casinh is odd.
 | |
| 
 | |
|       — casinh(+0 + i0) returns 0 + i0.
 | |
| 
 | |
|       — casinh(x + i∞) returns +∞ + iπ
 | |
|                                      2 for positive-signed finite x.
 | |
| 
 | |
|       — casinh(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite x.
 | |
| 
 | |
|       — casinh(+∞ + iy) returns +∞ + i0 for positive-signed finite y.
 | |
| 
 | |
|       — casinh(+∞ + i∞) returns +∞ + iπ
 | |
|                                       4 .
 | |
| 
 | |
|       — casinh(+∞ + iNaN) returns +∞ + iNaN.
 | |
| 
 | |
|       — casinh(NaN + i0) returns NaN + i0.
 | |
| 
 | |
|       — casinh(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite nonzero y.
 | |
| 
 | |
|       — casinh(NaN + i∞) returns ±∞ + iNaN (where the sign of the real part of the result is
 | |
|         unspecified).
 | |
| 
 | |
|       — casinh(NaN + iNaN) returns NaN + iNaN.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6.2.3'></a>
 | |
| <hr>
 | |
| <h3>G.6.2.3 [The catanh functions]</h3>
 | |
| <a name='G.6.2.3p1'></a>
 | |
| <pre>1     — catanh(conj(z)) = conj(catanh(z)). and catanh is odd.
 | |
| 
 | |
|       — catanh(+0 + i0) returns +0 + i0.
 | |
| 
 | |
|       — catanh(+0 + iNaN) returns +0 + iNaN.
 | |
| 
 | |
|       — catanh(+1 + i0) returns +∞ + i0 and raises the "divide-by-zero" floating-point exception.
 | |
| 
 | |
|       — catanh(x + i∞) returns +0 + iπ
 | |
|                                      2 , for finite positive-signed x.
 | |
| 
 | |
|       — catanh(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for nonzero finite x.
 | |
| 
 | |
|       — catanh(+∞ + iy) returns +0 + iπ
 | |
|                                       2 , for finite positive-signed y.
 | |
| 
 | |
|       — catanh(+∞ + i∞) returns +0 + iπ
 | |
|                                       2 .
 | |
| 
 | |
|       — catanh(+∞ + iNaN) returns +0 + iNaN.
 | |
| 
 | |
|       — catanh(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite y.
 | |
| 
 | |
|       — catanh(NaN + i∞) returns ±0 + iπ
 | |
|                                        2 (where the sign of the real part of the result is unspecified).
 | |
| 
 | |
|       — catanh(NaN + iNaN) returns NaN + iNaN.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6.2.4'></a>
 | |
| <hr>
 | |
| <h3>G.6.2.4 [The ccosh functions]</h3>
 | |
| <a name='G.6.2.4p1'></a>
 | |
| <pre>1     — ccosh(conj(z)) = conj(ccosh(z)) and ccosh is even.
 | |
| 
 | |
|       — ccosh(+0 + i0) returns 1 + i0.
 | |
| 
 | |
|       — ccosh(+0 + i∞) returns NaN±i0 (where the sign of the imaginary part of the result is unspec-
 | |
|         ified) and raises the "invalid" floating-point exception.
 | |
| 
 | |
|       — ccosh(+0 + iNaN) returns NaN±i0 (where the sign of the imaginary part of the result is
 | |
|         unspecified).
 | |
|       — ccosh(x + i∞) returns NaN + iNaN and raises the "invalid" floating-point exception, for
 | |
|         finite nonzero x.
 | |
| 
 | |
|       — ccosh(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite nonzero x.
 | |
| 
 | |
|       — ccosh(+∞ + i0) returns +∞ + i0.
 | |
| 
 | |
|       — ccosh(+∞ + iy) returns +∞ cis(y), for finite nonzero y.
 | |
| 
 | |
|       — ccosh(+∞+i∞) returns ±∞+iNaN (where the sign of the real part of the result is unspecified)
 | |
|         and raises the "invalid" floating-point exception.
 | |
| 
 | |
|       — ccosh(+∞ + iNaN) returns +∞ + iNaN.
 | |
| 
 | |
|       — ccosh(NaN + i0) returns NaN±i0 (where the sign of the imaginary part of the result is
 | |
|         unspecified).
 | |
| 
 | |
|       — ccosh(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for all nonzero numbers y.
 | |
| 
 | |
|       — ccosh(NaN + iNaN) returns NaN + iNaN.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6.2.5'></a>
 | |
| <hr>
 | |
| <h3>G.6.2.5 [The csinh functions]</h3>
 | |
| <a name='G.6.2.5p1'></a>
 | |
| <pre>1     — csinh(conj(z)) = conj(csinh(z)). and csinh is odd.
 | |
| 
 | |
|       — csinh(+0 + i0) returns +0 + i0.
 | |
| 
 | |
|       — csinh(+0 + i∞) returns ±0 + iNaN (where the sign of the real part of the result is unspecified)
 | |
|         and raises the "invalid" floating-point exception.
 | |
| 
 | |
|       — csinh(+0 + iNaN) returns ±0 + iNaN (where the sign of the real part of the result is unspeci-
 | |
|         fied).
 | |
| 
 | |
|       — csinh(x + i∞) returns NaN + iNaN and raises the "invalid" floating-point exception, for
 | |
|         positive finite x.
 | |
| 
 | |
|       — csinh(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite nonzero x.
 | |
| 
 | |
|       — csinh(+∞ + i0) returns +∞ + i0.
 | |
| 
 | |
|       — csinh(+∞ + iy) returns +∞ cis(y), for positive finite y.
 | |
| 
 | |
|       — csinh(+∞+i∞) returns ±∞+iNaN (where the sign of the real part of the result is unspecified)
 | |
|         and raises the "invalid" floating-point exception.
 | |
| 
 | |
|       — csinh(+∞ + iNaN) returns ±∞ + iNaN (where the sign of the real part of the result is
 | |
|         unspecified).
 | |
| 
 | |
|       — csinh(NaN + i0) returns NaN + i0.
 | |
| 
 | |
|       — csinh(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for all nonzero numbers y.
 | |
| 
 | |
|       — csinh(NaN + iNaN) returns NaN + iNaN.
 | |
| </pre>
 | |
| <a name='G.6.2.6'></a>
 | |
| <hr>
 | |
| <h3>G.6.2.6 [The ctanh functions]</h3>
 | |
| <a name='G.6.2.6p1'></a>
 | |
| <pre>1     — ctanh(conj(z)) = conj(ctanh(z)) and ctanh is odd.
 | |
|       — ctanh(+0 + i0) returns +0 + i0.
 | |
|       — ctanh(0 + i∞) returns 0 + iNaN and raises the "invalid" floating-point exception.
 | |
|       — ctanh(x + i∞) returns NaN + iNaN and raises the "invalid" floating-point exception, for
 | |
|         finite nonzero x.
 | |
|       — ctanh(0 + iNaN) returns 0 + iNaN.
 | |
|       — ctanh(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite nonzero x.
 | |
|       — ctanh(+∞ + iy) returns 1 + i0sin(2y), for positive-signed finite y.
 | |
|       — ctanh(+∞ + i∞) returns 1±i0 (where the sign of the imaginary part of the result is unspeci-
 | |
|         fied).
 | |
|       — ctanh(+∞ + iNaN) returns 1±i0 (where the sign of the imaginary part of the result is unspec-
 | |
|         ified).
 | |
|       — ctanh(NaN + i0) returns NaN + i0.
 | |
|       — ctanh(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for all nonzero numbers y.
 | |
|       — ctanh(NaN + iNaN) returns NaN + iNaN.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6.3'></a>
 | |
| <hr>
 | |
| <h3>G.6.3 [Exponential and logarithmic functions]</h3>
 | |
| <a name='G.6.3.1'></a>
 | |
| <hr>
 | |
| <h3>G.6.3.1 [The cexp functions]</h3>
 | |
| <a name='G.6.3.1p1'></a>
 | |
| <pre>1     — cexp(conj(z)) = conj(cexp(z)).
 | |
|       — cexp(±0 + i0) returns 1 + i0.
 | |
|       — cexp(x + i∞) returns NaN + iNaN and raises the "invalid" floating-point exception, for finite
 | |
|         x.
 | |
|       — cexp(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point excep-
 | |
|         tion, for finite x.
 | |
|       — cexp(+∞ + i0) returns +∞ + i0.
 | |
|       — cexp(−∞ + iy) returns +0 cis(y), for finite y.
 | |
|       — cexp(+∞ + iy) returns +∞ cis(y), for finite nonzero y.
 | |
|       — cexp(−∞ + i∞) returns ±0±i0 (where the signs of the real and imaginary parts of the result
 | |
|         are unspecified).
 | |
|       — cexp(+∞ + i∞) returns ±∞ + iNaN and raises the "invalid" floating-point exception (where
 | |
|         the sign of the real part of the result is unspecified).
 | |
|       — cexp(−∞ + iNaN) returns ±0±i0 (where the signs of the real and imaginary parts of the result
 | |
|         are unspecified).
 | |
|       — cexp(+∞ + iNaN) returns ±∞ + iNaN (where the sign of the real part of the result is unspec-
 | |
|         ified).
 | |
|       — cexp(NaN + i0) returns NaN + i0.
 | |
|       — cexp(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point excep-
 | |
|         tion, for all nonzero numbers y.
 | |
|       — cexp(NaN + iNaN) returns NaN + iNaN.
 | |
| </pre>
 | |
| <a name='G.6.3.2'></a>
 | |
| <hr>
 | |
| <h3>G.6.3.2 [The clog functions]</h3>
 | |
| <a name='G.6.3.2p1'></a>
 | |
| <pre>1     — clog(conj(z)) = conj(clog(z)).
 | |
| 
 | |
|       — clog(−0 + i0) returns −∞ + iπ and raises the "divide-by-zero" floating-point exception.
 | |
| 
 | |
|       — clog(+0 + i0) returns −∞ + i0 and raises the "divide-by-zero" floating-point exception.
 | |
| 
 | |
|       — clog(x + i∞) returns +∞ + iπ
 | |
|                                    2 , for finite x.
 | |
| 
 | |
|       — clog(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point excep-
 | |
|         tion, for finite x.
 | |
| 
 | |
|       — clog(−∞ + iy) returns +∞ + iπ, for finite positive-signed y.
 | |
| 
 | |
|       — clog(+∞ + iy) returns +∞ + i0, for finite positive-signed y.
 | |
| 
 | |
|       — clog(−∞ + i∞) returns +∞ + i 3π
 | |
|                                       4 .
 | |
| 
 | |
|       — clog(+∞ + i∞) returns +∞ + iπ
 | |
|                                     4 .
 | |
| 
 | |
|       — clog(±∞ + iNaN) returns +∞ + iNaN.
 | |
| 
 | |
|       — clog(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point excep-
 | |
|         tion, for finite y.
 | |
| 
 | |
|       — clog(NaN + i∞) returns +∞ + iNaN.
 | |
| 
 | |
|       — clog(NaN + iNaN) returns NaN + iNaN.
 | |
| 
 | |
| </pre>
 | |
| <a name='G.6.4'></a>
 | |
| <hr>
 | |
| <h3>G.6.4 [Power and absolute-value functions]</h3>
 | |
| <a name='G.6.4.1'></a>
 | |
| <hr>
 | |
| <h3>G.6.4.1 [The cpow functions]</h3>
 | |
| <a name='G.6.4.1p1'></a>
 | |
| <pre>1   The cpow functions raise floating-point exceptions if appropriate for the calculation of the parts of
 | |
|     the result, and may also raise spurious floating-point exceptions.<a href='#FOOTNOTE.462'><sup>[462]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.462'>
 | |
| <pre><i><b>Footnote 462)</b> This allows cpow(z, c) to be implemented as cexp(cclog(z)) without precluding implementations that treat special cases
 | |
|     more carefully.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='G.6.4.2'></a>
 | |
| <hr>
 | |
| <h3>G.6.4.2 [The csqrt functions]</h3>
 | |
| <a name='G.6.4.2p1'></a>
 | |
| <pre>1     — csqrt(conj(z)) = conj(csqrt(z)).
 | |
| 
 | |
|       — csqrt(±0 + i0) returns +0 + i0.
 | |
| 
 | |
|       — csqrt(x + i∞) returns +∞ + i∞, for all x (including NaN).
 | |
| 
 | |
|       — csqrt(x + iNaN) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite x.
 | |
| 
 | |
|       — csqrt(−∞ + iy) returns +0 + i∞, for finite positive-signed y.
 | |
| 
 | |
|       — csqrt(+∞ + iy) returns +∞ + i0, for finite positive-signed y.
 | |
| 
 | |
|       — csqrt(−∞ + iNaN) returns NaN±i∞ (where the sign of the imaginary part of the result is
 | |
|         unspecified).
 | |
| 
 | |
|       — csqrt(+∞ + iNaN) returns +∞ + iNaN.
 | |
| 
 | |
|       — csqrt(NaN + iy) returns NaN + iNaN and optionally raises the "invalid" floating-point
 | |
|         exception, for finite y.
 | |
| 
 | |
|       — csqrt(NaN + iNaN) returns NaN + iNaN.
 | |
| </pre>
 | |
| <a name='G.7'></a>
 | |
| <hr>
 | |
| <h3>G.7 [Type-generic math <tgmath.h>]</h3>
 | |
| <a name='G.7p1'></a>
 | |
| <pre>1   Type-generic macros that accept complex arguments also accept imaginary arguments. If an argu-
 | |
|     ment is imaginary, the macro expands to an expression whose type is real, imaginary, or complex, as
 | |
|     appropriate for the particular function: if the argument is imaginary, then the types of cos, cosh,
 | |
|     fabs, carg, cimag, and creal are real; the types of sin, tan, sinh, tanh, asin, atan, asinh, and
 | |
|     atanh are imaginary; and the types of the others are complex.
 | |
| </pre>
 | |
| <a name='G.7p2'></a>
 | |
| <pre>2   Given an imaginary argument, each of the type-generic macros cos, sin, tan, cosh, sinh, tanh,
 | |
|     asin, atan, asinh, atanh is specified by a formula in terms of real functions:
 | |
| 
 | |
|             cos(iy )   = cosh(y )
 | |
|             sin(iy )   = i sinh(y )
 | |
|             tan(iy )   = i tanh(y )
 | |
|             cosh(iy ) = cos(y )
 | |
|             sinh(iy ) = i sin(y )
 | |
|             tanh(iy ) = i tan(y )
 | |
|             asin(iy ) = i asinh(y )
 | |
|             atan(iy ) = i atanh(y )
 | |
|             asinh(iy ) = i asin(y )
 | |
|             atanh(iy ) = i atan(y )
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.'></a>
 | |
| <hr>
 | |
| <h3>H. [Annex H (normative) IEC 60559 interchange and extended types]</h3>
 | |
| <a name='H.1'></a>
 | |
| <hr>
 | |
| <h3>H.1 [Introduction]</h3>
 | |
| <a name='H.1p1'></a>
 | |
| <pre>1   This annex specifies extension types for programming language C that have the arithmetic inter-
 | |
|     change and extended floating-point formats specified in ISO/IEC/IEEE 60559. This annex also
 | |
|     includes functions that support the non-arithmetic interchange formats in that standard. This annex
 | |
|     was adapted from ISO/IEC TS 18661-3:2015, Floating-point extensions for C —Interchange and
 | |
|     extended types.
 | |
| </pre>
 | |
| <a name='H.1p2'></a>
 | |
| <pre>2   An implementation that defines __STDC_IEC_60559_TYPES__ to 202311L shall conform to the
 | |
|     specifications in this annex. An implementation may define __STDC_IEC_60559_TYPES__ only
 | |
|     if it defines __STDC_IEC_60559_BFP__ , indicating support for IEC 60559 binary floating-point
 | |
|     arithmetic, or defines __STDC_IEC_60559_DFP__ , indicating support for IEC 60559 decimal floating-
 | |
|     point arithmetic (or defines both). Where a binding between the C language and IEC 60559 is
 | |
|     indicated, the IEC 60559-specified behavior is adopted by reference, unless stated otherwise.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2'></a>
 | |
| <hr>
 | |
| <h3>H.2 [Types]</h3>
 | |
| <pre>This clause specifies types that support IEC 60559 arithmetic interchange and extended formats. The
 | |
|     encoding conversion functions (<a href='#H.11.3'>H.11.3</a>) and numeric conversion functions for encodings (<a href='#H.12.3'>H.12.3</a>,
 | |
|     and <a href='#H.12.4'>H.12.4</a>) support the non-arithmetic interchange formats specified in IEC 60559.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.1'></a>
 | |
| <hr>
 | |
| <h3>H.2.1 [Interchange floating types]</h3>
 | |
| <a name='H.2.1p1'></a>
 | |
| <pre>1 IEC 60559 specifies interchange formats, and their encodings, which can be used for the exchange of
 | |
|     floating-point data between implementations. These formats are identified by their radix (binary
 | |
|     or decimal) and their storage width N. The two tables below give the C floating-point model
 | |
|     parameters<a href='#FOOTNOTE.463'><sup>[463]</sup></a> (<a href='#5.2.4.2.2'>5.2.4.2.2</a>) for the IEC 60559 interchange formats, where the function round() rounds
 | |
|     to the nearest integer.
 | |
| 
 | |
|                                           Binary interchange format parameters
 | |
|                Parameter                    binary16 binary32 binary64 binary128                              binaryN (N ≥ 128)
 | |
|        N , storage width in bits               16         32         64         128                            N, a multiple of 32
 | |
|           p, precision in bits                 11         24         53         113                       N − round(4 × log2 (N )) + 13
 | |
|      emax , maximum exponent e                 16         128       1024       16384                                2(N −p−1)
 | |
|      emin , minimum exponent e                −13        −125      −1021     −16381                                 3 − emax
 | |
| 
 | |
|                                    Decimal interchange format parameters
 | |
|                    Parameter            decimal32 decimal64 decimal128                              decimalN (N ≥ 32)
 | |
|            N , storage width in bits        32          64          128                             N, a multiple of 32
 | |
|               p, precision in bits           7          16          34                               9 × (N ÷ 32) − 2
 | |
|          emax , maximum exponent e          97          385        6145                             3 × 2((N ÷16)+3) + 1
 | |
|          emin , minimum exponent e         −94        −382        −6142                                  3 − emax
 | |
| 
 | |
|    EXAMPLE For the binary160 format, p = 144, emax = 32678 and emin = −32765. For the decimal160 format, p = 43,
 | |
|     emax = 24577 and emin = −24574.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.463'>
 | |
| <pre><i><b>Footnote 463)</b> In IEC 60559, normal floating-point numbers are expressed with the first significant digit to the left of the radix point.
 | |
|     Hence the exponent in the C model (shown in the tables) is 1 more than the exponent of the same number in the IEC 60559
 | |
|     model.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='H.2.1p2'></a>
 | |
| <pre>2   Types designated:
 | |
|               _FloatN
 | |
| 
 | |
| 
 | |
|     where N is 16, 32, 64, or ≥ 128 and a multiple of 32; and, types designated
 | |
|             _DecimalN
 | |
| 
 | |
| 
 | |
|     where N ≥ 32 and a multiple of 32, are collectively called the interchange floating types. Each
 | |
|     interchange floating type has the IEC 60559 interchange format corresponding to its width (N ) and
 | |
|     radix (2 for _FloatN, 10 for _DecimalN). Each interchange floating type is not compatible with any
 | |
|     other type.
 | |
| </pre>
 | |
| <a name='H.2.1p3'></a>
 | |
| <pre>3   An implementation that defines __STDC_IEC_60559_BFP__ and __STDC_IEC_60559_TYPES__ shall
 | |
|     provide _Float32 and _Float64 as interchange floating types with the same representation and
 | |
|     alignment requirements as float and double, respectively. If the implementation’s long double
 | |
|     type supports an IEC 60559 interchange format of width N > 64, then the implementation shall also
 | |
|     provide the type _FloatN as an interchange floating type with the same representation and alignment
 | |
|     requirements as long double. The implementation may provide other radix-2 interchange floating
 | |
|     types _FloatN; the set of such types supported is implementation-defined.
 | |
| </pre>
 | |
| <a name='H.2.1p4'></a>
 | |
| <pre>4   An implementation that defines __STDC_IEC_60559_DFP__ provides the decimal floating
 | |
|     types _Decimal32 , _Decimal64 , and _Decimal128 (<a href='#6.2.5'>6.2.5</a>). If the implementation also defines
 | |
|     __STDC_IEC_60559_TYPES__ , it may provide other radix-10 interchange floating types _DecimalN;
 | |
|     the set of such types supported is implementation-defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.2'></a>
 | |
| <hr>
 | |
| <h3>H.2.2 [Non-arithmetic interchange formats]</h3>
 | |
| <a name='H.2.2p1'></a>
 | |
| <pre>1   An implementation supports IEC 60559 non-arithmetic interchange formats by providing the as-
 | |
|     sociated encoding-to-encoding conversion functions (<a href='#H.11.3.2'>H.11.3.2</a>) in <math.h> and the string-from-
 | |
|     encoding functions (<a href='#H.12.3'>H.12.3</a>) and string-to-encodng functions (<a href='#H.12.4'>H.12.4</a>) in <stdlib.h>.
 | |
| </pre>
 | |
| <a name='H.2.2p2'></a>
 | |
| <pre>2   An implementation that defines __STDC_IEC_60559_BFP__ and __STDC_IEC_60559_TYPES__ sup-
 | |
|     ports some IEC 60559 radix-2 interchange formats as arithmetic formats by providing types _Float
 | |
|     N (as well as float and double) with those formats. The implementation may support other
 | |
|     IEC 60559 radix-2 interchange formats as non-arithmetic formats; the set of such formats supported
 | |
|     is implementation-defined.
 | |
| </pre>
 | |
| <a name='H.2.2p3'></a>
 | |
| <pre>3   An implementation that defines __STDC_IEC_60559_DFP__ and __STDC_IEC_60559_TYPES__ sup-
 | |
|     ports some IEC 60559 radix-10 interchange formats as arithmetic formats by providing types
 | |
|     _DecimalN with those formats. The implementations may support other IEC 60559 radix-10 inter-
 | |
|     change formats as non-arithmetic formats; the set of such formats supported is implementation-
 | |
|     defined.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.3'></a>
 | |
| <hr>
 | |
| <h3>H.2.3 [Extended floating types]</h3>
 | |
| <a name='H.2.3p1'></a>
 | |
| <pre>1   For each of its basic formats, IEC 60559 specifies an extended format whose maximum exponent and
 | |
|     precision exceed those of the basic format it is associated with. Extended formats are intended for
 | |
|     arithmetic with more precision and exponent range than is available in the basic formats used for
 | |
|     the input data. The extra precision and range often mitigate round-off error and eliminate overflow
 | |
|     and underflow in intermediate computations. The table below gives the minimum values of these
 | |
|     parameters, as defined for the C floating-point model (<a href='#5.2.4.2.2'>5.2.4.2.2</a>). For all IEC 60559 extended (and
 | |
|     interchange) formats, emin = 3 − emax .
 | |
| 
 | |
|                          Extended format parameters for floating-point numbers
 | |
|                                          Extended formats associated with:
 | |
|                 Parameter binary32 binary64 binary128 decimal64 decimal128
 | |
|                 p digits ≥      32         64         128          22           40
 | |
|                  emax ≥        1024      16384       65536        6145        24577
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.3p2'></a>
 | |
| <pre>2   Types designated _Float32x , _Float64x , _Float128x , _Decimal64x , and _Decimal128x support
 | |
|     the corresponding IEC 60559 extended formats and are collectively called the extended floating
 | |
|     types. The set of values of _Float32x is a subset of the set of values of _Float64x ; the set
 | |
|     of values of _Float64x is a subset of the set of values of _Float128x . The set of values of
 | |
|     _Decimal64x is a subset of the set of values of _Decimal128x . Each extended floating type is
 | |
|     not compatible with any other type. An implementation that defines __STDC_IEC_60559_BFP__
 | |
|     and __STDC_IEC_60559_TYPES__ shall provide _Float32x , and may provide one or both of the
 | |
|     types _Float64x and _Float128x . An implementation that defines __STDC_IEC_60559_DFP__ and
 | |
|     __STDC_IEC_60559_TYPES__ shall provide _Decimal64x , and may provide _Decimal128x . Which
 | |
|     (if any) of the optional extended floating types are provided is implementation-defined.
 | |
| </pre>
 | |
| <a name='H.2.3p3'></a>
 | |
| <pre>3   NOTE IEC 60559 does not specify an extended format associated with the decimal32 format, nor does this annex specify an
 | |
|     extended type associated with the _Decimal32 type.
 | |
| </pre>
 | |
| <a name='H.2.3p4'></a>
 | |
| <pre>4   NOTE The _Float32x type may have the same format as double. The _Decimal64x type may have the same format as
 | |
|     _Decimal128 .
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.4'></a>
 | |
| <hr>
 | |
| <h3>H.2.4 [Classification of real floating types]</h3>
 | |
| <a name='H.2.4p1'></a>
 | |
| <pre>1   <a href='#6.2.5'>6.2.5</a> defines standard floating types as a collective name for the types float, double and
 | |
|     long double and it defines decimal floating types as a collective name for the types _Decimal32 ,
 | |
|     _Decimal64 , and _Decimal128 .
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.4p2'></a>
 | |
| <pre>2   <a href='#H.2.1'>H.2.1</a> defines interchange floating types and <a href='#H.2.3'>H.2.3</a> defines extended floating types.
 | |
| </pre>
 | |
| <a name='H.2.4p3'></a>
 | |
| <pre>3   The types _FloatN and _FloatNx are collectively called binary floating types.
 | |
| </pre>
 | |
| <a name='H.2.4p4'></a>
 | |
| <pre>4   This subclause broadens decimal floating types to include the types _DecimalN and _DecimalNx,
 | |
|     introduced in this annex, as well as _Decimal32 , _Decimal64 , and _Decimal128 .
 | |
| </pre>
 | |
| <a name='H.2.4p5'></a>
 | |
| <pre>5   This sublcause broadens real floating types to include all interchange floating types and extended
 | |
|     floating types, as well as standard floating types.
 | |
| </pre>
 | |
| <a name='H.2.4p6'></a>
 | |
| <pre>6   Thus, in this annex, real floating types are classified as follows:
 | |
| 
 | |
|          — standard floating types, composed of float, double, long double;
 | |
| 
 | |
|          — decimal floating types, composed of _DecimalN, _DecimalNx;
 | |
| 
 | |
|          — binary floating types, composed of _FloatN, _FloatNx;
 | |
| 
 | |
|          — interchange floating types, composed of _FloatN, _DecimalN; and,
 | |
| 
 | |
|          — extended floating types, composed of _FloatNx, _DecimalNx.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.4p7'></a>
 | |
| <pre>7   NOTE Standard floating types (which have an implementation-defined radix) are not included in either binary floating
 | |
|     types (which always have radix 2) or decimal floating types (which always have radix 10).
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.5'></a>
 | |
| <hr>
 | |
| <h3>H.2.5 [Complex types]</h3>
 | |
| <a name='H.2.5p1'></a>
 | |
| <pre>1   This subclause broadens the C complex types (<a href='#6.2.5'>6.2.5</a>) to also include similar types whose correspond-
 | |
|     ing real parts have binary floating types. For the types _FloatN and _FloatNx, there are complex
 | |
|     types designated respectively as _FloatN _Complex and _FloatNx _Complex . (Complex types are a
 | |
|     conditional feature that implementations need not support; see <a href='#6.10.9.3'>6.10.9.3</a>.)
 | |
| 
 | |
| </pre>
 | |
| <a name='H.2.6'></a>
 | |
| <hr>
 | |
| <h3>H.2.6 [Imaginary types]</h3>
 | |
| <a name='H.2.6p1'></a>
 | |
| <pre>1   This subclause broadens the C imaginary types (<a href='#G.2'>G.2</a>) to also include similar types whose correspond-
 | |
|     ing real parts have binary floating types. For the types _FloatN and _FloatNx, there are imaginary
 | |
|     types designated respectively as _FloatN _Imaginary and _FloatNx _Imaginary . The imaginary
 | |
|     types (along with the real floating and complex types) are floating types. (Annex G, including
 | |
|     imaginary types, is a conditional feature that implementations need not support; see <a href='#6.10.9.3'>6.10.9.3</a>.)
 | |
| 
 | |
| </pre>
 | |
| <a name='H.3'></a>
 | |
| <hr>
 | |
| <h3>H.3 [Characteristics in <float.h>]</h3>
 | |
| <a name='H.3p1'></a>
 | |
| <pre>1   This subclause enhances the FLT_EVAL_METHOD and DEC_EVAL_METHOD macros to apply to the types
 | |
|     introduced in this annex.
 | |
| </pre>
 | |
| <a name='H.3p2'></a>
 | |
| <pre>2   If FLT_RADIX is 2, the value of FLT_EVAL_METHOD (<a href='#5.2.4.2.2'>5.2.4.2.2</a>) characterizes the use of evaluation
 | |
|     formats for standard floating types and for binary floating types:
 | |
| 
 | |
|     -1            indeterminable;
 | |
|     0           evaluate all operations and constants, whose semantic type comprises a set of values
 | |
|                 that is a strict subset of the values of float, to the range and precision of float; evaluate
 | |
|                 all other operations and constants to the range and precision of the semantic type;
 | |
|     1           evaluate operations and constants, whose semantic type comprises a set of values that
 | |
|                 is a strict subset of the values of double, to the range and precision of double; evaluate
 | |
|                 all other operations and constants to the range and precision of the semantic type;
 | |
|     2           evaluate operations and constants, whose semantic type comprises a set of values that is
 | |
|                 a strict subset of the values of long double, to the range and precision of long double;
 | |
|                 evaluate all other operations and constants to the range and precision of the semantic
 | |
|                 type;
 | |
|     N           where _FloatN is a supported interchange floating type, evaluate operations and con-
 | |
|                 stants, whose semantic type comprises a set of values that is a strict subset of the values
 | |
|                 of _FloatN, to the range and precision of _FloatN; evaluate all other operations and
 | |
|                 constants to the range and precision of the semantic type;
 | |
|     N +1        where _FloatNx is a supported extended floating type, evaluate operations and con-
 | |
|                 stants, whose semantic type comprises a set of values that is a strict subset of the values
 | |
|                 of _FloatNx, to the range and precision of _FloatNx; evaluate all other operations and
 | |
|                 constants to the range and precision of the semantic type.
 | |
| 
 | |
|     If FLT_RADIX is not 2, the use of evaluation formats for operations and constants of binary floating
 | |
|     types is implementation-defined.
 | |
| </pre>
 | |
| <a name='H.3p3'></a>
 | |
| <pre>3   The implementation-defined value of DEC_EVAL_METHOD (<a href='#5.2.4.2.3'>5.2.4.2.3</a>) characterizes the use of evalua-
 | |
|     tion formats for decimal floating types:
 | |
| 
 | |
|     -1          indeterminable;
 | |
|     0           evaluate all operations and constants just to the range and precision of the type;
 | |
|     1           evaluate operations and constants, whose semantic type comprises a set of values that
 | |
|                 is a strict subset of the values of _Decimal64 , to the range and precision of _Decimal64 ;
 | |
|                 evaluate all other operations and constants to the range and precision of the semantic
 | |
|                 type;
 | |
|     2           evaluate operations and constants, whose semantic type comprises a set of values that is
 | |
|                 a strict subset of the values of _Decimal128 , to the range and precision of _Decimal128 ;
 | |
|                 evaluate all other operations and constants to the range and precision of the semantic
 | |
|                 type;
 | |
|     N           where _DecimalN is a supported interchange floating type evaluate operations and
 | |
|                 constants, whose semantic type comprises a set of values that is a strict subset of
 | |
|                 the values of _DecimalN, to the range and precision of _DecimalN; evaluate all other
 | |
|                 operations and constants to the range and precision of the semantic type;
 | |
|     N +1        where _DecimalNx is a supported extended floating type evaluate operations and
 | |
|                 constants, whose semantic type comprises a set of values that is a strict subset of the
 | |
|                 values of _DecimalNx, to the range and precision of _DecimalNx; evaluate all other
 | |
|                 operations and constants to the range and precision of the semantic type.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.3p4'></a>
 | |
| <pre>4   This subclause also specifies <float.h> macros, analogous to the macros for standard floating
 | |
|     types, that characterize binary floating types in terms of the model presented in <a href='#5.2.4.2.2'>5.2.4.2.2</a>. This
 | |
|     subclause generalizes the specification of characteristics in <a href='#5.2.4.2.3'>5.2.4.2.3</a> to include the decimal floating
 | |
|     types introduced in this annex. The prefix FLTN_ indicates the type _FloatN or the non-arithmetic
 | |
|     binary interchange format of width N . The prefix FLTNX_ indicates the type _FloatNx. The prefix
 | |
|     DECN_ indicates the type _DecimalN or the non-arithmetic decimal interchange format of width
 | |
|     N . The prefix DECNX_ indicates the type _DecimalNx. The type parameters p, emax , and emin for
 | |
|     extended floating types are for the extended floating type itself, not for the basic format that it
 | |
|     extends.
 | |
| </pre>
 | |
| <a name='H.3p5'></a>
 | |
| <pre>5   If __STDC_WANT_IEC_60559_TYPES_EXT__ is defined (by the user) at the point in the code where
 | |
|     <float.h> is first included, the following applies (<a href='#H.8'>H.8</a>). For each interchange or extended floating
 | |
|     type that the implementation provides, <float.h> shall define the associated macros in the fol-
 | |
|     lowing lists. Conversely, for each such type that the implementation does not provide, <float.h>
 | |
|     shall not define the associated macros in the following list, except, the implementation shall define
 | |
|     the macros FLTN_DECIMAL_DIG and FLTN_DIG if it supports the IEC 60559 non-arithmetic binary
 | |
|     interchange format of width N (<a href='#H.2.2'>H.2.2</a>).
 | |
| </pre>
 | |
| <a name='H.3p6'></a>
 | |
| <pre>6   The signaling NaN macros
 | |
|     The macro
 | |
| 
 | |
|             FLTN_SNAN
 | |
|             DECN_SNAN
 | |
|             FLTNX_SNAN
 | |
|             DECNX_SNAN
 | |
| 
 | |
| 
 | |
|     expand to constant expressions of types _FloatN, _DecimalN, _FloatNx, and _DecimalNx respec-
 | |
|     tively, representing a signaling NaN. If an optional unary + or- operator followed by a signaling
 | |
|     NaN macro is used for initializing an object of the same type that has static or thread storage
 | |
|     duration, the object is initialized with a signaling NaN value.
 | |
| </pre>
 | |
| <a name='H.3p7'></a>
 | |
| <pre>7   The integer values given in the following lists shall be replaced by integer constant expressions:
 | |
| 
 | |
|       — radix of exponent representation, b (2 for binary, 10 for decimal)
 | |
| 
 | |
|           For the standard floating types, this value is implementation-defined and is specified
 | |
|           by the macro FLT_RADIX. For the interchange and extended floating types there is no
 | |
|           corresponding macro; the radix is an inherent property of the types.
 | |
|       — The number of bits in the floating-point significand, p
 | |
| 
 | |
|                   FLTN_MANT_DIG
 | |
|                   FLTNX_MANT_DIG
 | |
| 
 | |
| 
 | |
|       — The number of digits in the coefficient, p
 | |
| 
 | |
|                   DECN_MANT_DIG
 | |
|                   DECNX_MANT_DIG
 | |
| 
 | |
| 
 | |
|       — number of decimal digits, n, such that any floating-point number with p bits can be rounded
 | |
|         to a floating-point number with n decimal digits and back again without change to the value,
 | |
|         ⌈1 + p log10 (2)⌉
 | |
| 
 | |
|                   FLTN_DECIMAL_DIG
 | |
|                   FLTNX_DECIMAL_DIG
 | |
| 
 | |
| 
 | |
|       — number of decimal digits, q, such that any floating-point number with q decimal digits can
 | |
|         be rounded to a floating-point number with p bits and back again without a change to the q
 | |
|         decimal digits, ⌊(p − 1) log10 (2)⌋
 | |
| 
 | |
|                   FLTN_DIG
 | |
|                   FLTNX_DIG
 | |
| 
 | |
| 
 | |
|       — minimum negative integer such that the radix raised to one less than that power is a normalized
 | |
|         floating-point number, emin
 | |
|            FLTN_MIN_EXP
 | |
|            FLTNX_MIN_EXP
 | |
|            DECN_MIN_EXP
 | |
|            DECNX_MIN_EXP
 | |
| 
 | |
| 
 | |
| 
 | |
| — minimum negative integer such that 10 raised to that power is in the range of normalized
 | |
|   floating-point numbers, ⌈ log10 (2)emin −1 ⌉
 | |
| 
 | |
|            FLTN_MIN_10_EXP
 | |
|            FLTNX_MIN_10_EXP
 | |
| 
 | |
| 
 | |
| 
 | |
| — maximum negative integer such that the radix raised to one less than that power is a repre-
 | |
|   sentable finite floating-point number, emax
 | |
| 
 | |
|            FLTN_MAX_EXP
 | |
|            FLTNX_MAX_EXP
 | |
|            DECN_MAX_EXP
 | |
|            DECNX_MAX_EXP
 | |
| 
 | |
| 
 | |
| 
 | |
| — maximum integer such that 10 raised to that power is in the range of representable finite
 | |
|   floating-point numbers, ⌊ log10 ((1 − 2−p )2emax )⌋
 | |
| 
 | |
|            FLTN_MAX_10_EXP
 | |
|            FLTNX_MAX_10_EXP
 | |
| 
 | |
| 
 | |
| 
 | |
| — maximum representable finite floating-pointer number, (1 − b−p )bemax
 | |
| 
 | |
|            FLTN_MAX
 | |
|            FLTNX_MAX
 | |
|            DECN_MAX
 | |
|            DECNX_MAX
 | |
| 
 | |
| 
 | |
| 
 | |
| — the difference between 1 and the least value greater than 1 that is representable in the given
 | |
|   floating-point type, b1−p
 | |
| 
 | |
|            FLTN_EPSILON
 | |
|            FLTNX_EPSILON
 | |
|            DECN_EPSILON
 | |
|            DECNX_EPSILON
 | |
| 
 | |
| 
 | |
| 
 | |
| — minimum normalized positive floating-point number, bemin −1
 | |
| 
 | |
|            FLTN_MIN
 | |
|            FLTNX_MIN
 | |
|            DECN_MIN
 | |
|            DECNX_MIN
 | |
| 
 | |
| 
 | |
| 
 | |
| — minimum positive floating-point number, bemin −p
 | |
| 
 | |
|            FLTN_TRUE_MIN
 | |
|            FLTNX_TRUE_MIN
 | |
|            DECN_TRUE_MIN
 | |
|            DECNX_TRUE_MIN
 | |
| </pre>
 | |
| <a name='H.4'></a>
 | |
| <hr>
 | |
| <h3>H.4 [Conversions]</h3>
 | |
| <a name='H.4p1'></a>
 | |
| <pre>1   This subclause enhances the usual arithmetic conversions (<a href='#6.3.1.8'>6.3.1.8</a>) to handle interchange and ex-
 | |
|     tended floating types. It supports the IEC 60559 recommendation against allowing implicit conver-
 | |
|     sions of operands to obtain a common type where the conversion is between types where neither is
 | |
|     a subset of (or equivalent to) the other.
 | |
| </pre>
 | |
| <a name='H.4p2'></a>
 | |
| <pre>2   This subclause also broadens the operation binding in <a href='#F.3'>F.3</a> for the IEC 60559 convertFormat operation
 | |
|     to apply to IEC 60559 arithmetic and non-arithmetic formats.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.4.1'></a>
 | |
| <hr>
 | |
| <h3>H.4.1 [Real floating and integer]</h3>
 | |
| <a name='H.4.1p1'></a>
 | |
| <pre>1   When a finite value of interchange or extended floating type is converted to an integer type other
 | |
|     than bool, the fractional part is discarded (i.e., the value is truncated toward zero). If the value of
 | |
|     the integral part cannot be represented by the integer type, the "invalid" floating-point exception
 | |
|     shall be raised and the result of the conversion is unspecified.
 | |
| </pre>
 | |
| <a name='H.4.1p2'></a>
 | |
| <pre>2   When a value of integer type is converted to an interchange or extended floating type, if the value
 | |
|     being converted can be represented exactly in the new type, it is unchanged. If the value being
 | |
|     converted cannot be represented exactly, the result shall be correctly rounded with exceptions raised
 | |
|     as specified in IEC 60559.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.4.2'></a>
 | |
| <hr>
 | |
| <h3>H.4.2 [Usual arithmetic conversions]</h3>
 | |
| <a name='H.4.2p1'></a>
 | |
| <pre>1   If either operand is of floating type, the common real type is determined as follows:
 | |
| 
 | |
|       — If one operand has decimal floating type, the other operand shall not have standard floating
 | |
|         type, binary floating type, complex type, or imaginary type.
 | |
|       — If only one operand has a floating type, the other operand is converted to the corresponding
 | |
|         real type of the operand of floating type.
 | |
|       — If both operands have the same corresponding real type, no further conversion is needed.
 | |
|       — If both operands have floating types and neither of the sets of values of their corresponding
 | |
|         real types is a subset of (or equivalent to) the other, the behavior is undefined.
 | |
|       — Otherwise, if both operands are floating types and the sets of values of their corresponding
 | |
|         real types are not equivalent, the operand whose set of values of its corresponding real type
 | |
|         is a strict subset of the set of values of the corresponding real type of the other operand is
 | |
|         converted, without change of type domain, to a type with the corresponding real type of that
 | |
|         other operand.
 | |
|       — Otherwise, if both operands are floating types and the sets of values of their corresponding
 | |
|         real types are equivalent, then the following rules are applied:
 | |
| 
 | |
|              – If the corresponding real type of either operand is an interchange floating type, the other
 | |
|                operand is converted, without change of type domain, to a type whose corresponding
 | |
|                real type is that same interchange floating type.
 | |
|              – Otherwise, if the corresponding real type of either operand is long double, the other
 | |
|                operand is converted, without change of type domain, to a type whose corresponding
 | |
|                real type is long double.
 | |
|              – Otherwise, if the corresponding real type of either operand is double, the other operand
 | |
|                is converted, without change of type domain, to a type whose corresponding real type is
 | |
|                double<a href='#FOOTNOTE.464'><sup>[464]</sup></a> .
 | |
|              – Otherwise, if the corresponding real type of either operand is _Float128x or
 | |
|                _Decimal128x , the other operand is converted, without change of type domain, to a type
 | |
|                whose corresponding real type is _Float128x or _Decimal128x , respectively.
 | |
|              – Otherwise, if the corresponding real type of either operand is _Float64x or _Decimal64x ,
 | |
|                the other operand is converted, without change of type domain, to a type whose corre-
 | |
|                sponding real type is _Float64x or _Decimal64x , respectively.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.464'>
 | |
| <pre><i><b>Footnote 464)</b> All cases where float might have the same format as another type are covered above.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='H.4.3'></a>
 | |
| <hr>
 | |
| <h3>H.4.3 [Arithmetic and non-arithmetic formats]</h3>
 | |
| <a name='H.4.3p1'></a>
 | |
| <pre>1   The operation binding in <a href='#F.3'>F.3</a> for the IEC 60559 convertFormat operation applies to IEC 60559
 | |
|     arithmetic and non-arithmetic formats as follows:
 | |
| 
 | |
|       — For conversions between arithmetic formats supported by floating types (same or different
 | |
|         radix) – casts and implicit conversions.
 | |
| 
 | |
|       — For same-radix conversions between non-arithmetic interchange formats – encoding-to-
 | |
|         encoding conversion functions (<a href='#H.11.3.2'>H.11.3.2</a>).
 | |
| 
 | |
|       — For conversions between non-arithmetic interchange formats (same or different radix) – compo-
 | |
|         sitions of string-from-encoding functions (<a href='#H.12.3'>H.12.3</a>) (converting exactly) and string-to-encoding
 | |
|         functions (<a href='#H.12.4'>H.12.4</a>).
 | |
| 
 | |
|       — For same-radix conversions from interchange formats supported by interchange floating types
 | |
|         to non-arithmetic interchange formats – compositions of encode functions (<a href='#H.11.3.1.1'>H.11.3.1.1</a>, <a href='#7.12.16.1'>7.12.16.1</a>,
 | |
|         <a href='#7.12.16.3'>7.12.16.3</a>) and encoding-to-encoding functions (<a href='#H.11.3.2'>H.11.3.2</a>).
 | |
| 
 | |
|       — For same radix conversions from non-arithmetic interchange formats to interchange formats
 | |
|         supported by interchange floating types – compositions of encoding-to-encoding conversion
 | |
|         functions (<a href='#H.11.3.2'>H.11.3.2</a>) and decode functions (<a href='#H.11.3.1.2'>H.11.3.1.2</a>, <a href='#7.12.16.2'>7.12.16.2</a>, <a href='#7.12.16.4'>7.12.16.4</a>). See the example in
 | |
|         <a href='#H.11.3.2.1'>H.11.3.2.1</a>.
 | |
| 
 | |
|       — For conversions from non-arithmetic interchange formats to arithmetic formats supported
 | |
|         by floating types (same or different radix) – compositions of string-from-encoding functions
 | |
|         (<a href='#H.12.3'>H.12.3</a>) (converting exactly) and numeric conversion functions strtod, etc. (<a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.24.1.6'>7.24.1.6</a>).
 | |
|         See the example in <a href='#H.12.2'>H.12.2</a>.
 | |
| 
 | |
|       — For conversions from arithmetic formats supported by floating types to non-arithmetic in-
 | |
|         terchange formats (same or different radix) – compositions of numeric conversion func-
 | |
|         tions strfromd, etc. (<a href='#7.24.1.3'>7.24.1.3</a>, <a href='#7.24.1.4'>7.24.1.4</a>) (converting exactly) and string-to-encoding functions
 | |
|         (<a href='#H.12.4'>H.12.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='H.5'></a>
 | |
| <hr>
 | |
| <h3>H.5 [Lexical Elements]</h3>
 | |
| <a name='H.5.1'></a>
 | |
| <hr>
 | |
| <h3>H.5.1 [Keywords]</h3>
 | |
| <a name='H.5.1p1'></a>
 | |
| <pre>1   This subclause expands the list of keywords (<a href='#6.4.1'>6.4.1</a>) to also include:
 | |
| 
 | |
|       — _FloatN, where N is 16, 32, 64, or ≥ 128 and a multiple of 32
 | |
| 
 | |
|       — _Float32x
 | |
| 
 | |
|       — _Float64x
 | |
| 
 | |
|       — _Float128x
 | |
| 
 | |
|       — _DecimalN, where N is 96 or > 128 and a multiple of 32
 | |
| 
 | |
|       — _Decimal64x
 | |
| 
 | |
|       — _Decimal128x
 | |
| 
 | |
| </pre>
 | |
| <a name='H.5.2'></a>
 | |
| <hr>
 | |
| <h3>H.5.2 [Constants]</h3>
 | |
| <a name='H.5.2p1'></a>
 | |
| <pre>1   This subclause specifies constants of interchange and extended floating types.
 | |
| </pre>
 | |
| <a name='H.5.2p2'></a>
 | |
| <pre>2   This subclause expands floating-suffix (<a href='#6.4.4.2'>6.4.4.2</a>) to also include: fN, FN, fNx, FNx, dN, DN, dNx, or DNx.
 | |
| </pre>
 | |
| <a name='H.5.2p3'></a>
 | |
| <pre>3   A floating suffix dN, DN, dNx, or DNx shall not be used in a hexadecimal-floating-constant.
 | |
| </pre>
 | |
| <a name='H.5.2p4'></a>
 | |
| <pre>4   A floating suffix shall not designate a type that the implementation does not provide.
 | |
| </pre>
 | |
| <a name='H.5.2p5'></a>
 | |
| <pre>5   If a floating constant is suffixed by fN or FN, it has type _FloatN. If suffixed by fNx or FNx, it has
 | |
|     type _FloatNx. If suffixed by dN or DN, it has type _DecimalN. If suffixed by dNx or DNx, it has type
 | |
|     _DecimalNx .
 | |
| 
 | |
| </pre>
 | |
| <a name='H.5.2p6'></a>
 | |
| <pre>6   The quantum exponent of a floating constant of decimal floating type is the same as for the result
 | |
|     value of the corresponding strtodN or strtodNx function (<a href='#H.12.2'>H.12.2</a>) for the same numeric string.
 | |
| </pre>
 | |
| <a name='H.5.2p7'></a>
 | |
| <pre>7   NOTE For N = 32, 64, and 128, the suffixes dN and DN in this subclause for constants of type _DecimalN are equivalent
 | |
|     alternatives to the suffixes df, dd, dl, DF, DD, and DL in <a href='#6.4.4.2'>6.4.4.2</a> for the same types.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.6'></a>
 | |
| <hr>
 | |
| <h3>H.6 [Expressions]</h3>
 | |
| <a name='H.6p1'></a>
 | |
| <pre>1   This subclause expands the specification of expressions to also cover interchange and extended
 | |
|     floating types.
 | |
| </pre>
 | |
| <a name='H.6p2'></a>
 | |
| <pre>2   Operators involving operands of interchange or extended floating type are evaluated according to
 | |
|     the semantics of IEC 60559, including production of decimal floating-point results with the preferred
 | |
|     quantum exponent as specified in IEC 60559 (see <a href='#5.2.4.2.3'>5.2.4.2.3</a>).
 | |
| </pre>
 | |
| <a name='H.6p3'></a>
 | |
| <pre>3   For multiplicative operators (<a href='#6.5.5'>6.5.5</a>), additive operators (<a href='#6.5.6'>6.5.6</a>), relational operators (<a href='#6.5.8'>6.5.8</a>), equality
 | |
|     operators (<a href='#6.5.9'>6.5.9</a>), and compound assignment operators (<a href='#6.5.16.2'>6.5.16.2</a>), if either operand has decimal
 | |
|     floating type, the other operand shall not have standard floating type, binary floating type, complex
 | |
|     type, or imaginary type.
 | |
| </pre>
 | |
| <a name='H.6p4'></a>
 | |
| <pre>4   For conditional operators (<a href='#6.5.15'>6.5.15</a>), if the second or third operand has decimal floating type, the
 | |
|     other of those operands shall not have standard floating type, binary floating type, complex type, or
 | |
|     imaginary type.
 | |
| </pre>
 | |
| <a name='H.6p5'></a>
 | |
| <pre>5   The equivalence of expressions noted in <a href='#F.9.2'>F.9.2</a> apply to expressions of binary floating types, as well
 | |
|     as standard floating types.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.7'></a>
 | |
| <hr>
 | |
| <h3>H.7 [Declarations]</h3>
 | |
| <a name='H.7p1'></a>
 | |
| <pre>1   This subclause expands the list of type specifiers (<a href='#6.7.2'>6.7.2</a>) to also include:
 | |
| 
 | |
|       — _FloatN, where N is 16, 32, 64, or ≥ 128 and a multiple of 32
 | |
| 
 | |
|       — _Float32x
 | |
| 
 | |
|       — _Float64x
 | |
| 
 | |
|       — _Float128x
 | |
| 
 | |
|       — _DecimalN, where N is 96 or > 128 and a multiple of 32
 | |
| 
 | |
|       — _Decimal64x
 | |
| 
 | |
|       — _Decimal128x
 | |
| 
 | |
| </pre>
 | |
| <a name='H.7p2'></a>
 | |
| <pre>2   The type specifiers _FloatN (where N is 16, 32, 64, or ≥ 128 and a multiple of 32), _Float32x ,
 | |
|     _Float64x , _Float128x , _DecimalN (where N is 96 or > 128 and a multiple of 32), _Decimal64x ,
 | |
|     and _Decimal128x shall not be used if the implementation does not support the corresponding
 | |
|     types (see <a href='#6.10.9.3'>6.10.9.3</a> and <a href='#H.2'>H.2</a>).
 | |
| </pre>
 | |
| <a name='H.7p3'></a>
 | |
| <pre>3   This subclause also expands the list under Constraints in <a href='#6.7.2'>6.7.2</a> to also include:
 | |
| 
 | |
|       — _FloatN, where N is 16, 32, 64, or ≥ 128 and a multiple of 32
 | |
| 
 | |
|       — _Float32x
 | |
| 
 | |
|       — _Float64x
 | |
| 
 | |
|       — _Float128x
 | |
| 
 | |
|       — _DecimalN, where N is 96 or > 128 and a multiple of 32
 | |
|       — _Decimal64x
 | |
| 
 | |
|       — _Decimal128x
 | |
| 
 | |
|       — _FloatN _Complex , where N is 16, 32, 64, or ≥ 128 and a multiple of 32
 | |
| 
 | |
|       — _Float32x _Complex
 | |
| 
 | |
|       — _Float64x _Complex
 | |
| 
 | |
|       — _Float128x _Complex
 | |
| 
 | |
| </pre>
 | |
| <a name='H.8'></a>
 | |
| <hr>
 | |
| <h3>H.8 [Identifiers in standard headers]</h3>
 | |
| <a name='H.8p1'></a>
 | |
| <pre>1   The identifiers added to library headers by this annex are defined or declared by their respective
 | |
|     headers only if the macro __STDC_WANT_IEC_60559_TYPES_EXT__ is defined (by the user) at the
 | |
|     point in the code where the appropriate header is first included.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.9'></a>
 | |
| <hr>
 | |
| <h3>H.9 [Complex arithmetic <complex.h>]</h3>
 | |
| <a name='H.9p1'></a>
 | |
| <pre>1   This subclause specifies complex functions for corresponding real types that are binary floating
 | |
|     types.
 | |
| </pre>
 | |
| <a name='H.9p2'></a>
 | |
| <pre>2   Each function synopsis in <a href='#7.3'>7.3</a> specifies a family of functions including a principal function with
 | |
|     one or more double complex parameters and a double complex or double return value. This
 | |
|     subclause expands the synopsis to also include other functions, with the same name as the principal
 | |
|     function but with fN and fNx suffixes, which are corresponding functions whose parameters and
 | |
|     return values have corresponding real types _FloatN and _FloatNx.
 | |
| </pre>
 | |
| <a name='H.9p3'></a>
 | |
| <pre>3   The following function prototypes are added to the synopses of the respective subclauses in <a href='#7.3'>7.3</a>.
 | |
|     For each binary floating type that the implementation provides, <complex.h> shall declare the
 | |
|     associated functions (see <a href='#H.8'>H.8</a>). Conversely, for each such type that the implementation does not
 | |
|     provide, <complex.h> shall not declare the associated functions.
 | |
|     (<a href='#7.3.5'>7.3.5</a>) Trigonometric functions
 | |
|             _FloatN complex cacosfN(_FloatN complex z);
 | |
|             _FloatNx complex cacosfNx(_FloatNx complex z);
 | |
|             _FloatN complex casinfN(_FloatN complex z);
 | |
|             _FloatNx complex casinfNx(_FloatNx complex z);
 | |
|             _FloatN complex catanfN(_FloatN complex z);
 | |
|             _FloatNx complex catanfNx(_FloatNx complex z);
 | |
|             _FloatN complex ccosfN(_FloatN complex z);
 | |
|             _FloatNx complex ccosfNx(_FloatNx complex z);
 | |
|             _FloatN complex csinfN(_FloatN complex z);
 | |
|             _FloatNx complex csinfNx(_FloatNx complex z);
 | |
|             _FloatN complex ctanfN(_FloatN complex z);
 | |
|             _FloatNx complex ctanfNx(_FloatNx complex z);
 | |
| 
 | |
| 
 | |
|     (<a href='#7.3.6'>7.3.6</a>) Hyperbolic functions
 | |
|             _FloatN complex cacoshfN(_FloatN complex z);
 | |
|             _FloatNx complex cacoshfNx(_FloatNx complex z);
 | |
|             _FloatN complex casinhfN(_FloatN complex z);
 | |
|             _FloatNx complex casinhfNx(_FloatNx complex z);
 | |
|             _FloatN complex catanhfN(_FloatN complex z);
 | |
|             _FloatNx complex catanhfNx(_FloatNx complex z);
 | |
|             _FloatN complex ccoshfN(_FloatN complex z);
 | |
|             _FloatNx complex ccoshfNx(_FloatNx complex z);
 | |
|             _FloatN complex csinhfN(_FloatN complex z);
 | |
|             _FloatNx complex csinhfNx(_FloatNx complex z);
 | |
|             _FloatN complex ctanhfN(_FloatN complex z);
 | |
|             _FloatNx complex ctanhfNx(_FloatNx complex z);
 | |
|     (<a href='#7.3.7'>7.3.7</a>) Exponential and logarithmic functions
 | |
|             _FloatN complex cexpfN(_FloatN complex z);
 | |
|             _FloatNx complex cexpfNx(_FloatNx complex z);
 | |
|             _FloatN complex clogfN(_FloatN complex z);
 | |
|             _FloatNx complex clogfNx(_FloatNx complex z);
 | |
| 
 | |
| 
 | |
|     (<a href='#7.3.8'>7.3.8</a>) Power and absolute value functions
 | |
|             _FloatN cabsfN(_FloatN complex z);
 | |
|             _FloatNx cabsfNx(_FloatNx complex z);
 | |
|             _FloatN complex cpowfN(_FloatN complex x, _FloatN complex y);
 | |
|             _FloatNx complex cpowfNx(_FloatNx complex x, _FloatNx complex y);
 | |
|             _FloatN complex csqrtfN(_FloatN complex z);
 | |
|             _FloatNx complex csqrtfNx(_FloatNx complex z);
 | |
| 
 | |
| 
 | |
|     (<a href='#7.3.9'>7.3.9</a>) Manipulation functions
 | |
|             _FloatN cargfN(_FloatN complex z);
 | |
|             _FloatNx cargfNx(_FloatNx complex z);
 | |
|             _FloatN cimagfN(_FloatN complex z);
 | |
|             _FloatNx cimagfNx(_FloatNx complex z);
 | |
|             _FloatN complex CMPLXFN(_FloatN x, _FloatN y);
 | |
|             _FloatNx complex CMPLXFNX(_FloatNx x, _FloatNx y);
 | |
|             _FloatN complex conjfN(_FloatN complex z);
 | |
|             _FloatNx complex conjfNx(_FloatNx complex z);
 | |
|             _FloatN complex cprojfN(_FloatN complex z);
 | |
|             _FloatNx complex cprojfNx(_FloatNx complex z);
 | |
|             _FloatN crealfN(_FloatN complex z);
 | |
|             _FloatNx crealfNx(_FloatNx complex z);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.9p4'></a>
 | |
| <pre>4   For the functions listed in "future library directions" for <complex.h> (<a href='#7.33.1'>7.33.1</a>), the possible suffixes
 | |
|     are expanded to also include fN and fNx.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.10'></a>
 | |
| <hr>
 | |
| <h3>H.10 [Floating-point environment]</h3>
 | |
| <a name='H.10p1'></a>
 | |
| <pre>1   This subclause broadens the effects of the floating-point environment (<a href='#7.6'>7.6</a>) to apply to types and
 | |
|     formats specified in this annex.
 | |
| </pre>
 | |
| <a name='H.10p2'></a>
 | |
| <pre>2   The same floating-point status flags are used by floating-point operations for all floating types,
 | |
|     including those types introduced in this annex, and by conversions for IEC 60559 non-arithmetic
 | |
|     interchange formats.
 | |
| </pre>
 | |
| <a name='H.10p3'></a>
 | |
| <pre>3   Both the dynamic rounding direction mode accessed by fegetround and fesetround and the
 | |
|     FENV_ROUND rounding control pragma apply to operations for binary floating types, as well as
 | |
|     for standard floating types, and also to conversions for radix-2 non-arithmetic interchange for-
 | |
|     mats. Likewise, both the dynamic rounding direction mode accessed by fe_dec_getround and
 | |
|     fe_dec_setround and the FENV_DEC_ROUND rounding control pragmas apply to operations for all
 | |
|     the decimal floating types, including those decimal floating types introduced in this annex, and to
 | |
|     conversions for radix-10 non-arithmetic interchange formats.
 | |
| </pre>
 | |
| <a name='H.10p4'></a>
 | |
| <pre>4   In <a href='#7.6.2'>7.6.2</a>, the table of functions affected by constant rounding modes for standard floating types
 | |
|     applies also for binary floating types. Each <math.h> function family listed in the table indicates
 | |
|     the family of functions of all standard and binary floating types (for example, the acos family
 | |
|     includes acosf, acosl, acosfN, and acosfNx as well as acos). The fMencfN, strfromencfN, and
 | |
|     strtoencfN functions are also affected by these constant rounding modes.
 | |
| </pre>
 | |
| <a name='H.10p5'></a>
 | |
| <pre>5   In <a href='#7.6.3'>7.6.3</a>, in the table of functions affected by constant rounding modes for decimal floating types, each
 | |
|     <math.h> function family indicates the family of functions of all decimal floating types (for example,
 | |
|     the acos family includes acosdN and acosdNx). The dMencbindN, dMencdecdN, strfromencbindN,
 | |
|     strfromencdecdN, strtoencbindN, and strtoencdecdN functions are also affected by these con-
 | |
|     stant rounding modes.
 | |
| </pre>
 | |
| <a name='H.11'></a>
 | |
| <hr>
 | |
| <h3>H.11 [Mathematics <math.h>]</h3>
 | |
| <a name='H.11p1'></a>
 | |
| <pre>1     This subclause specifies types, functions, and macros for interchange and extended floating types,
 | |
|       generally corresponding to those specified in <a href='#7.12'>7.12</a> and <a href='#F.10'>F.10</a>.
 | |
| </pre>
 | |
| <a name='H.11p2'></a>
 | |
| <pre>2     All classification macros (<a href='#7.12.3'>7.12.3</a>) and comparison macros (<a href='#7.12.17'>7.12.17</a>) naturally extend to handle inter-
 | |
|       change and extended floating types. For comparison macros, if neither of the sets of values of the
 | |
|       argument formats is a subset of (or equivalent to) the other, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='H.11p3'></a>
 | |
| <pre>3     This subclause also specifies encoding conversion functions that are part of support for the non-
 | |
|       arithmetic interchange formats in IEC 60559 (see <a href='#H.2.2'>H.2.2</a>).
 | |
| </pre>
 | |
| <a name='H.11p4'></a>
 | |
| <pre>4     Most function synopses in <a href='#7.12'>7.12</a> specify a family of functions including a principal function with
 | |
|       one or more double parameters, a double return value, or both. The synopses are expanded to
 | |
|       also include functions with the same name as the principal function but with fN, fNx, dN, and dNx
 | |
|       suffixes, which are corresponding functions whose parameters, return values, or both are of types
 | |
|       _FloatN, _FloatNx , _DecimalN, and _DecimalNx, respectively.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11p5'></a>
 | |
| <pre>5     For each interchange or extended floating type that the implementation provides, <math.h> shall
 | |
|       define the associated types and macros and declare the associated functions (see <a href='#H.8'>H.8</a>). Conversely, for
 | |
|       each such type that the implementation does not provide, <math.h> shall not define the associated
 | |
|       types and macros or declare the associated functions unless explicitly specified otherwise.
 | |
| </pre>
 | |
| <a name='H.11p6'></a>
 | |
| <pre>6     With the types
 | |
| 
 | |
|                float_t
 | |
|                double_t
 | |
| 
 | |
| 
 | |
|       in <a href='#7.12'>7.12</a> are included the type
 | |
| 
 | |
|                long_double_t
 | |
| 
 | |
| 
 | |
|       and for each supported type _FloatN, the type
 | |
|                _FloatN_t
 | |
| 
 | |
| 
 | |
|       and for each supported type _DecimalN , the type
 | |
|                _DecimalN_t
 | |
| 
 | |
| 
 | |
|       These are floating types, such that:
 | |
| 
 | |
|         — each of the types has at least the range and precision of the corresponding real floating type;
 | |
| 
 | |
|         — long_double_t has at least the range and precision of double_t;
 | |
|     — _FloatN_t
 | |
|              has at least the range and precision of _FloatM_t if N > M ;
 | |
|     — _DecimalN_t
 | |
|              has at least the range and precision of _DecimalM_t if N > M .
 | |
| 
 | |
|       If FLT_RADIX is 2 and FLT_EVAL_METHOD (<a href='#H.3'>H.3</a>) is nonnegative, then each of the types corresponding
 | |
|       to a standard or binary floating type is the type whose range and precision are specified by
 | |
|       FLT_EVAL_METHOD to be used for evaluating operations and constants of that standard or binary
 | |
|       floating type. If DEC_EVAL_METHOD (<a href='#H.3'>H.3</a>) is nonnegative, then each of the types corresponding to a
 | |
|       decimal floating type is the type whose range and precision are specified by DEC_EVAL_METHOD to
 | |
|       be used for evaluating operations and constants of that decimal floating type.
 | |
| </pre>
 | |
| <a name='H.11p7'></a>
 | |
| <pre>7     EXAMPLE If the supported standard and binary floating types are
 | |
|                                                 Type                      IEC 60559 format
 | |
|                                              _Float16                          binary16
 | |
|                                          float, _Float32                       binary32
 | |
|                                    double, _Float64 , _Float32x                binary64
 | |
|                                      long double, _Float64x           80-bit binary64-extended
 | |
|                                             _Float128                         binary128
 | |
| 
 | |
| 
 | |
|     then the following tables gives the types with _t suffixes for various values for a FLT_EVAL_METHOD of a given value m:
 | |
| 
 | |
|                          _t type/m              0                1                2                32
 | |
|                         _Float16_t            float           double        long double        _Float32
 | |
|                           float_t             float           double        long double          float
 | |
|                         _Float32_t          _Float32          double        long double        _Float32
 | |
|                           double_t           double           double        long double         double
 | |
|                         _Float64_t          _Float64        _Float64        long double        _Float64
 | |
|                        long_double_t      long double      long double      long double      long double
 | |
|                         _Float128_t        _Float128        _Float128        _Float128        _Float128
 | |
| 
 | |
|                            _t type/m             64             128              33               65
 | |
|                           _Float16_t         _Float64       _Float128       _Float32x        _Float64x
 | |
|                             float_t          _Float64       _Float128       _Float32x        _Float64x
 | |
|                           _Float32_t         _Float64       _Float128       _Float32x        _Float64x
 | |
|                             double_t           double       _Float128         double         _Float64x
 | |
|                           _Float64_t          _Float64      _Float128        _Float64        _Float64x
 | |
|                         long_double_t       long double     _Float128      long double      long double
 | |
|                          _Float128_t         _Float128      _Float128       _Float128        _Float128
 | |
| 
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.1'></a>
 | |
| <hr>
 | |
| <h3>H.11.1 [Macros]</h3>
 | |
| <a name='H.11.1p1'></a>
 | |
| <pre>1   This subclause adds macros in <a href='#7.12'>7.12</a> as follows.
 | |
| </pre>
 | |
| <a name='H.11.1p2'></a>
 | |
| <pre>2   The macros
 | |
| 
 | |
|               HUGE_VAL_FN
 | |
|               HUGE_VAL_DN
 | |
|               HUGE_VAL_FNX
 | |
|               HUGE_VAL_DNX
 | |
| 
 | |
| 
 | |
|     expand to constant expressions of types _FloatN, _DecimalN, _FloatNx, and _DecimalNx, respec-
 | |
|     tively, representing positive infinity.
 | |
| </pre>
 | |
| <a name='H.11.1p3'></a>
 | |
| <pre>3   The macros
 | |
| 
 | |
|               FP_FAST_FMAFN
 | |
|               FP_FAST_FMADN
 | |
|               FP_FAST_FMAFNX
 | |
|               FP_FAST_FMADNX
 | |
| 
 | |
| 
 | |
|     are, respectively, _FloatN, _DecimalN, _FloatNx, and _DecimalNx analogues of FP_FAST_FMA.
 | |
| </pre>
 | |
| <a name='H.11.1p4'></a>
 | |
| <pre>4   The macros in the following lists are interchange and extended floating type analogues of
 | |
|     FP_FAST_FADD, FP_FAST_FADDL, FP_FAST_DADDL, etc.
 | |
| </pre>
 | |
| <a name='H.11.1p5'></a>
 | |
| <pre>5   For M < N , the macros
 | |
| 
 | |
|               FP_FAST_FMADDFN
 | |
|               FP_FAST_FMSUBFN
 | |
|               FP_FAST_FMMULFN
 | |
|               FP_FAST_FMDIVFN
 | |
|               FP_FAST_FMFMAFN
 | |
|               FP_FAST_FMSQRTFN
 | |
|               FP_FAST_DMADDDN
 | |
|               FP_FAST_DMSUBDN
 | |
|               FP_FAST_DMMULDN
 | |
|               FP_FAST_DMDIVDN
 | |
|             FP_FAST_DMFMADN
 | |
|             FP_FAST_DMSQRTDN
 | |
| 
 | |
| 
 | |
|     characterize the corresponding functions whose arguments are of an interchange floating type of
 | |
|     width N and whose return type is an interchange floating type of width M .
 | |
| </pre>
 | |
| <a name='H.11.1p6'></a>
 | |
| <pre>6   For M ≤ N , the macros
 | |
| 
 | |
|             FP_FAST_FMADDFNX
 | |
|             FP_FAST_FMSUBFNX
 | |
|             FP_FAST_FMMULFNX
 | |
|             FP_FAST_FMDIVFNX
 | |
|             FP_FAST_FMFMAFNX
 | |
|             FP_FAST_FMSQRTFNX
 | |
|             FP_FAST_DMADDDNX
 | |
|             FP_FAST_DMSUBDNX
 | |
|             FP_FAST_DMMULDNX
 | |
|             FP_FAST_DMDIVDNX
 | |
|             FP_FAST_DMFMADNX
 | |
|             FP_FAST_DMSQRTDNX
 | |
| 
 | |
| 
 | |
|     characterize the corresponding functions whose arguments are of an extended floating type that
 | |
|     extends a format of width N and whose return type is an interchange floating type of width M .
 | |
| </pre>
 | |
| <a name='H.11.1p7'></a>
 | |
| <pre>7   For M < N , the macros
 | |
| 
 | |
|             FP_FAST_FMXADDFN
 | |
|             FP_FAST_FMXSUBFN
 | |
|             FP_FAST_FMXMULFN
 | |
|             FP_FAST_FMXDIVFN
 | |
|             FP_FAST_FMXFMAFN
 | |
|             FP_FAST_FMXSQRTFN
 | |
|             FP_FAST_DMXADDDN
 | |
|             FP_FAST_DMXSUBDN
 | |
|             FP_FAST_DMXMULDN
 | |
|             FP_FAST_DMXDIVDN
 | |
|             FP_FAST_DMXFMADN
 | |
|             FP_FAST_DMXSQRTDN
 | |
| 
 | |
| 
 | |
|     characterize the corresponding functions whose arguments are of an interchange floating type of
 | |
|     width N and whose return type is an extended floating type that extends a format of width M .
 | |
| </pre>
 | |
| <a name='H.11.1p8'></a>
 | |
| <pre>8   For M < N , the macros
 | |
| 
 | |
|             FP_FAST_FMXADDFNX
 | |
|             FP_FAST_FMXSUBFNX
 | |
|             FP_FAST_FMXMULFNX
 | |
|             FP_FAST_FMXDIVFNX
 | |
|             FP_FAST_FMXFMAFNX
 | |
|             FP_FAST_FMXSQRTFNX
 | |
|             FP_FAST_DMXADDDNX
 | |
|             FP_FAST_DMXSUBDNX
 | |
|             FP_FAST_DMXMULDNX
 | |
|             FP_FAST_DMXDIVDNX
 | |
|             FP_FAST_DMXFMADNX
 | |
|             FP_FAST_DMXSQRTDNX
 | |
| 
 | |
| 
 | |
|     characterize the corresponding functions whose arguments are of an extended floating type that
 | |
|     extends a format of width N and whose return type is an extended floating type that extends a
 | |
|     format of width M .
 | |
| </pre>
 | |
| <a name='H.11.2'></a>
 | |
| <hr>
 | |
| <h3>H.11.2 [Functions]</h3>
 | |
| <a name='H.11.2p1'></a>
 | |
| <pre>1   This sublause adds the following functions to the synopses of the respective subclauses in <a href='#7.12'>7.12</a>.
 | |
|     (<a href='#7.12.4'>7.12.4</a>) Trigonometric functions
 | |
|              _FloatN acosfN(_FloatN x);
 | |
|              _FloatNx acosfNx(_FloatNx x);
 | |
|              _DecimalN acosdN(_DecimalN x);
 | |
|              _DecimalNx acosdNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN asinfN(_FloatN x);
 | |
|              _FloatNx asinfNx(_FloatNx x);
 | |
|              _DecimalN asindN(_DecimalN x);
 | |
|              _DecimalNx asindNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN atanfN(_FloatN x);
 | |
|              _FloatNx atanfNx(_FloatNx x);
 | |
|              _DecimalN atandN(_DecimalN x);
 | |
|              _DecimalNx atandNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN atan2fN(_FloatN y, _FloatN x);
 | |
|              _FloatNx atan2fNx(_FloatNx y, _FloatNx x);
 | |
|              _DecimalN atan2dN(_DecimalN y, _DecimalN x);
 | |
|              _DecimalNx atan2dNx(_DecimalNx y, _DecimalNx x);
 | |
| 
 | |
|              _FloatN cosfN(_FloatN x);
 | |
|              _FloatNx cosfNx(_FloatNx x);
 | |
|              _DecimalN cosdN(_DecimalN x);
 | |
|              _DecimalNx cosdNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN sinfN(_FloatN x);
 | |
|              _FloatNx sinfNx(_FloatNx x);
 | |
|              _DecimalN sindN(_DecimalN x);
 | |
|              _DecimalNx sindNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN tanfN(_FloatN x);
 | |
|              _FloatNx tanfNx(_FloatNx x);
 | |
|              _DecimalN tandN(_DecimalN x);
 | |
|              _DecimalNx tandNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN acospifN(_FloatN x);
 | |
|              _FloatNx acospifNx(_FloatNx x);
 | |
|              _DecimalN acospidN(_DecimalN x);
 | |
|              _DecimalNx acospidNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN asinpifN(_FloatN x);
 | |
|              _FloatNx asinpifNx(_FloatNx x);
 | |
|              _DecimalN asinpidN(_DecimalN x);
 | |
|              _DecimalNx asinpidNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN atanpifN(_FloatN x);
 | |
|              _FloatNx atanpifNx(_FloatNx x);
 | |
|              _DecimalN atanpidN(_DecimalN x);
 | |
|              _DecimalNx atanpidNx(_DecimalNx x);
 | |
| 
 | |
|              _FloatN atan2pifN(_FloatN y, _FloatN x);
 | |
|              _FloatNx atan2pifNx(_FloatNx y, _FloatNx x);
 | |
|              _DecimalN atan2pidN(_DecimalN y, _DecimalN x);
 | |
|              _DecimalNx atan2pidNx(_DecimalNx y, _DecimalNx x);
 | |
| 
 | |
|              _FloatN cospifN(_FloatN x);
 | |
|              _FloatNx cospifNx(_FloatNx x);
 | |
|         _DecimalN cospidN(_DecimalN x);
 | |
|         _DecimalNx cospidNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN sinpifN(_FloatN x);
 | |
|         _FloatNx sinpifNx(_FloatNx x);
 | |
|         _DecimalN sinpidN(_DecimalN x);
 | |
|         _DecimalNx sinpidNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN tanpifN(_FloatN x);
 | |
|         _FloatNx tanpifNx(_FloatNx x);
 | |
|         _DecimalN tanpidN(_DecimalN x);
 | |
|         _DecimalNx tanpidNx(_DecimalNx x);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.5'>7.12.5</a>) Hyperbolic functions
 | |
|         _FloatN acoshfN(_FloatN x);
 | |
|         _FloatNx acoshfNx(_FloatNx x);
 | |
|         _DecimalN acoshdN(_DecimalN x);
 | |
|         _DecimalNx acoshdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN asinhfN(_FloatN x);
 | |
|         _FloatNx asinhfNx(_FloatNx x);
 | |
|         _DecimalN asinhdN(_DecimalN x);
 | |
|         _DecimalNx asinhdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN atanhfN(_FloatN x);
 | |
|         _FloatNx atanhfNx(_FloatNx x);
 | |
|         _DecimalN atanhdN(_DecimalN x);
 | |
|         _DecimalNx atanhdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN coshfN(_FloatN x);
 | |
|         _FloatNx coshfNx(_FloatNx x);
 | |
|         _DecimalN coshdN(_DecimalN x);
 | |
|         _DecimalNx coshdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN sinhfN(_FloatN x);
 | |
|         _FloatNx sinhfNx(_FloatNx x);
 | |
|         _DecimalN sinhdN(_DecimalN x);
 | |
|         _DecimalNx sinhdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN tanhfN(_FloatN x);
 | |
|         _FloatNx tanhfNx(_FloatNx x);
 | |
|         _DecimalN tanhdN(_DecimalN x);
 | |
|         _DecimalNx tanhdNx(_DecimalNx x);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.6'>7.12.6</a>) Exponential and logarithmic functions
 | |
|         _FloatN expfN(_FloatN x);
 | |
|         _FloatNx expfNx(_FloatNx x);
 | |
|         _DecimalN expdN(_DecimalN x);
 | |
|         _DecimalNx expdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN exp10fN(_FloatN x);
 | |
|         _FloatNx exp10fNx(_FloatNx x);
 | |
|         _DecimalN exp10dN(_DecimalN x);
 | |
|         _DecimalNx exp10dNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN exp10m1fN(_FloatN x);
 | |
|         _FloatNx exp10m1fNx(_FloatNx x);
 | |
|         _DecimalN exp10m1dN(_DecimalN x);
 | |
|         _DecimalNx exp10m1dNx(_DecimalNx x);
 | |
| _FloatN exp2fN(_FloatN x);
 | |
| _FloatNx exp2fNx(_FloatNx x);
 | |
| _DecimalN exp2dN(_DecimalN x);
 | |
| _DecimalNx exp2dNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN exp2m1fN(_FloatN x);
 | |
| _FloatNx exp2m1fNx(_FloatNx x);
 | |
| _DecimalN exp2m1dN(_DecimalN x);
 | |
| _DecimalNx exp2m1dNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN expm1fN(_FloatN x);
 | |
| _FloatNx expm1fNx(_FloatNx x);
 | |
| _DecimalN expm1dN(_DecimalN x);
 | |
| _DecimalNx expm1dNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN frexpfN(_FloatN value, int *exp);
 | |
| _FloatNx frexpfNx(_FloatNx value, int *exp);
 | |
| _DecimalN frexpdN(_DecimalN value, int *exp);
 | |
| _DecimalNx frexpdNx(_DecimalNx value, int *exp);
 | |
| 
 | |
| int ilogbfN(_FloatN x);
 | |
| int ilogbfNx(_FloatNx x);
 | |
| int ilogbdN(_DecimalNx x);
 | |
| int ilogbdNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN ldexpfN(_FloatN value, int exp);
 | |
| _FloatNx ldexpfNx(_FloatNx value, int exp);
 | |
| _DecimalN ldexpdN(_DecimalN value, int exp);
 | |
| _DecimalNx ldexpdNx(_DecimalNx value, int exp);
 | |
| 
 | |
| long int llogbfN(_FloatN x);
 | |
| long int llogbfNx(_FloatNx x);
 | |
| long int llogbdN(_DecimalN x);
 | |
| long int llogbdNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN logfN(_FloatN x);
 | |
| _FloatNx logfNx(_FloatNx x);
 | |
| _DecimalN logdN(_DecimalN x);
 | |
| _DecimalNx logdNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN log10fN(_FloatN x);
 | |
| _FloatNx log10fNx(_FloatNx x);
 | |
| _DecimalN log10dN(_DecimalN x);
 | |
| _DecimalNx log10dNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN log10p1fN(_FloatN x);
 | |
| _FloatNx log10p1fNx(_FloatNx x);
 | |
| _DecimalN log10p1dN(_DecimalN x);
 | |
| _DecimalNx log10p1dNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN log1pfN(_FloatN x);
 | |
| _FloatNx log1pfNx(_FloatNx x);
 | |
| _FloatN logp1fN(_FloatN x);
 | |
| _FloatNx logp1fNx(_FloatNx x);
 | |
| _DecimalN log1pdN(_DecimalN x);
 | |
| _DecimalNx log1pdNx(_DecimalNx x);
 | |
| _DecimalN logp1dN(_DecimalN x);
 | |
| _DecimalNx logp1dNx(_DecimalNx x);
 | |
| 
 | |
| _FloatN log2fN(_FloatN x);
 | |
|        _FloatNx log2fNx(_FloatNx x);
 | |
|        _DecimalN log2dN(_DecimalN x);
 | |
|        _DecimalNx log2dNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN log2p1fN(_FloatN x);
 | |
|        _FloatNx log2p1fNx(_FloatNx x);
 | |
|        _DecimalN log2p1dN(_DecimalN x);
 | |
|        _DecimalNx log2p1dNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN logbfN(_FloatN x);
 | |
|        _FloatNx logbfNx(_FloatNx x);
 | |
|        _DecimalN logbdN(_DecimalN x);
 | |
|        _DecimalNx logbdNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN modffN(_FloatN x, _FloatN *iptr);
 | |
|        _FloatNx modffNx(_FloatNx x, _FloatNx *iptr);
 | |
|        _DecimalN modfdN(_DecimalN x, _DecimalN *iptr);
 | |
|        _DecimalNx modfdNx(_DecimalNx x, _DecimalNx *iptr);
 | |
| 
 | |
|        _FloatN scalbnfN(_FloatN value, int exp);
 | |
|        _FloatNx scalbnfNx(_FloatNx value, int exp);
 | |
|        _DecimalN scalbndN(_DecimalN value, int exp);
 | |
|        _DecimalNx scalbndNx(_DecimalNx value, int exp);
 | |
| 
 | |
|        _FloatN scalblnfN(_FloatN value, long int exp);
 | |
|        _FloatNx scalblnfNx(_FloatNx value, long int exp);
 | |
|        _DecimalN scalblndN(_DecimalN value, long int exp);
 | |
|        _DecimalNx scalblndNx(_DecimalNx value, long int exp);
 | |
| 
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.7'>7.12.7</a>) Power and absolute-value functions
 | |
|        _FloatN cbrtfN(_FloatN x);
 | |
|        _FloatNx cbrtfNx(_FloatNx x);
 | |
|        _DecimalN cbrtdN(_DecimalN x);
 | |
|        _DecimalNx cbrtdNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN compoundnfN(_FloatN x, long long int n);
 | |
|        _FloatNx compoundnfNx(_FloatNx x, long long int n);
 | |
|        _DecimalN compoundndN(_DecimalN x, long long int n);
 | |
|        _DecimalNx compoundndNx(_DecimalNx x, long long int n);
 | |
| 
 | |
|        _FloatN fabsfN(_FloatN x);
 | |
|        _FloatNx fabsfNx(_FloatNx x);
 | |
|        _DecimalN fabsdN(_DecimalN x);
 | |
|        _DecimalNx fabsdNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN hypotfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx hypotfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN hypotdN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx hypotdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN powfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx powfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN powdN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx powdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN pownfN(_FloatN x, long long int n);
 | |
|        _FloatNx pownfNx(_FloatNx x, long long int n);
 | |
|        _DecimalN powndN(_DecimalN x, long long int n);
 | |
|        _DecimalNx powndNx(_DecimalNx x, long long int n);
 | |
|         _FloatN powrfN(_FloatN x, _FloatN y);
 | |
|         _FloatNx powrfNx(_FloatNx x, _FloatNx y);
 | |
|         _DecimalN powrdN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx powrdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         _FloatN rootnfN(_FloatN x, long long int n);
 | |
|         _FloatNx rootnfNx(_FloatNx x, long long int n);
 | |
|         _DecimalN rootndN(_DecimalN x, long long int n);
 | |
|         _DecimalNx rootndNx(_DecimalNx x, long long int n);
 | |
| 
 | |
|         _FloatN rsqrtfN(_FloatN x);
 | |
|         _FloatNx rsqrtfNx(_FloatNx x);
 | |
|         _DecimalN rsqrtdN(_DecimalN x);
 | |
|         _DecimalNx rsqrtdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN sqrtfN(_FloatN x);
 | |
|         _FloatNx sqrtfNx(_FloatNx x);
 | |
|         _DecimalN sqrtdN(_DecimalN x);
 | |
|         _DecimalNx sqrtdNx(_DecimalNx x);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.8'>7.12.8</a>) Error and gamma functions
 | |
|         _FloatN erffN(_FloatN x);
 | |
|         _FloatNx erffNx(_FloatNx x);
 | |
|         _DecimalN erfdN(_DecimalN x);
 | |
|         _DecimalNx erfdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN erfcfN(_FloatN x);
 | |
|         _FloatNx erfcfNx(_FloatNx x);
 | |
|         _DecimalN erfcdN(_DecimalN x);
 | |
|         _DecimalNx erfcdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN lgammafN(_FloatN x);
 | |
|         _FloatNx lgammafNx(_FloatNx x);
 | |
|         _DecimalN lgammadN(_DecimalN x);
 | |
|         _DecimalNx lgammadNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN tgammafN(_FloatN x);
 | |
|         _FloatNx tgammafNx(_FloatNx x);
 | |
|         _DecimalN tgammadN(_DecimalN x);
 | |
|         _DecimalNx tgammadNx(_DecimalNx x);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.9'>7.12.9</a>) Nearest integer functions
 | |
|         _FloatN ceilfN(_FloatN x);
 | |
|         _FloatNx ceilfNx(_FloatNx x);
 | |
|         _DecimalN ceildN(_DecimalN x);
 | |
|         _DecimalNx ceildNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN floorfN(_FloatN x);
 | |
|         _FloatNx floorfNx(_FloatNx x);
 | |
|         _DecimalN floordN(_DecimalN x);
 | |
|         _DecimalNx floordNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN nearbyintfN(_FloatN x);
 | |
|         _FloatNx nearbyintfNx(_FloatNx x);
 | |
|         _DecimalN nearbyintdN(_DecimalN x);
 | |
|         _DecimalNx nearbyintdNx(_DecimalNx x);
 | |
| 
 | |
|         _FloatN rintfN(_FloatN x);
 | |
|         _FloatNx rintfNx(_FloatNx x);
 | |
|        _DecimalN rintdN(_DecimalN x);
 | |
|        _DecimalNx rintdNx(_DecimalNx x);
 | |
| 
 | |
|        long int lrintfN(_FloatN x);
 | |
|        long int lrintfNx(_FloatNx x);
 | |
|        long int lrintdN(_DecimalN x);
 | |
|        long int lrintdNx(_DecimalNx x);
 | |
| 
 | |
|        long long int llrintfN(_FloatN x);
 | |
|        long long int llrintfNx(_FloatNx x);
 | |
|        long long int llrintdN(_DecimalN x);
 | |
|        long long int llrintdNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN roundfN(_FloatN x);
 | |
|        _FloatNx roundfNx(_FloatNx x);
 | |
|        _DecimalN rounddN(_DecimalN x);
 | |
|        _DecimalNx rounddNx(_DecimalNx x);
 | |
| 
 | |
|        long int lroundfN(_FloatN x);
 | |
|        long int lroundfNx(_FloatNx x);
 | |
|        long int lrounddN(_DecimalN x);
 | |
|        long int lrounddNx(_DecimalNx x);
 | |
| 
 | |
|        long long int llroundfN(_FloatN x);
 | |
|        long long int llroundfNx(_FloatNx x);
 | |
|        long long int llrounddN(_DecimalN x);
 | |
|        long long int llrounddNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN roundevenfN(_FloatN x);
 | |
|        _FloatNx roundevenfNx(_FloatNx x);
 | |
|        _DecimalN roundevendN(_DecimalN x);
 | |
|        _DecimalNx roundevendNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN truncfN(_FloatN x);
 | |
|        _FloatNx truncfNx(_FloatNx x);
 | |
|        _DecimalN truncdN(_DecimalN x);
 | |
|        _DecimalNx truncdNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN fromfpfN(_FloatN x, int rnd, unsigned int width);
 | |
|        _FloatNx fromfpfNx(_FloatNx x, int rnd, unsigned int width);
 | |
|        _DecimalN fromfpdN(_DecimalN x, int rnd, unsigned int width);
 | |
|        _DecimalNx fromfpdNx(_DecimalNx x, int rnd, unsigned int width);
 | |
|        _FloatN ufromfpfN(_FloatN x, int rnd, unsigned int width);
 | |
|        _FloatNx ufromfpfNx(_FloatNx x, int rnd, unsigned int width);
 | |
|        _DecimalN ufromfpdN(_DecimalN x, int rnd, unsigned int width);
 | |
|        _DecimalNx ufromfpdNx(_DecimalNx x, int rnd, unsigned int width);
 | |
| 
 | |
|        _FloatN fromfpxfN(_FloatN x, int rnd, unsigned int width);
 | |
|        _FloatNx fromfpxfNx(_FloatNx x, int rnd, unsigned int width);
 | |
|        _DecimalN fromfpxdN(_DecimalN x, int rnd, unsigned int width);
 | |
|        _DecimalNx fromfpxdNx(_DecimalNx x, int rnd, unsigned int width);
 | |
|        _FloatN ufromfpxfN(_FloatN x, int rnd, unsigned int width);
 | |
|        _FloatNx ufromfpxfNx(_FloatNx x, int rnd, unsigned int width);
 | |
|        _DecimalN ufromfpxdN(_DecimalN x, int rnd, unsigned int width);
 | |
|        _DecimalNx ufromfpxdNx(_DecimalNx x, int rnd, unsigned int width);
 | |
| 
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.10.2'>7.12.10.2</a>) Remainder functions
 | |
|        _FloatN fmodfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx fmodfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN fmoddN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx fmoddNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN remainderfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx remainderfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN remainderdN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx remainderdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN remquofN(_FloatN x, _FloatN y, int *quo);
 | |
|        _FloatNx remquofNx(_FloatNx x, _FloatNx y, int *quo);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.11'>7.12.11</a>) Manipulation functions
 | |
|        _FloatN copysignfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx copysignfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN copysigndN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx copysigndNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN nanfN(const char *tagp);
 | |
|        _FloatNx nanfNx(const char *tagp);
 | |
|        _DecimalN nandN(const char *tagp);
 | |
|        _DecimalNx nandNx(const char *tagp);
 | |
| 
 | |
|        _FloatN nextafterfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx nextafterfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN nextafterdN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx nextafterdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN nextupfN(_FloatN x);
 | |
|        _FloatNx nextupfNx(_FloatNx x);
 | |
|        _DecimalN nextupdN(_DecimalN x);
 | |
|        _DecimalNx nextupdNx(_DecimalNx x);
 | |
| 
 | |
|        _FloatN nextdownfN(_FloatN x);
 | |
|        _FloatNx nextdownfNx(_FloatNx x);
 | |
|        _DecimalN nextdowndN(_DecimalN x);
 | |
|        _DecimalNx nextdowndNx(_DecimalNx x);
 | |
| 
 | |
|        int canonicalizefN(_FloatN * cx, const _FloatN * x);
 | |
|        int canonicalizefNx(_FloatNx * cx, const _FloatNx * x);
 | |
|        int canonicalizedN(_DecimalN * cx, const _DecimalN * x);
 | |
|        int canonicalizedNx(_DecimalNx * cx, const _DecimalNx * x);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.12'>7.12.12</a>) Maximum, minimum, and positive difference functions
 | |
|        _FloatN fdimfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx fdimfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN fdimdN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx fdimdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN fmaximumfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx fmaximumfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN fmaximumdN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx fmaximumdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN fminimumfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx fminimumfNx(_FloatNx x, _FloatNx y);
 | |
|        _DecimalN fminimumdN(_DecimalN x, _DecimalN y);
 | |
|        _DecimalNx fminimumdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|        _FloatN fmaximum_magfN(_FloatN x, _FloatN y);
 | |
|        _FloatNx fmaximum_magfNx(_FloatNx x, _FloatNx y);
 | |
|         _DecimalN fmaximum_magdN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx fmaximum_magdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         _FloatN fminimum_magfN(_FloatN x, _FloatN y);
 | |
|         _FloatNx fminimum_magfNx(_FloatNx x, _FloatNx y);
 | |
|         _DecimalN fminimum_magdN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx fminimum_magdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         _FloatN fmaximum_numfN(_FloatN x, _FloatN y);
 | |
|         _FloatNx fmaximum_numfNx(_FloatNx x, _FloatNx y);
 | |
|         _DecimalN fmaximum_numdN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx fmaximum_numdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         _FloatN fminimum_numfN(_FloatN x, _FloatN y);
 | |
|         _FloatNx fminimum_numfNx(_FloatNx x, _FloatNx y);
 | |
|         _DecimalN fminimum_numdN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx fminimum_numdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         _FloatN fmaximum_mag_numfN(_FloatN x, _FloatN y);
 | |
|         _FloatNx fmaximum_mag_numfNx(_FloatNx x, _FloatNx y);
 | |
|         _DecimalN fmaximum_mag_numdN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx fmaximum_mag_numdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         _FloatN fminimum_mag_numfN(_FloatN x, _FloatN y);
 | |
|         _FloatNx fminimum_mag_numfNx(_FloatNx x, _FloatNx y);
 | |
|         _DecimalN fminimum_mag_numdN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx fminimum_mag_numdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.13.1'>7.12.13.1</a>) Fused multiply-add
 | |
|         _FloatN fmafN(_FloatN x, _FloatN y, _FloatN z);
 | |
|         _FloatNx fmafNx(_FloatNx x, _FloatNx y, _FloatNx z);
 | |
|         _DecimalN fmadN(_DecimalN x, _DecimalN y, _DecimalN z);
 | |
|         _DecimalNx fmadNx(_DecimalNx x, _DecimalNx y, _DecimalNx z);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.14'>7.12.14</a>) Functions that round result to narrower type
 | |
|         _FloatM fMaddfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatM fMaddfNx(_FloatNx x, _FloatNx y); // M ≤ N
 | |
|         _FloatMx fMxaddfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatMx fMxaddfNx(_FloatNx x, _FloatNx y); // M < N
 | |
|         _DecimalM dMadddN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalM dMadddNx(_DecimalNx x, _DecimalNx y); // M ≤ N
 | |
|         _DecimalMx dMxadddN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalMx dMxadddNx(_DecimalNx x, _DecimalNx y); // M < N
 | |
| 
 | |
|         _FloatM fMsubfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatM fMsubfNx(_FloatNx x, _FloatNx y); // M ≤ N
 | |
|         _FloatMx fMxsubfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatMx fMxsubfNx(_FloatNx x, _FloatNx y); // M < N
 | |
|         _DecimalM dMsubdN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalM dMsubdNx(_DecimalNx x, _DecimalNx y); // M ≤ N
 | |
|         _DecimalMx dMxsubdN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalMx dMxsubdNx(_DecimalNx x, _DecimalNx y); // M < N
 | |
| 
 | |
|         _FloatM fMmulfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatM fMmulfNx(_FloatNx x, _FloatNx y); // M ≤ N
 | |
|         _FloatMx fMxmulfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatMx fMxmulfNx(_FloatNx x, _FloatNx y); // M < N
 | |
|         _DecimalM dMmuldN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalM dMmuldNx(_DecimalNx x, _DecimalNx y); // M ≤ N
 | |
|         _DecimalMx dMxmuldN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalMx dMxmuldNx(_DecimalNx x, _DecimalNx y); // M < N
 | |
| 
 | |
|         _FloatM fMdivfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatM fMdivfNx(_FloatNx x, _FloatNx y); // M ≤ N
 | |
|         _FloatMx fMxdivfN(_FloatN x, _FloatN y); // M < N
 | |
|         _FloatMx fMxdivfNx(_FloatNx x, _FloatNx y); // M < N
 | |
|         _DecimalM dMdivdN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalM dMdivdNx(_DecimalNx x, _DecimalNx y); // M ≤ N
 | |
|         _DecimalMx dMxdivdN(_DecimalN x, _DecimalN y); // M < N
 | |
|         _DecimalMx dMxdivdNx(_DecimalNx x, _DecimalNx y); // M < N
 | |
| 
 | |
|         _FloatM fMfmafN(_FloatN x, _FloatN y, _FloatN z); // M < N
 | |
|         _FloatM fMfmafNx(_FloatNx x, _FloatNx y, _FloatNx z); // M ≤ N
 | |
|         _FloatMx fMxfmafN(_FloatN x, _FloatN y, _FloatN z); // M < N
 | |
|         _FloatMx fMxfmafNx(_FloatNx x, _FloatNx y, _FloatNx z); // M < N
 | |
|         _DecimalM dMfmadN(_DecimalN x, _DecimalN y, _DecimalN z); // M < N
 | |
|         _DecimalM dMfmadNx(_DecimalNx x, _DecimalNx y, _DecimalNx z); // M ≤ N
 | |
|         _DecimalMx dMxfmadN(_DecimalN x, _DecimalN y, _DecimalN z); // M < N
 | |
|         _DecimalMx dMxfmadNx(_DecimalNx x, _DecimalNx y, _DecimalNx z); // M < N
 | |
| 
 | |
|         _FloatM fMsqrtfN(_FloatN x); // M < N
 | |
|         _FloatM fMsqrtfNx(_FloatNx x); // M ≤ N
 | |
|         _FloatMx fMxsqrtfN(_FloatN x); // M < N
 | |
|         _FloatMx fMxsqrtfNx(_FloatNx x); // M < N
 | |
|         _DecimalM dMsqrtdN(_DecimalN x); // M < N
 | |
|         _DecimalM dMsqrtdNx(_DecimalNx x); // M ≤ N
 | |
|         _DecimalMx dMxsqrtdN(_DecimalN x); // M < N
 | |
|         _DecimalMx dMxsqrtdNx(_DecimalNx x); // M < N
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.15'>7.12.15</a>) Quantum and quantum exponent functions
 | |
|         _DecimalN quantizedN(_DecimalN x, _DecimalN y);
 | |
|         _DecimalNx quantizedNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         bool samequantumdN(_DecimalN x, _DecimalN y);
 | |
|         bool samequantumdNx(_DecimalNx x, _DecimalNx y);
 | |
| 
 | |
|         _DecimalN quantumdN(_DecimalN x);
 | |
|         _DecimalNx quantumdNx(_DecimalNx x);
 | |
| 
 | |
|         long long int llquantexpdN(_DecimalN x);
 | |
|         long long int llquantexpdNx(_DecimalNx x);
 | |
| 
 | |
| 
 | |
| (<a href='#7.12.16'>7.12.16</a>) Decimal re-encoding functions
 | |
| 
 | |
|         void encodedecdN(unsigned char * restrict encptr,
 | |
|               const _DecimalN * restrict xptr);
 | |
|         void decodedecdN(_DecimalN * restrict xptr,
 | |
|               const unsigned char * restrict encptr);
 | |
|         void encodebindN(unsigned char * restrict encptr,
 | |
|               const _DecimalN * restrict xptr);
 | |
|         void decodebindN(_DecimalN * restrict xptr,
 | |
|               const unsigned char * restrict encptr);
 | |
| 
 | |
| 
 | |
| (<a href='#F.10.12'>F.10.12</a>) Total order functions
 | |
| 
 | |
|         int totalorderfN(const _FloatN *x, const _FloatN *y);
 | |
|         int totalorderfNx(const _FloatNx *x, const _FloatNx *y);
 | |
|         int totalorderdN(const _DecimalN *x, const _DecimalN *y);
 | |
|         int totalorderdNx(const _DecimalNx *x, const _DecimalNx *y);
 | |
|              int totalordermagfN(const _FloatN *x, const _FloatN *y);
 | |
|              int totalordermagfNx(const _FloatNx *x, const _FloatNx *y);
 | |
|              int totalordermagdN(const _DecimalN *x, const _DecimalN *y);
 | |
|              int totalordermagdNx(const _DecimalNx *x, const _DecimalNx *y);
 | |
| 
 | |
| (<a href='#F.10.13'>F.10.13</a>) Payload functions
 | |
|              _FloatN getpayloadfN(const _FloatN *x);
 | |
|              _FloatNx getpayloadfNx(const _FloatNx *x);
 | |
|              _DecimalN getpayloaddN(const _DecimalN *x);
 | |
|              _DecimalNx getpayloaddNx(const _DecimalNx *x);
 | |
| 
 | |
|              int setpayloadfN(_FloatN *res, _FloatN pl);
 | |
|              int setpayloadfNx(_FloatNx *res, _FloatNx pl);
 | |
|              int setpayloaddN(_DecimalN *res, _DecimalN pl);
 | |
|              int setpayloaddNx(_DecimalNx *res, _DecimalNx pl);
 | |
| 
 | |
|              int setpayloadsigfN(_FloatN *res, _FloatN pl);
 | |
|              int setpayloadsigfNx(_FloatNx *res, _FloatNx pl);
 | |
|              int setpayloadsigdN(_DecimalN *res, _DecimalN pl);
 | |
|              int setpayloadsigdNx(_DecimalNx *res, _DecimalNx pl);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.2p2'></a>
 | |
| <pre>2   The specification of the frexp functions (<a href='#7.12.6.7'>7.12.6.7</a>) applies to the functions for binary floating types
 | |
|     like those for standard floating types: the exponent is an integral power of 2 and, when applicable,
 | |
|     value equals x × 2*exp .
 | |
| </pre>
 | |
| <a name='H.11.2p3'></a>
 | |
| <pre>3   The specification of the ldexp functions (<a href='#7.12.6.9'>7.12.6.9</a>) applies to the functions for binary floating types
 | |
|     like those for standard floating types: they return x × 2exp .
 | |
| </pre>
 | |
| <a name='H.11.2p4'></a>
 | |
| <pre>4   The specification of the logb functions (<a href='#7.12.6.17'>7.12.6.17</a>) applies to binary floating types, with b = 2.
 | |
| </pre>
 | |
| <a name='H.11.2p5'></a>
 | |
| <pre>5   The specification of the scalbn and scalbln functions (<a href='#7.12.6.19'>7.12.6.19</a>) applies to binary floating types,
 | |
|     with b = 2.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.3'></a>
 | |
| <hr>
 | |
| <h3>H.11.3 [Encoding conversion functions]</h3>
 | |
| <a name='H.11.3p1'></a>
 | |
| <pre>1   This subclause introduces <math.h> functions that, together with the numerical conversion functions
 | |
|     for encodings in <a href='#H.12'>H.12</a>, support the non-arithmetic interchange formats specified by IEC 60559.
 | |
|     Support for these formats is an optional feature of this annex. Implementations that do not support
 | |
|     non-arithmetic interchange formats need not declare the functions in this subclause.
 | |
| </pre>
 | |
| <a name='H.11.3p2'></a>
 | |
| <pre>2   Non-arithmetic interchange formats are not associated with floating types. Arrays of element
 | |
|     type unsigned char are used as parameters for conversion functions, to represent encodings in
 | |
|     interchange formats that might be non-arithmetic formats.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.3.1'></a>
 | |
| <hr>
 | |
| <h3>H.11.3.1 [Encode and decode functions]</h3>
 | |
| <a name='H.11.3.1p1'></a>
 | |
| <pre>1   This subclause specifies functions to map representations in binary floating types to and from
 | |
|     encodings in unsigned char arrays.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.3.1.1'></a>
 | |
| <hr>
 | |
| <h3>H.11.3.1.1 [The encodefN functions]</h3>
 | |
| <a name='H.11.3.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|              #include <math.h>
 | |
| 
 | |
|              void encodefN(unsigned char encptr[restrict static N/8],
 | |
|                    const _FloatN * restrict xptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.11.3.1.1p2'></a>
 | |
| <pre>2   The encodefN functions convert *xptr into an IEC 60559 binaryN encoding and store the resulting
 | |
|     encoding as an N /8 element array, with 8 bits per array element, in the object pointed to by encptr.
 | |
|     The order of bytes in the array is implementation-defined. These functions preserve the value of
 | |
|     *xptr and raise no floating-point exceptions. If *xptr is non-canonical, these functions may or may
 | |
|     not produce a canonical encoding.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.11.3.1.1p3'></a>
 | |
| <pre>3   The encodefN functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.3.1.2'></a>
 | |
| <hr>
 | |
| <h3>H.11.3.1.2 [The decodefN functions]</h3>
 | |
| <a name='H.11.3.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|              #include <math.h>
 | |
| 
 | |
|              void decodefN(_FloatN * restrict xptr,
 | |
|                    const unsigned char encptr[restrict static N/8]);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.11.3.1.2p2'></a>
 | |
| <pre>2   The decodefN functions interpret the N /8 element array pointed to by encptr as an IEC 60559
 | |
|     binaryN encoding, with 8 bits per array element. The order of bytes in the array is implementation-
 | |
|     defined. These functions convert the given encoding into a representation in the type _FloatN, and
 | |
|     store the result in the object pointed to by xptr. These functions preserve the encoded value and
 | |
|     raise no floating-point exceptions. If the encoding is non-canonical, these functions may or may not
 | |
|     produce a canonical representation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.11.3.1.2p3'></a>
 | |
| <pre>3   The decodefN functions return no value.
 | |
| </pre>
 | |
| <a name='H.11.3.1.2p4'></a>
 | |
| <pre>4   See EXAMPLE in <a href='#H.11.3.2.1'>H.11.3.2.1</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.3.2'></a>
 | |
| <hr>
 | |
| <h3>H.11.3.2 [Encoding-to-encoding conversion functions]</h3>
 | |
| <a name='H.11.3.2p1'></a>
 | |
| <pre>1   An implementation shall declare an fMencfN function for each M and N equal to the width of
 | |
|     a supported IEC 60559 arithmetic or non-arithmetic binary interchange format, M ̸= N . An
 | |
|     implementation shall provide both dMencdecdN and dMencbindNfunctions for each M and N equal
 | |
|     to the width of a supported IEC 60559 arithmetic or non-arithmetic decimal interchange format,
 | |
|     M ̸= N .
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.3.2.1'></a>
 | |
| <hr>
 | |
| <h3>H.11.3.2.1 [The fMencfN functions]</h3>
 | |
| <a name='H.11.3.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|              #include <math.h>
 | |
| 
 | |
|              void fMencfN(unsigned char encMptr[restrict static M/8],
 | |
|                    const unsigned char encNptr[restrict static N/8]);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.11.3.2.1p2'></a>
 | |
| <pre>2   The fMencfN functions convert between IEC 60559 binary interchange formats. These functions
 | |
|     interpret the N /8 element array pointed to by encNptr as an encoding of width N bits. They
 | |
|     convert the encoding to an encoding of width M bits and store the resulting encoding as an M /8
 | |
|     element array in the object pointed to by encMptr. The conversion rounds and raises floating-point
 | |
|     exceptions as specified in IEC 60559. The order of bytes in the arrays is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.11.3.2.1p3'></a>
 | |
| <pre>3   These functions return no value.
 | |
| </pre>
 | |
| <a name='H.11.3.2.1p4'></a>
 | |
| <pre>4   EXAMPLE If the IEC 60559 binary16 format is supported as a non-arithmetic format, data in binary16 format can be
 | |
|     converted to type float as follows:
 | |
| 
 | |
|              #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|              #include <math.h>
 | |
|              unsigned char b16[2]; // for input binary16 datum
 | |
|              float f; // for result
 | |
|              unsigned char b32[4];
 | |
|              _Float32 f32;
 | |
| 
 | |
|              // store input binary16 datum in array b16
 | |
|              ...
 | |
|              f32encf16(b32, b16);
 | |
|              decodef32(&f32, b32);
 | |
|              f = f32;
 | |
|              ...
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.11.3.2.2'></a>
 | |
| <hr>
 | |
| <h3>H.11.3.2.2 [The dMencdecdN and dMencbindN functions]</h3>
 | |
| <a name='H.11.3.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|              #include <math.h>
 | |
| 
 | |
|              void dMencdecdN(unsigned char encMptr[restrict static M/8],
 | |
|                    const unsigned char encNptr[restrict static N/8]);
 | |
|              void dMencbindN(unsigned char encMptr[restrict static M/8],
 | |
|                    const unsigned char encNptr[restrict static N/8]);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.11.3.2.2p2'></a>
 | |
| <pre>2   The dMencdecdN and dMencbindN functions convert between IEC 60559 decimal interchange formats
 | |
|     that use the same encoding scheme. The dMencdecdN functions convert between formats using the
 | |
|     encoding scheme based on decimal encoding of the significand. The dMencbindN functions convert
 | |
|     between formats using the encoding scheme based on binary encoding of the significand. These
 | |
|     functions interpret the N /8 element array pointed to by encNptr as an encoding of width N bits.
 | |
|     They convert the encoding to an encoding of width M bits and store the resulting encoding as an M /8
 | |
|     element array in the object pointed to by encMptr. The conversion rounds and raises floating-point
 | |
|     exceptions as specified in IEC 60559. The order of bytes in the arrays is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.11.3.2.2p3'></a>
 | |
| <pre>3   These functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12'></a>
 | |
| <hr>
 | |
| <h3>H.12 [Numeric conversion functions <stdlib.h>]</h3>
 | |
| <a name='H.12p1'></a>
 | |
| <pre>1   This clause expands the specification of numeric conversion functions in <stdlib.h> (<a href='#7.24.1'>7.24.1</a>) to also
 | |
|     include conversions of strings from and to interchange and extended floating types. The conversions
 | |
|     from floating are provided by functions analogous to the strfromd function. The conversions to
 | |
|     floating are provided by functions analogous to the strtod function.
 | |
| </pre>
 | |
| <a name='H.12p2'></a>
 | |
| <pre>2   This clause also specifies functions to convert strings from and to IEC 60559 interchange format
 | |
|     encodings.
 | |
| </pre>
 | |
| <a name='H.12p3'></a>
 | |
| <pre>3   For each interchange or extended floating type that the implementation provides, <stdlib.h> shall
 | |
|     declare the associated functions specified below in <a href='#H.12.1'>H.12.1</a> and <a href='#H.12.2'>H.12.2</a> (see <a href='#H.8'>H.8</a>). Conversely, for each
 | |
|     such type that the implementation does not provide, <stdlib.h> shall not declare the associated
 | |
|     functions.
 | |
| </pre>
 | |
| <a name='H.12p4'></a>
 | |
| <pre>4   For each IEC 60559 arithmetic or non-arithmetic format that the implementation supports,
 | |
|     <stdlib.h> shall declare the associated functions specified below in <a href='#H.12.3'>H.12.3</a> and <a href='#H.12.4'>H.12.4</a> (see <a href='#H.8'>H.8</a>).
 | |
|     Conversely, for each such format that the implementation does not provide, <stdlib.h> shall not
 | |
|     declare the associated functions.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.1'></a>
 | |
| <hr>
 | |
| <h3>H.12.1 [String from floating]</h3>
 | |
| <a name='H.12.1p1'></a>
 | |
| <pre>1   This subclause expands <a href='#7.24.1.3'>7.24.1.3</a> and <a href='#7.24.1.4'>7.24.1.4</a> to also include functions for the interchange and
 | |
|     extended floating types. It adds to the synopsis in <a href='#7.24.1.3'>7.24.1.3</a> the prototypes
 | |
|              int strfromfN(char * restrict s, size_t n,
 | |
|                    const char * restrict format, _FloatN fp);
 | |
|              int strfromfNx(char * restrict s, size_t n,
 | |
|                    const char * restrict format, _FloatNx fp);
 | |
| 
 | |
| 
 | |
|     It encompasses the prototypes in <a href='#7.24.1.4'>7.24.1.4</a> by replacing them with
 | |
| 
 | |
|              int strfromdN(char * restrict s, size_t n,
 | |
|                    const char * restrict format, _DecimalN fp);
 | |
|              int strfromdNx(char * restrict s, size_t n,
 | |
|                    const char * restrict format, _DecimalNx fp);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.1p2'></a>
 | |
| <pre>2   The descriptions and returns for the added functions are analogous to the ones in <a href='#7.24.1.3'>7.24.1.3</a>
 | |
|     and <a href='#7.24.1.4'>7.24.1.4</a>.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.2'></a>
 | |
| <hr>
 | |
| <h3>H.12.2 [String to floating]</h3>
 | |
| <a name='H.12.2p1'></a>
 | |
| <pre>1   This subclause expands <a href='#7.24.1.5'>7.24.1.5</a> and <a href='#7.24.1.6'>7.24.1.6</a> to also include functions for the interchange and
 | |
|     extended floating types. It adds to the synopsis in <a href='#7.24.1.5'>7.24.1.5</a> the prototypes
 | |
|              _FloatN strtofN(const char * restrict nptr,
 | |
|                    char ** restrict endptr);
 | |
|              _FloatNx strtofNx(const char * restrict nptr,
 | |
|                      char ** restrict endptr);
 | |
| 
 | |
| 
 | |
|     It encompasses the prototypes in <a href='#7.24.1.6'>7.24.1.6</a> by replacing them with
 | |
|              _DecimalN strtodN(const char * restrict nptr,
 | |
|                    char ** restrict endptr);
 | |
|              _DecimalNx strtodNx(const char * restrict nptr,
 | |
|                      char ** restrict endptr);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.2p2'></a>
 | |
| <pre>2   The descriptions and returns for the added functions are analogous to the ones in <a href='#7.24.1.5'>7.24.1.5</a> and <a href='#7.24.1.6'>7.24.1.6</a>.
 | |
| </pre>
 | |
| <a name='H.12.2p3'></a>
 | |
| <pre>3   For implementations that support both binary and decimal floating types and a (binary or dec-
 | |
|     imal) non-arithmetic interchange format, the strtodN and strtodNx functions (and hence the
 | |
|     strtoencdecdN and strtoencbindN functions in <a href='#H.12.4.2'>H.12.4.2</a>) shall accept subject sequences that have
 | |
|     the form of hexadecimal floating numbers and otherwise meet the requirements of subject sequences
 | |
|     (<a href='#7.24.1.6'>7.24.1.6</a>). Then the decimal results shall be correctly rounded if the subject sequence has at most
 | |
|     M significant hexadecimal digits, where M ≥ ⌈(P − 1)/4⌉ + 1 is implementation-defined, and P is
 | |
|     the maximum precision of the supported binary floating types and binary non-arithmetic formats.
 | |
|     If all subject sequences of hexadecimal form are correctly rounded, M may be regarded as infinite.
 | |
|     If the subject sequence has more than M significant hexadecimal digits, the implementation may
 | |
|     first round to M significant hexadecimal digits according to the applicable rounding direction mode,
 | |
|     signaling exceptions as though converting from a wider format, then correctly round the result of
 | |
|     the shortened hexadecimal input to the result type.
 | |
| </pre>
 | |
| <a name='H.12.2p4'></a>
 | |
| <pre>4   EXAMPLE If the IEC 60559 binary128 format is supported as a non-arithmetic format, data in binary128 format can be
 | |
|     converted to type _Decimal128 as follows:
 | |
| 
 | |
|              #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|              #include <stdlib.h>
 | |
|              #define MAXSIZE 41 // > intermediate hex string length
 | |
|              unsigned char b128[16]; // for input binary128 datum
 | |
|              _Decimal128 d128; // for result
 | |
|              char s[MAXSIZE];
 | |
|              // store input binary128 datum in array b128
 | |
|              ...
 | |
|              strfromencf128(s, MAXSIZE, "%a", b128);
 | |
|              d128 = strtod128(s, NULL);
 | |
|                ...
 | |
| 
 | |
| 
 | |
|     Use of "%a" for formatting assures an exact conversion of the value in binary format to character sequence. The value of that
 | |
|     character sequence will be correctly rounded to _Decimal128 , as specified above in this subclause. The array s for the output
 | |
|     of strfromencf128 need have no greater size than 41, which is the maximum length of strings of the form
 | |
|     [−]0xh.h . . . hp ± d
 | |
|     where there are up to 29 hexadecimal digits h and d has 5 digits plus 1 for the null character.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.3'></a>
 | |
| <hr>
 | |
| <h3>H.12.3 [String from encoding]</h3>
 | |
| <a name='H.12.3p1'></a>
 | |
| <pre>1   An implementation shall declare the strfromencfN function for each N equal to the width of a
 | |
|     supported IEC 60559 arithmetic or non-arithmetic binary interchange format. An implementation
 | |
|     shall declare both the strfromencdecdN and strfromencbindN functions for each N equal to the
 | |
|     width of a supported IEC 60559 arithmetic or non-arithmetic decimal interchange format.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.3.1'></a>
 | |
| <hr>
 | |
| <h3>H.12.3.1 [The strfromencf N functions]</h3>
 | |
| <a name='H.12.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|                #include <stdlib.h>
 | |
| 
 | |
|                int strfromencfN(char * restrict s, size_t n, const char * restrict format,
 | |
|                      const unsigned char encptr[restrict static N/8]);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.12.3.1p2'></a>
 | |
| <pre>2   The strfromencfN functions are similar to the strfromfN functions, except the input is the value of
 | |
|     the N /8 element array pointed to by encptr, interpreted as an IEC 60559 binaryN encoding. The
 | |
|     order of bytes in the arrays is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.12.3.1p3'></a>
 | |
| <pre>3   The strfromencfN functions return the same values as corresponding strfromfN functions.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.3.2'></a>
 | |
| <hr>
 | |
| <h3>H.12.3.2 [The strfromencdecdN and strfromencbindN functions]</h3>
 | |
| <a name='H.12.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|                #include <stdlib.h>
 | |
| 
 | |
|                int strfromencdecdN(char * restrict s, size_t n, const char * restrict format,
 | |
|                      const unsigned char encptr[restrict static N/8]);
 | |
|                int strfromencbindN(char * restrict s, size_t n, const char * restrict format,
 | |
|                      const unsigned char encptr[restrict static N/8]);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.12.3.2p2'></a>
 | |
| <pre>2   The strfromencdecdN functions are similar to the strfromdN functions except the input is the value
 | |
|     of the N /8 element array pointed to by encptr, interpreted as an IEC 60559 decimalN encoding in
 | |
|     the coding scheme based on decimal encoding of the significand. The strfromencbindN functions
 | |
|     are similar to the strfromdN functions except the input is the value of the N /8 element array pointed
 | |
|     to by encptr, interpreted as an IEC 60559 decimalN encoding in the coding scheme based on binary
 | |
|     encoding of the significand. The order of bytes in the arrays is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.12.3.2p3'></a>
 | |
| <pre>3   The strfromencdecdN and strfromencbindN functions return the same values as corresponding
 | |
|     strfromdN functions.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.4'></a>
 | |
| <hr>
 | |
| <h3>H.12.4 [String to encoding]</h3>
 | |
| <a name='H.12.4p1'></a>
 | |
| <pre>1   An implementation shall declare the strtoencfN function for each N equal to the width of a
 | |
|     supported IEC 60559 arithmetic or non-arithmetic binary interchange format. An implementation
 | |
|     shall declare both the strtoencdecdN and strtoencbindN functions for each N equal to the width
 | |
|     of a supported IEC 60559 arithmetic or non-arithmetic decimal interchange format.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.4.1'></a>
 | |
| <hr>
 | |
| <h3>H.12.4.1 [The strtoencfN functions]</h3>
 | |
| <a name='H.12.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|             #include <stdlib.h>
 | |
| 
 | |
|             void strtoencfN(unsigned char encptr[restrict static N/8],
 | |
|                   const char * restrict nptr, char ** restrict endptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.12.4.1p2'></a>
 | |
| <pre>2   The strtoencfN functions are similar to the strtofN functions, except they store an IEC 60559
 | |
|     encoding of the result as an N /8 element array in the object pointed to by encptr. The order of
 | |
|     bytes in the arrays is implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.12.4.1p3'></a>
 | |
| <pre>3   These functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.12.4.2'></a>
 | |
| <hr>
 | |
| <h3>H.12.4.2 [The strtoencdecdN and strtoencbindN functions]</h3>
 | |
| <a name='H.12.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|             #include <stdlib.h>
 | |
| 
 | |
|             void strtoencdecdN(unsigned char encptr[restrict static N/8],
 | |
|                   const char * restrict nptr, char ** restrict endptr);
 | |
|             void strtoencbindN(unsigned char encptr[restrict static N/8],
 | |
|                   const char * restrict nptr, char ** restrict endptr);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='H.12.4.2p2'></a>
 | |
| <pre>2   The strtoencdecdN and strtoencbindNfunctions are similar to the strtodN functions, except
 | |
|     they store an IEC 60559 encoding of the result as an N /8 element array in the object pointed to
 | |
|     by encptr. The strtoencdecdN functions produce an encoding in the encoding scheme based on
 | |
|     decimal encoding of the significand. The strtoencbindN functions produce an encoding in the
 | |
|     encoding scheme based on binary encoding of the significand. The order of bytes in the arrays is
 | |
|     implementation-defined.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='H.12.4.2p3'></a>
 | |
| <pre>3   These functions return no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.13'></a>
 | |
| <hr>
 | |
| <h3>H.13 [Type-generic macros <tgmath.h>]</h3>
 | |
| <a name='H.13p1'></a>
 | |
| <pre>1   This clause enhances the specification of type-generic macros in <tgmath.h> (<a href='#7.27'>7.27</a>) to apply to
 | |
|     interchange and extended floating types, as well as standard floating types.
 | |
| </pre>
 | |
| <a name='H.13p2'></a>
 | |
| <pre>2   If arguments for generic parameters of a type-generic macro are such that some argument has
 | |
|     a corresponding real type that is a standard floating type or a binary floating type and another
 | |
|     argument is of decimal floating type, the behavior is undefined.
 | |
| </pre>
 | |
| <a name='H.13p3'></a>
 | |
| <pre>3   The treatment of arguments of integer type in <a href='#7.27'>7.27</a> is expanded to cases where another argument
 | |
|     has extended type. Arguments of integer type are regarded as having type:
 | |
| 
 | |
|       — _Decimal64x , if any argument has a decimal extended type; otherwise
 | |
|       — _Float32x , if any argument has a binary extended type; otherwise
 | |
|       — _Decimal64 , if any argument has decimal type; otherwise
 | |
|       — double
 | |
| </pre>
 | |
| <a name='H.13p4'></a>
 | |
| <pre>4   Use of the macros carg, cimag, conj, cproj, or creal with any argument of standard floating type,
 | |
|     binary floating type, complex type, or imaginary type invokes a complex function. Use of the macro
 | |
|     with an argument of a decimal floating type results in undefined behavior.
 | |
| </pre>
 | |
| <a name='H.13p5'></a>
 | |
| <pre>5   The functions that round results to a narrower type have type-generic macros whose names are
 | |
|     obtained by omitting any suffix from the function names. Thus, the macros with f or d prefix are (as
 | |
|     in <a href='#7.27'>7.27</a>):
 | |
| 
 | |
|                                             fadd    fmul      ffma
 | |
|                                             dadd    dmul      dfma
 | |
|                                             fsub    fdiv     fsqrt
 | |
|                                             dsub    ddiv     dsqrt
 | |
| 
 | |
| 
 | |
|     and the macros with fM, fMx, dM, or dMx prefix are:
 | |
| 
 | |
|                                        fMadd       fMxmul      dMfma
 | |
|                                        fMsub       fMxdiv     dMsqrt
 | |
|                                        fMmul       fMxfma     dMxadd
 | |
|                                        fMdiv       fMxsqrt    dMxsub
 | |
|                                        fMfma        dMadd     dMxmul
 | |
|                                        fMsqrt       dMsub     dMxdiv
 | |
|                                        fMxadd       dMmul     dMxfma
 | |
|                                        fMxsub       dMdiv     dMxsqrt
 | |
| 
 | |
| 
 | |
|     All arguments are generic. If any argument is not real, use of the macro results in undefined behavior.
 | |
|     The following specification uses the notation type1 ⊆ type2 to mean the values of type1 are a subset
 | |
|     of (or the same as) the values of type2. The generic parameter type T for the function invoked by the
 | |
|     macro is determined as follows:
 | |
| 
 | |
|       — First, obtain a preliminary type P for the generic parameters: if all arguments are of integer
 | |
|         type, then P is double if the macro prefix is f, d, fN, or fNx and P is _Decimal64 if the macro
 | |
|         prefix is dN or dNx; otherwise (if some argument is not of integer type), apply the rules (for
 | |
|         determining the corresponding real type of the generic parameters) in <a href='#7.27'>7.27</a> for macros that
 | |
|         do not round result to narrower type, using the usual arithmetic conversion rules in <a href='#H.4.2'>H.4.2</a>, to
 | |
|         obtain P .
 | |
| 
 | |
|       — If there exists a corresponding function whose generic parameters have type P , then T is P .
 | |
| 
 | |
|       — Otherwise, T is determined from P and the macro prefix as follows:
 | |
| 
 | |
|             • For prefix f: if P is a standard or binary floating type, then T is the first standard floating
 | |
|               type of either double or long double, such that P ⊆ T , if such a type T exists. Otherwise
 | |
|               (if no such type T exists or P is a decimal floating type), the behavior is undefined.
 | |
|             • For prefix d: if P is a standard or binary floating type, then T is long double if P ⊆
 | |
|               long double. Otherwise (if P ⊆ long double is false or P is a decimal floating type),
 | |
|               the behavior is undefined.
 | |
|             • For prefix fM: if P is a standard or binary floating type, then T is _FloatN for minimum
 | |
|               N > M such that P ⊆ T , if such a type T is supported; otherwise T is _FloatNx for
 | |
|               minimum N ≥ M such that P ⊆ T , if such a type T is supported. Otherwise (if no
 | |
|               such _FloatN or _FloatNx is supported or P is a decimal floating type), the behavior is
 | |
|               undefined.
 | |
|             • For prefix fMx: if P is a standard or binary floating type, then T is _FloatNx for minimum
 | |
|               N > M such that P ⊆ T , if such a type T is supported; otherwise T is _FloatN for
 | |
|               minimum N > M such that P ⊆ T , if such a type T is supported. Otherwise (if no
 | |
|               such _FloatNx or _FloatN is supported or P is a decimal floating type), the behavior is
 | |
|               undefined.
 | |
|               • For prefix dM: if P is a decimal floating type, then T is _DecimalN for minimum N > M
 | |
|                 such that P ⊆ T , if such a type T is supported; otherwise T is _DecimalNx for minimum
 | |
|                 N ≥ M such that P ⊆ T . Otherwise (P is a standard or binary floating type), the behavior
 | |
|                 is undefined.
 | |
|               • For prefix dMx: if P is a decimal floating type, then T is _DecimalNx for minimum N > M
 | |
|                 such that P ⊆ T , if such a type T is supported; otherwise T is _DecimalN for minimum
 | |
|                 N > M such that P ⊆ T , if such a type T is supported. Otherwise (P is a standard or
 | |
|                 binary floating type), the behavior is undefined.
 | |
| 
 | |
| </pre>
 | |
| <a name='H.13p6'></a>
 | |
| <pre>6   EXAMPLE With the declarations
 | |
| 
 | |
|               #define __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
| 
 | |
|               #include <tgmath.h>
 | |
| 
 | |
|               int n;
 | |
|               double d;
 | |
|               long double ld;
 | |
|               double complex dc;
 | |
|               _Float32x f32x;
 | |
|               _Float64 f64;
 | |
|               _Float64x f64x;
 | |
|               _Float128 f128;
 | |
|               _Float64x complex f64xc;
 | |
| 
 | |
| 
 | |
|     functions invoked by use of type-generic macros are shown in the following table, where type1 ⊆ type2 means the values of
 | |
|     type1 are a subset of (or the same as) the values of type2, and type1 ⊂ type2 means the values of type1 are a strict subset of
 | |
|     the values of type2:
 | |
|      macro use                           invokes
 | |
| 
 | |
|      cos(f64xc)                          ccosf64x
 | |
| 
 | |
|      pow(dc, f128)                       cpowf128
 | |
| 
 | |
|      pow(f64, d)                         powf64
 | |
| 
 | |
|      pow(d, f32x)                        pow, the function, if _Float32x ⊆ double, else powf32x if double ⊂
 | |
|                                          _Float32x , else undefined
 | |
| 
 | |
|      pow(f32, n)                         pow, the function
 | |
| 
 | |
|      pow(f32x, n)                        pow32x
 | |
| 
 | |
|     Macros that round the result to a narrower type. . .
 | |
|      macro use                           invokes
 | |
| 
 | |
|      fsub(d, ld)                         fsubl
 | |
| 
 | |
|      dsub(d, f32)                        dsubl
 | |
|                                          undefined
 | |
|      fmul(dc, d)
 | |
| 
 | |
|      ddiv(ld, f128)                      ddivl if _Float128 ⊆ long double, else undefined
 | |
| 
 | |
|      f32add(f64x, f64)                   f32addf64x
 | |
| 
 | |
|      f32xsqrt(n)                         f32xsqrtf64
 | |
| 
 | |
|      f32mul(f128, f32x)                  f32mulf128 if _Float32x ⊆ _Float128 , else f32mulf32x if _Float128
 | |
|                                          ⊂ _Float32x , else undefined
 | |
| 
 | |
|      f32fma(f32x, n, f32x)               f32fmaf32x
 | |
| 
 | |
|      f32add(f32, f32)                    f32addf64
 | |
| 
 | |
|      f32xsqrt(f32)                       f32xsqrtf64x, as declaration above shows _Float64x is supported
 | |
| 
 | |
|      f64div(f32x, f32x)                  f64divf128 if _Float32x ⊆ _Float128 , else f64divf64x
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='I.'></a>
 | |
| <hr>
 | |
| <h3>I. [Annex I (informative) Common warnings]</h3>
 | |
| <a name='I.p1'></a>
 | |
| <pre>1   An implementation may generate warnings in many situations, none of which are specified as part
 | |
|     of this document. The following are a few of the more common situations.
 | |
| </pre>
 | |
| <a name='I.p2'></a>
 | |
| <pre>2     — A new struct or union type appears in a function prototype (<a href='#6.2.1'>6.2.1</a>, <a href='#6.7.2.3'>6.7.2.3</a>).
 | |
|       — A block with initialization of an object that has automatic storage duration is jumped into
 | |
|         (<a href='#6.2.4'>6.2.4</a>).
 | |
|       — An implicit narrowing conversion is encountered, such as the assignment of a long int or a
 | |
|         double to an int, or a pointer to void to a pointer to any type other than a character type (<a href='#6.3'>6.3</a>).
 | |
| 
 | |
|       — A hexadecimal floating constant cannot be represented exactly in its evaluation format (<a href='#6.4.4.2'>6.4.4.2</a>).
 | |
|       — An integer character constant includes more than one character or a wide character constant
 | |
|         includes more than one multibyte character (<a href='#6.4.4.4'>6.4.4.4</a>).
 | |
| 
 | |
|       — The characters /* are found in a comment (<a href='#6.4.7'>6.4.7</a>).
 | |
|       — An "unordered" binary operator (not comma, &&, or ||) contains a side effect to an lvalue in
 | |
|         one operand, and a side effect to, or an access to the value of, the identical lvalue in the other
 | |
|         operand (<a href='#6.5'>6.5</a>).
 | |
|       — An object is defined but not used (<a href='#6.7'>6.7</a>).
 | |
| 
 | |
|       — A value is given to an object of an enumerated type other than by assignment of an enumeration
 | |
|         constant that is a member of that type, or an enumeration object that has the same type, or the
 | |
|         value of a function that returns the same enumerated type (<a href='#6.7.2.2'>6.7.2.2</a>).
 | |
|       — An aggregate has a partly bracketed initialization (<a href='#6.7.8'>6.7.8</a>).
 | |
| 
 | |
|       — A statement cannot be reached (<a href='#6.8'>6.8</a>).
 | |
|       — A statement with no apparent effect is encountered (<a href='#6.8'>6.8</a>).
 | |
|       — A constant expression is used as the controlling expression of a selection statement (<a href='#6.8.4'>6.8.4</a>).
 | |
|       — An incorrectly formed preprocessing group is encountered while skipping a preprocessing
 | |
|         group (<a href='#6.10.1'>6.10.1</a>).
 | |
|       — An unrecognized #pragma directive is encountered (<a href='#6.10.7'>6.10.7</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.'></a>
 | |
| <hr>
 | |
| <h3>J. [Annex J (informative) Portability issues]</h3>
 | |
| <a name='J.p1'></a>
 | |
| <pre>1   This annex collects some information about portability that appears in this document.
 | |
| 
 | |
| </pre>
 | |
| <a name='J.1'></a>
 | |
| <hr>
 | |
| <h3>J.1 [Unspecified behavior]</h3>
 | |
| <a name='J.1p1'></a>
 | |
| <pre>1   The following are unspecified:
 | |
| 
 | |
|       — The manner and timing of static initialization (<a href='#5.1.2'>5.1.2</a>).
 | |
| 
 | |
|       — The termination status returned to the hosted environment if the return type of main is not
 | |
|         compatible with int (<a href='#5.1.2.2.3'>5.1.2.2.3</a>).
 | |
| 
 | |
|       — The values of objects that are neither lock-free atomic objects nor of type
 | |
|         volatile sig_atomic_t and the state of the floating-point environment, when the
 | |
|         processing of the abstract machine is interrupted by receipt of a signal (<a href='#5.1.2.3'>5.1.2.3</a>).
 | |
| 
 | |
|       — The behavior of the display device if a printing character is written when the active position is
 | |
|         at the final position of a line (<a href='#5.2.2'>5.2.2</a>).
 | |
| 
 | |
|       — The behavior of the display device if a backspace character is written when the active position
 | |
|         is at the initial position of a line (<a href='#5.2.2'>5.2.2</a>).
 | |
| 
 | |
|       — The behavior of the display device if a horizontal tab character is written when the active
 | |
|         position is at or past the last defined horizontal tabulation position (<a href='#5.2.2'>5.2.2</a>).
 | |
| 
 | |
|       — The behavior of the display device if a vertical tab character is written when the active position
 | |
|         is at or past the last defined vertical tabulation position (<a href='#5.2.2'>5.2.2</a>).
 | |
| 
 | |
|       — How an extended source character that does not correspond to a universal character name
 | |
|         counts toward the significant initial characters in an external identifier (<a href='#5.2.4.1'>5.2.4.1</a>).
 | |
| 
 | |
|       — Many aspects of the representations of types (<a href='#6.2.6'>6.2.6</a>).
 | |
| 
 | |
|       — The value of padding bytes when storing values in structures or unions (<a href='#6.2.6.1'>6.2.6.1</a>).
 | |
| 
 | |
|       — The values of bytes that correspond to union members other than the one last stored into
 | |
|         (<a href='#6.2.6.1'>6.2.6.1</a>).
 | |
| 
 | |
|       — The representation used when storing a value in an object that has more than one object
 | |
|         representation for that value (<a href='#6.2.6.1'>6.2.6.1</a>).
 | |
| 
 | |
|       — The values of any padding bits in integer representations (<a href='#6.2.6.2'>6.2.6.2</a>).
 | |
| 
 | |
|       — Whether two string literals result in distinct arrays (<a href='#6.4.5'>6.4.5</a>).
 | |
| 
 | |
|       — The order in which subexpressions are evaluated and the order in which side effects take place,
 | |
|         except as specified for the function-call () , &&, ||, ?:, and comma operators (<a href='#6.5'>6.5</a>).
 | |
| 
 | |
|       — The order in which the function designator, arguments, and subexpressions within the argu-
 | |
|         ments are evaluated in a function call (<a href='#6.5.2.2'>6.5.2.2</a>).
 | |
| 
 | |
|       — The order of side effects among compound literal initialization list expressions (<a href='#6.5.2.5'>6.5.2.5</a>).
 | |
| 
 | |
|       — The order in which the operands of an assignment operator are evaluated (<a href='#6.5.16'>6.5.16</a>).
 | |
| 
 | |
|       — The alignment of the addressable storage unit allocated to hold a bit-field (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
| 
 | |
|       — Whether a call to an inline function uses the inline definition or the external definition of the
 | |
|         function (<a href='#6.7.4'>6.7.4</a>).
 | |
| — Whether or not a size expression is evaluated when it is part of the operand of a sizeof
 | |
|   operator and changing the value of the size expression would not affect the result of the
 | |
|   operator (<a href='#6.7.6.2'>6.7.6.2</a>).
 | |
| 
 | |
| — The order in which any side effects occur among the initialization list expressions in an
 | |
|   initializer (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| — The layout of storage for function parameters (<a href='#6.9.1'>6.9.1</a>).
 | |
| 
 | |
| — When a fully expanded macro replacement list contains a function-like macro name as its
 | |
|   last preprocessing token and the next preprocessing token from the source file is a ( , and
 | |
|   the fully expanded replacement of that macro ends with the name of the first macro and the
 | |
|   next preprocessing token from the source file is again a ( , whether that is considered a nested
 | |
|   replacement (<a href='#6.10.4'>6.10.4</a>).
 | |
| 
 | |
| — The order in which # and ## operations are evaluated during macro substitution (<a href='#6.10.4.2'>6.10.4.2</a>,
 | |
|   and <a href='#6.10.4.3'>6.10.4.3</a>).
 | |
| 
 | |
| — The line number of a preprocessing token, in particular __LINE__ , that spans multiple physical
 | |
|   lines (<a href='#6.10.5'>6.10.5</a>).
 | |
| 
 | |
| — The line number of a preprocessing directive that spans multiple physical lines (<a href='#6.10.5'>6.10.5</a>).
 | |
| 
 | |
| — The line number of a macro invocation that spans multiple physical or logical lines (<a href='#6.10.5'>6.10.5</a>).
 | |
| 
 | |
| — The line number following a directive of the form #line __LINE__ new-line (<a href='#6.10.5'>6.10.5</a>).
 | |
| 
 | |
| — The state of the floating-point status flags when execution passes from a part of the program
 | |
|   translated with FENV_ACCESS "off" to a part translated with FENV_ACCESS "on" (<a href='#7.6.1'>7.6.1</a>).
 | |
| 
 | |
| — The order in which feraiseexcept raises floating-point exceptions, except as stated in <a href='#F.8.6'>F.8.6</a>
 | |
|   (<a href='#7.6.4.3'>7.6.4.3</a>).
 | |
| 
 | |
| — Whether math_errhandling is a macro or an identifier with external linkage (<a href='#7.12'>7.12</a>).
 | |
| 
 | |
| — The results of the frexp functions when the specified value is not a floating-point number
 | |
|   (<a href='#7.12.6.7'>7.12.6.7</a>).
 | |
| 
 | |
| — The numeric result of the ilogb functions when the correct value is outside the range of the
 | |
|   return type (<a href='#7.12.6.8'>7.12.6.8</a>, <a href='#F.10.3.8'>F.10.3.8</a>).
 | |
| 
 | |
| — The result of rounding when the value is out of range (<a href='#7.12.9.5'>7.12.9.5</a>, <a href='#7.12.9.7'>7.12.9.7</a>, <a href='#F.10.6.5'>F.10.6.5</a>).
 | |
| 
 | |
| — The value stored by the remquo functions in the object pointed to by quo when y is zero
 | |
|   (<a href='#7.12.10.3'>7.12.10.3</a>).
 | |
| 
 | |
| — Whether a comparison macro argument that is represented in a format wider than its semantic
 | |
|   type is converted to the semantic type (<a href='#7.12.17'>7.12.17</a>).
 | |
| 
 | |
| — Whether setjmp is a macro or an identifier with external linkage (<a href='#7.13'>7.13</a>).
 | |
| 
 | |
| — Whether va_copy and va_end are macros or identifiers with external linkage (<a href='#7.16.1'>7.16.1</a>).
 | |
| 
 | |
| — The hexadecimal digit before the decimal point when a non-normalized floating-point number
 | |
|   is printed with an a or A conversion specifier (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — The value of the file position indicator after a successful call to the ungetc function for a text
 | |
|   stream, or the ungetwc function for any stream, until all pushed-back characters are read or
 | |
|   discarded (<a href='#7.23.7.10'>7.23.7.10</a>, <a href='#7.31.3.10'>7.31.3.10</a>).
 | |
| 
 | |
| — The details of the value stored by the fgetpos function (<a href='#7.23.9.1'>7.23.9.1</a>).
 | |
| 
 | |
| — The details of the value returned by the ftell function for a text stream (<a href='#7.23.9.4'>7.23.9.4</a>).
 | |
| — Whether the strtod, strtof, strtold, wcstod, wcstof, and wcstold functions convert a
 | |
|   minus-signed sequence to a negative number directly or by negating the value resulting from
 | |
|   converting the corresponding unsigned sequence (<a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.31.4.1.2'>7.31.4.1.2</a>).
 | |
| 
 | |
| — The order and contiguity of storage allocated by successive calls to the calloc, malloc,
 | |
|   realloc, and aligned_alloc functions (<a href='#7.24.3'>7.24.3</a>).
 | |
| 
 | |
| — The amount of storage allocated by a successful call to the calloc, malloc, realloc, or
 | |
|   aligned_alloc function when 0 bytes was requested (<a href='#7.24.3'>7.24.3</a>).
 | |
| 
 | |
| — Whether a call to the atexit function that does not happen before the exit function is called
 | |
|   will succeed (<a href='#7.24.4.2'>7.24.4.2</a>).
 | |
| 
 | |
| — Whether a call to the at_quick_exit function that does not happen before the quick_exit
 | |
|   function is called will succeed (<a href='#7.24.4.3'>7.24.4.3</a>).
 | |
| 
 | |
| — Which of two elements that compare as equal is matched by the bsearch function (<a href='#7.24.5.1'>7.24.5.1</a>).
 | |
| 
 | |
| — The order of two elements that compare as equal in an array sorted by the qsort function
 | |
|   (<a href='#7.24.5.2'>7.24.5.2</a>).
 | |
| 
 | |
| — The order in which destructors are invoked by thrd_exit (<a href='#7.28.5.5'>7.28.5.5</a>).
 | |
| 
 | |
| — Whether calling tss_delete on a key while another thread is executing destructors affects the
 | |
|   number of invocations of the destructors associated with the key on that thread (<a href='#7.28.6.2'>7.28.6.2</a>).
 | |
| 
 | |
| — The encoding of the calendar time returned by the time function (<a href='#7.29.2.5'>7.29.2.5</a>).
 | |
| 
 | |
| — The characters stored by the strftime or wcsftime function if any of the time values being
 | |
|   converted is outside the normal range (<a href='#7.29.3.5'>7.29.3.5</a>, <a href='#7.31.5.1'>7.31.5.1</a>).
 | |
| 
 | |
| — Whether an encoding error occurs if a wchar_t value that does not correspond to a member of
 | |
|   the extended character set appears in the format string for a function in <a href='#7.31.2'>7.31.2</a> or <a href='#7.31.5'>7.31.5</a> and the
 | |
|   specified semantics do not require that value to be processed by wcrtomb (<a href='#7.31.1'>7.31.1</a>).
 | |
| 
 | |
| — The conversion state after an encoding error occurs (<a href='#7.31.6.3.2'>7.31.6.3.2</a>, <a href='#7.31.6.3.3'>7.31.6.3.3</a>, <a href='#7.31.6.4.1'>7.31.6.4.1</a>, <a href='#7.31.6.4.2'>7.31.6.4.2</a>,
 | |
|   and <a href='#7.30.1.1'>7.30.1.1</a>, <a href='#7.30.1.2'>7.30.1.2</a>, <a href='#7.30.1.3'>7.30.1.3</a>, <a href='#7.30.1.4'>7.30.1.4</a>, <a href='#7.30.1.5'>7.30.1.5</a>, <a href='#7.30.1.6'>7.30.1.6</a>).
 | |
| 
 | |
| — The resulting value when the "invalid" floating-point exception is raised during IEC 60559
 | |
|   floating to integer conversion (<a href='#F.4'>F.4</a>).
 | |
| 
 | |
| — Whether conversion of non-integer IEC 60559 floating values to integer raises the "inexact"
 | |
|   floating-point exception (<a href='#F.4'>F.4</a>).
 | |
| 
 | |
| — Whether or when library functions in <math.h> raise the "inexact" floating-point exception in
 | |
|   an IEC 60559 conformant implementation (<a href='#F.10'>F.10</a>).
 | |
| 
 | |
| — Whether or when library functions in <math.h> raise an undeserved "underflow" floating-
 | |
|   point exception in an IEC 60559 conformant implementation (<a href='#F.10'>F.10</a>).
 | |
| 
 | |
| — The exponent value stored by frexp for a NaN or infinity (<a href='#F.10.3.7'>F.10.3.7</a>).
 | |
| 
 | |
| — The numeric result returned by the lrint, llrint, lround, and llround functions if the
 | |
|   rounded value is outside the range of the return type (<a href='#F.10.6.5'>F.10.6.5</a>, <a href='#F.10.6.7'>F.10.6.7</a>).
 | |
| 
 | |
| — The sign of one part of the complex result of several math functions for certain special cases
 | |
|   in IEC 60559 compatible implementations (<a href='#G.6.1.1'>G.6.1.1</a>, <a href='#G.6.2.2'>G.6.2.2</a>, <a href='#G.6.2.3'>G.6.2.3</a>, <a href='#G.6.2.4'>G.6.2.4</a>, <a href='#G.6.2.5'>G.6.2.5</a>, <a href='#G.6.2.6'>G.6.2.6</a>,
 | |
|   and <a href='#G.6.3.1'>G.6.3.1</a>, <a href='#G.6.4.2'>G.6.4.2</a>).
 | |
| </pre>
 | |
| <a name='J.2'></a>
 | |
| <hr>
 | |
| <h3>J.2 [Undefined behavior]</h3>
 | |
| <a name='J.2p1'></a>
 | |
| <pre>1   The behavior is undefined in the following circumstances:
 | |
| 
 | |
|       — A "shall" or "shall not" requirement that appears outside of a constraint is violated (Clause 4).
 | |
| 
 | |
|       — A nonempty source file does not end in a new-line character which is not immediately preceded
 | |
|         by a backslash character or ends in a partial preprocessing token or comment (<a href='#5.1.1.2'>5.1.1.2</a>).
 | |
| 
 | |
|       — Token concatenation produces a character sequence matching the syntax of a universal charac-
 | |
|         ter name (<a href='#5.1.1.2'>5.1.1.2</a>).
 | |
| 
 | |
|       — A program in a hosted environment does not define a function named main using one of the
 | |
|         specified forms (<a href='#5.1.2.2.1'>5.1.2.2.1</a>).
 | |
| 
 | |
|       — The execution of a program contains a data race (<a href='#5.1.2.4'>5.1.2.4</a>).
 | |
| 
 | |
|       — A character not in the basic source character set is encountered in a source file, except in an
 | |
|         identifier, a character constant, a string literal, a header name, a comment, or a preprocessing
 | |
|         token that is never converted to a token (<a href='#5.2.1'>5.2.1</a>).
 | |
| 
 | |
|       — An identifier, comment, string literal, character constant, or header name contains an invalid
 | |
|         multibyte character or does not begin and end in the initial shift state (<a href='#5.2.1.1'>5.2.1.1</a>).
 | |
| 
 | |
|       — The same identifier has both internal and external linkage in the same translation unit (<a href='#6.2.2'>6.2.2</a>).
 | |
| 
 | |
|       — An object is referred to outside of its lifetime (<a href='#6.2.4'>6.2.4</a>).
 | |
| 
 | |
|       — The value of a pointer to an object whose lifetime has ended is used (<a href='#6.2.4'>6.2.4</a>).
 | |
| 
 | |
|       — The value of an object with automatic storage duration is used while the object has an indeter-
 | |
|         minate representation (<a href='#6.2.4'>6.2.4</a>, <a href='#6.7.10'>6.7.10</a>, <a href='#6.8'>6.8</a>).
 | |
| 
 | |
|       — A non-value representation is read by an lvalue expression that does not have character type
 | |
|         (<a href='#6.2.6.1'>6.2.6.1</a>).
 | |
| 
 | |
|       — A non-value representation is produced by a side effect that modifies any part of the object
 | |
|         using an lvalue expression that does not have character type (<a href='#6.2.6.1'>6.2.6.1</a>).
 | |
| 
 | |
|       — Two declarations of the same object or function specify types that are not compatible (<a href='#6.2.7'>6.2.7</a>).
 | |
| 
 | |
|       — A program requires the formation of a composite type from a variable length array type whose
 | |
|         size is specified by an expression that is not evaluated (<a href='#6.2.7'>6.2.7</a>).
 | |
| 
 | |
|       — Conversion to or from an integer type produces a value outside the range that can be repre-
 | |
|         sented (<a href='#6.3.1.4'>6.3.1.4</a>).
 | |
| 
 | |
|       — Demotion of one real floating type to another produces a value outside the range that can be
 | |
|         represented (<a href='#6.3.1.5'>6.3.1.5</a>).
 | |
| 
 | |
|       — An lvalue does not designate an object when evaluated (<a href='#6.3.2.1'>6.3.2.1</a>).
 | |
| 
 | |
|       — A non-array lvalue with an incomplete type is used in a context that requires the value of the
 | |
|         designated object (<a href='#6.3.2.1'>6.3.2.1</a>).
 | |
| 
 | |
|       — An lvalue designating an object of automatic storage duration that could have been declared
 | |
|         with the register storage class is used in a context that requires the value of the designated
 | |
|         object, but the object is uninitialized. (<a href='#6.3.2.1'>6.3.2.1</a>).
 | |
| 
 | |
|       — An lvalue having array type is converted to a pointer to the initial element of the array, and
 | |
|         the array object has register storage class (<a href='#6.3.2.1'>6.3.2.1</a>).
 | |
| 
 | |
|       — An attempt is made to use the value of a void expression, or an implicit or explicit conversion
 | |
|         (except to void) is applied to a void expression (<a href='#6.3.2.2'>6.3.2.2</a>).
 | |
| — Conversion of a pointer to an integer type produces a value outside the range that can be
 | |
|   represented (<a href='#6.3.2.3'>6.3.2.3</a>).
 | |
| — Conversion between two pointer types produces a result that is incorrectly aligned (<a href='#6.3.2.3'>6.3.2.3</a>).
 | |
| — A pointer is used to call a function whose type is not compatible with the referenced type
 | |
|   (<a href='#6.3.2.3'>6.3.2.3</a>).
 | |
| — An unmatched ’ or " character is encountered on a logical source line during tokenization
 | |
|   (<a href='#6.4'>6.4</a>).
 | |
| — A reserved keyword token is used in translation phase 7 or 8 for some purpose other than as a
 | |
|   keyword (<a href='#6.4.1'>6.4.1</a>).
 | |
| — A universal character name in an identifier does not designate a character whose encoding
 | |
|   falls into one of the specified ranges (<a href='#6.4.2.1'>6.4.2.1</a>).
 | |
| — The initial character of an identifier is a universal character name designating a digit (<a href='#6.4.2.1'>6.4.2.1</a>).
 | |
| — Two identifiers differ only in nonsignificant characters (<a href='#6.4.2.1'>6.4.2.1</a>).
 | |
| — The identifier __func__ is explicitly declared (<a href='#6.4.2.2'>6.4.2.2</a>).
 | |
| — The program attempts to modify a string literal (<a href='#6.4.5'>6.4.5</a>).
 | |
| — The characters ’ , \ , ", // , or /* occur in the sequence between the < and > delimiters, or the
 | |
|   characters ’ , \ , // , or /* occur in the sequence between the " delimiters, in a header name
 | |
|   preprocessing token (<a href='#6.4.7'>6.4.7</a>).
 | |
| — A side effect on a scalar object is unsequenced relative to either a different side effect on the
 | |
|   same scalar object or a value computation using the value of the same scalar object (<a href='#6.5'>6.5</a>).
 | |
| — An exceptional condition occurs during the evaluation of an expression (<a href='#6.5'>6.5</a>).
 | |
| — An object has its stored value accessed other than by an lvalue of an allowable type (<a href='#6.5'>6.5</a>).
 | |
| — A function is defined with a type that is not compatible with the type (of the expression)
 | |
|   pointed to by the expression that denotes the called function (<a href='#6.5.2.2'>6.5.2.2</a>).
 | |
| — A member of an atomic structure or union is accessed (<a href='#6.5.2.3'>6.5.2.3</a>).
 | |
| — The operand of the unary * operator has an invalid value (<a href='#6.5.3.2'>6.5.3.2</a>).
 | |
| — A pointer is converted to other than an integer or pointer type (<a href='#6.5.4'>6.5.4</a>).
 | |
| — The value of the second operand of the / or % operator is zero (<a href='#6.5.5'>6.5.5</a>).
 | |
| — If the quotient a/b is not representable, the behavior of both a/b and a%b (<a href='#6.5.5'>6.5.5</a>).
 | |
| — Addition or subtraction of a pointer into, or just beyond, an array object and an integer type
 | |
|   produces a result that does not point into, or just beyond, the same array object (<a href='#6.5.6'>6.5.6</a>).
 | |
| — Addition or subtraction of a pointer into, or just beyond, an array object and an integer type
 | |
|   produces a result that points just beyond the array object and is used as the operand of a unary
 | |
|   * operator that is evaluated (<a href='#6.5.6'>6.5.6</a>).
 | |
| — Pointers that do not point into, or just beyond, the same array object are subtracted (<a href='#6.5.6'>6.5.6</a>).
 | |
| — An array subscript is out of range, even if an object is apparently accessible with the given
 | |
|   subscript (as in the lvalue expression a[1][7] given the declaration int a[4][5]) (<a href='#6.5.6'>6.5.6</a>).
 | |
| — The result of subtracting two pointers is not representable in an object of type ptrdiff_t
 | |
|   (<a href='#6.5.6'>6.5.6</a>).
 | |
| — An expression is shifted by a negative number or by an amount greater than or equal to the
 | |
|   width of the promoted expression (<a href='#6.5.7'>6.5.7</a>).
 | |
| — An expression having signed promoted type is left-shifted and either the value of the expres-
 | |
|   sion is negative or the result of shifting would not be representable in the promoted type
 | |
|   (<a href='#6.5.7'>6.5.7</a>).
 | |
| 
 | |
| — Pointers that do not point to the same aggregate or union (nor just beyond the same array
 | |
|   object) are compared using relational operators (<a href='#6.5.8'>6.5.8</a>).
 | |
| 
 | |
| — An object is assigned to an inexactly overlapping object or to an exactly overlapping object
 | |
|   with incompatible type (<a href='#6.5.16.1'>6.5.16.1</a>).
 | |
| 
 | |
| — An expression that is required to be an integer constant expression does not have an integer
 | |
|   type; has operands that are not integer constants, enumeration constants, character constants,
 | |
|   predefined constants, sizeof expressions whose results are integer constants, alignof expres-
 | |
|   sions, or immediately-cast floating constants; or contains casts (outside operands to sizeof
 | |
|   and alignof operators) other than conversions of arithmetic types to integer types (<a href='#6.6'>6.6</a>).
 | |
| 
 | |
| — A constant expression in an initializer is not, or does not evaluate to, one of the following: an
 | |
|   arithmetic constant expression, a null pointer constant, an address constant, or an address
 | |
|   constant for a complete object type plus or minus an integer constant expression (<a href='#6.6'>6.6</a>).
 | |
| 
 | |
| — An arithmetic constant expression does not have arithmetic type; has operands that are not
 | |
|   integer constants, floating constants, enumeration constants, character constants, predefined
 | |
|   constants, sizeof expressions whose results are integer constants, or alignof expressions; or
 | |
|   contains casts (outside operands to sizeof or alignof operators) other than conversions of
 | |
|   arithmetic types to arithmetic types (<a href='#6.6'>6.6</a>).
 | |
| 
 | |
| — The value of an object is accessed by an array-subscript [], member-access . or-> , address &,
 | |
|   or indirection * operator or a pointer cast in creating an address constant (<a href='#6.6'>6.6</a>).
 | |
| 
 | |
| — An identifier for an object is declared with no linkage and the type of the object is incomplete
 | |
|   after its declarator, or after its init-declarator if it has an initializer (<a href='#6.7'>6.7</a>).
 | |
| 
 | |
| — A function is declared at block scope with an explicit storage-class specifier other than extern
 | |
|   (<a href='#6.7.1'>6.7.1</a>).
 | |
| 
 | |
| — A structure or union is defined without any named members (including those specified
 | |
|   indirectly via anonymous structures and unions) (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
| 
 | |
| — An attempt is made to access, or generate a pointer to just past, a flexible array member of a
 | |
|   structure when the referenced object provides no elements for that array (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
| 
 | |
| — When the complete type is needed, an incomplete structure or union type is not completed in
 | |
|   the same scope by another declaration of the tag that defines the content (<a href='#6.7.2.3'>6.7.2.3</a>).
 | |
| 
 | |
| — An attempt is made to modify an object defined with a const-qualified type through use of an
 | |
|   lvalue with non-const-qualified type (<a href='#6.7.3'>6.7.3</a>).
 | |
| 
 | |
| — An attempt is made to refer to an object defined with a volatile-qualified type through use of
 | |
|   an lvalue with non-volatile-qualified type (<a href='#6.7.3'>6.7.3</a>).
 | |
| 
 | |
| — The specification of a function type includes any type qualifiers (<a href='#6.7.3'>6.7.3</a>).
 | |
| 
 | |
| — Two qualified types that are required to be compatible do not have the identically qualified
 | |
|   version of a compatible type (<a href='#6.7.3'>6.7.3</a>).
 | |
| 
 | |
| — An object which has been modified is accessed through a restrict-qualified pointer to a const-
 | |
|   qualified type, or through a restrict-qualified pointer and another pointer that are not both
 | |
|   based on the same object (<a href='#6.7.3.1'>6.7.3.1</a>).
 | |
| 
 | |
| — A restrict-qualified pointer is assigned a value based on another restricted pointer whose
 | |
|   associated block neither began execution before the block associated with this pointer, nor
 | |
|   ended before the assignment (<a href='#6.7.3.1'>6.7.3.1</a>).
 | |
| — A function with external linkage is declared with an inline function specifier, but is not also
 | |
|   defined in the same translation unit (<a href='#6.7.4'>6.7.4</a>).
 | |
| 
 | |
| — A function declared with a _Noreturn function specifier returns to its caller (<a href='#6.7.4'>6.7.4</a>).
 | |
| 
 | |
| — The definition of an object has an alignment specifier and another declaration of that object
 | |
|   has a different alignment specifier (<a href='#6.7.5'>6.7.5</a>).
 | |
| 
 | |
| — Declarations of an object in different translation units have different alignment specifiers
 | |
|   (<a href='#6.7.5'>6.7.5</a>).
 | |
| 
 | |
| — Two pointer types that are required to be compatible are not identically qualified, or are not
 | |
|   pointers to compatible types (<a href='#6.7.6.1'>6.7.6.1</a>).
 | |
| 
 | |
| — The size expression in an array declaration is not a constant expression and evaluates at
 | |
|   program execution time to a nonpositive value (<a href='#6.7.6.2'>6.7.6.2</a>).
 | |
| 
 | |
| — In a context requiring two array types to be compatible, they do not have compatible element
 | |
|   types, or their size specifiers evaluate to unequal values (<a href='#6.7.6.2'>6.7.6.2</a>).
 | |
| 
 | |
| — A declaration of an array parameter includes the keyword static within the [ and ] and the
 | |
|   corresponding argument does not provide access to the first element of an array with at least
 | |
|   the specified number of elements (<a href='#6.7.6.3'>6.7.6.3</a>).
 | |
| 
 | |
| — A storage-class specifier or type qualifier modifies the keyword void as a function parameter
 | |
|   type list (<a href='#6.7.6.3'>6.7.6.3</a>).
 | |
| 
 | |
| — In a context requiring two function types to be compatible, they do not have compatible return
 | |
|   types, or their parameters disagree in use of the ellipsis terminator or the number and type of
 | |
|   parameters (after default argument promotion, when there is no parameter type list) (<a href='#6.7.6.3'>6.7.6.3</a>).
 | |
| 
 | |
| — A declaration for which a type is inferred contains a pointer, array, or function declarators
 | |
|   (<a href='#6.7.9'>6.7.9</a>).
 | |
| 
 | |
| — A declaration for which a type is inferred contains no or more than one declarators (<a href='#6.7.9'>6.7.9</a>).
 | |
| 
 | |
| — The value of an unnamed member of a structure or union is used (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| — The initializer for a scalar is neither a single expression nor a single expression enclosed in
 | |
|   braces (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| — The initializer for a structure or union object that has automatic storage duration is neither an
 | |
|   initializer list nor a single expression that has compatible structure or union type (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| — The initializer for an aggregate or union, other than an array initialized by a string literal, is
 | |
|   not a brace-enclosed list of initializers for its elements or members (<a href='#6.7.10'>6.7.10</a>).
 | |
| 
 | |
| — A function definition that does not have the asserted property is called by a function decla-
 | |
|   ration or a function pointer with a type that has the unsequenced or reproducible attribute
 | |
|   (<a href='#6.7.12.7'>6.7.12.7</a>).
 | |
| 
 | |
| — An identifier with external linkage is used, but in the program there does not exist exactly
 | |
|   one external definition for the identifier, or the identifier is not used and there exist multiple
 | |
|   external definitions for the identifier (<a href='#6.9'>6.9</a>).
 | |
| 
 | |
| — A function that accepts a variable number of arguments is defined without a parameter type
 | |
|   list that ends with the ellipsis notation (<a href='#6.9.1'>6.9.1</a>).
 | |
| 
 | |
| — The } that terminates a function is reached, and the value of the function call is used by the
 | |
|   caller (<a href='#6.9.1'>6.9.1</a>).
 | |
| 
 | |
| — An identifier for an object with internal linkage and an incomplete type is declared with a
 | |
|   tentative definition (<a href='#6.9.2'>6.9.2</a>).
 | |
| — A non-directive preprocessing directive is executed (<a href='#6.10'>6.10</a>).
 | |
| 
 | |
| — The token defined is generated during the expansion of a #if or #elif preprocessing direc-
 | |
|   tive, or the use of the defined unary operator does not match one of the two specified forms
 | |
|   prior to macro replacement (<a href='#6.10.1'>6.10.1</a>).
 | |
| 
 | |
| — The #include preprocessing directive that results after expansion does not match one of the
 | |
|   two header name forms (<a href='#6.10.2'>6.10.2</a>).
 | |
| 
 | |
| — The character sequence in an #include preprocessing directive does not start with a letter
 | |
|   (<a href='#6.10.2'>6.10.2</a>).
 | |
| 
 | |
| — There are sequences of preprocessing tokens within the list of macro arguments that would
 | |
|   otherwise act as preprocessing directives (<a href='#6.10.4'>6.10.4</a>).
 | |
| 
 | |
| — The result of the preprocessing operator # is not a valid character string literal (<a href='#6.10.4.2'>6.10.4.2</a>).
 | |
| 
 | |
| — The result of the preprocessing operator ## is not a valid preprocessing token (<a href='#6.10.4.3'>6.10.4.3</a>).
 | |
| 
 | |
| — The #line preprocessing directive that results after expansion does not match one of the two
 | |
|   well-defined forms, or its digit sequence specifies zero or a number greater than 2147483647
 | |
|   (<a href='#6.10.5'>6.10.5</a>).
 | |
| 
 | |
| — A non-STDC #pragma preprocessing directive that is documented as causing translation failure
 | |
|   or some other form of undefined behavior is encountered (<a href='#6.10.7'>6.10.7</a>).
 | |
| 
 | |
| — A #pragma STDC preprocessing directive does not match one of the well-defined forms (<a href='#6.10.7'>6.10.7</a>).
 | |
| 
 | |
| — The name of a predefined macro, or the identifier defined, is the subject of a #define or
 | |
|   #undef preprocessing directive (<a href='#6.10.9'>6.10.9</a>).
 | |
| 
 | |
| — An attempt is made to copy an object to an overlapping object by use of a library function,
 | |
|   other than as explicitly allowed (e.g., memmove) (Clause 7).
 | |
| 
 | |
| — A file with the same name as one of the standard headers, not provided as part of the implemen-
 | |
|   tation, is placed in any of the standard places that are searched for included source files (<a href='#7.1.2'>7.1.2</a>).
 | |
| 
 | |
| — A header is included within an external declaration or definition (<a href='#7.1.2'>7.1.2</a>).
 | |
| 
 | |
| — A function, object, type, or macro that is specified as being declared or defined by some
 | |
|   standard header is used before any header that declares or defines it is included (<a href='#7.1.2'>7.1.2</a>).
 | |
| 
 | |
| — A standard header is included while a macro is defined with the same name as a keyword
 | |
|   (<a href='#7.1.2'>7.1.2</a>).
 | |
| 
 | |
| — The program attempts to declare a library function itself, rather than via a standard header,
 | |
|   but the declaration does not have external linkage (<a href='#7.1.2'>7.1.2</a>).
 | |
| 
 | |
| — The program declares or defines a reserved identifier, other than as allowed by <a href='#7.1.4'>7.1.4</a> (<a href='#7.1.3'>7.1.3</a>).
 | |
| 
 | |
| — The program removes the definition of a macro whose name begins with an underscore and
 | |
|   either an uppercase letter or another underscore (<a href='#7.1.3'>7.1.3</a>).
 | |
| 
 | |
| — An argument to a library function has an invalid value or a type not expected by a function
 | |
|   with a variable number of arguments (<a href='#7.1.4'>7.1.4</a>).
 | |
| 
 | |
| — The pointer passed to a library function array parameter does not have a value such that all
 | |
|   address computations and object accesses are valid (<a href='#7.1.4'>7.1.4</a>).
 | |
| 
 | |
| — The macro definition of assert is suppressed in order to access an actual function (<a href='#7.2'>7.2</a>).
 | |
| 
 | |
| — The argument to the assert macro does not have a scalar type (<a href='#7.2'>7.2</a>).
 | |
| — The CX_LIMITED_RANGE, FENV_ACCESS, or FP_CONTRACT pragma is used in any context other
 | |
|   than outside all external declarations or preceding all explicit declarations and statements
 | |
|   inside a compound statement (<a href='#7.3.4'>7.3.4</a>, <a href='#7.6.1'>7.6.1</a>, <a href='#7.12.2'>7.12.2</a>).
 | |
| — The value of an argument to a character handling function is neither equal to the value of EOF
 | |
|   nor representable as an unsigned char (<a href='#7.4'>7.4</a>).
 | |
| — A macro definition of errno is suppressed in order to access an actual object, or the program
 | |
|   defines an identifier with the name errno (<a href='#7.5'>7.5</a>).
 | |
| — Part of the program tests floating-point status flags, sets floating-point control modes, or
 | |
|   runs under non-default mode settings, but was translated with the state for the FENV_ACCESS
 | |
|   pragma "off" (<a href='#7.6.1'>7.6.1</a>).
 | |
| — The exception-mask argument for one of the functions that provide access to the floating-point
 | |
|   status flags has a nonzero value not obtained by bitwise OR of the floating-point exception
 | |
|   macros (<a href='#7.6.4'>7.6.4</a>).
 | |
| — The fesetexceptflag function is used to set floating-point status flags that were not specified
 | |
|   in the call to the fegetexceptflag function that provided the value of the corresponding
 | |
|   fexcept_t object (<a href='#7.6.4.5'>7.6.4.5</a>).
 | |
| 
 | |
| — The argument to fesetenv or feupdateenv is neither an object set by a call to fegetenv or
 | |
|   feholdexcept, nor is it an environment macro (<a href='#7.6.6.3'>7.6.6.3</a>, <a href='#7.6.6.4'>7.6.6.4</a>).
 | |
| 
 | |
| — The value of the result of an integer arithmetic or conversion function cannot be represented
 | |
|   (<a href='#7.8.2.1'>7.8.2.1</a>, <a href='#7.8.2.2'>7.8.2.2</a>, <a href='#7.8.2.3'>7.8.2.3</a>, <a href='#7.8.2.4'>7.8.2.4</a>, <a href='#7.24.6.1'>7.24.6.1</a>, <a href='#7.24.6.2'>7.24.6.2</a>, <a href='#7.24.1'>7.24.1</a>).
 | |
| — The program modifies the string pointed to by the value returned by the setlocale function
 | |
|   (<a href='#7.11.1.1'>7.11.1.1</a>).
 | |
| — A pointer returned by the setlocale function is used after a subsequent call to the function,
 | |
|   or after the calling thread has exited (<a href='#7.11.1.1'>7.11.1.1</a>).
 | |
| — The program modifies the structure pointed to by the value returned by the localeconv
 | |
|   function (<a href='#7.11.2.1'>7.11.2.1</a>).
 | |
| — A macro definition of math_errhandling is suppressed or the program defines an identifier
 | |
|   with the name math_errhandling (<a href='#7.12'>7.12</a>).
 | |
| — An argument to a floating-point classification or comparison macro is not of real floating type
 | |
|   (<a href='#7.12.3'>7.12.3</a>, <a href='#7.12.17'>7.12.17</a>).
 | |
| — A macro definition of setjmp is suppressed in order to access an actual function, or the
 | |
|   program defines an external identifier with the name setjmp (<a href='#7.13'>7.13</a>).
 | |
| — An invocation of the setjmp macro occurs other than in an allowed context (<a href='#7.13.2.1'>7.13.2.1</a>).
 | |
| — The longjmp function is invoked to restore a nonexistent environment (<a href='#7.13.2.1'>7.13.2.1</a>).
 | |
| — After a longjmp, there is an attempt to access the value of an object of automatic storage dura-
 | |
|   tion that does not have volatile-qualified type, local to the function containing the invocation
 | |
|   of the corresponding setjmp macro, that was changed between the setjmp invocation and
 | |
|   longjmp call (<a href='#7.13.2.1'>7.13.2.1</a>).
 | |
| 
 | |
| — The program specifies an invalid pointer to a signal handler function (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — A signal handler returns when the signal corresponded to a computational exception (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — A signal handler called in response to SIGFPE, SIGILL, SIGSEGV, or any other implementation-
 | |
|   defined value corresponding to a computational exception returns (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — A signal occurs as the result of calling the abort or raise function, and the signal handler
 | |
|   calls the raise function (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — A signal occurs other than as the result of calling the abort or raise function, and the signal
 | |
|   handler refers to an object with static or thread storage duration that is not a lock-free atomic
 | |
|   object other than by assigning a value to an object declared as volatile sig_atomic_t, or
 | |
|   calls any function in the standard library other than the abort function, the _Exit function,
 | |
|   the quick_exit function, the functions in <stdatomic.h> (except where explicitly stated
 | |
|   otherwise) when the atomic arguments are lock-free, the atomic_is_lock_free function with
 | |
|   any atomic argument, or the signal function (for the same signal number) (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — The value of errno is referred to after a signal occurred other than as the result of calling the
 | |
|   abort or raise function and the corresponding signal handler obtained a SIG_ERR return
 | |
|   from a call to the signal function (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — A signal is generated by an asynchronous signal handler (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — The signal function is used in a multi-threaded program (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| — A function with a variable number of arguments attempts to access its varying arguments
 | |
|   other than through a properly declared and initialized va_list object, or before the va_start
 | |
|   macro is invoked (<a href='#7.16'>7.16</a>, <a href='#7.16.1.1'>7.16.1.1</a>, <a href='#7.16.1.4'>7.16.1.4</a>).
 | |
| — The macro va_arg is invoked using the parameter ap that was passed to a function that
 | |
|   invoked the macro va_arg with the same parameter (<a href='#7.16'>7.16</a>).
 | |
| — A macro definition of va_start, va_arg, va_copy, or va_end is suppressed in order to access
 | |
|   an actual function, or the program defines an external identifier with the name va_copy or
 | |
|   va_end (<a href='#7.16.1'>7.16.1</a>).
 | |
| 
 | |
| — The va_start or va_copy macro is invoked without a corresponding invocation of the va_end
 | |
|   macro in the same function, or vice versa (<a href='#7.16.1'>7.16.1</a>, <a href='#7.16.1.2'>7.16.1.2</a>, <a href='#7.16.1.3'>7.16.1.3</a>, <a href='#7.16.1.4'>7.16.1.4</a>).
 | |
| — The type parameter to the va_arg macro is not such that a pointer to an object of that type can
 | |
|   be obtained simply by postfixing a * (<a href='#7.16.1.1'>7.16.1.1</a>).
 | |
| — The va_arg macro is invoked when there is no actual next argument, or with a specified
 | |
|   type that is not compatible with the promoted type of the actual next argument, with certain
 | |
|   exceptions (<a href='#7.16.1.1'>7.16.1.1</a>).
 | |
| — Using a null pointer constant in form of an integer expression as an argument to a ... function
 | |
|   and then interpreting it as a void* or char* (<a href='#7.16.1.1'>7.16.1.1</a>).
 | |
| — The va_copy or va_start macro is called to initialize a va_list that was previously initialized
 | |
|   by either macro without an intervening invocation of the va_end macro for the same va_list
 | |
|   (<a href='#7.16.1.2'>7.16.1.2</a>, <a href='#7.16.1.4'>7.16.1.4</a>).
 | |
| — The macro definition of a generic function is suppressed in order to access an actual function
 | |
|   (<a href='#7.17.1'>7.17.1</a>, <a href='#7.18'>7.18</a>).
 | |
| — The type parameter of an offsetof macro defines a new type (<a href='#7.21'>7.21</a>).
 | |
| — When program execution reaches an unreachable() macro call (<a href='#7.21.1'>7.21.1</a>).
 | |
| — Arbitrarily copying or changing the bytes of or copying from a non-null pointer into a
 | |
|   nullptr_t object and then reading that object (<a href='#7.21.2'>7.21.2</a>).
 | |
| 
 | |
| — The member-designator parameter of an offsetof macro is an invalid right operand of the .
 | |
|   operator for the type parameter, or designates a bit-field (<a href='#7.21'>7.21</a>).
 | |
| — The argument in an instance of one of the integer-constant macros is not a decimal, octal, or
 | |
|   hexadecimal constant, or it has a value that exceeds the limits for the corresponding type
 | |
|   (<a href='#7.22.4'>7.22.4</a>).
 | |
| — A byte input/output function is applied to a wide-oriented stream, or a wide character
 | |
|   input/output function is applied to a byte-oriented stream (<a href='#7.23.2'>7.23.2</a>).
 | |
| — Use is made of any portion of a file beyond the most recent wide character written to a
 | |
|   wide-oriented stream (<a href='#7.23.2'>7.23.2</a>).
 | |
| 
 | |
| — The value of a pointer to a FILE object is used after the associated file is closed (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| — The stream for the fflush function points to an input stream or to an update stream in which
 | |
|   the most recent operation was input (<a href='#7.23.5.2'>7.23.5.2</a>).
 | |
| 
 | |
| — The string pointed to by the mode argument in a call to the fopen function does not exactly
 | |
|   match one of the specified character sequences (<a href='#7.23.5.3'>7.23.5.3</a>).
 | |
| 
 | |
| — An output operation on an update stream is followed by an input operation without an
 | |
|   intervening call to the fflush function or a file positioning function, or an input operation
 | |
|   on an update stream is followed by an output operation with an intervening call to a file
 | |
|   positioning function (<a href='#7.23.5.3'>7.23.5.3</a>).
 | |
| 
 | |
| — An attempt is made to use the contents of the array that was supplied in a call to the setvbuf
 | |
|   function (<a href='#7.23.5.6'>7.23.5.6</a>).
 | |
| 
 | |
| — There are insufficient arguments for the format in a call to one of the formatted input/output
 | |
|   functions, or an argument does not have an appropriate type (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.1'>7.31.2.1</a>,
 | |
|   and <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| 
 | |
| — The format in a call to one of the formatted input/output functions or to the strftime or
 | |
|   wcsftime function is not a valid multibyte character sequence that begins and ends in its
 | |
|   initial shift state (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.29.3.5'>7.29.3.5</a>, <a href='#7.31.2.1'>7.31.2.1</a>, <a href='#7.31.2.2'>7.31.2.2</a>, <a href='#7.31.5.1'>7.31.5.1</a>).
 | |
| 
 | |
| — In a call to one of the formatted output functions, a precision appears with a conversion
 | |
|   specifier other than those described (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — A conversion specification for a formatted output function uses an asterisk to denote an
 | |
|   argument-supplied field width or precision, but the corresponding argument is not provided
 | |
|   (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — A conversion specification for a formatted output function uses a # or 0 flag with a conversion
 | |
|   specifier other than those described (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — A conversion specification for one of the formatted input/output functions uses a length
 | |
|   modifier with a conversion specifier other than those described (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.1'>7.31.2.1</a>,
 | |
|   and <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| 
 | |
| — An s conversion specifier is encountered by one of the formatted output functions, and the
 | |
|   argument is missing the null terminator (unless a precision is specified that does not require
 | |
|   null termination) (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — An n conversion specification for one of the formatted input/output functions includes any
 | |
|   flags, an assignment-suppressing character, a field width, or a precision (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.23.6.2'>7.23.6.2</a>,
 | |
|   and <a href='#7.31.2.1'>7.31.2.1</a>, <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| 
 | |
| — A % conversion specifier is encountered by one of the formatted input/output functions, but
 | |
|   the complete conversion specification is not exactly %% (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.1'>7.31.2.1</a>, <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| 
 | |
| — An invalid conversion specification is found in the format for one of the formatted input/out-
 | |
|   put functions, or the strftime or wcsftime function (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.29.3.5'>7.29.3.5</a>, <a href='#7.31.2.1'>7.31.2.1</a>,
 | |
|   and <a href='#7.31.2.2'>7.31.2.2</a>, <a href='#7.31.5.1'>7.31.5.1</a>).
 | |
| 
 | |
| — The number of characters or wide characters transmitted by a formatted output function (or
 | |
|   written to an array, or that would have been written to an array) is greater than INT_MAX
 | |
|   (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — The number of input items assigned by a formatted input function is greater than INT_MAX
 | |
|   (<a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| — The result of a conversion by one of the formatted input functions cannot be represented in
 | |
|   the corresponding object, or the receiving object does not have an appropriate type (<a href='#7.23.6.2'>7.23.6.2</a>,
 | |
|   and <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| — A c, s, or [ conversion specifier is encountered by one of the formatted input functions, and
 | |
|   the array pointed to by the corresponding argument is not large enough to accept the input
 | |
|   sequence (and a null terminator if the conversion specifier is s or [) (<a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| — A c, s, or [ conversion specifier with an l qualifier is encountered by one of the formatted
 | |
|   input functions, but the input is not a valid multibyte character sequence that begins in the
 | |
|   initial shift state (<a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| — The input item for a %p conversion by one of the formatted input functions is not a value
 | |
|   converted earlier during the same program execution (<a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| — The vfprintf, vfscanf, vprintf, vscanf, vsnprintf, vsprintf, vsscanf, vfwprintf,
 | |
|   vfwscanf , vswprintf , vswscanf , vwprintf , or vwscanf function is called with an improperly
 | |
|   initialized va_list argument, or the argument is used (other than in an invocation of va_end)
 | |
|   after the function returns (<a href='#7.23.6.8'>7.23.6.8</a>, <a href='#7.23.6.9'>7.23.6.9</a>, <a href='#7.23.6.10'>7.23.6.10</a>, <a href='#7.23.6.11'>7.23.6.11</a>, <a href='#7.23.6.12'>7.23.6.12</a>, <a href='#7.23.6.13'>7.23.6.13</a>, <a href='#7.23.6.14'>7.23.6.14</a>,
 | |
|   and <a href='#7.31.2.5'>7.31.2.5</a>, <a href='#7.31.2.6'>7.31.2.6</a>, <a href='#7.31.2.7'>7.31.2.7</a>, <a href='#7.31.2.8'>7.31.2.8</a>, <a href='#7.31.2.9'>7.31.2.9</a>, <a href='#7.31.2.10'>7.31.2.10</a>).
 | |
| — The contents of the array supplied in a call to the fgets or fgetws function are used after a
 | |
|   read error occurred (<a href='#7.23.7.2'>7.23.7.2</a>, <a href='#7.31.3.2'>7.31.3.2</a>).
 | |
| — The file position indicator for a binary stream is used after a call to the ungetc function where
 | |
|   its value was zero before the call (<a href='#7.23.7.10'>7.23.7.10</a>).
 | |
| — The file position indicator for a stream is used after an error occurred during a call to the
 | |
|   fread or fwrite function (<a href='#7.23.8.1'>7.23.8.1</a>, <a href='#7.23.8.2'>7.23.8.2</a>).
 | |
| 
 | |
| — A partial element read by a call to the fread function is used (<a href='#7.23.8.1'>7.23.8.1</a>).
 | |
| — The fseek function is called for a text stream with a nonzero offset and either the offset was
 | |
|   not returned by a previous successful call to the ftell function on a stream associated with
 | |
|   the same file or whence is not SEEK_SET (<a href='#7.23.9.2'>7.23.9.2</a>).
 | |
| — The fsetpos function is called to set a position that was not returned by a previous successful
 | |
|   call to the fgetpos function on a stream associated with the same file (<a href='#7.23.9.3'>7.23.9.3</a>).
 | |
| — A non-null pointer returned by a call to the calloc, malloc, realloc, or aligned_alloc
 | |
|   function with a zero requested size is used to access an object (<a href='#7.24.3'>7.24.3</a>).
 | |
| — The value of a pointer that refers to space deallocated by a call to the free or realloc function
 | |
|   is used (<a href='#7.24.3'>7.24.3</a>).
 | |
| — The pointer argument to the free or realloc function does not match a pointer earlier
 | |
|   returned by a memory management function, or the space has been deallocated by a call to
 | |
|   free or realloc (<a href='#7.24.3.3'>7.24.3.3</a>, <a href='#7.24.3.7'>7.24.3.7</a>).
 | |
| 
 | |
| — The value of the object allocated by the malloc function is used (<a href='#7.24.3.6'>7.24.3.6</a>).
 | |
| — The values of any bytes in a new object allocated by the realloc function beyond the size of
 | |
|   the old object are used (<a href='#7.24.3.7'>7.24.3.7</a>).
 | |
| — The program calls the exit or quick_exit function more than once, or calls both functions
 | |
|   (<a href='#7.24.4.4'>7.24.4.4</a>, <a href='#7.24.4.7'>7.24.4.7</a>).
 | |
| — During the call to a function registered with the atexit or at_quick_exit function, a call is
 | |
|   made to the longjmp function that would terminate the call to the registered function (<a href='#7.24.4.4'>7.24.4.4</a>,
 | |
|   and <a href='#7.24.4.7'>7.24.4.7</a>).
 | |
| — The string set up by the getenv or strerror function is modified by the program (<a href='#7.24.4.6'>7.24.4.6</a>,
 | |
|   and <a href='#7.26.6.3'>7.26.6.3</a>).
 | |
| — A signal is raised while the quick_exit function is executing (<a href='#7.24.4.7'>7.24.4.7</a>).
 | |
| 
 | |
| — A command is executed through the system function in a way that is documented as causing
 | |
|   termination or some other form of undefined behavior (<a href='#7.24.4.8'>7.24.4.8</a>).
 | |
| 
 | |
| — A searching or sorting utility function is called with an invalid pointer argument, even if the
 | |
|   number of elements is zero (<a href='#7.24.5'>7.24.5</a>).
 | |
| 
 | |
| — The comparison function called by a searching or sorting utility function alters the contents of
 | |
|   the array being searched or sorted, or returns ordering values inconsistently (<a href='#7.24.5'>7.24.5</a>).
 | |
| 
 | |
| — The array being searched by the bsearch function does not have its elements in proper order
 | |
|   (<a href='#7.24.5.1'>7.24.5.1</a>).
 | |
| 
 | |
| — The current conversion state is used by a multibyte/wide character conversion function after
 | |
|   changing the LC_CTYPE category (<a href='#7.24.7'>7.24.7</a>).
 | |
| 
 | |
| — A string or wide string utility function is instructed to access an array beyond the end of an
 | |
|   object (<a href='#7.26.1'>7.26.1</a>, <a href='#7.31.4'>7.31.4</a>).
 | |
| 
 | |
| — A string or wide string utility function is called with an invalid pointer argument, even if the
 | |
|   length is zero (<a href='#7.26.1'>7.26.1</a>, <a href='#7.31.4'>7.31.4</a>).
 | |
| 
 | |
| — The contents of the destination array are used after a call to the strxfrm, strftime, wcsxfrm,
 | |
|   or wcsftime function in which the specified length was too small to hold the entire null-
 | |
|   terminated result (<a href='#7.26.4.5'>7.26.4.5</a>, <a href='#7.29.3.5'>7.29.3.5</a>, <a href='#7.31.4.4.4'>7.31.4.4.4</a>, <a href='#7.31.5.1'>7.31.5.1</a>).
 | |
| 
 | |
| — A sequence of calls of the strtok function is made from different threads (<a href='#7.26.5.9'>7.26.5.9</a>).
 | |
| 
 | |
| — The first argument in the very first call to the strtok or wcstok is a null pointer (<a href='#7.26.5.9'>7.26.5.9</a>,
 | |
|   and <a href='#7.31.4.6.7'>7.31.4.6.7</a>).
 | |
| 
 | |
| — A pointer returned by the strerror function is used after a subsequent call to the function, or
 | |
|   after the calling thread has exited (<a href='#7.26.6.3'>7.26.6.3</a>).
 | |
| 
 | |
| — The type of an argument to a type-generic macro is not compatible with the type of the
 | |
|   corresponding parameter of the selected function (<a href='#7.27'>7.27</a>).
 | |
| 
 | |
| — Arguments for generic parameters of a type-generic macro are such that some argument has a
 | |
|   corresponding real type that is of standard floating type and another argument is of decimal
 | |
|   floating type (<a href='#7.27'>7.27</a>).
 | |
| 
 | |
| — Arguments for generic parameters of a type-generic macro are such that neither <math.h> and
 | |
|   <complex.h> define a function whose generic parameters have the determined corresponding
 | |
|   real type (<a href='#7.27'>7.27</a>).
 | |
| 
 | |
| — A complex argument is supplied for a generic parameter of a type-generic macro that has no
 | |
|   corresponding complex function (<a href='#7.27'>7.27</a>).
 | |
| 
 | |
| — A decimal floating argument is supplied for a generic parameter of a type-generic macro that
 | |
|   expects a complex argument (<a href='#7.27'>7.27</a>).
 | |
| 
 | |
| — A standard floating or complex argument is supplied for a generic parameter of a type-generic
 | |
|   macro that expects a decimal floating type argument (<a href='#7.27'>7.27</a>).
 | |
| 
 | |
| — A non-recursive mutex passed to mtx_lock is locked by the calling thread (<a href='#7.28.4.3'>7.28.4.3</a>).
 | |
| 
 | |
| — The mutex passed to mtx_timedlock does not support timeout (<a href='#7.28.4.4'>7.28.4.4</a>).
 | |
| 
 | |
| — The mutex passed to mtx_unlock is not locked by the calling thread (<a href='#7.28.4.6'>7.28.4.6</a>).
 | |
| 
 | |
| — The thread passed to thrd_detach or thrd_join was previously detached or joined with
 | |
|   another thread (<a href='#7.28.5.3'>7.28.5.3</a>, <a href='#7.28.5.6'>7.28.5.6</a>).
 | |
|       — The tss_create function is called from within a destructor (<a href='#7.28.6.1'>7.28.6.1</a>).
 | |
| 
 | |
|       — The key passed to tss_delete, tss_get, or tss_set was not returned by a call to tss_create
 | |
|         before the thread commenced executing destructors (<a href='#7.28.6.2'>7.28.6.2</a>, <a href='#7.28.6.3'>7.28.6.3</a>, <a href='#7.28.6.4'>7.28.6.4</a>).
 | |
| 
 | |
|       — An attempt is made to access the pointer returned by the time conversion functions after the
 | |
|         thread that originally called the function to obtain it has exited (<a href='#7.29.3'>7.29.3</a>).
 | |
| 
 | |
|       — At least one member of the broken-down time passed to asctime contains a value outside its
 | |
|         normal range, or the calculated year exceeds four digits or is less than the year 1000 (<a href='#7.29.3.1'>7.29.3.1</a>).
 | |
| 
 | |
|       — The argument corresponding to an s specifier without an l qualifier in a call to the fwprintf
 | |
|         function does not point to a valid multibyte character sequence that begins in the initial shift
 | |
|         state (<a href='#7.31.2.11'>7.31.2.11</a>).
 | |
| 
 | |
|       — In a call to the wcstok function, the object pointed to by ptr does not have the value stored by
 | |
|         the previous call for the same wide string (<a href='#7.31.4.6.7'>7.31.4.6.7</a>).
 | |
| 
 | |
|       — An mbstate_t object is used inappropriately (<a href='#7.31.6'>7.31.6</a>).
 | |
| 
 | |
|       — The value of an argument of type wint_t to a wide character classification or case mapping
 | |
|         function is neither equal to the value of WEOF nor representable as a wchar_t (<a href='#7.32.1'>7.32.1</a>).
 | |
| 
 | |
|       — The iswctype function is called using a different LC_CTYPE category from the one in effect for
 | |
|         the call to the wctype function that returned the description (<a href='#7.32.2.2.1'>7.32.2.2.1</a>).
 | |
| 
 | |
|       — The towctrans function is called using a different LC_CTYPE category from the one in effect
 | |
|         for the call to the wctrans function that returned the description (<a href='#7.32.3.2.1'>7.32.3.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3'></a>
 | |
| <hr>
 | |
| <h3>J.3 [Implementation-defined behavior]</h3>
 | |
| <a name='J.3p1'></a>
 | |
| <pre>1   A conforming implementation is required to document its choice of behavior in each of the areas
 | |
|     listed in this subclause. The following are implementation-defined:
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.1'></a>
 | |
| <hr>
 | |
| <h3>J.3.1 [Translation]</h3>
 | |
| <a name='J.3.1p1'></a>
 | |
| <pre>1     — How a diagnostic is identified (<a href='#3.10'>3.10</a>, <a href='#5.1.1.3'>5.1.1.3</a>).
 | |
| 
 | |
|       — Whether each nonempty sequence of white-space characters other than new-line is retained or
 | |
|         replaced by one space character in translation phase 3 (<a href='#5.1.1.2'>5.1.1.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.2'></a>
 | |
| <hr>
 | |
| <h3>J.3.2 [Environment]</h3>
 | |
| <a name='J.3.2p1'></a>
 | |
| <pre>1     — The mapping between physical source file multibyte characters and the source character set in
 | |
|         translation phase 1 (<a href='#5.1.1.2'>5.1.1.2</a>).
 | |
| 
 | |
|       — The name and type of the function called at program startup in a freestanding environment
 | |
|         (<a href='#5.1.2.1'>5.1.2.1</a>).
 | |
| 
 | |
|       — The effect of program termination in a freestanding environment (<a href='#5.1.2.1'>5.1.2.1</a>).
 | |
| 
 | |
|       — An alternative manner in which the main function may be defined (<a href='#5.1.2.2.1'>5.1.2.2.1</a>).
 | |
| 
 | |
|       — The values given to the strings pointed to by the argv argument to main (<a href='#5.1.2.2.1'>5.1.2.2.1</a>).
 | |
| 
 | |
|       — What constitutes an interactive device (<a href='#5.1.2.3'>5.1.2.3</a>).
 | |
| 
 | |
|       — Whether a program can have more than one thread of execution in a freestanding environment
 | |
|         (<a href='#5.1.2.4'>5.1.2.4</a>).
 | |
| 
 | |
|       — The set of signals, their semantics, and their default handling (<a href='#7.14'>7.14</a>).
 | |
| 
 | |
|       — Signal values other than SIGFPE, SIGILL, and SIGSEGV that correspond to a computational
 | |
|         exception (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
|       — Signals for which the equivalent of signal(sig, SIG_IGN); is executed at program startup
 | |
|         (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| 
 | |
|       — The set of environment names and the method for altering the environment list used by the
 | |
|         getenv function (<a href='#7.24.4.6'>7.24.4.6</a>).
 | |
| 
 | |
|       — The manner of execution of the string by the system function (<a href='#7.24.4.8'>7.24.4.8</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.3'></a>
 | |
| <hr>
 | |
| <h3>J.3.3 [Identifiers]</h3>
 | |
| <a name='J.3.3p1'></a>
 | |
| <pre>1     — Which additional multibyte characters may appear in identifiers and their correspondence to
 | |
|         universal character names (<a href='#6.4.2'>6.4.2</a>).
 | |
| 
 | |
|       — The number of significant initial characters in an identifier (<a href='#5.2.4.1'>5.2.4.1</a>, <a href='#6.4.2'>6.4.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.4'></a>
 | |
| <hr>
 | |
| <h3>J.3.4 [Characters]</h3>
 | |
| <a name='J.3.4p1'></a>
 | |
| <pre>1     — The number of bits in a byte (<a href='#3.6'>3.6</a>).
 | |
| 
 | |
|       — The values of the members of the execution character set (<a href='#5.2.1'>5.2.1</a>).
 | |
| 
 | |
|       — The unique value of the member of the execution character set produced for each of the
 | |
|         standard alphabetic escape sequences (<a href='#5.2.2'>5.2.2</a>).
 | |
| 
 | |
|       — The value of a char object into which has been stored any character other than a member of
 | |
|         the basic execution character set (<a href='#6.2.5'>6.2.5</a>).
 | |
| 
 | |
|       — Which of signed char or unsigned char has the same range, representation, and behavior
 | |
|         as "plain" char (<a href='#6.2.5'>6.2.5</a>, <a href='#6.3.1.1'>6.3.1.1</a>).
 | |
| 
 | |
|       — The literal encoding, which maps of the characters of the execution character set to the values
 | |
|         in a character constant or string literal (<a href='#6.2.9'>6.2.9</a>, <a href='#6.4.4.4'>6.4.4.4</a>).
 | |
| 
 | |
|       — The wide literal encoding, of the characters of the execution character set to the values in a
 | |
|         wchar_t character constant or wchar_t string literal (<a href='#6.2.9'>6.2.9</a>, <a href='#6.4.4.4'>6.4.4.4</a>).
 | |
| 
 | |
|       — The mapping of members of the source character set (in character constants and string literals)
 | |
|         to members of the execution character set (<a href='#6.4.4.4'>6.4.4.4</a>, <a href='#5.1.1.2'>5.1.1.2</a>).
 | |
| 
 | |
|       — The value of an integer character constant containing more than one character or containing a
 | |
|         character or escape sequence that does not map to a single-byte execution character (<a href='#6.4.4.4'>6.4.4.4</a>).
 | |
| 
 | |
|       — The value of a wide character constant containing more than one multibyte character or a
 | |
|         single multibyte character that maps to multiple members of the extended execution character
 | |
|         set, or containing a multibyte character or escape sequence not represented in the extended
 | |
|         execution character set (<a href='#6.4.4.4'>6.4.4.4</a>).
 | |
| 
 | |
|       — The current locale used to convert a wide character constant consisting of a single multibyte
 | |
|         character that maps to a member of the extended execution character set into a corresponding
 | |
|         wide character code (<a href='#6.4.4.4'>6.4.4.4</a>).
 | |
| 
 | |
|       — The current locale used to convert a wide string literal into corresponding wide character
 | |
|         codes (<a href='#6.4.5'>6.4.5</a>).
 | |
| 
 | |
|       — The value of a string literal containing a multibyte character or escape sequence not represented
 | |
|         in the execution character set (<a href='#6.4.5'>6.4.5</a>).
 | |
| 
 | |
|       — The encoding of any of wchar_t, char16_t, and char32_t where the corresponding stan-
 | |
|         dard encoding macro (__STDC_ISO_10646__ , __STDC_UTF_16__ , or __STDC_UTF_32__ ) is not
 | |
|         defined (<a href='#6.10.9.2'>6.10.9.2</a>).
 | |
| </pre>
 | |
| <a name='J.3.5'></a>
 | |
| <hr>
 | |
| <h3>J.3.5 [Integers]</h3>
 | |
| <a name='J.3.5p1'></a>
 | |
| <pre>1     — Any extended integer types that exist in the implementation (<a href='#6.2.5'>6.2.5</a>).
 | |
| 
 | |
|       — The rank of any extended integer type relative to another extended integer type with the same
 | |
|         precision (<a href='#6.3.1.1'>6.3.1.1</a>).
 | |
| 
 | |
|       — The result of, or the signal raised by, converting an integer to a signed integer type when the
 | |
|         value cannot be represented in an object of that type (<a href='#6.3.1.3'>6.3.1.3</a>).
 | |
| 
 | |
|       — The results of some bitwise operations on signed integers (<a href='#6.5'>6.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.6'></a>
 | |
| <hr>
 | |
| <h3>J.3.6 [Floating-point]</h3>
 | |
| <a name='J.3.6p1'></a>
 | |
| <pre>1     — The accuracy of the floating-point operations and of the library functions in <math.h> and
 | |
|         <complex.h> that return floating-point results (<a href='#5.2.4.2.2'>5.2.4.2.2</a>).
 | |
| 
 | |
|       — The accuracy of the conversions between floating-point internal representations and string
 | |
|         representations performed by the library functions in <stdio.h>, <stdlib.h>, and <wchar.h>
 | |
|         (<a href='#5.2.4.2.2'>5.2.4.2.2</a>).
 | |
| 
 | |
|       — The rounding behaviors characterized by non-standard values of FLT_ROUNDS (<a href='#5.2.4.2.2'>5.2.4.2.2</a>).
 | |
| 
 | |
|       — The evaluation methods characterized by non-standard negative values of FLT_EVAL_METHOD
 | |
|         (<a href='#5.2.4.2.2'>5.2.4.2.2</a>).
 | |
| 
 | |
|       — The evaluation methods characterized by non-standard negative values of DEC_EVAL_METHOD
 | |
|         (<a href='#5.2.4.2.3'>5.2.4.2.3</a>).
 | |
| 
 | |
|       — If decimal floating types are supported (<a href='#6.2.5'>6.2.5</a>).
 | |
| 
 | |
|       — The direction of rounding when an integer is converted to a floating-point number that cannot
 | |
|         exactly represent the original value (<a href='#6.3.1.4'>6.3.1.4</a>).
 | |
| 
 | |
|       — The direction of rounding when a floating-point number is converted to a narrower floating-
 | |
|         point number (<a href='#6.3.1.5'>6.3.1.5</a>).
 | |
| 
 | |
|       — How the nearest representable value or the larger or smaller representable value immediately
 | |
|         adjacent to the nearest representable value is chosen for certain floating constants (<a href='#6.4.4.2'>6.4.4.2</a>).
 | |
| 
 | |
|       — Whether and how floating expressions are contracted when not disallowed by the
 | |
|         FP_CONTRACT pragma (<a href='#6.5'>6.5</a>).
 | |
| 
 | |
|       — The default state for the FENV_ACCESS pragma (<a href='#7.6.1'>7.6.1</a>).
 | |
| 
 | |
|       — Additional floating-point exceptions, rounding modes, environments, and classifications, and
 | |
|         their macro names (<a href='#7.6'>7.6</a>, <a href='#7.12'>7.12</a>).
 | |
| 
 | |
|       — The default state for the FP_CONTRACT pragma (<a href='#7.12.2'>7.12.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.7'></a>
 | |
| <hr>
 | |
| <h3>J.3.7 [Arrays and pointers]</h3>
 | |
| <a name='J.3.7p1'></a>
 | |
| <pre>1     — The result of converting a pointer to an integer or vice versa (<a href='#6.3.2.3'>6.3.2.3</a>).
 | |
| 
 | |
|       — The size of the result of subtracting two pointers to elements of the same array (<a href='#6.5.6'>6.5.6</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.8'></a>
 | |
| <hr>
 | |
| <h3>J.3.8 [Hints]</h3>
 | |
| <a name='J.3.8p1'></a>
 | |
| <pre>1     — The extent to which suggestions made by using the register storage-class specifier are
 | |
|         effective (<a href='#6.7.1'>6.7.1</a>).
 | |
| 
 | |
|       — The extent to which suggestions made by using the inline function specifier are effective
 | |
|         (<a href='#6.7.4'>6.7.4</a>).
 | |
| </pre>
 | |
| <a name='J.3.9'></a>
 | |
| <hr>
 | |
| <h3>J.3.9 [Structures, unions, enumerations, and bit-fields]</h3>
 | |
| <a name='J.3.9p1'></a>
 | |
| <pre>1     — Whether a "plain" int bit-field is treated as a signed int bit-field or as an unsigned int
 | |
|         bit-field (<a href='#6.7.2'>6.7.2</a>, <a href='#6.7.2.1'>6.7.2.1</a>).
 | |
|       — Allowable bit-field types other than bool, signed int, unsigned int, and bit-precise integer
 | |
|         types (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
|       — Whether atomic types are permitted for bit-fields (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
|       — Whether a bit-field can straddle a storage-unit boundary (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
|       — The order of allocation of bit-fields within a unit (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
|       — The alignment of non-bit-field members of structures (<a href='#6.7.2.1'>6.7.2.1</a>). This should present no problem
 | |
|         unless binary data written by one implementation is read by another.
 | |
|       — The integer type compatible with each enumerated type (<a href='#6.7.2.2'>6.7.2.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.10'></a>
 | |
| <hr>
 | |
| <h3>J.3.10 [Qualifiers]</h3>
 | |
| <a name='J.3.10p1'></a>
 | |
| <pre>1     — What constitutes an access to an object that has volatile-qualified type (<a href='#6.7.3'>6.7.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.11'></a>
 | |
| <hr>
 | |
| <h3>J.3.11 [Preprocessing directives]</h3>
 | |
| <a name='J.3.11p1'></a>
 | |
| <pre>1     — The locations within #pragma directives where header name preprocessing tokens are recog-
 | |
|         nized (<a href='#6.4'>6.4</a>, <a href='#6.4.7'>6.4.7</a>).
 | |
|       — How sequences in both forms of header names are mapped to headers or external source file
 | |
|         names (<a href='#6.4.7'>6.4.7</a>).
 | |
|       — Whether the value of a character constant in a constant expression that controls conditional
 | |
|         inclusion matches the value of the same character constant in the execution character set
 | |
|         (<a href='#6.10.1'>6.10.1</a>).
 | |
|       — Whether the value of a single-character character constant in a constant expression that controls
 | |
|         conditional inclusion may have a negative value (<a href='#6.10.1'>6.10.1</a>).
 | |
|       — The places that are searched for an included < > delimited header, and how the places are
 | |
|         specified or the header is identified (<a href='#6.10.2'>6.10.2</a>).
 | |
|       — How the named source file is searched for in an included " " delimited header (<a href='#6.10.2'>6.10.2</a>).
 | |
|       — The method by which preprocessing tokens (possibly resulting from macro expansion) in a
 | |
|         #include directive are combined into a header name (<a href='#6.10.2'>6.10.2</a>).
 | |
| 
 | |
|       — The nesting limit for #include processing (<a href='#6.10.2'>6.10.2</a>).
 | |
|       — Whether the # operator inserts a \ character before the \ character that begins a universal
 | |
|         character name in a character constant or string literal (<a href='#6.10.4.2'>6.10.4.2</a>).
 | |
|       — The behavior on each recognized non-STDC #pragma directive (<a href='#6.10.7'>6.10.7</a>).
 | |
|       — The definitions for __DATE__ and __TIME__ when respectively, the date and time of translation
 | |
|         are not available (<a href='#6.10.9.1'>6.10.9.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.12'></a>
 | |
| <hr>
 | |
| <h3>J.3.12 [Library functions]</h3>
 | |
| <a name='J.3.12p1'></a>
 | |
| <pre>1     — Any library facilities available to a freestanding program, other than the minimal set required
 | |
|         by Clause 4 (<a href='#5.1.2.1'>5.1.2.1</a>).
 | |
|       — The format of the diagnostic printed by the assert macro (<a href='#7.2.1.1'>7.2.1.1</a>).
 | |
|       — The representation of the floating-point status flags stored by the fegetexceptflag function
 | |
|         (<a href='#7.6.4.2'>7.6.4.2</a>).
 | |
| — Whether the feraiseexcept function raises the "inexact" floating-point exception in addition
 | |
|   to the "overflow" or "underflow" floating-point exception (<a href='#7.6.4.3'>7.6.4.3</a>).
 | |
| 
 | |
| — Strings other than "C" and "" that may be passed as the second argument to the setlocale
 | |
|   function (<a href='#7.11.1.1'>7.11.1.1</a>).
 | |
| 
 | |
| — The types defined for float_t and double_t when the value of the FLT_EVAL_METHOD macro
 | |
|   is less than 0 (<a href='#7.12'>7.12</a>).
 | |
| 
 | |
| — The types defined for _Decimal32_t and _Decimal64_t when the value of the
 | |
|   DEC_EVAL_METHOD macro is less than 0 (<a href='#7.12'>7.12</a>).
 | |
| 
 | |
| — Domain errors for the mathematics functions, other than those required by this document
 | |
|   (<a href='#7.12.1'>7.12.1</a>).
 | |
| 
 | |
| — The values returned by the mathematics functions on domain errors or pole errors (<a href='#7.12.1'>7.12.1</a>).
 | |
| 
 | |
| — The values returned by the mathematics functions on underflow range errors, whether errno
 | |
|   is set to the value of the macro ERANGE when the integer expression math_errhandling &
 | |
|   MATH_ERRNO is nonzero, and whether the "underflow" floating-point exception is raised when
 | |
|   the integer expression math_errhandling & MATH_ERREXCEPT is nonzero. (<a href='#7.12.1'>7.12.1</a>).
 | |
| 
 | |
| — Whether a domain error occurs or zero is returned when an fmod function has a second
 | |
|   argument of zero (<a href='#7.12.10.1'>7.12.10.1</a>).
 | |
| 
 | |
| — Whether a domain error occurs or zero is returned when a remainder function has a second
 | |
|   argument of zero (<a href='#7.12.10.2'>7.12.10.2</a>).
 | |
| 
 | |
| — The base-2 logarithm of the modulus used by the remquo functions in reducing the quotient
 | |
|   (<a href='#7.12.10.3'>7.12.10.3</a>).
 | |
| 
 | |
| — The byte order of decimal floating type encodings (<a href='#7.12.16'>7.12.16</a>).
 | |
| 
 | |
| — Whether a domain error occurs or zero is returned when a remquo function has a second
 | |
|   argument of zero (<a href='#7.12.10.3'>7.12.10.3</a>).
 | |
| 
 | |
| — Whether the equivalent of signal(sig, SIG_DFL); is executed prior to the call of a signal
 | |
|   handler, and, if not, the blocking of signals that is performed (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| 
 | |
| — The value of __STDC_ENDIAN_NATIVE__ if the execution environment is not big-endian or
 | |
|   little-endian (<a href='#7.18.2'>7.18.2</a>)
 | |
| 
 | |
| — The null pointer constant to which the macro NULL expands (<a href='#7.21'>7.21</a>).
 | |
| 
 | |
| — Whether the last line of a text stream requires a terminating new-line character (<a href='#7.23.2'>7.23.2</a>).
 | |
| 
 | |
| — Whether space characters that are written out to a text stream immediately before a new-line
 | |
|   character appear when read in (<a href='#7.23.2'>7.23.2</a>).
 | |
| 
 | |
| — The number of null characters that may be appended to data written to a binary stream (<a href='#7.23.2'>7.23.2</a>).
 | |
| 
 | |
| — Whether the file position indicator of an append-mode stream is initially positioned at the
 | |
|   beginning or end of the file (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| — Whether a write on a text stream causes the associated file to be truncated beyond that point
 | |
|   (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| — The characteristics of file buffering (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| — Whether a zero-length file actually exists (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| — The rules for composing valid file names (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| — Whether the same file can be simultaneously open multiple times (<a href='#7.23.3'>7.23.3</a>).
 | |
| — The nature and choice of encodings used for multibyte characters in files (<a href='#7.23.3'>7.23.3</a>).
 | |
| 
 | |
| — The effect of the remove function on an open file (<a href='#7.23.4.1'>7.23.4.1</a>).
 | |
| 
 | |
| — The effect if a file with the new name exists prior to a call to the rename function (<a href='#7.23.4.2'>7.23.4.2</a>).
 | |
| 
 | |
| — Whether an open temporary file is removed upon abnormal program termination (<a href='#7.23.4.3'>7.23.4.3</a>).
 | |
| 
 | |
| — Which changes of mode are permitted (if any), and under what circumstances (<a href='#7.23.5.4'>7.23.5.4</a>).
 | |
| 
 | |
| — The style used to print an infinity or NaN, and the meaning of any n-char or n-wchar sequence
 | |
|   printed for a NaN (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — The output for %p conversion in the fprintf or fwprintf function (<a href='#7.23.6.1'>7.23.6.1</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — The interpretation of a- character that is neither the first nor the last character, nor the second
 | |
|   where a ^ character is the first, in the scanlist for %[ conversion in the fscanf or fwscanf
 | |
|   function (<a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.1'>7.31.2.1</a>).
 | |
| 
 | |
| — The set of sequences matched by a %p conversion and the interpretation of the corresponding
 | |
|   input item in the fscanf or fwscanf function (<a href='#7.23.6.2'>7.23.6.2</a>, <a href='#7.31.2.2'>7.31.2.2</a>).
 | |
| 
 | |
| — The value to which the macro errno is set by the fgetpos, fsetpos, or ftell functions on
 | |
|   failure (<a href='#7.23.9.1'>7.23.9.1</a>, <a href='#7.23.9.3'>7.23.9.3</a>, <a href='#7.23.9.4'>7.23.9.4</a>).
 | |
| 
 | |
| — The meaning of any n-char or n-wchar sequence in a string representing a NaN that is
 | |
|   converted by the strtod, strtof, strtold, wcstod, wcstof, or wcstold function (<a href='#7.24.1.5'>7.24.1.5</a>,
 | |
|   and <a href='#7.31.4.1.2'>7.31.4.1.2</a>).
 | |
| 
 | |
| — Whether or not the strtod, strtof, strtold, wcstod, wcstof, or wcstold function sets
 | |
|   errno to ERANGE when underflow occurs (<a href='#7.24.1.5'>7.24.1.5</a>, <a href='#7.31.4.1.2'>7.31.4.1.2</a>).
 | |
| 
 | |
| — The meaning of any d-char or d-wchar sequence in a string representing a NaN that is con-
 | |
|   verted by the strtod32, strtod64, strtod128, wcstod32, wcstod64, or wcstod128 function
 | |
|   (<a href='#7.24.1.6'>7.24.1.6</a>, <a href='#7.31.4.1.3'>7.31.4.1.3</a>).
 | |
| 
 | |
| — Whether or not the strtod32, strtod64, strtod128, wcstod32, wcstod64, or wcstod128
 | |
|   function sets errno to ERANGE when underflow occurs (<a href='#7.24.1.6'>7.24.1.6</a>, <a href='#7.31.4.1.3'>7.31.4.1.3</a>).
 | |
| 
 | |
| — Whether the calloc, malloc, realloc, and aligned_alloc functions return a null pointer or
 | |
|   a pointer to an allocated object when the size requested is zero (<a href='#7.24.3'>7.24.3</a>).
 | |
| 
 | |
| — Whether open streams with unwritten buffered data are flushed, )open streams are closed, or
 | |
|   temporary files are removed when the abort or _Exit function is called (<a href='#7.24.4.1'>7.24.4.1</a>, <a href='#7.24.4.5'>7.24.4.5</a>).
 | |
| 
 | |
| — The termination status returned to the host environment by the abort, exit, _Exit , or
 | |
|   quick_exit function (<a href='#7.24.4.1'>7.24.4.1</a>, <a href='#7.24.4.4'>7.24.4.4</a>, <a href='#7.24.4.5'>7.24.4.5</a>, <a href='#7.24.4.7'>7.24.4.7</a>).
 | |
| 
 | |
| — The value returned by the system function when its argument is not a null pointer (<a href='#7.24.4.8'>7.24.4.8</a>).
 | |
| 
 | |
| — Whether the internal state of multibyte/wide character conversion functions has thread-storage
 | |
|   duration, and its initial value in newly created threads (<a href='#7.24.7'>7.24.7</a>).
 | |
| 
 | |
| — The range and precision of times representable in clock_t and time_t (<a href='#7.29'>7.29</a>).
 | |
| 
 | |
| — The local time zone and Daylight Saving Time (<a href='#7.29.1'>7.29.1</a>).
 | |
| 
 | |
| — Whether TIME_MONOTONIC or TIME_ACTIVE are supported time bases (<a href='#7.29.1'>7.29.1</a>).
 | |
| 
 | |
| — Whether TIME_THREAD_ACTIVE is a supported time bases (<a href='#7.29.1'>7.29.1</a>, <a href='#7.28.1'>7.28.1</a>).
 | |
| 
 | |
| — The local time zone and Daylight Saving Time (<a href='#7.29.1'>7.29.1</a>).
 | |
| 
 | |
| — The era for the clock function (<a href='#7.29.2.1'>7.29.2.1</a>).
 | |
|       — The TIME_UTC epoch (<a href='#7.29.2.6'>7.29.2.6</a>).
 | |
|       — The replacement string for the %Z specifier to the strftime, and wcsftime functions in the
 | |
|         "C" locale (<a href='#7.29.3.5'>7.29.3.5</a>, <a href='#7.31.5.1'>7.31.5.1</a>).
 | |
| 
 | |
|       — Whether internal mbstate_t objects have thread storage duration (<a href='#7.30.1'>7.30.1</a>, <a href='#7.31.6.3'>7.31.6.3</a>, <a href='#7.31.6.4'>7.31.6.4</a>).
 | |
|       — Whether the functions in <math.h> honor the rounding direction mode in an IEC 60559
 | |
|         conformant implementation, unless explicitly specified otherwise (<a href='#F.10'>F.10</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.3.13'></a>
 | |
| <hr>
 | |
| <h3>J.3.13 [Architecture]</h3>
 | |
| <a name='J.3.13p1'></a>
 | |
| <pre>1     — The values or expressions assigned to the macros specified in the headers <float.h>,
 | |
|         <limits.h>, and <stdint.h> (<a href='#5.2.4.2'>5.2.4.2</a>, <a href='#7.22'>7.22</a>).
 | |
| 
 | |
|       — The result of attempting to indirectly access an object with automatic or thread storage duration
 | |
|         from a thread other than the one with which it is associated (<a href='#6.2.4'>6.2.4</a>).
 | |
|       — The number, order, and encoding of bytes in any object (when not explicitly specified in this
 | |
|         document) (<a href='#6.2.6.1'>6.2.6.1</a>).
 | |
|       — Whether any extended alignments are supported and the contexts in which they are supported
 | |
|         (<a href='#6.2.8'>6.2.8</a>).
 | |
|       — Valid alignment values other than those returned by an alignof expression for fundamental
 | |
|         types, if any (<a href='#6.2.8'>6.2.8</a>).
 | |
|       — The value of the result of the sizeof and alignof operators (<a href='#6.5.3.4'>6.5.3.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.4'></a>
 | |
| <hr>
 | |
| <h3>J.4 [Locale-specific behavior]</h3>
 | |
| <a name='J.4p1'></a>
 | |
| <pre>1   The following characteristics of a hosted environment are locale-specific and are required to be
 | |
|     documented by the implementation:
 | |
| 
 | |
|       — Additional members of the source and execution character sets beyond the basic character set
 | |
|         (<a href='#5.2.1'>5.2.1</a>).
 | |
|       — The presence, meaning, and representation of additional multibyte characters in the execution
 | |
|         character set beyond the basic character set (<a href='#5.2.1.1'>5.2.1.1</a>).
 | |
|       — The shift states used for the encoding of multibyte characters (<a href='#5.2.1.1'>5.2.1.1</a>).
 | |
|       — The direction of writing of successive printing characters (<a href='#5.2.2'>5.2.2</a>).
 | |
|       — The decimal-point character (<a href='#7.1.1'>7.1.1</a>).
 | |
|       — The set of printing characters (<a href='#7.4'>7.4</a>, <a href='#7.32.2'>7.32.2</a>).
 | |
|       — The set of control characters (<a href='#7.4'>7.4</a>, <a href='#7.32.2'>7.32.2</a>).
 | |
|       — The sets of characters tested for by the isalpha, isblank, islower, ispunct, isspace,
 | |
|         isupper, iswalpha, iswblank, iswlower, iswpunct, iswspace, or iswupper functions
 | |
|         (<a href='#7.4.1.2'>7.4.1.2</a>, <a href='#7.4.1.3'>7.4.1.3</a>, <a href='#7.4.1.7'>7.4.1.7</a>, <a href='#7.4.1.9'>7.4.1.9</a>, <a href='#7.4.1.10'>7.4.1.10</a>, <a href='#7.4.1.11'>7.4.1.11</a>, <a href='#7.32.2.1.2'>7.32.2.1.2</a>, <a href='#7.32.2.1.3'>7.32.2.1.3</a>, <a href='#7.32.2.1.7'>7.32.2.1.7</a>, <a href='#7.32.2.1.9'>7.32.2.1.9</a>,
 | |
|         <a href='#7.32.2.1.10'>7.32.2.1.10</a>, <a href='#7.32.2.1.11'>7.32.2.1.11</a>).
 | |
|       — The native environment (<a href='#7.11.1.1'>7.11.1.1</a>).
 | |
|       — Additional subject sequences accepted by the numeric conversion functions (<a href='#7.24.1'>7.24.1</a>, <a href='#7.31.4.1'>7.31.4.1</a>).
 | |
|       — The collation sequence of the execution character set (<a href='#7.26.4.3'>7.26.4.3</a>, <a href='#7.31.4.4.2'>7.31.4.4.2</a>).
 | |
|       — The contents of the error message strings set up by the strerror function (<a href='#7.26.6.3'>7.26.6.3</a>).
 | |
|       — The formats for time and date (<a href='#7.29.3.5'>7.29.3.5</a>, <a href='#7.31.5.1'>7.31.5.1</a>).
 | |
|       — Character mappings that are supported by the towctrans function (<a href='#7.32.1'>7.32.1</a>).
 | |
|       — Character classifications that are supported by the iswctype function (<a href='#7.32.1'>7.32.1</a>).
 | |
| </pre>
 | |
| <a name='J.5'></a>
 | |
| <hr>
 | |
| <h3>J.5 [Common extensions]</h3>
 | |
| <a name='J.5p1'></a>
 | |
| <pre>1   The following extensions are widely used in many systems, but are not portable to all implemen-
 | |
|     tations. The inclusion of any extension that may cause a strictly conforming program to become
 | |
|     invalid renders an implementation nonconforming. Examples of such extensions are new keywords,
 | |
|     extra library functions declared in standard headers, or predefined macros with names that do not
 | |
|     begin with an underscore.
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.1'></a>
 | |
| <hr>
 | |
| <h3>J.5.1 [Environment arguments]</h3>
 | |
| <a name='J.5.1p1'></a>
 | |
| <pre>1   In a hosted environment, the main function receives a third argument, char *envp[], that points to
 | |
|     a null-terminated array of pointers to char, each of which points to a string that provides information
 | |
|     about the environment for this execution of the program (<a href='#5.1.2.2.1'>5.1.2.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.2'></a>
 | |
| <hr>
 | |
| <h3>J.5.2 [Specialized identifiers]</h3>
 | |
| <a name='J.5.2p1'></a>
 | |
| <pre>1   Characters other than the underscore _ , letters, and digits, that are not part of the basic source
 | |
|     character set (such as the dollar sign $, or characters in national character sets) may appear in an
 | |
|     identifier (<a href='#6.4.2'>6.4.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.3'></a>
 | |
| <hr>
 | |
| <h3>J.5.3 [Lengths and cases of identifiers]</h3>
 | |
| <a name='J.5.3p1'></a>
 | |
| <pre>1   All characters in identifiers (with or without external linkage) are significant (<a href='#6.4.2'>6.4.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.4'></a>
 | |
| <hr>
 | |
| <h3>J.5.4 [Scopes of identifiers]</h3>
 | |
| <a name='J.5.4p1'></a>
 | |
| <pre>1   A function identifier, or the identifier of an object the declaration of which contains the keyword
 | |
|     extern, has file scope (<a href='#6.2.1'>6.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.5'></a>
 | |
| <hr>
 | |
| <h3>J.5.5 [Writable string literals]</h3>
 | |
| <a name='J.5.5p1'></a>
 | |
| <pre>1   String literals are modifiable (in which case, identical string literals should denote distinct objects)
 | |
|     (<a href='#6.4.5'>6.4.5</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.6'></a>
 | |
| <hr>
 | |
| <h3>J.5.6 [Other arithmetic types]</h3>
 | |
| <a name='J.5.6p1'></a>
 | |
| <pre>1   Additional arithmetic types, such as __int128 or double double, and their appropriate conver-
 | |
|     sions are defined (<a href='#6.2.5'>6.2.5</a>, <a href='#6.3.1'>6.3.1</a>). Additional floating types may have more range or precision than
 | |
|     long double, may be used for evaluating expressions of other floating types, and may be used to
 | |
|     define float_t or double_t. Additional floating types may also have less range or precision than
 | |
|     float.
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.7'></a>
 | |
| <hr>
 | |
| <h3>J.5.7 [Function pointer casts]</h3>
 | |
| <a name='J.5.7p1'></a>
 | |
| <pre>1   A pointer to an object or to void may be cast to a pointer to a function, allowing data to be invoked
 | |
|     as a function (<a href='#6.5.4'>6.5.4</a>).
 | |
| </pre>
 | |
| <a name='J.5.7p2'></a>
 | |
| <pre>2   A pointer to a function may be cast to a pointer to an object or to void, allowing a function to be
 | |
|     inspected or modified (for example, by a debugger) (<a href='#6.5.4'>6.5.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.8'></a>
 | |
| <hr>
 | |
| <h3>J.5.8 [Extended bit-field types]</h3>
 | |
| <a name='J.5.8p1'></a>
 | |
| <pre>1   A bit-field may be declared with a type other than bool, unsigned int, signed int, or a bit-precise
 | |
|     integer type, with an appropriate maximum width (<a href='#6.7.2.1'>6.7.2.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.9'></a>
 | |
| <hr>
 | |
| <h3>J.5.9 [The fortran keyword]</h3>
 | |
| <a name='J.5.9p1'></a>
 | |
| <pre>1   The fortran function specifier may be used in a function declaration to indicate that calls suitable
 | |
|     for FORTRAN should be generated, or that a different representation for the external name is to be
 | |
|     generated (<a href='#6.7.4'>6.7.4</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.10'></a>
 | |
| <hr>
 | |
| <h3>J.5.10 [The asm keyword]</h3>
 | |
| <a name='J.5.10p1'></a>
 | |
| <pre>1   The asm keyword may be used to insert assembly language directly into the translator output (<a href='#6.8'>6.8</a>).
 | |
|     The most common implementation is via a statement of the form:
 | |
| 
 | |
|              asm (character-string-literal);
 | |
| </pre>
 | |
| <a name='J.5.11'></a>
 | |
| <hr>
 | |
| <h3>J.5.11 [Multiple external definitions]</h3>
 | |
| <a name='J.5.11p1'></a>
 | |
| <pre>1   There may be more than one external definition for the identifier of an object, with or without the
 | |
|     explicit use of the keyword extern; if the definitions disagree, or more than one is initialized, the
 | |
|     behavior is undefined (<a href='#6.9.2'>6.9.2</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.12'></a>
 | |
| <hr>
 | |
| <h3>J.5.12 [Predefined macro names]</h3>
 | |
| <a name='J.5.12p1'></a>
 | |
| <pre>1   Macro names that do not begin with an underscore, describing the translation and execution
 | |
|     environments, are defined by the implementation before translation begins (<a href='#6.10.9'>6.10.9</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.13'></a>
 | |
| <hr>
 | |
| <h3>J.5.13 [Floating-point status flags]</h3>
 | |
| <a name='J.5.13p1'></a>
 | |
| <pre>1   If any floating-point status flags are set on normal termination after all calls to functions registered
 | |
|     by the atexit function have been made (see <a href='#7.24.4.4'>7.24.4.4</a>), the implementation writes some diagnostics
 | |
|     indicating the fact to the stderr stream, if it is still open,
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.14'></a>
 | |
| <hr>
 | |
| <h3>J.5.14 [Extra arguments for signal handlers]</h3>
 | |
| <a name='J.5.14p1'></a>
 | |
| <pre>1   Handlers for specific signals are called with extra arguments in addition to the signal number
 | |
|     (<a href='#7.14.1.1'>7.14.1.1</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.15'></a>
 | |
| <hr>
 | |
| <h3>J.5.15 [Additional stream types and file-opening modes]</h3>
 | |
| <a name='J.5.15p1'></a>
 | |
| <pre>1   Additional mappings from files to streams are supported (<a href='#7.23.2'>7.23.2</a>).
 | |
| </pre>
 | |
| <a name='J.5.15p2'></a>
 | |
| <pre>2   Additional file-opening modes may be specified by characters appended to the mode argument of
 | |
|     the fopen function (<a href='#7.23.5.3'>7.23.5.3</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.16'></a>
 | |
| <hr>
 | |
| <h3>J.5.16 [Defined file position indicator]</h3>
 | |
| <a name='J.5.16p1'></a>
 | |
| <pre>1   The file position indicator is decremented by each successful call to the ungetc or ungetwc function
 | |
|     for a text stream, except if its value was zero before a call (<a href='#7.23.7.10'>7.23.7.10</a>, <a href='#7.31.3.10'>7.31.3.10</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.5.17'></a>
 | |
| <hr>
 | |
| <h3>J.5.17 [Math error reporting]</h3>
 | |
| <a name='J.5.17p1'></a>
 | |
| <pre>1   Functions declared in <complex.h> and <math.h> raise SIGFPE to report errors instead of, or in
 | |
|     addition to, setting errno or raising floating-point exceptions (<a href='#7.3'>7.3</a>, <a href='#7.12'>7.12</a>).
 | |
| 
 | |
| </pre>
 | |
| <a name='J.6'></a>
 | |
| <hr>
 | |
| <h3>J.6 [Reserved identifiers and keywords]</h3>
 | |
| <a name='J.6p1'></a>
 | |
| <pre>1   A lot of identifier preprocessing tokens are used for specific purposes in regular clauses or appendices
 | |
|     from translation phase 3 onwards. Using any of these for a purpose different from their description
 | |
|     in this document, even if the use is in a context where they are normatively permitted, may have an
 | |
|     impact on the portability of code and should thus be avoided.
 | |
| 
 | |
| </pre>
 | |
| <a name='J.6.1'></a>
 | |
| <hr>
 | |
| <h3>J.6.1 [Rule based identifiers]</h3>
 | |
| <a name='J.6.1p1'></a>
 | |
| <pre>1   The following 40 regular expressions characterize identifiers that are systematically reserved by
 | |
|     some clause this document.
 | |
| 
 | |
|     ATOMIC_[A-Z][a-zA-Z0-9_]*                            LC_[A-Z][a-zA-Z0-9_]*
 | |
|     DBL_[A-Z][a-zA-Z0-9_]*                               LDBL_[A-Z][a-zA-Z0-9_]*
 | |
|     DEC128_[A-Z][a-zA-Z0-9_]*                            MATH_[A-Z][a-zA-Z0-9_]*
 | |
|     DEC32_[A-Z][a-zA-Z0-9_]*                             PRI[a-zX][a-zA-Z0-9_]*
 | |
|     DEC64_[A-Z][a-zA-Z0-9_]*                             SCN[a-zX][a-zA-Z0-9_]*
 | |
|     DEC_[A-Z][a-zA-Z0-9_]*                               SIG[A-Z][a-zA-Z0-9_]*
 | |
|     E[0-9A-Z][a-zA-Z0-9_]*                               SIG_[A-Z][a-zA-Z0-9_]*
 | |
|     FE_[A-Z][a-zA-Z0-9_]*                                TIME_[A-Z][a-zA-Z0-9_]*
 | |
|     FLT_[A-Z][a-zA-Z0-9_]*                               UINT[a-zA-Z0-9_]*_C
 | |
|     FP_[A-Z][a-zA-Z0-9_]*                                UINT[a-zA-Z0-9_]*_MAX
 | |
|     INT[a-zA-Z0-9_]*_C                                   UINT[a-zA-Z0-9_]*_WIDTH
 | |
|     INT[a-zA-Z0-9_]*_MAX                                 _[a-zA-Z_][a-zA-Z0-9_]*
 | |
|     INT[a-zA-Z0-9_]*_MIN                                 atomic_[a-z][a-zA-Z0-9_]*
 | |
|     INT[a-zA-Z0-9_]*_WIDTH                               cnd_[a-z][a-zA-Z0-9_]*
 | |
|     cr_[a-z][a-zA-Z0-9_]*                          str[a-z][a-zA-Z0-9_]*
 | |
|     int[a-zA-Z0-9_]*_t                             thrd_[a-z][a-zA-Z0-9_]*
 | |
|     is[a-z][a-zA-Z0-9_]*                           to[a-z][a-zA-Z0-9_]*
 | |
|     mem[a-z][a-zA-Z0-9_]*                          tss_[a-z][a-zA-Z0-9_]*
 | |
|     mtx_[a-z][a-zA-Z0-9_]*                         uint[a-zA-Z0-9_]*_t
 | |
|     stdc_[a-zA-Z0-9_]*                             wcs[a-z][a-zA-Z0-9_]*
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='J.6.1p2'></a>
 | |
| <pre>2   The following 794 identifiers or keywords match these patterns and have particular semantics
 | |
|     provided by this document.
 | |
| 
 | |
|     atomic_bool                                    atomic_is_lock_free
 | |
|     ATOMIC_BOOL_LOCK_FREE                          atomic_llong
 | |
|     atomic_char                                    ATOMIC_LLONG_LOCK_FREE
 | |
|     atomic_char16_t                                atomic_load
 | |
|     ATOMIC_CHAR16_T_LOCK_FREE                      atomic_load_explicit
 | |
|     atomic_char32_t                                atomic_long
 | |
|     ATOMIC_CHAR32_T_LOCK_FREE                      ATOMIC_LONG_LOCK_FREE
 | |
|     atomic_char8_t                                 ATOMIC_POINTER_LOCK_FREE
 | |
|     ATOMIC_CHAR8_T_LOCK_FREE                       atomic_ptrdiff_t
 | |
|     ATOMIC_CHAR_LOCK_FREE                          atomic_schar
 | |
|     atomic_compare_exchange_strong                 atomic_short
 | |
|     atomic_compare_exchange_strong_explicit        ATOMIC_SHORT_LOCK_FREE
 | |
|     atomic_compare_exchange_weak                   atomic_signal_fence
 | |
|     atomic_compare_exchange_weak_explicit          atomic_size_t
 | |
|     atomic_exchange                                atomic_store
 | |
|     atomic_exchange_explicit                       atomic_store_explicit
 | |
|     atomic_fetch_                                  atomic_thread_fence
 | |
|     atomic_fetch_add                               atomic_uchar
 | |
|     atomic_fetch_add_explicit                      atomic_uint
 | |
|     atomic_fetch_and                               atomic_uintmax_t
 | |
|     atomic_fetch_and_explicit                      atomic_uintptr_t
 | |
|     atomic_fetch_or                                atomic_uint_fast16_t
 | |
|     atomic_fetch_or_explicit                       atomic_uint_fast32_t
 | |
|     atomic_fetch_sub                               atomic_uint_fast64_t
 | |
|     atomic_fetch_sub_explicit                      atomic_uint_fast8_t
 | |
|     atomic_fetch_xor                               atomic_uint_least16_t
 | |
|     atomic_fetch_xor_explicit                      atomic_uint_least32_t
 | |
|     atomic_flag                                    atomic_uint_least64_t
 | |
|     atomic_flag_clear                              atomic_uint_least8_t
 | |
|     atomic_flag_clear_explicit                     atomic_ullong
 | |
|     ATOMIC_FLAG_INIT                               atomic_ulong
 | |
|     atomic_flag_test_and_set                       atomic_ushort
 | |
|     atomic_flag_test_and_set_explicit              ATOMIC_VAR_INIT
 | |
|     atomic_init                                    atomic_wchar_t
 | |
|     atomic_int                                     ATOMIC_WCHAR_T_LOCK_FREE
 | |
|     atomic_intmax_t                                cnd_broadcast
 | |
|     atomic_intptr_t                                cnd_destroy
 | |
|     atomic_int_fast16_t                            cnd_init
 | |
|     atomic_int_fast32_t                            cnd_signal
 | |
|     atomic_int_fast64_t                            cnd_t
 | |
|     atomic_int_fast8_t                             cnd_timedwait
 | |
|     atomic_int_least16_t                           cnd_wait
 | |
|     atomic_int_least32_t                           DBL_DECIMAL_DIG
 | |
|     atomic_int_least64_t                           DBL_DIG
 | |
|     atomic_int_least8_t                            DBL_EPSILON
 | |
|     ATOMIC_INT_LOCK_FREE                           DBL_HAS_SUBNORM
 | |
| DBL_IS_IEC_60559           FE_DYNAMIC
 | |
| DBL_MANT_DIG               FE_INEXACT
 | |
| DBL_MAX                    FE_INVALID
 | |
| DBL_MAX_10_EXP             FE_OVERFLOW
 | |
| DBL_MAX_EXP                FE_SNANS_ALWAYS_SIGNAL
 | |
| DBL_MIN                    FE_TONEAREST
 | |
| DBL_MIN_10_EXP             FE_TONEARESTFROMZERO
 | |
| DBL_MIN_EXP                FE_TOWARDZERO
 | |
| DBL_NORM_MAX               FE_UNDERFLOW
 | |
| DBL_SNAN                   FE_UPWARD
 | |
| DBL_TRUE_MIN               FLT_DECIMAL_DIG
 | |
| DEC128_EPSILON             FLT_DIG
 | |
| DEC128_MANT_DIG            FLT_EPSILON
 | |
| DEC128_MAX                 FLT_EVAL_METHOD
 | |
| DEC128_MAX_EXP             FLT_HAS_SUBNORM
 | |
| DEC128_MIN                 FLT_IS_IEC_60559
 | |
| DEC128_MIN_EXP             FLT_MANT_DIG
 | |
| DEC128_SNAN                FLT_MAX
 | |
| DEC128_TRUE_MIN            FLT_MAX_10_EXP
 | |
| DEC32_EPSILON              FLT_MAX_EXP
 | |
| DEC32_MANT_DIG             FLT_MIN
 | |
| DEC32_MAX                  FLT_MIN_10_EXP
 | |
| DEC32_MAX_EXP              FLT_MIN_EXP
 | |
| DEC32_MIN                  FLT_NORM_MAX
 | |
| DEC32_MIN_EXP              FLT_RADIX
 | |
| DEC32_SNAN                 FLT_ROUNDS
 | |
| DEC32_TRUE_MIN             FLT_SNAN
 | |
| DEC64_EPSILON              FLT_TRUE_MIN
 | |
| DEC64_MANT_DIG             FP_CONTRACT
 | |
| DEC64_MAX                  FP_FAST_D
 | |
| DEC64_MAX_EXP              FP_FAST_D32ADDD128
 | |
| DEC64_MIN                  FP_FAST_D32ADDD64
 | |
| DEC64_MIN_EXP              FP_FAST_D32DIVD128
 | |
| DEC64_SNAN                 FP_FAST_D32DIVD64
 | |
| DEC64_TRUE_MIN             FP_FAST_D32FMAD128
 | |
| DEC_EVAL_METHOD            FP_FAST_D32FMAD64
 | |
| DEC_INFINITY               FP_FAST_D32MULD128
 | |
| DEC_NAN                    FP_FAST_D32MULD64
 | |
| EDOM                       FP_FAST_D32SQRTD128
 | |
| EILSEQ                     FP_FAST_D32SQRTD64
 | |
| EOF                        FP_FAST_D32SUBD128
 | |
| EOL                        FP_FAST_D32SUBD64
 | |
| ERANGE                     FP_FAST_D64ADDD128
 | |
| EXIT_FAILURE               FP_FAST_D64DIVD128
 | |
| EXIT_SUCCESS               FP_FAST_D64FMAD128
 | |
| FE_ALL_EXCEPT              FP_FAST_D64MULD128
 | |
| FE_DEC_DOWNWARD            FP_FAST_D64SQRTD128
 | |
| FE_DEC_DYNAMIC             FP_FAST_D64SUBD128
 | |
| FE_DEC_TONEAREST           FP_FAST_DADDL
 | |
| FE_DEC_TONEARESTFROMZERO   FP_FAST_DDIVL
 | |
| FE_DEC_TOWARDZERO          FP_FAST_DFMAL
 | |
| FE_DEC_UPWARD              FP_FAST_DMULL
 | |
| FE_DFL_ENV                 FP_FAST_DSQRTL
 | |
| FE_DFL_MODE                FP_FAST_DSUBL
 | |
| FE_DIVBYZERO               FP_FAST_F
 | |
| FE_DOWNWARD                FP_FAST_FADD
 | |
| FP_FAST_FADDL              INTMAX_WIDTH
 | |
| FP_FAST_FDIV               INTPTR_MAX
 | |
| FP_FAST_FDIVL              INTPTR_MIN
 | |
| FP_FAST_FFMA               intptr_t
 | |
| FP_FAST_FFMAL              INTPTR_WIDTH
 | |
| FP_FAST_FMA                int_fast16_t
 | |
| FP_FAST_FMAD               int_fast32_t
 | |
| FP_FAST_FMAD128            int_fast64_t
 | |
| FP_FAST_FMAD32             int_fast8_t
 | |
| FP_FAST_FMAD64             int_least16_t
 | |
| FP_FAST_FMAF               int_least32_t
 | |
| FP_FAST_FMAL               int_least64_t
 | |
| FP_FAST_FMUL               int_least8_t
 | |
| FP_FAST_FMULL              INT_MAX
 | |
| FP_FAST_FSQRT              INT_MIN
 | |
| FP_FAST_FSQRTL             INT_WIDTH
 | |
| FP_FAST_FSUB               isalnum
 | |
| FP_FAST_FSUBL              isalpha
 | |
| FP_ILOGB0                  isblank
 | |
| FP_ILOGBNAN                iscanonical
 | |
| FP_INFINITE                iscntrl
 | |
| FP_INT_DOWNWARD            isdigit
 | |
| FP_INT_TONEAREST           iseqsig
 | |
| FP_INT_TONEARESTFROMZERO   isfinite
 | |
| FP_INT_TOWARDZERO          isgraph
 | |
| FP_INT_UPWARD              isgreater
 | |
| FP_LLOGB0                  isgreaterequal
 | |
| FP_LLOGBNAN                isinf
 | |
| FP_NAN                     isless
 | |
| FP_NORMAL                  islessequal
 | |
| FP_SUBNORMAL               islessgreater
 | |
| FP_ZERO                    islower
 | |
| INT16_C                    isnan
 | |
| INT16_MAX                  isnormal
 | |
| INT16_MIN                  isprint
 | |
| int16_t                    ispunct
 | |
| INT16_WIDTH                issignaling
 | |
| INT32_C                    isspace
 | |
| INT32_MAX                  issubnormal
 | |
| INT32_MIN                  isunordered
 | |
| int32_t                    isupper
 | |
| INT32_WIDTH                iswalnum
 | |
| INT64_C                    iswalpha
 | |
| INT64_MAX                  iswblank
 | |
| INT64_MIN                  iswcntrl
 | |
| int64_t                    iswctype
 | |
| INT64_WIDTH                iswdigit
 | |
| INT8_C                     iswgraph
 | |
| INT8_MAX                   iswlower
 | |
| INT8_MIN                   iswprint
 | |
| int8_t                     iswpunct
 | |
| INT8_WIDTH                 iswspace
 | |
| INTMAX_C                   iswupper
 | |
| INTMAX_MAX                 iswxdigit
 | |
| INTMAX_MIN                 isxdigit
 | |
| intmax_t                   iszero
 | |
| LC_ALL                 PRIdLEAST64
 | |
| LC_COLLATE             PRIdMAX
 | |
| LC_CTYPE               PRIdPTR
 | |
| LC_MONETARY            PRIi32
 | |
| LC_NUMERIC             PRIi64
 | |
| LC_TIME                PRIiFAST32
 | |
| LDBL_DECIMAL_DIG       PRIiFAST64
 | |
| LDBL_DIG               PRIiLEAST32
 | |
| LDBL_EPSILON           PRIiLEAST64
 | |
| LDBL_HAS_SUBNORM       PRIiMAX
 | |
| LDBL_IS_IEC_60559      PRIiPTR
 | |
| LDBL_MANT_DIG          PRIo32
 | |
| LDBL_MAX               PRIo64
 | |
| LDBL_MAX_10_EXP        PRIoFAST32
 | |
| LDBL_MAX_EXP           PRIoFAST64
 | |
| LDBL_MIN               PRIoLEAST32
 | |
| LDBL_MIN_10_EXP        PRIoLEAST64
 | |
| LDBL_MIN_EXP           PRIoMAX
 | |
| LDBL_NORM_MAX          PRIoPTR
 | |
| LDBL_SNAN              PRIu32
 | |
| LDBL_TRUE_MIN          PRIu64
 | |
| MATH_ERREXCEPT         PRIuFAST32
 | |
| MATH_ERRNO             PRIuFAST64
 | |
| memalignment           PRIuLEAST32
 | |
| memccpy                PRIuLEAST64
 | |
| memchr                 PRIuMAX
 | |
| memcmp                 PRIuPTR
 | |
| memcpy                 PRIX32
 | |
| memcpy_s               PRIX64
 | |
| memmove                PRIXFAST32
 | |
| memmove_s              PRIXFAST64
 | |
| memory_order           PRIXLEAST32
 | |
| memory_order_acquire   PRIXLEAST64
 | |
| memory_order_acq_rel   PRIXMAX
 | |
| memory_order_consume   PRIXPTR
 | |
| memory_order_relaxed   SCNdMAX
 | |
| memory_order_release   SCNdPTR
 | |
| memory_order_seq_cst   SCNiMAX
 | |
| memset                 SCNiPTR
 | |
| memset_explicit        SCNoMAX
 | |
| memset_s               SCNoPTR
 | |
| mtx_destroy            SCNuMAX
 | |
| mtx_init               SCNuPTR
 | |
| mtx_lock               SCNxMAX
 | |
| mtx_plain              SCNxPTR
 | |
| mtx_recursive          SIGABRT
 | |
| mtx_t                  SIGFPE
 | |
| mtx_timed              SIGILL
 | |
| mtx_timedlock          SIGINT
 | |
| mtx_trylock            SIGSEGV
 | |
| mtx_unlock             SIGTERM
 | |
| PRId32                 SIG_ATOMIC_MAX
 | |
| PRId64                 SIG_ATOMIC_MIN
 | |
| PRIdFAST32             SIG_ATOMIC_WIDTH
 | |
| PRIdFAST64             SIG_DFL
 | |
| PRIdLEAST32            SIG_ERR
 | |
| SIG_IGN                       stdc_has_single_bituc
 | |
| stdc_bit_ceil                 stdc_has_single_bitui
 | |
| stdc_bit_ceiluc               stdc_has_single_bitul
 | |
| stdc_bit_ceilui               stdc_has_single_bitull
 | |
| stdc_bit_ceilul               stdc_has_single_bitus
 | |
| stdc_bit_ceilull              stdc_leading_ones
 | |
| stdc_bit_ceilus               stdc_leading_onesuc
 | |
| stdc_bit_floor                stdc_leading_onesui
 | |
| stdc_bit_flooruc              stdc_leading_onesul
 | |
| stdc_bit_floorui              stdc_leading_onesull
 | |
| stdc_bit_floorul              stdc_leading_onesus
 | |
| stdc_bit_floorull             stdc_leading_zeros
 | |
| stdc_bit_floorus              stdc_leading_zerosuc
 | |
| stdc_bit_width                stdc_leading_zerosui
 | |
| stdc_bit_widthuc              stdc_leading_zerosul
 | |
| stdc_bit_widthui              stdc_leading_zerosull
 | |
| stdc_bit_widthul              stdc_leading_zerosus
 | |
| stdc_bit_widthull             stdc_trailing_ones
 | |
| stdc_bit_widthus              stdc_trailing_onesuc
 | |
| stdc_count_ones               stdc_trailing_onesui
 | |
| stdc_count_onesuc             stdc_trailing_onesul
 | |
| stdc_count_onesui             stdc_trailing_onesull
 | |
| stdc_count_onesul             stdc_trailing_onesus
 | |
| stdc_count_onesull            stdc_trailing_zeros
 | |
| stdc_count_onesus             stdc_trailing_zerosuc
 | |
| stdc_count_zeros              stdc_trailing_zerosui
 | |
| stdc_count_zerosuc            stdc_trailing_zerosul
 | |
| stdc_count_zerosui            stdc_trailing_zerosull
 | |
| stdc_count_zerosul            stdc_trailing_zerosus
 | |
| stdc_count_zerosull           strcat
 | |
| stdc_count_zerosus            strcat_s
 | |
| stdc_first_leading_one        strchr
 | |
| stdc_first_leading_oneuc      strcmp
 | |
| stdc_first_leading_oneui      strcoll
 | |
| stdc_first_leading_oneul      strcpy
 | |
| stdc_first_leading_oneull     strcpy_s
 | |
| stdc_first_leading_oneus      strcspn
 | |
| stdc_first_leading_zero       strdup
 | |
| stdc_first_leading_zerouc     strerror
 | |
| stdc_first_leading_zeroui     strerrorlen_s
 | |
| stdc_first_leading_zeroul     strerror_s
 | |
| stdc_first_leading_zeroull    strfromd
 | |
| stdc_first_leading_zerous     strfromd128
 | |
| stdc_first_trailing_one       strfromd32
 | |
| stdc_first_trailing_oneuc     strfromd64
 | |
| stdc_first_trailing_oneui     strfromencbind
 | |
| stdc_first_trailing_oneul     strfromencdecd
 | |
| stdc_first_trailing_oneull    strfromencf
 | |
| stdc_first_trailing_oneus     strfromencf128
 | |
| stdc_first_trailing_zero      strfromf
 | |
| stdc_first_trailing_zerouc    strfroml
 | |
| stdc_first_trailing_zeroui    strftime
 | |
| stdc_first_trailing_zeroul    strlen
 | |
| stdc_first_trailing_zeroull   strncat
 | |
| stdc_first_trailing_zerous    strncat_s
 | |
| stdc_has_single_bit           strncmp
 | |
| strncpy              totalordermagd
 | |
| strncpy_s            totalordermagd128
 | |
| strndup              totalordermagd32
 | |
| strnlen_s            totalordermagd64
 | |
| strpbrk              totalordermagf
 | |
| strrchr              totalordermagl
 | |
| strspn               toupper
 | |
| strstr               towctrans
 | |
| strto                towlower
 | |
| strtod               towupper
 | |
| strtod128            tss_create
 | |
| strtod32             tss_delete
 | |
| strtod64             tss_dtor_t
 | |
| strtoencbind         tss_get
 | |
| strtoencdecd         tss_set
 | |
| strtoencf            tss_t
 | |
| strtof               UINT16_C
 | |
| strtoimax            UINT16_MAX
 | |
| strtok               uint16_t
 | |
| strtok_s             UINT16_WIDTH
 | |
| strtol               UINT32_C
 | |
| strtold              UINT32_MAX
 | |
| strtoll              uint32_t
 | |
| strtoul              UINT32_WIDTH
 | |
| strtoull             UINT64_C
 | |
| strtoumax            UINT64_MAX
 | |
| struct               uint64_t
 | |
| strxfrm              UINT64_WIDTH
 | |
| thrd_busy            UINT8_C
 | |
| thrd_create          UINT8_MAX
 | |
| thrd_current         uint8_t
 | |
| thrd_detach          UINT8_WIDTH
 | |
| thrd_equal           UINTMAX_C
 | |
| thrd_error           UINTMAX_MAX
 | |
| thrd_exit            uintmax_t
 | |
| thrd_join            UINTMAX_WIDTH
 | |
| thrd_nomem           UINTPTR_MAX
 | |
| thrd_sleep           uintptr_t
 | |
| thrd_start_t         UINTPTR_WIDTH
 | |
| thrd_success         uint_fast16_t
 | |
| thrd_t               uint_fast32_t
 | |
| thrd_timedout        uint_fast64_t
 | |
| thrd_yield           uint_fast8_t
 | |
| TIME_ACTIVE          uint_least16_t
 | |
| TIME_MONOTONIC       uint_least32_t
 | |
| TIME_THREAD_ACTIVE   uint_least64_t
 | |
| TIME_UTC             uint_least8_t
 | |
| tolower              UINT_MAX
 | |
| totalorder           UINT_WIDTH
 | |
| totalorderd          wcscat
 | |
| totalorderd128       wcscat_s
 | |
| totalorderd32        wcschr
 | |
| totalorderd64        wcscmp
 | |
| totalorderf          wcscoll
 | |
| totalorderl          wcscpy
 | |
| totalordermag        wcscpy_s
 | |
| wcscspn        _Float128_t
 | |
| wcsftime       _Float16
 | |
| wcslen         _Float16_t
 | |
| wcsncat        _Float32
 | |
| wcsncat_s      _Float32x
 | |
| wcsncmp        _Float32_t
 | |
| wcsncpy        _Float64
 | |
| wcsncpy_s      _Float64x
 | |
| wcsnlen_s      _Float64_t
 | |
| wcspbrk        _Generic
 | |
| wcsrchr        _Imaginary
 | |
| wcsrtombs      _Imaginary_I
 | |
| wcsrtombs_s    _IOFBF
 | |
| wcsspn         _IOLBF
 | |
| wcsstr         _IONBF
 | |
| wcsto          _MANT_DIG
 | |
| wcstod         _MAX_10_EXP
 | |
| wcstod128      _MAX_EXP
 | |
| wcstod32       _MIN_10_EXP
 | |
| wcstod64       _MIN_EXP
 | |
| wcstof         _Noreturn
 | |
| wcstoimax      _Pragma
 | |
| wcstok         _PRINTF_NAN_LEN_MAX
 | |
| wcstok_s       _SNAN
 | |
| wcstol         _Static_assert
 | |
| wcstold        _Thread_local
 | |
| wcstoll        _TRUE_MIN
 | |
| wcstombs       __alignas_is_defined
 | |
| wcstombs_s     __alignof_is_defined
 | |
| wcstoul        __bool_true_false_are_defined
 | |
| wcstoull       __cplusplus
 | |
| wcstoumax      __DATE__
 | |
| wcsxfrm        __deprecated__
 | |
| _Alignas       __fallthrough__
 | |
| _Alignof       __FILE__
 | |
| _Atomic        __func__
 | |
| _BitInt        __has_c_attribute
 | |
| _Bool          __has_embed
 | |
| _Complex       __has_include
 | |
| _Complex_I     __if_empty__
 | |
| _Decimal       __limit__
 | |
| _Decimal128    __LINE__
 | |
| _Decimal128x   __maybe_unused__
 | |
| _Decimal32     __nodiscard__
 | |
| _Decimal32_t   __noreturn__
 | |
| _Decimal64     __pp_param__
 | |
| _Decimal64x    __prefix__
 | |
| _Decimal64_t   __reproducible__
 | |
| _DECIMAL_DIG   __STDC_ANALYZABLE__
 | |
| _DIG           __STDC_ENDIAN_BIG__
 | |
| _EPSILON       __STDC_ENDIAN_LITTLE__
 | |
| _Exit          __STDC_ENDIAN_NATIVE__
 | |
| _EXT__         __STDC_HOSTED__
 | |
| _Float         __STDC_IEC_559_COMPLEX__
 | |
| _Float128      __STDC_IEC_559__
 | |
| _Float128x     __STDC_IEC_60559_BFP__
 | |
|     __STDC_IEC_60559_COMPLEX__                    __STDC_VERSION_STDLIB_H__
 | |
|     __STDC_IEC_60559_DFP__                        __STDC_VERSION_TGMATH_H__
 | |
|     __STDC_IEC_60559_TYPES__                      __STDC_VERSION_TIME_H__
 | |
|     __STDC_ISO_10646__                            __STDC_VERSION__
 | |
|     __STDC_LIB_EXT1__                             __STDC_WANT_IEC_60559_
 | |
|     __STDC_MB_MIGHT_NEQ_WC__                      __STDC_WANT_IEC_60559_EXT__
 | |
|     __STDC_NO_ATOMICS__                           __STDC_WANT_IEC_60559_TYPES_EXT__
 | |
|     __STDC_NO_COMPLEX__                           __STDC_WANT_LIB_EXT1__
 | |
|     __STDC_NO_THREADS__                           __STDC__
 | |
|     __STDC_NO_VLA__                               __suffix__
 | |
|     __STDC_UTF_16__                               __TIME__
 | |
|     __STDC_UTF_32__                               __unsequenced__
 | |
|     __STDC_VERSION_FENV_H__                       __VA_ARGS__
 | |
|     __STDC_VERSION_MATH_H__                       __VA_OPT__
 | |
|     __STDC_VERSION_STDINT_H__                     ___Noreturn__
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='J.6.2'></a>
 | |
| <hr>
 | |
| <h3>J.6.2 [Particular identifiers or keywords]</h3>
 | |
| <a name='J.6.2p1'></a>
 | |
| <pre>1   The following 1358 identifiers or keywords are not covered by the above and have particular
 | |
|     semantics provided by this document.
 | |
| 
 | |
|     abort_handler_s                asind                          atand
 | |
|     abort                          asinf                          atanf
 | |
|     abs                            asinhd128                      atanhd128
 | |
|     acosd128                       asinhd32                       atanhd32
 | |
|     acosd32                        asinhd64                       atanhd64
 | |
|     acosd64                        asinhd                         atanhd
 | |
|     acosd                          asinhf                         atanhf
 | |
|     acosf                          asinhl                         atanhl
 | |
|     acoshd128                      asinh                          atanh
 | |
|     acoshd32                       asinl                          atanl
 | |
|     acoshd64                       asinpid128                     atanpid128
 | |
|     acoshd                         asinpid32                      atanpid32
 | |
|     acoshf                         asinpid64                      atanpid64
 | |
|     acoshl                         asinpid                        atanpid
 | |
|     acosh                          asinpif                        atanpif
 | |
|     acosl                          asinpil                        atanpil
 | |
|     acospid128                     asinpi                         atanpi
 | |
|     acospid32                      asin                           atan
 | |
|     acospid64                      assert                         atexit
 | |
|     acospid                        atan2d128                      atof
 | |
|     acospif                        atan2d32                       atoi
 | |
|     acospil                        atan2d64                       atoll
 | |
|     acospi                         atan2d                         atol
 | |
|     acos                           atan2f                         at_quick_exit
 | |
|     addd                           atan2l                         auto
 | |
|     addf                           atan2pid128                    bitand
 | |
|     alignas                        atan2pid32                     BITINT_MAXWIDTH
 | |
|     aligned_alloc                  atan2pid64                     bitor
 | |
|     alignof                        atan2pid                       BOOL_MAX
 | |
|     and_eq                         atan2pif                       BOOL_WIDTH
 | |
|     and                            atan2pil                       bool
 | |
|     asctime_s                      atan2pi                        break
 | |
|     asctime                        atan2                          bsearch_s
 | |
|     asind128                       atand128                       bsearch
 | |
|     asind32                        atand32                        btowc
 | |
|     asind64                        atand64                        BUFSIZ
 | |
| c16rtomb           ceild32          compoundnl
 | |
| c32rtomb           ceild64          compoundn
 | |
| c8rtomb            ceild            conjf
 | |
| cabsf              ceilf            conjl
 | |
| cabsl              ceill            conj
 | |
| cabs               ceil             constexpr
 | |
| cacosf             cerfc            constraint_handler_t
 | |
| cacoshf            cerf             const
 | |
| cacoshl            cexp10m1         continue
 | |
| cacosh             cexp10           copysignd128
 | |
| cacosl             cexp2m1          copysignd32
 | |
| cacospi            cexp2            copysignd64
 | |
| cacos              cexpf            copysignd
 | |
| calloc             cexpl            copysignf
 | |
| call_once          cexpm1           copysignl
 | |
| canonicalized128   cexp             copysign
 | |
| canonicalized32    char16_t         cosd128
 | |
| canonicalized64    char32_t         cosd32
 | |
| canonicalized      char8_t          cosd64
 | |
| canonicalizef      CHAR_BIT         cosd
 | |
| canonicalizel      CHAR_MAX         cosf
 | |
| canonicalize       CHAR_MIN         coshd128
 | |
| cargf              CHAR_WIDTH       coshd32
 | |
| cargl              char             coshd64
 | |
| carg               cimagf           coshd
 | |
| case               cimagl           coshf
 | |
| casinf             cimag            coshl
 | |
| casinhf            ckd_add          cosh
 | |
| casinhl            ckd_div          cosl
 | |
| casinh             ckd_mul          cospid128
 | |
| casinl             ckd_sub          cospid32
 | |
| casinpi            ckd_             cospid64
 | |
| casin              clearerr         cospid
 | |
| catanf             clgamma          cospif
 | |
| catanhf            CLOCKS_PER_SEC   cospil
 | |
| catanhl            clock_t          cospi
 | |
| catanh             clock            cos
 | |
| catanl             clog10p1         cpowf
 | |
| catanpi            clog10           cpowl
 | |
| catan              clog1p           cpown
 | |
| cbrtd128           clog2p1          cpowr
 | |
| cbrtd32            clog2            cpow
 | |
| cbrtd64            clogf            cprojf
 | |
| cbrtd              clogl            cprojl
 | |
| cbrtf              clogp1           cproj
 | |
| cbrtl              clog             crealf
 | |
| cbrt               CMPLXF           creall
 | |
| ccompoundn         CMPLXL           creal
 | |
| ccosf              CMPLX            CR_DECIMAL_DIG
 | |
| ccoshf             complex          csinf
 | |
| ccoshl             compl            csinhf
 | |
| ccosh              compoundnd128    csinhl
 | |
| ccosl              compoundnd32     csinh
 | |
| ccospi             compoundnd64     csinl
 | |
| ccos               compoundnd       csinpi
 | |
| ceild128           compoundnf       csin
 | |
| csqrtf             decodebind64    erfcl
 | |
| csqrtl             decodebind      erfc
 | |
| csqrt              decodebin       erfd128
 | |
| ctanf              decodedecd128   erfd32
 | |
| ctanhf             decodedecd32    erfd64
 | |
| ctanhl             decodedecd64    erfd
 | |
| ctanh              decodedecd      erff
 | |
| ctanl              decodedec       erfl
 | |
| ctanpi             decodef         erf
 | |
| ctan               DEC             errno_t
 | |
| ctgamma            DEFAULT         errno
 | |
| ctime_s            defined         error
 | |
| ctime              define          exit
 | |
| currency_symbol    deprecated      exp10d128
 | |
| CX_LIMITED_RANGE   dfmal           exp10d32
 | |
| d32addd128         dfma            exp10d64
 | |
| d32addd64          difftime        exp10d
 | |
| d32add             divd            exp10f
 | |
| d32divd128         divf            exp10l
 | |
| d32divd64          div_t           exp10m1d128
 | |
| d32div             div             exp10m1d32
 | |
| d32fmad128         dmull           exp10m1d64
 | |
| d32fmad64          dmul            exp10m1d
 | |
| d32fma             double_t        exp10m1f
 | |
| d32muld128         double          exp10m1l
 | |
| d32muld64          do              exp10m1
 | |
| d32mul             dsqrtl          exp10
 | |
| d32sqrtd128        dsqrt           exp2d128
 | |
| d32sqrtd64         dsubl           exp2d32
 | |
| d32sqrt            dsub            exp2d64
 | |
| d32subd128         elifdef         exp2d
 | |
| d32subd64          elifndef        exp2f
 | |
| d32sub             elif            exp2l
 | |
| d64addd128         else            exp2m1d128
 | |
| d64add             embed           exp2m1d32
 | |
| d64divd128         encbind         exp2m1d64
 | |
| d64div             encdecd         exp2m1d
 | |
| d64fmad128         encf            exp2m1f
 | |
| d64fma             encodebind128   exp2m1l
 | |
| d64muld128         encodebind32    exp2m1
 | |
| d64mul             encodebind64    exp2
 | |
| d64sqrtd128        encodebind      expd128
 | |
| d64sqrt            encodebin       expd32
 | |
| d64subd128         encodedecd128   expd64
 | |
| d64sub             encodedecd32    expd
 | |
| daddl              encodedecd64    expf
 | |
| dadd               encodedecd      expl
 | |
| ddivl              encodedec       expm1d128
 | |
| ddiv               encodef         expm1d32
 | |
| DECIMAL_DIG        endif           expm1d64
 | |
| decimal_point      enum            expm1d
 | |
| Decimal            erfcd128        expm1f
 | |
| DECN_              erfcd32         expm1l
 | |
| DECN               erfcd64         expm1
 | |
| decodebind128      erfcd           exp
 | |
| decodebind32       erfcf           extern
 | |
| fabsd128           float_t                fmind64
 | |
| fabsd32            Float                  fmind
 | |
| fabsd64            floord128              fminf
 | |
| fabsd              floord32               fminimumd128
 | |
| fabsf              floord64               fminimumd32
 | |
| fabsl              floord                 fminimumd64
 | |
| fabs               floorf                 fminimumd
 | |
| faddl              floorl                 fminimumf
 | |
| fadd               floor                  fminimuml
 | |
| fallthrough        FLTN_                  fminimum_magd128
 | |
| false              FLTN                   fminimum_magd32
 | |
| fclose             FLT                    fminimum_magd64
 | |
| fdimd128           fmad128                fminimum_magd
 | |
| fdimd32            fmad32                 fminimum_magf
 | |
| fdimd64            fmad64                 fminimum_magl
 | |
| fdimd              fmad                   fminimum_mag_numd128
 | |
| fdimf              fmaf                   fminimum_mag_numd32
 | |
| fdiml              fmal                   fminimum_mag_numd64
 | |
| fdim               fmaxd128               fminimum_mag_numd
 | |
| fdivl              fmaxd32                fminimum_mag_numf
 | |
| fdiv               fmaxd64                fminimum_mag_numl
 | |
| feclearexcept      fmaxd                  fminimum_mag_num
 | |
| fegetenv           fmaxf                  fminimum_mag
 | |
| fegetexceptflag    fmaximumd128           fminimum_numd128
 | |
| fegetmode          fmaximumd32            fminimum_numd32
 | |
| fegetround         fmaximumd64            fminimum_numd64
 | |
| feholdexcept       fmaximumd              fminimum_numd
 | |
| femode_t           fmaximumf              fminimum_numf
 | |
| FENV_ACCESS        fmaximuml              fminimum_numl
 | |
| FENV_DEC_ROUND     fmaximum_magd128       fminimum_num
 | |
| FENV_ROUND         fmaximum_magd32        fminimum
 | |
| fenv_t             fmaximum_magd64        fminl
 | |
| feof               fmaximum_magd          fmin
 | |
| feraiseexcept      fmaximum_magf          fmodd128
 | |
| ferror             fmaximum_magl          fmodd32
 | |
| fesetenv           fmaximum_mag_numd128   fmodd64
 | |
| fesetexceptflag    fmaximum_mag_numd32    fmodd
 | |
| fesetexcept        fmaximum_mag_numd64    fmodf
 | |
| fesetmode          fmaximum_mag_numd      fmodl
 | |
| fesetround         fmaximum_mag_numf      fmod
 | |
| fetestexceptflag   fmaximum_mag_numl      fmull
 | |
| fetestexcept       fmaximum_mag_num       fmul
 | |
| feupdateenv        fmaximum_mag           FOPEN_MAX
 | |
| fexcept_t          fmaximum_numd128       fopen_s
 | |
| fe_dec_getround    fmaximum_numd32        fopen
 | |
| fe_dec_setround    fmaximum_numd64        for
 | |
| fflush             fmaximum_numd          fpclassify
 | |
| ffmal              fmaximum_numf          fpos_t
 | |
| ffma               fmaximum_numl          fprintf_s
 | |
| fgetc              fmaximum_num           fprintf
 | |
| fgetpos            fmaximum               fputc
 | |
| fgets              fmaxl                  fputs
 | |
| fgetwc             fmax                   fputwc
 | |
| fgetws             fma                    fputws
 | |
| FILENAME_MAX       fmind128               frac_digits
 | |
| FILE               fmind32                fread
 | |
| free_aligned_sized    gets                 ldexpd32
 | |
| free_sized            getwchar             ldexpd64
 | |
| free                  getwc                ldexpd
 | |
| freopen_s             gmtime_r             ldexpf
 | |
| freopen               gmtime_s             ldexpl
 | |
| frexpd128             gmtime               ldexp
 | |
| frexpd32              goto                 ldiv_t
 | |
| frexpd64              grouping             ldiv
 | |
| frexpd                HUGE_VALF            lgammad128
 | |
| frexpf                HUGE_VALL            lgammad32
 | |
| frexpl                HUGE_VAL_D128        lgammad64
 | |
| frexp                 HUGE_VAL_D32         lgammad
 | |
| fromfpd128            HUGE_VAL_D64         lgammaf
 | |
| fromfpd32             HUGE_VAL_D           lgammal
 | |
| fromfpd64             HUGE_VAL_F           lgamma
 | |
| fromfpd               HUGE_VAL             limit
 | |
| fromfpf               hypotd128            line
 | |
| fromfpl               hypotd32             llabs
 | |
| fromfpxd128           hypotd64             lldiv_t
 | |
| fromfpxd32            hypotd               lldiv
 | |
| fromfpxd64            hypotf               llogbd128
 | |
| fromfpxd              hypotl               llogbd32
 | |
| fromfpxf              hypot                llogbd64
 | |
| fromfpxl              ifdef                llogbd
 | |
| fromfpx               ifndef               llogbf
 | |
| fromfp                if_empty             llogbl
 | |
| fscanf_s              if                   llogb
 | |
| fscanf                ignore_handler_s     LLONG_MAX
 | |
| fseek                 ilogbd128            LLONG_MIN
 | |
| fsetpos               ilogbd32             LLONG_WIDTH
 | |
| fsqrtl                ilogbd64             llquantexpd128
 | |
| fsqrt                 ilogbd               llquantexpd32
 | |
| fsubl                 ilogbf               llquantexpd64
 | |
| fsub                  ilogbl               llquantexpd
 | |
| ftell                 ilogb                llquantexp
 | |
| fwide                 imaginary            llrintd128
 | |
| fwprintf_s            imaxabs              llrintd32
 | |
| fwprintf              imaxdiv_t            llrintd64
 | |
| fwrite                imaxdiv              llrintd
 | |
| fwscanf_s             include              llrintf
 | |
| fwscanf               INFINITY             llrintl
 | |
| generic_count_type    inline               llrint
 | |
| generic_return_type   int_curr_symbol      llroundd128
 | |
| generic_value_type    int_frac_digits      llroundd32
 | |
| getchar               int_n_cs_precedes    llroundd64
 | |
| getc                  int_n_sep_by_space   llroundd
 | |
| getenv_s              int_n_sign_posn      llroundf
 | |
| getenv                int_p_cs_precedes    llroundl
 | |
| getpayloadd128        int_p_sep_by_space   llround
 | |
| getpayloadd32         int_p_sign_posn      localeconv
 | |
| getpayloadd64         I                    localtime_r
 | |
| getpayloadd           jmp_buf              localtime_s
 | |
| getpayloadf           kill_dependency      localtime
 | |
| getpayloadl           labs                 log10d128
 | |
| getpayload            lconv                log10d32
 | |
| gets_s                ldexpd128            log10d64
 | |
| log10d          LONG_MIN            nanf
 | |
| log10f          LONG_WIDTH          nanl
 | |
| log10l          long                nan
 | |
| log10p1d128     lrintd128           NDEBUG
 | |
| log10p1d32      lrintd32            nearbyintd128
 | |
| log10p1d64      lrintd64            nearbyintd32
 | |
| log10p1d        lrintd              nearbyintd64
 | |
| log10p1f        lrintf              nearbyintd
 | |
| log10p1l        lrintl              nearbyintf
 | |
| log10p1         lrint               nearbyintl
 | |
| log10           lroundd128          nearbyint
 | |
| log1pd128       lroundd32           negative_sign
 | |
| log1pd32        lroundd64           nextafterd128
 | |
| log1pd64        lroundd             nextafterd32
 | |
| log1pd          lroundf             nextafterd64
 | |
| log1pf          lroundl             nextafterd
 | |
| log1pl          lround              nextafterf
 | |
| log1p           L_tmpnam_s          nextafterl
 | |
| log2d128        L_tmpnam            nextafter
 | |
| log2d32         main                nextdownd128
 | |
| log2d64         malloc              nextdownd32
 | |
| log2d           math_errhandling    nextdownd64
 | |
| log2f           max_align_t         nextdownd
 | |
| log2l           maybe_unused        nextdownf
 | |
| log2p1d128      mblen               nextdownl
 | |
| log2p1d32       mbrlen              nextdown
 | |
| log2p1d64       mbrtoc16            nexttowardd128
 | |
| log2p1d         mbrtoc32            nexttowardd32
 | |
| log2p1f         mbrtoc8             nexttowardd64
 | |
| log2p1l         mbrtowc             nexttowardf
 | |
| log2p1          mbsinit             nexttowardl
 | |
| log2            mbsrtowcs_s         nexttoward
 | |
| logbd128        mbsrtowcs           nextupd128
 | |
| logbd32         mbstate_t           nextupd32
 | |
| logbd64         mbstowcs_s          nextupd64
 | |
| logbd           mbstowcs            nextupd
 | |
| logbf           mbtowc              nextupf
 | |
| logbl           MB_CUR_MAX          nextupl
 | |
| logb            MB_LEN_MAX          nextup
 | |
| logd128         mktime              nodiscard
 | |
| logd32          modfd128            noreturn
 | |
| logd64          modfd32             not_eq
 | |
| logd            modfd64             not
 | |
| logf            modfd               nullptr_t
 | |
| logl            modff               nullptr
 | |
| logp1d128       modfl               NULL
 | |
| logp1d32        modf                n_cs_precedes
 | |
| logp1d64        mon_decimal_point   n_sep_by_space
 | |
| logp1d          mon_grouping        n_sign_posn
 | |
| logp1f          mon_thousands_sep   N
 | |
| logp1l          muld                offsetof
 | |
| logp1           mulf                OFF
 | |
| log             nand128             ONCE_FLAG_INIT
 | |
| longjmp         nand32              once_flag
 | |
| long_double_t   nand64              ON
 | |
| LONG_MAX        nand                or_eq
 | |
| or               QWchar_t        rsqrtf
 | |
| perror           raise           rsqrtl
 | |
| positive_sign    RAND_MAX        rsqrt
 | |
| powd128          rand            samequantumd128
 | |
| powd32           realloc         samequantumd32
 | |
| powd64           register        samequantumd64
 | |
| powd             remainderd128   samequantumd
 | |
| powf             remainderd32    samequantum
 | |
| powl             remainderd64    scalblnd128
 | |
| pownd128         remainderd      scalblnd32
 | |
| pownd32          remainderf      scalblnd64
 | |
| pownd64          remainderl      scalblnd
 | |
| pownd            remainder       scalblnf
 | |
| pownf            remove          scalblnl
 | |
| pownl            remquof         scalbln
 | |
| pown             remquol         scalbnd128
 | |
| powrd128         remquo          scalbnd32
 | |
| powrd32          rename          scalbnd64
 | |
| powrd64          reproducible    scalbnd
 | |
| powrd            restrict        scalbnf
 | |
| powrf            return          scalbnl
 | |
| powrl            rewind          scalbn
 | |
| powr             rintd128        scanf_s
 | |
| pow              rintd32         scanf
 | |
| pp_param         rintd64         SCHAR_MAX
 | |
| pragma           rintd           SCHAR_MIN
 | |
| prefix           rintf           SCHAR_WIDTH
 | |
| printf_s         rintl           SEEK_CUR
 | |
| printf           rint            SEEK_END
 | |
| PTRDIFF_MAX      rootnd128       SEEK_SET
 | |
| PTRDIFF_MIN      rootnd32        setbuf
 | |
| ptrdiff_t        rootnd64        setjmp
 | |
| PTRDIFF_WIDTH    rootnd          setlocale
 | |
| putchar          rootnf          setpayloadd128
 | |
| putc             rootnl          setpayloadd32
 | |
| puts             rootn           setpayloadd64
 | |
| putwchar         roundd128       setpayloadd
 | |
| putwc            roundd32        setpayloadf
 | |
| p_cs_precedes    roundd64        setpayloadl
 | |
| p_sep_by_space   roundd          setpayloadsigd128
 | |
| p_sign_posn      roundevend128   setpayloadsigd32
 | |
| QChar            roundevend32    setpayloadsigd64
 | |
| qsort_s          roundevend64    setpayloadsigd
 | |
| qsort            roundevend      setpayloadsigf
 | |
| quantized128     roundevenf      setpayloadsigl
 | |
| quantized32      roundevenl      setpayloadsig
 | |
| quantized64      roundeven       setpayload
 | |
| quantized        roundf          setvbuf
 | |
| quantize         roundl          set_constraint_handler_s
 | |
| quantumd128      round           short
 | |
| quantumd32       RSIZE_MAX       SHRT_MAX
 | |
| quantumd64       rsize_t         SHRT_MIN
 | |
| quantumd         rsqrtd128       SHRT_WIDTH
 | |
| quantum          rsqrtd32        signal
 | |
| quick_exit       rsqrtd64        signbit
 | |
| QVoid            rsqrtd          signed
 | |
| sig_atomic_t    tand128           truncf
 | |
| sind128         tand32            truncl
 | |
| sind32          tand64            trunc
 | |
| sind64          tand              TSS_DTOR_ITERATIONS
 | |
| sind            tanf              tv_nsec
 | |
| sinf            tanhd128          tv_sec
 | |
| sinhd128        tanhd32           typedef
 | |
| sinhd32         tanhd64           typeof_unqual
 | |
| sinhd64         tanhd             typeof
 | |
| sinhd           tanhf             UCHAR_MAX
 | |
| sinhf           tanhl             UCHAR_WIDTH
 | |
| sinhl           tanh              ufromfpd128
 | |
| sinh            tanl              ufromfpd32
 | |
| sinl            tanpid128         ufromfpd64
 | |
| sinpid128       tanpid32          ufromfpd
 | |
| sinpid32        tanpid64          ufromfpf
 | |
| sinpid64        tanpid            ufromfpl
 | |
| sinpid          tanpif            ufromfpxd128
 | |
| sinpif          tanpil            ufromfpxd32
 | |
| sinpil          tanpi             ufromfpxd64
 | |
| sinpi           tan               ufromfpxd
 | |
| sin             tgammad128        ufromfpxf
 | |
| sizeof          tgammad32         ufromfpxl
 | |
| SIZE_MAX        tgammad64         ufromfpx
 | |
| size_t          tgammad           ufromfp
 | |
| SIZE_WIDTH      tgammaf           ULLONG_MAX
 | |
| snprintf_s      tgammal           ULLONG_WIDTH
 | |
| snprintf        tgamma            ULONG_MAX
 | |
| snwprintf_s     thousands_sep     ULONG_WIDTH
 | |
| sprintf_s       thread_local      undef
 | |
| sprintf         timespec_getres   ungetc
 | |
| sqrtd128        timespec_get      ungetwc
 | |
| sqrtd32         timespec          union
 | |
| sqrtd64         time_t            unreachable
 | |
| sqrtd           time              unsequenced
 | |
| sqrtf           tmpfile_s         unsigned
 | |
| sqrtl           tmpfile           USHRT_MAX
 | |
| sqrt            tmpnam_s          USHRT_WIDTH
 | |
| srand           tmpnam            va_arg
 | |
| sscanf_s        TMP_MAX_S         va_copy
 | |
| sscanf          TMP_MAX           va_end
 | |
| static_assert   tm_hour           va_list
 | |
| static          tm_isdst          va_start
 | |
| STDC            tm_mday           vfprintf_s
 | |
| stderr          tm_min            vfprintf
 | |
| stdin           tm_mon            vfscanf_s
 | |
| stdout          tm_sec            vfscanf
 | |
| subd            tm_wday           vfwprintf_s
 | |
| subf            tm_yday           vfwprintf
 | |
| suffix          tm_year           vfwscanf_s
 | |
| switch          tm                vfwscanf
 | |
| swprintf_s      true              void
 | |
| swprintf        truncd128         volatile
 | |
| swscanf_s       truncd32          vprintf_s
 | |
| swscanf         truncd64          vprintf
 | |
| system          truncd            vscanf_s
 | |
|     vscanf                             wctomb                             xdivf
 | |
|     vsnprintf_s                        wctrans_t                          xfmad
 | |
|     vsnprintf                          wctrans                            xfmaf
 | |
|     vsnwprintf_s                       wctype_t                           xmuld
 | |
|     vsprintf_s                         wctype                             xmulf
 | |
|     vsprintf                           WEOF                               xor_eq
 | |
|     vsscanf_s                          while                              xor
 | |
|     vsscanf                            WINT_MAX                           xsqrtd
 | |
|     vswprintf_s                        WINT_MIN                           xsqrtf
 | |
|     vswprintf                          wint_t                             xsubd
 | |
|     vswscanf_s                         WINT_WIDTH                         xsubf
 | |
|     vswscanf                           wmemchr                            X_DECIMAL_DIG
 | |
|     vwprintf_s                         wmemcmp                            X_DIG
 | |
|     vwprintf                           wmemcpy_s                          X_EPSILON
 | |
|     vwscanf_s                          wmemcpy                            X_MANT_DIG
 | |
|     vwscanf                            wmemmove_s                         X_MAX_10_EXP
 | |
|     warning                            wmemmove                           X_MAX_EXP
 | |
|     WCHAR_MAX                          wmemset                            X_MAX
 | |
|     WCHAR_MIN                          wprintf_s                          X_MIN_10_EXP
 | |
|     wchar_t                            wprintf                            X_MIN_EXP
 | |
|     WCHAR_WIDTH                        wscanf_s                           X_MIN
 | |
|     wcrtomb_s                          wscanf                             X_SNAN
 | |
|     wcrtomb                            xaddd                              X_TRUE_MIN
 | |
|     wctob                              xaddf                              X_
 | |
|     wctomb_s                           xdivd
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='J.6.3'></a>
 | |
| <hr>
 | |
| <h3>J.6.3 [Type inference]</h3>
 | |
| <a name='J.6.3p1'></a>
 | |
| <pre>1   A declaration for which a type is inferred (<a href='#6.7.9'>6.7.9</a>) may additionally accept pointer declarators, function
 | |
|     declarators, and may have more than one declarator.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.'></a>
 | |
| <hr>
 | |
| <h3>K. [Annex K (normative) Bounds-checking interfaces]</h3>
 | |
| <a name='K.1'></a>
 | |
| <hr>
 | |
| <h3>K.1 [Background]</h3>
 | |
| <a name='K.1p1'></a>
 | |
| <pre>1   Traditionally, the C Library has contained many functions that trust the programmer to provide
 | |
|     output character arrays big enough to hold the result being produced. Not only do these functions
 | |
|     not check that the arrays are big enough, they frequently lack the information needed to perform
 | |
|     such checks. While it is possible to write safe, robust, and error-free code using the existing library,
 | |
|     the library tends to promote programming styles that lead to mysterious failures if a result is too big
 | |
|     for the provided array.
 | |
| </pre>
 | |
| <a name='K.1p2'></a>
 | |
| <pre>2   A common programming style is to declare character arrays large enough to handle most practical
 | |
|     cases. However, if these arrays are not large enough to handle the resulting strings, data can be
 | |
|     written past the end of the array overwriting other data and program structures. The program never
 | |
|     gets any indication that a problem exists, and so never has a chance to recover or to fail gracefully.
 | |
| </pre>
 | |
| <a name='K.1p3'></a>
 | |
| <pre>3   Worse, this style of programming has compromised the security of computers and networks. Buffer
 | |
|     overflows can often be exploited to run arbitrary code with the permissions of the vulnerable
 | |
|     (defective) program.
 | |
| </pre>
 | |
| <a name='K.1p4'></a>
 | |
| <pre>4   If the programmer writes runtime checks to verify lengths before calling library functions, then
 | |
|     those runtime checks frequently duplicate work done inside the library functions, which discover
 | |
|     string lengths as a side effect of doing their job.
 | |
| </pre>
 | |
| <a name='K.1p5'></a>
 | |
| <pre>5   This annex provides alternative library functions that promote safer, more secure programming. The
 | |
|     alternative functions verify that output buffers are large enough for the intended result and return a
 | |
|     failure indicator if they are not. Data is never written past the end of an array. All string results are
 | |
|     null terminated.
 | |
| </pre>
 | |
| <a name='K.1p6'></a>
 | |
| <pre>6   This annex also addresses another problem that complicates writing robust code: functions that are
 | |
|     not reentrant because they return pointers to static objects owned by the function. Such functions
 | |
|     can be troublesome since a previously returned result can change if the function is called again,
 | |
|     perhaps by another thread.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.2'></a>
 | |
| <hr>
 | |
| <h3>K.2 [Scope]</h3>
 | |
| <a name='K.2p1'></a>
 | |
| <pre>1   This annex specifies a series of optional extensions that can be useful in the mitigation of security
 | |
|     vulnerabilities in programs, and comprise new functions, macros, and types declared or defined in
 | |
|     existing standard headers.
 | |
| </pre>
 | |
| <a name='K.2p2'></a>
 | |
| <pre>2   An implementation that defines __STDC_LIB_EXT1__ shall conform to the specifications in this
 | |
|     annex.<a href='#FOOTNOTE.465'><sup>[465]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.465'>
 | |
| <pre><i><b>Footnote 465)</b> Implementations that do not define __STDC_LIB_EXT1__ are not required to conform to these specifications.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.2p3'></a>
 | |
| <pre>3   Subclause <a href='#K.3'>K.3</a> should be read as if it were merged into the parallel structure of named subclauses of
 | |
|     Clause 7.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3'></a>
 | |
| <hr>
 | |
| <h3>K.3 [Library]</h3>
 | |
| <a name='K.3.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.1 [Introduction]</h3>
 | |
| <a name='K.3.1.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.1.1 [Standard headers]</h3>
 | |
| <a name='K.3.1.1p1'></a>
 | |
| <pre>1   The functions, macros, and types declared or defined in <a href='#K.3'>K.3</a> and its subclauses are not declared
 | |
|     or defined by their respective headers if __STDC_WANT_LIB_EXT1__ is defined as a macro which
 | |
|     expands to the integer constant 0 at the point in the source file where the appropriate header is first
 | |
|     included.
 | |
| </pre>
 | |
| <a name='K.3.1.1p2'></a>
 | |
| <pre>2   The functions, macros, and types declared or defined in <a href='#K.3'>K.3</a> and its subclauses are declared and
 | |
|     defined by their respective headers if __STDC_WANT_LIB_EXT1__ is defined as a macro which ex-
 | |
|     pands to the integer constant 1 at the point in the source file where the appropriate header is first
 | |
|     included.<a href='#FOOTNOTE.466'><sup>[466]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.466'>
 | |
| <pre><i><b>Footnote 466)</b> Future revisions of this document might define meanings for other values of __STDC_WANT_LIB_EXT1__ .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.1.1p3'></a>
 | |
| <pre>3   It is implementation-defined whether the functions, macros, and types declared or defined in <a href='#K.3'>K.3</a> and
 | |
|     its subclauses are declared or defined by their respective headers if __STDC_WANT_LIB_EXT1__ is not
 | |
|     defined as a macro at the point in the source file where the appropriate header is first included.<a href='#FOOTNOTE.467'><sup>[467]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.467'>
 | |
| <pre><i><b>Footnote 467)</b> Subclause <a href='#7.1.3'>7.1.3</a> reserves certain names and patterns of names that an implementation can use in headers. All other names
 | |
|     are not reserved, and a conforming implementation is not permitted to use them. While some of the names defined in <a href='#K.3'>K.3</a> and
 | |
|     its subclauses are reserved, others are not. If an unreserved name is defined in a header when __STDC_WANT_LIB_EXT1__ is
 | |
|     defined as 0, the implementation is not conforming.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.1.1p4'></a>
 | |
| <pre>4   Within a preprocessing translation unit, __STDC_WANT_LIB_EXT1__ shall be defined identically for
 | |
|     all inclusions of any headers from Subclause <a href='#K.3'>K.3</a>. If __STDC_WANT_LIB_EXT1__ is defined differently
 | |
|     for any such inclusion, the implementation shall issue a diagnostic as if a preprocessor error directive
 | |
|     were used.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.1.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.1.2 [Reserved identifiers]</h3>
 | |
| <a name='K.3.1.2p1'></a>
 | |
| <pre>1   Each macro name in any of the following subclauses is reserved for use as specified if it is defined
 | |
|     by any of its associated headers when included; unless explicitly stated otherwise (see <a href='#7.1.4'>7.1.4</a>).
 | |
| </pre>
 | |
| <a name='K.3.1.2p2'></a>
 | |
| <pre>2   All identifiers with external linkage in any of the following subclauses are reserved for use as
 | |
|     identifiers with external linkage if any of them are used by the program. None of them are reserved
 | |
|     if none of them are used.
 | |
| </pre>
 | |
| <a name='K.3.1.2p3'></a>
 | |
| <pre>3   Each identifier with file scope listed in any of the following subclauses is reserved for use as a
 | |
|     macro name and as an identifier with file scope in the same name space if it is defined by any of its
 | |
|     associated headers when included.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.1.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.1.3 [Use of errno]</h3>
 | |
| <a name='K.3.1.3p1'></a>
 | |
| <pre>1   An implementation may set errno for the functions defined in this annex, but is not required to.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.1.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.1.4 [Runtime-constraint violations]</h3>
 | |
| <a name='K.3.1.4p1'></a>
 | |
| <pre>1   Most functions in this annex include as part of their specification a list of runtime-constraints. These
 | |
|     runtime-constraints are requirements on the program using the library.<a href='#FOOTNOTE.468'><sup>[468]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.468'>
 | |
| <pre><i><b>Footnote 468)</b> Although runtime-constraints replace many cases of undefined behavior, undefined behavior still exists in this annex.
 | |
|     Implementations are free to detect any case of undefined behavior and treat it as a runtime-constraint violation by calling the
 | |
|     runtime-constraint handler. This license comes directly from the definition of undefined behavior.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.1.4p2'></a>
 | |
| <pre>2   Implementations shall verify that the runtime-constraints for a function are not violated by the
 | |
|     program. If a runtime-constraint is violated, the implementation shall call the currently registered
 | |
|     runtime-constraint handler (see set_constraint_handler_s in <stdlib.h>). Multiple runtime-
 | |
|     constraint violations in the same call to a library function result in only one call to the runtime-
 | |
|     constraint handler. It is unspecified which one of the multiple runtime-constraint violations cause
 | |
|     the handler to be called.
 | |
| </pre>
 | |
| <a name='K.3.1.4p3'></a>
 | |
| <pre>3   If the runtime-constraints section for a function states an action to be performed when a runtime-
 | |
|     constraint violation occurs, the function shall perform the action before calling the runtime-constraint
 | |
|     handler. If the runtime-constraints section lists actions that are prohibited when a runtime-constraint
 | |
|     violation occurs, then such actions are prohibited to the function both before calling the handler and
 | |
|     after the handler returns.
 | |
| </pre>
 | |
| <a name='K.3.1.4p4'></a>
 | |
| <pre>4   The runtime-constraint handler might not return. If the handler does return, the library function
 | |
|     whose runtime-constraint was violated shall return some indication of failure as given by the returns
 | |
|     section in the function’s specification.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.2 [Errors <errno.h>]</h3>
 | |
| <a name='K.3.2p1'></a>
 | |
| <pre>1   The header <errno.h> defines a type.
 | |
| </pre>
 | |
| <a name='K.3.2p2'></a>
 | |
| <pre>2   The type is
 | |
| 
 | |
|               errno_t
 | |
|     which is type int.<a href='#FOOTNOTE.469'><sup>[469]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.469'>
 | |
| <pre><i><b>Footnote 469)</b> As a matter of programming style, errno_t can be used as the type of something that deals only with the values that
 | |
|     might be found in errno. For example, a function which returns the value of errno could be declared as having the return
 | |
|     type errno_t.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.3 [Common definitions <stddef.h>]</h3>
 | |
| <a name='K.3.3p1'></a>
 | |
| <pre>1   The header <stddef.h> defines a type.
 | |
| </pre>
 | |
| <a name='K.3.3p2'></a>
 | |
| <pre>2   The type is
 | |
| 
 | |
|               rsize_t
 | |
| 
 | |
| 
 | |
|     which is the type size_t.<a href='#FOOTNOTE.470'><sup>[470]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.470'>
 | |
| <pre><i><b>Footnote 470)</b> See the description of the RSIZE_MAX macro in <stdint.h>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.4 [Integer types <stdint.h>]</h3>
 | |
| <a name='K.3.4p1'></a>
 | |
| <pre>1   The header <stdint.h> defines a macro.
 | |
| </pre>
 | |
| <a name='K.3.4p2'></a>
 | |
| <pre>2   The macro is
 | |
| 
 | |
|               RSIZE_MAX
 | |
| 
 | |
| 
 | |
|     which expands to a value<a href='#FOOTNOTE.471'><sup>[471]</sup></a> of type size_t. Functions that have parameters of type rsize_t con-
 | |
|     sider it a runtime-constraint violation if the values of those parameters are greater than RSIZE_MAX.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.471'>
 | |
| <pre><i><b>Footnote 471)</b> The macro RSIZE_MAX need not expand to a constant expression.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.4p3'></a>
 | |
| <pre>3   Extremely large object sizes are frequently a sign that an object’s size was calculated incorrectly. For
 | |
|     example, negative numbers appear as very large positive numbers when converted to an unsigned
 | |
|     type like size_t. Also, some implementations do not support objects as large as the maximum
 | |
|     value that can be represented by type size_t.
 | |
| </pre>
 | |
| <a name='K.3.4p4'></a>
 | |
| <pre>4   For those reasons, it is sometimes beneficial to restrict the range of object sizes to detect programming
 | |
|     errors. For implementations targeting machines with large address spaces, it is recommended that
 | |
|     RSIZE_MAX be defined as the smaller of the size of the largest object supported or (SIZE_MAX >> 1) ,
 | |
|     even if this limit is smaller than the size of some legitimate, but very large, objects. Implementations
 | |
|     targeting machines with small address spaces may wish to define RSIZE_MAX as SIZE_MAX, which
 | |
|     means that there is no object size that is considered a runtime-constraint violation.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5'></a>
 | |
| <hr>
 | |
| <h3>K.3.5 [Input/output <stdio.h>]</h3>
 | |
| <a name='K.3.5p1'></a>
 | |
| <pre>1   The header <stdio.h> defines several macros and two types.
 | |
| </pre>
 | |
| <a name='K.3.5p2'></a>
 | |
| <pre>2   The macros are
 | |
| 
 | |
|               L_tmpnam_s
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the size needed for an array of char large
 | |
|     enough to hold a temporary file name string generated by the tmpnam_s function;
 | |
| 
 | |
|               TMP_MAX_S
 | |
| 
 | |
| 
 | |
|     which expands to an integer constant expression that is the maximum number of unique file names
 | |
|     that can be generated by the tmpnam_s function.
 | |
| </pre>
 | |
| <a name='K.3.5p3'></a>
 | |
| <pre>3   The types are
 | |
| 
 | |
|               errno_t
 | |
| 
 | |
| 
 | |
|     which is type int; and
 | |
|               rsize_t
 | |
| 
 | |
| 
 | |
|     which is the type size_t.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.1 [Operations on files]</h3>
 | |
| <a name='K.3.5.1.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.1.1 [The tmpfile_s function]</h3>
 | |
| <a name='K.3.5.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               errno_t tmpfile_s(FILE * restrict * restrict streamptr);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.1.1p2'></a>
 | |
| <pre>2   streamptr shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.1.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, tmpfile_s does not attempt to create a file.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.1.1p4'></a>
 | |
| <pre>4   The tmpfile_s function creates a temporary binary file that is different from any other existing file
 | |
|     and that will automatically be removed when it is closed or at program termination. If the program
 | |
|     terminates abnormally, whether an open temporary file is removed is implementation-defined. The
 | |
|     file is opened for update with "wb+" mode with the meaning that mode has in the fopen_s function
 | |
|     (including the mode’s effect on exclusive access and file permissions).
 | |
| </pre>
 | |
| <a name='K.3.5.1.1p5'></a>
 | |
| <pre>5   If the file was created successfully, then the pointer to FILE pointed to by streamptr will be set to
 | |
|     the pointer to the object controlling the opened file. Otherwise, the pointer to FILE pointed to by
 | |
|     streamptr will be set to a null pointer.
 | |
| 
 | |
|     Recommended practice
 | |
|     It should be possible to open at least TMP_MAX_S temporary files during the lifetime of the program
 | |
|     (this limit may be shared with tmpnam_s) and there should be no limit on the number simultaneously
 | |
|     open other than this limit and any limit on the number of open files (FOPEN_MAX).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.1.1p6'></a>
 | |
| <pre>6   The tmpfile_s function returns zero if it created the file. If it did not create the file or there was a
 | |
|     runtime-constraint violation, tmpfile_s returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.1.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.1.2 [The tmpnam_s function]</h3>
 | |
| <a name='K.3.5.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               errno_t tmpnam_s(char *s, rsize_t maxsize);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p2'></a>
 | |
| <pre>2   s shall not be a null pointer. maxsize shall be less than or equal to RSIZE_MAX. maxsize shall be
 | |
|     greater than the length of the generated file name string.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p3'></a>
 | |
| <pre>3   The tmpnam_s function generates a string that is a valid file name and that is not the same as the
 | |
|     name of an existing file.<a href='#FOOTNOTE.472'><sup>[472]</sup></a> The function is potentially capable of generating TMP_MAX_S different
 | |
|     strings, but any or all of them may already be in use by existing files and thus not be suitable return
 | |
|     values. The lengths of these strings shall be less than the value of the L_tmpnam_s macro.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.472'>
 | |
| <pre><i><b>Footnote 472)</b> Files created using strings generated by the tmpnam_s function are temporary only in the sense that their names are not
 | |
|     expected to collide with those generated by conventional naming rules for the implementation. It is still necessary to use the
 | |
|     remove function to remove such files when their use is ended, and before program termination.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.1.2p4'></a>
 | |
| <pre>4   The tmpnam_s function generates a different string each time it is called.
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p5'></a>
 | |
| <pre>5    It is assumed that s points to an array of at least maxsize characters. This array will be set to
 | |
|      generated string, as specified below.
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p6'></a>
 | |
| <pre>6    The implementation shall behave as if no library function except tmpnam calls the tmpnam_s func-
 | |
|      tion.<a href='#FOOTNOTE.473'><sup>[473]</sup></a>
 | |
| 
 | |
|      Recommended practice
 | |
| </pre>
 | |
| <a name='FOOTNOTE.473'>
 | |
| <pre><i><b>Footnote 473)</b> An implementation can have tmpnam call tmpnam_s (perhaps so there is only one naming convention for temporary files),
 | |
|      but this is not required.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.1.2p7'></a>
 | |
| <pre>7    After a program obtains a file name using the tmpnam_s function and before the program creates a
 | |
|      file with that name, the possibility exists that someone else may create a file with that same name.
 | |
|      To avoid this race condition, the tmpfile_s function should be used instead of tmpnam_s when
 | |
|      possible. One situation that requires the use of the tmpnam_s function is when the program needs to
 | |
|      create a temporary directory rather than a temporary file.
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p8'></a>
 | |
| <pre>8    Implementations should take care in choosing the patterns used for names returned by tmpnam_s.
 | |
|      For example, making a thread ID part of the names avoids the race condition and possible conflict
 | |
|      when multiple programs run simultaneously by the same user generate the same temporary file
 | |
|      names.
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p9'></a>
 | |
| <pre>9    If no suitable string can be generated, or if there is a runtime-constraint violation, the tmpnam_s
 | |
|      function:
 | |
| 
 | |
|        — if s is not null and maxsize is both greater than zero and not greater than RSIZE_MAX, writes a
 | |
|          null character to s[0]
 | |
|        — returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p10'></a>
 | |
| <pre>10   Otherwise, the tmpnam_s function writes the string in the array pointed to by s and returns zero.
 | |
| 
 | |
|      Environmental limits
 | |
| </pre>
 | |
| <a name='K.3.5.1.2p11'></a>
 | |
| <pre>11   The value of the macro TMP_MAX_S shall be at least 25.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.2 [File access functions]</h3>
 | |
| <a name='K.3.5.2.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.2.1 [The fopen_s function]</h3>
 | |
| <a name='K.3.5.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|                #include <stdio.h>
 | |
|                errno_t fopen_s(FILE * restrict * restrict streamptr,
 | |
|                      const char * restrict filename, const char * restrict mode);
 | |
| 
 | |
| 
 | |
|      Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.2.1p2'></a>
 | |
| <pre>2    None of streamptr, filename, or mode shall be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.2.1p3'></a>
 | |
| <pre>3    If there is a runtime-constraint violation, fopen_s does not attempt to open a file. Furthermore, if
 | |
|      streamptr is not a null pointer, fopen_s sets *streamptr to the null pointer.
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='K.3.5.2.1p4'></a>
 | |
| <pre>4    The fopen_s function opens the file whose name is the string pointed to by filename, and associates
 | |
|      a stream with it.
 | |
| </pre>
 | |
| <a name='K.3.5.2.1p5'></a>
 | |
| <pre>5    The mode string shall be as described for fopen, with the addition that modes starting with the
 | |
|      character ’w’ or ’a’ may be preceded by the character ’u’ , see below:
 | |
|      uw                  truncate to zero length or create text file for writing, default permissions
 | |
|      uwx                 create text file for writing, default permissions
 | |
|      ua                  append; open or create text file for writing at end-of-file, default permissions
 | |
|     uwb                truncate to zero length or create binary file for writing, default permissions
 | |
|     uwbx               create binary file for writing, default permissions
 | |
|     uab                append; open or create binary file for writing at end-of-file, default permissions
 | |
|     uw+                truncate to zero length or create text file for update, default permissions
 | |
|     uw+x               create text file for update, default permissions
 | |
|     ua+                append; open or create text file for update, writing at end-of-file, default permis-
 | |
|                        sions
 | |
|     uw+b or uwb+       truncate to zero length or create binary file for update, default permissions
 | |
|     uw+bx or uwb+x create binary file for update, default permissions
 | |
| 
 | |
|     ua+b or uab+       append; open or create binary file for update, writing at end-of-file, default permis-
 | |
|                        sions
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.2.1p6'></a>
 | |
| <pre>6   Opening a file with exclusive mode (’x’ as the last character in the mode argument) fails if the file
 | |
|     already exists or cannot be created.
 | |
| </pre>
 | |
| <a name='K.3.5.2.1p7'></a>
 | |
| <pre>7   To the extent that the underlying system supports the concepts, files opened for writing shall be
 | |
|     opened with exclusive (also known as non-shared) access. If the file is being created, and the first
 | |
|     character of the mode string is not ’u’ , to the extent that the underlying system supports it, the file
 | |
|     shall have a file permission that prevents other users on the system from accessing the file. If the
 | |
|     file is being created and first character of the mode string is ’u’ , then by the time the file has been
 | |
|     closed, it shall have the system default file access permissions.<a href='#FOOTNOTE.474'><sup>[474]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.474'>
 | |
| <pre><i><b>Footnote 474)</b> These are the same permissions that the file would have been created with by fopen.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.2.1p8'></a>
 | |
| <pre>8   If the file was opened successfully, then the pointer to FILE pointed to by streamptr will be set to
 | |
|     the pointer to the object controlling the opened file. Otherwise, the pointer to FILE pointed to by
 | |
|     streamptr will be set to a null pointer.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.2.1p9'></a>
 | |
| <pre>9   The fopen_s function returns zero if it opened the file. If it did not open the file or if there was a
 | |
|     runtime-constraint violation, fopen_s returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.2.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.2.2 [The freopen_s function]</h3>
 | |
| <a name='K.3.5.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #define __STDC_WANT_LIB_EXT1__ 1
 | |
|              #include <stdio.h>
 | |
|              errno_t freopen_s(FILE * restrict * restrict newstreamptr,
 | |
|                    const char * restrict filename, const char * restrict mode,
 | |
|                    FILE * restrict stream);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.2.2p2'></a>
 | |
| <pre>2   None of newstreamptr, mode, and stream shall be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.2.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, freopen_s neither attempts to close any file associated with
 | |
|     stream nor attempts to open a file. Furthermore, if newstreamptr is not a null pointer, fopen_s
 | |
|     sets *newstreamptr to the null pointer.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.2.2p4'></a>
 | |
| <pre>4   The freopen_s function opens the file whose name is the string pointed to by filename and
 | |
|     associates the stream pointed to by stream with it. The mode argument has the same meaning as in
 | |
|     the fopen_s function (including the mode’s effect on exclusive access and file permissions).
 | |
| </pre>
 | |
| <a name='K.3.5.2.2p5'></a>
 | |
| <pre>5   If filename is a null pointer, the freopen_s function attempts to change the mode of the stream
 | |
|     to that specified by mode, as if the name of the file currently associated with the stream had been
 | |
|     used. It is implementation-defined which changes of mode are permitted (if any), and under what
 | |
|     circumstances.
 | |
| </pre>
 | |
| <a name='K.3.5.2.2p6'></a>
 | |
| <pre>6   The freopen_s function first attempts to close any file that is associated with stream. Failure to
 | |
|     close the file is ignored. The error and end-of-file indicators for the stream are cleared.
 | |
| </pre>
 | |
| <a name='K.3.5.2.2p7'></a>
 | |
| <pre>7   If the file was opened successfully, then the pointer to FILE pointed to by newstreamptr will be set
 | |
|     to the value of stream. Otherwise, the pointer to FILE pointed to by newstreamptr will be set to a
 | |
|     null pointer.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.2.2p8'></a>
 | |
| <pre>8   The freopen_s function returns zero if it opened the file. If it did not open the file or there was a
 | |
|     runtime-constraint violation, freopen_s returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3 [Formatted input/output functions]</h3>
 | |
| <a name='K.3.5.3p1'></a>
 | |
| <pre>1   Unless explicitly stated otherwise, if the execution of a function described in this subclause causes
 | |
|     copying to take place between objects that overlap, the objects take on unspecified values.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.1 [The fprintf_s function]</h3>
 | |
| <a name='K.3.5.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               int fprintf_s(FILE * restrict stream, const char * restrict format, ...);
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.1p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. The %n specifier<a href='#FOOTNOTE.475'><sup>[475]</sup></a> (modified or not by flags,
 | |
|     field width, or precision) shall not appear in the string pointed to by format. Any argument to
 | |
|     fprintf_s corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.475'>
 | |
| <pre><i><b>Footnote 475)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the<a href='#FOOTNOTE.476'><sup>[476]</sup></a> fprintf_s function does not attempt to produce
 | |
|     further output, and it is unspecified to what extent fprintf_s produced output before discovering
 | |
|     the runtime-constraint violation.
 | |
|     Description
 | |
| </pre>
 | |
| <a name='FOOTNOTE.476'>
 | |
| <pre><i><b>Footnote 476)</b> Because an implementation can treat any undefined behavior as a runtime-constraint violation, an implementation can
 | |
|     treat any unsupported specifiers in the string pointed to by format as a runtime-constraint violation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.1p4'></a>
 | |
| <pre>4   The fprintf_s function is equivalent to the fprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.1p5'></a>
 | |
| <pre>5   The fprintf_s function returns the number of characters transmitted, or a negative value if an
 | |
|     output error, encoding error, or runtime-constraint violation occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.2 [The fscanf_s function]</h3>
 | |
| <a name='K.3.5.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               int fscanf_s(FILE * restrict stream, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.2p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. Any argument indirected though in order to
 | |
|     store converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.3.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the<a href='#FOOTNOTE.477'><sup>[477]</sup></a> fscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent fscanf_s performed input before discovering the
 | |
|     runtime-constraint violation.
 | |
|     Description
 | |
| </pre>
 | |
| <a name='FOOTNOTE.477'>
 | |
| <pre><i><b>Footnote 477)</b> Because an implementation can treat any undefined behavior as a runtime-constraint violation, an implementation can
 | |
|     treat any unsupported specifiers in the string pointed to by format as a runtime-constraint violation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.2p4'></a>
 | |
| <pre>4   The fscanf_s function is equivalent to fscanf except that the c, s, and [ conversion specifiers
 | |
|     apply to a pair of arguments (unless assignment suppression is indicated by a *). The first of these
 | |
|     arguments is the same as for fscanf. That argument is immediately followed in the argument list
 | |
|     by the second argument, which has type rsize_t and gives the number of elements in the array
 | |
|     pointed to by the first argument of the pair. If the first argument points to a scalar object, it is
 | |
|     considered to be an array of one element.<a href='#FOOTNOTE.478'><sup>[478]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.478'>
 | |
| <pre><i><b>Footnote 478)</b> If the format is known at translation time, an implementation can issue a diagnostic for any argument used to store
 | |
|     the result from a c, s, or [ conversion specifier if that argument is not followed by an argument of a type compatible with
 | |
|     rsize_t. A limited amount of checking can be done if even if the format is not known at translation time. For example, an
 | |
|     implementation could issue a diagnostic for each argument after format that has of type pointer to one of char, signed char,
 | |
|     unsigned char, or void that is not followed by an argument of a type compatible with rsize_t. The diagnostic could warn
 | |
|     that unless the pointer is being used with a conversion specifier using the hh length modifier, a length argument is expected
 | |
|     to follow the pointer argument. Another useful diagnostic could flag any non-pointer argument following format that did
 | |
|     not have a type compatible with rsize_t.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.2p5'></a>
 | |
| <pre>5   A matching failure occurs if the number of elements in a receiving object is insufficient to hold the
 | |
|     converted input (including any trailing null character).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.2p6'></a>
 | |
| <pre>6   The fscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the fscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| </pre>
 | |
| <a name='K.3.5.3.2p7'></a>
 | |
| <pre>7   EXAMPLE 1 The call:
 | |
| 
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               /* ... */
 | |
|               int n, i; float x; char name[50];
 | |
|               n = fscanf_s(stdin, "%d%f%s", &i, &x, name, (rsize_t) 50);
 | |
| 
 | |
| 
 | |
|     with the input line:
 | |
| 
 | |
|              25 54.32E-1 thompson
 | |
| 
 | |
| 
 | |
|     will assign to n the value 3, to i the value 25, to x the value 5.432, and to name the sequence thompson\0.
 | |
| </pre>
 | |
| <a name='K.3.5.3.2p8'></a>
 | |
| <pre>8   EXAMPLE 2 The call:
 | |
| 
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               /* ... */
 | |
|               int n; char s[5];
 | |
|               n = fscanf_s(stdin, "%s", s, sizeof s);
 | |
| 
 | |
| 
 | |
|     with the input line:
 | |
| 
 | |
|              hello
 | |
| 
 | |
| 
 | |
|     will assign to n the value 0 since a matching failure occurred because the sequence hello\0 requires an array of six characters
 | |
|     to store it.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.3 [The printf_s function]</h3>
 | |
| <a name='K.3.5.3.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               int printf_s(const char * restrict format, ...);
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.3p2'></a>
 | |
| <pre>2   format shall not be a null pointer. The %n specifier<a href='#FOOTNOTE.479'><sup>[479]</sup></a> (modified or not by flags, field width,
 | |
|     or precision) shall not appear in the string pointed to by format. Any argument to printf_s
 | |
|     corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.479'>
 | |
| <pre><i><b>Footnote 479)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.3p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the printf_s function does not attempt to produce further
 | |
|     output, and it is unspecified to what extent printf_s produced output before discovering the
 | |
|     runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.3p4'></a>
 | |
| <pre>4   The printf_s function is equivalent to the printf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.3p5'></a>
 | |
| <pre>5   The printf_s function returns the number of characters transmitted, or a negative value if an
 | |
|     output error, encoding error, or runtime-constraint violation occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.4 [The scanf_s function]</h3>
 | |
| <a name='K.3.5.3.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               int scanf_s(const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.4p2'></a>
 | |
| <pre>2   format shall not be a null pointer. Any argument indirected though in order to store converted
 | |
|     input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.3.4p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the scanf_s function does not attempt to perform further
 | |
|     input, and it is unspecified to what extent scanf_s performed input before discovering the runtime-
 | |
|     constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.4p4'></a>
 | |
| <pre>4   The scanf_s function is equivalent to fscanf_s with the argument stdin interposed before the
 | |
|     arguments to scanf_s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.4p5'></a>
 | |
| <pre>5   The scanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the scanf_s function returns the
 | |
|     number of input items assigned, which can be fewer than provided for, or even zero, in the event of
 | |
|     an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.5'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.5 [The snprintf_s function]</h3>
 | |
| <a name='K.3.5.3.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               int snprintf_s(char * restrict s, rsize_t n, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.5p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than RSIZE_MAX.
 | |
|     The %n specifier<a href='#FOOTNOTE.480'><sup>[480]</sup></a> (modified or not by flags, field width, or precision) shall not appear in the string
 | |
|     pointed to by format. Any argument to snprintf_s corresponding to a %s specifier shall not be a
 | |
|     null pointer. No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.480'>
 | |
| <pre><i><b>Footnote 480)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.5p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero and
 | |
|     not greater than RSIZE_MAX, then the snprintf_s function sets s[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.5p4'></a>
 | |
| <pre>4   The snprintf_s function is equivalent to the snprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.5.3.5p5'></a>
 | |
| <pre>5   The snprintf_s function, unlike sprintf_s, will truncate the result to fit within the array pointed
 | |
|     to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.5p6'></a>
 | |
| <pre>6   The snprintf_s function returns the number of characters that would have been written had n
 | |
|     been sufficiently large, not counting the terminating null character, or a negative value if a runtime-
 | |
|     constraint violation occurred. Thus, the null-terminated output has been completely written if and
 | |
|     only if the returned value is both nonnegative and less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.6'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.6 [The sprintf_s function]</h3>
 | |
| <a name='K.3.5.3.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               int sprintf_s(char * restrict s, rsize_t n, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.6p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than RSIZE_MAX.
 | |
|     The number of characters (including the trailing null) required for the result to be written to the
 | |
|     array pointed to by s shall not be greater than n. The %n specifier<a href='#FOOTNOTE.481'><sup>[481]</sup></a> (modified or not by flags,
 | |
|     field width, or precision) shall not appear in the string pointed to by format. Any argument to
 | |
|     sprintf_s corresponding to a %s specifier shall not be a null pointer. No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.481'>
 | |
| <pre><i><b>Footnote 481)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.6p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero and
 | |
|     not greater than RSIZE_MAX, then the sprintf_s function sets s[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.6p4'></a>
 | |
| <pre>4   The sprintf_s function is equivalent to the sprintf function except for the parameter n and the
 | |
|     explicit runtime-constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.5.3.6p5'></a>
 | |
| <pre>5   The sprintf_s function, unlike snprintf_s, treats a result too big for the array pointed to by s as a
 | |
|     runtime-constraint violation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.6p6'></a>
 | |
| <pre>6   If no runtime-constraint violation occurred, the sprintf_s function returns the number of characters
 | |
|     written in the array, not counting the terminating null character. If an encoding error occurred,
 | |
|     sprintf_s returns a negative value. If any other runtime-constraint violation occurred, sprintf_s
 | |
|     returns zero.
 | |
| </pre>
 | |
| <a name='K.3.5.3.7'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.7 [The sscanf_s function]</h3>
 | |
| <a name='K.3.5.3.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               int sscanf_s(const char * restrict s, const char * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.7p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. Any argument indirected though in order to store
 | |
|     converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.3.7p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the sscanf_s function does not attempt to perform further
 | |
|     input, and it is unspecified to what extent sscanf_s performed input before discovering the runtime-
 | |
|     constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.7p4'></a>
 | |
| <pre>4   The sscanf_s function is equivalent to fscanf_s, except that input is obtained from a string
 | |
|     (specified by the argument s) rather than from a stream. Reaching the end of the string is equivalent
 | |
|     to encountering end-of-file for the fscanf_s function. If copying takes place between objects that
 | |
|     overlap, the objects take on unspecified values.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.7p5'></a>
 | |
| <pre>5   The sscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the sscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.8'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.8 [The vfprintf_s function]</h3>
 | |
| <a name='K.3.5.3.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vfprintf_s(FILE *restrict stream, const char *restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.8p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. The %n specifier<a href='#FOOTNOTE.482'><sup>[482]</sup></a> (modified or not by flags,
 | |
|     field width, or precision) shall not appear in the string pointed to by format. Any argument to
 | |
|     vfprintf_s corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.482'>
 | |
| <pre><i><b>Footnote 482)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.8p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vfprintf_s function does not attempt to produce
 | |
|     further output, and it is unspecified to what extent vfprintf_s produced output before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.8p4'></a>
 | |
| <pre>4   The vfprintf_s function is equivalent to the vfprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.8p5'></a>
 | |
| <pre>5   The vfprintf_s function returns the number of characters transmitted, or a negative value if an
 | |
|     output error, encoding error, or runtime-constraint violation occurred.
 | |
| </pre>
 | |
| <a name='K.3.5.3.9'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.9 [The vfscanf_s function]</h3>
 | |
| <a name='K.3.5.3.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vfscanf_s(FILE *restrict stream, const char *restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.9p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. Any argument indirected though in order to
 | |
|     store converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.3.9p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vfscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent vfscanf_s performed input before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.9p4'></a>
 | |
| <pre>4   The vfscanf_s function is equivalent to fscanf_s, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vfscanf_s function does not invoke the va_end macro.<a href='#FOOTNOTE.483'><sup>[483]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.483'>
 | |
| <pre><i><b>Footnote 483)</b> As the functions vfprintf_s , vfscanf_s , vprintf_s , vscanf_s , vsnprintf_s , vsprintf_s , and vsscanf_s invoke
 | |
|     the va_arg macro, the representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.9p5'></a>
 | |
| <pre>5   The vfscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the vfscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.10'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.10 [The vprintf_s function]</h3>
 | |
| <a name='K.3.5.3.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vprintf_s(const char * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.10p2'></a>
 | |
| <pre>2   format shall not be a null pointer. The %n specifier<a href='#FOOTNOTE.484'><sup>[484]</sup></a> (modified or not by flags, field width,
 | |
|     or precision) shall not appear in the string pointed to by format. Any argument to vprintf_s
 | |
|     corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.484'>
 | |
| <pre><i><b>Footnote 484)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.10p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vprintf_s function does not attempt to produce
 | |
|     further output, and it is unspecified to what extent vprintf_s produced output before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.10p4'></a>
 | |
| <pre>4   The vprintf_s function is equivalent to the vprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.10p5'></a>
 | |
| <pre>5   The vprintf_s function returns the number of characters transmitted, or a negative value if an
 | |
|     output error, encoding error, or runtime-constraint violation occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.11'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.11 [The vscanf_s function]</h3>
 | |
| <a name='K.3.5.3.11p1'></a>
 | |
| <pre>1     Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vscanf_s(const char * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.11p2'></a>
 | |
| <pre>2   format shall not be a null pointer. Any argument indirected though in order to store converted
 | |
|     input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.3.11p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vscanf_s function does not attempt to perform further
 | |
|     input, and it is unspecified to what extent vscanf_s performed input before discovering the runtime-
 | |
|     constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.11p4'></a>
 | |
| <pre>4   The vscanf_s function is equivalent to scanf_s, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vscanf_s function does not invoke the va_end macro<a href='#FOOTNOTE.485'><sup>[485]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.485'>
 | |
| <pre><i><b>Footnote 485)</b> As the functions vfprintf_s , vfscanf_s , vprintf_s , vscanf_s , vsnprintf_s , vsprintf_s , and vsscanf_s invoke
 | |
|     the va_arg macro, the representation of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.11p5'></a>
 | |
| <pre>5   The vscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the vscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.12'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.12 [The vsnprintf_s function]</h3>
 | |
| <a name='K.3.5.3.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vsnprintf_s(char *restrict s, rsize_t n, const char *restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.12p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than RSIZE_MAX.
 | |
|     The %n specifier<a href='#FOOTNOTE.486'><sup>[486]</sup></a> (modified or not by flags, field width, or precision) shall not appear in the string
 | |
|     pointed to by format. Any argument to vsnprintf_s corresponding to a %s specifier shall not be a
 | |
|     null pointer. No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.486'>
 | |
| <pre><i><b>Footnote 486)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.12p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero and
 | |
|     not greater than RSIZE_MAX, then the vsnprintf_s function sets s[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.12p4'></a>
 | |
| <pre>4   The vsnprintf_s function is equivalent to the vsnprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.5.3.12p5'></a>
 | |
| <pre>5   The vsnprintf_s function, unlike vsprintf_s, will truncate the result to fit within the array pointed
 | |
|     to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.12p6'></a>
 | |
| <pre>6   The vsnprintf_s function returns the number of characters that would have been written had n
 | |
|     been sufficiently large, not counting the terminating null character, or a negative value if a runtime-
 | |
|     constraint violation occurred. Thus, the null-terminated output has been completely written if and
 | |
|     only if the returned value is both nonnegative and less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.13'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.13 [The vsprintf_s function]</h3>
 | |
| <a name='K.3.5.3.13p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vsprintf_s(char * restrict s, rsize_t n, const char * restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.13p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than RSIZE_MAX.
 | |
|     The number of characters (including the trailing null) required for the result to be written to the array
 | |
|     pointed to by s shall not be greater than n. The %n specifier<a href='#FOOTNOTE.487'><sup>[487]</sup></a> (modified or not by flags, field width,
 | |
|     or precision) shall not appear in the string pointed to by format. Any argument to vsprintf_s
 | |
|     corresponding to a %s specifier shall not be a null pointer. No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.487'>
 | |
| <pre><i><b>Footnote 487)</b> It is not a runtime-constraint violation for the characters %n to appear in sequence in the string pointed at by format
 | |
|     when those characters are not a interpreted as a %n specifier. For example, if the entire format string was %%n.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.13p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero and
 | |
|     not greater than RSIZE_MAX, then the vsprintf_s function sets s[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.13p4'></a>
 | |
| <pre>4   The vsprintf_s function is equivalent to the vsprintf function except for the parameter n and the
 | |
|     explicit runtime-constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.5.3.13p5'></a>
 | |
| <pre>5   The vsprintf_s function, unlike vsnprintf_s, treats a result too big for the array pointed to by s
 | |
|     as a runtime-constraint violation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.3.13p6'></a>
 | |
| <pre>6   If no runtime-constraint violation occurred, the vsprintf_s function returns the number of char-
 | |
|     acters written in the array, not counting the terminating null character. If an encoding error oc-
 | |
|     curred, vsprintf_s returns a negative value. If any other runtime-constraint violation occurred,
 | |
|     vsprintf_s returns zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.3.14'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.3.14 [The vsscanf_s function]</h3>
 | |
| <a name='K.3.5.3.14p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               int vsscanf_s(const char *restrict s, const char *restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.3.14p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. Any argument indirected though in order to store
 | |
|     converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.5.3.14p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vsscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent vsscanf_s performed input before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.3.14p4'></a>
 | |
| <pre>4   The vsscanf_s function is equivalent to sscanf_s, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vsscanf_s function does not invoke the va_end macro.<a href='#FOOTNOTE.488'><sup>[488]</sup></a>
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.488'>
 | |
| <pre><i><b>Footnote 488)</b> As the functions vfprintf_s , vfscanf_s , vprintf_s , vscanf_s , vsnprintf_s , vsprintf_s , and vsscanf_s invoke
 | |
|     the va_arg macro, the value of arg after the return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.3.14p5'></a>
 | |
| <pre>5   The vsscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the vscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.5.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.4 [Character input/output functions]</h3>
 | |
| <a name='K.3.5.4.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.5.4.1 [The gets_s function]</h3>
 | |
| <a name='K.3.5.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               char *gets_s(char *s, rsize_t n);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.5.4.1p2'></a>
 | |
| <pre>2   s shall not be a null pointer. n shall neither be equal to zero nor be greater than RSIZE_MAX. A new-
 | |
|     line character, end-of-file, or read error shall occur within reading n-1 characters from stdin.<a href='#FOOTNOTE.489'><sup>[489]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.489'>
 | |
| <pre><i><b>Footnote 489)</b> The gets_s function, unlike the historical gets function, makes it a runtime-constraint violation for a line of input to
 | |
|     overflow the buffer to store it. Unlike the fgets function, gets_s maintains a one-to-one relationship between input lines
 | |
|     and successful calls to gets_s. Programs that use gets expect such a relationship.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.5.4.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, characters are read and discarded from stdin until a
 | |
|     new-line character is read, or end-of-file or a read error occurs, and if s is not a null pointer, s[0] is
 | |
|     set to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.5.4.1p4'></a>
 | |
| <pre>4   The gets_s function reads at most one less than the number of characters specified by n from the
 | |
|     stream pointed to by stdin, into the array pointed to by s. No additional characters are read after a
 | |
|     new-line character (which is discarded) or after end-of-file. The discarded new-line character does
 | |
|     not count towards number of characters read. A null character is written immediately after the last
 | |
|     character read into the array.
 | |
| </pre>
 | |
| <a name='K.3.5.4.1p5'></a>
 | |
| <pre>5   If end-of-file is encountered and no characters have been read into the array, or if a read error
 | |
|     occurs during the operation, then s[0] is set to the null character, and the other elements of s take
 | |
|     unspecified values.
 | |
| 
 | |
|     Recommended practice
 | |
| </pre>
 | |
| <a name='K.3.5.4.1p6'></a>
 | |
| <pre>6   The fgets function allows properly-written programs to safely process input lines too long to store
 | |
|     in the result array. In general this requires that callers of fgets pay attention to the presence or
 | |
|     absence of a new-line character in the result array. Consider using fgets (along with any needed
 | |
|     processing based on new-line characters) instead of gets_s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.5.4.1p7'></a>
 | |
| <pre>7   The gets_s function returns s if successful. If there was a runtime-constraint violation, or if end-of-
 | |
|     file is encountered and no characters have been read into the array, or if a read error occurs during
 | |
|     the operation, then a null pointer is returned.
 | |
| </pre>
 | |
| <a name='K.3.6'></a>
 | |
| <hr>
 | |
| <h3>K.3.6 [General utilities <stdlib.h>]</h3>
 | |
| <a name='K.3.6p1'></a>
 | |
| <pre>1   The header <stdlib.h> defines three types.
 | |
| </pre>
 | |
| <a name='K.3.6p2'></a>
 | |
| <pre>2   The types are
 | |
| 
 | |
|               errno_t
 | |
| 
 | |
| 
 | |
|     which is type int; and
 | |
| 
 | |
|               rsize_t
 | |
| 
 | |
| 
 | |
|     which is the type size_t; and
 | |
| 
 | |
|               constraint_handler_t
 | |
| 
 | |
| 
 | |
|     which has the following definition
 | |
| 
 | |
|               typedef void (*constraint_handler_t)(
 | |
|                     const char * restrict msg,
 | |
|                     void * restrict ptr,
 | |
|                     errno_t error);
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.1 [Runtime-constraint handling]</h3>
 | |
| <a name='K.3.6.1.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.1.1 [The set_constraint_handler_s function]</h3>
 | |
| <a name='K.3.6.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdlib.h>
 | |
|               constraint_handler_t set_constraint_handler_s(constraint_handler_t handler);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.1.1p2'></a>
 | |
| <pre>2   The set_constraint_handler_s function sets the runtime-constraint handler to be handler. The
 | |
|     runtime-constraint handler is the function to be called when a library function detects a runtime-
 | |
|     constraint violation. Only the most recent handler registered with set_constraint_handler_s is
 | |
|     called when a runtime-constraint violation occurs.
 | |
| </pre>
 | |
| <a name='K.3.6.1.1p3'></a>
 | |
| <pre>3   When the handler is called, it is passed the following arguments in the following order:
 | |
| 
 | |
|        1. A pointer to a character string describing the runtime-constraint violation.
 | |
|        2. A null pointer or a pointer to an implementation-defined object.
 | |
|        3. If the function calling the handler has a return type declared as errno_t, the return value of
 | |
|           the function is passed. Otherwise, a positive value of type errno_t is passed.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.1.1p4'></a>
 | |
| <pre>4   The implementation has a default constraint handler that is used if no calls to the
 | |
|     set_constraint_handler_s function have been made. The behavior of the default handler is
 | |
|     implementation-defined, and it may cause the program to exit or abort.
 | |
| </pre>
 | |
| <a name='K.3.6.1.1p5'></a>
 | |
| <pre>5   If the handler argument to set_constraint_handler_s is a null pointer, the implementation
 | |
|     default handler becomes the current constraint handler.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.6.1.1p6'></a>
 | |
| <pre>6   The set_constraint_handler_s function returns a pointer to the previously registered handler.<a href='#FOOTNOTE.490'><sup>[490]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.490'>
 | |
| <pre><i><b>Footnote 490)</b> If the previous handler was registered by calling set_constraint_handler_s with a null pointer argument, a pointer to
 | |
|     the implementation default handler is returned (not NULL).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.1.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.1.2 [The abort_handler_s function]</h3>
 | |
| <a name='K.3.6.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdlib.h>
 | |
|               void abort_handler_s(const char * restrict msg, void * restrict ptr,
 | |
|                     errno_t error);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.1.2p2'></a>
 | |
| <pre>2   A pointer to the abort_handler_s function shall be a suitable argument to the
 | |
|     set_constraint_handler_s function.
 | |
| </pre>
 | |
| <a name='K.3.6.1.2p3'></a>
 | |
| <pre>3   The abort_handler_s function writes a message on the standard error stream in an implementation-
 | |
|     defined format. The message shall include the string pointed to by msg. The abort_handler_s
 | |
|     function then calls the abort function.<a href='#FOOTNOTE.491'><sup>[491]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.491'>
 | |
| <pre><i><b>Footnote 491)</b> Many implementations invoke a debugger when the abort function is called.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.1.2p4'></a>
 | |
| <pre>4   The abort_handler_s function does not return to its caller.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.1.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.1.3 [The ignore_handler_s function]</h3>
 | |
| <a name='K.3.6.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdlib.h>
 | |
|               void ignore_handler_s(const char * restrict msg, void * restrict ptr,
 | |
|                     errno_t error);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.1.3p2'></a>
 | |
| <pre>2   A pointer to the ignore_handler_s function shall be a suitable argument to the
 | |
|     set_constraint_handler_s function.
 | |
| </pre>
 | |
| <a name='K.3.6.1.3p3'></a>
 | |
| <pre>3   The ignore_handler_s function simply returns to its caller.<a href='#FOOTNOTE.492'><sup>[492]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.492'>
 | |
| <pre><i><b>Footnote 492)</b> If the runtime-constraint handler is set to the ignore_handler_s function, any library function in which a runtime-
 | |
|     constraint violation occurs will return to its caller. The caller can determine whether a runtime-constraint violation occurred
 | |
|     based on the library function’s specification (usually, the library function returns a nonzero errno_t).
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.1.3p4'></a>
 | |
| <pre>4   The ignore_handler_s function returns no value.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.2 [Communication with the environment]</h3>
 | |
| <a name='K.3.6.2.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.2.1 [The getenv_s function]</h3>
 | |
| <a name='K.3.6.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdlib.h>
 | |
|               errno_t getenv_s(size_t * restrict len, char * restrict value, rsize_t maxsize,
 | |
|                     const char * restrict name);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.6.2.1p2'></a>
 | |
| <pre>2   name shall not be a null pointer. maxsize shall not be greater than RSIZE_MAX. If maxsize is not
 | |
|     equal to zero, then value shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.6.2.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the integer pointed to by len is set to 0 (if len is not null),
 | |
|     and the environment list is not searched.
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.2.1p4'></a>
 | |
| <pre>4   The getenv_s function searches an environment list, provided by the host environment, for a string
 | |
|     that matches the string pointed to by name.
 | |
| </pre>
 | |
| <a name='K.3.6.2.1p5'></a>
 | |
| <pre>5   If that name is found then getenv_s performs the following actions. If len is not a null pointer, the
 | |
|     length of the string associated with the matched list member is stored in the integer pointed to by
 | |
|     len. If the length of the associated string is less than maxsize, then the associated string is copied to
 | |
|     the array pointed to by value.
 | |
| </pre>
 | |
| <a name='K.3.6.2.1p6'></a>
 | |
| <pre>6   If that name is not found then getenv_s performs the following actions. If len is not a null pointer,
 | |
|     zero is stored in the integer pointed to by len. If maxsize is greater than zero, then value[0] is set
 | |
|     to the null character.
 | |
| </pre>
 | |
| <a name='K.3.6.2.1p7'></a>
 | |
| <pre>7   The set of environment names and the method for altering the environment list are implementation-
 | |
|     defined. The getenv_s function need not avoid data races with other threads of execution that
 | |
|     modify the environment list.<a href='#FOOTNOTE.493'><sup>[493]</sup></a>
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.493'>
 | |
| <pre><i><b>Footnote 493)</b> Many implementations provide non-standard functions that modify the environment list.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.2.1p8'></a>
 | |
| <pre>8   The getenv_s function returns zero if the specified name is found and the associated string was
 | |
|     successfully stored in value. Otherwise, a nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.3 [Searching and sorting utilities]</h3>
 | |
| <a name='K.3.6.3p1'></a>
 | |
| <pre>1   These utilities make use of a comparison function to search or sort arrays of unspecified type. Where
 | |
|     an argument declared as size_t nmemb specifies the length of the array for a function, if nmemb has
 | |
|     the value zero on a call to that function, then the comparison function is not called, a search finds no
 | |
|     matching element, sorting performs no rearrangement, and the pointer to the array may be null.
 | |
| </pre>
 | |
| <a name='K.3.6.3p2'></a>
 | |
| <pre>2   The implementation shall ensure that the second argument of the comparison function (when called
 | |
|     from bsearch_s), or both arguments (when called from qsort_s), are pointers to elements of the
 | |
|     array.<a href='#FOOTNOTE.494'><sup>[494]</sup></a> The first argument when called from bsearch_s shall equal key.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.494'>
 | |
| <pre><i><b>Footnote 494)</b> That is, if the value passed is p, then the following expressions are always valid and nonzero:
 | |
|              ((char *)p - (char *)base) % size == 0
 | |
|               (char *)p >= (char *)base
 | |
|               (char *)p < (char *)base + nmemb * size
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.3p3'></a>
 | |
| <pre>3   The comparison function shall not alter the contents of either the array or search key. The implemen-
 | |
|     tation may reorder elements of the array between calls to the comparison function, but shall not
 | |
|     otherwise alter the contents of any individual element.
 | |
| </pre>
 | |
| <a name='K.3.6.3p4'></a>
 | |
| <pre>4   When the same objects (consisting of size bytes, irrespective of their current positions in the array)
 | |
|     are passed more than once to the comparison function, the results shall be consistent with one
 | |
|     another. That is, for qsort_s they shall define a total ordering on the array, and for bsearch_s the
 | |
|     same object shall always compare the same way with the key.
 | |
| </pre>
 | |
| <a name='K.3.6.3p5'></a>
 | |
| <pre>5   A sequence point occurs immediately before and immediately after each call to the comparison
 | |
|     function, and also between any call to the comparison function and any movement of the objects
 | |
|     passed as arguments to that call.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.3.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.3.1 [The bsearch_s generic function]</h3>
 | |
| <a name='K.3.6.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #define __STDC_WANT_LIB_EXT1__ 1
 | |
|              #include <stdlib.h>
 | |
|              void *bsearch_s(const void *key, QVoid *base, rsize_t nmemb, rsize_t size,
 | |
|                    int (*compar)(const void *k, const void *y, void *context),
 | |
|                    void *context);
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.6.3.1p2'></a>
 | |
| <pre>2   Neither nmemb nor size shall be greater than RSIZE_MAX. If nmemb is not equal to zero, then none of
 | |
|     key, base, or compar shall be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.6.3.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the bsearch_s function does not search the array.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.3.1p4'></a>
 | |
| <pre>4   The bsearch_s function searches an array of nmemb objects, the initial element of which is pointed
 | |
|     to by base, for an element that matches the object pointed to by key. The size of each element of the
 | |
|     array is specified by size.
 | |
| </pre>
 | |
| <a name='K.3.6.3.1p5'></a>
 | |
| <pre>5   The comparison function pointed to by compar is called with three arguments. The first two point
 | |
|     to the key object and to an array element, in that order. The function shall return an integer less
 | |
|     than, equal to, or greater than zero if the key object is considered, respectively, to be less than,
 | |
|     to match, or to be greater than the array element. The array shall consist of: all the elements
 | |
|     that compare less than, all the elements that compare equal to, and all the elements that compare
 | |
|     greater than the key object, in that order.<a href='#FOOTNOTE.495'><sup>[495]</sup></a> The third argument to the comparison function is the
 | |
|     context argument passed to bsearch_s. The sole use of context by bsearch_s is to pass it to the
 | |
|     comparison function.<a href='#FOOTNOTE.496'><sup>[496]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.495'>
 | |
| <pre><i><b>Footnote 495)</b> In practice, this means that the entire array has been sorted according to the comparison function.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='FOOTNOTE.496'>
 | |
| <pre><i><b>Footnote 496)</b> The context argument is for the use of the comparison function in performing its duties. For example, it might specify a
 | |
|     collating sequence used by the comparison function.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.3.1p6'></a>
 | |
| <pre>6   The bsearch_s function returns a pointer to a matching element of the array, or a null pointer if no
 | |
|     match is found or there is a runtime-constraint violation. If two elements compare as equal, which
 | |
|     element is matched is unspecified.
 | |
| </pre>
 | |
| <a name='K.3.6.3.1p7'></a>
 | |
| <pre>7   The bsearch_s function is generic in the qualification of the type pointed to by the argument to
 | |
|     base. If this argument is a pointer to a const-qualified object type, the returned pointer will be a
 | |
|     pointer to const-qualified void. Otherwise, the argument shall be a pointer to an unqualified object
 | |
|     type or a null pointer constant<a href='#FOOTNOTE.497'><sup>[497]</sup></a> , and the returned pointer will be a pointer to unqualified void.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.497'>
 | |
| <pre><i><b>Footnote 497)</b> If the argument is a null pointer and the call is executed, the behavior is undefined.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.3.1p8'></a>
 | |
| <pre>8   The external declaration of bsearch_s has the concrete type:
 | |
| 
 | |
|               void * (const void *, const void *, rsize_t, rsize_t, int (*) (const void *,
 | |
|                   const void *), void *)
 | |
| 
 | |
| 
 | |
| 
 | |
|     , which supports all correct uses. If a macro definition of the generic function is suppressed in order
 | |
|     to access an actual function, the external declaration with this concrete type is visible<a href='#FOOTNOTE.498'><sup>[498]</sup></a> .
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.498'>
 | |
| <pre><i><b>Footnote 498)</b> This is an obsolescent feature.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.3.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.3.2 [The qsort_s function]</h3>
 | |
| <a name='K.3.6.3.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdlib.h>
 | |
|               errno_t qsort_s(void *base, rsize_t nmemb, rsize_t size,
 | |
|                     int (*compar)(const void *x, const void *y, void *context),
 | |
|                     void *context);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.6.3.2p2'></a>
 | |
| <pre>2   Neither nmemb nor size shall be greater than RSIZE_MAX. If nmemb is not equal to zero, then neither
 | |
|     base nor compar shall be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.6.3.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the qsort_s function does not sort the array.
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.3.2p4'></a>
 | |
| <pre>4   The qsort_s function sorts an array of nmemb objects, the initial element of which is pointed to by
 | |
|     base. The size of each object is specified by size.
 | |
| </pre>
 | |
| <a name='K.3.6.3.2p5'></a>
 | |
| <pre>5   The contents of the array are sorted into ascending order according to a comparison function pointed
 | |
|     to by compar, which is called with three arguments. The first two point to the objects being compared.
 | |
|     The function shall return an integer less than, equal to, or greater than zero if the first argument is
 | |
|     considered to be respectively less than, equal to, or greater than the second. The third argument to
 | |
|     the comparison function is the context argument passed to qsort_s. The sole use of context by
 | |
|     qsort_s is to pass it to the comparison function<a href='#FOOTNOTE.499'><sup>[499]</sup></a> .
 | |
| </pre>
 | |
| <a name='FOOTNOTE.499'>
 | |
| <pre><i><b>Footnote 499)</b> The context argument is for the use of the comparison function in performing its duties. For example, it might specify a
 | |
|     collating sequence used by the comparison function.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.3.2p6'></a>
 | |
| <pre>6   If two elements compare as equal, their relative order in the resulting sorted array is unspecified.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.6.3.2p7'></a>
 | |
| <pre>7   The qsort_s function returns zero if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.4 [Multibyte/wide character conversion functions]</h3>
 | |
| <a name='K.3.6.4p1'></a>
 | |
| <pre>1   The behavior of the multibyte character functions is affected by the LC_CTYPE category of the current
 | |
|     locale. For a state-dependent encoding, each function is placed into its initial conversion state by a
 | |
|     call for which its character pointer argument, s, is a null pointer. Subsequent calls with s as other
 | |
|     than a null pointer cause the internal conversion state of the function to be altered as necessary. A
 | |
|     call with s as a null pointer causes these functions to set the int pointed to by their status argument
 | |
|     to a nonzero value if encodings have state dependency, and zero otherwise. <a href='#FOOTNOTE.500'><sup>[500]</sup></a>
 | |
|     Changing the LC_CTYPE category causes the internal object describing the conversion state of these
 | |
|     functions to have an indeterminate representation.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.500'>
 | |
| <pre><i><b>Footnote 500)</b> If the locale employs special bytes to change the shift state, these bytes do not produce separate wide character codes, but
 | |
|     are grouped with an adjacent multibyte character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.4.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.4.1 [The wctomb_s function]</h3>
 | |
| <a name='K.3.6.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdlib.h>
 | |
|               errno_t wctomb_s(int *restrict status, char *restrict s, rsize_t smax,
 | |
|                     wchar_t wc);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p2'></a>
 | |
| <pre>2   Let n denote the number of bytes needed to represent the multibyte character corresponding to the
 | |
|     wide character given by wc (including any shift sequences).
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p3'></a>
 | |
| <pre>3   If s is not a null pointer, then smax shall not be less than n, and smax shall not be greater than
 | |
|     RSIZE_MAX. If s is a null pointer, then smax shall equal zero.
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p4'></a>
 | |
| <pre>4   If there is a runtime-constraint violation, wctomb_s does not modify the int pointed to by status,
 | |
|     and if s is not a null pointer, no more than smax elements in the array pointed to by s will be
 | |
|     accessed.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p5'></a>
 | |
| <pre>5   The wctomb_s function determines n and stores the multibyte character representation of wc in the
 | |
|     array whose first element is pointed to by s (if s is not a null pointer). The number of characters
 | |
|     stored never exceeds MB_CUR_MAX or smax. If wc is a null wide character, a null byte is stored,
 | |
|     preceded by any shift sequence needed to restore the initial shift state, and the function is left in the
 | |
|     initial conversion state.
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p6'></a>
 | |
| <pre>6   The implementation shall behave as if no library function calls the wctomb_s function.
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p7'></a>
 | |
| <pre>7   If s is a null pointer, the wctomb_s function stores into the int pointed to by status a nonzero or zero
 | |
|      value, if multibyte character encodings, respectively, do or do not have state-dependent encodings.
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p8'></a>
 | |
| <pre>8    If s is not a null pointer, the wctomb_s function stores into the int pointed to by status either n or
 | |
|      −1 if wc, respectively, does or does not correspond to a valid multibyte character.
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p9'></a>
 | |
| <pre>9    In no case will the int pointed to by status be set to a value greater than the MB_CUR_MAX macro.
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='K.3.6.4.1p10'></a>
 | |
| <pre>10   The wctomb_s function returns zero if successful, and a nonzero value if there was a runtime-
 | |
|      constraint violation or wc did not correspond to a valid multibyte character.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.5'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.5 [Multibyte/wide string conversion functions]</h3>
 | |
| <a name='K.3.6.5p1'></a>
 | |
| <pre>1    The behavior of the multibyte string functions is affected by the LC_CTYPE category of the current
 | |
|      locale.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.5.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.5.1 [The mbstowcs_s function]</h3>
 | |
| <a name='K.3.6.5.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #include <stdlib.h>
 | |
|                errno_t mbstowcs_s(size_t *restrict retval, wchar_t *restrict dst,
 | |
|                      rsize_t dstmax, const char * restrict src, rsize_t len);
 | |
| 
 | |
| 
 | |
| 
 | |
|      Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.6.5.1p2'></a>
 | |
| <pre>2    Neither retval nor src shall be a null pointer. If dst is not a null pointer, then neither len nor
 | |
|      dstmax shall be greater than RSIZE_MAX/sizeof(wchar_t). If dst is a null pointer, then dstmax
 | |
|      shall equal zero. If dst is not a null pointer, then dstmax shall not equal zero. If dst is not a null
 | |
|      pointer and len is not less than dstmax, then a null character shall occur within the first dstmax
 | |
|      multibyte characters of the array pointed to by src.
 | |
| </pre>
 | |
| <a name='K.3.6.5.1p3'></a>
 | |
| <pre>3    If there is a runtime-constraint violation, then mbstowcs_s does the following. If retval is not
 | |
|      a null pointer, then mbstowcs_s sets *retval to (size_t)(-1) . If dst is not a null pointer and
 | |
|      dstmax is greater than zero and not greater than RSIZE_MAX/sizeof(wchar_t), then mbstowcs_s
 | |
|      sets dst[0] to the null wide character.
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='K.3.6.5.1p4'></a>
 | |
| <pre>4    The mbstowcs_s function converts a sequence of multibyte characters that begins in the initial shift
 | |
|      state from the array pointed to by src into a sequence of corresponding wide characters. If dst is
 | |
|      not a null pointer, the converted characters are stored into the array pointed to by dst. Conversion
 | |
|      continues up to and including a terminating null character, which is also stored. Conversion stops
 | |
|      earlier in two cases: when a sequence of bytes is encountered that does not form a valid multibyte
 | |
|      character, or (if dst is not a null pointer) when len wide characters have been stored into the array
 | |
|      pointed to by dst.<a href='#FOOTNOTE.501'><sup>[501]</sup></a> If dst is not a null pointer and no null wide character was stored into the
 | |
|      array pointed to by dst, then dst[len] is set to the null wide character. Each conversion takes place
 | |
|      as if by a call to the mbrtowc function.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.501'>
 | |
| <pre><i><b>Footnote 501)</b> Thus, the value of len is ignored if dst is a null pointer.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.5.1p5'></a>
 | |
| <pre>5    Regardless of whether dst is or is not a null pointer, if the input conversion encounters a sequence of
 | |
|      bytes that do not form a valid multibyte character, an encoding error occurs: the mbstowcs_s func-
 | |
|      tion stores the value (size_t)(-1) into *retval . Otherwise, the mbstowcs_s function stores into
 | |
|      *retval the number of multibyte characters successfully converted, not including the terminating
 | |
|      null character (if any).
 | |
| </pre>
 | |
| <a name='K.3.6.5.1p6'></a>
 | |
| <pre>6    All elements following the terminating null wide character (if any) written by mbstowcs_s in the
 | |
|      array of dstmax wide characters pointed to by dst take unspecified values when mbstowcs_s
 | |
|      returns.<a href='#FOOTNOTE.502'><sup>[502]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.502'>
 | |
| <pre><i><b>Footnote 502)</b> This allows an implementation to attempt converting the multibyte string before discovering a terminating null character
 | |
|      did not occur where required.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.5.1p7'></a>
 | |
| <pre>7    If copying takes place between objects that overlap, the objects take on unspecified values.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.6.5.1p8'></a>
 | |
| <pre>8   The mbstowcs_s function returns zero if no runtime-constraint violation and no encoding error
 | |
|     occurred. Otherwise, a nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.6.5.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.6.5.2 [The wcstombs_s function]</h3>
 | |
| <a name='K.3.6.5.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <stdlib.h>
 | |
|               errno_t wcstombs_s(size_t * restrict retval, char * restrict dst, rsize_t dstmax,
 | |
|                     const wchar_t * restrict src, rsize_t len);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.6.5.2p2'></a>
 | |
| <pre>2   Neither retval nor src shall be a null pointer. If dst is not a null pointer, then len shall not
 | |
|     be greater than RSIZE_MAX/sizeof(wchar_t) and dstmax shall be nonzero and not greater than
 | |
|     RSIZE_MAX. If dst is a null pointer, then dstmax shall equal zero. If dst is not a null pointer and
 | |
|     len is not less than dstmax, then the conversion shall have been stopped (see below) because a
 | |
|     terminating null wide character was reached or because an encoding error occurred.
 | |
| </pre>
 | |
| <a name='K.3.6.5.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then wcstombs_s does the following. If retval is not
 | |
|     a null pointer, then wcstombs_s sets *retval to (size_t)(-1) . If dst is not a null pointer and
 | |
|     dstmax is greater than zero and not greater than RSIZE_MAX, then wcstombs_s sets dst[0] to the
 | |
|     null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.6.5.2p4'></a>
 | |
| <pre>4   The wcstombs_s function converts a sequence of wide characters from the array pointed to by
 | |
|     src into a sequence of corresponding multibyte characters that begins in the initial shift state. If
 | |
|     dst is not a null pointer, the converted characters are then stored into the array pointed to by dst.
 | |
|     Conversion continues up to and including a terminating null wide character, which is also stored.
 | |
|     Conversion stops earlier in two cases:
 | |
| 
 | |
|       — when a wide character is reached that does not correspond to a valid multibyte character;
 | |
|       — (if dst is not a null pointer) when the next multibyte character would exceed the limit of n
 | |
|         total bytes to be stored into the array pointed to by dst. If the wide character being converted
 | |
|         is the null wide character, then n is the lesser of len or dstmax. Otherwise, n is the lesser of
 | |
|         len or dstmax-1.
 | |
| 
 | |
|     If the conversion stops without converting a null wide character and dst is not a null pointer, then
 | |
|     a null character is stored into the array pointed to by dst immediately following any multibyte
 | |
|     characters already stored. Each conversion takes place as if by a call to the wcrtomb function.<a href='#FOOTNOTE.503'><sup>[503]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.503'>
 | |
| <pre><i><b>Footnote 503)</b> If conversion stops because a terminating null wide character has been reached, the bytes stored include those necessary
 | |
|     to reach the initial shift state immediately before the null byte. However, if the conversion stops before a terminating null
 | |
|     wide character has been reached, the result will be null terminated, but might not end in the initial shift state.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.5.2p5'></a>
 | |
| <pre>5   Regardless of whether dst is or is not a null pointer, if the input conversion encounters a wide
 | |
|     character that does not correspond to a valid multibyte character, an encoding error occurs: the
 | |
|     wcstombs_s function stores the value (size_t)(-1) into *retval . Otherwise, the wcstombs_s
 | |
|     function stores into *retval the number of bytes in the resulting multibyte character sequence, not
 | |
|     including the terminating null character (if any).
 | |
| </pre>
 | |
| <a name='K.3.6.5.2p6'></a>
 | |
| <pre>6   All elements following the terminating null character (if any) written by wcstombs_s in the array of
 | |
|     dstmax elements pointed to by dst take unspecified values when wcstombs_s returns.<a href='#FOOTNOTE.504'><sup>[504]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.504'>
 | |
| <pre><i><b>Footnote 504)</b> When len is not less than dstmax, the implementation might fill the array before discovering a runtime-constraint
 | |
|     violation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.6.5.2p7'></a>
 | |
| <pre>7   If copying takes place between objects that overlap, the objects take on unspecified values.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.6.5.2p8'></a>
 | |
| <pre>8   The wcstombs_s function returns zero if no runtime-constraint violation and no encoding error
 | |
|     occurred. Otherwise, a nonzero value is returned.
 | |
| </pre>
 | |
| <a name='K.3.7'></a>
 | |
| <hr>
 | |
| <h3>K.3.7 [String handling <string.h>]</h3>
 | |
| <a name='K.3.7p1'></a>
 | |
| <pre>1   The header <string.h> defines two types.
 | |
| </pre>
 | |
| <a name='K.3.7p2'></a>
 | |
| <pre>2   The types are
 | |
| 
 | |
|             errno_t
 | |
| 
 | |
| 
 | |
|     which is type int; and
 | |
| 
 | |
|             rsize_t
 | |
| 
 | |
| 
 | |
|     which is the type size_t.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.7.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.1 [Copying functions]</h3>
 | |
| <a name='K.3.7.1.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.1.1 [The memcpy_s function]</h3>
 | |
| <a name='K.3.7.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <string.h>
 | |
|             errno_t memcpy_s(void * restrict s1, rsize_t s1max, const void * restrict s2,
 | |
|                   rsize_t n);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.1.1p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than RSIZE_MAX. n
 | |
|     shall not be greater than s1max. Copying shall not take place between objects that overlap.
 | |
| </pre>
 | |
| <a name='K.3.7.1.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the memcpy_s function stores zeros in the first s1max
 | |
|     characters of the object pointed to by s1 if s1 is not a null pointer and s1max is not greater than
 | |
|     RSIZE_MAX.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.1.1p4'></a>
 | |
| <pre>4   The memcpy_s function copies n characters from the object pointed to by s2 into the object pointed
 | |
|     to by s1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.7.1.1p5'></a>
 | |
| <pre>5   The memcpy_s function returns zero if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.7.1.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.1.2 [The memmove_s function]</h3>
 | |
| <a name='K.3.7.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <string.h>
 | |
|             errno_t memmove_s(void *s1, rsize_t s1max, const void *s2, rsize_t n);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.1.2p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than RSIZE_MAX. n
 | |
|     shall not be greater than s1max.
 | |
| </pre>
 | |
| <a name='K.3.7.1.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the memmove_s function stores zeros in the first s1max
 | |
|     characters of the object pointed to by s1 if s1 is not a null pointer and s1max is not greater than
 | |
|     RSIZE_MAX.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.1.2p4'></a>
 | |
| <pre>4   The memmove_s function copies n characters from the object pointed to by s2 into the object pointed
 | |
|     to by s1. This copying takes place as if the n characters from the object pointed to by s2 are first
 | |
|     copied into a temporary array of n characters that does not overlap the objects pointed to by s1 or
 | |
|     s2, and then the n characters from the temporary array are copied into the object pointed to by s1.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.7.1.2p5'></a>
 | |
| <pre>5   The memmove_s function returns zero if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| </pre>
 | |
| <a name='K.3.7.1.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.1.3 [The strcpy_s function]</h3>
 | |
| <a name='K.3.7.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               errno_t strcpy_s(char * restrict s1, rsize_t s1max, const char * restrict s2);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.1.3p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer. s1max shall not be greater than RSIZE_MAX. s1max shall
 | |
|     not equal zero. s1max shall be greater than strnlen_s(s2, s1max). Copying shall not take place
 | |
|     between objects that overlap.
 | |
| </pre>
 | |
| <a name='K.3.7.1.3p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX, then strcpy_s sets s1[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.1.3p4'></a>
 | |
| <pre>4   The strcpy_s function copies the string pointed to by s2 (including the terminating null character)
 | |
|     into the array pointed to by s1.
 | |
| </pre>
 | |
| <a name='K.3.7.1.3p5'></a>
 | |
| <pre>5   All elements following the terminating null character (if any) written by strcpy_s in the array of
 | |
|     s1max characters pointed to by s1 take unspecified values when strcpy_s returns.<a href='#FOOTNOTE.505'><sup>[505]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.505'>
 | |
| <pre><i><b>Footnote 505)</b> This allows an implementation to copy characters from s2 to s1 while simultaneously checking if any of those characters
 | |
|     are null. Such an approach might write a character to every element of s1 before discovering that the first element was set to
 | |
|     the null character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.1.3p6'></a>
 | |
| <pre>6   The strcpy_s function returns zero<a href='#FOOTNOTE.506'><sup>[506]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.506'>
 | |
| <pre><i><b>Footnote 506)</b> A zero return value implies that all of the requested characters from the string pointed to by s2 fit within the array
 | |
|     pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.1.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.1.4 [The strncpy_s function]</h3>
 | |
| <a name='K.3.7.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               errno_t strncpy_s(char * restrict s1, rsize_t s1max, const char * restrict s2,
 | |
|                     rsize_t n);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.1.4p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than RSIZE_MAX.
 | |
|     s1max shall not equal zero. If n is not less than s1max, then s1max shall be greater than
 | |
|     strnlen_s(s2, s1max). Copying shall not take place between objects that overlap.
 | |
| </pre>
 | |
| <a name='K.3.7.1.4p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX, then strncpy_s sets s1[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.1.4p4'></a>
 | |
| <pre>4   The strncpy_s function copies not more than n successive characters (characters that follow a null
 | |
|     character are not copied) from the array pointed to by s2 to the array pointed to by s1. If no null
 | |
|     character was copied from s2, then s1[n] is set to a null character.
 | |
| </pre>
 | |
| <a name='K.3.7.1.4p5'></a>
 | |
| <pre>5   All elements following the terminating null character (if any) written by strncpy_s in the array
 | |
|     of s1max characters pointed to by s1 take unspecified values when strncpy_s returns a nonzero
 | |
|     value.<a href='#FOOTNOTE.507'><sup>[507]</sup></a>
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.507'>
 | |
| <pre><i><b>Footnote 507)</b> This allows an implementation to copy characters from s2 to s1 while simultaneously checking if any of those characters
 | |
|     are null. Such an approach might write a character to every element of s1 before discovering that the first element was set to
 | |
|     the null character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.1.4p6'></a>
 | |
| <pre>6   The strncpy_s function returns zero<a href='#FOOTNOTE.508'><sup>[508]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.508'>
 | |
| <pre><i><b>Footnote 508)</b> A zero return value implies that all of the requested characters from the string pointed to by s2 fit within the array
 | |
|     pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.1.4p7'></a>
 | |
| <pre>7   EXAMPLE 1 The strncpy_s function can be used to copy a string without the danger that the result will not be null
 | |
|     terminated or that characters will be written past the end of the destination array.
 | |
| 
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               /* ... */
 | |
|               char src1[100] = "hello";
 | |
|               char src2[7] = {’g’, ’o’, ’o’, ’d’, ’b’, ’y’, ’e’};
 | |
|               char dst1[6], dst2[5], dst3[5];
 | |
|               int r1, r2, r3;
 | |
|               r1 = strncpy_s(dst1, 6, src1, 100);
 | |
|               r2 = strncpy_s(dst2, 5, src2, 7);
 | |
|               r3 = strncpy_s(dst3, 5, src2, 4);
 | |
| 
 | |
|     The first call will assign to r1 the value zero and to dst1 the sequence hello\0.
 | |
|     The second call will assign to r2 a nonzero value and to dst2 the sequence \0.
 | |
|     The third call will assign to r3 the value zero and to dst3 the sequence good\0.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.7.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.2 [Concatenation functions]</h3>
 | |
| <a name='K.3.7.2.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.2.1 [The strcat_s function]</h3>
 | |
| <a name='K.3.7.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               errno_t strcat_s(char * restrict s1, rsize_t s1max, const char * restrict s2);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.2.1p2'></a>
 | |
| <pre>2   Let m denote the value s1max - strnlen_s(s1, s1max) upon entry to strcat_s.
 | |
| </pre>
 | |
| <a name='K.3.7.2.1p3'></a>
 | |
| <pre>3   Neither s1 nor s2 shall be a null pointer. s1max shall not be greater than RSIZE_MAX. s1max shall
 | |
|     not equal zero. m shall not equal zero.<a href='#FOOTNOTE.509'><sup>[509]</sup></a> m shall be greater than strnlen_s(s2, m). Copying shall
 | |
|     not take place between objects that overlap.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.509'>
 | |
| <pre><i><b>Footnote 509)</b> Zero means that s1 was not null terminated upon entry to strcat_s.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.2.1p4'></a>
 | |
| <pre>4   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX, then strcat_s sets s1[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.2.1p5'></a>
 | |
| <pre>5   The strcat_s function appends a copy of the string pointed to by s2 (including the terminating
 | |
|     null character) to the end of the string pointed to by s1. The initial character from s2 overwrites the
 | |
|     null character at the end of s1.
 | |
| </pre>
 | |
| <a name='K.3.7.2.1p6'></a>
 | |
| <pre>6   All elements following the terminating null character (if any) written by strcat_s in the array of
 | |
|     s1max characters pointed to by s1 take unspecified values when strcat_s returns.<a href='#FOOTNOTE.510'><sup>[510]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.510'>
 | |
| <pre><i><b>Footnote 510)</b> This allows an implementation to append characters from s2 to s1 while simultaneously checking if any of those
 | |
|     characters are null. Such an approach might write a character to every element of s1 before discovering that the first element
 | |
|     was set to the null character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.2.1p7'></a>
 | |
| <pre>7   The strcat_s function returns zero<a href='#FOOTNOTE.511'><sup>[511]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.511'>
 | |
| <pre><i><b>Footnote 511)</b> A zero return value implies that all of the requested characters from the string pointed to by s2 were appended to the
 | |
|     string pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.2.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.2.2 [The strncat_s function]</h3>
 | |
| <a name='K.3.7.2.2p1'></a>
 | |
| <pre>1     Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               errno_t strncat_s(char * restrict s1, rsize_t s1max, const char * restrict s2,
 | |
|                     rsize_t n);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.2.2p2'></a>
 | |
| <pre>2   Let m denote the value s1max - strnlen_s(s1, s1max) upon entry to strncat_s.
 | |
| </pre>
 | |
| <a name='K.3.7.2.2p3'></a>
 | |
| <pre>3   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than RSIZE_MAX.
 | |
|     s1max shall not equal zero. m shall not equal zero.<a href='#FOOTNOTE.512'><sup>[512]</sup></a> If n is not less than m, then m shall be greater
 | |
|     than strnlen_s(s2, m). Copying shall not take place between objects that overlap.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.512'>
 | |
| <pre><i><b>Footnote 512)</b> Zero means that s1 was not null terminated upon entry to strncat_s.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.2.2p4'></a>
 | |
| <pre>4   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX, then strncat_s sets s1[0] to the null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.2.2p5'></a>
 | |
| <pre>5   The strncat_s function appends not more than n successive characters (characters that follow a
 | |
|     null character are not copied) from the array pointed to by s2 to the end of the string pointed to by
 | |
|     s1. The initial character from s2 overwrites the null character at the end of s1. If no null character
 | |
|     was copied from s2, then s1[s1max- m +n] is set to a null character.
 | |
| </pre>
 | |
| <a name='K.3.7.2.2p6'></a>
 | |
| <pre>6   All elements following the terminating null character (if any) written by strncat_s in the array of
 | |
|     s1max characters pointed to by s1 take unspecified values when strncat_s returns.<a href='#FOOTNOTE.513'><sup>[513]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.513'>
 | |
| <pre><i><b>Footnote 513)</b> This allows an implementation to append characters from s2 to s1 while simultaneously checking if any of those
 | |
|     characters are null. Such an approach might write a character to every element of s1 before discovering that the first element
 | |
|     was set to the null character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.2.2p7'></a>
 | |
| <pre>7   The strncat_s function returns zero<a href='#FOOTNOTE.514'><sup>[514]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.514'>
 | |
| <pre><i><b>Footnote 514)</b> A zero return value implies that all of the requested characters from the string pointed to by s2 were appended to the
 | |
|     string pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.2.2p8'></a>
 | |
| <pre>8   EXAMPLE 1 The strncat_s function can be used to copy a string without the danger that the result will not be null
 | |
|     terminated or that characters will be written past the end of the destination array.
 | |
| 
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               /* ... */
 | |
|               char s1[100] = "good";
 | |
|               char s2[6] = "hello";
 | |
|               char s3[6] = "hello";
 | |
|               char s4[7] = "abc";
 | |
|               char s5[1000] = "bye";
 | |
|               int r1, r2, r3, r4;
 | |
|               r1 = strncat_s(s1, 100, s5, 1000);
 | |
|               r2 = strncat_s(s2, 6, "", 1);
 | |
|               r3 = strncat_s(s3, 6, "X", 2);
 | |
|               r4 = strncat_s(s4, 7, "defghijklmn", 3);
 | |
| 
 | |
| 
 | |
|     After the first call r1 will have the value zero and s1 will contain the sequence goodbye\0.
 | |
|     After the second call r2 will have the value zero and s2 will contain the sequence hello\0.
 | |
|     After the third call r3 will have a nonzero value and s3 will contain the sequence \0.
 | |
|     After the fourth call r4 will have the value zero and s4 will contain the sequence abcdef\0.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.7.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.3 [Search functions]</h3>
 | |
| <a name='K.3.7.3.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.3.1 [The strtok_s function]</h3>
 | |
| <a name='K.3.7.3.1p1'></a>
 | |
| <pre>1      Synopsis
 | |
|             #define __STDC_WANT_LIB_EXT1__ 1
 | |
|              #include <string.h>
 | |
|              char *strtok_s(char * restrict s1, rsize_t * restrict s1max,
 | |
|                    const char * restrict s2, char ** restrict ptr);
 | |
| 
 | |
| 
 | |
|      Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p2'></a>
 | |
| <pre>2    None of s1max, s2, or ptr shall be a null pointer. If s1 is a null pointer, then *ptr shall not be a
 | |
|      null pointer. The value of *s1max shall not be greater than RSIZE_MAX. The end of the token found
 | |
|      shall occur within the first *s1max characters of s1 for the first call, and shall occur within the first
 | |
|      *s1max characters of where searching resumes on subsequent calls.
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p3'></a>
 | |
| <pre>3    If there is a runtime-constraint violation, the strtok_s function does not indirect through the s1 or
 | |
|      s2 pointers, and does not store a value in the object pointed to by ptr.
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p4'></a>
 | |
| <pre>4    A sequence of calls to the strtok_s function breaks the string pointed to by s1 into a sequence of
 | |
|      tokens, each of which is delimited by a character from the string pointed to by s2. The fourth argu-
 | |
|      ment points to a caller-provided char pointer into which the strtok_s function stores information
 | |
|      necessary for it to continue scanning the same string.
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p5'></a>
 | |
| <pre>5    The first call in a sequence has a non-null first argument and s1max points to an object whose value
 | |
|      is the number of elements in the character array pointed to by the first argument. The first call stores
 | |
|      an initial value in the object pointed to by ptr and updates the value pointed to by s1max to reflect
 | |
|      the number of elements that remain in relation to ptr. Subsequent calls in the sequence have a null
 | |
|      first argument and the objects pointed to by s1max and ptr are required to have the values stored
 | |
|      by the previous call in the sequence, which are then updated. The separator string pointed to by s2
 | |
|      may be different from call to call.
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p6'></a>
 | |
| <pre>6    The first call in the sequence searches the string pointed to by s1 for the first character that is not
 | |
|      contained in the current separator string pointed to by s2. If no such character is found, then there
 | |
|      are no tokens in the string pointed to by s1 and the strtok_s function returns a null pointer. If such
 | |
|      a character is found, it is the start of the first token.
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p7'></a>
 | |
| <pre>7    The strtok_s function then searches from there for the first character in s1 that is contained in the
 | |
|      current separator string. If no such character is found, the current token extends to the end of the
 | |
|      string pointed to by s1, and subsequent searches in the same string for a token return a null pointer.
 | |
|      If such a character is found, it is overwritten by a null character, which terminates the current token.
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p8'></a>
 | |
| <pre>8    In all cases, the strtok_s function stores sufficient information in the pointer pointed to by ptr so
 | |
|      that subsequent calls, with a null pointer for s1 and the unmodified pointer value for ptr, shall start
 | |
|      searching just past the element overwritten by a null character (if any).
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p9'></a>
 | |
| <pre>9    The strtok_s function returns a pointer to the first character of a token, or a null pointer if there is
 | |
|      no token or there is a runtime-constraint violation.
 | |
| </pre>
 | |
| <a name='K.3.7.3.1p10'></a>
 | |
| <pre>10   EXAMPLE
 | |
| 
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|              #include <string.h>
 | |
|              static char str1[] = "?a???b,,,#c";
 | |
|              static char str2[] = "\t \t";
 | |
|              char *t, *ptr1, *ptr2;
 | |
|              rsize_t max1 = sizeof (str1);
 | |
|              rsize_t max2 = sizeof (str2);
 | |
| 
 | |
|              t = strtok_s(str1, &max1, "?", &ptr1);            // t points to the token "a"
 | |
|              t = strtok_s(NULL, &max1, ",", &ptr1);            // t points to the token "??b"
 | |
|              t = strtok_s(str2, &max2, " \t", &ptr2);          // t is a null pointer
 | |
|              t = strtok_s(NULL, &max1, "#,", &ptr1);           // t points to the token "c"
 | |
|             t = strtok_s(NULL, &max1, "?", &ptr1);            // t is a null pointer
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.7.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.4 [Miscellaneous functions]</h3>
 | |
| <a name='K.3.7.4.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.4.1 [The memset_s function]</h3>
 | |
| <a name='K.3.7.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <string.h>
 | |
|             errno_t memset_s(void *s, rsize_t smax, int c, rsize_t n)
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.4.1p2'></a>
 | |
| <pre>2   s shall not be a null pointer. Neither smax nor n shall be greater than RSIZE_MAX. n shall not be
 | |
|     greater than smax.
 | |
| </pre>
 | |
| <a name='K.3.7.4.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and smax is not greater than
 | |
|     RSIZE_MAX, the memset_s function stores the value of c (converted to an unsigned char) into each
 | |
|     of the first smax characters of the object pointed to by s.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.4.1p4'></a>
 | |
| <pre>4   The memset_s function copies the value of c (converted to an unsigned char) into each of the first
 | |
|     n characters of the object pointed to by s. Unlike memset, any call to the memset_s function shall be
 | |
|     evaluated strictly according to the rules of the abstract machine as described in (<a href='#5.1.2.3'>5.1.2.3</a>). That is, any
 | |
|     call to the memset_s function shall assume that the memory indicated by s and n may be accessible
 | |
|     in the future and thus contains the values indicated by c.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.7.4.1p5'></a>
 | |
| <pre>5   The memset_s function returns zero if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.7.4.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.4.2 [The strerror_s function]</h3>
 | |
| <a name='K.3.7.4.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <string.h>
 | |
|             errno_t strerror_s(char *s, rsize_t maxsize, errno_t errnum);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.7.4.2p2'></a>
 | |
| <pre>2   s shall not be a null pointer. maxsize shall not be greater than RSIZE_MAX. maxsize shall not equal
 | |
|     zero.
 | |
| </pre>
 | |
| <a name='K.3.7.4.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then the array (if any) pointed to by s is not modified.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.4.2p4'></a>
 | |
| <pre>4   The strerror_s function maps the number in errnum to a locale-specific message string. Typically,
 | |
|     the values for errnum come from errno, but strerror_s shall map any value of type int to a
 | |
|     message.
 | |
| </pre>
 | |
| <a name='K.3.7.4.2p5'></a>
 | |
| <pre>5   If the length of the desired string is less than maxsize, then the string is copied to the array pointed
 | |
|     to by s.
 | |
| </pre>
 | |
| <a name='K.3.7.4.2p6'></a>
 | |
| <pre>6   Otherwise, if maxsize is greater than zero, then maxsize-1 characters are copied from the string
 | |
|     to the array pointed to by s and then s[maxsize-1] is set to the null character. Then, if maxsize
 | |
|     is greater than 3, then s[maxsize-2], s[maxsize-3], and s[maxsize-4] are set to the character
 | |
|     period (.).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.7.4.2p7'></a>
 | |
| <pre>7   The strerror_s function returns zero if the length of the desired string was less than maxsize and
 | |
|     there was no runtime-constraint violation. Otherwise, the strerror_s function returns a nonzero
 | |
|     value.
 | |
| </pre>
 | |
| <a name='K.3.7.4.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.4.3 [The strerrorlen_s function]</h3>
 | |
| <a name='K.3.7.4.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               size_t strerrorlen_s(errno_t errnum);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.4.3p2'></a>
 | |
| <pre>2   The strerrorlen_s function calculates the length of the (untruncated) locale-specific message
 | |
|     string that the strerror_s function maps to errnum.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.7.4.3p3'></a>
 | |
| <pre>3   The strerrorlen_s function returns the number of characters (not including the null character) in
 | |
|     the full message string.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.7.4.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.7.4.4 [The strnlen_s function]</h3>
 | |
| <a name='K.3.7.4.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <string.h>
 | |
|               size_t strnlen_s(const char *s, size_t maxsize);
 | |
| 
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.7.4.4p2'></a>
 | |
| <pre>2   The strnlen_s function computes the length of the string pointed to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.7.4.4p3'></a>
 | |
| <pre>3   If s is a null pointer,<a href='#FOOTNOTE.515'><sup>[515]</sup></a> then the strnlen_s function returns zero.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.515'>
 | |
| <pre><i><b>Footnote 515)</b> Note that the strnlen_s function has no runtime-constraints. This lack of runtime-constraints along with the values
 | |
|     returned for a null pointer or an unterminated string argument make strnlen_s useful in algorithms that gracefully handle
 | |
|     such exceptional data.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.7.4.4p4'></a>
 | |
| <pre>4   Otherwise, the strnlen_s function returns the number of characters that precede the terminating
 | |
|     null character. If there is no null character in the first maxsize characters of s then strnlen_s
 | |
|     returns maxsize. At most the first maxsize characters of s shall be accessed by strnlen_s.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.8'></a>
 | |
| <hr>
 | |
| <h3>K.3.8 [Date and time <time.h>]</h3>
 | |
| <a name='K.3.8p1'></a>
 | |
| <pre>1   The header <time.h> defines two types.
 | |
| </pre>
 | |
| <a name='K.3.8p2'></a>
 | |
| <pre>2   The types are
 | |
| 
 | |
|               errno_t
 | |
| 
 | |
| 
 | |
|     which is type int; and
 | |
| 
 | |
|               rsize_t
 | |
| 
 | |
| 
 | |
|     which is the type size_t.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.8.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.8.1 [Components of time]</h3>
 | |
| <a name='K.3.8.1p1'></a>
 | |
| <pre>1   A broken-down time is normalized if the values of the members of the tm structure are in their normal
 | |
|     rages.<a href='#FOOTNOTE.516'><sup>[516]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.516'>
 | |
| <pre><i><b>Footnote 516)</b> The normal ranges are defined in <a href='#7.29.1'>7.29.1</a>.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.8.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.8.2 [Time conversion functions]</h3>
 | |
| <a name='K.3.8.2p1'></a>
 | |
| <pre>1   Like the strftime function, the asctime_s and ctime_s functions do not return a pointer to a static
 | |
|     object, and other library functions are permitted to call them.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.8.2.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.8.2.1 [The asctime_s function]</h3>
 | |
| <a name='K.3.8.2.1p1'></a>
 | |
| <pre>1     Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <time.h>
 | |
|             errno_t asctime_s(char *s, rsize_t maxsize, const struct tm *timeptr);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.8.2.1p2'></a>
 | |
| <pre>2   Neither s nor timeptr shall be a null pointer. maxsize shall not be less than 26 and shall not be
 | |
|     greater than RSIZE_MAX. The broken-down time pointed to by timeptr shall be normalized. The
 | |
|     calendar year represented by the broken-down time pointed to by timeptr shall not be less than
 | |
|     calendar year 0 and shall not be greater than calendar year 9999.
 | |
| </pre>
 | |
| <a name='K.3.8.2.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, there is no attempt to convert the time, and s[0] is set to a
 | |
|     null character if s is not a null pointer and maxsize is not zero and is not greater than RSIZE_MAX.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.8.2.1p4'></a>
 | |
| <pre>4   The asctime_s function converts the normalized broken-down time in the structure pointed to by
 | |
|     timeptr into a 26 character (including the null character) string in the form
 | |
| 
 | |
|              Sun Sep 16 01:03:52 1973\n\0
 | |
| 
 | |
|     The fields making up this string are (in order):
 | |
| 
 | |
|        1. The name of the day of the week represented by timeptr->tm_wday using the following three
 | |
|           character weekday names: Sun, Mon, Tue, Wed, Thu, Fri, and Sat.
 | |
|        2. The character space.
 | |
|        3. The name of the month represented by timeptr->tm_mon using the following three character
 | |
|           month names: Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, and Dec.
 | |
|        4. The character space.
 | |
|        5. The value of timeptr->tm_mday as if printed using the fprintf format "%2d".
 | |
|        6. The character space.
 | |
|        7. The value of timeptr->tm_hour as if printed using the fprintf format "%.2d".
 | |
|        8. The character colon.
 | |
|        9. The value of timeptr->tm_min as if printed using the fprintf format "%.2d".
 | |
|      10. The character colon.
 | |
|      11. The value of timeptr->tm_sec as if printed using the fprintf format "%.2d".
 | |
|      12. The character space.
 | |
|      13. The value of timeptr->tm_year + 1900 as if printed using the fprintf format "%4d".
 | |
|      14. The character new line.
 | |
|      15. The null character.
 | |
| 
 | |
|     Recommended practice
 | |
|     The strftime function allows more flexible formatting and supports locale-specific behavior. If you
 | |
|     do not require the exact form of the result string produced by the asctime_s function, consider
 | |
|     using the strftime function instead.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.8.2.1p5'></a>
 | |
| <pre>5   The asctime_s function returns zero if the time was successfully converted and stored into the
 | |
|     array pointed to by s. Otherwise, it returns a nonzero value.
 | |
| </pre>
 | |
| <a name='K.3.8.2.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.8.2.2 [The ctime_s function]</h3>
 | |
| <a name='K.3.8.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <time.h>
 | |
|             errno_t ctime_s(char *s, rsize_t maxsize, const time_t *timer);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.8.2.2p2'></a>
 | |
| <pre>2   Neither s nor timer shall be a null pointer. maxsize shall not be less than 26 and shall not be greater
 | |
|     than RSIZE_MAX.
 | |
| </pre>
 | |
| <a name='K.3.8.2.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, s[0] is set to a null character if s is not a null pointer and
 | |
|     maxsize is not equal zero and is not greater than RSIZE_MAX.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.8.2.2p4'></a>
 | |
| <pre>4   The ctime_s function converts the calendar time pointed to by timer to local time in the form of a
 | |
|     string. It is equivalent to
 | |
| 
 | |
|         asctime_s(s, maxsize, localtime_s(timer, &(struct tm){ 0 }))
 | |
| 
 | |
| 
 | |
|     Recommended practice
 | |
|     The strftime function allows more flexible formatting and supports locale-specific behavior. If you
 | |
|     do not require the exact form of the result string produced by the ctime_s function, consider using
 | |
|     the strftime function instead.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.8.2.2p5'></a>
 | |
| <pre>5   The ctime_s function returns zero if the time was successfully converted and stored into the array
 | |
|     pointed to by s. Otherwise, it returns a nonzero value.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.8.2.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.8.2.3 [The gmtime_s function]</h3>
 | |
| <a name='K.3.8.2.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <time.h>
 | |
|             struct tm *gmtime_s(const time_t * restrict timer, struct tm * restrict result);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.8.2.3p2'></a>
 | |
| <pre>2   Neither timer nor result shall be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.8.2.3p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, there is no attempt to convert the time.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.8.2.3p4'></a>
 | |
| <pre>4   The gmtime_s function converts the calendar time pointed to by timer into a broken-down time,
 | |
|     expressed as UTC. The broken-down time is stored in the structure pointed to by result.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.8.2.3p5'></a>
 | |
| <pre>5   The gmtime_s function returns result, or a null pointer if the specified time cannot be converted to
 | |
|     UTC or there is a runtime-constraint violation.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.8.2.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.8.2.4 [The localtime_s function]</h3>
 | |
| <a name='K.3.8.2.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|            #define __STDC_WANT_LIB_EXT1__ 1
 | |
|             #include <time.h>
 | |
|             struct tm *localtime_s(const time_t *restrict timer, struct tm *restrict result);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.8.2.4p2'></a>
 | |
| <pre>2   Neither timer nor result shall be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.8.2.4p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, there is no attempt to convert the time.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.8.2.4p4'></a>
 | |
| <pre>4   The localtime_s function converts the calendar time pointed to by timer into a broken-down time,
 | |
|     expressed as local time. The broken-down time is stored in the structure pointed to by result.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.8.2.4p5'></a>
 | |
| <pre>5   The localtime_s function returns result, or a null pointer if the specified time cannot be converted
 | |
|     to local time or there is a runtime-constraint violation.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9'></a>
 | |
| <hr>
 | |
| <h3>K.3.9 [Extended multibyte and wide character utilities <wchar.h>]</h3>
 | |
| <a name='K.3.9p1'></a>
 | |
| <pre>1   The header <wchar.h> defines two types.
 | |
| </pre>
 | |
| <a name='K.3.9p2'></a>
 | |
| <pre>2   The types are
 | |
| 
 | |
|               errno_t
 | |
| 
 | |
| 
 | |
|     which is type int; and
 | |
| 
 | |
|               rsize_t
 | |
| 
 | |
| 
 | |
|     which is the type size_t.
 | |
| </pre>
 | |
| <a name='K.3.9p3'></a>
 | |
| <pre>3   Unless explicitly stated otherwise, if the execution of a function described in this subclause causes
 | |
|     copying to take place between objects that overlap, the objects take on unspecified values.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1 [Formatted wide character input/output functions]</h3>
 | |
| <a name='K.3.9.1.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.1 [The fwprintf_s function]</h3>
 | |
| <a name='K.3.9.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               int fwprintf_s(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.1p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. The %n specifier<a href='#FOOTNOTE.517'><sup>[517]</sup></a> (modified or not by flags,
 | |
|     field width, or precision) shall not appear in the wide string pointed to by format. Any argument to
 | |
|     fwprintf_s corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.517'>
 | |
| <pre><i><b>Footnote 517)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the fwprintf_s function does not attempt to produce
 | |
|     further output, and it is unspecified to what extent fwprintf_s produced output before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.1p4'></a>
 | |
| <pre>4   The fwprintf_s function is equivalent to the fwprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.1p5'></a>
 | |
| <pre>5   The fwprintf_s function returns the number of wide characters transmitted, or a negative value if
 | |
|     an output error, encoding error, or runtime-constraint violation occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.2 [The fwscanf_s function]</h3>
 | |
| <a name='K.3.9.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               int fwscanf_s(FILE * restrict stream, const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.2p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. Any argument indirected though in order to
 | |
|     store converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.9.1.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the fwscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent fwscanf_s performed input before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.2p4'></a>
 | |
| <pre>4   The fwscanf_s function is equivalent to fwscanf except that the c, s, and [ conversion specifiers
 | |
|     apply to a pair of arguments (unless assignment suppression is indicated by a *). The first of these
 | |
|     arguments is the same as for fwscanf. That argument is immediately followed in the argument
 | |
|     list by the second argument, which has type size_t and gives the number of elements in the array
 | |
|     pointed to by the first argument of the pair. If the first argument points to a scalar object, it is
 | |
|     considered to be an array of one element.<a href='#FOOTNOTE.518'><sup>[518]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.518'>
 | |
| <pre><i><b>Footnote 518)</b> If the format is known at translation time, an implementation can issue a diagnostic for any argument used to store
 | |
|     the result from a c, s, or [ conversion specifier if that argument is not followed by an argument of a type compatible with
 | |
|     rsize_t. A limited amount of checking can be done if even if the format is not known at translation time. For example, an
 | |
|     implementation could issue a diagnostic for each argument after format that has of type pointer to one of char, signed char,
 | |
|     unsigned char, or void that is not followed by an argument of a type compatible with rsize_t. The diagnostic could warn
 | |
|     that unless the pointer is being used with a conversion specifier using the hh length modifier, a length argument is expected
 | |
|     to follow the pointer argument. Another useful diagnostic could flag any non-pointer argument following format that did
 | |
|     not have a type compatible with rsize_t.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.2p5'></a>
 | |
| <pre>5   A matching failure occurs if the number of elements in a receiving object is insufficient to hold the
 | |
|     converted input (including any trailing null character).
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.2p6'></a>
 | |
| <pre>6   The fwscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the fwscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.3 [The snwprintf_s function]</h3>
 | |
| <a name='K.3.9.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               int snwprintf_s(wchar_t * restrict s, rsize_t n, const wchar_t * restrict format,
 | |
|                     ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.3p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). The %n specifier<a href='#FOOTNOTE.519'><sup>[519]</sup></a> (modified or not by flags, field width, or pre-
 | |
|     cision) shall not appear in the wide string pointed to by format. Any argument to snwprintf_s
 | |
|     corresponding to a %s specifier shall not be a null pointer. No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.519'>
 | |
| <pre><i><b>Footnote 519)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.3p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero
 | |
|     and not greater than RSIZE_MAX/sizeof(wchar_t), then the snwprintf_s function sets s[0] to
 | |
|     the null wide character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.3p4'></a>
 | |
| <pre>4   The snwprintf_s function is equivalent to the swprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.9.1.3p5'></a>
 | |
| <pre>5   The snwprintf_s function, unlike swprintf_s, will truncate the result to fit within the array pointed
 | |
|     to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.3p6'></a>
 | |
| <pre>6   The snwprintf_s function returns the number of wide characters that would have been written
 | |
|     had n been sufficiently large, not counting the terminating wide null character, or a negative value
 | |
|     if a runtime-constraint violation occurred. Thus, the null-terminated output has been completely
 | |
|     written if and only if the returned value is both nonnegative and less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.4 [The swprintf_s function]</h3>
 | |
| <a name='K.3.9.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               int swprintf_s(wchar_t * restrict s, rsize_t n, const wchar_t * restrict format,
 | |
|                     ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.4p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). The number of wide characters (including the trailing null) required
 | |
|     for the result to be written to the array pointed to by s shall not be greater than n. The %n specifier<a href='#FOOTNOTE.520'><sup>[520]</sup></a>
 | |
|     (modified or not by flags, field width, or precision) shall not appear in the wide string pointed to by
 | |
|     format. Any argument to swprintf_s corresponding to a %s specifier shall not be a null pointer.
 | |
|     No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.520'>
 | |
| <pre><i><b>Footnote 520)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.4p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero and
 | |
|     not greater than RSIZE_MAX/sizeof(wchar_t), then the swprintf_s function sets s[0] to the null
 | |
|     wide character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.4p4'></a>
 | |
| <pre>4   The swprintf_s function is equivalent to the swprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.9.1.4p5'></a>
 | |
| <pre>5   The swprintf_s function, unlike snwprintf_s, treats a result too big for the array pointed to by s
 | |
|     as a runtime-constraint violation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.4p6'></a>
 | |
| <pre>6   If no runtime-constraint violation occurred, the swprintf_s function returns the number of wide
 | |
|     characters written in the array, not counting the terminating null wide character. If an encoding
 | |
|     error occurred or if n or more wide characters are requested to be written, swprintf_s returns a
 | |
|     negative value. If any other runtime-constraint violation occurred, swprintf_s returns zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.5'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.5 [The swscanf_s function]</h3>
 | |
| <a name='K.3.9.1.5p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               int swscanf_s(const wchar_t * restrict s, const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.5p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. Any argument indirected though in order to store
 | |
|     converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.9.1.5p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the swscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent swscanf_s performed input before discovering
 | |
|     the runtime-constraint violation.
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.5p4'></a>
 | |
| <pre>4   The swscanf_s function is equivalent to fwscanf_s, except that the argument s specifies a wide
 | |
|     string from which the input is to be obtained, rather than from a stream. Reaching the end of the
 | |
|     wide string is equivalent to encountering end-of-file for the fwscanf_s function.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.5p5'></a>
 | |
| <pre>5   The swscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the swscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.6'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.6 [The vfwprintf_s function]</h3>
 | |
| <a name='K.3.9.1.6p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               int vfwprintf_s(FILE * restrict stream, const wchar_t * restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.6p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. The %n specifier<a href='#FOOTNOTE.521'><sup>[521]</sup></a> (modified or not by flags,
 | |
|     field width, or precision) shall not appear in the wide string pointed to by format. Any argument to
 | |
|     vfwprintf_s corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.521'>
 | |
| <pre><i><b>Footnote 521)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.6p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vfwprintf_s function does not attempt to produce
 | |
|     further output, and it is unspecified to what extent vfwprintf_s produced output before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.6p4'></a>
 | |
| <pre>4   The vfwprintf_s function is equivalent to the vfwprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.6p5'></a>
 | |
| <pre>5   The vfwprintf_s function returns the number of wide characters transmitted, or a negative value if
 | |
|     an output error, encoding error, or runtime-constraint violation occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.7'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.7 [The vfwscanf_s function]</h3>
 | |
| <a name='K.3.9.1.7p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <stdio.h>
 | |
|               #include <wchar.h>
 | |
|               int vfwscanf_s(FILE * restrict stream, const wchar_t * restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.7p2'></a>
 | |
| <pre>2   Neither stream nor format shall be a null pointer. Any argument indirected though in order to
 | |
|     store converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.9.1.7p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vfwscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent vfwscanf_s performed input before discovering
 | |
|     the runtime-constraint violation.
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.7p4'></a>
 | |
| <pre>4   The vfwscanf_s function is equivalent to fwscanf_s, with the variable argument list replaced by
 | |
|     arg, which shall have been initialized by the va_start macro (and possibly subsequent va_arg
 | |
|     calls). The vfwscanf_s function does not invoke the va_end macro<a href='#FOOTNOTE.522'><sup>[522]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.522'>
 | |
| <pre><i><b>Footnote 522)</b> As the functions vfwscanf_s , vwscanf_s , and vswscanf_s invoke the va_arg macro, the representation of arg after the
 | |
|     return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.7p5'></a>
 | |
| <pre>5   The vfwscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the vfwscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.8'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.8 [The vsnwprintf_s function]</h3>
 | |
| <a name='K.3.9.1.8p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <wchar.h>
 | |
|               int vsnwprintf_s(wchar_t *restrict s, rsize_t n, const wchar_t *restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.8p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). The %n specifier<a href='#FOOTNOTE.523'><sup>[523]</sup></a> (modified or not by flags, field width, or preci-
 | |
|     sion) shall not appear in the wide string pointed to by format. Any argument to vsnwprintf_s
 | |
|     corresponding to a %s specifier shall not be a null pointer. No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.523'>
 | |
| <pre><i><b>Footnote 523)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.8p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero and
 | |
|     not greater than RSIZE_MAX/sizeof(wchar_t), then the vsnwprintf_s function sets s[0] to the
 | |
|     null wide character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.8p4'></a>
 | |
| <pre>4   The vsnwprintf_s function is equivalent to the vswprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.9.1.8p5'></a>
 | |
| <pre>5   The vsnwprintf_s function, unlike vswprintf_s, will truncate the result to fit within the array
 | |
|     pointed to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.8p6'></a>
 | |
| <pre>6   The vsnwprintf_s function returns the number of wide characters that would have been written
 | |
|     had n been sufficiently large, not counting the terminating null character, or a negative value if
 | |
|     a runtime-constraint violation occurred. Thus, the null-terminated output has been completely
 | |
|     written if and only if the returned value is both nonnegative and less than n.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.9'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.9 [The vswprintf_s function]</h3>
 | |
| <a name='K.3.9.1.9p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <wchar.h>
 | |
|               int vswprintf_s(wchar_t *restrict s, rsize_t n, const wchar_t *restrict format,
 | |
|                     va_list arg);
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.9p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. n shall neither equal zero nor be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). The number of wide characters (including the trailing null) required
 | |
|     for the result to be written to the array pointed to by s shall not be greater than n. The %n specifier<a href='#FOOTNOTE.524'><sup>[524]</sup></a>
 | |
|     (modified or not by flags, field width, or precision) shall not appear in the wide string pointed to by
 | |
|     format. Any argument to vswprintf_s corresponding to a %s specifier shall not be a null pointer.
 | |
|     No encoding error shall occur.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.524'>
 | |
| <pre><i><b>Footnote 524)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.9p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s is not a null pointer and n is greater than zero
 | |
|     and not greater than RSIZE_MAX/sizeof(wchar_t), then the vswprintf_s function sets s[0] to
 | |
|     the null wide character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.9p4'></a>
 | |
| <pre>4   The vswprintf_s function is equivalent to the vswprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| </pre>
 | |
| <a name='K.3.9.1.9p5'></a>
 | |
| <pre>5   The vswprintf_s function, unlike vsnwprintf_s, treats a result too big for the array pointed to by
 | |
|     s as a runtime-constraint violation.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.9p6'></a>
 | |
| <pre>6   If no runtime-constraint violation occurred, the vswprintf_s function returns the number of wide
 | |
|     characters written in the array, not counting the terminating null wide character. If an encoding
 | |
|     error occurred or if n or more wide characters are requested to be written, vswprintf_s returns a
 | |
|     negative value. If any other runtime-constraint violation occurred, vswprintf_s returns zero.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.10'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.10 [The vswscanf_s function]</h3>
 | |
| <a name='K.3.9.1.10p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <wchar.h>
 | |
|               int vswscanf_s(const wchar_t * restrict s, const wchar_t * restrict format,
 | |
|                     va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.10p2'></a>
 | |
| <pre>2   Neither s nor format shall be a null pointer. Any argument indirected though in order to store
 | |
|     converted input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.9.1.10p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vswscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent vswscanf_s performed input before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.10p4'></a>
 | |
| <pre>4   The vswscanf_s function is equivalent to swscanf_s, with the variable argument list replaced by
 | |
|     arg, which shall have been initialized by the va_start macro (and possibly subsequent va_arg
 | |
|     calls). The vswscanf_s function does not invoke the va_end macro<a href='#FOOTNOTE.525'><sup>[525]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.525'>
 | |
| <pre><i><b>Footnote 525)</b> As the functions vfwscanf_s , vwscanf_s , and vswscanf_s invoke the va_arg macro, the representation of arg after the
 | |
|     return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.10p5'></a>
 | |
| <pre>5   The vswscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the vswscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.11'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.11 [The vwprintf_s function]</h3>
 | |
| <a name='K.3.9.1.11p1'></a>
 | |
| <pre>1     Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <wchar.h>
 | |
|               int vwprintf_s(const wchar_t * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.11p2'></a>
 | |
| <pre>2   format shall not be a null pointer. The %n specifier<a href='#FOOTNOTE.526'><sup>[526]</sup></a> (modified or not by flags, field width, or
 | |
|     precision) shall not appear in the wide string pointed to by format. Any argument to vwprintf_s
 | |
|     corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.526'>
 | |
| <pre><i><b>Footnote 526)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.11p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vwprintf_s function does not attempt to produce
 | |
|     further output, and it is unspecified to what extent vwprintf_s produced output before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.11p4'></a>
 | |
| <pre>4   The vwprintf_s function is equivalent to the vwprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.11p5'></a>
 | |
| <pre>5   The vwprintf_s function returns the number of wide characters transmitted, or a negative value if
 | |
|     an output error, encoding error, or runtime-constraint violation occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.12'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.12 [The vwscanf_s function]</h3>
 | |
| <a name='K.3.9.1.12p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <stdarg.h>
 | |
|               #include <wchar.h>
 | |
|               int vwscanf_s(const wchar_t * restrict format, va_list arg);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.12p2'></a>
 | |
| <pre>2   format shall not be a null pointer. Any argument indirected though in order to store converted
 | |
|     input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.9.1.12p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the vwscanf_s function does not attempt to perform
 | |
|     further input, and it is unspecified to what extent vwscanf_s performed input before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.12p4'></a>
 | |
| <pre>4   The vwscanf_s function is equivalent to wscanf_s, with the variable argument list replaced by arg,
 | |
|     which shall have been initialized by the va_start macro (and possibly subsequent va_arg calls).
 | |
|     The vwscanf_s function does not invoke the va_end macro<a href='#FOOTNOTE.527'><sup>[527]</sup></a> .
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.527'>
 | |
| <pre><i><b>Footnote 527)</b> As the functions vfwscanf_s , vwscanf_s , and vswscanf_s invoke the va_arg macro, the representation of arg after the
 | |
|     return is indeterminate.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.12p5'></a>
 | |
| <pre>5   The vwscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the vwscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.13'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.13 [The wprintf_s function]</h3>
 | |
| <a name='K.3.9.1.13p1'></a>
 | |
| <pre>1 Synopsis
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               int wprintf_s(const wchar_t * restrict format, ...);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.13p2'></a>
 | |
| <pre>2   format shall not be a null pointer. The %n specifier<a href='#FOOTNOTE.528'><sup>[528]</sup></a> (modified or not by flags, field width, or
 | |
|     precision) shall not appear in the wide string pointed to by format. Any argument to wprintf_s
 | |
|     corresponding to a %s specifier shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.528'>
 | |
| <pre><i><b>Footnote 528)</b> It is not a runtime-constraint violation for the wide characters %n to appear in sequence in the wide string pointed at
 | |
|     by format when those wide characters are not a interpreted as a %n specifier. For example, if the entire format string was
 | |
|     L"%%n".
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.1.13p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the wprintf_s function does not attempt to produce
 | |
|     further output, and it is unspecified to what extent wprintf_s produced output before discovering
 | |
|     the runtime-constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.13p4'></a>
 | |
| <pre>4   The wprintf_s function is equivalent to the wprintf function except for the explicit runtime-
 | |
|     constraints listed above.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.13p5'></a>
 | |
| <pre>5   The wprintf_s function returns the number of wide characters transmitted, or a negative value if
 | |
|     an output error, encoding error, or runtime-constraint violation occurred.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.1.14'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.1.14 [The wscanf_s function]</h3>
 | |
| <a name='K.3.9.1.14p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               int wscanf_s(const wchar_t * restrict format, ...);
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.1.14p2'></a>
 | |
| <pre>2   format shall not be a null pointer. Any argument indirected though in order to store converted
 | |
|     input shall not be a null pointer.
 | |
| </pre>
 | |
| <a name='K.3.9.1.14p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the wscanf_s function does not attempt to perform further
 | |
|     input, and it is unspecified to what extent wscanf_s performed input before discovering the runtime-
 | |
|     constraint violation.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.1.14p4'></a>
 | |
| <pre>4   The wscanf_s function is equivalent to fwscanf_s with the argument stdin interposed before the
 | |
|     arguments to wscanf_s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.1.14p5'></a>
 | |
| <pre>5   The wscanf_s function returns the value of the macro EOF if an input failure occurs before any
 | |
|     conversion or if there is a runtime-constraint violation. Otherwise, the wscanf_s function returns
 | |
|     the number of input items assigned, which can be fewer than provided for, or even zero, in the event
 | |
|     of an early matching failure.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2 [General wide string utilities]</h3>
 | |
| <a name='K.3.9.2.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.1 [Wide string copying functions]</h3>
 | |
| <a name='K.3.9.2.1.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.1.1 [The wcscpy_s function]</h3>
 | |
| <a name='K.3.9.2.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               errno_t wcscpy_s(wchar_t *restrict s1, rsize_t s1max,
 | |
|                     const wchar_t *restrict s2);
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.1p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer.             s1max shall not be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). s1max shall not equal zero. s1max shall be greater than
 | |
|     wcsnlen_s(s2, s1max) . Copying shall not take place between objects that overlap.
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX/sizeof(wchar_t), then wcscpy_s sets s1[0] to the null wide
 | |
|     character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.1p4'></a>
 | |
| <pre>4   The wcscpy_s function copies the wide string pointed to by s2 (including the terminating null wide
 | |
|     character) into the array pointed to by s1.
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.1p5'></a>
 | |
| <pre>5   All elements following the terminating null wide character (if any) written by wcscpy_s in the array
 | |
|     of s1max wide characters pointed to by s1 take unspecified values when wcscpy_s returns.<a href='#FOOTNOTE.529'><sup>[529]</sup></a>
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.529'>
 | |
| <pre><i><b>Footnote 529)</b> This allows an implementation to copy wide characters from s2 to s1 while simultaneously checking if any of those wide
 | |
|     characters are null. Such an approach might write a wide character to every element of s1 before discovering that the first
 | |
|     element was set to the null wide character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.1.1p6'></a>
 | |
| <pre>6   The wcscpy_s function returns zero<a href='#FOOTNOTE.530'><sup>[530]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.530'>
 | |
| <pre><i><b>Footnote 530)</b> A zero return value implies that all of the requested wide characters from the string pointed to by s2 fit within the array
 | |
|     pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.1.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.1.2 [The wcsncpy_s function]</h3>
 | |
| <a name='K.3.9.2.1.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               errno_t wcsncpy_s(wchar_t * restrict s1, rsize_t s1max,
 | |
|                     const wchar_t * restrict s2, rsize_t n);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.2p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). s1max shall not equal zero. If n is not less than s1max, then
 | |
|     s1max shall be greater than wcsnlen_s(s2, s1max) . Copying shall not take place between objects
 | |
|     that overlap.
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX/sizeof(wchar_t), then wcsncpy_s sets s1[0] to the null
 | |
|     wide character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.2p4'></a>
 | |
| <pre>4   The wcsncpy_s function copies not more than n successive wide characters (wide characters that
 | |
|     follow a null wide character are not copied) from the array pointed to by s2 to the array pointed to
 | |
|     by s1. If no null wide character was copied from s2, then s1[n] is set to a null wide character.
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.2p5'></a>
 | |
| <pre>5   All elements following the terminating null wide character (if any) written by wcsncpy_s in the array
 | |
|     of s1max wide characters pointed to by s1 take unspecified values when wcsncpy_s returns.<a href='#FOOTNOTE.531'><sup>[531]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.531'>
 | |
| <pre><i><b>Footnote 531)</b> This allows an implementation to copy wide characters from s2 to s1 while simultaneously checking if any of those wide
 | |
|     characters are null. Such an approach might write a wide character to every element of s1 before discovering that the first
 | |
|     element was set to the null wide character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.1.2p6'></a>
 | |
| <pre>6   The wcsncpy_s function returns zero<a href='#FOOTNOTE.532'><sup>[532]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.532'>
 | |
| <pre><i><b>Footnote 532)</b> A zero return value implies that all of the requested wide characters from the string pointed to by s2 fit within the array
 | |
|     pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.1.2p7'></a>
 | |
| <pre>7   EXAMPLE 1 The wcsncpy_s function can be used to copy a wide string without the danger that the result will not be null
 | |
|     terminated or that wide characters will be written past the end of the destination array.
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               /* ... */
 | |
|               wchar_t src1[100] = L"hello";
 | |
|               wchar_t src2[7] = {L’g’, L’o’, L’o’, L’d’, L’b’, L’y’, L’e’};
 | |
|               wchar_t dst1[6], dst2[5], dst3[5];
 | |
|               int r1, r2, r3;
 | |
|               r1 = wcsncpy_s(dst1, 6, src1, 100);
 | |
|               r2 = wcsncpy_s(dst2, 5, src2, 7);
 | |
|               r3 = wcsncpy_s(dst3, 5, src2, 4);
 | |
| 
 | |
|     The first call will assign to r1 the value zero and to dst1 the sequence of wide characters hello\0.
 | |
|     The second call will assign to r2 a nonzero value and to dst2 the sequence of wide characters \0.
 | |
|     The third call will assign to r3 the value zero and to dst3 the sequence of wide characters good\0.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.1.3 [The wmemcpy_s function]</h3>
 | |
| <a name='K.3.9.2.1.3p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               errno_t wmemcpy_s(wchar_t *restrict s1, rsize_t s1max,
 | |
|                     const wchar_t *restrict s2, rsize_t n);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.3p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). n shall not be greater than s1max. Copying shall not take
 | |
|     place between objects that overlap.
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.3p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the wmemcpy_s function stores zeros in the first s1max wide
 | |
|     characters of the object pointed to by s1 if s1 is not a null pointer and s1max is not greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t).
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.3p4'></a>
 | |
| <pre>4   The wmemcpy_s function copies n successive wide characters from the object pointed to by s2 into
 | |
|     the object pointed to by s1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.3p5'></a>
 | |
| <pre>5   The wmemcpy_s function returns zero if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.1.4 [The wmemmove_s function]</h3>
 | |
| <a name='K.3.9.2.1.4p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               errno_t wmemmove_s(wchar_t *s1, rsize_t s1max, const wchar_t *s2, rsize_t n);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.4p2'></a>
 | |
| <pre>2   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). n shall not be greater than s1max.
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.4p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, the wmemmove_s function stores zeros in the first s1max
 | |
|     wide characters of the object pointed to by s1 if s1 is not a null pointer and s1max is not greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t).
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.4p4'></a>
 | |
| <pre>4   The wmemmove_s function copies n successive wide characters from the object pointed to by s2 into
 | |
|     the object pointed to by s1. This copying takes place as if the n wide characters from the object
 | |
|     pointed to by s2 are first copied into a temporary array of n wide characters that does not overlap
 | |
|     the objects pointed to by s1 or s2, and then the n wide characters from the temporary array are
 | |
|     copied into the object pointed to by s1.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.2.1.4p5'></a>
 | |
| <pre>5   The wmemmove_s function returns zero if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.2.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.2 [Wide string concatenation functions]</h3>
 | |
| <a name='K.3.9.2.2.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.2.1 [The wcscat_s function]</h3>
 | |
| <a name='K.3.9.2.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               errno_t wcscat_s(wchar_t * restrict s1, rsize_t s1max,
 | |
|                     const wchar_t * restrict s2);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.1p2'></a>
 | |
| <pre>2   Let m denote the value s1max - wcsnlen_s(s1, s1max) upon entry to wcscat_s.
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.1p3'></a>
 | |
| <pre>3   Neither s1 nor s2 shall be a null pointer.              s1max shall not be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). s1max shall not equal zero. m shall not equal zero.<a href='#FOOTNOTE.533'><sup>[533]</sup></a>              m
 | |
|     shall be greater than wcsnlen_s(s2, m). Copying shall not take place between objects that overlap.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.533'>
 | |
| <pre><i><b>Footnote 533)</b> Zero means that s1 was not null terminated upon entry to wcscat_s .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.2.1p4'></a>
 | |
| <pre>4   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX/sizeof(wchar_t), then wcscat_s sets s1[0] to the null wide
 | |
|     character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.1p5'></a>
 | |
| <pre>5   The wcscat_s function appends a copy of the wide string pointed to by s2 (including the terminating
 | |
|     null wide character) to the end of the wide string pointed to by s1. The initial wide character from
 | |
|     s2 overwrites the null wide character at the end of s1.
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.1p6'></a>
 | |
| <pre>6   All elements following the terminating null wide character (if any) written by wcscat_s in the array
 | |
|     of s1max wide characters pointed to by s1 take unspecified values when wcscat_s returns.<a href='#FOOTNOTE.534'><sup>[534]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.534'>
 | |
| <pre><i><b>Footnote 534)</b> This allows an implementation to append wide characters from s2 to s1 while simultaneously checking if any of those
 | |
|     wide characters are null. Such an approach might write a wide character to every element of s1 before discovering that the
 | |
|     first element was set to the null wide character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.2.1p7'></a>
 | |
| <pre>7   The wcscat_s function returns zero<a href='#FOOTNOTE.535'><sup>[535]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.535'>
 | |
| <pre><i><b>Footnote 535)</b> A zero return value implies that all of the requested wide characters from the wide string pointed to by s2 were appended
 | |
|     to the wide string pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.2.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.2.2 [The wcsncat_s function]</h3>
 | |
| <a name='K.3.9.2.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               errno_t wcsncat_s(wchar_t * restrict s1, rsize_t s1max,
 | |
|                     const wchar_t * restrict s2, rsize_t n);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.2p2'></a>
 | |
| <pre>2   Let m denote the value s1max - wcsnlen_s(s1, s1max) upon entry to wcsncat_s.
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.2p3'></a>
 | |
| <pre>3   Neither s1 nor s2 shall be a null pointer. Neither s1max nor n shall be greater than
 | |
|     RSIZE_MAX/sizeof(wchar_t). s1max shall not equal zero. m shall not equal zero.<a href='#FOOTNOTE.536'><sup>[536]</sup></a> If n
 | |
|     is not less than m, then m shall be greater than wcsnlen_s(s2, m). Copying shall not take place
 | |
|     between objects that overlap.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.536'>
 | |
| <pre><i><b>Footnote 536)</b> Zero means that s1 was not null terminated upon entry to wcsncat_s .
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.2.2p4'></a>
 | |
| <pre>4   If there is a runtime-constraint violation, then if s1 is not a null pointer and s1max is greater than
 | |
|     zero and not greater than RSIZE_MAX/sizeof(wchar_t), then wcsncat_s sets s1[0] to the null
 | |
|     wide character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.2p5'></a>
 | |
| <pre>5   The wcsncat_s function appends not more than n successive wide characters (wide characters that
 | |
|     follow a null wide character are not copied) from the array pointed to by s2 to the end of the wide
 | |
|     string pointed to by s1. The initial wide character from s2 overwrites the null wide character at the
 | |
|     end of s1. If no null wide character was copied from s2, then s1[s1max- m +n] is set to a null wide
 | |
|     character.
 | |
| </pre>
 | |
| <a name='K.3.9.2.2.2p6'></a>
 | |
| <pre>6   All elements following the terminating null wide character (if any) written by wcsncat_s in the array
 | |
|     of s1max wide characters pointed to by s1 take unspecified values when wcsncat_s returns.<a href='#FOOTNOTE.537'><sup>[537]</sup></a>
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='FOOTNOTE.537'>
 | |
| <pre><i><b>Footnote 537)</b> This allows an implementation to append wide characters from s2 to s1 while simultaneously checking if any of those
 | |
|     wide characters are null. Such an approach might write a wide character to every element of s1 before discovering that the
 | |
|     first element was set to the null wide character.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.2.2p7'></a>
 | |
| <pre>7   The wcsncat_s function returns zero<a href='#FOOTNOTE.538'><sup>[538]</sup></a> if there was no runtime-constraint violation. Otherwise, a
 | |
|     nonzero value is returned.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.538'>
 | |
| <pre><i><b>Footnote 538)</b> A zero return value implies that all of the requested wide characters from the wide string pointed to by s2 were appended
 | |
|     to the wide string pointed to by s1 and that the result in s1 is null terminated.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.2.2p8'></a>
 | |
| <pre>8   EXAMPLE 1 The wcsncat_s function can be used to copy a wide string without the danger that the result will not be null
 | |
|     terminated or that wide characters will be written past the end of the destination array.
 | |
| 
 | |
|               #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               /* ... */
 | |
|               wchar_t s1[100] = L"good";
 | |
|               wchar_t s2[6] = L"hello";
 | |
|               wchar_t s3[6] = L"hello";
 | |
|               wchar_t s4[7] = L"abc";
 | |
|               wchar_t s5[1000] = L"bye";
 | |
|               int r1, r2, r3, r4;
 | |
|               r1 = wcsncat_s(s1, 100, s5, 1000);
 | |
|               r2 = wcsncat_s(s2, 6, L"", 1);
 | |
|               r3 = wcsncat_s(s3, 6, L"X", 2);
 | |
|               r4 = wcsncat_s(s4, 7, L"defghijklmn", 3);
 | |
| 
 | |
|     After the first call r1 will have the value zero and s1 will be the wide character sequence goodbye\0.
 | |
|     After the second call r2 will have the value zero and s2 will be the wide character sequence hello\0.
 | |
|     After the third call r3 will have a nonzero value and s3 will be the wide character sequence \0.
 | |
|     After the fourth call r4 will have the value zero and s4 will be the wide character sequence abcdef\0.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.2.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.3 [Wide string search functions]</h3>
 | |
| <a name='K.3.9.2.3.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.3.1 [The wcstok_s function]</h3>
 | |
| <a name='K.3.9.2.3.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|               #include <wchar.h>
 | |
|               wchar_t *wcstok_s(wchar_t * restrict s1, rsize_t * restrict s1max,
 | |
|                     const wchar_t * restrict s2, wchar_t ** restrict ptr);
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p2'></a>
 | |
| <pre>2   None of s1max, s2, or ptr shall be a null pointer. If s1 is a null pointer, then *ptr shall not be a null
 | |
|     pointer. The value of *s1max shall not be greater than RSIZE_MAX/sizeof(wchar_t). The end of
 | |
|      the token found shall occur within the first *s1max wide characters of s1 for the first call, and shall
 | |
|      occur within the first *s1max wide characters of where searching resumes on subsequent calls.
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p3'></a>
 | |
| <pre>3    If there is a runtime-constraint violation, the wcstok_s function does not indirect through the s1 or
 | |
|      s2 pointers, and does not store a value in the object pointed to by ptr.
 | |
| 
 | |
|      Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p4'></a>
 | |
| <pre>4    A sequence of calls to the wcstok_s function breaks the wide string pointed to by s1 into a sequence
 | |
|      of tokens, each of which is delimited by a wide character from the wide string pointed to by s2.
 | |
|      The fourth argument points to a caller-provided wchar_t pointer into which the wcstok_s function
 | |
|      stores information necessary for it to continue scanning the same wide string.
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p5'></a>
 | |
| <pre>5    The first call in a sequence has a non-null first argument and s1max points to an object whose value
 | |
|      is the number of elements in the wide character array pointed to by the first argument. The first call
 | |
|      stores an initial value in the object pointed to by ptr and updates the value pointed to by s1max
 | |
|      to reflect the number of elements that remain in relation to ptr. Subsequent calls in the sequence
 | |
|      have a null first argument and the objects pointed to by s1max and ptr are required to have the
 | |
|      values stored by the previous call in the sequence, which are then updated. The separator wide
 | |
|      string pointed to by s2 may be different from call to call.
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p6'></a>
 | |
| <pre>6    The first call in the sequence searches the wide string pointed to by s1 for the first wide character
 | |
|      that is not contained in the current separator wide string pointed to by s2. If no such wide character
 | |
|      is found, then there are no tokens in the wide string pointed to by s1 and the wcstok_s function
 | |
|      returns a null pointer. If such a wide character is found, it is the start of the first token.
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p7'></a>
 | |
| <pre>7    The wcstok_s function then searches from there for the first wide character in s1 that is contained
 | |
|      in the current separator wide string. If no such wide character is found, the current token extends
 | |
|      to the end of the wide string pointed to by s1, and subsequent searches in the same wide string
 | |
|      for a token return a null pointer. If such a wide character is found, it is overwritten by a null wide
 | |
|      character, which terminates the current token.
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p8'></a>
 | |
| <pre>8    In all cases, the wcstok_s function stores sufficient information in the pointer pointed to by ptr so
 | |
|      that subsequent calls, with a null pointer for s1 and the unmodified pointer value for ptr, shall start
 | |
|      searching just past the element overwritten by a null wide character (if any).
 | |
| 
 | |
|      Returns
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p9'></a>
 | |
| <pre>9    The wcstok_s function returns a pointer to the first wide character of a token, or a null pointer if
 | |
|      there is no token or there is a runtime-constraint violation.
 | |
| </pre>
 | |
| <a name='K.3.9.2.3.1p10'></a>
 | |
| <pre>10   EXAMPLE
 | |
| 
 | |
|              #define __STDC_WANT_LIB_EXT1__ 1
 | |
|              #include <wchar.h>
 | |
|              static wchar_t str1[] = L"?a???b,,,#c";
 | |
|              static wchar_t str2[] = L"\t \t";
 | |
|              wchar_t *t, *ptr1, *ptr2;
 | |
|              rsize_t max1 = wcslen(str1)+1;
 | |
|              rsize_t max2 = wcslen(str2)+1;
 | |
| 
 | |
|              t = wcstok_s(str1, &max1, "?", &ptr1);           // t points to the token "a"
 | |
|              t = wcstok_s(NULL, &max1, ",", &ptr1);           // t points to the token "??b"
 | |
|              t = wcstok_s(str2, &max2, " \t", &ptr2);         // t is a null pointer
 | |
|              t = wcstok_s(NULL, &max1, "#,", &ptr1);          // t points to the token "c"
 | |
|              t = wcstok_s(NULL, &max1, "?", &ptr1);           // t is a null pointer
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.2.4'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.4 [Miscellaneous functions]</h3>
 | |
| <a name='K.3.9.2.4.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.2.4.1 [The wcsnlen_s function]</h3>
 | |
| <a name='K.3.9.2.4.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|             #define __STDC_WANT_LIB_EXT1__ 1
 | |
|              #include <wchar.h>
 | |
|              size_t wcsnlen_s(const wchar_t *s, size_t maxsize);
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.2.4.1p2'></a>
 | |
| <pre>2   The wcsnlen_s function computes the length of the wide string pointed to by s.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.2.4.1p3'></a>
 | |
| <pre>3   If s is a null pointer,<a href='#FOOTNOTE.539'><sup>[539]</sup></a> then the wcsnlen_s function returns zero.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.539'>
 | |
| <pre><i><b>Footnote 539)</b> Note that the wcsnlen_s function has no runtime-constraints. This lack of runtime-constraints along with the values
 | |
|     returned for a null pointer or an unterminated wide string argument make wcsnlen_s useful in algorithms that gracefully
 | |
|     handle such exceptional data.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.2.4.1p4'></a>
 | |
| <pre>4   Otherwise, the wcsnlen_s function returns the number of wide characters that precede the termi-
 | |
|     nating null wide character. If there is no null wide character in the first maxsize wide characters of
 | |
|     s then wcsnlen_s returns maxsize. At most the first maxsize wide characters of s shall be accessed
 | |
|     by wcsnlen_s.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.3'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.3 [Extended multibyte/wide character conversion utilities]</h3>
 | |
| <a name='K.3.9.3.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.3.1 [Restartable multibyte/wide character conversion functions]</h3>
 | |
| <a name='K.3.9.3.1p1'></a>
 | |
| <pre>1   Unlike wcrtomb, wcrtomb_s does not permit the ps parameter (the pointer to the conversion state)
 | |
|     to be a null pointer.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.3.1.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.3.1.1 [The wcrtomb_s function]</h3>
 | |
| <a name='K.3.9.3.1.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               errno_t wcrtomb_s(size_t * restrict retval, char * restrict s, rsize_t smax,
 | |
|                     wchar_t wc, mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.3.1.1p2'></a>
 | |
| <pre>2   Neither retval nor ps shall be a null pointer. If s is not a null pointer, then smax shall not equal
 | |
|     zero and shall not be greater than RSIZE_MAX. If s is not a null pointer, then smax shall be not be less
 | |
|     than the number of bytes to be stored in the array pointed to by s. If s is a null pointer, then smax
 | |
|     shall equal zero.
 | |
| </pre>
 | |
| <a name='K.3.9.3.1.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then wcrtomb_s does the following. If s is not a null pointer
 | |
|     and smax is greater than zero and not greater than RSIZE_MAX, then wcrtomb_s sets s[0] to the null
 | |
|     character. If retval is not a null pointer, then wcrtomb_s sets *retval to (size_t)(-1) .
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.3.1.1p4'></a>
 | |
| <pre>4   If s is a null pointer, the wcrtomb_s function is equivalent to the call
 | |
| 
 | |
|                       wcrtomb_s(&retval, buf, sizeof buf, L’\0’, ps)
 | |
| 
 | |
| 
 | |
|     where retval and buf are internal variables of the appropriate types, and the size of buf is greater
 | |
|     than MB_CUR_MAX.
 | |
| </pre>
 | |
| <a name='K.3.9.3.1.1p5'></a>
 | |
| <pre>5   If s is not a null pointer, the wcrtomb_s function determines the number of bytes needed to represent
 | |
|     the multibyte character that corresponds to the wide character given by wc (including any shift
 | |
|     sequences), and stores the multibyte character representation in the array whose first element is
 | |
|     pointed to by s. At most MB_CUR_MAX bytes are stored. If wc is a null wide character, a null byte is
 | |
|     stored, preceded by any shift sequence needed to restore the initial shift state; the resulting state
 | |
|     described is the initial conversion state.
 | |
| </pre>
 | |
| <a name='K.3.9.3.1.1p6'></a>
 | |
| <pre>6   If wc does not correspond to a valid multibyte character, an encoding error occurs: the wcrtomb_s
 | |
|     function stores the value (size_t)(-1) into *retval and the conversion state is unspecified.
 | |
|     Otherwise, the wcrtomb_s function stores into *retval the number of bytes (including any shift
 | |
|     sequences) stored in the array pointed to by s.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.3.1.1p7'></a>
 | |
| <pre>7   The wcrtomb_s function returns zero if no runtime-constraint violation and no encoding error
 | |
|     occurred. Otherwise, a nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.3.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.3.2 [Restartable multibyte/wide string conversion functions]</h3>
 | |
| <a name='K.3.9.3.2p1'></a>
 | |
| <pre>1   Unlike mbsrtowcs and wcsrtombs, mbsrtowcs_s and wcsrtombs_s do not permit the ps parameter
 | |
|     (the pointer to the conversion state) to be a null pointer.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.1'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.3.2.1 [The mbsrtowcs_s function]</h3>
 | |
| <a name='K.3.9.3.2.1p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               errno_t mbsrtowcs_s(size_t * restrict retval, wchar_t * restrict dst,
 | |
|                     rsize_t dstmax, const char ** restrict src, rsize_t len,
 | |
|                     mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.1p2'></a>
 | |
| <pre>2   None of retval, src, *src , or ps shall be null pointers. If dst is not a null pointer, then neither
 | |
|     len nor dstmax shall be greater than RSIZE_MAX/sizeof(wchar_t). If dst is a null pointer, then
 | |
|     dstmax shall equal zero. If dst is not a null pointer, then dstmax shall not equal zero. If dst is not a
 | |
|     null pointer and len is not less than dstmax, then a null character shall occur within the first dstmax
 | |
|     multibyte characters of the array pointed to by *src .
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.1p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then mbsrtowcs_s does the following. If retval is not
 | |
|     a null pointer, then mbsrtowcs_s sets *retval to (size_t)(-1) . If dst is not a null pointer and
 | |
|     dstmax is greater than zero and not greater than RSIZE_MAX/sizeof(wchar_t), then mbsrtowcs_s
 | |
|     sets dst[0] to the null wide character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.1p4'></a>
 | |
| <pre>4   The mbsrtowcs_s function converts a sequence of multibyte characters that begins in the conversion
 | |
|     state described by the object pointed to by ps, from the array indirectly pointed to by src into a
 | |
|     sequence of corresponding wide characters. If dst is not a null pointer, the converted characters are
 | |
|     stored into the array pointed to by dst. Conversion continues up to and including a terminating null
 | |
|     character, which is also stored. Conversion stops earlier in two cases: when a sequence of bytes is
 | |
|     encountered that does not form a valid multibyte character, or (if dst is not a null pointer) when len
 | |
|     wide characters have been stored into the array pointed to by dst.<a href='#FOOTNOTE.540'><sup>[540]</sup></a> If dst is not a null pointer
 | |
|     and no null wide character was stored into the array pointed to by dst, then dst[len] is set to the
 | |
|     null wide character. Each conversion takes place as if by a call to the mbrtowc function.
 | |
| </pre>
 | |
| <a name='FOOTNOTE.540'>
 | |
| <pre><i><b>Footnote 540)</b> Thus, the value of len is ignored if dst is a null pointer.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.3.2.1p5'></a>
 | |
| <pre>5   If dst is not a null pointer, the pointer object pointed to by src is assigned either a null pointer (if
 | |
|     conversion stopped due to reaching a terminating null character) or the address just past the last
 | |
|     multibyte character converted (if any). If conversion stopped due to reaching a terminating null
 | |
|     character and if dst is not a null pointer, the resulting state described is the initial conversion state.
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.1p6'></a>
 | |
| <pre>6   Regardless of whether dst is or is not a null pointer, if the input conversion encounters a sequence
 | |
|     of bytes that do not form a valid multibyte character, an encoding error occurs: the mbsrtowcs_s
 | |
|     function stores the value (size_t)(-1) into *retval and the conversion state is unspecified.
 | |
|     Otherwise, the mbsrtowcs_s function stores into *retval the number of multibyte characters
 | |
|     successfully converted, not including the terminating null character (if any).
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.1p7'></a>
 | |
| <pre>7   All elements following the terminating null wide character (if any) written by mbsrtowcs_s in the
 | |
|     array of dstmax wide characters pointed to by dst take unspecified values when mbsrtowcs_s
 | |
|     returns.<a href='#FOOTNOTE.541'><sup>[541]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.541'>
 | |
| <pre><i><b>Footnote 541)</b> This allows an implementation to attempt converting the multibyte string before discovering a terminating null character
 | |
|     did not occur where required.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.3.2.1p8'></a>
 | |
| <pre>8   If copying takes place between objects that overlap, the objects take on unspecified values.
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.1p9'></a>
 | |
| <pre>9   The mbsrtowcs_s function returns zero if no runtime-constraint violation and no encoding error
 | |
|     occurred. Otherwise, a nonzero value is returned.
 | |
| 
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.2'></a>
 | |
| <hr>
 | |
| <h3>K.3.9.3.2.2 [The wcsrtombs_s function]</h3>
 | |
| <a name='K.3.9.3.2.2p1'></a>
 | |
| <pre>1 Synopsis
 | |
|              #include <wchar.h>
 | |
|               errno_t wcsrtombs_s(size_t * restrict retval, char * restrict dst,
 | |
|                     rsize_t dstmax, const wchar_t ** restrict src, rsize_t len,
 | |
|                     mbstate_t * restrict ps);
 | |
| 
 | |
| 
 | |
| 
 | |
|     Runtime-constraints
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.2p2'></a>
 | |
| <pre>2   None of retval, src, *src , or ps shall be null pointers. If dst is not a null pointer, then neither len
 | |
|     shall be greater than RSIZE_MAX/sizeof(wchar_t) nor dstmax shall be greater than RSIZE_MAX. If
 | |
|     dst is a null pointer, then dstmax shall equal zero. If dst is not a null pointer, then dstmax shall not
 | |
|     equal zero. If dst is not a null pointer and len is not less than dstmax, then the conversion shall
 | |
|     have been stopped (see below) because a terminating null wide character was reached or because an
 | |
|     encoding error occurred.
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.2p3'></a>
 | |
| <pre>3   If there is a runtime-constraint violation, then wcsrtombs_s does the following. If retval is not
 | |
|     a null pointer, then wcsrtombs_s sets *retval to (size_t)(-1) . If dst is not a null pointer and
 | |
|     dstmax is greater than zero and not greater than RSIZE_MAX, then wcsrtombs_s sets dst[0] to the
 | |
|     null character.
 | |
| 
 | |
|     Description
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.2p4'></a>
 | |
| <pre>4   The wcsrtombs_s function converts a sequence of wide characters from the array indirectly pointed
 | |
|     to by src into a sequence of corresponding multibyte characters that begins in the conversion state
 | |
|     described by the object pointed to by ps. If dst is not a null pointer, the converted characters are then
 | |
|     stored into the array pointed to by dst. Conversion continues up to and including a terminating
 | |
|     null wide character, which is also stored. Conversion stops earlier in two cases:
 | |
| 
 | |
|       — when a wide character is reached that does not correspond to a valid multibyte character;
 | |
| 
 | |
|       — (if dst is not a null pointer) when the next multibyte character would exceed the limit of n
 | |
|         total bytes to be stored into the array pointed to by dst. If the wide character being converted
 | |
|         is the null wide character, then n is the lesser of len or dstmax. Otherwise, n is the lesser of
 | |
|         len or dstmax-1.
 | |
| 
 | |
|     If the conversion stops without converting a null wide character and dst is not a null pointer, then
 | |
|     a null character is stored into the array pointed to by dst immediately following any multibyte
 | |
|     characters already stored. Each conversion takes place as if by a call to the wcrtomb function.<a href='#FOOTNOTE.542'><sup>[542]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.542'>
 | |
| <pre><i><b>Footnote 542)</b> If conversion stops because a terminating null wide character has been reached, the bytes stored include those necessary
 | |
|     to reach the initial shift state immediately before the null byte. However, if the conversion stops before a terminating null
 | |
|     wide character has been reached, the result will be null terminated, but might not end in the initial shift state.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.3.2.2p5'></a>
 | |
| <pre>5   If dst is not a null pointer, the pointer object pointed to by src is assigned either a null pointer (if
 | |
|     conversion stopped due to reaching a terminating null wide character) or the address just past the
 | |
|     last wide character converted (if any). If conversion stopped due to reaching a terminating null wide
 | |
|     character, the resulting state described is the initial conversion state.
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.2p6'></a>
 | |
| <pre>6   Regardless of whether dst is or is not a null pointer, if the input conversion encounters a wide
 | |
|     character that does not correspond to a valid multibyte character, an encoding error occurs: the
 | |
|     wcsrtombs_s function stores the value (size_t)(-1) into *retval and the conversion state is
 | |
|     unspecified. Otherwise, the wcsrtombs_s function stores into *retval the number of bytes in the
 | |
|     resulting multibyte character sequence, not including the terminating null character (if any).
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.2p7'></a>
 | |
| <pre>7   All elements following the terminating null character (if any) written by wcsrtombs_s in the array
 | |
|     of dstmax elements pointed to by dst take unspecified values when wcsrtombs_s returns.<a href='#FOOTNOTE.543'><sup>[543]</sup></a>
 | |
| </pre>
 | |
| <a name='FOOTNOTE.543'>
 | |
| <pre><i><b>Footnote 543)</b> When len is not less than dstmax, the implementation might fill the array before discovering a runtime-constraint
 | |
|     violation.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='K.3.9.3.2.2p8'></a>
 | |
| <pre>8   If copying takes place between objects that overlap, the objects take on unspecified values.
 | |
| 
 | |
|     Returns
 | |
| </pre>
 | |
| <a name='K.3.9.3.2.2p9'></a>
 | |
| <pre>9   The wcsrtombs_s function returns zero if no runtime-constraint violation and no encoding error
 | |
|     occurred. Otherwise, a nonzero value is returned.
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='L.'></a>
 | |
| <hr>
 | |
| <h3>L. [Annex L (normative) Analyzability]</h3>
 | |
| <a name='L.1'></a>
 | |
| <hr>
 | |
| <h3>L.1 [Scope]</h3>
 | |
| <a name='L.1p1'></a>
 | |
| <pre>1   This annex specifies optional behavior that can aid in the analyzability of C programs.
 | |
| </pre>
 | |
| <a name='L.1p2'></a>
 | |
| <pre>2   An implementation that defines __STDC_ANALYZABLE__ shall conform to the specifications in this
 | |
|     annex.<a href='#FOOTNOTE.544'><sup>[544]</sup></a>
 | |
| 
 | |
| </pre>
 | |
| <a name='FOOTNOTE.544'>
 | |
| <pre><i><b>Footnote 544)</b> Implementations that do not define __STDC_ANALYZABLE__ are not required to conform to these specifications.
 | |
| </i></pre>
 | |
| </a>
 | |
| <a name='L.2'></a>
 | |
| <hr>
 | |
| <h3>L.2 [Definitions]</h3>
 | |
| <a name='L.2.1'></a>
 | |
| <hr>
 | |
| <h3>L.2.1 [Definitions]</h3>
 | |
| <a name='L.2.1p1'></a>
 | |
| <pre>1   out-of-bounds store
 | |
|     an (attempted) access (<a href='#3.1'>3.1</a>) that, at run time, for a given computational state, would modify (or, for
 | |
|     an object declared volatile, fetch) one or more bytes that lie outside the bounds permitted by this
 | |
|     document.
 | |
| 
 | |
| </pre>
 | |
| <a name='L.2.2'></a>
 | |
| <hr>
 | |
| <h3>L.2.2 [Definitions]</h3>
 | |
| <a name='L.2.2p1'></a>
 | |
| <pre>1   bounded undefined behavior
 | |
|     undefined behavior (<a href='#3.4.3'>3.4.3</a>) that does not perform an out-of-bounds store.
 | |
| </pre>
 | |
| <a name='L.2.2p2'></a>
 | |
| <pre>2   Note 1 to entry: The behavior might perform a trap.
 | |
| </pre>
 | |
| <a name='L.2.2p3'></a>
 | |
| <pre>3   Note 2 to entry: Any values produced might be unspecified values, and the representation of objects that are written to
 | |
|     might become indeterminate.
 | |
| 
 | |
| </pre>
 | |
| <a name='L.2.3'></a>
 | |
| <hr>
 | |
| <h3>L.2.3 [Definitions]</h3>
 | |
| <a name='L.2.3p1'></a>
 | |
| <pre>1   critical undefined behavior
 | |
|     undefined behavior that is not bounded undefined behavior.
 | |
| </pre>
 | |
| <a name='L.2.3p2'></a>
 | |
| <pre>2   Note 1 to entry: The behavior might perform an out-of-bounds store or perform a trap.
 | |
| 
 | |
| </pre>
 | |
| <a name='L.3'></a>
 | |
| <hr>
 | |
| <h3>L.3 [Requirements]</h3>
 | |
| <a name='L.3p1'></a>
 | |
| <pre>1   If the program performs a trap (<a href='#3.19.5'>3.19.5</a>), the implementation is permitted to invoke a runtime-
 | |
|     constraint handler. Any such semantics are implementation-defined.
 | |
| </pre>
 | |
| <a name='L.3p2'></a>
 | |
| <pre>2   All undefined behavior shall be limited to bounded undefined behavior, except for the following
 | |
|     which are permitted to result in critical undefined behavior:
 | |
| 
 | |
|       — An object is referred to outside of its lifetime (<a href='#6.2.4'>6.2.4</a>).
 | |
| 
 | |
|       — A store is performed to an object that has two incompatible declarations (<a href='#6.2.7'>6.2.7</a>),
 | |
| 
 | |
|       — A pointer is used to call a function whose type is not compatible with the referenced type
 | |
|         (<a href='#6.2.7'>6.2.7</a>, <a href='#6.3.2.3'>6.3.2.3</a>, <a href='#6.5.2.2'>6.5.2.2</a>).
 | |
| 
 | |
|       — An lvalue does not designate an object when evaluated (<a href='#6.3.2.1'>6.3.2.1</a>).
 | |
| 
 | |
|       — The program attempts to modify a string literal (<a href='#6.4.5'>6.4.5</a>).
 | |
| 
 | |
|       — The operand of the unary * operator has an invalid value (<a href='#6.5.3.2'>6.5.3.2</a>).
 | |
| 
 | |
|       — Addition or subtraction of a pointer into, or just beyond, an array object and an integer type
 | |
|         produces a result that points just beyond the array object and is used as the operand of a unary
 | |
|         * operator that is evaluated (<a href='#6.5.6'>6.5.6</a>).
 | |
| 
 | |
|       — An attempt is made to modify an object defined with a const-qualified type through use of an
 | |
|         lvalue with non-const-qualified type (<a href='#6.7.3'>6.7.3</a>).
 | |
| — An argument to a function or macro defined in the standard library has an invalid value or a
 | |
|   type not expected by a function with variable number of arguments (<a href='#7.1.4'>7.1.4</a>).
 | |
| — The longjmp function is called with a jmp_buf argument where the most recent invocation
 | |
|   of the setjmp macro in the same invocation of the program with the corresponding jmp_buf
 | |
|   argument is nonexistent, or the invocation was from another thread of execution, or the
 | |
|   function containing the invocation has terminated execution in the interim, or the invocation
 | |
|   was within the scope of an identifier with variably modified type and execution has left that
 | |
|   scope in the interim (<a href='#7.13.2.1'>7.13.2.1</a>).
 | |
| — The value of a pointer that refers to space deallocated by a call to the free or realloc function is
 | |
|   used (<a href='#7.24.3'>7.24.3</a>).
 | |
| — A string or wide string utility function accesses an array beyond the end of an object (<a href='#7.26.1'>7.26.1</a>,
 | |
|   and <a href='#7.31.4'>7.31.4</a>).
 | |
| 
 | |
| 
 | |
| </pre>
 | |
| <a name='M.'></a>
 | |
| <hr>
 | |
| <h3>M. [Annex M (informative) Change History]</h3>
 | |
| <a name='M.1'></a>
 | |
| <hr>
 | |
| <h3>M.1 [Fifth Edition]</h3>
 | |
| <a name='M.1p1'></a>
 | |
| <pre>1   Major changes in this fifth edition (__STDC_VERSION__ 202311L) include:
 | |
| 
 | |
|       — allowed for implementations to provide keywords such as bool, static_assert, true, false,
 | |
|         and others with additional support to define them as macros and enable transition of programs
 | |
|         easily;
 | |
| 
 | |
|       — removed obsolete sign representations and integer width constraints (so-called "2’s comple-
 | |
|         ment");
 | |
| 
 | |
|       — added a one-argument version of static_assert;
 | |
| 
 | |
|       — removed support for function definitions with identifier lists;
 | |
| 
 | |
|       — mandated function declarations whose parameter list is empty by the same as parameter list
 | |
|         which only contain a single void;
 | |
| 
 | |
|       — harmonization with ISO/IEC 9945 (POSIX):
 | |
| 
 | |
|             • extended month name formats for strftime
 | |
|             • integration of functions: gmtime_r, localtime_r, memccpy, strdup, strndup
 | |
| 
 | |
|       — harmonization with floating point standard IEC 60559:
 | |
| 
 | |
|             • integration of binary floating-point technical specification TS 18661-1
 | |
|             • integration of decimal floating-point technical specification TS 18661-2
 | |
|             • integration of decimal floating-point technical specification TS 18661-4a
 | |
| 
 | |
|       — made the DECIMAL_DIG macro obsolescent;
 | |
| 
 | |
|       — added version test macros to certain library headers to aid in upgrading and portability to be
 | |
|         used alongside the __STDC_VERSION__ macro;
 | |
| 
 | |
|       — added the attributes feature, which includes the attributes:
 | |
| 
 | |
|             • deprecated, for marking entites as discouraged for future use;
 | |
|             • fallthrough, for explicitly marking cases where fallthrough in switches or labels is
 | |
|               intended rather than accidental;
 | |
|             • maybe_unused, for marking entities which may end up not being used;
 | |
|             • nodiscard, for marking entities which, when used, should have their value handled in
 | |
|               some way by a program;
 | |
|             • reproducible, for marking function types for which inputs may always produce pre-
 | |
|               dictable output if given the same input (e.g., cached data) but for which the order of such
 | |
|               calls still matter;
 | |
|             • unsequenced, for marking function types which always produce predictable output and
 | |
|               have no dependencies upon other data (and other relevant caveats), and,
 | |
|             • _Noreturn , for indicating a function shall never return;
 | |
| 
 | |
|       — added the u8 character prefix to match the u8 string prefix;
 | |
| 
 | |
|       — mandated all u8, u, and U strings be UTF-8, UTF-16, and UTF-32, respectively, as defined by
 | |
|         ISO/IEC 10646;
 | |
| — separated the literal, wide literal, and UTF-8 literal, UTF-16 literal, and UTF-32 literal encodings
 | |
|   for strings and characters and now have a solely execution-based version of these, particularly
 | |
|   execution and wide execution encodings;
 | |
| 
 | |
| — added mbrtoc8 and c8rtomb functions missing from <uchar.h>;
 | |
| 
 | |
| — compound literals may also include storage-class specifiers as part of the type to change the
 | |
|   lifetime of the compound literal (and possibly turn it into a constant expression)
 | |
| 
 | |
| — added the constexpr specifier for object definitions and improved what is recognized as a
 | |
|   constant expression in conjunction with the constexpr storage-class specifier;
 | |
| 
 | |
| — added the typeof and typeof_unqual operations for computing the type of an expression;
 | |
| 
 | |
| — improved tag compatibility rules, enabling more types to be compatible with other types;
 | |
| 
 | |
| — added the _BitInt the bit-precise integer types;
 | |
| 
 | |
| — improved rules for handling enumerations without underlying types;
 | |
| 
 | |
| — added a new colon-delimited type specifier for enumerations to specify a fixed underlying
 | |
|   type;
 | |
| 
 | |
| — added a new header <stdbit.h> and a suite of bit and byte-handling utilities for portable
 | |
|   access to many implementation’s most efficiency functionality;
 | |
| 
 | |
| — modified existing functions to preserve the const-ness of the type placed into the function;
 | |
| 
 | |
| — added a feature to embed binary data as faithfully as possible with a new preprocessor directive
 | |
|   #embed;
 | |
| 
 | |
| — added a nullptr constant and a nullptr_t type with a well-defined underlying representa-
 | |
|   tion identical to a pointer to void;
 | |
| 
 | |
| — added the __VA_OPT__ specifier and clarified language in the handling of macro invocation
 | |
|   and arguments;
 | |
| 
 | |
| — mandated support for variably-modified types (but not variable-length arrays themselves);
 | |
| 
 | |
| — ellipses on functions may appear without a preceding parameter in the parameter list of
 | |
|   functions and va_start no longer requires such an argument to be passed to it;
 | |
| 
 | |
| — unicode identifiers allowed in syntax;
 | |
| 
 | |
| — memset_explicit function for writing data;
 | |
| 
 | |
| — certain type definitions, bit-precise integer types, and extended integer types may exceed
 | |
|   the normal boundaries of intmax_t and uintmax_t for signed and unsigned integer types,
 | |
|   respectively;
 | |
| 
 | |
| — names of functions, macros, and variables in this document, where clarified, are potentially
 | |
|   reserved rather than reserved to avoid undefined behavior for a large class of identifiers used
 | |
|   by programs existing and to be created;
 | |
| 
 | |
| — mandated support for call_once;
 | |
| 
 | |
| — allowed ptrdiff_t to be an integer type of at least 16, rather than requiring an integer type
 | |
|   with a width of at least 17;
 | |
| 
 | |
| — added the __has_include feature;
 | |
| 
 | |
| — changed the type qualifiers of the _Imaginary_I and _Complex_I macros;
 | |
| 
 | |
| — added $ and $ into the source and execution character set;
 | |
|       — added the auto type specifier for single object definitions using type inference;
 | |
| 
 | |
|       — added the #elifdef and #elifndef conditional inclusion preprocessor directives;
 | |
| 
 | |
|       — added the #warning directive;
 | |
| 
 | |
|       — binary integer literals and appropriate formatting for input/output of binary integer numbers;
 | |
| 
 | |
|       — digit seperators with ’ ;
 | |
| 
 | |
|       — removed conditional support for mixed wide and narrow string literal concatenation;
 | |
| 
 | |
|       — added support for additional time bases in time.h;
 | |
| 
 | |
|       — zero-sized reallocations with realloc are undefined behavior;
 | |
| 
 | |
|       — added an unreachable feature which invokes undefined behavior if reached during program
 | |
|         execution;
 | |
| 
 | |
| </pre>
 | |
| <a name='M.2'></a>
 | |
| <hr>
 | |
| <h3>M.2 [Fourth Edition]</h3>
 | |
| <a name='M.2p1'></a>
 | |
| <pre>1   There were no major changes in the fourth edition (__STDC_VERSION__ 201710L), only technical
 | |
|     corrections and clarifications.
 | |
| 
 | |
| </pre>
 | |
| <a name='M.3'></a>
 | |
| <hr>
 | |
| <h3>M.3 [Third Edition]</h3>
 | |
| <a name='M.3p1'></a>
 | |
| <pre>1   Major changes in the third edition (__STDC_VERSION__ 201112L) included:
 | |
| 
 | |
|       — conditional (optional) features (including some that were previously mandatory)
 | |
| 
 | |
|       — support for multiple threads of execution including an improved memory sequencing model,
 | |
|         atomic objects, and thread storage (<stdatomic.h> and <threads.h>)
 | |
| 
 | |
|       — additional floating-point characteristic macros (<float.h>)
 | |
| 
 | |
|       — querying and specifying alignment of objects (<stdalign.h>, <stdlib.h>)
 | |
| 
 | |
|       — Unicode characters and strings (<uchar.h>) (originally specified in ISO/IEC TR 19769:2004)
 | |
| 
 | |
|       — type-generic expressions
 | |
| 
 | |
|       — static assertions
 | |
| 
 | |
|       — anonymous structures and unions
 | |
| 
 | |
|       — no-return functions
 | |
| 
 | |
|       — macros to create complex numbers (<complex.h>)
 | |
| 
 | |
|       — support for opening files for exclusive access
 | |
| 
 | |
|       — removed the gets function (<stdio.h>)
 | |
| 
 | |
|       — added the aligned_alloc, at_quick_exit, and quick_exit functions (<stdlib.h>)
 | |
| 
 | |
|       — (conditional) support for bounds-checking interfaces (originally specified in ISO/IEC TR 24731–
 | |
|         1:2007)
 | |
| 
 | |
|       — (conditional) support for analyzability
 | |
| </pre>
 | |
| <a name='M.4'></a>
 | |
| <hr>
 | |
| <h3>M.4 [Second Edition]</h3>
 | |
| <a name='M.4p1'></a>
 | |
| <pre>1   Major changes in the second edition (__STDC_VERSION__ 199901L) included:
 | |
| 
 | |
|       — restricted character set support via digraphs and <iso646.h> (originally specified in
 | |
|         ISO/IEC 9899:1990/Amd 1:1995)
 | |
|       — wide character library support in <wchar.h> and <wctype.h> (originally specified in
 | |
|         ISO/IEC 9899:1990/Amd 1:1995)
 | |
|       — more precise aliasing rules via effective type
 | |
|       — restricted pointers
 | |
|       — variable length arrays
 | |
|       — flexible array members
 | |
|       — static and type qualifiers in parameter array declarators
 | |
|       — complex (and imaginary) support in <complex.h>
 | |
|       — type-generic math macros in <tgmath.h>
 | |
|       — the long long int type and library functions
 | |
|       — extended integer types
 | |
|       — increased minimum translation limits
 | |
|       — additional floating-point characteristics in <float.h>
 | |
|       — remove implicit int
 | |
|       — reliable integer division
 | |
|       — universal character names (\u and \U)
 | |
|       — extended identifiers
 | |
|       — hexadecimal floating constants and %a and %A printf/scanf conversion specifiers
 | |
|       — compound literals
 | |
|       — designated initializers
 | |
|       — // comments
 | |
|       — specified width integer types and corresponding library functions in <inttypes.h> and
 | |
|           <stdint.h>
 | |
| 
 | |
|       — remove implicit function declaration
 | |
|       — preprocessor arithmetic done in intmax_t/uintmax_t
 | |
|       — mixed declarations and statements
 | |
|       — new block scopes for selection and iteration statements
 | |
|       — integer constant type rules
 | |
|       — integer promotion rules
 | |
|       — macros with a variable number of arguments (__VA_ARGS__ )
 | |
|       — the vscanf family of functions in <stdio.h> and <wchar.h>
 | |
|       — additional math library functions in <math.h>
 | |
|       — treatment of error conditions by math library functions (math_errhandling)
 | |
|       — floating-point environment access in <fenv.h>
 | |
|       — IEC 60559 (also known as IEC 559 or IEEE arithmetic) support
 | |
| 
 | |
|       — trailing comma allowed in enum declaration
 | |
|       — %lf conversion specifier allowed in printf
 | |
|       — inline functions
 | |
| 
 | |
|       — the snprintf family of functions in <stdio.h>
 | |
|       — boolean type in <stdbool.h>
 | |
|       — idempotent type qualifiers
 | |
|       — empty macro arguments
 | |
| 
 | |
|       — new structure type compatibility rules (tag compatibility)
 | |
|       — additional predefined macro names
 | |
|       — _Pragma preprocessing operator
 | |
|       — standard pragmas
 | |
| 
 | |
|       — __func__ predefined identifier
 | |
|       — va_copy macro
 | |
|       — additional strftime conversion specifiers
 | |
| 
 | |
|       — LIA compatibility annex
 | |
|       — deprecate ungetc at the beginning of a binary file
 | |
|       — remove deprecation of aliased array parameters
 | |
|       — conversion of array to pointer not limited to lvalues
 | |
| 
 | |
|       — relaxed constraints on aggregate and union initialization
 | |
|       — relaxed restrictions on portable header names
 | |
|       — return without expression not permitted in function that returns a value (and vice versa)
 | |
| 
 | |
| </pre>
 | |
| <a name='M.5'></a>
 | |
| <hr>
 | |
| <h3>M.5 [First Edition, Amendment 1]</h3>
 | |
| <a name='M.5p1'></a>
 | |
| <pre>1   Major changes in the amendment to the first edition (__STDC_VERSION__ 199409L) included:
 | |
| 
 | |
|       — addition of the predefined __STDC_VERSION__ macro
 | |
| 
 | |
|       — restricted character set support via digraphs and <iso646.h>
 | |
|       — wide character library support in <wchar.h> and <wctype.h>
 | |
| </pre>
 | |
| 
 | |
| </body>
 | |
| </html>
 |