clock: Update Korean resource.
[wine/multimedia.git] / dlls / msxml3 / main.c
blob1201d2bed7e45e775578243c3973b576a680f3e3
1 /*
2 * MSXML Class Factory
4 * Copyright 2002 Lionel Ulmer
5 * Copyright 2005 Mike McCormack
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"
23 #include "wine/port.h"
25 #define COBJMACROS
27 #include <stdarg.h>
28 #include "windef.h"
29 #include "winbase.h"
30 #include "winuser.h"
31 #include "ole2.h"
32 #include "msxml.h"
33 #include "msxml6.h"
35 #include "wine/unicode.h"
36 #include "wine/debug.h"
37 #include "wine/library.h"
39 #include "msxml_private.h"
41 WINE_DEFAULT_DEBUG_CHANNEL(msxml);
43 HINSTANCE MSXML_hInstance = NULL;
45 #ifdef HAVE_LIBXML2
47 void wineXmlCallbackLog(char const* caller, xmlErrorLevel lvl, char const* msg, va_list ap)
49 char* buf = NULL;
50 int len = 32, needed;
51 enum __wine_debug_class dbcl = __WINE_DBCL_ERR;
52 switch (lvl)
54 case XML_ERR_NONE:
55 dbcl = __WINE_DBCL_TRACE;
56 break;
57 case XML_ERR_WARNING:
58 dbcl = __WINE_DBCL_WARN;
59 break;
60 default:
61 break;
66 heap_free(buf);
67 buf = heap_alloc(len);
68 needed = vsnprintf(buf, len, msg, ap);
69 if (needed == -1)
70 len *= 2;
71 else if (needed >= len)
72 len = needed + 1;
73 else
74 needed = 0;
76 while (needed);
78 wine_dbg_log(dbcl, &__wine_dbch_msxml, caller, "%s", buf);
79 heap_free(buf);
82 void wineXmlCallbackError(char const* caller, xmlErrorPtr err)
84 enum __wine_debug_class dbcl;
86 switch (err->level)
88 case XML_ERR_NONE: dbcl = __WINE_DBCL_TRACE; break;
89 case XML_ERR_WARNING: dbcl = __WINE_DBCL_WARN; break;
90 default: dbcl = __WINE_DBCL_ERR; break;
92 wine_dbg_log(dbcl, &__wine_dbch_msxml, caller, "%s", err->message);
95 /* Support for loading xml files from a Wine Windows drive */
96 static int wineXmlMatchCallback (char const * filename)
98 int nRet = 0;
100 TRACE("%s\n", filename);
103 * We will deal with loading XML files from the file system
104 * We only care about files that linux cannot find.
105 * e.g. C:,D: etc
107 if(isalpha(filename[0]) && filename[1] == ':')
108 nRet = 1;
110 return nRet;
113 static void *wineXmlOpenCallback (char const * filename)
115 BSTR sFilename = bstr_from_xmlChar( (const xmlChar*)filename);
116 HANDLE hFile;
118 TRACE("%s\n", debugstr_w(sFilename));
120 hFile = CreateFileW(sFilename, GENERIC_READ,FILE_SHARE_READ, NULL,
121 OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL, NULL);
122 if(hFile == INVALID_HANDLE_VALUE) hFile = 0;
123 SysFreeString(sFilename);
124 return hFile;
127 static int wineXmlReadCallback(void * context, char * buffer, int len)
129 DWORD dwBytesRead;
131 TRACE("%p %s %d\n", context, buffer, len);
133 if ((context == NULL) || (buffer == NULL))
134 return(-1);
136 if(!ReadFile( context, buffer,len, &dwBytesRead, NULL))
138 ERR("Failed to read file\n");
139 return -1;
142 TRACE("Read %d\n", dwBytesRead);
144 return dwBytesRead;
147 static int wineXmlFileCloseCallback (void * context)
149 return CloseHandle(context) ? 0 : -1;
152 #endif
155 HRESULT WINAPI DllCanUnloadNow(void)
157 return S_FALSE;
161 void* libxslt_handle = NULL;
162 #ifdef SONAME_LIBXSLT
163 # define DECL_FUNCPTR(f) typeof(f) * p##f = NULL
164 DECL_FUNCPTR(xsltApplyStylesheet);
165 DECL_FUNCPTR(xsltCleanupGlobals);
166 DECL_FUNCPTR(xsltFreeStylesheet);
167 DECL_FUNCPTR(xsltParseStylesheetDoc);
168 # undef DECL_FUNCPTR
169 #endif
171 static void init_libxslt(void)
173 #ifdef SONAME_LIBXSLT
174 void (*pxsltInit)(void); /* Missing in libxslt <= 1.1.14 */
176 libxslt_handle = wine_dlopen(SONAME_LIBXSLT, RTLD_NOW, NULL, 0);
177 if (!libxslt_handle)
178 return;
180 #define LOAD_FUNCPTR(f, needed) if ((p##f = wine_dlsym(libxslt_handle, #f, NULL, 0)) == NULL && needed) { WARN("Can't find symbol %s\n", #f); goto sym_not_found; }
181 LOAD_FUNCPTR(xsltInit, 0);
182 LOAD_FUNCPTR(xsltApplyStylesheet, 1);
183 LOAD_FUNCPTR(xsltCleanupGlobals, 1);
184 LOAD_FUNCPTR(xsltFreeStylesheet, 1);
185 LOAD_FUNCPTR(xsltParseStylesheetDoc, 1);
186 #undef LOAD_FUNCPTR
188 if (pxsltInit)
189 pxsltInit();
190 return;
192 sym_not_found:
193 wine_dlclose(libxslt_handle, NULL, 0);
194 libxslt_handle = NULL;
195 #endif
199 BOOL WINAPI DllMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpv)
201 MSXML_hInstance = hInstDLL;
203 switch(fdwReason)
205 case DLL_PROCESS_ATTACH:
206 #ifdef HAVE_LIBXML2
207 xmlInitParser();
209 /* Set the default indent character to a single tab,
210 for this thread and as default for new threads */
211 xmlTreeIndentString = "\t";
212 xmlThrDefTreeIndentString("\t");
214 /* Register callbacks for loading XML files */
215 if(xmlRegisterInputCallbacks(wineXmlMatchCallback, wineXmlOpenCallback,
216 wineXmlReadCallback, wineXmlFileCloseCallback) == -1)
217 WARN("Failed to register callbacks\n");
219 schemasInit();
220 #endif
221 init_libxslt();
222 DisableThreadLibraryCalls(hInstDLL);
223 break;
224 case DLL_PROCESS_DETACH:
225 #ifdef SONAME_LIBXSLT
226 if (libxslt_handle)
228 pxsltCleanupGlobals();
229 wine_dlclose(libxslt_handle, NULL, 0);
230 libxslt_handle = NULL;
232 #endif
233 #ifdef HAVE_LIBXML2
234 /* Restore default Callbacks */
235 xmlCleanupInputCallbacks();
236 xmlRegisterDefaultInputCallbacks();
238 xmlCleanupParser();
239 schemasCleanup();
240 #endif
241 release_typelib();
242 break;
244 return TRUE;