IWETHEY v. 0.3.0 | TODO
1,095 registered users | 1 active user | 0 LpH | Statistics
Login | Create New User
IWETHEY Banner

Welcome to IWETHEY!

New I *heart* C++
OK, now that I've gotten your attention... ;-)

I HATE THIS FSCKING LANGUAGE.

Here's the deal: I'm porting 1.5M LOC from 2.95.4.patched-with-STL on Solaris to 3.2.1 on Linux. Fortunately for my sanity not all of that code is C++.

The current issue: 3.2.1 is MUCH pickier about certain things. I'm not a C++ programmer either, so this kind of shit confuses the hell out of me when I try to Make It Work.

Code from OtherClass:
\n\tbool Address(const char *address);\n\n\tinline std::string Address(bool bUseDot = true) const {\n


Now the call (in SomeClass):
\n\tm_server_address = m_addr.Address(false);\n

Where m_server_address is a std::string and m_addr is an OtherClass.

Now the error:
\nSomeClass.cpp: In member function `void \n   SomeClass::SomeMethod()':\nSomeClass.cpp:187: choosing `std::string OtherClass::Address(bool) const' \n   over `bool OtherClass::Address(const char*)'\nSomeClass.cpp:187:   because worst conversion for the former is better than \n   worst conversion for the latter\n


My achin' head. It can't tell the diff between a bool and a char*?

Wrapping a 'bool' typecast around the parameter in the call machts nicht as well.

Any help? I'll owe you a beer...
Regards,

-scott anderson

"Welcome to Rivendell, Mr. Anderson..."
New GNU compilers both sides?
Each compiler has its quirks, in the world of C and C++. This sort of crap comes with the territory. At least GNU compilers are free.

So what's your bool.h look like?

Oh, and GNU compiler optimizations are not to be trusted on many target platforms. Just write tight code instead. Except... you gotta have -O3 (? something like that) or your inline functions won't be inlined at all.


I am a Vast Right Wing Conspiracy of one.
Where's Abdul Rahman Yasin?
The reason I don't budge is I'm waiting for you to catch up.
[link|http://www.angelfire.com/ca3/marlowe/index.html|http://www.angelfire...arlowe/index.html]
[link|http://pascal.rockford.com:8888/SSK@jbf~W~x49RjZfyJwplqwurpNmg0PAgM/marlowe//|http://pascal.rockfo...mg0PAgM/marlowe//]
New What is the type of m_server_address?
And, by the way, this looks more like warning to me. Do you treat warning as errors?
--

We have only 2 things to worry about: That
things will never get back to normal, and that they already have.
Expand Edited by Arkadiy Jan. 17, 2003, 02:55:27 PM EST
New As noted:
Where m_server_address is a std::string


No, we don't treat warnings as errors.
Regards,

-scott anderson

"Welcome to Rivendell, Mr. Anderson..."
New Re: As noted:
Did you include a using statemet?

using namespace std;

at the top. Looks like a warning about a default choice of namespace to me.
-drl
New It isn't.
It's an error in the function declarations and an overly picky C++ compiler.

Not that gcc 3.2.1 doesn't have bugs in its namespace resolution as well... :-P
Regards,

-scott anderson

"Welcome to Rivendell, Mr. Anderson..."
New Fix:
Declare in addition:
\n \tinline std::string Address(bool bUseDot = true)\n


Notice the missing const.

*sigh*

I've found other issues with 3.2.1 as well, however.

1) The Amazing Disappearing 'isfinite' #define Macro
2) segfaults if you don't initialize std:strings with ""

and so on.

So here's what I'm doing:

'apt-get install libstlport4.5'

;-)
Regards,

-scott anderson

"Welcome to Rivendell, Mr. Anderson..."
New const is a design error
It often leads to amazingly unpredictable behavior or impossible to port code as compilers balk at compiling stuff that isn't exactly entirely const correct.

One possible solution

#define const

