00001 #ifndef PORT_H_INCLUDED_ 00002 #define PORT_H_INCLUDED_ 00003 00004 #include "rose.h" 00005 00006 #include "module.h" 00007 #include "object.h" 00008 00009 namespace risc { 00010 00011 class Port: public Object { 00012 00013 public: 00014 00018 explicit 00019 Port(SgVariableDefinition *ast_node, Class *parent, Type type = PortType); 00020 00025 virtual std::string get_ast_type_name(); 00026 00027 Class *parent_; 00028 00037 void get_mapped_channels(std::set<risc::Object*> &channels); 00038 00048 void get_mapped_channel_types(std::set<risc::Class*> &channels); 00049 00050 /* 00051 * after loading psg, this flag of the loaded port is set to true 00052 * 00053 */ 00054 bool bounded; 00055 private: 00056 00060 Port(const Port &p); 00061 }; 00062 00063 typedef std::vector<Port*> PortVector; 00064 typedef std::vector<Port*>::iterator PortVectorIter; 00065 typedef std::vector<Port*>::const_iterator PortVectorConstIter; 00066 00067 } // end of namespace risc 00068 00069 #endif /* PORT_H_INCLUDED_ */ 00070 00071 /* ex: set softtabstop=2 tabstop=2 shiftwidth=2 expandtab: */