summaryrefslogtreecommitdiffstats
path: root/signal-composer-binding/signal.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'signal-composer-binding/signal.cpp')
-rw-r--r--signal-composer-binding/signal.cpp38
1 files changed, 35 insertions, 3 deletions
diff --git a/signal-composer-binding/signal.cpp b/signal-composer-binding/signal.cpp
index 2dc517c..147aef0 100644
--- a/signal-composer-binding/signal.cpp
+++ b/signal-composer-binding/signal.cpp
@@ -15,6 +15,8 @@
* limitations under the License.
*/
+#include <float.h>
+#include <fnmatch.h>
#include <memory>
#include "signal.hpp"
@@ -45,12 +47,12 @@ bool Signal::operator ==(const Signal& other) const
return false;
}
-bool Signal::operator==(const std::string& aName) const
+bool Signal::operator ==(const std::string& aName) const
{
- if(id_ == aName) {return true;}
+ if(! fnmatch(aName.c_str(), id_.c_str(), FNM_CASEFOLD)) {return true;}
for( const std::string& src : signalSigList_)
{
- if(src == aName) {return true;}
+ if(! fnmatch(aName.c_str(), src.c_str(), FNM_CASEFOLD)) {return true;}
}
return false;
}
@@ -152,3 +154,33 @@ int Signal::recursionCheck()
}
return 0;
}
+
+double Signal::average(int seconds) const
+{
+ return 0.0;
+}
+double Signal::minimum() const
+{
+ double min = DBL_MAX;
+ for (auto& v : history_)
+ {
+ double temp_min = v.second;
+ if(temp_min < min) { min = temp_min;}
+ }
+ return min;
+}
+
+double Signal::maximum() const
+{
+ double max = 0.0;
+ for (auto& v : history_)
+ {
+ double temp_max = v.second;
+ if(temp_max > max) { max = temp_max;}
+ }
+ return max;
+}
+double Signal::last() const
+{
+ return history_.rbegin()->second;
+}