/*
** Do not change these include commands.
** All necessary header files are included in "geminc.h".
** All macros and constants are in "gemprm.h" and "bridge.h".
*/

#include "geminc.h"
#include "gemprm.h"
#include "bridge.h"

#include "decod_ut.h"

main ( argc, argv )
	int	argc;
	char	*argv[];

/************************************************************************
 * DCMAP								*
 *									*
 * This program decodes MAP (multi-agency profiler) data files from FSL	*
 * into	BUFR format.							*
 *									*
 *	Command line:							*
 *	    dcmap [options] [mapfl] [bufrtb]				*
 *									*
 *	    mapfl	= MAP data file from FSL			*
 *	    bufrtb	= BUFR tables file				*
 *									*
 **									*
 * Log:									*
 * J. Ator/NCEP         10/08						*
 * J. Ator/NCEP         01/09   Add circflg to dc_gopt call sequence    *
 * J. Ator/NCEP         01/19   Modify for Dell environment		*
 * J. Ator/NCEP         09/21   Modify for WCOSS2 environment           *
 ***********************************************************************/

{

#define NUMEXP	2

	int	nexp	= NUMEXP;
	char	*prgnam = "DCMAP";

/*
**	Define the standard decoder parameters.
*/
	char	stntbl[DCMXLN], stntb2[DCMXLN];
	char	prmfil[DCMXLN];
	int	iadstn;
	int	maxtim;
	int	nhours;
	int	txtflg;
	int	iwndht;
	int	circflg;

/*
**	Define default values for the standard decoder parameters.
*/
	char	*defprm	= " ";
	char	*defstn	= " ";
	char	*dfstn2	= " ";
	int	idfadd	= 0;
	int	idfmax	= 0;
	int	ndfhr1	= 240;  /* = 10 days */
	int	ndfhr2	= 240;  /* = 10 days */
	int	idfwdh	= 0;                     

/*
**	Define the additional decoder parameters.
*/
	const char *dvstr = DVSTR;  /* DVSTR is a compile-time macro */
	char	mapfl[DCMXLN];
	char	bufrtb[DCMXLN];

/*
**	Do not change these variables.  These variables are used by all
**	decoders for getting the command line parameters.
*/
	char	parms[NUMEXP][DCMXLN];
	char	curtim[DCMXLN];
	int	num;
	int	iret;
	int	ier;


/*---------------------------------------------------------------------*/

/*
**	Initialize the output logs, set the time out, and 
**	parse the command line parameters.
*/
	dc_init ( prgnam, argc, argv, nexp, parms, &num, &iret );

/*
**	Check for an initialization error.
*/
	if  ( iret < 0 )  {
	    dc_exit ( &iret );
	}

/*
**	Set each standard decoder parameter to the value from the
**	command line options (if defined) or else to the default
**	value.
*/
	dc_gopt ( defprm, defstn, dfstn2, idfadd, idfmax, ndfhr1,
		  ndfhr2, idfwdh, prmfil, stntbl, stntb2, &iadstn, 
		  &maxtim, curtim, &nhours, &txtflg, &circflg,
		  &iwndht, &iret );


/*
**	Set default values for the additional decoder parameters.
*/
	strcpy ( mapfl, "mapfl" );
	strcpy ( bufrtb, "bufrtab.002" );

/*
**	Now, for each additional decoder parameter, if a value was
**	defined on the command line, then use that value instead of
**	the default value.
*/
	if  ( num > 0 )  {
	    strcpy ( mapfl, parms[0] );
	}

	if  ( num > 1 )  {
	    strcpy ( bufrtb, parms[1] );
	}

/*
** Call the decoding routine.
**
** Change this function call, define command and prototype for the
** specific decoder.
*/

#ifdef UNDERSCORE
#define ap_dcod ap_dcod_
#endif

	void ap_dcod ( char *, char *, char *, int *, int *,
                       size_t, size_t, size_t );

	ut_prvs ( dvstr, strlen(dvstr) );
	ap_dcod ( curtim, mapfl, bufrtb, &nhours, &iret, 
		  strlen(curtim), strlen(mapfl), strlen(bufrtb) );

/*
**	Send shut down message and close the log files.
*/
	dc_exit ( &iret );

}