______________________________________________________________________ Annex B (informative) Implementation quantities [limits] ______________________________________________________________________ 1 Because computers are finite, C++ implementations are inevitably lim ited in the size of the programs they can successfully process. Every implementation shall +------- BEGIN BOX 1 -------+ This clause is non-normative, which means that this sentence must be restated in elsewhere as a normative requirement on implementations. +------- END BOX 1 -------+ document those limitations where known. This documentation may cite fixed limits where they exist, say how to compute variable limits as a function of available resources, or say that fixed limits do not exist or are unknown. 2 The limits may constrain quantities that include those described below or others. The bracketed number following each quantity is recom mended as the minimum for that quantity. However, these quantities are only guidelines and do not determine compliance. --Nesting levels of compound statements, iteration control structures, and selection control structures [256]. --Nesting levels of conditional inclusion [256]. --Pointer, array, and function declarators (in any combination) modi fying an arithmetic, structure, union, or incomplete type in a dec laration [256]. --Nesting levels of parenthesized expressions within a full expression [256]. --Number of initial characters in an internal identifier or macro name [1024]. --Number of initial characters in an external identifier [1024]. --External identifiers in one translation unit [65536]. --Identifiers with block scope declared in one block [1024]. --Macro identifiers simultaneously defined in one transation unit [65536]. --Parameters in one function definition [256]. --Arguments in one function call [256]. --Parameters in one macro definition [256]. --Arguments in one macro invocation [256]. --Characters in one logical source line [65536]. --Characters in a character string literal or wide string literal (after concatenation) [65536]. --Size of an object [262144]. +------- BEGIN BOX 2 -------+ This is trivial for some implementations to meet and very hard for others. +------- END BOX 2 -------+ --Nesting levels for #include files [256]. --Case labels for a switch statement (excluding those for any nested switch statements) [16384]. --Data members in a single class, structure, or union [16384]. --Enumeration constants in a single enumeration [4096]. --Levels of nested class, structure, or union definitions in a single struct-declaration-list [256]. --Functions registered by atexit()[32]. --Direct and indirect base classes [16384]. --Direct base classes for a single class [1024]. --Members declared in a single class [4096]. --Final overriding virtual functions in a class, accessible or not [16384]. +------- BEGIN BOX 3 -------+ I'm not quite sure what this means, but it was passed in Munich in this form. +------- END BOX 3 -------+ --Direct and indirect virtual bases of a class [1024]. --Static members of a class [1024]. --Friend declarations in a class [4096]. --Access control declarations in a class [4096]. --Member initializers in a constructor definition [6144]. --Scope qualifications of one identifier [256]. --Nested external specifications [1024]. --Template arguments in a template declaration [1024]. --Recursively nested template instantiations [17]. --Handlers per try block [256]. --Throw specifications on a single function declaration [256].