|
This is a multi-part message in MIME format... -- To: java400-l@midrange.com From: jamesl@hb.quik.com X-Advert: http://emumail.com Reply-To: jamesl@hb.quik.com Date: Mon, 16 Dec 2002 17:38:37 AST X-Mailer: EMUmail Subject: Re: Cycle vs. Non-Cycle RPG (vs. Java, C, et al.) It's been suggested that people are getting formal training in RPG that never mentions The Cycle. Coding in RPG without taking advantage of The Cycle sounds about as absurd as somebody writing Java programs that don't explicitly instantiate a single object. If you're not making at least SOME use of The Cycle, than why code in RPG at all? In fact, the only thing I can think of that seems more ludicrous than writing non-Cycle RPG programs is TEACHING people RPG without mentioning The Cycle. (For those unfamiliar with RPG, "The Cycle" is an implicit DO-UNTIL loop surrounding the main logic of every RPG program, controlled by a built-in Boolean variable called the LR ["Last Record"] Indicator. It has the additional capability of implicitly reading a record at the beginning of each iteration, and implicitly writing one at the end of each iteration). It's been argued that using The Cycle makes RPG programs less maintainable. That's (to again use a Java analogy) like saying that the use of objects makes a Java program less maintainable. The Cycle is as essential to RPG as objects are to Java, and if one's managed to overcome the non-trivial hurdle of learning RPG's bizarre syntax, understanding at least the basics of using The Cycle is simplicity itself. Of course, using Cycle output rather than explicit output (and, to a lesser extent, using Cycle input instead of explict input) can make things a bit tricky, but then again, just because your programs use The Cycle doesn't mean they have to use ALL of its features. As to RPG being an obsolete language, consider this: 1. The syntax is almost completely different from that of any other HLL, and is harder to read than most modern assemblers. It was suggested that Java would have been a failure if its syntax had been based on Object PL/I, but at least PL/I syntax is something any BASIC, FORTRAN, Pascal, COBOL, or C programmer can easily pick up. RPG, on the other hand, is syntactically so far from any other language that one must practically start from scratch. 2. Even if you're opening and closing files explicitly, there's no provision within the language (at least in traditional RPG) to open files whose names are not known at compile-time. I can't think of another language that doesn't allow you to wait until runtime to specify data file names. 3. Back in the heyday of RPG, trained programmers were a rare and expensive commodity, and canned software was practically nonexistent, while there were secretaries and mailroom-kids who could wire plugboards for unit record machines. That's why the S-3 and its successors were designed around RPG: its syntax was designed to be intuitive for the thousands of plugboard-jocks around the country. Now, plugboard-jocks are even rarer than RPG-only programmers, while kids are learning BASIC and Pascal in elementary school. In short, while I don't see much reason to use ALL the features of The Cycle in an RPG program, neither do I see much reason to use RPG in the first place if you're not making at least SOME use of The Cycle.
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.