mirror of
git://projects.qi-hardware.com/eda-tools.git
synced 2024-11-23 01:14:04 +02:00
b2/: add provider database (WIP)
This commit is contained in:
parent
c3a68453d0
commit
82d532e4a2
@ -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
1
b2/PROVIDER
Normal file
@ -0,0 +1 @@
|
|||||||
|
FOO USD 0 0
|
@ -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
39
b2/db.c
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
5
b2/db.h
5
b2/db.h
@ -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 */
|
||||||
|
@ -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, ...);
|
||||||
|
10
b2/lang.l
10
b2/lang.l
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
%}
|
%}
|
||||||
|
|
||||||
|
|
||||||
|
34
b2/lang.y
34
b2/lang.y
@ -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;
|
||||||
|
}
|
||||||
|
;
|
||||||
|
Loading…
Reference in New Issue
Block a user