support of openddlparser lib without x++11.

Signed-off-by: Kim Kulling <kim.kulling@googlemail.com>
pull/502/head
Kim Kulling 2015-01-31 11:46:13 +01:00
parent 8e87613bb3
commit e1c6a16b85
6 changed files with 92 additions and 87 deletions

View File

@ -13,6 +13,7 @@ else()
endif()
add_definitions( -DOPENDDLPARSER_BUILD )
add_definitions( -DOPENDDL_NO_USE_CPP11 )
add_definitions( -D_VARIADIC_MAX=10 )
INCLUDE_DIRECTORIES(

View File

@ -32,11 +32,11 @@ DDLNode::DllNodeList DDLNode::s_allocatedNodes;
template<class T>
inline
static void releaseDataType( T *ptr ) {
if( nullptr == ptr ) {
if( ddl_nullptr == ptr ) {
return;
}
T *current( nullptr );
T *current( ddl_nullptr );
while( ptr ) {
current = ptr;
ptr = ptr->m_next;
@ -49,10 +49,10 @@ DDLNode::DDLNode( const std::string &type, const std::string &name, size_t idx,
, m_name( name )
, m_parent( parent )
, m_children()
, m_properties( nullptr )
, m_value( nullptr )
, m_properties( ddl_nullptr )
, m_value( ddl_nullptr )
, m_idx( idx )
, m_dtArrayList( nullptr ) {
, m_dtArrayList( ddl_nullptr ) {
if( m_parent ) {
m_parent->m_children.push_back( this );
}
@ -63,9 +63,9 @@ DDLNode::~DDLNode() {
releaseDataType<Value>( m_value );
delete m_dtArrayList;
m_dtArrayList = nullptr;
m_dtArrayList = ddl_nullptr;
if( s_allocatedNodes[ m_idx ] == this ) {
s_allocatedNodes[ m_idx ] = nullptr;
s_allocatedNodes[ m_idx ] = ddl_nullptr;
}
}
@ -75,7 +75,7 @@ void DDLNode::attachParent( DDLNode *parent ) {
}
m_parent = parent;
if( nullptr != m_parent ) {
if( ddl_nullptr != m_parent ) {
m_parent->m_children.push_back( this );
}
}
@ -87,7 +87,7 @@ void DDLNode::detachParent() {
if( m_parent->m_children.end() != it ) {
m_parent->m_children.erase( it );
}
m_parent = nullptr;
m_parent = ddl_nullptr;
}
}

View File

@ -73,14 +73,14 @@ static bool isIntegerType( Value::ValueType integerType ) {
}
static DDLNode *createDDLNode( Identifier *id, Property *first, OpenDDLParser *parser ) {
if( nullptr == id || nullptr == parser ) {
return nullptr;
if( nullptr == id || ddl_nullptr == parser ) {
return ddl_nullptr;
}
const std::string type( id->m_buffer );
DDLNode *parent( parser->top() );
DDLNode *node = DDLNode::create( type, "", parent );
if( nullptr != first ) {
if( ddl_nullptr != first ) {
node->setProperties( first );
}
@ -108,19 +108,19 @@ static void logMessage( LogSeverity severity, const std::string &msg ) {
OpenDDLParser::OpenDDLParser()
: m_logCallback( logMessage )
, m_ownsBuffer( false )
,m_buffer( nullptr )
, m_buffer( ddl_nullptr )
, m_len( 0 )
, m_stack()
, m_context( nullptr ) {
, m_context( ddl_nullptr ) {
// empty
}
OpenDDLParser::OpenDDLParser( char *buffer, size_t len, bool ownsIt )
: m_logCallback( &logMessage )
, m_ownsBuffer( false )
, m_buffer( nullptr )
, m_buffer( ddl_nullptr )
, m_len( 0 )
, m_context( nullptr ) {
, m_context( ddl_nullptr ) {
if( 0 != m_len ) {
setBuffer( buffer, len, ownsIt );
}
@ -147,7 +147,7 @@ OpenDDLParser::logCallback OpenDDLParser::getLogCallback() const {
void OpenDDLParser::setBuffer( char *buffer, size_t len, bool ownsIt ) {
if( m_buffer && m_ownsBuffer ) {
delete[] m_buffer;
m_buffer = nullptr;
m_buffer = ddl_nullptr;
m_len = 0;
}
@ -176,11 +176,11 @@ void OpenDDLParser::clear() {
if( m_ownsBuffer ) {
delete [] m_buffer;
}
m_buffer = nullptr;
m_buffer = ddl_nullptr;
m_len = 0;
if( m_context ) {
m_context->m_root = nullptr;
m_context->m_root = ddl_nullptr;
}
DDLNode::releaseNodes();
@ -194,7 +194,7 @@ bool OpenDDLParser::parse() {
normalizeBuffer( m_buffer, m_len );
m_context = new Context;
m_context->m_root = DDLNode::create( "root", "", nullptr );
m_context->m_root = DDLNode::create( "root", "", ddl_nullptr );
pushNode( m_context->m_root );
// do the main parsing
@ -218,7 +218,7 @@ char *OpenDDLParser::parseHeader( char *in, char *end ) {
return in;
}
Identifier *id( nullptr );
Identifier *id( ddl_nullptr );
in = OpenDDLParser::parseIdentifier( in, end, &id );
#ifdef DEBUG_HEADER_NAME
@ -228,11 +228,11 @@ char *OpenDDLParser::parseHeader( char *in, char *end ) {
#endif // DEBUG_HEADER_NAME
in = getNextToken( in, end );
Property *first( nullptr );
if( nullptr != id ) {
Property *first( ddl_nullptr );
if( ddl_nullptr != id ) {
if( *in == '(' ) {
in++;
Property *prop( nullptr ), *prev( nullptr );
Property *prop( ddl_nullptr ), *prev( ddl_nullptr );
while( *in != ')' && in != end ) {
in = parseProperty( in, end, &prop );
in = getNextToken( in, end );
@ -241,11 +241,11 @@ char *OpenDDLParser::parseHeader( char *in, char *end ) {
logInvalidTokenError( in, ")", m_logCallback );
return in;
}
if( nullptr != prop && *in != ',' ) {
if( nullptr == first ) {
if( ddl_nullptr != prop && *in != ',' ) {
if( ddl_nullptr == first ) {
first = prop;
}
if( nullptr != prev ) {
if( ddl_nullptr != prev ) {
prev->m_next = prop;
}
prev = prop;
@ -262,9 +262,9 @@ char *OpenDDLParser::parseHeader( char *in, char *end ) {
std::cerr << "nullptr returned by creating DDLNode." << std::endl;
}
Name *name( nullptr );
Name *name( ddl_nullptr );
in = OpenDDLParser::parseName( in, end, &name );
if( nullptr != name ) {
if( ddl_nullptr != name ) {
const std::string nodeName( name->m_id->m_buffer );
node->setName( nodeName );
}
@ -288,21 +288,21 @@ char *OpenDDLParser::parseStructure( char *in, char *end ) {
if( Value::ddl_none != type ) {
in = getNextToken( in, end );
if( *in == '{' ) {
DataArrayList *dtArrayList( nullptr );
Value *values( nullptr );
DataArrayList *dtArrayList( ddl_nullptr );
Value *values( ddl_nullptr );
if( 1 == arrayLen ) {
in = parseDataList( in, end, &values );
if( nullptr != values ){
if( ddl_nullptr != values ){
DDLNode *currentNode( top() );
if( nullptr != currentNode ) {
if( ddl_nullptr != currentNode ) {
currentNode->setValue( values );
}
}
} else if( arrayLen > 1 ) {
in = parseDataArrayList( in, end, &dtArrayList );
if( nullptr != dtArrayList ) {
if( ddl_nullptr != dtArrayList ) {
DDLNode *currentNode( top() );
if( nullptr != currentNode ) {
if( ddl_nullptr != currentNode ) {
currentNode->setDataArrayList( dtArrayList );
}
}
@ -341,7 +341,7 @@ void OpenDDLParser::pushNode( DDLNode *node ) {
DDLNode *OpenDDLParser::popNode() {
if( m_stack.empty() ) {
return nullptr;
return ddl_nullptr;
}
DDLNode *topNode( top() );
@ -352,7 +352,7 @@ DDLNode *OpenDDLParser::popNode() {
DDLNode *OpenDDLParser::top() {
if( m_stack.empty() ) {
return nullptr;
return ddl_nullptr;
}
DDLNode *top( m_stack.back() );
@ -361,7 +361,7 @@ DDLNode *OpenDDLParser::top() {
DDLNode *OpenDDLParser::getRoot() const {
if( nullptr == m_context ) {
return nullptr;
return ddl_nullptr;
}
return m_context->m_root;
@ -401,8 +401,8 @@ void OpenDDLParser::normalizeBuffer( char *buffer, size_t len ) {
}
char *OpenDDLParser::parseName( char *in, char *end, Name **name ) {
*name = nullptr;
if( nullptr == in || in == end ) {
*name = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -417,8 +417,8 @@ char *OpenDDLParser::parseName( char *in, char *end, Name **name ) {
ntype = LocalName;
}
Name *currentName( nullptr );
Identifier *id( nullptr );
Name *currentName( ddl_nullptr );
Identifier *id( ddl_nullptr );
in = parseIdentifier( in, end, &id );
if( id ) {
currentName = new Name( ntype, id );
@ -431,8 +431,8 @@ char *OpenDDLParser::parseName( char *in, char *end, Name **name ) {
}
char *OpenDDLParser::parseIdentifier( char *in, char *end, Identifier **id ) {
*id = nullptr;
if( nullptr == in || in == end ) {
*id = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -464,7 +464,7 @@ char *OpenDDLParser::parseIdentifier( char *in, char *end, Identifier **id ) {
char *OpenDDLParser::parsePrimitiveDataType( char *in, char *end, Value::ValueType &type, size_t &len ) {
type = Value::ddl_none;
len = 0;
if( nullptr == in || in == end ) {
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -508,7 +508,7 @@ char *OpenDDLParser::parsePrimitiveDataType( char *in, char *end, Value::ValueTy
}
char *OpenDDLParser::parseReference( char *in, char *end, std::vector<Name*> &names ) {
if( nullptr == in || in == end ) {
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -527,7 +527,7 @@ char *OpenDDLParser::parseReference( char *in, char *end, std::vector<Name*> &na
}
in = getNextToken( in, end );
Name *nextName( nullptr );
Name *nextName( ddl_nullptr );
in = parseName( in, end, &nextName );
if( nextName ) {
names.push_back( nextName );
@ -548,8 +548,8 @@ char *OpenDDLParser::parseReference( char *in, char *end, std::vector<Name*> &na
}
char *OpenDDLParser::parseBooleanLiteral( char *in, char *end, Value **boolean ) {
*boolean = nullptr;
if( nullptr == in || in == end ) {
*boolean = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -565,7 +565,7 @@ char *OpenDDLParser::parseBooleanLiteral( char *in, char *end, Value **boolean )
if( 0 != res ) {
res = ::strncmp( BoolFalse, start, strlen( BoolFalse ) );
if( 0 != res ) {
*boolean = nullptr;
*boolean = ddl_nullptr;
return in;
}
*boolean = ValueAllocator::allocPrimData( Value::ddl_bool );
@ -579,7 +579,7 @@ char *OpenDDLParser::parseBooleanLiteral( char *in, char *end, Value **boolean )
}
char *OpenDDLParser::parseIntegerLiteral( char *in, char *end, Value **integer, Value::ValueType integerType ) {
*integer = nullptr;
*integer = ddl_nullptr;
if( nullptr == in || in == end ) {
return in;
}
@ -619,8 +619,8 @@ char *OpenDDLParser::parseIntegerLiteral( char *in, char *end, Value **integer,
}
char *OpenDDLParser::parseFloatingLiteral( char *in, char *end, Value **floating ) {
*floating = nullptr;
if( nullptr == in || in == end ) {
*floating = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -652,8 +652,8 @@ char *OpenDDLParser::parseFloatingLiteral( char *in, char *end, Value **floating
}
char *OpenDDLParser::parseStringLiteral( char *in, char *end, Value **stringData ) {
*stringData = nullptr;
if( nullptr == in || in == end ) {
*stringData = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -685,8 +685,8 @@ static void createPropertyWithData( Identifier *id, Value *primData, Property **
}
char *OpenDDLParser::parseHexaLiteral( char *in, char *end, Value **data ) {
*data = nullptr;
if( nullptr == in || in == end ) {
*data = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
@ -731,20 +731,20 @@ char *OpenDDLParser::parseHexaLiteral( char *in, char *end, Value **data ) {
}
char *OpenDDLParser::parseProperty( char *in, char *end, Property **prop ) {
*prop = nullptr;
if( nullptr == in || in == end ) {
*prop = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
in = getNextToken( in, end );
Identifier *id( nullptr );
Identifier *id( ddl_nullptr );
in = parseIdentifier( in, end, &id );
if( nullptr != id ) {
in = getNextToken( in, end );
if( *in == '=' ) {
in++;
in = getNextToken( in, end );
Value *primData( nullptr );
Value *primData( ddl_nullptr );
if( isInteger( in, end ) ) {
in = parseIntegerLiteral( in, end, &primData );
createPropertyWithData( id, primData, prop );
@ -770,17 +770,17 @@ char *OpenDDLParser::parseProperty( char *in, char *end, Property **prop ) {
}
char *OpenDDLParser::parseDataList( char *in, char *end, Value **data ) {
*data = nullptr;
if( nullptr == in || in == end ) {
*data = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
in = getNextToken( in, end );
if( *in == '{' ) {
in++;
Value *current( nullptr ), *prev( nullptr );
Value *current( ddl_nullptr ), *prev( ddl_nullptr );
while( '}' != *in ) {
current = nullptr;
current = ddl_nullptr;
in = getNextToken( in, end );
if( isInteger( in, end ) ) {
in = parseIntegerLiteral( in, end, &current );
@ -792,8 +792,8 @@ char *OpenDDLParser::parseDataList( char *in, char *end, Value **data ) {
in = parseHexaLiteral( in, end, &current );
}
if( nullptr != current ) {
if( nullptr == *data ) {
if( ddl_nullptr != current ) {
if( ddl_nullptr == *data ) {
*data = current;
prev = current;
} else {
@ -814,26 +814,26 @@ char *OpenDDLParser::parseDataList( char *in, char *end, Value **data ) {
}
char *OpenDDLParser::parseDataArrayList( char *in, char *end, DataArrayList **dataList ) {
*dataList = nullptr;
if( nullptr == in || in == end ) {
*dataList = ddl_nullptr;
if( ddl_nullptr == in || in == end ) {
return in;
}
in = getNextToken( in, end );
if( *in == '{' ) {
in++;
Value *current( nullptr );
DataArrayList *prev( nullptr ), *currentDataList( nullptr );
Value *current( ddl_nullptr );
DataArrayList *prev( ddl_nullptr ), *currentDataList( ddl_nullptr );
do {
in = parseDataList( in, end, &current );
if( nullptr != current ) {
if( nullptr == prev ) {
if( ddl_nullptr != current ) {
if( ddl_nullptr == prev ) {
*dataList = new DataArrayList;
(*dataList)->m_dataList = current;
prev = *dataList;
} else {
currentDataList = new DataArrayList;
if( nullptr != prev ) {
if( ddl_nullptr != prev ) {
prev->m_next = currentDataList;
prev = currentDataList;
}

View File

@ -29,8 +29,8 @@ BEGIN_ODDLPARSER_NS
Value::Value()
: m_type( ddl_none )
, m_size( 0 )
, m_data( nullptr )
, m_next( nullptr ) {
, m_data( ddl_nullptr )
, m_next( ddl_nullptr ) {
// empty
}
@ -171,7 +171,7 @@ Value *Value::getNext() const {
Value *ValueAllocator::allocPrimData( Value::ValueType type, size_t len ) {
if( type == Value::ddl_none || Value::ddl_types_max == type ) {
return nullptr;
return ddl_nullptr;
}
Value *data = new Value;
@ -236,8 +236,7 @@ void ValueAllocator::releasePrimData( Value **data ) {
}
delete *data;
*data = nullptr;
*data = ddl_nullptr;
}
END_ODDLPARSER_NS

View File

@ -46,6 +46,12 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
BEGIN_ODDLPARSER_NS
#ifndef OPENDDL_NO_USE_CPP11
# define ddl_nullptr nullptr
#else
# define ddl_nullptr NULL
#endif
class DDLNode;
class Value;
@ -106,9 +112,9 @@ struct Property {
Property( Identifier *id )
: m_id( id )
, m_primData( nullptr )
, m_ref( nullptr )
, m_next( nullptr ) {
, m_primData( ddl_nullptr )
, m_ref( ddl_nullptr )
, m_next( ddl_nullptr ) {
// empty
}
};
@ -120,8 +126,8 @@ struct DataArrayList {
DataArrayList()
: m_numItems( 0 )
, m_dataList( nullptr )
, m_next( nullptr ) {
, m_dataList( ddl_nullptr )
, m_next( ddl_nullptr ) {
// empty
}
};
@ -131,8 +137,8 @@ struct Context {
DDLNode *m_root;
Context()
: m_properties( nullptr )
, m_root( nullptr ) {
: m_properties( ddl_nullptr )
, m_root( ddl_nullptr ) {
// empty
}
};

View File

@ -106,7 +106,6 @@ private:
bool m_ownsBuffer;
char *m_buffer;
size_t m_len;
//DDLNode *m_root;
typedef std::vector<DDLNode*> DDLNodeStack;
DDLNodeStack m_stack;
Context *m_context;