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



> This should be a quick one for most of you.  What exactly is a service
> program, or rather, how are they implemented?  Is a service program like a
> compiled, standalone subroutine or module of multiple subroutines?

A *SRVPGM is just like a *PGM, except for two things:

a) You can export subprocedures so that they can be called individually.

b) You can't call a SRVPGM directly with the CALL command, it must be
called from a *PGM object.

Usually, yes, a service program is used as a library of subprocedures that
can be called from programs.

It's similar to a *MODULE (it's actually made of modules, like a *PGM is)
except that when you bind modules together, copies of those modules are
included in the *PGM.  When you bind to a *SRVPGM, there's only one copy
of the *SRVPGM that gets shared by all of the programs that use it.

The nice thing about having one copy, instead of a separate copy for each
program, is that when you want to make a change, you only have to
re-create one object, rather than many.  Saves a lot of time & headaches
on the maintenance side.

> I've read the comments people have made in reference to them but haven't
> had a need for them so far.

I think it's more likely that you do have a need for them, and you just
don't know it yet.  :)


> I'm still getting my feet wet with procedures and procedure interfaces.
> (I've used them for CALLP's and for replacing *ENTRY PLIST).  This may
> or may not be applicable but I am familiar with creating RPG modules and
> then binding them into a executable program.

You can't use procedures or procedure interfaces with CALLP or *ENTRY
LIST.  You're confusing procedures with prototypes. They're related, but
they're not the same thing.

Learning procedures is probably the best place to start, I think you're on
the right track.  Once you use subprocedures all the time, you'll find
yourself saying "I wish I could put this subprocedure somewhere and call
it from all of my programs!".  And then the light goes on and you say
"service programs are great!"

And then you start saying "I'm tired of having to remember to use
BNDSRVPGM() every time I compile this program."  and then the light goes
on about binding directories...


> Specifically, I've been adapting some of Scott Klement's code for reading
> and writing to the IFS in preparation for a project that's coming up.  It's
> been going good so far but one of the examples creates a service program
> and uses it in later programs.  I want to try to use it in my program but
> I'm not sure if I understand the implementation.
> The service program was successfully created in QGPL.
> I'm using a /COPY member of Scott's to define the procedure.
> I get the following error when I try to do a CRTBNDRPG on my program.  Do I
> need to create my program as a module and then bind it to the service
> program?

That would work.  An alternative is to create a binding directory, and
include that binding directory on the H-spec of the program you're calling
it from.

There's instructions for building a binding directory for the IFSTEXTR4
service program at the bottom of the following page:
  http://scottklement.com/rpg/ifs_ebook/textreading.html

(The same instructions are in the .PDF copy of the document as well, but I
don't know the page number off the top of my head)

Once you've got a binding directory, you just need an H-spec like this:

   H DFTACTGRP(*NO) BNDDIR('MYLIB/MYBNDDIR')

Plus, you have to copy the prototypes in with:

    /copy mylib/qrpglesrc,ifstext_h

Those two lines of code are all it takes.  You can now access all of the
routines.  Presto! :)


> MY ERROR MESSAGE:
> Message . . . . :   Definition not found for symbol 'READLINE'.

Library list is irrelevant...  *SRVPGM's are either explcitly included
with the BNDSRVPGM() parameter of the CRTPGM command, or by putting them
in a binding directory and including it on the H-spec or on the CRTBNDRPG
BNDDIR() parameter, or the CRTPGM BNDDIR() parameter.

What a lot of people will do to make things even simpler is put *ALL*
service programs in a single binding directory, and include that BNDDIR()
in every program that they write.  Then you never have to worry about it.


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.