skia2/tools/gpu/gl/debug/GrFrameBufferObj.h
Brian Salomon d3b65972aa Mark overridden destructors with 'override' and remove 'virtual'
This silences a new warning in clang 5.0

Change-Id: Ieb5b75a6ffed60107c3fd16075d2ecfd515b55e8
Reviewed-on: https://skia-review.googlesource.com/10006
Commit-Queue: Brian Salomon <bsalomon@google.com>
Reviewed-by: Mike Klein <mtklein@chromium.org>
2017-03-22 16:06:18 +00:00

69 lines
1.8 KiB
C++

/*
* Copyright 2012 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef GrFrameBufferObj_DEFINED
#define GrFrameBufferObj_DEFINED
#include "GrFakeRefObj.h"
class GrFBBindableObj;
////////////////////////////////////////////////////////////////////////////////
// TODO: when a framebuffer obj is bound the GL_SAMPLES query must return 0
// TODO: GL_STENCIL_BITS must also be redirected to the framebuffer
class GrFrameBufferObj : public GrFakeRefObj {
GR_DEFINE_CREATOR(GrFrameBufferObj)
public:
GrFrameBufferObj()
: GrFakeRefObj()
, fBound(false)
, fColorBuffer(nullptr)
, fDepthBuffer(nullptr)
, fStencilBuffer(nullptr) {
}
~GrFrameBufferObj() override {
fColorBuffer = nullptr;
fDepthBuffer = nullptr;
fStencilBuffer = nullptr;
}
void setBound() { fBound = true; }
void resetBound() { fBound = false; }
bool getBound() const { return fBound; }
void setColor(GrFBBindableObj *buffer);
GrFBBindableObj *getColor() { return fColorBuffer; }
void setDepth(GrFBBindableObj *buffer);
GrFBBindableObj *getDepth() { return fDepthBuffer; }
void setStencil(GrFBBindableObj *buffer);
GrFBBindableObj *getStencil() { return fStencilBuffer; }
void deleteAction() override {
setColor(nullptr);
setDepth(nullptr);
setStencil(nullptr);
this->INHERITED::deleteAction();
}
protected:
private:
bool fBound; // is this frame buffer currently bound via "glBindFramebuffer"?
GrFBBindableObj * fColorBuffer;
GrFBBindableObj * fDepthBuffer;
GrFBBindableObj * fStencilBuffer;
typedef GrFakeRefObj INHERITED;
};
#endif // GrFrameBufferObj_DEFINED