When something like this comes up, I usually declare a global variable (export
it if necessary) and then in each proc, check that variable for a value.
I like to use 10i0 and set it to non-zero when the file's have been open, and to
zero when they are closed.


 procOpenFile() 
   if not %OPEN(CUSTMAST);
       g_bFilesOpen = 0;
       OPEN(E) CUSTMAST;
       IF NOT %Error();
         g_bFilesOpen = 1;
       endif;
    endif;
    return g_bFilesOpen;
 endProcOpenFiles()


-Bob Cozzi
www.i5PodCast.com
Ask your manager to watch i5 TV



-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On
Behalf Of Knezevic, Mihael
Sent: Thursday, February 22, 2007 6:00 AM
To: RPG programming on the AS400 / iSeries
Subject: Performance and %open

hello,

i'm currently writing a serviceprogram which should be used for
interactive and batch programs and i'm wondering how to code the opening
and closing of the files. my concept was as following:

procOpenFiles() - opens files if they are not allready open
procCloseFiles() - closes files if they have been open by
procOpenFiles()
procSomething() - checks if the files have been opened with %open and do
some calculations

in a batch program i would call procOpenFiles() at the start and
procCloseFiles() at the end and call procSomething a couple of thousand
times. procSomething would check at the start if the files have been
opened and if not open them and close them at the end of the proc. in an
interactive program i would call procSomething only without the other
two procedures. but how does %open impact performance if it has to check
for 10 or 20 files in batch a couple of thousand times? or would it be
better to code a batch and a non-batch procedure?

any ideas?

thanx in advance

mihael knezevic

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.