8901ac210e
2000-08-09 Benjamin Kosnik <bkoz@purist.soma.redhat.com> Preliminary wchar_t implementation, with trivial encodings. * docs/configopts.html: Add bits about canonical configure option checking. * testsuite/27_io/iostream_objects.cc: Replace this file (which has newly-declared-illegal mixing of wide/narrow stdstreams) with... * testsuite/27_io/narrow_stream_objects.cc: New file. * testsuite/27_io/wide_stream_objects.cc: New file. * bits/fstream.tcc (underflow): Temporarily hack a solution together that writes from the external file to the internal buffers. This removes codecvt from the loop, and is incorrect. (_M_really_overflow): Same here. * testsuite/21_strings/inserters_extractors.cc (test05): Tweaks. 2000-08-08 Benjamin Kosnik <bkoz@cygnus.com> Ulrich Drepper <drepper@cygnus.com> * config/c_io_libio.h: Tweak. * config/c_io_libio_codecvt.c: New file. * libio/Makefile.am: Add c_codecvt.c. * libio/Makefile.in: Regenerate. * libio/genops.c (_IO_unbuffer_write): Don't call _IO_SETBUF if the stream is not orientated. * acinclude.m4: Add config/c_io_libio_codecvt.c dummy file, until encoding gets fleshed out. * bits/basic_file.h: Add specialization declarations. * config/c_io_libio.cc: Add specializations for pbackfail, uflow. * config/c_io_libio.h: Add __c_wfile_type. * bits/basic_file.h: Add _M_wfile. * config/c_io_libio.cc (__basic_file<char>): Initialize the streams without setting the orientation of the underlying FILE to either wide or narrow. (__basic_file<wchar_t>)): Enable tricky wchar_t io bits. From-SVN: r35584
172 lines
6.7 KiB
HTML
172 lines
6.7 KiB
HTML
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
|
|
<HTML>
|
|
<HEAD>
|
|
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
|
|
<META NAME="AUTHOR" CONTENT="pme@sources.redhat.com (Phil Edwards)">
|
|
<META NAME="KEYWORDS" CONTENT="libstdc++, libstdc++-v3, egcs, g++">
|
|
<META NAME="DESCRIPTION" CONTENT="Configuration options for libstdc++-v3.">
|
|
<META NAME="GENERATOR" CONTENT="vi and eight fingers">
|
|
<TITLE>libstdc++-v3 configure options</TITLE>
|
|
<LINK REL="home" HREF="http://sources.redhat.com/libstdc++/">
|
|
<LINK REL=StyleSheet HREF="lib3styles.css">
|
|
<!-- $Id: configopts.html,v 1.6 2000/07/11 21:45:07 pme Exp $ -->
|
|
</HEAD>
|
|
<BODY>
|
|
|
|
<H1 CLASS="centered"><A NAME="top">Interesting <TT>configure</TT>
|
|
options</A></H1>
|
|
|
|
<P>The latest version of this document is always available at
|
|
<A HREF="http://sources.redhat.com/libstdc++/configopts.html">
|
|
http://sources.redhat.com/libstdc++/configopts.html</A>.
|
|
</P>
|
|
|
|
<P>To the <A HREF="index.html">libstdc++-v3 homepage</A>.
|
|
|
|
|
|
<!-- ####################################################### -->
|
|
<HR>
|
|
<P>Here are some of the non-obvious options to libstdc++'s configure.
|
|
Keep in mind that
|
|
<!-- This SECnn should be the "Choosing Package Options" section. -->
|
|
<A HREF="http://sources.redhat.com/autoconf/autoconf.html#SEC74">they
|
|
all have opposite forms as well</A>
|
|
(enable/disable and with/without). The defaults are for the latest
|
|
snapshot, 2.90.8.
|
|
<P>
|
|
The canonical way to find out the configure options that are
|
|
available for a given set of libstdc++ sources is to go to the
|
|
source directory and then type: <TT> ./config --help </TT>
|
|
|
|
<DL>
|
|
<DT><TT>--enable-multilib </TT>[default]
|
|
<DD><P>This is part of the generic multilib support for building
|
|
cross compilers. As such, targets like "powerpc-elf" will
|
|
have libstdc++ built many different ways: "-msoft-float" and
|
|
not, etc. A different libstdc++ will be built for each of the
|
|
different multilib versions. This option is on by default.
|
|
</P>
|
|
|
|
<DT><TT>--enable-debug </TT>
|
|
<DD><P>The configure script will automatically detect the highest level
|
|
of optimization that the compiler in use can use (certain
|
|
versions of g++ will ICE if given the <TT>-O2</TT> option, but
|
|
this is fixed in later versions of the compiler). This --enable
|
|
flag will disable all optimizations and instruct the compiler to
|
|
emit as much extra debugging information as it can, for use
|
|
inside GDB.
|
|
</P>
|
|
|
|
<DT><TT>--enable-cstdio </TT>[default]
|
|
<DD><P>This is an abbreviated form of <TT>'--enable-cstdio=libio'</TT>
|
|
(described next).
|
|
</P>
|
|
|
|
<DT><TT>--enable-cstdio=LIB </TT>
|
|
<DD><P>Select a target-specific I/O package. As of libstdc++-v3
|
|
snapshot 2.90.8, the choices are 'libio' to specify the GNU
|
|
I/O package (from
|
|
<A HREF="http://sources.redhat.com/glibc/">glibc</A>, the
|
|
GNU C library), or 'wince' to specify the Microsoft Windows CE
|
|
library. Eventually a generic cstdio interface will be added
|
|
so that people who want to use libstdc++-v3 with say, the Palm
|
|
Pilot, will be able to use libstdc++-v3 without libio.
|
|
</P>
|
|
|
|
<DT><TT>--enable-long-long </TT>
|
|
<DD><P>The "long long" type was introduced in C99. It is
|
|
provided as a GNU extension to C++98 in g++. This flag builds
|
|
support for "long long" into the library (specialized
|
|
templates and the like).
|
|
</P>
|
|
|
|
<DT><TT>--enable-namespaces </TT>[default]
|
|
<DD><P>By default, g++ currently ignores namespace <TT>std</TT> for
|
|
backwards compatibility. It can be turned on with the
|
|
<TT> -fhonor-std </TT> flag to the compiler. As of libstdc++-v3
|
|
snapshot 2.90.8, that flag is passed to g++ when building the
|
|
library. (In g++ 2.96 and later, this flag is on by default if
|
|
libstdc++-v3 is used.) The --disable variant will put all std::
|
|
symbols into the global namespace.
|
|
</P>
|
|
|
|
<DT><TT>--enable-cshadow-headers </TT>
|
|
<DD><P>This turns on the code to construct shadowed C headers. Very
|
|
experimental as of this writing.
|
|
</P>
|
|
|
|
<DT><TT>--enable-threads </TT>
|
|
<DD><P>This is an abbreviated form of <TT>'--enable-threads=yes'</TT>
|
|
(described next).
|
|
</P>
|
|
|
|
<DT><TT>--enable-threads=LIB </TT>
|
|
<DD><P>Select a threading library. As of libstdc++-v3 snapshot 2.90.8,
|
|
the choices are:
|
|
'yes' for some kind of default (hmmmmm);
|
|
'decosf1', 'irix', 'mach', 'os2', 'posix'/'pthreads'
|
|
(same thing),
|
|
'solaris', 'win32', 'dce', or 'vxworks' to select the
|
|
corresponding interface;
|
|
and 'single', 'no', or 'none' for the null-case,
|
|
single-threaded library.
|
|
</P>
|
|
<P>All of this is currently undergoing a lot of changes. As of
|
|
2.90.8, 'single' and 'posix' are the only implemented models.
|
|
</P>
|
|
|
|
<DT><TT>--enable-libgcc-rebuild=DIR / --disable-libgcc-rebuild</TT>
|
|
<DD><P>This is a grueling temporary hack no matter which way you look
|
|
at it. It's described in <A HREF="gccrebuild.html">its own
|
|
little page</A>. Note that other --enable flags will
|
|
interact with this one. In libstdc++-v3 snapshot 2.90.8,
|
|
this is enabled by default, with DIR set to
|
|
<TT> '../..' </TT>, so that building the complete GCC sources
|
|
with libstdc++-v3 in place works transparently. Since then,
|
|
library sources have been merged into the compiler sources,
|
|
and this option has been removed.
|
|
</P>
|
|
|
|
<DT><TT>--enable-cxx-flags=FLAGS</TT>
|
|
<DD><P>With this option, you can pass a string of -f (functionality)
|
|
flags to the compiler to use when building libstdc++. FLAGS
|
|
is a quoted string of options, like
|
|
<PRE>
|
|
--enable-cxx-flags='-fsquangle -fvtable-gc -ansi'</PRE>
|
|
Note that the flags don't necessarily have to all be -f flags,
|
|
as shown, but usually those are the ones that will make sense
|
|
for experimentation and configure-time overriding.
|
|
</P>
|
|
<P>The advantage of --enable-cxx-flags over setting CXXFLAGS in
|
|
the 'make' environment is that, if libgcc is automatically
|
|
rebuilt, the same flags will be used when compiling those files
|
|
as well, so that everything matches.
|
|
</P>
|
|
<P>Fun flags to try might include combinations of
|
|
<PRE>
|
|
-fstrict-aliasing
|
|
-fnew-abi
|
|
-fnew-exceptions
|
|
-ffunction-sections
|
|
-fvtable-gc</PRE>
|
|
and -fno- forms of the same. Tell us (the mailing list) if
|
|
you discover more!
|
|
</P>
|
|
</DL>
|
|
</P>
|
|
<P>Return <A HREF="#top">to the top of the page</A> or
|
|
<A HREF="index.html">to the homepage</A>.
|
|
</P>
|
|
|
|
|
|
<!-- ####################################################### -->
|
|
|
|
<HR>
|
|
<P CLASS="fineprint"><EM>
|
|
$Id: configopts.html,v 1.6 2000/07/11 21:45:07 pme Exp $
|
|
</EM></P>
|
|
|
|
|
|
</BODY>
|
|
</HTML>
|