Subjects
Home
VOTE Move XML Commons to Xerces
Commented: (XERCESJ 589) Bug with pattern restriction on long strings
: Xerces J 2 8 1 Release on Wednesday, September 13th
: Xerces J 2 9 0 Release on Wednesday, November 22nd
Commented: (XERCESJ 1066) Restriction+choice+substitutionGroup error
Commented: (XERCESJ 1178) Error getting prefix for an attribute with no n
Updated: (XERCESJ 1244) XMLSchemaValidator does not contribute element 's
Some consideration about the xerces DOM implementation
Updated: (XERCESJ 1066) Restriction+choice+substitutionGroup error
Commented: (XERCESJ 1227) Poor performance / OutOfMemoryError for sequenc
retain exception stack traces
Updated: (XERCESJ 1193) NPE or hang when parsing using the "continue afte
Future of NekoHTML
Commented: (XERCESJ 1203) NPE in XMLDTDProcessor
DOM Level 3 APIs for Xalan J and a new Xalan release (2 7 1)
: xml commons external 1 3 04 Release on Wednesday, November 22nd
Commented: (XERCESJ 1247) Incorrect location information on SAX when usin
XInclude exceptions how to mirror Xerces J functionality into Xerces C++?
First proposal on SoC project "Add support for the StAX (JSR 173) cursor API
: xml commons resolver 1 2 Release on Wednesday, November 22nd
Typo in RangeToken java Please check
Validator features
java lang ClassCastException when adopting Node
using the org apache xerces impl xs identity package
Updated: (XERCESJ 1257) buffer overflow in UTF8Reader for characters out
Problem with ref attributes and schema validation
Updated: (XERCESJ 122) XMLSchemaValidator does not contribute element 's d
Performance problem under load Xerces with Weblogic 9 x
remove ignored memory allocation
Commented: (XERCESJ 1177) SAXXMLStreamReader doesn 't always report namesp
Commented: (XERCESJ 977) Null pointer exception during DOM parsing
Commented: (XERCESJ 1197) Code cleanup for org apache xml serialize
Commented: (XERCESJ 1201) Initial contribution for StAX Event API
Updated: (XERCESJ 1061) Regex "$ " and "^ " characters treated as special c
Commented: (XERCESJ 1199) SAXXMLStreamReader should attempt to register a
Commented: (XERCESJ 1061) Regex "$ " and "^ " characters treated as special
Updated: (XERCESJ 589) Bug with pattern restriction on long strings
StackOverflow
xerces Range unnecessarily not garbage collectable if not detached
Updated: (XERCESJ 1178) Error getting prefix for an attribute with no nam
Bug in xs:redefine
Commented: (XERCESJ 1204) Can not set XMLEntityResolver for LSParser
Updated: (XERCESJ 1253) Prototype for SoC2007 project "Add support for th
Updated: (XERCESJ 1259) Add SteamFilter Function to SoC2007 project "Add
Assigned: (XERCESJ 444) SAXException thrown by EntityResolver is reported
Google Summer of Code 2007
Xerces J and XInclude relative path issue
Assigned: (XERCESJ 206) Stack overflow when using a schema validation
Commented: (XERCESJ 1215) Restrictions involving two levels of substituti
Closed: (XERCESJ 1203) NPE in XMLDTDProcessor
non overriding equals methoda
Resolved: (XERCESJ 1079) invalid value returned for TOTALDIGITS facet in
Xerces AS3 port
Updated: (XERCESJ 325) Regular Expression; Pattern "| " clause order de
Updated: (XERCESJ 1196) Javadoc generation fails on Java SE 5 0
Closed: (XERCESJ 1202) DTD validation on XIncluded documents when the sch
Created: (XERCESJ 1124) Nonspecific schema error message
a bug in xerces
Updated: (XERCESJ 1201) Initial contribution for StAX Event API
Closed: (XERCESJ 1254) Empty uris in targetNamespace attribute not report
Links
Home
Oracle database error code
 
Search:  
Power your search with and, or, +, -, or "some phrase" operators.
My first proposal on SoC project "Add support for the StAX (JSR-173) cursor API

My first proposal on SoC project "Add support for the StAX (JSR-173) cursor API

2007-03-31       - By wei duan

Hello,Everyone,

      I'm a student applying for SoC
