Download Firefox -  a safer, easier to use web browser. Return to - Leap into the online experience! Return to - Leap into the online experience! - Leap into the online experience!

Project News :.

The latest project to launch was the site for Gorilla Offroad Company. Aside from their main site, a social media strategy was develop to launch the company into various industry specific automobile enthusist discussion board communities as well as popular social media fronts like Facebook, Pinterest, and Twitter.

Valid XHTML 1.0 Transitional

Valid CSS!

Section 508 Compliant

powered by: Macromedia ColdFusion MX

made with: Macromedia Dreamweaver MX

What is RSS

XML - often denotes RSS Feed information.

Macromedia - ColdFusion Programming
white horizontal rule

ColdFusion News :.

To bring a little life to my site, I've pulled a couple What is RSS Feeds into this page. You can currently choose between the technology related news stories from the following news sources:

You are currently viewing and RSS Feed from

Exceptions Are For Exceptional Circumstances Is Not A Value-Add Answer
Ben Nadel looks at when to use exceptions in your application and provides real, concrete advice from Scott Hanselman on exception management best practices....
(Fri, 31 Oct 2014 10:00:14 GMT)
[view article in new window]

Implementing ngRepeat Track-By Using A Directive In AngularJS 1.0.8
Ben Nadel looks at how to implement the AngularJS 1.2 ngRepeat "track by" feature in AngularJS 1.0.8 using a custom trackBy directive....
(Fri, 31 Oct 2014 10:00:14 GMT)
[view article in new window]

Brackets 1.0 RC1
Brackets 1.0 RC1 is available for download on GitHub. Get it!
(Fri, 31 Oct 2014 10:00:05 GMT)
[view article in new window]

TDD presentation
A coupla weeks back I was tasked with giving a presentation to the new PHP troops: an introduction to TDD. I'm not on the PHP team now, but they might need to be doing some TDD shortly, so I figured I'd at least expose them to the presentation slides if not actually take them through it. And I figured I might as well put it up for everyone to have a look at, in case it's of any use to anyone.

It's very bare bones, and I dunno how useful it'll be if I'm not there discussing each slide, but... oh well. It's here: "TDD".

If nothing else, it might solicit some questions from people, which will be a good thing.


(Fri, 31 Oct 2014 09:30:34 GMT)
[view article in new window]

Improving European education with collaborative applications

Educators and students throughout Europe benefit from the technological innovations that European Schoolnet builds using Adobe ColdFusion. The consortium of 31 education ministries develops programs and projects that benefit teachers, pupils, researchers, and industry partners who share the goal of improving the quality of education in Europe.

European Schoolnet serves more than 250,000 users and 25 different languages with projects like the eTwinning portal, a virtual meeting point for the exchange of information between schools. It provides all the tools and services schools need to find partners, resources, advice, help, and information, and even to build eTwinning projects in partnership with each other. To support its objectives, eTwinning needed to integrate smoothly with a wide range of third-party technologies, APIs, frameworks, and existing Oracle databases while still aligning with the organization's rapid development methodology.


"Development in Adobe ColdFusion is easily 40% faster than in other development environments. Significant time efficiencies are found in early development stages, faster coding, extensive code reusability, testing, and debugging," says Bart Vanhulle, technical manager and lead developer, European Schoolnet. "In addition, any conceptual, integration, and methodological challenges are readily addressed through the highly effective Adobe ColdFusion online developer community."

(Fri, 31 Oct 2014 02:00:07 GMT)
[view article in new window]

Just for Andy Allan
More times that you probably thought when you said that, I wager.

(Thu, 30 Oct 2014 18:29:51 GMT)
[view article in new window]

ColdFusion bug challenge: how quickly can one find a bug in ColdFusion 11?
Yesterday at lunchtime, I set myself a challenge: how quickly could I find a new, unreported bug in ColdFusion 11.

