Commit ece4fe14 authored by Oleg.Korshul's avatar Oleg.Korshul Committed by Alexander.Trofimov

баги в субпиксельном хинтинге

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@68914 954022d7-b5bf-4e40-9824-e11837661b57
parent 052de700
...@@ -2530,64 +2530,13 @@ function Ins_FDEF(exc, args, args_pos) ...@@ -2530,64 +2530,13 @@ function Ins_FDEF(exc, args, args_pos)
{ {
var bIsSubpix = exc.face.driver.library.tt_hint_props.TT_CONFIG_OPTION_SUBPIXEL_HINTING; var bIsSubpix = exc.face.driver.library.tt_hint_props.TT_CONFIG_OPTION_SUBPIXEL_HINTING;
/* some font programs are broken enough to redefine functions! */ var opcode_pattern = null;
/* We will then parse the current table. */ var opcode_patterns = null;
var defs = exc.FDefs; var opcode_pointer = null;
var rec = 0; var opcode_size = null;;
var limit = exc.numFDefs;
var n = args[args_pos];
for ( ; rec < limit; rec++)
{
if (defs[rec].opc == n)
break;
}
if (rec == limit)
{
/* check that there is enough room for new functions */
if (exc.numFDefs >= exc.maxFDefs)
{
exc.error = FT_Common.FT_Err_Too_Many_Function_Defs;
return;
}
exc.numFDefs++;
}
/* Although FDEF takes unsigned 32-bit integer, */
/* func # must be within unsigned 16-bit integer */
if (n > 0xFFFF)
{
exc.error = FT_Common.FT_Err_Too_Many_Function_Defs;
return;
}
defs[rec].range = exc.curRange;
defs[rec].opc = 0xFFFF & n;
defs[rec].start = exc.IP + 1;
defs[rec].active = true;
defs[rec].inline_delta = false;
defs[rec].sph_fdef_flags = 0x0000;
if (n > exc.maxFunc)
exc.maxFunc = 0xFFFF & n;
if (bIsSubpix) if (bIsSubpix)
{ {
/* We don't know for sure these are typeman functions, */ opcode_pattern = [
/* however they are only active when RS 22 is called */
if (n >= 64 && n <= 66)
defs[rec].sph_fdef_flags |= FT_Common.SPH_FDEF_TYPEMAN_STROKES;
}
/* Now skip the whole function definition. */
/* We don't allow nested IDEFS & FDEFs. */
while (SkipCode(exc) == 0)
{
if (bIsSubpix)//#ifdef TT_CONFIG_OPTION_SUBPIXEL_HINTING
{
var opcode_pattern = [
/* #0 inline delta function 1 */ /* #0 inline delta function 1 */
[ [
0x4B, /* PPEM */ 0x4B, /* PPEM */
...@@ -2679,10 +2628,68 @@ function Ins_FDEF(exc, args, args_pos) ...@@ -2679,10 +2628,68 @@ function Ins_FDEF(exc, args, args_pos)
0x7D, /* RDTG */ 0x7D, /* RDTG */
] ]
]; ];
var opcode_patterns = opcode_pattern.length; opcode_patterns = opcode_pattern.length;
var opcode_pointer = [ 0, 0, 0, 0, 0, 0, 0, 0, 0 ]; opcode_pointer = [ 0, 0, 0, 0, 0, 0, 0, 0, 0 ];
var opcode_size = [ 12, 8, 8, 6, 7, 4, 5, 4, 2 ]; opcode_size = [ 12, 8, 8, 6, 7, 4, 5, 4, 2 ];
}
/* some font programs are broken enough to redefine functions! */
/* We will then parse the current table. */
var defs = exc.FDefs;
var rec = 0;
var limit = exc.numFDefs;
var n = args[args_pos];
for ( ; rec < limit; rec++)
{
if (defs[rec].opc == n)
break;
}
if (rec == limit)
{
/* check that there is enough room for new functions */
if (exc.numFDefs >= exc.maxFDefs)
{
exc.error = FT_Common.FT_Err_Too_Many_Function_Defs;
return;
}
exc.numFDefs++;
}
/* Although FDEF takes unsigned 32-bit integer, */
/* func # must be within unsigned 16-bit integer */
if (n > 0xFFFF)
{
exc.error = FT_Common.FT_Err_Too_Many_Function_Defs;
return;
}
defs[rec].range = exc.curRange;
defs[rec].opc = 0xFFFF & n;
defs[rec].start = exc.IP + 1;
defs[rec].active = true;
defs[rec].inline_delta = false;
defs[rec].sph_fdef_flags = 0x0000;
if (n > exc.maxFunc)
exc.maxFunc = 0xFFFF & n;
if (bIsSubpix)
{
/* We don't know for sure these are typeman functions, */
/* however they are only active when RS 22 is called */
if (n >= 64 && n <= 66)
defs[rec].sph_fdef_flags |= FT_Common.SPH_FDEF_TYPEMAN_STROKES;
}
/* Now skip the whole function definition. */
/* We don't allow nested IDEFS & FDEFs. */
while (SkipCode(exc) == 0)
{
if (bIsSubpix)//#ifdef TT_CONFIG_OPTION_SUBPIXEL_HINTING
{
for (var i = 0; i < opcode_patterns; i++) for (var i = 0; i < opcode_patterns; i++)
{ {
if (opcode_pointer[i] < opcode_size[i] && exc.opcode == opcode_pattern[i][opcode_pointer[i]]) if (opcode_pointer[i] < opcode_size[i] && exc.opcode == opcode_pattern[i][opcode_pointer[i]])
...@@ -3831,7 +3838,7 @@ function Ins_RS(exc, args, args_pos) ...@@ -3831,7 +3838,7 @@ function Ins_RS(exc, args, args_pos)
/* subpixel hinting - avoid Typeman Dstroke and */ /* subpixel hinting - avoid Typeman Dstroke and */
/* IStroke and Vacuform rounds */ /* IStroke and Vacuform rounds */
if (exc.compatibility_mode && if (exc.ignore_x_mode &&
((I == 24) && (exc.face.sph_found_func_flags & (FT_Common.SPH_FDEF_SPACING_1 | FT_Common.SPH_FDEF_SPACING_2))) || ((I == 24) && (exc.face.sph_found_func_flags & (FT_Common.SPH_FDEF_SPACING_1 | FT_Common.SPH_FDEF_SPACING_2))) ||
((I == 22) && (exc.sph_in_func_flags & FT_Common.SPH_FDEF_TYPEMAN_STROKES)) || ((I == 22) && (exc.sph_in_func_flags & FT_Common.SPH_FDEF_TYPEMAN_STROKES)) ||
((I == 8) && (exc.face.sph_found_func_flags & FT_Common.SPH_FDEF_VACUFORM_ROUND_1) && exc.iup_called)) ((I == 8) && (exc.face.sph_found_func_flags & FT_Common.SPH_FDEF_VACUFORM_ROUND_1) && exc.iup_called))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment