From: Paolo Carlini Date: Sat, 10 Jan 2004 20:09:26 +0000 (+0000) Subject: lwg-active.html, [...]: Import Revision 28. X-Git-Tag: releases/gcc-3.4.0~1136 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=a8d6534992171afbaaa8523837f584d753ec5d4c;p=thirdparty%2Fgcc.git lwg-active.html, [...]: Import Revision 28. 2004-01-10 Paolo Carlini * docs/html/ext/lwg-active.html, docs/html/ext/lwg-defects.html: Import Revision 28. From-SVN: r75648 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index a20e904f8ca1..8e5ca1e5d9af 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,8 @@ +2004-01-10 Paolo Carlini + + * docs/html/ext/lwg-active.html, docs/html/ext/lwg-defects.html: + Import Revision 28. + 2004-01-10 Paolo Carlini PR libstdc++/13630 diff --git a/libstdc++-v3/docs/html/ext/lwg-active.html b/libstdc++-v3/docs/html/ext/lwg-active.html index 235e51dce36a..379e65861a38 100644 --- a/libstdc++-v3/docs/html/ext/lwg-active.html +++ b/libstdc++-v3/docs/html/ext/lwg-active.html @@ -4,11 +4,11 @@ - + - + @@ -19,7 +19,7 @@
Doc. no.N1515 = 03-0098N1537=03-0120
Date:20 Sep 200313 Nov 2003
Project:Matt Austern <austern@apple.com>
-

C++ Standard Library Active Issues List (Revision 27)

+

C++ Standard Library Active Issues List (Revision 28)

Reference ISO/IEC IS 14882:1998(E)

