CIndexer.h revision 03013fa9a0bf1ef4b907f5fec006c8f4000fdd21
1bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar//===- CIndexer.h - Clang-C Source Indexing Library -------------*- C++ -*-===//
2ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//
3ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//                     The LLVM Compiler Infrastructure
4ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//
5ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek// This file is distributed under the University of Illinois Open Source
6ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek// License. See LICENSE.TXT for details.
7ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//
8ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//===----------------------------------------------------------------------===//
9ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//
10ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek// This file defines CIndexer, a subclass of Indexer that provides extra
11ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek// functionality needed by the CIndex library.
12ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//
13ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek//===----------------------------------------------------------------------===//
14ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek
15ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek#ifndef LLVM_CLANG_CINDEXER_H
16ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek#define LLVM_CLANG_CINDEXER_H
17ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek
18ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek#include "clang-c/Index.h"
19fc8ea23eb6cbaaa5046f2abb4c033e24c8659efdDouglas Gregor#include "llvm/ADT/StringRef.h"
2003013fa9a0bf1ef4b907f5fec006c8f4000fdd21Michael J. Spencer#include "llvm/Support/Path.h"
214db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor#include <vector>
22ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek
23bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbarnamespace llvm {
24bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  class CrashRecoveryContext;
25bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar}
26bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar
27a030b7cf5e6aad5889b1b662b6979840bc75f87fDouglas Gregorclass CIndexer {
28ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  bool OnlyLocalDecls;
290a812cf707da15dadd19fdeb0178b9707f4e01a6Douglas Gregor  bool DisplayDiagnostics;
300a812cf707da15dadd19fdeb0178b9707f4e01a6Douglas Gregor
31d1e6fdb4c5325c61fedfa62751f70ee373880a52Douglas Gregor  llvm::sys::Path ResourcesPath;
32389db16c63eec6ecfa9b235155252d8da766e94eArgyrios Kyrtzidis  std::string WorkingDir;
33389db16c63eec6ecfa9b235155252d8da766e94eArgyrios Kyrtzidis
34ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenekpublic:
35b10daedb8fc4c6f70a66dbc1a6eea01684bb4e77Douglas Gregor CIndexer() : OnlyLocalDecls(false), DisplayDiagnostics(false) { }
36ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek
37ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  /// \brief Whether we only want to see "local" declarations (that did not
38ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  /// come from a previous precompiled header). If false, we want to see all
39ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  /// declarations.
40ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  bool getOnlyLocalDecls() const { return OnlyLocalDecls; }
41ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  void setOnlyLocalDecls(bool Local = true) { OnlyLocalDecls = Local; }
42ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek
430a812cf707da15dadd19fdeb0178b9707f4e01a6Douglas Gregor  bool getDisplayDiagnostics() const { return DisplayDiagnostics; }
440a812cf707da15dadd19fdeb0178b9707f4e01a6Douglas Gregor  void setDisplayDiagnostics(bool Display = true) {
450a812cf707da15dadd19fdeb0178b9707f4e01a6Douglas Gregor    DisplayDiagnostics = Display;
460a812cf707da15dadd19fdeb0178b9707f4e01a6Douglas Gregor  }
470a812cf707da15dadd19fdeb0178b9707f4e01a6Douglas Gregor
48ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  /// \brief Get the path of the clang resource files.
49ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek  std::string getClangResourcesPath();
50389db16c63eec6ecfa9b235155252d8da766e94eArgyrios Kyrtzidis
51389db16c63eec6ecfa9b235155252d8da766e94eArgyrios Kyrtzidis  const std::string &getWorkingDirectory() const { return WorkingDir; }
52389db16c63eec6ecfa9b235155252d8da766e94eArgyrios Kyrtzidis  void setWorkingDirectory(const std::string &Dir) { WorkingDir = Dir; }
53ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek};
54ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek
554db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregornamespace clang {
564db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor  /**
574db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor   * \brief Given a set of "unsaved" files, create temporary files and
584db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor   * construct the clang -cc1 argument list needed to perform the remapping.
594db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor   *
604db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor   * \returns true if an error occurred.
614db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor   */
624db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor  bool RemapFiles(unsigned num_unsaved_files,
634db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor                  struct CXUnsavedFile *unsaved_files,
644db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor                  std::vector<std::string> &RemapArgs,
654db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor                  std::vector<llvm::sys::Path> &TemporaryFiles);
66bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar
67bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  /// \brief Return the current size to request for "safety".
68bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  unsigned GetSafetyThreadStackSize();
69bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar
70bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  /// \brief Set the current size to request for "safety" (or 0, if safety
71bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  /// threads should not be used).
72bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  void SetSafetyThreadStackSize(unsigned Value);
73bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar
74bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  /// \brief Execution the given code "safely", using crash recovery or safety
75bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  /// threads when possible.
76bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  ///
77bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  /// \return False if a crash was detected.
78bf44c3b099602c9c967f1b20995919fb4ef39a51Daniel Dunbar  bool RunSafely(llvm::CrashRecoveryContext &CRC,
796c53fdd88f0d75875365463822fa817d7b1a9573Ted Kremenek                 void (*Fn)(void*), void *UserData, unsigned Size = 0);
804db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor}
814db64a461cb3442934afe43c83ed3f17f7c11c1dDouglas Gregor
82ab1889321f6f8f200f2b318ac26883ac18e49d03Ted Kremenek#endif
83