1
0
mirror of git://projects.qi-hardware.com/eda-tools.git synced 2024-11-22 20:14:04 +02:00

b2/: add provider database (WIP)

This commit is contained in:
Werner Almesberger 2012-05-01 14:57:12 -03:00
parent c3a68453d0
commit 82d532e4a2
8 changed files with 92 additions and 3 deletions

View File

@ -83,4 +83,4 @@ spotless: clean
# ----- Experiments ----------------------------------------------------------- # ----- Experiments -----------------------------------------------------------
try: try:
$(VALGRIND) ./boom HIERARCHY -c CHAR -x CURR -i INV $(VALGRIND) ./boom HIERARCHY -c CHAR -x CURR -p PROVIDER -i INV

1
b2/PROVIDER Normal file
View File

@ -0,0 +1 @@
FOO USD 0 0

View File

@ -43,6 +43,7 @@ static void usage(const char *name)
" -c characteristics\n" " -c characteristics\n"
" -i inventory\n" " -i inventory\n"
" -x currency exchange\n" " -x currency exchange\n"
" -p providers\n"
, name); , name);
exit(1); exit(1);
} }
@ -61,6 +62,8 @@ int main(int argc, char **argv)
parse = parse_inventory; parse = parse_inventory;
else if (!strcmp(argv[i], "-x")) else if (!strcmp(argv[i], "-x"))
parse = parse_currencies; parse = parse_currencies;
else if (!strcmp(argv[i], "-p"))
parse = parse_providers;
else else
usage(*argv); usage(*argv);
} else { } else {

39
b2/db.c
View File

@ -257,3 +257,42 @@ void currency_exchange(struct currency *from, const struct currency *to,
(*ex)->rate = rate; (*ex)->rate = rate;
(*ex)->next = NULL; (*ex)->next = NULL;
} }
/* ----- Provider database ------------------------------------------------- */
static struct provider *providers = NULL;
struct provider *provider_lookup(const char *name)
{
struct provider *p;
for (p = providers; p; p = p->next)
if (p->name == name)
break;
return p;
}
struct provider *provider_add(const char *name)
{
struct provider *p;
p = provider_lookup(name);
if (p)
return p;
p = alloc_type(struct provider);
p->name = name;
p->curr = NULL;
p->shipping = 0;
p->minimum = 0;
p->next = providers;
providers = p;
return p;
}

View File

@ -54,9 +54,9 @@ struct price {
struct provider { struct provider {
const char *name; const char *name;
const struct currency *curr;
double shipping; /* S&H cost */ double shipping; /* S&H cost */
double minimum; /* value of minimum order, before S&H */ double minimum; /* value of minimum order, before S&H */
const struct currency *curr;
struct provider *next; struct provider *next;
}; };
@ -105,4 +105,7 @@ struct currency *currency_add(const char *name);
void currency_exchange(struct currency *from, const struct currency *to, void currency_exchange(struct currency *from, const struct currency *to,
double rate); double rate);
struct provider *provider_lookup(const char *name);
struct provider *provider_add(const char *name);
#endif /* !DB_H */ #endif /* !DB_H */

View File

@ -17,6 +17,7 @@ void parse_hierarchy(void);
void parse_characteristics(void); void parse_characteristics(void);
void parse_inventory(void); void parse_inventory(void);
void parse_currencies(void); void parse_currencies(void);
void parse_providers(void);
void yywarnf(const char *fmt, ...); void yywarnf(const char *fmt, ...);
void yyerrorf(const char *fmt, ...); void yyerrorf(const char *fmt, ...);

View File

@ -53,6 +53,7 @@ void parse_inventory(void)
yyparse(); yyparse();
} }
void parse_currencies(void) void parse_currencies(void)
{ {
start_token = START_EXCHANGE; start_token = START_EXCHANGE;
@ -61,6 +62,15 @@ void parse_currencies(void)
yyparse(); yyparse();
} }
void parse_providers(void)
{
start_token = START_PROVIDERS;
expose_nl = 1;
lineno = 1;
yyparse();
}
%} %}

View File

@ -80,11 +80,12 @@ static const struct field *top_field(void)
struct param *param; struct param *param;
struct price *price; struct price *price;
struct stock *stock; struct stock *stock;
struct provider *prov;
}; };
%token START_HIERARCHY START_CHAR START_INVENTORY %token START_HIERARCHY START_CHAR START_INVENTORY
%token START_EXCHANGE %token START_EXCHANGE START_PROVIDERS
%token TOK_LE TOK_GE TOK_NL %token TOK_LE TOK_GE TOK_NL
%token <s> WORD %token <s> WORD
@ -102,6 +103,7 @@ static const struct field *top_field(void)
%type <param> param params %type <param> param params
%type <price> prices price %type <price> prices price
%type <stock> stock %type <stock> stock
%type <prov> providers provider
%% %%
@ -110,6 +112,7 @@ all:
| START_CHAR characteristics | START_CHAR characteristics
| START_INVENTORY inventory | START_INVENTORY inventory
| START_EXCHANGE exchange | START_EXCHANGE exchange
| START_PROVIDERS providers
; ;
@ -520,3 +523,32 @@ rate:
currency_exchange(curr, to, $2); currency_exchange(curr, to, $2);
} }
; ;
/* ----- Providers --------------------------------------------------------- */
providers:
{
$$ = NULL;
}
| TOK_NL
{
$$ = NULL;
}
| provider providers
{
$$ = $1;
$$->next = $2;
}
;
provider:
WORD WORD float float TOK_NL
{
$$ = provider_add($1);
$$->curr = currency_add($2);
$$->shipping = $3;
$$->minimum = $4;
}
;