3 # Convert CSV parts list into vendor import format
5 # Copyright © 2015 Keith Packard <keithp@keithp.com>, GPL v3+
11 string[*] not_vendors;
12 string not_vendor_list;
19 void fatal(string format, poly args ...)
21 File::fprintf(stderr, format, args...);
25 string[*] read_line(file f) {
27 string line = fgets(f);
29 return String::parse_csv(line);
34 string[*] required_elements = {
45 bool has_header_member(string member) {
46 for (int i = 0; i < dim(header); i++)
47 if (header[i] == member)
52 bool has_vendor(string[*] vendors, string vendor) {
53 for (int i = 0; i < dim(vendors); i++)
54 if (vendors[i] == vendor)
59 void read_header(file f) {
60 header = read_line(f);
62 for (int i = 0; i < dim(required_elements); i++)
63 if (!has_header_member(required_elements[i]))
64 fatal("Missing header element \"%s\"\n", required_elements[i]);
67 string[string] read_entry(file f) {
68 string[*] elements = read_line(f);
69 string[string] entry = {};
71 if (dim(header) != dim(elements))
72 fatal("line %d: has %d instead of %d elements (%V)\n",
73 lineno, dim(elements), dim(header), elements);
75 for (int i = 0; i < dim(header); i++) {
76 if (elements[i] == "")
77 elements[i] = "unknown";
78 entry[header[i]] = elements[i];
83 string part_number(string[string] entry)
86 return entry["mfg_part_number"];
88 return entry["vendor_part_number"];
91 void process_seeed(string[string] entry)
93 if (entry["loadstatus"] == "noload")
96 static bool start = true;
98 printf("Part/Designator,Manufacturer Part Number/Seeed SKU, Quantity\n");
102 string[*] refdes = String::wordsplit(entry["refdes"], " \t");
105 for (int i = 0; i < dim(refdes); i++) {
106 printf("%s", refdes[i]);
107 if (i < dim(refdes) - 1)
112 printf(",%s,%s\n", entry["mfg_part_number"], entry["quantity"]);
115 void process_digikey(string[string] entry)
117 if (entry["loadstatus"] == "noload")
119 printf("%s,%s,%s %s\n",
126 void process_mouser(string[string] entry)
128 if (entry["loadstatus"] == "noload")
130 /* printf("%s|%s\n", part_number(entry), entry["quantity"]); */
132 static bool start = true;
135 printf("Mouser Part Number,Manufacturer Part Number,Quantity 1\n");
140 entry["vendor_part_number"],
141 entry["mfg_part_number"],
145 void process_other(string[string] entry) {
146 if (entry["loadstatus"] == "noload")
148 printf("%s,%s,%s,%s %s\n",
156 void process_file(file f) {
158 while (!File::end(f)) {
159 string[string] entry = read_entry(f);
160 string vendor = entry["vendor"];
161 if (!is_uninit(&vendors) && has_vendor(vendors, "seeed")) {
162 process_seeed(entry);
163 } else if ((!is_uninit(&vendors) && has_vendor(vendors, vendor)) ||
164 (!is_uninit(¬_vendors) && !has_vendor(not_vendors, vendor))) {
165 switch (entry["vendor"]) {
167 process_digikey(entry);
170 process_mouser(entry);
173 process_other(entry);
180 ParseArgs::argdesc argd = {
182 { .var = { .arg_flag = &mfg_part },
185 .desc = "Display manufacturer part number"},
186 { .var = { .arg_string = &vendor_list },
189 .expr_name = "vendors",
190 .desc = "Vendors to match"},
191 { .var = { .arg_string = ¬_vendor_list },
193 .name = "not-vendor",
194 .expr_name = "not-vendor",
195 .desc = "Vendors to exclude"},
201 ParseArgs::parseargs(&argd, &argv);
202 if (!is_uninit(&vendor_list))
203 vendors = String::parse_csv(vendor_list);
205 if (!is_uninit(¬_vendor_list))
206 not_vendors = String::parse_csv(not_vendor_list);
208 if (!is_uninit(&argi)) {
209 for (int i = argi; i < dim(argv); i++)
210 twixt(file f = File::open(argv[i], "r"); File::close(f))