Blame client/X11/generate_argument_docbook.c

Packit Service fa4841
#include <stdlib.h>
Packit Service fa4841
#include <stdio.h>
Packit Service fa4841
#include <ctype.h>
Packit Service fa4841
#include <string.h>
Packit Service fa4841
Packit Service fa4841
#include "../common/cmdline.h"
Packit Service fa4841
Packit Service fa4841
#define TAG FREERDP_TAG("generate_argument_docbook")
Packit Service fa4841
LPSTR tr_esc_str(LPCSTR arg, bool format)
Packit Service fa4841
{
Packit Service fa4841
	LPSTR tmp = NULL;
Packit Service b1ea74
	LPSTR tmp2 = NULL;
Packit Service fa4841
	size_t cs = 0, x, ds, len;
Packit Service fa4841
	size_t s;
Packit Service fa4841
Packit Service fa4841
	if (NULL == arg)
Packit Service fa4841
		return NULL;
Packit Service fa4841
Packit Service fa4841
	s = strlen(arg);
Packit Service fa4841
Packit Service fa4841
	/* Find trailing whitespaces */
Packit Service fa4841
	while ((s > 0) && isspace(arg[s - 1]))
Packit Service fa4841
		s--;
Packit Service fa4841
Packit Service fa4841
	/* Prepare a initial buffer with the size of the result string. */
Packit Service fa4841
	ds = s + 1;
Packit Service fa4841
Packit Service b1ea74
	if (ds)
Packit Service b1ea74
	{
Packit Service b1ea74
		tmp2 = (LPSTR)realloc(tmp, ds * sizeof(CHAR));
Packit Service b1ea74
		if (!tmp2)
Packit Service b1ea74
			free(tmp);
Packit Service b1ea74
		tmp = tmp2;
Packit Service b1ea74
	}
Packit Service fa4841
Packit Service fa4841
	if (NULL == tmp)
Packit Service fa4841
	{
Packit Service b1ea74
		fprintf(stderr, "Could not allocate string buffer.\n");
Packit Service fa4841
		exit(-2);
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* Copy character for character and check, if it is necessary to escape. */
Packit Service fa4841
	memset(tmp, 0, ds * sizeof(CHAR));
Packit Service fa4841
Packit Service fa4841
	for (x = 0; x < s; x++)
Packit Service fa4841
	{
Packit Service fa4841
		switch (arg[x])
Packit Service fa4841
		{
Packit Service fa4841
			case '<':
Packit Service fa4841
				len = format ? 13 : 4;
Packit Service fa4841
				ds += len - 1;
Packit Service b1ea74
				tmp2 = (LPSTR)realloc(tmp, ds * sizeof(CHAR));
Packit Service b1ea74
				if (!tmp2)
Packit Service b1ea74
					free(tmp);
Packit Service b1ea74
				tmp = tmp2;
Packit Service fa4841
Packit Service fa4841
				if (NULL == tmp)
Packit Service fa4841
				{
Packit Service b1ea74
					fprintf(stderr, "Could not reallocate string buffer.\n");
Packit Service fa4841
					exit(-3);
Packit Service fa4841
				}
Packit Service fa4841
Packit Service fa4841
				if (format)
Packit Service fa4841
					/* coverity[buffer_size] */
Packit Service fa4841
					strncpy(&tmp[cs], "<replaceable>", len);
Packit Service fa4841
				else
Packit Service fa4841
					/* coverity[buffer_size] */
Packit Service fa4841
					strncpy(&tmp[cs], "<", len);
Packit Service fa4841
Packit Service fa4841
				cs += len;
Packit Service fa4841
				break;
Packit Service fa4841
Packit Service fa4841
			case '>':
Packit Service fa4841
				len = format ? 14 : 4;
Packit Service fa4841
				ds += len - 1;
Packit Service b1ea74
				tmp2 = (LPSTR)realloc(tmp, ds * sizeof(CHAR));
Packit Service b1ea74
				if (!tmp2)
Packit Service b1ea74
					free(tmp);
Packit Service b1ea74
				tmp = tmp2;
Packit Service fa4841
Packit Service fa4841
				if (NULL == tmp)
Packit Service fa4841
				{
Packit Service b1ea74
					fprintf(stderr, "Could not reallocate string buffer.\n");
Packit Service fa4841
					exit(-4);
Packit Service fa4841
				}
Packit Service fa4841
Packit Service fa4841
				if (format)
Packit Service fa4841
					/* coverity[buffer_size] */
Packit Service fa4841
					strncpy(&tmp[cs], "</replaceable>", len);
Packit Service fa4841
				else
Packit Service fa4841
					/* coverity[buffer_size] */
Packit Service b1ea74
					strncpy(&tmp[cs], ">", len);
Packit Service fa4841
Packit Service fa4841
				cs += len;
Packit Service fa4841
				break;
Packit Service fa4841
Packit Service fa4841
			case '\'':
Packit Service fa4841
				ds += 5;
Packit Service b1ea74
				tmp2 = (LPSTR)realloc(tmp, ds * sizeof(CHAR));
Packit Service b1ea74
				if (!tmp2)
Packit Service b1ea74
					free(tmp);
Packit Service b1ea74
				tmp = tmp2;
Packit Service fa4841
Packit Service fa4841
				if (NULL == tmp)
Packit Service fa4841
				{
Packit Service b1ea74
					fprintf(stderr, "Could not reallocate string buffer.\n");
Packit Service fa4841
					exit(-5);
Packit Service fa4841
				}
Packit Service fa4841
Packit Service fa4841
				tmp[cs++] = '&';
Packit Service fa4841
				tmp[cs++] = 'a';
Packit Service fa4841
				tmp[cs++] = 'p';
Packit Service fa4841
				tmp[cs++] = 'o';
Packit Service fa4841
				tmp[cs++] = 's';
Packit Service fa4841
				tmp[cs++] = ';';
Packit Service fa4841
				break;
Packit Service fa4841
Packit Service fa4841
			case '"':
Packit Service fa4841
				ds += 5;
Packit Service b1ea74
				tmp2 = (LPSTR)realloc(tmp, ds * sizeof(CHAR));
Packit Service b1ea74
				if (!tmp2)
Packit Service b1ea74
					free(tmp);
Packit Service b1ea74
				tmp = tmp2;
Packit Service fa4841
Packit Service fa4841
				if (NULL == tmp)
Packit Service fa4841
				{
Packit Service b1ea74
					fprintf(stderr, "Could not reallocate string buffer.\n");
Packit Service fa4841
					exit(-6);
Packit Service fa4841
				}
Packit Service fa4841
Packit Service fa4841
				tmp[cs++] = '&';
Packit Service fa4841
				tmp[cs++] = 'q';
Packit Service fa4841
				tmp[cs++] = 'u';
Packit Service fa4841
				tmp[cs++] = 'o';
Packit Service fa4841
				tmp[cs++] = 't';
Packit Service fa4841
				tmp[cs++] = ';';
Packit Service fa4841
				break;
Packit Service fa4841
Packit Service fa4841
			case '&':
Packit Service fa4841
				ds += 4;
Packit Service b1ea74
				tmp2 = (LPSTR)realloc(tmp, ds * sizeof(CHAR));
Packit Service b1ea74
				if (!tmp2)
Packit Service b1ea74
					free(tmp);
Packit Service b1ea74
				tmp = tmp2;
Packit Service fa4841
Packit Service fa4841
				if (NULL == tmp)
Packit Service fa4841
				{
Packit Service b1ea74
					fprintf(stderr, "Could not reallocate string buffer.\n");
Packit Service fa4841
					exit(-7);
Packit Service fa4841
				}
Packit Service fa4841
Packit Service fa4841
				tmp[cs++] = '&';
Packit Service fa4841
				tmp[cs++] = 'a';
Packit Service fa4841
				tmp[cs++] = 'm';
Packit Service fa4841
				tmp[cs++] = 'p';
Packit Service fa4841
				tmp[cs++] = ';';
Packit Service fa4841
				break;
Packit Service fa4841
Packit Service fa4841
			default:
Packit Service fa4841
				tmp[cs++] = arg[x];
Packit Service fa4841
				break;
Packit Service fa4841
		}
Packit Service fa4841
Packit Service fa4841
		/* Assure, the string is '\0' terminated. */
Packit Service fa4841
		tmp[ds - 1] = '\0';
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	return tmp;
Packit Service fa4841
}
Packit Service fa4841
Packit Service fa4841
int main(int argc, char* argv[])
Packit Service fa4841
{
Packit Service fa4841
	size_t elements = sizeof(args) / sizeof(args[0]);
Packit Service fa4841
	size_t x;
Packit Service fa4841
	const char* fname = "xfreerdp-argument.1.xml";
Packit Service fa4841
	FILE* fp = NULL;
Packit Service fa4841
	/* Open output file for writing, truncate if existing. */
Packit Service fa4841
	fp = fopen(fname, "w");
Packit Service fa4841
Packit Service fa4841
	if (NULL == fp)
Packit Service fa4841
	{
Packit Service b1ea74
		fprintf(stderr, "Could not open '%s' for writing.\n", fname);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* The tag used as header in the manpage */
Packit Service fa4841
	fprintf(fp, "<refsect1>\n");
Packit Service fa4841
	fprintf(fp, "\t<title>Options</title>\n");
Packit Service fa4841
	fprintf(fp, "\t\t<variablelist>\n");
Packit Service fa4841
Packit Service fa4841
	/* Iterate over argument struct and write data to docbook 4.5
Packit Service fa4841
	 * compatible XML */
Packit Service fa4841
	if (elements < 2)
Packit Service fa4841
	{
Packit Service b1ea74
		fprintf(stderr, "The argument array 'args' is empty, writing an empty file.\n");
Packit Service fa4841
		elements = 1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	for (x = 0; x < elements - 1; x++)
Packit Service fa4841
	{
Packit Service fa4841
		const COMMAND_LINE_ARGUMENT_A* arg = &args[x];
Packit Service b1ea74
		char* name = tr_esc_str((LPSTR)arg->Name, FALSE);
Packit Service b1ea74
		char* alias = tr_esc_str((LPSTR)arg->Alias, FALSE);
Packit Service fa4841
		char* format = tr_esc_str(arg->Format, TRUE);
Packit Service b1ea74
		char* text = tr_esc_str((LPSTR)arg->Text, FALSE);
Packit Service fa4841
		fprintf(fp, "\t\t\t<varlistentry>\n");
Packit Service fa4841
Packit Service fa4841
		do
Packit Service fa4841
		{
Packit Service fa4841
			fprintf(fp, "\t\t\t\t<term><option>");
Packit Service fa4841
Packit Service fa4841
			if (arg->Flags == COMMAND_LINE_VALUE_BOOL)
Packit Service fa4841
				fprintf(fp, "%s", arg->Default ? "-" : "+");
Packit Service fa4841
			else
Packit Service fa4841
				fprintf(fp, "/");
Packit Service fa4841
Packit Service fa4841
			fprintf(fp, "%s</option>", name);
Packit Service fa4841
Packit Service fa4841
			if (format)
Packit Service fa4841
			{
Packit Service fa4841
				if (arg->Flags == COMMAND_LINE_VALUE_OPTIONAL)
Packit Service fa4841
					fprintf(fp, "[");
Packit Service fa4841
Packit Service fa4841
				fprintf(fp, ":%s", format);
Packit Service fa4841
Packit Service fa4841
				if (arg->Flags == COMMAND_LINE_VALUE_OPTIONAL)
Packit Service fa4841
					fprintf(fp, "]");
Packit Service fa4841
			}
Packit Service fa4841
Packit Service fa4841
			fprintf(fp, "</term>\n");
Packit Service fa4841
Packit Service fa4841
			if (alias == name)
Packit Service fa4841
				break;
Packit Service fa4841
Packit Service fa4841
			free(name);
Packit Service fa4841
			name = alias;
Packit Service b1ea74
		} while (alias);
Packit Service fa4841
Packit Service fa4841
		if (text)
Packit Service fa4841
		{
Packit Service fa4841
			fprintf(fp, "\t\t\t\t<listitem>\n");
Packit Service fa4841
			fprintf(fp, "\t\t\t\t\t<para>");
Packit Service fa4841
Packit Service fa4841
			if (text)
Packit Service fa4841
				fprintf(fp, "%s", text);
Packit Service fa4841
Packit Service fa4841
			if (arg->Flags == COMMAND_LINE_VALUE_BOOL)
Packit Service fa4841
				fprintf(fp, " (default:%s)", arg->Default ? "on" : "off");
Packit Service fa4841
			else if (arg->Default)
Packit Service fa4841
			{
Packit Service b1ea74
				char* value = tr_esc_str((LPSTR)arg->Default, FALSE);
Packit Service fa4841
				fprintf(fp, " (default:%s)", value);
Packit Service fa4841
				free(value);
Packit Service fa4841
			}
Packit Service fa4841
Packit Service fa4841
			fprintf(fp, "</para>\n");
Packit Service fa4841
			fprintf(fp, "\t\t\t\t</listitem>\n");
Packit Service fa4841
		}
Packit Service fa4841
Packit Service fa4841
		fprintf(fp, "\t\t\t</varlistentry>\n");
Packit Service fa4841
		free(name);
Packit Service fa4841
		free(format);
Packit Service fa4841
		free(text);
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	fprintf(fp, "\t\t</variablelist>\n");
Packit Service fa4841
	fprintf(fp, "\t</refsect1>\n");
Packit Service fa4841
	fclose(fp);
Packit Service fa4841
	return 0;
Packit Service fa4841
}