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



Here we go long winded again. Replying by number.

1. The solution is design. Breaking the problem down to small pieces. If a 
function does one thing and one thing only, changes that you make are likely to 
be changes that you need to make. If you have a function(procedure) that 
calculates inventory turns, you are not likely to need to change it unless you 
change how inventory turns are calculated and if you change it you are likely 
to be either fixing an existing bug or changing how the calculation is done and 
anybody who uses that function would need to have the corrected function. 

If you need to calculate inventory turns in two or more different ways, then 
they are not the same function. So the question becomes, why do I have two 
different ways to calculate inventory turns? Maybe I need to break the problem 
further, or I need two functions. One to calculate turns using the Green method 
and to calculate using the Blue method and an internal function that does the 
actual calculations with a parameter that controls how the calculation is done. 
Etc, etc. 

If the function does more than one thing (The rule I use is that I have to be 
able to describe what a function does without the use of conjunctive verbs (and 
or)), then I could end up with a situation where changing part of the function 
could screw up something else. Poor design. 

2. The problem with programs is simple. Programs only have one entrance point 
and that is the *ENTRY point. Think about the IFS problem. You need a function 
that writes to the IFS in text and one in binary. You need a function that 
reads from the IFS in text and binary and you need function that checks to see 
if a directory exists. How do you code that with one entrance point. Each one 
has different parameters. You could try different programs but then what 
happens with common logic? It rapidly disintegrates into a mess. That why when 
I look at most calls to programs used for functions, I see huge monolith 
programs doing sometimes hundreds of functions. 

Service program allow multiple entrance points (One per exported procedure) so 
you can have a module bound into a service program XVIFSP that allow you to 
write text and another procedure that writes binary and internally there may be 
one routine that implements the actual write.

In addition, when I first wrote my IFS service program, I only supported text 
reads and writes but then one day I needed to read and write binary data so I 
only needed to add two new procedures to support that and because I used 
binding scripts, none of the programs using the existing functions where 
touched. Only the new program used the new functions. Try doing that with 
programs. What a nightmare.   

All of this ignores all the things you can do with a procedure, Long names, 
value parameters, varying string, optional parameters, etc, etc. The list goes 
on and on. Using procedures in service programs gives you flexibility you could 
never dream of in a program. 

The other issue is simply speed. I ran a test the other day making a call to 
procedure 15 million times. It took it 29 seconds for an average of .00000054 
per call and that is passing a long Value parameter. In contrast, a call to a 
program takes somewhere close to 100 ms per call. Making the same 15 million 
calls would run for hours and would knock your system to its knees.

When you break a problem down to small pieces, you end having to make many 
small calls. ILE is designed to do just that. 

The other thing to remember is that modules are used to group together things 
that need to be grouped together. You could group together in one module IFS 
and Inventory Turns but that doesn't make much sense. You would have IFS 
grouped together in one module and maybe Inventory functions in another module 
but the grouping also applies to grouping modules together. You could but why 
would you put an IFS module in the same service program as Inventory functions? 
You won't. Like things in like service programs. Again, you are isolating 
change.

It is a matter of balance. You don't want too much stuff in one service program 
nor do you want to go the other way and have too many service programs. So 
again, design. You have to think about all these questions. 
 
If you look at some of my earlier posts about how I organize modules and decide 
what goes into a module, you will see examples of how I have attacked this 
problem. 

I am currently working a Dynamic Arrays service program on the side and I am 
having to deal with all these issues. What service am I going to provide, what 
will each function do, how do I communicate data between the caller and the 
service program. How do I support find and sort, etc, etc, etc. Lot of thinking 
to do. Trying to make it easy to use but still powerful. That is tough. 

-----Original Message-----
From: ganeshkumar.murugesan@xxxxxxxxx
[mailto:ganeshkumar.murugesan@xxxxxxxxx]
Sent: Monday, February 07, 2005 10:11 PM
To: rpg400-l@xxxxxxxxxxxx
Subject: RE: Advantages of Service program



Your explanation is wonderful. But I have a few more doubts in this.

1. Suppose I write a service program with 4 modules inside it. Consider
that 100 other programmers are using the service program. Suddenly I
make some changes to one of the modules in the service program. Just
imagine what will happen to all those programs, which uses this service
program. Maybe they didn't want that change to happen. They will get
unexpected results because of the change I made to the service program,
without their knowledge. They actually don't want some unexpected
results but they will be getting it because I have done some changes.

2. Let us consider there are no service programs. So we just have
modules and procedures. In such a case, won't it be simpler to code a
separate logic inside a separate program instead of coding it inside a
module. You can attain the same results using a program. So why to go
for modules instead of individual programs which can contain the same
piece of reusable code.

Please clarify these doubts.


