1998-11-04 00:28:49 +01:00
|
|
|
/*
|
2010-01-08 23:49:48 +01:00
|
|
|
* Copyright (c) 1998-2008,2010 Stephen Williams (steve@icarus.com)
|
1998-11-04 00:28:49 +01:00
|
|
|
*
|
|
|
|
|
* 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
|
|
|
|
|
*/
|
|
|
|
|
|
2001-07-25 05:10:48 +02:00
|
|
|
# include "config.h"
|
|
|
|
|
|
1998-11-04 00:28:49 +01:00
|
|
|
# include "Statement.h"
|
|
|
|
|
# include "PExpr.h"
|
|
|
|
|
|
|
|
|
|
Statement::~Statement()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssign_::PAssign_(PExpr*lval__, PExpr*ex, bool is_constant)
|
|
|
|
|
: event_(0), count_(0), lval_(lval__), rval_(ex), is_constant_(is_constant)
|
1999-09-22 04:00:48 +02:00
|
|
|
{
|
2002-04-22 00:31:02 +02:00
|
|
|
delay_ = 0;
|
1999-09-22 04:00:48 +02:00
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssign_::PAssign_(PExpr*lval__, PExpr*de, PExpr*ex)
|
|
|
|
|
: event_(0), count_(0), lval_(lval__), rval_(ex), is_constant_(false)
|
1999-06-06 22:45:38 +02:00
|
|
|
{
|
2002-04-22 00:31:02 +02:00
|
|
|
delay_ = de;
|
1999-06-06 22:45:38 +02:00
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssign_::PAssign_(PExpr*lval__, PExpr*cnt, PEventStatement*ev, PExpr*ex)
|
|
|
|
|
: event_(ev), count_(cnt), lval_(lval__), rval_(ex), is_constant_(false)
|
1999-09-22 04:00:48 +02:00
|
|
|
{
|
2002-04-22 00:31:02 +02:00
|
|
|
delay_ = 0;
|
1999-09-22 04:00:48 +02:00
|
|
|
}
|
|
|
|
|
|
1999-06-14 01:51:16 +02:00
|
|
|
PAssign_::~PAssign_()
|
1999-06-06 22:45:38 +02:00
|
|
|
{
|
|
|
|
|
delete lval_;
|
|
|
|
|
delete rval_;
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssign::PAssign(PExpr*lval__, PExpr*ex)
|
2011-11-27 20:16:39 +01:00
|
|
|
: PAssign_(lval__, ex, false), op_(0)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PAssign::PAssign(PExpr*lval__, char op, PExpr*ex)
|
|
|
|
|
: PAssign_(lval__, ex, false), op_(op)
|
1999-07-12 02:59:36 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssign::PAssign(PExpr*lval__, PExpr*d, PExpr*ex)
|
2011-11-27 20:16:39 +01:00
|
|
|
: PAssign_(lval__, d, ex), op_(0)
|
1999-06-14 01:51:16 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssign::PAssign(PExpr*lval__, PExpr*cnt, PEventStatement*d, PExpr*ex)
|
2011-11-27 20:16:39 +01:00
|
|
|
: PAssign_(lval__, cnt, d, ex), op_(0)
|
1999-09-22 04:00:48 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssign::PAssign(PExpr*lval__, PExpr*ex, bool is_constant)
|
2011-11-27 20:16:39 +01:00
|
|
|
: PAssign_(lval__, ex, is_constant), op_(0)
|
2008-10-04 16:30:34 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
1999-06-14 01:51:16 +02:00
|
|
|
PAssign::~PAssign()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssignNB::PAssignNB(PExpr*lval__, PExpr*ex)
|
|
|
|
|
: PAssign_(lval__, ex, false)
|
1999-06-14 01:51:16 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssignNB::PAssignNB(PExpr*lval__, PExpr*d, PExpr*ex)
|
|
|
|
|
: PAssign_(lval__, d, ex)
|
1999-09-02 03:59:27 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-13 18:51:05 +02:00
|
|
|
PAssignNB::PAssignNB(PExpr*lval__, PExpr*cnt, PEventStatement*d, PExpr*ex)
|
|
|
|
|
: PAssign_(lval__, cnt, d, ex)
|
2008-09-04 01:05:12 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
1999-06-14 01:51:16 +02:00
|
|
|
PAssignNB::~PAssignNB()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2010-01-08 23:49:48 +01:00
|
|
|
PBlock::PBlock(perm_string n, LexicalScope*parent, BL_TYPE t)
|
2008-02-16 06:20:24 +01:00
|
|
|
: PScope(n, parent), bl_type_(t)
|
1999-06-24 06:24:18 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PBlock::PBlock(BL_TYPE t)
|
2008-06-18 06:45:37 +02:00
|
|
|
: PScope(perm_string()), bl_type_(t)
|
1999-06-24 06:24:18 +02:00
|
|
|
{
|
1998-11-04 00:28:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PBlock::~PBlock()
|
|
|
|
|
{
|
2011-09-17 21:10:05 +02:00
|
|
|
for (unsigned idx = 0 ; idx < list_.size() ; idx += 1)
|
1998-11-04 00:28:49 +01:00
|
|
|
delete list_[idx];
|
|
|
|
|
}
|
|
|
|
|
|
2011-09-17 21:10:05 +02:00
|
|
|
void PBlock::set_statement(const vector<Statement*>&st)
|
2008-02-16 06:20:24 +01:00
|
|
|
{
|
|
|
|
|
list_ = st;
|
|
|
|
|
}
|
|
|
|
|
|
2010-10-26 04:36:44 +02:00
|
|
|
PCallTask::PCallTask(const pform_name_t&n, const list<PExpr*>&p)
|
|
|
|
|
: path_(n), parms_(p.size())
|
|
|
|
|
{
|
|
|
|
|
list<PExpr*>::const_iterator cur = p.begin();
|
|
|
|
|
for (size_t idx = 0 ; idx < parms_.size() ; idx += 1) {
|
|
|
|
|
parms_[idx] = *cur;
|
|
|
|
|
++cur;
|
|
|
|
|
}
|
|
|
|
|
assert(cur == p.end());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PCallTask::PCallTask(perm_string n, const list<PExpr*>&p)
|
|
|
|
|
: parms_(p.size())
|
|
|
|
|
{
|
|
|
|
|
list<PExpr*>::const_iterator cur = p.begin();
|
|
|
|
|
for (size_t idx = 0 ; idx < parms_.size() ; idx += 1) {
|
|
|
|
|
parms_[idx] = *cur;
|
|
|
|
|
++cur;
|
|
|
|
|
}
|
|
|
|
|
assert(cur == p.end());
|
2007-05-24 06:07:11 +02:00
|
|
|
path_.push_back(name_component_t(n));
|
|
|
|
|
}
|
|
|
|
|
|
2001-11-22 07:20:59 +01:00
|
|
|
PCallTask::~PCallTask()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2007-05-24 06:07:11 +02:00
|
|
|
const pform_name_t& PCallTask::path() const
|
2001-12-03 05:47:14 +01:00
|
|
|
{
|
|
|
|
|
return path_;
|
|
|
|
|
}
|
|
|
|
|
|
1999-09-29 20:36:02 +02:00
|
|
|
PCase::PCase(NetCase::TYPE t, PExpr*ex, svector<PCase::Item*>*l)
|
|
|
|
|
: type_(t), expr_(ex), items_(l)
|
1999-02-03 05:20:11 +01:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PCase::~PCase()
|
|
|
|
|
{
|
|
|
|
|
delete expr_;
|
1999-06-15 07:38:39 +02:00
|
|
|
for (unsigned idx = 0 ; idx < items_->count() ; idx += 1)
|
1999-06-06 22:45:38 +02:00
|
|
|
if ((*items_)[idx]->stat) delete (*items_)[idx]->stat;
|
1999-02-03 05:20:11 +01:00
|
|
|
|
|
|
|
|
delete[]items_;
|
|
|
|
|
}
|
|
|
|
|
|
2000-05-12 01:37:26 +02:00
|
|
|
PCAssign::PCAssign(PExpr*l, PExpr*r)
|
|
|
|
|
: lval_(l), expr_(r)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PCAssign::~PCAssign()
|
|
|
|
|
{
|
|
|
|
|
delete lval_;
|
|
|
|
|
delete expr_;
|
|
|
|
|
}
|
|
|
|
|
|
2000-04-12 06:23:57 +02:00
|
|
|
PCondit::PCondit(PExpr*ex, Statement*i, Statement*e)
|
|
|
|
|
: expr_(ex), if_(i), else_(e)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
1998-11-07 18:05:05 +01:00
|
|
|
PCondit::~PCondit()
|
|
|
|
|
{
|
|
|
|
|
delete expr_;
|
|
|
|
|
delete if_;
|
|
|
|
|
delete else_;
|
|
|
|
|
}
|
|
|
|
|
|
2000-05-12 01:37:26 +02:00
|
|
|
PDeassign::PDeassign(PExpr*l)
|
|
|
|
|
: lval_(l)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PDeassign::~PDeassign()
|
|
|
|
|
{
|
|
|
|
|
delete lval_;
|
|
|
|
|
}
|
|
|
|
|
|
2000-04-12 06:23:57 +02:00
|
|
|
|
|
|
|
|
PDelayStatement::PDelayStatement(PExpr*d, Statement*st)
|
|
|
|
|
: delay_(d), statement_(st)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PDelayStatement::~PDelayStatement()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2007-05-24 06:07:11 +02:00
|
|
|
PDisable::PDisable(const pform_name_t&sc)
|
2000-07-26 07:08:07 +02:00
|
|
|
: scope_(sc)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PDisable::~PDisable()
|
|
|
|
|
{
|
|
|
|
|
}
|
2000-04-12 06:23:57 +02:00
|
|
|
|
2000-04-01 21:31:57 +02:00
|
|
|
PEventStatement::PEventStatement(const svector<PEEvent*>&ee)
|
|
|
|
|
: expr_(ee), statement_(0)
|
|
|
|
|
{
|
2002-04-21 06:59:07 +02:00
|
|
|
assert(expr_.count() > 0);
|
2000-04-01 21:31:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PEventStatement::PEventStatement(PEEvent*ee)
|
|
|
|
|
: expr_(1), statement_(0)
|
|
|
|
|
{
|
|
|
|
|
expr_[0] = ee;
|
|
|
|
|
}
|
|
|
|
|
|
2002-04-21 06:59:07 +02:00
|
|
|
PEventStatement::PEventStatement(void)
|
|
|
|
|
: statement_(0)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2000-04-01 21:31:57 +02:00
|
|
|
PEventStatement::~PEventStatement()
|
|
|
|
|
{
|
|
|
|
|
// delete the events and the statement?
|
|
|
|
|
}
|
|
|
|
|
|
2000-04-12 06:23:57 +02:00
|
|
|
void PEventStatement::set_statement(Statement*st)
|
|
|
|
|
{
|
|
|
|
|
statement_ = st;
|
|
|
|
|
}
|
|
|
|
|
|
2008-11-09 01:26:55 +01:00
|
|
|
bool PEventStatement::has_aa_term(Design*des, NetScope*scope)
|
|
|
|
|
{
|
|
|
|
|
bool flag = false;
|
|
|
|
|
for (unsigned idx = 0 ; idx < expr_.count() ; idx += 1) {
|
|
|
|
|
flag = expr_[idx]->has_aa_term(des, scope) || flag;
|
|
|
|
|
}
|
|
|
|
|
return flag;
|
|
|
|
|
}
|
|
|
|
|
|
2000-04-22 06:20:19 +02:00
|
|
|
PForce::PForce(PExpr*l, PExpr*r)
|
|
|
|
|
: lval_(l), expr_(r)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PForce::~PForce()
|
|
|
|
|
{
|
|
|
|
|
delete lval_;
|
|
|
|
|
delete expr_;
|
|
|
|
|
}
|
|
|
|
|
|
1999-06-19 23:06:16 +02:00
|
|
|
PForever::PForever(Statement*s)
|
|
|
|
|
: statement_(s)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PForever::~PForever()
|
|
|
|
|
{
|
|
|
|
|
delete statement_;
|
|
|
|
|
}
|
|
|
|
|
|
2001-11-22 07:20:59 +01:00
|
|
|
PForStatement::PForStatement(PExpr*n1, PExpr*e1, PExpr*cond,
|
2012-02-25 18:28:20 +01:00
|
|
|
Statement*step, Statement*st)
|
|
|
|
|
: name1_(n1), expr1_(e1), cond_(cond), step_(step), statement_(st)
|
2001-11-22 07:20:59 +01:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PForStatement::~PForStatement()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
1999-01-25 06:45:56 +01:00
|
|
|
PProcess::~PProcess()
|
|
|
|
|
{
|
|
|
|
|
delete statement_;
|
|
|
|
|
}
|
1998-11-04 00:28:49 +01:00
|
|
|
|
2000-04-22 06:20:19 +02:00
|
|
|
PRelease::PRelease(PExpr*l)
|
|
|
|
|
: lval_(l)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PRelease::~PRelease()
|
|
|
|
|
{
|
|
|
|
|
delete lval_;
|
|
|
|
|
}
|
|
|
|
|
|
1999-06-19 23:06:16 +02:00
|
|
|
PRepeat::PRepeat(PExpr*e, Statement*s)
|
|
|
|
|
: expr_(e), statement_(s)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PRepeat::~PRepeat()
|
|
|
|
|
{
|
|
|
|
|
delete expr_;
|
|
|
|
|
delete statement_;
|
|
|
|
|
}
|
|
|
|
|
|
2007-05-24 06:07:11 +02:00
|
|
|
PTrigger::PTrigger(const pform_name_t&e)
|
2000-04-01 21:31:57 +02:00
|
|
|
: event_(e)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PTrigger::~PTrigger()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2001-11-22 07:20:59 +01:00
|
|
|
PWhile::PWhile(PExpr*e1, Statement*st)
|
|
|
|
|
: cond_(e1), statement_(st)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
1998-11-11 04:13:04 +01:00
|
|
|
PWhile::~PWhile()
|
|
|
|
|
{
|
|
|
|
|
delete cond_;
|
|
|
|
|
delete statement_;
|
|
|
|
|
}
|