diff --git a/usr.bin/file2c/file2c.1 b/usr.bin/file2c/file2c.1 index 80bbb2eea606..a4f72e221e69 100644 --- a/usr.bin/file2c/file2c.1 +++ b/usr.bin/file2c/file2c.1 @@ -7,7 +7,7 @@ .\" .\" $FreeBSD$ .\" -.Dd May 14, 2005 +.Dd March 22, 2007 .Dt FILE2C 1 .Os .Sh NAME @@ -16,6 +16,7 @@ .Sh SYNOPSIS .Nm .Op Fl n Ar count +.Op Fl s .Op Fl x .Op Ar prefix Op Ar suffix .Sh DESCRIPTION @@ -27,7 +28,10 @@ The byte values are separated by a comma. This also means that the last byte value is not followed by a comma. By default the byte values are printed in decimal, but when the .Fl x -option is given, the values will be printed in hexadecimal. +option is given, the values will be printed in hexadecimal. When +.Fl s +option is given, each line is printed with a leading tab and each comma is +followed by a space except for the last one on the line. .Pp If more than 70 characters are printed on the same line, that line is ended and the output continues on the next line. @@ -50,9 +54,11 @@ This program is typically used to embed binary files into C source files. The prefix is used to define an array type and the suffix is used to end the C statement. The -.Fl x -and .Fl n +, +.Fl s +and +.Fl x options are useful when the binary data represents a bitmap and the output needs to remain readable and/or editable. Fonts, for example, are a good example of this. diff --git a/usr.bin/file2c/file2c.c b/usr.bin/file2c/file2c.c index 8e16bbb8b383..14f754e97faa 100644 --- a/usr.bin/file2c/file2c.c +++ b/usr.bin/file2c/file2c.c @@ -19,7 +19,7 @@ static void usage(void) { - fprintf(stderr, "usage: %s [-n count] [-x] [prefix [suffix]]\n", + fprintf(stderr, "usage: %s [-n count] [-s] [-x] [prefix [suffix]]\n", getprogname()); exit(1); } @@ -27,15 +27,19 @@ usage(void) int main(int argc, char *argv[]) { - int c, count, linepos, maxcount, radix; + int c, count, linepos, maxcount, pretty, radix; maxcount = 0; + pretty = 0; radix = 10; - while ((c = getopt(argc, argv, "n:x")) != -1) { + while ((c = getopt(argc, argv, "n:sx")) != -1) { switch (c) { case 'n': /* Max. number of bytes per line. */ maxcount = strtol(optarg, NULL, 10); break; + case 's': /* Be more style(9) comliant. */ + pretty = 1; + break; case 'x': /* Print hexadecimal numbers. */ radix = 16; break; @@ -60,6 +64,15 @@ main(int argc, char *argv[]) putchar('\n'); count = linepos = 0; } + if (pretty) { + if (count) { + putchar(' '); + linepos++; + } else { + putchar('\t'); + linepos += 8; + } + } switch (radix) { case 10: linepos += printf("%d", c);