/* Copyright (C) 2001 Kimmo Pekkola This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef __MEASURE_H__ #define __MEASURE_H__ #include #include #include #include "IfActions.h" #include "Litestep.h" #include "Section.h" enum AUTOSCALE { AUTOSCALE_1024 = 1, // scales by 1024 AUTOSCALE_1000 = 2, // scales by 1000 AUTOSCALE_1024K = 101, // scales by 1024, and uses kilo as the lowest unit AUTOSCALE_1000K = 102, // scales by 1000, and uses kilo as the lowest unit AUTOSCALE_OFF = 0, AUTOSCALE_ON = AUTOSCALE_1024 }; class MeasureValueSet { public: MeasureValueSet(double val, const WCHAR* str) : m_Value(val), m_StringValue(str) {} void Set(double val, const WCHAR* str) { m_Value = val; m_StringValue = str; } bool IsChanged(double val, const WCHAR* str) { if (m_Value != val || wcscmp(m_StringValue.c_str(), str) != 0) { Set(val, str); return true; } return false; } private: double m_Value; std::wstring m_StringValue; }; class Meter; class MeterWindow; class ConfigParser; class __declspec(novtable) Measure : public Section { public: virtual ~Measure(); void ReadOptions(ConfigParser& parser) { ReadOptions(parser, GetName()); } virtual void Initialize(); bool Update(); void Disable(); void Enable(); bool IsDisabled() { return m_Disabled; } void Pause(); void Unpause(); bool IsPaused() { return m_Paused; } virtual void Command(const std::wstring& command); double GetValue(); double GetRelativeValue(); double GetValueRange(); double GetMinValue() { return m_MinValue; } double GetMaxValue() { return m_MaxValue; } virtual const WCHAR* GetStringValue(); const WCHAR* GetStringOrFormattedValue(AUTOSCALE autoScale, double scale, int decimals, bool percentual); const WCHAR* GetFormattedValue(AUTOSCALE autoScale, double scale, int decimals, bool percentual); static void GetScaledValue(AUTOSCALE autoScale, int decimals, double theValue, WCHAR* buffer, size_t sizeInWords); static void RemoveTrailingZero(WCHAR* str, int strLen); const std::wstring& GetOnChangeAction() { return m_OnChangeAction; } void DoChangeAction(bool execute = true); static Measure* Create(const WCHAR* measure, MeterWindow* meterWindow, const WCHAR* name); static bool GetCurrentMeasureValue(const WCHAR* str, int len, double* value, void* context); protected: Measure(MeterWindow* meterWindow, const WCHAR* name); virtual void ReadOptions(ConfigParser& parser, const WCHAR* section); virtual void UpdateValue() = 0; bool ParseSubstitute(std::wstring buffer); std::wstring ExtractWord(std::wstring& buffer); const WCHAR* CheckSubstitute(const WCHAR* buffer); bool MakePlainSubstitute(std::wstring& str, size_t index); bool m_Invert; // If true, the value should be inverted bool m_LogMaxValue; // If true, The maximum & minimum values are logged double m_MinValue; // The minimum value (so far) double m_MaxValue; // The maximum value (so far) double m_Value; // The current value std::vector m_Substitute; // Vec of substitute strings bool m_RegExpSubstitute; std::vector m_MedianValues; // The values for the median filtering UINT m_MedianPos; // Position in the median array, where the new value is placed std::vector m_AverageValues; UINT m_AveragePos; UINT m_AverageSize; IfActions m_IfActions; bool m_Disabled; // Status of the measure bool m_Paused; bool m_Initialized; std::wstring m_OnChangeAction; MeasureValueSet* m_OldValue; bool m_ValueAssigned; }; #endif