| /* |
| * TTY bitmap driver |
| * |
| * Copyright 1999 Patrik Stridvall |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2.1 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| */ |
| |
| #include "config.h" |
| |
| #include <string.h> |
| |
| #include "bitmap.h" |
| #include "gdi.h" |
| #include "ttydrv.h" |
| #include "winbase.h" |
| #include "wine/debug.h" |
| |
| WINE_DEFAULT_DEBUG_CHANNEL(ttydrv); |
| |
| /**********************************************************************/ |
| |
| extern const DC_FUNCTIONS *TTYDRV_DC_Funcs; /* hack */ |
| |
| static LONG TTYDRV_DC_GetBitmapBits(BITMAPOBJ *bitmap, void *bits, LONG count); |
| static LONG TTYDRV_DC_SetBitmapBits(BITMAPOBJ *bitmap, void *bits, LONG count); |
| |
| /*********************************************************************** |
| * TTYDRV_DC_AllocBitmap |
| */ |
| TTYDRV_PHYSBITMAP *TTYDRV_DC_AllocBitmap(BITMAPOBJ *bitmap) |
| { |
| TTYDRV_PHYSBITMAP *physBitmap; |
| |
| if(!(physBitmap = HeapAlloc(GetProcessHeap(), 0, sizeof(TTYDRV_PHYSBITMAP)))) { |
| ERR("Can't alloc TTYDRV_PHYSBITMAP\n"); |
| return NULL; |
| } |
| |
| bitmap->physBitmap = physBitmap; |
| bitmap->funcs = TTYDRV_DC_Funcs; |
| |
| return physBitmap; |
| } |
| |
| /*********************************************************************** |
| * TTYDRV_DC_BitmapBits |
| */ |
| LONG TTYDRV_DC_BitmapBits(HBITMAP hbitmap, void *bits, LONG count, WORD flags) |
| { |
| BITMAPOBJ *bitmap; |
| LONG result; |
| |
| if(!(bitmap = (BITMAPOBJ *) GDI_GetObjPtr(hbitmap, BITMAP_MAGIC))) |
| return FALSE; |
| |
| if(flags == DDB_GET) |
| result = TTYDRV_DC_GetBitmapBits(bitmap, bits, count); |
| else if(flags == DDB_SET) |
| result = TTYDRV_DC_SetBitmapBits(bitmap, bits, count); |
| else { |
| ERR("Unknown flags value %d\n", flags); |
| result = 0; |
| } |
| |
| GDI_ReleaseObj(hbitmap); |
| return result; |
| } |
| |
| /*********************************************************************** |
| * TTYDRV_DC_CreateBitmap |
| */ |
| BOOL TTYDRV_DC_CreateBitmap(HBITMAP hbitmap) |
| { |
| TTYDRV_PHYSBITMAP *physBitmap; |
| BITMAPOBJ *bitmap; |
| |
| TRACE("(0x%04x)\n", hbitmap); |
| |
| if(!(bitmap = (BITMAPOBJ *) GDI_GetObjPtr(hbitmap, BITMAP_MAGIC))) |
| return FALSE; |
| |
| if(!(physBitmap = TTYDRV_DC_AllocBitmap(bitmap))) { |
| GDI_ReleaseObj(hbitmap); |
| return FALSE; |
| } |
| |
| /* Set bitmap bits */ |
| if(bitmap->bitmap.bmBits) { |
| TTYDRV_DC_BitmapBits(hbitmap, bitmap->bitmap.bmBits, |
| bitmap->bitmap.bmHeight * bitmap->bitmap.bmWidthBytes, |
| DDB_SET ); |
| } |
| |
| GDI_ReleaseObj(hbitmap); |
| |
| return TRUE; |
| } |
| |
| /*********************************************************************** |
| * TTYDRV_DC_BITMAP_DeleteObject |
| */ |
| BOOL TTYDRV_DC_BITMAP_DeleteObject(HBITMAP hbitmap, BITMAPOBJ *bitmap) |
| { |
| TRACE("(0x%04x, %p)\n", hbitmap, bitmap); |
| |
| HeapFree(GetProcessHeap(), 0, bitmap->physBitmap); |
| bitmap->physBitmap = NULL; |
| bitmap->funcs = NULL; |
| |
| return TRUE; |
| } |
| |
| /*********************************************************************** |
| * TTYDRV_DC_GetBitmapBits |
| */ |
| static LONG TTYDRV_DC_GetBitmapBits(BITMAPOBJ *bitmap, void *bits, LONG count) |
| { |
| FIXME("(%p, %p, %ld): stub\n", bitmap, bits, count); |
| |
| memset(bits, 0, count); |
| |
| return count; |
| } |
| |
| /*********************************************************************** |
| * SelectBitmap (TTYDRV.@) |
| */ |
| HBITMAP TTYDRV_SelectBitmap(TTYDRV_PDEVICE *physDev, HBITMAP hbitmap) |
| { |
| DC *dc = physDev->dc; |
| BITMAPOBJ *bitmap; |
| |
| TRACE("(%p, 0x%04x)\n", dc, hbitmap); |
| |
| if (!(bitmap = GDI_GetObjPtr( hbitmap, BITMAP_MAGIC ))) return 0; |
| /* Assure that the bitmap device dependent */ |
| if(!bitmap->physBitmap && !TTYDRV_DC_CreateBitmap(hbitmap)) |
| { |
| GDI_ReleaseObj( hbitmap ); |
| return 0; |
| } |
| |
| if(bitmap->funcs != dc->funcs) { |
| ERR("Trying to select a non-TTY DDB into a TTY DC\n"); |
| GDI_ReleaseObj( hbitmap ); |
| return 0; |
| } |
| |
| GDI_ReleaseObj( hbitmap ); |
| return hbitmap; |
| } |
| |
| /*********************************************************************** |
| * TTYDRV_DC_SetBitmapBits |
| */ |
| static LONG TTYDRV_DC_SetBitmapBits(BITMAPOBJ *bitmap, void *bits, LONG count) |
| { |
| FIXME("(%p, %p, %ld): semistub\n", bitmap, bits, count); |
| |
| return count; |
| } |
| |
| /*********************************************************************** |
| * TTYDRV_BITMAP_CreateDIBSection |
| */ |
| HBITMAP TTYDRV_BITMAP_CreateDIBSection( |
| TTYDRV_PDEVICE *physDev, BITMAPINFO *bmi, UINT usage, |
| LPVOID *bits, HANDLE section, DWORD offset) |
| { |
| FIXME("(%x, %p, %u, %p, 0x%04x, %ld): stub\n", |
| physDev->hdc, bmi, usage, bits, section, offset); |
| |
| return (HBITMAP) NULL; |
| } |
| |
| /*********************************************************************** |
| * TTYDRV_DC_SetDIBitsToDevice |
| */ |
| INT TTYDRV_DC_SetDIBitsToDevice(TTYDRV_PDEVICE *physDev, INT xDest, INT yDest, DWORD cx, |
| DWORD cy, INT xSrc, INT ySrc, |
| UINT startscan, UINT lines, LPCVOID bits, |
| const BITMAPINFO *info, UINT coloruse) |
| { |
| FIXME("(%x, %d, %d, %ld, %ld, %d, %d, %u, %u, %p, %p, %u): stub\n", |
| physDev->hdc, xDest, yDest, cx, cy, xSrc, ySrc, startscan, lines, bits, info, coloruse); |
| |
| return 0; |
| } |