2014-06-05 10:24:12 +08:00
|
|
|
#include "CocoLoader.h"
|
|
|
|
|
2014-06-18 11:54:25 +08:00
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
using namespace rapidjson;
|
|
|
|
|
|
|
|
namespace cocostudio{
|
2014-06-05 10:24:12 +08:00
|
|
|
|
2014-06-18 11:54:25 +08:00
|
|
|
|
|
|
|
const char* kTypeNames[] = { "Null", "False", "True", "Object", "Array", "String", "Number" };
|
|
|
|
const char* kObjKeyName[] = { "__type" , "classname" };
|
|
|
|
char g_Buff[2048];
|
|
|
|
|
|
|
|
Type stExpCocoNode::GetType(CocoLoader* pCoco)
|
|
|
|
{
|
|
|
|
Type tType = kObjectType;
|
|
|
|
if(m_ObjIndex >= 0)
|
|
|
|
{
|
|
|
|
stExpCocoObjectDesc* tpCocoObjectDesc = pCoco->GetCocoObjectDescArray();
|
|
|
|
if( m_AttribIndex >= 0 )
|
|
|
|
{
|
|
|
|
stExpCocoAttribDesc* tpAttribDescArray = (stExpCocoAttribDesc*) tpCocoObjectDesc[m_ObjIndex].m_pAttribDescArray;
|
|
|
|
tType = tpAttribDescArray[m_AttribIndex].m_Type;
|
|
|
|
|
|
|
|
if(kFalseType == tType || kTrueType == tType)
|
|
|
|
{
|
|
|
|
char* szValue = (char*)m_szValue;
|
|
|
|
if(szValue[0] == '0')
|
|
|
|
{
|
|
|
|
return kFalseType;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return kTrueType;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
tType = kObjectType;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if(m_AttribIndex >= 0)
|
|
|
|
{
|
|
|
|
tType = (Type)m_ChildNum;
|
|
|
|
|
|
|
|
if(kFalseType == tType || kTrueType == tType)
|
|
|
|
{
|
2014-06-11 09:35:24 +08:00
|
|
|
char* szValue = (char*)m_szValue;
|
2014-06-18 11:54:25 +08:00
|
|
|
if(szValue[0] == '0')
|
2014-06-11 09:35:24 +08:00
|
|
|
{
|
2014-06-18 11:54:25 +08:00
|
|
|
return kFalseType;
|
2014-06-11 09:35:24 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-06-18 11:54:25 +08:00
|
|
|
return kTrueType;
|
2014-06-11 09:35:24 +08:00
|
|
|
}
|
2014-06-18 11:54:25 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
tType = kArrayType;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return tType;
|
|
|
|
}
|
|
|
|
|
|
|
|
char* stExpCocoNode::GetName(CocoLoader* pCoco)
|
|
|
|
{
|
|
|
|
char* szName = NULL ;
|
|
|
|
if(m_ObjIndex >= 0)
|
|
|
|
{
|
|
|
|
stExpCocoObjectDesc* tpCocoObjectDesc = pCoco->GetCocoObjectDescArray();
|
|
|
|
if( m_AttribIndex >= 0 )
|
|
|
|
{
|
|
|
|
stExpCocoAttribDesc* tpAttribDescArray = (stExpCocoAttribDesc*) tpCocoObjectDesc[m_ObjIndex].m_pAttribDescArray;
|
|
|
|
szName = (char*)tpAttribDescArray[m_AttribIndex].m_szName;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
char* szValue = (char*)m_szValue;
|
|
|
|
if(szValue[0])
|
2014-06-11 09:35:24 +08:00
|
|
|
{
|
2014-06-18 11:54:25 +08:00
|
|
|
szName = (char*)m_szValue;
|
2014-06-11 09:35:24 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-06-18 11:54:25 +08:00
|
|
|
szName = (char*)tpCocoObjectDesc[m_ObjIndex].m_szName;
|
2014-06-11 09:35:24 +08:00
|
|
|
}
|
2014-06-18 11:54:25 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if(m_AttribIndex >= 0)
|
2014-06-11 09:35:24 +08:00
|
|
|
{
|
2014-06-18 11:54:25 +08:00
|
|
|
char* pStringAddr = (char*)pCoco->GetCocoObjectDescArray() + pCoco->GetFileHeader()->m_lStringMemAddr ;
|
|
|
|
szName = m_ChildArray + pStringAddr;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
szName = (char*)m_szValue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return szName ;
|
|
|
|
}
|
2014-06-11 09:35:24 +08:00
|
|
|
|
2014-06-18 11:54:25 +08:00
|
|
|
char* stExpCocoNode::GetValue()
|
|
|
|
{
|
|
|
|
return (char*)m_szValue;
|
|
|
|
}
|
|
|
|
|
|
|
|
int stExpCocoNode::GetChildNum()
|
|
|
|
{
|
|
|
|
return m_ChildNum;
|
|
|
|
}
|
|
|
|
|
|
|
|
stExpCocoNode* stExpCocoNode::GetChildArray()
|
|
|
|
{
|
|
|
|
return (stExpCocoNode*)m_ChildArray;
|
|
|
|
}
|
|
|
|
|
|
|
|
void stExpCocoNode::ReBuild(char* pCocoNodeAddr,char* pStringMemoryAddr)
|
|
|
|
{
|
|
|
|
m_szValue = m_szValue + (uint64_t)pStringMemoryAddr;
|
|
|
|
if( -1 == m_AttribIndex )
|
|
|
|
{
|
|
|
|
if(m_ChildNum > 0)
|
|
|
|
{
|
|
|
|
m_ChildArray = m_ChildArray + (uint64_t)pCocoNodeAddr;
|
|
|
|
|
|
|
|
stExpCocoNode* tpChildArray = (stExpCocoNode*)m_ChildArray;
|
|
|
|
for(int i = 0 ; i < m_ChildNum ; i++)
|
|
|
|
{
|
|
|
|
tpChildArray[i].ReBuild(pCocoNodeAddr,pStringMemoryAddr);
|
2014-06-11 09:35:24 +08:00
|
|
|
}
|
|
|
|
}
|
2014-06-18 11:54:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2014-06-05 10:24:12 +08:00
|
|
|
|
2014-06-18 11:54:25 +08:00
|
|
|
CocoLoader::CocoLoader()
|
|
|
|
{
|
|
|
|
m_pRootNode = NULL;
|
|
|
|
m_pObjectDescArray = NULL;
|
2014-06-05 10:24:12 +08:00
|
|
|
}
|
|
|
|
|
2014-06-18 11:54:25 +08:00
|
|
|
CocoLoader::~CocoLoader()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bool CocoLoader::ReadCocoBinBuff(char* pBinBuff)
|
|
|
|
{
|
|
|
|
char* pTempBuff = pBinBuff;
|
|
|
|
|
|
|
|
m_pFileHeader = (stCocoFileHeader*)pTempBuff;
|
|
|
|
pTempBuff += sizeof(stCocoFileHeader);
|
|
|
|
|
|
|
|
char* pStartAddr = pTempBuff;
|
|
|
|
m_pObjectDescArray = (stExpCocoObjectDesc*)pStartAddr;
|
|
|
|
|
|
|
|
char* pAttrAddr = pStartAddr + m_pFileHeader->m_lAttribMemAddr ;
|
|
|
|
char* pCocoMemAddr = pStartAddr + m_pFileHeader->m_CocoNodeMemAddr;
|
|
|
|
char* pStringAddr = pStartAddr + m_pFileHeader->m_lStringMemAddr ;
|
|
|
|
|
|
|
|
m_pRootNode = (stExpCocoNode*)pCocoMemAddr;
|
|
|
|
|
|
|
|
if(1 == m_pFileHeader->m_nFirstUsed)
|
|
|
|
{
|
|
|
|
for(int i = 0 ; i < m_pFileHeader->m_ObjectCount ; i++)
|
|
|
|
{
|
|
|
|
m_pObjectDescArray[i].ReBuild(pAttrAddr,pStringAddr) ;
|
|
|
|
}
|
|
|
|
m_pRootNode->ReBuild(pCocoMemAddr,pStringAddr);
|
|
|
|
|
|
|
|
m_pFileHeader->m_nFirstUsed = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
stExpCocoObjectDesc* CocoLoader::GetCocoObjectDesc(const char* szObjDesc)
|
|
|
|
{
|
|
|
|
for(int i = 0 ; i < m_pFileHeader->m_ObjectCount ; i++)
|
|
|
|
{
|
|
|
|
if(0 == strcmp((char*)m_pObjectDescArray[i].m_szName,szObjDesc))
|
|
|
|
{
|
|
|
|
return &m_pObjectDescArray[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|