Xref: news2.mv.net comp.os.msdos.djgpp:7290 From: edkiser AT jaxnet DOT com (M. Edward Kiser) Newsgroups: comp.os.msdos.djgpp Subject: Re: Standard C++ Library? I give up! Date: Tue, 13 Aug 1996 06:21:14 GMT Organization: Southeast Network Services, Inc. Lines: 76 Message-ID: <4up7ba$lde@jaxnet.southeast.net> References: Reply-To: edkiser AT jaxnet DOT com NNTP-Posting-Host: ts2-006.southeast.net To: djgpp AT delorie DOT com DJ-Gateway: from newsgroup comp.os.msdos.djgpp Eli Zaretskii wrote: >On Tue, 6 Aug 1996, M. Edward Kiser wrote: >> complexu.cpp: In function `int main()': >> complexu.cpp:22: redeclaration of `class complex * ii' >> complexu.cpp:22: `class complex * ii' previously declared here >Did you read section 8.11 of the DJGPP FAQ list? It discusses some >possible problems with using class complex in DJGPP. The latest version >of the FAQ is available as v2/faq201b.zip from the same place you get >DJGPP. I _had_ read the FAQ 2.00 and found nothing. I didn't know 2.01 was out until I saw your message. Thanks. But it didn't help. I'm _not_ confusing the GNU Complex class with the complex<> template. That seems to be what the FAQ's talking about. Maybe I should have numbered my lines, it's not even clear to me where the error is... the problem seems to be coming from the "vec::iterator ii" inside the "for" parentheses. It should expand to "complex * ii". It seems not to be working. That's STL, not the complex<> template. I've had problems with templates before. It seems under GCC that: * A template can't have a static data member. This is too bad because the STL list<> likes to keep a free list in a static buffer. This, of course, means EACH instantiation of the template would have its own buffer. Right now that code is inside #if 0 ... #endif, so I guess GCC doesn't support it. * A template _can_ have an enum or a typedef inside it, but this enum or typedef is only usable inside the class declaration. This is too bad, because vector<>::iterator, vector<>::const_iterator, and so forth are all typedefs; you can see for yourself in the .H file. Maybe this is the problem that I'm having with vec::iterator. I tried to write a hybrid array-stack with an enum mode { absolute, relative }, but when I had a function template T arraystack::peek (arraystack::index i, arraystack::mode m = arraystack::relative ); the compiler couldn't find arraystack::index because it said arraystack was an incomplete type. "arraystack::index" did the same thing, and "index" alone, of course, was undefined. But I was desperate and had to try it. You can put those enums and typedefs in a parent class and make the template descend from that class, but STL's typedefs are parametric, so that won't work. I've had other problems with STL: it has some templates in it so that if the operators != <= > >= aren't defined, it defines them (as template functions) in terms of == and < for you. But then when CINST.H tries to instantiate one of the != operators for complex<>, GCC says the instantiation is ambiguous. So I can't use STL and complex<> in the same program? Without these standard classes, C++ itself is broken. -------- Ed Kiser (edkiser AT jaxnet DOT com) "The great epochs of our lives are at the points where we rebaptize our badness as the best in us." -- Nietzsche