source: FOIAVistA/tag/r/TOOLKIT-AWCM-XD-XIN-XPAR-XQAB-XT-XUC-XUR-ZIN-ZTED/XPARTPV1.m@ 1607

Last change on this file since 1607 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 2.0 KB
Line 
1XPARTPV1 ;SLC/KCM - Transport, supporting calls
2 ;;7.3;TOOLKIT;**26**;Apr 25, 1995
3 ;
4ZPKG(IEN,NAME) ; get package IEN & Name
5 N DIC,X,Y
6 S IEN=0,NAME=""
7 S DIC=9.4,DIC(0)="AEMQ" D ^DIC Q:Y<1
8 S IEN=+Y_";DIC(9.4,",NAME=$P(Y,U,2)
9 Q
10PKG(IEN,NAME,NMSP) ; get namespace and associated package
11 N DIR,DIRUT,DTOUT,DUOUT,PKG
12 S IEN=0,NAME="",NMSP=""
13 S DIR("A")="Parameter Namespace",DIR(0)="F^2:30"
14 D ^DIR Q:$D(DIRUT) S NMSP=$P(Y,"*")
15 I $D(^DIC(9.4,"C",NMSP)) S IEN=$O(^DIC(9.4,"C",NMSP,0))
16 E S PKG=NMSP D
17 . F S PKG=$O(^DIC(9.4,"C",PKG),-1) Q:$E(NMSP,1,$L(PKG))=PKG
18 . I $L(PKG) S IEN=$O(^DIC(9.4,"C",PKG,0))
19 I IEN S NAME=$P(^DIC(9.4,IEN,0),U),IEN=IEN_";DIC(9.4,"
20 Q
21ROU(NAME) ; get routine name
22 N DIR,DIRUT,DTOUT,DUOUT
23 S NAME=""
24 S DIR("A")="Routine Name",DIR(0)="F^2:6"
25 D ^DIR Q:$D(DIRUT) S NAME=Y
26 W !!,"This will create a series of ",NAME," routines."
27 I $T(@(U_NAME))'="" W !,"But "_NAME_" already exists!"
28 S DIR("A")="Is that ok",DIR(0)="Y"
29 D ^DIR I $D(DIRUT)!(Y=0) S NAME=""
30 Q
31MAX(SIZ) ; get maximum routine size
32 N DIR,DIRUT,DTOUT,DUOUT
33 S SIZ=0
34 S DIR("A")="Maximum Routine Size",DIR(0)="N^2000:8000"
35 D ^DIR Q:$D(DIRUT) S SIZ=Y
36 Q
37VALTOTMP(PKG,NMSP) ; gather package level parameter values & put in ^TMP
38 N I,CNT K ^TMP($J,"XPARSAVE")
39 S (I,CNT)=0 F S I=$O(^XTV(8989.5,"B",PKG,I)) Q:'I D
40 . N PAR,PARNAME,INST,VAL,X
41 . S X=^XTV(8989.5,I,0),PAR=$P(X,U,2),INST=$P(X,U,3),VAL=^(1)
42 . S PARNAME=$P(^XTV(8989.51,PAR,0),U,1)
43 . I $E(PARNAME,1,$L(NMSP))'=NMSP Q ; skip if outside namespace
44 . S INST=$$EXT^XPARDD(INST,PAR,"I"),VAL=$$EXT^XPARDD(VAL,PAR,"V")
45 . I $D(^XTV(8989.5,I,2))>9 M VAL=^(2) K VAL(0)
46 . S ^TMP($J,"XPARSAVE",I,"KEY")=PARNAME_U_INST
47 . M ^TMP($J,"XPARSAVE",I,"VAL")=VAL
48 . S CNT=CNT+1 I CNT#100=0 W "."
49 Q
50SAVEROU ; loop thru ^TMP($J,"ROU") and save routines
51 N DIE,X,XCM,XCN
52 S X="" F S X=$O(^TMP($J,"ROU",X)) Q:X="" D
53 . W !,"Saving ",X
54 . S DIE="^TMP($J,""ROU"","""_X_""",",XCN=0
55 . X ^%ZOSF("SAVE")
56 Q
57MAKEID(I) ; return two char ID based on integer, (0..9,A..Z)=base 36
58 Q $TR($C(I\36+55)_$C(I#36+55),"789:;<=>?@","0123456789")
Note: See TracBrowser for help on using the repository browser.