rainmeter-studio/Library/MeasureCalc.h

56 lines
1.5 KiB
C
Raw Normal View History

2009-02-10 18:37:48 +00:00
/*
Copyright (C) 2004 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.
2009-02-10 18:37:48 +00:00
*/
#ifndef __MEASURECALC_H__
#define __MEASURECALC_H__
#include "Measure.h"
2013-05-31 14:18:52 +00:00
class MeasureCalc : public Measure
2009-02-10 18:37:48 +00:00
{
public:
2013-05-31 14:18:52 +00:00
MeasureCalc(MeterWindow* meterWindow, const WCHAR* name);
virtual ~MeasureCalc();
2009-02-10 18:37:48 +00:00
2013-05-31 14:18:52 +00:00
virtual UINT GetTypeID() { return TypeID<MeasureCalc>(); }
2012-04-09 16:45:54 +00:00
protected:
2013-05-31 14:18:52 +00:00
virtual void ReadOptions(ConfigParser& parser, const WCHAR* section);
virtual void UpdateValue();
2009-02-10 18:37:48 +00:00
private:
2013-06-13 14:00:24 +00:00
static bool GetMeasureValue(const WCHAR* str, int len, double* value, void* context);
2012-01-23 09:30:51 +00:00
void FormulaReplace();
int GetRandom();
2009-02-10 18:37:48 +00:00
std::wstring m_Formula;
bool m_ParseError;
2012-01-23 07:21:03 +00:00
int m_LowBound;
int m_HighBound;
2012-01-23 09:30:51 +00:00
bool m_UpdateRandom;
bool m_UniqueRandom;
std::vector<int> m_UniqueNumbers;
void UpdateUniqueNumberList();
2009-02-10 18:37:48 +00:00
};
#endif