|
I prefer SYSTEM() but only because I don't have to tell how many characters.
With the way I program, system() requires *extra* work!I make every effort to write error-free programs, but even so, errors occur. I always make it my business to make sure that when an error occurs, it's as easy as possible to troubleshoot and fix the problem -- the point at which the user is the most frustrated is when an error occurs, and if I can't find and solve his errors, I look bad.
Consider the following code: H DFTACTGRP(*NO) BNDDIR('QC2LE') D system PR 10I 0 extproc('system') D command * value options(*string) /free system('CPYF . . .');I'm assuming that my CPYF will always work. Always. Except when something stops it from working :) You know what I mean? I don't want to code for a condition where it'll fail, because I want to be as productive as possible. But, I don't want to do what I did above and simply ignore any errors and proceed, either! If that CPYF fails, I want to know about it, and I want to know WHY it failed so that I can fix the user's problem. So I have to code the following, at a bare minimum:
H DFTACTGRP(*NO) BNDDIR('QC2LE') D system PR 10I 0 extproc('system') D command * value options(*string) D systemErr s 7A import('_EXCP_MSGID') D wait s 1A D errMsg s 50A /free if system('CPYF . . .') <> 0; errMsg = systemErr + ' when running CPYF command!'; dsply errMsg '' wait; *inlr = *on; return; endif; /end-freeActually, in a production program I wouldn't use DSPLY, I'd call the QMHSNDPM API to end the program with an *ESCAPE message so my caller would know that if failed, too... but even if I cut corners and used DSPLY (as above) I've still added a significant amount of code to my program.
Even with that extra code, when the error occurs, all I'd get is a msgid like CPF0006 (or whatever) and I'd then have to look up that message ID to see what the problem is. If there are any fill-in fields in the msgid, I wouldn't know what they are. I'd probably have to try to re-create the problem on my own machine to get enough information to help the user.
The user himself would NEVER figure out the problem from the message "CPF0006 when running CPYF command!"
On the other hand, I could use QCMDEXC. For example: D QCMDEXC PR ExtPgm('QCMDEXC') D command 32702A const options(*varsize) D len 15P 5 const D cmd s 200A varying /free cmd = 'CPYF . . . '; QCMDEXC(cmd: %len(cmd)); *inlr = *on; /end-freeWhat I did was put the command in a VARYING variable and then used %LEN() to determine it's length so that I don't have to count the characters. Yes, that's one extra line of code over using system()! However, if the QCMDEXC call fails, my program receives and exception message and stops processing! That saves me having to code a routine to detect the error and display it. Furthermore, all of the error information is in the job log. It won't just be the msgid, but it'll be the exact details of the error.
There's a good chance that a more advanced user or system operator type person will be able to look at the job log and solve the problem from the information there. If not, he'll have the option to dump the program, which gives me additional diagnostics, plus I can look at the job log for even more diagnostics.
All in less code than it took to call system()!If you want QCMDEXC to work like system() where it counts the characters for you and returns a success/fail indicator, you can easily stick it in a subprocedure and add a few lines of code to make it work like system(). (but with full job log information).
I have to admit, I see people suggest system() as an "easier" alterative quite often, and I really wonder if they're thinking it all the way through.
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.