Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(274)

Side by Side Diff: cc/surfaces/sequence_surface_reference_factory.h

Issue 2616403003: Replacing SurfaceReferenceBase and SequenceSurfaceReference with Closures (Closed)
Patch Set: c Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CC_SURFACES_SEQUENCE_SURFACE_REFERENCE_FACTORY_H_ 5 #ifndef CC_SURFACES_SEQUENCE_SURFACE_REFERENCE_FACTORY_H_
6 #define CC_SURFACES_SEQUENCE_SURFACE_REFERENCE_FACTORY_H_ 6 #define CC_SURFACES_SEQUENCE_SURFACE_REFERENCE_FACTORY_H_
7 7
8 #include "cc/output/compositor_frame_metadata.h"
9 #include "cc/surfaces/surface_reference_base.h"
10 #include "cc/surfaces/surface_reference_factory.h" 8 #include "cc/surfaces/surface_reference_factory.h"
9 #include "cc/surfaces/surface_sequence.h"
11 #include "cc/surfaces/surfaces_export.h" 10 #include "cc/surfaces/surfaces_export.h"
12 11
13 namespace cc { 12 namespace cc {
14 13
15 // A surface reference factory that generates references which internally 14 // A surface reference factory that uses SurfaceSequence.
16 // use SurfaceSequence.
17 class CC_SURFACES_EXPORT SequenceSurfaceReferenceFactory 15 class CC_SURFACES_EXPORT SequenceSurfaceReferenceFactory
18 : public NON_EXPORTED_BASE(SurfaceReferenceFactory) { 16 : public NON_EXPORTED_BASE(SurfaceReferenceFactory) {
19 public: 17 public:
20 SequenceSurfaceReferenceFactory() = default; 18 SequenceSurfaceReferenceFactory() = default;
21 19
22 std::unique_ptr<SurfaceReferenceBase> CreateReference( 20 base::Closure CreateReference(SurfaceReferenceOwner* owner,
danakj 2017/01/10 21:12:06 // SurfaceReferenceFactory implementation.
Saman Sami 2017/01/10 21:56:14 Done.
23 SurfaceReferenceOwner* owner, 21 const SurfaceId& surface_id) const override;
24 const SurfaceId& surface_id) const override;
25 22
26 protected: 23 protected:
27 ~SequenceSurfaceReferenceFactory() override = default; 24 ~SequenceSurfaceReferenceFactory() override = default;
28 25
29 private: 26 private:
30 virtual void RequireSequence(const SurfaceId& surface_id, 27 virtual void RequireSequence(const SurfaceId& surface_id,
danakj 2017/01/10 21:12:06 What does it mean to be private and abstract? The
Fady Samuel 2017/01/10 21:33:07 +1
31 const SurfaceSequence& sequence) const = 0; 28 const SurfaceSequence& sequence) const = 0;
32 virtual void SatisfySequence(const SurfaceSequence& sequence) const = 0; 29 virtual void SatisfySequence(const SurfaceSequence& sequence) const = 0;
33 30
34 // SurfaceReferenceFactory implementation:
35 void DestroyReference(SurfaceReferenceBase* surface_ref) const override;
36
37 DISALLOW_COPY_AND_ASSIGN(SequenceSurfaceReferenceFactory); 31 DISALLOW_COPY_AND_ASSIGN(SequenceSurfaceReferenceFactory);
38 }; 32 };
39 33
40 } // namespace cc 34 } // namespace cc
41 35
42 #endif // CC_SURFACES_SEQUENCE_SURFACE_REFERENCE_FACTORY_H_ 36 #endif // CC_SURFACES_SEQUENCE_SURFACE_REFERENCE_FACTORY_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698