// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- /* * Ceph - scalable distributed file system * * Copyright (C) 2004-2006 Sage Weil * * 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 imports; set exports; //set hashdirs; map > 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::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::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