Steve's been in business for 16 years providing industrial solutions using Tcl/Tk and Linux. Customers include Wonder Bread (breads and cakes), Thumanns (deli meat products), North East Foods (provide buns for McDonalds and Burger King).
Last years solution. Added features to the Oracle solution. Using bits from the Tcl'ers Wiki. Took 20 line proxy by Michael A. Cleverly and extended it with ~1,200 more lines of code.
The Oracle Dilemma:
Oracle wanted $800K more. Steve (jokingly) offered customer to re-write it for $800K and park himself there for the next four years :-D. Deli company needed a way to enter orders and then have them picked, shipped, and invoiced. Steve cranked out a prototype in 3.5 weeks.
Initial design (reinventing the wheel):
Went live on a Monday morning. Shut Oracle down the same day. Never looked back.
After a couple weeks of use found some limitations discovered: speed and concurrency. "No, really...speed & concurrency!" The simple database was doing a linear search. Started reading up on the Wiki about b-trees. Then it hit him: why do b-trees? DRH has already created sqlite.
Second design (Wheel 2.0):
"Users break everything"--logging comes in very handy to figure out what happened afterwards.
If you are available (to your customer) they'll come to you with more modifications, more things to do... great for him being self-employed.
What he has now:
Program code checks the file mtime of the .kit and if it sees it has changed it unmounts the VFS and remounts it and re-sources the application code, and voila, it's running the updated code, no end user downtime. The customer was floored (especially in comparison to Oracle upgrades).
"Why I am here":
Happy to share how he makes a living with Tcl.
Question from the chat: Do you do anything with RFID? Answer: no, barcodes. RFID makes it hard to identify a single individual piece of equipment.