| 1 | LRWU5 ;SLC/RWF/BA - ADD A NEW DATA NAME TO FILE 63 ; 5/15/87  22:53 ;
 | 
|---|
| 2 |  ;;5.2;LAB SERVICE;**140,171,177,206,316**;Sep 27, 1994
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ; Reference to ^DD supported by DBIA #29
 | 
|---|
| 5 |  ; Reference to ^XMB(1 supported by DBIA #10091
 | 
|---|
| 6 |  ; Reference to ^XUSEC supported by DBIA #10076
 | 
|---|
| 7 |  ;
 | 
|---|
| 8 | ACCESS ;
 | 
|---|
| 9 |  I '$D(^XUSEC("LRLIASON",DUZ)) W $C(7),!,"You do not have access to this option" Q
 | 
|---|
| 10 | BEGIN ;
 | 
|---|
| 11 |  S U="^",LREND=0,DTIME=$S($D(DTIME):DTIME,1:300) W !!,"This option will add a new data name to the lab package." D DT^LRX,TEST
 | 
|---|
| 12 | END ;
 | 
|---|
| 13 |  K %,DA,DIC,DIK,DIR,I,LRDEC,LREND,LRI,LRLO,LMX,LRMIN,LRNAME,LROK,LRPIECE,LRSET,LRTYPE,LROK1,Q1,Q2,Q3,Q4,Q5,X,Y
 | 
|---|
| 14 |  Q
 | 
|---|
| 15 | TEST ;
 | 
|---|
| 16 |  F I=0:0 S LROK=1,DA=0 R !,"DATA NAME: ",X:DTIME Q:'$T!(X[U)!'$L(X)  S:X["?" X="=" D CHECK Q:LROK!(LREND)
 | 
|---|
| 17 |  Q:LREND=1
 | 
|---|
| 18 |  I 'DA Q:'$T!(X[U)!'$L(X)
 | 
|---|
| 19 |  F I=0:0 R !,"Enter data type for test: (N)umeric, (S)et of Codes, or (F)ree text? ",X:DTIME Q:X[U!(X="")!(X="N")!(X="S")!(X="F")  W !,"Enter 'N', 'S', 'F', or '^'"
 | 
|---|
| 20 |  I X=""!(X[U) Q
 | 
|---|
| 21 |  ;VMP OIFO BAY PINES;VGF;LR*5.2*316; H 5 IF ERROR
 | 
|---|
| 22 |  S Q1=X D @$S(Q1="N":"NUM",Q1="S":"CODES",1:"FREE") I 'LROK W !,"Nothing has been added." H 5 Q
 | 
|---|
| 23 |  S $P(^DD(63.04,0),U,4)=$P(^DD(63.04,0),U,4)+1
 | 
|---|
| 24 |  S DIK="^DD(63.04,",DA(1)=63.04 D IX1^DIK
 | 
|---|
| 25 |  W !!,"'",LRNAME,"' added as a new data name" D DISPLAY^LRWU6 W !!,"You must now add a new test in the LABORATORY TEST file and use",!,LRNAME," as the entry for the DATA NAME field."
 | 
|---|
| 26 |  Q
 | 
|---|
| 27 | CHECK ;
 | 
|---|
| 28 |  X $P(^DD(0,.01,0),U,5) I '$D(X) W $C(7)," ??",!,"ANSWER MUST BE 2-30 CHARACTERS AND NOT CONTAIN '='" S LROK=0 Q
 | 
|---|
| 29 |  S LRNAME=X,DIC="^DD(63.04,",DIC(0)="XM" D ^DIC I Y>0 W $C(7),!,"This data name already exists" S LROK=0 Q
 | 
|---|
| 30 |  S DA=$S($P($G(^XMB(1,1,"XUS")),U,17):$P(^("XUS"),U,17),1:0)*1000 D:'DA SITE Q:'LROK  F I=0:0 S DA=DA+1 Q:'$D(^DD(63.04,DA))
 | 
|---|
| 31 |  F I=0:0 W !,"ARE YOU ADDING ",LRNAME," (SUBFIELD # ",DA,") AS A NEW DATA NAME" S %=2 D YN^DICN Q:%  W " Answer 'Y'es or 'N'o."
 | 
|---|
| 32 |  I %'=1 S LROK=0 Q
 | 
|---|
| 33 |  Q
 | 
|---|
| 34 | SITE ;
 | 
|---|
| 35 |  W !,"Your site number is not defined, indicating that fileman was not ",!,"installed correctly.  Contact your site manager!"
 | 
|---|
| 36 |  S LROK=0,LREND=1 Q
 | 
|---|
| 37 | NUM ;
 | 
|---|
| 38 |  ;
 | 
|---|
| 39 | MIN ;
 | 
|---|
| 40 |  K DTOUT,DUOUT
 | 
|---|
| 41 |  S DIR(0)="F"
 | 
|---|
| 42 |  S DIR("A")="Minimum value: "
 | 
|---|
| 43 |  ;S DIR("B")=1
 | 
|---|
| 44 |  S DIR("?")="The smallest result value: "
 | 
|---|
| 45 |  D ^DIR
 | 
|---|
| 46 |  I $D(DUOUT)!($D(DTOUT)) S LROK=0 QUIT
 | 
|---|
| 47 |  S Q3=Y
 | 
|---|
| 48 | MAX ;
 | 
|---|
| 49 |  K DTOUT,DUOUT
 | 
|---|
| 50 |  S DIR(0)="F"
 | 
|---|
| 51 |  S DIR("A")="Maximum value: "
 | 
|---|
| 52 |  S DIR("B")=1
 | 
|---|
| 53 |  S DIR("?")="The maximum result THIS TEST will ever be: "
 | 
|---|
| 54 |  D ^DIR
 | 
|---|
| 55 |  I $D(DUOUT)!($D(DTOUT))!(Y<0) S LROK=0 QUIT
 | 
|---|
| 56 |  S Q4=Y
 | 
|---|
| 57 | DECIMAL ;
 | 
|---|
| 58 |  K DTDOUT,DUTOU
 | 
|---|
| 59 |  S DIR(0)="F"
 | 
|---|
| 60 |  S DIR("A")="Decimal value: "
 | 
|---|
| 61 |  S DIR("B")=1
 | 
|---|
| 62 |  S DIR("?")="The number of decimal places this result will need: "
 | 
|---|
| 63 |  D ^DIR
 | 
|---|
| 64 |  I $D(DUOUT)!($D(DTOUT))!(Y<0) S LROK=0 QUIT
 | 
|---|
| 65 |  S Q5=Y
 | 
|---|
| 66 |  ;
 | 
|---|
| 67 |  S ^DD(63.04,DA,0)=LRNAME_"^NXJ"_($L(Q4)+Q5+$S(Q5:1,1:0))_","_Q5_"^^"_DA_";1^"_"S Q9="""_Q3_","_Q4_","_Q5_""" D ^LRNUM",^(3)="TYPE A "_$S(Q5:"",1:"WHOLE ")_"NUMBER BETWEEN "_Q3_" AND "_Q4,^("DT")=DT
 | 
|---|
| 68 |  Q
 | 
|---|
| 69 | CODES ;
 | 
|---|
| 70 |  S Q2="",LROK1=1 F I=0:0 R !,"INTERNALLY-STORED CODE: // ",X:DTIME D CHK1 Q:'LROK1  R "   WILL STAND FOR: // ",X:DTIME D CHK2 Q:'LROK1
 | 
|---|
| 71 |  I '$L(Q2) S LROK=0 Q
 | 
|---|
| 72 |  S ^DD(63.04,DA,0)=LRNAME_"^S^"_Q2_"^"_DA_";1^Q",^(3)="",^("DT")=DT
 | 
|---|
| 73 |  Q
 | 
|---|
| 74 | CHK1 I X[U!'$T!'$L(X) S LROK1=0 Q
 | 
|---|
| 75 |  ;VMP OIFO BAY PINES;VGF;LR*5.2*316
 | 
|---|
| 76 |  I X[";"!(X[":") W !,": and ; not allowed ",$C(7) S Q3="",LROK1=0 Q
 | 
|---|
| 77 |  S Q3=X
 | 
|---|
| 78 |  Q
 | 
|---|
| 79 | CHK2 I X[U!'$T!'$L(X) S LROK1=0 Q
 | 
|---|
| 80 |  ;VMP OIFO BAY PINES;VGF;LR*5.2*316
 | 
|---|
| 81 |  I X[";"!(X[":") W !,": and ; not allowed ",$C(7) S Q2="",LROK1=0 Q
 | 
|---|
| 82 |  S Q4=X,Q2=Q2_Q3_":"_Q4_";" I $L(Q2)+$L(LRNAME)+9>245 W !,"Too many codes* ",$C(7) S Q2="",LROK1=0
 | 
|---|
| 83 |  Q
 | 
|---|
| 84 | FREE ;
 | 
|---|
| 85 |  F I=0:0 R !,"Minimum length: ",X:DTIME Q:X[U!'$T!(X'<1&(X'>20)&(+X=X))  W " Enter a whole number from 1 to 20"
 | 
|---|
| 86 |  I X[U!'$T S LROK=0 Q
 | 
|---|
| 87 |  S Q3=X
 | 
|---|
| 88 |  ;---LR*5.2*140 Changed max legnth from 80 to 50
 | 
|---|
| 89 |  F I=0:0 R !,"Maximum length: ",X:DTIME Q:X[U!'$T!(X'<Q3&(X'>50)&(+X=X))  W " Enter a whole number between ",Q3," to 50"
 | 
|---|
| 90 |  I X[U!'$T S LROK=0 Q
 | 
|---|
| 91 |  S Q4=X
 | 
|---|
| 92 |  S ^DD(63.04,DA,0)=LRNAME_"^F^^"_DA_";1^K:$L(X)>"_Q4_"!($L(X)<"_Q3_") X",^(3)="ANSWER MUST BE "_Q3_"-"_Q4_" CHARACTERS IN LENGTH",^("DT")=DT
 | 
|---|
| 93 |  Q
 | 
|---|