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
|