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
fa057686
Commit
fa057686
authored
Nov 20, 2007
by
Lei Zhang
Committed by
Alexandre Julliard
Nov 21, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
shell32: Perform copy in UnixFolder_ISFHelper_CopyItems.
parent
046f24a0
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
71 additions
and
2 deletions
+71
-2
shfldr_unixfs.c
dlls/shell32/shfldr_unixfs.c
+71
-2
No files found.
dlls/shell32/shfldr_unixfs.c
View file @
fa057686
...
@@ -742,6 +742,61 @@ static HRESULT UNIXFS_initialize_target_folder(UnixFolder *This, const char *szB
...
@@ -742,6 +742,61 @@ static HRESULT UNIXFS_initialize_target_folder(UnixFolder *This, const char *szB
}
}
/******************************************************************************
/******************************************************************************
* UNIXFS_copy [Internal]
*
* Copy pwszDosSrc to pwszDosDst.
*
* PARAMS
* pwszDosSrc [I] absolute path of the source
* pwszDosDst [I] absolute path of the destination
*
* RETURNS
* Success: S_OK,
* Failure: E_FAIL
*/
static
HRESULT
UNIXFS_copy
(
LPCWSTR
pwszDosSrc
,
LPCWSTR
pwszDosDst
)
{
SHFILEOPSTRUCTW
op
;
LPWSTR
pwszSrc
,
pwszDst
;
HRESULT
res
=
E_OUTOFMEMORY
;
UINT
iSrcLen
,
iDstLen
;
if
(
!
pwszDosSrc
||
!
pwszDosDst
)
return
E_FAIL
;
iSrcLen
=
lstrlenW
(
pwszDosSrc
);
iDstLen
=
lstrlenW
(
pwszDosDst
);
pwszSrc
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
iSrcLen
+
2
)
*
sizeof
(
WCHAR
));
pwszDst
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
iDstLen
+
2
)
*
sizeof
(
WCHAR
));
if
(
pwszSrc
&&
pwszDst
)
{
lstrcpyW
(
pwszSrc
,
pwszDosSrc
);
lstrcpyW
(
pwszDst
,
pwszDosDst
);
/* double null termination */
pwszSrc
[
iSrcLen
+
1
]
=
0
;
pwszDst
[
iDstLen
+
1
]
=
0
;
ZeroMemory
(
&
op
,
sizeof
(
op
));
op
.
hwnd
=
GetActiveWindow
();
op
.
wFunc
=
FO_COPY
;
op
.
pFrom
=
pwszSrc
;
op
.
pTo
=
pwszDst
;
op
.
fFlags
=
FOF_ALLOWUNDO
;
if
(
!
SHFileOperationW
(
&
op
))
{
WARN
(
"SHFileOperationW failed
\n
"
);
res
=
E_FAIL
;
}
else
res
=
S_OK
;
}
HeapFree
(
GetProcessHeap
(),
0
,
pwszSrc
);
HeapFree
(
GetProcessHeap
(),
0
,
pwszDst
);
return
res
;
}
/******************************************************************************
* UnixFolder
* UnixFolder
*
*
* Class whose heap based instances represent unix filesystem directories.
* Class whose heap based instances represent unix filesystem directories.
...
@@ -1864,7 +1919,7 @@ static HRESULT WINAPI UnixFolder_ISFHelper_CopyItems(ISFHelper* iface, IShellFol
...
@@ -1864,7 +1919,7 @@ static HRESULT WINAPI UnixFolder_ISFHelper_CopyItems(ISFHelper* iface, IShellFol
HRESULT
hr
;
HRESULT
hr
;
char
szAbsoluteDst
[
FILENAME_MAX
],
*
pszRelativeDst
;
char
szAbsoluteDst
[
FILENAME_MAX
],
*
pszRelativeDst
;
TRACE
(
"(iface=%p, psfFrom=%p, cidl=%d, apidl=%p)
: semi-stub
\n
"
,
iface
,
psfFrom
,
cidl
,
apidl
);
TRACE
(
"(iface=%p, psfFrom=%p, cidl=%d, apidl=%p)
\n
"
,
iface
,
psfFrom
,
cidl
,
apidl
);
if
(
!
psfFrom
||
!
cidl
||
!
apidl
)
if
(
!
psfFrom
||
!
cidl
||
!
apidl
)
return
E_INVALIDARG
;
return
E_INVALIDARG
;
...
@@ -1882,6 +1937,8 @@ static HRESULT WINAPI UnixFolder_ISFHelper_CopyItems(ISFHelper* iface, IShellFol
...
@@ -1882,6 +1937,8 @@ static HRESULT WINAPI UnixFolder_ISFHelper_CopyItems(ISFHelper* iface, IShellFol
WCHAR
wszSrc
[
MAX_PATH
];
WCHAR
wszSrc
[
MAX_PATH
];
char
szSrc
[
FILENAME_MAX
];
char
szSrc
[
FILENAME_MAX
];
STRRET
strret
;
STRRET
strret
;
HRESULT
res
;
WCHAR
*
pwszDosSrc
,
*
pwszDosDst
;
/* Build the unix path of the current source item. */
/* Build the unix path of the current source item. */
if
(
FAILED
(
IShellFolder_GetDisplayNameOf
(
psfFrom
,
apidl
[
i
],
SHGDN_FORPARSING
,
&
strret
)))
if
(
FAILED
(
IShellFolder_GetDisplayNameOf
(
psfFrom
,
apidl
[
i
],
SHGDN_FORPARSING
,
&
strret
)))
...
@@ -1894,7 +1951,19 @@ static HRESULT WINAPI UnixFolder_ISFHelper_CopyItems(ISFHelper* iface, IShellFol
...
@@ -1894,7 +1951,19 @@ static HRESULT WINAPI UnixFolder_ISFHelper_CopyItems(ISFHelper* iface, IShellFol
/* Build the unix path of the current destination item */
/* Build the unix path of the current destination item */
UNIXFS_filename_from_shitemid
(
apidl
[
i
],
pszRelativeDst
);
UNIXFS_filename_from_shitemid
(
apidl
[
i
],
pszRelativeDst
);
FIXME
(
"Would copy %s to %s. Not yet implemented.
\n
"
,
szSrc
,
szAbsoluteDst
);
pwszDosSrc
=
wine_get_dos_file_name
(
szSrc
);
pwszDosDst
=
wine_get_dos_file_name
(
szAbsoluteDst
);
if
(
pwszDosSrc
&&
pwszDosDst
)
res
=
UNIXFS_copy
(
pwszDosSrc
,
pwszDosDst
);
else
res
=
E_OUTOFMEMORY
;
HeapFree
(
GetProcessHeap
(),
0
,
pwszDosSrc
);
HeapFree
(
GetProcessHeap
(),
0
,
pwszDosDst
);
if
(
res
!=
S_OK
)
return
res
;
}
}
return
S_OK
;
return
S_OK
;
}
}
...
...
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