Voila is french for "there ya go".
Expand Edited by tuberculosis Aug. 21, 2007, 06:17:22 AM EDT
New One of my directives for this port:
#define DO_NOT_FIX_OLD_CODE_FOR_THE_SAKE_OF_THE_PORT

etc. ;-)
Regards,

-scott anderson

"Welcome to Rivendell, Mr. Anderson..."
New Re: One of my directives for this port:
I read Stroustrup's explanation of "const" in three different editions of his book, and still didn't really understand it.
-drl
New The "const" attribute means that, within the given scope,...
the object may not be modified, i.e. for practical purposes is read-only (or constant).
Alex

"No man's life, liberty, or property are safe while the legislature is in session."\t-- Mark Twain
New Because it's not supposed to be modified...
...i'd suspect that it's also not kosher to dereference a Const pointer. If a dereference is allowed then the program can backdoor a method to change the value by casting it to another type and then doing an assign.

Perhaps that's the point of the error message that Scott received?
New Yes, I remember all that..
..but why bother? I know what I'm doing when I call a C function - it's pedantic and *against C spirit* to obess on such things.

In the end, you could take BS's approach and make FORTRAN+1 or ADD1TOCOBOL and it would end up violating those languages. He'd have some stupid obession about COMMON blocks in FORTRAN, maybe.

The funny thing is, the early parts of C++ really are improvements to (ANSI) C. It's the bizarre attempts to cover up a fundamentally procedural idiom that gets him into deep shit.
-drl
New Re: why bother?
Because you don't "own" and may not know the innards of the function you use and the const is part of a compiler enforced interface spec that leads to more predictable code behavior.

When all the code is yours, it does not matter so much. Unless, like me, you may forget what you've done in a couple of weeks.
Alex

"No man's life, liberty, or property are safe while the legislature is in session."\t-- Mark Twain
New Well, yes, that was what BS was obsessing on
..but why not just make an API with use instructions? If you use it wrong, you will get burned.

CAUTION: Don't use the space heater in a room filled with natural gas.

CAUTION: Remain clear of the blast zone.

CAUTION: Failure to deploy flaps in a timely manner will result in a stall and a fiery metallic death on landing.

CAUTION: Consuming ten times the recommended dosage of this medicine may produce symptoms such as breathlessness, little or no heartbeat, and lack of motivation.


You can't prevent people from being stupid. You have to give them the freedom to be smart.
-drl
New Clearly BS hates programmers and doesn't trust them
as far as he can throw them. Why else would he work so hard to wrap everything in a straight jacket? Java is kind of that way too but more moderate.

The only thing C++ ought to be used for is purposes for which it was designed. If you're not writing a telephone switching operating system, you don't need it.



I think that it's extraordinarily important that we in computer science keep fun in computing. When it started out, it was an awful lot of fun. Of course, the paying customer got shafted every now and then, and after a while we began to take their complaints seriously. We began to feel as if we really were responsible for the successful, error-free perfect use of these machines. I don't think we are. I think we're responsible for stretching them, setting them off in new directions, and keeping fun in the house. I hope the field of computer science never loses its sense of fun. Above all, I hope we don't become missionaries. Don't feel as if you're Bible salesmen. The world has too many of those already. What you know about computing other people will learn. Don't feel as if the key to successful computing is only in your hands. What's in your hands, I think and hope, is intelligence: the ability to see the machine as more than when you were first led up to it, that you can make it more.

--Alan Perlis
Expand Edited by tuberculosis Aug. 21, 2007, 06:25:33 AM EDT
New Re: Because it's not supposed to be modified...
ChrisR: i'd suspect that it's also not kosher to dereference a Const pointer.

Huh? A pointer you can't dereference isn't much of a pointer, is it.

There's no problem dereferencing a constant pointer. In fact, arrays in C are (in a certain sense) nothing more than a constant pointer.

ChrisR: If a dereference is allowed then the program can backdoor a method to change the value by casting it to another type and then doing an assign.

