/*
 * Copyright (C) 2015 Apple Inc. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
 * THE POSSIBILITY OF SUCH DAMAGE.
 */

#ifndef WebCompiledContentExtensionData_h
#define WebCompiledContentExtensionData_h

#if ENABLE(CONTENT_EXTENSIONS)

#include "NetworkCacheData.h"
#include "SharedMemory.h"
#include <wtf/RefPtr.h>

namespace IPC {
class Decoder;
class Encoder;
}

namespace WebKit {

class WebCompiledContentExtensionData {
public:
    WebCompiledContentExtensionData()
    {
    }
    
    WebCompiledContentExtensionData(RefPtr<SharedMemory>&& data, NetworkCache::Data fileData, unsigned actionsOffset, unsigned actionsSize, unsigned filtersWithoutDomainsBytecodeOffset, unsigned filtersWithoutDomainsBytecodeSize, unsigned filtersWithDomainsBytecodeOffset, unsigned filtersWithDomainsBytecodeSize, unsigned domainFiltersBytecodeOffset, unsigned domainFiltersBytecodeSize)
        : data(WTFMove(data))
        , fileData(fileData)
        , actionsOffset(actionsOffset)
        , actionsSize(actionsSize)
        , filtersWithoutDomainsBytecodeOffset(filtersWithoutDomainsBytecodeOffset)
        , filtersWithoutDomainsBytecodeSize(filtersWithoutDomainsBytecodeSize)
        , filtersWithDomainsBytecodeOffset(filtersWithDomainsBytecodeOffset)
        , filtersWithDomainsBytecodeSize(filtersWithDomainsBytecodeSize)
        , domainFiltersBytecodeOffset(domainFiltersBytecodeOffset)
        , domainFiltersBytecodeSize(domainFiltersBytecodeSize)
    {
    }

    void encode(IPC::Encoder&) const;
    static bool decode(IPC::Decoder&, WebCompiledContentExtensionData&);

    RefPtr<SharedMemory> data;
    NetworkCache::Data fileData;
    unsigned actionsOffset { 0 };
    unsigned actionsSize { 0 };
    unsigned filtersWithoutDomainsBytecodeOffset { 0 };
    unsigned filtersWithoutDomainsBytecodeSize { 0 };
    unsigned filtersWithDomainsBytecodeOffset { 0 };
    unsigned filtersWithDomainsBytecodeSize { 0 };
    unsigned domainFiltersBytecodeOffset { 0 };
    unsigned domainFiltersBytecodeSize { 0 };
};

}

#endif // ENABLE(CONTENT_EXTENSIONS)
#endif // WebCompiledContentExtensionData_h
