1
0
mirror of git://projects.qi-hardware.com/antorcha.git synced 2024-11-01 05:43:09 +02:00

tools/ant-txt/ant-txt.c: add option -x for X bitmap output

This commit is contained in:
Werner Almesberger 2012-09-14 05:32:10 -03:00
parent d09499ccaa
commit 8d967a0480

View File

@ -51,6 +51,32 @@ static void dump_binary(const uint8_t *canvas)
}
static void dump_xbm(const uint8_t *canvas)
{
int x, y, i, n;
uint8_t v = 0;
printf("#define foo_width %d\n", W);
printf("#define foo_height %d\n", H);
printf("static unsigned char foo_bits[] = {\n");
n = 0;
for (y = 0; y != H; y++) {
for (x = 0; x < W; x += 8) {
if (n)
printf("%s 0x%02x",
(n-1) % 12 ? "," :
n == 1 ? " " : ",\n ", v);
v = 0;
for (i = x; i != W && i != x+8; i++)
if (canvas[(y*W+i) >> 3] & (1 << (i & 7)))
v |= 1 << (i-x);
n++;
}
}
printf("%s 0x%02x};\n", (n-1) % 12 ? "," : ",\n ", v);
}
static void dump_text(const uint8_t *canvas)
{
int x, y;
@ -68,7 +94,7 @@ static void dump_text(const uint8_t *canvas)
static void usage(const char *name)
{
fprintf(stderr, "usage: %s [-b] [-F font_dir ...] [text]\n", name);
fprintf(stderr, "usage: %s [-b|-x] [-F font_dir ...] [text]\n", name);
exit(1);
}
@ -78,20 +104,25 @@ int main(int argc, char **argv)
struct edit *edits = NULL, **last = &edits;
uint8_t *canvas;
const char *err;
int binary = 0;
int binary = 0, xbm = 0;
int i, c;
while ((c = getopt(argc, argv, "bF:")) != EOF)
while ((c = getopt(argc, argv, "bF:x")) != EOF)
switch (c) {
case 'b':
binary = 1;
break;
case 'x':
xbm = 1;
break;
case 'F':
add_font_dir(optarg);
break;
default:
usage(*argv);
}
if (binary && xbm)
usage(*argv);
for (i = optind; i != argc; i++) {
while (*last)
last = &(*last)->next;
@ -116,6 +147,8 @@ int main(int argc, char **argv)
}
if (binary)
dump_binary(canvas);
else if (xbm)
dump_xbm(canvas);
else
dump_text(canvas);
return 0;