30a69229737cdf4ed30b8b39beba18f1e564d5ae
[oota-llvm.git] / lib / Option / Arg.cpp
1 //===--- Arg.cpp - Argument Implementations -------------------------------===//
2 //
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 #include "llvm/Option/Arg.h"
11 #include "llvm/ADT/SmallString.h"
12 #include "llvm/ADT/Twine.h"
13 #include "llvm/Option/ArgList.h"
14 #include "llvm/Option/Option.h"
15 #include "llvm/Support/raw_ostream.h"
16
17 using namespace llvm;
18 using namespace llvm::opt;
19
20 Arg::Arg(const Option _Opt, StringRef S, unsigned _Index, const Arg *_BaseArg)
21   : Opt(_Opt), BaseArg(_BaseArg), Spelling(S), Index(_Index),
22     Claimed(false), OwnsValues(false) {
23 }
24
25 Arg::Arg(const Option _Opt, StringRef S, unsigned _Index,
26          const char *Value0, const Arg *_BaseArg)
27   : Opt(_Opt), BaseArg(_BaseArg), Spelling(S), Index(_Index),
28     Claimed(false), OwnsValues(false) {
29   Values.push_back(Value0);
30 }
31
32 Arg::Arg(const Option _Opt, StringRef S, unsigned _Index,
33          const char *Value0, const char *Value1, const Arg *_BaseArg)
34   : Opt(_Opt), BaseArg(_BaseArg), Spelling(S), Index(_Index),
35     Claimed(false), OwnsValues(false) {
36   Values.push_back(Value0);
37   Values.push_back(Value1);
38 }
39
40 Arg::~Arg() {
41   if (OwnsValues) {
42     for (unsigned i = 0, e = Values.size(); i != e; ++i)
43       delete[] Values[i];
44   }
45 }
46
47 void Arg::dump() const {
48   llvm::errs() << "<";
49
50   llvm::errs() << " Opt:";
51   Opt.dump();
52
53   llvm::errs() << " Index:" << Index;
54
55   llvm::errs() << " Values: [";
56   for (unsigned i = 0, e = Values.size(); i != e; ++i) {
57     if (i) llvm::errs() << ", ";
58     llvm::errs() << "'" << Values[i] << "'";
59   }
60
61   llvm::errs() << "]>\n";
62 }
63
64 std::string Arg::getAsString(const ArgList &Args) const {
65   small_string_ostream<256> OS;
66
67   ArgStringList ASL;
68   render(Args, ASL);
69   for (ArgStringList::iterator
70          it = ASL.begin(), ie = ASL.end(); it != ie; ++it) {
71     if (it != ASL.begin())
72       OS << ' ';
73     OS << *it;
74   }
75
76   return OS.str();
77 }
78
79 void Arg::renderAsInput(const ArgList &Args, ArgStringList &Output) const {
80   if (!getOption().hasNoOptAsInput()) {
81     render(Args, Output);
82     return;
83   }
84
85   for (unsigned i = 0, e = getNumValues(); i != e; ++i)
86     Output.push_back(getValue(i));
87 }
88
89 void Arg::render(const ArgList &Args, ArgStringList &Output) const {
90   switch (getOption().getRenderStyle()) {
91   case Option::RenderValuesStyle:
92     for (unsigned i = 0, e = getNumValues(); i != e; ++i)
93       Output.push_back(getValue(i));
94     break;
95
96   case Option::RenderCommaJoinedStyle: {
97     small_string_ostream<256> OS;
98     OS << getSpelling();
99     for (unsigned i = 0, e = getNumValues(); i != e; ++i) {
100       if (i) OS << ',';
101       OS << getValue(i);
102     }
103     Output.push_back(Args.MakeArgString(OS.str()));
104     break;
105   }
106
107  case Option::RenderJoinedStyle:
108     Output.push_back(Args.GetOrMakeJoinedArgString(
109                        getIndex(), getSpelling(), getValue(0)));
110     for (unsigned i = 1, e = getNumValues(); i != e; ++i)
111       Output.push_back(getValue(i));
112     break;
113
114   case Option::RenderSeparateStyle:
115     Output.push_back(Args.MakeArgString(getSpelling()));
116     for (unsigned i = 0, e = getNumValues(); i != e; ++i)
117       Output.push_back(getValue(i));
118     break;
119   }
120 }