您的位置:首页 > Web前端 > Node.js

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

2008-05-20 21:04 766 查看
前面介绍了什么是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来分析文件的数据。简单简单的代码,就是这样直接和清晰。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