Also see:

    @@ -87,6 +87,10 @@ directory as the issues list files.

    Revision History

      +
    • R28: +Post-Kona mailing: reflects decisiosn made at the Kona meeting. +Added new issues 432-440. +
    • R27: Pre-Kona mailing. Added new issues 404-431.
    • @@ -236,7 +240,7 @@ post-Dublin mailing. Updated to reflect LWG and full committee actions in Dublin. (99-0016/N1193, 21 Apr 99)
    • R7: -pre-Dublin updated: Added issues 130, 131, +pre-Dublin updated: Added issues 130, 131, 132, 133, 134, 135, 136, 137, 138, 139 (31 Mar 99) @@ -511,10 +515,18 @@ as an ill-formed field. It's not exactly the consensus from Santa Cruz, but he thinks it's the simplest and most robust rule and that it corresponds to widespread common practice.]

      +

      [Kona: Wording here still isn't quite right, partly because it +refers to scanf and the scanf description of error conditions is +murky. The LWG had to do a very close reading of scanf in an attempt +to figure out what this proposed resolution means. General agreement +that the correct solution: (1) should not refer to scanf behavior, (2) +should not set errno, (3) should allow users who care to figure out +what kind of error happened. Martin will provide wording, Howard may +help.]


      44. Iostreams use operator== on int_type values

      -Section: 27 [lib.input.output]  Status: Review  Submitter: Nathan Myers  Date: 6 Aug 1998

      +Section: 27 [lib.input.output]  Status: Ready  Submitter: Nathan Myers  Date: 6 Aug 1998

      Many of the specifications for iostreams specify that character values or their int_type equivalents are compared using operators == or !=, though in other places traits::eq() or traits::eq_int_type is @@ -781,7 +793,7 @@ change uses of == and != to use the traits members instead.


      92. Incomplete Algorithm Requirements

      -Section: 25 [lib.algorithms]  Status: Review  Submitter: Nico Josuttis  Date: 29 Sep 1998

      +Section: 25 [lib.algorithms]  Status: Ready  Submitter: Nico Josuttis  Date: 29 Sep 1998

      The standard does not state, how often a function object is copied, called, or the order of calls inside an algorithm. This may lead to surprising/buggy behavior. Consider the following example:

      @@ -936,7 +948,7 @@ solution.]


      98. Input iterator requirements are badly written

      -Section: 24.1.1 [lib.input.iterators]  Status: Review  Submitter: AFNOR  Date: 7 Oct 1998

      +Section: 24.1.1 [lib.input.iterators]  Status: Ready  Submitter: AFNOR  Date: 7 Oct 1998

      Table 72 in 24.1.1 [lib.input.iterators] specifies semantics for *r++ of:

      @@ -973,7 +985,7 @@ for *r++ from T to "convertible to T". much to read into these semantics clauses.


      120. Can an implementor add specializations?

      -Section: 17.4.3.1 [lib.reserved.names]  Status: Review  Submitter: Judy Ward  Date: 15 Dec 1998

      +Section: 17.4.3.1 [lib.reserved.names]  Status: Ready  Submitter: Judy Ward  Date: 15 Dec 1998

      The original issue asked whether a library implementor could specialize standard library templates for built-in types. (This was @@ -1021,11 +1033,14 @@ different explicit instantiations might be harmless.

      Append to 17.4.3.1 [lib.reserved.names] paragraph 1:

      A program may explicitly instantiate any templates in the standard - library only if the declaration depends on a user-defined name of - external linkage and the instantiation meets the standard library + library only if the declaration depends on the name of a user-defined + type of external linkage and the instantiation meets the standard library requirements for the original template.
      +

      [Kona: changed the wording from "a user-defined name" to "the name of + a user-defined type"]

      +

      Rationale:

      The LWG considered another possible resolution:

      @@ -1069,10 +1084,46 @@ different explicit instantiations might be harmless.

      The Committee is now considering standardization of dynamic linking. If there are such changes in the future, it may be appropriate to revisit this issue later.

      +
      +

      130. Return type of container::erase(iterator) differs for associative containers

      +Section: 23.1.2 [lib.associative.reqmts], 23.1.1 [lib.sequence.reqmts]  Status: Review  Submitter: Andrew Koenig  Date: 2 Mar 1999

      +

      Table 67 (23.1.1) says that container::erase(iterator) returns an +iterator. Table 69 (23.1.2) says that in addition to this requirement, +associative containers also say that container::erase(iterator) +returns void. That's not an addition; it's a change to the +requirements, which has the effect of making associative containers +fail to meet the requirements for containers.

      +

      Proposed resolution:

      + +

      +In 23.1.2 [lib.associative.reqmts], in Table 69 Associative container +requirements, change the return type of a.erase(q) from +void to iterator. Change the +assertion/not/pre/post-condition from "erases the element pointed to +by q" to "erases the element pointed to +by q and returns the iterator immediately following +q prior to the erasure." +

      + +

      +In 23.3.1 [lib.map], in the map class synopsis; and +in 23.3.2 [lib.multimap], in the multimap class synopsis; and +in 23.3.3 [lib.set], in the set class synopsis; and +in 23.3.4 [lib.multiset], in the multiset class synopsis: +change the signature of the first erase overload to +

      +
         iterator erase(iterator position);
      +
      + +

      [Pre-Kona: reopened at the request of Howard Hinnant]

      +

      [Post-Kona: the LWG agrees the return type should be +iterator, not void. (Alex Stepanov agrees too.) +Matt provided wording.]

      +

      167. Improper use of traits_type::length()

      -Section: 27.6.2.5.4 [lib.ostream.inserters.character]  Status: Review  Submitter: Dietmar Kühl  Date: 20 Jul 1999

      +Section: 27.6.2.5.4 [lib.ostream.inserters.character]  Status: Ready  Submitter: Dietmar Kühl  Date: 20 Jul 1999

      Paragraph 4 states that the length is determined using traits::length(s). Unfortunately, this function is not defined for example if the character type is wchar_t and the @@ -1094,10 +1145,10 @@ const*.

      to:

      -

      Effects: Behaves like an formatted inserter (as described in +

      Effects: Behaves like a formatted inserter (as described in lib.ostream.formatted.reqmts) of out. After a sentry object is constructed it inserts n characters starting at s, - where n is:

      + where n is the number that would be computed as if by:

      • traits::length(s) for the overload where the first argument is of type basic_ostream<charT, traits>& and the second is @@ -1120,6 +1171,9 @@ const*.

        [Santa Cruz: Matt supplied new wording]

        +

        [Kona: changed "where n is" to " where n is the + number that would be computed as if by"]

        +

        Rationale:

        We have five separate cases. In two of them we can use the user-supplied traits class without any fuss. In the other three we @@ -1297,7 +1351,7 @@ clear how numeric_limits applies to each of those cases. A wholesale review of numeric_limits is needed. A paper would be welcome.]


        226. User supplied specializations or overloads of namespace std function templates

        -Section: 17.4.3.1 [lib.reserved.names]  Status: Review  Submitter: Dave Abrahams  Date: 01 Apr 2000

        +Section: 17.4.3.1 [lib.reserved.names]  Status: Ready  Submitter: Dave Abrahams  Date: 01 Apr 2000

        The issues are: 

        1. How can a 3rd party library implementor (lib1) write a version of a standard algorithm which is specialized to work with his own class template? 

        @@ -1382,12 +1436,13 @@ not provide an operator<< for std::pair<>.

        Proposed resolution:

        -

        Adopt the wording proposed in Howard Hinnant's paper N1439=03-0021, -"Proposed Resolution To LWG issues 225, 226, 229".

        +

        Adopt the wording proposed in Howard Hinnant's paper + N1523=03-0106, "Proposed Resolution To LWG issues 225, 226, 229".

        +

        [Tokyo: Summary, "There is no conforming way to extend std::swap for user defined templates."  The LWG agrees that -there is a problem.  Would like more information before +there is a problem. Would like more information before proceeding. This may be a core issue. Core issue 229 has been opened to discuss the core aspects of this problem. It was also noted that submissions regarding this issue have been received from several @@ -1453,7 +1508,8 @@ resolution is the one proposed by Howard.]

        However, there were concerns about wording. Howard will provide new wording. Bill and Jeremy will review it.]

        -

        [Oxford: Howard proposed the new wording.]

        +

        [Kona: Howard proposed the new wording. The LWG accepted his + proposed resolution.]

        Rationale:

        Informally: introduce a Swappable concept, and specify that the @@ -1633,7 +1689,7 @@ complicated than a while loop whose body is a single-element insert.]


        253. valarray helper functions are almost entirely useless

        -Section: 26.3.2.1 [lib.valarray.cons], 26.3.2.2 [lib.valarray.assign]  Status: Review  Submitter: Robert Klarer  Date: 31 Jul 2000

        +Section: 26.3.2.1 [lib.valarray.cons], 26.3.2.2 [lib.valarray.assign]  Status: Ready  Submitter: Robert Klarer  Date: 31 Jul 2000

        This discussion is adapted from message c++std-lib-7056 posted November 11, 1999. I don't think that anyone can reasonably claim that the problem described below is NAD.

        @@ -1918,7 +1974,7 @@ desirable to provide this feature in a different way.

        283. std::replace() requirement incorrect/insufficient

        -Section: 25.2.4 [lib.alg.replace]  Status: Review  Submitter: Martin Sebor  Date: 15 Dec 2000

        +Section: 25.2.4 [lib.alg.replace]  Status: Ready  Submitter: Martin Sebor  Date: 15 Dec 2000

        (revision of the further discussion) There are a number of problems with the requires clauses for the @@ -2111,7 +2167,7 @@ blanket statement in Clause 25, not just a special requirement for


        291. Underspecification of set algorithms

        -Section: 25.3.5 [lib.alg.set.operations]  Status: Review  Submitter: Matt Austern  Date: 03 Jan 2001

        +Section: 25.3.5 [lib.alg.set.operations]  Status: Ready  Submitter: Matt Austern  Date: 03 Jan 2001

        The standard library contains four algorithms that compute set operations on sorted ranges: set_union, set_intersection, @@ -2668,7 +2724,7 @@ examined by the user to determine why something failed.


        347. locale::category and bitmask requirements

        -Section: 22.1.1.1.1 [lib.locale.category]  Status: Review  Submitter: P.J. Plauger, Nathan Myers  Date: 23 Oct 2001

        +Section: 22.1.1.1.1 [lib.locale.category]  Status: Ready  Submitter: P.J. Plauger, Nathan Myers  Date: 23 Oct 2001

        In 22.1.1.1.1 [lib.locale.category] paragraph 1, the category members are described as bitmask elements. In fact, the bitmask requirements @@ -2758,7 +2814,7 @@ of the other enumerated values; implementations may add extra categories.]


      352. missing fpos requirements

      -Section: 21.1.2 [lib.char.traits.typedefs]  Status: Review  Submitter: Martin Sebor  Date: 2 Dec 2001

      +Section: 21.1.2 [lib.char.traits.typedefs]  Status: Ready  Submitter: Martin Sebor  Date: 2 Dec 2001

      (1) There are no requirements on the stateT template parameter of @@ -2802,7 +2858,7 @@ state type already. Unless motivation is provided, the second should be considered NAD.


      355. Operational semantics for a.back()

      -Section: 23.1.1 [lib.sequence.reqmts]  Status: Review  Submitter: Yaroslav Mironov  Date: 23 Jan 2002

      +Section: 23.1.1 [lib.sequence.reqmts]  Status: Ready  Submitter: Yaroslav Mironov  Date: 23 Jan 2002

      Table 68 "Optional Sequence Operations" in 23.1.1/12 specifies operational semantics for "a.back()" as @@ -2828,7 +2884,7 @@ Operations" in 23.1.1/12 for "a.back()" from

      to

      - { iterator tmp = a.end(); --tmp; *tmp; } + { iterator tmp = a.end(); --tmp; return *tmp; }

      and the specification for "a.pop_back()" from

      @@ -2867,6 +2923,9 @@ LWG would like a new issue opened.]

      in Santa Cruz. It does not appear that this problem appears anywhere else in clauses 23 or 24.]

      +

      [Kona: In definition of operational semantics of back(), change +"*tmp" to "return *tmp;"]

      +

      356. Meaning of ctype_base::mask enumerators

      Section: 22.2.1 [lib.category.ctype]  Status: Open  Submitter: Matt Austern  Date: 23 Jan 2002

      @@ -3012,7 +3071,7 @@ option 1 is required for C99 compatibility.

      359. num_put<>::do_put (..., bool) undocumented

      -Section: 22.2.2.2.1 [lib.facet.num.put.members]  Status: Review  Submitter: Martin Sebor  Date: 12 Mar 2002

      +Section: 22.2.2.2.1 [lib.facet.num.put.members]  Status: Ready  Submitter: Martin Sebor  Date: 12 Mar 2002

      22.2.2.2.1, p1:

          iter_type put (iter_type out, ios_base& str, char_type fill,
      @@ -3165,7 +3224,7 @@ programming.
         of the Standard and will see what the original intent was.]


      365. Lack of const-qualification in clause 27

      -Section: 27 [lib.input.output]  Status: Review  Submitter: Walter Brown, Marc Paterno  Date: 10 May 2002

      +Section: 27 [lib.input.output]  Status: Ready  Submitter: Walter Brown, Marc Paterno  Date: 10 May 2002

      Some stream and streambuf member functions are declared non-const, even thought they appear only to report information rather than to @@ -3475,7 +3534,7 @@ be hard to track down by users. This would also make the need for an erase_if() member function that much greater.

      -

      This issue is somewhat related to LWG issue 130.

      +

      This issue is somewhat related to LWG issue 130.

      [Santa Cruz: More people need to look at this. Much user code may assume stability. On the other hand, it seems drastic to add a @@ -3571,7 +3630,7 @@ come up with better wording.]


      379. nonsensical ctype::do_widen() requirement

      -Section: 22.2.1.1.2 [lib.locale.ctype.virtuals]  Status: Review  Submitter: Martin Sebor  Date: 6 Sep 2002

      +Section: 22.2.1.1.2 [lib.locale.ctype.virtuals]  Status: Ready  Submitter: Martin Sebor  Date: 6 Sep 2002

      The last sentence in 22.2.1.1.2, p11 below doesn't seem to make sense.

      @@ -3603,14 +3662,17 @@ Replace the last sentence of 22.2.1.1.2

      382. codecvt do_in/out result

      -Section: 22.2.1.5 [lib.locale.codecvt]  Status: Review  Submitter: Martin Sebor  Date: 30 Aug 2002

      +Section: 22.2.1.5 [lib.locale.codecvt]  Status: Open  Submitter: Martin Sebor  Date: 30 Aug 2002

      It seems that the descriptions of codecvt do_in() and do_out() leave sufficient room for interpretation so that two implementations of @@ -3768,6 +3830,16 @@ resolution of lwg issue 19. that this general direction is probably correct. Dietmar, Howard, PJP, and Matt will review this wording.]

      +

      [Kona: this isn't quite right. (a) the description of noconv is +too vague, both in the existing standard and in the current proposed +resolution; (b) the description of what noconv means should be +normative; (c) the phrase "partial, i.e. if from_next != from_end" +isn't quite right, because those are two separate cases, it's possible +to get partial either form insufficient input or from insufficient +space in the output buffer. The big problem is that the standard is +written with the assumption of 1->N conversion in mind, not M->N. +Bill, Howard, and Martin will provide new wording. +]


      384. equal_range has unimplementable runtime complexity

      Section: 25.3.3.3 [lib.equal.range]  Status: Open  Submitter: Hans Bos  Date: 18 Oct 2002

      @@ -3880,7 +3952,7 @@ Comments from Dave Abrahams: IMO we should resolve 386 by just saying ]


      387. std::complex over-encapsulated

      -Section: 26.2 [lib.complex.numbers]  Status: Review  Submitter: Gabriel Dos Reis  Date: 8 Nov 2002

      +Section: 26.2 [lib.complex.numbers]  Status: Open  Submitter: Gabriel Dos Reis  Date: 8 Nov 2002

      The absence of explicit description of std::complex<T> layout makes it imposible to reuse existing software developed in traditional @@ -3974,6 +4046,16 @@ part of x part of x

      . +

      [Kona: The layout guarantee is absolutely necessary for C + compatibility. However, there was disagreement about the other part + of this proposal: retrieving elements of the complex number as + lvalues. An alternative: continue to have real() and imag() return + rvalues, but add set_real() and set_imag(). Straw poll: return + lvalues - 2, add setter functions - 5. Related issue: do we want + reinterpret_cast as the interface for converting a complex to an + array of two reals, or do we want to provide a more explicit way of + doing it? Howard will try to resolve this issue for the next + meeting.]

      Rationale:

      The LWG believes that C99 compatibility would be enough @@ -3981,7 +4063,7 @@ justification for this change even without other considerations. All existing implementations already have the layout proposed here.


      389. Const overload of valarray::operator[] returns by value

      -Section: 26.3.2 [lib.template.valarray]  Status: Review  Submitter: Gabriel Dos Reis  Date: 8 Nov 2002

      +Section: 26.3.2 [lib.template.valarray]  Status: Ready  Submitter: Gabriel Dos Reis  Date: 8 Nov 2002

      Consider the following program:

          #include <iostream>
           #include <ostream>
      @@ -4023,12 +4105,15 @@ should not return a const T&.

      Proposed resolution:

      In the class synopsis in 26.3.2 [lib.template.valarray], and in 26.3.2.3 [lib.valarray.access] just above paragraph 1, change

      -
        T operator[](size_t const;)
      +
        T operator[](size_t const);
       

      to

      -
        const T& operator[](size_t const;)
      +
        const T& operator[](size_t const);
       
      +

      [Kona: fixed a minor typo: put semicolon at the end of the line + wehre it belongs.]

      +

      Rationale:

      Return by value seems to serve no purpose. Valaray was explicitly designed to have a specified layout so that it could easily be @@ -4037,7 +4122,7 @@ defeats that purpose. It is believed that this change will have no impact on allowable optimizations.


      391. non-member functions specified as const

      -Section: 22.1.3.2 [lib.conversions]  Status: Review  Submitter: James Kanze  Date: 10 Dec 2002

      +Section: 22.1.3.2 [lib.conversions]  Status: Ready  Submitter: James Kanze  Date: 10 Dec 2002

      The specifications of toupper and tolower both specify the functions as const, althought they are not member functions, and are not specified as @@ -4050,7 +4135,7 @@ const in the header file synopsis in section 22.1

      394. behavior of formatted output on failure

      -Section: 27.6.2.5 [lib.ostream.formatted]  Status: Review  Submitter: Martin Sebor  Date: 27 Dec 2002

      +Section: 27.6.2.5.1 [lib.ostream.formatted.reqmts]  Status: Open  Submitter: Martin Sebor  Date: 27 Dec 2002

      There is a contradiction in Formatted output about what bit is supposed to be set if the formatting fails. On sentence says it's @@ -4123,35 +4208,30 @@ consistent, the Common requirements sections for the Formatted output functions should be changed as proposed below.

      Proposed resolution:

      -

      -In paragraph one of section 27.6.2.5 [lib.ostream.formatted], delete the -sentence beginning with "If the generation fails". -

      -

      Rationale:

      -

      -There isn't any contradiction here. put returns a streambuf iterator. -failed() is a member function of the streambuf iterator. If -it's set then that's a streambuf error, not a conversion error. -

      -

      -The real problem isn't that there's a contradiction, but that the "If -the generation fails" part makes little sense. "Generation" isn't -clearly defined. It's not clear what it means for generation to -fail, or even whether it can fail. The intention is probably that -generaion meant formatting, as opposed to character insertion, and -that this sentence was intended as analogous to character parsing. -

      -

      A more precise definition would be that we set failbit if the facet - reports failure. However, the mechanism for the facet reporting - failure is that it sets failbit! Saying that we set failbit if the - facet sets failbit would be silly, so the best thing to say is - nothing.

      +

      [Kona: There's agreement that this is a real issue. What we + decided at Kona: 1. An error from the buffer (which can be detected + either directly from streambuf's member functions or by examining a + streambuf_iterator) should always result in badbit getting set. + 2. There should never be a circumstance where failbit gets set. + That represents a formatting error, and there are no circumstances + under which the output facets are specified as signaling a + formatting error. (Even more so for string output that for numeric + because there's nothing to format.) If we ever decide to make it + possible for formatting errors to exist then the facets can signal + the error directly, and that should go in clause 22, not clause 27. + 3. The phrase "if generation fails" is unclear and should be + eliminated. It's not clear whether it's intended to mean a buffer + error (e.g. a full disk), a formatting error, or something else. + Most people thought it was supposed to refer to buffer errors; if + so, we should say so. Martin will provide wording.]

      + +

      Rationale:


      395. inconsistencies in the definitions of rand() and random_shuffle()

      -Section: 26.5 [lib.c.math]  Status: Review  Submitter: James Kanze  Date: 3 Jan 2003

      +Section: 26.5 [lib.c.math]  Status: Ready  Submitter: James Kanze  Date: 3 Jan 2003

      In 26.5 [lib.c.math], the C++ standard refers to the C standard for the definition of rand(); in the C standard, it is written that "The @@ -4233,13 +4313,20 @@ is a bitset, not a string. typename basic_string<charT, traits, Allocator>::size_type pos = 0, typename basic_string<charT, traits, Allocator>::size_type n = basic_string<charT, traits, Allocator>::npos, - charT zero = charT('0')); + charT zero = charT('0'), charT one = charT('1'))

      Change the first two sentences of 23.3.5.1 [lib.bitset.cons] p6 to: "An element of the constructed string has value 0 if the corresponding character in str, beginning at position pos, is zero. Otherwise, the element has the value 1.

      +

      Change the text of the second sentence in 23.3.5.1, p5 to read: + "The function then throws invalid_argument if any of the rlen + characters in str beginning at position pos is other than zero + or one. The function uses traits::eq() to compare the character + values." +

      +

      Change the declaration of the to_string member function immediately before 23.3.5.2 [lib.bitset.members] p33 to:

          template <class charT, class traits, class Allocator>
      @@ -4418,31 +4505,8 @@ end-of-file):
         and changing it on an individual basis wouldn't make things better.
         Dietmar will do this work.


      -

      400. redundant type cast in lib.allocator.members

      -Section: 20.4.1.1 [lib.allocator.members]  Status: Ready  Submitter: Markus Mauhart  Date: 27 Feb 2003

      -

      -20.4.1.1 [lib.allocator.members] allocator members, contains -the following 3 lines: -

      - -
        12 Returns: new((void *) p) T( val)
      -     void destroy(pointer p);
      -  13 Returns: ((T*) p)->~T()
      -
      - -

      -The type cast "(T*) p" in the last line is redundant cause -we know that std::allocator<T>::pointer is a typedef for T*. -

      -

      Proposed resolution:

      -

      -Replace "((T*) p)" with "p". -

      -

      Rationale:

      -

      Just a typo, this is really editorial.

      -

      401.  incorrect type casts in table 32 in lib.allocator.requirements

      -Section: 20.1.5 [lib.allocator.requirements]  Status: New  Submitter: Markus Mauhart  Date: 27 Feb 2003

      +Section: 20.1.5 [lib.allocator.requirements]  Status: Open  Submitter: Markus Mauhart  Date: 27 Feb 2003

      I think that in par2 of 20.1.5 [lib.allocator.requirements] the last two lines of table 32 contain two incorrect type casts. The lines are ... @@ -4483,9 +4547,18 @@ Note: Actually I would prefer to replace "((T*)p)?->dtor_name" with "p?->dtor_name", but AFAICS this is not possible cause of an omission in 13.5.6 [over.ref] (for which I have filed another DR on 29.11.2002).

      + +

      [Kona: The LWG thinks this is somewhere on the border between + Open and NAD. The intend is clear: construct constructs an + object at the location p. It's reading too much into the + description to think that literally calling new is + required. Tweaking this description is low priority until we can do + a thorough review of allocators, and, in particular, allocators with + non-default pointer types.]

      +

      402. wrong new expression in [some_]allocator::construct

      -Section: 20.1.5 [lib.allocator.requirements], 20.4.1.1 [lib.allocator.members],   Status: New  Submitter: Markus Mauhart  Date: 27 Feb 2003

      +Section: 20.1.5 [lib.allocator.requirements], 20.4.1.1 [lib.allocator.members],   Status: Ready  Submitter: Markus Mauhart  Date: 27 Feb 2003

      This applies to the new expression that is contained in both par12 of 20.4.1.1 [lib.allocator.members] and in par2 (table 32) of 20.1.5 [lib.allocator.requirements]. @@ -4534,12 +4607,11 @@ probably must think about it.

      Proposed resolution:

      -Therefore I think that "new" should be replaced with "::new" in both -cases. +Replace "new" with "::new" in both cases.


      403. basic_string::swap should not throw exceptions

      -Section: 21.3.5.8 [lib.string::swap]  Status: New  Submitter: Beman Dawes  Date: 25 Mar 2003

      +Section: 21.3.5.8 [lib.string::swap]  Status: Ready  Submitter: Beman Dawes  Date: 25 Mar 2003

      std::basic_string, 21.3 [lib.basic.string] paragraph 2 says that @@ -4596,7 +4668,7 @@ Throws: Shall not throw exceptions.


      404. May a replacement allocation function be declared inline?

      -Section: 17.4.3.4 [lib.replacement.functions], 18.4.1 [lib.new.delete]  Status: New  Submitter: Matt Austern  Date: 24 Apr 2003

      +Section: 17.4.3.4 [lib.replacement.functions], 18.4.1 [lib.new.delete]  Status: Ready  Submitter: Matt Austern  Date: 24 Apr 2003

      The eight basic dynamic memory allocation functions (single-object and array versions of ::operator new and ::operator delete, in the @@ -4624,8 +4696,12 @@ and 18.4.1.2 [lib.replacement.functions] paragraph 3: -"The program's definitions shall not be specified as inline." +"The program's definitions shall not be specified as inline. +No diagnostic is required."

      + +

      [Kona: added "no diagnostic is required"]

      +

      Rationale:

      The fact that inline isn't mentioned appears to have been @@ -4636,7 +4712,7 @@ believed to be of limited value.


      405. qsort and POD

      -Section: 25.4 [lib.alg.c.library]  Status: New  Submitter: Ray Lischner  Date: 08 Apr 2003

      +Section: 25.4 [lib.alg.c.library]  Status: Review  Submitter: Ray Lischner  Date: 08 Apr 2003

      Section 25.4 [lib.alg.c.library] describes bsearch and qsort, from the C standard library. Paragraph 4 does not list any restrictions on qsort, @@ -4644,9 +4720,19 @@ but it should limit the base parameter to point to POD. Presumably, qsort sorts the array by copying bytes, which requires POD.

      Proposed resolution:

      +

      +In 25.4 [lib.alg.c.library] paragraph 4, just after the declarations and +before the nonnormative note, add these words: "both of which have the +same behavior as the original declaration. The behavior is undefined +unless the objects in the array pointed to by base are of POD +type." +

      + +

      [Something along these lines is clearly necessary. Matt + provided wording.]


      406. vector::insert(s) exception safety

      -Section: 23.2.4.2 [lib.vector.capacity]  Status: New  Submitter: Dave Abrahams  Date: 27 Apr 2003

      +Section: 23.2.4.3 [lib.vector.modifiers]  Status: Open  Submitter: Dave Abrahams  Date: 27 Apr 2003

      There is a possible defect in the standard: the standard text was never intended to prevent arbitrary ForwardIterators, whose operations @@ -4666,9 +4752,14 @@ existing implementation. of T (or, if first and last satisfy the forward iterator requirements, an operation on first or last) there are no effects. + +

      [Something along these lines is probably a good idea. It's + unclear why we're making a distinction between Input Iterators and + Forward Iterators.]

      +

      407. Can singular iterators be destroyed?

      -Section: 24.1 [lib.iterator.requirements]  Status: New  Submitter: Nathan Myers  Date: 3 June 2003

      +Section: 24.1 [lib.iterator.requirements]  Status: Ready  Submitter: Nathan Myers  Date: 3 June 2003

      Clause 24.1 [lib.iterator.requirements], paragraph 5, says that the only expression that is defined for a singular iterator is "an assignment of a @@ -4685,7 +4776,7 @@ of a non-singular value to an iterator that holds a singular value."


      408. Is vector<reverse_iterator<char*> > forbidden?

      -Section: 24.1 [lib.iterator.requirements]  Status: New  Submitter: Nathan Myers  Date: 3 June 2003

      +Section: 24.1 [lib.iterator.requirements]  Status: Open  Submitter: Nathan Myers  Date: 3 June 2003

      I've been discussing iterator semantics with Dave Abrahams, and a surprise has popped up. I don't think this has been discussed before. @@ -4798,9 +4889,20 @@ iterator value, singular or not, default-initialized or not.

      Related issue: 407

      Proposed resolution:

      + +

      [ +We don't want to require all singular iterators to be copyable, +because that is not the case for pointers. However, default +construction may be a special case. Issue: is it really default +construction we want to talk about, or is it something like value +initialization? We need to check with core to see whether default +constructed pointers are required to be copyable; if not, it would be +wrong to impose so strict a requirement for iterators. +]

      +

      409. Closing an fstream should clear error state

      -Section: 27.8.1.7 [lib.ifstream.members], 27.8.1.10 [lib.ofstream.members]  Status: New  Submitter: Nathan Myers  Date: 3 June 2003

      +Section: 27.8.1.7 [lib.ifstream.members], 27.8.1.10 [lib.ofstream.members]  Status: Review  Submitter: Nathan Myers  Date: 3 June 2003

      A strict reading of 27.8.1 [lib.fstreams] shows that opening or closing a basic_[io]fstream does not affect the error bits. This @@ -4818,9 +4920,27 @@ changes in a TC. Now that we're working on a new revision of the language, those considerations no longer apply.

      Proposed resolution:

      + +

      Change 27.8.1.4, para. 3 from:

      +
      +If the open operation succeeds and ( mode & ios_base::ate) != 0, +positions the file to the end (``as if'' by calling +std::fseek(file,0,SEEK_END)). +
      +

      to:

      +
      +If the open operation succeeds, calls clear(0). Then if +( mode & ios_base::ate) != 0, positions the file to the end +(``as if'' by calling std::fseek(file,0,SEEK_END)). +
      + +

      [Kona: the LWG agrees this is a good idea. Post-Kona: Bill +provided wording. He suggests having open, not close, clear the error +flags.]

      +

      410. Missing semantics for stack and queue comparison operators

      -Section: 23.2.3.1 [lib.queue], 23.2.3.3 [lib.stack]  Status: New  Submitter: Hans Bos  Date: 7 Jun 2003

      +Section: 23.2.3.1 [lib.queue], 23.2.3.3 [lib.stack]  Status: Review  Submitter: Hans Bos  Date: 7 Jun 2003

      Sections 23.2.3.1 [lib.queue] and 23.2.3.3 [lib.stack] list comparison operators (==, !=, <, <=, >, =>) for queue and @@ -4828,9 +4948,79 @@ stack. Only the semantics for queue::operator== (23.2.3.1 [lib.queue] + paragraph 3:

      + +
      + +
        operator!=
      +
      +

      Returns: x.c != y.c +

      + +
        operator>
      +
      +

      Returns: x.c > y.c +

      + +
        operator<=
      +
      +

      Returns: x.c <= y.c +

      + +
        operator>=
      +
      +

      Returns: x.c >= y.c +

      + +
      + +

      Add the following paragraphs at the end of 23.2.3.3 [lib.stack]:

      + +
      + +
        operator==
      +
      +

      Returns: x.c == y.c +

      + +
        operator<
      +
      +

      Returns: x.c < y.c +

      + +
        operator!=
      +
      +

      Returns: x.c != y.c +

      + +
        operator>
      +
      +

      Returns: x.c > y.c +

      + +
        operator<=
      +
      +

      Returns: x.c <= y.c +

      + +
        operator>=
      +
      +

      Returns: x.c >= y.c +

      + +
      + + +

      [Kona: Matt provided wording.]

      + +

      Rationale:

      +There isn't any real doubt about what these operators are +supposed to do, but we ought to spell it out.

      411. Wrong names of set member functions

      -Section: 25.3.5 [lib.alg.set.operations]  Status: New  Submitter: Daniel Frey  Date: 9 Jul 2003

      +Section: 25.3.5 [lib.alg.set.operations]  Status: Ready  Submitter: Daniel Frey  Date: 9 Jul 2003

      25.3.5 [lib.alg.set.operations] paragraph 1 reads: "The semantics of the set operations are generalized to multisets in a @@ -4847,7 +5037,7 @@ set_intersection(), not union() and intersection().

      Change that sentence to use the correct names.


      412. Typo in 27.4.4.3

      -Section: 27.4.4.3 [lib.iostate.flags]  Status: New  Submitter: Martin Sebor  Date: 10 Jul 2003

      +Section: 27.4.4.3 [lib.iostate.flags]  Status: Review  Submitter: Martin Sebor  Date: 10 Jul 2003

      The Effects clause in 27.4.4.3 [lib.iostate.flags] paragraph 5 says that the function only throws if the respective bits are already set prior to @@ -4858,11 +5048,37 @@ exceptions()) == 0, returns. ..."

      Proposed resolution:

      In 27.4.4.3 [lib.iostate.flags] paragraph 5, replace "If (rdstate() & -exceptions()) == 0" with "If (state & exceptions()) == 0". +exceptions()) == 0" with "If ((state | (rdbuf() ? goodbit : badbit)) +& exceptions()) == 0". +

      + +

      [Kona: the original proposed resolution wasn't quite right. We + really do mean rdstate(); the ambiguity is that the wording in the + standard doesn't make it clear whether we mean rdstate() before + setting the new state, or rdsate() after setting it. We intend the + latter, of course. Post-Kona: Martin provided wording.]

      + +
      +

      413. Proposed resolution to LDR#64 still wrong

      +Section: 27.6.1.2.3 [lib.istream::extractors]  Status: New  Submitter: Bo Persson  Date: 13 Jul 2003

      +

      +The second sentence of the proposed resolution says: +

      + +

      +"If it inserted no characters because it caught an exception thrown +while extracting characters from sb and ..." +

      + +

      +However, we are not extracting from sb, but extracting from the +basic_istream (*this) and inserting into sb. I can't really tell if +"extracting" or "sb" is a typo.

      +

      Proposed resolution:


      414. Which iterators are invalidated by v.erase()?

      -Section: 23.2.4.3 [lib.vector.modifiers]  Status: New  Submitter: Matt Austern  Date: 19 Aug 2003

      +Section: 23.2.4.3 [lib.vector.modifiers]  Status: Ready  Submitter: Matt Austern  Date: 19 Aug 2003

      Consider the following code fragment:

      @@ -4898,7 +5114,7 @@ The standard doesn't say either of those things. It says that erase invalidates all iterators and references "after the point of the erase". This doesn't include i1, since it's at the point of the erase instead of after it. I can't think of any sensible definition -of invalidation by which one can say that i2 is invalidated by i1 +of invalidation by which one can say that i2 is invalidated but i1 isn't.

      @@ -4924,10 +5140,8 @@ erase". say that a reference to an erased value remains valid.


      415. behavior of std::ws

      -Section: 27.6.1.4 [lib.istream.manip]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - - +Section: 27.6.1.4 [lib.istream.manip]  Status: Review  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      According to 27.6.1.4, the ws() manipulator is not required to construct the sentry object. The manipulator is also not a member function so the text in 27.6.1, p1 through 4 that describes the exception policy for @@ -4936,22 +5150,26 @@ the rest of extractors and all the other input functions (i.e., ws will not cause a tied stream to be flushed before extraction, it doesn't check the stream's exceptions or catch exceptions thrown during input, and it doesn't affect the stream's gcount). +

      +

      Proposed resolution:

      +

      +Add to 27.6.1.4 [lib.istream.manip], immediately before the first sentence +of paragraph 1, the following text: +

      -

      -

      Proposed resolution:

      -

      - +

      + Behaves as an unformatted input function (as described in + 27.6.1.3, paragraph 1), except that it does not count the number + of characters extracted and does not affect the value returned by + subsequent calls to is.gcount(). After constructing a sentry + object... +
      -I propose that the manipulator be required to behave like an unformatted -member function. It should not behave as a formatted member function since -those set failbit in the sentry ctor according to DR195(*) and ws is explicitly -forbidden from doing that (sure, it could clear the bit, but why bother?) +

      [Post-Kona: Martin provided wording]

      -(*) http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-defects.html#195 -

      -
      +

      416. definitions of XXX_MIN and XXX_MAX macros in climits

      -Section: 18.2.2 [lib.c.limits]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      +Section: 18.2.2 [lib.c.limits]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      Given two overloads of the function foo(), one taking an argument of type @@ -4990,20 +5208,19 @@ where the actual type is easily detectable by overload resolution.

      Proposed resolution:

      -

      -Specify the exact type of each XXX_MIN and XXX_MAX constant #defined in -the header <climits>. Note that it is not possible to #define these macros -so that they are usable in preprocessor arithmetic expressions, having -any type other than char, int, unsigned int, long, and unsigned long. -This means that the type of SHRT_MIN, for instance, has to be either -int ot long in C++. -

      -
      -

      417. what does ctype::do_widen() return on failure

      -Section: 22.2.1.1.2 [lib.locale.ctype.virtuals]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      +

      [Kona: the LWG does not believe this is a defect. The C macro + definitions are what they are; we've got a better + mechanism, std::numeric_limits, that is specified more + precisely than the C limit macros. At most we should add a + nonnormative note recommending that users who care about the exact + types of limit quantities should use <limits> instead of + <climits>.]

      +
      +

      417. what does ctype::do_widen() return on failure

      +Section: 22.2.1.1.2 [lib.locale.ctype.virtuals]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      The Effects and Returns clauses of the do_widen() member function of the ctype facet fail to specify the behavior of the function on failure. That the function may not be able to simply cast the narrow character @@ -5012,44 +5229,47 @@ for some wchar_t encodings. Popular implementations of ctype<wchar_t> that use mbtowc() and UTF-8 as the native encoding (e.g., GNU glibc) will fail when the argument's MSB is set. There is no way for the the rest of locale and iostream to reliably detect this failure. - -

      -

      Proposed resolution:

      -

      - -A partial solution might be to specify that ctype<wchar_t>::do_widen(char) -must return WEOF to indicate a failure. -

      -
      +

      +

      Proposed resolution:

      +

      [Kona: This is a real problem. Widening can fail. It's unclear + what the solution should be. Returning WEOF works for the wchar_t + specialization, but not in general. One option might be to add a + default, like narrow. But that's an incompatible change. + Using traits::eof might seem like a good idea, but facets + don't have access to traits (a recurring problem). We could + have widen throw an exception, but that's a scary option; + existing library components aren't written with the assumption + that widen can throw.]

      +

      418. exceptions thrown during iostream cleanup

      -Section: 27.4.2.1.6 [lib.ios::Init]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - +Section: 27.4.2.1.6 [lib.ios::Init]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      The dtor of the ios_base::Init object is supposed to call flush() on the 6 standard iostream objects cout, cerr, clog, wcout, wcerr, and wclog. This call may cause an exception to be thrown. -
      +

      +

      17.4.4.8, p3 prohibits all library destructors from throwing exceptions. -
      +

      +

      The question is: What should this dtor do if one or more of these calls to flush() ends up throwing an exception? This can happen quite easily if one of the facets installed in the locale imbued in the iostream object throws. - -

      -

      Proposed resolution:

      -

      - -I'm not sure what the best approach is in this case -- ignore the exception -and proceed with the cleanup (required by the clause that prohibits library -dtors from throwing), abort right there and then, or allow the exception to -propagate (and allow an unfriendly termination of the program). -

      -
      +

      +

      Proposed resolution:

      +

      [Kona: We probably can't do much better than what we've got, so + the LWG is leaning toward NAD. At the point where the standard + stream objects are being cleaned up, the usual error reporting + mechanism are all unavailable. And exception from flush at this + point will definitely cause problems. A quality implementation + might reasonably swallow the exception, or call abort, or do + something even more drastic.]

      +

      419. istream extractors not setting failbit if eofbit is already set

      -Section: 27.6.1.1.2 [lib.istream::sentry]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      +Section: 27.6.1.1.2 [lib.istream::sentry]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      27.6.1.1.2, p2 says that istream::sentry ctor prepares for input if is.good() @@ -5120,202 +5340,37 @@ corrected.

      Proposed resolution:

      -

      - -A possible change might go in the Effects clause of the sentry ctor in -27.6.1.1.2, p1. At the end of the paragraph, i.e., after the text beginning -with -
      - -Effects: If is.good() is true, ... -
      - -add -
      - -Otherwise, if (is.rdstate() == ios_base::eofbit) is true, -the function calls is.setstate(failbit) (which may throw -ios_base::failure). -
      - -Another possible wording is -
      - -Otherwise, if is.eof() is true, the function calls -is.setstate(ios_base::failbit) (which may throw -ios_base::failure). -
      - -The difference between the two is that when failbit is set in is.exceptions(), -the first option will cause ios_base::failure to be thrown only during the -first call to the sentry ctor, while the second option will cause -ios_base::failure to be thrown each time the sentry ctor is invoked. I think -I like the first alternative better (i.e., there's no reason to call -setstate(failbit) if the bit is already known to be set). -
      - -The change does not address the possibility of just badbit being set. -Should it? I.e., should the sentry ctor set failbit if (only) badbit is set? -
      - -I haven't done a full survey of all the input functions to make sure the -change doesn't break something else. A second pair eyes would be helpful. -
      - -Survey posted in c++std-lib-11409: -
      - -Below is a survey of a number of popular implementations, including -classic iostreams. Three different sets of behavior exist (case 2 -is the same as case 1 except that istream::sentry does not set -eofbit or failbit in an initially good stream object when its -attempt to extract whitespace fails). -
      - -The major difference seems to be in how badbit is treated in the -initial stream state. Most implementations still set failbit in -this case, but there are three implementations of classic -iostreams that do not. Since all surveyed implementations of -standard iostreams do set failbit in this case, I think we -should probably either require such behavior, or leave it -unspecified (in which case I would prefer to be explicit -about it to avoid any confusion). -
      - -0. Compaq C++ classic + standard, g++ 2.95.2 classic, -g++ 3.2 standard, HP aCC 3.45 standard, Rogue Wave 3.1.1, -Sunpro 5.5 classic + standard, IBM VAC++ 6.0 standard, -STLport 4.5 classic + standard -
      - -1. HP aCC 4.45 classic, SGI MIPSpro 7.3 classic, IBM VAC++ 6.0 classic -
      - -2. SGI MIPSpro 7.3 standard -
      -

      -
                      0     1     2
      -    =========+=====+=====+=====
      -    B--  00  | B-F   B--   B-F
      -    B--  01  | B-F   B--   B-F
      -    B--  10  | B-F   B--   B-F
      -    B--  11  | B-F   B--   B-F
      -    -E-  00  | -EF   -EF   -EF
      -    -E-  01  | -EF   -EF   -EF
      -    -E-  10  | -EF   -EF   -EF
      -    -E-  11  | -EF   -EF   -EF
      -    --F  00  | --F   --F   --F
      -    --F  01  | --F   --F   --F
      -    --F  10  | --F   --F   --F
      -    --F  11  | --F   --F   --F
      -    ---  00  | ---   ---   ---
      -    ---  01  | ---   ---   ---
      -    ---  10  | -EF   -EF   ---
      -    ---  11  | ---   ---   ---
      -    BE-  00  | BEF   BEF   BEF
      -    BE-  01  | BEF   BEF   BEF
      -    BE-  10  | BEF   BEF   BEF
      -    BE-  11  | BEF   BEF   BEF
      -    B-F  00  | B-F   B-F   B-F
      -    B-F  01  | B-F   B-F   B-F
      -    B-F  10  | B-F   B-F   B-F
      -    B-F  11  | B-F   B-F   B-F
      -    BEF  00  | BEF   BEF   BEF
      -    BEF  01  | BEF   BEF   BEF
      -    BEF  10  | BEF   BEF   BEF
      -    BEF  11  | BEF   BEF   BEF
      -    -EF  00  | -EF   -EF   -EF
      -    -EF  01  | -EF   -EF   -EF
      -    -EF  10  | -EF   -EF   -EF
      -    -EF  11  | -EF   -EF   -EF
      -    =========+=====+=====+=====
      -    ^^^  ^^    ^^^   ^^^   ^^^
      -     |   ||     |     |     |
      -     |   ||     +-----+-----+-- final stream state (Bad, Eof, Good,
      -     |   ||                     or '-')
      -     |   |+-------------------- noskiws argument to sentry or ipfx(int)
      -     |   +--------------------- value of (ios::skipws & rdflags()) != 0
      -     +------------------------- initial stream state (Bad, Eof, Good,
      -                                '-')
      -
      -
      -#include <istream>
      -#include <streambuf>
      -#include <stdio.h>
      -
      -struct mybuf: std::streambuf { };
      -
      -int main ()
      -{
      -    static const std::ios::iostate states[] = {
      -        std::ios::badbit,
      -        std::ios::eofbit,
      -        std::ios::failbit,
      -        std::ios::goodbit,
      -        std::ios::badbit | std::ios::eofbit,
      -        std::ios::badbit | std::ios::failbit,
      -        std::ios::badbit | std::ios::eofbit | std::ios::failbit,
      -        std::ios::eofbit | std::ios::failbit
      -    };
      -
      -    for (int i = 0; i != sizeof states / sizeof *states; ++i) {
      -        for (int skipws = 0; skipws != 2; ++skipws) {
      -            for (int noskipws = 0; noskipws != 2; ++noskipws) {
      -              mybuf sb;
      -
      -              std::istream strm (&sb);
      -
      -              strm.setstate (states [i]);
      -
      -              if (skipws)
      -                  strm.setf (std::ios::skipws);
      -              else
      -                  strm.unsetf (std::ios::skipws);
      -
      -              // strm.ipfx (noskipws);
      -              std::istream::sentry guard (strm, !!noskipws);
      -
      -              const std::ios::iostate state = strm.rdstate ();
      -
      -              printf ("%c%c%c %d%d -> %c%c%c\n",
      -                      states [i] & std::ios::badbit ? 'B' : '-',
      -                      states [i] & std::ios::eofbit ? 'E' : '-',
      -                      states [i] & std::ios::failbit ? 'F' : '-',
      -                      skipws, noskipws,
      -                      state & std::ios::badbit ? 'B' : '-',
      -                      state & std::ios::eofbit ? 'E' : '-',
      -                      state & std::ios::failbit ? 'F' : '-');
      -            }
      -        }
      -    }
      -}
      -
      -
      -
      +

      Kona: Possibly NAD. If eofbit is set then good() will return false. We + then set ok to false. We believe that the sentry's + constructor should always set failbit when ok is false, and + we also think the standard already says that. Possibly it could be + clearer.

      + +

      420. is std::FILE a complete type?

      -Section: 27.8.1 [lib.fstreams]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - -7.19.1, p2, of C99 requires that the FILE type only be declared in <stdio.h>. -None of the (implementation-defined) members of the struct is mentioned -anywhere for obvious reasons. +Section: 27.8.1 [lib.fstreams]  Status: Ready  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      +7.19.1, p2, of C99 requires that the FILE type only be declared in +<stdio.h>. None of the (implementation-defined) members of the +struct is mentioned anywhere for obvious reasons. +

      +

      C++ says in 27.8.1, p2 that FILE is a type that's defined in <cstdio>. Is it really the intent that FILE be a complete type or is an implementation allowed to just declare it without providing a full definition? - -

      -

      Proposed resolution:

      -

      - -Change 27.8.1, p2 to say that FILE is declared in <cstdio> and a note saying -that it's implementation-defined whether the type is complete or not. -

      -
      +

      +

      Proposed resolution:

      +

      In the first sentence of 27.8.1 [lib.fstreams] paragraph 2, change + "defined" to "declared".

      +

      Rationale:

      +

      We don't want to impose any restrictions beyond what the C standard + already says. We don't want to make anything implementation defined, + because that imposes new requirements in implementations.

      +

      421. is basic_streambuf copy-constructible?

      -Section: 27.5.2.1 [lib.streambuf.cons]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - +Section: 27.5.2.1 [lib.streambuf.cons]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      The reflector thread starting with c++std-lib-11346 notes that the class template basic_streambuf, along with basic_stringbuf and basic_filebuf, is copy-constructible but that the semantics of the copy constructors @@ -5330,169 +5385,22 @@ these operations well-defined semantics. Note that this problem doesn't seem to be isolated to just the three types mentioned above. A number of other types in the library section of the standard provide a compiler-generated copy ctor and assignment -operator yet fail to specify their semantics. A (possibly still -incomplete) list of such types along with the headers they are defined -in is provided below, courtesy of Howard Hinnant: -
      -

      -
      <limits>
      -        numeric_limits
      -<stdexcept>
      -        logic_error
      -        domain_error
      -        invalid_argument
      -        length_error
      -        out_of_range
      -        runtime_error
      -        range_error
      -        overflow_error
      -        underflow_error
      -<utility>
      -        pair
      -<functional>
      -        unary_function
      -        binary_function
      -        plus
      -        minus
      -        multiplies
      -        divides
      -        modulus
      -        negate
      -        equal_to
      -        not_equal_to
      -        greater
      -        less
      -        greater_equal
      -        less_equal
      -        logical_and
      -        logical_or
      -        logical_not
      -        unary_negate
      -        binary_negate
      -        binder1st
      -        binder2nd
      -        pointer_to_unary_function
      -        pointer_to_binary_function
      -        mem_fun_t
      -        mem_fun1_t
      -        mem_fun_ref_t
      -        mem_fun1_ref_t
      -        const_mem_fun_t
      -        const_mem_fun1_t
      -        const_mem_fun_ref_t
      -        const_mem_fun1_ref_t
      -<memory>
      -        allocator<void>
      -        allocator  // operator= only, which also isn't required by Allocator Requirements
      -        raw_storage_iterator
      -<string>
      -        char_traits<char>
      -        char_traits<wchar_t>
      -<locale>
      -        ctype_base
      -        ctype
      -        ctype_byname
      -        ctype<char>
      -        ctype_byname<char>
      -        codecvt_base
      -        codecvt
      -        codecvt_byname
      -        num_get
      -        num_put
      -        numpunct
      -        numpunct_byname
      -        collate
      -        collate_byname
      -        time_base
      -        time_get
      -        time_get_byname
      -        time_put
      -        time_put_byname
      -        money_get
      -        money_put
      -        money_base
      -        moneypunct
      -        moneypunct_byname
      -        messages_base
      -        messages
      -        messages_byname
      -<queue>
      -        queue
      -        priority_queue
      -<stack>
      -        stack
      -<vector>
      -        vector<bool>::reference // copy ctor only
      -<map>
      -        map::value_compare
      -        multimap::value_compare
      -<bitset>
      -        bitset::reference  // copy ctor only
      -        bitset
      -<iterator>
      -        iterator_traits
      -        iterator_traits<T*>
      -        iterator_traits<const T*>
      -        iterator
      -        input_iterator_tag
      -        output_iterator_tag
      -        forward_iterator_tag
      -        bidirectional_iterator_tag
      -        random_access_iterator_tag
      -        reverse_iterator
      -        back_insert_iterator
      -        front_insert_iterator
      -        insert_iterator
      -        istream_iterator // operator= only
      -        ostream_iterator // operator= only
      -        istreambuf_iterator
      -        istreambuf_iterator::proxy
      -        ostreambuf_iterator
      -<complex>
      -        complex<float> // copy ctor only
      -        complex<double> // copy ctor only
      -        complex<long double> // copy ctor only
      -<valarray>
      -        slice
      -        gslice
      -<ios>
      -        ios_base  // addressed by TC issue 50
      -        ios_base::failure
      -        ios_base::Init
      -        fpos
      -<streambuf>
      -        basic_streambuf
      -<istream>
      -        basic_istream
      -        basic_iostream
      -<ostream>
      -        basic_ostream
      -<sstream>
      -        basic_stringbuf
      -        basic_istringstream
      -        basic_ostringstream
      -        basic_stringstream
      -<fstream>
      -        basic_filebuf
      -        basic_ifstream
      -        basic_ofstream
      -        basic_fstream
      -<strstream>
      -        strstreambuf
      -        istrstream
      -        ostrstream
      -        strstream
      -
      -

      Proposed resolution:

      -

      +operator yet fail to specify their semantics. It's believed that the +only types for which this is actually a problem (i.e. types where the +compiler-generated default may be inappropriate and may not have been +intended) are locale facets. See issue 439. +

      +

      Proposed resolution:

      +

      [Kona: this is an issue for basic_streambuf itself and for its + derived classes. We are leaning toward allowing basic_streambuf to + be copyable, and specifying its precise semantics. (Probably the + obvious: copying the buffer pointers.) We are less sure whether + the streambuf derived classes should be copyable. Howard will + write up a proposal.]

      -The standard ought to be clarified to either explicitly disallow copy -ctors and assignment operators for these types, or to specify what -the exact semantics of these functions are. -

      -
      +

      422. explicit specializations of member functions of class templates

      -Section: 17.4.3.1 [lib.reserved.names]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      +Section: 17.4.3.1 [lib.reserved.names]  Status: Review  Submitter: Martin Sebor  Date: 18 Sep 2003

      It has been suggested that 17.4.3.1, p1 may or may not allow programs to explicitly specialize members of standard templates on user-defined types. @@ -5504,19 +5412,27 @@ in terms of the other member function (the one explicitly specialized by the program) by relying on the "as if" rule.

      Proposed resolution:

      +

      -While I think programs should be allowed to explicitly specialize member -functions of standard templates, I don't find it reasonable to expect -implementations to follow the "as if" rule to the letter. I propose to add -a clause to chapter 17 saying that where a function is described in terms -of another (non-virtual) function using the "as if" rule, an implementation -may substitute another (non-virtual) function call as long as the effects -on the object remain the same as in the absence of any specializations -of the called function in the program. + Add the following sentence immediately after the text of 17.4.3.1 [lib.reserved.names], p1:

      + +
      + The behavior of a program that declares explicit specializations + of any members of class templates or explicit specializations of + any member templates of classes or class templates defined in + this library is undefined. +
      + + +

      [Kona: straw poll was 6-1 that user programs should not be + allowed to specialize individual member functions of standard + library class templates, and that doing so invokes undefined + behavior. Post-Kona: Martin provided wording.]

      +

      423. effects of negative streamsize in iostreams

      -Section: 27 [lib.input.output]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      +Section: 27 [lib.input.output]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      A third party test suite tries to exercise istream::ignore(N) with @@ -5539,9 +5455,15 @@ is to allow negative streamsize values in calls to precision() and width() but disallow it in calls to streambuf::sgetn(), istream::ignore(), or ostream::write().

      + +

      [Kona: The LWG agreed that this is probably what we want. However, we + need a review to find all places where functions in clause 27 take + arguments of type streamsize that shouldn't be allowed to go + negative. Martin will do that review.]

      +

      424. normative notes

      -Section: 17.3.1.1 [lib.structure.summary]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      +Section: 17.3.1.1 [lib.structure.summary]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      The text in 17.3.1.1, p1 says: @@ -5583,152 +5505,110 @@ None of these lists is meant to be exhaustive.

      Proposed resolution:

      -

      -One possible solution is to identify all the paragraphs marked "Note(s):" -that are intended to be normative and either remove the labeling or replace -it with some other word, such as "Effects:" to make the normative intent -clear. -
      +

      [Definitely a real problem. The big problem is there's material + that doesn't quite fit any of the named paragraph categories + (e.g. Effects). Either we need a new kind of named + paragraph, or we need to put more material in unnamed paragraphs + jsut after the signature. We need to talk to the Project Editor + about how to do this. +]

      -Another possible solution is to change 17.3.1.1, p1 and remove the mention -of Notes being informative, and then go through all the paragraphs marked -"Note(s):" that are intended to be informative and make change preserving -their informative nature. -

      -
      +

      425. return value of std::get_temporary_buffer

      -Section: 20.4.3 [lib.temporary.buffer]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - +Section: 20.4.3 [lib.temporary.buffer]  Status: Review  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      The standard is not clear about the requirements on the value returned from a call to get_temporary_buffer(0). In particular, it fails to specify whether the call should return a distinct pointer each time it is called (like operator new), or whether the value is unspecified (as if returned by malloc). The standard also fails to mention what the required behavior is when the argument is less than 0. - -

      -

      Proposed resolution:

      -

      - -In the first case, I propose that the function behave like malloc, i.e., -
      - -If the size of the space requested is zero, the behavior is -implementation-defined: either pair(0, 0) is returned, or the behavior is -as if the size were some nonzero value, except that the returned pointer -is not dereferenceable. -
      - -In the second case, I propose that the function fail by returning pair(0, 0). -

      -
      +

      +

      Proposed resolution:

      +

      Change 20.4.3 [lib.temporary.buffer] paragraph 2 from "...or a pair of 0 +values if no storage can be obtained" to "...or a pair of 0 values if +no storage can be obtained or if n <= 0."

      +

      [Kona: Matt provided wording]

      +

      426. search_n(), fill_n(), and generate_n() with negative n

      -Section: 25.1.9 [lib.alg.search], 25.2.5 [lib.alg.fill], 25.2.6 [lib.alg.generate]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - +Section: 25.1.9 [lib.alg.search], 25.2.5 [lib.alg.fill], 25.2.6 [lib.alg.generate]  Status: Review  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      The complexity requirements for these function templates are incorrect -(or don't even make sense) for negative n: -
      +(or don't even make sense) for negative n:

      -25.1.9, p7 (search_n): +

      25.1.9, p7 (search_n):
      - Complexity: At most (last1 - first1) * count applications -of the corresponding predicate. -
      - -25.2.5, p3 (fill_n): -
      +of the corresponding predicate.

      -Complexity: Exactly last - first (or n) assignments. +

      25.2.5, p3 (fill_n):
      - -25.2.6, p3 (generate_n): +Complexity: Exactly last - first (or n) assignments.


      -Complexity: Exactly last - first (or n) assignments. +

      25.2.6, p3 (generate_n):
      +Complexity: Exactly last - first (or n) assignments.

      +

      In addition, the Requirements or the Effects clauses for the latter two templates don't say anything about the behavior when n is negative. +

      +

      Proposed resolution:

      +

      Change 25.1.9, p7 to

      -

      -

      Proposed resolution:

      -

      - -My proposed fix is to: -
      - -Change 25.1.9, p7 to -
      - +

      Complexity: At most (last1 - first1) * count applications of the corresponding predicate if count is non-negative, or 0 otherwise. -
      - -Change 25.2.5, p2 from -
      - -Effects: Assigns value through all the iterators in the -range [first, last) or [first, first + n). -
      - -to -
      +
      +

      Change 25.2.5, p2 to

      +
      Effects: Assigns value through all the iterators in the range [first, last), or [first, first + n) if n is non negative, none otherwise. -
      - -Change 25.2.5, p3 to: -
      +
      +

      Change 25.2.5, p3 to:

      +
      Complexity: Exactly last - first (or n if n is non-negative, or 0 otherwise) assignments. -
      - -Change 25.2.6, p1 from -
      - -Effects: Invokes the function object gen and assigns the return -value of gen though all the iterators in the range [first, last) -or [first, first + n). -
      +
      +

      +Change 25.2.6, p1 to (notice the correction for the misspelled "through"): -
      - +

      +
      Effects: Invokes the function object genand assigns the return value of gen through all the iterators in the range [first, last), or [first, first + n) if n is non-negative, or [first, first) otherwise. -
      - -Change 25.2.6, p3 to: -
      +
      +

      Change 25.2.6, p3 to:

      +
      Complexity: Exactly last - first (or n if n is non-negative, or 0 otherwise) assignments. -
      - -The alternative is to require that n be non-negative. I chose -the other option in order to keep the requirements in line with -those of search_n which allows negative counts. -

      -
      +
      +

      Rationale:

      +

      Informally, we want to say that whenever we see a negative number + we treat it the same as if it were zero. We believe the above + changes do that (although they probably aren't the minimal way of + saying so). The LWG considered and rejected the alternative of + saying that negative numbers are undefined behavior.

      +

      427. stage 2 and rationale of DR 221

      -Section: 22.2.2.1.2 [lib.facet.num.get.virtuals]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - +Section: 22.2.2.1.2 [lib.facet.num.get.virtuals]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      The requirements specified in Stage 2 and reiterated in the rationale of DR 221 (and echoed again in DR 303) specify that num_get<charT>:: do_get() compares characters on the stream against the widened elements of "012...abc...ABCX+-" -
      +

      +

      An implementation is required to allow programs to instantiate the num_get template on any charT that satisfies the requirements on a user-defined character type. These requirements do not include the ability of the @@ -5740,119 +5620,62 @@ must either make the assumption that the character type is equality-comparable the comparisons (some other popular implementations do that). This diversity of approaches makes it difficult to write portable programs that attempt to instantiate the num_get template on user-defined types. - -

      -

      Proposed resolution:

      -

      - -Specify a mechanism whereby the num_get template may compare objects of -user-defined character types. Several possible solutions, each having -some drawbacks, were discussed in a thread on c++std-lib@research.att.com -starting with c++std-lib-10623. -
      - -One possibility is to require that user-defined character types be equality -comparable, thus obviating tye need for the char_traits::eq() function. This -solution would make the requirements imposed on user-defined character types -by the locale templates inconsistent with those of basic_string. -
      - -Another option is to require that programs that instantiate num_get on -user-defined types provide an explicit specialization of the std::char_traits -template on that type and require num_get to use it. This solution would -render the basic_string Traits template parameter useless. -
      - -Yet another option is to specify that when the num_get facet is instantiated -on a user-defined character type, say charT, that defines the nested type -charT::traits_type, num_get should use it to do comparisons. Otherwise, -num_get should use std::char_traits<charT>. This solution, while more -robust than the first two, might set the unwarranted expectation that -a program that provides two traits classes for the same character type -will have meaningful semantics. -
      - -Finally, arguably the most flexible solution is to remove the requirement -from Stage 2 that num_get compare the widened set of character literals and -instead have the template compare the narrowed characters read from the -input sequence. This issue proposes to adopt this last option as the -resolution. -

      -
      +

      +

      Proposed resolution:

      +

      [Kona: the heart of the problem is that we're theoretically + supposed to use traits classes for all fundamental character + operations like assignment and comparison, but facets don't have + traits parameters. This is a fundamental design flaw and it + appears all over the place, not just in this one place. It's not + clear what the correct solution is, but a thorough review of facets + and traits is in order. (The LWG considered and rejected the + possibility of changing numeric facets to use narrowing instead of + widening: it wouldn't fix the general problem, it would be a + drastic reversal of a deliberate change, and it would probably have + unfortunate performance implications.)]

      +

      428. string::erase(iterator) validity

      -Section: 21.3.5.5 [lib.string::erase]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - +Section: 21.3.5.5 [lib.string::erase]  Status: Ready  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      23.1.1, p3 along with Table 67 specify as a prerequisite for a.erase(q) that q must be a valid dereferenceable iterator into the sequence a. -
      +

      +

      However, 21.3.5.5, p5 describing string::erase(p) only requires that p be a valid iterator. -
      +

      +

      This may be interepreted as a relaxation of the general requirement, which is most likely not the intent. - -

      -

      Proposed resolution:

      -

      - -Either clarify 21.3.5.5, p5 to say that the iterator is required to be -valid and dereferenceable or drop the requirement altogether and rely -on the general container requirements outlined in Table 67. -

      -
      -

      429. typo in basic_ios::clear(iostate)

      -Section: 27.4.4.3 [lib.iostate.flags]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - -The Effects clause in 27.4.4.3, p5 describing the effects of a call to -the ios_base member function clear(iostate state) says that the function -only throws if the respective bits are already set prior to the function -call. That's obviously not the intent. If it was, a call to clear(badbit) -on an object for which (rdstate() == goodbit && exceptions() == badbit) -holds would not result in an exception being thrown. - -

      -

      Proposed resolution:

      -

      - -The text ought to be changed from -
      - -"If (rdstate() & exceptions()) == 0, returns. ..." -
      - -to -
      - -"If (state & exceptions()) == 0, returns. ..." -

      -
      +

      +

      Proposed resolution:

      +

      Remove 21.3.5.5 [lib.string::erase] paragraph 5.

      +

      Rationale:

      +

      The LWG considered two options: changing the string requirements to + match the general container requirements, or just removing the + erroneous string requirements altogether. The LWG chose the latter + option, on the grounds that duplicating text always risks the + possibility that it might be duplicated incorrectly.

      +

      430. valarray subset operations

      -Section: 26.3.2.4 [lib.valarray.sub]  Status: New  Submitter: Martin Sebor  Date: 18 Sep 2003

      -

      - +Section: 26.3.2.4 [lib.valarray.sub]  Status: Open  Submitter: Martin Sebor  Date: 18 Sep 2003

      +

      The standard fails to specify the behavior of valarray::operator[](slice) and other valarray subset operations when they are passed an "invalid" slice object, i.e., either a slice that doesn't make sense at all (e.g., slice (0, 1, 0) or one that doesn't specify a valid subset of the valarray object (e.g., slice (2, 1, 1) for a valarray of size 1). - -

      -

      Proposed resolution:

      -

      - -Clarify the text of the standard to define what constitutes a valid and -invalid slice object, and either specify the exact behavior of these -member functions when passed an invalid slice object, or explicitly -specify that the behavior is undefined under these conditions for the -sake of efficiency. -

      -
      +

      +

      Proposed resolution:

      +

      [Kona: the LWG believes that invalid slices should invoke + undefined behavior. Valarrays are supposed to be designed for high + performance, so we don't want to require specific checking. We + need wording to express this decision.]

      +

      431. Swapping containers with unequal allocators

      -Section: 20.1.5 [lib.allocator.requirements], 25 [lib.algorithms]  Status: New  Submitter: Matt Austern  Date: 20 Sep 2003

      +Section: 20.1.5 [lib.allocator.requirements], 25 [lib.algorithms]  Status: Open  Submitter: Matt Austern  Date: 20 Sep 2003

      Clause 20.1.5 [lib.allocator.requirements] paragraph 4 says that implementations are permitted to supply containers that are unable to cope with allocator instances and that container implementations may assume @@ -5892,5 +5715,559 @@ sake of efficiency.

      Proposed resolution:

      + +

      [Kona: This is part of a general problem. We need a paper + saying how to deal with unequal allocators in general.]

      + +
      +

      432. stringbuf::overflow() makes only one write position available

      +Section: 27.7.1.3 [lib.stringbuf.virtuals]  Status: Open  Submitter: Christian W Brock  Date: 24 Sep 2003

      +

      27.7.1.3 par 8 says:

      +
      +Notes: The function can make a write position available only if + ( mode & ios_base::out) != 0. To make a write position + available, the function reallocates (or initially allocates) an + array object with a sufficient number of elements to hold the + current array object (if any), plus one additional write position. + If ( mode & ios_base::in) != 0, the function alters the read end + pointer egptr() to point just past the new write position (as + does the write end pointer epptr()). +
      + +

      +The sentences "plus one additional write position." and especially + "(as does the write end pointer epptr())" COULD by interpreted + (and is interpreted by at least my library vendor) as: +

      + +
      + post-condition: epptr() == pptr()+1 +
      + +

      +This WOULD force sputc() to call the virtual overflow() each time. +

      + +

      The proposed change also affects Defect Report 169.

      + +

      Proposed resolution:

      +

      Change the paragraph in question to:

      +
      +Notes: The function can make a write position available only if + ( mode & ios_base::out) != 0. To make a write position + available, the function reallocates (or initially allocates) an + array object with a sufficient number of elements to hold the + current array object (if any), plus at least one additional write + position. The function alters the write end + pointer epptr() to point one position past + the end of the new available write area. + If ( mode & ios_base::in) != 0, the function alters the read end + pointer egptr() to point just past the new write position. +
      + +

      [Kona: we want to make this change because of efficiency, but we + need to specify more precisely what the underlying character + sequence is; the proposed change isn't enough. (We want the + returned string to end with the last character written, for example, + not the last character allocated. This probably implies that the + stringbuf keep track of a high water mark.) Howard will provide + wording.]

      + +
      +

      434. bitset::to_string() hard to use

      +Section: 23.3.5.2 [lib.bitset.members]  Status: Open  Submitter: Martin Sebor  Date: 15 Oct 2003

      +

      +It has been pointed out a number of times that the bitset to_string() member +function template is tedious to use since callers must explicitly specify the +entire template argument list (3 arguments). At least two implementations +provide a number of overloads of this template to make it easier to use. +

      +

      Proposed resolution:

      +

      In order to allow callers to specify no template arguments at all, just the +first one (charT), or the first 2 (charT and traits), in addition to all +three template arguments, add the following three overloads to both the +interface (declarations only) of the class template bitset as well as to +section 23.3.5.2, immediately after p34, the Returns clause of the existing +to_string() member function template:

      + +
          template <class charT, class traits>
      +    basic_string<charT, traits, allocator<charT> >
      +    to_string () const;
      +
      +    -34.1- Returns: to_string<charT, traits, allocator<charT> >().
      +
      +    template <class charT>
      +    basic_string<charT, char_traits<charT>, allocator<charT> >
      +    to_string () const;
      +
      +    -34.2- Returns: to_string<charT, char_traits<charT>, allocator<charT> >().
      +
      +    basic_string<char, char_traits<char>, allocator<char> >
      +    to_string () const;
      +
      +    -34.3- Returns: to_string<char, char_traits<char>, allocator<char> >().
      +
      + +

      [Kona: the LWG agrees that this is an improvement over the + status quo. Dietmar will propose an alternative using a proxy + object, so that "s = b.to_string()" would work not just when s is + of type std::string, but when s is of type std::basic_string<C,T> + for arbitrary types C and T.]

      + +
      +

      435. bug in DR 25

      +Section: 21.3.7.9 [lib.string.io]  Status: Review  Submitter: Martin Sebor  Date: 15 Oct 2003

      + +

      +It has been pointed out that the proposed resolution in DR 25 may not be +quite up to snuff:
      +http://gcc.gnu.org/ml/libstdc++/2003-09/msg00147.html +http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-defects.html#25
      +

      + +

      +It looks like Petur is right. The complete corrected text is copied below. +I think we may have have been confused by the reference to 22.2.2.2.2 and +the subsequent description of `n' which actually talks about the second +argument to sputn(), not about the number of fill characters to pad with. +

      + +

      +So the question is: was the original text correct? If the intent was to +follow classic iostreams then it most likely wasn't, since setting width() +to less than the length of the string doesn't truncate it on output. This +is also the behavior of most implementations (except for SGI's standard +iostreams where the operator does truncate). +

      +

      Proposed resolution:

      +

      Change the text in 21.3.7.9, p4 from

      +
      + If bool(k) is true, inserts characters as if by calling + os.rdbuf()->sputn(str.data(), n), padding as described in stage 3 + of lib.facet.num.put.virtuals, where n is the larger of os.width() + and str.size(); +
      +

      to

      +
      + If bool(k) is true, determines padding as described in + lib.facet.num.put.virtuals, and then inserts the resulting + sequence of characters as if by calling + os.rdbuf()->sputn(sequence, n), where n is the larger of + os.width() and str.size(); +
      + +

      [Kona: it appears that neither the original wording, DR25, nor the + proposed resolution, is quite what we want. We want to say that + the string will be output, padded to os.width() if necessary. We + don't want to duplicate the padding rules in clause 22, because + they're complicated, but we need to be careful because they weren't + quite written with quite this case in mind. We need to say what + the character sequence is, and then defer to clause 22. Post-Kona: + Benjamin provided wording.]

      + +
      +

      436. are cv-qualified facet types valid facets?

      +Section: 22.1.1.1.2 [lib.locale.facet]  Status: Ready  Submitter: Martin Sebor  Date: 15 Oct 2003

      +

      +Is "const std::ctype<char>" a valid template argument to has_facet, use_facet, +and the locale template ctor? And if so, does it designate the same Facet as +the non-const "std::ctype<char>?" What about "volatile std::ctype<char>?" +Different implementations behave differently: some fail to compile, others +accept such types but behave inconsistently. +

      +

      Proposed resolution:

      +

      Change 22.1.1.1.2, p1 to read:

      + +

      Template parameters in this clause which are required to be facets +are those named Facet in declarations. A program that passes a type +that is not a facet, or a type that refers to volatile-qualified +facet, as an (explicit or deduced) template parameter to a locale +function expecting a facet, is ill-formed. A const-qualified facet is +a valid template argument to any locale function that expects a Facet +template parameter.

      + +

      [Kona: changed the last sentence from a footnote to normative +text.]

      + +
      +

      438. Ambiguity in the "do the right thing" clause

      +Section: 23.1.1 [lib.sequence.reqmts]  Status: Review  Submitter: Howard Hinnant  Date: 20 Oct 2003

      + +

      Section 23.1.1 [lib.sequence.reqmts], paragraphs 9-11, fixed up the problem +noticed with statements like:

      +
      vector<int> v(10, 1);
      +
      + +

      The intent of the above statement was to construct with:

      +
      vector(size_type, const value_type&);
      +
      + +

      but early implementations failed to compile as they bound to:

      +
      template <class InputIterator>
      +vector(InputIterator f, InputIterator l);
      +
      +

      instead.

      + +

      Paragraphs 9-11 say that if InputIterator is an integral type, then the +member template constructor will have the same effect as:

      +
      vector<static_cast<size_type>(f), static_cast<value_type>(l));
      +
      +

      (and similarly for the other member template functions of sequences).

      + +

      There is also a note that describes one implementation technique:

      +
      + One way that sequence implementors can satisfy this requirement is to + specialize the member template for every integral type. +
      + +

      This might look something like:

      +
      +
      template <class T>
      +struct vector
      +{
      +     typedef unsigned size_type;
      +
      +     explicit vector(size_type) {}
      +     vector(size_type, const T&) {}
      +
      +     template <class I>
      +     vector(I, I);
      +
      +     // ...
      +};
      +
      +template <class T>
      +template <class I>
      +vector<T>::vector(I, I) { ... }
      +
      +template <>
      +template <>
      +vector<int>::vector(int, int) { ... }
      +
      +template <>
      +template <>
      +vector<int>::vector(unsigned, unsigned) { ... }
      +
      +//  ...
      +
      +
      + +

      Label this solution 'A'.

      + +

      The standard also says:

      +
      + Less cumbersome implementation techniques also exist. +
      +

      +A popular technique is to not specialize as above, but instead catch +every call with the member template, detect the type of InputIterator, +and then redirect to the correct logic. Something like: +

      +
      +
      template <class T>
      +template <class I>
      +vector<T>::vector(I f, I l)
      +{
      +     choose_init(f, l, int2type<is_integral<I>::value>());
      +}
      +
      +template <class T>
      +template <class I>
      +vector<T>::choose_init(I f, I l, int2type<false>)
      +{
      +    // construct with iterators
      +}
      +
      +template <class T>
      +template <class I>
      +vector<T>::choose_init(I f, I l, int2type<true>)
      +{
      +    size_type sz = static_cast<size_type>(f);
      +    value_type v = static_cast<value_type>(l);
      +    // construct with sz,v
      +}
      +
      +
      + +

      Label this solution 'B'.

      + +

      Both of these solutions solve the case the standard specifically +mentions:

      +
      vector<int> v(10, 1);  // ok, vector size 10, initialized to 1
      +
      + +

      +However, (and here is the problem), the two solutions have different +behavior in some cases where the value_type of the sequence is not an +integral type. For example consider: +

      +
           pair<char, char>                     p('a', 'b');
      +     vector<vector<pair<char, char> > >   d('a', 'b');
      +
      +

      +The second line of this snippet is likely an error. Solution A catches +the error and refuses to compile. The reason is that there is no +specialization of the member template constructor that looks like: +

      +
      template <>
      +template <>
      +vector<vector<pair<char, char> > >::vector(char, char) { ... }
      +
      + +

      +So the expression binds to the unspecialized member template +constructor, and then fails (compile time) because char is not an +InputIterator. +

      + +

      +Solution B compiles the above example though. 'a' is casted to an +unsigned integral type and used to size the outer vector. 'b' is +static casted to the inner vector using it's explicit constructor: +

      + +
      explicit vector(size_type n);
      +
      + +

      +and so you end up with a static_cast<size_type>('a') by +static_cast<size_type>('b') matrix. +

      + +

      +It is certainly possible that this is what the coder intended. But the +explicit qualifier on the inner vector has been thwarted at any rate. +

      + +

      +The standard is not clear whether the expression: +

      + +
           vector<vector<pair<char, char> > >   d('a', 'b');
      +
      + +

      +(and similar expressions) are: +

      + +
        +
      1. undefined behavior.
      2. +
      3. illegal and must be rejected.
      4. +
      5. legal and must be accepted.
      6. +
      + +

      My preference is listed in the order presented.

      + +

      There are still other techniques for implementing the requirements of +paragraphs 9-11, namely the "restricted template technique" (e.g. +enable_if). This technique is the most compact and easy way of coding +the requirements, and has the behavior of #2 (rejects the above +expression). +

      + +

      +Choosing 1 would allow all implementation techniques I'm aware of. +Choosing 2 would allow only solution 'A' and the enable_if technique. +Choosing 3 would allow only solution 'B'. +

      + +

      +Possible wording for a future standard if we wanted to actively reject +the expression above would be to change "static_cast" in paragraphs +9-11 to "implicit_cast" where that is defined by: +

      + +
      +
      template <class T, class U>
      +inline
      +T implicit_cast(const U& u)
      +{
      +     return u;
      +}
      +
      +
      + +

      Proposed resolution:

      + +Replace 23.1.1 [lib.sequence.reqmts] paragraphs 9 - 11 with: + +

      For every sequence defined in this clause and in clause lib.strings:

      + +
        +
      • +

        If the constructor

        +
               template <class InputIterator>
        +       X(InputIterator f, InputIterator l,
        +         const allocator_type& a = allocator_type())
        +       
        +

        is called with a type InputIterator that does not qualify as + an input iterator, then the constructor will behave as if the + overloaded constructor:

        +
               X(size_type, const value_type& = value_type(),
        +         const allocator_type& = allocator_type())
        +       
        +

        were called instead, with the arguments f, l and a, respectively.

        +
      • + +
      • +

        If the member functions of the forms:

        +
               template <class InputIterator>          //  such as  insert()
        +       rt fx1(iterator p, InputIterator f, InputIterator l);
        +
        +       template <class InputIterator>          //  such as  append(), assign()
        +       rt fx2(InputIterator f, InputIterator l);
        +
        +       template <class InputIterator>          //  such as  replace()
        +       rt fx3(iterator i1, iterator i2, InputIterator f, InputIterator l);
        +       
        +

        are called with a type InputIterator that does not qualify as + an input iterator, then these functions will behave as if the + overloaded member functions:

        +
               rt fx1(iterator, size_type, const value_type&);
        +
        +       rt fx2(size_type, const value_type&);
        +
        +       rt fx3(iterator, iterator, size_type, const value_type&);
        +       
        +

        were called instead, with the same arguments.

        +
      • +
      + +

      In the previous paragraph the alternative binding will fail if f +is not implicitly convertible to X::size_type or if l is not implicitly +convertible to X::value_type.

      + +

      The extent to which an implementation endeavors to qualify a type +as an input iterator is unspecified, except that as a minimum integral +types will not qualify as input iterators.

      + + + +

      [ +Kona: agreed that the current standard requires v('a', 'b') +to be accepted, and also agreed that this is surprising behavior. +The LWG considered several options, including something like +implicit_cast, which doesn't appear to be quite what we want. We +considered Howards three options: allow acceptance or rejection, +require rejection as a compile time error, and require acceptance. +By straw poll (1-6-1), we chose to require a compile time error. +Post-Kona: Howard provided wording. +]

      + +

      Rationale:

      +

      The proposed resolution fixes:

      + +
        vector<int> v(10, 1);
      +
      + +

      +since as integral types 10 and 1 must be disqualified as input +iterators and therefore the (size,value) constructor is called (as +if).

      + +

      The proposed resolution breaks:

      + +
        vector<vector<T> > v(10, 1);
      +
      + +

      +because the integral type 1 is not *implicitly* convertible to +vector<T>. The wording above requires a diagnostic.

      + +

      +The proposed resolution leaves the behavior of the following code +unspecified. +

      + +
        struct A
      +  {
      +    operator int () const {return 10;}
      +  };
      +
      +  struct B
      +  {
      +    B(A) {}
      +  };
      +
      +  vector<B> v(A(), A());
      +
      + +

      +The implementation may or may not detect that A is not an input +iterator and employee the (size,value) constructor. Note though that +in the above example if the B(A) constructor is qualified explicit, +then the implementation must reject the constructor as A is no longer +implicitly convertible to B. +

      +
      +

      439. Should facets be copyable?

      +Section: 22.2 [lib.locale.categories]  Status: New  Submitter: Matt Austern  Date: 2 Nov 2003

      +

      The following facets classes have no copy constructors described in + the standard, which, according to the standard, means that they are + supposed to use the compiler-generated defaults. Default copy + behavior is probably inappropriate. We should either make these + classes uncopyable or else specify exactly what their constructors do.

      + +

      Related issue: 421.

      + +
              ctype_base
      +        ctype
      +        ctype_byname
      +        ctype<char>
      +        ctype_byname<char>
      +        codecvt_base
      +        codecvt
      +        codecvt_byname
      +        num_get
      +        num_put
      +        numpunct
      +        numpunct_byname
      +        collate
      +        collate_byname
      +        time_base
      +        time_get
      +        time_get_byname
      +        time_put
      +        time_put_byname
      +        money_get
      +        money_put
      +        money_base
      +        moneypunct
      +        moneypunct_byname
      +        messages_base
      +        messages
      +        messages_byname
      +
      + +

      Proposed resolution:

      +

      +

      +
      +

      440. Should std::complex use unqualified transcendentals?

      +Section: 26.2.8 [lib.complex.transcendentals]  Status: New  Submitter: Matt Austern  Date: 5 Nov 2003

      +

      +Operations like pow and exp on +complex<T> are typically implemented in terms of +operations like sin and cos on T. +Should implementations write this as std::sin, or as plain +unqualified sin? +

      + +

      The issue, of course, is whether we want to use +argument-dependent lookup in the case where T is a +user-defined type. This is similar to the issue of valarray +transcendentals, as discussed in issue 226.

      + +

      This issue differs from valarray transcendentals in two important +ways. First, "the effect of instantiating the template +complex for types other than float, double or long double is +unspecified." (26.2.1 [lib.complex.synopsis]) Second, the standard does not +dictate implementation, so there is no guarantee that a particular +real math function is used in the implementation of a particular +complex function.

      + +

      Proposed resolution:

      +

      +

      ----- End of document -----

      \ No newline at end of file diff --git a/libstdc++-v3/docs/html/ext/lwg-defects.html b/libstdc++-v3/docs/html/ext/lwg-defects.html index 3c26633595f3..dc11dc47eb12 100644 --- a/libstdc++-v3/docs/html/ext/lwg-defects.html +++ b/libstdc++-v3/docs/html/ext/lwg-defects.html @@ -4,11 +4,11 @@ - + - + @@ -19,7 +19,7 @@
      Doc. no.N1516 = 03-0099N1538=03-0121
      Date:20 Sep 200313 Nov 2003
      Project:Matt Austern <austern@apple.com>
      -

      C++ Standard Library Defect Report List (Revision 27)

      +

      C++ Standard Library Defect Report List (Revision 28)

      Reference ISO/IEC IS 14882:1998(E)

      Also see:

      (that is, remove the `&').


      -

      261. Missing description of istream_iterator::operator!= -

      +

      261. Missing description of istream_iterator::operator!= +

      Section: 24.5.1.2 [lib.istream.iterator.ops]  Status: WP  Submitter: Martin Sebor  Date: 27 Aug 2000

      24.5.1, p3 lists the synopsis for @@ -6823,7 +6827,7 @@ Add paragraph 7 to the end of section 24.5.1.2 with the following text:

      -7- Returns: !(x == y).


      -

      262. Bitmask operator ~ specified incorrectly

      +

      262. Bitmask operator ~ specified incorrectly

      Section: 17.3.2.1.2 [lib.bitmask.types]  Status: WP  Submitter: Beman Dawes  Date: 03 Sep 2000

      The ~ operation should be applied after the cast to int_type. @@ -6845,7 +6849,7 @@ to: { return static_cast< bitmask>(~static_cast<int_type>(X)); }


      -

      263. Severe restriction on basic_string reference counting

      +

      263. Severe restriction on basic_string reference counting

      Section: 21.3 [lib.basic.string]  Status: WP  Submitter: Kevlin Henney  Date: 04 Sep 2000

      The note in paragraph 6 suggests that the invalidation rules for @@ -6916,7 +6920,7 @@ Change the following sentence in 21.3 paragraph 5 from or rend().


      -

      264. Associative container insert(i, j) complexity requirements are not feasible.

      +

      264. Associative container insert(i, j) complexity requirements are not feasible.

      Section: 23.1.2 [lib.associative.reqmts]  Status: WP  Submitter: John Potter  Date: 07 Sep 2000

      Table 69 requires linear time if [i, j) is sorted. Sorted is necessary but not sufficient. @@ -8706,7 +8710,7 @@ comment in c++std-lib-8939. ]


      -

      312. Table 27 is missing headers

      +

      312. Table 27 is missing headers

      Section: 20 [lib.utilities]  Status: WP  Submitter: Martin Sebor  Date: 29 Mar 2001

      Table 27 in section 20 lists the header <memory> (only) for Memory (lib.memory) but neglects to mention the headers @@ -8822,7 +8826,7 @@ template at all, but simply provide the primary template.

      Remove the comment from the text in 22.2.3.2 and from the proposed resolution of library issue 228.


      -

      319. Storage allocation wording confuses "Required behavior", "Requires"

      +

      319. Storage allocation wording confuses "Required behavior", "Requires"

      Section: 18.4.1.1 [lib.new.delete.single], 18.4.1.2 [lib.new.delete.array]  Status: WP  Submitter: Beman Dawes  Date: 15 May 2001

      The standard specifies 17.3.1.3 [lib.structure.specifications] that "Required behavior" elements describe "the semantics of a function definition @@ -8944,7 +8948,7 @@ with "Replaces the elements of a with a copy of [i, j)." Changes not deemed serious enough to requre rereview.]


      -

      321. Typo in num_get

      +

      321. Typo in num_get

      Section: 22.2.2.1.2 [lib.facet.num.get.virtuals]  Status: WP  Submitter: Kevin Djang  Date: 17 May 2001

      Section 22.2.2.1.2 at p7 states that "A length specifier is added to @@ -10248,5 +10252,28 @@ Change the guarantee to "postcondition: r is dereferenceable."

      Rationale:

      Fixes an obvious typo

      +
      +

      400. redundant type cast in lib.allocator.members

      +Section: 20.4.1.1 [lib.allocator.members]  Status: WP  Submitter: Markus Mauhart  Date: 27 Feb 2003

      +

      +20.4.1.1 [lib.allocator.members] allocator members, contains +the following 3 lines: +

      + +
        12 Returns: new((void *) p) T( val)
      +     void destroy(pointer p);
      +  13 Returns: ((T*) p)->~T()
      +
      + +

      +The type cast "(T*) p" in the last line is redundant cause +we know that std::allocator<T>::pointer is a typedef for T*. +

      +

      Proposed resolution:

      +

      +Replace "((T*) p)" with "p". +

      +

      Rationale:

      +

      Just a typo, this is really editorial.

      ----- End of document -----

      \ No newline at end of file