/*
*
* (c) COPYRIGHT MIT and INRIA, 1996-2001
* Please first read the full copyright statement in file COPYRIGHT.
*
*/
/*
*
* fetchXMLname
*
* Author: I. Vatton
*
*/
#define THOT_EXPORT extern
#include "amaya.h"
#include "parser.h"
#include "HTMLnames.h"
#include "MathMLnames.h"
#include "GraphMLnames.h"
#include "XLinknames.h"
/* define some pointers to let other parser functions access the local table */
int HTML_ENTRIES = (sizeof(XHTMLElemMappingTable) / sizeof(ElemMapping));
ElemMapping *pHTMLGIMapping = XHTMLElemMappingTable;
AttributeMapping *pHTMLAttributeMapping = XHTMLAttributeMappingTable;
XmlEntity *pXhtmlEntityTable = XhtmlEntityTable;
XmlEntity *pMathEntityTable = MathEntityTable;
#include "fetchXMLname_f.h"
/* Global variables used by the entity mapping */
static int XHTMLSup = 0;
static int MathSup = 0;
/*----------------------------------------------------------------------
GetXHTMLSSchema returns the XHTML Thot schema for document doc.
----------------------------------------------------------------------*/
SSchema GetXHTMLSSchema (Document doc)
{
SSchema XHTMLSSchema;
XHTMLSSchema = TtaGetSSchema (TEXT("HTML"), doc);
if (XHTMLSSchema == NULL)
XHTMLSSchema = TtaNewNature(doc, TtaGetDocumentSSchema(doc),
TEXT("HTML"), TEXT("HTMLP"));
return (XHTMLSSchema);
}
/*----------------------------------------------------------------------
GetMathMLSSchema returns the MathML Thot schema for document doc.
----------------------------------------------------------------------*/
SSchema GetMathMLSSchema (Document doc)
{
SSchema MathMLSSchema;
MathMLSSchema = TtaGetSSchema (TEXT("MathML"), doc);
if (MathMLSSchema == NULL)
MathMLSSchema = TtaNewNature(doc,
TtaGetDocumentSSchema(doc), TEXT("MathML"),
TEXT("MathMLP"));
return (MathMLSSchema);
}
/*----------------------------------------------------------------------
GetGraphMLSSchema returns the GraphML Thot schema for document doc.
----------------------------------------------------------------------*/
SSchema GetGraphMLSSchema (Document doc)
{
SSchema GraphMLSSchema;
GraphMLSSchema = TtaGetSSchema (TEXT("GraphML"), doc);
if (GraphMLSSchema == NULL)
GraphMLSSchema = TtaNewNature(doc,
TtaGetDocumentSSchema(doc), TEXT("GraphML"),
TEXT("GraphMLP"));
return (GraphMLSSchema);
}
/*----------------------------------------------------------------------
GetXLinkSSchema returns the XLink Thot schema for document doc.
----------------------------------------------------------------------*/
SSchema GetXLinkSSchema (Document doc)
{
SSchema XLinkSSchema;
XLinkSSchema = TtaGetSSchema (TEXT("XLink"), doc);
if (XLinkSSchema == NULL)
XLinkSSchema = TtaNewNature(doc, TtaGetDocumentSSchema(doc), TEXT("XLink"),
TEXT("XLinkP"));
return (XLinkSSchema);
}
/*----------------------------------------------------------------------
GetXMLSSchema returns the XML Thot schema for document doc.
----------------------------------------------------------------------*/
SSchema GetXMLSSchema (int XMLtype, Document doc)
{
if (XMLtype == XHTML_TYPE)
return GetXHTMLSSchema (doc);
else if (XMLtype == MATH_TYPE)
return GetMathMLSSchema (doc);
else if (XMLtype == GRAPH_TYPE)
return GetGraphMLSSchema (doc);
else if (XMLtype == XLINK_TYPE)
return GetXLinkSSchema (doc);
else
return NULL;
}
/*----------------------------------------------------------------------
MapXMLElementType
Generic function which searchs in the Element Mapping table, selected
by the parameter XMLtype, the entry XMLname and returns the corresponding
Thot element type.
Returns:
- ElTypeNum and ElSSchema into elType ElTypeNum = 0 if not found.
- content
----------------------------------------------------------------------*/
void MapXMLElementType (int XMLtype,
STRING XMLname,
ElementType *elType,
STRING *mappedName,
CHAR_T *content,
ThotBool *highEnoughLevel,
Document doc)
{
int i;
ElemMapping *ptr;
/* Initialize variables */
*mappedName = NULL;
*highEnoughLevel = TRUE;
elType->ElTypeNum = 0;
/* Select the right table */
if (XMLtype == XHTML_TYPE)
ptr = XHTMLElemMappingTable;
else if (XMLtype == MATH_TYPE)
{
if (ParsingLevel[doc] == L_Basic && DocumentTypes[doc] == docHTML)
{
/* Maths are not allowed in this document */
ptr = NULL;
*highEnoughLevel = FALSE;
}
else
ptr = MathMLElemMappingTable;
}
else if (XMLtype == GRAPH_TYPE)
{
if (ParsingLevel[doc] == L_Basic && DocumentTypes[doc] == docHTML)
{
/* Graphics are not allowed in this document */
ptr = NULL;
*highEnoughLevel = FALSE;
}
else
ptr = GraphMLElemMappingTable;
}
else
ptr = NULL;
if (ptr != NULL)
{
/* search in the ElemMappingTable */
i = 0;
/* look for the first concerned entry in the table */
while (ptr[i].XMLname[0] < XMLname[0] && ptr[i].XMLname[0] != WC_EOS)
i++;
/* look at all entries starting with the right character */
do
if (ustrcmp (ptr[i].XMLname, XMLname))
/* it's not the tag */
i++;
else if (ParsingLevel[doc] != L_Other &&
ptr[i].Level > ParsingLevel[doc])
{
/* this tag is not valid for the current parsing level */
*highEnoughLevel = FALSE;
i++;
}
else
{
elType->ElTypeNum = ptr[i].ThotType;
if (elType->ElSSchema == NULL)
elType->ElSSchema = GetXMLSSchema (XMLtype, doc);
*mappedName = ptr[i].XMLname;
*content = ptr[i].XMLcontents;
}
while (elType->ElTypeNum <= 0 && ptr[i].XMLname[0] == XMLname[0]);
}
}
/*----------------------------------------------------------------------
GetXMLElementName
Generic function which searchs in the mapping table the XML name for
a given Thot type.
----------------------------------------------------------------------*/
CHAR_T* GetXMLElementName (ElementType elType, Document doc)
{
ElemMapping *ptr;
STRING name;
int i;
ThotBool invalid = FALSE;
if (elType.ElTypeNum > 0)
{
i = 0;
/* Select the table which matches with the element schema */
name = TtaGetSSchemaName (elType.ElSSchema);
if (ustrcmp (TEXT("MathML"), name) == 0)
ptr = MathMLElemMappingTable;
else if (ustrcmp (TEXT("GraphML"), name) == 0)
ptr = GraphMLElemMappingTable;
else
ptr = XHTMLElemMappingTable;
if (ptr)
do
{
if (ptr[i].ThotType == elType.ElTypeNum)
{
if (doc == 0 ||
ParsingLevel[doc] == L_Other ||
ptr[i].Level <= ParsingLevel[doc])
return ptr[i].XMLname;
else
invalid = TRUE;
}
i++;
}
while (ptr[i].XMLname[0] != WC_EOS);
}
if (invalid)
return TEXT("");
else
return TEXT("???");
}
/*----------------------------------------------------------------------
IsXMLElementInline
Generic function which searchs in the mapping table if a given
Thot type is an inline character or not
----------------------------------------------------------------------*/
ThotBool IsXMLElementInline (ElementType elType)
{
int i;
ThotBool ret = FALSE;
STRING name;
ElemMapping *ptr;
if (elType.ElTypeNum > 0)
{
i = 0;
/* Select the table which matches with the element schema */
name = TtaGetSSchemaName (elType.ElSSchema);
if (ustrcmp (TEXT("MathML"), name) == 0)
ptr = MathMLElemMappingTable;
else if (ustrcmp (TEXT("GraphML"), name) == 0)
ptr = GraphMLElemMappingTable;
else
ptr = XHTMLElemMappingTable;
if (ptr)
{
while (ptr[i].XMLname[0] != WC_EOS &&
ptr[i].ThotType != elType.ElTypeNum)
i++;
if (ptr[i].ThotType == elType.ElTypeNum)
ret = ptr[i].Inline;
}
}
return ret;
}
/*----------------------------------------------------------------------
MapXMLAttribute
Generic function which searchs in the Attribute Mapping Table (table)
the entry attrName associated to the element elementName.
Returns the corresponding entry or -1.
----------------------------------------------------------------------*/
int MapXMLAttribute (int XMLtype, CHAR_T *attrName,
CHAR_T *elementName, ThotBool *highEnoughLevel,
Document doc, int *thotType)
{
int i;
AttributeMapping *ptr;
/* Initialization */
*highEnoughLevel = TRUE;
i = 1;
*thotType = 0;
/* Select the right table */
if (XMLtype == XHTML_TYPE)
ptr = XHTMLAttributeMappingTable;
else if (XMLtype == MATH_TYPE)
ptr = MathMLAttributeMappingTable;
else if (XMLtype == GRAPH_TYPE)
ptr = GraphMLAttributeMappingTable;
else if (XMLtype == XLINK_TYPE)
ptr = XLinkAttributeMappingTable;
else
ptr = NULL;
if (ptr == NULL)
return -1;
/* look for the first concerned entry in the table */
while (ptr[i].XMLattribute[0] < attrName[0] &&
ptr[i].XMLattribute[0] != WC_EOS)
i++;
while (ptr[i].XMLattribute[0] == attrName[0])
{
if (ustrcmp (ptr[i].XMLattribute, attrName) ||
(ptr[i].XMLelement[0] != WC_EOS &&
ustrcmp (ptr[i].XMLelement, elementName)))
i++;
else if (ptr[i].Level > ParsingLevel[doc])
{
*highEnoughLevel = FALSE;
i++;
}
else
{
*thotType = ptr[i].ThotAttribute;
return (i);
}
}
return (-1);
}
/*----------------------------------------------------------------------
GetXMLAttributeName
Generic function which searchs in the mapping table the XML name for
a given Thot type.
----------------------------------------------------------------------*/
CHAR_T* GetXMLAttributeName (AttributeType attrType,
ElementType elType,
Document doc)
{
AttributeMapping *ptr;
STRING name, tag;
int i;
ThotBool invalid = FALSE;
if (attrType.AttrTypeNum > 0)
{
/* get the specific element tag */
if (elType.ElTypeNum > 0)
tag = GetXMLElementName (elType, doc);
else
tag = TEXT("");
i = 0;
/* Select the table which matches with the element schema */
name = TtaGetSSchemaName (attrType.AttrSSchema);
if (ustrcmp (TEXT("MathML"), name) == 0)
ptr = MathMLAttributeMappingTable;
else if (ustrcmp (TEXT("GraphML"), name) == 0)
ptr = GraphMLAttributeMappingTable;
else if (ustrcmp (TEXT("XLink"), name) == 0)
ptr = XLinkAttributeMappingTable;
else
ptr = XHTMLAttributeMappingTable;
if (ptr)
do
{
if (ptr[i].ThotAttribute == attrType.AttrTypeNum &&
(ptr[i].XMLelement[0] == WC_EOS ||
!ustrcmp (ptr[i].XMLelement, tag)))
{
if (doc == 0 || ptr[i].Level <= ParsingLevel[doc])
return ptr[i].XMLattribute;
else
invalid = TRUE;
}
i++;
}
while (ptr[i].XMLattribute[0] != WC_EOS);
}
if (invalid)
return TEXT("");
else
return TEXT("???");
}
/*----------------------------------------------------------------------
MapXMLEntity
Generic function which searchs in the Entity Mapping Table (table)
the entry entityName and give the corresponding decimal value.
Returns FALSE if entityName is not found.
----------------------------------------------------------------------*/
ThotBool MapXMLEntity (int XMLtype, STRING entityName, int *entityValue)
{
XmlEntity *ptr;
ThotBool found;
int inf, sup, med, rescomp;
/* Initialization */
found = FALSE;
/* Select the right table */
if (XMLtype == XHTML_TYPE)
{
ptr = XhtmlEntityTable;
if (XHTMLSup == 0)
for (XHTMLSup = 0; ptr[XHTMLSup].charCode > 0; XHTMLSup++);
sup = XHTMLSup;
}
else if (XMLtype == MATH_TYPE)
{
ptr = MathEntityTable;
if (MathSup == 0)
for (MathSup = 0; ptr[MathSup].charCode > 0; MathSup++);
sup = MathSup;
}
else
ptr = NULL;
if (ptr == NULL)
return found;
inf = 0;
while (sup >= inf && !found)
/* Dichotomic research */
{
med = (sup + inf) / 2;
rescomp = ustrcmp (ptr[med].charName, entityName);
if (rescomp == 0)
{
/* entity found */
*entityValue = ptr[med].charCode;
found = TRUE;
}
else
{
if (rescomp > 0)
sup = med - 1;
else
inf = med + 1;
}
}
return found;
}
/*----------------------------------------------------------------------
MapEntityByCode
Generic function which searchs in the Entity Mapping Table (table)
the entry with code entityValue and give the corresponding name.
Returns FALSE if entityValue is not found.
----------------------------------------------------------------------*/
CHAR_T* MapEntityByCode (int XMLtype, int entityValue)
{
XmlEntity *ptr;
ThotBool found;
int i;
/* Select the right table */
if (XMLtype == XHTML_TYPE)
ptr = XhtmlEntityTable;
else if (XMLtype == MATH_TYPE)
ptr = MathEntityTable;
else
ptr = NULL;
if (ptr == NULL)
return ptr;
/* look for the first concerned entry in the table */
found = FALSE;
for (i = 0; ptr[i].charCode >= 0 && !found; i++)
found = (ptr[i].charCode == entityValue);
if (found)
{
/* entity value found */
i--;
return ptr[i].charName;
}
else
return NULL;
}
Webmaster