blob: fa8e233fcddf8073e383285e570bde15b08c72f3 [file] [log] [blame]
Daniel Dunbarfb36cae2009-03-04 22:37:52 +00001//===--- 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 "clang/Driver/Arg.h"
Daniel Dunbar06482622009-03-05 06:38:47 +000011#include "clang/Driver/ArgList.h"
Daniel Dunbarf781c412009-03-04 23:02:50 +000012#include "clang/Driver/Option.h"
13#include "llvm/Support/raw_ostream.h"
Daniel Dunbarfb36cae2009-03-04 22:37:52 +000014
15using namespace clang::driver;
16
17Arg::Arg(ArgClass _Kind, const Option *_Opt, unsigned _Index)
18 : Kind(_Kind),
19 Opt(_Opt),
Daniel Dunbar6d91b042009-03-18 02:57:50 +000020 Index(_Index),
21 Claimed(false)
Daniel Dunbarfb36cae2009-03-04 22:37:52 +000022{
23}
24
25Arg::~Arg() { }
26
Daniel Dunbarf781c412009-03-04 23:02:50 +000027void Arg::dump() const {
28 llvm::errs() << "<";
29 switch (Kind) {
30 default:
31 assert(0 && "Invalid kind");
32#define P(N) case N: llvm::errs() << #N; break
Daniel Dunbar06482622009-03-05 06:38:47 +000033 P(FlagClass);
Daniel Dunbarf781c412009-03-04 23:02:50 +000034 P(PositionalClass);
35 P(JoinedClass);
36 P(SeparateClass);
37 P(CommaJoinedClass);
38 P(JoinedAndSeparateClass);
39#undef P
40 }
41
42 llvm::errs() << " Opt:";
43 Opt->dump();
44
45 llvm::errs() << " Index:" << Index;
46
Daniel Dunbarbbf842b2009-03-04 23:22:02 +000047 if (isa<CommaJoinedArg>(this) || isa<SeparateArg>(this))
48 llvm::errs() << " NumValues:" << getNumValues();
Daniel Dunbarf781c412009-03-04 23:02:50 +000049
50 llvm::errs() << ">\n";
Daniel Dunbarf781c412009-03-04 23:02:50 +000051}
52
Daniel Dunbar06482622009-03-05 06:38:47 +000053FlagArg::FlagArg(const Option *Opt, unsigned Index)
54 : Arg(FlagClass, Opt, Index) {
55}
56
57void FlagArg::render(const ArgList &Args, ArgStringList &Output) const {
Daniel Dunbar21fd6ac2009-03-18 08:01:48 +000058 Output.push_back(Args.getArgString(getIndex()));
Daniel Dunbar06482622009-03-05 06:38:47 +000059}
60
61const char *FlagArg::getValue(const ArgList &Args, unsigned N) const {
62 assert(0 && "Invalid index.");
63 return 0;
64}
65
Daniel Dunbarfb36cae2009-03-04 22:37:52 +000066PositionalArg::PositionalArg(const Option *Opt, unsigned Index)
67 : Arg(PositionalClass, Opt, Index) {
68}
69
70void PositionalArg::render(const ArgList &Args, ArgStringList &Output) const {
Daniel Dunbar21fd6ac2009-03-18 08:01:48 +000071 Output.push_back(Args.getArgString(getIndex()));
Daniel Dunbarfb36cae2009-03-04 22:37:52 +000072}
73
74const char *PositionalArg::getValue(const ArgList &Args, unsigned N) const {
Daniel Dunbar06482622009-03-05 06:38:47 +000075 assert(N < getNumValues() && "Invalid index.");
76 return Args.getArgString(getIndex());
Daniel Dunbarfb36cae2009-03-04 22:37:52 +000077}
78
79JoinedArg::JoinedArg(const Option *Opt, unsigned Index)
80 : Arg(JoinedClass, Opt, Index) {
81}
82
83void JoinedArg::render(const ArgList &Args, ArgStringList &Output) const {
Daniel Dunbar21fd6ac2009-03-18 08:01:48 +000084 if (getOption().hasForceSeparateRender()) {
85 Output.push_back(getOption().getName());
86 Output.push_back(getValue(Args, 0));
87 } else {
88 Output.push_back(Args.getArgString(getIndex()));
89 }
Daniel Dunbarfb36cae2009-03-04 22:37:52 +000090}
91
92const char *JoinedArg::getValue(const ArgList &Args, unsigned N) const {
Daniel Dunbar06482622009-03-05 06:38:47 +000093 assert(N < getNumValues() && "Invalid index.");
94 // FIXME: Avoid strlen.
95 return Args.getArgString(getIndex()) + strlen(getOption().getName());
Daniel Dunbarfb36cae2009-03-04 22:37:52 +000096}
97
98CommaJoinedArg::CommaJoinedArg(const Option *Opt, unsigned Index,
Daniel Dunbar06482622009-03-05 06:38:47 +000099 const char *Str)
100 : Arg(CommaJoinedClass, Opt, Index) {
101 const char *Prev = Str;
102 for (;; ++Str) {
103 char c = *Str;
104
105 if (!c) {
106 if (Prev != Str)
107 Values.push_back(std::string(Prev, Str));
108 break;
109 } else if (c == ',') {
110 if (Prev != Str)
111 Values.push_back(std::string(Prev, Str));
112 Prev = Str + 1;
113 }
114 }
Daniel Dunbarfb36cae2009-03-04 22:37:52 +0000115}
116
117void CommaJoinedArg::render(const ArgList &Args, ArgStringList &Output) const {
Daniel Dunbar21fd6ac2009-03-18 08:01:48 +0000118 Output.push_back(Args.getArgString(getIndex()));
Daniel Dunbarfb36cae2009-03-04 22:37:52 +0000119}
120
121const char *CommaJoinedArg::getValue(const ArgList &Args, unsigned N) const {
Daniel Dunbar06482622009-03-05 06:38:47 +0000122 assert(N < getNumValues() && "Invalid index.");
123 return Values[N].c_str();
Daniel Dunbarfb36cae2009-03-04 22:37:52 +0000124}
125
Daniel Dunbarf781c412009-03-04 23:02:50 +0000126SeparateArg::SeparateArg(const Option *Opt, unsigned Index, unsigned _NumValues)
127 : Arg(SeparateClass, Opt, Index), NumValues(_NumValues) {
128}
129
130void SeparateArg::render(const ArgList &Args, ArgStringList &Output) const {
Daniel Dunbar21fd6ac2009-03-18 08:01:48 +0000131 if (getOption().hasForceJoinedRender()) {
132 assert(getNumValues() == 1 && "Cannot force joined render with > 1 args.");
133 // FIXME: Avoid std::string.
134 std::string Joined(getOption().getName());
135 Joined += Args.getArgString(getIndex());
136 Output.push_back(Args.MakeArgString(Joined.c_str()));
137 } else {
138 Output.push_back(Args.getArgString(getIndex()));
139 for (unsigned i = 0; i < NumValues; ++i)
140 Output.push_back(Args.getArgString(getIndex() + 1 + i));
141 }
Daniel Dunbarf781c412009-03-04 23:02:50 +0000142}
143
144const char *SeparateArg::getValue(const ArgList &Args, unsigned N) const {
Daniel Dunbar06482622009-03-05 06:38:47 +0000145 assert(N < getNumValues() && "Invalid index.");
146 return Args.getArgString(getIndex() + 1 + N);
Daniel Dunbarf781c412009-03-04 23:02:50 +0000147}
148
Daniel Dunbarfb36cae2009-03-04 22:37:52 +0000149JoinedAndSeparateArg::JoinedAndSeparateArg(const Option *Opt, unsigned Index)
150 : Arg(JoinedAndSeparateClass, Opt, Index) {
151}
152
153void JoinedAndSeparateArg::render(const ArgList &Args,
154 ArgStringList &Output) const {
Daniel Dunbar21fd6ac2009-03-18 08:01:48 +0000155 Output.push_back(Args.getArgString(getIndex()));
156 Output.push_back(Args.getArgString(getIndex()) + 1);
Daniel Dunbarfb36cae2009-03-04 22:37:52 +0000157}
158
159const char *JoinedAndSeparateArg::getValue(const ArgList &Args,
160 unsigned N) const {
Daniel Dunbar06482622009-03-05 06:38:47 +0000161 assert(N < getNumValues() && "Invalid index.");
Daniel Dunbarec29d362009-03-18 01:48:37 +0000162 if (N == 0)
163 return Args.getArgString(getIndex()) + strlen(getOption().getName());
164 return Args.getArgString(getIndex() + 1);
Daniel Dunbarfb36cae2009-03-04 22:37:52 +0000165}