* src/sfnt/ttcmap0.c (tt_cmap4_char_index): Fix serious typo


			
			
				BRANCH-2-1-5
			
			
		
Werner Lemberg 23 years ago
parent 3faaa46429
commit 75e6d1ce91
  1. 73
      ChangeLog
  2. 4
      builds/freetype.mk
  3. 2
      docs/INSTALL
  4. 1
      include/freetype/config/ftstdlib.h
  5. 29
      src/sfnt/ttcmap0.c
  6. 4
      src/sfnt/ttload.c

@ -1,42 +1,49 @@
2002-05-02 Werner Lemberg <wl@gnu.org>
* src/sfnt/ttcmap0.c (tt_cmap4_char_index): Fix serious typo
(0xFFFU -> 0xFFFFU).
2002-05-01 Werner Lemberg <wl@gnu.org>
* docs/INSTALL: Fix URL of makepp.
2002-05-01 David Turner <david@freetype.org>
* src/sfnt/sfobjs.c (tt_face_get_name): fixing a bug that
caused FreeType to crash when certain broken fonts (e.g.
"hya6gb.ttf") were opened.
* src/sfnt/sfobjs.c (tt_face_get_name): Fixing a bug that caused
FreeType to crash when certain broken fonts (e.g. "hya6gb.ttf")
were opened.
* src/sfnt/ttload.c (TT_Load_Names): applied a small work-around to
manage fonts containing a broken name table (e.g. "hya6gb.ttf")
* src/sfnt/ttload.c (TT_Load_Names): Applied a small work-around to
manage fonts containing a broken name table (e.g. "hya6gb.ttf").
* src/sfnt/ttcmap0.c (tt_cmap4_validate):
fixed over-restrictive validation test. the charmap validator
now accepts overlapping ranges in format 4 charmaps.
* src/sfnt/ttcmap0.c (tt_cmap4_validate): Fixed over-restrictive
validation test. The charmap validator now accepts overlapping
ranges in format 4 charmaps.
* src/sfnt/ttcmap0.c (tt_cmap4_char_index):
switched to a binary search algorithm. Certain fonts contain
more than 170 distinct segments !!
* src/sfnt/ttcmap0.c (tt_cmap4_char_index): Switched to a binary
search algorithm. Certain fonts contain more than 170 distinct
segments!
* include/freetype/config/ftstdlib.h: adding an alias for the
'exit' function. This will be used in the near future to panic
in case of un-expected exception (which shouldn't happen in
theory, but as everyone knows, shit happens :-) )
* include/freetype/config/ftstdlib.h: Adding an alias for the `exit'
function. This will be used in the near future to panic in case of
unexpected exception (which shouldn't happen in theory).
* include/freetype/internal/fthash.h, src/base/fthash.c:
adding a generic implementation of dynamic hash tables using
linear algorithm (to get rid of 'stalls' during resizes). This
will be used in the future in at least three parts of the
library: the cache sub-system, the object sub-system and
the memory debugger.
* include/freetype/internal/fthash.h, src/base/fthash.c: Adding a
generic implementation of dynamic hash tables using a linear
algorithm (to get rid of `stalls' during resizes). This will be
used in the future in at least three parts of the library: the cache
sub-system, the object sub-system, and the memory debugger.
* include/freetype/internal/ftcore.h: added this header file to
group all new definitions related to exception handling and
memory management. It's very likely that this file will disappear
or be renamed in the future..
* include/freetype/internal/ftcore.h: Added this header file to
group all new definitions related to exception handling and memory
management. It is very likely that this file will disappear or be
renamed in the future.
* include/freetype/internal/ftobject.h, include/freetype/ftsysmem.h:
adding comments to better explain the object sub-system as well
as the new memory manager interface.
* include/freetype/internal/ftobject.h, include/freetype/ftsysmem.h:
Adding comments to better explain the object sub-system as well as
the new memory manager interface.
2002-04-30 Wenlin Institute (Tom Bishop) <wenlin@wenlin.com>
2002-04-30 Wenlin Institute (Tom Bishop) <wenlin@wenlin.com>
* src/base/ftmac.c (p2c_str): Removed.
(file_spec_from_path) [TARGET_API_MAC_CARBON]: Added support for
@ -167,10 +174,10 @@
2002-04-18 David Turner <david@freetype.org>
* src/base/ftobjs.c, builds/win32/ftdebug.c,
builds/amiga/src/base/ftdebug.c: Version 2.1.0 couldn't be linked
against applications in Win32 and Amiga builds due to changes to
"src/base/ftdebug.c" that were not properly propagated to
"builds/win32" and "builds/amiga". This has been fixed.
builds/amiga/src/base/ftdebug.c: Version 2.1.0 couldn't be linked
against applications in Win32 and Amiga builds due to changes to
"src/base/ftdebug.c" that were not properly propagated to
"builds/win32" and "builds/amiga". This has been fixed.
* include/freetype/internal/ftobject.h,
include/freetype/internal/ftexcept.h, include/freetype/ftsysmem.h,

@ -3,7 +3,7 @@
#
# Copyright 1996-2000 by
# Copyright 1996-2000, 2002 by
# David Turner, Robert Wilhelm, and Werner Lemberg.
#
# This file is part of the FreeType project, and may only be used, modified,
@ -276,7 +276,7 @@ distclean_project_std: clean_project_std
# The Dos command shell does not support very long list of arguments, so
# we are stuck with wildcards.
#
# Don't break the command lines with; this prevents the "del" command from
# Don't break the command lines with \; this prevents the "del" command from
# working correctly on Win9x.
#
clean_project_dos:

@ -70,7 +70,7 @@ II. From the command line
[Well, this is not really correct. Recently, a perl implementation
of make called `makepp' has appeared which can also build FreeType 2
successfully on Unix platforms. See http://LNC.usc.edu/~holt/makepp
successfully on Unix platforms. See http://makepp.sourceforge.net
for more details.]
- Go to the `freetype2' directory.

@ -98,6 +98,7 @@
#define ft_qsort qsort
#define ft_exit exit /* only used to exit from un-handled exceptions */
/**********************************************************************/
/* */
/* execution control */

@ -670,9 +670,9 @@
if ( start > end )
FT_INVALID_DATA;
/* this test should be performed at default validation level */
/* unfortunately, some popular asian fonts present overlapping */
/* ranges in their charmaps.. */
/* this test should be performed at default validation level; */
/* unfortunately, some popular Asian fonts present overlapping */
/* ranges in their charmaps */
/* */
if ( valid->level >= FT_VALIDATE_TIGHT )
{
@ -735,19 +735,19 @@
num_segs2 = TT_PEEK_USHORT( p ) & -2; /* be paranoid! */
#if 1
/* some fonts have more than 170 segments in their charmaps !! */
/* we changed this function to use a more efficient binary */
/* search to boost its performance */
/* Some fonts have more than 170 segments in their charmaps! */
/* We changed this function to use a more efficient binary */
/* search for improving performance */
{
FT_UInt min = 0;
FT_UInt max = num_segs2 >> 1;
FT_UInt mid, start, end, offset;
FT_UInt min = 0;
FT_UInt max = num_segs2 >> 1;
FT_UInt mid, start, end, offset;
while ( min < max )
{
mid = ( min + max ) >> 1;
p = table + 14 + mid*2;
p = table + 14 + mid * 2;
end = TT_NEXT_USHORT( p );
p += num_segs2;
start = TT_PEEK_USHORT( p);
@ -756,7 +756,7 @@
max = mid;
else if ( code > end )
min = mid+1;
min = mid + 1;
else
{
@ -771,12 +771,12 @@
if ( offset != 0 )
{
p += offset + 2*( idx - start );
p += offset + 2 * ( idx - start );
idx = TT_PEEK_USHORT( p );
}
if ( idx != 0 )
result = (FT_UInt)( idx + delta ) & 0xFFFU;
result = (FT_UInt)( idx + delta ) & 0xFFFFU;
goto Exit;
}
@ -784,6 +784,7 @@
}
#else /* 0 - old code */
{
FT_UInt n;
FT_Byte* q;
@ -823,7 +824,9 @@
}
}
}
#endif /* 0 */
}
Exit:

@ -988,8 +988,8 @@
/* check the 'storageOffset' field */
storageOffset = names->storageOffset;
/* some broken asian fonts have a storage offset whose value is */
/* 12*numNameRecords. We deal with them here.. */
/* Some broken Asian fonts have a storage offset whose value is */
/* 12 * numNameRecords. We deal with them here. */
if ( storageOffset == (FT_ULong)(12 * names->numNameRecords) )
storageOffset += 6;

Loading…
Cancel
Save