--- /dev/null
+#!/usr/bin/python3
+# Copyright 2021 by Bdale Garbee <bdale@gag.com>. GPLv3
+#
+# Program to emit PCB footprint for Luna CDS Photoconductive Photocell
+#
+
+import math
+
+# dimensions in mm from PDV-P8103.pdf Luna Optoelectronics datasheet
+BodyDiam = 5.08
+HoleDiam = 0.5 # pins are 0.4mm, make hole large enough
+HoleSpacing = 3.40
+FlatSpacing = 4.29
+
+FlatHalfLength = math.sqrt((BodyDiam / 2)**2 - (FlatSpacing / 2)**2)
+ArcStart = 180 * math.atan((FlatSpacing/2)/FlatHalfLength)/math.pi
+
+# we're going to use the 1/100 of a mil fundamental unit form
+def mm2mils100( mm ):
+ return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
+
+print('# author: Bdale Garbee')
+print('# email: bdale@gag.com')
+print('# dist-license: GPL 3')
+print('# use-license: unlimited')
+
+print('Element[0x0 "PDV-P8103" "" "" 0 0 0 0 0 100 0x0]')
+print("(")
+print(' Pin[',\
+ mm2mils100(-HoleSpacing/2), \
+ 0, \
+ mm2mils100(2.5*HoleDiam), \
+ mm2mils100(0.5), \
+ mm2mils100(3*HoleDiam), \
+ mm2mils100(HoleDiam), \
+ '"pin1" "1" 0x0001]')
+
+print(' Pin[',\
+ mm2mils100(HoleSpacing/2), \
+ 0, \
+ mm2mils100(2.5*HoleDiam), \
+ mm2mils100(0.5), \
+ mm2mils100(3*HoleDiam), \
+ mm2mils100(HoleDiam), \
+ '"pin2" "2" 0x0001]')
+
+print(' ElementArc[',\
+ 0, \
+ 0, \
+ mm2mils100(BodyDiam/2), \
+ mm2mils100(BodyDiam/2), \
+ ArcStart, \
+ -2 * ArcStart, \
+ 1000, \
+ ']')
+
+print(' ElementArc[',\
+ 0, \
+ 0, \
+ mm2mils100(BodyDiam/2), \
+ mm2mils100(BodyDiam/2), \
+ ArcStart + 180, \
+ -2 * ArcStart, \
+ 1000, \
+ ']')
+
+print(' ElementLine[',\
+ mm2mils100(-FlatHalfLength), \
+ mm2mils100(-FlatSpacing/2), \
+ mm2mils100(FlatHalfLength), \
+ mm2mils100(-FlatSpacing/2), \
+ 1000, \
+ ']')
+
+print(' ElementLine[',\
+ mm2mils100(-FlatHalfLength), \
+ mm2mils100(FlatSpacing/2), \
+ mm2mils100(FlatHalfLength), \
+ mm2mils100(FlatSpacing/2), \
+ 1000, \
+ ']')
+
+print(")")