| 
 | 
Keshav,
As you already know, you can make modules, usually NOMAIN modules,
that contain lots of useful procedures that you can call from your
RPG program.
To make these "utility procedures" very useful, you need to be able
to bind them to many different programs.   This becomes cumbersome,
because now when you make a change to your utility module, you have
to first search out all programs that use your module, then you have
to recreate all of these programs.
Another problem with this approach is that when you bind modules
with the CRTPGM command, you're "binding by copy" which means that
each program has a complete copy of the module in it.   Thats not
a very efficient use of disk space!
So this is where service programs come in.   You can take one or more
modules and create a service program.   Then, you can bind this
service program to the programs that you want to call its utility
functions from.  When this happens, you are "binding by reference",
which means that your program only stores "references" to the service
program, rather than an entire copy of the module.  And because its
stored in a seperate object on the disk, you don't have to re-create
all of the programs -- unless the "interface" has changed.
The "interface" for a service program tells the system which
procedures are available for other programs to call, and what order
they are listed in the service program.   This is important because
it determines how the operating system creates "references" when you
bind your programs to a service program.   By creating some source
code for your "interface" you can allow the service program to
have previous interfaces as well as the current interface.  This
is useful if you want to avoid recompiling your existing programs
when you change your service program's interface.
So thats what service programs are...
The RPG code for a service program, instead of a bound module is
identical, so I won't try to show you a code difference.
However, to make a program from two modules, you do this:
CRTPGM PGM(mypgmname) MODULE(module1 module2) actgrp(myactgrp)
To do the same thing, but have module2 be a service program, you'd
do:
crtsrvpgm srvpgm(mylib/mysrvpgm) module(module2) export(*all) +
     text('my service program') actgrp(*caller)
crtpgm pgm(mypgmname) module(module1) bndsrvpgm(mylib/mysrvpgm) +
       actgrp(myactgrp)
and, if (and you SHOULD do this!) you needed to specify your srvpgm's
interface, you'd make a source member like this:
(for example, this might be in MYLIB/QSRVSRC in the MYSRVPGM member)
STRPGMEXP PGMLVL(*CURRENT)
     EXPORT SYMBOL(FirstProc)
     EXPORT SYMBOL(SecondProc)
     EXPORT SYMBOL(ThirdProc)
ENDPGMEXP
And then you'd compile it with:
crtsrvpgm srvpgm(mylib/mysrvpgm) module(module2) export(*srcfile) +
     srcfile(mylib/qsrvsrc) srcmbr(mysrvpgm) text('my service +
     program') actgrp(*caller)
crtpgm pgm(mypgmname) module(module1) bndsrvpgm(mylib/mysrvpgm) +
       actgrp(myactgrp)
Thats really all there is to service programs...   They're not very
different from calling other modules from your RPG programs.
If you need more info, theres details and some good examples in
the "AS/400 ILE Concepts" book which is available in your softcopy
library or in ibm's on-line library at:
http://as400bks.rochester.ibm.com/pubs/html/as400/onlinelib.htm
Good luck!
"keshava narasimha" <anandthirta@hotmail.com> wrote:
> Hi !
>
> Yes I am familiar with the sub-procedures & NOMAIN modules
> Thanks again.
>
> Keshav
>
> >"keshava narasimha" <anandthirta@hotmail.com> wrote:
> > >
> > > Hi everybody!
> > >
> > > I have just started with ILE RPG/400.I am not very clear in
> > >  understanding
> > > Service programs.Could someone from the list  discuss  it with
> > > examples(source).
> > >
> > > Thanks,
> > >
> > > Keshav
+---
| 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 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.