sc_object.hh (12940:f191f383f3bf) sc_object.hh (12950:af1f0b5e8dfb)
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

--- 20 unchanged lines hidden (view full) ---

29
30#ifndef __SYSTEMC_EXT_CORE_SC_OBJECT_HH__
31#define __SYSTEMC_EXT_CORE_SC_OBJECT_HH__
32
33#include <iostream>
34#include <string>
35#include <vector>
36
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

--- 20 unchanged lines hidden (view full) ---

29
30#ifndef __SYSTEMC_EXT_CORE_SC_OBJECT_HH__
31#define __SYSTEMC_EXT_CORE_SC_OBJECT_HH__
32
33#include <iostream>
34#include <string>
35#include <vector>
36
37namespace sc_gem5
38{
39
40class Object;
41
42} // namespace sc_gem5
43
37namespace sc_core
38{
39
40class sc_event;
41class sc_attr_base;
42class sc_attr_cltn;
43class sc_simcontext;
44
45class sc_object
46{
47 public:
48 const char *name() const;
49 const char *basename() const;
50
44namespace sc_core
45{
46
47class sc_event;
48class sc_attr_base;
49class sc_attr_cltn;
50class sc_simcontext;
51
52class sc_object
53{
54 public:
55 const char *name() const;
56 const char *basename() const;
57
51 virtual const char *kind() const;
58 virtual const char *kind() const { return "sc_object"; }
52
53 virtual void print(std::ostream & =std::cout) const;
54 virtual void dump(std::ostream & =std::cout) const;
55
56 virtual const std::vector<sc_object *> &get_child_objects() const;
57 virtual const std::vector<sc_event *> &get_child_events() const;
58 sc_object *get_parent_object() const;
59
60 bool add_attribute(sc_attr_base &);
61 sc_attr_base *get_attribute(const std::string &);
62 sc_attr_base *remove_attribute(const std::string &);
63 void remove_all_attributes();
64 int num_attributes() const;
65 sc_attr_cltn &attr_cltn();
66 const sc_attr_cltn &attr_cltn() const;
67
68 // Deprecated
59
60 virtual void print(std::ostream & =std::cout) const;
61 virtual void dump(std::ostream & =std::cout) const;
62
63 virtual const std::vector<sc_object *> &get_child_objects() const;
64 virtual const std::vector<sc_event *> &get_child_events() const;
65 sc_object *get_parent_object() const;
66
67 bool add_attribute(sc_attr_base &);
68 sc_attr_base *get_attribute(const std::string &);
69 sc_attr_base *remove_attribute(const std::string &);
70 void remove_all_attributes();
71 int num_attributes() const;
72 sc_attr_cltn &attr_cltn();
73 const sc_attr_cltn &attr_cltn() const;
74
75 // Deprecated
69 sc_simcontext *
70 simcontext() const;
76 sc_simcontext *simcontext() const;
71
72 protected:
73 sc_object();
74 sc_object(const char *);
75 sc_object(const sc_object &);
76 sc_object &operator = (const sc_object &);
77 virtual ~sc_object();
77
78 protected:
79 sc_object();
80 sc_object(const char *);
81 sc_object(const sc_object &);
82 sc_object &operator = (const sc_object &);
83 virtual ~sc_object();
84
85 private:
86 friend class sc_gem5::Object;
87 sc_gem5::Object *_gem5_object;
78};
79
80const std::vector<sc_object *> &sc_get_top_level_objects();
81sc_object *sc_find_object(const char *);
82
83} // namespace sc_core
84
85#endif //__SYSTEMC_EXT_CORE_SC_OBJECT_HH__
88};
89
90const std::vector<sc_object *> &sc_get_top_level_objects();
91sc_object *sc_find_object(const char *);
92
93} // namespace sc_core
94
95#endif //__SYSTEMC_EXT_CORE_SC_OBJECT_HH__