home *** CD-ROM | disk | FTP | other *** search
/ BCI NET 2 / BCI NET 2.iso / archives / programming / source / term43-source.lha / Extras / Source / term-Source.lha / termGlobal.h < prev    next >
Encoding:
C/C++ Source or Header  |  1995-02-07  |  40.8 KB  |  1,643 lines

  1. /*
  2. **    termGlobal.h
  3. **
  4. **    Global data structure definitions
  5. **
  6. **    Copyright © 1990-1995 by Olaf `Olsen' Barthel
  7. **        All Rights Reserved
  8. */
  9.  
  10.     /* The configuration file format version. This will from now
  11.      * on hopefully stay the same.
  12.      */
  13.  
  14. #define CONFIG_FILE_VERSION    4
  15. #define CONFIG_FILE_REVISION    3
  16.  
  17.     /* Jump table entry. */
  18.  
  19. typedef BYTE (*  JUMP)(UBYTE Char);
  20.  
  21.     /* Pointer to function returning nothing. */
  22.  
  23. typedef VOID (* VPTR)();
  24.  
  25.     /* Capture output routine. */
  26.  
  27. typedef VOID (* __regargs COPTR)(register APTR Data,register LONG Size);
  28.  
  29.     /* Menu item codes. */
  30.  
  31. enum    {    MEN_SAVE_AS_PICTURE=1,MEN_SAVE_AS_TEXT,MEN_PRINT_SCREEN,MEN_PRINT_CLIP,MEN_CAPTURE_TO_FILE,
  32.         MEN_CAPTURE_TO_PRINTER,MEN_ICONIFY,MEN_ABOUT,MEN_QUIT,
  33.  
  34.         MEN_COPY,MEN_PASTE,MEN_CLEAR,
  35.  
  36.         MEN_EXECUTE_DOS_COMMAND,MEN_EXECUTE_REXX_COMMAND,MEN_RECORD,MEN_RECORD_LINE,
  37.         MEN_EDIT_TRAPS,MEN_DISABLE_TRAPS,
  38.  
  39.         MEN_PHONEBOOK,MEN_REDIAL,MEN_DIAL_NUMBER,MEN_SEND_BREAK,
  40.         MEN_HANG_UP,MEN_WAIT,MEN_FLUSH_BUFFER,MEN_RELEASE_DEVICE,
  41.  
  42.         MEN_UPLOAD_ASCII,MEN_DOWNLOAD_ASCII,MEN_UPLOAD_TEXT,MEN_DOWNLOAD_TEXT,MEN_EDIT_AND_UPLOAD_TEXT,
  43.         MEN_UPLOAD_BINARY,MEN_DOWNLOAD_BINARY,
  44.  
  45.         MEN_CLEAR_BUFFER,MEN_DISPLAY_BUFFER,MEN_CLOSE_BUFFER,MEN_FREEZE_BUFFER,MEN_OPEN_BUFFER,
  46.         MEN_SAVE_BUFFER_AS,
  47.  
  48.         MEN_CLEAR_SCREEN,MEN_RESET_FONT,MEN_RESET_STYLES,MEN_RESET_TERMINAL,
  49.  
  50.         MEN_SERIAL,MEN_MODEM,MEN_SCREEN,MEN_TERMINAL,MEN_SET_EMULATION,MEN_CLIPBOARD,MEN_CAPTURE,MEN_COMMANDS,
  51.         MEN_MISC,MEN_PATH,MEN_TRANSFER_PROTOCOL,MEN_TRANSFER,MEN_TRANSLATION,MEN_MACROS,
  52.         MEN_CURSORKEYS,MEN_FAST_MACROS,MEN_HOTKEYS,MEN_SPEECH,MEN_SOUND,MEN_RATES,MEN_SET_CONSOLE,MEN_OPEN_SETTINGS,MEN_SAVE_SETTINGS,
  53.         MEN_SAVE_SETTINGS_AS,
  54.  
  55.         MEN_STATUS_WINDOW,MEN_REVIEW_WINDOW,MEN_PACKET_WINDOW,MEN_CHAT_LINE,MEN_FAST_MACROS_WINDOW,
  56.         MEN_UPLOAD_QUEUE_WINDOW,
  57.  
  58.         // Avoid recompilation
  59.  
  60.         MEN_PRINT_SCREEN_AS_GFX,
  61.         MEN_EXTRA_DIAL
  62.     };
  63.  
  64.     /* Menu item code limit, required by the quick dial menu. */
  65.  
  66. #define DIAL_MENU_LIMIT 1000
  67.  
  68.     /* How many phone book entries will be stored in
  69.      * the quick dial menu.
  70.      */
  71.  
  72. #define DIAL_MENU_MAX    50
  73.  
  74.     /* Undefine the following symbols, the preferences header file
  75.      * will use the same names and the same values.
  76.      */
  77.  
  78. #undef PARITY_NONE
  79. #undef PARITY_EVEN
  80. #undef PARITY_ODD
  81. #undef PARITY_MARK
  82. #undef PARITY_SPACE
  83.  
  84.     /* Serial settings. */
  85.  
  86. enum    {    PARITY_NONE,PARITY_EVEN,PARITY_ODD,PARITY_MARK,PARITY_SPACE };
  87.  
  88. enum    {    HANDSHAKING_NONE,HANDSHAKING_RTSCTS,HANDSHAKING_RTSCTS_DSR };
  89. enum    {    DUPLEX_FULL,DUPLEX_HALF };
  90. enum    {    FLOW_NONE,FLOW_XON_XOFF };
  91.  
  92.     /* Terminal settings. */
  93.  
  94. enum    {    EOL_IGNORE,EOL_CR,EOL_LF,EOL_CRLF,EOL_LFCR };
  95. enum    {    EMULATION_ANSIVT100,EMULATION_ATOMIC,EMULATION_TTY,EMULATION_EXTERNAL,EMULATION_HEX };
  96. enum    {    COLOUR_AMIGA,COLOUR_EIGHT,COLOUR_SIXTEEN,COLOUR_MONO };
  97.  
  98.     /* Protocol types. */
  99.  
  100. enum    {    PROTOCOL_XMODEM,PROTOCOL_XMODEMCRC,PROTOCOL_YMODEM,PROTOCOL_ZMODEM };
  101.  
  102.     /* Font types. */
  103.  
  104. enum    {    FONT_STANDARD,FONT_IBM,FONT_IBM_RAW };
  105.  
  106.     /* Bell modes. */
  107.  
  108. enum    {    BELL_NONE, BELL_VISIBLE, BELL_AUDIBLE, BELL_BOTH, BELL_SYSTEM };
  109.  
  110.     /* Data flow scanner indices. */
  111.  
  112. enum    {    SCAN_NOCARRIER, SCAN_CONNECT, SCAN_VOICE, SCAN_RING, SCAN_BUSY, SCAN_NODIALTONE,
  113.         SCAN_OK, SCAN_ERROR, SCAN_SIGDEFAULTUPLOAD, SIG_DEFAULTUPLOAD,
  114.         SCAN_SIGASCIIUPLOAD,SCAN_SIGASCIIDOWNLOAD, SCAN_SIGTEXTUPLOAD,
  115.         SCAN_SIGTEXTDOWNLOAD, SCAN_SIGBINARYUPLOAD,
  116.         SCAN_SIGBINARYDOWNLOAD, SCAN_COUNT
  117.     };
  118.  
  119.     /* Status types. */
  120.  
  121. enum    {    STATUS_READY,STATUS_HOLDING,STATUS_DIALING,STATUS_UPLOAD,
  122.         STATUS_DOWNLOAD,STATUS_BREAKING,STATUS_HANGUP,
  123.         STATUS_RECORDING,STATUS_RECORDING_LINE
  124.     };
  125.  
  126.     /* Sound types. */
  127.  
  128. enum    {    SOUND_BELL,SOUND_CONNECT,SOUND_DISCONNECT,SOUND_GOODTRANSFER,
  129.         SOUND_BADTRANSFER,SOUND_RING,SOUND_VOICE,SOUND_ERROR,
  130.         SOUND_COUNT
  131.     };
  132.  
  133.     /* Settings types. */
  134.  
  135. enum    {    PREF_ALL,PREF_SERIAL,PREF_MODEM,PREF_COMMAND,PREF_SCREEN,
  136.         PREF_TERMINAL,PREF_PATH,PREF_MISC,PREF_CLIP,PREF_CAPTURE,
  137.         PREF_FILE,PREF_EMULATION,PREF_TRANSFER };
  138.  
  139.     /* Status line modes. */
  140.  
  141. enum    {    STATUSLINE_DISABLED,STATUSLINE_STANDARD,STATUSLINE_COMPRESSED };
  142.  
  143.     /* Capture filter modes. */
  144.  
  145. enum    {    FILTER_NONE,FILTER_ESCAPE,FILTER_CONTROL,FILTER_BOTH };
  146.  
  147.     /* Scrolling modes. */
  148.  
  149. enum    {    SCROLL_JUMP,SCROLL_SMOOTH };
  150.  
  151.     /* Auto-capture file creation. */
  152.  
  153. enum    {    AUTOCAPTURE_DATE_NAME,AUTOCAPTURE_DATE_INCLUDE };
  154.  
  155.     /* Cursor and numeric keypad modes. */
  156.  
  157. enum    {    KEYMODE_STANDARD,KEYMODE_APPLICATION };
  158.  
  159.     /* Font scales. */
  160.  
  161. enum    {    SCALE_NORMAL,SCALE_HALF };
  162. enum    {    SCALE_ATTR_NORMAL,SCALE_ATTR_TOP2X,SCALE_ATTR_BOT2X,SCALE_ATTR_2X };
  163.  
  164.     /* Character tables. */
  165.  
  166. enum    {    TABLE_ASCII,TABLE_GFX };
  167.  
  168.     /* Transfer types. */
  169.  
  170. enum    {    TRANSFER_BINARY,TRANSFER_TEXT,TRANSFER_ASCII };
  171.  
  172.     /* Translation table entry types. */
  173.  
  174. enum    {    TRANSLATE_SINGLE,TRANSLATE_STRING };
  175.  
  176.     /* Upload panel actions. */
  177.  
  178. enum    {    UPLOAD_TEXT=1,UPLOAD_BINARY,UPLOAD_IGNORE,UPLOAD_ABORT,
  179.         UPLOAD_TEXT_FROM_LIST,UPLOAD_BINARY_FROM_LIST,UPLOAD_DUMMY
  180.     };
  181.  
  182.     /* Alert types. */
  183.  
  184. enum    {    ALERT_NONE,ALERT_BEEP,ALERT_SCREEN,ALERT_BEEP_SCREEN };
  185.  
  186.     /* Online time display modes. */
  187.  
  188. enum    {    ONLINETIME_TIME,ONLINETIME_COST,ONLINETIME_BOTH };
  189.  
  190.     /* Clipboard read errors. */
  191.  
  192. enum    {    CLIPERR_NONE,CLIPERR_NOTEXT,CLIPERR_IFF,CLIPERR_OPEN,CLIPERR_MEM };
  193.  
  194.     /* What to print. */
  195.  
  196. enum    {    PRINT_SCREEN,PRINT_CLIP };
  197.  
  198.     /* Dial command types. */
  199.  
  200. enum    {    DIAL_IGNORE,DIAL_LIST,DIAL_REDIAL };
  201.  
  202.     /* Errors returned by ReconfigureSerial(). */
  203.  
  204. enum    {    RECONFIGURE_FAILURE,RECONFIGURE_NOCHANGE,RECONFIGURE_SUCCESS };
  205.  
  206.     /* Operation codes for SetItem(). */
  207.  
  208. enum    {    SETITEM_SETCHECK,SETITEM_CLRCHECK,SETITEM_ON,SETITEM_OFF };
  209.  
  210.     /* File identification actions. */
  211.  
  212. enum    {    IDENTIFY_IGNORE,IDENTIFY_FILETYPE,IDENTIFY_SOURCE };
  213.  
  214.     /* Generic list types. */
  215.  
  216. enum    {    GLIST_UPLOAD,GLIST_DOWNLOAD,GLIST_DIAL,GLIST_WAIT,GLIST_TRAP,GLIST_COUNT };
  217.  
  218.     /* Generic list add operations. */
  219.  
  220. enum    {    ADD_GLIST_BOTTOM,ADD_GLIST_TOP,ADD_GLIST_BEHIND,ADD_GLIST_BEFORE };
  221.  
  222.     /* Dialing modes. */
  223.  
  224. enum    {    DIALMODE_PULSE, DIALMODE_TONE };
  225.  
  226.     /* Transfer window gadgets. */
  227.  
  228. enum    {    GAD_TRANSFER_INFORMATION_LIST=1,
  229.         GAD_TRANSFER_PERCENT,GAD_TRANSFER_TIME,
  230.         GAD_TRANSFER_ABORT,GAD_TRANSFER_SKIP,
  231.         GAD_TRANSFER_PROTOCOL,GAD_TRANSFER_FILE,
  232.         GAD_TRANSFER_SIZE,GAD_TRANSFER_SECONDS,
  233.         GAD_TRANSFER_TOTALTIME,GAD_TRANSFER_ERRORS,
  234.         GAD_TRANSFER_ABORT_FILE
  235.     };
  236.  
  237.     /* How to satisfy OwnDevUnit.library requests. */
  238.  
  239. enum    {    ODU_RELEASE,ODU_WAIT,ODU_KEEP };
  240.  
  241.     /* When to notify the user during a file transfer. */
  242.  
  243. enum    {    XFERNOTIFY_NEVER,XFERNOTIFY_ALWAYS,XFERNOTIFY_START,XFERNOTIFY_END };
  244.  
  245.     /* XPR options setting. */
  246.  
  247. enum    {    GAD_XPROPTIONS_USE=42,GAD_XPROPTIONS_CANCEL };
  248.  
  249.     /* AmigaGuide help context. */
  250.  
  251. enum    {    CONTEXT_MAIN,CONTEXT_SERIAL,CONTEXT_MODEM,CONTEXT_SCREEN,
  252.         CONTEXT_TERMINAL,CONTEXT_CLIP,CONTEXT_CAPTURE,CONTEXT_COMMAND,
  253.         CONTEXT_MISC,CONTEXT_PATHS,CONTEXT_TRANSLATION,CONTEXT_MACROS,
  254.         CONTEXT_CURSOR,CONTEXT_FASTMACROS,CONTEXT_HOTKEYS,CONTEXT_SPEECH,
  255.         CONTEXT_EMULATION,CONTEXT_TRANSFER,CONTEXT_PHONEBOOK,CONTEXT_DATE,
  256.         CONTEXT_DAY,CONTEXT_IMPORT,CONTEXT_RATES,CONTEXT_TIME,
  257.         CONTEXT_COPY,CONTEXT_PASSWORDUSER,CONTEXT_DIAL,CONTEXT_PRINT,
  258.         CONTEXT_TEXTBUFFER,CONTEXT_PACKETWINDOW,CONTEXT_SOUND,
  259.         CONTEXT_LIBS,CONTEXT_ASCII,CONTEXT_PENS,CONTEXT_UPLOAD_QUEUE,
  260.         CONTEXT_TRAPS,CONTEXT_AREA_CODES,CONTEXT_MAIN_MENU,
  261.         CONTEXT_BUFFER_MENU,CONTEXT_PACKET_MENU,CONTEXT_PROJECT_MEN,
  262.         CONTEXT_EDIT_MEN,CONTEXT_CMDS_MEN,CONTEXT_PHONE_MEN,
  263.         CONTEXT_TRANSF_MEN,CONTEXT_BUFFER_MEN,CONTEXT_TERMINAL_MEN,
  264.         CONTEXT_SETTINGS_MEN,CONTEXT_WINDOWS_MEN,CONTEXT_DIAL_MEN,
  265.         CONTEXT_TEXTPEN_PANEL,CONTEXT_ASCII_TRANSFER_SETTINGS,
  266.         CONTEXT_PARAMETERS,CONTEXT_SIGNATURE
  267.  
  268.     };
  269.  
  270.     /* Character types. */
  271.  
  272. enum    {    CHAR_VANILLA,CHAR_CURSOR,CHAR_FUNCTION,CHAR_HELP,
  273.         CHAR_XON,CHAR_XOFF,CHAR_ENTER,CHAR_RETURN };
  274.  
  275.     /* Review window positioning codes. */
  276.  
  277. enum    {    REVIEW_MOVE_TOP,REVIEW_MOVE_BOTTOM,REVIEW_MOVE_UP,REVIEW_MOVE_DOWN };
  278.  
  279.     /* File type classes. */
  280.  
  281. enum    {    FILETYPE_NONE,FILETYPE_DIR,FILETYPE_FILE,FILETYPE_TEXT,FILETYPE_SOUND,
  282.         FILETYPE_PICTURE,FILETYPE_PREFS,FILETYPE_ARCHIVE,
  283.         FILETYPE_PROGRAM,
  284.  
  285.         FILETYPE_COUNT };
  286.  
  287.     /* Text pacing modes. */
  288.  
  289. enum    {    PACE_DIRECT,PACE_ECHO,PACE_ANYECHO,PACE_PROMPT,PACE_DELAY,PACE_KEYBOARD };
  290.  
  291.     /* Where to open the buffer text window. */
  292.  
  293. enum    {    BUFFER_TOP,BUFFER_END };
  294.  
  295.     /* Where to place the buffer screen horizontally. */
  296.  
  297. enum    {    SCREEN_LEFT,SCREEN_CENTRE,SCREEN_RIGHT };
  298.  
  299.     /* File transfer mode. */
  300.  
  301. enum    {    XFER_XPR,XFER_EXTERNALPROGRAM,XFER_DEFAULT,XFER_INTERNAL };
  302.  
  303.     /* File transfer protocol signatures. */
  304.  
  305. enum    {    TRANSFERSIG_DEFAULTUPLOAD,TRANSFERSIG_DEFAULTDOWNLOAD,
  306.         TRANSFERSIG_ASCIIUPLOAD,TRANSFERSIG_ASCIIDOWNLOAD,
  307.         TRANSFERSIG_TEXTUPLOAD,TRANSFERSIG_TEXTDOWNLOAD,
  308.         TRANSFERSIG_BINARYUPLOAD,TRANSFERSIG_BINARYDOWNLOAD
  309.     };
  310.  
  311.     /* Some raw key codes. */
  312.  
  313. #define HELP_CODE        95
  314. #define DEL_CODE        70
  315. #define BACKSPACE_CODE        65
  316. #define RAMIGA_CODE        103
  317. #define TAB_CODE        66
  318.  
  319. #define CURSOR_UP_CODE        76
  320. #define CURSOR_DOWN_CODE    77
  321. #define CURSOR_RIGHT_CODE    78
  322. #define CURSOR_LEFT_CODE    79
  323.  
  324. #define F01_CODE        80
  325. #define F02_CODE        81
  326. #define F03_CODE        82
  327. #define F04_CODE        83
  328. #define F05_CODE        84
  329. #define F06_CODE        85
  330. #define F07_CODE        86
  331. #define F08_CODE        87
  332. #define F09_CODE        88
  333. #define F10_CODE        89
  334.  
  335.     /* A couple of useful minterms. */
  336.  
  337. #define MINTERM_ZERO        0
  338. #define MINTERM_ONE        ABC | ABNC | ANBC | ANBNC | NABC | NABNC | NANBC | NANBNC
  339. #define MINTERM_COPY        ABC | ABNC | NABC | NABNC
  340. #define MINTERM_NOT_C        ABNC | ANBNC | NABNC | NANBNC
  341. #define MINTERM_B_AND_C        ABC | NABC
  342. #define MINTERM_NOT_B_AND_C    ANBC | NANBC
  343. #define MINTERM_B_OR_C        ABC | ABNC | NABC | NABNC | ANBC | NANBC
  344.  
  345.     /* Printer control bits. */
  346.  
  347. #define PRINT_SERIAL    (1L << 0)
  348. #define PRINT_MODEM    (1L << 1)
  349. #define PRINT_SCREEN    (1L << 2)
  350. #define PRINT_TERMINAL    (1L << 3)
  351. #define PRINT_USERNAME    (1L << 4)
  352. #define PRINT_COMMENT    (1L << 5)
  353. #define PRINT_SIZE    (1L << 6)
  354. #define PRINT_DATE    (1L << 7)
  355. #define PRINT_BITS    (1L << 8)
  356.  
  357.     /* Day of week flags. */
  358.  
  359. #define DAY_MONDAY    (1L << 0)
  360. #define DAY_TUESDAY    (1L << 1)
  361. #define DAY_WEDNESDAY    (1L << 2)
  362. #define DAY_THURSDAY    (1L << 3)
  363. #define DAY_FRIDAY    (1L << 4)
  364. #define DAY_SATURDAY    (1L << 5)
  365. #define DAY_SUNDAY    (1L << 6)
  366.  
  367.     /* These signal masks will make life a bit easier. */
  368.  
  369. #define SIG_WINDOW    (1L << Window -> UserPort -> mp_SigBit)
  370. #define SIG_SERIAL    (ReadPort ? 1L << ReadPort -> mp_SigBit : NULL)
  371. #define SIG_TIMER    (1L << TimePort -> mp_SigBit)
  372. #define SIG_QUEUE    (SpecialQueue -> SigMask)
  373. #define SIG_CHECK    (1L << CheckBit)
  374. #define SIG_WORKBENCH    (1L << WorkbenchPort -> mp_SigBit)
  375. #define SIG_REXX    (1L << TermRexxPort -> mp_SigBit)
  376.  
  377.     /* Task termination and handshake signal. Note: don't try this at
  378.      * home kids, we are all trained professionals here!
  379.      */
  380.  
  381. #define SIG_KILL    SIGBREAKF_CTRL_C
  382. #define SIG_HANDSHAKE    SIGF_SINGLE
  383.  
  384.     /* Double-buffered file server command. */
  385.  
  386. #define    SIG_COMMAND    SIGBREAKF_CTRL_D
  387.  
  388.     /* ARexx break signal. */
  389.  
  390. #define SIG_BREAK    SIGBREAKF_CTRL_D
  391.  
  392.     /* Hotkey reset command. */
  393.  
  394. #define SIG_RESET    SIGBREAKF_CTRL_D
  395.  
  396.     /* Skip dial entry. */
  397.  
  398. #define SIG_SKIP    SIGBREAKF_CTRL_D
  399.  
  400.     /* Status commands. */
  401.  
  402. #define SIG_BELL    SIGBREAKF_CTRL_D
  403. #define SIG_RESETTIME    SIGBREAKF_CTRL_E
  404.  
  405.     /* Buffer special signals. */
  406.  
  407. #define SIG_TOFRONT    SIGBREAKF_CTRL_D
  408. #define SIG_UPDATE    SIGBREAKF_CTRL_E
  409. #define SIG_MOVEUP    SIGBREAKF_CTRL_F
  410.  
  411.     /* Status display task. */
  412.  
  413. #define SIG_CLOSEWINDOW    SIGBREAKF_CTRL_F
  414.  
  415.     /* Upload queue. */
  416.  
  417. #define SIG_SHOW    SIGBREAKF_CTRL_D
  418. #define SIG_HIDE    SIGBREAKF_CTRL_E
  419. #define SIG_GOAWAY    SIGBREAKF_CTRL_F
  420.  
  421.     /* A port signal mask. */
  422.  
  423. #define PORTMASK(P)    (1L << (((struct MsgPort *)(P)) -> mp_SigBit))
  424.  
  425.     /* Replacements for CheckItem() and OnMenu()/OffMenu(). */
  426.  
  427. #define CheckItem(ID,Mode)    SetItem(ID,Mode ? SETITEM_SETCHECK : SETITEM_CLRCHECK)
  428. #define OnItem(ID)        SetItem(ID,SETITEM_ON)
  429. #define OffItem(ID)        SetItem(ID,SETITEM_OFF)
  430.  
  431.     /* A handy signal macro. */
  432.  
  433. #define ClrSignal(Signals)    SetSignal(0,Signals)
  434.  
  435.     /* Another neat macro. */
  436.  
  437. #define NumElements(s)        (sizeof(s) / sizeof((s)[0]))
  438. #define NEW(t)            t = AllocVecPooled(sizeof(* ## t),MEMF_ANY | MEMF_CLEAR)
  439. #define DISPOSE(x)        { FreeVecPooled(x); x = NULL; }
  440.  
  441.     /* Definitions to access the line signal setting functions supported by
  442.      * some IO serial boards (namely the ASDG board).
  443.      */
  444.  
  445. #define SIOCMD_SETCTRLLINES    (CMD_NONSTD + 7)
  446. #define SIOB_RTSB        0
  447. #define SIOB_DTRB        1
  448. #define SIOB_RTSF        (1L << SIOB_RTSB)
  449. #define SIOB_DTRF        (1L << SIOB_DTRB)
  450.  
  451.     /* Turn time of day into `compressed' format. */
  452.  
  453. #define DT_GET_TIME(Hour,Minute) ((Minute) / 10 + (Hour) * 6)
  454.  
  455.     /* Vector offsets for the TimeDate structure. */
  456.  
  457. enum    { DT_FIRST_UNIT,DT_NEXT_UNIT };
  458.  
  459.     /* Multiply lines and columns with the current font size. */
  460.  
  461. #define MUL_X(x)        OffsetXTable[x]
  462. #define MUL_Y(y)        OffsetYTable[y]
  463.  
  464.     /* A handy and short alias. */
  465.  
  466. #define TICK            (CHECKIT | MENUTOGGLE)
  467.  
  468.     /* For now the maximum length of a path/file name. */
  469.  
  470. #define MAX_FILENAME_LENGTH    256
  471.  
  472.     /* The maximum width of a line to be stored in the text buffer. */
  473.  
  474. #define BUFFER_LINE_MAX        255
  475.  
  476.     /* User interface definitions. */
  477.  
  478. #define SZ_AutoWidth    TAG_USER+2    /* Use default width? */
  479. #define SZ_NewColumn    TAG_USER+4    /* Start new column */
  480. #define SZ_Lines    TAG_USER+5    /* Number of lines in object */
  481.  
  482.     /* Box information types. */
  483.  
  484. enum    {    BOX_LEFT,BOX_TOP,BOX_WIDTH,BOX_HEIGHT };
  485.  
  486.     /* Status gadget properties. */
  487.  
  488. #define SGA_FullWidth    (TAG_USER+42)
  489. #define SGA_Mode    (TAG_USER+43)
  490.  
  491.     /* Sizing gadget sizes. */
  492.  
  493. #define SIZE_GADGET_WIDTH_HIGH    18
  494. #define SIZE_GADGET_WIDTH_LOW    13
  495.  
  496.     /* Some windows to be opened on the main screen. */
  497.  
  498. enum    {    WINDOW_PACKET,WINDOW_STATUS,WINDOW_FILE,
  499.         WINDOW_REVIEW,WINDOW_FAST,WINDOW_FONT,
  500.         WINDOW_SCREEN,WINDOW_PERF,WINDOW_MAIN,
  501.  
  502.         WINDOW_COUNT };
  503.  
  504.     /* Window alignment information. */
  505.  
  506. #define WC_ALIGNLEFT    (1<<0)
  507. #define WC_ALIGNRIGHT    (1<<1)
  508. #define WC_ALIGNTOP    (1<<2)
  509. #define WC_ALIGNBOTTOM    (1<<3)
  510. #define WC_EXPANDWIDTH    (1<<4)
  511. #define WC_EXPANDHEIGHT    (1<<5)
  512. #define WC_ALIGNSIDE    (1<<6)
  513. #define WC_ALIGNBELOW    (1<<7)
  514.  
  515.     /* The chat line gadget ID. */
  516.  
  517. #define CHAT_ID        744
  518.  
  519.     /* Screen mode list entry. */
  520.  
  521. struct ModeNode
  522. {
  523.     struct Node    VanillaNode;
  524.     ULONG        DisplayID;
  525. };
  526.  
  527.     /* Trap management. */
  528.  
  529. struct TrapNode
  530. {
  531.     struct Node    Node;
  532.     LONG        Count,
  533.             SequenceLen;
  534.     STRPTR        Sequence,
  535.             Command;
  536. };
  537.  
  538.     /* Trap preferences, not much. */
  539.  
  540. struct TrapSettings
  541. {
  542.     BYTE        Enabled,
  543.             Pad;
  544. };
  545.  
  546.     /* Window alignment data. */
  547.  
  548. struct WindowInfo
  549. {
  550.     UWORD    ID;
  551.     UWORD    WindowFlags;
  552.  
  553.     LONG    Left,
  554.         Top,
  555.         Width,
  556.         Height;
  557. };
  558.  
  559.     /* Special character treatment. */
  560.  
  561. struct SpecialKey
  562. {
  563.     UBYTE    Key;
  564.     BYTE    (*  Routine)(VOID);
  565. };
  566.  
  567.     /* Cursor backup data. */
  568.  
  569. struct CursorData
  570. {
  571.     struct TextFont        *CurrentFont;
  572.     WORD             CursorX,
  573.                  CursorY;
  574.     BYTE             Charset;
  575.     BYTE             CharMode[2];
  576.     BYTE             Attributes;
  577.     BYTE             FgPen,
  578.                  BgPen;
  579.     UBYTE             Style;
  580. };
  581.  
  582.     /* File transfer information. */
  583.  
  584. struct FileTransferNode
  585. {
  586.     struct MinNode         Node;
  587.     ULONG             Size;
  588.     STRPTR             Name;
  589. };
  590.  
  591. struct FileTransferInfo
  592. {
  593.     struct MinList         FileList;
  594.     ULONG             TotalSize;
  595.     LONG             TotalFiles;
  596.  
  597.     ULONG             DoneSize;
  598.     LONG             DoneFiles;
  599.  
  600.     struct FileTransferNode    *CurrentFile;
  601.     ULONG             CurrentSize;
  602. };
  603.  
  604.     /* Global data link. */
  605.  
  606. struct TermPort
  607. {
  608.     struct MsgPort         ExecNode;
  609.  
  610.     struct Window        *TopWindow;
  611.  
  612.     struct SignalSemaphore     OpenSemaphore;
  613.  
  614.     LONG             ID,OpenCount,HoldIt;
  615.     LONG             Reserved[5];
  616. };
  617.  
  618.     /* Buffer search support. */
  619.  
  620. struct SearchInfo
  621. {
  622.     UBYTE    Distance[256],
  623.         Pattern[256];
  624.     LONG    FoundX,
  625.         FoundY;
  626.     WORD    PatternWidth;
  627.     WORD    Index;
  628.     BOOLEAN    Forward,
  629.         IgnoreCase,
  630.         WholeWords;
  631. };
  632.  
  633. struct SearchContext
  634. {
  635.     struct Window        *SearchWindow;
  636.     struct LayoutHandle    *SearchHandle;
  637.  
  638.     UBYTE             LocalBuffer[256];
  639.     STRPTR             Buffer;
  640.  
  641.     BOOLEAN             Ok;
  642. };
  643.  
  644.     /* Support for optimized scrolling routines. */
  645.  
  646. struct ScrollLineInfo
  647. {
  648.     UWORD             Left,Right,Width,
  649.                  ColourMask;
  650. };
  651.  
  652.     /* A dial list entry. */
  653.  
  654. struct PhoneNode
  655. {
  656.     struct Node         VanillaNode;
  657.  
  658.     UBYTE             LocalName[50];
  659.  
  660.     struct PhoneEntry    *Entry;
  661. };
  662.  
  663.     /* A Fast! macro list entry. */
  664.  
  665. struct MacroNode
  666. {
  667.     struct MacroNode    *mn_Succ;    /* Modeled after the default Node. */
  668.     struct MacroNode    *mn_Pred;
  669.  
  670.     WORD             mn_Pad;    /* Included only for Node compatibility. */
  671.  
  672.     UBYTE            *mn_Macro;    /* = ln_Name, title */
  673.     UBYTE            *mn_Code;    /* The execution code. */
  674. };
  675.  
  676.     /* Speech preferences. */
  677.  
  678. struct SpeechConfig
  679. {
  680.     WORD            Rate,
  681.                 Pitch;
  682.     LONG            Frequency;
  683.     BYTE            Sex,
  684.                 Volume,
  685.                 Enabled,
  686.                 Pad;
  687. };
  688.  
  689.     /* Sound preferences */
  690.  
  691. struct SoundConfig
  692. {
  693.     UBYTE            BellFile[MAX_FILENAME_LENGTH],
  694.  
  695.                 ConnectFile[MAX_FILENAME_LENGTH],
  696.                 DisconnectFile[MAX_FILENAME_LENGTH],
  697.  
  698.                 GoodTransferFile[MAX_FILENAME_LENGTH],
  699.                 BadTransferFile[MAX_FILENAME_LENGTH],
  700.  
  701.                 RingFile[MAX_FILENAME_LENGTH],
  702.                 VoiceFile[MAX_FILENAME_LENGTH];
  703.  
  704.     BYTE            Preload,
  705.                 Pad;
  706.     BYTE            Volume,
  707.                 Pad2;
  708.  
  709.     UBYTE            ErrorNotifyFile[MAX_FILENAME_LENGTH];
  710. };
  711.  
  712.     /* Macro Preferences. */
  713.  
  714. struct MacroKeys
  715. {
  716.     UBYTE            Keys[4][10][256];
  717. };
  718.  
  719.     /* Cursor key preferences. */
  720.  
  721. struct CursorKeys
  722. {
  723.     UBYTE            Keys[4][4][256];
  724. };
  725.  
  726.     /* Translation table entry. */
  727.  
  728. struct TranslationEntry
  729. {
  730.     STRPTR            String;        /* Corresponding code string. */
  731.     UBYTE            Type;        /* Table entry type. */
  732.     UBYTE            Len;        /* String length if any. */
  733.     UBYTE            Extra;        /* Saves space, don't need to allocate memory for this one. */
  734.     UBYTE            Null;        /* Terminating null. */
  735. };
  736.  
  737. struct TranslationHeader
  738. {
  739.     UBYTE            Type;        /* Table entry type. */
  740.     UBYTE            Code;        /* Table offset. */
  741.     UBYTE            Len;        /* Entry length. */
  742.     UBYTE            Pad;
  743. };
  744.  
  745.     /* Buffer translation handle. */
  746.  
  747. struct TranslationHandle
  748. {
  749.     STRPTR            LocalBuffer;
  750.     LONG            LocalLen;
  751.  
  752.     STRPTR            SourceBuffer;
  753.     LONG            SourceLen;
  754.  
  755.     STRPTR            DestinationBuffer;
  756.     LONG            DestinationLen;
  757.  
  758.     struct TranslationEntry    **Table;
  759. };
  760.  
  761.     /* term hotkey configuration. */
  762.  
  763. struct HotkeysOld
  764. {
  765.     UBYTE            termScreenToFront[256];
  766.     UBYTE            BufferScreenToFront[256];
  767.     UBYTE            SkipDialEntry[256];
  768.     BYTE            CommodityPriority;
  769.     BYTE            HotkeysEnabled;
  770.  
  771.     ULONG            Reserved[25];
  772. };
  773.  
  774. struct Hotkeys
  775. {
  776.     UBYTE            termScreenToFront[256];
  777.     UBYTE            BufferScreenToFront[256];
  778.     UBYTE            SkipDialEntry[256];
  779.     BYTE            CommodityPriority;
  780.     BYTE            HotkeysEnabled;
  781.  
  782.     ULONG            Reserved[25];
  783.  
  784.     UBYTE            AbortARexx[256];
  785. };
  786.  
  787.     /* Time/date structure. */
  788.  
  789. struct TimeDate
  790. {
  791.     LONG             Count;        /* Table size. */
  792.     WORD             PayPerUnit[2],    /* Pay for each unit. */
  793.                  SecPerUnit[2];    /* Number of seconds each unit lasts. */
  794.     UBYTE             Time,        /* The time associated with this entry. */
  795.                  Pad;
  796. };
  797.  
  798.     /* Time date header information. */
  799.  
  800. struct TimeDateHeader
  801. {
  802.     UBYTE             Comment[22];    /* Comment for this entry. */
  803.  
  804.     BYTE             Month,        /* Month of year or -1 -> Day = bitmapped days of week. */
  805.                  Day;        /* Day of month or -1 -> standard settings. */
  806. };
  807.  
  808. struct TimeDateNode
  809. {
  810.     struct Node         VanillaNode;    /* Default node entry. */
  811.     UBYTE             Buffer[30];    /* Name buffer. */
  812.  
  813.     struct TimeDate        *Table;        /* Table of time/date entries. */
  814.  
  815.     struct TimeDateHeader     Header;    /* Header information. */
  816. };
  817.  
  818. struct TimeNode
  819. {
  820.     struct Node         VanillaNode;    /* Default node entry. */
  821.     UBYTE             Name[20];    /* Name string. */
  822.     UBYTE             Time;        /* The time for this entry. */
  823. };
  824.  
  825.     /* This node type links phone number patterns
  826.      * and date/time lists.
  827.      */
  828.  
  829. struct PatternNode
  830. {
  831.     struct Node        Node;
  832.     UBYTE            Pattern[256],
  833.                     Comment[40];
  834.     struct List        List;
  835. };
  836.  
  837.     /* Serial settings. */
  838.  
  839. struct SerialSettings
  840. {
  841.     ULONG    BaudRate;        /* Baud rate. */
  842.     ULONG    BreakLength;        /* Length of break signal in microseconds. */
  843.     ULONG    SerialBufferSize;    /* Size of serial read/write buffer. */
  844.  
  845.     UBYTE    SerialDevice[MAX_FILENAME_LENGTH];
  846.                     /* Serial device name. */
  847.     LONG    UnitNumber;        /* Serial device unit number. */
  848.  
  849.     BYTE    BitsPerChar;        /* Bits per character. */
  850.     BYTE    Parity;            /* Parity check mode. */
  851.     BYTE    StopBits;        /* Number of stop bits. */
  852.     BYTE    HandshakingProtocol;    /* Handshaking protocol (RTS/CTS, etc.). */
  853.     BYTE    Duplex;            /* Full- or half-duplex? */
  854.  
  855.     BYTE    xONxOFF;        /* xON/xOFF handshaking enabled? */
  856.     BYTE    HighSpeed;        /* Radboogie? */
  857.     BYTE    Shared;            /* Shared device access? */
  858.     BYTE    StripBit8;        /* Strip high-order bit? */
  859.     BYTE    CheckCarrier;        /* Track the carrier signal? */
  860.     BYTE    PassThrough;        /* Pass xON/xOFF characters through to modem? */
  861.     BYTE    UseOwnDevUnit;        /* Enable OwnDevUnit.library? */
  862.  
  863.     ULONG    Quantum;        /* Buffer read quantum. */
  864.  
  865.     BYTE    IgnoreCarrier;        /* Ignore carrier signal. */
  866.  
  867.     BYTE    UseNet;            /* Use DNet-ID. */
  868.     UWORD    NetID;            /* The DNet-ID to use. */
  869.  
  870.     BYTE    SatisfyODURequests;    /* How to satisfy ODU requests. */
  871.     BYTE    Pad;
  872.  
  873.     UWORD    LastVersionSaved,    /* The last version the config file was saved with. */
  874.         LastRevisionSaved;
  875. };
  876.  
  877.     /* Modem settings. */
  878.  
  879. struct ModemSettings
  880. {
  881.     UBYTE    ModemInit[80];        /* Modem init string. */
  882.     UBYTE     ModemExit[80];        /* Modem exit string. */
  883.     UBYTE     ModemHangup[80];    /* Modem hangup string. */
  884.     UBYTE    DialPrefix[80];        /* Dial command prefix. */
  885.     UBYTE    DialSuffix[80];        /* Dial command suffix. */
  886.  
  887.     UBYTE    NoCarrier[16];        /* `No carrier' string. */
  888.     UBYTE    NoDialTone[16];        /* `No dialtone' string. */
  889.     UBYTE    Connect[16];        /* `Connect' string. */
  890.     UBYTE    Voice[16];        /* `Voice' string. */
  891.     UBYTE    Ring[16];        /* `Ring' string. */
  892.     UBYTE    Busy[16];        /* `Busy' string. */
  893.  
  894.     LONG    RedialDelay;        /* Length of redial delay. */
  895.     LONG    DialRetries;        /* Number of dial retries. */
  896.     LONG    DialTimeout;        /* Length of dial timeout. */
  897.     BYTE    ConnectAutoBaud;    /* Use baud rate returned by modem? */
  898.     BYTE    DropDTR;        /* Drop the DTR signal on hangup? */
  899.     BYTE    RedialAfterHangup;    /* Redial list after hangup? */
  900.     BYTE    VerboseDialing;        /* Output modem responses while dialing? */
  901.  
  902.     UBYTE    Ok[16];            /* `Ok' string. */
  903.     UBYTE    Error[16];        /* `Error' string. */
  904.  
  905.     BYTE    NoCarrierIsBusy;    /* Treat `NO CARRIER' as `BUSY' signal? */
  906.     BYTE    AbortHangsUp;        /* Dialer `Abort' sends hangup string? */
  907.  
  908.     WORD    ConnectLimit;                /* Connection limit. */
  909.     UBYTE    ConnectLimitMacro[MAX_FILENAME_LENGTH];    /* Macro to be executed when limit is reached. */
  910.  
  911.     LONG    TimeToConnect;        /* Number of seconds to pass between modem picking up
  912.                      * the line and issuing the `CONNECT' message.
  913.                      */
  914.  
  915.     BYTE    DialMode;        /* Use tone or pulse dialing? */
  916.     BYTE    Pad;
  917. };
  918.  
  919.     /* Command settings. */
  920.  
  921. struct CommandSettings
  922. {
  923.     UBYTE    StartupMacro[256];    /* Startup macro. */
  924.     UBYTE    LogoffMacro[256];    /* Macro executed after carrier has dropped or hung up. */
  925.     UBYTE    UploadMacro[256];    /* Macro to execute after a successful upload. */
  926.     UBYTE    DownloadMacro[256];    /* Macro to execute after a successful download. */
  927.  
  928.     UBYTE    LoginMacro[256];    /* Login macro, complements the logoff macro. */
  929. };
  930.  
  931.     /* Screen settings. */
  932.  
  933. struct ScreenSettings
  934. {
  935.     ULONG    DisplayMode;            /* Screen display mode. */
  936.     WORD    ColourMode;            /* The terminal colour mode. */
  937.     UWORD    Colours[16];            /* Colour palette. */
  938.     UBYTE    FontName[MAX_FILENAME_LENGTH];    /* Default user interface font. */
  939.     WORD    FontHeight;            /* Default user interface font height. */
  940.  
  941.     BYTE    MakeScreenPublic;        /* Are we to make our screen public? */
  942.     BYTE    ShanghaiWindows;        /* Are we to `shanghai' windows? */
  943.  
  944.     BYTE    Blinking;            /* Screen blinking enabled? */
  945.     BYTE    FasterLayout;            /* Faster screen layout? */
  946.     BYTE    TitleBar;            /* Is the screen title bar enabled? */
  947.     BYTE    StatusLine;            /* Which mode is the status line in? */
  948.  
  949.     BYTE    UseWorkbench;            /* Use the Workbench screen for the terminal window? */
  950.  
  951.     UBYTE    PubScreenName[MAXPUBSCREENNAME + 1];    /* Name of public screen to open window upon. */
  952.  
  953.     BYTE    TimeMode;            /* Online time/fee display. */
  954.     BYTE    Depth;                /* Screen depth if any, 0 = don't bother. */
  955.  
  956.     BYTE    UsePens;            /* Use special screen pens? */
  957.     BYTE    PenColourMode;            /* For which colour mode was the pen array built? */
  958.  
  959.     UWORD    PenArray[16];            /* Pen index array. */
  960.  
  961.     ULONG    DisplayWidth,            /* Screen width. */
  962.         DisplayHeight;            /* Screen height. */
  963.     UWORD    OverscanType;            /* Screen overscan type. */
  964.  
  965.     BYTE    ShareScreen;            /* Don't open a backdrop window, share pens. */
  966.     BYTE    SplitStatus;            /* Split the status line from the main window. */
  967.  
  968.     BYTE    Pad;
  969.     BYTE    UseColours96;            /* Use the 96 bit colours? */
  970.     ULONG    Colours96[16 * 3];        /* The 96 bit colour table. */
  971. };
  972.  
  973.     /* Terminal settings. */
  974.  
  975. struct TerminalSettings
  976. {
  977.     BYTE    BellMode;                /* The bell mode. */
  978.     BYTE    AlertMode;                /* The user alert mode. */
  979.     BYTE    EmulationMode;                /* The terminal emulation mode. */
  980.     BYTE    FontMode;                /* The font mode. */
  981.  
  982.     BYTE    SendCR;                    /* Standard translations. */
  983.     BYTE    SendLF;
  984.     BYTE    ReceiveCR;
  985.     BYTE    ReceiveLF;
  986.  
  987.     UWORD    NumColumns,                /* Size of the terminal window. */
  988.         NumLines;
  989.  
  990.     UBYTE    KeyMapFileName[MAX_FILENAME_LENGTH];    /* Name of custom keymap file. */
  991.     UBYTE    EmulationFileName[MAX_FILENAME_LENGTH];    /* External emulation file name. */
  992.     UBYTE    BeepFileName[MAX_FILENAME_LENGTH];    /* Name of the custom beep sound file. */
  993.  
  994.     UBYTE    TextFontName[MAX_FILENAME_LENGTH];    /* Terminal text font name. */
  995.     WORD    TextFontHeight;                /* Terminal text font height. */
  996.  
  997.     BYTE    UseTerminalTask;            /* Enable the terminal emulation process. */
  998.     BYTE    Pad;
  999.  
  1000.     UBYTE    IBMFontName[MAX_FILENAME_LENGTH];    /* Terminal text font name. */
  1001.     WORD    IBMFontHeight;                /* Terminal text font height. */
  1002. };
  1003.  
  1004.     /* Path settings. */
  1005.  
  1006. struct PathSettings
  1007. {
  1008.     UBYTE    ASCIIUploadPath[MAX_FILENAME_LENGTH];        /* Default ASCII upload file path. */
  1009.     UBYTE    ASCIIDownloadPath[MAX_FILENAME_LENGTH];        /* Default ASCII download file path. */
  1010.  
  1011.     UBYTE    TextUploadPath[MAX_FILENAME_LENGTH];        /* Default text upload file path. */
  1012.     UBYTE    TextDownloadPath[MAX_FILENAME_LENGTH];        /* Default text download file path. */
  1013.  
  1014.     UBYTE    BinaryUploadPath[MAX_FILENAME_LENGTH];        /* Default binary data upload file path. */
  1015.     UBYTE    BinaryDownloadPath[MAX_FILENAME_LENGTH];    /* Default binary data download file path. */
  1016.  
  1017.     UBYTE    DefaultStorage[MAX_FILENAME_LENGTH];        /* Default configuration storage path. */
  1018.  
  1019.     UBYTE    Editor[MAX_FILENAME_LENGTH];            /* Text file editor to use. */
  1020.  
  1021.     UBYTE    HelpFile[MAX_FILENAME_LENGTH];            /* Help text file. */
  1022. };
  1023.  
  1024.     /* Miscellaneous settings. */
  1025.  
  1026. struct MiscSettings
  1027. {
  1028.     BYTE    Priority;        /* Program priority. */
  1029.     BYTE    BackupConfig;        /* Save the configuration between calls? */
  1030.  
  1031.     BYTE    OpenFastMacroPanel;    /* Open the fast! macro panel? */
  1032.     BYTE    ReleaseDevice;        /* Release serial device when iconified? */
  1033.  
  1034.     BYTE    TransferServer;        /* Enable data transfer server? */
  1035.     BYTE    EmulationServer;    /* Enable terminal emulation server? */
  1036.  
  1037.     BYTE    OverridePath;        /* Override the protocol transfer path? */
  1038.     BYTE    AutoUpload;        /* Enable the auto-upload panel? */
  1039.     BYTE    SetArchivedBit;        /* Set the archived bit for files sent? */
  1040.     BYTE    IdentifyFiles;        /* Try to identify files after download? */
  1041.  
  1042.     BYTE    TransferIcons;        /* Transfer files along with their icons? */
  1043.     BYTE    CreateIcons;        /* Create icons for files saved? */
  1044.  
  1045.     BYTE    SimpleIO;        /* Use simple file I/O? */
  1046.     BYTE    PerfMeter;        /* Transfer performance meter enabled? */
  1047.  
  1048.     LONG    IOBufferSize;        /* Size of the asynchronous I/O buffer. */
  1049.  
  1050.     BYTE    HideUploadIcon;        /* Hide the upload queue icon? */
  1051.     BYTE    ProtectiveMode;        /* Give hints and ask for confirmation? */
  1052. };
  1053.  
  1054.     /* Clipboard settings. */
  1055.  
  1056. struct ClipSettings
  1057. {
  1058.     WORD    ClipboardUnit;        /* Clipboard unit to use. */
  1059.  
  1060.     WORD    LineDelay,        /* Insert line delay. */
  1061.         CharDelay;        /* Insert character delay. */
  1062.  
  1063.     UBYTE    InsertPrefix[80];    /* Line insertion prefix. */
  1064.     UBYTE    InsertSuffix[80];    /* Line insertion suffix. */
  1065.  
  1066.     UBYTE    LinePrompt[256];    /* Line wait prompt. */
  1067.     WORD    SendTimeout;        /* Line send timeout. */
  1068.     UBYTE    PacingMode;        /* Text pacing mode. */
  1069.     BYTE    ConvertLF;        /* Convert <LF> characters to <CR> */
  1070. };
  1071.  
  1072.     /* Capture and logfile settings. */
  1073.  
  1074. struct CaptureSettings
  1075. {
  1076.     BYTE    LogActions;                /* Create logfile? */
  1077.     BYTE    LogCall;                /* Create callinfo-compatible logfile? */
  1078.     UBYTE    LogFileName[MAX_FILENAME_LENGTH];    /* Default logfile name. */
  1079.  
  1080.     LONG    MaxBufferSize;                /* Maximum text buffer size. */
  1081.     BYTE    BufferEnabled;                /* Is the text buffer enabled? */
  1082.  
  1083.     BYTE    ConnectAutoCapture;            /* Open capture file on logon? */
  1084.     BYTE    CaptureFilterMode;            /* The capture filter mode. */
  1085.     UBYTE    CapturePath[MAX_FILENAME_LENGTH];    /* The default path for capture files. */
  1086.  
  1087.     UBYTE    CallLogFileName[MAX_FILENAME_LENGTH];    /* Name of the call log file. */
  1088.     UBYTE    BufferPath[MAX_FILENAME_LENGTH];    /* Text buffer save path. */
  1089.  
  1090.     BYTE    AutoCaptureDate;            /* Where to include the creation date? */
  1091.     UBYTE    SearchHistory;
  1092.  
  1093.     BYTE    OpenBufferWindow;            /* Where to open the buffer window. */
  1094.     BYTE    OpenBufferScreen;            /* Where to open the buffer screen. */
  1095.  
  1096.     BYTE    BufferScreenPosition;            /* Where to place the buffer screen (horizontal) */
  1097.     UBYTE    BufferWidth;                /* How long each line in the buffer should be. */
  1098.  
  1099.     BYTE    RememberBufferWindow;            /* Remember buffer window context? */
  1100.     BYTE    RememberBufferScreen;            /* Remember buffer screen context? */
  1101.  
  1102.     ULONG    BufferScreenMode;            /* Screen display mode for buffer screen. */
  1103.  
  1104.     BYTE    ConvertChars;                /* Convert IBM characters? */
  1105.     BYTE    Pad;
  1106. };
  1107.  
  1108.     /* File settings. */
  1109.  
  1110. struct FileSettings
  1111. {
  1112.     UBYTE    ProtocolFileName[MAX_FILENAME_LENGTH];        /* Transfer protocol file name. */
  1113.     UBYTE    TranslationFileName[MAX_FILENAME_LENGTH];    /* Character translation file name. */
  1114.     UBYTE    MacroFileName[MAX_FILENAME_LENGTH];        /* Keyboard macro file name. */
  1115.     UBYTE    CursorFileName[MAX_FILENAME_LENGTH];        /* Cursor key file name. */
  1116.     UBYTE    FastMacroFileName[MAX_FILENAME_LENGTH];        /* Fast macro file name. */
  1117. };
  1118.  
  1119.     /* Emulation settings. */
  1120.  
  1121. struct EmulationSettings
  1122. {
  1123.     BYTE    CursorMode;        /* Are the cursor keys switched to application mode? */
  1124.     BYTE    NumericMode;        /* Is the numeric keypad switched to application mode? */
  1125.  
  1126.     BYTE    CursorWrap;        /* Is cursor position wrapping enabled? */
  1127.     BYTE    LineWrap;        /* Is character line wrapping enabled? */
  1128.  
  1129.     BYTE    InsertMode;        /* Is the character insertion mode enabled? */
  1130.     BYTE    NewLineMode;        /* Is the newline mode enabled? */
  1131.  
  1132.     BYTE    FontScale;        /* Which font scale is enabled? */
  1133.     BYTE    ScrollMode;        /* Is smooth scrolling enabled? */
  1134.     BYTE    DestructiveBackspace;    /* Backspace erases characters? */
  1135.     BYTE    SwapBSDelete;        /* DEL and BS keys are swapped? */
  1136.     BYTE    PrinterEnabled;        /* Printer commands enabled? */
  1137.     BYTE    CLSResetsCursor;    /* Clear screen command resets cursor position? */
  1138.  
  1139.     UBYTE    AnswerBack[80];        /* Answer-back message. */
  1140.  
  1141.     BYTE    KeysLocked;        /* Numeric keypad mode locked? */
  1142.     UBYTE    MaxScroll;        /* Maximum number of lines to prescroll. */
  1143.     UBYTE    MaxJump;        /* Maximum number of lines to scroll in one jump. */
  1144.     BYTE    CursorLocked;        /* Cursor keys locked? */
  1145.     BYTE    FontLocked;        /* Font size locked? */
  1146.     BYTE    LockWrapping;        /* Line wrapping locked? */
  1147.     BYTE    LockStyle;        /* Text style locked? */
  1148.     BYTE    LockColour;        /* Text colour locked? */
  1149.  
  1150.     BYTE    UseStandardPens;    /* Use the standard pens/attributes? */
  1151.     BYTE    Pad;
  1152.  
  1153.     UBYTE    Attributes[4];        /* Attribute mappings. */
  1154.     UWORD    Pens[16];        /* Rendering pens. */
  1155. };
  1156.  
  1157. struct TransferSignature
  1158. {
  1159.     UBYTE    Signature[40];
  1160.     WORD    Length;
  1161. };
  1162.  
  1163.     /* File transfer library settings. */
  1164.  
  1165. struct TransferSettings
  1166. {
  1167.     UBYTE    DefaultLibrary[MAX_FILENAME_LENGTH],
  1168.         ASCIIUploadLibrary[MAX_FILENAME_LENGTH],
  1169.         ASCIIDownloadLibrary[MAX_FILENAME_LENGTH],
  1170.         TextUploadLibrary[MAX_FILENAME_LENGTH],
  1171.         TextDownloadLibrary[MAX_FILENAME_LENGTH],
  1172.         BinaryUploadLibrary[MAX_FILENAME_LENGTH],
  1173.         BinaryDownloadLibrary[MAX_FILENAME_LENGTH];
  1174.     BYTE    InternalASCIIUpload,
  1175.         InternalASCIIDownload,
  1176.         QuietTransfer,
  1177.         MangleFileNames;
  1178.  
  1179.     WORD    LineDelay,        /* Insert line delay. */
  1180.         CharDelay;        /* Insert character delay. */
  1181.  
  1182.     UBYTE    LinePrompt[256];    /* Line wait prompt. */
  1183.     WORD    SendTimeout;        /* Line send timeout. */
  1184.     UBYTE    PacingMode;        /* Text pacing mode. */
  1185.     BYTE    StripBit8;        /* Strip high order bit. */
  1186.     BYTE    IgnoreDataPastArnold;    /* Ignore data past terminator. */
  1187.     UBYTE    TerminatorChar;        /* Terminator character. */
  1188.     BYTE    SendCR,
  1189.         SendLF,
  1190.         ReceiveCR,
  1191.         ReceiveLF;
  1192.  
  1193.     UWORD    ErrorNotification;    /* Notify user after <n> errors have occured. */
  1194.     BYTE    TransferNotification;    /* Notify the user when a transfer has started/finished? */
  1195.     BYTE    DefaultType,
  1196.         ASCIIDownloadType,
  1197.         ASCIIUploadType,
  1198.         TextDownloadType,
  1199.         TextUploadType,
  1200.         BinaryUploadType,
  1201.         BinaryDownloadType;
  1202.  
  1203.     struct TransferSignature Signatures[TRANSFERSIG_BINARYDOWNLOAD + 1];
  1204.  
  1205.     BYTE    OverridePath;        /* Override the protocol transfer path? */
  1206.     BYTE    SetArchivedBit;        /* Set the archived bit for files sent? */
  1207.     BYTE    IdentifyFiles;        /* Try to identify files after download? */
  1208.     BYTE    TransferIcons;        /* Transfer files along with their icons? */
  1209.     BYTE    PerfMeter;        /* Transfer performance meter enabled? */
  1210.     BYTE    HideUploadIcon;        /* Hide the upload queue icon? */
  1211. };
  1212.  
  1213.     /* The new configuration settings. */
  1214.  
  1215. struct Configuration
  1216. {
  1217.     struct SerialSettings        *SerialConfig;
  1218.     struct ModemSettings        *ModemConfig;
  1219.     struct ScreenSettings        *ScreenConfig;
  1220.     struct TerminalSettings        *TerminalConfig;
  1221.     struct EmulationSettings    *EmulationConfig;
  1222.     struct ClipSettings        *ClipConfig;
  1223.     struct CaptureSettings        *CaptureConfig;
  1224.     struct CommandSettings        *CommandConfig;
  1225.     struct MiscSettings        *MiscConfig;
  1226.     struct PathSettings        *PathConfig;
  1227.     struct FileSettings        *FileConfig;
  1228.     struct TransferSettings        *TransferConfig;
  1229. };
  1230.  
  1231.     /* Phonebook entry header. */
  1232.  
  1233. struct PhoneHeader
  1234. {
  1235.     UBYTE    Name[40],        /* BBS name. */
  1236.         Number[100],        /* Phone number. */
  1237.         Comment[100];        /* Comment. */
  1238.  
  1239.     UBYTE    UserName[100],        /* User name for this BSS. */
  1240.         Password[100];        /* Password for user name. */
  1241.  
  1242.     BYTE    QuickMenu;        /* This entry appears in the quick dial menu? */
  1243.     BYTE    Pad;
  1244. };
  1245.  
  1246.     /* A phonebook entry. */
  1247.  
  1248. struct PhoneEntry
  1249. {
  1250.     struct PhoneNode    *Node;
  1251.  
  1252.     struct MinList         TimeDateList;
  1253.  
  1254.     LONG             Count;
  1255.  
  1256.     struct PhoneHeader    *Header;
  1257.     struct Configuration    *Config;
  1258. };
  1259.  
  1260.     /* A text box for several lines of text. */
  1261.  
  1262. struct TextBox
  1263. {
  1264.     struct TextBox        *NextBox;        /* Next box in chain. */
  1265.  
  1266.     LONG             Left,Top,        /* Position and size. */
  1267.                  Width,Height;
  1268.  
  1269.     LONG             LineWidth,        /* Line width in pixels. */
  1270.                  LineHeight;        /* Line height in pixels. */
  1271.  
  1272.     LONG             NumChars,        /* Number of chars per line. */
  1273.                  NumLines;        /* Number of lines. */
  1274.  
  1275.     STRPTR            *Title,            /* Line titles. */
  1276.                 *Text;            /* Line texts. */
  1277.  
  1278.     LONG             TitleFgPen,
  1279.                  TitleBgPen,
  1280.                  TextPen;
  1281. };
  1282.  
  1283.     /* Block marker structure. */
  1284.  
  1285. struct BlockMarker
  1286. {
  1287.         /* The object to manipulate. */
  1288.  
  1289.     APTR            Object;
  1290.  
  1291.         /* Selection and unselection routines. */
  1292.  
  1293.     VOID         (* Select)(struct BlockMarker *Marker,LONG Left,LONG Top,LONG Width,LONG Height);
  1294.     VOID         (* Unselect)(struct BlockMarker *Marker,LONG Left,LONG Top,LONG Width,LONG Height);
  1295.  
  1296.         /* Origin anchor point. */
  1297.  
  1298.     LONG            OriginX,
  1299.                 OriginY;
  1300.  
  1301.         /* First and last selected line. */
  1302.  
  1303.     LONG            FirstLine,
  1304.                 LastLine;
  1305.  
  1306.         /* First and last selected column. */
  1307.  
  1308.     LONG            FirstColumn,
  1309.                 LastColumn;
  1310.  
  1311.         /* Top of display window, lines in the buffer and size of
  1312.          * the display window.
  1313.          */
  1314.  
  1315.     LONG            Top,
  1316.                 Lines,
  1317.                 Width,
  1318.                 Height;
  1319.  
  1320.         /* Canvas left and top edge. */
  1321.  
  1322.     LONG            LeftEdge,
  1323.                 TopEdge;
  1324.  
  1325.         /* Last mouse position. */
  1326.  
  1327.     LONG            LastX,
  1328.                 LastY;
  1329.  
  1330.         /* Single character dimensions. */
  1331.  
  1332.     LONG            TextFontWidth,
  1333.                 TextFontHeight;
  1334.  
  1335.         /* Plane write mask. */
  1336.  
  1337.     UBYTE            WriteMask;
  1338. };
  1339.  
  1340.     /* Global data flow <-> term interface. */
  1341.  
  1342. struct FlowInfo
  1343. {
  1344.     BYTE            Changed;
  1345.  
  1346.     BYTE            NoCarrier;
  1347.  
  1348.     BYTE            Connect,
  1349.                 Voice,
  1350.                 Ring,
  1351.                 Busy,
  1352.                 NoDialTone,
  1353.                 Ok,
  1354.                 Error;
  1355.  
  1356.     BYTE            Signature;
  1357. };
  1358.  
  1359.     /* A scan sequence, somewhat similar to the FlowInfo structure. */
  1360.  
  1361. struct WaitNode
  1362. {
  1363.     struct Node    Node;
  1364.     LONG        Count;        /* Number of characters matched. */
  1365.     STRPTR        Response;    /* Immediate response. */
  1366.     LONG        ResponseLen;    /* Length of immediate response string. */
  1367. };
  1368.  
  1369. struct DialNode
  1370. {
  1371.     struct Node         Node;        // List link
  1372.     struct PhoneEntry    *Entry;        // Points to the configuration data
  1373. };
  1374.  
  1375.     /* A list as employed by the ARexx interface. */
  1376.  
  1377. struct GenericList
  1378. {
  1379.     struct MinList         ListHeader;
  1380.     struct Node        *ListNode;
  1381.     LONG             ListCount;
  1382.     struct SignalSemaphore     ListSemaphore;
  1383. };
  1384.  
  1385.     /* Number of buffers to be used for buffered I/O. */
  1386.  
  1387. #define BUFFER_NUMBER        2
  1388.  
  1389.     /* Auxiliary structure for buffered file I/O. */
  1390.  
  1391. struct Buffer
  1392. {
  1393.     struct Message             Message;            /* Vanilla message header. */
  1394.  
  1395.     BYTE                 SimpleIO;            /* Real simple I/O? */
  1396.     BYTE                 Pad;
  1397.  
  1398.     BYTE                 Read;                /* Last access has read data. */
  1399.     BYTE                 Written;            /* Last access has written data. */
  1400.  
  1401.     LONG                 Action;            /* Action to perform. */
  1402.     LONG                 ActionData[2];            /* Seek and the like. */
  1403.     LONG                 Result;            /* Return value. */
  1404.  
  1405.     BPTR                 FileHandle;            /* Dos filehandle. */
  1406.  
  1407.     UBYTE                *Data;                /* Data buffer. */
  1408.     LONG                 BufLength;            /* Length of data buffer. */
  1409.  
  1410.     LONG                 BufPosition;            /* Read/write pointer into buffer. */
  1411.  
  1412.     LONG                 ReadBufFull;            /* How many bytes are still to be read from the buffer? */
  1413.     LONG                 WriteBufFull;            /* How many bytes are still to be written to the buffer?*/
  1414.  
  1415.     LONG                 RealPosition;            /* Real position in file. */
  1416.     LONG                 Cached;            /* How many bytes in pre-load cache. */
  1417.  
  1418.     UBYTE                *DataBuffer[BUFFER_NUMBER];    /* The data buffers. */
  1419.     LONG                 DataLength[BUFFER_NUMBER];    /* The lengths of the data buffers. */
  1420.     WORD                 DataCount;            /* Which buffer to use. */
  1421.     BYTE                 WriteAccess;            /* TRUE if a write file handle. */
  1422.     BYTE                 LastActionFailed;        /* TRUE if last action failed -> abort actions. */
  1423.  
  1424.     struct Process            *Child;
  1425.     struct Process            *Caller;            /* Synchronization. */
  1426.  
  1427.     BPTR                 DirLock;
  1428.     struct InfoData __aligned     InfoData;
  1429.  
  1430.     BYTE                 Fresh;                /* TRUE if no read/write access has taken place yet. */
  1431.     BYTE                 Used;                /* Did any access take place at all? */
  1432.  
  1433.     struct DateStamp         OpenDate;            /* Date and time when file was opened. */
  1434. };
  1435.  
  1436.     /* xpr serial bits. */
  1437.  
  1438. #define ST_PARTYON    (1L << 0)
  1439. #define ST_PARTYODD    (1L << 1)
  1440. #define ST_7WIRE    (1L << 2)
  1441. #define ST_QBREAK    (1L << 3)
  1442. #define ST_RADBOOGIE    (1L << 4)
  1443. #define ST_SHARED    (1L << 5)
  1444. #define ST_EOFMODE    (1L << 6)
  1445. #define ST_XDISABLED    (1L << 7)
  1446. #define ST_PARTYMARKON    (1L << 8)
  1447. #define ST_PARTYMARK    (1L << 9)
  1448. #define ST_2BITS    (1L << 10)
  1449. #define ST_READ7    (1L << 11)
  1450. #define ST_WRITE7    (1L << 12)
  1451.  
  1452.     /* Miscellaneous definitions. */
  1453.  
  1454. #define MILLION        1000000
  1455.  
  1456.     /* Raster text line attributes. */
  1457.  
  1458. #define    ATTR_UNDERLINE    1
  1459. #define    ATTR_HIGHLIGHT    2
  1460. #define ATTR_BLINK    4
  1461. #define    ATTR_INVERSE    8
  1462.  
  1463. enum    {    TEXTATTR_UNDERLINE,TEXTATTR_HIGHLIGHT,
  1464.         TEXTATTR_BLINK,TEXTATTR_INVERSE,
  1465.         TEXTATTR_NONE
  1466.     };
  1467.  
  1468.     /* Audio channels. */
  1469.  
  1470. #define LEFT0F  1
  1471. #define RIGHT0F  2
  1472. #define RIGHT1F  4
  1473. #define LEFT1F  8
  1474.  
  1475.     /* Program revision and the approriate info structure. */
  1476.  
  1477. struct TermInfo
  1478. {
  1479.     UWORD    Version;
  1480.     UWORD    Revision;
  1481. };
  1482.  
  1483. /**********************************************************************/
  1484.  
  1485.  
  1486.     // This defines the destructor data type
  1487.  
  1488. typedef VOID (* __stdargs DESTRUCTOR)(struct MsgItem *);
  1489.  
  1490.     // A message queue handle
  1491.  
  1492. struct MsgQueue
  1493. {
  1494.     struct SignalSemaphore     Access;    // Access semaphore
  1495.     struct MinList         MsgList;    // This is where the queue items go
  1496.  
  1497.     LONG             QueueSize,    // The length of the queue
  1498.                  MaxSize;    // The maximum size of the queue, may be 0
  1499.  
  1500.     struct MinList         WaitList;    // The list of tasks to wait for a wakeup signal
  1501.  
  1502.     struct Task        *SigTask;    // The owner of this handle
  1503.     ULONG             SigMask;    // The signal mask to wake up the owner
  1504.     WORD             SigBit;    // The bit allocated for the mask, may be -1
  1505.  
  1506.     BOOL             Discard;    // Discard or queue new items?
  1507. };
  1508.  
  1509.     // A message item as used by the queue manager
  1510.  
  1511. struct MsgItem
  1512. {
  1513.     struct MinNode         Link;        // List node link
  1514.     DESTRUCTOR         Destructor;    // Destructor routine if any
  1515. };
  1516.  
  1517.     // Your simple message item destructor setup
  1518.  
  1519. #define InitMsgItem(Item,Dest)    (((struct MsgItem *)Item) -> Destructor = (Dest))
  1520.  
  1521.  
  1522. /**********************************************************************/
  1523.  
  1524.  
  1525. enum    {    DATAMSGTYPE_WRITE,DATAMSGTYPE_WRITECLIP,
  1526.         DATAMSGTYPE_UPDATEREVIEW,DATAMSGTYPE_MOVEREVIEW,
  1527.         DATAMSGTYPE_SERIALCOMMAND,DATAMSGTYPE_UPLOAD,
  1528.         DATAMSGTYPE_COMMANDDONE,DATAMSGTYPE_MENU,
  1529.         DATAMSGTYPE_RENDEZVOUS,DATAMSGTYPE_SERIALCOMMANDNOECHO
  1530.     };
  1531.  
  1532.     // An extension of the MsgItem data type
  1533.  
  1534. struct DataMsg
  1535. {
  1536.     struct MsgItem    Item;    // The message item link
  1537.  
  1538.     LONG        Type;    // Message type
  1539.     UBYTE *        Data;    // Pointer to data area
  1540.     LONG        Size;    // Size of data area
  1541.  
  1542.     struct Task *    Client;    // Client task to signal
  1543.     ULONG        Mask;    // Client signal mask
  1544. };
  1545.  
  1546.     // An extension of the DataMsg data type
  1547.  
  1548. struct DataReplyMsg
  1549. {
  1550.     struct DataMsg    Data;        // DataMsg link
  1551.  
  1552.     struct Task *    Creator;    // Creator to notify
  1553.     ULONG        CreatorMask;    // Creator notification signal
  1554. };
  1555.  
  1556.  
  1557. /**********************************************************************/
  1558.  
  1559.  
  1560.     // Serial device attributes
  1561.  
  1562. #define SERA_Baud        TAG_USER+1    // Baud rate
  1563. #define SERA_BreakTime        TAG_USER+2    // Break time
  1564. #define SERA_BitsPerChar    TAG_USER+3    // Bits per character
  1565. #define SERA_StopBits        TAG_USER+4    // Number of stop bits
  1566. #define SERA_BufferSize        TAG_USER+5    // Read/Write buffer size
  1567. #define SERA_Parity        TAG_USER+6    // Parity
  1568. #define SERA_Handshaking    TAG_USER+7    // Handshaking mode
  1569. #define SERA_HighSpeed        TAG_USER+8    // Highspeed mode
  1570. #define SERA_Shared        TAG_USER+9    // Shared access
  1571.  
  1572.  
  1573. /**********************************************************************/
  1574.  
  1575.  
  1576.     /* One of the emulation callback routines. */
  1577.  
  1578. typedef VOID (*  EPTR)(STRPTR Buffer);
  1579.  
  1580.     /* This structure describes an ANSI control sequence. */
  1581.  
  1582. struct ControlCode
  1583. {
  1584.     UBYTE    FirstChar;
  1585.     STRPTR    Match,
  1586.         Terminator;
  1587.     UBYTE    LastChar;
  1588.  
  1589.     BYTE    ExactSize;
  1590.     EPTR    Func;
  1591. };
  1592.  
  1593.  
  1594. /**********************************************************************/
  1595.  
  1596.  
  1597.     /* A 96 bit colour entry. */
  1598.  
  1599. typedef struct ColourEntry
  1600. {
  1601.     ULONG            Red,
  1602.                 Green,
  1603.                 Blue;
  1604. } ColourEntry;
  1605.  
  1606.     /* A table of colour entries, ready for LoadRGB32(). */
  1607.  
  1608. typedef struct ColourTable
  1609. {
  1610.     WORD        NumColours,
  1611.             FirstColour;
  1612.  
  1613.     ColourEntry    Entry[0];
  1614.  
  1615.     WORD        Terminator;
  1616. } ColourTable;
  1617.  
  1618.     /* Spread a byte across a long word. */
  1619.  
  1620. #define SPREAD(v)    ((ULONG)(v) << 24 | (ULONG)(v) << 16 | (ULONG)(v) << 8 | (v))
  1621.  
  1622.     /* Do the same with a word. */
  1623.  
  1624. #define SPREADW(v)    ((ULONG)(v) << 16 | (v))
  1625.  
  1626.  
  1627. /**********************************************************************/
  1628.  
  1629.  
  1630.     /* AmigaUW terminal window resize support. */
  1631.  
  1632. #define UWCMD_TTYRESIZE (CMD_NONSTD)+20
  1633.  
  1634.  
  1635. /**********************************************************************/
  1636.  
  1637.  
  1638.     /* And now for something completely different... */
  1639.  
  1640. #include "termProtos.h"
  1641. #include "termData.h"
  1642. #include "termErrors.h"
  1643.