Rename timezone to avoid shadowing

This commit is contained in:
Bruce Hill 2025-03-28 13:45:16 -04:00
parent a0b18d9867
commit a79b3c2216

View File

@ -63,7 +63,7 @@ public Moment_t Moment$now(void)
return (Moment_t){.tv_sec=ts.tv_sec, .tv_usec=ts.tv_nsec/1000};
}
public Moment_t Moment$new(Int_t year, Int_t month, Int_t day, Int_t hour, Int_t minute, double second, OptionalText_t timezone)
public Moment_t Moment$new(Int_t year, Int_t month, Int_t day, Int_t hour, Int_t minute, double second, OptionalText_t tz)
{
struct tm info = {
.tm_min=Int32$from_int(minute, false),
@ -75,17 +75,17 @@ public Moment_t Moment$new(Int_t year, Int_t month, Int_t day, Int_t hour, Int_t
};
time_t t;
WITH_TIMEZONE(timezone, t = mktime(&info));
WITH_TIMEZONE(tz, t = mktime(&info));
return (Moment_t){.tv_sec=t + (time_t)second, .tv_usec=(suseconds_t)(fmod(second, 1.0) * 1e9)};
}
public Moment_t Moment$after(Moment_t moment, double seconds, double minutes, double hours, Int_t days, Int_t weeks, Int_t months, Int_t years, OptionalText_t timezone)
public Moment_t Moment$after(Moment_t moment, double seconds, double minutes, double hours, Int_t days, Int_t weeks, Int_t months, Int_t years, OptionalText_t tz)
{
double offset = seconds + 60.*minutes + 3600.*hours;
moment.tv_sec += (time_t)offset;
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
info.tm_mday += Int32$from_int(days, false) + 7*Int32$from_int(weeks, false);
info.tm_mon += Int32$from_int(months, false);
@ -115,10 +115,10 @@ CONSTFUNC public double Moment$hours_till(Moment_t now, Moment_t then)
public void Moment$get(
Moment_t moment, Int_t *year, Int_t *month, Int_t *day, Int_t *hour, Int_t *minute, Int_t *second,
Int_t *nanosecond, Int_t *weekday, OptionalText_t timezone)
Int_t *nanosecond, Int_t *weekday, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
if (year) *year = I(info.tm_year + 1900);
if (month) *month = I(info.tm_mon + 1);
@ -130,89 +130,89 @@ public void Moment$get(
if (weekday) *weekday = I(info.tm_wday + 1);
}
public Int_t Moment$year(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$year(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_year + 1900);
}
public Int_t Moment$month(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$month(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_mon + 1);
}
public Int_t Moment$day_of_week(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$day_of_week(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_wday + 1);
}
public Int_t Moment$day_of_month(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$day_of_month(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_mday);
}
public Int_t Moment$day_of_year(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$day_of_year(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_yday);
}
public Int_t Moment$hour(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$hour(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_hour);
}
public Int_t Moment$minute(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$minute(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_min);
}
public Int_t Moment$second(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$second(Moment_t moment, OptionalText_t tz)
{
struct tm info = {};
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
return I(info.tm_sec);
}
public Int_t Moment$microsecond(Moment_t moment, OptionalText_t timezone)
public Int_t Moment$microsecond(Moment_t moment, OptionalText_t tz)
{
(void)timezone;
(void)tz;
return I(moment.tv_usec);
}
public Text_t Moment$format(Moment_t moment, Text_t fmt, OptionalText_t timezone)
public Text_t Moment$format(Moment_t moment, Text_t fmt, OptionalText_t tz)
{
struct tm info;
WITH_TIMEZONE(timezone, localtime_r(&moment.tv_sec, &info));
WITH_TIMEZONE(tz, localtime_r(&moment.tv_sec, &info));
static char buf[256];
size_t len = strftime(buf, sizeof(buf), Text$as_c_string(fmt), &info);
return Text$format("%.*s", (int)len, buf);
}
public Text_t Moment$date(Moment_t moment, OptionalText_t timezone)
public Text_t Moment$date(Moment_t moment, OptionalText_t tz)
{
return Moment$format(moment, Text("%F"), timezone);
return Moment$format(moment, Text("%F"), tz);
}
public Text_t Moment$time(Moment_t moment, bool seconds, bool am_pm, OptionalText_t timezone)
public Text_t Moment$time(Moment_t moment, bool seconds, bool am_pm, OptionalText_t tz)
{
Text_t text;
if (seconds)
text = Moment$format(moment, am_pm ? Text("%l:%M:%S%P") : Text("%T"), timezone);
text = Moment$format(moment, am_pm ? Text("%l:%M:%S%P") : Text("%T"), tz);
else
text = Moment$format(moment, am_pm ? Text("%l:%M%P") : Text("%H:%M"), timezone);
text = Moment$format(moment, am_pm ? Text("%l:%M%P") : Text("%H:%M"), tz);
return Text$trim(text, Pattern(" "), true, true);
}
@ -228,7 +228,7 @@ public OptionalMoment_t Moment$parse(Text_t text, Text_t format)
if (!invalid || invalid[0] != '\0')
return NONE_MOMENT;
long offset = info.tm_gmtoff; // Need to cache this because mktime() mutates it to local timezone >:(
long offset = info.tm_gmtoff; // Need to cache this because mktime() mutates it to local tz >:(
time_t t = mktime(&info);
return (Moment_t){.tv_sec=t + offset - info.tm_gmtoff};
}
@ -240,11 +240,11 @@ static INLINE Text_t num_format(long n, const char *unit)
return Text$format((n == 1 || n == -1) ? "%ld %s %s" : "%ld %ss %s", n < 0 ? -n : n, unit, n < 0 ? "ago" : "later");
}
public Text_t Moment$relative(Moment_t moment, Moment_t relative_to, OptionalText_t timezone)
public Text_t Moment$relative(Moment_t moment, Moment_t relative_to, OptionalText_t tz)
{
struct tm info = {};
struct tm relative_info = {};
WITH_TIMEZONE(timezone, {
WITH_TIMEZONE(tz, {
localtime_r(&moment.tv_sec, &info);
localtime_r(&relative_to.tv_sec, &relative_info);
});
@ -282,14 +282,14 @@ CONSTFUNC public Moment_t Moment$from_unix_timestamp(Int64_t timestamp)
return (Moment_t){.tv_sec=(time_t)timestamp};
}
public void Moment$set_local_timezone(OptionalText_t timezone)
public void Moment$set_local_timezone(OptionalText_t tz)
{
if (timezone.length >= 0) {
setenv("TZ", Text$as_c_string(timezone), 1);
if (tz.length >= 0) {
setenv("TZ", Text$as_c_string(tz), 1);
} else {
unsetenv("TZ");
}
_local_timezone = timezone;
_local_timezone = tz;
tzset();
}
@ -299,13 +299,13 @@ public Text_t Moment$get_local_timezone(void)
static char buf[PATH_MAX];
ssize_t len = readlink("/etc/localtime", buf, sizeof(buf));
if (len < 0)
fail("Could not get local timezone!");
fail("Could not get local tz!");
char *zoneinfo = strstr(buf, "/zoneinfo/");
if (zoneinfo)
_local_timezone = Text$from_str(zoneinfo + strlen("/zoneinfo/"));
else
fail("Could not resolve local timezone!");
fail("Could not resolve local tz!");
}
return _local_timezone;
}