Small fixes.

This commit is contained in:
Juergen Schmied 2000-01-04 00:33:56 +00:00 committed by Alexandre Julliard
parent 6afc68aabd
commit 6d17c61096
7 changed files with 68 additions and 30 deletions

View File

@ -77,7 +77,7 @@ init Shell32LibMain
69 stub SHGetNetResource 69 stub SHGetNetResource
70 stdcall SHCreateDefClassObject(long long long long long)SHCreateDefClassObject 70 stdcall SHCreateDefClassObject(long long long long long)SHCreateDefClassObject
71 stdcall Shell_GetImageList(ptr ptr) Shell_GetImageList 71 stdcall Shell_GetImageList(ptr ptr) Shell_GetImageList
72 stdcall Shell_GetCachedImageIndex(ptr ptr long) Shell_GetCachedImageIndexA # ASCII!!! 72 stdcall Shell_GetCachedImageIndex(ptr ptr long) Shell_GetCachedImageIndexAW
73 stdcall SHShellFolderView_Message(long long long) SHShellFolderView_Message 73 stdcall SHShellFolderView_Message(long long long) SHShellFolderView_Message
74 stub SHCreateStdEnumFmtEtc 74 stub SHCreateStdEnumFmtEtc
75 stdcall PathYetAnotherMakeUniqueName(ptr ptr) PathYetAnotherMakeUniqueNameA 75 stdcall PathYetAnotherMakeUniqueName(ptr ptr) PathYetAnotherMakeUniqueNameA
@ -304,7 +304,7 @@ init Shell32LibMain
295 stub ShellHookProc # exported by name 295 stub ShellHookProc # exported by name
296 stdcall Shell_NotifyIcon(long ptr) Shell_NotifyIcon 296 stdcall Shell_NotifyIcon(long ptr) Shell_NotifyIcon
297 stdcall Shell_NotifyIconA(long ptr) Shell_NotifyIconA 297 stdcall Shell_NotifyIconA(long ptr) Shell_NotifyIconA
298 stub Shell_NotifyIconW # exported by name 298 stdcall Shell_NotifyIconW(long ptr) Shell_NotifyIconW
299 stub Shl1632_ThunkData32 299 stub Shl1632_ThunkData32
300 stub Shl3216_ThunkData32 300 stub Shl3216_ThunkData32
301 stub StrChrA # proper ordinal unknown 301 stub StrChrA # proper ordinal unknown

View File

@ -816,7 +816,8 @@ BOOL WINAPI Shell32LibMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID fImpLoad)
} }
SIC_Initialize(); SIC_Initialize();
SYSTRAY_Init();
break; break;
case DLL_THREAD_ATTACH: case DLL_THREAD_ATTACH:

View File

@ -138,4 +138,7 @@ HRESULT WINAPI Shell_MergeMenus (HMENU hmDst, HMENU hmSrc, UINT uInsert, UINT uI
(((kst) & MK_SHIFT) ? DROPEFFECT_LINK : DROPEFFECT_COPY):\ (((kst) & MK_SHIFT) ? DROPEFFECT_LINK : DROPEFFECT_COPY):\
DROPEFFECT_MOVE) DROPEFFECT_MOVE)
/* Systray */
BOOL SYSTRAY_Init(void);
#endif #endif

View File

@ -1454,3 +1454,14 @@ BOOL WINAPI Win32DeleteFile(LPSTR fName)
return TRUE; return TRUE;
} }
/*
LPSTR WINAPI StrCpyNA(LPSTR psz1, LPCSTR psz2, int cchMax)
{
return lstrcpynA(psz1, psz2, cchMax);
}
LPWSTR WINAPI StrCpyNW(LPWSTR psz1, LPCWSTR psz2, int cchMax)
{
return lstrcpynW(psz1, psz2, cchMax);
}
*/

View File

