/* * The contents of this file are subject to the Mozilla Public License * Version 1.0 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the * License for the specific language governing rights and limitations * under the License. * * The Initial Developer of this code is David Baum. * Portions created by David Baum are Copyright (C) 1999 David Baum. * All Rights Reserved. * * Portions created by John Hansen are Copyright (C) 2005 John Hansen. * All Rights Reserved. * */ #ifndef __CallStmt_h #define __CallStmt_h #ifndef __Stmt_h #include "Stmt.h" #endif #ifndef __parser_h #include "parser.h" #endif #include using std::vector; class Symbol; class Expr; class CallStmt : public ChainStmt { public: CallStmt(); ~CallStmt(); void EmitActual(Bytecode &b); Stmt* CloneActual(Mapping *b) const; virtual void GetExprs(vector & v) const; void SetName(const Symbol *name) { fName = name; } void SetLocation(const struct LexLocation &loc) { fLocation = loc; } void AddParam(Expr *c) { fParams.push_back(c); } void Expand(Fragment *f); class Expander { public: Expander(Fragment *f) : fFragment(f) {} bool operator()(Stmt *s); private: Fragment* fFragment; }; private: void ExpandFunction(FunctionDef *func, Fragment *fragment); const Symbol* fName; struct LexLocation fLocation; vector fParams; }; #endif