| 1 | ENXLFIX ;WISC/SAB-FIX POINTERS TO ENG SPACE FILE ;1-24-94
|
---|
| 2 | ;;7.0;ENGINEERING;**1**;Aug 17, 1993
|
---|
| 3 | EN S DIR(0)="S^EQ:EQUIPMENT FILE;WO:WORK ORDER FILE;"
|
---|
| 4 | S DIR("A")=$S(ENCVTM:"Convert",1:"Report of")_" location fields in which file"
|
---|
| 5 | S DIR("?")="Enter EQ or WO to select the desired file."
|
---|
| 6 | S DIR("?",1)="You must choose which file to process. The LOCATION"
|
---|
| 7 | S DIR("?",2)="field of the selected file will be checked and"
|
---|
| 8 | I ENCVTM D
|
---|
| 9 | .S DIR("?",3)="any free-text values which match an entry in the space"
|
---|
| 10 | .S DIR("?",4)="file will be converted to pointers. Any unconverted"
|
---|
| 11 | .S DIR("?",5)="free-text values will be identified by a leading '*'"
|
---|
| 12 | E D
|
---|
| 13 | .S DIR("?",3)="the number and type of free-text entries in this"
|
---|
| 14 | .S DIR("?",4)="pointer field will be reported."
|
---|
| 15 | S DIR("?",9)=" "
|
---|
| 16 | D ^DIR K DIR I $D(DIRUT) G EXIT
|
---|
| 17 | S ENFL=Y
|
---|
| 18 | S ENDETAIL=1
|
---|
| 19 | I ENCVTM D D ^DIR K DIR S ENDETAIL=Y I $D(DIRUT) G EXIT
|
---|
| 20 | .S DIR(0)="Y",DIR("A")="Should locations be listed on output? Y/N"
|
---|
| 21 | .S DIR("?")="Enter Y or N"
|
---|
| 22 | .S DIR("?",1)="If you answer yes a line will be printed for each"
|
---|
| 23 | .S DIR("?",2)="unique free-text location. The line will contain"
|
---|
| 24 | .S DIR("?",3)="the location, the number of entries with that location,"
|
---|
| 25 | .S DIR("?",4)="and if the location was converted to a pointer."
|
---|
| 26 | S %ZIS="QM" D ^%ZIS G EXIT:POP
|
---|
| 27 | I $D(IO("Q")) D G EXIT
|
---|
| 28 | .S ZTRTN="DQ^ENXLFIX"
|
---|
| 29 | .S ZTSAVE("ENCVTM")="",ZTSAVE("ENFL")="",ZTSAVE("ENDETAIL")=""
|
---|
| 30 | .S ZTDESC=$S(ENCVTM:"Convert",1:"Report of")_" Locations in "_$S(ENFL="EQ":"EQUIP",1:"W.O.")_" file"
|
---|
| 31 | .D ^%ZTLOAD D HOME^%ZIS K IO("Q")
|
---|
| 32 | DQ ; queued entry
|
---|
| 33 | S Y=DT D DD^%DT S ENDATE=Y
|
---|
| 34 | S (END,ENPG,ENT("LOC"),ENT("REC"),ENT("LOC_CVT"),ENT("REC_CVT"))=0
|
---|
| 35 | S ENFLNM=$S(ENFL="EQ":"Equipment File",1:"Work Order File")
|
---|
| 36 | S ENXRF=$S(ENFL="EQ":"^ENG(6914,""D"",",1:"^ENG(6920,""C"",")
|
---|
| 37 | S ENODE=$S(ENFL="EQ":"^ENG(6914,ENDA,3)",1:"^ENG(6920,ENDA,0)")
|
---|
| 38 | S ENPIECE=$S(ENFL="EQ":5,1:4)
|
---|
| 39 | U IO D HDR
|
---|
| 40 | I 'ENDETAIL W !," Locations not listed by user request",!
|
---|
| 41 | ; loop thru free-text locations
|
---|
| 42 | S ENLOC=" " F S ENLOC=$O(@(ENXRF_"ENLOC)")) Q:ENLOC=""!END D LOCAT
|
---|
| 43 | I 'END D
|
---|
| 44 | .I ENCVTM,$Y+6+$S(ENT("REC"):6,1:2)+$S(ENT("REC_CVT"):3,1:0)>IOSL D HDR
|
---|
| 45 | .I 'ENCVTM,$Y+6+$S(ENT("REC"):7,1:2)+$S(ENT("REC_CVT"):6,1:0)>IOSL D HDR
|
---|
| 46 | I END W !,"HALTED BY USER REQUEST",!
|
---|
| 47 | E D RFTR^ENXLFIX0
|
---|
| 48 | D ^%ZISC
|
---|
| 49 | EXIT I $D(ZTQUEUED),'$D(ZTSTOP) S ZTREQ="Q"
|
---|
| 50 | K %ZIS,DA,DIE,DIRUT,DR
|
---|
| 51 | K ENCVTM,ENCVTS,END,ENDA,ENDATE,ENDETAIL,ENFL,ENFLNM,ENLOC,ENODE
|
---|
| 52 | K ENPG,ENPIECE,ENSPDA,ENSPLOC,ENT,ENXRF,POP,X,Y
|
---|
| 53 | Q
|
---|
| 54 | LOCAT ; process location
|
---|
| 55 | I ENCVTM,$E(ENLOC,1)=" " D SPACES^ENXLFIX0 Q ; handle leading spaces
|
---|
| 56 | S ENCVTS=0,ENT("LOC")=ENT("LOC")+1
|
---|
| 57 | ; strip * for match
|
---|
| 58 | S ENSPLOC=$E(ENLOC,$S($E(ENLOC,1)="*":2,1:1),$L(ENLOC))
|
---|
| 59 | I ENSPLOC']"" S ENSPLOC=ENLOC
|
---|
| 60 | ; match space .01?
|
---|
| 61 | S ENSPDA=$O(^ENG("SP","B",ENSPLOC,""))
|
---|
| 62 | ; if not match and has lowercase, uppercase match .01?
|
---|
| 63 | I 'ENSPDA,ENSPLOC?.E1L.E D
|
---|
| 64 | .S X=ENSPLOC X ^%ZOSF("UPPERCASE")
|
---|
| 65 | .S ENSPDA=$O(^ENG("SP","B",Y,""))
|
---|
| 66 | ; if we found a match to .01 (either method)
|
---|
| 67 | I ENSPDA S ENCVTS=1,ENT("LOC_CVT")=ENT("LOC_CVT")+1
|
---|
| 68 | ; if not match, match space synonym?
|
---|
| 69 | I 'ENSPDA S ENSPDA=$O(^ENG("SP","F",ENSPLOC,"")) D:ENSPDA
|
---|
| 70 | .I $O(^ENG("SP","F",ENSPLOC,ENSPDA)) S ENCVTS="M"
|
---|
| 71 | .E S ENCVTS=2,ENT("LOC_CVT")=ENT("LOC_CVT")+1
|
---|
| 72 | ; if still no match and free-text location has *, match synonym?
|
---|
| 73 | I 'ENSPDA,ENSPLOC'=ENLOC S ENSPDA=$O(^ENG("SP","F",ENLOC,"")) D:ENSPDA
|
---|
| 74 | .I $O(^ENG("SP","F",ENLOC,ENSPDA)) S ENCVTS="M"
|
---|
| 75 | .E S ENCVTS=2,ENT("LOC_CVT")=ENT("LOC_CVT")+1
|
---|
| 76 | ; loop thru records within location
|
---|
| 77 | S ENT("REC_IN_LOC")=0,ENDA=""
|
---|
| 78 | F S ENDA=$O(@(ENXRF_"ENLOC,ENDA)")) Q:'ENDA D
|
---|
| 79 | .I '$D(@ENODE) K @(ENXRF_"ENLOC,ENDA)") Q ; invalid x-ref node
|
---|
| 80 | .S ENT("REC_IN_LOC")=ENT("REC_IN_LOC")+1
|
---|
| 81 | .I ENCVTM,ENCVTS D ; convert to pointer
|
---|
| 82 | ..I ENFL="EQ",ENLOC["E" K ^ENG(6914,"D",ENLOC,ENDA) S $P(^ENG(6914,ENDA,3),U,5)=""
|
---|
| 83 | ..S DIE=$S(ENFL="EQ":"^ENG(6914,",1:"^ENG(6920,"),DA=ENDA
|
---|
| 84 | ..S DR=$S(ENFL="EQ":"24",1:"3")_"////"_ENSPDA D ^DIE
|
---|
| 85 | .I ENCVTM,'ENCVTS,$E(ENLOC,1)'="*" D ; add leading *
|
---|
| 86 | ..S $P(@ENODE,U,ENPIECE)="*"_$P(@ENODE,U,ENPIECE)
|
---|
| 87 | ..K @(ENXRF_"ENLOC,ENDA)") ; old x-ref
|
---|
| 88 | ..S @(ENXRF_"""*"_ENLOC_""","_ENDA_")")="" ; new x-ref
|
---|
| 89 | S ENT("REC")=ENT("REC")+ENT("REC_IN_LOC")
|
---|
| 90 | I ENCVTS S ENT("REC_CVT")=ENT("REC_CVT")+ENT("REC_IN_LOC")
|
---|
| 91 | W:ENDETAIL ?5,ENLOC,?30,ENT("REC_IN_LOC"),?40,$S($E(ENLOC,1)=" ":"?? (leading spaces)",ENCVTS=1:"YES, by room number",ENCVTS=2:"YES, by synonym",ENCVTS="M":"NO, multiple synonyms",1:"NO"),!
|
---|
| 92 | I $Y+4>IOSL D HDR
|
---|
| 93 | Q
|
---|
| 94 | HDR ; page header
|
---|
| 95 | I $$S^%ZTLOAD S (END,ZTSTOP)=1 Q
|
---|
| 96 | I ENPG,$E(IOST,1,2)="C-" S DIR(0)="E" D ^DIR K DIR S END='Y Q:END
|
---|
| 97 | W:'($E(IOST,1,2)'="C-"&'ENPG) @IOF
|
---|
| 98 | S ENPG=ENPG+1
|
---|
| 99 | W ?5,"Free-Text Values in ",ENFLNM," LOCATION Fields"
|
---|
| 100 | W ?60,ENDATE,?73,"page ",ENPG,!!
|
---|
| 101 | W ?5,"Free-Text Location",?30,"Count"
|
---|
| 102 | W ?40,"Convert"_$S(ENCVTM:"ed?",1:"ible?"),!
|
---|
| 103 | W ?5,"------------------",?30,"-----",?40,"------------",!!
|
---|
| 104 | Q
|
---|