2008-02-14 04:59:05 +01:00
|
|
|
#ifndef __PScope_H
|
|
|
|
|
#define __PScope_H
|
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2008 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
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
# include "StringHeap.h"
|
2008-02-16 06:20:24 +01:00
|
|
|
# include "pform_types.h"
|
2008-02-14 04:59:05 +01:00
|
|
|
# include <map>
|
|
|
|
|
|
|
|
|
|
class PEvent;
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* The PScope class is a base representation of an object that
|
2008-02-16 06:20:24 +01:00
|
|
|
* represents lexical scope. For example, a module, a function/task, a
|
|
|
|
|
* named block is derived from a PScope.
|
2008-02-14 04:59:05 +01:00
|
|
|
*
|
|
|
|
|
* NOTE: This is note the same concept as the "scope" of an elaborated
|
|
|
|
|
* hierarchy. That is represented by NetScope objects after elaboration.
|
|
|
|
|
*/
|
|
|
|
|
class PScope {
|
|
|
|
|
|
|
|
|
|
public:
|
2008-02-16 06:20:24 +01:00
|
|
|
// When created, a scope has a name and a parent. The name is
|
|
|
|
|
// the name of the definition. For example, if this is a
|
|
|
|
|
// module declaration, the name is the name after the "module"
|
|
|
|
|
// keyword, and if this is a task scope, the name is the task
|
|
|
|
|
// name. The parent is the lexical parent of this scope. Since
|
|
|
|
|
// modules do not nest in Verilog, the parent must be nil for
|
|
|
|
|
// modules. Scopes for tasks and functions point to their
|
|
|
|
|
// containing module.
|
|
|
|
|
PScope(perm_string name, PScope*parent);
|
|
|
|
|
virtual ~PScope();
|
2008-02-14 04:59:05 +01:00
|
|
|
|
|
|
|
|
perm_string pscope_name() const { return name_; }
|
2008-02-16 06:20:24 +01:00
|
|
|
PScope* pscope_parent() { return parent_; }
|
2008-02-14 04:59:05 +01:00
|
|
|
|
|
|
|
|
// Named events in the scope.
|
|
|
|
|
map<perm_string,PEvent*>events;
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
perm_string name_;
|
2008-02-16 06:20:24 +01:00
|
|
|
PScope*parent_;
|
2008-02-14 04:59:05 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#endif
|