[thin] Use specific damage visitors to improve error messages.

There's now a damage visitor for dev_trees, mapping_trees and
single_mapping_trees.
This commit is contained in:
Joe Thornber 2015-04-07 12:16:46 +01:00
parent f581f34be8
commit 7f643b7050

View File

@ -141,9 +141,9 @@ namespace {
} }
}; };
class ll_damage_visitor { class dev_tree_damage_visitor {
public: public:
ll_damage_visitor(damage_visitor &v) dev_tree_damage_visitor(damage_visitor &v)
: v_(v) { : v_(v) {
} }
@ -158,14 +158,56 @@ namespace {
break; break;
default: default:
// shouldn't get here. throw std::runtime_error("dev_tree_damage_visitor: path too long");
throw std::runtime_error("ll_damage_visitor: path too long");
} }
} }
private: private:
damage_visitor &v_; damage_visitor &v_;
}; };
class mapping_tree_damage_visitor {
public:
mapping_tree_damage_visitor(damage_visitor &v)
: v_(v) {
}
virtual void visit(btree_path const &path, btree_detail::damage const &d) {
switch (path.size()) {
case 0:
v_.visit(missing_devices(d.desc_, d.lost_keys_));
break;
default:
throw std::runtime_error("mapping_tree_damage_visitor: path too long");
}
}
private:
damage_visitor &v_;
};
class single_mapping_tree_damage_visitor {
public:
single_mapping_tree_damage_visitor(damage_visitor &v)
: v_(v) {
}
virtual void visit(btree_path const &path, btree_detail::damage const &d) {
switch (path.size()) {
case 0:
v_.visit(missing_mappings(d.desc_, path[0], d.lost_keys_));
break;
default:
throw std::runtime_error("single_mapping_tree_damage_visitor: path too long");
}
}
private:
damage_visitor &v_;
};
} }
void void
@ -173,7 +215,7 @@ thin_provisioning::walk_mapping_tree(dev_tree const &tree,
mapping_tree_detail::device_visitor &dev_v, mapping_tree_detail::device_visitor &dev_v,
mapping_tree_detail::damage_visitor &dv) mapping_tree_detail::damage_visitor &dv)
{ {
ll_damage_visitor ll_dv(dv); dev_tree_damage_visitor ll_dv(dv);
btree_visit_values(tree, dev_v, ll_dv); btree_visit_values(tree, dev_v, ll_dv);
} }
@ -190,7 +232,7 @@ thin_provisioning::walk_mapping_tree(mapping_tree const &tree,
mapping_tree_detail::mapping_visitor &mv, mapping_tree_detail::mapping_visitor &mv,
mapping_tree_detail::damage_visitor &dv) mapping_tree_detail::damage_visitor &dv)
{ {
ll_damage_visitor ll_dv(dv); mapping_tree_damage_visitor ll_dv(dv);
btree_visit_values(tree, mv, ll_dv); btree_visit_values(tree, mv, ll_dv);
} }
@ -207,7 +249,7 @@ thin_provisioning::walk_mapping_tree(single_mapping_tree const &tree,
mapping_tree_detail::mapping_visitor &mv, mapping_tree_detail::mapping_visitor &mv,
mapping_tree_detail::damage_visitor &dv) mapping_tree_detail::damage_visitor &dv)
{ {
ll_damage_visitor ll_dv(dv); single_mapping_tree_damage_visitor ll_dv(dv);
btree_visit_values(tree, mv, ll_dv); btree_visit_values(tree, mv, ll_dv);
} }