/usr/lib/python2.7/dist-packages/xcffib/damage.py is in python-xcffib 0.5.1-1build3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 | import xcffib
import struct
import six
MAJOR_VERSION = 1
MINOR_VERSION = 1
key = xcffib.ExtensionKey("DAMAGE")
_events = {}
_errors = {}
from . import xproto
from . import xfixes
class ReportLevel:
RawRectangles = 0
DeltaRectangles = 1
BoundingBox = 2
NonEmpty = 3
class BadDamageError(xcffib.Error):
def __init__(self, unpacker):
if isinstance(unpacker, xcffib.Protobj):
unpacker = xcffib.MemoryUnpacker(unpacker.pack())
xcffib.Error.__init__(self, unpacker)
base = unpacker.offset
unpacker.unpack("xx2x")
self.bufsize = unpacker.offset - base
def pack(self):
buf = six.BytesIO()
buf.write(struct.pack("=B", 0))
buf.write(struct.pack("=x2x"))
return buf.getvalue()
BadBadDamage = BadDamageError
_errors[0] = BadDamageError
class QueryVersionReply(xcffib.Reply):
def __init__(self, unpacker):
if isinstance(unpacker, xcffib.Protobj):
unpacker = xcffib.MemoryUnpacker(unpacker.pack())
xcffib.Reply.__init__(self, unpacker)
base = unpacker.offset
self.major_version, self.minor_version = unpacker.unpack("xx2x4xII16x")
self.bufsize = unpacker.offset - base
class QueryVersionCookie(xcffib.Cookie):
reply_type = QueryVersionReply
class NotifyEvent(xcffib.Event):
def __init__(self, unpacker):
if isinstance(unpacker, xcffib.Protobj):
unpacker = xcffib.MemoryUnpacker(unpacker.pack())
xcffib.Event.__init__(self, unpacker)
base = unpacker.offset
self.level, self.drawable, self.damage, self.timestamp = unpacker.unpack("xB2xIII")
self.area = xproto.RECTANGLE(unpacker)
unpacker.pad(xproto.RECTANGLE)
self.geometry = xproto.RECTANGLE(unpacker)
self.bufsize = unpacker.offset - base
def pack(self):
buf = six.BytesIO()
buf.write(struct.pack("=B", 0))
buf.write(struct.pack("=B2xIII", self.level, self.drawable, self.damage, self.timestamp))
buf.write(self.area.pack() if hasattr(self.area, "pack") else RECTANGLE.synthetic(*self.area).pack())
buf.write(self.geometry.pack() if hasattr(self.geometry, "pack") else RECTANGLE.synthetic(*self.geometry).pack())
buf_len = len(buf.getvalue())
if buf_len < 32:
buf.write(struct.pack("x" * (32 - buf_len)))
return buf.getvalue()
@classmethod
def synthetic(cls, level, drawable, damage, timestamp, area, geometry):
self = cls.__new__(cls)
self.level = level
self.drawable = drawable
self.damage = damage
self.timestamp = timestamp
self.area = area
self.geometry = geometry
return self
_events[0] = NotifyEvent
class damageExtension(xcffib.Extension):
def QueryVersion(self, client_major_version, client_minor_version, is_checked=True):
buf = six.BytesIO()
buf.write(struct.pack("=xx2xII", client_major_version, client_minor_version))
return self.send_request(0, buf, QueryVersionCookie, is_checked=is_checked)
def Create(self, damage, drawable, level, is_checked=False):
buf = six.BytesIO()
buf.write(struct.pack("=xx2xIIB3x", damage, drawable, level))
return self.send_request(1, buf, is_checked=is_checked)
def Destroy(self, damage, is_checked=False):
buf = six.BytesIO()
buf.write(struct.pack("=xx2xI", damage))
return self.send_request(2, buf, is_checked=is_checked)
def Subtract(self, damage, repair, parts, is_checked=False):
buf = six.BytesIO()
buf.write(struct.pack("=xx2xIII", damage, repair, parts))
return self.send_request(3, buf, is_checked=is_checked)
def Add(self, drawable, region, is_checked=False):
buf = six.BytesIO()
buf.write(struct.pack("=xx2xII", drawable, region))
return self.send_request(4, buf, is_checked=is_checked)
xcffib._add_ext(key, damageExtension, _events, _errors)
|