summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorParth Wazurkar <parthwazurkar@gmail.com>2018-08-05 17:02:09 +0530
committerParth Wazurkar <parthwazurkar@gmail.com>2018-08-05 17:02:09 +0530
commitad0453fd392c914db66c1737bbf4721ddc76571c (patch)
tree00ca35dd6e1f4489737cf56bbfe2d8c016f9cd48
parentd93d4f6b34acb96c51dc619e452e7c67b74a667c (diff)
downloadfreetype2-ad0453fd392c914db66c1737bbf4721ddc76571c.tar.gz
[gf, pk] Improve `attach_file' functions.
-rw-r--r--src/gf/gfdrivr.c51
-rw-r--r--src/pk/pkdrivr.c50
2 files changed, 53 insertions, 48 deletions
diff --git a/src/gf/gfdrivr.c b/src/gf/gfdrivr.c
index 5cebaee23..a568dda55 100644
--- a/src/gf/gfdrivr.c
+++ b/src/gf/gfdrivr.c
@@ -483,37 +483,40 @@
FT_TRACE4(( "TFM_Read_Metrics: Invoking TFM_Service.\n" ));
tfm = (TFM_Service)face->tfm;
-
- /* Initialise TFM Service */
- error = tfm->init( &parser,
+ if ( tfm->tfm_parser_funcs )
+ {
+ /* Initialise TFM Service */
+ error = tfm->tfm_parser_funcs->init( &parser,
memory,
stream );
- if ( !error )
- {
- FT_TRACE4(( "TFM_Read_Metrics: Initialised tfm metric data.\n" ));
- parser.FontInfo = fi;
- parser.user_data = gf_glyph;
-
- error = tfm->parse_metrics( &parser );
- if( !error )
- FT_TRACE4(( "TFM_Read_Metrics: parsing TFM metric information done.\n" ));
-
- FT_TRACE6(( "TFM_Read_Metrics: TFM Metric Information:\n"
- " Check Sum : %ld\n"
- " Design Size: %ld\n"
- " Begin Char : %d\n"
- " End Char : %d\n"
- " font_bbx_w : %d\n"
- " font_bbx_h : %d\n"
- " slant : %d\n", parser.FontInfo->cs, parser.FontInfo->design_size, parser.FontInfo->begin_char,
- parser.FontInfo->end_char, parser.FontInfo->font_bbx_w,
- parser.FontInfo->font_bbx_h, parser.FontInfo->slant ));
- tfm->done( &parser );
+ if ( !error )
+ {
+ FT_TRACE4(( "TFM_Read_Metrics: Initialised tfm metric data.\n" ));
+ parser.FontInfo = fi;
+ parser.user_data = gf_glyph;
+
+ error = tfm->tfm_parser_funcs->parse_metrics( &parser );
+ if( !error )
+ FT_TRACE4(( "TFM_Read_Metrics: parsing TFM metric information done.\n" ));
+
+ FT_TRACE6(( "TFM_Read_Metrics: TFM Metric Information:\n"
+ " Check Sum : %ld\n"
+ " Design Size: %ld\n"
+ " Begin Char : %d\n"
+ " End Char : %d\n"
+ " font_bbx_w : %d\n"
+ " font_bbx_h : %d\n"
+ " slant : %d\n", parser.FontInfo->cs, parser.FontInfo->design_size, parser.FontInfo->begin_char,
+ parser.FontInfo->end_char, parser.FontInfo->font_bbx_w,
+ parser.FontInfo->font_bbx_h, parser.FontInfo->slant ));
+ tfm->tfm_parser_funcs->done( &parser );
+ }
}
if ( !error )
{
+ printf("Hi I reached here\n");
/* Modify GF_Glyph data according to TFM metric values */
/*face->gf_glyph->font_bbx_w = fi->font_bbx_w;
diff --git a/src/pk/pkdrivr.c b/src/pk/pkdrivr.c
index 306d29dec..12056f913 100644
--- a/src/pk/pkdrivr.c
+++ b/src/pk/pkdrivr.c
@@ -479,33 +479,35 @@
FT_TRACE4(( "TFM_Read_Metrics: Invoking TFM_Service.\n" ));
tfm = (TFM_Service)face->tfm;
-
- /* Initialise TFM Service */
- error = tfm->init( &parser,
+ if ( tfm->tfm_parser_funcs )
+ {
+ /* Initialise TFM Service */
+ error = tfm->tfm_parser_funcs->init( &parser,
memory,
stream );
- if ( !error )
- {
- FT_TRACE4(( "TFM_Read_Metrics: Initialised tfm metric data.\n" ));
- parser.FontInfo = fi;
- parser.user_data = pk_glyph;
-
- error = tfm->parse_metrics( &parser );
- if( !error )
- FT_TRACE4(( "TFM_Read_Metrics: parsing TFM metric information done.\n" ));
-
- FT_TRACE6(( "TFM_Read_Metrics: TFM Metric Information:\n"
- " Check Sum : %ld\n"
- " Design Size: %ld\n"
- " Begin Char : %d\n"
- " End Char : %d\n"
- " font_bbx_w : %d\n"
- " font_bbx_h : %d\n"
- " slant : %d\n", parser.FontInfo->cs, parser.FontInfo->design_size, parser.FontInfo->begin_char,
- parser.FontInfo->end_char, parser.FontInfo->font_bbx_w,
- parser.FontInfo->font_bbx_h, parser.FontInfo->slant ));
- tfm->done( &parser );
+ if ( !error )
+ {
+ FT_TRACE4(( "TFM_Read_Metrics: Initialised tfm metric data.\n" ));
+ parser.FontInfo = fi;
+ parser.user_data = pk_glyph;
+
+ error = tfm->tfm_parser_funcs->parse_metrics( &parser );
+ if( !error )
+ FT_TRACE4(( "TFM_Read_Metrics: parsing TFM metric information done.\n" ));
+
+ FT_TRACE6(( "TFM_Read_Metrics: TFM Metric Information:\n"
+ " Check Sum : %ld\n"
+ " Design Size: %ld\n"
+ " Begin Char : %d\n"
+ " End Char : %d\n"
+ " font_bbx_w : %d\n"
+ " font_bbx_h : %d\n"
+ " slant : %d\n", parser.FontInfo->cs, parser.FontInfo->design_size, parser.FontInfo->begin_char,
+ parser.FontInfo->end_char, parser.FontInfo->font_bbx_w,
+ parser.FontInfo->font_bbx_h, parser.FontInfo->slant ));
+ tfm->tfm_parser_funcs->done( &parser );
+ }
}
if ( !error )