damage.h revision 03532efdc331b598d3dedc8cc7477641c3b0dd12
/*
* Copyright © 2003 Keith Packard
*
* Permission to use, copy, modify, distribute, and sell this software and its
* documentation for any purpose is hereby granted without fee, provided that
* the above copyright notice appear in all copies and that both that
* copyright notice and this permission notice appear in supporting
* documentation, and that the name of Keith Packard not be used in
* advertising or publicity pertaining to distribution of the software without
* specific, written prior permission. Keith Packard makes no
* representations about the suitability of this software for any purpose. It
* is provided "as is" without express or implied warranty.
*
* KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
* EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
* DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
#ifdef HAVE_DIX_CONFIG_H
#include <dix-config.h>
#endif
#ifndef _DAMAGE_H_
#define _DAMAGE_H_
typedef enum _damageReportLevel {
void *closure);
/* It's the responsibility of the driver to duplicate both regions. */
/* At some point DamageRegionRendered() must be called. */
void *closure);
typedef void (*DamageScreenCreateFunc) (DamagePtr);
typedef void (*DamageScreenDestroyFunc) (DamagePtr);
typedef struct _damageScreenFuncs {
extern _X_EXPORT void
extern _X_EXPORT void
extern _X_EXPORT void
extern _X_EXPORT void
extern _X_EXPORT void
/* In case of rendering, call this before the submitting the commands. */
extern _X_EXPORT void
/* Call this directly after the rendering operation has been submitted. */
extern _X_EXPORT void
/* Call this some time after rendering is done, only relevant when a damageMarker is provided. */
extern _X_EXPORT void
/* Call this when you create a new Damage and you wish to send an initial damage message (to it). */
extern _X_EXPORT void
/* Avoid using this call, it only exists for API compatibility. */
extern _X_EXPORT void
extern _X_EXPORT void
extern _X_EXPORT void
#endif /* _DAMAGE_H_ */