YTAUIR ;ALB/ASF- AUIR DRIVER ;12/20/89 09:35 ;2/21/89 12:33
;;5.01;MENTAL HEALTH;;Dec 30, 1994
;
X ^%ZOSF("NO-TYPE-AHEAD")
I '$D(J) S J=1,YSRP="",B="",YSBEGIN=DT
I $P(^YTT(601,YSTEST,0),U,6)]"" S YSCH=$P(^(0),U,6),Y=$P(^(0),U,7) D DD^%DT S YSCD=Y I $D(^YTT(601.3,YSCH,0)) S YSCHN=YSCH,YSCH=$P(^(0),U) D CR
NX ;
I $P($G(^YTT(601,YSTEST,"Q",J,0)),U,2)]"" S C=$P(^(0),U,2)
S K=$G(^YTT(601,YSTEST,"Q",J,"B")) S:K'="" B=K
MAR ;
I J=209 D MARQ,RD G BK:X="^",^YTAR2:X="*",MAR:X'=1&(X'=2) I X=1 S X="" D ^YTFILE Q
I '$D(^YTT(601,YSTEST,"Q",J,"I",1,0)) G D1
W @IOF F K=1:1 Q:'$D(^YTT(601,YSTEST,"Q",J,"I",K)) W:$D(^(K,0)) !!?3,^(0)
W !!!?3,"PRESS THE SPACE BAR TO CONTINUE."
I2 ;
D RD I X'=" " G:X="*" ^YTAR2 W " ? " G I2
D1 ;
W @IOF F K=1:1 Q:'$D(^YTT(601,YSTEST,"Q",J,"T",K)) W:$D(^(K,0)) !!?3,^(0)
X:B'="" B
D3 ;
S YZT=$P($H,",",2) D RD G HOLD:YZT+1>$P($H,",",2),D4:C[X,BK:X="^",^YTAR2:X="*",WHERE:X="?" W " ? " G D3
D4 S YSRP=YSRP_X D:J#200=0 EN4^YTFILE S J=J+1 I $D(^YTT(601,YSTEST,"Q",J)) G NX
D ^YTFILE Q
RD ;
R *X:900 S:'$T X=42 G:X<32 RD S X=$C(X)
Q
BK ;
G:J=1 D1 S J=J-1,X=$L(YSRP),YSRP=$S(X>1:$E(YSRP,1,X-1),X=1:"",1:$E(^YTD(601.4,YSDFN,1,YSENT,J\200),1,199)) G NX
WHERE ;
W !,YSTESTN," QUESTION # ",J,! X:B]"" B G D3
CR ;
I YSCH="IPAT"!(YSCH="PSYC") S YSTNM=$P($P(^YTT(601,YSTEST,"P"),U),"---",2),YSTNM=$E(YSTNM,1,$L(YSTNM)-1) G IP:YSCH="IPAT",PS:YSCH="PSYC"
W @IOF,!!!?3,^YTT(601.3,YSCHN,1,1,0)," ",YSCD," ",^YTT(601.3,YSCHN,1,2,0) S YSTX=2
NL ;
S YSTX=$O(^YTT(601.3,YSCHN,1,YSTX)) G:'YSTX H5 W !?3,^(YSTX,0) G NL
H5 ;
W !! H 5 K YSCH,YSCHN,YSCD,YSTX Q
IP ;
W @IOF,!!!?3,^YTT(601.3,YSCHN,1,1,0),!?3,^YTT(601.3,YSCHN,1,2,0),YSTNM,",",!?3,^YTT(601.3,YSCHN,1,3,0)," ",YSCD," ",^YTT(601.3,YSCHN,1,4,0),!?3,^YTT(601.3,YSCHN,1,5,0),! H 5 K YSCH,YSCHN,YSCD,YSTX,YSTNM Q
PS W @IOF,!!!?3,^YTT(601.3,YSCHN,1,1,0),YSTNM,!?3,^YTT(601.3,YSCHN,1,2,0)," ",YSCD,!?3,^YTT(601.3,YSCHN,1,3,0)," ",^YTT(601.3,YSCHN,1,4,0) H 5 K YSCH,YSCHN,YSCD,YSTX,YSTNM Q
HOLD ;
W !!,"Please read each question carefully",$C(7) R X:3 K X G D1
MARQ ;
W @IOF,!,"Have you been living in a marriage or marriage-type situation",!,"within the past six months?",!!!?3,"1. No",!!?3,"2. Yes" Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HYTAUIR 2231 printed Nov 22, 2024@17:27:02 Page 2
YTAUIR ;ALB/ASF- AUIR DRIVER ;12/20/89 09:35 ;2/21/89 12:33
+1 ;;5.01;MENTAL HEALTH;;Dec 30, 1994
+2 ;
+3 XECUTE ^%ZOSF("NO-TYPE-AHEAD")
+4 IF '$DATA(J)
SET J=1
SET YSRP=""
SET B=""
SET YSBEGIN=DT
+5 IF $PIECE(^YTT(601,YSTEST,0),U,6)]""
SET YSCH=$PIECE(^(0),U,6)
SET Y=$PIECE(^(0),U,7)
DO DD^%DT
SET YSCD=Y
IF $DATA(^YTT(601.3,YSCH,0))
SET YSCHN=YSCH
SET YSCH=$PIECE(^(0),U)
DO CR
NX ;
+1 IF $PIECE($GET(^YTT(601,YSTEST,"Q",J,0)),U,2)]""
SET C=$PIECE(^(0),U,2)
+2 SET K=$GET(^YTT(601,YSTEST,"Q",J,"B"))
if K'=""
SET B=K
MAR ;
+1 IF J=209
DO MARQ
DO RD
if X="^"
GOTO BK
if X="*"
GOTO ^YTAR2
if X'=1&(X'=2)
GOTO MAR
IF X=1
SET X=""
DO ^YTFILE
QUIT
+2 IF '$DATA(^YTT(601,YSTEST,"Q",J,"I",1,0))
GOTO D1
+3 WRITE @IOF
FOR K=1:1
if '$DATA(^YTT(601,YSTEST,"Q",J,"I",K))
QUIT
if $DATA(^(K,0))
WRITE !!?3,^(0)
+4 WRITE !!!?3,"PRESS THE SPACE BAR TO CONTINUE."
I2 ;
+1 DO RD
IF X'=" "
if X="*"
GOTO ^YTAR2
WRITE " ? "
GOTO I2
D1 ;
+1 WRITE @IOF
FOR K=1:1
if '$DATA(^YTT(601,YSTEST,"Q",J,"T",K))
QUIT
if $DATA(^(K,0))
WRITE !!?3,^(0)
+2 if B'=""
XECUTE B
D3 ;
+1 SET YZT=$PIECE($HOROLOG,",",2)
DO RD
if YZT+1>$PIECE($HOROLOG,",",2)
GOTO HOLD
if C[X
GOTO D4
if X="^"
GOTO BK
if X="*"
GOTO ^YTAR2
if X="?"
GOTO WHERE
WRITE " ? "
GOTO D3
D4 SET YSRP=YSRP_X
if J#200=0
DO EN4^YTFILE
SET J=J+1
IF $DATA(^YTT(601,YSTEST,"Q",J))
GOTO NX
+1 DO ^YTFILE
QUIT
RD ;
+1 READ *X:900
if '$TEST
SET X=42
if X<32
GOTO RD
SET X=$CHAR(X)
+2 QUIT
BK ;
+1 if J=1
GOTO D1
SET J=J-1
SET X=$LENGTH(YSRP)
SET YSRP=$SELECT(X>1:$EXTRACT(YSRP,1,X-1),X=1:"",1:$EXTRACT(^YTD(601.4,YSDFN,1,YSENT,J\200),1,199))
GOTO NX
WHERE ;
+1 WRITE !,YSTESTN," QUESTION # ",J,!
if B]""
XECUTE B
GOTO D3
CR ;
+1 IF YSCH="IPAT"!(YSCH="PSYC")
SET YSTNM=$PIECE($PIECE(^YTT(601,YSTEST,"P"),U),"---",2)
SET YSTNM=$EXTRACT(YSTNM,1,$LENGTH(YSTNM)-1)
if YSCH="IPAT"
GOTO IP
if YSCH="PSYC"
GOTO PS
+2 WRITE @IOF,!!!?3,^YTT(601.3,YSCHN,1,1,0)," ",YSCD," ",^YTT(601.3,YSCHN,1,2,0)
SET YSTX=2
NL ;
+1 SET YSTX=$ORDER(^YTT(601.3,YSCHN,1,YSTX))
if 'YSTX
GOTO H5
WRITE !?3,^(YSTX,0)
GOTO NL
H5 ;
+1 WRITE !!
HANG 5
KILL YSCH,YSCHN,YSCD,YSTX
QUIT
IP ;
+1 WRITE @IOF,!!!?3,^YTT(601.3,YSCHN,1,1,0),!?3,^YTT(601.3,YSCHN,1,2,0),YSTNM,",",!?3,^YTT(601.3,YSCHN,1,3,0)," ",YSCD," ",^YTT(601.3,YSCHN,1,4,0),!?3,^YTT(601.3,YSCHN,1,5,0),!
HANG 5
KILL YSCH,YSCHN,YSCD,YSTX,YSTNM
QUIT
PS WRITE @IOF,!!!?3,^YTT(601.3,YSCHN,1,1,0),YSTNM,!?3,^YTT(601.3,YSCHN,1,2,0)," ",YSCD,!?3,^YTT(601.3,YSCHN,1,3,0)," ",^YTT(601.3,YSCHN,1,4,0)
HANG 5
KILL YSCH,YSCHN,YSCD,YSTX,YSTNM
QUIT
HOLD ;
+1 WRITE !!,"Please read each question carefully",$CHAR(7)
READ X:3
KILL X
GOTO D1
MARQ ;
+1 WRITE @IOF,!,"Have you been living in a marriage or marriage-type situation",!,"within the past six months?",!!!?3,"1. No",!!?3,"2. Yes"
QUIT