The Archive Documents Utility

CL
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

If you have OfficeVision documents on your system dating back several years, you may be paying a heavy price to store them online. If disk space problems are "haunting" you, you are a prime candidate for the utilities printed in this article.

The heart and soul of these utilities is based upon the premise that an office document takes considerably less space in a save file than in a document library object (DLO) folder. By storing your documents in save files on disk, you can cut a significant amount of disk space required for them. Our tests revealed that you can cut the amount of space required for your documents by more than one half.

In this article, we present a utility that allows you to selectively archive your office documents into online save files (based upon the creation date) and another that allows you to retrieve them. With the second utility, you can search for and select individual documents and instantly restore them back into folders.

Office Documents and the Hierarchical File System

One of the primary things making OfficeVision/400 different from other AS/400 applications is that OfficeVision/400 stores objects in a hierarchical file system.

The AS/400 relational database you are familiar with stores information in data files. These files contain records, each of which is formatted exactly the same. OfficeVision/400 groups data into files containing variable length records, which are in turn indexed in larger groups called folders. The folders do not contain data, but simply act as a directory (much like a library).

The documents created by OfficeVision/400, generally referred to as DLOs, are a unique type of object, and they have a unique set of tools to manage them. Key GO CMDDLO on your system to get a menu of the various commands that you may run to work with DLO objects.

Our observation has been that DLO might also stand for DASD Lost in Oblivion. The amount of disk absorbed by these objects is what is truly "frightening." Unfortunately, we cannot offer you a lot of insight as to where all of the DASD goes, but we might be able to help you do something about it.

We set out to minimize this condition, and this utility helped us realize our goal. Our hope is that you will find it useful as well.

Deciphering the Code

Compile all of the code shown in Figures 1 through 7 and you are potentially ready to save a great deal of disk space. The Archive Folders Utility contains two parts: copying the documents into a save file and then restoring them to a folder on command.

The ARCDOC command drives the first function. When you run this command, it asks for the name of the folder and a range of dates between which documents have been created (revision date would have been better, but was not available in the outfile used to create our summary file). It also requests the name and library of the save file that will hold the compressed documents. If the save file already exists, the ARCDOC utility aborts and sends a message informing the user of the situation.

If you decide to use this utility, you should be aware of several things. Since the ARCDOC command uses fields that are defined with a *DATE type, specific rules are automatically applied to the date fields. For example, if you specify 010101 as a date field, the system automatically converts the date to January 1, 2000.

Also, there is minimal error handling. For example, a user might attempt to save documents for a date range, yet no documents are found that fall within the range. The user will not be informed that no documents were saved. However, the job log can be examined to determine what documents were saved. You should find a message for every document saved that reads "Document xxx moved from folder xxx." The user will also not be informed if the folder path is invalid. Here again, the job log can be examined.

The ARC001RG program is the heart of the function and is shown in 4. After initializing some work fields, the ARC001RG program opens the requested folder (also called a directory) using the Open Directory API (QHFOPNDR). The Open Directory API returns an internal system name (commonly referred to as a handle) that the Read Directory API (QHFRDDR) uses to actually read the directory entries.

The ARC001RG program is the heart of the function and is shown in Figure 4. After initializing some work fields, the ARC001RG program opens the requested folder (also called a directory) using the Open Directory API (QHFOPNDR). The Open Directory API returns an internal system name (commonly referred to as a handle) that the Read Directory API (QHFRDDR) uses to actually read the directory entries.

While opening the directory we define the attributes (fields) that the Read Directory API returns. To do this, we use the table name parameter (TABSPC) and the table length parameter specified when we call the Open Directory API. If you leave the table name blank and use negative 1 (-1) as a field length (as we have done here), all standard attributes will be returned when the directory is read. The particular attribute that interests us in this example is QCRTDTTIM, which is the date and time the document was created.

