Tue Jun 7 08:41:27 1994 Bob Amstadt (bob@pooh) * loader/selector.c (FixupFunctionPrologs): New function to fixup loaded DLL function prologs. It replaces the do nothing code with code that loads DS with the appropriate data segment for the DLL. * misc/cursor.c (LoadCursor): Disabled cursor loading from .EXE or .DLL. The code needs to handle the possibility of multiple cursors in a single directory. Also, it should check to see if the cursor is the right size. * objects/font.c (EnumFonts): Checked for lpLogFontList[i] == NULL * objects/gdiobj.c (SetObjectOwner): Removed stub. Replaced with simple return in gdi.spec. This function is not defined for the retail version of Windows. * memory/heap.c (WIN16_LocalHandleDelta): New function. This is really a dummy that imitates the proper return values. * loader/library.c (GetProcAddress): Fixed definition of IS_BUILTIN_DLL() macro. Mon Jun 6 18:15:40 1994 Bob Amstadt (bob@pooh) * miscemu/int21.c (SeekFile): Needed to return current position in DX:AX. * windows/utility.c (windows_wsprintf): Added support for '#' in format, and fixed bug with "ptr" being incremented too many times. * miscemu/int21.c (OpenExistingFile): Add code to handle opening files read-only and write-only. * loader/wine.c: Segment fixups now done in LoadImage instead of _WinMain. This is necessary to support LoadLibrary(). Sun Jun 5 17:34:24 1994 Erik Bos (erik@hacktic.nl) * [loader/*] - fixed: GetModuleHandle() sometimes returned a wrong handle. - don't init dlls when cs == 0 (lzexpand, doesn't seem to have a init function) - LoadLibrary & LoadImage now return error instead of stopping wine. - moved most of NE-functions into one file. - LoadLibrary() uses w_files list instead of its own list. - NE exectables are now fixed-up and initialised when loaded instead of only once before calling InitTask. * [miscemu/int15.c] [miscemu/int31.c] Added. * [loader/selector.c] Stubs added for {Get|Set}SelectorLimit(), {Get|Set}SelectorBase(). * [misc/main.c] Stub added for IsRomModule(). * [miscemu/int21.c] Some cleanup, added heap for returning data. Jun 6, 94 martin2@trgcorp.solucorp.qc.ca (Martin Ayotte) * [tools/build.c] Change MAX_ORDINALS define to higher value, 1299 entries. (MMSYSTEM doesn't have succesive numbers, some are around 1200). * [windows/utility.c] Bug fix in windows_wsprintf(), (twice increments ...). * [windows/winpos.c] Bug fix in SetWindowPos(), redraw was done if flag was set to SWP_NOREDRAW while SWP_SHOWWINDOW). * [misc/message.c] [controls/combo.c] Add an InvalidateRect() in WM_SHOWWINDOW to statisfy the new 'saveunder'. * [windows/win.c] In CreateWindowEx(), do SetMenu() calls after window creation, just before sending to WM_NCCALCSIZE. * [controls/menu.c] In function SetMenu(), now use SetWindowPos() with flags SWP_FRAMECHANGED to readjust menu area. Function MenuBarCalcSize() redone. Sun May 29 11:08:24 1994 David B. Thomas (dt@yenta.abq.nm.us) * [objects/text.c] Fixed problems associated with DT_WORDBREAK flag. String length was not being properly decremented when lines were folded, and wrapping was not performed when DT_NOCLIP and DT_NOPREFIX were both on in addition to DT_WORDBREAK. Windows does wrapping in this case, and now so does wine. Sun Jun 5 19:17:49 1994 Olaf Flebbe (olaf@dragon) * [edit.c] cp1 was uninitialized iff lineno == 0 * FindFile tests for existance of file even if a full filename was supplied. What about unix file names? * [controls/listbox ] wndPtr was uninitialized for LB_SETTOPINDEX * [misc/property.c] Do not free lpProp. Is it really allocated by malloc? {edited by Bob Amstadt: changed free() to GlobalFree()}
182 lines
4.9 KiB
C
182 lines
4.9 KiB
C
/*
|
|
* Wine Drivers functions
|
|
*
|
|
* Copyright 1994 Martin Ayotte
|
|
*/
|
|
|
|
static char Copyright[] = "Copyright Martin Ayotte, 1994";
|
|
|
|
#include <stdio.h>
|
|
#include "windows.h"
|
|
#include "win.h"
|
|
#include "user.h"
|
|
#include "dlls.h"
|
|
#include "driver.h"
|
|
|
|
LPDRIVERITEM lpDrvItemList = NULL;
|
|
|
|
/**************************************************************************
|
|
* SendDriverMessage [USER.251]
|
|
*/
|
|
LRESULT WINAPI SendDriverMessage(HDRVR hDriver, WORD msg, LPARAM lParam1, LPARAM lParam2)
|
|
{
|
|
printf("SendDriverMessage(%04X, %04X, %08X, %08X);\n",
|
|
hDriver, msg, lParam1, lParam2);
|
|
}
|
|
|
|
/**************************************************************************
|
|
* OpenDriver [USER.252]
|
|
*/
|
|
HDRVR OpenDriver(LPSTR lpDriverName, LPSTR lpSectionName, LPARAM lParam)
|
|
{
|
|
HDRVR hDrvr;
|
|
LPDRIVERITEM lpnewdrv;
|
|
LPDRIVERITEM lpdrv = lpDrvItemList;
|
|
char DrvName[128];
|
|
printf("OpenDriver('%s', '%s', %08X);\n",
|
|
lpDriverName, lpSectionName, lParam);
|
|
if (lpSectionName == NULL) lpSectionName = "drivers";
|
|
GetPrivateProfileString(lpSectionName, lpDriverName,
|
|
"", DrvName, sizeof(DrvName), "SYSTEM.INI");
|
|
printf("OpenDriver // DrvName='%s'\n", DrvName);
|
|
if (strlen(DrvName) < 1) return 0;
|
|
while (lpdrv != NULL) {
|
|
if (lpdrv->lpNextItem == NULL) break;
|
|
lpdrv = lpdrv->lpNextItem;
|
|
}
|
|
hDrvr = GlobalAlloc(GMEM_MOVEABLE, sizeof(DRIVERITEM));
|
|
lpnewdrv = (LPDRIVERITEM) GlobalLock(hDrvr);
|
|
if (lpnewdrv == NULL) return 0;
|
|
lpnewdrv->dis.length = sizeof(DRIVERINFOSTRUCT);
|
|
lpnewdrv->dis.hModule = LoadImage("DrvName", DLL, 0);
|
|
if (lpnewdrv->dis.hModule == 0) {
|
|
GlobalUnlock(hDrvr);
|
|
GlobalFree(hDrvr);
|
|
return 0;
|
|
}
|
|
lpnewdrv->dis.hDriver = hDrvr;
|
|
strcpy(lpnewdrv->dis.szAliasName, lpDriverName);
|
|
lpnewdrv->count = 0;
|
|
lpnewdrv->lpNextItem = NULL;
|
|
if (lpDrvItemList == NULL || lpdrv == NULL) {
|
|
lpDrvItemList = lpnewdrv;
|
|
lpnewdrv->lpPrevItem = NULL;
|
|
}
|
|
else {
|
|
lpdrv->lpNextItem = lpnewdrv;
|
|
lpnewdrv->lpPrevItem = lpdrv;
|
|
}
|
|
lpnewdrv->lpDrvProc = NULL;
|
|
printf("OpenDriver // hDrvr=%04X loaded !\n", hDrvr);
|
|
return hDrvr;
|
|
}
|
|
|
|
/**************************************************************************
|
|
* CloseDriver [USER.253]
|
|
*/
|
|
LRESULT CloseDriver(HDRVR hDrvr, LPARAM lParam1, LPARAM lParam2)
|
|
{
|
|
LPDRIVERITEM lpdrv;
|
|
printf("CloseDriver(%04X, %08X, %08X);\n", hDrvr, lParam1, lParam2);
|
|
lpdrv = (LPDRIVERITEM) GlobalLock(hDrvr);
|
|
if (lpdrv != NULL && lpdrv->dis.hDriver == hDrvr) {
|
|
if (lpdrv->lpPrevItem)
|
|
((LPDRIVERITEM)lpdrv->lpPrevItem)->lpNextItem = lpdrv->lpNextItem;
|
|
if (lpdrv->lpNextItem)
|
|
((LPDRIVERITEM)lpdrv->lpNextItem)->lpPrevItem = lpdrv->lpPrevItem;
|
|
GlobalUnlock(hDrvr);
|
|
GlobalFree(hDrvr);
|
|
printf("CloseDriver // hDrvr=%04X closed !\n", hDrvr);
|
|
return TRUE;
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
/**************************************************************************
|
|
* GetDriverModuleHandle [USER.254]
|
|
*/
|
|
HANDLE GetDriverModuleHandle(HDRVR hDrvr)
|
|
{
|
|
LPDRIVERITEM lpdrv;
|
|
HANDLE hModule = 0;
|
|
printf("GetDriverModuleHandle(%04X);\n", hDrvr);
|
|
lpdrv = (LPDRIVERITEM) GlobalLock(hDrvr);
|
|
if (lpdrv != NULL) {
|
|
hModule = lpdrv->dis.hModule;
|
|
GlobalUnlock(hDrvr);
|
|
}
|
|
return hModule;
|
|
}
|
|
|
|
/**************************************************************************
|
|
* DefDriverProc [USER.255]
|
|
*/
|
|
LRESULT DefDriverProc(DWORD dwDevID, HDRVR hDriv, WORD wMsg,
|
|
DWORD dwParam1, DWORD dwParam2)
|
|
{
|
|
switch(wMsg) {
|
|
case DRV_LOAD:
|
|
return (LRESULT)0L;
|
|
case DRV_FREE:
|
|
return (LRESULT)0L;
|
|
case DRV_OPEN:
|
|
return (LRESULT)0L;
|
|
case DRV_CLOSE:
|
|
return (LRESULT)0L;
|
|
case DRV_ENABLE:
|
|
return (LRESULT)0L;
|
|
case DRV_DISABLE:
|
|
return (LRESULT)0L;
|
|
case DRV_QUERYCONFIGURE:
|
|
return (LRESULT)0L;
|
|
case DRV_CONFIGURE:
|
|
MessageBox((HWND)NULL, "Driver isn't configurable !",
|
|
"Wine Driver", MB_OK);
|
|
return (LRESULT)0L;
|
|
case DRV_INSTALL:
|
|
return (LRESULT)DRVCNF_RESTART;
|
|
case DRV_REMOVE:
|
|
return (LRESULT)DRVCNF_RESTART;
|
|
default:
|
|
return (LRESULT)0L;
|
|
}
|
|
}
|
|
|
|
/**************************************************************************
|
|
* GetDriverInfo [USER.256]
|
|
*/
|
|
BOOL GetDriverInfo(HDRVR hDrvr, LPDRIVERINFOSTRUCT lpDrvInfo)
|
|
{
|
|
LPDRIVERITEM lpdrv;
|
|
printf("GetDriverInfo(%04X, %08X);\n", hDrvr, lpDrvInfo);
|
|
if (lpDrvInfo == NULL) return FALSE;
|
|
lpdrv = (LPDRIVERITEM) GlobalLock(hDrvr);
|
|
if (lpdrv == NULL) return FALSE;
|
|
memcpy(lpDrvInfo, &lpdrv->dis, sizeof(DRIVERINFOSTRUCT));
|
|
GlobalUnlock(hDrvr);
|
|
return TRUE;
|
|
}
|
|
|
|
/**************************************************************************
|
|
* GetNextDriver [USER.257]
|
|
*/
|
|
HDRVR GetNextDriver(HDRVR hDrvr, DWORD dwFlags)
|
|
{
|
|
LPDRIVERITEM lpdrv;
|
|
HDRVR hRetDrv = 0;
|
|
printf("GetNextDriver(%04X, %08X);\n", hDrvr, dwFlags);
|
|
lpdrv = (LPDRIVERITEM) GlobalLock(hDrvr);
|
|
if (lpdrv != NULL) {
|
|
if (dwFlags & GND_REVERSE)
|
|
if (lpdrv->lpPrevItem)
|
|
hRetDrv = ((LPDRIVERITEM)lpdrv->lpPrevItem)->dis.hDriver;
|
|
if (dwFlags & GND_FORWARD)
|
|
if (lpdrv->lpNextItem)
|
|
hRetDrv = ((LPDRIVERITEM)lpdrv->lpNextItem)->dis.hDriver;
|
|
GlobalUnlock(hDrvr);
|
|
}
|
|
return hRetDrv;
|
|
|
|
}
|
|
|
|
|