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

XPDER.m

Go to the documentation of this file.
  1. XPDER ;SFISC/RSD - Rollup Patches into Build ;09/13/96 09:04 [ 04/02/2003 8:29 AM ]
  1. ;;8.0;KERNEL;**1002,1003,1004,1005,1007**;APR 1, 2003
  1. ;;8.0;KERNEL;**44**;Jul 10, 1995
  1. EN1 ;rollup patches into new build
  1. N DIR,DIRUT,XPD,XPDA,XPDIT,XPDF,XPDFL,XPDJ,XPDNM,XPDVER,XPDPKG,XPDT,XPDY,X,Y,Z W !
  1. ;only find Single packages, not patches, that have a Package file link
  1. S Z="AEMQZ",Z("S")="S %=$G(^(0)) I $P(%,U)'[""*"",$D(^DIC(9.4,+$P(%,U,2),0)),'$P(%,U,3)"
  1. Q:'$$DIC^XPDE(.Z,"Rollup patches into Build: ")
  1. S XPDA=+Y,XPDNM=$P(Y(0),U),XPDPKG=+$P(Y(0),U,2),XPDVER=$$VER^XPDUTL(XPDNM)
  1. ;check if package contains patches
  1. S (Y,Z)=0
  1. F S Y=$O(^XPD(9.6,XPDA,10,Y)) Q:'Y S X=^(Y,0) D
  1. .I 'Z W !,"This package already contains the following patches:" S Z=1
  1. .W !?3,X
  1. W !!,"The following patches can be rolled into Package ",XPDNM,!
  1. S X=0 F S X=$O(^XPD(9.6,"C",XPDPKG,X)) Q:'X D
  1. .Q:'$D(^XPD(9.6,X,0)) S Y=$P(^(0),U)
  1. .I $P(Y,"*",2)=XPDVER,'$D(^XPD(9.6,XPDA,10,"B",Y)) S XPDT(X)=Y W ?5,Y,!
  1. I '$D(XPDT) W !!,"No patches exist" D QUIT^XPDE(XPDA) Q
  1. S DIR(0)="Y",DIR("A")="OK to continue",DIR("B")="YES" D ^DIR
  1. I 'Y!$D(DIRUT) D QUIT^XPDE(XPDA) W ! Q
  1. D WAIT^DICD S XPDIT=0
  1. F S XPDIT=$O(XPDT(XPDIT)),(XPDF,XPDFL)=0 Q:'XPDIT D
  1. .;loop through Files
  1. .N DA,DIK
  1. .F W "." S XPDF=$O(^XPD(9.6,XPDIT,4,XPDF)) Q:'XPDF K XPD M XPD(XPDF)=^(XPDF) D
  1. ..;if file doesn't exist in original build
  1. ..I '$D(^XPD(9.6,XPDA,4,XPDF)) M ^(XPDF)=XPD(XPDF) S XPDFL=1 Q
  1. ..S Y=$G(^XPD(9.6,XPDA,4,XPDF,222))
  1. ..;if original is a full DD do nothing
  1. ..I $P(Y,U,3)="f" K XPD(XPDF) Q
  1. ..I $P($G(XPD(XPDF,222)),U,3)="f" K ^XPD(9.6,XPDA,4,XPDF) M ^(XPDF)=XPD(XPDF) S XPDFL=1 Q
  1. ..;since it must be a partial, don't need these nodes
  1. ..K XPD(XPDF,0),XPD(XPDF,222),XPD(XPDF,223),XPD(XPDF,224)
  1. ..S XPDJ=0
  1. ..;loop thru incoming partial subDD's
  1. ..F S XPDJ=$O(XPD(XPDF,2,XPDJ)) Q:'XPDJ D
  1. ...;if original has this subDD and doesn't have any field, then it is taking the entire subDD, so don't care about incoming
  1. ...I '$D(^XPD(9.6,XPDA,4,XPDF,2,XPDJ)) M ^(XPDJ)=XPD(XPDF,2,XPDJ) Q
  1. ...I '$O(^XPD(9.6,XPDA,4,XPDF,2,XPDJ,1,0)) K XPD(XPDF,2,XPDJ) Q
  1. ...S XPDY=0
  1. ...F S XPDY=$O(XPD(XPDF,2,XPDJ,1,XPDY)) Q:'XPDY D
  1. ....I $D(^XPD(9.6,XPDA,4,XPDF,2,XPDJ,1,XPDY)) K XPD(XPDF,2,XPDJ,1,XPDY) Q
  1. ....M ^XPD(9.6,XPDA,4,XPDF,2,XPDJ,1,XPDY)=XPD(XPDF,2,XPDJ,1,XPDY)
  1. ...Q:'$O(XPD(XPDF,2,XPDJ,1,0))
  1. ...K DA,XPD(XPDF,2,XPDJ)
  1. ...S DA(3)=XPDA,DA(2)=XPDF,DA(1)=XPDJ,DIK="^XPD(9.6,"_XPDA_",4,"_XPDF_",2,"_XPDJ_",1," D IXALL^DIK
  1. ..Q:'$O(XPD(XPDF,2,0))
  1. ..K DA,XPD(XPDF)
  1. ..S DA(2)=XPDA,DA(1)=XPDF,DIK="^XPD(9.6,"_XPDA_",4,"_XPDF_",2," D IXALL^DIK
  1. .;XPDFL=1 if we merged data into node 4 at top level
  1. .I XPDFL K DA S DA(1)=XPDA,DIK="^XPD(9.6,"_XPDA_",4," D IXALL^DIK
  1. .;loop through Build Components
  1. .S XPDF=0 F S XPDF=$O(^XPD(9.6,XPDIT,"KRN",XPDF)) Q:'XPDF D
  1. ..K XPD S (XPDJ,XPDY)=0 W "."
  1. ..F S XPDY=$O(^XPD(9.6,XPDIT,"KRN",XPDF,"NM",XPDY)) Q:XPDY="" S XPDX=$G(^(XPDY,0)) D:$P(XPDX,U)]""
  1. ...;quit if components exist in original build
  1. ...Q:$D(^XPD(9.6,XPDA,"KRN",XPDF,"NM","B",$P(XPDX,U)))
  1. ...S XPDJ=XPDJ+1,Y="+"_XPDJ_","_XPDF_","_XPDA_",",XPD(9.68,Y,.01)=$P(XPDX,U),XPD(9.68,Y,.03)=$P(XPDX,U,3)
  1. ..Q:'$D(XPD) D UPDATE^DIE("","XPD")
  1. .;put patch in mulitple
  1. .K XPD S XPD(9.63,"+1,"_XPDA_",",.01)=XPDT(XPDIT)
  1. .D UPDATE^DIE("","XPD")
  1. D QUIT^XPDE(XPDA) W "...Done.",!
  1. Q