From fa32be64a8781d8c1cdec9b359a2e8fe62668416 Mon Sep 17 00:00:00 2001 From: Klaus Schmidinger Date: Sat, 2 Feb 2002 15:57:48 +0100 Subject: [PATCH] Config files can now contain comments separated by '#' --- config.c | 6 +++--- config.h | 11 ++++++++--- 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/config.c b/config.c index 918ee348..eaf937a3 100644 --- a/config.c +++ b/config.c @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: config.c 1.79 2002/02/02 12:45:30 kls Exp $ + * $Id: config.c 1.80 2002/02/02 15:57:48 kls Exp $ */ #include "config.h" @@ -658,9 +658,9 @@ cCommands Commands; cChannels Channels; -bool cChannels::Load(const char *FileName) +bool cChannels::Load(const char *FileName, bool AllowComments) { - if (cConfig::Load(FileName)) { + if (cConfig::Load(FileName, AllowComments)) { ReNumber(); return true; } diff --git a/config.h b/config.h index 42f73378..15069438 100644 --- a/config.h +++ b/config.h @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: config.h 1.90 2002/01/30 18:30:03 kls Exp $ + * $Id: config.h 1.91 2002/02/02 15:57:48 kls Exp $ */ #ifndef __CONFIG_H @@ -182,7 +182,7 @@ private: public: cConfig(void) { fileName = NULL; } virtual ~cConfig() { delete fileName; } - virtual bool Load(const char *FileName) + virtual bool Load(const char *FileName, bool AllowComments = false) { Clear(); fileName = strdup(FileName); @@ -196,6 +196,11 @@ public: result = true; while (fgets(buffer, sizeof(buffer), f) > 0) { line++; + if (AllowComments) { + char *p = strchr(buffer, '#'); + if (p) + *p = 0; + } if (!isempty(buffer)) { T *l = new T; if (l->Parse(buffer)) @@ -242,7 +247,7 @@ protected: int maxNumber; public: cChannels(void) { maxNumber = 0; } - virtual bool Load(const char *FileName); + virtual bool Load(const char *FileName, bool AllowComments = false); int GetNextGroup(int Idx); // Get next channel group int GetPrevGroup(int Idx); // Get previous channel group int GetNextNormal(int Idx); // Get next normal channel (not group)