From 76c4567c8c674483e9e3b7286f78ab45115a8cf9 Mon Sep 17 00:00:00 2001 From: Charles Kerr Date: Mon, 16 Mar 2015 18:18:15 +0100 Subject: in DateTime::DateTime(GTimeZone*,GDateTime*), don't allow either argument to be nullptr --- src/date-time.cpp | 32 +++++++++----------------------- 1 file changed, 9 insertions(+), 23 deletions(-) (limited to 'src/date-time.cpp') diff --git a/src/date-time.cpp b/src/date-time.cpp index 46591e6..47ca047 100644 --- a/src/date-time.cpp +++ b/src/date-time.cpp @@ -33,7 +33,8 @@ DateTime::DateTime() DateTime::DateTime(GTimeZone* gtz, GDateTime* gdt) { - g_return_if_fail((gtz==nullptr) == (gdt==nullptr)); + g_return_if_fail(gtz!=nullptr); + g_return_if_fail(gdt!=nullptr); reset(gtz, gdt); } @@ -175,29 +176,14 @@ int64_t DateTime::to_unix() const void DateTime::reset(GTimeZone* gtz, GDateTime* gdt) { - g_return_if_fail ((gdt==nullptr) == (gtz==nullptr)); // all or nothin' + g_return_if_fail (gdt!=nullptr); + g_return_if_fail (gtz!=nullptr); - if (gtz) - { - auto deleter = [](GTimeZone* tz){g_time_zone_unref(tz);}; - m_tz = std::shared_ptr(g_time_zone_ref(gtz), deleter); - g_assert(m_tz); - } - else - { - m_tz.reset(); - } - - if (gdt) - { - auto deleter = [](GDateTime* dt){g_date_time_unref(dt);}; - m_dt = std::shared_ptr(g_date_time_ref(gdt), deleter); - g_assert(m_dt); - } - else - { - m_dt.reset(); - } + auto tz_deleter = [](GTimeZone* tz){g_time_zone_unref(tz);}; + m_tz = std::shared_ptr(g_time_zone_ref(gtz), tz_deleter); + + auto dt_deleter = [](GDateTime* dt){g_date_time_unref(dt);}; + m_dt = std::shared_ptr(g_date_time_ref(gdt), dt_deleter); } bool DateTime::operator<(const DateTime& that) const -- cgit v1.2.3