-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Alan Campin
Sent: Tuesday, February 08, 2005 5:51 AM
To: RPG programming on the AS400 / iSeries
Subject: RE: Advantages of Service program

This is very long winded. Sorry

In a word. Encapsulation. Again that word. Service programs allow you
take pieces of logic, hide them in procedures and to create libraries of
functions that hide information and to do it at a speed that is
comparable to running the same procedure in a bound module.

If you have had any experience with Microsoft DLL's (Dynamic Link Load
Library), a service program is the same thing. The same thing a DLL does
for you, a service program does for you but I must say, it is a lot
easier in ILE than Microsoft DLL's. Instead of putting your logic in
every program, you put the logic in one service program and the most
important part is that you can hide the logic. If the service program is
properly written, it hides how it works, i.e. it encapsulates the logic.


The problem with this and it is a bugaboo is that ILE RPG is a whole new
world, really a new language. A completely different way of thinking and
it takes time to learn how to think that way.

Instead of writing everything in one big program, you have to break
everything down into small pieces and procedures that do one thing.

An example would that you need to read and write to the IFS. When you
first look at the problem, you could just include all the logic in one
big program which is as far as most RPG programmer would go. Each time
they need to read and write to the IFS, they would just copy the logic
from the other program and have a another version that might or might
not be the same. Languages like RPG III made it very difficult to do
anything except write monolith programs. With RPG IV, we still can write
monolith programs but ILE RPG gives use the means to do something
completely different

But if you stop and think for second, it might occur to you that, "Hey,
that logic is the same logic I used before. Why not take that logic
(read and write to the IFS) and put it in another module? That way I
only have to include that module each time I need to read and write to
the IFS and if I need new functions, I can add them to the module.

The next logical step is it might occur to you that "Wait a minute, I
have to use that logic in many places and other people might be able to
use it and if I add new functions to the module, I have to rebind every
program so why don't I create a service program, then anybody can use
the logic?" That is exactly what a service program is about. If you
create the service program, other people can use it and if you find an
error in your logic, you can fix the service program without having to
create any program that uses it.

The trick here is that you really have to think. How are they going to
use the service program? What services do I provide? How do I handle
errors (Big one)? If you do it right, there is a huge payoff. Suddenly
each time to you need to read and write to the IFS, you just include the
service program and you don't have to worry about how the read and write
to the IFS works.

Anyway, my point is if you logically break a problem down to smaller and
smaller pieces, you naturally end at the service program. More and more
of the program logic ends up in the service program and that is what a
service program was created for. To support just that process.

Another example of using a service program. At a company I was at
previously, we had a very complicated price system and the logic to
price was buried in the order entry program. If you wanted to price, you
had to copy out the logic and adopt it for that environment. When I took
a look at the process is occurred to me that the pricing logic was
separate so I ended up with a service program that published three
services. GetBasePrice, GetCustomerPrice and GetDetails. GetBasePrice
just picked up a base price before any customer discounts,
GetCustomerPrice received a customer number along with the item. To get
the base price, I just needed to call GetBasePrice. If I wanted to
display the details of how the price was calculated, I could just call
Get Details and retrieve all the details.

Internally I had a lot of logic that was hidden in internal procedures
but the outside world only say the three procedures.

Now the only thing anyone had to do was call the service program for
prices and if I needed to change how the internal prices worked, I only
needed to change the internal logic and what was returned, a base or
customer price did not change. That is what a service program is for.
When done right, it is a beautiful thing. Done wrong, it is a mess.

The criminal shame is that we did not have this capability back twenty
or more years ago. Instead of writing monolith programs, everyone could
have learned to write using service programs and small pieces of logic.
What a price we pay. The rest of the world had it, but not us.

-----Original Message-----
From: ganeshkumar.murugesan@xxxxxxxxx
[mailto:ganeshkumar.murugesan@xxxxxxxxx]
Sent: Monday, February 07, 2005 2:57 AM
To: rpg400-l@xxxxxxxxxxxx
Subject: Advantages of Service program



Why to include modules in a service program instead of directly
including the modules in the program object using CRTPGM command. What
is the advantage of using service program apart from the initial load
performance point of view?





Confidentiality Notice

The information contained in this electronic message and any attachments
to this message are intended for the exclusive use of the addressee(s)
and may contain confidential or privileged information. If you are not
the intended recipient, please notify the sender at Wipro or
Mailadmin@xxxxxxxxx immediately and destroy all copies of this message
and any attachments.





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




Confidentiality Notice

The information contained in this electronic message and any attachments to 
this message are intended
for the exclusive use of the addressee(s) and may contain confidential or 
privileged information. If
you are not the intended recipient, please notify the sender at Wipro or 
Mailadmin@xxxxxxxxx immediately
and destroy all copies of this message and any attachments.






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.