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




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-free

Actually, 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-free

What 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 thread ...

Follow-Ups:
Replies:

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.