Blame os400/xmllintcl.c

Packit Service a31ea6
/**
Packit Service a31ea6
***     XMLLINT command response program.
Packit Service a31ea6
***
Packit Service a31ea6
***     See Copyright for the status of this software.
Packit Service a31ea6
***
Packit Service a31ea6
***     Author: Patrick Monnerat <pm@datasphere.ch>, DATASPHERE S.A.
Packit Service a31ea6
**/
Packit Service a31ea6
Packit Service a31ea6
#include <stdio.h>
Packit Service a31ea6
#include <stdlib.h>
Packit Service a31ea6
#include <string.h>
Packit Service a31ea6
#include <qshell.h>
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
/* Variable-length string, with 16-bit length. */
Packit Service a31ea6
typedef struct {
Packit Service a31ea6
        short           len;
Packit Service a31ea6
        char            string[5000];
Packit Service a31ea6
}               vary2;
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
/* Variable-length string, with 32-bit length. */
Packit Service a31ea6
typedef struct {
Packit Service a31ea6
        int             len;
Packit Service a31ea6
        char            string[5000];
Packit Service a31ea6
}               vary4;
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
/* Multiple occurrence parameter list. */
Packit Service a31ea6
#define paramlist(itemsize, itemtype)                                   \
Packit Service a31ea6
        _Packed struct {                                                \
Packit Service a31ea6
                short           len;                                    \
Packit Service a31ea6
                union {                                                 \
Packit Service a31ea6
                         char           _pad[itemsize];                 \
Packit Service a31ea6
                        itemtype        param;                          \
Packit Service a31ea6
                }               item[1];                                \
Packit Service a31ea6
        }
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
/* Arguments from CL command. */
Packit Service a31ea6
typedef struct {
Packit Service a31ea6
        char *          pgm;            /* Program name. */
Packit Service a31ea6
        vary2 *         stmf;           /* XML file name or URL. */
Packit Service a31ea6
        vary2 *         dtd;            /* DTD location or public identifier. */
Packit Service a31ea6
        char *          dtdvalid;       /* *DTDURL or *DTDFPI. */
Packit Service a31ea6
        vary2 *         schema;         /* Schema file name or URL. */
Packit Service a31ea6
        vary2 *         schemakind;     /* --schema/--relaxng/--schematron. */
Packit Service a31ea6
        vary2 *         outstmf;        /* Output stream file name. */
Packit Service a31ea6
        vary2 *         xpath;          /* XPath filter. */
Packit Service a31ea6
        vary2 *         pattern;        /* Reader filter pattern. */
Packit Service a31ea6
        paramlist(5000 + 2, vary2) * path; /* Path for resources. */
Packit Service a31ea6
        vary2 *         pretty;         /* Pretty-print style. */
Packit Service a31ea6
        unsigned long * maxmem;         /* Maximum dynamic memory. */
Packit Service a31ea6
        vary2 *         encoding;       /* Output encoding. */
Packit Service a31ea6
        paramlist(20 + 2, vary2) * options; /* Other options. */
Packit Service a31ea6
}               arguments;
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
/* Definition of QSHELL program. */
Packit Service a31ea6
extern void     qshell(vary4 * cmd);
Packit Service a31ea6
#pragma linkage(qshell, OS)
Packit Service a31ea6
#pragma map(qshell, "QSHELL/QZSHQSHC")
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
static void
Packit Service a31ea6
vary4nappend(vary4 * dst, const char * src, size_t len)
Packit Service a31ea6
Packit Service a31ea6
{
Packit Service a31ea6
        if (len > sizeof(dst->string) - dst->len)
Packit Service a31ea6
                len = sizeof(dst->string) - dst->len;
Packit Service a31ea6
Packit Service a31ea6
        if (len) {
Packit Service a31ea6
                memcpy(dst->string + dst->len, src, len);
Packit Service a31ea6
                dst->len += len;
Packit Service a31ea6
                }
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
static void
Packit Service a31ea6
vary4append(vary4 * dst, const char * src)
Packit Service a31ea6
Packit Service a31ea6
{
Packit Service a31ea6
        vary4nappend(dst, src, strlen(src));
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
static void
Packit Service a31ea6
vary4arg(vary4 * dst, const char * arg)
Packit Service a31ea6
Packit Service a31ea6
{
Packit Service a31ea6
        vary4nappend(dst, " ", 1);
Packit Service a31ea6
        vary4append(dst, arg);
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
static void
Packit Service a31ea6
vary4varg(vary4 * dst, vary2 * arg)
Packit Service a31ea6
Packit Service a31ea6
{
Packit Service a31ea6
        vary4nappend(dst, " ", 1);
Packit Service a31ea6
        vary4nappend(dst, arg->string, arg->len);
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
static void
Packit Service a31ea6
vary4vescape(vary4 * dst, vary2 * arg)
Packit Service a31ea6
Packit Service a31ea6
{
Packit Service a31ea6
        int i;
Packit Service a31ea6
Packit Service a31ea6
        for (i = 0; i < arg->len; i++)
Packit Service a31ea6
                if (arg->string[i] == '\'')
Packit Service a31ea6
                        vary4nappend(dst, "'\"'\"'", 5);
Packit Service a31ea6
                else
Packit Service a31ea6
                        vary4nappend(dst, arg->string + i, 1);
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
static void
Packit Service a31ea6
vary4vargquote(vary4 * dst, vary2 * arg)
Packit Service a31ea6
Packit Service a31ea6
{
Packit Service a31ea6
        vary4nappend(dst, " '", 2);
Packit Service a31ea6
        vary4vescape(dst, arg);
Packit Service a31ea6
        vary4nappend(dst, "'", 1);
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
int
Packit Service a31ea6
main(int argsc, arguments * args)
Packit Service a31ea6
Packit Service a31ea6
{
Packit Service a31ea6
        vary4 cmd;
Packit Service a31ea6
        int i;
Packit Service a31ea6
        char textbuf[20];
Packit Service a31ea6
        char * lang;
Packit Service a31ea6
Packit Service a31ea6
        /* find length of library name. */
Packit Service a31ea6
        for (i = 0; i < 10 && args->pgm[i] && args->pgm[i] != '/'; i++)
Packit Service a31ea6
                ;
Packit Service a31ea6
Packit Service a31ea6
        /* Store program name in command buffer. */
Packit Service a31ea6
        cmd.len = 0;
Packit Service a31ea6
        vary4append(&cmd, "/QSYS.LIB/");
Packit Service a31ea6
        vary4nappend(&cmd, args->pgm, i);
Packit Service a31ea6
        vary4append(&cmd, ".LIB/XMLLINT.PGM");
Packit Service a31ea6
Packit Service a31ea6
        /* Map command arguments to standard xmllint argument vector. */
Packit Service a31ea6
Packit Service a31ea6
        if (args->dtd && args->dtd->len) {
Packit Service a31ea6
                if (args->dtdvalid && args->dtdvalid[4] == 'F')
Packit Service a31ea6
                        vary4arg(&cmd, "--dtdvalidfpi");
Packit Service a31ea6
                else
Packit Service a31ea6
                        vary4arg(&cmd, "--dtdvalid");
Packit Service a31ea6
Packit Service a31ea6
                vary4vargquote(&cmd, args->dtd);
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        if (args->schema && args->schema->len) {
Packit Service a31ea6
                vary4varg(&cmd, args->schemakind);
Packit Service a31ea6
                vary4vargquote(&cmd, args->schema);
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        if (args->outstmf && args->outstmf->len) {
Packit Service a31ea6
                vary4arg(&cmd, "--output");
Packit Service a31ea6
                vary4vargquote(&cmd, args->outstmf);
Packit Service a31ea6
Packit Service a31ea6
                if (args->encoding && args->encoding->len) {
Packit Service a31ea6
                        vary4arg(&cmd, "--encoding");
Packit Service a31ea6
                        vary4vargquote(&cmd, args->encoding);
Packit Service a31ea6
                        }
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        if (args->xpath && args->xpath->len) {
Packit Service a31ea6
                vary4arg(&cmd, "--xpath");
Packit Service a31ea6
                vary4vargquote(&cmd, args->xpath);
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        if (args->pattern && args->pattern->len) {
Packit Service a31ea6
                vary4arg(&cmd, "--pattern");
Packit Service a31ea6
                vary4vargquote(&cmd, args->pattern);
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        if (args->path && args->path->len) {
Packit Service a31ea6
                vary4arg(&cmd, "--path '");
Packit Service a31ea6
                vary4vescape(&cmd, &args->path->item[0].param);
Packit Service a31ea6
                for (i = 1; i < args->path->len; i++) {
Packit Service a31ea6
                        vary4nappend(&cmd, ":", 1);
Packit Service a31ea6
                        vary4vescape(&cmd, &args->path->item[i].param);
Packit Service a31ea6
                        }
Packit Service a31ea6
                vary4nappend(&cmd, "'", 1);
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        if (args->pretty && args->pretty->len &&
Packit Service a31ea6
            args->pretty->string[0] != '0') {
Packit Service a31ea6
                vary4arg(&cmd, "--pretty");
Packit Service a31ea6
                vary4varg(&cmd, args->pretty);
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        if (args->maxmem && *args->maxmem) {
Packit Service a31ea6
                snprintf(textbuf, sizeof textbuf, "%lu", *args->maxmem);
Packit Service a31ea6
                vary4arg(&cmd, "--maxmem");
Packit Service a31ea6
                vary4arg(&cmd, textbuf);
Packit Service a31ea6
                }
Packit Service a31ea6
Packit Service a31ea6
        for (i = 0; i < args->options->len; i++)
Packit Service a31ea6
                vary4varg(&cmd, &args->options->item[i].param);
Packit Service a31ea6
Packit Service a31ea6
        vary4vargquote(&cmd, args->stmf);
Packit Service a31ea6
Packit Service a31ea6
        /* Execute the shell command. */
Packit Service a31ea6
        qshell(&cmd);
Packit Service a31ea6
Packit Service a31ea6
        /* Terminate. */
Packit Service a31ea6
        exit(0);
Packit Service a31ea6
}