1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
/**
* Copyright (C) 2011 Nokia Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library 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
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#include "config.h"
#include "QuotesData.h"
namespace WebCore {
QuotesData* QuotesData::create(int stringCount)
{
char* tmp = new char[sizeof(QuotesData)+sizeof(String)*stringCount];
if (!tmp)
return 0;
new (tmp) QuotesData(stringCount);
for (int i = 0; i < stringCount; ++i)
new (tmp +sizeof(QuotesData) + sizeof(String)*i) String();
return reinterpret_cast<QuotesData*>(tmp);
}
bool QuotesData::equal(const QuotesData* quotesData1, const QuotesData* quotesData2)
{
if (quotesData1 == quotesData2)
return true;
if (!quotesData1 || !quotesData2)
return false;
if (quotesData1->length != quotesData2->length)
return false;
const String* data1 = quotesData1->data();
const String* data2 = quotesData2->data();
for (int i = quotesData1->length - 1; i >= 0; --i)
if (data1[i] != data2[i])
return false;
return true;
}
QuotesData::~QuotesData()
{
String* p = data();
for (int i = 0; i < length; ++i)
p[i].~String();
}
} // namespace WebCore
|