The i-Technology Media!
Register | Log in
   
 
.NET  ·  AJAX  ·  CLOUD  ·  ECLIPSE  ·  FLEX  ·  OPEN WEB  ·  iPHONE  ·  JAVA  ·  LINUX  ·  OPEN SOURCE  ·  ORACLE  ·  PBDJ  ·  SEARCH  ·  SILVERLIGHT  ·  SOA  ·  VIRTUALIZATION  ·  WEB 2.0  ·  WIRELESS  ·  XML
Comments
Drool, Britannia? Is the UK Failing the Cloud?
By Roger Strukhoff
Richard Davies wrote: The UK has a good crop of technology pioneers in cloud computing - for example ElasticHosts, FlexiScale, Flexiant, OnApp - and also some strong government initiatives such as G-Cloud. We will have to see whether this kind of technical leadership converts into swift mass-market adoption or not.
Jan. 8, 2012 11:38 AM EST
read more & respond »
Cloud Expo on Google News
Did you read today's front page stories & breaking news?

Cloud Expo & Virtualization 2011 West
Keynotes
Oracle
Opening Keynote | An Enterprise Cloud for Business-Critical Applications
Abiquo
Day 2 Keynote | The Enterprise Cloud Tightrope - Balancing for Success
Akamai
Day 3 Keynote | The DNA of an Enterprise Cloud
DIAMOND SPONSOR:
Oracle
Many Clouds, Many Choices'Cloud
PLATINUM PLUS SPONSORS:
Abiquo
Enterprise Cloud Best Practices - Town Hall - Join the discussion…
PLATINUM SPONSORS:
Intel
Progressing Toward the Federated, Automated and Client-Aware Cloud
New Relic
How to build an app with Twitter-like throughput
Rackspace
Computing in the Cloud Era
GOLD SPONSORS:
Gale Technologies
Practical Cloud Migration
IBM
Re-think IT. Re-inventing Business.
Intel/McAfee
Identity Driven Security in the Cloud
PerspecSys
Hackers Hackers Everywhere, Is My Public Cloud That Safe?
Red Hat
Unlock the Value of the Cloud
SHI
Mission Critical Applications and the Cloud - Myth or Reality?
SoftLayer
Not Your Grandpa's Cloud
Terremark
Integrating Enterprise Clouds
VMware
Upgrade to a vCloud
POWER PANELS:
Cloud Expo Silicon Valley: CTO Power Panel
Cloud Expo Silicon Valley: CEO Power Panel
Cloud Expo Silicon Valley: Cloud SuperStars Panel
Cloud Expo Silicon Valley: CloudNOW Panel
Click For 2010 West
Event Webcasts
Cloud Expo & Virtualization 2011 East
DIAMOND SPONSOR:
Dell
Dell & VMware Deliver the Enterprise Hybrid Cloud
PLATINUM PLUS SPONSORS:
Abiquo
Are Financial Services Organizations Risking Security by Avoiding Cloud Computing?
Oracle
From Consolidation to Enterprise Private PaaS
PLATINUM SPONSORS:
Intel
Driving the Transformation to Next Generation Cloud Data Centers
Rackspace
The Inevitability of an Open Cloud
GOLD SPONSORS:
CA Technologies
Follow YOUR path to Cloud Computing
Interxion
Who Keeps the Cloud in the Air?
Microsoft
Patterns for Cloud Computing
PerspecSys
War in the Clouds: Are you ready?
ServiceMesh
The Big Win: Stop Playing Small-Ball with Your Cloud Strategy
Terremark
Evaluating Enterprise Clouds
Xiotech
Cloud Storage: Myths and Realities
POWER PANELS:
Cloud Expo New York: CTO Power Panel
Cloud Expo New York: CEO Power Panel
Cloud Expo New York: CMO Power Panel
Cloud Expo New York: Wrap-Up Power Panel
Click For 2010 West
Event Webcasts
Live Google News by SYS-CON!
Top Three Links You Must Click On


Fusebox
Fusebox Perspectives:
Assessing the Importance of the Fusebox Development Methodology

By: Hal Helms
Sep. 18, 2003 12:00 AM

Recently, someone e-mailed CF Advisor's Fusebox Columnist, Hal Helms, posing the question, "Why is Fusebox important?" At the recent Allaire Developer's Conference in Boston, Hal addressed that question when he spoke before 300 people at a special interest group session. And he also shares the answer here.

Why is Fusebox important? To help answer that question, let's explore the similarities between the state of software development in 2000 and the state of rifle making exactly two centuries ago in 1800. What are the noticeable qualities both share?

  • Skilled craftspeople are needed to create the product.
  • Each product is a unique work of its creator.
  • There is a shortage of skilled workers.
  • There is a wide variation in the quality of finished goods.
  • Maintenance of our products requires the user to go back to the creator or to employ the skills of a highly-paid master craftsperson.
  • There is very limited division of labor.
  • There is little efficiency of scale: it takes 10 times as long to produce 10 products as one.

