Clang Project

clang_source_code/lib/Frontend/ASTMerge.cpp
1//===-- ASTMerge.cpp - AST Merging Frontend Action --------------*- 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#include "clang/Frontend/ASTUnit.h"
9#include "clang/AST/ASTContext.h"
10#include "clang/AST/ASTDiagnostic.h"
11#include "clang/AST/ASTImporter.h"
12#include "clang/AST/ASTImporterLookupTable.h"
13#include "clang/Basic/Diagnostic.h"
14#include "clang/Frontend/CompilerInstance.h"
15#include "clang/Frontend/FrontendActions.h"
16
17using namespace clang;
18
19std::unique_ptr<ASTConsumer>
20ASTMergeAction::CreateASTConsumer(CompilerInstance &CIStringRef InFile) {
21  return AdaptedAction->CreateASTConsumer(CI, InFile);
22}
23
24bool ASTMergeAction::BeginSourceFileAction(CompilerInstance &CI) {
25  // FIXME: This is a hack. We need a better way to communicate the
26  // AST file, compiler instance, and file name than member variables
27  // of FrontendAction.
28  AdaptedAction->setCurrentInput(getCurrentInput(), takeCurrentASTUnit());
29  AdaptedAction->setCompilerInstance(&CI);
30  return AdaptedAction->BeginSourceFileAction(CI);
31}
32
33void ASTMergeAction::ExecuteAction() {
34  CompilerInstance &CI = getCompilerInstance();
35  CI.getDiagnostics().getClient()->BeginSourceFile(
36                                             CI.getASTContext().getLangOpts());
37  CI.getDiagnostics().SetArgToStringFn(&FormatASTNodeDiagnosticArgument,
38                                       &CI.getASTContext());
39  IntrusiveRefCntPtr<DiagnosticIDs>
40      DiagIDs(CI.getDiagnostics().getDiagnosticIDs());
41  ASTImporterLookupTable LookupTable(
42      *CI.getASTContext().getTranslationUnitDecl());
43  for (unsigned I = 0N = ASTFiles.size(); I != N; ++I) {
44    IntrusiveRefCntPtr<DiagnosticsEngine>
45        Diags(new DiagnosticsEngine(DiagIDs, &CI.getDiagnosticOpts(),
46                                    new ForwardingDiagnosticConsumer(
47                                          *CI.getDiagnostics().getClient()),
48                                    /*ShouldOwnClient=*/true));
49    std::unique_ptr<ASTUnitUnit = ASTUnit::LoadFromASTFile(
50        ASTFiles[I], CI.getPCHContainerReader(), ASTUnit::LoadEverything, Diags,
51        CI.getFileSystemOpts(), false);
52
53    if (!Unit)
54      continue;
55
56    ASTImporter Importer(CI.getASTContext(), CI.getFileManager(),
57                         Unit->getASTContext(), Unit->getFileManager(),
58                         /*MinimalImport=*/false, &LookupTable);
59
60    TranslationUnitDecl *TU = Unit->getASTContext().getTranslationUnitDecl();
61    for (auto *D : TU->decls()) {
62      // Don't re-import __va_list_tag, __builtin_va_list.
63      if (const auto *ND = dyn_cast<NamedDecl>(D))
64        if (IdentifierInfo *II = ND->getIdentifier())
65          if (II->isStr("__va_list_tag") || II->isStr("__builtin_va_list"))
66            continue;
67
68      Decl *ToD = Importer.Import(D);
69
70      if (ToD) {
71        DeclGroupRef DGR(ToD);
72        CI.getASTConsumer().HandleTopLevelDecl(DGR);
73      }
74    }
75  }
76
77  AdaptedAction->ExecuteAction();
78  CI.getDiagnostics().getClient()->EndSourceFile();
79}
80
81void ASTMergeAction::EndSourceFileAction() {
82  return AdaptedAction->EndSourceFileAction();
83}
84
85ASTMergeAction::ASTMergeAction(std::unique_ptr<FrontendActionadaptedAction,
86                               ArrayRef<std::stringASTFiles)
87AdaptedAction(std::move(adaptedAction)), ASTFiles(ASTFiles.begin(), ASTFiles.end()) {
88   (0) . __assert_fail ("AdaptedAction && \"ASTMergeAction needs an action to adapt\"", "/home/seafit/code_projects/clang_source/clang/lib/Frontend/ASTMerge.cpp", 88, __PRETTY_FUNCTION__))" file_link="../../../include/assert.h.html#88" macro="true">assert(AdaptedAction && "ASTMergeAction needs an action to adapt");
89}
90
91ASTMergeAction::~ASTMergeAction() {
92}
93
94bool ASTMergeAction::usesPreprocessorOnly() const {
95  return AdaptedAction->usesPreprocessorOnly();
96}
97
98TranslationUnitKind ASTMergeAction::getTranslationUnitKind() {
99  return AdaptedAction->getTranslationUnitKind();
100}
101
102bool ASTMergeAction::hasPCHSupport() const {
103  return AdaptedAction->hasPCHSupport();
104}
105
106bool ASTMergeAction::hasASTFileSupport() const {
107  return AdaptedAction->hasASTFileSupport();
108}
109
110bool ASTMergeAction::hasCodeCompletionSupport() const {
111  return AdaptedAction->hasCodeCompletionSupport();
112}
113
clang::ASTMergeAction::CreateASTConsumer
clang::ASTMergeAction::BeginSourceFileAction
clang::ASTMergeAction::ExecuteAction
clang::ASTMergeAction::EndSourceFileAction
clang::ASTMergeAction::usesPreprocessorOnly
clang::ASTMergeAction::getTranslationUnitKind
clang::ASTMergeAction::hasPCHSupport
clang::ASTMergeAction::hasASTFileSupport
clang::ASTMergeAction::hasCodeCompletionSupport