Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: MCDUPR

MCDUPR.m

Go to the documentation of this file.
  1. MCDUPR ;WASH/DCB-Reporting of the duplicates ;5/16/96 15:39
  1. ;;2.3;Medicine;;09/13/1996
  1. START ;
  1. N POP,%ZIS,ZTSAVE,ZTRTN,ZTDESC,ZTSK
  1. W @IOF
  1. K IO("Q") S %ZIS="MQ",%ZIS("B")="Q",%ZIS("A")="This report should be captured on a printer for documentation purposes!! " D ^%ZIS I POP Q
  1. I $D(IO("Q")) D Q
  1. . S ZTRTN="MAIN^MCDUPR"
  1. . S ZTSAVE("^TMP($J,""DUP"",")=""
  1. . S ZTDESC="Removal of Duplication for Medicine"
  1. . D ^%ZTLOAD K ZTSK
  1. . Q
  1. D MAIN
  1. Q
  1. MAIN ;
  1. U IO
  1. I $E(IOST,1,2)="C-" W @IOF
  1. I $D(^TMP($J,"DUP")) D RPT1,RPT2,^%ZISC
  1. Q
  1. RPT1 ;Duplicate Static File Entries
  1. N PGE,CNT,MCNT S (CNT,MCNT)=0 D RPT1H,RPT1M,RPT1F Q
  1. RPT2 ;Pointing to Duplicates
  1. N PGE,CNT,MCNT,SCNT,S1CNT S (CNT,MCNT,SCNT,S1CNT)=0 D RPT2H,RPT2MA,RPT2F Q
  1. ;----------------------------------------------
  1. RPT1H ;Header for Duplicate Static File Entries
  1. N TEMP S TEMP="" S $P(TEMP,"-",80)=""
  1. W:$G(PGE) @IOF S PGE=$G(PGE)+1
  1. W "Report 1",?20,"Duplicate Static File Entries",?60,"Page: ",PGE,!
  1. W !,"STATIC",?8,"STATIC FILE",?35,"DUPLICATE ENTRY"
  1. W !,"FILE #",?8," NAME ",?35,"IEN",?40,"KEY",!,TEMP,!
  1. Q
  1. RPT1M ;Duplicate Static File Entries Main
  1. N FILE,FILENAME,TMP,SIZE S SIZE=IOM-40
  1. S FILE="" F S FILE=$O(^TMP($J,"DUP","F",FILE)) Q:FILE="" D
  1. .S FILENAME=$$GET1^DID(FILE,"","","NAME"),MCNT=$G(MCNT)+1
  1. .S FILENAME=$E(FILENAME,1,26)
  1. .I ^TMP($J,"DUP","F",FILE)=0 W $$TST("RPT1H",1),FILE,?8,FILENAME,?35,"**** No Duplicates ****" Q
  1. .S TMP="" F S TMP=$O(^TMP($J,"DUP","I",FILE,TMP)) Q:TMP="" D RPT1A(FILE,TMP,FILENAME,SIZE)
  1. Q
  1. RPT1A(FILE,TMP,FILENAME,SIZE) ;
  1. N LOOP,REC,REC2,TEMP,LINES,MULTI,TEXT,BEG,END
  1. S REC="" F S REC=+$O(^TMP($J,"DUP","I",FILE,TMP,REC)) Q:REC=0 D
  1. .Q:'$D(^TMP($J,"DUP","I",FILE,TMP,REC,1))
  1. .Q:$P(^TMP($J,"DUP","I",FILE,TMP,REC,1),U,2)="*"
  1. .F LOOP=1:1 S REC2=$P($G(^TMP($J,"DUP","I",FILE,TMP,REC,1)),U,LOOP) Q:REC2="*" D
  1. ..S TEMP=^TMP($J,"DUP","I",FILE,TMP,REC2,0),CNT=$G(CNT)+1
  1. ..S TEXT=TMP_TEMP
  1. ..W $$TST("RPT1H",1),FILE,?8,FILENAME,?35,REC2,?40,$E(TEXT,1,SIZE)
  1. ..I $L(TEXT)>SIZE D
  1. ...S LINES=$L(TEXT)\SIZE
  1. ...F MULTI=1:1:LINES D
  1. ....S BEG=SIZE*MULTI+1,END=BEG+SIZE S:END>$L(TEXT) END=$L(TEXT)
  1. ....W $$TST("RPT1H",1),?40,$E(TEXT,BEG,END)
  1. Q
  1. RPT1F ;Duplicate Static File Entries
  1. N TEMP,DIR S TEMP="" S $P(TEMP,"-",80)=""
  1. W "FILES: ",$$TST("RPT1H",3),TEMP,!,"TOTALS",!,"FILES: ",MCNT,?35,"DUPLICATES: ",$G(CNT)
  1. I $E(IOST,1,2)="C-" S DIR(0)="E" D ^DIR
  1. W @IOF
  1. Q
  1. ;-------------------------------------------------------------------
  1. RPT2H ;Header for Pointing to Duplicates
  1. N TEMP S TEMP="" S $P(TEMP,"-",80)=""
  1. W:$G(PGE) @IOF S PGE=$G(PGE)+1
  1. W "Report 2",?20,"Pointing to Duplicates",?60,"Page: ",PGE,!
  1. W !,?56,"SUB",?64,"SUB"
  1. W !,"STATIC",?8,"OLD",?16,"NEW",?24,"FROM ",?32,"MAIN",?40,"SUB",?48,"SUB",?56,"SUB",?64,"SUB"
  1. W !,"FILE #",?8,"IEN",?16,"IEN",?24,"FILE #",?32,"IEN ",?40,"FILE",?48,"IEN",?56,"FILE",?64,"IEN"
  1. W !,TEMP,!
  1. Q
  1. RPT2MA ;Main Print for Pointing to Duplicates
  1. N FILE,TMP,TEMP,NIEN,OIEN,EX
  1. S FILE="" F S FILE=$O(^TMP($J,"DUP","F",FILE)) Q:FILE="" D
  1. .Q:^TMP($J,"DUP","F",FILE)=0
  1. .Q:'$D(^TMP($J,"DUP","J",FILE))
  1. .S CNT=$G(CNT)+1,TMP=""
  1. .F S TMP=$O(^TMP($J,"DUP","J",FILE,TMP)) Q:TMP="" D
  1. ..S TEMP=^TMP($J,"DUP","J",FILE,TMP,1),OIEN=^TMP($J,"DUP","J",FILE,TMP,"OLD"),NIEN=^TMP($J,"DUP","J",FILE,TMP,"NEW")
  1. ..S EX="D RPT2"_$P(TEMP,U)_"(FILE,TEMP,OIEN,NIEN)"
  1. ..X EX
  1. Q
  1. RPT2M(SFILE,TEMP,OIEN,NIEN) ;Pointing to with a Main File
  1. N MAINFILE,MAINREC S (MAINFILE,MAINREC)=""
  1. D RPT2B(TEMP,.MAINFILE,.MAINREC)
  1. W $$TST("RPT2H",1),SFILE,?8,OIEN,?16,NIEN,?24,MAINFILE,?32,MAINREC,?40,"N/A"
  1. Q
  1. RPT2S(SFILE,TEMP,OIEN,NIEN) ;Pointing to with Sub-File
  1. N MAINFILE,MAINREC,SUBFILE,SUBREC S (MAINFILE,MAINREC,SUBFILE,SUBREC)=""
  1. D RPT2B(TEMP,.MAINFILE,.MAINREC),RPT2C(TEMP,.SUBFILE,.SUBREC)
  1. W $$TST("RPT2H",1),SFILE,?8,OIEN,?16,NIEN,?24,MAINFILE,?32,MAINREC,?40,SUBFILE,?48,SUBREC
  1. Q
  1. RPT2SS(SFILE,TEMP,OIEN,NIEN) ;Pointing to with sub-file within sub-file
  1. N MAINFILE,MAINREC,SUBFILE,SUBREC,SUBFILE1,SUBREC1 S (MAINFILE,MAINREC,SUBFILE,SUBREC)=""
  1. D RPT2B(TEMP,.MAINFILE,.MAINREC),RPT2C(TEMP,.SUBFILE,.SUBREC)
  1. S SUBFILE=$P(TEMP,U,6),SUBREC=$P(TEMP,U,7)
  1. S SUBFILE1=$P(TEMP,U,10),SUBREC1=$P(TEMP,U,11)
  1. W $$TST("RPT2H",1),SFILE,?8,OIEN,?16,NIEN,?24,MAINFILE,?32,MAINREC,?40,SUBFILE1,?48,SUBREC1,?56,SUBFILE,?64,SUBREC S S1CNT=$G(S1CNT)+1
  1. Q
  1. RPT2B(TEMP,MFILE,MREC) ;Get main file and main record
  1. S MFILE=$P(TEMP,U,2),MREC=$P(TEMP,U,3),MCNT=$G(MCNT)+1
  1. Q
  1. RPT2C(TEMP,SFILE,SREC) ;Get Sub-file and sub-record
  1. S SFILE=$P(TEMP,U,6),SREC=$P(TEMP,U,7),SCNT=$G(SCNT)+1
  1. Q
  1. RPT2F ;Footer for Pointing to Duplicates
  1. N TEMP,DIR S TEMP="" S $P(TEMP,"-",80)=""
  1. W $$TST("RPT2H",3),TEMP
  1. W !,"TOTALS:",!,?2,$G(CNT),?24,$G(MCNT),?40,$G(SCNT),?56,$G(S1CNT)
  1. I $E(IOST,1,2)="C-" S DIR(0)="E" D ^DIR
  1. W @IOF
  1. Q
  1. TST(RTN,SKIP) ;Checks $Y and does formfeed if needed and skips the new lines
  1. N LINE,DIR
  1. I ($Y+SKIP+$S($E(IOST,1,2)="C-":2,1:4))>IOSL D
  1. .I $E(IOST,1,2)="C-" S DIR(0)="E",DIR("A")="Press RETURN to continue: " D ^DIR
  1. .D @RTN S SKIP=1
  1. F LINE=1:1:SKIP W !
  1. Q ""