[gnome-clocks/zbrown/more-awkward-places-stuff: 2/2] world: handle impossible places
- From: Zander <zbrown src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-clocks/zbrown/more-awkward-places-stuff: 2/2] world: handle impossible places
- Date: Sun, 10 May 2020 09:08:36 +0000 (UTC)
commit ec28bb055bf513336b4026778a9a5bc4110f5d13
Author: Zander Brown <zbrown gnome org>
Date: Sun May 10 10:04:21 2020 +0100
world: handle impossible places
Actually check the return value so we don't spam to log with criticals
Finally fix https://gitlab.gnome.org/GNOME/gnome-clocks/-/issues/91
src/world.vala | 44 ++++++++++++++++++++++++++++++--------------
1 file changed, 30 insertions(+), 14 deletions(-)
---
diff --git a/src/world.vala b/src/world.vala
index 7e341b1..127dc85 100644
--- a/src/world.vala
+++ b/src/world.vala
@@ -217,6 +217,15 @@ public class Item : Object, ContentItem {
}
}
+ private bool is_current (DateTime? sunrise, DateTime? sunset) {
+ if (sunrise == null || sunset == null) {
+ return false;
+ }
+
+ return (date_time.compare ((DateTime) sunrise) > 0) &&
+ (date_time.compare ((DateTime) sunset) < 0);
+ }
+
// CSS class for the current time of day
public string state_class {
get {
@@ -224,19 +233,19 @@ public class Item : Object, ContentItem {
return "none";
}
- if (date_time.compare ((DateTime) sun_rise) > 0 && date_time.compare ((DateTime) sun_set) < 0) {
+ if (is_current (sun_rise, sun_set)) {
return "day";
}
- if (date_time.compare ((DateTime) civil_rise) > 0 && date_time.compare ((DateTime) civil_set) <
0) {
+ if (is_current (civil_rise, civil_set)) {
return "civil";
}
- if (date_time.compare ((DateTime) naut_rise) > 0 && date_time.compare ((DateTime) naut_set) < 0)
{
+ if (is_current (naut_rise, naut_set)) {
return "naut";
}
- if (date_time.compare ((DateTime) astro_rise) > 0 && date_time.compare ((DateTime) astro_set) <
0) {
+ if (is_current (astro_rise, astro_set)) {
return "astro";
}
@@ -290,16 +299,23 @@ public class Item : Object, ContentItem {
int rise_hour, rise_min;
int set_hour, set_min;
- calculate_sunrise_sunset (latitude,
- longitude,
- year,
- month,
- day,
- correction,
- out rise_hour,
- out rise_min,
- out set_hour,
- out set_min);
+ if (!calculate_sunrise_sunset (latitude,
+ longitude,
+ year,
+ month,
+ day,
+ correction,
+ out rise_hour,
+ out rise_min,
+ out set_hour,
+ out set_min)) {
+ sunrise = null;
+ sunset = null;
+ debug ("Location (%f,%f) has incalculable sunset/sunrise",
+ latitude,
+ longitude);
+ return;
+ }
var utc_sunrise = (DateTime?) new DateTime.utc (year, month, day, rise_hour, rise_min, 0);
if (utc_sunrise != null) {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]