first go at a general skin updater program. not very useful yet

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26332 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Jonathan Gordon 2010-05-27 15:35:22 +00:00
parent 7b197352a2
commit e7ef935448
3 changed files with 533 additions and 0 deletions

View file

@ -0,0 +1,199 @@
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <string.h>
#include "tag_table.h"
#define PUTCH(out, c) fprintf(out, "%c", c)
extern struct tag_info legal_tags[];
/* dump "count" args to output replacing '|' with ',' except after the last count.
* return the amount of chars read. (start+return will be after the last | )
*/
int dump_arg(FILE* out, const char* start, int count, bool close)
{
int l = 0;
while (count)
{
if (start[l] == '|')
{
if (count > 1)
{
printf(",");
} else if (close) {
printf(")");
}
count--;
} else {
PUTCH(out, start[l]);
}
l++;
}
return l;
}
#define MATCH(s) (!strcmp(tag->name, s))
int parse_tag(FILE* out, const char* start)
{
struct tag_info *tag;
int len = 0;
for(tag = legal_tags;
tag->name[0] && strncmp(start, tag->name, strlen(tag->name)) != 0;
tag++) ;
if (!tag->name[0])
return -1;
if (tag->params[0] == '\0')
{
fprintf(out, "%s", tag->name);
return strlen(tag->name);
}
fprintf(out, "%s", tag->name);
len += strlen(tag->name);
start += len;
/* handle individual tags which accept params */
if (MATCH("bl") || MATCH("pb") || MATCH("pv"))
{
start++; len++;
if (*start == '|')
{
PUTCH(out, '(');
/* TODO: need to verify that we are actually using the long form... */
len += dump_arg(out, start, 5, true);
}
}
else if (MATCH("d") || MATCH("D") || MATCH("mv") || MATCH("pS") || MATCH("pE") || MATCH("t") || MATCH("Tl"))
{
char temp[8] = {'\0'};
int i = 0;
/* tags which maybe have a number after them */
while ((*start >= '0' && *start <= '9') || *start == '.')
{
temp[i++] = *start++;
}
if (i!= 0)
{
fprintf(out, "(%s)", temp);
len += i;
}
}
else if (MATCH("xl"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 5, true);
}
else if (MATCH("xd"))
{
/* NOTE: almost certainly needs work */
PUTCH(out, '(');
PUTCH(out, *start++); len++;
if ((*start >= 'a' && *start <= 'z') ||
(*start >= 'A' && *start <= 'Z'))
PUTCH(out, *start); len++;
PUTCH(out, ')');
}
else if (MATCH("x"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 4, true);
}
else if (MATCH("Fl"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 2, true);
}
else if (MATCH("Cl"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 4, true);
}
else if (MATCH("Vd") || MATCH("VI"))
{
PUTCH(out, '(');
PUTCH(out, *start); len++;
PUTCH(out, ')');
}
else if (MATCH("Vp"))
{
/* NOTE: almost certainly needs work */
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 3, true);
}
else if (MATCH("Vl") || MATCH("Vi"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 8, true);
}
else if (MATCH("V"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 7, true);
}
else if (MATCH("X"))
{
if (*start+1 == 'd')
{
fprintf(out, "(d)");
len ++;
}
else
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 1, true);
}
}
else if (MATCH("St") || MATCH("Sx"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 1, true);
}
else if (MATCH("T"))
{
PUTCH(out, '(');
len += 1+dump_arg(out, start+1, 5, true);
}
return len;
}
void parse_text(const char* in, FILE* out)
{
const char* end = in+strlen(in);
top:
while (in < end && *in)
{
if (*in == '%')
{
PUTCH(out, *in++);
switch(*in)
{
case '%':
case '<':
case '|':
case '>':
case ';':
case '#':
PUTCH(out, *in++);
goto top;
break;
case '?':
PUTCH(out, *in++);
break;
}
in += parse_tag(out, in);
}
else
{
PUTCH(out, *in++);
}
}
}
int main(int argc, char* argv[])
{
parse_text("%s%?it<%?in<%in. |>%it|%fn>\n"
"%s%?ia<%ia|%?d2<%d2|(root)>>\n"
"%s%?id<%id|%?d1<%d1|(root)>> %?iy<(%iy)|>\n\n"
"%al%pc/%pt%ar[%pp:%pe]\n"
"%fbkBit %?fv<avg|> %?iv<(id3v%iv)|(no id3)>\n"
"%pb\n%pm\n", stdout);
return 0;
}

View file

