blob: 8ee5fb9ca1055b508678122fc6541f4b4809dae4 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "fieldTypeInfo.hh"
using namespace hadoop;
FieldTypeInfo::~FieldTypeInfo()
{
delete pFieldID;
delete pTypeID;
}
FieldTypeInfo::FieldTypeInfo(const FieldTypeInfo& ti)
{
pFieldID = new std::string(*ti.pFieldID);
pTypeID = ti.pTypeID->clone();
}
void FieldTypeInfo::serialize(::hadoop::OArchive& a_, const char* tag) const
{
a_.serialize(*pFieldID, tag);
pTypeID->serialize(a_, tag);
}
bool FieldTypeInfo::operator==(const FieldTypeInfo& peer_) const
{
// first check if fieldID matches
if (0 != pFieldID->compare(*(peer_.pFieldID))) {
return false;
}
// now see if typeID matches
return (*pTypeID == *(peer_.pTypeID));
}
// print out the structure. Helps in debugging.
void FieldTypeInfo::print(int space) const
{
for (int i=0; i<space; i++) {
printf(" ");
}
printf("FieldTypeInfo(%lx):\n", (long)this);
for (int i=0; i<space+2; i++) {
printf(" ");
}
printf("field = \"%s\"\n", pFieldID->c_str());
pTypeID->print(space+2);
}