For the next step in the ARC001RG program, we established a loop to read all the directory entries in the folder we opened. The Read Directory API (QHFRDDR) returns the actual number of directory entries read (NUMRDR) on each call to the API. When all directory entries have been read, this field is returned as zero. It returns the actual document names (along with other information, such as size and date created) in the field DIRBUF, which we move into an array in order to strip out the document name and creation date. If the document creation date is within the date range keyed, the MOVEIT subroutine is called, and the next document is processed. The MOVEIT subroutine moves the document into a temporary holding folder called ARCHIVE.

After all the documents have been processed, we close the directory and execute the WRTSUM subroutine before setting on LR. The subroutine uses QCMDEXC to execute the Save Document Library Object (SAVDLO) command saving all the documents in the ARCHIVE folder into the designated save file. It also deletes the documents from the ARCHIVE folder and creates an "outfile" (ARCDOCS) with one record for each document saved to the save file.

The ARCDOCS file uses the system file QAOJSAVO for its format that has a record length of 777 bytes. Since the whole purpose of this utility is to save space, this is clearly unacceptable. So the last functions the WRTSUM subroutine performs are reading the ARCDOC outfile and writing the pertinent fields into our archived documents file named ARCDOCPF.

The second part of the utility is a simple subfile selection RPG program over the ARCDOCPF summary file we created in the previous example. Figures 5, 6, and 7 show the Work with Archived Documents (WRKARCDOC) command, the ARC002DF display file, and the ARC002RG program.

The ARC002RG program displays the file of archived documents and allows you to search for the document alphabetically by document name or to select a document to be restored (as seen in 8). If you choose the restore option, a prompt is displayed for the Restore DLO (RSTDLO) command, and the document may be restored from the save file to a folder. Once restored, you may work with the document as if it were never archived at all.

The ARC002RG program displays the file of archived documents and allows you to search for the document alphabetically by document name or to select a document to be restored (as seen in Figure 8). If you choose the restore option, a prompt is displayed for the Restore DLO (RSTDLO) command, and the document may be restored from the save file to a folder. Once restored, you may work with the document as if it were never archived at all.

Error handling is limited in ARC002RG. You may sometimes receive generic error messages that don't let you know what the specific problem is. For example, if you attempt to restore a document to a folder that doesn't exist, you'll receive the generic error message "Error occurred during processing of command." If you receive a generic message, go to the job log to obtain more detail. You could easily embellish the ARC002RG program by adding a few additional options that would allow you to view and position the subfile by folder name, description, or document creation date. We omitted these functions from this program in the interest of brevity.

Disk Space Problems: A "Ghost" from the Past

Okay. We really cannot promise that your disk space problems will go away. What we can promise, though, is that this utility is a step in the right direction if your shop uses OfficeVision/400 for document processing.

By archiving our documents, we were able to take a small 1.13MB folder and "archive" it into a save file that required less than 170KB. The original folder was reduced to less than 131KB, and the file records in the ARCDOCPF file required less than 30KB. The sum total of these components was 331KB as compared to the original 1.13MB. That is a DASD savings of more than 70 percent!

While this utility is not the ultimate panacea for all OfficeVision/400 users, it could very well give you a little breathing room in regard to your disk storage problems, "witch" ain't a bad thing!

Doug Pence is the founder and Ron Hawkins is the research and development manager of Computer Processing Unlimited, Inc. in San Diego, California.


The Archive Documents Utility

Figure 1: Physical File ARCDOCPF

 *=============================================================== * To compile: * * CRTPF FILE(XXX/ARCDOCPF) SRCFILE(XXX/QDDSSRC) * *=============================================================== *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 A R ARCFMT A DOCNAM 12 COLHDG('Document name') A FOLDER 63 COLHDG('Folder name') A SDLSFL 10 COLHDG('Save file lib') A SDLSFN 10 COLHDG('Save file name') A DATARC 7 COLHDG('Date archived') A DOCCRT 7 COLHDG('Date doc created') A DOCDSC 32 COLHDG('Description') A K DOCNAM A K FOLDER A K SDLSFL A K SDLSFN *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 
