File:  [Coherent Logic Development] / freem_fileman / USER / DICE1.m
Revision 1.1: download - view: text, annotated - select for diffs
Mon Apr 28 14:13:19 2025 UTC (5 weeks, 5 days ago) by snw
Branches: MAIN
CVS tags: HEAD
Restructure repository

DICE1	;SFISC/XAK-TRIGGER LOGIC ;5/7/93  1:54 PM
	;;21.0;VA FileMan;;Dec 28, 1994
	;Per VHA Directive 10-93-142, this routine should not be modified.
FIELD	S %=DI,%F=DL,DOLD=$P(^DD(DI,DL,0),U) W !!,"WHEN THE " D WR^DIDH
	R "IS CHANGED,",!,"WHAT FIELD SHOULD BE 'TRIGGERED': ",X:DTIME Q:U[X
	I X?1."?" S DIC="^DD("_DI_",",DIC(0)="QE",DIC("S")="S %=$P(^(0),U,2) I %'[""C""&(%'[""W"")",DIC("W")="W:$P(^(0),U,2) ""   (multiple)""" D ^DIC K DIC G FIELD
	F %=0:0 S %=$F(X," IN ") Q:'%  S X=$E(X,1,%-5)_":"_$E(X,%,999),%=$F(X," FILE") S:% X=$E(X,1,%-6)_$E(X,%,999)
	F %=99:0 S %=$O(I(%)) Q:%=""  K I(%),J(%)
	S %=-1,DCNEW=X,DICOMP="SW?",X="INTERNAL("_$P(X,":",1)_")"_$S($F(X,":"):":",1:"")_$P(X,":",2,99) D DA,DICOMP
	I '$D(X) S X=DCNEW,DICOMP="SW?" D DICOMP
	F %=9.2:.1 Q:'$D(X(%))  S ^UTILITY("DICE",$J,%+80)=X(%)
	I '$D(X)!'DICOMPX W !,"  ...",I,$C(7),!,"YOU MUST IDENTIFY SOME FIELD, EITHER WITHIN THE",!,"'",@("$P("_DIU_"0),U,1)"),"' FILE OR IN SOME OTHER" G FIELD
	S DFLD=X,DENEW=+$P(DICOMPX,U,2),DIN=+DICOMPX,DREF="",DLAY=Y["L"
	K X F X=Y\100*100:-100:0 F %=X:1 Q:'$D(J(%))  G CK:J(%)=DIN
	W $C(7),!,"SORRY, I AM CONFUSED" G FIELD
CK	I DENEW=.001 W $C(7),!,"CAN'T UPDATE A 'NUMBER' FIELD!" G FIELD
	I DENEW=DL,DIN=DI W $C(7),!,"CAN'T HAVE A FIELD TRIGGERING ITSELF!!!" G FIELD
	S DIFILE=J(X),DIAC="DD" D ^DIAC I '% W $C(7),!,"YOU DON'T HAVE 'DATA DEFINITION' ACCESS TO",!,"  THE '",$O(^DD(J(X),0,"NM",0)),"' FILE!" G FIELD
	I $P($G(^DD(J(X),0,"DI")),U,2)["Y" W $C(7),!,"CAN'T TRIGGER A RESTRICTED"_$S($P(^("DI"),U)["Y":" (ARCHIVE)",1:"")_" FILE!" G FIELD
	F X=X:1 S %=X#100,DREF=DREF_I(X)_$E(",",1,%)_"DIV("_%_"),",A=X S:$S('$D(J(%)):1,1:J(%)-J(X))&'$D(DICOMPX(0,J(X))) ^UTILITY("DICE",$J,"DIC")="LOOKUP" Q:J(X)=+DICOMPX!'$D(I(X+1))
	S DLOC=$P(^DD(DIN,DENEW,0),U,4),DSUB=$P(DLOC,";",1),DLOC=$P(DLOC,";",2),DNEW=$P(^(0),U,1) S:+DSUB'=DSUB DSUB=Q_DSUB_Q
	I $P(^(0),U,2)["C" W !,$C(7),"CAN'T TRIGGER A COMPUTED FIELD!" G FIELD
	W "  ...OK" K DIFILE,DIAC Q
	;
DA	S DA="^DD("_DI_","_DL_",1,"_DQ_","_8 Q
	;
DICOMP	;
	S DICOMPX="",DICOMPX(0)="DIV(",DQI="Y(" G ^DICOMP
	;

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