mirror of
https://gitlab.gnome.org/GNOME/libxml2
synced 2025-03-28 21:33:13 +00:00
renaming testCatalog as xmlcatalog, making it an installed app adding a
* Makefile.am xmlcatalog.c libxml.spec.in: renaming testCatalog as xmlcatalog, making it an installed app adding a shell, and preparing it to be a /etc/xml/catalog management tool, though not ready yet * catalog.c include/libxml/catalog.h: adding support for XML Catalogs http://www.oasis-open.org/committees/entity/ not finished, there is some interesting tradeoffs and a few open questions left. Daniel
This commit is contained in:
parent
b7664f4441
commit
344cee76a6
11
ChangeLog
11
ChangeLog
@ -1,3 +1,14 @@
|
|||||||
|
Mon Aug 20 02:04:13 CEST 2001 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* Makefile.am xmlcatalog.c libxml.spec.in: renaming
|
||||||
|
testCatalog as xmlcatalog, making it an installed app
|
||||||
|
adding a shell, and preparing it to be a /etc/xml/catalog
|
||||||
|
management tool, though not ready yet
|
||||||
|
* catalog.c include/libxml/catalog.h: adding support for
|
||||||
|
XML Catalogs http://www.oasis-open.org/committees/entity/
|
||||||
|
not finished, there is some interesting tradeoffs and a
|
||||||
|
few open questions left.
|
||||||
|
|
||||||
Sun Aug 19 14:59:56 CEST 2001 Daniel Veillard <daniel@veillard.com>
|
Sun Aug 19 14:59:56 CEST 2001 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
* xmllint.c: fixed a line formatting problem
|
* xmllint.c: fixed a line formatting problem
|
||||||
|
12
Makefile.am
12
Makefile.am
@ -7,9 +7,9 @@ SUBDIRS = include . doc example
|
|||||||
|
|
||||||
INCLUDES = -I@srcdir@/include -I$(top_builddir)/include @Z_CFLAGS@
|
INCLUDES = -I@srcdir@/include -I$(top_builddir)/include @Z_CFLAGS@
|
||||||
|
|
||||||
noinst_PROGRAMS=testSAX testHTML testXPath testURI testDocbook testCatalog
|
noinst_PROGRAMS=testSAX testHTML testXPath testURI testDocbook
|
||||||
|
|
||||||
bin_PROGRAMS = xmllint
|
bin_PROGRAMS = xmllint xmlcatalog
|
||||||
|
|
||||||
bin_SCRIPTS=xml2-config
|
bin_SCRIPTS=xml2-config
|
||||||
|
|
||||||
@ -62,10 +62,10 @@ testDocbook_LDFLAGS =
|
|||||||
testDocbook_DEPENDENCIES = $(DEPS)
|
testDocbook_DEPENDENCIES = $(DEPS)
|
||||||
testDocbook_LDADD= $(LDADDS)
|
testDocbook_LDADD= $(LDADDS)
|
||||||
|
|
||||||
testCatalog_SOURCES=testCatalog.c
|
xmlcatalog_SOURCES=xmlcatalog.c
|
||||||
testCatalog_LDFLAGS =
|
xmlcatalog_LDFLAGS =
|
||||||
testCatalog_DEPENDENCIES = $(DEPS)
|
xmlcatalog_DEPENDENCIES = $(DEPS)
|
||||||
testCatalog_LDADD= $(LDADDS)
|
xmlcatalog_LDADD= $(LDADDS)
|
||||||
|
|
||||||
testXPath_SOURCES=testXPath.c
|
testXPath_SOURCES=testXPath.c
|
||||||
testXPath_LDFLAGS =
|
testXPath_LDFLAGS =
|
||||||
|
@ -42,6 +42,13 @@ void xmlCatalogCleanup (void);
|
|||||||
void xmlCatalogDump (FILE *out);
|
void xmlCatalogDump (FILE *out);
|
||||||
const xmlChar * xmlCatalogGetSystem (const xmlChar *sysID);
|
const xmlChar * xmlCatalogGetSystem (const xmlChar *sysID);
|
||||||
const xmlChar * xmlCatalogGetPublic (const xmlChar *pubID);
|
const xmlChar * xmlCatalogGetPublic (const xmlChar *pubID);
|
||||||
|
const xmlChar * xmlCatalogResolve (const xmlChar *pubID,
|
||||||
|
const xmlChar *sysID);
|
||||||
|
int xmlCatalogAdd (const xmlChar *type,
|
||||||
|
const xmlChar *orig,
|
||||||
|
const xmlChar *replace);
|
||||||
|
int xmlCatalogRemove (const xmlChar *value);
|
||||||
|
int xmlCatalogSetDebug (int level);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@ -122,6 +122,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
|
|
||||||
%{prefix}/lib/lib*.so.*
|
%{prefix}/lib/lib*.so.*
|
||||||
%{prefix}/bin/xmllint
|
%{prefix}/bin/xmllint
|
||||||
|
%{prefix}/bin/xmlcatalog
|
||||||
|
|
||||||
%files devel
|
%files devel
|
||||||
%defattr(-, root, root)
|
%defattr(-, root, root)
|
||||||
|
@ -1,33 +0,0 @@
|
|||||||
/*
|
|
||||||
* testCatalog.c : a small tester program for Catalog loading
|
|
||||||
*
|
|
||||||
* See Copyright for the status of this software.
|
|
||||||
*
|
|
||||||
* daniel@veillard.com
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "libxml.h"
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdarg.h>
|
|
||||||
|
|
||||||
#include <libxml/xmlmemory.h>
|
|
||||||
#include <libxml/uri.h>
|
|
||||||
#include <libxml/catalog.h>
|
|
||||||
#include <libxml/parser.h>
|
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
|
||||||
#ifdef LIBXML_CATALOG_ENABLED
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 1; i < argc; i++)
|
|
||||||
xmlLoadCatalog(argv[i]);
|
|
||||||
|
|
||||||
xmlCatalogDump(stdout);
|
|
||||||
xmlCatalogCleanup();
|
|
||||||
xmlCleanupParser();
|
|
||||||
xmlMemoryDump();
|
|
||||||
#endif
|
|
||||||
return(0);
|
|
||||||
}
|
|
2
xmlIO.c
2
xmlIO.c
@ -3,7 +3,7 @@
|
|||||||
*
|
*
|
||||||
* See Copyright for the status of this software.
|
* See Copyright for the status of this software.
|
||||||
*
|
*
|
||||||
* Daniel.Veillard@w3.org
|
* daniel@veillard.com
|
||||||
*
|
*
|
||||||
* 14 Nov 2000 ht - for VMS, truncated name of long functions to under 32 char
|
* 14 Nov 2000 ht - for VMS, truncated name of long functions to under 32 char
|
||||||
*/
|
*/
|
||||||
|
216
xmlcatalog.c
Normal file
216
xmlcatalog.c
Normal file
@ -0,0 +1,216 @@
|
|||||||
|
/*
|
||||||
|
* xmlcatalog.c : a small utility program to handle XML catalogs
|
||||||
|
*
|
||||||
|
* See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* daniel@veillard.com
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "libxml.h"
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#include <libxml/xmlmemory.h>
|
||||||
|
#include <libxml/uri.h>
|
||||||
|
#include <libxml/catalog.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
|
||||||
|
static int shell = 0;
|
||||||
|
static int noout = 0;
|
||||||
|
static int verbose = 0;
|
||||||
|
|
||||||
|
#ifdef LIBXML_CATALOG_ENABLED
|
||||||
|
/************************************************************************
|
||||||
|
* *
|
||||||
|
* Shell Interface *
|
||||||
|
* *
|
||||||
|
************************************************************************/
|
||||||
|
/**
|
||||||
|
* xmlShellReadline:
|
||||||
|
* @prompt: the prompt value
|
||||||
|
*
|
||||||
|
* Read a string
|
||||||
|
*
|
||||||
|
* Returns a pointer to it or NULL on EOF the caller is expected to
|
||||||
|
* free the returned string.
|
||||||
|
*/
|
||||||
|
static char *
|
||||||
|
xmlShellReadline(const char *prompt) {
|
||||||
|
#ifdef HAVE_LIBREADLINE
|
||||||
|
char *line_read;
|
||||||
|
|
||||||
|
/* Get a line from the user. */
|
||||||
|
line_read = readline (prompt);
|
||||||
|
|
||||||
|
/* If the line has any text in it, save it on the history. */
|
||||||
|
if (line_read && *line_read)
|
||||||
|
add_history (line_read);
|
||||||
|
|
||||||
|
return (line_read);
|
||||||
|
#else
|
||||||
|
char line_read[501];
|
||||||
|
|
||||||
|
if (prompt != NULL)
|
||||||
|
fprintf(stdout, "%s", prompt);
|
||||||
|
if (!fgets(line_read, 500, stdin))
|
||||||
|
return(NULL);
|
||||||
|
line_read[500] = 0;
|
||||||
|
return(strdup(line_read));
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void usershell(void) {
|
||||||
|
char *cmdline = NULL, *cur;
|
||||||
|
int nbargs;
|
||||||
|
char command[100];
|
||||||
|
char arg[400];
|
||||||
|
int i;
|
||||||
|
const xmlChar *answer;
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
cmdline = xmlShellReadline("> ");
|
||||||
|
if (cmdline == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Parse the command itself
|
||||||
|
*/
|
||||||
|
cur = cmdline;
|
||||||
|
nbargs = 0;
|
||||||
|
while ((*cur == ' ') || (*cur == '\t')) cur++;
|
||||||
|
i = 0;
|
||||||
|
while ((*cur != ' ') && (*cur != '\t') &&
|
||||||
|
(*cur != '\n') && (*cur != '\r')) {
|
||||||
|
if (*cur == 0)
|
||||||
|
break;
|
||||||
|
command[i++] = *cur++;
|
||||||
|
}
|
||||||
|
command[i] = 0;
|
||||||
|
if (i == 0) continue;
|
||||||
|
nbargs++;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Parse the argument
|
||||||
|
*/
|
||||||
|
while ((*cur == ' ') || (*cur == '\t')) cur++;
|
||||||
|
i = 0;
|
||||||
|
while ((*cur != '\n') && (*cur != '\r') && (*cur != 0)) {
|
||||||
|
if (*cur == 0)
|
||||||
|
break;
|
||||||
|
arg[i++] = *cur++;
|
||||||
|
}
|
||||||
|
arg[i] = 0;
|
||||||
|
if (i != 0)
|
||||||
|
nbargs++;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* start interpreting the command
|
||||||
|
*/
|
||||||
|
if (!strcmp(command, "exit"))
|
||||||
|
break;
|
||||||
|
if (!strcmp(command, "quit"))
|
||||||
|
break;
|
||||||
|
if (!strcmp(command, "bye"))
|
||||||
|
break;
|
||||||
|
if (!strcmp(command, "public")) {
|
||||||
|
answer = xmlCatalogGetPublic((const xmlChar *) arg);
|
||||||
|
if (answer == NULL) {
|
||||||
|
printf("No entry for PUBLIC %s\n", arg);
|
||||||
|
} else {
|
||||||
|
printf("%s\n", answer);
|
||||||
|
}
|
||||||
|
} else if (!strcmp(command, "system")) {
|
||||||
|
answer = xmlCatalogGetSystem((const xmlChar *) arg);
|
||||||
|
if (answer == NULL) {
|
||||||
|
printf("No entry for SYSTEM %s\n", arg);
|
||||||
|
} else {
|
||||||
|
printf("%s\n", answer);
|
||||||
|
}
|
||||||
|
} else if (!strcmp(command, "dump")) {
|
||||||
|
xmlCatalogDump(stdout);
|
||||||
|
} else {
|
||||||
|
if (strcmp(command, "help")) {
|
||||||
|
printf("Unrecognized command %s\n", command);
|
||||||
|
}
|
||||||
|
printf("Commands available:\n");
|
||||||
|
printf("\tpublic PublicID: make a PUBLIC identifier lookup\n");
|
||||||
|
printf("\tsystem SystemID: make a SYSTEM identifier lookup\n");
|
||||||
|
printf("\tdump: print the current catalog state\n");
|
||||||
|
printf("\texit: quit the shell\n");
|
||||||
|
}
|
||||||
|
free(cmdline); /* not xmlFree here ! */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/************************************************************************
|
||||||
|
* *
|
||||||
|
* Main *
|
||||||
|
* *
|
||||||
|
************************************************************************/
|
||||||
|
static void usage(const char *name) {
|
||||||
|
printf("Usage : %s [options] catalogfile ...\n", name);
|
||||||
|
printf("\tParse the catalog file(s) and output the result of the parsing\n");
|
||||||
|
printf("\t--shell : run a shell allowing interactive queries\n");
|
||||||
|
printf("\t-v --verbose : provide debug informations\n");
|
||||||
|
}
|
||||||
|
int main(int argc, char **argv) {
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (argc <= 1) {
|
||||||
|
usage(argv[0]);
|
||||||
|
return(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
LIBXML_TEST_VERSION
|
||||||
|
for (i = 1; i < argc ; i++) {
|
||||||
|
if (!strcmp(argv[i], "-"))
|
||||||
|
break;
|
||||||
|
|
||||||
|
if (argv[i][0] != '-')
|
||||||
|
continue;
|
||||||
|
if ((!strcmp(argv[i], "-verbose")) ||
|
||||||
|
(!strcmp(argv[i], "-v")) ||
|
||||||
|
(!strcmp(argv[i], "--verbose"))) {
|
||||||
|
verbose++;
|
||||||
|
xmlCatalogSetDebug(verbose);
|
||||||
|
} else if ((!strcmp(argv[i], "-shell")) ||
|
||||||
|
(!strcmp(argv[i], "--shell"))) {
|
||||||
|
shell++;
|
||||||
|
noout = 1;
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "Unknown option %s\n", argv[i]);
|
||||||
|
usage(argv[0]);
|
||||||
|
return(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 1; i < argc; i++) {
|
||||||
|
if (argv[i][0] == '-')
|
||||||
|
continue;
|
||||||
|
xmlLoadCatalog(argv[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (shell) {
|
||||||
|
usershell();
|
||||||
|
}
|
||||||
|
if (!noout) {
|
||||||
|
xmlCatalogDump(stdout);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Cleanup and check for memory leaks
|
||||||
|
*/
|
||||||
|
xmlCatalogCleanup();
|
||||||
|
xmlCleanupParser();
|
||||||
|
xmlMemoryDump();
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
int main(int argc, char **argv) {
|
||||||
|
fprintf(stderr, "libxml was not compiled with catalog support\n");
|
||||||
|
return(1);
|
||||||
|
}
|
||||||
|
#endif
|
Loading…
x
Reference in New Issue
Block a user