\input texinfo @c -*-texinfo-*- @c %**start of header @setfilename gcc.info @c INTERNALS is used by md.texi to determine whether to include the @c whole of that file, in the internals manual, or only the part @c dealing with constraints, in the user manual. @clear INTERNALS @c NOTE: checks/things to do: @c @c -have bob do a search in all seven files for "mew" (ideally --mew, @c but i may have forgotten the occasional "--"..). @c Just checked... all have `--'! Bob 22Jul96 @c Use this to search: grep -n '\-\-mew' *.texi @c -item/itemx, text after all (sub/sub)section titles, etc.. @c -consider putting the lists of options on pp 17--> etc in columns or @c some such. @c -overfulls. do a search for "mew" in the files, and you will see @c overfulls that i noted but could not deal with. @c -have to add text: beginning of chapter 8 @c @c anything else? --mew 10feb93 @include gcc-common.texi @settitle Using the GNU Compiler Collection (GCC) @c Create a separate index for command line options. @defcodeindex op @c Merge the standard indexes into a single one. @syncodeindex fn cp @syncodeindex vr cp @syncodeindex ky cp @syncodeindex pg cp @syncodeindex tp cp @paragraphindent 1 @c %**end of header @copying Copyright @copyright{} 1988-2020 Free Software Foundation, Inc. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.3 or any later version published by the Free Software Foundation; with the Invariant Sections being ``Funding Free Software'', the Front-Cover Texts being (a) (see below), and with the Back-Cover Texts being (b) (see below). A copy of the license is included in the section entitled ``GNU Free Documentation License''. (a) The FSF's Front-Cover Text is: A GNU Manual (b) The FSF's Back-Cover Text is: You have freedom to copy and modify this GNU Manual, like GNU software. Copies published by the Free Software Foundation raise funds for GNU development. @end copying @ifnottex @dircategory Software development @direntry * gcc: (gcc). The GNU Compiler Collection. * g++: (gcc). The GNU C++ compiler. * gcov: (gcc) Gcov. @command{gcov}---a test coverage program. * gcov-tool: (gcc) Gcov-tool. @command{gcov-tool}---an offline gcda profile processing program. * gcov-dump: (gcc) Gcov-dump. @command{gcov-dump}---an offline gcda and gcno profile dump tool. * lto-dump: (gcc) lto-dump. @command{lto-dump}---Tool for dumping LTO object files. @end direntry This file documents the use of the GNU compilers. @sp 1 @insertcopying @sp 1 @end ifnottex @setchapternewpage odd @titlepage @title Using the GNU Compiler Collection @versionsubtitle @author Richard M. Stallman and the @sc{GCC} Developer Community @page @vskip 0pt plus 1filll Published by: @multitable @columnfractions 0.5 0.5 @item GNU Press @tab Website: @uref{http://www.gnupress.org} @item a division of the @tab General: @email{press@@gnu.org} @item Free Software Foundation @tab Orders: @email{sales@@gnu.org} @item 51 Franklin Street, Fifth Floor @tab Tel 617-542-5942 @item Boston, MA 02110-1301 USA @tab Fax 617-542-2652 @end multitable @sp 2 @ifset FSFPRINT @c Update this ISBN when printing a new edition. @acronym{ISBN} 1-882114-39-6 Cover art by Gary M. Torrisi. Cover design by Jonathan Richard. @end ifset @ifclear FSFPRINT Last printed October 2003 for GCC 3.3.1.@* Printed copies are available for $45 each. @end ifclear @sp 1 @insertcopying @end titlepage @summarycontents @contents @page @node Top, G++ and GCC @top Introduction @cindex introduction This manual documents how to use the GNU compilers, as well as their features and incompatibilities, and how to report bugs. It corresponds to the compilers @ifset VERSION_PACKAGE @value{VERSION_PACKAGE} @end ifset version @value{version-GCC}. The internals of the GNU compilers, including how to port them to new targets and some information about how to write front ends for new languages, are documented in a separate manual. @xref{Top,, Introduction, gccint, GNU Compiler Collection (GCC) Internals}. @menu * G++ and GCC:: You can compile C or C++ programs. * Standards:: Language standards supported by GCC. * Invoking GCC:: Command options supported by @samp{gcc}. * C Implementation:: How GCC implements the ISO C specification. * C++ Implementation:: How GCC implements the ISO C++ specification. * C Extensions:: GNU extensions to the C language family. * C++ Extensions:: GNU extensions to the C++ language. * Objective-C:: GNU Objective-C runtime features. * Compatibility:: Binary Compatibility * Gcov:: @command{gcov}---a test coverage program. * Gcov-tool:: @command{gcov-tool}---an offline gcda profile processing program. * Gcov-dump:: @command{gcov-dump}---an offline gcda and gcno profile dump tool. * lto-dump:: @command{lto-dump}---Tool for dumping LTO object files. * Trouble:: If you have trouble using GCC. * Bugs:: How, why and where to report bugs. * Service:: How To Get Help with GCC * Contributing:: How to contribute to testing and developing GCC. * Funding:: How to help assure funding for free software. * GNU Project:: The GNU Project and GNU/Linux. * Copying:: GNU General Public License says how you can copy and share GCC. * GNU Free Documentation License:: How you can copy and share this manual. * Contributors:: People who have contributed to GCC. * Option Index:: Index to command line options. * Keyword Index:: Index of concepts and symbol names. @end menu @include frontends.texi @include standards.texi @include invoke.texi @include implement-c.texi @include implement-cxx.texi @include extend.texi @include objc.texi @include compat.texi @include gcov.texi @include gcov-tool.texi @include gcov-dump.texi @include lto-dump.texi @include trouble.texi @include bugreport.texi @include service.texi @include contribute.texi @include funding.texi @include gnu.texi @include gpl_v3.texi @c --------------------------------------------------------------------- @c GFDL @c --------------------------------------------------------------------- @include fdl.texi @include contrib.texi @c --------------------------------------------------------------------- @c Indexes @c --------------------------------------------------------------------- @node Option Index @unnumbered Option Index GCC's command line options are indexed here without any initial @samp{-} or @samp{--}. Where an option has both positive and negative forms (such as @option{-f@var{option}} and @option{-fno-@var{option}}), relevant entries in the manual are indexed under the most appropriate form; it may sometimes be useful to look up both forms. @printindex op @node Keyword Index @unnumbered Keyword Index @printindex cp @c --------------------------------------------------------------------- @c Epilogue @c --------------------------------------------------------------------- @bye