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
23 #include "wine/port.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
;
47 void wineXmlCallbackLog(char const* caller
, xmlErrorLevel lvl
, char const* msg
, va_list ap
)
51 enum __wine_debug_class dbcl
= __WINE_DBCL_ERR
;
55 dbcl
= __WINE_DBCL_TRACE
;
58 dbcl
= __WINE_DBCL_WARN
;
67 buf
= heap_alloc(len
);
68 needed
= vsnprintf(buf
, len
, msg
, ap
);
71 else if (needed
>= len
)
78 wine_dbg_log(dbcl
, &__wine_dbch_msxml
, caller
, "%s", buf
);
82 void wineXmlCallbackError(char const* caller
, xmlErrorPtr err
)
84 enum __wine_debug_class dbcl
;
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
)
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.
107 if(isalpha(filename
[0]) && filename
[1] == ':')
113 static void *wineXmlOpenCallback (char const * filename
)
115 BSTR sFilename
= bstr_from_xmlChar( (const xmlChar
*)filename
);
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
);
127 static int wineXmlReadCallback(void * context
, char * buffer
, int len
)
131 TRACE("%p %s %d\n", context
, buffer
, len
);
133 if ((context
== NULL
) || (buffer
== NULL
))
136 if(!ReadFile( context
, buffer
,len
, &dwBytesRead
, NULL
))
138 ERR("Failed to read file\n");
142 TRACE("Read %d\n", dwBytesRead
);
147 static int wineXmlFileCloseCallback (void * context
)
149 return CloseHandle(context
) ? 0 : -1;
155 HRESULT WINAPI
DllCanUnloadNow(void)
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
);
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);
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);
193 wine_dlclose(libxslt_handle
, NULL
, 0);
194 libxslt_handle
= NULL
;
199 BOOL WINAPI
DllMain(HINSTANCE hInstDLL
, DWORD fdwReason
, LPVOID lpv
)
201 MSXML_hInstance
= hInstDLL
;
205 case DLL_PROCESS_ATTACH
:
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");
222 DisableThreadLibraryCalls(hInstDLL
);
224 case DLL_PROCESS_DETACH
:
225 #ifdef SONAME_LIBXSLT
228 pxsltCleanupGlobals();
229 wine_dlclose(libxslt_handle
, NULL
, 0);
230 libxslt_handle
= NULL
;
234 /* Restore default Callbacks */
235 xmlCleanupInputCallbacks();
236 xmlRegisterDefaultInputCallbacks();