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


  • Subject: Re: Design shift of view
  • From: "James W. Kilgore" <qappdsn@xxxxxxx>
  • Date: Fri, 24 Jul 1998 02:52:52 -0700
  • Organization: Progressive Data Systems, Inc.



Pete Hall wrote:

> Actually, it's not absolutely required. If you create a temporary version of 
>the *DSPF (different name), and compile the program to use it, you can wait 
>until the permanent display is no longer allocated, then compile it and 
>recompile the program with the correct file name. It's a bit of a hassle, but 
>nobody gets kicked off the system and the job does get done...
>

That's what we do also where it fits.  It's a work around.  For a given display 
file we'll have multiple programs using it. (sharing and all that) so we have 
to compile all programs, wait for shift change, change all the programs again, 
recompile, wait for next shift change ... well, you get the picture.

I take it that you are speaking of the majority environment where you compile 
directly into the production library.  This is just a gut feel from looking at 
the statistics of single machine installations and number of unit sales of CMS 
and have concluded that, well I wouldn't be surprised at 70%, of the shops 
compile to live.

The idea of a "shift of view" is to create a clean method that reduces the work 
around busy work that eats talent without producing benefit.  We all live in 
the real world and work arounds have become the norm. Or should I say numb. <g> 
 They're both four letter words!

You can request that all users sign off, then sign back on.  I've asked. Then 
you spend more CPU and man hours copying back the display file to the name it's 
supposed to be, changing all programs, submitting compiles and during this 
whole process no -real- progress in made.  But you get the naming convention 
back to where it's supposed to be. Whew!

There has got to be a better way.

Ok, let's say you're stuck with DDS and straight RPG/400.  When a program 
change is made and that program is in use, it gets moved to QRPLOBJ and the 
user keeps on running it.  What if, during that move, a flag was set.  When the 
user job made it's next resolved call, that flag triggered a new resolution 
like a first call?  It's a start.

Now we can wait for the OS/compiler to do this, or we can design it in.  How 
you ask. When a call is made and it returns without LR on it stays in the PAG.  
This speeds up the next call.  That's a good thing.  What if, just what if, 
that program was made aware of it's replacement?  Could it seton LR and 
initiate a recall?  Of course it can. We're clever little
buggers and we can do this. <g> (Venu, I'm going to twist this whole thing 
around by bringing in data queues as an alternative to CALL/PARM next time out)

Now that works for programs, but not for files of any flavor. Display, physical 
or logical.  I've understood the concept behind the "file" labeling of 
displays.  Programs have I/O to files.  Well they do have I/O to more than just 
files, but files are what appear in the "F" specs.  Now here's a wild idea, a 
new spec type for display files.  Well we can't use "D",
already taken, maybe "P" for panel or maybe "U" for user interface?  That could 
have the QRPLOBJ behavior of a program?

Well let's take a look at the characteristics of a "file". A physical file has 
a single format.   (let's not quibble over the S/36 concession to multi format 
logicals and the format selector that comes along as additional baggage) A 
display file does have multiple formats by design.  A physical contains 
persistent data. A display file contains transient data.  Other
than the arbitrary labeling of "file", physical files and display files don't 
have a lot in common other than they are a buffer to variable mapping 
mechanisms. So why do we have display "files". Well how about looking at a 
display "file" as a collection of data structures. Now don't get me wrong, I 
love the evolution that WORKSTN files have gone through.
Unfortunately the label of "file" has put shackles on an I/O parsing object 
that should be as dynamically replaceable as a program object.  They are both 
transients.

Ok, here's the rub.  Since every new solution creates a new problem, how do you 
sync a change in a display file to trigger a recompile of a program to avoid 
level checks?  How about stop treating files and programs as separate objects.  
If the two have to dance together, why not capitalize on the ability of knowing 
"where used" to trigger an auto sync commit type
wholesale replacement?

Dare I say that display files are not "files", but program components and 
should behave accordingly?   If we can perform an update with commitment 
control to multiple files, why couldn't a compiler perform the same "unit of 
work" commitment control to program components?

Wow! I'll leave this on a note where applications are more capable then the 
tool!  That's a twist! <vbg>

James W. Kilgore
qappdsn@ibm.net

+---
| This is the Midrange System Mailing List!
| To submit a new message, send your mail to MIDRANGE-L@midrange.com.
| To subscribe to this list send email to MIDRANGE-L-SUB@midrange.com.
| To unsubscribe from this list send email to MIDRANGE-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@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.