00001 // Copyright (C) 2001, Compaq Computer Corporation 00002 // 00003 // This file is part of Vesta. 00004 // 00005 // Vesta is free software; you can redistribute it and/or 00006 // modify it under the terms of the GNU Lesser General Public 00007 // License as published by the Free Software Foundation; either 00008 // version 2.1 of the License, or (at your option) any later version. 00009 // 00010 // Vesta is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00013 // Lesser General Public License for more details. 00014 // 00015 // You should have received a copy of the GNU Lesser General Public 00016 // License along with Vesta; if not, write to the Free Software 00017 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00018 00019 // 00020 // Mastership.H 00021 // Last modified on Tue Jul 20 17:27:28 EDT 2004 by ken@xorian.net 00022 // modified on Mon Mar 20 18:49:11 PST 2000 by mann 00023 // 00024 // Implements RequestMastership and grantMastership, etc. 00025 // 00026 00027 #include "UniqueId.H" 00028 #include "FP.H" 00029 #include "VestaSource.H" 00030 00031 // Module initialization 00032 // Call before log is recovered. 00033 void MastershipInit1() throw (); 00034 // Call after log is recovered. 00035 void MastershipInit2() throw (); 00036 00037 00038 VestaSource::errorCode AcquireMastership(const char* pathname, 00039 const char* srcHost, const char* srcPort, char pathnameSep, 00040 AccessControl::Identity dwho, AccessControl::Identity swho) throw (); 00041 00042 void QueueRecoverMastership(const char* pathname, char pathnameSep, 00043 const char* requestid) throw (); 00044 00045 void MastershipCheckpoint(std::fstream& ckpt) throw (); 00046 00047 extern Text myHostPort, myMasterHint;