summaryrefslogtreecommitdiffstats
path: root/lib/Driver/ToolChains.h
blob: be476d78ed6c8bcdf1abd2d716aa52b0d8d25ab9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
//===--- ToolChains.h - ToolChain Implementations ---------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

#ifndef CLANG_LIB_DRIVER_TOOLCHAINS_H_
#define CLANG_LIB_DRIVER_TOOLCHAINS_H_

#include "clang/Driver/Action.h"
#include "clang/Driver/ToolChain.h"

#include "llvm/ADT/DenseMap.h"
#include "llvm/Support/Compiler.h"

#include "Tools.h"

namespace clang {
namespace driver {
namespace toolchains VISIBILITY_HIDDEN {

  /// Generic_GCC - A tool chain using the 'gcc' command to perform
  /// all subcommands; this relies on gcc translating the majority of
  /// command line options.
class Generic_GCC : public ToolChain {
  mutable llvm::DenseMap<unsigned, Tool*> Tools;

public:
  Generic_GCC(const HostInfo &Host, const char *Arch, const char *Platform, 
              const char *OS) : ToolChain(Host, Arch, Platform, OS) {}

  virtual ArgList *TranslateArgs(ArgList &Args) const { return &Args; }

  virtual Tool &SelectTool(const Compilation &C, const JobAction &JA) const {
    Action::ActionClass Key;
    if (ShouldUseClangCompiler(C, JA))
      Key = Action::AnalyzeJobClass;
    else
      Key = JA.getKind();

    Tool *&T = Tools[Key];
    if (!T) {
      switch (Key) {
      default:
        assert(0 && "Invalid tool kind.");
      case Action::PreprocessJobClass: 
        T = new tools::GCC_Preprocess(*this); break;
      case Action::PrecompileJobClass: 
        T = new tools::GCC_Precompile(*this); break;
      case Action::AnalyzeJobClass: 
        T = new tools::Clang(*this); break;
      case Action::CompileJobClass: 
        T = new tools::GCC_Compile(*this); break;
      case Action::AssembleJobClass: 
        T = new tools::GCC_Assemble(*this); break;
      case Action::LinkJobClass: 
        T = new tools::GCC_Assemble(*this); break;
      }
    }

    return *T;
  }

  virtual bool IsMathErrnoDefault() const { return true; }

  virtual bool IsUnwindTablesDefault() const { 
    // FIXME: Gross; we should probably have some separate target definition,
    // possibly even reusing the one in clang.
    return getArchName() == "x86_64";
  }

  virtual const char *GetDefaultRelocationModel() const {
    return "static";
  }

  virtual const char *GetForcedPicModel() const {
    return 0;
  }
};

} // end namespace toolchains
} // end namespace driver
} // end namespace clang

#endif