* BUG: Document: Fixed a memory leak when the instanciation failed due to
  a parsing exception.
* BUG: XmlElement: Internally setting an attribute with a NULL value does
  not crash anymore.
* BUG: Encountering a never-ended attribute does not crash the parser 
  anymore.
* OPT: Optimized parser cleanup when an exception is thrown.

[GB.XML.HTML]
* BUG: Encountering a never-ended attribute does not crash the parser 
  anymore.

git-svn-id: svn://localhost/gambas/trunk@7223 867c0c6c-44f3-4631-809d-bfa615b0a4ec
This commit is contained in:
Adrien Prokopowicz 2015-08-14 08:34:56 +00:00
parent cf2a16a845
commit a327fcb807
5 changed files with 39 additions and 17 deletions

View File

@ -47,7 +47,7 @@ Document* XMLDocument_New()
} }
Document* XMLDocument_NewFromFile(const char *fileName, const size_t lenFileName, const DocumentType docType) Document* XMLDocument_NewFromFile(const char *fileName, const size_t lenFileName, const DocumentType docType) throw(XMLParseException)
{ {
Document *newDoc = (Document*)malloc(sizeof(Document)); Document *newDoc = (Document*)malloc(sizeof(Document));
@ -56,8 +56,16 @@ Document* XMLDocument_NewFromFile(const char *fileName, const size_t lenFileName
newDoc->root = 0; newDoc->root = 0;
newDoc->parentDocument = newDoc; newDoc->parentDocument = newDoc;
newDoc->docType = docType; newDoc->docType = docType;
XMLDocument_Open(newDoc, fileName, lenFileName); try
{
XMLDocument_Open(newDoc, fileName, lenFileName);
}
catch(XMLParseException ex)
{
XMLDocument_Release(newDoc);
throw ex;
}
return newDoc; return newDoc;
} }
@ -99,7 +107,7 @@ void XMLDocument_Open(Document *doc, const char *fileName, const size_t lenFileN
} }
void XMLDocument_SetContent(Document *doc, const char *content, size_t len) throw(XMLParseException) void XMLDocument_SetContent(Document *doc, const char *content, const size_t len) throw(XMLParseException)
{ {
char *posStart = 0, *posEnd = 0; char *posStart = 0, *posEnd = 0;

View File

@ -26,11 +26,11 @@
#include "utils.h" #include "utils.h"
Document* XMLDocument_New(); Document* XMLDocument_New();
Document* XMLDocument_NewFromFile(const char *fileName, const size_t lenFileName, const DocumentType docType = XMLDocumentType); Document* XMLDocument_NewFromFile(const char *fileName, const size_t lenFileName, const DocumentType docType = XMLDocumentType) throw(XMLParseException);
void XMLDocument_Release(Document *doc); void XMLDocument_Release(Document *doc);
void XMLDocument_Open(Document *doc, const char *fileName, const size_t lenFileName) throw(XMLParseException); void XMLDocument_Open(Document *doc, const char *fileName, const size_t lenFileName) throw(XMLParseException);
void XMLDocument_SetContent(Document *doc, const char *content, size_t len) throw(XMLParseException); void XMLDocument_SetContent(Document *doc, const char *content, const size_t len) throw(XMLParseException);
void XMLDocument_Save(Document *doc, const char *fileName, bool indent = false); void XMLDocument_Save(Document *doc, const char *fileName, bool indent = false);
void XMLDocument_SetRoot(Document *doc, Element *newRoot); void XMLDocument_SetRoot(Document *doc, Element *newRoot);

View File

@ -300,8 +300,11 @@ Attribute* XMLAttribute_New(const char *nattrName, const size_t nlenAttrName,
newAttr->attrName = (char*)malloc(sizeof(char)*(nlenAttrName)); newAttr->attrName = (char*)malloc(sizeof(char)*(nlenAttrName));
memcpy(newAttr->attrName, nattrName, nlenAttrName); memcpy(newAttr->attrName, nattrName, nlenAttrName);
newAttr->attrValue = (char*)malloc(nlenAttrVal); if(nattrVal && nlenAttrVal)
memcpy(newAttr->attrValue, nattrVal, nlenAttrVal); {
newAttr->attrValue = (char*)malloc(nlenAttrVal);
memcpy(newAttr->attrValue, nattrVal, nlenAttrVal);
}
return newAttr; return newAttr;
} }

View File

@ -305,7 +305,7 @@ Node** parseHTML(char const *data, const size_t lendata, size_t *nodeCount)// XM
//Seeking to the next white space or tag-end //Seeking to the next white space or tag-end
while(!(XML.isWhiteSpace(s)) && pos < endData && s != '>'){pos++; s = *pos;} while(!(XML.isWhiteSpace(s)) && pos < endData && s != '>'){pos++; s = *pos;}
delimiter = s; delimiter = s;
char* delimiterPos = (char*)memchr(pos, delimiter, endData - pos); const char* delimiterPos = (char*)memchr(pos, delimiter, endData - pos);
XML.XMLElement_AddAttribute(elmt, attrNamestart, attrNameEnd - attrNamestart, XML.XMLElement_AddAttribute(elmt, attrNamestart, attrNameEnd - attrNamestart,
pos, delimiterPos - pos); pos, delimiterPos - pos);
@ -315,7 +315,8 @@ Node** parseHTML(char const *data, const size_t lendata, size_t *nodeCount)// XM
else else
{ {
pos++; pos++;
char* delimiterPos = (char*)memchr(pos, delimiter, endData - pos); const char* delimiterPos = (char*)memchr(pos, delimiter, endData - pos);
if(!delimiterPos) delimiterPos = endData;
XML.XMLElement_AddAttribute(elmt, attrNamestart, attrNameEnd - attrNamestart, XML.XMLElement_AddAttribute(elmt, attrNamestart, attrNameEnd - attrNamestart,
pos, delimiterPos - pos); pos, delimiterPos - pos);

View File

@ -64,12 +64,16 @@ else \
XMLNode_appendChild(curElement, _elmt); \ XMLNode_appendChild(curElement, _elmt); \
} }
#define THROW(_ex) for(size_t i = 0; i < *nodeCount; i++)\ void parser_cleanup(Node **elements, size_t *nodeCount)
{\ {
XMLNode_Free(elements[i]);\ for(size_t i = *nodeCount; i --> 0;)
}\ {
free(elements);\ XMLNode_Free(elements[i]);
throw(_ex) }
free(elements);
}
#define THROW(_ex) parser_cleanup(elements, nodeCount); throw(_ex)
Node** parseXML(char const *data, const size_t lendata, size_t *nodeCount) throw(XMLParseException) Node** parseXML(char const *data, const size_t lendata, size_t *nodeCount) throw(XMLParseException)
{ {
@ -308,7 +312,13 @@ Node** parseXML(char const *data, const size_t lendata, size_t *nodeCount) throw
pos++; pos++;
char* delimiterPos = (char*)memchr(pos, delimiter, endData - pos); char* delimiterPos = (char*)memchr(pos, delimiter, endData - pos);
if(!delimiterPos)
{
THROW(XMLParseException_New("Never-ending attribute value",
data, lendata, pos - 1));
}
XMLElement_AddAttribute(elmt, attrNamestart, attrNameEnd - attrNamestart, XMLElement_AddAttribute(elmt, attrNamestart, attrNameEnd - attrNamestart,
pos, delimiterPos - pos); pos, delimiterPos - pos);
pos = delimiterPos; pos = delimiterPos;