2016-03-28 35 views
1

私は特定のXML設定を使用するC++アプリケーションを持っています。この設定には再帰的ノードがあります。例えば、SubStrategyは、Strategyノードを有することができ、ノードは、別のノードを有することができる。SubStrategyノード。Xerces-C++で再帰的XMLスキーマ(XSD)を解析中にSegフォールト

<?xml version="1.0" encoding="UTF-8"?> 
<CONF xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="rfq.xsd"> 
     <SubStrategy name="ss1"> 
       <Strategy> 
         <SubStrategy name="ss2"/> 
       </Strategy> 
     </SubStrategy> 
     <SubStrategy name="ss3"> 
     </SubStrategy> 
</CONF> 

私は同じスキーマを持っていますが、私のアプリはロード中にクラッシュしています。 gdbのバックトレースを見ると、再帰的なスキーマの検証がうまくいかないことがわかります。以下 がScehma

<?xml version="1.0" encoding="UTF-8"?> 
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"> 
     <xs:element name="SubStrategy"> 
       <xs:complexType mixed="true"> 
         <xs:sequence> 
           <xs:element ref="Strategy" minOccurs="0"/> 
         </xs:sequence> 
         <xs:attribute name="name" type="xs:string" use="required"> 
         </xs:attribute> 
       </xs:complexType> 
     </xs:element> 
     <xs:element name="Strategy"> 
       <xs:complexType> 
         <xs:sequence> 
           <xs:element ref="SubStrategy"/> 
         </xs:sequence> 
       </xs:complexType> 
     </xs:element> 
     <xs:element name="CONF"> 
       <xs:complexType> 
         <xs:sequence> 
           <xs:element ref="SubStrategy" maxOccurs="unbounded"/> 
         </xs:sequence> 
       </xs:complexType> 
     </xs:element> 
</xs:schema> 

GDBバックトレース

#0 0x00007ffff6619ee6 in _int_malloc() from /usr/lib64/libc.so.6 
#1 0x00007ffff661c11c in malloc() from /usr/lib64/libc.so.6 
#2 0x00007ffff6ed40cd in operator new(unsigned long)() from /usr/lib64/libstdc++.so.6 
#3 0x00007ffff6f327e9 in std::string::_Rep::_S_create(unsigned long, unsigned long, std::allocator<char> const&)() from /usr/lib64/libstdc++.so.6 
#4 0x00007ffff6f3342b in std::string::_Rep::_M_clone(std::allocator<char> const&, unsigned long)() from /usr/lib64/libstdc++.so.6 
#5 0x00007ffff6f334d4 in std::string::reserve(unsigned long)() from /usr/lib64/libstdc++.so.6 
#6 0x00007ffff7bcf468 in push_back (__c=<optimized out>, this=<optimized out>) 
    at /usr/lib/gcc/x86_64-redhat-linux/4.1.2/../../../../include/c++/4.1.2/bits/basic_string.h:858 
#7 operator+= (__c=<optimized out>, this=<optimized out>) at /usr/lib/gcc/x86_64-redhat-linux/4.1.2/../../../../include/c++/4.1.2/bits/basic_string.h:777 
#8 XMLCh_ToString (s=<optimized out>, n="") at /local_dev/cdmi_bmt/../ConfigFile/src/Test.cpp:75 
#9 0x00007ffff7bc1877 in ConfigFileImp::processSchemaElem (this=0x6273e0, curElem=..., 
    rootname_="CONF.**SubStrategy.Strategy.SubStrategy.Strategy.SubStrategy.Strategy.SubStrategy.Strategy.SubStrategy.Strategy.SubStrategy.Strategy.SubStrategy.Strategy.SubStrategy.Strategy.SubStrategy.Strategy**.SubStr"...) at /local_dev/cdmi_bmt/configFile.cpp:1591 

である私は、内部XERCES-C++バージョン3.1.1を使用するXMLパーサのためのサードパーティ製のラッパーを使用しています。私の質問は、XERCES-Cでスキーマ内で再帰を使用する方法を知っているか、あるいはXERCESで既知の問題であるかどうかです。 apacheページに関連する情報が見つかりませんでした。

答えて

1

XMLまたはXSDに問題はありません。あなたのXMLはあなたのXSDに対して有効です。

Xercesは再帰的XMLスキーマをうまく処理できます。

あなたやあなたが使っている "ラッパー"は、おそらく解析コールバックの中から誤って解析を再呼び出ししている可能性があります。これは、Xercesのフォールト(XMLやXSDのフォールト)ではありません。それはXercesがどのように使われているかの問題です。