× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



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 thread ...

Follow-Ups:
Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

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.