<http://code.google.com/soc/>projectAdd support for the StAX(JSR-173)
cursor API to Xerces-J<http://wiki.apache.org/general/SummerOfCode2007>.
Michael suggested I could discuss my proposal in the mailing list. So I
would like to introduce my thoughts and plan on this student project, any
comments are welcomed. : )

       The abstract description of project is: "To design and implement the
cursor-based XMLStreamReader<http://java.sun.com/javase/6/docs/api/javax/xml
/stream/XMLStreamReader.html>(and
[image:
[WWW]] filtering<http://java.sun.com/javase/6/docs/api/javax/xml/stream
/StreamFilter.html>support).
It should be possible to accomplish this using
XNI <http://xerces.apache.org/xerces2-j/xni.html> by building the
XMLStreamReader<http://java.sun.com/javase/6/docs/api/javax/xml/stream
/XMLStreamReader.html>on
top of anXMLPullParserConfiguration<http://xerces.apache.org/xerces2-j/javadocs
/xni/org/apache/xerces/xni/parser/XMLPullParserConfiguration.html>."


Besides XNI, there are several ways to implement StAX interface. For
example, parse the XML document as raw text and start from scratch,
including parsing characters, building token, and interpreting tokens, and
so on. Or to implement a converter from existing DOM or SAX interfaces.
However, after reading Xerces sources code, I found both SAX and DOM
implementations are based on XNI, so it's very natural to build StAX on XNI.


To implement XMLStreamReader, two important preconditions should be
confirmed.

1.       XML event information can be received.

2.       The pull style parsing process can be simulated.

When I look through the XNI interfaces, I found it actually meets these two
preconditions. The handler interfaces in XNI such as XMLDocumentHandler and
XMLDTDHandler can get XML events including startDocument and endDocument,
which can be easily mapped to StAX events accordingly.
XMLPullParserConfiguration<http://xerces.apache.org/xerces2-j/javadocs/xni/org
/apache/xerces/xni/parser/XMLPullParserConfiguration.html>interface
in XNI is used to represent a parser configuration that can be
used as the configuration for a "pull" parser, thus the pull parsing process
of StAX can be simulated by calling "boolean parse(boolean)" method in
XMLPullParserConfiguration<http://xerces.apache.org/xerces2-j/javadocs/xni/org
/apache/xerces/xni/parser/XMLPullParserConfiguration.html>
.

Then I looked through the current Xerces Implementation, I found
AbstractXMLDocumentParser class implements XMLDocumentHandler,
XMLDTDHandler, and XMLDTDContentModelHandler interfaces. Both
AbstractDOMParser and AbstractSAXParser extend from
AbstractXMLDocumentParser. So I think  I can implement an AbstractStAXParser
extending AbstractXMLDocumentParser to get XML events.

For example, code in current AbstractSAXParser:

*    public void comment(XMLString text, Augmentations augs) throws
XNIException { *

*        try {*

*            // SAX2 extension*

*            if (fLexicalHandler != null) {*

*                fLexicalHandler.comment(text.ch, 0, text.length);*

*            }*

*        }*

*        catch (SAXException e) {*

*            throw new XNIException(e);*

*        }*

*     } // comment(XMLString)*



And in my AbstractStAXPaser, it may be implemented like this,

*   public class AbstractStAXParser extends AbstractXMLDocumentParser {*

*        public int m_curEventType;*

*        public String m_characters;*

*       ….*

*       public void comment(XMLString text, Augmentations augs) throws
XNIException {*

*              m_curEventType = XMLStreamConstants.COMMENT;*

*              m_characters = new String(text.ch, text.offset, text.length);
*

*       }*

*      … *

*  }*

*
*

Meanwhile, XMLPullParserConfiguration<http://xerces.apache.org/xerces2-j
/javadocs/xni/org/apache/xerces/xni/parser/XMLPullParserConfiguration.html>will
be used to control the parsing process. XML11Configuration is the
implementation of XMLPullParserConfiguration interface in Xerces. I think I
can implement StAXPaserConfiguration which extends from XML11Configuration
for XML1.0 and XML 1.1. In runtime, AbstractStAXParser will be set as the
handlers of the StAXParserConfiguration instance.

As for XMLStreamReader, it can be implemented as this,

