Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
594e0b67
Commit
594e0b67
authored
May 09, 2015
by
Nikolay Sivov
Committed by
Alexandre Julliard
May 11, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
shell32: Forward couple of IKnownFolder methods to regular API equivalents.
parent
2c98d5b9
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
46 additions
and
15 deletions
+46
-15
shell32.spec
dlls/shell32/shell32.spec
+1
-0
shellpath.c
dlls/shell32/shellpath.c
+28
-6
shlobj.h
include/shlobj.h
+17
-9
No files found.
dlls/shell32/shell32.spec
View file @
594e0b67
...
@@ -379,6 +379,7 @@
...
@@ -379,6 +379,7 @@
@ stdcall SHGetItemFromDataObject(ptr long ptr ptr)
@ stdcall SHGetItemFromDataObject(ptr long ptr ptr)
@ stdcall SHGetItemFromObject(ptr ptr ptr)
@ stdcall SHGetItemFromObject(ptr ptr ptr)
@ stdcall SHGetKnownFolderIDList(ptr long ptr ptr)
@ stdcall SHGetKnownFolderIDList(ptr long ptr ptr)
@ stdcall SHGetKnownFolderItem(ptr long long ptr ptr)
@ stdcall SHGetKnownFolderPath(ptr long ptr ptr)
@ stdcall SHGetKnownFolderPath(ptr long ptr ptr)
@ stdcall SHGetLocalizedName(wstr ptr long ptr)
@ stdcall SHGetLocalizedName(wstr ptr long ptr)
@ stdcall SHGetMalloc(ptr)
@ stdcall SHGetMalloc(ptr)
...
...
dlls/shell32/shellpath.c
View file @
594e0b67
...
@@ -5103,12 +5103,13 @@ static HRESULT WINAPI knownfolder_GetCategory(
...
@@ -5103,12 +5103,13 @@ static HRESULT WINAPI knownfolder_GetCategory(
static
HRESULT
WINAPI
knownfolder_GetShellItem
(
static
HRESULT
WINAPI
knownfolder_GetShellItem
(
IKnownFolder
*
iface
,
IKnownFolder
*
iface
,
DWORD
dwF
lags
,
DWORD
f
lags
,
REFIID
riid
,
REFIID
riid
,
void
**
ppv
)
void
**
ppv
)
{
{
FIXME
(
"0x%08x, %s, %p
\n
"
,
dwFlags
,
debugstr_guid
(
riid
),
ppv
);
struct
knownfolder
*
knownfolder
=
impl_from_IKnownFolder
(
iface
);
return
E_NOTIMPL
;
TRACE
(
"(%p, 0x%08x, %s, %p)
\n
"
,
knownfolder
,
flags
,
debugstr_guid
(
riid
),
ppv
);
return
SHGetKnownFolderItem
(
&
knownfolder
->
id
,
flags
,
NULL
,
riid
,
ppv
);
}
}
static
HRESULT
get_known_folder_path
(
static
HRESULT
get_known_folder_path
(
...
@@ -5275,11 +5276,12 @@ static HRESULT WINAPI knownfolder_SetPath(
...
@@ -5275,11 +5276,12 @@ static HRESULT WINAPI knownfolder_SetPath(
static
HRESULT
WINAPI
knownfolder_GetIDList
(
static
HRESULT
WINAPI
knownfolder_GetIDList
(
IKnownFolder
*
iface
,
IKnownFolder
*
iface
,
DWORD
dwF
lags
,
DWORD
f
lags
,
PIDLIST_ABSOLUTE
*
ppidl
)
PIDLIST_ABSOLUTE
*
ppidl
)
{
{
FIXME
(
"0x%08x, %p
\n
"
,
dwFlags
,
ppidl
);
struct
knownfolder
*
knownfolder
=
impl_from_IKnownFolder
(
iface
);
return
E_NOTIMPL
;
TRACE
(
"(%p, 0x%08x, %p)
\n
"
,
knownfolder
,
flags
,
ppidl
);
return
SHGetKnownFolderIDList
(
&
knownfolder
->
id
,
flags
,
NULL
,
ppidl
);
}
}
static
HRESULT
WINAPI
knownfolder_GetFolderType
(
static
HRESULT
WINAPI
knownfolder_GetFolderType
(
...
@@ -5717,6 +5719,26 @@ HRESULT WINAPI SHGetKnownFolderIDList(REFKNOWNFOLDERID rfid, DWORD flags, HANDLE
...
@@ -5717,6 +5719,26 @@ HRESULT WINAPI SHGetKnownFolderIDList(REFKNOWNFOLDERID rfid, DWORD flags, HANDLE
return
E_NOTIMPL
;
return
E_NOTIMPL
;
}
}
HRESULT
WINAPI
SHGetKnownFolderItem
(
REFKNOWNFOLDERID
rfid
,
KNOWN_FOLDER_FLAG
flags
,
HANDLE
hToken
,
REFIID
riid
,
void
**
ppv
)
{
PIDLIST_ABSOLUTE
pidl
;
HRESULT
hr
;
TRACE
(
"%s, 0x%08x, %p, %s, %p
\n
"
,
debugstr_guid
(
rfid
),
flags
,
hToken
,
debugstr_guid
(
riid
),
ppv
);
hr
=
SHGetKnownFolderIDList
(
rfid
,
flags
,
hToken
,
&
pidl
);
if
(
FAILED
(
hr
))
{
*
ppv
=
NULL
;
return
hr
;
}
hr
=
SHCreateItemFromIDList
(
pidl
,
riid
,
ppv
);
CoTaskMemFree
(
pidl
);
return
hr
;
}
static
void
register_system_knownfolders
(
void
)
static
void
register_system_knownfolders
(
void
)
{
{
int
i
;
int
i
;
...
...
include/shlobj.h
View file @
594e0b67
...
@@ -42,6 +42,21 @@ extern "C" {
...
@@ -42,6 +42,21 @@ extern "C" {
DECLARE_HANDLE
(
HPSXA
);
DECLARE_HANDLE
(
HPSXA
);
#endif
#endif
typedef
enum
{
KF_FLAG_DEFAULT
=
0x00000000
,
KF_FLAG_SIMPLE_IDLIST
=
0x00000100
,
KF_FLAG_NOT_PARENT_RELATIVE
=
0x00000200
,
KF_FLAG_DEFAULT_PATH
=
0x00000400
,
KF_FLAG_INIT
=
0x00000800
,
KF_FLAG_NO_ALIAS
=
0x00001000
,
KF_FLAG_DONT_UNEXPAND
=
0x00002000
,
KF_FLAG_DONT_VERIFY
=
0x00004000
,
KF_FLAG_CREATE
=
0x00008000
,
KF_FLAG_NO_APPCONTAINER_REDIRECTION
=
0x00010000
,
KF_FLAG_ALIAS_ONLY
=
0x80000000
}
KNOWN_FOLDER_FLAG
;
UINT
WINAPI
SHAddFromPropSheetExtArray
(
HPSXA
,
LPFNADDPROPSHEETPAGE
,
LPARAM
);
UINT
WINAPI
SHAddFromPropSheetExtArray
(
HPSXA
,
LPFNADDPROPSHEETPAGE
,
LPARAM
);
LPVOID
WINAPI
SHAlloc
(
ULONG
)
__WINE_ALLOC_SIZE
(
1
);
LPVOID
WINAPI
SHAlloc
(
ULONG
)
__WINE_ALLOC_SIZE
(
1
);
HRESULT
WINAPI
SHCoCreateInstance
(
LPCWSTR
,
const
CLSID
*
,
IUnknown
*
,
REFIID
,
LPVOID
*
);
HRESULT
WINAPI
SHCoCreateInstance
(
LPCWSTR
,
const
CLSID
*
,
IUnknown
*
,
REFIID
,
LPVOID
*
);
...
@@ -62,6 +77,8 @@ HRESULT WINAPI SHGetInstanceExplorer(IUnknown**);
...
@@ -62,6 +77,8 @@ HRESULT WINAPI SHGetInstanceExplorer(IUnknown**);
HRESULT
WINAPI
SHGetFolderPathAndSubDirA
(
HWND
,
int
,
HANDLE
,
DWORD
,
LPCSTR
,
LPSTR
);
HRESULT
WINAPI
SHGetFolderPathAndSubDirA
(
HWND
,
int
,
HANDLE
,
DWORD
,
LPCSTR
,
LPSTR
);
HRESULT
WINAPI
SHGetFolderPathAndSubDirW
(
HWND
,
int
,
HANDLE
,
DWORD
,
LPCWSTR
,
LPWSTR
);
HRESULT
WINAPI
SHGetFolderPathAndSubDirW
(
HWND
,
int
,
HANDLE
,
DWORD
,
LPCWSTR
,
LPWSTR
);
#define SHGetFolderPathAndSubDir WINELIB_NAME_AW(SHGetFolderPathAndSubDir)
#define SHGetFolderPathAndSubDir WINELIB_NAME_AW(SHGetFolderPathAndSubDir)
HRESULT
WINAPI
SHGetKnownFolderIDList
(
REFKNOWNFOLDERID
,
DWORD
,
HANDLE
,
PIDLIST_ABSOLUTE
*
);
HRESULT
WINAPI
SHGetKnownFolderItem
(
REFKNOWNFOLDERID
,
KNOWN_FOLDER_FLAG
,
HANDLE
,
REFIID
,
void
**
);
HRESULT
WINAPI
SHGetKnownFolderPath
(
REFKNOWNFOLDERID
,
DWORD
,
HANDLE
,
PWSTR
*
);
HRESULT
WINAPI
SHGetKnownFolderPath
(
REFKNOWNFOLDERID
,
DWORD
,
HANDLE
,
PWSTR
*
);
BOOL
WINAPI
SHGetPathFromIDListA
(
LPCITEMIDLIST
,
LPSTR
);
BOOL
WINAPI
SHGetPathFromIDListA
(
LPCITEMIDLIST
,
LPSTR
);
BOOL
WINAPI
SHGetPathFromIDListW
(
LPCITEMIDLIST
,
LPWSTR
);
BOOL
WINAPI
SHGetPathFromIDListW
(
LPCITEMIDLIST
,
LPWSTR
);
...
@@ -92,15 +109,6 @@ BOOL WINAPI Shell_GetImageLists(HIMAGELIST*,HIMAGELIST*);
...
@@ -92,15 +109,6 @@ BOOL WINAPI Shell_GetImageLists(HIMAGELIST*,HIMAGELIST*);
BOOL
WINAPI
SignalFileOpen
(
PCIDLIST_ABSOLUTE
);
BOOL
WINAPI
SignalFileOpen
(
PCIDLIST_ABSOLUTE
);
BOOL
WINAPI
ImportPrivacySettings
(
LPCWSTR
,
BOOL
*
,
BOOL
*
);
BOOL
WINAPI
ImportPrivacySettings
(
LPCWSTR
,
BOOL
*
,
BOOL
*
);
#define KF_FLAG_SIMPLE_IDLIST 0x00000100
#define KF_FLAG_NOT_PARENT_RELATIVE 0x00000200
#define KF_FLAG_DEFAULT_PATH 0x00000400
#define KF_FLAG_INIT 0x00000800
#define KF_FLAG_NO_ALIAS 0x00001000
#define KF_FLAG_DONT_UNEXPAND 0x00002000
#define KF_FLAG_DONT_VERIFY 0x00004000
#define KF_FLAG_CREATE 0x00008000
#define SHFMT_ERROR __MSABI_LONG(0xFFFFFFFF)
/* Error on last format, drive may be formattable */
#define SHFMT_ERROR __MSABI_LONG(0xFFFFFFFF)
/* Error on last format, drive may be formattable */
#define SHFMT_CANCEL __MSABI_LONG(0xFFFFFFFE)
/* Last format was cancelled */
#define SHFMT_CANCEL __MSABI_LONG(0xFFFFFFFE)
/* Last format was cancelled */
#define SHFMT_NOFORMAT __MSABI_LONG(0xFFFFFFFD)
/* Drive is not formattable */
#define SHFMT_NOFORMAT __MSABI_LONG(0xFFFFFFFD)
/* Drive is not formattable */
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment