-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdatetomjd.c
104 lines (80 loc) · 2.65 KB
/
datetomjd.c
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
/****************************************************************************
*
* Copyright (C) 2011 Peter W. Draper ([email protected])
*
* 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.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
****************************************************************************/
/*+
=pod
=head1 NAME
datetomjd
=head1 SYNOPSIS
datetomjd now
datetomjd <date_and_time>
=head1 DESCRIPTION
Converts a UT date and time or the current second ("now") to a Modified Julian
Date.
If given the date and time should be in "YYYY-MM-DD HH:MM:SS.SS" format.
=head1 AUTHOR
Peter W. Draper: 10-JUN-2011
Durham University
=cut
-*/
/* Include files */
#define _GNU_SOURCE
#include <stdio.h>
#include <unistd.h>
#include <time.h>
#include <string.h>
/* Date of the Unix epoch as a Modified Julian Date. */
#define MJD_EPOCH 40587
/* Number of seconds per day. */
#define SECS_PER_DAY (60 * 60 * 24)
/* Maximum length of time string. */
#define BUFLEN 64
/**
* Main routine.
*/
int main( int argc, char *argv[] )
{
double mjd; /* Modified Julian Date */
time_t unixsecs; /* Seconds since the UNIX epoch */
struct tm utc; /* UTC time struct */
/* Get the command-line value. */
if ( argc != 2 ) {
printf( "Usage: %s now\n"
" %s 'YYYY-MM-DD HH:MM:SS.SS'\n", argv[0], argv[0] );
return 1;
}
/* Do we want "now"? */
if ( strncmp( argv[1], "now", 3 ) == 0 ) {
/* Seconds of the UNIX epoch. */
unixsecs = time( NULL );
}
else {
/* Convert formatted time into a struct. */
if ( strptime( argv[1], "%Y-%m-%d %H:%M:%S", &utc ) == NULL ) {
printf( "Failed to convert date (%s)\n", argv[1] );
return 1;
}
/* Seconds since the UNIX epoch. */
unixsecs = timegm( &utc );
}
/* MJD. */
mjd = ( unixsecs / SECS_PER_DAY ) + MJD_EPOCH;
printf( "MJD: %g\n", mjd );
return 1;
}