New developments in software are fair comment

Daily Newsletters

Sign up to ZDNet UK's daily newsletter.

Having to maintain software with few if any comments is hard enough when it's a few thousand lines of fairly straightforward code -- I've been there, and I've religiously overcommented my own software ever since. But with large programming projects now easily generating hundreds of thousands of lines, pulled together from many teams and including previous software, the problem can become overwhelming. Even when code is adequately commented in the beginning, changes made subsequently to the software are rarely reflected in the documentation.

MDA should be self-documenting. The idea is that to make an application, you build a model of what it should do according to business rules, and includes the kind of data that'll be handled. Many programming projects start like this with models on paper: the programmers then turn the paper ideas into working code. MDA has a different approach: the model is described in the Unified Modelling Language (UML) that can be automatically converted to runnable code. This happens by stages, so that multiple different programs for different platforms can be generated from a single platform independent intermediate model.

Because most of the development work happens in the model, changes to the application will happen there -- and the MDA development tool will then generate a modified program. Programmers will at all times be working on the latest, most accurate source of the design ideas behind the program, rather than the program itself: not only will this be much quicker, MDA's proponents say, but much less prone to error.

Can it work? Although MDA is conceptually finished, there are still gaps in the standard and much discussion going on, especially in the trickiest bits: how do you turn a conceptual model into real code without going through the head of a programmer? And then, how do you test what you've done and verify that it works? These are the details that can take a good idea and damn it to irrelevancy. In the past, 4GL languages, computer-aided software engineering (CASE) and many other loudly trumpeted breakthroughs in programming have either lost relevance or been scaled down because their promise on paper failed to translate into a workable system that programmers found more useful than infuriating.

There's no doubt that, at some point, programming will become a matter of designing a model and waving a magic wand. Whether that time is now -- and whether the efficiency of the MDA process consistently matches or equals the old ways -- can only be answered over time. Case studies are good -- suggesting 35 to 50 percent productivity increase with no loss of code quality -- and products like CompuWare's OptimalJ enterprise application development environment are provoking much interest. This could be the last time that programmers can ever answer questions about their code with "no comment".

Talkback

Sounds nice. But.....

But it's messing with rice-bowls: There are legions of coders who know how to make code do things, but who either can't think or aren't interested in thinking in models.

But it's messing with aesthetics: A good chunk of the people who got into this game did so because of the love of seeing behind the curtain. This kind of approach turns the curtain into a solid steel door with a biometric lock.

But it's limiting to innovation: Once you turn the curtain into a locked door, you set specific standards for innovation, and thus decrease its rate. Visionary individuals will be prevented from deploying solutions because they don't fit into the modeling framework.

I've no doubt that modeling-driven approaches will become central to software development. But if they expect to make decent progress, it's advocates will have to address to these cultural and pragmatic issues, lest the inevitable failures cause it to be damned as yet another wave of hype.

via Facebook 21 August, 2003 14:50
Reply

Ask any coder a simple question ?

Have most of the projects that you have worked on been ..... ?

A) A brand new system

B) An upgrade or add-on to an existing system

Yep, you've guest it! The answer would be 'B' in most cases.

Why oh why, has the software industry never really caught on to this fact ? Programs are almost never these days written from scratch! This is why .Net and Java do not rule to the roost.

UML is fine, but what if an system was never written using UML in the first place. Have you ever tried reverse-engineering an system into UML ??? I have just done just that! and it's taken 6 months on a medium sized enterprise app.

The only way I can see the coding industry speed up is to help us easily move the past foward into the future.

Till then, I'm going to carry on, carrying around my 15 year old copy of "Code Complete"

via Facebook 27 August, 2003 17:56
Reply

Post your comment

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

You can also log in with Facebook. Log in or create your ZDNet UK account below

  • Login

Will not be displayed with your comment

By signing up for this service, you indicate that you agree to our Terms and Conditions and have read and understood our Privacy Policy. Questions about membership? Find the answers in the Community FAQ

Get ZDNet UK's daily newsletter

Enter your email address to sign up

ZDNet UK Live

UnderINK

I agree with the previous commenter wholeheartedly. I couldn't say it better myself. This is very 'Big Brother'. And while I agree with protecting...

2 hours ago by UnderINK on European e-identity plan to be unveiled this month
Simon Bisson and Mary Branscombe

