mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-04-18 21:44:02 +03:00
86 lines
2.4 KiB
C++
86 lines
2.4 KiB
C++
/* Copyright (C) 2014 InfiniDB, Inc.
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; version 2 of
|
|
the License.
|
|
|
|
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 General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
MA 02110-1301, USA. */
|
|
|
|
/******************************************************************************
|
|
* $Id: logicalpartition.h 1823 2013-01-21 14:13:09Z rdempsey $
|
|
*
|
|
*****************************************************************************/
|
|
|
|
/** @file
|
|
* Put LogicalPartition define here to avoid header file include confilct.
|
|
* This struct will be used in connector, brm and writeengine
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "bytestream.h"
|
|
|
|
namespace BRM
|
|
{
|
|
// Logical partition number descriptor
|
|
struct LogicalPartition
|
|
{
|
|
uint16_t dbroot; // dbroot #
|
|
uint32_t pp; // physical partition #
|
|
uint16_t seg; // segment #
|
|
|
|
LogicalPartition() : dbroot((uint16_t)-1), pp((uint32_t)-1), seg((uint16_t)-1)
|
|
{
|
|
}
|
|
|
|
LogicalPartition(uint16_t d, uint32_t p, uint16_t s) : dbroot(d), pp(p), seg(s)
|
|
{
|
|
}
|
|
|
|
bool operator<(const LogicalPartition& n) const
|
|
{
|
|
return ((pp < n.pp) || (pp == n.pp && seg < n.seg) || (pp == n.pp && seg == n.seg && dbroot < n.dbroot));
|
|
}
|
|
|
|
void serialize(messageqcpp::ByteStream& b) const
|
|
{
|
|
b << (uint16_t)dbroot;
|
|
b << (uint32_t)pp;
|
|
b << (uint16_t)seg;
|
|
}
|
|
|
|
void unserialize(messageqcpp::ByteStream& b)
|
|
{
|
|
b >> (uint16_t&)dbroot;
|
|
b >> (uint32_t&)pp;
|
|
b >> (uint16_t&)seg;
|
|
}
|
|
|
|
/** @bug4816. For output to user purpose */
|
|
std::string toString() const;
|
|
};
|
|
|
|
/**
|
|
* ostream operator
|
|
*/
|
|
std::ostream& operator<<(std::ostream& output, const LogicalPartition& rhs);
|
|
std::istream& operator>>(std::istream& input, LogicalPartition& rhs);
|
|
|
|
/**
|
|
* bytestream operator
|
|
*/
|
|
messageqcpp::ByteStream& operator<<(messageqcpp::ByteStream& bs, const LogicalPartition& rhs);
|
|
|
|
messageqcpp::ByteStream& operator>>(messageqcpp::ByteStream& bs, LogicalPartition& rhs);
|
|
|
|
} // namespace BRM
|