1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/* ============================================================
 *
 * This file is a part of digiKam project
 * https://www.digikam.org
 *
 * Date        : 2023-05-15
 * Description : geolocation engine based on Marble.
 *               (c) 2007-2022 Marble Team
 *               https://invent.kde.org/education/marble/-/raw/master/data/credits_authors.html
 *
 * SPDX-FileCopyrightText: 2023-2024 by Gilles Caulier <caulier dot gilles at gmail dot com>
 *
 * SPDX-License-Identifier: LGPL-2.1-or-later
 *
 * ============================================================ */

#include "GeoDataTimeSpan.h"
#include "GeoDataTimeSpan_p.h"

// Qt includes

#include <QDataStream>
#include <QDateTime>

// Local includes

#include "GeoDataTypes.h"
#include "digikam_debug.h"

namespace Marble
{

GeoDataTimeSpan::GeoDataTimeSpan()
    : GeoDataTimePrimitive(),
      d(new GeoDataTimeSpanPrivate)
{
}

GeoDataTimeSpan::GeoDataTimeSpan(const GeoDataTimeSpan& other)
    : GeoDataTimePrimitive(other),
      d(new GeoDataTimeSpanPrivate(*other.d))
{
}

GeoDataTimeSpan::~GeoDataTimeSpan()
{
    delete d;
}

const char* GeoDataTimeSpan::nodeType() const
{
    return GeoDataTypes::GeoDataTimePrimitiveType;
}

const GeoDataTimeStamp& GeoDataTimeSpan::end() const
{
    return d->m_end;
}

GeoDataTimeStamp& GeoDataTimeSpan::end()
{
    return d->m_end;
}

void GeoDataTimeSpan::setEnd(const GeoDataTimeStamp& end)
{
    d->m_end = end;
}

bool GeoDataTimeSpan::isValid() const
{
    if (d->m_begin.when().isValid() != d->m_end.when().isValid())<--- Assuming that condition 'd->m_begin.when().isValid()!=d->m_end.when().isValid()' is not redundant
    {
        return true;
    }

    return d->m_begin.when().isValid() && d->m_end.when().isValid() && d->m_begin.when() <= d->m_end.when();<--- Return value 'd->m_end.when().isValid()' is always true<--- Assuming that condition 'd->m_begin.when().isValid()' is not redundant
}

const GeoDataTimeStamp& GeoDataTimeSpan::begin() const
{
    return d->m_begin;
}

GeoDataTimeStamp& GeoDataTimeSpan::begin()
{
    return d->m_begin;
}

void GeoDataTimeSpan::setBegin(const GeoDataTimeStamp& begin)
{
    d->m_begin = begin;
}

GeoDataTimeSpan& GeoDataTimeSpan::operator=(const GeoDataTimeSpan& other)
{
    GeoDataTimePrimitive::operator=(other);
    *d = *other.d;
    return *this;
}

bool GeoDataTimeSpan::operator==(const GeoDataTimeSpan& other) const
{
    return equals(other) &&
           d->m_begin == other.d->m_begin &&
           d->m_end == other.d->m_end;
}

bool GeoDataTimeSpan::operator!=(const GeoDataTimeSpan& other) const
{
    return !this->operator==(other);
}

void GeoDataTimeSpan::pack(QDataStream& stream) const
{
    GeoDataTimePrimitive::pack(stream);
    d->m_begin.pack(stream);
    d->m_end.pack(stream);
}

void GeoDataTimeSpan::unpack(QDataStream& stream)
{
    GeoDataTimePrimitive::unpack(stream);
    d->m_begin.unpack(stream);
    d->m_end.unpack(stream);
}

} // namespace Marble