Hi Praveen,
 
<snip>
One of the biggest practical problem I am finding with using one copy book
per service program to store the procedure declaration is: Each time I add a
new procedure to the service program, the copy book changes and as such I
have to recompile all of my programs that use this. Also I cannot use updpgm
as Turnover does not allow it.
 
I do not have a problem with Turnover compiling all the programs, but we
have 4 production environments spread across us and each change has to be
distributed to all 4 m/c. So say if 20 pgms use my srvpgm & include a copy
book, I have to compile all the 20 pgms even though they do not use all the
procedures or the new one added and distribute them.
 
So for this setup I feel the best way to go might be to not use copybooks.
Am I missing anything here.
</snip>
 
[General disclaimer: I may be wrong on some or all points made below - it is
late and I have just been accepted by DIMIA to emigrate to Australia, so my
mind is not fully-focused :-) ]
 
I would say that using a copybook for a single service program (to hold
prototypes) is perfectly fine. I am not saying it is better than other
methods, just that it is fine. What I would prefer to do is create a
separate copybook for the prototypes of each module - named the same as the
module. I would then create a copybook for the service program and simply
include the copybooks for the modules used to create the service program. I
would then reference the service program copysource in the client program.
This is a nice way to help in the reuse of modules: When you create a new
service program which uses existing modules, create a copybook for it and
slap in the module copybooks  - nice and easy. This method also helps to
document the constituent service program modules.
 
Now, copysource by definition is simply source temporarily copied into the
source prior to compile. Recompiling a service program after adding a new
prototype to a module will not necessarily affect the client program. If
your new procedure is not exported outside the module then the client
program shouldn't care. If the new procedure is not exported outside the
service program the client program shouldn't care. It is only when you
create a new procedure designed for public consumption that you may get
problems - unless you use binder language to declare the new procedure (at
the foot of the new *CURRENT block) and deprecate the current declarations
to a *PRV. You could also use custom-signatures. It is the signature and
order of exported procedures that the client program cares about - nothing
else. As long as you are careful you shouldn't need to recompile the whole
world when you have simply added a new procedure to be used by two new
client programs.
 
TurnOver will "offer" to recompile all client programs when recompiling a
service program but, if you are certain the changes will not affect some
programs you can decline the recompile for these.
 
Regarding problems with distribution to production environments - the use of
copysource and/or binding directories, or even the use of service programs
themselves, will not make a difference. Consider a service program designed
for general-purpose string manipulation. This program could be used
EVERYWHERE in a single production environment - during night and day
processes, during interactive and batch processes. Getting your changes in
can be a nightmare because you will cause some problems somewhere. But we
have always had these problems, even with OPM utility programs. We've all
had the "a program tried to refer to all or part of an object which no
longer exists" error after a code promotion - because there was some NEP
somewhere which used your program and you didn't know about it. :-)
 
I would say - use copy-per-module and group these copymembers on a
per-service program basis. I would also use binding directories - they make
life much easier. But most of all, I would strongly suggest you use binder
language. This is simply the best way I have found to allow a service
program to run with a new exported procedure added while only recompiling
the client programs which need it.
 
 
Finally, as you said:
<snip>One of the biggest practical problem I am finding with using one copy
book per service program to store the procedure declaration is: Each time I
add a new procedure to the service program, the copy book changes and as
such I have to recompile all of my programs that use this. Also I cannot use
updpgm as Turnover does not allow it.
</snip>
 
If you insist on recompiling all client programs when changing a copymember
used by a service program then consider what would happen if you DIDN'T use
a separate copymember for each service program. If several service programs
shared a copymember you would have to recompile all service programs which
use the copymember and then recompile all client programs which use all of
the service programs. Total nightmare, and all for a simple additional
procedure. The other alternative is to not use copysource and simply
cut-n-paste the prototypes into the client programs. I really wouldn't go
down that road. It is the road to maintenance hell. I would keep it simple -
you compile modules, not programs or service programs. Keep the prototype
copysource on a per-module basis and group them on a per-program or
per-service program basis. It just makes sense to me.
 
Cheers
 
Larry Ducie   

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.