Two centuries ago, the emerging government of the United States needed rifles. But rifle making was a slow process requiring highly trained craftsmen. Into that situation stepped an American genius named Eli Whitney. Whitney had already produced the cotton gin when he proposed to the government that it contract him to produce ten thousand rifles at a cost of $13.40 each, to be delivered in two years. The idea was so preposterous that only his reputation as "the man who can make anything" won him the contract.

Of course, Whitney went on to revolutionize rifle making--and in general the methods of production--by the simple idea that the component parts of an object should be so clearly specified (by means of a template) that a worker could be trained on creating that part only; it would not require a master worker at each step of production. Though he was late delivering the product (for which I nominate him as patron saint of programmers), his method was so clearly superior that he won another contract for fifteen thousand rifles. With his system perfected, he delivered these in under two years.

Whitney's method solved the "rifle crisis", transforming rifle making from a craft to an industry. By creating a method that made use of workers at all skill levels (rather than relying on individual masters of their craft), Whitney created an archetype for production. The lesson was not lost on the young nation.

And what of our own "software crisis"? We live in a time where the ability to quickly produce quality software may be the crucial factor in a business' long-term success. And in software, as with most things, quality is defined by the ultimate user of the product. As developers, we work very hard to achieve that. ColdFusion's success traces how much speed and simplicity matter. Yet, we still lack a methodology that helps us work together to tackle a problem. Programming is still very much a solitary art. While there is an important part for the lone coder, large-scale problems are often best solved by a team approach.

"The Fusebox architecture encourages the creation of many fuses--small code files, each greatly limited in scope and having a distinct purpose."

The Fusebox architecture encourages the creation of many fuses--small code files, each greatly limited in scope and having a distinct purpose. This means that the coder who works on a particular file doesn't have to know the overall application architecture--or even know of the existence of other fuses. Different fuses can be parsed out to different programmers with different skills; we don't require a few master programmers to handle all ingredients of the job. We're getting very close here to Whitney's mass production techniques.

Some developers are not comfortable with this idea. Not too long ago, I spoke with the owner of a large ColdFusion development shop and asked him what methodology they were using. He laughed, "We've got a great methodology--and as soon as I figure out what it is, I'm going to write it down!" Yet not having a methodology is to have a methodology--though I suspect it is one that few of us would choose if we were aware of our decision.

Then there is the reaction of a good friend of mine who, after hearing me talk on Fusebox and apparently inspired by the movie "Blazing Saddles", declared "We don't need no stinkin' fuses!" Many programmers feel secure working in an area where their hard work and skill have made them essential. Well, the good news is that job security isn't likely to be an issue for a long, long time. In fact, working in a system that produces on-time, high quality code is likely to enhance our fortunes even more. And do you really want to have to recreate the same code over and over--or notch one more user input form on your programming belt? Maybe having some help in these areas wouldn't be so threatening after all.

Fusebox can also help us in is dealing with documentation. We've been preached at--warned of the dangers of neglecting the dreaded "D" word since we wrote our first "Hello world!" program. But no one has told us how to document code. It tilts from the trivial ("Loop over all the users") to the tedious ("This next bit of code will ask the user for their name and password. The user will enter..."). In both cases, the documentation gets in our way more than it helps and informs us.

Fusedoc is a method for writing just the right amount and the right type of comments in our code. An experienced Fusebox architect can decompose an application into its component fuses and then, using the Fusedoc method, s/he adds the the information the fuse coder needs to carry out their job. The fuse coder receives a "fuse stub", a page template with the Fusedoc portion filled in. Fuse stubs minimize misunderstanding and confusion.

Using a fuse documentor (available at www.teamallaire.com/hal), you can run code that will automatically extract fuse information from an entire directory of fuses. Being able to quickly understand what code files are up to is extremely helpful in integrating code, and may help us begin to create reusable components. The fuse documentor is an example of inventing tools to help us create a complete development system--just as Eli Whitney invented the milling machine to make his system of standardized components work. As more of us adopt Fusebox, I believe we will see many more such tools created that will help us all.

Why is Fusebox important? By offering a method that allows each of us, at whatever skill level we are, to contribute to making high quality software, Fusebox provides a way that applications can be built in an environment where development cycles are short, complexity high, and resources limited. By breaking down a complex application into small, discrete chunks that do not depend on other pieces, companies can use less experienced programmers to handle the 80% of development that doesn't require highly specialized skills. If software development is to move from the state that rifle making was in two centuries ago, we will need to learn from Whitney's experience.

