* except.c (expand_start_catch_block): We only need the rethrow
[official-gcc.git] / gcc / NEWS
blob6483738327de3786b0f1e782541b6a6fc1880c32
1 Noteworthy changes in GCC version 2.8.0:
3 The -specs=file switch allows you to override default specs used in invoking
4 programs like cc1, as, etc.
6 Options -Wall and -Wimplicit now cause GCC to warn about implicit int
7 in declarations (e.g. `register i;'), since the C Standard committee
8 has decided to disallow this in the next revision of the standard.
10 The following new targets are supported:
12     Solaris 2.5 running on UltraSPARC's.
13     The sparclet cpu (a.out file format).
14     Solaris 2.51 running on PowerPC's.
15     Linux running on PowerPC's.
16     Embedded target m32r-elf.
18 New features for the Hitachi H8/300(H).
20     -malign-300
21     -ms
23 The -ms switch generates code for the Hitachi H8/S processor.
25 New features for SPARC-based systems:
27     -mcpu=xxx
28     -mtune=xxx
29     -mimpure-text and -mno-impure-text
31 New features for all rs6000 and PowerPC systems:
33     -mcpu=604e
34     -mcpu=801
35     -mcpu=823
36     -mtune=xxx
37     -mupdate
38     -mno-update
39     -mfused-madd
40     -mno-fused-madd
42 New features for PowerPC-based systems running either System V, Linux, Solaris,
43 or embedded systems:
45     -mregnames
46     -meabi
47     -mcall-linux
48     -mcall-solaris
49     -mcall-sysv-eabi
50     -mcall-sysv-noeabi
51     -msdata
52     -msdata=none
53     -msdata=default
54     -msdata=sysv
55     -msdata=eabi
56     -memb
57     -msim
58     -mmvme
59     wchar_t is now of type long, not unsigned short as per ABI.
60     -p/-pg support
61     -mcpu=403 now implies -mstrict-align.
63 Options -mno-v8 and -mno-sparclite are no longer supported on SPARC
64 targets.  Options -mcypress, -mv8, -msupersparc, -msparclite, -mf930,
65 and -mf934 are deprecated and will be deleted in GCC 2.9.
66 Use -mcpu=xxx instead.
68 GCC on the PA requires either gas-2.7 or the HP assembler; for best
69 results using GAS is highly recommended.  GAS is required for -g
70 and exception handling support.
72 Aix 4.1 GCC targets now default to -mcpu=common so that programs compiled can
73 be moved between rs6000 and powerpc based systems.  A consequence of this is
74 that -static won't work, and that some programs may be slightly slower.
76 You can select the default value to use for -mcpu=xxx on rs6000 and powerpc
77 targets by using the --with-cpu=xxx option when confiuring the compiler.  In
78 addition, a new options, -mtune=xxx was added that selects the machine to
79 schedule for but does not select the architecture level.
81 Directory names used for storing the multilib libraries on System V and
82 embedded PowerPC systems have been shortened to work with commands like tar
83 that have fixed limits on pathname size.
85 Noteworthy changes in GCC version 2.7.2:
87 A few bugs have been fixed (most notably the generation of an
88 invalid assembler opcode on some RS/6000 systems).
90 Noteworthy changes in GCC version 2.7.1:
92 This release fixes numerous bugs (mostly minor) in GCC 2.7.0, but
93 also contains a few new features, mostly related to specific targets.
95 Major changes have been made in code to support Windows NT.
97 The following new targets are supported:
99         2.9 BSD on PDP-11
100         Linux on m68k
101         HP/UX version 10 on HP PA RISC (treated like version 9)
102         DEC Alpha running Windows NT
104 When parsing C, GCC now recognizes C++ style `//' comments unless you
105 specify `-ansi' or `-traditional'.
107 The PowerPC System V targets (powerpc-*-sysv, powerpc-*-eabi) now use the
108 calling sequence specified in the System V Application Binary Interface
109 Processor Supplement (PowerPC Processor ABI Supplement) rather than the calling
110 sequence used in GCC version 2.7.0.  That calling sequence was based on the AIX
111 calling sequence without function descriptors.  To compile code for that older
112 calling sequence, either configure the compiler for powerpc-*-eabiaix or use
113 the -mcall-aix switch when compiling and linking.
115 Noteworthy changes in GCC version 2.7.0:
117 GCC now works better on systems that use ".obj" and ".exe" instead of
118 ".o" and no extension.  This involved changes to the driver program,
119 gcc.c, to convert ".o" names to ".obj" and to GCC's Makefile to use
120 ".obj" and ".exe" in filenames that are not targets.  In order to
121 build GCC on such systems, you may need versions of GNU make and/or
122 compatible shells.  At this point, this support is preliminary.
124 Object file extensions of ".obj" and executable file extensions of
125 ".exe" are allowed when using appropriate version of GNU Make.
127 Numerous enhancements were made to the __attribute__ facility including
128 more attributes and more places that support it.  We now support the
129 "packed", "nocommon", "noreturn", "volatile", "const", "unused",
130 "transparent_union", "constructor", "destructor", "mode", "section",
131 "align", "format", "weak", and "alias" attributes.  Each of these
132 names may also be specified with added underscores, e.g., "__packed__".
133 __attribute__ may now be applied to parameter definitions, function
134 definitions, and structure, enum, and union definitions.
136 GCC now supports returning more structures in registers, as specified by
137 many calling sequences (ABIs), such as on the HP PA RISC.
139 A new option '-fpack-struct' was added to automatically pack all structure
140 members together without holes.
142 There is a new library (cpplib) and program (cppmain) that at some
143 point will replace cpp (aka cccp).  To use cppmain as cpp now, pass
144 the option CCCP=cppmain to make.  The library is already used by the
145 fix-header program, which should speed up the fixproto script.
147 New options for supported targets:
149     GNU on many targets.
150     NetBSD on MIPS, m68k, VAX, and x86.
151     LynxOS on x86, m68k, Sparc, and RS/6000.
152     VxWorks on many targets.
154     Windows/NT on x86 architecture.  Initial support for Windows/NT on Alpha
155     (not fully working).
157     Many embedded targets, specifically UDI on a29k, aout, coff, elf,
158     and vsta "operating systems" on m68k, m88k, mips, sparc, and x86.
160 Additional support for x86 (i386, i486, and Pentium):
162     Work with old and new linkers for Linux-based GNU systems,
163         supporting both a.out and ELF.
164     FreeBSD on x86.
165     Stdcall convention.
166     -malign-double, -mregparm=, -malign-loops= and -malign-jumps=  switches.
167     On ISC systems, support -Xp like -posix.
169 Additions for RS/6000:
171     Instruction scheduling information for PowerPC 403.
172     AIX 4.1 on PowerPC.
173     -mstring and -mno-string.
174     -msoft-float and floating-point emulation included.
175     Preliminary support for PowerPC System V.4 with or without the GNU as.
176     Preliminary support for EABI.
177     Preliminary support for 64-bit systems.
178     Both big and little endian systems.
180 New features for MIPS-based systems:
182     r4650.
183     mips4 and R8000.
184     Irix 6.0.
185     64-bit ABI.
186     Allow dollar signs in labels on SGI/Irix 5.x.
188 New support for HP PA RISC:
190     Generation of PIC (requires binutils-2.5.2.u6 or later).
191     HP-UX version 9 on HP PA RISC (dynamically links even with -g).
192     Processor variants for HP PA RISC: 700, 7100, and 7100LC.
193     Automatic generation of long calls when needed.
194     -mfast-indirect-calls for kernels and static binaries.
196     The called routine now copies arguments passed by invisible reference,
197     as required by the calling standard.
199 Other new miscellaneous target-specific support:
201     -mno-multm on a29k.
202     -mold-align for i960.
203     Configuration for "semi-hosted" ARM.
204     -momit-leaf-frame-pointer for M88k.
205     SH3 variant of Hitachi Super-H and support both big and little endian.
207 Changes to Objective-C:
209     Bare-bones implementation of NXConstantString has been added,
210     which is invoked by the @"string" directive.
212     Class * has been changed to Class to conform to the NextSTEP and
213     OpenStep runtime.
215     Enhancements to make dynamic loading easier.
217     The module version number has been updated to Version 7, thus existing
218     code will need to be recompiled to use the current run-time library.
220 GCC now supports the ISO Normative Addendum 1 to the C Standard.
221 As a result:
223     The header <iso646.h> defines macros for C programs written
224     in national variants of ISO 646.
226     The following digraph tokens are supported:
227         <:      :>      <%      %>      %:      %:%:
228     These behave like the following, respectively:
229         [       ]       {       }       #       ##
231     Digraph tokens are supported unless you specify the `-traditional'
232     option; you do not need to specify `-ansi' or `-trigraphs'.  Except
233     for contrived and unlikely examples involving preprocessor
234     stringizing, digraph interpretation doesn't change the meaning of
235     programs; this is unlike trigraph interpretation, which changes the
236     meanings of relatively common strings.
238     The macro __STDC_VERSION__ has the value 199409L.
240   As usual, for full conformance to the standard, you also need a
241   C library that conforms.
243 The following lists changes that have been made to g++.  If some
244 features mentioned below sound unfamiliar, you will probably want to
245 look at the recently-released public review copy of the C++ Working
246 Paper.  For PostScript and PDF (Adobe Acrobat) versions, see the
247 archive at ftp://research.att.com/dist/stdc++/WP.  For HTML and ASCII
248 versions, see ftp://ftp.cygnus.com/pub/g++.  On the web, see
249 http://www.cygnus.com/~mrs/wp-draft.
251 The scope of variables declared in the for-init-statement has been changed
252 to conform to http://www.cygnus.com/~mrs/wp-draft/stmt.html#stmt.for; as a
253 result, packages such as groff 1.09 will not compile unless you specify the
254 -fno-for-scope flag.  PLEASE DO NOT REPORT THIS AS A BUG; this is a change
255 mandated by the C++ standardization committee.
257 Binary incompatibilities:
259     The builtin 'bool' type is now the size of a machine word on RISC targets,
260     for code efficiency; it remains one byte long on CISC targets.
262     Code that does not use #pragma interface/implementation will most
263     likely shrink dramatically, as g++ now only emits the vtable for a
264     class in the translation unit where its first non-inline, non-abstract
265     virtual function is defined.
267     Classes that do not define the copy constructor will sometimes be
268     passed and returned in registers.  This may illuminate latent bugs in
269     your code.
271 Support for automatic template instantiation has *NOT* been added, due
272 to a disagreement over design philosophies.
274 Support for exception handling has been improved; more targets are now
275 supported, and throws will use the RTTI mechanism to match against the
276 catch parameter type.  Optimization is NOT SUPPORTED with
277 -fhandle-exceptions; no need to report this as a bug.
279 Support for Run-Time Type Identification has been added with -frtti.
280 This support is still in alpha; one major restriction is that any file
281 compiled with -frtti must include <typeinfo.h>.
283 Preliminary support for namespaces has been added.  This support is far
284 from complete, and probably not useful.
286 Synthesis of compiler-generated constructors, destructors and
287 assignment operators is now deferred until the functions are used.
289 The parsing of expressions such as `a ? b : c = 1' has changed from
290 `(a ? b : c) = 1' to `a : b ? (c = 1)'.
292 The code generated for testing conditions, especially those using ||
293 and &&, is now more efficient.
295 The operator keywords and, and_eq, bitand, bitor, compl, not, not_eq,
296 or, or_eq, xor and xor_eq are now supported.  Use -ansi or
297 -foperator-names to enable them.
299 The 'explicit' keyword is now supported.  'explicit' is used to mark
300 constructors and type conversion operators that should not be used
301 implicitly.
303 g++ now accepts the typename keyword, though it currently has no
304 semantics; it can be a no-op in the current template implementation.
305 You may want to start using it in your code, however, since the
306 pending rewrite of the template implementation to compile STL properly
307 (perhaps for 2.8.0, perhaps not) will require you to use it as
308 indicated by the current draft.
310 Handling of user-defined type conversion has been overhauled so that
311 type conversion operators are now found and used properly in
312 expressions and function calls.
314 -fno-strict-prototype now only applies to function declarations with
315 "C" linkage.
317 g++ now warns about 'if (x=0)' with -Wparentheses or -Wall.
319 #pragma weak and #pragma pack are supported on System V R4 targets, as
320 are various other target-specific #pragmas supported by gcc.
322 new and delete of const types is now allowed (with no additional
323 semantics).
325 Explicit instantiation of template methods is now supported.  Also,
326 'inline template class foo<int>;' can be used to emit only the vtable
327 for a template class.
329 With -fcheck-new, g++ will check the return value of all calls to
330 operator new, and not attempt to modify a returned null pointer.
332 The template instantiation code now handles more conversions when
333 passing to a parameter that does not depend on template arguments.
334 This means that code like 'string s; cout << s;' now works.
336 Invalid jumps in a switch statement past declarations that require
337 initializations are now caught.
339 Functions declared 'extern inline' now have the same linkage semantics
340 as inline member functions.  On supported targets, where previously
341 these functions (and vtables, and template instantiations) would have
342 been defined statically, they will now be defined as weak symbols so
343 that only one out-of-line definition is used.
345 collect2 now demangles linker output, and c++filt has become part of
346 the gcc distribution.
348 Noteworthy changes in GCC version 2.6.3:
350 A few more bugs have been fixed.
352 Noteworthy changes in GCC version 2.6.2:
354 A few bugs have been fixed.
356 Names of attributes can now be preceded and followed by double underscores.
358 Noteworthy changes in GCC version 2.6.1:
360 Numerous (mostly minor) bugs have been fixed.
362 The following new configurations are supported:
364         GNU on x86 (instead of treating it like MACH)
365         NetBSD on Sparc and Motorola 68k
366         AIX 4.1 on RS/6000 and PowerPC systems
367         Sequent DYNUX/ptx 1.x and 2.x.
368         Both COFF and ELF configurations on AViiON without using /bin/gcc
369         Windows/NT on x86 architecture; preliminary
370         AT&T DSP1610 digital signal processor chips
371         i960 systems on bare boards using COFF
372         PDP11; target only and not extensively tested
374 The -pg option is now supported for Alpha under OSF/1 V3.0 or later.
376 Files with an extension of ".c++" are treated as C++ code.
378 The -Xlinker and -Wl arguments are now passed to the linker in the
379 position they were specified on the command line.  This makes it
380 possible, for example, to pass flags to the linker about specific
381 object files.
383 The use of positional arguments to the configure script is no longer
384 recommended.  Use --target= to specify the target; see the GCC manual.
386 The 386 now supports two new switches: -mreg-alloc=<string> changes
387 the default register allocation order used by the compiler, and
388 -mno-wide-multiply disables the use of the mul/imul instructions that
389 produce 64 bit results in EAX:EDX from 32 bit operands to do long long
390 multiplies and 32-bit division by constants.
392 Noteworthy changes in GCC version 2.6.0:
394 Numerous bugs have been fixed, in the C and C++ front-ends, as
395 well as in the common compiler code.
397 This release includes the C, Objective-C, and C++ compilers.  However,
398 we have moved the files for the C++ compiler (G++) files to a
399 subdirectory, cp.  Subsequent releases of GCC will split these files
400 to a separate TAR file.
402 The G++ team has been tracking the development of the ANSI standard for C++.
403 Here are some new features added from the latest working paper:
405         * built-in boolean type 'bool', with constants 'true' and 'false'.
406         * array new and delete (operator new [] and delete []).
407         * WP-conforming lifetime of temporaries.
408         * explicit instantiation of templates (template class A<int>;),
409           along with an option (-fno-implicit-templates) to disable emission
410           of implicitly instantiated templates, obsoletes -fexternal-templates.
411         * static member constants (static const int foo = 4; within the
412           class declaration).
414 Many error messages have been improved to tell the user more about the
415 problem.  Conformance checking with -pedantic-errors has been
416 improved.  G++ now compiles Fresco.
418 There is now an experimental implementation of virtual functions using
419 thunks instead of Cfront-style vtables, enabled with -fvtable-thunks.
420 This option also enables a heuristic which causes the compiler to only
421 emit the vtable in the translation unit where its first non-inline
422 virtual function is defined; using this option and
423 -fno-implicit-templates, users should be able to avoid #pragma
424 interface/implementation altogether.
426 Signatures have been added as a GNU C++ extension.  Using the option
427 -fhandle-signatures, users are able to turn on recognition of
428 signatures.  A short introduction on signatures is in the section
429 `Extension to the C++ Language' in the manual.
431 The `g++' program is now a C program, rather than a shell script.
433 Lots and lots and lots of bugs fixes, in nested types, access control,
434 pointers to member functions, the parser, templates, overload
435 resolution, etc, etc.
437 There have been two major enhancements to the Objective-C compiler:
439 1) Added portability.  It now runs on Alpha, and some problems with
440    message forwarding have been addressed on other platforms.
442 2) Selectors have been redefined to be pointers to structs like:
443    { void *sel_id, char *sel_types }, where the sel_id is the unique
444    identifier, the selector itself is no longer unique.  
446    Programmers should use the new function sel_eq to test selector
447    equivalence.
449 The following major changes have been made to the base compiler and
450 machine-specific files.
452 - The MIL-STD-1750A is a new port, but still preliminary.
454 - The h8/300h is now supported; both the h8/300 and h8/300h ports come
455   with 32 bit IEEE 754 software floating point support.
457 - The 64-bit Sparc (v9) and 64-bit MIPS chips are supported.
459 - NetBSD is supported on m68k, Intel x86, and pc523 systems and FreeBSD
460   on x86.
462 - COFF is supported on x86, m68k, and Sparc systems running LynxOS.
464 - 68K systems from Bull and Concurrent are supported and System V
465   Release 4 is supported on the Atari.
467 - GCC supports GAS on the Motorola 3300 (sysV68) and debugging
468   (assuming GAS) on the Plexus 68K system.  (However, GAS does not yet
469   work on those systems).
471 - System V Release 4 is supported on MIPS (Tandem).
473 - For DG/UX, an ELF configuration is now supported, and both the ELF
474   and BCS configurations support ELF and COFF object file formats.
476 - OSF/1 V2.0 is supported on Alpha.
478 - Function profiling is also supported on Alpha.
480 - GAS and GDB is supported for Irix 5 (MIPS).
482 - "common mode" (code that will run on both POWER and PowerPC
483   architectures) is now supported for the RS/6000 family; the
484   compiler knows about more PPC chips.
486 - Both NeXTStep 2.1 and 3 are supported on 68k-based architectures.
488 - On the AMD 29k, the -msoft-float is now supported, as well as
489   -mno-sum-in-toc for RS/6000, -mapp-regs and -mflat for Sparc, and
490   -membedded-pic for MIPS.
492 - GCC can now convert division by integer constants into the equivalent
493   multiplication and shift operations when that is faster than the
494   division.
495         
496 - Two new warning options, -Wbad-function-cast and
497   -Wmissing-declarations have been added.
499 - Configurations may now add machine-specific __attribute__ options on
500   type; many machines support the `section' attribute.
502 - The -ffast-math flag permits some optimization that violate strict
503   IEEE rules, such as converting X * 0.0 to 0.0.
505 Noteworthy changes in GCC version 2.5.8:
507 This release only fixes a few serious bugs.  These include fixes for a
508 bug that prevented most programs from working on the RS/6000, a bug
509 that caused invalid assembler code for programs with a `switch'
510 statement on the NS32K, a G++ problem that caused undefined names in
511 some configurations, and several less serious problems, some of which
512 can affect most configuration.
514 Noteworthy change in GCC version 2.5.7:
516 This release only fixes a few bugs, one of which was causing bootstrap
517 compare errors on some systems.
519 Noteworthy change in GCC version 2.5.6:
521 A few backend bugs have been fixed, some of which only occur on one
522 machine.
524 The C++ compiler in 2.5.6 includes:
526  * fixes for some common crashes
527  * correct handling of nested types that are referenced as `foo::bar'
528  * spurious warnings about friends being declared static and never
529    defined should no longer appear
530  * enums that are local to a method in a class, or a class that's
531    local to a function, are now handled correctly.  For example:
532        class foo { void bar () { enum { x, y } E; x; } };
533        void bar () { class foo { enum { x, y } E; E baz; }; }
535 Noteworthy change in GCC version 2.5.5:
537 A large number of C++ bugs have been fixed.
539 The fixproto script adds prototypes conditionally on __cplusplus.
541 Noteworthy change in GCC version 2.5.4:
543 A bug fix in passing of structure arguments for the HP-PA architecture
544 makes code compiled with GCC 2.5.4 incompatible with code compiled
545 with earlier versions (if it passes struct arguments of 33 to 64 bits,
546 interspersed with other types of arguments).
548 Noteworthy change in gcc version 2.5.3:
550 The method of "mangling" C++ function names has been changed.  So you
551 must recompile all C++ programs completely when you start using GCC
552 2.5.  Also, GCC 2.5 requires libg++ version 2.5.  Earlier libg++
553 versions won't work with GCC 2.5.  (This is generally true--GCC
554 version M.N requires libg++ version M.N.)
556 Noteworthy GCC changes in version 2.5:
558 * There is now support for the IBM 370 architecture as a target.
559 Currently the only operating system supported is MVS; GCC does not run
560 on MVS, so you must produce .s files using GCC as a cross compiler,
561 then transfer them to MVS to assemble them.  This port is not reliable
562 yet.
564 * The Power PC is now supported.
566 * The i860-based Paragon machine is now supported.
568 * The Hitachi 3050 (an HP-PA machine) is now supported.
570 * The variable __GNUC_MINOR__ holds the minor version number of GCC, as
571 an integer.  For version 2.5.X, the value is 5.
573 * In C, initializers for static and global variables are now processed
574 an element at a time, so that they don't need a lot of storage.
576 * The C syntax for specifying which structure field comes next in an
577 initializer is now `.FIELDNAME='.  The corresponding syntax for
578 array initializers is now `[INDEX]='.  For example,
580   char whitespace[256]
581     = { [' '] = 1, ['\t'] = 1, ['\n'] = 1 };
583 This was changed to accord with the syntax proposed by the Numerical
584 C Extensions Group (NCEG).
586 * Complex numbers are now supported in C.  Use the keyword __complex__
587 to declare complex data types.  See the manual for details.
589 * GCC now supports `long double' meaningfully on the Sparc (128-bit
590 floating point) and on the 386 (96-bit floating point).  The Sparc
591 support is enabled on on Solaris 2.x because earlier system versions
592 (SunOS 4) have bugs in the emulation.
594 * All targets now have assertions for cpu, machine and system.  So you
595 can now use assertions to distinguish among all supported targets.
597 * Nested functions in C may now be inline.  Just declare them inline
598 in the usual way.
600 * Packed structure members are now supported fully; it should be possible 
601 to access them on any supported target, no matter how little alignment
602 they have.
604 * To declare that a function does not return, you must now write
605 something like this (works only in 2.5):
607     void fatal () __attribute__ ((noreturn));
609 or like this (works in older versions too):
611     typedef void voidfn ();
613     volatile voidfn fatal;
615 It used to be possible to do so by writing this:
617     volatile void fatal ();
619 but it turns out that ANSI C requires that to mean something
620 else (which is useless).
622 Likewise, to declare that a function is side-effect-free
623 so that calls may be deleted or combined, write
624 something like this (works only in 2.5):
626     int computation () __attribute__ ((const));
628 or like this (works in older versions too):
630     typedef int intfn ();
632     const intfn computation;
634 * The new option -iwithprefixbefore specifies a directory to add to 
635 the search path for include files in the same position where -I would
636 put it, but uses the specified prefix just like -iwithprefix.
638 * Basic block profiling has been enhanced to record the function the
639 basic block comes from, and if the module was compiled for debugging,
640 the line number and filename.  A default version of the basic block
641 support module has been added to libgcc2 that appends the basic block
642 information to a text file 'bb.out'.  Machine descriptions can now
643 override the basic block support module in the target macro file.
645 New features in g++:
647 * The new flag `-fansi-overloading' for C++.  Use a newly implemented
648 scheme of argument matching for C++.  It makes g++ more accurately
649 obey the rules set down in Chapter 13 of the Annotated C++ Reference
650 Manual (the ARM).  This option will be turned on by default in a
651 future release.
653 * The -finline-debug flag is now gone (it was never really used by the
654   compiler).
656 * Recognizing the syntax for pointers to members, e.g., "foo::*bar", has been
657   dramatically improved.  You should not get any syntax errors or incorrect
658   runtime results while using pointers to members correctly; if you do, it's
659   a definite bug.
661 * Forward declaration of an enum is now flagged as an error.
663 * Class-local typedefs are now working properly.
665 * Nested class support has been significantly improved.  The compiler
666   will now (in theory) support up to 240 nested classes before hitting
667   other system limits (like memory size).
669 * There is a new C version of the `g++' driver, to replace the old
670   shell script.  This should significantly improve the performance of
671   executing g++ on a system where a user's PATH environment variable
672   references many NFS-mounted filesystems.  This driver also works
673   under MS-DOS and OS/2.
675 * The ANSI committee working on the C++ standard has adopted a new
676   keyword `mutable'.  This will allow you to make a specific member be
677   modifiable in an otherwise const class.
679 Noteworthy GCC changes in version 2.4.4:
681   A crash building g++ on various hosts (including m68k) has been
682   fixed.  Also the g++ compiler no longer reports incorrect
683   ambiguities in some situations where they do not exist, and
684   const template member functions are now being found properly.
686 Noteworthy GCC changes in version 2.4:
688 * On each target, the default is now to return short structures
689 compatibly with the "usual" compiler on that target.
691 For most targets, this means the default is to return all structures
692 in memory, like long structures, in whatever way is used on that
693 target.  Use -freg-struct-return to enable returning short structures
694 (and unions) in registers.
696 This change means that newly compiled binaries are incompatible with
697 binaries compiled with previous versions of GCC.
699 On some targets, GCC is itself the usual compiler.  On these targets,
700 the default way to return short structures is still in registers.
701 Use -fpcc-struct-return to tell GCC to return them in memory.
703 * There is now a floating point emulator which can imitate the way all
704 supported target machines do floating point arithmetic.
706 This makes it possible to have cross compilation to and from the VAX,
707 and between machines of different endianness.  However, this works
708 only when the target machine description is updated to use the new
709 facilities, and not all have been updated.
711 This also makes possible support for longer floating point types.
712 GCC 2.4 supports extended format on the 68K if you use `long double',
713 for targets that have a 68881.  (When we have run time library
714 routines for extended floating point, then `long double' will use
715 extended format on all 68K targets.)
717 We expect to support extended floating point on the i386 and Sparc in
718 future versions.
720 * Building GCC now automatically fixes the system's header files.
721 This should require no attention.
723 * GCC now installs an unsigned data type as size_t when it fixes the
724 header files (on all but a handful of old target machines).
725 Therefore, the bug that size_t failed to be unsigned is fixed.
727 * Building and installation are now completely separate.
728 All new files are constructed during the build process; 
729 installation just copies them.
731 * New targets supported: Clipper, Hitachi SH, Hitachi 8300, and Sparc
732 Lite.
734 * A totally new and much better Objective C run time system is included.
736 * Objective C supports many new features.  Alas, I can't describe them
737 since I don't use that language; however, they are the same ones 
738 supported in recent versions of the NeXT operating system.
740 * The builtin functions __builtin_apply_args, __builtin_apply and
741 __builtin_return let you record the arguments and returned
742 value of a function without knowing their number or type.
744 * The builtin string variables __FUNCTION__ and __PRETTY_FUNCTION__
745 give the name of the function in the source, and a pretty-printed
746 version of the name.  The two are the same in C, but differ in C++.
748 * Casts to union types do not yield lvalues.
750 * ## before an empty rest argument discards the preceding sequence
751 of non-whitespace characters from the macro definition.
752 (This feature is subject to change.)
755 New features specific to C++:
757 * The manual contains a new section ``Common Misunderstandings with
758 GNU C++'' that C++ users should read.
760 * #pragma interface and #pragma implementation let you use the same
761 C++ source file for both interface and implementation.
762 However, this mechanism is still in transition.
764 * Named returned values let you avoid an extra constructor call
765 when a function result has a class type.
767 * The C++ operators <? and >? yield min and max, respectively.
769 * C++ gotos can exit a block safely even if the block has
770 aggregates that require destructors.
772 * gcc defines the macro __GNUG__ when compiling C++ programs.
774 * GNU C++ now correctly distinguishes between the prefix and postfix
775 forms of overloaded operator ++ and --.  To avoid breaking old
776 code, if a class defines only the prefix form, the compiler
777 accepts either ++obj or obj++, unless -pedantic is used.
779 * If you are using version 2.3 of libg++, you need to rebuild it with
780 `make CC=gcc' to avoid mismatches in the definition of `size_t'.
782 Newly documented compiler options:
784 -fnostartfiles
785         Omit the standard system startup files when linking.
787 -fvolatile-global
788         Consider memory references to extern and global data items to
789         be volatile.
791 -idirafter DIR
792         Add DIR to the second include path.
794 -iprefix PREFIX
795         Specify PREFIX for later -iwithprefix options.
797 -iwithprefix DIR
798         Add PREFIX/DIR to the second include path.
800 -mv8
801         Emit Sparc v8 code (with integer multiply and divide).
802 -msparclite
803         Emit Sparclite code (roughly v7.5).
805 -print-libgcc-file-name
806         Search for the libgcc.a file, print its absolute file name, and exit.
808 -Woverloaded-virtual
809         Warn when a derived class function declaration may be an error
810         in defining a C++ virtual function. 
812 -Wtemplate-debugging
813         When using templates in a C++ program, warn if debugging is
814         not yet fully available.
817         Control how C++ virtual function definitions are used
818         (like cfront 1.x).