MCAROPE ; GENERATED FROM 'MCAROPE' PRINT TEMPLATE (#1003) ; 10/04/96 ; (FILE 699, MARGIN=80)
G BEGIN
N W !
T W:$X ! I '$D(DIOT(2)),DN,$D(IOSL),$S('$D(DIWF):1,$P(DIWF,"B",2):$P(DIWF,"B",2),1:1)+$Y'<IOSL,$D(^UTILITY($J,1))#2,^(1)?1U1P1E.E X ^(1)
S DISTP=DISTP+1,DILCT=DILCT+1 D:'(DISTP#100) CSTP^DIO2
Q
DT I $G(DUZ("LANG"))>1,Y W $$OUT^DIALOGU(Y,"DD") Q
I Y W $P("JAN^FEB^MAR^APR^MAY^JUN^JUL^AUG^SEP^OCT^NOV^DEC",U,$E(Y,4,5))_" " W:Y#100 $J(Y#100\1,2)_"," W Y\10000+1700 W:Y#1 " "_$E(Y_0,9,10)_":"_$E(Y_"000",11,12) Q
W Y Q
M D @DIXX
Q
BEGIN ;
S:'$D(DN) DN=1 S DISTP=$G(DISTP),DILCT=$G(DILCT)
I $D(DXS)<9 F X=0:0 S X=$O(^DIPT(1003,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 X DXS(1,9) K DIP K:DN Y W X
S I(1)=30,J(1)=699.01 F D1=0:0 Q:$O(^MCAR(699,D0,30,D1))'>0 X:$D(DSC(699.01)) DSC(699.01) S D1=$O(^(D1)) Q:D1'>0 D:$X>0 T Q:'DN D A1
G A1R
A1 ;
D T Q:'DN D N D N:$X>2 Q:'DN W ?2 W "LOCATION: "
S X=$G(^MCAR(699,D0,30,D1,0)) W ?14 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(697,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D N:$X>2 Q:'DN W ?2 W "DESCRIPTION: "
D N:$X>16 Q:'DN W ?16 S Y=$P(X,U,3) S Y=$S(Y="":Y,$D(^MCAR(699.55,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,20)
W ?16 X DXS(2,9) K DIP K:DN Y
W ?27 K ZI,ZZ K DIP K:DN Y
D N:$X>2 Q:'DN W ?2 X DXS(3,9.2) S X=$S(DIP(2):DIP(3),DIP(4):X) K DIP K:DN Y W X
S X=$G(^MCAR(699,D0,30,D1,0)) W ?0,$E($P(X,U,4),1,15)
D N:$X>2 Q:'DN W ?2 W "Technique: "
S I(2)=2,J(2)=699.15 F D2=0:0 Q:$O(^MCAR(699,D0,30,D1,2,D2))'>0 X:$D(DSC(699.15)) DSC(699.15) S D2=$O(^(D2)) Q:D2'>0 D:$X>15 T Q:'DN D A2
G A2R
A2 ;
S X=$G(^MCAR(699,D0,30,D1,2,D2,0)) D N:$X>16 Q:'DN W ?16 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(699.6,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,60)
Q
A2R ;
D N:$X>2 Q:'DN W ?2 W "Impression: "
S X=$G(^MCAR(699,D0,30,D1,0)) D N:$X>16 Q:'DN W ?16 S Y=$P(X,U,6) S Y=$S(Y="":Y,$D(^MCAR(697.5,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,50)
Q
A1R ;
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 X DXS(4,9) K DIP K:DN Y W X
D N:$X>2 Q:'DN W ?2 W "Results:"
S I(1)=16,J(1)=699.56 F D1=0:0 Q:$O(^MCAR(699,D0,16,D1))'>0 X:$D(DSC(699.56)) DSC(699.56) S D1=$O(^(D1)) Q:D1'>0 D:$X>12 T Q:'DN D B1
G B1R
B1 ;
S X=$G(^MCAR(699,D0,16,D1,0)) D N:$X>11 Q:'DN W ?11 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(699.81,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,60)
Q
B1R ;
D N:$X>2 Q:'DN W ?2 W "Complications: "
S I(1)=17,J(1)=699.58 F D1=0:0 Q:$O(^MCAR(699,D0,17,D1))'>0 X:$D(DSC(699.58)) DSC(699.58) S D1=$O(^(D1)) Q:D1'>0 D:$X>19 T Q:'DN D C1
G C1R
C1 ;
S X=$G(^MCAR(699,D0,17,D1,0)) D N:$X>17 Q:'DN W ?17 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(696.9,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,40)
W ", "
S Y=$P(X,U,2) W:Y]"" $S($D(DXS(8,Y)):DXS(8,Y),1:Y)
Q
C1R ;
S I(1)=25,J(1)=699.73 F D1=0:0 Q:$O(^MCAR(699,D0,25,D1))'>0 X:$D(DSC(699.73)) DSC(699.73) S D1=$O(^(D1)) Q:D1'>0 D:$X>17 T Q:'DN D D1
G D1R
D1 ;
D N:$X>2 Q:'DN W ?2 W "Disposition: "
S X=$G(^MCAR(699,D0,25,D1,0)) D N:$X>20 Q:'DN W ?20 S Y=$P(X,U,1) W:Y]"" $S($D(DXS(9,Y)):DXS(9,Y),1:Y)
D N:$X>12 Q:'DN W ?12 W "Date: "
D N:$X>20 Q:'DN W ?20 S Y=$P(X,U,2) D DT
D N:$X>12 Q:'DN W ?12 W "Reason: "
D N:$X>20 Q:'DN W ?20,$E($P(X,U,3),1,80)
Q
D1R ;
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 X DXS(5,9) K DIP K:DN Y W X
D N:$X>2 Q:'DN W ?2 W "Primary: "
S X=$G(^MCAR(699,D0,204)) D N:$X>17 Q:'DN W ?17 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(697.5,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,50)
S X=$G(^MCAR(699,D0,205)) D N:$X>17 Q:'DN W ?17,$E($P(X,U,1),1,60)
S I(1)=27,J(1)=699.75 F D1=0:0 Q:$O(^MCAR(699,D0,27,D1))'>0 X:$D(DSC(699.75)) DSC(699.75) S D1=$O(^(D1)) Q:D1'>0 D:$X>79 T Q:'DN D E1
G E1R
E1 ;
D N:$X>2 Q:'DN W ?2 W "Secondary: "
S X=$G(^MCAR(699,D0,27,D1,0)) D N:$X>17 Q:'DN W ?17 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(697.5,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,50)
D N:$X>17 Q:'DN W ?17,$E($P(X,U,2),1,60)
Q
E1R ;
D N:$X>2 Q:'DN W ?2 W "Supplement: "
S I(1)=33,J(1)=699.04 F D1=0:0 Q:$O(^MCAR(699,D0,33,D1))'>0 S D1=$O(^(D1)) D:$X>16 T Q:'DN D F1
G F1R
F1 ;
S X=$G(^MCAR(699,D0,33,D1,0)) S DIWL=18,DIWR=78 D ^DIWP
Q
F1R ;
D A^DIWW
D N:$X>2 Q:'DN W ?2 X DXS(6,9.2) S X=$S(DIP(2):DIP(3),DIP(4):X) K DIP K:DN Y W X
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 X DXS(7,9) K DIP K:DN Y W X
D N:$X>2 Q:'DN W ?2 W "Prescriptions: "
S I(1)=26,J(1)=699.74 F D1=0:0 Q:$O(^MCAR(699,D0,26,D1))'>0 X:$D(DSC(699.74)) DSC(699.74) S D1=$O(^(D1)) Q:D1'>0 D:$X>19 T Q:'DN D G1
G G1R^MCAROPE1
G1 ;
G ^MCAROPE1
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMCAROPE 4579 printed Oct 16, 2024@18:14:15 Page 2
MCAROPE ; GENERATED FROM 'MCAROPE' PRINT TEMPLATE (#1003) ; 10/04/96 ; (FILE 699, MARGIN=80)
+1 GOTO BEGIN
N WRITE !
T if $X
WRITE !
IF '$DATA(DIOT(2))
IF DN
IF $DATA(IOSL)
IF $SELECT('$DATA(DIWF):1,$PIECE(DIWF,"B",2):$PIECE(DIWF,"B",2),1:1)+$Y'<IOSL
IF $DATA(^UTILITY($JOB,1))#2
IF ^(1)?1U1P1E.E
XECUTE ^(1)
+1 SET DISTP=DISTP+1
SET DILCT=DILCT+1
if '(DISTP#100)
DO CSTP^DIO2
+2 QUIT
DT IF $GET(DUZ("LANG"))>1
IF Y
WRITE $$OUT^DIALOGU(Y,"DD")
QUIT
+1 IF Y
WRITE $PIECE("JAN^FEB^MAR^APR^MAY^JUN^JUL^AUG^SEP^OCT^NOV^DEC",U,$EXTRACT(Y,4,5))_" "
if Y#100
WRITE $JUSTIFY(Y#100\1,2)_","
WRITE Y\10000+1700
if Y#1
WRITE " "_$EXTRACT(Y_0,9,10)_":"_$EXTRACT(Y_"000",11,12)
QUIT
+2 WRITE Y
QUIT
M DO @DIXX
+1 QUIT
BEGIN ;
+1 if '$DATA(DN)
SET DN=1
SET DISTP=$GET(DISTP)
SET DILCT=$GET(DILCT)
+2 IF $DATA(DXS)<9
FOR X=0:0
SET X=$ORDER(^DIPT(1003,"DXS",X))
if 'X
QUIT
SET Y=$ORDER(^(X,""))
FOR X=X:0
if Y=""
QUIT
SET DXS(X,Y)=^(Y)
SET Y=$ORDER(^(Y))
+3 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
XECUTE DXS(1,9)
KILL DIP
if DN
KILL Y
WRITE X
+4 SET I(1)=30
SET J(1)=699.01
FOR D1=0:0
if $ORDER(^MCAR(699,D0,30,D1))'>0
QUIT
if $DATA(DSC(699.01))
XECUTE DSC(699.01)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>0
DO T
if 'DN
QUIT
DO A1
+5 GOTO A1R
A1 ;
+1 DO T
if 'DN
QUIT
DO N
if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "LOCATION: "
+2 SET X=$GET(^MCAR(699,D0,30,D1,0))
WRITE ?14
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(697,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+3 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "DESCRIPTION: "
+4 if $X>16
DO N
if 'DN
QUIT
WRITE ?16
SET Y=$PIECE(X,U,3)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(699.55,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,20)
+5 WRITE ?16
XECUTE DXS(2,9)
KILL DIP
if DN
KILL Y
+6 WRITE ?27
KILL ZI,ZZ
KILL DIP
if DN
KILL Y
+7 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
XECUTE DXS(3,9.2)
SET X=$SELECT(DIP(2):DIP(3),DIP(4):X)
KILL DIP
if DN
KILL Y
WRITE X
+8 SET X=$GET(^MCAR(699,D0,30,D1,0))
WRITE ?0,$EXTRACT($PIECE(X,U,4),1,15)
+9 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Technique: "
+10 SET I(2)=2
SET J(2)=699.15
FOR D2=0:0
if $ORDER(^MCAR(699,D0,30,D1,2,D2))'>0
QUIT
if $DATA(DSC(699.15))
XECUTE DSC(699.15)
SET D2=$ORDER(^(D2))
if D2'>0
QUIT
if $X>15
DO T
if 'DN
QUIT
DO A2
+11 GOTO A2R
A2 ;
+1 SET X=$GET(^MCAR(699,D0,30,D1,2,D2,0))
if $X>16
DO N
if 'DN
QUIT
WRITE ?16
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(699.6,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,60)
+2 QUIT
A2R ;
+1 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Impression: "
+2 SET X=$GET(^MCAR(699,D0,30,D1,0))
if $X>16
DO N
if 'DN
QUIT
WRITE ?16
SET Y=$PIECE(X,U,6)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(697.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,50)
+3 QUIT
A1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
XECUTE DXS(4,9)
KILL DIP
if DN
KILL Y
WRITE X
+2 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Results:"
+3 SET I(1)=16
SET J(1)=699.56
FOR D1=0:0
if $ORDER(^MCAR(699,D0,16,D1))'>0
QUIT
if $DATA(DSC(699.56))
XECUTE DSC(699.56)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>12
DO T
if 'DN
QUIT
DO B1
+4 GOTO B1R
B1 ;
+1 SET X=$GET(^MCAR(699,D0,16,D1,0))
if $X>11
DO N
if 'DN
QUIT
WRITE ?11
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(699.81,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,60)
+2 QUIT
B1R ;
+1 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Complications: "
+2 SET I(1)=17
SET J(1)=699.58
FOR D1=0:0
if $ORDER(^MCAR(699,D0,17,D1))'>0
QUIT
if $DATA(DSC(699.58))
XECUTE DSC(699.58)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>19
DO T
if 'DN
QUIT
DO C1
+3 GOTO C1R
C1 ;
+1 SET X=$GET(^MCAR(699,D0,17,D1,0))
if $X>17
DO N
if 'DN
QUIT
WRITE ?17
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(696.9,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,40)
+2 WRITE ", "
+3 SET Y=$PIECE(X,U,2)
if Y]""
WRITE $SELECT($DATA(DXS(8,Y)):DXS(8,Y),1:Y)
+4 QUIT
C1R ;
+1 SET I(1)=25
SET J(1)=699.73
FOR D1=0:0
if $ORDER(^MCAR(699,D0,25,D1))'>0
QUIT
if $DATA(DSC(699.73))
XECUTE DSC(699.73)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>17
DO T
if 'DN
QUIT
DO D1
+2 GOTO D1R
D1 ;
+1 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Disposition: "
+2 SET X=$GET(^MCAR(699,D0,25,D1,0))
if $X>20
DO N
if 'DN
QUIT
WRITE ?20
SET Y=$PIECE(X,U,1)
if Y]""
WRITE $SELECT($DATA(DXS(9,Y)):DXS(9,Y),1:Y)
+3 if $X>12
DO N
if 'DN
QUIT
WRITE ?12
WRITE "Date: "
+4 if $X>20
DO N
if 'DN
QUIT
WRITE ?20
SET Y=$PIECE(X,U,2)
DO DT
+5 if $X>12
DO N
if 'DN
QUIT
WRITE ?12
WRITE "Reason: "
+6 if $X>20
DO N
if 'DN
QUIT
WRITE ?20,$EXTRACT($PIECE(X,U,3),1,80)
+7 QUIT
D1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
XECUTE DXS(5,9)
KILL DIP
if DN
KILL Y
WRITE X
+2 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Primary: "
+3 SET X=$GET(^MCAR(699,D0,204))
if $X>17
DO N
if 'DN
QUIT
WRITE ?17
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(697.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,50)
+4 SET X=$GET(^MCAR(699,D0,205))
if $X>17
DO N
if 'DN
QUIT
WRITE ?17,$EXTRACT($PIECE(X,U,1),1,60)
+5 SET I(1)=27
SET J(1)=699.75
FOR D1=0:0
if $ORDER(^MCAR(699,D0,27,D1))'>0
QUIT
if $DATA(DSC(699.75))
XECUTE DSC(699.75)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>79
DO T
if 'DN
QUIT
DO E1
+6 GOTO E1R
E1 ;
+1 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Secondary: "
+2 SET X=$GET(^MCAR(699,D0,27,D1,0))
if $X>17
DO N
if 'DN
QUIT
WRITE ?17
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(697.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,50)
+3 if $X>17
DO N
if 'DN
QUIT
WRITE ?17,$EXTRACT($PIECE(X,U,2),1,60)
+4 QUIT
E1R ;
+1 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Supplement: "
+2 SET I(1)=33
SET J(1)=699.04
FOR D1=0:0
if $ORDER(^MCAR(699,D0,33,D1))'>0
QUIT
SET D1=$ORDER(^(D1))
if $X>16
DO T
if 'DN
QUIT
DO F1
+3 GOTO F1R
F1 ;
+1 SET X=$GET(^MCAR(699,D0,33,D1,0))
SET DIWL=18
SET DIWR=78
DO ^DIWP
+2 QUIT
F1R ;
+1 DO A^DIWW
+2 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
XECUTE DXS(6,9.2)
SET X=$SELECT(DIP(2):DIP(3),DIP(4):X)
KILL DIP
if DN
KILL Y
WRITE X
+3 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
XECUTE DXS(7,9)
KILL DIP
if DN
KILL Y
WRITE X
+4 if $X>2
DO N
if 'DN
QUIT
WRITE ?2
WRITE "Prescriptions: "
+5 SET I(1)=26
SET J(1)=699.74
FOR D1=0:0
if $ORDER(^MCAR(699,D0,26,D1))'>0
QUIT
if $DATA(DSC(699.74))
XECUTE DSC(699.74)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>19
DO T
if 'DN
QUIT
DO G1
+6 GOTO G1R^MCAROPE1
G1 ;
+1 GOTO ^MCAROPE1