/* * Ceph - scalable distributed file system * * This is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software * Foundation. See file COPYING. * */ #include "cls_replica_log_types.h" #include "common/Formatter.h" #include "common/ceph_json.h" void cls_replica_log_item_marker::dump(Formatter *f) const { f->dump_string("name", item_name); f->dump_stream("timestamp") << item_timestamp; } void cls_replica_log_item_marker::decode_json(JSONObj *obj) { JSONDecoder::decode_json("name", item_name, obj); JSONDecoder::decode_json("timestamp", item_timestamp, obj); } void cls_replica_log_item_marker:: generate_test_instances(std::list& ls) { ls.push_back(new cls_replica_log_item_marker); ls.back()->item_name = "test_item_1"; ls.back()->item_timestamp.set_from_double(0); ls.push_back(new cls_replica_log_item_marker); ls.back()->item_name = "test_item_2"; ls.back()->item_timestamp.set_from_double(20); } void cls_replica_log_progress_marker::dump(Formatter *f) const { encode_json("entity", entity_id, f); encode_json("position_marker", position_marker, f); encode_json("position_time", position_time, f); encode_json("items_in_progress", items, f); } void cls_replica_log_progress_marker::decode_json(JSONObj *obj) { JSONDecoder::decode_json("entity", entity_id, obj); JSONDecoder::decode_json("position_marker", position_marker, obj); JSONDecoder::decode_json("position_time", position_time, obj); JSONDecoder::decode_json("items_in_progress", items, obj); } void cls_replica_log_progress_marker:: generate_test_instances(std::list& ls) { ls.push_back(new cls_replica_log_progress_marker); ls.push_back(new cls_replica_log_progress_marker); ls.back()->entity_id = "entity1"; ls.back()->position_marker = "pos1"; ls.back()->position_time.set_from_double(20); std::list test_items; cls_replica_log_item_marker::generate_test_instances(test_items); std::list::iterator i = test_items.begin(); for ( ; i != test_items.end(); ++i) { ls.back()->items.push_back(*(*i)); } } void cls_replica_log_bound::dump(Formatter *f) const { encode_json("position_marker", position_marker, f); encode_json("position_time", position_time, f); encode_json("marker_exists", marker_exists, f); if (marker_exists) { encode_json("marker", marker, f); //progress marker } } void cls_replica_log_bound::decode_json(JSONObj *obj) { JSONDecoder::decode_json("position_marker", position_marker, obj); JSONDecoder::decode_json("position_time", position_time, obj); JSONDecoder::decode_json("marker_exists", marker_exists, obj); if (marker_exists) { JSONDecoder::decode_json("marker", marker, obj); //progress marker } } void cls_replica_log_bound:: generate_test_instances(std::list& ls) { ls.push_back(new cls_replica_log_bound); std::list marker_objects; cls_replica_log_progress_marker::generate_test_instances(marker_objects); std::list::iterator i = marker_objects.begin(); ls.back()->update_marker(*(*i)); ls.push_back(new cls_replica_log_bound); ++i; ls.back()->update_marker(*(*i)); }