During my initial testing of ColdFusion 11 (when it was beta, and continuing through until I got sick of doing Adobe's testing for them), it was hardly even a sport finding bugs in ColdFusion 11. All one had to do was to look at it, and bugs would crawl out going "hi!". It really was that bloody simple. Their prerelease testing  and QA was a shambles for CF11. Until they release a substantial service pack for it, I do not believe it is fit for purpose. Unfortunately a substantial service pack will no-doubt bring a raft of bugs of its own, so I don't know when I'd actually consider it fit for purpose. Some people have gone live with it, that said. Good luck to them.

Anyway, I think the low-hanging fruit have been plucked, bug-wise, so figured it might be harder to find a new bug these days. Although I did kinda think the one hour I gave myself at lunchtime would still be OK.

I opened the "New in ColdFusion" page from the docs, and scanned down for quick things to test: I only had an hour after all.

I dismissed the entire "End-to-end mobile development" section, because - as Andy alluded to on Twitter yesterday:

This is something I whole-heartedly agree with. The whole concept counts as a planning / design / implementation bug, and we already know about it.

I also dismissed "A new lightweight edition", as looking for bugs in that is kinda devops shit, which I detest, so amn't interested.

I settled on the "Language Enhancements" section. This covers a lot, so thought there'd be some scraps around to find.

Scanning down the topics I figured the Elvis operator would be a candidate for a bug, because it's not entirely the most straight forward thing ever, so the ColdFusion Team would probably balls it up.

Indeed they have, but I've raised it already, dammit: "Null coalescing operator not quite implemented correctly". Predictably ColdFusion doesn't quite get how "nulls" work.

Another thing I guessed would be wrong is that ?: should be short-circuited, but it probably hasn't been implemented that way:

// nullcoalescingShortCircuit.cfm
function defaulter(){
writeOutput("defaulter() was called<br>");
return "default";

result = URL.param ?: defaulter();
writeOutput("Value of result: [#result#]<br>");

If I run this without URL.param set I get this:

defaulter() was called
Value of result: [default]

This is correct.

However if I call it and pass param=set on the URL, I get this:

defaulter() was called
Value of result: [set]

This is less than ideal, as the default option should only be called if necessary. This is a bug (FYI: Railo gets this right). However... it's already been raised: "Elvis operator executes RHS (right hand side) when it doesn't need to."

I moved on from the Elvis operator section. Next was queryExecute(), but I skipped that as I've already given it a bit of a test thrashing, and didn't expect to be able to find a new bug there within the 50min I had left.

JSON serialisation was after that, but I skipped that too as it takes some messing around to create test CFCs and serialisers and stuff. Plus I've looked at these too, so probably wouldn't be able to find anything new quickly enough.

I breezed through some of the member functions looking for things that were likely to be messed up, but nothing leapt out at me. I tried a few things but everything worked to spec. Inconvenient for my challenge, but good for ColdFusion.

I guessed that they'd probably mess up listEach(), so had a quick look there. Perhaps they'd mishandle empty list items or different delimiters (although I had a suspicion I'd already looked at this):

// listEach.cfm
oddNumbers = "tahi||toru||";

writeOutput(e & "<br>");
}, "|", true);

However this works just fine:




Actually at this point I skirted very close to finding a bug. In fact I identified one (by simply guessing it'd be buggy), but incorrectly "remembered" that I had already raised it. So I didn't check it. I'll come back to this.

I was about 20min into the hour now.

Next I figured queryGetRow() would probably not be able to cope with non-standard query columns, so I tried to break that:

// queryGetRow.cfm
json = '{"COLUMNS":["ID","COL with ## in name"],"DATA":[[1,"tahi"],[2,"rua"],[3,"toru"],[4,"wha"]]}';
records = deserializeJson(json, false);

row = queryGetRow(records, 1);

"Sadly" this worked fine:

COL with # in nameID
COL with # in nametahi

I also tested getting an invalid row, and queryGetRow() dealt with that OK too:

The row number 6 is out of bounds.

The error occurred in queryGetRow.cfm: line 7
5 : writeDump(records);
6 :
7 : row = queryGetRow(records, 6);
8 : writeDump(row);
9 : </cfscript>

Actually in playing around with some things now, I just found a tiny bug. Just the grammar in an error message:

Parameter validation error for the QUERYGETROW function.

The function takes 2 parameter.
The error occurred inC:/apps/adobe/ColdFusion/11/express/ColdFusion/cfusion/wwwroot/shared/github-scratch/blogExamples/datatypes/queries/queryGetRow.cfm: line 7
5 : writeDump(records);
6 :
7 : row = queryGetRow(records, 1, true);
8 : writeDump(row);
9 : </cfscript>

(It should be "parameters")

That's not interesting enough to worry about, although I guess I'll raise it anyhow (later).

I was at about the 30min mark now. Still no bug.

Hmmm.... I thought I'd tested built-in functions being first-class now, but I thought of something I might not have tested to try:

// passing.cfm
function stringTransformer(required string text, required function transformer){
return transformer(text);

string = "G'day World!";
handler = ucase;
transformed = stringtransformer(string, handler);

writeDump([string, transformed]);

I'd tested passing built-in functions as argument values, but wasn't too sure had I tested assigning them to variables first. But it works OK anyhow:

1G'day World!


Clicking around the "what's new" doc, and feeling pressure to come up with something, I spotted the "Security Enhancements (ColdFusion 11)" page, and figured this'd be easy. Adobe are crap at security (like in CFAdmin) so I'd find something.

I scrolled down and spotted the "Changes in Administrator API" subsection and reference to the "isAllowCuncurrentAdminLogin()" function. I was so hoping that spelling mistake had made it into the product I thought I had better check. This would not qualify as a reasonable enough bug to raise, but I figured I was running shy of time so probably wouldn't now find one anyhow.

First things first, I needed to be able to login to the thing. I always disable the need for a password on my CFAdmin because it's a waste of time on a dev machine (and, indeed, any well-configured prod machine), so I figured I'd need an account with a password to use on the API.

I went into CFAdmin, into the Security section, and user manager.
I added a user apiuser, and when trying to set it for "Allow Administrative Access", I got a pop-up thus:

Sigh, yeah, fair enough. So I dismissed that, also selected "API Access Only", then saved the user and moved back to the Administrator screen as suggested.

On this screen I selected "Separate user name [etc]..." and submitted the changes. And was confronted with this:

Dammit. Not being one to give up immediately, I just changed the radio button again and resubmitted:

It's getting worse! I tried another time and the message was the same.

So I sighed and wondered if it was getting confused because I had already created another user, or something, so went back to the "User Manager", and got this:

And no amount of reattempts to load that page worked. But that, to me, is a bug. Indeed it's twofold: a) simply using the UI should not... well.. break it; b) have you heard of error trapping, Adobe? Blimey. you shouldn't just let errors throw up on the screen: catch 'em and present something less amateur-looking than just a raw error message.

At this point I had been looking for 44min, and I'd found a bug. Job done.

I restarted CF and the error cleared itself, and I was then able to make my setting change, and off I went. And I hasten to add I could not replicate the issue again, on that machine. However I have just tried on a second machine, and got exactly the same thing. And on a third machine: same thing.

That was good enough for my mission, but I wanted to find a sort of code bug, so after the restart I was able to create an AdminAPI user so would be able to authenticate to the API and run some code:

// securityObjectBug.cfm
administrator = new CFIDE.adminapi.administrator();
administrator.login("12345678", "apiuser");
try {
writeOutput("isAdminUser() according to administrator object: ");
} catch (any e){
security = new CFIDE.adminapi.Security();
writeOutput("security object exists: " & structKeyExists(variables, "security") & "<br>");
writeOutput("isAdminUser() method in security object exists: " & structKeyExists(security, "isAdminUser") & "<br>");
writeOutput("isAdminUser() method in security object is a function: " & isCustomFunction(security.isAdminUser) & "<br>");
writeDump(var=getMetadata(security.isAdminUser), label="metadata for security.isAdminUser");

writeOutput("isAdminUser() according to security object: ");

I arrived at this code because I was trying to login then run some method (I can't remember which now), but it was erroring about security, so decided to verify that I was actually logged in and as a user authorised to call the method. This is as far as I got before I just threw my hands in the air saying "well, yeah, I knew it would not take long to find shittily-written CFML in the admin API, because "shittily-written" is the only sort of CFML the ColdFusion Team are capable of writing".

This is the output of that code, btw:

isAdminUser() according to administrator object: true
security object exists: YES
isAdminUser() method in security object exists: YES
isAdminUser() method in security object is a function: YES

metadata for security.isAdminUser - struct
HINTCheck to see if user is authenticated
metadata for security.isAdminUser - array
metadata for security.isAdminUser - struct
DEFAULT[empty string]
HINTList of required roles.
isAdminUser() according to security object:
The web site you are accessing has experienced an unexpected error.
Please contact the website administrator. 

The following information is meant for the website developer for debugging purposes.
Error Occurred While Processing Request

Variable SECURITY is undefined.

The error occurred in base.cfc: line 27
-1 : Unable to display error's location in a CFML template.

Note that this is not a reference to my code erroring. It's the code in the AdminAPI erroring. And naturally I cannot go and find out why, because Adobe precompile the AdminAPI files and don't ship the source. Groan.

So I was fed up with CF11 now, and - this was after about 1.5 hours - I'd found two bugs.

What about the bug I guessed was there at the 20min mark?

I guessed that even if listEach() handled the delimiters and empty elements properly, that it wouldn't be passing those arguments into the callback. Although it needs to, because whilst the callback gets passed the element, index and the whole list, the whole list is unusable unless you know the delimiters too. And whether to respect empty elements. Here's some code which demonstrates the difference between what listEach()'s and listMap()'s callbacks receive:

// listEach.cfm
oddNumbers = "tahi||toru";

}, "|", true);

}, "|", true);



1[empty string]


1[empty string]

Notice how listMap() correctly receives the delimiter and empty-elements setting? But listEach() does not. This is a bug in the implementation of listEach().

Unfortunately for my little challenge I misremembered raising this with Adobe already, but I only kind of had. I raised it for listMap(): "listMap() doesn't pass correct args to callback". I even wrote an article about it!! ("ColdFusion 11: .map() and .reduce()"). The annoying thing here is that bug entry only mentions listMap() and in-passing listReduce()... so listMap() and listReduce() are the only ones they addressed. The Adobe ColdFusion engineer addressing this didn't have the nous for it to occur to them that they also need to do the same thing for all the other list iteration functions. Either that, or they're just mind-boggling lazy and didn't bother. Neither would surprise me.

I didn't repro this until I was writing this article, so it can't really count for my bug-finding exercise. But combining the initial exercise of trying to find a bug, and the follow-up writing the article, I've found a total of four new bugs:
  • The broken behaviour in CFAdmin;
  • The broken behavious in the CFAdmin API;
  • The wee spelling mistake in that error message;
  • This fail in listEach().

The only one I care about here is the last one, TBH, but still.

I also think I found another bug in ColdFusion 9 today too. But I haven't got a repro for that yet, so cannot file it.

Bug-spotting in ColdFusion is way too easy.

(Thu, 30 Oct 2014 16:43:18 GMT)
[view article in new window]

Always Trigger The $destroy Event Before Removing Elements In AngularJS Directives
Ben Nadel demonstrates that you should always trigger the $destroy event before removing elements in AngularJS directives; otherwise, you can get unexpected behavior and memory leaks, especially when using jQuery plugins....
(Thu, 30 Oct 2014 10:00:18 GMT)
[view article in new window]

Finding ColdFusion installers, updaters, hotfixes, and docs for all recent releases
Many folks have been confused by the fact that they can seem to only find ColdFusion 11 installers on the Adobe site. There are a variety of reasons for that (not all as nefarious as some may feel).

Find CF installers, updaters, and docs for past several releases

The good news is that if one wants to find ANY installers for most ANY version of CF, they can be found on an external repository setup by Gavin Pickin (and added to by myself and others, to include updates, hotfixes, and docs): Gavin Pickin's ColdFusion Downloads / Install Repo If it helps, you can also access it using the easier to remember:

What happened to

(Thu, 30 Oct 2014 10:00:08 GMT)
[view article in new window]

If you're in the UK, can you please do me a quick favour?
Hey, if you're in the UK, can you please run some code for me and let me know what you get?

Here's the code:

<!--- lsDateFormat.cfm --->

It'll output something like:

English (UK)

Could you also please let me know what your regional/locale settings are at OS level, and whether or not you have any locale settings in your jvm.config (or whatever it is if you're not on Windows), eg:

java.args=-server -Xms1024m -Xmx1024m -XX:PermSize=256m -XX:MaxPermSize=256m -Duser.language=en -Duser.region=GB

The reason I ask is that we've recently seen some behavioural changes with locale, and trying to track down what caused it. I suspect it's that we've just upgraded from 9.0.1 to 9.0.2, but this doesn't seem to be entirely borne out by what we're seeing.

On our local dev machines despite the OS's locale/regional stuff being set to en_GB, CF is defaulting to en_US. Unless we force its hand by using those java.args settings, which we have not needed to do before.

I'd appreciate any feedback on this stuff you can give me! Cheers.

(Thu, 30 Oct 2014 07:25:53 GMT)
[view article in new window]

© The connection to the COLDFUSIONBLOGGERS's RSS feed has timed out - please try again later. We are sorry for any inconvenience this may have caused.