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
4ec5aa68
Commit
4ec5aa68
authored
Jul 18, 2005
by
Michael Jung
Committed by
Alexandre Julliard
Jul 18, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Append filename extension if necessary in IShellFolder::SetNameOf.
parent
da6f8fac
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
57 additions
and
23 deletions
+57
-23
shfldr.h
dlls/shell32/shfldr.h
+1
-0
shfldr_fs.c
dlls/shell32/shfldr_fs.c
+16
-3
shfldr_unixfs.c
dlls/shell32/shfldr_unixfs.c
+40
-20
No files found.
dlls/shell32/shfldr.h
View file @
4ec5aa68
...
@@ -70,3 +70,4 @@ static inline int SHELL32_GUIDToStringW (REFGUID guid, LPWSTR str)
...
@@ -70,3 +70,4 @@ static inline int SHELL32_GUIDToStringW (REFGUID guid, LPWSTR str)
}
}
void
SHELL_FS_ProcessDisplayFilename
(
LPSTR
szPath
,
DWORD
dwFlags
);
void
SHELL_FS_ProcessDisplayFilename
(
LPSTR
szPath
,
DWORD
dwFlags
);
BOOL
SHELL_FS_HideExtension
(
LPWSTR
pwszPath
);
dlls/shell32/shfldr_fs.c
View file @
4ec5aa68
...
@@ -700,7 +700,20 @@ static const WCHAR HideFileExtW[] = { 'H','i','d','e','F','i','l','e','E','x',
...
@@ -700,7 +700,20 @@ static const WCHAR HideFileExtW[] = { 'H','i','d','e','F','i','l','e','E','x',
static
const
WCHAR
NeverShowExtW
[]
=
{
'N'
,
'e'
,
'v'
,
'e'
,
'r'
,
'S'
,
'h'
,
'o'
,
'w'
,
'E'
,
static
const
WCHAR
NeverShowExtW
[]
=
{
'N'
,
'e'
,
'v'
,
'e'
,
'r'
,
'S'
,
'h'
,
'o'
,
'w'
,
'E'
,
'x'
,
't'
,
0
};
'x'
,
't'
,
0
};
static
BOOL
hide_extension
(
LPWSTR
szPath
)
/******************************************************************************
* SHELL_FS_HideExtension [Internal]
*
* Query the registry if the filename extension of a given path should be
* hidden.
*
* PARAMS
* szPath [I] Relative or absolute path of a file
*
* RETURNS
* TRUE, if the filename's extension should be hidden
* FALSE, otherwise.
*/
BOOL
SHELL_FS_HideExtension
(
LPWSTR
szPath
)
{
{
HKEY
hKey
;
HKEY
hKey
;
DWORD
dwData
;
DWORD
dwData
;
...
@@ -739,7 +752,7 @@ void SHELL_FS_ProcessDisplayFilename(LPSTR szPath, DWORD dwFlags)
...
@@ -739,7 +752,7 @@ void SHELL_FS_ProcessDisplayFilename(LPSTR szPath, DWORD dwFlags)
if
(
!
(
dwFlags
&
SHGDN_FORPARSING
)
&&
if
(
!
(
dwFlags
&
SHGDN_FORPARSING
)
&&
((
dwFlags
&
SHGDN_INFOLDER
)
||
(
dwFlags
==
SHGDN_NORMAL
)))
{
((
dwFlags
&
SHGDN_INFOLDER
)
||
(
dwFlags
==
SHGDN_NORMAL
)))
{
MultiByteToWideChar
(
CP_ACP
,
0
,
szPath
,
-
1
,
pathW
,
MAX_PATH
);
MultiByteToWideChar
(
CP_ACP
,
0
,
szPath
,
-
1
,
pathW
,
MAX_PATH
);
if
(
hide_e
xtension
(
pathW
)
&&
szPath
[
0
]
!=
'.'
)
if
(
SHELL_FS_HideE
xtension
(
pathW
)
&&
szPath
[
0
]
!=
'.'
)
PathRemoveExtensionA
(
szPath
);
PathRemoveExtensionA
(
szPath
);
}
}
}
}
...
@@ -844,7 +857,7 @@ static HRESULT WINAPI IShellFolder_fnSetNameOf (IShellFolder2 * iface,
...
@@ -844,7 +857,7 @@ static HRESULT WINAPI IShellFolder_fnSetNameOf (IShellFolder2 * iface,
}
else
}
else
lstrcpynW
(
szDest
,
lpName
,
MAX_PATH
);
lstrcpynW
(
szDest
,
lpName
,
MAX_PATH
);
if
(
!
(
dwFlags
&
SHGDN_FORPARSING
)
&&
hide_e
xtension
(
szSrc
))
{
if
(
!
(
dwFlags
&
SHGDN_FORPARSING
)
&&
SHELL_FS_HideE
xtension
(
szSrc
))
{
WCHAR
*
ext
=
PathFindExtensionW
(
szSrc
);
WCHAR
*
ext
=
PathFindExtensionW
(
szSrc
);
if
(
*
ext
!=
'\0'
)
{
if
(
*
ext
!=
'\0'
)
{
INT
len
=
strlenW
(
szDest
);
INT
len
=
strlenW
(
szDest
);
...
...
dlls/shell32/shfldr_unixfs.c
View file @
4ec5aa68
...
@@ -833,11 +833,12 @@ static HRESULT WINAPI UnixFolder_IShellFolder2_SetNameOf(IShellFolder2* iface, H
...
@@ -833,11 +833,12 @@ static HRESULT WINAPI UnixFolder_IShellFolder2_SetNameOf(IShellFolder2* iface, H
{
{
UnixFolder
*
This
=
ADJUST_THIS
(
UnixFolder
,
IShellFolder2
,
iface
);
UnixFolder
*
This
=
ADJUST_THIS
(
UnixFolder
,
IShellFolder2
,
iface
);
char
szSrc
[
FILENAME_MAX
],
szDest
[
FILENAME_MAX
];
char
szSrc
[
FILENAME_MAX
],
szDest
[
FILENAME_MAX
],
szDosDest
[
MAX_PATH
];
WCHAR
wszDosDest
[
MAX_PATH
];
int
cBasePathLen
=
lstrlenA
(
This
->
m_pszPath
);
int
cBasePathLen
=
lstrlenA
(
This
->
m_pszPath
);
struct
stat
statDest
;
struct
stat
statDest
;
LPITEMIDLIST
pidl
New
;
LPITEMIDLIST
pidl
Src
,
pidlDest
;
TRACE
(
"(iface=%p, hwnd=%p, pidl=%p, lpszName=%s, uFlags=0x%08lx, ppidlOut=%p)
\n
"
,
TRACE
(
"(iface=%p, hwnd=%p, pidl=%p, lpszName=%s, uFlags=0x%08lx, ppidlOut=%p)
\n
"
,
iface
,
hwnd
,
pidl
,
debugstr_w
(
lpszName
),
uFlags
,
ppidlOut
);
iface
,
hwnd
,
pidl
,
debugstr_w
(
lpszName
),
uFlags
,
ppidlOut
);
...
@@ -856,9 +857,19 @@ static HRESULT WINAPI UnixFolder_IShellFolder2_SetNameOf(IShellFolder2* iface, H
...
@@ -856,9 +857,19 @@ static HRESULT WINAPI UnixFolder_IShellFolder2_SetNameOf(IShellFolder2* iface, H
if
(
uFlags
&
SHGDN_FORPARSING
)
{
/* absolute path in lpszName */
if
(
uFlags
&
SHGDN_FORPARSING
)
{
/* absolute path in lpszName */
WideCharToMultiByte
(
CP_ACP
,
0
,
lpszName
,
-
1
,
szDest
,
FILENAME_MAX
,
NULL
,
NULL
);
WideCharToMultiByte
(
CP_ACP
,
0
,
lpszName
,
-
1
,
szDest
,
FILENAME_MAX
,
NULL
,
NULL
);
}
else
{
}
else
{
WCHAR
wszSrcRelative
[
MAX_PATH
];
memcpy
(
szDest
,
This
->
m_pszPath
,
cBasePathLen
);
memcpy
(
szDest
,
This
->
m_pszPath
,
cBasePathLen
);
WideCharToMultiByte
(
CP_ACP
,
0
,
lpszName
,
-
1
,
szDest
+
cBasePathLen
,
WideCharToMultiByte
(
CP_ACP
,
0
,
lpszName
,
-
1
,
szDest
+
cBasePathLen
,
FILENAME_MAX
-
cBasePathLen
,
NULL
,
NULL
);
FILENAME_MAX
-
cBasePathLen
,
NULL
,
NULL
);
/* uFlags is SHGDN_FOREDITING of SHGDN_FORADDRESSBAR. If the filename's
* extension is hidden to the user, we have to append it. */
if
(
_ILSimpleGetTextW
(
pidl
,
wszSrcRelative
,
MAX_PATH
)
&&
SHELL_FS_HideExtension
(
wszSrcRelative
))
{
char
*
pszExt
=
PathFindExtensionA
(
_ILGetTextPointer
(
pidl
));
lstrcatA
(
szDest
,
pszExt
);
}
}
}
TRACE
(
"src=%s dest=%s
\n
"
,
szSrc
,
szDest
);
TRACE
(
"src=%s dest=%s
\n
"
,
szSrc
,
szDest
);
...
@@ -866,24 +877,33 @@ static HRESULT WINAPI UnixFolder_IShellFolder2_SetNameOf(IShellFolder2* iface, H
...
@@ -866,24 +877,33 @@ static HRESULT WINAPI UnixFolder_IShellFolder2_SetNameOf(IShellFolder2* iface, H
/* Fail, if destination does already exist */
/* Fail, if destination does already exist */
if
(
!
stat
(
szDest
,
&
statDest
))
if
(
!
stat
(
szDest
,
&
statDest
))
return
E_FAIL
;
return
E_FAIL
;
/* Rename the file and inform the shell */
/* Rename the file */
if
(
!
rename
(
szSrc
,
szDest
)
&&
UNIXFS_path_to_pidl
(
This
,
lpszName
,
&
pidlNew
))
{
if
(
rename
(
szSrc
,
szDest
))
LPITEMIDLIST
pidlSrc
=
ILCombine
(
This
->
m_pidlLocation
,
pidl
);
return
E_FAIL
;
LPITEMIDLIST
pidlDest
=
ILCombine
(
This
->
m_pidlLocation
,
pidlNew
);
if
(
_ILIsFolder
(
pidlNew
))
/* Build a pidl for the path of the renamed file */
SHChangeNotify
(
SHCNE_RENAMEFOLDER
,
SHCNF_IDLIST
,
pidlSrc
,
pidlDest
);
if
(
!
GetFullPathNameA
(
szDest
,
MAX_PATH
,
szDosDest
,
NULL
)
||
else
!
MultiByteToWideChar
(
CP_ACP
,
0
,
szDosDest
,
-
1
,
wszDosDest
,
MAX_PATH
)
||
SHChangeNotify
(
SHCNE_RENAMEITEM
,
SHCNF_IDLIST
,
pidlSrc
,
pidlDest
);
!
UNIXFS_path_to_pidl
(
This
,
wszDosDest
,
&
pidlDest
))
ILFree
(
pidlSrc
);
{
ILFree
(
pidlDest
);
rename
(
szDest
,
szSrc
);
/* Undo the renaming */
if
(
ppidlOut
)
return
E_FAIL
;
*
ppidlOut
=
pidlNew
;
else
ILFree
(
pidlNew
);
return
S_OK
;
}
}
return
E_FAIL
;
/* Inform the shell */
pidlSrc
=
ILCombine
(
This
->
m_pidlLocation
,
pidl
);
if
(
_ILIsFolder
(
ILFindLastID
(
pidlDest
)))
SHChangeNotify
(
SHCNE_RENAMEFOLDER
,
SHCNF_IDLIST
,
pidlSrc
,
pidlDest
);
else
SHChangeNotify
(
SHCNE_RENAMEITEM
,
SHCNF_IDLIST
,
pidlSrc
,
pidlDest
);
ILFree
(
pidlSrc
);
ILFree
(
pidlDest
);
if
(
ppidlOut
)
_ILCreateFromPathW
(
wszDosDest
,
ppidlOut
);
return
S_OK
;
}
}
static
HRESULT
WINAPI
UnixFolder_IShellFolder2_EnumSearches
(
IShellFolder2
*
iface
,
static
HRESULT
WINAPI
UnixFolder_IShellFolder2_EnumSearches
(
IShellFolder2
*
iface
,
...
...
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