The Archive Documents Utility

Figure 2: Command ARCDOC

 /*===============================================================*/ /* To compile: */ /* */ /* CRTCMD CMD(XXX/ARCDOC) PGM(XXX/ARC001CL) + */ /* SRCFILE(XXX/QCMDSRC) */ /* */ /*===============================================================*/ CMD PROMPT('Archive Documents') PARM KWD(FRMDATE) TYPE(*DATE) MIN(1) PROMPT('From + creation date') PARM KWD(TODATE) TYPE(*DATE) MIN(1) PROMPT('To + creation date') PARM KWD(FLR) TYPE(*CHAR) LEN(63) MIN(1) + PROMPT('Folder') PARM KWD(SAVF) TYPE(QUAL) MIN(1) PROMPT('Save file') QUAL: QUAL TYPE(*NAME) LEN(10) QUAL TYPE(*NAME) LEN(10) DFT(*CURLIB) + SPCVAL((*CURLIB)) PROMPT('Library') 
The Archive Documents Utility

Figure 3: CL Program ARC001CL

 /*===============================================================*/ /* To compile: */ /* */ /* CRTCLPGM PGM(XXX/ARC001CL) SRCFILE(XXX/QCLSRC) */ /* */ /*===============================================================*/ PGM PARM(&FRMDATE &TODATE &FLR &SAVF) DCL VAR(&FLR) TYPE(*CHAR) LEN(63) DCL VAR(&FRMDATE) TYPE(*CHAR) LEN(7) DCL VAR(&TODATE) TYPE(*CHAR) LEN(7) DCL VAR(&SAVF) TYPE(*CHAR) LEN(20) DCL VAR(&ERR) TYPE(*CHAR) LEN(1) DCL VAR(&MSG) TYPE(*CHAR) LEN(7) DCL VAR(&DTA) TYPE(*CHAR) LEN(100) /* If archive folder does not exist, create it */ CHKOBJ OBJ(ARCHIVE) OBJTYPE(*FLR) MONMSG MSGID(CPF9801) EXEC(DO) CRTFLR FLR(ARCHIVE) MONMSG MSGID(CPF0000) ENDDO /* If designated save file does not exist, create it */ CHKOBJ OBJ(%SST(&SAVF 11 10)/%SST(&SAVF 1 10)) + OBJTYPE(*FILE) MONMSG MSGID(CPF9801) EXEC(DO) CRTSAVF FILE(%SST(&SAVF 11 10)/%SST(&SAVF 1 10)) GOTO CMDLBL(SKIP) ENDDO SNDPGMMSG MSGID(CPF9898) MSGF(QCPFMSG) MSGDTA('Save + file' *BCAT %SST(&SAVF 11 10) *TCAT '/' + *CAT %SST(&SAVF 1 10) *BCAT 'already + exists') MSGTYPE(*ESCAPE) SKIP: CALL PGM(ARC001RG) PARM(&FRMDATE &TODATE &FLR + &SAVF &ERR &MSG &DTA) IF COND(&ERR *EQ 'Y') THEN(SNDPGMMSG + MSGID(&MSG) MSGF(QCPFMSG) MSGDTA(&DTA) + MSGTYPE(*ESCAPE)) ENDPGM: ENDPGM 
The Archive Documents Utility

