summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lcd.c36
-rw-r--r--setup.c1
-rw-r--r--sockets.c4
3 files changed, 25 insertions, 16 deletions
diff --git a/lcd.c b/lcd.c
index 6c8151e..15c9340 100644
--- a/lcd.c
+++ b/lcd.c
@@ -33,8 +33,11 @@ cLcd::cLcd() {
int i, j;
connected = false;
suspended = false;
- ThreadStateData.showvolume = false;
- ThreadStateData.newscroll = false;
+ memset(&ThreadStateData,0,sizeof(ThreadStateData));
+ memset(&LastState,0,sizeof(LastState));
+ memset(&StringBuffer,0,sizeof(StringBuffer));
+ LastStateP=LineMode=0;
+ ToggleMode=false;
sock = wid = hgt = cellwid = cellhgt = 0;
closing = false;
host = NULL;
@@ -47,11 +50,14 @@ cLcd::cLcd() {
ThreadStateData.lcddirty[i][j]=true;
}
ThreadStateData.State=Menu;
- for (i=0;i<LCDMAXSTATEBUF;i++) LastState[i]=Title; LastStateP=0;
- ThreadStateData.barx=1, ThreadStateData.bary=1, ThreadStateData.barl=0;
- for (i=0;i<LCDMAXCARDS;i++) ThreadStateData.CardStat[i]=0;
+ for (i=0;i<LCDMAXSTATEBUF;i++) LastState[i]=Title;
+ ThreadStateData.barx=1;
+ ThreadStateData.bary=1;
channelSwitched = false;
SummaryText = NULL;
+ SummaryTextL = SummaryCurrent = port = LCDd_dead = 0;
+ LastProgress = (time_t) 0;
+
#if VDRVERSNUM < 10711
conv = new cCharSetConv(cCharSetConv::SystemCharacterTable() ? cCharSetConv::SystemCharacterTable() : "UTF-8", "ISO-8859-1");
#else
@@ -102,7 +108,7 @@ bool cLcd::Open() {
while ( ((int)i<((int)strlen(istring)-5)) && (strncmp("lcd",istring+i,3) != 0 ) ) i++;
- if (sscanf(istring+i,"lcd wid %d hgt %d cellwid %d cellhgt %d", &wid, &hgt, &cellwid, &cellhgt)) connected=true;
+ if (sscanf(istring+i,"lcd wid %3d hgt %3d cellwid %3d cellhgt %3d", &wid, &hgt, &cellwid, &cellhgt)) connected=true;
if ((hgt < 4 ) || (wid < 16)) connected = false; // 4 lines are needed, may work with more than 4 though
if ((hgt==2) && (wid>31)) { connected = true; wid=wid/2; LineMode=0; } // 2x32-2x40
@@ -197,7 +203,6 @@ void cLcd::SetTitle( const char *string) {
const char* c_string = Convert(string);
- unsigned int i;
char title[wid+1];
// we need to know the length of the translated string "Schedule"
@@ -212,7 +217,7 @@ void cLcd::SetTitle( const char *string) {
} else {
memset(title,' ',wid/2+1);
snprintf(title + ( (wid-strlen(c_string))/2 ),wid-( (wid-strlen(c_string))/2 ),"%s",c_string); // center title
- for (i=0;i<strlen(title);i++) title[i]=toupper(title[i]); // toupper
+ for (unsigned int i=0;i<strlen(title);i++) title[i]=toupper(title[i]); // toupper
}
cLcd::SetLine(LCDMENU,0,title);
}
@@ -599,9 +604,8 @@ void cLcd::EndMutualExclusion() {
void cLcd::Copy(char *to, const char *from, unsigned int max) { // eliminates tabs, double blanks, ...
- unsigned int i=0 , out=0;
-
if (from != NULL) {
+ unsigned int i=0 , out=0;
while ((out < max) && (from[i] != '\0') ) {
to[out]=(isspace(from[i]))?' ':from[i];
if ( (out>0) && (to[out-1]==' ') && ispunct(to[out]) ) {to[out-1]=to[out]; to[out]=' '; }
@@ -620,7 +624,7 @@ void cLcd::Copy(char *to, const char *from, unsigned int max) { // eliminates ta
void cLcd::Split(char *string, char *string1, char *string2) {
- unsigned int i,j,k,ofs;
+ unsigned int i,j,ofs;
if ( hgt>2 && ( strlen(string) < 2*wid) && isdigit(string[0]) && isdigit(string[1]) // beautification ..
&& string[2]==':' && isdigit(string[3]) && isdigit(string[4]) ) {
@@ -642,6 +646,7 @@ void cLcd::Split(char *string, char *string1, char *string2) {
if ( ( (2*wid-j) >= (ofs=wid-(i+1)) ) && ofs+j <= 2*wid ) {
string[j+ofs]='\0';
+ unsigned int k;
for (k=j+ofs-1;k>i+ofs; k-- ) string[k]=string[k-ofs];
for (k=0;k<ofs;k++) string[i+k+1]=' ';
}
@@ -746,8 +751,8 @@ void cLcd::Action(void) { // LCD output thread
unsigned int i,j, barx, bary, barl, ScrollState, ScrollLine, lasttitlelen;
int Current, Total, scrollpos, scrollcnt, scrollwaitcnt, lastAltShift, lastBackLight,lastPrio, keycnt;
struct timeval now, voltime;
- char workstring[WorkString_Length];
- char workstring2[101];
+ char workstring[WorkString_Length]="";
+ char workstring2[101]="";
char lastkeypressed='\0';
cLcd::ThreadStates PrevState = Menu;
struct cLcd::StateData OutStateData;
@@ -760,6 +765,9 @@ void cLcd::Action(void) { // LCD output thread
// LCR
static int lcrCycle;
+ memset(&OutStateData,0,sizeof(OutStateData));
+ memset(&Lcddirty,0,sizeof(Lcddirty));
+
time_t nextLcdUpdate, lastUserActivity;
while (true) { // outer (reconnect) loop
@@ -1202,10 +1210,10 @@ void cLcd::Action(void) { // LCD output thread
// Output
- int OutValue = 0;
char lcdCommand[100];
if (!closing){
if (LcdSetup.OutputNumber > 0){
+ int OutValue = 0;
for (int o=0; o < LcdSetup.OutputNumber; o++){
switch(LcdSetup.OutputFunction[o]){
case 0: // Off
diff --git a/setup.c b/setup.c
index 218f88d..075be70 100644
--- a/setup.c
+++ b/setup.c
@@ -17,6 +17,7 @@ cLcdSetup::cLcdSetup(void)
SetPrio = 2;
BackLightWait = 20;
PrioWait = 60;
+ ClientPrioWait = 60;
OutputNumber = 0;
for (int i = 0; i < LCDMAXOUTPUTS; i++)
OutputFunction[i] = 0;
diff --git a/sockets.c b/sockets.c
index ff3a6a6..2df4fc7 100644
--- a/sockets.c
+++ b/sockets.c
@@ -134,7 +134,7 @@ sock_recv_string (int fd, char *dest, size_t maxlen)
if (!dest)
return -1;
- if (maxlen <= 0)
+ if (maxlen == 0)
return 0;
while (1) {
@@ -215,7 +215,7 @@ sock_recv (int fd, void *dest, size_t maxlen)
if (!dest)
return -1;
- if (maxlen <= 0)
+ if (maxlen == 0)
return 0;
err = read (fd, dest, maxlen);