| 1 | ESPDUP ;ALBANY/CJM - DELETES DUPLICATE ENTRIES IN MASTER NAME INDEX FILE;8/92
 | 
|---|
| 2 |  ;;1.0;POLICE & SECURITY;**17**;Mar 31, 1994
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | EN ;Allows duplicate names to be deleted from the Master Name Index file.
 | 
|---|
| 5 |  ;The user is required to select the name which is the 'good' one.
 | 
|---|
| 6 |  ;
 | 
|---|
| 7 |  N NAME
 | 
|---|
| 8 |  S (NAME("DELETE"),NAME("KEEP"))=""
 | 
|---|
| 9 |  W !!,"Which name do you want to delete from the Master Name Index?"
 | 
|---|
| 10 |  S NAME("DELETE")=$$SELECT
 | 
|---|
| 11 |  Q:'NAME("DELETE")
 | 
|---|
| 12 |  ;
 | 
|---|
| 13 |  W !!,"** PLEASE NOTE **"
 | 
|---|
| 14 |  W !,"Entries in the Master Name Index file are referenced from many other files."
 | 
|---|
| 15 |  W !,"Before you are allowed to delete a duplicate entry you must first indicate"
 | 
|---|
| 16 |  W !,"the correct entry to keep so that all references in all files can be changed"
 | 
|---|
| 17 |  W !,"to the correct entry."
 | 
|---|
| 18 |  W !!,"Which entry do you want to keep?",!
 | 
|---|
| 19 |  ;
 | 
