Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
2fa0dbd5
Commit
2fa0dbd5
authored
Oct 28, 2005
by
Mike McCormack
Committed by
Alexandre Julliard
Oct 28, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Translate INVALID_HANDLE_VALUE to zero for cabinet handles.
parent
d2e0d5e8
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
19 additions
and
10 deletions
+19
-10
files.c
dlls/msi/files.c
+19
-10
No files found.
dlls/msi/files.c
View file @
2fa0dbd5
...
@@ -119,6 +119,7 @@ static void cabinet_free(void *pv)
...
@@ -119,6 +119,7 @@ static void cabinet_free(void *pv)
static
INT_PTR
cabinet_open
(
char
*
pszFile
,
int
oflag
,
int
pmode
)
static
INT_PTR
cabinet_open
(
char
*
pszFile
,
int
oflag
,
int
pmode
)
{
{
HANDLE
handle
;
DWORD
dwAccess
=
0
;
DWORD
dwAccess
=
0
;
DWORD
dwShareMode
=
0
;
DWORD
dwShareMode
=
0
;
DWORD
dwCreateDisposition
=
OPEN_EXISTING
;
DWORD
dwCreateDisposition
=
OPEN_EXISTING
;
...
@@ -141,35 +142,42 @@ static INT_PTR cabinet_open(char *pszFile, int oflag, int pmode)
...
@@ -141,35 +142,42 @@ static INT_PTR cabinet_open(char *pszFile, int oflag, int pmode)
dwCreateDisposition
=
CREATE_NEW
;
dwCreateDisposition
=
CREATE_NEW
;
else
if
(
oflag
&
_O_CREAT
)
else
if
(
oflag
&
_O_CREAT
)
dwCreateDisposition
=
CREATE_ALWAYS
;
dwCreateDisposition
=
CREATE_ALWAYS
;
return
(
INT_PTR
)
CreateFileA
(
pszFile
,
dwAccess
,
dwShareMode
,
NULL
,
handle
=
CreateFileA
(
pszFile
,
dwAccess
,
dwShareMode
,
NULL
,
dwCreateDisposition
,
0
,
NULL
);
dwCreateDisposition
,
0
,
NULL
);
if
(
handle
==
INVALID_HANDLE_VALUE
)
return
0
;
return
(
INT_PTR
)
handle
;
}
}
static
UINT
cabinet_read
(
INT_PTR
hf
,
void
*
pv
,
UINT
cb
)
static
UINT
cabinet_read
(
INT_PTR
hf
,
void
*
pv
,
UINT
cb
)
{
{
HANDLE
handle
=
(
HANDLE
)
hf
;
DWORD
dwRead
;
DWORD
dwRead
;
if
(
ReadFile
(
(
HANDLE
)
hf
,
pv
,
cb
,
&
dwRead
,
NULL
))
if
(
ReadFile
(
handle
,
pv
,
cb
,
&
dwRead
,
NULL
))
return
dwRead
;
return
dwRead
;
return
0
;
return
0
;
}
}
static
UINT
cabinet_write
(
INT_PTR
hf
,
void
*
pv
,
UINT
cb
)
static
UINT
cabinet_write
(
INT_PTR
hf
,
void
*
pv
,
UINT
cb
)
{
{
HANDLE
handle
=
(
HANDLE
)
hf
;
DWORD
dwWritten
;
DWORD
dwWritten
;
if
(
WriteFile
(
(
HANDLE
)
hf
,
pv
,
cb
,
&
dwWritten
,
NULL
))
if
(
WriteFile
(
handle
,
pv
,
cb
,
&
dwWritten
,
NULL
))
return
dwWritten
;
return
dwWritten
;
return
0
;
return
0
;
}
}
static
int
cabinet_close
(
INT_PTR
hf
)
static
int
cabinet_close
(
INT_PTR
hf
)
{
{
return
CloseHandle
((
HANDLE
)
hf
)
?
0
:
-
1
;
HANDLE
handle
=
(
HANDLE
)
hf
;
return
CloseHandle
(
handle
)
?
0
:
-
1
;
}
}
static
long
cabinet_seek
(
INT_PTR
hf
,
long
dist
,
int
seektype
)
static
long
cabinet_seek
(
INT_PTR
hf
,
long
dist
,
int
seektype
)
{
{
HANDLE
handle
=
(
HANDLE
)
hf
;
/* flags are compatible and so are passed straight through */
/* flags are compatible and so are passed straight through */
return
SetFilePointer
(
(
HANDLE
)
hf
,
dist
,
NULL
,
seektype
);
return
SetFilePointer
(
handle
,
dist
,
NULL
,
seektype
);
}
}
static
INT_PTR
cabinet_notify
(
FDINOTIFICATIONTYPE
fdint
,
PFDINOTIFICATION
pfdin
)
static
INT_PTR
cabinet_notify
(
FDINOTIFICATIONTYPE
fdint
,
PFDINOTIFICATION
pfdin
)
...
@@ -250,15 +258,16 @@ static INT_PTR cabinet_notify(FDINOTIFICATIONTYPE fdint, PFDINOTIFICATION pfdin)
...
@@ -250,15 +258,16 @@ static INT_PTR cabinet_notify(FDINOTIFICATIONTYPE fdint, PFDINOTIFICATION pfdin)
case
fdintCLOSE_FILE_INFO
:
case
fdintCLOSE_FILE_INFO
:
{
{
FILETIME
ft
;
FILETIME
ft
;
FILETIME
ftLocal
;
FILETIME
ftLocal
;
HANDLE
handle
=
(
HANDLE
)
pfdin
->
hf
;
if
(
!
DosDateTimeToFileTime
(
pfdin
->
date
,
pfdin
->
time
,
&
ft
))
if
(
!
DosDateTimeToFileTime
(
pfdin
->
date
,
pfdin
->
time
,
&
ft
))
return
-
1
;
return
-
1
;
if
(
!
LocalFileTimeToFileTime
(
&
ft
,
&
ftLocal
))
if
(
!
LocalFileTimeToFileTime
(
&
ft
,
&
ftLocal
))
return
-
1
;
return
-
1
;
if
(
!
SetFileTime
(
(
HANDLE
)
pfdin
->
hf
,
&
ftLocal
,
0
,
&
ftLocal
))
if
(
!
SetFileTime
(
handle
,
&
ftLocal
,
0
,
&
ftLocal
))
return
-
1
;
return
-
1
;
CloseHandle
(
handle
);
cabinet_close
(
pfdin
->
hf
);
return
1
;
return
1
;
}
}
default:
default:
...
...
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