Wed Jul 5 19:06:35 1995 Alexandre Julliard <julliard@sunsite.unc.edu> * [controls/scroll.c] Fixed drawing bug that caused part of a non-client scroll bar to be painted even when the scroll-bar was hidden. * [debugger/break.c] [debugger/dbg.y] Rewrote breakpoint handling to work in 16-bit mode. Implemented single-stepping ('step' and 'next' instructions). * [debugger/debug.l] Format specifier is now a separate token. Entering an empty line at the debugger prompt causes the previous command to be repeated, like under gdb. * [debugger/debug.l] [debugger/registers.c] Differentiate 16-bit and 32-bit registers without taking current mode into account ($eax is always 32-bit, $ax always 16-bit). * [debugger/stack.c] Fixed stack information routines to differentiate between 16-bit and 32-bit stacks. * [loader/task.c] Option -debug now sets a breakpoint at the first instruction of every loaded task. * [miscemu/instr.c] Added handling of lock, repe and repne prefixes. * [objects/dib.c] Changed StretchDIBits() to do the correct thing, even if it's still not really optimal. * [windows/graphics.c] Fixes in RoundRect(), thanks to Babak Masalehdan. * [windows/message.c] Tried to fix mouse event handling with respect to disabled windows. * [windows/painting.c] Clear WIN_NEEDS_NCPAINT flag before sending WM_NCPAINT to avoid infinite loops. * [windows/win.c] Fixed IsWindowVisible() to return FALSE when one of the parent windows is hidden. Sat Jul 1 22:08:21 1995 Martin von Loewis <loewis@informatik.hu-berlin.de> * [if1632/compobj.spec][misc/compobj.c] CoGetMalloc: New function Added relay entries for COMPOBJ ordinals above 100 CoInitialize: Changed parameter to DWORD * [if1632/ole2.spec] Exported implementation of OleBuildVersion * [if1632/ole2disp.spec][misc/ole2disp.c][misc/Imakefile] ole2disp.c: New file SysAllocString, SysReallocString, SysAllocStringLen, SysReAllocStringLen, SysFreeString, SysStringLen: new functions * [if1632/ole2nls.spec][include/winnls.h][misc/ole2nls.c] CompareStringA: New function Thu Jun 29 19:42:02 1995 Marcus Meissner <msmeissn@faui01.informatik.uni-erlangen.de> * [objects/font.c] [if1632/gdi.spec] New stubs for CreateScalableFontResource, GetGlyphOutline. Thu Jun 29 13:47:08 GMT 1995 Göran Thyni (goran@norrsken.bildbasen.se) * [misc/commdlg.c] Extensive changes and bug fixes to FileDialog handling, behaves more like native Windows. Wed Jun 28 13:04:44 1995 Bernd Schmidt <crux@pool.informatik.rwth-aachen.de> * [controls/listbox.c] [controls/combo.c] Some minor optimizations. * [memory/local.c] LOCAL_FindFreeBlock(): Never use the last one. * [memory/global.c] GlobalReAlloc(): GMEM_MODIFY must not be ignored when size==0. * [misc/file.c] read() returns an error when length==0. This is not what Windows programs expect, so pay attention to this in _lread(). Changed this in _lwrite(), _hread(), _hwrite(), too. * [loader/resource.c] LoadIcon(): Ignore bih->biSizeImage, some icons have wrong values in there. * [if1632/shell.spec] [misc/shell.c] Wrong spec file entries caused havoc: HKEY has 32 bit, not 16. Accept some more combinations of parameters in the Reg..() functions. * [if1632/toolhelp.spec] Make InterruptRegister() and InterruptUnregister() return false. * [windows/hook.c] CallNextHookEx() used to crash when called with a null hhook. Fixed. Wed Jun 28 10:14:34 1995 Martin von Loewis <martin@informatik.hu-berlin.de> * [include/neexe.h][loader/ne_image.c] NE_LoadSegment: Detect iterated segments * [misc/ole2nls.c] LOCALE_SLONGDATE: fixed typo * [miscemu/int5c.c] Reordered include files to avoid conflicts with Linux libc.5.1 * [rc/winerc.c] Added -b option to process binary resource files into C arrays * [include/callback.h] CallWndProc: Added dummy ds parameter for libwine * [include/gdi.h][include/user.h] USER_HEAP_ALLOC, GDI_HEAP_ALLOC: dropped flags parameter * [include/ldt.h][include/stackframe.h] defined segment conversion macros for libwine * [misc/atom.c] Defined USER_HeapSel for libwine * [misc/main.c] Disable -dll option for libwine * [misc/user.c] removed GetFreeSystemResources, SystemHeapInfo from libwine for now * [toolkit/heap.c] fixed LocalLock prototype * [toolkit/sup.c] sync'ed load_mz_header, load_ne_header with structures * [toolkit/winmain.c] Disabled resource DLLs for libwine for now Mon Jun 26 19:30:24 1995 Hans de Graaff (graaff@twi72.twi.tudelft.nl) * [misc/main.c] Fixed -enhanced option to report a 386 CPU instead of a 286. Fri Jun 23 23:18:25 1995 Marcus Meissner <msmeissn@faui01.informatik.uni-erlangen.de> * [misc/dos_fs.c] Remove maximum open dosdirent limit (fixing the winfile.exe problem) by using telldir()/seekdir(). Fri Jun 23 13:42:25 1995 Hans de Graaff (graaff@twi72.twi.tudelft.nl) * [misc/profile.c] Fixed problem parsing empty lines within sections in .ini files.
502 lines
15 KiB
C
502 lines
15 KiB
C
/*
|
|
* Shell Library Functions
|
|
*/
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <unistd.h>
|
|
#include "windows.h"
|
|
#include "shell.h"
|
|
#include "neexe.h"
|
|
#include "selectors.h"
|
|
#include "../rc/sysres.h"
|
|
#include "dlgs.h"
|
|
#include "dialog.h"
|
|
#include "stddebug.h"
|
|
#include "debug.h"
|
|
|
|
LPKEYSTRUCT lphRootKey = NULL,lphTopKey = NULL;
|
|
|
|
static char RootKeyName[]=".classes", TopKeyName[] = "(null)";
|
|
|
|
/*************************************************************************
|
|
* SHELL_RegCheckForRoot() internal use only
|
|
*/
|
|
static LONG SHELL_RegCheckForRoot()
|
|
{
|
|
HKEY hNewKey;
|
|
|
|
if (lphRootKey == NULL){
|
|
hNewKey = GlobalAlloc(GMEM_MOVEABLE,sizeof(KEYSTRUCT));
|
|
lphRootKey = (LPKEYSTRUCT) GlobalLock(hNewKey);
|
|
if (lphRootKey == NULL) {
|
|
printf("SHELL_RegCheckForRoot: Couldn't allocate root key!\n");
|
|
return ERROR_OUTOFMEMORY;
|
|
}
|
|
lphRootKey->hKey = 1;
|
|
lphRootKey->lpSubKey = RootKeyName;
|
|
lphRootKey->dwType = 0;
|
|
lphRootKey->lpValue = NULL;
|
|
lphRootKey->lpSubLvl = lphRootKey->lpNextKey = lphRootKey->lpPrevKey = NULL;
|
|
|
|
hNewKey = GlobalAlloc(GMEM_MOVEABLE,sizeof(KEYSTRUCT));
|
|
lphTopKey = (LPKEYSTRUCT) GlobalLock(hNewKey);
|
|
if (lphTopKey == NULL) {
|
|
printf("SHELL_RegCheckForRoot: Couldn't allocate top key!\n");
|
|
return ERROR_OUTOFMEMORY;
|
|
}
|
|
lphTopKey->hKey = 0;
|
|
lphTopKey->lpSubKey = TopKeyName;
|
|
lphTopKey->dwType = 0;
|
|
lphTopKey->lpValue = NULL;
|
|
lphTopKey->lpSubLvl = lphRootKey;
|
|
lphTopKey->lpNextKey = lphTopKey->lpPrevKey = NULL;
|
|
|
|
dprintf_reg(stddeb,"SHELL_RegCheckForRoot: Root/Top created\n");
|
|
}
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* RegOpenKey [SHELL.1]
|
|
*/
|
|
LONG RegOpenKey(HKEY hKey, LPCSTR lpSubKey, HKEY FAR *lphKey)
|
|
{
|
|
LPKEYSTRUCT lpKey;
|
|
LPCSTR ptr;
|
|
char str[128];
|
|
LONG dwRet;
|
|
|
|
dwRet = SHELL_RegCheckForRoot();
|
|
if (dwRet != ERROR_SUCCESS) return dwRet;
|
|
dprintf_reg(stddeb, "RegOpenKey(%08lX, %p='%s', %p)\n",
|
|
hKey, lpSubKey, lpSubKey, lphKey);
|
|
if (lpSubKey == NULL) return ERROR_INVALID_PARAMETER;
|
|
if (lphKey == NULL) return ERROR_INVALID_PARAMETER;
|
|
switch(hKey) {
|
|
case 0:
|
|
lpKey = lphTopKey; break;
|
|
case HKEY_CLASSES_ROOT: /* == 1 */
|
|
lpKey = lphRootKey; break;
|
|
default:
|
|
dprintf_reg(stddeb,"RegOpenKey // specific key = %08lX !\n", hKey);
|
|
lpKey = (LPKEYSTRUCT)GlobalLock(hKey);
|
|
}
|
|
if (!*lpSubKey) { *lphKey = hKey; return ERROR_SUCCESS; }
|
|
while(*lpSubKey) {
|
|
ptr = strchr(lpSubKey,'\\');
|
|
if (!ptr) ptr = lpSubKey + strlen(lpSubKey);
|
|
strncpy(str,lpSubKey,ptr-lpSubKey);
|
|
str[ptr-lpSubKey] = 0;
|
|
lpSubKey = ptr;
|
|
if (*lpSubKey) lpSubKey++;
|
|
|
|
lpKey = lpKey->lpSubLvl;
|
|
while(lpKey != NULL && strcmp(lpKey->lpSubKey, str) != 0) { lpKey = lpKey->lpNextKey; }
|
|
if (lpKey == NULL) {
|
|
dprintf_reg(stddeb,"RegOpenKey: key %s not found!\n",str);
|
|
return ERROR_BADKEY;
|
|
}
|
|
}
|
|
*lphKey = lpKey->hKey;
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* RegCreateKey [SHELL.2]
|
|
*/
|
|
LONG RegCreateKey(HKEY hKey, LPCSTR lpSubKey, HKEY FAR *lphKey)
|
|
{
|
|
HKEY hNewKey;
|
|
LPKEYSTRUCT lpNewKey;
|
|
LPKEYSTRUCT lpKey;
|
|
LPKEYSTRUCT lpPrevKey;
|
|
LONG dwRet;
|
|
LPCSTR ptr;
|
|
char str[128];
|
|
|
|
dwRet = SHELL_RegCheckForRoot();
|
|
if (dwRet != ERROR_SUCCESS) return dwRet;
|
|
dprintf_reg(stddeb, "RegCreateKey(%08lX, '%s', %p)\n", hKey, lpSubKey, lphKey);
|
|
if (lpSubKey == NULL) return ERROR_INVALID_PARAMETER;
|
|
if (lphKey == NULL) return ERROR_INVALID_PARAMETER;
|
|
switch(hKey) {
|
|
case 0:
|
|
lpKey = lphTopKey; break;
|
|
case HKEY_CLASSES_ROOT: /* == 1 */
|
|
lpKey = lphRootKey; break;
|
|
default:
|
|
dprintf_reg(stddeb,"RegCreateKey // specific key = %08lX !\n", hKey);
|
|
lpKey = (LPKEYSTRUCT)GlobalLock(hKey);
|
|
}
|
|
if (!*lpSubKey) { *lphKey = hKey; return ERROR_SUCCESS; }
|
|
while (*lpSubKey) {
|
|
dprintf_reg(stddeb, "RegCreateKey: Looking for subkey %s\n", lpSubKey);
|
|
ptr = strchr(lpSubKey,'\\');
|
|
if (!ptr) ptr = lpSubKey + strlen(lpSubKey);
|
|
strncpy(str,lpSubKey,ptr-lpSubKey);
|
|
str[ptr-lpSubKey] = 0;
|
|
lpSubKey = ptr;
|
|
if (*lpSubKey) lpSubKey++;
|
|
|
|
lpPrevKey = lpKey;
|
|
lpKey = lpKey->lpSubLvl;
|
|
while(lpKey != NULL && strcmp(lpKey->lpSubKey, str) != 0) {
|
|
lpKey = lpKey->lpNextKey;
|
|
}
|
|
if (lpKey == NULL) {
|
|
hNewKey = GlobalAlloc(GMEM_MOVEABLE, sizeof(KEYSTRUCT));
|
|
lpNewKey = (LPKEYSTRUCT) GlobalLock(hNewKey);
|
|
if (lpNewKey == NULL) {
|
|
printf("RegCreateKey // Can't alloc new key !\n");
|
|
return ERROR_OUTOFMEMORY;
|
|
}
|
|
lpNewKey->hKey = hNewKey;
|
|
lpNewKey->lpSubKey = malloc(strlen(str) + 1);
|
|
if (lpNewKey->lpSubKey == NULL) {
|
|
printf("RegCreateKey // Can't alloc key string !\n");
|
|
return ERROR_OUTOFMEMORY;
|
|
}
|
|
strcpy(lpNewKey->lpSubKey, str);
|
|
lpNewKey->lpNextKey = lpPrevKey->lpSubLvl;
|
|
lpNewKey->lpPrevKey = NULL;
|
|
lpPrevKey->lpSubLvl = lpNewKey;
|
|
|
|
lpNewKey->dwType = 0;
|
|
lpNewKey->lpValue = NULL;
|
|
lpNewKey->lpSubLvl = NULL;
|
|
*lphKey = hNewKey;
|
|
dprintf_reg(stddeb,"RegCreateKey // successful '%s' key=%08lX !\n", str, hNewKey);
|
|
lpKey = lpNewKey;
|
|
} else {
|
|
*lphKey = lpKey->hKey;
|
|
dprintf_reg(stddeb,"RegCreateKey // found '%s', key=%08lX\n", str, *lphKey);
|
|
}
|
|
}
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* RegCloseKey [SHELL.3]
|
|
*/
|
|
LONG RegCloseKey(HKEY hKey)
|
|
{
|
|
dprintf_reg(stdnimp, "EMPTY STUB !!! RegCloseKey(%08lX);\n", hKey);
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* RegDeleteKey [SHELL.4]
|
|
*/
|
|
LONG RegDeleteKey(HKEY hKey, LPCSTR lpSubKey)
|
|
{
|
|
dprintf_reg(stdnimp, "EMPTY STUB !!! RegDeleteKey(%08lX, '%s');\n",
|
|
hKey, lpSubKey);
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* RegSetValue [SHELL.5]
|
|
*/
|
|
LONG RegSetValue(HKEY hKey, LPCSTR lpSubKey, DWORD dwType,
|
|
LPCSTR lpVal, DWORD dwIgnored)
|
|
{
|
|
HKEY hRetKey;
|
|
LPKEYSTRUCT lpKey;
|
|
LONG dwRet;
|
|
dprintf_reg(stddeb, "RegSetValue(%08lX, '%s', %08lX, '%s', %08lX);\n",
|
|
hKey, lpSubKey, dwType, lpVal, dwIgnored);
|
|
if (lpSubKey == NULL) return ERROR_INVALID_PARAMETER;
|
|
if (lpVal == NULL) return ERROR_INVALID_PARAMETER;
|
|
if ((dwRet = RegOpenKey(hKey, lpSubKey, &hRetKey)) != ERROR_SUCCESS) {
|
|
dprintf_reg(stddeb, "RegSetValue // key not found ... so create it !\n");
|
|
if ((dwRet = RegCreateKey(hKey, lpSubKey, &hRetKey)) != ERROR_SUCCESS) {
|
|
fprintf(stderr, "RegSetValue // key creation error %08lX !\n", dwRet);
|
|
return dwRet;
|
|
}
|
|
}
|
|
lpKey = (LPKEYSTRUCT)GlobalLock(hRetKey);
|
|
if (lpKey == NULL) return ERROR_BADKEY;
|
|
if (lpKey->lpValue != NULL) free(lpKey->lpValue);
|
|
lpKey->lpValue = malloc(strlen(lpVal) + 1);
|
|
strcpy(lpKey->lpValue, lpVal);
|
|
dprintf_reg(stddeb,"RegSetValue // successful key='%s' val='%s' !\n", lpSubKey, lpKey->lpValue);
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* RegQueryValue [SHELL.6]
|
|
*/
|
|
LONG RegQueryValue(HKEY hKey, LPCSTR lpSubKey, LPSTR lpVal, LONG FAR *lpcb)
|
|
{
|
|
HKEY hRetKey;
|
|
LPKEYSTRUCT lpKey;
|
|
LONG dwRet;
|
|
int size;
|
|
dprintf_reg(stddeb, "RegQueryValue(%08lX, '%s', %p, %p);\n",
|
|
hKey, lpSubKey, lpVal, lpcb);
|
|
if (lpSubKey == NULL) return ERROR_INVALID_PARAMETER;
|
|
if (lpVal == NULL) return ERROR_INVALID_PARAMETER;
|
|
if (lpcb == NULL) return ERROR_INVALID_PARAMETER;
|
|
if (!*lpcb) return ERROR_INVALID_PARAMETER;
|
|
|
|
if ((dwRet = RegOpenKey(hKey, lpSubKey, &hRetKey)) != ERROR_SUCCESS) {
|
|
fprintf(stderr, "RegQueryValue // key not found !\n");
|
|
return dwRet;
|
|
}
|
|
lpKey = (LPKEYSTRUCT)GlobalLock(hRetKey);
|
|
if (lpKey == NULL) return ERROR_BADKEY;
|
|
if (lpKey->lpValue != NULL) {
|
|
if ((size = strlen(lpKey->lpValue)+1) > *lpcb){
|
|
strncpy(lpVal,lpKey->lpValue,*lpcb-1);
|
|
lpVal[*lpcb-1] = 0;
|
|
} else {
|
|
strcpy(lpVal,lpKey->lpValue);
|
|
*lpcb = size;
|
|
}
|
|
} else {
|
|
*lpVal = 0;
|
|
*lpcb = (LONG)1;
|
|
}
|
|
dprintf_reg(stddeb,"RegQueryValue // return '%s' !\n", lpVal);
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* RegEnumKey [SHELL.7]
|
|
*/
|
|
LONG RegEnumKey(HKEY hKey, DWORD dwSubKey, LPSTR lpBuf, DWORD dwSize)
|
|
{
|
|
LPKEYSTRUCT lpKey;
|
|
LONG dwRet;
|
|
LONG len;
|
|
|
|
dwRet = SHELL_RegCheckForRoot();
|
|
if (dwRet != ERROR_SUCCESS) return dwRet;
|
|
dprintf_reg(stddeb, "RegEnumKey(%08lX, %ld)\n", hKey, dwSubKey);
|
|
if (lpBuf == NULL) return ERROR_INVALID_PARAMETER;
|
|
switch(hKey) {
|
|
case 0:
|
|
lpKey = lphTopKey; break;
|
|
case HKEY_CLASSES_ROOT: /* == 1 */
|
|
lpKey = lphRootKey; break;
|
|
default:
|
|
dprintf_reg(stddeb,"RegEnumKey // specific key = %08lX !\n", hKey);
|
|
lpKey = (LPKEYSTRUCT)GlobalLock(hKey);
|
|
}
|
|
|
|
lpKey = lpKey->lpSubLvl;
|
|
while(lpKey != NULL){
|
|
if (!dwSubKey){
|
|
len = min(dwSize-1,strlen(lpKey->lpSubKey));
|
|
strncpy(lpBuf,lpKey->lpSubKey,len);
|
|
lpBuf[len] = 0;
|
|
dprintf_reg(stddeb, "RegEnumKey: found %s\n",lpBuf);
|
|
return ERROR_SUCCESS;
|
|
}
|
|
dwSubKey--;
|
|
lpKey = lpKey->lpNextKey;
|
|
}
|
|
dprintf_reg(stddeb, "RegEnumKey: key not found!\n");
|
|
return ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* DragAcceptFiles [SHELL.9]
|
|
*/
|
|
void DragAcceptFiles(HWND hWnd, BOOL b)
|
|
{
|
|
fprintf(stdnimp, "DragAcceptFiles : Empty Stub !!!\n");
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* DragQueryFile [SHELL.11]
|
|
*/
|
|
void DragQueryFile(HDROP h, UINT u, LPSTR u2, UINT u3)
|
|
{
|
|
fprintf(stdnimp, "DragQueryFile : Empty Stub !!!\n");
|
|
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* DragFinish [SHELL.12]
|
|
*/
|
|
void DragFinish(HDROP h)
|
|
{
|
|
fprintf(stdnimp, "DragFinish : Empty Stub !!!\n");
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* DragQueryPoint [SHELL.13]
|
|
*/
|
|
BOOL DragQueryPoint(HDROP h, POINT FAR *p)
|
|
{
|
|
fprintf(stdnimp, "DragQueryPoint : Empty Stub !!!\n");
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* ShellExecute [SHELL.20]
|
|
*/
|
|
HINSTANCE ShellExecute(HWND hWnd, LPCSTR lpOperation, LPCSTR lpFile, LPCSTR lpParameters, LPCSTR lpDirectory, int iShowCmd)
|
|
{
|
|
char cmd[400];
|
|
dprintf_exec(stddeb, "ShellExecute(%4X,'%s','%s','%s','%s',%x)\n",
|
|
hWnd, lpOperation ? lpOperation:"<null>", lpFile ? lpFile:"<null>",
|
|
lpParameters ? lpParameters : "<null>",
|
|
lpDirectory ? lpDirectory : "<null>", iShowCmd);
|
|
if(lpOperation && !strcasecmp(lpOperation,"print"))
|
|
{
|
|
fprintf(stderr, "Shell print %s: not supported\n", lpFile);
|
|
return 2; /* file not found */
|
|
}
|
|
if(lpOperation && !strcasecmp(lpOperation,"open"))
|
|
{
|
|
fprintf(stderr, "ShellExecute: Unknown operation %s\n",lpOperation);
|
|
return 2;
|
|
}
|
|
/* OK. We are supposed to lookup the program associated with lpFile,
|
|
then to execute it using that program. If lpFile is a program,
|
|
we have to pass the parameters. If an instance is already running,
|
|
we might have to send DDE commands.
|
|
This implementation does none of that. It assumes lpFile is a program.
|
|
Plain WinExec will do what we need */
|
|
if(lpParameters)
|
|
sprintf(cmd,"%s %s",lpFile,lpParameters);
|
|
else
|
|
strcpy(cmd,lpFile);
|
|
return WinExec(cmd,iShowCmd);
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* FindExecutable [SHELL.21]
|
|
*/
|
|
HINSTANCE FindExecutable(LPCSTR lpFile, LPCSTR lpDirectory, LPSTR lpResult)
|
|
{
|
|
fprintf(stdnimp, "FindExecutable : Empty Stub !!!\n");
|
|
return 0;
|
|
}
|
|
|
|
static char AppName[512], AppMisc[512];
|
|
|
|
/*************************************************************************
|
|
* AboutDlgProc [SHELL.33]
|
|
*/
|
|
INT AboutDlgProc(HWND hWnd, WORD msg, WORD wParam, LONG lParam)
|
|
{
|
|
switch(msg) {
|
|
case WM_INITDIALOG:
|
|
SendDlgItemMessage(hWnd,stc1,STM_SETICON,LOWORD(lParam),0);
|
|
SetWindowText(hWnd, AppName);
|
|
SetWindowText(GetDlgItem(hWnd,100), AppMisc);
|
|
return 1;
|
|
|
|
case WM_COMMAND:
|
|
switch (wParam) {
|
|
case IDOK:
|
|
EndDialog(hWnd, TRUE);
|
|
return TRUE;
|
|
}
|
|
break;
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* ShellAbout [SHELL.22]
|
|
*/
|
|
INT ShellAbout(HWND hWnd, LPCSTR szApp, LPCSTR szOtherStuff, HICON hIcon)
|
|
{
|
|
if (szApp) {
|
|
sprintf(AppName, "About %s", szApp);
|
|
} else {
|
|
*AppName = 0;
|
|
}
|
|
if (szOtherStuff) {
|
|
strcpy(AppMisc, szOtherStuff);
|
|
} else {
|
|
*AppMisc = 0;
|
|
}
|
|
if (!hIcon) {
|
|
hIcon = LoadIcon(0,MAKEINTRESOURCE(OIC_WINEICON));
|
|
}
|
|
return DialogBoxIndirectParamPtr(GetWindowWord(hWnd, GWW_HINSTANCE),
|
|
sysres_DIALOG_SHELL_ABOUT_MSGBOX,
|
|
hWnd, GetWndProcEntry16("AboutDlgProc"),
|
|
hIcon);
|
|
}
|
|
|
|
/*************************************************************************
|
|
* ExtractIcon [SHELL.34]
|
|
*/
|
|
HICON ExtractIcon(HINSTANCE hInst, LPCSTR lpszExeFileName, UINT nIconIndex)
|
|
{
|
|
HICON hIcon = 0;
|
|
HINSTANCE hInst2 = hInst;
|
|
dprintf_reg(stddeb, "ExtractIcon(%04X, '%s', %d\n",
|
|
hInst, lpszExeFileName, nIconIndex);
|
|
return 0;
|
|
if (lpszExeFileName != NULL) {
|
|
hInst2 = LoadModule(lpszExeFileName,(LPVOID)-1);
|
|
}
|
|
if (hInst2 != 0 && nIconIndex == (UINT)-1) {
|
|
#if 0
|
|
count = GetRsrcCount(hInst2, NE_RSCTYPE_GROUP_ICON);
|
|
dprintf_reg(stddeb, "ExtractIcon // '%s' has %d icons !\n", lpszExeFileName, count);
|
|
return (HICON)count;
|
|
#endif
|
|
}
|
|
if (hInst2 != hInst && hInst2 != 0) {
|
|
FreeLibrary(hInst2);
|
|
}
|
|
return hIcon;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* ExtractAssociatedIcon [SHELL.36]
|
|
*/
|
|
HICON ExtractAssociatedIcon(HINSTANCE hInst,LPSTR lpIconPath, LPWORD lpiIcon)
|
|
{
|
|
dprintf_reg(stdnimp, "ExtractAssociatedIcon : Empty Stub !!!\n");
|
|
return 0;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* DoEnvironmentSubst [SHELL.37]
|
|
*/
|
|
DWORD DoEnvironmentSubst(LPSTR str,WORD len)
|
|
{
|
|
dprintf_reg(stdnimp, "DoEnvironmentSubst(%s,%x): Empyt Stub !!!\n",str,len);
|
|
return 0;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* RegisterShellHook [SHELL.102]
|
|
*/
|
|
int RegisterShellHook(void *ptr)
|
|
{
|
|
dprintf_reg(stdnimp, "RegisterShellHook : Empty Stub !!!\n");
|
|
return 0;
|
|
}
|
|
|
|
|
|
/*************************************************************************
|
|
* ShellHookProc [SHELL.103]
|
|
*/
|
|
int ShellHookProc(void)
|
|
{
|
|
dprintf_reg(stdnimp, "ShellHookProc : Empty Stub !!!\n");
|
|
return 0;
|
|
}
|