|---|
| 20 |  F  D  Q:(NAME("DELETE")'=NAME("KEEP"))
 | 
|---|
| 21 |  .S NAME("KEEP")=$$SELECT
 | 
|---|
| 22 |  .I NAME("DELETE")=NAME("KEEP") W !,"You must select a different entry!",!
 | 
|---|
| 23 |  Q:'NAME("KEEP")
 | 
|---|
| 24 |  ;
 | 
|---|
| 25 |  D:$$RUSURE(NAME("DELETE"),NAME("KEEP"))
 | 
|---|
| 26 |  .;
 | 
|---|
| 27 |  .;first update all the xrefs, replacing NAME("DELETE") with NAME("KEEP")
 | 
|---|
| 28 |  .D REPLACE(NAME("DELETE"),NAME("KEEP"))
 | 
|---|
| 29 |  .;
 | 
|---|
| 30 |  .;next delete the duplicate entry
 | 
|---|
| 31 |  .D DELETE(NAME("DELETE"))
 | 
|---|
| 32 |  .W !!,"DONE",!!
 | 
|---|
| 33 |  Q
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 | SELECT() ;
 | 
|---|
| 36 |  ;asks user to select from file 910
 | 
|---|
| 37 |  ;returns ptr to file 910, the Master Name Index
 | 
|---|
| 38 |  ;
 | 
|---|
| 39 |  N Y,DINUM,DIC,X,DTIME,DLAYGO
 | 
|---|
| 40 |  S DIC=910,DIC(0)="AEFMQ"
 | 
|---|
| 41 |  S DIC("A")="Select a name: "
 | 
|---|
| 42 |  D ^DIC
 | 
|---|
| 43 |  I (Y=-1)!$D(DTOUT)!$D(DUOUT) Q 0
 | 
|---|
| 44 |  Q +Y
 | 
|---|
| 45 |  ;
 | 
|---|
| 46 | REPLACE(OLD,NEW) ;
 | 
|---|
| 47 |  ;replaces all pointers to file 910 = OLD with NEW
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 |  N REF,COUNT,REC,SUBREC
 | 
|---|
| 50 |  S COUNT=1
 | 
|---|
| 51 |  F  S REF=$P($T(REFS+COUNT),";;",2) Q:(REF="")  D
 | 
|---|
| 52 |  .S COUNT=COUNT+1
 | 
|---|
| 53 |  .S REF("FILE")=$P(REF,"^"),REF("XREF")=$P(REF,"^",2),REF("SUB")=$P(REF,"^",3),REF("FIELD")=$P(REF,"^",4)
 | 
|---|
| 54 |  .Q:REF("FILE")=""
 | 
|---|
| 55 |  .Q:REF("XREF")=""
 | 
|---|
| 56 |  .Q:REF("FIELD")=""
 | 
|---|
| 57 |  .;
 | 
|---|
| 58 |  .S REC=0 F  S REC=$O(^ESP(REF("FILE"),REF("XREF"),OLD,REC)) Q:'REC  D
 | 
|---|
| 59 |  ..I REF("SUB")="" D
 | 
|---|
| 60 |  ...D EDIT(REF("FILE"),REC,REF("FIELD"),NEW)
 | 
|---|
| 61 |  ..E  S SUBREC=0 F  S SUBREC=$O(^ESP(REF("FILE"),REF("XREF"),OLD,REC,SUBREC)) Q:'SUBREC  D EDIT(REF("FILE"),REC,REF("FIELD"),NEW,REF("SUB"),SUBREC)
 | 
|---|
| 62 |  Q
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 | DELETE(OLD) ;
 | 
|---|
| 65 |  N DIK,DA
 | 
|---|
| 66 |  S DIK="^ESP(910,",DA=OLD
 | 
|---|
| 67 |  D ^DIK
 | 
|---|
| 68 |  W !,"DELETED",!
 | 
|---|
| 69 |  Q
 | 
|---|
| 70 |  ;
 | 
|---|
| 71 | RUSURE(OLD,NEW) ;
 | 
|---|
| 72 |  ;
 | 
|---|
| 73 |  N DIR,DA,X,Y
 | 
|---|
| 74 |  S DIR(0)="Y"
 | 
|---|
| 75 |  S DIR("B")="NO"
 | 
|---|
| 76 |  S DIR("A")="Replace "_$P($G(^ESP(910,OLD,0)),"^")_" with "_$P($G(^ESP(910,NEW,0)),"^")_" and then delete"
 | 
|---|
| 77 |  W !
 | 
|---|
| 78 |  D ^DIR
 | 
|---|
| 79 |  Q Y
 | 
|---|
| 80 |  ;
 | 
|---|
| 81 | EDIT(FILE,REC,FIELD,VALUE,SUB,SUBREC) ;
 | 
|---|
| 82 |  N DIE,DA,DR
 | 
|---|
| 83 |  S DIE="^ESP("_FILE_","
 | 
|---|
| 84 |  S DR=FIELD_"////"_VALUE
 | 
|---|
| 85 |  I $G(SUB)="" D
 | 
|---|
| 86 |  .S DA=REC
 | 
|---|
| 87 |  .D ^DIE
 | 
|---|
| 88 |  E  D
 | 
|---|
| 89 |  .Q:'SUBREC
 | 
|---|
| 90 |  .S DIE=DIE_REC_","_SUB_","
 | 
|---|
| 91 |  .S DA(1)=REC
 | 
|---|
| 92 |  .S DA=SUBREC
 | 
|---|
| 93 |  .D ^DIE
 | 
|---|
| 94 |  Q
 | 
|---|
| 95 |  ;
 | 
|---|
| 96 |  ;
 | 
|---|
| 97 | REFS ;;<file #>;<xref>;<subscript if in multiple>;<field #>
 | 
|---|
| 98 |  ;;910.2^D^^.03
 | 
|---|
| 99 |  ;;910.2^I^^4.05
 | 
|---|
| 100 |  ;;910.2^J^^5.01
 | 
|---|
| 101 |  ;;910.2^V^^6.01
 | 
|---|
| 102 |  ;;910.2^BI^^6.02
 | 
|---|
| 103 |  ;;910.2^W^^6.03
 | 
|---|
| 104 |  ;;910.2^P^^6.04
 | 
|---|
| 105 |  ;;910.2^G^^6.05
 | 
|---|
| 106 |  ;;910.8^C^1^.04
 | 
|---|
| 107 |  ;;910.8^D^5^.03
 | 
|---|
| 108 |  ;;912^D^20^.02
 | 
|---|
| 109 |  ;;912^E^30^.02
 | 
|---|
| 110 |  ;;912^G^40^.02
 | 
|---|
| 111 |  ;;912^I^50^.02
 | 
|---|
| 112 |  ;;912^J^80^.11
 | 
|---|
| 113 |  ;;913^B^^.01
 | 
|---|
| 114 |  ;;914^E^^.09
 | 
|---|
| 115 |  ;;
 | 
|---|