librados::TestClassHandler *cls = get_class_handler();
return cls->create_method(hclass, method, class_call, handle);
}
+
+int cls_register_cxx_filter(cls_handle_t hclass,
+ const std::string &filter_name,
+ cls_cxx_filter_factory_t fn,
+ cls_filter_handle_t *)
+{
+ librados::TestClassHandler *cls = get_class_handler();
+ return cls->create_filter(hclass, filter_name, fn);
+}
return ctx;
}
+int TestClassHandler::create_filter(cls_handle_t hclass,
+ const std::string& name,
+ cls_cxx_filter_factory_t fn)
+{
+ Class *cls = reinterpret_cast<Class*>(hclass);
+ if (cls->filters.find(name) != cls->filters.end()) {
+ return -EEXIST;
+ }
+ cls->filters[name] = fn;
+ return 0;
+}
+
TestClassHandler::MethodContext::~MethodContext() {
io_ctx_impl->put();
}
};
typedef boost::shared_ptr<Method> SharedMethod;
typedef std::map<std::string, SharedMethod> Methods;
+ typedef std::map<std::string, cls_cxx_filter_factory_t> Filters;
struct Class {
Methods methods;
+ Filters filters;
};
typedef boost::shared_ptr<Class> SharedClass;
const std::string &oid,
const SnapContext &snapc);
+ int create_filter(cls_handle_t hclass, const std::string& filter_name,
+ cls_cxx_filter_factory_t fn);
+
private:
typedef std::map<std::string, SharedClass> Classes;
Classes m_classes;
ClassHandles m_class_handles;
+ Filters m_filters;
void open_class(const std::string& name, const std::string& path);