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

XPARTPV1.m

Go to the documentation of this file.
  1. XPARTPV1 ;SLC/KCM - Transport, supporting calls
  1. ;;7.3;TOOLKIT;**26**;Apr 25, 1995
  1. ;
  1. ZPKG(IEN,NAME) ; get package IEN & Name
  1. N DIC,X,Y
  1. S IEN=0,NAME=""
  1. S DIC=9.4,DIC(0)="AEMQ" D ^DIC Q:Y<1
  1. S IEN=+Y_";DIC(9.4,",NAME=$P(Y,U,2)
  1. Q
  1. PKG(IEN,NAME,NMSP) ; get namespace and associated package
  1. N DIR,DIRUT,DTOUT,DUOUT,PKG
  1. S IEN=0,NAME="",NMSP=""
  1. S DIR("A")="Parameter Namespace",DIR(0)="F^2:30"
  1. D ^DIR Q:$D(DIRUT) S NMSP=$P(Y,"*")
  1. I $D(^DIC(9.4,"C",NMSP)) S IEN=$O(^DIC(9.4,"C",NMSP,0))
  1. E S PKG=NMSP D
  1. . F S PKG=$O(^DIC(9.4,"C",PKG),-1) Q:$E(NMSP,1,$L(PKG))=PKG
  1. . I $L(PKG) S IEN=$O(^DIC(9.4,"C",PKG,0))
  1. I IEN S NAME=$P(^DIC(9.4,IEN,0),U),IEN=IEN_";DIC(9.4,"
  1. Q
  1. ROU(NAME) ; get routine name
  1. N DIR,DIRUT,DTOUT,DUOUT
  1. S NAME=""
  1. S DIR("A")="Routine Name",DIR(0)="F^2:6"
  1. D ^DIR Q:$D(DIRUT) S NAME=Y
  1. W !!,"This will create a series of ",NAME," routines."
  1. I $T(@(U_NAME))'="" W !,"But "_NAME_" already exists!"
  1. S DIR("A")="Is that ok",DIR(0)="Y"
  1. D ^DIR I $D(DIRUT)!(Y=0) S NAME=""
  1. Q
  1. MAX(SIZ) ; get maximum routine size
  1. N DIR,DIRUT,DTOUT,DUOUT
  1. S SIZ=0
  1. S DIR("A")="Maximum Routine Size",DIR(0)="N^2000:8000"
  1. D ^DIR Q:$D(DIRUT) S SIZ=Y
  1. Q
  1. VALTOTMP(PKG,NMSP) ; gather package level parameter values & put in ^TMP
  1. N I,CNT K ^TMP($J,"XPARSAVE")
  1. S (I,CNT)=0 F S I=$O(^XTV(8989.5,"B",PKG,I)) Q:'I D
  1. . N PAR,PARNAME,INST,VAL,X
  1. . S X=^XTV(8989.5,I,0),PAR=$P(X,U,2),INST=$P(X,U,3),VAL=^(1)
  1. . S PARNAME=$P(^XTV(8989.51,PAR,0),U,1)
  1. . I $E(PARNAME,1,$L(NMSP))'=NMSP Q ; skip if outside namespace
  1. . S INST=$$EXT^XPARDD(INST,PAR,"I"),VAL=$$EXT^XPARDD(VAL,PAR,"V")
  1. . I $D(^XTV(8989.5,I,2))>9 M VAL=^(2) K VAL(0)
  1. . S ^TMP($J,"XPARSAVE",I,"KEY")=PARNAME_U_INST
  1. . M ^TMP($J,"XPARSAVE",I,"VAL")=VAL
  1. . S CNT=CNT+1 I CNT#100=0 W "."
  1. Q
  1. SAVEROU ; loop thru ^TMP($J,"ROU") and save routines
  1. N DIE,X,XCM,XCN
  1. S X="" F S X=$O(^TMP($J,"ROU",X)) Q:X="" D
  1. . W !,"Saving ",X
  1. . S DIE="^TMP($J,""ROU"","""_X_""",",XCN=0
  1. . X ^%ZOSF("SAVE")
  1. Q
  1. MAKEID(I) ; return two char ID based on integer, (0..9,A..Z)=base 36
  1. Q $TR($C(I\36+55)_$C(I#36+55),"789:;<=>?@","0123456789")