Published Sep. 18, 2003— Reads 7,437
Copyright © 2003 SYS-CON Media, Inc. — All Rights Reserved.
Syndicated stories and blog feeds, all rights reserved by the author.
About Hal Helms
Hal Helms is a well-known speaker/writer/strategist on software development issues. He holds training sessions on Java, ColdFusion, and software development processes. He authors a popular monthly newsletter series. For more information, contact him at hal (at) halhelms.com or see his website, www.halhelms.com.

Add Your Feedback

In order to post a comment you need to be registered and logged in.

Register | Sign-in

Reader Feedback: Page 1 of 1

Subscribe to the World's Most Powerful Newsletters
Subscribe to Our Rss Feeds & Get Your SYS-CON News Live!
Click to Add our RSS Feeds to the Service of Your Choice:
Google Reader or Homepage Add to My Yahoo! Subscribe with Bloglines Subscribe in NewsGator Online
myFeedster Add to My AOL Subscribe in Rojo Add 'Hugg' to Newsburst from CNET News.com Kinja Digest View Additional SYS-CON Feeds
Publish Your Article! Please send it to editorial(at)sys-con.com!

Advertise on this site! Contact advertising(at)sys-con.com! 201 802-3021

SYS-CON Featured Whitepapers

ADS BY GOOGLE

Breaking Java News
Bird River Resources: Update on Last Five Wells Completed & Production
Tetra Tech to Present at the Baird Business Solutions Conference
BC Advantage Funds Announces Robert W. Rieder as a New Director
Trilantic Capital Partners to Invest in Nixon Inc.
Saving Money on Fuel Is a Priority According to Research by Mobil 1
Faruqi & Faruqi, LLP is Investigating Masco Corporation on Behalf of its Shareholders
Faruqi & Faruqi, LLP Announces Investigation of Hyperdynamics Corporation
NASDAQ Lifts Pending Delisting Notification for PremierWest Bancorp
Matthew Key, Head, Telefónica Digital; Caroline Thomson, COO, BBC; Graeme Oxby, Managing Director, Virgin; Andrew Harrison, CEO, Best Buy Europe; Byun Jae-Woan, CTO, SK Telecom; David Lister, CIO, National Grid; Ed Richards, Chief Executive, Ofcom to Spea
100% of Roman Catholic Bishops Have Now Publicly Denounced HHS Mandate

ADVERTISE   |   MAGAZINE SUBSCRIPTIONS   |   FREE BREAKING-NEWSLETTERS!   |   SYS-CON.TV   |   BLOG-N-PLAY!   |   WEBCAST   |   EDUCATION   |   RESEARCH

.NET Developer's Journal - .NETDJ   |   ColdFusion Developer's Journal - CFDJ   |   Eclipse Developer's Journal - EDJ   |   Enterprise Open Source Magazine - EOS
Open Web Developer's Journal - OPENWEB   |   iPhone Developer's Journal - iPHONE   |   Virtualization - Virtualization   |   Java Developer's Journal - JDJ   |   Linux.SYS-CON.com
PowerBuilder Developer's Journal - PBDJ   |   SEO / SEM Journal - SJ   |   SOAWorld Magazine - SOAWM   |   IT Solutions Guide - ITSG   |   Symbian Developer's Journal - SDJ
WebLogic Developer's Journal - WLDJ   |   WebSphere Journal - WJ   |   Wireless Business & Technology - WBT   |   XML-Journal - XMLJ   |   Internet Video - iTV
Flex Developer's Journal - Flex   |   AJAXWorld Magazine - AWM   |   Silverlight Developer's Journal - SLDJ   |   PHP.SYS-CON.com   |   Web 2.0 Journal - WEB2
Apache   |   CMS   |   CRM   |   HP   |   Oracle Journal   |   Perl   |   Python   |   Red Hat   |   Ruby on Rails   |   SAP   |   SaaS

SYS-CON MEDIA:   ABOUT US   |   CONTACT US   |   COMPANY NEWS   |   CAREERS   |   SITE MAP
SYS-CON EVENTS:   |  AJAXWorld Conference & Expo  |  iPhone Developer Summit  |  Cloud Computing Conference & Expo  |  SOA World Conference & Expo  |  Virtualization Conference & Expo
INTERNATIONAL SITES:   India  |  U.K.  |  Canada  |  Germany  |  France  |  Australia  |  Italy  |  Spain  |  Netherlands  |  Brazil  |  Belgium
 Terms of Use & Our Privacy Statement     About Newsfeeds / Video Feeds
Copyright ©1994-2008 SYS-CON Publications, Inc. All Rights Reserved. All marks are trademarks of SYS-CON Media.
Reproduction in whole or in part in any form or medium without express written permission of SYS-CON Publications, Inc. is prohibited.
 
close this window