From 5b03953fd15cce03138c91a4398d30f58645cc93 Mon Sep 17 00:00:00 2001 From: horchi Date: Sat, 3 Mar 2018 09:03:00 +0100 Subject: [PATCH] anged menu numbering handling vor mcMain --- HISTORY | 5 +++++ coreengine/listelements.c | 26 ++++++++++++++++++++++++++ skindesigner.c | 2 +- 3 files changed, 32 insertions(+), 1 deletion(-) diff --git a/HISTORY b/HISTORY index 3add251..df16700 100644 --- a/HISTORY +++ b/HISTORY @@ -443,3 +443,8 @@ Version 1.2.5 (horchi) Version 1.2.6 (horchi) - extended epg2vdr timer interface for schedules + +Version 1.2.7 (horchi) + +- changed menu numbering handling vor mcMain + > now only numbers up to 999 are detected as 'Numbering' diff --git a/coreengine/listelements.c b/coreengine/listelements.c index 7c8da35..9a2108b 100644 --- a/coreengine/listelements.c +++ b/coreengine/listelements.c @@ -474,6 +474,31 @@ cVeMenuMain::~cVeMenuMain(void) { free(label); } +int countDigits(int arg) +{ + return snprintf(NULL, 0, "%d", arg) - (arg < 0); +} + +void cVeMenuMain::SplitText(void) { + char* string = skipspace(text); + unsigned int num = atoi(string); + int digits = countDigits(num); + + free(number); + free(label); + + if (digits > 0 && digits < 4 && string[digits] == ' ') + { + if (asprintf(&label, "%s", string+digits+1)) ; + if (asprintf(&number, "%d", num)) ; + } + else + { + if (asprintf(&label, "%s", string)) ; + number = strdup(""); + } +} +/* void cVeMenuMain::SplitText(void) { char *start = skipspace(text); bool found = false; @@ -521,6 +546,7 @@ void cVeMenuMain::SplitText(void) { } label = strdup(skipspace(c)); } +*/ /****************************************************************** * cLeMenuMain diff --git a/skindesigner.c b/skindesigner.c index 326429b..fdcd745 100644 --- a/skindesigner.c +++ b/skindesigner.c @@ -20,7 +20,7 @@ #endif -static const char *VERSION = "1.2.6"; +static const char *VERSION = "1.2.7"; static const char *DESCRIPTION = trNOOP("Skin Designer"); class cPluginSkinDesigner : public cPlugin, public skindesignerapi::SkindesignerAPI {