+++ /dev/null
-// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
-// vim: ts=8 sw=2 smarttab
-
-#ifndef CEPH_RBD_MIRROR_BASE_REQUEST_H
-#define CEPH_RBD_MIRROR_BASE_REQUEST_H
-
-#include "common/RefCountedObj.h"
-#include "include/Context.h"
-
-namespace rbd {
-namespace mirror {
-
-class BaseRequest : public RefCountedObject {
-public:
- BaseRequest(const std::string& name, CephContext *cct, Context *on_finish)
- : RefCountedObject(cct), m_name(name), m_cct(cct),
- m_on_finish(on_finish) {
- }
-
- virtual void send() = 0;
- virtual void cancel() {}
-
-protected:
- virtual void finish(int r) {
- if (m_cct) {
- lsubdout(m_cct, rbd_mirror, 20) << m_name << "::finish: r=" << r << dendl;
- }
- if (m_on_finish) {
- m_on_finish->complete(r);
- }
- put();
- }
-
-private:
- const std::string m_name;
- CephContext *m_cct;
- Context *m_on_finish;
-};
-
-} // namespace mirror
-} // namespace rbd
-
-#endif // CEPH_RBD_MIRROR_BASE_REQUEST_H
--- /dev/null
+// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
+// vim: ts=8 sw=2 smarttab
+
+#ifndef CEPH_RBD_MIRROR_CANCELABLE_REQUEST_H
+#define CEPH_RBD_MIRROR_CANCELABLE_REQUEST_H
+
+#include "common/RefCountedObj.h"
+#include "include/Context.h"
+
+namespace rbd {
+namespace mirror {
+
+class CancelableRequest : public RefCountedObject {
+public:
+ CancelableRequest(const std::string& name, CephContext *cct,
+ Context *on_finish)
+ : RefCountedObject(cct), m_name(name), m_cct(cct),
+ m_on_finish(on_finish) {
+ }
+
+ virtual void send() = 0;
+ virtual void cancel() {}
+
+protected:
+ virtual void finish(int r) {
+ if (m_cct) {
+ lsubdout(m_cct, rbd_mirror, 20) << m_name << "::finish: r=" << r << dendl;
+ }
+ if (m_on_finish) {
+ m_on_finish->complete(r);
+ }
+ put();
+ }
+
+private:
+ const std::string m_name;
+ CephContext *m_cct;
+ Context *m_on_finish;
+};
+
+} // namespace mirror
+} // namespace rbd
+
+#endif // CEPH_RBD_MIRROR_CANCELABLE_REQUEST_H
InstanceWatcher<I> *instance_watcher,
ProgressContext *progress_ctx,
Context *on_finish)
- : BaseRequest("rbd::mirror::ImageSync", local_image_ctx->cct, on_finish),
+ : CancelableRequest("rbd::mirror::ImageSync", local_image_ctx->cct,
+ on_finish),
m_threads(threads),
m_local_image_ctx(local_image_ctx),
m_remote_image_ctx(remote_image_ctx),
m_lock.lock();
if (m_canceled) {
m_lock.unlock();
- BaseRequest::finish(-ECANCELED);
+ CancelableRequest::finish(-ECANCELED);
return;
}
m_lock.unlock();
if (r < 0) {
- BaseRequest::finish(r);
+ CancelableRequest::finish(r);
return;
}
dout(20) << ": r=" << r << dendl;
m_instance_watcher->notify_sync_complete(m_local_image_ctx->id);
- BaseRequest::finish(r);
+ CancelableRequest::finish(r);
}
} // namespace mirror
#include "librbd/ImageCtx.h"
#include "librbd/Types.h"
#include "common/ceph_mutex.h"
-#include "tools/rbd_mirror/BaseRequest.h"
+#include "tools/rbd_mirror/CancelableRequest.h"
#include "tools/rbd_mirror/image_sync/Types.h"
class Context;
namespace image_sync { struct SyncPointHandler; }
template <typename ImageCtxT = librbd::ImageCtx>
-class ImageSync : public BaseRequest {
+class ImageSync : public CancelableRequest {
public:
static ImageSync* create(
Threads<ImageCtxT>* threads,
Journaler** remote_journaler,
bool* do_resync,
Context* on_finish)
- : BaseRequest("rbd::mirror::image_replayer::BootstrapRequest",
- reinterpret_cast<CephContext*>(local_io_ctx.cct()), on_finish),
+ : CancelableRequest("rbd::mirror::image_replayer::BootstrapRequest",
+ reinterpret_cast<CephContext*>(local_io_ctx.cct()),
+ on_finish),
m_threads(threads),
m_local_io_ctx(local_io_ctx),
m_remote_io_ctx(remote_io_ctx),
#include "librbd/journal/Types.h"
#include "librbd/journal/TypeTraits.h"
#include "librbd/mirror/Types.h"
-#include "tools/rbd_mirror/BaseRequest.h"
+#include "tools/rbd_mirror/CancelableRequest.h"
#include "tools/rbd_mirror/Types.h"
#include <list>
#include <string>
namespace journal { template <typename> class StateBuilder; }
template <typename ImageCtxT = librbd::ImageCtx>
-class BootstrapRequest : public BaseRequest {
+class BootstrapRequest : public CancelableRequest {
public:
typedef librbd::journal::TypeTraits<ImageCtxT> TypeTraits;
typedef typename TypeTraits::Journaler Journaler;