Figure 4: RPG Program ARC001RG

 *=============================================================== * To compile: * * CRTRPGPGM PGM(XXX/ARC001RG) SRCFILE(XXX/QRPGSRC) * *=============================================================== *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 H Y FQAOJSAVOIF E DISK UC FARCDOCPFO E DISK E AB 2000 1 ICMDDS IDS 512 I DS I B 1 40TABLEN I B 5 80DIRBLN I B 9 120NUMDIR I B 13 160NUMDRD I B 17 200LENDIR I B 21 240DIRPLN IDIRBUF DS 2000 IBINARY DS 40 I B 1 40O IBIN1 DS 40 I B 1 40AO IATRIBS DS 40 I B 5 80VL I 13 20 ANAME I 13 17 NAME5 IERR DS 116 I I B 1 40VAR1 I B 5 80BYTAVA I 9 15 MSGID I 16 16 ERR### I 17 116 MSGDTA I '10 ' C DIROCN I 'MOVDOC FROMDOC(' C MOVCON I ') FROMFLR(''' C FRMCON I ''') TOFLR(ARCHIVE)' C TOFCON I 'SAVDLO DLO(*ALL) FLR-C SAVCON I '(ARCHIVE) DEV(*SAVF)- I ' SAVF(' I ') STG(*DELETE) OUTPU-C STGCON I 'T(*OUTFILE) OUTFILE(- I 'ARCDOCS) DTACPR(*YES- I ')' I 'OVRDBF FILE(QAOJSAVO-C OVRCON I ') TOFILE(ARCDOCS)' C *ENTRY PLIST C PARM FRDATE 7 C PARM TODATE 7 C PARM FOLDER 63 C PARM SAVFIL 20 C PARM ERROR 1 C PARM MSG 7 C PARM DTA 100 C MOVE FRDATE FRMDAT 70 C MOVE TODATE TODAT 70 C MOVELSAVFIL SAVFF 10 C MOVE SAVFIL SAVFL 10 C SAVFL CAT '/':0 LIBFIL 21 C CAT SAVFF:0 LIBFIL C '/QDLS/' CAT FOLDER:0 DIRPAT 69 P C MOVE DIROCN DIROIF C Z-ADD116 VAR1 C Z-SUB1 TABLEN C CALL 'QHFOPNDR' C PARM DIRHND 16 C PARM DIRPAT C PARM 69 DIRPLN C PARM DIROIF 6 C PARM ' ' TABSPC200 C PARM TABLEN C PARM ERR C BYTAVA IFGT 0 C MOVEL'Y' ERROR C MOVELMSGID MSG C MOVELMSGDTA DTA C ELSE C NUMDRD DOUEQ0 C CALL 'QHFRDDR' C PARM DIRHND C PARM DIRBUF C PARM 2000 DIRBLN C PARM 10 NUMDIR C PARM NUMDRD C PARM LENDIR C PARM ERR C MOVEADIRBUF AB,1 C MOVEAAB,1 BINARY C Z-ADDO NUMENT 40 C Z-ADD1 X 40 C DO NUMENT C ADD 4 X C MOVEAAB,X BINARY C ADD 1 O C Z-ADDO P 40 C P ADD 4 I 40 C MOVEAAB,O BINARY C Z-ADDO AT# 40 C DO AT# C MOVEAAB,I BIN1 C ADD P AO C MOVEAAB,AO ATRIBS C NAME5 IFEQ 'QNAME' C AO ADD 17 AP 40 C MOVEAAB,AP DOCNAM 12 P C VL SUBSTDOCNAM:1 DOCNAM P C ENDIF C ANAME IFNE 'QCRTDTTM' C ADD 4 I C ITER C ENDIF C ADD 20 AO C MOVEAAB,AO ACCESD 7 C MOVE ACCESD ACCDAT 70 C ACCDAT IFGE FRMDAT C ACCDAT ANDLETODAT C EXSR MOVEIT C ENDIF C LEAVE C ENDDO C ENDDO C ENDDO C CALL 'QHFCLODR' C PARM DIRHND C PARM ERR C SAVCON CAT LIBFIL:0 CMDDS P C CAT STGCON:0 CMDDS C Z-ADD140 LEN 155 C CALL 'QCMDEXC' C PARM CMDDS C PARM LEN C EXSR WRITSM C END C MOVE *ON *INLR *=============================================================== C MOVEIT BEGSR C MOVCON CAT DOCNAM:0 CMDDS P C CAT FRMCON:0 CMDDS C CAT FOLDER:0 CMDDS C CAT TOFCON:0 CMDDS C Z-ADD512 LEN 155 C CALL 'QCMDEXC' 99 C PARM CMDDS C PARM LEN C ENDSR *=============================================================== C WRITSM BEGSR C Z-ADD60 LEN 155 C MOVELOVRCON CMDDS P C CALL 'QCMDEXC' 99 C PARM CMDDS C PARM LEN C OPEN QAOJSAVO C *IN50 DOUEQ*ON C READ QAOJSAVO 50 C *IN50 IFEQ *OFF C SDLTYP ANDEQ02 C MOVE UDATE DATARC C MOVELSDSDTC DATARC C MOVE SDLCDT DOCCRT C MOVELSDCDTC DOCCRT C MOVELSDLDOC DOCNAM C MOVELSDLDSC DOCDSC C WRITEARCFMT C ENDIF C ENDDO C ENDSR *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 
