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

/************************************************************************
 * DCMSSF								*
 *									*
 * This program decodes bulletins containing WMO-migrated marine   	*
 * subsurface BUFR data into NCEP BUFR format. 	                    	*
 *									*
 *	Command line:							*
 *	    dcmssf [options] [bufrtn] [wgosid]		                *
 *									*
 *	    bufrtn	= NCEP BUFR tables file				*
 *          wgosid      = wigos ids test KWNB                           *
 **									*
 * Log:									*
 * J. Ator/NCEP		01/14						*
 * M. Weiss/NCEP        19/02   Modified for Dell conversion            *       
 * M. Weiss/IMSG        11/19   Add wgosid wigos ids USA (KWNB)         * 
 * J. Ator/NCEP         09/21   Modify for WCOSS2 environment           *
 ***********************************************************************/

{

#define NUMEXP	2

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

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

/*
**	Define the additional decoder parameters.
*/
        const char *dvstr = DVSTR;  /* DVSTR is a compile-time macro */
	char	bufrtn[DCMXLN];
        char    wgosid[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.031" );

/*
**	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] );
	}
        if  ( num > 1 )  {
            strcpy ( wgosid, parms[1] );
        }

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

#ifdef UNDERSCORE
#define mf_dcod mf_dcod_
#endif

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

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

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

}