shithub: fnt

ref: 6bf0a834bc0b9a179a63eab0f603db232227da42
dir: /test_unix.c/

View raw version
#include <stdio.h>
#include <stdlib.h>
#include "otf.h"

static char *argv0;

#define	ARGBEGIN	for((argv0? 0: (argv0=*argv)),argv++,argc--;\
			    argv[0] && argv[0][0]=='-' && argv[0][1];\
			    argc--, argv++) {\
				char *_args, *_argt;\
				int _argc;\
				_args = &argv[0][1];\
				if(_args[0]=='-' && _args[1]==0){\
					argc--; argv++; break;\
				}\
				_argc = 0;\
				while((_argc = *_args++) != 0)\
				switch(_argc)
#define	ARGEND		(void)_argt; (void)_argc; (void)_args;}(void)argv; (void)argc;
#define	ARGF()		(_argt=_args, _args="",\
				(*_argt? _argt: argv[1]? (argc--, *++argv): 0))
#define	ARGC()		_argc

#define	EARGF(x)		(_argt=_args, _args="",\
				(*_argt? _argt: argv[1]? (argc--, *++argv): (x, (char*)0)))

static int
otfseek(void *aux, int off, int whence)
{
	if(fseek(aux, off, whence) < 0)
		return -1;
	return ftell(aux);
}

static int
otfread(void *aux, void *dst, int sz)
{
	return fread(dst, 1, sz, aux);
}

static void
usage(void)
{
	fprintf(stderr, "usage: %s [-g GLYPH_ID] [-G] [-i N] [-s PX] font.otf ...\n", argv0);
	fprintf(stderr, " -g: specifies a single glyph id\n");
	fprintf(stderr, " -G: print out glyph ids, only ones that can be drawn atm (no compound yet)\n");
	fprintf(stderr, " -s: draw (of size PX) and write the image to stdout\n");
	exit(1);
}

int
main(int argc, char **argv)
{
	int i, gi, G, h;
	Otfile in, out;
	Otf *o;

	gi = -1;
	G = 0;
	h = 0;
	ARGBEGIN{
	case 'g':
		gi = strtol(EARGF(usage()), NULL, 0);
		break;
	case 'G':
		G++;
		break;
	case 's':
		h = strtol(EARGF(usage()), NULL, 0);
		break;
	default:
		usage();
	}ARGEND

	in.seek = otfseek;
	in.read = otfread;
	out.print = (void*)fprintf;

	out.aux = fdopen(1, "wb");
	for(i = 0; i < argc; i++){
		if(h <= 0)
			fprintf(out.aux, "%s\n", argv[i]);
		if((in.aux = fopen(argv[i], "rb")) == NULL || (o = otfopen(&in)) == NULL){
			fprintf(stderr, "%s: failed\n", argv[i]);
			continue;
		}
		if(G){
			int i, n = otfglyfnum(o);
			for(i = 0; i < n; i++){
				Glyf *g = otfglyf(o, i);
				if(g != NULL && g->simple != NULL && g->numberOfContours > 0){
					if(h > 0){
						int w;
						u8int *b = otfdrawglyf(g, h, &w);
						if(b == NULL){
							fprintf(stderr, "failed\n");
							exit(1);
						}
						free(b);
					}else{
						fprintf(out.aux, "%d ", i);
					}
				}
				free(g);
			}
			if(h <= 0)
				fprintf(out.aux, "\n");
		}else if(gi < 0){
			otfprint(o, &out, indentΔ);
		}else{
			int n = otfglyfnum(o);
			if(gi >= n){
				fprintf(stderr, "glyph %d out of range, max %d\n", gi, n-1);
				exit(1);
			}
			Glyf *g = otfglyf(o, gi);
			if(g == NULL){
				fprintf(stderr, "%d: failed\n", gi);
			}else if(h > 0){
				if(g->component != NULL)
					fprintf(stderr, "%d: component\n", gi);
				else{
					int w;
					u8int *b = otfdrawglyf(g, h, &w);
					if(b == NULL){
						fprintf(stderr, "failed\n");
						exit(1);
					}
					fprintf(out.aux, "%11s %11d %11d %11d %11d ", "k8", 0, 0, w, h);
					fwrite(b, 1, w*h, out.aux);
					free(b);
				}
			}else{
				fprintf(out.aux, "\n%d:\n", gi);
				print_Glyf(&out, indentΔ, o, g);
			}
		}
		otfclose(o);
		fclose(in.aux);
	}
	fclose(out.aux);

	return 0;
}