diff -r 000000000000 -r 6474c204b198 gfx/thebes/gfxXlibSurface.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gfx/thebes/gfxXlibSurface.h Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,115 @@ +/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 4 -*- + * 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 GFX_XLIBSURFACE_H +#define GFX_XLIBSURFACE_H + +#include "gfxASurface.h" + +#include +#include + +#if defined(GL_PROVIDER_GLX) +#include "GLXLibrary.h" +#endif + +#include "nsSize.h" + +class gfxXlibSurface : public gfxASurface { +public: + // construct a wrapper around the specified drawable with dpy/visual. + // Will use XGetGeometry to query the window/pixmap size. + gfxXlibSurface(Display *dpy, Drawable drawable, Visual *visual); + + // construct a wrapper around the specified drawable with dpy/visual, + // and known width/height. + gfxXlibSurface(Display *dpy, Drawable drawable, Visual *visual, const gfxIntSize& size); + + // construct a wrapper around the specified drawable with dpy/format, + // and known width/height. + gfxXlibSurface(Screen *screen, Drawable drawable, XRenderPictFormat *format, + const gfxIntSize& size); + + gfxXlibSurface(cairo_surface_t *csurf); + + // create a new Pixmap and wrapper surface. + // |relatedDrawable| provides a hint to the server for determining whether + // the pixmap should be in video or system memory. It must be on + // |screen| (if specified). + static already_AddRefed + Create(Screen *screen, Visual *visual, const gfxIntSize& size, + Drawable relatedDrawable = None); + static cairo_surface_t * + CreateCairoSurface(Screen *screen, Visual *visual, const gfxIntSize& size, + Drawable relatedDrawable = None); + static already_AddRefed + Create(Screen* screen, XRenderPictFormat *format, const gfxIntSize& size, + Drawable relatedDrawable = None); + + virtual ~gfxXlibSurface(); + + virtual already_AddRefed + CreateSimilarSurface(gfxContentType aType, const gfxIntSize& aSize); + virtual void Finish() MOZ_OVERRIDE; + + virtual const gfxIntSize GetSize() const; + + Display* XDisplay() { return mDisplay; } + Screen* XScreen(); + Drawable XDrawable() { return mDrawable; } + XRenderPictFormat* XRenderFormat(); + + static int DepthOfVisual(const Screen* screen, const Visual* visual); + static Visual* FindVisual(Screen* screen, gfxImageFormat format); + static XRenderPictFormat *FindRenderFormat(Display *dpy, gfxImageFormat format); + static bool GetColormapAndVisual(cairo_surface_t* aXlibSurface, Colormap* colormap, Visual **visual); + + // take ownership of a passed-in Pixmap, calling XFreePixmap on it + // when the gfxXlibSurface is destroyed. + void TakePixmap(); + + // Release ownership of this surface's Pixmap. This is only valid + // on gfxXlibSurfaces for which the user called TakePixmap(), or + // on those created by a Create() factory method. + Drawable ReleasePixmap(); + + // Find a visual and colormap pair suitable for rendering to this surface. + bool GetColormapAndVisual(Colormap* colormap, Visual **visual); + + // This surface is a wrapper around X pixmaps, which are stored in the X + // server, not the main application. + virtual gfxMemoryLocation GetMemoryLocation() const; + +#if defined(GL_PROVIDER_GLX) + GLXPixmap GetGLXPixmap(); +#endif + + // Return true if cairo will take its slow path when this surface is used + // in a pattern with EXTEND_PAD. As a workaround for XRender's RepeatPad + // not being implemented correctly on old X servers, cairo avoids XRender + // and instead reads back to perform EXTEND_PAD with pixman. Cairo does + // this for servers older than xorg-server 1.7. + bool IsPadSlow() { + // The test here matches that for buggy_pad_reflect in + // _cairo_xlib_device_create. + return VendorRelease(mDisplay) >= 60700000 || + VendorRelease(mDisplay) < 10699000; + } + +protected: + // if TakePixmap() has been called on this + bool mPixmapTaken; + + Display *mDisplay; + Drawable mDrawable; + + const gfxIntSize DoSizeQuery(); + +#if defined(GL_PROVIDER_GLX) + GLXPixmap mGLXPixmap; +#endif +}; + +#endif /* GFX_XLIBSURFACE_H */