blob: d21dc4f7fd13f7df93df04103a177f9d41fe5f67 [file] [log] [blame]
Shinichiro Hamaji1d545aa2015-06-23 15:29:13 +09001// Copyright 2015 Google Inc. All rights reserved
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Fumitoshi Ukai744bb2b2015-06-25 00:10:52 +090015// +build ignore
16
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090017#include "var.h"
18
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090019#include "expr.h"
Shinichiro Hamaji4c469b32015-06-15 19:53:36 +090020#include "log.h"
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090021
22UndefinedVar kUndefinedBuf;
23UndefinedVar* kUndefined = &kUndefinedBuf;
24
Shinichiro Hamajif62e9a72015-06-26 04:18:21 +090025const char* GetOriginStr(VarOrigin origin) {
26 switch (origin) {
27 case VarOrigin::UNDEFINED: return "undefined";
28 case VarOrigin::DEFAULT: return "default";
29 case VarOrigin::ENVIRONMENT: return "environment";
30 case VarOrigin::ENVIRONMENT_OVERRIDE: return "environment override";
31 case VarOrigin::FILE: return "file";
32 case VarOrigin::COMMAND_LINE: return "command line";
33 case VarOrigin::OVERRIDE: return "override";
34 case VarOrigin::AUTOMATIC: return "automatic";
35 }
36 CHECK(false);
37 return "*** broken origin ***";
38}
39
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090040Var::Var() {
41}
42
43Var::~Var() {
44}
45
Shinichiro Hamaji4c469b32015-06-15 19:53:36 +090046void Var::AppendVar(Evaluator*, Value*) {
47 CHECK(false);
48}
49
Shinichiro Hamaji5081c712015-08-14 16:49:20 +090050SimpleVar::SimpleVar(const string& v, VarOrigin origin)
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090051 : v_(v), origin_(origin) {
52}
53
54void SimpleVar::Eval(Evaluator*, string* s) const {
Shinichiro Hamaji5081c712015-08-14 16:49:20 +090055 *s += v_;
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090056}
57
Shinichiro Hamaji4c469b32015-06-15 19:53:36 +090058void SimpleVar::AppendVar(Evaluator* ev, Value* v) {
Shinichiro Hamaji5081c712015-08-14 16:49:20 +090059 v_.push_back(' ');
60 v->Eval(ev, &v_);
Shinichiro Hamaji4c469b32015-06-15 19:53:36 +090061}
62
Shinichiro Hamaji81699be2015-06-22 18:07:38 +090063StringPiece SimpleVar::String() const {
Shinichiro Hamaji5081c712015-08-14 16:49:20 +090064 return v_;
Shinichiro Hamaji81699be2015-06-22 18:07:38 +090065}
66
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090067string SimpleVar::DebugString() const {
Shinichiro Hamaji5081c712015-08-14 16:49:20 +090068 return v_;
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090069}
70
Shinichiro Hamajif62e9a72015-06-26 04:18:21 +090071RecursiveVar::RecursiveVar(Value* v, VarOrigin origin, StringPiece orig)
Shinichiro Hamaji81699be2015-06-22 18:07:38 +090072 : v_(v), origin_(origin), orig_(orig) {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090073}
74
75void RecursiveVar::Eval(Evaluator* ev, string* s) const {
76 v_->Eval(ev, s);
77}
78
Shinichiro Hamaji4c469b32015-06-15 19:53:36 +090079void RecursiveVar::AppendVar(Evaluator*, Value* v) {
80 v_ = NewExpr3(v_, NewLiteral(" "), v);
81}
82
Shinichiro Hamaji81699be2015-06-22 18:07:38 +090083StringPiece RecursiveVar::String() const {
84 return orig_;
85}
86
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090087string RecursiveVar::DebugString() const {
88 return v_->DebugString();
89}
90
91UndefinedVar::UndefinedVar() {}
92
93void UndefinedVar::Eval(Evaluator*, string*) const {
94 // Nothing to do.
95}
96
Shinichiro Hamaji81699be2015-06-22 18:07:38 +090097StringPiece UndefinedVar::String() const {
Shinichiro Hamaji388e8582015-07-03 16:51:46 +090098 return StringPiece("");
Shinichiro Hamaji81699be2015-06-22 18:07:38 +090099}
100
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900101string UndefinedVar::DebugString() const {
102 return "*undefined*";
103}
104
105Vars::~Vars() {
106 for (auto p : *this) {
107 delete p.second;
108 }
109}
110
Shinichiro Hamajie7992752015-06-29 18:38:35 +0900111Var* Vars::Lookup(Symbol name) const {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900112 auto found = find(name);
113 if (found == end())
114 return kUndefined;
Shinichiro Hamaji5163e042015-07-14 03:51:44 +0900115 Var* v = found->second;
116 if (v->Origin() == VarOrigin::ENVIRONMENT ||
117 v->Origin() == VarOrigin::ENVIRONMENT_OVERRIDE) {
118 used_env_vars_.insert(name);
119 }
120 return v;
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900121}
122
Shinichiro Hamajie7992752015-06-29 18:38:35 +0900123void Vars::Assign(Symbol name, Var* v) {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900124 auto p = insert(make_pair(name, v));
125 if (!p.second) {
Shinichiro Hamaji0ea9e912015-06-26 04:24:38 +0900126 Var* orig = p.first->second;
127 if (orig->Origin() == VarOrigin::OVERRIDE ||
128 orig->Origin() == VarOrigin::ENVIRONMENT_OVERRIDE) {
129 return;
130 }
Shinichiro Hamaji2bb8f372015-06-26 06:58:13 +0900131 if (orig->Origin() == VarOrigin::AUTOMATIC) {
132 ERROR("overriding automatic variable is not implemented yet");
133 }
Shinichiro Hamaji0ea9e912015-06-26 04:24:38 +0900134 if (orig->IsDefined())
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900135 delete p.first->second;
136 p.first->second = v;
137 }
138}
Shinichiro Hamajicf0cd682015-06-18 16:18:13 +0900139
Shinichiro Hamaji5163e042015-07-14 03:51:44 +0900140unordered_set<Symbol> Vars::used_env_vars_;
141
Shinichiro Hamajie7992752015-06-29 18:38:35 +0900142ScopedVar::ScopedVar(Vars* vars, Symbol name, Var* var)
Shinichiro Hamajicf0cd682015-06-18 16:18:13 +0900143 : vars_(vars), orig_(NULL) {
144 auto p = vars->insert(make_pair(name, var));
145 iter_ = p.first;
146 if (!p.second) {
147 orig_ = iter_->second;
148 iter_->second = var;
149 }
150}
151
152ScopedVar::~ScopedVar() {
153 if (orig_) {
154 iter_->second = orig_;
155 } else {
156 vars_->erase(iter_);
157 }
158}