/* aprs_tt.h */ #ifndef APRS_TT_H #define APRS_TT_H 1 /* * For holding location format specifications from config file. * Same thing is also useful for macro definitions. * We have exactly the same situation of looking for a pattern * match and extracting fixed size groups of digits. */ struct ttloc_s { enum { TTLOC_POINT, TTLOC_VECTOR, TTLOC_GRID, TTLOC_UTM, TTLOC_MGRS, TTLOC_USNG, TTLOC_MACRO, TTLOC_MHEAD, TTLOC_SATSQ } type; char pattern[20]; /* e.g. B998, B5bbbdddd, B2xxyy, Byyyxxx, BAxxxx */ /* For macros, it should be all fixed digits, */ /* and the letters x, y, z. e.g. 911, xxyyyz */ union { struct { double lat; /* Specific locations. */ double lon; } point; struct { double lat; /* For bearing/direction. */ double lon; double scale; /* conversion to meters */ } vector; struct { double lat0; /* yyy all zeros. */ double lon0; /* xxx */ double lat9; /* yyy all nines. */ double lon9; /* xxx */ } grid; struct { double scale; double x_offset; double y_offset; long lzone; /* UTM zone, should be 1-60 */ char latband; /* Latitude band if specified, otherwise space or - */ char hemi; /* UTM Hemisphere, should be 'N' or 'S'. */ } utm; struct { char zone[8]; /* Zone and square for USNG/MGRS */ } mgrs; struct { char prefix[24]; /* should be 10, 6, or 4 digits to be */ /* prepended to the received sequence. */ } mhead; struct { char *definition; } macro; }; }; /* Error codes for sending responses to user. */ #define TT_ERROR_OK 0 /* Success. */ #define TT_ERROR_D_MSG 1 /* D was first char of field. Not implemented yet. */ #define TT_ERROR_INTERNAL 2 /* Internal error. Shouldn't be here. */ #define TT_ERROR_MACRO_NOMATCH 3 /* No definition for digit sequence. */ #define TT_ERROR_BAD_CHECKSUM 4 /* Bad checksum on call. */ #define TT_ERROR_INVALID_CALL 5 /* Invalid callsign. */ #define TT_ERROR_INVALID_OBJNAME 6 /* Invalid object name. */ #define TT_ERROR_INVALID_SYMBOL 7 /* Invalid symbol specification. */ #define TT_ERROR_INVALID_LOC 8 /* Invalid location. */ #define TT_ERROR_NO_CALL 9 /* No call or object name included. */ #define TT_ERROR_INVALID_MHEAD 10 /* Invalid Maidenhead Locator. */ #define TT_ERROR_INVALID_SATSQ 11 /* Satellite square must be 4 digits. */ #define TT_ERROR_MAXP1 12 /* Number of items above. i.e. Last number plus 1. */ #if CONFIG_C /* Is this being included from config.c? */ /* Must keep in sync with above !!! */ static const char *tt_msg_id[TT_ERROR_MAXP1] = { "OK", "D_MSG", "INTERNAL", "MACRO_NOMATCH", "BAD_CHECKSUM", "INVALID_CALL", "INVALID_OBJNAME", "INVALID_SYMBOL", "INVALID_LOC", "NO_CALL", "INVALID_MHEAD", "INVALID_SATSQ" }; #endif /* * Configuration options for APRStt. */ #define TT_MAX_XMITS 10 #define TT_MTEXT_LEN 64 struct tt_config_s { int gateway_enabled; /* Send DTMF sequences to APRStt gateway. */ int obj_recv_chan; /* Channel to listen for tones. */ int obj_xmit_chan; /* Channel to transmit object report. */ /* -1 for none. This could happpen if we */ /* are only sending to application */ /* and/or IGate. */ int obj_send_to_app; /* send to attached application(s). */ int obj_send_to_ig; /* send to IGate. */ char obj_xmit_via[AX25_MAX_REPEATERS * (AX25_MAX_ADDR_LEN+1)]; /* e.g. empty or "WIDE2-1,WIDE1-1" */ int retain_time; /* Seconds to keep information about a user. */ int num_xmits; /* Number of times to transmit object report. */ int xmit_delay[TT_MAX_XMITS]; /* Delay between them. */ /* e.g. 3 seconds before first transmission then */ /* delays of 16, 32, seconds etc. in between repeats. */ struct ttloc_s *ttloc_ptr; /* Pointer to variable length array of above. */ int ttloc_size; /* Number of elements allocated. */ int ttloc_len; /* Number of elements actually used. */ double corral_lat; /* The "corral" for unknown locations. */ double corral_lon; double corral_offset; int corral_ambiguity; char status[10][TT_MTEXT_LEN]; /* Up to 9 status messages. e.g. "/enroute" */ /* Position 0 means none and can't be changed. */ struct { char method[AX25_MAX_ADDR_LEN]; /* SPEECH or MORSE[-n] */ char mtext[TT_MTEXT_LEN]; /* Message text. */ } response[TT_ERROR_MAXP1]; char ttcmd[80]; /* Command to generate custom audible response. */ }; void aprs_tt_init (struct tt_config_s *p_config); void aprs_tt_button (int chan, char button); #define APRSTT_LOC_DESC_LEN 32 /* Need at least 26 */ void aprs_tt_dao_to_desc (char *dao, char *str); void aprs_tt_sequence (int chan, char *msg); int dw_run_cmd (char *cmd, int oneline, char *result, int maxresult); #endif /* end aprs_tt.h */