Committing JamesAC / spx changes to SpeedFan plugin to support conversion of default Centigrade temp values to Fahrenheit or Kelvin. Also manual update to support change.

This commit is contained in:
jsmorley 2010-05-09 17:14:20 +00:00
parent d0fe23ec1f
commit befa90ce8f
3 changed files with 63 additions and 15 deletions

View File

@ -28,8 +28,8 @@ LANGUAGE LANG_FINNISH, SUBLANG_DEFAULT
//
VS_VERSION_INFO VERSIONINFO
FILEVERSION 1,2,0,399
PRODUCTVERSION 1,2,0,399
FILEVERSION 1,2,0,401
PRODUCTVERSION 1,2,0,401
FILEFLAGSMASK 0x17L
#ifdef _DEBUG
FILEFLAGS 0x1L
@ -45,12 +45,12 @@ BEGIN
BLOCK "040b04b0"
BEGIN
VALUE "FileDescription", "Rainmeter - A Customizable Resource Meter"
VALUE "FileVersion", "1, 2, 0, 399"
VALUE "FileVersion", "1, 2, 0, 401"
VALUE "InternalName", "Rainmeter"
VALUE "LegalCopyright", "Copyright (C) 2010 - Rainy"
VALUE "OriginalFilename", "Rainmeter.exe"
VALUE "ProductName", "Rainmeter"
VALUE "ProductVersion", "1, 2, 0, 399"
VALUE "ProductVersion", "1, 2, 0, 401"
END
END
BLOCK "VarFileInfo"

View File

@ -58,9 +58,17 @@ enum SensorType
TYPE_VOLT
};
bool ReadSharedData(SensorType type, UINT number, double* value);
enum TempScale
{
SCALE_CENTIGRADE,
SCALE_FARENHEIT,
SCALE_KELVIN
};
bool ReadSharedData(SensorType type, TempScale scale, UINT number, double* value);
static std::map<UINT, SensorType> g_Types;
static std::map<UINT, TempScale> g_Scales;
static std::map<UINT, UINT> g_Numbers;
/*
@ -84,6 +92,29 @@ UINT Initialize(HMODULE instance, LPCTSTR iniFile, LPCTSTR section, UINT id)
if (wcsicmp(L"TEMPERATURE", type) == 0)
{
g_Types[id] = TYPE_TEMP;
LPCTSTR scale = ReadConfigString(section, L"SpeedFanScale", L"C");
if (scale)
{
if (wcsicmp(L"C", scale) == 0)
{
g_Scales[id] = SCALE_CENTIGRADE;
}
else if (wcsicmp(L"F", scale) == 0)
{
g_Scales[id] = SCALE_FARENHEIT;
}
else if (wcsicmp(L"K", scale) == 0)
{
g_Scales[id] = SCALE_KELVIN;
}
else
{
std::wstring error = L"No such SpeedFanScale: ";
error += scale;
MessageBox(NULL, error.c_str(), L"Rainmeter", MB_OK);
}
}
}
else if (wcsicmp(L"FAN", type) == 0)
{
@ -116,22 +147,23 @@ The function returns the new value.
*/
double Update2(UINT id)
{
double value = 0;
double value = 0.0;
std::map<UINT, SensorType>::iterator type = g_Types.find(id);
std::map<UINT, UINT>::iterator number = g_Numbers.find(id);
std::map<UINT, SensorType>::const_iterator type = g_Types.find(id);
std::map<UINT, TempScale>::const_iterator scale = g_Scales.find(id);
std::map<UINT, UINT>::const_iterator number = g_Numbers.find(id);
if(type == g_Types.end() || number == g_Numbers.end())
if(type == g_Types.end() || number == g_Numbers.end() || ((*type).second == TYPE_TEMP && scale == g_Scales.end()))
{
return 0; // No id in the map. How this can be ????
return 0.0; // No id in the map. How this can be ????
}
if (ReadSharedData((*type).second, (*number).second, &value))
if (ReadSharedData((*type).second, (*scale).second, (*number).second, &value))
{
return value;
}
return 0;
return 0.0;
}
/*
@ -152,12 +184,18 @@ void Finalize(HMODULE instance, UINT id)
{
g_Numbers.erase(i2);
}
std::map<UINT, TempScale>::iterator i3 = g_Scales.find(id);
if (i3 != g_Scales.end())
{
g_Scales.erase(i3);
}
}
/*
Get the data from shared memory.
*/
bool ReadSharedData(SensorType type, UINT number, double* value)
bool ReadSharedData(SensorType type, TempScale scale, UINT number, double* value)
{
SpeedFanData* ptr;
HANDLE hData;
@ -181,6 +219,16 @@ bool ReadSharedData(SensorType type, UINT number, double* value)
{
*value = ptr->temps[number];
*value /= 100.0;
if (scale == SCALE_FARENHEIT)
{
*value *= 1.8;
*value += 32.0;
}
else if (scale == SCALE_KELVIN)
{
*value += 273.15;
}
}
break;
@ -213,7 +261,7 @@ bool ReadSharedData(SensorType type, UINT number, double* value)
UINT GetPluginVersion()
{
return 1001;
return 1002;
}
LPCTSTR GetPluginAuthor()

View File

@ -1,2 +1,2 @@
#pragma once
const int revision_number = 399;
const int revision_number = 401;