// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab /* * 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 __MDSTABLE_H #define __MDSTABLE_H #include "mdstypes.h" #include "mds_table_types.h" #include "include/buffer.h" #include "include/Context.h" class MDS; class MDSTable { protected: MDS *mds; const char *table_name; inodeno_t ino; ceph_file_layout layout; static const int STATE_UNDEF = 0; static const int STATE_OPENING = 1; static const int STATE_ACTIVE = 2; //static const int STATE_COMMITTING = 3; int state; version_t version, committing_version, committed_version; map > waitfor_save; public: MDSTable(MDS *m, const char *n) : mds(m), table_name(n), ino(0), state(STATE_UNDEF), version(0), committing_version(0), committed_version(0) { } virtual ~MDSTable() {} version_t get_version() { return version; } version_t get_committed_version() { return committed_version; } version_t get_committing_version() { return committing_version; } // load/save from disk (hack) bool is_undef() { return state == STATE_UNDEF; } bool is_active() { return state == STATE_ACTIVE; } bool is_opening() { return state == STATE_OPENING; } void reset(); void save(Context *onfinish=0, version_t need=0); void save_2(version_t v); void shutdown() { if (is_active()) save(0); } void load(Context *onfinish); void load_2(int, bufferlist&, Context *onfinish); // child must overload these virtual void init_inode() = 0; virtual void reset_state() = 0; virtual void decode_state(bufferlist::iterator& p) = 0; virtual void encode_state(bufferlist& bl) = 0; }; #endif