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

BMXADO2.m

Go to the documentation of this file.
  1. BMXADO2 ; IHS/CIHA/GIS - BMX ADO RECORDSET UTILS ;
  1. ;;4.0;BMX;;JUN 28, 2010
  1. ;
  1. ;
  1. GEN(BMXY,BMXF) ;EP - Generate an ADO Schema string from a list of fields
  1. ;BMXY Is an out-parameter called by reference.
  1. ;On return, BMXY will be a zero-based one-dimensional array each node of which will
  1. ;contain the schema corresponding to the fields info in BMXF
  1. ;
  1. ;BMXF is an in-parameter called by reference.
  1. ;On input, BMXF will contain the field info on which to build the schema string.
  1. ;
  1. ;Field info in BMXF is arranged in a zero-based one-dimensional array.
  1. ;Node 0 of BMXF contains the KEYFIELDNAME^FILENUMBER^READONLY
  1. ;where KEYFIELDNAME is the name of the unique key field in the database and
  1. ;FILENUMBER is the FileMan file number and
  1. ;READONLY denotes whether the entire recordset is updateable.
  1. ;
  1. ;Each subsequent node of the BMXF arrray contains field info in the form
  1. ;1FILE#^2FIELD#^3LENGTH^4DATATYPE^5ALIAS^6READONLY^7KEYFIELD^8NULLOK
  1. ;If FILE# AND FIELD# are defined, the LENGTH and DATATYPE will be taken from the FileMan data dictionary
  1. ;If ALIAS is defined, the schema string will use ALIAS as the column name
  1. ;READONLY, KEYFIELD and NULLOK are binary fields. Note that there should be only one field
  1. ;in the recordset having KEYFIELD=TRUE
  1. ;
  1. ;New column info format is @@@meta@@@KEYFIELD|FILE#
  1. ; For each field: ^1FILE#|2FIELD#|3DATATYPE|4LENGTH|5FIELDNAME|6READONLY|7KEYFIELD|8NULL ALLOWED
  1. ;example:
  1. ;BMXY(0)="@@@meta@@@BMXIEN|2160010^"
  1. ;BMXY(1)="2160010|.001|I|10|BMXIEN|TRUE|TRUE|FALSE^"
  1. ;
  1. S BMXY(0)="@@@meta@@@"_$G(BMXF(0))
  1. N BMXI,BMXS,BMXFM,BMXDD,BMXTYP,BMXLEN,BMXLEN2,BMXNAM,BMXKEY,BMXREAD,BMXNULL
  1. S BMXI=0
  1. F S BMXI=$O(BMXF(BMXI)) Q:'+BMXI D
  1. . N BMXFM,BMXDD,BMXTYP,BMXLEN,BMXLEN2,BMXNAM,BMXKEY,BMXREAD,BMXNULL
  1. . S (BMXDD,BMXTYP,BMXLEN,BMXLEN2,BMXNAM,BMXKEY,BMXREAD,BMXNULL)=""
  1. . S BMXFM=0 ;Flag indicating whether BMXF(BMXI) is a FileMan field
  1. . S BMXY(BMXI)=""
  1. . I BMXF(BMXI) S BMXY(BMXI)=$P(BMXF(BMXI),U,1,2) S BMXFM=1
  1. . I BMXFM D ;Look in ^DD for attributes
  1. . . S BMXDD=$G(^DD($P(BMXF(BMXI),U),$P(BMXF(BMXI),U,2),0))
  1. . . ;column name
  1. . . S BMXNAM=$P(BMXDD,U)
  1. . . S BMXNAM=$TR(BMXNAM," ","_")
  1. . . ;Data type
  1. . . I $P(BMXDD,U,2)["P" S BMXDD=$$PTYPE(BMXDD)
  1. . . S BMXTYP=$P(BMXDD,U,2)
  1. . . S BMXTYP=$S(BMXTYP["F":"T",BMXTYP["S":"T",BMXTYP["D":"D")
  1. . . I BMXTYP["N" S BMXTYP=$S($P(BMXTYP,",",2)>0:"N",1:"I")
  1. . . ;default columnn lengths based on type
  1. . . I BMXTYP="N"!(BMXTYP="I") S BMXLEN=$P(BMXDD,U,2),BMXLEN=$P(BMXLEN,","),BMXLEN=$E(BMXLEN,3,$L(BMXLEN))
  1. . . I BMXTYP="I" S BMXLEN2=$P(BMXDD,U,2),BMXLEN2=$P(BMXLEN,",",2),BMXLEN=BMXLEN+BMXLEN2+1
  1. . . I BMXTYP="T" S BMXLEN=0
  1. . . I BMXTYP="D" S BMXLEN=30
  1. . . S BMXNULL="TRUE" S:$P(BMXDD,U,2)["R" BMXNULL="FALSE"
  1. . ;Look in BMXF for user-specified attributes
  1. . S:$P(BMXF(BMXI),U,5)]"" BMXNAM=$P(BMXF(BMXI),U,5) ;Alias
  1. . ;Set KEY, NULL and READONLY
  1. . S BMXNULL="TRUE",BMXREAD="TRUE",BMXKEY="FALSE"
  1. . I $P(BMXF(BMXI),U,7)="TRUE" S BMXKEY="TRUE",BMXNULL="FALSE",BMXREAD="TRUE"
  1. . E S:$P(BMXF(BMXI),U,8)]"" BMXNULL=$P(BMXF(BMXI),U,8) S:$P(BMXF(BMXI),U,6)]"" BMXREAD=$P(BMXF(BMXI),U,6)
  1. . ;Set BMXY node
  1. . S $P(BMXY(BMXI),"|",3)=BMXTYP
  1. . S $P(BMXY(BMXI),"|",4)=BMXLEN
  1. . S $P(BMXY(BMXI),"|",5)=BMXNAM
  1. . S $P(BMXY(BMXI),"|",6)=BMXREAD
  1. . S $P(BMXY(BMXI),"|",7)=BMXKEY
  1. . S $P(BMXY(BMXI),"|",8)=BMXNULL
  1. ;
  1. Q
  1. PTYPE(BMXDD) ;
  1. ;Traverse pointer chain to retrieve data type of pointed-to field
  1. N BMXFILE
  1. I $P(BMXDD,U,2)'["P" Q BMXDD
  1. S BMXFILE=$P(BMXDD,U,2)
  1. S BMXFILE=+$P(BMXFILE,"P",2)
  1. S BMXDD=$G(^DD(BMXFILE,".01",0))
  1. S BMXDD=$$PTYPE(BMXDD)
  1. Q BMXDD