2023-01-08 12:16:53 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/dateTimeHelpers/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/dateTimeHelpers/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/dateTimeHelpers/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/dateTimeHelpers/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/dateTimeHelpers/actions/workflows/jsoncheck.yml)
|
2023-10-24 15:24:25 +02:00
|
|
|
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/dateTimeHelpers.svg)](https://github.com/RobTillaart/dateTimeHelpers/issues)
|
|
|
|
|
2023-01-08 12:16:53 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/dateTimeHelpers/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/dateTimeHelpers.svg?maxAge=3600)](https://github.com/RobTillaart/dateTimeHelpers/releases)
|
2023-10-24 15:24:25 +02:00
|
|
|
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/dateTimeHelpers.svg)](https://registry.platformio.org/libraries/robtillaart/dateTimeHelpers)
|
2023-01-08 12:16:53 +01:00
|
|
|
|
|
|
|
|
|
|
|
# dateTimeHelpers
|
|
|
|
|
|
|
|
Arduino library with date and time helper functions.
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
This library contains functions that have the goal to help with date and time processing.
|
|
|
|
It is primary a placeholder.
|
|
|
|
|
|
|
|
Please report missing functions, open an issue or preferably a PR.
|
|
|
|
|
|
|
|
|
|
|
|
#### Related libraries
|
|
|
|
|
|
|
|
- https://github.com/RobTillaart/printHelpers
|
|
|
|
- https://github.com/RobTillaart/stopWatch_RT
|
|
|
|
- https://github.com/RobTillaart/CountDown
|
|
|
|
- https://github.com/RobTillaart/timing
|
|
|
|
|
|
|
|
|
|
|
|
#### Implementation notes
|
|
|
|
|
|
|
|
- the functions share an output buffer.
|
|
|
|
This can give problems when prints are made fast after each other as the buffer
|
|
|
|
is not printed completely before it is filled again. (think also RTOS)
|
|
|
|
- math is straightforward, may be optimized? sprintf()?
|
|
|
|
- code has repeating parts, may be optimized?
|
|
|
|
|
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
|
|
|
```cpp
|
|
|
|
#include "dateTimeHelpers.h"
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Display functions
|
|
|
|
|
|
|
|
- **void secondsSplit(uint32_t seconds, uint16_t \* days, uint8_t \* hours, uint8_t \* minutes, uint8_t \* sec)** Splits the seconds into days, hours, minutes and seconds.
|
|
|
|
This is the worker for the next three.
|
|
|
|
Note: days is max 65535 == 179 years.
|
|
|
|
- **char \* seconds2duration(uint32_t seconds, bool displaySeconds = false)** returns "days 00:00:00 .. 23:59:59" or "days 00:00 .. 23:59"
|
|
|
|
- **char \* seconds2clock24(uint32_t seconds, bool displaySeconds = false)** returns "00:00:00 .. 23:59:59" or "00:00 .. 23:59"
|
|
|
|
- **char \* seconds2clock12(uint32_t seconds, bool displaySeconds = false)** returns "00:00:00 .. 12:59:59" or "00:00 .. 12:59".
|
|
|
|
Note this function has no morning or afternoon indication.
|
|
|
|
- **char \* seconds2clockAMPM(uint32_t seconds, bool displaySeconds = false)** returns "00:00:00 AM .. 12:59:59 PM" or "00:00 AM .. 12:59 PM".
|
|
|
|
- **char \* millis2duration(uint32_t millis)** returns "days 00:00:00.000 .. 23:59:59.999"
|
|
|
|
- **char \* millis2clock(uint32_t millis)** returns "00:00:00.000 .. 23:59:59.999"
|
|
|
|
|
|
|
|
|
|
|
|
#### AM PM
|
|
|
|
|
|
|
|
**seconds2clockAMPM** has two more or less undefined moments: midnight (00:00 AM 12:00 PM) and noon (12:00 AM 12:00 PM).
|
|
|
|
See https://www.npl.co.uk/resources/q-a/is-midnight-12am-or-12pm)
|
|
|
|
|
|
|
|
At night one uses 00:15 AM and after noon one uses 12:15 PM.
|
|
|
|
Therefore I use in this implementation:
|
|
|
|
- midnight == 00:00 AM
|
|
|
|
- noon == 12:00 PM
|
|
|
|
|
|
|
|
|
|
|
|
### Convertors
|
|
|
|
|
|
|
|
Note: the following functions use float math so there might occur rounding.
|
|
|
|
|
|
|
|
- **float seconds2weeks(uint32_t seconds)** idem.
|
|
|
|
- **float seconds2days(uint32_t seconds)** idem.
|
|
|
|
- **float seconds2hours(uint32_t seconds)** idem.
|
|
|
|
- **float seconds2minutes(uint32_t seconds)** idem.
|
|
|
|
|
|
|
|
|
|
|
|
## Future
|
|
|
|
|
|
|
|
#### Must
|
|
|
|
|
|
|
|
- improve documentation
|
|
|
|
- test a lot
|
|
|
|
|
|
|
|
#### Should
|
|
|
|
|
|
|
|
- optimize for performance
|
|
|
|
- secondssplit() (see fast math lib)
|
2023-10-24 15:24:25 +02:00
|
|
|
- seconds2clock24 => divmod10
|
2023-01-08 12:16:53 +01:00
|
|
|
- merge code where possible
|
|
|
|
- extend examples
|
|
|
|
- add unit tests
|
|
|
|
- create .cpp file, + move code
|
|
|
|
|
|
|
|
|
|
|
|
#### Could
|
|
|
|
|
|
|
|
- date math functions
|
|
|
|
- days=date-date or date = date + days
|
|
|
|
- day of week
|
|
|
|
- time math functions
|
|
|
|
- 64 bit versions of convertors?
|
|
|
|
- unusual time units for converters?
|
|
|
|
- atomic time
|
|
|
|
- micros2clock()
|
|
|
|
- mm:ss:ttt:mmm or mm:ss.ttt.mmm ?
|
|
|
|
- hour2angle(hh.mm.ss) = angle of the hour hand
|
|
|
|
- 12x60x60 = 360° in 1/12th parts
|
|
|
|
- idem radians..
|
|
|
|
- minute2angle(mm.ss) = angle of the minute hand (mm x 6 + ss x 0.1
|
2023-10-24 15:24:25 +02:00
|
|
|
- seconds2angle(ss) = angle of the seconds hand (ss x 6)
|
2023-01-08 12:16:53 +01:00
|
|
|
- "classify" ?
|
|
|
|
- extern "C" ?
|
|
|
|
|
2023-10-24 15:24:25 +02:00
|
|
|
|
2023-01-08 12:16:53 +01:00
|
|
|
#### Won't
|
|
|
|
|
|
|
|
|
2023-10-24 15:24:25 +02:00
|
|
|
## Support
|
|
|
|
|
|
|
|
If you appreciate my libraries, you can support the development and maintenance.
|
|
|
|
Improve the quality of the libraries by providing issues and Pull Requests, or
|
|
|
|
donate through PayPal or GitHub sponsors.
|
|
|
|
|
|
|
|
Thank you,
|
|
|
|
|
|
|
|
|