There’s been much rubbing of magic lamps and wishing of wishes over what features we should throw into ColdFusion 8 aka Scorpio. Sean has the roundup of comments from Simon Horwith, Brian Kotek and Brandon Harper. Which will be granted? Only Damon can tell… ;-) Loudmouth that I am, I can’t help but add my own 2 paisa to the debate.
CFML is a simple language. Joe/Jane developer can get up and running building a CF application in a fraction of the time it would take with practically any other technology. At heart, CFML is a language rooted in tags. There’s no need to digest half a dozen reference books to dive into CFML - you can just pick the tags you need and go from there.
Adding new language features to parallel those available elsewhere (Java, Ruby, whatever) does not detract from this power - it adds to it. Your applications can be as simple or as complex as you want them to be. But even when they’re complex, the complexity can be isolated at a layer of abstraction above the actual business logic, because the business logic is still largely composed of simple, powerful tags. The key, of course, is to ensure that the features we add do not mess with CFML’s essential simplicity; if there’s one thing the CF team is paranoid about, this would be it.
But addition of any new feature is tempered by the time we have available to release, and the number of other features in queue. Prioritisation is a hard task, especially when we have you, our vociferous users, to answer to. Some features will make it, and others won’t - you know how the game is played. So you’ll see some new features that will enrich the CF language, allowing more object oriented behaviour and what-not. And you’ll soon see others like CFPRESENTATION and CFPDFFORM, which Jason showed off at CFUNITED, that will continue in the CF tradition of making hard things easy.
Some have asked whether CF should ship a framework to help define how to build applications. I would have to disagree. Each framework brings its own architectural philosophy to the table, and each is valid in its own space. Today we have frameworks that are great for building web applications. But what about frameworks for applications with Flex front ends? What if someone were to build a framework to enable CF as a data integration hub, using all the rich network interfaces that are available? Each of these will have their own specific requirements - no framework is sufficiently generic to address all needs.
CF goes far enough to make things easy, but at the same time stops short of defining how you should build your applications. That little detail, we leave to you…

Mike Kelp | 25-Jul-06 at 4:12 pm | Permalink
I really feel you are right on the mark with that last line. CF treads a perfect line between flexibility, power, and simplicity. These don’t have to be mutually exclusive, but it does make feature decisions harder.
Thanks for sharing your comments and all of your hard work on CF.
Mike.
Sean Corfield | 26-Jul-06 at 4:23 am | Permalink
Nicely said Ashwin!
As for frameworks, yes, it would be an impossible choice to make. Should CFMX ship with something suitable for procedural programmers (e.g., Fusebox 5) or something suitable for OO programmers (e.g., Model-Glue: Unity) or something suitable for Flex back ends (e.g., Tartan) or…? And how then would updates to the frameworks be handled?
As someone who is heavily involved in the frameworks community, I would not want to see Adobe endorse any specific framework (our Web Team uses Mach II, cfcUnit and Tartan; our Hosted Services team uses Model-Glue: Unity, cfcUnit, ColdSpring and Reactor; one of our Senior Computer Scientists built Fusebox 5 so we’re spreading the love right now - and that’s how it should be!).
Teddy R Payne | 27-Jul-06 at 3:29 pm | Permalink
I think the ability to create a framework for procedural, OO or RIA in a singular language is impressive in itself. ColdFusion gives the power to the developer to create a development process solidly using tools that work impressively well together. Developers can make it simple, complicated or a mixture of both; they have the “choice.”
With every version, the word “limitation” is slowly removed from my CF dictionary.