| Index: cc/CCRenderPass.h | 
| diff --git a/cc/CCRenderPass.h b/cc/CCRenderPass.h | 
| index d4c518aca37aa7597e56098b538a82fd0da0ed64..4cafa613c97c2d3dd3d4d767340ff8fc81502e07 100644 | 
| --- a/cc/CCRenderPass.h | 
| +++ b/cc/CCRenderPass.h | 
| @@ -10,11 +10,11 @@ | 
| #include "CCSharedQuadState.h" | 
| #include "FloatRect.h" | 
| #include "SkColor.h" | 
| +#include "cc/hash_pair.h" | 
| #include "cc/own_ptr_vector.h" | 
| +#include "cc/scoped_ptr_hash_map.h" | 
| #include <public/WebFilterOperations.h> | 
| #include <public/WebTransformationMatrix.h> | 
| -#include <wtf/HashMap.h> | 
| -#include <wtf/PassOwnPtr.h> | 
| #include <wtf/Vector.h> | 
|  | 
| namespace cc { | 
| @@ -58,10 +58,10 @@ public: | 
| bool operator<(const Id& other) const { return layerId < other.layerId || (layerId == other.layerId && index < other.index); } | 
| }; | 
|  | 
| -    static PassOwnPtr<CCRenderPass> create(Id, IntRect outputRect, const WebKit::WebTransformationMatrix& transformToRootTarget); | 
| +    static scoped_ptr<CCRenderPass> create(Id, IntRect outputRect, const WebKit::WebTransformationMatrix& transformToRootTarget); | 
|  | 
| // A shallow copy of the render pass, which does not include its quads. | 
| -    PassOwnPtr<CCRenderPass> copy(Id newId) const; | 
| +    scoped_ptr<CCRenderPass> copy(Id newId) const; | 
|  | 
| void appendQuadsForLayer(CCLayerImpl*, CCOcclusionTrackerImpl*, CCAppendQuadsData&); | 
| void appendQuadsForRenderSurfaceLayer(CCLayerImpl*, const CCRenderPass* contributingRenderPass, CCOcclusionTrackerImpl*, CCAppendQuadsData&); | 
| @@ -109,27 +109,27 @@ protected: | 
|  | 
| } // namespace cc | 
|  | 
| -namespace WTF { | 
| -template<> struct HashTraits<cc::CCRenderPass::Id> : GenericHashTraits<cc::CCRenderPass::Id> { | 
| -    static const bool emptyValueIsZero = false; | 
| -    static const bool needsDestruction = false; | 
| -    static cc::CCRenderPass::Id emptyValue() { return cc::CCRenderPass::Id(0, 0); } | 
| -    static void constructDeletedValue(cc::CCRenderPass::Id& slot) { slot = cc::CCRenderPass::Id(-1, -1); } | 
| -    static bool isDeletedValue(cc::CCRenderPass::Id value) { return value.layerId == -1 && value.index == -1; } | 
| +namespace BASE_HASH_NAMESPACE { | 
| +#if defined(COMPILER_MSVC) | 
| +template<> | 
| +inline size_t hash_value<cc::CCRenderPass::Id>(const cc::CCRenderPass::Id& key) { | 
| +    return hash_value<std::pair<int, int> >(std::pair<int, int>(key.layerId, key.index)); | 
| +} | 
| +#elif defined(COMPILER_GCC) | 
| +template<> | 
| +struct hash<cc::CCRenderPass::Id> { | 
| +    size_t operator()(cc::CCRenderPass::Id key) const { | 
| +        return hash<std::pair<int, int> >()(std::pair<int, int>(key.layerId, key.index)); | 
| +    } | 
| }; | 
| -template<> struct IntHash<cc::CCRenderPass::Id> { | 
| -    static unsigned hash(const cc::CCRenderPass::Id& key) { return PairHash<int, int>::hash(std::make_pair(key.layerId, key.index)); } | 
| -    static bool equal(const cc::CCRenderPass::Id& a, const cc::CCRenderPass::Id& b) { return a == b; } | 
| -    static const bool safeToCompareToEmptyOrDeleted = true; | 
| -}; | 
| -template<> struct DefaultHash<cc::CCRenderPass::Id> { | 
| -    typedef IntHash<cc::CCRenderPass::Id> Hash; | 
| -}; | 
| -} // namespace WTF | 
| +#else | 
| +#error define a hash function for your compiler | 
| +#endif // COMPILER | 
| +} | 
|  | 
| namespace cc { | 
| typedef Vector<CCRenderPass*> CCRenderPassList; | 
| -typedef HashMap<CCRenderPass::Id, OwnPtr<CCRenderPass> > CCRenderPassIdHashMap; | 
| +typedef ScopedPtrHashMap<CCRenderPass::Id, CCRenderPass> CCRenderPassIdHashMap; | 
| } // namespace cc | 
|  | 
| #endif | 
|  |