On 7/8/2014 12:53 PM, D*B wrote:
Buck,
in my little example C1Rec is declared in the global section. If you
have a look to the headline (2 lines up) there is the ctiteria for
global vars - statefull! the state of the complete module should be
declared in global vars and the procedures work with the state of the
module. As a rule of thumb best practices are:
- never export variables, provide get and set methods instead
- don't use static local vars
- keep parameter interfaces tiny (more than 5 vars are unreadable and
errorprone)
- define statefull (it's not a technical issue, but a design issue)
vars global to the module
- define all temporary information local in its context
- put all procedures in the same module, which are sharing statefull
information

D*B

I very much agree with all of this. I did not see a getter in
doSomething() which is probably where my brain got stuck. Thank you for
your patience. As a self-taught programmer, I don't always recognise
when I need to learn some more :-)
--buck

--------------------------------------------------
From: "D*B" <dieter.bender@xxxxxxxxxxxx>
Sent: Tuesday, July 08, 2014 10:46 AM
To: "RPG programming on the IBM i / System i" <rpg400-l@xxxxxxxxxxxx>
Subject: Re: Are subroutines codependent?

... not very humorous, but simple:
supprocedures could replace subroutines, but subroutines could not
replace subprocedures, because they don't have parameters, local
variables and prototypes. to keep programms simple you don't need both
and best is to forget subroutines.

example to demonstrate power of subProcedures

/* local prototypes
D work PR
D fetchC1 PR n
D doSomething PR
/*--- Constants
D TRUE C *ON
D FALSE C *OFF
/* statefull variables
d halString s 200
d C1Rec e ds extname(COVELENZ)
c/exec sql
c+ declare C1
c+ cursor for S1
/* very unimportant procedure main ----------------------------------*/
c/end-exec
/free
work();
return;
/end-free
/* end of vup -------------------------------------------------------*/
p work b
/free
halString = 'select * from COVELENZ';
exec sql prepare S1 from :halString;:
exec sql open C1;

dow fetchc1();
doSomething();
enddo;

exec sql close C1;
return ;
/end-free
p work e
/*-------------------------------------------------------------------*/
P fetchC1 B
D fetchC1 PI n
d result s n inz(FALSE)
/free
exec sql fetch next from C1
into :C1Rec;
if sqlcode = 0;
result = TRUE;
endif;
return result;
/end-free
P fetchC1 E
/*-------------------------------------------------------------------*/
P doSomething B
D doSomething PI
/free
// process the fetched record
return;
/end-free
P doSomething E
****************** End of data ****************************************

Additinal note:
global data and coupling procedures by global data is not bad design!
Bad design is to define data global, which is needed only local!!!

D*B



As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

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.