This issue has been automatically converted from the original issue lists and some formatting may not have been preserved.
Authors: Josey (US)
Date: 2005-09-28
Reference document: N1138
Submitted against: C99
Status: Fixed
Fixed in: C99 TC3
Converted from: summary-c99.htm, dr_323.htm
Summary: The imaginary macro is missing in the normative text.
I think there may be a problem here with C99 (as amended by TC2). As far as I
can see there is no longer any mention of the imaginary macro in normative text,
which means implementations are not allowed to define it (because it is not
reserved for use by the implementation). Yet in Annex G it still recommends (in
informative text) that implementations which define __STDC_IEC_559_COMPLEX__
should define the imaginary macro. It also recommends that these implementations
should define I "to be _Imaginary_I (not _Complex_I as stated in 7.3)".
Yet implementations that do so would not comply with the normative text in 7.3
which requires I to be defined as _Complex_I.
Assuming that the intention was to allow implementations to follow the recommendations in Annex G, but by an oversight the necessary normative text to allow them to do so was omitted from TC2, perhaps in POSIX we should keep the current text but mark some of it CX?
Comment from WG14 on 2006-10-25:
It was pointed out that implementing Annex G causes nonconforming changes to the normative text in C99. Exact instances were not given or known. The implications of NOT allowing 'I' to expand to '_Imaginary_I' are not readily clear.
We did not fully realize the repercusions of the changes that DR 207 would do (implementing Annex G and
make the implementation non-conforming; our intent was to allow implementations to do Annex G and still conform) and agree that (some of) the effects of DR 207 should be undone. There are three possible levels of undo that could be done.
Some members of the committee had hoped that imaginary would be ignored and go away. However, at least one vendor has shipped an implementation that supports imaginary and Annex G. This vendor has indicated that it would not be hard to modify its implementation so that it passes strict conformance with one command line switch and offer a default implementation with imaginary without that switch.
One problem with I being imaginary versus complex is f(I) is either passed one double or two doubles. However, this only matters to a few type generic math functions and no user functions (since users have no means to define their own type generic functions). One such type generic math function is cosh(), i.e., cosh(I*y) is the real cos(y) if I is imaginary, but is the complex cosh(z) if I is complex.
It has been observed that the relational operators (<, <=, >=, >) of 6.5.8 and comparison macros of 7.12.14 (isless, ...) should be allowed to be used with imaginary types when both operands are imaginary; this was an oversite in the original C99 specification.
The mimimal changes to restore back to C99 w.r.t. to DR 207 is restore paragraphs 3, 4, and 5 of 7.3.1 of C99; this is a subset of the changes done by DR 207 in TC2.
In 7.3.1 of C99+TC1+TC2, replace paragraphs 3 and 4 with:
[#3] The macros
imaginaryand
_Imaginary_Iare defined if and only if the implementation supports imaginary types;165 if defined, they expand to
_Imaginaryand a constant expression of typeconst float _Imaginarywith the value of the imaginary unit.[#4] The macro
Iexpands to
_Imaginary_Ior_Complex_I. If_Imaginary_Iis not defined,Ishall expand to_Complex_I.[#5] Notwithstanding the provisions of subclause 7.1.3, a program may undefine and perhaps then redefine the macros
complex,imaginaryandI.165A specification for imaginary types is in informative annex G.