Discussion:
[perl.git] branch blead, updated. GitLive-blead-824-g7430375
(too old to reply)
Craig A. Berry
2009-03-26 16:08:04 UTC
Permalink
In perl.git, the branch blead has been updated

<http://perl5.git.perl.org/perl.git/commitdiff/7430375d1909c2b62c1fb3f9c6ed4b9d24dfcf32?hp=5c1e544edd3a9f584fd8b4c8d2f6dcbf01639ec2>

- Log -----------------------------------------------------------------
commit 7430375d1909c2b62c1fb3f9c6ed4b9d24dfcf32
Author: Craig A. Berry <***@mac.com>
Date: Thu Mar 26 10:44:41 2009 -0500

Namespace clean-up for time64.

All of the time64 functions are only visible within pp_sys.c and are not
part of the public API, so make them all static and give them the S_ prefix.
A side effect of this is that we now unambiguously use S_localtime64_r and
S_gmtime64_r and should no longer collide with system-supplied versions, if
any.

One possible future direction is that if and when Configure detects any
system-supplied *time64_r functions, their prototypes, and their valid
time ranges, we could optionally select those instead of the home-grown
ones.

Another possible future direction is that we could s/S_/Perl_/ and make
the *time64_r functions part of the public API in some post-5.10.x
release. Currently they are only exposed to the outside world via
Perl_pp_gmtime.

Also gave some TRACE macros more specific names.
-----------------------------------------------------------------------

Summary of changes:
pp_sys.c | 4 +-
time64.c | 90 +++++++++++++++++++++++++++++++------------------------------
time64.h | 12 ++++----
3 files changed, 54 insertions(+), 52 deletions(-)

diff --git a/pp_sys.c b/pp_sys.c
index b42cced..46cb17e 100644
--- a/pp_sys.c
+++ b/pp_sys.c
@@ -4473,9 +4473,9 @@ PP(pp_gmtime)
}

if (PL_op->op_type == OP_LOCALTIME)
- err = localtime64_r(&when, &tmbuf);
+ err = S_localtime64_r(&when, &tmbuf);
else
- err = gmtime64_r(&when, &tmbuf);
+ err = S_gmtime64_r(&when, &tmbuf);
#endif

