Doc No: SC22/WG21/N2785 PL22.16/08-0295 Date: 2008-10-06 Project: JTC1.22.32 Reply to: Robert Klarer IBM Canada, Ltd. klarer@ca.ibm.com
Clamage called the meeting to order at 09:00 (UTC-8) on Monday, September 15, 2008
Crowl described the arrangements and facilities for the meeting.
Clamage had the attendees introduce themselves.
Clamage reviewed the patent disclosure rules.
Clamage presented the agenda (document PL22.16/08-0230 = WG21/N2720).
Motion to approve the agenda:
| Mover: Klarer | 
| Seconder: Stoughton | 
Approved by unanimous consent.
Each of the Working Group chairs presented their plans for the coming week.
Adamczyk reported that there are eleven papers in the queue of things to be discussed by CWG at this meeting. The CWG's most important task this week is to get concepts ready to be voted in, but the CWG's goal is to get all eleven papers in the queue reviewed and made the subject of formal motions.
Hinnant reported that there was an unofficial concepts meeting between meetings, and that the LWG may split into concepts and non-concepts groups for the duration of the week.
Boehm reported that the EWG "... will meet with [the LWG] for a little bit in order to get the ground rules straightened out [regarding the use of multithreading in the C++ Standard Library]."
Crowl recalled that there were things that were explicitly deferred at the last meeting to this meeting.
Gregor asked whether there is any feasible path for those things to get into the CD at this meeting and, if not, whether the group should devote resources to them.
Plauger requested that Crowl and Glassborow quickly prioritize the EWG's work, to see whether it was likely that these items would remain unresolved by the end of the week.
Motion to approve the minutes (document PL22.16/08-0191 = WG21/N2681)
Miller proposed the following friendly amendment: "Correct the document number of the paper title "Solving the SFINAE problem for expressions." It was identified as 2658, but it should be 2634.
Klarer proposed the following friendly amendment: "Correct the spelling of Hedquist's name under agenda item 1.7."
| Mover: Dawes | 
| Seconder: Plauger | 
Approved by unanimous consent as amended.
Stoughton reported that WG14 is in the beginning of a revision cycle of the C standard.
Plum reported that he took a number of C++ innovations and drafted them as C extensions, including:
Rao asked whether the C memory model will be consistent with the C++ memory model. Nelson explained that C is going to adopt the same granularity that C++ did, and Stoughton expanded on this, noting that compatibility with C++ was "a big driving factor to WG14's decisions."
Stoughton noted that a Liaison Statement can be located on the Wiki.
The most recent working paper is PL22.16/08-0233 = WG21/N2723. The Editor's Report is PL22.16/08-0234 = WG21/N2724.
Motion to accept the working paper
| Mover: Plauger | 
| Seconder: Stoughton | 
Approved by unanimous consent.
Hinnant indicated that N2723 has a change that Project Editor believes is editorial. Hinnant, however, believes that the change is not editorial, and he hesitates to accept N2723 because he is unsure of the procedure.
Plauger recommended approving the paper and treating the issue, if there is one, with high priority.
Becker explained that the editor's report contains information about those cases where he felt it was necessary to apply his individual discretion to the task of reflecting the committee's decisions to the existing text.
Becker also noted that the current draft is twice the length of the C++03 standard.
Meredith reported that BSI strongly object to the organization of this paper, since it requires changes to existing standard headers, and that makes it difficult for a third party to implement a library based on this specification.
Plauger indicated that this objection can be addressed as an NB comment
The most recent working paper is PL22.16/08-0227 = WG21/N2717.
Motion to advance N2717 to ISO for Ballot
| Mover: Plauger | 
| Seconder: Brown | 
Approved by unanimous consent.
The most recent working paper is PL22.16/08-0242 = WG21/N2732.
Motion to advance N2732 to ISO for Ballot
| Mover: Klarer | 
| Seconder: Dawes | 
Approved by unanimous consent.
Motion to close TR2
| Mover: Stoughton | 
| Seconder: Dawes | 
Approved by unanimous consent.
Motion to close Modules TR
| Mover: Vandevoorde | 
| Seconder: Gregor | 
Approved by unanimous consent.
We have three subgroups: Core, Library, and Evolution. There will be a subgroup of Evolution to deal with issues relating to concurrency.
The committee broke into subgroups at 10:30 (UTC-8).
Adamczyk gave the following report on the proposals that the Core Working Group intends to move on Saturday:
Motion 1: The usual motion about issues in Ready status in the latest Core Issues list, N2714. Question about conflict between 594 and N2762.
Motion 2: N2757 "Expedited core issues handling (revision 2)", i.e., resolutions for core issues numbered 220, 592, 606, 614, 624, 681, 683, 688. Some issues we would normally move to Ready for next time, but wanted to fast-track to get into the CD.
Note that no action is being taken on the deprecated conversion of strings to char *. We're pretty sure we don't want to take away that conversion, at least because of C compatibility issues, but we have yet to decide if we want the conversion to apply only to the string kinds that were in C++2003 or to all the new string kinds. In any case, the current situation (allowed for old and some, but not all, new strings) is unacceptable.
Motion 3: N2756 "Non-static data member initializers". Note that use of "auto" for non-static data members (N2713) is dead; there are indeed technical reasons why that's a bad idea. Also, the paper being adopted adds {}-form initializers for non-static data members but doesn't change non-static data member initializers, so {}-form initializers for those would have to come later from some other paper.
Motion 4: N2764 "Forward declaration of enumerations (rev. 3)". Allows forward declaration of an enum type. This is not incomplete forward declarations as many implementations have: The forward-declared enum has a known size/base type and you can declare objects of that type; you just don't have the enumerators.
Motion 5: N2762 "Not So Trivial Issues with Trivial". Continues the POD/trivial type cleanup.
Motion 6: N2752 "Proposed Text for Bidirectional Fences". Memory model issues. Includes library changes, blessed by the LWG.
Motion 7: N2765 "User-defined Literals (aka. Extensible Literals (revision 5)". The syntax for the name of the operator functions was changed at this meeting, to
operator "" xxxx()Note that the space between "" and the xxxx suffix name is required, for now. There's also some remaining desire for a way to make the operator functions once-only, so that literal value computation is not done more than once for, say, a user-defined literal in a loop. That's left as a possible future work item.Motion 8: N2761 "Towards support for attributes in C++ (Revision 6)". The paper is ready for a vote, if not quite at the level of refinement we usually like to see. There was a significant syntax change for the position of attributes on statements just this week. There are three builtin attributes: align, noreturn, and final. An additional builtin attribute, carries_dependency, is proposed in the motion following this one.
There's some controversy about this feature:
- Pro: It allows introduction of small features without adding a keyword. These features admittedly end up somewhat as second-class citizens, but they would probably not have a chance at all if they had to get a keyword. The alignas keyword can be dropped and replaced by an attribute.
- Pro: IBM and CodeGear have already implemented something close to this proposal.
- Pro: The C committee is looking at adding the same syntax.
- Pro: In theory, having a standard syntax for attributes should allow vendors to eliminate their old vendor-specific forms and use the standard form.
- Con: It's not going to happen. Microsoft's declspec and GNU's attribute forms will doubtless be around anyway.
- Con: The syntax, using [[...]], conflicts with the syntax used by Microsoft for their (very different) attributes. Microsoft has said they will probably not implement these standard attributes.
- Con: There's controversy about whether attributes should be allowed to affect semantics. CWG is pretty clear about the fact that they can. If you think you want to restrict attributes so they can't affect semantics, you should probably vote against this proposal, because it won't be possible to stop that.
- Con: The proposal allows attributes in all kinds of places, without really saying what that means. For example, it allows attributes to apply to types, but doesn't really say how that would affect the type system. We're saved on that only because no builtin attributes that apply to types are being proposed. Vendors who add such attributes would have to define what they mean in detail.
Also note that BSI wants attributes, but doesn't want them added later if they're not in the CD. So it's sort of now or never.
Motion 9: N2782 "C++ Data-Dependency Ordering: Function Annotation". The carries_dependency attribute.
Motion 10: N2773 "Proposed Wording for Concepts (Revision 9)". Continued progress on this, but there were still some significant changes in the proposal just this week. It would be nice to have more time, but it's a marquee feature which has to be in the CD, a lot of thought has gone into it, and it's been (mostly) implemented.
Motion 11: N2782 "Named Requirements for C++0X Concepts". Syntactic sugar to make concept requirements more compact.
Motion 12: N2778 "Wording for range-based for-loop (revision 3)". The range-based for loop, including library changes (waiting for confirmation) blessed by the LWG. Requires concepts.
Motion 13: N2763 "Unified Function Syntax". Whether "auto" or "[]" should be used in the late-specified return type syntax. Lots of controversy, which is mostly about aesthetic preference, but also about
- For auto: it's a placeholder for a type, just like other uses of auto.
- For []: It's an introducer for a callable object, just like lambdas, and selecting [] gives a path forward to adding other similar callable objects, in particular local functions. (It should be noted that there was widespread agreement on both sides of the issue that if local functions are added the "[]" syntax would be good for them.)
Hinnant reviewed the LWG formal motions (see below).
2-6 March 2009, Summit NJ:
This meeting will be sponsored by EDG, Dinkumware, and Plum Hall, though other potential sponsors are urged to volunteer funds.
13-18 July 2009, Frankfurt Germany.
19-24 October 2009, Santa Cruz, CA area:
Plauger noted that this meeting conflicts with OOPSLA, but that there is no viable alternative except to move the meeting to the last week of October, and to ask WG14 to convene during the week of October 19.
Two members reported concern about the scheduling conflict with OOPSLA, but in a subsequent show of hands, only six members favored moving the meeting to the last week of October, while eleven members opposed such a move.
Motion 1. Move we apply the resolutions of all issues marked "ready" from N2714 to the C++0X Working Paper, i.e. issues numbered 222, 594, 634, 637, 639, 647, 648, 649, 651, 659, 660, 671, 677, 679, 686.
Approved by unanimous consent.
Motion 2. Move WG21/N2757 "Expedited core issues handling (revision 2)" into the C++0X Working Paper, i.e. resolutions for core issues numbered 220, 592, 606, 614, 624, 681, 683, 688.
Approved by unanimous consent.
Motion 3. Move WG21/N2756 "Non-static data member initializers" into the C++0X Working Paper.
Nelson inquired as to whether this item had been implemented. Caves replied, explaining that it had not.
| favor | oppose | abstain | 
| many | 3 | 
Motion 4. Move WG21/N2764 "Forward declaration of enumerations (rev. 3)" into the C++0X Working Paper.
Approved by unanimous consent.
Motion 5. Move WG21/N2762 "Not So Trivial Issues with Trivial" into the C++0X Working Paper.
Approved by unanimous consent.
Motion 6. Move WG21/N2752 "Proposed Text for Bidirectional Fences" into the C++0X Working Paper.
Approved by unanimous consent.
Motion 7. Move WG21/N2765 User-defined Literals (aka. Extensible Literals (revision 5) into the C++0X Working Paper.
Merrill asked what happened to the suggestion to change the declaration syntax to use "operator for." Vandevoorde replied that there was no significant support for that idea.
Stoughton asked whether has this item been implemented. Adamczyk explained that it had not.
| favor | oppose | abstain | 
| many | 1 | 
Motion 8. Move WG21/N2761 "Towards support for attributes in C++ (Revision 6)" into the C++0X Working Paper.
Abrahams asked "how do we ensure that vendors use the same attribute names for the same functionality?"
Adamczyk explained that "there is a facility for qualifying attribute names, but apart from that, market pressures will encourage convergence."
Meredith asked whether he, as a vendor, is allowed to do things with an attribute that I am not allowed to with a pragma.
Adamczyk answered that the syntax for usage is more selective than for pragmas.
Vandevoorde stated that this feature creates an opportunity for future language evolution, as the standard committee can add portable attributes in the future.
Dawes asked whether he will be, for example, forced to use to conditional compilation in BOOST code.
Merrill observed that code that requires vendor-specific extensions will always require conditional compilation for portability, regardless of whether or not attributes are used.
Witt agreed, arguing that attributes are no worse than the status quo, since the situation with #pragmas is the same.
Stroustrup asked whether it is true that a program is ill-formed if it uses a pragma that is ignored by the compiler.
Adamczyk explained that the implementation is free to specify that it ignores attributes that it doesn't understand.
Spertus asked whether it is true that Microsoft refuses to implement this feature. Caves confirmed that it is.
Discussion ensued.
Glassborow noted that just about every major compiler already has attributes, and further opined "It's time we standardized the syntax for them."
| favor | oppose | abstain | 
| 29 | 7 | 
Motion 9.
Move WG21/N2782 "C++ Data-Dependency Ordering: Function Annotation" into the C++0X Working Paper.Approved by unanimous consent.
Motion 10.
Move WG21/N2773 "Proposed Wording for Concepts (Revision 9)" into the C++0X Working Paper.| favor | oppose | abstain | 
| many | 1 | 
Motion 11. Move WG21/N2780 "Named Requirements for C++0X Concepts" into the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 12. Move WG21/N2778 "Wording for range-based for-loop (revision 3)" into the C++0X Working Paper.
Nelson asked whether this proposal has been implemented. Gregor confirmed that it had.
Abrahams asked, for his information, why Vandevoorde was consistently voting against Concepts-related motions.
Vandevoorde explained that he does not have enough confidence in the quality of the core Concepts specification, and the risk of getting it wrong is too great.
| favor | oppose | abstain | 
| many | 3 | 
Motion 13. Move WG21/N2763 "Unified Function Syntax" into the C++0X Working Paper.
Adamczyk recalled that, when lambda was voted into the WP, it was with the understanding that it would not prejudice the committee toward "auto" instead of "[]" Further, Adamczyk reported that this proposal does not completely resolve all of the grammar changes required to enable []. The [] is a placeholder for a type, rather than an introducer. The grammar can later be modified to allow [] to act as an introducer.
Discussion ensued.
Glassborow reported that, assuming this motion is approved, the UK will be issuing an NB comment that they want [] to be an introducer rather than a placeholder for a type.
Discussion ensued.
Stroustrup reported that France will support the UK position on the use of brackets.
Caves suggested that the committee trying to create unity by using a notation that is different from what almost all programmers use today; that is confusing and unnecessary
Marcus expressed a preference that, when things are similar but not exactly the same, they should not look the same, to emphasize the distinction.
Merrill noted that this is a very large change in how people write C++, and that large projects will transition to any new notation gradually, so both forms will be evident in a single source tree.
Vandevoorde argued that the keyword "auto" is counter-intuitive, as there is nothing in the word auto that implies "placeholder."
Merrill agreed, but explained that auto looks like a specifier.
Spicer asked whether the bracket syntax introduces an ambiguity.
Adamczyk speculated that an ambiguity may arise once the grammar is modified to make the square brackets an introducer, just as implicit int created ambiguities.
Crowl expanded on this, noting that the ambiguity doesn't arise when the function has a late-specified return type.
Gibbons predicted that programmers will be tempted to define a macro like #define Function(name) []name.
Crowl observed that the difference in semantics that have been highlighted are not so much differences as restrictions. For example, there are no default parameters for lambdas because it makes no sense to allow defaults for parameters that you can't be named anyway. "It's not so much that functions and lambdas are inconsistent, but that different constraints apply."
| favor | oppose | abstain | 
| 14 | 16 | 11 | 
Plauger, noting that there appears to be no consensus, asked whether there is some state that in which the committee can leave the draft in that will appease all sides of the debate.
Spicer suggested that "perhaps we could agree that this is something that we can continue to work on."
Plauger agreed that "this is unequivocally an open issue and the failure to reach consensus today should not prejudice the committee against any [future] proposal" that aims to solve the problem.
Motion 1. Move we apply the resolutions to the following issues from N2727 to the C++0X Working Paper: 180, 387, 396, 522, 629, 691, 713, 714, 720, 728, 762, 769, 771, 772, 776, 779, 787, 805, 806, 807, 808, 809, 813, 824, 829, 842, 844, 848, 850, 852
Vandevoorde asked whether any of the issues in this list deal with Concepts. Hinnant: "No."
Approved by unanimous consent.
Motion 2. Move we apply the resolutions to the following issues to the C++0X Working Paper: 23, 675, 692, 698, 709, 734, 804, 820, 823 (requires foundational concepts), 843, 856 These issues were not in Ready status in the pre-meeting mailing. However the LWG reviewed them and believes they should be go into the WP at this meeting because they are critical to the quality of the CD.
| favor | oppose | abstain | 
| many | 1 | 
Motion 3. Move we apply N2771 LWG Issues" to the C++0x working paper. 858, 882
Approved by unanimous consent.
Motion 4. Move we apply N2783 "Collected Issues with Atomics" to the C++0x working paper. 818, 845, 846, 864
Approved by unanimous consent.
Motion 5. Move we apply N2637 "Revisiting std::shared_ptr comparison" to the C++0X Working Paper.
Meredith recalled that this was controversial at the previous meeting, but that he has withdrawn his objections.
| favor | oppose | abstain | 
| many | 1 | 
Motion 6. Move we apply N2755 "Concepts for the C++0x Standard Library: Chapter 17 -Introduction (Revision 2)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 7. Move we apply N2774 "Foundational Concepts (Revision 5)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 8. Move we apply N2777 "Concepts for the C++0x Standard Library: Iterators (Revision 4)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 9. Move we apply N2758 "Iterator Concepts for the C++0x Standard Library (Revision 6)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 10. Move we apply N2759 "Concepts for the C++0x Standard Library: Algorithms (Revision 6)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 11. Move we apply N2768 "Allocator Concepts, part 1 (revision 2)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 2 | 
Motion 12. Move we apply N2770 "Concepts for the C++0x Standard Library: Utilities (Revision 6)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 13. Move we apply N2620 "Concepts for the C++0x Standard Library: Diagnostics Library" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 14. Move we apply N2776 "Concepts for the C++0x Standard Library: Containers (Revision 4)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 15. Move we apply only the changes for section 26.6 in the paper N2736 "Concepts for the C++0x Standard Library: Numerics (Revision 4)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 16. Move we apply N2779 "Concepts for clause 18 (Part 2)" to the C++0X Working Paper.
Austern: If the LWG takes the position that double is not EqualityComparable, that has implications beyond numeric_limits.| favor | oppose | abstain | 
| 23 | 4 | 7 | 
Motion 17. Move we apply N2668 "Concurrency Modifications to Basic String" to the C++0X Working Paper.
Approved by unanimous consent.
Motion 18. Move we apply N2748 "Strong Compare and Exchange" to the C++0X Working Paper.
Approved by unanimous consent.
Motion 19. Move we apply N2760 "Input/Output Library Thread Safety" to the C++0X Working Paper.
Dawes explained that this paper was not in the pre-meeting mailing, but the LWG felt this was non-controversial and that it is required for the completeness of the CD.
Halpern asked whether this proposal has been implemented. Plauger explained that this proposal seeks to codify existing practice, so it has been implemented broadly.
Approved by unanimous consent.
Motion 20. Move we apply N2769 "Detailed Reporting for Input/Output Library Errors (Revision 2)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 21. Move we apply N2772 "Variadic Functions: Variadic Templates or Initializer Lists? (revision 1)" to the C++0X Working Paper.
Approved by unanimous consent.
Motion 22. Move we apply N2775 "Small library thread-safety revisions" to the C++0X Working Paper.
Approved by unanimous consent.
Motion 23. Move we apply N2671 "An Asynchronous Future Value" with the name for the error category changed from "FUTURE" to "future" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 1 | 
Motion 24. Move we apply N2709 "Packaging Tasks for Asynchronous Execution" with the addition that it goes into the same section and header file as futures to the C++0X Working Paper.
| favor | oppose | abstain | 
| 21 | 3 | 17 | 
Motion 25. Move we apply N2786 "Simplifying unique_copy (Revision 1)" to the C++0X Working Paper.
| favor | oppose | abstain | 
| many | 1 | 
Motion 26. Move we apply N2530 "Making It Easier to Use std::type_info as an Index" to the C++0x working paper.
Meredith expressed his belief that a concepts constraints library there will enable better techniques for achieving the same end.
Approved by unanimous consent.
Motion to move the Working Draft to Committee Draft Status
Move we empower the Convenor to advance the Working Paper as amended by the foregoing motions to Committee Draft Status.
| Mover: Klarer | 
| Seconder: Dawes | 
| favor | oppose | abstain | 
| 40 | 1 | 
A review committee was appointed to assist the Project Editor. This committee consists of:
Clamage reviewed all of the motions that were the subject of straw polls under Agenda Item 7, with the exception of CWG Motion 13, on Unified Function Syntax.
No objection was raised against any of the motions.
See 11.1, below.
None.
Adamczyk requested that members inform him about their plans to attend the Summit NJ meeting.
Maurer reported that the POSIX C++ bindings group will be meeting on the Friday before the WG21 meeting in Frankfurt.
Maurer also reported that there will be tours on the Saturday and Sunday preceding the WG21 meeting, and requested that members inform him about their plans to participate.
Nelson reported the following mailing deadlines:
| post-meeting mailing | Oct 3, 2008 | 
| mid-term mailing | December 5, 2008 | 
| pre-Summit mailing | February 26, 2009 | 
The following meetings are as follows:
Plum moved to thank the host. Applause.
Brown moved to thank the outgoing convenor. Applause.
There was general agreement that new versions of the core and library issues lists would not appear in the mid-meeting mailing.
Motion to adjourn
| Mover: Dawes | 
| Seconder: Nelson | 
Unanimous consent.
| Company/Organization | Representative | Mon | Tue | Wed | Thu | Fri | Sat | |
|---|---|---|---|---|---|---|---|---|
| Adobe Systems | Mat Marcus | V | V | V | V | V | V | |
| Apple Computer | Howard E. Hinnant | V | V | V | V | V | V | |
| Bloomberg | John Lakos | V | V | V | V | V | ||
| BoostPro Computing | David Abrahams | V | V | V | V | V | V | |
| Cilk Arts | Pablo Halpern | A | A | A | A | A | A | |
| CodeGear | Dawn Perchik | V | V | V | V | V | V | |
| CodeGear | Lee Cantey | A | ||||||
| CodeGear | Dan Dean | A | ||||||
| CodeGear | James Dennett | A | A | A | A | A | ||
| CodeGear | Vera Lychagina | A | A | |||||
| CodeGear | Alisdair Meredith | A | A | A | A | A | A | |
| Dawes | Beman G. Dawes | V | V | V | V | V | V | |
| Dawes | Bill Seymour | A | A | A | A | A | ||
| Dinkumware | P. J. Plauger | V | V | V | V | V | ||
| Dinkumware | Tana Plauger | A | A | A | A | A | ||
| Dinkumware | Christopher Walker | A | A | A | A | A | ||
| Edison Design Group | J. Stephen Adamczyk | V | V | V | V | V | V | |
| Edison Design Group | Daveed Vandevoorde | A | A | A | A | A | A | |
| Edison Design Group | John H. Spicer | A | A | A | A | A | A | |
| Edison Design Group | Mike Herrick | A | A | A | A | A | A | |
| Edison Design Group | William M. Miller | A | A | A | A | A | A | |
| Edison Design Group | Jens Maurer | A | A | A | A | A | A | |
| Fermi Nat. Accelerator Lab | Walter E. Brown | V | V | V | V | V | V | |
| Gimpel Software | James Widman | V | V | V | V | V | V | |
| Matt Austern | V | V | V | V | V | |||
| Lawrence Crowl | A | A | A | A | A | V | ||
| Bill Gibbons | A | A | A | A | A | |||
| James Dennett | A | A | A | A | A | |||
| Hewlett-Packard | PremAnand Rao | V | V | V | V | V | V | |
| Hewlett-Packard | Hans Boehm | A | A | A | A | A | A | |
| IBM | Robert Klarer | V | V | V | V | V | V | |
| IBM | Michael Wong | A | A | A | A | A | A | |
| IBM | Paul McKenney | A | A | A | ||||
| Indiana University | Doug Gregor | V | V | V | V | V | V | |
| Intel | Clark Nelson | V | V | V | V | V | V | |
| Microsoft | Jonathan Caves | V | V | V | V | V | V | |
| Oracle | Paolo Carlini | V | V | V | ||||
| Perennial | Barry Hedquist | V | V | V | V | V | ||
| Plum Hall | Thomas Plum | V | V | V | V | |||
| Plum Hall | Francis W. Glassborow | A | A | A | A | A | A | |
| Red Hat | Jason Merrill | V | V | V | V | V | V | |
| Red Hat | Benjamin Kosnik | A | A | A | A | A | A | |
| Rogue Wave Software | Martin Sebor | V | V | V | V | |||
| Roundhouse Consulting | Pete Becker | V | V | V | V | V | V | |
| Sun Microsystems | Stephen D. Clamage | V | V | V | V | V | V | |
| Symantec | Mike Spertus | V | ||||||
| Tele Atlas | Alan Talbot | V | V | V | V | V | V | |
| Texas A&M | Bjarne Stroustrup | V | V | V | ||||
| USENIX | Nick Stoughton | V | V | V | V | |||
| Zephyr Associates | Thomas Witt | V | V | V | V | V | V | |
| Amazon.com | Gary Powell | N | N | N | N | N | ||
| University Carlos III/AFNOR | J. Daniel Garcia | N | N | N | N | N | N | |
| Vollmann Engineering | Detlef Vollmann | N | N | N | N | N | N |