mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-23 04:03:52 +01:00 
			
		
		
		
	Merge remote-tracking branch 'upstream/dev' into integration
This commit is contained in:
		| @@ -203,27 +203,13 @@ void ESPTime::recalc_timestamp_local() { | ||||
| } | ||||
|  | ||||
| int32_t ESPTime::timezone_offset() { | ||||
|   int32_t offset = 0; | ||||
|   time_t now = ::time(nullptr); | ||||
|   auto local = ESPTime::from_epoch_local(now); | ||||
|   auto utc = ESPTime::from_epoch_utc(now); | ||||
|   bool negative = utc.hour > local.hour && local.day_of_year <= utc.day_of_year; | ||||
|  | ||||
|   if (utc.minute > local.minute) { | ||||
|     local.minute += 60; | ||||
|     local.hour -= 1; | ||||
|   } | ||||
|   offset += (local.minute - utc.minute) * 60; | ||||
|  | ||||
|   if (negative) { | ||||
|     offset -= (utc.hour - local.hour) * 3600; | ||||
|   } else { | ||||
|     if (utc.hour > local.hour) { | ||||
|       local.hour += 24; | ||||
|     } | ||||
|     offset += (local.hour - utc.hour) * 3600; | ||||
|   } | ||||
|   return offset; | ||||
|   struct tm local_tm = *::localtime(&now); | ||||
|   local_tm.tm_isdst = 0;  // Cause mktime to ignore daylight saving time because we want to include it in the offset. | ||||
|   time_t local_time = mktime(&local_tm); | ||||
|   struct tm utc_tm = *::gmtime(&now); | ||||
|   time_t utc_time = mktime(&utc_tm); | ||||
|   return static_cast<int32_t>(local_time - utc_time); | ||||
| } | ||||
|  | ||||
| bool ESPTime::operator<(const ESPTime &other) const { return this->timestamp < other.timestamp; } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user