<indexxmlns:doc="uri:doc">3</index>
<indexxmlns:doc="uri:doc">6</index>
<indexxmlns:doc="uri:doc">1</index>
<indexxmlns:doc="uri:doc">7</index>
<answerquestion="What’s a Distinguished Engineer">
<para>
It just means I’ve been doing this for a while ☺️
</para>
</answer>
<answerquestion="Why is your LinkedIn ID “xmlguy”">
<para>
I was doing XML in the very early days, even before it came to be used in web services.
In 1997 I was working on a few shareware Windows applications, and wanted them to exchange data.
I started out with a text format based on Microsoft’s Regedit text format (similar to YAML), but
it had limitations. Then I found XML, but I couldn't find any parsers, so I wrote my own.
About a year later I was interviewing at Dell, and they wanted to use XML to re-do the Dell Europe
website. I was the first person they’d talked to that had even heard of XML.
</para>
<para>
I ended up writing a scripting language called XSP where the scripts themselves were written in XML.
We then used that to support Dell.com in Europe in 22 countries. XSP had an interesting content inheritance
model that let you manage a large number of countries but only localizing what you wanted to. This was
very popular with the business, and in 1999 we rolled it out to support the website globally in 85 countries.
</para>
<para>
I have an updated version of that script engine
<ahref="https://github.com/ssaxon/xsp">on my GitHub</a>
.
And in the spirit of “eating your own dogfood”, this site was built with that engine. The original
engine did quite a bit more, but this version is orders of magnitude faster (this page executed in
<time/>
) ...
The benefit of 25 years advancement in technology (and my ability, I guess).
</para> <para>
Proof:
<aonclick="showRaw()">this is the unstyled output of the page script</a>
</para> <para>
More proof:
<aonclick="showTrace()">this is the execution trace</a>
.
</para> <para>
Also, did you notice what happens when you refresh the page? Just in case you didn’t think there was
a script running the page 😉
</para>
<para>
One fun thing about XSP ... In late 1998 I showed what I was working on to some folks at Microsoft, as I was
encountering a lot of stress bugs in MSXML.DLL (the parser/XSL processor I was using at that time). They were
giving each other furtive glances, and one said “is this
<i>that</i>
XSP?”. “No, he made his own!”. It turned
out there was effort inside Microsoft to create their own XSP to replace Classic ASP, where they were basically
adding XSL constructs to Classic ASP. We got connected, and I showed the XSP team what I was working on. I don’t
know exactly what happened next, but about a month later they scrapped what they were doing, and ASP.NET was born.
</para> <para>
There were quite a few similarities — the idea of creating an intermediate hierarchy of nodes, then rendering it.
In XSP that was an intermediate XML document, and in ASP.NET 1.0 it was the Control hierarchy. XSP also created a
hierarchical trace so you could see what it was doing, and where, and ASP.NET 1.0 had basically the same thing.
</para>
<para>
One thing ASP.NET 1.0 didn’t do was borrow XSP’s functional override mechanism. In XSP script support inheritance,
so when you are building up a webpage, you can override a base method to change the content in a section on a page.
This enables the base page to act like an overridable template. There was no easy way to do this in ASP.NET 1.0, but
ASP.NET 2.0 introduced Master Pages that let you achieve the same thing. Of course, XSP had been doing that for 7
years by then!
</para>
</answer>
<answerquestion="Cake or Death">
<para>Ooohh... What kind of cake is it?</para>
</answer>
<answerquestion="What programming languages do you use">
<para>
In my day job I’m mostly using using
<ahref="https://kotlinlang.org">Kotlin</a>
, and some Java.
I would say Kotlin is my favorite language of any I’ve used a lot — I’m impressed that they were able to
make a language that was expressive enough to make you highly productive, while still making it highly
readable and fun to write.
</para> <para>
Prior to that it was a mix of C#, Java, and TypeScript, but I’ve also done Python and straight javascript
along the way. I went back to C# to re-create XSP, and after using Kotlin I find C# really clunky. I think
it’t all the semicolons, but also the lambda syntax in C#.
</para>
</answer>
<answerquestion="What else have you worked on">
<para>
Prior to Intuit I was working at
<b>Microsoft</b>
, where I was Chief Architect for Real-Time Communications,
which is basically all the back-end chat and VoIP video and voice calling that powers Teams, and Skype.
I also created something called
<ahref="https://azure.microsoft.com/en-us/products/communication-services">Azure Communication Services</a>
,
which lets you add those same features in your own applications.
</para> <para>
Before Microsoft I was working on Alexa at
<b>Amazon</b>
, where I led the creation of
<ahref="https://developer.amazon.com/en-US/alexa/alexa-haus/alexa-presentation-language">Alexa Presentation Language</a>
,
which enables skill developers to create visuals that will show up on Alexa visual devices such as Echo Show and
Alexa-enabled TVs.
</para> <para>
I worked on Dell.com for 7 years during the Dot Com boom and bust, and led the site through 3 global site redesigns.
The initial version for Europe was built with a scripting language I created that supported script inheritance — still
a fairly unique thing. There is an updated version of that language processor on my
<ahref="https://github.com/ssaxon/xsp">GitHub</a>
I then went on to port the content publishing and rendering platform to ASP.NET with a framework internally called Storm,
which was used on Dell.com for the next 14 years.
</para> <para>
During the 1990s I led the creation of Renault’s showroom system, where you could pick your options and set the price
update in real time. Of course now every car website has this, but this was revolutionary in 1992 before the Internet.
It also let you do side-by-side finance comparisons so you could play with your options. Finally it used part of the screen
to show you the margin the deal, so even though the customer was looking at the screen with you, the sales rep would always
know how much wiggle room they had to offer discounts.
</para>
<para>
I included some videos below of things I’ve worked on.
</para>
</answer>
<answerquestion="Do you speak other languages">
<para>
I do ... but I’m a bit rusty. I used to be fluent in Spanish (Castilian aka. Standard Spanish), and
conversational in Japanese. But along the way I’ve learned French, Welsh, Italian, Portugese, plus
some Cantonese and Mandarin (which I can understand better than I can speak).
</para>
<para>
I’m currently doing Spanish and Japanese in Duolingo, then I’m moving on to Mandarin to improve that,
and adding Hindi. I’ve found I can learn two languages at a time as long as they’re not similar. That
was a mistake I made before when I was learning Spanish, Portugese, and Italian at the same time, and
found I was getting the vocabulary all mixed up in my head.
</para>
<para>
As a computer guy, I’ve always been fascinated with the syntax and etymology of spoken languages, and
how they provide a window into the mindset of different cultures. I find Japanese particularly
interesting in this regard — the whole language works like LEGOs, and they have verb conjugation that
would require extra words in English. For example a verb like
<i>okiru</i>
(起きる — to wake up), but if
you conjugate with
<i>-nikui</i>
(にくい — “hard to
<i>do something</i>
”), you get
<i>okinikui</i>
(起きにくい — “(it is)
hard to wake up”. Such an interesting language. Japanese also adapts words for “sound convenience” (to
make words easier to say), which is also a big thing in Welsh. I’m such a nerd.
</para> </answer>
<answerquestion="What kind of music do you listen to">
<para>
My Spotify is all over the place, from Death Metal (Opeth, Lamb of God), to 80s/90s J-Pop
(Yuming, Imai Maki, Anri, Speed, Chemistry), and more recently to Taylor Swift, and classic jazz.
</para>
<para>
I was into hardcode rap (e.g. DMX, Ruff Ryders), but when Office Space came out, I realized I was
the Michael Bolton character, and I pivoted.
</para>
</answer>
<answerquestion="What is your defining quality as a software engineer">
<para>
I am a builder — I always have been. I find a problem, and I don’t rest until I have an elegant
solution. Elegant can take many forms, but for me it often means creating frameworks that make it
easy to do something that was previously hard. Often times that takes the form of creating domain-specific
languages that make it easy to get results without writing a ton of code.
</para>
<para>
When I was at Amazon, they use their Leadership Principles to define what they think your “superpowers” are,
and for me it was Think Big. A lot of times I’m living a year in the future, thinking about problems the team
doesn’t even know it has yet, which gives me time to help them avoid pitfalls. But it also means I have to
spend time explaining things that don’t always seem obvious to the rest of the team.
</para>
<para>
I also used to tell people that my personal motto was “if you see me running, try and keep up!”, but over time
I’ve come to understand there’s no point running if you’re not following me. Maybe I’ve mellowed!
</para>
</answer>
<answerquestion="Where do you live">
<para>
I live in Southern California now, out near Palm Springs, but I am originally from the UK. I was
actually born in West London, very close to where Ted Lasso is set. I’ve also spent quite a few years
in North Wales (in the UK), Texas, Arizona, and Washington (State), so my accent is wonky.
</para>
</answer>