The Archive Documents Utility

Figure 5: Command WRKARCDOC

 /*===============================================================*/ /* To compile: */ /* */ /* CRTCMD CMD(XXX/WRKARCDOC) PGM(XXX/ARC002RG) + */ /* SRCFILE(XXX/QCMDSRC) */ /* */ /*===============================================================*/ CMD PROMPT('Work with Archived Documents') 
The Archive Documents Utility

Figure 6: Display File ARC002DF

 *=============================================================== * To compile: * * CRTDSPF FILE(XXX/ARC002DF) SRCFILE(XXX/QDDSSRC) * *=============================================================== *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 A DSPSIZ(24 80 *DS3) A CA03(03) A CA12(03) A R SFLRCD SFL A SFLRRN 4S 0H A HDSAVF 10A H A HDSAVL 10A H A SFLSEL 1A B 7 2DSPATR(HI) A ZDOCNM 12A O 7 6 A ZDATAR 6Y 0O 7 23EDTCDE(Y) A ZDATCR 6Y 0O 7 33EDTCDE(Y) A ZDESC 32A O 7 43 A ZFOLDR 63A O 8 6 A R SFLCTL SFLCTL(SFLRCD) A SFLSIZ(0008) A SFLPAG(0007) A 21 SFLDSP A SFLDSPCTL A OVERLAY A 25 SFLCLR A 41 SFLEND(*MORE) A N41 ROLLUP(27) A ROLLDOWN(28) A RRN 4 0H SFLRCDNBR A 1 27'Work with' A DSPATR(HI) A 1 37'Archived Documents' A DSPATR(HI) A 3 2'Type options,' A COLOR(BLU) A 3 45'Position to . . . . .' A INDOCN 12A B 3 68 A 4 4'1=Restore' A COLOR(BLU) A 6 1'Opt Document/Folder' A DSPATR(HI) A 6 23'Archived Created' A DSPATR(HI) A 6 43'Description' A DSPATR(HI) A 3 16'press Enter.' A COLOR(BLU) A R MSGSFL SFL A SFLMSGRCD(24) A MSGKEY SFLMSGKEY A PGMQ SFLPGMQ A R MSGCTL SFLCTL(MSGSFL) A OVERLAY A SFLDSP A SFLDSPCTL A N03 SFLEND A SFLINZ A SFLPAG(0001) A SFLSIZ(0002) A PGMQ SFLPGMQ A R FKEYS A 23 2'F3=Exit' A COLOR(BLU) A 23 12'F12=Cancel' A COLOR(BLU) *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 
The Archive Documents Utility

