Changeset 2256 in ntrip for trunk/BNS/RTCM


Ignore:
Timestamp:
Jan 16, 2010, 11:22:15 AM (15 years ago)
Author:
mervart
Message:

* empty log message *

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/BNS/RTCM/rtcm3torinex.c

    r2236 r2256  
    11/*
    22  Converter for RTCM3 data to RINEX.
    3   $Id: rtcm3torinex.c,v 1.28 2010/01/12 12:13:23 mervart Exp $
     3  $Id: rtcm3torinex.c,v 1.30 2010/01/16 10:21:09 mervart Exp $
    44  Copyright (C) 2005-2008 by Dirk Stöcker <stoecker@alberding.eu>
    55
     
    5555
    5656/* CVS revision and version */
    57 static char revisionstr[] = "$Revision: 1.28 $";
     57static char revisionstr[] = "$Revision: 1.30 $";
    5858
    5959#ifndef COMPILEDATE
     
    251251}
    252252
    253 void updatetime(int *week, int *tow, int tk, int fixnumleap)
     253// Convert Moscow time into UTC (fixnumleap == 1) or GPS (fixnumleap == 0)
     254void updatetime(int *week, int *secOfWeek, int mSecOfWeek, int fixnumleap)
    254255{
    255256  int y,m,d,k,l, nul;
    256   unsigned int j = *week*(7*24*60*60) + *tow + 5*24*60*60+3*60*60;
     257  unsigned int j = *week*(7*24*60*60) + *secOfWeek + 5*24*60*60+3*60*60;
    257258  int glo_daynumber = 0, glo_timeofday;
    258259  for(y = 1980; j >= (unsigned int)(k = (l = (365+longyear(y,0)))*24*60*60)
     
    272273  glo_timeofday = j-nul;
    273274
    274   if(tk < 5*60*1000 && glo_timeofday > 23*60*60)
    275     *tow += 24*60*60;
    276   else if(glo_timeofday < 5*60 && tk > 23*60*60*1000)
    277     *tow -= 24*60*60;
    278   *tow += tk/1000-glo_timeofday;
     275  if(mSecOfWeek < 5*60*1000 && glo_timeofday > 23*60*60)
     276    *secOfWeek += 24*60*60;
     277  else if(glo_timeofday < 5*60 && mSecOfWeek > 23*60*60*1000)
     278    *secOfWeek -= 24*60*60;
     279  *secOfWeek += mSecOfWeek/1000-glo_timeofday;
    279280  if(fixnumleap)
    280     *tow -= nul;
    281   if(*tow < 0) {*tow += 24*60*60*7; --*week; }
    282   if(*tow >= 24*60*60*7) {*tow -= 24*60*60*7; ++*week; }
     281    *secOfWeek -= nul;
     282  if(*secOfWeek < 0) {*secOfWeek += 24*60*60*7; --*week; }
     283  if(*secOfWeek >= 24*60*60*7) {*secOfWeek -= 24*60*60*7; ++*week; }
    283284}
    284285
     
    639640        GETBITS(i,27) /* tk */
    640641
    641         updatetime(&handle->GPSWeek, &handle->GPSTOW, i, 0);
    642642        i = handle->GPSTOW*1000;
     643        updatetime(&handle->GPSWeek, &handle->GPSTOW, i, 0); // Moscow -> GPS
    643644        if(gnss->week && (gnss->timeofweek != i || gnss->week
    644645        != handle->GPSWeek))
     
    13961397            struct converttimeinfo cti;
    13971398
    1398             updatetime(&w, &tow, e->tb*1000, 1);
     1399            updatetime(&w, &tow, e->tb*1000, 1);  // Moscow - > UTC
    13991400            converttime(&cti, w, tow);
    14001401
     
    16831684
    16841685#ifndef NO_RTCM3_MAIN
    1685 static char datestr[]     = "$Date: 2010/01/12 12:13:23 $";
     1686static char datestr[]     = "$Date: 2010/01/16 10:21:09 $";
    16861687
    16871688/* The string, which is send as agent in HTTP request */
Note: See TracChangeset for help on using the changeset viewer.