source: WorldVistAEHR/trunk/r/ORDER_ENTRY_RESULTS_REPORTING-OR-OCX--ORRC--ORRJ/OCXSEND6.m@ 1604

Last change on this file since 1604 was 623, checked in by George Lilly, 15 years ago

revised back to 6/30/08 version

File size: 5.4 KB
Line 
1OCXSEND6 ;SLC/RJS,CLA - BUILD RULE TRANSPORTER ROUTINES (Build Library Routine 2) ;2/01/01 10:03
2 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,76,74,96,105**;Dec 17,1997
3 ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
4 ;
5EN() ;
6 ;
7 N R,LINE,TEXT,NOW,RUCI,XCM
8 S NOW=$$NOW^OCXSEND3,RUCI=$$NETNAME^OCXSEND
9 F LINE=1:1:999 S TEXT=$P($T(TEXT+LINE),";",2,999) Q:TEXT S TEXT=$P(TEXT,";",2,999) S R(LINE,0)=$$CONV^OCXSEND3(TEXT)
10 ;
11 M ^TMP("OCXSEND",$J,"RTN")=R
12 ;
13 S DIE="^TMP(""OCXSEND"","_$J_",""RTN"",",XCN=0,X=$$RNAME^OCXSEND3(2,1)
14 W !,X X ^%ZOSF("SAVE") W " ... ",XCM," Lines filed" K ^TMP("OCXSEND",$J,"RTN")
15 ;
16 Q XCM
17 ;
18TEXT ;
19 ;;|$$RNAME^OCXSEND3(2,1)| ;SLC/RJS,CLA - OCX PACKAGE RULE TRANSPORT ROUTINE |OCXPATCH| ;|NOW|
20 ;;|OCXLIN2|
21 ;;|OCXLIN3|
22 ;; ;
23 ;;S ;
24 ;; ; Record Utilities
25 ;; Q
26 ;; ;
27 ;;ADDREC(OCXCREF) ;
28 ;; ;
29 ;; N QUIT,OCXDD,OCXDA,OCXGREF,OCXNAME
30 ;; S OCXDD=$O(@OCXCREF@("")) Q:'OCXDD 0
31 ;; S OCXNAME=$G(@OCXCREF@(OCXDD,.01,"E"))
32 ;; ;
33 ;; W " record missing..."
34 ;; I (OCXFLAG["D") Q 0
35 ;; ;
36 ;; S OCXDA=0 D CREATE(OCXCREF,OCXDD,.OCXDA,0)
37 ;; S:$L(OCXNAME) ^TMP("OCXRULE",$J,"A",+OCXDD,OCXNAME)=""
38 ;; ;
39 ;; Q 0
40 ;; ;
41 ;;CREATE(OCXCREF,OCXDD,OCXDA,OCXLVL) ;
42 ;; ;
43 ;; N OCXFLD,OCXGREF,OCXKEY
44 ;; ;
45 ;; I $L(OCXDA),'(OCXDA=+OCXDA) W !!,"Unresolved subscript." Q
46 ;; ;
47 ;; S OCXKEY=@OCXCREF@(OCXDD,.01,"E")
48 ;; S OCXGREF=$$GETREF(+OCXDD,.OCXDA,OCXLVL) Q:'$L(OCXGREF)
49 ;; I 'OCXDA D
50 ;; .S OCXDA=$O(^TMP("OCXRULE",$J,"B",+OCXDD,OCXKEY,0)) Q:OCXDA
51 ;; .S OCXDA=$O(@(OCXGREF_""" "")"),-1)+1
52 ;; .F OCXDA=OCXDA:1 Q:'$D(@(OCXGREF_OCXDA_",0)"))
53 ;; .I $D(@(OCXGREF_OCXDA_",0)")) S OCXDA=0
54 ;; ;
55 ;; I 'OCXDA W !!,"Error adding record..." Q
56 ;; ;
57 ;; I '$D(@(OCXGREF_"0)")) S @(OCXGREF_"0)")=U_$$FILEHDR^OCXSENDD(+OCXDD)_U_U
58 ;; ;
59 ;; S OCXFLD=0 F S OCXFLD=$O(@OCXCREF@(OCXDD,OCXFLD)) Q:'OCXFLD Q:(OCXFLD[":") I '$$EXFLD^|$$RNAME^OCXSEND3(1,1)|(+OCXDD,OCXFLD) D
60 ;; .I $L($G(@OCXCREF@(OCXDD,OCXFLD,"E"))) D DIE(OCXDD,OCXGREF,OCXFLD,@OCXCREF@(OCXDD,OCXFLD,"E"),.OCXDA,OCXLVL)
61 ;; .I $O(@OCXCREF@(OCXDD,OCXFLD,0)) D WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,OCXCREF)
62 ;; ;
63 ;; D PUSH(.OCXDA)
64 ;; S OCXFLD="" F S OCXFLD=$O(@OCXCREF@(OCXDD,OCXFLD)) Q:'$L(OCXFLD) I (OCXFLD[":") D
65 ;; .S OCXDA=$P(OCXFLD,":",2) W ! D CREATE($$APPEND(OCXCREF,OCXDD),OCXFLD,.OCXDA,OCXLVL+1)
66 ;; D POP(.OCXDA)
67 ;; Q
68 ;; ;
69 ;;LOADWORD(RREF,OCXDD,OCXFLD,OCXSUB) ;
70 ;; ;
71 ;; N QUIT,DDPATH,INDEX,OCXDA,OCXGREF
72 ;; S DDPATH=$P($P($$APPEND(RREF,OCXDD),"(",2),")",1)
73 ;; F INDEX=1:1:$L(DDPATH,",") S OCXDA($L(DDPATH,",")-INDEX)=+$P($P(DDPATH,",",INDEX),":",2)
74 ;; S OCXDA=$G(OCXDA(0)) K OCXDA(0)
75 ;; Q:(OCXFLAG["D") 0
76 ;; I (OCXFLAG["A") S QUIT=$$READ("Y"," Do you want to reload the local '"_$$FIELD^OCXSENDD(+OCXDD,+OCXFLD,"LABEL")_"' field ?","YES") Q:'QUIT (QUIT[U)
77 ;; S OCXGREF=$$GETREF(+OCXDD,.OCXDA,$L(DDPATH,",")-1) Q:'$L(OCXGREF)
78 ;; D WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,RREF)
79 ;; Q 0
80 ;; ;
81 ;;GETREF(OCXDD,OCXDA,OCXLVL) ;
82 ;; ;
83 ;; Q:'OCXDD ""
84 ;; ;
85 ;; N OCXIENS,OCXERR,OCXX
86 ;; S OCXIENS=$$IENS^DILF(.OCXDA),OCXERR=""
87 ;; S OCXX=$$ROOT^DILFD(OCXDD,OCXIENS,0,OCXERR)
88 ;; Q OCXX
89 ;; ;
90 ;;WORD(DD,GREF,FLD,DA,RREF) ;
91 ;; ;
92 ;; N SUB,GLROOT,LINE
93 ;; S SUB=$P($$FIELD^OCXSENDD(+DD,FLD,"GLOBAL SUBSCRIPT LOCATION"),";",1) S:'(SUB=+SUB) SUB=""""_SUB_""""
94 ;; S GLROOT=GREF_DA_","_SUB_")" K @GLROOT
95 ;; S LINE=0 F S LINE=$O(@RREF@(DD,FLD,LINE)) Q:'LINE D
96 ;; .S @GLROOT@($O(@GLROOT@(""),-1)+1,0)=@RREF@(DD,FLD,LINE)
97 ;; S LINE=$O(@GLROOT@(""),-1),@GLROOT@(0)=U_U_LINE_U_LINE_U_$$DATE("T")_U
98 ;; ;
99 ;; Q
100 ;; ;
101 ;;DATE(X) N %DT,Y S %DT="" D ^%DT Q +Y
102 ;; ;
103 ;;DIE(OCXDD,OCXDIC,OCXFLD,OCXVAL,OCXDA,OCXLVL) ;
104 ;; ;
105 ;; N DIC,DIE,X,Y,DR,DA,OCXDVAL,OCXPTR,OCXGREF,D0,OCXSCR
106 ;; S (D0,DA)=OCXDA,(DIC,DIE)=OCXDIC,DR=""
107 ;; S:OCXLVL D0=OCXDA(1),DR="S DA(1)="_(+D0)_",D0="_(+D0)_";"
108 ;; S:OCXVAL="?" OCXVAL="? " S DR=DR_OCXFLD_"///^S X=OCXVAL"
109 ;; I '(OCXVAL="@") W !,?(OCXLVL*5),$$FIELD^OCXSENDD(+OCXDD,OCXFLD,"LABEL"),": ",OCXVAL
110 ;; ;
111 ;; I '(OCXVAL="@") D
112 ;; .N OCXIEN,SHORT
113 ;; .S OCXPTR=+$P($$FIELD^OCXSENDD(+OCXDD,OCXFLD,"SPECIFIER"),"P",2)
114 ;; .Q:'OCXPTR
115 ;; .S OCXGREF="^"_$$FIELD^OCXSENDD(+OCXDD,OCXFLD,"POINTER")
116 ;; .I '($E(OCXGREF,1,4)="^OCX"),'(OCXGREF="^ORD(100.9,"),'(OCXGREF="^ORD(100.8,") Q
117 ;; .Q:$$DIC(OCXGREF,OCXVAL,0)
118 ;; .S OCXIEN=$$DIC(OCXGREF,OCXVAL,1)
119 ;; .S ^TMP("OCXRULE",$J,"B",OCXPTR,OCXVAL,OCXIEN)=""
120 ;; ;
121 ;; S OCXSCR=1
122 ;; D ^DIE
123 ;; ;
124 ;; ; I $D(Y) -> DIE FILER ERROR
125 ;; I $D(Y) W " ^DIE filer data error..." S OCXDIER=$G(OCXDIER)+1
126 ;; I '$D(Y) W " ...Correct data Filed"
127 ;; ;
128 ;; Q
129 ;; ;
130 ;;DIC(DIC,X,OCXADD) N OCXSCR S DIC(0)="",OCXSCR=1 S:OCXADD DIC(0)="L" D ^DIC Q:(+Y>0) +Y Q 0
131 ;; ;
132 ;;PUSH(OCXDA) ;
133 ;; N OCXSUB S OCXSUB="" F S OCXSUB=$O(OCXDA(OCXSUB),-1) Q:'OCXSUB S OCXDA(OCXSUB+1)=OCXDA(OCXSUB)
134 ;; S OCXDA(1)=OCXDA,OCXDA=0
135 ;; Q
136 ;; ;
137 ;;POP(OCXDA) ;
138 ;; N OCXSUB S OCXSUB="" F S OCXSUB=$O(OCXDA(OCXSUB)) Q:'OCXSUB S OCXDA(OCXSUB)=$G(OCXDA(OCXSUB+1))
139 ;; S OCXDA=OCXDA(1) K OCXDA($O(OCXDA(""),-1))
140 ;; Q
141 ;; ;
142 ;;APPEND(ARRAY,OCXSUB) ;
143 ;; S:'(OCXSUB=+OCXSUB) OCXSUB=""""_OCXSUB_""""
144 ;; Q:'(ARRAY["(") ARRAY_"("_OCXSUB_")"
145 ;; Q $E(ARRAY,1,$L(ARRAY)-1)_","_OCXSUB_")"
146 ;; ;
147 ;;READ(OCXZ0,OCXZA,OCXZB,OCXZL) ;
148 ;; N OCXLINE,DIR,DTOUT,DUOUT,DIRUT,DIROUT
149 ;; Q:'$L($G(OCXZ0)) U
150 ;; S DIR(0)=OCXZ0
151 ;; S:$L($G(OCXZA)) DIR("A")=OCXZA
152 ;; S:$L($G(OCXZB)) DIR("B")=OCXZB
153 ;; F OCXLINE=1:1:($G(OCXZL)-1) W !
154 ;; D ^DIR
155 ;; I $D(DTOUT)!$D(DUOUT)!$D(DIRUT)!$D(DIROUT) Q U
156 ;; Q Y
157 ;; ;
158 ;;PAUSE() W " Press Enter " R X:DTIME W ! Q (X[U)
159 ;; ;
160 ;;$
161 ;1;
162 ;
Note: See TracBrowser for help on using the repository browser.