@ -651,9 +651,11 @@ VOID WINAPI PathUnquoteSpacesW(LPWSTR str)
return; return;
} }
VOID WINAPI PathUnquoteSpacesAW(LPVOID str) VOID WINAPI PathUnquoteSpacesAW(LPVOID str)
{ if(VERSION_OsIsUnicode()) {
if(VERSION_OsIsUnicode())
PathUnquoteSpacesW(str); PathUnquoteSpacesW(str);
PathUnquoteSpacesA(str); else
PathUnquoteSpacesA(str);
} }
@ -890,7 +892,7 @@ BOOL WINAPI SHGetSpecialFolderPathA (
case CSIDL_PROGRAMS: case CSIDL_PROGRAMS:
hRootKey = HKEY_CURRENT_USER; hRootKey = HKEY_CURRENT_USER;
strcpy(szValueName, "Programs"); strcpy(szValueName, "Programs");
strcpy(szDefaultPath, "StatrMenu\\Programs"); strcpy(szDefaultPath, "StartMenu\\Programs");
break; break;
case CSIDL_COMMON_PROGRAMS: case CSIDL_COMMON_PROGRAMS:
@ -1012,31 +1014,22 @@ BOOL WINAPI SHGetSpecialFolderPathAW (
* *
*/ */
LPSTR WINAPI PathRemoveBackslashA( LPSTR WINAPI PathRemoveBackslashA( LPSTR lpPath )
LPSTR lpPath
)
{ {
LPSTR temp = lpPath; LPSTR p = lpPath;
LPSTR prev = lpPath;
while (*temp) while (*lpPath) p = lpPath++;
{ if ( *p == (CHAR)'\\') *p = (CHAR)'\0';
prev = temp++; return p;
}
if ( *prev == (CHAR)'\\')
{
*prev = (CHAR)'\0';
}
return prev;
} }
LPWSTR WINAPI PathRemoveBackslashW( LPWSTR WINAPI PathRemoveBackslashW( LPWSTR lpPath )
LPWSTR lpPath
)
{ {
FIXME("(%p),stub!\n", lpPath); LPWSTR p = lpPath;
return lpPath;
while (*lpPath); p = lpPath++;
if ( *p == (WCHAR)'\\') *p = (WCHAR)'\0';
return p;
} }
/* /*

View File

@ -1,7 +1,6 @@
/* /*
* see www.geocities.com/SiliconValley/4942/filemenu.html * see www.geocities.com/SiliconValley/4942/filemenu.html
*/ */
#include <assert.h>
#include <string.h> #include <string.h>
#include "wine/obj_base.h" #include "wine/obj_base.h"
@ -61,7 +60,11 @@ LPFMINFO FM_GetMenuInfo(HMENU hmenu)
menudata = (LPFMINFO)MenuInfo.dwMenuData; menudata = (LPFMINFO)MenuInfo.dwMenuData;
assert ((menudata != 0) && (MenuInfo.cbSize == sizeof(MENUINFO))); if ((menudata == 0) || (MenuInfo.cbSize != sizeof(MENUINFO)))
{
ERR("menudata corrupt: %p %lu\n", menudata, MenuInfo.cbSize);
return 0;
}
return menudata; return menudata;
@ -122,7 +125,11 @@ static int FM_InitMenuPopup(HMENU hmenu, LPITEMIDLIST pAlternatePidl)
menudata = (LPFMINFO)MenuInfo.dwMenuData; menudata = (LPFMINFO)MenuInfo.dwMenuData;
assert ((menudata != 0) && (MenuInfo.cbSize == sizeof(MENUINFO))); if ((menudata == 0) || (MenuInfo.cbSize != sizeof(MENUINFO)))
{
ERR("menudata corrupt: %p %lu\n", menudata, MenuInfo.cbSize);
return 0;
}
if (menudata->bInitialized) if (menudata->bInitialized)
return 0; return 0;
@ -334,7 +341,12 @@ BOOL WINAPI FileMenu_AppendItemA(
return FALSE; return FALSE;
menudata = (LPFMINFO)MenuInfo.dwMenuData; menudata = (LPFMINFO)MenuInfo.dwMenuData;
assert ((menudata != 0) && (MenuInfo.cbSize == sizeof(MENUINFO))); if ((menudata == 0) || (MenuInfo.cbSize != sizeof(MENUINFO)))
{
ERR("menudata corrupt: %p %lu\n", menudata, MenuInfo.cbSize);
return 0;
}
menudata->bFixedItems = TRUE; menudata->bFixedItems = TRUE;
SetMenuInfo(hMenu, &MenuInfo); SetMenuInfo(hMenu, &MenuInfo);

View File

@ -13,6 +13,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include "heap.h"
#include "shellapi.h" #include "shellapi.h"
#include "shell32_main.h" #include "shell32_main.h"
#include "windows.h" #include "windows.h"
@ -420,6 +421,23 @@ BOOL WINAPI Shell_NotifyIconA(DWORD dwMessage, PNOTIFYICONDATAA pnid )
return flag; return flag;
} }
/*************************************************************************
* Shell_NotifyIconA [SHELL32.297]
*/
BOOL WINAPI Shell_NotifyIconW (DWORD dwMessage, PNOTIFYICONDATAW pnid )
{
BOOL ret;
PNOTIFYICONDATAA p = HeapAlloc(GetProcessHeap(),0,sizeof(NOTIFYICONDATAA));
memcpy(p, pnid, sizeof(NOTIFYICONDATAA));
if (*(pnid->szTip))
lstrcpynWtoA (p->szTip, pnid->szTip, 64 );
ret = Shell_NotifyIconA(dwMessage, p );
HeapFree(GetProcessHeap(),0,p);
return ret;
}
/************************************************************************* /*************************************************************************
* Shell_NotifyIcon [SHELL32.296] * Shell_NotifyIcon [SHELL32.296]
*/ */