what will eventually be the smart playlist parser

This commit is contained in:
Ron Pedde 2005-08-02 03:17:22 +00:00
parent 15fcb6b902
commit 517fe14667
4 changed files with 134 additions and 0 deletions

19
src/parser-driver.c Normal file
View File

@ -0,0 +1,19 @@
/*
* Test harness for the parser
*/
#include <stdio.h>
#include "smart-parser.h"
int main(int argc, char *argv[]) {
PARSETREE pt;
printf("Parsing %s\n",argv[1]);
pt=sp_init();
sp_parse(pt,argv[1]);
sp_dispose(pt);
printf("Done!\n");
return 0;
}

8
src/parser.mk Normal file
View File

@ -0,0 +1,8 @@
CC=gcc
CFLAGS := $(CFLAGS) -g -I/sw/include -DHAVE_CONFIG_H -I. -I.. -Wall
TARGET=parser
OBJECTS=parser-driver.o smart-parser.o err.o
$(TARGET): $(OBJECTS)
$(CC) -o $(TARGET) $(LDFLAGS) $(OBJECTS)

91
src/smart-parser.c Normal file
View File

@ -0,0 +1,91 @@
/*
* $Id$
*
* This is really two parts -- the lexer and the parser. Converting
* a parse tree back to a format that works with the database backend
* is left to the db backend.
*
* Oh, and this is called "smart-parser" because it parses terms for
* specifying smart playlists, not because it is particularly smart. :)
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "err.h"
typedef struct tag_parsetree {
char *term;
int token;
int next_token;
} PARSESTRUCT, *PARSETREE;
#define SP_TOK_EOF 0
/**
* set up the initial parse tree
*
* @returns opaque parsetree struct
*/
PARSETREE sp_init(void) {
PARSETREE ptree;
ptree = (PARSETREE)malloc(sizeof(PARSESTRUCT));
if(!ptree)
DPRINTF(E_FATAL,L_PARSE,"Alloc error\n");
memset(ptree,0,sizeof(PARSESTRUCT));
return ptree;
}
/**
* parse a term or phrase into a tree.
*
* @param tree parsetree previously created with sp_init
* @param term term or phrase to parse
* @returns 1 if successful, 0 if not
*/
int sp_parse(PARSETREE tree, char *term) {
tree->term = strdup(term); /* will be destroyed by parsing */
while(sp_scan(tree)) {
if(tree->token == SP_TOK_EOF)
return 1; /* valid tree! */
/* otherwise, keep scanning until done or error */
}
}
/**
* dispose of an initialized tree
*
* @param tree tree to dispose
* @returns 1
*/
int sp_dispose(PARSETREE tree) {
if(tree->term)
free(tree->term);
free(tree);
return 1;
}
/**
* if there was an error in a previous action (parsing?)
* then return that error to the client. This does not
* clear the error condition -- multiple calls to sp_geterror
* will return the same value.
*
* memory handling is done on the smart-parser side.
*
* @param tree tree that generated the last error
* @returns text of the last error
*/
char *sp_geterror(PARSETREE tree) {
return "blah";
}

16
src/smart-parser.h Normal file
View File

@ -0,0 +1,16 @@
/*
* $Id$
*/
#ifndef _SMART_PARSER_H_
#define _SMART_PARSER_H_
typedef void* PARSETREE;
extern PARSETREE sp_init(void);
extern int sp_parse(PARSETREE *tree, char *term);
extern int sp_dispose(PARSETREE tree);
extern char *sp_geterror(PARSETREE tree);
#endif /* _SMART_PARSER_H_ */