1
0
mirror of https://github.com/mariadb-corporation/mariadb-columnstore-engine.git synced 2025-08-08 14:22:09 +03:00

the begginning

This commit is contained in:
david hill
2016-01-06 14:08:59 -06:00
parent 66a31debcb
commit f6afc42dd0
18251 changed files with 16460679 additions and 2 deletions

View File

@@ -0,0 +1,116 @@
/* 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: rtscommand-jl.cpp 9655 2013-06-25 23:08:13Z xlou $
// C++ Implementation: rtscommand-jl
//
// Description:
//
//
// Author: Patrick <pleblanc@localhost.localdomain>, (C) 2008
//
// Copyright: See COPYING file that comes with this distribution
//
//
#include "bpp-jl.h"
#include "tablecolumn.h"
using namespace std;
using namespace messageqcpp;
namespace joblist
{
RTSCommandJL::RTSCommandJL(const pColStep &c, const pDictionaryStep &d)
{
col.reset(new ColumnCommandJL(c));
dict.reset(new DictStepJL(d));
/* XXXPAT: Need to validate the width; critical for tuple return functionality */
dict->setWidth(c.realWidth);
OID = d.oid();
colName = d.name();
passThru = 0;
}
RTSCommandJL::RTSCommandJL(const PassThruStep &p, const pDictionaryStep &d)
{
execplan::CalpontSystemCatalog::ColType colType;
dict.reset(new DictStepJL(d));
/* XXXPAT: Need to validate the width; critical for tuple return functionality */
dict->setWidth(p.realWidth);
OID = d.oid();
colName = d.name();
passThru = 1;
}
RTSCommandJL::~RTSCommandJL()
{
}
void RTSCommandJL::setLBID(uint64_t data, uint32_t dbroot)
{
if (!passThru)
col->setLBID(data, dbroot);
dict->setLBID(data, dbroot);
}
void RTSCommandJL::createCommand(ByteStream &bs) const
{
bs << (uint8_t) RID_TO_STRING;
bs << passThru;
if (!passThru)
col->createCommand(bs);
dict->createCommand(bs);
CommandJL::createCommand(bs);
}
void RTSCommandJL::runCommand(ByteStream &bs) const
{
if (!passThru)
col->runCommand(bs);
dict->runCommand(bs);
}
uint8_t RTSCommandJL::getTableColumnType()
{
return TableColumn::STRING;
}
string RTSCommandJL::toString()
{
ostringstream ret;
ret << "RTSCommandJL: oid=" << OID << " colName=" << colName << endl;
ret << " ";
if (!passThru)
ret << col->toString() << endl;
ret << " ";
ret << dict->toString();
return ret.str();
}
uint16_t RTSCommandJL::getWidth()
{
return dict->getWidth();
}
};