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



Thanks Joel,

    I understand it ALOT better than before!!!!

Justin Houchin
Programmer
Reliatek, Inc

----- Original Message -----
From: "Joel R. Cochran" <jrc@masi-brac.com>
To: <rpg400-l@midrange.com>
Sent: Wednesday, April 17, 2002 11:10 AM
Subject: RE: Prototypes


> > -----Original Message-----
> > From: Justin Houchin [mailto:jhouchin9@charter.net]
> > Sent: Wednesday, April 17, 2002 11:31 AM
> > To: RPG Midrange
> > Subject: Prototypes
> >
> >
> > This is a multi-part message in MIME format.
> > --
> > [ Picked text/plain from multipart/alternative ]
> > I also have one more question. I am new to procedures. Can
> > someone explain in lemans terms  a definition of a prototype,
> > procedure, sub procedure and how they relate. I am confused
> > on the terminology. I read the section in the back of the
> > RPGIV book but I just need to better definition.
>
> I will try to answer your questions, but I cannot adequately do so
> briefly...
>
> 1:)  Prototypes
>
> The definition of how a procedure or sub-procedure shall be called.  This
> sets the rules for the call and must exist in both the calling program and
> the receiving procedure in order to use the 'callp' opcode.
>
> Example:
> d #OverFile       PR
> d  OldFile                      10    value
> d  NewFile                      10    value
> d  NewLibrary                   10    value
> d  NewMember                    10    value options(*nopass)
>
> This states that a call to the procedure '#OverFile' must include the
first
> three parms and may include the fourth.  Additionally, each is allowed to
be
> sent by Value instead of by Reference (I'll cover that in a moment).  This
> prototype also lets us know that the procedure does NOT return a value
since
> there is no return type defined to the right of the PR.
>
> To compile the '#OverFile' module, this PR statement must exist in the
code.
> To call '#OverFile' from another program, this PR statement must exist in
> the code.
> Because I have used the option 'value' on each of the parameters, I can
> issue the callp statement using literals like so:
>
> callp  #overfile( 'myFile' : 'myFile' : 'myLibrary' : 'myMember' )
> but I don't have to pass it the fourth parm...
> callp  #overfile( 'myFile' : 'myFile' : 'myLibrary' )
> because I specified the fourth parm in my PR as *nopass.
>
> If I had not used the values kseyword then I caould only pass variables
and
> it would look more like so...
> eval   myFileName = 'myFile'
> eval   myNewFileName = 'myFile'
> eval   myLibraryName = 'myLibrary'
> eval   myMemberName = 'myMember'
> callp  #overfile( myFileName : myNewFileName : myLibraryName :
myMemberName
> )
>
> It is also good to know that the field names on a PR block are documentary
> only and do not exist as variables in your program.  On a PI block, which
> must mimc your PR block exactly EXCEPT for the variable names, the names
> become program variables.
>
>
>
> 2:)  Procedure/Sub-procedure
>
> I think there are two acceptable views of a procedure in RPGIV.
>
> First (and the one I typically use) is that a procedure is any 'main'
piece
> of code.  A parent module if you will.
>
> Second is that a procedure is any piece of code that incorporates the
cycle,
> meaning it does NOT have NOMAIN at the top of the code.
>
> Tomato tomahta in my view since it is preferred that they are both defined
> and called the same way: with Prototypes and Procedural Interfaces (PI
> blocks).  Personally I think it is a distinction with little merit.  I
tend
> to use the term sub-procedure to refer to a homegrown BIF that is meant to
> be used as part of an expression or to perform a function but that is just
> me.  A procedure to me encompasses the whole entity of a program and what
it
> accomplishes.
>
>
> 3)  How do they all fit together.
>
> Very nicely :-)
>
> A procedure/sub-procedure has a Prototype.  The same prototype is then
used
> in the calling program to establish the rules for the compiler.  The
> compiler then uses the prototype to ensure that your code is following
those
> rules when it calls the procedure/sub-procedure.  Since the two prototypes
> MUST match exactly, the accepted approach is to use a /copy member to
ensure
> that the PR is alway correctly defined.
>
>
> I'm sure this isn't complete but I hope it gets you a little further
along.
> Al standard disclaimers apply... :-)
>
>
> Joel R. Cochran
> Director of Internet Services
> VamaNet.com
> (800)480-8810
> mailto:webmaster@vamanet.com
> _______________________________________________
> This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list
> To post a message email: RPG400-L@midrange.com
> To subscribe, unsubscribe, or change list options,
> visit: http://lists.midrange.com/cgi-bin/listinfo/rpg400-l
> or email: RPG400-L-request@midrange.com
> 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 thread ...

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.