LocalTimeRK (community library)
Summary
Name | Value |
---|---|
Name | LocalTimeRK |
Version | 0.1.2 |
Installs | |
License | MIT |
Author | Rick Kaseguma rickkas7@rickkas7.com |
URL | https://github.com/rickkas7/LocalTimeRK |
Repository | https://github.com/rickkas7/LocalTimeRK.git |
Download | .tar.gz |
All Versions | 0.1.2, 0.1.1, 0.1.0, 0.0.9, 0.0.8, 0.0.7, 0.0.6, 0.0.5, 0.0.4, 0.0.3, 0.0.2, 0.0.1 |
Timezone and DST handling for Particle devices
Example Build Testing
Device OS Version:
This table is generated from an automated build. Success only indicates that the code compiled successfully.
Library Read Me
This content is provided by the library maintainer and has not been validated or approved.
LocalTimeRK
Timezone and DST handling for Particle devices
This library is designed for specific local time and daylight saving time scenarios on Particle devices. It is not intended to solve all problems in all situations, however it will work well in certain scenarios:
- Full API docs
- Github repository: https://github.com/rickkas7/LocalTimeRK/
- License: MIT
What it's good for:
- Managing local time, and daylight saving time, if needed, on devices in a known location
- Mostly intended for devices in your own home
- Managing scheduling of tasks at a specific local time
- Displaying local time
What it's not intended for:
- Mobile devices that may change locations
- Customer devices that could be in any timezone
Features
- Timezone configuration using a POSIX timezone rule string
- Does not require network access to determine timezone and daylight saving transitions
- Good for displaying local time, such as on clock-like devices
- Good for scheduling operations at a specific local time. For example, every day at 8:00 AM regardless of timezone and DST
- Support for locations with DST and without DST (timezone only)
- Should work in the southern hemisphere were DST is opposite on the calendar
- Should work in any country as long as a compatible POSIX timezone configuration string can be generated
What is a POSIX timezone configuration?
For the United States east coast, the configuration string is:
EST5EDT,M3.2.0/2:00:00,M11.1.0/2:00:00"
What this means is:
- "EST" is the standard time timezone name
- 5 is the offset from UTC in hours. Actually -5, as the sign is backwards from the way it's normally expressed. And it could be hours and minutes.
- "EDT" is the daylight saving time timezone name
- "M3.2.0" is when DST starts. Month 3 (March), 2nd week, 0 = Sunday
- "2:00:00" transition to DST at 2:00 AM local time
- "M11.1.0" transition back to standard time November, 1st week, on Sunday
- "2:00:00" transition back to standard time at 2:00 AM local time
There are a bunch of supported formats, including for locations that don't have DST (such as Arizona, "MST7") and southern hemisphere where daylight saving is on the opposite part of the year, such as Eastern Australian time used in Sydney, Australia "AEST-10AEDT,M10.1.0/02:00:00,M4.1.0/03:00:00".
Using for scheduling
This library does not modify the Time
class timezone! This has the potential to disrupt all sorts of things that depend on Time
, and should be avoided. A new class and methods provide access to local time when needed.
Additionally, it's designed to handle scheduling. For example, say you want to perform an operation at 3:00 AM every day, local time. The class can find the UTC time corresponding to this, taking into account timezones and DST changes. Using Time.now()
comparisons (at UTC) is fast and efficient. It's also good when you want to store the desired time in EEPROM, retained memory, or the file system.
The library also handles weird transition scenarios that occur on spring forward (in the north hemisphere) where the hour from 2:00 AM local time to 2:59:59 doesn't exist, and in the fall back where the hour from 1:00:00 to 1:59:59 local time occurs twice.
It also handles other common scheduling scenarios:
- Tomorrow (same time)
- Tomorrow (at a specific local time)
- On a specific day of week at a specific time ("every Saturday at 3:00 AM")
- On a day of week with an ordinal ("on the 2nd Saturday of the month")
- On a specific day of month at a specific time
- Also the last day of the month, the second to last day of the month, ...
- On the next weekday (Monday - Friday)
- On the next weekend day (Saturday - Sunday)
Clock Example
There is an example of using the library to use an Adafruit FeatherWing OLED Display 128x32 as a clock.
The display is available at Adafruit. You can find more technical information at Adafruit. The library is available in the Web IDE as oled-wing-adafruit. You can find additional documentation here.
The code example is in the more-examples directory in the Clock directory and is quite simple:
#include "Particle.h"
#include "LocalTimeRK.h"
#include "oled-wing-adafruit.h"
SerialLogHandler logHandler;
SYSTEM_THREAD(ENABLED);
OledWingAdafruit display;
void setup() {
// Set timezone to the Eastern United States
LocalTime::instance().withConfig(LocalTimePosixTimezone("EST5EDT,M3.2.0/2:00:00,M11.1.0/2:00:00"));
display.setup();
display.clearDisplay();
display.display();
}
void loop() {
static unsigned long lastUpdate = 0;
if (millis() - lastUpdate >= 1000 && Time.isValid()) {
lastUpdate = millis();
LocalTimeConvert conv;
conv.withCurrentTime().convert();
// Log.info("local time: %s", conv.format(TIME_FORMAT_ISO8601_FULL).c_str());
// Room for 11 characters at text size 2
display.clearDisplay();
display.setTextColor(WHITE);
display.setTextSize(2);
display.setFont(NULL);
display.setCursor(0, 1);
String msg;
msg = conv.format("%Y-%m-%d"); // 2021-06-07
display.println(msg);
msg = conv.format("%I:%M:%S%p"); // 10:00:00AM
display.println(msg);
display.display();
}
}
(image removed)
Using the library
Configure the timezone
Determine the POSIX timezone string for your location. For example, the US eastern timezone is shown in the example
At setup, configure the timezone:
LocalTime::instance().withConfig(LocalTimePosixTimezone("EST5EDT,M3.2.0/2:00:00,M11.1.0/2:00:00"));
Some configuration strings:
Location | Timezone Configuration |
---|---|
New York | "EST5EDT,M3.2.0/02:00:00,M11.1.0/02:00:00" |
Chicago | "CST6CDT,M3.2.0/2:00:00,M11.1.0/2:00:00" |
Denver | "MST7MDT,M3.2.0/2:00:00,M11.1.0/2:00:00" |
Phoenix | "MST7" |
Los Angeles | "PST8PDT,M3.2.0/2:00:00,M11.1.0/2:00:00" |
London | "BST0GMT,M3.5.0/1:00:00,M10.5.0/2:00:00" |
Sydney, Australia | "AEST-10AEDT,M10.1.0/02:00:00,M4.1.0/03:00:00" |
Adelaide, Australia | "ACST-9:30ACDT,M10.1.0/02:00:00,M4.1.0/03:00:00" |
UTC | "UTC" |
Getting the current local time
Use the LocalTimeConvert
class like this to get the current time:
LocalTimeConvert conv;
conv.withCurrentTime().convert();
This will initialize the conv
object with information about the current local time in the timezone you have configured.
Additional useful LocalTimeConvert methods:
bool isDST() const
---
###### bool LocalTimeConvert::isStandardTime() const
Returns true of the current time in in standard time.
bool isStandardTime() const
---
###### String LocalTimeConvert::timeStr()
Works like Time.timeStr() to generate a readable string of the local time.
String timeStr()
Uses asctime formatting, which looks like "Fri Jan 1 18:45:56 2021". The strings are not localized; they're always in English.
---
###### String LocalTimeConvert::format(const char formatSpec)
Works like Time.format()
`
String format(const char formatSpec)
####### Parameters
* `formatSpec` the format specifies, which can be
* TIME_FORMAT_DEFAULT (example: "Thu Apr 1 12:00:00 2021")
* TIME_FORMAT_ISO8601_FULL (example: "2021-04-01T12:00:00-04:00")
* custom format based on strftime()
There are many options to strftime described here: [https://www.cplusplus.com/reference/ctime/strftime/?kw=strftime](https://www.cplusplus.com/reference/ctime/strftime/?kw=strftime)
Unlike Time.format(), you can use Z to output the timezone abbreviation, for example "EDT" for the Eastern United States, daylight saving instead of -04:00.
The z formatting matches that of Time.format(), which is wrong. The correct output should be "-400" but the output will be "-04:00" for compatibility.
If you want to make a US-style AM/PM clock display, the formatting string "%I:%M %p" will produce something like "12:30 PM".
---
###### String LocalTimeConvert::zoneName() const
Returns the abbreviated time zone name for the current time.
String zoneName() const
For example, for the United States east coast, EST or EDT depending on whether the current time is DST or not. See also isDST().
This string comes from the LocalTimePosixTimezone object.
##### Converting UTC to local time
Use the `LocalTimeConvert` class like this to get the current time:
cpp
time_t timeVal = 1612393852; // Wednesday, February 3, 2021 11:10:52 PM
LocalTimeConvert conv;
conv.withTime(timeVal).convert();
`
Advanced scheduling
An advanced scheduling mode was added in version 0.0.8. This allows complex schedules such as:
- Every 15 minutes in the hour, between 9:00 AM and 5:00 PM local time, Monday - Friday, except on 2022-03-21
- Every 4 hours of the day starting at 00:00:00 (midnight) other times
This can either be specified in code, or it can be expressed in JSON. JSON allows the schedule to be updating using a Particle.function, for example.
This is a compact representation of that schedule in 77 bytes of JSON data:
[{"mh":15,"y":62,"s":"09:00:00","e":"16:59:59","x":["2022-03-21"]},{"hd":4}]
While scheduling is designed to work with local time, each schedule calculator can optionally have a time zone override, which makes it possible to do some calculations at UTC if you prefer to do that.
Using a schedule
This is the code in examples/2-schedule:
#include "LocalTimeRK.h"
SerialLogHandler logHandler;
SYSTEM_THREAD(ENABLED);
LocalTimeSchedule publishSchedule;
void setup() {
// Set timezone to the Eastern United States
LocalTime::instance().withConfig(LocalTimePosixTimezone("EST5EDT,M3.2.0/2:00:00,M11.1.0/2:00:00"));
// Publish every 5 minutes at :00, :05, :10, ...
publishSchedule.withMinuteOfHour(5);
}
void loop() {
if (publishSchedule.isScheduledTime() && Particle.connected()) {
Particle.publish("testEvent", "scheduled publish!");
}
}
This is a simple example that publishes at :00, :05, :10, .... Note that these are clock times, not rolling times.
Technically you don't need a timezone for this example since it doesn't do any hour-based calculations, but it's set using withConfig()
when you need to use one.
The part in loop() tests to see if it's time to publish and then publishes. As shown in the example, if you are not connected to the cloud at the scheduled time, that scheduled time is skipped.
If you reverse the order in the if statement, then if you are not connected to the cloud, it's possible to get publish immediately after reconnecting to the cloud to make up for the one that was missed.
// Allow one out-of-schedule publish to catch up for a missed publish in this order
if (Particle.connected() && publishSchedule.isScheduledTime())
The real benefit is when you start to make more complex schedules, such as:
// Every 15 minutes between 9:00 AM and 5:00 PM local time Monday - Friday
publishSchedule.withMinuteOfHour(15, LocalTimeRange(LocalTimeHMS("09:00:00"), LocalTimeHMS("16:59:59"), LocalTimeRestrictedDate(LocalTimeDayOfWeek::MASK_WEEKDAY)));
// Every hour otherwise
publishSchedule.withMinuteOfHour(60);
You can exclude dates from a schedule. For example, the every 15 minutes on weekdays schedule excludes Monday, April 11, 2022 with this schedule:
publishSchedule.withMinuteOfHour(15, LocalTimeRange(LocalTimeHMS("09:00:00"), LocalTimeHMS("16:59:59"),
LocalTimeRestrictedDate(LocalTimeDayOfWeek::MASK_WEEKDAY, {}, {"2022-04-11"})));
publishSchedule.withMinuteOfHour(60);
LocalTimeSchedule items
LocalTimeSchedule include things like every n minutes, every n hours, as well as day of week and day of month multiples. Each multiple has a type, an increment, in some cases additional data, and a LocalTimeRange
that determines when the multiple is used.
LocalTimeRange
is itself composed of a TimeRange
, and a LocalTimeRestrictedDate
. This specifies both the time of day, as well as an optional restriction on the dates it applies. See above for for an explanation of these types.
Minute of hour
This schedule item is used for "every n minutes." For example, if you want to publish an event every 15 minutes.
// PROTOTYPE (class LocalTimeSchedule)
LocalTimeSchedule &withMinuteOfHour(int increment, LocalTimeRange timeRange = LocalTimeRange());
- Minute multiples are relative to the hour, so you typically want to use an increment that 60 is evenly divisible by in order to keep the period constant (2, 3, 4, 5, 6, 10, 12, 15, 20, 30).
- The
LocalTimeRange
can restrict this to certain hours of the day, and certain days of the week. It can also handle exception dates, both only on date, or to exclude dates. - The minute of the start of the time range specifies the offset relative to the hour to start the increment from (modulo the increment).
- The second of the start of the time range specifies the second offset.
For example, every 15 minutes all day, at 05:00, 20:00, 35:00, 50:00:
schedule.withMinuteOfHour(15, LocalTimeRange(LocalTimeHMS("00:05:00")));
Every 5 minutes from 9:00 AM to 5:00 PM local time every day:
schedule.withMinuteOfHour(5, LocalTimeRange(LocalTimeHMS("09:00:00"), LocalTimeHMS("16:59:59")))
Every 5 minutes from 9:00 AM to 5:00 PM local time on weekdays (not Saturday or Sunday):
schedule.withMinuteOfHour(5, LocalTimeRange(LocalTimeHMS("09:00:00"), LocalTimeHMS("16:59:59"), LocalTimeRestrictedDate(LocalTimeDayOfWeek::MASK_WEEKDAY)));
In generating from JSON:
Key | Type | Description | Default |
---|---|---|---|
"mh" | integer | Minute of hour multiple | |
"f" | integer | Flag bits (optional) | 0 |
"s" | string | The start time (HH:MM:SS format, can omit MM or SS) | "00:00:00" |
"e" | string | The end time (HH:MM:SS format, can omit MM or SS) | "23:59:59" |
"y" | integer | Mask value for days of the week (optional) | |
"a" | Array of string | Array of strings of the form YYYY-MM-DD to allow specific dates (optional) | |
"x" | Array of string | Array of strings of the form YYYY-MM-DD to exclude specific dates (optional) |
Hour of day multiples
This schedule is used for "every n hours." For example, if you want to wake and publish every 4 hours.
// PROTOTYPE (class LocalTimeSchedule)
LocalTimeSchedule &withHourOfDay(int hourMultiple, LocalTimeRange timeRange = LocalTimeRange());
- Hour multiples are relative to the day, so you typically want to use a value that 24 is evenly divisible by (2, 3, 4, 6, 8, 12).
- The
LocalTimeRange
can restrict this to certain hours of the day, and certain days of the week. It can also handle exception dates, both only on date, or to exclude dates. - The hour of the start of the time range specifies the offset relative to the day to start the increment from (modulo the increment)
- The minute and second of the start of the time range specifies the minute and second offset
For example, every 2 hours (00:00, 02:00, 04:00) local time.
schedule.withHourOfDay(2);
Every 2 hours, but starting at 01:30 local time (01:30, 03:30, 05:30, ...).
schedule.withHourOfDay(2, LocalTimeRange(LocalTimeHMS("01:30:00"), LocalTimeHMS("23:59:59")));
Every 15 minutes between 9:00 AM and 5:00 PM local time, otherwise every 2 hours (00:00, 02:00, 04:00 local time)
schedule.withMinuteOfHour(15, LocalTimeRange(LocalTimeHMS("09:00:00"), LocalTimeHMS("16:59:59")));
schedule.withHourOfDay(2);
If configuring by JSON:
Key | Type | Description | Default |
---|---|---|---|
"hd" | integer | Hour of day multiple | |
"f" | integer | Flag bits (optional) | 0 |
"s" | string | The start time (HH:MM:SS format, can omit MM or SS) | "00:00:00" |
"e" | string | The end time (HH:MM:SS format, can omit MM or SS) | "23:59:59" |
"y" | integer | Mask value for days of the week (optional) | |
"a" | Array of string | Array of strings of the form YYYY-MM-DD to allow specific dates (optional) | |
"x" | Array of string | Array of strings of the form YYYY-MM-DD to exclude specific dates (optional) |
Day of week of the month
This is used for things like: "Every first Monday of the month," "Every second Tuesday of the month," or "Last Friday of the month."
// PROTOTYPE (class LocalTimeSchedule)
LocalTimeSchedule &withDayOfWeekOfMonth(int dayOfWeek, int instance, LocalTimeRange timeRange = LocalTimeRange());
- The dayOfWeek specifies the day of the week (Sunday = 0, Monday = 1, Tuesday = 2, ..., Saturday = 6).
- The instance specifies which instance (1 = first, 2 = second, ... Or -1 = last, -2 = second to last, ...)
- The
LocalTimeRange
can restrict this to certain hours of the day, and certain days of the week. It can also handle exception dates, both only on date, or to exclude dates. - The start of the time range specifies the hour, minute, and second (local time)
- Use a time of day with day of week restriction instead if you want to do "Every Monday"
First Saturday of the month at midnight local time:
schedule.withDayOfWeekOfMonth(LocalTimeDayOfWeek::DAY_SATURDAY, 1);
First Monday of the month at 9:00 AM local time:
schedule.withDayOfWeekOfMonth(LocalTimeDayOfWeek::DAY_MONDAY, 1, LocalTimeHMS("09:00:00"));
Last Friday of the month at 5 PM local time.
schedule.withDayOfWeekOfMonth(LocalTimeDayOfWeek::DAY_FRIDAY, -1, LocalTimeHMS("17:00:00"));
Key | Type | Description | Default |
---|---|---|---|
"dw" | integer | Day of week instance (1 = first, 2 = second, ..., or -1 = last, -2 = second to last, ... | |
"d" | integer | Day of the week 0 = Sunday, 1 = Monday, ..., 6 = Saturday | |
"f" | integer | Flag bits (optional) | 0 |
"s" | string | The start time (HH:MM:SS format, can omit MM or SS) | "00:00:00" |
"e" | string | The end time (HH:MM:SS format, can omit MM or SS) | "23:59:59" |
"y" | integer | Mask value for days of the week (optional) | |
"a" | Array of string | Array of strings of the form YYYY-MM-DD to allow specific dates (optional) | |
"x" | Array of string | Array of strings of the form YYYY-MM-DD to exclude specific dates (optional) |
Day of month
This is used for things like "The 1st of the month," "The 15th of the month," or "the last day of the month."
// PROTOTYPE (class LocalTimeSchedule)
LocalTimeSchedule &withDayOfMonth(int dayOfMonth, LocalTimeRange timeRange = LocalTimeRange());
- The dayOfMonth specifies which instance (1 = 1st of the month, 2 = 2nd of the month, ... Or -1 = last day, -2 = second to last day, ...)
- A
LocalTimeRange
can handle exception dates, both only on date, or to exclude dates. - The start of the time range specifies the hour, minute, and second (local time)
For example, the 6th of the month at midnight:
schedule.withDayOfMonth(6);
The 6th of the month at 6:00 AM local time:
schedule.withDayOfMonth(6, LocalTimeHMS("06:00"));
The last day of the month at 11:59:59 PM:
schedule.withDayOfMonth(-1, LocalTimeHMS("23:59:59"));
The second to last day of the month:
schedule.withDayOfMonth(-2);
Key | Type | Description | Default |
---|---|---|---|
"dw" | integer | Day of month instance (1 = 1st, 2 = 2nd, ... or -1 = last day of month, -2 = second to last, ... | |
"f" | integer | Flag bits (optional) | 0 |
"s" | string | The start time (HH:MM:SS format, can omit MM or SS) | "00:00:00" |
"e" | string | The end time (HH:MM:SS format, can omit MM or SS) | "23:59:59" |
"y" | integer | Mask value for days of the week (optional) | |
"a" | Array of string | Array of strings of the form YYYY-MM-DD to allow specific dates (optional) | |
"x" | Array of string | Array of strings of the form YYYY-MM-DD to exclude specific dates (optional) |
Time schedule
It's also possible to schedule at a specific time in local time. You can specify zero or more LocalTimeHMSRestricted
objects, limited by available RAM.
The LocalTimeHMSRestricted
is itself composed of a LocalTimeHMS
object, for hours minutes and seconds, and a LocalTimeRestrictedDate
which can optionally restrict which dates the times re used.
Some ways you can use times:
- "At 17:00:00" every day (local time)
- "At 17:00:00, Monday - Friday"
- "At 09:00:00, Monday - Friday, except for 2022-03-21"
- "At 23:59:59 on 2022-03-31"
// PROTOTYPE (class LocalTimeSchedule)
LocalTimeSchedule &withTime(LocalTimeHMSRestricted hms);
LocalTimeSchedule &withTimes(std::initializer_list<LocalTimeHMSRestricted> timesParam);
At 4:00 AM local time, every day:
schedule.withTime(LocalTimeHMS("04:00"));
At 06:00 and 18:30 (4:30 PM) local time, every day. Note the {} surrounding a list of times.
schedule.withTimes({LocalTimeHMS("06:00"), LocalTimeHMS("18:30")});
At 4:00 AM on weekdays:
schedule.withTime(LocalTimeHMSRestricted("04:00", LocalTimeRestrictedDate(LocalTimeDayOfWeek::MASK_WEEKDAY)));
At midnight (local time) on Saturdays:
schedule.withTime(LocalTimeHMSRestricted("00:00", LocalTimeRestrictedDate(LocalTimeDayOfWeek::MASK_SATURDAY)));
If configuring by JSON:
Key | Type | Description | Default |
---|---|---|---|
"tm" | string | Time in "HH:MM:SS" format, 24 hour clock, local time | |
"f" | integer | Flag bits (optional) | 0 |
"y" | number | Mask value for days of the week (optional) | |
"a" | Array of string | Array of strings of the form YYYY-MM-DD to allow specific dates (optional) | |
"x" | Array of string | Array of strings of the form YYYY-MM-DD to exclude specific dates (optional) |
All methods
LocalTimeSchedule & withMinuteOfHour(int increment, LocalTimeRange timeRange)
####### Parameters
increment
Number of minutes (must be 1 <= minutes <= 59). A value that is is divisible by is recommended.
timeRange
When to apply this minute multiple and/or minute offset (optional)
This schedule publishes every n minutes within the hour. This really is every hour, not rolling, so you should use a value that 60 is divisible by (2, 3, 4, 5, 6, 10, 12, 15, 20, 30) otherwise there will be an inconsistent period at the top of the hour.
If you specify a time range that does not start at 00:00:00 you can customize which minute the schedule starts at. For example: 15, LocalTimeRange(LocalTimeHMS("00:05:00"), LocalTimeHMS("23:59:59")
will schedule every 15 minutes, but starting at 5 minutes past the hour, so 05:00, 20:00, 35:00, 50:00.
The largest value for hmsEnd of the time range is 23:59:59.
####### Returns
LocalTimeSchedule&
---
###### LocalTimeSchedule & LocalTimeSchedule::withHourOfDay(int hourMultiple, LocalTimeRange timeRange)
Adds multiple times periodically in a time range with an hour increment.
LocalTimeSchedule & withHourOfDay(int hourMultiple, LocalTimeRange timeRange)
####### Parameters
hourMultiple
Hours between items must be >= 1. For example: 2 = every other hour.
timeRange
Time range to add items to. This is optional; if not specified then the entire day. Also is used to specify a minute offset.
####### Returns
LocalTimeSchedule&
Hours are per day, local time. For whole-day schedules, you will typically use a value that 24 is evenly divisible by (2, 3, 4, 6, 8, 12), because otherwise the time periods will brief unequal at midnight.
Also note that times are local, and take into account daylight saving. Thus during a time switch, the interval may end up being a different number of hours than specified. For example, if the times would have been 00:00 and 04:00, a hourMultiple of 4, and you do this over a spring forward, the actual number hours between 00:00 and 04:00 is 5 (at least in the US where DST starts at 2:00).
---
###### LocalTimeSchedule & LocalTimeSchedule::withDayOfWeekOfMonth(int dayOfWeek, int instance, LocalTimeRange timeRange)
Schedule an item on a specific instance of a day of week of the month.
LocalTimeSchedule & withDayOfWeekOfMonth(int dayOfWeek, int instance, LocalTimeRange timeRange)
####### Parameters
dayOfWeek
Day of week 0 = Sunday, 1 = Monday, ..., 6 = Saturday
instance
1 = first week, 2 = second week, ..., -1 = last week, -2 = 2nd to last week
timeRange
Optional to restrict dates or to set a time for the item
####### Returns
LocalTimeSchedule&
---
###### LocalTimeSchedule & LocalTimeSchedule::withDayOfMonth(int dayOfMonth, LocalTimeRange timeRange)
Schedule an item on a specific day of the month.
LocalTimeSchedule & withDayOfMonth(int dayOfMonth, LocalTimeRange timeRange)
####### Parameters
dayOfMonth
1 = 1st, 2 = 2nd of the month, ..., -1 = last day of the month, -2 = second to last day of the month, ...
timeRange
Optional to restrict dates or to set a time for the item
####### Returns
LocalTimeSchedule&
---
###### LocalTimeSchedule & LocalTimeSchedule::withTime(LocalTimeHMSRestricted hms)
Add a scheduled item at a time in local time during the day.
LocalTimeSchedule & withTime(LocalTimeHMSRestricted hms)
####### Parameters
hms
The time in local time 00:00:00 to 23:59:59, optionally with date restrictions
####### Returns
LocalTimeSchedule&
You can call this multiple times, and also combine it with minute multiple schedules.
---
###### LocalTimeSchedule & LocalTimeSchedule::withTimes(std::initializer_list< LocalTimeHMSRestricted > timesParam)
Add multiple scheduled items at a time in local time during the day.
LocalTimeSchedule & withTimes(std::initializer_list< LocalTimeHMSRestricted > timesParam)
####### Parameters
timesParam
an auto-initialized list of LocalTimeHMS objects
####### Returns
LocalTimeSchedule&
You can call this multiple times, and also combine it with minute multiple schedules.
schedule.withTimes({LocalTimeHMS("06:00"), LocalTimeHMS("18:30")});
---
###### LocalTimeSchedule & LocalTimeSchedule::withName(const char name)
Sets the name of this schedule (optional)
LocalTimeSchedule & withName(const char * name)
####### Parameters
name
####### Returns
LocalTimeSchedule&
---
###### LocalTimeSchedule & LocalTimeSchedule::withFlags(uint32_t flags)
Sets the flags for this schedule (optional)
LocalTimeSchedule & withFlags(uint32_t flags)
####### Parameters
flags
####### Returns
LocalTimeSchedule&
---
###### bool LocalTimeSchedule::isEmpty() const
Returns true if the schedule does not have any items in it.
bool isEmpty() const
####### Returns
true
####### Returns
false
---
###### void LocalTimeSchedule::clear()
Clear the existing settings.
void clear()
---
###### void LocalTimeSchedule::fromJson(const char jsonStr)
Set the schedule from a JSON string containing an array of objects.
`
void fromJson(const char jsonStr)
####### Parameters
* `jsonStr`
See the overload that takes a JSONValue if the JSON string has already been parsed.
---
###### void LocalTimeSchedule::fromJson(JSONValue jsonArray)
Set the schedule of this object from a JSONValue, typically the outer object.
void fromJson(JSONValue jsonArray)
####### Parameters
* `jsonArray` A JSONValue containing an array of objects
Array of LocalTimeScheduleItem objects:
* mh (integer): Minute of hour (takes place of setting m and i separately)
* hd (integer): Hour of day (takes place of setting m and i separately)
* dw (integer): Day of week (takes place of setting m and i separately)
* dm (integer): Day of month (takes place of setting m and i separately)
* tm (string) Time string in HH:MM:SS format (can omit MM and SS parts, see LocalTimeHMS) for TIME items
* m (integer) type of multiple (optional if mm, )
* i (integer) increment
* f (integer) flag bits (optional)
* s (string) The start time (HH:MM:SS format, can omit MM or SS) [from LocalTimeRange via LocalTimeRange]
* e (string) The end time (HH:MM:SS format, can omit MM or SS) [from LocalTimeRange via LocalTimeRange]
* y (integer) mask value for onlyOnDays [from LocalTimeRestrictedDate via LocalTimeRange]
* a (array) Array of YYYY-MM-DD value strings to allow [from LocalTimeRestrictedDate via LocalTimeRange]
* x (array) Array of YYYY-MM-DD values to exclude [from LocalTimeRestrictedDate via LocalTimeRange]
---
###### bool LocalTimeSchedule::getNextScheduledTime(LocalTimeConvert & conv) const
Update the conv object to point at the next schedule item.
bool getNextScheduledTime(LocalTimeConvert & conv) const
####### Parameters
* `conv` LocalTimeConvert object, may be modified
####### Returns
true if there is an item available or false if not. if false, conv will be unchanged.
This method finds closest scheduled time for this objecvt, if it's in the near future. The LocalTime::instance().getScheduleLookaheadDays() setting determines how far in the future to check; the default is 3 days. The way schedules work each day needs to be checked to make sure all of the constraints are met, so long look-aheads are computationally intensive. This is not normally an issue, because the idea is that you'll wake from sleep or check the schedule at least every few days, at which point the new schedule may be available.
---
###### bool LocalTimeSchedule::getNextScheduledTime(LocalTimeConvert & conv, std::function< bool(LocalTimeScheduleItem &item)> filter) const
Update the conv object to point at the next schedule item.
bool getNextScheduledTime(LocalTimeConvert & conv, std::function< bool(LocalTimeScheduleItem &item)> filter) const
`
####### Parameters
conv
LocalTimeConvert object, may be modified
filter
A function to determine, for each schedule item, if it should be tested
####### Returns
true if there is an item available or false if not. if false, conv will be unchanged.
This method finds closest scheduled time for this objecvt, if it's in the near future. The LocalTime::instance().getScheduleLookaheadDays() setting determines how far in the future to check; the default is 3 days. The way schedules work each day needs to be checked to make sure all of the constraints are met, so long look-aheads are computationally intensive. This is not normally an issue, because the idea is that you'll wake from sleep or check the schedule at least every few days, at which point the new schedule may be available.
The filter function or lambda has this prototype:
bool filterCallback(LocalTimeScheduleItem &item)
If should return true to check this item, or false to skip this item for schedule checking.
LocalTimeHMS
This object holds a hour, minute, and second value (HMS). There are numerous methods to compare time values, and convert the values to other formats.
When converting from string format always use 24-hour clock format; this object does not support AM/PM. Also when converting from strings you can omit the seconds, or even both the minutes and seconds.
Note that hour 24 is never a valid value. Because HMS calculations are always inclusive, the end of the day is 23:59:59. Leap seconds are not supported by the underlying C standard time library.
LocalTimeHMS()
---
###### LocalTimeHMS::~LocalTimeHMS()
Destructor.
virtual ~LocalTimeHMS()
---
###### LocalTimeHMS::LocalTimeHMS(const char str)
Constructs the object from a time string.
`
LocalTimeHMS(const char str)
####### Parameters
* `str` The time string
The time string is normally of the form HH:MM:SS, such as "04:00:00" for 4:00 AM. The hour is in 24-hour format. Other formats are supported as well, including omitting the seconds (04:00), or including only the hour "04", or omitting the leadings zeros (4:0:0).
Additionally, the hour could be negative, used in UTC DST offsets. The minute and second are always positive (0-59). The hour could also be > 24 when used as a timezone offset.
---
###### LocalTimeHMS::LocalTimeHMS(const LocalTimeValue & value)
Construct this HMS from a LocalTimeValue (which contains YMD and HMS)
LocalTimeHMS(const LocalTimeValue & value)
####### Parameters
* `value`
---
###### void LocalTimeHMS::clear()
Sets the hour, minute, and second to 0.
void clear()
---
###### void LocalTimeHMS::parse(const char * str)
Parse a "H:MM:SS" string.
void parse(const char str)
`
####### Parameters
str
Input string
Multiple formats are supported, and parts are optional:
H:MM:SS (examples: "2:00:00" or "2:0:0")
H:MM (examples: "2:00" or "2:0")
H (examples: "2")
Hours are always 0 - 23 (24-hour clock). Can also be a negative hour -1 to -23.
---
###### String LocalTimeHMS::toString() const
Turns the parsed data into a normalized string of the form: "HH:MM:SS" (24-hour clock, with leading zeroes)
String toString() const
---
###### int LocalTimeHMS::toSeconds() const
Convert hour minute second into a number of seconds (simple multiplication and addition)
int toSeconds() const
---
###### void LocalTimeHMS::fromTimeInfo(const struct tm pTimeInfo)
Sets the hour, minute, and second fields from a struct tm.
void fromTimeInfo(const struct tm * pTimeInfo)
---
###### void LocalTimeHMS::fromLocalTimeValue(const LocalTimeValue & value)
Sets the HMS from a LocalTimeValue.
void fromLocalTimeValue(const LocalTimeValue & value)
####### Parameters
value
---
###### void LocalTimeHMS::toTimeInfo(struct tm pTimeInfo) const
Fill in the tm_hour, tm_min, and tm_sec fields of a struct tm from the values in this object.
void toTimeInfo(struct tm * pTimeInfo) const
####### Parameters
pTimeInfo
The struct tm to modify
---
###### void LocalTimeHMS::adjustTimeInfo(struct tm pTimeInfo) const
Adjust the values in a struct tm from the values in this object.
void adjustTimeInfo(struct tm * pTimeInfo) const
####### Parameters
pTimeInfo
The struct tm to modify
After calling this, the values in the struct tm may be out of range, for example tm_hour > 23. This is fine, as calling mktime/gmtime normalizes this case and carries out-of-range values into the other fields as necessary.
---
###### void LocalTimeHMS::fromJson(JSONValue jsonObj)
Parses a JSON value of type string in HH:MM:SS format.
void fromJson(JSONValue jsonObj)
####### Parameters
jsonObj
---
###### LocalTimeHMS & LocalTimeHMS::withHour(int hour)
Sets this object to be the specified hour, with minute and second set to 0.
LocalTimeHMS & withHour(int hour)
####### Parameters
hour
0 <= hour < 24
####### Returns
LocalTimeHMS&
---
###### LocalTimeHMS & LocalTimeHMS::withHourMinute(int hour, int minute)
Sets this object to be the specified hour and minute, with second set to 0.
LocalTimeHMS & withHourMinute(int hour, int minute)
####### Parameters
hour
0 <= hour < 24
minute
0 <= minute < 60
####### Returns
LocalTimeHMS&
---
###### int LocalTimeHMS::compareTo(const LocalTimeHMS & other) const
Compare two LocalTimeHMS objects.
int compareTo(const LocalTimeHMS & other) const
####### Parameters
other
The item to compare to
####### Returns
int -1 if this item is < other; 0 if this = other, or +1 if this > other
---
###### bool LocalTimeHMS::operator==(const LocalTimeHMS & other) const
Returns true if this item is equal to other. Compares hour, minute, and second.
bool operator==(const LocalTimeHMS & other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeHMS::operator!=(const LocalTimeHMS & other) const
Returns true if this item is not equal to other.
bool operator!=(const LocalTimeHMS & other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeHMS::operator<(const LocalTimeHMS & other) const
Returns true if this item is < other.
bool operator<(const LocalTimeHMS & other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeHMS::operator>(const LocalTimeHMS & other) const
Returns true if this item is > other.
bool operator>(const LocalTimeHMS & other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeHMS::operator<=(const LocalTimeHMS & other) const
Returns true if this item <= other.
bool operator<=(const LocalTimeHMS & other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeHMS::operator>=(const LocalTimeHMS & other) const
Returns true if this item is >= other.
bool operator>=(const LocalTimeHMS & other) const
####### Parameters
other
####### Returns
true
####### Returns
false
LocalTimeYMD
This object specifies a year, month, and day. There are numerous methods to compare time values, and convert the values to other formats.
When converting from a string this must always be "YYYY-MM-DD" format, with dashes, and in that order. Other date formats including common but poorly defined United States date formats cannot be used!
LocalTimeYMD()
---
###### LocalTimeYMD::LocalTimeYMD(const char s)
Construct a YMD value from a string.
`
LocalTimeYMD(const char s)
####### Parameters
* `s` String, must be in YYYY-MM-DD format. No other formars are allowed!
---
###### LocalTimeYMD::LocalTimeYMD(const LocalTimeValue & value)
Construct from a LocalTimeValue object.
LocalTimeYMD(const LocalTimeValue & value)
####### Parameters
* `value` The date to copy from
---
###### bool LocalTimeYMD::isEmpty() const
Returns true if the date is uninitialized, as from the default constructor.
bool isEmpty() const
####### Returns
true
####### Returns
false
---
###### int LocalTimeYMD::getYear() const
Get the year as a 4-digit year, for example: 2022.
int getYear() const
####### Returns
int The year, 4-digit
---
###### void LocalTimeYMD::setYear(int year)
Set the year value.
void setYear(int year)
####### Parameters
* `year` Year to set, can be several different values but typically is 4-digit year (2022, for example)
---
###### int LocalTimeYMD::getMonth() const
Get the month, 1 - 12 inclusive.
int getMonth() const
####### Returns
int month
---
###### void LocalTimeYMD::setMonth(int month)
Set the month, 1 - 12 inclusive.
void setMonth(int month)
####### Parameters
* `month` Month value
---
###### int LocalTimeYMD::getDay() const
Get the day of month, starting a 1.
int getDay() const
####### Returns
int
---
###### void LocalTimeYMD::setDay(int day)
Set the day of the month, staring at 1.
void setDay(int day)
####### Parameters
* `day`
This method does not validate the date value, but you should avoid setting invalid date values since the results can be unpredictable.
---
###### void LocalTimeYMD::fromTimeInfo(const struct tm * pTimeInfo)
Copies the year, month, and day from a struct tm.
void fromTimeInfo(const struct tm pTimeInfo)
`
####### Parameters
pTimeInfo
The pointer to a struct tm to copy the year, month, and day from.
The tm should be in local time.
---
###### void LocalTimeYMD::fromLocalTimeValue(const LocalTimeValue & value)
The LocalTimeValue to copy the year, month and day from.
void fromLocalTimeValue(const LocalTimeValue & value)
####### Parameters
value
Source of the year, month, and day values
Since LocalTimeValue contains a struct tm, this uses fromTimeInfo internally.
---
###### void LocalTimeYMD::addDay(int numberOfDays)
Add a number of days to the current YMD (updating month or year as necessary)
void addDay(int numberOfDays)
####### Parameters
numberOfDays
Number of days to add (positive) or subtract (negative)
Works correctly with leap years.
---
###### int LocalTimeYMD::getDayOfWeek() const
Get the day of the week, 0 = Sunday, 1 = Monday, 2 = Tuesday, ..., 6 = Saturday.
int getDayOfWeek() const
####### Returns
int the day of the week
---
###### int LocalTimeYMD::compareTo(const LocalTimeYMD other) const
Compare to another LocalTimeYMD object.
int compareTo(const LocalTimeYMD other) const
####### Parameters
other
####### Returns
int -1 if this is < other, 0 if this == other, or 1 if this > other.
---
###### bool LocalTimeYMD::operator==(const LocalTimeYMD other) const
Tests if this LocalTimeYMD is equal to other.
bool operator==(const LocalTimeYMD other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeYMD::operator!=(const LocalTimeYMD other) const
Tests if this LocalTimeYMD is not equal to other.
bool operator!=(const LocalTimeYMD other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeYMD::operator<(const LocalTimeYMD other) const
Tests if this LocalTimeYMD is less than other.
bool operator<(const LocalTimeYMD other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeYMD::operator<=(const LocalTimeYMD other) const
Tests if this LocalTimeYMD is less than or equal to other.
bool operator<=(const LocalTimeYMD other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeYMD::operator>(const LocalTimeYMD other) const
Tests if this LocalTimeYMD is greater than other.
bool operator>(const LocalTimeYMD other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeYMD::operator>=(const LocalTimeYMD other) const
Tests if this LocalTimeYMD is greater than or equal to other.
bool operator>=(const LocalTimeYMD other) const
####### Parameters
other
####### Returns
true
####### Returns
false
---
###### bool LocalTimeYMD::parse(const char s)
Parse a YMD string in the format "YYYY-MD-DD". Only this format is supported!
bool parse(const char * s)
####### Parameters
* s
####### Returns
true
####### Returns
false
Do not use this function with other date formats like "mm/dd/yyyy"!
---
###### String LocalTimeYMD::toString() const
Converts the value to YYYY-MM-DD format as a String with leading zeros.
String toString() const
####### Returns
String
### struct LocalTimeYMD::YMD
Packed structure to hold the YMD value.
LocalTimeRange
A LocalTimeRange
is a start time and end time in local time, expressed as LocalTimeHMS
objects (hours, minutes, seconds).
Time ranges are inclusive, so the entire day is 00:00:00 to 23:59:59.
The default constructor for LocalTimeRange
sets the time range to the entire day.
When converting from JSON:
Key | Type | Description | Default |
---|---|---|---|
"s" | string | Starting time in "HH:MM:SS" format, 24 hour clock, local time | "00:00:00" |
"e" | string | Ending time in "HH:MM:SS" format, 24 hour clock, local time | "23:59:59" |
LocalTimeRange()
This is start = 00:00:00, end = 23:59:59. The system clock does not have a concept of leap seconds.
---
###### LocalTimeRange::LocalTimeRange(LocalTimeHMS hmsStart, LocalTimeHMS hmsEnd)
Construct a new Time Range object with the specifies start and end times.
LocalTimeRange(LocalTimeHMS hmsStart, LocalTimeHMS hmsEnd)
####### Parameters
hmsStart
Start time in local time 00:00:00 <= hmsStart <= 23:59:59
hmsEnd
End time in local time 00:00:00 <= hmsStart <= 23:59:59 (optional)
Note that 24:00:00 is not a valid time. You should generally use inclusive times such that 23:59:59 is the end of the day.
---
###### LocalTimeRange::LocalTimeRange(LocalTimeHMS hmsStart, LocalTimeHMS hmsEnd, LocalTimeRestrictedDate dateRestriction)
Construct a new object that specifies start time, end time, and date restrictions.
LocalTimeRange(LocalTimeHMS hmsStart, LocalTimeHMS hmsEnd, LocalTimeRestrictedDate dateRestriction)
####### Parameters
hmsStart
Start time in local time 00:00:00 <= hmsStart <= 23:59:59
hmsEnd
End time in local time 00:00:00 <= hmsStart <= 23:59:59
dateRestriction
Only use this time range on certain dates
---
###### void LocalTimeRange::clear()
Clear time range to all day, every day.
void clear()
---
###### time_t LocalTimeRange::getTimeSpan(const LocalTimeConvert & conv) const
Get the number of seconds between start and end based on a LocalTimeConvert object.
time_t getTimeSpan(const LocalTimeConvert & conv) const
The reason for the conv object is that it contains the time to calculate at, as well as the daylight saving time settings. This methods takes into account the actual number of seconds including when a time change is crossed.
####### Parameters
conv
The time and timezone settings to calculate the time span at
####### Returns
time_t Time difference in seconds
In the weird case that start > end, it can return a negative value, as time_t is a signed long (or long long) value.
This does not take into account date restrictions!
---
###### int LocalTimeRange::compareTo(LocalTimeHMS hms) const
Compares a time (LocalTimeHHS, local time) to this time range.
int compareTo(LocalTimeHMS hms) const
####### Parameters
hms
####### Returns
int -1 if hms is before hmsStart, 0 if in range, +1 if hms is after hmsEnd
---
###### bool LocalTimeRange::isValidDate(LocalTimeYMD ymd) const
Returns true if the date restrictions allow this day.
bool isValidDate(LocalTimeYMD ymd) const
####### Parameters
ymd
####### Returns
true
####### Returns
false
---
###### bool LocalTimeRange::inRange(LocalTimeValue localTimeValue) const
Returns true if the date restrictions allow this date and the time is in this range (inclusive)
bool inRange(LocalTimeValue localTimeValue) const
####### Parameters
localTimeValue
####### Returns
true
####### Returns
false
---
###### void LocalTimeRange::fromTime(LocalTimeHMSRestricted hms)
Set the date restrictions from a LocalTimeHMSRestricted object.
void fromTime(LocalTimeHMSRestricted hms)
####### Parameters
hms
LocalTimeHMSRestricted, really only uses the date restrictions, not the HMS part
---
###### void LocalTimeRange::fromJson(JSONValue jsonObj)
Fills in the time range from a JSON object.
void fromJson(JSONValue jsonObj)
####### Parameters
jsonObj
Keys:
s (string) The start time (HH:MM:SS format, can omit MM or SS)
* e (string) The end time (HH:MM:SS format, can omit MM or SS)
####### LocalTimeDayOfWeek
A LocalTimeDayOfWeek
specifies zero or more days of the week (Sunday, Monday, ...)
Common mask values:
Value Hex | Value Decimal | Constant | Description |
---|---|---|---|
0x01 | 1 | MASK_SUNDAY | Sunday |
0x02 | 2 | MASK_MONDAY | Monday |
0x04 | 4 | MASK_TUESDAY | Tuesday |
0x08 | 8 | MASK_WEDNESDAY | Wednesday |
0x10 | 16 | MASK_THURSDAY | Thursday |
0x20 | 32 | MASK_FRIDAY | Friday |
0x40 | 64 | MASK_SATURDAY | Saturday |
0x7f | 127 | MASK_ALL | Every day |
0x3e | 62 | MASK_WEEKDAY | Weekdays (Monday - Friday) |
0x41 | 65 | MASK_WEEKEND | Weekends (Saturday - Sunday) |
Note that you can combine any mask bits. For example, Monday, Wednesday, Friday is 2 + 8 + 32 = 42,
In JSON, you can only use the numeric mask values, as a decimal number. For example, weekdays Monday - Friday is 62.
Key | Type | Description |
---|---|---|
"y" | number | Mask value for days of the week, see table above |
LocalTimeRestrictedDate
A LocalTimeRestrictedDate
is used for both multiples and times (below). It can have:
- A day of week selection (
LocalTimeDayOfWeek
), which is a bitmask of days to allow. This makes it easy to specify, for example, weekdays (Monday - Friday). - A list of dates to allow (vector of
LocalTimeYMD
) - A list of dates to exclude (vector of
LocalTimeYMD
)
Key | Type | Description | Default |
---|---|---|---|
"y" | number | Mask value for days of the week, see table above (optional) | |
"a" | Array of string | Array of strings of the form YYYY-MM-DD to allow specific dates (optional) | |
"x" | Array of string | Array of strings of the form YYYY-MM-DD to exclude specific dates (optional) |
LocalTimeRestrictedDate(uint8_t mask)
####### Parameters
mask
The days of the week to enable. Pass LocalTimeDayOfWeek::MASK_ALL to allow on every day (no restrictions)
---
###### LocalTimeRestrictedDate::LocalTimeRestrictedDate(uint8_t mask, std::initializer_list< const char > onlyOnDates, std::initializer_list< const char > exceptDates)
Construct an object with an initializer list of strings.
`
LocalTimeRestrictedDate(uint8_t mask, std::initializer_list< const char > onlyOnDates, std::initializer_list< const char > exceptDates)
`
####### Parameters
mask
mask value, see LocalTimeDayOfWeek for values
onlyOnDates
Initializer list of strings of the form YYYY-MM-DD
exceptDates
Initializer list of strings of the form YYYY-MM-DD
---
###### LocalTimeRestrictedDate::LocalTimeRestrictedDate(uint8_t mask, std::initializer_list< LocalTimeYMD > onlyOnDates, std::initializer_list< LocalTimeYMD > exceptDates)
Construct an object with an initializer list of LocalTimeYMD objects.
LocalTimeRestrictedDate(uint8_t mask, std::initializer_list< LocalTimeYMD > onlyOnDates, std::initializer_list< LocalTimeYMD > exceptDates)
####### Parameters
mask
mask value, see LocalTimeDayOfWeek for values
onlyOnDates
Initializer list of LocalTimeYMD values
exceptDates
Initializer list of LocalTimeYMD values
---
###### LocalTimeRestrictedDate & LocalTimeRestrictedDate::withOnAllDays()
Set the mask value to MASK_ALL. Does not change only on date or except on date lists.
LocalTimeRestrictedDate & withOnAllDays()
####### Returns
LocalTimeRestrictedDate&
---
###### LocalTimeRestrictedDate & LocalTimeRestrictedDate::withOnlyOnDays(LocalTimeDayOfWeek value)
Restrict to days of the week.
LocalTimeRestrictedDate & withOnlyOnDays(LocalTimeDayOfWeek value)
####### Parameters
value
A LocalTimeDayOfWeek object specifying the days of the week (mask bits for Sunday - Saturday)
####### Returns
LocalTimeRestrictedDate&
A day of the week is allowed if the day of week mask bit is set. If a date is in the except dates list, then isValid return false. If a date is in the only on days mask OR only on dates list, then isValid will return true.
---
###### LocalTimeRestrictedDate & LocalTimeRestrictedDate::withOnlyOnDays(uint8_t mask)
Restrict to certain dates.
LocalTimeRestrictedDate & withOnlyOnDays(uint8_t mask)
####### Parameters
mask
Mask value, such as LocalTimeDayOfWeek::MASK_MONDAY
####### Returns
LocalTimeRestrictedDate&
A day of the week is allowed if the day of week mask bit is set. If a date is in the except dates list, then isValid return false. If a date is in the only on days mask OR only on dates list, then isValid will return true.
---
###### LocalTimeRestrictedDate & LocalTimeRestrictedDate::withOnlyOnDates(std::initializer_list< const char > dates)
Restrict to certain dates.
LocalTimeRestrictedDate & withOnlyOnDates(std::initializer_list< const char * > dates)
####### Parameters
dates
A {} list of strings of the form YYYY-MM-DD. No other date formats are allowed!
####### Returns
LocalTimeRestrictedDate&
If a date is in the except dates list, then isValid return false. If a date is in the only on days mask OR only on dates list, then isValid will return true.
---
###### LocalTimeRestrictedDate & LocalTimeRestrictedDate::withOnlyOnDates(std::initializer_list< LocalTimeYMD > dates)
Restrict to certain dates.
LocalTimeRestrictedDate & withOnlyOnDates(std::initializer_list< LocalTimeYMD > dates)
####### Parameters
dates
A {} list of LocalTimeYMD objects
####### Returns
LocalTimeRestrictedDate&
If a date is in the except dates list, then isValid return false. If a date is in the only on days mask OR only on dates list, then isValid will return true.
---
###### LocalTimeRestrictedDate & LocalTimeRestrictedDate::withExceptDates(std::initializer_list< const char > dates)
Dates that will always return false for isValid.
`
LocalTimeRestrictedDate & withExceptDates(std::initializer_list< const char > dates)
####### Parameters
* `dates` A {} list of strings of the form YYYY-MM-DD. No other date formats are allowed!
####### Returns
LocalTimeRestrictedDate&
If a date is in the except dates list, then isValid return false. If a date is in the only on days mask OR only on dates list, then isValid will return true.
---
###### LocalTimeRestrictedDate & LocalTimeRestrictedDate::withExceptDates(std::initializer_list< LocalTimeYMD > dates)
Dates that will always return false for isValid.
LocalTimeRestrictedDate & withExceptDates(std::initializer_list< LocalTimeYMD > dates)
####### Parameters
* `dates` A {} list of LocalTimeYMD objects
####### Returns
LocalTimeRestrictedDate&
If a date is in the except dates list, then isValid return false. If a date is in the only on days mask OR only on dates list, then isValid will return true.
---
###### bool LocalTimeRestrictedDate::isEmpty() const
Returns true if onlyOnDays mask is 0 and the onlyOnDates and exceptDates lists are empty.
bool isEmpty() const
####### Returns
true
####### Returns
false
---
###### void LocalTimeRestrictedDate::clear()
Clear all settings.
void clear()
---
###### bool LocalTimeRestrictedDate::isValid(LocalTimeValue localTimeValue) const
Returns true if a date is in the onlyOnDays or onlyOnDates list, and not in the exceptDates list.
bool isValid(LocalTimeValue localTimeValue) const
####### Parameters
* `localTimeValue` Date to check (local time)
####### Returns
true
####### Returns
false
---
###### bool LocalTimeRestrictedDate::isValid(LocalTimeYMD ymd) const
Returns true if a date is in the onlyOnDays or onlyOnDates list, and not in the exceptDates list.
bool isValid(LocalTimeYMD ymd) const
####### Parameters
* `ymd` Date to check (local time)
####### Returns
true
####### Returns
false
---
###### bool LocalTimeRestrictedDate::inOnlyOnDates(LocalTimeYMD ymd) const
Returns true of a date is in the onlyOnDates list.
bool inOnlyOnDates(LocalTimeYMD ymd) const
####### Parameters
* `ymd`
####### Returns
true
####### Returns
false
---
###### bool LocalTimeRestrictedDate::inExceptDates(LocalTimeYMD ymd) const
Returns true of a date is in the exceptDates list.
bool inExceptDates(LocalTimeYMD ymd) const
####### Parameters
* `ymd`
####### Returns
true
####### Returns
false
---
###### void LocalTimeRestrictedDate::fromJson(JSONValue jsonObj)
Fills in this object from JSON data.
void fromJson(JSONValue jsonObj)
`
####### Parameters
jsonObj
Keys:
y (integer) mask value for onlyOnDays (optional)
a (array) Array of YYYY-MM-DD value strings to allow (optional)
x (array) Array of YYYY-MM-DD values to exclude (optional)
### class LocalTimeSchedule
A complete time schedule.
A time schedule consists of minute multiples ("every 15 minutes"), optionally within a time range (all day, or from 09:00:00 to 17:00:00 local time, for example.
It can also have hour multiples, optionally in a time range, at a defined minute ("every 4 hours at :15
past the hour").
Schedules can be at a specifc day week, with an ordinal (first Monday, last Friday) at a specific time, optionally with exceptions.
Schedules can be a specific day of the month (the 1st, the 5th of the month, the last day of the month, the second to last day of month).
It can also have any number of specific times in the day ("at 08:17:30 local time, 18:15:20 local time") every day, specific days of the week, on specific dates, or with date exceptions.
Version history
0.1.2 (2024-08-01)
- Added LocalTimeConvert methods: nextMinute, nextHour, and nextDayMidnight. Example 3 shows how to use them.
0.1.1 (2023-12-10)
- Added LocalDateTimeRange as a container to hold a UTC time range.
0.1.0 (2023-11-25)
- Added support for LocalTimeRange that crosses midnight (9:00 PM to 5:00 AM, for example).
0.0.9 (2022-04-06)
- Remove automated test from Particle library upload
0.0.8 (2022-04-06)
- Added advanced scheduling modes (JSON scheduling)
- Updated docs
0.0.7 (2022-03-08)
- Added inLocalTimeRange and nextTimeList functions
- Added LocalTimeSchedule
0.0.6 (2022-03-08)
- Added nextMinuteMultiple() and nextTime() functions
0.0.5 (2021-07-08)
- Fixed bug in calculation of negative hour offsets that also included minutes
- Added unit test for Adelaide, Australia
0.0.4 (2021-06-26)
- Added nextDayOrTimeChange
0.0.3 (2021-06-11)
- Remove more-examples code from library
0.0.2 (2021-06-07)
- Add examples
0.0.1 (2021-06-06)
- Initial version
Browse Library Files