|
yast2-storage
|
00001 /* 00002 * Copyright (c) [2004-2009] Novell, Inc. 00003 * 00004 * All Rights Reserved. 00005 * 00006 * This program is free software; you can redistribute it and/or modify it 00007 * under the terms of version 2 of the GNU General Public License as published 00008 * by the Free Software Foundation. 00009 * 00010 * This program is distributed in the hope that it will be useful, but WITHOUT 00011 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00012 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 00013 * more details. 00014 * 00015 * You should have received a copy of the GNU General Public License along 00016 * with this program; if not, contact Novell, Inc. 00017 * 00018 * To contact Novell about this file by physical or electronic mail, you may 00019 * find current contact information at www.novell.com. 00020 */ 00021 00022 00023 #ifndef DM_CO_H 00024 #define DM_CO_H 00025 00026 #include "storage/PeContainer.h" 00027 #include "storage/Dm.h" 00028 00029 namespace storage 00030 { 00031 class SystemInfo; 00032 00033 00034 class CmdDmsetup 00035 { 00036 00037 public: 00038 00039 CmdDmsetup(); 00040 00041 struct Entry 00042 { 00043 Entry() : name(), mjr(0), mnr(0), segments(0), uuid() {} 00044 00045 string name; 00046 unsigned long mjr; 00047 unsigned long mnr; 00048 unsigned segments; 00049 string uuid; 00050 string table; 00051 }; 00052 00053 bool getEntry(const string& name, Entry& entry) const; 00054 00055 list<string> getEntries() const; 00056 00057 template<class Pred> 00058 list<string> getMatchingEntries(Pred pred) const 00059 { 00060 list<string> ret; 00061 for (const_iterator i = data.begin(); i != data.end(); ++i) 00062 if (pred(i->first)) 00063 ret.push_back(i->first); 00064 return ret; 00065 } 00066 00067 typedef map<string, Entry>::const_iterator const_iterator; 00068 00069 const_iterator begin() const { return data.begin(); } 00070 const_iterator end() const { return data.end(); } 00071 00072 private: 00073 00074 map<string, Entry> data; 00075 00076 }; 00077 00078 00079 class DmCo : public PeContainer 00080 { 00081 friend class Storage; 00082 00083 public: 00084 00085 DmCo(Storage * const s); 00086 DmCo(Storage * const s, SystemInfo& systeminfo, bool only_crypt); 00087 DmCo(const DmCo& c); 00088 virtual ~DmCo(); 00089 00090 void second(SystemInfo& systeminfo, bool only_crypt); 00091 00092 static storage::CType staticType() { return storage::DM; } 00093 friend std::ostream& operator<< (std::ostream&, const DmCo& ); 00094 bool equalContent( const Container& rhs ) const; 00095 00096 virtual void logDifferenceWithVolumes(std::ostream& log, const Container& rhs) const; 00097 00098 void updateDmMaps(); 00099 00100 int removeDm( const string& table ); 00101 int removeVolume( Volume* v ); 00102 00103 protected: 00104 00105 void getDmData(SystemInfo& systeminfo); 00106 void getDmDataCrypt(SystemInfo& systeminfo); 00107 bool getProcSize(SystemInfo& systeminfo, unsigned nr, unsigned long long& s); 00108 bool findDm( unsigned num, DmIter& i ); 00109 bool findDm( unsigned num ); 00110 bool findDm( const string& dev, DmIter& i ); 00111 bool findDm( const string& dev ); 00112 void addDm( Dm* m ); 00113 void checkDm( Dm* m ); 00114 00115 virtual Container* getCopy() const { return( new DmCo( *this ) ); } 00116 00117 storage::EncryptType detectEncryption( const string& device ) const; 00118 00119 virtual void print( std::ostream& s ) const { s << *this; } 00120 00121 int doRemove( Volume* v ); 00122 00123 private: 00124 00125 DmCo& operator=(const DmCo&); // disallow 00126 00127 }; 00128 00129 } 00130 00131 #endif
1.7.3