1
  
2
  
3
  
4
  
5
  
6
  
7
  
8
  
9
  
10
  
11
  
12
  
13
  
14
  
15
  
16
  
17
  
18
  
19
  
20
  
21
  
22
  
23
  
24
  
25
  
26
  
27
  
28
  
29
  
30
  
31
  
32
  
33
  
34
  
35
  
36
  
37
  
38
  
39
  
40
  
41
  
42
  
43
  
44
  
45
  
46
  
47
  
48
  
49
  
50
  
51
  
52
  
53
  
54
  
55
  
56
  
57
  
58
  
59
  
60
  
61
  
62
  
63
  
64
  
65
  
66
  
67
  
68
  
69
  
70
  
71
  
72
  
73
  
74
  
75
  
76
  
77
  
78
  
79
  
80
  
81
  
82
  
83
  
84
  
85
  
86
  
87
  
88
  
89
  
90
  
91
  
92
  
93
  
94
  
95
  
96
  
97
  
98
  
99
  
100
  
101
  
102
  
103
  
104
  
105
  
106
  
107
  
108
  
//! submodule Stardate 
//!   time unit: TNGDate 
 
//! class TNGDate 
//!   implements ST:TNG stardates 
//!   can be used as create argument to Day  
 
class TNGDate 
{ 
   inherit Calendar._TimeUnit; 
 
   // 40759.5  2363-10-05  2584405 
   // 47391.2  2370-05-23  2586827 
 
   // 50893.5  2373-11-23  2588107 
 
   //  6631.7  ----------  2422  
   // 10134.0  ----------  3702 
   //  1000.0  ----------  365.2425 
   //     0.0      -  -    2569519 
#define TNGSTARPERJULIAN (1000.0/365.2425) 
 
//-- variables ------------------------------------------------------ 
 
   float jd; 
   float tics; 
    
//-- standard methods ----------------------------------------------- 
 
   void create(int|float|object ... day) 
   { 
      float jd; 
      if (!sizeof(day)) 
         day=({Calendar.Gregorian.Second()}); 
      else if (floatp(day[0])) 
      { 
         from_stardate(day[0]); 
         return; 
      } 
      if (!intp(day[0])) 
      { 
         object o=day[0]; 
 
         if (o->julian_day || o->julian_day_f) 
            jd=(float)(o->julian_day_f||o->julian_day)(); 
         else // dig 
            if (o->day) // larger 
            { 
               o=o->day(0); 
               if (o->julian_day_f) 
                  jd=o->julian_day_f(); 
               else if (o->julian_day) 
                  jd=(float)o->julian_day(); 
               else 
                  ; // error, like 
            } 
            else // smaller 
            { 
               float z=1.0; 
               while (sizeof(o->greater())) 
               { 
                  string name=o->is(); 
                  o=o[o->greater()[0]](); 
                  z*=o["number_of_"+name+"s"](); 
                  if (o->julian_day_f || o->julian_day)  
                  { 
                     jd=(o->julian_day||o->julian_day_f)()/z; 
                     break; 
                  } 
               } 
            } 
      } 
      else  
         jd=(float)day[0]; 
      from_julian_day(jd); 
   } 
 
   static void from_stardate(float f) 
   { 
      tics=f; 
      jd=f/TNGSTARPERJULIAN+2569518.5; 
   } 
 
   static void from_julian_day(float f) 
   { 
      jd=f; 
      tics=(f-2569518.5)*TNGSTARPERJULIAN; 
   } 
 
//-- nonstandard methods -------------------------------------------- 
 
   float number() 
   { 
      return tics; 
   } 
    
   int julian_day() 
   { 
      return (int)jd; 
   } 
 
   float julian_day_f() 
   { 
      return jd; 
   } 
}