diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /gfx/gl/GLContextGLX.h | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'gfx/gl/GLContextGLX.h')
-rw-r--r-- | gfx/gl/GLContextGLX.h | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/gfx/gl/GLContextGLX.h b/gfx/gl/GLContextGLX.h new file mode 100644 index 0000000000..b6f6e9a959 --- /dev/null +++ b/gfx/gl/GLContextGLX.h @@ -0,0 +1,87 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef GLCONTEXTGLX_H_ +#define GLCONTEXTGLX_H_ + +#include "GLContext.h" +#include "GLXLibrary.h" +#include "mozilla/X11Util.h" + +namespace mozilla { +namespace gl { + +class GLContextGLX : public GLContext { + public: + MOZ_DECLARE_REFCOUNTED_VIRTUAL_TYPENAME(GLContextGLX, override) + static already_AddRefed<GLContextGLX> CreateGLContext( + const GLContextDesc&, std::shared_ptr<gfx::XlibDisplay> display, + GLXDrawable drawable, GLXFBConfig cfg, Drawable ownedPixmap = X11None); + + static bool FindVisual(Display* display, int screen, int* const out_visualId); + + // Finds a GLXFBConfig compatible with the provided window. + static bool FindFBConfigForWindow( + Display* display, int screen, Window window, + GLXFBConfig* const out_config, int* const out_visid, bool aWebRender); + + virtual ~GLContextGLX(); + + GLContextType GetContextType() const override { return GLContextType::GLX; } + + static GLContextGLX* Cast(GLContext* gl) { + MOZ_ASSERT(gl->GetContextType() == GLContextType::GLX); + return static_cast<GLContextGLX*>(gl); + } + + bool Init() override; + + bool MakeCurrentImpl() const override; + + bool IsCurrentImpl() const override; + + Maybe<SymbolLoader> GetSymbolLoader() const override; + + bool IsDoubleBuffered() const override; + + bool SwapBuffers() override; + + GLint GetBufferAge() const override; + + void GetWSIInfo(nsCString* const out) const override; + + // Overrides the current GLXDrawable backing the context and makes the + // context current. + bool OverrideDrawable(GLXDrawable drawable); + + // Undoes the effect of a drawable override. + bool RestoreDrawable(); + + private: + friend class GLContextProviderGLX; + + GLContextGLX(const GLContextDesc&, std::shared_ptr<gfx::XlibDisplay> aDisplay, + GLXDrawable aDrawable, GLXContext aContext, bool aDoubleBuffered, + Drawable aOwnedPixmap = X11None); + + const GLXContext mContext; + const std::shared_ptr<gfx::XlibDisplay> mDisplay; + const GLXDrawable mDrawable; + // The X pixmap associated with the GLX pixmap. If this is provided, then this + // class assumes responsibility for freeing both. Otherwise, the user of this + // class is responsibility for freeing the drawables. + const Drawable mOwnedPixmap; + const bool mDoubleBuffered; + + GLXLibrary* const mGLX; + + const bool mOwnsContext = true; +}; + +} // namespace gl +} // namespace mozilla + +#endif // GLCONTEXTGLX_H_ |