| [641] | 1 | XBFORM0 ; IHS/ADC/GTH - Documentation for XBFORM ;   [ 02/07/97   3:02 PM ] | 
|---|
|  | 2 | ;;4.0;XB;;Jul 20, 2009;Build 2 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | ; This utility provides a word processing format of free | 
|---|
|  | 5 | ; text and local variable references to build an array. | 
|---|
|  | 6 | ; | 
|---|
|  | 7 | ; A file is necessary that has a .01 field for the form name | 
|---|
|  | 8 | ; and a WP field to hold the WP form. | 
|---|
|  | 9 | ; | 
|---|
|  | 10 | ; Two Entry points | 
|---|
|  | 11 | ; | 
|---|
|  | 12 | ; EDIT^XBFORM(NAME,DIC,FIELD)  Edits and Displays the form. | 
|---|
|  | 13 | ;    Place the call to EDIT in the code where the data or | 
|---|
|  | 14 | ;    variables have been gathered. Typically this is one line | 
|---|
|  | 15 | ;    previous to the call to $$GEN^XBFORM. Once the form is | 
|---|
|  | 16 | ;    designed the EDIT call is commented out. | 
|---|
|  | 17 | ; | 
|---|
|  | 18 | ; $$GEN^XBFORM(NAME,DIC,FIELD,%Y,FORMAT,OFFSET) | 
|---|
|  | 19 | ;    Generates the form into the root array indicated by %Y. | 
|---|
|  | 20 | ;    The call to $$GEN must have all variables used gathered. | 
|---|
|  | 21 | ;    The return value of $$GEN is equal to the last line set | 
|---|
|  | 22 | ;    in the array. | 
|---|
|  | 23 | ; | 
|---|
|  | 24 | ; INPUT VARIABLES | 
|---|
|  | 25 | ;    NAME   The name space variable that holds the name of | 
|---|
|  | 26 | ;           the form to be used. | 
|---|
|  | 27 | ; | 
|---|
|  | 28 | ;    DIC    The root or file number of the file holding the | 
|---|
|  | 29 | ;           forms. | 
|---|
|  | 30 | ; | 
|---|
|  | 31 | ;    FIELD  The field number of the WP field holding the form. | 
|---|
|  | 32 | ; | 
|---|
|  | 33 | ;    %Y     The root of the target array to be built.  Either | 
|---|
|  | 34 | ;           a global or a variable root as in the format used | 
|---|
|  | 35 | ;           for a %XY^%RCR call. (%RCR is actually used) | 
|---|
|  | 36 | ; | 
|---|
|  | 37 | ;    FORMAT null or zero  The array is built %Y(line)="... | 
|---|
|  | 38 | ;           1             The array is built %Y(line,0)=".... | 
|---|
|  | 39 | ; | 
|---|
|  | 40 | ;    OFFSET The offset in line numbers in building the array. | 
|---|
|  | 41 | ;           The array will start construction at OFFSET+1. | 
|---|
|  | 42 | ;           The value of the last line created is returned | 
|---|
|  | 43 | ;           $$GEN. | 
|---|
|  | 44 | ; | 
|---|
|  | 45 | ; WP FORMAT INSTRUCTIONS | 
|---|
|  | 46 | ; | 
|---|
|  | 47 | ;    Free Text:  Free text is key striked in where desired. | 
|---|
|  | 48 | ;                Do not use | as it is used to mark variables. | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | ;    Variables:  The reference to a variable is marked with | 
|---|
|  | 51 | ;                a beginning | and a trailing |. The trailing | 
|---|
|  | 52 | ;                | is always required even if the variable is | 
|---|
|  | 53 | ;                last item on the line. | 
|---|
|  | 54 | ; | 
|---|
|  | 55 | ;                To use a "|" in your display use "||" in the | 
|---|
|  | 56 | ;                form. | 
|---|
|  | 57 | ; | 
|---|
|  | 58 | ;    Mnemonics Comments - A short hand for variables is | 
|---|
|  | 59 | ;       available.  Programmers comments can be put into the | 
|---|
|  | 60 | ;       form which are ignored by the generator. | 
|---|
|  | 61 | ; | 
|---|
|  | 62 | ;    Output Transform - Mumps output transforms can be | 
|---|
|  | 63 | ;       indicated for execution upon selected variables. | 
|---|
|  | 64 | ; | 
|---|
|  | 65 | ; WP SPECIAL FUNCTIONS  Located at the top of the form. | 
|---|
|  | 66 | ; | 
|---|
|  | 67 | ; Comment line          Begin the line with a ';' | 
|---|
|  | 68 | ; | 
|---|
|  | 69 | ; Variable Mneumonic - Reference Name spaced variables can | 
|---|
|  | 70 | ;       be long. A mnemonic reference is available to make | 
|---|
|  | 71 | ;       life simple.  Multiple mnemonic lines can be used | 
|---|
|  | 72 | ;       if desired. | 
|---|
|  | 73 | ; | 
|---|
|  | 74 | ; | 
|---|
|  | 75 | ;     SETUP | 
|---|
|  | 76 | ; | 
|---|
|  | 77 | ;     #mneum1=variable1|mneum2=variable2*... | 
|---|
|  | 78 | ;     #mneumZ=variableZ|..... | 
|---|
|  | 79 | ; | 
|---|
|  | 80 | ;     Example: | 
|---|
|  | 81 | ;                  #D=DUZ | V =BARVPT | 
|---|
|  | 82 | ;                  #I=BARIPT | 
|---|
|  | 83 | ; | 
|---|
|  | 84 | ;         (BARIPT array is storing IHS Patient Information) | 
|---|
|  | 85 | ;         (BARVPT array is storing  VA Patient Information) | 
|---|
|  | 86 | ; | 
|---|
|  | 87 | ; | 
|---|
|  | 88 | ;           '#'         Marker placed in the first column | 
|---|
|  | 89 | ; | 
|---|
|  | 90 | ;           mnemonic1  User's choice | 
|---|
|  | 91 | ;                       ex: D to denote DUZ | 
|---|
|  | 92 | ;           '='         EQUALS | 
|---|
|  | 93 | ; | 
|---|
|  | 94 | ;           variable1   User's choice of the local variable | 
|---|
|  | 95 | ;                       ex: DUZ | 
|---|
|  | 96 | ;           '|'         Repeat seperator if more than one | 
|---|
|  | 97 | ;                       mnemonic is indicated on a line | 
|---|
|  | 98 | ; | 
|---|
|  | 99 | ;     USE               The mnemonic reference can be used | 
|---|
|  | 100 | ;                       any where in the WP form. | 
|---|
|  | 101 | ;          Format       ~mnemonic|variable subscript~ | 
|---|
|  | 102 | ; | 
|---|
|  | 103 | ;           '|'         Beginning marker for the variable | 
|---|
|  | 104 | ; | 
|---|
|  | 105 | ;           mnemonic1  User's mnemonic | 
|---|
|  | 106 | ; | 
|---|
|  | 107 | ;           '@'         Mneumonic dubstitution marker | 
|---|
|  | 108 | ; | 
|---|
|  | 109 | ;           subscript   The subscript of the variable to be | 
|---|
|  | 110 | ;                       used. | 
|---|
|  | 111 | ; | 
|---|
|  | 112 | ;           '|'         Ending marker for the variable | 
|---|
|  | 113 | ; | 
|---|
|  | 114 | ;                       ex:  |D@|      for DUZ | 
|---|
|  | 115 | ;                            |D@0|     for DUZ(0) | 
|---|
|  | 116 | ;                            |I@.01|   for BARIPT(.01) | 
|---|
|  | 117 | ; | 
|---|
|  | 118 | ;  MUMPS OUTPUT TRANSFORM  -  A simple mumps output | 
|---|
|  | 119 | ;     transform is also provided to aid in form design. A | 
|---|
|  | 120 | ;     variable or mnemonic indicated will have its output | 
|---|
|  | 121 | ;     transformed prior to being put into the form. | 
|---|
|  | 122 | ; | 
|---|
|  | 123 | ;    SETUP | 
|---|
|  | 124 | ; | 
|---|
|  | 125 | ;      *var1:mumps code1|var2:mumps code2 | 
|---|
|  | 126 | ;      *mnemonic3:mumps code3|mnemonic4:mumps code4 | 
|---|
|  | 127 | ; | 
|---|
|  | 128 | ; Ex:      *DUZ(2):$J(X,10,2)  will output $J(DUZ(2),10,2) | 
|---|
|  | 129 | ;          *D@2! :$J(X,10,2)     mnemonic notation of same | 
|---|
|  | 130 | ; | 
|---|
|  | 131 | ; '*'          Output Transform marker in column one. Near TOF | 
|---|
|  | 132 | ; | 
|---|
|  | 133 | ; Variable/    Variable or mnemonic as it would appear in the | 
|---|
|  | 134 | ; Mneumonic    form between '~'s. | 
|---|
|  | 135 | ; | 
|---|
|  | 136 | ; ':'          Separator | 
|---|
|  | 137 | ; | 
|---|
|  | 138 | ; mumps code   Mumps code expression as a function of x. | 
|---|
|  | 139 | ;              Do not state 'S X=f(x)' | 
|---|
|  | 140 | ;              Enter the function only, f(x). | 
|---|
|  | 141 | ; | 
|---|
|  | 142 | ; '|'          Repeat Separator if more than one is put | 
|---|
|  | 143 | ;              on one line. | 
|---|
|  | 144 | ; | 
|---|
|  | 145 | ; SPECIAL OUTPUT TRANSFORMS provided by XBFORM | 
|---|
|  | 146 | ; | 
|---|
|  | 147 | ; $$MDY(X) | 
|---|
|  | 148 | ; *xxx:$$MDY(X)    a literal |"NOW"| or    variable |IT@9| | 
|---|
|  | 149 | ;      ex:         *"NOW":$$MDY(X)   or    *IT@9:$$MDY(X) | 
|---|
|  | 150 | ;                  returns mm/dd/yy | 
|---|
|  | 151 | ; | 
|---|
|  | 152 | ; $$WP("X") | 
|---|
|  | 153 | ; *xxx:$$WP("X")   for a word processing field array |xxx| | 
|---|
|  | 154 | ; | 
|---|
|  | 155 | ;      NOTE: "X"   IS ABSOLUTELY NECESSARY | 
|---|
|  | 156 | ;            The variable array must have the form | 
|---|
|  | 157 | ;            xxx(n) where n = 1:1 | 
|---|
|  | 158 | ;            xxx may be B@101 as if returned by | 
|---|
|  | 159 | ;            XBDIQ1 in the node 101 of B@ | 
|---|
|  | 160 | ;   EX: | 
|---|
|  | 161 | ;   *B@:$$WP("X")    |B@|    for B=BARWP with BARWP(n) defined | 
|---|
|  | 162 | ;   *B@101:$$WP("X") |B@101| for B=BARWP with BARWP(101,n) defined | 
|---|
|  | 163 | ; | 
|---|
|  | 164 | ;  $$FL(X) | 
|---|
|  | 165 | ;  *19:$$FL(X)      |19| in form:  fill lines through 19 | 
|---|
|  | 166 | ; | 
|---|
|  | 167 | ;  ;D10 | 
|---|
|  | 168 | ;  *xxx:;D10        Performs $J(xxx,10,2) | 
|---|
|  | 169 | ; | 
|---|
|  | 170 | ;  ;R20 | 
|---|
|  | 171 | ;  *xxx:;R20        Performs $J(xxx,20) | 
|---|
|  | 172 | ; | 
|---|
|  | 173 | ;  ;L15 | 
|---|
|  | 174 | ;  *xxx:;L15        Performs $E(xxx,1,15) | 
|---|
|  | 175 | ; | 
|---|
|  | 176 | Q | 
|---|
|  | 177 | TEST    ;; | 
|---|
|  | 178 | ;** set up variables | 
|---|
|  | 179 | D ENP^XBDIQ1(200,DUZ,".01:.116","XBFU(") | 
|---|
|  | 180 | I '$D(XBFFORM) S XBFFORM="JAN" | 
|---|
|  | 181 | D EDIT^XBFORM(XBFFORM,90053.01,1000) | 
|---|
|  | 182 | KILL XBFFM | 
|---|
|  | 183 | S Y=$$GEN^XBFORM(XBFFORM,90053.01,1000,"XBFFM(",0,0) | 
|---|
|  | 184 | Q | 
|---|
|  | 185 | TESTE   ;;END | 
|---|
|  | 186 | PRT     ; | 
|---|
|  | 187 | D ^%ZIS | 
|---|
|  | 188 | U IO W ! | 
|---|
|  | 189 | F I=1:1 Q:'$D(XBFFM(I))  U IO W XBFFM(I),! | 
|---|
|  | 190 | U IO W # | 
|---|
|  | 191 | D ^%ZISC | 
|---|
|  | 192 | Q | 
|---|