forked from bblanchon/ArduinoJson
Added JsonObjectIterator::operator->()
This commit is contained in:
@ -12,41 +12,36 @@ namespace ArduinoJson
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
explicit JsonObjectIterator(Internals::JsonNode* node)
|
explicit JsonObjectIterator(Internals::JsonNode* node)
|
||||||
: _node(node)
|
: _objectKeyValue(node)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* key() const
|
|
||||||
{
|
|
||||||
return operator*().key();
|
|
||||||
}
|
|
||||||
|
|
||||||
JsonValue value() const
|
|
||||||
{
|
|
||||||
return operator*().value();
|
|
||||||
}
|
|
||||||
|
|
||||||
void operator++()
|
void operator++()
|
||||||
{
|
{
|
||||||
_node = _node->next;
|
++_objectKeyValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
JsonObjectKeyValue operator*() const
|
JsonObjectKeyValue operator*() const
|
||||||
{
|
{
|
||||||
return JsonObjectKeyValue(_node);
|
return _objectKeyValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonObjectKeyValue* operator->()
|
||||||
|
{
|
||||||
|
return &_objectKeyValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator==(const JsonObjectIterator& other) const
|
bool operator==(const JsonObjectIterator& other) const
|
||||||
{
|
{
|
||||||
return _node == other._node;
|
return _objectKeyValue == other._objectKeyValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator!=(const JsonObjectIterator& other) const
|
bool operator!=(const JsonObjectIterator& other) const
|
||||||
{
|
{
|
||||||
return _node != other._node;
|
return _objectKeyValue != other._objectKeyValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Internals::JsonNode* _node;
|
JsonObjectKeyValue _objectKeyValue;
|
||||||
};
|
};
|
||||||
}
|
}
|
@ -12,7 +12,7 @@ namespace ArduinoJson
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* key()
|
const char* key() const
|
||||||
{
|
{
|
||||||
return _node->getAsObjectKey();
|
return _node->getAsObjectKey();
|
||||||
}
|
}
|
||||||
@ -22,6 +22,21 @@ namespace ArduinoJson
|
|||||||
return JsonValue(_node->getAsObjectValue());
|
return JsonValue(_node->getAsObjectValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void operator++()
|
||||||
|
{
|
||||||
|
_node = _node->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool operator==(const JsonObjectKeyValue& other) const
|
||||||
|
{
|
||||||
|
return _node == other._node;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool operator!=(const JsonObjectKeyValue& other) const
|
||||||
|
{
|
||||||
|
return _node != other._node;
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Internals::JsonNode* _node;
|
Internals::JsonNode* _node;
|
||||||
};
|
};
|
||||||
|
@ -16,12 +16,12 @@ TEST(JsonObject_Iterator_Test, SimpleTest)
|
|||||||
JsonObjectIterator end = object.end();
|
JsonObjectIterator end = object.end();
|
||||||
|
|
||||||
EXPECT_NE(end, it);
|
EXPECT_NE(end, it);
|
||||||
EXPECT_STREQ("ab", it.key());
|
EXPECT_STREQ("ab", it->key());
|
||||||
EXPECT_EQ(12, static_cast<int>(it.value()));
|
EXPECT_EQ(12, static_cast<int>(it->value()));
|
||||||
++it;
|
++it;
|
||||||
EXPECT_NE(end, it);
|
EXPECT_NE(end, it);
|
||||||
EXPECT_STREQ("cd", it.key());
|
EXPECT_STREQ("cd", it->key());
|
||||||
EXPECT_EQ(34, static_cast<int>(it.value()));
|
EXPECT_EQ(34, static_cast<int>(it->value()));
|
||||||
++it;
|
++it;
|
||||||
EXPECT_EQ(object.end(), it);
|
EXPECT_EQ(object.end(), it);
|
||||||
}
|
}
|
Reference in New Issue
Block a user