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



A hearty Bravo! One of the most important points I got out of this article, and 
it should be, was the discussion about programming skills. Back in the 
trenches, roll out is key, key. Keeping up a high effort level, that's a whole 
other program, especially on a Monday!
Rob
> -----Original Message-----
> From: Reeve [mailto:news@xxxxxxxxxx]
> Sent: Monday, February 16, 2004, 8:24 PM
> To: 'RPG programming on the AS400 / iSeries' <rpg400-l@xxxxxxxxxxxx>
> Subject: NOTO (or "no GOTO in FreeForm RPG"): The Empire Strikes Back
> 
> <snip>
> 
> Huh?  Understanding a SELECT group is not intuitive?!!  This is hardly
> complex stuff here.  If a SELECT group is too difficult for you, you have no
> business being a programmer.
> 
> </snip>
> 
>  
> 
> Huh?  Shoulda worn Nomex today...I'm sure the "you" in "you have no business
> being a programmer" was the editorial "you"!  And what should we say to
> those correspondents making the weekly requests about coloring source code?
> I can't decide if this is vigorous discussion or youthful impatience.
> 
>   
> 
> My customers (many of the most prestigious names in the industry) have
> purchased over 200,000,000 lines of iSeries ERP code I've written myself
> (that number includes quite a bit of reused code, /COPY, etc.).  This is
> about business: my customers appreciate the functionality, style,
> consistency, and stability in my application.  In context (interactive
> programs), my use of GOTO fits a very specific requirement, and I believe
> the customers changing on my code long after I've left the premises
> appreciate its unambiguous style (maintenance programmers are not known for
> having a long attention span).  Business is what I have, and TCO is the
> primary reason organizations buy my application from me (a one-man company)
> and an iSeries to run it.  I stopped writing magazine articles (that you're
> paid for once, usually) in 1980 so I could concentrate on writing code I
> can, and have, sold and installed dozens of times.
> 
>  
> 
> When I was in training for IBM, my final systems project was perfect with
> one exception: the instructor said this System/3 OCL wouldn't work:
> 
>  
> 
> // file name-master1,label-master  ..as a direct file
> 
> // file name-master2,label-master  ..as an indexed file
> 
>  
> 
> I neglected to mention to the instructor that this technique was in
> production at several CCP accounts.  Sales training, you know...John Milton,
> if you're out there...stand corrected and sit down!  (I've wanted to get
> that off my chest for a long time).  How much of what your instructor told
> you have you rejected in the last 15 years?  Plenty, I hope.
> 
>  
> 
> I have had customers (all very nice people) who will look high and low for a
> paper RPG manual to figure out SELECT, and they'll try to figure out what
> that little "c" does in the middle of those I-just-don't-get-them "D"
> specifications.  And when they can't find a source member in QRPGSRC, it's
> because I've deleted it (or at least that's what their voicemails say), and
> then there's a certain amount of angst when the QRPGLESRC member pops up in
> mixed case, with expressions, on their 80-column green screen.  No, I'm not
> referring to you, RPK!
> 
>  
> 
> The reason the iSeries hasn't enjoyed the wild success of other platforms
> isn't because of the use of GOTO's; it's because IBM's midrange offerings
> were later to market than most other players to the GUI/browser environment
> and offered (present tense, too) no integration to common business
> applications available and popular today (Linux doesn't meet both conditions
> yet).  Modern programming constructs are required to support a more
> sophisticated UI, but iSeries purchase decisions are frequently based on
> applications and not on the availability of qualified data structures, etc.
> API's haven't been around forever, gentle reader, and we're much better off
> for having them available.
> 
>  
> 
> Programmers are limited by what IBM provides, and IMHO IBM won the battle
> but lost the war by enhancing the S/36 instead of pricing the AS/400 right,
> developing an effective conversion tool, and dumping the 36 altogether (I've
> stayed 36-free for a career).  In the history of IBM's midrange family (my
> history goes back 29 years), RPG has made real advances not in the last 29
> years but mainly with the advent of the iSeries, and I salute George,
> Barbara, Hans, et al. for their contributions (I can't say it in Python). 
> 
>  
> 
> I don't think I'm tilting at windmills here.  I believe the proper use of
> GOTO reduces deep, complex, error-prone levels of nesting and eliminates the
> requirement for switches, flags, and other non-structural techniques. 
> 
>  
> 
> I see many emotional arguments ("best practice", "Programming 101", "dying
> out") against GOTO.  "Best practice" doesn't mean "only practice" or "right
> way", of course, and I wonder how many other "best practices" go into the
> dust bin.  I suggest the real problem in programming training is that it
> usually teaches coding techniques and a programming language, not
> programming skills.  And I offer the possibility that the problems created
> by GOTO mishmashes can be trumped by the problems arising from the use of
> more complex (not "more elegant") coding structures to control program flow
> (application logic is a distinctly different case), all in the interest of
> worshipping the False Prophet Of Noto.  Programming errors are a fact of
> programming life; the key is minimizing them, and then making them easy to
> identify and fix for the Unknown Programmer In The Future.
> 
>  
> 
> Let's see what Google says about programming "best practices": 
> 
> www-106.ibm.com/developerworks/eserver/articles/hook_duttaC.html?ca=dgr-nxw0
> 2BestC
> 
>  
> 
> First on the list: "Use a source code style that makes the code readable and
> consistent."
> 
> Way, WAY down on the list (around #25): "GOTO should be used sparingly"
> 
>  
> 
> Dijkstra, Rubin, and McConnell have comments regarding GOTO; they're worth
> reading.
> 
>  
> 
> Back in the Dark Ages (apparently when I learned to code), program
> readability was important.  One of the big considerations was keeping a
> meaningful hunk of code on a single page, so excessive page-turning by the
> programmer was eliminated.  Now, we have WDSCi and can flip CRT pages, but I
> have to believe that trying to determine a program's function by flipping
> around, even assuming the programmer is hip enough to use WDSCi's outline,
> is not good.  Obviously I have to brush up on my "best practices"; I'm
> hoping to see "write it so the next programmer will understand it" somewhere
> on the first page.  And then we have the concept of a proper program, with
> one entry point and one exit point (golly, if I don't understand SELECT, how
> can I know this?); depending upon how far you decompose your code, this
> construct could be hard to design properly...or should we design our systems
> to be like PARS?
> 
>  
> 
> The flap over GOTO's is a canard: the real problem is what's NOT used by, or
> understood by, far too many programmers: prototyped calls, procedures,
> embedded SQL, stored procedures, activation groups, BIF's, expressions,
> WDSCi, that funny QC2LE binding directory, basic debit-and-credit
> accounting, and industry knowledge.  All of those features coexist very
> nicely with GOTO!  Besides, it's not the GOTO's, it's those pesky,
> poorly-positioned TAG's that cause the problems.
> 
>  
> 
> There's a lot of ease-of-use and functionality built into my example
> (below), and a careful examination of the GOTO's will show no occurrence of
> the GOTO "deadly embrace"...I hope...
> 
>  
> 
> Tag1:
> 
> Tag2:
> 
> Goto tag1
> 
> Goto tag2   
> 
>  
> 
> ...which is, I believe, the major problem with most uses of GOTO.  An
> extremely useful syntax check could have been a warning of deadly embrace
> GOTO's; I'm highly confident such a feature will be absent from the next
> "Vote for your enhancements" survey from the RPG team.
> 
>  
> 
> Interesting...I just noticed only one TAG per main (non-HELP) panel.  Do I
> get any points for having a high GOTO/TAG ratio?
> 
>  
> 
> Refactoring pieces is easy; it's doing the whole thing that's nasty.  Nomex
> on...
> 
>  
> 
> Tag1:
> 
>             Display format
> 
>                         Display file error
> 
>                                     Do something to recover and to redisplay
> the format
> 
>             If cmd1
> 
>                         Display help
> 
>                                     Do something to recover and to redisplay
> the format
> 
>                         If not valid-command-key goto tag1
> 
>  
> 
> ***These lines are a group
> 
>             When cmd2
> 
>                         Inquiry1
> 
>                         Goto tag1
> 
>             When cmd3
> 
>                         Exit
> 
>             When cmd7
> 
>                         Inquiry2
> 
>                         Goto tag1
> 
>             When cmd12
> 
>                         Goto tag1
> 
>  
> 
>             Application code
> 
>                         When error
> 
>                                     Goto     tag1
> 
>  
> 
> Tag2:
> 
>             Display format
> 
>                         Display file error
> 
>                                     Do something to recover and to redisplay
> the format
> 
>             If cmd1
> 
>                         Display help
> 
>                                     Do something to recover and to redisplay
> the format
> 
>                         If not valid-command-key goto tag2
> 
>  
> 
> ***These lines are a group
> 
>             When cmd2
> 
>                         Inquiry1
> 
>                         Goto tag2
> 
>             When cmd3
> 
>                         Exit
> 
>             When cmd5
> 
>                         Inquiry3
> 
>             When cmd7
> 
>                         Inquiry2
> 
>                         Goto tag2
> 
>             When cmd12
> 
>                         Goto tag1
> 
>  
> 
>             Application code
> 
>                         When error
> 
>                                     Goto tag2
> 
>  
> 
> ...and so on...
> 
>  
> 
> Considerations:
> 
> The HELP panel is not required to use command keys, which is why it's coded
> outside the implicit SELECT.  The command keys are accessible from the main
> panel or from the help panel.
> 
>  
> 
> There are multiple panels in every application
> 
>  
> 
> Each panel has a combination of standard and unique command key options.
> 
>  
> 
> There may be a shortcut on the main panel to jump directly to other panels.
> 
>  
> 
> This is a refactoring exercise; no alteration or reduction of user function
> is allowed.  If there is a better path, I will take it.  But "better" is an
> emotional response too!
> 
>  
> 
> --------------------------
> 
> I've failed to mention the self-documenting nature of the GOTO/TAG
> construct, possibly because I've failed to take advantage of that useful
> feature myself.  I'm paying too much attention to style; all my tags are
> named TAGnnn.
> 
>  
> 
> At this point, I have to GOTO the sandbox and then GOTO dinner.  Or is it
> DOU *FULL and DOW NOT *HUNGRY?
> 
>  
> 
> -Reeve
> 
>  
> 
>  
> 
> _______________________________________________
> This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list
> To post a message email: RPG400-L@xxxxxxxxxxxx
> To subscribe, unsubscribe, or change list options,
> visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
> or email: RPG400-L-request@xxxxxxxxxxxx
> Before posting, please take a moment to review the archives
> at http://archive.midrange.com/rpg400-l.
> 

As an Amazon Associate we earn from qualifying purchases.

This thread ...


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.