第二人生的源码分析(六十七)LLXMLNode使用Expat库打开文件

前面介绍了什么是expat库,也介绍怎么使用它来打开XML文件进行分析,接着下来就来分析第二人生里是怎么样使用它。详细的函数代码如下:
#001 // static
#002 bool LLXMLNode::parseFile(
#003    LLString filename,
#004    LLXMLNodePtr& node,
#005    LLXMLNode* defaults_tree)
#006 {
 
下面开始调用文件函数打开文件。
#007    // Read file
#008    FILE* fp = LLFile::fopen(filename.c_str(), "rb");       /* Flawfinder: ignore */
 
下面判断文件打开是否成功。
#009    if (fp == NULL)
#010    {
#011        node = new LLXMLNode();
#012        return false;
#013    }
 
下面获取文件的长度。先把文件指针移到文件尾,然后获取当前的长度,再把文件指针移回到原来的位置。
#014    fseek(fp, 0, SEEK_END);
#015    U32 length = ftell(fp);
#016    fseek(fp, 0, SEEK_SET);
#017 
 
下面创建文件长度的数据缓冲区。
#018    U8* buffer = new U8[length+1];
 
把数据读取缓冲区里。
#019    size_t nread = fread(buffer, 1, length, fp);
#020    buffer[nread] = 0;
 
关闭文件。
#021    fclose(fp);
#022 
 
开始调用类成员函数parseBuffer来分析文件的数据。
#023    bool rv = parseBuffer(buffer, nread, node, defaults_tree);
 
删除分配的内存缓冲区。
#024    delete [] buffer;
#025    return rv;
#026 }
 
上面这个函数先把文件打开,然后获取文件的长度,接着创建一个与文件长度一样的缓冲区,把数据读取到内存缓冲区里,最后调用函数parseBuffer来分析文件的数据。简单简单的代码,就是这样直接和清晰。
 
posted @ 2008-05-20 21:04  ajuanabc  阅读(152)  评论(0)    收藏  举报