One language, one WebKit, to rule them all
Success and age are catching up with Appcelerator, which is re-writing its Titanium mobile development framework to be leaner and cheaper to run on more mobes.
The goal is for Appcelerator to stop devoting over half its annual $10m R&D budget on Titanium, a free product, while also supporting new mobes as they roll out.
Also, Appcelerator wants to clean up its code base, which has grown as new features and platform support has been added.
Founded in 2006 to build rich web and desktop apps, Appcelerator was one of the first to jump on the iPhone. The company today claims to have nearly half a million registered developers using its kit.
According to Haynie:
“A lot has changed in a short period of time. Not only is Android a major market share leader with Apple, but Microsoft now has a viable platform, RIM has a re-tooled Blackberry, Firefox has just released the first phones with Firefox OS, Samsung and Intel have collaborated to create Tizen and Ubuntu is doing something.”
Yes, he said Microsoft now has a “viable platform,” although he didn’t say which.
He continued: “We believe that we can cut the overall total costs of building and maintaining Titanium in ways that we couldn’t do in the current architecture. Today, each new platform is a linear-plus cost equation. Tomorrow, it will be fractional – in fact, each platform could drive down the overall cost to some degree.”
“That’s fast," Haynie said of the current performance, "but not too fast for modern CPUs. Our target is sub-microsecond operations – in fact, we think we can get faster in most cases than pure native code."
Also, for simplicity, there will be WebKit KJS VM for all platforms.
“We have found a way to make the WebKit KJS VM work on multiple platforms instead of using different VMs per platform,” Haynie said. Appcelerator have created a small microkernel that’ll have “minimal bootstrap code in the native language,” he said.
There was no date on when Ti.Next would be released. ®
Sponsored: Network DDoS protection