[ expat-Bugs-419585 ] Compiling with gcc for C++ exceptions.
noreply@sourceforge.net
noreply@sourceforge.net
Thu, 26 Jul 2001 13:50:33 -0700
Bugs item #419585, was opened at 2001-04-27 11:49
You can respond by visiting:
http://sourceforge.net/tracker/?func=detail&atid=110127&aid=419585&group_id=10127
Category: Build control
Group: Feature Request
>Status: Closed
>Resolution: Fixed
Priority: 5
Submitted By: David Crowley (dcrowley)
Assigned to: Fred L. Drake, Jr. (fdrake)
Summary: Compiling with gcc for C++ exceptions.
Initial Comment:
It would be nice if when compiling with gcc, the
flag "-fexceptions" was added so it can deal with C++
handlers that throw exceptions. As it's now built by
default, C++ programs will crash if they throw in the
handler. Perhaps make "-fexceptions" the default so as
to be most robust, and allow people to turn off the
flag as a parameter to configure ("configure --no-
exceptions" or whatever).
----------------------------------------------------------------------
>Comment By: Fred L. Drake, Jr. (fdrake)
Date: 2001-07-26 13:50
Message:
Logged In: YES
user_id=3066
OK, that's fine then. I've added the -fexceptions flag when we can determine that the compiler is GCC. This is in configure.in revision 1.18.
----------------------------------------------------------------------
Comment By: David Crowley (dcrowley)
Date: 2001-07-25 15:53
Message:
Logged In: YES
user_id=27458
Here are the results of my bench mark. Running on Linux
2.2.16 (SGI, dual processors, 800MHz), and parsing a 123MB
xml file.
Each run was initiated like this:
% time cat bigdog.xml | ./xbench
xbench is dynamically linked against expat. I copied
libexpat.so.0.0.1 compiled with -fexceptions
to /usr/local/lib, ran, and then copied one compiled w/o -
fexceptions, ran.
With -fexceptions: 9.82s, 9.80s, 9.79s.
W/o -fexceptions: 9.78s, 9.77s, 9.78s.
So the difference is pretty negligible. Around <.5% if any.
xbench.c is attached. Make your own 123MB file :)
----------------------------------------------------------------------
Comment By: Fred L. Drake, Jr. (fdrake)
Date: 2001-07-25 14:33
Message:
Logged In: YES
user_id=3066
This sounds like a reasonable plan -- I look forward to your measurement results. I really don't know what the C++ penetration is on Unix platforms, and may be exhibiting an unfortunate C bias.
I've marked the feature request as "pending"; when you add to it it will be automatically re-opened and assigned back to me, so it won't get lost.
----------------------------------------------------------------------
Comment By: David Crowley (dcrowley)
Date: 2001-07-25 14:20
Message:
Logged In: YES
user_id=27458
While I agree that yes, it IS a C implementation, I would
think that it would still be nice to for the library to be
more easily useable by C++ coders out of the box. I will
do a benchmark in C and see if I can figure out how much of
an impact the -fexceptions flag really makes. If it's less
than 2-3% impact in performance, I see no reason not to
make it a default. If a C coder REALLY needs that extra
speed and knows they will never install any C++ apps which
link against it, then by all means they can remove the flag.
----------------------------------------------------------------------
Comment By: Fred L. Drake, Jr. (fdrake)
Date: 2001-07-24 20:19
Message:
Logged In: YES
user_id=3066
Added a note about this in README revision 1.7.
This is not being added as a default option -- Expat is fundamentally a C implementation, not C++. Avoiding this option for normal C allows the optimizer to perform more effective optimizations and generally improve performance.
----------------------------------------------------------------------
You can respond by visiting:
http://sourceforge.net/tracker/?func=detail&atid=110127&aid=419585&group_id=10127