ceph/branches/riccardo/monitor2/messages/MExportDirNotify.h
riccardo80 07ac5d3e74 creating branch for distributed monitor
git-svn-id: https://ceph.svn.sf.net/svnroot/ceph@1068 29311d96-e01e-0410-9327-a35deaab8ce9
2007-02-01 05:43:23 +00:00

112 lines
2.9 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 __MEXPORTDIRNOTIFY_H
#define __MEXPORTDIRNOTIFY_H
#include "msg/Message.h"
#include <string>
using namespace std;
class MExportDirNotify : public Message {
int new_auth;
int old_auth;
inodeno_t ino;
list<inodeno_t> exports; // bounds; these dirs are _not_ included (tho the inodes are)
list<inodeno_t> subdirs;
public:
inodeno_t get_ino() { return ino; }
int get_new_auth() { return new_auth; }
int get_old_auth() { return old_auth; }
list<inodeno_t>& get_exports() { return exports; }
list<inodeno_t>::iterator subdirs_begin() { return subdirs.begin(); }
list<inodeno_t>::iterator subdirs_end() { return subdirs.end(); }
int num_subdirs() { return subdirs.size(); }
MExportDirNotify() {}
MExportDirNotify(inodeno_t ino, int old_auth, int new_auth) :
Message(MSG_MDS_EXPORTDIRNOTIFY) {
this->ino = ino;
this->old_auth = old_auth;
this->new_auth = new_auth;
}
virtual char *get_type_name() { return "ExNot"; }
void copy_subdirs(list<inodeno_t>& s) {
this->subdirs = s;
}
void copy_exports(list<inodeno_t>& ex) {
this->exports = ex;
}
virtual void decode_payload(crope& s, int& off) {
s.copy(off, sizeof(int), (char*)&new_auth);
off += sizeof(int);
s.copy(off, sizeof(int), (char*)&old_auth);
off += sizeof(int);
s.copy(off, sizeof(ino), (char*)&ino);
off += sizeof(ino);
// notify
int n;
s.copy(off, sizeof(int), (char*)&n);
off += sizeof(int);
for (int i=0; i<n; i++) {
inodeno_t ino;
s.copy(off, sizeof(ino), (char*)&ino);
exports.push_back(ino);
off += sizeof(inodeno_t);
}
// subdirs
s.copy(off, sizeof(int), (char*)&n);
off += sizeof(int);
for (int i=0; i<n; i++) {
inodeno_t ino;
s.copy(off, sizeof(ino), (char*)&ino);
subdirs.push_back(ino);
off += sizeof(inodeno_t);
}
}
virtual void encode_payload(crope& s) {
s.append((char*)&new_auth, sizeof(int));
s.append((char*)&old_auth, sizeof(int));
s.append((char*)&ino, sizeof(ino));
// notify
int n = exports.size();
s.append((char*)&n, sizeof(int));
for (list<inodeno_t>::iterator it = exports.begin();
it != exports.end();
it++) {
inodeno_t ino = *it;
s.append((char*)&ino, sizeof(ino));
}
// subdirs
n = subdirs.size();
s.append((char*)&n, sizeof(int));
for (list<inodeno_t>::iterator it = subdirs.begin();
it != subdirs.end();
it++) {
inodeno_t ino = *it;
s.append((char*)&ino, sizeof(ino));
}
}
};
#endif