mirror of
https://github.com/jbeder/yaml-cpp.git
synced 2025-09-09 12:41:17 +00:00
Started specialization for operator[] for integers
This commit is contained in:
@@ -13,13 +13,43 @@ namespace YAML
|
|||||||
{
|
{
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
|
template<typename Key, typename Enable = void>
|
||||||
|
struct get_idx_helper {
|
||||||
|
static node *get(const Key& /* key */, shared_memory_holder /* pMemory */) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename Key>
|
||||||
|
struct get_idx_helper<Key, typename boost::enable_if<boost::is_integral<Key> >::type> {
|
||||||
|
static node *get(const Key& key, shared_memory_holder pMemory) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename Key>
|
||||||
|
inline node *get_idx(const Key& key, shared_memory_holder pMemory) {
|
||||||
|
return get_idx_helper<Key>::get(key, pMemory);
|
||||||
|
}
|
||||||
|
|
||||||
// indexing
|
// indexing
|
||||||
template<typename Key>
|
template<typename Key>
|
||||||
inline node& node_data::get(const Key& key, shared_memory_holder pMemory) const
|
inline node& node_data::get(const Key& key, shared_memory_holder pMemory) const
|
||||||
{
|
{
|
||||||
if(m_type != NodeType::Map)
|
switch(m_type) {
|
||||||
return pMemory->create_node();
|
case NodeType::Map:
|
||||||
|
break;
|
||||||
|
case NodeType::Undefined:
|
||||||
|
case NodeType::Null:
|
||||||
|
return pMemory->create_node();
|
||||||
|
case NodeType::Sequence:
|
||||||
|
if(node *pNode = get_idx(key, pMemory))
|
||||||
|
return *pNode;
|
||||||
|
return pMemory->create_node();
|
||||||
|
case NodeType::Scalar:
|
||||||
|
throw std::runtime_error("Can't call operator[] on a scalar");
|
||||||
|
}
|
||||||
|
|
||||||
for(node_map::const_iterator it=m_map.begin();it!=m_map.end();++it) {
|
for(node_map::const_iterator it=m_map.begin();it!=m_map.end();++it) {
|
||||||
if(equals(*it->first, key, pMemory))
|
if(equals(*it->first, key, pMemory))
|
||||||
return *it->second;
|
return *it->second;
|
||||||
@@ -31,20 +61,19 @@ namespace YAML
|
|||||||
template<typename Key>
|
template<typename Key>
|
||||||
inline node& node_data::get(const Key& key, shared_memory_holder pMemory)
|
inline node& node_data::get(const Key& key, shared_memory_holder pMemory)
|
||||||
{
|
{
|
||||||
// TODO: check if 'key' is index-like, and we're a sequence
|
|
||||||
|
|
||||||
switch(m_type) {
|
switch(m_type) {
|
||||||
case NodeType::Undefined:
|
|
||||||
case NodeType::Null:
|
|
||||||
case NodeType::Scalar:
|
|
||||||
m_type = NodeType::Map;
|
|
||||||
m_map.clear();
|
|
||||||
break;
|
|
||||||
case NodeType::Sequence:
|
|
||||||
convert_sequence_to_map(pMemory);
|
|
||||||
break;
|
|
||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
break;
|
break;
|
||||||
|
case NodeType::Undefined:
|
||||||
|
case NodeType::Null:
|
||||||
|
case NodeType::Sequence:
|
||||||
|
if(node *pNode = get_idx(key, pMemory))
|
||||||
|
return *pNode;
|
||||||
|
|
||||||
|
convert_to_map(pMemory);
|
||||||
|
break;
|
||||||
|
case NodeType::Scalar:
|
||||||
|
throw std::runtime_error("Can't call operator[] on a scalar");
|
||||||
}
|
}
|
||||||
|
|
||||||
for(node_map::const_iterator it=m_map.begin();it!=m_map.end();++it) {
|
for(node_map::const_iterator it=m_map.begin();it!=m_map.end();++it) {
|
||||||
|
@@ -64,7 +64,9 @@ namespace YAML
|
|||||||
|
|
||||||
void reset_sequence();
|
void reset_sequence();
|
||||||
void reset_map();
|
void reset_map();
|
||||||
|
|
||||||
void insert_map_pair(node& key, node& value);
|
void insert_map_pair(node& key, node& value);
|
||||||
|
void convert_to_map(shared_memory_holder pMemory);
|
||||||
void convert_sequence_to_map(shared_memory_holder pMemory);
|
void convert_sequence_to_map(shared_memory_holder pMemory);
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
|
@@ -163,16 +163,18 @@ namespace YAML
|
|||||||
|
|
||||||
void node_data::insert(node& key, node& value, shared_memory_holder pMemory)
|
void node_data::insert(node& key, node& value, shared_memory_holder pMemory)
|
||||||
{
|
{
|
||||||
if(m_type == NodeType::Undefined || m_type == NodeType::Null) {
|
switch(m_type) {
|
||||||
m_type = NodeType::Map;
|
case NodeType::Map:
|
||||||
reset_map();
|
break;
|
||||||
} else if(m_type == NodeType::Sequence) {
|
case NodeType::Undefined:
|
||||||
convert_sequence_to_map(pMemory);
|
case NodeType::Null:
|
||||||
|
case NodeType::Sequence:
|
||||||
|
convert_to_map(pMemory);
|
||||||
|
break;
|
||||||
|
case NodeType::Scalar:
|
||||||
|
throw std::runtime_error("Can't call operator[] on a scalar");
|
||||||
}
|
}
|
||||||
|
|
||||||
if(m_type != NodeType::Map)
|
|
||||||
throw std::runtime_error("Can't insert into a non-map node");
|
|
||||||
|
|
||||||
insert_map_pair(key, value);
|
insert_map_pair(key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -193,17 +195,15 @@ namespace YAML
|
|||||||
node& node_data::get(node& key, shared_memory_holder pMemory)
|
node& node_data::get(node& key, shared_memory_holder pMemory)
|
||||||
{
|
{
|
||||||
switch(m_type) {
|
switch(m_type) {
|
||||||
case NodeType::Undefined:
|
|
||||||
case NodeType::Null:
|
|
||||||
case NodeType::Scalar:
|
|
||||||
m_type = NodeType::Map;
|
|
||||||
reset_map();
|
|
||||||
break;
|
|
||||||
case NodeType::Sequence:
|
|
||||||
convert_sequence_to_map(pMemory);
|
|
||||||
break;
|
|
||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
break;
|
break;
|
||||||
|
case NodeType::Undefined:
|
||||||
|
case NodeType::Null:
|
||||||
|
case NodeType::Sequence:
|
||||||
|
convert_to_map(pMemory);
|
||||||
|
break;
|
||||||
|
case NodeType::Scalar:
|
||||||
|
throw std::runtime_error("Can't call operator[] on a scalar");
|
||||||
}
|
}
|
||||||
|
|
||||||
for(node_map::const_iterator it=m_map.begin();it!=m_map.end();++it) {
|
for(node_map::const_iterator it=m_map.begin();it!=m_map.end();++it) {
|
||||||
@@ -250,6 +250,25 @@ namespace YAML
|
|||||||
m_undefinedPairs.push_back(kv_pair(&key, &value));
|
m_undefinedPairs.push_back(kv_pair(&key, &value));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void node_data::convert_to_map(shared_memory_holder pMemory)
|
||||||
|
{
|
||||||
|
switch(m_type) {
|
||||||
|
case NodeType::Undefined:
|
||||||
|
case NodeType::Null:
|
||||||
|
reset_map();
|
||||||
|
m_type = NodeType::Map;
|
||||||
|
break;
|
||||||
|
case NodeType::Sequence:
|
||||||
|
convert_sequence_to_map(pMemory);
|
||||||
|
break;
|
||||||
|
case NodeType::Map:
|
||||||
|
break;
|
||||||
|
case NodeType::Scalar:
|
||||||
|
assert(false);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void node_data::convert_sequence_to_map(shared_memory_holder pMemory)
|
void node_data::convert_sequence_to_map(shared_memory_holder pMemory)
|
||||||
{
|
{
|
||||||
assert(m_type == NodeType::Sequence);
|
assert(m_type == NodeType::Sequence);
|
||||||
|
Reference in New Issue
Block a user