summaryrefslogtreecommitdiffstats
path: root/third_party/WebKit/Source/core/fetch/CachedMetadataHandler.h
blob: 560e9a7ab72f42e7d2af782fd783dd5c2d03968b (plain)
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
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CachedMetadataHandler_h
#define CachedMetadataHandler_h

#include "platform/heap/Handle.h"
#include "wtf/Forward.h"

namespace blink {

class CachedMetadata;

// Handler class for caching operations.
class CachedMetadataHandler : public NoBaseWillBeGarbageCollectedFinalized<CachedMetadataHandler> {
    USING_FAST_MALLOC_WILL_BE_REMOVED(CachedMetadataHandler);
public:
    enum CacheType {
        SendToPlatform, // send cache data to blink::Platform::cacheMetadata
        CacheLocally // cache only in Resource's member variables
    };
    virtual ~CachedMetadataHandler() { }
    DEFINE_INLINE_VIRTUAL_TRACE() { }
    // Caches the given metadata in association with this resource and suggests
    // that the platform persist it. The dataTypeID is a pseudo-randomly chosen
    // identifier that is used to distinguish data generated by the caller.
    virtual void setCachedMetadata(unsigned dataTypeID, const char*, size_t, CacheType = SendToPlatform) = 0;
    // Reset existing metadata, to allow setting new data.
    virtual void clearCachedMetadata(CacheType = CacheLocally) = 0;
    // Returns cached metadata of the given type associated with this resource.
    virtual CachedMetadata* cachedMetadata(unsigned dataTypeID) const = 0;
    // Returns the encoding to which the cache is specific.
    virtual String encoding() const = 0;

protected:
    CachedMetadataHandler() { }
};
} // namespace blink

#endif // CachedMetadataHandler_h