This source file includes following definitions.
- initialize
- reset
- assign
- elementCount
- elementAt
- appendData
- appendFile
- appendFileRange
- appendFileSystemURLRange
- appendBlob
- identifier
- setIdentifier
- containsPasswordData
- setContainsPasswordData
- assign
- ensureMutable
#include "config.h"
#include "public/platform/WebHTTPBody.h"
#include "platform/FileMetadata.h"
#include "platform/network/FormData.h"
using namespace WebCore;
namespace blink {
class WebHTTPBodyPrivate : public FormData {
};
void WebHTTPBody::initialize()
{
assign(static_cast<WebHTTPBodyPrivate*>(FormData::create().leakRef()));
}
void WebHTTPBody::reset()
{
assign(0);
}
void WebHTTPBody::assign(const WebHTTPBody& other)
{
WebHTTPBodyPrivate* p = const_cast<WebHTTPBodyPrivate*>(other.m_private);
if (p)
p->ref();
assign(p);
}
size_t WebHTTPBody::elementCount() const
{
ASSERT(!isNull());
return m_private->elements().size();
}
bool WebHTTPBody::elementAt(size_t index, Element& result) const
{
ASSERT(!isNull());
if (index >= m_private->elements().size())
return false;
const FormDataElement& element = m_private->elements()[index];
result.data.reset();
result.filePath.reset();
result.fileStart = 0;
result.fileLength = 0;
result.modificationTime = invalidFileTime();
result.blobUUID.reset();
switch (element.m_type) {
case FormDataElement::data:
result.type = Element::TypeData;
result.data.assign(element.m_data.data(), element.m_data.size());
break;
case FormDataElement::encodedFile:
result.type = Element::TypeFile;
result.filePath = element.m_filename;
result.fileStart = element.m_fileStart;
result.fileLength = element.m_fileLength;
result.modificationTime = element.m_expectedFileModificationTime;
break;
case FormDataElement::encodedBlob:
result.type = Element::TypeBlob;
result.blobUUID = element.m_blobUUID;
break;
case FormDataElement::encodedFileSystemURL:
result.type = Element::TypeFileSystemURL;
result.fileSystemURL = element.m_fileSystemURL;
result.fileStart = element.m_fileStart;
result.fileLength = element.m_fileLength;
result.modificationTime = element.m_expectedFileModificationTime;
break;
default:
ASSERT_NOT_REACHED();
return false;
}
return true;
}
void WebHTTPBody::appendData(const WebData& data)
{
ensureMutable();
m_private->appendData(data.data(), data.size());
}
void WebHTTPBody::appendFile(const WebString& filePath)
{
ensureMutable();
m_private->appendFile(filePath);
}
void WebHTTPBody::appendFileRange(const WebString& filePath, long long fileStart, long long fileLength, double modificationTime)
{
ensureMutable();
m_private->appendFileRange(filePath, fileStart, fileLength, modificationTime);
}
void WebHTTPBody::appendFileSystemURLRange(const WebURL& url, long long start, long long length, double modificationTime)
{
ASSERT(KURL(url).protocolIs("filesystem"));
ensureMutable();
m_private->appendFileSystemURLRange(url, start, length, modificationTime);
}
void WebHTTPBody::appendBlob(const WebString& uuid)
{
ensureMutable();
m_private->appendBlob(uuid, nullptr);
}
long long WebHTTPBody::identifier() const
{
ASSERT(!isNull());
return m_private->identifier();
}
void WebHTTPBody::setIdentifier(long long identifier)
{
ensureMutable();
return m_private->setIdentifier(identifier);
}
bool WebHTTPBody::containsPasswordData() const
{
return m_private->containsPasswordData();
}
void WebHTTPBody::setContainsPasswordData(bool containsPasswordData)
{
m_private->setContainsPasswordData(containsPasswordData);
}
WebHTTPBody::WebHTTPBody(const PassRefPtr<FormData>& data)
: m_private(static_cast<WebHTTPBodyPrivate*>(data.leakRef()))
{
}
WebHTTPBody& WebHTTPBody::operator=(const PassRefPtr<FormData>& data)
{
assign(static_cast<WebHTTPBodyPrivate*>(data.leakRef()));
return *this;
}
WebHTTPBody::operator PassRefPtr<FormData>() const
{
return m_private;
}
void WebHTTPBody::assign(WebHTTPBodyPrivate* p)
{
if (m_private)
m_private->deref();
m_private = p;
}
void WebHTTPBody::ensureMutable()
{
ASSERT(!isNull());
if (!m_private->hasOneRef())
assign(static_cast<WebHTTPBodyPrivate*>(m_private->copy().leakRef()));
}
}