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
3d5b3bef
Commit
3d5b3bef
authored
Nov 24, 2010
by
Andrew Bogott
Committed by
Alexandre Julliard
Dec 06, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
shdocvw: Add reading of iconfile and iconframe via IPersistFile.
parent
3f9abe2c
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
93 additions
and
17 deletions
+93
-17
intshcut.c
dlls/shdocvw/intshcut.c
+93
-17
No files found.
dlls/shdocvw/intshcut.c
View file @
3d5b3bef
...
@@ -411,10 +411,37 @@ static HRESULT WINAPI PersistFile_IsDirty(IPersistFile *pFile)
...
@@ -411,10 +411,37 @@ static HRESULT WINAPI PersistFile_IsDirty(IPersistFile *pFile)
return
This
->
isDirty
?
S_OK
:
S_FALSE
;
return
This
->
isDirty
?
S_OK
:
S_FALSE
;
}
}
/* A helper function: Allocate and fill rString. Return number of bytes read. */
static
DWORD
get_profile_string
(
LPCWSTR
lpAppName
,
LPCWSTR
lpKeyName
,
LPCWSTR
lpFileName
,
WCHAR
**
rString
)
{
DWORD
r
=
0
;
DWORD
len
=
128
;
*
rString
=
CoTaskMemAlloc
(
len
*
sizeof
(
WCHAR
));
if
(
rString
!=
NULL
)
{
r
=
GetPrivateProfileStringW
(
lpAppName
,
lpKeyName
,
NULL
,
*
rString
,
len
,
lpFileName
);
while
(
r
==
len
-
1
)
{
CoTaskMemFree
(
rString
);
len
*=
2
;
rString
=
CoTaskMemAlloc
(
len
*
sizeof
(
WCHAR
));
if
(
rString
==
NULL
)
break
;
r
=
GetPrivateProfileStringW
(
lpAppName
,
lpKeyName
,
NULL
,
*
rString
,
len
,
lpFileName
);
}
}
return
r
;
}
static
HRESULT
WINAPI
PersistFile_Load
(
IPersistFile
*
pFile
,
LPCOLESTR
pszFileName
,
DWORD
dwMode
)
static
HRESULT
WINAPI
PersistFile_Load
(
IPersistFile
*
pFile
,
LPCOLESTR
pszFileName
,
DWORD
dwMode
)
{
{
WCHAR
str_header
[]
=
{
'I'
,
'n'
,
't'
,
'e'
,
'r'
,
'n'
,
'e'
,
't'
,
'S'
,
'h'
,
'o'
,
'r'
,
't'
,
'c'
,
'u'
,
't'
,
0
};
WCHAR
str_header
[]
=
{
'I'
,
'n'
,
't'
,
'e'
,
'r'
,
'n'
,
'e'
,
't'
,
'S'
,
'h'
,
'o'
,
'r'
,
't'
,
'c'
,
'u'
,
't'
,
0
};
WCHAR
str_URL
[]
=
{
'U'
,
'R'
,
'L'
,
0
};
WCHAR
str_URL
[]
=
{
'U'
,
'R'
,
'L'
,
0
};
WCHAR
str_iconfile
[]
=
{
'i'
,
'c'
,
'o'
,
'n'
,
'f'
,
'i'
,
'l'
,
'e'
,
0
};
WCHAR
str_iconindex
[]
=
{
'i'
,
'c'
,
'o'
,
'n'
,
'i'
,
'n'
,
'd'
,
'e'
,
'x'
,
0
};
WCHAR
*
filename
=
NULL
;
WCHAR
*
filename
=
NULL
;
HRESULT
hr
;
HRESULT
hr
;
InternetShortcut
*
This
=
impl_from_IPersistFile
(
pFile
);
InternetShortcut
*
This
=
impl_from_IPersistFile
(
pFile
);
...
@@ -424,39 +451,88 @@ static HRESULT WINAPI PersistFile_Load(IPersistFile *pFile, LPCOLESTR pszFileNam
...
@@ -424,39 +451,88 @@ static HRESULT WINAPI PersistFile_Load(IPersistFile *pFile, LPCOLESTR pszFileNam
filename
=
co_strdupW
(
pszFileName
);
filename
=
co_strdupW
(
pszFileName
);
if
(
filename
!=
NULL
)
if
(
filename
!=
NULL
)
{
{
DWORD
len
=
128
;
DWORD
r
;
DWORD
r
;
WCHAR
*
url
=
CoTaskMemAlloc
(
len
*
sizeof
(
WCHAR
));
WCHAR
*
url
;
if
(
url
!=
NULL
)
{
r
=
get_profile_string
(
str_header
,
str_URL
,
pszFileName
,
&
url
);
r
=
GetPrivateProfileStringW
(
str_header
,
str_URL
,
NULL
,
url
,
len
,
pszFileName
);
while
(
r
==
len
-
1
)
{
CoTaskMemFree
(
url
);
len
*=
2
;
url
=
CoTaskMemAlloc
(
len
*
sizeof
(
WCHAR
));
if
(
url
==
NULL
)
break
;
r
=
GetPrivateProfileStringW
(
str_header
,
str_URL
,
NULL
,
url
,
len
,
pszFileName
);
}
if
(
r
==
0
)
if
(
r
==
0
)
{
hr
=
E_FAIL
;
hr
=
E_FAIL
;
CoTaskMemFree
(
filename
);
}
else
if
(
url
!=
NULL
)
else
if
(
url
!=
NULL
)
{
{
hr
=
S_OK
;
CoTaskMemFree
(
This
->
currentFile
);
CoTaskMemFree
(
This
->
currentFile
);
This
->
currentFile
=
filename
;
This
->
currentFile
=
filename
;
CoTaskMemFree
(
This
->
url
);
CoTaskMemFree
(
This
->
url
);
This
->
url
=
url
;
This
->
url
=
url
;
This
->
isDirty
=
FALSE
;
This
->
isDirty
=
FALSE
;
return
S_OK
;
}
}
else
else
{
hr
=
E_OUTOFMEMORY
;
hr
=
E_OUTOFMEMORY
;
CoTaskMemFree
(
url
);
CoTaskMemFree
(
filename
);
}
/* Now we're going to read in the iconfile and iconindex.
If we don't find them, that's not a failure case -- it's possible
that they just aren't in there. */
if
(
SUCCEEDED
(
hr
))
{
IPropertyStorage
*
pPropStg
;
WCHAR
*
iconfile
;
WCHAR
*
iconindexstring
;
hr
=
IPropertySetStorage_Open
(
This
->
property_set_storage
,
&
FMTID_Intshcut
,
STGM_READWRITE
|
STGM_SHARE_EXCLUSIVE
,
&
pPropStg
);
r
=
get_profile_string
(
str_header
,
str_iconfile
,
pszFileName
,
&
iconfile
);
if
(
iconfile
!=
NULL
)
{
PROPSPEC
ps
;
PROPVARIANT
pv
;
ps
.
ulKind
=
PRSPEC_PROPID
;
ps
.
propid
=
PID_IS_ICONFILE
;
pv
.
vt
=
VT_LPWSTR
;
pv
.
pwszVal
=
iconfile
;
hr
=
IPropertyStorage_WriteMultiple
(
pPropStg
,
1
,
&
ps
,
&
pv
,
0
);
if
(
FAILED
(
hr
))
{
TRACE
(
"Failed to store the iconfile to our property storage. hr = 0x%x
\n
"
,
hr
);
}
CoTaskMemFree
(
iconfile
);
}
r
=
get_profile_string
(
str_header
,
str_iconindex
,
pszFileName
,
&
iconindexstring
);
if
(
iconindexstring
!=
NULL
)
{
int
iconindex
;
PROPSPEC
ps
;
PROPVARIANT
pv
;
char
*
iconindexastring
=
co_strdupWtoA
(
iconindexstring
);
sscanf
(
iconindexastring
,
"%d"
,
&
iconindex
);
CoTaskMemFree
(
iconindexastring
);
ps
.
ulKind
=
PRSPEC_PROPID
;
ps
.
propid
=
PID_IS_ICONINDEX
;
pv
.
vt
=
VT_I4
;
pv
.
iVal
=
iconindex
;
hr
=
IPropertyStorage_WriteMultiple
(
pPropStg
,
1
,
&
ps
,
&
pv
,
0
);
if
(
FAILED
(
hr
))
{
TRACE
(
"Failed to store the iconindex to our property storage. hr = 0x%x
\n
"
,
hr
);
}
CoTaskMemFree
(
iconfile
);
}
IPropertyStorage_Release
(
pPropStg
);
}
}
else
else
hr
=
E_OUTOFMEMORY
;
hr
=
E_OUTOFMEMORY
;
CoTaskMemFree
(
filename
);
}
}
else
else
hr
=
E_OUTOFMEMORY
;
hr
=
E_OUTOFMEMORY
;
...
...
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