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


  • Subject: Re: Variable file name in rpg /or cl
  • From: Jim Langston <jimlangston@xxxxxxxxxxxxxxxx>
  • Date: Fri, 13 Oct 2000 10:14:02 -0700
  • Organization: Pacer International

This is a good question, and one I have contemplated myself.  Why do an 
override in CL instead of using USROPN in an RPG program?  There are a 
few reasons I can think of.

1. Easier to maintain.  Easier to find the CL program and see the OVRDBF and 
change it
   then to find the same thing in an RPG program (finding the USROPN, tracking 
the
   point in the program where the OPEN opcode is used, finding out where QCMDEXC
   is called and then finding out what parameters are passed, then finding out 
where
   the variable is set, and if the variable is being passed, finding out where 
it is
   being passed from, etc..  A lot faster in CL to find the OVRDBF and then 
finding
   the variable if used and where it's set or passed.

2. Segregation of logic.  Now I have a CL calling the RPG.  If I decide for test
   purposes, or a different company or subdivision, to use a different file 
set, I can
   change the CL program and still have it call the RPG program.  I am 
separating
   Input from Program logic.  If I do it in the RPG I will have to either copy 
the
   program, then have 2 programs to maintain much harder than maintaining 2 CLs,
   or change the program logic to reflect 2 possible sets of files.

Okay, there are also reasons I can think to use USROPN instead of CL.

1. Integration of system.  Use the USROPN and CALL QCMDEXC but move the QCMDEXC 
into
   a directory.  Have the directory look at the logic as to which set of files 
to open
   from however it wants to, it is now transparent to the RPG program (just as 
the CL
   then RPG was).  Again, easier to maintain as now I don't have to worry at 
all in the
   RPG program which set of files I am opening, I just have to work on the 
program logic.
   The library can be as complicated or simple as I need and desire.  In fact, 
it now
   becomes a simple matter ot give the RPG program to a junior programmer to 
maintain, and
   have the programmer/analyst maintain the library in all its complexity.

2. Less overhead and files to maintain.  Now I just have the RPG program to 
maintain, and
   now 2 or more separate files.  Using either method I should be using a 
binding directory
   anyway, so that doesn't really become an issue.

In conclusion, in a smaller shop, or maintaining an older system, or stand 
alone programs,
I would use the OVRDBF in CL.  In a new package or rewriting a system, use the 
USROPN and
move the which file logic to the binding directory (okay, what is the official 
term for a set
of programs put into a directory to be linked at run time?  On PCs this would 
be a Library.).

Just my $0.02.

Regards,

Jim Langston

A smart man learns from his own mistakes.  A wise man learns from the mistakes 
of others.

rob@dekko.com wrote:
> 
> Lots of good suggestions pouring in on this.  I go with the OVRDBF.  My
> only suggestion is why write two programs - an RPG and a CL?  Use the
> USROPN keyword on your F spec.  Use CALL QCMDEXC, (or the alternatives), to
> OVRDBF the file from within the RPG program.  Then use the OPEN opcode to
> open the file.  When you are done, use the CLOSE op code.  I've really cut
> back on CL.  In fact if you use the alternatives to QCMDEXC you get the
> error return code.  Which I think is easier to handle than a MONMSG.
> 
> For example, which is more thorough:
> MONMSG CPF000 GOTO(ERROR)
> GOTO NOERROR:
> ERROR:  /* Find out which error code we actually got and then process
> accordingly */
> 
> - or -
> eval    error=runthis(cmd)
> Select
> when error=*blanks
> when error='CPF....'
> ...
> when error='CPF,,,,'
> ...
> other
> ....
> endsl
> 
> 
>                     Quazy
>                     <quazy@SoftHome.n        To:     rpg400-l@midrange.com
>                     et>                      cc:
>                     Sent by:                 Subject:     Variable file name 
>in rpg /or cl
>                     owner-rpg400-l@mi
>                     drange.com
> 
> 
>                     10/13/00 09:18 AM
>                     Please respond to
>                     RPG400-L
> 
> 
> 
> I need to have a cl program pass a variable to either a rpg or cl program.
> 
> This variable is the file name that the program needs to read from.
> 
> Any suggestions on how to do this???
> 
> Thanks
> 
> Chris
+---
| 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
+---

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.