Theme Editor: Made Viewport the top level parse tree element, along with a bugfix to the tag parsing function
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26442 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
acb524e51a
commit
d1659d69df
|
@ -35,7 +35,11 @@ int main(int argc, char* argv[])
|
|||
{
|
||||
QApplication app(argc, argv);
|
||||
|
||||
char doc[] = "#Comment\n%Vd(U);Hey\n%?bl(test,3,5,2,1)<param2|param3>";
|
||||
char doc[] = "#Comment\n"
|
||||
"%Vd(U);Hey\n"
|
||||
"%?bl(test,3,5,2,1)<param2|param3>\n"
|
||||
"%V(1,2,3,4,5)%pS(5)\n"
|
||||
"Some more stuff here";
|
||||
|
||||
ParseTreeModel tree(doc);
|
||||
|
||||
|
|
|
@ -64,6 +64,7 @@ ParseTreeNode::ParseTreeNode(struct skin_element* data, ParseTreeNode* parent)
|
|||
}
|
||||
break;
|
||||
|
||||
case VIEWPORT:
|
||||
case LINE:
|
||||
for(struct skin_element* current = data->children[0]; current;
|
||||
current = current->next)
|
||||
|
@ -92,6 +93,10 @@ QString ParseTreeNode::genCode() const
|
|||
{
|
||||
switch(element->type)
|
||||
{
|
||||
|
||||
case VIEWPORT:
|
||||
buffer.append(children[0]->genCode());
|
||||
|
||||
case LINE:
|
||||
for(int i = 0; i < children.count(); i++)
|
||||
{
|
||||
|
@ -220,6 +225,9 @@ QVariant ParseTreeNode::data(int column) const
|
|||
{
|
||||
switch(element->type)
|
||||
{
|
||||
case VIEWPORT:
|
||||
return QObject::tr("Viewport");
|
||||
|
||||
case LINE:
|
||||
return QObject::tr("Logical Line");
|
||||
|
||||
|
@ -272,6 +280,7 @@ QVariant ParseTreeNode::data(int column) const
|
|||
{
|
||||
switch(element->type)
|
||||
{
|
||||
case VIEWPORT:
|
||||
case LINE:
|
||||
case SUBLINES:
|
||||
case CONDITIONAL:
|
||||
|
|
|
@ -91,6 +91,16 @@ void skin_debug_tree(struct skin_element* root)
|
|||
switch(current->type)
|
||||
{
|
||||
|
||||
case VIEWPORT:
|
||||
printf("[ Viewport \n");
|
||||
|
||||
debug_indent_level++;
|
||||
skin_debug_tree(current->children[0]);
|
||||
debug_indent_level--;
|
||||
|
||||
printf("]");
|
||||
break;
|
||||
|
||||
case TEXT:
|
||||
printf("[ Plain text on line %d : %s ]\n", current->line,
|
||||
current->text);
|
||||
|
|
|
@ -38,6 +38,7 @@ int skin_current_block = 0;
|
|||
int skin_line = 0;
|
||||
|
||||
/* Auxiliary parsing functions (not visible at global scope) */
|
||||
struct skin_element* skin_parse_viewport(char** document);
|
||||
struct skin_element* skin_parse_line(char** document);
|
||||
struct skin_element* skin_parse_line_optional(char** document, int conditional);
|
||||
struct skin_element* skin_parse_sublines(char** document);
|
||||
|
@ -54,26 +55,68 @@ struct skin_element* skin_parse_code_as_arg(char** document);
|
|||
|
||||
struct skin_element* skin_parse(char* document)
|
||||
{
|
||||
|
||||
|
||||
struct skin_element* root = NULL;
|
||||
struct skin_element* last = NULL;
|
||||
|
||||
struct skin_element** to_write = 0;
|
||||
|
||||
char* cursor = document; /* Keeps track of location in the document */
|
||||
char* bookmark; /* Used when we need to look ahead */
|
||||
|
||||
int sublines = 0; /* Flag for parsing sublines */
|
||||
char* cursor = document; /* Keeps track of location in the document */
|
||||
|
||||
skin_line = 1;
|
||||
|
||||
while(*cursor != '\0')
|
||||
{
|
||||
|
||||
if(!root)
|
||||
to_write = &root;
|
||||
else
|
||||
to_write = &(last->next);
|
||||
|
||||
|
||||
*to_write = skin_parse_viewport(&cursor);
|
||||
last = *to_write;
|
||||
if(!last)
|
||||
return NULL;
|
||||
|
||||
/* Making sure last is at the end */
|
||||
while(last->next)
|
||||
last = last->next;
|
||||
|
||||
}
|
||||
|
||||
return root;
|
||||
|
||||
}
|
||||
|
||||
struct skin_element* skin_parse_viewport(char** document)
|
||||
{
|
||||
|
||||
struct skin_element* root = NULL;
|
||||
struct skin_element* last = NULL;
|
||||
struct skin_element* retval = NULL;
|
||||
|
||||
retval = skin_alloc_element();
|
||||
retval->type = VIEWPORT;
|
||||
retval->children = skin_alloc_children(1);
|
||||
retval->children_count = 1;
|
||||
retval->line = skin_line;
|
||||
|
||||
struct skin_element** to_write = 0;
|
||||
|
||||
char* cursor = *document; /* Keeps track of location in the document */
|
||||
char* bookmark; /* Used when we need to look ahead */
|
||||
|
||||
int sublines = 0; /* Flag for parsing sublines */
|
||||
|
||||
while(*cursor != '\0' && !(check_viewport(cursor) && cursor != *document))
|
||||
{
|
||||
|
||||
/* First, we check to see if this line will contain sublines */
|
||||
bookmark = cursor;
|
||||
sublines = 0;
|
||||
while(*cursor != '\n' && *cursor != '\0')
|
||||
while(*cursor != '\n' && *cursor != '\0'
|
||||
&& !(check_viewport(cursor) && cursor != *document))
|
||||
{
|
||||
if(*cursor == MULTILINESYM)
|
||||
{
|
||||
|
@ -135,10 +178,13 @@ struct skin_element* skin_parse(char* document)
|
|||
while(last->next)
|
||||
last = last->next;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
*document = cursor;
|
||||
|
||||
retval->children[0] = root;
|
||||
return retval;
|
||||
|
||||
return root;
|
||||
|
||||
}
|
||||
|
||||
/* Auxiliary Parsing Functions */
|
||||
|
@ -176,7 +222,8 @@ struct skin_element* skin_parse_line_optional(char** document, int conditional)
|
|||
|| *cursor == ARGLISTCLOSESYM
|
||||
|| *cursor == ENUMLISTSEPERATESYM
|
||||
|| *cursor == ENUMLISTCLOSESYM)
|
||||
&& conditional))
|
||||
&& conditional)
|
||||
&& !(check_viewport(cursor) && cursor != *document))
|
||||
{
|
||||
/* Allocating memory if necessary */
|
||||
if(root)
|
||||
|
@ -244,7 +291,8 @@ struct skin_element* skin_parse_sublines_optional(char** document,
|
|||
|| *cursor == ARGLISTCLOSESYM
|
||||
|| *cursor == ENUMLISTSEPERATESYM
|
||||
|| *cursor == ENUMLISTCLOSESYM)
|
||||
&& conditional))
|
||||
&& conditional)
|
||||
&& !(check_viewport(cursor) && cursor != *document))
|
||||
{
|
||||
if(*cursor == COMMENTSYM)
|
||||
skip_comment(&cursor);
|
||||
|
@ -405,7 +453,7 @@ int skin_parse_tag(struct skin_element* element, char** document)
|
|||
if(*tag_args == '|')
|
||||
{
|
||||
optional = 1;
|
||||
req_args = i - 1;
|
||||
req_args = i;
|
||||
tag_args++;
|
||||
}
|
||||
|
||||
|
@ -478,6 +526,14 @@ int skin_parse_tag(struct skin_element* element, char** document)
|
|||
|
||||
tag_args++;
|
||||
|
||||
/* Checking for the optional bar */
|
||||
if(*tag_args == '|')
|
||||
{
|
||||
optional = 1;
|
||||
req_args = i + 1;
|
||||
tag_args++;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/* Checking for a premature end */
|
||||
|
|
|
@ -42,6 +42,7 @@ extern char skin_parse_tree[];
|
|||
/* Possible types of element in a WPS file */
|
||||
enum skin_element_type
|
||||
{
|
||||
VIEWPORT,
|
||||
LINE,
|
||||
SUBLINES,
|
||||
CONDITIONAL,
|
||||
|
|
|
@ -22,6 +22,7 @@
|
|||
#include <stdio.h>
|
||||
#include <ctype.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "skin_scan.h"
|
||||
#include "skin_debug.h"
|
||||
|
@ -136,3 +137,22 @@ int scan_int(char** document)
|
|||
*document = cursor;
|
||||
return retval;
|
||||
}
|
||||
|
||||
int check_viewport(char* document)
|
||||
{
|
||||
if(strlen(document) < 3)
|
||||
return 0;
|
||||
|
||||
if(document[0] != TAGSYM)
|
||||
return 0;
|
||||
|
||||
if(document[1] != 'V')
|
||||
return 0;
|
||||
|
||||
if(document[2] != ARGLISTOPENSYM
|
||||
&& document[2] != 'l'
|
||||
&& document[2] != 'i')
|
||||
return 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
|
|
@ -33,6 +33,7 @@ void skip_comment(char** document);
|
|||
void skip_whitespace(char** document);
|
||||
char* scan_string(char** document);
|
||||
int scan_int(char** document);
|
||||
int check_viewport(char* document); /* Checks for a viewport declaration */
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user