/***
File melt-make-string.c [making C constant strings from arguments]
Copyright (C) 2011, 2012 Free Software Foundation, Inc.
Indented with GNU indent.
This file is part of GCC.
GCC is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3, or (at your option)
any later version.
GCC is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with GCC; see the file COPYING3. If not see
.
***/
/**
This is a self contained utility program. When given a list of pairs
as program argument, it outputs on stdout a sequence of C constant
strings. So, if invoked as:
melt-make-string foo abc bar bcd
it produces on stdout:
const char foo[]="abc";
const char bar[]="bcd";
However, it handles special characters correctly, e.g.
melt-make-string foo 'a"'
gives rightly, since the single quote is handled by the shell
const char foo[]="a\"";
and so on.
**/
#include
#include
#include
void output_cstr (const char *s);
/* output a C string with escapes when needed. */
void
output_cstr (const char *s)
{
char c;
for (s = s; (c = (*s)) != (char) 0; s++)
{
switch (c)
{
case '\n':
fputs ("\\n", stdout);
break;
case '\r':
fputs ("\\r", stdout);
break;
case '\t':
fputs ("\\t", stdout);
break;
case '\b':
fputs ("\\b", stdout);
break;
case '\v':
fputs ("\\v", stdout);
break;
case '\f':
fputs ("\\f", stdout);
break;
case '\\':
fputs ("\\\\", stdout);
break;
case '\'':
fputs ("\\\'", stdout);
break;
case '\"':
fputs ("\\\"", stdout);
break;
case '/':
case '*':
case '+':
case '-':
case '%':
case '$':
case ' ':
putc (c, stdout);
break;
default:
if (c < 0x7f && isprint (c))
putc (c, stdout);
else
printf ("\\%03o", (int) (c & 0xff));
break;
}
}
}
int
main (int argc, char **argv)
{
int ix = 0;
for (ix = 1; (ix + 1) < argc; ix += 2)
{
const char *name = argv[ix];
const char *str = argv[ix + 1];
const char *ps = NULL;
int badname = 0;
if (!name || !str)
break;
badname = !isalpha (name[0]);
for (ps = name; !badname && *ps; ps++)
if (isalnum (*ps) || *ps == '_')
continue;
else
badname = 1;
if (badname)
{
printf ("#error bad name %s\n", name);
fprintf (stderr, "bad name #%d: %s\n", ix, name);
exit (1);
}
puts ("#ifdef __cplusplus");
puts (" extern \"C\"");
puts ("#endif /*__cplusplus*/");
printf ("const char %s[]=\"", name);
output_cstr (str);
fputs ("\";\n", stdout);
}
if (fflush (stdout))
{
perror ("failed to flush stdout");
exit (1);
};
return 0;
}