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
de79a638
Commit
de79a638
authored
May 17, 2010
by
Andrey Turkin
Committed by
Alexandre Julliard
May 17, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
kernel32: Implement CreateHardLink.
parent
42debac1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
66 additions
and
7 deletions
+66
-7
path.c
dlls/kernel32/path.c
+66
-7
No files found.
dlls/kernel32/path.c
View file @
de79a638
...
...
@@ -1217,10 +1217,54 @@ BOOL WINAPI MoveFileA( LPCSTR source, LPCSTR dest )
BOOL
WINAPI
CreateHardLinkW
(
LPCWSTR
lpFileName
,
LPCWSTR
lpExistingFileName
,
LPSECURITY_ATTRIBUTES
lpSecurityAttributes
)
{
FIXME
(
"(%s, %s, %p): stub
\n
"
,
debugstr_w
(
lpFileName
),
NTSTATUS
status
;
UNICODE_STRING
ntDest
,
ntSource
;
ANSI_STRING
unixDest
,
unixSource
;
BOOL
ret
=
FALSE
;
TRACE
(
"(%s, %s, %p)
\n
"
,
debugstr_w
(
lpFileName
),
debugstr_w
(
lpExistingFileName
),
lpSecurityAttributes
);
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
return
FALSE
;
ntDest
.
Buffer
=
ntSource
.
Buffer
=
NULL
;
if
(
!
RtlDosPathNameToNtPathName_U
(
lpFileName
,
&
ntDest
,
NULL
,
NULL
)
||
!
RtlDosPathNameToNtPathName_U
(
lpExistingFileName
,
&
ntSource
,
NULL
,
NULL
))
{
SetLastError
(
ERROR_PATH_NOT_FOUND
);
goto
err
;
}
unixSource
.
Buffer
=
unixDest
.
Buffer
=
NULL
;
status
=
wine_nt_to_unix_file_name
(
&
ntSource
,
&
unixSource
,
FILE_OPEN
,
FALSE
);
if
(
!
status
)
{
status
=
wine_nt_to_unix_file_name
(
&
ntDest
,
&
unixDest
,
FILE_CREATE
,
FALSE
);
if
(
!
status
)
/* destination must not exist */
{
status
=
STATUS_OBJECT_NAME_EXISTS
;
}
else
if
(
status
==
STATUS_NO_SUCH_FILE
)
{
status
=
STATUS_SUCCESS
;
}
}
if
(
status
)
SetLastError
(
RtlNtStatusToDosError
(
status
)
);
else
if
(
!
link
(
unixSource
.
Buffer
,
unixDest
.
Buffer
))
{
TRACE
(
"Hardlinked '%s' to '%s'
\n
"
,
debugstr_a
(
unixDest
.
Buffer
),
debugstr_a
(
unixSource
.
Buffer
));
ret
=
TRUE
;
}
else
FILE_SetDosError
();
RtlFreeAnsiString
(
&
unixSource
);
RtlFreeAnsiString
(
&
unixDest
);
err:
RtlFreeUnicodeString
(
&
ntSource
);
RtlFreeUnicodeString
(
&
ntDest
);
return
ret
;
}
...
...
@@ -1230,10 +1274,25 @@ BOOL WINAPI CreateHardLinkW(LPCWSTR lpFileName, LPCWSTR lpExistingFileName,
BOOL
WINAPI
CreateHardLinkA
(
LPCSTR
lpFileName
,
LPCSTR
lpExistingFileName
,
LPSECURITY_ATTRIBUTES
lpSecurityAttributes
)
{
FIXME
(
"(%s, %s, %p): stub
\n
"
,
debugstr_a
(
lpFileName
),
debugstr_a
(
lpExistingFileName
),
lpSecurityAttributes
);
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
return
FALSE
;
WCHAR
*
sourceW
,
*
destW
;
BOOL
res
;
if
(
!
(
sourceW
=
FILE_name_AtoW
(
lpExistingFileName
,
TRUE
)))
{
return
FALSE
;
}
if
(
!
(
destW
=
FILE_name_AtoW
(
lpFileName
,
TRUE
)))
{
HeapFree
(
GetProcessHeap
(),
0
,
sourceW
);
return
FALSE
;
}
res
=
CreateHardLinkW
(
destW
,
sourceW
,
lpSecurityAttributes
);
HeapFree
(
GetProcessHeap
(),
0
,
sourceW
);
HeapFree
(
GetProcessHeap
(),
0
,
destW
);
return
res
;
}
...
...
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