|
Hi Sherry... Sounds to me like you've already got a VERY good handle on what you need to do. I'm not sure what you're looking for in the way of "live advice", but I'll take a crack at it anyway :) Here are the thoughts of what this program is going to take to write, as it occurs to me... 1) You'll need F-specs set up to read from one file, and write to the other file. 2) Since you'll have two files, in different libraries that will probably both have the same name, you'll also need to make the compiler see them as different files (otherwise it doesnt know which one you're reading from, and which you're writing to]) So, you'll give them different names on your F-spec, and the override one of them from the command prompt, or from a CL program. 3) Since they are, really, the same file, they'll probably have he same record format name. The compiler isnt able to deal with two files with the same record format name, so you'll need to rename one of them in your RPG program. 4) All the fields in the file will probably be the same name as they were before. In fact, the only difference between your files will probably be the dates -- but they'll probably keep the same fieldnames, anyway. This means that you'll have two different definitions for each date field, one from the old file and one from the new. You'll need to rename one or the other so the definitions don't conflict. 5) I'm not entirely certain if, by "*ISO dates" you mean an 8-digit number in *ISO format, or if you mean an actual date data type with the DATFMT(*ISO) keyword... I'll assume in this example that you're dates are defined as 8S 0 in your new DDS, and 6S 0 in your old DDS. This is the way that I do it, since the date data type is difficult to use in my legacy S/36 programs. First, you need to make your test file in your test library. I'd do this by simply changing the 6S 0 in my OLD DDS to 8S 0, for each date, and then building the new file (we'll call it MYFILE) in the test library with: CRTPF FILE(TESTLIB/MYFILE) SRCFILE(SOURCELIB/QDDSSRC) We'll write an RPG program to convert the data from the old to new... So, here's a sample of that RPG program: * MYFILE is my old, non-Y2K safe file FMYFILE IP E DISK * MYFILE2 is my new, Y2K safe file FMYFILE2 O A E DISK RENAME(MYFMT:MYFMT2) D TempDate S D * I can't have MYDATE1 and MYDATE2 in both files because * they're different. I rename the old ones, here... IMYFMT I MYDATE1 OLDDATE1 I MYDATE2 OLDDATE2 * convert first date C *YMD test(d) OLDDATE1 c if *IN10 = *ON c eval MYDATE1 = *LOVAL c else C *YMD MOVE OLDDATE1 TempDate c *ISO MOVE TempDate MYDATE1 c endif * convert second date C *YMD test(d) OLDDATE2 c if *IN10 = *ON c eval MYDATE2 = *LOVAL c else C *YMD MOVE OLDDATE2 TempDate c *ISO MOVE TempDate MYDATE2 c endif * write to new file. c write MYFMT2 If I try to compile this source member, it won't work because there is no external description for "MYFILE2", its actually called MYFILE but is in a different library than the other "MYFILE". So, before I try to compile my program, I type: OVRDBF FILE(MYFILE) TOFILE(PRODLIB/MYFILE) OVRDBF FILE(MYFILE2) TOFILE(TESTLIB/MYFILE) now I can compile my program with CRTRPGMOD/CRTPGM or CRTBNDRPG as I normally do. Then, probably DLTOVR FILE(MYFILE MYFILE2), unless you want to run it immediately. When you do want to run the program, you type this, again: OVRDBF FILE(MYFILE) TOFILE(PRODLIB/MYFILE) OVRDBF FILE(MYFILE2) TOFILE(TESTLIB/MYFILE) and then: CALL (program-name) and finally: DLTOVR FILE(MYFILE MYFILE2) Now take a few minutes to inspect your file in your test library and make sure everything worked correctly :) I didn't do the code for the "exception report" that you're referring to. To add that in, you'll need an F-spec defining your printer file. I use program-defined output specs for my reports, I dont know what your company does... but thats what I use, so I'd add this code: At the end of your F specs, add this line: FQSYSPRT O F 132 DISK OFLIND(*INOF) After each time you assign *LOVAL to a date, do this: C except Error1 or C except Error2 And create output specs for the report, at the end... OQSYSPRT H 1P 2 3 O OR OF O 50 'Bad Dates in - O date conversion' O E Error1 O 8 'MYDATE1=' O OLDDATE1 15 O E Error2 O 8 'MYDATE2=' O OLDDATE2 15 Hope that helps] Scott Klement Information Systems Manager Klement's Sausage Co, Inc. "Sherry McMahon" <smcm@frontiernet.net> wrote: > I would appreciate any help on writing a conversion program to > change the dates in an existing physical file to *ISO dates in a new > data file. My idea is to create a new physical file with new date > fields and in an RPG program rename the fields, TEST(D) on any > dates, move the 6,0 ymd dates into the new *ISO field, if a bad > date, set it to *loval, write the bad dates to an exception(?) > report, and move all the new fields from the PF to the same name PF > in a test lib. I feel I have a fairly good idea of what I want to > do but darned if I'm sure of how to go about it. It must be pretty > obvious I'm a new programmer and could use some examples on how to > set the RPG up, the proper way to test the dates and how to write > the exception report. I've read the books, been to the IBM site but > would appreciate some 'live' advice. Thank you all in advance for > your time and patience. * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * This is the RPG/400 Discussion Mailing List! To submit a new * * message, send your mail to "RPG400-L@midrange.com". To unsubscribe * * from this list send email to MAJORDOMO@midrange.com and specify * * 'unsubscribe RPG400-L' in the body of your message. Questions should * * be directed to the list owner / operator: david@midrange.com * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
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.