PROJECT=telelco
# intentionally want to rebuild drc and bom on every invocation
-all: drc partslist partslist.csv pcb
+all: drc pcb partslist partslist.csv partslist.dk
drc: $(PROJECT).sch Makefile
-gnetlist -g drc2 $(PROJECT).sch -o $(PROJECT).drc
partslist: $(PROJECT).sch Makefile
gnetlist -g bom -o $(PROJECT)-bom.unsorted $(PROJECT).sch
- head -n1 $(PROJECT)-bom.unsorted > partslist
- tail -n+2 $(PROJECT)-bom.unsorted | sort >> partslist
+ (head -n1 $(PROJECT)-bom.unsorted && tail -n+2 $(PROJECT)-bom.unsorted | sort) | nickle ./retab >> partslist
rm -f $(PROJECT)-bom.unsorted
-partslist.csv: $(PROJECT).sch Makefile
- gnetlist -l gnet-partslist-keithp.scm -g partslist-keithp -o $@ $(PROJECT).sch
+partslist.csv: $(PROJECT).sch Makefile gnet-partslist-keithp.scm
+ gnetlist -l gnet-partslist-keithp.scm -g partslist-keithp -o $(PROJECT)-list.unsorted $(PROJECT).sch
+ nickle ./retab < $(PROJECT)-list.unsorted > $@
+
+partslist.dk: $(PROJECT).sch Makefile gnet-partslist-bom.scm
+ gnetlist -m ./gnet-partslist-bom.scm -g partslist-bom -Ovendor=digikey -o $@ $(PROJECT).sch
pcb: $(PROJECT).sch project Makefile
gsch2pcb project
--- /dev/null
+; Copyright © 2012 Keith Packard <keithp@keithp.com>
+; gnet-partslist-bom.scm
+;
+; 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.
+;
+; This program is distributed in the hope that it will be useful,
+; but WITHOUT ANY WARRANTY; without even the implied warranty of
+; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+; GNU General Public License for more details.
+;
+; You should have received a copy of the GNU General Public License
+; along with this program; if not, write to the Free Software
+; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+
+; The /'s may not work on win32
+(load (string-append gedadata "/scheme/gnet-partslist-common.scm"))
+
+(define (caddddddr s)
+ (car (cdr (cdr (cdr (cdr (cdr (cdr s))))))))
+
+(define (cadddddr s)
+ (car (cdr (cdr (cdr (cdr (cdr s)))))))
+
+(define (caddddr s)
+ (car (cdr (cdr (cdr (cdr s))))))
+
+(define multiplier 1)
+
+(define (partslist-bom:write-part s port)
+ (let ((quantity (caddddddr s))
+ (part (cadddddr s))
+ (device (cadr s))
+ (value (caddr s)))
+ (display (* multiplier quantity) port)
+ (display ", " port)
+ (display part port)
+ (display ", " port)
+ (display device port)
+ (display " " port)
+ (display value port)
+ (display "\n" port)))
+
+(define (partslist-bom:write-partslist ls port)
+ (if (null? ls)
+ '()
+ (begin (partslist-bom:write-part (car ls) port)
+ (partslist-bom:write-partslist (cdr ls) port))))
+
+(define (count-same-parts ls)
+ (if (null? ls)
+ (append ls)
+ (let* ((parts-table-no-uref (let ((result '()))
+ (for-each (lambda (l) (set! result (cons (cdr l) result))) (reverse ls))
+ (append result)))
+ (first-ls (car parts-table-no-uref))
+ (match-length (length (member first-ls (reverse parts-table-no-uref))))
+ (rest-ls (list-tail ls match-length))
+ (match-ls (list-tail (reverse ls) (- (length ls) match-length)))
+ (uref-ls (let ((result '()))
+ (for-each (lambda (l) (set! result (cons (car l) result))) match-ls)
+ (append result))))
+ (cons (cons uref-ls (append first-ls (list match-length))) (count-same-parts rest-ls)))))
+
+(define get-vendor
+ (lambda (package)
+ (gnetlist:get-package-attribute package "vendor")))
+
+(define get-vendor-part-number
+ (lambda (package)
+ (gnetlist:get-package-attribute package "vendor_part_number")))
+
+(define get-footprint
+ (lambda (package)
+ (gnetlist:get-package-attribute package "footprint")))
+
+(define (get-parts-table-bom packages vendor)
+ (if (null? packages)
+ '()
+ (let ((package (car packages)))
+ (if (string=? (get-vendor package) vendor)
+ (if (string=? (get-device package) "include")
+ (get-parts-table-bom (cdr packages) vendor)
+ (cons (list package
+ (get-device package)
+ (get-value package)
+ (get-footprint package)
+ (get-vendor package)
+ (get-vendor-part-number package)) ;; sdb change
+ (get-parts-table-bom (cdr packages) vendor)))
+ (get-parts-table-bom (cdr packages) vendor)))))
+
+
+(define (get-vendor-match)
+ (let ((vendor-param (calling-flag? "vendor" (gnetlist:get-calling-flags))))
+ (if vendor-param
+ (cdr vendor-param)
+ "digikey")))
+
+(define (partslist-bom output-filename)
+ (let ((port (open-output-file output-filename))
+ (parts-table (marge-sort-with-multikey (get-parts-table-bom packages (get-vendor-match)) '(1 2 3 0))))
+ (set! parts-table (count-same-parts parts-table))
+ (partslist-bom:write-partslist parts-table port)
+ (close-output-port port)))
--- /dev/null
+#!/usr/bin/nickle
+
+string[*][*] lines;
+int[*] widths;
+
+string[*] get_one(file in) {
+ string l = File::fgets(in);
+ return String::wordsplit(l, "\t");
+}
+
+string[*][*] get_all(file in) {
+ string[...][*] l = {};
+ while (!File::end(in))
+ l[dim(l)] = get_one(in);
+ return l;
+}
+
+int[*] find_widths(string[*][*] lines) {
+ int[...] w = {};
+ for (int r = 0; r < dim(lines); r++) {
+ for (int c = 0; c < dim(lines[r]); c++) {
+ int len = String::length(lines[r][c]);
+ if (c >= dim(w))
+ w[c] = len;
+ else
+ w[c] = max(w[c], len);
+ }
+ }
+ return w;
+}
+
+void print_one(string s, int w) {
+ int l = String::length(s);
+ printf ("%s ", s);
+ while (l < w) {
+ putchar(' ');
+ l++;
+ }
+}
+
+void print_line(string[*] line) {
+ for (int c = 0; c < dim(line); c++)
+ print_one(line[c], widths[c]);
+ putchar('\n');
+}
+
+void print_all() {
+ for (int r = 0; r < dim(lines); r++)
+ print_line(lines[r]);
+}
+
+void doit () {
+ lines = get_all(stdin);
+ widths = find_widths(lines);
+ print_all();
+}
+
+doit();