|
I find this argument a little out of kilter. Many of the issues you are bringing up are not language-specific, especially in a multi-lingual environment like ILE. They are OS issues, and handled quite nicely in ILE (better than most other OS's, in fact). Exceptions can be signaled to any point in the stack (unlike the "bubble up one" of most exception-oriented languages). This is EXTREMELY powerful. You can easily hook the job end exit point and provide whatever finalization your job needs. While it's not handed to you on a silver platter, it's much nicer than, say, Java, where canceling the JVM aborts any finalization. With ILE, I can do an ENDJOB *IMMED, and my end-of-job routine STILL gets invoked. Destructors are only required for garbage-collected languages, and while garbage collection is a nice-to-have especially for OO languages, it's certainly not necessary. We got along just fine without them in C, and wrote some pretty bullet-proof code. It's a matter of registering cleanup code to be execute when the application ends, either normally or abnormally. Of course, with ILE much of the system-level cleanup (locks, ODPs, overrides) can be taken care of for you when you end the activation group, which is what was intended. There are many ways to skin a cat, and ILE RPG provides everything you need. Just not necessarily the way you're used to. Joe > From: Steve Richter > > what I dont see mentioned in these posts is that RPG does not have > features that are critical to writing bullet proof modular code. That > is, it does not have destructors, integrated exception handling, > struct member functions and base classes. > > A module has to be able to throw an exception when the inputs are not > what the module expects. And since a module is going to call other > modules which may throw exceptions, a module has to be able to define > destructor code which will run in the event of an unhandled exception. > That is, code which will shut the module down in an orderly fashion ( > close files, release mutex locks, free heap allocations ). > > -Steve
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.