/* * Copyright (C) 2004, 2006, 2008, 2011 Apple Inc. All rights reserved. * Copyright (C) 2009 Google Inc. All rights reserved. * Copyright (C) 2012 Digia Plc. and/or its subsidiary(-ies) * * 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 "platform/network/FormData.h" #include "platform/network/FormDataBuilder.h" #include "wtf/text/CString.h" #include "wtf/text/TextEncoding.h" namespace blink { inline FormData::FormData() : m_identifier(0) , m_alwaysStream(false) , m_containsPasswordData(false) { } inline FormData::FormData(const FormData& data) : RefCounted() , m_elements(data.m_elements) , m_identifier(data.m_identifier) , m_alwaysStream(false) , m_containsPasswordData(data.m_containsPasswordData) { } FormData::~FormData() { } PassRefPtr FormData::create() { return adoptRef(new FormData); } PassRefPtr FormData::create(const void* data, size_t size) { RefPtr result = create(); result->appendData(data, size); return result.release(); } PassRefPtr FormData::create(const CString& string) { RefPtr result = create(); result->appendData(string.data(), string.length()); return result.release(); } PassRefPtr FormData::create(const Vector& vector) { RefPtr result = create(); result->appendData(vector.data(), vector.size()); return result.release(); } PassRefPtr FormData::copy() const { return adoptRef(new FormData(*this)); } PassRefPtr FormData::deepCopy() const { RefPtr formData(create()); formData->m_alwaysStream = m_alwaysStream; size_t n = m_elements.size(); formData->m_elements.reserveInitialCapacity(n); for (size_t i = 0; i < n; ++i) { const FormDataElement& e = m_elements[i]; switch (e.m_type) { case FormDataElement::data: formData->m_elements.uncheckedAppend(FormDataElement(e.m_data)); break; } } return formData.release(); } void FormData::appendData(const void* data, size_t size) { if (m_elements.isEmpty() || m_elements.last().m_type != FormDataElement::data) m_elements.append(FormDataElement()); FormDataElement& e = m_elements.last(); size_t oldSize = e.m_data.size(); e.m_data.grow(oldSize + size); memcpy(e.m_data.data() + oldSize, data, size); } void FormData::flatten(Vector& data) const { // Concatenate all the byte arrays, but omit any files. data.clear(); size_t n = m_elements.size(); for (size_t i = 0; i < n; ++i) { const FormDataElement& e = m_elements[i]; if (e.m_type == FormDataElement::data) data.append(e.m_data.data(), static_cast(e.m_data.size())); } } String FormData::flattenToString() const { Vector bytes; flatten(bytes); return Latin1Encoding().decode(reinterpret_cast(bytes.data()), bytes.size()); } unsigned long long FormData::sizeInBytes() const { unsigned size = 0; size_t n = m_elements.size(); for (size_t i = 0; i < n; ++i) { const FormDataElement& e = m_elements[i]; switch (e.m_type) { case FormDataElement::data: size += e.m_data.size(); break; } } return size; } } // namespace blink