|
Charlie Massoglia wrote: > The 1 DOWEQ 1 construct is not really the logic of the loop. The logic of > the loop is really continue the loop until you press F3 or F12 to exit. True. The reasons behind my technique isn't a more perfect loop, rather it is to keep related functions near to each other and clarity of intent. This is a very simple example, but after adding 4 or 5 other command keys, and maybe some other program specific logic, this subroutine gets more complex, it becomes more confusing. The point is that, without paging forward or back several screens to check what exactly the do loop was conditioned on, I check a single specific condition and I leave (get out) or iter (go back) or continue. My style is to break things down into as small and as simple tasks as possible an stack them one after another, rather than muck up the works with a lot of complicated compound conditional statements. > Instead of using *INKC and *INKL we normally define an INFDS and check the > AID byte. I've liked and wanted to use the aid byte for years, but for whatever reason (laziness probably) I've just never done it. - but even if I did, I would have still coded *ink, in the example to keep from having to explain them for the benefit of those who dont use it. > C SELEC > > C $$FKEY WHEQ ##F03 (If F3 or F12 is > C $$FKEY OREQ ##F12 pressed, set loop exit) > C MOVE 'Y' #EXIT1 > > C $$FKEY WHEQ ##F04 > C EXSR @@INQ1 (prompt/lookup inquiry calls) > > C OTHER > C EXSR @@EDT1 (input field editing) > > C $ERROR IFNE 'Y' > C EXSR @@UPD1 (file update) > C EXSR @@INZ1 > C ENDIF > > (Again, $ERROR IFEQ 'N' could also be used.) > > C ENDSL > > C ENDDO > > C ENDSR I've done it this way in the past, but changed to my way because I never have to worry about initializing or flipping the value of a variable - in my way, leave/iter/continue are my only choices. as for using the select stuctures, I sometimes find that when the logic gets more complicated, I might have to split the groups into two with some common code in the middle or something to that effect. I've done it both ways, but I've gravitated to using simple IFXX statements with the leave or iter, because when I duplicate the program, it always works with little changes. But this is just my own habits. I do wonder though, why the heavy use of special charactors? I usually use a single @ for any passed parms (in or out), and a single $ for any program defined variables, but other than that, I think it makes the program hard on the eyes. - same with subroutines - I like using the F1DISP/F1INZ/F1EDIT/F1UPDT or S1DISP/S1INZ/S1LOAD/ S1READ/S1EDIT/S1UPDT for subfile processing. > and an ENDDO several pages later, we always reverse the subroutine name to > form the ENDSR tag. An @@xxxx ALWAYS represents a subroutine BEGSR and a > xxxx@@ ALWAYS represents the end of the subroutine. Yes, the GOTO drives > structured purists wild but an exit to the end of a routine is structured > code and we ALWAYS code this the same way in every program. This is the > only time we use a GOTO and will do so until we get a LEAVE type op code to > exit a subroutine. > I anxiously await (look forward to?) the condemnations for using a GOTO. Be > nice - remember no flames! I won't go there. I wish they had a leavesr opcode too, but I still hate gotos. thanks for the critique, always nice to see how the other half lives. regards, rick * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * This is the Midrange System Mailing List! To submit a new message, * * send your mail to "MIDRANGE-L@midrange.com". To unsubscribe from * * this list send email to MAJORDOMO@midrange.com and specify * * 'unsubscribe MIDRANGE-L' in the body of your message. Questions * * should be directed to the list owner / operator: david@midrange.com * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
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.