jehanne/sys/src/lib/memdraw/mkcmap.c

89 lines
1.9 KiB
C

/*
* This file is part of the UCB release of Plan 9. It is subject to the license
* terms in the LICENSE file found in the top-level directory of this
* distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
* part of the UCB release of Plan 9, including this file, may be copied,
* modified, propagated, or distributed except according to the terms contained
* in the LICENSE file.
*/
#include <u.h>
#include <libc.h>
#include <draw.h>
#include <memdraw.h>
/*
struct Memcmap
{
uchar cmap2rgb[3*256];
uchar rgb2cmap[16*16*16];
};
*/
static Memcmap*
mkcmap(void)
{
static Memcmap def;
int i, rgb, r, g, b;
for(i=0; i<256; i++){
rgb = cmap2rgb(i);
r = (rgb>>16)&0xff;
g = (rgb>>8)&0xff;
b = rgb&0xff;
def.cmap2rgb[3*i] = r;
def.cmap2rgb[3*i+1] = g;
def.cmap2rgb[3*i+2] = b;
}
for(r=0; r<16; r++)
for(g=0; g<16; g++)
for(b=0; b<16; b++)
def.rgb2cmap[r*16*16+g*16+b] = rgb2cmap(r*0x11, g*0x11, b*0x11);
return &def;
}
void
main(int argc, char **argv)
{
Memcmap *c;
int i, j, inferno;
inferno = 0;
ARGBEGIN{
case 'i':
inferno = 1;
}ARGEND
memimageinit();
c = mkcmap();
if(!inferno)
jehanne_print("#include <u.h>\n#include <libc.h>\n");
else
jehanne_print("#include \"lib9.h\"\n");
jehanne_print("#include <draw.h>\n");
jehanne_print("#include <memdraw.h>\n\n");
jehanne_print("static Memcmap def = {\n");
jehanne_print("/* cmap2rgb */ {\n");
for(i=0; i<sizeof(c->cmap2rgb); ){
jehanne_print("\t");
for(j=0; j<16; j++, i++)
jehanne_print("0x%2.2ux,", c->cmap2rgb[i]);
jehanne_print("\n");
}
jehanne_print("},\n");
jehanne_print("/* rgb2cmap */ {\n");
for(i=0; i<sizeof(c->rgb2cmap);){
jehanne_print("\t");
for(j=0; j<16; j++, i++)
jehanne_print("0x%2.2ux,", c->rgb2cmap[i]);
jehanne_print("\n");
}
jehanne_print("}\n");
jehanne_print("};\n");
jehanne_print("Memcmap *memdefcmap = &def;\n");
jehanne_print("void _memmkcmap(void){}\n");
jehanne_exits(0);
}