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
9f5748e6
Commit
9f5748e6
authored
Jul 19, 2008
by
Jacek Caban
Committed by
Alexandre Julliard
Jul 21, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wininet: Move remeining InternetQueryOption implementation to vtbl.
parent
46f26284
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
108 additions
and
121 deletions
+108
-121
internet.c
dlls/wininet/internet.c
+108
-121
No files found.
dlls/wininet/internet.c
View file @
9f5748e6
...
@@ -2066,137 +2066,90 @@ DWORD INET_QueryOption(DWORD option, void *buffer, DWORD *size, BOOL unicode)
...
@@ -2066,137 +2066,90 @@ DWORD INET_QueryOption(DWORD option, void *buffer, DWORD *size, BOOL unicode)
return
APPINFO_QueryOption
(
&
ai
.
hdr
,
INTERNET_OPTION_PROXY
,
buffer
,
size
,
unicode
);
/* FIXME */
return
APPINFO_QueryOption
(
&
ai
.
hdr
,
INTERNET_OPTION_PROXY
,
buffer
,
size
,
unicode
);
/* FIXME */
}
}
case
INTERNET_OPTION_MAX_CONNS_PER_SERVER
:
TRACE
(
"INTERNET_OPTION_MAX_CONNS_PER_SERVER
\n
"
);
if
(
*
size
<
sizeof
(
ULONG
))
return
ERROR_INSUFFICIENT_BUFFER
;
*
(
ULONG
*
)
buffer
=
2
;
*
size
=
sizeof
(
ULONG
);
return
ERROR_SUCCESS
;
case
INTERNET_OPTION_MAX_CONNS_PER_1_0_SERVER
:
TRACE
(
"INTERNET_OPTION_MAX_CONNS_1_0_SERVER
\n
"
);
if
(
*
size
<
sizeof
(
ULONG
))
return
ERROR_INSUFFICIENT_BUFFER
;
*
(
ULONG
*
)
size
=
4
;
*
size
=
sizeof
(
ULONG
);
return
ERROR_SUCCESS
;
case
INTERNET_OPTION_SECURITY_FLAGS
:
FIXME
(
"INTERNET_OPTION_SECURITY_FLAGS: Stub
\n
"
);
return
ERROR_SUCCESS
;
case
INTERNET_OPTION_VERSION
:
{
static
const
INTERNET_VERSION_INFO
info
=
{
1
,
2
};
TRACE
(
"INTERNET_OPTION_VERSION
\n
"
);
if
(
*
size
<
sizeof
(
INTERNET_VERSION_INFO
))
return
ERROR_INSUFFICIENT_BUFFER
;
memcpy
(
buffer
,
&
info
,
sizeof
(
info
));
*
size
=
sizeof
(
info
);
return
ERROR_SUCCESS
;
}
}
FIXME
(
"Stub for %d
\n
"
,
option
);
case
INTERNET_OPTION_PER_CONNECTION_OPTION
:
{
return
ERROR_INTERNET_INCORRECT_HANDLE_TYPE
;
INTERNET_PER_CONN_OPTION_LISTW
*
con
=
buffer
;
}
DWORD
res
=
ERROR_SUCCESS
,
i
;
/***********************************************************************
FIXME
(
"INTERNET_OPTION_PER_CONNECTION_OPTION stub
\n
"
);
* INET_QueryOptionHelper (internal)
*/
static
BOOL
INET_QueryOptionHelper
(
BOOL
bIsUnicode
,
HINTERNET
hInternet
,
DWORD
dwOption
,
LPVOID
lpBuffer
,
LPDWORD
lpdwBufferLength
)
{
LPWININETHANDLEHEADER
lpwhh
;
BOOL
bSuccess
=
FALSE
;
TRACE
(
"(%p, 0x%08x, %p, %p)
\n
"
,
hInternet
,
dwOption
,
lpBuffer
,
lpdwBufferLength
);
if
(
*
size
<
sizeof
(
INTERNET_PER_CONN_OPTION_LISTW
))
return
ERROR_INSUFFICIENT_BUFFER
;
lpwhh
=
WININET_GetObject
(
hInternet
);
for
(
i
=
0
;
i
<
con
->
dwOptionCount
;
i
++
)
{
INTERNET_PER_CONN_OPTIONW
*
option
=
con
->
pOptions
+
i
;
switch
(
dwOption
)
switch
(
option
->
dwOption
)
{
{
case
INTERNET_PER_CONN_FLAGS
:
case
INTERNET_OPTION_MAX_CONNS_PER_SERVER
:
option
->
Value
.
dwValue
=
PROXY_TYPE_DIRECT
;
{
break
;
ULONG
conn
=
2
;
TRACE
(
"INTERNET_OPTION_MAX_CONNS_PER_SERVER: %d
\n
"
,
conn
);
if
(
*
lpdwBufferLength
<
sizeof
(
ULONG
))
INTERNET_SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
else
{
memcpy
(
lpBuffer
,
&
conn
,
sizeof
(
ULONG
));
bSuccess
=
TRUE
;
}
*
lpdwBufferLength
=
sizeof
(
ULONG
);
break
;
}
case
INTERNET_OPTION_MAX_CONNS_PER_1_0_SERVER
:
{
ULONG
conn
=
4
;
TRACE
(
"INTERNET_OPTION_MAX_CONNS_1_0_SERVER: %d
\n
"
,
conn
);
if
(
*
lpdwBufferLength
<
sizeof
(
ULONG
))
INTERNET_SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
else
{
memcpy
(
lpBuffer
,
&
conn
,
sizeof
(
ULONG
));
bSuccess
=
TRUE
;
}
*
lpdwBufferLength
=
sizeof
(
ULONG
);
break
;
}
case
INTERNET_OPTION_SECURITY_FLAGS
:
FIXME
(
"INTERNET_OPTION_SECURITY_FLAGS: Stub
\n
"
);
bSuccess
=
TRUE
;
break
;
case
INTERNET_OPTION_VERSION
:
case
INTERNET_PER_CONN_PROXY_SERVER
:
{
case
INTERNET_PER_CONN_PROXY_BYPASS
:
TRACE
(
"INTERNET_OPTION_VERSION
\n
"
);
case
INTERNET_PER_CONN_AUTOCONFIG_URL
:
if
(
*
lpdwBufferLength
<
sizeof
(
INTERNET_VERSION_INFO
))
case
INTERNET_PER_CONN_AUTODISCOVERY_FLAGS
:
INTERNET_SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
case
INTERNET_PER_CONN_AUTOCONFIG_SECONDARY_URL
:
else
case
INTERNET_PER_CONN_AUTOCONFIG_RELOAD_DELAY_MINS
:
{
case
INTERNET_PER_CONN_AUTOCONFIG_LAST_DETECT_TIME
:
static
const
INTERNET_VERSION_INFO
info
=
{
1
,
2
};
case
INTERNET_PER_CONN_AUTOCONFIG_LAST_DETECT_URL
:
memcpy
(
lpBuffer
,
&
info
,
sizeof
(
info
));
FIXME
(
"Unhandled dwOption %d
\n
"
,
option
->
dwOption
);
*
lpdwBufferLength
=
sizeof
(
info
);
option
->
Value
.
dwValue
=
0
;
bSuccess
=
TRUE
;
res
=
ERROR_INVALID_PARAMETER
;
break
;
default:
FIXME
(
"Unknown dwOption %d
\n
"
,
option
->
dwOption
);
res
=
ERROR_INVALID_PARAMETER
;
break
;
}
}
break
;
}
}
case
INTERNET_OPTION_PER_CONNECTION_OPTION
:
FIXME
(
"INTERNET_OPTION_PER_CONNECTION_OPTION stub
\n
"
);
if
(
*
lpdwBufferLength
<
sizeof
(
INTERNET_PER_CONN_OPTION_LISTW
))
INTERNET_SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
else
{
INTERNET_PER_CONN_OPTION_LISTW
*
con
=
lpBuffer
;
int
x
;
bSuccess
=
TRUE
;
for
(
x
=
0
;
x
<
con
->
dwOptionCount
;
++
x
)
{
INTERNET_PER_CONN_OPTIONW
*
option
=
con
->
pOptions
+
x
;
switch
(
option
->
dwOption
)
{
case
INTERNET_PER_CONN_FLAGS
:
option
->
Value
.
dwValue
=
PROXY_TYPE_DIRECT
;
break
;
case
INTERNET_PER_CONN_PROXY_SERVER
:
case
INTERNET_PER_CONN_PROXY_BYPASS
:
case
INTERNET_PER_CONN_AUTOCONFIG_URL
:
case
INTERNET_PER_CONN_AUTODISCOVERY_FLAGS
:
case
INTERNET_PER_CONN_AUTOCONFIG_SECONDARY_URL
:
case
INTERNET_PER_CONN_AUTOCONFIG_RELOAD_DELAY_MINS
:
case
INTERNET_PER_CONN_AUTOCONFIG_LAST_DETECT_TIME
:
case
INTERNET_PER_CONN_AUTOCONFIG_LAST_DETECT_URL
:
FIXME
(
"Unhandled dwOption %d
\n
"
,
option
->
dwOption
);
option
->
Value
.
dwValue
=
0
;
bSuccess
=
FALSE
;
break
;
default:
FIXME
(
"Unknown dwOption %d
\n
"
,
option
->
dwOption
);
bSuccess
=
FALSE
;
break
;
}
}
if
(
!
bSuccess
)
INTERNET_SetLastError
(
ERROR_INVALID_PARAMETER
);
}
break
;
case
66
:
FIXME
(
"66
\n
"
);
bSuccess
=
TRUE
;
break
;
default:
{
DWORD
res
;
if
(
lpwhh
)
return
res
;
res
=
lpwhh
->
vtbl
->
QueryOption
(
lpwhh
,
dwOption
,
lpBuffer
,
lpdwBufferLength
,
bIsUnicode
);
}
else
res
=
INET_QueryOption
(
dwOption
,
lpBuffer
,
lpdwBufferLength
,
bIsUnicode
);
if
(
res
==
ERROR_SUCCESS
)
bSuccess
=
TRUE
;
else
SetLastError
(
res
);
}
}
}
if
(
lpwhh
)
WININET_Release
(
lpwhh
);
return
bSuccess
;
FIXME
(
"Stub for %d
\n
"
,
option
);
return
ERROR_INTERNET_INCORRECT_HANDLE_TYPE
;
}
}
/***********************************************************************
/***********************************************************************
...
@@ -2212,7 +2165,24 @@ static BOOL INET_QueryOptionHelper(BOOL bIsUnicode, HINTERNET hInternet, DWORD d
...
@@ -2212,7 +2165,24 @@ static BOOL INET_QueryOptionHelper(BOOL bIsUnicode, HINTERNET hInternet, DWORD d
BOOL
WINAPI
InternetQueryOptionW
(
HINTERNET
hInternet
,
DWORD
dwOption
,
BOOL
WINAPI
InternetQueryOptionW
(
HINTERNET
hInternet
,
DWORD
dwOption
,
LPVOID
lpBuffer
,
LPDWORD
lpdwBufferLength
)
LPVOID
lpBuffer
,
LPDWORD
lpdwBufferLength
)
{
{
return
INET_QueryOptionHelper
(
TRUE
,
hInternet
,
dwOption
,
lpBuffer
,
lpdwBufferLength
);
LPWININETHANDLEHEADER
hdr
;
DWORD
res
=
ERROR_INVALID_HANDLE
;
TRACE
(
"%p %d %p %p
\n
"
,
hInternet
,
dwOption
,
lpBuffer
,
lpdwBufferLength
);
if
(
hInternet
)
{
hdr
=
WININET_GetObject
(
hInternet
);
if
(
hdr
)
{
res
=
hdr
->
vtbl
->
QueryOption
(
hdr
,
dwOption
,
lpBuffer
,
lpdwBufferLength
,
TRUE
);
WININET_Release
(
hdr
);
}
}
else
{
res
=
INET_QueryOption
(
dwOption
,
lpBuffer
,
lpdwBufferLength
,
TRUE
);
}
if
(
res
!=
ERROR_SUCCESS
)
SetLastError
(
res
);
return
res
==
ERROR_SUCCESS
;
}
}
/***********************************************************************
/***********************************************************************
...
@@ -2228,7 +2198,24 @@ BOOL WINAPI InternetQueryOptionW(HINTERNET hInternet, DWORD dwOption,
...
@@ -2228,7 +2198,24 @@ BOOL WINAPI InternetQueryOptionW(HINTERNET hInternet, DWORD dwOption,
BOOL
WINAPI
InternetQueryOptionA
(
HINTERNET
hInternet
,
DWORD
dwOption
,
BOOL
WINAPI
InternetQueryOptionA
(
HINTERNET
hInternet
,
DWORD
dwOption
,
LPVOID
lpBuffer
,
LPDWORD
lpdwBufferLength
)
LPVOID
lpBuffer
,
LPDWORD
lpdwBufferLength
)
{
{
return
INET_QueryOptionHelper
(
FALSE
,
hInternet
,
dwOption
,
lpBuffer
,
lpdwBufferLength
);
LPWININETHANDLEHEADER
hdr
;
DWORD
res
=
ERROR_INVALID_HANDLE
;
TRACE
(
"%p %d %p %p
\n
"
,
hInternet
,
dwOption
,
lpBuffer
,
lpdwBufferLength
);
if
(
hInternet
)
{
hdr
=
WININET_GetObject
(
hInternet
);
if
(
hdr
)
{
res
=
hdr
->
vtbl
->
QueryOption
(
hdr
,
dwOption
,
lpBuffer
,
lpdwBufferLength
,
FALSE
);
WININET_Release
(
hdr
);
}
}
else
{
res
=
INET_QueryOption
(
dwOption
,
lpBuffer
,
lpdwBufferLength
,
FALSE
);
}
if
(
res
!=
ERROR_SUCCESS
)
SetLastError
(
res
);
return
res
==
ERROR_SUCCESS
;
}
}
...
...
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