1
// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
2
// vim: ts=8 sw=2 smarttab
4
* Ceph - scalable distributed file system
6
* Copyright (C) 2004-2006 Sage Weil <sage@newdream.net>
8
* This is free software; you can redistribute it and/or
9
* modify it under the terms of the GNU Lesser General Public
10
* License version 2.1, as published by the Free Software
11
* Foundation. See file COPYING.
15
#ifndef CEPH_MDS_EFRAGMENT_H
16
#define CEPH_MDS_EFRAGMENT_H
18
#include "../LogEvent.h"
19
#include "EMetaBlob.h"
21
class EFragment : public LogEvent {
26
__s32 bits; // positive for split (from basefrag), negative for merge (to basefrag)
28
EFragment() : LogEvent(EVENT_FRAGMENT) { }
29
EFragment(MDLog *mdlog, inodeno_t i, frag_t bf, int b) :
30
LogEvent(EVENT_FRAGMENT), metablob(mdlog),
31
ino(i), basefrag(bf), bits(b) { }
32
void print(ostream& out) {
33
out << "EFragment " << ino << " " << basefrag << " by " << bits << " " << metablob;
36
void encode(bufferlist &bl) const {
38
::encode(struct_v, bl);
40
::encode(basefrag, bl);
42
::encode(metablob, bl);
44
void decode(bufferlist::iterator &bl) {
46
::decode(struct_v, bl);
48
::decode(basefrag, bl);
50
::decode(metablob, bl);
53
void replay(MDS *mds);