c++/7708: g++ -O inserts definition of std::string::replace in library module
Bradford Castalia
Castalia@azstarnet.com
Tue Jan 14 00:46:00 GMT 2003
The following reply was made to PR c++/7708; it has been noted by GNATS.
From: Bradford Castalia <Castalia@azstarnet.com>
To: bangerth@dealii.org, Castalia@azstarnet.com, gcc-bugs@gcc.gnu.org,
gcc-prs@gcc.gnu.org, nobody@gcc.gnu.org, gcc-gnats@gcc.gnu.org
Cc:
Subject: Re: c++/7708: g++ -O inserts definition of std::string::replace in
library module
Date: Mon, 13 Jan 2003 17:36:47 -0700
I've just installed the gcc32 package from the FreePSG ports site:
idaeim:castalia>> g++ --version
g++ (GCC) 3.2.1
After running the test cases, as well as the full recompile of my project code,
I can confirm that the -O switch no longer generates library symbol definitions
for the std::string::replace method.
Using a Test.h file:
#include <string>
class Test
{
public:
Test (const std::string& message = "");
void message (const std::string& message);
private:
std::string Message;
};
And a Test.cpp file:
#include "Test.h"
Test::Test (const std::string& message) : Message (message)
{
if (! Message.empty () && Message[Message.size () - 1] == '\n')
Message.erase (Message.size () - 1);
}
void Test::message (const std::string& new_message)
{
Message.replace (std::string::size_type(0), Message.length (), new_message);
if (! Message.empty () && Message[Message.size () - 1] == '\n')
Message.erase (Message.size () - 1);
}
Building an object module compiled with g++ 3.1.1 20020617 (prerelease) [FreeBSD]
(g++31 -O -c -o opt-Test.o Test.cpp) and then examing the object symbols reveals,
in addition to the weak symbols, a text symbol for "replace":
idaeim:castalia>> nm -g -o -C opt-Test.o | grep replace
opt-Test.o:00000000 W std::string& std::string::_M_replace<char const*>(__gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, char const*, char const*, std::input_iterator_tag)
opt-Test.o:00000000 W std::string& std::string::_M_replace_safe<__gnu_cxx::__normal_iterator<char*, std::string> >(__gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>)
opt-Test.o:00000000 W std::string& std::string::_M_replace_safe<char const*>(__gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, char const*, char const*)
opt-Test.o:000001f0 T std::string::replace(unsigned, unsigned, char const*, unsigned)
Building an object module compiled with g++ 3.2.1 and then examing the symbols
reveals that the text symbol is now an undefined reference to "replace" as expected:
idaeim:castalia>> nm -g -o -C new-opt-Test.o | grep replace
new-opt-Test.o:00000000 W std::string& std::string::_M_replace<char const*>(__gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, char const*, char const*, std::input_iterator_tag)
new-opt-Test.o:00000000 W std::string& std::string::_M_replace_safe<__gnu_cxx::__normal_iterator<char*, std::string> >(__gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>)
new-opt-Test.o:00000000 W std::string& std::string::_M_replace_safe<char const*>(__gnu_cxx::__normal_iterator<char*, std::string>, __gnu_cxx::__normal_iterator<char*, std::string>, char const*, char const*)
new-opt-Test.o: U std::string::replace(unsigned, unsigned, char const*, unsigned)
The problem of problem of multiple definitions at link time has now been fixed.
Thnx!
--
Bradford Castalia
Systems Analyst
bangerth@dealii.org wrote:
>
> Synopsis: g++ -O inserts definition of std::string::replace in library module
>
> State-Changed-From-To: open->feedback
> State-Changed-By: bangerth
> State-Changed-When: Thu Dec 19 18:19:52 2002
> State-Changed-Why:
> I tried your program with gcc3.2, but on x86 linux. I can
> confirm that the mentioned symbols are present in the
> object file. However, they are weak:
> 00000000 W std::string& std::string::_M_replace<....
>
> Weak symbols means: they can be in multiple object files,
> and one of these copies is picked at link time.
>
> Could you possibly check whether the problem still exists
> on your platform with gcc3.2.1?
>
> Thanks
> Wolfgang
>
> http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=7708
Wolfgang Bangerth wrote:
>
> On Sun, 22 Dec 2002, Bradford Castalia wrote:
>
> > When I get gcc3.2.1 (or greater) installed on the FreeBSD workstation
> > (hasn't happened yet, sorry) I will definately run the test files
> > again. You will probably get a faster response from one of the FreeBSD
> > developers (http://www.FreeBSD.org).
>
> Please let us know about your results. Maybe someone of the FeeBSD
> maintainers could also try to look into this?
>
> Regards
> Wolfgang
>
> -------------------------------------------------------------------------
> Wolfgang Bangerth email: bangerth@ticam.utexas.edu
> www: http://www.ticam.utexas.edu/~bangerth
More information about the Gcc-prs
mailing list