gambas-source-code/gb.xml/CDocument.cpp

239 lines
5.5 KiB
C++
Raw Normal View History

/***************************************************************************
(c) 2012 Adrien Prokopowicz <prokopy@users.sourceforge.net>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
MA 02110-1301, USA.
***************************************************************************/
#include "CDocument.h"
#include "CNode.h"
#include "node.h"
#include "document.h"
#include "element.h"
#include "utils.h"
#include "serializer.h"
#define GBTHIS (static_cast<CDocument*>(_object))
#define THIS ((Document*)(static_cast<CDocument*>(_object)->node))
BEGIN_METHOD(CDocument_new, GB_STRING fileName)
[GB.XML] OPT : A few compilation optimizations in headers inclusions. OPT : Use of separated internal classes of gambas objects. This might prevent from a lot of problems. OPT : Strings are not stored as wchar_t* anymore, but as simple char*, and are converted only when necessary (like UTF8 characters verification). OPT : Does not use STL classes anymore. They are too slow. Uses now handmade classes. OPT : Nodes are now internally linked to their brothers, so it makes find them really fasters, and allows no longer use of external linked list. OPT : When creating new nodes, linked Gambas objects are created only when necessary, so it makes internals instanciations very faster (such as the parser). OPT : Handmade string/memory classes and functions are now separated from the main.cpp component file. OPT : Use specialized memory management functions (like memcpy, memchr ...) into the parser. They are really faster than C loops, and speeds up the parser for documents that have a lot of plain text. OPT : Internally, the stream parser (XmlReader) takes only one char, not a unuseful wole string object. OPT : Does not updates debugging data when parsing a file. They will be generated only if an error is raised (not implemented yet). It will allow a speedier parser and more precise informations. BUG : When loading a document from a file, now correctly releases the file data. BUG : Solved a few XmlReader uninitialized variables, that could make the stream parser crash or returns strange results. git-svn-id: svn://localhost/gambas/trunk@4737 867c0c6c-44f3-4631-809d-bfa615b0a4ec
2012-05-17 22:49:54 +02:00
if(XMLNode_NoInstanciate()) return;
bool isHtml = false;
if(GB.Is(_object, GB.FindClass("HtmlDocument")))//Called as inherited HtmlDocument constructor
{
if(CheckHtmlInterface())
{
isHtml = true;
}
}
try
{
if(!MISSING(fileName))
{
if(isHtml)
{
GBTHIS->node = (Node*)XMLDocument_NewFromFile(STRING(fileName), LENGTH(fileName), HTMLDocumentType);
}
else
{
GBTHIS->node = (Node*)XMLDocument_NewFromFile(STRING(fileName), LENGTH(fileName));
}
}
else
{
if(isHtml)
{
GBTHIS->node = (Node*)HTML.HtmlDocument_New();
}
else
{
GBTHIS->node = (Node*)XMLDocument_New();
}
}
THIS->GBObject = (CDocument*)(_object);
}
catch(XMLParseException &e)
{
GB.Error(e.errorWhat);
GB.ReturnNull();
XMLParseException_Cleanup(&e);
}
END_METHOD
BEGIN_METHOD_VOID(CDocument_free)
XMLNode_Free(GBTHIS->node);
END_METHOD
BEGIN_METHOD(CDocument_fromString, GB_STRING content)
try
{
XMLDocument_SetContent(THIS, STRING(content), LENGTH(content));
}
catch(XMLParseException &e)
{
GB.Error(e.errorWhat);
XMLParseException_Cleanup(&e);
}
[GB.XML] OPT : A few compilation optimizations in headers inclusions. OPT : Use of separated internal classes of gambas objects. This might prevent from a lot of problems. OPT : Strings are not stored as wchar_t* anymore, but as simple char*, and are converted only when necessary (like UTF8 characters verification). OPT : Does not use STL classes anymore. They are too slow. Uses now handmade classes. OPT : Nodes are now internally linked to their brothers, so it makes find them really fasters, and allows no longer use of external linked list. OPT : When creating new nodes, linked Gambas objects are created only when necessary, so it makes internals instanciations very faster (such as the parser). OPT : Handmade string/memory classes and functions are now separated from the main.cpp component file. OPT : Use specialized memory management functions (like memcpy, memchr ...) into the parser. They are really faster than C loops, and speeds up the parser for documents that have a lot of plain text. OPT : Internally, the stream parser (XmlReader) takes only one char, not a unuseful wole string object. OPT : Does not updates debugging data when parsing a file. They will be generated only if an error is raised (not implemented yet). It will allow a speedier parser and more precise informations. BUG : When loading a document from a file, now correctly releases the file data. BUG : Solved a few XmlReader uninitialized variables, that could make the stream parser crash or returns strange results. git-svn-id: svn://localhost/gambas/trunk@4737 867c0c6c-44f3-4631-809d-bfa615b0a4ec
2012-05-17 22:49:54 +02:00
END_METHOD
BEGIN_METHOD(CDocument_tostring, GB_BOOLEAN indent)
char *str = 0;
size_t len = 0;
GBserializeNode((Node*)THIS, str, len, VARG(indent) == -1 ? 0 : -1);
GB.ReturnString(str);
END_METHOD
BEGIN_PROPERTY(CDocument_content)
if(READ_PROPERTY)
{
char *str = 0;
size_t len = 0;
GBserializeNode((Node*)THIS, str, len);
GB.ReturnString(str);
}
else
{
try
{
XMLDocument_SetContent(THIS, PSTRING(), PLENGTH());
}
catch(XMLParseException &e)
{
GB.Error(e.errorWhat);
XMLParseException_Cleanup(&e);
}
}
END_PROPERTY
BEGIN_PROPERTY(CDocument_root)
if(READ_PROPERTY)
{
XML_ReturnNode((Node*)(THIS->root));
}
else
{
XMLDocument_SetRoot(THIS, ((Element*)(VPROPOBJ(CNode)->node)));
}
END_PROPERTY
BEGIN_METHOD(CDocument_open, GB_STRING fileName)
try
{
XMLDocument_Open(THIS, STRING(fileName), LENGTH(fileName));
}
catch(XMLParseException &e)
{
GB.Error(e.errorWhat);
XMLParseException_Cleanup(&e);
}
END_METHOD
BEGIN_METHOD(CDocument_save, GB_STRING fileName; GB_BOOLEAN indent)
XMLDocument_Save(THIS, GB.ToZeroString(ARG(fileName)), VARG(indent));
END_METHOD
BEGIN_METHOD(CDocument_getElementsByTagName, GB_STRING tagName; GB_INTEGER mode; GB_INTEGER depth;)
GB_ARRAY array;
XMLNode_getGBChildrenByTagName(THIS, STRING(tagName), LENGTH(tagName), &array, VARGOPT(mode, GB_STRCOMP_BINARY), VARGOPT(depth, -1));
GB.ReturnObject(array);
END_METHOD
BEGIN_METHOD(CDocument_getElementsByNamespace, GB_STRING name; GB_INTEGER mode; GB_INTEGER depth;)
GB_ARRAY array;
XMLNode_getGBChildrenByTagName(THIS, STRING(name), LENGTH(name), &array, VARGOPT(mode, GB_STRCOMP_BINARY), VARGOPT(depth, -1));
GB.ReturnObject(array);
END_METHOD
BEGIN_PROPERTY(CDocument_getAll)
GB_ARRAY array;
XMLNode_getGBAllChildren(THIS, &array);
GB.ReturnObject(array);
END_METHOD
BEGIN_METHOD(CDocument_createElement, GB_STRING tagName)
Element *elmt = XMLElement_New(STRING(tagName), LENGTH(tagName));
XML_ReturnNode(elmt);
END_METHOD
GB_DESC CDocumentDesc[] =
{
[GB.XML] OPT : A few compilation optimizations in headers inclusions. OPT : Use of separated internal classes of gambas objects. This might prevent from a lot of problems. OPT : Strings are not stored as wchar_t* anymore, but as simple char*, and are converted only when necessary (like UTF8 characters verification). OPT : Does not use STL classes anymore. They are too slow. Uses now handmade classes. OPT : Nodes are now internally linked to their brothers, so it makes find them really fasters, and allows no longer use of external linked list. OPT : When creating new nodes, linked Gambas objects are created only when necessary, so it makes internals instanciations very faster (such as the parser). OPT : Handmade string/memory classes and functions are now separated from the main.cpp component file. OPT : Use specialized memory management functions (like memcpy, memchr ...) into the parser. They are really faster than C loops, and speeds up the parser for documents that have a lot of plain text. OPT : Internally, the stream parser (XmlReader) takes only one char, not a unuseful wole string object. OPT : Does not updates debugging data when parsing a file. They will be generated only if an error is raised (not implemented yet). It will allow a speedier parser and more precise informations. BUG : When loading a document from a file, now correctly releases the file data. BUG : Solved a few XmlReader uninitialized variables, that could make the stream parser crash or returns strange results. git-svn-id: svn://localhost/gambas/trunk@4737 867c0c6c-44f3-4631-809d-bfa615b0a4ec
2012-05-17 22:49:54 +02:00
GB_DECLARE("XmlDocument", sizeof(CDocument)),
GB_METHOD("_new", "", CDocument_new, "[(FileName)s]"),
GB_METHOD("_free", "", CDocument_free, ""),
GB_METHOD("CreateElement", "XmlElement", CDocument_createElement, "(TagName)s"),
GB_PROPERTY("Root", "XmlElement", CDocument_root),
GB_PROPERTY_READ("All", "XmlNode[]", CDocument_getAll),
GB_METHOD("GetElementsByTagName", "XmlElement[]", CDocument_getElementsByTagName, "(TagName)s[(Mode)i(Depth)i]"),
GB_METHOD("GetElementsByNamespace", "XmlElement[]", CDocument_getElementsByNamespace, "(Namespace)s[(Mode)i(Depth)i]"),
GB_PROPERTY("Content", "s", CDocument_content),
GB_METHOD("FromString", "", CDocument_fromString, "(Data)s"),
GB_METHOD("HtmlFromString", "", CDocument_fromString, "(Data)s"),
GB_METHOD("ToString", "s", CDocument_tostring, "[(Indent)b]"),
GB_METHOD("Open", "", CDocument_open, "(FileName)s"),
GB_METHOD("Save", "", CDocument_save, "(FileName)s[(Indent)b]"),
GB_METHOD("Write", "", CDocument_save, "(FileName)s[(Indent)b]"),
GB_END_DECLARE
};