Figure 7: RPG Program ARC002RG

 *=============================================================== * To compile: * * CRTRPGPGM PGM(XXX/ARC002RG) SRCFILE(XXX/QRPGSRC) * *=============================================================== *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 FARC002DFCF E WORKSTN F RRN KSFILE SFLRCD FARCDOCPFIF E K DISK IDATE7 IDS I 2 3 YR I 4 70MD I SDS I 1 10 PGMQ I IDS I B 1 40STKCNT I B 5 80ERRCOD I 'RSTDLO ?*DLO(' C RSTCN1 I ') ?*SAVFLR(ARCHIVE) -C RSTCN2 I '??RSTFLR(''' I ''') ?*DEV(*SAVF) ??S-C RSTCN3 I 'AVF(' C *IN03 DOUEQ*ON C *IN27 DOUEQ*OFF C *IN28 ANDEQ*OFF C EXSR LODSFL C WRITEFKEYS C WRITEMSGCTL C EXFMTSFLCTL C CALL 'QMHRMVPM' C PARM PGMQ C PARM STKCNT C PARM *BLANKS MSGKY 4 C PARM '*ALL' MSGRMV 10 C PARM ERRCOD C *IN28 CASEQ*ON ROLLB C ENDCS C ENDDO C *IN03 IFEQ *OFF C INDOCN IFNE *BLANKS C INDOCN SETLLARCDOCPF C MOVE *BLANKS INDOCN C ITER C ENDIF C EXSR PROCES C ENDIF C ENDDO C MOVE *ON *INLR *=============================================================== C LODSFL BEGSR C *IN27 IFEQ *OFF C MOVEA'00001' *IN,21 C WRITESFLCTL C Z-ADD0 RRN 25 C END C Z-ADD0 X C X DOUEQ7 C READ ARCDOCPF 41 C *IN41 IFEQ *ON C *HIVAL SETLLARCDOCPF C READPARCDOCPF 68 C LEAVE C ENDIF C ADD 1 X 40 C MOVELFOLDER ZFOLDR C MOVELDOCNAM ZDOCNM C MOVELDOCDSC ZDESC C MOVE DATARC DATE7 C MOVELMD ZDATAR P C MOVE YR ZDATAR C MOVE DOCCRT DATE7 C MOVELMD ZDATCR P C MOVE YR ZDATCR C MOVE *BLANKS SFLSEL C MOVE SDLSFN HDSAVF C MOVE SDLSFL HDSAVL C ADD 1 RRN 21 C WRITESFLRCD C ENDDO C ENDSR *=============================================================== C PROCES BEGSR C *IN70 DOUEQ*ON C READCSFLRCD 70 C SFLSEL IFEQ '1' C *IN70 ANDEQ*OFF C RSTCN1 CAT ZDOCNM:0 CMDDS P C CAT RSTCN2:0 CMDDS C CAT ZFOLDR:0 CMDDS C CAT RSTCN3:0 CMDDS C CAT HDSAVL:0 CMDDS C CAT '/':0 CMDDS C CAT HDSAVF:0 CMDDS C CAT ')':0 CMDDS C CALL 'QCMDEXC' 99 C PARM CMDDS 140 C PARM 140 LEN 155 C MOVE *BLANKS SFLSEL C UPDATSFLRCD C ENDIF C ENDDO C 1 CHAINSFLRCD 68 C ZDOCNM SETLLARCDOCPF C ENDSR *=============================================================== C ROLLB BEGSR C RRN IFEQ *ZEROS C INDOCN SETLLARCDOCPF C ELSE C 1 CHAINSFLRCD 68 C ZDOCNM SETLLARCDOCPF C DO 8 C READPARCDOCPF 68 C *IN68 IFEQ *ON C *LOVAL SETLLARCDOCPF C LEAVE C ENDIF C ENDDO C ENDIF C ENDSR *. 1 ...+... 2 ...+... 3 ...+... 4 ...+... 5 ...+... 6 ...+... 7 
The Archive Documents Utility

Figure 8: The WRKARCDOC Display


BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$0.00 Raised:
$