if (err == NULL && ckWARN(WARN_OVERFLOW)) {
diff --git a/time64.c b/time64.c
index 0f58812..1453bd9 100755
--- a/time64.c
+++ b/time64.c
@@ -33,9 +33,9 @@ long' type can use localtime64_r() and gmtime64_r() which correctly
converts the time even on 32-bit systems. Whether you have 64-bit time
values will depend on the operating system.

-localtime64_r() is a 64-bit equivalent of localtime_r().
+S_localtime64_r() is a 64-bit equivalent of localtime_r().

-gmtime64_r() is a 64-bit equivalent of gmtime_r().
+S_gmtime64_r() is a 64-bit equivalent of gmtime_r().

*/

@@ -110,27 +110,27 @@ static const int dow_year_start[SOLAR_CYCLE_LENGTH] = {

/* Multi varadic macros are a C99 thing, alas */
#ifdef TIME_64_DEBUG
-# define TRACE(format) (fprintf(stderr, format))
-# define TRACE1(format, var1) (fprintf(stderr, format, var1))
-# define TRACE2(format, var1, var2) (fprintf(stderr, format, var1, var2))
-# define TRACE3(format, var1, var2, var3) (fprintf(stderr, format, var1, var2, var3))
+# define TIME64_TRACE(format) (fprintf(stderr, format))
+# define TIME64_TRACE1(format, var1) (fprintf(stderr, format, var1))
+# define TIME64_TRACE2(format, var1, var2) (fprintf(stderr, format, var1, var2))
+# define TIME64_TRACE3(format, var1, var2, var3) (fprintf(stderr, format, var1, var2, var3))
#else
-# define TRACE(format) ((void)0)
-# define TRACE1(format, var1) ((void)0)
-# define TRACE2(format, var1, var2) ((void)0)
-# define TRACE3(format, var1, var2, var3) ((void)0)
+# define TIME64_TRACE(format) ((void)0)
+# define TIME64_TRACE1(format, var1) ((void)0)
+# define TIME64_TRACE2(format, var1, var2) ((void)0)
+# define TIME64_TRACE3(format, var1, var2, var3) ((void)0)
#endif

-static int is_exception_century(Year year)
+static int S_is_exception_century(Year year)
{
int is_exception = ((year % 100 == 0) && !(year % 400 == 0));
- TRACE1("# is_exception_century: %s\n", is_exception ? "yes" : "no");
+ TIME64_TRACE1("# is_exception_century: %s\n", is_exception ? "yes" : "no");

return(is_exception);
}


-Time64_T timegm64(struct TM *date) {
+static Time64_T S_timegm64(struct TM *date) {
int days = 0;
Time64_T seconds = 0;
Year year;
@@ -166,7 +166,7 @@ Time64_T timegm64(struct TM *date) {


#ifdef DEBUGGING
-static int check_tm(struct TM *tm)
+static int S_check_tm(struct TM *tm)
{
/* Don't forget leap seconds */
assert(tm->tm_sec >= 0);
@@ -203,7 +203,7 @@ static int check_tm(struct TM *tm)
/* The exceptional centuries without leap years cause the cycle to
shift by 16
*/
-static Year cycle_offset(Year year)
+static Year S_cycle_offset(Year year)
{
const Year start_year = 2000;
Year year_diff = year - start_year;
@@ -215,7 +215,7 @@ static Year cycle_offset(Year year)
exceptions = year_diff / 100;
exceptions -= year_diff / 400;

- TRACE3("# year: %lld, exceptions: %lld, year_diff: %lld\n",
+ TIME64_TRACE3("# year: %lld, exceptions: %lld, year_diff: %lld\n",
year, exceptions, year_diff);

return exceptions * 16;
@@ -238,17 +238,17 @@ static Year cycle_offset(Year year)
It doesn't need the same leap year status since we only care about
January 1st.
*/
-static int safe_year(Year year)
+static int S_safe_year(Year year)
{
int safe_year;
- Year year_cycle = year + cycle_offset(year);
+ Year year_cycle = year + S_cycle_offset(year);

/* Change non-leap xx00 years to an equivalent */
- if( is_exception_century(year) )
+ if( S_is_exception_century(year) )
year_cycle += 11;

/* Also xx01 years, since the previous year will be wrong */
- if( is_exception_century(year - 1) )
+ if( S_is_exception_century(year - 1) )
year_cycle += 17;

year_cycle %= SOLAR_CYCLE_LENGTH;
@@ -261,14 +261,14 @@ static int safe_year(Year year)

assert(safe_year <= 2037 && safe_year >= 2010);

- TRACE3("# year: %lld, year_cycle: %lld, safe_year: %d\n",
+ TIME64_TRACE3("# year: %lld, year_cycle: %lld, safe_year: %d\n",
year, year_cycle, safe_year);

return safe_year;
}


-void copy_little_tm_to_big_TM(const struct tm *src, struct TM *dest) {
+static void S_copy_little_tm_to_big_TM(const struct tm *src, struct TM *dest) {
if( src == NULL ) {
memset(dest, 0, sizeof(*dest));
}
@@ -300,7 +300,7 @@ void copy_little_tm_to_big_TM(const struct tm *src, struct TM *dest) {
}


-void copy_big_TM_to_little_tm(const struct TM *src, struct tm *dest) {
+static void S_copy_big_TM_to_little_tm(const struct TM *src, struct tm *dest) {
if( src == NULL ) {
memset(dest, 0, sizeof(*dest));
}
@@ -332,8 +332,9 @@ void copy_big_TM_to_little_tm(const struct TM *src, struct tm *dest) {
}


+#ifndef HAS_LOCALTIME_R
/* Simulate localtime_r() to the best of our ability */
-struct tm * fake_localtime_r(const time_t *clock, struct tm *result) {
+static struct tm * S_localtime_r(const time_t *clock, struct tm *result) {
dTHX; /* in case the following is defined as Perl_my_localtime(aTHX_ ...) */
const struct tm *static_result = localtime(clock);

@@ -348,10 +349,11 @@ struct tm * fake_localtime_r(const time_t *clock, struct tm *result) {
return result;
}
}
+#endif

-
+#ifndef HAS_GMTIME_R
/* Simulate gmtime_r() to the best of our ability */
-struct tm * fake_gmtime_r(const time_t *clock, struct tm *result) {
+static struct tm * S_gmtime_r(const time_t *clock, struct tm *result) {
dTHX; /* in case the following is defined as Perl_my_gmtime(aTHX_ ...) */
const struct tm *static_result = gmtime(clock);

@@ -366,9 +368,9 @@ struct tm * fake_gmtime_r(const time_t *clock, struct tm *result) {
return result;
}
}
+#endif

-
-struct TM *gmtime64_r (const Time64_T *in_time, struct TM *p)
+static struct TM *S_gmtime64_r (const Time64_T *in_time, struct TM *p)
{
int v_tm_sec, v_tm_min, v_tm_hour, v_tm_mon, v_tm_wday;
Time64_T v_tm_tday;
@@ -386,8 +388,8 @@ struct TM *gmtime64_r (const Time64_T *in_time, struct TM *p)
struct tm safe_date;
GMTIME_R(&safe_time, &safe_date);

- copy_little_tm_to_big_TM(&safe_date, p);
- assert(check_tm(p));
+ S_copy_little_tm_to_big_TM(&safe_date, p);
+ assert(S_check_tm(p));

return p;
}
@@ -489,13 +491,13 @@ struct TM *gmtime64_r (const Time64_T *in_time, struct TM *p)
p->tm_mon = v_tm_mon;
p->tm_wday = v_tm_wday;

- assert(check_tm(p));
+ assert(S_check_tm(p));

return p;
}


-struct TM *localtime64_r (const Time64_T *time, struct TM *local_tm)
+struct TM *S_localtime64_r (const Time64_T *time, struct TM *local_tm)
{
time_t safe_time;
struct tm safe_date;
@@ -509,18 +511,18 @@ struct TM *localtime64_r (const Time64_T *time, struct TM *local_tm)
if( SHOULD_USE_SYSTEM_LOCALTIME(*time) ) {
safe_time = (time_t)*time;

- TRACE1("Using system localtime for %lld\n", *time);
+ TIME64_TRACE1("Using system localtime for %lld\n", *time);

LOCALTIME_R(&safe_time, &safe_date);

- copy_little_tm_to_big_TM(&safe_date, local_tm);
- assert(check_tm(local_tm));
+ S_copy_little_tm_to_big_TM(&safe_date, local_tm);
+ assert(S_check_tm(local_tm));

return local_tm;
}

- if( gmtime64_r(time, &gm_tm) == NULL ) {
- TRACE1("gmtime64_r returned null for %lld\n", *time);
+ if( S_gmtime64_r(time, &gm_tm) == NULL ) {
+ TIME64_TRACE1("gmtime64_r returned null for %lld\n", *time);
return NULL;
}

@@ -530,21 +532,21 @@ struct TM *localtime64_r (const Time64_T *time, struct TM *local_tm)
gm_tm.tm_year < (1970 - 1900)
)
{
- TRACE1("Mapping tm_year %lld to safe_year\n", (Year)gm_tm.tm_year);
- gm_tm.tm_year = safe_year((Year)(gm_tm.tm_year + 1900)) - 1900;
+ TIME64_TRACE1("Mapping tm_year %lld to safe_year\n", (Year)gm_tm.tm_year);
+ gm_tm.tm_year = S_safe_year((Year)(gm_tm.tm_year + 1900)) - 1900;
}

- safe_time = (time_t)timegm64(&gm_tm);
+ safe_time = (time_t)S_timegm64(&gm_tm);
if( LOCALTIME_R(&safe_time, &safe_date) == NULL ) {
- TRACE1("localtime_r(%d) returned NULL\n", (int)safe_time);
+ TIME64_TRACE1("localtime_r(%d) returned NULL\n", (int)safe_time);
return NULL;
}

- copy_little_tm_to_big_TM(&safe_date, local_tm);
+ S_copy_little_tm_to_big_TM(&safe_date, local_tm);

local_tm->tm_year = orig_year;
if( local_tm->tm_year != orig_year ) {
- TRACE2("tm_year overflow: tm_year %lld, orig_year %lld\n",
+ TIME64_TRACE2("tm_year overflow: tm_year %lld, orig_year %lld\n",
(Year)local_tm->tm_year, (Year)orig_year);

#ifdef EOVERFLOW
@@ -579,7 +581,7 @@ struct TM *localtime64_r (const Time64_T *time, struct TM *local_tm)
if( !IS_LEAP(local_tm->tm_year) && local_tm->tm_yday == 365 )
local_tm->tm_yday--;

- assert(check_tm(local_tm));
+ assert(S_check_tm(local_tm));

return local_tm;
}
diff --git a/time64.h b/time64.h
index 329d425..000f101 100644
--- a/time64.h
+++ b/time64.h
@@ -45,22 +45,22 @@ struct TM64 {
#endif


-/* Declare public functions */
-struct TM *gmtime64_r (const Time64_T *, struct TM *);
-struct TM *localtime64_r (const Time64_T *, struct TM *);
-Time64_T timegm64 (struct TM *);
+/* Declare functions */
+static struct TM *S_gmtime64_r (const Time64_T *, struct TM *);
+static struct TM *S_localtime64_r (const Time64_T *, struct TM *);
+static Time64_T S_timegm64 (struct TM *);


/* Not everyone has gm/localtime_r(), provide a replacement */
#ifdef HAS_LOCALTIME_R
# define LOCALTIME_R(clock, result) (L_R_TZSET localtime_r(clock, result))
#else
-# define LOCALTIME_R(clock, result) (L_R_TZSET fake_localtime_r(clock, result))
+# define LOCALTIME_R(clock, result) (L_R_TZSET S_localtime_r(clock, result))
#endif
#ifdef HAS_GMTIME_R
# define GMTIME_R(clock, result) gmtime_r(clock, result)
#else
-# define GMTIME_R(clock, result) fake_gmtime_r(clock, result)
+# define GMTIME_R(clock, result) S_gmtime_r(clock, result)
#endif

#endif

--
Perl5 Master Repository
Jerry D. Hedden
2009-03-26 19:42:13 UTC
Permalink
Post by Craig A. Berry
In perl.git, the branch blead has been updated
<http://perl5.git.perl.org/perl.git/commitdiff/7430375d1909c2b62c1fb3f9c6ed4b9d24dfcf32?hp=5c1e544edd3a9f584fd8b4c8d2f6dcbf01639ec2>
   Namespace clean-up for time64.
   All of the time64 functions are only visible within pp_sys.c and are not
   part of the public API, so make them all static and give them the S_ prefix.
-void copy_big_TM_to_little_tm(const struct TM *src, struct tm *dest) {
+static void S_copy_big_TM_to_little_tm(const struct TM *src, struct tm *dest) {
    if( src == NULL ) {
        memset(dest, 0, sizeof(*dest));
    }
This function (S_copy_big_TM_to_little_tm) is not used
anywhere that I can find, and causes the following build
warning:

time64.c:303: warning: 'S_copy_big_TM_to_little_tm' defined but not used
Craig A. Berry
2009-03-26 20:22:26 UTC
Permalink
Post by Jerry D. Hedden
Post by Craig A. Berry
In perl.git, the branch blead has been updated
<http://perl5.git.perl.org/perl.git/commitdiff/7430375d1909c2b62c1fb3f9c6ed4b9d24dfcf32?hp=5c1e544edd3a9f584fd8b4c8d2f6dcbf01639ec2
Namespace clean-up for time64.
All of the time64 functions are only visible within pp_sys.c and are not
part of the public API, so make them all static and give them the S_ prefix.
-void copy_big_TM_to_little_tm(const struct TM *src, struct tm *dest) {
+static void S_copy_big_TM_to_little_tm(const struct TM *src,
struct tm *dest) {
if( src == NULL ) {
memset(dest, 0, sizeof(*dest));
}
This function (S_copy_big_TM_to_little_tm) is not used
anywhere that I can find, and causes the following build
time64.c:303: warning: 'S_copy_big_TM_to_little_tm' defined but not used
Ah, good. Making it static revealed more clean-up that we can do.
I'll snip that function out of there shortly. Thanks for the heads up.

________________________________________
Craig A. Berry
mailto:***@mac.com

"... getting out of a sonnet is much more
difficult than getting in."
Brad Leithauser

Loading...