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

DIQGU0.m

Go to the documentation of this file.
  1. DIQGU0 ;SFISC/DCL-DATA RETRIVIAL UTILITY PROGRAM ;02:42 PM 24 Aug 1993
  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. R(%R) ;
  1. N %C,%F,%G,%I,%R1,%R2
  1. S %R1=$P(%R,"(")_"(" I $E(%R1)="^" S %R2=$P($Q(@(%R1_""""")")),"(")_"(" S:$P(%R2,"(")]"" %R1=%R2
  1. S %R2=$P($E(%R,1,($L(%R)-($E(%R,$L(%R))=")"))),"(",2,99)
  1. S %C=$L(%R2,","),%F=1 F %I=1:1:%C S %G=$P(%R2,",",%F,%I) Q:%G="" I ($L(%G,"(")=$L(%G,")")&($L(%G,"""")#2))!(($L(%G,"""")#2)&($E(%G)="""")&($E(%G,$L(%G))="""")) S %G=$$S(%G),$P(%R2,",",%F,%I)=%G,%F=%F+$L(%G,","),%I=%F-1
  1. Q %R1_%R2
  1. S(%Z) ;
  1. I $G(%Z)']"" Q ""
  1. I $E(%Z)'="""",$L(%Z,"E")=2,+$P(%Z,"E")=$P(%Z,"E"),+$P(%Z,"E",2)=$P(%Z,"E",2) Q +%Z
  1. I +%Z=%Z Q %Z
  1. I %Z="""""" Q ""
  1. I $E(%Z)'?1A,"%$+@"'[$E(%Z) Q %Z
  1. I "+$"[$E(%Z) X "S %Z="_%Z Q $$Q(%Z)
  1. I $D(@%Z) Q $$Q(@%Z)
  1. Q %Z
  1. Q(%Z) ;
  1. S %Z(%Z)="",%Z=$Q(%Z("")) Q $E(%Z,4,$L(%Z)-1)
  1. DDLST(DDN,ATRN,FL) ;
  1. N X,Y S:$D(^DD(DDN)) ATRN(DDN)="" S FL=+$G(FL)
  1. D S X=0 F S X=$O(^DD(DDN,"SB",X)) Q:X'>0 S ATRN(X)="" D D DDLST(X,.ATRN,FL)
  1. .I 'FL S Y="" F S Y=$O(^DD(DDN,"B",Y)) Q:Y="" S ATRN(Y,DDN)=$O(^(Y,""))
  1. .Q
  1. Q
  1. DDN(ATN,F) ;
  1. N DNA,DDN,X,Y S X="$$$ NO SUCH ATTRIBUTE $$$"
  1. Q:$G(ATN)']"" X
  1. D DDLST(+$G(F),.DNA,1)
  1. S DDN="" F S DDN=$O(DNA(DDN)) Q:DDN="" D Q:X
  1. .S Y="" F S Y=$O(^DD(DDN,"B",Y)) Q:Y="" I Y=ATN S X=DDN_"^"_$O(^DD(DDN,"B",Y,"")) Q
  1. .Q
  1. I '$G(F),$E(X,1,6)="$$$ NO" Q $$DDN(ATN,1)
  1. Q X
  1. DDLST2(DDN,ATRN,FL) ;
  1. N X,Y S:$D(^DD(DDN)) ATRN(DDN)="" S FL='$D(FL)
  1. S X=0 F S X=$O(^DD(DDN,"SB",X)) Q:X'>0 D
  1. .I FL S ATRN(X)="",Y=0 F S Y=$O(^DD(DDN,Y)) Q:Y'>0 S ATRN(Y,DDN)=$P($G(^(Y,0)),"^")
  1. .D DDLST2(X,.ATRN)
  1. .Q
  1. Q