mirror of
https://github.com/ceph/ceph
synced 2025-01-25 04:24:24 +00:00
67 lines
1.6 KiB
C
67 lines
1.6 KiB
C
|
// -*- 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
|