From 620eb8150bd5cf1605c45bfbef018b716e50c544 Mon Sep 17 00:00:00 2001 From: Klaus Schmidinger Date: Wed, 5 Mar 2008 17:16:31 +0100 Subject: Revoked the fixed change of the default character set for SI data and introduced an environment variable to control it --- libsi/si.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'libsi') diff --git a/libsi/si.c b/libsi/si.c index 43ef0382..49464baf 100644 --- a/libsi/si.c +++ b/libsi/si.c @@ -6,7 +6,7 @@ * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * - * $Id: si.c 1.24 2008/03/01 12:02:01 kls Exp $ + * $Id: si.c 1.25 2008/03/05 17:00:55 kls Exp $ * * ***************************************************************************/ @@ -14,6 +14,7 @@ #include #include #include +#include // for broadcaster stupidity workaround #include #include "descriptor.h" @@ -340,9 +341,12 @@ bool SetSystemCharacterTable(const char *CharacterTable) { // and length are adjusted accordingly. static const char *getCharacterTable(const unsigned char *&buffer, int &length, bool *isSingleByte = NULL) { const char *cs = "ISO6937"; - cs = "ISO-8859-9"; // Workaround for broadcaster stupidity: according to + // Workaround for broadcaster stupidity: according to // "ETSI EN 300 468" the default character set is ISO6937. But unfortunately some // broadcasters actually use ISO-8859-9, but fail to correctly announce that. + static const char *CharsetOverride = getenv("VDR_CHARSET_OVERRIDE"); + if (CharsetOverride) + cs = CharsetOverride; if (isSingleByte) *isSingleByte = false; if (length <= 0) -- cgit v1.2.3