Annotation of freem_fileman/DDSUTL.m, revision 1.1

1.1     ! snw         1: DDSUTL ;SFISC/MKO-PROGRAMMER UTILITIES ;03:36 PM  7 Dec 1994
        !             2:        ;;21.0;VA FileMan;;Dec 28, 1994
        !             3:        ;Per VHA Directive 10-93-142, this routine should not be modified.
        !             4:        ;
        !             5: MSG(TXT)       ;
        !             6:        ;Data validation messages
        !             7:        D PROC(.TXT,$NA(@DDSREFT@("MSG")))
        !             8:        Q
        !             9:        ;
        !            10: HLP(TXT)       ;
        !            11:        ;Help box messages
        !            12:        D PROC(.TXT,$NA(@DDSREFT@("HLP")))
        !            13:        Q
        !            14: PROC(TXT,GLB)  ;
        !            15:        ;Put text into global
        !            16:        N CNT,I
        !            17:        S CNT=$G(@GLB)
        !            18:        I $D(TXT)<9 S CNT=CNT+1,@GLB@(CNT)=TXT
        !            19:        E  S I="" F CNT=CNT:1 S I=$O(TXT(I)) Q:I=""  S @GLB@(CNT+1)=TXT(I)
        !            20:        S @GLB=CNT
        !            21:        Q
        !            22:        ;
        !            23: REFRESH        ;Refresh the screen
        !            24:        G R^DDSR
        !            25:        ;
        !            26: MLOAD(DDSIEN)  ;Load subrecords for current multiple
        !            27:        G MLOAD^DDSM1
        !            28:        ;
        !            29: MDEL(DDSIEN)   ;Delete subrecords for current multiple
        !            30:        G MDEL^DDSM1
        !            31:        ;
        !            32: UNED(DDSF,DDSB,DDSP,DDSVAL,DDSUDA)     ;Change DISABLE EDITING attribute
        !            33:        S:$D(DDSVAL)[0 DDSVAL=""
        !            34:        D SETATT(4)
        !            35:        Q
        !            36:        ;
        !            37: REQ(DDSF,DDSB,DDSP,DDSVAL,DDSUDA)      ;Change REQUIRED attribute
        !            38:        S:$D(DDSVAL)[0 DDSVAL=""
        !            39:        D SETATT(1)
        !            40:        Q
        !            41:        ;
        !            42:        ;
        !            43: SETATT(DDSUPC) ;Set attribute node, piece DDSUPC
        !            44:        N DDSOVAL,DDSUDDP,DDSUFLD,DDSUTP
        !            45:        I $D(DDSPG)[0 N DDSPG S DDSPG=""
        !            46:        I $D(DDSBK)[0 N DDSBK S DDSBK=""
        !            47:        S DDSP=$$GETFLD^DDSLIB(DDSF,$G(DDSB),$G(DDSP),+DDS,DDSPG,DDSBK)
        !            48:        I $G(DIERR) D ERR^DDSMSG Q
        !            49:        ;
        !            50:        S DDSF=$P(DDSP,","),DDSB=$P(DDSP,",",2),DDSP=$P(DDSP,",",3)
        !            51:        ;
        !            52:        S DDSUDDP=+$P($G(^DIST(.404,DDSB,0)),U,2)
        !            53:        I DDSUDDP,$G(DDSUDA)]"" N DDSDA S DDSDA=DDSUDA
        !            54:        E  I DDSUDDP,DDSB'=DDSBK N DDSDA D GL^DDS10(DDSUDDP,.DDSDAORG,"","",.DDSDA)
        !            55:        ;
        !            56:        S DDSUTP=$P($G(^DIST(.404,DDSB,40,DDSF,0)),U,3)
        !            57:        I DDSUTP=2 D
        !            58:        . S DDSUFLD=DDSF_","_DDSB
        !            59:        . S DDSUDDP=0
        !            60:        E  I DDSUTP=3 D  Q:'DDSUFLD
        !            61:        . S DDSUFLD=$P($G(^DIST(.404,DDSB,40,DDSF,1)),U)
        !            62:        E  Q
        !            63:        ;
        !            64:        S DDSOVAL=$P($G(@DDSREFT@("F"_DDSUDDP,DDSDA,DDSUFLD,"A")),U,DDSUPC)
        !            65:        Q:DDSVAL=DDSOVAL
        !            66:        S $P(@DDSREFT@("F"_DDSUDDP,DDSDA,DDSUFLD,"A"),U,DDSUPC)=DDSVAL
        !            67:        Q
        !            68:        ;
        !            69: ADD(DDSFIL,X,DA,DINUM,DDSDIC0,DDSDR,DDSL)      ;
        !            70:        ;Add an entry as part of a transaction
        !            71:        ;DDSL=1 means don't lock
        !            72:        ;
        !            73:        N %,%W,%Y,C,D0,DD,DO,DI,DIC,DIE,DQ,DR
        !            74:        N DDSDA,DDSDIC,DDSFD,DDSREQ,DDSUP,I
        !            75:        K DIERR,^TMP("DIERR",$J)
        !            76:        K:'$G(DINUM) DINUM
        !            77:        S:$G(DDSDIC0)="" DDSDIC0="L"
        !            78:        S DIC(0)=DDSDIC0,Y=-1
        !            79:        S:$G(DDSDR)]"" DIC("DR")=DDSDR
        !            80:        S DIC=$$ROOT^DILFD(DDSFIL,.DA),DDSDIC=$$CREF^DIQGU(DIC)
        !            81:        ;
        !            82:        I $D(@DDSDIC@(0))[0 D  Q:$G(DIC("P"))=""
        !            83:        . S DDSUP=$G(^DD(DDSFIL,0,"UP")) Q:'DDSUP
        !            84:        . S DDSFD=$O(^DD(DDSUP,"SB",DDSFIL,"")) Q:'DDSFD
        !            85:        . S DIC("P")=$P($G(^DD(DDSUP,DDSFD,0)),U,2)
        !            86:        ;
        !            87:        I DDSDIC0'["E",$$REQID(DDSFIL,.DDSREQ) D  Q:$G(DIERR)
        !            88:        . N F
        !            89:        . S F=""
        !            90:        . F  S F=$O(DDSREQ(F)) Q:'F  I $G(DIC("DR"))'[(F_"///") D BLD^DIALOG(3031,"ADD^DDSUTL") Q
        !            91:        ;
        !            92:        D FILE^DICN K DTOUT,DUOUT Q:Y=-1!'$D(DDS)
        !            93:        ;
        !            94:        I '$G(DDSL) D
        !            95:        . N I,L,R
        !            96:        . S L=1,R=DIC_DA_","
        !            97:        . F I=$L(R,",")-1:-1:1 I $D(^TMP("DDS",$J,"LOCK",$P(R,",",1,I)_")"))#2 S L=0 Q
        !            98:        . I L,$D(^TMP("DDS",$J,"LOCK",$P(R,"(")))#2 S L=0
        !            99:        . I L L +@(DIC_+Y_")"):0 S ^TMP("DDS",$J,"LOCK",DIC_+Y_")")=""
        !           100:        ;
        !           101:        S DDSDA=+Y_","
        !           102:        F I=1:1 Q:$D(DA(I))[0  S DDSDA=DDSDA_DA(I)_","
        !           103:        S ^("ADD")=$G(@DDSREFT@("ADD"))+1,^("ADD",^("ADD"))=DDSDA_DIC
        !           104:        Q
        !           105:        ;
        !           106: REQID(FIL,REQ) ;
        !           107:        ;Get list of required identifiers into DDSREQ
        !           108:        N F
        !           109:        K REQ
        !           110:        S F="" F  S F=$O(^DD(FIL,0,"ID",F)) Q:F'=+$P(F,"E")  D
        !           111:        . S:$P($G(^DD(FIL,F,0)),U,2)["R" REQ(F)=""
        !           112:        Q $D(REQ)>0
        !           113:        ;
        !           114: DDSDA(DA,DL,DDSDA)     ;Determine DDSDA
        !           115:        ;
        !           116:        N I
        !           117:        I DA="" S DDSDA="" Q
        !           118:        S DDSDA=DA_"," F I=1:1:DL S DDSDA=DDSDA_DA(I)_","
        !           119:        Q

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>