Warning: That file was not part of the compilation database. It may have many parsing errors.

1//===--- Types.h - Input & Temporary Driver Types ---------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#ifndef LLVM_CLANG_DRIVER_TYPES_H
11#define LLVM_CLANG_DRIVER_TYPES_H
12
13#include "clang/Driver/Phases.h"
14#include "llvm/ADT/SmallVector.h"
15
16namespace llvm {
17class StringRef;
18}
19namespace clang {
20namespace driver {
21namespace types {
22 enum ID {
23 TY_INVALID,
24#define TYPE(NAME, ID, PP_TYPE, TEMP_SUFFIX, FLAGS) TY_##ID,
25#include "clang/Driver/Types.def"
26#undef TYPE
27 TY_LAST
28 };
29
30 /// getTypeName - Return the name of the type for \p Id.
31 const char *getTypeName(ID Id);
32
33 /// getPreprocessedType - Get the ID of the type for this input when
34 /// it has been preprocessed, or INVALID if this input is not
35 /// preprocessed.
36 ID getPreprocessedType(ID Id);
37
38 /// getPrecompiledType - Get the ID of the type for this input when
39 /// it has been precompiled, or INVALID if this input is not
40 /// precompiled.
41 ID getPrecompiledType(ID Id);
42
43 /// getTypeTempSuffix - Return the suffix to use when creating a
44 /// temp file of this type, or null if unspecified.
45 const char *getTypeTempSuffix(ID Id, bool CLMode = false);
46
47 /// onlyAssembleType - Should this type only be assembled.
48 bool onlyAssembleType(ID Id);
49
50 /// onlyPrecompileType - Should this type only be precompiled.
51 bool onlyPrecompileType(ID Id);
52
53 /// canTypeBeUserSpecified - Can this type be specified on the
54 /// command line (by the type name); this is used when forwarding
55 /// commands to gcc.
56 bool canTypeBeUserSpecified(ID Id);
57
58 /// appendSuffixForType - When generating outputs of this type,
59 /// should the suffix be appended (instead of replacing the existing
60 /// suffix).
61 bool appendSuffixForType(ID Id);
62
63 /// canLipoType - Is this type acceptable as the output of a
64 /// universal build (currently, just the Nothing, Image, and Object
65 /// types).
66 bool canLipoType(ID Id);
67
68 /// isAcceptedByClang - Can clang handle this input type.
69 bool isAcceptedByClang(ID Id);
70
71 /// isCXX - Is this a "C++" input (C++ and Obj-C++ sources and headers).
72 bool isCXX(ID Id);
73
74 /// Is this LLVM IR.
75 bool isLLVMIR(ID Id);
76
77 /// isCuda - Is this a CUDA input.
78 bool isCuda(ID Id);
79
80 /// isHIP - Is this a HIP input.
81 bool isHIP(ID Id);
82
83 /// isObjC - Is this an "ObjC" input (Obj-C and Obj-C++ sources and headers).
84 bool isObjC(ID Id);
85
86 /// isSrcFile - Is this a source file, i.e. something that still has to be
87 /// preprocessed. The logic behind this is the same that decides if the first
88 /// compilation phase is a preprocessing one.
89 bool isSrcFile(ID Id);
90
91 /// lookupTypeForExtension - Lookup the type to use for the file
92 /// extension \p Ext.
93 ID lookupTypeForExtension(llvm::StringRef Ext);
94
95 /// lookupTypeForTypSpecifier - Lookup the type to use for a user
96 /// specified type name.
97 ID lookupTypeForTypeSpecifier(const char *Name);
98
99 /// getCompilationPhases - Get the list of compilation phases ('Phases') to be
100 /// done for type 'Id'.
101 void getCompilationPhases(
102 ID Id,
103 llvm::SmallVectorImpl<phases::ID> &Phases);
104
105 /// lookupCXXTypeForCType - Lookup CXX input type that corresponds to given
106 /// C type (used for clang++ emulation of g++ behaviour)
107 ID lookupCXXTypeForCType(ID Id);
108
109 /// Lookup header file input type that corresponds to given
110 /// source file type (used for clang-cl emulation of \Yc).
111 ID lookupHeaderTypeForSourceType(ID Id);
112
113} // end namespace types
114} // end namespace driver
115} // end namespace clang
116
117#endif
118

Warning: That file was not part of the compilation database. It may have many parsing errors.