blob: 76edf150dbeee8915b1f0382463f2046ddb8cff3 [file] [log] [blame]
//===- DependencyScanningService.h - clang-scan-deps service ===-*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_CLANG_TOOLING_DEPENDENCY_SCANNING_SERVICE_H
#define LLVM_CLANG_TOOLING_DEPENDENCY_SCANNING_SERVICE_H
#include "clang/Tooling/DependencyScanning/DependencyScanningFilesystem.h"
namespace clang {
namespace tooling {
namespace dependencies {
/// The mode in which the dependency scanner will operate to find the
/// dependencies.
enum class ScanningMode {
/// This mode is used to compute the dependencies by running the preprocessor
/// over
/// the unmodified source files.
CanonicalPreprocessing,
/// This mode is used to compute the dependencies by running the preprocessor
/// over
/// the source files that have been minimized to contents that might affect
/// the dependencies.
MinimizedSourcePreprocessing
};
/// The format that is output by the dependency scanner.
enum class ScanningOutputFormat {
/// This is the Makefile compatible dep format. This will include all of the
/// deps necessary for an implicit modules build, but won't include any
/// intermodule dependency information.
Make,
/// This outputs the full module dependency graph suitable for use for
/// explicitly building modules.
Full,
};
/// The dependency scanning service contains the shared state that is used by
/// the invidual dependency scanning workers.
class DependencyScanningService {
public:
DependencyScanningService(ScanningMode Mode, ScanningOutputFormat Format,
bool ReuseFileManager = true,
bool SkipExcludedPPRanges = true);
ScanningMode getMode() const { return Mode; }
ScanningOutputFormat getFormat() const { return Format; }
bool canReuseFileManager() const { return ReuseFileManager; }
bool canSkipExcludedPPRanges() const { return SkipExcludedPPRanges; }
DependencyScanningFilesystemSharedCache &getSharedCache() {
return SharedCache;
}
private:
const ScanningMode Mode;
const ScanningOutputFormat Format;
const bool ReuseFileManager;
/// Set to true to use the preprocessor optimization that skips excluded PP
/// ranges by bumping the buffer pointer in the lexer instead of lexing the
/// tokens in the range until reaching the corresponding directive.
const bool SkipExcludedPPRanges;
/// The global file system cache.
DependencyScanningFilesystemSharedCache SharedCache;
};
} // end namespace dependencies
} // end namespace tooling
} // end namespace clang
#endif // LLVM_CLANG_TOOLING_DEPENDENCY_SCANNING_SERVICE_H