2011-08-25 19:08:55 +08:00
|
|
|
/*
|
|
|
|
* Summary: Tree debugging APIs
|
|
|
|
* Description: Interfaces to a set of routines used for debugging the tree
|
|
|
|
* produced by the XML parser.
|
|
|
|
*
|
|
|
|
* Copy: See Copyright for the status of this software.
|
|
|
|
*
|
|
|
|
* Author: Daniel Veillard
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __DEBUG_XML__
|
|
|
|
#define __DEBUG_XML__
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <libxml/xmlversion.h>
|
|
|
|
#include <libxml/tree.h>
|
|
|
|
|
|
|
|
#ifdef LIBXML_DEBUG_ENABLED
|
|
|
|
|
|
|
|
#include <libxml/xpath.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The standard Dump routines.
|
|
|
|
*/
|
2012-04-19 14:35:52 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlDebugDumpString (FILE *output,
|
|
|
|
const xmlChar *str);
|
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlDebugDumpAttr (FILE *output,
|
|
|
|
xmlAttrPtr attr,
|
|
|
|
int depth);
|
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlDebugDumpAttrList (FILE *output,
|
|
|
|
xmlAttrPtr attr,
|
|
|
|
int depth);
|
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlDebugDumpOneNode (FILE *output,
|
|
|
|
xmlNodePtr node,
|
|
|
|
int depth);
|
2011-08-25 19:08:55 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
2012-04-19 14:35:52 +08:00
|
|
|
xmlDebugDumpNode (FILE *output,
|
|
|
|
xmlNodePtr node,
|
|
|
|
int depth);
|
2011-08-25 19:08:55 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
2012-04-19 14:35:52 +08:00
|
|
|
xmlDebugDumpNodeList (FILE *output,
|
|
|
|
xmlNodePtr node,
|
|
|
|
int depth);
|
2011-08-25 19:08:55 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
2012-04-19 14:35:52 +08:00
|
|
|
xmlDebugDumpDocumentHead(FILE *output,
|
|
|
|
xmlDocPtr doc);
|
2011-08-25 19:08:55 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
2012-04-19 14:35:52 +08:00
|
|
|
xmlDebugDumpDocument (FILE *output,
|
|
|
|
xmlDocPtr doc);
|
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlDebugDumpDTD (FILE *output,
|
|
|
|
xmlDtdPtr dtd);
|
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlDebugDumpEntities (FILE *output,
|
|
|
|
xmlDocPtr doc);
|
2011-08-25 19:08:55 +08:00
|
|
|
|
|
|
|
/****************************************************************
|
2012-04-19 14:35:52 +08:00
|
|
|
* *
|
|
|
|
* Checking routines *
|
|
|
|
* *
|
2011-08-25 19:08:55 +08:00
|
|
|
****************************************************************/
|
|
|
|
|
|
|
|
XMLPUBFUN int XMLCALL
|
2012-04-19 14:35:52 +08:00
|
|
|
xmlDebugCheckDocument (FILE * output,
|
|
|
|
xmlDocPtr doc);
|
2011-08-25 19:08:55 +08:00
|
|
|
|
|
|
|
/****************************************************************
|
2012-04-19 14:35:52 +08:00
|
|
|
* *
|
|
|
|
* XML shell helpers *
|
|
|
|
* *
|
2011-08-25 19:08:55 +08:00
|
|
|
****************************************************************/
|
|
|
|
|
2012-04-19 14:35:52 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlLsOneNode (FILE *output, xmlNodePtr node);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlLsCountNode (xmlNodePtr node);
|
2011-08-25 19:08:55 +08:00
|
|
|
|
|
|
|
XMLPUBFUN const char * XMLCALL
|
2012-04-19 14:35:52 +08:00
|
|
|
xmlBoolToText (int boolval);
|
2011-08-25 19:08:55 +08:00
|
|
|
|
|
|
|
/****************************************************************
|
2012-04-19 14:35:52 +08:00
|
|
|
* *
|
|
|
|
* The XML shell related structures and functions *
|
|
|
|
* *
|
2011-08-25 19:08:55 +08:00
|
|
|
****************************************************************/
|
|
|
|
|
|
|
|
#ifdef LIBXML_XPATH_ENABLED
|
|
|
|
/**
|
|
|
|
* xmlShellReadlineFunc:
|
|
|
|
* @prompt: a string prompt
|
|
|
|
*
|
|
|
|
* This is a generic signature for the XML shell input function.
|
|
|
|
*
|
|
|
|
* Returns a string which will be freed by the Shell.
|
|
|
|
*/
|
|
|
|
typedef char * (* xmlShellReadlineFunc)(char *prompt);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* xmlShellCtxt:
|
|
|
|
*
|
|
|
|
* A debugging shell context.
|
|
|
|
* TODO: add the defined function tables.
|
|
|
|
*/
|
|
|
|
typedef struct _xmlShellCtxt xmlShellCtxt;
|
|
|
|
typedef xmlShellCtxt *xmlShellCtxtPtr;
|
|
|
|
struct _xmlShellCtxt {
|
|
|
|
char *filename;
|
|
|
|
xmlDocPtr doc;
|
|
|
|
xmlNodePtr node;
|
|
|
|
xmlXPathContextPtr pctxt;
|
|
|
|
int loaded;
|
|
|
|
FILE *output;
|
|
|
|
xmlShellReadlineFunc input;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* xmlShellCmd:
|
|
|
|
* @ctxt: a shell context
|
|
|
|
* @arg: a string argument
|
|
|
|
* @node: a first node
|
|
|
|
* @node2: a second node
|
|
|
|
*
|
|
|
|
* This is a generic signature for the XML shell functions.
|
|
|
|
*
|
|
|
|
* Returns an int, negative returns indicating errors.
|
|
|
|
*/
|
|
|
|
typedef int (* xmlShellCmd) (xmlShellCtxtPtr ctxt,
|
|
|
|
char *arg,
|
2012-04-19 14:35:52 +08:00
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
|
|
|
|
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlShellPrintXPathError (int errorType,
|
|
|
|
const char *arg);
|
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlShellPrintXPathResult(xmlXPathObjectPtr list);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellList (xmlShellCtxtPtr ctxt,
|
|
|
|
char *arg,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellBase (xmlShellCtxtPtr ctxt,
|
|
|
|
char *arg,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellDir (xmlShellCtxtPtr ctxt,
|
|
|
|
char *arg,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellLoad (xmlShellCtxtPtr ctxt,
|
|
|
|
char *filename,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
2011-08-25 19:08:55 +08:00
|
|
|
#ifdef LIBXML_OUTPUT_ENABLED
|
2012-04-19 14:35:52 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlShellPrintNode (xmlNodePtr node);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellCat (xmlShellCtxtPtr ctxt,
|
|
|
|
char *arg,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellWrite (xmlShellCtxtPtr ctxt,
|
|
|
|
char *filename,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellSave (xmlShellCtxtPtr ctxt,
|
|
|
|
char *filename,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
2011-08-25 19:08:55 +08:00
|
|
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
|
|
|
#ifdef LIBXML_VALID_ENABLED
|
2012-04-19 14:35:52 +08:00
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellValidate (xmlShellCtxtPtr ctxt,
|
|
|
|
char *dtd,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
2011-08-25 19:08:55 +08:00
|
|
|
#endif /* LIBXML_VALID_ENABLED */
|
2012-04-19 14:35:52 +08:00
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellDu (xmlShellCtxtPtr ctxt,
|
|
|
|
char *arg,
|
|
|
|
xmlNodePtr tree,
|
|
|
|
xmlNodePtr node2);
|
|
|
|
XMLPUBFUN int XMLCALL
|
|
|
|
xmlShellPwd (xmlShellCtxtPtr ctxt,
|
|
|
|
char *buffer,
|
|
|
|
xmlNodePtr node,
|
|
|
|
xmlNodePtr node2);
|
2011-08-25 19:08:55 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The Shell interface.
|
|
|
|
*/
|
2012-04-19 14:35:52 +08:00
|
|
|
XMLPUBFUN void XMLCALL
|
|
|
|
xmlShell (xmlDocPtr doc,
|
|
|
|
char *filename,
|
|
|
|
xmlShellReadlineFunc input,
|
|
|
|
FILE *output);
|
|
|
|
|
2011-08-25 19:08:55 +08:00
|
|
|
#endif /* LIBXML_XPATH_ENABLED */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* LIBXML_DEBUG_ENABLED */
|
|
|
|
#endif /* __DEBUG_XML__ */
|