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

DIC.m

Go to the documentation of this file.
  1. DIC ;SFISC/XAK,TKW,SEA/TOAD-VA FileMan: Lookup, Part 1 ;12SEP2013
  1. ;;22.2;VA FileMan;;Jan 05, 2016;Build 42
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;;Submitted to OSEHRA 5 January 2015 by the VISTA Expertise Network.
  1. ;;Based on Medsphere Systems Corporation's MSC FileMan 1051.
  1. ;;Licensed under the terms of the Apache License, Version 2.0.
  1. ;
  1. N %,D,DF,DIFILEI,DIENS,DINDEX,DS,DIASKOK,DIY,DO S U="^",DIC(0)=$G(DIC(0))
  1. D GETFILE^DIC0(.DIC,.DIFILEI,.DIENS) I DIFILEI="" S Y=-1 Q
  1. S %=$P("K^",U,DIC(0)["K"),(D,DINDEX,DINDEX("START"))=$$DINDEX^DICL(DIFILEI,%) ;ASSUMES A "B" CROSS-REFERENCE
  1. K %
  1. EN I $G(DIFILEI)=""!('$D(DINDEX)#2) N DIFILEI,DIENS,DINDEX,DIASKOK,%
  1. K DO,DICR,DIROUT,DTOUT,DUOUT S U="^"
  1. D INIT^DIC0 I DIFILEI="" S Y=-1 D Q^DIC2 Q
  1. S DIC(0)=$G(DIC(0)) D
  1. . I DIC(0)["T" K ^TMP($J,"DICSEEN") S ^TMP($J,"DICSEEN",DIFILEI)=""
  1. . I $D(ZTQUEUED),$E($G(IOST),1,2)'="C-" S DIC(0)=$TR(DIC(0),"AEQ")
  1. . I DIC(0)["X",DIC(0)["O" S DIC(0)=$TR(DIC(0),"O")
  1. . S:DINDEX("#")>1 DIC(0)=$TR(DIC(0),"M") Q
  1. N DIPGM S DIPGM=$$PGM^DIC2(.DIC,$G(DF),DIFILEI)
  1. I DIPGM]"" D KILL1^DIC0 K DIC("W") S DIPGM(0)=1 G @DIPGM
  1. ASK I $G(DIFILEI)=""!('$D(DINDEX)#2) N DIFILEI,DIENS,DINDEX,DIASKOK,% D INIT^DIC0 I DIFILEI="" S Y=-1 D Q^DIC2 Q
  1. I '$D(DIVAL) N DIVAL,DIALLVAL
  1. K DIVAL,DIALLVAL S DIVAL(0)=0,Y=-1,DIALLVAL=1
  1. I DIC(0)["A" K X W ! D ^DIC1 I $G(DTOUT) D Q^DIC2 Q
  1. I DIC(0)'["A" D CHKVAL^DIC0,CHKVAL2^DIC0(DINDEX("#"),.DIVAL,DIC(0),.DDS)
  1. A1 I DIVAL(0) D
  1. . D CHKVAL1^DIC0(DINDEX("#"),.DIVAL,DIC(0),DIC(0),.DIALLVAL) Q:'DIVAL(0)
  1. . I $D(DIADD),X]"",X'["""" S (X,DIVAL(1))=""""_X_"""" S:DINDEX("#")>1 X(1)=X
  1. . N DUOUT K DINDEX S (DINDEX,DINDEX("START"))=D,DINDEX("WAY")=1
  1. . D INDEX^DICUIX(.DIFILEI,"4l",.DINDEX,"",.DIVAL) Q
  1. X ;from DICM0
  1. I $G(DIFILEI)=""!('$D(DINDEX)#2) K DUOUT,DTOUT N DIFILEI,DIENS,DINDEX,DIASKOK,% N:'$D(DIVAL(0)) DIVAL,DIALLVAL D I DIFILEI="" S Y=-1 D Q^DIC2 Q
  1. . D INIT^DIC0 Q:$D(DIVAL(0))!(DIFILEI="")
  1. . D SETVAL^DIC0 Q
  1. I DIVAL(0),$D(^DD(DIFILEI,.01,7.5)) X ^(7.5) D NODE75^DIC5 I $G(X)="" G:DIC(0)["A" ASK D Q^DIC2 Q
  1. N DIPGM S DIPGM=$S(DIVAL(0)'>1:$$PGM^DIC2(.DIC,$G(DF),DIFILEI),1:"")
  1. I DIPGM]"" D KILL2^DIC0 S DIPGM(0)=2 G @DIPGM
  1. RTN I $G(DIFILEI)=""!('$D(DINDEX)#2) N DIFILEI,DIENS,DINDEX,DIASKOK,% N:'$D(DIVAL(0)) DIVAL,DIALLVAL D I DIFILEI="" S Y=-1 D Q^DIC2 Q
  1. . D INIT^DIC0 Q:$D(DIVAL(0))!(DIFILEI="")
  1. . D SETVAL^DIC0 Q
  1. I X?1."?" D Q:$G(DTOUT) G:DIC(0)["A" ASK Q
  1. . D DSPHLP^DICQ(.DIC,.DIFILEI,.DINDEX,X)
  1. . S Y=-1 Q
  1. I DIVAL(0)=0!($G(DUOUT)) S Y=-1 D Q^DIC2 Q
  1. D:'$D(DO(2)) GETFA^DIC1(.DIC,.DO)
  1. GRV I X?1"`".NP S Y=-1 G DBLGRV:X?1"``".E&(DO(2)["P") D BYIEN1^DIC5 Q:Y>0 I '$$TRYADD^DIC11(.DIC,DIFILEI) D DING G:DIC(0)["A" ASK D Q^DIC2 Q
  1. I DIVAL(0)=1,+$P(X,"E")=X,X>0 S Y=-1 N DISKIPIX D BYIEN2^DIC5 Q:Y>0
  1. I X=" ",$L(DIC)<29,$D(^DISV(DUZ,DIC))#2 S Y=+^(DIC) D SPACEBAR^DIC5 Q:Y>0 D DING G:DIC(0)["A" ASK D Q^DIC2 Q
  1. F ; Start regular lookup
  1. N DD,DS,DIX,DIY,DIYX,DIDONE,DISAVDS,%Y,%H,DISYS
  1. I $G(DIFILEI)=""!('$D(DINDEX)#2) N DIFILEI,DIENS,DINDEX,DIASKOK,% N:'$D(DIVAL(0)) DIVAL,DIALLVAL D
  1. . D INIT^DIC0 Q:$D(DIVAL(0))
  1. . D SETVAL^DIC0 Q
  1. F1 S (DD,DS,DS(0),DS("DD"))=0
  1. D SEARCH^DIC3
  1. I $G(DTOUT)!(Y'<0) D Q^DIC2 Q
  1. I $P(DS(0),U,2)="?",(DIC(0)_$G(DICR(1,0)))'["A" D K,INDEX^DICUIX(.DIFILEI,"4l",.DINDEX,"",.DIVAL) G F1 ;**170
  1. I +DS(0)=2 S X=$P(DS(0),U,2) D K D G A1
  1. . K DIVAL,DIALLVAL S DIVAL(0)=0,Y=-1,DIALLVAL=1
  1. . D CHKVAL^DIC0,CHKVAL2^DIC0(DINDEX("#"),.DIVAL,DIC(0),.DDS)
  1. . Q
  1. D D K I Y<0,DIC(0)["A" D D^DIC0 W:DIC(0)["E" ! K:$D(DIROUT) DIROUT G ASK
  1. . Q:$G(DIROUT)
  1. . I DS(0),$P(DS(0),U,2)="" S:DIC(0)["Y"&($O(Y(0))) Y=0 D DING Q
  1. . Q:'($D(DS)#2)
  1. . I (DS(0)=0!($P(DS(0),U,2)="U")),DS("DD")=DS,(DO(2)["O"!($G(DIASKOK))!(DIC(0)["T")),DO(2)'["A",DO(2)'["P",DO(2)'["V",DO(2)'["D",DO(2)'["S",DIC(0)["L" D L^DICM
  1. . Q
  1. D Q^DIC2 Q
  1. ;
  1. ;
  1. DBLGRV S X=$E(X,2,999) S:'$D(DICR(1)) DICR=0 S %="B",DS=^DD(+DO(2),.01,0) D A^DICM K DO S DO="DUMMY" D P^DICM0 S DIC(0)="U"_DIC(0) D D^DICM I Y>0 G K^DICM ;RECURSIVE LOOKUP ON THE SECOND `
  1. NOGOOD D DING G:DIC(0)["A" ASK D Q^DIC2 Q
  1. ;
  1. ;
  1. K K DD,DS,DIX,DIY,DIYX,DIDONE,DISAVDS
  1. I '$G(DICR),DIC(0)["T" K ^TMP($J,"DICSEEN") S ^TMP($J,"DICSEEN",DIFILEI)=""
  1. Q
  1. ;
  1. DING Q:DIC(0)'["Q"!(DIC(0)'["E")
  1. W:'$D(DUOUT) $C(7)_$S('$D(DDS):" ??",1:"") Q
  1. ;
  1. ;
  1. IX N DINDEX,DF
  1. S (DF,DINDEX,DINDEX("START"))=D
  1. G EN
  1. ;
  1. A K DIY,DIYX,DS I DIC(0)["A" D D^DIC0 Q
  1. NO S Y=-1 D Q^DIC2 Q
  1. ;
  1. ; DBS Entry points
  1. LIST(DIFILE,DIFIEN,DIFIELDS,DIFLAGS,DINUMBER,DIFROM,DIPART,DINDEX,DISCREEN,DIWRITE,DILIST,DIMSGA) ;
  1. ;ENTRY POINT--return a list of entries from a file (SEA/TOAD)
  1. G IN^DICL
  1. ;
  1. FIND1(DIFILE,DIFIEN,DIFLAGS,DIVALUE,DIFORCE,DISCREEN,DIMSGA) ;SEA/TOAD
  1. ;ENTRY POINT--find a single entry in the file
  1. I '$D(DIQUIET) N DIQUIET S DIQUIET=1
  1. I '$D(DIFM) N DIFM S DIFM=1 D INIZE^DIEFU
  1. N DICLERR S DICLERR=$G(DIERR) K DIERR
  1. N DIERN,DIFIND,DIPE,DITARGET
  1. N DIVALS M DIVALS=DIVALUE I $G(DIVALS)="" S DIVALS=$G(DIVALUE(1))
  1. D FIND^DICF($G(DIFILE),$G(DIFIEN),"",$G(DIFLAGS)_"f",.DIVALUE,1,$G(DIFORCE),.DISCREEN,"","DITARGET")
  1. I $D(DIERR) S DIFIND=""
  1. E I $P($G(DITARGET(0)),U,3) K DITARGET S DIFIND="" D
  1. . I $O(DIVALS(1)) N I F I=1:0 S I=$O(DIVALS(I)) Q:'I D:DIVALS(I)]"" Q:'I
  1. . . I ($L(DIVALS)+$L(DIVALS(I)))>100 S DIVALS=DIVALS_"...",I="" Q
  1. . . S DIVALS=DIVALS_$P(", ^",U,DIVALS]"")_DIVALS(I) Q
  1. . D ERR^DICF4(299,$G(DIFILE),$G(DIFIEN),"",DIVALS)
  1. . Q
  1. E S DIFIND=+$G(DITARGET(1))
  1. I DICLERR'=""!$G(DIERR) D
  1. . S DIERR=$G(DIERR)+DICLERR_U_($P($G(DIERR),U,2)+$P(DICLERR,U,2))
  1. I $G(DIMSGA)'="" D CALLOUT^DIEFU(DIMSGA)
  1. Q DIFIND
  1. ;
  1. FIND(DIFILE,DIFIEN,DIFIELDS,DIFLAGS,DIVALUE,DINUMBER,DIFORCE,DISCREEN,DIWRITE,DILIST,DIMSGA) ;SEA/TOAD
  1. ;ENTRY POINT--in a file find entries that match a value
  1. G FINDX^DICF
  1. ;
  1. ; Error messages:
  1. ; 299 More than one entry matches the value(s) '|1|'
  1. ; 120 The previous error occurred when performing
  1. ; 8090 Pre-lookup transform (7.5 node)
  1. ;