2012-04-25 17:14:39 -03:00
|
|
|
/*
|
|
|
|
* boom.c - BOOM, main function
|
|
|
|
*
|
|
|
|
* Copyright 2012 by Werner Almesberger
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
2012-04-30 20:11:53 -03:00
|
|
|
#include <string.h>
|
2012-04-25 17:14:39 -03:00
|
|
|
|
2012-05-20 19:01:49 -03:00
|
|
|
#include "util.h"
|
2012-04-26 03:02:48 -03:00
|
|
|
#include "lang.h"
|
2012-05-20 23:16:51 -03:00
|
|
|
#include "param.h"
|
2012-05-30 12:58:29 -03:00
|
|
|
#include "chr.h"
|
2012-06-02 15:05:40 -03:00
|
|
|
#include "subst.h"
|
2012-05-20 19:01:49 -03:00
|
|
|
#include "subex.h"
|
2012-05-21 21:20:23 -03:00
|
|
|
#include "db.h"
|
2012-05-20 19:01:49 -03:00
|
|
|
|
|
|
|
|
2012-05-21 19:19:04 -03:00
|
|
|
static struct param *vars = NULL, **last_var = &vars;
|
2012-05-21 21:20:23 -03:00
|
|
|
static int select_parts = 0;
|
2012-05-30 12:58:29 -03:00
|
|
|
static int verbose = 0;
|
2012-05-20 19:01:49 -03:00
|
|
|
|
|
|
|
|
|
|
|
static void add_var(const char *arg)
|
|
|
|
{
|
|
|
|
char *tmp = stralloc(arg);
|
|
|
|
char *eq;
|
|
|
|
|
|
|
|
eq = strchr(tmp, '=');
|
|
|
|
if (!eq) {
|
|
|
|
fprintf(stderr, "no = in variable setting\n");
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
*eq = 0;
|
2012-05-20 23:16:51 -03:00
|
|
|
*last_var = make_var(tmp, rel_eq, eq+1);
|
2012-05-20 19:01:49 -03:00
|
|
|
last_var = &(*last_var)->next;
|
2012-05-21 19:19:04 -03:00
|
|
|
free(tmp);
|
2012-05-20 19:01:49 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void do_substitutions(void)
|
|
|
|
{
|
2012-05-21 19:19:04 -03:00
|
|
|
struct param *out;
|
|
|
|
const struct param *var;
|
2012-05-21 21:20:23 -03:00
|
|
|
const struct part **parts, **p;
|
2012-05-20 19:01:49 -03:00
|
|
|
|
2012-05-21 23:17:33 -03:00
|
|
|
if (!substitute(substitutions, vars, &out)) {
|
|
|
|
fprintf(stderr, "ignore\n");
|
|
|
|
return;
|
|
|
|
}
|
2012-05-21 21:20:23 -03:00
|
|
|
if (select_parts) {
|
|
|
|
parts = select_parametric(out, &hierarchy);
|
|
|
|
if (!parts) {
|
|
|
|
fprintf(stderr, "no matches\n");
|
|
|
|
} else {
|
|
|
|
for (p = parts; *p; p++)
|
|
|
|
printf("%s %s\n", (*p)->domain, (*p)->name);
|
|
|
|
free(parts);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
for (var = out; var; var = var->next) {
|
|
|
|
printf("%s", var->u.name);
|
|
|
|
dump_relop(stdout, var->op);
|
|
|
|
printf("%s\n", var->value.u.s);
|
|
|
|
}
|
|
|
|
free_vars(out);
|
2012-05-20 23:16:51 -03:00
|
|
|
}
|
2012-05-20 19:01:49 -03:00
|
|
|
}
|
2012-04-25 17:14:39 -03:00
|
|
|
|
|
|
|
|
2012-06-03 10:10:47 -03:00
|
|
|
static void parse_re(const char *re)
|
|
|
|
{
|
|
|
|
char *res;
|
|
|
|
|
|
|
|
subst_match(NULL, re, &res);
|
|
|
|
printf("%s\n", res);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-05-30 12:58:29 -03:00
|
|
|
static void dump_hierarchy(struct action act)
|
|
|
|
{
|
|
|
|
fields_dump(stderr, act.fields);
|
|
|
|
if (act.fields)
|
|
|
|
fprintf(stderr, "\n");
|
|
|
|
rules_dump(stderr, act.rules);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-06-02 05:24:50 -03:00
|
|
|
static void dump(const char *s)
|
|
|
|
{
|
|
|
|
while (*s) {
|
|
|
|
switch (*s) {
|
2012-06-02 05:49:22 -03:00
|
|
|
case 'c':
|
|
|
|
parts_dump(stderr);
|
|
|
|
break;
|
2012-06-02 05:24:50 -03:00
|
|
|
case 'h':
|
|
|
|
dump_hierarchy(hierarchy);
|
|
|
|
break;
|
2012-06-02 15:05:40 -03:00
|
|
|
case 's':
|
|
|
|
subst_dump(stderr, substitutions);
|
|
|
|
break;
|
2012-06-02 05:24:50 -03:00
|
|
|
default:
|
|
|
|
fprintf(stderr, "no database '%c'\n", *s);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
s++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-04-25 17:14:39 -03:00
|
|
|
static void usage(const char *name)
|
2012-03-18 13:24:12 -03:00
|
|
|
{
|
2012-04-30 20:11:53 -03:00
|
|
|
fprintf(stderr,
|
2012-05-30 12:58:29 -03:00
|
|
|
"usage: %s file [-v] [[-N name] [-type] file ...] [(-q|-Q) var=value ...] ...\n\n"
|
2012-04-30 20:11:53 -03:00
|
|
|
" file types:\n"
|
|
|
|
" -c characteristics\n"
|
|
|
|
" -i inventory\n"
|
2012-04-30 22:49:33 -03:00
|
|
|
" -x currency exchange\n"
|
2012-05-01 14:57:12 -03:00
|
|
|
" -p providers\n"
|
2012-05-20 11:18:18 -03:00
|
|
|
" -s substitutions\n"
|
2012-05-23 16:05:24 -03:00
|
|
|
" -b KiCad eeschema BOM\n"
|
2012-05-23 17:26:35 -03:00
|
|
|
" -X symbols (BOM supplement)\n"
|
2012-05-30 12:11:53 -03:00
|
|
|
" other options:\n"
|
2012-05-30 12:58:29 -03:00
|
|
|
" -v ... increase verbosity level\n"
|
2012-06-02 15:05:40 -03:00
|
|
|
" -dCHARS dump the specified database (h, c, s, ...)\n"
|
2012-05-30 12:11:53 -03:00
|
|
|
" -N name for the next file, override the name in diagnostics\n"
|
2012-05-23 15:14:58 -03:00
|
|
|
" -q var=value ... run substitutions with the specified inputs\n"
|
|
|
|
" -Q var=value ... run substitutions and then do parametric search\n"
|
2012-06-03 10:10:47 -03:00
|
|
|
" -R regex parse and print regular expression\n"
|
2012-04-30 20:11:53 -03:00
|
|
|
, name);
|
2012-04-25 17:14:39 -03:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
2012-05-20 19:01:49 -03:00
|
|
|
void (*process)(const char *name) = parse_hierarchy;
|
2012-06-02 23:09:17 -03:00
|
|
|
int query = 0;
|
2012-04-28 11:46:42 -03:00
|
|
|
int i;
|
|
|
|
|
2012-05-22 13:01:39 -03:00
|
|
|
dollar = unique("$");
|
2012-06-03 02:04:27 -03:00
|
|
|
subst_init();
|
2012-06-03 02:00:56 -03:00
|
|
|
subex_init();
|
2012-04-30 20:11:53 -03:00
|
|
|
for (i = 1; i != argc; i++) {
|
2012-06-02 05:26:33 -03:00
|
|
|
if (*argv[i] != '-') {
|
2012-05-20 19:01:49 -03:00
|
|
|
process(argv[i]);
|
2012-06-02 05:26:33 -03:00
|
|
|
continue;
|
2012-04-30 20:11:53 -03:00
|
|
|
}
|
2012-06-02 05:26:33 -03:00
|
|
|
if (!strcmp(argv[i], "-N")) {
|
|
|
|
i++;
|
|
|
|
file_name_override = argv[i];
|
|
|
|
} else if (!strcmp(argv[i], "-v")) {
|
|
|
|
verbose++;
|
|
|
|
} else if (!strncmp(argv[i], "-d", 2)) {
|
|
|
|
if (argv[i][2]) {
|
|
|
|
dump(argv[i]+2);
|
|
|
|
} else {
|
|
|
|
i++;
|
|
|
|
if (!argv[i])
|
|
|
|
usage(*argv);
|
|
|
|
dump(argv[i]);
|
|
|
|
}
|
|
|
|
} else if (!strcmp(argv[i], "-c")) {
|
|
|
|
process = parse_characteristics;
|
|
|
|
} else if (!strcmp(argv[i], "-i")) {
|
|
|
|
process = parse_inventory;
|
|
|
|
} else if (!strcmp(argv[i], "-x")) {
|
|
|
|
process = parse_currencies;
|
|
|
|
} else if (!strcmp(argv[i], "-p")) {
|
|
|
|
process = parse_providers;
|
|
|
|
} else if (!strcmp(argv[i], "-s")) {
|
|
|
|
process = parse_substitutions;
|
|
|
|
} else if (!strcmp(argv[i], "-b")) {
|
|
|
|
process = parse_kicad_bom;
|
|
|
|
} else if (!strcmp(argv[i], "-X")) {
|
|
|
|
process = parse_symbols;
|
|
|
|
} else if (!strcmp(argv[i], "-q")) {
|
|
|
|
process = add_var;
|
2012-06-02 23:09:17 -03:00
|
|
|
query = 1;
|
2012-06-02 05:26:33 -03:00
|
|
|
} else if (!strcmp(argv[i], "-Q")) {
|
|
|
|
process = add_var;
|
2012-06-02 23:09:17 -03:00
|
|
|
query = 1;
|
2012-06-02 05:26:33 -03:00
|
|
|
select_parts = 1;
|
2012-06-03 10:10:47 -03:00
|
|
|
} else if (!strcmp(argv[i], "-R")) {
|
|
|
|
i++;
|
|
|
|
if (!argv[i])
|
|
|
|
usage(*argv);
|
|
|
|
parse_re(argv[i]);
|
2012-06-02 05:26:33 -03:00
|
|
|
} else
|
|
|
|
usage(*argv);
|
2012-04-28 11:46:42 -03:00
|
|
|
}
|
2012-06-02 23:09:17 -03:00
|
|
|
if (query)
|
2012-05-20 19:01:49 -03:00
|
|
|
do_substitutions();
|
2012-03-18 13:24:12 -03:00
|
|
|
return 0;
|
|
|
|
}
|