Re: Standard Versus Non-Standard C++
On Tuesday, July 3, 2012 5:06:54 PM UTC-5, Dave Harris wrote:
Your original post was about C++/CX, which is different to C++/CLI.
Some of the differences are due to lessons learnt from mistakes made
in C++/CLI, so it's not fair to tar them both with the same brush.
Well, actually, I guess this is a nit, but I wrote in my original post
was:
<quote>
I asked the question because I believe that Microsoft is being
somewhat untruthful when they persist in calling C++/CX or C++/CLI or
C++/whatever "C++".
</quote>
So I was referring to both C++/CLI and C++/CX, as all versions from
Microsoft that extend C++ have new keywords, etc. I lump them together
because they all share the same issue (from my point of view).
"C++/CLI changes the meaning of currently valid C++ syntax"
See the second page of:
http://www2.research.att.com/~bs/uk-objections.pdf
For what it's worth, I disagree with that section. Their example
code is not conforming C++ because it uses "interface" or "ref
class" rather than "class". Their later point about constructor and
destructor semantics, on the other hand, is valid. It is also an
example of a mistake that C++/CX avoids.
Ahhh...then we are in agreement. To see this, allow me to restate what
you just wrote:
<quote>
Their example code is not conforming C++ because it uses "interface"
or "ref class rather than "class"
</quote>
Their example code is "not conforming". That is all I am saying. And
because it is not conforming, Microsoft should not portray it as such.
Allow me to reiterate that:
1. I do not take issue with calling their language C++/CLI or C++/CX.
2. I do not take issue with programmers learning C++/CX as their first
language (or 10th language).
3. I do not take issue with infusing normally portable code with
C++/CLI or C++/CX constructs.
The only thing I take issue with is writing code that is clearly
non-standard, and not just in a tweak sense (think #pragma's), but
fundamentally different, where traditional C++ keywords take on new,
incompatible meaning, and calling it "C++" without qualification.
If Microsoft makes the mistake of omitting the /CLI or /CX qualifier
when presenting C++/CLI or C++/CX code, that would be one thing, but
the evidence on the Internet indicates, at least to me, that there is
a a deliberate campaign of misrepresentation. This would be the
logical next step, since ISO rejected their standardization effort,
saying that they should at least give the language a new name first.
-Le Chaud Lapin-
--
[ See http://www.gotw.ca/resources/clcm.htm for info about ]
[ comp.lang.c++.moderated. First time posters: Do this! ]