Piotr Caban : wininet: Support Punycode in SetUrlCacheEntryInfoW.
Alexandre Julliard
julliard at winehq.org
Mon Apr 1 13:48:42 CDT 2013
Module: wine
Branch: master
Commit: f08e79ce9252c929e345ddfce2bd1f54c36b9b61
URL: http://source.winehq.org/git/wine.git/?a=commit;h=f08e79ce9252c929e345ddfce2bd1f54c36b9b61
Author: Piotr Caban <piotr at codeweavers.com>
Date: Mon Apr 1 13:14:56 2013 +0200
wininet: Support Punycode in SetUrlCacheEntryInfoW.
---
dlls/wininet/urlcache.c | 103 ++++++++++++++---------------------------------
1 files changed, 30 insertions(+), 73 deletions(-)
diff --git a/dlls/wininet/urlcache.c b/dlls/wininet/urlcache.c
index 9759f8d..059129e 100644
--- a/dlls/wininet/urlcache.c
+++ b/dlls/wininet/urlcache.c
@@ -1351,31 +1351,31 @@ static DWORD urlcache_copy_entry(
* urlcache_set_entry_info (Internal)
*
* Helper for SetUrlCacheEntryInfo{A,W}. Sets fields in URL entry
- * according to the flags set by dwFieldControl.
+ * according to the flags set by field_control.
*
* RETURNS
* ERROR_SUCCESS if the buffer was big enough
* ERROR_INSUFFICIENT_BUFFER if the buffer was too small
*
*/
-static DWORD urlcache_set_entry_info(entry_url * pUrlEntry, const INTERNET_CACHE_ENTRY_INFOW * lpCacheEntryInfo, DWORD dwFieldControl)
+static DWORD urlcache_set_entry_info(entry_url *url_entry, const INTERNET_CACHE_ENTRY_INFOA *entry_info, DWORD field_control)
{
- if (dwFieldControl & CACHE_ENTRY_ACCTIME_FC)
- pUrlEntry->access_time = lpCacheEntryInfo->LastAccessTime;
- if (dwFieldControl & CACHE_ENTRY_ATTRIBUTE_FC)
- pUrlEntry->cache_entry_type = lpCacheEntryInfo->CacheEntryType;
- if (dwFieldControl & CACHE_ENTRY_EXEMPT_DELTA_FC)
- pUrlEntry->exempt_delta = lpCacheEntryInfo->u.dwExemptDelta;
- if (dwFieldControl & CACHE_ENTRY_EXPTIME_FC)
- file_time_to_dos_date_time(&lpCacheEntryInfo->ExpireTime, &pUrlEntry->expire_date, &pUrlEntry->expire_time);
- if (dwFieldControl & CACHE_ENTRY_HEADERINFO_FC)
+ if (field_control & CACHE_ENTRY_ACCTIME_FC)
+ url_entry->access_time = entry_info->LastAccessTime;
+ if (field_control & CACHE_ENTRY_ATTRIBUTE_FC)
+ url_entry->cache_entry_type = entry_info->CacheEntryType;
+ if (field_control & CACHE_ENTRY_EXEMPT_DELTA_FC)
+ url_entry->exempt_delta = entry_info->u.dwExemptDelta;
+ if (field_control & CACHE_ENTRY_EXPTIME_FC)
+ file_time_to_dos_date_time(&entry_info->ExpireTime, &url_entry->expire_date, &url_entry->expire_time);
+ if (field_control & CACHE_ENTRY_HEADERINFO_FC)
FIXME("CACHE_ENTRY_HEADERINFO_FC unimplemented\n");
- if (dwFieldControl & CACHE_ENTRY_HITRATE_FC)
- pUrlEntry->hit_rate = lpCacheEntryInfo->dwHitRate;
- if (dwFieldControl & CACHE_ENTRY_MODTIME_FC)
- pUrlEntry->modification_time = lpCacheEntryInfo->LastModifiedTime;
- if (dwFieldControl & CACHE_ENTRY_SYNCTIME_FC)
- file_time_to_dos_date_time(&lpCacheEntryInfo->LastAccessTime, &pUrlEntry->sync_date, &pUrlEntry->sync_time);
+ if (field_control & CACHE_ENTRY_HITRATE_FC)
+ url_entry->hit_rate = entry_info->dwHitRate;
+ if (field_control & CACHE_ENTRY_MODTIME_FC)
+ url_entry->modification_time = entry_info->LastModifiedTime;
+ if (field_control & CACHE_ENTRY_SYNCTIME_FC)
+ file_time_to_dos_date_time(&entry_info->LastAccessTime, &url_entry->sync_date, &url_entry->sync_time);
return ERROR_SUCCESS;
}
@@ -1973,10 +1973,9 @@ BOOL WINAPI GetUrlCacheEntryInfoW(LPCWSTR lpszUrl,
/***********************************************************************
* SetUrlCacheEntryInfoA (WININET.@)
*/
-BOOL WINAPI SetUrlCacheEntryInfoA(
- LPCSTR lpszUrlName,
- LPINTERNET_CACHE_ENTRY_INFOA lpCacheEntryInfo,
- DWORD dwFieldControl)
+BOOL WINAPI SetUrlCacheEntryInfoA(LPCSTR lpszUrlName,
+ LPINTERNET_CACHE_ENTRY_INFOA lpCacheEntryInfo,
+ DWORD dwFieldControl)
{
urlcache_header *pHeader;
struct hash_entry *pHashEntry;
@@ -2020,10 +2019,7 @@ BOOL WINAPI SetUrlCacheEntryInfoA(
return FALSE;
}
- urlcache_set_entry_info(
- (entry_url *)pEntry,
- (const INTERNET_CACHE_ENTRY_INFOW *)lpCacheEntryInfo,
- dwFieldControl);
+ urlcache_set_entry_info((entry_url*)pEntry, lpCacheEntryInfo, dwFieldControl);
cache_container_unlock_index(pContainer, pHeader);
@@ -2033,58 +2029,19 @@ BOOL WINAPI SetUrlCacheEntryInfoA(
/***********************************************************************
* SetUrlCacheEntryInfoW (WININET.@)
*/
-BOOL WINAPI SetUrlCacheEntryInfoW(LPCWSTR lpszUrl, LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo, DWORD dwFieldControl)
+BOOL WINAPI SetUrlCacheEntryInfoW(LPCWSTR lpszUrl,
+ LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo,
+ DWORD dwFieldControl)
{
- urlcache_header *pHeader;
- struct hash_entry *pHashEntry;
- entry_header *pEntry;
- cache_container *pContainer;
- DWORD error;
-
- TRACE("(%s, %p, 0x%08x)\n", debugstr_w(lpszUrl), lpCacheEntryInfo, dwFieldControl);
-
- error = cache_containers_findW(lpszUrl, &pContainer);
- if (error != ERROR_SUCCESS)
- {
- SetLastError(error);
- return FALSE;
- }
-
- error = cache_container_open_index(pContainer, MIN_BLOCK_NO);
- if (error != ERROR_SUCCESS)
- {
- SetLastError(error);
- return FALSE;
- }
-
- if (!(pHeader = cache_container_lock_index(pContainer)))
- return FALSE;
-
- if (!urlcache_find_hash_entryW(pHeader, lpszUrl, &pHashEntry))
- {
- cache_container_unlock_index(pContainer, pHeader);
- WARN("entry %s not found!\n", debugstr_w(lpszUrl));
- SetLastError(ERROR_FILE_NOT_FOUND);
- return FALSE;
- }
+ char *url;
+ BOOL ret;
- pEntry = (entry_header*)((LPBYTE)pHeader + pHashEntry->offset);
- if (pEntry->signature != URL_SIGNATURE)
- {
- cache_container_unlock_index(pContainer, pHeader);
- FIXME("Trying to retrieve entry of unknown format %s\n", debugstr_an((LPSTR)&pEntry->signature, sizeof(DWORD)));
- SetLastError(ERROR_FILE_NOT_FOUND);
+ if(!urlcache_encode_url_alloc(lpszUrl, &url))
return FALSE;
- }
-
- urlcache_set_entry_info(
- (entry_url *)pEntry,
- lpCacheEntryInfo,
- dwFieldControl);
-
- cache_container_unlock_index(pContainer, pHeader);
- return TRUE;
+ ret = SetUrlCacheEntryInfoA(url, (INTERNET_CACHE_ENTRY_INFOA*)lpCacheEntryInfo, dwFieldControl);
+ heap_free(url);
+ return ret;
}
/***********************************************************************
More information about the wine-cvs
mailing list