Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: XPDCPU

XPDCPU.m

Go to the documentation of this file.
  1. XPDCPU ;SFISC/RWF,RSD - Code that update each cpu ;09/09/96 08:01 [ 04/02/2003 8:29 AM ]
  1. ;;8.0;KERNEL;**1002,1003,1004,1005,1007**;APR 1, 2003
  1. ;;8.0;KERNEL;**41,44**;JUL 03, 1995
  1. N DIC,X,XPDA
  1. S DIC("S")="I $P(^(0),U,9)=2,$D(^XPD(9.7,""ASP"",Y,1,Y)),$D(^XTMP(""XPDI"",Y))"
  1. D EN1 Q:'XPDA
  1. S X=$O(^XPD(9.7,XPDA,"VOL","B",^%ZOSF("VOL"),0)) Q:'X
  1. D EN(XPDA,X)
  1. Q
  1. ;
  1. MOVE ;move routines to other CPU
  1. N DIC,DIR,DIRUT,X,XPDA,XPDJ,Y
  1. S DIC("S")="I $P(^(0),U,9)=3"
  1. D EN1 Q:'XPDA
  1. S DIR(0)="Y",DIR("A")="Want to move the Routine for this Package to another CPU",DIR("B")="YES",DIR("?")="YES means you want to update the routines on another CPU"
  1. D ^DIR Q:'Y!$D(DIRUT)
  1. K ^XTMP("XPDR",XPDA)
  1. S ^XTMP("XPDR",0)=DT_U_DT,XPDJ=""
  1. F S XPDJ=$O(^XPD(9.7,XPDA,"RTN","B",XPDJ)) Q:XPDJ="" D
  1. .Q:XPDJ="XPDCPU"
  1. .N DIF,XCNP,%N
  1. .S DIF="^XTMP(""XPDR"",XPDA,""RTN"",XPDJ,",XCNP=0,X=XPDJ
  1. .X ^%ZOSF("LOAD")
  1. I $D(^XTMP("XPDR",XPDA)) W !!,"Run INSTALL^XPDCPU on the other CPU to install the Routines.",!
  1. Q
  1. INSTALL ;install routines
  1. N DIC,DIR,DIRUT,X,XPDA,XPDJ,Y
  1. S DIC("S")="I $P(^(0),U,9)=3,$D(^XTMP(""XPDR"",Y))"
  1. D EN1 Q:'XPDA
  1. S DIR(0)="Y",DIR("A")="Want to install the Routine for this Package",DIR("B")="YES",DIR("?")="YES means you want to install the routines on this CPU"
  1. D ^DIR Q:'Y!$D(DIRUT)
  1. S XPDJ=""
  1. F S XPDJ=$O(^XTMP("XPDR",XPDA,"RTN",XPDJ)) Q:XPDJ="" D
  1. .N %,DIE,XCM,XCN,XCS
  1. .S DIE="^XTMP(""XPDR"",XPDA,""RTN"",XPDJ,",XCN=0,X=XPDJ
  1. .X ^%ZOSF("SAVE")
  1. W !!,"Done",!!
  1. Q
  1. ;
  1. EN(XPDA,XPDVDA) ;XPDA=ien of INSTALL file, XPDVDA=VOLUME SET ien
  1. L +^XPD(9.7,XPDA,"VOL",XPDVDA):2 E W:IO]"" !,"Can't Lock global, another XPDCPU must be running",! Q
  1. N Y,%,XPDNM
  1. S Y=0,ZTREQ="@"
  1. F S Y=$O(^XPD(9.7,"ASP",XPDA,Y)) Q:'Y S %=$O(^(Y,0)) D:% Q:$D(XPDABORT)
  1. .N XPDA,Y
  1. .S XPDA=%,XPDNM=$P($G(^XPD(9.7,XPDA,0)),U) D EN2
  1. Q
  1. EN1 ;ask for Install
  1. N Y S XPDA=0
  1. I $D(DUZ)_$D(DUZ(0))_$D(U)[0 D DT^DICRW
  1. S DIC(0)="QEAMZ",DIC="^XPD(9.7,"
  1. D ^DIC K DIC Q:Y'>0
  1. S XPDA=+Y
  1. Q
  1. EN2 N X,XPD,XPDBLD,XPDI,ZTUCI,ZTCPU,ZTRTN,ZTDTH,ZTIO,ZTDESC
  1. ;must have XTMP & entry in file 9.7
  1. Q:'$D(^XTMP("XPDI",XPDA))!'$D(^XPD(9.7,XPDA,0))
  1. ;hang 1 hr or until VOLUME multiple is set, XPDIJ sets VOL multiple
  1. F X=0:1:60 Q:$D(^XPD(9.7,XPDA,"VOL",+$G(XPDVDA),0)) H 60 W:IO]"" "."
  1. I X=60 W:IO]"" !!,"Package ",$P(^XPD(9.7,XPDA,0),U)," never installed",! Q
  1. S XPDBLD=$O(^XTMP("XPDI",XPDA,"BLD",0))
  1. D FILE(2),UPDT
  1. W:IO]"" !,"Loading Routines"
  1. I $D(^XTMP("XPDI",XPDA,"RTN","XPDCPU")) S X=$$RTNUP^XPDUTL("XPDCPU",2)
  1. ;make sure routines have been loaded
  1. F X=0:1:240 Q:$P($G(^XPD(9.7,XPDA,1)),U,2) H 15 W:IO]"" "." D UPDT
  1. D UPDT,RTN^XPDIJ(XPDA),UPDT
  1. W:IO]"" !!,"Recompiling Template routines"
  1. F XPD="DIKZ","DIEZ","DIPZ" D
  1. .S XPDI="" Q:'$$CHCK
  1. .F S XPDI=$O(^XTMP("XPDI",XPDA,XPD,XPDI)) Q:'XPDI S X=^(XPDI) D:X]"" @("EN2^"_XPD_"("""_XPDI_""","""","""_X_""")"),UPDT
  1. D UPDT,FILE(1)
  1. Q
  1. CHCK() ;check if the component is installed, return 1 if installed, 0 to abort
  1. N XPDC,Y
  1. I XPD="DIKZ" S XPDC="S Y=$G(^(+$O(^XPD(9.7,XPDA,4,""A""),-1),0))"
  1. E S Y=$S(XPD="DIPZ":.4,1:.402),XPDC="S Y=$G(^XPD(9.7,XPDA,""KRN"","_Y_",0))"
  1. F X XPDC Q:'Y!$P(Y,U,2) H 60 D UPDT W:IO]"" "." I $D(ZTMQUE),$$STOP^%ZTLOAD S Y=0 Q
  1. Q ''Y
  1. FILE(XPDF) ;set NOW into the VOLUME SET multiple, XPDF=field number
  1. N XPD
  1. S XPD(9.703,XPDVDA_","_XPDA_",",XPDF)=$$NOW^XLFDT
  1. D FILE^DIE("","XPD")
  1. Q
  1. UPDT ;update $H into VOLUME SET multiple, field 4
  1. S ^XPD(9.7,XPDA,"VOL",XPDVDA,1)=$H
  1. Q