awips2/ncep/gov.noaa.nws.ncep.viz.rsc.ncgrid/dgdriv_c/dbgetgnav.c
Steve Harris 7f90924706 12.4.1-10 baseline
Former-commit-id: 7fa9dbd5fb [formerly 4bfbdad17d] [formerly 9f8cb727a5] [formerly 7fa9dbd5fb [formerly 4bfbdad17d] [formerly 9f8cb727a5] [formerly 8485b90ff8 [formerly 9f8cb727a5 [formerly bf53d06834caa780226121334ac1bcf0534c3f16]]]]
Former-commit-id: 8485b90ff8
Former-commit-id: 40aa780b3d [formerly 33a67cdd82] [formerly 73930fb29d0c1e91204e76e6ebfdbe757414f319 [formerly a28d70b5c5]]
Former-commit-id: a16a1b4dd44fc344ee709abbe262aeed58a8339b [formerly e5543a0e86]
Former-commit-id: 0c25458510
2012-05-01 18:06:13 -05:00

62 lines
2 KiB
C

#include "geminc.h"
#include "gemprm.h"
#include "dbcmn.h"
#include <sys/timeb.h>
void db_getgnav (char *model, char *eventName,char *navTime, char *gridNav, int *lGridNav, int *iret )
/************************************************************************
* *
* db_getgnav *
* *
* m.gamazaychikov/SAIC 11/08 Created *
************************************************************************/
{
int ier, ier1;
char diagMessage[720],queryText[320];
struct timeb t_callback, t_current;
/*----------------------------------------------------------------------*/
/*
* If the pointer to the callback function is not set, return
*/
if ( navClbkPtr == NULL ) {
ier = -17;
er_wmsg ( "DB", &ier, "db_getgnav", &ier1, 2, strlen("db_getgnav") );
*iret = -1;
return;
}
/*
* Initialization
*/
*iret = 0;
*lGridNav = 0;
gridNav[0] = '\0';
diagMessage[0] = '\0';
sprintf (queryText, "%s|%s|%s",model,eventName,navTime);
/*
* Execute the callback to get the navigation
*/
db_msgcave ("db_getgnav", "debug", "calling the callback function", &ier);
ftime(&t_callback);
navClbkPtr(queryText);
ftime(&t_current);
sprintf (diagMessage, "%s %d", "time spent in callback ", (int) (1000.0 * (t_current.time - t_callback.time) + (t_current.millitm - t_callback.millitm)));
db_msgcave ("db_getgnav", "info", diagMessage, &ier);
if ( navStrLength > 0 && navStrBack != NULL ) {
sprintf (gridNav, "%s", navStrBack);
*lGridNav = strlen(gridNav);
G_FREE( navStrBack, char );
sprintf (diagMessage, "%s %s", "got this nav string", gridNav);
db_msgcave ("db_getgnav", "debug", diagMessage, &ier);
}
else {
db_msgcave ("db_getgnav", "error", "!!! *could not get nav string* !!!", &ier);
ier = -18;
er_wmsg ( "DB", &ier, "Navigation", &ier1, 2, strlen("Navigation") );
*iret = -1;
return;
}
return;
}