convert Python footprint generators to Python 3
[hw/altusmetrum] / packages / TSOT26.py
1 #!/usr/bin/python3
2 # Copyright 2022 by Bdale Garbee <bdale@gag.com>.  GPLv3
3 #
4 # Program to emit PCB footprint for TSOT26 package used by AP62150
5 #
6
7 # dimensions in mm from diodes-inc/AP62150.pdf
8
9 PinWidth = 0.7
10 PinHeight = 1.0
11 PinSpacing = 0.95
12 RowOuters = 3.2
13 RowSpacing = RowOuters - (2 * PinHeight)
14
15 import sys
16
17 # we're going to use the 1/100 of a mil fundamental unit form
18 def mm2mils100( mm ):
19         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
20
21 print ('# author: Bdale Garbee')
22 print ('# email: bdale@gag.com')
23 print ('# dist-license: GPL 3')
24 print ('# use-license: unlimited')
25
26 print ('Element[0x0 "TSOT26" "" "" 0 0 -10161 -12011 0 100 0x0]')
27 print ("(")
28 for pin in range (0,3):
29     print ('   Pad[',\
30         mm2mils100((pin-1) * PinSpacing), \
31         mm2mils100(-(RowSpacing/2 + PinWidth/2)), \
32         mm2mils100((pin-1) * PinSpacing), \
33         mm2mils100(-(RowSpacing/2 + PinHeight - PinWidth/2)), \
34         mm2mils100(PinWidth), \
35         mm2mils100(PinSpacing - PinWidth), \
36         mm2mils100(PinWidth)+600, \
37         '"pin%i"' % (6 - pin), '"%i"' % (6 - pin), '0x0100]')
38
39     print ('   Pad[',\
40         mm2mils100((pin-1) * PinSpacing), \
41         mm2mils100(RowSpacing/2 + PinWidth/2), \
42         mm2mils100((pin-1) * PinSpacing), \
43         mm2mils100(RowSpacing/2 + PinHeight - PinWidth/2), \
44         mm2mils100(PinWidth), \
45         mm2mils100(PinSpacing - PinWidth), \
46         mm2mils100(PinWidth)+600, \
47         '"pin%i"' % (1 + pin), '"%i"' % (1 + pin), '0x0100]')
48
49 print ('   ElementArc[',\
50         mm2mils100(-1.5 * PinSpacing), \
51         mm2mils100(RowSpacing/2+PinHeight*1.25), \
52         '500 500 0 360 1000 ]')
53
54 print (")")