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

DG17201.m

Go to the documentation of this file.
  1. DG17201 ;BHM/RGY,ALS-Find and save all files pointing to religion and marital status files ;FEB 20,1998
  1. ;;5.3;Registration;**172,1015**;Aug 13, 1993;Build 21
  1. CF ;
  1. NEW FILE,FIELD,CONV
  1. K ^TMP("DG11N13",$J)
  1. F CONV=11,13 F FILE=0:0 S FILE=$O(^DD(CONV,0,"PT",FILE)) Q:FILE="" F FIELD=0:0 S FIELD=$O(^DD(CONV,0,"PT",FILE,FIELD)) Q:FIELD="" D ADD(FILE,FIELD,CONV)
  1. D:$D(^TMP("DG11N13",$J)) CONVMSG
  1. K ^TMP("DG11N13",$J)
  1. Q
  1. ADD(FILE,FIELD,TYPE) ;
  1. NEW PIECE,NODE,GLOB,GLLOC
  1. I FILE=""!(FIELD="") Q
  1. I FILE=390.2 Q
  1. D FIELD^DID(FILE,FIELD,"","GLOBAL SUBSCRIPT LOCATION","GLLOC")
  1. S PIECE=$P($G(GLLOC("GLOBAL SUBSCRIPT LOCATION")),";",2)
  1. I PIECE="" D CONVF(FILE,FIELD,"Unknown/Invalid pointer, DD("_CONV_",0,""PT"","_FILE_","_FIELD_").") Q
  1. S NODE=$P($G(GLLOC("GLOBAL SUBSCRIPT LOCATION")),";")
  1. I NODE="" D CONVF(FILE,FIELD,"Unknown/Invalid pointer, DD("_CONV_",0,""PT"","_FILE_","_FIELD_").") Q
  1. S GLOB=$P($$GET1^DID(FILE,"","","GLOBAL NAME"),U,2) I GLOB="" D NOCONV(FILE,FIELD) Q
  1. S EN=$$ADD^DG17202(390.1)
  1. S DIE="^XTMP(""DGTMP"",390.1,",DR="[DG172 NEW ENTRY]",DA=EN D ^DIE
  1. K DIE,DR,DA,EN,X
  1. K ^TMP("DIERR",$J)
  1. Q
  1. NOCONV(FILE,FIELD) ;CONVERTING FILE 11 AND 13 NON-STANDARD ENTRIES
  1. N SUBX,SUB,PIECE,GLLOC,SUBFILE
  1. S SUB(0)=FILE_"^"_FIELD
  1. I '$D(^DD(FILE,0,"UP")) D CONVF(FILE,FIELD,"Unknown/Invalid pointer, DD("_CONV_",0,""PT"","_FILE_","_FIELD_").") Q
  1. I $D(^DD(FILE,0,"UP")) S SUB=1,SUBFILE=FILE F S:$D(^DD(SUBFILE,0,"UP")) SUB(SUB)=^DD(SUBFILE,0,"UP"),SUBFILE=SUB(SUB),SUB=SUB+1 Q:'$D(^DD(SUBFILE,0,"UP"))
  1. S SUBX=$O(SUB(" "),-1) I SUBX>0 D CONVF(FILE,FIELD,"Cannot convert the "_$P(^DD(FILE,0),U)_" in the "_$$GET1^DID(SUB(SUBX),"","","NAME")_" File.",.SUB)
  1. Q
  1. CONVF(FILE,FIELD,TXT,SUB) ;
  1. N X,LAST
  1. S ^TMP("DG11N13",$J,CONV,$O(^TMP("DG11N13",$J,CONV," "),-1)+1)=FILE_"^"_FIELD_"^"_TXT_"^"
  1. S LAST=$O(^TMP("DG11N13",$J,CONV," "),-1)
  1. I '$D(SUB) S ^TMP("DG11N13",$J,CONV,LAST)=^TMP("DG11N13",$J,CONV,LAST)_FILE
  1. I $D(SUB) S X=0,LAST=$O(^TMP("DG11N13",$J,CONV," "),-1) F X=$O(SUB(" "),-1):-1:0 S ^TMP("DG11N13",$J,CONV,LAST)=^TMP("DG11N13",$J,CONV,LAST)_$P(SUB(X),U)_"/"
  1. Q
  1. CONVMSG ;send file 11 and 13 conversion problem message
  1. N HDR,DGX,SPACE,DGY,STRG,CONV
  1. S SPACE=""
  1. S DGY=1
  1. S STRG=" File 11 and 13 Conversion Problem list" D STRING(STRG,.DGY)
  1. S STRG=" " F X=1:1:2 D STRING(STRG,.DGY)
  1. F CONV=11,13 D
  1. .S STRG=$S(CONV=11:"MARITAL STATUS (#11) File Conversion Problems:",CONV=13:"RELIGION (#13) File Converion Problems:",1:"") D STRING(STRG,.DGY)
  1. .S STRG=" " F X=1:1:2 D STRING(STRG,.DGY)
  1. .I '$D(^TMP("DG11N13",$J,CONV)) S STRG="No problems" D STRING(STRG,.DGY) Q
  1. .D CONVHDR
  1. .S DGX=0 F S DGX=$O(^TMP("DG11N13",$J,CONV,DGX)) Q:'DGX D
  1. ..S STRG="",SPACE=""
  1. ..F X=1:1 S STRG=$S(X>1:SPACE,1:"")_$P($P(^TMP("DG11N13",$J,CONV,DGX),U,4),"/",X) Q:X=$L($P(^TMP("DG11N13",$J,CONV,DGX),U,4),"/") D
  1. ...I X<$L($P(^TMP("DG11N13",$J,CONV,DGX),U,4),"/") D STRING(STRG,.DGY)
  1. ...S SPACE=SPACE_" "
  1. ..S SPACE="",STRG=STRG_"^"_$P(^TMP("DG11N13",$J,CONV,DGX),U,2)_"^"_$P(^TMP("DG11N13",$J,CONV,DGX),U,3) D STRING(STRG,.DGY)
  1. .S STRG=" " F X=1:1:2 D STRING(STRG,.DGY)
  1. D MAILMSG
  1. Q
  1. CONVHDR ;
  1. S STRG="Pointer File/Subfile^Field^Problem Description" D STRING(STRG,.DGY)
  1. S STRG="-------------------------------------------------------------------" D STRING(STRG,.DGY)
  1. Q
  1. STRING(STR,DGY) ;convert string into column display
  1. N RST ;result
  1. N X
  1. S RST=$P(STR,U)
  1. I $P($G(STR),U,2)="" S DGY(DGY)=RST,DGY=DGY+1 Q
  1. F X=$L(RST):1:25 S RST=RST_" "
  1. ;format field start column at 25
  1. S RST=RST_$P(STR,U,2)
  1. I $P($G(STR),U,3)="" S DGY(DGY)=RST,DGY=DGY+1 Q
  1. F X=$L(RST):1:35 S RST=RST_" "
  1. ;format problem description start each line at 35
  1. F Q:($L(RST)+$L($P(STR,U,3)))<78 D
  1. .S RST=RST_$P(STR,U,3)
  1. .S STR="",$P(STR,U,3)=$E(RST,79,120)
  1. .S RST=$E(RST,1,78) S DGY(DGY)=RST,DGY=DGY+1
  1. .S RST="" F X=1:1:35 S RST=RST_" "
  1. .S RST=RST_$P(STR,U,3),$P(STR,U,3)=""
  1. S DGY(DGY)=RST,DGY=DGY+1
  1. Q
  1. MAILMSG ;send problem message to user that started task
  1. S XMDUZ="DG*5.3*172",XMTEXT="DGY(",XMY(DUZ)="",XMSUB="File 11 and 13 Conversion Problems"
  1. N DIFROM D ^XMD K XMTEXT,XMY,XMSUB,XMDUZ,XMZ
  1. Q