mariadb/storage/ndb/include/kernel/signaldata/CreateFragmentation.hpp
2014-01-06 10:52:35 +05:30

98 lines
2.1 KiB
C++

/* Copyright (c) 2003-2005 MySQL AB
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 */
#ifndef CREATE_FRAGMENTATION_REQ_HPP
#define CREATE_FRAGMENTATION_REQ_HPP
#include "SignalData.hpp"
class CreateFragmentationReq {
/**
* Sender(s)
*/
friend class Dbdict;
/**
* Receiver(s)
*/
friend class Dbdih;
friend bool printCREATE_FRAGMENTATION_REQ(FILE *,
const Uint32 *, Uint32, Uint16);
public:
STATIC_CONST( SignalLength = 5 );
private:
Uint32 senderRef;
Uint32 senderData;
Uint32 fragmentationType;
Uint32 noOfFragments;
Uint32 primaryTableId; // use same fragmentation as this table if not RNIL
};
class CreateFragmentationRef {
/**
* Sender(s)
*/
friend class Dbdih;
/**
* Receiver(s)
*/
friend class Dbdict;
friend bool printCREATE_FRAGMENTATION_REF(FILE *,
const Uint32 *, Uint32, Uint16);
public:
STATIC_CONST( SignalLength = 3 );
enum ErrorCode {
OK = 0
,InvalidNodeGroup = 771
,InvalidFragmentationType = 772
,InvalidPrimaryTable = 749
};
private:
Uint32 senderRef;
Uint32 senderData;
Uint32 errorCode;
};
class CreateFragmentationConf {
/**
* Sender(s)
*/
friend class Dbdih;
/**
* Receiver(s)
*/
friend class Dbdict;
friend bool printCREATE_FRAGMENTATION_CONF(FILE *,
const Uint32 *, Uint32, Uint16);
public:
STATIC_CONST( SignalLength = 4 );
SECTION( FRAGMENTS = 0 );
private:
Uint32 senderRef;
Uint32 senderData;
Uint32 noOfReplicas;
Uint32 noOfFragments;
};
#endif