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



What I do with RPG xTools *SRVPGM is to hard code the signature.
When a new procedure is introduced, it is added to the bottom.
If a replacement procedure is introduced, it is, effectively, a new
procedure so it too is added to the bottom.

There is an exception to this, read on...

If a procedure is to be retired, but needs to continue to be in service
until all existing code that references it is recompiled, thee following is
what I do.

Assume the proc name is FindReplace(). I write a faster or better version
and have the streamline the parameters.
In my binder source I originally have this:

STRPGMEXP  PGMLVL(*CURRENT) SIGNATURE('RPGXTOOLS')   
 EXPORT SYMBOL("aesEncrypt") 
 EXPORT SYMBOL("aesDecrypt")  
 EXPORT SYMBOL("FindReplace_V1")    
 EXPORT SYMBOL("CpyToCsvIFS")    
......
ENDPGMEXP

Now I write a new procedure to replace the old FindReplace routine.
That new procedure is named FindReplace but has a different parameter list.
By different, I mean perhaps I moved from a VARYING parm, to CONST
OPTIONS(*VARSIZE) which would cause the compiler to pass data in a different
form, but would not cause source code changes to the caller. 
So in my binder language I do this:
STRPGMEXP  PGMLVL(*CURRENT) SIGNATURE('RPGXTOOLS')   
 EXPORT SYMBOL("aesEncrypt") 
 EXPORT SYMBOL("aesDecrypt")  
 EXPORT SYMBOL("FindReplace_V1")    
 EXPORT SYMBOL("CpyToCsvIFS")    
...
 EXPORT SYMBOL("FindReplace")    
ENDPGMEXP

Note that I've changed the name of the original FindReplace export to
FindReplace_V1 and inserted a new EXPORT statement with FindReplace.
In my source code I would change the original FindReplace procedure name to
FindReplace_V1 and then create the new FindReplace routine someplace else.

This leaves the old FindReplace in the service program and exported in with
the same ordinal. So a program that is already compiled and is calling
ordinal number 3 (my original FindReplace routine) will continue to call the
original routine because it is not calling it by name, but by export ID or
"ordinal".

When new programs are compiled and use the FindReplace routine, they will
get the new version because the name matches the new EXPORT I've added and
does not match the FindReplace_V1 name in the binder source.
When current programs are recompiled, they too will now use the new version
of FindReplace instead of the old one. 

Again, as long as the parameter list is compatible, this technique works. I
will say I've only done this twice and there are nearly 200 procedures in
RPG xTools, so it doesn't come up too often.



-Bob Cozzi
www.RPGxTools.com
RPG xTools - Enjoy programming again.


-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]
On Behalf Of Francis Lapeyre
Sent: Thursday, September 15, 2005 11:51 AM
To: 'RPG programming on the AS400 / iSeries'
Subject: RE: Service Programs and Naming Conventions

Bob:

That's the way I would do it, also. The whole idea is to do aa little "code
cloning" as possibe; less stuff to maintain that way. Yes, I'm aware that
the old versions in Marvin's model are not supposed to change, but what if
one of them has a bug? You have to know where that code is everywhere on the
system. I'd rather change it in just one place.

-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]
On Behalf Of Bob Cozzi
Sent: Thursday, September 15, 2005 11:29 AM
To: 'RPG programming on the AS400 / iSeries'
Subject: RE: Service Programs and Naming Conventions

If you only add new parameters then adding one with OPTIONS(*NOPASS) or
OPTIONS(*NOPASS : *OMIT) would make no difference in the signature.
I've moved to hard coding the signature in the binder source and adding my
new procedure names to the bottom. That way everything continues to work
without recompiling.
I also always add new parameters with OPTIONS(*NOPASS : *OMIT)

-Bob Cozzi
www.RPGxTools.com
RPG xTools - Enjoy programming again.


-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]
On Behalf Of Marvin Radding
Sent: Thursday, September 15, 2005 10:12 AM
To: RPG programming on the AS400 / iSeries
Subject: RE: Service Programs and Naming Conventions


1a. Then when I see module names in upper/lower case that must mean that it
was not written in RPG but probably C or C++

1b. I was planning to use the dots in the name of the module thinking that
it would be hidden inside quote marks.

2. Yes I mean service program.  I understand the need to not disturb the
order as this would force an update of the program, which I am trying to
avoid while making improvements/enhancements to the service program.

On your last statement, wouldn't adding a parameter even if it was
OPTIONS(*NOPASS) change the signature forcing an update of the program?
That is what I am trying to avoid.  I want to make changes and enhancements
without the necessity of updating all program to make sure there won't be
any fatal errors when the user goes to use a program.
The update could take a long time with over 2,000 programs over 6 systems.

Marvin

-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Francis Lapeyre
Sent: Wednesday, September 14, 2005 8:00 PM
To: 'RPG programming on the AS400 / iSeries'
Subject: RE: Service Programs and Naming Conventions

1A. OS/400 and the RPG compiler is case-insensitive. Any source you supply
is interpreted as upper case by the compiler. You can use mixed case for
readability, but remember that Foo is the same as fOO and foO.

1B. You can't use dots in a variable name unless you use the QUALIFIED
keyword on a data structure. I'd use an underscore instead.

2. If by "module", you really mean "service program", yes, as long as you
add the new versions after everything else in the service program. Never add
anything in the middle. 

Personally, I would modify the existing function within the service program
to do things the new way, when it is passed an optional parameter
(OPTIONS(*NOPASS)).

-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx]
On Behalf Of Marvin Radding
Sent: Wednesday, September 14, 2005 7:15 PM
To: RPG programming on the AS400 / iSeries
Subject: Service Programs and Naming Conventions

I am designing a service program and considering version, revisions and
naming conventions.

 

Here's what I am proposing so far.

 

1.      Every program has a name that consists of  upper/lower case
letters ending with a release.version numering.

        a.      How do I get the upper/lower case name?  The D-Spec
always comes out in upper case.
        b.      Can I append a number.number to the end of the name?  I
tried but the compiler rejects the dots.

2.      When an enhancement/improvement is made to a module, the
release.version will change and the new module will be added to the service
program but the old module will not be replaced.  This way no
recompilations/modifications will be necessary.  Is this idea feasible?
Can I added different modules for basically the same program without
encountering any problems as long as the external/exported names are
different?

 

Any idea if this is possible?

 

Marvin

 

 

 

--
This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or
change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives at
http://archive.midrange.com/rpg400-l.



--
This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or
change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
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.