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

HLCSORAT.m

Go to the documentation of this file.
  1. HLCSORAT ;ALB/MFK/jc - HEALTH LEVEL SEVEN ;07/13/99 15:20 [ 04/02/2003 8:38 AM ]
  1. ;;1.6;HEALTH LEVEL SEVEN;**1004**;APR 1, 2003
  1. ;;1.6;HEALTH LEVEL SEVEN;**57**;Oct 13, 1995
  1. ;Report low level communications errors for serial links (HLLP,
  1. ;X3.28) in file 870.
  1. START ; Main Entry point
  1. N DIR,DIC,X,Y,HLZ,LINE,HLERR,HLSORT,HLAAA,HLSTAT,HLLL,HLQUEUE,POP
  1. N %ZIS,DTOUT,DUOUT,HLDONE,HLTMP,SET,FOO,CODES
  1. S (HLERR,HLSTAT,LINE)=""
  1. D PROMPT I (Y=-1)!($D(DUOUT))!($D(DTOUT)) Q
  1. D OPEN G END:POP
  1. I $D(IO("Q")) D QUEUED,HOME^%ZIS G END
  1. U IO
  1. REPORT ; Output data after gathering
  1. S HLZ=0
  1. ; GATHER AND SORT DATA
  1. D ^HLCSORA1
  1. I 'HLZ G NEXT
  1. I HLDONE G END
  1. F HLAAA=$Y:1:(IOSL-3) W !
  1. I ($E(IOST,1,2)="C-") S DIR(0)="E" D ^DIR K DIR I Y=0!(Y="")!($D(DIRUT)) G END
  1. NEXT ; PRINT THE DATA
  1. D ^HLCSORA2
  1. I 'HLZ W !,"No data found for this request"
  1. END ;
  1. ; Clean up. Kill the ^TMP and other assorted variables.
  1. K ^TMP("HLCSORAT",$J)
  1. I $D(ZTQUEUED) S ZTREQ="@" Q
  1. K DIRUT,HLZ
  1. D ^%ZISC
  1. Q
  1. PROMPT ; Find out how user wants report done
  1. S HLLL=""
  1. S DIR(0)="FAOU"
  1. S DIR("A")="Select HL7 Logical Link: "
  1. S DIR("B")="All Links"
  1. D ^DIR
  1. Q:$D(DTOUT)!($D(DUOUT))
  1. I Y="All Links" S Y=0
  1. I Y'=0 D
  1. .S X=Y,DIC="^HLCS(870,",DIC(0)="EMQZ" D ^DIC K DIC
  1. Q:$D(DTOUT)!($D(DUOUT))
  1. S HLLL=$P(Y,"^",1)
  1. I Y=-1 Q
  1. S DIR(0)="S^I:IN QUEUE;O:OUT QUEUE;B:BOTH"
  1. S DIR("A")="Select queue for report",DIR("B")="B" D ^DIR K DIR
  1. S HLQUEUE=Y
  1. I '("IOB"[Y) Q
  1. S HLQUEUE=$S(HLQUEUE="B":"12",HLQUEUE="I":1,HLQUEUE="O":2)
  1. S SET="",CODES=$$GET1^DID(870.019,2,"","POINTER")
  1. F HLTMP=1:1 S FOO=$P(CODES,";",HLTMP) Q:(FOO="") D
  1. .S SET=SET_$E(FOO,1,1)
  1. ERR S DIR(0)="SOM^"_CODES_"ALL:ALL ERRORS;F:FINISH SELECTING ERRORS"
  1. S DIR("A")="Select an error code to sort by"_$S(HLERR'="":" ("_HLERR_")",1:"")
  1. S DIR("B")=$S((HLERR=""):"ALL",1:"F")
  1. S DIR("?",1)="Select the list of errors that you would like to sort by. There are also"
  1. S DIR("?",2)="two special selections. ALL means that you would like to sort on all the"
  1. S DIR("?")="error codes. F means that you have finished selecting error codes."
  1. D ^DIR K DIR
  1. I ((HLERR'[Y)&(Y'="F")) S HLERR=HLERR_Y
  1. I Y="ALL" S HLERR=SET
  1. I (HLERR="")!($D(DUOUT))!($D(DTOUT)) S Y=-1 Q
  1. I (Y'="ALL")&(Y'="F") G ERR
  1. S SET="",CODES=$$GET1^DID(870.019,1,"","POINTER")
  1. F HLTMP=1:1 S FOO=$P(CODES,";",HLTMP) Q:(FOO="") D
  1. .S SET=SET_$E(FOO,1,1)
  1. STAT S DIR(0)="SOM^"_CODES_"ALL:ALL STATUS;F:FINISH SELECTING STATUS CODES"
  1. S DIR("A")="Select a status code to sort by"_$S(HLSTAT'="":" ("_HLSTAT_")",1:"")
  1. S DIR("B")=$S((HLSTAT=""):"ALL",1:"F")
  1. S DIR("?",1)="Select a status code to sort the report by. There are two special"
  1. S DIR("?",2)="selections. ALL indicates you would like a report on all the statuses. The"
  1. S DIR("?")="F means you are finished selecting statuses."
  1. D ^DIR K DIR
  1. I ((HLSTAT'[Y)&(Y'="F")) S HLSTAT=HLSTAT_Y
  1. I Y="ALL" S HLSTAT=SET
  1. I (HLSTAT="")!($D(DTOUT))!($D(DUOUT)) S Y=-1 Q
  1. I (Y'="ALL")&(Y'="F") G STAT
  1. S HLSORT=HLERR_"^"_HLSTAT
  1. Q
  1. QUEUED ; If queued, set up and kick in TASKMAN
  1. S ZTRTN="REPORT^HLCSORAT",ZTDESC="HL7 LOGICAL LINK REPORT",ZTSAVE("HLLL")="",ZTSAVE("HLQUEUE")="",ZTSAVE("HLSORT")="" D ^%ZTLOAD
  1. W !!,$S($D(ZTSK):"Request Queued",1:"Request Cancelled")
  1. K ZTSK
  1. Q
  1. OPEN ; Open a device
  1. S %ZIS="QM" D ^%ZIS
  1. Q