Isn't that the whole point of casting in C? :-)
--
-- Jim Weirich jweirich@one.net [link|http://w3.one.net/~jweirich|http://w3.one.net/~jweirich]
---------------------------------------------------------------------
"Beware of bugs in the above code; I have only proved it correct,
not tried it." -- Donald Knuth (in a memo to Peter van Emde Boas)
New Re: const is a design error
> One possible solution
> #define const

Ummm ... That could make some function signatures (that differ only in const) ambiguous.
--
-- Jim Weirich jweirich@one.net [link|http://w3.one.net/~jweirich|http://w3.one.net/~jweirich]
---------------------------------------------------------------------
"Beware of bugs in the above code; I have only proved it correct,
not tried it." -- Donald Knuth (in a memo to Peter van Emde Boas)
New Only if such differences exist
more often, programmers throw const around here and there without really understanding what its doing. As des said - its not well understood and generally misused.

You may find that definining it away results in less errors than leaving it.

Its a porting trick - sometimes it helps - sometimes not.
I think that it's extraordinarily important that we in computer science keep fun in computing. When it started out, it was an awful lot of fun. Of course, the paying customer got shafted every now and then, and after a while we began to take their complaints seriously. We began to feel as if we really were responsible for the successful, error-free perfect use of these machines. I don't think we are. I think we're responsible for stretching them, setting them off in new directions, and keeping fun in the house. I hope the field of computer science never loses its sense of fun. Above all, I hope we don't become missionaries. Don't feel as if you're Bible salesmen. The world has too many of those already. What you know about computing other people will learn. Don't feel as if the key to successful computing is only in your hands. What's in your hands, I think and hope, is intelligence: the ability to see the machine as more than when you were first led up to it, that you can make it more.

--Alan Perlis
Expand Edited by tuberculosis Aug. 21, 2007, 06:17:37 AM EDT
New Fun in computing.
I know about that. Many of my favourite moments in my current job are "having fun" with the thing. For instance, I wrote a fortunes module (our product is a groupware product run over an intranet with a web browser). It was nearly as much fun writing it as putting good fortunes in there!

A more productive moment was aggregating a whole heap of functions for drawing HTML form controls into one function. Suddenly they all had the whole range of options and parameter processing that was duplicated incompletety amongst the older functions. That was fun. And doing some very fancy manipulation of school marks for reporting that required PHP arrays of 5 and 6 dimensions. I've had a client ask to see how that works... :-)

Wade.

Is it enough to love
Is it enough to breathe
Somebody rip my heart out
And leave me here to bleed
 
Is it enough to die
Somebody save my life
I'd rather be Anything but Ordinary
Please

-- "Anything but Ordinary" by Avril Lavigne.

New Re: Only if such differences exist
Todd: more often, programmers throw const around here and there without really understanding what its doing. As des said - its not well understood and generally misused.

Really. I've not run into much problems with const, which is, after all, an ANSI C construct and is well entrenched in the ANSI C libraries. I'd be surprised if most C programmers had trouble, otherwise they would constantly run afoul of the standard library.

The problem in C++ is its interaction with overloading, which can be subtl. In fact, the problem Todd is having is more with overloading than with const.

BTW ... I like the Alan Perlis quote. Programming should be fun.
--
-- Jim Weirich jweirich@one.net [link|http://w3.one.net/~jweirich|http://w3.one.net/~jweirich]
---------------------------------------------------------------------
"Beware of bugs in the above code; I have only proved it correct,
not tried it." -- Donald Knuth (in a memo to Peter van Emde Boas)
New const functions
are the problem. And as you point out - overloading on const (which is pretty lame).

The biggest problem is mixing cost references (I hate references - they suck - use pointers) with objects that aren't exactly const correct (nearly all of them).

People forget to declare methods const - even if they are, and suddenly you're casting away const to get around it. Especially in foreign libraries you don't control the source to.

If C++ were a powertool, OSHA would have made Stroustrup take it off the market.



I think that it's extraordinarily important that we in computer science keep fun in computing. When it started out, it was an awful lot of fun. Of course, the paying customer got shafted every now and then, and after a while we began to take their complaints seriously. We began to feel as if we really were responsible for the successful, error-free perfect use of these machines. I don't think we are. I think we're responsible for stretching them, setting them off in new directions, and keeping fun in the house. I hope the field of computer science never loses its sense of fun. Above all, I hope we don't become missionaries. Don't feel as if you're Bible salesmen. The world has too many of those already. What you know about computing other people will learn. Don't feel as if the key to successful computing is only in your hands. What's in your hands, I think and hope, is intelligence: the ability to see the machine as more than when you were first led up to it, that you can make it more.

--Alan Perlis
Expand Edited by tuberculosis Aug. 21, 2007, 06:28:10 AM EDT
New Well, it doesnt' appear to be overloaded on const
in fact I'm not sure you can overload on const (I think I tried to at one point).

One function was taking a bool in the sig (defaulted to true) and the other a char *.

I think (but am not sure) that the problem was that the function itself was const (on one sig) and in the other it wasn't, but I'd have to prototype to verify.


BTW: I do agree with your other statements however. Beware programmers that overly use const, as it becomes a REAL pain to get around them later.
New Re: Well, it doesnt' appear to be overloaded on const
Beware programmers that overly use const, as it becomes a REAL pain to get around them later.

There are two ways to work with const ...

1) Never use const ...

2) Always use const where appropriate ...

In both cases you run into problems with libraries that did it the other way. I tend to fall into category 2.
--
-- Jim Weirich jweirich@one.net [link|http://w3.one.net/~jweirich|http://w3.one.net/~jweirich]
---------------------------------------------------------------------
"Beware of bugs in the above code; I have only proved it correct,
not tried it." -- Donald Knuth (in a memo to Peter van Emde Boas)
New No, thats exactly the problem
It works like this:

class List
{
public:

void addItem(int i) { /* do add */ }
void addItem(int i) const { throw new ConstListException(); }
}

List* list = new List();
const List* clist = list;

list.addItem(i); // fine - adds an item
clist.addItem(i); // throws an exception because const version is invoked

IOW, if you define a member function and you don't make it const, then you can't call it using a const ref to the object.

If you define a member function and make it const, you can call it with both a const and non-const ref to the object.

If you define both a non-const and const version of the same function, the const version is called when you have a const ref to the object and the non-const version is called with non-const refs.

As developers aren't particularly good judges on what is const and what isn't const, this "feature" has turned out to be a PITA.

------

There is a different approach that was employed in ObjectiveC.

The collection classes (which is usually the issue anyhow - do you return a new copy or a reference to private data?) are defined at two levels.

NSArray, NSDictionary, and NSSet have read-only semantics. No mutators are defined in these classes. So they are effective immutable. NSMutableArray is a subclass of NSArray and adds mutator methods (those that you wouldn't declare const). Same with NSDictionary and NSSet, mutable subclasses exist.

Suppose I have a class Artist with an array of Paintings.

@interface Artist
{
NSMutableArray* _paintings;
}

-(void)addPainting:(Painting*)p { [_paintings addObject: p]; }
-(void)removePainting:(Painting*)p { [_paintings removeObject: p; }
-(NSArray*)paintings { return _paintings; }
@end

Notice that when asked for the list of paintings, I say I return the superclass type NSArray. Its private data, but if you try to send it a mutator method, the compiler will warn you that this is not cool (but it'll still do it).

Thus, I get out of copying the collection and still keep it from being modified. (They could downcast - but downcasting is evil and thus they deserve what they get for that).

Simple two level design idea. C++'s const mechanism tries to do the same thing, but its more confusing to use and I think it fails because its confusing.





I think that it's extraordinarily important that we in computer science keep fun in computing. When it started out, it was an awful lot of fun. Of course, the paying customer got shafted every now and then, and after a while we began to take their complaints seriously. We began to feel as if we really were responsible for the successful, error-free perfect use of these machines. I don't think we are. I think we're responsible for stretching them, setting them off in new directions, and keeping fun in the house. I hope the field of computer science never loses its sense of fun. Above all, I hope we don't become missionaries. Don't feel as if you're Bible salesmen. The world has too many of those already. What you know about computing other people will learn. Don't feel as if the key to successful computing is only in your hands. What's in your hands, I think and hope, is intelligence: the ability to see the machine as more than when you were first led up to it, that you can make it more.

--Alan Perlis
Expand Edited by tuberculosis Aug. 21, 2007, 06:37:06 AM EDT
New This is what bugs me in Scott's problem...
>>>>>>>>>>>>>
If you define a member function and make it const, you can call it with both a const and non-const ref to the object.
<<<<<<<<<<<<

He has a const member function. There is really no conversion involved in calling const function on non-const reference. What the hell does compiler want from the poor guy?

One more thing. In this code:

\nclass OtherClass\n{\npublic:\n\n\tbool Address(const char *address);\n\n\tinline std::string Address(bool bUseDot = true) const ;\n};\n\n\nvoid tryThis()\n{\n    OtherClass m_addr;\n\tstd::string m_server_address = m_addr.Address(false/*replace here*/);\n}\n\n

If I replace "false" in tryThis() with "true", it compiles fine. Could GCC be trying to interpret "false" as NULL? Dumb, I know.

--

We have only 2 things to worry about: That
things will never get back to normal, and that they already have.
New I was pissed enough at the problem
I hacked gcc code to report on what conversions take place.

Here is the code I used for testing:

\nclass OtherClass\n{\npublic:\n\n    bool Address(const char *address);\n\n    inline const char *Address(bool bUseDot = true) const ;\n};\n\n\nvoid tryThis()\n{\n    OtherClass m_addr;\n    const char *m_server_address = m_addr.Address(false);\n}\n


Works just as badly as the original.

Here is the debug output:

\ng++ -c test.cpp\ntest.cpp: In function `void tryThis()':\ntest.cpp:25: warning: from "OtherClass*" "&m_addr"to "const OtherClass*" using\ntest.cpp:25: warning:  qual_conv\ntest.cpp:25: warning:  identity_conv\ntest.cpp:25: warning:  &m_addr\n\ntest.cpp:25: warning: from "bool" "false"to "bool" using\ntest.cpp:25: warning:  identity_conv\ntest.cpp:25: warning:  false\n\ntest.cpp:25: warning: from "OtherClass*" "&m_addr"to "OtherClass*" using\ntest.cpp:25: warning:  identity_conv\ntest.cpp:25: warning:  &m_addr\n\ntest.cpp:25: warning: from "bool" "false"to "const char*" using\ntest.cpp:25: warning:  std_conv\ntest.cpp:25: warning:  identity_conv\ntest.cpp:25: warning:  false\n\ntest.cpp:25: choosing `const char* OtherClass::Address(bool) const' over `bool\n   OtherClass::Address(const char*)'\ntest.cpp:25:   because worst conversion for the former is better than worst\n   conversion for the latter\n\nCompilation exited abnormally with code 1 at Tue Jan 21 21:31:05\n


So, it takes 2 conversions to go from false to (const char *)

Here are relevant paragraphs from [link|http://www.comnets.rwth-aachen.de/doc/c++std/conv.html|C++ standard:]

>>>>>>>>>>>>>>>>>>>>>>>
1 Standard conversions are implicit conversions defined for built-in
types. The full set of such conversions is enumerated in this clause.
A standard conversion sequence is a sequence of standard conversions
in the following order:

--Zero or one conversion from the following set: lvalue-to-rvalue con-
version, array-to-pointer conversion, and function-to-pointer con-
version.

--Zero or one conversion from the following set: integral promotions,
floating point promotion, integral conversions, floating point con-
versions, floating-integral conversions, pointer conversions,
pointer to member conversions, and boolean conversions.

--Zero or one qualification conversion.

[Note: a standard conversion sequence can be empty, i.e., it can con-
sist of no conversions. ] A standard conversion sequence will be
applied to an expression if necessary to convert it to a required des-
tination type.

........


4 An rvalue of type bool can be converted to an rvalue of type int, with
false becoming zero and true becoming one.

.........

1 An integral constant expression (_expr.const_) rvalue of integer type
that evaluates to zero (called a null pointer constant) can be con-
verted to a pointer type. The result is a value (called the null
pointer value of that type) distinguishable from every pointer to an
object or function. Two null pointer values of the same type shall
compare equal. The conversion of a null pointer constant to a pointer
to cv-qualified type is a single conversion, and not the sequence of a
pointer conversion followed by a qualification conversion
(_conv.qual_).

<<<<<<<<<<<<<<<<<<<

So, GCC is right. And I have to concede: C++ is a sick language.

However, the correct conversion should still be picked by comparing length of path for 2 possibilities. The text that Scott saw on screen was a "pedantic warning" - something less than a regular warning. It should never fail the compilation. I'll try to find out why the exit code is 1 after that "pedwarn".


--

We have only 2 things to worry about: That
things will never get back to normal, and that they already have.
New I was pissed enough that I:
Switched to 2.95.4 with stlport, which works "wonderfully" (read: sufficiently crummy version of wonderful as defined by the C++ spec) as compared to 3.2.1.
Regards,

-scott anderson

"Welcome to Rivendell, Mr. Anderson..."
New Solution
`-fpermissive'
Downgrade messages about nonconformant code from errors to
warnings. By default, G++ effectively sets `-pedantic-errors'
without `-pedantic'; this option reverses that. This behavior and
this option are superseded by `-pedantic', which works as it does
for GNU C.


I think GCC is no less fucked than C++ standard. But at least you can make it swallow the code.
--

We have only 2 things to worry about: That
things will never get back to normal, and that they already have.
New ROFL
But at least you can make it swallow the code.


gcc: the compiler that swallows, not spits.
Regards,

-scott anderson

"Welcome to Rivendell, Mr. Anderson..."
New Re: "..you can make it swallow the code." Beautiful!
Alex

"No man's life, liberty, or property are safe while the legislature is in session."\t-- Mark Twain
     I *heart* C++ - (admin) - (30)
         GNU compilers both sides? - (marlowe)
         What is the type of m_server_address? - (Arkadiy) - (3)
             As noted: - (admin) - (2)
                 Re: As noted: - (deSitter) - (1)
                     It isn't. - (admin)
         Fix: - (admin) - (24)
             const is a design error - (tuberculosis) - (23)
                 One of my directives for this port: - (admin) - (8)
                     Re: One of my directives for this port: - (deSitter) - (7)
                         The "const" attribute means that, within the given scope,... - (a6l6e6x) - (6)
                             Because it's not supposed to be modified... - (ChrisR) - (5)
                                 Yes, I remember all that.. - (deSitter) - (3)
                                     Re: why bother? - (a6l6e6x) - (2)
                                         Well, yes, that was what BS was obsessing on - (deSitter) - (1)
                                             Clearly BS hates programmers and doesn't trust them - (tuberculosis)
                                 Re: Because it's not supposed to be modified... - (JimWeirich)
                 Re: const is a design error - (JimWeirich) - (13)
                     Only if such differences exist - (tuberculosis) - (12)
                         Fun in computing. - (static)
                         Re: Only if such differences exist - (JimWeirich) - (10)
                             const functions - (tuberculosis) - (9)
                                 Well, it doesnt' appear to be overloaded on const - (Simon_Jester) - (8)
                                     Re: Well, it doesnt' appear to be overloaded on const - (JimWeirich)
                                     No, thats exactly the problem - (tuberculosis) - (6)
                                         This is what bugs me in Scott's problem... - (Arkadiy) - (5)
                                             I was pissed enough at the problem - (Arkadiy) - (4)
                                                 I was pissed enough that I: - (admin) - (3)
                                                     Solution - (Arkadiy) - (2)
                                                         ROFL - (admin)
                                                         Re: "..you can make it swallow the code." Beautiful! -NT - (a6l6e6x)

Worst case, tell your boss it's a new kind of ultra-XML -- not quite invisible, but only very sophisticated and intelligent people can see it...
347 ms