#if DIRECT3D_VERSION >= 0x0900
-static inline size_t
-_getLockSize(IDirect3DVertexBuffer9 *pBuffer, UINT OffsetToLock, UINT SizeToLock, void ** ppbData) {
+static inline void
+_getLockInfo(IDirect3DVertexBuffer9 *pBuffer, UINT OffsetToLock, UINT SizeToLock, void ** ppbData,
+ void * & pLockedData, size_t & LockedSize) {
+ pLockedData = *ppbData;
+ LockedSize = 0;
+
if (SizeToLock == 0) {
D3DVERTEXBUFFER_DESC Desc;
HRESULT hr = pBuffer->GetDesc(&Desc);
if (FAILED(hr)) {
- return 0;
- }
- SizeToLock = Desc.Size;
+ return;
+ }
+ LockedSize = Desc.Size;
+ } else {
+ LockedSize = SizeToLock;
}
-
- return SizeToLock;
}
-static inline size_t
-_getLockSize(IDirect3DIndexBuffer9 *pBuffer, UINT OffsetToLock, UINT SizeToLock, void ** ppbData) {
+static inline void
+_getLockInfo(IDirect3DIndexBuffer9 *pBuffer, UINT OffsetToLock, UINT SizeToLock, void ** ppbData,
+ void * & pLockedData, size_t & LockedSize) {
+ pLockedData = *ppbData;
+ LockedSize = 0;
+
if (SizeToLock == 0) {
D3DINDEXBUFFER_DESC Desc;
HRESULT hr = pBuffer->GetDesc(&Desc);
if (FAILED(hr)) {
- return 0;
- }
- SizeToLock = Desc.Size;
+ return;
+ }
+ LockedSize = Desc.Size;
+ } else {
+ LockedSize = SizeToLock;
}
-
- return SizeToLock;
}
-static inline size_t
-_getLockSize(IDirect3DSurface9 *pSurface, const D3DLOCKED_RECT *pLockedRect, const RECT *pRect) {
+static inline void
+_getLockInfo(IDirect3DSurface9 *pSurface, const D3DLOCKED_RECT *pLockedRect, const RECT *pRect,
+ void * & pLockedData, size_t & LockedSize) {
+ pLockedData = pLockedRect->pBits;
+ LockedSize = 0;
+
HRESULT hr;
D3DSURFACE_DESC Desc;
hr = pSurface->GetDesc(&Desc);
if (FAILED(hr)) {
- return 0;
- }
+ return;
+ }
UINT Width;
UINT Height;
Height = Desc.Height;
}
- return _getLockSize(Desc.Format, Width, Height, pLockedRect->Pitch);
+ LockedSize = _getLockSize(Desc.Format, Width, Height, pLockedRect->Pitch);
}
-static inline size_t
-_getLockSize(IDirect3DTexture9 *pTexture, UINT Level, const D3DLOCKED_RECT *pLockedRect, const RECT *pRect) {
+static inline void
+_getLockInfo(IDirect3DTexture9 *pTexture, UINT Level, const D3DLOCKED_RECT *pLockedRect, const RECT *pRect,
+ void * & pLockedData, size_t & LockedSize) {
+ pLockedData = pLockedRect->pBits;
+ LockedSize = 0;
+
HRESULT hr;
D3DSURFACE_DESC Desc;
hr = pTexture->GetLevelDesc(Level, &Desc);
if (FAILED(hr)) {
- return 0;
+ return;
}
UINT Width;
Height = Desc.Height;
}
- return _getLockSize(Desc.Format, Width, Height, pLockedRect->Pitch);
+ LockedSize = _getLockSize(Desc.Format, Width, Height, pLockedRect->Pitch);
}
-static inline size_t
-_getLockSize(IDirect3DCubeTexture9 *pTexture, D3DCUBEMAP_FACES FaceType, UINT Level, const D3DLOCKED_RECT *pLockedRect, const RECT *pRect) {
+static inline void
+_getLockInfo(IDirect3DCubeTexture9 *pTexture, D3DCUBEMAP_FACES FaceType, UINT Level, const D3DLOCKED_RECT *pLockedRect, const RECT *pRect,
+ void * & pLockedData, size_t & LockedSize) {
+ pLockedData = pLockedRect->pBits;
+ LockedSize = 0;
+
HRESULT hr;
(void)FaceType;
D3DSURFACE_DESC Desc;
hr = pTexture->GetLevelDesc(Level, &Desc);
if (FAILED(hr)) {
- return 0;
+ return;
}
UINT Width;
Height = Desc.Height;
}
- return _getLockSize(Desc.Format, Width, Height, pLockedRect->Pitch);
+ LockedSize = _getLockSize(Desc.Format, Width, Height, pLockedRect->Pitch);
}
-static inline size_t
-_getLockSize(IDirect3DVolume9 *pVolume, const D3DLOCKED_BOX *pLockedVolume, const D3DBOX *pBox) {
+static inline void
+_getLockInfo(IDirect3DVolume9 *pVolume, const D3DLOCKED_BOX *pLockedVolume, const D3DBOX *pBox,
+ void * & pLockedData, size_t & LockedSize) {
+ pLockedData = pLockedVolume->pBits;
+ LockedSize = 0;
+
HRESULT hr;
D3DVOLUME_DESC Desc;
hr = pVolume->GetDesc(&Desc);
if (FAILED(hr)) {
- return 0;
+ return;
}
UINT Width;
Depth = Desc.Depth;
}
- return _getLockSize(Desc.Format, Width, Height, pLockedVolume->RowPitch, Depth, pLockedVolume->SlicePitch);
+ LockedSize = _getLockSize(Desc.Format, Width, Height, pLockedVolume->RowPitch, Depth, pLockedVolume->SlicePitch);
}
-static inline size_t
-_getLockSize(IDirect3DVolumeTexture9 *pTexture, UINT Level, const D3DLOCKED_BOX *pLockedVolume, const D3DBOX *pBox) {
+static inline void
+_getLockInfo(IDirect3DVolumeTexture9 *pTexture, UINT Level, const D3DLOCKED_BOX *pLockedVolume, const D3DBOX *pBox,
+ void * & pLockedData, size_t & LockedSize) {
+ pLockedData = pLockedVolume->pBits;
+ LockedSize = 0;
+
HRESULT hr;
D3DVOLUME_DESC Desc;
hr = pTexture->GetLevelDesc(Level, &Desc);
if (FAILED(hr)) {
- return 0;
+ return;
}
UINT Width;
Depth = Desc.Depth;
}
- return _getLockSize(Desc.Format, Width, Height, pLockedVolume->RowPitch, Depth, pLockedVolume->SlicePitch);
+ LockedSize = _getLockSize(Desc.Format, Width, Height, pLockedVolume->RowPitch, Depth, pLockedVolume->SlicePitch);
}
print r' }'
if method.name in ('Lock', 'LockRect', 'LockBox'):
- print ' size_t _LockedSize = _getLockSize(_this, %s);' % ', '.join(method.argNames()[:-1])
- if method.name == 'Lock':
- # FIXME: handle recursive locks
- print ' VOID *_pbData = *ppbData;'
- elif method.name == 'LockRect':
- print ' VOID *_pbData = pLockedRect->pBits;'
- elif method.name == 'LockBox':
- print ' VOID *_pbData = pLockedVolume->pBits;'
- else:
- raise NotImplementedError
- print ' _this->SetPrivateData(GUID_APITRACE, &_pbData, sizeof _pbData, 0);'
+ print ' VOID *_pbData = NULL;'
+ print ' size_t _LockedSize = 0;'
+ print ' _getLockInfo(_this, %s, _pbData, _LockedSize);' % ', '.join(method.argNames()[:-1])
+ print ' _this->SetPrivateData(GUID_APITRACE, &_pbData, sizeof _pbData, 0);'
if method.name in ('Unlock', 'UnlockRect', 'UnlockBox'):
- print ' VOID *_pbData = 0;'
- print ' DWORD dwSizeOfData = sizeof _pbData;'
- print ' _this->GetPrivateData(GUID_APITRACE, &_pbData, &dwSizeOfData);'
- print ' if (_pbData) {'
- print ' retrace::delRegionByPointer(_pbData);'
- print ' }'
+ print ' VOID *_pbData = 0;'
+ print ' DWORD dwSizeOfData = sizeof _pbData;'
+ print ' _this->GetPrivateData(GUID_APITRACE, &_pbData, &dwSizeOfData);'
+ print ' if (_pbData) {'
+ print ' retrace::delRegionByPointer(_pbData);'
+ print ' }'
if __name__ == '__main__':
DllTracer.implementWrapperInterfaceMethodBody(self, interface, base, method)
if method.name in ('Lock', 'LockRect', 'LockBox'):
+ # FIXME: handle recursive locks
print ' if (SUCCEEDED(_result) && !(Flags & D3DLOCK_READONLY)) {'
- print ' _LockedSize = _getLockSize(_this, %s);' % ', '.join(method.argNames()[:-1])
- if method.name == 'Lock':
- # FIXME: handle recursive locks
- print ' m_pbData = *ppbData;'
- elif method.name == 'LockRect':
- print ' m_pbData = pLockedRect->pBits;'
- elif method.name == 'LockBox':
- print ' m_pbData = pLockedVolume->pBits;'
- else:
- raise NotImplementedError
+ print ' _getLockInfo(_this, %s, m_pbData, _LockedSize);' % ', '.join(method.argNames()[:-1])
print ' } else {'
print ' m_pbData = NULL;'
+ print ' _LockedSize = 0;'
print ' }'