1518 lines
55 KiB
Diff
1518 lines
55 KiB
Diff
|
diff -Nru wmlaptop-1.4-orig/src/battery.c wmlaptop-1.4/src/battery.c
|
||
|
--- wmlaptop-1.4-orig/src/battery.c 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/battery.c 2008-04-18 21:56:45.002550126 +0300
|
||
|
@@ -15,6 +15,8 @@
|
||
|
*/
|
||
|
|
||
|
#include "battery.h"
|
||
|
+#include <dirent.h>
|
||
|
+
|
||
|
|
||
|
bool mallocBatteryVector( )
|
||
|
{
|
||
|
@@ -96,9 +98,10 @@
|
||
|
}
|
||
|
|
||
|
powerState.type = SUPPORT_ACPI;
|
||
|
- powerState.updater = ACPI_Update;
|
||
|
+ powerState.updater = print_battery;
|
||
|
+
|
||
|
+
|
||
|
|
||
|
- /* counting number of batteries */
|
||
|
powerState.nBatt = 0;
|
||
|
powerState.batteryVector = NULL;
|
||
|
|
||
|
@@ -108,26 +111,23 @@
|
||
|
return ERROR;
|
||
|
}
|
||
|
|
||
|
- /* a cicle for creating as many battery_str structures
|
||
|
- * as are the batteries on the laptop; everyone will be
|
||
|
- * filled with static informations */
|
||
|
+
|
||
|
while ((batt = readdir (battdir)))
|
||
|
{
|
||
|
|
||
|
name = batt->d_name;
|
||
|
- /* jump . and .. */
|
||
|
+
|
||
|
if (!strncmp (".", name, 1) || !strncmp ("..", name, 2))
|
||
|
continue;
|
||
|
|
||
|
countBattery++;
|
||
|
|
||
|
- /* adding a battery to powerState vector */
|
||
|
+
|
||
|
if( mallocBatteryVector( ) == ERROR )
|
||
|
return ERROR;
|
||
|
|
||
|
batPtr = powerState.batteryVector[ powerState.nBatt - 1 ];
|
||
|
|
||
|
- /* we can find 'status' or even 'state' */
|
||
|
snprintf( path, 52, "%s/%s/status", ACPI_BATTERY_DIR, name );
|
||
|
if (access(path, R_OK) == SUCCESS )
|
||
|
snprintf( batPtr -> stateFile, 52, "%s/%s/status",ACPI_BATTERY_DIR, name );
|
||
|
@@ -135,20 +135,17 @@
|
||
|
snprintf( batPtr -> stateFile, 52, "%s/%s/state", ACPI_BATTERY_DIR, name );
|
||
|
|
||
|
|
||
|
- /* calculating maximum capacity of this battery
|
||
|
- * reading file infos */
|
||
|
+
|
||
|
batPtr -> useLFC = ACPI_lfcArgs_get( countBattery );
|
||
|
batPtr -> counter = countBattery;
|
||
|
snprintf( batPtr -> infoFile, 52, "%s/%s/info", ACPI_BATTERY_DIR, name );
|
||
|
batPtr -> present = ACPI_maxCapacity ( batPtr );
|
||
|
|
||
|
- /* THIS IS NOT A BATTERY ! set error field to true: don't use it */
|
||
|
if( batPtr -> capacity == ~0x00 && batPtr -> present == true )
|
||
|
{
|
||
|
batPtr -> error = true;
|
||
|
}
|
||
|
|
||
|
- /* filler selection :P */
|
||
|
batPtr -> filler = ACPI_Filler;
|
||
|
}
|
||
|
|
||
|
@@ -166,8 +163,6 @@
|
||
|
u_int16 saltCounter = 0;
|
||
|
char * errorMessage = "wmlaptop will ignore this battery. If you don't want to see\nthis message, use '-q' option as argument.\n";
|
||
|
|
||
|
- /* we control 'last full capacity' tag before, if this
|
||
|
- * don't exists or it's value is 0, then we use 'design capacity' */
|
||
|
char * lfcTagPointer = NULL;
|
||
|
char * dcTagPointer = NULL;
|
||
|
u_int32 lastFullCapacity = 0;
|
||
|
@@ -189,7 +184,7 @@
|
||
|
|
||
|
if( !strcmp( presentString, "present:" ) && !strcmp( yesNoString, "no" ) )
|
||
|
{
|
||
|
- /* to avoid division by 0 ? */
|
||
|
+
|
||
|
p -> capacity = 1;
|
||
|
return false;
|
||
|
}
|
||
|
@@ -207,11 +202,11 @@
|
||
|
}
|
||
|
|
||
|
|
||
|
- /* naah.. */
|
||
|
+
|
||
|
if( saltCounter >= 492 && !dcTagPointer && !lfcTagPointer )
|
||
|
{
|
||
|
PRINTQ( stderr, "The info file (%s) has not \n'design capacity' and not event 'last full capacity' tag\n%s\n", p -> infoFile, errorMessage );
|
||
|
- /* we treat 1111.1111.1111.1111 as error here */
|
||
|
+
|
||
|
p -> capacity = ~0x00;
|
||
|
}
|
||
|
|
||
|
@@ -340,66 +335,6 @@
|
||
|
}
|
||
|
|
||
|
|
||
|
-void ACPI_Update ( )
|
||
|
-{
|
||
|
- FILE * fp;
|
||
|
- char *where = NULL;
|
||
|
- char buf[512];
|
||
|
-
|
||
|
- register int i;
|
||
|
- register u_int32 capacitySum = 0;
|
||
|
- register u_int32 actualStateSum = 0;
|
||
|
-
|
||
|
- for( i = 0; i < powerState.nBatt; i++ )
|
||
|
- {
|
||
|
- powerState.batteryVector[i] -> filler( powerState.batteryVector[i] );
|
||
|
- if (powerState.batteryVector[i] -> present) {
|
||
|
- capacitySum += powerState.batteryVector[i] -> capacity;
|
||
|
- actualStateSum += powerState.batteryVector[i] -> actualState;
|
||
|
- }
|
||
|
- }
|
||
|
-
|
||
|
- if (capacitySum > 0)
|
||
|
- powerState.percentage = (actualStateSum * 100) / capacitySum;
|
||
|
- else
|
||
|
- powerState.percentage = 0;
|
||
|
-
|
||
|
- /* battery charger information reading
|
||
|
- * thanks to wmpower */
|
||
|
-
|
||
|
- if (!(fp = fopen ("/proc/acpi/ac_adapter/0/status", "r")))
|
||
|
- if (!(fp = fopen ("/proc/acpi/ac_adapter/ACAD/state", "r")))
|
||
|
- if (!(fp = fopen ("/proc/acpi/ac_adapter/AC/state", "r")))
|
||
|
- if (!(fp = fopen ("/proc/acpi/ac_adapter/ADP1/state", "r")))
|
||
|
- return;
|
||
|
-
|
||
|
- fread_unlocked (buf, 512, 1, fp);
|
||
|
- fclose(fp);
|
||
|
-
|
||
|
- if (strncmp(buf, "state:", 6) == 0)
|
||
|
- where = buf + 26;
|
||
|
- if (strncmp(buf, "Status:", 7) == 0)
|
||
|
- where = buf + 26;
|
||
|
-
|
||
|
- if (where)
|
||
|
- {
|
||
|
- if (where[0] == 'n')
|
||
|
- powerState.isCharging = true;
|
||
|
- if (where[0] == 'f')
|
||
|
- powerState.isCharging = false;
|
||
|
- }
|
||
|
-
|
||
|
- if( args_ttyMode )
|
||
|
- return;
|
||
|
-
|
||
|
-
|
||
|
- setNewBatteryState();
|
||
|
-
|
||
|
-
|
||
|
- return;
|
||
|
-}
|
||
|
-
|
||
|
-
|
||
|
/* this vector will contain in each position the number of the
|
||
|
* battery the user wants to be used with 'last full capacity' */
|
||
|
static u_int8 * lfcArgsVector = NULL;
|
||
|
@@ -571,7 +506,7 @@
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
- estimatedTimeClock( );
|
||
|
+ print_battery( );
|
||
|
}
|
||
|
draw_all();
|
||
|
lastChargingState = powerState.isCharging;
|
||
|
@@ -580,101 +515,177 @@
|
||
|
}
|
||
|
}
|
||
|
|
||
|
+void read_power()
|
||
|
+{
|
||
|
+ DIR *dir;
|
||
|
+ struct dirent *dirent;
|
||
|
+ FILE *file;
|
||
|
+ extern double powerrate;
|
||
|
+ char filename[256];
|
||
|
|
||
|
|
||
|
-void estimatedTimeClock ( )
|
||
|
-{
|
||
|
- /* we remember last 5 percent values changes.
|
||
|
- * for every value we record even the exact moment when this
|
||
|
- * value was recorded (reading global variable secondsCounter) */
|
||
|
- static u_int32 values[5][2];
|
||
|
- static u_int8 valueIndex = ~0;
|
||
|
+ dir = opendir("/proc/acpi/battery");
|
||
|
+ if (!dir)
|
||
|
+ return;
|
||
|
|
||
|
- static bool lastIsCharging = false;
|
||
|
+ while ((dirent = readdir(dir))) {
|
||
|
|
||
|
- register u_int8 diffPercentage = 0;
|
||
|
- register u_int32 diffTime = 0;
|
||
|
- register int i;
|
||
|
+ char line[1024];
|
||
|
+
|
||
|
+ sprintf(filename, "/proc/acpi/battery/%s/state", dirent->d_name);
|
||
|
+ file = fopen(filename, "r");
|
||
|
+ if (!file)
|
||
|
+ continue;
|
||
|
+ memset(line, 0, 1024);
|
||
|
+ while (fgets(line, 1024, file) != NULL) {
|
||
|
+ char *c;
|
||
|
+ if (strstr(line, "present:") && strstr(line, "no"))
|
||
|
+ break;
|
||
|
|
||
|
+ c = strchr(line, ':');
|
||
|
+ if (!c)
|
||
|
+ continue;
|
||
|
+ c++;
|
||
|
|
||
|
- /* if battery charge is plugged in, values fetched before are
|
||
|
- * reset to zero and return (draw_all() function already called
|
||
|
- * by updater will draw TIME unlit, to indicate that we haven't
|
||
|
- * a time estimation */
|
||
|
- if( lastIsCharging != powerState.isCharging )
|
||
|
- {
|
||
|
- lastIsCharging = powerState.isCharging;
|
||
|
- valueIndex = ~0;
|
||
|
- powerState.remainingTime = 0;
|
||
|
- return;
|
||
|
+ if (strstr(line, "present rate") && strstr(c, "mW"))
|
||
|
+ powerrate = strtoull(c, NULL, 10) / 1000.0;
|
||
|
}
|
||
|
+ fclose(file);
|
||
|
|
||
|
+ }
|
||
|
+ closedir(dir);
|
||
|
+// fprintf(stdout,"powerrate = %3.1f\n", powerrate);
|
||
|
|
||
|
- for( i = 4; i > 0; i-- )
|
||
|
- {
|
||
|
- values[i][1] = values[i-1][1];
|
||
|
- values[i][0] = values[i-1][0];
|
||
|
+}
|
||
|
+
|
||
|
+
|
||
|
+void battery_capacity()
|
||
|
+{
|
||
|
+ DIR *dir;
|
||
|
+ struct dirent *dirent;
|
||
|
+ FILE *file;
|
||
|
+ extern double capacity;
|
||
|
+ char filename[256];
|
||
|
+
|
||
|
+
|
||
|
+ dir = opendir("/proc/acpi/battery");
|
||
|
+ if (!dir)
|
||
|
+ return;
|
||
|
+
|
||
|
+ while ((dirent = readdir(dir))) {
|
||
|
+
|
||
|
+ char line[1024];
|
||
|
+
|
||
|
+ sprintf(filename, "/proc/acpi/battery/%s/info", dirent->d_name);
|
||
|
+ file = fopen(filename, "r");
|
||
|
+ if (!file)
|
||
|
+ continue;
|
||
|
+ memset(line, 0, 1024);
|
||
|
+ while (fgets(line, 1024, file) != NULL) {
|
||
|
+ char *c;
|
||
|
+ if (strstr(line, "present:") && strstr(line, "no"))
|
||
|
+ break;
|
||
|
+
|
||
|
+ c = strchr(line, ':');
|
||
|
+ if (!c)
|
||
|
+ continue;
|
||
|
+ c++;
|
||
|
+
|
||
|
+ if (strstr(line, "last full capacity") && strstr(c, "mWh"))
|
||
|
+ capacity = strtoull(c, NULL, 10) / 1000.0;
|
||
|
+ }
|
||
|
+ fclose(file);
|
||
|
}
|
||
|
- values[i][0] = powerState.percentage;
|
||
|
- values[i][1] = secondsCounter;
|
||
|
+ closedir(dir);
|
||
|
+// fprintf(stdout,"capacity = %3.1f\n", capacity);
|
||
|
|
||
|
+}
|
||
|
|
||
|
- valueIndex += 1;
|
||
|
- if( valueIndex > 4 )
|
||
|
- valueIndex = 4;
|
||
|
+void print_battery(void)
|
||
|
+{
|
||
|
+ DIR *dir;
|
||
|
+ struct dirent *dirent;
|
||
|
+ FILE *file;
|
||
|
+ double rate = 0;
|
||
|
+ double cap = 0;
|
||
|
|
||
|
- /* if it's the first measure, jump the comparation */
|
||
|
- if( valueIndex > 0 )
|
||
|
- {
|
||
|
- u_int32 remainingSeconds;
|
||
|
- /* we have into values[0] the most recent value,
|
||
|
- * and in values[ valueIndex ] the less one */
|
||
|
+ char filename[256];
|
||
|
|
||
|
- if( powerState.isCharging )
|
||
|
- diffPercentage = values[0][0] - values[ valueIndex ][0];
|
||
|
- else
|
||
|
- diffPercentage = values[ valueIndex ][0] - values[0][0];
|
||
|
|
||
|
- diffTime = values[0][1] - values[ valueIndex ][1];
|
||
|
+ dir = opendir("/proc/acpi/battery");
|
||
|
+ if (!dir)
|
||
|
+ return;
|
||
|
+
|
||
|
+ while ((dirent = readdir(dir))) {
|
||
|
+ double voltage = 0.0;
|
||
|
+ double amperes_drawn = 0.0;
|
||
|
+ double watts_drawn = 0.0;
|
||
|
+ double amperes_left = 0.0;
|
||
|
+ double watts_left = 0.0;
|
||
|
+ char line[1024];
|
||
|
+ powerState.isCharging = false;
|
||
|
+
|
||
|
+ if (strlen(dirent->d_name) < 3)
|
||
|
+ continue;
|
||
|
+
|
||
|
+ sprintf(filename, "/proc/acpi/battery/%s/state", dirent->d_name);
|
||
|
+ file = fopen(filename, "r");
|
||
|
+ if (!file)
|
||
|
+ continue;
|
||
|
+ memset(line, 0, 1024);
|
||
|
+ while (fgets(line, 1024, file) != NULL) {
|
||
|
+ char *c;
|
||
|
+ if (strstr(line, "present:") && strstr(line, "no"))
|
||
|
+ break;
|
||
|
|
||
|
- /* this is the logic way: if diffTime is the number of seconds for
|
||
|
- * losing(gaining) diffPercentage percent battery charge, how many
|
||
|
- * seconds will it takes to lose(gain) remaining points ? in other words:
|
||
|
- * diffTime : diffPercentage = remainingSeconds : powerState.percentage
|
||
|
- * (or if we are charging = remainingSeconds : (100-powerState.percentage))
|
||
|
- * it shouldn't be possible to have diffPercentage = 0
|
||
|
- * because this function is called everytime that percent changes */
|
||
|
- if( diffPercentage == 0 )
|
||
|
- {
|
||
|
- /* sometime it happends that 'diffPercentage == 0': i recieved some bug
|
||
|
- * report about this. I don't know why this happends, and i didn't find
|
||
|
- * any way to correct this conceptually, so i have to put this condition
|
||
|
- * here and turn off the estimated remaining time */
|
||
|
- PRINTQ( stderr, "There is no difference of percentage between the first\n");
|
||
|
- PRINTQ( stderr, "relevation and the last one: i have to put remainingTime to 0\n");
|
||
|
- remainingSeconds = 0;
|
||
|
+ if (strstr(line, "charging state:")
|
||
|
+ && !strstr(line, "discharging")){
|
||
|
+ powerState.isCharging = true;
|
||
|
}
|
||
|
- else
|
||
|
- {
|
||
|
- if( powerState.isCharging )
|
||
|
- remainingSeconds = ( diffTime * (100-powerState.percentage) ) / diffPercentage;
|
||
|
- else
|
||
|
- remainingSeconds = ( diffTime * powerState.percentage ) / diffPercentage;
|
||
|
+ c = strchr(line, ':');
|
||
|
+ if (!c)
|
||
|
+ continue;
|
||
|
+ c++;
|
||
|
+
|
||
|
+ if (strstr(line, "present voltage"))
|
||
|
+ voltage = strtoull(c, NULL, 10) / 1000.0;
|
||
|
+
|
||
|
+ if (strstr(line, "remaining capacity") && strstr(c, "mW"))
|
||
|
+ watts_left = strtoull(c, NULL, 10) / 1000.0;
|
||
|
+
|
||
|
+ if (strstr(line, "remaining capacity") && strstr(c, "mAh"))
|
||
|
+ amperes_left = strtoull(c, NULL, 10) / 1000.0;
|
||
|
+
|
||
|
+ if (strstr(line, "present rate") && strstr(c, "mW"))
|
||
|
+ watts_drawn = strtoull(c, NULL, 10) / 1000.0 ;
|
||
|
+
|
||
|
+ if (strstr(line, "present rate") && strstr(c, "mA"))
|
||
|
+ amperes_drawn = strtoull(c, NULL, 10) / 1000.0;
|
||
|
+
|
||
|
}
|
||
|
+ fclose(file);
|
||
|
+
|
||
|
|
||
|
- /* value in minutes */
|
||
|
- powerState.remainingTime = remainingSeconds / 60;
|
||
|
- }
|
||
|
- else
|
||
|
- powerState.remainingTime = 0;
|
||
|
-
|
||
|
+ if (!powerState.isCharging) {
|
||
|
+ rate += watts_drawn + voltage * amperes_drawn;
|
||
|
+ cap += watts_left + voltage * amperes_left;
|
||
|
+ powerState.remainingTime = 60*cap/rate;
|
||
|
+ powerrate = rate;
|
||
|
+// fprintf(stdout,"taxa = %3.1fW horas=%3.1f \n", rate, cap/rate);
|
||
|
+ }
|
||
|
+ if (powerState.isCharging){
|
||
|
+ rate += watts_drawn + voltage * amperes_drawn;
|
||
|
+// fprintf(stdout,"watts left = %3.1f, watts drawn=%3.1f \n", watts_left, watts_drawn);
|
||
|
+ /* time to charge battery at 100% */
|
||
|
+ powerState.remainingTime = 60*(capacity - watts_left)/watts_drawn;
|
||
|
+ }
|
||
|
+
|
||
|
+ powerrate = rate;
|
||
|
+ powerState.percentage = 100*(watts_left/capacity);
|
||
|
+// fprintf(stdout, "capacidade = %3.1f \n", capacity);
|
||
|
+// fprintf(stdout,"porcentagem = %d \n", powerState.percentage);
|
||
|
|
||
|
-#ifdef DEBUG
|
||
|
- printf("TEMPO TRASCORSO: %u:%02u (%u secondi)\n",diffTime/60,diffTime%60,diffTime);
|
||
|
- printf("PERCENTUALI: values[0] = %u, values[%d] = %u\n", values[0][0], valueIndex, values[valueIndex][0] );
|
||
|
- printf("TEMPIVALORI: values[0] = %u, values[%d] = %u\n", values[0][1], valueIndex, values[valueIndex][1] );
|
||
|
- printf("DIFFENREZA: %d\n", diffPercentage );
|
||
|
- printf("TEMPOSTIMATO: %d\n\n\n", powerState.remainingTime );
|
||
|
-#endif
|
||
|
+ }
|
||
|
+ closedir(dir);
|
||
|
}
|
||
|
|
||
|
diff -Nru wmlaptop-1.4-orig/src/battery.h wmlaptop-1.4/src/battery.h
|
||
|
--- wmlaptop-1.4-orig/src/battery.h 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/battery.h 2008-04-18 21:56:45.002550126 +0300
|
||
|
@@ -109,11 +109,10 @@
|
||
|
* state is changed. */
|
||
|
void setNewBatteryState( );
|
||
|
|
||
|
+void read_power();
|
||
|
|
||
|
-/* function invoked every time that remaining battery percentage changes
|
||
|
- * and calculates estimated remaining time.
|
||
|
- * (if changed from previous updates the dockapp */
|
||
|
-void estimatedTimeClock ( );
|
||
|
+void battery_capacity();
|
||
|
|
||
|
+void print_battery();
|
||
|
|
||
|
#endif
|
||
|
diff -Nru wmlaptop-1.4-orig/src/cpu.c wmlaptop-1.4/src/cpu.c
|
||
|
--- wmlaptop-1.4-orig/src/cpu.c 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/cpu.c 2008-04-18 21:56:45.002550126 +0300
|
||
|
@@ -65,10 +65,9 @@
|
||
|
return loadline;
|
||
|
}
|
||
|
|
||
|
-
|
||
|
void manageCpuLoad( )
|
||
|
{
|
||
|
- static u_int8 lastCpuLoad = 100;
|
||
|
+// static u_int8 lastCpuLoad = 100;
|
||
|
#ifndef LONGRUN
|
||
|
static u_int32 lastFreqChange = 0;
|
||
|
#endif
|
||
|
@@ -76,10 +75,10 @@
|
||
|
cpuLoad = getCpuLoad();
|
||
|
|
||
|
|
||
|
- if( cpuLoad != lastCpuLoad || cpuLoad == 100 )
|
||
|
- draw_all();
|
||
|
+// if( cpuLoad != lastCpuLoad || cpuLoad == 100 )
|
||
|
+// draw_all();
|
||
|
|
||
|
- lastCpuLoad = cpuLoad;
|
||
|
+// lastCpuLoad = cpuLoad;
|
||
|
|
||
|
|
||
|
/* Longrun manages frequency automatically, so skip all this */
|
||
|
@@ -120,7 +119,7 @@
|
||
|
|
||
|
/* let's read actual frequency to avoid a two seconds wait
|
||
|
* dto now it */
|
||
|
- cpuReadFreq();
|
||
|
+// cpuReadFreq();
|
||
|
#endif
|
||
|
|
||
|
return;
|
||
|
@@ -130,10 +129,14 @@
|
||
|
|
||
|
void cpuReadFreq( )
|
||
|
{
|
||
|
+
|
||
|
#ifndef LONGRUN
|
||
|
FILE * fp;
|
||
|
char red[10];
|
||
|
|
||
|
+ if (governor != 1)
|
||
|
+ cpuState.setFreqFile = "/sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq";
|
||
|
+
|
||
|
if( (fp = fopen( cpuState.setFreqFile, "r" )) == NULL )
|
||
|
{
|
||
|
fprintf(stderr, "Error reading the info file (%s):\n%s\n", cpuState.setFreqFile, strerror(errno) );
|
||
|
@@ -170,19 +173,50 @@
|
||
|
}
|
||
|
|
||
|
|
||
|
+void cpuReadTemp( ){
|
||
|
+ DIR *dir;
|
||
|
+ struct dirent *dirent;
|
||
|
+ FILE *file;
|
||
|
+ int cpuTemp = 0;
|
||
|
+ char filename[256];
|
||
|
|
||
|
-void cpuCheckFreq()
|
||
|
-{
|
||
|
- static u_int32 lastCpuFreq = 0;
|
||
|
+ dir = opendir("/proc/acpi/thermal_zone");
|
||
|
+ if (!dir){
|
||
|
+ return;
|
||
|
+ }
|
||
|
+ while ((dirent = readdir(dir))) {
|
||
|
+ char line[1024];
|
||
|
|
||
|
- cpuReadFreq();
|
||
|
+ if (strlen(dirent->d_name) < 3)
|
||
|
+ continue;
|
||
|
|
||
|
- if( lastCpuFreq != cpuState.actualFreq )
|
||
|
- draw_all();
|
||
|
|
||
|
- lastCpuFreq = cpuState.actualFreq;
|
||
|
-}
|
||
|
+ sprintf(filename, "/proc/acpi/thermal_zone/%s/temperature", dirent->d_name);
|
||
|
+ file = fopen(filename, "r");
|
||
|
+ if (!file)
|
||
|
+ continue;
|
||
|
+ memset(line, 0, 1024);
|
||
|
+ while (fgets(line, 1024, file) != NULL) {
|
||
|
+ char *c;
|
||
|
+ // if (strstr(line, "present:") && strstr(line, "no"))
|
||
|
+ // break;
|
||
|
+
|
||
|
+ c = strchr(line, ':');
|
||
|
+ if (!c)
|
||
|
+ continue;
|
||
|
+ c++;
|
||
|
+
|
||
|
+ if (strstr(line, "temperature") && strstr(c, "C"))
|
||
|
+ cpuTemp = strtoull(c, NULL, 10);
|
||
|
|
||
|
+ }
|
||
|
+ fclose(file);
|
||
|
+
|
||
|
+ cpuState.Temp = cpuTemp;
|
||
|
+// fprintf(stdout,"temperatura = %d\n", cpuState.Temp);
|
||
|
+ }
|
||
|
+ closedir(dir);
|
||
|
+}
|
||
|
|
||
|
void cpuSetFreq( bool direction, bool speed )
|
||
|
{
|
||
|
diff -Nru wmlaptop-1.4-orig/src/cpu.h wmlaptop-1.4/src/cpu.h
|
||
|
--- wmlaptop-1.4-orig/src/cpu.h 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/cpu.h 2008-04-18 21:56:45.003550530 +0300
|
||
|
@@ -37,6 +37,8 @@
|
||
|
* global variable cpuState */
|
||
|
void cpuReadFreq( );
|
||
|
|
||
|
+/* read cpu temperature and puts into cpuState.Temp */
|
||
|
+void cpuReadTemp();
|
||
|
|
||
|
/* invoked by events cycle e time every 2 seconds, it reads actual
|
||
|
* frequency (calling readCpuFreq) and it redraws the dockapp if it's
|
||
|
diff -Nru wmlaptop-1.4-orig/src/draw.c wmlaptop-1.4/src/draw.c
|
||
|
--- wmlaptop-1.4-orig/src/draw.c 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/draw.c 2008-04-18 21:56:45.003550530 +0300
|
||
|
@@ -16,6 +16,7 @@
|
||
|
|
||
|
#include "draw.h"
|
||
|
|
||
|
+extern double powerrate;
|
||
|
|
||
|
void draw_area(int sx, int sy, int w, int h, int dx, int dy)
|
||
|
{
|
||
|
@@ -37,9 +38,13 @@
|
||
|
|
||
|
draw_cpuload ( );
|
||
|
|
||
|
+ if (governor == 1){ // 1 means userspace
|
||
|
draw_auto_freq ( );
|
||
|
-
|
||
|
draw_freq_arrows ( );
|
||
|
+ } else {
|
||
|
+ draw_cputemp();
|
||
|
+ draw_powerrate();
|
||
|
+ }
|
||
|
|
||
|
draw_actual_freq ( );
|
||
|
|
||
|
@@ -59,6 +64,18 @@
|
||
|
/* Mhz */
|
||
|
draw_area( 46, 119, 15, 9, 38, 51 );
|
||
|
|
||
|
+ // colocar graus C e Watts se ondemand
|
||
|
+ /* C */
|
||
|
+ if (governor == 2){
|
||
|
+ /* draw C (Celsius) */
|
||
|
+ draw_area( 0, 117, 4, 7, 52, 36 );
|
||
|
+ /* draw W (Watts) */
|
||
|
+ if (powerState.isCharging)
|
||
|
+ draw_area( 70, 130, 9, 7, 25, 37 );
|
||
|
+ else
|
||
|
+ draw_area( 81, 130, 9, 7, 25, 37 );
|
||
|
+ }
|
||
|
+
|
||
|
/* two gray lines */
|
||
|
draw_area( 66, 118, 55, 1, 4, 24 );
|
||
|
draw_area( 66, 118, 55, 1, 4, 48 );
|
||
|
@@ -87,10 +104,6 @@
|
||
|
|
||
|
u_int8 numBars;
|
||
|
int i;
|
||
|
- int j;
|
||
|
- int battery = 0;
|
||
|
- int batterySlot;
|
||
|
- int presentBatteries = 0;
|
||
|
|
||
|
if( powerState.percentage == 100 )
|
||
|
/* drawing the green <1> at first position*/
|
||
|
@@ -118,30 +131,15 @@
|
||
|
/* drawing <%> symbol of the right color */
|
||
|
draw_area( 40, baseY, 7, 7, 20, 5 );
|
||
|
|
||
|
-
|
||
|
- /* let's see, how many batteries are present */
|
||
|
- for ( batterySlot = 0; batterySlot < powerState.nBatt; batterySlot ++ )
|
||
|
- if (powerState.batteryVector[batterySlot] -> present)
|
||
|
- presentBatteries ++;
|
||
|
-
|
||
|
-
|
||
|
- for( batterySlot = 0; batterySlot < powerState.nBatt; batterySlot ++ ) {
|
||
|
-
|
||
|
- if (powerState.batteryVector[batterySlot] -> present) {
|
||
|
- battery ++;
|
||
|
-
|
||
|
/* battery drawing */
|
||
|
- numBars = (22 * powerState.batteryVector[batterySlot] -> percentage) / 100;
|
||
|
+ numBars = (22 * powerState.percentage) / 100;
|
||
|
|
||
|
for( i = 0; i < numBars; i++ )
|
||
|
- draw_area( 49 + ( i > 10 ? i - 11 : i ), 95 + ( i > 10 ? 7 : 0), 1, (7 / presentBatteries), 15+(i*2), 15 + (battery - 1) * (7 / presentBatteries + 1 ) );
|
||
|
+ draw_area( 49 + ( i > 10 ? i - 11 : i ), 95 + ( i > 10 ? 7 : 0), 1, (7 / 1), 15+(i*2), 15 );
|
||
|
|
||
|
/* unlit remaining battery */
|
||
|
- for( j = i; j < 22; j++ )
|
||
|
- draw_area( 60, 95, 1, (7 / presentBatteries), 15 + (j*2), 15 + (battery - 1) * (7 / presentBatteries + 1 ) );
|
||
|
-
|
||
|
- }
|
||
|
- }
|
||
|
+// for( j = i; j < 22; j++ )
|
||
|
+// draw_area( 60, 95, 1, (7 / 1), 15 + (j*2), 15 + (battery - 1) * (7 / 2 ) );
|
||
|
|
||
|
return;
|
||
|
}
|
||
|
@@ -232,6 +230,60 @@
|
||
|
|
||
|
}
|
||
|
|
||
|
+void draw_cputemp ( )
|
||
|
+{
|
||
|
+
|
||
|
+ u_int8 decine = cpuState.Temp == 100 ? 0 : (cpuState.Temp / 10);
|
||
|
+ u_int8 unita = cpuState.Temp % 10;
|
||
|
+
|
||
|
+
|
||
|
+ /* tens drawing */
|
||
|
+ if( decine == 0 && cpuState.Temp != 100 )
|
||
|
+ draw_area( 57, 75, 4, 7, 49, 27 );
|
||
|
+ else
|
||
|
+ draw_area( decine*4, 71, 4, 7, 40, 36 );
|
||
|
+
|
||
|
+ /* units drawing */
|
||
|
+ draw_area( unita*4, 71, 4, 7, 45, 36 );
|
||
|
+
|
||
|
+
|
||
|
+}
|
||
|
+
|
||
|
+void draw_powerrate ( )
|
||
|
+{
|
||
|
+
|
||
|
+ u_int8 decine = 0;
|
||
|
+ u_int8 unita = 0;
|
||
|
+ u_int8 decimal = 0;
|
||
|
+
|
||
|
+ if (powerrate > 10){
|
||
|
+ decine = (powerrate / 10);
|
||
|
+ unita = powerrate - decine*10;
|
||
|
+ decimal = powerrate*10 - decine*100 - unita*10;
|
||
|
+ }
|
||
|
+ else {
|
||
|
+ decine = 0;
|
||
|
+ unita = powerrate;
|
||
|
+ decimal = powerrate*10 - unita*10;
|
||
|
+ }
|
||
|
+
|
||
|
+ /* tens drawing */
|
||
|
+ if( decine == 0 )
|
||
|
+ draw_area( 57, 75, 4, 7, 5, 37 );
|
||
|
+ else
|
||
|
+ draw_area( decine*4, 78 - powerState.isCharging*14, 4, 7, 5, 37 );
|
||
|
+
|
||
|
+ /* units drawing */
|
||
|
+ draw_area( unita*4, 78 - powerState.isCharging*14, 4, 7, 10, 37 );
|
||
|
+
|
||
|
+ /* decimal point */
|
||
|
+ draw_area( 0, 83 - powerState.isCharging*14, 2, 1, 15, 43 );
|
||
|
+
|
||
|
+ /* decimals drawing */
|
||
|
+ draw_area( decimal*4, 78 - powerState.isCharging*14, 4, 7, 18, 37 );
|
||
|
+}
|
||
|
+
|
||
|
+
|
||
|
void draw_auto_freq ( )
|
||
|
{
|
||
|
if ( cpuState.auto_freq_state ){
|
||
|
diff -Nru wmlaptop-1.4-orig/src/draw.h wmlaptop-1.4/src/draw.h
|
||
|
--- wmlaptop-1.4-orig/src/draw.h 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/draw.h 2008-04-18 21:56:45.004550097 +0300
|
||
|
@@ -53,10 +53,19 @@
|
||
|
void draw_auto_freq ( );
|
||
|
|
||
|
/* it draws the arrows at left and right of the cpu frequency */
|
||
|
+
|
||
|
void draw_freq_arrows ( );
|
||
|
|
||
|
-/* it draws actua cpu frequency */
|
||
|
+
|
||
|
+/* it draws the actual cpu frequency */
|
||
|
void draw_actual_freq ( );
|
||
|
|
||
|
+/* it draws the cpu temperature */
|
||
|
+void draw_cputemp();
|
||
|
+
|
||
|
+/* it draws the rate at which the battery is
|
||
|
+ * discharging/charging */
|
||
|
+void draw_powerrate();
|
||
|
+
|
||
|
|
||
|
#endif
|
||
|
diff -Nru wmlaptop-1.4-orig/src/event.c wmlaptop-1.4/src/event.c
|
||
|
--- wmlaptop-1.4-orig/src/event.c 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/event.c 2008-04-18 21:56:45.004550097 +0300
|
||
|
@@ -16,11 +16,10 @@
|
||
|
|
||
|
#include "event.h"
|
||
|
|
||
|
-
|
||
|
-
|
||
|
void event_handler ( )
|
||
|
{
|
||
|
- u_int32 update_seconds;
|
||
|
+ u_int32 update_seconds, update_seconds2, update_seconds3;
|
||
|
+ u_int32 batteryUpdate, powerUpdate, tempUpdate;
|
||
|
u_int8 lastPercentage;
|
||
|
int j;
|
||
|
|
||
|
@@ -31,9 +30,11 @@
|
||
|
secondsCounter = time(NULL);
|
||
|
powerState.updater();
|
||
|
update_seconds = time(NULL);
|
||
|
+ update_seconds2 = update_seconds;
|
||
|
lastPercentage = powerState.percentage;
|
||
|
|
||
|
- if( powerState.percentage == 100 && powerState.isCharging && args_paradisiac == PARADISIAC_ON )
|
||
|
+
|
||
|
+ if( powerState.percentage == 100 && powerState.isCharging && args_paradisiac == PARADISIAC_ON && governor == 1)
|
||
|
{
|
||
|
if( args_ttyMode && args_beQuiet == false
|
||
|
#ifndef LONGRUN
|
||
|
@@ -78,6 +79,7 @@
|
||
|
|
||
|
switch ( j )
|
||
|
{
|
||
|
+ if (governor == 1){
|
||
|
/* auto-freq */
|
||
|
case MREGION_AUTOFREQ:
|
||
|
/* toggle auto-freqency "(c)2003 LdP" scaling mode */
|
||
|
@@ -112,7 +114,7 @@
|
||
|
cpuState.auto_freq_state = false;
|
||
|
#endif
|
||
|
break;
|
||
|
-
|
||
|
+ }
|
||
|
}
|
||
|
|
||
|
/* if a cliccable region was clicked, the dockapp is redrawn */
|
||
|
@@ -134,17 +136,32 @@
|
||
|
}
|
||
|
|
||
|
|
||
|
- /* update battery percentage and cpuFreq
|
||
|
- * once every batteryUpdate milliseconds; check for autoscripts
|
||
|
- * and cpuParadisiac too */
|
||
|
- if( update_seconds <= secondsCounter - (args_batteryUpdate/1000) )
|
||
|
+ /* If cpuload is less than 90% then the system is 'idle', so we
|
||
|
+ * update battery percentage, temperature and power with
|
||
|
+ * defaults values (which are confortably big as to not
|
||
|
+ * overuse the acpi system and generate to many wakeups (detected
|
||
|
+ * by Intel's powertop).
|
||
|
+ * If cpuload is bigger than 90% it makes sense to check these
|
||
|
+ * values more often (especially the temperature), so we set
|
||
|
+ * the update times to default small values.
|
||
|
+ */
|
||
|
+
|
||
|
+ if (cpuLoad < 90) {
|
||
|
+ batteryUpdate = args_batteryUpdate;
|
||
|
+ powerUpdate = args_powerUpdate;
|
||
|
+ tempUpdate = args_tempUpdate;
|
||
|
+ }
|
||
|
+ else {
|
||
|
+ batteryUpdate = 10;
|
||
|
+ powerUpdate = 2;
|
||
|
+ tempUpdate = 2;
|
||
|
+ }
|
||
|
+
|
||
|
+
|
||
|
+ if( update_seconds <= secondsCounter - batteryUpdate )
|
||
|
{
|
||
|
update_seconds = secondsCounter;
|
||
|
- /* longrun adjusts so quickly that if you put the check
|
||
|
- after the succeeding line it consistently reads a
|
||
|
- higher MHz (in ACPI) */
|
||
|
- cpuCheckFreq();
|
||
|
- powerState.updater();
|
||
|
+ print_battery();
|
||
|
|
||
|
if( args_autoShutdown != AUTOSHUTDOWN_OFF )
|
||
|
checkAutoShutdown ( );
|
||
|
@@ -152,13 +169,31 @@
|
||
|
if( args_autoAlarm != AUTOALARM_OFF )
|
||
|
checkAutoAlarm ( );
|
||
|
|
||
|
- if( args_paradisiac == PARADISIAC_ON )
|
||
|
- cpuSetParadisiac ( );
|
||
|
+// if( args_paradisiac == PARADISIAC_ON && governor == 1)
|
||
|
+// cpuSetParadisiac ( );
|
||
|
+ }
|
||
|
+
|
||
|
+ if( update_seconds2 <= secondsCounter - tempUpdate ){
|
||
|
+ update_seconds2 = secondsCounter;
|
||
|
+ cpuReadTemp();
|
||
|
+// fprintf(stdout,"executei temperatura \n");
|
||
|
+ }
|
||
|
+
|
||
|
+ if( update_seconds3 <= secondsCounter - powerUpdate ){
|
||
|
+ update_seconds3 = secondsCounter;
|
||
|
+ read_power();
|
||
|
+// fprintf(stdout,"executei power \n");
|
||
|
}
|
||
|
|
||
|
/* check and redraw cpu load */
|
||
|
+ if (governor == 1)
|
||
|
manageCpuLoad();
|
||
|
- usleep( 1000*args_cpuUpdate /*150000*/ );
|
||
|
+ if (governor == 2){
|
||
|
+ cpuLoad = getCpuLoad();
|
||
|
+ }
|
||
|
+ cpuReadFreq();
|
||
|
+ draw_all();
|
||
|
+ usleep( 1000*args_cpuUpdate );
|
||
|
|
||
|
}
|
||
|
}
|
||
|
diff -Nru wmlaptop-1.4-orig/src/init.c wmlaptop-1.4/src/init.c
|
||
|
--- wmlaptop-1.4-orig/src/init.c 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/init.c 2008-04-18 21:56:45.005550432 +0300
|
||
|
@@ -189,80 +189,6 @@
|
||
|
}
|
||
|
|
||
|
|
||
|
-/* this chech for the string 'userspace' is in scaling_governor file under /sys/.. dir
|
||
|
- * (only in case we are going to use SYS's way to set cpufreq). If 'userspace' is not set
|
||
|
- * then we try to set it by ourself */
|
||
|
-void scalingGovernorHelper( )
|
||
|
-{
|
||
|
- char * scaling_governor_path = "/sys/devices/system/cpu/cpu0/cpufreq/scaling_governor";
|
||
|
- char * scaling_governor_av_path = "/sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors";
|
||
|
- char * error_msg = "Unable to read <%s>:\n%s\nwmlaptop cannot help you in cpu scaling governor\n";
|
||
|
- FILE * sysfp;
|
||
|
- FILE * sysavfp;
|
||
|
- char littleBuffer[128];
|
||
|
-
|
||
|
- bool printIt = false;
|
||
|
- int i;
|
||
|
-
|
||
|
- if( ( sysfp = fopen( scaling_governor_path, "r" ) ) == NULL ) {
|
||
|
- PRINTQ( stderr, error_msg, scaling_governor_path, strerror(errno) );
|
||
|
- return;
|
||
|
- }
|
||
|
-
|
||
|
- fgets( littleBuffer, 127, sysfp );
|
||
|
- fclose( sysfp );
|
||
|
-
|
||
|
- if( !strcmp( littleBuffer, "userspace\n" ) )
|
||
|
- return;
|
||
|
-
|
||
|
- if( ( sysavfp = fopen( scaling_governor_av_path, "r" ) ) == NULL ) {
|
||
|
- PRINTQ( stderr, error_msg, scaling_governor_av_path, strerror(errno) );
|
||
|
- return;
|
||
|
- }
|
||
|
-
|
||
|
- fgets( littleBuffer, 127, sysavfp );
|
||
|
- fclose( sysavfp );
|
||
|
-
|
||
|
- for( i = 0; i < strlen( littleBuffer ) - 9 ; i++ )
|
||
|
- if( !strncmp( littleBuffer, "userspace", 9 ) )
|
||
|
- {
|
||
|
- /* ok, module is loaded */
|
||
|
- printIt = true;
|
||
|
- break;
|
||
|
- }
|
||
|
-
|
||
|
-
|
||
|
- if( printIt == false ) {
|
||
|
- int s;
|
||
|
- PRINTQ( stderr, "It seems that you do not have 'cpufreq_userspace' module loaded in your kernel\n");
|
||
|
- PRINTQ( stderr, "I try to call \"/sbin/modprobe cpufreq_userspace\"\n");
|
||
|
-
|
||
|
- /* ugly.. but very fast */
|
||
|
- s = system( "/sbin/modprobe cpufreq_userspace" );
|
||
|
-
|
||
|
- if( s == 0 )
|
||
|
- PRINTQ( stderr, "..good.\n" );
|
||
|
- else
|
||
|
- {
|
||
|
- PRINTQ( stderr, "you should do it by yourself (maybe you need to recompile kernel ?)\n");
|
||
|
- return;
|
||
|
- }
|
||
|
- }
|
||
|
-
|
||
|
- /* All ok here */
|
||
|
- if( ( sysfp = fopen( scaling_governor_path, "w" )) == NULL )
|
||
|
- PRINTQ( stderr, error_msg, scaling_governor_path, strerror(errno));
|
||
|
- else
|
||
|
- {
|
||
|
- PRINTQ( stderr, "echoing 'userspace' > '%s'\n", scaling_governor_path );
|
||
|
- fprintf( sysfp, "userspace" );
|
||
|
- fclose( sysfp );
|
||
|
- }
|
||
|
-
|
||
|
- return;
|
||
|
-}
|
||
|
-
|
||
|
-
|
||
|
|
||
|
/* riempe la struttura cpuState tenendo anche conto
|
||
|
* degli argomenti passati da linea di comando */
|
||
|
@@ -293,7 +219,6 @@
|
||
|
/* auto_freq_state */
|
||
|
cpuState.auto_freq_state = ( args_autoFreq == AUTOFREQ_ON );
|
||
|
|
||
|
-
|
||
|
/* min freq */
|
||
|
if( (fp = fopen( paths[0][idx[0]], "r" )) == NULL ) {
|
||
|
fprintf( stderr, "Error reading the info file (%s):\n%s\n", paths[0][idx[0]], strerror(errno) );
|
||
|
@@ -313,21 +238,12 @@
|
||
|
|
||
|
fgets ( red, 10, fp );
|
||
|
cpuState.maxFreq = atoi ( red );
|
||
|
-
|
||
|
fclose ( fp );
|
||
|
|
||
|
/* set freq file */
|
||
|
cpuState.setFreqFile = paths[2][idx[2]];
|
||
|
|
||
|
- /* if we have to use the SYS's way to set cpufreq, then ensure that in
|
||
|
- * scaling_governor there has been put 'userspace'; otherwise let's try
|
||
|
- * to put it by ourself */
|
||
|
- if( idx[2] == 0 )
|
||
|
- scalingGovernorHelper( );
|
||
|
-
|
||
|
-
|
||
|
- cpuReadFreq( );
|
||
|
-
|
||
|
+ cpuReadFreq();
|
||
|
|
||
|
/* set freq */
|
||
|
cpuState.setFreq = cpuState.actualFreq;
|
||
|
@@ -336,6 +252,7 @@
|
||
|
/* step freq */
|
||
|
cpuState.stepFreq = args_incrementalStep;
|
||
|
|
||
|
+
|
||
|
#else
|
||
|
/* init and get first actual frequency */
|
||
|
/* PENDING: get these files from config */
|
||
|
@@ -377,8 +294,7 @@
|
||
|
free_and_exit( ERROR );
|
||
|
}
|
||
|
#endif
|
||
|
- switch( args_startingFreq )
|
||
|
- {
|
||
|
+ switch( args_startingFreq ){
|
||
|
case STARTINGFREQ_MIN:
|
||
|
#ifndef LONGRUN
|
||
|
/* frequence at min */
|
||
|
@@ -398,14 +314,16 @@
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
+
|
||
|
#ifndef LONGRUN
|
||
|
#ifdef DEBUG
|
||
|
fprintf ( stderr, "min freq: %d\nmax freq: %d\nactual freq: %d\n", cpuState.minFreq, cpuState.maxFreq, cpuState.actualFreq );
|
||
|
#endif
|
||
|
#else
|
||
|
fprintf ( stderr, "LongRun CPU starts at %d, with autoadjust = %d\n\n", cpuState.setLevelIdx, cpuState.auto_freq_state );
|
||
|
- cpuEchoFreq(); /* set initial range */
|
||
|
+// cpuEchoFreq(); /* set initial range */
|
||
|
#endif
|
||
|
+
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
diff -Nru wmlaptop-1.4-orig/src/main.c wmlaptop-1.4/src/main.c
|
||
|
--- wmlaptop-1.4-orig/src/main.c 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/main.c 2008-04-18 22:08:44.250548770 +0300
|
||
|
@@ -29,6 +29,8 @@
|
||
|
|
||
|
/* command line's args */
|
||
|
u_int32 args_cpuUpdate = ARGSDEF_LEAVE;
|
||
|
+ u_int32 args_powerUpdate = ARGSDEF_LEAVE;
|
||
|
+ u_int32 args_tempUpdate = ARGSDEF_LEAVE;
|
||
|
u_int32 args_batteryUpdate = ARGSDEF_LEAVE;
|
||
|
char * args_XDisplayName = NULL;
|
||
|
bool args_autoFreq = ARGSDEF_LEAVE;
|
||
|
@@ -52,6 +54,9 @@
|
||
|
bool args_dontBlink100 = ARGSDEF_DONTBLINK100;
|
||
|
bool args_ttyMode = ARGSDEF_LEAVE;
|
||
|
bool args_skin = ARGSDEF_LEAVE;
|
||
|
+ int governor = 2; // 1=userspace 2=ondemand
|
||
|
+ double powerrate = 1;
|
||
|
+ double capacity;
|
||
|
|
||
|
/* X's stuff */
|
||
|
struct mouseRegion mouse_region[MAX_MOUSE_REGION];
|
||
|
@@ -106,8 +111,13 @@
|
||
|
}
|
||
|
}
|
||
|
|
||
|
- init_cpuState ( );
|
||
|
- powerState.updater();
|
||
|
+ if (governor == 1){
|
||
|
+ init_cpuState();
|
||
|
+ }
|
||
|
+ battery_capacity();
|
||
|
+ cpuReadTemp();
|
||
|
+ print_battery();
|
||
|
+
|
||
|
|
||
|
if( args_ttyMode ) {
|
||
|
fprintf( stdout, "\n" );
|
||
|
@@ -119,6 +129,7 @@
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
+ if (governor == 1){
|
||
|
/* auto-freq mouse region */
|
||
|
AddMouseRegion( MREGION_AUTOFREQ, 7, 36, 55, 46 );
|
||
|
/* cpu frequency left arrow */
|
||
|
@@ -126,6 +137,9 @@
|
||
|
/* cpu frequency right arrow */
|
||
|
AddMouseRegion( MREGION_MAXFREQ, 55, 52, 58, 59 );
|
||
|
}
|
||
|
+
|
||
|
+ }
|
||
|
+
|
||
|
event_handler ( );
|
||
|
|
||
|
|
||
|
@@ -204,9 +218,13 @@
|
||
|
fprintf( stderr, " v - victory jingle\n");
|
||
|
fprintf( stderr, " h - high-bell sounds\n");
|
||
|
fprintf( stderr, " --alarm-repeat=N repeat the choosen alarm N times\n");
|
||
|
+ fprintf( stderr, "[KERNEL-related-options]:\n");
|
||
|
+ fprintf( stderr, " --governor=ondemand|userspace choose cpu scaling governor\n");
|
||
|
fprintf( stderr, "[GENERAL-options]:\n");
|
||
|
fprintf( stderr, " --cpu-update=N how often, in milliseconds, to update CPU display\n");
|
||
|
- fprintf( stderr, " --battery-update=N how often, in milliseconds, update battery state\n");
|
||
|
+ fprintf( stderr, " --battery-update=N how often, in seconds, to update battery state\n");
|
||
|
+ fprintf( stderr, " --power-update=N how often, in seconds, to update power state\n");
|
||
|
+ fprintf( stderr, " --temperature-update=N how often, in seconds, to update temperature state\n");
|
||
|
fprintf( stderr, " -p --play play alarm and exit\n");
|
||
|
fprintf( stderr, " -q --quiet do not print messages and warnings\n");
|
||
|
fprintf( stderr, " -d --default show the default compiled settings and exit\n");
|
||
|
@@ -318,6 +336,14 @@
|
||
|
args_startingFreq = STARTINGFREQ_MAX;
|
||
|
continue;
|
||
|
}
|
||
|
+ if( !strcmp( argv[i], "--governor=ondemand" ) ) {
|
||
|
+ governor=2;
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+ if( !strcmp( argv[i], "--governor=userspace" ) ) {
|
||
|
+ governor=1;
|
||
|
+ continue;
|
||
|
+ }
|
||
|
|
||
|
if( !strncmp( argv[i], "--max-freq=", 11 ) ) {
|
||
|
EXIT_IF_ALREADY_SET( args_maxFreq, ARGSDEF_LEAVE, "maxFreq" );
|
||
|
@@ -465,7 +491,7 @@
|
||
|
ptr = strchr( argv[i], '=' );
|
||
|
ptr++;
|
||
|
args_cpuUpdate = atoi( ptr );
|
||
|
- WARNING_IS_SET_TO_ZERO( args_maxFreq, "cpuUpdate" );
|
||
|
+ WARNING_IS_SET_TO_ZERO( args_cpuUpdate, "cpuUpdate" );
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
@@ -474,7 +500,25 @@
|
||
|
ptr = strchr( argv[i], '=' );
|
||
|
ptr++;
|
||
|
args_batteryUpdate = atoi( ptr );
|
||
|
- WARNING_IS_SET_TO_ZERO( args_maxFreq, "batteryUpdate" );
|
||
|
+ WARNING_IS_SET_TO_ZERO( args_batteryUpdate, "batteryUpdate" );
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+
|
||
|
+ if( !strncmp( argv[i], "--power-update=", 11 ) ) {
|
||
|
+ EXIT_IF_ALREADY_SET( args_powerUpdate, ARGSDEF_LEAVE, "powerUpdate" );
|
||
|
+ ptr = strchr( argv[i], '=' );
|
||
|
+ ptr++;
|
||
|
+ args_powerUpdate = atoi( ptr );
|
||
|
+ WARNING_IS_SET_TO_ZERO( args_powerUpdate, "powerUpdate" );
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+
|
||
|
+ if( !strncmp( argv[i], "--temperature-update=", 11 ) ) {
|
||
|
+ EXIT_IF_ALREADY_SET( args_tempUpdate, ARGSDEF_LEAVE, "tempUpdate" );
|
||
|
+ ptr = strchr( argv[i], '=' );
|
||
|
+ ptr++;
|
||
|
+ args_tempUpdate = atoi( ptr );
|
||
|
+ WARNING_IS_SET_TO_ZERO( args_tempUpdate, "tempUpdate" );
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
@@ -511,6 +555,8 @@
|
||
|
/* setting default values not set by command line */
|
||
|
SET_DEFAULT( args_cpuUpdate, ARGSDEF_LEAVE, ARGSDEF_CPUUPDATE );
|
||
|
SET_DEFAULT( args_batteryUpdate, ARGSDEF_LEAVE, ARGSDEF_BATTERYUPDATE );
|
||
|
+ SET_DEFAULT( args_powerUpdate, ARGSDEF_LEAVE, ARGSDEF_POWERUPDATE );
|
||
|
+ SET_DEFAULT( args_tempUpdate, ARGSDEF_LEAVE, ARGSDEF_TEMPUPDATE );
|
||
|
SET_DEFAULT( args_XDisplayName, NULL, ARGSDEF_XDISPLAYNAME );
|
||
|
SET_DEFAULT( args_autoFreq, ARGSDEF_LEAVE, ARGSDEF_AUTOFREQ );
|
||
|
SET_DEFAULT( args_incrementalStep, ARGSDEF_LEAVE, ARGSDEF_INCREMENTALSTEP );
|
||
|
@@ -566,6 +612,8 @@
|
||
|
fprintf( stdout, " --skin=%d\n", ARGSDEF_SKIN );
|
||
|
fprintf( stdout, "[CPU-options]:\n");
|
||
|
fprintf( stdout, " --cpu-update=%d\n", ARGSDEF_CPUUPDATE );
|
||
|
+ fprintf( stdout, " --temperature-update=%d\n", ARGSDEF_TEMPUPDATE );
|
||
|
+ fprintf( stdout, " --power-update=%d\n", ARGSDEF_POWERUPDATE );
|
||
|
fprintf( stdout, " --auto-freq=%s\n", ARGSDEF_AUTOFREQ == AUTOFREQ_ON ? "on" : "off" );
|
||
|
fprintf( stdout, " --incremental-step=%d\n", ARGSDEF_INCREMENTALSTEP );
|
||
|
if( ARGSDEF_STARTINGFREQ != ARGSDEF_LEAVE )
|
||
|
diff -Nru wmlaptop-1.4-orig/src/main.h wmlaptop-1.4/src/main.h
|
||
|
--- wmlaptop-1.4-orig/src/main.h 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/main.h 2008-04-18 21:56:45.010548403 +0300
|
||
|
@@ -134,7 +134,7 @@
|
||
|
u_int8 counter;
|
||
|
char stateFile[52];
|
||
|
char infoFile[52];
|
||
|
- u_int32 capacity;
|
||
|
+ double capacity;
|
||
|
u_int32 actualState;
|
||
|
u_int16 percentage;
|
||
|
bool useLFC;
|
||
|
@@ -175,9 +175,12 @@
|
||
|
u_int8 percentage;
|
||
|
u_int16 remainingTime;
|
||
|
bool isCharging;
|
||
|
+// double rate;
|
||
|
void(*updater)();
|
||
|
};
|
||
|
|
||
|
+extern double powerrate;
|
||
|
+extern double capacity;
|
||
|
|
||
|
/*******************
|
||
|
* CPUS' STUFF *
|
||
|
@@ -192,6 +195,7 @@
|
||
|
* events cycle. *
|
||
|
*****************************************************************/
|
||
|
extern u_int8 cpuLoad;
|
||
|
+extern int governor;
|
||
|
|
||
|
/*****************************************************************
|
||
|
* global variable cpuState is a structure of this type, it *
|
||
|
@@ -224,6 +228,7 @@
|
||
|
char * setFreqFile;
|
||
|
u_int32 setFreq;
|
||
|
u_int32 stepFreq;
|
||
|
+ int Temp;
|
||
|
#else
|
||
|
u_int16 *longRunLevels;
|
||
|
u_int16 nLongRunLevels;
|
||
|
@@ -337,14 +342,22 @@
|
||
|
|
||
|
/* update frequencies, in milliseconds; cpu must < battery */
|
||
|
#ifndef ARGSDEF_CPUUPDATE
|
||
|
-# define ARGSDEF_CPUUPDATE 80
|
||
|
+# define ARGSDEF_CPUUPDATE 400
|
||
|
#endif
|
||
|
#ifndef ARGSDEF_BATTERYUPDATE
|
||
|
-# define ARGSDEF_BATTERYUPDATE 5000
|
||
|
+# define ARGSDEF_BATTERYUPDATE 30 // seconds
|
||
|
+#endif
|
||
|
+#ifndef ARGSDEF_POWERUPDATE
|
||
|
+# define ARGSDEF_POWERUPDATE 5 // seconds
|
||
|
+#endif
|
||
|
+#ifndef ARGSDEF_TEMPUPDATE
|
||
|
+# define ARGSDEF_TEMPUPDATE 10 // seconds
|
||
|
#endif
|
||
|
|
||
|
extern u_int32 args_cpuUpdate;
|
||
|
extern u_int32 args_batteryUpdate;
|
||
|
+extern u_int32 args_powerUpdate;
|
||
|
+extern u_int32 args_tempUpdate;
|
||
|
|
||
|
/* name of diplay to open */
|
||
|
#ifndef ARGSDEF_XDISPLAYNAME
|
||
|
@@ -363,7 +376,7 @@
|
||
|
|
||
|
/* incremental auto-scaling step */
|
||
|
#ifndef ARGSDEF_INCREMENTALSTEP
|
||
|
-# define ARGSDEF_INCREMENTALSTEP 100000
|
||
|
+# define ARGSDEF_INCREMENTALSTEP 200000
|
||
|
#endif
|
||
|
extern u_int32 args_incrementalStep;
|
||
|
|
||
|
@@ -395,7 +408,7 @@
|
||
|
#define PARADISIAC_OFF 2
|
||
|
|
||
|
#ifndef ARGSDEF_PARADISIAC
|
||
|
-# define ARGSDEF_PARADISIAC PARADISIAC_ON
|
||
|
+# define ARGSDEF_PARADISIAC PARADISIAC_OFF
|
||
|
#endif
|
||
|
extern bool args_paradisiac;
|
||
|
|
||
|
diff -Nru wmlaptop-1.4-orig/src/pixmap.c wmlaptop-1.4/src/pixmap.c
|
||
|
--- wmlaptop-1.4-orig/src/pixmap.c 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/pixmap.c 2008-04-18 21:56:45.012548584 +0300
|
||
|
@@ -18,9 +18,235 @@
|
||
|
|
||
|
char ** wmlaptop_xpm = NULL;
|
||
|
|
||
|
+/* XPM */
|
||
|
+static char * wmlaptop_xpm_type0[] = {
|
||
|
+"123 140 81 1",
|
||
|
+" c None",
|
||
|
+". c #FF0000",
|
||
|
+"+ c #000000",
|
||
|
+"@ c #00FF04",
|
||
|
+"# c #968E8E",
|
||
|
+"$ c #FFFF00",
|
||
|
+"% c #FF1700",
|
||
|
+"& c #FF2F00",
|
||
|
+"* c #FF4700",
|
||
|
+"= c #FF5F00",
|
||
|
+"- c #FF7700",
|
||
|
+"; c #FF8E00",
|
||
|
+"> c #FFA600",
|
||
|
+", c #FFBE00",
|
||
|
+"' c #FFD600",
|
||
|
+") c #FFEE00",
|
||
|
+"! c #FFF900",
|
||
|
+"~ c #F4FA00",
|
||
|
+"{ c #DFFA00",
|
||
|
+"] c #C9FB00",
|
||
|
+"^ c #B4FB00",
|
||
|
+"/ c #9FFC00",
|
||
|
+"( c #89FD00",
|
||
|
+"_ c #74FD00",
|
||
|
+": c #5EFE00",
|
||
|
+"< c #49FE00",
|
||
|
+"[ c #3FFF00",
|
||
|
+"} c #050500",
|
||
|
+"| c #EFEC19",
|
||
|
+"1 c #242303",
|
||
|
+"2 c #B1AF13",
|
||
|
+"3 c #262504",
|
||
|
+"4 c #ECE919",
|
||
|
+"5 c #060600",
|
||
|
+"6 c #94920F",
|
||
|
+"7 c #E7E418",
|
||
|
+"8 c #6F6D0B",
|
||
|
+"9 c #ABA912",
|
||
|
+"0 c #67660B",
|
||
|
+"a c #020200",
|
||
|
+"b c #F3F01A",
|
||
|
+"c c #0F0F01",
|
||
|
+"d c #6A690B",
|
||
|
+"e c #A2A011",
|
||
|
+"f c #86850E",
|
||
|
+"g c #191902",
|
||
|
+"h c #101001",
|
||
|
+"i c #8C8B0F",
|
||
|
+"j c #605F0A",
|
||
|
+"k c #AAA812",
|
||
|
+"l c #2A2904",
|
||
|
+"m c #FBF81B",
|
||
|
+"n c #383706",
|
||
|
+"o c #AEAC12",
|
||
|
+"p c #525108",
|
||
|
+"q c #E0DD18",
|
||
|
+"r c #222203",
|
||
|
+"s c #161602",
|
||
|
+"t c #E8E518",
|
||
|
+"u c #5B5A09",
|
||
|
+"v c #F5F21A",
|
||
|
+"w c #63620A",
|
||
|
+"x c #E5E218",
|
||
|
+"y c #0B0B01",
|
||
|
+"z c #F8F51A",
|
||
|
+"A c #C6C415",
|
||
|
+"B c #BCB914",
|
||
|
+"C c #999710",
|
||
|
+"D c #C1BF14",
|
||
|
+"E c #AFAD12",
|
||
|
+"F c #7C7A0D",
|
||
|
+"G c #F7F41A",
|
||
|
+"H c #272604",
|
||
|
+"I c #5F5E0A",
|
||
|
+"J c #181802",
|
||
|
+"K c #0E0E01",
|
||
|
+"L c #313005",
|
||
|
+"M c #C4C215",
|
||
|
+"N c #DCD917",
|
||
|
+"O c #131302",
|
||
|
+"P c #6D6B0B",
|
||
|
+" ...........................................................",
|
||
|
+" ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.........+++....+++......+++.............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++........+++++...+++......+++.............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++..+++......+++.............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++..+++......+++.............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++...+++....+++..............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++...+++....+++..............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++...+++....+++..............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++...+++....+++..............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++...+++.++.+++..............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++...+++.++.+++..............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++....++.++.++...............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++....++.++.++...............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++....++.++.++...............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++.......+++.+++....++.++.++...............",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++++++...+++.+++.....++..++................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++++++....+++++......++..++................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...............+++++++.....+++.......++..++................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++.....+++...+++++++.+++++++.+++++.+++++....+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++....+++++..+++++++.+++++++.+++++.+++++++..+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++++.+++++++.+++++++.+++++++.+++++.+++++++..+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++++++...+++.....+++...+++...+++.++++.+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++.+++...+++.....+++...+++...+++..+++.+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++.+++...+++.....+++...+++...+++.++++.+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++.+++...+++.....+++...+++...+++.+++..+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++++.+++.+++...+++.....+++...++++..+++++++..+++.+++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..++++++..+++++++...+++.....+++...++++..+++++....+++++++...",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++++.+++++++...+++.....+++...++++..+++++.....+++++....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++++++...+++.....+++...+++...++++++....+++++....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++.+++...+++.....+++...+++...++++++.....+++.....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++.+++...+++.....+++...+++...+++++++....+++.....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++.+++.+++.+++...+++.....+++...+++...+++.+++....+++.....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++++.+++.+++...+++.....+++...+++++.+++.++++...+++.....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++...+++.+++...+++.....+++...+++++.+++..+++...+++.....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ..+++++...+++.+++...+++.....+++...+++++.+++..+++...+++.....",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...........................................................",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+" +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"+@@+++@++@@+@@@+@+++@@@++@@+@@@@+@@++@@++@++++@++++###+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++@+@@+@++@+++@@+++@+++@++++++@@++@@++@@+@++@++++#++###+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++@@+@+@++@+++@@+++@+++@++++++@@++@@++@+@++@++++#+++#+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++@++@+++@++@@+@+++@@@+@@@++++@+@@++@@@+++@++++#+#++###+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++@++@++@+++++@@+@++++@@++@++@+@++@+++@++@++@+#+++###+++++++++++++++++++++++++$$$+++++++++$$$++++$$$++++++$$$+++++++++++++",
|
||
|
+"@++@++@+@++++++@@@@@+++@@++@++@+@++@+++@+@++@+@#+++++++++++++++++++++++++++++++$$$++++++++$$$$$+++$$$++++++$$$+++++++++++++",
|
||
|
+"+@@+@@@@@@@@@@@+++@+@@@++@@+++@++@@++@@+@++++@+++++@@@+++......++++++++++++++++$$$+++++++$$$+$$$++$$$++++++$$$+++++++++++++",
|
||
|
+"+$$+++$++$$+$$$+$+++$$$++$$+$$$$+$$++$$++$++++$+++@++@@@+++++++++++++++++++++++$$$+++++++$$$+$$$++$$$++++++$$$+++++++++++++",
|
||
|
+"$++$+$$+$++$+++$$+++$+++$++++++$$++$$++$$+$++$+++@+++@+++++++++++++++++++++++++$$$+++++++$$$+$$$+++$$$++++$$$++++++++++++++",
|
||
|
+"$++$$+$+$++$+++$$+++$+++$++++++$$++$$++$+$++$+++@+@++@@@+++++++++++++++++++++++$$$+++++++$$$+$$$+++$$$++++$$$++++++++++++++",
|
||
|
+"$++$++$+++$++$$+$+++$$$+$$$++++$+$$++$$$+++$+++@+++@@@+++++++++++++++++++++++++$$$+++++++$$$+$$$+++$$$++++$$$++++++++++++++",
|
||
|
+"$++$++$++$+++++$$+$++++$$++$++$+$++$+++$++$++$+@+++++++++++++++++++++++++++++++$$$+++++++$$$+$$$+++$$$++++$$$++++++++++++++",
|
||
|
+"$++$++$+$++++++$$$$$+++$$++$++$+$++$+++$+$++$+$++++++++++++++++++++++++++++++++$$$+++++++$$$+$$$+++$$$+$$+$$$++++++++++++++",
|
||
|
+"+$$+$$$$$$$$$$$+++$+$$$++$$+++$++$$++$$+$++++$+++++$$++++++++++++++++++++++++++$$$+++++++$$$+$$$+++$$$+$$+$$$++++++++++++++",
|
||
|
+"+..+++.++..+...+.+++...++..+....+..++..++.++++.+++$$$$+++++++++++++++++++++++++$$$+++++++$$$+$$$++++$$+$$+$$+++++++++++++++",
|
||
|
+".++.+..+.++.+++..+++.+++.++++++..++..++..+.++.+++$$$$$$++++++++++++++++++++++++$$$+++++++$$$+$$$++++$$+$$+$$+++++++++++++++",
|
||
|
+".++..+.+.++.+++..+++.+++.++++++..++..++.+.++.+++$$$$$$$$+++++++++++++++++++++++$$$+++++++$$$+$$$++++$$+$$+$$+++++++++++++++",
|
||
|
+".++.++.+++.++..+.+++...+...++++.+..++...+++.+++++$$$$$$++++++++++++++++++++++++$$$+++++++$$$+$$$++++$$+$$+$$+++++++++++++++",
|
||
|
+".++.++.++.+++++..+.++++..++.++.+.++.+++.++.++.++++$$$$+++++++++++++++++++++++++$$$$$$$+++$$$+$$$+++++$$++$$++++++++++++++++",
|
||
|
+".++.++.+.++++++.....+++..++.++.+.++.+++.+.++.+.++++$$++++++++++++++++++++++++++$$$$$$$++++$$$$$++++++$$++$$++++++++++++++++",
|
||
|
+"+..+...........+++.+...++..+++.++..++..+.++++.+++++++++++++++++++++++++++++++++$$$$$$$+++++$$$+++++++$$++$$++++++++++++++++",
|
||
|
+"+@@@@++++@+++@@@@+@@@@+++++@++@@@@@++@@@@+@@@@@@+@@@@++@@@@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@++@@++@++++@++++@++++@++@+++++@+++++@++++@@++++@@++++@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@+@+@++@++++@+++++@++@+++@+++++@++++++++++@@++++@@++++@#.@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@@++@+++++++@+++++@++@+++@+++++@++++++++++@@++++@@++++@#.@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@+++@++++++@+++@@@++@++++@@@@++@@@@@+++++@++@@@@++@@@@@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@+++@+++++@++++++@++@++++++++@+@++++@++++@+@++++@+++++@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@+++@++++@++++++++@@++@+++++++@@++++@+++@++@++++@+++++@#.@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@+++@+++@+++++++++@@@@@@@+++++@@++++@+++@++@++++@+++++@#.@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"@++++@+++@++@+++++++++@++++@++++++@+@++++@+++@++@++++@+++++@++++++$$$$$+++++$$$+++$$$$$$$+$$$$$$$+$$$$$+$$$$$++++$$$+$$$+++",
|
||
|
+"+@@@@+@@@@@@@@@@@@@@@@+++++@++@@@@+++@@@@++++@+++@@@@++@@@@+++++++$$$$$++++$$$$$++$$$$$$$+$$$$$$$+$$$$$+$$$$$$$++$$$+$$$+++",
|
||
|
+"..................................................%&*=-;>,')++++++$$$$$$$+$$$$$$$+$$$$$$$+$$$$$$$+$$$$$+$$$$$$$++$$$+$$$+++",
|
||
|
+".+++++++++++++++++++++++++++++++++++++++++++++++..%&*=-;>,')++++++$$$+$$$+$$$$$$$+++$$$+++++$$$+++$$$+++$$$+$$$$+$$$+$$$+++",
|
||
|
+".+++.+++.++.+.....++..++++++....+...++....++..++..%&*=-;>,')++++++$$$+$$$+$$$+$$$+++$$$+++++$$$+++$$$+++$$$++$$$+$$$+$$$+++",
|
||
|
+".+++.+++.++.+++.+++.++.+++++.++++.++.+.++++.++.+..%&*=-;>,')++++++$$$+$$$+$$$+$$$+++$$$+++++$$$+++$$$+++$$$+$$$$+$$$+$$$+++",
|
||
|
+".++.+.++.++.+++.+++.++.+++++.++++.++.+.++++.++.+..%&*=-;>,')++++++$$$+$$$+$$$+$$$+++$$$+++++$$$+++$$$+++$$$+$$$++$$$+$$$+++",
|
||
|
+".++.+.++.++.+++.+++.++.+...+...++...++...++.++.+..%&*=-;>,')++++++$$$$$$$+$$$+$$$+++$$$+++++$$$+++$$$$++$$$$$$$++$$$+$$$+++",
|
||
|
+".+.....+.++.+++.+++.++.+++++.++++.++.+.++++..+.+..%&*=-;>,')++++++$$$$$$++$$$$$$$+++$$$+++++$$$+++$$$$++$$$$$++++$$$$$$$+++",
|
||
|
+".+.+++.+.++.+++.+++.++.+++++.++++.++.+.++++.+..+.!~{]^/(_:<[++++++$$$$$$$+$$$$$$$+++$$$+++++$$$+++$$$$++$$$$$+++++$$$$$++++",
|
||
|
+".+.+++.++..++++.++++..++++++.++++.++.+....++...+.!~{]^/(_:<[++++++$$$+$$$+$$$$$$$+++$$$+++++$$$+++$$$+++$$$$$$++++$$$$$++++",
|
||
|
+".+++++++++++++++++++++++++++++++++++++++++++++++.!~{]^/(_:<[++++++$$$+$$$+$$$+$$$+++$$$+++++$$$+++$$$+++$$$$$$+++++$$$+++++",
|
||
|
+".................................................!~{]^/(_:<[++++++$$$+$$$+$$$+$$$+++$$$+++++$$$+++$$$+++$$$$$$$++++$$$+++++",
|
||
|
+"#################################################!~{]^/(_:<[++++++$$$+$$$+$$$+$$$+++$$$+++++$$$+++$$$+++$$$+$$$++++$$$+++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++++++#!~{]^/(_:<[++++++$$$$$$$+$$$+$$$+++$$$+++++$$$+++$$$$$+$$$+$$$$+++$$$+++++",
|
||
|
+"#+++#+++#++#+#####++##++++++####+###++####++##++#!~{]^/(_:<[++++++$$$$$+++$$$+$$$+++$$$+++++$$$+++$$$$$+$$$++$$$+++$$$+++++",
|
||
|
+"#+++#+++#++#+++#+++#++#+++++#++++#++#+#++++#++#+#++++##+++++++++++$$$$$+++$$$+$$$+++$$$+++++$$$+++$$$$$+$$$++$$$+++$$$+++++",
|
||
|
+"#++#+#++#++#+++#+++#++#+++++#++++#++#+#++++#++#+#+++####+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"#++#+#++#++#+++#+++#++#+###+###++###++###++#++#+#++######++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"#+#####+#++#+++#+++#++#+++++#++++#++#+#++++##+#+#+########+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"#+#+++#+#++#+++#+++#++#+++++#++++#++#+#++++#+##+#++######++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"#+#+++#++##++++#++++##++++++#++++#++#+####++###+#+++####+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++++++#++++##++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"#################################################++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"+$$$+$$$++$++$++$+++++$$$++++$+++$$$+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"$++++$++$+$++$++$++++$+++$+++$+++$++$++####+++++++++++++++++++++ ####################################################### ",
|
||
|
+"$++++$++$+$++$++$++++$+++$++$+$++$++$+#++++#++@+++@+@++@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"$++++$$$++$++$++$++++$+++$++$+$++$++$+#++++#++@@+@@+@++@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"$++++$++++$++$++$++++$+++$+$$$$$+$++$+#++++#++@@@@@+@++@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"$++++$++++$++$++$++++$+++$+$+++$+$++$+#++++#++@+@+@+@@@@+@@@@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"+$$$+$+++++$$+++$$$$++$$$++$+++$+$$$++#++++#++@+++@+@@@@++++@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"+...+...++.++.++.+++++...++++.+++...++#++++#++@+++@+@++@+++@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+".++++.++.+.++.++.++++.+++.+++.+++.++.+#++++#++@+++@+@++@+++@+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+".++++.++.+.++.++.++++.+++.++.+.++.++.+#++++#++@+++@+@++@++@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+".++++...++.++.++.++++.+++.++.+.++.++.++####+++@+++@+@++@+@@@@++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+".++++.++++.++.++.++++.+++.+.....+.++.++++++++++++++++++++++++++++}+++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+".++++.++++.++.++.++++.+++.+.+++.+.++.++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"+...+.+++++..+++....++...++.+++.+...++++++++++++++++++++++++++++++++++@+++++++@++.+++++++.+++++++++++++++++++++++++++++++++",
|
||
|
+"############################################# ++++++@+++++++@++.+++++++.+++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++# ++++++@+++++++@++.+++++++.+++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++# ++++++@+++++++@++.+++++++.+++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++# ++++++@+++@+++@++.+++.+++.+++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++# ++++++@@+@@@+@@++..+...+..+++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++# +++++++@@+++@@++++..+++..++++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"#+++++++++++++++++++++++++++++++++++++++++++# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
+"############################################# "};
|
||
|
+
|
||
|
+
|
||
|
|
||
|
/* XPM */
|
||
|
-char * wmlaptop_xpm_type0[] = {
|
||
|
+/*char * wmlaptop_xpm_type0[] = {
|
||
|
"123 140 27 1",
|
||
|
" c None",
|
||
|
". c #FF0000",
|
||
|
@@ -190,7 +416,7 @@
|
||
|
"#+++++++++++++++++++++++++++++++++++++++++++# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++",
|
||
|
"############################################# "};
|
||
|
|
||
|
-
|
||
|
+*/
|
||
|
|
||
|
|
||
|
/* XPM */
|
||
|
diff -Nru wmlaptop-1.4-orig/src/version.h wmlaptop-1.4/src/version.h
|
||
|
--- wmlaptop-1.4-orig/src/version.h 2008-04-18 21:55:54.497550614 +0300
|
||
|
+++ wmlaptop-1.4/src/version.h 2008-04-18 21:56:45.012548584 +0300
|
||
|
@@ -1,7 +1,7 @@
|
||
|
#ifndef __VERSION_H__
|
||
|
#define __VERSION_H__
|
||
|
|
||
|
-#define BUILD_NR 256
|
||
|
+#define BUILD_NR 495
|
||
|
#define PROGNAME "WmLaptop"
|
||
|
#define VERSION "1.4"
|
||
|
|