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



+1

His proposed approach to handling signatures and rebuilds is just plain dumb. It seems likely to me that he is perhaps working on the assumption that signatures on SPs work in the same way as Java (i.e. based on name _and_ parameter type/size _and_ parameter sequence). They aren't and therefore the automatic defences against a bad build that he may be expecting are just not there.

I would also add that I find their current method of one source one object also rather dated and pointless. But is is sadly a quite widely used approach.


Jon P

On Nov 1, 2022, at 8:42 AM, Therrien, Paul via RPG400-L <rpg400-l@xxxxxxxxxxxxxxxxxx> wrote:

I'm no expert, but at our shop here, we use the export *ALL philosophy, and we have to create all of our programs with the *DUPPROC and *DUPVAR options otherwise we cannot compile.
I like the strategy that you have described. I hope that you are able to keep it.


-----Original Message-----
From: RPG400-L <rpg400-l-bounces@xxxxxxxxxxxxxxxxxx> On Behalf Of Birgitta Hauser
Sent: Tuesday, November 1, 2022 2:54 AM
To: 'RPG programming on IBM i' <rpg400-l@xxxxxxxxxxxxxxxxxx>
Subject: ILE Concepts

Hi everybody,

I need some comments/strategies about ILE Concepts.
A company worked since years as follows:
- One Source one Object (Service-Program or Program)
- a Service-Program could include 1 to n (exported and a few internal) procedures
- Binder Language was used in the way, it was maintained before creating or updating the service program. (They even had a tool which generated the binder language automatically by scanning the source)
- The signature was kept static, i.e. Signature Name = Service-Program name
- Even though the signature was static, the previous export blocks are stored in the binder source just to see what procedures were added.

With this method they could easily add new procedures to service programs and transfer single service programs from the development system to the productive system.
In the case of the company they had to implement the application and fixes on different customer machines. Because the tool was a development tool, the customers had to call the exported procedures.
... and until now it worked without problems.

Now a new (java) guy/leader (who knows everything better) came and told them everything they did were bullshit.
He wants the following:
- Service-Programs are compiled/bound without binder language (i.e. EXPORT
*ALL)
- After the binder language is retrieved (and the signature get modified, i.e. ALL SERVICE PROGRAMS will get the SAME NAME, i.e. Company name = SIGNATURE).
- Then an UPDSRVPGM is performed to include the new Signature in the Service-Program

- if new procedures are added, again the Service-Program is again created with EXPORT *ALL, and the binder source retrieved.
- the binder language is retrieved again, and only the signature has to be changed.

IMHO this cannot work ... at least not without recompiling everything.

Someone can tell me what happens if ALL Service-Programs get the same signature?
Are the right service-Programs still found or are just ALL service-programs activated at the same time?
Are the right procedures still called if all Service-Programs have the right signature?

What do you think about this new strategy ...and was the old one so silly?

Mit freundlichen Grüßen / Best regards

Birgitta Hauser
Modernization - Education - Consulting on IBM i


"Shoot for the moon, even if you miss, you'll land among the stars." (Les
Brown)
"If you think education is expensive, try ignorance." (Derek Bok) "What is worse than training your staff and losing them? Not training them and keeping them!"
"Train people well enough so they can leave, treat them well enough so they don't want to." (Richard Branson)


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

Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related questions.

Help support midrange.com by shopping at amazon.com with our affiliate link: https://amazon.midrange.com

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

Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related questions.

Help support midrange.com by shopping at amazon.com with our affiliate link: https://amazon.midrange.com


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.