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

DITP.m

Go to the documentation of this file.
  1. DITP ;SFISC/GFT-TRANSFER POINTERS ;17MAY2005
  1. ;;22.2;VA FileMan;**10**;Jan 05, 2016;Build 11
  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. D ASK Q:%-1 G PTS
  1. ;
  1. ASK ;
  1. I '$D(^UTILITY("DIT",$J,0,1)) S %=2 Q
  1. S %=$O(^(1)),%Y=+^(1) S:%="" %=-1
  1. U I $D(^DD(%Y,0,"UP")) S %Y=^("UP") G U
  1. W !,"SINCE THE "_$P("TRANSFERRED^DELETED",U,DH+1)_" ENTRY MAY HAVE BEEN 'POINTED TO'"
  1. W !,"BY ENTRIES IN THE '"_$P(^DIC(+%Y,0),U,1)_"' FILE," W:%>1 " ETC.,"
  1. Q W !,"DO YOU WANT THOSE POINTERS UPDATED (WHICH COULD TAKE QUITE A WHILE)"
  1. S %=2 D YN^DICN Q:%
  1. W !?4,"ANSWER 'YES' IF YOU THINK THAT THE ENTRY WHICH YOU HAVE JUST "_$P("MOVED^DELETED",U,DH+1),!?4,"MAY BE 'POINTED TO' BY SOME POINTER-TYPE FIELD VALUE SOMEWHERE",!
  1. G Q
  1. ;
  1. ;
  1. ;
  1. ;
  1. EN(DIFILE,DILIST) ;IF THERE ARE POINTERS TO FILE 'DIFILE', GO THRU THE DILIST AND CHANGE THE POINTERS
  1. K ^UTILITY("DIT",$J)
  1. N Y,DIA,DTO,DL
  1. S (DIA("P"),Y)=DIFILE,(DIA,DTO)=$G(^DIC(+DIFILE,0,"GL")) I DTO="" W "ERROR in specification" Q ;,DIA(1)=FROM
  1. D PTS^DIT
  1. S X=0 F Y=0:0 S Y=$O(DILIST(Y)) Q:'Y S %=$P(DILIST(Y),U,2) D I '$D(X) W "ERROR in specification" G END
  1. .I '%,"@"'[% K X Q
  1. .I %,'$D(@(DTO_"%)")) K X Q
  1. .S X=X+1,^UTILITY("DIT",$J,+DILIST(Y))=%_";"_$E(DTO,2,99)
  1. I X D P
  1. END K ^UTILITY("DIT",$J)
  1. Q
  1. ;
  1. PTS ;
  1. D WAIT^DICD K IOP
  1. ;At this point, e.g.^UTILITY("DIT",$J,0,1)=801.41^15^V
  1. ;and ^UTILITY("DIT",$J,38)="103;AUTTIMM(" meaning that pointers to entry 38 in ^AUTTIMM are being moved to 103
  1. P F S X=$O(^UTILITY("DIT",$J,0,0)) Q:X="" S Y=^UTILITY("DIT",$J,0,X),L=$P(Y,U,2) K ^(X) D 1(+Y,L,.DTO) ;KILL NODES AS WE PROCESS THEM
  1. K ^UTILITY("DIT",$J) Q
  1. ;
  1. 1(DIPFILE,DIPFIELD,DTO) ;CALL DIP PRINT MODULE ONCE TO GO THRU CHANGING ONE FIELD'S VALUE. 'DTO' IS ROOT OF FILE BEING POINTED TO.
  1. N DIPVP,DL,L,DHD,DIA,BY,DITPY,DR,D,X,FLDS,DIOBEG,FR,TO,DISTOP,DIOBEG
  1. S (BY,FR,TO)="",DIPVP=$P(^DD(DIPFILE,DIPFIELD,0),U,2)["V" Q:$P(^(0),U,2) ;A MULTIPLE CAN'T POINT
  1. S DL=1,DL(1)=DIPFIELD_"////^D STUFF^DITP("_(DIPVP)_")"
  1. ;S X=$S($D(DE(DQ))[0:"""",$D(^UTILITY(""DIT"",$J,DE(DQ)))-1:"""",^(DE(DQ)):"_$S($P(Y,U,3)'["V":"+",1:"")_"^(DE(DQ)),1:""@"") I X]"""",$G(DIFIXPT)=1 D PTRPT^DITP" K ^(X)
  1. S L=$P(^DD(DIPFILE,DIPFIELD,0),U,4),%=$P(L,";",2),L=""""_$P(L,";",1)_"""",DHD=$P(^(0),U) I % S %="$P(^("_L_"),U,"_%_")"
  1. E S %="$E(^("_L_"),"_+$E(%,2,9)_","_$P(%,",",2)_")"
  1. S L=L_")):"""","_%_"?."" "":"""","
  1. I DIPVP,DTO]"" S L=L_"$P("_%_","";"",2)'="""_$E(DTO,2,99)_""":"""","
  1. S L=L_"'$D(^UTILITY(""DIT"",$J,+"_%_")):"""","
  1. UP S (D(DL),%)=+Y I $D(^DD(%,0,"UP")) S DL=DL+1,Y=^("UP"),(DL(DL),%)=$O(^DD(Y,"SB",%,0))_"///",X(DL)=""""_$P($P(^DD(Y,+%,0),U,4),";")_"""",BY=+%_","_BY G UP
  1. S DHD=$O(^("NM",0))_" entries whose '"_DHD_"' pointers have been changed"
  1. Q:'$D(^DIC(%,0,"GL")) S DIC=^("GL"),DITPY="S X=$S('$D("_DIC_"D0,"
  1. F X=0:1:DL-1 S DR(X+1,D(DL-X))=DL(DL-X) S:X DITPY=DITPY_X(DL+1-X)_",D"_X_","
  1. S DIA("P")=%,%=$L(BY,",") I %>2 S BY=$P(BY,",",%-2)_",.01,"_BY
  1. S DITPY=DITPY_L_"1:D"_X_")",BY=BY_"X DITPY;@"
  1. ;Now DITPY=e.g. S X=$S('$D(^AUPNVIMM(D0,"0")):"",$P(^("0"),U,1)?." ":"",'$D(^UTILITY("DIT",$J,+$P(^("0"),U,1))):"",1:D0)
  1. S L=0,FLDS="",DISTOP=0,DHIT="N DIFIXPT G LOOP^DIA2",%ZIS="",DIOBEG="W !!" ;It will happen in DIA2
  1. I $G(DIQUIET) K DIOBEG S DIFIXPT=1 ;DHD="@@"
  1. D EN1^DIP
  1. IOP S IOP=$S($G(IOS):"`"_IOS,1:$G(IO)) Q ;KEEP THE SAME OUTPUT DEVICE AS WE GO THRU DIFFERENT 'PRINTINGS'
  1. ;
  1. STUFF(VP) ;VP=BOOLEAN
  1. S X="" Q:$G(DE(DQ))=""
  1. N % S %=DE(DQ) Q:'%!'$D(^UTILITY("DIT",$J,+%)) ;^UTILITY("DIT",$J,38)="103;AUTTIMM(" means 'CHANGE OLD 38 TO 103' if we have a variable-pointer to ^AUTTIMM
  1. S X=^(+%) I 'VP S X=+X
  1. E S X=$S($P(X,";",2)'=$P(%,";",2):"",'X:"@",1:X) W:X="" " (no change)" Q
  1. S:'X X="@"
  1. Q
  1. ;
  1. PTRPT Q:'$G(DIFIXPTC) N I,J,X
  1. F I=1:1:DL S J="" F S J=$O(DR(I,J)) Q:J="" I DR(I,J)["///" S X=$P($G(DR(I,J)),"///",1) I X]"" D
  1. . S ^TMP("DIFIXPT",$J,DIFIXPTC)=^TMP("DIFIXPT",$J,DIFIXPTC)_$S(I>1:" entry:"_$S(I=DL:$G(DA),1:$G(DA(DL-I))),1:"")_$S(I=DL:" field:",1:" mult.fld:")_X
  1. . Q
  1. Q