|
"Douglas A. Griffin" <degriff@srv.net> on 99-03-27 16:06:38 Please respond to RPG400-L@midrange.com To: RPG400-L@midrange.com cc: (bcc: Stefan Tageson/MMX/Sema Group/SE) Subject: Re: Determine Spool file attributes//spoolfile archiving > Hi. A related question. I have a bunch of spool files for a job that is > already finished sitting in an outq. I want to back up these files to tape > and the only way I know how to do that is copy them to a physical file using > CPYSPLF (if there is a better way please let me know). There are several > thousand of them so I need to write a program rather than do it from the > command line. > Since these files were created with multiple jobs previously run I can't use > the file feedback data structure to retrieve the spool file attributes I > need. required by CPYSPLF. Hi, found this code some time ago, I haven't used it. Try it if you like and please tell me if it worked. Regards // Stefan Tageson +>----------------------------------------------------------------------<+ tel: +46 40 693 3500 fax: +46 40 693 3600 mobile: +46 708 51 3543 e-mail stefan.tageson@notes.sema.se +>---------------------------------------------------------------------<+ TITLE: ...... Using QSPGETF and QSPPUTF APIs with Command Source DESCRIPTION: Using QSPGETF and QSPPUTF APIs with Command Source This document covers usage of the QSPGETF and QSPPUTF print APIs. The command source for the QSPGETF API is supplied if the user wants to facility usage at a command entry screen. This is intended for archiving or AS/400 support diagnostics when the spoolfile printer device type is *AFPDS, *IPDS, or special controls in the spoolfile that does not allow the CPYSPLF command to work. These are the instructions to archive the spool file to a physical file. Use QSPPUTF to restore as a spoolfile. Let the program create the file for you. If you have problems with it creating, then create before running the program. Enter at the command line: CRTPF FILE( ) RCDLEN(4083) MAXMBRS(*NOMAX) + SIZE(*NOMAX) LVLCHK(*NO) Example usage of the QSPGETF API to write to a member in your database file: CALL PGM(QSYS/QSPGETF) PARM('QPRINT ' 'SPOOLDB USER1LIB ' 'DSP03 USER1 010160' X'0001' 'MBR1 ') This API call dumps a spool file QPRINT to a database file SPOOLDB in USER1LIB library, member MBR1. The spool file number is 1. The spool file job is 010160/user1/dsp03. This information can be seen in the WRKSPLF screen by pressing F11 or using Optioin 2. The parameter values must be in uppercase and there must be a space between the single quotation marks. Following are the parts to the parameter list: o The 10-character spool file name. o A 20-character database file and library. Allow for 10 characters for each name. o A 26-character qualified job name for the spool file. This name can be seen in the WRKSPLF screen (press F11). Allow 10 characters each for the job name and user, and 6 positions for the job number. o Numeric file number, 1 through 9999. Use the hexadecimal representation as in the example. Make sure a space is inserted after the previous single quotation mark and the X'0001'. o 10 characters for the database member. To restore the spool file from the database follow the example and instructions below. Example usage of the QSPPUTF API to create a spoolfile from a member in your database file: CALL PGM(QSYS/QSPPUTF) PARM('SPOOLDB USER1LIB ' 'USER1 QGPL ' 'MBR1 ') This API call creates a spool file in USER1 output queue in QGPL library from the MBR1 member in the SPOOLDB database file. The parameter values must be in uppercase, and there must be a space between the quotes. Following are the parts to the parameter list: o 20-character database file and library. Allow for 10 characters for each name. o 20-character output queue name and library. Allow for 10 characters for each name. o 10 characters for the database member. The above API programs can be run from the command line or from a CL program. If you are going to use these APIs on a regular basis, a command interface would be more convenient. The following is the command source for the QSPGETF API. The source code for command GETSPLF, command interface to QSYS/QSPGETF follows. To compile the command, on the OS/400 command line type the following: CRTCMD CMD(lib_name/GETSPLF) PGM(QSYS/QSPGETF) + SRCFILE(lib_name/file_name) SRCMBR(*CMD) GETSPLF: CMD PROMPT('Get Spooled File') PARM KWD(FILE) TYPE(*NAME) LEN(10) RTNVAL(*NO) RSTD(*NO) MIN(1) + MAX(1) FILE(*IN) FULL(*NO) EXPR(*YES) VARY(*NO) PASSATR(*NO) + PROMPT('Spooled file') PARM KWD(TOFILE) TYPE(Q1) RTNVAL(*NO) MIN(1) MAX(1) FILE(*OUT) + PROMPT('To data base file') PARM KWD(JOB) TYPE(Q2) RTNVAL(*NO) DFT(*) SNGVAL(*) MIN(0) MAX(1) + FILE(*NO) PROMPT('Job name') PARM KWD(SPLNBR) TYPE(*INT2) RTNVAL(*NO) RSTD(*NO) DFT(*ONLY) + RANGE(1 9999) SPCVAL((*ONLY 0) (*LAST -1)) MIN(0) MAX(1) + EXPR(*YES) VARY(*NO) PASSATR(*NO) PROMPT('Spooled file number') PARM KWD(TOMBR) TYPE(*NAME) LEN(10) RTNVAL(*NO) RSTD(*NO) + DFT(*FIRST) SPCVAL(*FIRST) MIN(0) MAX(1) FILE(*NO) FULL(*NO) + EXPR(*YES) VARY(*NO) PASSATR(*NO) PROMPT('To member') Q1: QUAL TYPE(*NAME) LEN(10) RSTD(*NO) MIN(1) FULL(*NO) VARY(*NO) + EXPR(*YES) PASSATR(*NO) QUAL TYPE(*NAME) LEN(10) RSTD(*NO) DFT(*LIBL) MIN(0) FULL(*NO) + SPCVAL((*LIBL) (*CURLIB *CURLIB)) VARY(*NO) EXPR(*YES) + PASSATR(*NO) PROMPT('Library') Q2: QUAL TYPE(*NAME) LEN(10) RSTD(*NO) MIN(1) FULL(*NO) + VARY(*NO) EXPR(*YES) PASSATR(*NO) QUAL TYPE(*NAME) LEN(10) RSTD(*NO) MIN(0) FULL(*NO) VARY(*NO) + EXPR(*YES) PASSATR(*NO) PROMPT('User') QUAL TYPE(*CHAR) LEN(6) RSTD(*NO) RANGE(000000 999999) MIN(0) + FULL(*YES) EXPR(*YES) PASSATR(*NO) PROMPT('Number') ---------------------------------------------------------------------- The source code for command PUTSPLF, command interface to QSYS/QSPPUTF follows (see Note below). To compile the command, on the OS/400 command line type the following: CRTCMD CMD(lib_name/PUTSPLF) PGM(QSYS/QSPPUTF) + SRCFILE(lib_name/file_name) SRCMBR(*CMD) Note: The source is not included, Use the GETSPLF as an example. * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 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.