*public class StAXXMLStreamReaderr implements XMLStreamReader {*

*       public StAXPaserConfiguration m_configuration;*

*       public StAXParser m_parser;*

*       ….*

*      int getEventType<http://java.sun.com/javase/6/docs/api/javax/xml/stream
/XMLStreamReader.html#getEventType%28%29>
()*

*{*

*    return m_parser.m_curEventType;*

*     }
*

*int next<http://java.sun.com/javase/6/docs/api/javax/xml/stream
/XMLStreamReader.html#getEventType%28%29>
()*

*{*

*    m_configuration.parse(false)*

*return m_parser.m_curEventType;;*

*}*

*… *

*}*



     Above are some of my rough thoughts, so if you have any comments and
questions, I would like to discuss with you.



Thanks, Wei



<p><span style="font-size: 12pt;" lang="EN-US">Hello</span><span style="font
-size: 12pt;">,</span><span style="font-size: 12pt;" lang="EN-US">Everyone,<
/span></p>

<p><span style="font-size: 12pt;" lang="EN-US"><span>&nbsp; &nbsp;&nbsp; &nbsp;
</span>I&#39;m a student applying for <a href="http://code.google.com/soc/"
target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">SoC </a
>project
<a href="http://wiki.apache.org/general/SummerOfCode2007" target="_blank"
onclick="return top.js.OpenExtLink(window,event,this)"> Add support for the
StAX(JSR-173) cursor API to Xerces-J</a>.
<span>Michael suggested I could discuss my
proposal in the mailing list. So I would like to introduce my thoughts and plan
on
this student project, any comments are welcomed</span></span><span style="font
-size: 12pt;" lang="EN-US"><span>.</span></span><span style="font-size: 12pt;"
lang="EN-US"><span> : ) </span><span><ins cite="mailto:home" datetime="2007-03
-31T14:27">
</ins></span></span></p>



<p><span lang="EN-US">&nbsp;<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><
/span><span style="font-size: 12pt;" lang="EN-US">The abstract description
of project is:</span><span style="font-size: 12pt;" lang="EN-US"> &quot;To
design and implement the cursor-based<a href="http://java.sun.com/javase/6/docs
/api/javax/xml/stream/XMLStreamReader.html" target="_blank" onclick="return top
.js.OpenExtLink(window,event,this)"><span style="color: windowtext; text
-decoration: none;">
<span></span></span><span style="color: windowtext; text-decoration: none;">
XMLStreamReader</span></a>
(and <a href="http://java.sun.com/javase/6/docs/api/javax/xml/stream
/StreamFilter.html" target="_blank" onclick="return top.js.OpenExtLink(window
,event,this)"><span style="color: windowtext; text-decoration: none;"><span>
<img alt="[WWW]" border="0" height="11" width="11">
</span></span><span style="color: windowtext; text-decoration: none;">filtering
</span></a>
support). It should be possible to accomplish this using <a href="http://xerces
.apache.org/xerces2-j/xni.html" target="_blank" onclick="return top.js
.OpenExtLink(window,event,this)"><span style="color: windowtext; text-decoration
: none;">
</span><span style="color: windowtext; text-decoration: none;">
XNI</span></a>
by building the <a href="http://java.sun.com/javase/6/docs/api/javax/xml/stream
/XMLStreamReader.html" target="_blank" onclick="return top.js.OpenExtLink(window
,event,this)"><span style="color: windowtext; text-decoration: none;">
<span></span></span><span style="color: windowtext; text-decoration: none;">
XMLStreamReader</span></a>
on top of an<a href="http://xerces.apache.org/xerces2-j/javadocs/xni/org/apache
/xerces/xni/parser/XMLPullParserConfiguration.html" target="_blank" onclick=
"return top.js.OpenExtLink(window,event,this)"><span style="color: windowtext;
text-decoration: none;">
<span></span></span><span style="color: windowtext; text-decoration: none;">
XMLPullParserConfiguration</span></a>.&quot;
</span></p>





<p style="text-indent: 24pt;"><span style="font-size: 12pt;" lang="EN-US"
>Besides XNI, there
are several ways to implement StAX interface. For example, parse the XML
document
as raw text and start from scratch, including parsing characters, building
token, and interpreting tokens, and so on. Or to implement a converter from
existing
DOM or SAX interfaces. However, after reading Xerces sources code, I found both
SAX and DOM implementations are based on XNI, so it&#39;s very natural to build
StAX on XNI.<span>&nbsp;&nbsp; </span><span>&nbsp;</span>&nbsp;</span></p>

