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

XMJDIR.m

Go to the documentation of this file.
  1. XMJDIR ;ISC-SF/GMB- MailMan's DIR ;10/31/2001 12:33
  1. ;;8.0;MailMan;;Jun 28, 2002
  1. XMDIR(XMDIR,XMOPT,XMOX,XMY,XMABORT) ;
  1. ; XMDIR("A") User prompt
  1. ; XMDIR("B") Default choice
  1. ; XMDIR(0) Special instructions
  1. ; S - Show the choices
  1. ; C - Show choices in 2 columns, if necessary
  1. ; XMDIR("?") Help text for 1 ?
  1. ; XMDIR("??") Help text for 2 or more ?
  1. N XMX
  1. K XMY
  1. I +XMDIR("A")=XMDIR("A") S XMDIR("A")=$$EZBLD^DIALOG(XMDIR("A"))
  1. I $D(XMDIR("B")),+XMDIR("B")=XMDIR("B") S XMDIR("B")=$$EZBLD^DIALOG(XMDIR("B"))
  1. I $G(XMDIR(0))["S" D
  1. . W !!,?5,$$EZBLD^DIALOG(37008),! ; Select one of the following:
  1. . D HELPCMD(.XMOPT,.XMOX,$S(XMDIR(0)["C":IOSL-$Y-3,1:IOSL-4))
  1. F D Q:$D(XMY)!XMABORT
  1. . W !!,XMDIR("A"),$S($D(XMDIR("B")):$P(XMDIR("B"),":",2,99)_"// ",1:"")
  1. . R XMX:DTIME I '$T S XMABORT=DTIME Q
  1. . I XMX[U S XMABORT=1 Q
  1. . I XMX="" D Q
  1. . . I '$D(XMDIR("B")) S XMABORT=1 Q
  1. . . S XMY=$P(XMDIR("B"),":",1)
  1. . I $E(XMX)="?" D QHELP Q
  1. . I $D(XMDIR("PRE")) X XMDIR("PRE")
  1. . S XMY=$$COMMAND(.XMOPT,.XMOX,XMX)
  1. . I $D(XMOPT(XMY)),'$D(XMOPT(XMY,"?")) Q
  1. . I XMY=-1 D
  1. . . W $C(7) D HELPSCR(.XMOPT,.XMOX)
  1. . E D SHOWERR(.XMOPT,XMY) I $D(XMOPT(XMY,"?X")) X XMOPT(XMY,"?X") I $T Q
  1. . K XMY
  1. Q
  1. SHOWERR(XMOPT,XMY) ; Show error message
  1. W $C(7),!
  1. I +XMOPT(XMY,"?")=XMOPT(XMY,"?") D Q
  1. . N XMTEXT
  1. . D BLD^DIALOG(XMOPT(XMY,"?"),"","","XMTEXT","F")
  1. . D MSG^DIALOG("WE","",IOM,"","XMTEXT")
  1. I $D(XMOPT(XMY,"?",1)) D
  1. . N I
  1. . S I=0
  1. . F S I=$O(XMOPT(XMY,"?",I)) Q:'I W !,XMOPT(XMY,"?",I)
  1. W !,XMOPT(XMY,"?")
  1. Q
  1. QHELP ;
  1. I XMX="?" D HELPSCR(.XMOPT,.XMOX) Q
  1. N XQH
  1. S XQH=$G(XMDIR("??"),"XM-U-MO-READ")
  1. I "@"[XQH D HELPSCR(.XMOPT,.XMOX) Q
  1. I $E(XQH,1,2)="D " X XQH Q
  1. D EN^XQH
  1. Q
  1. HELPSCR(XMOPT,XMOX) ;
  1. I $D(XMDIR("?")) D
  1. . N XMTEXT
  1. . W !
  1. . D BLD^DIALOG(XMDIR("?"),"","","XMTEXT","F")
  1. . D MSG^DIALOG("WH","",IOM,"","XMTEXT")
  1. W !!,$$EZBLD^DIALOG(34054),! ; Enter a code from the list.
  1. D HELPCMD(.XMOPT,.XMOX)
  1. Q
  1. HELPCMD(XMOPT,XMOX,XMPMAX) ;
  1. N XMCNT,XMCMD,XMROWS,I,XMHELP,XMLEN
  1. S (XMCNT,XMLEN)=0,XMCMD=""
  1. F S XMCMD=$O(XMOPT(XMCMD)) Q:XMCMD="" I '$D(XMOPT(XMCMD,"?")) S XMCNT=XMCNT+1 I $L(XMOX("O",XMCMD))>XMLEN S XMLEN=$L(XMOX("O",XMCMD))
  1. I XMCNT<$G(XMPMAX,IOSL-4) D Q
  1. . F S XMCMD=$O(XMOX("X",XMCMD)) Q:XMCMD="" D
  1. . . Q:$D(XMOPT(XMOX("X",XMCMD),"?"))
  1. . . W !,?9,$E(XMCMD_" ",1,10)_XMOPT(XMOX("X",XMCMD))
  1. S XMROWS=XMCNT+1\2
  1. S I=0
  1. F D Q:I=XMROWS
  1. . S XMCMD=$O(XMOX("X",XMCMD))
  1. . Q:$D(XMOPT(XMOX("X",XMCMD),"?"))
  1. . S I=I+1
  1. . S XMHELP(I)=" "_$E(XMCMD_" ",1,XMLEN+2)_XMOPT(XMOX("X",XMCMD))
  1. S I=0
  1. F S XMCMD=$O(XMOX("X",XMCMD)) Q:XMCMD="" D
  1. . Q:$D(XMOPT(XMOX("X",XMCMD),"?"))
  1. . S I=I+1
  1. . W !,$E(XMHELP(I)_" ",1,39)_" "_$E(XMCMD_" ",1,XMLEN+2)_$E(XMOPT(XMOX("X",XMCMD)),1,37-XMLEN)
  1. S I=I+1
  1. W:$D(XMHELP(I)) !,XMHELP(I)
  1. Q
  1. COMMAND(XMOPT,XMOX,XMY) ; Check what the user enters against the list of
  1. ; acceptable choices. If the user enters something ambiguous,
  1. ; ^DIR is called to ask the user to choose one.
  1. I XMY?.E1C.E Q -1
  1. I $L(XMY)>64 Q -1
  1. N XMX,XMCD,XMLEN
  1. S XMX=XMY
  1. S XMLEN=$L(XMX)
  1. S XMY=$$UP^XLFSTR(XMY)
  1. I $D(XMOX("X",XMY)) D Q XMCD
  1. . S XMCD=XMOX("X",XMY)
  1. . D PARROT
  1. N XMTXT,XMC,XMT,XMCHOOSE
  1. S XMCD=""
  1. F S XMCD=$O(XMOPT(XMCD)) Q:XMCD="" S:'$D(XMOPT(XMCD,"?")) XMTXT(XMOPT(XMCD))=XMCD
  1. S XMT=$CHAR($A($E(XMY))-1)_"~"
  1. F S XMT=$O(XMTXT(XMT)) Q:XMT=""!($E(XMT)'=$E(XMY)) I $$UP^XLFSTR($E(XMT,1,XMLEN))=XMY S XMCHOOSE(XMT)=""
  1. S XMC=$CHAR($A($E(XMY))-1)_"~"
  1. F S XMC=$O(XMOX("X",XMC)) Q:XMC=""!($E(XMC)'=$E(XMY)) I $$UP^XLFSTR($E(XMC,1,XMLEN))=XMY S:'$D(XMOPT(XMOX("X",XMC),"?")) XMCHOOSE(XMOPT(XMOX("X",XMC)))=""
  1. I '$D(XMCHOOSE) Q -1
  1. N I,DIR,Y,X
  1. S I=0,(DIR(0),XMT)=""
  1. F S XMT=$O(XMCHOOSE(XMT)) Q:XMT="" S I=I+1,DIR(0)=DIR(0)_I_":"_XMT_";",XMCD(I)=XMTXT(XMT)
  1. I I=1 D Q $P(XMCD," ") ; (for Q xxx)
  1. . S XMCD=XMCD(I)
  1. . D PARROT
  1. S DIR(0)="SO^"_$E(DIR(0),1,$L(DIR(0))-1)
  1. ;S DIR("A")="Choose 1-"_I
  1. D ^DIR Q:$D(DIRUT) -1
  1. Q $P(XMCD(Y)," ") ; (for Q xxx)
  1. PARROT ;
  1. I $E(XMOPT(XMCD),1,XMLEN)=XMX W $E(XMOPT(XMCD),XMLEN+1,99) Q
  1. W " ",XMOPT(XMCD)
  1. Q