2 # Copyright 2022 by Bdale Garbee <bdale@gag.com>. GPLv3
4 # Program to emit PCB footprint for GCT MEM2067-02-180-00-A micro SD connector
7 # dimensions in mm from gct/mem2067.pdf
31 # we're going to use the 1/100 of a mil fundamental unit form
33 return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
35 print('# author: Bdale Garbee')
36 print('# email: bdale@gag.com')
37 print('# dist-license: GPL 3')
38 print('# use-license: unlimited')
40 print('Element[0x0 "microSD" "" "" 0 0 0 0 0 100 0x0]')
45 mm2mils100(-MntX/2), \
46 mm2mils100(MntY1-(MntHeight/2)+(MntWidth/2)), \
47 mm2mils100(-MntX/2), \
48 mm2mils100(MntY1+(MntHeight/2)-(MntWidth/2)), \
49 mm2mils100(MntWidth), \
50 mm2mils100(Clearance), \
51 mm2mils100(MntWidth + MaskAdd), \
56 mm2mils100(MntY1-(MntHeight/2)+(MntWidth/2)), \
58 mm2mils100(MntY1+(MntHeight/2)-(MntWidth/2)), \
59 mm2mils100(MntWidth), \
60 mm2mils100(Clearance), \
61 mm2mils100(MntWidth + MaskAdd), \
65 mm2mils100(-MntX/2), \
66 mm2mils100(MntY2-(MntHeight/2)+(MntWidth/2)), \
67 mm2mils100(-MntX/2), \
68 mm2mils100(MntY2+(MntHeight/2)-(MntWidth/2)), \
69 mm2mils100(MntWidth), \
70 mm2mils100(Clearance), \
71 mm2mils100(MntWidth + MaskAdd), \
76 mm2mils100(MntY2-(MntHeight/2)+(MntWidth/2)), \
78 mm2mils100(MntY2+(MntHeight/2)-(MntWidth/2)), \
79 mm2mils100(MntWidth), \
80 mm2mils100(Clearance), \
81 mm2mils100(MntWidth + MaskAdd), \
85 for pin in range (1,9):
87 mm2mils100(-PinXOffset + (8-pin) * PinSpacing), \
88 mm2mils100(PinY-(PinHeight/2)+(PinWidth/2)), \
89 mm2mils100(-PinXOffset + (8-pin) * PinSpacing), \
90 mm2mils100(PinY+(PinHeight/2)-(PinWidth/2)), \
91 mm2mils100(PinWidth), \
92 mm2mils100(Clearance), \
93 mm2mils100(PinWidth + MaskAdd), \
94 '"pin%i"' % (pin), '"%i"' % (pin), '0x0100]')
97 print(' ElementLine[', \
100 mm2mils100(BoxX/2), \
104 print(' ElementLine[', \
105 mm2mils100(-BoxX/2), \
107 mm2mils100(-BoxX/2), \
111 print(' ElementLine[', \
112 mm2mils100(-BoxX/2), \
114 mm2mils100(+BoxX/2), \
118 print(' ElementLine[', \
119 mm2mils100(-BoxX/2), \
121 mm2mils100(+BoxX/2), \
125 print(' ElementArc[', \
127 mm2mils100(BoxY+(BoxX/2)-ArcOffset), \
128 mm2mils100(BoxX/2), \
129 mm2mils100(BoxX/2), \