sc_event.hh (13089:2cd69e58c0f8) | sc_event.hh (13132:1fb4a87f550f) |
---|---|
1/* 2 * Copyright 2018 Google, Inc. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions are 6 * met: redistributions of source code must retain the above copyright 7 * notice, this list of conditions and the following disclaimer; 8 * redistributions in binary form must reproduce the above copyright --- 50 unchanged lines hidden (view full) --- 59class sc_event_finder 60{ 61 protected: 62 virtual ~sc_event_finder() {} 63 64 public: 65 // Should be "implementation defined" but used in the tests. 66 virtual const sc_event &find_event(sc_interface *if_p=NULL) const = 0; | 1/* 2 * Copyright 2018 Google, Inc. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions are 6 * met: redistributions of source code must retain the above copyright 7 * notice, this list of conditions and the following disclaimer; 8 * redistributions in binary form must reproduce the above copyright --- 50 unchanged lines hidden (view full) --- 59class sc_event_finder 60{ 61 protected: 62 virtual ~sc_event_finder() {} 63 64 public: 65 // Should be "implementation defined" but used in the tests. 66 virtual const sc_event &find_event(sc_interface *if_p=NULL) const = 0; |
67 virtual const sc_port_base *port() const = 0; |
|
67}; 68 69template <class IF> 70class sc_event_finder_t : public sc_event_finder 71{ 72 public: 73 sc_event_finder_t(const sc_port_base &p, 74 const sc_event & (IF::*_method)() const) : 75 _method(_method) 76 { 77 _port = dynamic_cast<const sc_port_b<IF> *>(&p); 78 assert(_port); 79 } 80 81 virtual ~sc_event_finder_t() {} 82 | 68}; 69 70template <class IF> 71class sc_event_finder_t : public sc_event_finder 72{ 73 public: 74 sc_event_finder_t(const sc_port_base &p, 75 const sc_event & (IF::*_method)() const) : 76 _method(_method) 77 { 78 _port = dynamic_cast<const sc_port_b<IF> *>(&p); 79 assert(_port); 80 } 81 82 virtual ~sc_event_finder_t() {} 83 |
84 const sc_port_base *port() const { return _port; } 85 |
|
83 const sc_event & 84 find_event(sc_interface *if_p=NULL) const override 85 { 86 const IF *iface = if_p ? dynamic_cast<const IF *>(if_p) : 87 dynamic_cast<const IF *>(_port->get_interface()); 88 return (const_cast<IF *>(iface)->*_method)(); 89 } 90 --- 158 unchanged lines hidden --- | 86 const sc_event & 87 find_event(sc_interface *if_p=NULL) const override 88 { 89 const IF *iface = if_p ? dynamic_cast<const IF *>(if_p) : 90 dynamic_cast<const IF *>(_port->get_interface()); 91 return (const_cast<IF *>(iface)->*_method)(); 92 } 93 --- 158 unchanged lines hidden --- |