0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-30 17:10:48 +01:00
mongodb/db/storage.h
2009-02-02 18:18:22 -05:00

150 lines
3.7 KiB
C++

/**
* Copyright (C) 2008 10gen Inc.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License, version 3,
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/* storage.h
Storage subsystem management.
Lays out our datafiles on disk, manages disk space.
*/
#pragma once
namespace mongo {
#pragma pack(1)
class Record;
class DeletedRecord;
class Extent;
class BtreeBucket;
class BSONObj;
class MongoDataFile;
class DiskLoc {
int fileNo; /* this will be volume, file #, etc. */
int ofs;
public:
enum { MaxFiles=4000, NullOfs = -1 };
int a() const {
return fileNo;
}
DiskLoc(int a, int b) : fileNo(a), ofs(b) {
//assert(ofs!=0);
}
DiskLoc() { Null(); }
DiskLoc(const DiskLoc& l) {
fileNo=l.fileNo;
ofs=l.ofs;
}
bool questionable() {
return ofs < -1 ||
fileNo < -1 ||
fileNo > 20;
}
bool isNull() const {
return fileNo == -1;
// return ofs == NullOfs;
}
void Null() {
fileNo = -1;
ofs = 0;
}
void assertOk() {
assert(!isNull());
}
void setInvalid() {
fileNo = -2;
}
bool isValid() const {
return fileNo != -2;
}
string toString() const {
if ( isNull() )
return "null";
stringstream ss;
ss << hex << fileNo << ':' << ofs;
return ss.str();
}
int& GETOFS() {
return ofs;
}
int getOfs() const {
return ofs;
}
void set(int a, int b) {
fileNo=a;
ofs=b;
}
void setOfs(int _fileNo, int _ofs) {
fileNo = _fileNo;
ofs = _ofs;
}
void inc(int amt) {
assert( !isNull() );
ofs += amt;
}
bool sameFile(DiskLoc b) {
return fileNo == b.fileNo;
}
bool operator==(const DiskLoc& b) const {
return fileNo==b.fileNo && ofs == b.ofs;
}
bool operator!=(const DiskLoc& b) const {
return !(*this==b);
}
const DiskLoc& operator=(const DiskLoc& b) {
fileNo=b.fileNo;
ofs = b.ofs;
//assert(ofs!=0);
return *this;
}
int compare(const DiskLoc& b) const {
int x = fileNo - b.fileNo;
if ( x )
return x;
return ofs - b.ofs;
}
bool operator<(const DiskLoc& b) const {
return compare(b) < 0;
}
/* get the "thing" associated with this disk location.
it is assumed the object is what it is -- you must asure that:
think of this as an unchecked type cast.
*/
BSONObj obj() const;
Record* rec() const;
DeletedRecord* drec() const;
Extent* ext() const;
BtreeBucket* btree() const;
BtreeBucket* btreemod() const; // marks modified / dirty
MongoDataFile& pdf() const;
};
#pragma pack()
} // namespace mongo