|
True, the error monitoring is better, but I try to catch errors other ways. For example, If I am to create a file in QTEMP, I issue the command (either CRTDUPOBJ or CRTPF), then open(E) the file. If there is an error, I would rather deal with it that way, than monitoring the CL command. Hmmm... maybe I should be using the API to dup an object.... On 9/2/05, rob@xxxxxxxxx <rob@xxxxxxxxx> wrote: > > I used to be a big system() fan. Then I went back to QCMDEXC. The psds > returns information from QCMDEXC that is not available in the errorcode > returned by system(). For example, let's say there was a mythical message > "USR0154-Object in use by &1". With the psds and QCMDEXC you could get > the value for &1. Now, for true message thoroughness nothing beats > QCAPCMD. The psds can only return so many characters of message data. No > such limitation with QCAPCMD. I find that most times that QCMDEXC is > "good enough" and is easier to code. (I know, I know a good wrapper... > but then you get into activation group levels, etc.) > > And the people who say using a CL is easier because of MONMSG etc, would > throw their mother from the train before using a Monitor structure in > RPGLE. > > Rob Berendt > -- > Group Dekko Services, LLC > Dept 01.073 > PO Box 2000 > Dock 108 > 6928N 400E > Kendallville, IN 46755 > http://www.dekko.com > > > > > > Tony Carolla <carolla@xxxxxxxxx> > Sent by: rpg400-l-bounces@xxxxxxxxxxxx > 09/02/2005 01:51 PM > Please respond to > RPG programming on the AS400 / iSeries <rpg400-l@xxxxxxxxxxxx> > > > To > RPG programming on the AS400 / iSeries <rpg400-l@xxxxxxxxxxxx> > cc > > Subject > Re: Using CL to call RPG pgms > > > > > > > I personally don't use CL in any new projects. I actually just re-wrote my > > initial program in RPG, using APIs. ;-) > > Here's how I handle the stuff. First of all, system() is much easier to > use > than QCMDEXC, in my opinion. In case you haven't used it, you prototype it > > as follows: > > D system PR 10I 0 ExtProc('system') > D szCmd * Value > D Options(*String) > > D RC S 10I 0 Inz > > Then, you can use it as follows: > > RC=system('CRTPF ...'); > > If RC=0, the command was successful. There are more options for checking > the > detailed error (see many posts on system()) > > For specifying which library to find files in (rather than using OVRDBF), > I > use the EXTFILE keyword on the F-specs, that tells exactly what > library/file > to open. You can even use a variable, and set the file as USROPN. Then, in > > your calcs, resolve the variable and open the file. If you need to hit the > > file in multiple places, close it, re-resolve the variable, and open it > again. Of course, when you compile, your current library list is searched > for the file, but once compiled, you are in the driver's seat as to which > file to actually open. > > Another thing to consider is the use of APIs. When you are using system() > or > QCMDEXC to run a CL Command, often times the CL command runs a program > that > uses APIs to perform the action. For these, it might be beneficial to just > > prototype the API, and call it from within the RPG program. I wrote a > program that displays field level details, in a much more abbreviated > fashion than DSPFFD, and rather than use DSPFFD to an outfile, I used > QUSLRCD, QUSLFLD and QDBRTVFD (to get key data) directly. It is very fast. > > > But some might say that this approach is too complex, when you can simply > issue a CL command. > > > On 9/2/05, Igor.Beslic@xxxxxxxxxxxx <Igor.Beslic@xxxxxxxxxxxx> wrote: > > > > Hello! > > > > I have almost 1,5 year expirience in ILE RPG IV and now I realized that > > almost evry RPG pgm I've made needed additional CL pgm that shold > prepare > > LIBL, clear output PFs and perform similar actions after pgm finises... > > > > > > -- > "Enter any 11-digit prime number to continue..." > "In Hebrew SQL, how do you use right() and left()?..." - Random Thought > "If all you have is a hammer, all your problems begin to look like nails" > -- > 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. > > > -- > 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 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.