Commit 9f99e4c6 authored by Thomas G. Lockhart's avatar Thomas G. Lockhart

Add conversion from datetime to time data type.

Rename date+time conversion to datetime to ensure less than 16 characters
 in routine name (required to fit in pg_proc table).
parent 0d6facba
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/adt/datetime.c,v 1.16 1997/09/08 21:48:22 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/adt/datetime.c,v 1.17 1997/10/25 05:16:09 thomas Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -110,12 +110,12 @@ date_in(char *str) ...@@ -110,12 +110,12 @@ date_in(char *str)
date = (date2j(tm->tm_year, tm->tm_mon, tm->tm_mday) - date2j(2000, 1, 1)); date = (date2j(tm->tm_year, tm->tm_mon, tm->tm_mday) - date2j(2000, 1, 1));
return (date); return (date);
} /* date_in() */ } /* date_in() */
/* date_out() /* date_out()
* Given internal format date, convert to text string. * Given internal format date, convert to text string.
*/ */
char * char *
date_out(DateADT date) date_out(DateADT date)
{ {
char *result; char *result;
...@@ -123,31 +123,17 @@ date_out(DateADT date) ...@@ -123,31 +123,17 @@ date_out(DateADT date)
*tm = &tt; *tm = &tt;
char buf[MAXDATELEN + 1]; char buf[MAXDATELEN + 1];
#if FALSE
int year,
month,
day;
#endif
j2date((date + date2j(2000, 1, 1)), j2date((date + date2j(2000, 1, 1)),
&(tm->tm_year), &(tm->tm_mon), &(tm->tm_mday)); &(tm->tm_year), &(tm->tm_mon), &(tm->tm_mday));
EncodeDateOnly(tm, DateStyle, buf); EncodeDateOnly(tm, DateStyle, buf);
#if FALSE
if (EuroDates == 1) /* Output European-format dates */
sprintf(buf, "%02d-%02d-%04d", day, month, year);
else
sprintf(buf, "%02d-%02d-%04d", month, day, year);
#endif
result = PALLOC(strlen(buf) + 1); result = PALLOC(strlen(buf) + 1);
strcpy(result, buf); strcpy(result, buf);
return (result); return (result);
} /* date_out() */ } /* date_out() */
bool bool
date_eq(DateADT dateVal1, DateADT dateVal2) date_eq(DateADT dateVal1, DateADT dateVal2)
...@@ -165,25 +151,25 @@ bool ...@@ -165,25 +151,25 @@ bool
date_lt(DateADT dateVal1, DateADT dateVal2) date_lt(DateADT dateVal1, DateADT dateVal2)
{ {
return (dateVal1 < dateVal2); return (dateVal1 < dateVal2);
} /* date_lt() */ } /* date_lt() */
bool bool
date_le(DateADT dateVal1, DateADT dateVal2) date_le(DateADT dateVal1, DateADT dateVal2)
{ {
return (dateVal1 <= dateVal2); return (dateVal1 <= dateVal2);
} /* date_le() */ } /* date_le() */
bool bool
date_gt(DateADT dateVal1, DateADT dateVal2) date_gt(DateADT dateVal1, DateADT dateVal2)
{ {
return (dateVal1 > dateVal2); return (dateVal1 > dateVal2);
} /* date_gt() */ } /* date_gt() */
bool bool
date_ge(DateADT dateVal1, DateADT dateVal2) date_ge(DateADT dateVal1, DateADT dateVal2)
{ {
return (dateVal1 >= dateVal2); return (dateVal1 >= dateVal2);
} /* date_ge() */ } /* date_ge() */
int int
date_cmp(DateADT dateVal1, DateADT dateVal2) date_cmp(DateADT dateVal1, DateADT dateVal2)
...@@ -197,47 +183,50 @@ date_cmp(DateADT dateVal1, DateADT dateVal2) ...@@ -197,47 +183,50 @@ date_cmp(DateADT dateVal1, DateADT dateVal2)
return 1; return 1;
} }
return 0; return 0;
} /* date_cmp() */ } /* date_cmp() */
DateADT DateADT
date_larger(DateADT dateVal1, DateADT dateVal2) date_larger(DateADT dateVal1, DateADT dateVal2)
{ {
return (date_gt(dateVal1, dateVal2) ? dateVal1 : dateVal2); return (date_gt(dateVal1, dateVal2) ? dateVal1 : dateVal2);
} /* date_larger() */ } /* date_larger() */
DateADT DateADT
date_smaller(DateADT dateVal1, DateADT dateVal2) date_smaller(DateADT dateVal1, DateADT dateVal2)
{ {
return (date_lt(dateVal1, dateVal2) ? dateVal1 : dateVal2); return (date_lt(dateVal1, dateVal2) ? dateVal1 : dateVal2);
} /* date_smaller() */ } /* date_smaller() */
/* Compute difference between two dates in days. */ /* Compute difference between two dates in days.
*/
int4 int4
date_mi(DateADT dateVal1, DateADT dateVal2) date_mi(DateADT dateVal1, DateADT dateVal2)
{ {
return (dateVal1 - dateVal2); return (dateVal1 - dateVal2);
} /* date_mi() */ } /* date_mi() */
/* Add a number of days to a date, giving a new date. /* Add a number of days to a date, giving a new date.
Must handle both positive and negative numbers of days. */ * Must handle both positive and negative numbers of days.
*/
DateADT DateADT
date_pli(DateADT dateVal, int4 days) date_pli(DateADT dateVal, int4 days)
{ {
return (dateVal + days); return (dateVal + days);
} /* date_pli() */ } /* date_pli() */
/* Subtract a number of days from a date, giving a new date. */ /* Subtract a number of days from a date, giving a new date.
*/
DateADT DateADT
date_mii(DateADT dateVal, int4 days) date_mii(DateADT dateVal, int4 days)
{ {
return (date_pli(dateVal, -days)); return (date_pli(dateVal, -days));
} /* date_mii() */ } /* date_mii() */
/* date_datetime() /* date_datetime()
* Convert date to datetime data type. * Convert date to datetime data type.
*/ */
DateTime * DateTime *
date_datetime(DateADT dateVal) date_datetime(DateADT dateVal)
{ {
DateTime *result; DateTime *result;
...@@ -261,7 +250,7 @@ date_datetime(DateADT dateVal) ...@@ -261,7 +250,7 @@ date_datetime(DateADT dateVal)
elog(WARN, "Datetime out of range", NULL); elog(WARN, "Datetime out of range", NULL);
return (result); return (result);
} /* date_datetime() */ } /* date_datetime() */
/* datetime_date() /* datetime_date()
...@@ -302,7 +291,7 @@ datetime_date(DateTime *datetime) ...@@ -302,7 +291,7 @@ datetime_date(DateTime *datetime)
result = (date2j(tm->tm_year, tm->tm_mon, tm->tm_mday) - date2j(2000, 1, 1)); result = (date2j(tm->tm_year, tm->tm_mon, tm->tm_mday) - date2j(2000, 1, 1));
return (result); return (result);
} /* datetime_date() */ } /* datetime_date() */
/* abstime_date() /* abstime_date()
...@@ -344,7 +333,7 @@ abstime_date(AbsoluteTime abstime) ...@@ -344,7 +333,7 @@ abstime_date(AbsoluteTime abstime)
} }
return (result); return (result);
} /* abstime_date() */ } /* abstime_date() */
/* date2tm() /* date2tm()
...@@ -388,11 +377,6 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn) ...@@ -388,11 +377,6 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn)
tm->tm_year = tx->tm_year + 1900; tm->tm_year = tx->tm_year + 1900;
tm->tm_mon = tx->tm_mon + 1; tm->tm_mon = tx->tm_mon + 1;
tm->tm_mday = tx->tm_mday; tm->tm_mday = tx->tm_mday;
#if FALSE
tm->tm_hour = tx->tm_hour;
tm->tm_min = tx->tm_min;
tm->tm_sec = tx->tm_sec;
#endif
tm->tm_isdst = tx->tm_isdst; tm->tm_isdst = tx->tm_isdst;
#ifdef HAVE_INT_TIMEZONE #ifdef HAVE_INT_TIMEZONE
...@@ -420,13 +404,6 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn) ...@@ -420,13 +404,6 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn)
} }
else else
{ {
#if FALSE
j2date((dateVal + date2j(2000, 1, 1)), &(tm->tm_year), &(tm->tm_mon), &(tm->tm_mday));
tm->tm_hour = 0;
tm->tm_min = 0;
tm->tm_sec = 0;
#endif
#ifdef DATEDEBUG #ifdef DATEDEBUG
printf("date2tm- convert %d-%d-%d %d:%d%d to datetime\n", printf("date2tm- convert %d-%d-%d %d:%d%d to datetime\n",
tm->tm_year, tm->tm_mon, tm->tm_mday, tm->tm_hour, tm->tm_min, tm->tm_sec); tm->tm_year, tm->tm_mon, tm->tm_mday, tm->tm_hour, tm->tm_min, tm->tm_sec);
...@@ -439,7 +416,7 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn) ...@@ -439,7 +416,7 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn)
} }
return 0; return 0;
} /* date2tm() */ } /* date2tm() */
/***************************************************************************** /*****************************************************************************
...@@ -447,7 +424,7 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn) ...@@ -447,7 +424,7 @@ date2tm(DateADT dateVal, int *tzp, struct tm * tm, double *fsec, char **tzn)
*****************************************************************************/ *****************************************************************************/
TimeADT * TimeADT *
time_in(char *str) time_in(char *str)
{ {
TimeADT *time; TimeADT *time;
...@@ -481,22 +458,16 @@ time_in(char *str) ...@@ -481,22 +458,16 @@ time_in(char *str)
*time = ((((tm->tm_hour * 60) + tm->tm_min) * 60) + tm->tm_sec + fsec); *time = ((((tm->tm_hour * 60) + tm->tm_min) * 60) + tm->tm_sec + fsec);
return (time); return (time);
} /* time_in() */ } /* time_in() */
char * char *
time_out(TimeADT *time) time_out(TimeADT *time)
{ {
char *result; char *result;
struct tm tt, struct tm tt,
*tm = &tt; *tm = &tt;
#if FALSE
int hour,
min,
sec;
#endif
double fsec; double fsec;
char buf[MAXDATELEN + 1]; char buf[MAXDATELEN + 1];
...@@ -511,31 +482,12 @@ time_out(TimeADT *time) ...@@ -511,31 +482,12 @@ time_out(TimeADT *time)
EncodeTimeOnly(tm, fsec, DateStyle, buf); EncodeTimeOnly(tm, fsec, DateStyle, buf);
#if FALSE
if (sec == 0.0)
{
sprintf(buf, "%02d:%02d", hour, min);
}
else
{
if (fsec == 0)
{
sprintf(buf, "%02d:%02d:%02d", hour, min, sec);
}
else
{
sprintf(buf, "%02d:%02d:%05.2f", hour, min, (sec + fsec));
}
}
#endif
result = PALLOC(strlen(buf) + 1); result = PALLOC(strlen(buf) + 1);
strcpy(result, buf); strcpy(result, buf);
return (result); return (result);
} /* time_out() */ } /* time_out() */
bool bool
...@@ -545,7 +497,7 @@ time_eq(TimeADT *time1, TimeADT *time2) ...@@ -545,7 +497,7 @@ time_eq(TimeADT *time1, TimeADT *time2)
return (FALSE); return (FALSE);
return (*time1 == *time2); return (*time1 == *time2);
} /* time_eq() */ } /* time_eq() */
bool bool
time_ne(TimeADT *time1, TimeADT *time2) time_ne(TimeADT *time1, TimeADT *time2)
...@@ -554,7 +506,7 @@ time_ne(TimeADT *time1, TimeADT *time2) ...@@ -554,7 +506,7 @@ time_ne(TimeADT *time1, TimeADT *time2)
return (FALSE); return (FALSE);
return (*time1 != *time2); return (*time1 != *time2);
} /* time_eq() */ } /* time_eq() */
bool bool
time_lt(TimeADT *time1, TimeADT *time2) time_lt(TimeADT *time1, TimeADT *time2)
...@@ -563,7 +515,7 @@ time_lt(TimeADT *time1, TimeADT *time2) ...@@ -563,7 +515,7 @@ time_lt(TimeADT *time1, TimeADT *time2)
return (FALSE); return (FALSE);
return (*time1 < *time2); return (*time1 < *time2);
} /* time_eq() */ } /* time_eq() */
bool bool
time_le(TimeADT *time1, TimeADT *time2) time_le(TimeADT *time1, TimeADT *time2)
...@@ -572,7 +524,7 @@ time_le(TimeADT *time1, TimeADT *time2) ...@@ -572,7 +524,7 @@ time_le(TimeADT *time1, TimeADT *time2)
return (FALSE); return (FALSE);
return (*time1 <= *time2); return (*time1 <= *time2);
} /* time_eq() */ } /* time_eq() */
bool bool
time_gt(TimeADT *time1, TimeADT *time2) time_gt(TimeADT *time1, TimeADT *time2)
...@@ -581,7 +533,7 @@ time_gt(TimeADT *time1, TimeADT *time2) ...@@ -581,7 +533,7 @@ time_gt(TimeADT *time1, TimeADT *time2)
return (FALSE); return (FALSE);
return (*time1 > *time2); return (*time1 > *time2);
} /* time_eq() */ } /* time_eq() */
bool bool
time_ge(TimeADT *time1, TimeADT *time2) time_ge(TimeADT *time1, TimeADT *time2)
...@@ -590,20 +542,65 @@ time_ge(TimeADT *time1, TimeADT *time2) ...@@ -590,20 +542,65 @@ time_ge(TimeADT *time1, TimeADT *time2)
return (FALSE); return (FALSE);
return (*time1 >= *time2); return (*time1 >= *time2);
} /* time_eq() */ } /* time_eq() */
int int
time_cmp(TimeADT *time1, TimeADT *time2) time_cmp(TimeADT *time1, TimeADT *time2)
{ {
return ((*time1 < *time2) ? -1 : (((*time1 > *time2) ? 1 : 0))); return ((*time1 < *time2) ? -1 : (((*time1 > *time2) ? 1 : 0)));
} /* time_cmp() */ } /* time_cmp() */
/* datetime_datetime() /* datetime_time()
* Convert datetime to time data type.
*/
TimeADT *
datetime_time(DateTime *datetime)
{
TimeADT *result;
struct tm tt,
*tm = &tt;
int tz;
double fsec;
char *tzn;
if (!PointerIsValid(datetime))
elog(WARN, "Unable to convert null datetime to date", NULL);
if (DATETIME_NOT_FINITE(*datetime))
elog(WARN, "Unable to convert datetime to date", NULL);
if (DATETIME_IS_EPOCH(*datetime))
{
datetime2tm(SetDateTime(*datetime), NULL, tm, &fsec, NULL);
}
else if (DATETIME_IS_CURRENT(*datetime))
{
datetime2tm(SetDateTime(*datetime), &tz, tm, &fsec, &tzn);
}
else
{
if (datetime2tm(*datetime, &tz, tm, &fsec, &tzn) != 0)
elog(WARN, "Unable to convert datetime to date", NULL);
}
result = PALLOCTYPE(TimeADT);
*result = ((((tm->tm_hour * 60) + tm->tm_min) * 60) + tm->tm_sec + fsec);
return (result);
} /* datetime_time() */
/* datet_datetime()
* Convert date and time to datetime data type. * Convert date and time to datetime data type.
* Should be called datetime_datetime()
* but need <= 16 characters for function names.
*/ */
DateTime * DateTime *
datetime_datetime(DateADT date, TimeADT *time) datet_datetime(DateADT date, TimeADT *time)
{ {
DateTime *result; DateTime *result;
...@@ -611,16 +608,13 @@ datetime_datetime(DateADT date, TimeADT *time) ...@@ -611,16 +608,13 @@ datetime_datetime(DateADT date, TimeADT *time)
{ {
result = PALLOCTYPE(DateTime); result = PALLOCTYPE(DateTime);
DATETIME_INVALID(*result); DATETIME_INVALID(*result);
} else {
}
else
{
result = date_datetime(date); result = date_datetime(date);
*result += *time; *result += *time;
} }
return (result); return (result);
} /* datetime_datetime() */ } /* datet_datetime() */
int32 /* RelativeTime */ int32 /* RelativeTime */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment