From 14c38dccd18befa0ec91d9107067e69536a5f31f Mon Sep 17 00:00:00 2001 From: Kushal K S V S Date: Tue, 8 Aug 2017 23:55:00 -0700 Subject: [PATCH] Updating Makefile and runme.sh --- tests/make_png/Makefile | 27 +++++++++++-------- tests/make_png/README | 52 +++++++++++++++++------------------- tests/make_png/bitmap.c | 1 + tests/make_png/bitmap.h | 18 +++++-------- tests/make_png/make_sprite.c | 41 ++++++++++++---------------- tests/make_png/runme.sh | 40 +++++++++++++-------------- 6 files changed, 83 insertions(+), 96 deletions(-) mode change 100644 => 100755 tests/make_png/runme.sh diff --git a/tests/make_png/Makefile b/tests/make_png/Makefile index b742dbff7..ef5a73424 100644 --- a/tests/make_png/Makefile +++ b/tests/make_png/Makefile @@ -1,27 +1,32 @@ -# Define required macros here +TOP_DIR := ../.. +BUILD_DIR := $(TOP_DIR)/builds/unix -SHELL = /bin/sh +include $(TOP_DIR)/builds/unix/unix-def.mk SRC_SPRITE = make_sprite.c bitmap.c murmur3.c +SRC_LIB = $(libdir)/libfreetype.a -SRC_LIB = ./base/lib/libfreetype.a OBJS = $(src:.c=.o) CFLAGS = -Wall -g CC = gcc -INCLUDE = -I ./base/include/freetype2/ +INCLUDE = -I $(includedir)/freetype2 LIBS = -lpng -lharfbuzz -lbz2 -ldl -DPI = 72 +DPI ?= 72 +FT_TEST_RENDER_MODE ?= RGB -all: sprite +all: tests -sprite:$(SRC_SPRITE) - $(CC) $(CFLAGS) $(INCLUDE) -DDPI=$(DPI) -o $@ $(SRC_SPRITE) $(SRC_LIB) $(OBJS) $(LIBS) +tests: $(SRC_SPRITE) render_modes dpi + $(CC) $(CFLAGS) $(INCLUDE) -DDPI=$(DPI) -DFT_TEST_RENDER_MODE=$(FT_TEST_RENDER_MODE) -o $@ $(SRC_SPRITE) $(SRC_LIB) $(OBJS) $(LIBS) -.PHONY: clean +.PHONY: clean force clean: -rm -f *.o - - +render_modes: force + echo '$(FT_TEST_RENDER_MODE)' | cmp -s - $@ || echo '$(FT_TEST_RENDER_MODE)' > $@ + +dpi: force + echo '$(DPI)' | cmp -s - $@ || echo '$(DPI)' > $@ \ No newline at end of file diff --git a/tests/make_png/README b/tests/make_png/README index 8c46ba8bf..9430a26a9 100644 --- a/tests/make_png/README +++ b/tests/make_png/README @@ -5,10 +5,6 @@ TODO: Generate HTML page for detailed comparison INSTRUCTIONS -*** -FOR NOW JUST RUN ./runme.sh test.tff -*** - NOTE: One version of FreeType is referred as "base" version and the other as the "test" version. @@ -18,51 +14,56 @@ NOTE: One version of FreeType is referred as "base" version and the directory. Next, download an older version of FreeType (For example : 2.6.5) - ( This being the "test" version of the two) + ( This being the "base" version of the two) Go to 'include/freetype/ftoption.h' and uncomment this line #define FT_CONFIG_OPTION_SUBPIXEL_RENDERING - 2. Install the two versions + 2. Compile the two versions ------------------------------------- - Go to the "test" version's folder and change the default + Go to the "base" version's folder and change the default installation directory to the "test" folder created. - ./configure --prefix= + ./configure - Compile and install the library + Compile the library - make - make install + make - Repeat step 2. for the "base" version as well. + Repeat step 2. for the "test" version as well. 3. Compile the code ------------------------------------- Return to this folder and make the binary - make + make tests [options] - (set resolution in DPI by passing argument - example: make DPI=100, if not specified,default is 72) + Set resolution in DPI by passing argument to variable DPI. + Example: make tests DPI=100, if not specified,default is 72. - 3. Run the executable - ------------------------------------- + Set the Rendering mode by passing FT_TEST_RENDER_MODE. + can take values 1. MONO + 2. AA + 3. RGB + 4. BGR + 5. VRGB + 6. VBGR + ( Example: make tests FT_TEST_RENDER_MODE=RGB ) - ./sprite + 4. Run the executable + ------------------------------------- - is the libfreetype.so from the base vesion. - is the libfreetype.so from the test vesion. + sh runme.sh - ( and are in /lib/ ) + is directory of the 'base' FreeType version. ( The path to these should be absolute. ) - Open index.html for "list-view" + Open ./html/index.html for "list-view" --------------------------------------------------------------------- FEATURES - Generates sprite sheets in the ./images folder. + Generates sprite sheets in the ./html/images folder. Generates "list-view" web-page i.e index.html @@ -71,8 +72,3 @@ FEATURES -> Glyph-Index -> Name -> Difference Metric - - - - - diff --git a/tests/make_png/bitmap.c b/tests/make_png/bitmap.c index db6d616e4..e0ab98737 100644 --- a/tests/make_png/bitmap.c +++ b/tests/make_png/bitmap.c @@ -289,6 +289,7 @@ int Generate_PNG (IMAGE *bitmap, status = 0; + printf("Generated image %s\n", path ); for (y = 0; y < bitmap->height; y++) { png_free (png_ptr, row_pointers[y]); } diff --git a/tests/make_png/bitmap.h b/tests/make_png/bitmap.h index d74a08171..0ce860d77 100644 --- a/tests/make_png/bitmap.h +++ b/tests/make_png/bitmap.h @@ -31,6 +31,7 @@ typedef struct { /* To store 128bit Hash */ FT_UInt32 hash[4]; }HASH_128; +/* A 32-bit pixel */ typedef struct { unsigned char red; unsigned char green; @@ -38,21 +39,16 @@ typedef struct { unsigned char alpha; } PIXEL; -typedef struct { - unsigned char red; - unsigned char green; - unsigned char blue; - unsigned char alpha; -} PIXEL_BGRA; - -/* A picture. */ - +/* A picture. */ typedef struct { PIXEL* pixels; size_t width; size_t height; } IMAGE; - + +/* Render modes */ +enum render_modes + { MONO, AA, RGB, BGR, VRGB, VBGR }; /*-----------------------------------------------------------------*/ HASH_32* Generate_Hash_x86_32(FT_Bitmap* bitmap, HASH_32* murmur); @@ -66,7 +62,7 @@ int Compare_Hash(HASH_128* hash_b, HASH_128* hash_t); /* Returns a pointer to pixel */ /* at (x,y) co-ordinate */ PIXEL* Pixel_At (IMAGE * bitmap, int x, int y); -/* buffer to image */ +/*Render mode string to render_mode code */ void Make_PNG (FT_Bitmap* bitmap,IMAGE* fruit, int i,int render_mode); /* Image to file */ int Generate_PNG (IMAGE *bitmap, const char *path,int render_mode); diff --git a/tests/make_png/make_sprite.c b/tests/make_png/make_sprite.c index 72cfd6737..b85d3eeaf 100644 --- a/tests/make_png/make_sprite.c +++ b/tests/make_png/make_sprite.c @@ -2,18 +2,10 @@ int main(int argc, char const *argv[]) { - if(argc != 6) + if(argc != 5) { - printf("Usage: ./sprite \ - \n"); - - printf("Values for render_mode 0 - monochrome\n"); - printf(" 1 - anti-aliased\n"); - printf(" 2 - lcd horizontal-RGB\n"); - printf(" 3 - lcd horizontal-BGR\n"); - printf(" 4 - lcd vertical-RGB\n"); - printf(" 5 - lcd vertical-BGR\n"); - + printf("Usage: ./tests \ + \n"); return 0; } @@ -22,8 +14,7 @@ int main(int argc, char const *argv[]) const char* base_version; const char* test_version; const char* font_file; - int size; - int render_mode; + int size; int load_flag; /* FT_LOAD_XXX */ int render_flag; /* FT_RENDER_MODE_XXX */ @@ -34,7 +25,6 @@ int main(int argc, char const *argv[]) font_file = argv[3]; size = atoi(argv[4]); - render_mode = atoi(argv[5]); FT_Library base_library; FT_Face base_face; @@ -64,7 +54,7 @@ int main(int argc, char const *argv[]) HASH_128 * base_murmur = (HASH_128 *) malloc(sizeof(HASH_128)) ; HASH_128 * test_murmur = (HASH_128 *) malloc(sizeof(HASH_128)) ; - int Is_Different; + int Is_Different, total_count = 0; int pixel_diff, i; char glyph_name[50] = ".not-def"; @@ -203,8 +193,8 @@ int main(int argc, char const *argv[]) "FT_Done_FreeType"); /*******************************************************************/ - - switch ( render_mode ) { + + switch ( FT_TEST_RENDER_MODE ) { case 0: render_flag = FT_RENDER_MODE_MONO; load_flag = FT_LOAD_MONOCHROME; target_flag = FT_LOAD_TARGET_MONO; @@ -251,7 +241,7 @@ int main(int argc, char const *argv[]) exit(1); } - if (render_mode > 1 ) + if (FT_TEST_RENDER_MODE > 1 ) { error = Base_Library_SetLcdFilter( base_library, FT_LCD_FILTER_DEFAULT ); @@ -389,16 +379,17 @@ int main(int argc, char const *argv[]) if (Is_Different != 0) { + total_count++; pixel_diff = 0; /* Difference metric*/ - if (render_mode == 0) + if (FT_TEST_RENDER_MODE == 0) { /* If monochrome, take the converted image*/ - Make_PNG( &base_target, base_png, i, render_mode ); - Make_PNG( &test_target, test_png, i, render_mode ); + Make_PNG( &base_target, base_png, i, FT_TEST_RENDER_MODE ); + Make_PNG( &test_target, test_png, i, FT_TEST_RENDER_MODE ); }else{ - Make_PNG( base_bitmap, base_png, i, render_mode ); - Make_PNG( test_bitmap, test_png, i, render_mode ); + Make_PNG( base_bitmap, base_png, i, FT_TEST_RENDER_MODE ); + Make_PNG( test_bitmap, test_png, i, FT_TEST_RENDER_MODE ); } /* Aligning images and appending rows */ if (base_png->height < test_png->height) @@ -437,11 +428,13 @@ int main(int argc, char const *argv[]) sprintf( output_file_name, "./html/images/%s.png", glyph_name ); - Generate_PNG ( output, output_file_name, render_mode ); + Generate_PNG ( output, output_file_name, FT_TEST_RENDER_MODE ); /* To print table row to HTML file */ Print_Row(fp,i,glyph_name,pixel_diff ); } } + printf("Total %ld\nFaulty %d\n",base_face->num_glyphs, + total_count ); /* HTML footer */ fprintf(fp, "\n\ diff --git a/tests/make_png/runme.sh b/tests/make_png/runme.sh old mode 100644 new mode 100755 index 9761ad7a2..1b768c30f --- a/tests/make_png/runme.sh +++ b/tests/make_png/runme.sh @@ -1,30 +1,26 @@ -TEST_DIR=$1 -BASE_DIR=$PWD +rm -f ./html/images/* -cd $TEST_DIR/include/freetype/config/ -sed -i 's/\/\* #define FT_CONFIG_OPTION_SUBPIXEL_RENDERING \*\//#define FT_CONFIG_OPTION_SUBPIXEL_RENDERING /g' ftoption.h +BASE_DIR=$1 +TEST_DIR=../.. -cd $TEST_DIR -./autogen.sh -./configure --prefix=$BASE_DIR/test/ -make -make install +BASE_LIB=$BASE_DIR/objs/.libs/libfreetype.so +TEST_LIB=$TEST_DIR/objs/.libs/libfreetype.so -cd $BASE_DIR/../.. -./autogen.sh -./configure --prefix=$BASE_DIR/base/ -make -make install +FONT_FILE=$2 +PT_SIZE=$3 -cd $BASE_DIR -make +echo +echo "*** Generating Images ***" +echo -BASE_LIB=./base/lib/libfreetype.so -TEST_LIB=./test/lib/libfreetype.so +./tests $BASE_LIB $TEST_LIB $FONT_FILE $PT_SIZE + +echo "Font: " $FONT_FILE +echo "Size: " $PT_SIZE + +# Removing the current DPI and Render Mode settings +# for future compilations. +rm -f ./render_modes ./dpi -FONT_FILE=$2 -PT_SIZE=$3 -RENDER_MODE=$4 -./sprite $BASE_LIB $TEST_LIB $FONT_FILE $PT_SIZE $RENDER_MODE