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

DGPMDDLD.m

Go to the documentation of this file.
  1. DGPMDDLD ;ALB/MRL - DETERMINE LODGER X-REF'S; 9 FEB 89
  1. ;;5.3;Registration;**54,1015**;Aug 13, 1993;Build 21
  1. ;
  1. EN ; -- lodger x-ref on ward field in
  1. I $S(('$D(DA)#2):1,'$D(DGPMDDF):1,'$D(DGPMDDT):1,1:0) G KX
  1. I DGPMDDF'=6,DGPMDDF'=7 G KX
  1. N DFN S DFN=+$P(^DGPM(+DA,0),"^",3) I '$D(^DPT(DFN,0)) G KX
  1. I 'DGPMDDT D @("K"_+DGPMDDF) G Q
  1. D FIND
  1. I $S('DGWD:1,1:$P(DGWD,"^",2)="") D G Q
  1. . N VAWD
  1. . D INPTCK^DGPMDDCN
  1. . I VAWD,($P(VAWD,"^",2)]"") D 1^DGPMDDCN Q
  1. . K X
  1. D @("S"_+DGPMDDF)
  1. G Q
  1. ;
  1. KX K X
  1. Q K DGPMX,DGPMX,DGWD,DGRM,DGMV,DGMV0,DGFLD,DGPMDD,DGPMDDF,DGPMDDT Q
  1. ;
  1. S6 ; -- ward x-ref
  1. S DGFLD=.107 I $D(^DPT(DFN,.107)) S DGPMX=^(.107) I DGPMX]"" K ^DGPM("LD",DGPMX,DA) D KILL^DGPMDDCN
  1. S DGPMX=$P(DGWD,"^",2),^DGPM("LD",DGPMX,DGMV)=""
  1. D SET^DGPMDDCN
  1. Q
  1. ;
  1. K6 ;
  1. I X S W=$S($D(^DIC(42,+X,0)):$P(^(0),"^",1),1:"") I W]"" K ^DGPM("LD",W,DA) I $D(^DPT(DFN,.107)),^(.107)=W S DGPMX=W,DGFLD=.107 D KILL^DGPMDDCN
  1. K W
  1. Q
  1. ;
  1. S7 S DGFLD=.108
  1. I $D(^DPT(DFN,.108)) S DGPMX=^(.108),DGFLD=.108 D KILL^DGPMDDCN F DGPMX1=0:0 S DGPMX1=+$O(^DGPM("ARM",DGPMX,DGPMX1)) D CHK I $T K ^DGPM("ARM",DGPMX,DGPMX1) Q
  1. S DGPMX=+DGRM D SET^DGPMDDCN:DGPMX
  1. I +DGRM S DGFLD=.108,DGPMX=+DGRM,^DGPM("ARM",DGPMX,DGMV)=1 D SET^DGPMDDCN
  1. Q
  1. ;
  1. K7 I $D(^DPT(DFN,.108)),X=+^(.108) S DGPMX=X I $D(^DGPM("ARM",DGPMX,DA)) K ^(DA) S DGFLD=.108 D KILL^DGPMDDCN
  1. Q
  1. ;
  1. CHK ;
  1. I '$D(^DGPM(DGPMX1,0)) Q
  1. I $P(^DGPM(DGPMX1,0),"^",3)=DFN Q
  1. Q
  1. ;
  1. LD ; -- set "LD" x-ref for file #2 equal to corresp adm mv (#.107)
  1. N DFN,DGMV,DGMV0,DGX S DFN=DA
  1. S DGX=X D FIND S:$P(DGWD,U,2)=DGX ^DPT("LD",DGX,DFN)=DGMV
  1. Q
  1. ;
  1. FIND ;
  1. D NOW^%DTC S DGID=9999999.999999-%,(DGMV,DGMV0)=0,(DGWD,DGRM)=""
  1. F DGID=DGID:0 S DGID=$O(^DGPM("ATID4",DFN,DGID)) Q:'DGID S DGMV=+$O(^(DGID,0)) I $D(^DGPM(DGMV,0)) S DGMV0=^(0) S:$S('$D(^DGPM(+$P(DGMV0,"^",17),0)):0,1:+^(0)'>%) (DGMV,DGMV0)=0 Q
  1. I $D(^DIC(42,+$P(DGMV0,"^",6),0)) S DGWD=$P(DGMV0,"^",6)_"^"_$P(^(0),"^")
  1. I $D(^DG(405.4,+$P(DGMV0,"^",7),0)) S DGRM=+$P(DGMV0,"^",7)_"^"_$P(^(0),"^")
  1. K DGID Q
  1. ;
  1. RESET ; -- reset ^DPT nodes and x-refs
  1. ; input: DFN
  1. ;
  1. ; -- kill data and x-refs
  1. I $D(^DPT(DFN,.107)) S DGPMX=^(.107),DGFLD=.107 I DGPMX]"" K ^DGPM("LD",DGPMX,DA) D KILL^DGPMDDCN
  1. I $D(^DPT(DFN,.108)) S DGPMX=^(.108),DGFLD=.108 D KILL^DGPMDDCN F DGPMX1=0:0 S DGPMX1=+$O(^DGPM("ARM",DGPMX,DGPMX1)) D CHK I $T K ^DGPM("ARM",DGPMX,DGPMX1) Q
  1. ; -- reset data and x-refs
  1. D FIND
  1. I $S('DGWD:1,1:$P(DGWD,"^",2)="") D G RESETQ
  1. . N VAWD
  1. . D INPTCK^DGPMDDCN
  1. . I VAWD,($P(VAWD,"^",2)]"") D RESET^DGPMDDCN
  1. D S6,S7
  1. ;
  1. RESETQ K DGWD,DGRM,DGPMX,DGPMX1,DGFLD,I,DGMV,DGMV0 Q
  1. ;
  1. XREF ;
  1. Q:$P(^DGPM(DA,0),U,2)'=4
  1. N DFN S DFN=+$P(^DGPM(DA,0),U,3) D RESET
  1. Q