blob: 5c95a8f7e026df0c3c909a5c9f40b276e44e0ffb [file] [log] [blame]
Shock Jiangb7370c22014-09-05 14:43:22 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Yumin Xia55a7cc42017-05-14 18:43:34 -07002/*
Davide Pesavento948c50c2020-12-26 21:30:45 -05003 * Copyright (c) 2014-2020, Regents of the University of California.
Shock Jiangb7370c22014-09-05 14:43:22 -07004 *
5 * This file is part of NDNS (Named Data Networking Domain Name Service).
6 * See AUTHORS.md for complete list of NDNS authors and contributors.
7 *
8 * NDNS is free software: you can redistribute it and/or modify it under the terms
9 * of the GNU General Public License as published by the Free Software Foundation,
10 * either version 3 of the License, or (at your option) any later version.
11 *
12 * NDNS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
13 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 * PURPOSE. See the GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along with
17 * NDNS, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20#include "rrset.hpp"
21
22namespace ndn {
23namespace ndns {
24
25Rrset::Rrset(Zone* zone)
26 : m_id(0)
27 , m_zone(zone)
28{
29}
30
31std::ostream&
32operator<<(std::ostream& os, const Rrset& rrset)
33{
34 os << "Rrset: Id=" << rrset.getId();
Shock Jiangcde28712014-10-19 21:17:20 -070035 if (rrset.getZone() != nullptr)
Shock Jiangb7370c22014-09-05 14:43:22 -070036 os << " Zone=(" << *rrset.getZone() << ")";
37
38 os << " Label=" << rrset.getLabel()
39 << " Type=" << rrset.getType()
40 << " Version=" << rrset.getVersion();
41 return os;
42}
43
Shock Jiangcde28712014-10-19 21:17:20 -070044bool
45Rrset::operator==(const Rrset& other) const
46{
47 if (getZone() == nullptr && other.getZone() != nullptr)
48 return false;
49 else if (getZone() != nullptr && other.getZone() == nullptr)
50 return false;
51 else if (getZone() == nullptr && other.getZone() == nullptr)
52 return (getLabel() == other.getLabel() &&
53 getType() == other.getType() && getVersion() == other.getVersion());
54 else
55 return (*getZone() == *other.getZone() && getLabel() == other.getLabel() &&
56 getType() == other.getType() && getVersion() == other.getVersion());
57
58}
59
Yumin Xia55a7cc42017-05-14 18:43:34 -070060bool
61Rrset::operator<(const Rrset& other) const
62{
63 if (getZone() != other.getZone() ||
64 (getZone() != nullptr && *getZone() != *other.getZone())) {
Davide Pesavento948c50c2020-12-26 21:30:45 -050065 NDN_THROW(std::runtime_error("Cannot compare Rrset that belong to different zones"));
Yumin Xia55a7cc42017-05-14 18:43:34 -070066 }
67
68 bool isLess = getLabel() < other.getLabel();
69 if (!isLess && getLabel() == other.getLabel()) {
70 isLess = getType() < other.getType();
71
72 if (!isLess && getType() == other.getType()) {
73 isLess = getVersion() < other.getVersion();
74 }
75 }
76 return isLess;
77}
78
79
Shock Jiangb7370c22014-09-05 14:43:22 -070080} // namespace ndns
81} // namespace ndn