|
Dane, I've looked into doing this myself, but that project hasn't gotten off the ground yet, so my method is as yet unproven. I think versioning is a fine term for this, actually. If you keep all of your procedure prototypes in a /COPY member, the programmer can use one procedure name. Within the copy member, for each include an EXTPROC keyword on the D-specs. So: myProc pr extproc(myProcv5r1m0) ... Then, using an // IF DEFINED directive you can reverse-compile for previous versions with a defined condition. So: /COPY copylib/qcpysrc,myproc /IF DEFINED(V5R1M0) myProc pr extproc(myProcv5r1m0) ... /ELSE myProc pr extproc(myProcv5r1m1) ... /ENDIF Use the binding directory to manage the signatures in the service program and, if my thinking is correct, you've got a versioning system! Cheers, Eric Filson Dane Cox <DCox@xxxxxxxxxxxxx> wrote: I've been doing some research into the mechanics of 'versioning' RPG code on the iSeries. Because versioning tends to mean one thing to one person and one thing to another person, let me try and make my definition clear, even if it is not quite accurate. I have no doubt I'll get lots of advice on the proper terminology, which of course, is one of the reasons I'm posting this. Versioning as I understand is the distinction of one version of 'something' from another version of the same 'something'. For the sake of specificity, let's say that I have a simple program that performs an inquiry on an account. It receives 2 input parameters, chains to a file, and returns 50 output parameters, nothing too complicated. Now, I have the very first version of this program in a library call TEST2005. What are my options for modifying this program to return an additional 10 output parameters? At this point, let's say I already have a change management application that helps me promote my code changes from development to test/QA to production. Typically, this change management application simply overlays the old object with the new, right? Well, what happens if I need to be able to deploy multiple versions of this program throughout a development life cycle? How do I keep this old copy in a deployable state while also making changes and creating new versions of it over time? Stated another way, how do I handle 'minor' versions of the code (PTF's or 'hot fixes') during the life cycle of a major version of the code. My first reaction would be a separate promotion path with target libraries different from the original (e.g. TEST2005V1). Is that the only option on the iSeries? As I understand it, PC versioning is done a little differently where the code is labeled or 'versioned' and any version can be deployed at will. Is this correct? If so, how is this accomplished on the iSeries? I have searched the archives on this topic, and can't seem to find any recent information that is related to this closely enough. If I've missed something, by all means point me in the right direction. Best regards, Dane -- 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.
As an Amazon Associate we earn from qualifying purchases.
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.