JSMLR06 LANSA Field List

 

FUNCTION   OPTIONS(*DIRECT)

**********

DEFINE     FIELD(#JSMSTS) TYPE(*CHAR) LENGTH(20)

DEFINE     FIELD(#JSMMSG) TYPE(*CHAR) LENGTH(256)

DEFINE     FIELD(#JSMCMD) TYPE(*CHAR) LENGTH(256)

**********

DEFINE     FIELD(#BNDMAPS) TYPE(*CHAR) LENGTH(10)

DEFINE     FIELD(#BNDMAPL) TYPE(*CHAR) LENGTH(30)

DEFINE     FIELD(#BNDFLDSTR) TYPE(*CHAR) LENGTH(10)

DEFINE     FIELD(#BNDFLDNME) TYPE(*CHAR) LENGTH(10)

DEFINE     FIELD(#BNDFLDDSC) TYPE(*CHAR) LENGTH(40)

DEFINE     FIELD(#BNDFLDFIL) TYPE(*CHAR) LENGTH(10)

**********

DEF_LIST   NAME(#MAPLST) FIELDS((#BNDMAPS) (#BNDMAPL)) TYPE(*WORKING)

**********

DEF_LIST   NAME(#FLDLST) FIELDS((#BNDFLDNME) (#BNDFLDDSC) (#BNDFLDFIL)) TYPE(*WORKING) ENTRYS(9999)

**********

DEF_LIST   NAME(#FLDTABLE) FIELDS((#BNDFLDNME) (#BNDFLDDSC)) TYPE(*WORKING) ENTRYS(9999)

**********

********** Build field/column map

**********

EXECUTE    SUBROUTINE(BLDMAP)

**********

********** Open service

**********

USE        BUILTIN(JSM_OPEN) TO_GET(#JSMSTS #JSMMSG)

EXECUTE    SUBROUTINE(CHECK) WITH_PARMS(#JSMSTS #JSMMSG)

**********

********** Load service

**********

CHANGE     FIELD(#JSMCMD) TO('SERVICE_LOAD SERVICE(RFIDataSourceService) SERVICE_LIST(BNDMAPS,BNDMAPL) BIND(*FIELD) TRACE(*NO)')

USE        BUILTIN(JSM_COMMAND) WITH_ARGS(#JSMCMD) TO_GET(#JSMSTS #JSMMSG #MAPLST)

EXECUTE    SUBROUTINE(CHECK) WITH_PARMS(#JSMSTS #JSMMSG)

**********

********** Create datasource

**********

USE        BUILTIN(JSM_COMMAND) WITH_ARGS('CREATE DATASOURCE(REPOSITORY)') TO_GET(#JSMSTS #JSMMSG)

EXECUTE    SUBROUTINE(CHECK) WITH_PARMS(#JSMSTS #JSMMSG)

**********

********** Add fields

**********

USE        BUILTIN(GET_FIELD_LIST) WITH_ARGS(#BNDFLDSTR) TO_GET(#FLDLST)

**********

SELECTLIST NAMED(#FLDLST)

**********

ADD_ENTRY  TO_LIST(#FLDTABLE)

**********

ENDSELECT

**********

CHANGE     FIELD(#JSMCMD) TO('PUT OBJECT(*TABLE) NAME(FIELD_LIST) SERVICE_LIST(BNDFLDNME,BNDFLDDSC)')

USE        BUILTIN(JSM_COMMAND) WITH_ARGS(#JSMCMD) TO_GET(#JSMSTS #JSMMSG #FLDTABLE)

EXECUTE    SUBROUTINE(CHECK) WITH_PARMS(#JSMSTS #JSMMSG)

**********

********** Send datasource

**********

USE        BUILTIN(JSM_COMMAND) WITH_ARGS('SEND OBJECT(*DATASOURCE)') TO_GET(#JSMSTS #JSMMSG)

EXECUTE    SUBROUTINE(CHECK) WITH_PARMS(#JSMSTS #JSMMSG)

**********

********** Close service and send the HTTP response

**********

USE        BUILTIN(JSM_CLOSE) TO_GET(#JSMSTS #JSMMSG)

EXECUTE    SUBROUTINE(CHECK) WITH_PARMS(#JSMSTS #JSMMSG)

**********

********** SUB ROUTINES

**********

SUBROUTINE NAME(CHECK) PARMS((#JSMSTS *RECEIVED) (#JSMMSG *RECEIVED))

**********

IF         COND('#JSMSTS *NE OK')

**********

********** Close service

**********

USE        BUILTIN(JSM_CLOSE) TO_GET(#JSMSTS #JSMMSG)

**********

ENDIF

**********

ENDROUTINE

**********

SUBROUTINE NAME(BLDMAP)

**********

CHANGE     FIELD(#BNDMAPS) TO(BNDFLDSTR)

CHANGE     FIELD(#BNDMAPL) TO(FIELD_START)

ADD_ENTRY  TO_LIST(#MAPLST)

**********

CHANGE     FIELD(#BNDMAPS) TO(BNDFLDNME)

CHANGE     FIELD(#BNDMAPL) TO(FIELD_NAME)

ADD_ENTRY  TO_LIST(#MAPLST)

**********

CHANGE     FIELD(#BNDMAPS) TO(BNDFLDDSC)

CHANGE     FIELD(#BNDMAPL) TO(FIELD_DESC)

ADD_ENTRY  TO_LIST(#MAPLST)

**********

ENDROUTINE