ceph/branches/sage/pgs/mds/events/EImportMap.h

67 lines
1.6 KiB
C
Raw Normal View History

// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
/*
* Ceph - scalable distributed file system
*
* Copyright (C) 2004-2006 Sage Weil <sage@newdream.net>
*
* 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.
*
*/
#ifndef __MDS_EIMPORTMAP_H
#define __MDS_EIMPORTMAP_H
#include "../LogEvent.h"
#include "EMetaBlob.h"
class EImportMap : public LogEvent {
public:
EMetaBlob metablob;
set<inodeno_t> imports;
set<inodeno_t> exports;
//set<inodeno_t> hashdirs;
map<inodeno_t, set<inodeno_t> > nested_exports;
EImportMap() : LogEvent(EVENT_IMPORTMAP) { }
void print(ostream& out) {
out << "import_map " << imports.size() << " imports, "
<< exports.size() << " exports"
<< " " << metablob;
}
void encode_payload(bufferlist& bl) {
metablob._encode(bl);
::_encode(imports, bl);
::_encode(exports, bl);
for (set<inodeno_t>::iterator p = imports.begin();
p != imports.end();
++p) {
::_encode(nested_exports[*p], bl);
if (nested_exports[*p].empty())
nested_exports.erase(*p);
}
}
void decode_payload(bufferlist& bl, int& off) {
metablob._decode(bl, off);
::_decode(imports, bl, off);
::_decode(exports, bl, off);
for (set<inodeno_t>::iterator p = imports.begin();
p != imports.end();
++p) {
::_decode(nested_exports[*p], bl, off);
if (nested_exports[*p].empty())
nested_exports.erase(*p);
}
}
bool has_expired(MDS *mds);
void expire(MDS *mds, Context *c);
void replay(MDS *mds);
};
#endif