mirror of
https://github.com/darlinghq/darling-libxml2.git
synced 2025-03-01 06:56:10 +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>
|
||||
|
||||
* 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@
|
||||
|
||||
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
|
||||
|
||||
@ -62,10 +62,10 @@ testDocbook_LDFLAGS =
|
||||
testDocbook_DEPENDENCIES = $(DEPS)
|
||||
testDocbook_LDADD= $(LDADDS)
|
||||
|
||||
testCatalog_SOURCES=testCatalog.c
|
||||
testCatalog_LDFLAGS =
|
||||
testCatalog_DEPENDENCIES = $(DEPS)
|
||||
testCatalog_LDADD= $(LDADDS)
|
||||
xmlcatalog_SOURCES=xmlcatalog.c
|
||||
xmlcatalog_LDFLAGS =
|
||||
xmlcatalog_DEPENDENCIES = $(DEPS)
|
||||
xmlcatalog_LDADD= $(LDADDS)
|
||||
|
||||
testXPath_SOURCES=testXPath.c
|
||||
testXPath_LDFLAGS =
|
||||
|
@ -42,6 +42,13 @@ void xmlCatalogCleanup (void);
|
||||
void xmlCatalogDump (FILE *out);
|
||||
const xmlChar * xmlCatalogGetSystem (const xmlChar *sysID);
|
||||
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
|
||||
}
|
||||
|
@ -122,6 +122,7 @@ rm -rf $RPM_BUILD_ROOT
|
||||
|
||||
%{prefix}/lib/lib*.so.*
|
||||
%{prefix}/bin/xmllint
|
||||
%{prefix}/bin/xmlcatalog
|
||||
|
||||
%files devel
|
||||
%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.
|
||||
*
|
||||
* Daniel.Veillard@w3.org
|
||||
* daniel@veillard.com
|
||||
*
|
||||
* 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