1998-04-24 00:52:24 +00:00
|
|
|
//
|
|
|
|
// fg_time.hxx -- data structures and routines for managing time related stuff.
|
|
|
|
//
|
|
|
|
// Written by Curtis Olson, started August 1997.
|
|
|
|
//
|
|
|
|
// Copyright (C) 1997 Curtis L. Olson - curt@infoplane.com
|
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License as
|
|
|
|
// published by the Free Software Foundation; either version 2 of the
|
|
|
|
// License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful, but
|
|
|
|
// WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
// General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
//
|
|
|
|
// $Id$
|
|
|
|
// (Log is kept at end of this file)
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef _FG_TIME_HXX
|
|
|
|
#define _FG_TIME_HXX
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef __cplusplus
|
|
|
|
# error This library requires C++
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef HAVE_WINDOWS_H
|
|
|
|
# include <windows.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <GL/glut.h>
|
|
|
|
#include <time.h>
|
|
|
|
|
1998-12-04 01:32:46 +00:00
|
|
|
#ifdef HAVE_SYS_TIMEB_H
|
|
|
|
# include <sys/timeb.h> // for ftime() and struct timeb
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
# include <unistd.h> // for gettimeofday()
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_TIME_H
|
|
|
|
# include <sys/time.h> // for get/setitimer, gettimeofday, struct timeval
|
|
|
|
#endif
|
|
|
|
|
1998-10-16 23:26:44 +00:00
|
|
|
#include <Flight/flight.hxx>
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Define a structure containing global time parameters
|
1998-04-28 01:22:16 +00:00
|
|
|
typedef struct {
|
1998-04-24 00:52:24 +00:00
|
|
|
// the date/time in various forms
|
|
|
|
// Unix "calendar" time in seconds
|
|
|
|
time_t cur_time;
|
|
|
|
|
|
|
|
// Break down of GMT time
|
|
|
|
struct tm *gmt;
|
|
|
|
|
|
|
|
// Julian date
|
|
|
|
double jd;
|
|
|
|
|
|
|
|
// modified Julian date
|
|
|
|
double mjd;
|
|
|
|
|
|
|
|
// side real time at prime meridian
|
|
|
|
double gst;
|
|
|
|
|
|
|
|
// local side real time
|
|
|
|
double lst;
|
|
|
|
|
|
|
|
// the difference between the precise sidereal time algorithm
|
|
|
|
// result and the course result.
|
|
|
|
// course + diff has good accuracy for the short term
|
|
|
|
double gst_diff;
|
|
|
|
|
|
|
|
// An offset in seconds from the true time. Allows us to adjust
|
|
|
|
// the effective time of day.
|
|
|
|
long int warp;
|
|
|
|
|
|
|
|
// How much to change the value of warp each iteration. Allows us
|
|
|
|
// to make time progress faster than normal.
|
|
|
|
long int warp_delta;
|
1998-07-27 18:42:22 +00:00
|
|
|
|
|
|
|
// Paused (0 = no, 1 = yes)
|
|
|
|
int pause;
|
1998-04-28 01:22:16 +00:00
|
|
|
} fgTIME;
|
1998-04-24 00:52:24 +00:00
|
|
|
|
1998-04-28 01:22:16 +00:00
|
|
|
extern fgTIME cur_time_params;
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
|
1998-12-04 01:32:46 +00:00
|
|
|
class fgTIMESTAMP {
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
1998-04-24 00:52:24 +00:00
|
|
|
long seconds;
|
|
|
|
long millis;
|
|
|
|
|
1998-12-04 01:32:46 +00:00
|
|
|
public:
|
|
|
|
|
|
|
|
fgTIMESTAMP();
|
|
|
|
fgTIMESTAMP( const long s, const long m );
|
|
|
|
~fgTIMESTAMP();
|
|
|
|
|
|
|
|
// Set time to current time
|
|
|
|
void stamp();
|
|
|
|
|
|
|
|
fgTIMESTAMP& operator = ( const fgTIMESTAMP& t );
|
|
|
|
|
|
|
|
friend fgTIMESTAMP operator + (const fgTIMESTAMP& t, const long& m);
|
|
|
|
friend long operator - (const fgTIMESTAMP& a, const fgTIMESTAMP& b);
|
|
|
|
|
|
|
|
inline long get_seconds() const { return seconds; }
|
|
|
|
inline long get_millis() const { return millis; }
|
|
|
|
};
|
|
|
|
|
|
|
|
inline fgTIMESTAMP::fgTIMESTAMP() {
|
|
|
|
}
|
|
|
|
|
|
|
|
inline fgTIMESTAMP::fgTIMESTAMP( const long s, const long m ) {
|
|
|
|
seconds = s;
|
|
|
|
millis = m;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline fgTIMESTAMP::~fgTIMESTAMP() {
|
|
|
|
}
|
|
|
|
|
|
|
|
inline fgTIMESTAMP& fgTIMESTAMP::operator = (const fgTIMESTAMP& t)
|
|
|
|
{
|
|
|
|
seconds = t.seconds;
|
|
|
|
millis = t.millis;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void fgTIMESTAMP::stamp() {
|
|
|
|
#if defined( WIN32 )
|
|
|
|
unsigned int t;
|
|
|
|
t = timeGetTime();
|
|
|
|
seconds = 0;
|
|
|
|
millis = t;
|
|
|
|
#elif defined( HAVE_GETTIMEOFDAY )
|
|
|
|
struct timeval current;
|
|
|
|
struct timezone tz;
|
|
|
|
// fg_timestamp currtime;
|
|
|
|
gettimeofday(¤t, &tz);
|
|
|
|
seconds = current.tv_sec;
|
|
|
|
millis = current.tv_usec / 1000;
|
|
|
|
#elif defined( HAVE_GETLOCALTIME )
|
|
|
|
SYSTEMTIME current;
|
|
|
|
GetLocalTime(¤t);
|
|
|
|
seconds = current.wSecond;
|
|
|
|
millis = current.wMilliseconds;
|
|
|
|
#elif defined( HAVE_FTIME )
|
|
|
|
struct timeb current;
|
|
|
|
ftime(¤t);
|
|
|
|
seconds = current.time;
|
|
|
|
millis = current.millitm;
|
|
|
|
#else
|
|
|
|
# error Port me
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
// difference between time stamps in milliseconds
|
|
|
|
inline fgTIMESTAMP operator + (const fgTIMESTAMP& t, const long& m) {
|
|
|
|
#ifdef WIN32
|
|
|
|
return fgTIMESTAMP( 0, t.millis + m );
|
|
|
|
#else
|
|
|
|
return fgTIMESTAMP( t.seconds + ( t.millis + m ) / 1000,
|
|
|
|
( t.millis + m ) % 1000 );
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
// difference between time stamps in milliseconds
|
|
|
|
inline long operator - (const fgTIMESTAMP& a, const fgTIMESTAMP& b)
|
|
|
|
{
|
|
|
|
#if defined( WIN32 )
|
|
|
|
return a.millis - b.millis;
|
|
|
|
#else
|
|
|
|
return 1000 * (a.seconds - b.seconds) + (a.millis - b.millis);
|
|
|
|
#endif
|
|
|
|
}
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
// Portability wrap to get current time.
|
1998-12-04 01:32:46 +00:00
|
|
|
// void timestamp(fg_timestamp *timestamp);
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Return duration in millis from first to last
|
1998-12-04 01:32:46 +00:00
|
|
|
// long timediff(fg_timestamp *first, fg_timestamp *last);
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Return new timestamp given a time stamp and an interval to add in
|
1998-12-04 01:32:46 +00:00
|
|
|
// void timesum(fg_timestamp *res, fg_timestamp *start, long millis);
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
|
1998-04-25 20:24:00 +00:00
|
|
|
// Update time variables such as gmt, julian date, and sidereal time
|
1998-04-28 01:22:16 +00:00
|
|
|
void fgTimeInit(fgTIME *t);
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Update the time dependent variables
|
1998-04-28 01:22:16 +00:00
|
|
|
void fgTimeUpdate(fgFLIGHT *f, fgTIME *t);
|
1998-04-24 00:52:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
#endif // _FG_TIME_HXX
|
|
|
|
|
|
|
|
|
|
|
|
// $Log$
|
1998-12-04 01:32:46 +00:00
|
|
|
// Revision 1.9 1998/12/04 01:32:50 curt
|
|
|
|
// Converted "struct fg_timestamp" to "class fgTIMESTAMP" and added some
|
|
|
|
// convenience inline operators.
|
|
|
|
//
|
1998-10-16 23:26:44 +00:00
|
|
|
// Revision 1.8 1998/10/16 23:28:00 curt
|
|
|
|
// C++-ifying.
|
|
|
|
//
|
1998-10-16 00:51:46 +00:00
|
|
|
// Revision 1.7 1998/10/16 00:56:09 curt
|
|
|
|
// Converted to Point3D class.
|
|
|
|
//
|
1998-07-27 18:42:22 +00:00
|
|
|
// Revision 1.6 1998/07/27 18:42:22 curt
|
|
|
|
// Added a pause option.
|
|
|
|
//
|
1998-05-22 21:14:53 +00:00
|
|
|
// Revision 1.5 1998/05/22 21:14:54 curt
|
|
|
|
// Rewrote event.cxx in C++ as a class using STL for the internal event list
|
|
|
|
// and run queue this removes the arbitrary list sizes and makes things much
|
|
|
|
// more dynamic. Because this is C++-classified we can now have multiple
|
|
|
|
// event_tables if we'd ever want them.
|
|
|
|
//
|
1998-04-28 01:22:16 +00:00
|
|
|
// Revision 1.4 1998/04/28 01:22:17 curt
|
|
|
|
// Type-ified fgTIME and fgVIEW.
|
|
|
|
//
|
1998-04-25 22:06:24 +00:00
|
|
|
// Revision 1.3 1998/04/25 22:06:34 curt
|
|
|
|
// Edited cvs log messages in source files ... bad bad bad!
|
|
|
|
//
|
1998-04-25 20:24:00 +00:00
|
|
|
// Revision 1.2 1998/04/25 20:24:03 curt
|
|
|
|
// Cleaned up initialization sequence to eliminate interdependencies
|
|
|
|
// between sun position, lighting, and view position. This creates a
|
|
|
|
// valid single pass initialization path.
|
|
|
|
//
|
1998-04-24 00:52:24 +00:00
|
|
|
// Revision 1.1 1998/04/24 00:52:28 curt
|
|
|
|
// Wrapped "#include <config.h>" in "#ifdef HAVE_CONFIG_H"
|
|
|
|
// Fog color fixes.
|
|
|
|
// Separated out lighting calcs into their own file.
|
|
|
|
//
|
|
|
|
// Revision 1.20 1998/04/22 13:24:05 curt
|
|
|
|
// C++ - ifiing the code a bit.
|
|
|
|
// Starting to reorginize some of the lighting calcs to use a table lookup.
|
|
|
|
//
|
|
|
|
// Revision 1.19 1998/04/21 17:01:44 curt
|
|
|
|
// Fixed a problems where a pointer to a function was being passed around. In
|
|
|
|
// one place this functions arguments were defined as ( void ) while in another
|
|
|
|
// place they were defined as ( int ). The correct answer was ( int ).
|
|
|
|
//
|
|
|
|
// Prepairing for C++ integration.
|
|
|
|
//
|
|
|
|
// Revision 1.18 1998/04/08 23:35:40 curt
|
|
|
|
// Tweaks to Gnu automake/autoconf system.
|
|
|
|
//
|
|
|
|
// Revision 1.17 1998/04/03 22:12:56 curt
|
|
|
|
// Converting to Gnu autoconf system.
|
|
|
|
// Centralized time handling differences.
|
|
|
|
//
|
|
|
|
// Revision 1.16 1998/02/07 15:29:47 curt
|
|
|
|
// Incorporated HUD changes and struct/typedef changes from Charlie Hotchkiss
|
|
|
|
// <chotchkiss@namg.us.anritsu.com>
|
|
|
|
//
|
|
|
|
// Revision 1.15 1998/01/27 00:48:06 curt
|
1998-04-25 22:06:24 +00:00
|
|
|
// Incorporated Paul Bleisch's <pbleisch@acm.org> new debug message
|
1998-04-24 00:52:24 +00:00
|
|
|
// system and commandline/config file processing code.
|
|
|
|
//
|
|
|
|
// Revision 1.14 1998/01/22 02:59:43 curt
|
|
|
|
// Changed #ifdef FILE_H to #ifdef _FILE_H
|
|
|
|
//
|
|
|
|
// Revision 1.13 1998/01/19 19:27:20 curt
|
|
|
|
// Merged in make system changes from Bob Kuehne <rpk@sgi.com>
|
|
|
|
// This should simplify things tremendously.
|
|
|
|
//
|
|
|
|
// Revision 1.12 1998/01/05 18:44:37 curt
|
|
|
|
// Add an option to advance/decrease time from keyboard.
|
|
|
|
//
|
|
|
|
// Revision 1.11 1997/12/19 23:35:07 curt
|
|
|
|
// Lot's of tweaking with sky rendering and lighting.
|
|
|
|
//
|
|
|
|
// Revision 1.10 1997/12/15 23:55:07 curt
|
|
|
|
// Add xgl wrappers for debugging.
|
|
|
|
// Generate terrain normals on the fly.
|
|
|
|
//
|
|
|
|
// Revision 1.9 1997/12/10 22:37:55 curt
|
|
|
|
// Prepended "fg" on the name of all global structures that didn't have it yet.
|
|
|
|
// i.e. "struct WEATHER {}" became "struct fgWEATHER {}"
|
|
|
|
//
|
|
|
|
// Revision 1.8 1997/12/09 04:25:38 curt
|
|
|
|
// Working on adding a global lighting params structure.
|
|
|
|
//
|
|
|
|
// Revision 1.7 1997/11/25 19:25:41 curt
|
|
|
|
// Changes to integrate Durk's moon/sun code updates + clean up.
|
|
|
|
//
|
|
|
|
// Revision 1.6 1997/09/20 03:34:35 curt
|
|
|
|
// Still trying to get those durned stars aligned properly.
|
|
|
|
//
|
|
|
|
// Revision 1.5 1997/09/16 15:50:31 curt
|
|
|
|
// Working on star alignment and time issues.
|
|
|
|
//
|
|
|
|
// Revision 1.4 1997/09/13 02:00:08 curt
|
|
|
|
// Mostly working on stars and generating sidereal time for accurate star
|
|
|
|
// placement.
|
|
|
|
//
|
|
|
|
// Revision 1.3 1997/09/04 02:17:39 curt
|
|
|
|
// Shufflin' stuff.
|
|
|
|
//
|
|
|
|
// Revision 1.2 1997/08/27 03:30:36 curt
|
|
|
|
// Changed naming scheme of basic shared structures.
|
|
|
|
//
|
|
|
|
// Revision 1.1 1997/08/13 21:56:00 curt
|
|
|
|
// Initial revision.
|
|
|
|
//
|