public inbox for gcc-prs@sourceware.org
help / color / mirror / Atom feed
* c++/1877: gcc-20010122 and gcc-20010205 cause linker errors with static const int
@ 2001-04-01 0:00 spencer
0 siblings, 0 replies; only message in thread
From: spencer @ 2001-04-01 0:00 UTC (permalink / raw)
To: gcc-gnats
>Number: 1877
>Category: c++
>Synopsis: gcc-20010122 and gcc-20010205 cause linker errors with static const int
>Confidential: no
>Severity: serious
>Priority: medium
>Responsible: unassigned
>State: open
>Class: rejects-legal
>Submitter-Id: net
>Arrival-Date: Mon Feb 05 11:16:00 PST 2001
>Closed-Date:
>Last-Modified:
>Originator: Brad Spencer
>Release: 20010122 and 20010205
>Organization:
>Environment:
$ uname -a; /opt/gcc-20010122/bin/g++ -v
SunOS starbug 5.6 Generic_105182-05 i86pc i386 i86pc
Reading specs from /opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/specs
Configured with: ../gcc-20010122/configure --prefix=/opt/gcc-20010122 --enable-languages=c++
gcc version 2.97 20010122 (experimental)
>Description:
Code that uses the ternary operator (?:) with a "static const int" class data member in a certain way causes a strange linker error. Using "if-then" logic instead of "?:" or using an unsigned integer avoids the error.
Complete source (no includes) of an example follows.
// BEGIN
class A
{
public:
A() : var(2), flag(false) {}
static const int c = 1;
int var;
bool flag;
public:
int f() const { return flag ? var : c; }
};
int main()
{
A object;
const int e = object.f();
return e;
}
// END
Changing the definiton of the function "f" to
int f() const { if(flag) return var; return c; }
_or_ the definition of the constant "c" to
static const unsigned int c = 1;
does not generate the error.
I used the codesourcery online compiler to try gcc-20010205 and my own installation for gcc-20010122.
$ /opt/gcc-20010122/bin/g++ -v foo.cc
Reading specs from /opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/specs
Configured with: ../gcc-20010122/configure --prefix=/opt/gcc-20010122 --enable-languages=c++
gcc version 2.97 20010122 (experimental)
/opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/cc1plus -v -D__GNUC__=2 -D__GNUC_MINOR__=97 -D__GNUC_PATCHLEVEL__=0 -Dunix -D__svr4__ -D__SVR4 -Dsun -D__unix__ -D__svr4__ -D__SVR4 -D__sun__ -D__unix -D__sun -Asystem=svr4 -D__STDC_HOSTED__=1 -Acpu=i386 -Amachine=i386 -Di386 -D__i386 -D__i386__ -D__tune_i386__ foo.cc -D__GNUG__=2 -D_GNU_SOURCE -D__GXX_ABI_VERSION=100 -quiet -dumpbase foo.cc -version -o /var/tmp/ccu1T5ZL.s
GNU CPP version 2.97 20010122 (experimental) (cpplib) (i386 System V Release 4)
GNU CPP version 2.97 20010122 (experimental) (cpplib) (i386 System V Release 4)
GNU C++ version 2.97 20010122 (experimental) (i386-pc-solaris2.6)
compiled by GNU C version 2.95.2 19991024 (release).
#include "..." search starts here:
#include <...> search starts here:
/opt/gcc-20010122/include/g++-v3
/opt/gcc-20010122/i386-pc-solaris2.6/include/g++-v3
/opt/gcc-20010122/include
/opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/include
/opt/gcc-20010122/i386-pc-solaris2.6/include
/usr/include
End of search list.
/usr/ccs/bin/as -V -Qy -s -o /var/tmp/ccG26AGw.o /var/tmp/ccu1T5ZL.s
GNU assembler version 2.10 (i386-pc-solaris2.6) using BFD version 2.10
/opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/collect2 -V -Y P,/usr/ccs/lib:/usr/lib -Qy /opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/crt1.o /opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/crti.o /usr/ccs/lib/values-Xa.o /opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/crtbegin.o -L/opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97 -L/usr/ccs/bin -L/usr/ccs/lib -L/opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/../../.. /var/tmp/ccG26AGw.o -lstdc++ -lm -lgcc -lc -lgcc /opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/crtend.o /opt/gcc-20010122/lib/gcc-lib/i386-pc-solaris2.6/2.97/crtn.o
/var/tmp/ccG26AGw.o: In function `A::f() const':
/var/tmp/ccG26AGw.o(.gnu.linkonce.t._ZNK1A1fEv+0x1d): undefined reference to `A::c '
GNU ld version 2.10 (with BFD 2.10)
Supported emulations:
elf_i386
collect2: ld returned 1 exit status
---------
Reading specs from /usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97/specs
Configured with: ../configure --prefix=/tmp/gcc-20010205-root/usr/local --enable-shared --enable-threads --disable-checking i386-pc-linux-gnu : (reconfigured)
gcc version 2.97 20010205 (experimental)
/usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97/cc1plus -v -iprefix /usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97/ -D__GNUC__=2 -D__GNUC_MINOR__=97 -D__GNUC_PATCHLEVEL__=0 -D__ELF__ -Dunix -Dlinux -D__ELF__ -D__unix__ -D__linux__ -D__unix -D__linux -Asystem=posix -D__STDC_HOSTED__=1 -Acpu=i386 -Amachine=i386 -Di386 -D__i386 -D__i386__ -D__tune_i386__ /tmp/@933.7.cc -D__GNUG__=2 -D_GNU_SOURCE -D__GXX_ABI_VERSION=100 -quiet -dumpbase @933.7.cc -version -o /tmp/ccpehC9e.s
GNU CPP version 2.97 20010205 (experimental) (cpplib) (i386 Linux/ELF)
GNU CPP version 2.97 20010205 (experimental) (cpplib) (i386 Linux/ELF)
GNU C++ version 2.97 20010205 (experimental) (i386-pc-linux-gnu)
compiled by GNU C version 2.97 20010205 (experimental).
ignoring nonexistent directory "/usr/local/include/g++-"
ignoring nonexistent directory "/usr/local/i386-pc-linux-gnu/include/g++-"
ignoring nonexistent directory "/tmp/gcc-20010205-root/usr/local/include/g++-"
ignoring nonexistent directory "/tmp/gcc-20010205-root/usr/local/i386-pc-linux-gnu/include/g++-"
ignoring nonexistent directory "/tmp/gcc-20010205-root/usr/local/lib/gcc-lib/i386-pc-linux-gnu/2.97/include"
ignoring nonexistent directory "/tmp/gcc-20010205-root/usr/local/i386-pc-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
/usr/local/lib/gcc-lib/i386-pc-linux-gnu/2.97/include
/usr/local/i386-pc-linux-gnu/include
/usr/local/include
/usr/include
End of search list.
/tmp/@933.7.cc:21:1: warning: no newline at end of file
as -V -Qy -o /tmp/cczmn0Hk.o /tmp/ccpehC9e.s
GNU assembler version 2.9.1 (i386-redhat-linux), using BFD version 2.9.1.0.24
/usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97/collect2 -m elf_i386 -dynamic-linker /lib/ld-linux.so.2 -o /tmp/@933.8 /usr/lib/crt1.o /usr/lib/crti.o /usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97/crtbegin.o -L/usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97 -L/usr/local/bin/../lib/gcc-lib -L/usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97/../../.. /tmp/cczmn0Hk.o -lstdc++ -lm -lgcc -lc -lgcc /usr/local/bin/../lib/gcc-lib/i386-pc-linux-gnu/2.97/crtend.o /usr/lib/crtn.o
/tmp/cczmn0Hk.o: In function `A::f() const':
/tmp/cczmn0Hk.o(.gnu.linkonce.t._ZNK1A1fEv+0x1d): undefined reference to `A::c '
collect2: ld returned 1 exit status
--------
It works with gcc-2.95.2.
$ g++ -v foo.cc
Reading specs from /opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/specs
gcc version 2.95.2 19991024 (release)
/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/cpp -lang-c++ -v -D__GNUC__=2 -D__GNUG__=2 -D__GNUC_MINOR__=95 -D__cplusplus -Dunix -D__svr4__ -D__SVR4 -Dsun -D__unix__ -D__svr4__ -D__SVR4 -D__sun__ -D__unix -D__sun -Asystem(svr4) -D__EXCEPTIONS -Acpu(i386) -Amachine(i386) -Di386 -D__i386 -D__i386__ foo.cc /var/tmp/ccigX8Yq.ii
GNU CPP version 2.95.2 19991024 (release) (i386 System V Release 4)
#include "..." search starts here:
#include <...> search starts here:
/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/../../../../include/g++-3
/usr/local/include
/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/../../../../i386-pc-solaris2.6/include
/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/include
/usr/include
End of search list.
The following default directories have been omitted from the search path:
End of omitted list.
/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/cc1plus /var/tmp/ccigX8Yq.ii -quiet -dumpbase foo.cc -version -o /var/tmp/ccgRopdJ.s
GNU C++ version 2.95.2 19991024 (release) (i386-pc-solaris2.6) compiled by GNU C version 2.95.2 19991024 (release).
/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/as -V -Qy -o /var/tmp/ccCcMyD2.o /var/tmp/ccgRopdJ.s
GNU assembler version 2.9.1 (i386-pc-solaris2.6), using BFD version 2.9.1
/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/collect2 -V -Y P,/usr/ccs/lib:/usr/lib -Qy /opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/crt1.o /opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/crti.o /usr/ccs/lib/values-Xa.o /opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/crtbegin.o -L/opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2 -L/usr/ccs/bin -L/usr/ccs/lib -L/opt/gcc-2.95.2/lib /var/tmp/ccCcMyD2.o -lstdc++ -lm -lgcc -lc -lgcc /opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/crtend.o /opt/gcc-2.95.2/lib/gcc-lib/i386-pc-solaris2.6/2.95.2/crtn.o
GNU ld version 2.10 (with BFD 2.10)
Supported emulations:
elf_i386
>How-To-Repeat:
>Fix:
>Release-Note:
>Audit-Trail:
>Unformatted:
>From B.Touron@citb.bull.net Sun Apr 01 00:00:00 2001
From: B.Touron@citb.bull.net
To: gcc-gnats@gcc.gnu.org
Subject: c++/2208: Problem with g++ and templates
Date: Sun, 01 Apr 2001 00:00:00 -0000
Message-id: <20010307183810.21369.qmail@sourceware.cygnus.com>
X-SW-Source: 2001-q1/msg02086.html
Content-length: 997
>Number: 2208
>Category: c++
>Synopsis: Problem with g++ and templates
>Confidential: no
>Severity: serious
>Priority: medium
>Responsible: unassigned
>State: open
>Class: sw-bug
>Submitter-Id: net
>Arrival-Date: Wed Mar 07 10:46:01 PST 2001
>Closed-Date:
>Last-Modified:
>Originator: Benoit Touron
>Release: gcc version 2.95.2 19991024 (release)
>Organization:
>Environment:
UnixWare bdsdev 5 7.1.0 i386 x86at SCO UNIX_SVR5
(result of uname -a)
>Description:
This program does not compile
--> START
template<class BASE_CLASS>
class myclass : public BASE_CLASS
{
public:
void fun(BASE_CLASS::mytype p) // GOT " parse error
// before `)'"
{ return; }
};
void main()
{
}
<-- END
BASE_CLASS is supposed to have type "mytype"
defined inside it (and public).
This file compiles OK with MS compiler.
>How-To-Repeat:
g++ -c test.cc
>Fix:
>Release-Note:
>Audit-Trail:
>Unformatted:
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2001-04-01 0:00 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2001-04-01 0:00 c++/1877: gcc-20010122 and gcc-20010205 cause linker errors with static const int spencer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).