From patchwork Sat Jan 7 22:59:53 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sandra Loosemore X-Patchwork-Id: 90293 Delivered-To: patch@linaro.org Received: by 10.140.20.101 with SMTP id 92csp265673qgi; Sat, 7 Jan 2017 15:00:31 -0800 (PST) X-Received: by 10.84.217.66 with SMTP id e2mr163340060plj.109.1483830031612; Sat, 07 Jan 2017 15:00:31 -0800 (PST) Return-Path: Received: from sourceware.org (server1.sourceware.org. [209.132.180.131]) by mx.google.com with ESMTPS id j191si59201369pgd.157.2017.01.07.15.00.31 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sat, 07 Jan 2017 15:00:31 -0800 (PST) Received-SPF: pass (google.com: domain of gcc-patches-return-445622-patch=linaro.org@gcc.gnu.org designates 209.132.180.131 as permitted sender) client-ip=209.132.180.131; Authentication-Results: mx.google.com; dkim=pass header.i=@gcc.gnu.org; spf=pass (google.com: domain of gcc-patches-return-445622-patch=linaro.org@gcc.gnu.org designates 209.132.180.131 as permitted sender) smtp.mailfrom=gcc-patches-return-445622-patch=linaro.org@gcc.gnu.org DomainKey-Signature: a=rsa-sha1; c=nofws; d=gcc.gnu.org; h=list-id :list-unsubscribe:list-archive:list-post:list-help:sender:to :from:subject:message-id:date:mime-version:content-type; q=dns; s=default; b=ufzRtS0k+zUJyZpXXI7A+/w18JVrdqssC45Rd0wnMl7Zbz0TjF E+TKXFtCqSmpanPjg8iLEmKsa9xL62o9YaV21faaWQ+rGZKquAiX3yJYH8BO3rFf PjERxjBLXCeLR3ywlvduzYVerqttROESTO89c2iQnaK14IBMka4qQeNg8= DKIM-Signature: v=1; a=rsa-sha1; c=relaxed; d=gcc.gnu.org; h=list-id :list-unsubscribe:list-archive:list-post:list-help:sender:to :from:subject:message-id:date:mime-version:content-type; s= default; bh=x9MYZJwnPKHWqCkc/1XF6uzJd4s=; b=cwbsJbKBVtkMuBsy/lJ4 K2liqCi57wOIPx0PwxwWopwCT6cL7l4BG0pIHlUdpZiM8Kp0jl26zoxY7/FFGRtq SbWOgPyUw5bnYhk7OJzxbnTAoy0w56tfsyswnpH2vT5sIQ3UPKNsJWrAoWpH2xm3 yWUfad0CI2V1EtI2j08e+ho= Received: (qmail 31893 invoked by alias); 7 Jan 2017 23:00:18 -0000 Mailing-List: contact gcc-patches-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Unsubscribe: List-Archive: List-Post: List-Help: Sender: gcc-patches-owner@gcc.gnu.org Delivered-To: mailing list gcc-patches@gcc.gnu.org Received: (qmail 31868 invoked by uid 89); 7 Jan 2017 23:00:17 -0000 Authentication-Results: sourceware.org; auth=none X-Virus-Found: No X-Spam-SWARE-Status: No, score=-0.0 required=5.0 tests=AWL, BAYES_00, RCVD_IN_DNSWL_NONE, SPF_PASS, UNSUBSCRIBE_BODY, URIBL_RED autolearn=no version=3.3.2 spammy=loosemore, Loosemore, informative, U*sandra X-HELO: relay1.mentorg.com Received: from relay1.mentorg.com (HELO relay1.mentorg.com) (192.94.38.131) by sourceware.org (qpsmtpd/0.93/v0.84-503-g423c35a) with ESMTP; Sat, 07 Jan 2017 22:59:59 +0000 Received: from svr-orw-mbx-03.mgc.mentorg.com ([147.34.90.203]) by relay1.mentorg.com with esmtp id 1cPzxt-0003rT-2e from Sandra_Loosemore@mentor.com for gcc-patches@gcc.gnu.org; Sat, 07 Jan 2017 14:59:57 -0800 Received: from [127.0.0.1] (147.34.91.1) by svr-orw-mbx-03.mgc.mentorg.com (147.34.90.203) with Microsoft SMTP Server (TLS) id 15.0.1210.3; Sat, 7 Jan 2017 14:59:54 -0800 To: "gcc-patches@gcc.gnu.org" From: Sandra Loosemore Subject: [doc, committed] clean up include search path documentation in cpp.texi Message-ID: <587172E9.5050409@codesourcery.com> Date: Sat, 7 Jan 2017 15:59:53 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.5.1 MIME-Version: 1.0 X-ClientProxiedBy: svr-orw-mbx-01.mgc.mentorg.com (147.34.90.201) To svr-orw-mbx-03.mgc.mentorg.com (147.34.90.203) I've checked in this patch to modernize the tutorial information about the preprocessor search path in cpp.texi -- in particular, removing the discussion of the deprecated -I- option, better integrating information about the preferred replacement -iquote and -system options into the flow, and removing some other redundant or obsolete bits. There's also been PR 13498 open since 2003 to report other inaccurate information in this section, so I've addressed those problems here as well. It's kind of bad that we've been providing incorrect documentation for 13+ years. :-( Since it's clear maintaining this manual is a low priority, I've generally gone with the approach of not providing too many details in the tutorial material and instead pointing people at the relevant command-line options. -Sandra Index: gcc/doc/cpp.texi =================================================================== --- gcc/doc/cpp.texi (revision 244106) +++ gcc/doc/cpp.texi (working copy) @@ -837,74 +837,49 @@ final newline. @node Search Path @section Search Path -GCC looks in several different places for headers. On a normal Unix -system, if you do not instruct it otherwise, it will look for headers -requested with @code{@w{#include <@var{file}>}} in: - -@smallexample -/usr/local/include -@var{libdir}/gcc/@var{target}/@var{version}/include -/usr/@var{target}/include -/usr/include -@end smallexample - -For C++ programs, it will also look in -@file{@var{libdir}/../include/c++/@var{version}}, -first. In the above, @var{target} is the canonical name of the system -GCC was configured to compile code for; often but not always the same as -the canonical name of the system it runs on. @var{version} is the -version of GCC in use. - -You can add to this list with the @option{-I@var{dir}} command-line -option. All the directories named by @option{-I} are searched, in -left-to-right order, @emph{before} the default directories. The only -exception is when @file{dir} is already searched by default. In -this case, the option is ignored and the search order for system -directories remains unchanged. - -Duplicate directories are removed from the quote and bracket search -chains before the two chains are merged to make the final search chain. -Thus, it is possible for a directory to occur twice in the final search -chain if it was specified in both the quote and bracket chains. - -You can prevent GCC from searching any of the default directories with -the @option{-nostdinc} option. This is useful when you are compiling an -operating system kernel or some other program that does not use the -standard C library facilities, or the standard C library itself. -@option{-I} options are not ignored as described above when -@option{-nostdinc} is in effect. - -GCC looks for headers requested with @code{@w{#include "@var{file}"}} -first in the directory containing the current file, then in the -directories as specified by @option{-iquote} options, then in the same -places it would have looked for a header requested with angle -brackets. For example, if @file{/usr/include/sys/stat.h} contains +By default, the preprocessor looks for header files included by the quote +form of the directive @code{@w{#include "@var{file}"}} first relative to +the directory of the current file, and then in a preconfigured list +of standard system directories. +For example, if @file{/usr/include/sys/stat.h} contains @code{@w{#include "types.h"}}, GCC looks for @file{types.h} first in @file{/usr/include/sys}, then in its usual search path. -@samp{#line} (@pxref{Line Control}) does not change GCC's idea of the -directory containing the current file. +For the angle-bracket form @code{@w{#include <@var{file}>}}, the +preprocessor's default behavior is to look only in the standard system +directories. The exact search directory list depends on the target +system, how GCC is configured, and where it is installed. You can +find the default search directory list for your version of CPP by +invoking it with the @option{-v} option. For example, -You may put @option{-I-} at any point in your list of @option{-I} options. -This has two effects. First, directories appearing before the -@option{-I-} in the list are searched only for headers requested with -quote marks. Directories after @option{-I-} are searched for all -headers. Second, the directory containing the current file is not -searched for anything, unless it happens to be one of the directories -named by an @option{-I} switch. @option{-I-} is deprecated, @option{-iquote} -should be used instead. - -@option{-I. -I-} is not the same as no @option{-I} options at all, and does -not cause the same behavior for @samp{<>} includes that @samp{""} -includes get with no special options. @option{-I.} searches the -compiler's current working directory for header files. That may or may -not be the same as the directory containing the current file. - -If you need to look for headers in a directory named @file{-}, write -@option{-I./-}. +@smallexample +cpp -v /dev/null -o /dev/null +@end smallexample -There are several more ways to adjust the header search path. They are -generally less useful. @xref{Invocation}. +There are a number of command-line options you can use to add +additional directories to the search path. +The most commonly-used option is @option{-I@var{dir}}, which causes +@var{dir} to be searched after the current directory (for the quote +form of the directive) and ahead of the standard system directories. +You can specify multiple @option{-I} options on the command line, +in which case the directories are searched in left-to-right order. + +If you need separate control over the search paths for the quote and +angle-bracket forms of the @samp{#include} directive, you can use the +@option{-iquote} and/or @option{-isystem} options instead of @option{-I}. +@xref{Invocation}, for a detailed description of these options, as +well as others that are less generally useful. + +If you specify other options on the command line, such as @option{-I}, +that affect where the preprocessor searches for header files, the +directory list printed by the @option{-v} option reflects the actual +search path used by the preprocessor. + +Note that you can also prevent the preprocessor from searching any of +the default system header directories with the @option{-nostdinc} +option. This is useful when you are compiling an operating system +kernel or some other program that does not use the standard C library +facilities, or the standard C library itself. @node Once-Only Headers @section Once-Only Headers @@ -1142,30 +1117,22 @@ because of code in macros defined in sys Normally, only the headers found in specific directories are considered system headers. These directories are determined when GCC is compiled. -There are, however, two ways to make normal headers into system headers. +There are, however, two ways to make normal headers into system headers: -The @option{-isystem} command-line option adds its argument to the list of -directories to search for headers, just like @option{-I}. Any headers -found in that directory will be considered system headers. - -All directories named by @option{-isystem} are searched @emph{after} all -directories named by @option{-I}, no matter what their order was on the -command line. If the same directory is named by both @option{-I} and -@option{-isystem}, the @option{-I} option is ignored. GCC provides an -informative message when this occurs if @option{-v} is used. +@itemize @bullet +@item +Header files found in directories added to the search path with the +@option{-isystem} and @option{-idirafter} command-line options are +treated as system headers for the purposes of diagnostics. +@item @findex #pragma GCC system_header There is also a directive, @code{@w{#pragma GCC system_header}}, which tells GCC to consider the rest of the current include file a system header, no matter where it was found. Code that comes before the -@samp{#pragma} in the file will not be affected. @code{@w{#pragma GCC +@samp{#pragma} in the file is not affected. @code{@w{#pragma GCC system_header}} has no effect in the primary source file. - -On very old systems, some of the pre-defined system header directories -get even more special treatment. GNU C++ considers code in headers -found in those directories to be surrounded by an @code{@w{extern "C"}} -block. There is no way to request this behavior with a @samp{#pragma}, -or from the command line. +@end itemize @node Macros @chapter Macros