Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
6b2e7a18
Commit
6b2e7a18
authored
Jul 27, 2008
by
Piotr Caban
Committed by
Alexandre Julliard
Jul 28, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msxml3: Generalize bsc_t implementation.
parent
eb16f43b
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
339 additions
and
276 deletions
+339
-276
Makefile.in
dlls/msxml3/Makefile.in
+1
-0
bsc.c
dlls/msxml3/bsc.c
+310
-0
domdoc.c
dlls/msxml3/domdoc.c
+23
-276
msxml_private.h
dlls/msxml3/msxml_private.h
+5
-0
No files found.
dlls/msxml3/Makefile.in
View file @
6b2e7a18
...
@@ -10,6 +10,7 @@ EXTRAINCL = @XML2INCL@ @XSLTINCL@
...
@@ -10,6 +10,7 @@ EXTRAINCL = @XML2INCL@ @XSLTINCL@
C_SRCS
=
\
C_SRCS
=
\
attribute.c
\
attribute.c
\
bsc.c
\
cdata.c
\
cdata.c
\
comment.c
\
comment.c
\
docfrag.c
\
docfrag.c
\
...
...
dlls/msxml3/bsc.c
0 → 100644
View file @
6b2e7a18
/*
* Copyright 2008 Piotr Caban
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
#define COBJMACROS
#define NONAMELESSUNION
#include "config.h"
#include <stdarg.h>
#include <assert.h>
#include "windef.h"
#include "winbase.h"
#include "winuser.h"
#include "ole2.h"
#include "msxml2.h"
#include "wininet.h"
#include "urlmon.h"
#include "winreg.h"
#include "shlwapi.h"
#include "wine/debug.h"
#include "msxml_private.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
msxml
);
struct
bsc_t
{
const
struct
IBindStatusCallbackVtbl
*
lpVtbl
;
LONG
ref
;
void
*
obj
;
HRESULT
(
*
onDataAvailable
)(
void
*
,
char
*
,
DWORD
);
IBinding
*
binding
;
IStream
*
memstream
;
};
static
inline
bsc_t
*
impl_from_IBindStatusCallback
(
IBindStatusCallback
*
iface
)
{
return
(
bsc_t
*
)((
char
*
)
iface
-
FIELD_OFFSET
(
bsc_t
,
lpVtbl
));
}
static
HRESULT
WINAPI
bsc_QueryInterface
(
IBindStatusCallback
*
iface
,
REFIID
riid
,
LPVOID
*
ppobj
)
{
if
(
IsEqualGUID
(
riid
,
&
IID_IUnknown
)
||
IsEqualGUID
(
riid
,
&
IID_IBindStatusCallback
))
{
IBindStatusCallback_AddRef
(
iface
);
*
ppobj
=
iface
;
return
S_OK
;
}
FIXME
(
"interface %s not implemented
\n
"
,
debugstr_guid
(
riid
));
return
E_NOINTERFACE
;
}
static
ULONG
WINAPI
bsc_AddRef
(
IBindStatusCallback
*
iface
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
LONG
ref
=
InterlockedIncrement
(
&
This
->
ref
);
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
return
ref
;
}
static
ULONG
WINAPI
bsc_Release
(
IBindStatusCallback
*
iface
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
LONG
ref
=
InterlockedDecrement
(
&
This
->
ref
);
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
if
(
!
ref
)
{
if
(
This
->
binding
)
IBinding_Release
(
This
->
binding
);
if
(
This
->
memstream
)
IStream_Release
(
This
->
memstream
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
}
return
ref
;
}
static
HRESULT
WINAPI
bsc_OnStartBinding
(
IBindStatusCallback
*
iface
,
DWORD
dwReserved
,
IBinding
*
pib
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
HRESULT
hr
;
TRACE
(
"(%p)->(%x %p)
\n
"
,
This
,
dwReserved
,
pib
);
This
->
binding
=
pib
;
IBindStatusCallback_AddRef
(
pib
);
hr
=
CreateStreamOnHGlobal
(
NULL
,
TRUE
,
&
This
->
memstream
);
if
(
FAILED
(
hr
))
return
hr
;
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_GetPriority
(
IBindStatusCallback
*
iface
,
LONG
*
pnPriority
)
{
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnLowResource
(
IBindStatusCallback
*
iface
,
DWORD
reserved
)
{
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnProgress
(
IBindStatusCallback
*
iface
,
ULONG
ulProgress
,
ULONG
ulProgressMax
,
ULONG
ulStatusCode
,
LPCWSTR
szStatusText
)
{
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnStopBinding
(
IBindStatusCallback
*
iface
,
HRESULT
hresult
,
LPCWSTR
szError
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
HRESULT
hr
=
S_OK
;
TRACE
(
"(%p)->(%08x %s)
\n
"
,
This
,
hresult
,
debugstr_w
(
szError
));
if
(
This
->
binding
)
{
IBinding_Release
(
This
->
binding
);
This
->
binding
=
NULL
;
}
if
(
This
->
obj
&&
SUCCEEDED
(
hresult
))
{
HGLOBAL
hglobal
;
hr
=
GetHGlobalFromStream
(
This
->
memstream
,
&
hglobal
);
if
(
SUCCEEDED
(
hr
))
{
DWORD
len
=
GlobalSize
(
hglobal
);
char
*
ptr
=
GlobalLock
(
hglobal
);
hr
=
This
->
onDataAvailable
(
This
->
obj
,
ptr
,
len
);
GlobalUnlock
(
hglobal
);
}
}
return
hr
;
}
static
HRESULT
WINAPI
bsc_GetBindInfo
(
IBindStatusCallback
*
iface
,
DWORD
*
grfBINDF
,
BINDINFO
*
pbindinfo
)
{
*
grfBINDF
=
BINDF_GETNEWESTVERSION
|
BINDF_PULLDATA
|
BINDF_RESYNCHRONIZE
|
BINDF_PRAGMA_NO_CACHE
;
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnDataAvailable
(
IBindStatusCallback
*
iface
,
DWORD
grfBSCF
,
DWORD
dwSize
,
FORMATETC
*
pformatetc
,
STGMEDIUM
*
pstgmed
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
BYTE
buf
[
4096
];
DWORD
read
,
written
;
HRESULT
hr
;
TRACE
(
"(%p)->(%x %d %p %p)
\n
"
,
This
,
grfBSCF
,
dwSize
,
pformatetc
,
pstgmed
);
do
{
hr
=
IStream_Read
(
pstgmed
->
u
.
pstm
,
buf
,
sizeof
(
buf
),
&
read
);
if
(
FAILED
(
hr
))
break
;
hr
=
IStream_Write
(
This
->
memstream
,
buf
,
read
,
&
written
);
}
while
(
SUCCEEDED
(
hr
)
&&
written
!=
0
&&
read
!=
0
);
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnObjectAvailable
(
IBindStatusCallback
*
iface
,
REFIID
riid
,
IUnknown
*
punk
)
{
return
S_OK
;
}
static
const
struct
IBindStatusCallbackVtbl
bsc_vtbl
=
{
bsc_QueryInterface
,
bsc_AddRef
,
bsc_Release
,
bsc_OnStartBinding
,
bsc_GetPriority
,
bsc_OnLowResource
,
bsc_OnProgress
,
bsc_OnStopBinding
,
bsc_GetBindInfo
,
bsc_OnDataAvailable
,
bsc_OnObjectAvailable
};
HRESULT
bind_url
(
LPCWSTR
url
,
HRESULT
(
*
onDataAvailable
)(
void
*
,
char
*
,
DWORD
),
void
*
obj
,
bsc_t
**
ret
)
{
WCHAR
fileUrl
[
INTERNET_MAX_URL_LENGTH
];
bsc_t
*
bsc
;
IBindCtx
*
pbc
;
HRESULT
hr
;
TRACE
(
"%s
\n
"
,
debugstr_w
(
url
));
if
(
!
PathIsURLW
(
url
))
{
WCHAR
fullpath
[
MAX_PATH
];
DWORD
needed
=
sizeof
(
fileUrl
)
/
sizeof
(
WCHAR
);
if
(
!
PathSearchAndQualifyW
(
url
,
fullpath
,
sizeof
(
fullpath
)
/
sizeof
(
WCHAR
)))
{
WARN
(
"can't find path
\n
"
);
return
E_FAIL
;
}
if
(
FAILED
(
UrlCreateFromPathW
(
url
,
fileUrl
,
&
needed
,
0
)))
{
ERR
(
"can't create url from path
\n
"
);
return
E_FAIL
;
}
url
=
fileUrl
;
}
hr
=
CreateBindCtx
(
0
,
&
pbc
);
if
(
FAILED
(
hr
))
return
hr
;
bsc
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
bsc_t
));
bsc
->
lpVtbl
=
&
bsc_vtbl
;
bsc
->
ref
=
1
;
bsc
->
obj
=
obj
;
bsc
->
onDataAvailable
=
onDataAvailable
;
bsc
->
binding
=
NULL
;
bsc
->
memstream
=
NULL
;
hr
=
RegisterBindStatusCallback
(
pbc
,
(
IBindStatusCallback
*
)
&
bsc
->
lpVtbl
,
NULL
,
0
);
if
(
SUCCEEDED
(
hr
))
{
IMoniker
*
moniker
;
hr
=
CreateURLMoniker
(
NULL
,
url
,
&
moniker
);
if
(
SUCCEEDED
(
hr
))
{
IStream
*
stream
;
hr
=
IMoniker_BindToStorage
(
moniker
,
pbc
,
NULL
,
&
IID_IStream
,
(
LPVOID
*
)
&
stream
);
IMoniker_Release
(
moniker
);
if
(
stream
)
IStream_Release
(
stream
);
}
IBindCtx_Release
(
pbc
);
}
*
ret
=
bsc
;
return
hr
;
}
void
detach_bsc
(
bsc_t
*
bsc
)
{
if
(
bsc
->
binding
)
IBinding_Abort
(
bsc
->
binding
);
bsc
->
obj
=
NULL
;
IBindStatusCallback_Release
((
IBindStatusCallback
*
)
&
bsc
->
lpVtbl
);
}
dlls/msxml3/domdoc.c
View file @
6b2e7a18
...
@@ -32,7 +32,6 @@
...
@@ -32,7 +32,6 @@
#include "ole2.h"
#include "ole2.h"
#include "msxml2.h"
#include "msxml2.h"
#include "wininet.h"
#include "wininet.h"
#include "urlmon.h"
#include "winreg.h"
#include "winreg.h"
#include "shlwapi.h"
#include "shlwapi.h"
#include "ocidl.h"
#include "ocidl.h"
...
@@ -50,8 +49,6 @@ static const WCHAR SZ_PROPERTY_SELECTION_LANGUAGE[] = {'S','e','l','e','c','t','
...
@@ -50,8 +49,6 @@ static const WCHAR SZ_PROPERTY_SELECTION_LANGUAGE[] = {'S','e','l','e','c','t','
static
const
WCHAR
SZ_VALUE_XPATH
[]
=
{
'X'
,
'P'
,
'a'
,
't'
,
'h'
,
0
};
static
const
WCHAR
SZ_VALUE_XPATH
[]
=
{
'X'
,
'P'
,
'a'
,
't'
,
'h'
,
0
};
static
const
WCHAR
SZ_VALUE_XSLPATTERN
[]
=
{
'X'
,
'S'
,
'L'
,
'P'
,
'a'
,
't'
,
't'
,
'e'
,
'r'
,
'n'
,
0
};
static
const
WCHAR
SZ_VALUE_XSLPATTERN
[]
=
{
'X'
,
'S'
,
'L'
,
'P'
,
'a'
,
't'
,
't'
,
'e'
,
'r'
,
'n'
,
0
};
typedef
struct
bsc_t
bsc_t
;
typedef
struct
_domdoc
typedef
struct
_domdoc
{
{
const
struct
IXMLDOMDocument2Vtbl
*
lpVtbl
;
const
struct
IXMLDOMDocument2Vtbl
*
lpVtbl
;
...
@@ -80,21 +77,6 @@ typedef struct _domdoc
...
@@ -80,21 +77,6 @@ typedef struct _domdoc
DWORD
safeopt
;
DWORD
safeopt
;
}
domdoc
;
}
domdoc
;
struct
bsc_t
{
const
struct
IBindStatusCallbackVtbl
*
lpVtbl
;
LONG
ref
;
domdoc
*
doc
;
IBinding
*
binding
;
IStream
*
memstream
;
};
static
inline
bsc_t
*
impl_from_IBindStatusCallback
(
IBindStatusCallback
*
iface
)
{
return
(
bsc_t
*
)((
char
*
)
iface
-
FIELD_OFFSET
(
bsc_t
,
lpVtbl
));
}
static
xmlDocPtr
doparse
(
char
*
ptr
,
int
len
)
static
xmlDocPtr
doparse
(
char
*
ptr
,
int
len
)
{
{
#ifdef HAVE_XMLREADMEMORY
#ifdef HAVE_XMLREADMEMORY
...
@@ -109,208 +91,6 @@ static xmlDocPtr doparse( char *ptr, int len )
...
@@ -109,208 +91,6 @@ static xmlDocPtr doparse( char *ptr, int len )
#endif
#endif
}
}
static
HRESULT
WINAPI
bsc_QueryInterface
(
IBindStatusCallback
*
iface
,
REFIID
riid
,
LPVOID
*
ppobj
)
{
if
(
IsEqualGUID
(
riid
,
&
IID_IUnknown
)
||
IsEqualGUID
(
riid
,
&
IID_IBindStatusCallback
))
{
IBindStatusCallback_AddRef
(
iface
);
*
ppobj
=
iface
;
return
S_OK
;
}
FIXME
(
"interface %s not implemented
\n
"
,
debugstr_guid
(
riid
));
return
E_NOINTERFACE
;
}
static
ULONG
WINAPI
bsc_AddRef
(
IBindStatusCallback
*
iface
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
LONG
ref
=
InterlockedIncrement
(
&
This
->
ref
);
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
return
ref
;
}
static
ULONG
WINAPI
bsc_Release
(
IBindStatusCallback
*
iface
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
LONG
ref
=
InterlockedDecrement
(
&
This
->
ref
);
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
if
(
!
ref
)
{
if
(
This
->
binding
)
IBinding_Release
(
This
->
binding
);
if
(
This
->
doc
&&
This
->
doc
->
bsc
==
This
)
This
->
doc
->
bsc
=
NULL
;
if
(
This
->
memstream
)
IStream_Release
(
This
->
memstream
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
}
return
ref
;
}
static
HRESULT
WINAPI
bsc_OnStartBinding
(
IBindStatusCallback
*
iface
,
DWORD
dwReserved
,
IBinding
*
pib
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
HRESULT
hr
;
TRACE
(
"(%p)->(%x %p)
\n
"
,
This
,
dwReserved
,
pib
);
This
->
binding
=
pib
;
IBindStatusCallback_AddRef
(
pib
);
hr
=
CreateStreamOnHGlobal
(
NULL
,
TRUE
,
&
This
->
memstream
);
if
(
FAILED
(
hr
))
return
hr
;
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_GetPriority
(
IBindStatusCallback
*
iface
,
LONG
*
pnPriority
)
{
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnLowResource
(
IBindStatusCallback
*
iface
,
DWORD
reserved
)
{
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnProgress
(
IBindStatusCallback
*
iface
,
ULONG
ulProgress
,
ULONG
ulProgressMax
,
ULONG
ulStatusCode
,
LPCWSTR
szStatusText
)
{
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnStopBinding
(
IBindStatusCallback
*
iface
,
HRESULT
hresult
,
LPCWSTR
szError
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
HRESULT
hr
;
TRACE
(
"(%p)->(%08x %s)
\n
"
,
This
,
hresult
,
debugstr_w
(
szError
));
if
(
This
->
binding
)
{
IBinding_Release
(
This
->
binding
);
This
->
binding
=
NULL
;
}
if
(
This
->
doc
&&
SUCCEEDED
(
hresult
))
{
HGLOBAL
hglobal
;
hr
=
GetHGlobalFromStream
(
This
->
memstream
,
&
hglobal
);
if
(
SUCCEEDED
(
hr
))
{
DWORD
len
=
GlobalSize
(
hglobal
);
char
*
ptr
=
GlobalLock
(
hglobal
);
xmlDocPtr
xmldoc
;
if
(
len
!=
0
)
{
xmldoc
=
doparse
(
ptr
,
len
);
if
(
xmldoc
)
{
xmldoc
->
_private
=
0
;
attach_xmlnode
(
This
->
doc
->
node
,
(
xmlNodePtr
)
xmldoc
);
}
}
GlobalUnlock
(
hglobal
);
}
}
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_GetBindInfo
(
IBindStatusCallback
*
iface
,
DWORD
*
grfBINDF
,
BINDINFO
*
pbindinfo
)
{
*
grfBINDF
=
BINDF_GETNEWESTVERSION
|
BINDF_PULLDATA
|
BINDF_RESYNCHRONIZE
|
BINDF_PRAGMA_NO_CACHE
;
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnDataAvailable
(
IBindStatusCallback
*
iface
,
DWORD
grfBSCF
,
DWORD
dwSize
,
FORMATETC
*
pformatetc
,
STGMEDIUM
*
pstgmed
)
{
bsc_t
*
This
=
impl_from_IBindStatusCallback
(
iface
);
BYTE
buf
[
4096
];
DWORD
read
,
written
;
HRESULT
hr
;
TRACE
(
"(%p)->(%x %d %p %p)
\n
"
,
This
,
grfBSCF
,
dwSize
,
pformatetc
,
pstgmed
);
do
{
hr
=
IStream_Read
(
pstgmed
->
u
.
pstm
,
buf
,
sizeof
(
buf
),
&
read
);
if
(
FAILED
(
hr
))
break
;
hr
=
IStream_Write
(
This
->
memstream
,
buf
,
read
,
&
written
);
}
while
(
SUCCEEDED
(
hr
)
&&
written
!=
0
&&
read
!=
0
);
return
S_OK
;
}
static
HRESULT
WINAPI
bsc_OnObjectAvailable
(
IBindStatusCallback
*
iface
,
REFIID
riid
,
IUnknown
*
punk
)
{
return
S_OK
;
}
static
const
struct
IBindStatusCallbackVtbl
bsc_vtbl
=
{
bsc_QueryInterface
,
bsc_AddRef
,
bsc_Release
,
bsc_OnStartBinding
,
bsc_GetPriority
,
bsc_OnLowResource
,
bsc_OnProgress
,
bsc_OnStopBinding
,
bsc_GetBindInfo
,
bsc_OnDataAvailable
,
bsc_OnObjectAvailable
};
static
bsc_t
*
create_bsc
(
domdoc
*
doc
)
{
bsc_t
*
bsc
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
bsc_t
));
bsc
->
lpVtbl
=
&
bsc_vtbl
;
bsc
->
ref
=
1
;
bsc
->
doc
=
doc
;
bsc
->
binding
=
NULL
;
bsc
->
memstream
=
NULL
;
return
bsc
;
}
LONG
xmldoc_add_ref
(
xmlDocPtr
doc
)
LONG
xmldoc_add_ref
(
xmlDocPtr
doc
)
{
{
LONG
ref
=
InterlockedIncrement
((
LONG
*
)
&
doc
->
_private
);
LONG
ref
=
InterlockedIncrement
((
LONG
*
)
&
doc
->
_private
);
...
@@ -547,12 +327,8 @@ static ULONG WINAPI domdoc_Release(
...
@@ -547,12 +327,8 @@ static ULONG WINAPI domdoc_Release(
ref
=
InterlockedDecrement
(
&
This
->
ref
);
ref
=
InterlockedDecrement
(
&
This
->
ref
);
if
(
ref
==
0
)
if
(
ref
==
0
)
{
{
if
(
This
->
bsc
)
{
if
(
This
->
bsc
)
if
(
This
->
bsc
->
binding
)
detach_bsc
(
This
->
bsc
);
IBinding_Abort
(
This
->
bsc
->
binding
);
This
->
bsc
->
doc
=
NULL
;
IBindStatusCallback_Release
((
IBindStatusCallback
*
)
&
This
->
bsc
->
lpVtbl
);
}
if
(
This
->
site
)
if
(
This
->
site
)
IUnknown_Release
(
This
->
site
);
IUnknown_Release
(
This
->
site
);
...
@@ -1395,63 +1171,34 @@ static HRESULT WINAPI domdoc_nodeFromID(
...
@@ -1395,63 +1171,34 @@ static HRESULT WINAPI domdoc_nodeFromID(
return
E_NOTIMPL
;
return
E_NOTIMPL
;
}
}
static
HRESULT
do
read
(
domdoc
*
This
,
LPWSTR
filename
)
static
HRESULT
do
mdoc_onDataAvailable
(
void
*
obj
,
char
*
ptr
,
DWORD
len
)
{
{
HRESULT
hr
;
domdoc
*
This
=
obj
;
IBindCtx
*
pbc
;
xmlDocPtr
xmldoc
;
WCHAR
url
[
INTERNET_MAX_URL_LENGTH
];
TRACE
(
"%s
\n
"
,
debugstr_w
(
filename
));
if
(
!
PathIsURLW
(
filename
))
{
WCHAR
fullpath
[
MAX_PATH
];
DWORD
needed
=
sizeof
(
url
)
/
sizeof
(
WCHAR
);
if
(
!
PathSearchAndQualifyW
(
filename
,
fullpath
,
sizeof
(
fullpath
)
/
sizeof
(
WCHAR
)))
{
WARN
(
"can't find path
\n
"
);
return
E_FAIL
;
}
if
(
FAILED
(
UrlCreateFromPathW
(
fullpath
,
url
,
&
needed
,
0
)))
xmldoc
=
doparse
(
ptr
,
len
);
{
if
(
xmldoc
)
{
ERR
(
"can't create url from path
\n
"
);
xmldoc
->
_private
=
0
;
return
E_FAIL
;
attach_xmlnode
(
This
->
node
,
(
xmlNodePtr
)
xmldoc
);
}
filename
=
url
;
}
}
hr
=
CreateBindCtx
(
0
,
&
pbc
);
return
S_OK
;
if
(
SUCCEEDED
(
hr
))
}
{
if
(
This
->
bsc
)
{
if
(
This
->
bsc
->
binding
)
IBinding_Abort
(
This
->
bsc
->
binding
);
This
->
bsc
->
doc
=
NULL
;
IBindStatusCallback_Release
((
IBindStatusCallback
*
)
&
This
->
bsc
->
lpVtbl
);
}
This
->
bsc
=
create_bsc
(
This
);
static
HRESULT
doread
(
domdoc
*
This
,
LPWSTR
filename
)
{
bsc_t
*
bsc
;
HRESULT
hr
;
hr
=
RegisterBindStatusCallback
(
pbc
,
(
IBindStatusCallback
*
)
&
This
->
bsc
->
lpVtbl
,
NULL
,
0
);
hr
=
bind_url
(
filename
,
domdoc_onDataAvailable
,
This
,
&
bsc
);
if
(
SUCCEEDED
(
hr
))
if
(
FAILED
(
hr
))
{
return
hr
;
IMoniker
*
moniker
;
hr
=
CreateURLMoniker
(
NULL
,
filename
,
&
moniker
);
if
(
SUCCEEDED
(
hr
))
{
IStream
*
stream
;
hr
=
IMoniker_BindToStorage
(
moniker
,
pbc
,
NULL
,
&
IID_IStream
,
(
LPVOID
*
)
&
stream
);
IMoniker_Release
(
moniker
);
if
(
stream
)
IStream_Release
(
stream
);
}
}
IBindCtx_Release
(
pbc
);
}
return
hr
;
if
(
This
->
bsc
)
detach_bsc
(
This
->
bsc
);
This
->
bsc
=
bsc
;
return
S_OK
;
}
}
static
HRESULT
WINAPI
domdoc_load
(
static
HRESULT
WINAPI
domdoc_load
(
...
...
dlls/msxml3/msxml_private.h
View file @
6b2e7a18
...
@@ -93,6 +93,11 @@ extern HRESULT SchemaCache_create( IUnknown *pUnkOuter, LPVOID *ppObj );
...
@@ -93,6 +93,11 @@ extern HRESULT SchemaCache_create( IUnknown *pUnkOuter, LPVOID *ppObj );
extern
HRESULT
XMLDocument_create
(
IUnknown
*
pUnkOuter
,
LPVOID
*
ppObj
);
extern
HRESULT
XMLDocument_create
(
IUnknown
*
pUnkOuter
,
LPVOID
*
ppObj
);
extern
HRESULT
SAXXMLReader_create
(
IUnknown
*
pUnkOuter
,
LPVOID
*
ppObj
);
extern
HRESULT
SAXXMLReader_create
(
IUnknown
*
pUnkOuter
,
LPVOID
*
ppObj
);
typedef
struct
bsc_t
bsc_t
;
HRESULT
bind_url
(
LPCWSTR
,
HRESULT
(
*
onDataAvailable
)(
void
*
,
char
*
,
DWORD
),
void
*
,
bsc_t
**
);
void
detach_bsc
(
bsc_t
*
);
/* typelibs */
/* typelibs */
enum
tid_t
{
enum
tid_t
{
IXMLDOMAttribute_tid
,
IXMLDOMAttribute_tid
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment