convert Python footprint generators to Python 3
[hw/altusmetrum] / packages / microSDold.py
1 #!/usr/bin/python3
2 # Copyright 2011 by Bdale Garbee <bdale@gag.com>.  GPLv2
3 #
4 # Program to emit PCB footprint(for Amphenol micro SD connector
5 #
6
7 # dimensions in mm from 101-00303-xx.pdf
8 PinWidth = 0.60
9 PinHeight = 1.05
10 PinSpacing = 1.10
11 PinY = 9.47
12 PinXOffset = 4.53
13
14 MntWidth = 1.05
15 MntHeight = 1.50
16 MntY1 = 3.60
17 MntY2 = 12.00
18 MntX = 13.60
19
20 BoxX = 13.60
21 BoxY = 13.30
22 LineWidth = 1000
23
24 MaskAdd = 0.15
25
26 import sys
27
28 # we're going to use the 1/100 of a mil fundamental unit form
29 def mm2mils100( mm ):
30         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
31
32 print('# author: Bdale Garbee')
33 print('# email: bdale@gag.com')
34 print('# dist-license: GPL 3')
35 print('# use-license: unlimited')
36
37 print('Element[0x0 "microSD" "" "" 0 0 0 0 0 100 0x0]')
38 print("(")
39
40 # mounting pads
41 print('   Pad[',\
42         mm2mils100(-MntX/2), \
43         mm2mils100(MntY1-(MntHeight/2)+(MntWidth/2)), \
44         mm2mils100(-MntX/2), \
45         mm2mils100(MntY1+(MntHeight/2)-(MntWidth/2)), \
46         mm2mils100(MntWidth), \
47         mm2mils100(0), \
48         mm2mils100(MntWidth + MaskAdd), \
49         '"9" "9" 0x0100]')
50
51 print('   Pad[',\
52         mm2mils100(MntX/2), \
53         mm2mils100(MntY1-(MntHeight/2)+(MntWidth/2)), \
54         mm2mils100(MntX/2), \
55         mm2mils100(MntY1+(MntHeight/2)-(MntWidth/2)), \
56         mm2mils100(MntWidth), \
57         mm2mils100(0), \
58         mm2mils100(MntWidth + MaskAdd), \
59         '"9" "9" 0x0100]')
60
61 print('   Pad[',\
62         mm2mils100(-MntX/2), \
63         mm2mils100(MntY2-(MntHeight/2)+(MntWidth/2)), \
64         mm2mils100(-MntX/2), \
65         mm2mils100(MntY2+(MntHeight/2)-(MntWidth/2)), \
66         mm2mils100(MntWidth), \
67         mm2mils100(0), \
68         mm2mils100(MntWidth + MaskAdd), \
69         '"9" "9" 0x0100]')
70
71 print('   Pad[',\
72         mm2mils100(MntX/2), \
73         mm2mils100(MntY2-(MntHeight/2)+(MntWidth/2)), \
74         mm2mils100(MntX/2), \
75         mm2mils100(MntY2+(MntHeight/2)-(MntWidth/2)), \
76         mm2mils100(MntWidth), \
77         mm2mils100(0), \
78         mm2mils100(MntWidth + MaskAdd), \
79         '"9" "9" 0x0100]')
80
81 # signal pads
82 for pin in range (1,9):
83     print('   Pad[',\
84         mm2mils100(-PinXOffset + (8-pin) * PinSpacing), \
85         mm2mils100(PinY-(PinHeight/2)+(PinWidth/2)), \
86         mm2mils100(-PinXOffset + (8-pin) * PinSpacing), \
87         mm2mils100(PinY+(PinHeight/2)-(PinWidth/2)), \
88         mm2mils100(PinWidth), \
89         mm2mils100(0), \
90         mm2mils100(PinWidth + MaskAdd), \
91         '"pin%i"' % (pin), '"%i"' % (pin), '0x0100]')
92
93 # silkscreen box
94 print('   ElementLine[', \
95         mm2mils100(BoxX/2), \
96         mm2mils100(0), \
97         mm2mils100(BoxX/2), \
98         mm2mils100(BoxY), \
99         LineWidth, ']')
100
101 print('   ElementLine[', \
102         mm2mils100(-BoxX/2), \
103         mm2mils100(0), \
104         mm2mils100(-BoxX/2), \
105         mm2mils100(BoxY), \
106         LineWidth, ']')
107
108 print('   ElementLine[', \
109         mm2mils100(-BoxX/2), \
110         mm2mils100(0), \
111         mm2mils100(+BoxX/2), \
112         mm2mils100(0), \
113         LineWidth, ']')
114
115 print('   ElementLine[', \
116         mm2mils100(-BoxX/2), \
117         mm2mils100(BoxY), \
118         mm2mils100(+BoxX/2), \
119         mm2mils100(BoxY), \
120         LineWidth, ']')
121
122
123 print(")")