/*
** 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[];

/************************************************************************
 * DCOZON								*
 *									*
 * This program copies bulletins containing EPA Ozon BUFR messages   	*
 * into NCEP's BUFR database. No reformatting is done at this time.    	*
 *									*
 *	Command line:							*
 *	    dcozon [options]                      			*
 *									*
 **									*
 * Log:									*
 * J. Ator/NCEP		01/98						*
 * J. Ator/NCEP		03/99	Added nhours to ac_dcod call sequence	*
 * C. Caruso Magee/NCEP 04/04   Modifying for dcozon.                 	*
 * J. Ator/NCEP         01/05   Increased ndfhr1 from 120 to 240        *
 * C. Caruso Magee/NCEP 02/06   Added new args to calling sequence of   *
 *                              dc_gopt                                 *
 * J. Ator/NCEP         01/09   Add circflg to dc_gopt call sequence    *
 * M. Weiss/NCEP        02/19   Modified for DELL conversion            *
 * J. Ator/NCEP         09/21   Modify for WCOSS2 environment           *
 ***********************************************************************/

{

#define NUMEXP	2

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

/*
**	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;
	int	ndfhr2	= 240;
	int	idfwdh	= 0;

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

/*
**	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.
*/

/*
**	Now, for each additional decoder parameter, if a value was
**	defined on the command line, then use that value instead of
**	the default value.
*/

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

#ifdef UNDERSCORE
#define oz_dcod oz_dcod_
#endif

	void oz_dcod ( int * );

        ut_prvs ( dvstr, strlen(dvstr) );
	oz_dcod ( &iret );

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

}