Authors: Mike McCormack <mike@codeweavers.com>, Aric Stewart <aric@codeweavers.com>
[wine/multimedia.git] / dlls / msi / suminfo.c
blob737428f4e4365030f1d226cd0682064aebf5d3b6
1 /*
2 * Implementation of the Microsoft Installer (msi.dll)
4 * Copyright 2002 Mike McCormack for CodeWeavers
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #define NONAMELESSUNION
23 #include <stdarg.h>
25 #include "windef.h"
26 #include "winbase.h"
27 #include "winreg.h"
28 #include "winnls.h"
29 #include "shlwapi.h"
30 #include "wine/debug.h"
31 #include "msi.h"
32 #include "msiquery.h"
33 #include "msipriv.h"
34 #include "objidl.h"
36 WINE_DEFAULT_DEBUG_CHANNEL(msi);
38 static const WCHAR szSumInfo[] = { 5 ,'S','u','m','m','a','r','y',
39 'I','n','f','o','r','m','a','t','i','o','n',0 };
41 static void MSI_CloseSummaryInfo( MSIOBJECTHDR *arg )
43 MSISUMMARYINFO *suminfo = (MSISUMMARYINFO *) arg;
44 IPropertyStorage_Release( suminfo->propstg );
47 UINT WINAPI MsiGetSummaryInformationA(MSIHANDLE hDatabase,
48 LPCSTR szDatabase, UINT uiUpdateCount, MSIHANDLE *phSummaryInfo)
50 LPWSTR szwDatabase = NULL;
51 UINT ret;
53 TRACE("%ld %s %d %p\n", hDatabase, debugstr_a(szDatabase),
54 uiUpdateCount, phSummaryInfo);
56 if( szDatabase )
58 UINT len = MultiByteToWideChar( CP_ACP, 0, szDatabase, -1, NULL, 0 );
59 szwDatabase = HeapAlloc( GetProcessHeap(), 0, len*sizeof(WCHAR) );
60 if( !szwDatabase )
61 return ERROR_FUNCTION_FAILED;
62 MultiByteToWideChar( CP_ACP, 0, szDatabase, -1, szwDatabase, len );
65 ret = MsiGetSummaryInformationW(hDatabase, szwDatabase, uiUpdateCount, phSummaryInfo);
67 if( szwDatabase )
68 HeapFree( GetProcessHeap(), 0, szwDatabase );
70 return ret;
73 UINT WINAPI MsiGetSummaryInformationW(MSIHANDLE hDatabase,
74 LPCWSTR szDatabase, UINT uiUpdateCount, MSIHANDLE *phSummaryInfo)
76 HRESULT r;
77 MSIHANDLE handle;
78 MSISUMMARYINFO *suminfo;
79 MSIDATABASE *db;
80 UINT ret = ERROR_SUCCESS;
81 IPropertySetStorage *psstg = NULL;
82 IPropertyStorage *ps = NULL;
83 DWORD grfMode;
85 TRACE("%ld %s %d %p\n", hDatabase, debugstr_w(szDatabase),
86 uiUpdateCount, phSummaryInfo);
88 if( !phSummaryInfo )
89 return ERROR_INVALID_PARAMETER;
91 if( szDatabase )
93 UINT res;
95 res = MSI_OpenDatabaseW(szDatabase, NULL, &db);
96 if( res != ERROR_SUCCESS )
97 return res;
99 else
101 db = msihandle2msiinfo(hDatabase, MSIHANDLETYPE_DATABASE);
102 if( !db )
103 return ERROR_INVALID_PARAMETER;
106 r = IStorage_QueryInterface( db->storage,
107 &IID_IPropertySetStorage, (LPVOID)&psstg);
108 if( FAILED( r ) )
110 ERR("IStorage -> IPropertySetStorage failed\n");
111 if (db)
112 msiobj_release(&db->hdr);
113 return ERROR_FUNCTION_FAILED;
115 ERR("storage = %p propertysetstorage = %p\n", db->storage, psstg);
117 grfMode = STGM_READ | STGM_SHARE_EXCLUSIVE;
118 r = IPropertySetStorage_Open( psstg, &FMTID_SummaryInformation, grfMode, &ps );
119 if( FAILED( r ) )
121 ERR("failed to get IPropertyStorage r=%08lx\n",r);
122 ret = ERROR_FUNCTION_FAILED;
123 goto end;
126 suminfo = alloc_msiobject( MSIHANDLETYPE_SUMMARYINFO,
127 sizeof (MSISUMMARYINFO), MSI_CloseSummaryInfo );
128 if( !suminfo )
130 ret = ERROR_FUNCTION_FAILED;
131 goto end;
134 IPropertyStorage_AddRef(ps);
135 suminfo->propstg = ps;
136 handle = alloc_msihandle( &suminfo->hdr );
137 if( handle )
138 *phSummaryInfo = handle;
139 else
140 ret = ERROR_FUNCTION_FAILED;
141 msiobj_release( &suminfo->hdr );
143 end:
144 if( ps )
145 IPropertyStorage_Release(ps);
146 if( psstg )
147 IPropertySetStorage_Release(psstg);
148 if (db)
149 msiobj_release(&db->hdr);
151 return ret;
154 UINT WINAPI MsiSummaryInfoGetPropertyCount(MSIHANDLE hSummaryInfo, UINT *pCount)
156 MSISUMMARYINFO *suminfo;
158 FIXME("%ld %p\n",hSummaryInfo, pCount);
160 suminfo = msihandle2msiinfo( hSummaryInfo, MSIHANDLETYPE_SUMMARYINFO );
161 if( !suminfo )
162 return ERROR_INVALID_HANDLE;
164 return ERROR_CALL_NOT_IMPLEMENTED;
167 UINT WINAPI MsiSummaryInfoGetPropertyA(
168 MSIHANDLE hSummaryInfo, UINT uiProperty, UINT *puiDataType, INT *piValue,
169 FILETIME *pftValue, LPSTR szValueBuf, DWORD *pcchValueBuf)
171 MSISUMMARYINFO *suminfo;
172 HRESULT r;
173 PROPSPEC spec;
174 PROPVARIANT var;
176 TRACE("%ld %d %p %p %p %p %p\n",
177 hSummaryInfo, uiProperty, puiDataType, piValue,
178 pftValue, szValueBuf, pcchValueBuf);
180 suminfo = msihandle2msiinfo( hSummaryInfo, MSIHANDLETYPE_SUMMARYINFO );
181 if( !suminfo )
182 return ERROR_INVALID_HANDLE;
184 spec.ulKind = PRSPEC_PROPID;
185 spec.u.propid = uiProperty;
187 r = IPropertyStorage_ReadMultiple( suminfo->propstg, 1, &spec, &var);
188 if( FAILED(r) )
189 return ERROR_FUNCTION_FAILED;
191 if( puiDataType )
192 *puiDataType = var.vt;
194 switch( var.vt )
196 case VT_I4:
197 if( piValue )
198 *piValue = var.u.lVal;
199 break;
200 case VT_LPSTR:
201 if( pcchValueBuf && szValueBuf )
203 lstrcpynA(szValueBuf, var.u.pszVal, *pcchValueBuf );
204 *pcchValueBuf = lstrlenA( var.u.pszVal );
206 break;
207 case VT_FILETIME:
208 if( pftValue )
209 memcpy(pftValue, &var.u.filetime, sizeof (FILETIME) );
210 break;
211 case VT_EMPTY:
212 break;
213 default:
214 FIXME("Unknown property variant type\n");
215 break;
218 return ERROR_SUCCESS;
221 UINT WINAPI MsiSummaryInfoGetPropertyW(
222 MSIHANDLE hSummaryInfo, UINT uiProperty, UINT *puiDataType, INT *piValue,
223 FILETIME *pftValue, LPWSTR szValueBuf, DWORD *pcchValueBuf)
225 FIXME("%ld %d %p %p %p %p %p\n",
226 hSummaryInfo, uiProperty, puiDataType, piValue,
227 pftValue, szValueBuf, pcchValueBuf);
229 return ERROR_CALL_NOT_IMPLEMENTED;