<p style="text-indent: 24pt;"><span style="font-size: 12pt;" lang="EN-US">To
implement
XMLStreamReader, two important preconditions should be confirmed.</span></p>

<p style="margin-left: 42pt; text-indent: -18pt;"><span style="font-size: 12pt;
" lang="EN-US"><span>1.<span style="font-style: normal; font-variant: normal;
font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust:
none; font-stretch: normal;">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
</span></span></span><span style="font-size: 12pt;" lang="EN-US">XML event
information can be received.</span></p>

<p style="margin-left: 42pt; text-indent: -18pt;"><span style="font-size: 12pt;
" lang="EN-US"><span>2.<span style="font-style: normal; font-variant: normal;
font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust:
none; font-stretch: normal;">

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
</span></span></span><span style="font-size: 12pt;" lang="EN-US">The pull style
parsing process can be simulated. </span></p>

<p style="text-indent: 24pt;"><span style="font-size: 12pt;" lang="EN-US">When
I look
through the XNI interfaces, I found it actually meets these two preconditions.
The
handler interfaces in XNI such as XMLDocumentHandler and XMLDTDHandler can get
XML events including startDocument and endDocument, which can be easily mapped
to StAX events accordingly. <a href="http://xerces.apache.org/xerces2-j
/javadocs/xni/org/apache/xerces/xni/parser/XMLPullParserConfiguration.html"
title="interface in org.apache.xerces.xni.parser" target="_blank" onclick=
"return top.js.OpenExtLink(window,event,this)">
<span style="color: windowtext; text-decoration: none;">
XMLPullParserConfiguration</span></a>
interface in XNI is used to represent a parser configuration that can be used
as the configuration for a &quot;pull&quot; parser, thus the pull parsing
process of StAX can be simulated by calling &quot;boolean parse(boolean)&quot;
method in <a href="http://xerces.apache.org/xerces2-j/javadocs/xni/org/apache
/xerces/xni/parser/XMLPullParserConfiguration.html" title="interface in org
.apache.xerces.xni.parser" target="_blank" onclick="return top.js.OpenExtLink
(window,event,this)">

<span style="color: windowtext; text-decoration: none;"
>XMLPullParserConfiguration</span></a>
<span>&nbsp;</span>.<span>&nbsp;&nbsp;
</span></span></p>



<p style="text-indent: 24pt;"><span style="font-size: 12pt;" lang="EN-US">Then
I looked
through the current Xerces Implementation, I found AbstractXMLDocumentParser
class implements XMLDocumentHandler, XMLDTDHandler, and
XMLDTDContentModelHandler
interfaces. Both AbstractDOMParser and AbstractSAXParser extend from
AbstractXMLDocumentParser.
So I think&nbsp; I can implement an AbstractStAXParser extending
AbstractXMLDocumentParser to get XML events. </span></p>



<p style="text-indent: 24pt;"><span style="font-size: 12pt;" lang="EN-US">For
example, code
in current AbstractSAXParser:</span></p>



<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
</span>public void
comment(XMLString text, Augmentations augs) throws XNIException {&nbsp;</span><
/i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp; </span>try {</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>//
SAX2 extension</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>if
(fLexicalHandler != null) {</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
</span>fLexicalHandler.comment(text.ch, 0, text.length);</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>}</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp; </span>}</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp; </span>catch
(SAXException e) {</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
</span>throw new XNIException(e);</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp; </span>}</span></i></p><p style="text-indent: 21.75pt;"
><i><span lang="EN-US"><span>
&nbsp;&nbsp;&nbsp; </span>} //
comment(XMLString)</span></i></p>

<p style="text-indent: 21.75pt;"><span lang="EN-US">&nbsp;</span></p>

