From 02116a2fd41518c779decdd8acc2e4c80e358425 Mon Sep 17 00:00:00 2001 From: uli Date: Wed, 23 Nov 2022 12:41:28 +0100 Subject: [PATCH] BLE CTS: fixed signedness of timezone --- src/components/ble/CurrentTimeService.h | 4 ++-- src/components/datetime/DateTimeController.cpp | 2 +- src/components/datetime/DateTimeController.h | 12 ++++++------ 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/src/components/ble/CurrentTimeService.h b/src/components/ble/CurrentTimeService.h index 91544314..9933923d 100644 --- a/src/components/ble/CurrentTimeService.h +++ b/src/components/ble/CurrentTimeService.h @@ -47,8 +47,8 @@ namespace Pinetime { } CtsCurrentTimeData; typedef struct __attribute__((packed)) { - uint8_t timezone; - uint8_t dst; + int8_t timezone; + int8_t dst; } CtsLocalTimeData; DateTime& m_dateTimeController; diff --git a/src/components/datetime/DateTimeController.cpp b/src/components/datetime/DateTimeController.cpp index 8aab49ec..e8c7cd5b 100644 --- a/src/components/datetime/DateTimeController.cpp +++ b/src/components/datetime/DateTimeController.cpp @@ -51,7 +51,7 @@ void DateTime::SetTime(uint16_t year, systemTask->PushMessage(System::Messages::OnNewTime); } -void DateTime::SetTimeZone(uint8_t timezone, uint8_t dst) { +void DateTime::SetTimeZone(int8_t timezone, int8_t dst) { tzOffset = timezone; dstOffset = dst; } diff --git a/src/components/datetime/DateTimeController.h b/src/components/datetime/DateTimeController.h index 681bafbf..24a3ed40 100644 --- a/src/components/datetime/DateTimeController.h +++ b/src/components/datetime/DateTimeController.h @@ -48,7 +48,7 @@ namespace Pinetime { * timezone is expected to be constant over DST which will be reported in * dst field. */ - void SetTimeZone(uint8_t timezone, uint8_t dst); + void SetTimeZone(int8_t timezone, int8_t dst); void UpdateTime(uint32_t systickCounter); uint16_t Year() const { @@ -80,7 +80,7 @@ namespace Pinetime { * supports the BLE CTS Local Time Characteristic. Expect it to be 0 * if not. */ - uint8_t UtcOffset() const { + int8_t UtcOffset() const { return tzOffset + dstOffset; } @@ -92,7 +92,7 @@ namespace Pinetime { * supports the BLE CTS Local Time Characteristic. Expect it to be 0 * if not. */ - uint8_t TzOffset() const { + int8_t TzOffset() const { return tzOffset; } @@ -105,7 +105,7 @@ namespace Pinetime { * supports the BLE CTS Local Time Characteristic. Expect it to be 0 * if not. */ - uint8_t DstOffset() const { + int8_t DstOffset() const { return dstOffset; } @@ -136,8 +136,8 @@ namespace Pinetime { uint8_t hour = 0; uint8_t minute = 0; uint8_t second = 0; - uint8_t tzOffset = 0; - uint8_t dstOffset = 0; + int8_t tzOffset = 0; + int8_t dstOffset = 0; uint32_t previousSystickCounter = 0; std::chrono::time_point currentDateTime;