@ -0,0 +1,252 @@
/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id: tag_table.c 26297 2010-05-26 03:53:06Z jdgordon $
*
* Copyright (C) 2010 Robert Bieber
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
****************************************************************************/
#include "tag_table.h"
#include <string.h>
/* The tag definition table */
struct tag_info legal_tags[] =
{
{ "ac", "" },
{ "al", "" },
{ "aL", "" },
{ "ar", "" },
{ "aR", "" },
{ "aX", "" },
{ "bl" , "*fIIII" },
{ "bv", "" },
{ "bt", "" },
{ "bs", "" },
{ "bc", "" },
{ "bp", "" },
{ "bu", "" },
{ "cc", "" },
{ "cd", "" },
{ "ce", "" },
{ "cf", "" },
{ "cH", "" },
{ "ck", "" },
{ "cI", "" },
{ "cl", "" },
{ "cm", "" },
{ "cM", "" },
{ "cS", "" },
{ "cy", "" },
{ "cY", "" },
{ "cP", "" },
{ "cp", "" },
{ "ca", "" },
{ "cb", "" },
{ "cu", "" },
{ "cw", "" },
{ "fb", "" },
{ "fc", "" },
{ "ff", "" },
{ "fk", "" },
{ "fm", "" },
{ "fn", "" },
{ "fp", "" },
{ "fs", "" },
{ "fv", "" },
{ "d" , "I" },
{ "Fb", "" },
{ "Fc", "" },
{ "Ff", "" },
{ "Fk", "" },
{ "Fm", "" },
{ "Fn", "" },
{ "Fp", "" },
{ "Fs", "" },
{ "Fv", "" },
{ "D" , "I" },
{ "ia", "" },
{ "ic", "" },
{ "id", "" },
{ "iA", "" },
{ "iG", "" },
{ "ig", "" },
{ "ik", "" },
{ "in", "" },
{ "it", "" },
{ "iv", "" },
{ "iy", "" },
{ "iC", "" },
{ "Ia", "" },
{ "Ic", "" },
{ "Id", "" },
{ "IA", "" },
{ "IG", "" },
{ "Ig", "" },
{ "Ik", "" },
{ "In", "" },
{ "It", "" },
{ "Iv", "" },
{ "Iy", "" },
{ "IC", "" },
{ "Sp", "" },
{ "Ss", "" },
{ "lh", "" },
{ "mh", "" },
{ "mr", "" },
{ "mm", "" },
{ "mp", "" },
{ "mv", "|I" },
{ "pm", "" },
{ "pf", "" },
{ "pb" , "*fIIII" },
{ "pv" , "*fIIII" },
{ "px", "" },
{ "pc", "" },
{ "pr", "" },
{ "pt", "" },
{ "pS" , "|I"},
{ "pE" , "|I"},
{ "pp", "" },
{ "pe", "" },
{ "pn", "" },
{ "ps", "" },
{ "rp", "" },
{ "rr", "" },
{ "ra", "" },
{ "rg", "" },
{ "xf", "" },
{ "tp", "" },
{ "tt", "" },
{ "tm", "" },
{ "ts", "" },
{ "ta", "" },
{ "tb", "" },
{ "tf", "" },
{ "Ti", "" },
{ "Tn", "" },
{ "Tf", "" },
{ "Tc", "" },
{ "tx", "" },
{ "ty", "" },
{ "tz", "" },
{ "s", "" },
{ "t" , "I" },
{ "we", "" },
{ "wd", "" },
{ "wi", "" },
{ "xl", "SFIIi" },
{ "xd", "S" },
{ "x", "SFII" },
{ "Fl" , "IF"},
{ "Cl" , "IISS"},
{ "C" , ""},
{ "Vd" , "S"},
{ "VI" , "S"},
{ "Vp" , "ICC"},
{ "Lt" , ""},
{ "Li" , ""},
{ "Vl" , "SIIiii|ii"},
{ "Vi" , "sIIiii|ii"},
{ "V" , "IIiii|ii"},
{ "X" , "f"},
{ "St" , "S"},
{ "Sx" , "S"},
{ "Sr" , ""},
{ "Tl" , "|I"},
{ "cs", "" },
{ "T" , "IIiiI"},
{ "Rp" , ""},
{ "Rr" , ""},
{ "Rf" , ""},
{ "Re" , ""},
{ "Rb" , ""},
{ "Rm" , ""},
{ "Rs" , ""},
{ "Rn" , ""},
{ "Rh" , ""},
{ "s",""},
{ "" , ""} /* Keep this here to mark the end of the table */
};
/* A table of legal escapable characters */
char legal_escape_characters[] = "%(,);#<|>";
/*
* Just does a straight search through the tag table to find one by
* the given name
*/
char* find_tag(char* name)
{
struct tag_info* current = legal_tags;
/*
* Continue searching so long as we have a non-empty name string
* and the name of the current element doesn't match the name
* we're searching for
*/
while(strcmp(current->name, name) && current->name[0] != '\0')
current++;
if(current->name[0] == '\0')
return NULL;
else
return current->params;
}
/* Searches through the legal escape characters string */
int find_escape_character(char lookup)
{
char* current = legal_escape_characters;
while(*current != lookup && *current != '\0')
current++;
if(*current == lookup)
return 1;
else
return 0;
}

View file

@ -0,0 +1,82 @@
/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id: tag_table.h 26292 2010-05-25 22:24:08Z bieber $
*
* Copyright (C) 2010 Robert Bieber
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
****************************************************************************/
#ifndef TAG_TABLE_H
#define TAG_TABLE_H
#ifdef __cplusplus
extern "C"
{
namespace wps
{
#endif
/*
* Struct for tag parsing information
* name - The name of the tag, i.e. V for %V
* params - A string specifying all of the tags parameters, each
* character representing a single parameter. Valid
* characters for parameters are:
* I - Required integer
* i - Nullable integer
* S - Required string
* s - Nullable string
* F - Required file name
* f - Nullable file name
* C - Required WPS code
* Any nullable parameter may be replaced in the WPS file
* with a '-'. To specify that parameters may be left off
* altogether, place a '|' in the parameter string. For
* instance, with the parameter string...
* Ii|Ss
* one integer must be specified, one integer can be
* specified or set to default with '-', and the user can
* stop providing parameters at any time after that.
* To specify multiple instances of the same type, put a
* number before the character. For instance, the string...
* 2s
* will specify two strings. An asterisk (*) at the beginning of the
* string will specify that either all or none of the optional
*
*/
struct tag_info
{
char* name;
char* params;
};
/*
* Finds a tag by name and returns its parameter list, or an empty
* string if the tag is not found in the table
*/
char* find_tag(char* name);
/*
* Determines whether a character is legal to escape or not. If
* lookup is not found in the legal escape characters string, returns
* false, otherwise returns true
*/
int find_escape_character(char lookup);
#endif /* TAG_TABLE_H */