From 9c21258e2cd7904ff0933f8a9bb4c5bc428c23cc Mon Sep 17 00:00:00 2001 From: Jonathan Gordon Date: Tue, 21 Feb 2012 00:34:58 +1100 Subject: skin engine: Add 'touch' command to the %vs() tag %vs(label, touch, -) will reset the timeout for the variable without changing the variables value. Change-Id: Idba03f454a82ac7460bb53a4de3aa6903656c585 --- apps/gui/skin_engine/skin_parser.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'apps/gui') diff --git a/apps/gui/skin_engine/skin_parser.c b/apps/gui/skin_engine/skin_parser.c index 0be88f4..8409f0e 100644 --- a/apps/gui/skin_engine/skin_parser.c +++ b/apps/gui/skin_engine/skin_parser.c @@ -1179,7 +1179,10 @@ static int parse_skinvar( struct skin_element *element, if (!data) return WPS_ERROR_INVALID_PARAM; data->var = PTRTOSKINOFFSET(skin_buffer, var); - data->newval = get_param(element, 2)->data.number; + if (!isdefault(get_param(element, 2))) + data->newval = get_param(element, 2)->data.number; + else if (strcmp(get_param_text(element, 1), "touch")) + return WPS_ERROR_INVALID_PARAM; data->max = 0; if (!strcmp(get_param_text(element, 1), "set")) data->direct = true; @@ -1192,6 +1195,11 @@ static int parse_skinvar( struct skin_element *element, data->direct = false; data->newval *= -1; } + else if (!strcmp(get_param_text(element, 1), "touch")) + { + data->direct = false; + data->newval = 0; + } if (element->params_count > 3) data->max = get_param(element, 3)->data.number; token->value.data = PTRTOSKINOFFSET(skin_buffer, data); -- cgit v1.1