blob: 1b4d5c563228d52caa8b4a46354deb966c251176 [file] [log] [blame]
Daniel Dunbarbf44c3b2010-11-05 07:19:31 +00001//===- CIndexer.h - Clang-C Source Indexing Library -------------*- C++ -*-===//
Ted Kremenekab188932010-01-05 19:32:54 +00002//
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// This file defines CIndexer, a subclass of Indexer that provides extra
11// functionality needed by the CIndex library.
12//
13//===----------------------------------------------------------------------===//
14
15#ifndef LLVM_CLANG_CINDEXER_H
16#define LLVM_CLANG_CINDEXER_H
17
18#include "clang-c/Index.h"
Douglas Gregorfc8ea232010-01-26 17:06:03 +000019#include "llvm/ADT/StringRef.h"
Michael J. Spencer03013fa2010-11-29 18:12:39 +000020#include "llvm/Support/Path.h"
Rafael Espindola34392372013-06-11 19:59:07 +000021#include "llvm/Support/PathV1.h"
Douglas Gregor4db64a42010-01-23 00:14:00 +000022#include <vector>
Ted Kremenekab188932010-01-05 19:32:54 +000023
Daniel Dunbarbf44c3b2010-11-05 07:19:31 +000024namespace llvm {
25 class CrashRecoveryContext;
26}
27
Argyrios Kyrtzidisbbca5642012-03-28 02:18:02 +000028namespace clang {
Argyrios Kyrtzidise722ed62012-04-11 02:11:16 +000029 class ASTUnit;
Argyrios Kyrtzidis664b06f2013-01-07 19:16:25 +000030 class MacroInfo;
31 class MacroDefinition;
32 class SourceLocation;
33 class Token;
34 class IdentifierInfo;
Argyrios Kyrtzidisbbca5642012-03-28 02:18:02 +000035
Douglas Gregora030b7c2010-01-22 20:35:53 +000036class CIndexer {
Ted Kremenekab188932010-01-05 19:32:54 +000037 bool OnlyLocalDecls;
Douglas Gregor0a812cf2010-02-18 23:07:20 +000038 bool DisplayDiagnostics;
Argyrios Kyrtzidisfdc17952012-03-28 02:18:05 +000039 unsigned Options; // CXGlobalOptFlags.
Douglas Gregor0a812cf2010-02-18 23:07:20 +000040
Benjamin Kramer082ad2b2013-06-13 13:56:37 +000041 std::string ResourcesPath;
Argyrios Kyrtzidis389db162010-11-03 22:45:23 +000042
Ted Kremenekab188932010-01-05 19:32:54 +000043public:
Argyrios Kyrtzidisfdc17952012-03-28 02:18:05 +000044 CIndexer() : OnlyLocalDecls(false), DisplayDiagnostics(false),
45 Options(CXGlobalOpt_None) { }
Ted Kremenekab188932010-01-05 19:32:54 +000046
Ted Kremenekab188932010-01-05 19:32:54 +000047 /// \brief Whether we only want to see "local" declarations (that did not
48 /// come from a previous precompiled header). If false, we want to see all
49 /// declarations.
50 bool getOnlyLocalDecls() const { return OnlyLocalDecls; }
51 void setOnlyLocalDecls(bool Local = true) { OnlyLocalDecls = Local; }
52
Douglas Gregor0a812cf2010-02-18 23:07:20 +000053 bool getDisplayDiagnostics() const { return DisplayDiagnostics; }
54 void setDisplayDiagnostics(bool Display = true) {
55 DisplayDiagnostics = Display;
56 }
57
Argyrios Kyrtzidisfdc17952012-03-28 02:18:05 +000058 unsigned getCXGlobalOptFlags() const { return Options; }
59 void setCXGlobalOptFlags(unsigned options) { Options = options; }
60
61 bool isOptEnabled(CXGlobalOptFlags opt) const {
Argyrios Kyrtzidisf962eb42012-03-28 20:42:59 +000062 return Options & opt;
Argyrios Kyrtzidisfdc17952012-03-28 02:18:05 +000063 }
64
Ted Kremenekab188932010-01-05 19:32:54 +000065 /// \brief Get the path of the clang resource files.
Benjamin Kramer082ad2b2013-06-13 13:56:37 +000066 const std::string &getClangResourcesPath();
Ted Kremenekab188932010-01-05 19:32:54 +000067};
68
Douglas Gregor4db64a42010-01-23 00:14:00 +000069 /**
70 * \brief Given a set of "unsaved" files, create temporary files and
71 * construct the clang -cc1 argument list needed to perform the remapping.
72 *
73 * \returns true if an error occurred.
74 */
75 bool RemapFiles(unsigned num_unsaved_files,
76 struct CXUnsavedFile *unsaved_files,
77 std::vector<std::string> &RemapArgs,
78 std::vector<llvm::sys::Path> &TemporaryFiles);
Daniel Dunbarbf44c3b2010-11-05 07:19:31 +000079
80 /// \brief Return the current size to request for "safety".
81 unsigned GetSafetyThreadStackSize();
82
83 /// \brief Set the current size to request for "safety" (or 0, if safety
84 /// threads should not be used).
85 void SetSafetyThreadStackSize(unsigned Value);
86
87 /// \brief Execution the given code "safely", using crash recovery or safety
88 /// threads when possible.
89 ///
90 /// \return False if a crash was detected.
91 bool RunSafely(llvm::CrashRecoveryContext &CRC,
Ted Kremenek6c53fdd2010-11-14 17:47:35 +000092 void (*Fn)(void*), void *UserData, unsigned Size = 0);
Douglas Gregor6df78732011-05-05 20:27:22 +000093
Argyrios Kyrtzidisfdc17952012-03-28 02:18:05 +000094 /// \brief Set the thread priority to background.
95 /// FIXME: Move to llvm/Support.
Argyrios Kyrtzidis81b5ac32012-03-28 02:49:54 +000096 void setThreadBackgroundPriority();
Argyrios Kyrtzidisfdc17952012-03-28 02:18:05 +000097
Douglas Gregor6df78732011-05-05 20:27:22 +000098 /// \brief Print libclang's resource usage to standard error.
99 void PrintLibclangResourceUsage(CXTranslationUnit TU);
Argyrios Kyrtzidise722ed62012-04-11 02:11:16 +0000100
101 namespace cxindex {
102 void printDiagsToStderr(ASTUnit *Unit);
Argyrios Kyrtzidis664b06f2013-01-07 19:16:25 +0000103
104 /// \brief If \c MacroDefLoc points at a macro definition with \c II as
105 /// its name, this retrieves its MacroInfo.
106 MacroInfo *getMacroInfo(const IdentifierInfo &II,
107 SourceLocation MacroDefLoc,
108 CXTranslationUnit TU);
109
110 /// \brief Retrieves the corresponding MacroInfo of a MacroDefinition.
Dmitri Gribenko67812b22013-01-11 21:01:49 +0000111 const MacroInfo *getMacroInfo(const MacroDefinition *MacroDef,
112 CXTranslationUnit TU);
Argyrios Kyrtzidis664b06f2013-01-07 19:16:25 +0000113
114 /// \brief If \c Loc resides inside the definition of \c MI and it points at
115 /// an identifier that has ever been a macro name, this returns the latest
116 /// MacroDefinition for that name, otherwise it returns NULL.
117 MacroDefinition *checkForMacroInMacroDefinition(const MacroInfo *MI,
118 SourceLocation Loc,
119 CXTranslationUnit TU);
120
121 /// \brief If \c Tok resides inside the definition of \c MI and it points at
122 /// an identifier that has ever been a macro name, this returns the latest
123 /// MacroDefinition for that name, otherwise it returns NULL.
124 MacroDefinition *checkForMacroInMacroDefinition(const MacroInfo *MI,
125 const Token &Tok,
126 CXTranslationUnit TU);
Argyrios Kyrtzidise722ed62012-04-11 02:11:16 +0000127 }
Douglas Gregor4db64a42010-01-23 00:14:00 +0000128}
129
Ted Kremenekab188932010-01-05 19:32:54 +0000130#endif