/* * Copyright (c) 1998 Stephen Williams (steve@icarus.com) * * This source code is free software; you can redistribute it * and/or modify it in source code form under the terms of the GNU * General Public License as published by the Free Software * Foundation; either version 2 of the License, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA */ #if !defined(WINNT) #ident "$Id: Statement.cc,v 1.7 1999/06/06 20:45:38 steve Exp $" #endif # include "Statement.h" # include "PExpr.h" Statement::~Statement() { } PAssign::~PAssign() { delete lval_; delete expr_; } PAssignNB::~PAssignNB() { delete lval_; delete rval_; } PBlock::PBlock(BL_TYPE t, const list&st) : bl_type_(t) { nlist_ = st.size(); list_ = new Statement*[nlist_]; list::const_iterator s = st.begin(); for (unsigned idx = 0 ; s != st.end() ; s ++, idx += 1 ) { list_[idx] = *s; } } PBlock::~PBlock() { for (unsigned idx = 0 ; idx < nlist_ ; idx += 1) delete list_[idx]; delete[]list_; } PCallTask::PCallTask(const string&n, const svector&p) : name_(n), parms_(p) { } PCase::PCase(PExpr*ex, svector*l) : expr_(ex), items_(l) { } PCase::~PCase() { delete expr_; for (unsigned idx = 0 ; idx < items_->count() ; idx += 1) { if ((*items_)[idx]->expr) delete (*items_)[idx]->expr; if ((*items_)[idx]->stat) delete (*items_)[idx]->stat; } delete[]items_; } PCondit::~PCondit() { delete expr_; delete if_; delete else_; } PProcess::~PProcess() { delete statement_; } PWhile::~PWhile() { delete cond_; delete statement_; } /* * $Log: Statement.cc,v $ * Revision 1.7 1999/06/06 20:45:38 steve * Add parse and elaboration of non-blocking assignments, * Replace list with an svector version, * Add integer support. * * Revision 1.6 1999/05/10 00:16:58 steve * Parse and elaborate the concatenate operator * in structural contexts, Replace vector * and list with svector, evaluate * constant expressions with parameters, handle * memories as lvalues. * * Parse task declarations, integer types. * * Revision 1.5 1999/02/03 04:20:11 steve * Parse and elaborate the Verilog CASE statement. * * Revision 1.4 1999/01/25 05:45:56 steve * Add the LineInfo class to carry the source file * location of things. PGate, Statement and PProcess. * * elaborate handles module parameter mismatches, * missing or incorrect lvalues for procedural * assignment, and errors are propogated to the * top of the elaboration call tree. * * Attach line numbers to processes, gates and * assignment statements. * * Revision 1.3 1998/11/11 03:13:04 steve * Handle while loops. * * Revision 1.2 1998/11/07 17:05:05 steve * Handle procedural conditional, and some * of the conditional expressions. * * Elaborate signals and identifiers differently, * allowing the netlist to hold signal information. * * Revision 1.1 1998/11/03 23:28:55 steve * Introduce verilog to CVS. * */