summaryrefslogtreecommitdiff
path: root/timers.c
diff options
context:
space:
mode:
authorKlaus Schmidinger <vdr@tvdr.de>2009-08-09 12:45:36 +0200
committerKlaus Schmidinger <vdr@tvdr.de>2009-08-09 12:45:36 +0200
commit23b5b1336dbabcf3b79889d39906de24712f8066 (patch)
tree6a4243a6dbc5d585a9f45673e7e6be95e8c25733 /timers.c
parentc5910f79873651559f0e30a77419ddc30e044c0d (diff)
downloadvdr-23b5b1336dbabcf3b79889d39906de24712f8066.tar.gz
vdr-23b5b1336dbabcf3b79889d39906de24712f8066.tar.bz2
Fixed handling file name length on VFAT systems in case they contain UTF-8 characters
Diffstat (limited to 'timers.c')
-rw-r--r--timers.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/timers.c b/timers.c
index 191c0312..a684bb4a 100644
--- a/timers.c
+++ b/timers.c
@@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and
* how to reach the author.
*
- * $Id: timers.c 2.2 2009/06/21 14:06:33 kls Exp $
+ * $Id: timers.c 2.3 2009/08/09 12:43:20 kls Exp $
*/
#include "timers.h"
@@ -51,6 +51,11 @@ cTimer::cTimer(bool Instant, bool Pause, cChannel *Channel)
event = NULL;
if (Instant && channel)
snprintf(file, sizeof(file), "%s%s", Setup.MarkInstantRecord ? "@" : "", *Setup.NameInstantRecord ? Setup.NameInstantRecord : channel->Name());
+ if (VfatFileSystem && (Utf8StrLen(file) > VFAT_MAX_FILENAME)) {
+ dsyslog("timer file name too long for VFAT file system: '%s'", file);
+ file[Utf8SymChars(file, VFAT_MAX_FILENAME)] = 0;
+ dsyslog("timer file name truncated to '%s'", file);
+ }
}
cTimer::cTimer(const cEvent *Event)
@@ -83,6 +88,11 @@ cTimer::cTimer(const cEvent *Event)
const char *Title = Event->Title();
if (!isempty(Title))
Utf8Strn0Cpy(file, Event->Title(), sizeof(file));
+ if (VfatFileSystem && (Utf8StrLen(file) > VFAT_MAX_FILENAME)) {
+ dsyslog("timer file name too long for VFAT file system: '%s'", file);
+ file[Utf8SymChars(file, VFAT_MAX_FILENAME)] = 0;
+ dsyslog("timer file name truncated to '%s'", file);
+ }
aux = NULL;
event = NULL; // let SetEvent() be called to get a log message
}
@@ -296,13 +306,13 @@ bool cTimer::Parse(const char *s)
p++;
else
p = filebuffer;
- if (strlen(p) > VFAT_MAX_FILENAME) {
+ if (Utf8StrLen(p) > VFAT_MAX_FILENAME) {
dsyslog("timer file name too long for VFAT file system: '%s'", p);
- p[VFAT_MAX_FILENAME] = 0;
+ p[Utf8SymChars(p, VFAT_MAX_FILENAME)] = 0;
dsyslog("timer file name truncated to '%s'", p);
}
}
- Utf8Strn0Cpy(file, filebuffer, MaxFileName);
+ Utf8Strn0Cpy(file, filebuffer, sizeof(file));
strreplace(file, '|', ':');
if (isnumber(channelbuffer))
channel = Channels.GetByNumber(atoi(channelbuffer));