A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
boolean-probe.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011 Bucknell University
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Authors: L. Felipe Perrone (perrone@bucknell.edu)
18 * Tiago G. Rodrigues (tgr002@bucknell.edu)
19 *
20 * Modified by: Mitch Watrous (watrous@u.washington.edu)
21 */
22
23#ifndef BOOL_PROBE_H
24#define BOOL_PROBE_H
25
26#include "probe.h"
27
28#include "ns3/boolean.h"
29#include "ns3/callback.h"
30#include "ns3/object.h"
31#include "ns3/simulator.h"
32#include "ns3/traced-value.h"
33
34namespace ns3
35{
36
37/**
38 * \ingroup probes
39 *
40 * This class is designed to probe an underlying ns3 TraceSource exporting
41 * a bool. This probe exports a trace source "Output" of type bool.
42 * The Output trace source emits a value when either the trace source
43 * emits a new value, or when SetValue () is called.
44 *
45 * The current value of the probe can be polled with the GetValue ()
46 * method.
47 */
48class BooleanProbe : public Probe
49{
50 public:
51 /**
52 * \brief Get the type ID.
53 * \return the object TypeId
54 */
55 static TypeId GetTypeId();
57 ~BooleanProbe() override;
58
59 /**
60 * \return the most recent value
61 */
62 bool GetValue() const;
63
64 /**
65 * \param value set the traced bool to a new value
66 */
67 void SetValue(bool value);
68
69 /**
70 * \brief Set a probe value by its name in the Config system
71 *
72 * \param path Config path to access the probe
73 * \param value set the traced bool to a new value
74 */
75 static void SetValueByPath(std::string path, bool value);
76
77 /**
78 * \brief connect to a trace source attribute provided by a given object
79 *
80 * \param traceSource the name of the attribute TraceSource to connect to
81 * \param obj ns3::Object to connect to
82 * \return true if the trace source was successfully connected
83 */
84 bool ConnectByObject(std::string traceSource, Ptr<Object> obj) override;
85
86 /**
87 * \brief connect to a trace source provided by a config path
88 *
89 * \param path Config path to bind to
90 *
91 * Note, if an invalid path is provided, the probe will not be connected
92 * to anything.
93 */
94 void ConnectByPath(std::string path) override;
95
96 private:
97 /**
98 * \brief Method to connect to an underlying ns3::TraceSource of type bool
99 *
100 * \param oldData previous value of the bool
101 * \param newData new value of the bool
102 */
103 void TraceSink(bool oldData, bool newData);
104
105 TracedValue<bool> m_output; //!< Output trace source.
106};
107
108} // namespace ns3
109
110#endif // BOOL_PROBE_H
This class is designed to probe an underlying ns3 TraceSource exporting a bool.
Definition: boolean-probe.h:49
static void SetValueByPath(std::string path, bool value)
Set a probe value by its name in the Config system.
TracedValue< bool > m_output
Output trace source.
static TypeId GetTypeId()
Get the type ID.
void TraceSink(bool oldData, bool newData)
Method to connect to an underlying ns3::TraceSource of type bool.
void SetValue(bool value)
void ConnectByPath(std::string path) override
connect to a trace source provided by a config path
bool GetValue() const
bool ConnectByObject(std::string traceSource, Ptr< Object > obj) override
connect to a trace source attribute provided by a given object
~BooleanProbe() override
Base class for probes.
Definition: probe.h:41
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
Trace classes with value semantics.
Definition: traced-value.h:116
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.