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



On 8/7/06, Rory Hewitt <roryhewitt@xxxxxxxxx> wrote:
 Steve,

>>either method looks confusing.  Do people use /if defined to bring in code
or prototypes?

Personally, the only in-line code I bring in using an /IF DEFINED is debug
code. But then, the only in-line code I bring in using a /COPY is 'standard'
*PSSR code - I don't like using compiler directives (any of 'em!) in
C-specs.

>>Instead of conditionally compiling code I prefer to have the code exist in
service program procedures.  And instead of conditionally including
prototypes it is easier for me to have one PR source member for each service
program. Then the module being compiled simply includes the PR source
members of the service programs it will be calling into.  I find that even
5000 line PR source members compile fairly quickly.

What do you do about duplication? For instance, what do you do if you have a
program which calls 2 IBM API's, both of which use QUSEC? Do you have a
copybook which defines the QUSEC structure and explicitly include it in your
program? Do you have any 'standard' variables that are used by different
procedures in different service programs?

something like the api error struct is declared in my core functions
copybook. Every module I compile includes this.  All the wrappers and
prototypes for the system apis are in another copybook.  If the module
calls any system apis then it includes that copybook also.

I tend to use one copybook per module - each module tends to include related
procedures, so it makes sense to group them that way. In a multi-module
*SRVPGM, this might mean that an application program would
include several /COPY's for each module used instead of a single
*SRVPGM-level /COPY, but I think the reduction in needless procedure
definitions is worth it.

>>...bottom line is I recommend against conditional compilation.

Fair enough. I think we would probably agree that it makes sense to have a
single copybook per 'group' of related functions, whether it be at a module-
or *SRVPGM-level.

It is working for me. I have a core functions service program and a
core functions copybook.  There is a utility service program and
utility copybook. A system api wrapper service program and copybook.

-Steve

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.