msvcp110: Add tr2_sys__File_size_wchar implementation and test.
[wine/multimedia.git] / dlls / gdi32 / icm.c
blobd3a345d3bc27faea8cad656564446127491ac4a1
1 /*
2 * Image Color Management
4 * Copyright 2004 Marcus Meissner
5 * Copyright 2008 Hans Leidekker
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
22 #include "config.h"
24 #include <stdarg.h>
25 #include <string.h>
27 #include "windef.h"
28 #include "winbase.h"
29 #include "wingdi.h"
30 #include "winnls.h"
31 #include "winreg.h"
33 #include "gdi_private.h"
35 #include "wine/debug.h"
36 #include "wine/unicode.h"
38 WINE_DEFAULT_DEBUG_CHANNEL(icm);
41 struct enum_profiles
43 ICMENUMPROCA funcA;
44 LPARAM data;
47 static INT CALLBACK enum_profiles_callbackA( LPWSTR filename, LPARAM lparam )
49 int len, ret = -1;
50 struct enum_profiles *ep = (struct enum_profiles *)lparam;
51 char *filenameA;
53 len = WideCharToMultiByte( CP_ACP, 0, filename, -1, NULL, 0, NULL, NULL );
54 filenameA = HeapAlloc( GetProcessHeap(), 0, len );
55 if (filenameA)
57 WideCharToMultiByte( CP_ACP, 0, filename, -1, filenameA, len, NULL, NULL );
58 ret = ep->funcA( filenameA, ep->data );
59 HeapFree( GetProcessHeap(), 0, filenameA );
61 return ret;
64 /***********************************************************************
65 * EnumICMProfilesA (GDI32.@)
67 INT WINAPI EnumICMProfilesA(HDC hdc, ICMENUMPROCA func, LPARAM lparam)
69 struct enum_profiles ep;
71 if (!func) return -1;
72 ep.funcA = func;
73 ep.data = lparam;
74 return EnumICMProfilesW( hdc, enum_profiles_callbackA, (LPARAM)&ep );
77 /***********************************************************************
78 * EnumICMProfilesW (GDI32.@)
80 INT WINAPI EnumICMProfilesW(HDC hdc, ICMENUMPROCW func, LPARAM lparam)
82 DC *dc;
83 INT ret = -1;
85 TRACE("%p, %p, 0x%08lx\n", hdc, func, lparam);
87 if (!func) return -1;
88 if ((dc = get_dc_ptr(hdc)))
90 PHYSDEV physdev = GET_DC_PHYSDEV( dc, pEnumICMProfiles );
91 ret = physdev->funcs->pEnumICMProfiles( physdev, func, lparam );
92 release_dc_ptr(dc);
94 return ret;
97 /**********************************************************************
98 * GetICMProfileA (GDI32.@)
100 * Returns the filename of the specified device context's color
101 * management profile, even if color management is not enabled
102 * for that DC.
104 * RETURNS
105 * TRUE if filename is copied successfully.
106 * FALSE if the buffer length pointed to by size is too small.
108 * FIXME
109 * How does Windows assign these? Some registry key?
111 BOOL WINAPI GetICMProfileA(HDC hdc, LPDWORD size, LPSTR filename)
113 WCHAR filenameW[MAX_PATH];
114 DWORD buflen = MAX_PATH;
115 BOOL ret = FALSE;
117 TRACE("%p, %p, %p\n", hdc, size, filename);
119 if (!hdc || !size || !filename) return FALSE;
121 if (GetICMProfileW(hdc, &buflen, filenameW))
123 int len = WideCharToMultiByte(CP_ACP, 0, filenameW, -1, NULL, 0, NULL, NULL);
124 if (*size >= len)
126 WideCharToMultiByte(CP_ACP, 0, filenameW, -1, filename, *size, NULL, NULL);
127 ret = TRUE;
129 else SetLastError(ERROR_INSUFFICIENT_BUFFER);
130 *size = len;
132 return ret;
135 /**********************************************************************
136 * GetICMProfileW (GDI32.@)
138 BOOL WINAPI GetICMProfileW(HDC hdc, LPDWORD size, LPWSTR filename)
140 BOOL ret = FALSE;
141 DC *dc = get_dc_ptr(hdc);
143 TRACE("%p, %p, %p\n", hdc, size, filename);
145 if (dc)
147 PHYSDEV physdev = GET_DC_PHYSDEV( dc, pGetICMProfile );
148 ret = physdev->funcs->pGetICMProfile( physdev, size, filename );
149 release_dc_ptr(dc);
151 return ret;
154 /**********************************************************************
155 * GetLogColorSpaceA (GDI32.@)
157 BOOL WINAPI GetLogColorSpaceA(HCOLORSPACE colorspace, LPLOGCOLORSPACEA buffer, DWORD size)
159 FIXME("%p %p 0x%08x stub\n", colorspace, buffer, size);
160 return FALSE;
163 /**********************************************************************
164 * GetLogColorSpaceW (GDI32.@)
166 BOOL WINAPI GetLogColorSpaceW(HCOLORSPACE colorspace, LPLOGCOLORSPACEW buffer, DWORD size)
168 FIXME("%p %p 0x%08x stub\n", colorspace, buffer, size);
169 return FALSE;
172 /**********************************************************************
173 * SetICMProfileA (GDI32.@)
175 BOOL WINAPI SetICMProfileA(HDC hdc, LPSTR filename)
177 FIXME("%p %s stub\n", hdc, debugstr_a(filename));
179 if (!filename)
181 SetLastError( ERROR_INVALID_PARAMETER );
182 return FALSE;
184 if (!hdc)
186 SetLastError( ERROR_INVALID_HANDLE );
187 return FALSE;
189 return TRUE;
192 /**********************************************************************
193 * SetICMProfileW (GDI32.@)
195 BOOL WINAPI SetICMProfileW(HDC hdc, LPWSTR filename)
197 FIXME("%p %s stub\n", hdc, debugstr_w(filename));
199 if (!filename)
201 SetLastError( ERROR_INVALID_PARAMETER );
202 return FALSE;
204 if (!hdc)
206 SetLastError( ERROR_INVALID_HANDLE );
207 return FALSE;
209 return TRUE;
212 /**********************************************************************
213 * UpdateICMRegKeyA (GDI32.@)
215 BOOL WINAPI UpdateICMRegKeyA(DWORD reserved, LPSTR cmid, LPSTR filename, UINT command)
217 FIXME("0x%08x, %s, %s, 0x%08x stub\n", reserved, debugstr_a(cmid), debugstr_a(filename), command);
218 return TRUE;
221 /**********************************************************************
222 * UpdateICMRegKeyW (GDI32.@)
224 BOOL WINAPI UpdateICMRegKeyW(DWORD reserved, LPWSTR cmid, LPWSTR filename, UINT command)
226 FIXME("0x%08x, %s, %s, 0x%08x stub\n", reserved, debugstr_w(cmid), debugstr_w(filename), command);
227 return TRUE;