/*
** 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" /* contains prototype for ut_prvs */

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

/************************************************************************
 * DCROCC								*
 *									*
 * This program copies bulletins containing CHAMP, COSMIC and GRAS   	*
 * radio occultation data into NCEP's BUFR database.		   	*
 *									*
 *	Command line:							*
 *	    dcrocc [options] [bufrtn]					*
 *									*
 *	    bufrtn	= NCEP BUFR tables file				*
 **									*
 * Log:									*
 * J. Ator/NCEP		10/08						*
 * J. Ator/NCEP         01/09   Add circflg to dc_gopt call sequence    *
 * J. Ator/NCEP         02/19   Modify for Dell environment		*
 * J. Ator/NCEP         09/20   Pass nhours,curtim and bufrtn to rc_dcod*
 * M. Weiss/IMSG        09/21   WCOSS2 install: #include "decod_ut.h"   *
 *                              and void rc_dcod have been added.       *
 ***********************************************************************/

{

#define NUMEXP	1

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

/*
**	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 */
	char    bufrtn[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 ( bufrtn, "bufrtab.003" );

/*
**	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 ( bufrtn, parms[0] );
        }

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

#ifdef UNDERSCORE
#define rc_dcod rc_dcod_
#endif

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

	ut_prvs ( dvstr, strlen(dvstr) );
	rc_dcod ( curtim, bufrtn, &nhours, &iret,
		  strlen(curtim), strlen(bufrtn) );

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

}