<p style="text-indent: 24pt;"><span style="font-size: 12pt;" lang="EN-US">And in
my AbstractStAXPaser, it may be implemented like this,<br></span></p><p style=
"text-indent: 21.75pt;"><i><span lang="EN-US"><span style="font-style: italic;">
&nbsp;&nbsp; </span>public class AbstractStAXParser extends
AbstractXMLDocumentParser
{</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp; &nbsp;&nbsp; </span>public int
m_curEventType;</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp; <
/span><span>&nbsp;</span> &nbsp;&nbsp; public String m_characters;</span></i></p
>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp; &nbsp
; &nbsp; </span>….</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp; &nbsp;</span><span style="font-style: italic;"><span style="font-style:
italic;"> </span></span>public void
comment(XMLString text, Augmentations augs) throws XNIException {</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>m
_curEventType
= XMLStreamConstants.COMMENT;</span></i></p>



<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>m_characters
= new String(text.ch, text.offset, text.length);<span>&nbsp;</span></span></i><
/p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp; &nbsp
; &nbsp; </span>}</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp; &nbsp
;&nbsp; </span>… </span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span style="font-style:
italic;">&nbsp; </span>}</span></i></p><p style="text-indent: 21.75pt;"><i>
<span lang="EN-US"><br></span></i></p><p style="text-indent: 24pt;"><span style=
"font-size: 12pt;" lang="EN-US">
Meanwhile, <a href="http://xerces.apache.org/xerces2-j/javadocs/xni/org/apache
/xerces/xni/parser/XMLPullParserConfiguration.html" title="interface in org
.apache.xerces.xni.parser" target="_blank" onclick="return top.js.OpenExtLink
(window,event,this)">

<span style="color: windowtext; text-decoration: none;"
>XMLPullParserConfiguration</span></a>
will be used to control the parsing process. XML11Configuration is the
implementation
of XMLPullParserConfiguration interface in Xerces. I think I can implement
StAXPaserConfiguration which extends from XML11Configuration for XML1.0 and XML
1.1. In runtime, AbstractStAXParser will be set as the handlers of the
StAXParserConfiguration
instance. </span></p>

<p style="text-indent: 24pt;"><span style="font-size: 12pt;" lang="EN-US">As for
XMLStreamReader, it can be implemented as this,<br></span></p>



<p style="text-indent: 21.75pt;"><i><span lang="EN-US">public class
StAXXMLStreamReaderr implements XMLStreamReader
{</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp; </span>public StAXPaserConfiguration
m_configuration;</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp; &nbsp;
&nbsp;&nbsp; </span>public StAXParser
m_parser;</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;&nbsp; &nbsp
; &nbsp; </span>….</span></i></p>

<p style="text-indent: 21.75pt;"><i><span lang="EN-US"><span>&nbsp;</span><span
> &nbsp; &nbsp; </span>int <a href="http://java.sun.com/javase/6/docs/api/javax
/xml/stream/XMLStreamReader.html#getEventType%28%29" target="_blank" onclick=
"return top.js.OpenExtLink(window,event,this)">

<span style="color: windowtext; text-decoration: none;">getEventType</span></a>
()</span></i></p>

<p style="text-indent: 37.5pt;"><i><span lang="EN-US">{</span></i></p>

<p style="text-indent: 37.5pt;"><i><span lang="EN-US"><span>&nbsp; </span><span
>&nbsp; </span>return m_parser.m_curEventType;</span></i></p>



<p style="text-indent: 21.75pt;"><i><span lang="EN-US">&nbsp;&nbsp;&nbsp;&nbsp;
}<br><span></span></span></i></p>

<p style="text-indent: 37.5pt;"><i><span lang="EN-US">int <a href="http://java
.sun.com/javase/6/docs/api/javax/xml/stream/XMLStreamReader.html#getEventType%28
%29" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">
<span style="color: windowtext; text-decoration: none;">
next</span></a>()</span></i></p>

<p style="text-indent: 37.5pt;"><i><span lang="EN-US">{</span></i></p>

<p style="text-indent: 37.5pt;"><i><span lang="EN-US"><span>&nbsp; </span><span
>&nbsp;
</span>m_configuration.parse(false)</span></i></p>

<p style="text-indent: 53.25pt;"><i><span lang="EN-US">return m_parser.m
_curEventType;;</span></i></p>

<p style="text-indent: 36.75pt;"><i><span lang="EN-US">}</span></i></p>

<p style="text-indent: 36.75pt;"><i><span lang="EN-US">… </span></i></p>

<p style="text-indent: 21pt;"><i><span lang="EN-US">}</span></i></p>

<p><span style="font-size: 12pt;" lang="EN-US">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<br></span></p><p><span style="font-size: 12pt;" lang="EN-US">&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp; Above are some of my rough thoughts, so if you have any comments
and questions, I would like to discuss with you.
<br></span></p><p><span style="font-size: 12pt;" lang="EN-US">&nbsp;</span></p>

<p><span style="font-size: 12pt;" lang="EN-US">Thanks, Wei</span></p>