blob: 155e0cd535435f5f90084982fe10e8d5b6f1e27a [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 Hamaji645cca72015-09-24 17:04:21 +090017#include "stmt.h"
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090018
19#include "eval.h"
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090020#include "expr.h"
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090021#include "stringprintf.h"
Shinichiro Hamajic195f402015-06-24 14:44:04 +090022#include "strutil.h"
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090023
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090024Stmt::Stmt() {}
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090025
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090026Stmt::~Stmt() {}
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090027
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090028string RuleStmt::DebugString() const {
29 return StringPrintf("RuleStmt(expr=%s term=%d after_term=%s loc=%s:%d)",
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090030 expr->DebugString().c_str(),
31 term,
Shinichiro Hamaji8ee8c372015-06-16 16:19:40 +090032 after_term->DebugString().c_str(),
33 LOCF(loc()));
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090034}
35
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090036string AssignStmt::DebugString() const {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090037 const char* opstr = "???";
38 switch (op) {
39 case AssignOp::EQ: opstr = "EQ"; break;
40 case AssignOp::COLON_EQ: opstr = "COLON_EQ"; break;
41 case AssignOp::PLUS_EQ: opstr = "PLUS_EQ"; break;
42 case AssignOp::QUESTION_EQ: opstr = "QUESTION_EQ"; break;
43 }
44 const char* dirstr = "???";
45 switch (directive) {
46 case AssignDirective::NONE: dirstr = ""; break;
47 case AssignDirective::OVERRIDE: dirstr = "override"; break;
48 case AssignDirective::EXPORT: dirstr = "export"; break;
49 }
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090050 return StringPrintf("AssignStmt(lhs=%s rhs=%s (%s) "
Shinichiro Hamaji81699be2015-06-22 18:07:38 +090051 "opstr=%s dir=%s loc=%s:%d)",
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090052 lhs->DebugString().c_str(),
53 rhs->DebugString().c_str(),
Shinichiro Hamajic195f402015-06-24 14:44:04 +090054 NoLineBreak(orig_rhs.as_string()).c_str(),
Shinichiro Hamaji8ee8c372015-06-16 16:19:40 +090055 opstr, dirstr, LOCF(loc()));
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090056}
57
Shinichiro Hamaji92a47382016-02-17 17:19:21 +090058Symbol AssignStmt::GetLhsSymbol(Evaluator* ev) const {
59 if (!lhs->IsLiteral()) {
60 string buf;
61 lhs->Eval(ev, &buf);
62 return Intern(buf);
63 }
64
65 if (!lhs_sym_cache_.IsValid()) {
66 lhs_sym_cache_ = Intern(lhs->GetLiteralValueUnsafe());
67 }
68 return lhs_sym_cache_;
69}
70
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090071string CommandStmt::DebugString() const {
72 return StringPrintf("CommandStmt(%s, loc=%s:%d)",
Shinichiro Hamaji8ee8c372015-06-16 16:19:40 +090073 expr->DebugString().c_str(), LOCF(loc()));
Shinichiro Hamaji776ca302015-06-06 03:52:48 +090074}
75
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090076string IfStmt::DebugString() const {
Shinichiro Hamaji7e256df2015-06-17 15:33:11 +090077 const char* opstr = "???";
78 switch (op) {
79 case CondOp::IFEQ: opstr = "ifeq"; break;
80 case CondOp::IFNEQ: opstr = "ifneq"; break;
81 case CondOp::IFDEF: opstr = "ifdef"; break;
82 case CondOp::IFNDEF: opstr = "ifndef"; break;
83 }
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090084 return StringPrintf("IfStmt(op=%s, lhs=%s, rhs=%s t=%zu f=%zu loc=%s:%d)",
Shinichiro Hamaji7e256df2015-06-17 15:33:11 +090085 opstr,
86 lhs->DebugString().c_str(),
87 rhs->DebugString().c_str(),
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090088 true_stmts.size(),
89 false_stmts.size(),
Shinichiro Hamaji7e256df2015-06-17 15:33:11 +090090 LOCF(loc()));
91}
92
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090093string IncludeStmt::DebugString() const {
94 return StringPrintf("IncludeStmt(%s, loc=%s:%d)",
Shinichiro Hamaji42b625f2015-06-16 23:07:21 +090095 expr->DebugString().c_str(), LOCF(loc()));
96}
97
Shinichiro Hamaji645cca72015-09-24 17:04:21 +090098string ExportStmt::DebugString() const {
99 return StringPrintf("ExportStmt(%s, %d, loc=%s:%d)",
Shinichiro Hamaji45a0c762015-06-26 06:47:10 +0900100 expr->DebugString().c_str(),
101 is_export,
102 LOCF(loc()));
103}
104
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900105string ParseErrorStmt::DebugString() const {
106 return StringPrintf("ParseErrorStmt(%s, loc=%s:%d)",
Shinichiro Hamaji56227862015-08-05 16:53:37 +0900107 msg.c_str(),
108 LOCF(loc()));
109}
110
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900111RuleStmt::~RuleStmt() {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900112 delete expr;
113 delete after_term;
114}
115
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900116void RuleStmt::Eval(Evaluator* ev) const {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900117 ev->EvalRule(this);
118}
119
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900120AssignStmt::~AssignStmt() {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900121 delete lhs;
122 delete rhs;
123}
124
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900125void AssignStmt::Eval(Evaluator* ev) const {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900126 ev->EvalAssign(this);
127}
128
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900129CommandStmt::~CommandStmt() {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900130 delete expr;
131}
132
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900133void CommandStmt::Eval(Evaluator* ev) const {
Shinichiro Hamaji776ca302015-06-06 03:52:48 +0900134 ev->EvalCommand(this);
135}
Shinichiro Hamaji42b625f2015-06-16 23:07:21 +0900136
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900137IfStmt::~IfStmt() {
Shinichiro Hamaji7e256df2015-06-17 15:33:11 +0900138 delete lhs;
139 delete rhs;
140}
141
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900142void IfStmt::Eval(Evaluator* ev) const {
Shinichiro Hamaji7e256df2015-06-17 15:33:11 +0900143 ev->EvalIf(this);
144}
145
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900146IncludeStmt::~IncludeStmt() {
Shinichiro Hamaji42b625f2015-06-16 23:07:21 +0900147 delete expr;
148}
149
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900150void IncludeStmt::Eval(Evaluator* ev) const {
Shinichiro Hamaji42b625f2015-06-16 23:07:21 +0900151 ev->EvalInclude(this);
152}
Shinichiro Hamaji45a0c762015-06-26 06:47:10 +0900153
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900154ExportStmt::~ExportStmt() {
Shinichiro Hamaji45a0c762015-06-26 06:47:10 +0900155 delete expr;
156}
157
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900158void ExportStmt::Eval(Evaluator* ev) const {
Shinichiro Hamaji45a0c762015-06-26 06:47:10 +0900159 ev->EvalExport(this);
160}
Shinichiro Hamaji56227862015-08-05 16:53:37 +0900161
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900162ParseErrorStmt::~ParseErrorStmt() {
Shinichiro Hamaji56227862015-08-05 16:53:37 +0900163}
164
Shinichiro Hamaji645cca72015-09-24 17:04:21 +0900165void ParseErrorStmt::Eval(Evaluator* ev) const {
Shinichiro Hamaji56227862015-08-05 16:53:37 +0900166 ev->set_loc(loc());
167 ev->Error(msg);
168}