That is exactly what I would want CL and RPG in the same source member
(Calling QCMDEXC does not provide all the functionality of a CL program)

>>> -----Original Message-----
>>> From: Scott Klement [mailto:infosys@klements.com]
>>> Sent: Tuesday, August 10, 1999 12:28 AM
>>> To: RPG400-L@midrange.com
>>> Subject: Re: imbedded CL in RPG
>>> 
>>> 
>>> "Roll your own" seems a bit strong for simply writing a prototype!
>>> 
>>> Try this:
>>> 
>>> D RunCmd          PR                  ExtPgm('QCMDEXC')
>>> D   command                    500A   CONST
>>> D   Length                      15P 5 CONST
>>> C                   CALLP     RunCmd('SNDMSG MSG(''Neato'') -
>>> C                               TOUSR(WHOMEVER)': 500)
>>> 
>>> At one point, I wrote a somewhat better one than this that was an
>>> actual sub-procedure, used operational descriptors to get the length
>>> of the command, and called QCAPCMD instead of QCMDEXC so it could
>>> actually return the MsgID of an error (as a return value) or blanks
>>> for success.
>>> 
>>> However, due to the extra hassle of binding to that sub-proc every
>>> time, I tend to ususally just use a simple prototype like in the
>>> example above :)
>>> 
>>> This example does NOT address the idea of passing variables by
>>> reference in order to get a return value.
>>> 
>>> ANOTHER IDEA:   (and this one DOES address the variable issue)
>>> 
>>> How about having seperate sub-procedures for your CL commands, in
>>> other words, each subprocedure would need to be labelled as either
>>> RPG or CL.
>>> 
>>> Then, a simple program... a "preprocessor" if you will...  could be
>>> written to do the following:
>>> 
>>>           1) Seperate each CL "sub-procedure" into its own source
>>>                   member in a file in QTEMP.
>>>           2) Seperate the RPG source into its own source member
>>>                    in a file in QTEMP.
>>>           3) Compile each RPG & CL module (using CRTRPGMOD and
>>>                    CRTCLMOD) individually in QTEMP.
>>>           4) Finally, bind them all into a program.
>>> 
>>> This would, effectively, allow you to run CL stuff in the 
>>> same source
>>> member as your RPG program...  Since you can bind modules written in
>>> CL to modules written in RPG, this would give you very 
>>> nearly the same
>>> performance and benefits of having the CL embedded.
>>> 
>>> Without losing the convienience of having it all in one 
>>> source member.
>>> 
>>> Just an idea!
>>> 
>>> Scott Klement
>>> Information Systems Manager
>>> Klement's Sausage Co, Inc.
>>> 
>>> 
>>> Rob Berendt <rob@dekko.com> wrote:
>>> >
>>> > No, you have to roll your own.
>>> >
>>> > And they never did get back to me as to whether or not 
>>> the following
>>> >  will
>>> > be supported, or is doable:
>>> >
>>> > C    Eval   JobUser = *blanks
>>> > C    CALLP  Runcmd(RTVJOBA USER(&JobUser) )
>>> > C    DSPLY  JobUser
>>> >
>>> > dbale@genfast.com on 08/09/99 12:57:06 PM
>>> > Please respond to RPG400-L@midrange.com@Internet
>>> > To: RPG400-L@midrange.com@Internet
>>> > cc:
>>> > Fax to:
>>> > Subject: RE: imbedded CL in RPG
>>> >
>>> > Hans, Bob, et al:
>>> >
>>> > >>C    CALLP  Runcmd('OVRPRTF QPRINT OUTQ(' + 
>>> variablename + ')')<<
>>> >
>>> > Uh, is this Runcmd procedure available to us already, in 
>>> the compile
>>> >   Or do we
>>> > have to build this ourselves?  I scanned for Runcmd in 
>>> the softcopy
>>> >  but came up
>>> > with zilch.  We're at V4R2.
>>> >
>>> > - Dan Bale
>>> >
>>> +---
>>> | This is the RPG/400 Mailing List!
>>> | To submit a new message, send your mail to RPG400-L@midrange.com.
>>> | To subscribe to this list send email to RPG400-L-SUB@midrange.com.
>>> | To unsubscribe from this list send email to 
>>> RPG400-L-UNSUB@midrange.com.
>>> | Questions should be directed to the list owner/operator: 
>>> david@midrange.com
>>> +---END
>>> 
+---
| This is the RPG/400 Mailing List!
| To submit a new message, send your mail to RPG400-L@midrange.com.
| To subscribe to this list send email to RPG400-L-SUB@midrange.com.
| To unsubscribe from this list send email to RPG400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@midrange.com
+---END



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.