diff options
| author | Klaus Schmidinger <vdr@tvdr.de> | 2012-09-29 14:30:48 +0200 | 
|---|---|---|
| committer | Klaus Schmidinger <vdr@tvdr.de> | 2012-09-29 14:30:48 +0200 | 
| commit | 3c860ee0439bf106413a759c284de616d31da638 (patch) | |
| tree | 92c470b8fce785c89985895cb3e4d988d6f9fd7b | |
| parent | c5dfaf9681b25de03fe18909bd08f52797c2cf41 (diff) | |
| download | vdr-3c860ee0439bf106413a759c284de616d31da638.tar.gz vdr-3c860ee0439bf106413a759c284de616d31da638.tar.bz2 | |
Reactivated stripping control characters from EPG texts and adapted it to UTF-8
| -rw-r--r-- | HISTORY | 1 | ||||
| -rw-r--r-- | epg.c | 33 | 
2 files changed, 25 insertions, 9 deletions
| @@ -7262,3 +7262,4 @@ Video Disk Recorder Revision History    thread to avoid sluggish response to user input on slow systems (based on a patch from    Sören Moch).  - Fixed sorting folders before recordings in case of UTF-8 (thanks to Sören Moch). +- Reactivated stripping control characters from EPG texts and adapted it to UTF-8. @@ -7,7 +7,7 @@   * Original version (as used in VDR before 1.3.0) written by   * Robert Schneider <Robert.Schneider@web.de> and Rolf Hakenes <hakenes@hippomi.de>.   * - * $Id: epg.c 2.20 2012/09/29 11:49:11 kls Exp $ + * $Id: epg.c 2.21 2012/09/29 14:29:49 kls Exp $   */  #include "epg.h" @@ -641,6 +641,26 @@ void ReportEpgBugFixStats(bool Force)       }  } +static void StripControlCharacters(char *s) +{ +  if (s) { +     int len = strlen(s); +     while (len > 0) { +           int l = Utf8CharLen(s); +           uchar *p = (uchar *)s; +           if (l == 2 && *p == 0xC2) // UTF-8 sequence +              p++; +           if (*p == 0x86 || *p == 0x87) { +              memmove(s, p + 1, len - l + 1); // we also copy the terminating 0! +              len -= l; +              l = 0; +              } +           s += l; +           len -= l; +           } +     } +} +  void cEvent::FixEpgBugs(void)  {    if (isempty(title)) { @@ -850,15 +870,10 @@ Final:              strreplace(p->description, '\n', ' ');           }       } -  /* TODO adapt to UTF-8    // Same for control characters: -  strreplace(title, '\x86', ' '); -  strreplace(title, '\x87', ' '); -  strreplace(shortText, '\x86', ' '); -  strreplace(shortText, '\x87', ' '); -  strreplace(description, '\x86', ' '); -  strreplace(description, '\x87', ' '); -  XXX*/ +  StripControlCharacters(title); +  StripControlCharacters(shortText); +  StripControlCharacters(description);  }  // --- cSchedule ------------------------------------------------------------- | 