Nice to see that Turing's idea of a general purpose computer doing once-hardware-powered tasks in software is now universal ;-) Mary

8 hours ago by Simon Bisson and Mary Branscombe on Software with everything
Jason Burchell

seriously now. I've only bothered to read a small bit of the comments. do me and the rest of the world a favour. stop saying it does not work or...

12 hours ago by Jason Burchell via Facebook on Music industry negotiating over 24-bit downloads
Philip Charles Cohen

Read about it and weep, John Donahoe ... In addition to Visa’s V.me, there is now MasterCard’s PayPass digital wallet soon to arrive; another...

16 hours ago by Philip Charles Cohen via Facebook on PayPal takes phone-based payments to the high street
apexwm

Leslie Satenstein : Where have you ever seen Mozilla even mention this? Firefox is the most popular browser in the GNU/Linux OS, so I don't see...

16 hours ago by apexwm on Firefox rapid release improves Fedora Linux
songmaster

SHleG: Do you remember building a clockwork scorpion kit (I'm pretty sure I have a photo of it somewhere) — I think it was called something like...

18 hours ago by songmaster on Software with everything
Chris Wortman

Good I love Yahoo! Their search engine is getting better than Google as of late. I find more of what I want on the first page, and usually within...

19 hours ago by Chris Wortman via Facebook on Linux Mint 13 ramps up for KDE release
PatrickG

openhgs has made the point for Windows 8 multiple monitors without realising it! With Windows 7 you have to switch the mouse and so your focus...

20 hours ago by PatrickG on Windows 8 could speed multi-monitor uptake
Leslie Satenstein

Mozilla has threatened to stop supporting Linux. I guess that UBUNTU is going with another browser. I indicated that if Mozilla stops supporting...

22 hours ago by Leslie Satenstein via Facebook on Firefox rapid release improves Fedora Linux
Andy Bolstridge

Much as I abhor Microsoft's licensing practices, this is almost certainly down to purchasing IT equipment via 3rd party consultants - you get the...

22 hours ago by Andy Bolstridge via Facebook on 6 million wasted licences and £1,200 PCs: welcome to government IT
Jack Schofield

@openhgs Windows users have had multiple desktops since Linus started writing Linux. They just haven't shipped as standard because not enough...

2 days ago by Jack Schofield on Windows 8 could speed multi-monitor uptake
Jack Schofield

@Phil at Cloud4 What, Microsoft gets £1,200 per PC and £1,622 per server? Gosh, I'm amazed....

2 days ago by Jack Schofield on 6 million wasted licences and £1,200 PCs: welcome to government IT
craigsc

You guys have no idea what is going on at Autonomy. Autonomy could have been a much more profitable organization. The sales operations at Autonomy...

2 days ago by craigsc on HP cuts 27,000 staff as Autonomy chief Lynch leaves
Moley

How does this impact on dual or multi booting? Seems to me to more or less prohibit this, from Windows 8 anyway. Will Grub 2 recognise Windows 8,...

2 days ago by Moley on Windows 8 start-up speed forces USB boot workaround
apexwm

I don't understand why there cannot be a slight pause during the boot process so the user can press a key. Many operating systems do this, even if...

2 days ago by apexwm on Windows 8 start-up speed forces USB boot workaround
Gavin Goodman

You can now buy the Xi3 modular computer in the UK at http://www.ocdistribution.com . This can be bought with the Tand3m software, pricing and...

2 days ago by Gavin Goodman on CES 2012: Xi3 microSERV3R
Phil at Cloud4

I agree: Mike Lynch can clearly build a business and manage strategy. I suspect the exit of Mike is more likely the end of a planned handover...

2 days ago by Phil at Cloud4 on HP cuts 27,000 staff as Autonomy chief Lynch leaves
Phil at Cloud4

This is unbeleivable government wastage with only one winner... Microsoft 1 - Tax payer Nil!

2 days ago by Phil at Cloud4 on 6 million wasted licences and £1,200 PCs: welcome to government IT
Mispam

So what do you do when you can't boot into windows? Why can't I just hold Shift while I power up instead of having to boot into windows and click a...

2 days ago by Mispam on Windows 8 start-up speed forces USB boot workaround
apexwm

I've also seen that Mac OS X for Intel machines is supposed to run in VirtualBox, which would also be a nice solution. I've never tried it though.

2 days ago by apexwm on xTreme Triple Booting: Linux, Mac & Windows