clang 23.0.0git
PreprocessorOptions.h
Go to the documentation of this file.
1//===- PreprocessorOptions.h ------------------------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLVM_CLANG_LEX_PREPROCESSOROPTIONS_H_
10#define LLVM_CLANG_LEX_PREPROCESSOROPTIONS_H_
11
14#include "clang/Basic/LLVM.h"
16#include "llvm/ADT/StringRef.h"
17#include "llvm/ADT/StringSet.h"
18#include <functional>
19#include <map>
20#include <memory>
21#include <optional>
22#include <set>
23#include <string>
24#include <utility>
25#include <vector>
26
27namespace llvm {
28
29class MemoryBuffer;
30
31} // namespace llvm
32
33namespace clang {
34
35/// Enumerate the kinds of standard library that
38
39 /// libc++
41
42 /// libstdc++
44};
45
46/// How to initialize the date/time macros.
48 /// Set to the current date and time.
50
51 /// Set to literal string "1".
53
54 /// Keep undefined.
56};
57
58/// Whether to disable the normal validation performed on precompiled
59/// headers and module files when they are loaded.
61 /// Perform validation, don't disable it.
62 None = 0,
63
64 /// Disable validation for a precompiled header and the modules it depends on.
65 PCH = 0x1,
66
67 /// Disable validation for module files.
68 Module = 0x2,
69
70 /// Disable validation for all kinds.
72
74};
75
76/// PreprocessorOptions - This class is used for passing the various options
77/// used in preprocessor initialization to InitializePreprocessor().
79public:
80 std::vector<std::pair<std::string, bool/*isUndef*/>> Macros;
81 std::vector<std::string> Includes;
82 std::vector<std::string> MacroIncludes;
83
84 /// Perform extra checks when loading PCM files for mutable file systems.
86
87 /// Initialize the preprocessor with the compiler and target specific
88 /// predefines.
89 bool UsePredefines = true;
90
91 /// Indicates whether to predefine target OS macros.
93
94 /// Whether we should maintain a detailed record of all macro
95 /// definitions and expansions.
96 bool DetailedRecord = false;
97
98 /// When true, we are creating or using a PCH where a #pragma hdrstop is
99 /// expected to indicate the beginning or end of the PCH.
100 bool PCHWithHdrStop = false;
101
102 /// When true, we are creating a PCH or creating the PCH object while
103 /// expecting a #pragma hdrstop to separate the two. Allow for a
104 /// missing #pragma hdrstop, which generates a PCH for the whole file,
105 /// and creates an empty PCH object.
107
108 /// If non-empty, the filename used in an #include directive in the primary
109 /// source file (or command-line preinclude) that is used to implement
110 /// MSVC-style precompiled headers. When creating a PCH, after the #include
111 /// of this header, the PCH generation stops. When using a PCH, tokens are
112 /// skipped until after an #include of this header is seen.
113 std::string PCHThroughHeader;
114
115 /// The implicit PCH included at the start of the translation unit, or empty.
117
118 /// Headers that will be converted to chained PCHs in memory.
119 std::vector<std::string> ChainedIncludes;
120
121 /// Whether to disable most of the normal validation performed on
122 /// precompiled headers and module files.
125
126 /// When true, a PCH with compiler errors will not be rejected.
128
129 /// When true, a PCH with modules cache path different to the current
130 /// compilation will not be rejected.
132
133 /// Dump declarations that are deserialized from PCH, for testing.
135
136 /// This is a set of names for decls that we do not want to be
137 /// deserialized, and we emit an error if they are; for testing purposes.
138 std::set<std::string> DeserializedPCHDeclsToErrorOn;
139
140 /// If non-zero, the implicit PCH include is actually a precompiled
141 /// preamble that covers this number of bytes in the main source file.
142 ///
143 /// The boolean indicates whether the preamble ends at the start of a new
144 /// line.
145 std::pair<unsigned, bool> PrecompiledPreambleBytes;
146
147 /// True indicates that a preamble is being generated.
148 ///
149 /// When the lexer is done, one of the things that need to be preserved is the
150 /// conditional #if stack, so the ASTWriter/ASTReader can save/restore it when
151 /// processing the rest of the file. Similarly, we track an unterminated
152 /// #pragma assume_nonnull.
153 bool GeneratePreamble = false;
154
155 /// Whether to write comment locations into the PCH when building it.
156 /// Reading the comments from the PCH can be a performance hit even if the
157 /// clients don't use them.
159
160 /// When enabled, preprocessor is in a mode for parsing a single file only.
161 ///
162 /// Disables #includes of other files and if there are unresolved identifiers
163 /// in preprocessor directive conditions it causes all blocks to be parsed so
164 /// that the client can get the maximum amount of information from the parser.
166
167 /// When enabled, preprocessor is in a mode for parsing a single module only.
168 ///
169 /// Disables imports of other modules and if there are any unresolved
170 /// identifiers in preprocessor directive conditions it causes all blocks to
171 /// be skipped so that the client can get a strict subset of the contents.
173
174 /// When enabled, the preprocessor will construct editor placeholder tokens.
176
177 /// True if the SourceManager should report the original file name for
178 /// contents of files that were remapped to other files. Defaults to true.
180
181 /// The set of file remappings, which take existing files on
182 /// the system (the first part of each pair) and gives them the
183 /// contents of other files on the system (the second part of each
184 /// pair).
185 std::vector<std::pair<std::string, std::string>> RemappedFiles;
186
187 /// The set of file-to-buffer remappings, which take existing files
188 /// on the system (the first part of each pair) and gives them the contents
189 /// of the specified memory buffer (the second part of each pair).
190 std::vector<std::pair<std::string, llvm::MemoryBuffer *>> RemappedFileBuffers;
191
192 /// User specified embed entries.
193 std::vector<std::string> EmbedEntries;
194
195 /// Whether the compiler instance should retain (i.e., not free)
196 /// the buffers associated with remapped files.
197 ///
198 /// This flag defaults to false; it can be set true only through direct
199 /// manipulation of the compiler invocation object, in cases where the
200 /// compiler invocation and its buffers will be reused.
202
203 /// When enabled, excluded conditional blocks retain in the main file.
205
206 /// The Objective-C++ ARC standard library that we should support,
207 /// by providing appropriate definitions to retrofit the standard library
208 /// with support for lifetime-qualified pointers.
210
211 /// Set up preprocessor for RunAnalysis action.
213
214 /// Prevents intended crashes when using #pragma clang __debug. For testing.
216
217 /// If set, the UNIX timestamp specified by SOURCE_DATE_EPOCH.
218 std::optional<uint64_t> SourceDateEpoch;
219
220 /// The initial value for __COUNTER__; typically is zero but can be set via a
221 /// -cc1 flag for testing purposes.
223
224 /// Specify initialization kind for __DATE__, __TIME__ and __TIMESTAMP__
225 /// macros.
227
228public:
230
231 void addMacroDef(StringRef Name) {
232 Macros.emplace_back(std::string(Name), false);
233 }
234 void addMacroUndef(StringRef Name) {
235 Macros.emplace_back(std::string(Name), true);
236 }
237
238 void addRemappedFile(StringRef From, StringRef To) {
239 RemappedFiles.emplace_back(std::string(From), std::string(To));
240 }
241
242 void addRemappedFile(StringRef From, llvm::MemoryBuffer *To) {
243 RemappedFileBuffers.emplace_back(std::string(From), To);
244 }
245
247 RemappedFiles.clear();
248 RemappedFileBuffers.clear();
249 }
250
251 /// Reset any options that are not considered when building a
252 /// module.
254 Includes.clear();
255 MacroIncludes.clear();
256 ChainedIncludes.clear();
258 ImplicitPCHInclude.clear();
259 SingleFileParseMode = false;
262 PrecompiledPreambleBytes.first = 0;
263 PrecompiledPreambleBytes.second = false;
265 }
266};
267
268} // namespace clang
269
270#endif // LLVM_CLANG_LEX_PREPROCESSOROPTIONS_H_
Provides LLVM's BitmaskEnum facility to enumeration types declared in namespace clang.
This is the interface for scanning header and source files to get the minimum necessary preprocessor ...
Defines interfaces for clang::FileEntry and clang::FileEntryRef.
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
Describes a module or submodule.
Definition Module.h:340
std::vector< std::pair< std::string, std::string > > RemappedFiles
The set of file remappings, which take existing files on the system (the first part of each pair) and...
bool PCHWithHdrStopCreate
When true, we are creating a PCH or creating the PCH object while expecting a pragma hdrstop to separ...
bool DisablePragmaDebugCrash
Prevents intended crashes when using pragma clang __debug. For testing.
std::vector< std::string > MacroIncludes
std::vector< std::string > Includes
std::pair< unsigned, bool > PrecompiledPreambleBytes
If non-zero, the implicit PCH include is actually a precompiled preamble that covers this number of b...
bool WriteCommentListToPCH
Whether to write comment locations into the PCH when building it.
bool RemappedFilesKeepOriginalName
True if the SourceManager should report the original file name for contents of files that were remapp...
bool LexEditorPlaceholders
When enabled, the preprocessor will construct editor placeholder tokens.
uint32_t InitialCounterValue
The initial value for COUNTER; typically is zero but can be set via a -cc1 flag for testing purposes.
DateTimeInitKind InitDateTimeMacros
Specify initialization kind for DATE, TIME and TIMESTAMP macros.
void resetNonModularOptions()
Reset any options that are not considered when building a module.
bool RetainRemappedFileBuffers
Whether the compiler instance should retain (i.e., not free) the buffers associated with remapped fil...
ObjCXXARCStandardLibraryKind ObjCXXARCStandardLibrary
The Objective-C++ ARC standard library that we should support, by providing appropriate definitions t...
bool ModulesCheckRelocated
Perform extra checks when loading PCM files for mutable file systems.
void addMacroUndef(StringRef Name)
std::string PCHThroughHeader
If non-empty, the filename used in an include directive in the primary source file (or command-line p...
std::set< std::string > DeserializedPCHDeclsToErrorOn
This is a set of names for decls that we do not want to be deserialized, and we emit an error if they...
std::vector< std::string > EmbedEntries
User specified embed entries.
bool SingleFileParseMode
When enabled, preprocessor is in a mode for parsing a single file only.
void addMacroDef(StringRef Name)
bool DefineTargetOSMacros
Indicates whether to predefine target OS macros.
bool DetailedRecord
Whether we should maintain a detailed record of all macro definitions and expansions.
void addRemappedFile(StringRef From, llvm::MemoryBuffer *To)
std::vector< std::string > ChainedIncludes
Headers that will be converted to chained PCHs in memory.
bool RetainExcludedConditionalBlocks
When enabled, excluded conditional blocks retain in the main file.
bool PCHWithHdrStop
When true, we are creating or using a PCH where a pragma hdrstop is expected to indicate the beginnin...
std::string ImplicitPCHInclude
The implicit PCH included at the start of the translation unit, or empty.
DisableValidationForModuleKind DisablePCHOrModuleValidation
Whether to disable most of the normal validation performed on precompiled headers and module files.
bool AllowPCHWithDifferentModulesCachePath
When true, a PCH with modules cache path different to the current compilation will not be rejected.
bool SingleModuleParseMode
When enabled, preprocessor is in a mode for parsing a single module only.
bool DumpDeserializedPCHDecls
Dump declarations that are deserialized from PCH, for testing.
std::optional< uint64_t > SourceDateEpoch
If set, the UNIX timestamp specified by SOURCE_DATE_EPOCH.
bool UsePredefines
Initialize the preprocessor with the compiler and target specific predefines.
void addRemappedFile(StringRef From, StringRef To)
bool SetUpStaticAnalyzer
Set up preprocessor for RunAnalysis action.
std::vector< std::pair< std::string, bool > > Macros
bool GeneratePreamble
True indicates that a preamble is being generated.
bool AllowPCHWithCompilerErrors
When true, a PCH with compiler errors will not be rejected.
std::vector< std::pair< std::string, llvm::MemoryBuffer * > > RemappedFileBuffers
The set of file-to-buffer remappings, which take existing files on the system (the first part of each...
The JSON file list parser is used to communicate input to InstallAPI.
ObjCXXARCStandardLibraryKind
Enumerate the kinds of standard library that.
@ ARCXX_libcxx
libc++
@ ARCXX_libstdcxx
libstdc++
DateTimeInitKind
How to initialize the date/time macros.
@ Default
Set to the current date and time.
@ Undefined
Keep undefined.
@ LiteralOne
Set to literal string "1".
DisableValidationForModuleKind
Whether to disable the normal validation performed on precompiled headers and module files when they ...
@ None
Perform validation, don't disable it.
@ PCH
Disable validation for a precompiled header and the modules it depends on.
@ None
The alignment was not explicit in code.
Definition ASTContext.h:176
Diagnostic wrappers for TextAPI types for error reporting.
Definition Dominators.h:30
__packed_splat4 __packed_splat2 __packed_splat8 __packed_splat4 __packed_splat2 __packed_splat4 __packed_splat2 __packed_splat8 __packed_splat4 uint32_t
#define false
Definition stdbool.h:26