pax_global_header00006660000000000000000000000064124553567200014523gustar00rootroot0000000000000052 comment=2912c0a2e0a246318f41bf1997f34ce1dc3e5e42 libgd-gd-2.1.1/000077500000000000000000000000001245535672000131755ustar00rootroot00000000000000libgd-gd-2.1.1/.gitignore000066400000000000000000000124131245535672000151660ustar00rootroot00000000000000syntax: glob *~ *.[ao] .dirstamp *.exe *.obj *.dll Makefile CMakeCache.txt CMakeFiles cmake_install.cmake cscope.out CPackConfig.cmake CPackSourceConfig.cmake CTestTestfile.cmake libimagequant libimagequant-prefix src/deps.mk deps Release_GD # Autotools related files. *.l[ao] .deps .libs Makefile.in /aclocal.m4 /autom4te.cache /config.h /config.cache /config.log /config.status /configure /libtool /config/ar-lib /config/compile /config/config.guess /config/config.sub /config/depcomp /config/install-sh /config/ltmain.sh /config/missing /config/mkinstalldirs /m4/libtool.m4 /m4/ltoptions.m4 /m4/ltsugar.m4 /m4/ltversion.m4 /m4/lt~obsolete.m4 /src/config.hin /src/stamp-h1 # Common GD artifacts. /config/gdlib-config /config/gdlib.pc /src/config.h /src/annotate /src/circletexttest /src/fontconfigtest /src/fontsizetest /src/fontwheeltest /src/gd2copypal /src/gd2time /src/gd2togif /src/gd2topng /src/gd_color_map_test /src/gdcmpgif /src/gddemo /src/gdparttopng /src/gdtest /src/gdtestft /src/gdtopng /src/gifanimtest /src/giftogd2 /src/pngtogd /src/pngtogd2 /src/testac /src/testtr /src/webpng # Tests artifacts /config/test-driver /tests/*.log /tests/*/*.log /tests/*/*.trs /tests/a.png /tests/bmp_im2im_dst.bmp /tests/bmp_im2im_src.bmp /tests/bug00132.c_35_diff.png /tests/bug00132.c_35_out.png /tests/bug00181.gif /tests/bug00181a.gif /tests/bug00227.gif /tests/gd2_im2im_dst.gd2 /tests/gd2_im2im_src.gd2 /tests/gd_im2im_dst.gd /tests/gd_im2im_src.gd /tests/gdimageline_aa.c_38_diff.png /tests/gdimageline_aa.c_38_out.png /tests/gdimagestringft_bbox.png /tests/gif_im2im_dst.gif /tests/gif_im2im_src.gif /tests/jpeg_im2im_dst.jpeg /tests/jpeg_im2im_src.jpeg /tests/jpeg_read.c_25_diff.png /tests/jpeg_read.c_25_out.png /tests/png_im2im_dst.png /tests/png_im2im_src.png /tests/tiff_im2im_dst.tiff /tests/tiff_im2im_src.tiff /tests/wbmp/wbmp_im2im_dst.wbmp /tests/wbmp/wbmp_im2im_src.wbmp /tests/wbmp_im2im_dst.wbmp /tests/wbmp_im2im_src.wbmp /tests/gd2/gd2_empty_file /tests/gdimagesetpixel/bug00186 /tests/gdimagestringftex/gdimagestringftex_returnfontpathname /tests/gdimageline/gdimageline_aa_outofrange /tests/gdimagerectangle/bug00003 /tests/gdimagerectangle/bug00106_gdimagerectangle /tests/gd/gd_null /tests/gd/gd_num_colors /tests/gd/gd_versiontest /tests/tga/tga_null /tests/gdimagepixelate/gdimagepixelate /tests/gdimagecopy/bug00007 /tests/gdnewfilectx/gdnewfilectx_null /tests/gdimagefilledrectangle/bug00078 /tests/gdimagefilledrectangle/bug00004 /tests/gdimagefilledrectangle/bug00106_gdimagefilledrectangle /tests/gdimagecolordeallocate/gdimagecolordeallocate /tests/wbmp/wbmp_null /tests/gdimagecolortransparent/gdimagecolortransparent /tests/gif/bug00005_2 /tests/gif/gif_null /tests/gif/bug00181 /tests/gif/bug00227 /tests/bmp/bmp_null /tests/gdimagestringft/gdimagestringft_bbox /tests/gdtiled/bug00032 /tests/gd2/gd2_im2im /tests/gd2/gd2_null /tests/gd2/gd2_read /tests/gdimagearc/bug00079 /tests/gdimageline/gdimageline_aa /tests/gdimageline/bug00072 /tests/gdimageline/bug00077 /tests/gdimageline/bug00111 /tests/gdimageopenpolygon/gdimageopenpolygon2 /tests/gdimageopenpolygon/gdimageopenpolygon1 /tests/gdimageopenpolygon/gdimageopenpolygon0 /tests/gdimageopenpolygon/gdimageopenpolygon3 /tests/gd/gd_im2im /tests/gdimagecopy/bug00081 /tests/gdimagecopyrotated/bug00020 /tests/gdimagepolygon/gdimagepolygon0 /tests/gdimagepolygon/gdimagepolygon3 /tests/gdimagepolygon/gdimagepolygon1 /tests/gdimagepolygon/gdimagepolygon2 /tests/gdimagecolorresolve/gdimagecolorresolve /tests/gdimagefilledpolygon/gdimagefilledpolygon0 /tests/gdimagefilledpolygon/gdimagefilledpolygon3 /tests/gdimagefilledpolygon/gdimagefilledpolygon2 /tests/gdimagefilledpolygon/gdimagefilledpolygon1 /tests/gdimagefilledpolygon/bug00100 /tests/gdimagecolorreplace/gdimagecolorreplace /tests/gdimagefill/bug00002_2 /tests/gdimagefill/bug00002_1 /tests/gdimagefill/bug00002_4 /tests/gdimagefill/bug00002_3 /tests/gdimagecolorclosest/gdimagecolorclosest /tests/gif/bug00005 /tests/gif/gif_im2im /tests/gif/bug00066 /tests/gif/bug00006 /tests/gif/bug00060 /tests/gdimagecolorexact/gdimagecolorexact /tests/gdimagefilledellipse/bug00191 /tests/gdimagefilledellipse/bug00010 /tests/xpm/bug00185 /tests/xpm/color_name /tests/xpm/bug00166 /tests/jpeg/jpeg_empty_file /tests/jpeg/jpeg_resolution /tests/jpeg/jpeg_im2im /tests/jpeg/jpeg_null /tests/jpeg/jpeg_read /tests/png/png_null /tests/png/bug00033 /tests/png/bug00193 /tests/png/bug00011 /tests/png/bug00088 /tests/png/png_resolution /tests/png/bug00086 /tests/png/png_im2im /tests/wbmp/wbmp_im2im /tests/tiff/tiff_null /tests/tiff/tiff_im2im /tests/freetype/bug00132 /tests/bmp/bmp_im2im /tests/gdimagescatterex/bug00208_1 /tests/gdimagescatterex/bug00208_2 /tests/gdimagefilltoborder/bug00037 /tests/jpeg_read.c_28_diff.png /tests/jpeg_read.c_28_out.png /tests/test_config.h /tests/gdimagerotate/php_bug_64898 /tests/php_bug_64898.c_55_diff.png /tests/php_bug_64898.c_55_out.png /tests/gdimagerotate/bug00067 /tests/gdimageline/gdImageAALine_thickness /tests/gdimageline/gdimageline_bug5 /tests/gdinterpolatedscale/gdTrivialResize /tests/gdinterpolatedscale/gdModesAndPalettes /tests/gdimagefile/gdnametest /tests/gdimagefile/img.png /tests/gdimagefilter/gdCopyBlurred # Doc artifacts /docs/naturaldocs/html/ /docs/naturaldocs/project/Data/ gd-dotnet-bindings-generator build_msvc12_x86 build_msvc12_x64 build_mingw_x86 build_mingw_x64 libgd-gd-2.1.1/.travis.yml000066400000000000000000000010171245535672000153050ustar00rootroot00000000000000language: cpp env: - tbs_arch=x86 - tbs_arch=x64 os: - linux - osx before_install: - if [ "$TRAVIS_OS_NAME" = "linux" ]; then sudo apt-get update -qq; sudo apt-get -y install nasm; if [ "$tbs_arch" = "x86" ]; then sudo apt-get -y install gcc-multilib; sudo apt-get -y install g++-multilib; fi fi - if [ "$TRAVIS_OS_NAME" = "osx" ]; then brew install nasm; fi script: - ./thumbs.sh make - ./thumbs.sh check libgd-gd-2.1.1/CMakeLists.txt000066400000000000000000000163411245535672000157420ustar00rootroot00000000000000# $Id$ CMAKE_MINIMUM_REQUIRED(VERSION 2.6 FATAL_ERROR) SET(PACKAGE GD) SET(PACKAGE_NAME GD) CMAKE_POLICY(SET CMP0017 OLD) PROJECT(GD) SET(CMAKE_MODULE_PATH "${GD_SOURCE_DIR}/cmake/modules") OPTION(ENABLE_PNG "Enable PNG support" 0) OPTION(ENABLE_LIQ "Enable libimagequant support" 0) OPTION(ENABLE_JPEG "Enable JPEG support" 0) OPTION(ENABLE_TIFF "Enable TIFF support" 0) OPTION(ENABLE_ICONV "Enable ICONV support" 0) OPTION(ENABLE_XPM "Enable XPM support" 0) OPTION(ENABLE_FREETYPE "Enable Freetype2 support" 0) OPTION(ENABLE_FONTCONFIG "Enable FontConfig support" 0) OPTION(ENABLE_WEBP "Enable WebP support" 0) if (BUILD_TEST) ENABLE_TESTING() endif(BUILD_TEST) # if you would like to pass C flags to the compiler, then just # - specify -DCMAKE_C_FLAGS=... on invocation of cmake, or # - specify CFLAGS=... on invocation of make IF(CMAKE_COMPILER_IS_GNUCC) SET(CMAKE_C_FLAGS_DEBUG "-g -Wall -Wextra -O0") # will be added to CMAKE_C_FLAGS when CMAKE_BUILD_TYPE is "Debug" ENDIF(CMAKE_COMPILER_IS_GNUCC) SET (CMAKE_LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/Bin CACHE PATH "Single Directory for all Libraries" ) # --------- Setup the Executable output Directory ------------- SET (CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/Bin CACHE PATH "Single Directory for all Executables." ) # --------- Setup the Executable output Directory ------------- SET (CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/Bin CACHE PATH "Single Directory for all static libraries." ) if (USE_EXT_GD) message("Using GD at: ${USE_EXT_GD}") INCLUDE_DIRECTORIES(BEFORE ${GD_INCLUDE_DIR}) FIND_PACKAGE(GD) if (GD_FOUND) INCLUDE_DIRECTORIES(BEFORE ${GD_INCLUDE_DIR}) LINK_DIRECTORIES(${GD_LIBRARIES}) SET(GD_LIB ${GD_LIBRARIES}) SET(GD_LIBS_DIR ${GD_LIBRARY}) message("GD libs #: ${GD_LIBRARIES}") message("GD lib #: ${GD_LIBRARY}") message("GD include: ${GD_INCLUDE_DIR}") else (GD_FOUND) message("No gd found") endif (GD_FOUND) else (USE_EXT_GD) SET(GD_VERSION_MAJOR "2") SET(GD_VERSION_MINOR "1") SET(GD_VERSION_PATCH "1") SET(GD_VERSION_EXTRA "") SET(GD_VERSION "${GD_VERSION_MAJOR}.${GD_VERSION_MINOR}.${GD_VERSION_PATCH}${GD_VERSION_EXTRA}") SET(GD_VERSION_STRING "${GD_VERSION}") SET(GD_VERSION_INT "20101") SET(CMAKE_REQUIRED_INCLUDES "/usr/include" "/usr/local/include") include(CheckIncludeFiles) include(CheckIncludeFile) include(AC_HEADER_STDC) include(CheckPrototypeExists) if (ENABLE_PNG) FIND_PACKAGE(PNG REQUIRED) endif (ENABLE_PNG) if (ENABLE_ICONV) FIND_PACKAGE(ICONV REQUIRED) endif (ENABLE_ICONV) FIND_PACKAGE(ZLIB) IF (ENABLE_WEBP) FIND_PACKAGE(VPX) ENDIF (ENABLE_WEBP) IF (ENABLE_LIQ) FIND_PACKAGE(LIQ) ENDIF (ENABLE_LIQ) IF (NOT WIN32) FIND_PACKAGE(PTHREAD) ENDIF (NOT WIN32) if (ENABLE_JPEG) FIND_PACKAGE(JPEG) endif (ENABLE_JPEG) if (ENABLE_TIFF) FIND_PACKAGE(TIFF) endif (ENABLE_TIFF) if (ENABLE_FREETYPE) FIND_PACKAGE(Freetype) endif (ENABLE_FREETYPE) if (ENABLE_XPM) FIND_PACKAGE(XPM) endif (ENABLE_XPM) if (ENABLE_FONTCONFIG) FIND_PACKAGE(FontConfig) endif (ENABLE_FONTCONFIG) if (FREETYPE_FOUND) INCLUDE_DIRECTORIES(${FREETYPE_INCLUDE_DIRS}) SET(HAVE_FT2BUILD_H 1) SET(HAVE_LIBFREETYPE 1) ENDIF(FREETYPE_FOUND) IF(ZLIB_FOUND) INCLUDE_DIRECTORIES(${ZLIB_INCLUDE_DIR}) SET(HAVE_LIBZ 1) ENDIF(ZLIB_FOUND) IF(VPX_FOUND) INCLUDE_DIRECTORIES(${VPX_INCLUDE_DIR}) SET(HAVE_LIBVPX 1) ENDIF(VPX_FOUND) IF(PNG_FOUND) INCLUDE_DIRECTORIES(${PNG_INCLUDE_DIR}) SET(HAVE_LIBPNG 1) ENDIF(PNG_FOUND) IF(ICONV_FOUND) INCLUDE_DIRECTORIES(${ICONV_INCLUDE_DIR}) SET(HAVE_ICONV 1) SET(HAVE_ICONV_H 1) ENDIF(ICONV_FOUND) IF(LIQ_FOUND) INCLUDE_DIRECTORIES(${LIQ_INCLUDE_DIR}) SET(HAVE_LIBIMAGEQUANT_H 1) ENDIF(LIQ_FOUND) IF(XPM_FOUND) INCLUDE_DIRECTORIES(${XPM_INCLUDE_DIR}) SET(HAVE_LIBXPM 1) ENDIF(XPM_FOUND) IF(JPEG_FOUND) INCLUDE_DIRECTORIES(${JPEG_INCLUDE_DIR}) SET(HAVE_LIBJPEG 1) ENDIF(JPEG_FOUND) IF(TIFF_FOUND) INCLUDE_DIRECTORIES(${TIFF_INCLUDE_DIR}) SET(HAVE_LIBTIFF 1) ENDIF(TIFF_FOUND) IF(FONTCONFIG_FOUND) INCLUDE_DIRECTORIES(${FONTCONFIG_INCLUDE_DIR}) SET(HAVE_LIBFONTCONFIG 1) ELSE (FONTCONFIG_FOUND) SET(FONTCONFIG_LIBRARY "") SET(FONTCONFIG_INCLUDE_DIR "") SET(FONTCONFIG_LIB_DIR "") ENDIF(FONTCONFIG_FOUND) SET(HAVE_CONFIG_H 1) ADD_DEFINITIONS(-DHAVE_CONFIG_H) CHECK_INCLUDE_FILE("stdint.h" HAVE_STDINT_H) CHECK_INCLUDE_FILE("inttypes.h" HAVE_INTTYPES_H) CONFIGURE_FILE(${GD_SOURCE_DIR}/src/config.h.cmake ${GD_SOURCE_DIR}/src/config.h ESCAPE_QUOTES) set(BUILD_SHARED_LIBS On) if (WIN32) SET(GD_LIB libgd) ADD_DEFINITIONS( -DWIN32 -D_WIN32 -DMSWIN32 -DBGDWIN32 -DWINVER=0x0500 -D_WIN32_WINNT=0x0500 -D_WIN32_IE=0x0600) if(NOT MINGW AND MSVC_VERSION GREATER 1399) ADD_DEFINITIONS("/D_CRT_SECURE_NO_DEPRECATE") endif(NOT MINGW AND MSVC_VERSION GREATER 1399) if (MINGW OR MSYS) ADD_DEFINITIONS("-mms-bitfields") # -m32 endif (MINGW OR MSYS) else (WIN32) SET(GD_LIB gd) endif (WIN32) SET(GD_LIB_STATIC "${GD_LIB}_static") IF(PROFILE) add_definitions("-pg") set(CMAKE_EXE_LINKER_FLAGS ${LINK_FLAGS} "-pg") ENDIF(PROFILE) SET(GD_INCLUDE_DIR "${GD_SOURCE_DIR}/src" "${GD_SOURCE_DIR}") INCLUDE_DIRECTORIES(before ${FONTCONFIG_INCLUDE_DIR}) add_subdirectory(src) endif (USE_EXT_GD) add_subdirectory(tests) add_subdirectory(examples) add_subdirectory(docs) SET(CPACK_PACKAGE_NAME "libgd") SET(CPACK_PACKAGE_DESCRIPTION_SUMMARY "libGD, powerful and easy to use graphic library") SET(CPACK_PACKAGE_VENDOR "http://www.libgd.org") SET(CPACK_PACKAGE_VERSION_MAJOR "2") SET(CPACK_PACKAGE_VERSION_MINOR "1") SET(CPACK_PACKAGE_VERSION_PATCH "0") if(WIN32) set(CPACK_GENERATOR ZIP) else(WIN32) set(CPACK_GENERATOR TGZ) endif(WIN32) IF (ENABLE_LIQ AND LIQ_BUILD) ADD_DEPENDENCIES(${GD_LIB} libimagequant) ADD_DEPENDENCIES(${GD_LIB_STATIC} libimagequant) ENDIF(ENABLE_LIQ AND LIQ_BUILD) INSTALL(FILES docs/INSTALL DESTINATION share/docs) INSTALL(FILES docs/README.JPN DESTINATION share/docs) INSTALL(FILES docs/README.CMAKE DESTINATION share/docs) INSTALL(FILES docs/README.TESTING DESTINATION share/docs) INSTALL(FILES docs/README.TXT DESTINATION share/docs) INSTALL(FILES examples/arc.c DESTINATION share/docs) INSTALL(FILES examples/copyrotated.c DESTINATION share/docs) INSTALL(FILES examples/crop.c DESTINATION share/docs) INSTALL(FILES examples/flip.c DESTINATION share/docs) INSTALL(FILES examples/gif.c DESTINATION share/docs) INSTALL(FILES examples/nnquant.c DESTINATION share/docs) INSTALL(FILES examples/noIcon.pic DESTINATION share/docs) INSTALL(FILES examples/noIcon.sgi DESTINATION share/docs) INSTALL(FILES examples/noIcon.tga DESTINATION share/docs) INSTALL(FILES examples/noIconAlpha.tga DESTINATION share/docs) INSTALL(FILES examples/test_crop_threshold.png DESTINATION share/docs) INSTALL(FILES examples/tgaread.c DESTINATION share/docs) INSTALL(FILES examples/tiffread.c DESTINATION share/docs) INSTALL(FILES examples/windows.c DESTINATION share/docs) set(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_SOURCE_DIR}/COPYING") set(CPACK_SOURCE_GENERATOR TGZ) set(CPACK_SOURCE_IGNORE_FILES "~$" "\\\\.swp$" "\\\\.gitignore$" "^${PROJECT_SOURCE_DIR}/debian/" "^${PROJECT_SOURCE_DIR}/old/" "^${PROJECT_SOURCE_DIR}/bld/" ) install(FILES ${top_level_DOCFILES} DESTINATION ${DOC_DIR}) INCLUDE(CPack) libgd-gd-2.1.1/CONTRIBUTORS000066400000000000000000000004411245535672000150540ustar00rootroot00000000000000chapg Chris Reuter Colin Watson Dimitar Dobrev edink Gilles Espinasse guenter Kornel Lesiński kshepherd lhecking Marcin Wojdyr mattias Mike Frysinger mloskot Nathanael Jones nlopess Ondřej Surý Pierre Joye pornel Remi Collet scottmac tabe Takeshi Abe Tim Toohey tostercx Vincent Bernat libgd-gd-2.1.1/COPYING000066400000000000000000000043731245535672000142370ustar00rootroot00000000000000 Portions copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 by Cold Spring Harbor Laboratory. Funded under Grant P41-RR02188 by the National Institutes of Health. Portions copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002 by Boutell.Com, Inc. Portions relating to GD2 format copyright 1999, 2000, 2001, 2002 Philip Warner. Portions relating to PNG copyright 1999, 2000, 2001, 2002 Greg Roelofs. Portions relating to gdttf.c copyright 1999, 2000, 2001, 2002 John Ellson (ellson@lucent.com). Portions relating to gdft.c copyright 2001, 2002 John Ellson (ellson@lucent.com). Portions copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007 Pierre-Alain Joye (pierre@libgd.org). Portions relating to JPEG and to color quantization copyright 2000, 2001, 2002, Doug Becker and copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, Thomas G. Lane. This software is based in part on the work of the Independent JPEG Group. See the file README-JPEG.TXT for more information. Portions relating to WBMP copyright 2000, 2001, 2002 Maurice Szmurlo and Johan Van den Brande. Permission has been granted to copy, distribute and modify gd in any context without fee, including a commercial application, provided that this notice is present in user-accessible supporting documentation. This does not affect your ownership of the derived work itself, and the intent is to assure proper credit for the authors of gd, not to interfere with your productive use of gd. If you have questions, ask. "Derived works" includes all programs that utilize the library. Credit must be given in user-accessible documentation. This software is provided "AS IS." The copyright holders disclaim all warranties, either express or implied, including but not limited to implied warranties of merchantability and fitness for a particular purpose, with respect to this code and accompanying documentation. Although their code does not appear in gd, the authors wish to thank David Koblas, David Rowley, and Hutchison Avenue Software Corporation for their prior contributions. libgd-gd-2.1.1/ChangeLog000066400000000000000000000470711245535672000147600ustar00rootroot00000000000000be907e0 fix indent (Pierre Joye) 999b5d2 add sanity check and fix leak on exit (Pierre Joye) 1424dd6 free path on error (Pierre Joye) 13d87a6 free im on error (Pierre Joye) 2a40315 update changelog (Pierre Joye) 5c562ec Add thumbs.bat and thumbs.sh to Makefile.am (Nathanael Jones) bc372f2 Merge branch 'master' into rebase-1-for-2015 (Nathanael Jones) a247407 Use sprintf instead of snprintf to be C89 compliant. (Nathanael Jones) 0324316 Remove uneeded includes introduced in earlier version-local commits. (Nathanael Jones) 4d54513 Exposed all missing format-independent members in the C++ wrapper. (Nathanael Jones) c7bf379 Update gdpp.* to use HAVE_LIBPNG vs HAVE_PNG, etc.- should honor the same feature support flags as the rest of gd, (Nathanael Jones) 40c6129 Normalize static lib name to libgd.a on *nix and libgd_static.lib on windows. (Nathanael Jones) 7c2b071 Replace windows MSVC makefile; update msys iconv path. (Nathanael Jones) 07c3fde Drop -m32 definition on MINGW; prevents a 64-bit build from occurring. (Nathanael Jones) 37f5925 Skip bug00132 - failing because test data is out if date (we think). (Nathanael Jones) f085a2e When both CPP_SHARP and _WIN32 are defined, do not enable thread safety. (Nathanael Jones) e81ff90 Export C++ wrapper clases. Change two Gd() functions of the C++ wrapper to return values when the underlying C calls do. (Nathanael Jones) 56f79f3 C89 compat; define vars at top of function (Nathanael Jones) b52b9c5 Upgrade to long-syntax CMAKE add_test command to improve cross-platform compatibility. (Nathanael Jones) e8a1a46 free coeffs (Pierre Joye) 5f7c099 free allocated palette on error (Pierre Joye) 7b49862 fix im leaked on error (Pierre Joye) 4faf926 just reduce static analyzer noise (Pierre Joye) 2a09086 free tc_cache and path on error (leak) (Pierre Joye) 09e954b Thumbs: add osx settings for travis (tostercx) 4af76c9 fix comment (Remi Collet) 3c0d220 Fix possible infinite loop (php bug report #68713) - make code more legible (yy>=yy-1 seems ugly) - fix mem leak, always free src->tpixels (Remi Collet) 7a8e6b8 Thumbs: use rsync -u on osx as it doesn't have cp -u (tostercx) eb9d7d1 Thumbs: Remove cp -u usage (Nathanael Jones) c9e458b add read-only test images to tarball (Remi Collet) 3169371 use / in image patch (Remi Collet) 81e9a99 move overflow test outside the loop for perf (Remi Collet) 47eb44b Fix possible buffer read overflow detected by -fsanitize=address, thanks to Jan Bee (Remi Collet) 5fe6837 squash test commits; add deps from nuget; fix bindings (tostercx) 679fd78 pack compressed dll vers; build bindings (tostercx) 0c3b914 fix mingw if blocks (tostercx) 84319d1 replace slashes with backslashes for appveyor/cmd (tostercx) c954881 add build targets for gnu with thumbs (tostercx) 18c51e6 fix tiff targets (tostercx) 5f99611 fix dll_name not set before usage (tostercx) c447d68 fetch nasm (tostercx) 7ba81f0 add thumbs (tostercx) 4865cdb rename libs correctly as soon as they're copied (tostercx) bf51c4e fix tbsd_*_built flags not being set (tostercx) f3deb6b add basic msvc thumbs (tostercx) 39fd5ce Exposed all missing format-independent members in the C++ wrapper. (Dimitar Dobrev) 2d74b00 update lib switching macros (tostercx) d5527e7 push config.h (tostercx) 5828f7e Use ifdefs around keyword redefinitions (Nathanael Jones) d3fb9c3 update appveyor project url (tostercx) 6db34b7 Merged in nathanaeljones/gd-libgd/test-message-improvements (pull request #22) (Nathanael Jones) d1a6768 Merged in nathanaeljones/gd-libgd/add-osx-boostrap-support (pull request #21) - bootstrap.sh now offers build tips on OS X and defaults to glibtoolize (Nathanael Jones) 31619ab Merged in nathanaeljones/gd-libgd/shut-up-automake (pull request #23) Silence automake 1.14 warnings (Nathanael Jones) 7eb9462 Merged in nathanaeljones/gd-libgd/cmake-iconv (pull request #24) (Nathanael Jones) dedf03f Merged in nathanaeljones/gd-libgd/msvc-fix-keyword-macros (pull request #25) (Nathanael Jones) c4809ae Changed two functions of the C++ wrapper to return values when the underlying C calls do. (Dimitar Dobrev) 433b04a set msvc output to minimal (tostercx) daa7613 move drone build script to file (tostercx) 82550ca add drone badge (tostercx) 6ea31fb reset build type (tostercx) 47eaee1 test CMAKE_BULD_TYPE (tostercx) e4fbb28 test CMAKE_BULD_TYPE (tostercx) 8e18552 push uncompressed dlls as artifacts (tostercx) 0bcb5e3 push uncompressed dlls as artifacts (tostercx) 5d09526 test dgn w64 (tostercx) e3fe7e4 warn inline (tostercx) adc3b7c test w64-32 (tostercx) 55f9066 inline test 3 (tostercx) 12898fe inline test 2 (tostercx) 8864390 inline test (tostercx) 0cd926f Exported all classes from the C++ binding of libgd. (Nathanael Jones) c8711e7 fetch binding gen from master (tostercx) 23b5f11 test 32bit msvc bindings (tostercx) 98d1a1a update binding artifact handling (tostercx) 6be49c8 test msvc x64 bindings 4 (tostercx) 97c2846 test msvc x64 bindings 3 (tostercx) eee663c test msvc x64 bindings 2 (tostercx) a7ce8bb test msvc x64 bindings (tostercx) 12a6fbc scrap ramdisks (tostercx) 1f07497 ramdisk test 3 (tostercx) 398a82c ramdisk test 2 (tostercx) c6cd0d8 ramdisk test (tostercx) ae8a7e5 imdisk test 7 (tostercx) 3a178fd imdisk test 6 (tostercx) 5d5eb2a imdisk test 6 (tostercx) bfdc673 imdisk test 5 (tostercx) 1855563 imdisk test 5 (tostercx) 084e2e2 imdisk test 4 (tostercx) bbad6a7 imdisk test 3 (tostercx) 9d3bd38 imdisk test 2 (tostercx) ff7ace5 Merge branch 'master' of https://github.com/imazen/gd-libgd (tostercx) e78df6a imdisk test (tostercx) f15ea0e Msbuild logging: Fix block scope error (Nathanael Jones) 3a7334c Msbuild now logs to file and uploads as artifact (Nathanael Jones) c0ce1fa Enable verbose msbuild output temporarily (Nathanael Jones) b70fd99 fix unix static name (tostercx) b217d22 update nuget package names; add version # (tostercx) 724869d update test macro usage (tostercx) 560aa9b fix ps syntax errors (tostercx) dce1809 configure files only if building bindings (tostercx) e023800 test min=1 (tostercx) 668ef42 test min=0 (tostercx) c28d572 quote function (tostercx) cd9ae09 test test switching macros (tostercx) c9b0fec add gdsharp .cs files to artifact (tostercx) c19f2e0 remove SET spaces (tostercx) 3e88692 fix if spacing (tostercx) 9208848 test min flag (tostercx) fef130e mingw test - noft; wtiff (tostercx) 8fae7df test mingw no tiff (tostercx) bef860f mingw test build (tostercx) 841f3cd fix msvc static lib name; test mingw no-rtti (tostercx) 31552f5 build all (tostercx) 071963b fix if block (tostercx) 71f8aaf remove original dll on pack (tostercx) b7ac813 minimal build (tostercx) 487ee4c re-enable packing (tostercx) 8e4ea0e test ps spacing (tostercx) 3ef2235 disable upx (tostercx) 918d603 update library names (tostercx) bfff81d update library names (tostercx) daa782e upx test 3 (tostercx) 5fc0ca3 upx test 2 (tostercx) 4fba094 add upx; fix cmake_cmd (tostercx) 015be62 spring cleaning (tostercx) 09daf1d re-fix if block (tostercx) 338c39b fix mingw freetype static link (tostercx) 335fd04 fix tiff static link (tostercx) 397029a fix if block (tostercx) c16ccd1 fix freetype static links (tostercx) 6c3617a add appveyor badge (tostercx) b6b0249 push nunit result xml as artifact (tostercx) d87b394 disable iconv (tostercx) fb10cf1 fix dll dir for bindings (tostercx) 61e8d53 simplify build script (tostercx) b6a6ba6 fix static link to iconv for mingw builds (tostercx) f8d2a36 fix mingw static links (tostercx) ff2eb8a fix msvc link to static jpeg (tostercx) 1d75d52 remove inline flags; fetch deps from subbuilds (tostercx) b0167e9 keep inline functions (tostercx) 6d3ab8d fix mingw dir; build only mingw (tostercx) 4d88ae7 scrap .vhd mount; update compiler blob location (tostercx) 1f7d33b test mounted mingww64 (tostercx) bd4cebd fix bloated freetype (tostercx) ade007d Support MSVC++ 2013 and higher: define _ALLOW_KEYWORD_MACROS, inline, strcasecmp, snprintf. (Nathanael Jones) f82b371 Add libiconv support to CMake files (Nathanael Jones) 10ffb33 Silence automake 1.14 warnings ("source file is in a subdirectory, but option subdir-objects is disabled"). (Nathanael Jones) 90c3799 Add gdTestAssertMsg(condition, formatmessage, variables) to support detailed failure messages. Improve error reporting and diagnostics in gdimagefile test. Fix 'max' definition conflict on some compilers. (Nathanael Jones) 7f1d183 bootstrap.sh now offers build tips on OS X and defaults to glibtoolize (Nathanael Jones) 444c760 update mingw crt static link command (tostercx) 0b10bb8 exclude failing binding test; build all (tostercx) f05791c static link msvc runtime (tostercx) 4f8e411 fix elseif block (tostercx) 7dc864c static link mingw compiler deps (tostercx) c38ad3c update repositories (tostercx) 64b843b Merge pull request #5 from tostercx/master (tostercx) 292124c squash everything (tostercx) 8d63a96 Merge pull request #4 from tostercx/master (Nathanael Jones) 344267f fix testing env detection and directory (tostercx) 9664951 fix tests not executing (tostercx) 701507b fix x64 cross compiles (tostercx) 33dff1f not needed anymore (tostercx) c1bcfcd not needed anymore (tostercx) 9546428 fix platform letter case (tostercx) 4d74480 fix gdtest not rebuilding (tostercx) 4fac5f7 remove mkdir error messages (tostercx) 6e7128a Prevent CppSharp parsing error (Nathanael Jones) 8e8c0f9 Get gdnametest passing on windows (Nathanael Jones) 300b6ff Fix gdnametest on *nix (Nathanael Jones) 6c4ffe7 Improve error messages in gdnametest. (Nathanael Jones) ddbf021 Drop strcasecmp implementation. Only define 'inline' on msvc builds. (Nathanael Jones) 42e5fa7 Merge remote-tracking branch 'origin/master' (Nathanael Jones) e30293d Add a readme for building on windows. (Nathanael Jones) 681992a Remove src/config.h and src/gd.h from .gitignore. Sheesh. (Nathanael Jones) 235c5b0 Merge pull request #3 from tostercx/master (Nathanael Jones) 0eb3b05 fix rebuilds failing (tostercx) dab8734 fix mkdir failing on appveyor (tostercx) 0356ea9 fix mkdir failing on appveyor (tostercx) 96408de fix mkdir (tostercx) 073197d fix dir making (tostercx) 2e1d22e fix makefile always rebuilding (tostercx) 25b31be add cleanup, .gitnore build directories and deps, partially fix always rebuilding (tostercx) 7f735f6 Merged in nathanaeljones/gd-libgd/nathanaeljones/restore-support-for-alphablendingflag-va-1409782287517 (pull request #20) (Pierre Joye) 08eb6ee Restore support for alphaBlendingFlag value gdEffectAlphaBlend (Nathanael Jones) e3ff6ec C89 compat (tostercx) e52ed5e Merge pull request #2 from tostercx/master (Nathanael Jones) 6cc63f2 fix platorm reports in test (tostercx) 68a8dc0 updated windows makefile and test execution (tostercx) 8e7df78 Fix syntax error in Makefile.vc (missing line continuations) (Nathanael Jones) 71ab3d8 Fix space/tab mix in Makefile.vc; enable vectorization reporting. (Nathanael Jones) 911046d Comment out unused compilation vars; ensure (_)WIN32 is set, enable speed optimizations via /O2 (Nathanael Jones) 749b33e Improve error reporting in gdimagefile test. Add gdTestAssertMsg(condition, message, variables) to support detailed failure messages. (Nathanael Jones) db88704 Restore support for alphaBlendingFlag value gdEffectAlphaBlend. (9 unit tests pass again). (Nathanael Jones) dc8bb49 Only omit the 'max' macro if it is already present (this may break windows, let's see) (Nathanael Jones) b0b140f Drop 7zip installation step, should already be installed on AppVeyor by default. (Nathanael Jones) bcf7cb4 Switch dependency repository back, and use a named branch now for compatibility. (Nathanael Jones) 043dfa8 Merge pull request #1 from tostercx/master (Nathanael Jones) 12ab27b add notes (tostercx) b710274 remove old makefiles (tostercx) dd870dc consolidate makefiles to windows/makefile.vc (tostercx) c114d89 consolidate makefiles to windows/makefile.vc (tostercx) 720f82b add static lib to artifacts, generate test config in makefile (tostercx) c088f28 add static lib to artifacts, generate test config in makefile (tostercx) 0db988e add static lib to artifacts, generate test config in kaefile (tostercx) 1ce2b19 fix overwriting LIB env var (tostercx) e0475cc debug iconv tmp fix (tostercx) a3ee395 re-fix mkdir (tostercx) 5abb901 fix mkdir (tostercx) 35888c5 added making static libgd (tostercx) 701bc63 switch to libjpeg-turbo (tostercx) d74fa37 fetch deps from imazen/gd-win-dependencies (tostercx) 23cbea2 Add AppVeyor files provided by TosterCx (Nathanael Jones) af9ca1d Simplify makefile and add static lib generation. (Nathanael Jones) ce5f060 Simplify Makefile.vc (Nathanael Jones) ab31a6d Build inside Release_GD (Nathanael Jones) ee308e1 Rename Makefile.gd and add some notes (Nathanael Jones) d8987f5 Added strcasecmp implementation, now creates a .dll (Nathanael Jones) 09006c4 Get makefile almost working (Nathanael Jones) 2fdf3ad Start work on nmake makefile (Nathanael Jones) 0eb8429 Changed path to libiconv in msys Makefile. (Nathanael Jones) 5aee678 Merged from the upstream. (Nathanael Jones) 31ff666 Merged in ttoohey/gd-libgd/layout-effect (pull request #18) (Ondřej Surý) 33c05c1 Merged in ttoohey/gd-libgd/bugfix/font_path_overrun (pull request #19) (Ondřej Surý) 463c3bd CVE-2014-2497, NULL pointer dereference, fix #126 (Remi Collet) f01ade7 Remove wrong license headers. Based on http://www.paulbourke.net/dataformats/tga/ (Pierre Joye) 354409b Fix buffer overrun from long font search path (Tim Toohey) 01dccbd add tests for layer effects (Tim Toohey) b39f92b Add overlay and multiply effects to gdImageSetPixel (Tim Toohey) 4b86e06 Fix artefact in gdImageScale using GD_BILINEAR_FIXED (Remi Collet) 1de3b80 new example "resize" (Remi Collet) 5b42b11 Fix gdImageSetInterpolationMethod with GD_DEFAULT (Remi Collet) 2d5dc2e MSys Makefile now statically links libgd.dll to libiconv. (Chris Reuter) 01104a2 MSys Makefile fix (Chris Reuter) 7a8e8b2 Bug fix: GD DLL rename hadn't been propagated everywhere. (Chris Reuter) 6b94f66 Minor enhancements to the MinGW+Msys build scripts. (Chris Reuter) 339b17a Updated the MSys build files. (Chris Reuter) 0cb34fd Got gd_filename.c to work correctly under Windows. (Chris Reuter) 74ad18c Updated .gitignore. (Chris Reuter) 0da2258 Added TIFF to the list of skipped image formats in gdnametest.c (Chris Reuter) 0afe34d Merge branch 'master' of https://bitbucket.org/libgd/gd-libgd (Chris Reuter) 275ac17 Started importing the old manual into Naturaldocs comments. (Chris Reuter) 3b2caf6 Added function 'gdImageGetInterpolationMethod()'. (Chris Reuter) 592e232 Merge branch 'master' of https://bitbucket.org/libgd/gd-libgd (Chris Reuter) 00cd958 Added gdnametest and gdCopyBlurred to .gitignore. (Chris Reuter) 4761a7e Added gdnametest and gdCopyBlurred to .gitignore. (Chris Reuter) c9d2f89 Added gdImageFile(), gdImageCreateFromFile() and gdSupportsFileType(). (Chris Reuter) 9eb3951 Added gdImageFile(), gdImageCreateFromFile() and gdSupportsFileType(). (Chris Reuter) e054be7 Small code cleanup. (Chris Reuter) 3cb508f Small code cleanup. (Chris Reuter) 9933000 Merge branch 'master' of https://bitbucket.org/libgd/gd-libgd (Chris Reuter) b20cdef Added a test case for gdImageCopyGaussianBlurred(). (Chris Reuter) 6febd90 Added a new Gaussian blur function. (Chris Reuter) 3c43f07 Merge branch 'master' of https://bitbucket.org/libgd/gd-libgd (Chris Reuter) d525680 Bug fix: gdImageScale() was sometimes messing up transparency. (Chris Reuter) b505465 Merge remote-tracking branch 'upstream/master' (Chris Reuter) 549addc Added .gitignore lines to exclude naturaldocs by-products. (Chris Reuter) bb1d4a0 Added documention for gdImageCreate() and type gdImage. (Chris Reuter) 3c1202e Added beginnings of an updated manual (Chris Reuter) 7060f5e Added another Makefile. (Chris Reuter) 769fb15 Added another Makefile. (Chris Reuter) 3f8931d Bug fix: tests didn't (always) return a valid status. (Chris Reuter) 0dfd45c Bug fix: tests didn't (always) return a valid status. (Chris Reuter) f316c8a Removed bash-ism from bootstrap.sh. (Not /bin/sh are bash, even these days.) (Chris Reuter) 6cb7f9f Merge branch 'master' of github.com:imazen-discovery/gd-libgd (Chris Reuter) 0adaf8a Merge branch 'master' of https://bitbucket.org/libgd/gd-libgd (Chris Reuter) d21db28 Merge remote-tracking branch 'refs/remotes/origin/master' (Nathanael Jones) 68d38a8 bootstrap.sh now offers build tips on OS X and defaults to glibtoolize (Nathanael Jones) 9812cc4 Merge branch 'master' of https://bitbucket.org/suetanvil/gd-libgd. (Chris Reuter) 506e57a Merged libgd/gd-libgd into master (Chris Reuter) 16ccce6 Fixed a comment. (Chris Reuter) e82b084 Added new files to CMakeLists.txt. (Chris Reuter) 8cdb109 Updated Netware makefile (Chris Reuter) 784ffdd Test case for new version code. (Chris Reuter) 4378b8d gd.h now holds the canonical version number. (Chris Reuter) 3c96ad1 Keep automake from complaining "automake: but option 'subdir-objects' is disabled" (Nathanael Jones) 5b7f746 Merged libgd/gd-libgd into master (Chris Reuter) 3766620 Merge branch 'master' of https://bitbucket.org/libgd/gd-libgd (Chris Reuter) 3884557 Merged in suetanvil/gd-libgd/scale-palette-image-bug (pull request #16) (Chris Reuter) 1a92b2e Merged in suetanvil/gd-libgd/interp-precision (pull request #15) (Chris Reuter) 723ea52 Fix for Issue #97: segfaults when scaling a non-truecolor image (Chris Reuter) f321961 Added test case to exercise all of the gdImageScale() modes. (Chris Reuter) 5586a1e Merged libgd/gd-libgd into master (Chris Reuter) 948bb0a Higher precision in scaling. (Chris Reuter) 3f713da Higher precision in scaling. (Chris Reuter) 1c6ee56 More dead code removal. (Chris Reuter) 241ada6 Removed some dead code. (Chris Reuter) 916d00c Merged in suetanvil/gd-libgd/suetanvil-scale-code-cleanup (pull request #14) (Pierre Joye) 0510b4f Merged in suetanvil/gd-libgd/suetanvil-dead-code-removal (pull request #13) (Pierre Joye) 2ade818 Merge branch 'private-scale-axis-merge-rebased' (Chris Reuter) 546b274 Bug fix: #92: Bicubic scaling leaves the rightmost and bottom rows black (Chris Reuter) 16ed1a9 Added a test case for gdImageScaleTwoPass(). (Chris Reuter) 65fce84 Improved testing code (Chris Reuter) be3c8cb Cleaned up floating-point rescaling code. (Chris Reuter) 0d13658 More dead code removal. (Chris Reuter) 5ce14ef Removed some dead code. (Chris Reuter) 70a4070 Merge branch 'master' of https://bitbucket.org/suetanvil/gd-libgd (Chris Reuter) 08fdff6 Merged libgd/gd-libgd into master (Chris Reuter) 6db2828 Merge remote-tracking branch 'remotes/bitbucket-repo/suetanvil' (Chris Reuter) 3c5c639 Merged in suetanvil/gd-libgd/suetanvil (pull request #12) (Pierre Joye) 4f65a3e Fixed memory overrun bug in gdImageScaleTwoPass (Chris Reuter) 3e76d30 Merged libgd/gd-libgd into master (Chris Reuter) de7acbf Merged in suetanvil/gd-libgd (pull request #11) (Pierre Joye) 4c70f57 Fix #86: gdImageScale segfaults with most interpolation types (Chris Reuter) 6d1275d Fix bug #86 (segfaults on gdImageScale with most interpolation modes). (Chris Reuter) 2a862b2 Undo previous change to make a cleaner changeset. (Chris Reuter) 4a90e3f Fixed bug #86. https://bitbucket.org/libgd/gd-libgd/issue/86/gdimagescale-segfaults-with-most (Chris Reuter) d47c718 Merge branch '2.1.0-stable' into bicubic-fixed-perf (Chris Reuter) fda0b29 Added a function to retrieve the interpolation mode ID. (Chris Reuter) fb93646 Added the latest manual I could find. (Chris Reuter) a0be11f Added new README.md prior to importing into GitHub. (Chris Reuter) a0f58c6 fix #81, cmake_minimum_required must be the 1st line in 2.8+ (Pierre Joye) 54f8019 GD_EXTRA_VERSION and GD_VERSION_STRING needs quotes (Courtesy of Marc Deslauriers) (Ondřej Surý) dfea094 Add INSTALL notes for Solaris conflicting iconv.h headers (fixes #76) (Ondřej Surý) 37689ef ignore generated gd.h header (Ondřej Surý) 5b917b4 Merged in fix-version-in-gd.h (pull request #9) (Ondřej Surý) f597bd4 Don't append dash when GDLIB_EXTRA is empty (Ondřej Surý) f47a1df Create gd.h from gd.h.in to properly include current library version (Ondřej Surý)libgd-gd-2.1.1/Makefile.am000066400000000000000000000002621245535672000152310ustar00rootroot00000000000000ACLOCAL_AMFLAGS = -I m4 SUBDIRS = src config tests EXTRA_DIST = test docs examples windows VMS cmake netware bootstrap.sh CMakeLists.txt thumbs.bat thumbs.sh CONTRIBUTORS README libgd-gd-2.1.1/NEWS000066400000000000000000000132701245535672000136770ustar00rootroot00000000000000'GD NEWS ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| GD HEAD 169, gdColorMapLookup() answers the RGB values according to given color map (Takeshi Abe) 176, Added support of variable resolution by Alan Boudreault (Takeshi Abe) 184, new filter gdImagePixelate() by Kalle Sommer Nielsen (Takeshi Abe) GD 2.0.36 (2007-11-xx) 145, Fixed leak in gdImageCopyResized (Patch by Brent Bottles) 81, Fixed gdImageCopy with true color image, the transparent color was ignored (Pierre, Mark Fisher) 88, Fixed support of PNG grayscale image with alpha channel (Pierre) 95, Added Netware builds script (Guenter) 97, ease the creation of regexp to match symbols/functions in the sources (Guenter) 100, spurious horizontal line drawn by gdImageFilledPolygon (Takeshi Abe) 101, _gdCreateFromFile() can crash if gdImageCreate fails (Mattias Bengtsson) 105, gdImageCreateFrom*Ptr() can crash if gdNewDynamicCtxEx() fails (Mattias) 106, gdImageRectangle draws 1x1 rectangles as 1x3 rectangles (Pierre) 109, Possible integer overflow in gdImageFill() (Mattias Bengtsson) 111, Optimization for single pixel line not in correct order (Mattias) 112, gdImageColorDeallocate can write outside buffer (Mattias Bengtsson) 113, gdImageColorTransparent can write outside buffer (Mattias Bengtsson) 127, gdImageWBMPCtx can crash when createwbmp fails (Scott) 132, Fixed decoding of the html entity ϑ (Thomas Bonfort, Pierre) 133, Fixed configure script ignoring --with-png=DIR option (Scott) 166, Fixed handling 3-digit RGB and transparent color in XPM (Takeshi Abe) 173, Fixed the memory management in font_path() of gdft.c (Takeshi Abe) 174, Fixed that font_path() in gdft.c breaks reentrancy (Takeshi Abe) 180, Added a Makefile entry for tests/xpm (Takeshi Abe) 181, Fixed gd_gif_out.c to enable proper interlace 185, Fixed memory leaks in gdImageCreateFromXpm() (Takeshi Abe) 186, Fixed tiling true colour with palette image (Marko Vukovic, Takeshi Abe) 193, Fixed gdImagePng() with no color allocated (Martin McNickle, Takeshi Abe) 196, Fixed a memory leak in newDynamic() (Steve Fossen) 198, Fixed useFontConfig() to work as documented (Mojca Miklavec, Ethan Merritt) GD 2.0.35 (2007-06-21) 41, Fix valgrind error in gdImageFillTiled (Nuno Lopes) 45, Add missing custom cmake macros (required for the tests suite) 51, Avoid signature buffer copy in gd_gif_c (Nuno Lopes) 48, Race condition in gdImageStringFTEx (Antony Dogval, Pierre Scott MacVicar) 52, Reading GIF images is not thread safe (static usage in private functions) (Roman Nemecek, Nuno Lopes, Pierre) 60, GIF Local palette is read twice 66, GIF, Use local frame dimension when possible instead of the logical screen size (Pierre) 68, OpenVMS build support, see VMS/README.VMS for the details (Alexey Chupahin) 70, GIF, do not try to use the global colmap if it does not exist (Nuno Lopes, Pierre) 72, gdImageAALine draws axis lines with two pixels width (Pierre) 73, TTF usage doesn't work properly on Netware (Guenter Knauf, Scott MacVicar) 74, gdImageArc CPU usage with large angles (Pierre) 78, gdImageFilledRectangle regression fixed when used with reversed edges (Pierre) 86, Possible infinite loop in libgd/gd_png.c, flaw found by Xavier Roche (Pierre) 87, Fixed segfault when an invalid color index is present in a GIF image data, reported by Elliot (Pierre) 89, Possible integer overflow in gdImageCreateTrueColor (Pierre) 94, gdImageCreateXbm can crash if gdImageCreate fails (Pierre) GD 2.0.34 (2007-02-07) 3, Initialize variables in tweenColorTest, fix cache 4, gdImageFill, multiple segfaults with patterns or invalid arguments 5, gdImageRectangle draws corners twice 6, GIF Output does use the transparent color with truecolor images 7, Multiple security issues in GIF loader 8, gdIimageCopy doen't use the alpha channel 9, Add autogen and and misc configure/makefile (Lars Hecking) 10, gdImageFilledEllipse does not respect transparency 11, gdImageCreateFromPng* crashes with empty file 12, gdImageCreateFromPngCrx, initialize the signature buffer not the infile 13, leak in jinit_2pass_quantizer (gd_topal.c) 14, Added santiy checks for possible memory allocation errors 15, gdImageCreatePaletteFromTrueColor, later color allocations overwrite the palette colors (Rob Leslie) 16, Obscure error on Sun's compiler in entities.tcl (John Ellson/Graphviz) 17, gdImageCreate, invalid gdFree call when overflow2 fails 18, HWB_Diff, invalid usage of abs instead of fabs (Nick Atty) 19, Fixed gdImageCopyMergeGray when used with a true color image 20, transparency preservation in gdImageCopyRotated 21, Out of range checks in gdImageSetAAPixelColor 22, gdFontCacheSetup does not stop on error 23, Errors when gdImageStringFTEx is called with an empty string (Kevin Scaldeferri) 24, gdft.c, uninitialized variable "charmap" and avoid divide-by-zero (John Ellson/Graphviz) 25, DISABLE_THREADS to permit disabling of thread support (John Ellson/Graphviz) 26, dynamicGetbuf, sourceGetbuf must return 0 for errors and EOF 27, gdSeek declaration is wrong 29, Windows native makefile (Edin Kadribašić) 30, restores the ability to recognize and handle a font with Adobe-specific character encoding. Added gdFTEX_Adobe_Custom. 31, Shared library support on cygwin (Dr. Volker Zell) 32, Pattern-fill works incorrectly if tile is created via gdImageCreateTruecolor (Ethan Merritt) 33, malformed PNG image crashes (CRC error) 34, reading some gif images creates infinite loop 36, gdImageFillToBorder crashes when used with alpha 40, possible Buffer overflow in the gdImageStringFTEx function in gdft.c (CVE-2007-0455) (Kees Cook) libgd-gd-2.1.1/README000066400000000000000000000011361245535672000140560ustar00rootroot00000000000000GD is an open source code library for the dynamic creation of images by programmers. GD is written in C, and "wrappers" are available for Perl, PHP and other languages. GD creates PNG, JPEG, GIF, WebP, XPM, BMP images, among other formats. GD is commonly used to generate charts, graphics, thumbnails, and most anything else, on the fly. While not restricted to use on the web. The most common applications of GD involve website development. The library was originally developped by Thomas Boutell and is now maintained by many contributors (see the CONTRIBUTORS file) under the umbrella of PHP.net. libgd-gd-2.1.1/VMS/000077500000000000000000000000001245535672000136425ustar00rootroot00000000000000libgd-gd-2.1.1/VMS/CONFIGURE.COM000066400000000000000000001024311245535672000155240ustar00rootroot00000000000000$! (c) Alexey Chupahin 18-APR-2006, 15-DEC-2007 $! OpenVMS 8.2 Alpha DEC 2000 model 300 $! OpenVMS 8.3 Itanium rx1620 $! GNU $! $! $DEF SYS$ERROR _NL0: $ SET NOON $WRITE SYS$OUTPUT " " $WRITE SYS$OUTPUT "Configuring GD library for OpenVMS" $WRITE SYS$OUTPUT "(c) Alexey Chupahin " $! Checking architecture $! Checking architecture $ IF F$GETSYI("ARCH_TYPE").EQ.1 THEN CPU = "VAX" $ IF F$GETSYI("ARCH_TYPE").EQ.2 THEN CPU = "Alpha" $ IF F$GETSYI("ARCH_TYPE").EQ.3 THEN CPU = "I64" $ OS = F$GETSYI("VERSION") $WRITE SYS$OUTPUT "Checking architecture ... ", CPU $WRITE SYS$OUTPUT "Checking OS ... OpenVMS ",OS $SHARED=0 $IF ( (CPU.EQS."Alpha").OR.(CPU.EQS."I64") ) $ THEN $ SHARED=64 $ ELSE $ SHARED=32 $ENDIF $DECC = F$SEARCH("SYS$SYSTEM:DECC$COMPILER.EXE") .NES. "" $IF (DECC) THEN $WRITE SYS$OUTPUT "Compiler ... DEC C" $IF (.NOT. DECC) THEN $WRITE SYS$OUTPUT "BAD compiler" GOTO EXIT $MMS = F$SEARCH("SYS$SYSTEM:MMS.EXE") .NES. "" $MMK = F$TYPE(MMK) $IF (MMS .OR. MMK.NES."") THEN GOTO TEST_LIBRARIES $WRITE SYS$OUTPUT "Please install MMS from DECSET or MMK" $! I cant find any make tool $GOTO EXIT $! $! $TEST_LIBRARIES: $! Setting as MAKE utility one of MMS or MMK. I prefer MMS. $IF (MMK.NES."") THEN MAKE="MMK/IGN=WAR" $IF (MMS) THEN MAKE="MMS/IGN=WAR" $WRITE SYS$OUTPUT "Checking build utility ... ''MAKE'" $WRITE SYS$OUTPUT " " $! $IF (P1.EQS."STATIC") .OR. (P1.EQS."static") $ THEN $ WRITE SYS$OUTPUT "Configuring for static only" $ SHARED=0 $ENDIF $! $! Is it package root directory? If no, go to [-] $ IF (F$SEARCH("[]VMS.DIR").EQS."") .AND. (F$SEARCH("[]vms.dir").EQS."") $ THEN $ SET DEF [-] $ ENDIF $! $!Checking for iconv $! $ DEFINE SYS$OUTPUT _NLA0: $ CC/OBJECT=TEST.OBJ SYS$INPUT #include int main() { iconv_t cd; cd = iconv_open ((const char *)0, (const char *)0); } $TMP = $STATUS $DEAS SYS$OUTPUT $IF (TMP .NE. %X10B90001) $ THEN $ HAVE_ICONV=0 $ENDIF $DEFINE SYS$OUTPUT _NLA0: $LINK/EXE=TEST TEST $TMP = $STATUS $!WRITE SYS$OUTPUT TMP $IF (TMP .NE. %X10000001) $ THEN $ HAVE_ICONV=0 $ ELSE $ HAVE_ICONV=1 $ENDIF $DEAS SYS$OUTPUT $IF (HAVE_ICONV.EQ.1) $ THEN $ WRITE SYS$OUTPUT "Checking for system iconv library... Yes" $ ELSE $ WRITE SYS$OUTPUT "Checking for system iconv library... No" $ENDIF $! $!"Checking for correct zlib library " $ ZLIB_STATIC=0 $ DEFINE SYS$OUTPUT _NLA0: $ CC/OBJECT=TEST.OBJ/INCLUDE=(ZLIB) SYS$INPUT #include #include #include int main() { printf("checking version zlib: %s\n",zlibVersion()); } $TMP = $STATUS $DEAS SYS$OUTPUT $IF (TMP .NE. %X10B90001) $ THEN $ HAVE_ZLIB=0 $ GOTO NEXT1 $ENDIF $DEFINE SYS$OUTPUT _NLA0: $!Testing for shared ZLIB $COPY SYS$INPUT [.SRC]OPT.OPT SYS$SHARE:LIBZSHR/SHARE $LINK/EXE=TEST TEST,[.SRC]OPT/OPT $TMP = $STATUS $DEL [.SRC]OPT.OPT;* $!WRITE SYS$OUTPUT TMP $IF (TMP .NE. %X10000001) $ THEN $ LINK/EXE=TEST TEST,ZLIB:LIBZ/LIB $ TMP = $STATUS $ IF (TMP .NE. %X10000001) $ THEN $ HAVE_ZLIB=0 $ ELSE $ HAVE_ZLIB=1 $ ZLIB_STATIC=1 $ ENDIF $ ELSE $ HAVE_ZLIB=1 $ENDIF $NEXT1: $DEAS SYS$OUTPUT $IF (HAVE_ZLIB.EQ.1) $ THEN $ WRITE SYS$OUTPUT "Checking for correct zlib library ... Yes" $ ELSE $ WRITE SYS$OUTPUT "Checking for correct zlib library ... No" $ WRITE SYS$OUTPUT "This is fatal. Please download and install good library from fafner.dyndns.org/~alexey/libsdl/public.html" $ GOTO EXIT $ENDIF $RUN TEST $! $! $FREETYPE_STATIC=0 $!"Checking for correct Freetype2 library" $ DEFINE SYS$OUTPUT _NLA0: $ CC/OBJECT=TEST.OBJ/INCLUDE=(FREETYPE2) SYS$INPUT #include #include int main(int argc, char *argv[]) { #if FREETYPE_MAJOR == 2 && FREETYPE_MINOR <= 1 printf("This version is too old. Please get newest\n"); printf("From fafner.dyndns.org/~alexey/libsdl/required.html\n"); exit(2); #endif printf("checking version FreeType : %d.%d.%d\n", FREETYPE_MAJOR, FREETYPE_MINOR, FREETYPE_PATCH); return(0); } $TMP = $STATUS $DEAS SYS$OUTPUT $IF (TMP .NE. %X10B90001) $ THEN $ HAVE_FREETYPE=0 $ GOTO NEXT0 $ENDIF $DEAS SYS$OUTPUT $DEFINE SYS$OUTPUT _NLA0: $LINK/EXE=TEST TEST,FREETYPE2:FREETYPE/OPT $TMP = $STATUS $IF (TMP .NE. %X10000001) $ THEN $ LINK/EXE=TEST TEST,FREETYPE2:FREETYPE/LIB,ZLIB:LIBZ/LIB $ TMP = $STATUS $ IF (TMP .NE. %X10000001) $ THEN $ TMP = $STATUS $ HAVE_FREETYPE=0 $ GOTO NEXT0 $ ELSE $ FREETYPE_STATIC=1 $ ENDIF $ENDIF $! $RUN TEST $IF ($STATUS .NE. %X00000001) $ THEN $ HAVE_FREETYPE=0 $ GOTO NEXT0 $ ELSE $ HAVE_FREETYPE=1 $ENDIF $NEXT0: $DEAS SYS$OUTPUT $IF (HAVE_FREETYPE.EQ.1) $ THEN $ WRITE SYS$OUTPUT "Checking for correct FreeType ... Yes" $ RUN TEST $ ELSE $ WRITE SYS$OUTPUT "Checking for correct FreeType ... No" $ WRITE SYS$OUTPUT "This is required library " $ WRITE SYS$OUTPUT "install it first from fafner.dyndns.org/~alexey/libsdl/required.html" $ GOTO EXIT $ENDIF $! $! $HAVE_TIFF=0 $!"Checking for libPNG " $ DEFINE SYS$OUTPUT _NLA0: $ CC/OBJECT=TEST.OBJ/INCLUDE=(PNG,ZLIB) SYS$INPUT #include #include int main() { png_uint_32 n,n1,n2,n3; n=png_access_version_number(); n3=n%100; n=n/100; n2=n%100; n=n/100; n1=n%100; if ( (n1<=1)&&(n2<2) ) { printf("checking version libPNG: %d.%d.%d\n",n1,n2,n3); printf("This version is too old. Please get newest\n"); printf("From fafner.dyndns.org/~alexey/libsdl/public.html\n"); exit(2); } printf("checking version libPNG: %d.%d.%d\n",n1,n2,n3); } $! $TMP = $STATUS $DEAS SYS$OUTPUT $IF (TMP .NE. %X10B90001) $ THEN $ HAVE_LIBPNG=0 $ GOTO NEXT2 $ENDIF $DEFINE SYS$OUTPUT _NLA0: $LINK/EXE=TEST TEST,PNG:LIBPNG$SHR/OPT,ZLIB:LIBZ/LIB $TMP = $STATUS $!WRITE SYS$OUTPUT TMP $IF (TMP .NE. %X10000001) $ THEN $! Trying for static libpng $ LINK/EXE=TEST TEST,PNG:LIBPNG/LIB,ZLIB:LIBZ/LIB $ TMP = $STATUS $ IF (TMP .NE. %X10000001) $ THEN $ LIBPNG_STATIC=0 $ HAVE_LIBPNG=0 $ GOTO NEXT2 $ ELSE $ HAVE_LIBPNG=1 $ LIBPNG_STATIC=1 $ ENDIF $ ELSE $ HAVE_LIBPNG=1 $ LIBPNG_STATIC=0 $ENDIF $! $RUN TEST $IF ($STATUS .NE. %X00000001) $ THEN $ HAVE_LIBPNG=0 $ ELSE $ HAVE_LIBPNG=1 $ENDIF $NEXT2: $DEAS SYS$OUTPUT $IF (HAVE_LIBPNG.EQ.1) $ THEN $ WRITE SYS$OUTPUT "Checking for correct libPNG ... Yes" $ RUN TEST $ ELSE $ WRITE SYS$OUTPUT "Checking for correct libPNG ... No" $ WRITE SYS$OUTPUT "This is fatal. Please download and install good library from fafner.dyndns.org/~alexey/libsdl/public.html" $ GOTO EXIT $ENDIF $! $! $! $! Checking for JPEG ... $ DEFINE SYS$OUTPUT _NLA0: $ CC/OBJECT=TEST.OBJ/INCLUDE=(JPEG) SYS$INPUT #include #include #include #include int main() { printf("checking version jpeg: %s\n",JVERSION); jpeg_quality_scaling(0); return 0; } $TMP = $STATUS $DEAS SYS$OUTPUT $!WRITE SYS$OUTPUT TMP $IF (TMP .NE. %X10B90001) $ THEN $ HAVE_JPEG=0 $ GOTO NEXT3 $ENDIF $DEFINE SYS$OUTPUT _NLA0: $LINK/EXE=TEST TEST,JPEG:LIBJPEG$SHR/OPT $TMP = $STATUS $!WRITE SYS$OUTPUT TMP $IF (TMP .NE. %X10000001) $ THEN $ LINK/EXE=TEST TEST,JPEG:LIBJPEG/OPT $ TMP = $STATUS $ IF (TMP .NE. %X10000001) $ THEN $ HAVE_JPEG=0 $ JPEG_STATIC=0 $ GOTO NEXT3 $ ELSE $ HAVE_JPEG=1 $ JPEG_STATIC=1 $ ENDIF $ ELSE $ HAVE_JPEG=1 $ JPEG_STATIC=0 $ENDIF $! $NEXT3: $DEAS SYS$OUTPUT $IF (HAVE_JPEG.EQ.1) $ THEN $ WRITE SYS$OUTPUT "Checking for correct jpeg library ... Yes" $ ELSE $ WRITE SYS$OUTPUT "Checking for correct jpeg library ... No" $ WRITE SYS$OUTPUT "This is fatal. Please download and install good library from fafner.dyndns.org/~alexey/libsdl/public.html" $ GOTO EXIT $ENDIF $RUN TEST $! $! $!Checking for libTIFF $ DEFINE SYS$OUTPUT _NLA0: $ DEL TEST.*;* $ CC/OBJECT=TEST.OBJ/INCLUDE=(TIFF) SYS$INPUT #include #include #include int main() { printf("checking libTIFF version:\t%s\n\n", TIFFGetVersion()); return 0; } $! $TMP = $STATUS $DEAS SYS$OUTPUT $IF (TMP .NE. %X10B90001) $ THEN $ HAVE_TIFF=0 $ GOTO NEXT4 $ENDIF $DEFINE SYS$OUTPUT _NLA0: $LINK TEST, TIFF:LIBTIFF/OPT, ZLIB:LIBZ/LIB $TMP = $STATUS $!WRITE SYS$OUTPUT TMP $IF (TMP .NE. %X10000001) $ THEN $ HAVE_TIFF=0 $ ELSE $ HAVE_TIFF=1 $ENDIF $NEXT4: $DEAS SYS$OUTPUT $IF (HAVE_TIFF.EQ.1) $ THEN $ WRITE SYS$OUTPUT "Checking for TIFF library ... Yes" $ TIFF_LIBRARY_PATH="TIFF:LIBTIFF/OPT" $ RUN TEST $ ELSE $ WRITE SYS$OUTPUT "Checking for TIFF library ... No" $ WRITE SYS$OUTPUT "No TIFF library installed. This is fatal. Please download and install good library from fafner.dyndns.org/~alexey/libsdl/public.html" $ GOTO EXIT $ENDIF $! $! $!WRITING BUILD FILES $! $IF (SHARED.EQ.64) $ THEN $ COPY SYS$INPUT [.SRC]LIBGD$DEF.OPT SYMBOL_VECTOR= (- gdAlphaBlend=PROCEDURE,- gdImageCreate=PROCEDURE,- gdImageCreateTrueColor=PROCEDURE,- gdImageCreateFromPng=PROCEDURE,- gdImageCreateFromPngCtx=PROCEDURE,- gdImageCreateFromPngPtr=PROCEDURE,- gdImageCreateFromGif=PROCEDURE,- gdImageCreateFromGifCtx=PROCEDURE,- gdImageCreateFromGifPtr=PROCEDURE,- gdImageCreateFromWBMP=PROCEDURE,- gdImageCreateFromWBMPCtx=PROCEDURE,- gdImageCreateFromWBMPPtr=PROCEDURE,- gdImageCreateFromJpeg=PROCEDURE,- gdImageCreateFromJpegCtx=PROCEDURE,- gdImageCreateFromJpegPtr=PROCEDURE,- gdImageCreateFromPngSource=PROCEDURE,- gdImageCreateFromGd=PROCEDURE,- gdImageCreateFromGdCtx=PROCEDURE,- gdImageCreateFromGdPtr=PROCEDURE,- gdImageCreateFromGd2=PROCEDURE,- gdImageCreateFromGd2Ctx=PROCEDURE,- gdImageCreateFromGd2Ptr=PROCEDURE,- gdImageCreateFromGd2Part=PROCEDURE,- gdImageCreateFromGd2PartCtx=PROCEDURE,- gdImageCreateFromGd2PartPtr=PROCEDURE,- gdImageCreateFromXbm=PROCEDURE,- gdImageCreateFromXpm=PROCEDURE,- gdImageStringFTCircle=PROCEDURE,- gdImageDestroy=PROCEDURE,- gdImageSetPixel=PROCEDURE,- gdImageGetPixel=PROCEDURE,- gdImageGetTrueColorPixel=PROCEDURE,- gdImageAABlend=PROCEDURE,- gdImageLine=PROCEDURE,- gdImageDashedLine=PROCEDURE,- gdImageRectangle=PROCEDURE,- gdImageFilledRectangle=PROCEDURE,- gdImageSetClip=PROCEDURE,- gdImageGetClip=PROCEDURE,- gdImageBoundsSafe=PROCEDURE,- gdImageChar=PROCEDURE,- gdImageCharUp=PROCEDURE,- gdImageString=PROCEDURE,- gdImageStringUp=PROCEDURE,- gdImageString16=PROCEDURE,- gdImageStringUp16=PROCEDURE,- gdFontCacheSetup=PROCEDURE,- gdFontCacheShutdown=PROCEDURE,- gdFreeFontCache=PROCEDURE,- gdImageStringTTF=PROCEDURE,- gdImageStringFT=PROCEDURE,- gdFTUseFontConfig=PROCEDURE,- gdImageStringFTEx=PROCEDURE,- gdImagePolygon=PROCEDURE,- gdImageOpenPolygon=PROCEDURE,- gdImageFilledPolygon=PROCEDURE,- gdImageColorAllocate=PROCEDURE,- gdImageColorAllocateAlpha=PROCEDURE,- gdImageColorClosest=PROCEDURE,- gdImageColorClosestAlpha=PROCEDURE,- gdImageColorClosestHWB=PROCEDURE,- gdImageColorExact=PROCEDURE,- gdImageColorExactAlpha=PROCEDURE,- gdImageColorResolve=PROCEDURE,- gdImageColorResolveAlpha=PROCEDURE,- gdImageColorDeallocate=PROCEDURE,- gdImageCreatePaletteFromTrueCol=PROCEDURE,- gdImageTrueColorToPalette=PROCEDURE,- gdImageColorTransparent=PROCEDURE,- gdImagePaletteCopy=PROCEDURE,- gdImageGif=PROCEDURE,- gdImagePng=PROCEDURE,- gdImagePngCtx=PROCEDURE,- gdImageGifCtx=PROCEDURE,- gdImagePngEx=PROCEDURE,- gdImagePngCtxEx=PROCEDURE,- gdImageWBMP=PROCEDURE,- gdImageWBMPCtx=PROCEDURE,- gdFree=PROCEDURE,- gdImageWBMPPtr=PROCEDURE,- gdImageJpeg=PROCEDURE,- gdImageJpegCtx=PROCEDURE,- gdImageJpegPtr=PROCEDURE,- gdImageGifAnimBegin=PROCEDURE,- gdImageGifAnimAdd=PROCEDURE,- gdImageGifAnimEnd=PROCEDURE,- gdImageGifAnimBeginCtx=PROCEDURE,- gdImageGifAnimAddCtx=PROCEDURE,- gdImageGifAnimEndCtx=PROCEDURE,- gdImageGifAnimBeginPtr=PROCEDURE,- gdImageGifAnimAddPtr=PROCEDURE,- gdImageGifAnimEndPtr=PROCEDURE,- gdImagePngToSink=PROCEDURE,- gdImageGd=PROCEDURE,- gdImageGd2=PROCEDURE,- gdImageGifPtr=PROCEDURE,- gdImagePngPtr=PROCEDURE,- gdImagePngPtrEx=PROCEDURE,- gdImageGdPtr=PROCEDURE,- gdImageGd2Ptr=PROCEDURE,- gdImageFilledArc=PROCEDURE,- gdImageArc=PROCEDURE,- gdImageFilledEllipse=PROCEDURE,- gdImageFillToBorder=PROCEDURE,- gdImageFill=PROCEDURE,- gdImageCopy=PROCEDURE,- gdImageCopyMerge=PROCEDURE,- gdImageCopyMergeGray=PROCEDURE,- gdImageCopyResized=PROCEDURE,- gdImageCopyResampled=PROCEDURE,- gdImageCopyRotated=PROCEDURE,- gdImageSetBrush=PROCEDURE,- gdImageSetTile=PROCEDURE,- gdImageSetAntiAliased=PROCEDURE,- gdImageSetAntiAliasedDontBlend=PROCEDURE,- gdImageSetStyle=PROCEDURE,- gdImageSetThickness=PROCEDURE,- gdImageInterlace=PROCEDURE,- gdImageAlphaBlending=PROCEDURE,- gdImageSaveAlpha=PROCEDURE,- gdNewFileCtx=PROCEDURE,- gdNewDynamicCtx=PROCEDURE,- gdNewDynamicCtxEx=PROCEDURE,- gdNewSSCtx=PROCEDURE,- gdDPExtractData=PROCEDURE,- gdFontGetGiant=PROCEDURE,- gdFontGetLarge=PROCEDURE,- gdFontGetMediumBold=PROCEDURE,- gdFontGetSmall=PROCEDURE,- gdFontGetTiny=PROCEDURE,- gdImageCompare=PROCEDURE,- gdImageCreateFromTiff=PROCEDURE,- gdImageCreateFromTiffCtx=PROCEDURE,- gdImageCreateFromTiffPtr=PROCEDURE,- gdImageCreateFromTga=PROCEDURE,- gdImageCreateFromTgaCtx=PROCEDURE,- gdImageCreateFromTgaPtr=PROCEDURE,- gdImageTiff=PROCEDURE,- gdImageTiffPtr=PROCEDURE,- gdImageTiffCtx=PROCEDURE,- gdImageCrop=PROCEDURE,- gdImageAutoCrop=PROCEDURE,- gdImageThresholdCrop=PROCEDURE,- gdFontGiant=DATA,- GDFONTLARGE=DATA,- GDFONTMEDIUMBOLD=DATA,- GDFONTSMALL=DATA,- GDFONTTINY=DATA- ) $ENDIF $! $IF (SHARED.EQ.32) $ THEN $ COPY SYS$INPUT [.SRC]LIBGD$DEF.OPT UNIVERSAL=gdAlphaBlend UNIVERSAL=gdImageCreate UNIVERSAL=gdImageCreateTrueColor UNIVERSAL=gdImageCreateFromPng UNIVERSAL=gdImageCreateFromPngCtx UNIVERSAL=gdImageCreateFromPngPtr UNIVERSAL=gdImageCreateFromGif UNIVERSAL=gdImageCreateFromGifCtx UNIVERSAL=gdImageCreateFromGifPtr UNIVERSAL=gdImageCreateFromWBMP UNIVERSAL=gdImageCreateFromWBMPCtx UNIVERSAL=gdImageCreateFromWBMPPtr UNIVERSAL=gdImageCreateFromJpeg UNIVERSAL=gdImageStringFTCircle UNIVERSAL=gdImageCreateFromJpegCtx UNIVERSAL=gdImageCreateFromJpegPtr UNIVERSAL=gdImageCreateFromPngSource UNIVERSAL=gdImageCreateFromGd UNIVERSAL=gdImageCreateFromGdCtx UNIVERSAL=gdImageCreateFromGdPtr UNIVERSAL=gdImageCreateFromGd2 UNIVERSAL=gdImageCreateFromGd2Ctx UNIVERSAL=gdImageCreateFromGd2Ptr UNIVERSAL=gdImageCreateFromGd2Part UNIVERSAL=gdImageCreateFromGd2PartCtx UNIVERSAL=gdImageCreateFromGd2PartPtr UNIVERSAL=gdImageCreateFromXbm UNIVERSAL=gdImageCreateFromXpm UNIVERSAL=gdImageDestroy UNIVERSAL=gdImageSetPixel UNIVERSAL=gdImageGetPixel UNIVERSAL=gdImageGetTrueColorPixel UNIVERSAL=gdImageAABlend UNIVERSAL=gdImageLine UNIVERSAL=gdImageDashedLine UNIVERSAL=gdImageRectangle UNIVERSAL=gdImageFilledRectangle UNIVERSAL=gdImageSetClip UNIVERSAL=gdImageGetClip UNIVERSAL=gdImageBoundsSafe UNIVERSAL=gdImageChar UNIVERSAL=gdImageCharUp UNIVERSAL=gdImageString UNIVERSAL=gdImageStringUp UNIVERSAL=gdImageString16 UNIVERSAL=gdImageStringUp16 UNIVERSAL=gdFontCacheSetup UNIVERSAL=gdFontCacheShutdown UNIVERSAL=gdFreeFontCache UNIVERSAL=gdImageStringTTF UNIVERSAL=gdImageStringFT UNIVERSAL=gdFTUseFontConfig UNIVERSAL=gdImageStringFTEx UNIVERSAL=gdImagePolygon UNIVERSAL=gdImageOpenPolygon UNIVERSAL=gdImageFilledPolygon UNIVERSAL=gdImageColorAllocate UNIVERSAL=gdImageColorAllocateAlpha UNIVERSAL=gdImageColorClosest UNIVERSAL=gdImageColorClosestAlpha UNIVERSAL=gdImageColorClosestHWB UNIVERSAL=gdImageColorExact UNIVERSAL=gdImageColorExactAlpha UNIVERSAL=gdImageColorResolve UNIVERSAL=gdImageColorResolveAlpha UNIVERSAL=gdImageColorDeallocate UNIVERSAL=gdImageCreatePaletteFromTrueCol UNIVERSAL=gdImageTrueColorToPalette UNIVERSAL=gdImageColorTransparent UNIVERSAL=gdImagePaletteCopy UNIVERSAL=gdImageGif UNIVERSAL=gdImagePng UNIVERSAL=gdImagePngCtx UNIVERSAL=gdImageGifCtx UNIVERSAL=gdImagePngEx UNIVERSAL=gdImagePngCtxEx UNIVERSAL=gdImageWBMP UNIVERSAL=gdImageWBMPCtx UNIVERSAL=gdFree UNIVERSAL=gdImageWBMPPtr UNIVERSAL=gdImageJpeg UNIVERSAL=gdImageJpegCtx UNIVERSAL=gdImageJpegPtr UNIVERSAL=gdImageGifAnimBegin UNIVERSAL=gdImageGifAnimAdd UNIVERSAL=gdImageGifAnimEnd UNIVERSAL=gdImageGifAnimBeginCtx UNIVERSAL=gdImageGifAnimAddCtx UNIVERSAL=gdImageGifAnimEndCtx UNIVERSAL=gdImageGifAnimBeginPtr UNIVERSAL=gdImageGifAnimAddPtr UNIVERSAL=gdImageGifAnimEndPtr UNIVERSAL=gdImagePngToSink UNIVERSAL=gdImageGd UNIVERSAL=gdImageGd2 UNIVERSAL=gdImageGifPtr UNIVERSAL=gdImagePngPtr UNIVERSAL=gdImagePngPtrEx UNIVERSAL=gdImageGdPtr UNIVERSAL=gdImageGd2Ptr UNIVERSAL=gdImageFilledArc UNIVERSAL=gdImageArc UNIVERSAL=gdImageFilledEllipse UNIVERSAL=gdImageFillToBorder UNIVERSAL=gdImageFill UNIVERSAL=gdImageCopy UNIVERSAL=gdImageCopyMerge UNIVERSAL=gdImageCopyMergeGray UNIVERSAL=gdImageCopyResized UNIVERSAL=gdImageCopyResampled UNIVERSAL=gdImageCopyRotated UNIVERSAL=gdImageSetBrush UNIVERSAL=gdImageSetTile UNIVERSAL=gdImageSetAntiAliased UNIVERSAL=gdImageSetAntiAliasedDontBlend UNIVERSAL=gdImageSetStyle UNIVERSAL=gdImageSetThickness UNIVERSAL=gdImageInterlace UNIVERSAL=gdImageAlphaBlending UNIVERSAL=gdImageSaveAlpha UNIVERSAL=gdNewFileCtx UNIVERSAL=gdNewDynamicCtx UNIVERSAL=gdNewDynamicCtxEx UNIVERSAL=gdNewSSCtx UNIVERSAL=gdDPExtractData UNIVERSAL=gdFontGetGiant UNIVERSAL=gdFontGetLarge UNIVERSAL=gdFontGetMediumBold UNIVERSAL=gdFontGetSmall UNIVERSAL=gdFontGetTiny UNIVERSAL=gdImageCompare UNIVERSAL=gdFontGiant UNIVERSAL=gdImageCreateFromTiff UNIVERSAL=gdImageCreateFromTiffCtx UNIVERSAL=gdImageCreateFromTiffPtr UNIVERSAL=gdImageCreateFromTga UNIVERSAL=gdImageCreateFromTgaCtx UNIVERSAL=gdImageCreateFromTgaPtr UNIVERSAL=gdImageTiff UNIVERSAL=gdImageTiffPtr UNIVERSAL=gdImageTiffCtx UNIVERSAL=gdImageCrop UNIVERSAL=gdImageAutoCrop UNIVERSAL=gdImageThresholdCrop UNIVERSAL=GDFONTLARGE UNIVERSAL=GDFONTMEDIUMBOLD UNIVERSAL=GDFONTSMALL UNIVERSAL=GDFONTTINY $ENDIF $! $! $DEF SYS$OUTPUT _NL0: $! $!Making OPT file for GD$SHR.EXE, i.e without reference to himself $COPY SYS$INPUT [.SRC]OPT.OPT []GD/LIB $IF ((HAVE_LIBPNG.EQ.1) .AND. (LIBPNG_STATIC.EQ.1)) $ THEN $ APP SYS$INPUT [.SRC]OPT.OPT PNG:LIBPNG/LIB $ENDIF $IF ((HAVE_LIBPNG.EQ.1) .AND. (LIBPNG_STATIC.EQ.0)) $ THEN $ APP PNG:LIBPNG$SHR.OPT [.SRC]OPT.OPT $ENDIF $! $IF ((HAVE_JPEG.EQ.1) .AND. (JPEG_STATIC.EQ.1) .AND. (HAVE_TIFF.NE.1)) $ THEN $ APP SYS$INPUT [.SRC]OPT.OPT JPEG:LIBJPEG/LIB $ENDIF $IF ((HAVE_JPEG.EQ.1) .AND. (JPEG_STATIC.EQ.0) .AND. (HAVE_TIFF.NE.1)) $ THEN $ APP JPEG:LIBJPEG$SHR.OPT [.SRC]OPT.OPT $ENDIF $! $IF (HAVE_TIFF.EQ.1) $ THEN $ APP TIFF:LIBTIFF.OPT [.SRC]OPT.OPT $ENDIF $! $IF (HAVE_FREETYPE.EQ.1) .AND. (FREETYPE_STATIC.EQ.1) $ THEN $ APP SYS$INPUT [.SRC]OPT.OPT FREETYPE2:FREETYPE/LIB ZLIB:LIBZ/LIB $ENDIF $IF (HAVE_FREETYPE.EQ.1) .AND. (FREETYPE_STATIC.EQ.0) $ THEN $ APP FREETYPE2:FREETYPE.OPT [.SRC]OPT.OPT $ENDIF $! $IF (HAVE_ZLIB.EQ.1) .AND. ((FREETYPE_STATIC.NE.1).AND.(JPEG_STATIC.NE.1)) $ THEN $ IF (ZLIB_STATIC.EQ.0) $ THEN $ APP SYS$INPUT [.SRC]OPT.OPT SYS$SHARE:LIBZSHR/SHARE $ ELSE $ APP SYS$INPUT [.SRC]OPT.OPT ZLIB:LIBZ/LIB $ ENDIF $ ELSE $ APP SYS$INPUT [.SRC]OPT.OPT ZLIB:LIBZ/LIB $ENDIF $! $! $PURGE [.SRC]OPT.OPT $! $! $!Making working LIBGD.OPT file $! $IF (SHARED.GT.0) $ THEN $COPY SYS$INPUT [.SRC]LIBGD.OPT SYS$SHARE:GD$SHR/SHARE $ ELSE $COPY SYS$INPUT [.SRC]LIBGD.OPT LIBGD:GD/LIB $ENDIF $! $!Append OPT files to LIBGD.OPT $IF ((HAVE_LIBPNG.EQ.1) .AND. (LIBPNG_STATIC.EQ.1)) $ THEN $ APP SYS$INPUT [.SRC]LIBGD.OPT PNG:LIBPNG/LIB $ENDIF $IF ((HAVE_LIBPNG.EQ.1) .AND. (LIBPNG_STATIC.EQ.0)) $ THEN $ APP PNG:LIBPNG$SHR.OPT [.SRC]LIBGD.OPT $ENDIF $! $IF ((HAVE_JPEG.EQ.1) .AND. (HAVE_TIFF.NE.1) .AND. (JPEG_STATIC.EQ.1)) $ THEN $ APP JPEG:LIBJPEG.OPT [.SRC]LIBGD.OPT $ENDIF $IF ((HAVE_JPEG.EQ.1) .AND. (JPEG_STATIC.EQ.0) .AND. (HAVE_TIFF.NE.1)) $ THEN $ APP JPEG:LIBJPEG$SHR.OPT [.SRC]LIBGD.OPT $ENDIF $! $IF (HAVE_TIFF.EQ.1) $ THEN $ APP TIFF:LIBTIFF.OPT [.SRC]LIBGD.OPT $ENDIF $! $IF (HAVE_FREETYPE.EQ.1) .AND. (FREETYPE_STATIC.EQ.1) $ THEN $ APP SYS$INPUT [.SRC]LIBGD.OPT FREETYPE2:FREETYPE/LIB ZLIB:LIBZ/LIB $ENDIF $IF (HAVE_FREETYPE.EQ.1) .AND. (FREETYPE_STATIC.EQ.0) $ THEN $ APP FREETYPE2:FREETYPE.OPT [.SRC]LIBGD.OPT $ENDIF $! $IF (HAVE_ZLIB.EQ.1) .AND. ((FREETYPE_STATIC.NE.1).AND.(JPEG_STATIC.NE.1)) $ THEN $ IF (ZLIB_STATIC.EQ.0) $ THEN $ APP SYS$INPUT [.SRC]LIBGD.OPT SYS$SHARE:LIBZSHR/SHARE $ ELSE $ APP SYS$INPUT [.SRC]LIBGD.OPT ZLIB:LIBZ/LIB $ ENDIF $ENDIF $! $PURGE LIBGD.OPT $! $DEAS SYS$OUTPUT $! $OPEN/WRITE OUT BUILD.COM $ WRITE OUT "$SET DEF [.SRC]" $ WRITE OUT "$",MAKE $ WRITE OUT "$ CURRENT = F$ENVIRONMENT (""DEFAULT"") " $ WRITE OUT "$TMP=CURRENT" $ WRITE OUT "$OPEN/WRITE OUTT [-]LIBGD$STARTUP.COM" $ WRITE OUT "$WRITE OUTT ""DEFINE LIBGD """"", "'","'","TMP'""""""" $ WRITE OUT "$WRITE OUTT ""GD2COPYPAL==""""$","'","'","TMP'"",""GD2COPYPAL"""" " $ WRITE OUT "$WRITE OUTT ""GD2TIME==""""$","'","'","TMP'"",""GD2TIME"""" " $ WRITE OUT "$WRITE OUTT ""GD2TOGIF==""""$","'","'","TMP'"",""GD2TOGIF"""" " $ WRITE OUT "$WRITE OUTT ""GD2TOPNG==""""$","'","'","TMP'"",""GD2TOPNG"""" " $ WRITE OUT "$WRITE OUTT ""GDCMPGIF==""""$","'","'","TMP'"",""GDCMPGIF"""" " $ WRITE OUT "$WRITE OUTT ""GDTOPNG==""""$","'","'","TMP'"",""GDTOPNG"""" " $ WRITE OUT "$WRITE OUTT ""GIFTOGD2==""""$","'","'","TMP'"",""GIFTOGD2"""" " $ WRITE OUT "$WRITE OUTT ""PNGTOGD==""""$","'","'","TMP'"",""PNGTOGD"""" " $ WRITE OUT "$WRITE OUTT ""PNGTOGD2==""""$","'","'","TMP'"",""PNGTOGD2"""" " $ WRITE OUT "$WRITE OUTT ""WEBPNG==""""$","'","'","TMP'"",""WEBPNG"""" " $ WRITE OUT "$CLOSE OUTT" $! $ WRITE OUT "$WRITE SYS$OUTPUT "" "" " $ WRITE OUT "$WRITE SYS$OUTPUT ""***************************************************************************** "" " $ WRITE OUT "$WRITE SYS$OUTPUT ""LIBGD$STARTUP.COM has been created. "" " $ WRITE OUT "$WRITE SYS$OUTPUT ""This file setups all logicals needed. It should be execute before using "" " $ WRITE OUT "$WRITE SYS$OUTPUT ""Nice place to call it - LOGIN.COM "" " $ WRITE OUT "$WRITE SYS$OUTPUT """" " $ WRITE OUT "$WRITE SYS$OUTPUT ""Using:"" " $ WRITE OUT "$WRITE SYS$OUTPUT ""CC/INCL=LIBGD PROG"" " $ WRITE OUT "$WRITE SYS$OUTPUT ""LINK PROG, LIBGD:LIBGD/OPT"" " $ WRITE OUT "$WRITE SYS$OUTPUT ""***************************************************************************** "" " $ WRITE OUT "$WRITE SYS$OUTPUT ""***************************************************************************** "" " $ WRITE OUT "$SET DEF [-]" $CLOSE OUT $! $! $!Writing config.h $COPY SYS$INPUT [.SRC]CONFIG.H /* Generated by configure.com for OpenVMS */ /* Define to 1 if you have the header file. */ #define HAVE_DLFCN_H 1 /* Define to 1 if you have the header file. */ #define HAVE_ERRNO_H 1 /* Define to 1 if you have the header file. */ #define HAVE_INTTYPES_H 1 #define PACKAGE_NAME "GD" /* Define to the full name and version of this package. */ #define PACKAGE_STRING "GD 2.1.0" /* Define to the one symbol short name of this package. */ #define PACKAGE_TARNAME "GD" /* Define to the version of this package. */ #define PACKAGE_VERSION "2.1.0" /* Define to necessary symbol if this constant uses a non-standard name on * your system. */ /* #undef PTHREAD_CREATE_JOINABLE */ /* Define to 1 if you have the ANSI C header files. */ #define STDC_HEADERS 1 /* Version number of package */ #define VERSION "2.1.0" /* Define to 1 if you have the `m' library (-lm). */ #define HAVE_LIBM 1 /* Define to 1 if you have the header file. */ /* #undef HAVE_LIBPNG_PNG_H */ /* Define to 1 if you have the header file. */ //#define HAVE_LIMITS_H 1 /* Define to 1 if you have the header file. */ #define HAVE_MEMORY_H 1 /* Define if you have POSIX threads libraries and header files. */ #define HAVE_PTHREAD 1 /* Define to 1 if you have the header file. */ #define HAVE_STDDEF_H 1 /* Define to 1 if you have the header file. */ //#define HAVE_STDINT_H 1 /* Define to 1 if you have the header file. */ #define HAVE_STDLIB_H 1 /* Define to 1 if you have the header file. */ #define HAVE_STRINGS_H 1 /* Define to 1 if you have the header file. */ #define HAVE_STRING_H 1 /* Define to 1 if you have the header file. */ #define HAVE_SYS_STAT_H 1 /* Define to 1 if you have the header file. */ #define HAVE_SYS_TYPES_H 1 /* Define to 1 if you have the header file. */ #define HAVE_UNISTD_H 1 /* Define as const if the declaration of iconv() needs const. */ //#define ICONV_CONST /* Name of package */ #define PACKAGE "gd" /* Define to the address where bug reports for this package should be sent. */ #define PACKAGE_BUGREPORT "http://bugs.libgd.org" /* Define to the full name of this package. */ $IF HAVE_ICONV.EQ.1 $ THEN $ APP SYS$INPUT [.SRC]CONFIG.H /* Define if you have the iconv() function. */ #define HAVE_ICONV 1 /* Define to 1 if you have the header file. */ #define HAVE_ICONV_H 1 /* Define if defines iconv_t. */ #define HAVE_ICONV_T_DEF 1 $ENDIF $IF HAVE_TIFF.EQ.1 $ THEN $ APP SYS$INPUT [.SRC]CONFIG.H #define HAVE_LIBTIFF 1 $ENDIF $IF HAVE_LIBPNG.EQ.1 $ THEN $ APP SYS$INPUT [.SRC]CONFIG.H #define HAVE_LIBPNG 1 #define HAVE_PNG_H 1 $ENDIF $IF HAVE_FREETYPE.EQ.1 $ THEN $ APP SYS$INPUT [.SRC]CONFIG.H #define HAVE_LIBFREETYPE 1 #define HAVE_FT2BUILD_H 1 $ENDIF $IF HAVE_JPEG.EQ.1 $ THEN $ APP SYS$INPUT [.SRC]CONFIG.H #define HAVE_LIBJPEG 1 $ENDIF $IF HAVE_ZLIB.EQ.1 $ THEN $ APP SYS$INPUT [.SRC]CONFIG.H #define HAVE_LIBZ 1 $ENDIF $IF HAVE_TIFF.EQ.1 $ THEN $ APP SYS$INPUT [.SRC]CONFIG.H #define HAVE_LIBTIFF 1 $ENDIF $! $! $! $! $COP SYS$INPUT [.SRC]DESCRIP.MMS # Generated by CONFIGURE.COM # Alexey Chupahin elvis_75@mail.ru # OpenVMS 7.3-1,8.2 DEC 2000 mod.300 # OpenVMS 8.3 HP rx1620 .FIRST DEF LIBGD [] CC=cc CFLAGS=/OPT=(INLINE=SPEED) /INCL=([],JPEG,PNG,FREETYPE2,ZLIB,TIFF) /DEF=(HAVE_CONFIG_H)/WARN=(DIS=MACROREDEF) LIBS=[]LIBGD/OPT ALL : \ gd.olb,\ $IF (SHARED.GT.0) $ THEN $ APP SYS$INPUT [.SRC]DESCRIP.MMS gd$shr.exe,\ $ENDIF $! $APP SYS$INPUT [.SRC]DESCRIP.MMS annotate.exe,\ circletexttest.exe,\ fontconfigtest.exe,\ circletexttest.exe,\ fontconfigtest.exe,\ fontsizetest.exe,\ fontwheeltest.exe,\ gd2copypal.exe,\ gd2time.exe,\ gd2togif.exe,\ gd2topng.exe,\ gdcmpgif.exe,\ gddemo.exe,\ gdtest.exe,\ gdtestft.exe,\ gdtopng.exe,\ gifanimtest.exe,\ giftogd2.exe,\ pngtogd.exe,\ pngtogd2.exe,\ testac.exe,\ testtr.exe,\ webpng.exe,\ gdparttopng.exe $! annotate.exe : annotate.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* circletexttest.exe : circletexttest.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* fontconfigtest.exe : fontconfigtest.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* fontsizetest.exe : fontsizetest.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* fontwheeltest.exe : fontwheeltest.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gd2copypal.exe : gd2copypal.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gd2time.exe : gd2time.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gd2togif.exe : gd2togif.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gd2topng.exe : gd2topng.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gdcmpgif.exe : gdcmpgif.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gddemo.exe : gddemo.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gdtest.exe : gdtest.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gdtestft.exe : gdtestft.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gdtopng.exe : gdtopng.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gifanimtest.exe : gifanimtest.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* giftogd2.exe : giftogd2.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* giftogd2.obj : giftogd2.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* pngtogd.exe : pngtogd.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* pngtogd2.exe : pngtogd2.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* testac.exe : testac.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* testtr.exe : testtr.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* webpng.exe : webpng.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* gdparttopng.exe : gdparttopng.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=TMP.OBJ LINK/EXE=$(MMS$TARGET) TMP.OBJ, $(LIBS) DEL TMP.OBJ;* OBJ=\ gd.obj,\ gdcache.obj,\ gdfontg.obj,\ gdfontl.obj,\ gdfontmb.obj,\ gdfonts.obj,\ gdfontt.obj,\ gdft.obj,\ gdfx.obj,\ gdhelpers.obj,\ gdkanji.obj,\ gdtables.obj,\ gdxpm.obj,\ gd_bmp.obj,\ gd_gd.obj,\ gd_gd2.obj,\ gd_gif_in.obj,\ gd_gif_out.obj,\ gd_io.obj,\ gd_io_dp.obj,\ gd_io_file.obj,\ gd_io_ss.obj,\ gd_jpeg.obj,\ gd_png.obj,\ gd_security.obj,\ gd_ss.obj,\ gd_crop.obj,\ gd_tga.obj,\ gd_tiff.obj,\ gd_transform.obj,\ gd_topal.obj,\ gd_wbmp.obj,\ wbmp.obj gd_transform.obj : gd_transform.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_tiff.obj : gd_tiff.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_tga.obj : gd_tga.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_bmp.obj : gd_bmp.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_crop.obj : gd_crop.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd.obj : gd.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdcache.obj : gdcache.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdfontg.obj : gdfontg.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdfontl.obj : gdfontl.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdfontmb.obj : gdfontmb.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdfonts.obj : gdfonts.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdfontt.obj : gdfontt.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdft.obj : gdft.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdfx.obj : gdfx.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdhelpers.obj : gdhelpers.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdkanji.obj : gdkanji.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdtables.obj : gdtables.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gdxpm.obj : gdxpm.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_gd.obj : gd_gd.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_gd2.obj : gd_gd2.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_gif_in.obj : gd_gif_in.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_gif_out.obj : gd_gif_out.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_io.obj : gd_io.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_io_dp.obj : gd_io_dp.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_io_file.obj : gd_io_file.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_io_ss.obj : gd_io_ss.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_jpeg.obj : gd_jpeg.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_png.obj : gd_png.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_security.obj : gd_security.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_ss.obj : gd_ss.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_topal.obj : gd_topal.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) gd_wbmp.obj : gd_wbmp.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) wbmp.obj : wbmp.c $(CC) $(CFLAGS) $(MMS$SOURCE) /OBJ=$(MMS$TARGET) GD.OLB : $(OBJ) LIB/CREA GD.OLB $(OBJ) GD$SHR.EXE : $(OBJ) LINK/SHARE=GD$SHR GD.OBJ,LIBGD$DEF/OPT,OPT/OPT COPY GD$SHR.EXE SYS$SHARE CLEAN : DEL [...]*.OBJ;* DEL [...]*.OLB;* DEL [...]*.EXE;* $!DEL TMP.MMS;* $! $IF (F$SEARCH("[.SRC]GD.H;2").EQS."") $ THEN $ WRITE SYS$OUTPUT "Patching GD.H" $ DEF SYS$OUTPUT "_NLA0:" $ COPY SYS$INPUT [.SRC]GD.H;2 #define gdImageCreatePaletteFromTrueColor gdImageCreatePaletteFromTrueCol $ APP [.SRC]GD.H;1 [.SRC]GD.H;2 $ DEAS SYS$INPUT $ENDIF $! $! $! $! $WRITE SYS$OUTPUT " " $WRITE SYS$OUTPUT " " $WRITE SYS$OUTPUT "Now you can type @BUILD " $! $EXIT: $DEFINE SYS$OUTPUT _NLA0: $DEL TEST.OBJ;* $DEL TEST.C;* $DEL TEST.EXE;* $DEAS SYS$OUTPUT libgd-gd-2.1.1/VMS/README.VMS000066400000000000000000000034261245535672000151730ustar00rootroot00000000000000Dear OpenVMS user, Installation process is identical to one in *nix* world and consist to four simple steps: 1. Installing required libraries 2. Configuration 3. Compiling 4. Installation. 1. Please install required libraries first: 1. ZLIB 1.2 or newer 2. PNG 1.2.12 or newer 3. FreeType 2 4. JPEG 6B All may be found at OpenVMS libSDL porting project site http://fafner.dyndns.org/~alexey/libsdl/required.html Also, system should have MMS make utility from DEC or free analogue MMK. And C compiler with runtime, of course. ;) 2. Configuration is doing automatically by a configuration script: $@[.VMS]CONFIGURE The script detects hardware,system and required libraries have been installed. Compilation stage will be prepeared to create shared and static libraries. Alpha,IA64 or VAX platform are supported. Optional argument "static" tells to configurator to make static libraries only: $@[.VMS]CONFIGURE STATIC CONFIGURE script checks your ZLIB, FREETYPE, JPEG, PNG libraries. If it detects any troubles, you may get and install good and tested ones from OpenVMS libSDL porting project site: http://fafner.dyndns.org/~alexey/libsdl/required.html When success, it creates a building script named BUILD.COM 3. Compilation: $@BUILD It should be error-free. When success, it creates a setup script named LIBGD$STARTUP.COM 4. Setup OpenVMS environment before using libGD: $@LIBGD$STARTUP LIBGD and its utilites are ready to using. Optionally you may insert this startup file into your LOGIN.COM to set libGD environment every time you login automatically. To learn libGD please refer libGD official documentation. Compiling with library should be: $CC/INCL=LIBGD PROG $LINK PROG, LIBGD:LIBGD/OPT yours, Alexey Chupahin Rostov-on-Don, Russia elvis_75@mail.ru alex@rostov.rs-ultra.ru libgd-gd-2.1.1/appveyor.yml000066400000000000000000000173061245535672000155740ustar00rootroot00000000000000version: 2.1.1.{build} shallow_clone: true environment: # settings min_build: 0 # if 1 overwrites tbs_gd_* flags to leave png and jpeg tbs_gd_png: 1 tbs_gd_jpeg: 1 tbs_gd_freetype: 1 tbs_gd_iconv: 0 # todo: add iconv thumbs tbs_gd_tiff: 1 build_bindings: 1 # build .net bidnings pack_dlls: 1 # pack dll with upx matrix: - tbs_arch: "x86" tbs_tools: "msvc12" tbs_static_runtime: 0 - tbs_arch: "x64" tbs_tools: "msvc12" tbs_static_runtime: 0 - tbs_arch: "x86" tbs_tools: "mingw" tbs_static_runtime: 1 - tbs_arch: "x64" tbs_tools: "mingw" tbs_static_runtime: 1 install: - if [%min_build%]==[1] ( SET tbs_gd_png=1&& SET tbs_gd_jpeg=1&& SET tbs_gd_freetype=0&& SET tbs_gd_iconv=0&& SET tbs_gd_tiff=0) - ps: if($env:build_platform -eq 'x64') { $env:vcvar_arg = 'x86_amd64'; } else { $env:vcvar_arg = 'x86'; } - ps: 'function prepend($file, $line) { Set-Content (Resolve-Path $file) -value $line,(Get-Content (Resolve-Path $file)) }' # get common functions - git clone https://github.com/imazen/gd-appveyor-helpers - ps: . .\gd-appveyor-helpers\appveyor_funcs.ps1 # fetch deps - mkdir deps - ps: if($env:build_bindings -eq 1) { invoke 'git' 'clone https://github.com/imazen/gd-dotnet-bindings-generator.git --depth 1' } - nuget install zlib-%tbs_tools%-%tbs_arch%-master -Source https://ci.appveyor.com/nuget/zlib-94hmpf3q011d - ps: move zlib*\* deps -force - if [%tbs_tools%]==[mingw] move deps\libzlibstatic.a deps\libz.a - if [%tbs_tools%]==[msvc12] move deps\zlibstatic.lib deps\zlib.lib - SET tbsd_zlib_built=1 - SET tbsd_zlib_incdir=deps - SET tbsd_zlib_libdir=deps - if [%tbs_gd_jpeg%]==[1] ( nuget install libjpeg-%tbs_tools%-%tbs_arch%-master -Source https://ci.appveyor.com/nuget/libjpeg-turbo-t70qw53csfhj && powershell -Command "move libjpeg*\* deps -force" && (if [%tbs_tools%]==[msvc12] move deps\jpeg_static.lib deps\jpeg.lib) && SET tbsd_libjpeg_turbo_built=1) - if [%tbs_gd_png%]==[1] ( nuget install libpng-%tbs_tools%-%tbs_arch%-master -Source https://ci.appveyor.com/nuget/libpng-7hwq4pmmrc48 && powershell -Command "move libpng*\* deps -force" && (if [%tbs_tools%]==[mingw] move deps\libpng16.a deps\libpng.a) && (if [%tbs_tools%]==[msvc12] move deps\libpng16_static.lib deps\png.lib) && SET tbsd_libpng_built=1) - if [%tbs_gd_freetype%]==[1] ( nuget install freetype-%tbs_tools%-%tbs_arch%-master -Source https://ci.appveyor.com/nuget/freetype-vf7bw7v5ec29 && powershell -Command "move freetype*\* deps -force" && (if [%tbs_tools%]==[msvc12] move deps\freetype_static.lib deps\freetype.lib) && SET tbsd_freetype_built=1) - if [%tbs_gd_tiff%]==[1] ( nuget install libtiff-%tbs_tools%-%tbs_arch%-master -Source https://ci.appveyor.com/nuget/libtiff-i3h8tqqy7o7b && powershell -Command "move libtiff*\* deps -force" && (if [%tbs_tools%]==[msvc12] move deps\tiff_static.lib deps\tiff.lib) && SET tbsd_libtiff_built=1) # remove dyn libs - del deps\*.dll* # get upx (cinst broken; gets dos ver) #- if [%pack_dlls%]==[1] cinst upx - if [%pack_dlls%]==[1] ( curl -L -o upx.zip http://upx.sourceforge.net/download/upx391w.zip && 7z e upx.zip *.exe -r ) # get mingw-w64-dgn (C:\mingw64) - ps: if($env:tbs_tools -eq 'mingw' -and $env:tbs_arch -eq 'x64') { invoke 'curl' '-L -o mw64.7z "http://libgd.blob.core.windows.net/mingw/mingw-w64-dgn-x86_64-20141001.7z"'; invoke '7z' 'x -oC:\ mw64.7z'; } # get mingw-w64-32bit (C:\mingw32) - ps: if($env:tbs_tools -eq 'mingw' -and $env:tbs_arch -eq 'x86' -and $env:build_bindings -eq 1) { invoke 'curl' '-L -o mw64-32.7z "http://libgd.blob.core.windows.net/mingw/i686-4.9.1-release-posix-dwarf-rt_v3-rev1.7z"'; invoke '7z' 'x -oC:\ mw64-32.7z'; } build_script: - '"C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall" %vcvar_arg%' - if [%tbs_tools%]==[mingw] if [%tbs_arch%]==[x86] SET PATH=C:\mingw\bin;%PATH% - if [%tbs_tools%]==[mingw] if [%tbs_arch%]==[x64] SET PATH=C:\mingw64\bin;%PATH% - SET zip=libgd-%tbs_tools%-%tbs_arch%.zip - ps: $nupkg_b = "libgd-$($env:tbs_tools)-$($env:tbs_arch)-$($env:APPVEYOR_REPO_BRANCH)"; - ps: $nupkg_c = "libgd-$($env:tbs_tools)-$($env:tbs_arch)-$($env:APPVEYOR_REPO_COMMIT)"; - if [%tbs_arch%]==[x86] SET dll_make=C:\mingw32\bin\mingw32-make.exe - if [%tbs_arch%]==[x64] SET dll_make=C:\mingw64\bin\mingw32-make.exe - for /f "tokens=*" %%i in ('thumbs list_bin') do set dll_name=%%i - SET dll_name=%dll_name:/=\% - for /f %%i in ("%dll_name%") do set dll_basename=%%~nxi - SET dll_raw=%dll_name%.raw - if [%tbs_tools%]==[msvc12] SET cli_args=%dll_basename% - if [%tbs_tools%]==[mingw] SET cli_args=%dll_make% %dll_basename% - thumbs make - for /f "tokens=*" %%i in ('thumbs list') do set files=%%i - copy %dll_name% %dll_raw% - if [%pack_dlls%]==[1] ( appveyor PushArtifact %dll_raw% && del %dll_name% && upx -o %dll_name% %dll_raw% ) - 7z a %zip% %files% - appveyor PushArtifact %zip% - ps: if(Test-Path $env:zip) { zip2nuget $env:zip $nupkg_b; zip2nuget $env:zip $nupkg_c; } # build bindings - ps: if($env:with_tiff -eq 0 -and $env:build_bindings -eq 1) { prepend 'gd-dotnet-bindings-generator\LibGD.CLI\LibGDExtensions.cs' '#define NO_TIFF'; $env:test_defs += 'NO_TIFF;' } - ps: if($env:with_freetype -eq 0 -and $env:build_bindings -eq 1) { prepend 'gd-dotnet-bindings-generator\LibGD.CLI\LibGDExtensions.cs' '#define NO_FREETYPE'; $env:test_defs += 'NO_FREETYPE;' } - '"C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall"' - if [%build_bindings%]==[1] ( cd gd-dotnet-bindings-generator && msbuild LibGD.CLI\LibGD.CLI.csproj /p:Configuration=Debug /p:Platform=AnyCPU /v:m && copy ..\%dll_raw% LibGD.CLI\bin\Debug\%dll_basename% && cd LibGD.CLI\bin\Debug && LibGD.CLI.exe %APPVEYOR_BUILD_FOLDER%\src %cli_args% && cd ..\..\.. && msbuild LibGD.Tests\LibGD.Tests.csproj /p:Configuration=Debug /p:Platform=AnyCPU /p:DefineConstants="%test_defs%" /v:m && cd..) - SET zip=LibGDSharp-%tbs_tools%-%tbs_arch%.zip - ps: if($env:build_bindings -eq 1) { invoke '7z' "a $($env:zip) .\$($env:dll_pack) .\gd-dotnet-bindings-generator\LibGD.CLI\bin\Debug\_iobuf.cs .\gd-dotnet-bindings-generator\LibGD.CLI\bin\Debug\LibGD.cs .\gd-dotnet-bindings-generator\LibGD.CLI\bin\Debug\LibGDExtensions.cs .\gd-dotnet-bindings-generator\LibGD.CLI\bin\Debug\LibGDSharp.dll"; Push-AppveyorArtifact $($env:zip); } - appveyor PushArtifact src\config.h test_script: - SET fail=0 - thumbs check || SET fail=1 & ver > nul - ps: Push-Ctest-Results 'build' - ps: Push-AppveyorArtifact build\Testing\Temporary\LastTest.log - exit %fail% - if [%build_bindings%]==[1] ( copy %dll_name% gd-dotnet-bindings-generator\LibGD.Tests\bin\Debug\%dll_basename% && (if [%tbs_arch%]==[x86] (nunit-console-x86 gd-dotnet-bindings-generator\LibGD.Tests\bin\Debug\LibGD.Tests.dll) else if [%tbs_arch%]==[x64] (nunit-console gd-dotnet-bindings-generator\LibGD.Tests\bin\Debug\LibGD.Tests.dll)) && appveyor PushArtifact TestResult.xml ) on_success: - ps: Push-AppveyorArtifact "$nupkg_b*.nupkg" - ps: Push-AppveyorArtifact "$nupkg_c*.nupkg" libgd-gd-2.1.1/bootstrap.sh000077500000000000000000000027021245535672000155520ustar00rootroot00000000000000#!/bin/sh -- # $Id$ # Small shell script to build gd from source # Generate the manual (unless naturaldocs isn't installed). Source # dists should include the docs so that end users don't need to # install naturaldocs. At the same time, we tolerate it being missing # so that random hackers don't need it just to build the code. if which naturaldocs > /dev/null; then echo "Generation user docs:" (cd docs/naturaldocs; bash run_docs.sh) else echo "Can't find naturaldocs; not generating user manual." fi # allow importing from the environment, e.g. # "AUTOCONF=autoconf259 ... ./bootstrap.sh" if echo $OSTYPE | grep -q '^darwin' ; then echo Having trouble on OS X? Try brew install autoconf libtool automake gettext apple-gcc42 pkg-config cmake LIBTOOLIZE=${LIBTOOLIZE:-glibtoolize} fi ACLOCAL=${ACLOCAL:-aclocal} AUTOCONF=${AUTOCONF:-autoconf} AUTOHEADER=${AUTOHEADER:-autoheader} AUTOMAKE=${AUTOMAKE:-automake} LIBTOOLIZE=${LIBTOOLIZE:-libtoolize} # might handle this differently AUTOMAKE_FLAGS="--add-missing --copy" # CLEANFILES="Makefile.in aclocal.m4 autom4te.cache configure libtool config/Makefile.in \ tests/Makefile.in src/Makefile.in" # rm -rf ${CLEANFILES} # if ${ACLOCAL} -I m4 \ && ${LIBTOOLIZE} --automake --copy --force \ && ${ACLOCAL} -I m4 \ && ${AUTOHEADER} \ && ${AUTOMAKE} ${AUTOMAKE_FLAGS} \ && ${AUTOCONF} --force && [ -f configure ] then echo Now run configure and make else echo Failed exit 1 fi exit 0 libgd-gd-2.1.1/cmake/000077500000000000000000000000001245535672000142555ustar00rootroot00000000000000libgd-gd-2.1.1/cmake/modules/000077500000000000000000000000001245535672000157255ustar00rootroot00000000000000libgd-gd-2.1.1/cmake/modules/AC_HEADER_STDC.cmake000066400000000000000000000024641245535672000210450ustar00rootroot00000000000000message(STATUS "Checking whether system has ANSI C header files") include(CheckPrototypeExists) include(CheckPrototypeExists) check_include_files("dlfcn.h;stdint.h;stddef.h;inttypes.h;stdlib.h;strings.h;string.h;float.h" StandardHeadersExist) if(StandardHeadersExist) check_prototype_exists(memchr string.h memchrExists) if(memchrExists) check_prototype_exists(free stdlib.h freeExists) if(freeExists) message(STATUS "ANSI C header files - found") set(STDC_HEADERS 1 CACHE INTERNAL "System has ANSI C header files") set(HAVE_STRINGS_H 1) set(HAVE_STRING_H 1) set(HAVE_FLOAT_H 1) set(HAVE_STDLIB_H 1) set(HAVE_STDDEF_H 1) set(HAVE_STDINT_H 1) set(HAVE_INTTYPES_H 1) set(HAVE_DLFCN_H 1) endif(freeExists) endif(memchrExists) endif(StandardHeadersExist) if(NOT STDC_HEADERS) message(STATUS "ANSI C header files - not found") set(STDC_HEADERS 0 CACHE INTERNAL "System has ANSI C header files") endif(NOT STDC_HEADERS) check_include_files(unistd.h HAVE_UNISTD_H) include(CheckDIRSymbolExists) check_dirsymbol_exists("sys/stat.h;sys/types.h;dirent.h" HAVE_DIRENT_H) if (HAVE_DIRENT_H) set(HAVE_SYS_STAT_H 1) set(HAVE_SYS_TYPES_H 1) endif (HAVE_DIRENT_H) check_include_files("dlfcn.h;stdint.h;stddef.h;inttypes.h;stdlib.h;strings.h;string.h;float.h" StandardHeadersExist) set(HAVE_LIBM 1) libgd-gd-2.1.1/cmake/modules/CMakeParseArguments.cmake000066400000000000000000000153711245535672000225770ustar00rootroot00000000000000# CMAKE_PARSE_ARGUMENTS( args...) # # CMAKE_PARSE_ARGUMENTS() is intended to be used in macros or functions for # parsing the arguments given to that macro or function. # It processes the arguments and defines a set of variables which hold the # values of the respective options. # # The argument contains all options for the respective macro, # i.e. keywords which can be used when calling the macro without any value # following, like e.g. the OPTIONAL keyword of the install() command. # # The argument contains all keywords for this macro # which are followed by one value, like e.g. DESTINATION keyword of the # install() command. # # The argument contains all keywords for this macro # which can be followed by more than one value, like e.g. the TARGETS or # FILES keywords of the install() command. # # When done, CMAKE_PARSE_ARGUMENTS() will have defined for each of the # keywords listed in , and # a variable composed of the given # followed by "_" and the name of the respective keyword. # These variables will then hold the respective value from the argument list. # For the keywords this will be TRUE or FALSE. # # All remaining arguments are collected in a variable # _UNPARSED_ARGUMENTS, this can be checked afterwards to see whether # your macro was called with unrecognized parameters. # # As an example here a my_install() macro, which takes similar arguments as the # real install() command: # # function(MY_INSTALL) # set(options OPTIONAL FAST) # set(oneValueArgs DESTINATION RENAME) # set(multiValueArgs TARGETS CONFIGURATIONS) # cmake_parse_arguments(MY_INSTALL "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN} ) # ... # # Assume my_install() has been called like this: # my_install(TARGETS foo bar DESTINATION bin OPTIONAL blub) # # After the cmake_parse_arguments() call the macro will have set the following # variables: # MY_INSTALL_OPTIONAL = TRUE # MY_INSTALL_FAST = FALSE (this option was not used when calling my_install() # MY_INSTALL_DESTINATION = "bin" # MY_INSTALL_RENAME = "" (was not used) # MY_INSTALL_TARGETS = "foo;bar" # MY_INSTALL_CONFIGURATIONS = "" (was not used) # MY_INSTALL_UNPARSED_ARGUMENTS = "blub" (no value expected after "OPTIONAL" # # You can the continue and process these variables. # # Keywords terminate lists of values, e.g. if directly after a one_value_keyword # another recognized keyword follows, this is interpreted as the beginning of # the new option. # E.g. my_install(TARGETS foo DESTINATION OPTIONAL) would result in # MY_INSTALL_DESTINATION set to "OPTIONAL", but MY_INSTALL_DESTINATION would # be empty and MY_INSTALL_OPTIONAL would be set to TRUE therefor. #============================================================================= # Copyright 2010 Alexander Neundorf # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. #============================================================================= if(__CMAKE_PARSE_ARGUMENTS_INCLUDED) return() endif() set(__CMAKE_PARSE_ARGUMENTS_INCLUDED TRUE) function(CMAKE_PARSE_ARGUMENTS prefix _optionNames _singleArgNames _multiArgNames) # first set all result variables to empty/FALSE foreach(arg_name ${_singleArgNames} ${_multiArgNames}) set(${prefix}_${arg_name}) endforeach() foreach(option ${_optionNames}) set(${prefix}_${option} FALSE) endforeach() set(${prefix}_UNPARSED_ARGUMENTS) set(insideValues FALSE) set(currentArgName) # now iterate over all arguments and fill the result variables foreach(currentArg ${ARGN}) list(FIND _optionNames "${currentArg}" optionIndex) # ... then this marks the end of the arguments belonging to this keyword list(FIND _singleArgNames "${currentArg}" singleArgIndex) # ... then this marks the end of the arguments belonging to this keyword list(FIND _multiArgNames "${currentArg}" multiArgIndex) # ... then this marks the end of the arguments belonging to this keyword if(${optionIndex} EQUAL -1 AND ${singleArgIndex} EQUAL -1 AND ${multiArgIndex} EQUAL -1) if(insideValues) if("${insideValues}" STREQUAL "SINGLE") set(${prefix}_${currentArgName} ${currentArg}) set(insideValues FALSE) elseif("${insideValues}" STREQUAL "MULTI") list(APPEND ${prefix}_${currentArgName} ${currentArg}) endif() else() list(APPEND ${prefix}_UNPARSED_ARGUMENTS ${currentArg}) endif() else() if(NOT ${optionIndex} EQUAL -1) set(${prefix}_${currentArg} TRUE) set(insideValues FALSE) elseif(NOT ${singleArgIndex} EQUAL -1) set(currentArgName ${currentArg}) set(${prefix}_${currentArgName}) set(insideValues "SINGLE") elseif(NOT ${multiArgIndex} EQUAL -1) set(currentArgName ${currentArg}) set(${prefix}_${currentArgName}) set(insideValues "MULTI") endif() endif() endforeach() # propagate the result variables to the caller: foreach(arg_name ${_singleArgNames} ${_multiArgNames} ${_optionNames}) set(${prefix}_${arg_name} ${${prefix}_${arg_name}} PARENT_SCOPE) endforeach() set(${prefix}_UNPARSED_ARGUMENTS ${${prefix}_UNPARSED_ARGUMENTS} PARENT_SCOPE) endfunction() libgd-gd-2.1.1/cmake/modules/CheckDIRSymbolExists.cmake000066400000000000000000000116731245535672000227010ustar00rootroot00000000000000# Copyright (c) 2002 Kitware, Inc., Insight Consortium # All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # - Check if the DIR symbol exists like in AC_HEADER_DIRENT. # CHECK_DIRSYMBOL_EXISTS(FILES VARIABLE) # # FILES - include files to check # VARIABLE - variable to return result # # This module is a small but important variation on CheckSymbolExists.cmake. # The symbol always searched for is DIR, and the test programme follows # the AC_HEADER_DIRENT test programme rather than the CheckSymbolExists.cmake # test programme which always fails since DIR tends to be typedef'd # rather than #define'd. # # The following variables may be set before calling this macro to # modify the way the check is run: # # CMAKE_REQUIRED_FLAGS = string of compile command line flags # CMAKE_REQUIRED_DEFINITIONS = list of macros to define (-DFOO=bar) # CMAKE_REQUIRED_INCLUDES = list of include directories # CMAKE_REQUIRED_LIBRARIES = list of libraries to link MACRO(CHECK_DIRSYMBOL_EXISTS FILES VARIABLE) IF(NOT DEFINED ${VARIABLE}) SET(CMAKE_CONFIGURABLE_FILE_CONTENT "/* */\n") SET(MACRO_CHECK_DIRSYMBOL_EXISTS_FLAGS ${CMAKE_REQUIRED_FLAGS}) IF(CMAKE_REQUIRED_LIBRARIES) SET(CHECK_DIRSYMBOL_EXISTS_LIBS "-DLINK_LIBRARIES:STRING=${CMAKE_REQUIRED_LIBRARIES}") ELSE(CMAKE_REQUIRED_LIBRARIES) SET(CHECK_DIRSYMBOL_EXISTS_LIBS) ENDIF(CMAKE_REQUIRED_LIBRARIES) IF(CMAKE_REQUIRED_INCLUDES) SET(CMAKE_DIRSYMBOL_EXISTS_INCLUDES "-DINCLUDE_DIRECTORIES:STRING=${CMAKE_REQUIRED_INCLUDES}") ELSE(CMAKE_REQUIRED_INCLUDES) SET(CMAKE_DIRSYMBOL_EXISTS_INCLUDES) ENDIF(CMAKE_REQUIRED_INCLUDES) FOREACH(FILE ${FILES}) SET(CMAKE_CONFIGURABLE_FILE_CONTENT "${CMAKE_CONFIGURABLE_FILE_CONTENT}#include <${FILE}>\n") ENDFOREACH(FILE) SET(CMAKE_CONFIGURABLE_FILE_CONTENT "${CMAKE_CONFIGURABLE_FILE_CONTENT}\nint main()\n{if ((DIR *) 0) return 0;}\n") CONFIGURE_FILE("${CMAKE_ROOT}/Modules/CMakeConfigurableFile.in" "${CMAKE_BINARY_DIR}/CMakeFiles/CMakeTmp/CheckDIRSymbolExists.c" @ONLY) MESSAGE(STATUS "Looking for DIR in ${FILES}") TRY_COMPILE(${VARIABLE} ${CMAKE_BINARY_DIR} ${CMAKE_BINARY_DIR}/CMakeFiles/CMakeTmp/CheckDIRSymbolExists.c COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS} CMAKE_FLAGS -DCOMPILE_DEFINITIONS:STRING=${MACRO_CHECK_DIRSYMBOL_EXISTS_FLAGS} "${CHECK_DIRSYMBOL_EXISTS_LIBS}" "${CMAKE_DIRSYMBOL_EXISTS_INCLUDES}" OUTPUT_VARIABLE OUTPUT) IF(${VARIABLE}) MESSAGE(STATUS "Looking for DIR in ${FILES} - found") SET(${VARIABLE} 1 CACHE INTERNAL "Have symbol DIR") FILE(APPEND ${CMAKE_BINARY_DIR}/CMakeFiles/CMakeOutput.log "Determining if the DIR symbol is defined as in AC_HEADER_DIRENT " "passed with the following output:\n" "${OUTPUT}\nFile ${CMAKE_BINARY_DIR}/CMakeFiles/CMakeTmp/CheckDIRSymbolExists.c:\n" "${CMAKE_CONFIGURABLE_FILE_CONTENT}\n") ELSE(${VARIABLE}) MESSAGE(STATUS "Looking for DIR in ${FILES} - not found.") SET(${VARIABLE} "" CACHE INTERNAL "Have symbol DIR") FILE(APPEND ${CMAKE_BINARY_DIR}/CMakeFiles/CMakeError.log "Determining if the DIR symbol is defined as in AC_HEADER_DIRENT " "failed with the following output:\n" "${OUTPUT}\nFile ${CMAKE_BINARY_DIR}/CMakeFiles/CMakeTmp/CheckDIRSymbolExists.c:\n" "${CMAKE_CONFIGURABLE_FILE_CONTENT}\n") ENDIF(${VARIABLE}) ENDIF(NOT DEFINED ${VARIABLE}) ENDMACRO(CHECK_DIRSYMBOL_EXISTS) libgd-gd-2.1.1/cmake/modules/CheckPrototypeExists.cmake000066400000000000000000000054631245535672000231020ustar00rootroot00000000000000#============================================================================= # Copyright 2010 Alexander Neundorf # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. #============================================================================= # AWI, downloaded from KDE repository since has not yet been transferred # to cmake repository as of 2006-07-31. # http://websvn.kde.org/trunk/KDE/kdelibs/cmake/modules/CheckPrototypeExists.cmake?rev=505849&view=markup # # - Check if the prototype for a function exists. # CHECK_PROTOTYPE_EXISTS (FUNCTION HEADER VARIABLE) # # FUNCTION - the name of the function you are looking for # HEADER - the header(s) where the prototype should be declared # VARIABLE - variable to store the result # INCLUDE(CheckCXXSourceCompiles) MACRO(CHECK_PROTOTYPE_EXISTS _SYMBOL _HEADER _RESULT) SET(_INCLUDE_FILES) FOREACH(it ${_HEADER}) SET(_INCLUDE_FILES "${_INCLUDE_FILES}#include <${it}>\n") ENDFOREACH(it) SET(_CHECK_PROTO_EXISTS_SOURCE_CODE " ${_INCLUDE_FILES} void cmakeRequireSymbol(int dummy,...){(void)dummy;} int main() { #ifndef ${_SYMBOL} #ifndef _MSC_VER cmakeRequireSymbol(0,&${_SYMBOL}); #else char i = sizeof(&${_SYMBOL}); #endif #endif return 0; } ") CHECK_CXX_SOURCE_COMPILES("${_CHECK_PROTO_EXISTS_SOURCE_CODE}" ${_RESULT}) ENDMACRO(CHECK_PROTOTYPE_EXISTS _SYMBOL _HEADER _RESULT) libgd-gd-2.1.1/cmake/modules/FindFontConfig.cmake000066400000000000000000000053251245535672000215710ustar00rootroot00000000000000# Copyright (c) 2006,2007 Laurent Montel, # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # # 1. Redistributions of source code must retain the copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # 3. The name of the author may not be used to endorse or promote products # derived from this software without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. # IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # - Try to find Fontconfig # Once done this will define # # FONTCONFIG_FOUND - system has Fontconfig # FONTCONFIG_INCLUDE_DIR - the Fontconfig include directory # FONTCONFIG_LIBRARY - Link these to use Fontconfig if ( FONTCONFIG_INCLUDE_DIR AND FONTCONFIG_LIBRARY ) # in cache already SET(Fontconfig_FIND_QUIETLY TRUE) endif ( FONTCONFIG_INCLUDE_DIR AND FONTCONFIG_LIBRARY ) # use pkg-config to get the directories and then use these values # in the FIND_PATH() and FIND_LIBRARY() calls if( NOT WIN32 ) find_package(PkgConfig) pkg_check_modules(FONTCONFIG_PKG QUIET fontconfig) endif( NOT WIN32 ) FIND_PATH(FONTCONFIG_INCLUDE_DIR NAMES fontconfig/fontconfig.h PATHS /usr/local/include /usr/X11/include /usr/include HINTS ${FONTCONFIG_PKG_INCLUDE_DIRS} # Generated by pkg-config ) FIND_LIBRARY(FONTCONFIG_LIBRARY NAMES fontconfig ${FONTCONFIG_PKG_LIBRARY} PATHS /usr/local /usr/X11 /usr HINTS ${FONTCONFIG_PKG_LIBRARY_DIRS} # Generated by pkg-config PATH_SUFFIXES lib64 lib ) include(FindPackageHandleStandardArgs) FIND_PACKAGE_HANDLE_STANDARD_ARGS(Fontconfig DEFAULT_MSG FONTCONFIG_LIBRARY FONTCONFIG_INCLUDE_DIR ) # show the FONTCONFIG_INCLUDE_DIR and FONTCONFIG_LIBRARY variables only in the advanced view MARK_AS_ADVANCED(FONTCONFIG_INCLUDE_DIR FONTCONFIG_LIBRARY ) libgd-gd-2.1.1/cmake/modules/FindFreetype.cmake000066400000000000000000000123671245535672000213240ustar00rootroot00000000000000# - Locate FreeType library # This module defines # FREETYPE_LIBRARIES, the library to link against # FREETYPE_FOUND, if false, do not try to link to FREETYPE # FREETYPE_INCLUDE_DIRS, where to find headers. # FREETYPE_VERSION_STRING, the version of freetype found (since CMake 2.8.8) # This is the concatenation of the paths: # FREETYPE_INCLUDE_DIR_ft2build # FREETYPE_INCLUDE_DIR_freetype2 # # $FREETYPE_DIR is an environment variable that would # correspond to the ./configure --prefix=$FREETYPE_DIR # used in building FREETYPE. #============================================================================= # Copyright 2007-2009 Kitware, Inc. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # Created by Eric Wing. # Modifications by Alexander Neundorf. # This file has been renamed to "FindFreetype.cmake" instead of the correct # "FindFreeType.cmake" in order to be compatible with the one from KDE4, Alex. # Ugh, FreeType seems to use some #include trickery which # makes this harder than it should be. It looks like they # put ft2build.h in a common/easier-to-find location which # then contains a #include to a more specific header in a # more specific location (#include ). # Then from there, they need to set a bunch of #define's # so you can do something like: # #include FT_FREETYPE_H # Unfortunately, using CMake's mechanisms like include_directories() # wants explicit full paths and this trickery doesn't work too well. # I'm going to attempt to cut out the middleman and hope # everything still works. find_path(FREETYPE_INCLUDE_DIR_ft2build ft2build.h HINTS ENV FREETYPE_DIR PATHS /usr/local/X11R6 /usr/local/X11 /usr/freeware PATH_SUFFIXES include/freetype2 include ) find_path(FREETYPE_INCLUDE_DIR_freetype2 freetype/config/ftheader.h HINTS ENV FREETYPE_DIR PATHS /usr/local/X11R6 /usr/local/X11 /usr/freeware PATH_SUFFIXES include/freetype2 include ) find_library(FREETYPE_LIBRARY NAMES freetype libfreetype freetype219 freetype_a HINTS ENV FREETYPE_DIR PATH_SUFFIXES lib PATHS /usr/local/X11R6 /usr/local/X11 /usr/freeware ) # set the user variables if(FREETYPE_INCLUDE_DIR_ft2build AND FREETYPE_INCLUDE_DIR_freetype2) set(FREETYPE_INCLUDE_DIRS "${FREETYPE_INCLUDE_DIR_ft2build};${FREETYPE_INCLUDE_DIR_freetype2}") endif() set(FREETYPE_LIBRARIES "${FREETYPE_LIBRARY}") if(FREETYPE_INCLUDE_DIR_freetype2 AND EXISTS "${FREETYPE_INCLUDE_DIR_freetype2}/freetype/freetype.h") file(STRINGS "${FREETYPE_INCLUDE_DIR_freetype2}/freetype/freetype.h" freetype_version_str REGEX "^#[\t ]*define[\t ]+FREETYPE_(MAJOR|MINOR|PATCH)[\t ]+[0-9]+$") unset(FREETYPE_VERSION_STRING) foreach(VPART MAJOR MINOR PATCH) foreach(VLINE ${freetype_version_str}) if(VLINE MATCHES "^#[\t ]*define[\t ]+FREETYPE_${VPART}") string(REGEX REPLACE "^#[\t ]*define[\t ]+FREETYPE_${VPART}[\t ]+([0-9]+)$" "\\1" FREETYPE_VERSION_PART "${VLINE}") if(FREETYPE_VERSION_STRING) set(FREETYPE_VERSION_STRING "${FREETYPE_VERSION_STRING}.${FREETYPE_VERSION_PART}") else() set(FREETYPE_VERSION_STRING "${FREETYPE_VERSION_PART}") endif() unset(FREETYPE_VERSION_PART) endif() endforeach() endforeach() endif() # handle the QUIETLY and REQUIRED arguments and set FREETYPE_FOUND to TRUE if # all listed variables are TRUE include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake) FIND_PACKAGE_HANDLE_STANDARD_ARGS(Freetype REQUIRED_VARS FREETYPE_LIBRARY FREETYPE_INCLUDE_DIRS VERSION_VAR FREETYPE_VERSION_STRING) mark_as_advanced(FREETYPE_LIBRARY FREETYPE_INCLUDE_DIR_freetype2 FREETYPE_INCLUDE_DIR_ft2build) libgd-gd-2.1.1/cmake/modules/FindGD.cmake000066400000000000000000000070101245535672000200200ustar00rootroot00000000000000# - Find GD # Find the native GD includes and library # This module defines # GD_INCLUDE_DIR, where to find gd.h, etc. # GD_LIBRARIES, the libraries needed to use GD. # GD_FOUND, If false, do not try to use GD. # also defined, but not for general use are # GD_LIBRARY, where to find the GD library. # GD_SUPPORTS_PNG, GD_SUPPORTS_JPEG, GD_SUPPORTS_GIF, test # support for image formats in GD. FIND_PATH(GD_INCLUDE_DIR gd.h /usr/local/include /usr/include ) if(WIN32 AND NOT CYGWIN) SET(GD_NAMES ${GD_NAMES} bgd) else(WIN32) SET(GD_NAMES ${GD_NAMES} gd) endif(WIN32 AND NOT CYGWIN) FIND_LIBRARY(GD_LIBRARY NAMES ${GD_NAMES} PATHS /usr/lib64 /usr/lib /usr/local/lib ) IF (GD_LIBRARY AND GD_INCLUDE_DIR) SET(GD_LIBRARIES ${GD_LIBRARY}) SET(GD_FOUND "YES") ELSE (GD_LIBRARY AND GD_INCLUDE_DIR) SET(GD_FOUND "NO") ENDIF (GD_LIBRARY AND GD_INCLUDE_DIR) message("Found GD: ${GD_FOUND}") IF (GD_FOUND) IF (WIN32 AND NOT CYGWIN) SET(GD_SUPPORTS_PNG ON) SET(GD_SUPPORTS_JPEG ON) SET(GD_SUPPORTS_GIF ON) get_filename_component(GD_LIBRARY_DIR ${GD_LIBRARY} PATH) ELSE (WIN32 AND NOT CYGWIN) INCLUDE(CheckLibraryExists) GET_FILENAME_COMPONENT(GD_LIB_PATH ${GD_LIBRARY} PATH) GET_FILENAME_COMPONENT(GD_LIB ${GD_LIBRARY} NAME) CHECK_LIBRARY_EXISTS("${GD_LIBRARY}" "gdImagePng" "${GD_LIB_PATH}" GD_SUPPORTS_PNG) IF (GD_SUPPORTS_PNG) find_package(PNG) IF (PNG_FOUND) SET(GD_LIBRARIES ${GD_LIBRARIES} ${PNG_LIBRARIES}) SET(GD_INCLUDE_DIR ${GD_INCLUDE_DIR} ${PNG_INCLUDE_DIR}) ELSE (PNG_FOUND) SET(GD_SUPPORTS_PNG "NO") ENDIF (PNG_FOUND) ENDIF (GD_SUPPORTS_PNG) CHECK_LIBRARY_EXISTS("${GD_LIBRARY}" "gdImageJpeg" "${GD_LIB_PATH}" GD_SUPPORTS_JPEG) IF (GD_SUPPORTS_JPEG) find_package(JPEG) IF (JPEG_FOUND) SET(GD_LIBRARIES ${GD_LIBRARIES} ${JPEG_LIBRARIES}) SET(GD_INCLUDE_DIR ${GD_INCLUDE_DIR} ${JPEG_INCLUDE_DIR}) ELSE (JPEG_FOUND) SET(GD_SUPPORTS_JPEG "NO") ENDIF (JPEG_FOUND) ENDIF (GD_SUPPORTS_JPEG) CHECK_LIBRARY_EXISTS("${GD_LIBRARY}" "gdImageGif" "${GD_LIB_PATH}" GD_SUPPORTS_GIF) # Trim the list of include directories SET(GDINCTRIM) FOREACH(GD_DIR ${GD_INCLUDE_DIR}) SET(GD_TMP_FOUND OFF) FOREACH(GD_TRIMMED ${GDINCTRIM}) IF ("${GD_DIR}" STREQUAL "${GD_TRIMMED}") SET(GD_TMP_FOUND ON) ENDIF ("${GD_DIR}" STREQUAL "${GD_TRIMMED}") ENDFOREACH(GD_TRIMMED ${GDINCTRIM}) IF (NOT GD_TMP_FOUND) SET(GDINCTRIM "${GDINCTRIM}" "${GD_DIR}") ENDIF (NOT GD_TMP_FOUND) ENDFOREACH(GD_DIR ${GD_INCLUDE_DIR}) SET(GD_INCLUDE_DIR ${GDINCTRIM}) SET(GD_LIBRARY_DIR) # Generate trimmed list of library directories and list of libraries FOREACH(GD_LIB ${GD_LIBRARIES}) GET_FILENAME_COMPONENT(GD_NEXTLIBDIR ${GD_LIB} PATH) SET(GD_TMP_FOUND OFF) FOREACH(GD_LIBDIR ${GD_LIBRARY_DIR}) IF ("${GD_NEXTLIBDIR}" STREQUAL "${GD_LIBDIR}") SET(GD_TMP_FOUND ON) ENDIF ("${GD_NEXTLIBDIR}" STREQUAL "${GD_LIBDIR}") ENDFOREACH(GD_LIBDIR ${GD_LIBRARIES}) IF (NOT GD_TMP_FOUND) SET(GD_LIBRARY_DIR "${GD_LIBRARY_DIR}" "${GD_NEXTLIBDIR}") ENDIF (NOT GD_TMP_FOUND) ENDFOREACH(GD_LIB ${GD_LIBRARIES}) ENDIF (WIN32 AND NOT CYGWIN) ENDIF (GD_FOUND) IF (GD_FOUND) IF (NOT GD_FIND_QUIETLY) MESSAGE(STATUS "Found GD: ${GD_LIBRARY}") ENDIF (NOT GD_FIND_QUIETLY) ELSE (GD_FOUND) IF (GD_FIND_REQUIRED) MESSAGE(FATAL_ERROR "Could not find GD library") ENDIF (GD_FIND_REQUIRED) ENDIF (GD_FOUND) MARK_AS_ADVANCED( GD_LIBRARY GD_LIBRARIES GD_INCLUDE_DIR GD_LIBRARY_DIR GD_SUPPORTS_PNG GD_SUPPORTS_JPEG GD_SUPPORTS_GIF ) libgd-gd-2.1.1/cmake/modules/FindICONV.cmake000066400000000000000000000034551245535672000204150ustar00rootroot00000000000000# - Try to find Iconv # Once done this will define # # ICONV_FOUND - system has Iconv # ICONV_INCLUDE_DIR - the Iconv include directory # ICONV_LIBRARIES - Link these to use Iconv # ICONV_SECOND_ARGUMENT_IS_CONST - the second argument for iconv() is const # include(CheckCCompilerFlag) include(CheckCSourceCompiles) IF (ICONV_INCLUDE_DIR AND ICONV_LIBRARIES) # Already in cache, be silent SET(ICONV_FIND_QUIETLY TRUE) ENDIF (ICONV_INCLUDE_DIR AND ICONV_LIBRARIES) FIND_PATH(ICONV_INCLUDE_DIR iconv.h HINTS /sw/include/ PATHS /opt/local) FIND_LIBRARY(ICONV_LIBRARIES NAMES libiconv_a iconv libiconv c PATHS /opt/local) IF(ICONV_INCLUDE_DIR AND ICONV_LIBRARIES) SET(ICONV_FOUND TRUE) ENDIF(ICONV_INCLUDE_DIR AND ICONV_LIBRARIES) set(CMAKE_REQUIRED_INCLUDES ${ICONV_INCLUDE_DIR}) set(CMAKE_REQUIRED_LIBRARIES ${ICONV_LIBRARIES}) IF(ICONV_FOUND) check_c_compiler_flag("-Werror" ICONV_HAVE_WERROR) set (CMAKE_C_FLAGS_BACKUP "${CMAKE_C_FLAGS}") if(ICONV_HAVE_WERROR) set (CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Werror") endif(ICONV_HAVE_WERROR) check_c_source_compiles(" #include int main(){ iconv_t conv = 0; const char* in = 0; size_t ilen = 0; char* out = 0; size_t olen = 0; iconv(conv, &in, &ilen, &out, &olen); return 0; } " ICONV_SECOND_ARGUMENT_IS_CONST ) set (CMAKE_C_FLAGS "${CMAKE_C_FLAGS_BACKUP}") ENDIF(ICONV_FOUND) set(CMAKE_REQUIRED_INCLUDES) set(CMAKE_REQUIRED_LIBRARIES) IF(ICONV_FOUND) IF(NOT ICONV_FIND_QUIETLY) MESSAGE(STATUS "Found Iconv: ${ICONV_LIBRARIES}") ENDIF(NOT ICONV_FIND_QUIETLY) ELSE(ICONV_FOUND) IF(Iconv_FIND_REQUIRED) MESSAGE(FATAL_ERROR "Could not find Iconv") ENDIF(Iconv_FIND_REQUIRED) ENDIF(ICONV_FOUND) MARK_AS_ADVANCED( ICONV_INCLUDE_DIR ICONV_LIBRARIES ICONV_SECOND_ARGUMENT_IS_CONST )libgd-gd-2.1.1/cmake/modules/FindJPEG.cmake000066400000000000000000000051411245535672000202560ustar00rootroot00000000000000# - Find JPEG # Find the native JPEG includes and library # This module defines # JPEG_INCLUDE_DIR, where to find jpeglib.h, etc. # JPEG_LIBRARIES, the libraries needed to use JPEG. # JPEG_FOUND, If false, do not try to use JPEG. # also defined, but not for general use are # JPEG_LIBRARY, where to find the JPEG library. #============================================================================= # Copyright 2001-2009 Kitware, Inc. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. find_path(JPEG_INCLUDE_DIR jpeglib.h) set(JPEG_NAMES ${JPEG_NAMES} jpeg libjpeg_a) find_library(JPEG_LIBRARY NAMES ${JPEG_NAMES} ) # handle the QUIETLY and REQUIRED arguments and set JPEG_FOUND to TRUE if # all listed variables are TRUE include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake) FIND_PACKAGE_HANDLE_STANDARD_ARGS(JPEG DEFAULT_MSG JPEG_LIBRARY JPEG_INCLUDE_DIR) if(JPEG_FOUND) set(JPEG_LIBRARIES ${JPEG_LIBRARY}) endif() # Deprecated declarations. set (NATIVE_JPEG_INCLUDE_PATH ${JPEG_INCLUDE_DIR} ) if(JPEG_LIBRARY) get_filename_component (NATIVE_JPEG_LIB_PATH ${JPEG_LIBRARY} PATH) endif() mark_as_advanced(JPEG_LIBRARY JPEG_INCLUDE_DIR ) libgd-gd-2.1.1/cmake/modules/FindLIQ.cmake000066400000000000000000000037151245535672000201630ustar00rootroot00000000000000# Find libimagequant includes and library (and download+build if needed) # http://pngquant.org/lib # # This module defines # LIQ_INCLUDE_DIR, where to find libimagequant.h # LIQ_LIBRARIES, the libraries to link against to use libimagequant. # LIQ_FOUND, If false, do not try to use libimagequant. SET(LIQ_FOUND "NO") FIND_PATH(LIQ_INCLUDE_DIR libimagequant.h "${PROJECT_SOURCE_DIR}/libimagequant" "${PROJECT_SOURCE_DIR}/pngquant/lib" /usr/local/include /usr/include ) FIND_LIBRARY(LIQ_LIBRARY NAMES libimagequant imagequant PATHS "${PROJECT_SOURCE_DIR}/libimagequant" "${PROJECT_SOURCE_DIR}/pngquant/lib" /usr/lib64 /usr/lib /usr/local/lib ) IF (LIQ_LIBRARY AND LIQ_INCLUDE_DIR) SET(LIQ_FOUND "YES") SET(LIQ_LIBRARIES ${LIQ_LIBRARY}) SET(HAVE_LIBIMAGEQUANT_H 1) ENDIF (LIQ_LIBRARY AND LIQ_INCLUDE_DIR) IF (LIQ_FOUND) IF (NOT LIQ_FIND_QUIETLY) MESSAGE(STATUS "Found LIQ: ${LIQ_LIBRARY} ${LIQ_INCLUDE_DIR}") ENDIF (NOT LIQ_FIND_QUIETLY) ELSE (LIQ_FOUND) # if existing library not found, then download and build it IF (NOT WIN32 OR CYGWIN OR MINGW) # MSVC's C compiler is too old to compile libimagequant IF (CMAKE_VERSION VERSION_GREATER "2.8.1") MESSAGE(STATUS "LIQ will be built") INCLUDE(ExternalProject) EXTERNALPROJECT_ADD( libimagequant URL "http://pngquant.org/libimagequant-2.0.0-src.tar.bz2" SOURCE_DIR libimagequant BUILD_IN_SOURCE 1 INSTALL_DIR libimagequant INSTALL_COMMAND true CONFIGURE_COMMAND true BUILD_COMMAND make static CFLAGSADD='-fPIC' ) SET(LIQ_FOUND "SORTOF") SET(LIQ_BUILD "YES") SET(LIQ_LIBRARIES "${PROJECT_BINARY_DIR}/libimagequant/libimagequant.a") SET(LIQ_INCLUDE_DIR "${PROJECT_BINARY_DIR}/libimagequant/") SET(HAVE_LIBIMAGEQUANT_H 1) ENDIF(CMAKE_VERSION VERSION_GREATER "2.8.1") ENDIF(NOT WIN32 OR CYGWIN OR MINGW) ENDIF (LIQ_FOUND) MARK_AS_ADVANCED(LIQ_INCLUDE_DIR LIQ_LIBRARIES LIQ_BUILD) libgd-gd-2.1.1/cmake/modules/FindPNG.cmake000066400000000000000000000101421245535672000201520ustar00rootroot00000000000000# - Find the native PNG includes and library # # This module searches libpng, the library for working with PNG images. # # It defines the following variables # PNG_INCLUDE_DIRS, where to find png.h, etc. # PNG_LIBRARIES, the libraries to link against to use PNG. # PNG_DEFINITIONS - You should add_definitons(${PNG_DEFINITIONS}) before compiling code that includes png library files. # PNG_FOUND, If false, do not try to use PNG. # PNG_VERSION_STRING - the version of the PNG library found (since CMake 2.8.8) # Also defined, but not for general use are # PNG_LIBRARY, where to find the PNG library. # For backward compatiblity the variable PNG_INCLUDE_DIR is also set. It has the same value as PNG_INCLUDE_DIRS. # # Since PNG depends on the ZLib compression library, none of the above will be # defined unless ZLib can be found. #============================================================================= # Copyright 2002-2009 Kitware, Inc. # # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. if(PNG_FIND_QUIETLY) set(_FIND_ZLIB_ARG QUIET) endif() find_package(ZLIB ${_FIND_ZLIB_ARG}) if(ZLIB_FOUND) find_path(PNG_PNG_INCLUDE_DIR png.h /usr/local/include/libpng # OpenBSD ) set(PNG_NAMES ${PNG_NAMES} png libpng png15 libpng15 png15d libpng15d png14 libpng14 png14d libpng14d png12 libpng12 png12d libpng12d libpng_a) find_library(PNG_LIBRARY NAMES ${PNG_NAMES} ) if (PNG_LIBRARY AND PNG_PNG_INCLUDE_DIR) # png.h includes zlib.h. Sigh. set(PNG_INCLUDE_DIRS ${PNG_PNG_INCLUDE_DIR} ${ZLIB_INCLUDE_DIR} ) set(PNG_INCLUDE_DIR ${PNG_INCLUDE_DIRS} ) # for backward compatiblity set(PNG_LIBRARIES ${PNG_LIBRARY} ${ZLIB_LIBRARY}) if (CYGWIN) if(BUILD_SHARED_LIBS) # No need to define PNG_USE_DLL here, because it's default for Cygwin. else() set (PNG_DEFINITIONS -DPNG_STATIC) endif() endif () endif () if (PNG_PNG_INCLUDE_DIR AND EXISTS "${PNG_PNG_INCLUDE_DIR}/png.h") file(STRINGS "${PNG_PNG_INCLUDE_DIR}/png.h" png_version_str REGEX "^#define[ \t]+PNG_LIBPNG_VER_STRING[ \t]+\".+\"") string(REGEX REPLACE "^#define[ \t]+PNG_LIBPNG_VER_STRING[ \t]+\"([^\"]+)\".*" "\\1" PNG_VERSION_STRING "${png_version_str}") unset(png_version_str) endif () endif() # handle the QUIETLY and REQUIRED arguments and set PNG_FOUND to TRUE if # all listed variables are TRUE include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake) find_package_handle_standard_args(PNG REQUIRED_VARS PNG_LIBRARY PNG_PNG_INCLUDE_DIR VERSION_VAR PNG_VERSION_STRING) mark_as_advanced(PNG_PNG_INCLUDE_DIR PNG_LIBRARY ) libgd-gd-2.1.1/cmake/modules/FindPTHREAD.cmake000066400000000000000000000055141245535672000206240ustar00rootroot00000000000000############################################################################# # # $Id: FindPTHREAD.cmake 4056 2013-01-05 13:04:42Z fspindle $ # # This file is part of the ViSP software. # Copyright (C) 2005 - 2013 by INRIA. All rights reserved. # # This software is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # ("GPL") version 2 as published by the Free Software Foundation. # See the file LICENSE.txt at the root directory of this source # distribution for additional information about the GNU GPL. # # For using ViSP with software that can not be combined with the GNU # GPL, please contact INRIA about acquiring a ViSP Professional # Edition License. # # See http://www.irisa.fr/lagadic/visp/visp.html for more information. # # This software was developed at: # INRIA Rennes - Bretagne Atlantique # Campus Universitaire de Beaulieu # 35042 Rennes Cedex # France # http://www.irisa.fr/lagadic # # If you have questions regarding the use of this file, please contact # INRIA at visp@inria.fr # # This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE # WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. # # Description: # Try to find pthread library. # Once run this will define: # # PTHREAD_FOUND # PTHREAD_INCLUDE_DIRS # PTHREAD_LIBRARIES # # Authors: # Fabien Spindler # ############################################################################# FIND_PATH(PTHREAD_INCLUDE_DIR pthread.h "$ENV{PTHREAD_HOME}/include" "$ENV{PTHREAD_DIR}/include" /usr/include "C:/MinGW/include" ) #MESSAGE("DBG PTHREAD_INCLUDE_DIR=${PTHREAD_INCLUDE_DIR}") # pthreadVSE pthreadGCE pthreadGC pthreadVC1 pthreadVC2 are comming from web FIND_LIBRARY(PTHREAD_LIBRARY NAMES pthread pthreadGC2 pthreadVSE pthreadGCE pthreadGC pthreadVC1 pthreadVC2 PATHS "$ENV{PTHREAD_HOME}/lib" "$ENV{PTHREAD_DIR}/lib" /usr/lib /usr/local/lib /lib "C:/MinGW/lib" ) #MESSAGE(STATUS "DBG PTHREAD_LIBRARY=${PTHREAD_LIBRARY}") ## -------------------------------- IF(PTHREAD_LIBRARY) SET(PTHREAD_LIBRARIES ${PTHREAD_LIBRARY}) ELSE(PTHREAD_LIBRARY) #MESSAGE(SEND_ERROR "pthread library not found.") ENDIF(PTHREAD_LIBRARY) IF(NOT PTHREAD_INCLUDE_DIR) #MESSAGE(SEND_ERROR "pthread include dir not found.") ENDIF(NOT PTHREAD_INCLUDE_DIR) IF(PTHREAD_LIBRARIES AND PTHREAD_INCLUDE_DIR) SET(PTHREAD_INCLUDE_DIRS ${PTHREAD_INCLUDE_DIR}) SET(PTHREAD_FOUND TRUE) ELSE(PTHREAD_LIBRARIES AND PTHREAD_INCLUDE_DIR) SET(PTHREAD_FOUND FALSE) ENDIF(PTHREAD_LIBRARIES AND PTHREAD_INCLUDE_DIR) MARK_AS_ADVANCED( PTHREAD_INCLUDE_DIR PTHREAD_LIBRARY ) #MESSAGE(STATUS "PTHREAD_FOUND : ${PTHREAD_FOUND}") libgd-gd-2.1.1/cmake/modules/FindPackageHandleStandardArgs.cmake000066400000000000000000000314211245535672000244760ustar00rootroot00000000000000# FIND_PACKAGE_HANDLE_STANDARD_ARGS( ... ) # # This function is intended to be used in FindXXX.cmake modules files. # It handles the REQUIRED, QUIET and version-related arguments to find_package(). # It also sets the _FOUND variable. # The package is considered found if all variables ... listed contain # valid results, e.g. valid filepaths. # # There are two modes of this function. The first argument in both modes is # the name of the Find-module where it is called (in original casing). # # The first simple mode looks like this: # FIND_PACKAGE_HANDLE_STANDARD_ARGS( (DEFAULT_MSG|"Custom failure message") ... ) # If the variables to are all valid, then _FOUND # will be set to TRUE. # If DEFAULT_MSG is given as second argument, then the function will generate # itself useful success and error messages. You can also supply a custom error message # for the failure case. This is not recommended. # # The second mode is more powerful and also supports version checking: # FIND_PACKAGE_HANDLE_STANDARD_ARGS(NAME [REQUIRED_VARS ...] # [VERSION_VAR ] # [HANDLE_COMPONENTS] # [CONFIG_MODE] # [FAIL_MESSAGE "Custom failure message"] ) # # As above, if through are all valid, _FOUND # will be set to TRUE. # After REQUIRED_VARS the variables which are required for this package are listed. # Following VERSION_VAR the name of the variable can be specified which holds # the version of the package which has been found. If this is done, this version # will be checked against the (potentially) specified required version used # in the find_package() call. The EXACT keyword is also handled. The default # messages include information about the required version and the version # which has been actually found, both if the version is ok or not. # If the package supports components, use the HANDLE_COMPONENTS option to enable # handling them. In this case, find_package_handle_standard_args() will report # which components have been found and which are missing, and the _FOUND # variable will be set to FALSE if any of the required components (i.e. not the # ones listed after OPTIONAL_COMPONENTS) are missing. # Use the option CONFIG_MODE if your FindXXX.cmake module is a wrapper for # a find_package(... NO_MODULE) call. In this case VERSION_VAR will be set # to _VERSION and the macro will automatically check whether the # Config module was found. # Via FAIL_MESSAGE a custom failure message can be specified, if this is not # used, the default message will be displayed. # # Example for mode 1: # # FIND_PACKAGE_HANDLE_STANDARD_ARGS(LibXml2 DEFAULT_MSG LIBXML2_LIBRARY LIBXML2_INCLUDE_DIR) # # LibXml2 is considered to be found, if both LIBXML2_LIBRARY and # LIBXML2_INCLUDE_DIR are valid. Then also LIBXML2_FOUND is set to TRUE. # If it is not found and REQUIRED was used, it fails with FATAL_ERROR, # independent whether QUIET was used or not. # If it is found, success will be reported, including the content of . # On repeated Cmake runs, the same message won't be printed again. # # Example for mode 2: # # FIND_PACKAGE_HANDLE_STANDARD_ARGS(BISON REQUIRED_VARS BISON_EXECUTABLE # VERSION_VAR BISON_VERSION) # In this case, BISON is considered to be found if the variable(s) listed # after REQUIRED_VAR are all valid, i.e. BISON_EXECUTABLE in this case. # Also the version of BISON will be checked by using the version contained # in BISON_VERSION. # Since no FAIL_MESSAGE is given, the default messages will be printed. # # Another example for mode 2: # # find_package(Automoc4 QUIET NO_MODULE HINTS /opt/automoc4) # FIND_PACKAGE_HANDLE_STANDARD_ARGS(Automoc4 CONFIG_MODE) # In this case, FindAutmoc4.cmake wraps a call to find_package(Automoc4 NO_MODULE) # and adds an additional search directory for automoc4. # The following FIND_PACKAGE_HANDLE_STANDARD_ARGS() call produces a proper # success/error message. #============================================================================= # Copyright 2007-2009 Kitware, Inc. # # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. include(FindPackageMessage) include(CMakeParseArguments) # internal helper macro macro(_FPHSA_FAILURE_MESSAGE _msg) if (${_NAME}_FIND_REQUIRED) message(FATAL_ERROR "${_msg}") else () if (NOT ${_NAME}_FIND_QUIETLY) message(STATUS "${_msg}") endif () endif () endmacro() # internal helper macro to generate the failure message when used in CONFIG_MODE: macro(_FPHSA_HANDLE_FAILURE_CONFIG_MODE) # _CONFIG is set, but FOUND is false, this means that some other of the REQUIRED_VARS was not found: if(${_NAME}_CONFIG) _FPHSA_FAILURE_MESSAGE("${FPHSA_FAIL_MESSAGE}: missing: ${MISSING_VARS} (found ${${_NAME}_CONFIG} ${VERSION_MSG})") else() # If _CONSIDERED_CONFIGS is set, the config-file has been found, but no suitable version. # List them all in the error message: if(${_NAME}_CONSIDERED_CONFIGS) set(configsText "") list(LENGTH ${_NAME}_CONSIDERED_CONFIGS configsCount) math(EXPR configsCount "${configsCount} - 1") foreach(currentConfigIndex RANGE ${configsCount}) list(GET ${_NAME}_CONSIDERED_CONFIGS ${currentConfigIndex} filename) list(GET ${_NAME}_CONSIDERED_VERSIONS ${currentConfigIndex} version) set(configsText "${configsText} ${filename} (version ${version})\n") endforeach() if (${_NAME}_NOT_FOUND_MESSAGE) set(configsText "${configsText} Reason given by package: ${${_NAME}_NOT_FOUND_MESSAGE}\n") endif() _FPHSA_FAILURE_MESSAGE("${FPHSA_FAIL_MESSAGE} ${VERSION_MSG}, checked the following files:\n${configsText}") else() # Simple case: No Config-file was found at all: _FPHSA_FAILURE_MESSAGE("${FPHSA_FAIL_MESSAGE}: found neither ${_NAME}Config.cmake nor ${_NAME_LOWER}-config.cmake ${VERSION_MSG}") endif() endif() endmacro() function(FIND_PACKAGE_HANDLE_STANDARD_ARGS _NAME _FIRST_ARG) # set up the arguments for CMAKE_PARSE_ARGUMENTS and check whether we are in # new extended or in the "old" mode: set(options CONFIG_MODE HANDLE_COMPONENTS) set(oneValueArgs FAIL_MESSAGE VERSION_VAR) set(multiValueArgs REQUIRED_VARS) set(_KEYWORDS_FOR_EXTENDED_MODE ${options} ${oneValueArgs} ${multiValueArgs} ) list(FIND _KEYWORDS_FOR_EXTENDED_MODE "${_FIRST_ARG}" INDEX) if(${INDEX} EQUAL -1) set(FPHSA_FAIL_MESSAGE ${_FIRST_ARG}) set(FPHSA_REQUIRED_VARS ${ARGN}) set(FPHSA_VERSION_VAR) else() CMAKE_PARSE_ARGUMENTS(FPHSA "${options}" "${oneValueArgs}" "${multiValueArgs}" ${_FIRST_ARG} ${ARGN}) if(FPHSA_UNPARSED_ARGUMENTS) message(FATAL_ERROR "Unknown keywords given to FIND_PACKAGE_HANDLE_STANDARD_ARGS(): \"${FPHSA_UNPARSED_ARGUMENTS}\"") endif() if(NOT FPHSA_FAIL_MESSAGE) set(FPHSA_FAIL_MESSAGE "DEFAULT_MSG") endif() endif() # now that we collected all arguments, process them if("${FPHSA_FAIL_MESSAGE}" STREQUAL "DEFAULT_MSG") set(FPHSA_FAIL_MESSAGE "Could NOT find ${_NAME}") endif() # In config-mode, we rely on the variable _CONFIG, which is set by find_package() # when it successfully found the config-file, including version checking: if(FPHSA_CONFIG_MODE) list(INSERT FPHSA_REQUIRED_VARS 0 ${_NAME}_CONFIG) list(REMOVE_DUPLICATES FPHSA_REQUIRED_VARS) set(FPHSA_VERSION_VAR ${_NAME}_VERSION) endif() if(NOT FPHSA_REQUIRED_VARS) message(FATAL_ERROR "No REQUIRED_VARS specified for FIND_PACKAGE_HANDLE_STANDARD_ARGS()") endif() list(GET FPHSA_REQUIRED_VARS 0 _FIRST_REQUIRED_VAR) string(TOUPPER ${_NAME} _NAME_UPPER) string(TOLOWER ${_NAME} _NAME_LOWER) # collect all variables which were not found, so they can be printed, so the # user knows better what went wrong (#6375) set(MISSING_VARS "") set(DETAILS "") set(${_NAME_UPPER}_FOUND TRUE) # check if all passed variables are valid foreach(_CURRENT_VAR ${FPHSA_REQUIRED_VARS}) if(NOT ${_CURRENT_VAR}) set(${_NAME_UPPER}_FOUND FALSE) set(MISSING_VARS "${MISSING_VARS} ${_CURRENT_VAR}") else() set(DETAILS "${DETAILS}[${${_CURRENT_VAR}}]") endif() endforeach() # component handling unset(FOUND_COMPONENTS_MSG) unset(MISSING_COMPONENTS_MSG) if(FPHSA_HANDLE_COMPONENTS) foreach(comp ${${_NAME}_FIND_COMPONENTS}) if(${_NAME}_${comp}_FOUND) if(NOT DEFINED FOUND_COMPONENTS_MSG) set(FOUND_COMPONENTS_MSG "found components: ") endif() set(FOUND_COMPONENTS_MSG "${FOUND_COMPONENTS_MSG} ${comp}") else() if(NOT DEFINED MISSING_COMPONENTS_MSG) set(MISSING_COMPONENTS_MSG "missing components: ") endif() set(MISSING_COMPONENTS_MSG "${MISSING_COMPONENTS_MSG} ${comp}") if(${_NAME}_FIND_REQUIRED_${comp}) set(${_NAME_UPPER}_FOUND FALSE) set(MISSING_VARS "${MISSING_VARS} ${comp}") endif() endif() endforeach() set(COMPONENT_MSG "${FOUND_COMPONENTS_MSG} ${MISSING_COMPONENTS_MSG}") set(DETAILS "${DETAILS}[c${COMPONENT_MSG}]") endif() # version handling: set(VERSION_MSG "") set(VERSION_OK TRUE) set(VERSION ${${FPHSA_VERSION_VAR}} ) if (${_NAME}_FIND_VERSION) if(VERSION) if(${_NAME}_FIND_VERSION_EXACT) # exact version required if (NOT "${${_NAME}_FIND_VERSION}" VERSION_EQUAL "${VERSION}") set(VERSION_MSG "Found unsuitable version \"${VERSION}\", but required is exact version \"${${_NAME}_FIND_VERSION}\"") set(VERSION_OK FALSE) else () set(VERSION_MSG "(found suitable exact version \"${VERSION}\")") endif () else() # minimum version specified: if ("${${_NAME}_FIND_VERSION}" VERSION_GREATER "${VERSION}") set(VERSION_MSG "Found unsuitable version \"${VERSION}\", but required is at least \"${${_NAME}_FIND_VERSION}\"") set(VERSION_OK FALSE) else () set(VERSION_MSG "(found suitable version \"${VERSION}\", minimum required is \"${${_NAME}_FIND_VERSION}\")") endif () endif() else() # if the package was not found, but a version was given, add that to the output: if(${_NAME}_FIND_VERSION_EXACT) set(VERSION_MSG "(Required is exact version \"${${_NAME}_FIND_VERSION}\")") else() set(VERSION_MSG "(Required is at least version \"${${_NAME}_FIND_VERSION}\")") endif() endif() else () if(VERSION) set(VERSION_MSG "(found version \"${VERSION}\")") endif() endif () if(VERSION_OK) set(DETAILS "${DETAILS}[v${VERSION}(${${_NAME}_FIND_VERSION})]") else() set(${_NAME_UPPER}_FOUND FALSE) endif() # print the result: if (${_NAME_UPPER}_FOUND) FIND_PACKAGE_MESSAGE(${_NAME} "Found ${_NAME}: ${${_FIRST_REQUIRED_VAR}} ${VERSION_MSG} ${COMPONENT_MSG}" "${DETAILS}") else () if(FPHSA_CONFIG_MODE) _FPHSA_HANDLE_FAILURE_CONFIG_MODE() else() if(NOT VERSION_OK) _FPHSA_FAILURE_MESSAGE("${FPHSA_FAIL_MESSAGE}: ${VERSION_MSG} (found ${${_FIRST_REQUIRED_VAR}})") else() _FPHSA_FAILURE_MESSAGE("${FPHSA_FAIL_MESSAGE} (missing: ${MISSING_VARS}) ${VERSION_MSG}") endif() endif() endif () set(${_NAME_UPPER}_FOUND ${${_NAME_UPPER}_FOUND} PARENT_SCOPE) endfunction() libgd-gd-2.1.1/cmake/modules/FindVPX.cmake000066400000000000000000000055051245535672000202120ustar00rootroot00000000000000# - Find the native VPX includes and library # # This module defines # VPX_INCLUDE_DIR, where to find png.h, etc. # VPX_LIBRARIES, the libraries to link against to use VPX. # VPX_DEFINITIONS - You should ADD_DEFINITONS(${VPX_DEFINITIONS}) before compiling code that includes png library files. # VPX_FOUND, If false, do not try to use VPX. # also defined, but not for general use are # VPX_LIBRARY, where to find the VPX library. # # Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. INCLUDE(FindZLIB) SET(VPX_FOUND "NO") SET(VPX_LIBRARY "") FIND_PATH(VPX_INCLUDE_DIR vp8cx.h /usr/local/include/vpx /usr/include/vpx ) SET(VPX_NAMES ${VPX_NAMES} "vpxmt" "libvpx") FIND_LIBRARY(VPX_LIBRARY NAMES ${VPX_NAMES} PATHS "${PROJECT_SOURCE_DIR}/../deps/lib" /usr/lib64 /usr/lib /usr/local/lib ) IF (VPX_LIBRARY AND VPX_INCLUDE_DIR) SET(VPX_INCLUDE_DIR ${VPX_INCLUDE_DIR}) SET(VPX_LIBRARIES ${VPX_LIBRARY}) SET(VPX_FOUND "YES") ENDIF (VPX_LIBRARY AND VPX_INCLUDE_DIR) IF (VPX_FOUND) IF (NOT VPX_FIND_QUIETLY) MESSAGE(STATUS "Found VPX: ${VPX_LIBRARY}") ENDIF (NOT VPX_FIND_QUIETLY) ELSE (VPX_FOUND) IF (VPX_FIND_REQUIRED) MESSAGE(FATAL_ERROR "Could not find VPX library") ENDIF (VPX_FIND_REQUIRED) ENDIF (VPX_FOUND) MARK_AS_ADVANCED(VPX_INCLUDE_DIR VPX_LIBRARY ) SET(VPX_LIBRARIES ${VPX_LIBRARY}) libgd-gd-2.1.1/cmake/modules/FindXPM.cmake000066400000000000000000000057001245535672000201760ustar00rootroot00000000000000# - Find the native XPM includes and library # # This module defines # XPM_INCLUDE_DIR, where to find png.h, etc. # XPM_LIBRARIES, the libraries to link against to use XPM. # XPM_DEFINITIONS - You should ADD_DEFINITONS(${XPM_DEFINITIONS}) before compiling code that includes png library files. # XPM_FOUND, If false, do not try to use XPM. # also defined, but not for general use are # XPM_LIBRARY, where to find the XPM library. # Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are # met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # * Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # * The names of Kitware, Inc., the Insight Consortium, or the names of # any consortium members, or of any contributors, may not be used to # endorse or promote products derived from this software without # specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS'' # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. SET(XPM_FOUND "NO") FIND_PATH(XPM_XPM_INCLUDE_DIR xpm.h /usr/local/include/X11 /usr/include/X11 ) SET(XPM_NAMES ${XPM_NAMES} Xpm libXpm) FIND_LIBRARY(XPM_LIBRARY NAMES ${XPM_NAMES} PATHS /usr/lib64 /usr/lib /usr/local/lib ) IF (XPM_LIBRARY AND XPM_XPM_INCLUDE_DIR) SET(XPM_INCLUDE_DIR ${XPM_XPM_INCLUDE_DIR}) SET(XPM_LIBRARIES ${XPM_LIBRARY}) SET(XPM_FOUND "YES") IF (CYGWIN) IF(BUILD_SHARED_LIBS) # No need to define XPM_USE_DLL here, because it's default for Cygwin. ELSE(BUILD_SHARED_LIBS) SET (XPM_DEFINITIONS -DXPM_STATIC) ENDIF(BUILD_SHARED_LIBS) ENDIF (CYGWIN) ENDIF (XPM_LIBRARY AND XPM_XPM_INCLUDE_DIR) IF (XPM_FOUND) IF (NOT XPM_FIND_QUIETLY) MESSAGE(STATUS "Found XPM: ${XPM_LIBRARY}") ENDIF (NOT XPM_FIND_QUIETLY) ELSE (XPM_FOUND) IF (XPM_FIND_REQUIRED) MESSAGE(FATAL_ERROR "Could not find XPM library") ENDIF (XPM_FIND_REQUIRED) ENDIF (XPM_FOUND) MARK_AS_ADVANCED(XPM_XPM_INCLUDE_DIR XPM_LIBRARY ) libgd-gd-2.1.1/cmake/modules/TestForHighBitCharacters.c000066400000000000000000000024321245535672000227170ustar00rootroot00000000000000/* * Copyright (C) 2006 Alan W. Irwin * * This file is part of PLplot. * * PLplot is free software; you can redistribute it and/or modify * it under the terms of the GNU Library General Public License as published * by the Free Software Foundation; version 2 of the License. * * PLplot is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with the file PLplot; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #include #if ((' ' & 0x0FF) == 0x020) # define ISLOWER(c) ('a' <= (c) && (c) <= 'z') # define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) #else # define ISLOWER(c) \ (('a' <= (c) && (c) <= 'i') \ || ('j' <= (c) && (c) <= 'r') \ || ('s' <= (c) && (c) <= 'z')) # define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) #endif #define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) int main () { int i; for (i = 0; i < 256; i++) if (XOR (islower (i), ISLOWER (i)) || toupper (i) != TOUPPER (i)) exit(1); exit (0); } libgd-gd-2.1.1/cmake/modules/TestForHighBitCharacters.cmake000066400000000000000000000037261245535672000235640ustar00rootroot00000000000000# cmake/modules/TestForHighBitCharacters.cmake # # Copyright (C) 2006 Alan W. Irwin # # This file is part of PLplot. # # PLplot is free software; you can redistribute it and/or modify # it under the terms of the GNU Library General Public License as published # by the Free Software Foundation; version 2 of the License. # # PLplot is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Library General Public License for more details. # # You should have received a copy of the GNU Library General Public License # along with the file PLplot; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA # Check if ctype.h macros work on characters with the high bit set. if(NOT DEFINED CMAKE_HIGH_BIT_CHARACTERS) message(STATUS "Check for whether ctype.h macros work on characters with the\n" " high bit set." ) try_compile(CMAKE_HIGH_BIT_CHARACTERS ${CMAKE_BINARY_DIR} ${CMAKE_SOURCE_DIR}/CMakeModules/TestForHighBitCharacters.c OUTPUT_VARIABLE OUTPUT) if(CMAKE_HIGH_BIT_CHARACTERS) message(STATUS "High-bit characters - work") set(HIGH_BIT_CHARACTERS 1 CACHE INTERNAL "Do ctype.h macros work on high-bit characters") file(APPEND ${CMAKE_BINARY_DIR}/CMakeFiles/CMakeOutput.log "Determining if ctype.h macros work on high-bit characters passed with " "the following output:\n${OUTPUT}\n\n") else(CMAKE_HIGH_BIT_CHARACTERS) message(STATUS "High-bit characters - don't work") set(HIGH_BIT_CHARACTERS 0 CACHE INTERNAL "Do ctype.h macros work on high-bit characters") file(APPEND ${CMAKE_BINARY_DIR}/CMakeFiles/CMakeError.log "Determining if ctype.h macros work on high-bit characters failed with " "the following output:\n${OUTPUT}\n\n") endif(CMAKE_HIGH_BIT_CHARACTERS) endif(NOT DEFINED CMAKE_HIGH_BIT_CHARACTERS) libgd-gd-2.1.1/cmake/modules/TestForStandardHeaderwait.cmake000066400000000000000000000025071245535672000240000ustar00rootroot00000000000000# cmake/modules/CheckHEADER_SYS_WAIT.cmake # # Copyright (C) 2006 Alan W. Irwin # # This file is part of PLplot. # # PLplot is free software; you can redistribute it and/or modify # it under the terms of the GNU Library General Public License as published # by the Free Software Foundation; version 2 of the License. # # PLplot is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Library General Public License for more details. # # You should have received a copy of the GNU Library General Public License # along with the file PLplot; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA # # - Check for sys/wait.h that is POSIX.1 compatible following autotools # AC_HEADER_SYS_WAIT include(CheckCSourceCompiles) set(_CHECK_HEADER_SYS_WAIT_SOURCE_CODE " #include #include #ifndef WEXITSTATUS # define WEXITSTATUS(stat_val) ((unsigned)(stat_val) >> 8) #endif #ifndef WIFEXITED # define WIFEXITED(stat_val) (((stat_val) & 255) == 0) #endif int main () { int s; wait (&s); s = WIFEXITED (s) ? WEXITSTATUS (s) : 1; ; return 0; } ") check_c_source_compiles( "${_CHECK_HEADER_SYS_WAIT_SOURCE_CODE}" HAVE_SYS_WAIT_H) libgd-gd-2.1.1/cmake/modules/gd.cmake000066400000000000000000000001151245535672000173160ustar00rootroot00000000000000option(BUILD_TEST "Compile examples in the build tree and enable ctest" OFF) libgd-gd-2.1.1/config/000077500000000000000000000000001245535672000144425ustar00rootroot00000000000000libgd-gd-2.1.1/config/Makefile.am000066400000000000000000000003141245535672000164740ustar00rootroot00000000000000## Process this file with automake to produce Makefile.in -*-Makefile-*- EXTRA_DIST = gdlib-config.in gdlib.pc.in bin_SCRIPTS = gdlib-config pkgconfigdir = $(libdir)/pkgconfig pkgconfig_DATA = gdlib.pc libgd-gd-2.1.1/config/config.rpath000066400000000000000000000444351245535672000167610ustar00rootroot00000000000000#! /bin/sh # Output a system dependent set of variables, describing how to set the # run time search path of shared libraries in an executable. # # Copyright 1996-2012 Free Software Foundation, Inc. # Taken from GNU libtool, 2001 # Originally by Gordon Matzigkeit , 1996 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # # The first argument passed to this file is the canonical host specification, # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # The environment variables CC, GCC, LDFLAGS, LD, with_gnu_ld # should be set by the caller. # # The set of defined variables is at the end of this script. # Known limitations: # - On IRIX 6.5 with CC="cc", the run time search patch must not be longer # than 256 bytes, otherwise the compiler driver will dump core. The only # known workaround is to choose shorter directory names for the build # directory and/or the installation directory. # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a shrext=.so host="$1" host_cpu=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` host_vendor=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` host_os=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` # Code taken from libtool.m4's _LT_CC_BASENAME. for cc_temp in $CC""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done cc_basename=`echo "$cc_temp" | sed -e 's%^.*/%%'` # Code taken from libtool.m4's _LT_COMPILER_PIC. wl= if test "$GCC" = yes; then wl='-Wl,' else case "$host_os" in aix*) wl='-Wl,' ;; mingw* | cygwin* | pw32* | os2* | cegcc*) ;; hpux9* | hpux10* | hpux11*) wl='-Wl,' ;; irix5* | irix6* | nonstopux*) wl='-Wl,' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu) case $cc_basename in ecc*) wl='-Wl,' ;; icc* | ifort*) wl='-Wl,' ;; lf95*) wl='-Wl,' ;; nagfor*) wl='-Wl,-Wl,,' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) wl='-Wl,' ;; ccc*) wl='-Wl,' ;; xl* | bgxl* | bgf* | mpixl*) wl='-Wl,' ;; como) wl='-lopt=' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ F* | *Sun*Fortran*) wl= ;; *Sun\ C*) wl='-Wl,' ;; esac ;; esac ;; newsos6) ;; *nto* | *qnx*) ;; osf3* | osf4* | osf5*) wl='-Wl,' ;; rdos*) ;; solaris*) case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) wl='-Qoption ld ' ;; *) wl='-Wl,' ;; esac ;; sunos4*) wl='-Qoption ld ' ;; sysv4 | sysv4.2uw2* | sysv4.3*) wl='-Wl,' ;; sysv4*MP*) ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) wl='-Wl,' ;; unicos*) wl='-Wl,' ;; uts4*) ;; esac fi # Code taken from libtool.m4's _LT_LINKER_SHLIBS. hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_direct=no hardcode_minus_L=no case "$host_os" in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test "$GCC" != yes; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd*) with_gnu_ld=no ;; esac ld_shlibs=yes if test "$with_gnu_ld" = yes; then # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. # Unlike libtool, we use -rpath here, not --rpath, since the documented # option of GNU ld is called -rpath, not --rpath. hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' case "$host_os" in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test "$host_cpu" != ia64; then ld_shlibs=no fi ;; amigaos*) case "$host_cpu" in powerpc) ;; m68k) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then : else ld_shlibs=no fi ;; haiku*) ;; interix[3-9]*) hardcode_direct=no hardcode_libdir_flag_spec='${wl}-rpath,$libdir' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; netbsd*) ;; solaris*) if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then ld_shlibs=no elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs=no ;; *) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' else ld_shlibs=no fi ;; esac ;; sunos4*) hardcode_direct=yes ;; *) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; esac if test "$ld_shlibs" = no; then hardcode_libdir_flag_spec= fi else case "$host_os" in aix3*) # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test "$GCC" = yes; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # need to do runtime linking. case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then aix_use_runtimelinking=yes break fi done ;; esac fi hardcode_direct=yes hardcode_libdir_separator=':' if test "$GCC" = yes; then case $host_os in aix4.[012]|aix4.[012].*) collect2name=`${CC} -print-prog-name=collect2` if test -f "$collect2name" && \ strings "$collect2name" | grep resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct=unsupported hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac fi # Begin _LT_AC_SYS_LIBPATH_AIX. echo 'int main () { return 0; }' > conftest.c ${CC} ${LDFLAGS} conftest.c -o conftest aix_libpath=`dump -H conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } }'` if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } }'` fi if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib" fi rm -f conftest.c conftest # End _LT_AC_SYS_LIBPATH_AIX. if test "$aix_use_runtimelinking" = yes; then hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" else if test "$host_cpu" = ia64; then hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' else hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" fi fi ;; amigaos*) case "$host_cpu" in powerpc) ;; m68k) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. hardcode_libdir_flag_spec=' ' libext=lib ;; darwin* | rhapsody*) hardcode_direct=no if { case $cc_basename in ifort*) true;; *) test "$GCC" = yes;; esac; }; then : else ld_shlibs=no fi ;; dgux*) hardcode_libdir_flag_spec='-L$libdir' ;; freebsd2.2*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; freebsd2*) hardcode_direct=yes hardcode_minus_L=yes ;; freebsd* | dragonfly*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; hpux9*) hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; hpux10*) if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes fi ;; hpux11*) if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no ;; *) hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; netbsd*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; newsos6) hardcode_direct=yes hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; *nto* | *qnx*) ;; openbsd*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then hardcode_libdir_flag_spec='${wl}-rpath,$libdir' else case "$host_os" in openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) hardcode_libdir_flag_spec='-R$libdir' ;; *) hardcode_libdir_flag_spec='${wl}-rpath,$libdir' ;; esac fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; osf3*) hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) if test "$GCC" = yes; then hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' else # Both cc and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi hardcode_libdir_separator=: ;; solaris*) hardcode_libdir_flag_spec='-R$libdir' ;; sunos4*) hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes ;; sysv4) case $host_vendor in sni) hardcode_direct=yes # is this really true??? ;; siemens) hardcode_direct=no ;; motorola) hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac ;; sysv4.3*) ;; sysv4*MP*) if test -d /usr/nec; then ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) ;; sysv5* | sco3.2v5* | sco5v6*) hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' hardcode_libdir_separator=':' ;; uts4*) hardcode_libdir_flag_spec='-L$libdir' ;; *) ld_shlibs=no ;; esac fi # Check dynamic linker characteristics # Code taken from libtool.m4's _LT_SYS_DYNAMIC_LINKER. # Unlike libtool.m4, here we don't care about _all_ names of the library, but # only about the one the linker finds when passed -lNAME. This is the last # element of library_names_spec in libtool.m4, or possibly two of them if the # linker has special search rules. library_names_spec= # the last element of library_names_spec in libtool.m4 libname_spec='lib$name' case "$host_os" in aix3*) library_names_spec='$libname.a' ;; aix[4-9]*) library_names_spec='$libname$shrext' ;; amigaos*) case "$host_cpu" in powerpc*) library_names_spec='$libname$shrext' ;; m68k) library_names_spec='$libname.a' ;; esac ;; beos*) library_names_spec='$libname$shrext' ;; bsdi[45]*) library_names_spec='$libname$shrext' ;; cygwin* | mingw* | pw32* | cegcc*) shrext=.dll library_names_spec='$libname.dll.a $libname.lib' ;; darwin* | rhapsody*) shrext=.dylib library_names_spec='$libname$shrext' ;; dgux*) library_names_spec='$libname$shrext' ;; freebsd* | dragonfly*) case "$host_os" in freebsd[123]*) library_names_spec='$libname$shrext$versuffix' ;; *) library_names_spec='$libname$shrext' ;; esac ;; gnu*) library_names_spec='$libname$shrext' ;; haiku*) library_names_spec='$libname$shrext' ;; hpux9* | hpux10* | hpux11*) case $host_cpu in ia64*) shrext=.so ;; hppa*64*) shrext=.sl ;; *) shrext=.sl ;; esac library_names_spec='$libname$shrext' ;; interix[3-9]*) library_names_spec='$libname$shrext' ;; irix5* | irix6* | nonstopux*) library_names_spec='$libname$shrext' case "$host_os" in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= ;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 ;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 ;; *) libsuff= shlibsuff= ;; esac ;; esac ;; linux*oldld* | linux*aout* | linux*coff*) ;; linux* | k*bsd*-gnu | kopensolaris*-gnu) library_names_spec='$libname$shrext' ;; knetbsd*-gnu) library_names_spec='$libname$shrext' ;; netbsd*) library_names_spec='$libname$shrext' ;; newsos6) library_names_spec='$libname$shrext' ;; *nto* | *qnx*) library_names_spec='$libname$shrext' ;; openbsd*) library_names_spec='$libname$shrext$versuffix' ;; os2*) libname_spec='$name' shrext=.dll library_names_spec='$libname.a' ;; osf3* | osf4* | osf5*) library_names_spec='$libname$shrext' ;; rdos*) ;; solaris*) library_names_spec='$libname$shrext' ;; sunos4*) library_names_spec='$libname$shrext$versuffix' ;; sysv4 | sysv4.3*) library_names_spec='$libname$shrext' ;; sysv4*MP*) library_names_spec='$libname$shrext' ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) library_names_spec='$libname$shrext' ;; tpf*) library_names_spec='$libname$shrext' ;; uts4*) library_names_spec='$libname$shrext' ;; esac sed_quote_subst='s/\(["`$\\]\)/\\\1/g' escaped_wl=`echo "X$wl" | sed -e 's/^X//' -e "$sed_quote_subst"` shlibext=`echo "$shrext" | sed -e 's,^\.,,'` escaped_libname_spec=`echo "X$libname_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` escaped_library_names_spec=`echo "X$library_names_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` escaped_hardcode_libdir_flag_spec=`echo "X$hardcode_libdir_flag_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` LC_ALL=C sed -e 's/^\([a-zA-Z0-9_]*\)=/acl_cv_\1=/' <&2 fi while test $# -gt 0; do case "$1" in -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;; *) optarg= ;; esac case $1 in --libdir) echo $libdir ;; --includedir) echo $includedir ;; --version) echo @VERSION@ ;; --majorversion) echo @GDLIB_MAJOR@ ;; --minorversion) echo @GDLIB_MINOR@ ;; --revision) echo @GDLIB_REVISION@ ;; --ldflags) echo @LDFLAGS@ ;; --libs) echo -lgd @LIBS@ @LIBICONV@ ;; --cflags|--includes) echo -I@includedir@ ;; --features) echo @FEATURES@ ;; --all) echo "GD library @VERSION@" echo "includedir: $includedir" echo "cflags: -I@includedir@" echo "ldflags: @LDFLAGS@" echo "libs: @LIBS@ @LIBICONV@" echo "libdir: $libdir" echo "features: @FEATURES@" ;; *) usage 1 1>&2 ;; esac shift done libgd-gd-2.1.1/config/gdlib.pc.in000066400000000000000000000003371245535672000164570ustar00rootroot00000000000000prefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ includedir=@includedir@ Name: gd Description: GD graphics library Version: @VERSION@ Cflags: -I${includedir} Libs.private: @LIBS@ @LIBICONV@ Libs: -L${libdir} -lgd libgd-gd-2.1.1/config/getver.pl000077500000000000000000000020171245535672000162760ustar00rootroot00000000000000#!/usr/bin/env perl # Simple script to extract the version number parts from src/gd.h. If # called with the middle word of the version macro, it prints the # value of that macro. If called with no argument, it outputs a # human-readable version string. This must be run in the project # root. It is used by configure.ac and docs/naturaldocs/run_docs.sh. use strict; my $key = shift; my @version_parts = (); open FH, ") { next unless m{version605b5d1778}; next unless /^#define\s+GD_([A-Z0-9]+)_VERSION+\s+(\S+)/; my ($lk, $lv) = ($1, $2); if ($lk eq $key) { chomp $lv; $lv =~ s/"//g; print $lv; # no newline exit(0); # success! } push @version_parts, $lv if (!$key); } close(FH); if (scalar @version_parts == 4) { my $result = join(".", @version_parts[0..2]); $result .= $version_parts[3]; $result =~ s/"//g; print $result; exit(0); } exit(1); # failure libgd-gd-2.1.1/configure.ac000066400000000000000000000301231245535672000154620ustar00rootroot00000000000000# Process this file with autoconf to produce a configure script. # Configure template for gd library AC_PREREQ(2.54) # We extract version numbers from src/versions.h define([gv],[perl config/getver.pl ]$1) m4_define([gd_MAJOR],esyscmd(gv(MAJOR)))dnl m4_define([gd_MINOR],esyscmd(gv(MINOR)))dnl m4_define([gd_REVISION],esyscmd(gv(RELEASE)))dnl m4_define([gd_EXTRA],esyscmd(gv(EXTRA)))dnl m4_define([gd_PKG_VERSION],[gd_MAJOR.gd_MINOR.gd_REVISION]gd_EXTRA)]dnl AC_INIT([GD], gd_PKG_VERSION, [https://bitbucket.org/libgd/gd-libgd/issues], [libgd], [http://lib.gd]) AC_CONFIG_SRCDIR([src/gd.c]) AC_CONFIG_AUX_DIR(config) AC_CONFIG_MACRO_DIR([m4]) AC_CANONICAL_HOST # This is not used anywhere. However, Makefile.netware searches # through configure for these definitions to find the version numbers. # (Assuming anyone still uses Netware, that should be changed to use # gd.h via getver.pl instead.) GDLIB_MAJOR=gd_MAJOR GDLIB_MINOR=gd_MINOR GDLIB_REVISION=gd_REVISION GDLIB_EXTRA=gd_EXTRA GDLIB_VERSION=gd_PKG_VERSION # Dynamic library version information # See http://www.gnu.org/software/libtool/manual/libtool.html#Updating-version-info GDLIB_CURRENT=3 GDLIB_REVISION=0 GDLIB_AGE=0 AC_SUBST(GDLIB_CURRENT) AC_SUBST(GDLIB_REVISION) AC_SUBST(GDLIB_AGE) #Expanded by tests later in this file. TBB 2.0.26 #2.0.28: GIF is standard now. Doesn't depend on anything else, #so we always build it. FEATURES="GD_GIF GD_GIFANIM GD_OPENPOLYGON" AC_SUBST(FEATURES) AM_INIT_AUTOMAKE([foreign dist-bzip2 dist-xz -Wall -Werror subdir-objects]) AC_CONFIG_HEADERS([src/config.h:src/config.hin]) dnl newer automake wants this, but we still want to work with older m4_ifndef([AM_PROG_AR],[m4_define([AM_PROG_AR],[:])]) AM_PROG_AR AC_PROG_CC_STDC AM_PROG_CC_C_O AC_PROG_INSTALL AC_PROG_LIBTOOL AC_PROG_LN_S AC_PROG_MAKE_SET LT_INIT([win32-dll]) PKG_PROG_PKG_CONFIG dnl may be required for freetype and Xpm AC_PATH_X if test -n "$x_includes" && test "x$x_includes" != xNONE ; then CFLAGS="$CFLAGS -I$x_includes" fi if test -n "$x_libraries" && test "x$x_libraries" != xNONE ; then LDFLAGS="$LDFLAGS -L$x_libraries" fi AC_HEADER_STDC AC_CHECK_HEADERS([errno.h limits.h stddef.h stdlib.h string.h unistd.h]) dnl if we're configuring on a system w/out gettext, don't fall over m4_ifndef([AM_ICONV],[m4_define([AM_ICONV],[:])]) AM_ICONV # if test -n "$LIBICONV" ; then # LIBS="$LIBS $LIBICONV" # fi AC_CHECK_HEADERS(iconv.h, [AC_MSG_CHECKING(whether iconv.h defines iconv_t) AC_EGREP_HEADER([typedef.*iconv_t],iconv.h, [AC_MSG_RESULT(yes) AC_DEFINE(HAVE_ICONV_T_DEF, 1, [Define if defines iconv_t.])], AC_MSG_RESULT(no))]) # Checks for typedefs, structures, and compiler characteristics. #AC_C_CONST #AC_TYPE_SIZE_T # Checks for library functions. #AC_FUNC_ERROR_AT_LINE #AC_FUNC_MALLOC #AC_FUNC_REALLOC #AC_FUNC_VPRINTF #AC_CHECK_FUNCS([floor memset sqrt strchr strdup strtol]) dnl do we need to specify -lm explicitly? AC_CHECK_FUNC(sin,,[AC_CHECK_LIB(m,sin)]) dnl zlib is required AC_ARG_WITH(zlib, [ --with-zlib=DIR where to find the zlib library]) if test "$with_zlib" != no; then AC_CHECK_LIB(z,deflate, [LIBS="-lz $LIBS" AC_DEFINE(HAVE_LIBZ, 1, [Define if you have zlib.]) with_zlib=yes], [AC_MSG_WARN([zlib is required - see http://www.gzip.org/zlib/]) with_zlib=no]) fi AM_CONDITIONAL([HAVE_LIBZ], test "$with_zlib" = yes) dnl libpng is required AC_ARG_WITH(png,dnl [ --with-png=DIR where to find the png library]) case $with_png in no) ;; yes|"") PKG_CHECK_MODULES([LIBPNG], libpng, [ with_png=yes ],[ if test "$with_png" = yes; then AC_MSG_ERROR([png support requested, but not found - see http://www.libpng.org/pub/png/]) fi with_png=no ]) ;; *) AC_MSG_CHECKING([libpng-config script]) LIBPNG_CONFIG=$with_png/bin/libpng-config if test -e "$LIBPNG_CONFIG"; then LIBPNG_CFLAGS=`$LIBPNG_CONFIG --cflags` LIBPNG_LIBS=`$LIBPNG_CONFIG --ldflags` with_png=yes AC_MSG_RESULT([$LIBPNG_CONFIG, cflags: $LIBPNG_CFLAGS, libs: $LIBPNG_LIBS]) else AC_MSG_ERROR([png support requested, but not found at requested location: $LIBPNG_CONFIG]) fi ;; esac if test "$with_png" != no; then CPPFLAGS="$CPPFLAGS $LIBPNG_CFLAGS" LIBS="$LIBS $LIBPNG_LIBS" FEATURES="GD_PNG $FEATURES" AC_DEFINE(HAVE_LIBPNG, 1, [Define if you have the png library.]) fi AM_CONDITIONAL([HAVE_LIBPNG], test "$with_png" = yes) dnl FreeType configure tests snarfed from libwmf .. AC_ARG_WITH(freetype,dnl [ --with-freetype=DIR where to find the freetype 2.x library]]) case $with_freetype in no) ;; yes|"") dnl All freetype2 versions are numerically much larger than the actual dnl version number you see in the tarball. This is because the number dnl corresponds to the shared library version rather than the release. dnl 9.8.3 is the version that freetype2-2.1.10 used. PKG_CHECK_MODULES([LIBFREETYPE], [freetype2 >= 9.8.3], [ with_freetype=yes ],[ if test "$with_freetype" = yes; then AC_MSG_ERROR([freetype support requested, but not found]) fi with_freetype=no ]) ;; *) FREETYPE_CONFIG=$with_freetype/bin/freetype-config if test -e "$FREETYPE_CONFIG"; then LIBFREETYPE_CFLAGS=`$FREETYPE_CONFIG --cflags` LIBFREETYPE_LIBS=`$FREETYPE_CONFIG --libs` with_freetype=yes else AC_MSG_ERROR([freetype support requested, but not found: $FREETYPE_CONFIG]) fi ;; esac if test "$with_freetype" = yes; then CPPFLAGS="$CPPFLAGS $LIBFREETYPE_CFLAGS" LIBS="$LIBS $LIBFREETYPE_LIBS" FEATURES="GD_FREETYPE $FEATURES" AC_DEFINE(HAVE_LIBFREETYPE, 1, [Define if you have the freetype library.]) AC_DEFINE(HAVE_FT2BUILD_H, 1, [Define if you have the ft2build.h header.]) fi AM_CONDITIONAL([HAVE_LIBFREETYPE], test "$with_freetype" = yes) dnl check for libfontconfig by default AC_ARG_WITH(fontconfig,dnl [ --with-fontconfig=DIR where to find the fontconfig library]) case $with_fontconfig in no) ;; yes|"") PKG_CHECK_MODULES([LIBFONTCONFIG], fontconfig, [with_fontconfig=yes], [ if test "$with_fontconfig" = yes; then AC_MSG_ERROR([fontconfig support requested, but not found]) fi with_fontconfig=no ]) ;; *) save_LIBS="$LIBS" save_CPPFLAGS="$CPPFLAGS" if test -d "$with_fontconfig"; then LIBFONTCONFIG_CFLAGS="-I$with_fontconfig/include" LIBFONTCONFIG_LIBS="-L$with_fontconfig/lib" fi CPPFLAGS="$CPPFLAGS $LIBFONTCONFIG_CFLAGS" LIBS="$LIBS $LIBFONTCONFIG_LIBS" AC_CHECK_LIB(fontconfig, FcInit, [ LIBFONTCONFIG_LIBS="$LIBFONTCONFIG_LIBS -lfontconfig" with_fontconfig=yes ],[ if test "$with_fontconfig" != ""; then AC_MSG_ERROR([fontconfig support requested, but not found]) else with_fontconfig=no fi ]) CPPFLAGS="$save_CPPFLAGS" LIBS="$save_LIBS" ;; esac if test "$with_fontconfig" != no; then CPPFLAGS="$CPPFLAGS $LIBFONTCONFIG_CFLAGS" LIBS="$LIBS $LIBFONTCONFIG_LIBS -lfontconfig" FEATURES="GD_FONTCONFIG $FEATURES" AC_DEFINE(HAVE_LIBFONTCONFIG, 1, [ Define if you have the fontconfig library. ]) fi AM_CONDITIONAL([HAVE_LIBFONTCONFIG], test "$with_fontconfig" = yes) dnl check for libjpeg by default AC_ARG_WITH(jpeg,dnl [ --with-jpeg=DIR where to find the jpeg library], [if test -d "$withval"; then LDFLAGS="$LDFLAGS -L$withval/lib" CFLAGS="$CFLAGS -I$withval/include" fi], withval=yes) if test "$withval" != no; then AC_CHECK_LIB(jpeg,jpeg_set_defaults, [LIBS="-ljpeg $LIBS" FEATURES="GD_JPEG $FEATURES" AC_DEFINE(HAVE_LIBJPEG, 1, [ Define if you have the jpeg library. ])]) else ac_cv_lib_jpeg_jpeg_set_defaults=no fi AM_CONDITIONAL([HAVE_LIBJPEG], test "$ac_cv_lib_jpeg_jpeg_set_defaults" = yes) dnl check for libXpm by default AC_ARG_WITH(xpm,dnl [ --with-xpm=DIR where to find the xpm library]) case $with_xpm in no) ;; yes|"") PKG_CHECK_MODULES([LIBXPM], xpm, [with_xpm=yes], [ if test "$with_xpm" = yes; then AC_MSG_ERROR([Xpm support requested, but not found]) fi with_xpm=no ]) ;; *) save_LIBS="$LIBS" save_CPPFLAGS="$CPPFLAGS" if test -d "$with_xpm"; then LIBXPM_CFLAGS="-I$with_xpm/include" LIBXPM_LIBS="-L$with_xpm/lib -lXpm" fi CPPFLAGS="$CPPFLAGS $LIBXPM_CFLAGS" LIBS="$LIBS $LIBXPM_LIBS" AC_CHECK_LIB(Xpm,XpmReadFileToXpmImage, [ if test -z "$LIBXPM_LIBS"; then LIBXPM_LIBS="-lXpm" fi with_xpm=yes ],[ if test "$with_xpm" != ""; then AC_MSG_ERROR([Xpm support requested, but not found]) else with_xpm=no fi ]) CPPFLAGS="$save_CPPFLAGS" LIBS="$save_LIBS" ;; esac if test "$with_xpm" != no; then CPPFLAGS="$CPPFLAGS $LIBXPM_CFLAGS" LIBS="$LIBS $LIBXPM_LIBS" FEATURES="GD_XPM $FEATURES" AC_DEFINE(HAVE_LIBXPM, 1, [ Define if you have the Xpm library. ]) fi AM_CONDITIONAL([HAVE_LIBXPM], test "$with_xpm" = yes) dnl check for libvpx by default AC_ARG_WITH(vpx,dnl [ --with-vpx=DIR where to find the vpx library]) case $with_vpx in no) ;; yes|"") PKG_CHECK_MODULES([LIBVPX], vpx, [with_vpx=yes], [ PKG_CHECK_MODULES([LIBVPX], libvpx, [with_vpx=yes], [ if test "$with_vpx" = yes; then AC_MSG_ERROR([VPX support requested, but not found]) fi with_vpx=no ]) ]) ;; *) save_LIBS="$LIBS" save_CPPFLAGS="$CPPFLAGS" if test -d "$with_vpx"; then LIBVPX_CFLAGS="-I$with_vpx/include" LIBVPX_LIBS="-L$with_vpx/lib -lvpx" fi CPPFLAGS="$CPPFLAGS $LIBVPX_CFLAGS" LIBS="$LIBS $LIBVPX_LIBS" AC_CHECK_LIB(vpx,vpx_codec_destroy, [ if test -z "$LIBVPX_LIBS"; then LIBVPX_LIBS="-lvpx" fi with_vpx=yes ],[ if test "$with_vpx" != ""; then AC_MSG_ERROR([vpx support requested, but not found]) else with_vpx=no fi ]) CPPFLAGS="$save_CPPFLAGS" LIBS="$save_LIBS" ;; esac if test "$with_vpx" != no; then CPPFLAGS="$CPPFLAGS $LIBVPX_CFLAGS" LIBS="$LIBS $LIBVPX_LIBS" FEATURES="GD_VPX $FEATURES" AC_DEFINE(HAVE_LIBVPX, 1, [ Define if you have the VPX library. ]) fi AM_CONDITIONAL([HAVE_LIBVPX], test "$with_vpx" = yes) dnl check for libtiff by default AC_ARG_WITH(tiff,dnl [ --with-tiff=DIR where to find the TIFF library]) case $with_tiff in no) ;; yes|"") PKG_CHECK_MODULES([LIBTIFF], libtiff-4, [with_tiff=yes], [ if test "$with_tiff" = yes; then AC_MSG_ERROR([TIFF support requested, but not found]) fi with_tiff=no ]) ;; *) save_CPPFLAGS="$CPPFLAGS" save_LIBS="$LIBS" if test -d "$with_tiff"; then LIBTIFF_CFLAGS="-I$with_tiff/include" LIBTIFF_LIBS="-L$with_tiff/lib" fi CPPFLAGS="$CPPFLAGS $LIBTIFF_CFLAGS" LIBS="$LIBS $LIBTIFF_LIBS" AC_CHECK_LIB(tiff,TIFFClientOpen, [ LIBTIFF_LIBS="$LIBTIFF_LIBS -ltiff" with_tiff=yes ],[ if test "$with_tiff" != ""; then AC_MSG_ERROR([tiff support requested, but not found]) else with_tiff=no fi ]) CPPFLAGS="$save_CPPFLAGS" LIBS="$save_LIBS" ;; esac if test "$with_tiff" != no; then CPPFLAGS="$CPPFLAGS $LIBTIFF_CFLAGS" LIBS="$LIBS $LIBTIFF_LIBS" FEATURES="GD_TIFF $FEATURES" AC_DEFINE(HAVE_LIBTIFF, 1, [ Define if you have the Tiff library. ]) fi AM_CONDITIONAL([HAVE_LIBTIFF], test "$with_tiff" = yes) gl_VISIBILITY() CFLAGS="$CFLAGS $CFLAG_VISIBILITY" AX_PTHREAD() MINGW_AC_WIN32_NATIVE_HOST() if test "$mingw_cv_win32_host" = yes; then AC_DEFINE([BGDWIN32], [], [Define is you are building for Win32 API]) fi dnl report configuration AC_MSG_RESULT([ ** Configuration summary for $PACKAGE $VERSION: Support for Zlib: $with_zlib Support for PNG library: $with_png Support for JPEG library: $ac_cv_lib_jpeg_jpeg_set_defaults Support for VPX library: $with_vpx Support for TIFF library: $with_tiff Support for Freetype 2.x library: $with_freetype Support for Fontconfig library: $with_fontconfig Support for Xpm library: $with_xpm Support for pthreads: $ax_pthread_ok ]) AC_CONFIG_FILES([Makefile src/Makefile tests/Makefile tests/test_config.h config/Makefile config/gdlib-config config/gdlib.pc]) AC_OUTPUT libgd-gd-2.1.1/docs/000077500000000000000000000000001245535672000141255ustar00rootroot00000000000000libgd-gd-2.1.1/docs/INSTALL000066400000000000000000000366001245535672000151630ustar00rootroot00000000000000Installation Instructions ************************* Copyright (C) 1994-1996, 1999-2002, 2004-2011 Free Software Foundation, Inc. Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. This file is offered as-is, without warranty of any kind. Basic Installation ================== Briefly, the shell commands `./configure; make; make install' should configure, build, and install this package. The following more-detailed instructions are generic; see the `README' file for instructions specific to this package. Some packages provide this `INSTALL' file but do not implement all of the features documented below. The lack of an optional feature in a given package is not necessarily a bug. More recommendations for GNU packages can be found in *note Makefile Conventions: (standards)Makefile Conventions. The `configure' shell script attempts to guess correct values for various system-dependent variables used during compilation. It uses those values to create a `Makefile' in each directory of the package. It may also create one or more `.h' files containing system-dependent definitions. Finally, it creates a shell script `config.status' that you can run in the future to recreate the current configuration, and a file `config.log' containing compiler output (useful mainly for debugging `configure'). It can also use an optional file (typically called `config.cache' and enabled with `--cache-file=config.cache' or simply `-C') that saves the results of its tests to speed up reconfiguring. Caching is disabled by default to prevent problems with accidental use of stale cache files. If you need to do unusual things to compile the package, please try to figure out how `configure' could check whether to do them, and mail diffs or instructions to the address given in the `README' so they can be considered for the next release. If you are using the cache, and at some point `config.cache' contains results you don't want to keep, you may remove or edit it. The file `configure.ac' (or `configure.in') is used to create `configure' by a program called `autoconf'. You need `configure.ac' if you want to change it or regenerate `configure' using a newer version of `autoconf'. The simplest way to compile this package is: 1. `cd' to the directory containing the package's source code and type `./configure' to configure the package for your system. Running `configure' might take a while. While running, it prints some messages telling which features it is checking for. 2. Type `make' to compile the package. 3. Optionally, type `make check' to run any self-tests that come with the package, generally using the just-built uninstalled binaries. 4. Type `make install' to install the programs and any data files and documentation. When installing into a prefix owned by root, it is recommended that the package be configured and built as a regular user, and only the `make install' phase executed with root privileges. 5. Optionally, type `make installcheck' to repeat any self-tests, but this time using the binaries in their final installed location. This target does not install anything. Running this target as a regular user, particularly if the prior `make install' required root privileges, verifies that the installation completed correctly. 6. You can remove the program binaries and object files from the source code directory by typing `make clean'. To also remove the files that `configure' created (so you can compile the package for a different kind of computer), type `make distclean'. There is also a `make maintainer-clean' target, but that is intended mainly for the package's developers. If you use it, you may have to get all sorts of other programs in order to regenerate files that came with the distribution. 7. Often, you can also type `make uninstall' to remove the installed files again. In practice, not all packages have tested that uninstallation works correctly, even though it is required by the GNU Coding Standards. 8. Some packages, particularly those that use Automake, provide `make distcheck', which can by used by developers to test that all other targets like `make install' and `make uninstall' work correctly. This target is generally not run by end users. Compilers and Options ===================== Some systems require unusual options for compilation or linking that the `configure' script does not know about. Run `./configure --help' for details on some of the pertinent environment variables. You can give `configure' initial values for configuration parameters by setting variables in the command line or in the environment. Here is an example: ./configure CC=c99 CFLAGS=-g LIBS=-lposix *Note Defining Variables::, for more details. Compiling For Multiple Architectures ==================================== You can compile the package for more than one kind of computer at the same time, by placing the object files for each architecture in their own directory. To do this, you can use GNU `make'. `cd' to the directory where you want the object files and executables to go and run the `configure' script. `configure' automatically checks for the source code in the directory that `configure' is in and in `..'. This is known as a "VPATH" build. With a non-GNU `make', it is safer to compile the package for one architecture at a time in the source code directory. After you have installed the package for one architecture, use `make distclean' before reconfiguring for another architecture. On MacOS X 10.5 and later systems, you can create libraries and executables that work on multiple system types--known as "fat" or "universal" binaries--by specifying multiple `-arch' options to the compiler but only a single `-arch' option to the preprocessor. Like this: ./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ CPP="gcc -E" CXXCPP="g++ -E" This is not guaranteed to produce working output in all cases, you may have to build one architecture at a time and combine the results using the `lipo' tool if you have problems. Installation Names ================== By default, `make install' installs the package's commands under `/usr/local/bin', include files under `/usr/local/include', etc. You can specify an installation prefix other than `/usr/local' by giving `configure' the option `--prefix=PREFIX', where PREFIX must be an absolute file name. You can specify separate installation prefixes for architecture-specific files and architecture-independent files. If you pass the option `--exec-prefix=PREFIX' to `configure', the package uses PREFIX as the prefix for installing programs and libraries. Documentation and other data files still use the regular prefix. In addition, if you use an unusual directory layout you can give options like `--bindir=DIR' to specify different values for particular kinds of files. Run `configure --help' for a list of the directories you can set and what kinds of files go in them. In general, the default for these options is expressed in terms of `${prefix}', so that specifying just `--prefix' will affect all of the other directory specifications that were not explicitly provided. The most portable way to affect installation locations is to pass the correct locations to `configure'; however, many packages provide one or both of the following shortcuts of passing variable assignments to the `make install' command line to change installation locations without having to reconfigure or recompile. The first method involves providing an override variable for each affected directory. For example, `make install prefix=/alternate/directory' will choose an alternate location for all directory configuration variables that were expressed in terms of `${prefix}'. Any directories that were specified during `configure', but not in terms of `${prefix}', must each be overridden at install time for the entire installation to be relocated. The approach of makefile variable overrides for each directory variable is required by the GNU Coding Standards, and ideally causes no recompilation. However, some platforms have known limitations with the semantics of shared libraries that end up requiring recompilation when using this method, particularly noticeable in packages that use GNU Libtool. The second method involves providing the `DESTDIR' variable. For example, `make install DESTDIR=/alternate/directory' will prepend `/alternate/directory' before all installation names. The approach of `DESTDIR' overrides is not required by the GNU Coding Standards, and does not work on platforms that have drive letters. On the other hand, it does better at avoiding recompilation issues, and works well even when some directory options were not specified in terms of `${prefix}' at `configure' time. Optional Features ================= If the package supports it, you can cause programs to be installed with an extra prefix or suffix on their names by giving `configure' the option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'. Some packages pay attention to `--enable-FEATURE' options to `configure', where FEATURE indicates an optional part of the package. They may also pay attention to `--with-PACKAGE' options, where PACKAGE is something like `gnu-as' or `x' (for the X Window System). The `README' should mention any `--enable-' and `--with-' options that the package recognizes. For packages that use the X Window System, `configure' can usually find the X include and library files automatically, but if it doesn't, you can use the `configure' options `--x-includes=DIR' and `--x-libraries=DIR' to specify their locations. Some packages offer the ability to configure how verbose the execution of `make' will be. For these packages, running `./configure --enable-silent-rules' sets the default to minimal output, which can be overridden with `make V=1'; while running `./configure --disable-silent-rules' sets the default to verbose, which can be overridden with `make V=0'. Particular systems ================== On HP-UX, the default C compiler is not ANSI C compatible. If GNU CC is not installed, it is recommended to use the following options in order to use an ANSI C compiler: ./configure CC="cc -Ae -D_XOPEN_SOURCE=500" and if that doesn't work, install pre-built binaries of GCC for HP-UX. HP-UX `make' updates targets which have the same time stamps as their prerequisites, which makes it generally unusable when shipped generated files such as `configure' are involved. Use GNU `make' instead. On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot parse its `' header file. The option `-nodtk' can be used as a workaround. If GNU CC is not installed, it is therefore recommended to try ./configure CC="cc" and if that doesn't work, try ./configure CC="cc -nodtk" On Solaris, don't put `/usr/ucb' early in your `PATH'. This directory contains several dysfunctional programs; working variants of these programs are available in `/usr/bin'. So, if you need `/usr/ucb' in your `PATH', put it _after_ `/usr/bin'. On Haiku, software installed for all users goes in `/boot/common', not `/usr/local'. It is recommended to use the following options: ./configure --prefix=/boot/common Specifying the System Type ========================== There may be some features `configure' cannot figure out automatically, but needs to determine by the type of machine the package will run on. Usually, assuming the package is built to be run on the _same_ architectures, `configure' can figure that out, but if it prints a message saying it cannot guess the machine type, give it the `--build=TYPE' option. TYPE can either be a short name for the system type, such as `sun4', or a canonical name which has the form: CPU-COMPANY-SYSTEM where SYSTEM can have one of these forms: OS KERNEL-OS See the file `config.sub' for the possible values of each field. If `config.sub' isn't included in this package, then this package doesn't need to know the machine type. If you are _building_ compiler tools for cross-compiling, you should use the option `--target=TYPE' to select the type of system they will produce code for. If you want to _use_ a cross compiler, that generates code for a platform different from the build platform, you should specify the "host" platform (i.e., that on which the generated programs will eventually be run) with `--host=TYPE'. Sharing Defaults ================ If you want to set default values for `configure' scripts to share, you can create a site shell script called `config.site' that gives default values for variables like `CC', `cache_file', and `prefix'. `configure' looks for `PREFIX/share/config.site' if it exists, then `PREFIX/etc/config.site' if it exists. Or, you can set the `CONFIG_SITE' environment variable to the location of the site script. A warning: not all `configure' scripts look for a site script. Defining Variables ================== Variables not defined in a site shell script can be set in the environment passed to `configure'. However, some packages may run configure again during the build, and the customized values of these variables may be lost. In order to avoid this problem, you should set them in the `configure' command line, using `VAR=value'. For example: ./configure CC=/usr/local2/bin/gcc causes the specified `gcc' to be used as the C compiler (unless it is overridden in the site shell script). Unfortunately, this technique does not work for `CONFIG_SHELL' due to an Autoconf bug. Until the bug is fixed you can use this workaround: CONFIG_SHELL=/bin/bash /bin/bash ./configure CONFIG_SHELL=/bin/bash `configure' Invocation ====================== `configure' recognizes the following options to control how it operates. `--help' `-h' Print a summary of all of the options to `configure', and exit. `--help=short' `--help=recursive' Print a summary of the options unique to this package's `configure', and exit. The `short' variant lists options used only in the top level, while the `recursive' variant lists options also present in any nested packages. `--version' `-V' Print the version of Autoconf used to generate the `configure' script, and exit. `--cache-file=FILE' Enable the cache: use and save the results of the tests in FILE, traditionally `config.cache'. FILE defaults to `/dev/null' to disable caching. `--config-cache' `-C' Alias for `--cache-file=config.cache'. `--quiet' `--silent' `-q' Do not print messages saying which checks are being made. To suppress all normal output, redirect it to `/dev/null' (any error messages will still be shown). `--srcdir=DIR' Look for the package's source code in directory DIR. Usually `configure' can determine that directory automatically. `--prefix=DIR' Use DIR as the installation prefix. *note Installation Names:: for more details, including other options available for fine-tuning the installation locations. `--no-create' `-n' Run the configure checks, but stop before creating any output files. `configure' also accepts some other, not widely useful, options. Run `configure --help' for more details. libgd-gd-2.1.1/docs/INSTALL.Solaris000066400000000000000000000011241245535672000165670ustar00rootroot00000000000000Solaris CAVEATS =============== If you are using GNU iconv library installed in f.e. /opt, you will need to add the header location to CMAKE= in configure invokation to ensure that the system iconv.h header is not used when searching for iconv library. The resulting ./configure invokation would look something like this: MAKE=gmake CC="gcc -m64" ./configure --prefix=/opt/local \ CFLAGS="-I/opt/local/include -DHAVE_ICONV -O2 -fomit-frame-pointer -pipe -m64" \ --with-png=/usr --with-freetype=/opt/local For more information and discussion see: https://bitbucket.org/libgd/gd-libgd/issue/76 libgd-gd-2.1.1/docs/README.CMAKE000066400000000000000000000024231245535672000156250ustar00rootroot00000000000000||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| $Id$ Tobuild GD using CMake, all you need is (add the cmake options if you need any or if the default libs and include paths are not the default) : In a sub directory: $ mkdir bld $ cd bld $ cmake -DBUILD_TEST=1 The available options are: ENABLE_PNG=1 ENABLE_JPEG=1 ENABLE_TIFF=1 ENABLE_FREETYPE=1 ENABLE_FONTCONFIG=1 ENABLE_XPM=1 You can optionnally run our tests suite using: $ ctest . Or if you like to build in the source tree: $ cmake -DBUILD_TEST=1 . $ ctest . Add "-DCMAKE_BUILD_TYPE=DEBUG" if you like to have a debug version. Typical usage with only PNG enabled: This command generates VS7 project files and add some custom libraries and includes directories (libpng in this case): cmake -DCMAKE_GENERATOR="Visual Studio 7 .NET 2003" -DENABLE_PNG=1 -DCMAKE_LIBRARY_PATH=c:\gd_build\gd_deps\lib -DCMAKE_INCLUDE_PATH=c:\gd_build\gd_deps\include c:\libgd_src A typical CMake call to build using the MinGW tools: cmake -G"MinGW Makefiles" -DCMAKE_LIBRARY_PATH=c:\mingw\lib -DCMAKE_INCLUDE_PATH=c:\MinGW\include -DENABLE_JPEG=On -DBUILD_TEST=On -DCMAKE_RELEASE_TYPE=DEBUG ..\libgd_head Given that your MinGW install is under c:\mingw and that you install all libraries using the /usr prefix libgd-gd-2.1.1/docs/README.JPN000066400000000000000000000033741245535672000154420ustar00rootroot00000000000000 gd $B%i%$%V%i%j$GF|K\8lJ8;zNs$r;H$&>e$G$NCm0U;v9`(B $B;32l@5?M(B (ma@yama-ga.com) gd-1.7.0 $B$+$i$O$=$N$^$^$G(B gdImageStringTTF() $B$KBP$7$F(B SJIS encoding $B$N%U%)%s%H$,;HMQ$G$-$^$9!#(B $B"((B Unicode encoding $B$N%U%)%s%H$KBP$7$F$OF|K\8lJ8;zNs$r(B UTF-8 $B$G(B $B;XDj$9$l$PF|K\8l$,I=<($G$-$^$9!#(B $B$D$^$j(B gdImageStringTTF() $B$G(B SJIS encoding $B$N%U%)%s%H$r;XDj$9$k$H(B $BJ8;zNs$OL5>r7o$KF|K\8l$G$"$k$H2rl9g$O!"%3%s%Q%$%k;~$K(B -DJISX0208 $B$rIU$1$F%3%s%Q%$%k$7$F$/$@$5$$!#(B $B$3$&$9$k$H(B gdImageStringTTF() $B$G;XDj$5$l$?J8;zNs$K(B ASCII $B0J30$NJ8;z$,$"$k$H(B $BL5>r7o$KF|K\8lJ8;zNs$G$"$k$H2rl9g$O(B UTF-8 $B$NF|K\8lJ8;zNs$r07$($J$/$J$j$^$9$N$G!"(B $B$4MxMQ$N4D6-Ey$K1~$8$F(B -DJISX0208 $B$rIU$1$k$+H]$+$r7h$a$F$/$@$5$$!#(B $B4A;z%3!<%I$NJQ49$K(B OS $BIUB0$N(B iconv() $B$r;H$&>l9g$O(B CFLAGS $B$K(B -DHAVE_ICONV $B$rIU$1$F%3%s%Q%$%k$7$F$/$@$5$$!#(B $B$3$N>l9g$K(B -DHAVE_STDARG_H $B$H(B -DHAVE_ERRNO_H $B$bIU$1$F$*$/$H(B $B4A;z%3!<%IJQ49$N:]$K%(%i!<$,H/@8$7$?>l9g$KE,@Z$J%a%C%;!<%8$r(B $BI=<($9$k$h$&$K$J$j$^$9!#(B $B!y(B EUC $B$+(B SJIS $B$+H=JL$G$-$J$+$C$?>l9g$N4A;z%3!<%I$NH=JLJ}K!(B (1) $B4D6-JQ?t(B LC_ALL, LC_CTYPE, LANG $B$r$3$N=gHV$G%A%'%C%/$9$k(B (2) $B4D6-JQ?t$+$i$bH=JL$G$-$J$+$C$?>l9g$O(B UNIX $B$J$i$P(B EUC$B!"(B Win32 $B$J$i$P(B SJIS $B$H8+$J$9(B $B%3%s%Q%$%k;~$K(B -DSJISPRE $B$rIU$1$F%3%s%Q%$%k$9$l$P!"(BUNIX $B$G$"$C$F$b(B SJIS $B$rM%@h$9$k$h$&$K$J$j$^$9!#(B libgd-gd-2.1.1/docs/README.TESTING000066400000000000000000000035611245535672000161260ustar00rootroot00000000000000||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| To run the tests suite, all you need is (add the cmake options if you need any or if the default libs and include paths are not the default) : In a sub directory: $ mkdir bld $ cd bld $ cmake -DBUILD_TEST=1 .. $ ctest . Or if you like to build in the source tree: $ cmake -DBUILD_TEST=1 . $ ctest . Add "-DCMAKE_BUILD_TYPE=DEBUG" if you like to have a debug version. If you like to run the tests against a installed GD library, set the following environment variables: export CMAKE_INCLUDE_PATH=/path/to/the/gd/include export CMAKE_LIBRARY_PATH=/path/to/the/gd/lib then call cmake using: $ cmake -DUSE_EXT_GD=1 -DBUILD_TEST=1 $ make and finally: $ ctest . I will certainly add a nice CMake option to give prefix later. What to do if tests fail on your platform and you use the last GD release? either from your favourite distributions or from http://www.libgd.org or git? If you use a packaged version of the GD Library (installed from RPM, deb or ports, gentoo packages or any other packages format or distribution), please try to run the tests using the source releases available at: http://www.libgd.org/Downloads If the tests fail using our source release, please report a bug here: http://bugs.libgd.org You can attach the two files available in: ./Testing/Temporary Later versions will have an automatic post mode. If the tests run successfully, please report a bug to the maintainer of the packages (debian, bsd, ubuntu or whoever is responsible for the packages). Reasons of failures: Exception: SegFault: self explaining Failed test failed, check the log to know where timeout the default timeout is 5 seconds. Some test may have infinite loops when compiled against old versions of the GD library (esp. 2.0.33 or earlier) libgd-gd-2.1.1/docs/README.TXT000066400000000000000000000033441245535672000154670ustar00rootroot00000000000000For documentation, browse index.html. Quick install guide: If the sources have been fetched from git, run bootstrap.sh [options]. From a released source, use: 1. Type './configure' 2. Type 'make install' Generic configuration instructions are in the file INSTALL. The following 3rd-party libraries will be used by gd if found by configure. While gd will compile and install even without these, we suggest that at least zlib and libpng are installed, and recommend that freetype and jpeg are installed as well: 1. zlib, available from http://www.gzip.org/zlib/ Data compression library 2. libpng, available from http://www.libpng.org/pub/png/ Portable Network Graphics library; requires zlib 3. FreeType 2.x, available from http://www.freetype.org/ Free, high-quality, and portable font engine 4. JPEG library, available from http://www.ijg.org/ Portable JPEG compression/decompression library 5. XPM, available from http://koala.ilog.fr/lehors/xpm.html X Pixmap library If any of these libraries are installed, but not detected by configure, you can use the following command line options: --with-png=DIR Without the DIR argument, configure will check for png header files and libraries in a default location. To switch off png support, use --without-png, or --with-png=no. If the DIR argument is specified, configure tries to find the png header files in DIR/include, and the libraries in DIR/lib. To accommodate OpenBSD ports, DIR/include/libpng is also checked if necessary. --with-freetype=DIR Dto. for freetype 2.x library. The search path for include files is DIR/include/freetype2. --with-jpeg=DIR Dto. for jpeg library. --with-xpm=DIR Dto. for xpm library. --with-tiff=DIR Dto. for TIFF library. libgd-gd-2.1.1/docs/naturaldocs/000077500000000000000000000000001245535672000164445ustar00rootroot00000000000000libgd-gd-2.1.1/docs/naturaldocs/license.txt000066400000000000000000000060521245535672000206320ustar00rootroot00000000000000Title: License Credits and license terms: > In order to resolve any possible confusion regarding the authorship of > gd, the following copyright statement covers all of the authors who > have required such a statement. If you are aware of any oversights in > this copyright notice, please contact Pierre-A. Joye who will be > pleased to correct them. > > Portions copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, > 2002, 2003, 2004 by Cold Spring Harbor Laboratory. Funded under > Grant P41-RR02188 by the National Institutes of Health. > > Portions copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, > 2004 by Boutell.Com, Inc. > > Portions relating to GD2 format copyright 1999, 2000, 2001, 2002, > 2003, 2004 Philip Warner. > > Portions relating to PNG copyright 1999, 2000, 2001, 2002, 2003, > 2004 Greg Roelofs. > > Portions relating to gdttf.c copyright 1999, 2000, 2001, 2002, > 2003, 2004 John Ellson (ellson@graphviz.org). > > Portions relating to gdft.c copyright 2001, 2002, 2003, 2004 John > Ellson (ellson@graphviz.org). > > Portions copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007 > Pierre-Alain Joye (pierre@libgd.org). > > Portions relating to JPEG and to color quantization copyright > 2000, 2001, 2002, 2003, 2004, Doug Becker and copyright (C) 1994, > 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004 Thomas > G. Lane. This software is based in part on the work of the > Independent JPEG Group. See the file README-JPEG.TXT for more > information. > > Portions relating to GIF compression copyright 1989 by Jef > Poskanzer and David Rowley, with modifications for thread safety > by Thomas Boutell. > > Portions relating to GIF decompression copyright 1990, 1991, 1993 > by David Koblas, with modifications for thread safety by Thomas > Boutell. > > Portions relating to WBMP copyright 2000, 2001, 2002, 2003, 2004 > Maurice Szmurlo and Johan Van den Brande. > > Portions relating to GIF animations copyright 2004 Jaakko Hyvätti > (jaakko.hyvatti@iki.fi) > > Permission has been granted to copy, distribute and modify gd in > any context without fee, including a commercial application, > provided that this notice is present in user-accessible supporting > documentation. > > This does not affect your ownership of the derived work itself, > and the intent is to assure proper credit for the authors of gd, > not to interfere with your productive use of gd. If you have > questions, ask. "Derived works" includes all programs that utilize > the library. Credit must be given in user-accessible > documentation. > > This software is provided "AS IS." The copyright holders disclaim > all warranties, either express or implied, including but not > limited to implied warranties of merchantability and fitness for a > particular purpose, with respect to this code and accompanying > documentation. > > Although their code does not appear in the current release, the > authors also wish to thank Hutchison Avenue Software Corporation > for their prior contributions. libgd-gd-2.1.1/docs/naturaldocs/nobgd.pl000066400000000000000000000022711245535672000200740ustar00rootroot00000000000000#!/usr/bin/env perl # Copy C source files (i.e. *.[ch]) from $src to $dest, first # stripping out uses of the macro BGD_DECLARE(). A line must # begin with 'BGD_DECLARE' for it to be considered a use. use strict; use warnings; use File::Basename; my ($src, $dest) = @ARGV; die "Invalid arguments: nobgd.pl \n" unless ($src && $dest && -d $src && -d $dest); for my $file (glob("$src/*.c"), glob("$src/*.h")) { do {local $| = 1; print "."}; fixup($file, $dest); } print "\n"; sub fixup { my ($src, $destDir) = @_; my $dest = $destDir . "/" . basename($src); my $content = slurp($src); $content =~ s{^ BGD_DECLARE \( ([^)]+) \)}{$1}gmx; unslurp($dest, $content); } sub slurp { my ($filename) = @_; local $/; # no file separator my $data; open my $fh, "<", $filename or die "Unable to read file '$filename'.\n"; $data = <$fh>; close($fh); return $data; } sub unslurp { my ($filename, $data) = @_; die "Refusing to overwrite file '$filename'\n" if -f $filename; open my $fh, ">", $filename or die "Unable to open '$filename' for writing.\n"; print {$fh} $data or die "Error writing file '$filename'\n"; close ($fh); } libgd-gd-2.1.1/docs/naturaldocs/preamble.txt000066400000000000000000000063511245535672000210010ustar00rootroot00000000000000Title: About LibGD @VERSION@ What is gd?: gd is a graphics library. It allows your code to quickly draw images complete with lines, arcs, text, multiple colors, cut and paste from other images, and flood fills, and write out the result as a PNG or JPEG file. This is particularly useful in World Wide Web applications, where PNG and JPEG are two of the formats accepted for inline images by most browsers. gd is not a paint program. If you are looking for a paint program, you are looking in the wrong place. If you are not a programmer, you are looking in the wrong place, unless you are installing a required library in order to run an application. gd does not provide for every possible desirable graphics operation. It is not necessary or desirable for gd to become a kitchen-sink graphics package, but version 2.0 does include most frequently requested features, including both truecolor and palette images, resampling (smooth resizing of truecolor images) and so forth. gd basics: using gd in your program: gd lets you create PNG or JPEG images on the fly. To use gd in your program, include the file gd.h, and link with the gd library and the other required libraries; the syntax for most Unix flavors is: > -lgd -lpng -lz -ljpeg -lfreetype -lm Assuming that all of these libraries are available. If you want to use the provided simple fonts, include gdfontt.h, gdfonts.h, gdfontmb.h, gdfontl.h and/or gdfontg.h. For more impressive results, install FreeType 2.x and use the gdImageStringFT function. If you are not using the provided Makefile and/or a library-based approach, be sure to include the source modules as well in your project. Here is a short example program. (For a more advanced example, see gddemo.c, included in the distribution. gddemo.c is NOT the same program; it demonstrates additional features!) >/* Bring in gd library functions */ >#include "gd.h" > >/* Bring in standard I/O so we can output the PNG to a file */ >#include > >int main() { > /* Declare the image */ > gdImagePtr im; > /* Declare output files */ > FILE *pngout, *jpegout; > /* Declare color indexes */ > int black; > int white; > > /* Allocate the image: 64 pixels across by 64 pixels tall */ > im = gdImageCreate(64, 64); > > /* Allocate the color black (red, green and blue all minimum). > Since this is the first color in a new image, it will > be the background color. */ > black = gdImageColorAllocate(im, 0, 0, 0); > > /* Allocate the color white (red, green and blue all maximum). */ > white = gdImageColorAllocate(im, 255, 255, 255); > > /* Draw a line from the upper left to the lower right, > using white color index. */ > gdImageLine(im, 0, 0, 63, 63, white); > > /* Open a file for writing. "wb" means "write binary", important > under MSDOS, harmless under Unix. */ > pngout = fopen("test.png", "wb"); > > /* Do the same for a JPEG-format file. */ > jpegout = fopen("test.jpg", "wb"); > > /* Output the image to the disk file in PNG format. */ > gdImagePng(im, pngout); > > /* Output the same image in JPEG format, using the default > JPEG quality setting. */ > gdImageJpeg(im, jpegout, -1); > > /* Close the files. */ > fclose(pngout); > fclose(jpegout); > > /* Destroy the image in memory. */ > gdImageDestroy(im); >} > libgd-gd-2.1.1/docs/naturaldocs/project/000077500000000000000000000000001245535672000201125ustar00rootroot00000000000000libgd-gd-2.1.1/docs/naturaldocs/project/Languages.txt000066400000000000000000000115011245535672000225570ustar00rootroot00000000000000Format: 1.51 # This is the Natural Docs languages file for this project. If you change # anything here, it will apply to THIS PROJECT ONLY. If you'd like to change # something for all your projects, edit the Languages.txt in Natural Docs' # Config directory instead. # You can prevent certain file extensions from being scanned like this: # Ignore Extensions: [extension] [extension] ... #------------------------------------------------------------------------------- # SYNTAX: # # Unlike other Natural Docs configuration files, in this file all comments # MUST be alone on a line. Some languages deal with the # character, so you # cannot put comments on the same line as content. # # Also, all lists are separated with spaces, not commas, again because some # languages may need to use them. # # Language: [name] # Alter Language: [name] # Defines a new language or alters an existing one. Its name can use any # characters. If any of the properties below have an add/replace form, you # must use that when using Alter Language. # # The language Shebang Script is special. It's entry is only used for # extensions, and files with those extensions have their shebang (#!) lines # read to determine the real language of the file. Extensionless files are # always treated this way. # # The language Text File is also special. It's treated as one big comment # so you can put Natural Docs content in them without special symbols. Also, # if you don't specify a package separator, ignored prefixes, or enum value # behavior, it will copy those settings from the language that is used most # in the source tree. # # Extensions: [extension] [extension] ... # [Add/Replace] Extensions: [extension] [extension] ... # Defines the file extensions of the language's source files. You can # redefine extensions found in the main languages file. You can use * to # mean any undefined extension. # # Shebang Strings: [string] [string] ... # [Add/Replace] Shebang Strings: [string] [string] ... # Defines a list of strings that can appear in the shebang (#!) line to # designate that it's part of the language. You can redefine strings found # in the main languages file. # # Ignore Prefixes in Index: [prefix] [prefix] ... # [Add/Replace] Ignored Prefixes in Index: [prefix] [prefix] ... # # Ignore [Topic Type] Prefixes in Index: [prefix] [prefix] ... # [Add/Replace] Ignored [Topic Type] Prefixes in Index: [prefix] [prefix] ... # Specifies prefixes that should be ignored when sorting symbols in an # index. Can be specified in general or for a specific topic type. # #------------------------------------------------------------------------------ # For basic language support only: # # Line Comments: [symbol] [symbol] ... # Defines a space-separated list of symbols that are used for line comments, # if any. # # Block Comments: [opening sym] [closing sym] [opening sym] [closing sym] ... # Defines a space-separated list of symbol pairs that are used for block # comments, if any. # # Package Separator: [symbol] # Defines the default package separator symbol. The default is a dot. # # [Topic Type] Prototype Enders: [symbol] [symbol] ... # When defined, Natural Docs will attempt to get a prototype from the code # immediately following the topic type. It stops when it reaches one of # these symbols. Use \n for line breaks. # # Line Extender: [symbol] # Defines the symbol that allows a prototype to span multiple lines if # normally a line break would end it. # # Enum Values: [global|under type|under parent] # Defines how enum values are referenced. The default is global. # global - Values are always global, referenced as 'value'. # under type - Values are under the enum type, referenced as # 'package.enum.value'. # under parent - Values are under the enum's parent, referenced as # 'package.value'. # # Perl Package: [perl package] # Specifies the Perl package used to fine-tune the language behavior in ways # too complex to do in this file. # #------------------------------------------------------------------------------ # For full language support only: # # Full Language Support: [perl package] # Specifies the Perl package that has the parsing routines necessary for full # language support. # #------------------------------------------------------------------------------- # The following languages are defined in the main file, if you'd like to alter # them: # # Text File, Shebang Script, C/C++, C#, Java, JavaScript, Perl, Python, # PHP, SQL, Visual Basic, Pascal, Assembly, Ada, Tcl, Ruby, Makefile, # ActionScript, ColdFusion, R, Fortran # If you add a language that you think would be useful to other developers # and should be included in Natural Docs by default, please e-mail it to # languages [at] naturaldocs [dot] org. libgd-gd-2.1.1/docs/naturaldocs/project/Topics.txt000066400000000000000000000060771245535672000221260ustar00rootroot00000000000000Format: 1.51 # This is the Natural Docs topics file for this project. If you change anything # here, it will apply to THIS PROJECT ONLY. If you'd like to change something # for all your projects, edit the Topics.txt in Natural Docs' Config directory # instead. # If you'd like to prevent keywords from being recognized by Natural Docs, you # can do it like this: # Ignore Keywords: [keyword], [keyword], ... # # Or you can use the list syntax like how they are defined: # Ignore Keywords: # [keyword] # [keyword], [plural keyword] # ... #------------------------------------------------------------------------------- # SYNTAX: # # Topic Type: [name] # Alter Topic Type: [name] # Creates a new topic type or alters one from the main file. Each type gets # its own index and behavior settings. Its name can have letters, numbers, # spaces, and these charaters: - / . ' # # Plural: [name] # Sets the plural name of the topic type, if different. # # Keywords: # [keyword] # [keyword], [plural keyword] # ... # Defines or adds to the list of keywords for the topic type. They may only # contain letters, numbers, and spaces and are not case sensitive. Plural # keywords are used for list topics. You can redefine keywords found in the # main topics file. # # Index: [yes|no] # Whether the topics get their own index. Defaults to yes. Everything is # included in the general index regardless of this setting. # # Scope: [normal|start|end|always global] # How the topics affects scope. Defaults to normal. # normal - Topics stay within the current scope. # start - Topics start a new scope for all the topics beneath it, # like class topics. # end - Topics reset the scope back to global for all the topics # beneath it. # always global - Topics are defined as global, but do not change the scope # for any other topics. # # Class Hierarchy: [yes|no] # Whether the topics are part of the class hierarchy. Defaults to no. # # Page Title If First: [yes|no] # Whether the topic's title becomes the page title if it's the first one in # a file. Defaults to no. # # Break Lists: [yes|no] # Whether list topics should be broken into individual topics in the output. # Defaults to no. # # Can Group With: [type], [type], ... # Defines a list of topic types that this one can possibly be grouped with. # Defaults to none. #------------------------------------------------------------------------------- # The following topics are defined in the main file, if you'd like to alter # their behavior or add keywords: # # Generic, Class, Interface, Section, File, Group, Function, Variable, # Property, Type, Constant, Enumeration, Event, Delegate, Macro, # Database, Database Table, Database View, Database Index, Database # Cursor, Database Trigger, Cookie, Build Target # If you add something that you think would be useful to other developers # and should be included in Natural Docs by default, please e-mail it to # topics [at] naturaldocs [dot] org. libgd-gd-2.1.1/docs/naturaldocs/run_docs.sh000077500000000000000000000014511245535672000206200ustar00rootroot00000000000000#!/bin/bash set -e # Version number VERSION=`(cd ../../; perl config/getver.pl)` # Clear away old docs and ensure the doc dir. is present. [ -d html ] && rm -rf html mkdir html # Create a lightly-processed copy of the source to use as input. This # file skips all non-C code in src/ and removes the BGD_DECLARE() # macro from definitions so they don't show up in the docs. [ -d tmp ] && rm -rf tmp mkdir tmp perl nobgd.pl ../../src/ tmp/ # Add the external docs. cp license.txt tmp/ sed -e "s/@VERSION@/$VERSION/g" preamble.txt > tmp/preamble.txt # ^^^ hack to get the version number in the docs. # Run naturaldocs to create the manual. naturaldocs --rebuild --rebuild-output --documented-only \ -i tmp/ \ -o html html \ --project project/ # And cleanup the temp files. rm -rf Data tmp libgd-gd-2.1.1/examples/000077500000000000000000000000001245535672000150135ustar00rootroot00000000000000libgd-gd-2.1.1/examples/CMakeLists.txt000066400000000000000000000016141245535672000175550ustar00rootroot00000000000000include_directories (BEFORE "${GD_SOURCE_DIR}/src" "${CMAKE_BINARY_DIR}") SET(TESTS_FILES arc crop gif nnquant tgaread ) if (JPEG_FOUND) LIST(APPEND TESTS_FILES copyrotated flip) endif (JPEG_FOUND) if (TIFF_FOUND) LIST(APPEND TESTS_FILES tiffread) endif (TIFF_FOUND) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} ${GD_LIB}) ENDFOREACH(test_name) if(JPEG_FOUND) if(UNIX) target_link_libraries(copyrotated m) endif(UNIX) endif(JPEG_FOUND) if (WIN32 AND NOT MINGW AND NOT MSYS) add_executable(windows WIN32 "windows.c") target_link_libraries (windows ${GD_LIB}) else (WIN32 AND NOT MINGW AND NOT MSYS) if (MINGW OR MSYS) add_executable(windows "windows.c") add_definitions("-mwindows") target_link_libraries(windows ${GD_LIB} stdc++ gdi32) endif (MINGW OR MSYS) endif (WIN32 AND NOT MINGW AND NOT MSYS) libgd-gd-2.1.1/examples/arc.c000066400000000000000000000011171245535672000157240ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include int main() { gdImagePtr im; FILE *fp; int cor_rad = 60; im = gdImageCreateTrueColor(400, 400); gdImageFilledRectangle(im, 0, 0, 399, 399, 0x00FFFFFF); gdImageFilledArc (im, cor_rad, 399 - cor_rad, cor_rad *2, cor_rad *2, 90, 180, 0x0, gdPie); fp = fopen("b.png", "wb"); if (!fp) { fprintf(stderr, "Can't save png image.\n"); gdImageDestroy(im); return 1; } #ifdef HAVE_LIBPNG gdImagePng(im, fp); #else printf("No PNG support. Cannot save image.\n"); #endif fclose(fp); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/examples/copyrotated.c000066400000000000000000000034721245535672000175220ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include gdImagePtr loadImage(const char *name) { FILE *fp; gdImagePtr im; fp = fopen(name, "rb"); if (!fp) { fprintf(stderr, "Can't open jpeg file\n"); return NULL; } im = gdImageCreateFromJpeg(fp); fclose(fp); return im; } int savePngImage(gdImagePtr im, const char *name) { FILE *fp; fp = fopen(name, "wb"); if (!fp) { fprintf(stderr, "Can't save png image fromtiff.png\n"); return 0; } gdImagePng(im, fp); fclose(fp); return 1; } int main(int argc, char **arg) { gdImagePtr im, im2; int new_width, new_height; double angle, a2; if (argc < 3) { fprintf(stderr, "Usage: copyrotated [angle in degree] [filename.png]\n"); return 1; } angle = strtod(arg[1], 0); im = loadImage(arg[2]); if (!im) { fprintf(stderr, "Can't load PNG file <%s>", arg[1]); return 1; } /* cos adj hyp (cos = adjacent / hypothenus) sin op hyp (sin adjacent / hypothenus) + 10 pixels margin */ /* to radian */ a2 = angle * .0174532925; new_width = ceil(cos(a2) * gdImageSX(im)) + fabs(sin(a2) * gdImageSY(im)); new_height = ceil(cos(a2) * gdImageSY(im)) + fabs(sin(a2) * gdImageSX(im)); im2 = gdImageCreateTrueColor(new_width, new_height); if (!im2) { fprintf(stderr, "Can't create a new image"); gdImageDestroy(im); return 1; } gdImageAlphaBlending(im2, 0); gdImageFilledRectangle(im2, 0, 0, gdImageSX(im2), gdImageSY(im2), gdTrueColorAlpha(127,0,0,127)); gdImageCopyRotated(im2, im, new_width/2, new_height/2, 0, 0, gdImageSX(im), gdImageSY(im), angle); gdImageSaveAlpha(im2, 1); if (!savePngImage(im2, "rotated.png")) { fprintf(stderr, "Can't save PNG file rotated.png"); gdImageDestroy(im); gdImageDestroy(im2); return 1; } gdImageDestroy(im2); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/examples/crop.c000066400000000000000000000025021245535672000161210ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include void save_png(gdImagePtr im, const char *filename) { FILE *fp; fp = fopen(filename, "wb"); if (!fp) { fprintf(stderr, "Can't save png image %s\n", filename); return; } #ifdef HAVE_LIBPNG gdImagePng(im, fp); #else printf("No PNG support. Cannot save image.\n"); #endif fclose(fp); } gdImagePtr read_png(const char *filename) { FILE * fp; gdImagePtr im; fp = fopen(filename, "rb"); if (!fp) { fprintf(stderr, "Can't read png image %s\n", filename); return NULL; } #ifdef HAVE_LIBPNG im = gdImageCreateFromPng(fp); #else im = NULL; printf("No PNG support. Cannot read image.\n"); #endif fclose(fp); return im; } int main() { gdImagePtr im, im2; im = gdImageCreateTrueColor(400, 400); if (!im) { fprintf(stderr, "Can't create 400x400 TC image\n"); return 1; } gdImageFilledRectangle(im, 19, 29, 390, 390, 0xFFFFFF); gdImageRectangle(im, 19, 29, 390, 390, 0xFF0000); save_png(im, "a1.png"); im2 = gdImageCropAuto(im, GD_CROP_SIDES); if (im2) { save_png(im2, "a2.png"); gdImageDestroy(im2); } gdImageDestroy(im); im = read_png("test_crop_threshold.png"); if (!im) { return 1; } im2 = gdImageCropThreshold(im, 0xFFFFFF, 0.6); if (im2) { save_png(im2, "a4.png"); gdImageDestroy(im2); } gdImageDestroy(im); return 0; } libgd-gd-2.1.1/examples/flip.c000066400000000000000000000022741245535672000161160ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include gdImagePtr loadImage(const char *name) { FILE *fp; gdImagePtr im; fp = fopen(name, "rb"); if (!fp) { fprintf(stderr, "Can't open jpeg file\n"); return NULL; } im = gdImageCreateFromJpeg(fp); fclose(fp); return im; } int savePngImage(gdImagePtr im, const char *name) { FILE *fp; fp = fopen(name, "wb"); if (!fp) { fprintf(stderr, "Can't save png image fromtiff.png\n"); return 0; } gdImagePng(im, fp); fclose(fp); return 1; } int main(int argc, char **arg) { gdImagePtr im; int returncode = 0; if (argc < 2) { fprintf(stderr, "Usage: flip [filename.png]\n"); return 1; } im = loadImage(arg[1]); if (!im) goto error; gdImageFlipHorizontal(im); if (!savePngImage(im, "flip_horizontal.png")) { goto error; } gdImageDestroy(im); im = loadImage(arg[1]); if (!im) goto error; gdImageFlipVertical(im); if (!savePngImage(im, "flip_vertical.png")) { goto error; } gdImageDestroy(im); im = loadImage(arg[1]); if (!im) goto error; gdImageFlipBoth(im); if (!savePngImage(im, "flip_both.png")) { goto error; } gdImageDestroy(im); goto done; error: returncode = 1; done: return returncode; } libgd-gd-2.1.1/examples/gif.c000066400000000000000000000020111245535672000157160ustar00rootroot00000000000000#include #include #include int main(void) { int i; FILE * out; gdImagePtr im; gdImagePtr prev =NULL; int black; im = gdImageCreate(100, 100); if (!im) { fprintf(stderr, "can't create image"); return 1; } out = fopen("anim.gif", "wb"); if (!out) { fprintf(stderr, "can't create file %s", "anim.gif"); return 1; } gdImageColorAllocate(im, 255, 255, 255); /* allocate white as side effect */ gdImageGifAnimBegin(im, out, 1, -1); for(i = 0; i < 20; i++) { int r,g,b; im = gdImageCreate(100, 100); r = rand() % 255; g = rand() % 255; b = rand() % 255; gdImageColorAllocate(im, 255, 255, 255); /* allocate white as side effect */ black = gdImageColorAllocate(im, r, g, b); printf("(%i, %i, %i)\n",r, g, b); gdImageFilledRectangle(im, rand() % 100, rand() % 100, rand() % 100, rand() % 100, black); gdImageGifAnimAdd(im, out, 1, 0, 0, 10, 1, prev); if(prev) { gdImageDestroy(prev); } prev = im; } gdImageGifAnimEnd(out); fclose(out); return 0; }libgd-gd-2.1.1/examples/nnquant.c000066400000000000000000000022361245535672000166460ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include void save_png(gdImagePtr im, const char *filename) { FILE *fp; fp = fopen(filename, "wb"); if (!fp) { fprintf(stderr, "Can't save png image %s\n", filename); return; } #ifdef HAVE_LIBPNG gdImagePng(im, fp); #else printf("No PNG support. Cannot save image.\n"); #endif fclose(fp); } int main() { #ifdef HAVE_JPEG gdImagePtr im, im2; FILE *fp; char path[2048]; fp=fopen("resampledbug.jpeg", "rb"); if (!fp) { fprintf(stderr, "Can't load /home/pierre/IM3801.jpg\n"); return 1; } im = gdImageCreateFromJpeg(fp); fclose(fp); if (!im) { fprintf(stderr, "Can't load TIFF image %s\n", path); return 1; } im2 = gdImageNeuQuant(im, 256, 3); if (im2) { gdImageSaveAlpha(im2, 1); save_png(im2, "a_nnquant.png"); gdImageDestroy(im2); } else { printf("neu quant failed.\n"); } gdImageTrueColorToPalette(im, 1, 256); gdImageSaveAlpha(im, 1); save_png(im, "a_jquant_dither.png"); gdImageDestroy(im); #else printf("JPEG support is required for this example. Please recompile GD with JPEG or change this example to use another format as input."); return 1; #endif return 0; } libgd-gd-2.1.1/examples/noIcon.pic000066400000000000000000001737761245535672000167620ustar00rootroot00000000000000S4@`PICT?NzzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zzzzzzzzzzzzFFFF[[[[zBkzYBkzz߅߅zzzzzzkzYB߅zWvWv߅FFF0!߅[[[[^߅zYz!f1zzEEEEE11ff!fff!E!fffzzzzzzcBz!!fffzv @ fFFFf[[[[ ^ fzBYzBrzzUUU1!rzzzzzzr11BzYBrzWvW v΄FFF0!U[[[[!^^z!YzfffU)zJzzvv111fUvvvfUJzzzzzzf1fBzf1fU)UzJz vf5 bWHFFFF4[[[[E^E9izBrYzrJzf11zzfff1!Efff1zzzzzzBJBzrJzfff11zWvb@f)FFFA&Ff [[[[^i^if!Ϡ111!!!ϢEEE!!!ϠfffϑϗϜϠfϑzYz!vvvz1f1zz11!v1f1!v11fzzzzz11zBz!!v8vz11f1fzvv@e)WFFFF ![[[[ !^P!EzYzQ111E!!rz 111EEEE!1EEEE!rzzzzz111JYf1fzQ11E!EEEE!!rzvk1+ܒ):E΂FF+ EU[[[[1iEs!.EzYzU)!BBz11U!߃U!BBzzzzzzU)U!!BBBzv5WWHvvvFF!..[[[[9^^^zYzkBzU)!z11U!Uz)U!zzzzzYf1fkBzzU)U!!zvW5vHFF!F[[[[[E^9zYzBrzQzffff 1zQYzzzzzzBBrzzQYzvWkv΂ܒFFAF[:A[[[[^^s!!!UUUfff!!!UUUfffvvv111!!!UUUfff!!!UUUfff!Uf!UfUf!Ufzzzzρzzzzzzzzlv, 0Cs܁w<́iizzzzzzzzzzzzb"Oru߁܁ށ*] &F΁3F11́[7>`Lzzzzzzzzzzzzbv,XX6܁܅GF F=$[7*E!^^:zzzzzzzzzzzzbKvXAs܁Uf܁Fe FC[[J7*F azzzzzzzzzzzzX^܁<l FD*FP[[P1aE eތuށ E eތzzzzzzzzzzzzb^ΐ܁w=F=F[[Lzzzzzzzzzzzz"܁ȁ=FF[[7zzzzzzzzzzzzbO܁=FF[[7>zzzzzzzzzzzzwO܁=FF[[Cezzzzzzzzzzzz,DS܁=FF[[$Uzzzzzzzzzzzzwr"܁w]FF[[Cu$vDe0fuvDezzzzzzzzzzzz,r"K܁eXFF[[`0Qzzzzzzzzzzzz b܁΂چGFF[[` i zzzzzzzzzzzzDKC܁wX9&FF[[$Qi4zzzzzzzzzzzzDbEc܁l *FF[[$i/Rzzzzzzzzzzzze,w܁ +w+Ɂ=FF[[>/fD 0!fDzzzzzzzzzzzzOD܁l l vFF[[e4zzzzzzzzzzzz,r^ "/܁߂FF[[`a $$zzzzzzzzzzzzK@C܁FF[[*14^zzzzzzzzzzzzlޗsS܁ޏ[9FF[[=̗a:zzzzzzzzzzzzD݅܁0 FFF[[ $Յe1zBkzBBkzzBk߂zzzzzzkzBBk߃zW(_sccCvM BFFF!.[*`uR?^zYz!!!E!!JzEEEEE11ff!EEEE!!Eς!EEEE!E!JzzzzzzcBz!!E!EEEE!!Jzvć C܂] BFFF E[*$̇ EizBYzzU)zUU1!!!z)Urzzzzzzr11BzBzzU)UrzWvK6^C܂+lMBFFF!F[[vLa^/9z!YzzYzvv111vzYYzzzzzzf1fBzBzzYYz vwfوC܂<FFF!F[[[C F߮/zBrYzzBz!EEEzBrzzzzzzBJBzBzzBrzWv/A,AX܂wIE<fFFFAEF!F[.U[[[[J1E/ F^^i^^^EEEfff111!!!EEEfffEEE!!!EEEffffffEEEfffEf1!E!EffEfzYz!!!E!1v8z11!EEEE1v111!EEEE!E18vzzzzz11zBz!!E!EEEE11v8vzv!+J/܂FFFA&!1F E &[[[[ !^.E!PzYzzYz11zYBzzzzz111JYf1fzBzzYBzvv/܂FFF0&F!F[A.[[[[1iE^^zYzzE!EEEz11E߃z!EzzzzzzBzzE!Ezv+E/Ɂ܂FFA=v܁SFw|[[+>g邮Y׆׆w!ɇY>wY׆׆wzzzzzzzzzzzze3ǂ!܁܂SFRFW[[w+΂zzzzzzzzzzzz܁9χɁF<wF+[[߃ݰzzzzzzzzzzzzԇ͢܁FۄF͇[[ӅzzzzzzzzzzzzǂLJ܁܁qdFF[[zɇzzzzzzzzzzzzy܁SFF[[[p߄|zzzzzzzzzzzz3܁ބ)FwF[[Ӄא5YYzzzzzzzzzzzzǁe܁SFF[[Wzzzzzzzzzzzzǁ܁qFF[[וzzzzzzzzzzzz׍!܁FF[[!zzzzzzzzzzzzۋ܁FF[[͋zzzzzzzzzzzze3܁φFF[[W5!׆Ɇw!׆zzzzzzzzzzzzԴ܁SFF[[݁ڽzzzzzzzzzzzzeǂ܁ރ9FF[[W΂zzzzzzzzzzzzԃ܁FF[[́zzzzzzzzzzzzǃՇ܁܂FF[[ׇ́zzzzzzzzzzzz悢v܁!)FF[[āwzzzzzzzzzzzzeʹځ܁SFF[[Wӽ߁݈wׄ!!!wׄ!zzzzzzzzzzzz荊܁S]FF[[ꐊāzzzzzzzzzzzzΘ܁FFF[[Ӂzzzzzzzzzzzz3܁9iFFF[[+䁮zzzzzzzzzzzzۏ=܁!<FFF[[͏5|zzzzzzzzzzzz܁׌YۂFFF[[ήɁ׆ׄ!wɁ׆חzzzzzzzzzzzzԁ3v܁q9ρRFFF[[+gzzzzzzzzzzzzywe܁wqۃRFFF[[ݠiWwzzzzzzzzzzzz܁FFF[[[߸遮zzzzzzzzzzzzͮ܁FFFF[[[[zȁӸzzzzzzzzzzzz܁FFFF[[[[߃ϞσϠϤ߂ϑ߃ϞυϤ߂ϑzYz!!!E!!f1zEEEEE11ff!EEEE!f!E!EEEE!1fzzzzzzcBz!!E!EEEE!!f1fzv!+@EC/c܁FF 7F E![[[[ ^.EEzBYzzJvvvzvUUU1!zJ8vzzzzzzr11BzBzzJv8vzWvbv܁FFŪiю8yԺ؈_ݒ{19v0fR>t:p !&"\#$%&'H(~)*, ,-/V1 246=79:<>a?@AC&DTEFRGHMIJKLMJNOQRXSToU/VoWXZZ[}\]_G`abcdfg&hhiklnapqrsuw{y=z{|~SG9oa%[G}3i A3kz+xa;3y JDŽȷʬˏ!iкѓ҉ )QUܰ+y2hBHK#mE1g#E{  !g"#% &?&'()++,a,-/1s3*4679s;<=>?@BCgDEFWGWHIJL LMNPQURSTtUpVWY"ZSZ[\^>_`bbcefHgghikemnppqstSvwyz{}&~]LDzf0fR*tL:t 4VC|$H|,tM MƋ-ʱbϪј LjגRۖ*hF .V7.dP<r(333333333333333 Pa^]c`G`cc`43333333333333333333333333333333@AaaZSR0Pbd`@333333333333333333333333333333339aZW_bK`_c`S3333333333333333333333333333333=^]Zd_GZ[[SP333333333333333QQQQQQQQQQQQQQQ dtnkqoGquus4QQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQ\Atrjgf0ftvt@QQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQ9tjemqKqqusiQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQ=rqktpGnqqjgQQQQQQQQQQQQQQQAAAAAAAAAAAAAAA Sdf`bcGad`g4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAASAdh`X[0Wf`g@AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAG9dfbfiKeh`gZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAG=`d`fgG]bZ]ZAAAAAAAAAAAAAAAqqqqqqqqqqqqqqq B2rio;rod]m=|~7{vrln)y}D}}ZeiEzr09rrrrriqqqqqqqqqqqqqqqqqqqqsqussv;JsVqf_ozbc~yunpuZm||YcgMsnALv qqqqqqqqqqqqqqqGzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[~F~F~F~FGzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[~F~F~F~FGzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[Gzzzz*zzzz9zzzzU܁܁܁܁FFFF[[[[r߻Or߻Or߻Or߻Of 1kzzzz fzYz1kzf zzBzz1kz v1f$fv @܁܁FF7FF!O[[[[^ Ef1ffJczzzzz f1zYzfYJzfff1zzBzz1YYJczzf 1f1#f1vfvb ccܺ ܁܁FF!F<FF004 H[[[[[^Ei! 1E1zz!zzzzzf1EzYzzEz11EzY1zzBzzzz!zzEU1Ef1EvE/qqwqqMQq܁܁FFF<FF!FF[[ [[[[[E^!.1zzJczzzzzYzzJcz1zzzBzzzzJcz vb/܁܁FF<FFF!FF[[4H[[[[^i1zzrBzzzz1fzYzzrBz1z1JYY1zzBzzzzrBz 1fvW/܁܁FFF0FF!FF[[U.[[[[1iE^^1zBzzzz1zYzzBz1zzzBzzBzzzBz 11vW/܁܁FFFA&!FF!FF[.[[[[ !^^^1! E!f1! E!f1! E!f1! E!fzzcQzzzz zBrYzzcQzzzBJBzzBzzzzcQz !EWvk܁܁FFFA FF!FF[[H:[[[[^i^^s!v1vzzBrzzzz fzYzzBrzv1vzzz1BzzBzzzzBrz 1v f vWs1܁܁FFv!F!FF!FF[[.U[[[[E^^^vUzJ8zzzzz 1vzBYzzJvzvUzzzrBzzBzzzJ8zzv U1!v!1vWvbv܁܁FFUwYwGzzzz*zzzz9zzzzU>=v S FF w|[[[+>gGzzzz*zzzz9zzzzUΞ! w )FF )ɫw [[[!ѢGzzzz*zzzz9zzzzUwFFF[[[pWGzzzz*zzzz9zzzzU!/Gzzzz*zzzz9zzzzUDbEc܂ l *FFF[[[$i/RGzzzz*zzzz9zzzzUDKC܂w܅X9&FFF[[[$Qi4Gzzzz*zzzz9zzzzU b܂܆GFFF[[[` i Gzzzz*zzzz9zzzzU,r"K܂eX܆FFF[[[`0Q~F~F~FvDe0fuvDeGzzzz*zzzz9zzzzUw r"܂܆w]FFF[[[C u$Gzzzz*zzzz9zzzzU,D S܂܆܅=FFF[[$ UGzzzz*zzzz9zzzzUwO܂܆ܡ=FFF[[CeGzzzz*zzzz9zzzzUbO܂܆ܡ=FFF[[7>Gzzzz*zzzz9zzzzU"܂܆ܡ=FFF[[7Gzzzz*zzzz9zzzzUb^܂܆w=FF=F[[L~F~F~FE e u E e Gzzzz*zzzz9zzzzUX^ ܂܆<l FFD*FP[[[P1a Gzzzz*zzzz9zzzzUbKKvXAs܂Uf܆FFe FC[[J7*F aGzzzz*zzzz9zzzzUbv,XX6܂܅܅GFF F=$[7*E!^^:Gzzzz*zzzz9zzzzUb"Oru܂܅*] &FF3F11[7>`LGzzzz*zzzz9zzzzUerb܂ ]w3FF BFF L [>ii~F~F~F1evve fEu !vEE1evveGzzzz*zzzz9zzzzU C܂ +l 9UF mqL[` /Gzzzz*zzzz9zzzzUK r22@sC܂ M=e F [ e 11[*u44Cua/Gzzzz*zzzz9zzzzUS܂9 F=[PC^Gzzzz*zzzz9zzzzU,2܂*FqU[D tGzzzz*zzzz9zzzzUws܂= FFU$[[Ca ~F~F~FUD 0euUGzzzz*zzzz9zzzzU 0܂= 9FFF9 q1[[[U1!Gzzzz*zzzz9zzzzU^ s0܂= 9FF u$[[L a!Gzzzz*zzzz9zzzzUUr͹SE܄=D=*l9FF9L$[[U1ΪuCEGzzzz*zzzz9zzzzUX ܁ f fBFF3 1[[[[1 ^Gzzzz*zzzz9zzzz߻Blv, 0Cs܃w<wYwzzzzzzzzzzzzzzzzzzz>zzzzzz=vSFFwz|zzzzzzzzzzz[z[z[zzzzzzzzzz+zzzzzz>zzzzzzzgzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz!w)FF)wzzzzzzzzzzzz[z[z[zzzzzzzzzz!zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzwzzzzzzzzzzzzFFFzzzzzzzzzzzz[z[z[zpzzzWzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz!<FFFzzzzzzzz|zzzez[z[z[z[zzzzzzzzzzzzzzzzzzzzz!zzzzzzzzzzzzzzzzzzzzzzzzzzyYYkzzzzzzzzqFFFFkzzzzzzzzzz[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzYkߘzzzzzvvv1EEEYvvvEEEY!vvv111vvvEEEYGvvvvEEEEzzzzzzYvzzzz1fLBrzJQ1zzzzzzvfffff1SiFFFFF1fQ1kzzzzzz[z[z[z[z[z[z[zezzz?zzzzzzzzzzzzzzEBzzf1fE B^rQs11! kߘzzzzzzzzYvzzzYvzzzzkfffzzzzzz!11fiFFFFFFU!zkf1zzzzz[z[z[z[z[z[z[z[z[zezzzzzzzzzzzzYYYYf1fzYQszzzkߘ f1fEzzzzzzzzYvzzz)U5!zzzzz1fUUUzezzzzzYv11UH!fUqqiFFFFFFFU!d)zzf1LU)zzzz[z[z[z[z[z[z[z[z[z[z[zzzzzzwzzzzzzLEvzU)U9!!zzzzzf1fEU)U9zzzzzzzzYvzzz!8vJzzzzzzzzzzzz11!vFFFFFFFFw!vzzzzzzz[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzz111JYYuf1fEz!!v8vPzzzzzzzzzzzzzzzYvzzzBWzzzzzzzzzzzz11vFFFFFFFF1Fyzzzzzzez[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzz11zzB^zB^zzzzzzzzz111!!!!EEE!!!ffffzzzzBWrYvzzz1)U5zzzzzzzzzzzz1)UHFFFFFFFF!EF1UFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzB^JiB^z11!U)U9zzzzzzzzzzzzz! Yvzzz8vJ zzzzz!E+zzzzzzvv111ve E:vFFFFFFFFvvvFvAFFz[z[E!B.z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzf1fEB^zv8vP rzzzzE!E.B^zzzzzzzBWYvzzzr ffffzzzzBWzzzzzz fWvFFFFFFFFUUU1!FAfFFz[B.YAz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzr11!B^zr f1fEzzzB^YzzzzzzzzYvzzzzcσ!8vJBW!E+1f@zzzzzzEEEEE11ffc !veE:fWFFFFFFFF!EFF7!vE!f1!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzcύ B^zzcύ !!v8vPE!E.f1fEzzzUUUUEEEEffffUUUUEEEEffffUUUUEEEEffffUUUUEEEEffffzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz<z/zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzDzzbzzzzEcl *FFFFFFFz[zzzzzzzzzzzz[z[zzzzzzzzzz$zizzzzz/zRzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzDzzKzzzzCwX9&FFFFFFFz[zzzzzzzzzzzz[z[zzzzzzzzzz$zQzzzzziz4zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz zbzzzGFFFFFFFz[zzzzzzzzzzzz[z[zzzzzzzzzz`z zizzzzz zzzzzzzzzzzzzzzzzzzzzzzzzzzz,zzrzzzzzzz"zzzzKzeXFFFFFFFz[zzzzzzzzzzzz[z[zzz`zzzzzzz0zzzzQzzzzzzzzzzzzzzzzzzzzvDe0fuvDezzzzzzzzzzzwzzzzzzzzzzzzrz"zw]FFFFFFFz[zzzzzzzzzzzz[z[zCzzzzzzzzzzzzuz$zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz,zDzzzzzzzzzzzzS=FFFFFFFz[zzzzzzzzzzzz[z[z[zzz$zzzzzzzzzzzzUzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzwzzOzzzzzzzzzzz=FFFFFFFz[zzzzzzzzzzzz[z[z[zCzzezzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzzOzzzzzzzzzz=FFFFFFFz[zzzzzzzzzzzz[z[z[z[z7zz>zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz"zzzzzzzzz=FFFFFFFz[zzzzzzzzzzzz[z[z[z[z[z7zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzzzzz^zzzzzzw=FF=FFFFz[zzzzzzzzzzzz[z[z[z[z[z[zzzzzLzzzzzzzzzzzzzzzzzzzzzzzzzE eu E ezzzzzzzzzzzzzzzzzzXzzzzzzz^<l FFD*FFFFzPzzzzzzzzzzzz[z[z[z[z[z[z[z[zPz1zzzzzzzazzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzKzKvzXzAzzzzsUfFFe FFFFzCzzzzzzzzzzzz[z[z[z[z[z[z[zJz7z*z*z*zFzzzzz zazzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbvz,zzzzzzzXzzzXz6GFF FFFFz=zz$zzzzzzzzzz[z[z[z[z7z*Ezzzzzz!z^zzz^z:zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzzzzz"zOzruzzzzzz*] &FF3FFFz1zz1zzzzzzzzzz[z[z[z7zzzzzz>z`zLzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzezrzzzzzzzzbzzz]w3FF BFFz zzLzzzzzzzzz z[z[z[zzz>zzzzzzzzizzzzizzzzzzzzzzzzzzzzzz1evve fEu!vEE1evvezzzzzzzzzzzzzzzzzzzzz zzzzC+l9UFFFmzzqzzzzzzzzLzzz[z[z[zzz`zzzzzzz zzzzzzzzzzzzzzz/zzzzzzzzzzzzzzzzzzzzKz zzzzzzzzzrz2z2z@sCM=eFFF[ ezzzzzzzzzz1zz1z[z[z[z*zzzzzzzzzzuz4z4zCzuzzzzzzzzazz/zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzS9 FFFzzzzzzzzzzzz=z[z[z[zPzzzzzzzzzzzzzzzzzzzzzzCzz^zzzzzzzzzzzzzzzzzzzzz,z2zzzzzzzzzzz*FFFzzzzzzzzzqzzzUz[z[z[z[zzDzzzzzzzzzzzzzzzzzzzz zztzzzzzzzzzzzzzzzzzzzzzwzzzzzzzzzzzzs= FFFFUzzzzzzzzzzz$z[z[z[z[z[zCzzzzzzzzzzzzzzzzzzzzazz zzzzzzzzzUD0euUzzzzzzzzzzzzzzzz zzzzzzzzz0=9FFFFF9zzzzzzzqzzz1z[z[z[z[z[z[z[zU1zzzzzzzzzzzzzzzzzzzz!zzzzzzzzzzzzzzzzzzzzzzzzzzzz^zzzzzzzs0=9FFFFFF zzzzzzuzzz$z[z[z[z[z[z[z[z[z[zzzzLzzzzzzzzzzzzzazz!zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzUzrzzzzzSE=D=====*l9FFFFFFF9zzzzzLzzz$z[z[z[z[z[z[z[z[z[z[zUzzzzz1zzzzzzzzuzCzzzEzzzzzzzzzzzzzzzzzzzzzzzzzzzzzXz zzzzzzzffBFFFFFFFF3 zzzzzzz1z[z[z[z[z[z[z[z[z[z[z[z[z[z1zzzzzzzzzzzzzz z^zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzlvz,z zzzz0Csw<<fFFFFFFFFFFF* zzzzzz1z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z=z*Ez zzzzzz!z/zQztzzzzzzzzzzzzzz!!!!UUUUffff!!!!UUUUffffvvv111!!!UUUUffff!!!!UUUUffffzzzzzzYvzzBWrzzzzQkzzzzzzffffvFFFFFFFFF1AFFFz[Q:YAz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzB^B^rzzzzQsYzzzzzzzzYvzzkߎBWzzzz)U5!zzzzzz11vUH!FFFFFFFFFU!FFFz[U)!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzYYYYf1fEkߘB^zzzzU)U9!!zzzzzzzzzYvzzz)U5!BWBWBWBWBWzzzzzz11UH!vvvvvFFFFFFFFFU!!!!B.B.z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzU)U9!!B^B^B^B^B^zzzzzzzzzYvzzzQk1111!E+!E+!E+!rzzzzzz111)E:E:EEEE!FFFFFFFFF+1E E EEEE!rUz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzz1111JiYYf1fEzQs11!E!E.E!E.EEEE!!rzzzzzzzzzYvzzzz!vvvvzzz11f@zzzzzzz11!ve1)fWFFFFFFFFF1F!vFF1 f1!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzz 11!zzB^zz!!v8vPzz11!f1fEzzzz111!!!EEE!!!ffffzzzzBWrYvzzzzrJbz1f@1zzzzzzzzffff1)FFFFFFFFF!EFA&Fffff1 z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzB^JiB^zzrJizffff11!zzzzzzzzz! Yvzzzzzffff)U5z Jbzzzzzzzzvv111fWUHFFFFFFFFFvvvFFfUFJ4z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzf1fEB^zzzf1fEU)U9zJizzzzzzzzzzBWYvzzzzzBW rzzzzzzzzvFFFFFFFFFUUU1!FF0!rUz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzr11!B^zzzYB^rzzzzzzzzzzzYvzzzzz! 1f@zzzzzzzzzEEEEE11ff! ffffFFFFFFFFF!EFFF!ffffz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzcύ B^zzzz!! ffffzzzzzzzzzzzzBWkߎzzzzzYvBWkߎzzzzzzzzzvFFFFFFFFFFFF0!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzkߘkߘzzzzYB^zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzlibgd-gd-2.1.1/examples/noIconAlpha.tga000066400000000000000000004541221245535672000177130ustar00rootroot00000000000000 zzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzz߻zzzzzzYvzzzz 1f@kߎzzzzzzfFFFFFFFFFFFFv17FFf1!kOz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzB^zz f1fEkߘzzzzzzzzzYvzzzzffffYvYvYvJb1 zzzzzzffcffcf1FFFFFFFFFFFF!F<1FFf00J41 cHz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzB^zzf1fEYYJi11! cύzzzzzzzzYvzzzzzzzzz1EEEEzzzzzz11/qqwqq1MEQqFFFFFFFFFFFFUFFF<FF!FFz[z[1 E!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzYYYYf1fEzzB^zzzz11!E!E.zzzzzzzzYvzzzzzzzzzJbcσzzzzz11/FFFFFFFFFFFF<FFFFFF!FFz[z[J4cHz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzB^zzzzJicύzzzzzzzYvzzzzzzzzzrBWzzzzz11/FFFFFFFFFFFFFFFF0FF!FFz[z[rUB.z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzz1111JiYYf1fEzzB^zzzzrB^zzzzzzzYvzzzzzzzzzzBWzzzzz11/FFFFFFFFFFFFFA&!1FF!FFz[z[z[B.z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzz 11!zzB^zzB^zzzzzB^z1111!!!!EEEE!!!!ffffzzzzBWrYvzzzzzzzzzcσQkzzzzzFFFFFFFFFFFFFFFA!E FF!FFz[z[cHQ:z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzB^JiB^zzB^zzzzcύQszzzzz! YvzzzzzzzzzBWrzzzzzvvs1111FFFFFFFFFFFFvvvv!FFF!FF!FFz[z[B.rUz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzf1fEB^zzB^zzzzB^rzzzzzzBWYvzzzzzzzzJbvvvvzzzzzzvFFFFFFFFFFFFUUUU<FA1!FF!FFz[J4v8&z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzr11!B^zzB^zzzJiv8vPzzzzzzzzYvzzzz!!!!!E+!E+!E+!1f@zzzzzzEEEEEEC11/ffc!EEEEE!fFFFFFFFFFFFF!E 7FF!E E EEEE!f1!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzcύ B^zz!!E!E.E!E.EEEE!!f1fEzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFz[zzzzzzzzzz[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzywzezzzzzwqRFFFFFFFFFFFFFzzzzzzzzzzzz[z[z[z[z[z[zzzzzzizWwzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz3zzzzzzzzzvq9RFFFFFFFFFFFFzzzzzzzzzzzz[z[z[z[z[zzzz+zzzzzzzzzzzzzzzzzzzgzzzzzzzzz!wzzzzzzzzzzzzzzzzzzzzzzzzzYFFFFFFFFFFFzzzzzzzzzzzz[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz=!<FFFFFFFFFFzzzzzzzzzzzz[z[z[zzzzzzzzzzzzzzzzzz5zzzzzz|zzzzzzzzzzzzzzzzzzzzzzz3zzzzzzzzzzzz9iFFFFFFFFFzzzzzzzzzzzz[z[zzzz+zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFzzzzzzzzzzzz[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzS]FFFFFFFFzzzzzzzzzzzz[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzw!!!w!zzzzzzzzzzzzzzzzzzzezzzzzzSFFFFFFFFzzzzzzzzzzzz[z[zzzzzzzzzzWzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzv!)FFFFFFFFzzzzzzzzzzzz[z[zzzzzzzzzzzzzzzzzwzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFzzzzzzzzzzzz[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFzzzzzzzzzzzz[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzezzzzzzzzzzzzz9FFFFFFFFzzzzzzzzzzzz[z[zzzWzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzSFFFFFFFFzzzzzzzzzzzz[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz!w!zzzzzzzzzzzzzezzzzzzzz3zzzzFFFFFFFFzzzzzzzzzzzz[z[zzzzWzzzzzzzz5zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFzzzzzzzzzzzz[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz!FFFFFFFFzzzzzzzzzzzz[z[z[zzzzzzzzzzzzzzzz!zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzqFFFFFFFFzzzzzzzzzzzz[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzezzzzzzzzzSFFFFFFFFzzzzzzzzzzzz[z[z[z[z[zzzzWzzzzzzzzzzzzzzzzzzzzzzzzzzzzYYzzzzzzzzzzzzzzzzzzzzzz3zzz)FFwFFFFFzzzzzzzzzzzz[z[z[z[z[z[z[zzzzzzzz5zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzySFFFFFFFzzzzzzzzzzzz[z[z[z[z[z[z[z[zpzzzzzzzzz|zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzqdFFFFFFFzzzzzzzzzzzz[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFzzzzzzzzzzzz[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz9FF<wFFFFzzzzzzzzz+zzz[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzezzzzz3zzzzzz!SFFRFFFzzzzzzzzzWzzz[z[z[zzzzwzzzzz+zzzzzzzzzzzzzzzzzzzzzzzzzYw!Y>wYwzzzzzzzzzzzzzzzzzzz>zzzzzz=vSFFwz|zzzzzzzzzzz[z[z[zzzzzzzzzz+zzzzzz>zzzzzzzgzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz!w)FF)wzzzzzzzzzzzz[z[z[zzzzzzzzzz!zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzwzzzzzzzzzzzzFFFzzzzzzzzzzzz[z[z[zpzzzWzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz!<FFFzzzzzzzz|zzzez[z[z[z[zzzzzzzzzzzzzzzzzzzzz!zzzzzzzzzzzzzzzzzzzzzzzzzzyYYkzzzzzzzzqFFFFkzzzzzzzzzz[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzYkߘzzzzzvvv1EEEYvvvEEEY!vvv111vvvEEEYGvvvvEEEEzzzzzzYvzzzz1fLBrzJQ1zzzzzzvfffff1SiFFFFF1fQ1kzzzzzz[z[z[z[z[z[z[zezzz?zzzzzzzzzzzzzzEBzzf1fE B^rQs11! kߘzzzzzzzzYvzzzYvzzzzkfffzzzzzz!11fiFFFFFFU!zkf1zzzzz[z[z[z[z[z[z[z[z[zezzzzzzzzzzzzYYYYf1fzYQszzzkߘ f1fEzzzzzzzzYvzzz)U5!zzzzz1fUUUzezzzzzYv11UH!fUqqiFFFFFFFU!d)zzf1LU)zzzz[z[z[z[z[z[z[z[z[z[z[zzzzzzwzzzzzzLEvzU)U9!!zzzzzf1fEU)U9zzzzzzzzYvzzz!8vJzzzzzzzzzzzz11!vFFFFFFFFw!vzzzzzzz[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzz111JYYuf1fEz!!v8vPzzzzzzzzzzzzzzzYvzzzBWzzzzzzzzzzzz11vFFFFFFFF1Fyzzzzzzez[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzz11zzB^zB^zzzzzzzzz111!!!!EEE!!!ffffzzzzBWrYvzzz1)U5zzzzzzzzzzzz1)UHFFFFFFFF!EF1UFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzB^JiB^z11!U)U9zzzzzzzzzzzzz! Yvzzz8vJ zzzzz!E+zzzzzzvv111ve E:vFFFFFFFFvvvFvAFFz[z[E!B.z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzf1fEB^zv8vP rzzzzE!E.B^zzzzzzzBWYvzzzr ffffzzzzBWzzzzzz fWvFFFFFFFFUUU1!FAfFFz[B.YAz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzr11!B^zr f1fEzzzB^YzzzzzzzzYvzzzzcσ!8vJBW!E+1f@zzzzzzEEEEE11ffc !veE:fWFFFFFFFF!EFF7!vE!f1!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzcύ B^zzcύ !!v8vPE!E.f1fEzzzUUUUEEEEffffUUUUEEEEffffUUUUEEEEffffUUUUEEEEffffzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz<z/zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzDzzbzzzzEcl *FFFFFFFz[zzzzzzzzzzzz[z[zzzzzzzzzz$zizzzzz/zRzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzDzzKzzzzCwX9&FFFFFFFz[zzzzzzzzzzzz[z[zzzzzzzzzz$zQzzzzziz4zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz zbzzzGFFFFFFFz[zzzzzzzzzzzz[z[zzzzzzzzzz`z zizzzzz zzzzzzzzzzzzzzzzzzzzzzzzzzzz,zzrzzzzzzz"zzzzKzeXFFFFFFFz[zzzzzzzzzzzz[z[zzz`zzzzzzz0zzzzQzzzzzzzzzzzzzzzzzzzzvDe0fuvDezzzzzzzzzzzwzzzzzzzzzzzzrz"zw]FFFFFFFz[zzzzzzzzzzzz[z[zCzzzzzzzzzzzzuz$zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz,zDzzzzzzzzzzzzS=FFFFFFFz[zzzzzzzzzzzz[z[z[zzz$zzzzzzzzzzzzUzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzwzzOzzzzzzzzzzz=FFFFFFFz[zzzzzzzzzzzz[z[z[zCzzezzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzzOzzzzzzzzzz=FFFFFFFz[zzzzzzzzzzzz[z[z[z[z7zz>zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz"zzzzzzzzz=FFFFFFFz[zzzzzzzzzzzz[z[z[z[z[z7zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzzzzz^zzzzzzw=FF=FFFFz[zzzzzzzzzzzz[z[z[z[z[z[zzzzzLzzzzzzzzzzzzzzzzzzzzzzzzzE eu E ezzzzzzzzzzzzzzzzzzXzzzzzzz^<l FFD*FFFFzPzzzzzzzzzzzz[z[z[z[z[z[z[z[zPz1zzzzzzzazzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzKzKvzXzAzzzzsUfFFe FFFFzCzzzzzzzzzzzz[z[z[z[z[z[z[zJz7z*z*z*zFzzzzz zazzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbvz,zzzzzzzXzzzXz6GFF FFFFz=zz$zzzzzzzzzz[z[z[z[z7z*Ezzzzzz!z^zzz^z:zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzbzzzzz"zOzruzzzzzz*] &FF3FFFz1zz1zzzzzzzzzz[z[z[z7zzzzzz>z`zLzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzezrzzzzzzzzbzzz]w3FF BFFz zzLzzzzzzzzz z[z[z[zzz>zzzzzzzzizzzzizzzzzzzzzzzzzzzzzz1evve fEu!vEE1evvezzzzzzzzzzzzzzzzzzzzz zzzzC+l9UFFFmzzqzzzzzzzzLzzz[z[z[zzz`zzzzzzz zzzzzzzzzzzzzzz/zzzzzzzzzzzzzzzzzzzzKz zzzzzzzzzrz2z2z@sCM=eFFF[ ezzzzzzzzzz1zz1z[z[z[z*zzzzzzzzzzuz4z4zCzuzzzzzzzzazz/zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzS9 FFFzzzzzzzzzzzz=z[z[z[zPzzzzzzzzzzzzzzzzzzzzzzCzz^zzzzzzzzzzzzzzzzzzzzz,z2zzzzzzzzzzz*FFFzzzzzzzzzqzzzUz[z[z[z[zzDzzzzzzzzzzzzzzzzzzzz zztzzzzzzzzzzzzzzzzzzzzzwzzzzzzzzzzzzs= FFFFUzzzzzzzzzzz$z[z[z[z[z[zCzzzzzzzzzzzzzzzzzzzzazz zzzzzzzzzUD0euUzzzzzzzzzzzzzzzz zzzzzzzzz0=9FFFFF9zzzzzzzqzzz1z[z[z[z[z[z[z[zU1zzzzzzzzzzzzzzzzzzzz!zzzzzzzzzzzzzzzzzzzzzzzzzzzz^zzzzzzzs0=9FFFFFF zzzzzzuzzz$z[z[z[z[z[z[z[z[z[zzzzLzzzzzzzzzzzzzazz!zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzUzrzzzzzSE=D=====*l9FFFFFFF9zzzzzLzzz$z[z[z[z[z[z[z[z[z[z[zUzzzzz1zzzzzzzzuzCzzzEzzzzzzzzzzzzzzzzzzzzzzzzzzzzzXz zzzzzzzffBFFFFFFFF3 zzzzzzz1z[z[z[z[z[z[z[z[z[z[z[z[z[z1zzzzzzzzzzzzzz z^zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzlvz,z zzzz0Csw<<fFFFFFFFFFFF* zzzzzz1z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z=z*Ez zzzzzz!z/zQztzzzzzzzzzzzzzz!!!!UUUUffff!!!!UUUUffffvvv111!!!UUUUffff!!!!UUUUffffzzzzzzYvzzBWrzzzzQkzzzzzzffffvFFFFFFFFF1AFFFz[Q:YAz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzB^B^rzzzzQsYzzzzzzzzYvzzkߎBWzzzz)U5!zzzzzz11vUH!FFFFFFFFFU!FFFz[U)!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzYYYYf1fEkߘB^zzzzU)U9!!zzzzzzzzzYvzzz)U5!BWBWBWBWBWzzzzzz11UH!vvvvvFFFFFFFFFU!!!!B.B.z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzU)U9!!B^B^B^B^B^zzzzzzzzzYvzzzQk1111!E+!E+!E+!rzzzzzz111)E:E:EEEE!FFFFFFFFF+1E E EEEE!rUz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzz1111JiYYf1fEzQs11!E!E.E!E.EEEE!!rzzzzzzzzzYvzzzz!vvvvzzz11f@zzzzzzz11!ve1)fWFFFFFFFFF1F!vFF1 f1!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzz 11!zzB^zz!!v8vPzz11!f1fEzzzz111!!!EEE!!!ffffzzzzBWrYvzzzzrJbz1f@1zzzzzzzzffff1)FFFFFFFFF!EFA&Fffff1 z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzB^JiB^zzrJizffff11!zzzzzzzzz! Yvzzzzzffff)U5z Jbzzzzzzzzvv111fWUHFFFFFFFFFvvvFFfUFJ4z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzf1fEB^zzzf1fEU)U9zJizzzzzzzzzzBWYvzzzzzBW rzzzzzzzzvFFFFFFFFFUUU1!FF0!rUz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzr11!B^zzzYB^rzzzzzzzzzzzYvzzzzz! 1f@zzzzzzzzzEEEEE11ff! ffffFFFFFFFFF!EFFF!ffffz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzcύ B^zzzz!! ffffzzzzzzzzzzzzBWkߎzzzzzYvBWkߎzzzzzzzzzvFFFFFFFFFFFF0!z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzkߘkߘzzzzYB^zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzFFFFFFFFFFFFFFFFFFFFFFFFz[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[z[zzzzzzzzzzzzzzzzzzzzzzzzlibgd-gd-2.1.1/examples/resize.c000066400000000000000000000020211245535672000164530ustar00rootroot00000000000000#include "gd.h" #include #include int main (int argc, char *argv[]) { FILE *fp; gdImagePtr in, out; int w, h; /* Help */ if (argc<=4) { printf("%s input.jpg output.jpg width height\n", argv[0]); return 1; } /* Size */ w = atoi(argv[3]); h = atoi(argv[4]); if (w<=0 || h<=0) { fprintf(stderr, "Bad size %dx%d\n", h, w); return 2; } /* Input */ fp = fopen(argv[1], "rb"); if (!fp) { fprintf(stderr, "Can't read image %s\n", argv[1]); return 3; } in = gdImageCreateFromJpeg(fp); fclose(fp); if (!in) { fprintf(stderr, "Can't create image from %s\n", argv[1]); return 4; } /* Resize */ gdImageSetInterpolationMethod(in, GD_BILINEAR_FIXED); out = gdImageScale(in, w, h); if (!out) { fprintf(stderr, "gdImageScale fails\n"); return 5; } /* Output */ fp = fopen(argv[2], "wb"); if (!fp) { fprintf(stderr, "Can't save image %s\n", argv[2]); return 6; } gdImageJpeg(out, fp, 90); fclose(fp); /* Cleanups */ gdImageDestroy(in); gdImageDestroy(out); return 0; }libgd-gd-2.1.1/examples/test_crop_threshold.png000066400000000000000000000173571245535672000216140ustar00rootroot00000000000000PNG  IHDRdHNsRGBbKGD pHYs  tIME 5|tEXtCommentCreated with GIMPWJIDATxͼ1. d}>!SЖY maBWȜUһ"G VXJfI qPKSؗgmLXbͯg̀ZAKGjZ}j4?am[/[TWs<}]P*8C0l};<*Q 1FӾh{xi`OސG=6}a I6b3[c-M1*kEnWʪχ k-@{_!?7{0?r?ro8۞_j/ou=(ٻ7.?rw9b:ߴˬU=s͙h`&ٟPߵec͐SԮˆЖ~7ʴNzćd;Nnh十>z<ͥ*Nwʍ,U-KKc5YciaЋ:$r[ݖ¯hOBxMb0@mia=a5Np$fl_nSΎ5[: Zvf2pԎe#Ϭ})w\4 (3NJ0%97Z'(V Lhx}rfm]3i7:Љ =:u4wi_RHBX8 W[jȉ;9 +$Zay}˭p)]w{aN6𲰮x%Keg}v֩<,=kӣ[3l \qDס=a_[ȶjg]agyP . LCk BTGP,w_~*Cmgx؜g Hjkݶ^ :gn5(XoOUB ۏvm˟=>oiMZI,?wbӳG!>0C nNiY BtvYRdmk,]}&k"{F~y^ѻng+lo3,99Owvm`~㕰_ ,_6̌$8R^J]jKiY0 zo$Ӿ8#,9'xlRj1ݸ/htg"6*ܤ2-ˋx ?r dNJ*enU jjR! M{e}Œ#:|.k0~~( y.#fϼM^rn -!%+Tޜ<T̲7TݮOǬrwG6Y;YN{g4v7u|x o}w ezo^=sלw4c$qj 9v洼*:T~'Wd,fX*"zuGx;QrXhMt􁢟7h*?*~鲶FOtPPSOgةf8V9Fejﴰ-q>څ6zO`&{4N8MztZ$r4p-5vQ󱂊nqrV-S>><M^Ewpk(IsNy{?^@5-J 5F})F)mm).뫉nOA1}q#% ubTXѐD/cmΨ:ߺ]a*'W&]t4›M:Ol{uam8,"*l,byʩ iױ+k0}ê=7C犫GWY[Om3tParΐ#+=(=zxP16<;nW5MS dbo:,[LUЁQr:4*4dED6&,*35|`S{X>5`4ۀHi;؟Qm(DZ,a1>*#J~ch|jxߊSb±NHo>>)`Wޅ8?ᙢlr vh: v8ÔoOaG 6S5wwa棓yLx|jPZ&;Xk 8X؝0P=ʯ` po-%\2{C91 sL2S S*:+>]::Vj1XŬ#M껬O{8wa"7'hB峞ALn)O'xb>_撉=;[{;\"@ f˼iH&iqͧ}i)ӧXp C>,4ku /i,7ʂǘeDN]޼gX mцd9j26T=(uyd>ZtrCɉg;ɑQxz_Y>7E#ua o)os(YZblOvPYlU7=|LWjT]F~)-75'<ڬJ3T ({ղQ: BmXa[;;7"aoB(?=)ߺ&Ľ{sxF +`4ǃMy[KrNSs@ LSߨ1-yu01b?Y4*z:oma*Z9(t7Ce!ѼpX P2FW963}~:vsl w^| 5bŦ`|Р#;FrV-?!ɶuڙ;'C'Z9 em%Qv6qUNu㻅A+ LK$3U=yձ☣MnaNmpdU2Xjm{}2Ӑ2Q3^QCjGM>b4W޿ ib-9ʺnYBŚȴWeռ+RFWٲ@Dw>ӎpw >h+n9=<_t}R6Z@ƒz+۫H-G uS,S#9лqmc,ҬsWì5Р.gbf%fٶ]hp5DH̛ӐNϡkg, aǾ;~b<:tá9i'}V Iakܪ,L}aU۲0Z ?P^ClنlA-\#)喬̚OX$#> L׆C5Tr /GW2m;5!o?9v!MY3`BՖ:fE>M7okO,vۭʧqPc}YN끡]E24u蜭NϑI^|wF G*;zt𡑯c8cKuF-UR~.+*+uρ`|F_mX%J@w(5I.`ilfWi4 Y"mu4@Bѡ^{.Ӯa5կ|2ejd0E`fitB25nSa'Y!͒]h&W,ȏqU^kZ~HT9Y=8~m$+a< <;AuFI3@cJhrf? :}ly)FMj۷0t [b1!Rgu`xyͽ2ܭ-tƞ"0][ԟJ1f÷g_}-O[~: WH.1Oztր XW_{*pzJq_?LY&[:^ov脇K EuQ6RHځThoՄԠyrLdtܞ ^Ü ;y 0N ~a.2.7Fu߈N"}w:Vk\gU=/Mi ;0sf)+ U{ ̓6h{_ {b!PD mӺ}8 /5Cw^K@h3 *$!"r_7Pq| nRavxzke;\yLuCUʓkv!>Iw?| ꑘ^S5ч!5_(_rV\M,Xf'{0.i)'/ORʖ#Ɂ\lBlؒYtU=F6ΤK-ng;njh5ro3ا.Vc.4c qic &ƈtV5Vh5]fHCVG2E7NG_aAА{5^ ݣQN[tu 4mX#aRm≠GE/lW9钥UztgA>+z{O/7.E;P_Jc, )i}J 1f- FbC#ϐRߖFى"m|%b;&#hXB||ζpcxTlDMz>1:oK=CX-?CV7w:6? !va =\6{ ȾJږ.xRD?t=}H 5GɆڲ,Y_|Ͷ'xOmß1ro"?2TrSgtKmON]ueC_G1Gnigr}ҭڻqXgɁ},˭,cC^Z]N>@ 0]pSRPBZ[L0VqLڛըIu{(YYۊv5zfV=Wu̎^S:@njOΡ$x])tlֶrk=~ފw,EuIo 0PR\>n^ qX yɷܼFT-U'az|--u1%E C3mn26n)=kdܥlK8UuHZ6emS#( ^cl/n hG/ĩ3qU2.g,WO2|&fbwl"2^}#G A\*-@~t7LzY3r{gh9/ڇofjwEk)Ga=FnYEfj#hGp5N<*2=Aqv7>fY?}"1{5U3#@a \cFO x[F }2f)'*hk?9OtQ]Ojp0x;n}u1v'g%h*~yqdŽdoPlRqzPf=8= &{v nuof@ 3L{o!Zh쪀G3wUg)]{|X~b{& G٦'+t뚢qz?Z3JZYQ+9| %<>8p~nXme H _ cL3Ѡ0?X<OMǻ,|d@v;x '_1Iq=)dTwp<{dUVwOa .OVfwrށ}zrigԛKn'wo$vUqIENDB`libgd-gd-2.1.1/examples/tgaread.c000066400000000000000000000017171245535672000165740ustar00rootroot00000000000000/* $Id$ */ /* * You can fetch a set of samples TIFF images here: * ftp://ftp.remotesensing.org/pub/libtiff/ * (pics-x.y.z.tar.gz) */ #include #include #include int main() { gdImagePtr im; FILE *fp; char path[4][2048]; int i; char dst[2048]; sprintf(path[0], "noIconAlpha.tga"); sprintf(path[1], "noIcon.tga"); for (i = 0; i < 2; i++) { printf("opening %s\n", path[i]); fp = fopen(path[i], "rb"); if (!fp) { printf("failed, cannot open file\n"); return 1; } im = gdImageCreateFromTga(fp); fclose(fp); if (!im) { fprintf(stderr, "Can't load TIFF image %s\n", path[i]); return 1; } sprintf(dst, "%i.png", i); fp = fopen(dst, "wb"); if (!fp) { fprintf(stderr, "Can't save png image fromtiff.png\n"); gdImageDestroy(im); return 1; } #ifdef HAVE_LIBPNG gdImagePng(im, fp); #else printf("No PNG support. Cannot save image.\n"); #endif fclose(fp); gdImageDestroy(im); } return 0; } libgd-gd-2.1.1/examples/tiffread.c000066400000000000000000000021551245535672000167460ustar00rootroot00000000000000/* $Id$ */ /* * You can fetch a set of samples TIFF images here: * ftp://ftp.remotesensing.org/pub/libtiff/ * (pics-x.y.z.tar.gz) */ #include #include #include int main() { gdImagePtr im; FILE *fp; char path[9][2048]; int i; char dst[2048]; sprintf(path[0], "cramps-tile.tif"); sprintf(path[1], "cramps.tif"); sprintf(path[2], "ycbcr-cat.tif"); sprintf(path[3], "jello.tif"); sprintf(path[4], "caspian.tif"); sprintf(path[5], "strike.tif"); sprintf(path[6], "off_luv24.tif"); sprintf(path[7], "off_l16.tif"); sprintf(path[8], "fax2d.tif"); for (i = 0; i < 9; i++) { printf("opening %s\n", path[i]); fp = fopen(path[i], "rb"); if (!fp) { printf("failed, cannot open file\n"); return 1; } im = gdImageCreateFromTiff(fp); fclose(fp); if (!im) { fprintf(stderr, "Can't load TIFF image %s\n", path[i]); return 1; } sprintf(dst, "%i.png", i); fp = fopen(dst, "wb"); if (!fp) { fprintf(stderr, "Can't save png image fromtiff.png\n"); gdImageDestroy(im); return 1; } gdImagePng(im, fp); fclose(fp); gdImageDestroy(im); } return 0; } libgd-gd-2.1.1/examples/windows.c000066400000000000000000000164631245535672000166630ustar00rootroot00000000000000/* Sample usage of GD on windows. This little program opens a window, fetch its DIB and assigns to a GD truecolor image. Thanks to Mateusz Loskot (http://mateusz.loskot.net) for the AttachBuffer function! $Id$ */ #include #include #include #include gdImagePtr gdImageTrueColorAttachBuffer(int* buffer, int sx, int sy, int stride) { int i; int height; int* rowptr; gdImagePtr im; im = (gdImage *) malloc (sizeof (gdImage)); if (!im) { return 0; } memset (im, 0, sizeof (gdImage)); #if 0 if (overflow2(sizeof (int *), sy)) { return 0; } #endif im->tpixels = (int **) malloc (sizeof (int *) * sy); if (!im->tpixels) { free(im); return 0; } im->polyInts = 0; im->polyAllocated = 0; im->brush = 0; im->tile = 0; im->style = 0; height = sy; rowptr = buffer; if (stride < 0) { int startoff = (height - 1) * stride; rowptr = buffer - startoff; } i = 0; while (height--) { im->tpixels[i] = rowptr; rowptr += stride; i++; } im->sx = sx; im->sy = sy; im->transparent = (-1); im->interlace = 0; im->trueColor = 1; im->saveAlphaFlag = 0; im->alphaBlendingFlag = 1; im->thick = 1; im->AA = 0; im->cx1 = 0; im->cy1 = 0; im->cx2 = im->sx - 1; im->cy2 = im->sy - 1; return im; } void gdImageDetachBuffer(gdImagePtr im) { free(im->tpixels); free(im); } BITMAPINFO gdCreateBmp(int width, int height) { BITMAPINFO bmp_info; // Configure bitmap properties ZeroMemory(&bmp_info, sizeof(BITMAPINFO)); bmp_info.bmiHeader.biSize = sizeof(BITMAPINFOHEADER); bmp_info.bmiHeader.biWidth = width; bmp_info.bmiHeader.biHeight = height; bmp_info.bmiHeader.biPlanes = 1; bmp_info.bmiHeader.biBitCount = 32; bmp_info.bmiHeader.biCompression = BI_RGB; bmp_info.bmiHeader.biSizeImage = 0; bmp_info.bmiHeader.biXPelsPerMeter = 0; bmp_info.bmiHeader.biYPelsPerMeter = 0; bmp_info.bmiHeader.biClrUsed = 0; bmp_info.bmiHeader.biClrImportant = 0; return bmp_info; } LRESULT CALLBACK WndProc (HWND, UINT, WPARAM, LPARAM) ; int WINAPI WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, PSTR szCmdLine, int iCmdShow) { static TCHAR szAppName[] = TEXT ("Bezier") ; HWND hwnd ; MSG msg ; WNDCLASS wndclass ; wndclass.style = CS_HREDRAW | CS_VREDRAW ; wndclass.lpfnWndProc = WndProc ; wndclass.cbClsExtra = 0 ; wndclass.cbWndExtra = 0 ; wndclass.hInstance = hInstance ; wndclass.hIcon = LoadIcon (NULL, IDI_APPLICATION) ; wndclass.hCursor = LoadCursor (NULL, IDC_ARROW) ; wndclass.hbrBackground = (HBRUSH) GetStockObject (WHITE_BRUSH) ; wndclass.lpszMenuName = NULL ; wndclass.lpszClassName = szAppName ; if (!RegisterClass (&wndclass)) { // UNICODE-Compilierung ist die einzige realistische Fehlermöglichkeit MessageBox (NULL, TEXT ("Programm arbeitet mit Unicode und setzt Windows NT voraus!"), szAppName, MB_ICONERROR) ; return 0 ; } hwnd = CreateWindow (szAppName, TEXT ("Bezierkurven"), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, NULL, hInstance, NULL) ; ShowWindow (hwnd, iCmdShow) ; UpdateWindow (hwnd) ; while (GetMessage (&msg, NULL, 0, 0)) { TranslateMessage (&msg) ; DispatchMessage (&msg) ; } return msg.wParam ; } void DrawBezier (HDC hdc, POINT apt[]) { PolyBezier (hdc, apt, 4) ; MoveToEx (hdc, apt[0].x, apt[0].y, NULL) ; LineTo (hdc, apt[1].x, apt[1].y) ; MoveToEx (hdc, apt[2].x, apt[2].y, NULL) ; LineTo (hdc, apt[3].x, apt[3].y) ; } void gdDrawImage(HDC hdc, RECT *rc) { HDC mem_dc; BITMAPINFO bmp_info; void* bits; HBITMAP bmp, temp; gdImagePtr im; int width, height, stride; int white, black, blue, red; char *s = "Hello world!"; gdFontPtr lfont, gfont; width = rc->right - rc->left; height = rc->bottom - rc->top; bmp_info = gdCreateBmp(width, height); // Create memory device context mem_dc = CreateCompatibleDC(hdc); if (!mem_dc) { MessageBox(NULL, "Can't create a compatible DC!", "Error!", MB_ICONEXCLAMATION | MB_OK); return; } // bits points to a shared buffer of pixels bits = NULL; bmp = CreateDIBSection(mem_dc, &bmp_info, DIB_RGB_COLORS, (void**)&bits, 0, 0); // Selecting the object before doing anything allows you to use libgd // together with native Windows GDI. temp = (HBITMAP)SelectObject(mem_dc, bmp); /*stride = ((width * 1 + 3) >> 2) << 2;*/ // always uses 32bit in BMPINFO stride = width; im = NULL; // Attach shared buffer of pixels to GD image // Negative stride places 0,0 in upper-left corner im = gdImageTrueColorAttachBuffer((int*)bits, width, height, -stride); if (!im) { MessageBox(NULL, "GD image creation failed!", "Error!", MB_ICONEXCLAMATION | MB_OK); return; } // Start of GD drawing white = gdImageColorAllocate(im, 255, 255, 255); black = gdImageColorAllocate(im, 0, 0, 0); blue = gdImageColorAllocate(im, 0, 0, 255); // Allocate the color red, 50% transparent. red = gdImageColorAllocateAlpha(im, 255, 0, 0, 64); // Erase background with white color gdImageFilledRectangle(im, 0, 0, width, height, 0xFF0000); lfont = gdFontGetLarge(); gfont = gdFontGetGiant(); // Draw a dashed line from the upper left corner to the lower right corner. gdImageFilledRectangle(im, 25, 25, 100, 100, blue); gdImageChar(im, gfont, 35, 35, 'Q', white); gdImageFilledRectangle(im, 50, 50, 75, 175, red); gdImageLine(im, 0, 0, 150, 150, black); gdImageString(im, gdFontGetLarge(), im->sx / 2 - (strlen(s) * lfont->w / 2), im->sy / 2 - lfont->h / 2, (unsigned char*)s, black); // Copy drawing from memory context (shared bitmap buffer) to screen DC. BitBlt(hdc, rc->left, rc->top, width, height, mem_dc, 0, 0, SRCCOPY); // Free gdImageDetachBuffer(im); SelectObject(mem_dc, temp); DeleteObject(bmp); DeleteObject(mem_dc); } LRESULT CALLBACK WndProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { static POINT apt[4] ; HDC hdc ; int cxClient, cyClient ; PAINTSTRUCT ps ; RECT rc; GetClientRect(hwnd, &rc); switch (message) { case WM_SIZE: cxClient = LOWORD (lParam) ; cyClient = HIWORD (lParam) ; apt[0].x = cxClient / 4 ; apt[0].y = cyClient / 2 ; apt[1].x = cxClient / 2 ; apt[1].y = cyClient / 4 ; apt[2].x = cxClient / 2 ; apt[2].y = 3 * cyClient / 4 ; apt[3].x = 3 * cxClient / 4 ; apt[3].y = cyClient / 2 ; return 0 ; case WM_LBUTTONDOWN: case WM_RBUTTONDOWN: case WM_MOUSEMOVE: if (wParam & MK_LBUTTON || wParam & MK_RBUTTON) { hdc = GetDC (hwnd) ; // alte Kurve löschen (mit Weiß übermalen) SelectObject (hdc, GetStockObject (WHITE_PEN)) ; DrawBezier (hdc, apt) ; if (wParam & MK_LBUTTON) { apt[1].x = LOWORD (lParam) ; apt[1].y = HIWORD (lParam) ; } if (wParam & MK_RBUTTON) { apt[2].x = LOWORD (lParam) ; apt[2].y = HIWORD (lParam) ; } // neue Kurve (mit Schwarz) zeichnen SelectObject (hdc, GetStockObject (BLACK_PEN)) ; gdDrawImage(hdc, &rc); DrawBezier (hdc, apt) ; ReleaseDC (hwnd, hdc) ; } return 0 ; case WM_PAINT: hdc = BeginPaint (hwnd, &ps) ; GetClientRect(hwnd, &rc); gdDrawImage(hdc, &rc); DrawBezier (hdc, apt) ; EndPaint (hwnd, &ps) ; return 0 ; case WM_DESTROY: PostQuitMessage (0) ; return 0 ; } return DefWindowProc (hwnd, message, wParam, lParam) ; } libgd-gd-2.1.1/m4/000077500000000000000000000000001245535672000135155ustar00rootroot00000000000000libgd-gd-2.1.1/m4/ax_pthread.m4000066400000000000000000000312671245535672000161070ustar00rootroot00000000000000# =========================================================================== # http://www.gnu.org/software/autoconf-archive/ax_pthread.html # =========================================================================== # # SYNOPSIS # # AX_PTHREAD([ACTION-IF-FOUND[, ACTION-IF-NOT-FOUND]]) # # DESCRIPTION # # This macro figures out how to build C programs using POSIX threads. It # sets the PTHREAD_LIBS output variable to the threads library and linker # flags, and the PTHREAD_CFLAGS output variable to any special C compiler # flags that are needed. (The user can also force certain compiler # flags/libs to be tested by setting these environment variables.) # # Also sets PTHREAD_CC to any special C compiler that is needed for # multi-threaded programs (defaults to the value of CC otherwise). (This # is necessary on AIX to use the special cc_r compiler alias.) # # NOTE: You are assumed to not only compile your program with these flags, # but also link it with them as well. e.g. you should link with # $PTHREAD_CC $CFLAGS $PTHREAD_CFLAGS $LDFLAGS ... $PTHREAD_LIBS $LIBS # # If you are only building threads programs, you may wish to use these # variables in your default LIBS, CFLAGS, and CC: # # LIBS="$PTHREAD_LIBS $LIBS" # CFLAGS="$CFLAGS $PTHREAD_CFLAGS" # CC="$PTHREAD_CC" # # In addition, if the PTHREAD_CREATE_JOINABLE thread-attribute constant # has a nonstandard name, defines PTHREAD_CREATE_JOINABLE to that name # (e.g. PTHREAD_CREATE_UNDETACHED on AIX). # # Also HAVE_PTHREAD_PRIO_INHERIT is defined if pthread is found and the # PTHREAD_PRIO_INHERIT symbol is defined when compiling with # PTHREAD_CFLAGS. # # ACTION-IF-FOUND is a list of shell commands to run if a threads library # is found, and ACTION-IF-NOT-FOUND is a list of commands to run it if it # is not found. If ACTION-IF-FOUND is not specified, the default action # will define HAVE_PTHREAD. # # Please let the authors know if this macro fails on any platform, or if # you have any other suggestions or comments. This macro was based on work # by SGJ on autoconf scripts for FFTW (http://www.fftw.org/) (with help # from M. Frigo), as well as ac_pthread and hb_pthread macros posted by # Alejandro Forero Cuervo to the autoconf macro repository. We are also # grateful for the helpful feedback of numerous users. # # Updated for Autoconf 2.68 by Daniel Richard G. # # LICENSE # # Copyright (c) 2008 Steven G. Johnson # Copyright (c) 2011 Daniel Richard G. # # This program is free software: you can redistribute it and/or modify it # under the terms of the GNU General Public License as published by the # Free Software Foundation, either version 3 of the License, or (at your # option) any later version. # # This program is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General # Public License for more details. # # You should have received a copy of the GNU General Public License along # with this program. If not, see . # # As a special exception, the respective Autoconf Macro's copyright owner # gives unlimited permission to copy, distribute and modify the configure # scripts that are the output of Autoconf when processing the Macro. You # need not follow the terms of the GNU General Public License when using # or distributing such scripts, even though portions of the text of the # Macro appear in them. The GNU General Public License (GPL) does govern # all other use of the material that constitutes the Autoconf Macro. # # This special exception to the GPL applies to versions of the Autoconf # Macro released by the Autoconf Archive. When you make and distribute a # modified version of the Autoconf Macro, you may extend this special # exception to the GPL to apply to your modified version as well. #serial 20 AU_ALIAS([ACX_PTHREAD], [AX_PTHREAD]) AC_DEFUN([AX_PTHREAD], [ AC_REQUIRE([AC_CANONICAL_HOST]) AC_LANG_PUSH([C]) ax_pthread_ok=no # We used to check for pthread.h first, but this fails if pthread.h # requires special compiler flags (e.g. on True64 or Sequent). # It gets checked for in the link test anyway. # First of all, check if the user has set any of the PTHREAD_LIBS, # etcetera environment variables, and if threads linking works using # them: if test x"$PTHREAD_LIBS$PTHREAD_CFLAGS" != x; then save_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS $PTHREAD_CFLAGS" save_LIBS="$LIBS" LIBS="$PTHREAD_LIBS $LIBS" AC_MSG_CHECKING([for pthread_join in LIBS=$PTHREAD_LIBS with CFLAGS=$PTHREAD_CFLAGS]) AC_TRY_LINK_FUNC(pthread_join, ax_pthread_ok=yes) AC_MSG_RESULT($ax_pthread_ok) if test x"$ax_pthread_ok" = xno; then PTHREAD_LIBS="" PTHREAD_CFLAGS="" fi LIBS="$save_LIBS" CFLAGS="$save_CFLAGS" fi # We must check for the threads library under a number of different # names; the ordering is very important because some systems # (e.g. DEC) have both -lpthread and -lpthreads, where one of the # libraries is broken (non-POSIX). # Create a list of thread flags to try. Items starting with a "-" are # C compiler flags, and other items are library names, except for "none" # which indicates that we try without any flags at all, and "pthread-config" # which is a program returning the flags for the Pth emulation library. ax_pthread_flags="pthreads none -Kthread -kthread lthread -pthread -pthreads -mthreads pthread --thread-safe -mt pthread-config" # The ordering *is* (sometimes) important. Some notes on the # individual items follow: # pthreads: AIX (must check this before -lpthread) # none: in case threads are in libc; should be tried before -Kthread and # other compiler flags to prevent continual compiler warnings # -Kthread: Sequent (threads in libc, but -Kthread needed for pthread.h) # -kthread: FreeBSD kernel threads (preferred to -pthread since SMP-able) # lthread: LinuxThreads port on FreeBSD (also preferred to -pthread) # -pthread: Linux/gcc (kernel threads), BSD/gcc (userland threads) # -pthreads: Solaris/gcc # -mthreads: Mingw32/gcc, Lynx/gcc # -mt: Sun Workshop C (may only link SunOS threads [-lthread], but it # doesn't hurt to check since this sometimes defines pthreads too; # also defines -D_REENTRANT) # ... -mt is also the pthreads flag for HP/aCC # pthread: Linux, etcetera # --thread-safe: KAI C++ # pthread-config: use pthread-config program (for GNU Pth library) case ${host_os} in solaris*) # On Solaris (at least, for some versions), libc contains stubbed # (non-functional) versions of the pthreads routines, so link-based # tests will erroneously succeed. (We need to link with -pthreads/-mt/ # -lpthread.) (The stubs are missing pthread_cleanup_push, or rather # a function called by this macro, so we could check for that, but # who knows whether they'll stub that too in a future libc.) So, # we'll just look for -pthreads and -lpthread first: ax_pthread_flags="-pthreads pthread -mt -pthread $ax_pthread_flags" ;; darwin*) ax_pthread_flags="-pthread $ax_pthread_flags" ;; esac if test x"$ax_pthread_ok" = xno; then for flag in $ax_pthread_flags; do case $flag in none) AC_MSG_CHECKING([whether pthreads work without any flags]) ;; -*) AC_MSG_CHECKING([whether pthreads work with $flag]) PTHREAD_CFLAGS="$flag" ;; pthread-config) AC_CHECK_PROG(ax_pthread_config, pthread-config, yes, no) if test x"$ax_pthread_config" = xno; then continue; fi PTHREAD_CFLAGS="`pthread-config --cflags`" PTHREAD_LIBS="`pthread-config --ldflags` `pthread-config --libs`" ;; *) AC_MSG_CHECKING([for the pthreads library -l$flag]) PTHREAD_LIBS="-l$flag" ;; esac save_LIBS="$LIBS" save_CFLAGS="$CFLAGS" LIBS="$PTHREAD_LIBS $LIBS" CFLAGS="$CFLAGS $PTHREAD_CFLAGS" # Check for various functions. We must include pthread.h, # since some functions may be macros. (On the Sequent, we # need a special flag -Kthread to make this header compile.) # We check for pthread_join because it is in -lpthread on IRIX # while pthread_create is in libc. We check for pthread_attr_init # due to DEC craziness with -lpthreads. We check for # pthread_cleanup_push because it is one of the few pthread # functions on Solaris that doesn't have a non-functional libc stub. # We try pthread_create on general principles. AC_LINK_IFELSE([AC_LANG_PROGRAM([#include static void routine(void *a) { a = 0; } static void *start_routine(void *a) { return a; }], [pthread_t th; pthread_attr_t attr; pthread_create(&th, 0, start_routine, 0); pthread_join(th, 0); pthread_attr_init(&attr); pthread_cleanup_push(routine, 0); pthread_cleanup_pop(0) /* ; */])], [ax_pthread_ok=yes], []) LIBS="$save_LIBS" CFLAGS="$save_CFLAGS" AC_MSG_RESULT($ax_pthread_ok) if test "x$ax_pthread_ok" = xyes; then break; fi PTHREAD_LIBS="" PTHREAD_CFLAGS="" done fi # Various other checks: if test "x$ax_pthread_ok" = xyes; then save_LIBS="$LIBS" LIBS="$PTHREAD_LIBS $LIBS" save_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS $PTHREAD_CFLAGS" # Detect AIX lossage: JOINABLE attribute is called UNDETACHED. AC_MSG_CHECKING([for joinable pthread attribute]) attr_name=unknown for attr in PTHREAD_CREATE_JOINABLE PTHREAD_CREATE_UNDETACHED; do AC_LINK_IFELSE([AC_LANG_PROGRAM([#include ], [int attr = $attr; return attr /* ; */])], [attr_name=$attr; break], []) done AC_MSG_RESULT($attr_name) if test "$attr_name" != PTHREAD_CREATE_JOINABLE; then AC_DEFINE_UNQUOTED(PTHREAD_CREATE_JOINABLE, $attr_name, [Define to necessary symbol if this constant uses a non-standard name on your system.]) fi AC_MSG_CHECKING([if more special flags are required for pthreads]) flag=no case ${host_os} in aix* | freebsd* | darwin*) flag="-D_THREAD_SAFE";; osf* | hpux*) flag="-D_REENTRANT";; solaris*) if test "$GCC" = "yes"; then flag="-D_REENTRANT" else flag="-mt -D_REENTRANT" fi ;; esac AC_MSG_RESULT(${flag}) if test "x$flag" != xno; then PTHREAD_CFLAGS="$flag $PTHREAD_CFLAGS" fi AC_CACHE_CHECK([for PTHREAD_PRIO_INHERIT], ax_cv_PTHREAD_PRIO_INHERIT, [ AC_LINK_IFELSE([ AC_LANG_PROGRAM([[#include ]], [[int i = PTHREAD_PRIO_INHERIT;]])], [ax_cv_PTHREAD_PRIO_INHERIT=yes], [ax_cv_PTHREAD_PRIO_INHERIT=no]) ]) AS_IF([test "x$ax_cv_PTHREAD_PRIO_INHERIT" = "xyes"], AC_DEFINE([HAVE_PTHREAD_PRIO_INHERIT], 1, [Have PTHREAD_PRIO_INHERIT.])) LIBS="$save_LIBS" CFLAGS="$save_CFLAGS" # More AIX lossage: compile with *_r variant if test "x$GCC" != xyes; then case $host_os in aix*) AS_CASE(["x/$CC"], [x*/c89|x*/c89_128|x*/c99|x*/c99_128|x*/cc|x*/cc128|x*/xlc|x*/xlc_v6|x*/xlc128|x*/xlc128_v6], [#handle absolute path differently from PATH based program lookup AS_CASE(["x$CC"], [x/*], [AS_IF([AS_EXECUTABLE_P([${CC}_r])],[PTHREAD_CC="${CC}_r"])], [AC_CHECK_PROGS([PTHREAD_CC],[${CC}_r],[$CC])])]) ;; esac fi fi test -n "$PTHREAD_CC" || PTHREAD_CC="$CC" AC_SUBST(PTHREAD_LIBS) AC_SUBST(PTHREAD_CFLAGS) AC_SUBST(PTHREAD_CC) # Finally, execute ACTION-IF-FOUND/ACTION-IF-NOT-FOUND: if test x"$ax_pthread_ok" = xyes; then ifelse([$1],,AC_DEFINE(HAVE_PTHREAD,1,[Define if you have POSIX threads libraries and header files.]),[$1]) : else ax_pthread_ok=no $2 fi AC_LANG_POP ])dnl AX_PTHREAD libgd-gd-2.1.1/m4/visibility.m4000066400000000000000000000041301245535672000161440ustar00rootroot00000000000000# visibility.m4 serial 1 (gettext-0.15) dnl Copyright (C) 2005 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl Tests whether the compiler supports the command-line option dnl -fvisibility=hidden and the function and variable attributes dnl __attribute__((__visibility__("hidden"))) and dnl __attribute__((__visibility__("default"))). dnl Does *not* test for __visibility__("protected") - which has tricky dnl semantics (see the 'vismain' test in glibc) and does not exist e.g. on dnl MacOS X. dnl Does *not* test for __visibility__("internal") - which has processor dnl dependent semantics. dnl Does *not* test for #pragma GCC visibility push(hidden) - which is dnl "really only recommended for legacy code". dnl Set the variable CFLAG_VISIBILITY. dnl Defines and sets the variable HAVE_VISIBILITY. AC_DEFUN([gl_VISIBILITY], [ AC_REQUIRE([AC_PROG_CC]) CFLAG_VISIBILITY= HAVE_VISIBILITY=0 if test -n "$GCC"; then AC_MSG_CHECKING([for simple visibility declarations]) AC_CACHE_VAL(gl_cv_cc_visibility, [ gl_save_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -fvisibility=hidden" AC_TRY_COMPILE( [extern __attribute__((__visibility__("hidden"))) int hiddenvar; extern __attribute__((__visibility__("default"))) int exportedvar; extern __attribute__((__visibility__("hidden"))) int hiddenfunc (void); extern __attribute__((__visibility__("default"))) int exportedfunc (void);], [], gl_cv_cc_visibility=yes, gl_cv_cc_visibility=no) CFLAGS="$gl_save_CFLAGS"]) AC_MSG_RESULT([$gl_cv_cc_visibility]) if test $gl_cv_cc_visibility = yes; then CFLAG_VISIBILITY="-fvisibility=hidden" HAVE_VISIBILITY=1 fi fi AC_SUBST([CFLAG_VISIBILITY]) AC_SUBST([HAVE_VISIBILITY]) AC_DEFINE_UNQUOTED([HAVE_VISIBILITY], [$HAVE_VISIBILITY], [Define to 1 or 0, depending whether the compiler supports simple visibility declarations.]) ]) libgd-gd-2.1.1/m4/w32.m4000066400000000000000000000006201245535672000143700ustar00rootroot00000000000000# MINGW_AC_WIN32_NATIVE_HOST # -------------------------- # Check if the runtime platform is a native Win32 host. # AC_DEFUN([MINGW_AC_WIN32_NATIVE_HOST], [AC_CACHE_CHECK([whether we are building for a Win32 host], [mingw_cv_win32_host], AC_COMPILE_IFELSE([AC_LANG_SOURCE([[ #ifdef _WIN32 choke me #endif]])], [mingw_cv_win32_host=no], [mingw_cv_win32_host=yes]))dnl ])# MINGW_AC_WIN32_NATIVE_HOST libgd-gd-2.1.1/make_drone.io000077500000000000000000000012051245535672000156330ustar00rootroot00000000000000#!/bin/bash mkdir out sudo apt-get update -qq > /dev/null sudo apt-get -y install nasm > /dev/null ./thumbs.sh make || exit 1 ./thumbs.sh check || exit 1 objdump -f build/Bin/*.so | grep ^architecture ldd build/Bin/*.so tar -zcf out/libgd-x64.tar.gz --transform 's/.*\///' $(./thumbs.sh list) ./thumbs.sh clean sudo apt-get -y install gcc-multilib > /dev/null sudo apt-get -y install g++-multilib > /dev/null export tbs_arch=x86 ./thumbs.sh make || exit 1 ./thumbs.sh check || exit 1 objdump -f build/Bin/*.so | grep ^architecture ldd build/Bin/*.so tar -zcf out/libgd-x86.tar.gz --transform 's/.*\///' $(./thumbs.sh list) ./thumbs.sh clean libgd-gd-2.1.1/netware/000077500000000000000000000000001245535672000146425ustar00rootroot00000000000000libgd-gd-2.1.1/netware/Makefile.netware000066400000000000000000000351121245535672000177500ustar00rootroot00000000000000################################################################# # ## Makefile for building libgd.nlm (NetWare version - gnu make) ## Use: make -f Makefile ## ## Comments to: Guenter Knauf ## ## $Id$ # ################################################################# # Edit the path below to point to the base of your Novell NDK. ifndef NDKBASE NDKBASE = c:/novell endif # Base for the lib sources ifndef LIBBASE LIBBASE = ../.. endif # All library code is statically linked to avoid problems with other lib NLMs. # Edit the path below to point to your libpng sources or set environment var. ifndef LIBPNG LIBPNG = $(LIBBASE)/libpng-1.2.16 endif # Edit the path below to point to your libpng sources or set environment var. ifndef LIBJPEG LIBJPEG = $(LIBBASE)/jpeg-6b endif # Edit the path below to point to your freetype sources or set environment var. ifndef LIBFT2 LIBFT2 = $(LIBBASE)/freetype-2.3.4 endif # Edit the path below to point to your zlib sources or set environment var. ifndef ZLIBSDK ZLIBSDK = $(LIBBASE)/zlib-1.2.3 endif LIBGD = .. ifndef INSTDIR INSTDIR = libgd-$(LIBGD_VERSION_STR)-bin-nw endif # Edit the vars below to change NLM target settings. TARGET = libgd COPYR = Copyright (C) 1996-2007 Boutell.Com, Inc. WWW = http://www.libgd.org/ DESCR = libgd $(LIBGD_VERSION_STR) - $(WWW) MTSAFE = YES STACK = 64000 SCREEN = none EXPORTS = @$(TARGET).imp EPREFIX = LIBGD # Edit the var below to point to your lib architecture. ifndef LIBARCH LIBARCH = LIBC endif # must be equal to DEBUG or NDEBUG DB = NDEBUG # DB = DEBUG # Optimization: -O or debugging: -g ifeq ($(DB),NDEBUG) OPT = -O2 OBJDIR = release else OPT = -g OBJDIR = debug endif # Include the version info retrieved from xml2ver.h -include $(OBJDIR)/version.inc # The following line defines your compiler. ifdef METROWERKS CC = mwccnlm else CC = gcc endif # http://www.gknw.net/development/prgtools/awk.zip AWK = awk YACC = bison -y CP = cp -afv # RM = rm -f # if you want to mark the target as MTSAFE you will need a tool for # generating the xdc data for the linker; here's a minimal tool: # http://www.gknw.net/development/prgtools/mkxdc.zip MPKXDC = mkxdc PATCH = patch PERLRUN = perl # Global flags for all compilers CFLAGS = $(OPT) -D$(DB) -DNETWARE -DHAVE_CONFIG_H -nostdinc #CFLAGS += -DHAVE_LIBPNG=1 -DHAVE_LIBJPEG=1 #CFLAGS += -DHAVE_LIBFREETYPE=1 -DHAVE_FT2BUILD_H=1 #CFLAGS += -DHAVE_LIBZ=1 ifeq ($(CC),mwccnlm) LD = mwldnlm LDFLAGS = -nostdlib $(PRELUDE) $(OBJL) $(LDLIBS) -o $@ -commandfile AR = mwldnlm ARFLAGS = -type library -w nocmdline $(OBJS) -o LIBEXT = lib CFLAGS += -msgstyle gcc -gccinc -inline off -opt nointrinsics -proc 586 CFLAGS += -relax_pointers #CFLAGS += -w on ifeq ($(LIBARCH),LIBC) PRELUDE = $(SDK_LIBC)/imports/libcpre.o CFLAGS += -align 4 else PRELUDE = "$(METROWERKS)/Novell Support/libraries/runtime/prelude.obj" # CFLAGS += -include "$(METROWERKS)/Novell Support/headers/nlm_prefix.h" CFLAGS += -align 1 endif else LD = nlmconv LDFLAGS = -T AR = ar ARFLAGS = -cq LIBEXT = a CFLAGS += -fno-builtin -fpcc-struct-return -fno-strict-aliasing CFLAGS += -Wall -Wno-unused -Wno-main # -pedantic ifeq ($(LIBARCH),LIBC) PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o else PRELUDE = $(SDK_CLIB)/imports/clibpre.gcc.o CFLAGS += -include $(NDKBASE)/nlmconv/genlm.h endif endif NDK_ROOT = $(NDKBASE)/ndk SDK_CLIB = $(NDK_ROOT)/nwsdk SDK_LIBC = $(NDK_ROOT)/libc INCLUDES = -I. -I$(LIBGD) -I$(LIBPNG) -I$(LIBJPEG) -I$(LIBFT2)/include -I$(ZLIBSDK) ifeq ($(LIBARCH),LIBC) INCLUDES += -I$(SDK_LIBC)/include # INCLUDES += -I$(SDK_LIBC)/include/nks CFLAGS += -D_POSIX_SOURCE # CFLAGS += -D__ANSIC__ else INCLUDES += -I$(SDK_CLIB)/include/nlm # INCLUDES += -I$(SDK_CLIB)/include # INCLUDES += -I$(SDK_CLIB)/include/nlm/obsolete endif CFLAGS += $(INCLUDES) ifeq ($(MTSAFE),YES) XDCOPT = -n endif ifeq ($(MTSAFE),NO) XDCOPT = -u endif ifdef XDCOPT XDCDATA = $(OBJDIR)/$(TARGET).xdc endif ifeq ($(findstring linux,$(OSTYPE)),linux) DL = ' #-include $(NDKBASE)/nlmconv/ncpfs.inc endif GDLIBOBJS = \ $(OBJDIR)/gd.o \ $(OBJDIR)/gd_gd.o \ $(OBJDIR)/gd_gd2.o \ $(OBJDIR)/gd_gif_in.o \ $(OBJDIR)/gd_gif_out.o \ $(OBJDIR)/gd_io.o \ $(OBJDIR)/gd_io_dp.o \ $(OBJDIR)/gd_io_file.o \ $(OBJDIR)/gd_io_ss.o \ $(OBJDIR)/gd_jpeg.o \ $(OBJDIR)/gd_png.o \ $(OBJDIR)/gd_ss.o \ $(OBJDIR)/gd_topal.o \ $(OBJDIR)/gd_wbmp.o \ $(OBJDIR)/gdcache.o \ $(OBJDIR)/gdfontg.o \ $(OBJDIR)/gdfontl.o \ $(OBJDIR)/gdfontmb.o \ $(OBJDIR)/gdfonts.o \ $(OBJDIR)/gdfontt.o \ $(OBJDIR)/gdft.o \ $(OBJDIR)/gdfx.o \ $(OBJDIR)/gdhelpers.o \ $(OBJDIR)/gdkanji.o \ $(OBJDIR)/gdtables.o \ $(OBJDIR)/gdxpm.o \ $(OBJDIR)/wbmp.o \ $(EOLIST) ifeq "$(wildcard $(LIBGD)/gd_security.c)" "$(LIBGD)/gd_security.c" GDLIBOBJS += \ $(OBJDIR)/gd_security.o \ $(EOLIST) endif PNGLIBOBJS = \ $(OBJDIR)/png.o \ $(OBJDIR)/pngerror.o \ $(OBJDIR)/pngget.o \ $(OBJDIR)/pngmem.o \ $(OBJDIR)/pngpread.o \ $(OBJDIR)/pngread.o \ $(OBJDIR)/pngrio.o \ $(OBJDIR)/pngrtran.o \ $(OBJDIR)/pngrutil.o \ $(OBJDIR)/pngset.o \ $(OBJDIR)/pngtrans.o \ $(OBJDIR)/pngwio.o \ $(OBJDIR)/pngwrite.o \ $(OBJDIR)/pngwtran.o \ $(OBJDIR)/pngwutil.o \ $(EOLIST) ifeq "$(wildcard $(LIBPNG)/pnggccrd.c)" "$(LIBPNG)/pnggccrd.c" PNGLIBOBJS += \ $(OBJDIR)/pnggccrd.o \ $(OBJDIR)/pngvcrd.o \ $(EOLIST) endif OBJ_JPG = $(OBJDIR) JPGLIBOBJS = \ $(OBJ_JPG)/jcapimin.o \ $(OBJ_JPG)/jcapistd.o \ $(OBJ_JPG)/jccoefct.o \ $(OBJ_JPG)/jccolor.o \ $(OBJ_JPG)/jcdctmgr.o \ $(OBJ_JPG)/jchuff.o \ $(OBJ_JPG)/jcinit.o \ $(OBJ_JPG)/jcmainct.o \ $(OBJ_JPG)/jcmarker.o \ $(OBJ_JPG)/jcmaster.o \ $(OBJ_JPG)/jcomapi.o \ $(OBJ_JPG)/jcparam.o \ $(OBJ_JPG)/jcphuff.o \ $(OBJ_JPG)/jcprepct.o \ $(OBJ_JPG)/jcsample.o \ $(OBJ_JPG)/jctrans.o \ $(OBJ_JPG)/jdapimin.o \ $(OBJ_JPG)/jdapistd.o \ $(OBJ_JPG)/jdatadst.o \ $(OBJ_JPG)/jdatasrc.o \ $(OBJ_JPG)/jdcoefct.o \ $(OBJ_JPG)/jdcolor.o \ $(OBJ_JPG)/jddctmgr.o \ $(OBJ_JPG)/jdhuff.o \ $(OBJ_JPG)/jdinput.o \ $(OBJ_JPG)/jdmainct.o \ $(OBJ_JPG)/jdmarker.o \ $(OBJ_JPG)/jdmaster.o \ $(OBJ_JPG)/jdmerge.o \ $(OBJ_JPG)/jdphuff.o \ $(OBJ_JPG)/jdpostct.o \ $(OBJ_JPG)/jdsample.o \ $(OBJ_JPG)/jdtrans.o \ $(OBJ_JPG)/jerror.o \ $(OBJ_JPG)/jfdctflt.o \ $(OBJ_JPG)/jfdctfst.o \ $(OBJ_JPG)/jfdctint.o \ $(OBJ_JPG)/jidctflt.o \ $(OBJ_JPG)/jidctfst.o \ $(OBJ_JPG)/jidctint.o \ $(OBJ_JPG)/jidctred.o \ $(OBJ_JPG)/jquant1.o \ $(OBJ_JPG)/jquant2.o \ $(OBJ_JPG)/jutils.o \ $(OBJ_JPG)/jmemmgr.o \ $(OBJ_JPG)/jmemansi.o \ $(EOLIST) LIBFT2OBJS = \ $(OBJ_FT2)/autohint.o \ $(OBJ_FT2)/bdf.o \ $(OBJ_FT2)/cff.o \ $(OBJ_FT2)/ftbase.o \ $(OBJ_FT2)/ftcache.o \ $(OBJ_FT2)/ftglyph.o \ $(OBJ_FT2)/ftinit.o \ $(OBJ_FT2)/ftmm.o \ $(OBJ_FT2)/ftsystem.o \ $(OBJ_FT2)/pcf.o \ $(OBJ_FT2)/pfr.o \ $(OBJ_FT2)/psaux.o \ $(OBJ_FT2)/pshinter.o \ $(OBJ_FT2)/psmodule.o \ $(OBJ_FT2)/raster.o \ $(OBJ_FT2)/sfnt.o \ $(OBJ_FT2)/smooth.o \ $(OBJ_FT2)/truetype.o \ $(OBJ_FT2)/type1.o \ $(OBJ_FT2)/type1cid.o \ $(OBJ_FT2)/type42.o \ $(OBJ_FT2)/winfnt.o \ $(OBJ_FT2)/infutil.o \ $(OBJ_FT2)/ftgzip.o \ $(OBJ_FT2)/ftlzw.o \ $(OBJ_FT2)/ftpfr.o \ $(OBJ_FT2)/ftstroke.o \ $(OBJ_FT2)/ftsynth.o \ $(OBJ_FT2)/fttype1.o \ $(OBJ_FT2)/ftwinfnt.o \ $(OBJ_FT2)/ftxf86.o \ $(OBJ_FT2)/ftbbox.o \ $(EOLIST) ZLIBOBJS = \ $(OBJDIR)/adler32.o \ $(OBJDIR)/compress.o \ $(OBJDIR)/crc32.o \ $(OBJDIR)/deflate.o \ $(OBJDIR)/inflate.o \ $(OBJDIR)/inffast.o \ $(OBJDIR)/inftrees.o \ $(OBJDIR)/trees.o \ $(OBJDIR)/uncompr.o \ $(OBJDIR)/zutil.o \ $(EOLIST) ifeq "$(wildcard $(ZLIBSDK)/infblock.c)" "$(ZLIBSDK)/infblock.c" ZLIBOBJS += \ $(OBJDIR)/infblock.o \ $(OBJDIR)/infcodes.o \ $(OBJDIR)/infutil.o \ $(EOLIST) endif LDLIBS += $(LIBFT2)/builds/netware/LIBC/libft2.$(LIBEXT) OBJS := $(GDLIBOBJS) $(PNGLIBOBJS) $(JPGLIBOBJS) $(ZLIBOBJS) OBJL = $(OBJS) $(OBJDIR)/nwlibc.o vpath %.c . $(LIBGD) $(LIBPNG) $(LIBJPEG) $(ZLIBSDK) .PHONY: all prebuild dist install clean clean-all test-cmds help all: lib nlm nlm: prebuild $(TARGET).nlm lib: prebuild $(TARGET).$(LIBEXT) prebuild: $(OBJDIR) $(OBJDIR)/version.inc config.h $(OBJDIR)/%.o: %.c # @echo Compiling $< $(CC) $(CFLAGS) -c $< -o $@ $(OBJDIR)/version.inc: ../configure $(OBJDIR) @echo Creating $@ @$(AWK) -f get_ver.awk $< > $@ # TODO: get version info from src/gd.h dist: all -$(RM) -r $(OBJDIR)* install: $(INSTDIR) all @$(CP) $(TARGET).nlm $(INSTDIR) @$(CP) $(TARGET).$(LIBEXT) $(INSTDIR) @$(CP) ../CHANGES $(INSTDIR) @$(CP) ../COPYING $(INSTDIR) @$(CP) ../README $(INSTDIR) @$(CP) ../RELEASE-NOTES $(INSTDIR) clean: -$(RM) config.h -$(RM) -r $(OBJDIR)* -$(RM) $(TARGET).nlm $(TARGET).$(LIBEXT) $(TARGET).imp dist-clean: -$(RM) config.h -$(RM) -r $(OBJDIR)* clean-all: clean -$(MAKE) -C tests -f Makefile clean test-cmds: -$(MAKE) -C tests -f Makefile $(INSTDIR): @mkdir $(INSTDIR) $(OBJDIR): @mkdir $(OBJDIR) $(TARGET).$(LIBEXT): $(OBJS) @echo Creating $@ @-$(RM) $@ @$(AR) $(ARFLAGS) $@ $^ $(TARGET).nlm: $(OBJDIR)/$(TARGET).def $(TARGET).imp $(OBJL) $(XDCDATA) @echo Linking $@ @-$(RM) $@ @$(LD) $(LDFLAGS) $< $(OBJDIR)/%.xdc: Makefile @echo Creating $@ @$(MPKXDC) $(XDCOPT) $@ $(OBJDIR)/%.def: Makefile @echo $(DL)# DEF file for linking with $(LD)$(DL) > $@ @echo $(DL)# Do not edit this file - it is created by make!$(DL) >> $@ @echo $(DL)# All your changes will be lost!!$(DL) >> $@ @echo $(DL)#$(DL) >> $@ @echo $(DL)copyright "$(COPYR)"$(DL) >> $@ @echo $(DL)description "$(DESCR)"$(DL) >> $@ @echo $(DL)version $(LIBGD_VERSION)$(DL) >> $@ ifdef NLMTYPE @echo $(DL)type $(NLMTYPE)$(DL) >> $@ endif ifdef STACK @echo $(DL)stack $(STACK)$(DL) >> $@ endif ifdef SCREEN @echo $(DL)screenname "$(SCREEN)"$(DL) >> $@ else @echo $(DL)screenname "DEFAULT"$(DL) >> $@ endif ifeq ($(DB),DEBUG) @echo $(DL)debug$(DL) >> $@ endif @echo $(DL)threadname "$(TARGET)"$(DL) >> $@ ifdef XDCDATA @echo $(DL)xdcdata $(XDCDATA)$(DL) >> $@ endif @echo $(DL)flag_on 64$(DL) >> $@ ifeq ($(LIBARCH),CLIB) @echo $(DL)start _Prelude$(DL) >> $@ @echo $(DL)exit _Stop$(DL) >> $@ @echo $(DL)import @$(SDK_CLIB)/imports/clib.imp$(DL) >> $@ @echo $(DL)import @$(SDK_CLIB)/imports/threads.imp$(DL) >> $@ @echo $(DL)import @$(SDK_CLIB)/imports/nlmlib.imp$(DL) >> $@ @echo $(DL)import @$(SDK_CLIB)/imports/socklib.imp$(DL) >> $@ @echo $(DL)module clib$(DL) >> $@ else @echo $(DL)pseudopreemption$(DL) >> $@ @echo $(DL)start _LibCPrelude$(DL) >> $@ @echo $(DL)exit _LibCPostlude$(DL) >> $@ @echo $(DL)check _LibCCheckUnload$(DL) >> $@ @echo $(DL)import @$(SDK_LIBC)/imports/libc.imp$(DL) >> $@ @echo $(DL)import @$(SDK_LIBC)/imports/netware.imp$(DL) >> $@ @echo $(DL)module libc$(DL) >> $@ endif ifdef MODULES @echo $(DL)module $(MODULES)$(DL) >> $@ endif ifdef IMPORTS @echo $(DL)import $(IMPORTS)$(DL) >> $@ endif ifdef EXPORTS @echo $(DL)export $(EXPORTS)$(DL) >> $@ endif ifeq ($(LD),nlmconv) @echo $(DL)input $(OBJL)$(DL) >> $@ @echo $(DL)input $(PRELUDE)$(DL) >> $@ ifdef LDLIBS @echo $(DL)input $(LDLIBS)$(DL) >> $@ endif @echo $(DL)output $(TARGET).nlm$(DL) >> $@ endif config.h: Makefile @echo Creating $@ @echo $(DL)/* $@ for NetWare target.$(DL) > $@ @echo $(DL)** Do not edit this file - it is created by make!$(DL) >> $@ @echo $(DL)** All your changes will be lost!!$(DL) >> $@ @echo $(DL)*/$(DL) >> $@ @echo $(DL)#define OS "i586-pc-NetWare"$(DL) >> $@ @echo $(DL)#define VERSION "$(LIBGD_VERSION_STR)"$(DL) >> $@ @echo $(DL)#define PACKAGE_BUGREPORT "http://bugs.libgd.org/"$(DL) >> $@ @echo $(DL)#define HAVE_ARPA_INET_H 1$(DL) >> $@ @echo $(DL)#define HAVE_ASSERT_H 1$(DL) >> $@ @echo $(DL)#define HAVE_DLFCN_H 1$(DL) >> $@ @echo $(DL)#define HAVE_DLOPEN 1$(DL) >> $@ @echo $(DL)#define HAVE_ERR_H 1$(DL) >> $@ @echo $(DL)#define HAVE_ERRNO_H 1$(DL) >> $@ @echo $(DL)#define HAVE_FCNTL_H 1$(DL) >> $@ @echo $(DL)#define HAVE_FIONBIO 1$(DL) >> $@ @echo $(DL)#define HAVE_GETHOSTBYADDR 1$(DL) >> $@ @echo $(DL)#define HAVE_GETTIMEOFDAY 1$(DL) >> $@ @echo $(DL)#define HAVE_INET_ADDR 1$(DL) >> $@ @echo $(DL)#define HAVE_INET_NTOA 1$(DL) >> $@ @echo $(DL)#define HAVE_INET_PTON 1$(DL) >> $@ @echo $(DL)#define HAVE_INTTYPES_H 1$(DL) >> $@ @echo $(DL)#define HAVE_LIMITS_H 1$(DL) >> $@ @echo $(DL)#define HAVE_LONGLONG 1$(DL) >> $@ @echo $(DL)#define HAVE_MALLOC_H 1$(DL) >> $@ @echo $(DL)#define HAVE_NETINET_IN_H 1$(DL) >> $@ @echo $(DL)#define HAVE_SELECT 1$(DL) >> $@ @echo $(DL)#define HAVE_SETJMP_H 1$(DL) >> $@ @echo $(DL)#define HAVE_SIGNAL 1$(DL) >> $@ @echo $(DL)#define HAVE_SOCKET 1$(DL) >> $@ @echo $(DL)#define HAVE_STDARG_H 1$(DL) >> $@ @echo $(DL)#define HAVE_STDDEF_H 1$(DL) >> $@ @echo $(DL)#define HAVE_STDINT_H 1$(DL) >> $@ @echo $(DL)#define HAVE_STDLIB_H 1$(DL) >> $@ @echo $(DL)#define HAVE_STRCASECMP 1$(DL) >> $@ @echo $(DL)#define HAVE_STRDUP 1$(DL) >> $@ @echo $(DL)#define HAVE_STRFTIME 1$(DL) >> $@ @echo $(DL)#define HAVE_STRING_H 1$(DL) >> $@ @echo $(DL)#define HAVE_STRLCAT 1$(DL) >> $@ @echo $(DL)#define HAVE_STRLCPY 1$(DL) >> $@ @echo $(DL)#define HAVE_STRSTR 1$(DL) >> $@ @echo $(DL)#define HAVE_SYS_PARAM_H 1$(DL) >> $@ @echo $(DL)#define HAVE_SYS_SELECT_H 1$(DL) >> $@ @echo $(DL)#define HAVE_SYS_STAT_H 1$(DL) >> $@ @echo $(DL)#define HAVE_SYS_TIME_H 1$(DL) >> $@ @echo $(DL)#define HAVE_TERMIOS_H 1$(DL) >> $@ @echo $(DL)#define HAVE_TIME_H 1$(DL) >> $@ @echo $(DL)#define HAVE_UNAME 1$(DL) >> $@ @echo $(DL)#define HAVE_UNISTD_H 1$(DL) >> $@ @echo $(DL)#define STDC_HEADERS 1$(DL) >> $@ @echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@ @echo $(DL)#define HAVE_SYS_TYPES_H 1$(DL) >> $@ @echo $(DL)#define HAVE_ZLIB_H 1$(DL) >> $@ @echo $(DL)#define HAVE_LIBZ 1$(DL) >> $@ @echo $(DL)#define HAVE_LIBPNG 1$(DL) >> $@ @echo $(DL)#define HAVE_LIBJPEG 1$(DL) >> $@ @echo $(DL)#define HAVE_LIBFREETYPE 1$(DL) >> $@ @echo $(DL)#define HAVE_FT2BUILD_H 1$(DL) >> $@ # @echo $(DL)#define DEFAULT_FONTPATH "sys:/java/nwgfx/lib/x11/fonts/ttf"$(DL) >> $@ # @echo $(DL)#define PATHSEPARATOR ";"$(DL) >> $@ $(TARGET).imp: get_exp.awk $(LIBGD)/gd.h @echo Creating $@ @$(AWK) -v EPREFIX=$(EPREFIX) -f $^ > $@ patch: Makefile @echo Patching sources... $(PATCH) -d $(LIBGD) -b -p 0 -i $(LIBGD)/netware/$(notdir $(wildcard $(LIBGD)/netware/*.diff)) help: @echo $(DL)===========================================================$(DL) @echo Novell NDK Base = $(NDKBASE) @echo libpng Source = $(LIBPNG) @echo libjpeg Source = $(LIBJPEG) @echo Freetype 2 SDK = $(LIBFT2) @echo Zlib SDK = $(ZLIBSDK) @echo $(DL)===========================================================$(DL) @echo $(DL)libgd $(LIBGD_VERSION_STR) - available targets are:$(DL) @echo $(DL)$(MAKE) all$(DL) @echo $(DL)$(MAKE) nlm$(DL) @echo $(DL)$(MAKE) lib$(DL) @echo $(DL)$(MAKE) clean$(DL) @echo $(DL)$(MAKE) clean-all$(DL) @echo $(DL)$(MAKE) test-cmds$(DL) @echo $(DL)$(MAKE) patch$(DL) @echo $(DL)===========================================================$(DL) libgd-gd-2.1.1/netware/get_exp.awk000066400000000000000000000020201245535672000167730ustar00rootroot00000000000000#!awk # awk hack to fetch libgd export functions from header # and write them to STDOUT. Here you can get an awk version for Win32: # http://www.gknw.net/development/prgtools/awk.zip # $Id$ # BEGIN { print "# Exports extracted from " ARGV[1] ""; print "# Do not edit this file - it is created by make!"; print "# All your changes will be lost!!"; if (EPREFIX) { print " (" EPREFIX ")"; } print " gdFontGetGiant,"; print " gdFontGetLarge,"; print " gdFontGetMediumBold,"; print " gdFontGetSmall,"; print " gdFontGetTiny,"; print " gdImageSquareToCircle,"; print " gdImageStringFTCircle,"; print " gdImageSharpen,"; } # try to catch the function names from lines like: # BGD_DECLARE(gdImagePtr) function ... # BGD_DECLARE(void *) function ... # /^[ \t]*BGD_DECLARE\([^\)]*\) +(gd[A-Za-z0-9_]+)/ { sub(/^[ \t]*BGD_DECLARE\([^\)]+\) +/, ""); sub(/[ \t]*\(.*$/, ""); # hack to filter gdImageEllipse() since we have no C implementation. if ($0 != "gdImageEllipse") { print " " $0 ","; } } libgd-gd-2.1.1/netware/get_ver.awk000066400000000000000000000014111245535672000167760ustar00rootroot00000000000000#!awk # awk script which fetches libgd version number and string from input file # and writes them to STDOUT. Here you can get an awk version for Win32: # http://www.gknw.net/development/prgtools/awk.zip # $Id$ # BEGIN { while ((getline < ARGV[1]) > 0) { if (match ($0, /^GDLIB_MAJOR=([0-9]*)$/)) { split($1, t, "="); v_maj = t[2]; } if (match ($0, /^GDLIB_MINOR=([0-9]*)$/)) { split($1, t, "="); v_min = t[2]; } if (match ($0, /^GDLIB_REVISION=([0-9]*)$/)) { split($1, t, "="); v_rev = t[2]; } } libgd_ver = v_maj "," v_min "," v_rev; libgd_ver_str = v_maj "." v_min "." v_rev; print "LIBGD_VERSION = " libgd_ver ""; print "LIBGD_VERSION_STR = " libgd_ver_str ""; } libgd-gd-2.1.1/netware/keepscreen.c000066400000000000000000000010501245535672000171260ustar00rootroot00000000000000/* Simple _NonAppStop() implementation which can be linked to your * NLM in order to keep the screen open when the NLM terminates * (the good old clib behaviour). * You dont have to call it, its done automatically from LibC. * * 2004-Aug-11 by Guenter Knauf * * URL: http://www.gknw.com/development/mk_nlm/ * * $Id$ */ #include #include void _NonAppStop() { uint16_t row, col; GetScreenSize(&row, &col); gotorowcol(row-1, 0); /* pressanykey(); */ printf(" "); getcharacter(); } libgd-gd-2.1.1/netware/nwlibc.c000066400000000000000000000170271245535672000162730ustar00rootroot00000000000000/********************************************************************* * Universal NetWare library stub. * * written by Ulrich Neuman and given to OpenSource copyright-free. * * version: 1.0 * * $Id$ *********************************************************************/ #include #include #include #include #include #include #include #include typedef struct { int _errno; void *twentybytes; } libthreaddata_t; typedef struct { int x; int y; int z; void *tenbytes; NXKey_t perthreadkey; /* if -1, no key obtained... */ NXMutex_t *lock; } libdata_t; int gLibId = -1; void *gLibHandle = (void *) NULL; rtag_t gAllocTag = (rtag_t) NULL; NXMutex_t *gLibLock = (NXMutex_t *) NULL; /* internal library function prototypes... */ int DisposeLibraryData ( void * ); void DisposeThreadData ( void * ); int GetOrSetUpData ( int id, libdata_t **data, libthreaddata_t **threaddata ); int _NonAppStart ( void *NLMHandle, void *errorScreen, const char *cmdLine, const char *loadDirPath, size_t uninitializedDataLength, void *NLMFileHandle, int (*readRoutineP)( int conn, void *fileHandle, size_t offset, size_t nbytes, size_t *bytesRead, void *buffer ), size_t customDataOffset, size_t customDataSize, int messageCount, const char **messages ) { NX_LOCK_INFO_ALLOC(liblock, "Per-Application Data Lock", 0); #ifndef __GNUC__ #pragma unused(cmdLine) #pragma unused(loadDirPath) #pragma unused(uninitializedDataLength) #pragma unused(NLMFileHandle) #pragma unused(readRoutineP) #pragma unused(customDataOffset) #pragma unused(customDataSize) #pragma unused(messageCount) #pragma unused(messages) #endif /* ** Here we process our command line, post errors (to the error screen), ** perform initializations and anything else we need to do before being able ** to accept calls into us. If we succeed, we return non-zero and the NetWare ** Loader will leave us up, otherwise we fail to load and get dumped. */ gAllocTag = AllocateResourceTag(NLMHandle, " memory allocations", AllocSignature); if (!gAllocTag) { OutputToScreen(errorScreen, "Unable to allocate resource tag for " "library memory allocations.\n"); return -1; } gLibId = register_library(DisposeLibraryData); if (gLibId < -1) { OutputToScreen(errorScreen, "Unable to register library with kernel.\n"); return -1; } gLibHandle = NLMHandle; gLibLock = NXMutexAlloc(0, 0, &liblock); if (!gLibLock) { OutputToScreen(errorScreen, "Unable to allocate library data lock.\n"); return -1; } return 0; } /* ** Here we clean up any resources we allocated. Resource tags is a big part ** of what we created, but NetWare doesn't ask us to free those. */ void _NonAppStop( void ) { (void) unregister_library(gLibId); NXMutexFree(gLibLock); } /* ** This function cannot be the first in the file for if the file is linked ** first, then the check-unload function's offset will be nlmname.nlm+0 ** which is how to tell that there isn't one. When the check function is ** first in the linked objects, it is ambiguous. For this reason, we will ** put it inside this file after the stop function. ** ** Here we check to see if it's alright to ourselves to be unloaded. If not, ** we return a non-zero value. Right now, there isn't any reason not to allow ** it. */ int _NonAppCheckUnload( void ) { return 0; } int GetOrSetUpData ( int id, libdata_t **appData, libthreaddata_t **threadData ) { int err; libdata_t *app_data; libthreaddata_t *thread_data; NXKey_t key; NX_LOCK_INFO_ALLOC(liblock, "Application Data Lock", 0); err = 0; thread_data = (libthreaddata_t *) NULL; /* ** Attempt to get our data for the application calling us. This is where we ** store whatever application-specific information we need to carry in support ** of calling applications. */ app_data = (libdata_t *) get_app_data(id); if (!app_data) { /* ** This application hasn't called us before; set up application AND per-thread ** data. Of course, just in case a thread from this same application is calling ** us simultaneously, we better lock our application data-creation mutex. We ** also need to recheck for data after we acquire the lock because WE might be ** that other thread that was too late to create the data and the first thread ** in will have created it. */ NXLock(gLibLock); if (!(app_data = (libdata_t *) get_app_data(id))) { app_data = (libdata_t *) malloc(sizeof(libdata_t)); if (app_data) { memset(app_data, 0, sizeof(libdata_t)); app_data->tenbytes = malloc(10); app_data->lock = NXMutexAlloc(0, 0, &liblock); if (!app_data->tenbytes || !app_data->lock) { if (app_data->lock) NXMutexFree(app_data->lock); free(app_data); app_data = (libdata_t *) NULL; err = ENOMEM; } if (app_data) { /* ** Here we burn in the application data that we were trying to get by calling ** get_app_data(). Next time we call the first function, we'll get this data ** we're just now setting. We also go on here to establish the per-thread data ** for the calling thread, something we'll have to do on each application ** thread the first time it calls us. */ err = set_app_data(gLibId, app_data); if (err) { free(app_data); app_data = (libdata_t *) NULL; err = ENOMEM; } else { /* create key for thread-specific data... */ err = NXKeyCreate(DisposeThreadData, (void *) NULL, &key); if (err) /* (no more keys left?) */ key = -1; app_data->perthreadkey = key; } } } } NXUnlock(gLibLock); } if (app_data) { key = app_data->perthreadkey; if ( key != -1 /* couldn't create a key? no thread data */ && !(err = NXKeyGetValue(key, (void **) &thread_data)) && !thread_data) { /* ** Allocate the per-thread data for the calling thread. Regardless of whether ** there was already application data or not, this may be the first call by a ** a new thread. The fact that we allocation 20 bytes on a pointer is not very ** important, this just helps to demonstrate that we can have arbitrarily ** complex per-thread data. */ thread_data = (libthreaddata_t *) malloc(sizeof(libthreaddata_t)); if (thread_data) { thread_data->_errno = 0; thread_data->twentybytes = malloc(20); if (!thread_data->twentybytes) { free(thread_data); thread_data = (libthreaddata_t *) NULL; err = ENOMEM; } if ((err = NXKeySetValue(key, thread_data))) { free(thread_data->twentybytes); free(thread_data); thread_data = (libthreaddata_t *) NULL; } } } } if (appData) *appData = app_data; if (threadData) *threadData = thread_data; return err; } int DisposeLibraryData ( void *data ) { if (data) { void *tenbytes = ((libdata_t *) data)->tenbytes; if (tenbytes) free(tenbytes); free(data); } return 0; } void DisposeThreadData ( void *data ) { if (data) { void *twentybytes = ((libthreaddata_t *) data)->twentybytes; if (twentybytes) free(twentybytes); free(data); } } libgd-gd-2.1.1/netware/tests/000077500000000000000000000000001245535672000160045ustar00rootroot00000000000000libgd-gd-2.1.1/netware/tests/Makefile.netware000066400000000000000000000156131245535672000211160ustar00rootroot00000000000000################################################################### # ## Makefile for building libgd tests (NetWare version - gnu make) ## Use: make -f Makefile ## ## Comments to: Guenter Knauf ## ## $Id$ # ################################################################### # Edit the path below to point to the base of your Novell NDK. ifndef NDKBASE NDKBASE = c:/novell endif LIBGD = ../.. ifndef INSTDIR INSTDIR = ../libgd-$(LIBGD_VERSION_STR)-bin-nw endif # Edit the vars below to change NLM target settings. TARGETS = gddemo.nlm gdtest.nlm gdtestft.nlm gdtopng.nlm gdcmpgif.nlm TARGETS += gd2time.nlm gd2togif.nlm gd2topng.nlm gd2copypal.nlm TARGETS += gifanimtest.nlm giftogd2.nlm pngtogd2.nlm pngtogd.nlm webpng.nlm TARGETS += annotate.nlm circletexttest.nlm fontsizetest.nlm fontwheeltest.nlm TARGETS += testac.nlm testtr.nlm DTARGET = ../libgd.nlm LTARGET = ../libgd.lib COPYR = Copyright (C) 1996-2007 Boutell.Com, Inc. WWW = http://www.libgd.org/ DESCR = libgd $(LIBGD_VERSION_STR) $(subst .def,,$(notdir $@)) - $(WWW) MTSAFE = YES STACK = 64000 #SCREEN = NONE #SCREEN = $(DESCR) # Comment the line below if you dont want to load protected automatically. #LDRING = 3 # Comment the line below if you dont want to link the static libgd.lib. #LSTATIC = 1 ifdef LSTATIC LDLIBS = $(LTARGET) else IMPORTS = @../libgd.imp MODULES = $(notdir $(DTARGET)) endif # Edit the var below to point to your lib architecture. ifndef LIBARCH LIBARCH = LIBC endif # must be equal to DEBUG or NDEBUG DB = NDEBUG # DB = DEBUG # DB = CURLDEBUG # Optimization: -O or debugging: -g ifeq ($(DB),NDEBUG) OPT = -O2 OBJDIR = release else OPT = -g OBJDIR = debug endif # Include the version info retrieved from header. -include $(OBJDIR)/version.inc # The following line defines your compiler. ifdef METROWERKS CC = mwccnlm else CC = gcc endif YACC = bison -y CP = cp -afv # RM = rm -f # if you want to mark the target as MTSAFE you will need a tool for # generating the xdc data for the linker; here's a minimal tool: # http://www.gknw.net/development/prgtools/mkxdc.zip MPKXDC = mkxdc # Global flags for all compilers CFLAGS = $(OPT) -D$(DB) -DNETWARE -DHAVE_CONFIG_H -nostdinc ifeq ($(CC),mwccnlm) LD = mwldnlm #LDFLAGS = -nostdlib $(PRELUDE) $(LDLIBS) $(<:.def=.o) -o $@ -commandfile LDFLAGS = -nostdlib $(PRELUDE) $(OBJSCR) $(LDLIBS) $(OBJDIR)/$(basename $@).o -o $@ -commandfile AR = mwldnlm ARFLAGS = -type library -w nocmdline $(OBJS) -o CFLAGS += -msgstyle gcc -gccinc -inline off -opt nointrinsics -proc 586 CFLAGS += -relax_pointers #CFLAGS += -w on ifeq ($(LIBARCH),LIBC) PRELUDE = $(SDK_LIBC)/imports/libcpre.o CFLAGS += -align 4 else PRELUDE = "$(METROWERKS)/Novell Support/libraries/runtime/prelude.obj" # CFLAGS += -include "$(METROWERKS)/Novell Support/headers/nlm_prefix.h" CFLAGS += -align 1 endif else LD = nlmconv LDFLAGS = -T AR = ar ARFLAGS = -cq CFLAGS += -fno-builtin -fpcc-struct-return -fno-strict-aliasing CFLAGS += -Wall -Wno-unused #-Wno-format # -pedantic ifeq ($(LIBARCH),LIBC) PRELUDE = $(SDK_LIBC)/imports/libcpre.gcc.o else PRELUDE = $(SDK_CLIB)/imports/clibpre.gcc.o CFLAGS += -include $(NDKBASE)/nlmconv/genlm.h endif endif NDK_ROOT = $(NDKBASE)/ndk SDK_CLIB = $(NDK_ROOT)/nwsdk SDK_LIBC = $(NDK_ROOT)/libc ifeq ($(LIBARCH),LIBC) INCLUDES += -I$(SDK_LIBC)/include # INCLUDES += -I$(SDK_LIBC)/include/nks CFLAGS += -D_POSIX_SOURCE # CFLAGS += -D__ANSIC__ else INCLUDES += -I$(SDK_CLIB)/include/nlm # INCLUDES += -I$(SDK_CLIB)/include # INCLUDES += -I$(SDK_CLIB)/include/nlm/obsolete endif CFLAGS += -I. -I.. -I$(LIBGD) CFLAGS += $(INCLUDES) ifeq ($(MTSAFE),YES) XDCOPT = -n endif ifeq ($(MTSAFE),NO) XDCOPT = -u endif ifeq ($(findstring linux,$(OSTYPE)),linux) DL = ' #-include $(NDKBASE)/nlmconv/ncpfs.inc endif vpath %.c . .. $(LIBGD) ifdef SCREEN ifneq ($(SCREEN),NONE) OBJSCR = $(OBJDIR)/keepscreen.o endif endif .PHONY: all prebuild dist install clean .PRECIOUS: $(OBJDIR)/%.o $(OBJDIR)/%.def $(OBJDIR)/%.xdc $(LTARGET) $(DTARGET) all: prebuild $(TARGETS) prebuild: $(OBJDIR) $(OBJDIR)/version.inc ifdef LSTATIC $(MAKE) -C ../ -f Makefile lib else $(MAKE) -C ../ -f Makefile nlm endif dist: all -$(RM) -r $(OBJDIR) install: $(INSTDIR) all @$(CP) *.nlm $(INSTDIR) @$(CP) ../CHANGES $(INSTDIR) @$(CP) ../COPYING $(INSTDIR) @$(CP) ../README $(INSTDIR) @$(CP) ../RELEASE-NOTES $(INSTDIR) clean: -$(RM) -r $(OBJDIR) -$(RM) $(TARGETS) clean-all: clean -$(MAKE) -C ../ -f Makefile clean %.lib: $(OBJS) @echo Creating $@ @-$(RM) $@ @$(AR) $(ARFLAGS) $@ $^ %.nlm: $(OBJDIR)/%.def $(OBJDIR)/%.o $(OBJDIR)/%.xdc $(OBJSCR) $(LDLIBS) @echo Linking $@ @-$(RM) $@ @$(LD) $(LDFLAGS) $< $(INSTDIR): @mkdir $(INSTDIR) $(OBJDIR): @mkdir $(OBJDIR) $(OBJDIR)/%.o: %.c # @echo Compiling $< $(CC) $(CFLAGS) -c $< -o $@ $(OBJDIR)/version.inc: ../../configure.ac $(OBJDIR) @echo Creating $@ @awk -f ../get_ver.awk $< > $@ $(OBJDIR)/%.xdc: Makefile @echo Creating $@ @$(MPKXDC) $(XDCOPT) $@ $(OBJDIR)/%.def: Makefile @echo Creating $@ @echo $(DL)# DEF file for linking with $(LD)$(DL) > $@ @echo $(DL)# Do not edit this file - it is created by make!$(DL) >> $@ @echo $(DL)# All your changes will be lost!!$(DL) >> $@ @echo $(DL)#$(DL) >> $@ @echo $(DL)copyright "$(COPYR)"$(DL) >> $@ @echo $(DL)description "$(DESCR)"$(DL) >> $@ @echo $(DL)version $(LIBGD_VERSION)$(DL) >> $@ ifdef NLMTYPE @echo $(DL)type $(NLMTYPE)$(DL) >> $@ endif ifdef STACK @echo $(DL)stack $(STACK)$(DL) >> $@ endif ifdef SCREEN @echo $(DL)screenname "$(SCREEN)"$(DL) >> $@ else @echo $(DL)screenname "DEFAULT"$(DL) >> $@ endif ifeq ($(DB),DEBUG) @echo $(DL)debug$(DL) >> $@ endif @echo $(DL)threadname "$(subst .def,,$(notdir $@))"$(DL) >> $@ ifdef XDCOPT @echo $(DL)xdcdata $(@:.def=.xdc)$(DL) >> $@ endif ifeq ($(LDRING),0) @echo $(DL)flag_on 16$(DL) >> $@ endif ifeq ($(LDRING),3) @echo $(DL)flag_on 512$(DL) >> $@ endif @echo $(DL)flag_on 64$(DL) >> $@ ifeq ($(LIBARCH),CLIB) @echo $(DL)start _Prelude$(DL) >> $@ @echo $(DL)exit _Stop$(DL) >> $@ @echo $(DL)import @$(SDK_CLIB)/imports/clib.imp$(DL) >> $@ @echo $(DL)import @$(SDK_CLIB)/imports/threads.imp$(DL) >> $@ @echo $(DL)import @$(SDK_CLIB)/imports/nlmlib.imp$(DL) >> $@ @echo $(DL)module clib$(DL) >> $@ else @echo $(DL)pseudopreemption$(DL) >> $@ @echo $(DL)start _LibCPrelude$(DL) >> $@ @echo $(DL)exit _LibCPostlude$(DL) >> $@ @echo $(DL)check _LibCCheckUnload$(DL) >> $@ @echo $(DL)import @$(SDK_LIBC)/imports/libc.imp$(DL) >> $@ @echo $(DL)import @$(SDK_LIBC)/imports/netware.imp$(DL) >> $@ @echo $(DL)module libc$(DL) >> $@ endif ifdef MODULES @echo $(DL)module $(MODULES)$(DL) >> $@ endif ifdef EXPORTS @echo $(DL)export $(EXPORTS)$(DL) >> $@ endif ifdef IMPORTS @echo $(DL)import $(IMPORTS)$(DL) >> $@ endif ifeq ($(LD),nlmconv) @echo $(DL)input $(PRELUDE)$(DL) >> $@ @echo $(DL)input $(OBJSCR)$(DL) >> $@ @echo $(DL)input $(@:.def=.o)$(DL) >> $@ ifdef LSTATIC @echo $(DL)input $(LTARGET)$(DL) >> $@ endif @echo $(DL)output $(notdir $(@:.def=.nlm))$(DL) >> $@ endif libgd-gd-2.1.1/src/000077500000000000000000000000001245535672000137645ustar00rootroot00000000000000libgd-gd-2.1.1/src/CMakeLists.txt000066400000000000000000000047121245535672000165300ustar00rootroot00000000000000 SET (LIBGD_SRC_FILES gd.c gdfx.c gdfx.h gd_color.c gd_color.h gd_color_map.c gd_color_map.h gd_crop.c gd_transform.c gd_security.c gdpp.cxx gdpp.h gd_bmp.c bmp.h gd_filter.c gd_gd.c gd_gd2.c gd_io.c gd_io.h gd_io_stream.cxx gd_io_stream.h gd_io_dp.c gd_interpolation.c gd_gif_in.c gd_gif_out.c gd_io_file.c gd_io_ss.c gd_jpeg.c gd_matrix.c gd_nnquant.c gd_nnquant.h gd_png.c gd_rotate.c gd_tiff.c gd_tga.c gd_tga.h gd_ss.c gd_topal.c gd_wbmp.c gdcache.c gdcache.h gdfontg.c gdfontg.h gdfontl.c gdfontl.h gdfontmb.c gdfontmb.h gdfonts.c gdfonts.h gdfontt.c gdfontt.h gdft.c gdhelpers.c gdhelpers.h gdkanji.c gdtables.c gdxpm.c jisx0208.h wbmp.c gd.h wbmp.h gd_webp.c webpimg.c gd_xbm.c gd_version.c ) add_library(${GD_LIB} ${LIBGD_SRC_FILES}) add_library(${GD_LIB_STATIC} STATIC ${LIBGD_SRC_FILES}) if (WIN32 AND NOT MINGW AND NOT MSYS) # SET_TARGET_PROPERTIES(${GD_LIB} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:msvcrt.lib") SET_PROPERTY(TARGET ${GD_LIB_STATIC} APPEND PROPERTY COMPILE_DEFINITIONS NONDLL=1) ENDIF(WIN32 AND NOT MINGW AND NOT MSYS) if(UNIX) set_target_properties(${GD_LIB_STATIC} PROPERTIES OUTPUT_NAME ${GD_LIB}) endif() if (MINGW OR MSYS) ADD_DEFINITIONS("-mms-bitfields") set_target_properties(${GD_LIB_STATIC} PROPERTIES OUTPUT_NAME ${GD_LIB}) endif (MINGW OR MSYS) INCLUDE_DIRECTORIES(BEFORE "${PROJECT_BINARY_DIR}" "${CMAKE_BINARY_DIR}" "${GD_SOURCE_DIR}/src") target_link_libraries(${GD_LIB} ${ZLIB_LIBRARIES} ${FREETYPE_LIBRARIES} ${PNG_LIBRARIES} ${ICONV_LIBRARIES} ${LIQ_LIBRARIES} ${JPEG_LIBRARIES} ${TIFF_LIBRARIES} ${XPM_LIBRARIES} ${FONTCONFIG_LIBRARY} ${VPX_LIBRARIES}) target_link_libraries(${GD_LIB_STATIC} ${ZLIB_LIBRARIES} ${FREETYPE_LIBRARIES} ${PNG_LIBRARIES} ${ICONV_LIBRARIES} ${LIQ_LIBRARIES} ${JPEG_LIBRARIES} ${TIFF_LIBRARIES} ${XPM_LIBRARIES} ${FONTCONFIG_LIBRARY} ${VPX_LIBRARIES} ) set(GD_PROGRAMS annotate gdparttopng gdtopng gd2copypal gd2topng pngtogd pngtogd2 webpng gd2togif gdcmpgif giftogd2) foreach(program ${GD_PROGRAMS}) add_executable(${program} ${program}.c) target_link_libraries(${program} ${GD_LIB}) endforeach(program) install(TARGETS ${GD_LIB} ${GD_LIB_STATIC} ${GD_PROGRAMS} RUNTIME DESTINATION bin LIBRARY DESTINATION lib ARCHIVE DESTINATION lib) install(PROGRAMS bdftogd DESTINATION bin) install(FILES gd.h gdfx.h gd_io.h gdcache.h gdfontg.h gdfontl.h gdfontmb.h gdfonts.h gdfontt.h gd_color_map.h gd_errors.h DESTINATION include) libgd-gd-2.1.1/src/COPYING000066400000000000000000000044001245535672000150150ustar00rootroot00000000000000 Portions copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 by Cold Spring Harbor Laboratory. Funded under Grant P41-RR02188 by the National Institutes of Health. Portions copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002 by Boutell.Com, Inc. Portions relating to GD2 format copyright 1999, 2000, 2001, 2002 Philip Warner. Portions relating to PNG copyright 1999, 2000, 2001, 2002 Greg Roelofs. Portions relating to gdttf.c copyright 1999, 2000, 2001, 2002 John Ellson (ellson@lucent.com). Portions relating to gdft.c copyright 2001, 2002 John Ellson (ellson@lucent.com). Portions copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007 2008 Pierre-Alain Joye (pierre@libgd.org). Portions relating to JPEG and to color quantization copyright 2000, 2001, 2002, Doug Becker and copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, Thomas G. Lane. This software is based in part on the work of the Independent JPEG Group. See the file README-JPEG.TXT for more information. Portions relating to WBMP copyright 2000, 2001, 2002 Maurice Szmurlo and Johan Van den Brande. Permission has been granted to copy, distribute and modify gd in any context without fee, including a commercial application, provided that this notice is present in user-accessible supporting documentation. This does not affect your ownership of the derived work itself, and the intent is to assure proper credit for the authors of gd, not to interfere with your productive use of gd. If you have questions, ask. "Derived works" includes all programs that utilize the library. Credit must be given in user-accessible documentation. This software is provided "AS IS." The copyright holders disclaim all warranties, either express or implied, including but not limited to implied warranties of merchantability and fitness for a particular purpose, with respect to this code and accompanying documentation. Although their code does not appear in gd, the authors wish to thank David Koblas, David Rowley, and Hutchison Avenue Software Corporation for their prior contributions. libgd-gd-2.1.1/src/Makefile.am000066400000000000000000000036521245535672000160260ustar00rootroot00000000000000## Process this file with automake to produce Makefile.in -*-Makefile-*- bin_PROGRAMS = gdcmpgif check_PROGRAMS = gifanimtest gd_color_map_test if HAVE_LIBPNG bin_PROGRAMS += gdtopng pngtogd webpng check_PROGRAMS += circletexttest fontsizetest fontwheeltest gddemo testac if HAVE_LIBZ bin_PROGRAMS += gdparttopng gd2topng pngtogd2 check_PROGRAMS += gdtest endif endif if HAVE_LIBJPEG if !HAVE_LIBPNG check_PROGRAMS += fontsizetest fontwheeltest endif endif if HAVE_LIBFONTCONFIG check_PROGRAMS += fontconfigtest endif if HAVE_LIBFREETYPE bin_PROGRAMS += annotate check_PROGRAMS += gdtestft testtr endif if HAVE_LIBZ bin_PROGRAMS += gd2copypal gd2togif giftogd2 endif bin_SCRIPTS = bdftogd if HAVE_LIBZ check_PROGRAMS += gd2time endif EXTRA_DIST = bdftogd demoin.png entities.html entities.tcl CMakeLists.txt config.h.cmake gd_io_stream.cxx gdpp.cxx msinttypes/inttypes.h msinttypes/stdint.h include_HEADERS = gd.h gdfx.h gd_io.h gdcache.h gdfontg.h gdfontl.h gdfontmb.h gdfonts.h gdfontt.h entities.h gd_color_map.h gd_errors.h gdpp.h lib_LTLIBRARIES = libgd.la libgd_la_SOURCES = gd.c gd_color.c gd_color_map.c gd_transform.c gdfx.c gd_security.c gd_gd.c gd_gd2.c gd_io.c gd_io_dp.c gd_gif_in.c \ gd_gif_out.c gd_io_file.c gd_io_ss.c gd_jpeg.c gd_png.c gd_ss.c gd_topal.c gd_wbmp.c gdcache.c gdfontg.c gdfontl.c \ gdfontmb.c gdfonts.c gdfontt.c gdft.c gdhelpers.c gdhelpers.h gdkanji.c gdtables.c gdxpm.c jisx0208.h wbmp.c wbmp.h \ gd_filter.c gd_nnquant.c gd_rotate.c gd_matrix.c gd_interpolation.c gd_crop.c webpimg.c webpimg.h gd_webp.c gd_tiff.c \ gd_tga.c gd_tga.h gd_bmp.c bmp.h gd_color.h gd_nnquant.h gd_tga.h gd_intern.h gd_io_stream.h gd_xbm.c \ gd_color_match.c gd_version.c gd_filename.c libgd_la_LDFLAGS = -version-info $(GDLIB_CURRENT):$(GDLIB_REVISION):$(GDLIB_AGE) -no-undefined libgd_la_LIBADD = $(LTLIBICONV) LDADD = libgd.la $(LIBICONV) libgd-gd-2.1.1/src/annotate.c000066400000000000000000000102471245535672000157450ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include "gd.h" /* A neat little utility which adds freetype text to * existing JPEG images. Type annotate -h for instructions. * Thanks to Joel Dubiner for supporting this work. -TBB */ enum { left, center, right }; int main(int argc, char *argv[]) { #ifndef HAVE_LIBFREETYPE (void)argc; (void)argv; /* 2.0.12 */ fprintf(stderr, "annotate is not useful without freetype.\n" "Install freetype, then './configure; make clean; make install'\n" "the gd library again.\n" ); return 1; #else gdImagePtr im; char *iin, *iout; FILE *in, *out; char s[1024]; int bounds[8]; int lines = 1; int color = gdTrueColor(0, 0, 0); char font[1024]; int size = 12; int align = left; int x = 0, y = 0; char *fontError; strcpy(font, "times"); if(argc != 3) { fprintf(stderr, "Usage: annotate imagein.jpg imageout.jpg\n\n"); fprintf(stderr, "Standard input should consist of\n"); fprintf(stderr, "lines in the following formats:\n"); fprintf(stderr, "color r g b (0-255 each) [a (0-127, 0 is opaque)]\n"); fprintf(stderr, "font fontname\n"); fprintf(stderr, "size pointsize\n"); fprintf(stderr, "align (left|right|center)\n"); fprintf(stderr, "move x y\n"); fprintf(stderr, "text actual-output-text\n\n"); fprintf(stderr, "If the file 'paris.ttf' exists in /usr/share/fonts/truetype or in a\n"); fprintf(stderr, "location specified in the GDFONTPATH environment variable, 'font paris' is\n"); fprintf(stderr, "sufficient. You may also specify the full, rooted path of a font file.\n"); exit(1); } iin = argv[1]; iout = argv[2]; in = fopen(iin, "rb"); if(!in) { fprintf(stderr, "Couldn't open %s\n", iin); exit(2); } #ifdef HAVE_LIBJPEG im = gdImageCreateFromJpeg(in); #else fprintf(stderr, "No JPEG library support available.\n"); exit(1); #endif fclose(in); if(!im) { fprintf(stderr, "%s did not load properly\n", iin); exit(3); } while(fgets(s, sizeof(s), stdin)) { char *st; char *text; st = strtok(s, " \t\r\n"); if(!st) { /* Be nice about blank lines */ continue; } if(!strcmp(st, "font")) { char *st = strtok(0, " \t\r\n"); if(!st) { goto badLine; } strcpy(font, st); } else if(!strcmp(st, "align")) { char *st = strtok(0, " \t\r\n"); if(!st) { goto badLine; } if(!strcmp(st, "left")) { align = 0; } else if(!strcmp(st, "center")) { align = 1; } else if(!strcmp(st, "right")) { align = 2; } } else if(!strcmp(st, "size")) { char *st = strtok(0, " \t\r\n"); if(!st) { goto badLine; } size = atoi(st); } else if(!strcmp(st, "color")) { char *st = strtok(0, "\r\n"); int r, g, b, a = 0; if(!st) { goto badLine; } if(sscanf(st, "%d %d %d %d", &r, &g, &b, &a) < 3) { fprintf(stderr, "Bad color at line %d\n", lines); exit(2); } color = gdTrueColorAlpha(r, g, b, a); } else if(!strcmp(st, "move")) { char *st = strtok(0, "\r\n"); if(!st) { goto badLine; } if(sscanf(st, "%d %d", &x, &y) != 2) { fprintf(stderr, "Missing coordinates at line %d\n", lines); exit(3); } } else if(!strcmp(st, "text")) { int rx = x; text = strtok(0, "\r\n"); if(!text) { text = ""; } gdImageStringFT(0, bounds, color, font, size, 0, x, y, text); switch(align) { case left: break; case center: rx -= (bounds[2] - bounds[0]) / 2; break; case right: rx -= (bounds[2] - bounds[0]); break; } fontError = gdImageStringFT(im, 0, color, font, size, 0, rx, y, text); if(fontError) { fprintf(stderr, "font error at line %d: %s\n", lines, fontError); exit(7); } y -= (bounds[7] - bounds[1]); } else { goto badLine; } lines++; continue; badLine: fprintf(stderr, "Bad syntax, line %d\n", lines); exit(4); } out = fopen(iout, "wb"); if(!out) { fprintf(stderr, "Cannot create %s\n", iout); exit(5); } #ifdef HAVE_LIBJPEG gdImageJpeg(im, out, 95); #else fprintf(stderr, "No JPEG library support available.\n"); #endif gdImageDestroy(im); fclose(out); return 0; #endif /* HAVE_LIBFREETYPE */ } libgd-gd-2.1.1/src/bdftogd000077500000000000000000000076461245535672000153400ustar00rootroot00000000000000#!/usr/bin/perl -w # # Simple convertor from bdf to gd font format. # # Author: Jan Pazdziora, adelton@fi.muni.cz, http://www.fi.muni.cz/~adelton/ # at Faculty of Informatics, Masaryk University in Brno, Czech Republic. # # Example of use: # fstobdf -s fontserverhost:7100 -fn 8x16 | ./bdftogd FontLarge gdfontl # use strict; my $VERSION = '0.60'; my $now = localtime; if (@ARGV != 2) { die "usage: bdftogd fontname filename, eg. bdftogd FontLarge gdfontl\n"; } my $gdname = shift; $gdname = 'gd' . $gdname unless $gdname =~ /^gd/i; my $filename = shift; $filename = 'gd' . $filename unless $filename =~ /^gd/i; if (-f "$filename.c") { die "File $filename.c already exists, won't overwrite\n"; } if (-f "$filename.h") { die "File $filename.h already exists, won't overwrite\n"; } my ($width, $height); my (@data, @left, @bottom); my ($globalleft, $globaltop); my ($minchar, $maxchar); my ($copyright, $fontdef); my $currentchar; my $gobitmap = 0; while (<>) { chomp; s/\r$//; my ($tag, $value) = split / /, $_, 2; die "Font is not fixed width\n" if $tag eq 'SPACING' and not $value =~ /[CM]/i; $currentchar = $value if $tag eq 'ENCODING'; $minchar = $currentchar if not defined $minchar or $currentchar < $minchar; $maxchar = $currentchar if not defined $maxchar or $currentchar > $maxchar; if ($tag eq 'ENDCHAR') { $gobitmap = 0; my $bottom = $globaltop - $bottom[$currentchar]; if ($bottom > 0) { $data[$currentchar] = substr $data[$currentchar], 0, length($data[$currentchar]) - $bottom * $width; } else { $data[$currentchar] .= '0' x (-$bottom * $width); } } if ($tag eq 'FONTBOUNDINGBOX') { my ($tag, $wid, $hei, $left, $top) = split / /; if (defined $top) { $globalleft = $left; $globaltop = $top; $height = $hei; $width = $wid; } } if ($tag eq 'FONT' and not defined $fontdef) { $fontdef = $value; } if ($tag eq 'COPYRIGHT' and not defined $copyright) { $copyright = $value; } if ($tag eq 'BBX') { my ($tag, $wid, $hei, $left, $bottom) = split / /; if (defined $bottom) { $left[$currentchar] = $left; $bottom[$currentchar] = $bottom; } } if ($gobitmap) { my $value = pack 'H*', $_; my $bits = unpack 'B*', $value; $bits = ('0' x $left[$currentchar]) . $bits; $bits .= '0' x ($width - length $bits); $bits = substr $bits, 0, $width; $data[$currentchar] .= $bits; } if ($tag eq 'BITMAP') { $gobitmap = 1; $data[$currentchar] = ''; } } my $info = <<"EOF"; /* This is a header file for gd font, generated using bdftogd version $VERSION by Jan Pazdziora, adelton\@fi.muni.cz from bdf font $fontdef at $now. EOF if (defined $copyright) { $info .= <<"EOF"; The original bdf was holding following copyright: $copyright */ EOF } else { $info .= <<"EOF"; No copyright info was found in the original bdf. */ EOF } open FILEC, "> $filename.c" or die "Error writing $filename.c: $!\n"; open FILEH, "> $filename.h" or die "Error writing $filename.h: $!\n"; print FILEC <<"EOF"; $info #include "$filename.h" char ${gdname}Data[] = { EOF $minchar = 0 unless defined $minchar; $maxchar = 255 unless defined $maxchar; for (my $i = $minchar; $i <= $maxchar; $i++) { $data[$i] = '' unless defined $data[$i]; $data[$i] = '0' x ($width * $height - length $data[$i]) . $data[$i]; print FILEC "/* Char $i */\n"; for my $line (0 .. $height - 1) { print FILEC join ',', split(//, substr($data[$i], $line * $width, $width)), "\n"; } print FILEC "\n"; next; for my $line (0 .. $height - 1) { print substr($data[$i], $line * $width, $width), "\n"; } } my $capdef = "\U_${filename}_H_"; print FILEC <<"EOF"; }; gdFont ${gdname}Rep = { @{[ $maxchar - $minchar + 1]}, $minchar, $width, $height, ${gdname}Data }; gdFontPtr ${gdname} = &${gdname}Rep; /* This file has not been truncated. */ EOF close FILEC; print FILEH <<"EOF"; #ifndef $capdef #define $capdef 1 $info #include "gd.h" extern gdFontPtr $gdname; #endif EOF 1; libgd-gd-2.1.1/src/bmp.h000066400000000000000000000046221245535672000147170ustar00rootroot00000000000000/* $Id$ */ #ifdef __cplusplus extern "C" { #endif /* gd_bmp.c Bitmap format support for libgd * Written 2007, Scott MacVicar --------------------------------------------------------------------------- Todo: RLE4, RLE8 and Bitfield encoding Add full support for Windows v4 and Windows v5 header formats ---------------------------------------------------------------------------- */ #ifndef BMP_H #define BMP_H 1 #define BMP_PALETTE_3 1 #define BMP_PALETTE_4 2 #define BMP_WINDOWS_V3 40 #define BMP_OS2_V1 12 #define BMP_OS2_V2 64 #define BMP_WINDOWS_V4 108 #define BMP_WINDOWS_V5 124 #define BMP_BI_RGB 0 #define BMP_BI_RLE8 1 #define BMP_BI_RLE4 2 #define BMP_BI_BITFIELDS 3 #define BMP_BI_JPEG 4 #define BMP_BI_PNG 5 #define BMP_RLE_COMMAND 0 #define BMP_RLE_ENDOFLINE 0 #define BMP_RLE_ENDOFBITMAP 1 #define BMP_RLE_DELTA 2 #define BMP_RLE_TYPE_RAW 0 #define BMP_RLE_TYPE_RLE 1 /* BMP header. */ typedef struct { /* 16 bit - header identifying the type */ signed short int magic; /* 32bit - size of the file */ int size; /* 16bit - these two are in the spec but "reserved" */ signed short int reserved1; signed short int reserved2; /* 32 bit - offset of the bitmap header from data in bytes */ signed int off; } bmp_hdr_t; /* BMP info. */ typedef struct { /* 16bit - Type, ie Windows or OS/2 for the palette info */ signed short int type; /* 32bit - The length of the bitmap information header in bytes. */ signed int len; /* 32bit - The width of the bitmap in pixels. */ signed int width; /* 32bit - The height of the bitmap in pixels. */ signed int height; /* 8 bit - The bitmap data is specified in top-down order. */ signed char topdown; /* 16 bit - The number of planes. This must be set to a value of one. */ signed short int numplanes; /* 16 bit - The number of bits per pixel. */ signed short int depth; /* 32bit - The type of compression used. */ signed int enctype; /* 32bit - The size of the image in bytes. */ signed int size; /* 32bit - The horizontal resolution in pixels/metre. */ signed int hres; /* 32bit - The vertical resolution in pixels/metre. */ signed int vres; /* 32bit - The number of color indices used by the bitmap. */ signed int numcolors; /* 32bit - The number of color indices important for displaying the bitmap. */ signed int mincolors; } bmp_info_t; #endif #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/circletexttest.c000066400000000000000000000026431245535672000172030ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include "gd.h" int main(void) { /* 2.0.22: can't depend on PNG either */ #ifndef HAVE_LIBPNG fprintf(stderr, "Requires PNG support, gd was compiled without it\n"); return 0; #else char *error; FILE *in = 0; FILE *out; gdImagePtr im; int radius; /* Create an image of text on a circle, with an * alpha channel so that we can copy it onto a * background * TBB: 2.0.18: shouldn't depend on JPEG */ #ifdef HAVE_LIBJPEG in = fopen("eleanor.jpg", "rb"); if(!in) { im = gdImageCreateTrueColor(300, 300); } else { im = gdImageCreateFromJpeg(in); fclose(in); } #else im = gdImageCreateTrueColor(300, 300); #endif /* HAVE_LIBJPEG */ if(gdImageSX(im) < gdImageSY(im)) { radius = gdImageSX(im) / 2; } else { radius = gdImageSY(im) / 2; } error = gdImageStringFTCircle(im, gdImageSX(im) / 2, gdImageSY(im) / 2, radius, radius / 2, 0.8, "arial", 24, "top text", "bottom text", gdTrueColorAlpha(192, 100, 255, 32) ); if(error) { fprintf(stderr, "gdImageStringFTEx error: %s\n", error); } out = fopen("gdfx.png", "wb"); if(!out) { fprintf(stderr, "Can't create gdfx.png\n"); return 1; } gdImagePng(im, out); fclose(out); gdImageDestroy(im); #endif /* HAVE_LIBPNG */ return 0; } libgd-gd-2.1.1/src/config.h.cmake000066400000000000000000000065601245535672000164700ustar00rootroot00000000000000/* config.hin. Generated from config.h.cmake by cmake */ /* Define to 1 if you have the header file. */ #cmakedefine HAVE_DLFCN_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_ERRNO_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_FT2BUILD_H /* Define if you have the iconv() function. */ #cmakedefine HAVE_ICONV /* Define to 1 if you have the header file. */ #cmakedefine HAVE_ICONV_H /* Define if defines iconv_t. */ #cmakedefine HAVE_ICONV_T_DEF /* Define to 1 if you have the header file. */ #cmakedefine HAVE_INTTYPES_H /* Define if you have the fontconfig library. */ #cmakedefine HAVE_LIBFONTCONFIG /* Define if you have the freetype library. */ #cmakedefine HAVE_LIBFREETYPE /* Define if you have the jpeg library. */ #cmakedefine HAVE_LIBJPEG /* Define if you have the jpeg library. */ #cmakedefine HAVE_LIBTIFF /* Define to 1 if you have the `m' library (-lm). */ #cmakedefine HAVE_LIBM /* Define if you have the png library. */ #cmakedefine HAVE_LIBPNG /* Define if you have the VPX library. */ #cmakedefine HAVE_LIBVPX /* Define to 1 if you have the header file. */ #cmakedefine HAVE_LIBIMAGEQUANT_H /* Define if you have the Xpm library. */ #cmakedefine HAVE_LIBXPM /* Define if you have zlib. */ #cmakedefine HAVE_LIBZ /* Define to 1 if you have the header file. */ #cmakedefine HAVE_LIMITS_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_MEMORY_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_PNG_H /* Define if you have POSIX threads libraries and header files. */ #cmakedefine HAVE_PTHREAD /* Define to 1 if you have the header file. */ #cmakedefine HAVE_STDDEF_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_STDINT_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_STDLIB_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_STRINGS_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_STRING_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_SYS_STAT_H /* Define to 1 if you have the header file. */ #cmakedefine HAVE_SYS_TYPES_H /* Define to 1 if you have the header file. */ #ifndef HAVE_UNISTD_H #cmakedefine HAVE_UNISTD_H #endif /* Define as const if the declaration of iconv() needs const. */ #cmakedefine ICONV_CONST /* Name of package */ #cmakedefine PACKAGE /* Define to the address where bug reports for this package should be sent. */ #cmakedefine PACKAGE_BUGREPORT /* Define to the full name of this package. */ #cmakedefine PACKAGE_NAME /* Define to the full name and version of this package. */ #cmakedefine PACKAGE_STRING /* Define to the one symbol short name of this package. */ #cmakedefine PACKAGE_TARNAME /* Define to the version of this package. */ #cmakedefine PACKAGE_VERSION /* Define to necessary symbol if this constant uses a non-standard name on your system. */ #cmakedefine PTHREAD_CREATE_JOINABLE /* Define to 1 if you have the ANSI C header files. */ #cmakedefine STDC_HEADERS /* Define to 1 if you have the stdint.h header file. */ #cmakedefine HAVE_STDINT_H /* Define to 1 if you have the inttypes.h header file. */ #cmakedefine HAVE_INTTYPES_H /* Version number of package */ libgd-gd-2.1.1/src/demoin.png000066400000000000000000000234531245535672000157540ustar00rootroot00000000000000PNG  IHDRPLTE3f3f3f333ffff3"f̙3ff3f33D33fffwww̙U3ffff333f3UUUwf3ffffff̙f3333f̙ff3ff̙Uf3ff333ff3ffff̙wf3333̙3f3fff̙3Uf3f33333ffffff̙f̙3̙33f333DDDfffff33f"3"""33ff3fff33f"̙ R IDATxU{cV Rke! ; ЅHroGwA\ټ /t+5H"a0~ރRH 7̼+fvhgXh6%`xþԦO ,¦/6oq,_!b?[ɸl{iabE _.׿:ېtkq-q[74$G?$pE?pY!䆫SPd|#ra%І2N<$m Џ]ď܄")9/7617?aO-Af]&D h #8N>W.㐿vE. nOAw~L16O` 8#f»"L"GENLh'B~*#L!(C&`Lb ނ Y~\H/nn ] AeƇ,z mx 8pQym T,,ڏc%+Ҏe *+8 2rb]aáᵪʐ"r"Bks4EȈl21%e~z ?3<z.8(0g\Ha,BS¦оeqVj; Ҳ:uLky1*-L*P _EgPaAnmB,UΐD0mcO^D`p/u^z=<RS,8w?k<*\;|9r*Ax qDQx'/LJfϠ3Ot,t 5 W{lnލq9c-I~PBCo"]dTc;r|c&lMBݏhvep H{ ATNDdx/xN)("+SAn7p1?|hKg;" Aޝ#K OĊBn':󨨊mdl ?7x>~̜ǏьixMi,W:›8 dm*k`ۿq&mO/f~h]޹ri(R~ zS\hNi]qKocGnxu8*[v^Ԑ%i[ljC#yz/)6{9۱R$Ƚ|wAz +LrJ)(:䞐7@!&Y򒾱r̕hG[Pq2ۑ._Kmt>hMB~XąnhZa"SFJh\N̯븹;rem϶Fcz5mk^ c+>Qf1ɔHDL¡ =R(CT4K|kF|Q:;jD4)h{@+[ϴEBG?|0(BY|KQ>#̻;:)(>Ϯ˫+mTPC +";!@ gc&XYBLtO8x bQϺ/݋h 7lsRێҺ)1OCT,G7MƎv4S<^#O;= W[/,|>X#bFfȊD%ntGÜ~(GY3wi5<m5Ӑ\8RMV~y<^og|S:;llf֐Ccі*\+aт;)]tF>$(R=X]oJ׉Qe;;WI n`p/z'b*E.>B}z ѣfB9O8*(Esζ85^])%w{Qeܬ&_2fr'dMC'*u|ZD$Y&pA|8FNh|Y_/{3/$Nv0 q?&^}m}&bt+oS[AmQ5%^kGZs+Kmu"iT{WϽ^nPNs?z~~hQ͎344%]: b0~v {~Z׊&N]m+ECzx}hfl1p;,\Y͉6/GuFvxJ8#?MO-Oko|LN?3+:x{K<_oHi>pYnĵjUsn.un_̙~°Uəi`=ŒJz^N  j^ӪZXHdhj"EYڝ1 }93$x 3# Mybi]ݢQӶQRl'O\~8@#_ ~,KG'O0rvчʒf ܴW?)(, vjGqG*__nQsl#hNgtjňKۡRL, 1 ^y˝3)uGuPiEKw htL/9|U1 1]vfAu]{jU4.{N Ϗ)N 8 DM>(=IO4(ZdJ&ghn&jU*8qyo錐|:C3Xwhݭ]ނRm<)H(WkڹN띗;̹U|t?/hy%7j9QFsbBEr+O@45vwgת*b@6z=v O5 Z9{OrRẄrW HD;z9몊{!٧IDa hgPh:|63R_>]-N^PY}X}B|qR |yD%?px&tp'bO.S]0J%AD~q(̎o D^l~ /sL7Pπv ՜o lqrYb޲6miա=#詧%wQ͢Y{heE,ρ1v {Qj4?"Pm8>XwFo"6Q{vG9.z9og`mxrdGlG$0$W0Ebn@I6hJ!QdfC϶) o¿E0Oq,wo= u/*x ƒd.O^kة7=Eo9%Cۛrbh,Pc! 9ЃWkAß+B|5:C Ԅvu^h:6 F?S[7mZOPCd&4Dg}+wvLlrz( ʥ+]))wu;jՕTιzK@b͖ry* LQ2PL?H]$6 4$ B;5h/ Nܷgq -s1 ij.]3HkS+?}2W٠M9 Ą T'bӐ+ #1܏/mRFSgaAP8-ZjDo gvFXDC2d Ci}qNEw1n?rW@n;!Ȃ:@ 1X~V.yr~{hH!1i;L K:6.u8_w424$}?}o@g؟m# ƴ0eҙVI4@2rhFC:oN[f VoʓJ󴯧)d`iN&ý?QG?\.;=ruOt9r 396& abO@IRsn+iEQ)tzHУxB'F@HHBx{&r7lt:~UÂm%0Ӽ艹WOȫ rC3@ BG`e)M ]zK ؤ?3A`$ ` AFj71Jy ^<"  ${Ifi2 F4 }b4f-n5JO8j*$>ie dKMr֠=J&j:hvcOl:@IS9v#>(:"1OϪz<|1HX@& ;By1fBaэ^GkMўnu7W~|z(}V?"y>fX< P=Xii*mGd"d>2dFzG?vJi 3!UH=c@sMOLNRࡌSF: /nҧ()UiB5MG#uZ<ĀBJ>#L_R%O ^$qhoQTdAJ[4ZVPPM>9^gn0&\ D8Jv+ R @n@JZq"DgPԲ!l= 8f(Fj`Y*DUx[ e:Oڥ HaNZ!J"}Q{_^@Iu0bEDpKujy]}Tx>Rx BWso=â'N pՁ"UqZV^Q@ Px0(BJEZupO#ebJe _Azma^{k T#d)xqUOU0:pƸ @M]n@)<#鰯Z~c|ߵbtB//T+AVj5A\U4/^JGW\i>4kbDg`aӿzo Q c <ӑ cIN4A``vDU(j7pA.I5y_*0}5ِw9S+8ҺW?f( Uz.j ؑ~<ɐF N='Y2i+42vO:[ T ܕZZ_܇Ȃߐ]βPKdm|`4po޸+F ϛ4*%TY'rPWԳ|ٞhcK%#Etkk+zXtgzɧ@GVj8F<N)5hC.346'tVdw[ {#!qkBHZ (Щ@R xREV4 $B[Bi ґh*@~1p ,R`\9J]P[>ޘQЃzhz̍*}<([C m>A[ t{7:P}^ӈ|v]_Hhr7hHUq܏E&"VxgH?U*qyj"VjĤ2qU\xIB ģPxU‚:>ZnTu~kuf}YUWz j\ۍ~q^k ؏35^/U=N'r.i \pyb{f=P9F01TXx UnL߯Ě(/GW0 > tDžU2%9cHmrKÇO*?@}7rH ZNCO?µUU5y6I. if test -z "$depmode" || test -z "$source" || test -z "$object"; then echo "depcomp: Variables source, object and depmode must be set" 1>&2 exit 1 fi # `libtool' can also be set to `yes' or `no'. if test -z "$depfile"; then base=`echo "$object" | sed -e 's,^.*/,,' -e 's,\.\([^.]*\)$,.P\1,'` dir=`echo "$object" | sed 's,/.*$,/,'` if test "$dir" = "$object"; then dir= fi # FIXME: should be _deps on DOS. depfile="$dir.deps/$base" fi tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} rm -f "$tmpdepfile" # Some modes work just like other modes, but use different flags. We # parameterize here, but still list the modes in the big case below, # to make depend.m4 easier to write. Note that we *cannot* use a case # here, because this file can only contain one case statement. if test "$depmode" = hp; then # HP compiler uses -M and no extra arg. gccflag=-M depmode=gcc fi if test "$depmode" = dashXmstdout; then # This is just like dashmstdout with a different argument. dashmflag=-xM depmode=dashmstdout fi case "$depmode" in gcc3) ## gcc 3 implements dependency tracking that does exactly what ## we want. Yay! Note: for some reason libtool 1.4 doesn't like ## it if -MD -MP comes after the -MF stuff. Hmm. "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" stat=$? if test $stat -eq 0; then : else rm -f "$tmpdepfile" exit $stat fi mv "$tmpdepfile" "$depfile" ;; gcc) ## There are various ways to get dependency output from gcc. Here's ## why we pick this rather obscure method: ## - Don't want to use -MD because we'd like the dependencies to end ## up in a subdir. Having to rename by hand is ugly. ## (We might end up doing this anyway to support other compilers.) ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like ## -MM, not -M (despite what the docs say). ## - Using -M directly means running the compiler twice (even worse ## than renaming). if test -z "$gccflag"; then gccflag=-MD, fi "$@" -Wp,"$gccflag$tmpdepfile" stat=$? if test $stat -eq 0; then : else rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz ## The second -e expression handles DOS-style file names with drive letters. sed -e 's/^[^:]*: / /' \ -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" ## This next piece of magic avoids the `deleted header file' problem. ## The problem is that when a header file which appears in a .P file ## is deleted, the dependency causes make to die (because there is ## typically no way to rebuild the header). We avoid this by adding ## dummy dependencies for each header file. Too bad gcc doesn't do ## this for us directly. tr ' ' ' ' < "$tmpdepfile" | ## Some versions of gcc put a space before the `:'. On the theory ## that the space means something, we add a space to the output as ## well. ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; sgi) if test "$libtool" = yes; then "$@" "-Wp,-MDupdate,$tmpdepfile" else "$@" -MDupdate "$tmpdepfile" fi stat=$? if test $stat -eq 0; then : else rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files echo "$object : \\" > "$depfile" # Clip off the initial element (the dependent). Don't try to be # clever and replace this with sed code, as IRIX sed won't handle # lines with more than a fixed number of characters (4096 in # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; # the IRIX cc adds comments like `#:fec' to the end of the # dependency line. tr ' ' ' ' < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \ tr ' ' ' ' >> $depfile echo >> $depfile # The second pass generates a dummy entry for each header file. tr ' ' ' ' < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ >> $depfile else # The sourcefile does not contain any dependencies, so just # store a dummy comment line, to avoid errors with the Makefile # "include basename.Plo" scheme. echo "#dummy" > "$depfile" fi rm -f "$tmpdepfile" ;; aix) # The C for AIX Compiler uses -M and outputs the dependencies # in a .u file. This file always lives in the current directory. # Also, the AIX compiler puts `$object:' at the start of each line; # $object doesn't have directory information. stripped=`echo "$object" | sed -e 's,^.*/,,' -e 's/\(.*\)\..*$/\1/'` tmpdepfile="$stripped.u" outname="$stripped.o" if test "$libtool" = yes; then "$@" -Wc,-M else "$@" -M fi stat=$? if test $stat -eq 0; then : else rm -f "$tmpdepfile" exit $stat fi if test -f "$tmpdepfile"; then # Each line is of the form `foo.o: dependent.h'. # Do two passes, one to just change these to # `$object: dependent.h' and one to simply `dependent.h:'. sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile" sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile" else # The sourcefile does not contain any dependencies, so just # store a dummy comment line, to avoid errors with the Makefile # "include basename.Plo" scheme. echo "#dummy" > "$depfile" fi rm -f "$tmpdepfile" ;; tru64) # The Tru64 compiler uses -MD to generate dependencies as a side # effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'. # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put # dependencies in `foo.d' instead, so we check for that too. # Subdirectories are respected. dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` test "x$dir" = "x$object" && dir= base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` if test "$libtool" = yes; then tmpdepfile1="$dir.libs/$base.lo.d" tmpdepfile2="$dir.libs/$base.d" "$@" -Wc,-MD else tmpdepfile1="$dir$base.o.d" tmpdepfile2="$dir$base.d" "$@" -MD fi stat=$? if test $stat -eq 0; then : else rm -f "$tmpdepfile1" "$tmpdepfile2" exit $stat fi if test -f "$tmpdepfile1"; then tmpdepfile="$tmpdepfile1" else tmpdepfile="$tmpdepfile2" fi if test -f "$tmpdepfile"; then sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile" # That's a space and a tab in the []. sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile" else echo "#dummy" > "$depfile" fi rm -f "$tmpdepfile" ;; #nosideeffect) # This comment above is used by automake to tell side-effect # dependency tracking mechanisms from slower ones. dashmstdout) # Important note: in order to support this mode, a compiler *must* # always write the proprocessed file to stdout, regardless of -o. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test $1 != '--mode=compile'; do shift done shift fi # Remove `-o $object'. We will use -o /dev/null later, # however we can't do the remplacement now because # `-o $object' might simply not be used IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done test -z "$dashmflag" && dashmflag=-M "$@" -o /dev/null $dashmflag | sed 's:^[^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile" rm -f "$depfile" cat < "$tmpdepfile" > "$depfile" tr ' ' ' ' < "$tmpdepfile" | \ ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; dashXmstdout) # This case only exists to satisfy depend.m4. It is never actually # run, as this mode is specially recognized in the preamble. exit 1 ;; makedepend) "$@" || exit $? # X makedepend shift cleared=no for arg in "$@"; do case $cleared in no) set ""; shift cleared=yes ;; esac case "$arg" in -D*|-I*) set fnord "$@" "$arg"; shift ;; -*) ;; *) set fnord "$@" "$arg"; shift ;; esac done obj_suffix="`echo $object | sed 's/^.*\././'`" touch "$tmpdepfile" ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" rm -f "$depfile" cat < "$tmpdepfile" > "$depfile" sed '1,2d' "$tmpdepfile" | tr ' ' ' ' | \ ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" "$tmpdepfile".bak ;; cpp) # Important note: in order to support this mode, a compiler *must* # always write the proprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test $1 != '--mode=compile'; do shift done shift fi # Remove `-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done "$@" -E | sed -n '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' | sed '$ s: \\$::' > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" cat < "$tmpdepfile" >> "$depfile" sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; msvisualcpp) # Important note: in order to support this mode, a compiler *must* # always write the proprocessed file to stdout, regardless of -o, # because we must use -o when running libtool. "$@" || exit $? IFS=" " for arg do case "$arg" in "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") set fnord "$@" shift shift ;; *) set fnord "$@" "$arg" shift shift ;; esac done "$@" -E | sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile" echo " " >> "$depfile" . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile" rm -f "$tmpdepfile" ;; none) exec "$@" ;; *) echo "Unknown depmode $depmode" 1>&2 exit 1 ;; esac exit 0 libgd-gd-2.1.1/src/entities.h000066400000000000000000000115021245535672000157600ustar00rootroot00000000000000/* * Generated file - do not edit directly. * * This file was generated from: * http://www.w3.org/TR/REC-html40/sgml/entities.html * by means of the script: * entities.tcl */ #ifdef __cplusplus extern "C" { #endif static struct entities_s { char *name; int value; } entities[] = { {"AElig", 198}, {"Aacute", 193}, {"Acirc", 194}, {"Agrave", 192}, {"Alpha", 913}, {"Aring", 197}, {"Atilde", 195}, {"Auml", 196}, {"Beta", 914}, {"Ccedil", 199}, {"Chi", 935}, {"Dagger", 8225}, {"Delta", 916}, {"ETH", 208}, {"Eacute", 201}, {"Ecirc", 202}, {"Egrave", 200}, {"Epsilon", 917}, {"Eta", 919}, {"Euml", 203}, {"Gamma", 915}, {"Iacute", 205}, {"Icirc", 206}, {"Igrave", 204}, {"Iota", 921}, {"Iuml", 207}, {"Kappa", 922}, {"Lambda", 923}, {"Mu", 924}, {"Ntilde", 209}, {"Nu", 925}, {"OElig", 338}, {"Oacute", 211}, {"Ocirc", 212}, {"Ograve", 210}, {"Omega", 937}, {"Omicron", 927}, {"Oslash", 216}, {"Otilde", 213}, {"Ouml", 214}, {"Phi", 934}, {"Pi", 928}, {"Prime", 8243}, {"Psi", 936}, {"Rho", 929}, {"Scaron", 352}, {"Sigma", 931}, {"THORN", 222}, {"Tau", 932}, {"Theta", 920}, {"Uacute", 218}, {"Ucirc", 219}, {"Ugrave", 217}, {"Upsilon", 933}, {"Uuml", 220}, {"Xi", 926}, {"Yacute", 221}, {"Yuml", 376}, {"Zeta", 918}, {"aacute", 225}, {"acirc", 226}, {"acute", 180}, {"aelig", 230}, {"agrave", 224}, {"alefsym", 8501}, {"alpha", 945}, {"amp", 38}, {"and", 8743}, {"ang", 8736}, {"aring", 229}, {"asymp", 8776}, {"atilde", 227}, {"auml", 228}, {"bdquo", 8222}, {"beta", 946}, {"brvbar", 166}, {"bull", 8226}, {"cap", 8745}, {"ccedil", 231}, {"cedil", 184}, {"cent", 162}, {"chi", 967}, {"circ", 710}, {"clubs", 9827}, {"cong", 8773}, {"copy", 169}, {"crarr", 8629}, {"cup", 8746}, {"curren", 164}, {"dArr", 8659}, {"dagger", 8224}, {"darr", 8595}, {"deg", 176}, {"delta", 948}, {"diams", 9830}, {"divide", 247}, {"eacute", 233}, {"ecirc", 234}, {"egrave", 232}, {"empty", 8709}, {"emsp", 8195}, {"ensp", 8194}, {"epsilon", 949}, {"equiv", 8801}, {"eta", 951}, {"eth", 240}, {"euml", 235}, {"euro", 8364}, {"exist", 8707}, {"fnof", 402}, {"forall", 8704}, {"frac12", 189}, {"frac14", 188}, {"frac34", 190}, {"frasl", 8260}, {"gamma", 947}, {"ge", 8805}, {"gt", 62}, {"hArr", 8660}, {"harr", 8596}, {"hearts", 9829}, {"hellip", 8230}, {"iacute", 237}, {"icirc", 238}, {"iexcl", 161}, {"igrave", 236}, {"image", 8465}, {"infin", 8734}, {"int", 8747}, {"iota", 953}, {"iquest", 191}, {"isin", 8712}, {"iuml", 239}, {"kappa", 954}, {"lArr", 8656}, {"lambda", 955}, {"lang", 9001}, {"laquo", 171}, {"larr", 8592}, {"lceil", 8968}, {"ldquo", 8220}, {"le", 8804}, {"lfloor", 8970}, {"lowast", 8727}, {"loz", 9674}, {"lrm", 8206}, {"lsaquo", 8249}, {"lsquo", 8216}, {"lt", 60}, {"macr", 175}, {"mdash", 8212}, {"micro", 181}, {"middot", 183}, {"minus", 8722}, {"mu", 956}, {"nabla", 8711}, {"nbsp", 160}, {"ndash", 8211}, {"ne", 8800}, {"ni", 8715}, {"not", 172}, {"notin", 8713}, {"nsub", 8836}, {"ntilde", 241}, {"nu", 957}, {"oacute", 243}, {"ocirc", 244}, {"oelig", 339}, {"ograve", 242}, {"oline", 8254}, {"omega", 969}, {"omicron", 959}, {"oplus", 8853}, {"or", 8744}, {"ordf", 170}, {"ordm", 186}, {"oslash", 248}, {"otilde", 245}, {"otimes", 8855}, {"ouml", 246}, {"para", 182}, {"part", 8706}, {"permil", 8240}, {"perp", 8869}, {"phi", 966}, {"pi", 960}, {"piv", 982}, {"plusmn", 177}, {"pound", 163}, {"prime", 8242}, {"prod", 8719}, {"prop", 8733}, {"psi", 968}, {"quot", 34}, {"rArr", 8658}, {"radic", 8730}, {"rang", 9002}, {"raquo", 187}, {"rarr", 8594}, {"rceil", 8969}, {"rdquo", 8221}, {"real", 8476}, {"reg", 174}, {"rfloor", 8971}, {"rho", 961}, {"rlm", 8207}, {"rsaquo", 8250}, {"rsquo", 8217}, {"sbquo", 8218}, {"scaron", 353}, {"sdot", 8901}, {"sect", 167}, {"shy", 173}, {"sigma", 963}, {"sigmaf", 962}, {"sim", 8764}, {"spades", 9824}, {"sub", 8834}, {"sube", 8838}, {"sum", 8721}, {"sup", 8835}, {"sup1", 185}, {"sup2", 178}, {"sup3", 179}, {"supe", 8839}, {"szlig", 223}, {"tau", 964}, {"there4", 8756}, {"theta", 952}, {"thetasym", 977}, {"thinsp", 8201}, {"thorn", 254}, {"tilde", 732}, {"times", 215}, {"trade", 8482}, {"uArr", 8657}, {"uacute", 250}, {"uarr", 8593}, {"ucirc", 251}, {"ugrave", 249}, {"uml", 168}, {"upsih", 978}, {"upsilon", 965}, {"uuml", 252}, {"weierp", 8472}, {"xi", 958}, {"yacute", 253}, {"yen", 165}, {"yuml", 255}, {"zeta", 950}, {"zwj", 8205}, {"zwnj", 8204}, }; #define ENTITY_NAME_LENGTH_MAX 8 #define NR_OF_ENTITIES 252 #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/entities.html000066400000000000000000001221541245535672000165030ustar00rootroot00000000000000 Character entity references in HTML 4

24 Character entity references in HTML 4

24.1 Introduction to character entity references

A character entity reference is an SGML construct that references a character of the document character set.

This version of HTML supports several sets of character entity references:

The following sections present the complete lists of character entity references. Although, by convention, [ISO10646] the comments following each entry are usually written with uppercase letters, we have converted them to lowercase in this specification for reasons of readability.

24.2 Character entity references for ISO 8859-1 characters

The character entity references in this section produce characters whose numeric equivalents should already be supported by conforming HTML 2.0 user agents. Thus, the character entity reference &divide; is a more convenient form than &#247; for obtaining the division sign ().

To support these named entities, user agents need only recognize the entity names and convert them to characters that lie within the repertoire of [ISO88591].

Character 65533 (FFFD hexadecimal) is the last valid character in UCS-2. 65534 (FFFE hexadecimal) is unassigned and reserved as the byte-swapped version of ZERO WIDTH NON-BREAKING SPACE for byte-order detection purposes. 65535 (FFFF hexadecimal) is unassigned.

24.2.1 The list of characters

<!-- Portions  International Organization for Standardization 1986
     Permission to copy in any form is granted for use with
     conforming SGML systems and applications as defined in
     ISO 8879, provided this notice is included in all copies.
-->
<!-- Character entity set. Typical invocation:
     <!ENTITY % HTMLlat1 PUBLIC
       "-//W3C//ENTITIES Latin 1//EN//HTML">
     %HTMLlat1;
-->

<!ENTITY nbsp   CDATA "&#160;" -- no-break space = non-breaking space,
                                  U+00A0 ISOnum -->
<!ENTITY iexcl  CDATA "&#161;" -- inverted exclamation mark, U+00A1 ISOnum -->
<!ENTITY cent   CDATA "&#162;" -- cent sign, U+00A2 ISOnum -->
<!ENTITY pound  CDATA "&#163;" -- pound sign, U+00A3 ISOnum -->
<!ENTITY curren CDATA "&#164;" -- currency sign, U+00A4 ISOnum -->
<!ENTITY yen    CDATA "&#165;" -- yen sign = yuan sign, U+00A5 ISOnum -->
<!ENTITY brvbar CDATA "&#166;" -- broken bar = broken vertical bar,
                                  U+00A6 ISOnum -->
<!ENTITY sect   CDATA "&#167;" -- section sign, U+00A7 ISOnum -->
<!ENTITY uml    CDATA "&#168;" -- diaeresis = spacing diaeresis,
                                  U+00A8 ISOdia -->
<!ENTITY copy   CDATA "&#169;" -- copyright sign, U+00A9 ISOnum -->
<!ENTITY ordf   CDATA "&#170;" -- feminine ordinal indicator, U+00AA ISOnum -->
<!ENTITY laquo  CDATA "&#171;" -- left-pointing double angle quotation mark
                                  = left pointing guillemet, U+00AB ISOnum -->
<!ENTITY not    CDATA "&#172;" -- not sign, U+00AC ISOnum -->
<!ENTITY shy    CDATA "&#173;" -- soft hyphen = discretionary hyphen,
                                  U+00AD ISOnum -->
<!ENTITY reg    CDATA "&#174;" -- registered sign = registered trade mark sign,
                                  U+00AE ISOnum -->
<!ENTITY macr   CDATA "&#175;" -- macron = spacing macron = overline
                                  = APL overbar, U+00AF ISOdia -->
<!ENTITY deg    CDATA "&#176;" -- degree sign, U+00B0 ISOnum -->
<!ENTITY plusmn CDATA "&#177;" -- plus-minus sign = plus-or-minus sign,
                                  U+00B1 ISOnum -->
<!ENTITY sup2   CDATA "&#178;" -- superscript two = superscript digit two
                                  = squared, U+00B2 ISOnum -->
<!ENTITY sup3   CDATA "&#179;" -- superscript three = superscript digit three
                                  = cubed, U+00B3 ISOnum -->
<!ENTITY acute  CDATA "&#180;" -- acute accent = spacing acute,
                                  U+00B4 ISOdia -->
<!ENTITY micro  CDATA "&#181;" -- micro sign, U+00B5 ISOnum -->
<!ENTITY para   CDATA "&#182;" -- pilcrow sign = paragraph sign,
                                  U+00B6 ISOnum -->
<!ENTITY middot CDATA "&#183;" -- middle dot = Georgian comma
                                  = Greek middle dot, U+00B7 ISOnum -->
<!ENTITY cedil  CDATA "&#184;" -- cedilla = spacing cedilla, U+00B8 ISOdia -->
<!ENTITY sup1   CDATA "&#185;" -- superscript one = superscript digit one,
                                  U+00B9 ISOnum -->
<!ENTITY ordm   CDATA "&#186;" -- masculine ordinal indicator,
                                  U+00BA ISOnum -->
<!ENTITY raquo  CDATA "&#187;" -- right-pointing double angle quotation mark
                                  = right pointing guillemet, U+00BB ISOnum -->
<!ENTITY frac14 CDATA "&#188;" -- vulgar fraction one quarter
                                  = fraction one quarter, U+00BC ISOnum -->
<!ENTITY frac12 CDATA "&#189;" -- vulgar fraction one half
                                  = fraction one half, U+00BD ISOnum -->
<!ENTITY frac34 CDATA "&#190;" -- vulgar fraction three quarters
                                  = fraction three quarters, U+00BE ISOnum -->
<!ENTITY iquest CDATA "&#191;" -- inverted question mark
                                  = turned question mark, U+00BF ISOnum -->
<!ENTITY Agrave CDATA "&#192;" -- latin capital letter A with grave
                                  = latin capital letter A grave,
                                  U+00C0 ISOlat1 -->
<!ENTITY Aacute CDATA "&#193;" -- latin capital letter A with acute,
                                  U+00C1 ISOlat1 -->
<!ENTITY Acirc  CDATA "&#194;" -- latin capital letter A with circumflex,
                                  U+00C2 ISOlat1 -->
<!ENTITY Atilde CDATA "&#195;" -- latin capital letter A with tilde,
                                  U+00C3 ISOlat1 -->
<!ENTITY Auml   CDATA "&#196;" -- latin capital letter A with diaeresis,
                                  U+00C4 ISOlat1 -->
<!ENTITY Aring  CDATA "&#197;" -- latin capital letter A with ring above
                                  = latin capital letter A ring,
                                  U+00C5 ISOlat1 -->
<!ENTITY AElig  CDATA "&#198;" -- latin capital letter AE
                                  = latin capital ligature AE,
                                  U+00C6 ISOlat1 -->
<!ENTITY Ccedil CDATA "&#199;" -- latin capital letter C with cedilla,
                                  U+00C7 ISOlat1 -->
<!ENTITY Egrave CDATA "&#200;" -- latin capital letter E with grave,
                                  U+00C8 ISOlat1 -->
<!ENTITY Eacute CDATA "&#201;" -- latin capital letter E with acute,
                                  U+00C9 ISOlat1 -->
<!ENTITY Ecirc  CDATA "&#202;" -- latin capital letter E with circumflex,
                                  U+00CA ISOlat1 -->
<!ENTITY Euml   CDATA "&#203;" -- latin capital letter E with diaeresis,
                                  U+00CB ISOlat1 -->
<!ENTITY Igrave CDATA "&#204;" -- latin capital letter I with grave,
                                  U+00CC ISOlat1 -->
<!ENTITY Iacute CDATA "&#205;" -- latin capital letter I with acute,
                                  U+00CD ISOlat1 -->
<!ENTITY Icirc  CDATA "&#206;" -- latin capital letter I with circumflex,
                                  U+00CE ISOlat1 -->
<!ENTITY Iuml   CDATA "&#207;" -- latin capital letter I with diaeresis,
                                  U+00CF ISOlat1 -->
<!ENTITY ETH    CDATA "&#208;" -- latin capital letter ETH, U+00D0 ISOlat1 -->
<!ENTITY Ntilde CDATA "&#209;" -- latin capital letter N with tilde,
                                  U+00D1 ISOlat1 -->
<!ENTITY Ograve CDATA "&#210;" -- latin capital letter O with grave,
                                  U+00D2 ISOlat1 -->
<!ENTITY Oacute CDATA "&#211;" -- latin capital letter O with acute,
                                  U+00D3 ISOlat1 -->
<!ENTITY Ocirc  CDATA "&#212;" -- latin capital letter O with circumflex,
                                  U+00D4 ISOlat1 -->
<!ENTITY Otilde CDATA "&#213;" -- latin capital letter O with tilde,
                                  U+00D5 ISOlat1 -->
<!ENTITY Ouml   CDATA "&#214;" -- latin capital letter O with diaeresis,
                                  U+00D6 ISOlat1 -->
<!ENTITY times  CDATA "&#215;" -- multiplication sign, U+00D7 ISOnum -->
<!ENTITY Oslash CDATA "&#216;" -- latin capital letter O with stroke
                                  = latin capital letter O slash,
                                  U+00D8 ISOlat1 -->
<!ENTITY Ugrave CDATA "&#217;" -- latin capital letter U with grave,
                                  U+00D9 ISOlat1 -->
<!ENTITY Uacute CDATA "&#218;" -- latin capital letter U with acute,
                                  U+00DA ISOlat1 -->
<!ENTITY Ucirc  CDATA "&#219;" -- latin capital letter U with circumflex,
                                  U+00DB ISOlat1 -->
<!ENTITY Uuml   CDATA "&#220;" -- latin capital letter U with diaeresis,
                                  U+00DC ISOlat1 -->
<!ENTITY Yacute CDATA "&#221;" -- latin capital letter Y with acute,
                                  U+00DD ISOlat1 -->
<!ENTITY THORN  CDATA "&#222;" -- latin capital letter THORN,
                                  U+00DE ISOlat1 -->
<!ENTITY szlig  CDATA "&#223;" -- latin small letter sharp s = ess-zed,
                                  U+00DF ISOlat1 -->
<!ENTITY agrave CDATA "&#224;" -- latin small letter a with grave
                                  = latin small letter a grave,
                                  U+00E0 ISOlat1 -->
<!ENTITY aacute CDATA "&#225;" -- latin small letter a with acute,
                                  U+00E1 ISOlat1 -->
<!ENTITY acirc  CDATA "&#226;" -- latin small letter a with circumflex,
                                  U+00E2 ISOlat1 -->
<!ENTITY atilde CDATA "&#227;" -- latin small letter a with tilde,
                                  U+00E3 ISOlat1 -->
<!ENTITY auml   CDATA "&#228;" -- latin small letter a with diaeresis,
                                  U+00E4 ISOlat1 -->
<!ENTITY aring  CDATA "&#229;" -- latin small letter a with ring above
                                  = latin small letter a ring,
                                  U+00E5 ISOlat1 -->
<!ENTITY aelig  CDATA "&#230;" -- latin small letter ae
                                  = latin small ligature ae, U+00E6 ISOlat1 -->
<!ENTITY ccedil CDATA "&#231;" -- latin small letter c with cedilla,
                                  U+00E7 ISOlat1 -->
<!ENTITY egrave CDATA "&#232;" -- latin small letter e with grave,
                                  U+00E8 ISOlat1 -->
<!ENTITY eacute CDATA "&#233;" -- latin small letter e with acute,
                                  U+00E9 ISOlat1 -->
<!ENTITY ecirc  CDATA "&#234;" -- latin small letter e with circumflex,
                                  U+00EA ISOlat1 -->
<!ENTITY euml   CDATA "&#235;" -- latin small letter e with diaeresis,
                                  U+00EB ISOlat1 -->
<!ENTITY igrave CDATA "&#236;" -- latin small letter i with grave,
                                  U+00EC ISOlat1 -->
<!ENTITY iacute CDATA "&#237;" -- latin small letter i with acute,
                                  U+00ED ISOlat1 -->
<!ENTITY icirc  CDATA "&#238;" -- latin small letter i with circumflex,
                                  U+00EE ISOlat1 -->
<!ENTITY iuml   CDATA "&#239;" -- latin small letter i with diaeresis,
                                  U+00EF ISOlat1 -->
<!ENTITY eth    CDATA "&#240;" -- latin small letter eth, U+00F0 ISOlat1 -->
<!ENTITY ntilde CDATA "&#241;" -- latin small letter n with tilde,
                                  U+00F1 ISOlat1 -->
<!ENTITY ograve CDATA "&#242;" -- latin small letter o with grave,
                                  U+00F2 ISOlat1 -->
<!ENTITY oacute CDATA "&#243;" -- latin small letter o with acute,
                                  U+00F3 ISOlat1 -->
<!ENTITY ocirc  CDATA "&#244;" -- latin small letter o with circumflex,
                                  U+00F4 ISOlat1 -->
<!ENTITY otilde CDATA "&#245;" -- latin small letter o with tilde,
                                  U+00F5 ISOlat1 -->
<!ENTITY ouml   CDATA "&#246;" -- latin small letter o with diaeresis,
                                  U+00F6 ISOlat1 -->
<!ENTITY divide CDATA "&#247;" -- division sign, U+00F7 ISOnum -->
<!ENTITY oslash CDATA "&#248;" -- latin small letter o with stroke,
                                  = latin small letter o slash,
                                  U+00F8 ISOlat1 -->
<!ENTITY ugrave CDATA "&#249;" -- latin small letter u with grave,
                                  U+00F9 ISOlat1 -->
<!ENTITY uacute CDATA "&#250;" -- latin small letter u with acute,
                                  U+00FA ISOlat1 -->
<!ENTITY ucirc  CDATA "&#251;" -- latin small letter u with circumflex,
                                  U+00FB ISOlat1 -->
<!ENTITY uuml   CDATA "&#252;" -- latin small letter u with diaeresis,
                                  U+00FC ISOlat1 -->
<!ENTITY yacute CDATA "&#253;" -- latin small letter y with acute,
                                  U+00FD ISOlat1 -->
<!ENTITY thorn  CDATA "&#254;" -- latin small letter thorn,
                                  U+00FE ISOlat1 -->
<!ENTITY yuml   CDATA "&#255;" -- latin small letter y with diaeresis,
                                  U+00FF ISOlat1 -->

24.3 Character entity references for symbols, mathematical symbols, and Greek letters

The character entity references in this section produce characters that may be represented by glyphs in the widely available Adobe Symbol font, including Greek characters, various bracketing symbols, and a selection of mathematical operators such as gradient, product, and summation symbols.

To support these entities, user agents may support full [ISO10646] or use other means. Display of glyphs for these characters may be obtained by being able to display the relevant [ISO10646] characters or by other means, such as internally mapping the listed entities, numeric character references, and characters to the appropriate position in some font that contains the requisite glyphs.

When to use Greek entities. This entity set contains all the letters used in modern Greek. However, it does not include Greek punctuation, precomposed accented characters nor the non-spacing accents (tonos, dialytika) required to compose them. There are no archaic letters, Coptic-unique letters, or precomposed letters for Polytonic Greek. The entities defined here are not intended for the representation of modern Greek text and would not be an efficient representation; rather, they are intended for occasional Greek letters used in technical and mathematical works.

24.3.1 The list of characters

<!-- Mathematical, Greek and Symbolic characters for HTML -->

<!-- Character entity set. Typical invocation:
     <!ENTITY % HTMLsymbol PUBLIC
       "-//W3C//ENTITIES Symbols//EN//HTML">
     %HTMLsymbol; -->

<!-- Portions  International Organization for Standardization 1986:
     Permission to copy in any form is granted for use with
     conforming SGML systems and applications as defined in
     ISO 8879, provided this notice is included in all copies.
-->

<!-- Relevant ISO entity set is given unless names are newly introduced.
     New names (i.e., not in ISO 8879 list) do not clash with any
     existing ISO 8879 entity names. ISO 10646 character numbers
     are given for each character, in hex. CDATA values are decimal
     conversions of the ISO 10646 values and refer to the document
     character set. Names are ISO 10646 names. 

-->

<!-- Latin Extended-B -->
<!ENTITY fnof     CDATA "&#402;" -- latin small f with hook = function
                                    = florin, U+0192 ISOtech -->

<!-- Greek -->
<!ENTITY Alpha    CDATA "&#913;" -- greek capital letter alpha, U+0391 -->
<!ENTITY Beta     CDATA "&#914;" -- greek capital letter beta, U+0392 -->
<!ENTITY Gamma    CDATA "&#915;" -- greek capital letter gamma,
                                    U+0393 ISOgrk3 -->
<!ENTITY Delta    CDATA "&#916;" -- greek capital letter delta,
                                    U+0394 ISOgrk3 -->
<!ENTITY Epsilon  CDATA "&#917;" -- greek capital letter epsilon, U+0395 -->
<!ENTITY Zeta     CDATA "&#918;" -- greek capital letter zeta, U+0396 -->
<!ENTITY Eta      CDATA "&#919;" -- greek capital letter eta, U+0397 -->
<!ENTITY Theta    CDATA "&#920;" -- greek capital letter theta,
                                    U+0398 ISOgrk3 -->
<!ENTITY Iota     CDATA "&#921;" -- greek capital letter iota, U+0399 -->
<!ENTITY Kappa    CDATA "&#922;" -- greek capital letter kappa, U+039A -->
<!ENTITY Lambda   CDATA "&#923;" -- greek capital letter lambda,
                                    U+039B ISOgrk3 -->
<!ENTITY Mu       CDATA "&#924;" -- greek capital letter mu, U+039C -->
<!ENTITY Nu       CDATA "&#925;" -- greek capital letter nu, U+039D -->
<!ENTITY Xi       CDATA "&#926;" -- greek capital letter xi, U+039E ISOgrk3 -->
<!ENTITY Omicron  CDATA "&#927;" -- greek capital letter omicron, U+039F -->
<!ENTITY Pi       CDATA "&#928;" -- greek capital letter pi, U+03A0 ISOgrk3 -->
<!ENTITY Rho      CDATA "&#929;" -- greek capital letter rho, U+03A1 -->
<!-- there is no Sigmaf, and no U+03A2 character either -->
<!ENTITY Sigma    CDATA "&#931;" -- greek capital letter sigma,
                                    U+03A3 ISOgrk3 -->
<!ENTITY Tau      CDATA "&#932;" -- greek capital letter tau, U+03A4 -->
<!ENTITY Upsilon  CDATA "&#933;" -- greek capital letter upsilon,
                                    U+03A5 ISOgrk3 -->
<!ENTITY Phi      CDATA "&#934;" -- greek capital letter phi,
                                    U+03A6 ISOgrk3 -->
<!ENTITY Chi      CDATA "&#935;" -- greek capital letter chi, U+03A7 -->
<!ENTITY Psi      CDATA "&#936;" -- greek capital letter psi,
                                    U+03A8 ISOgrk3 -->
<!ENTITY Omega    CDATA "&#937;" -- greek capital letter omega,
                                    U+03A9 ISOgrk3 -->

<!ENTITY alpha    CDATA "&#945;" -- greek small letter alpha,
                                    U+03B1 ISOgrk3 -->
<!ENTITY beta     CDATA "&#946;" -- greek small letter beta, U+03B2 ISOgrk3 -->
<!ENTITY gamma    CDATA "&#947;" -- greek small letter gamma,
                                    U+03B3 ISOgrk3 -->
<!ENTITY delta    CDATA "&#948;" -- greek small letter delta,
                                    U+03B4 ISOgrk3 -->
<!ENTITY epsilon  CDATA "&#949;" -- greek small letter epsilon,
                                    U+03B5 ISOgrk3 -->
<!ENTITY zeta     CDATA "&#950;" -- greek small letter zeta, U+03B6 ISOgrk3 -->
<!ENTITY eta      CDATA "&#951;" -- greek small letter eta, U+03B7 ISOgrk3 -->
<!ENTITY theta    CDATA "&#952;" -- greek small letter theta,
                                    U+03B8 ISOgrk3 -->
<!ENTITY iota     CDATA "&#953;" -- greek small letter iota, U+03B9 ISOgrk3 -->
<!ENTITY kappa    CDATA "&#954;" -- greek small letter kappa,
                                    U+03BA ISOgrk3 -->
<!ENTITY lambda   CDATA "&#955;" -- greek small letter lambda,
                                    U+03BB ISOgrk3 -->
<!ENTITY mu       CDATA "&#956;" -- greek small letter mu, U+03BC ISOgrk3 -->
<!ENTITY nu       CDATA "&#957;" -- greek small letter nu, U+03BD ISOgrk3 -->
<!ENTITY xi       CDATA "&#958;" -- greek small letter xi, U+03BE ISOgrk3 -->
<!ENTITY omicron  CDATA "&#959;" -- greek small letter omicron, U+03BF NEW -->
<!ENTITY pi       CDATA "&#960;" -- greek small letter pi, U+03C0 ISOgrk3 -->
<!ENTITY rho      CDATA "&#961;" -- greek small letter rho, U+03C1 ISOgrk3 -->
<!ENTITY sigmaf   CDATA "&#962;" -- greek small letter final sigma,
                                    U+03C2 ISOgrk3 -->
<!ENTITY sigma    CDATA "&#963;" -- greek small letter sigma,
                                    U+03C3 ISOgrk3 -->
<!ENTITY tau      CDATA "&#964;" -- greek small letter tau, U+03C4 ISOgrk3 -->
<!ENTITY upsilon  CDATA "&#965;" -- greek small letter upsilon,
                                    U+03C5 ISOgrk3 -->
<!ENTITY phi      CDATA "&#966;" -- greek small letter phi, U+03C6 ISOgrk3 -->
<!ENTITY chi      CDATA "&#967;" -- greek small letter chi, U+03C7 ISOgrk3 -->
<!ENTITY psi      CDATA "&#968;" -- greek small letter psi, U+03C8 ISOgrk3 -->
<!ENTITY omega    CDATA "&#969;" -- greek small letter omega,
                                    U+03C9 ISOgrk3 -->
<!ENTITY thetasym CDATA "&#977;" -- greek small letter theta symbol,
                                    U+03D1 NEW -->
<!ENTITY upsih    CDATA "&#978;" -- greek upsilon with hook symbol,
                                    U+03D2 NEW -->
<!ENTITY piv      CDATA "&#982;" -- greek pi symbol, U+03D6 ISOgrk3 -->

<!-- General Punctuation -->
<!ENTITY bull     CDATA "&#8226;" -- bullet = black small circle,
                                     U+2022 ISOpub  -->
<!-- bullet is NOT the same as bullet operator, U+2219 -->
<!ENTITY hellip   CDATA "&#8230;" -- horizontal ellipsis = three dot leader,
                                     U+2026 ISOpub  -->
<!ENTITY prime    CDATA "&#8242;" -- prime = minutes = feet, U+2032 ISOtech -->
<!ENTITY Prime    CDATA "&#8243;" -- double prime = seconds = inches,
                                     U+2033 ISOtech -->
<!ENTITY oline    CDATA "&#8254;" -- overline = spacing overscore,
                                     U+203E NEW -->
<!ENTITY frasl    CDATA "&#8260;" -- fraction slash, U+2044 NEW -->

<!-- Letterlike Symbols -->
<!ENTITY weierp   CDATA "&#8472;" -- script capital P = power set
                                     = Weierstrass p, U+2118 ISOamso -->
<!ENTITY image    CDATA "&#8465;" -- blackletter capital I = imaginary part,
                                     U+2111 ISOamso -->
<!ENTITY real     CDATA "&#8476;" -- blackletter capital R = real part symbol,
                                     U+211C ISOamso -->
<!ENTITY trade    CDATA "&#8482;" -- trade mark sign, U+2122 ISOnum -->
<!ENTITY alefsym  CDATA "&#8501;" -- alef symbol = first transfinite cardinal,
                                     U+2135 NEW -->
<!-- alef symbol is NOT the same as hebrew letter alef,
     U+05D0 although the same glyph could be used to depict both characters -->

<!-- Arrows -->
<!ENTITY larr     CDATA "&#8592;" -- leftwards arrow, U+2190 ISOnum -->
<!ENTITY uarr     CDATA "&#8593;" -- upwards arrow, U+2191 ISOnum-->
<!ENTITY rarr     CDATA "&#8594;" -- rightwards arrow, U+2192 ISOnum -->
<!ENTITY darr     CDATA "&#8595;" -- downwards arrow, U+2193 ISOnum -->
<!ENTITY harr     CDATA "&#8596;" -- left right arrow, U+2194 ISOamsa -->
<!ENTITY crarr    CDATA "&#8629;" -- downwards arrow with corner leftwards
                                     = carriage return, U+21B5 NEW -->
<!ENTITY lArr     CDATA "&#8656;" -- leftwards double arrow, U+21D0 ISOtech -->
<!-- ISO 10646 does not say that lArr is the same as the 'is implied by' arrow
    but also does not have any other character for that function. So ? lArr can
    be used for 'is implied by' as ISOtech suggests -->
<!ENTITY uArr     CDATA "&#8657;" -- upwards double arrow, U+21D1 ISOamsa -->
<!ENTITY rArr     CDATA "&#8658;" -- rightwards double arrow,
                                     U+21D2 ISOtech -->
<!-- ISO 10646 does not say this is the 'implies' character but does not have 
     another character with this function so ?
     rArr can be used for 'implies' as ISOtech suggests -->
<!ENTITY dArr     CDATA "&#8659;" -- downwards double arrow, U+21D3 ISOamsa -->
<!ENTITY hArr     CDATA "&#8660;" -- left right double arrow,
                                     U+21D4 ISOamsa -->

<!-- Mathematical Operators -->
<!ENTITY forall   CDATA "&#8704;" -- for all, U+2200 ISOtech -->
<!ENTITY part     CDATA "&#8706;" -- partial differential, U+2202 ISOtech  -->
<!ENTITY exist    CDATA "&#8707;" -- there exists, U+2203 ISOtech -->
<!ENTITY empty    CDATA "&#8709;" -- empty set = null set = diameter,
                                     U+2205 ISOamso -->
<!ENTITY nabla    CDATA "&#8711;" -- nabla = backward difference,
                                     U+2207 ISOtech -->
<!ENTITY isin     CDATA "&#8712;" -- element of, U+2208 ISOtech -->
<!ENTITY notin    CDATA "&#8713;" -- not an element of, U+2209 ISOtech -->
<!ENTITY ni       CDATA "&#8715;" -- contains as member, U+220B ISOtech -->
<!-- should there be a more memorable name than 'ni'? -->
<!ENTITY prod     CDATA "&#8719;" -- n-ary product = product sign,
                                     U+220F ISOamsb -->
<!-- prod is NOT the same character as U+03A0 'greek capital letter pi' though
     the same glyph might be used for both -->
<!ENTITY sum      CDATA "&#8721;" -- n-ary sumation, U+2211 ISOamsb -->
<!-- sum is NOT the same character as U+03A3 'greek capital letter sigma'
     though the same glyph might be used for both -->
<!ENTITY minus    CDATA "&#8722;" -- minus sign, U+2212 ISOtech -->
<!ENTITY lowast   CDATA "&#8727;" -- asterisk operator, U+2217 ISOtech -->
<!ENTITY radic    CDATA "&#8730;" -- square root = radical sign,
                                     U+221A ISOtech -->
<!ENTITY prop     CDATA "&#8733;" -- proportional to, U+221D ISOtech -->
<!ENTITY infin    CDATA "&#8734;" -- infinity, U+221E ISOtech -->
<!ENTITY ang      CDATA "&#8736;" -- angle, U+2220 ISOamso -->
<!ENTITY and      CDATA "&#8743;" -- logical and = wedge, U+2227 ISOtech -->
<!ENTITY or       CDATA "&#8744;" -- logical or = vee, U+2228 ISOtech -->
<!ENTITY cap      CDATA "&#8745;" -- intersection = cap, U+2229 ISOtech -->
<!ENTITY cup      CDATA "&#8746;" -- union = cup, U+222A ISOtech -->
<!ENTITY int      CDATA "&#8747;" -- integral, U+222B ISOtech -->
<!ENTITY there4   CDATA "&#8756;" -- therefore, U+2234 ISOtech -->
<!ENTITY sim      CDATA "&#8764;" -- tilde operator = varies with = similar to,
                                     U+223C ISOtech -->
<!-- tilde operator is NOT the same character as the tilde, U+007E,
     although the same glyph might be used to represent both  -->
<!ENTITY cong     CDATA "&#8773;" -- approximately equal to, U+2245 ISOtech -->
<!ENTITY asymp    CDATA "&#8776;" -- almost equal to = asymptotic to,
                                     U+2248 ISOamsr -->
<!ENTITY ne       CDATA "&#8800;" -- not equal to, U+2260 ISOtech -->
<!ENTITY equiv    CDATA "&#8801;" -- identical to, U+2261 ISOtech -->
<!ENTITY le       CDATA "&#8804;" -- less-than or equal to, U+2264 ISOtech -->
<!ENTITY ge       CDATA "&#8805;" -- greater-than or equal to,
                                     U+2265 ISOtech -->
<!ENTITY sub      CDATA "&#8834;" -- subset of, U+2282 ISOtech -->
<!ENTITY sup      CDATA "&#8835;" -- superset of, U+2283 ISOtech -->
<!-- note that nsup, 'not a superset of, U+2283' is not covered by the Symbol 
     font encoding and is not included. Should it be, for symmetry?
     It is in ISOamsn  --> 
<!ENTITY nsub     CDATA "&#8836;" -- not a subset of, U+2284 ISOamsn -->
<!ENTITY sube     CDATA "&#8838;" -- subset of or equal to, U+2286 ISOtech -->
<!ENTITY supe     CDATA "&#8839;" -- superset of or equal to,
                                     U+2287 ISOtech -->
<!ENTITY oplus    CDATA "&#8853;" -- circled plus = direct sum,
                                     U+2295 ISOamsb -->
<!ENTITY otimes   CDATA "&#8855;" -- circled times = vector product,
                                     U+2297 ISOamsb -->
<!ENTITY perp     CDATA "&#8869;" -- up tack = orthogonal to = perpendicular,
                                     U+22A5 ISOtech -->
<!ENTITY sdot     CDATA "&#8901;" -- dot operator, U+22C5 ISOamsb -->
<!-- dot operator is NOT the same character as U+00B7 middle dot -->

<!-- Miscellaneous Technical -->
<!ENTITY lceil    CDATA "&#8968;" -- left ceiling = apl upstile,
                                     U+2308 ISOamsc  -->
<!ENTITY rceil    CDATA "&#8969;" -- right ceiling, U+2309 ISOamsc  -->
<!ENTITY lfloor   CDATA "&#8970;" -- left floor = apl downstile,
                                     U+230A ISOamsc  -->
<!ENTITY rfloor   CDATA "&#8971;" -- right floor, U+230B ISOamsc  -->
<!ENTITY lang     CDATA "&#9001;" -- left-pointing angle bracket = bra,
                                     U+2329 ISOtech -->
<!-- lang is NOT the same character as U+003C 'less than' 
     or U+2039 'single left-pointing angle quotation mark' -->
<!ENTITY rang     CDATA "&#9002;" -- right-pointing angle bracket = ket,
                                     U+232A ISOtech -->
<!-- rang is NOT the same character as U+003E 'greater than' 
     or U+203A 'single right-pointing angle quotation mark' -->

<!-- Geometric Shapes -->
<!ENTITY loz      CDATA "&#9674;" -- lozenge, U+25CA ISOpub -->

<!-- Miscellaneous Symbols -->
<!ENTITY spades   CDATA "&#9824;" -- black spade suit, U+2660 ISOpub -->
<!-- black here seems to mean filled as opposed to hollow -->
<!ENTITY clubs    CDATA "&#9827;" -- black club suit = shamrock,
                                     U+2663 ISOpub -->
<!ENTITY hearts   CDATA "&#9829;" -- black heart suit = valentine,
                                     U+2665 ISOpub -->
<!ENTITY diams    CDATA "&#9830;" -- black diamond suit, U+2666 ISOpub -->

24.4 Character entity references for markup-significant and internationalization characters

The character entity references in this section are for escaping markup-significant characters (these are the same as those in HTML 2.0 and 3.2), for denoting spaces and dashes. Other characters in this section apply to internationalization issues such as the disambiguation of bidirectional text (see the section on bidirectional text for details).

Entities have also been added for the remaining characters occurring in CP-1252 which do not occur in the HTMLlat1 or HTMLsymbol entity sets. These all occur in the 128 to 159 range within the CP-1252 charset. These entities permit the characters to be denoted in a platform-independent manner.

To support these entities, user agents may support full [ISO10646] or use other means. Display of glyphs for these characters may be obtained by being able to display the relevant [ISO10646] characters or by other means, such as internally mapping the listed entities, numeric character references, and characters to the appropriate position in some font that contains the requisite glyphs.

24.4.1 The list of characters

<!-- Special characters for HTML -->

<!-- Character entity set. Typical invocation:
     <!ENTITY % HTMLspecial PUBLIC
       "-//W3C//ENTITIES Special//EN//HTML">
     %HTMLspecial; -->

<!-- Portions  International Organization for Standardization 1986:
     Permission to copy in any form is granted for use with
     conforming SGML systems and applications as defined in
     ISO 8879, provided this notice is included in all copies.
-->

<!-- Relevant ISO entity set is given unless names are newly introduced.
     New names (i.e., not in ISO 8879 list) do not clash with any
     existing ISO 8879 entity names. ISO 10646 character numbers
     are given for each character, in hex. CDATA values are decimal
     conversions of the ISO 10646 values and refer to the document
     character set. Names are ISO 10646 names. 

-->

<!-- C0 Controls and Basic Latin -->
<!ENTITY quot    CDATA "&#34;"   -- quotation mark = APL quote,
                                    U+0022 ISOnum -->
<!ENTITY amp     CDATA "&#38;"   -- ampersand, U+0026 ISOnum -->
<!ENTITY lt      CDATA "&#60;"   -- less-than sign, U+003C ISOnum -->
<!ENTITY gt      CDATA "&#62;"   -- greater-than sign, U+003E ISOnum -->

<!-- Latin Extended-A -->
<!ENTITY OElig   CDATA "&#338;"  -- latin capital ligature OE,
                                    U+0152 ISOlat2 -->
<!ENTITY oelig   CDATA "&#339;"  -- latin small ligature oe, U+0153 ISOlat2 -->
<!-- ligature is a misnomer, this is a separate character in some languages -->
<!ENTITY Scaron  CDATA "&#352;"  -- latin capital letter S with caron,
                                    U+0160 ISOlat2 -->
<!ENTITY scaron  CDATA "&#353;"  -- latin small letter s with caron,
                                    U+0161 ISOlat2 -->
<!ENTITY Yuml    CDATA "&#376;"  -- latin capital letter Y with diaeresis,
                                    U+0178 ISOlat2 -->

<!-- Spacing Modifier Letters -->
<!ENTITY circ    CDATA "&#710;"  -- modifier letter circumflex accent,
                                    U+02C6 ISOpub -->
<!ENTITY tilde   CDATA "&#732;"  -- small tilde, U+02DC ISOdia -->

<!-- General Punctuation -->
<!ENTITY ensp    CDATA "&#8194;" -- en space, U+2002 ISOpub -->
<!ENTITY emsp    CDATA "&#8195;" -- em space, U+2003 ISOpub -->
<!ENTITY thinsp  CDATA "&#8201;" -- thin space, U+2009 ISOpub -->
<!ENTITY zwnj    CDATA "&#8204;" -- zero width non-joiner,
                                    U+200C NEW RFC 2070 -->
<!ENTITY zwj     CDATA "&#8205;" -- zero width joiner, U+200D NEW RFC 2070 -->
<!ENTITY lrm     CDATA "&#8206;" -- left-to-right mark, U+200E NEW RFC 2070 -->
<!ENTITY rlm     CDATA "&#8207;" -- right-to-left mark, U+200F NEW RFC 2070 -->
<!ENTITY ndash   CDATA "&#8211;" -- en dash, U+2013 ISOpub -->
<!ENTITY mdash   CDATA "&#8212;" -- em dash, U+2014 ISOpub -->
<!ENTITY lsquo   CDATA "&#8216;" -- left single quotation mark,
                                    U+2018 ISOnum -->
<!ENTITY rsquo   CDATA "&#8217;" -- right single quotation mark,
                                    U+2019 ISOnum -->
<!ENTITY sbquo   CDATA "&#8218;" -- single low-9 quotation mark, U+201A NEW -->
<!ENTITY ldquo   CDATA "&#8220;" -- left double quotation mark,
                                    U+201C ISOnum -->
<!ENTITY rdquo   CDATA "&#8221;" -- right double quotation mark,
                                    U+201D ISOnum -->
<!ENTITY bdquo   CDATA "&#8222;" -- double low-9 quotation mark, U+201E NEW -->
<!ENTITY dagger  CDATA "&#8224;" -- dagger, U+2020 ISOpub -->
<!ENTITY Dagger  CDATA "&#8225;" -- double dagger, U+2021 ISOpub -->
<!ENTITY permil  CDATA "&#8240;" -- per mille sign, U+2030 ISOtech -->
<!ENTITY lsaquo  CDATA "&#8249;" -- single left-pointing angle quotation mark,
                                    U+2039 ISO proposed -->
<!-- lsaquo is proposed but not yet ISO standardized -->
<!ENTITY rsaquo  CDATA "&#8250;" -- single right-pointing angle quotation mark,
                                    U+203A ISO proposed -->
<!-- rsaquo is proposed but not yet ISO standardized -->
<!ENTITY euro   CDATA "&#8364;"  -- euro sign, U+20AC NEW -->
libgd-gd-2.1.1/src/entities.tcl000066400000000000000000000025451245535672000163220ustar00rootroot00000000000000#!/usr/bin/tclsh # get names for html-4.0 characters from: # http://www.w3.org/TR/REC-html40/sgml/entities.html set f [open entities.html r] set entity_name_length_max 0 set nr_of_entities 0 while {! [eof $f]} { set rec [gets $f] if {[scan $rec {<!ENTITY %s CDATA "&#%d;"; --} name val] == 2} { set entity($name) $val set entity_name_length [string length $name] if {$entity_name_length > $entity_name_length_max} { set entity_name_length_max $entity_name_length } incr nr_of_entities } } close $f set f [open entities.h w] puts $f "/*" puts $f " * Generated file - do not edit directly." puts $f " *" puts $f " * This file was generated from:" puts $f " * http://www.w3.org/TR/REC-html40/sgml/entities.html" puts $f " * by means of the script:" puts $f " * entities.tcl" puts $f " */" puts $f "" puts $f "#ifdef __cplusplus" puts $f "extern \"C\" {" puts $f "#endif" puts $f "" puts $f "static struct entities_s {" puts $f " char *name;" puts $f " int value;" puts $f "} entities\[\] = {" foreach name [lsort [array names entity]] { puts $f " {\"$name\", $entity($name)}," } puts $f "};" puts $f "" puts $f "#define ENTITY_NAME_LENGTH_MAX $entity_name_length_max" puts $f "#define NR_OF_ENTITIES $nr_of_entities" puts $f "" puts $f "#ifdef __cplusplus" puts $f "}" puts $f "#endif" close $f libgd-gd-2.1.1/src/fontconfigtest.c000066400000000000000000000025341245535672000171700ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" int main (int argc, char *argv[]) { gdImagePtr im; int green, blue; gdFTStringExtra se; FILE *out; im = gdImageCreateTrueColor(300, 100); green = gdImageColorAllocate(im, 128, 255, 128); gdImageFilledRectangle(im, 0, 0, 300, 100, green); blue = gdImageColorAllocate(im, 128, 128, 255); /* Default: fontlist argument is a pathname to a truetype font */ gdImageStringFT(im, 0, blue, "arial", 12, 0, 20, 20, "plain pathname default"); /* Specifically opt for fontconfig */ se.flags = gdFTEX_FONTCONFIG; gdImageStringFTEx(im, 0, blue, "arial:bold", 12, 0, 20, 40, "fontconfig arial:bold", &se); /* Change the default to fontconfig */ if (!gdFTUseFontConfig(1)) { fprintf(stderr, "fontconfig not compiled into gd\n"); } /* Use fontconfig by (newly set) default */ gdImageStringFT(im, 0, blue, "arial:bold", 12, 0, 20, 60, "fontconfig arial:bold default"); /* Explicitly use a pathname despite fontconfig default */ se.flags = gdFTEX_FONTPATHNAME; gdImageStringFTEx(im, 0, blue, "arial", 12, 0, 20, 80, "plain pathname", &se); #ifdef HAVE_LIBPNG out = fopen("fontconfigtest.png", "wb"); gdImagePng(im, out); fclose(out); #else fprintf(stderr, "PNG not compiled into gd\n"); #endif /* HAVE_LIBPNG */ return 0; } libgd-gd-2.1.1/src/fontsizetest.c000066400000000000000000000044621245535672000166770ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" void dosizes (gdImagePtr im, int color, char *fontfile, int x, int y, const char *string) { int brect[8]; double curang = 0.0; char *cp; int cursize; char buf[60]; for (cursize = 1; cursize <= 20; cursize++) { sprintf (buf, "%d: %s", cursize, string); /* The case of newlines is taken care of in the gdImageStringTTF call */ #if defined(OLDER_GD) cp = gdImageStringTTF (im, brect, color, fontfile, cursize, curang, x, y, buf); #else cp = gdImageStringFT (im, brect, color, fontfile, cursize, curang, x, y, buf); #endif if (cp) fprintf(stderr, "%s\n", cp); y += cursize + 4; /* render the same fontsize with antialiasing turned off */ #if defined(OLDER_GD) cp = gdImageStringTTF (im, brect, 0 - color, fontfile, cursize, curang, x, y, buf); #else cp = gdImageStringFT (im, brect, 0 - color, fontfile, cursize, curang, x, y, buf); #endif if (cp) fprintf(stderr, "%s\n", cp); y += cursize + 4; } } void dotest (char *font, int w, int h, char *string, const char *filename) { gdImagePtr im; FILE *out; int bg; int fc; im = gdImageCreate (w, h); bg = gdImageColorAllocate (im, 0, 0, 0); gdImageFilledRectangle (im, 1, 1, w - 1, h - 1, bg); fc = gdImageColorAllocate (im, 255, 192, 192); out = fopen (filename, "wb"); dosizes (im, fc, font, 20, 20, string); #if defined(HAVE_LIBPNG) gdImagePng (im, out); #elif defined(HAVE_LIBJPEG) gdImageJpeg (im, out, -1); #endif fclose (out); } int main(void) { #if defined(HAVE_LIBPNG) dotest ("times", 400, 600, ".....Hello, there!", "fontsizetest1.png"); dotest ("cour", 400, 600, ".....Hello, there!", "fontsizetest2.png"); dotest ("arial", 400, 600, ".....Hello, there!", "fontsizetest3.png"); dotest ("luximr", 400, 600, ".....Hello, there!", "fontsizetest4.png"); #elif defined(HAVE_LIBJPEG) dotest ("times", 400, 600, ".....Hello, there!", "fontsizetest1.jpeg"); dotest ("cour", 400, 600, ".....Hello, there!", "fontsizetest2.jpeg"); dotest ("arial", 400, 600, ".....Hello, there!", "fontsizetest3.jpeg"); dotest ("luximr", 400, 600, ".....Hello, there!", "fontsizetest4.jpeg"); #else fprintf(stderr, "no PNG or JPEG support\n"); #endif return 0; } libgd-gd-2.1.1/src/fontwheeltest.c000066400000000000000000000063551245535672000170340ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include "gd.h" #define DEGTORAD(x) ( (x) * (2.0 * 3.14159265) / 360.0 ) void doerr (FILE * err, const char *msg) { if (err) { fprintf (err, "%s\n", msg); fflush (err); } } void dowheel (gdImagePtr im, int color, char *fontfile, int fontsize, double angle, int x, int y, int offset, char *string) { int brect[8]; FILE *err; double curangrads, curang, x0, y0; char *cp; err = fopen ("err.out", "a"); doerr (err, "------------- New fontwheel --------------"); doerr (err, fontfile); doerr (err, string); doerr (err, "------------------------------------------"); for (curang = 0.0; curang < 360.0; curang += angle) { curangrads = DEGTORAD(curang); x0 = x + cos (curangrads) * offset; y0 = y - sin (curangrads) * offset; /* The case of newlines is taken care of in the gdImageStringTTF call */ #if defined(OLDER_GD) cp = gdImageStringTTF (im, brect, color, fontfile, fontsize, curangrads, x0, y0, string); #else cp = gdImageStringFT (im, brect, color, fontfile, fontsize, curangrads, x0, y0, string); #endif if (cp) doerr (err, cp); gdImagePolygon (im, (gdPointPtr)brect, 4, color); } fclose (err); } #if 0 void dolines (gdImagePtr im, int color, double incr, int x, int y, int offset, int length) { double curang; double angle; double x0, x1, y0, y1; for (curang = 0.0; curang < 360.0; curang += incr) { angle = curang * (2.0 * 3.14159265) / 360.0; x0 = cos (angle) * offset + x; x1 = cos (angle) * (offset + length) + x; y0 = sin (angle) * offset + y; y1 = sin (angle) * (offset + length) + y; gdImageLine (im, x0, y0, x1, y1, color); } } #endif void dotest (char *font, int size, double incr, int w, int h, char *string, const char *filename) { gdImagePtr im; FILE *out; int bg; int fc; #if 0 int lc; #endif int xc = w / 2; int yc = h / 2; im = gdImageCreate (w, h); bg = gdImageColorAllocate (im, 0, 0, 0); gdImageFilledRectangle (im, 1, 1, w - 1, h - 1, bg); fc = gdImageColorAllocate (im, 255, 192, 192); #if 0 lc = gdImageColorAllocate (im, 192, 255, 255); #endif out = fopen (filename, "wb"); dowheel (im, fc, font, size, incr, xc, yc, 20, string); #if 0 dolines (im, lc, incr, xc, yc, 20, 120); #endif #if defined(HAVE_LIBPNG) gdImagePng (im, out); #elif defined(HAVE_LIBJPEG) gdImageJpeg (im, out, -1); #endif fclose (out); } int main(void) { #if defined(HAVE_LIBPNG) dotest ("times", 16, 20.0, 400, 400, "Hello, there!", "fontwheeltest1.png"); dotest ("times", 16, 30.0, 400, 400, "Hello, there!", "fontwheeltest2.png"); dotest ("arial", 16, 45.0, 400, 400, "Hello, there!", "fontwheeltest3.png"); dotest ("arial", 16, 90.0, 400, 400, "Hello\nthere!", "fontwheeltest4.png"); #elif defined(HAVE_LIBJPEG) dotest ("times", 16, 20.0, 400, 400, "Hello, there!", "fontwheeltest1.jpeg"); dotest ("times", 16, 30.0, 400, 400, "Hello, there!", "fontwheeltest2.jpeg"); dotest ("arial", 16, 45.0, 400, 400, "Hello, there!", "fontwheeltest3.jpeg"); dotest ("arial", 16, 90.0, 400, 400, "Hello\nthere!", "fontwheeltest4.jpeg"); #else fprintf(stderr, "no PNG or JPEG support\n"); #endif return 0; } libgd-gd-2.1.1/src/gd.c000066400000000000000000002527571245535672000145440ustar00rootroot00000000000000/* $Id$ */ #include #include #include #include #include #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd_intern.h" /* 2.03: don't include zlib here or we can't build without PNG */ #include "gd.h" #include "gdhelpers.h" #include "gd_color.h" #include "gd_errors.h" /* 2.0.12: this now checks the clipping rectangle */ #define gdImageBoundsSafeMacro(im, x, y) (!((((y) < (im)->cy1) || ((y) > (im)->cy2)) || (((x) < (im)->cx1) || ((x) > (im)->cx2)))) #ifdef _OSD_POSIX /* BS2000 uses the EBCDIC char set instead of ASCII */ #define CHARSET_EBCDIC #define __attribute__(any) /*nothing */ #endif /*_OSD_POSIX*/ #ifndef CHARSET_EBCDIC #define ASC(ch) ch #else /*CHARSET_EBCDIC */ #define ASC(ch) gd_toascii[(unsigned char)ch] static const unsigned char gd_toascii[256] = { /*00 */ 0x00, 0x01, 0x02, 0x03, 0x85, 0x09, 0x86, 0x7f, 0x87, 0x8d, 0x8e, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, /*................ */ /*10 */ 0x10, 0x11, 0x12, 0x13, 0x8f, 0x0a, 0x08, 0x97, 0x18, 0x19, 0x9c, 0x9d, 0x1c, 0x1d, 0x1e, 0x1f, /*................ */ /*20 */ 0x80, 0x81, 0x82, 0x83, 0x84, 0x92, 0x17, 0x1b, 0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x05, 0x06, 0x07, /*................ */ /*30 */ 0x90, 0x91, 0x16, 0x93, 0x94, 0x95, 0x96, 0x04, 0x98, 0x99, 0x9a, 0x9b, 0x14, 0x15, 0x9e, 0x1a, /*................ */ /*40 */ 0x20, 0xa0, 0xe2, 0xe4, 0xe0, 0xe1, 0xe3, 0xe5, 0xe7, 0xf1, 0x60, 0x2e, 0x3c, 0x28, 0x2b, 0x7c, /* .........`.<(+| */ /*50 */ 0x26, 0xe9, 0xea, 0xeb, 0xe8, 0xed, 0xee, 0xef, 0xec, 0xdf, 0x21, 0x24, 0x2a, 0x29, 0x3b, 0x9f, /*&.........!$*);. */ /*60 */ 0x2d, 0x2f, 0xc2, 0xc4, 0xc0, 0xc1, 0xc3, 0xc5, 0xc7, 0xd1, 0x5e, 0x2c, 0x25, 0x5f, 0x3e, 0x3f, /*-/........^,%_>?*/ /*70 */ 0xf8, 0xc9, 0xca, 0xcb, 0xc8, 0xcd, 0xce, 0xcf, 0xcc, 0xa8, 0x3a, 0x23, 0x40, 0x27, 0x3d, 0x22, /*..........:#@'=" */ /*80 */ 0xd8, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0xab, 0xbb, 0xf0, 0xfd, 0xfe, 0xb1, /*.abcdefghi...... */ /*90 */ 0xb0, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f, 0x70, 0x71, 0x72, 0xaa, 0xba, 0xe6, 0xb8, 0xc6, 0xa4, /*.jklmnopqr...... */ /*a0 */ 0xb5, 0xaf, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79, 0x7a, 0xa1, 0xbf, 0xd0, 0xdd, 0xde, 0xae, /*..stuvwxyz...... */ /*b0 */ 0xa2, 0xa3, 0xa5, 0xb7, 0xa9, 0xa7, 0xb6, 0xbc, 0xbd, 0xbe, 0xac, 0x5b, 0x5c, 0x5d, 0xb4, 0xd7, /*...........[\].. */ /*c0 */ 0xf9, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48, 0x49, 0xad, 0xf4, 0xf6, 0xf2, 0xf3, 0xf5, /*.ABCDEFGHI...... */ /*d0 */ 0xa6, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f, 0x50, 0x51, 0x52, 0xb9, 0xfb, 0xfc, 0xdb, 0xfa, 0xff, /*.JKLMNOPQR...... */ /*e0 */ 0xd9, 0xf7, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59, 0x5a, 0xb2, 0xd4, 0xd6, 0xd2, 0xd3, 0xd5, /*..STUVWXYZ...... */ /*f0 */ 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0xb3, 0x7b, 0xdc, 0x7d, 0xda, 0x7e /*0123456789.{.}.~ */ }; #endif /*CHARSET_EBCDIC */ extern const int gdCosT[]; extern const int gdSinT[]; void gd_stderr_error(int priority, const char *format, va_list args) { switch (priority) { case GD_ERROR: fputs("GD Error: ", stderr); break; case GD_WARNING: fputs("GD Warning: ", stderr); break; case GD_NOTICE: fputs("GD Notice: ", stderr); break; case GD_INFO: fputs("GD Info: ", stderr); break; case GD_DEBUG: fputs("GD Debug: ", stderr); break; } vfprintf(stderr, format, args); fflush(stderr); } static gdErrorMethod gd_error_method = gd_stderr_error; void gd_error(const char *format, ...) { va_list args; va_start(args, format); gd_error_ex(GD_WARNING, format, args); va_end(args); } void gd_error_ex(int priority, const char *format, ...) { va_list args; va_start(args, format); if (gd_error_method) { gd_error_method(priority, format, args); } va_end(args); } BGD_DECLARE(void) gdSetErrorMethod(gdErrorMethod error_method) { gd_error_method = error_method; } BGD_DECLARE(void) gdClearErrorMethod(void) { gd_error_method = gd_stderr_error; } static void gdImageBrushApply (gdImagePtr im, int x, int y); static void gdImageTileApply (gdImagePtr im, int x, int y); BGD_DECLARE(int) gdImageGetTrueColorPixel (gdImagePtr im, int x, int y); /* Function: gdImageCreate gdImageCreate is called to create palette-based images, with no more than 256 colors. The image must eventually be destroyed using gdImageDestroy(). Parameters: sx - The image width. sy - The image height. Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > im = gdImageCreate(64, 64); > // ... Use the image ... > gdImageDestroy(im); See Also: */ BGD_DECLARE(gdImagePtr) gdImageCreate (int sx, int sy) { int i; gdImagePtr im; if (overflow2(sizeof (unsigned char *), sy)) { return NULL; } if (overflow2(sizeof (unsigned char *), sx)) { return NULL; } im = (gdImage *) gdCalloc(1, sizeof(gdImage)); if (!im) { return NULL; } /* Row-major ever since gd 1.3 */ im->pixels = (unsigned char **) gdMalloc (sizeof (unsigned char *) * sy); if (!im->pixels) { gdFree(im); return NULL; } im->polyInts = 0; im->polyAllocated = 0; im->brush = 0; im->tile = 0; im->style = 0; for (i = 0; (i < sy); i++) { /* Row-major ever since gd 1.3 */ im->pixels[i] = (unsigned char *) gdCalloc (sx, sizeof (unsigned char)); if (!im->pixels[i]) { for (--i ; i >= 0; i--) { gdFree(im->pixels[i]); } gdFree(im->pixels); gdFree(im); return NULL; } } im->sx = sx; im->sy = sy; im->colorsTotal = 0; im->transparent = (-1); im->interlace = 0; im->thick = 1; im->AA = 0; for (i = 0; (i < gdMaxColors); i++) { im->open[i] = 1; }; im->trueColor = 0; im->tpixels = 0; im->cx1 = 0; im->cy1 = 0; im->cx2 = im->sx - 1; im->cy2 = im->sy - 1; im->res_x = GD_RESOLUTION; im->res_y = GD_RESOLUTION; im->interpolation = NULL; im->interpolation_id = GD_BILINEAR_FIXED; return im; } /* Function: gdImageCreateTrueColor is called to create truecolor images, with an essentially unlimited number of colors. Invoke with the x and y dimensions of the desired image. returns a to the new image, or NULL if unable to allocate the image. The image must eventually be destroyed using (). Truecolor images are always filled with black at creation time. There is no concept of a "background" color index. Parameters: sx - The image width. sy - The image height. Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > im = gdImageCreateTrueColor(64, 64); > // ... Use the image ... > gdImageDestroy(im); See Also: */ BGD_DECLARE(gdImagePtr) gdImageCreateTrueColor (int sx, int sy) { int i; gdImagePtr im; if (overflow2(sx, sy)) { return NULL; } if (overflow2(sizeof (int *), sy)) { return 0; } if (overflow2(sizeof(int), sx)) { return NULL; } im = (gdImage *) gdMalloc (sizeof (gdImage)); if (!im) { return 0; } memset (im, 0, sizeof (gdImage)); im->tpixels = (int **) gdMalloc (sizeof (int *) * sy); if (!im->tpixels) { gdFree(im); return 0; } im->polyInts = 0; im->polyAllocated = 0; im->brush = 0; im->tile = 0; im->style = 0; for (i = 0; (i < sy); i++) { im->tpixels[i] = (int *) gdCalloc (sx, sizeof (int)); if (!im->tpixels[i]) { /* 2.0.34 */ i--; while (i >= 0) { gdFree(im->tpixels[i]); i--; } gdFree(im->tpixels); gdFree(im); return 0; } } im->sx = sx; im->sy = sy; im->transparent = (-1); im->interlace = 0; im->trueColor = 1; /* 2.0.2: alpha blending is now on by default, and saving of alpha is off by default. This allows font antialiasing to work as expected on the first try in JPEGs -- quite important -- and also allows for smaller PNGs when saving of alpha channel is not really desired, which it usually isn't! */ im->saveAlphaFlag = 0; im->alphaBlendingFlag = 1; im->thick = 1; im->AA = 0; im->cx1 = 0; im->cy1 = 0; im->cx2 = im->sx - 1; im->cy2 = im->sy - 1; im->res_x = GD_RESOLUTION; im->res_y = GD_RESOLUTION; im->interpolation = NULL; im->interpolation_id = GD_BILINEAR_FIXED; return im; } /* Function: gdImageDestroy is used to free the memory associated with an image. It is important to invoke before exiting your program or assigning a new image to a variable. Parameters: im - Pointer to the gdImage to delete. Returns: Nothing. Example: > gdImagePtr im; > im = gdImageCreate(10, 10); > // ... Use the image ... > // Now destroy it > gdImageDestroy(im); */ BGD_DECLARE(void) gdImageDestroy (gdImagePtr im) { int i; if (im->pixels) { for (i = 0; (i < im->sy); i++) { gdFree (im->pixels[i]); } gdFree (im->pixels); } if (im->tpixels) { for (i = 0; (i < im->sy); i++) { gdFree (im->tpixels[i]); } gdFree (im->tpixels); } if (im->polyInts) { gdFree (im->polyInts); } if (im->style) { gdFree (im->style); } gdFree (im); } BGD_DECLARE(int) gdImageColorClosest (gdImagePtr im, int r, int g, int b) { return gdImageColorClosestAlpha (im, r, g, b, gdAlphaOpaque); } BGD_DECLARE(int) gdImageColorClosestAlpha (gdImagePtr im, int r, int g, int b, int a) { int i; long rd, gd, bd, ad; int ct = (-1); int first = 1; long mindist = 0; if (im->trueColor) { return gdTrueColorAlpha (r, g, b, a); } for (i = 0; (i < (im->colorsTotal)); i++) { long dist; if (im->open[i]) { continue; } rd = (im->red[i] - r); gd = (im->green[i] - g); bd = (im->blue[i] - b); /* gd 2.02: whoops, was - b (thanks to David Marwood) */ /* gd 2.16: was blue rather than alpha! Geez! Thanks to Artur Jakub Jerzak */ ad = (im->alpha[i] - a); dist = rd * rd + gd * gd + bd * bd + ad * ad; if (first || (dist < mindist)) { mindist = dist; ct = i; first = 0; } } return ct; } /* This code is taken from http://www.acm.org/jgt/papers/SmithLyons96/hwb_rgb.html, an article * on colour conversion to/from RBG and HWB colour systems. * It has been modified to return the converted value as a * parameter. */ #define RETURN_HWB(h, w, b) {HWB->H = h; HWB->W = w; HWB->B = b; return HWB;} #define RETURN_RGB(r, g, b) {RGB->R = r; RGB->G = g; RGB->B = b; return RGB;} #define HWB_UNDEFINED -1 #define SETUP_RGB(s, r, g, b) {s.R = r/255.0; s.G = g/255.0; s.B = b/255.0;} #define MIN(a,b) ((a)<(b)?(a):(b)) #define MIN3(a,b,c) ((a)<(b)?(MIN(a,c)):(MIN(b,c))) #define MAX(a,b) ((a)<(b)?(b):(a)) #define MAX3(a,b,c) ((a)<(b)?(MAX(b,c)):(MAX(a,c))) /* * Theoretically, hue 0 (pure red) is identical to hue 6 in these transforms. Pure * red always maps to 6 in this implementation. Therefore UNDEFINED can be * defined as 0 in situations where only unsigned numbers are desired. */ typedef struct { float R, G, B; } RGBType; typedef struct { float H, W, B; } HWBType; static HWBType * RGB_to_HWB (RGBType RGB, HWBType * HWB) { /* * RGB are each on [0, 1]. W and B are returned on [0, 1] and H is * returned on [0, 6]. Exception: H is returned UNDEFINED if W == 1 - B. */ float R = RGB.R, G = RGB.G, B = RGB.B, w, v, b, f; int i; w = MIN3 (R, G, B); v = MAX3 (R, G, B); b = 1 - v; if (v == w) RETURN_HWB (HWB_UNDEFINED, w, b); f = (R == w) ? G - B : ((G == w) ? B - R : R - G); i = (R == w) ? 3 : ((G == w) ? 5 : 1); RETURN_HWB (i - f / (v - w), w, b); } static float HWB_Diff (int r1, int g1, int b1, int r2, int g2, int b2) { RGBType RGB1, RGB2; HWBType HWB1, HWB2; float diff; SETUP_RGB (RGB1, r1, g1, b1); SETUP_RGB (RGB2, r2, g2, b2); RGB_to_HWB (RGB1, &HWB1); RGB_to_HWB (RGB2, &HWB2); /* * I made this bit up; it seems to produce OK results, and it is certainly * more visually correct than the current RGB metric. (PJW) */ if ((HWB1.H == HWB_UNDEFINED) || (HWB2.H == HWB_UNDEFINED)) { diff = 0; /* Undefined hues always match... */ } else { diff = fabs (HWB1.H - HWB2.H); if (diff > 3) { diff = 6 - diff; /* Remember, it's a colour circle */ } } diff = diff * diff + (HWB1.W - HWB2.W) * (HWB1.W - HWB2.W) + (HWB1.B - HWB2.B) * (HWB1.B - HWB2.B); return diff; } #if 0 /* * This is not actually used, but is here for completeness, in case someone wants to * use the HWB stuff for anything else... */ static RGBType * HWB_to_RGB (HWBType HWB, RGBType * RGB) { /* * H is given on [0, 6] or UNDEFINED. W and B are given on [0, 1]. * RGB are each returned on [0, 1]. */ float h = HWB.H, w = HWB.W, b = HWB.B, v, n, f; int i; v = 1 - b; if (h == HWB_UNDEFINED) RETURN_RGB (v, v, v); i = floor (h); f = h - i; if (i & 1) f = 1 - f; /* if i is odd */ n = w + f * (v - w); /* linear interpolation between w and v */ switch (i) { case 6: case 0: RETURN_RGB (v, n, w); case 1: RETURN_RGB (n, v, w); case 2: RETURN_RGB (w, v, n); case 3: RETURN_RGB (w, n, v); case 4: RETURN_RGB (n, w, v); case 5: RETURN_RGB (v, w, n); } return RGB; } #endif BGD_DECLARE(int) gdImageColorClosestHWB (gdImagePtr im, int r, int g, int b) { int i; /* long rd, gd, bd; */ int ct = (-1); int first = 1; float mindist = 0; if (im->trueColor) { return gdTrueColor (r, g, b); } for (i = 0; (i < (im->colorsTotal)); i++) { float dist; if (im->open[i]) { continue; } dist = HWB_Diff (im->red[i], im->green[i], im->blue[i], r, g, b); if (first || (dist < mindist)) { mindist = dist; ct = i; first = 0; } } return ct; } BGD_DECLARE(int) gdImageColorExact (gdImagePtr im, int r, int g, int b) { return gdImageColorExactAlpha (im, r, g, b, gdAlphaOpaque); } BGD_DECLARE(int) gdImageColorExactAlpha (gdImagePtr im, int r, int g, int b, int a) { int i; if (im->trueColor) { return gdTrueColorAlpha (r, g, b, a); } for (i = 0; (i < (im->colorsTotal)); i++) { if (im->open[i]) { continue; } if ((im->red[i] == r) && (im->green[i] == g) && (im->blue[i] == b) && (im->alpha[i] == a)) { return i; } } return -1; } BGD_DECLARE(int) gdImageColorAllocate (gdImagePtr im, int r, int g, int b) { return gdImageColorAllocateAlpha (im, r, g, b, gdAlphaOpaque); } BGD_DECLARE(int) gdImageColorAllocateAlpha (gdImagePtr im, int r, int g, int b, int a) { int i; int ct = (-1); if (im->trueColor) { return gdTrueColorAlpha (r, g, b, a); } for (i = 0; (i < (im->colorsTotal)); i++) { if (im->open[i]) { ct = i; break; } } if (ct == (-1)) { ct = im->colorsTotal; if (ct == gdMaxColors) { return -1; } im->colorsTotal++; } im->red[ct] = r; im->green[ct] = g; im->blue[ct] = b; im->alpha[ct] = a; im->open[ct] = 0; return ct; } /* * gdImageColorResolve is an alternative for the code fragment: * * if ((color=gdImageColorExact(im,R,G,B)) < 0) * if ((color=gdImageColorAllocate(im,R,G,B)) < 0) * color=gdImageColorClosest(im,R,G,B); * * in a single function. Its advantage is that it is guaranteed to * return a color index in one search over the color table. */ BGD_DECLARE(int) gdImageColorResolve (gdImagePtr im, int r, int g, int b) { return gdImageColorResolveAlpha (im, r, g, b, gdAlphaOpaque); } BGD_DECLARE(int) gdImageColorResolveAlpha (gdImagePtr im, int r, int g, int b, int a) { int c; int ct = -1; int op = -1; long rd, gd, bd, ad, dist; long mindist = 4 * 255 * 255; /* init to max poss dist */ if (im->trueColor) { return gdTrueColorAlpha (r, g, b, a); } for (c = 0; c < im->colorsTotal; c++) { if (im->open[c]) { op = c; /* Save open slot */ continue; /* Color not in use */ } if (c == im->transparent) { /* don't ever resolve to the color that has * been designated as the transparent color */ continue; } rd = (long) (im->red[c] - r); gd = (long) (im->green[c] - g); bd = (long) (im->blue[c] - b); ad = (long) (im->alpha[c] - a); dist = rd * rd + gd * gd + bd * bd + ad * ad; if (dist < mindist) { if (dist == 0) { return c; /* Return exact match color */ } mindist = dist; ct = c; } } /* no exact match. We now know closest, but first try to allocate exact */ if (op == -1) { op = im->colorsTotal; if (op == gdMaxColors) { /* No room for more colors */ return ct; /* Return closest available color */ } im->colorsTotal++; } im->red[op] = r; im->green[op] = g; im->blue[op] = b; im->alpha[op] = a; im->open[op] = 0; return op; /* Return newly allocated color */ } BGD_DECLARE(void) gdImageColorDeallocate (gdImagePtr im, int color) { if (im->trueColor || (color >= gdMaxColors) || (color < 0)) { return; } /* Mark it open. */ im->open[color] = 1; } BGD_DECLARE(void) gdImageColorTransparent (gdImagePtr im, int color) { if (!im->trueColor) { if((color < -1) || (color >= gdMaxColors)) { return; } if (im->transparent != -1) { im->alpha[im->transparent] = gdAlphaOpaque; } if (color != -1) { im->alpha[color] = gdAlphaTransparent; } } im->transparent = color; } BGD_DECLARE(void) gdImagePaletteCopy (gdImagePtr to, gdImagePtr from) { int i; int x, y, p; int xlate[256]; if (to->trueColor) { return; } if (from->trueColor) { return; } for (i = 0; i < 256; i++) { xlate[i] = -1; }; for (y = 0; y < (to->sy); y++) { for (x = 0; x < (to->sx); x++) { /* Optimization: no gdImageGetPixel */ p = to->pixels[y][x]; if (xlate[p] == -1) { /* This ought to use HWB, but we don't have an alpha-aware version of that yet. */ xlate[p] = gdImageColorClosestAlpha (from, to->red[p], to->green[p], to->blue[p], to->alpha[p]); /*printf("Mapping %d (%d, %d, %d, %d) to %d (%d, %d, %d, %d)\n", */ /* p, to->red[p], to->green[p], to->blue[p], to->alpha[p], */ /* xlate[p], from->red[xlate[p]], from->green[xlate[p]], from->blue[xlate[p]], from->alpha[xlate[p]]); */ }; /* Optimization: no gdImageSetPixel */ to->pixels[y][x] = xlate[p]; }; }; for (i = 0; (i < (from->colorsTotal)); i++) { /*printf("Copying color %d (%d, %d, %d, %d)\n", i, from->red[i], from->blue[i], from->green[i], from->alpha[i]); */ to->red[i] = from->red[i]; to->blue[i] = from->blue[i]; to->green[i] = from->green[i]; to->alpha[i] = from->alpha[i]; to->open[i] = 0; }; for (i = from->colorsTotal; (i < to->colorsTotal); i++) { to->open[i] = 1; }; to->colorsTotal = from->colorsTotal; } BGD_DECLARE(int) gdImageColorReplace (gdImagePtr im, int src, int dst) { register int x, y; int n = 0; if (src == dst) { return 0; } #define REPLACING_LOOP(pixel) do { \ for (y = im->cy1; y <= im->cy2; y++) { \ for (x = im->cx1; x <= im->cx2; x++) { \ if (pixel(im, x, y) == src) { \ gdImageSetPixel(im, x, y, dst); \ n++; \ } \ } \ } \ } while (0) if (im->trueColor) { REPLACING_LOOP(gdImageTrueColorPixel); } else { REPLACING_LOOP(gdImagePalettePixel); } #undef REPLACING_LOOP return n; } BGD_DECLARE(int) gdImageColorReplaceThreshold (gdImagePtr im, int src, int dst, float threshold) { register int x, y; int n = 0; if (src == dst) { return 0; } #define REPLACING_LOOP(pixel) do { \ for (y = im->cy1; y <= im->cy2; y++) { \ for (x = im->cx1; x <= im->cx2; x++) { \ if (gdColorMatch(im, src, pixel(im, x, y), threshold)) { \ gdImageSetPixel(im, x, y, dst); \ n++; \ } \ } \ } \ } while (0) if (im->trueColor) { REPLACING_LOOP(gdImageTrueColorPixel); } else { REPLACING_LOOP(gdImagePalettePixel); } #undef REPLACING_LOOP return n; } static int colorCmp (const void *x, const void *y) { int a = *(int const *)x; int b = *(int const *)y; return (a > b) - (a < b); } BGD_DECLARE(int) gdImageColorReplaceArray (gdImagePtr im, int len, int *src, int *dst) { register int x, y; int c, *d, *base; int i, n = 0; if (len <= 0 || src == dst) { return 0; } if (len == 1) { return gdImageColorReplace(im, src[0], dst[0]); } if (overflow2(len, sizeof(int)<<1)) { return -1; } base = (int *)gdMalloc(len * (sizeof(int)<<1)); if (!base) { return -1; } for (i = 0; i < len; i++) { base[(i<<1)] = src[i]; base[(i<<1)+1] = dst[i]; } qsort(base, len, sizeof(int)<<1, colorCmp); #define REPLACING_LOOP(pixel) do { \ for (y = im->cy1; y <= im->cy2; y++) { \ for (x = im->cx1; x <= im->cx2; x++) { \ c = pixel(im, x, y); \ if ( (d = (int *)bsearch(&c, base, len, sizeof(int)<<1, colorCmp)) ) { \ gdImageSetPixel(im, x, y, d[1]); \ n++; \ } \ } \ } \ } while (0) if (im->trueColor) { REPLACING_LOOP(gdImageTrueColorPixel); } else { REPLACING_LOOP(gdImagePalettePixel); } #undef REPLACING_LOOP gdFree(base); return n; } BGD_DECLARE(int) gdImageColorReplaceCallback (gdImagePtr im, gdCallbackImageColor callback) { int c, d, n = 0; if (!callback) { return 0; } if (im->trueColor) { register int x, y; for (y = im->cy1; y <= im->cy2; y++) { for (x = im->cx1; x <= im->cx2; x++) { c = gdImageTrueColorPixel(im, x, y); if ( (d = callback(im, c)) != c) { gdImageSetPixel(im, x, y, d); n++; } } } } else { /* palette */ int *sarr, *darr; int k, len = 0; sarr = (int *)gdCalloc(im->colorsTotal, sizeof(int)); if (!sarr) { return -1; } for (c = 0; c < im->colorsTotal; c++) { if (!im->open[c]) { sarr[len++] = c; } } darr = (int *)gdCalloc(len, sizeof(int)); if (!darr) { gdFree(sarr); return -1; } for (k = 0; k < len; k++) { darr[k] = callback(im, sarr[k]); } n = gdImageColorReplaceArray(im, k, sarr, darr); gdFree(darr); gdFree(sarr); } return n; } /* 2.0.10: before the drawing routines, some code to clip points that are * outside the drawing window. Nick Atty (nick@canalplan.org.uk) * * This is the Sutherland Hodgman Algorithm, as implemented by * Duvanenko, Robbins and Gyurcsik - SH(DRG) for short. See Dr Dobb's * Journal, January 1996, pp107-110 and 116-117 * * Given the end points of a line, and a bounding rectangle (which we * know to be from (0,0) to (SX,SY)), adjust the endpoints to be on * the edges of the rectangle if the line should be drawn at all, * otherwise return a failure code */ /* this does "one-dimensional" clipping: note that the second time it is called, all the x parameters refer to height and the y to width - the comments ignore this (if you can understand it when it's looking at the X parameters, it should become clear what happens on the second call!) The code is simplified from that in the article, as we know that gd images always start at (0,0) */ /* 2.0.26, TBB: we now have to respect a clipping rectangle, it won't necessarily start at 0. */ static int clip_1d (int *x0, int *y0, int *x1, int *y1, int mindim, int maxdim) { double m; /* gradient of line */ if (*x0 < mindim) { /* start of line is left of window */ if (*x1 < mindim) /* as is the end, so the line never cuts the window */ return 0; m = (*y1 - *y0) / (double) (*x1 - *x0); /* calculate the slope of the line */ /* adjust x0 to be on the left boundary (ie to be zero), and y0 to match */ *y0 -= (int)(m * (*x0 - mindim)); *x0 = mindim; /* now, perhaps, adjust the far end of the line as well */ if (*x1 > maxdim) { *y1 += m * (maxdim - *x1); *x1 = maxdim; } return 1; } if (*x0 > maxdim) { /* start of line is right of window - complement of above */ if (*x1 > maxdim) /* as is the end, so the line misses the window */ return 0; m = (*y1 - *y0) / (double) (*x1 - *x0); /* calculate the slope of the line */ *y0 += (int)(m * (maxdim - *x0)); /* adjust so point is on the right boundary */ *x0 = maxdim; /* now, perhaps, adjust the end of the line */ if (*x1 < mindim) { *y1 -= (int)(m * (*x1 - mindim)); *x1 = mindim; } return 1; } /* the final case - the start of the line is inside the window */ if (*x1 > maxdim) { /* other end is outside to the right */ m = (*y1 - *y0) / (double) (*x1 - *x0); /* calculate the slope of the line */ *y1 += (int)(m * (maxdim - *x1)); *x1 = maxdim; return 1; } if (*x1 < mindim) { /* other end is outside to the left */ m = (*y1 - *y0) / (double) (*x1 - *x0); /* calculate the slope of the line */ *y1 -= (int)(m * (*x1 - mindim)); *x1 = mindim; return 1; } /* only get here if both points are inside the window */ return 1; } /* end of line clipping code */ BGD_DECLARE(void) gdImageSetPixel (gdImagePtr im, int x, int y, int color) { int p; switch (color) { case gdStyled: if (!im->style) { /* Refuse to draw if no style is set. */ return; } else { p = im->style[im->stylePos++]; } if (p != (gdTransparent)) { gdImageSetPixel (im, x, y, p); } im->stylePos = im->stylePos % im->styleLength; break; case gdStyledBrushed: if (!im->style) { /* Refuse to draw if no style is set. */ return; } p = im->style[im->stylePos++]; if ((p != gdTransparent) && (p != 0)) { gdImageSetPixel (im, x, y, gdBrushed); } im->stylePos = im->stylePos % im->styleLength; break; case gdBrushed: gdImageBrushApply (im, x, y); break; case gdTiled: gdImageTileApply (im, x, y); break; case gdAntiAliased: /* This shouldn't happen (2.0.26) because we just call gdImageAALine now, but do something sane. */ gdImageSetPixel(im, x, y, im->AA_color); break; default: if (gdImageBoundsSafeMacro (im, x, y)) { if (im->trueColor) { switch (im->alphaBlendingFlag) { default: case gdEffectReplace: im->tpixels[y][x] = color; break; case gdEffectAlphaBlend: case gdEffectNormal: im->tpixels[y][x] = gdAlphaBlend(im->tpixels[y][x], color); break; case gdEffectOverlay : im->tpixels[y][x] = gdLayerOverlay(im->tpixels[y][x], color); break; case gdEffectMultiply : im->tpixels[y][x] = gdLayerMultiply(im->tpixels[y][x], color); break; } } else { im->pixels[y][x] = color; } } break; } } static void gdImageBrushApply (gdImagePtr im, int x, int y) { int lx, ly; int hy; int hx; int x1, y1, x2, y2; int srcx, srcy; if (!im->brush) { return; } hy = gdImageSY (im->brush) / 2; y1 = y - hy; y2 = y1 + gdImageSY (im->brush); hx = gdImageSX (im->brush) / 2; x1 = x - hx; x2 = x1 + gdImageSX (im->brush); srcy = 0; if (im->trueColor) { if (im->brush->trueColor) { for (ly = y1; (ly < y2); ly++) { srcx = 0; for (lx = x1; (lx < x2); lx++) { int p; p = gdImageGetTrueColorPixel (im->brush, srcx, srcy); /* 2.0.9, Thomas Winzig: apply simple full transparency */ if (p != gdImageGetTransparent (im->brush)) { gdImageSetPixel (im, lx, ly, p); } srcx++; } srcy++; } } else { /* 2.0.12: Brush palette, image truecolor (thanks to Thorben Kundinger for pointing out the issue) */ for (ly = y1; (ly < y2); ly++) { srcx = 0; for (lx = x1; (lx < x2); lx++) { int p, tc; p = gdImageGetPixel (im->brush, srcx, srcy); tc = gdImageGetTrueColorPixel (im->brush, srcx, srcy); /* 2.0.9, Thomas Winzig: apply simple full transparency */ if (p != gdImageGetTransparent (im->brush)) { gdImageSetPixel (im, lx, ly, tc); } srcx++; } srcy++; } } } else { for (ly = y1; (ly < y2); ly++) { srcx = 0; for (lx = x1; (lx < x2); lx++) { int p; p = gdImageGetPixel (im->brush, srcx, srcy); /* Allow for non-square brushes! */ if (p != gdImageGetTransparent (im->brush)) { /* Truecolor brush. Very slow on a palette destination. */ if (im->brush->trueColor) { gdImageSetPixel (im, lx, ly, gdImageColorResolveAlpha (im, gdTrueColorGetRed (p), gdTrueColorGetGreen (p), gdTrueColorGetBlue (p), gdTrueColorGetAlpha (p))); } else { gdImageSetPixel (im, lx, ly, im->brushColorMap[p]); } } srcx++; } srcy++; } } } static void gdImageTileApply (gdImagePtr im, int x, int y) { gdImagePtr tile = im->tile; int srcx, srcy; int p; if (!tile) { return; } srcx = x % gdImageSX (tile); srcy = y % gdImageSY (tile); if (im->trueColor) { p = gdImageGetPixel (tile, srcx, srcy); if (p != gdImageGetTransparent (tile)) { if (!tile->trueColor) { p = gdTrueColorAlpha(tile->red[p], tile->green[p], tile->blue[p], tile->alpha[p]); } gdImageSetPixel (im, x, y, p); } } else { p = gdImageGetPixel (tile, srcx, srcy); /* Allow for transparency */ if (p != gdImageGetTransparent (tile)) { if (tile->trueColor) { /* Truecolor tile. Very slow on a palette destination. */ gdImageSetPixel (im, x, y, gdImageColorResolveAlpha (im, gdTrueColorGetRed (p), gdTrueColorGetGreen (p), gdTrueColorGetBlue (p), gdTrueColorGetAlpha (p))); } else { gdImageSetPixel (im, x, y, im->tileColorMap[p]); } } } } BGD_DECLARE(int) gdImageGetPixel (gdImagePtr im, int x, int y) { if (gdImageBoundsSafeMacro (im, x, y)) { if (im->trueColor) { return im->tpixels[y][x]; } else { return im->pixels[y][x]; } } else { return 0; } } BGD_DECLARE(int) gdImageGetTrueColorPixel (gdImagePtr im, int x, int y) { int p = gdImageGetPixel (im, x, y); if (!im->trueColor) { return gdTrueColorAlpha (im->red[p], im->green[p], im->blue[p], (im->transparent == p) ? gdAlphaTransparent : im->alpha[p]); } else { return p; } } BGD_DECLARE(void) gdImageAABlend (gdImagePtr im) { /* NO-OP, kept for library compatibility. */ (void)im; } static void gdImageAALine (gdImagePtr im, int x1, int y1, int x2, int y2, int col); static void gdImageHLine(gdImagePtr im, int y, int x1, int x2, int col) { if (im->thick > 1) { int thickhalf = im->thick >> 1; gdImageFilledRectangle(im, x1, y - thickhalf, x2, y + im->thick - thickhalf - 1, col); } else { if (x2 < x1) { int t = x2; x2 = x1; x1 = t; } for (; x1 <= x2; x1++) { gdImageSetPixel(im, x1, y, col); } } return; } static void gdImageVLine(gdImagePtr im, int x, int y1, int y2, int col) { if (im->thick > 1) { int thickhalf = im->thick >> 1; gdImageFilledRectangle(im, x - thickhalf, y1, x + im->thick - thickhalf - 1, y2, col); } else { if (y2 < y1) { int t = y1; y1 = y2; y2 = t; } for (; y1 <= y2; y1++) { gdImageSetPixel(im, x, y1, col); } } return; } /* Bresenham as presented in Foley & Van Dam */ BGD_DECLARE(void) gdImageLine (gdImagePtr im, int x1, int y1, int x2, int y2, int color) { int dx, dy, incr1, incr2, d, x, y, xend, yend, xdirflag, ydirflag; int wid; int w, wstart; int thick; if (color == gdAntiAliased) { /* gdAntiAliased passed as color: use the much faster, much cheaper and equally attractive gdImageAALine implementation. That clips too, so don't clip twice. */ gdImageAALine(im, x1, y1, x2, y2, im->AA_color); return; } /* 2.0.10: Nick Atty: clip to edges of drawing rectangle, return if no points need to be drawn. 2.0.26, TBB: clip to edges of clipping rectangle. We were getting away with this because gdImageSetPixel is used for actual drawing, but this is still more efficient and opens the way to skip per-pixel bounds checking in the future. */ if (clip_1d (&x1, &y1, &x2, &y2, im->cx1, im->cx2) == 0) return; if (clip_1d (&y1, &x1, &y2, &x2, im->cy1, im->cy2) == 0) return; thick = im->thick; dx = abs (x2 - x1); dy = abs (y2 - y1); if (dx == 0) { gdImageVLine(im, x1, y1, y2, color); return; } else if (dy == 0) { gdImageHLine(im, y1, x1, x2, color); return; } if (dy <= dx) { /* More-or-less horizontal. use wid for vertical stroke */ /* Doug Claar: watch out for NaN in atan2 (2.0.5) */ if ((dx == 0) && (dy == 0)) { wid = 1; } else { /* 2.0.12: Michael Schwartz: divide rather than multiply; TBB: but watch out for /0! */ double ac = cos (atan2 (dy, dx)); if (ac != 0) { wid = thick / ac; } else { wid = 1; } if (wid == 0) { wid = 1; } } d = 2 * dy - dx; incr1 = 2 * dy; incr2 = 2 * (dy - dx); if (x1 > x2) { x = x2; y = y2; ydirflag = (-1); xend = x1; } else { x = x1; y = y1; ydirflag = 1; xend = x2; } /* Set up line thickness */ wstart = y - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, x, w, color); if (((y2 - y1) * ydirflag) > 0) { while (x < xend) { x++; if (d < 0) { d += incr1; } else { y++; d += incr2; } wstart = y - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, x, w, color); } } else { while (x < xend) { x++; if (d < 0) { d += incr1; } else { y--; d += incr2; } wstart = y - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, x, w, color); } } } else { /* More-or-less vertical. use wid for horizontal stroke */ /* 2.0.12: Michael Schwartz: divide rather than multiply; TBB: but watch out for /0! */ double as = sin (atan2 (dy, dx)); if (as != 0) { wid = thick / as; } else { wid = 1; } if (wid == 0) wid = 1; d = 2 * dx - dy; incr1 = 2 * dx; incr2 = 2 * (dx - dy); if (y1 > y2) { y = y2; x = x2; yend = y1; xdirflag = (-1); } else { y = y1; x = x1; yend = y2; xdirflag = 1; } /* Set up line thickness */ wstart = x - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, w, y, color); if (((x2 - x1) * xdirflag) > 0) { while (y < yend) { y++; if (d < 0) { d += incr1; } else { x++; d += incr2; } wstart = x - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, w, y, color); } } else { while (y < yend) { y++; if (d < 0) { d += incr1; } else { x--; d += incr2; } wstart = x - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, w, y, color); } } } } static void dashedSet (gdImagePtr im, int x, int y, int color, int *onP, int *dashStepP, int wid, int vert); BGD_DECLARE(void) gdImageDashedLine (gdImagePtr im, int x1, int y1, int x2, int y2, int color) { int dx, dy, incr1, incr2, d, x, y, xend, yend, xdirflag, ydirflag; int dashStep = 0; int on = 1; int wid; int vert; int thick = im->thick; dx = abs (x2 - x1); dy = abs (y2 - y1); if (dy <= dx) { /* More-or-less horizontal. use wid for vertical stroke */ /* 2.0.12: Michael Schwartz: divide rather than multiply; TBB: but watch out for /0! */ double as = sin (atan2 (dy, dx)); if (as != 0) { wid = thick / as; } else { wid = 1; } vert = 1; d = 2 * dy - dx; incr1 = 2 * dy; incr2 = 2 * (dy - dx); if (x1 > x2) { x = x2; y = y2; ydirflag = (-1); xend = x1; } else { x = x1; y = y1; ydirflag = 1; xend = x2; } dashedSet (im, x, y, color, &on, &dashStep, wid, vert); if (((y2 - y1) * ydirflag) > 0) { while (x < xend) { x++; if (d < 0) { d += incr1; } else { y++; d += incr2; } dashedSet (im, x, y, color, &on, &dashStep, wid, vert); } } else { while (x < xend) { x++; if (d < 0) { d += incr1; } else { y--; d += incr2; } dashedSet (im, x, y, color, &on, &dashStep, wid, vert); } } } else { /* 2.0.12: Michael Schwartz: divide rather than multiply; TBB: but watch out for /0! */ double as = sin (atan2 (dy, dx)); if (as != 0) { wid = thick / as; } else { wid = 1; } vert = 0; d = 2 * dx - dy; incr1 = 2 * dx; incr2 = 2 * (dx - dy); if (y1 > y2) { y = y2; x = x2; yend = y1; xdirflag = (-1); } else { y = y1; x = x1; yend = y2; xdirflag = 1; } dashedSet (im, x, y, color, &on, &dashStep, wid, vert); if (((x2 - x1) * xdirflag) > 0) { while (y < yend) { y++; if (d < 0) { d += incr1; } else { x++; d += incr2; } dashedSet (im, x, y, color, &on, &dashStep, wid, vert); } } else { while (y < yend) { y++; if (d < 0) { d += incr1; } else { x--; d += incr2; } dashedSet (im, x, y, color, &on, &dashStep, wid, vert); } } } } static void dashedSet (gdImagePtr im, int x, int y, int color, int *onP, int *dashStepP, int wid, int vert) { int dashStep = *dashStepP; int on = *onP; int w, wstart; dashStep++; if (dashStep == gdDashSize) { dashStep = 0; on = !on; } if (on) { if (vert) { wstart = y - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, x, w, color); } else { wstart = x - wid / 2; for (w = wstart; w < wstart + wid; w++) gdImageSetPixel (im, w, y, color); } } *dashStepP = dashStep; *onP = on; } BGD_DECLARE(int) gdImageBoundsSafe (gdImagePtr im, int x, int y) { return gdImageBoundsSafeMacro (im, x, y); } BGD_DECLARE(void) gdImageChar (gdImagePtr im, gdFontPtr f, int x, int y, int c, int color) { int cx, cy; int px, py; int fline; cx = 0; cy = 0; #ifdef CHARSET_EBCDIC c = ASC (c); #endif /*CHARSET_EBCDIC */ if ((c < f->offset) || (c >= (f->offset + f->nchars))) { return; } fline = (c - f->offset) * f->h * f->w; for (py = y; (py < (y + f->h)); py++) { for (px = x; (px < (x + f->w)); px++) { if (f->data[fline + cy * f->w + cx]) { gdImageSetPixel (im, px, py, color); } cx++; } cx = 0; cy++; } } BGD_DECLARE(void) gdImageCharUp (gdImagePtr im, gdFontPtr f, int x, int y, int c, int color) { int cx, cy; int px, py; int fline; cx = 0; cy = 0; #ifdef CHARSET_EBCDIC c = ASC (c); #endif /*CHARSET_EBCDIC */ if ((c < f->offset) || (c >= (f->offset + f->nchars))) { return; } fline = (c - f->offset) * f->h * f->w; for (py = y; (py > (y - f->w)); py--) { for (px = x; (px < (x + f->h)); px++) { if (f->data[fline + cy * f->w + cx]) { gdImageSetPixel (im, px, py, color); } cy++; } cy = 0; cx++; } } BGD_DECLARE(void) gdImageString (gdImagePtr im, gdFontPtr f, int x, int y, unsigned char *s, int color) { int i; int l; l = strlen ((char *) s); for (i = 0; (i < l); i++) { gdImageChar (im, f, x, y, s[i], color); x += f->w; } } BGD_DECLARE(void) gdImageStringUp (gdImagePtr im, gdFontPtr f, int x, int y, unsigned char *s, int color) { int i; int l; l = strlen ((char *) s); for (i = 0; (i < l); i++) { gdImageCharUp (im, f, x, y, s[i], color); y -= f->w; } } static int strlen16 (unsigned short *s); BGD_DECLARE(void) gdImageString16 (gdImagePtr im, gdFontPtr f, int x, int y, unsigned short *s, int color) { int i; int l; l = strlen16 (s); for (i = 0; (i < l); i++) { gdImageChar (im, f, x, y, s[i], color); x += f->w; } } BGD_DECLARE(void) gdImageStringUp16 (gdImagePtr im, gdFontPtr f, int x, int y, unsigned short *s, int color) { int i; int l; l = strlen16 (s); for (i = 0; (i < l); i++) { gdImageCharUp (im, f, x, y, s[i], color); y -= f->w; } } static int strlen16 (unsigned short *s) { int len = 0; while (*s) { s++; len++; } return len; } #ifndef HAVE_LSQRT /* If you don't have a nice square root function for longs, you can use ** this hack */ long lsqrt (long n) { long result = (long) sqrt ((double) n); return result; } #endif /* s and e are integers modulo 360 (degrees), with 0 degrees being the rightmost extreme and degrees changing clockwise. cx and cy are the center in pixels; w and h are the horizontal and vertical diameter in pixels. Nice interface, but slow. See gd_arc_f_buggy.c for a better version that doesn't seem to be bug-free yet. */ BGD_DECLARE(void) gdImageArc (gdImagePtr im, int cx, int cy, int w, int h, int s, int e, int color) { gdImageFilledArc (im, cx, cy, w, h, s, e, color, gdNoFill); } BGD_DECLARE(void) gdImageFilledArc (gdImagePtr im, int cx, int cy, int w, int h, int s, int e, int color, int style) { gdPoint pts[3]; int i; int lx = 0, ly = 0; int fx = 0, fy = 0; if ((s % 360) == (e % 360)) { s = 0; e = 360; } else { if (s > 360) { s = s % 360; } if (e > 360) { e = e % 360; } while (s < 0) { s += 360; } while (e < s) { e += 360; } if (s == e) { s = 0; e = 360; } } for (i = s; (i <= e); i++) { int x, y; x = ((long) gdCosT[i % 360] * (long) w / (2 * 1024)) + cx; y = ((long) gdSinT[i % 360] * (long) h / (2 * 1024)) + cy; if (i != s) { if (!(style & gdChord)) { if (style & gdNoFill) { gdImageLine (im, lx, ly, x, y, color); } else { /* This is expensive! */ pts[0].x = lx; pts[0].y = ly; pts[1].x = x; pts[1].y = y; pts[2].x = cx; pts[2].y = cy; gdImageFilledPolygon (im, pts, 3, color); } } } else { fx = x; fy = y; } lx = x; ly = y; } if (style & gdChord) { if (style & gdNoFill) { if (style & gdEdged) { gdImageLine (im, cx, cy, lx, ly, color); gdImageLine (im, cx, cy, fx, fy, color); } gdImageLine (im, fx, fy, lx, ly, color); } else { pts[0].x = fx; pts[0].y = fy; pts[1].x = lx; pts[1].y = ly; pts[2].x = cx; pts[2].y = cy; gdImageFilledPolygon (im, pts, 3, color); } } else { if (style & gdNoFill) { if (style & gdEdged) { gdImageLine (im, cx, cy, lx, ly, color); gdImageLine (im, cx, cy, fx, fy, color); } } } } BGD_DECLARE(void) gdImageEllipse(gdImagePtr im, int mx, int my, int w, int h, int c) { int x=0,mx1=0,mx2=0,my1=0,my2=0; long aq,bq,dx,dy,r,rx,ry,a,b; a=w>>1; b=h>>1; gdImageSetPixel(im,mx+a, my, c); gdImageSetPixel(im,mx-a, my, c); mx1 = mx-a; my1 = my; mx2 = mx+a; my2 = my; aq = a * a; bq = b * b; dx = aq << 1; dy = bq << 1; r = a * bq; rx = r << 1; ry = 0; x = a; while (x > 0) { if (r > 0) { my1++; my2--; ry +=dx; r -=ry; } if (r <= 0) { x--; mx1++; mx2--; rx -=dy; r +=rx; } gdImageSetPixel(im,mx1, my1, c); gdImageSetPixel(im,mx1, my2, c); gdImageSetPixel(im,mx2, my1, c); gdImageSetPixel(im,mx2, my2, c); } } BGD_DECLARE(void) gdImageFilledEllipse (gdImagePtr im, int mx, int my, int w, int h, int c) { int x=0,mx1=0,mx2=0,my1=0,my2=0; long aq,bq,dx,dy,r,rx,ry,a,b; int i; int old_y2; a=w>>1; b=h>>1; for (x = mx-a; x <= mx+a; x++) { gdImageSetPixel(im, x, my, c); } mx1 = mx-a; my1 = my; mx2 = mx+a; my2 = my; aq = a * a; bq = b * b; dx = aq << 1; dy = bq << 1; r = a * bq; rx = r << 1; ry = 0; x = a; old_y2=-2; while (x > 0) { if (r > 0) { my1++; my2--; ry +=dx; r -=ry; } if (r <= 0) { x--; mx1++; mx2--; rx -=dy; r +=rx; } if(old_y2!=my2) { for(i=mx1; i<=mx2; i++) { gdImageSetPixel(im,i,my1,c); } } if(old_y2!=my2) { for(i=mx1; i<=mx2; i++) { gdImageSetPixel(im,i,my2,c); } } old_y2 = my2; } } BGD_DECLARE(void) gdImageFillToBorder (gdImagePtr im, int x, int y, int border, int color) { int lastBorder; /* Seek left */ int leftLimit, rightLimit; int i; int restoreAlphaBleding; if (border < 0) { /* Refuse to fill to a non-solid border */ return; } leftLimit = (-1); restoreAlphaBleding = im->alphaBlendingFlag; im->alphaBlendingFlag = 0; for (i = x; (i >= 0); i--) { if (gdImageGetPixel (im, i, y) == border) { break; } gdImageSetPixel (im, i, y, color); leftLimit = i; } if (leftLimit == (-1)) { im->alphaBlendingFlag = restoreAlphaBleding; return; } /* Seek right */ rightLimit = x; for (i = (x + 1); (i < im->sx); i++) { if (gdImageGetPixel (im, i, y) == border) { break; } gdImageSetPixel (im, i, y, color); rightLimit = i; } /* Look at lines above and below and start paints */ /* Above */ if (y > 0) { lastBorder = 1; for (i = leftLimit; (i <= rightLimit); i++) { int c; c = gdImageGetPixel (im, i, y - 1); if (lastBorder) { if ((c != border) && (c != color)) { gdImageFillToBorder (im, i, y - 1, border, color); lastBorder = 0; } } else if ((c == border) || (c == color)) { lastBorder = 1; } } } /* Below */ if (y < ((im->sy) - 1)) { lastBorder = 1; for (i = leftLimit; (i <= rightLimit); i++) { int c = gdImageGetPixel (im, i, y + 1); if (lastBorder) { if ((c != border) && (c != color)) { gdImageFillToBorder (im, i, y + 1, border, color); lastBorder = 0; } } else if ((c == border) || (c == color)) { lastBorder = 1; } } } im->alphaBlendingFlag = restoreAlphaBleding; } /* * set the pixel at (x,y) and its 4-connected neighbors * with the same pixel value to the new pixel value nc (new color). * A 4-connected neighbor: pixel above, below, left, or right of a pixel. * ideas from comp.graphics discussions. * For tiled fill, the use of a flag buffer is mandatory. As the tile image can * contain the same color as the color to fill. To do not bloat normal filling * code I added a 2nd private function. */ static int gdImageTileGet (gdImagePtr im, int x, int y) { int srcx, srcy; int tileColor,p; if (!im->tile) { return -1; } srcx = x % gdImageSX(im->tile); srcy = y % gdImageSY(im->tile); p = gdImageGetPixel(im->tile, srcx, srcy); if (p == im->tile->transparent) { tileColor = im->transparent; } else if (im->trueColor) { if (im->tile->trueColor) { tileColor = p; } else { tileColor = gdTrueColorAlpha( gdImageRed(im->tile,p), gdImageGreen(im->tile,p), gdImageBlue (im->tile,p), gdImageAlpha (im->tile,p)); } } else { if (im->tile->trueColor) { tileColor = gdImageColorResolveAlpha(im, gdTrueColorGetRed (p), gdTrueColorGetGreen (p), gdTrueColorGetBlue (p), gdTrueColorGetAlpha (p)); } else { tileColor = gdImageColorResolveAlpha(im, gdImageRed (im->tile,p), gdImageGreen (im->tile,p), gdImageBlue (im->tile,p), gdImageAlpha (im->tile,p)); } } return tileColor; } /* horizontal segment of scan line y */ struct seg { int y, xl, xr, dy; }; /* max depth of stack */ #define FILL_MAX ((int)(im->sy*im->sx)/4) #define FILL_PUSH(Y, XL, XR, DY) \ if (sp=0 && Y+(DY)y = Y; sp->xl = XL; sp->xr = XR; sp->dy = DY; sp++;} #define FILL_POP(Y, XL, XR, DY) \ {sp--; Y = sp->y+(DY = sp->dy); XL = sp->xl; XR = sp->xr;} static void _gdImageFillTiled(gdImagePtr im, int x, int y, int nc); BGD_DECLARE(void) gdImageFill(gdImagePtr im, int x, int y, int nc) { int l, x1, x2, dy; int oc; /* old pixel value */ int wx2,wy2; int alphablending_bak; /* stack of filled segments */ /* struct seg stack[FILL_MAX],*sp = stack;; */ struct seg *stack; struct seg *sp; if (!im->trueColor && nc > (im->colorsTotal - 1)) { return; } alphablending_bak = im->alphaBlendingFlag; im->alphaBlendingFlag = 0; if (nc==gdTiled) { _gdImageFillTiled(im,x,y,nc); im->alphaBlendingFlag = alphablending_bak; return; } wx2=im->sx; wy2=im->sy; oc = gdImageGetPixel(im, x, y); if (oc==nc || x<0 || x>wx2 || y<0 || y>wy2) { im->alphaBlendingFlag = alphablending_bak; return; } /* Do not use the 4 neighbors implementation with * small images */ if (im->sx < 4) { int ix = x, iy = y, c; do { do { c = gdImageGetPixel(im, ix, iy); if (c != oc) { goto done; } gdImageSetPixel(im, ix, iy, nc); } while(ix++ < (im->sx -1)); ix = x; } while(iy++ < (im->sy -1)); goto done; } if(overflow2(im->sy, im->sx)) { return; } if(overflow2(sizeof(struct seg), ((im->sy * im->sx) / 4))) { return; } stack = (struct seg *)gdMalloc(sizeof(struct seg) * ((int)(im->sy*im->sx)/4)); if (!stack) { return; } sp = stack; /* required! */ FILL_PUSH(y,x,x,1); /* seed segment (popped 1st) */ FILL_PUSH(y+1, x, x, -1); while (sp>stack) { FILL_POP(y, x1, x2, dy); for (x=x1; x>=0 && gdImageGetPixel(im,x, y)==oc; x--) { gdImageSetPixel(im,x, y, nc); } if (x>=x1) { goto skip; } l = x+1; /* leak on left? */ if (lx2+1) { FILL_PUSH(y, x2+1, x-1, -dy); } skip: for (x++; x<=x2 && (gdImageGetPixel(im, x, y)!=oc); x++); l = x; } while (x<=x2); } gdFree(stack); done: im->alphaBlendingFlag = alphablending_bak; } static void _gdImageFillTiled(gdImagePtr im, int x, int y, int nc) { int l, x1, x2, dy; int oc; /* old pixel value */ int wx2,wy2; /* stack of filled segments */ struct seg *stack; struct seg *sp; char *pts; if (!im->tile) { return; } wx2=im->sx; wy2=im->sy; if(overflow2(im->sy, im->sx)) { return; } if(overflow2(sizeof(struct seg), ((im->sy * im->sx) / 4))) { return; } pts = (char *) gdCalloc(im->sy * im->sx, sizeof(char)); if (!pts) { return; } stack = (struct seg *)gdMalloc(sizeof(struct seg) * ((int)(im->sy*im->sx)/4)); if (!stack) { gdFree(pts); return; } sp = stack; oc = gdImageGetPixel(im, x, y); /* required! */ FILL_PUSH(y,x,x,1); /* seed segment (popped 1st) */ FILL_PUSH(y+1, x, x, -1); while (sp>stack) { FILL_POP(y, x1, x2, dy); for (x=x1; x>=0 && (!pts[y + x*wx2] && gdImageGetPixel(im,x,y)==oc); x--) { nc = gdImageTileGet(im,x,y); pts[y + x*wx2]=1; gdImageSetPixel(im,x, y, nc); } if (x>=x1) { goto skip; } l = x+1; /* leak on left? */ if (lx2+1) { FILL_PUSH(y, x2+1, x-1, -dy); } skip: for (x++; x<=x2 && (pts[y + x*wx2] || gdImageGetPixel(im,x, y)!=oc); x++); l = x; } while (x<=x2); } gdFree(pts); gdFree(stack); } BGD_DECLARE(void) gdImageRectangle (gdImagePtr im, int x1, int y1, int x2, int y2, int color) { int thick = im->thick; if (x1 == x2 && y1 == y2 && thick == 1) { gdImageSetPixel(im, x1, y1, color); return; } if (y2 < y1) { int t; t = y1; y1 = y2; y2 = t; t = x1; x1 = x2; x2 = t; } if (thick > 1) { int cx, cy, x1ul, y1ul, x2lr, y2lr; int half = thick >> 1; x1ul = x1 - half; y1ul = y1 - half; x2lr = x2 + half; y2lr = y2 + half; cy = y1ul + thick; while (cy-- > y1ul) { cx = x1ul - 1; while (cx++ < x2lr) { gdImageSetPixel(im, cx, cy, color); } } cy = y2lr - thick; while (cy++ < y2lr) { cx = x1ul - 1; while (cx++ < x2lr) { gdImageSetPixel(im, cx, cy, color); } } cy = y1ul + thick - 1; while (cy++ < y2lr -thick) { cx = x1ul - 1; while (cx++ < x1ul + thick) { gdImageSetPixel(im, cx, cy, color); } } cy = y1ul + thick - 1; while (cy++ < y2lr -thick) { cx = x2lr - thick - 1; while (cx++ < x2lr) { gdImageSetPixel(im, cx, cy, color); } } return; } else { gdImageLine(im, x1, y1, x2, y1, color); gdImageLine(im, x1, y2, x2, y2, color); gdImageLine(im, x1, y1 + 1, x1, y2 - 1, color); gdImageLine(im, x2, y1 + 1, x2, y2 - 1, color); } } BGD_DECLARE(void) gdImageFilledRectangle (gdImagePtr im, int x1, int y1, int x2, int y2, int color) { int x, y; if (x1 == x2 && y1 == y2) { gdImageSetPixel(im, x1, y1, color); return; } if (x1 > x2) { x = x1; x1 = x2; x2 = x; } if (y1 > y2) { y = y1; y1 = y2; y2 = y; } if (x1 < 0) { x1 = 0; } if (x2 >= gdImageSX(im)) { x2 = gdImageSX(im) - 1; } if (y1 < 0) { y1 = 0; } if (y2 >= gdImageSY(im)) { y2 = gdImageSY(im) - 1; } for (y = y1; (y <= y2); y++) { for (x = x1; (x <= x2); x++) { gdImageSetPixel (im, x, y, color); } } } BGD_DECLARE(gdImagePtr) gdImageClone (gdImagePtr src) { gdImagePtr dst; register int i, x; if (src->trueColor) { dst = gdImageCreateTrueColor(src->sx , src->sy); } else { dst = gdImageCreate(src->sx , src->sy); } if (dst == NULL) { return NULL; } if (src->trueColor == 0) { dst->colorsTotal = src->colorsTotal; for (i = 0; i < gdMaxColors; i++) { dst->red[i] = src->red[i]; dst->green[i] = src->green[i]; dst->blue[i] = src->blue[i]; dst->alpha[i] = src->alpha[i]; dst->open[i] = src->open[i]; } for (i = 0; i < src->sy; i++) { for (x = 0; x < src->sx; x++) { dst->pixels[i][x] = dst->pixels[i][x]; } } } else { for (i = 0; i < src->sy; i++) { for (x = 0; x < src->sx; x++) { dst->tpixels[i][x] = src->tpixels[i][x]; } } } if (src->styleLength > 0) { dst->styleLength = src->styleLength; dst->stylePos = src->stylePos; for (i = 0; i < src->styleLength; i++) { dst->style[i] = src->style[i]; } } dst->interlace = src->interlace; dst->alphaBlendingFlag = src->alphaBlendingFlag; dst->saveAlphaFlag = src->saveAlphaFlag; dst->AA = src->AA; dst->AA_color = src->AA_color; dst->AA_dont_blend = src->AA_dont_blend; dst->cx1 = src->cx1; dst->cy1 = src->cy1; dst->cx2 = src->cx2; dst->cy2 = src->cy2; dst->res_x = src->res_x; dst->res_y = src->res_x; dst->paletteQuantizationMethod = src->paletteQuantizationMethod; dst->paletteQuantizationSpeed = src->paletteQuantizationSpeed; dst->paletteQuantizationMinQuality = src->paletteQuantizationMinQuality; dst->paletteQuantizationMinQuality = src->paletteQuantizationMinQuality; dst->interpolation_id = src->interpolation_id; dst->interpolation = src->interpolation; if (src->brush) { dst->brush = gdImageClone(src->brush); } if (src->tile) { dst->tile = gdImageClone(src->tile); } if (src->style) { gdImageSetStyle(dst, src->style, src->styleLength); } for (i = 0; i < gdMaxColors; i++) { dst->brushColorMap[i] = src->brushColorMap[i]; dst->tileColorMap[i] = src->tileColorMap[i]; } if (src->polyAllocated > 0) { dst->polyAllocated = src->polyAllocated; for (i = 0; i < src->polyAllocated; i++) { dst->polyInts[i] = src->polyInts[i]; } } return dst; } BGD_DECLARE(void) gdImageCopy (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h) { int c; int x, y; int tox, toy; int i; int colorMap[gdMaxColors]; if (dst->trueColor) { /* 2.0: much easier when the destination is truecolor. */ /* 2.0.10: needs a transparent-index check that is still valid if * * the source is not truecolor. Thanks to Frank Warmerdam. */ if (src->trueColor) { for (y = 0; (y < h); y++) { for (x = 0; (x < w); x++) { int c = gdImageGetTrueColorPixel (src, srcX + x, srcY + y); if (c != src->transparent) { gdImageSetPixel (dst, dstX + x, dstY + y, c); } } } } else { /* source is palette based */ for (y = 0; (y < h); y++) { for (x = 0; (x < w); x++) { int c = gdImageGetPixel (src, srcX + x, srcY + y); if (c != src->transparent) { gdImageSetPixel(dst, dstX + x, dstY + y, gdTrueColorAlpha(src->red[c], src->green[c], src->blue[c], src->alpha[c])); } } } } return; } for (i = 0; (i < gdMaxColors); i++) { colorMap[i] = (-1); } toy = dstY; for (y = srcY; (y < (srcY + h)); y++) { tox = dstX; for (x = srcX; (x < (srcX + w)); x++) { int nc; int mapTo; c = gdImageGetPixel (src, x, y); /* Added 7/24/95: support transparent copies */ if (gdImageGetTransparent (src) == c) { tox++; continue; } /* Have we established a mapping for this color? */ if (src->trueColor) { /* 2.05: remap to the palette available in the destination image. This is slow and works badly, but it beats crashing! Thanks to Padhrig McCarthy. */ mapTo = gdImageColorResolveAlpha (dst, gdTrueColorGetRed (c), gdTrueColorGetGreen (c), gdTrueColorGetBlue (c), gdTrueColorGetAlpha (c)); } else if (colorMap[c] == (-1)) { /* If it's the same image, mapping is trivial */ if (dst == src) { nc = c; } else { /* Get best match possible. This function never returns error. */ nc = gdImageColorResolveAlpha (dst, src->red[c], src->green[c], src->blue[c], src->alpha[c]); } colorMap[c] = nc; mapTo = colorMap[c]; } else { mapTo = colorMap[c]; } gdImageSetPixel (dst, tox, toy, mapTo); tox++; } toy++; } } /* This function is a substitute for real alpha channel operations, so it doesn't pay attention to the alpha channel. */ BGD_DECLARE(void) gdImageCopyMerge (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct) { int c, dc; int x, y; int tox, toy; int ncR, ncG, ncB; toy = dstY; for (y = srcY; (y < (srcY + h)); y++) { tox = dstX; for (x = srcX; (x < (srcX + w)); x++) { int nc; c = gdImageGetPixel (src, x, y); /* Added 7/24/95: support transparent copies */ if (gdImageGetTransparent (src) == c) { tox++; continue; } /* If it's the same image, mapping is trivial */ if (dst == src) { nc = c; } else { dc = gdImageGetPixel (dst, tox, toy); ncR = gdImageRed (src, c) * (pct / 100.0) + gdImageRed (dst, dc) * ((100 - pct) / 100.0); ncG = gdImageGreen (src, c) * (pct / 100.0) + gdImageGreen (dst, dc) * ((100 - pct) / 100.0); ncB = gdImageBlue (src, c) * (pct / 100.0) + gdImageBlue (dst, dc) * ((100 - pct) / 100.0); /* Find a reasonable color */ nc = gdImageColorResolve (dst, ncR, ncG, ncB); } gdImageSetPixel (dst, tox, toy, nc); tox++; } toy++; } } /* This function is a substitute for real alpha channel operations, so it doesn't pay attention to the alpha channel. */ BGD_DECLARE(void) gdImageCopyMergeGray (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct) { int c, dc; int x, y; int tox, toy; int ncR, ncG, ncB; float g; toy = dstY; for (y = srcY; (y < (srcY + h)); y++) { tox = dstX; for (x = srcX; (x < (srcX + w)); x++) { int nc; c = gdImageGetPixel (src, x, y); /* Added 7/24/95: support transparent copies */ if (gdImageGetTransparent (src) == c) { tox++; continue; } /* * If it's the same image, mapping is NOT trivial since we * merge with greyscale target, but if pct is 100, the grey * value is not used, so it becomes trivial. pjw 2.0.12. */ if (dst == src && pct == 100) { nc = c; } else { dc = gdImageGetPixel (dst, tox, toy); g = 0.29900 * gdImageRed(dst, dc) + 0.58700 * gdImageGreen(dst, dc) + 0.11400 * gdImageBlue(dst, dc); ncR = gdImageRed (src, c) * (pct / 100.0) + g * ((100 - pct) / 100.0); ncG = gdImageGreen (src, c) * (pct / 100.0) + g * ((100 - pct) / 100.0); ncB = gdImageBlue (src, c) * (pct / 100.0) + g * ((100 - pct) / 100.0); /* First look for an exact match */ nc = gdImageColorExact (dst, ncR, ncG, ncB); if (nc == (-1)) { /* No, so try to allocate it */ nc = gdImageColorAllocate (dst, ncR, ncG, ncB); /* If we're out of colors, go for the closest color */ if (nc == (-1)) { nc = gdImageColorClosest (dst, ncR, ncG, ncB); } } } gdImageSetPixel (dst, tox, toy, nc); tox++; } toy++; } } BGD_DECLARE(void) gdImageCopyResized (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH) { int c; int x, y; int tox, toy; int ydest; int i; int colorMap[gdMaxColors]; /* Stretch vectors */ int *stx; int *sty; /* We only need to use floating point to determine the correct stretch vector for one line's worth. */ if (overflow2(sizeof (int), srcW)) { return; } if (overflow2(sizeof (int), srcH)) { return; } stx = (int *) gdMalloc (sizeof (int) * srcW); if (!stx) { return; } sty = (int *) gdMalloc (sizeof (int) * srcH); if (!sty) { gdFree(stx); return; } /* Fixed by Mao Morimoto 2.0.16 */ for (i = 0; (i < srcW); i++) { stx[i] = dstW * (i + 1) / srcW - dstW * i / srcW; } for (i = 0; (i < srcH); i++) { sty[i] = dstH * (i + 1) / srcH - dstH * i / srcH; } for (i = 0; (i < gdMaxColors); i++) { colorMap[i] = (-1); } toy = dstY; for (y = srcY; (y < (srcY + srcH)); y++) { for (ydest = 0; (ydest < sty[y - srcY]); ydest++) { tox = dstX; for (x = srcX; (x < (srcX + srcW)); x++) { int nc = 0; int mapTo; if (!stx[x - srcX]) { continue; } if (dst->trueColor) { /* 2.0.9: Thorben Kundinger: Maybe the source image is not a truecolor image */ if (!src->trueColor) { int tmp = gdImageGetPixel (src, x, y); mapTo = gdImageGetTrueColorPixel (src, x, y); if (gdImageGetTransparent (src) == tmp) { /* 2.0.21, TK: not tox++ */ tox += stx[x - srcX]; continue; } } else { /* TK: old code follows */ mapTo = gdImageGetTrueColorPixel (src, x, y); /* Added 7/24/95: support transparent copies */ if (gdImageGetTransparent (src) == mapTo) { /* 2.0.21, TK: not tox++ */ tox += stx[x - srcX]; continue; } } } else { c = gdImageGetPixel (src, x, y); /* Added 7/24/95: support transparent copies */ if (gdImageGetTransparent (src) == c) { tox += stx[x - srcX]; continue; } if (src->trueColor) { /* Remap to the palette available in the destination image. This is slow and works badly. */ mapTo = gdImageColorResolveAlpha (dst, gdTrueColorGetRed (c), gdTrueColorGetGreen (c), gdTrueColorGetBlue (c), gdTrueColorGetAlpha (c)); } else { /* Have we established a mapping for this color? */ if (colorMap[c] == (-1)) { /* If it's the same image, mapping is trivial */ if (dst == src) { nc = c; } else { /* Find or create the best match */ /* 2.0.5: can't use gdTrueColorGetRed, etc with palette */ nc = gdImageColorResolveAlpha (dst, gdImageRed (src, c), gdImageGreen (src, c), gdImageBlue (src, c), gdImageAlpha (src, c)); } colorMap[c] = nc; } mapTo = colorMap[c]; } } for (i = 0; (i < stx[x - srcX]); i++) { gdImageSetPixel (dst, tox, toy, mapTo); tox++; } } toy++; } } gdFree (stx); gdFree (sty); } /* gd 2.0.8: gdImageCopyRotated is added. Source is a rectangle, with its upper left corner at srcX and srcY. Destination is the *center* of the rotated copy. Angle is in degrees, same as gdImageArc. Floating point destination center coordinates allow accurate rotation of objects of odd-numbered width or height. */ BGD_DECLARE(void) gdImageCopyRotated (gdImagePtr dst, gdImagePtr src, double dstX, double dstY, int srcX, int srcY, int srcWidth, int srcHeight, int angle) { double dx, dy; double radius = sqrt (srcWidth * srcWidth + srcHeight * srcHeight); double aCos = cos (angle * .0174532925); double aSin = sin (angle * .0174532925); double scX = srcX + ((double) srcWidth) / 2; double scY = srcY + ((double) srcHeight) / 2; int cmap[gdMaxColors]; int i; /* 2.0.34: transparency preservation. The transparentness of the transparent color is more important than its hue. */ if (src->transparent != -1) { if (dst->transparent == -1) { dst->transparent = src->transparent; } } for (i = 0; (i < gdMaxColors); i++) { cmap[i] = (-1); } for (dy = dstY - radius; (dy <= dstY + radius); dy++) { for (dx = dstX - radius; (dx <= dstX + radius); dx++) { double sxd = (dx - dstX) * aCos - (dy - dstY) * aSin; double syd = (dy - dstY) * aCos + (dx - dstX) * aSin; int sx = sxd + scX; int sy = syd + scY; if ((sx >= srcX) && (sx < srcX + srcWidth) && (sy >= srcY) && (sy < srcY + srcHeight)) { int c = gdImageGetPixel (src, sx, sy); /* 2.0.34: transparency wins */ if (c == src->transparent) { gdImageSetPixel (dst, dx, dy, dst->transparent); } else if (!src->trueColor) { /* Use a table to avoid an expensive lookup on every single pixel */ if (cmap[c] == -1) { cmap[c] = gdImageColorResolveAlpha (dst, gdImageRed (src, c), gdImageGreen (src, c), gdImageBlue (src, c), gdImageAlpha (src, c)); } gdImageSetPixel (dst, dx, dy, cmap[c]); } else { gdImageSetPixel (dst, dx, dy, gdImageColorResolveAlpha (dst, gdImageRed (src, c), gdImageGreen (src, c), gdImageBlue (src, c), gdImageAlpha (src, c))); } } } } } /* When gd 1.x was first created, floating point was to be avoided. These days it is often faster than table lookups or integer arithmetic. The routine below is shamelessly, gloriously floating point. TBB */ /* 2.0.10: cast instead of floor() yields 35% performance improvement. Thanks to John Buckman. */ #define floor2(exp) ((long) exp) /*#define floor2(exp) floor(exp)*/ BGD_DECLARE(void) gdImageCopyResampled (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH) { int x, y; double sy1, sy2, sx1, sx2; if (!dst->trueColor) { gdImageCopyResized (dst, src, dstX, dstY, srcX, srcY, dstW, dstH, srcW, srcH); return; } for (y = dstY; (y < dstY + dstH); y++) { sy1 = ((double) y - (double) dstY) * (double) srcH / (double) dstH; sy2 = ((double) (y + 1) - (double) dstY) * (double) srcH / (double) dstH; for (x = dstX; (x < dstX + dstW); x++) { double sx, sy; double spixels = 0; double red = 0.0, green = 0.0, blue = 0.0, alpha = 0.0; double alpha_sum = 0.0, contrib_sum = 0.0; sx1 = ((double) x - (double) dstX) * (double) srcW / dstW; sx2 = ((double) (x + 1) - (double) dstX) * (double) srcW / dstW; sy = sy1; do { double yportion; if (floor2 (sy) == floor2 (sy1)) { yportion = 1.0 - (sy - floor2 (sy)); if (yportion > sy2 - sy1) { yportion = sy2 - sy1; } sy = floor2 (sy); } else if (sy == floor2 (sy2)) { yportion = sy2 - floor2 (sy2); } else { yportion = 1.0; } sx = sx1; do { double xportion; double pcontribution; int p; if (floor2 (sx) == floor2 (sx1)) { xportion = 1.0 - (sx - floor2 (sx)); if (xportion > sx2 - sx1) { xportion = sx2 - sx1; } sx = floor2 (sx); } else if (sx == floor2 (sx2)) { xportion = sx2 - floor2 (sx2); } else { xportion = 1.0; } pcontribution = xportion * yportion; /* 2.08: previously srcX and srcY were ignored. Andrew Pattison */ p = gdImageGetTrueColorPixel (src, (int) sx + srcX, (int) sy + srcY); red += gdTrueColorGetRed (p) * pcontribution; green += gdTrueColorGetGreen (p) * pcontribution; blue += gdTrueColorGetBlue (p) * pcontribution; alpha += gdTrueColorGetAlpha (p) * pcontribution; spixels += xportion * yportion; sx += 1.0; } while (sx < sx2); sy += 1.0; } while (sy < sy2); if (spixels != 0.0) { red /= spixels; green /= spixels; blue /= spixels; alpha /= spixels; alpha += 0.5; } if ( alpha_sum != 0.0f) { if( contrib_sum != 0.0f) { alpha_sum /= contrib_sum; } red /= alpha_sum; green /= alpha_sum; blue /= alpha_sum; } /* Clamping to allow for rounding errors above */ if (red > 255.0) { red = 255.0; } if (green > 255.0) { green = 255.0; } if (blue > 255.0) { blue = 255.0; } if (alpha > gdAlphaMax) { alpha = gdAlphaMax; } gdImageSetPixel (dst, x, y, gdTrueColorAlpha ((int) red, (int) green, (int) blue, (int) alpha)); } } } BGD_DECLARE(void) gdImagePolygon (gdImagePtr im, gdPointPtr p, int n, int c) { if (n <= 0) { return; } gdImageLine (im, p->x, p->y, p[n - 1].x, p[n - 1].y, c); gdImageOpenPolygon (im, p, n, c); } BGD_DECLARE(void) gdImageOpenPolygon (gdImagePtr im, gdPointPtr p, int n, int c) { int i; int lx, ly; if (n <= 0) { return; } lx = p->x; ly = p->y; for (i = 1; (i < n); i++) { p++; gdImageLine (im, lx, ly, p->x, p->y, c); lx = p->x; ly = p->y; } } /* THANKS to Kirsten Schulz for the polygon fixes! */ /* The intersection finding technique of this code could be improved */ /* by remembering the previous intertersection, and by using the slope. */ /* That could help to adjust intersections to produce a nice */ /* interior_extrema. */ BGD_DECLARE(void) gdImageFilledPolygon (gdImagePtr im, gdPointPtr p, int n, int c) { int i; int j; int index; int y; int miny, maxy, pmaxy; int x1, y1; int x2, y2; int ind1, ind2; int ints; int fill_color; if (n <= 0) { return; } if (c == gdAntiAliased) { fill_color = im->AA_color; } else { fill_color = c; } if (!im->polyAllocated) { if (overflow2(sizeof (int), n)) { return; } im->polyInts = (int *) gdMalloc (sizeof (int) * n); if (!im->polyInts) { return; } im->polyAllocated = n; } if (im->polyAllocated < n) { while (im->polyAllocated < n) { im->polyAllocated *= 2; } if (overflow2(sizeof (int), im->polyAllocated)) { return; } im->polyInts = (int *) gdReallocEx (im->polyInts, sizeof (int) * im->polyAllocated); if (!im->polyInts) { return; } } miny = p[0].y; maxy = p[0].y; for (i = 1; (i < n); i++) { if (p[i].y < miny) { miny = p[i].y; } if (p[i].y > maxy) { maxy = p[i].y; } } pmaxy = maxy; /* 2.0.16: Optimization by Ilia Chipitsine -- don't waste time offscreen */ /* 2.0.26: clipping rectangle is even better */ if (miny < im->cy1) { miny = im->cy1; } if (maxy > im->cy2) { maxy = im->cy2; } /* Fix in 1.3: count a vertex only once */ for (y = miny; (y <= maxy); y++) { ints = 0; for (i = 0; (i < n); i++) { if (!i) { ind1 = n - 1; ind2 = 0; } else { ind1 = i - 1; ind2 = i; } y1 = p[ind1].y; y2 = p[ind2].y; if (y1 < y2) { x1 = p[ind1].x; x2 = p[ind2].x; } else if (y1 > y2) { y2 = p[ind1].y; y1 = p[ind2].y; x2 = p[ind1].x; x1 = p[ind2].x; } else { continue; } /* Do the following math as float intermediately, and round to ensure * that Polygon and FilledPolygon for the same set of points have the * same footprint. */ if ((y >= y1) && (y < y2)) { im->polyInts[ints++] = (int) ((float) ((y - y1) * (x2 - x1)) / (float) (y2 - y1) + 0.5 + x1); } else if ((y == pmaxy) && (y == y2)) { im->polyInts[ints++] = x2; } } /* 2.0.26: polygons pretty much always have less than 100 points, and most of the time they have considerably less. For such trivial cases, insertion sort is a good choice. Also a good choice for future implementations that may wish to indirect through a table. */ for (i = 1; (i < ints); i++) { index = im->polyInts[i]; j = i; while ((j > 0) && (im->polyInts[j - 1] > index)) { im->polyInts[j] = im->polyInts[j - 1]; j--; } im->polyInts[j] = index; } for (i = 0; (i < (ints-1)); i += 2) { /* 2.0.29: back to gdImageLine to prevent segfaults when performing a pattern fill */ gdImageLine (im, im->polyInts[i], y, im->polyInts[i + 1], y, fill_color); } } /* If we are drawing this AA, then redraw the border with AA lines. */ /* This doesn't work as well as I'd like, but it doesn't clash either. */ if (c == gdAntiAliased) { gdImagePolygon (im, p, n, c); } } static void gdImageSetAAPixelColor(gdImagePtr im, int x, int y, int color, int t); BGD_DECLARE(void) gdImageSetStyle (gdImagePtr im, int *style, int noOfPixels) { if (im->style) { gdFree (im->style); } if (overflow2(sizeof (int), noOfPixels)) { return; } im->style = (int *) gdMalloc (sizeof (int) * noOfPixels); if (!im->style) { return; } memcpy (im->style, style, sizeof (int) * noOfPixels); im->styleLength = noOfPixels; im->stylePos = 0; } BGD_DECLARE(void) gdImageSetThickness (gdImagePtr im, int thickness) { im->thick = thickness; } BGD_DECLARE(void) gdImageSetBrush (gdImagePtr im, gdImagePtr brush) { int i; im->brush = brush; if ((!im->trueColor) && (!im->brush->trueColor)) { for (i = 0; (i < gdImageColorsTotal (brush)); i++) { int index; index = gdImageColorResolveAlpha (im, gdImageRed (brush, i), gdImageGreen (brush, i), gdImageBlue (brush, i), gdImageAlpha (brush, i)); im->brushColorMap[i] = index; } } } BGD_DECLARE(void) gdImageSetTile (gdImagePtr im, gdImagePtr tile) { int i; im->tile = tile; if ((!im->trueColor) && (!im->tile->trueColor)) { for (i = 0; (i < gdImageColorsTotal (tile)); i++) { int index; index = gdImageColorResolveAlpha (im, gdImageRed (tile, i), gdImageGreen (tile, i), gdImageBlue (tile, i), gdImageAlpha (tile, i)); im->tileColorMap[i] = index; } } } BGD_DECLARE(void) gdImageSetAntiAliased (gdImagePtr im, int c) { im->AA = 1; im->AA_color = c; im->AA_dont_blend = -1; } BGD_DECLARE(void) gdImageSetAntiAliasedDontBlend (gdImagePtr im, int c, int dont_blend) { im->AA = 1; im->AA_color = c; im->AA_dont_blend = dont_blend; } BGD_DECLARE(void) gdImageInterlace (gdImagePtr im, int interlaceArg) { im->interlace = interlaceArg; } BGD_DECLARE(int) gdImageCompare (gdImagePtr im1, gdImagePtr im2) { int x, y; int p1, p2; int cmpStatus = 0; int sx, sy; if (im1->interlace != im2->interlace) { cmpStatus |= GD_CMP_INTERLACE; } if (im1->transparent != im2->transparent) { cmpStatus |= GD_CMP_TRANSPARENT; } if (im1->trueColor != im2->trueColor) { cmpStatus |= GD_CMP_TRUECOLOR; } sx = im1->sx; if (im1->sx != im2->sx) { cmpStatus |= GD_CMP_SIZE_X + GD_CMP_IMAGE; if (im2->sx < im1->sx) { sx = im2->sx; } } sy = im1->sy; if (im1->sy != im2->sy) { cmpStatus |= GD_CMP_SIZE_Y + GD_CMP_IMAGE; if (im2->sy < im1->sy) { sy = im2->sy; } } if (im1->colorsTotal != im2->colorsTotal) { cmpStatus |= GD_CMP_NUM_COLORS; } for (y = 0; (y < sy); y++) { for (x = 0; (x < sx); x++) { p1 = im1->trueColor ? gdImageTrueColorPixel (im1, x, y) : gdImagePalettePixel (im1, x, y); p2 = im2->trueColor ? gdImageTrueColorPixel (im2, x, y) : gdImagePalettePixel (im2, x, y); if (gdImageRed (im1, p1) != gdImageRed (im2, p2)) { cmpStatus |= GD_CMP_COLOR + GD_CMP_IMAGE; break; } if (gdImageGreen (im1, p1) != gdImageGreen (im2, p2)) { cmpStatus |= GD_CMP_COLOR + GD_CMP_IMAGE; break; } if (gdImageBlue (im1, p1) != gdImageBlue (im2, p2)) { cmpStatus |= GD_CMP_COLOR + GD_CMP_IMAGE; break; } #if 0 /* Soon we'll add alpha channel to palettes */ if (gdImageAlpha (im1, p1) != gdImageAlpha (im2, p2)) { cmpStatus |= GD_CMP_COLOR + GD_CMP_IMAGE; break; } #endif } if (cmpStatus & GD_CMP_COLOR) { break; }; } return cmpStatus; } /* Thanks to Frank Warmerdam for this superior implementation of gdAlphaBlend(), which merges alpha in the destination color much better. */ BGD_DECLARE(int) gdAlphaBlend (int dst, int src) { int src_alpha = gdTrueColorGetAlpha(src); int dst_alpha, alpha, red, green, blue; int src_weight, dst_weight, tot_weight; /* -------------------------------------------------------------------- */ /* Simple cases we want to handle fast. */ /* -------------------------------------------------------------------- */ if( src_alpha == gdAlphaOpaque ) return src; dst_alpha = gdTrueColorGetAlpha(dst); if( src_alpha == gdAlphaTransparent ) return dst; if( dst_alpha == gdAlphaTransparent ) return src; /* -------------------------------------------------------------------- */ /* What will the source and destination alphas be? Note that */ /* the destination weighting is substantially reduced as the */ /* overlay becomes quite opaque. */ /* -------------------------------------------------------------------- */ src_weight = gdAlphaTransparent - src_alpha; dst_weight = (gdAlphaTransparent - dst_alpha) * src_alpha / gdAlphaMax; tot_weight = src_weight + dst_weight; /* -------------------------------------------------------------------- */ /* What red, green and blue result values will we use? */ /* -------------------------------------------------------------------- */ alpha = src_alpha * dst_alpha / gdAlphaMax; red = (gdTrueColorGetRed(src) * src_weight + gdTrueColorGetRed(dst) * dst_weight) / tot_weight; green = (gdTrueColorGetGreen(src) * src_weight + gdTrueColorGetGreen(dst) * dst_weight) / tot_weight; blue = (gdTrueColorGetBlue(src) * src_weight + gdTrueColorGetBlue(dst) * dst_weight) / tot_weight; /* -------------------------------------------------------------------- */ /* Return merged result. */ /* -------------------------------------------------------------------- */ return ((alpha << 24) + (red << 16) + (green << 8) + blue); } static int gdAlphaOverlayColor (int src, int dst, int max ); BGD_DECLARE(int) gdLayerOverlay (int dst, int src) { int a1, a2; a1 = gdAlphaMax - gdTrueColorGetAlpha(dst); a2 = gdAlphaMax - gdTrueColorGetAlpha(src); return ( ((gdAlphaMax - a1*a2/gdAlphaMax) << 24) + (gdAlphaOverlayColor( gdTrueColorGetRed(src), gdTrueColorGetRed(dst), gdRedMax ) << 16) + (gdAlphaOverlayColor( gdTrueColorGetGreen(src), gdTrueColorGetGreen(dst), gdGreenMax ) << 8) + (gdAlphaOverlayColor( gdTrueColorGetBlue(src), gdTrueColorGetBlue(dst), gdBlueMax )) ); } /* Apply 'overlay' effect - background pixels are colourised by the foreground colour */ static int gdAlphaOverlayColor (int src, int dst, int max ) { dst = dst << 1; if( dst > max ) { /* in the "light" zone */ return dst + (src << 1) - (dst * src / max) - max; } else { /* in the "dark" zone */ return dst * src / max; } } /* Apply 'multiply' effect */ BGD_DECLARE(int) gdLayerMultiply (int dst, int src) { int a1, a2, r1, r2, g1, g2, b1, b2; a1 = gdAlphaMax - gdTrueColorGetAlpha(src); a2 = gdAlphaMax - gdTrueColorGetAlpha(dst); r1 = gdRedMax - (a1 * (gdRedMax - gdTrueColorGetRed(src))) / gdAlphaMax; r2 = gdRedMax - (a2 * (gdRedMax - gdTrueColorGetRed(dst))) / gdAlphaMax; g1 = gdGreenMax - (a1 * (gdGreenMax - gdTrueColorGetGreen(src))) / gdAlphaMax; g2 = gdGreenMax - (a2 * (gdGreenMax - gdTrueColorGetGreen(dst))) / gdAlphaMax; b1 = gdBlueMax - (a1 * (gdBlueMax - gdTrueColorGetBlue(src))) / gdAlphaMax; b2 = gdBlueMax - (a2 * (gdBlueMax - gdTrueColorGetBlue(dst))) / gdAlphaMax ; a1 = gdAlphaMax - a1; a2 = gdAlphaMax - a2; return ( ((a1*a2/gdAlphaMax) << 24) + ((r1*r2/gdRedMax) << 16) + ((g1*g2/gdGreenMax) << 8) + ((b1*b2/gdBlueMax)) ); } BGD_DECLARE(void) gdImageAlphaBlending (gdImagePtr im, int alphaBlendingArg) { im->alphaBlendingFlag = alphaBlendingArg; } BGD_DECLARE(void) gdImageSaveAlpha (gdImagePtr im, int saveAlphaArg) { im->saveAlphaFlag = saveAlphaArg; } BGD_DECLARE(void) gdImageSetClip (gdImagePtr im, int x1, int y1, int x2, int y2) { if (x1 < 0) { x1 = 0; } if (x1 >= im->sx) { x1 = im->sx - 1; } if (x2 < 0) { x2 = 0; } if (x2 >= im->sx) { x2 = im->sx - 1; } if (y1 < 0) { y1 = 0; } if (y1 >= im->sy) { y1 = im->sy - 1; } if (y2 < 0) { y2 = 0; } if (y2 >= im->sy) { y2 = im->sy - 1; } im->cx1 = x1; im->cy1 = y1; im->cx2 = x2; im->cy2 = y2; } BGD_DECLARE(void) gdImageGetClip (gdImagePtr im, int *x1P, int *y1P, int *x2P, int *y2P) { *x1P = im->cx1; *y1P = im->cy1; *x2P = im->cx2; *y2P = im->cy2; } BGD_DECLARE(void) gdImageSetResolution(gdImagePtr im, const unsigned int res_x, const unsigned int res_y) { if (res_x > 0) im->res_x = res_x; if (res_y > 0) im->res_y = res_y; } /* * Added on 2003/12 by Pierre-Alain Joye (pajoye@pearfr.org) * */ #define BLEND_COLOR(a, nc, c, cc) \ nc = (cc) + (((((c) - (cc)) * (a)) + ((((c) - (cc)) * (a)) >> 8) + 0x80) >> 8); static void gdImageSetAAPixelColor(gdImagePtr im, int x, int y, int color, int t) { int dr,dg,db,p,r,g,b; /* 2.0.34: watch out for out of range calls */ if (!gdImageBoundsSafeMacro(im, x, y)) { return; } p = gdImageGetPixel(im,x,y); /* TBB: we have to implement the dont_blend stuff to provide the full feature set of the old implementation */ if ((p == color) || ((p == im->AA_dont_blend) && (t != 0x00))) { return; } dr = gdTrueColorGetRed(color); dg = gdTrueColorGetGreen(color); db = gdTrueColorGetBlue(color); r = gdTrueColorGetRed(p); g = gdTrueColorGetGreen(p); b = gdTrueColorGetBlue(p); BLEND_COLOR(t, dr, r, dr); BLEND_COLOR(t, dg, g, dg); BLEND_COLOR(t, db, b, db); im->tpixels[y][x] = gdTrueColorAlpha(dr, dg, db, gdAlphaOpaque); } static void gdImageAALine (gdImagePtr im, int x1, int y1, int x2, int y2, int col) { /* keep them as 32bits */ long x, y, inc, frac; long dx, dy,tmp; int w, wid, wstart; int thick = im->thick; if (!im->trueColor) { /* TBB: don't crash when the image is of the wrong type */ gdImageLine(im, x1, y1, x2, y2, col); return; } /* TBB: use the clipping rectangle */ if (clip_1d (&x1, &y1, &x2, &y2, im->cx1, im->cx2) == 0) return; if (clip_1d (&y1, &x1, &y2, &x2, im->cy1, im->cy2) == 0) return; dx = x2 - x1; dy = y2 - y1; if (dx == 0 && dy == 0) { /* TBB: allow setting points */ gdImageSetAAPixelColor(im, x1, y1, col, 0xFF); return; } else { double ag; ag = (abs(dy) < abs(dx)) ? cos(atan2(dy, dx)) : sin(atan2(dy, dx)); if (ag != 0) { wid = abs(thick / ag); } else { wid = 1; } if (wid == 0) { wid = 1; } } /* Axis aligned lines */ if (dx == 0) { gdImageVLine(im, x1, y1, y2, col); return; } else if (dy == 0) { gdImageHLine(im, y1, x1, x2, col); return; } if (abs(dx) > abs(dy)) { if (dx < 0) { tmp = x1; x1 = x2; x2 = tmp; tmp = y1; y1 = y2; y2 = tmp; dx = x2 - x1; dy = y2 - y1; } y = y1; inc = (dy * 65536) / dx; frac = 0; /* TBB: set the last pixel for consistency (<=) */ for (x = x1 ; x <= x2 ; x++) { wstart = y - wid / 2; for (w = wstart; w < wstart + wid; w++) { gdImageSetAAPixelColor(im, x , w , col , (frac >> 8) & 0xFF); gdImageSetAAPixelColor(im, x , w + 1 , col, (~frac >> 8) & 0xFF); } frac += inc; if (frac >= 65536) { frac -= 65536; y++; } else if (frac < 0) { frac += 65536; y--; } } } else { if (dy < 0) { tmp = x1; x1 = x2; x2 = tmp; tmp = y1; y1 = y2; y2 = tmp; dx = x2 - x1; dy = y2 - y1; } x = x1; inc = (dx * 65536) / dy; frac = 0; /* TBB: set the last pixel for consistency (<=) */ for (y = y1 ; y <= y2 ; y++) { wstart = x - wid / 2; for (w = wstart; w < wstart + wid; w++) { gdImageSetAAPixelColor(im, w , y , col, (frac >> 8) & 0xFF); gdImageSetAAPixelColor(im, w + 1, y, col, (~frac >> 8) & 0xFF); } frac += inc; if (frac >= 65536) { frac -= 65536; x++; } else if (frac < 0) { frac += 65536; x--; } } } } /* convert a palette image to true color */ BGD_DECLARE(int) gdImagePaletteToTrueColor(gdImagePtr src) { unsigned int y; unsigned int yy; if (src == NULL) { return 0; } if (src->trueColor == 1) { return 1; } else { unsigned int x; const unsigned int sy = gdImageSY(src); const unsigned int sx = gdImageSX(src); src->tpixels = (int **) gdMalloc(sizeof(int *) * sy); if (src->tpixels == NULL) { return 0; } for (y = 0; y < sy; y++) { const unsigned char *src_row = src->pixels[y]; int * dst_row; /* no need to calloc it, we overwrite all pxl anyway */ src->tpixels[y] = (int *) gdMalloc(sx * sizeof(int)); if (src->tpixels[y] == NULL) { goto clean_on_error; } dst_row = src->tpixels[y]; for (x = 0; x < sx; x++) { const unsigned char c = *(src_row + x); if (c == src->transparent) { *(dst_row + x) = gdTrueColorAlpha(0, 0, 0, 127);; } else { *(dst_row + x) = gdTrueColorAlpha(src->red[c], src->green[c], src->blue[c], src->alpha[c]); } } } } /* free old palette buffer (y is sy) */ for (yy = 0; yy < y; yy++) { gdFree(src->pixels[yy]); } gdFree(src->pixels); src->trueColor = 1; src->pixels = NULL; src->alphaBlendingFlag = 0; src->saveAlphaFlag = 1; return 1; clean_on_error: /* free new true color buffer (y is not allocated, have failed) */ for (yy = 0; yy < y; yy++) { gdFree(src->tpixels[yy]); } gdFree(src->tpixels); return 0; } libgd-gd-2.1.1/src/gd.h000066400000000000000000001440051245535672000145330ustar00rootroot00000000000000#ifdef __cplusplus extern "C" { #endif #ifndef GD_H #define GD_H 1 /* Version information. This gets parsed by build scripts as well as * gcc so each #define line in this group must also be splittable on * whitespace, take the form GD_*_VERSION and contain the magical * trailing comment. */ #define GD_MAJOR_VERSION 2 /*version605b5d1778*/ #define GD_MINOR_VERSION 1 /*version605b5d1778*/ #define GD_RELEASE_VERSION 1 /*version605b5d1778*/ #define GD_EXTRA_VERSION "" /*version605b5d1778*/ /* End parsable section. */ /* The version string. This is constructed from the version number * parts above via macro abuse^Wtrickery. */ #define GDXXX_VERSION_STR(mjr, mnr, rev, ext) mjr "." mnr "." rev ext #define GDXXX_STR(s) GDXXX_SSTR(s) /* Two levels needed to expand args. */ #define GDXXX_SSTR(s) #s #define GD_VERSION_STRING \ GDXXX_VERSION_STR(GDXXX_STR(GD_MAJOR_VERSION), \ GDXXX_STR(GD_MINOR_VERSION), \ GDXXX_STR(GD_RELEASE_VERSION), \ GD_EXTRA_VERSION) /* Do the DLL dance: dllexport when building the DLL, dllimport when importing from it, nothing when not on Silly Silly Windows (tm Aardman Productions). */ /* 2.0.20: for headers */ /* 2.0.24: __stdcall also needed for Visual BASIC and other languages. This breaks ABI compatibility with previous DLL revs, but it's necessary. */ /* 2.0.29: WIN32 programmers can declare the NONDLL macro if they wish to build gd as a static library or by directly including the gd sources in a project. */ /* http://gcc.gnu.org/wiki/Visibility */ #if defined(_WIN32) || defined(CYGWIN) || defined(_WIN32_WCE) # ifdef BGDWIN32 # ifdef NONDLL # define BGD_EXPORT_DATA_PROT # else # ifdef __GNUC__ # define BGD_EXPORT_DATA_PROT __attribute__ ((dllexport)) # else # define BGD_EXPORT_DATA_PROT __declspec(dllexport) # endif # endif # else # ifdef __GNUC__ # define BGD_EXPORT_DATA_PROT __attribute__ ((dllimport)) # else # define BGD_EXPORT_DATA_PROT __declspec(dllimport) # endif # endif # define BGD_STDCALL __stdcall # define BGD_EXPORT_DATA_IMPL #else # ifdef HAVE_VISIBILITY # define BGD_EXPORT_DATA_PROT __attribute__ ((visibility ("default"))) # define BGD_EXPORT_DATA_IMPL __attribute__ ((visibility ("hidden"))) # else # define BGD_EXPORT_DATA_PROT # define BGD_EXPORT_DATA_IMPL # endif # define BGD_STDCALL #endif #define BGD_DECLARE(rt) BGD_EXPORT_DATA_PROT rt BGD_STDCALL /* VS2012+ disable keyword macroizing unless _ALLOW_KEYWORD_MACROS is set We define inline, snprintf, and strcasecmp if they're missing */ #ifdef _MSC_VER # define _ALLOW_KEYWORD_MACROS # ifndef inline # define inline __inline # endif # ifndef strcasecmp # define strcasecmp _stricmp # endif # ifndef snprintf # define snprintf _snprintf # endif #endif #ifdef __cplusplus extern "C" { #endif /* gd.h: declarations file for the graphic-draw module. * Permission to use, copy, modify, and distribute this software and its * documentation for any purpose and without fee is hereby granted, provided * that the above copyright notice appear in all copies and that both that * copyright notice and this permission notice appear in supporting * documentation. This software is provided "AS IS." Thomas Boutell and * Boutell.Com, Inc. disclaim all warranties, either express or implied, * including but not limited to implied warranties of merchantability and * fitness for a particular purpose, with respect to this code and accompanying * documentation. */ /* stdio is needed for file I/O. */ #include #include #include "gd_io.h" /* The maximum number of palette entries in palette-based images. In the wonderful new world of gd 2.0, you can of course have many more colors when using truecolor mode. */ #define gdMaxColors 256 /* Image type. See functions below; you will not need to change the elements directly. Use the provided macros to access sx, sy, the color table, and colorsTotal for read-only purposes. */ /* If 'truecolor' is set true, the image is truecolor; pixels are represented by integers, which must be 32 bits wide or more. True colors are repsented as follows: ARGB Where 'A' (alpha channel) occupies only the LOWER 7 BITS of the MSB. This very small loss of alpha channel resolution allows gd 2.x to keep backwards compatibility by allowing signed integers to be used to represent colors, and negative numbers to represent special cases, just as in gd 1.x. */ #define gdAlphaMax 127 #define gdAlphaOpaque 0 #define gdAlphaTransparent 127 #define gdRedMax 255 #define gdGreenMax 255 #define gdBlueMax 255 #define gdTrueColorGetAlpha(c) (((c) & 0x7F000000) >> 24) #define gdTrueColorGetRed(c) (((c) & 0xFF0000) >> 16) #define gdTrueColorGetGreen(c) (((c) & 0x00FF00) >> 8) #define gdTrueColorGetBlue(c) ((c) & 0x0000FF) #define gdEffectReplace 0 #define gdEffectAlphaBlend 1 #define gdEffectNormal 2 #define gdEffectOverlay 3 #define gdEffectMultiply 4 #define GD_TRUE 1 #define GD_FALSE 0 #define GD_EPSILON 1e-6 #ifndef M_PI # define M_PI 3.14159265358979323846 #endif /* This function accepts truecolor pixel values only. The source color is composited with the destination color based on the alpha channel value of the source color. The resulting color is opaque. */ BGD_DECLARE(int) gdAlphaBlend (int dest, int src); BGD_DECLARE(int) gdLayerOverlay (int dest, int src); BGD_DECLARE(int) gdLayerMultiply (int dest, int src); enum gdPaletteQuantizationMethod { GD_QUANT_DEFAULT = 0, GD_QUANT_JQUANT = 1, /* libjpeg's old median cut. Fast, but only uses 16-bit color. */ GD_QUANT_NEUQUANT = 2, /* neuquant - approximation using kohonen neural network. */ GD_QUANT_LIQ = 3 /* combination of algorithms used in libimagequant/pngquant2 aiming for highest quality at cost of speed */ }; /** * Group: Transform * * Constants: gdInterpolationMethod * * GD_BELL - Bell * GD_BESSEL - Bessel * GD_BILINEAR_FIXED - fixed point bilinear * GD_BICUBIC - Bicubic * GD_BICUBIC_FIXED - fixed point bicubic integer * GD_BLACKMAN - Blackman * GD_BOX - Box * GD_BSPLINE - BSpline * GD_CATMULLROM - Catmullrom * GD_GAUSSIAN - Gaussian * GD_GENERALIZED_CUBIC - Generalized cubic * GD_HERMITE - Hermite * GD_HAMMING - Hamming * GD_HANNING - Hannig * GD_MITCHELL - Mitchell * GD_NEAREST_NEIGHBOUR - Nearest neighbour interpolation * GD_POWER - Power * GD_QUADRATIC - Quadratic * GD_SINC - Sinc * GD_TRIANGLE - Triangle * GD_WEIGHTED4 - 4 pixels weighted bilinear interpolation * * See also: * **/ typedef enum { GD_DEFAULT = 0, GD_BELL, GD_BESSEL, GD_BILINEAR_FIXED, GD_BICUBIC, GD_BICUBIC_FIXED, GD_BLACKMAN, GD_BOX, GD_BSPLINE, GD_CATMULLROM, GD_GAUSSIAN, GD_GENERALIZED_CUBIC, GD_HERMITE, GD_HAMMING, GD_HANNING, GD_MITCHELL, GD_NEAREST_NEIGHBOUR, GD_POWER, GD_QUADRATIC, GD_SINC, GD_TRIANGLE, GD_WEIGHTED4, GD_METHOD_COUNT = 21 } gdInterpolationMethod; /* define struct with name and func ptr and add it to gdImageStruct gdInterpolationMethod interpolation; */ /* Interpolation function ptr */ typedef double (* interpolation_method )(double); /* Group: Types typedef: gdImage typedef: gdImagePtr The data structure in which gd stores images. , and the various image file-loading functions return a pointer to this type, and the other functions expect to receive a pointer to this type as their first argument. *gdImagePtr* is a pointer to *gdImage*. (Previous versions of this library encouraged directly manipulating the contents ofthe struct but we are attempting to move away from this practice so the fields are no longer documented here. If you need to poke at the internals of this struct, feel free to look at *gd.h*.) */ typedef struct gdImageStruct { /* Palette-based image pixels */ unsigned char **pixels; int sx; int sy; /* These are valid in palette images only. See also 'alpha', which appears later in the structure to preserve binary backwards compatibility */ int colorsTotal; int red[gdMaxColors]; int green[gdMaxColors]; int blue[gdMaxColors]; int open[gdMaxColors]; /* For backwards compatibility, this is set to the first palette entry with 100% transparency, and is also set and reset by the gdImageColorTransparent function. Newer applications can allocate palette entries with any desired level of transparency; however, bear in mind that many viewers, notably many web browsers, fail to implement full alpha channel for PNG and provide support for full opacity or transparency only. */ int transparent; int *polyInts; int polyAllocated; struct gdImageStruct *brush; struct gdImageStruct *tile; int brushColorMap[gdMaxColors]; int tileColorMap[gdMaxColors]; int styleLength; int stylePos; int *style; int interlace; /* New in 2.0: thickness of line. Initialized to 1. */ int thick; /* New in 2.0: alpha channel for palettes. Note that only Macintosh Internet Explorer and (possibly) Netscape 6 really support multiple levels of transparency in palettes, to my knowledge, as of 2/15/01. Most common browsers will display 100% opaque and 100% transparent correctly, and do something unpredictable and/or undesirable for levels in between. TBB */ int alpha[gdMaxColors]; /* Truecolor flag and pixels. New 2.0 fields appear here at the end to minimize breakage of existing object code. */ int trueColor; int **tpixels; /* Should alpha channel be copied, or applied, each time a pixel is drawn? This applies to truecolor images only. No attempt is made to alpha-blend in palette images, even if semitransparent palette entries exist. To do that, build your image as a truecolor image, then quantize down to 8 bits. */ int alphaBlendingFlag; /* Should the alpha channel of the image be saved? This affects PNG at the moment; other future formats may also have that capability. JPEG doesn't. */ int saveAlphaFlag; /* There should NEVER BE ACCESSOR MACROS FOR ITEMS BELOW HERE, so this part of the structure can be safely changed in new releases. */ /* 2.0.12: anti-aliased globals. 2.0.26: just a few vestiges after switching to the fast, memory-cheap implementation from PHP-gd. */ int AA; int AA_color; int AA_dont_blend; /* 2.0.12: simple clipping rectangle. These values must be checked for safety when set; please use gdImageSetClip */ int cx1; int cy1; int cx2; int cy2; /* 2.1.0: allows to specify resolution in dpi */ unsigned int res_x; unsigned int res_y; /* Selects quantization method, see gdImageTrueColorToPaletteSetMethod() and gdPaletteQuantizationMethod enum. */ int paletteQuantizationMethod; /* speed/quality trade-off. 1 = best quality, 10 = best speed. 0 = method-specific default. Applicable to GD_QUANT_LIQ and GD_QUANT_NEUQUANT. */ int paletteQuantizationSpeed; /* Image will remain true-color if conversion to palette cannot achieve given quality. Value from 1 to 100, 1 = ugly, 100 = perfect. Applicable to GD_QUANT_LIQ.*/ int paletteQuantizationMinQuality; /* Image will use minimum number of palette colors needed to achieve given quality. Must be higher than paletteQuantizationMinQuality Value from 1 to 100, 1 = ugly, 100 = perfect. Applicable to GD_QUANT_LIQ.*/ int paletteQuantizationMaxQuality; gdInterpolationMethod interpolation_id; interpolation_method interpolation; } gdImage; typedef gdImage *gdImagePtr; /* Point type for use in polygon drawing. */ /** * Group: Types * * typedef: gdPointF * Defines a point in a 2D coordinate system using floating point * values. * x - Floating point position (increase from left to right) * y - Floating point Row position (increase from top to bottom) * * typedef: gdPointFPtr * Pointer to a * * See also: * , , **/ typedef struct { double x, y; } gdPointF, *gdPointFPtr; /* Group: Types typedef: gdFont typedef: gdFontPtr A font structure, containing the bitmaps of all characters in a font. Used to declare the characteristics of a font. Text-output functions expect these as their second argument, following the argument. and both return one. You can provide your own font data by providing such a structure and the associated pixel array. You can determine the width and height of a single character in a font by examining the w and h members of the structure. If you will not be creating your own fonts, you will not need to concern yourself with the rest of the components of this structure. Please see the files gdfontl.c and gdfontl.h for an example of the proper declaration of this structure. > typedef struct { > // # of characters in font > int nchars; > // First character is numbered... (usually 32 = space) > int offset; > // Character width and height > int w; > int h; > // Font data; array of characters, one row after another. > // Easily included in code, also easily loaded from > // data files. > char *data; > } gdFont; gdFontPtr is a pointer to gdFont. */ typedef struct { /* # of characters in font */ int nchars; /* First character is numbered... (usually 32 = space) */ int offset; /* Character width and height */ int w; int h; /* Font data; array of characters, one row after another. Easily included in code, also easily loaded from data files. */ char *data; } gdFont; /* Text functions take these. */ typedef gdFont *gdFontPtr; typedef void(*gdErrorMethod)(int, const char *, va_list); BGD_DECLARE(void) gdSetErrorMethod(gdErrorMethod); BGD_DECLARE(void) gdClearErrorMethod(void); /* For backwards compatibility only. Use gdImageSetStyle() for MUCH more flexible line drawing. Also see gdImageSetBrush(). */ #define gdDashSize 4 /* Special colors. */ #define gdStyled (-2) #define gdBrushed (-3) #define gdStyledBrushed (-4) #define gdTiled (-5) /* NOT the same as the transparent color index. This is used in line styles only. */ #define gdTransparent (-6) #define gdAntiAliased (-7) /* Functions to manipulate images. */ /* Creates a palette-based image (up to 256 colors). */ BGD_DECLARE(gdImagePtr) gdImageCreate (int sx, int sy); /* An alternate name for the above (2.0). */ #define gdImageCreatePalette gdImageCreate /* Creates a truecolor image (millions of colors). */ BGD_DECLARE(gdImagePtr) gdImageCreateTrueColor (int sx, int sy); /* Creates an image from various file types. These functions return a palette or truecolor image based on the nature of the file being loaded. Truecolor PNG stays truecolor; palette PNG stays palette-based; JPEG is always truecolor. */ BGD_DECLARE(gdImagePtr) gdImageCreateFromPng (FILE * fd); BGD_DECLARE(gdImagePtr) gdImageCreateFromPngCtx (gdIOCtxPtr in); BGD_DECLARE(gdImagePtr) gdImageCreateFromPngPtr (int size, void *data); /* These read the first frame only */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGif (FILE * fd); BGD_DECLARE(gdImagePtr) gdImageCreateFromGifCtx (gdIOCtxPtr in); BGD_DECLARE(gdImagePtr) gdImageCreateFromGifPtr (int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromWBMP (FILE * inFile); BGD_DECLARE(gdImagePtr) gdImageCreateFromWBMPCtx (gdIOCtx * infile); BGD_DECLARE(gdImagePtr) gdImageCreateFromWBMPPtr (int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromJpeg (FILE * infile); BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegEx (FILE * infile, int ignore_warning); BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegCtx (gdIOCtx * infile); BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegCtxEx (gdIOCtx * infile, int ignore_warning); BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegPtr (int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegPtrEx (int size, void *data, int ignore_warning); BGD_DECLARE(gdImagePtr) gdImageCreateFromWebp (FILE * inFile); BGD_DECLARE(gdImagePtr) gdImageCreateFromWebpPtr (int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromWebpCtx (gdIOCtx * infile); BGD_DECLARE(gdImagePtr) gdImageCreateFromTiff(FILE *inFile); BGD_DECLARE(gdImagePtr) gdImageCreateFromTiffCtx(gdIOCtx *infile); BGD_DECLARE(gdImagePtr) gdImageCreateFromTiffPtr(int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromTga( FILE * fp ); BGD_DECLARE(gdImagePtr) gdImageCreateFromTgaCtx(gdIOCtx* ctx); BGD_DECLARE(gdImagePtr) gdImageCreateFromTgaPtr(int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromBmp (FILE * inFile); BGD_DECLARE(gdImagePtr) gdImageCreateFromBmpPtr (int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromBmpCtx (gdIOCtxPtr infile); BGD_DECLARE(gdImagePtr) gdImageCreateFromFile(const char *filename); /* Group: Types typedef: gdSource typedef: gdSourcePtr *Note:* This interface is *obsolete* and kept only for *compatibility. Use instead. Represents a source from which a PNG can be read. Programmers who do not wish to read PNGs from a file can provide their own alternate input mechanism, using the function. See the documentation of that function for an example of the proper use of this type. > typedef struct { > int (*source) (void *context, char *buffer, int len); > void *context; > } gdSource, *gdSourcePtr; The source function must return -1 on error, otherwise the number of bytes fetched. 0 is EOF, not an error! 'context' will be passed to your source function. */ typedef struct { int (*source) (void *context, char *buffer, int len); void *context; } gdSource, *gdSourcePtr; /* Deprecated in favor of gdImageCreateFromPngCtx */ BGD_DECLARE(gdImagePtr) gdImageCreateFromPngSource (gdSourcePtr in); BGD_DECLARE(gdImagePtr) gdImageCreateFromGd (FILE * in); BGD_DECLARE(gdImagePtr) gdImageCreateFromGdCtx (gdIOCtxPtr in); BGD_DECLARE(gdImagePtr) gdImageCreateFromGdPtr (int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2 (FILE * in); BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2Ctx (gdIOCtxPtr in); BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2Ptr (int size, void *data); BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2Part (FILE * in, int srcx, int srcy, int w, int h); BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2PartCtx (gdIOCtxPtr in, int srcx, int srcy, int w, int h); BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2PartPtr (int size, void *data, int srcx, int srcy, int w, int h); /* 2.0.10: prototype was missing */ BGD_DECLARE(gdImagePtr) gdImageCreateFromXbm (FILE * in); BGD_DECLARE(void) gdImageXbmCtx(gdImagePtr image, char* file_name, int fg, gdIOCtx * out); /* NOTE: filename, not FILE */ BGD_DECLARE(gdImagePtr) gdImageCreateFromXpm (char *filename); BGD_DECLARE(void) gdImageDestroy (gdImagePtr im); /* Replaces or blends with the background depending on the most recent call to gdImageAlphaBlending and the alpha channel value of 'color'; default is to overwrite. Tiling and line styling are also implemented here. All other gd drawing functions pass through this call, allowing for many useful effects. Overlay and multiply effects are used when gdImageAlphaBlending is passed gdEffectOverlay and gdEffectMultiply */ BGD_DECLARE(void) gdImageSetPixel (gdImagePtr im, int x, int y, int color); /* FreeType 2 text output with hook to extra flags */ BGD_DECLARE(int) gdImageGetPixel (gdImagePtr im, int x, int y); BGD_DECLARE(int) gdImageGetTrueColorPixel (gdImagePtr im, int x, int y); BGD_DECLARE(void) gdImageAABlend (gdImagePtr im); BGD_DECLARE(void) gdImageLine (gdImagePtr im, int x1, int y1, int x2, int y2, int color); /* For backwards compatibility only. Use gdImageSetStyle() for much more flexible line drawing. */ BGD_DECLARE(void) gdImageDashedLine (gdImagePtr im, int x1, int y1, int x2, int y2, int color); /* Corners specified (not width and height). Upper left first, lower right second. */ BGD_DECLARE(void) gdImageRectangle (gdImagePtr im, int x1, int y1, int x2, int y2, int color); /* Solid bar. Upper left corner first, lower right corner second. */ BGD_DECLARE(void) gdImageFilledRectangle (gdImagePtr im, int x1, int y1, int x2, int y2, int color); BGD_DECLARE(void) gdImageSetClip(gdImagePtr im, int x1, int y1, int x2, int y2); BGD_DECLARE(void) gdImageGetClip(gdImagePtr im, int *x1P, int *y1P, int *x2P, int *y2P); BGD_DECLARE(void) gdImageSetResolution(gdImagePtr im, const unsigned int res_x, const unsigned int res_y); BGD_DECLARE(int) gdImageBoundsSafe (gdImagePtr im, int x, int y); BGD_DECLARE(void) gdImageChar (gdImagePtr im, gdFontPtr f, int x, int y, int c, int color); BGD_DECLARE(void) gdImageCharUp (gdImagePtr im, gdFontPtr f, int x, int y, int c, int color); BGD_DECLARE(void) gdImageString (gdImagePtr im, gdFontPtr f, int x, int y, unsigned char *s, int color); BGD_DECLARE(void) gdImageStringUp (gdImagePtr im, gdFontPtr f, int x, int y, unsigned char *s, int color); BGD_DECLARE(void) gdImageString16 (gdImagePtr im, gdFontPtr f, int x, int y, unsigned short *s, int color); BGD_DECLARE(void) gdImageStringUp16 (gdImagePtr im, gdFontPtr f, int x, int y, unsigned short *s, int color); /* 2.0.16: for thread-safe use of gdImageStringFT and friends, call this before allowing any thread to call gdImageStringFT. Otherwise it is invoked by the first thread to invoke gdImageStringFT, with a very small but real risk of a race condition. Return 0 on success, nonzero on failure to initialize freetype. */ BGD_DECLARE(int) gdFontCacheSetup (void); /* Optional: clean up after application is done using fonts in gdImageStringFT(). */ BGD_DECLARE(void) gdFontCacheShutdown (void); /* 2.0.20: for backwards compatibility. A few applications did start calling this function when it first appeared although it was never documented. Simply invokes gdFontCacheShutdown. */ BGD_DECLARE(void) gdFreeFontCache (void); /* Calls gdImageStringFT. Provided for backwards compatibility only. */ BGD_DECLARE(char *) gdImageStringTTF (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string); /* FreeType 2 text output */ BGD_DECLARE(char *) gdImageStringFT (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string); /* Group: Types typedef: gdFTStringExtra typedef: gdFTStringExtraPtr A structure and associated pointer type used to pass additional parameters to the function. See for the structure definition. Thanks to Wez Furlong. */ /* 2.0.5: provides an extensible way to pass additional parameters. Thanks to Wez Furlong, sorry for the delay. */ typedef struct { int flags; /* Logical OR of gdFTEX_ values */ double linespacing; /* fine tune line spacing for '\n' */ int charmap; /* TBB: 2.0.12: may be gdFTEX_Unicode, gdFTEX_Shift_JIS, gdFTEX_Big5, or gdFTEX_Adobe_Custom; when not specified, maps are searched for in the above order. */ int hdpi; /* if (flags & gdFTEX_RESOLUTION) */ int vdpi; /* if (flags & gdFTEX_RESOLUTION) */ char *xshow; /* if (flags & gdFTEX_XSHOW) then, on return, xshow is a malloc'ed string containing xshow position data for the last string. NB. The caller is responsible for gdFree'ing the xshow string. */ char *fontpath; /* if (flags & gdFTEX_RETURNFONTPATHNAME) then, on return, fontpath is a malloc'ed string containing the actual font file path name used, which can be interesting when fontconfig is in use. The caller is responsible for gdFree'ing the fontpath string. */ } gdFTStringExtra, *gdFTStringExtraPtr; #define gdFTEX_LINESPACE 1 #define gdFTEX_CHARMAP 2 #define gdFTEX_RESOLUTION 4 #define gdFTEX_DISABLE_KERNING 8 #define gdFTEX_XSHOW 16 /* The default unless gdFTUseFontConfig(1); has been called: fontlist is a full or partial font file pathname or list thereof (i.e. just like before 2.0.29) */ #define gdFTEX_FONTPATHNAME 32 /* Necessary to use fontconfig patterns instead of font pathnames as the fontlist argument, unless gdFTUseFontConfig(1); has been called. New in 2.0.29 */ #define gdFTEX_FONTCONFIG 64 /* Sometimes interesting when fontconfig is used: the fontpath element of the structure above will contain a gdMalloc'd string copy of the actual font file pathname used, if this flag is set when the call is made */ #define gdFTEX_RETURNFONTPATHNAME 128 /* If flag is nonzero, the fontlist parameter to gdImageStringFT and gdImageStringFTEx shall be assumed to be a fontconfig font pattern if fontconfig was compiled into gd. This function returns zero if fontconfig is not available, nonzero otherwise. */ BGD_DECLARE(int) gdFTUseFontConfig(int flag); /* These are NOT flags; set one in 'charmap' if you set the gdFTEX_CHARMAP bit in 'flags'. */ #define gdFTEX_Unicode 0 #define gdFTEX_Shift_JIS 1 #define gdFTEX_Big5 2 #define gdFTEX_Adobe_Custom 3 BGD_DECLARE(char *) gdImageStringFTEx (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string, gdFTStringExtraPtr strex); /* Group: Types typedef: gdPoint typedef: gdPointPtr Represents a point in the coordinate space of the image; used by , and for polygon drawing. > typedef struct { > int x, y; > } gdPoint, *gdPointPtr; */ typedef struct { int x, y; } gdPoint, *gdPointPtr; typedef struct { int x, y; int width, height; } gdRect, *gdRectPtr; BGD_DECLARE(void) gdImagePolygon (gdImagePtr im, gdPointPtr p, int n, int c); BGD_DECLARE(void) gdImageOpenPolygon (gdImagePtr im, gdPointPtr p, int n, int c); BGD_DECLARE(void) gdImageFilledPolygon (gdImagePtr im, gdPointPtr p, int n, int c); /* These functions still work with truecolor images, for which they never return error. */ BGD_DECLARE(int) gdImageColorAllocate (gdImagePtr im, int r, int g, int b); /* gd 2.0: palette entries with non-opaque transparency are permitted. */ BGD_DECLARE(int) gdImageColorAllocateAlpha (gdImagePtr im, int r, int g, int b, int a); /* Assumes opaque is the preferred alpha channel value */ BGD_DECLARE(int) gdImageColorClosest (gdImagePtr im, int r, int g, int b); /* Closest match taking all four parameters into account. A slightly different color with the same transparency beats the exact same color with radically different transparency */ BGD_DECLARE(int) gdImageColorClosestAlpha (gdImagePtr im, int r, int g, int b, int a); /* An alternate method */ BGD_DECLARE(int) gdImageColorClosestHWB (gdImagePtr im, int r, int g, int b); /* Returns exact, 100% opaque matches only */ BGD_DECLARE(int) gdImageColorExact (gdImagePtr im, int r, int g, int b); /* Returns an exact match only, including alpha */ BGD_DECLARE(int) gdImageColorExactAlpha (gdImagePtr im, int r, int g, int b, int a); /* Opaque only */ BGD_DECLARE(int) gdImageColorResolve (gdImagePtr im, int r, int g, int b); /* Based on gdImageColorExactAlpha and gdImageColorClosestAlpha */ BGD_DECLARE(int) gdImageColorResolveAlpha (gdImagePtr im, int r, int g, int b, int a); /* A simpler way to obtain an opaque truecolor value for drawing on a truecolor image. Not for use with palette images! */ #define gdTrueColor(r, g, b) (((r) << 16) + \ ((g) << 8) + \ (b)) /* Returns a truecolor value with an alpha channel component. gdAlphaMax (127, **NOT 255**) is transparent, 0 is completely opaque. */ #define gdTrueColorAlpha(r, g, b, a) (((a) << 24) + \ ((r) << 16) + \ ((g) << 8) + \ (b)) BGD_DECLARE(void) gdImageColorDeallocate (gdImagePtr im, int color); /* Converts a truecolor image to a palette-based image, using a high-quality two-pass quantization routine which attempts to preserve alpha channel information as well as R/G/B color information when creating a palette. If ditherFlag is set, the image will be dithered to approximate colors better, at the expense of some obvious "speckling." colorsWanted can be anything up to 256. If the original source image includes photographic information or anything that came out of a JPEG, 256 is strongly recommended. Better yet, don't use these function -- write real truecolor PNGs and JPEGs. The disk space gain of conversion to palette is not great (for small images it can be negative) and the quality loss is ugly. DIFFERENCES: gdImageCreatePaletteFromTrueColor creates and returns a new image. gdImageTrueColorToPalette modifies an existing image, and the truecolor pixels are discarded. gdImageTrueColorToPalette() returns TRUE on success, FALSE on failure. */ BGD_DECLARE(gdImagePtr) gdImageCreatePaletteFromTrueColor (gdImagePtr im, int ditherFlag, int colorsWanted); BGD_DECLARE(int) gdImageTrueColorToPalette (gdImagePtr im, int ditherFlag, int colorsWanted); BGD_DECLARE(int) gdImagePaletteToTrueColor(gdImagePtr src); /* An attempt at getting the results of gdImageTrueColorToPalette to * look a bit more like the original (im1 is the original and im2 is * the palette version */ BGD_DECLARE(int) gdImageColorMatch(gdImagePtr im1, gdImagePtr im2); /* Selects quantization method used for subsequent gdImageTrueColorToPalette calls. See gdPaletteQuantizationMethod enum (e.g. GD_QUANT_NEUQUANT, GD_QUANT_LIQ). Speed is from 1 (highest quality) to 10 (fastest). Speed 0 selects method-specific default (recommended). Returns FALSE if the given method is invalid or not available. */ BGD_DECLARE(int) gdImageTrueColorToPaletteSetMethod (gdImagePtr im, int method, int speed); /* Chooses quality range that subsequent call to gdImageTrueColorToPalette will aim for. Min and max quality is in range 1-100 (1 = ugly, 100 = perfect). Max must be higher than min. If palette cannot represent image with at least min_quality, then image will remain true-color. If palette can represent image with quality better than max_quality, then lower number of colors will be used. This function has effect only when GD_QUANT_LIQ method has been selected and the source image is true-color. */ BGD_DECLARE(void) gdImageTrueColorToPaletteSetQuality (gdImagePtr im, int min_quality, int max_quality); /* Specifies a color index (if a palette image) or an RGB color (if a truecolor image) which should be considered 100% transparent. FOR TRUECOLOR IMAGES, THIS IS IGNORED IF AN ALPHA CHANNEL IS BEING SAVED. Use gdImageSaveAlpha(im, 0); to turn off the saving of a full alpha channel in a truecolor image. Note that gdImageColorTransparent is usually compatible with older browsers that do not understand full alpha channels well. TBB */ BGD_DECLARE(void) gdImageColorTransparent (gdImagePtr im, int color); BGD_DECLARE(void) gdImagePaletteCopy (gdImagePtr dst, gdImagePtr src); typedef int (*gdCallbackImageColor)(gdImagePtr im, int src); BGD_DECLARE(int) gdImageColorReplace(gdImagePtr im, int src, int dst); BGD_DECLARE(int) gdImageColorReplaceThreshold(gdImagePtr im, int src, int dst, float threshold); BGD_DECLARE(int) gdImageColorReplaceArray(gdImagePtr im, int len, int *src, int *dst); BGD_DECLARE(int) gdImageColorReplaceCallback(gdImagePtr im, gdCallbackImageColor callback); BGD_DECLARE(void) gdImageGif (gdImagePtr im, FILE * out); BGD_DECLARE(void) gdImagePng (gdImagePtr im, FILE * out); BGD_DECLARE(void) gdImagePngCtx (gdImagePtr im, gdIOCtx * out); BGD_DECLARE(void) gdImageGifCtx (gdImagePtr im, gdIOCtx * out); BGD_DECLARE(void) gdImageTiff(gdImagePtr im, FILE *outFile); BGD_DECLARE(void *) gdImageTiffPtr(gdImagePtr im, int *size); BGD_DECLARE(void) gdImageTiffCtx(gdImagePtr image, gdIOCtx *out); BGD_DECLARE(void *) gdImageBmpPtr(gdImagePtr im, int *size, int compression); BGD_DECLARE(void) gdImageBmp(gdImagePtr im, FILE *outFile, int compression); BGD_DECLARE(void) gdImageBmpCtx(gdImagePtr im, gdIOCtxPtr out, int compression); /* 2.0.12: Compression level: 0-9 or -1, where 0 is NO COMPRESSION at all, 1 is FASTEST but produces larger files, 9 provides the best compression (smallest files) but takes a long time to compress, and -1 selects the default compiled into the zlib library. */ BGD_DECLARE(void) gdImagePngEx (gdImagePtr im, FILE * out, int level); BGD_DECLARE(void) gdImagePngCtxEx (gdImagePtr im, gdIOCtx * out, int level); BGD_DECLARE(void) gdImageWBMP (gdImagePtr image, int fg, FILE * out); BGD_DECLARE(void) gdImageWBMPCtx (gdImagePtr image, int fg, gdIOCtx * out); BGD_DECLARE(int) gdImageFile(gdImagePtr im, const char *filename); BGD_DECLARE(int) gdSupportsFileType(const char *filename, int writing); /* Guaranteed to correctly free memory returned by the gdImage*Ptr functions */ BGD_DECLARE(void) gdFree (void *m); /* Best to free this memory with gdFree(), not free() */ BGD_DECLARE(void *) gdImageWBMPPtr (gdImagePtr im, int *size, int fg); /* 100 is highest quality (there is always a little loss with JPEG). 0 is lowest. 10 is about the lowest useful setting. */ BGD_DECLARE(void) gdImageJpeg (gdImagePtr im, FILE * out, int quality); BGD_DECLARE(void) gdImageJpegCtx (gdImagePtr im, gdIOCtx * out, int quality); /* Best to free this memory with gdFree(), not free() */ BGD_DECLARE(void *) gdImageJpegPtr (gdImagePtr im, int *size, int quality); BGD_DECLARE(void) gdImageWebpEx (gdImagePtr im, FILE * outFile, int quantization); BGD_DECLARE(void) gdImageWebp (gdImagePtr im, FILE * outFile); BGD_DECLARE(void *) gdImageWebpPtr (gdImagePtr im, int *size); BGD_DECLARE(void *) gdImageWebpPtrEx (gdImagePtr im, int *size, int quantization); BGD_DECLARE(void) gdImageWebpCtx (gdImagePtr im, gdIOCtx * outfile, int quantization); /** * Group: GifAnim * * Legal values for Disposal. gdDisposalNone is always used by * the built-in optimizer if previm is passed. * * Constants: gdImageGifAnim * * gdDisposalUnknown - Not recommended * gdDisposalNone - Preserve previous frame * gdDisposalRestoreBackground - First allocated color of palette * gdDisposalRestorePrevious - Restore to before start of frame * * See also: */ enum { gdDisposalUnknown, gdDisposalNone, gdDisposalRestoreBackground, gdDisposalRestorePrevious }; BGD_DECLARE(void) gdImageGifAnimBegin(gdImagePtr im, FILE *outFile, int GlobalCM, int Loops); BGD_DECLARE(void) gdImageGifAnimAdd(gdImagePtr im, FILE *outFile, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm); BGD_DECLARE(void) gdImageGifAnimEnd(FILE *outFile); BGD_DECLARE(void) gdImageGifAnimBeginCtx(gdImagePtr im, gdIOCtx *out, int GlobalCM, int Loops); BGD_DECLARE(void) gdImageGifAnimAddCtx(gdImagePtr im, gdIOCtx *out, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm); BGD_DECLARE(void) gdImageGifAnimEndCtx(gdIOCtx *out); BGD_DECLARE(void *) gdImageGifAnimBeginPtr(gdImagePtr im, int *size, int GlobalCM, int Loops); BGD_DECLARE(void *) gdImageGifAnimAddPtr(gdImagePtr im, int *size, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm); BGD_DECLARE(void *) gdImageGifAnimEndPtr(int *size); /* Group: Types typedef: gdSink typedef: gdSinkPtr *Note:* This interface is *obsolete* and kept only for *compatibility. Use instead. Represents a "sink" (destination) to which a PNG can be written. Programmers who do not wish to write PNGs to a file can provide their own alternate output mechanism, using the function. See the documentation of that function for an example of the proper use of this type. > typedef struct { > int (*sink) (void *context, char *buffer, int len); > void *context; > } gdSink, *gdSinkPtr; The _sink_ function must return -1 on error, otherwise the number of bytes written, which must be equal to len. _context_ will be passed to your sink function. */ typedef struct { int (*sink) (void *context, const char *buffer, int len); void *context; } gdSink, *gdSinkPtr; BGD_DECLARE(void) gdImagePngToSink (gdImagePtr im, gdSinkPtr out); BGD_DECLARE(void) gdImageGd (gdImagePtr im, FILE * out); BGD_DECLARE(void) gdImageGd2 (gdImagePtr im, FILE * out, int cs, int fmt); /* Best to free this memory with gdFree(), not free() */ BGD_DECLARE(void *) gdImageGifPtr (gdImagePtr im, int *size); /* Best to free this memory with gdFree(), not free() */ BGD_DECLARE(void *) gdImagePngPtr (gdImagePtr im, int *size); BGD_DECLARE(void *) gdImagePngPtrEx (gdImagePtr im, int *size, int level); /* Best to free this memory with gdFree(), not free() */ BGD_DECLARE(void *) gdImageGdPtr (gdImagePtr im, int *size); /* Best to free this memory with gdFree(), not free() */ BGD_DECLARE(void *) gdImageGd2Ptr (gdImagePtr im, int cs, int fmt, int *size); /* Style is a bitwise OR ( | operator ) of these. gdArc and gdChord are mutually exclusive; gdChord just connects the starting and ending angles with a straight line, while gdArc produces a rounded edge. gdPie is a synonym for gdArc. gdNoFill indicates that the arc or chord should be outlined, not filled. gdEdged, used together with gdNoFill, indicates that the beginning and ending angles should be connected to the center; this is a good way to outline (rather than fill) a 'pie slice'. */ #define gdArc 0 #define gdPie gdArc #define gdChord 1 #define gdNoFill 2 #define gdEdged 4 BGD_DECLARE(void) gdImageFilledArc (gdImagePtr im, int cx, int cy, int w, int h, int s, int e, int color, int style); BGD_DECLARE(void) gdImageArc (gdImagePtr im, int cx, int cy, int w, int h, int s, int e, int color); BGD_DECLARE(void) gdImageEllipse(gdImagePtr im, int cx, int cy, int w, int h, int color); BGD_DECLARE(void) gdImageFilledEllipse (gdImagePtr im, int cx, int cy, int w, int h, int color); BGD_DECLARE(void) gdImageFillToBorder (gdImagePtr im, int x, int y, int border, int color); BGD_DECLARE(void) gdImageFill (gdImagePtr im, int x, int y, int color); BGD_DECLARE(void) gdImageCopy (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h); BGD_DECLARE(void) gdImageCopyMerge (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct); BGD_DECLARE(void) gdImageCopyMergeGray (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct); /* Stretches or shrinks to fit, as needed. Does NOT attempt to average the entire set of source pixels that scale down onto the destination pixel. */ BGD_DECLARE(void) gdImageCopyResized (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH); /* gd 2.0: stretches or shrinks to fit, as needed. When called with a truecolor destination image, this function averages the entire set of source pixels that scale down onto the destination pixel, taking into account what portion of the destination pixel each source pixel represents. This is a floating point operation, but this is not a performance issue on modern hardware, except for some embedded devices. If the destination is a palette image, gdImageCopyResized is substituted automatically. */ BGD_DECLARE(void) gdImageCopyResampled (gdImagePtr dst, gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH); /* gd 2.0.8: gdImageCopyRotated is added. Source is a rectangle, with its upper left corner at srcX and srcY. Destination is the *center* of the rotated copy. Angle is in degrees, same as gdImageArc. Floating point destination center coordinates allow accurate rotation of objects of odd-numbered width or height. */ BGD_DECLARE(void) gdImageCopyRotated (gdImagePtr dst, gdImagePtr src, double dstX, double dstY, int srcX, int srcY, int srcWidth, int srcHeight, int angle); BGD_DECLARE(gdImagePtr) gdImageClone (gdImagePtr src); BGD_DECLARE(void) gdImageSetBrush (gdImagePtr im, gdImagePtr brush); BGD_DECLARE(void) gdImageSetTile (gdImagePtr im, gdImagePtr tile); BGD_DECLARE(void) gdImageSetAntiAliased (gdImagePtr im, int c); BGD_DECLARE(void) gdImageSetAntiAliasedDontBlend (gdImagePtr im, int c, int dont_blend); BGD_DECLARE(void) gdImageSetStyle (gdImagePtr im, int *style, int noOfPixels); /* Line thickness (defaults to 1). Affects lines, ellipses, rectangles, polygons and so forth. */ BGD_DECLARE(void) gdImageSetThickness (gdImagePtr im, int thickness); /* On or off (1 or 0) for all three of these. */ BGD_DECLARE(void) gdImageInterlace (gdImagePtr im, int interlaceArg); BGD_DECLARE(void) gdImageAlphaBlending (gdImagePtr im, int alphaBlendingArg); BGD_DECLARE(void) gdImageSaveAlpha (gdImagePtr im, int saveAlphaArg); BGD_DECLARE(gdImagePtr) gdImageNeuQuant(gdImagePtr im, const int max_color, int sample_factor); enum gdPixelateMode { GD_PIXELATE_UPPERLEFT, GD_PIXELATE_AVERAGE }; BGD_DECLARE(int) gdImagePixelate(gdImagePtr im, int block_size, const unsigned int mode); typedef struct { int sub; int plus; unsigned int num_colors; int *colors; unsigned int seed; } gdScatter, *gdScatterPtr; BGD_DECLARE(int) gdImageScatter(gdImagePtr im, int sub, int plus); BGD_DECLARE(int) gdImageScatterColor(gdImagePtr im, int sub, int plus, int colors[], unsigned int num_colors); BGD_DECLARE(int) gdImageScatterEx(gdImagePtr im, gdScatterPtr s); BGD_DECLARE(int) gdImageSmooth(gdImagePtr im, float weight); BGD_DECLARE(int) gdImageMeanRemoval(gdImagePtr im); BGD_DECLARE(int) gdImageEmboss(gdImagePtr im); BGD_DECLARE(int) gdImageGaussianBlur(gdImagePtr im); BGD_DECLARE(int) gdImageEdgeDetectQuick(gdImagePtr src); BGD_DECLARE(int) gdImageSelectiveBlur( gdImagePtr src); BGD_DECLARE(int) gdImageConvolution(gdImagePtr src, float filter[3][3], float filter_div, float offset); BGD_DECLARE(int) gdImageColor(gdImagePtr src, const int red, const int green, const int blue, const int alpha); BGD_DECLARE(int) gdImageContrast(gdImagePtr src, double contrast); BGD_DECLARE(int) gdImageBrightness(gdImagePtr src, int brightness); BGD_DECLARE(int) gdImageGrayScale(gdImagePtr src); BGD_DECLARE(int) gdImageNegate(gdImagePtr src); BGD_DECLARE(gdImagePtr) gdImageCopyGaussianBlurred(gdImagePtr src, int radius, double sigma); /* Macros to access information about images. */ /* Returns nonzero if the image is a truecolor image, zero for a palette image. */ #define gdImageTrueColor(im) ((im)->trueColor) #define gdImageSX(im) ((im)->sx) #define gdImageSY(im) ((im)->sy) #define gdImageColorsTotal(im) ((im)->colorsTotal) #define gdImageRed(im, c) ((im)->trueColor ? gdTrueColorGetRed(c) : \ (im)->red[(c)]) #define gdImageGreen(im, c) ((im)->trueColor ? gdTrueColorGetGreen(c) : \ (im)->green[(c)]) #define gdImageBlue(im, c) ((im)->trueColor ? gdTrueColorGetBlue(c) : \ (im)->blue[(c)]) #define gdImageAlpha(im, c) ((im)->trueColor ? gdTrueColorGetAlpha(c) : \ (im)->alpha[(c)]) #define gdImageGetTransparent(im) ((im)->transparent) #define gdImageGetInterlaced(im) ((im)->interlace) /* These macros provide direct access to pixels in palette-based and truecolor images, respectively. If you use these macros, you must perform your own bounds checking. Use of the macro for the correct type of image is also your responsibility. */ #define gdImagePalettePixel(im, x, y) (im)->pixels[(y)][(x)] #define gdImageTrueColorPixel(im, x, y) (im)->tpixels[(y)][(x)] #define gdImageResolutionX(im) (im)->res_x #define gdImageResolutionY(im) (im)->res_y /* I/O Support routines. */ BGD_DECLARE(gdIOCtx *) gdNewFileCtx (FILE *); /* If data is null, size is ignored and an initial data buffer is allocated automatically. NOTE: this function assumes gd has the right to free or reallocate "data" at will! Also note that gd will free "data" when the IO context is freed. If data is not null, it must point to memory allocated with gdMalloc, or by a call to gdImage[something]Ptr. If not, see gdNewDynamicCtxEx for an alternative. */ BGD_DECLARE(gdIOCtx *) gdNewDynamicCtx (int size, void *data); /* 2.0.21: if freeFlag is nonzero, gd will free and/or reallocate "data" as needed as described above. If freeFlag is zero, gd will never free or reallocate "data", which means that the context should only be used for *reading* an image from a memory buffer, or writing an image to a memory buffer which is already large enough. If the memory buffer is not large enough and an image write is attempted, the write operation will fail. Those wishing to write an image to a buffer in memory have a much simpler alternative in the gdImage[something]Ptr functions. */ BGD_DECLARE(gdIOCtx *) gdNewDynamicCtxEx (int size, void *data, int freeFlag); BGD_DECLARE(gdIOCtx *) gdNewSSCtx (gdSourcePtr in, gdSinkPtr out); BGD_DECLARE(void *) gdDPExtractData (struct gdIOCtx *ctx, int *size); #define GD2_CHUNKSIZE 128 #define GD2_CHUNKSIZE_MIN 64 #define GD2_CHUNKSIZE_MAX 4096 #define GD2_VERS 2 #define GD2_ID "gd2" #define GD2_FMT_RAW 1 #define GD2_FMT_COMPRESSED 2 /* Image comparison definitions */ BGD_DECLARE(int) gdImageCompare (gdImagePtr im1, gdImagePtr im2); BGD_DECLARE(void) gdImageFlipHorizontal(gdImagePtr im); BGD_DECLARE(void) gdImageFlipVertical(gdImagePtr im); BGD_DECLARE(void) gdImageFlipBoth(gdImagePtr im); #define GD_FLIP_HORINZONTAL 1 #define GD_FLIP_VERTICAL 2 #define GD_FLIP_BOTH 3 /** * Group: Crop * * Constants: gdCropMode * GD_CROP_DEFAULT - Default crop mode (4 corners or background) * GD_CROP_TRANSPARENT - Crop using the transparent color * GD_CROP_BLACK - Crop black borders * GD_CROP_WHITE - Crop white borders * GD_CROP_SIDES - Crop using colors of the 4 corners * * See also: * **/ enum gdCropMode { GD_CROP_DEFAULT = 0, GD_CROP_TRANSPARENT, GD_CROP_BLACK, GD_CROP_WHITE, GD_CROP_SIDES, GD_CROP_THRESHOLD }; BGD_DECLARE(gdImagePtr) gdImageCrop(gdImagePtr src, const gdRect *crop); BGD_DECLARE(gdImagePtr) gdImageCropAuto(gdImagePtr im, const unsigned int mode); BGD_DECLARE(gdImagePtr) gdImageCropThreshold(gdImagePtr im, const unsigned int color, const float threshold); BGD_DECLARE(int) gdImageSetInterpolationMethod(gdImagePtr im, gdInterpolationMethod id); BGD_DECLARE(gdInterpolationMethod) gdImageGetInterpolationMethod(gdImagePtr im); BGD_DECLARE(gdImagePtr) gdImageScale(const gdImagePtr src, const unsigned int new_width, const unsigned int new_height); BGD_DECLARE(gdImagePtr) gdImageRotateInterpolated(const gdImagePtr src, const float angle, int bgcolor); typedef enum { GD_AFFINE_TRANSLATE = 0, GD_AFFINE_SCALE, GD_AFFINE_ROTATE, GD_AFFINE_SHEAR_HORIZONTAL, GD_AFFINE_SHEAR_VERTICAL } gdAffineStandardMatrix; BGD_DECLARE(int) gdAffineApplyToPointF (gdPointFPtr dst, const gdPointFPtr src, const double affine[6]); BGD_DECLARE(int) gdAffineInvert (double dst[6], const double src[6]); BGD_DECLARE(int) gdAffineFlip (double dst_affine[6], const double src_affine[6], const int flip_h, const int flip_v); BGD_DECLARE(int) gdAffineConcat (double dst[6], const double m1[6], const double m2[6]); BGD_DECLARE(int) gdAffineIdentity (double dst[6]); BGD_DECLARE(int) gdAffineScale (double dst[6], const double scale_x, const double scale_y); BGD_DECLARE(int) gdAffineRotate (double dst[6], const double angle); BGD_DECLARE(int) gdAffineShearHorizontal (double dst[6], const double angle); BGD_DECLARE(int) gdAffineShearVertical(double dst[6], const double angle); BGD_DECLARE(int) gdAffineTranslate (double dst[6], const double offset_x, const double offset_y); BGD_DECLARE(double) gdAffineExpansion (const double src[6]); BGD_DECLARE(int) gdAffineRectilinear (const double src[6]); BGD_DECLARE(int) gdAffineEqual (const double matrix1[6], const double matrix2[6]); BGD_DECLARE(int) gdTransformAffineGetImage(gdImagePtr *dst, const gdImagePtr src, gdRectPtr src_area, const double affine[6]); BGD_DECLARE(int) gdTransformAffineCopy(gdImagePtr dst, int dst_x, int dst_y, const gdImagePtr src, gdRectPtr src_region, const double affine[6]); /* gdTransformAffineCopy(gdImagePtr dst, int x0, int y0, int x1, int y1, const gdImagePtr src, int src_width, int src_height, const double affine[6]); */ BGD_DECLARE(int) gdTransformAffineBoundingBox(gdRectPtr src, const double affine[6], gdRectPtr bbox); #define GD_CMP_IMAGE 1 /* Actual image IS different */ #define GD_CMP_NUM_COLORS 2 /* Number of Colours in pallette differ */ #define GD_CMP_COLOR 4 /* Image colours differ */ #define GD_CMP_SIZE_X 8 /* Image width differs */ #define GD_CMP_SIZE_Y 16 /* Image heights differ */ #define GD_CMP_TRANSPARENT 32 /* Transparent colour */ #define GD_CMP_BACKGROUND 64 /* Background colour */ #define GD_CMP_INTERLACE 128 /* Interlaced setting */ #define GD_CMP_TRUECOLOR 256 /* Truecolor vs palette differs */ /* resolution affects ttf font rendering, particularly hinting */ #define GD_RESOLUTION 96 /* pixels per inch */ /* Version information functions */ BGD_DECLARE(int) gdMajorVersion(void); BGD_DECLARE(int) gdMinorVersion(void); BGD_DECLARE(int) gdReleaseVersion(void); BGD_DECLARE(const char *) gdExtraVersion(void); BGD_DECLARE(const char *) gdVersionString(void); #ifdef __cplusplus } #endif /* newfangled special effects */ #include "gdfx.h" #endif /* GD_H */ #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/gd2copypal.c000066400000000000000000000024031245535672000161730ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include "gd.h" /* A short program which converts a .png file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ int main (int argc, char **argv) { gdImagePtr im; gdImagePtr pal; FILE *in, *out; if (argc != 3) { fprintf(stderr, "Usage: gd2copypal palettefile.gd2 filename.gd2\n"); exit (1); } in = fopen (argv[1], "rb"); if (!in) { fprintf(stderr, "Palette file does not exist!\n"); exit (1); } pal = gdImageCreateFromGd2 (in); fclose (in); if (!pal) { fprintf(stderr, "Palette is not in GD2 format!\n"); exit (1); } in = fopen (argv[2], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit (1); } im = gdImageCreateFromGd2 (in); fclose (in); if (!im) { fprintf(stderr, "Input is not in GD2 format!\n"); exit (1); } gdImagePaletteCopy (im, pal); out = fopen (argv[2], "wb"); if (!out) { fprintf(stderr, "Output file cannot be written to!\n"); gdImageDestroy (im); exit (1); } gdImageGd2 (im, out, 128, 2); fclose (out); gdImageDestroy (pal); gdImageDestroy (im); return 0; } libgd-gd-2.1.1/src/gd2time.c000066400000000000000000000023071245535672000154650ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include /* for atoi */ #include /* For time */ #include "gd.h" /* A short program which converts a .png file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ int main (int argc, char **argv) { gdImagePtr im; FILE *in; int x, y, w, h; int c; int i; int t0; if (argc != 7) { fprintf(stderr, "Usage: gd2time filename.gd count x y w h\n"); exit (1); } c = atoi (argv[2]); x = atoi (argv[3]); y = atoi (argv[4]); w = atoi (argv[5]); h = atoi (argv[6]); printf ("Extracting %d times from (%d, %d), size is %dx%d\n", c, x, y, w, h); t0 = time (0); for (i = 0; i < c; i++) { in = fopen (argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit (1); } im = gdImageCreateFromGd2Part (in, x, y, w, h); fclose (in); if (!im) { fprintf(stderr, "Error reading source file!\n"); exit (1); } gdImageDestroy (im); }; t0 = time (0) - t0; printf ("%d seconds to extract (& destroy) %d times\n", t0, c); return 0; } libgd-gd-2.1.1/src/gd2togif.c000066400000000000000000000016531245535672000156420ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include "gd.h" /* A short program which converts a .gif file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ int main(int argc, char **argv) { gdImagePtr im; FILE *in, *out; if (argc != 3) { fprintf(stderr, "Usage: gd2togif filename.gd2 filename.gif\n"); exit(1); } in = fopen(argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit(1); } im = gdImageCreateFromGd2(in); fclose(in); if (!im) { fprintf(stderr, "Input is not in GD2 format!\n"); exit(1); } out = fopen(argv[2], "wb"); if (!out) { fprintf(stderr, "Output file cannot be written to!\n"); gdImageDestroy(im); exit(1); } gdImageGif(im, out); fclose(out); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/src/gd2topng.c000066400000000000000000000026101245535672000156530ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include "gd.h" /* A short program which converts a .png file into a .gd2 file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd2 format is not intended to be a general-purpose format. */ int main (int argc, char **argv) { gdImagePtr im; FILE *in, *out; int x=0, y=0, w=0, h=0; if ((argc != 3) && (argc != 7)) { fprintf (stderr, "Usage: gd2topng filename.gd2 filename.png [srcx srcy width height]\n"); fprintf (stderr, "If the coordinates are absent,t he entire image is converted.\n"); exit (1); } if (argc == 7) { x = atoi (argv[3]); y = atoi (argv[4]); w = atoi (argv[5]); h = atoi (argv[6]); } in = fopen (argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit (1); } if (argc == 7) { im = gdImageCreateFromGd2Part (in, x, y, w, h); } else { im = gdImageCreateFromGd2 (in); } fclose (in); if (!im) { fprintf(stderr, "Input is not in GD2 format!\n"); exit (1); } out = fopen (argv[2], "wb"); if (!out) { fprintf(stderr, "Output file cannot be written to!\n"); gdImageDestroy (im); exit (1); } #ifdef HAVE_LIBPNG gdImagePng (im, out); #else fprintf(stderr, "No PNG library support available.\n"); #endif fclose (out); gdImageDestroy (im); return 0; } libgd-gd-2.1.1/src/gd_bmp.c000066400000000000000000000632401245535672000153650ustar00rootroot00000000000000/* gd_bmp.c Bitmap format support for libgd * Written 2007, Scott MacVicar --------------------------------------------------------------------------- Todo: Bitfield encoding ---------------------------------------------------------------------------- */ /* $Id$ */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include #include "gd.h" #include "gdhelpers.h" #include "bmp.h" static int compress_row(unsigned char *uncompressed_row, int length); static int build_rle_packet(unsigned char *row, int packet_type, int length, unsigned char *data); static int bmp_read_header(gdIOCtxPtr infile, bmp_hdr_t *hdr); static int bmp_read_info(gdIOCtxPtr infile, bmp_info_t *info); static int bmp_read_windows_v3_info(gdIOCtxPtr infile, bmp_info_t *info); static int bmp_read_os2_v1_info(gdIOCtxPtr infile, bmp_info_t *info); static int bmp_read_os2_v2_info(gdIOCtxPtr infile, bmp_info_t *info); static int bmp_read_direct(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header); static int bmp_read_1bit(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header); static int bmp_read_4bit(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header); static int bmp_read_8bit(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header); static int bmp_read_rle(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info); #define BMP_DEBUG(s) static int gdBMPPutWord(gdIOCtx *out, int w) { /* Byte order is little-endian */ gdPutC(w & 0xFF, out); gdPutC((w >> 8) & 0xFF, out); return 0; } static int gdBMPPutInt(gdIOCtx *out, int w) { /* Byte order is little-endian */ gdPutC(w & 0xFF, out); gdPutC((w >> 8) & 0xFF, out); gdPutC((w >> 16) & 0xFF, out); gdPutC((w >> 24) & 0xFF, out); return 0; } BGD_DECLARE(void *) gdImageBmpPtr(gdImagePtr im, int *size, int compression) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); if (out == NULL) return NULL; gdImageBmpCtx(im, out, compression); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } BGD_DECLARE(void) gdImageBmp(gdImagePtr im, FILE *outFile, int compression) { gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageBmpCtx(im, out, compression); out->gd_free(out); } BGD_DECLARE(void) gdImageBmpCtx(gdImagePtr im, gdIOCtxPtr out, int compression) { int bitmap_size = 0, info_size, total_size, padding; int i, row, xpos, pixel; int error = 0; unsigned char *uncompressed_row = NULL, *uncompressed_row_start = NULL; FILE *tmpfile_for_compression = NULL; gdIOCtxPtr out_original = NULL; /* No compression if its true colour or we don't support seek */ if (im->trueColor) { compression = 0; } if (compression == 1 && !out->seek) { /* Try to create a temp file where we can seek */ if ((tmpfile_for_compression = tmpfile()) == NULL) { compression = 0; } else { out_original = out; if ((out = (gdIOCtxPtr)gdNewFileCtx(tmpfile_for_compression)) == NULL) { out = out_original; out_original = NULL; compression = 0; } } } bitmap_size = ((im->sx * (im->trueColor ? 24 : 8)) / 8) * im->sy; /* 40 byte Windows v3 header */ info_size = BMP_WINDOWS_V3; /* data for the palette */ if (!im->trueColor) { info_size += im->colorsTotal * 4; if (compression) { bitmap_size = 0; } } /* bitmap header + info header + data */ total_size = 14 + info_size + bitmap_size; /* write bmp header info */ gdPutBuf("BM", 2, out); gdBMPPutInt(out, total_size); gdBMPPutWord(out, 0); gdBMPPutWord(out, 0); gdBMPPutInt(out, 14 + info_size); /* write Windows v3 headers */ gdBMPPutInt(out, BMP_WINDOWS_V3); /* header size */ gdBMPPutInt(out, im->sx); /* width */ gdBMPPutInt(out, im->sy); /* height */ gdBMPPutWord(out, 1); /* colour planes */ gdBMPPutWord(out, (im->trueColor ? 24 : 8)); /* bit count */ gdBMPPutInt(out, (compression ? BMP_BI_RLE8 : BMP_BI_RGB)); /* compression */ gdBMPPutInt(out, bitmap_size); /* image size */ gdBMPPutInt(out, 0); /* H resolution */ gdBMPPutInt(out, 0); /* V ressolution */ gdBMPPutInt(out, im->colorsTotal); /* colours used */ gdBMPPutInt(out, 0); /* important colours */ /* The line must be divisible by 4, else its padded with NULLs */ padding = ((int)(im->trueColor ? 3 : 1) * im->sx) % 4; if (padding) { padding = 4 - padding; } /* 8-bit colours */ if (!im->trueColor) { for(i = 0; i< im->colorsTotal; ++i) { Putchar(gdImageBlue(im, i), out); Putchar(gdImageGreen(im, i), out); Putchar(gdImageRed(im, i), out); Putchar(0, out); } if (compression) { /* Can potentially change this to X + ((X / 128) * 3) */ uncompressed_row = uncompressed_row_start = (unsigned char *) gdCalloc(gdImageSX(im) * 2, sizeof(char)); if (!uncompressed_row) { /* malloc failed */ goto cleanup; } } for (row = (im->sy - 1); row >= 0; row--) { if (compression) { memset (uncompressed_row, 0, gdImageSX(im)); } for (xpos = 0; xpos < im->sx; xpos++) { if (compression) { *uncompressed_row++ = (unsigned char)gdImageGetPixel(im, xpos, row); } else { Putchar(gdImageGetPixel(im, xpos, row), out); } } if (!compression) { /* Add padding to make sure we have n mod 4 == 0 bytes per row */ for (xpos = padding; xpos > 0; --xpos) { Putchar('\0', out); } } else { int compressed_size = 0; uncompressed_row = uncompressed_row_start; if ((compressed_size = compress_row(uncompressed_row, gdImageSX(im))) < 0) { error = 1; break; } bitmap_size += compressed_size; gdPutBuf(uncompressed_row, compressed_size, out); Putchar(BMP_RLE_COMMAND, out); Putchar(BMP_RLE_ENDOFLINE, out); bitmap_size += 2; } } if (compression && uncompressed_row) { gdFree(uncompressed_row); if (error != 0) { goto cleanup; } /* Update filesize based on new values and set compression flag */ Putchar(BMP_RLE_COMMAND, out); Putchar(BMP_RLE_ENDOFBITMAP, out); bitmap_size += 2; /* Write new total bitmap size */ gdSeek(out, 2); gdBMPPutInt(out, total_size + bitmap_size); /* Total length of image data */ gdSeek(out, 34); gdBMPPutInt(out, bitmap_size); } } else { for (row = (im->sy - 1); row >= 0; row--) { for (xpos = 0; xpos < im->sx; xpos++) { pixel = gdImageGetPixel(im, xpos, row); Putchar(gdTrueColorGetBlue(pixel), out); Putchar(gdTrueColorGetGreen(pixel), out); Putchar(gdTrueColorGetRed(pixel), out); } /* Add padding to make sure we have n mod 4 == 0 bytes per row */ for (xpos = padding; xpos > 0; --xpos) { Putchar('\0', out); } } } /* If we needed a tmpfile for compression copy it over to out_original */ if (tmpfile_for_compression) { unsigned char* copy_buffer = NULL; int buffer_size = 0; gdSeek(out, 0); copy_buffer = (unsigned char *) gdMalloc(1024 * sizeof(unsigned char)); if (copy_buffer == NULL) { goto cleanup; } while ((buffer_size = gdGetBuf(copy_buffer, 1024, out)) != EOF) { if (buffer_size == 0) { break; } gdPutBuf(copy_buffer , buffer_size, out_original); } gdFree(copy_buffer); /* Replace the temp with the original which now has data */ out->gd_free(out); out = out_original; out_original = NULL; } cleanup: if (tmpfile_for_compression) { #ifdef _WIN32 _rmtmp(); #else fclose(tmpfile_for_compression); #endif tmpfile_for_compression = NULL; } if (out_original) { out_original->gd_free(out_original); } return; } static int compress_row(unsigned char *row, int length) { int rle_type = 0; int compressed_length = 0; int pixel = 0, compressed_run = 0, rle_compression = 0; unsigned char *uncompressed_row = NULL, *uncompressed_rowp = NULL, *uncompressed_start = NULL; uncompressed_row = (unsigned char *) gdMalloc(length); if (!uncompressed_row) { return -1; } memcpy(uncompressed_row, row, length); uncompressed_start = uncompressed_rowp = uncompressed_row; for (pixel = 0; pixel < length; pixel++) { if (compressed_run == 0) { uncompressed_row = uncompressed_rowp; compressed_run++; uncompressed_rowp++; rle_type = BMP_RLE_TYPE_RAW; continue; } if (compressed_run == 1) { /* Compare next byte */ if (memcmp(uncompressed_rowp, uncompressed_rowp - 1, 1) == 0) { rle_type = BMP_RLE_TYPE_RLE; } } if (rle_type == BMP_RLE_TYPE_RLE) { if (compressed_run >= 128 || memcmp(uncompressed_rowp, uncompressed_rowp - 1, 1) != 0) { /* more than what we can store in a single run or run is over due to non match, force write */ rle_compression = build_rle_packet(row, rle_type, compressed_run, uncompressed_row); row += rle_compression; compressed_length += rle_compression; compressed_run = 0; pixel--; } else { compressed_run++; uncompressed_rowp++; } } else { if (compressed_run >= 128 || memcmp(uncompressed_rowp, uncompressed_rowp - 1, 1) == 0) { /* more than what we can store in a single run or run is over due to match, force write */ rle_compression = build_rle_packet(row, rle_type, compressed_run, uncompressed_row); row += rle_compression; compressed_length += rle_compression; compressed_run = 0; pixel--; } else { /* add this pixel to the row */ compressed_run++; uncompressed_rowp++; } } } if (compressed_run) { if (rle_type == BMP_RLE_TYPE_RLE) { compressed_length += build_rle_packet(row, rle_type, compressed_run, uncompressed_row); } else { compressed_length += build_rle_packet(row, rle_type, compressed_run, uncompressed_row); } } gdFree(uncompressed_start); return compressed_length; } static int build_rle_packet(unsigned char *row, int packet_type, int length, unsigned char *data) { int compressed_size = 0; if (length < 1 || length > 128) { return 0; } /* Bitmap specific cases is that we can't have uncompressed rows of length 1 or 2 */ if (packet_type == BMP_RLE_TYPE_RAW && length < 3) { int i = 0; for (i = 0; i < length; i++) { compressed_size += 2; memset(row, 1, 1); row++; memcpy(row, data++, 1); row++; } } else if (packet_type == BMP_RLE_TYPE_RLE) { compressed_size = 2; memset(row, length, 1); row++; memcpy(row, data, 1); row++; } else { compressed_size = 2 + length; memset(row, BMP_RLE_COMMAND, 1); row++; memset(row, length, 1); row++; memcpy(row, data, length); row += length; /* Must be an even number for an uncompressed run */ if (length % 2) { memset(row, 0, 1); row++; compressed_size++; } } return compressed_size; } BGD_DECLARE(gdImagePtr) gdImageCreateFromBmp(FILE * inFile) { gdImagePtr im = 0; gdIOCtx *in = gdNewFileCtx(inFile); if (in == NULL) return NULL; im = gdImageCreateFromBmpCtx(in); in->gd_free(in); return im; } BGD_DECLARE(gdImagePtr) gdImageCreateFromBmpPtr(int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx(size, data, 0); if (in == NULL) return NULL; im = gdImageCreateFromBmpCtx(in); in->gd_free(in); return im; } BGD_DECLARE(gdImagePtr) gdImageCreateFromBmpCtx(gdIOCtxPtr infile) { bmp_hdr_t *hdr; bmp_info_t *info; gdImagePtr im = NULL; int error = 0; if (!(hdr= (bmp_hdr_t *)gdCalloc(1, sizeof(bmp_hdr_t)))) { return NULL; } if (bmp_read_header(infile, hdr)) { gdFree(hdr); return NULL; } if (hdr->magic != 0x4d42) { gdFree(hdr); return NULL; } if (!(info = (bmp_info_t *)gdCalloc(1, sizeof(bmp_info_t)))) { gdFree(hdr); return NULL; } if (bmp_read_info(infile, info)) { gdFree(hdr); gdFree(info); return NULL; } BMP_DEBUG(printf("Numcolours: %d\n", info->numcolors)); BMP_DEBUG(printf("Width: %d\n", info->width)); BMP_DEBUG(printf("Height: %d\n", info->height)); BMP_DEBUG(printf("Planes: %d\n", info->numplanes)); BMP_DEBUG(printf("Depth: %d\n", info->depth)); BMP_DEBUG(printf("Offset: %d\n", hdr->off)); if (info->depth >= 16) { im = gdImageCreateTrueColor(info->width, info->height); } else { im = gdImageCreate(info->width, info->height); } if (!im) { gdFree(hdr); gdFree(info); return NULL; } switch (info->depth) { case 1: BMP_DEBUG(printf("1-bit image\n")); error = bmp_read_1bit(im, infile, info, hdr); break; case 4: BMP_DEBUG(printf("4-bit image\n")); error = bmp_read_4bit(im, infile, info, hdr); break; case 8: BMP_DEBUG(printf("8-bit image\n")); error = bmp_read_8bit(im, infile, info, hdr); break; case 16: case 24: case 32: BMP_DEBUG(printf("Direct BMP image\n")); error = bmp_read_direct(im, infile, info, hdr); break; default: BMP_DEBUG(printf("Unknown bit count\n")); error = 1; } gdFree(hdr); gdFree(info); if (error) { gdImageDestroy(im); return NULL; } return im; } static int bmp_read_header(gdIOCtx *infile, bmp_hdr_t *hdr) { if( !gdGetWordLSB(&hdr->magic, infile) || !gdGetIntLSB(&hdr->size, infile) || !gdGetWordLSB(&hdr->reserved1, infile) || !gdGetWordLSB(&hdr->reserved2 , infile) || !gdGetIntLSB(&hdr->off , infile) ) { return 1; } return 0; } static int bmp_read_info(gdIOCtx *infile, bmp_info_t *info) { /* read BMP length so we can work out the version */ if (!gdGetIntLSB(&info->len, infile)) { return 1; } switch (info->len) { /* For now treat Windows v4 + v5 as v3 */ case BMP_WINDOWS_V3: case BMP_WINDOWS_V4: case BMP_WINDOWS_V5: BMP_DEBUG(printf("Reading Windows Header\n")); if (bmp_read_windows_v3_info(infile, info)) { return 1; } break; case BMP_OS2_V1: if (bmp_read_os2_v1_info(infile, info)) { return 1; } break; case BMP_OS2_V2: if (bmp_read_os2_v2_info(infile, info)) { return 1; } break; default: BMP_DEBUG(printf("Unhandled bitmap\n")); return 1; } return 0; } static int bmp_read_windows_v3_info(gdIOCtxPtr infile, bmp_info_t *info) { if ( !gdGetIntLSB(&info->width, infile) || !gdGetIntLSB(&info->height, infile) || !gdGetWordLSB(&info->numplanes, infile) || !gdGetWordLSB(&info->depth, infile) || !gdGetIntLSB(&info->enctype, infile) || !gdGetIntLSB(&info->size, infile) || !gdGetIntLSB(&info->hres, infile) || !gdGetIntLSB(&info->vres, infile) || !gdGetIntLSB(&info->numcolors, infile) || !gdGetIntLSB(&info->mincolors, infile) ) { return 1; } if (info->height < 0) { info->topdown = 1; info->height = -info->height; } else { info->topdown = 0; } info->type = BMP_PALETTE_4; if (info->width <= 0 || info->height <= 0 || info->numplanes <= 0 || info->depth <= 0 || info->numcolors < 0 || info->mincolors < 0) { return 1; } return 0; } static int bmp_read_os2_v1_info(gdIOCtxPtr infile, bmp_info_t *info) { if ( !gdGetWordLSB((signed short int *)&info->width, infile) || !gdGetWordLSB((signed short int *)&info->height, infile) || !gdGetWordLSB(&info->numplanes, infile) || !gdGetWordLSB(&info->depth, infile) ) { return 1; } /* OS2 v1 doesn't support topdown */ info->topdown = 0; info->numcolors = 1 << info->depth; info->type = BMP_PALETTE_3; if (info->width <= 0 || info->height <= 0 || info->numplanes <= 0 || info->depth <= 0 || info->numcolors < 0) { return 1; } return 0; } static int bmp_read_os2_v2_info(gdIOCtxPtr infile, bmp_info_t *info) { char useless_bytes[24]; if ( !gdGetIntLSB(&info->width, infile) || !gdGetIntLSB(&info->height, infile) || !gdGetWordLSB(&info->numplanes, infile) || !gdGetWordLSB(&info->depth, infile) || !gdGetIntLSB(&info->enctype, infile) || !gdGetIntLSB(&info->size, infile) || !gdGetIntLSB(&info->hres, infile) || !gdGetIntLSB(&info->vres, infile) || !gdGetIntLSB(&info->numcolors, infile) || !gdGetIntLSB(&info->mincolors, infile) ) { return 1; } /* Lets seek the next 24 pointless bytes, we don't care too much about it */ if (!gdGetBuf(useless_bytes, 24, infile)) { return 1; } if (info->height < 0) { info->topdown = 1; info->height = -info->height; } else { info->topdown = 0; } info->type = BMP_PALETTE_4; if (info->width <= 0 || info->height <= 0 || info->numplanes <= 0 || info->depth <= 0 || info->numcolors < 0 || info->mincolors < 0) { return 1; } return 0; } static int bmp_read_direct(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header) { int ypos = 0, xpos = 0, row = 0; int padding = 0, alpha = 0, red = 0, green = 0, blue = 0; signed short int data = 0; switch(info->enctype) { case BMP_BI_RGB: /* no-op */ break; case BMP_BI_BITFIELDS: if (info->depth == 24) { BMP_DEBUG(printf("Bitfield compression isn't supported for 24-bit\n")); return 1; } BMP_DEBUG(printf("Currently no bitfield support\n")); return 1; break; case BMP_BI_RLE8: if (info->depth != 8) { BMP_DEBUG(printf("RLE is only valid for 8-bit images\n")); return 1; } case BMP_BI_RLE4: if (info->depth != 4) { BMP_DEBUG(printf("RLE is only valid for 4-bit images\n")); return 1; } case BMP_BI_JPEG: case BMP_BI_PNG: default: BMP_DEBUG(printf("Unsupported BMP compression format\n")); return 1; } /* There is a chance the data isn't until later, would be wierd but it is possible */ if (gdTell(infile) != header->off) { /* Should make sure we don't seek past the file size */ gdSeek(infile, header->off); } /* The line must be divisible by 4, else its padded with NULLs */ padding = ((int)(info->depth / 8) * info->width) % 4; if (padding) { padding = 4 - padding; } for (ypos = 0; ypos < info->height; ++ypos) { if (info->topdown) { row = ypos; } else { row = info->height - ypos - 1; } for (xpos = 0; xpos < info->width; xpos++) { if (info->depth == 16) { if (!gdGetWordLSB(&data, infile)) { return 1; } BMP_DEBUG(printf("Data: %X\n", data)); red = ((data & 0x7C00) >> 10) << 3; green = ((data & 0x3E0) >> 5) << 3; blue = (data & 0x1F) << 3; BMP_DEBUG(printf("R: %d, G: %d, B: %d\n", red, green, blue)); } else if (info->depth == 24) { if (!gdGetByte(&blue, infile) || !gdGetByte(&green, infile) || !gdGetByte(&red, infile)) { return 1; } } else { if (!gdGetByte(&blue, infile) || !gdGetByte(&green, infile) || !gdGetByte(&red, infile) || !gdGetByte(&alpha, infile)) { return 1; } } /*alpha = gdAlphaMax - (alpha >> 1);*/ gdImageSetPixel(im, xpos, row, gdTrueColor(red, green, blue)); } for (xpos = padding; xpos > 0; --xpos) { if (!gdGetByte(&red, infile)) { return 1; } } } return 0; } static int bmp_read_palette(gdImagePtr im, gdIOCtxPtr infile, int count, int read_four) { int i; int r, g, b, z; for (i = 0; i < count; i++) { if ( !gdGetByte(&b, infile) || !gdGetByte(&g, infile) || !gdGetByte(&r, infile) || (read_four && !gdGetByte(&z, infile)) ) { return 1; } im->red[i] = r; im->green[i] = g; im->blue[i] = b; im->open[i] = 1; } return 0; } static int bmp_read_1bit(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header) { int ypos = 0, xpos = 0, row = 0, index = 0; int padding = 0, current_byte = 0, bit = 0; if (info->enctype != BMP_BI_RGB) { return 1; } if (!info->numcolors) { info->numcolors = 2; } else if (info->numcolors < 0 || info->numcolors > 2) { return 1; } if (bmp_read_palette(im, infile, info->numcolors, (info->type == BMP_PALETTE_4))) { return 1; } im->colorsTotal = info->numcolors; /* There is a chance the data isn't until later, would be wierd but it is possible */ if (gdTell(infile) != header->off) { /* Should make sure we don't seek past the file size */ gdSeek(infile, header->off); } /* The line must be divisible by 4, else its padded with NULLs */ padding = ((int)ceill(0.1 * info->width)) % 4; if (padding) { padding = 4 - padding; } for (ypos = 0; ypos < info->height; ++ypos) { if (info->topdown) { row = ypos; } else { row = info->height - ypos - 1; } for (xpos = 0; xpos < info->width; xpos += 8) { /* Bitmaps are always aligned in bytes so we'll never overflow */ if (!gdGetByte(¤t_byte, infile)) { return 1; } for (bit = 0; bit < 8; bit++) { index = ((current_byte & (0x80 >> bit)) != 0 ? 0x01 : 0x00); if (im->open[index]) { im->open[index] = 0; } gdImageSetPixel(im, xpos + bit, row, index); /* No need to read anything extra */ if ((xpos + bit) >= info->width) { break; } } } for (xpos = padding; xpos > 0; --xpos) { if (!gdGetByte(&index, infile)) { return 1; } } } return 0; } static int bmp_read_4bit(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header) { int ypos = 0, xpos = 0, row = 0, index = 0; int padding = 0, current_byte = 0; if (info->enctype != BMP_BI_RGB && info->enctype != BMP_BI_RLE4) { return 1; } if (!info->numcolors) { info->numcolors = 16; } else if (info->numcolors < 0 || info->numcolors > 16) { return 1; } if (bmp_read_palette(im, infile, info->numcolors, (info->type == BMP_PALETTE_4))) { return 1; } im->colorsTotal = info->numcolors; /* There is a chance the data isn't until later, would be wierd but it is possible */ if (gdTell(infile) != header->off) { /* Should make sure we don't seek past the file size */ gdSeek(infile, header->off); } /* The line must be divisible by 4, else its padded with NULLs */ padding = ((int)ceil(0.5 * info->width)) % 4; if (padding) { padding = 4 - padding; } switch (info->enctype) { case BMP_BI_RGB: for (ypos = 0; ypos < info->height; ++ypos) { if (info->topdown) { row = ypos; } else { row = info->height - ypos - 1; } for (xpos = 0; xpos < info->width; xpos += 2) { if (!gdGetByte(¤t_byte, infile)) { return 1; } index = (current_byte >> 4) & 0x0f; if (im->open[index]) { im->open[index] = 0; } gdImageSetPixel(im, xpos, row, index); /* This condition may get called often, potential optimsations */ if (xpos >= info->width) { break; } index = current_byte & 0x0f; if (im->open[index]) { im->open[index] = 0; } gdImageSetPixel(im, xpos + 1, row, index); } for (xpos = padding; xpos > 0; --xpos) { if (!gdGetByte(&index, infile)) { return 1; } } } break; case BMP_BI_RLE4: if (bmp_read_rle(im, infile, info)) { return 1; } break; default: return 1; } return 0; } static int bmp_read_8bit(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info, bmp_hdr_t *header) { int ypos = 0, xpos = 0, row = 0, index = 0; int padding = 0; if (info->enctype != BMP_BI_RGB && info->enctype != BMP_BI_RLE8) { return 1; } if (!info->numcolors) { info->numcolors = 256; } else if (info->numcolors < 0 || info->numcolors > 256) { return 1; } if (bmp_read_palette(im, infile, info->numcolors, (info->type == BMP_PALETTE_4))) { return 1; } im->colorsTotal = info->numcolors; /* There is a chance the data isn't until later, would be wierd but it is possible */ if (gdTell(infile) != header->off) { /* Should make sure we don't seek past the file size */ gdSeek(infile, header->off); } /* The line must be divisible by 4, else its padded with NULLs */ padding = (1 * info->width) % 4; if (padding) { padding = 4 - padding; } switch (info->enctype) { case BMP_BI_RGB: for (ypos = 0; ypos < info->height; ++ypos) { if (info->topdown) { row = ypos; } else { row = info->height - ypos - 1; } for (xpos = 0; xpos < info->width; ++xpos) { if (!gdGetByte(&index, infile)) { return 1; } if (im->open[index]) { im->open[index] = 0; } gdImageSetPixel(im, xpos, row, index); } /* Could create a new variable, but it isn't really worth it */ for (xpos = padding; xpos > 0; --xpos) { if (!gdGetByte(&index, infile)) { return 1; } } } break; case BMP_BI_RLE8: if (bmp_read_rle(im, infile, info)) { return 1; } break; default: return 1; } return 0; } static int bmp_read_rle(gdImagePtr im, gdIOCtxPtr infile, bmp_info_t *info) { int ypos = 0, xpos = 0, row = 0, index = 0; int rle_length = 0, rle_data = 0; int padding = 0; int i = 0, j = 0; int pixels_per_byte = 8 / info->depth; for (ypos = 0; ypos < info->height && xpos <= info->width;) { if (!gdGetByte(&rle_length, infile) || !gdGetByte(&rle_data, infile)) { return 1; } row = info->height - ypos - 1; if (rle_length != BMP_RLE_COMMAND) { if (im->open[rle_data]) { im->open[rle_data] = 0; } for (i = 0; (i < rle_length) && (xpos < info->width);) { for (j = 1; (j <= pixels_per_byte) && (xpos < info->width) && (i < rle_length); j++, xpos++, i++) { index = (rle_data & (((1 << info->depth) - 1) << (8 - (j * info->depth)))) >> (8 - (j * info->depth)); if (im->open[index]) { im->open[index] = 0; } gdImageSetPixel(im, xpos, row, index); } } } else if (rle_length == BMP_RLE_COMMAND && rle_data > 2) { /* Uncompressed RLE needs to be even */ padding = 0; for (i = 0; (i < rle_data) && (xpos < info->width); i += pixels_per_byte) { int max_pixels = pixels_per_byte; if (!gdGetByte(&index, infile)) { return 1; } padding++; if (rle_data - i < max_pixels) { max_pixels = rle_data - i; } for (j = 1; (j <= max_pixels) && (xpos < info->width); j++, xpos++) { int temp = (index >> (8 - (j * info->depth))) & ((1 << info->depth) - 1); if (im->open[temp]) { im->open[temp] = 0; } gdImageSetPixel(im, xpos, row, temp); } } /* Make sure the bytes read are even */ if (padding % 2 && !gdGetByte(&index, infile)) { return 1; } } else if (rle_length == BMP_RLE_COMMAND && rle_data == BMP_RLE_ENDOFLINE) { /* Next Line */ xpos = 0; ypos++; } else if (rle_length == BMP_RLE_COMMAND && rle_data == BMP_RLE_DELTA) { /* Delta Record, used for bmp files that contain other data*/ if (!gdGetByte(&rle_length, infile) || !gdGetByte(&rle_data, infile)) { return 1; } xpos += rle_length; ypos += rle_data; } else if (rle_length == BMP_RLE_COMMAND && rle_data == BMP_RLE_ENDOFBITMAP) { /* End of bitmap */ break; } } return 0; } libgd-gd-2.1.1/src/gd_color.c000066400000000000000000000014361245535672000157240ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" #include "gd_color.h" int gdColorMatch(gdImagePtr im, int col1, int col2, float threshold) { const int dr = gdImageRed(im, col1) - gdImageRed(im, col2); const int dg = gdImageGreen(im, col1) - gdImageGreen(im, col2); const int db = gdImageBlue(im, col1) - gdImageBlue(im, col2); const int da = gdImageAlpha(im, col1) - gdImageAlpha(im, col2); const int dist = dr * dr + dg * dg + db * db + da * da; return (100.0 * dist / 195075) < threshold; } /* * To be implemented when we have more image formats. * Buffer like gray8 gray16 or rgb8 will require some tweak * and can be done in this function (called from the autocrop * function. (Pierre) */ #if 0 static int colors_equal (const int col1, const in col2) { } #endif libgd-gd-2.1.1/src/gd_color.h000066400000000000000000000002751245535672000157310ustar00rootroot00000000000000#ifndef GD_COLOR_H #define GD_COLOR_H 1 #ifdef __cplusplus extern "C" { #endif int gdColorMatch(gdImagePtr im, int col1, int col2, float threshold); #ifdef __cplusplus } #endif #endif libgd-gd-2.1.1/src/gd_color_map.c000066400000000000000000000552711245535672000165670ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include "gd.h" #include "gd_color_map.h" static const gdColorMapEntry GD_COLOR_MAP_X11_ENTRIES[] = { {"AliceBlue", 240, 248, 255}, {"AntiqueWhite", 250, 235, 215}, {"AntiqueWhite1", 255, 239, 219}, {"AntiqueWhite2", 238, 223, 204}, {"AntiqueWhite3", 205, 192, 176}, {"AntiqueWhite4", 139, 131, 120}, {"BlanchedAlmond", 255, 235, 205}, {"BlueViolet", 138, 43, 226}, {"CadetBlue", 95, 158, 160}, {"CadetBlue1", 152, 245, 255}, {"CadetBlue2", 142, 229, 238}, {"CadetBlue3", 122, 197, 205}, {"CadetBlue4", 83, 134, 139}, {"CornflowerBlue", 100, 149, 237}, {"DarkBlue", 0, 0, 139}, {"DarkCyan", 0, 139, 139}, {"DarkGoldenrod", 184, 134, 11}, {"DarkGoldenrod1", 255, 185, 15}, {"DarkGoldenrod2", 238, 173, 14}, {"DarkGoldenrod3", 205, 149, 12}, {"DarkGoldenrod4", 139, 101, 8}, {"DarkGray", 169, 169, 169}, {"DarkGreen", 0, 100, 0}, {"DarkGrey", 169, 169, 169}, {"DarkKhaki", 189, 183, 107}, {"DarkMagenta", 139, 0, 139}, {"DarkOliveGreen", 85, 107, 47}, {"DarkOliveGreen1", 202, 255, 112}, {"DarkOliveGreen2", 188, 238, 104}, {"DarkOliveGreen3", 162, 205, 90}, {"DarkOliveGreen4", 110, 139, 61}, {"DarkOrange", 255, 140, 0}, {"DarkOrange1", 255, 127, 0}, {"DarkOrange2", 238, 118, 0}, {"DarkOrange3", 205, 102, 0}, {"DarkOrange4", 139, 69, 0}, {"DarkOrchid", 153, 50, 204}, {"DarkOrchid1", 191, 62, 255}, {"DarkOrchid2", 178, 58, 238}, {"DarkOrchid3", 154, 50, 205}, {"DarkOrchid4", 104, 34, 139}, {"DarkRed", 139, 0, 0}, {"DarkSalmon", 233, 150, 122}, {"DarkSeaGreen", 143, 188, 143}, {"DarkSeaGreen1", 193, 255, 193}, {"DarkSeaGreen2", 180, 238, 180}, {"DarkSeaGreen3", 155, 205, 155}, {"DarkSeaGreen4", 105, 139, 105}, {"DarkSlateBlue", 72, 61, 139}, {"DarkSlateGray", 47, 79, 79}, {"DarkSlateGray1", 151, 255, 255}, {"DarkSlateGray2", 141, 238, 238}, {"DarkSlateGray3", 121, 205, 205}, {"DarkSlateGray4", 82, 139, 139}, {"DarkSlateGrey", 47, 79, 79}, {"DarkTurquoise", 0, 206, 209}, {"DarkViolet", 148, 0, 211}, {"DeepPink", 255, 20, 147}, {"DeepPink1", 255, 20, 147}, {"DeepPink2", 238, 18, 137}, {"DeepPink3", 205, 16, 118}, {"DeepPink4", 139, 10, 80}, {"DeepSkyBlue", 0, 191, 255}, {"DeepSkyBlue1", 0, 191, 255}, {"DeepSkyBlue2", 0, 178, 238}, {"DeepSkyBlue3", 0, 154, 205}, {"DeepSkyBlue4", 0, 104, 139}, {"DimGray", 105, 105, 105}, {"DimGrey", 105, 105, 105}, {"DodgerBlue", 30, 144, 255}, {"DodgerBlue1", 30, 144, 255}, {"DodgerBlue2", 28, 134, 238}, {"DodgerBlue3", 24, 116, 205}, {"DodgerBlue4", 16, 78, 139}, {"FloralWhite", 255, 250, 240}, {"ForestGreen", 34, 139, 34}, {"GhostWhite", 248, 248, 255}, {"GreenYellow", 173, 255, 47}, {"HotPink", 255, 105, 180}, {"HotPink1", 255, 110, 180}, {"HotPink2", 238, 106, 167}, {"HotPink3", 205, 96, 144}, {"HotPink4", 139, 58, 98}, {"IndianRed", 205, 92, 92}, {"IndianRed1", 255, 106, 106}, {"IndianRed2", 238, 99, 99}, {"IndianRed3", 205, 85, 85}, {"IndianRed4", 139, 58, 58}, {"LavenderBlush", 255, 240, 245}, {"LavenderBlush1", 255, 240, 245}, {"LavenderBlush2", 238, 224, 229}, {"LavenderBlush3", 205, 193, 197}, {"LavenderBlush4", 139, 131, 134}, {"LawnGreen", 124, 252, 0}, {"LemonChiffon", 255, 250, 205}, {"LemonChiffon1", 255, 250, 205}, {"LemonChiffon2", 238, 233, 191}, {"LemonChiffon3", 205, 201, 165}, {"LemonChiffon4", 139, 137, 112}, {"LightBlue", 173, 216, 230}, {"LightBlue1", 191, 239, 255}, {"LightBlue2", 178, 223, 238}, {"LightBlue3", 154, 192, 205}, {"LightBlue4", 104, 131, 139}, {"LightCoral", 240, 128, 128}, {"LightCyan", 224, 255, 255}, {"LightCyan1", 224, 255, 255}, {"LightCyan2", 209, 238, 238}, {"LightCyan3", 180, 205, 205}, {"LightCyan4", 122, 139, 139}, {"LightGoldenrod", 238, 221, 130}, {"LightGoldenrod1", 255, 236, 139}, {"LightGoldenrod2", 238, 220, 130}, {"LightGoldenrod3", 205, 190, 112}, {"LightGoldenrod4", 139, 129, 76}, {"LightGoldenrodYellow", 250, 250, 210}, {"LightGray", 211, 211, 211}, {"LightGreen", 144, 238, 144}, {"LightGrey", 211, 211, 211}, {"LightPink", 255, 182, 193}, {"LightPink1", 255, 174, 185}, {"LightPink2", 238, 162, 173}, {"LightPink3", 205, 140, 149}, {"LightPink4", 139, 95, 101}, {"LightSalmon", 255, 160, 122}, {"LightSalmon1", 255, 160, 122}, {"LightSalmon2", 238, 149, 114}, {"LightSalmon3", 205, 129, 98}, {"LightSalmon4", 139, 87, 66}, {"LightSeaGreen", 32, 178, 170}, {"LightSkyBlue", 135, 206, 250}, {"LightSkyBlue1", 176, 226, 255}, {"LightSkyBlue2", 164, 211, 238}, {"LightSkyBlue3", 141, 182, 205}, {"LightSkyBlue4", 96, 123, 139}, {"LightSlateBlue", 132, 112, 255}, {"LightSlateGray", 119, 136, 153}, {"LightSlateGrey", 119, 136, 153}, {"LightSteelBlue", 176, 196, 222}, {"LightSteelBlue1", 202, 225, 255}, {"LightSteelBlue2", 188, 210, 238}, {"LightSteelBlue3", 162, 181, 205}, {"LightSteelBlue4", 110, 123, 139}, {"LightYellow", 255, 255, 224}, {"LightYellow1", 255, 255, 224}, {"LightYellow2", 238, 238, 209}, {"LightYellow3", 205, 205, 180}, {"LightYellow4", 139, 139, 122}, {"LimeGreen", 50, 205, 50}, {"MediumAquamarine", 102, 205, 170}, {"MediumBlue", 0, 0, 205}, {"MediumOrchid", 186, 85, 211}, {"MediumOrchid1", 224, 102, 255}, {"MediumOrchid2", 209, 95, 238}, {"MediumOrchid3", 180, 82, 205}, {"MediumOrchid4", 122, 55, 139}, {"MediumPurple", 147, 112, 219}, {"MediumPurple1", 171, 130, 255}, {"MediumPurple2", 159, 121, 238}, {"MediumPurple3", 137, 104, 205}, {"MediumPurple4", 93, 71, 139}, {"MediumSeaGreen", 60, 179, 113}, {"MediumSlateBlue", 123, 104, 238}, {"MediumSpringGreen", 0, 250, 154}, {"MediumTurquoise", 72, 209, 204}, {"MediumVioletRed", 199, 21, 133}, {"MidnightBlue", 25, 25, 112}, {"MintCream", 245, 255, 250}, {"MistyRose", 255, 228, 225}, {"MistyRose1", 255, 228, 225}, {"MistyRose2", 238, 213, 210}, {"MistyRose3", 205, 183, 181}, {"MistyRose4", 139, 125, 123}, {"NavajoWhite", 255, 222, 173}, {"NavajoWhite1", 255, 222, 173}, {"NavajoWhite2", 238, 207, 161}, {"NavajoWhite3", 205, 179, 139}, {"NavajoWhite4", 139, 121, 94}, {"NavyBlue", 0, 0, 128}, {"OldLace", 253, 245, 230}, {"OliveDrab", 107, 142, 35}, {"OliveDrab1", 192, 255, 62}, {"OliveDrab2", 179, 238, 58}, {"OliveDrab3", 154, 205, 50}, {"OliveDrab4", 105, 139, 34}, {"OrangeRed", 255, 69, 0}, {"OrangeRed1", 255, 69, 0}, {"OrangeRed2", 238, 64, 0}, {"OrangeRed3", 205, 55, 0}, {"OrangeRed4", 139, 37, 0}, {"PaleGoldenrod", 238, 232, 170}, {"PaleGreen", 152, 251, 152}, {"PaleGreen1", 154, 255, 154}, {"PaleGreen2", 144, 238, 144}, {"PaleGreen3", 124, 205, 124}, {"PaleGreen4", 84, 139, 84}, {"PaleTurquoise", 175, 238, 238}, {"PaleTurquoise1", 187, 255, 255}, {"PaleTurquoise2", 174, 238, 238}, {"PaleTurquoise3", 150, 205, 205}, {"PaleTurquoise4", 102, 139, 139}, {"PaleVioletRed", 219, 112, 147}, {"PaleVioletRed1", 255, 130, 171}, {"PaleVioletRed2", 238, 121, 159}, {"PaleVioletRed3", 205, 104, 137}, {"PaleVioletRed4", 139, 71, 93}, {"PapayaWhip", 255, 239, 213}, {"PeachPuff", 255, 218, 185}, {"PeachPuff1", 255, 218, 185}, {"PeachPuff2", 238, 203, 173}, {"PeachPuff3", 205, 175, 149}, {"PeachPuff4", 139, 119, 101}, {"PowderBlue", 176, 224, 230}, {"RosyBrown", 188, 143, 143}, {"RosyBrown1", 255, 193, 193}, {"RosyBrown2", 238, 180, 180}, {"RosyBrown3", 205, 155, 155}, {"RosyBrown4", 139, 105, 105}, {"RoyalBlue", 65, 105, 225}, {"RoyalBlue1", 72, 118, 255}, {"RoyalBlue2", 67, 110, 238}, {"RoyalBlue3", 58, 95, 205}, {"RoyalBlue4", 39, 64, 139}, {"SaddleBrown", 139, 69, 19}, {"SandyBrown", 244, 164, 96}, {"SeaGreen", 46, 139, 87}, {"SeaGreen1", 84, 255, 159}, {"SeaGreen2", 78, 238, 148}, {"SeaGreen3", 67, 205, 128}, {"SeaGreen4", 46, 139, 87}, {"SkyBlue", 135, 206, 235}, {"SkyBlue1", 135, 206, 255}, {"SkyBlue2", 126, 192, 238}, {"SkyBlue3", 108, 166, 205}, {"SkyBlue4", 74, 112, 139}, {"SlateBlue", 106, 90, 205}, {"SlateBlue1", 131, 111, 255}, {"SlateBlue2", 122, 103, 238}, {"SlateBlue3", 105, 89, 205}, {"SlateBlue4", 71, 60, 139}, {"SlateGray", 112, 128, 144}, {"SlateGray1", 198, 226, 255}, {"SlateGray2", 185, 211, 238}, {"SlateGray3", 159, 182, 205}, {"SlateGray4", 108, 123, 139}, {"SlateGrey", 112, 128, 144}, {"SpringGreen", 0, 255, 127}, {"SpringGreen1", 0, 255, 127}, {"SpringGreen2", 0, 238, 118}, {"SpringGreen3", 0, 205, 102}, {"SpringGreen4", 0, 139, 69}, {"SteelBlue", 70, 130, 180}, {"SteelBlue1", 99, 184, 255}, {"SteelBlue2", 92, 172, 238}, {"SteelBlue3", 79, 148, 205}, {"SteelBlue4", 54, 100, 139}, {"VioletRed", 208, 32, 144}, {"VioletRed1", 255, 62, 150}, {"VioletRed2", 238, 58, 140}, {"VioletRed3", 205, 50, 120}, {"VioletRed4", 139, 34, 82}, {"WhiteSmoke", 245, 245, 245}, {"YellowGreen", 154, 205, 50}, {"alice blue", 240, 248, 255}, {"antique white", 250, 235, 215}, {"aquamarine", 127, 255, 212}, {"aquamarine1", 127, 255, 212}, {"aquamarine2", 118, 238, 198}, {"aquamarine3", 102, 205, 170}, {"aquamarine4", 69, 139, 116}, {"azure", 240, 255, 255}, {"azure1", 240, 255, 255}, {"azure2", 224, 238, 238}, {"azure3", 193, 205, 205}, {"azure4", 131, 139, 139}, {"beige", 245, 245, 220}, {"bisque", 255, 228, 196}, {"bisque1", 255, 228, 196}, {"bisque2", 238, 213, 183}, {"bisque3", 205, 183, 158}, {"bisque4", 139, 125, 107}, {"black", 0, 0, 0}, {"blanched almond", 255, 235, 205}, {"blue", 0, 0, 255}, {"blue violet", 138, 43, 226}, {"blue1", 0, 0, 255}, {"blue2", 0, 0, 238}, {"blue3", 0, 0, 205}, {"blue4", 0, 0, 139}, {"brown", 165, 42, 42}, {"brown1", 255, 64, 64}, {"brown2", 238, 59, 59}, {"brown3", 205, 51, 51}, {"brown4", 139, 35, 35}, {"burlywood", 222, 184, 135}, {"burlywood1", 255, 211, 155}, {"burlywood2", 238, 197, 145}, {"burlywood3", 205, 170, 125}, {"burlywood4", 139, 115, 85}, {"cadet blue", 95, 158, 160}, {"chartreuse", 127, 255, 0}, {"chartreuse1", 127, 255, 0}, {"chartreuse2", 118, 238, 0}, {"chartreuse3", 102, 205, 0}, {"chartreuse4", 69, 139, 0}, {"chocolate", 210, 105, 30}, {"chocolate1", 255, 127, 36}, {"chocolate2", 238, 118, 33}, {"chocolate3", 205, 102, 29}, {"chocolate4", 139, 69, 19}, {"coral", 255, 127, 80}, {"coral1", 255, 114, 86}, {"coral2", 238, 106, 80}, {"coral3", 205, 91, 69}, {"coral4", 139, 62, 47}, {"cornflower blue", 100, 149, 237}, {"cornsilk", 255, 248, 220}, {"cornsilk1", 255, 248, 220}, {"cornsilk2", 238, 232, 205}, {"cornsilk3", 205, 200, 177}, {"cornsilk4", 139, 136, 120}, {"cyan", 0, 255, 255}, {"cyan1", 0, 255, 255}, {"cyan2", 0, 238, 238}, {"cyan3", 0, 205, 205}, {"cyan4", 0, 139, 139}, {"dark blue", 0, 0, 139}, {"dark cyan", 0, 139, 139}, {"dark goldenrod", 184, 134, 11}, {"dark gray", 169, 169, 169}, {"dark green", 0, 100, 0}, {"dark grey", 169, 169, 169}, {"dark khaki", 189, 183, 107}, {"dark magenta", 139, 0, 139}, {"dark olive green", 85, 107, 47}, {"dark orange", 255, 140, 0}, {"dark orchid", 153, 50, 204}, {"dark red", 139, 0, 0}, {"dark salmon", 233, 150, 122}, {"dark sea green", 143, 188, 143}, {"dark slate blue", 72, 61, 139}, {"dark slate gray", 47, 79, 79}, {"dark slate grey", 47, 79, 79}, {"dark turquoise", 0, 206, 209}, {"dark violet", 148, 0, 211}, {"deep pink", 255, 20, 147}, {"deep sky blue", 0, 191, 255}, {"dim gray", 105, 105, 105}, {"dim grey", 105, 105, 105}, {"dodger blue", 30, 144, 255}, {"firebrick", 178, 34, 34}, {"firebrick1", 255, 48, 48}, {"firebrick2", 238, 44, 44}, {"firebrick3", 205, 38, 38}, {"firebrick4", 139, 26, 26}, {"floral white", 255, 250, 240}, {"forest green", 34, 139, 34}, {"gainsboro", 220, 220, 220}, {"ghost white", 248, 248, 255}, {"gold", 255, 215, 0}, {"gold1", 255, 215, 0}, {"gold2", 238, 201, 0}, {"gold3", 205, 173, 0}, {"gold4", 139, 117, 0}, {"goldenrod", 218, 165, 32}, {"goldenrod1", 255, 193, 37}, {"goldenrod2", 238, 180, 34}, {"goldenrod3", 205, 155, 29}, {"goldenrod4", 139, 105, 20}, {"gray", 190, 190, 190}, {"gray0", 0, 0, 0}, {"gray1", 3, 3, 3}, {"gray10", 26, 26, 26}, {"gray100", 255, 255, 255}, {"gray11", 28, 28, 28}, {"gray12", 31, 31, 31}, {"gray13", 33, 33, 33}, {"gray14", 36, 36, 36}, {"gray15", 38, 38, 38}, {"gray16", 41, 41, 41}, {"gray17", 43, 43, 43}, {"gray18", 46, 46, 46}, {"gray19", 48, 48, 48}, {"gray2", 5, 5, 5}, {"gray20", 51, 51, 51}, {"gray21", 54, 54, 54}, {"gray22", 56, 56, 56}, {"gray23", 59, 59, 59}, {"gray24", 61, 61, 61}, {"gray25", 64, 64, 64}, {"gray26", 66, 66, 66}, {"gray27", 69, 69, 69}, {"gray28", 71, 71, 71}, {"gray29", 74, 74, 74}, {"gray3", 8, 8, 8}, {"gray30", 77, 77, 77}, {"gray31", 79, 79, 79}, {"gray32", 82, 82, 82}, {"gray33", 84, 84, 84}, {"gray34", 87, 87, 87}, {"gray35", 89, 89, 89}, {"gray36", 92, 92, 92}, {"gray37", 94, 94, 94}, {"gray38", 97, 97, 97}, {"gray39", 99, 99, 99}, {"gray4", 10, 10, 10}, {"gray40", 102, 102, 102}, {"gray41", 105, 105, 105}, {"gray42", 107, 107, 107}, {"gray43", 110, 110, 110}, {"gray44", 112, 112, 112}, {"gray45", 115, 115, 115}, {"gray46", 117, 117, 117}, {"gray47", 120, 120, 120}, {"gray48", 122, 122, 122}, {"gray49", 125, 125, 125}, {"gray5", 13, 13, 13}, {"gray50", 127, 127, 127}, {"gray51", 130, 130, 130}, {"gray52", 133, 133, 133}, {"gray53", 135, 135, 135}, {"gray54", 138, 138, 138}, {"gray55", 140, 140, 140}, {"gray56", 143, 143, 143}, {"gray57", 145, 145, 145}, {"gray58", 148, 148, 148}, {"gray59", 150, 150, 150}, {"gray6", 15, 15, 15}, {"gray60", 153, 153, 153}, {"gray61", 156, 156, 156}, {"gray62", 158, 158, 158}, {"gray63", 161, 161, 161}, {"gray64", 163, 163, 163}, {"gray65", 166, 166, 166}, {"gray66", 168, 168, 168}, {"gray67", 171, 171, 171}, {"gray68", 173, 173, 173}, {"gray69", 176, 176, 176}, {"gray7", 18, 18, 18}, {"gray70", 179, 179, 179}, {"gray71", 181, 181, 181}, {"gray72", 184, 184, 184}, {"gray73", 186, 186, 186}, {"gray74", 189, 189, 189}, {"gray75", 191, 191, 191}, {"gray76", 194, 194, 194}, {"gray77", 196, 196, 196}, {"gray78", 199, 199, 199}, {"gray79", 201, 201, 201}, {"gray8", 20, 20, 20}, {"gray80", 204, 204, 204}, {"gray81", 207, 207, 207}, {"gray82", 209, 209, 209}, {"gray83", 212, 212, 212}, {"gray84", 214, 214, 214}, {"gray85", 217, 217, 217}, {"gray86", 219, 219, 219}, {"gray87", 222, 222, 222}, {"gray88", 224, 224, 224}, {"gray89", 227, 227, 227}, {"gray9", 23, 23, 23}, {"gray90", 229, 229, 229}, {"gray91", 232, 232, 232}, {"gray92", 235, 235, 235}, {"gray93", 237, 237, 237}, {"gray94", 240, 240, 240}, {"gray95", 242, 242, 242}, {"gray96", 245, 245, 245}, {"gray97", 247, 247, 247}, {"gray98", 250, 250, 250}, {"gray99", 252, 252, 252}, {"green", 0, 255, 0}, {"green yellow", 173, 255, 47}, {"green1", 0, 255, 0}, {"green2", 0, 238, 0}, {"green3", 0, 205, 0}, {"green4", 0, 139, 0}, {"grey", 190, 190, 190}, {"grey0", 0, 0, 0}, {"grey1", 3, 3, 3}, {"grey10", 26, 26, 26}, {"grey100", 255, 255, 255}, {"grey11", 28, 28, 28}, {"grey12", 31, 31, 31}, {"grey13", 33, 33, 33}, {"grey14", 36, 36, 36}, {"grey15", 38, 38, 38}, {"grey16", 41, 41, 41}, {"grey17", 43, 43, 43}, {"grey18", 46, 46, 46}, {"grey19", 48, 48, 48}, {"grey2", 5, 5, 5}, {"grey20", 51, 51, 51}, {"grey21", 54, 54, 54}, {"grey22", 56, 56, 56}, {"grey23", 59, 59, 59}, {"grey24", 61, 61, 61}, {"grey25", 64, 64, 64}, {"grey26", 66, 66, 66}, {"grey27", 69, 69, 69}, {"grey28", 71, 71, 71}, {"grey29", 74, 74, 74}, {"grey3", 8, 8, 8}, {"grey30", 77, 77, 77}, {"grey31", 79, 79, 79}, {"grey32", 82, 82, 82}, {"grey33", 84, 84, 84}, {"grey34", 87, 87, 87}, {"grey35", 89, 89, 89}, {"grey36", 92, 92, 92}, {"grey37", 94, 94, 94}, {"grey38", 97, 97, 97}, {"grey39", 99, 99, 99}, {"grey4", 10, 10, 10}, {"grey40", 102, 102, 102}, {"grey41", 105, 105, 105}, {"grey42", 107, 107, 107}, {"grey43", 110, 110, 110}, {"grey44", 112, 112, 112}, {"grey45", 115, 115, 115}, {"grey46", 117, 117, 117}, {"grey47", 120, 120, 120}, {"grey48", 122, 122, 122}, {"grey49", 125, 125, 125}, {"grey5", 13, 13, 13}, {"grey50", 127, 127, 127}, {"grey51", 130, 130, 130}, {"grey52", 133, 133, 133}, {"grey53", 135, 135, 135}, {"grey54", 138, 138, 138}, {"grey55", 140, 140, 140}, {"grey56", 143, 143, 143}, {"grey57", 145, 145, 145}, {"grey58", 148, 148, 148}, {"grey59", 150, 150, 150}, {"grey6", 15, 15, 15}, {"grey60", 153, 153, 153}, {"grey61", 156, 156, 156}, {"grey62", 158, 158, 158}, {"grey63", 161, 161, 161}, {"grey64", 163, 163, 163}, {"grey65", 166, 166, 166}, {"grey66", 168, 168, 168}, {"grey67", 171, 171, 171}, {"grey68", 173, 173, 173}, {"grey69", 176, 176, 176}, {"grey7", 18, 18, 18}, {"grey70", 179, 179, 179}, {"grey71", 181, 181, 181}, {"grey72", 184, 184, 184}, {"grey73", 186, 186, 186}, {"grey74", 189, 189, 189}, {"grey75", 191, 191, 191}, {"grey76", 194, 194, 194}, {"grey77", 196, 196, 196}, {"grey78", 199, 199, 199}, {"grey79", 201, 201, 201}, {"grey8", 20, 20, 20}, {"grey80", 204, 204, 204}, {"grey81", 207, 207, 207}, {"grey82", 209, 209, 209}, {"grey83", 212, 212, 212}, {"grey84", 214, 214, 214}, {"grey85", 217, 217, 217}, {"grey86", 219, 219, 219}, {"grey87", 222, 222, 222}, {"grey88", 224, 224, 224}, {"grey89", 227, 227, 227}, {"grey9", 23, 23, 23}, {"grey90", 229, 229, 229}, {"grey91", 232, 232, 232}, {"grey92", 235, 235, 235}, {"grey93", 237, 237, 237}, {"grey94", 240, 240, 240}, {"grey95", 242, 242, 242}, {"grey96", 245, 245, 245}, {"grey97", 247, 247, 247}, {"grey98", 250, 250, 250}, {"grey99", 252, 252, 252}, {"honeydew", 240, 255, 240}, {"honeydew1", 240, 255, 240}, {"honeydew2", 224, 238, 224}, {"honeydew3", 193, 205, 193}, {"honeydew4", 131, 139, 131}, {"hot pink", 255, 105, 180}, {"indian red", 205, 92, 92}, {"ivory", 255, 255, 240}, {"ivory1", 255, 255, 240}, {"ivory2", 238, 238, 224}, {"ivory3", 205, 205, 193}, {"ivory4", 139, 139, 131}, {"khaki", 240, 230, 140}, {"khaki1", 255, 246, 143}, {"khaki2", 238, 230, 133}, {"khaki3", 205, 198, 115}, {"khaki4", 139, 134, 78}, {"lavender", 230, 230, 250}, {"lavender blush", 255, 240, 245}, {"lawn green", 124, 252, 0}, {"lemon chiffon", 255, 250, 205}, {"light blue", 173, 216, 230}, {"light coral", 240, 128, 128}, {"light cyan", 224, 255, 255}, {"light goldenrod", 238, 221, 130}, {"light goldenrod yellow", 250, 250, 210}, {"light gray", 211, 211, 211}, {"light green", 144, 238, 144}, {"light grey", 211, 211, 211}, {"light pink", 255, 182, 193}, {"light salmon", 255, 160, 122}, {"light sea green", 32, 178, 170}, {"light sky blue", 135, 206, 250}, {"light slate blue", 132, 112, 255}, {"light slate gray", 119, 136, 153}, {"light slate grey", 119, 136, 153}, {"light steel blue", 176, 196, 222}, {"light yellow", 255, 255, 224}, {"lime green", 50, 205, 50}, {"linen", 250, 240, 230}, {"magenta", 255, 0, 255}, {"magenta1", 255, 0, 255}, {"magenta2", 238, 0, 238}, {"magenta3", 205, 0, 205}, {"magenta4", 139, 0, 139}, {"maroon", 176, 48, 96}, {"maroon1", 255, 52, 179}, {"maroon2", 238, 48, 167}, {"maroon3", 205, 41, 144}, {"maroon4", 139, 28, 98}, {"medium aquamarine", 102, 205, 170}, {"medium blue", 0, 0, 205}, {"medium orchid", 186, 85, 211}, {"medium purple", 147, 112, 219}, {"medium sea green", 60, 179, 113}, {"medium slate blue", 123, 104, 238}, {"medium spring green", 0, 250, 154}, {"medium turquoise", 72, 209, 204}, {"medium violet red", 199, 21, 133}, {"midnight blue", 25, 25, 112}, {"mint cream", 245, 255, 250}, {"misty rose", 255, 228, 225}, {"moccasin", 255, 228, 181}, {"navajo white", 255, 222, 173}, {"navy", 0, 0, 128}, {"navy blue", 0, 0, 128}, {"old lace", 253, 245, 230}, {"olive drab", 107, 142, 35}, {"orange", 255, 165, 0}, {"orange red", 255, 69, 0}, {"orange1", 255, 165, 0}, {"orange2", 238, 154, 0}, {"orange3", 205, 133, 0}, {"orange4", 139, 90, 0}, {"orchid", 218, 112, 214}, {"orchid1", 255, 131, 250}, {"orchid2", 238, 122, 233}, {"orchid3", 205, 105, 201}, {"orchid4", 139, 71, 137}, {"pale goldenrod", 238, 232, 170}, {"pale green", 152, 251, 152}, {"pale turquoise", 175, 238, 238}, {"pale violet red", 219, 112, 147}, {"papaya whip", 255, 239, 213}, {"peach puff", 255, 218, 185}, {"peru", 205, 133, 63}, {"pink", 255, 192, 203}, {"pink1", 255, 181, 197}, {"pink2", 238, 169, 184}, {"pink3", 205, 145, 158}, {"pink4", 139, 99, 108}, {"plum", 221, 160, 221}, {"plum1", 255, 187, 255}, {"plum2", 238, 174, 238}, {"plum3", 205, 150, 205}, {"plum4", 139, 102, 139}, {"powder blue", 176, 224, 230}, {"purple", 160, 32, 240}, {"purple1", 155, 48, 255}, {"purple2", 145, 44, 238}, {"purple3", 125, 38, 205}, {"purple4", 85, 26, 139}, {"red", 255, 0, 0}, {"red1", 255, 0, 0}, {"red2", 238, 0, 0}, {"red3", 205, 0, 0}, {"red4", 139, 0, 0}, {"rosy brown", 188, 143, 143}, {"royal blue", 65, 105, 225}, {"saddle brown", 139, 69, 19}, {"salmon", 250, 128, 114}, {"salmon1", 255, 140, 105}, {"salmon2", 238, 130, 98}, {"salmon3", 205, 112, 84}, {"salmon4", 139, 76, 57}, {"sandy brown", 244, 164, 96}, {"sea green", 46, 139, 87}, {"seashell", 255, 245, 238}, {"seashell1", 255, 245, 238}, {"seashell2", 238, 229, 222}, {"seashell3", 205, 197, 191}, {"seashell4", 139, 134, 130}, {"sienna", 160, 82, 45}, {"sienna1", 255, 130, 71}, {"sienna2", 238, 121, 66}, {"sienna3", 205, 104, 57}, {"sienna4", 139, 71, 38}, {"sky blue", 135, 206, 235}, {"slate blue", 106, 90, 205}, {"slate gray", 112, 128, 144}, {"slate grey", 112, 128, 144}, {"snow", 255, 250, 250}, {"snow1", 255, 250, 250}, {"snow2", 238, 233, 233}, {"snow3", 205, 201, 201}, {"snow4", 139, 137, 137}, {"spring green", 0, 255, 127}, {"steel blue", 70, 130, 180}, {"tan", 210, 180, 140}, {"tan1", 255, 165, 79}, {"tan2", 238, 154, 73}, {"tan3", 205, 133, 63}, {"tan4", 139, 90, 43}, {"thistle", 216, 191, 216}, {"thistle1", 255, 225, 255}, {"thistle2", 238, 210, 238}, {"thistle3", 205, 181, 205}, {"thistle4", 139, 123, 139}, {"tomato", 255, 99, 71}, {"tomato1", 255, 99, 71}, {"tomato2", 238, 92, 66}, {"tomato3", 205, 79, 57}, {"tomato4", 139, 54, 38}, {"turquoise", 64, 224, 208}, {"turquoise1", 0, 245, 255}, {"turquoise2", 0, 229, 238}, {"turquoise3", 0, 197, 205}, {"turquoise4", 0, 134, 139}, {"violet", 238, 130, 238}, {"violet red", 208, 32, 144}, {"wheat", 245, 222, 179}, {"wheat1", 255, 231, 186}, {"wheat2", 238, 216, 174}, {"wheat3", 205, 186, 150}, {"wheat4", 139, 126, 102}, {"white", 255, 255, 255}, {"white smoke", 245, 245, 245}, {"yellow", 255, 255, 0}, {"yellow green", 154, 205, 50}, {"yellow1", 255, 255, 0}, {"yellow2", 238, 238, 0}, {"yellow3", 205, 205, 0}, {"yellow4", 139, 139, 0}, }; BGD_EXPORT_DATA_PROT gdColorMap GD_COLOR_MAP_X11 = { sizeof(GD_COLOR_MAP_X11_ENTRIES)/sizeof(gdColorMapEntry), (gdColorMapEntry *)GD_COLOR_MAP_X11_ENTRIES }; BGD_DECLARE(int) gdColorMapLookup(const gdColorMap color_map, const char *color_name, int *r, int *g, int *b) { gdColorMapEntry *entries = color_map.entries; int low = 0; int high = color_map.num_entries - 1; while (low <= high) { int i = (low+high)/2; int result = strcmp(color_name, entries[i].color_name); if (result == 0) { *r = entries[i].red; *g = entries[i].green; *b = entries[i].blue; return 1; } else if (result < 0) { high = i - 1; } else { low = i + 1; } } return 0; } libgd-gd-2.1.1/src/gd_color_map.h000066400000000000000000000007361245535672000165700ustar00rootroot00000000000000#ifndef GD_COLOR_MAP_H #define GD_COLOR_MAP_H 1 #include "gd.h" #ifdef __cplusplus extern "C" { #endif typedef struct { char *color_name; int red; int green; int blue; } gdColorMapEntry; typedef struct { int num_entries; gdColorMapEntry *entries; } gdColorMap; extern BGD_EXPORT_DATA_PROT gdColorMap GD_COLOR_MAP_X11; BGD_DECLARE(int) gdColorMapLookup(const gdColorMap color_map, const char *color_name, int *r, int *g, int *b); #ifdef __cplusplus } #endif #endif libgd-gd-2.1.1/src/gd_color_map_test.c000066400000000000000000000010721245535672000176140ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include "gd.h" #include "gd_color_map.h" int main(void) { int r, g, b; int i; for (i=0; i #include "gd.h" #include "gdhelpers.h" /* bring the palette colors in im2 to be closer to im1 * */ BGD_DECLARE(int) gdImageColorMatch (gdImagePtr im1, gdImagePtr im2) { unsigned long *buf; /* stores our calculations */ unsigned long *bp; /* buf ptr */ int color, rgb; int x,y; int count; if (!im1->trueColor) { return -1; /* im1 must be True Color */ } if (im2->trueColor) { return -2; /* im2 must be indexed */ } if ((im1->sx != im2->sx) || (im1->sy != im2->sy)) { return -3; /* the images are meant to be the same dimensions */ } if (im2->colorsTotal < 1) { return -4; /* At least 1 color must be allocated */ } buf = (unsigned long *)gdMalloc(sizeof(unsigned long) * 5 * im2->colorsTotal); memset (buf, 0, sizeof(unsigned long) * 5 * im2->colorsTotal ); for (x=0; x < im1->sx; x++) { for( y=0; ysy; y++ ) { color = im2->pixels[y][x]; rgb = im1->tpixels[y][x]; bp = buf + (color * 5); (*(bp++))++; *(bp++) += gdTrueColorGetRed(rgb); *(bp++) += gdTrueColorGetGreen(rgb); *(bp++) += gdTrueColorGetBlue(rgb); *(bp++) += gdTrueColorGetAlpha(rgb); } } bp = buf; for (color=0; color < im2->colorsTotal; color++) { count = *(bp++); if( count > 0 ) { im2->red[color] = *(bp++) / count; im2->green[color] = *(bp++) / count; im2->blue[color] = *(bp++) / count; im2->alpha[color] = *(bp++) / count; } else { bp += 4; } } gdFree(buf); return 0; } libgd-gd-2.1.1/src/gd_crop.c000066400000000000000000000131011245535672000155410ustar00rootroot00000000000000/* Crop support * manual crop using a gdRect or automatic crop using a background * color (automatic detections or using either the transparent color, * black or white). * An alternative method allows to crop using a given color and a * threshold. It works relatively well but it can be improved. * Maybe L*a*b* and Delta-E will give better results (and a better * granularity). */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include "gd.h" #include "gd_color.h" static int gdGuessBackgroundColorFromCorners(gdImagePtr im, int *color); BGD_DECLARE(gdImagePtr) gdImageCrop(gdImagePtr src, const gdRect *crop) { gdImagePtr dst; dst = gdImageCreateTrueColor(crop->width, crop->height); if (!dst) return NULL; gdImageCopy(dst, src, 0, 0, crop->x, crop->y, crop->width, crop->height); return dst; } BGD_DECLARE(gdImagePtr) gdImageCropAuto(gdImagePtr im, const unsigned int mode) { const int width = gdImageSX(im); const int height = gdImageSY(im); int x,y; int color, match; gdRect crop; crop.x = 0; crop.y = 0; crop.width = 0; crop.height = 0; switch (mode) { case GD_CROP_TRANSPARENT: color = gdImageGetTransparent(im); break; case GD_CROP_BLACK: color = gdImageColorClosestAlpha(im, 0, 0, 0, 0); break; case GD_CROP_WHITE: color = gdImageColorClosestAlpha(im, 255, 255, 255, 0); break; case GD_CROP_SIDES: gdGuessBackgroundColorFromCorners(im, &color); break; case GD_CROP_DEFAULT: default: color = gdImageGetTransparent(im); break; } /* TODO: Add gdImageGetRowPtr and works with ptr at the row level * for the true color and palette images * new formats will simply work with ptr */ match = 1; for (y = 0; match && y < height; y++) { for (x = 0; match && x < width; x++) { match = (color == gdImageGetPixel(im, x,y)); } } /* Nothing to do > bye * Duplicate the image? */ if (y == height - 1) { return NULL; } crop.y = y -1; match = 1; for (y = height - 1; match && y >= 0; y--) { for (x = 0; match && x < width; x++) { match = (color == gdImageGetPixel(im, x,y)); } } if (y == 0) { crop.height = height - crop.y + 1; } else { crop.height = y - crop.y + 2; } match = 1; for (x = 0; match && x < width; x++) { for (y = 0; match && y < crop.y + crop.height - 1; y++) { match = (color == gdImageGetPixel(im, x,y)); } } crop.x = x - 1; match = 1; for (x = width - 1; match && x >= 0; x--) { for (y = 0; match && y < crop.y + crop.height - 1; y++) { match = (color == gdImageGetPixel(im, x,y)); } } crop.width = x - crop.x + 2; return gdImageCrop(im, &crop); } BGD_DECLARE(gdImagePtr) gdImageCropThreshold(gdImagePtr im, const unsigned int color, const float threshold) { const int width = gdImageSX(im); const int height = gdImageSY(im); int x,y; int match; gdRect crop; crop.x = 0; crop.y = 0; crop.width = 0; crop.height = 0; /* Pierre: crop everything sounds bad */ if (threshold > 100.0) { return NULL; } /* TODO: Add gdImageGetRowPtr and works with ptr at the row level * for the true color and palette images * new formats will simply work with ptr */ match = 1; for (y = 0; match && y < height; y++) { for (x = 0; match && x < width; x++) { match = (gdColorMatch(im, color, gdImageGetPixel(im, x,y), threshold)) > 0; } } /* Pierre * Nothing to do > bye * Duplicate the image? */ if (y == height - 1) { return NULL; } crop.y = y -1; match = 1; for (y = height - 1; match && y >= 0; y--) { for (x = 0; match && x < width; x++) { match = (gdColorMatch(im, color, gdImageGetPixel(im, x, y), threshold)) > 0; } } if (y == 0) { crop.height = height - crop.y + 1; } else { crop.height = y - crop.y + 2; } match = 1; for (x = 0; match && x < width; x++) { for (y = 0; match && y < crop.y + crop.height - 1; y++) { match = (gdColorMatch(im, color, gdImageGetPixel(im, x,y), threshold)) > 0; } } crop.x = x - 1; match = 1; for (x = width - 1; match && x >= 0; x--) { for (y = 0; match && y < crop.y + crop.height - 1; y++) { match = (gdColorMatch(im, color, gdImageGetPixel(im, x,y), threshold)) > 0; } } crop.width = x - crop.x + 2; return gdImageCrop(im, &crop); } /* This algorithm comes from pnmcrop (http://netpbm.sourceforge.net/) * Three steps: * - if 3 corners are equal. * - if two are equal. * - Last solution: average the colors */ static int gdGuessBackgroundColorFromCorners(gdImagePtr im, int *color) { const int tl = gdImageGetPixel(im, 0, 0); const int tr = gdImageGetPixel(im, gdImageSX(im) - 1, 0); const int bl = gdImageGetPixel(im, 0, gdImageSY(im) -1); const int br = gdImageGetPixel(im, gdImageSX(im) - 1, gdImageSY(im) -1); if (tr == bl && tr == br) { *color = tr; return 3; } else if (tl == bl && tl == br) { *color = tl; return 3; } else if (tl == tr && tl == br) { *color = tl; return 3; } else if (tl == tr && tl == bl) { *color = tl; return 3; } else if (tl == tr || tl == bl || tl == br) { *color = tl; return 2; } else if (tr == bl) { *color = tr; return 2; } else if (br == bl) { *color = bl; return 2; } else { register int r,b,g,a; r = (int)(0.5f + (gdImageRed(im, tl) + gdImageRed(im, tr) + gdImageRed(im, bl) + gdImageRed(im, br)) / 4); g = (int)(0.5f + (gdImageGreen(im, tl) + gdImageGreen(im, tr) + gdImageGreen(im, bl) + gdImageGreen(im, br)) / 4); b = (int)(0.5f + (gdImageBlue(im, tl) + gdImageBlue(im, tr) + gdImageBlue(im, bl) + gdImageBlue(im, br)) / 4); a = (int)(0.5f + (gdImageAlpha(im, tl) + gdImageAlpha(im, tr) + gdImageAlpha(im, bl) + gdImageAlpha(im, br)) / 4); *color = gdImageColorClosestAlpha(im, r, g, b, a); return 0; } } libgd-gd-2.1.1/src/gd_errors.h000066400000000000000000000027371245535672000161340ustar00rootroot00000000000000#ifndef GD_ERRORS_H #define GD_ERRORS_H #ifndef _WIN32 # include #else /* * priorities/facilities are encoded into a single 32-bit quantity, where the * bottom 3 bits are the priority (0-7) and the top 28 bits are the facility * (0-big number). Both the priorities and the facilities map roughly * one-to-one to strings in the syslogd(8) source code. This mapping is * included in this file. * * priorities (these are ordered) */ # define LOG_EMERG 0 /* system is unusable */ # define LOG_ALERT 1 /* action must be taken immediately */ # define LOG_CRIT 2 /* critical conditions */ # define LOG_ERR 3 /* error conditions */ # define LOG_WARNING 4 /* warning conditions */ # define LOG_NOTICE 5 /* normal but significant condition */ # define LOG_INFO 6 /* informational */ # define LOG_DEBUG 7 /* debug-level messages */ #endif /* LOG_EMERG system is unusable LOG_ALERT action must be taken immediately LOG_CRIT critical conditions LOG_ERR error conditions LOG_WARNING warning conditions LOG_NOTICE normal, but significant, condition LOG_INFO informational message LOG_DEBUG debug-level message */ #define GD_ERROR LOG_ERR #define GD_WARNING LOG_WARNING #define GD_NOTICE LOG_NOTICE #define GD_INFO LOG_INFO #define GD_DEBUG LOG_DEBUG void gd_error(const char *format, ...); void gd_error_ex(int priority, const char *format, ...); #endif libgd-gd-2.1.1/src/gd_filename.c000066400000000000000000000146421245535672000163710ustar00rootroot00000000000000/* Convenience functions to read or write images from or to disk, * determining file type from the filename extension. */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include "gd.h" typedef gdImagePtr (BGD_STDCALL *ReadFn)(FILE *in); typedef void (BGD_STDCALL *WriteFn)(gdImagePtr im, FILE *out); typedef gdImagePtr (BGD_STDCALL *LoadFn)(char *filename); #ifdef HAVE_LIBZ static void BGD_STDCALL writegd2(gdImagePtr im, FILE *out) { gdImageGd2(im, out, 0, GD2_FMT_COMPRESSED); }/* writegd*/ #endif #ifdef HAVE_LIBJPEG static void BGD_STDCALL writejpeg(gdImagePtr im, FILE *out) { gdImageJpeg(im, out, -1); }/* writejpeg*/ #endif static void BGD_STDCALL writewbmp(gdImagePtr im, FILE *out) { int fg = gdImageColorClosest(im, 0, 0, 0); gdImageWBMP(im, fg, out); }/* writejpeg*/ static void BGD_STDCALL writebmp(gdImagePtr im, FILE *out) { gdImageBmp(im, out, GD_TRUE); }/* writejpeg*/ enum FType {UNKNOWN, PNG, JPG, GIF, TIFF, GD, GD2, WEBP}; static struct FileType { const char *ext; ReadFn reader; WriteFn writer; LoadFn loader; } Types[] = { {".gif", gdImageCreateFromGif, gdImageGif, NULL}, {".gd", gdImageCreateFromGd, gdImageGd, NULL}, {".wbmp", gdImageCreateFromWBMP, writewbmp, NULL}, {".bmp", gdImageCreateFromBmp, writebmp, NULL}, {".xbm", gdImageCreateFromXbm, NULL, NULL}, {".tga", gdImageCreateFromTga, NULL, NULL}, #ifdef HAVE_LIBPNG {".png", gdImageCreateFromPng, gdImagePng, NULL}, #endif #ifdef HAVE_LIBJPEG {".jpg", gdImageCreateFromJpeg, writejpeg, NULL}, {".jpeg", gdImageCreateFromJpeg, writejpeg, NULL}, #endif #ifdef HAVE_LIBTIFF {".tiff", gdImageCreateFromTiff, gdImageTiff, NULL}, {".tif" , gdImageCreateFromTiff, gdImageTiff, NULL}, #endif #ifdef HAVE_LIBZ {".gd2", gdImageCreateFromGd2, writegd2, NULL}, #endif #ifdef HAVE_LIBVPX {".webp", gdImageCreateFromWebp, gdImageWebp, NULL}, #endif #ifdef HAVE_LIBXPM {".xpm", NULL, NULL, gdImageCreateFromXpm}, #endif {NULL, NULL, NULL} }; struct FileType * ftype(const char *filename) { int n; char *ext; /* Find the file extension (i.e. the last period in the string. */ ext = strrchr(filename, '.'); if (!ext) return NULL; for (n = 0; Types[n].ext; n++) { if (strcasecmp(ext, Types[n].ext) == 0) { return &Types[n]; }/* if */ }/* for */ return NULL; }/* ftype*/ /* Function: gdSupportsFileType Tests if a given file type is supported by GD. Given the name of an image file (which does not have to exist), returns 1 (i.e. TRUE) if can read a file of that type. This is useful if you do not know which image types were enabled at compile time. If _writing_ is true, the result will be true only if can write a file of this type. Note that filename parsing is done exactly the same as is done by and and is subject to the same limitations. Assuming LibGD is compiled with support for these image types, the following extensions are supported: - .gif - .gd, .gd2 - .wbmp - .bmp - .xbm - .tga - .png - .jpg, .jpeg - .tiff, .tif - .webp - .xpm Names are parsed case-insenstively. Parameters: filename - Filename with tested extension. writing - Flag: true tests if writing works Returns: GD_TRUE (1) if the file type is supported, GD_FALSE (0) if not. */ BGD_DECLARE(int) gdSupportsFileType(const char *filename, int writing) { struct FileType *entry = ftype(filename); return !!entry && (!writing || !!entry->writer); }/* gdSupportsFileType*/ /* Function: gdImageCreateFromFile Read an image file of any supported. Given the path to a file, will open the file, read its contents with the appropriate _gdImageCreateFrom*_ function and return it. File type is determined by the filename extension, so having an incorrect extension will probably not work. For example, renaming PNG image "foo.png" to "foo.gif" and then attempting to load it will fail even if GD supports both formats. See for more details. NULL is returned on error. Parameters: filename - the input file name Returns: A pointer to the new image or NULL if an error occurred. */ BGD_DECLARE(gdImagePtr) gdImageCreateFromFile(const char *filename) { struct FileType *entry = ftype(filename); FILE *fh; gdImagePtr result; if (!entry) return NULL; if (entry->loader) return entry->loader((char *)filename); if (!entry->reader) return NULL; fh = fopen(filename, "rb"); if (!fh) return NULL; result = entry->reader(fh); fclose(fh); return result; }/* gdImageCreateFromFile*/ /* Function: gdImageFile Writes an image to a file in the format indicated by the filename. File type is determined by the extension of the file name. See for an overview of the parsing. For file types that require extra arguments, attempts to use sane defaults: - chunk size = 0, compression is enabled. - quality = -1 (i.e. the reasonable default) - foreground is the darkest available color Everything else is called with the two-argument function and so will use the default values. has some rudimentary error detection and will return GD_FALSE (0) if a detectable error occurred. However, the image loaders do not normally return their error status so a result of GD_TRUE (1) does **not** mean the file was saved successfully. Parameters: im - The image to save. filename - The path to the file to which the image is saved. Returns: GD_FALSE (0) if an error was detected, GD_TRUE (1) if not. */ BGD_DECLARE(int) gdImageFile(gdImagePtr im, const char *filename) { struct FileType *entry = ftype(filename); FILE *fh; if (!entry || !entry->writer) return GD_FALSE; fh = fopen(filename, "wb"); if (!fh) return GD_FALSE; entry->writer(im, fh); fclose(fh); return GD_TRUE; }/* gdImageFile*/ libgd-gd-2.1.1/src/gd_filter.c000066400000000000000000000506401245535672000160740ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" #include "gdhelpers.h" #include "gd_intern.h" #ifdef _WIN32 # include #else # include #endif #include #include #include #define NDEBUG /* Uncomment to enable assertions. */ #include typedef int (BGD_STDCALL *FuncPtr)(gdImagePtr, int, int); #define GET_PIXEL_FUNCTION(src)(src->trueColor?gdImageGetTrueColorPixel:gdImageGetPixel) #define MIN(a,b) ((a)<(b)?(a):(b)) #define MAX(a,b) ((a)<(b)?(b):(a)) #ifdef _WIN32 # define GD_SCATTER_SEED() (unsigned int)(time(0) * GetCurrentProcessId()) #else # define GD_SCATTER_SEED() (unsigned int)(time(0) * getpid()) #endif BGD_DECLARE(int) gdImageScatter(gdImagePtr im, int sub, int plus) { gdScatter s; s.sub = sub; s.plus = plus; s.num_colors = 0; s.seed = GD_SCATTER_SEED(); return gdImageScatterEx(im, &s); } BGD_DECLARE(int) gdImageScatterColor(gdImagePtr im, int sub, int plus, int colors[], unsigned int num_colors) { gdScatter s; s.sub = sub; s.plus = plus; s.colors = colors; s.num_colors = num_colors; s.seed = GD_SCATTER_SEED(); return gdImageScatterEx(im, &s); } BGD_DECLARE(int) gdImageScatterEx(gdImagePtr im, gdScatterPtr scatter) { register int x, y; int dest_x, dest_y; int pxl, new_pxl; unsigned int n; int sub = scatter->sub, plus = scatter->plus; if (plus == 0 && sub == 0) { return 1; } else if (sub >= plus) { return 0; } (void)srand(scatter->seed); if (scatter->num_colors) { for (y = 0; y < im->sy; y++) { for (x = 0; x < im->sx; x++) { dest_x = (int) (x + ((rand() % (plus - sub)) + sub)); dest_y = (int) (y + ((rand() % (plus - sub)) + sub)); if (!gdImageBoundsSafe(im, dest_x, dest_y)) { continue; } pxl = gdImageGetPixel(im, x, y); new_pxl = gdImageGetPixel(im, dest_x, dest_y); for (n = 0; n < scatter->num_colors; n++) { if (pxl == scatter->colors[n]) { gdImageSetPixel(im, dest_x, dest_y, pxl); gdImageSetPixel(im, x, y, new_pxl); } } } } } else { for (y = 0; y < im->sy; y++) { for (x = 0; x < im->sx; x++) { dest_x = (int) (x + ((rand() % (plus - sub)) + sub)); dest_y = (int) (y + ((rand() % (plus - sub)) + sub)); if (!gdImageBoundsSafe(im, dest_x, dest_y)) { continue; } pxl = gdImageGetPixel(im, x, y); new_pxl = gdImageGetPixel(im, dest_x, dest_y); gdImageSetPixel(im, dest_x, dest_y, pxl); gdImageSetPixel(im, x, y, new_pxl); } } } return 1; } BGD_DECLARE(int) gdImagePixelate(gdImagePtr im, int block_size, const unsigned int mode) { int x, y; if (block_size <= 0) { return 0; } else if (block_size == 1) { return 1; } switch (mode) { case GD_PIXELATE_UPPERLEFT: for (y = 0; y < im->sy; y += block_size) { for (x = 0; x < im->sx; x += block_size) { if (gdImageBoundsSafe(im, x, y)) { int c = gdImageGetPixel(im, x, y); gdImageFilledRectangle(im, x, y, x + block_size - 1, y + block_size - 1, c); } } } break; case GD_PIXELATE_AVERAGE: for (y = 0; y < im->sy; y += block_size) { for (x = 0; x < im->sx; x += block_size) { int a, r, g, b, c; int total; int cx, cy; a = r = g = b = c = total = 0; /* sampling */ for (cy = 0; cy < block_size; cy++) { for (cx = 0; cx < block_size; cx++) { if (!gdImageBoundsSafe(im, x + cx, y + cy)) { continue; } c = gdImageGetPixel(im, x + cx, y + cy); a += gdImageAlpha(im, c); r += gdImageRed(im, c); g += gdImageGreen(im, c); b += gdImageBlue(im, c); total++; } } /* drawing */ if (total > 0) { c = gdImageColorResolveAlpha(im, r / total, g / total, b / total, a / total); gdImageFilledRectangle(im, x, y, x + block_size - 1, y + block_size - 1, c); } } } break; default: return 0; } return 1; } /* invert src image */ BGD_DECLARE(int) gdImageNegate(gdImagePtr src) { int x, y; int r,g,b,a; int new_pxl, pxl; FuncPtr f; if (src==NULL) { return 0; } f = GET_PIXEL_FUNCTION(src); for (y=0; ysy; ++y) { for (x=0; xsx; ++x) { pxl = f (src, x, y); r = gdImageRed(src, pxl); g = gdImageGreen(src, pxl); b = gdImageBlue(src, pxl); a = gdImageAlpha(src, pxl); new_pxl = gdImageColorAllocateAlpha(src, 255-r, 255-g, 255-b, a); if (new_pxl == -1) { new_pxl = gdImageColorClosestAlpha(src, 255-r, 255-g, 255-b, a); } gdImageSetPixel (src, x, y, new_pxl); } } return 1; } /* Convert the image src to a grayscale image */ BGD_DECLARE(int) gdImageGrayScale(gdImagePtr src) { int x, y; int r,g,b,a; int new_pxl, pxl; FuncPtr f; if (src==NULL) { return 0; } f = GET_PIXEL_FUNCTION(src); for (y=0; ysy; ++y) { for (x=0; xsx; ++x) { pxl = f (src, x, y); r = gdImageRed(src, pxl); g = gdImageGreen(src, pxl); b = gdImageBlue(src, pxl); a = gdImageAlpha(src, pxl); r = g = b = (int) (.299 * r + .587 * g + .114 * b); new_pxl = gdImageColorAllocateAlpha(src, r, g, b, a); if (new_pxl == -1) { new_pxl = gdImageColorClosestAlpha(src, r, g, b, a); } gdImageSetPixel (src, x, y, new_pxl); } } return 1; } /* Set the brightness level for the image src */ BGD_DECLARE(int) gdImageBrightness(gdImagePtr src, int brightness) { int x, y; int r,g,b,a; int new_pxl, pxl; FuncPtr f; if (src==NULL || (brightness < -255 || brightness > 255)) { return 0; } if (brightness==0) { return 1; } f = GET_PIXEL_FUNCTION(src); for (y=0; ysy; ++y) { for (x=0; xsx; ++x) { pxl = f (src, x, y); r = gdImageRed(src, pxl); g = gdImageGreen(src, pxl); b = gdImageBlue(src, pxl); a = gdImageAlpha(src, pxl); r = r + brightness; g = g + brightness; b = b + brightness; r = (r > 255)? 255 : ((r < 0)? 0:r); g = (g > 255)? 255 : ((g < 0)? 0:g); b = (b > 255)? 255 : ((b < 0)? 0:b); new_pxl = gdImageColorAllocateAlpha(src, (int)r, (int)g, (int)b, a); if (new_pxl == -1) { new_pxl = gdImageColorClosestAlpha(src, (int)r, (int)g, (int)b, a); } gdImageSetPixel (src, x, y, new_pxl); } } return 1; } BGD_DECLARE(int) gdImageContrast(gdImagePtr src, double contrast) { int x, y; int r,g,b,a; double rf,gf,bf; int new_pxl, pxl; FuncPtr f; if (src==NULL) { return 0; } f = GET_PIXEL_FUNCTION(src); contrast = (double)(100.0-contrast)/100.0; contrast = contrast*contrast; for (y=0; ysy; ++y) { for (x=0; xsx; ++x) { pxl = f(src, x, y); r = gdImageRed(src, pxl); g = gdImageGreen(src, pxl); b = gdImageBlue(src, pxl); a = gdImageAlpha(src, pxl); rf = (double)r/255.0; rf = rf-0.5; rf = rf*contrast; rf = rf+0.5; rf = rf*255.0; bf = (double)b/255.0; bf = bf-0.5; bf = bf*contrast; bf = bf+0.5; bf = bf*255.0; gf = (double)g/255.0; gf = gf-0.5; gf = gf*contrast; gf = gf+0.5; gf = gf*255.0; rf = (rf > 255.0)? 255.0 : ((rf < 0.0)? 0.0:rf); gf = (gf > 255.0)? 255.0 : ((gf < 0.0)? 0.0:gf); bf = (bf > 255.0)? 255.0 : ((bf < 0.0)? 0.0:bf); new_pxl = gdImageColorAllocateAlpha(src, (int)rf, (int)gf, (int)bf, a); if (new_pxl == -1) { new_pxl = gdImageColorClosestAlpha(src, (int)rf, (int)gf, (int)bf, a); } gdImageSetPixel (src, x, y, new_pxl); } } return 1; } BGD_DECLARE(int) gdImageColor(gdImagePtr src, const int red, const int green, const int blue, const int alpha) { int x, y; int new_pxl, pxl; FuncPtr f; if (src == NULL) { return 0; } f = GET_PIXEL_FUNCTION(src); for (y=0; ysy; ++y) { for (x=0; xsx; ++x) { int r,g,b,a; pxl = f(src, x, y); r = gdImageRed(src, pxl); g = gdImageGreen(src, pxl); b = gdImageBlue(src, pxl); a = gdImageAlpha(src, pxl); r = r + red; g = g + green; b = b + blue; a = a + alpha; r = (r > 255)? 255 : ((r < 0)? 0 : r); g = (g > 255)? 255 : ((g < 0)? 0 : g); b = (b > 255)? 255 : ((b < 0)? 0 : b); a = (a > 127)? 127 : ((a < 0)? 0 : a); new_pxl = gdImageColorAllocateAlpha(src, r, g, b, a); if (new_pxl == -1) { new_pxl = gdImageColorClosestAlpha(src, r, g, b, a); } gdImageSetPixel (src, x, y, new_pxl); } } return 1; } BGD_DECLARE(int) gdImageConvolution(gdImagePtr src, float filter[3][3], float filter_div, float offset) { int x, y, i, j, new_a; float new_r, new_g, new_b; int new_pxl, pxl=0; gdImagePtr srcback; FuncPtr f; if (src==NULL) { return 0; } /* We need the orinal image with each safe neoghb. pixel */ srcback = gdImageCreateTrueColor (src->sx, src->sy); if (srcback==NULL) { return 0; } gdImageSaveAlpha(srcback, 1); new_pxl = gdImageColorAllocateAlpha(srcback, 0, 0, 0, 127); gdImageFill(srcback, 0, 0, new_pxl); gdImageCopy(srcback, src,0,0,0,0,src->sx,src->sy); f = GET_PIXEL_FUNCTION(src); for ( y=0; ysy; y++) { for(x=0; xsx; x++) { new_r = new_g = new_b = 0; new_a = gdImageAlpha(srcback, pxl); for (j=0; j<3; j++) { int yv = MIN(MAX(y - 1 + j, 0), src->sy - 1); for (i=0; i<3; i++) { pxl = f(srcback, MIN(MAX(x - 1 + i, 0), src->sx - 1), yv); new_r += (float)gdImageRed(srcback, pxl) * filter[j][i]; new_g += (float)gdImageGreen(srcback, pxl) * filter[j][i]; new_b += (float)gdImageBlue(srcback, pxl) * filter[j][i]; } } new_r = (new_r/filter_div)+offset; new_g = (new_g/filter_div)+offset; new_b = (new_b/filter_div)+offset; new_r = (new_r > 255.0f)? 255.0f : ((new_r < 0.0f)? 0.0f:new_r); new_g = (new_g > 255.0f)? 255.0f : ((new_g < 0.0f)? 0.0f:new_g); new_b = (new_b > 255.0f)? 255.0f : ((new_b < 0.0f)? 0.0f:new_b); new_pxl = gdImageColorAllocateAlpha(src, (int)new_r, (int)new_g, (int)new_b, new_a); if (new_pxl == -1) { new_pxl = gdImageColorClosestAlpha(src, (int)new_r, (int)new_g, (int)new_b, new_a); } gdImageSetPixel (src, x, y, new_pxl); } } gdImageDestroy(srcback); return 1; } BGD_DECLARE(int) gdImageSelectiveBlur( gdImagePtr src) { int x, y, i, j; float new_r, new_g, new_b; int new_pxl, cpxl, pxl, new_a=0; float flt_r [3][3]; float flt_g [3][3]; float flt_b [3][3]; float flt_r_sum, flt_g_sum, flt_b_sum; gdImagePtr srcback; FuncPtr f; if (src==NULL) { return 0; } /* We need the orinal image with each safe neoghb. pixel */ srcback = gdImageCreateTrueColor (src->sx, src->sy); if (srcback==NULL) { return 0; } gdImageCopy(srcback, src,0,0,0,0,src->sx,src->sy); f = GET_PIXEL_FUNCTION(src); for(y = 0; ysy; y++) { for (x=0; xsx; x++) { flt_r_sum = flt_g_sum = flt_b_sum = 0.0; cpxl = f(src, x, y); for (j=0; j<3; j++) { for (i=0; i<3; i++) { if ((j == 1) && (i == 1)) { flt_r[1][1] = flt_g[1][1] = flt_b[1][1] = 0.5; } else { pxl = f(src, x-(3>>1)+i, y-(3>>1)+j); new_a = gdImageAlpha(srcback, pxl); new_r = ((float)gdImageRed(srcback, cpxl)) - ((float)gdImageRed (srcback, pxl)); if (new_r < 0.0f) { new_r = -new_r; } if (new_r != 0) { flt_r[j][i] = 1.0f/new_r; } else { flt_r[j][i] = 1.0f; } new_g = ((float)gdImageGreen(srcback, cpxl)) - ((float)gdImageGreen(srcback, pxl)); if (new_g < 0.0f) { new_g = -new_g; } if (new_g != 0) { flt_g[j][i] = 1.0f/new_g; } else { flt_g[j][i] = 1.0f; } new_b = ((float)gdImageBlue(srcback, cpxl)) - ((float)gdImageBlue(srcback, pxl)); if (new_b < 0.0f) { new_b = -new_b; } if (new_b != 0) { flt_b[j][i] = 1.0f/new_b; } else { flt_b[j][i] = 1.0f; } } flt_r_sum += flt_r[j][i]; flt_g_sum += flt_g[j][i]; flt_b_sum += flt_b [j][i]; } } for (j=0; j<3; j++) { for (i=0; i<3; i++) { if (flt_r_sum != 0.0) { flt_r[j][i] /= flt_r_sum; } if (flt_g_sum != 0.0) { flt_g[j][i] /= flt_g_sum; } if (flt_b_sum != 0.0) { flt_b [j][i] /= flt_b_sum; } } } new_r = new_g = new_b = 0.0; for (j=0; j<3; j++) { for (i=0; i<3; i++) { pxl = f(src, x-(3>>1)+i, y-(3>>1)+j); new_r += (float)gdImageRed(srcback, pxl) * flt_r[j][i]; new_g += (float)gdImageGreen(srcback, pxl) * flt_g[j][i]; new_b += (float)gdImageBlue(srcback, pxl) * flt_b[j][i]; } } new_r = (new_r > 255.0f)? 255.0f : ((new_r < 0.0f)? 0.0f:new_r); new_g = (new_g > 255.0f)? 255.0f : ((new_g < 0.0f)? 0.0f:new_g); new_b = (new_b > 255.0f)? 255.0f : ((new_b < 0.0f)? 0.0f:new_b); new_pxl = gdImageColorAllocateAlpha(src, (int)new_r, (int)new_g, (int)new_b, new_a); if (new_pxl == -1) { new_pxl = gdImageColorClosestAlpha(src, (int)new_r, (int)new_g, (int)new_b, new_a); } gdImageSetPixel (src, x, y, new_pxl); } } gdImageDestroy(srcback); return 1; } BGD_DECLARE(int) gdImageEdgeDetectQuick(gdImagePtr src) { float filter[3][3] = {{-1.0,0.0,-1.0}, {0.0,4.0,0.0}, {-1.0,0.0,-1.0}}; return gdImageConvolution(src, filter, 1, 127); } /* Function: gdImageGaussianBlur performs a Gaussian blur of radius 1 on the image. The image is modified in place. *NOTE:* You will almost certain want to use instead, as it allows you to change your kernel size and sigma value. Future versions of this function may fall back to calling it instead of , causing subtle changes so be warned. Parameters: im - The image to blur Returns: GD_TRUE (1) on success, GD_FALSE (0) on failure. */ BGD_DECLARE(int) gdImageGaussianBlur(gdImagePtr im) { float filter[3][3] = { {1.0, 2.0, 1.0}, {2.0, 4.0, 2.0}, {1.0, 2.0, 1.0} }; return gdImageConvolution(im, filter, 16, 0); } BGD_DECLARE(int) gdImageEmboss(gdImagePtr im) { /* float filter[3][3] = {{1.0,1.0,1.0}, {0.0,0.0,0.0}, {-1.0,-1.0,-1.0}}; */ float filter[3][3] = {{ 1.5, 0.0, 0.0}, { 0.0, 0.0, 0.0}, { 0.0, 0.0,-1.5}}; return gdImageConvolution(im, filter, 1, 127); } BGD_DECLARE(int) gdImageMeanRemoval(gdImagePtr im) { float filter[3][3] = {{-1.0,-1.0,-1.0}, {-1.0,9.0,-1.0}, {-1.0,-1.0,-1.0}}; return gdImageConvolution(im, filter, 1, 0); } BGD_DECLARE(int) gdImageSmooth(gdImagePtr im, float weight) { float filter[3][3] = {{1.0,1.0,1.0}, {1.0,0.0,1.0}, {1.0,1.0,1.0}}; filter[1][1] = weight; return gdImageConvolution(im, filter, weight+8, 0); } /* ======================== Gaussian Blur Code ======================== */ /* Return an array of coefficients for 'radius' and 'sigma' (sigma >= * 0 means compute it). Result length is 2*radius+1. */ static double * gaussian_coeffs(int radius, double sigmaArg) { const double sigma = (sigmaArg <= 0.0) ? (2.0/3.0)*radius : sigmaArg; const double s = 2.0 * sigma * sigma; double *result; double sum = 0; int x, n, count; count = 2*radius + 1; result = gdMalloc(sizeof(double) * count); if (!result) { return NULL; }/* if */ for (x = -radius; x <= radius; x++) { double coeff = exp(-(x*x)/s); sum += coeff; result[x + radius] = coeff; }/* for */ for (n = 0; n < count; n++) { result[n] /= sum; }/* for */ return result; }/* gaussian_coeffs*/ static inline int reflect(int max, int x) { assert(x > -max && x < 2*max); if(x < 0) return -x; if(x >= max) return max - (x - max) - 1; return x; }/* reflect*/ static inline void applyCoeffsLine(gdImagePtr src, gdImagePtr dst, int line, int linelen, double *coeffs, int radius, gdAxis axis) { int ndx; for (ndx = 0; ndx < linelen; ndx++) { double r = 0, g = 0, b = 0, a = 0; int cndx; int *dest = (axis == HORIZONTAL) ? &dst->tpixels[line][ndx] : &dst->tpixels[ndx][line]; for (cndx = -radius; cndx <= radius; cndx++) { const double coeff = coeffs[cndx + radius]; const int rndx = reflect(linelen, ndx + cndx); const int srcpx = (axis == HORIZONTAL) ? src->tpixels[line][rndx] : src->tpixels[rndx][line]; r += coeff * (double)gdTrueColorGetRed(srcpx); g += coeff * (double)gdTrueColorGetGreen(srcpx); b += coeff * (double)gdTrueColorGetBlue(srcpx); a += coeff * (double)gdTrueColorGetAlpha(srcpx); }/* for */ *dest = gdTrueColorAlpha(uchar_clamp(r, 0xFF), uchar_clamp(g, 0xFF), uchar_clamp(b, 0xFF), uchar_clamp(a, 0x7F)); }/* for */ }/* applyCoeffsLine*/ static void applyCoeffs(gdImagePtr src, gdImagePtr dst, double *coeffs, int radius, gdAxis axis) { int line, numlines, linelen; if (axis == HORIZONTAL) { numlines = src->sy; linelen = src->sx; } else { numlines = src->sx; linelen = src->sy; }/* if .. else*/ for (line = 0; line < numlines; line++) { applyCoeffsLine(src, dst, line, linelen, coeffs, radius, axis); }/* for */ }/* applyCoeffs*/ /* Function: gdImageCopyGaussianBlurred Return a copy of the source image _src_ blurred according to the parameters using the Gaussian Blur algorithm. _radius_ is a radius, not a diameter so a radius of 2 (for example) will blur across a region 5 pixels across (2 to the center, 1 for the center itself and another 2 to the other edge). _sigma_ represents the "fatness" of the curve (lower == fatter). If _sigma_ is less than or equal to 0, ignores it and instead computes an "optimal" value. Be warned that future versions of this function may compute sigma differently. The resulting image is always truecolor. More Details: A Gaussian Blur is generated by replacing each pixel's color values with the average of the surrounding pixels' colors. This region is a circle whose radius is given by argument _radius_. Thus, a larger radius will yield a blurrier image. This average is not a simple mean of the values. Instead, values are weighted using the Gaussian function (roughly a bell curve centered around the destination pixel) giving it much more influence on the result than its neighbours. Thus, a fatter curve will give the center pixel more weight and make the image less blurry; lower _sigma_ values will yield flatter curves. Currently, computes the default sigma as (2/3)*radius Note, however that we reserve the right to change this if we find a better ratio. If you absolutely need the current sigma value, you should set it yourself. Parameters: src - the source image radius - the blur radius (*not* diameter--range is 2*radius + 1) sigma - the sigma value or a value <= 0.0 to use the computed default Returns: The new image or NULL if an error occurred. The result is always truecolor. Example: > FILE *in; > gdImagePtr result, src; > > in = fopen("foo.png", "rb"); > src = gdImageCreateFromPng(in); > > result = gdImageCopyGaussianBlurred(im, src->sx / 10, -1.0); */ /* TODO: Look into turning this into a generic seperable filter * function with Gaussian Blur being one special case. (At the * moment, I can't find any other useful separable filter so for not, * it's just blur.) */ BGD_DECLARE(gdImagePtr) gdImageCopyGaussianBlurred(gdImagePtr src, int radius, double sigma) { gdImagePtr tmp = NULL, result = NULL; double *coeffs; int freeSrc = 0; if (radius < 1) { return NULL; }/* if */ /* Compute the coefficients. */ coeffs = gaussian_coeffs(radius, sigma); if (!coeffs) { return NULL; }/* if */ /* If the image is not truecolor, we first make a truecolor * scratch copy. */ if (!src->trueColor) { int tcstat; src = gdImageClone(src); if (!src) { gdFree(coeffs); return NULL; } tcstat = gdImagePaletteToTrueColor(src); if (!tcstat) { gdImageDestroy(src); gdFree(coeffs); return NULL; }/* if */ freeSrc = 1; }/* if */ /* Apply the filter horizontally. */ tmp = gdImageCreateTrueColor(src->sx, src->sy); if (!tmp) { gdFree(coeffs); return NULL; } applyCoeffs(src, tmp, coeffs, radius, HORIZONTAL); /* Apply the filter vertically. */ result = gdImageCreateTrueColor(src->sx, src->sy); if (result) { applyCoeffs(tmp, result, coeffs, radius, VERTICAL); }/* if */ gdImageDestroy(tmp); gdFree(coeffs); if (freeSrc) gdImageDestroy(src); return result; }/* gdImageCopyGaussianBlurred*/ libgd-gd-2.1.1/src/gd_gd.c000066400000000000000000000160571245535672000152050ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include #include "gd.h" #define TRUE 1 #define FALSE 0 /* Use this for commenting out debug-print statements. */ /* Just use the first '#define' to allow all the prints... */ /*#define GD2_DBG(s) (s) */ #define GD2_DBG(s) /* */ /* Shared code to read color tables from gd file. */ /* */ int _gdGetColors (gdIOCtx * in, gdImagePtr im, int gd2xFlag) { int i; if (gd2xFlag) { int trueColorFlag; if (!gdGetByte (&trueColorFlag, in)) { goto fail1; } /* 2.0.12: detect bad truecolor .gd files created by pre-2.0.12. Beginning in 2.0.12 truecolor is indicated by the initial 2-byte signature. */ if (trueColorFlag != im->trueColor) { goto fail1; } /* This should have been a word all along */ if (!im->trueColor) { if (!gdGetWord (&im->colorsTotal, in)) { goto fail1; } if (im->colorsTotal > gdMaxColors) { goto fail1; } } /* Int to accommodate truecolor single-color transparency */ if (!gdGetInt (&im->transparent, in)) { goto fail1; } } else { if (!gdGetByte (&im->colorsTotal, in)) { goto fail1; } if (!gdGetWord (&im->transparent, in)) { goto fail1; } if (im->transparent == 257) { im->transparent = (-1); } } GD2_DBG (printf ("Palette had %d colours (T=%d)\n", im->colorsTotal, im->transparent)); if (im->trueColor) { return TRUE; } for (i = 0; (i < gdMaxColors); i++) { if (!gdGetByte (&im->red[i], in)) { goto fail1; } if (!gdGetByte (&im->green[i], in)) { goto fail1; } if (!gdGetByte (&im->blue[i], in)) { goto fail1; } if (gd2xFlag) { if (!gdGetByte (&im->alpha[i], in)) { goto fail1; } } } for (i = 0; (i < im->colorsTotal); i++) { im->open[i] = 0; }; return TRUE; fail1: return FALSE; } /* */ /* Use the common basic header info to make the image object. */ /* */ static gdImagePtr _gdCreateFromFile (gdIOCtx * in, int *sx, int *sy) { gdImagePtr im; int gd2xFlag = 0; int trueColorFlag = 0; if (!gdGetWord (sx, in)) { goto fail1; } if ((*sx == 65535) || (*sx == 65534)) { /* This is a gd 2.0 .gd file */ gd2xFlag = 1; /* 2.0.12: 65534 signals a truecolor .gd file. There is a slight redundancy here but we can live with it. */ if (*sx == 65534) { trueColorFlag = 1; } if (!gdGetWord (sx, in)) { goto fail1; } } if (!gdGetWord (sy, in)) { goto fail1; } GD2_DBG (printf ("Image is %dx%d\n", *sx, *sy)); if (trueColorFlag) { im = gdImageCreateTrueColor (*sx, *sy); } else { im = gdImageCreate (*sx, *sy); } if (!im) { goto fail1; } if (!_gdGetColors (in, im, gd2xFlag)) { goto fail2; } return im; fail2: gdImageDestroy (im); fail1: return 0; } /* Function: gdImageCreateFromGd is called to load images from gd format files. Invoke with an already opened pointer to a file containing the desired image in the gd file format, which is specific to gd and intended for very fast loading. (It is not intended for compression; for compression, use PNG or JPEG.) returns a to the new image, or NULL if unable to load the image (most often because the file is corrupt or does not contain a gd format image). does not close the file. You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using . Variants: creates an image from GD data (i.e. the contents of a GD file) already in memory. reads in an image using the functions in a struct. Parameters: infile - The input FILE pointer Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > FILE *in; > in = fopen("mygd.gd", "rb"); > im = gdImageCreateFromGd(in); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd (FILE * inFile) { gdImagePtr im; gdIOCtx *in; in = gdNewFileCtx (inFile); if (in == NULL) return NULL; im = gdImageCreateFromGdCtx (in); in->gd_free (in); return im; } /* Function: gdImageCreateFromGdPtr Parameters: size - size of GD data in bytes. data - GD data (i.e. contents of a GIF file). Reads in GD data from memory. See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGdPtr (int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx (size, data, 0); if(!in) return 0; im = gdImageCreateFromGdCtx (in); in->gd_free (in); return im; } /* Function: gdImageCreateFromGdCtx Reads in a GD image via a struct. See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGdCtx (gdIOCtxPtr in) { int sx, sy; int x, y; gdImagePtr im; /* Read the header */ im = _gdCreateFromFile (in, &sx, &sy); if (im == NULL) { goto fail1; }; /* Then the data... */ /* 2.0.12: support truecolor properly in .gd as well as in .gd2. Problem reported by Andreas Pfaller. */ if (im->trueColor) { for (y = 0; (y < sy); y++) { for (x = 0; (x < sx); x++) { int pix; if (!gdGetInt (&pix, in)) { goto fail2; } im->tpixels[y][x] = pix; } } } else { for (y = 0; (y < sy); y++) { for (x = 0; (x < sx); x++) { int ch; ch = gdGetC (in); if (ch == EOF) { goto fail2; } /* ROW-MAJOR IN GD 1.3 */ im->pixels[y][x] = ch; } } } return im; fail2: gdImageDestroy (im); fail1: return 0; } void _gdPutColors (gdImagePtr im, gdIOCtx * out) { int i; gdPutC (im->trueColor, out); if (!im->trueColor) { gdPutWord (im->colorsTotal, out); } gdPutInt (im->transparent, out); if (!im->trueColor) { for (i = 0; (i < gdMaxColors); i++) { gdPutC ((unsigned char) im->red[i], out); gdPutC ((unsigned char) im->green[i], out); gdPutC ((unsigned char) im->blue[i], out); gdPutC ((unsigned char) im->alpha[i], out); } } } static void _gdPutHeader (gdImagePtr im, gdIOCtx * out) { /* 65535 indicates this is a gd 2.x .gd file. 2.0.12: 65534 indicates truecolor. */ if (im->trueColor) { gdPutWord (65534, out); } else { gdPutWord (65535, out); } gdPutWord (im->sx, out); gdPutWord (im->sy, out); _gdPutColors (im, out); } static void _gdImageGd (gdImagePtr im, gdIOCtx * out) { int x, y; _gdPutHeader (im, out); for (y = 0; (y < im->sy); y++) { for (x = 0; (x < im->sx); x++) { /* ROW-MAJOR IN GD 1.3 */ if (im->trueColor) { gdPutInt (im->tpixels[y][x], out); } else { gdPutC ((unsigned char) im->pixels[y][x], out); } } } } BGD_DECLARE(void) gdImageGd (gdImagePtr im, FILE * outFile) { gdIOCtx *out = gdNewFileCtx (outFile); if (out == NULL) return; _gdImageGd (im, out); out->gd_free (out); } BGD_DECLARE(void *) gdImageGdPtr (gdImagePtr im, int *size) { void *rv; gdIOCtx *out = gdNewDynamicCtx (2048, NULL); if (out == NULL) return NULL; _gdImageGd (im, out); rv = gdDPExtractData (out, size); out->gd_free (out); return rv; } libgd-gd-2.1.1/src/gd_gd2.c000066400000000000000000000616071245535672000152700ustar00rootroot00000000000000/* * gd_gd2.c * * Implements the I/O and support for the GD2 format. * * Changing the definition of GD2_DBG (below) will cause copious messages * to be displayed while it processes requests. * * Designed, Written & Copyright 1999, Philip Warner. * */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include /* 2.0.29: no more errno.h, makes windows happy */ #include #include #include #include "gd.h" #include "gd_errors.h" #include "gdhelpers.h" /* 2.03: gd2 is no longer mandatory */ /* JCE - test after including gd.h so that HAVE_LIBZ can be set in * a config.h file included by gd.h */ #ifdef HAVE_LIBZ #include #define TRUE 1 #define FALSE 0 /* 2.11: not part of the API, as the save routine can figure it out from im->trueColor, and the load routine doesn't need to tell the end user the saved format. NOTE: adding 2 is assumed to result in the correct format value for truecolor! */ #define GD2_FMT_TRUECOLOR_RAW 3 #define GD2_FMT_TRUECOLOR_COMPRESSED 4 #define gd2_compressed(fmt) (((fmt) == GD2_FMT_COMPRESSED) || \ ((fmt) == GD2_FMT_TRUECOLOR_COMPRESSED)) #define gd2_truecolor(fmt) (((fmt) == GD2_FMT_TRUECOLOR_RAW) || \ ((fmt) == GD2_FMT_TRUECOLOR_COMPRESSED)) /* Use this for commenting out debug-print statements. */ /* Just use the first '#define' to allow all the prints... */ /*#define GD2_DBG(s) (s) */ #define GD2_DBG(s) typedef struct { int offset; int size; } t_chunk_info; extern int _gdGetColors (gdIOCtx * in, gdImagePtr im, int gd2xFlag); extern void _gdPutColors (gdImagePtr im, gdIOCtx * out); /* */ /* Read the extra info in the gd2 header. */ /* */ static int _gd2GetHeader (gdIOCtxPtr in, int *sx, int *sy, int *cs, int *vers, int *fmt, int *ncx, int *ncy, t_chunk_info ** chunkIdx) { int i; int ch; char id[5]; t_chunk_info *cidx; int sidx; int nc; GD2_DBG (printf ("Reading gd2 header info\n")); for (i = 0; i < 4; i++) { ch = gdGetC (in); if (ch == EOF) { goto fail1; }; id[i] = ch; }; id[4] = 0; GD2_DBG (printf ("Got file code: %s\n", id)); /* Equiv. of 'magick'. */ if (strcmp (id, GD2_ID) != 0) { GD2_DBG (printf ("Not a valid gd2 file\n")); goto fail1; }; /* Version */ if (gdGetWord (vers, in) != 1) { goto fail1; }; GD2_DBG (printf ("Version: %d\n", *vers)); if ((*vers != 1) && (*vers != 2)) { GD2_DBG (printf ("Bad version: %d\n", *vers)); goto fail1; }; /* Image Size */ if (!gdGetWord (sx, in)) { GD2_DBG (printf ("Could not get x-size\n")); goto fail1; } if (!gdGetWord (sy, in)) { GD2_DBG (printf ("Could not get y-size\n")); goto fail1; } GD2_DBG (printf ("Image is %dx%d\n", *sx, *sy)); /* Chunk Size (pixels, not bytes!) */ if (gdGetWord (cs, in) != 1) { goto fail1; }; GD2_DBG (printf ("ChunkSize: %d\n", *cs)); if ((*cs < GD2_CHUNKSIZE_MIN) || (*cs > GD2_CHUNKSIZE_MAX)) { GD2_DBG (printf ("Bad chunk size: %d\n", *cs)); goto fail1; }; /* Data Format */ if (gdGetWord (fmt, in) != 1) { goto fail1; }; GD2_DBG (printf ("Format: %d\n", *fmt)); if ((*fmt != GD2_FMT_RAW) && (*fmt != GD2_FMT_COMPRESSED) && (*fmt != GD2_FMT_TRUECOLOR_RAW) && (*fmt != GD2_FMT_TRUECOLOR_COMPRESSED)) { GD2_DBG (printf ("Bad data format: %d\n", *fmt)); goto fail1; }; /* # of chunks wide */ if (gdGetWord (ncx, in) != 1) { goto fail1; }; GD2_DBG (printf ("%d Chunks Wide\n", *ncx)); /* # of chunks high */ if (gdGetWord (ncy, in) != 1) { goto fail1; }; GD2_DBG (printf ("%d Chunks vertically\n", *ncy)); if (gd2_compressed (*fmt)) { nc = (*ncx) * (*ncy); GD2_DBG (printf ("Reading %d chunk index entries\n", nc)); sidx = sizeof (t_chunk_info) * nc; cidx = gdCalloc (sidx, 1); if (!cidx) { goto fail1; } for (i = 0; i < nc; i++) { if (gdGetInt (&cidx[i].offset, in) != 1) { goto fail2; }; if (gdGetInt (&cidx[i].size, in) != 1) { goto fail2; }; }; *chunkIdx = cidx; }; GD2_DBG (printf ("gd2 header complete\n")); return 1; fail2: gdFree(cidx); fail1: return 0; } static gdImagePtr _gd2CreateFromFile (gdIOCtxPtr in, int *sx, int *sy, int *cs, int *vers, int *fmt, int *ncx, int *ncy, t_chunk_info ** cidx) { gdImagePtr im; if (_gd2GetHeader (in, sx, sy, cs, vers, fmt, ncx, ncy, cidx) != 1) { GD2_DBG (printf ("Bad GD2 header\n")); goto fail1; } if (gd2_truecolor (*fmt)) { im = gdImageCreateTrueColor (*sx, *sy); } else { im = gdImageCreate (*sx, *sy); } if (im == NULL) { GD2_DBG (printf ("Could not create gdImage\n")); goto fail2; }; if (!_gdGetColors (in, im, (*vers) == 2)) { GD2_DBG (printf ("Could not read color palette\n")); goto fail3; } GD2_DBG (printf ("Image palette completed: %d colours\n", im->colorsTotal)); return im; fail3: gdImageDestroy (im); fail2: gdFree(*cidx); fail1: return 0; } static int _gd2ReadChunk (int offset, char *compBuf, int compSize, char *chunkBuf, uLongf * chunkLen, gdIOCtx * in) { int zerr; if (gdTell (in) != offset) { GD2_DBG (printf ("Positioning in file to %d\n", offset)); gdSeek (in, offset); } else { GD2_DBG (printf ("Already Positioned in file to %d\n", offset)); }; /* Read and uncompress an entire chunk. */ GD2_DBG (printf ("Reading file\n")); if (gdGetBuf (compBuf, compSize, in) != compSize) { return FALSE; }; GD2_DBG (printf ("Got %d bytes. Uncompressing into buffer of %d bytes\n", compSize, *chunkLen)); zerr = uncompress ((unsigned char *) chunkBuf, chunkLen, (unsigned char *) compBuf, compSize); if (zerr != Z_OK) { GD2_DBG (printf ("Error %d from uncompress\n", zerr)); return FALSE; }; GD2_DBG (printf ("Got chunk\n")); return TRUE; } /* Function: gdImageCreateFromGd2 is called to load images from gd2 format files. Invoke with an already opened pointer to a file containing the desired image in the gd2 file format, which is specific to gd2 and intended for fast loading of parts of large images. (It is a compressed format, but generally not as good as maximum compression of the entire image would be.) returns a to the new image, or NULL if unable to load the image (most often because the file is corrupt or does not contain a gd format image). does not close the file. You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using . Variants: creates an image from GD data (i.e. the contents of a GD2 file) already in memory. reads in an image using the functions in a struct. Parameters: infile - The input FILE pointer Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > FILE *in; > in = fopen("mygd.gd2", "rb"); > im = gdImageCreateFromGd2(in); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2 (FILE * inFile) { gdIOCtx *in = gdNewFileCtx (inFile); gdImagePtr im; if (in == NULL) return NULL; im = gdImageCreateFromGd2Ctx (in); in->gd_free (in); return im; } /* Function: gdImageCreateFromGd2Ptr Parameters: size - size of GD2 data in bytes. data - GD2 data (i.e. contents of a GIF file). See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2Ptr (int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx (size, data, 0); if(!in) return 0; im = gdImageCreateFromGd2Ctx (in); in->gd_free (in); return im; } /* Function: gdImageCreateFromGd2Ctx Reads in a GD2 image via a struct. See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2Ctx (gdIOCtxPtr in) { int sx, sy; int i; int ncx, ncy, nc, cs, cx, cy; int x, y, ylo, yhi, xlo, xhi; int vers, fmt; t_chunk_info *chunkIdx = NULL; /* So we can gdFree it with impunity. */ unsigned char *chunkBuf = NULL; /* So we can gdFree it with impunity. */ int chunkNum = 0; int chunkMax = 0; uLongf chunkLen; int chunkPos = 0; int compMax = 0; int bytesPerPixel; char *compBuf = NULL; /* So we can gdFree it with impunity. */ gdImagePtr im; /* Get the header */ im = _gd2CreateFromFile (in, &sx, &sy, &cs, &vers, &fmt, &ncx, &ncy, &chunkIdx); if (im == NULL) { gdFree (chunkIdx); return 0; } bytesPerPixel = im->trueColor ? 4 : 1; nc = ncx * ncy; if (gd2_compressed (fmt)) { /* Find the maximum compressed chunk size. */ compMax = 0; for (i = 0; (i < nc); i++) { if (chunkIdx[i].size > compMax) { compMax = chunkIdx[i].size; }; }; compMax++; /* Allocate buffers */ chunkMax = cs * bytesPerPixel * cs; chunkBuf = gdCalloc (chunkMax, 1); if (!chunkBuf) { goto fail; } compBuf = gdCalloc (compMax, 1); if (!compBuf) { goto fail; } GD2_DBG (printf ("Largest compressed chunk is %d bytes\n", compMax)); }; /* if ( (ncx != sx / cs) || (ncy != sy / cs)) { */ /* goto fail2; */ /* }; */ /* Read the data... */ for (cy = 0; (cy < ncy); cy++) { for (cx = 0; (cx < ncx); cx++) { ylo = cy * cs; yhi = ylo + cs; if (yhi > im->sy) { yhi = im->sy; }; GD2_DBG (printf ("Processing Chunk %d (%d, %d), y from %d to %d\n", chunkNum, cx, cy, ylo, yhi)); if (gd2_compressed (fmt)) { chunkLen = chunkMax; if (!_gd2ReadChunk (chunkIdx[chunkNum].offset, compBuf, chunkIdx[chunkNum].size, (char *) chunkBuf, &chunkLen, in)) { GD2_DBG (printf ("Error reading comproessed chunk\n")); goto fail; }; chunkPos = 0; }; for (y = ylo; (y < yhi); y++) { xlo = cx * cs; xhi = xlo + cs; if (xhi > im->sx) { xhi = im->sx; }; /*GD2_DBG(printf("y=%d: ",y)); */ if (!gd2_compressed (fmt)) { for (x = xlo; x < xhi; x++) { if (im->trueColor) { if (!gdGetInt (&im->tpixels[y][x], in)) { /*printf("EOF while reading\n"); */ /*gdImageDestroy(im); */ /*return 0; */ im->tpixels[y][x] = 0; } } else { int ch; if (!gdGetByte (&ch, in)) { /*printf("EOF while reading\n"); */ /*gdImageDestroy(im); */ /*return 0; */ ch = 0; } im->pixels[y][x] = ch; } } } else { for (x = xlo; x < xhi; x++) { if (im->trueColor) { /* 2.0.1: work around a gcc bug by being verbose. TBB */ int a = chunkBuf[chunkPos++] << 24; int r = chunkBuf[chunkPos++] << 16; int g = chunkBuf[chunkPos++] << 8; int b = chunkBuf[chunkPos++]; /* 2.0.11: tpixels */ im->tpixels[y][x] = a + r + g + b; } else { im->pixels[y][x] = chunkBuf[chunkPos++]; } }; }; /*GD2_DBG(printf("\n")); */ }; chunkNum++; }; }; GD2_DBG (printf ("Freeing memory\n")); gdFree (chunkBuf); gdFree (compBuf); gdFree (chunkIdx); GD2_DBG (printf ("Done\n")); return im; fail: gdImageDestroy (im); if (chunkBuf) { gdFree (chunkBuf); } if (compBuf) { gdFree (compBuf); } if (chunkIdx) { gdFree (chunkIdx); } return 0; } /* Function: gdImageCreateFromGd2Part is called to load parts of images from gd2 format files. Invoked in the same way as , but with extra parameters indicating the source (x, y) and width/height of the desired image. returns a to the new image, or NULL if unable to load the image. The image must eventually be destroyed using . Variants: creates an image from GD2 data (i.e. the contents of a GD2 file) already in memory. reads in an image using the functions in a struct. Parameters: infile - The input FILE pointer srcx, srcy - The source X and Y coordinates w, h - The resulting image's width and height Returns: A pointer to the new image or NULL if an error occurred. */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2Part (FILE * inFile, int srcx, int srcy, int w, int h) { gdImagePtr im; gdIOCtx *in = gdNewFileCtx (inFile); if (in == NULL) return NULL; im = gdImageCreateFromGd2PartCtx (in, srcx, srcy, w, h); in->gd_free (in); return im; } /* Function: gdImageCreateFromGd2PartPtr Parameters: size - size of GD data in bytes. data - GD data (i.e. contents of a GIF file). srcx, srcy - The source X and Y coordinates w, h - The resulting image's width and height Reads in part of a GD2 image file stored from memory. See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2PartPtr (int size, void *data, int srcx, int srcy, int w, int h) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx (size, data, 0); if(!in) return 0; im = gdImageCreateFromGd2PartCtx (in, srcx, srcy, w, h); in->gd_free (in); return im; } /* Function: gdImageCreateFromGd2PartCtx Parameters: in - The data source. srcx, srcy - The source X and Y coordinates w, h - The resulting image's width and height Reads in part of a GD2 data image file via a struct. See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2PartCtx (gdIOCtx * in, int srcx, int srcy, int w, int h) { int scx, scy, ecx, ecy, fsx, fsy; int nc, ncx, ncy, cs, cx, cy; int x, y, ylo, yhi, xlo, xhi; int dstart, dpos; int i; /* 2.0.12: unsigned is correct; fixes problems with color munging. Thanks to Steven Brown. */ unsigned int ch; int vers, fmt; t_chunk_info *chunkIdx = NULL; unsigned char *chunkBuf = NULL; int chunkNum; int chunkMax = 0; uLongf chunkLen; int chunkPos = 0; int compMax; char *compBuf = NULL; gdImagePtr im; /* */ /* The next few lines are basically copied from gd2CreateFromFile */ /* - we change the file size, so don't want to use the code directly. */ /* but we do need to know the file size. */ /* */ if (_gd2GetHeader (in, &fsx, &fsy, &cs, &vers, &fmt, &ncx, &ncy, &chunkIdx) != 1) { goto fail1; } GD2_DBG (printf ("File size is %dx%d\n", fsx, fsy)); /* This is the difference - make a file based on size of chunks. */ if (gd2_truecolor (fmt)) { im = gdImageCreateTrueColor (w, h); } else { im = gdImageCreate (w, h); } if (im == NULL) { goto fail1; }; if (!_gdGetColors (in, im, vers == 2)) { goto fail2; } GD2_DBG (printf ("Image palette completed: %d colours\n", im->colorsTotal)); /* Process the header info */ nc = ncx * ncy; if (gd2_compressed (fmt)) { /* Find the maximum compressed chunk size. */ compMax = 0; for (i = 0; (i < nc); i++) { if (chunkIdx[i].size > compMax) { compMax = chunkIdx[i].size; }; }; compMax++; if (im->trueColor) { chunkMax = cs * cs * 4; } else { chunkMax = cs * cs; } chunkBuf = gdCalloc (chunkMax, 1); if (!chunkBuf) { goto fail2; } compBuf = gdCalloc (compMax, 1); if (!compBuf) { goto fail2; } }; /* Don't bother with this... */ /* if ( (ncx != sx / cs) || (ncy != sy / cs)) { */ /* goto fail2; */ /* }; */ /* Work out start/end chunks */ scx = srcx / cs; scy = srcy / cs; if (scx < 0) { scx = 0; }; if (scy < 0) { scy = 0; }; ecx = (srcx + w) / cs; ecy = (srcy + h) / cs; if (ecx >= ncx) { ecx = ncx - 1; }; if (ecy >= ncy) { ecy = ncy - 1; }; /* Remember file position of image data. */ dstart = gdTell (in); GD2_DBG (printf ("Data starts at %d\n", dstart)); /* Loop through the chunks. */ for (cy = scy; (cy <= ecy); cy++) { ylo = cy * cs; yhi = ylo + cs; if (yhi > fsy) { yhi = fsy; }; for (cx = scx; (cx <= ecx); cx++) { xlo = cx * cs; xhi = xlo + cs; if (xhi > fsx) { xhi = fsx; }; GD2_DBG (printf ("Processing Chunk (%d, %d), from %d to %d\n", cx, cy, ylo, yhi)); if (!gd2_compressed (fmt)) { GD2_DBG (printf ("Using raw format data\n")); if (im->trueColor) { dpos = (cy * (cs * fsx) * 4 + cx * cs * (yhi - ylo) * 4) + dstart; } else { dpos = cy * (cs * fsx) + cx * cs * (yhi - ylo) + dstart; } /* gd 2.0.11: gdSeek returns TRUE on success, not 0. Longstanding bug. 01/16/03 */ if (!gdSeek (in, dpos)) { gd_error("Seek error\n"); goto fail2; }; GD2_DBG (printf ("Reading (%d, %d) from position %d\n", cx, cy, dpos - dstart)); } else { chunkNum = cx + cy * ncx; chunkLen = chunkMax; if (!_gd2ReadChunk (chunkIdx[chunkNum].offset, compBuf, chunkIdx[chunkNum].size, (char *) chunkBuf, &chunkLen, in)) { printf ("Error reading comproessed chunk\n"); goto fail2; }; chunkPos = 0; GD2_DBG (printf ("Reading (%d, %d) from chunk %d\n", cx, cy, chunkNum)); }; GD2_DBG (printf (" into (%d, %d) - (%d, %d)\n", xlo, ylo, xhi, yhi)); for (y = ylo; (y < yhi); y++) { for (x = xlo; x < xhi; x++) { if (!gd2_compressed (fmt)) { if (im->trueColor) { if (!gdGetInt ((int *) &ch, in)) { ch = 0; /*printf("EOF while reading file\n"); */ /*goto fail2; */ } } else { ch = gdGetC (in); if ((int) ch == EOF) { ch = 0; /*printf("EOF while reading file\n"); */ /*goto fail2; */ } } } else { if (im->trueColor) { ch = chunkBuf[chunkPos++]; ch = (ch << 8) + chunkBuf[chunkPos++]; ch = (ch << 8) + chunkBuf[chunkPos++]; ch = (ch << 8) + chunkBuf[chunkPos++]; } else { ch = chunkBuf[chunkPos++]; } }; /* Only use a point that is in the image. */ if ((x >= srcx) && (x < (srcx + w)) && (x < fsx) && (x >= 0) && (y >= srcy) && (y < (srcy + h)) && (y < fsy) && (y >= 0)) { /* 2.0.11: tpixels */ if (im->trueColor) { im->tpixels[y - srcy][x - srcx] = ch; } else { im->pixels[y - srcy][x - srcx] = ch; } } }; }; }; }; gdFree (chunkBuf); gdFree (compBuf); gdFree (chunkIdx); return im; fail2: gdImageDestroy (im); fail1: if (chunkBuf) { gdFree (chunkBuf); } if (compBuf) { gdFree (compBuf); } if (chunkIdx) { gdFree (chunkIdx); } return 0; } static void _gd2PutHeader (gdImagePtr im, gdIOCtx * out, int cs, int fmt, int cx, int cy) { int i; /* Send the gd2 id, to verify file format. */ for (i = 0; i < 4; i++) { gdPutC ((unsigned char) (GD2_ID[i]), out); }; /* */ /* We put the version info first, so future versions can easily change header info. */ /* */ gdPutWord (GD2_VERS, out); gdPutWord (im->sx, out); gdPutWord (im->sy, out); gdPutWord (cs, out); gdPutWord (fmt, out); gdPutWord (cx, out); gdPutWord (cy, out); } static void _gdImageGd2 (gdImagePtr im, gdIOCtx * out, int cs, int fmt) { int ncx, ncy, cx, cy; int x, y, ylo, yhi, xlo, xhi; int chunkLen; int chunkNum = 0; char *chunkData = NULL; /* So we can gdFree it with impunity. */ char *compData = NULL; /* So we can gdFree it with impunity. */ uLongf compLen; int idxPos = 0; int idxSize; t_chunk_info *chunkIdx = NULL; int posSave; int bytesPerPixel = im->trueColor ? 4 : 1; int compMax = 0; /*printf("Trying to write GD2 file\n"); */ /* */ /* Force fmt to a valid value since we don't return anything. */ /* */ if ((fmt != GD2_FMT_RAW) && (fmt != GD2_FMT_COMPRESSED)) { fmt = im->trueColor ? GD2_FMT_TRUECOLOR_COMPRESSED : GD2_FMT_COMPRESSED; }; if (im->trueColor) { fmt += 2; } /* */ /* Make sure chunk size is valid. These are arbitrary values; 64 because it seems */ /* a little silly to expect performance improvements on a 64x64 bit scale, and */ /* 4096 because we buffer one chunk, and a 16MB buffer seems a little large - it may be */ /* OK for one user, but for another to read it, they require the buffer. */ /* */ if (cs == 0) { cs = GD2_CHUNKSIZE; } else if (cs < GD2_CHUNKSIZE_MIN) { cs = GD2_CHUNKSIZE_MIN; } else if (cs > GD2_CHUNKSIZE_MAX) { cs = GD2_CHUNKSIZE_MAX; }; /* Work out number of chunks. */ ncx = im->sx / cs + 1; ncy = im->sy / cs + 1; /* Write the standard header. */ _gd2PutHeader (im, out, cs, fmt, ncx, ncy); if (gd2_compressed (fmt)) { /* */ /* Work out size of buffer for compressed data, If CHUNKSIZE is large, */ /* then these will be large! */ /* */ /* The zlib notes say output buffer size should be (input size) * 1.01 * 12 */ /* - we'll use 1.02 to be paranoid. */ /* */ compMax = cs * bytesPerPixel * cs * 1.02 + 12; /* */ /* Allocate the buffers. */ /* */ chunkData = gdCalloc (cs * bytesPerPixel * cs, 1); if (!chunkData) { goto fail; } compData = gdCalloc (compMax, 1); if (!compData) { goto fail; } /* */ /* Save the file position of chunk index, and allocate enough space for */ /* each chunk_info block . */ /* */ idxPos = gdTell (out); idxSize = ncx * ncy * sizeof (t_chunk_info); GD2_DBG (printf ("Index size is %d\n", idxSize)); gdSeek (out, idxPos + idxSize); chunkIdx = gdCalloc (idxSize * sizeof (t_chunk_info), 1); if (!chunkIdx) { goto fail; } }; _gdPutColors (im, out); GD2_DBG (printf ("Size: %dx%d\n", im->sx, im->sy)); GD2_DBG (printf ("Chunks: %dx%d\n", ncx, ncy)); for (cy = 0; (cy < ncy); cy++) { for (cx = 0; (cx < ncx); cx++) { ylo = cy * cs; yhi = ylo + cs; if (yhi > im->sy) { yhi = im->sy; }; GD2_DBG (printf ("Processing Chunk (%dx%d), y from %d to %d\n", cx, cy, ylo, yhi)); chunkLen = 0; for (y = ylo; (y < yhi); y++) { /*GD2_DBG(printf("y=%d: ",y)); */ xlo = cx * cs; xhi = xlo + cs; if (xhi > im->sx) { xhi = im->sx; }; if (gd2_compressed (fmt)) { for (x = xlo; x < xhi; x++) { /* 2.0.11: use truecolor pixel array. TBB */ /*GD2_DBG(printf("%d...",x)); */ if (im->trueColor) { int p = im->tpixels[y][x]; chunkData[chunkLen++] = gdTrueColorGetAlpha (p); chunkData[chunkLen++] = gdTrueColorGetRed (p); chunkData[chunkLen++] = gdTrueColorGetGreen (p); chunkData[chunkLen++] = gdTrueColorGetBlue (p); } else { int p = im->pixels[y][x]; chunkData[chunkLen++] = p; } }; } else { for (x = xlo; x < xhi; x++) { /*GD2_DBG(printf("%d, ",x)); */ if (im->trueColor) { gdPutInt (im->tpixels[y][x], out); } else { gdPutC ((unsigned char) im->pixels[y][x], out); } }; }; /*GD2_DBG(printf("y=%d done.\n",y)); */ }; if (gd2_compressed (fmt)) { compLen = compMax; if (compress ((unsigned char *) &compData[0], &compLen, (unsigned char *) &chunkData[0], chunkLen) != Z_OK) { printf ("Error from compressing\n"); } else { chunkIdx[chunkNum].offset = gdTell (out); chunkIdx[chunkNum++].size = compLen; GD2_DBG (printf ("Chunk %d size %d offset %d\n", chunkNum, chunkIdx[chunkNum - 1].size, chunkIdx[chunkNum - 1].offset)); if (gdPutBuf (compData, compLen, out) <= 0) { gd_error("gd write error\n"); }; }; }; }; }; if (gd2_compressed (fmt)) { /* Save the position, write the index, restore position (paranoia). */ GD2_DBG (printf ("Seeking %d to write index\n", idxPos)); posSave = gdTell (out); gdSeek (out, idxPos); GD2_DBG (printf ("Writing index\n")); for (x = 0; x < chunkNum; x++) { GD2_DBG (printf ("Chunk %d size %d offset %d\n", x, chunkIdx[x].size, chunkIdx[x].offset)); gdPutInt (chunkIdx[x].offset, out); gdPutInt (chunkIdx[x].size, out); }; /* We don't use fwrite for *endian reasons. */ /*fwrite(chunkIdx, sizeof(int)*2, chunkNum, out); */ gdSeek (out, posSave); }; /*printf("Memory block size is %d\n",gdTell(out)); */ fail: GD2_DBG (printf ("Freeing memory\n")); if (chunkData) { gdFree (chunkData); } if (compData) { gdFree (compData); } if (chunkIdx) { gdFree (chunkIdx); } GD2_DBG (printf ("Done\n")); } BGD_DECLARE(void) gdImageGd2 (gdImagePtr im, FILE * outFile, int cs, int fmt) { gdIOCtx *out = gdNewFileCtx (outFile); if (out == NULL) return; _gdImageGd2 (im, out, cs, fmt); out->gd_free (out); } BGD_DECLARE(void *) gdImageGd2Ptr (gdImagePtr im, int cs, int fmt, int *size) { void *rv; gdIOCtx *out = gdNewDynamicCtx (2048, NULL); if (out == NULL) return NULL; _gdImageGd2 (im, out, cs, fmt); rv = gdDPExtractData (out, size); out->gd_free (out); return rv; } #else /* no HAVE_LIBZ */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2 (FILE * inFile) { gd_error("GD2 support is not available - no libz\n"); return NULL; } BGD_DECLARE(gdImagePtr) gdImageCreateFromGd2Ctx (gdIOCtxPtr in) { gd_error("GD2 support is not available - no libz\n"); return NULL; } #endif /* HAVE_LIBZ */ libgd-gd-2.1.1/src/gd_gif_in.c000066400000000000000000000354501245535672000160440ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include #include "gd.h" /* Used only when debugging GIF compression code */ /* #define DEBUGGING_ENVARS */ #ifdef DEBUGGING_ENVARS static int verbose_set = 0; static int verbose; #define VERBOSE (verbose_set ? verbose : set_verbose()) static int set_verbose(void) { verbose = !!getenv("GIF_VERBOSE"); verbose_set = 1; return(verbose); } #else #define VERBOSE 0 #endif #define MAXCOLORMAPSIZE 256 #define TRUE 1 #define FALSE 0 #define CM_RED 0 #define CM_GREEN 1 #define CM_BLUE 2 #define MAX_LWZ_BITS 12 #define INTERLACE 0x40 #define LOCALCOLORMAP 0x80 #define BitSet(byte, bit) (((byte) & (bit)) == (bit)) #define ReadOK(file, buffer, len) (gdGetBuf(buffer, len, file) > 0) #define LM_to_uint(a, b) (((b)<<8)|(a)) /* We may eventually want to use this information, but def it out for now */ #if 0 static struct { unsigned int Width; unsigned int Height; unsigned char ColorMap[3][MAXCOLORMAPSIZE]; unsigned int BitPixel; unsigned int ColorResolution; unsigned int Background; unsigned int AspectRatio; } GifScreen; #endif #if 0 static struct { int transparent; int delayTime; int inputFlag; int disposal; } Gif89 = { -1, -1, -1, 0 }; #endif #define STACK_SIZE ((1<<(MAX_LWZ_BITS))*2) #define CSD_BUF_SIZE 280 typedef struct { unsigned char buf[CSD_BUF_SIZE]; int curbit; int lastbit; int done; int last_byte; } CODE_STATIC_DATA; typedef struct { int fresh; int code_size, set_code_size; int max_code, max_code_size; int firstcode, oldcode; int clear_code, end_code; int table[2][(1<< MAX_LWZ_BITS)]; int stack[STACK_SIZE], *sp; CODE_STATIC_DATA scd; } LZW_STATIC_DATA; static int ReadColorMap (gdIOCtx *fd, int number, unsigned char (*buffer)[256]); static int DoExtension (gdIOCtx *fd, int label, int *Transparent, int *ZeroDataBlockP); static int GetDataBlock (gdIOCtx *fd, unsigned char *buf, int *ZeroDataBlockP); static int GetCode (gdIOCtx *fd, CODE_STATIC_DATA *scd, int code_size, int flag, int *ZeroDataBlockP); static int LWZReadByte (gdIOCtx *fd, LZW_STATIC_DATA *sd, char flag, int input_code_size, int *ZeroDataBlockP); static void ReadImage (gdImagePtr im, gdIOCtx *fd, int len, int height, unsigned char (*cmap)[256], int interlace, int *ZeroDataBlockP); /*1.4//, int ignore); */ /* Function: gdImageCreateFromGif is called to load images from GIF format files. Invoke with an already opened pointer to a file containing the desired image. returns a to the new image, or NULL if unable to load the image (most often because the file is corrupt or does not contain a GIF image). does not close the file. You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using . Variants: creates an image from GIF data (i.e. the contents of a GIF file) already in memory. reads in an image using the functions in a struct. Parameters: infile - The input FILE pointer Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > ... inside a function ... > FILE *in; > in = fopen("mygif.gif", "rb"); > im = gdImageCreateFromGif(in); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGif(FILE *fdFile) { gdIOCtx *fd = gdNewFileCtx(fdFile); gdImagePtr im; if (fd == NULL) return NULL; im = gdImageCreateFromGifCtx(fd); fd->gd_free(fd); return im; } /* Function: gdImageCreateFromGifPtr Parameters: size - size of GIF data in bytes. data - GIF data (i.e. contents of a GIF file). See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGifPtr (int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx(size, data, 0); if(!in) { return 0; } im = gdImageCreateFromGifCtx(in); in->gd_free(in); return im; } /* Function: gdImageCreateFromGifCtx See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromGifCtx(gdIOCtxPtr fd) { int BitPixel; #if 0 int ColorResolution; int Background; int AspectRatio; #endif int Transparent = (-1); unsigned char buf[16]; unsigned char c; unsigned char ColorMap[3][MAXCOLORMAPSIZE]; unsigned char localColorMap[3][MAXCOLORMAPSIZE]; int imw, imh, screen_width, screen_height; int useGlobalColormap; int bitPixel, i; /*1.4//int imageCount = 0; */ /* 2.0.28: threadsafe storage */ int ZeroDataBlock = FALSE; int haveGlobalColormap; gdImagePtr im = 0; if(!ReadOK(fd, buf, 6)) { return 0; } if(strncmp((char *)buf, "GIF", 3) != 0) { return 0; } if(memcmp((char *)buf + 3, "87a", 3) == 0) { /* GIF87a */ } else if(memcmp((char *)buf + 3, "89a", 3) == 0) { /* GIF89a */ } else { return 0; } if(!ReadOK(fd, buf, 7)) { return 0; } BitPixel = 2 << (buf[4] & 0x07); #if 0 ColorResolution = (int) (((buf[4]&0x70)>>3)+1); Background = buf[5]; AspectRatio = buf[6]; #endif screen_width = imw = LM_to_uint(buf[0], buf[1]); screen_height = imh = LM_to_uint(buf[2], buf[3]); haveGlobalColormap = BitSet(buf[4], LOCALCOLORMAP); /* Global Colormap */ if(haveGlobalColormap) { if(ReadColorMap(fd, BitPixel, ColorMap)) { return 0; } } for (;;) { int top, left; int width, height; if(!ReadOK(fd, &c, 1)) { return 0; } if (c == ';') { /* GIF terminator */ goto terminated; } if(c == '!') { /* Extension */ if(!ReadOK(fd, &c, 1)) { return 0; } DoExtension(fd, c, &Transparent, &ZeroDataBlock); continue; } if(c != ',') { /* Not a valid start character */ continue; } /*1.4//++imageCount; */ if(!ReadOK(fd, buf, 9)) { return 0; } useGlobalColormap = !BitSet(buf[8], LOCALCOLORMAP); bitPixel = 1 << ((buf[8] & 0x07) + 1); left = LM_to_uint(buf[0], buf[1]); top = LM_to_uint(buf[2], buf[3]); width = LM_to_uint(buf[4], buf[5]); height = LM_to_uint(buf[6], buf[7]); if(((left + width) > screen_width) || ((top + height) > screen_height)) { if(VERBOSE) { printf("Frame is not confined to screen dimension.\n"); } return 0; } if(!(im = gdImageCreate(width, height))) { return 0; } im->interlace = BitSet(buf[8], INTERLACE); if(!useGlobalColormap) { if(ReadColorMap(fd, bitPixel, localColorMap)) { gdImageDestroy(im); return 0; } ReadImage(im, fd, width, height, localColorMap, BitSet(buf[8], INTERLACE), &ZeroDataBlock); } else { if(!haveGlobalColormap) { gdImageDestroy(im); return 0; } ReadImage(im, fd, width, height, ColorMap, BitSet(buf[8], INTERLACE), &ZeroDataBlock); } if(Transparent != (-1)) { gdImageColorTransparent(im, Transparent); } goto terminated; } terminated: /* Terminator before any image was declared! */ if(!im) { return 0; } if(!im->colorsTotal) { gdImageDestroy(im); return 0; } /* Check for open colors at the end, so * we can reduce colorsTotal and ultimately * BitsPerPixel */ for(i = im->colorsTotal - 1; i >= 0; i--) { if(im->open[i]) { im->colorsTotal--; } else { break; } } return im; } static int ReadColorMap(gdIOCtx *fd, int number, unsigned char (*buffer)[256]) { int i; unsigned char rgb[3]; for(i = 0; i < number; ++i) { if(!ReadOK(fd, rgb, sizeof(rgb))) { return TRUE; } buffer[CM_RED][i] = rgb[0]; buffer[CM_GREEN][i] = rgb[1]; buffer[CM_BLUE][i] = rgb[2]; } return FALSE; } static int DoExtension(gdIOCtx *fd, int label, int *Transparent, int *ZeroDataBlockP) { unsigned char buf[256]; switch(label) { case 0xf9: /* Graphic Control Extension */ memset(buf, 0, 4); /* initialize a few bytes in the case the next function fails */ (void) GetDataBlock(fd, (unsigned char*) buf, ZeroDataBlockP); #if 0 Gif89.disposal = (buf[0] >> 2) & 0x7; Gif89.inputFlag = (buf[0] >> 1) & 0x1; Gif89.delayTime = LM_to_uint(buf[1], buf[2]); #endif if((buf[0] & 0x1) != 0) { *Transparent = buf[3]; } while(GetDataBlock(fd, (unsigned char*) buf, ZeroDataBlockP) > 0); return FALSE; default: break; } while(GetDataBlock(fd, (unsigned char*) buf, ZeroDataBlockP) > 0); return FALSE; } static int GetDataBlock_(gdIOCtx *fd, unsigned char *buf, int *ZeroDataBlockP) { unsigned char count; if(!ReadOK(fd, &count, 1)) { return -1; } *ZeroDataBlockP = count == 0; if((count != 0) && (!ReadOK(fd, buf, count))) { return -1; } return count; } static int GetDataBlock(gdIOCtx *fd, unsigned char *buf, int *ZeroDataBlockP) { int rv, i; rv = GetDataBlock_(fd,buf, ZeroDataBlockP); if(VERBOSE) { printf("[GetDataBlock returning %d",rv); if(rv > 0) { printf(":"); for(i = 0; i < rv; i++) { printf(" %02x",buf[i]); } } printf("]\n"); } return rv; } static int GetCode_(gdIOCtx *fd, CODE_STATIC_DATA *scd, int code_size, int flag, int *ZeroDataBlockP) { int i, j, ret; unsigned char count; if(flag) { scd->curbit = 0; scd->lastbit = 0; scd->last_byte = 0; scd->done = FALSE; return 0; } if((scd->curbit + code_size) >= scd->lastbit) { if(scd->done) { if(scd->curbit >= scd->lastbit) { /* Oh well */ } return -1; } scd->buf[0] = scd->buf[scd->last_byte - 2]; scd->buf[1] = scd->buf[scd->last_byte - 1]; if((count = GetDataBlock(fd, &scd->buf[2], ZeroDataBlockP)) <= 0) { scd->done = TRUE; } scd->last_byte = 2 + count; scd->curbit = (scd->curbit - scd->lastbit) + 16; scd->lastbit = (2 + count) * 8; } if ((scd->curbit + code_size - 1) >= (CSD_BUF_SIZE * 8)) { ret = -1; } else { ret = 0; for (i = scd->curbit, j = 0; j < code_size; ++i, ++j) { ret |= ((scd->buf[i / 8] & (1 << (i % 8))) != 0) << j; } } scd->curbit += code_size; return ret; } static int GetCode(gdIOCtx *fd, CODE_STATIC_DATA *scd, int code_size, int flag, int *ZeroDataBlockP) { int rv; rv = GetCode_(fd, scd, code_size,flag, ZeroDataBlockP); if(VERBOSE) { printf("[GetCode(,%d,%d) returning %d]\n",code_size,flag,rv); } return rv; } static int LWZReadByte_(gdIOCtx *fd, LZW_STATIC_DATA *sd, char flag, int input_code_size, int *ZeroDataBlockP) { int code, incode, i; if(flag) { sd->set_code_size = input_code_size; sd->code_size = sd->set_code_size + 1; sd->clear_code = 1 << sd->set_code_size; sd->end_code = sd->clear_code + 1; sd->max_code_size = 2 * sd->clear_code; sd->max_code = sd->clear_code + 2; GetCode(fd, &sd->scd, 0, TRUE, ZeroDataBlockP); sd->fresh = TRUE; for(i = 0; i < sd->clear_code; ++i) { sd->table[0][i] = 0; sd->table[1][i] = i; } for(; i < (1 << MAX_LWZ_BITS); ++i) { sd->table[0][i] = sd->table[1][0] = 0; } sd->sp = sd->stack; return 0; } else if(sd->fresh) { sd->fresh = FALSE; do { sd->firstcode = sd->oldcode = GetCode(fd, &sd->scd, sd->code_size, FALSE, ZeroDataBlockP); } while(sd->firstcode == sd->clear_code); return sd->firstcode; } if(sd->sp > sd->stack) { return *--sd->sp; } while((code = GetCode(fd, &sd->scd, sd->code_size, FALSE, ZeroDataBlockP)) >= 0) { if(code == sd->clear_code) { for(i = 0; i < sd->clear_code; ++i) { sd->table[0][i] = 0; sd->table[1][i] = i; } for (; i < (1 << MAX_LWZ_BITS); ++i) { sd->table[0][i] = sd->table[1][i] = 0; } sd->code_size = sd->set_code_size + 1; sd->max_code_size = 2 * sd->clear_code; sd->max_code = sd->clear_code + 2; sd->sp = sd->stack; sd->firstcode = sd->oldcode = GetCode(fd, &sd->scd, sd->code_size, FALSE, ZeroDataBlockP); return sd->firstcode; } else if(code == sd->end_code) { int count; unsigned char buf[260]; if(*ZeroDataBlockP) { return -2; } while((count = GetDataBlock(fd, buf, ZeroDataBlockP)) > 0); if(count != 0) { return -2; } } incode = code; if(sd->sp == (sd->stack + STACK_SIZE)) { /* Bad compressed data stream */ return -1; } if(code >= sd->max_code) { *sd->sp++ = sd->firstcode; code = sd->oldcode; } while(code >= sd->clear_code) { if(sd->sp == (sd->stack + STACK_SIZE)) { /* Bad compressed data stream */ return -1; } *sd->sp++ = sd->table[1][code]; if(code == sd->table[0][code]) { /* Oh well */ } code = sd->table[0][code]; } *sd->sp++ = sd->firstcode = sd->table[1][code]; if((code = sd->max_code) < (1 << MAX_LWZ_BITS)) { sd->table[0][code] = sd->oldcode; sd->table[1][code] = sd->firstcode; ++sd->max_code; if((sd->max_code >= sd->max_code_size) && (sd->max_code_size < (1<max_code_size *= 2; ++sd->code_size; } } sd->oldcode = incode; if(sd->sp > sd->stack) { return *--sd->sp; } } return code; } static int LWZReadByte(gdIOCtx *fd, LZW_STATIC_DATA *sd, char flag, int input_code_size, int *ZeroDataBlockP) { int rv; rv = LWZReadByte_(fd, sd, flag, input_code_size, ZeroDataBlockP); if(VERBOSE) { printf("[LWZReadByte(,%d,%d) returning %d]\n",flag,input_code_size,rv); } return rv; } static void ReadImage(gdImagePtr im, gdIOCtx *fd, int len, int height, unsigned char (*cmap)[256], int interlace, int *ZeroDataBlockP) /*1.4//, int ignore) */ { unsigned char c; int xpos = 0, ypos = 0, pass = 0; int v, i; LZW_STATIC_DATA sd; /* Initialize the Compression routines */ if(!ReadOK(fd, &c, 1)) { return; } if(c > MAX_LWZ_BITS) { return; } /* Stash the color map into the image */ for(i=0; (i < gdMaxColors); i++) { im->red[i] = cmap[CM_RED][i]; im->green[i] = cmap[CM_GREEN][i]; im->blue[i] = cmap[CM_BLUE][i]; im->open[i] = 1; } /* Many (perhaps most) of these colors will remain marked open. */ im->colorsTotal = gdMaxColors; if(LWZReadByte(fd, &sd, TRUE, c, ZeroDataBlockP) < 0) { return; } /* ** If this is an "uninteresting picture" ignore it. ** REMOVED For 1.4 */ /*if (ignore) { */ /* while (LWZReadByte(fd, &sd, FALSE, c) >= 0) */ /* ; */ /* return; */ /*} */ while((v = LWZReadByte(fd, &sd, FALSE, c, ZeroDataBlockP)) >= 0 ) { if(v >= gdMaxColors) { v = 0; } /* This how we recognize which colors are actually used. */ if(im->open[v]) { im->open[v] = 0; } gdImageSetPixel(im, xpos, ypos, v); ++xpos; if(xpos == len) { xpos = 0; if(interlace) { switch (pass) { case 0: case 1: ypos += 8; break; case 2: ypos += 4; break; case 3: ypos += 2; break; } if(ypos >= height) { ++pass; switch (pass) { case 1: ypos = 4; break; case 2: ypos = 2; break; case 3: ypos = 1; break; default: goto fini; } } } else { ++ypos; } } if(ypos >= height) { break; } } fini: if(LWZReadByte(fd, &sd, FALSE, c, ZeroDataBlockP) >=0) { /* Ignore extra */ } } libgd-gd-2.1.1/src/gd_gif_out.c000066400000000000000000001211751245535672000162450ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include #include "gd.h" #include "gdhelpers.h" /* Code drawn from ppmtogif.c, from the pbmplus package ** ** Based on GIFENCOD by David Rowley . A ** Lempel-Zim compression based on "compress". ** ** Modified by Marcel Wijkstra ** ** Copyright (C) 1989 by Jef Poskanzer. ** ** Permission to use, copy, modify, and distribute this software and its ** documentation for any purpose and without fee is hereby granted, provided ** that the above copyright notice appear in all copies and that both that ** copyright notice and this permission notice appear in supporting ** documentation. This software is provided "as is" without express or ** implied warranty. ** ** The Graphics Interchange Format(c) is the Copyright property of ** CompuServe Incorporated. GIF(sm) is a Service Mark property of ** CompuServe Incorporated. */ /* a code_int must be able to hold 2**GIFBITS values of type int, and also -1 */ typedef int code_int; #ifdef SIGNED_COMPARE_SLOW typedef unsigned long int count_int; typedef unsigned short int count_short; #else /* SIGNED_COMPARE_SLOW */ typedef long int count_int; #endif /* SIGNED_COMPARE_SLOW */ /* 2.0.28: threadsafe */ #define maxbits GIFBITS /* should NEVER generate this code */ #define maxmaxcode ((code_int)1 << GIFBITS) #define HSIZE 5003 /* 80% occupancy */ #define hsize HSIZE /* Apparently invariant, left over from compress */ typedef struct { int Width, Height; int curx, cury; long CountDown; int Pass; int Interlace; int n_bits; code_int maxcode; count_int htab [HSIZE]; unsigned short codetab [HSIZE]; /* first unused entry */ code_int free_ent; /* block compression parameters -- after all codes are used up, * and compression rate changes, start over. */ int clear_flg; int offset; long int in_count; /* # of codes output (for debugging) */ long int out_count; int g_init_bits; gdIOCtx * g_outfile; int ClearCode; int EOFCode; unsigned long cur_accum; int cur_bits; int a_count; char accum[ 256 ]; } GifCtx; static int gifPutWord(int w, gdIOCtx *out); static int colorstobpp(int colors); static void BumpPixel(GifCtx *ctx); static int GIFNextPixel(gdImagePtr im, GifCtx *ctx); static void GIFEncode(gdIOCtxPtr fp, int GWidth, int GHeight, int GInterlace, int Background, int Transparent, int BitsPerPixel, int *Red, int *Green, int *Blue, gdImagePtr im); static void GIFAnimEncode(gdIOCtxPtr fp, int IWidth, int IHeight, int LeftOfs, int TopOfs, int GInterlace, int Transparent, int Delay, int Disposal, int BitsPerPixel, int *Red, int *Green, int *Blue, gdImagePtr im); static void compress(int init_bits, gdIOCtx *outfile, gdImagePtr im, GifCtx *ctx); static void output(code_int code, GifCtx *ctx); static void cl_block(GifCtx *ctx); static void cl_hash(register count_int chsize, GifCtx *ctx); static void char_init(GifCtx *ctx); static void char_out(int c, GifCtx *ctx); static void flush_char(GifCtx *ctx); /* Function: gdImageGifPtr Identical to except that it returns a pointer to a memory area with the GIF data. This memory must be freed by the caller when it is no longer needed. The caller *must* invoke , not _free()_. This is because it is not guaranteed that libgd will use the same implementation of malloc, free, etc. as your proggram. The 'size' parameter receives the total size of the block of memory. Parameters: im - The image to write size - Output: the size of the resulting image. Returns: A pointer to the GIF data or NULL if an error occurred. */ BGD_DECLARE(void *) gdImageGifPtr(gdImagePtr im, int *size) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); if (out == NULL) return NULL; gdImageGifCtx(im, out); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } /* Function: gdImageGif outputs the specified image to the specified file in GIF format. The file must be open for binary writing. (Under MSDOS and all versions of Windows, it is important to use "wb" as opposed to simply "w" as the mode when opening the file; under Unix there is no penalty for doing so). does not close the file; your code must do so. GIF does not support true color; GIF images can contain a maximum of 256 colors. If the image to be written is a truecolor image, such as those created with gdImageCreateTrueColor or loaded from a JPEG or a truecolor PNG image file, a palette-based temporary image will automatically be created internally using the function. The original image pixels are not modified. This conversion produces high quality palettes but does require some CPU time. If you are regularly converting truecolor to palette in this way, you should consider creating your image as a palette-based image in the first place. Variants: outputs the image via a struct. stores the image in a large array of bytes. Parameters: im - The image to write outFile - The FILE pointer to write the image to. Returns: Nothing Example: > gdImagePtr im; > int black, white; > FILE *out; > // Create the image > im = gdImageCreate(100, 100); > // Allocate background > white = gdImageColorAllocate(im, 255, 255, 255); > // Allocate drawing color > black = gdImageColorAllocate(im, 0, 0, 0); > // Draw rectangle > gdImageRectangle(im, 0, 0, 99, 99, black); > // Open output file in binary mode > out = fopen("rect.gif", "wb"); > // Write GIF > gdImageGif(im, out); > // Close file > fclose(out); > // Destroy image > gdImageDestroy(im); */ BGD_DECLARE(void) gdImageGif(gdImagePtr im, FILE *outFile) { gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageGifCtx(im, out); out->gd_free(out); } /* Function: gdImageGifCtx Writes a GIF image via a . See . Parameters: im - The image to write out - The struct used to do the writing. Returns: Nothing. */ BGD_DECLARE(void) gdImageGifCtx(gdImagePtr im, gdIOCtxPtr out) { gdImagePtr pim = 0, tim = im; int interlace, BitsPerPixel; interlace = im->interlace; if(im->trueColor) { /* Expensive, but the only way that produces an acceptable result: mix down to a palette based temporary image. */ pim = gdImageCreatePaletteFromTrueColor(im, 1, 256); if(!pim) { return; } tim = pim; } BitsPerPixel = colorstobpp(tim->colorsTotal); /* All set, let's do it. */ GIFEncode( out, tim->sx, tim->sy, interlace, 0, tim->transparent, BitsPerPixel, tim->red, tim->green, tim->blue, tim); if(pim) { /* Destroy palette based temporary image. */ gdImageDestroy( pim); } } /* Function: gdImageGifAnimBeginPtr Like except that it outputs to a memory buffer. See . The returned memory must be freed by the caller when it is no longer needed. **The caller must invoke (), not free()**, unless the caller is absolutely certain that the same implementations of malloc, free, etc. are used both at library build time and at application build time (but don't; it could always change). The 'size' parameter receives the total size of the block of memory. Parameters: im - The reference image size - Output: the size in bytes of the result. GlobalCM - Global colormap flag: 1 -> yes, 0 -> no, -1 -> do default Loops - Loop count; 0 -> infinite, -1 means no loop Returns: A pointer to the resulting data (the contents of the start of the GIF) or NULL if an error occurred. */ BGD_DECLARE(void *) gdImageGifAnimBeginPtr(gdImagePtr im, int *size, int GlobalCM, int Loops) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); if (out == NULL) return NULL; gdImageGifAnimBeginCtx(im, out, GlobalCM, Loops); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } /* Function: gdImageGifAnimBegin This function must be called as the first function when creating a GIF animation. It writes the correct GIF file headers to selected file output, and prepares for frames to be added for the animation. The image argument is not used to produce an image frame to the file, it is only used to establish the GIF animation frame size, interlacing options and the color palette. is used to add the first and subsequent frames to the animation, and the animation must be terminated by writing a semicolon character (;) to it or by using gdImageGifAnimEnd to do that. The GlobalCM flag indicates if a global color map (or palette) is used in the GIF89A header. A nonzero value specifies that a global color map should be used to reduce the size of the animation. Of course, if the color maps of individual frames differ greatly, a global color map may not be a good idea. GlobalCM=1 means write global color map, GlobalCM=0 means do not, and GlobalCM=-1 means to do the default, which currently is to use a global color map. If Loops is 0 or greater, the Netscape 2.0 extension for animation loop count is written. 0 means infinite loop count. -1 means that the extension is not added which results in no looping. -1 is the default. Variants: outputs the image via a struct. stores the image in a large array of bytes. Parameters: im - The reference image outfile - The output FILE*. GlobalCM - Global colormap flag: 1 -> yes, 0 -> no, -1 -> do default Loops - Loop count; 0 -> infinite, -1 means no loop Returns: Nothing. Example: See . */ BGD_DECLARE(void) gdImageGifAnimBegin(gdImagePtr im, FILE *outFile, int GlobalCM, int Loops) { gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageGifAnimBeginCtx(im, out, GlobalCM, Loops); out->gd_free(out); } /* Function: gdImageGifAnimBeginCtx Like except that it outputs to . See . Parameters: im - The reference image out - Pointer to the output . GlobalCM - Global colormap flag: 1 -> yes, 0 -> no, -1 -> do default Loops - Loop count; 0 -> infinite, -1 means no loop Returns: Nothing. */ BGD_DECLARE(void) gdImageGifAnimBeginCtx(gdImagePtr im, gdIOCtxPtr out, int GlobalCM, int Loops) { int B; int RWidth, RHeight; int Resolution; int ColorMapSize; int BitsPerPixel; int Background = 0; int i; /* Default is to use global color map */ if (GlobalCM < 0) { GlobalCM = 1; } BitsPerPixel = colorstobpp(im->colorsTotal); ColorMapSize = 1 << BitsPerPixel; RWidth = im->sx; RHeight = im->sy; Resolution = BitsPerPixel; /* Write the Magic header */ gdPutBuf("GIF89a", 6, out); /* Write out the screen width and height */ gifPutWord(RWidth, out); gifPutWord(RHeight, out); /* Indicate that there is a global colour map */ B = GlobalCM ? 0x80 : 0; /* OR in the resolution */ B |= (Resolution - 1) << 4; /* OR in the Bits per Pixel */ B |= (BitsPerPixel - 1); /* Write it out */ gdPutC(B, out); /* Write out the Background colour */ gdPutC(Background, out); /* Byte of 0's (future expansion) */ gdPutC(0, out); /* Write out the Global Colour Map */ if(GlobalCM) { for(i = 0; i < ColorMapSize; ++i) { gdPutC(im->red[i], out); gdPutC(im->green[i], out); gdPutC(im->blue[i], out); } } if(Loops >= 0) { gdPutBuf("!\377\13NETSCAPE2.0\3\1", 16, out); gifPutWord(Loops, out); gdPutC(0, out); } } /* Function: gdImageGifAnimAddPtr Like (which contains more information) except that it stores the data to write into memory and returns a pointer to it. This memory must be freed by the caller when it is no longer needed. **The caller must invoke (), not free(),** unless the caller is absolutely certain that the same implementations of malloc, free, etc. are used both at library build time and at application build time (but don't; it could always change). The 'size' parameter receives the total size of the block of memory. Parameters: im - The image to add. size - Output: the size of the resulting buffer. LocalCM - Flag. If 1, use a local color map for this frame. LeftOfs - Left offset of image in frame. TopOfs - Top offset of image in frame. Delay - Delay before next frame (in 1/100 seconds) Disposal - MODE: How to treat this frame when the next one loads. previm - NULL or a pointer to the previous image written. Returns: Pointer to the resulting data or NULL if an error occurred. */ BGD_DECLARE(void *) gdImageGifAnimAddPtr(gdImagePtr im, int *size, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); if (out == NULL) return NULL; gdImageGifAnimAddCtx(im, out, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } /* Function: gdImageGifAnimAdd This function writes GIF animation frames to GIF animation, which was initialized with . With _LeftOfs_ and _TopOfs_ you can place this frame in different offset than (0,0) inside the image screen as defined in . Delay between the previous frame and this frame is in 1/100s units. _Disposal_ is usually , meaning that the pixels changed by this frame should remain on the display when the next frame begins to render, but can also be (not recommended), (restores the first allocated color of the global palette), or (restores the appearance of the affected area before the frame was rendered). Only is a sensible choice for the first frame. If _previm_ is passed, the built-in GIF optimizer will always use regardless of the Disposal parameter. Setting the _LocalCM_ flag to 1 adds a local palette for this image to the animation. Otherwise the global palette is assumed and the user must make sure the palettes match. Use to do that. Automatic optimization is activated by giving the previous image as a parameter. This function then compares the images and only writes the changed pixels to the new frame in animation. The _Disposal_ parameter for optimized animations must be set to 1, also for the first frame. _LeftOfs_ and _TopOfs_ parameters are ignored for optimized frames. To achieve good optimization, it is usually best to use a single global color map. To allow to compress unchanged pixels via the use of a transparent color, the image must include a transparent color. Variants: outputs its data via a struct. outputs its data to a memory buffer which it returns. Parameters: im - The image to add. outfile - The output FILE* being written. LocalCM - Flag. If 1, use a local color map for this frame. LeftOfs - Left offset of image in frame. TopOfs - Top offset of image in frame. Delay - Delay before next frame (in 1/100 seconds) Disposal - MODE: How to treat this frame when the next one loads. previm - NULL or a pointer to the previous image written. Returns: Nothing. Example: > { > gdImagePtr im, im2, im3; > int black, white, trans; > FILE *out; > > im = gdImageCreate(100, 100); // Create the image > white = gdImageColorAllocate(im, 255, 255, 255); // Allocate background > black = gdImageColorAllocate(im, 0, 0, 0); // Allocate drawing color > trans = gdImageColorAllocate(im, 1, 1, 1); // trans clr for compression > gdImageRectangle(im, 0, 0, 10, 10, black); // Draw rectangle > > out = fopen("anim.gif", "wb");// Open output file in binary mode > gdImageGifAnimBegin(im, out, 1, 3);// Write GIF hdr, global clr map,loops > // Write the first frame. No local color map. Delay = 1s > gdImageGifAnimAdd(im, out, 0, 0, 0, 100, 1, NULL); > > // construct the second frame > im2 = gdImageCreate(100, 100); > (void)gdImageColorAllocate(im2, 255, 255, 255); // White background > gdImagePaletteCopy (im2, im); // Make sure the palette is identical > gdImageRectangle(im2, 0, 0, 15, 15, black); // Draw something > // Allow animation compression with transparent pixels > gdImageColorTransparent (im2, trans); > gdImageGifAnimAdd(im2, out, 0, 0, 0, 100, 1, im); // Add second frame > > // construct the third frame > im3 = gdImageCreate(100, 100); > (void)gdImageColorAllocate(im3, 255, 255, 255); // white background > gdImagePaletteCopy (im3, im); // Make sure the palette is identical > gdImageRectangle(im3, 0, 0, 15, 20, black); // Draw something > // Allow animation compression with transparent pixels > gdImageColorTransparent (im3, trans); > // Add the third frame, compressing against the second one > gdImageGifAnimAdd(im3, out, 0, 0, 0, 100, 1, im2); > gdImageGifAnimEnd(out); // End marker, same as putc(';', out); > fclose(out); // Close file > > // Destroy images > gdImageDestroy(im); > gdImageDestroy(im2); > gdImageDestroy(im3); > } */ BGD_DECLARE(void) gdImageGifAnimAdd(gdImagePtr im, FILE *outFile, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm) { gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageGifAnimAddCtx(im, out, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm); out->gd_free(out); } static int comparewithmap(gdImagePtr im1, gdImagePtr im2, int c1, int c2, int *colorMap) { if(!colorMap) { return c1 == c2; } if(-2 != colorMap[c1]) { return colorMap[c1] == c2; } return (colorMap[c1] = gdImageColorExactAlpha(im2, im1->red[c1], im1->green[c1], im1->blue[c1], im1->alpha[c1])) == c2; } /* Function: gdImageGifAnimAddCtx Adds an animation frame via a . See gdImageGifAnimAdd>. Parameters: im - The image to add. out - The output . LocalCM - Flag. If 1, use a local color map for this frame. LeftOfs - Left offset of image in frame. TopOfs - Top offset of image in frame. Delay - Delay before next frame (in 1/100 seconds) Disposal - MODE: How to treat this frame when the next one loads. previm - NULL or a pointer to the previous image written. Returns: Nothing. */ BGD_DECLARE(void) gdImageGifAnimAddCtx(gdImagePtr im, gdIOCtxPtr out, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm) { gdImagePtr pim = NULL, tim = im; int interlace, transparent, BitsPerPixel; interlace = im->interlace; transparent = im->transparent; /* Default is no local color map */ if(LocalCM < 0) { LocalCM = 0; } if(im->trueColor) { /* Expensive, but the only way that produces an acceptable result: mix down to a palette based temporary image. */ pim = gdImageCreatePaletteFromTrueColor(im, 1, 256); if (!pim) { return; } tim = pim; } if (previm) { /* create optimized animation. Compare this image to the previous image and crop the temporary copy of current image to include only changed rectangular area. Also replace unchanged pixels inside this area with transparent color. Transparent color needs to be already allocated! Preconditions: TopOfs, LeftOfs are assumed 0 Images should be of same size. If not, a temporary copy is made with the same size as previous image. */ gdImagePtr prev_pim = 0, prev_tim = previm; int x, y; int min_x = 0; int min_y = tim->sy; int max_x = 0; int max_y = 0; int colorMap[256]; if (previm->trueColor) { prev_pim = gdImageCreatePaletteFromTrueColor(previm, 1, 256); if (!prev_pim) { goto fail_end; } prev_tim = prev_pim; } for (x = 0; x < 256; ++x) { colorMap[x] = -2; } /* First find bounding box of changed areas. */ /* first find the top changed row */ for (y = 0; y < tim->sy; ++y) { for (x = 0; x < tim->sx; ++x) { if (!comparewithmap(prev_tim, tim, prev_tim->pixels[y][x], tim->pixels[y][x], colorMap)) { min_y = max_y = y; min_x = max_x = x; goto break_top; } } } break_top: if (tim->sy == min_y) { /* No changes in this frame!! Encode empty image. */ transparent = 0; min_x = min_y = 1; max_x = max_y = 0; } else { /* Then the bottom row */ for (y = tim->sy - 1; y > min_y; --y) { for (x = 0; x < tim->sx; ++x) { if (!comparewithmap (prev_tim, tim, prev_tim->pixels[y][x], tim->pixels[y][x], colorMap)) { max_y = y; if(x < min_x) { min_x = x; } if(x > max_x) { max_x = x; } goto break_bot; } } } break_bot: /* left side */ for (x = 0; x < min_x; ++x) { for (y = min_y; y <= max_y; ++y) { if (!comparewithmap (prev_tim, tim, prev_tim->pixels[y][x], tim->pixels[y][x], colorMap)) { min_x = x; goto break_left; } } } break_left: /* right side */ for (x = tim->sx - 1; x > max_x; --x) { for (y = min_y; y <= max_y; ++y) { if (!comparewithmap (prev_tim, tim, prev_tim->pixels[y][x], tim->pixels[y][x], colorMap)) { max_x = x; goto break_right; } } } break_right: ; } LeftOfs = min_x; TopOfs = min_y; Disposal = 1; /* Make a copy of the image with the new offsets. But only if necessary. */ if (min_x != 0 || max_x != tim->sx - 1 || min_y != 0 || max_y != tim->sy - 1 || transparent >= 0) { gdImagePtr pim2 = gdImageCreate(max_x-min_x + 1, max_y-min_y + 1); if (!pim2) { if (prev_pim) { gdImageDestroy(prev_pim); } goto fail_end; } gdImagePaletteCopy(pim2, LocalCM ? tim : prev_tim); gdImageCopy(pim2, tim, 0, 0, min_x, min_y, max_x - min_x + 1, max_y - min_y + 1); if (pim) { gdImageDestroy(pim); } tim = pim = pim2; } /* now let's compare pixels for transparent optimization. But only if transparent is set. */ if (transparent >= 0) { for(y = 0; y < tim->sy; ++y) { for (x = 0; x < tim->sx; ++x) { if(comparewithmap (prev_tim, tim, prev_tim->pixels[min_y + y][min_x + x], tim->pixels[y][x], 0)) { gdImageSetPixel(tim, x, y, transparent); break; } } } } if(prev_pim) { gdImageDestroy(prev_pim); } } BitsPerPixel = colorstobpp(tim->colorsTotal); /* All set, let's do it. */ GIFAnimEncode( out, tim->sx, tim->sy, LeftOfs, TopOfs, interlace, transparent, Delay, Disposal, BitsPerPixel, LocalCM ? tim->red : 0, tim->green, tim->blue, tim); fail_end: if(pim) { /* Destroy palette based temporary image. */ gdImageDestroy(pim); } } /* Function: gdImageGifAnimEnd Terminates the GIF file properly. (Previous versions of this function's documentation suggested just manually writing a semicolon (';') instead since that is all this function does. While that has no longer changed, we now suggest that you do not do this and instead always call (or equivalent) since later versions could possibly do more or different things.) Variants: outputs its data via a struct. outputs its data to a memory buffer which it returns. Parameters: outfile - the destination FILE*. Returns: Nothing. */ BGD_DECLARE(void) gdImageGifAnimEnd(FILE *outFile) { #if 1 putc(';', outFile); #else gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageGifAnimEndCtx(out); out->gd_free(out); #endif } /* Function: gdImageGifAnimEndPtr Like (which contains more information) except that it stores the data to write into memory and returns a pointer to it. This memory must be freed by the caller when it is no longer needed. **The caller must invoke (), not free(),** unless the caller is absolutely certain that the same implementations of malloc, free, etc. are used both at library build time and at application build time (but don't; it could always change). The 'size' parameter receives the total size of the block of memory. Parameters: size - Output: the size of the resulting buffer. Returns: Pointer to the resulting data or NULL if an error occurred. */ BGD_DECLARE(void *) gdImageGifAnimEndPtr(int *size) { char *rv = (char *) gdMalloc(1); if(!rv) { return 0; } *rv = ';'; *size = 1; return (void *)rv; } /* Function: gdImageGifAnimEndCtx Like , but writes its data via a . Parameters: out - the destination . Returns: Nothing. */ BGD_DECLARE(void) gdImageGifAnimEndCtx(gdIOCtx *out) { /* * Write the GIF file terminator */ gdPutC(';', out); } static int colorstobpp(int colors) { int bpp = 0; if(colors <= 2) bpp = 1; else if(colors <= 4) bpp = 2; else if(colors <= 8) bpp = 3; else if(colors <= 16) bpp = 4; else if(colors <= 32) bpp = 5; else if(colors <= 64) bpp = 6; else if(colors <= 128) bpp = 7; else if(colors <= 256) bpp = 8; return bpp; } /***************************************************************************** * * GIFENCODE.C - GIF Image compression interface * * GIFEncode( FName, GHeight, GWidth, GInterlace, Background, Transparent, * BitsPerPixel, Red, Green, Blue, gdImagePtr ) * *****************************************************************************/ #define TRUE 1 #define FALSE 0 /* Bump the 'curx' and 'cury' to point to the next pixel */ static void BumpPixel(GifCtx *ctx) { /* Bump the current X position */ ++(ctx->curx); /* If we are at the end of a scan line, set curx back to the beginning * If we are interlaced, bump the cury to the appropriate spot, * otherwise, just increment it. */ if(ctx->curx == ctx->Width) { ctx->curx = 0; if(!ctx->Interlace) { ++(ctx->cury); } else { switch(ctx->Pass) { case 0: ctx->cury += 8; if(ctx->cury >= ctx->Height) { ++(ctx->Pass); ctx->cury = 4; } break; case 1: ctx->cury += 8; if(ctx->cury >= ctx->Height) { ++(ctx->Pass); ctx->cury = 2; } break; case 2: ctx->cury += 4; if(ctx->cury >= ctx->Height) { ++(ctx->Pass); ctx->cury = 1; } break; case 3: ctx->cury += 2; break; } } } } /* Return the next pixel from the image */ static int GIFNextPixel(gdImagePtr im, GifCtx *ctx) { int r; if(ctx->CountDown == 0) { return EOF; } --(ctx->CountDown); r = gdImageGetPixel(im, ctx->curx, ctx->cury); BumpPixel(ctx); return r; } /* public */ static void GIFEncode(gdIOCtxPtr fp, int GWidth, int GHeight, int GInterlace, int Background, int Transparent, int BitsPerPixel, int *Red, int *Green, int *Blue, gdImagePtr im) { int B; int RWidth, RHeight; int LeftOfs, TopOfs; int Resolution; int ColorMapSize; int InitCodeSize; int i; GifCtx ctx; memset(&ctx, 0, sizeof(ctx)); ctx.Interlace = GInterlace; ctx.in_count = 1; ColorMapSize = 1 << BitsPerPixel; RWidth = ctx.Width = GWidth; RHeight = ctx.Height = GHeight; LeftOfs = TopOfs = 0; Resolution = BitsPerPixel; /* Calculate number of bits we are expecting */ ctx.CountDown = (long)ctx.Width * (long)ctx.Height; /* Indicate which pass we are on (if interlace) */ ctx.Pass = 0; /* The initial code size */ if(BitsPerPixel <= 1) { InitCodeSize = 2; } else { InitCodeSize = BitsPerPixel; } /* Set up the current x and y position */ ctx.curx = ctx.cury = 0; /* Write the Magic header */ gdPutBuf(Transparent < 0 ? "GIF87a" : "GIF89a", 6, fp); /* Write out the screen width and height */ gifPutWord(RWidth, fp); gifPutWord(RHeight, fp); /* Indicate that there is a global colour map */ /* Yes, there is a color map */ B = 0x80; /* OR in the resolution */ B |= (Resolution - 1) << 4; /* OR in the Bits per Pixel */ B |= (BitsPerPixel - 1); /* Write it out */ gdPutC(B, fp); /* Write out the Background colour */ gdPutC(Background, fp); /* Byte of 0's (future expansion) */ gdPutC(0, fp); /* Write out the Global Colour Map */ for(i = 0; i < ColorMapSize; ++i) { gdPutC(Red[i], fp); gdPutC(Green[i], fp); gdPutC(Blue[i], fp); } /* Write out extension for transparent colour index, if necessary. */ if(Transparent >= 0) { gdPutC('!', fp); gdPutC(0xf9, fp); gdPutC(4, fp); gdPutC(1, fp); gdPutC(0, fp); gdPutC(0, fp); gdPutC((unsigned char) Transparent, fp); gdPutC(0, fp); } /* Write an Image separator */ gdPutC(',', fp); /* Write the Image header */ gifPutWord(LeftOfs, fp); gifPutWord(TopOfs, fp); gifPutWord(ctx.Width, fp); gifPutWord(ctx.Height, fp); /* Write out whether or not the image is interlaced */ if(ctx.Interlace) { gdPutC(0x40, fp); } else { gdPutC(0x00, fp); } /* Write out the initial code size */ gdPutC(InitCodeSize, fp); /* Go and actually compress the data */ compress(InitCodeSize + 1, fp, im, &ctx); /* Write out a Zero-length packet (to end the series) */ gdPutC(0, fp); /* Write the GIF file terminator */ gdPutC(';', fp); } static void GIFAnimEncode(gdIOCtxPtr fp, int IWidth, int IHeight, int LeftOfs, int TopOfs, int GInterlace, int Transparent, int Delay, int Disposal, int BitsPerPixel, int *Red, int *Green, int *Blue, gdImagePtr im) { int B; int ColorMapSize; int InitCodeSize; int i; GifCtx ctx; memset(&ctx, 0, sizeof(ctx)); ctx.Interlace = GInterlace; ctx.in_count = 1; ColorMapSize = 1 << BitsPerPixel; if(LeftOfs < 0) { LeftOfs = 0; } if(TopOfs < 0) { TopOfs = 0; } if(Delay < 0) { Delay = 100; } if(Disposal < 0) { Disposal = 1; } ctx.Width = IWidth; ctx.Height = IHeight; /* Calculate number of bits we are expecting */ ctx.CountDown = (long)ctx.Width * (long)ctx.Height; /* Indicate which pass we are on (if interlace) */ ctx.Pass = 0; /* The initial code size */ if(BitsPerPixel <= 1) { InitCodeSize = 2; } else { InitCodeSize = BitsPerPixel; } /* Set up the current x and y position */ ctx.curx = ctx.cury = 0; /* Write out extension for image animation and looping */ gdPutC('!', fp); gdPutC(0xf9, fp); gdPutC(4, fp); gdPutC((Transparent >= 0 ? 1 : 0) | (Disposal << 2), fp); gdPutC((unsigned char)(Delay & 255), fp); gdPutC((unsigned char)((Delay >> 8) & 255), fp); gdPutC((unsigned char) Transparent, fp); gdPutC(0, fp); /* Write an Image separator */ gdPutC(',', fp); /* Write out the Image header */ gifPutWord(LeftOfs, fp); gifPutWord(TopOfs, fp); gifPutWord(ctx.Width, fp); gifPutWord(ctx.Height, fp); /* Indicate that there is a local colour map */ B = (Red && Green && Blue) ? 0x80 : 0; /* OR in the interlacing */ B |= ctx.Interlace ? 0x40 : 0; /* OR in the Bits per Pixel */ B |= (Red && Green && Blue) ? (BitsPerPixel - 1) : 0; /* Write it out */ gdPutC(B, fp); /* Write out the Local Colour Map */ if(Red && Green && Blue) { for(i = 0; i < ColorMapSize; ++i) { gdPutC(Red[i], fp); gdPutC(Green[i], fp); gdPutC(Blue[i], fp); } } /* Write out the initial code size */ gdPutC(InitCodeSize, fp); /* Go and actually compress the data */ compress(InitCodeSize + 1, fp, im, &ctx); /* Write out a Zero-length packet (to end the series) */ gdPutC(0, fp); } /*************************************************************************** * * GIFCOMPR.C - GIF Image compression routines * * Lempel-Ziv compression based on 'compress'. GIF modifications by * David Rowley (mgardi@watdcsu.waterloo.edu) * ***************************************************************************/ /* General DEFINEs */ #define GIFBITS 12 #ifdef NO_UCHAR typedef char char_type; #else /* NO_UCHAR */ typedef unsigned char char_type; #endif /* NO_UCHAR */ /* * * GIF Image compression - modified 'compress' * * Based on: compress.c - File compression ala IEEE Computer, June 1984. * * By Authors: Spencer W. Thomas (decvax!harpo!utah-cs!utah-gr!thomas) * Jim McKie (decvax!mcvax!jim) * Steve Davies (decvax!vax135!petsd!peora!srd) * Ken Turkowski (decvax!decwrl!turtlevax!ken) * James A. Woods (decvax!ihnp4!ames!jaw) * Joe Orost (decvax!vax135!petsd!joe) * */ #include #define ARGVAL() (*++(*argv) || (--argc && *++argv)) #ifdef COMPATIBLE /* But wrong! */ # define MAXCODE(n_bits) ((code_int) 1 << (n_bits) - 1) #else /* COMPATIBLE */ # define MAXCODE(n_bits) (((code_int) 1 << (n_bits)) - 1) #endif /* COMPATIBLE */ #define HashTabOf(i) ctx->htab[i] #define CodeTabOf(i) ctx->codetab[i] /* * To save much memory, we overlay the table used by compress() with those * used by decompress(). The tab_prefix table is the same size and type * as the codetab. The tab_suffix table needs 2**GIFBITS characters. We * get this from the beginning of htab. The output stack uses the rest * of htab, and contains characters. There is plenty of room for any * possible stack (stack used to be 8000 characters). */ #define tab_prefixof(i) CodeTabOf(i) #define tab_suffixof(i) ((char_type*)(htab))[i] #define de_stack ((char_type*)&tab_suffixof((code_int)1 << GIFBITS)) /* * compress stdin to stdout * * Algorithm: use open addressing double hashing (no chaining) on the * prefix code / next character combination. We do a variant of Knuth's * algorithm D (vol. 3, sec. 6.4) along with G. Knott's relatively-prime * secondary probe. Here, the modular division first probe is gives way * to a faster exclusive-or manipulation. Also do block compression with * an adaptive reset, whereby the code table is cleared when the compression * ratio decreases, but after the table fills. The variable-length output * codes are re-sized at this point, and a special CLEAR code is generated * for the decompressor. Late addition: construct the table according to * file size for noticeable speed improvement on small files. Please direct * questions about this implementation to ames!jaw. */ static void output(code_int code, GifCtx *ctx); static void compress(int init_bits, gdIOCtxPtr outfile, gdImagePtr im, GifCtx *ctx) { register long fcode; register code_int i; register int c; register code_int ent; register code_int disp; register code_int hsize_reg; register int hshift; /* Set up the globals: * g_init_bits - initial number of bits * g_outfile - pointer to output file */ ctx->g_init_bits = init_bits; ctx->g_outfile = outfile; /* Set up the necessary values */ ctx->offset = 0; ctx->out_count = 0; ctx->clear_flg = 0; ctx->in_count = 1; ctx->maxcode = MAXCODE(ctx->n_bits = ctx->g_init_bits); ctx->ClearCode = (1 << (init_bits - 1)); ctx->EOFCode = ctx->ClearCode + 1; ctx->free_ent = ctx->ClearCode + 2; char_init(ctx); ent = GIFNextPixel(im, ctx); hshift = 0; for(fcode = (long)hsize; fcode < 65536L; fcode *= 2L) { ++hshift; } hshift = 8 - hshift; /* set hash code range bound */ hsize_reg = hsize; cl_hash((count_int) hsize_reg, ctx); /* clear hash table */ output((code_int)ctx->ClearCode, ctx); #ifdef SIGNED_COMPARE_SLOW while((c = GIFNextPixel(im)) != (unsigned) EOF) { #else /* SIGNED_COMPARE_SLOW */ while((c = GIFNextPixel(im, ctx)) != EOF) { #endif /* SIGNED_COMPARE_SLOW */ ++(ctx->in_count); fcode = (long) (((long) c << maxbits) + ent); i = (((code_int)c << hshift) ^ ent); /* xor hashing */ if(HashTabOf(i) == fcode) { ent = CodeTabOf (i); continue; } else if ((long)HashTabOf (i) < 0) {/* empty slot */ goto nomatch; } disp = hsize_reg - i; /* secondary hash (after G. Knott) */ if(i == 0) { disp = 1; } probe: if((i -= disp) < 0) { i += hsize_reg; } if(HashTabOf(i) == fcode) { ent = CodeTabOf (i); continue; } if((long)HashTabOf(i) > 0) { goto probe; } nomatch: output((code_int) ent, ctx); ++(ctx->out_count); ent = c; #ifdef SIGNED_COMPARE_SLOW if((unsigned) ctx->free_ent < (unsigned) maxmaxcode) { #else /*SIGNED_COMPARE_SLOW*/ if (ctx->free_ent < maxmaxcode) { /* } */ #endif /*SIGNED_COMPARE_SLOW*/ CodeTabOf(i) = ctx->free_ent++; /* code -> hashtable */ HashTabOf(i) = fcode; } else { cl_block(ctx); } } /* Put out the final code. */ output((code_int)ent, ctx); ++(ctx->out_count); output((code_int) ctx->EOFCode, ctx); } /***************************************************************** * TAG( output ) * * Output the given code. * Inputs: * code: A n_bits-bit integer. If == -1, then EOF. This assumes * that n_bits =< (long)wordsize - 1. * Outputs: * Outputs code to the file. * Assumptions: * Chars are 8 bits long. * Algorithm: * Maintain a GIFBITS character long buffer (so that 8 codes will * fit in it exactly). Use the VAX insv instruction to insert each * code in turn. When the buffer fills up empty it and start over. */ static unsigned long masks[] = { 0x0000, 0x0001, 0x0003, 0x0007, 0x000F, 0x001F, 0x003F, 0x007F, 0x00FF, 0x01FF, 0x03FF, 0x07FF, 0x0FFF, 0x1FFF, 0x3FFF, 0x7FFF, 0xFFFF }; static void output(code_int code, GifCtx *ctx) { ctx->cur_accum &= masks[ctx->cur_bits]; if(ctx->cur_bits > 0) { ctx->cur_accum |= ((long)code << ctx->cur_bits); } else { ctx->cur_accum = code; } ctx->cur_bits += ctx->n_bits; while(ctx->cur_bits >= 8) { char_out((unsigned int)(ctx->cur_accum & 0xff), ctx); ctx->cur_accum >>= 8; ctx->cur_bits -= 8; } /* * If the next entry is going to be too big for the code size, * then increase it, if possible. */ if(ctx->free_ent > ctx->maxcode || ctx->clear_flg) { if(ctx->clear_flg) { ctx->maxcode = MAXCODE (ctx->n_bits = ctx->g_init_bits); ctx->clear_flg = 0; } else { ++(ctx->n_bits); if(ctx->n_bits == maxbits) { ctx->maxcode = maxmaxcode; } else { ctx->maxcode = MAXCODE(ctx->n_bits); } } } if(code == ctx->EOFCode) { /* At EOF, write the rest of the buffer. */ while(ctx->cur_bits > 0) { char_out((unsigned int)(ctx->cur_accum & 0xff), ctx); ctx->cur_accum >>= 8; ctx->cur_bits -= 8; } flush_char(ctx); } } /* * Clear out the hash table */ static void cl_block (GifCtx *ctx) /* table clear for block compress */ { cl_hash((count_int) hsize, ctx); ctx->free_ent = ctx->ClearCode + 2; ctx->clear_flg = 1; output((code_int)ctx->ClearCode, ctx); } static void cl_hash(register count_int chsize, GifCtx *ctx) /* reset code table */ { register count_int *htab_p = ctx->htab+chsize; register long i; register long m1 = -1; i = chsize - 16; do { /* might use Sys V memset(3) here */ *(htab_p - 16) = m1; *(htab_p - 15) = m1; *(htab_p - 14) = m1; *(htab_p - 13) = m1; *(htab_p - 12) = m1; *(htab_p - 11) = m1; *(htab_p - 10) = m1; *(htab_p - 9) = m1; *(htab_p - 8) = m1; *(htab_p - 7) = m1; *(htab_p - 6) = m1; *(htab_p - 5) = m1; *(htab_p - 4) = m1; *(htab_p - 3) = m1; *(htab_p - 2) = m1; *(htab_p - 1) = m1; htab_p -= 16; } while((i -= 16) >= 0); for(i += 16; i > 0; --i) { *--htab_p = m1; } } /****************************************************************************** * * GIF Specific routines * ******************************************************************************/ /* * Set up the 'byte output' routine */ static void char_init(GifCtx *ctx) { ctx->a_count = 0; } /* * Add a character to the end of the current packet, and if it is 254 * characters, flush the packet to disk. */ static void char_out(int c, GifCtx *ctx) { ctx->accum[ctx->a_count++] = c; if(ctx->a_count >= 254) { flush_char(ctx); } } /* * Flush the packet to disk, and reset the accumulator */ static void flush_char(GifCtx *ctx) { if(ctx->a_count > 0) { gdPutC(ctx->a_count, ctx->g_outfile); gdPutBuf(ctx->accum, ctx->a_count, ctx->g_outfile); ctx->a_count = 0; } } static int gifPutWord(int w, gdIOCtx *out) { /* Byte order is little-endian */ gdPutC(w & 0xFF, out); gdPutC((w >> 8) & 0xFF, out); return 0; } libgd-gd-2.1.1/src/gd_intern.h000066400000000000000000000037101245535672000161070ustar00rootroot00000000000000#ifndef GD_INTERN_H #define GD_INTERN_H #if HAVE_LIMITS_H #include #endif #ifndef MAXPATHLEN # ifdef PATH_MAX # define MAXPATHLEN PATH_MAX # elif defined(MAX_PATH) # define MAXPATHLEN MAX_PATH # else # if defined(__GNU__) # define MAXPATHLEN 4096 # else # define MAXPATHLEN 256 /* Should be safe for any weird systems that do not define it */ # endif # endif #endif #ifdef HAVE_STDINT_H # include #else # if defined(HAVE_INTTYPES_H) # include # else # include "msinttypes/inttypes.h" # endif #endif #include "gd.h" #ifndef MIN #define MIN(a,b) ((a)<(b)?(a):(b)) #endif #define MIN3(a,b,c) ((a)<(b)?(MIN(a,c)):(MIN(b,c))) #ifndef MAX #define MAX(a,b) ((a)<(b)?(b):(a)) #endif #define MAX3(a,b,c) ((a)<(b)?(MAX(b,c)):(MAX(a,c))) typedef enum { HORIZONTAL, VERTICAL, } gdAxis; /* Convert a double to an unsigned char, rounding to the nearest * integer and clamping the result between 0 and max. The absolute * value of clr must be less than the maximum value of an unsigned * short. */ static inline unsigned char uchar_clamp(double clr, unsigned char max) { unsigned short result; //assert(fabs(clr) <= SHRT_MAX); /* Casting a negative float to an unsigned short is undefined. * However, casting a float to a signed truncates toward zero and * casting a negative signed value to an unsigned of the same size * results in a bit-identical value (assuming twos-complement * arithmetic). This is what we want: all legal negative values * for clr will be greater than 255. */ /* Convert and clamp. */ result = (unsigned short)(short)(clr + 0.5); if (result > max) { result = (clr < 0) ? 0 : max; }/* if */ return result; }/* uchar_clamp*/ /* Internal prototypes: */ /* gd_rotate.c */ gdImagePtr gdImageRotate90(gdImagePtr src, int ignoretransparent); gdImagePtr gdImageRotate180(gdImagePtr src, int ignoretransparent); gdImagePtr gdImageRotate270(gdImagePtr src, int ignoretransparent); #endif libgd-gd-2.1.1/src/gd_interpolation.c000066400000000000000000002177151245535672000175060ustar00rootroot00000000000000/* * The two pass scaling function is based on: * Filtered Image Rescaling * Based on Gems III * - Schumacher general filtered image rescaling * (pp. 414-424) * by Dale Schumacher * * Additional changes by Ray Gardener, Daylon Graphics Ltd. * December 4, 1999 * * Ported to libgd by Pierre Joye. Support for multiple channels * added (argb for now). * * Initial sources code is avaibable in the Gems Source Code Packages: * http://www.acm.org/pubs/tog/GraphicsGems/GGemsIII.tar.gz * */ /* Summary: - Horizontal filter contributions are calculated on the fly, as each column is mapped from src to dst image. This lets us omit having to allocate a temporary full horizontal stretch of the src image. - If none of the src pixels within a sampling region differ, then the output pixel is forced to equal (any of) the source pixel. This ensures that filters do not corrupt areas of constant color. - Filter weight contribution results, after summing, are rounded to the nearest pixel color value instead of being casted to ILubyte (usually an int or char). Otherwise, artifacting occurs. */ /* Additional functions are available for simple rotation or up/downscaling. downscaling using the fixed point implementations are usually much faster than the existing gdImageCopyResampled while having a similar or better quality. For image rotations, the optimized versions have a lazy antialiasing for the edges of the images. For a much better antialiased result, the affine function is recommended. */ /* TODO: - Optimize pixel accesses and loops once we have continuous buffer - Add scale support for a portion only of an image (equivalent of copyresized/resampled) */ #ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include #include #include #include #include #define NDEBUG 1 /* TODO: disable/enable assertions in configure. */ #include #include "gd.h" #include "gdhelpers.h" #include "gd_intern.h" #ifdef _MSC_VER # pragma optimize("t", on) # include #endif static gdImagePtr gdImageScaleBilinear(gdImagePtr im, const unsigned int new_width, const unsigned int new_height); static gdImagePtr gdImageScaleBicubicFixed(gdImagePtr src, const unsigned int width, const unsigned int height); static gdImagePtr gdImageScaleNearestNeighbour(gdImagePtr im, const unsigned int width, const unsigned int height); static gdImagePtr gdImageRotateNearestNeighbour(gdImagePtr src, const float degrees, const int bgColor); static gdImagePtr gdImageRotateBilinear(gdImagePtr src, const float degrees, const int bgColor); static gdImagePtr gdImageRotateBicubicFixed(gdImagePtr src, const float degrees, const int bgColor); static gdImagePtr gdImageRotateGeneric(gdImagePtr src, const float degrees, const int bgColor); #define CLAMP(x, low, high) (((x) > (high)) ? (high) : (((x) < (low)) ? (low) : (x))) /* only used here, let do a generic fixed point integers later if required by other part of GD */ typedef long gdFixed; /* Integer to fixed point */ #define gd_itofx(x) ((x) << 8) /* Float to fixed point */ #define gd_ftofx(x) (long)((x) * 256) /* Double to fixed point */ #define gd_dtofx(x) (long)((x) * 256) /* Fixed point to integer */ #define gd_fxtoi(x) ((x) >> 8) /* Fixed point to float */ # define gd_fxtof(x) ((float)(x) / 256) /* Fixed point to double */ #define gd_fxtod(x) ((double)(x) / 256) /* Multiply a fixed by a fixed */ #define gd_mulfx(x,y) (((x) * (y)) >> 8) /* Divide a fixed by a fixed */ #define gd_divfx(x,y) (((x) << 8) / (y)) typedef struct { double *Weights; /* Normalized weights of neighboring pixels */ int Left,Right; /* Bounds of source pixels window */ } ContributionType; /* Contirbution information for a single pixel */ typedef struct { ContributionType *ContribRow; /* Row (or column) of contribution weights */ unsigned int WindowSize, /* Filter window size (of affecting source pixels) */ LineLength; /* Length of line (no. or rows / cols) */ } LineContribType; /* Each core filter has its own radius */ #define DEFAULT_FILTER_BICUBIC 3.0 #define DEFAULT_FILTER_BOX 0.5 #define DEFAULT_FILTER_GENERALIZED_CUBIC 0.5 #define DEFAULT_FILTER_RADIUS 1.0 #define DEFAULT_LANCZOS8_RADIUS 8.0 #define DEFAULT_LANCZOS3_RADIUS 3.0 #define DEFAULT_HERMITE_RADIUS 1.0 #define DEFAULT_BOX_RADIUS 0.5 #define DEFAULT_TRIANGLE_RADIUS 1.0 #define DEFAULT_BELL_RADIUS 1.5 #define DEFAULT_CUBICSPLINE_RADIUS 2.0 #define DEFAULT_MITCHELL_RADIUS 2.0 #define DEFAULT_COSINE_RADIUS 1.0 #define DEFAULT_CATMULLROM_RADIUS 2.0 #define DEFAULT_QUADRATIC_RADIUS 1.5 #define DEFAULT_QUADRATICBSPLINE_RADIUS 1.5 #define DEFAULT_CUBICCONVOLUTION_RADIUS 3.0 #define DEFAULT_GAUSSIAN_RADIUS 1.0 #define DEFAULT_HANNING_RADIUS 1.0 #define DEFAULT_HAMMING_RADIUS 1.0 #define DEFAULT_SINC_RADIUS 1.0 #define DEFAULT_WELSH_RADIUS 1.0 static double KernelBessel_J1(const double x) { double p, q; register long i; static const double Pone[] = { 0.581199354001606143928050809e+21, -0.6672106568924916298020941484e+20, 0.2316433580634002297931815435e+19, -0.3588817569910106050743641413e+17, 0.2908795263834775409737601689e+15, -0.1322983480332126453125473247e+13, 0.3413234182301700539091292655e+10, -0.4695753530642995859767162166e+7, 0.270112271089232341485679099e+4 }, Qone[] = { 0.11623987080032122878585294e+22, 0.1185770712190320999837113348e+20, 0.6092061398917521746105196863e+17, 0.2081661221307607351240184229e+15, 0.5243710262167649715406728642e+12, 0.1013863514358673989967045588e+10, 0.1501793594998585505921097578e+7, 0.1606931573481487801970916749e+4, 0.1e+1 }; p = Pone[8]; q = Qone[8]; for (i=7; i >= 0; i--) { p = p*x*x+Pone[i]; q = q*x*x+Qone[i]; } return (double)(p/q); } static double KernelBessel_P1(const double x) { double p, q; register long i; static const double Pone[] = { 0.352246649133679798341724373e+5, 0.62758845247161281269005675e+5, 0.313539631109159574238669888e+5, 0.49854832060594338434500455e+4, 0.2111529182853962382105718e+3, 0.12571716929145341558495e+1 }, Qone[] = { 0.352246649133679798068390431e+5, 0.626943469593560511888833731e+5, 0.312404063819041039923015703e+5, 0.4930396490181088979386097e+4, 0.2030775189134759322293574e+3, 0.1e+1 }; p = Pone[5]; q = Qone[5]; for (i=4; i >= 0; i--) { p = p*(8.0/x)*(8.0/x)+Pone[i]; q = q*(8.0/x)*(8.0/x)+Qone[i]; } return (double)(p/q); } static double KernelBessel_Q1(const double x) { double p, q; register long i; static const double Pone[] = { 0.3511751914303552822533318e+3, 0.7210391804904475039280863e+3, 0.4259873011654442389886993e+3, 0.831898957673850827325226e+2, 0.45681716295512267064405e+1, 0.3532840052740123642735e-1 }, Qone[] = { 0.74917374171809127714519505e+4, 0.154141773392650970499848051e+5, 0.91522317015169922705904727e+4, 0.18111867005523513506724158e+4, 0.1038187585462133728776636e+3, 0.1e+1 }; p = Pone[5]; q = Qone[5]; for (i=4; i >= 0; i--) { p = p*(8.0/x)*(8.0/x)+Pone[i]; q = q*(8.0/x)*(8.0/x)+Qone[i]; } return (double)(p/q); } static double KernelBessel_Order1(double x) { double p, q; if (x == 0.0) return (0.0f); p = x; if (x < 0.0) x=(-x); if (x < 8.0) return (p*KernelBessel_J1(x)); q = (double)sqrt(2.0f/(M_PI*x))*(double)(KernelBessel_P1(x)*(1.0f/sqrt(2.0f)*(sin(x)-cos(x)))-8.0f/x*KernelBessel_Q1(x)* (-1.0f/sqrt(2.0f)*(sin(x)+cos(x)))); if (p < 0.0f) q = (-q); return (q); } static double filter_bessel(const double x) { if (x == 0.0f) return (double)(M_PI/4.0f); return (KernelBessel_Order1((double)M_PI*x)/(2.0f*x)); } static double filter_blackman(const double x) { return (0.42f+0.5f*(double)cos(M_PI*x)+0.08f*(double)cos(2.0f*M_PI*x)); } /** * Bicubic interpolation kernel (a=-1): \verbatim / | 1-2|t|**2+|t|**3 , if |t| < 1 h(t) = | 4-8|t|+5|t|**2-|t|**3 , if 1<=|t|<2 | 0 , otherwise \ \endverbatim * ***bd*** 2.2004 */ static double filter_bicubic(const double t) { const double abs_t = (double)fabs(t); const double abs_t_sq = abs_t * abs_t; if (abs_t<1) return 1-2*abs_t_sq+abs_t_sq*abs_t; if (abs_t<2) return 4 - 8*abs_t +5*abs_t_sq - abs_t_sq*abs_t; return 0; } /** * Generalized cubic kernel (for a=-1 it is the same as BicubicKernel): \verbatim / | (a+2)|t|**3 - (a+3)|t|**2 + 1 , |t| <= 1 h(t) = | a|t|**3 - 5a|t|**2 + 8a|t| - 4a , 1 < |t| <= 2 | 0 , otherwise \ \endverbatim * Often used values for a are -1 and -1/2. */ static double filter_generalized_cubic(const double t) { const double a = -DEFAULT_FILTER_GENERALIZED_CUBIC; double abs_t = (double)fabs(t); double abs_t_sq = abs_t * abs_t; if (abs_t < 1) return (a + 2) * abs_t_sq * abs_t - (a + 3) * abs_t_sq + 1; if (abs_t < 2) return a * abs_t_sq * abs_t - 5 * a * abs_t_sq + 8 * a * abs_t - 4 * a; return 0; } #ifdef FUNCTION_NOT_USED_YET /* CubicSpline filter, default radius 2 */ static double filter_cubic_spline(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; if (x < 1.0 ) { const double x2 = x*x; return (0.5 * x2 * x - x2 + 2.0 / 3.0); } if (x < 2.0) { return (pow(2.0 - x, 3.0)/6.0); } return 0; } #endif #ifdef FUNCTION_NOT_USED_YET /* CubicConvolution filter, default radius 3 */ static double filter_cubic_convolution(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; const double x2 = x1 * x1; const double x2_x = x2 * x; if (x <= 1.0) return ((4.0 / 3.0)* x2_x - (7.0 / 3.0) * x2 + 1.0); if (x <= 2.0) return (- (7.0 / 12.0) * x2_x + 3 * x2 - (59.0 / 12.0) * x + 2.5); if (x <= 3.0) return ( (1.0/12.0) * x2_x - (2.0 / 3.0) * x2 + 1.75 * x - 1.5); return 0; } #endif static double filter_box(double x) { if (x < - DEFAULT_FILTER_BOX) return 0.0f; if (x < DEFAULT_FILTER_BOX) return 1.0f; return 0.0f; } static double filter_catmullrom(const double x) { if (x < -2.0) return(0.0f); if (x < -1.0) return(0.5f*(4.0f+x*(8.0f+x*(5.0f+x)))); if (x < 0.0) return(0.5f*(2.0f+x*x*(-5.0f-3.0f*x))); if (x < 1.0) return(0.5f*(2.0f+x*x*(-5.0f+3.0f*x))); if (x < 2.0) return(0.5f*(4.0f+x*(-8.0f+x*(5.0f-x)))); return(0.0f); } #ifdef FUNCTION_NOT_USED_YET static double filter_filter(double t) { /* f(t) = 2|t|^3 - 3|t|^2 + 1, -1 <= t <= 1 */ if(t < 0.0) t = -t; if(t < 1.0) return((2.0 * t - 3.0) * t * t + 1.0); return(0.0); } #endif #ifdef FUNCTION_NOT_USED_YET /* Lanczos8 filter, default radius 8 */ static double filter_lanczos8(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; #define R DEFAULT_LANCZOS8_RADIUS if ( x == 0.0) return 1; if ( x < R) { return R * sin(x*M_PI) * sin(x * M_PI/ R) / (x * M_PI * x * M_PI); } return 0.0; #undef R } #endif #ifdef FUNCTION_NOT_USED_YET /* Lanczos3 filter, default radius 3 */ static double filter_lanczos3(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; #define R DEFAULT_LANCZOS3_RADIUS if ( x == 0.0) return 1; if ( x < R) { return R * sin(x*M_PI) * sin(x * M_PI / R) / (x * M_PI * x * M_PI); } return 0.0; #undef R } #endif /* Hermite filter, default radius 1 */ static double filter_hermite(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; if (x < 1.0) return ((2.0 * x - 3) * x * x + 1.0 ); return 0.0; } /* Trangle filter, default radius 1 */ static double filter_triangle(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; if (x < 1.0) return (1.0 - x); return 0.0; } /* Bell filter, default radius 1.5 */ static double filter_bell(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; if (x < 0.5) return (0.75 - x*x); if (x < 1.5) return (0.5 * pow(x - 1.5, 2.0)); return 0.0; } /* Mitchell filter, default radius 2.0 */ static double filter_mitchell(const double x) { #define KM_B (1.0f/3.0f) #define KM_C (1.0f/3.0f) #define KM_P0 (( 6.0f - 2.0f * KM_B ) / 6.0f) #define KM_P2 ((-18.0f + 12.0f * KM_B + 6.0f * KM_C) / 6.0f) #define KM_P3 (( 12.0f - 9.0f * KM_B - 6.0f * KM_C) / 6.0f) #define KM_Q0 (( 8.0f * KM_B + 24.0f * KM_C) / 6.0f) #define KM_Q1 ((-12.0f * KM_B - 48.0f * KM_C) / 6.0f) #define KM_Q2 (( 6.0f * KM_B + 30.0f * KM_C) / 6.0f) #define KM_Q3 (( -1.0f * KM_B - 6.0f * KM_C) / 6.0f) if (x < -2.0) return(0.0f); if (x < -1.0) return(KM_Q0-x*(KM_Q1-x*(KM_Q2-x*KM_Q3))); if (x < 0.0f) return(KM_P0+x*x*(KM_P2-x*KM_P3)); if (x < 1.0f) return(KM_P0+x*x*(KM_P2+x*KM_P3)); if (x < 2.0f) return(KM_Q0+x*(KM_Q1+x*(KM_Q2+x*KM_Q3))); return(0.0f); } #ifdef FUNCTION_NOT_USED_YET /* Cosine filter, default radius 1 */ static double filter_cosine(const double x) { if ((x >= -1.0) && (x <= 1.0)) return ((cos(x * M_PI) + 1.0)/2.0); return 0; } #endif /* Quadratic filter, default radius 1.5 */ static double filter_quadratic(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; if (x <= 0.5) return (- 2.0 * x * x + 1); if (x <= 1.5) return (x * x - 2.5* x + 1.5); return 0.0; } static double filter_bspline(const double x) { if (x>2.0f) { return 0.0f; } else { double a, b, c, d; /* Was calculated anyway cause the "if((x-1.0f) < 0)" */ const double xm1 = x - 1.0f; const double xp1 = x + 1.0f; const double xp2 = x + 2.0f; if ((xp2) <= 0.0f) a = 0.0f; else a = xp2*xp2*xp2; if ((xp1) <= 0.0f) b = 0.0f; else b = xp1*xp1*xp1; if (x <= 0) c = 0.0f; else c = x*x*x; if ((xm1) <= 0.0f) d = 0.0f; else d = xm1*xm1*xm1; return (0.16666666666666666667f * (a - (4.0f * b) + (6.0f * c) - (4.0f * d))); } } #ifdef FUNCTION_NOT_USED_YET /* QuadraticBSpline filter, default radius 1.5 */ static double filter_quadratic_bspline(const double x1) { const double x = x1 < 0.0 ? -x1 : x1; if (x <= 0.5) return (- x * x + 0.75); if (x <= 1.5) return (0.5 * x * x - 1.5 * x + 1.125); return 0.0; } #endif static double filter_gaussian(const double x) { /* return(exp((double) (-2.0 * x * x)) * sqrt(2.0 / M_PI)); */ return (double)(exp(-2.0f * x * x) * 0.79788456080287f); } static double filter_hanning(const double x) { /* A Cosine windowing function */ return(0.5 + 0.5 * cos(M_PI * x)); } static double filter_hamming(const double x) { /* should be (0.54+0.46*cos(M_PI*(double) x)); but this approximation is sufficient */ if (x < -1.0f) return 0.0f; if (x < 0.0f) return 0.92f*(-2.0f*x-3.0f)*x*x+1.0f; if (x < 1.0f) return 0.92f*(2.0f*x-3.0f)*x*x+1.0f; return 0.0f; } static double filter_power(const double x) { const double a = 2.0f; if (fabs(x)>1) return 0.0f; return (1.0f - (double)fabs(pow(x,a))); } static double filter_sinc(const double x) { /* X-scaled Sinc(x) function. */ if (x == 0.0) return(1.0); return (sin(M_PI * (double) x) / (M_PI * (double) x)); } #ifdef FUNCTION_NOT_USED_YET static double filter_welsh(const double x) { /* Welsh parabolic windowing filter */ if (x < 1.0) return(1 - x*x); return(0.0); } #endif #if defined(_MSC_VER) && !defined(inline) # define inline __inline #endif /* Copied from upstream's libgd */ static inline int _color_blend (const int dst, const int src) { const int src_alpha = gdTrueColorGetAlpha(src); if( src_alpha == gdAlphaOpaque ) { return src; } else { const int dst_alpha = gdTrueColorGetAlpha(dst); if( src_alpha == gdAlphaTransparent ) return dst; if( dst_alpha == gdAlphaTransparent ) { return src; } else { register int alpha, red, green, blue; const int src_weight = gdAlphaTransparent - src_alpha; const int dst_weight = (gdAlphaTransparent - dst_alpha) * src_alpha / gdAlphaMax; const int tot_weight = src_weight + dst_weight; alpha = src_alpha * dst_alpha / gdAlphaMax; red = (gdTrueColorGetRed(src) * src_weight + gdTrueColorGetRed(dst) * dst_weight) / tot_weight; green = (gdTrueColorGetGreen(src) * src_weight + gdTrueColorGetGreen(dst) * dst_weight) / tot_weight; blue = (gdTrueColorGetBlue(src) * src_weight + gdTrueColorGetBlue(dst) * dst_weight) / tot_weight; return ((alpha << 24) + (red << 16) + (green << 8) + blue); } } } static inline int _setEdgePixel(const gdImagePtr src, unsigned int x, unsigned int y, gdFixed coverage, const int bgColor) { const gdFixed f_127 = gd_itofx(127); register int c = src->tpixels[y][x]; c = c | (( (int) (gd_fxtof(gd_mulfx(coverage, f_127)) + 50.5f)) << 24); return _color_blend(bgColor, c); } static inline int getPixelOverflowTC(gdImagePtr im, const int x, const int y, const int bgColor) { if (gdImageBoundsSafe(im, x, y)) { const int c = im->tpixels[y][x]; if (c == im->transparent) { return bgColor == -1 ? gdTrueColorAlpha(0, 0, 0, 127) : bgColor; } return c; } else { register int border = 0; if (y < im->cy1) { border = im->tpixels[0][im->cx1]; goto processborder; } if (y < im->cy1) { border = im->tpixels[0][im->cx1]; goto processborder; } if (y > im->cy2) { if (x >= im->cx1 && x <= im->cx1) { border = im->tpixels[im->cy2][x]; goto processborder; } else { return gdTrueColorAlpha(0, 0, 0, 127); } } /* y is bound safe at this point */ if (x < im->cx1) { border = im->tpixels[y][im->cx1]; goto processborder; } if (x > im->cx2) { border = im->tpixels[y][im->cx2]; } processborder: if (border == im->transparent) { return gdTrueColorAlpha(0, 0, 0, 127); } else{ return gdTrueColorAlpha(gdTrueColorGetRed(border), gdTrueColorGetGreen(border), gdTrueColorGetBlue(border), 127); } } } #define colorIndex2RGBA(c) gdTrueColorAlpha(im->red[(c)], im->green[(c)], im->blue[(c)], im->alpha[(c)]) #define colorIndex2RGBcustomA(c, a) gdTrueColorAlpha(im->red[(c)], im->green[(c)], im->blue[(c)], im->alpha[(a)]) static inline int getPixelOverflowPalette(gdImagePtr im, const int x, const int y, const int bgColor) { if (gdImageBoundsSafe(im, x, y)) { const int c = im->pixels[y][x]; if (c == im->transparent) { return bgColor == -1 ? gdTrueColorAlpha(0, 0, 0, 127) : bgColor; } return colorIndex2RGBA(c); } else { register int border = 0; if (y < im->cy1) { border = gdImageGetPixel(im, im->cx1, 0); goto processborder; } if (y < im->cy1) { border = gdImageGetPixel(im, im->cx1, 0); goto processborder; } if (y > im->cy2) { if (x >= im->cx1 && x <= im->cx1) { border = gdImageGetPixel(im, x, im->cy2); goto processborder; } else { return gdTrueColorAlpha(0, 0, 0, 127); } } /* y is bound safe at this point */ if (x < im->cx1) { border = gdImageGetPixel(im, im->cx1, y); goto processborder; } if (x > im->cx2) { border = gdImageGetPixel(im, im->cx2, y); } processborder: if (border == im->transparent) { return gdTrueColorAlpha(0, 0, 0, 127); } else{ return colorIndex2RGBcustomA(border, 127); } } } static int getPixelInterpolateWeight(gdImagePtr im, const double x, const double y, const int bgColor) { /* Closest pixel <= (xf,yf) */ int sx = (int)(x); int sy = (int)(y); const double xf = x - (double)sx; const double yf = y - (double)sy; const double nxf = (double) 1.0 - xf; const double nyf = (double) 1.0 - yf; const double m1 = xf * yf; const double m2 = nxf * yf; const double m3 = xf * nyf; const double m4 = nxf * nyf; /* get color values of neighbouring pixels */ const int c1 = im->trueColor == 1 ? getPixelOverflowTC(im, sx, sy, bgColor) : getPixelOverflowPalette(im, sx, sy, bgColor); const int c2 = im->trueColor == 1 ? getPixelOverflowTC(im, sx - 1, sy, bgColor) : getPixelOverflowPalette(im, sx - 1, sy, bgColor); const int c3 = im->trueColor == 1 ? getPixelOverflowTC(im, sx, sy - 1, bgColor) : getPixelOverflowPalette(im, sx, sy - 1, bgColor); const int c4 = im->trueColor == 1 ? getPixelOverflowTC(im, sx - 1, sy - 1, bgColor) : getPixelOverflowPalette(im, sx, sy - 1, bgColor); int r, g, b, a; if (x < 0) sx--; if (y < 0) sy--; /* component-wise summing-up of color values */ if (im->trueColor) { r = (int)(m1*gdTrueColorGetRed(c1) + m2*gdTrueColorGetRed(c2) + m3*gdTrueColorGetRed(c3) + m4*gdTrueColorGetRed(c4)); g = (int)(m1*gdTrueColorGetGreen(c1) + m2*gdTrueColorGetGreen(c2) + m3*gdTrueColorGetGreen(c3) + m4*gdTrueColorGetGreen(c4)); b = (int)(m1*gdTrueColorGetBlue(c1) + m2*gdTrueColorGetBlue(c2) + m3*gdTrueColorGetBlue(c3) + m4*gdTrueColorGetBlue(c4)); a = (int)(m1*gdTrueColorGetAlpha(c1) + m2*gdTrueColorGetAlpha(c2) + m3*gdTrueColorGetAlpha(c3) + m4*gdTrueColorGetAlpha(c4)); } else { r = (int)(m1*im->red[(c1)] + m2*im->red[(c2)] + m3*im->red[(c3)] + m4*im->red[(c4)]); g = (int)(m1*im->green[(c1)] + m2*im->green[(c2)] + m3*im->green[(c3)] + m4*im->green[(c4)]); b = (int)(m1*im->blue[(c1)] + m2*im->blue[(c2)] + m3*im->blue[(c3)] + m4*im->blue[(c4)]); a = (int)(m1*im->alpha[(c1)] + m2*im->alpha[(c2)] + m3*im->alpha[(c3)] + m4*im->alpha[(c4)]); } r = CLAMP(r, 0, 255); g = CLAMP(g, 0, 255); b = CLAMP(b, 0, 255); a = CLAMP(a, 0, gdAlphaMax); return gdTrueColorAlpha(r, g, b, a); } /** * InternalFunction: getPixelInterpolated * Returns the interpolated color value using the default interpolation * method. The returned color is always in the ARGB format (truecolor). * * Parameters: * im - Image to set the default interpolation method * y - X value of the ideal position * y - Y value of the ideal position * method - Interpolation method * * Returns: * GD_TRUE if the affine is rectilinear or GD_FALSE * * See also: * */ int getPixelInterpolated(gdImagePtr im, const double x, const double y, const int bgColor) { const int xi=(int)((x) < 0 ? x - 1: x); const int yi=(int)((y) < 0 ? y - 1: y); int yii; int i; double kernel, kernel_cache_y; double kernel_x[12], kernel_y[4]; double new_r = 0.0f, new_g = 0.0f, new_b = 0.0f, new_a = 0.0f; /* These methods use special implementations */ if (im->interpolation_id == GD_BILINEAR_FIXED || im->interpolation_id == GD_BICUBIC_FIXED || im->interpolation_id == GD_NEAREST_NEIGHBOUR) { return -1; } if (im->interpolation_id == GD_WEIGHTED4) { return getPixelInterpolateWeight(im, x, y, bgColor); } if (im->interpolation_id == GD_NEAREST_NEIGHBOUR) { if (im->trueColor == 1) { return getPixelOverflowTC(im, xi, yi, bgColor); } else { return getPixelOverflowPalette(im, xi, yi, bgColor); } } if (im->interpolation) { for (i=0; i<4; i++) { kernel_x[i] = (double) im->interpolation((double)(xi+i-1-x)); kernel_y[i] = (double) im->interpolation((double)(yi+i-1-y)); } } else { return -1; } /* * TODO: use the known fast rgba multiplication implementation once * the new formats are in place */ for (yii = yi-1; yii < yi+3; yii++) { int xii; kernel_cache_y = kernel_y[yii-(yi-1)]; if (im->trueColor) { for (xii=xi-1; xiiWindowSize = windows_size; res->LineLength = line_length; res->ContribRow = (ContributionType *) gdMalloc(line_length * sizeof(ContributionType)); for (u = 0 ; u < line_length ; u++) { res->ContribRow[u].Weights = (double *) gdMalloc(windows_size * sizeof(double)); } return res; } static inline void _gdContributionsFree(LineContribType * p) { unsigned int u; for (u = 0; u < p->LineLength; u++) { gdFree(p->ContribRow[u].Weights); } gdFree(p->ContribRow); gdFree(p); } static inline LineContribType *_gdContributionsCalc(unsigned int line_size, unsigned int src_size, double scale_d, const interpolation_method pFilter) { double width_d; double scale_f_d = 1.0; const double filter_width_d = DEFAULT_BOX_RADIUS; int windows_size; unsigned int u; LineContribType *res; if (scale_d < 1.0) { width_d = filter_width_d / scale_d; scale_f_d = scale_d; } else { width_d= filter_width_d; } windows_size = 2 * (int)ceil(width_d) + 1; res = _gdContributionsAlloc(line_size, windows_size); for (u = 0; u < line_size; u++) { const double dCenter = (double)u / scale_d; /* get the significant edge points affecting the pixel */ register int iLeft = MAX(0, (int)floor (dCenter - width_d)); int iRight = MIN((int)ceil(dCenter + width_d), (int)src_size - 1); double dTotalWeight = 0.0; int iSrc; /* Cut edge points to fit in filter window in case of spill-off */ if (iRight - iLeft + 1 > windows_size) { if (iLeft < ((int)src_size - 1 / 2)) { iLeft++; } else { iRight--; } } res->ContribRow[u].Left = iLeft; res->ContribRow[u].Right = iRight; for (iSrc = iLeft; iSrc <= iRight; iSrc++) { dTotalWeight += (res->ContribRow[u].Weights[iSrc-iLeft] = scale_f_d * (*pFilter)(scale_f_d * (dCenter - (double)iSrc))); } if (dTotalWeight < 0.0) { _gdContributionsFree(res); return NULL; } if (dTotalWeight > 0.0) { for (iSrc = iLeft; iSrc <= iRight; iSrc++) { res->ContribRow[u].Weights[iSrc-iLeft] /= dTotalWeight; } } } return res; } static inline void _gdScaleOneAxis(gdImagePtr pSrc, gdImagePtr dst, unsigned int dst_len, unsigned int row, LineContribType *contrib, gdAxis axis) { unsigned int ndx; for (ndx = 0; ndx < dst_len; ndx++) { double r = 0, g = 0, b = 0, a = 0; const int left = contrib->ContribRow[ndx].Left; const int right = contrib->ContribRow[ndx].Right; int *dest = (axis == HORIZONTAL) ? &dst->tpixels[row][ndx] : &dst->tpixels[ndx][row]; int i; /* Accumulate each channel */ for (i = left; i <= right; i++) { const int left_channel = i - left; const int srcpx = (axis == HORIZONTAL) ? pSrc->tpixels[row][i] : pSrc->tpixels[i][row]; r += contrib->ContribRow[ndx].Weights[left_channel] * (double)(gdTrueColorGetRed(srcpx)); g += contrib->ContribRow[ndx].Weights[left_channel] * (double)(gdTrueColorGetGreen(srcpx)); b += contrib->ContribRow[ndx].Weights[left_channel] * (double)(gdTrueColorGetBlue(srcpx)); a += contrib->ContribRow[ndx].Weights[left_channel] * (double)(gdTrueColorGetAlpha(srcpx)); }/* for */ *dest = gdTrueColorAlpha(uchar_clamp(r, 0xFF), uchar_clamp(g, 0xFF), uchar_clamp(b, 0xFF), uchar_clamp(a, 0x7F)); /* alpha is 0..127 */ }/* for */ }/* _gdScaleOneAxis*/ static inline int _gdScalePass(const gdImagePtr pSrc, const unsigned int src_len, const gdImagePtr pDst, const unsigned int dst_len, const unsigned int num_lines, const gdAxis axis) { unsigned int line_ndx; LineContribType * contrib; /* Same dim, just copy it. */ assert(dst_len != src_len); // TODO: caller should handle this. contrib = _gdContributionsCalc(dst_len, src_len, (double)dst_len / (double)src_len, pSrc->interpolation); if (contrib == NULL) { return 0; } /* Scale each line */ for (line_ndx = 0; line_ndx < num_lines; line_ndx++) { _gdScaleOneAxis(pSrc, pDst, dst_len, line_ndx, contrib, axis); } _gdContributionsFree (contrib); return 1; }/* _gdScalePass*/ static gdImagePtr gdImageScaleTwoPass(const gdImagePtr src, const unsigned int new_width, const unsigned int new_height) { const unsigned int src_width = src->sx; const unsigned int src_height = src->sy; gdImagePtr tmp_im = NULL;; gdImagePtr dst = NULL; /* First, handle the trivial case. */ if (src_width == new_width && src_height == new_height) { return gdImageClone(src); }/* if */ /* Convert to truecolor if it isn't; this code requires it. */ if (!src->trueColor) { gdImagePaletteToTrueColor(src); }/* if */ /* Scale horizontally unless sizes are the same. */ if (src_width == new_width) { tmp_im = src; } else { tmp_im = gdImageCreateTrueColor(new_width, src_height); if (tmp_im == NULL) { return NULL; } gdImageSetInterpolationMethod(tmp_im, src->interpolation_id); _gdScalePass(src, src_width, tmp_im, new_width, src_height, HORIZONTAL); }/* if .. else*/ /* If vertical sizes match, we're done. */ if (src_height == new_height) { assert(tmp_im != src); return tmp_im; }/* if */ /* Otherwise, we need to scale vertically. */ dst = gdImageCreateTrueColor(new_width, new_height); if (dst != NULL) { gdImageSetInterpolationMethod(dst, src->interpolation_id); _gdScalePass(tmp_im, src_height, dst, new_height, new_width, VERTICAL); }/* if */ if (src != tmp_im) { gdFree(tmp_im); }/* if */ return dst; }/* gdImageScaleTwoPass*/ /* BilinearFixed, BicubicFixed and nearest implementations are rewamped versions of the implementation in CBitmapEx http://www.codeproject.com/Articles/29121/CBitmapEx-Free-C-Bitmap-Manipulation-Class Integer only implementation, good to have for common usages like pre scale very large images before using another interpolation methods for the last step. */ static gdImagePtr gdImageScaleNearestNeighbour(gdImagePtr im, const unsigned int width, const unsigned int height) { const unsigned long new_width = MAX(1, width); const unsigned long new_height = MAX(1, height); const float dx = (float)im->sx / (float)new_width; const float dy = (float)im->sy / (float)new_height; const gdFixed f_dx = gd_ftofx(dx); const gdFixed f_dy = gd_ftofx(dy); gdImagePtr dst_img; unsigned long dst_offset_x; unsigned long dst_offset_y = 0; unsigned int i; dst_img = gdImageCreateTrueColor(new_width, new_height); if (dst_img == NULL) { return NULL; } for (i=0; itrueColor) { for (j=0; jtpixels[dst_offset_y][dst_offset_x++] = im->tpixels[m][n]; } } else { for (j=0; jtpixels[dst_offset_y][dst_offset_x++] = colorIndex2RGBA(im->pixels[m][n]); } } dst_offset_y++; } return dst_img; } static inline int getPixelOverflowColorTC(gdImagePtr im, const int x, const int y, const int color) { if (gdImageBoundsSafe(im, x, y)) { const int c = im->tpixels[y][x]; if (c == im->transparent) { return gdTrueColorAlpha(0, 0, 0, 127); } return c; } else { register int border = 0; if (y < im->cy1) { border = im->tpixels[0][im->cx1]; goto processborder; } if (y < im->cy1) { border = im->tpixels[0][im->cx1]; goto processborder; } if (y > im->cy2) { if (x >= im->cx1 && x <= im->cx1) { border = im->tpixels[im->cy2][x]; goto processborder; } else { return gdTrueColorAlpha(0, 0, 0, 127); } } /* y is bound safe at this point */ if (x < im->cx1) { border = im->tpixels[y][im->cx1]; goto processborder; } if (x > im->cx2) { border = im->tpixels[y][im->cx2]; } processborder: if (border == im->transparent) { return gdTrueColorAlpha(0, 0, 0, 127); } else{ return gdTrueColorAlpha(gdTrueColorGetRed(border), gdTrueColorGetGreen(border), gdTrueColorGetBlue(border), 127); } } } static gdImagePtr gdImageScaleBilinearPalette(gdImagePtr im, const unsigned int new_width, const unsigned int new_height) { long _width = MAX(1, new_width); long _height = MAX(1, new_height); float dx = (float)gdImageSX(im) / (float)_width; float dy = (float)gdImageSY(im) / (float)_height; gdFixed f_dx = gd_ftofx(dx); gdFixed f_dy = gd_ftofx(dy); gdFixed f_1 = gd_itofx(1); int dst_offset_h; int dst_offset_v = 0; long i; gdImagePtr new_img; const int transparent = im->transparent; new_img = gdImageCreateTrueColor(new_width, new_height); if (new_img == NULL) { return NULL; } new_img->transparent = gdTrueColorAlpha(im->red[transparent], im->green[transparent], im->blue[transparent], im->alpha[transparent]); for (i=0; i < _height; i++) { long j; const gdFixed f_i = gd_itofx(i); const gdFixed f_a = gd_mulfx(f_i, f_dy); register long m = gd_fxtoi(f_a); dst_offset_h = 0; for (j=0; j < _width; j++) { /* Update bitmap */ gdFixed f_j = gd_itofx(j); gdFixed f_b = gd_mulfx(f_j, f_dx); const long n = gd_fxtoi(f_b); gdFixed f_f = f_a - gd_itofx(m); gdFixed f_g = f_b - gd_itofx(n); const gdFixed f_w1 = gd_mulfx(f_1-f_f, f_1-f_g); const gdFixed f_w2 = gd_mulfx(f_1-f_f, f_g); const gdFixed f_w3 = gd_mulfx(f_f, f_1-f_g); const gdFixed f_w4 = gd_mulfx(f_f, f_g); unsigned int pixel1; unsigned int pixel2; unsigned int pixel3; unsigned int pixel4; register gdFixed f_r1, f_r2, f_r3, f_r4, f_g1, f_g2, f_g3, f_g4, f_b1, f_b2, f_b3, f_b4, f_a1, f_a2, f_a3, f_a4; /* zero for the background color, nothig gets outside anyway */ pixel1 = getPixelOverflowPalette(im, n, m, 0); pixel2 = getPixelOverflowPalette(im, n + 1, m, 0); pixel3 = getPixelOverflowPalette(im, n, m + 1, 0); pixel4 = getPixelOverflowPalette(im, n + 1, m + 1, 0); f_r1 = gd_itofx(gdTrueColorGetRed(pixel1)); f_r2 = gd_itofx(gdTrueColorGetRed(pixel2)); f_r3 = gd_itofx(gdTrueColorGetRed(pixel3)); f_r4 = gd_itofx(gdTrueColorGetRed(pixel4)); f_g1 = gd_itofx(gdTrueColorGetGreen(pixel1)); f_g2 = gd_itofx(gdTrueColorGetGreen(pixel2)); f_g3 = gd_itofx(gdTrueColorGetGreen(pixel3)); f_g4 = gd_itofx(gdTrueColorGetGreen(pixel4)); f_b1 = gd_itofx(gdTrueColorGetBlue(pixel1)); f_b2 = gd_itofx(gdTrueColorGetBlue(pixel2)); f_b3 = gd_itofx(gdTrueColorGetBlue(pixel3)); f_b4 = gd_itofx(gdTrueColorGetBlue(pixel4)); f_a1 = gd_itofx(gdTrueColorGetAlpha(pixel1)); f_a2 = gd_itofx(gdTrueColorGetAlpha(pixel2)); f_a3 = gd_itofx(gdTrueColorGetAlpha(pixel3)); f_a4 = gd_itofx(gdTrueColorGetAlpha(pixel4)); { const char red = (char) gd_fxtoi(gd_mulfx(f_w1, f_r1) + gd_mulfx(f_w2, f_r2) + gd_mulfx(f_w3, f_r3) + gd_mulfx(f_w4, f_r4)); const char green = (char) gd_fxtoi(gd_mulfx(f_w1, f_g1) + gd_mulfx(f_w2, f_g2) + gd_mulfx(f_w3, f_g3) + gd_mulfx(f_w4, f_g4)); const char blue = (char) gd_fxtoi(gd_mulfx(f_w1, f_b1) + gd_mulfx(f_w2, f_b2) + gd_mulfx(f_w3, f_b3) + gd_mulfx(f_w4, f_b4)); const char alpha = (char) gd_fxtoi(gd_mulfx(f_w1, f_a1) + gd_mulfx(f_w2, f_a2) + gd_mulfx(f_w3, f_a3) + gd_mulfx(f_w4, f_a4)); new_img->tpixels[dst_offset_v][dst_offset_h] = gdTrueColorAlpha(red, green, blue, alpha); } dst_offset_h++; } dst_offset_v++; } return new_img; } static gdImagePtr gdImageScaleBilinearTC(gdImagePtr im, const unsigned int new_width, const unsigned int new_height) { long dst_w = MAX(1, new_width); long dst_h = MAX(1, new_height); float dx = (float)gdImageSX(im) / (float)dst_w; float dy = (float)gdImageSY(im) / (float)dst_h; gdFixed f_dx = gd_ftofx(dx); gdFixed f_dy = gd_ftofx(dy); gdFixed f_1 = gd_itofx(1); int dst_offset_h; int dst_offset_v = 0; long i; gdImagePtr new_img; new_img = gdImageCreateTrueColor(new_width, new_height); if (!new_img){ return NULL; } for (i=0; i < dst_h; i++) { long j; dst_offset_h = 0; for (j=0; j < dst_w; j++) { /* Update bitmap */ gdFixed f_i = gd_itofx(i); gdFixed f_j = gd_itofx(j); gdFixed f_a = gd_mulfx(f_i, f_dy); gdFixed f_b = gd_mulfx(f_j, f_dx); const gdFixed m = gd_fxtoi(f_a); const gdFixed n = gd_fxtoi(f_b); gdFixed f_f = f_a - gd_itofx(m); gdFixed f_g = f_b - gd_itofx(n); const gdFixed f_w1 = gd_mulfx(f_1-f_f, f_1-f_g); const gdFixed f_w2 = gd_mulfx(f_1-f_f, f_g); const gdFixed f_w3 = gd_mulfx(f_f, f_1-f_g); const gdFixed f_w4 = gd_mulfx(f_f, f_g); unsigned int pixel1; unsigned int pixel2; unsigned int pixel3; unsigned int pixel4; register gdFixed f_r1, f_r2, f_r3, f_r4, f_g1, f_g2, f_g3, f_g4, f_b1, f_b2, f_b3, f_b4, f_a1, f_a2, f_a3, f_a4; /* 0 for bgColor, nothing gets outside anyway */ pixel1 = getPixelOverflowTC(im, n, m, 0); pixel2 = getPixelOverflowTC(im, n + 1, m, 0); pixel3 = getPixelOverflowTC(im, n, m + 1, 0); pixel4 = getPixelOverflowTC(im, n + 1, m + 1, 0); f_r1 = gd_itofx(gdTrueColorGetRed(pixel1)); f_r2 = gd_itofx(gdTrueColorGetRed(pixel2)); f_r3 = gd_itofx(gdTrueColorGetRed(pixel3)); f_r4 = gd_itofx(gdTrueColorGetRed(pixel4)); f_g1 = gd_itofx(gdTrueColorGetGreen(pixel1)); f_g2 = gd_itofx(gdTrueColorGetGreen(pixel2)); f_g3 = gd_itofx(gdTrueColorGetGreen(pixel3)); f_g4 = gd_itofx(gdTrueColorGetGreen(pixel4)); f_b1 = gd_itofx(gdTrueColorGetBlue(pixel1)); f_b2 = gd_itofx(gdTrueColorGetBlue(pixel2)); f_b3 = gd_itofx(gdTrueColorGetBlue(pixel3)); f_b4 = gd_itofx(gdTrueColorGetBlue(pixel4)); f_a1 = gd_itofx(gdTrueColorGetAlpha(pixel1)); f_a2 = gd_itofx(gdTrueColorGetAlpha(pixel2)); f_a3 = gd_itofx(gdTrueColorGetAlpha(pixel3)); f_a4 = gd_itofx(gdTrueColorGetAlpha(pixel4)); { const unsigned char red = (unsigned char) gd_fxtoi(gd_mulfx(f_w1, f_r1) + gd_mulfx(f_w2, f_r2) + gd_mulfx(f_w3, f_r3) + gd_mulfx(f_w4, f_r4)); const unsigned char green = (unsigned char) gd_fxtoi(gd_mulfx(f_w1, f_g1) + gd_mulfx(f_w2, f_g2) + gd_mulfx(f_w3, f_g3) + gd_mulfx(f_w4, f_g4)); const unsigned char blue = (unsigned char) gd_fxtoi(gd_mulfx(f_w1, f_b1) + gd_mulfx(f_w2, f_b2) + gd_mulfx(f_w3, f_b3) + gd_mulfx(f_w4, f_b4)); const unsigned char alpha = (unsigned char) gd_fxtoi(gd_mulfx(f_w1, f_a1) + gd_mulfx(f_w2, f_a2) + gd_mulfx(f_w3, f_a3) + gd_mulfx(f_w4, f_a4)); new_img->tpixels[dst_offset_v][dst_offset_h] = gdTrueColorAlpha(red, green, blue, alpha); } dst_offset_h++; } dst_offset_v++; } return new_img; } static gdImagePtr gdImageScaleBilinear(gdImagePtr im, const unsigned int new_width, const unsigned int new_height) { if (im->trueColor) { return gdImageScaleBilinearTC(im, new_width, new_height); } else { return gdImageScaleBilinearPalette(im, new_width, new_height); } } static gdImagePtr gdImageScaleBicubicFixed(gdImagePtr src, const unsigned int width, const unsigned int height) { const long new_width = MAX(1, width); const long new_height = MAX(1, height); const int src_w = gdImageSX(src); const int src_h = gdImageSY(src); const gdFixed f_dx = gd_ftofx((float)src_w / (float)new_width); const gdFixed f_dy = gd_ftofx((float)src_h / (float)new_height); const gdFixed f_1 = gd_itofx(1); const gdFixed f_2 = gd_itofx(2); const gdFixed f_4 = gd_itofx(4); const gdFixed f_6 = gd_itofx(6); const gdFixed f_gamma = gd_ftofx(1.04f); gdImagePtr dst; unsigned int dst_offset_x; unsigned int dst_offset_y = 0; long i; /* impact perf a bit, but not that much. Implementation for palette images can be done at a later point. */ if (src->trueColor == 0) { gdImagePaletteToTrueColor(src); } dst = gdImageCreateTrueColor(new_width, new_height); if (!dst) { return NULL; } dst->saveAlphaFlag = 1; for (i=0; i < new_height; i++) { long j; dst_offset_x = 0; for (j=0; j < new_width; j++) { const gdFixed f_a = gd_mulfx(gd_itofx(i), f_dy); const gdFixed f_b = gd_mulfx(gd_itofx(j), f_dx); const long m = gd_fxtoi(f_a); const long n = gd_fxtoi(f_b); const gdFixed f_f = f_a - gd_itofx(m); const gdFixed f_g = f_b - gd_itofx(n); unsigned int src_offset_x[16], src_offset_y[16]; long k; register gdFixed f_red = 0, f_green = 0, f_blue = 0, f_alpha = 0; unsigned char red, green, blue, alpha = 0; int *dst_row = dst->tpixels[dst_offset_y]; if ((m < 1) || (n < 1)) { src_offset_x[0] = n; src_offset_y[0] = m; } else { src_offset_x[0] = n - 1; src_offset_y[0] = m; } if (m < 1) { src_offset_x[1] = n; src_offset_y[1] = m; } else { src_offset_x[1] = n; src_offset_y[1] = m; } if ((m < 1) || (n >= src_w - 1)) { src_offset_x[2] = n; src_offset_y[2] = m; } else { src_offset_x[2] = n + 1; src_offset_y[2] = m; } if ((m < 1) || (n >= src_w - 2)) { src_offset_x[3] = n; src_offset_y[3] = m; } else { src_offset_x[3] = n + 1 + 1; src_offset_y[3] = m; } if (n < 1) { src_offset_x[4] = n; src_offset_y[4] = m; } else { src_offset_x[4] = n - 1; src_offset_y[4] = m; } src_offset_x[5] = n; src_offset_y[5] = m; if (n >= src_w-1) { src_offset_x[6] = n; src_offset_y[6] = m; } else { src_offset_x[6] = n + 1; src_offset_y[6] = m; } if (n >= src_w - 2) { src_offset_x[7] = n; src_offset_y[7] = m; } else { src_offset_x[7] = n + 1 + 1; src_offset_y[7] = m; } if ((m >= src_h - 1) || (n < 1)) { src_offset_x[8] = n; src_offset_y[8] = m; } else { src_offset_x[8] = n - 1; src_offset_y[8] = m; } if (m >= src_h - 1) { src_offset_x[8] = n; src_offset_y[8] = m; } else { src_offset_x[9] = n; src_offset_y[9] = m; } if ((m >= src_h-1) || (n >= src_w-1)) { src_offset_x[10] = n; src_offset_y[10] = m; } else { src_offset_x[10] = n + 1; src_offset_y[10] = m; } if ((m >= src_h - 1) || (n >= src_w - 2)) { src_offset_x[11] = n; src_offset_y[11] = m; } else { src_offset_x[11] = n + 1 + 1; src_offset_y[11] = m; } if ((m >= src_h - 2) || (n < 1)) { src_offset_x[12] = n; src_offset_y[12] = m; } else { src_offset_x[12] = n - 1; src_offset_y[12] = m; } if (m >= src_h - 2) { src_offset_x[13] = n; src_offset_y[13] = m; } else { src_offset_x[13] = n; src_offset_y[13] = m; } if ((m >= src_h - 2) || (n >= src_w - 1)) { src_offset_x[14] = n; src_offset_y[14] = m; } else { src_offset_x[14] = n + 1; src_offset_y[14] = m; } if ((m >= src_h - 2) || (n >= src_w - 2)) { src_offset_x[15] = n; src_offset_y[15] = m; } else { src_offset_x[15] = n + 1 + 1; src_offset_y[15] = m; } for (k = -1; k < 3; k++) { const gdFixed f = gd_itofx(k)-f_f; const gdFixed f_fm1 = f - f_1; const gdFixed f_fp1 = f + f_1; const gdFixed f_fp2 = f + f_2; register gdFixed f_a = 0, f_b = 0, f_d = 0, f_c = 0; register gdFixed f_RY; int l; if (f_fp2 > 0) f_a = gd_mulfx(f_fp2, gd_mulfx(f_fp2,f_fp2)); if (f_fp1 > 0) f_b = gd_mulfx(f_fp1, gd_mulfx(f_fp1,f_fp1)); if (f > 0) f_c = gd_mulfx(f, gd_mulfx(f,f)); if (f_fm1 > 0) f_d = gd_mulfx(f_fm1, gd_mulfx(f_fm1,f_fm1)); f_RY = gd_divfx((f_a - gd_mulfx(f_4,f_b) + gd_mulfx(f_6,f_c) - gd_mulfx(f_4,f_d)),f_6); for (l = -1; l < 3; l++) { const gdFixed f = gd_itofx(l) - f_g; const gdFixed f_fm1 = f - f_1; const gdFixed f_fp1 = f + f_1; const gdFixed f_fp2 = f + f_2; register gdFixed f_a = 0, f_b = 0, f_c = 0, f_d = 0; register gdFixed f_RX, f_R, f_rs, f_gs, f_bs, f_ba; register int c; const int _k = ((k+1)*4) + (l+1); if (f_fp2 > 0) f_a = gd_mulfx(f_fp2,gd_mulfx(f_fp2,f_fp2)); if (f_fp1 > 0) f_b = gd_mulfx(f_fp1,gd_mulfx(f_fp1,f_fp1)); if (f > 0) f_c = gd_mulfx(f,gd_mulfx(f,f)); if (f_fm1 > 0) f_d = gd_mulfx(f_fm1,gd_mulfx(f_fm1,f_fm1)); f_RX = gd_divfx((f_a-gd_mulfx(f_4,f_b)+gd_mulfx(f_6,f_c)-gd_mulfx(f_4,f_d)),f_6); f_R = gd_mulfx(f_RY,f_RX); c = src->tpixels[*(src_offset_y + _k)][*(src_offset_x + _k)]; f_rs = gd_itofx(gdTrueColorGetRed(c)); f_gs = gd_itofx(gdTrueColorGetGreen(c)); f_bs = gd_itofx(gdTrueColorGetBlue(c)); f_ba = gd_itofx(gdTrueColorGetAlpha(c)); f_red += gd_mulfx(f_rs,f_R); f_green += gd_mulfx(f_gs,f_R); f_blue += gd_mulfx(f_bs,f_R); f_alpha += gd_mulfx(f_ba,f_R); } } red = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_red, f_gamma)), 0, 255); green = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_green, f_gamma)), 0, 255); blue = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_blue, f_gamma)), 0, 255); alpha = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_alpha, f_gamma)), 0, 127); *(dst_row + dst_offset_x) = gdTrueColorAlpha(red, green, blue, alpha); dst_offset_x++; } dst_offset_y++; } return dst; } BGD_DECLARE(gdImagePtr) gdImageScale(const gdImagePtr src, const unsigned int new_width, const unsigned int new_height) { gdImagePtr im_scaled = NULL; if (src == NULL || src->interpolation_id < 0 || src->interpolation_id > GD_METHOD_COUNT) { return 0; } switch (src->interpolation_id) { /*Special cases, optimized implementations */ case GD_NEAREST_NEIGHBOUR: im_scaled = gdImageScaleNearestNeighbour(src, new_width, new_height); break; case GD_BILINEAR_FIXED: im_scaled = gdImageScaleBilinear(src, new_width, new_height); break; case GD_BICUBIC_FIXED: im_scaled = gdImageScaleBicubicFixed(src, new_width, new_height); break; /* generic */ default: if (src->interpolation == NULL) { return NULL; } im_scaled = gdImageScaleTwoPass(src, new_width, new_height); break; } return im_scaled; } static gdImagePtr gdImageRotateNearestNeighbour(gdImagePtr src, const float degrees, const int bgColor) { float _angle = ((float) (-degrees / 180.0f) * (float)M_PI); const int src_w = gdImageSX(src); const int src_h = gdImageSY(src); const unsigned int new_width = (unsigned int)(abs((int)(src_w * cos(_angle))) + abs((int)(src_h * sin(_angle))) + 0.5f); const unsigned int new_height = (unsigned int)(abs((int)(src_w * sin(_angle))) + abs((int)(src_h * cos(_angle))) + 0.5f); const gdFixed f_0_5 = gd_ftofx(0.5f); const gdFixed f_H = gd_itofx(src_h/2); const gdFixed f_W = gd_itofx(src_w/2); const gdFixed f_cos = gd_ftofx(cos(-_angle)); const gdFixed f_sin = gd_ftofx(sin(-_angle)); unsigned int dst_offset_x; unsigned int dst_offset_y = 0; unsigned int i; gdImagePtr dst; /* impact perf a bit, but not that much. Implementation for palette images can be done at a later point. */ if (src->trueColor == 0) { gdImagePaletteToTrueColor(src); } dst = gdImageCreateTrueColor(new_width, new_height); if (!dst) { return NULL; } dst->saveAlphaFlag = 1; for (i = 0; i < new_height; i++) { unsigned int j; dst_offset_x = 0; for (j = 0; j < new_width; j++) { gdFixed f_i = gd_itofx((int)i - (int)new_height / 2); gdFixed f_j = gd_itofx((int)j - (int)new_width / 2); gdFixed f_m = gd_mulfx(f_j,f_sin) + gd_mulfx(f_i,f_cos) + f_0_5 + f_H; gdFixed f_n = gd_mulfx(f_j,f_cos) - gd_mulfx(f_i,f_sin) + f_0_5 + f_W; long m = gd_fxtoi(f_m); long n = gd_fxtoi(f_n); if ((m > 0) && (m < src_h-1) && (n > 0) && (n < src_w-1)) { if (dst_offset_y < new_height) { dst->tpixels[dst_offset_y][dst_offset_x++] = src->tpixels[m][n]; } } else { if (dst_offset_y < new_height) { dst->tpixels[dst_offset_y][dst_offset_x++] = bgColor; } } } dst_offset_y++; } return dst; } static gdImagePtr gdImageRotateGeneric(gdImagePtr src, const float degrees, const int bgColor) { float _angle = ((float) (-degrees / 180.0f) * (float)M_PI); const int src_w = gdImageSX(src); const int src_h = gdImageSY(src); const unsigned int new_width = (unsigned int)(abs((int)(src_w * cos(_angle))) + abs((int)(src_h * sin(_angle))) + 0.5f); const unsigned int new_height = (unsigned int)(abs((int)(src_w * sin(_angle))) + abs((int)(src_h * cos(_angle))) + 0.5f); const gdFixed f_0_5 = gd_ftofx(0.5f); const gdFixed f_H = gd_itofx(src_h/2); const gdFixed f_W = gd_itofx(src_w/2); const gdFixed f_cos = gd_ftofx(cos(-_angle)); const gdFixed f_sin = gd_ftofx(sin(-_angle)); unsigned int dst_offset_x; unsigned int dst_offset_y = 0; unsigned int i; gdImagePtr dst; const gdFixed f_slop_y = f_sin; const gdFixed f_slop_x = f_cos; const gdFixed f_slop = f_slop_x > 0 && f_slop_x > 0 ? f_slop_x > f_slop_y ? gd_divfx(f_slop_y, f_slop_x) : gd_divfx(f_slop_x, f_slop_y) : 0; if (bgColor < 0) { return NULL; } /* impact perf a bit, but not that much. Implementation for palette images can be done at a later point. */ if (src->trueColor == 0) { gdImagePaletteToTrueColor(src); } dst = gdImageCreateTrueColor(new_width, new_height); if (!dst) { return NULL; } dst->saveAlphaFlag = 1; for (i = 0; i < new_height; i++) { unsigned int j; dst_offset_x = 0; for (j = 0; j < new_width; j++) { gdFixed f_i = gd_itofx((int)i - (int)new_height / 2); gdFixed f_j = gd_itofx((int)j - (int)new_width / 2); gdFixed f_m = gd_mulfx(f_j,f_sin) + gd_mulfx(f_i,f_cos) + f_0_5 + f_H; gdFixed f_n = gd_mulfx(f_j,f_cos) - gd_mulfx(f_i,f_sin) + f_0_5 + f_W; long m = gd_fxtoi(f_m); long n = gd_fxtoi(f_n); if ((n <= 0) || (m <= 0) || (m >= src_h) || (n >= src_w)) { dst->tpixels[dst_offset_y][dst_offset_x++] = bgColor; } else if ((n <= 1) || (m <= 1) || (m >= src_h - 1) || (n >= src_w - 1)) { register int c = getPixelInterpolated(src, n, m, bgColor); c = c | (( gdTrueColorGetAlpha(c) + ((int)(127* gd_fxtof(f_slop)))) << 24); dst->tpixels[dst_offset_y][dst_offset_x++] = _color_blend(bgColor, c); } else { dst->tpixels[dst_offset_y][dst_offset_x++] = getPixelInterpolated(src, n, m, bgColor); } } dst_offset_y++; } return dst; } static gdImagePtr gdImageRotateBilinear(gdImagePtr src, const float degrees, const int bgColor) { float _angle = (float)((- degrees / 180.0f) * M_PI); const unsigned int src_w = gdImageSX(src); const unsigned int src_h = gdImageSY(src); unsigned int new_width = abs((int)(src_w*cos(_angle))) + abs((int)(src_h*sin(_angle) + 0.5f)); unsigned int new_height = abs((int)(src_w*sin(_angle))) + abs((int)(src_h*cos(_angle) + 0.5f)); const gdFixed f_0_5 = gd_ftofx(0.5f); const gdFixed f_H = gd_itofx(src_h/2); const gdFixed f_W = gd_itofx(src_w/2); const gdFixed f_cos = gd_ftofx(cos(-_angle)); const gdFixed f_sin = gd_ftofx(sin(-_angle)); const gdFixed f_1 = gd_itofx(1); unsigned int i; unsigned int dst_offset_x; unsigned int dst_offset_y = 0; unsigned int src_offset_x, src_offset_y; gdImagePtr dst; /* impact perf a bit, but not that much. Implementation for palette images can be done at a later point. */ if (src->trueColor == 0) { gdImagePaletteToTrueColor(src); } dst = gdImageCreateTrueColor(new_width, new_height); if (dst == NULL) { return NULL; } dst->saveAlphaFlag = 1; for (i = 0; i < new_height; i++) { unsigned int j; dst_offset_x = 0; for (j=0; j < new_width; j++) { const gdFixed f_i = gd_itofx((int)i - (int)new_height / 2); const gdFixed f_j = gd_itofx((int)j - (int)new_width / 2); const gdFixed f_m = gd_mulfx(f_j,f_sin) + gd_mulfx(f_i,f_cos) + f_0_5 + f_H; const gdFixed f_n = gd_mulfx(f_j,f_cos) - gd_mulfx(f_i,f_sin) + f_0_5 + f_W; const unsigned int m = gd_fxtoi(f_m); const unsigned int n = gd_fxtoi(f_n); if ((m > 0) && (m < src_h - 1) && (n > 0) && (n < src_w - 1)) { const gdFixed f_f = f_m - gd_itofx(m); const gdFixed f_g = f_n - gd_itofx(n); const gdFixed f_w1 = gd_mulfx(f_1-f_f, f_1-f_g); const gdFixed f_w2 = gd_mulfx(f_1-f_f, f_g); const gdFixed f_w3 = gd_mulfx(f_f, f_1-f_g); const gdFixed f_w4 = gd_mulfx(f_f, f_g); if (n < src_w - 1) { src_offset_x = n + 1; src_offset_y = m; } if (m < src_h - 1) { src_offset_x = n; src_offset_y = m + 1; } if (!((n >= src_w - 1) || (m >= src_h - 1))) { src_offset_x = n + 1; src_offset_y = m + 1; } { const int pixel1 = src->tpixels[src_offset_y][src_offset_x]; register int pixel2, pixel3, pixel4; if (src_offset_y + 1 >= src_h) { pixel2 = bgColor; pixel3 = bgColor; pixel4 = bgColor; } else if (src_offset_x + 1 >= src_w) { pixel2 = bgColor; pixel3 = bgColor; pixel4 = bgColor; } else { pixel2 = src->tpixels[src_offset_y][src_offset_x + 1]; pixel3 = src->tpixels[src_offset_y + 1][src_offset_x]; pixel4 = src->tpixels[src_offset_y + 1][src_offset_x + 1]; } { const gdFixed f_r1 = gd_itofx(gdTrueColorGetRed(pixel1)); const gdFixed f_r2 = gd_itofx(gdTrueColorGetRed(pixel2)); const gdFixed f_r3 = gd_itofx(gdTrueColorGetRed(pixel3)); const gdFixed f_r4 = gd_itofx(gdTrueColorGetRed(pixel4)); const gdFixed f_g1 = gd_itofx(gdTrueColorGetGreen(pixel1)); const gdFixed f_g2 = gd_itofx(gdTrueColorGetGreen(pixel2)); const gdFixed f_g3 = gd_itofx(gdTrueColorGetGreen(pixel3)); const gdFixed f_g4 = gd_itofx(gdTrueColorGetGreen(pixel4)); const gdFixed f_b1 = gd_itofx(gdTrueColorGetBlue(pixel1)); const gdFixed f_b2 = gd_itofx(gdTrueColorGetBlue(pixel2)); const gdFixed f_b3 = gd_itofx(gdTrueColorGetBlue(pixel3)); const gdFixed f_b4 = gd_itofx(gdTrueColorGetBlue(pixel4)); const gdFixed f_a1 = gd_itofx(gdTrueColorGetAlpha(pixel1)); const gdFixed f_a2 = gd_itofx(gdTrueColorGetAlpha(pixel2)); const gdFixed f_a3 = gd_itofx(gdTrueColorGetAlpha(pixel3)); const gdFixed f_a4 = gd_itofx(gdTrueColorGetAlpha(pixel4)); const gdFixed f_red = gd_mulfx(f_w1, f_r1) + gd_mulfx(f_w2, f_r2) + gd_mulfx(f_w3, f_r3) + gd_mulfx(f_w4, f_r4); const gdFixed f_green = gd_mulfx(f_w1, f_g1) + gd_mulfx(f_w2, f_g2) + gd_mulfx(f_w3, f_g3) + gd_mulfx(f_w4, f_g4); const gdFixed f_blue = gd_mulfx(f_w1, f_b1) + gd_mulfx(f_w2, f_b2) + gd_mulfx(f_w3, f_b3) + gd_mulfx(f_w4, f_b4); const gdFixed f_alpha = gd_mulfx(f_w1, f_a1) + gd_mulfx(f_w2, f_a2) + gd_mulfx(f_w3, f_a3) + gd_mulfx(f_w4, f_a4); const unsigned char red = (unsigned char) CLAMP(gd_fxtoi(f_red), 0, 255); const unsigned char green = (unsigned char) CLAMP(gd_fxtoi(f_green), 0, 255); const unsigned char blue = (unsigned char) CLAMP(gd_fxtoi(f_blue), 0, 255); const unsigned char alpha = (unsigned char) CLAMP(gd_fxtoi(f_alpha), 0, 127); dst->tpixels[dst_offset_y][dst_offset_x++] = gdTrueColorAlpha(red, green, blue, alpha); } } } else { dst->tpixels[dst_offset_y][dst_offset_x++] = bgColor; } } dst_offset_y++; } return dst; } static gdImagePtr gdImageRotateBicubicFixed(gdImagePtr src, const float degrees,const int bgColor) { const float _angle = (float)((- degrees / 180.0f) * M_PI); const int src_w = gdImageSX(src); const int src_h = gdImageSY(src); const unsigned int new_width = abs((int)(src_w*cos(_angle))) + abs((int)(src_h*sin(_angle) + 0.5f)); const unsigned int new_height = abs((int)(src_w*sin(_angle))) + abs((int)(src_h*cos(_angle) + 0.5f)); const gdFixed f_0_5 = gd_ftofx(0.5f); const gdFixed f_H = gd_itofx(src_h/2); const gdFixed f_W = gd_itofx(src_w/2); const gdFixed f_cos = gd_ftofx(cos(-_angle)); const gdFixed f_sin = gd_ftofx(sin(-_angle)); const gdFixed f_1 = gd_itofx(1); const gdFixed f_2 = gd_itofx(2); const gdFixed f_4 = gd_itofx(4); const gdFixed f_6 = gd_itofx(6); const gdFixed f_gama = gd_ftofx(1.04f); unsigned int dst_offset_x; unsigned int dst_offset_y = 0; unsigned int i; gdImagePtr dst; /* impact perf a bit, but not that much. Implementation for palette images can be done at a later point. */ if (src->trueColor == 0) { gdImagePaletteToTrueColor(src); } dst = gdImageCreateTrueColor(new_width, new_height); if (dst == NULL) { return NULL; } dst->saveAlphaFlag = 1; for (i=0; i < new_height; i++) { unsigned int j; dst_offset_x = 0; for (j=0; j < new_width; j++) { const gdFixed f_i = gd_itofx((int)i - (int)new_height / 2); const gdFixed f_j = gd_itofx((int)j - (int)new_width / 2); const gdFixed f_m = gd_mulfx(f_j,f_sin) + gd_mulfx(f_i,f_cos) + f_0_5 + f_H; const gdFixed f_n = gd_mulfx(f_j,f_cos) - gd_mulfx(f_i,f_sin) + f_0_5 + f_W; const int m = gd_fxtoi(f_m); const int n = gd_fxtoi(f_n); if ((m > 0) && (m < src_h - 1) && (n > 0) && (n < src_w-1)) { const gdFixed f_f = f_m - gd_itofx(m); const gdFixed f_g = f_n - gd_itofx(n); unsigned int src_offset_x[16], src_offset_y[16]; unsigned char red, green, blue, alpha; gdFixed f_red=0, f_green=0, f_blue=0, f_alpha=0; int k; if ((m < 1) || (n < 1)) { src_offset_x[0] = n; src_offset_y[0] = m; } else { src_offset_x[0] = n - 1; src_offset_y[0] = m; } if (m < 1) { src_offset_x[1] = n; src_offset_y[1] = m; } else { src_offset_x[1] = n; src_offset_y[1] = m ; } if ((m < 1) || (n >= src_w-1)) { src_offset_x[2] = - 1; src_offset_y[2] = - 1; } else { src_offset_x[2] = n + 1; src_offset_y[2] = m ; } if ((m < 1) || (n >= src_w-2)) { src_offset_x[3] = - 1; src_offset_y[3] = - 1; } else { src_offset_x[3] = n + 1 + 1; src_offset_y[3] = m ; } if (n < 1) { src_offset_x[4] = - 1; src_offset_y[4] = - 1; } else { src_offset_x[4] = n - 1; src_offset_y[4] = m; } src_offset_x[5] = n; src_offset_y[5] = m; if (n >= src_w-1) { src_offset_x[6] = - 1; src_offset_y[6] = - 1; } else { src_offset_x[6] = n + 1; src_offset_y[6] = m; } if (n >= src_w-2) { src_offset_x[7] = - 1; src_offset_y[7] = - 1; } else { src_offset_x[7] = n + 1 + 1; src_offset_y[7] = m; } if ((m >= src_h-1) || (n < 1)) { src_offset_x[8] = - 1; src_offset_y[8] = - 1; } else { src_offset_x[8] = n - 1; src_offset_y[8] = m; } if (m >= src_h-1) { src_offset_x[8] = - 1; src_offset_y[8] = - 1; } else { src_offset_x[9] = n; src_offset_y[9] = m; } if ((m >= src_h-1) || (n >= src_w-1)) { src_offset_x[10] = - 1; src_offset_y[10] = - 1; } else { src_offset_x[10] = n + 1; src_offset_y[10] = m; } if ((m >= src_h-1) || (n >= src_w-2)) { src_offset_x[11] = - 1; src_offset_y[11] = - 1; } else { src_offset_x[11] = n + 1 + 1; src_offset_y[11] = m; } if ((m >= src_h-2) || (n < 1)) { src_offset_x[12] = - 1; src_offset_y[12] = - 1; } else { src_offset_x[12] = n - 1; src_offset_y[12] = m; } if (m >= src_h-2) { src_offset_x[13] = - 1; src_offset_y[13] = - 1; } else { src_offset_x[13] = n; src_offset_y[13] = m; } if ((m >= src_h-2) || (n >= src_w - 1)) { src_offset_x[14] = - 1; src_offset_y[14] = - 1; } else { src_offset_x[14] = n + 1; src_offset_y[14] = m; } if ((m >= src_h-2) || (n >= src_w-2)) { src_offset_x[15] = - 1; src_offset_y[15] = - 1; } else { src_offset_x[15] = n + 1 + 1; src_offset_y[15] = m; } for (k=-1; k<3; k++) { const gdFixed f = gd_itofx(k)-f_f; const gdFixed f_fm1 = f - f_1; const gdFixed f_fp1 = f + f_1; const gdFixed f_fp2 = f + f_2; gdFixed f_a = 0, f_b = 0,f_c = 0, f_d = 0; gdFixed f_RY; int l; if (f_fp2 > 0) { f_a = gd_mulfx(f_fp2,gd_mulfx(f_fp2,f_fp2)); } if (f_fp1 > 0) { f_b = gd_mulfx(f_fp1,gd_mulfx(f_fp1,f_fp1)); } if (f > 0) { f_c = gd_mulfx(f,gd_mulfx(f,f)); } if (f_fm1 > 0) { f_d = gd_mulfx(f_fm1,gd_mulfx(f_fm1,f_fm1)); } f_RY = gd_divfx((f_a-gd_mulfx(f_4,f_b)+gd_mulfx(f_6,f_c)-gd_mulfx(f_4,f_d)),f_6); for (l=-1; l< 3; l++) { const gdFixed f = gd_itofx(l) - f_g; const gdFixed f_fm1 = f - f_1; const gdFixed f_fp1 = f + f_1; const gdFixed f_fp2 = f + f_2; gdFixed f_a = 0, f_b = 0, f_c = 0, f_d = 0; gdFixed f_RX, f_R; const int _k = ((k + 1) * 4) + (l + 1); register gdFixed f_rs, f_gs, f_bs, f_as; register int c; if (f_fp2 > 0) { f_a = gd_mulfx(f_fp2,gd_mulfx(f_fp2,f_fp2)); } if (f_fp1 > 0) { f_b = gd_mulfx(f_fp1,gd_mulfx(f_fp1,f_fp1)); } if (f > 0) { f_c = gd_mulfx(f,gd_mulfx(f,f)); } if (f_fm1 > 0) { f_d = gd_mulfx(f_fm1,gd_mulfx(f_fm1,f_fm1)); } f_RX = gd_divfx((f_a - gd_mulfx(f_4, f_b) + gd_mulfx(f_6, f_c) - gd_mulfx(f_4, f_d)), f_6); f_R = gd_mulfx(f_RY, f_RX); if ((src_offset_x[_k] <= 0) || (src_offset_y[_k] <= 0) || (src_offset_y[_k] >= src_h) || (src_offset_x[_k] >= src_w)) { c = bgColor; } else if ((src_offset_x[_k] <= 1) || (src_offset_y[_k] <= 1) || (src_offset_y[_k] >= (int)src_h - 1) || (src_offset_x[_k] >= (int)src_w - 1)) { gdFixed f_127 = gd_itofx(127); c = src->tpixels[src_offset_y[_k]][src_offset_x[_k]]; c = c | (( (int) (gd_fxtof(gd_mulfx(f_R, f_127)) + 50.5f)) << 24); c = _color_blend(bgColor, c); } else { c = src->tpixels[src_offset_y[_k]][src_offset_x[_k]]; } f_rs = gd_itofx(gdTrueColorGetRed(c)); f_gs = gd_itofx(gdTrueColorGetGreen(c)); f_bs = gd_itofx(gdTrueColorGetBlue(c)); f_as = gd_itofx(gdTrueColorGetAlpha(c)); f_red += gd_mulfx(f_rs, f_R); f_green += gd_mulfx(f_gs, f_R); f_blue += gd_mulfx(f_bs, f_R); f_alpha += gd_mulfx(f_as, f_R); } } red = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_red, f_gama)), 0, 255); green = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_green, f_gama)), 0, 255); blue = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_blue, f_gama)), 0, 255); alpha = (unsigned char) CLAMP(gd_fxtoi(gd_mulfx(f_alpha, f_gama)), 0, 127); dst->tpixels[dst_offset_y][dst_offset_x] = gdTrueColorAlpha(red, green, blue, alpha); } else { dst->tpixels[dst_offset_y][dst_offset_x] = bgColor; } dst_offset_x++; } dst_offset_y++; } return dst; } BGD_DECLARE(gdImagePtr) gdImageRotateInterpolated(const gdImagePtr src, const float angle, int bgcolor) { /* round to two decimals and keep the 100x multiplication to use it in the common square angles case later. Keep the two decimal precisions so smaller rotation steps can be done, useful for slow animations, f.e. */ const int angle_rounded = fmod((int) floorf(angle * 100), 360 * 100); if (bgcolor < 0) { return NULL; } /* 0 && 90 degrees multiple rotation, 0 rotation simply clones the return image and convert it to truecolor, as we must return truecolor image. */ switch (angle_rounded) { case 0: { gdImagePtr dst = gdImageClone(src); if (dst == NULL) { return NULL; } if (dst->trueColor == 0) { gdImagePaletteToTrueColor(dst); } return dst; } case -2700: case 9000: return gdImageRotate90(src, 0); case -18000: case 18000: return gdImageRotate180(src, 0); case -9000: case 27000: return gdImageRotate270(src, 0); } if (src == NULL || src->interpolation_id < 1 || src->interpolation_id > GD_METHOD_COUNT) { return NULL; } switch (src->interpolation_id) { case GD_NEAREST_NEIGHBOUR: return gdImageRotateNearestNeighbour(src, angle, bgcolor); break; case GD_BILINEAR_FIXED: return gdImageRotateBilinear(src, angle, bgcolor); break; case GD_BICUBIC_FIXED: return gdImageRotateBicubicFixed(src, angle, bgcolor); break; default: return gdImageRotateGeneric(src, angle, bgcolor); } return NULL; } /** * Title: Affine transformation **/ /** * Group: Transform **/ static void gdImageClipRectangle(gdImagePtr im, gdRectPtr r) { int c1x, c1y, c2x, c2y; int x1,y1; gdImageGetClip(im, &c1x, &c1y, &c2x, &c2y); x1 = r->x + r->width - 1; y1 = r->y + r->height - 1; r->x = CLAMP(r->x, c1x, c2x); r->y = CLAMP(r->y, c1y, c2y); r->width = CLAMP(x1, c1x, c2x) - r->x + 1; r->height = CLAMP(y1, c1y, c2y) - r->y + 1; } void gdDumpRect(const char *msg, gdRectPtr r) { printf("%s (%i, %i) (%i, %i)\n", msg, r->x, r->y, r->width, r->height); } /** * Function: gdTransformAffineGetImage * Applies an affine transformation to a region and return an image * containing the complete transformation. * * Parameters: * dst - Pointer to a gdImagePtr to store the created image, NULL when * the creation or the transformation failed * src - Source image * src_area - rectangle defining the source region to transform * dstY - Y position in the destination image * affine - The desired affine transformation * * Returns: * GD_TRUE if the affine is rectilinear or GD_FALSE */ BGD_DECLARE(int) gdTransformAffineGetImage(gdImagePtr *dst, const gdImagePtr src, gdRectPtr src_area, const double affine[6]) { int res; double m[6]; gdRect bbox; gdRect area_full; if (src_area == NULL) { area_full.x = 0; area_full.y = 0; area_full.width = gdImageSX(src); area_full.height = gdImageSY(src); src_area = &area_full; } gdTransformAffineBoundingBox(src_area, affine, &bbox); *dst = gdImageCreateTrueColor(bbox.width, bbox.height); if (*dst == NULL) { return GD_FALSE; } (*dst)->saveAlphaFlag = 1; if (!src->trueColor) { gdImagePaletteToTrueColor(src); } /* Translate to dst origin (0,0) */ gdAffineTranslate(m, -bbox.x, -bbox.y); gdAffineConcat(m, affine, m); gdImageAlphaBlending(*dst, 0); res = gdTransformAffineCopy(*dst, 0,0, src, src_area, m); if (res != GD_TRUE) { gdImageDestroy(*dst); dst = NULL; return GD_FALSE; } else { return GD_TRUE; } } /** * Function: gdTransformAffineCopy * Applies an affine transformation to a region and copy the result * in a destination to the given position. * * Parameters: * dst - Image to draw the transformed image * src - Source image * dstX - X position in the destination image * dstY - Y position in the destination image * src_area - Rectangular region to rotate in the src image * * Returns: * GD_TRUE if the affine is rectilinear or GD_FALSE */ BGD_DECLARE(int) gdTransformAffineCopy(gdImagePtr dst, int dst_x, int dst_y, const gdImagePtr src, gdRectPtr src_region, const double affine[6]) { int c1x,c1y,c2x,c2y; int backclip = 0; int backup_clipx1, backup_clipy1, backup_clipx2, backup_clipy2; register int x, y, src_offset_x, src_offset_y; double inv[6]; int *dst_p; gdPointF pt, src_pt; gdRect bbox; int end_x, end_y; gdInterpolationMethod interpolation_id_bak = GD_DEFAULT; /* These methods use special implementations */ if (src->interpolation_id == GD_BILINEAR_FIXED || src->interpolation_id == GD_BICUBIC_FIXED || src->interpolation_id == GD_NEAREST_NEIGHBOUR) { interpolation_id_bak = src->interpolation_id; gdImageSetInterpolationMethod(src, GD_BICUBIC); } gdImageClipRectangle(src, src_region); if (src_region->x > 0 || src_region->y > 0 || src_region->width < gdImageSX(src) || src_region->height < gdImageSY(src)) { backclip = 1; gdImageGetClip(src, &backup_clipx1, &backup_clipy1, &backup_clipx2, &backup_clipy2); gdImageSetClip(src, src_region->x, src_region->y, src_region->x + src_region->width - 1, src_region->y + src_region->height - 1); } if (!gdTransformAffineBoundingBox(src_region, affine, &bbox)) { if (backclip) { gdImageSetClip(src, backup_clipx1, backup_clipy1, backup_clipx2, backup_clipy2); } gdImageSetInterpolationMethod(src, interpolation_id_bak); return GD_FALSE; } gdImageGetClip(dst, &c1x, &c1y, &c2x, &c2y); end_x = bbox.width + (int) fabs(bbox.x); end_y = bbox.height + (int) fabs(bbox.y); /* Get inverse affine to let us work with destination -> source */ gdAffineInvert(inv, affine); src_offset_x = src_region->x; src_offset_y = src_region->y; if (dst->alphaBlendingFlag) { for (y = bbox.y; y <= end_y; y++) { pt.y = y + 0.5; for (x = 0; x <= end_x; x++) { pt.x = x + 0.5; gdAffineApplyToPointF(&src_pt, &pt, inv); gdImageSetPixel(dst, dst_x + x, dst_y + y, getPixelInterpolated(src, src_offset_x + src_pt.x, src_offset_y + src_pt.y, 0)); } } } else { for (y = 0; y <= end_y; y++) { pt.y = y + 0.5 + bbox.y; if ((dst_y + y) < 0 || ((dst_y + y) > gdImageSY(dst) -1)) { continue; } dst_p = dst->tpixels[dst_y + y] + dst_x; for (x = 0; x <= end_x; x++) { pt.x = x + 0.5 + bbox.x; gdAffineApplyToPointF(&src_pt, &pt, inv); if ((dst_x + x) < 0 || (dst_x + x) > (gdImageSX(dst) - 1)) { break; } *(dst_p++) = getPixelInterpolated(src, src_offset_x + src_pt.x, src_offset_y + src_pt.y, -1); } } } /* Restore clip if required */ if (backclip) { gdImageSetClip(src, backup_clipx1, backup_clipy1, backup_clipx2, backup_clipy2); } gdImageSetInterpolationMethod(src, interpolation_id_bak); return GD_TRUE; } /** * Function: gdTransformAffineBoundingBox * Returns the bounding box of an affine transformation applied to a * rectangular area * * Parameters: * src - Rectangular source area for the affine transformation * affine - the affine transformation * bbox - the resulting bounding box * * Returns: * GD_TRUE if the affine is rectilinear or GD_FALSE */ BGD_DECLARE(int) gdTransformAffineBoundingBox(gdRectPtr src, const double affine[6], gdRectPtr bbox) { gdPointF extent[4], min, max, point; int i; extent[0].x=0.0; extent[0].y=0.0; extent[1].x=(double) src->width; extent[1].y=0.0; extent[2].x=(double) src->width; extent[2].y=(double) src->height; extent[3].x=0.0; extent[3].y=(double) src->height; for (i=0; i < 4; i++) { point=extent[i]; if (gdAffineApplyToPointF(&extent[i], &point, affine) != GD_TRUE) { return GD_FALSE; } } min=extent[0]; max=extent[0]; for (i=1; i < 4; i++) { if (min.x > extent[i].x) min.x=extent[i].x; if (min.y > extent[i].y) min.y=extent[i].y; if (max.x < extent[i].x) max.x=extent[i].x; if (max.y < extent[i].y) max.y=extent[i].y; } bbox->x = (int) min.x; bbox->y = (int) min.y; bbox->width = (int) floor(max.x - min.x) - 1; bbox->height = (int) floor(max.y - min.y); return GD_TRUE; } BGD_DECLARE(int) gdImageSetInterpolationMethod(gdImagePtr im, gdInterpolationMethod id) { if (im == NULL || id < 0 || id > GD_METHOD_COUNT) { return 0; } switch (id) { case GD_DEFAULT: id = GD_BILINEAR_FIXED; /* Optimized versions */ case GD_BILINEAR_FIXED: case GD_BICUBIC_FIXED: case GD_NEAREST_NEIGHBOUR: case GD_WEIGHTED4: im->interpolation = NULL; break; /* generic versions*/ case GD_BELL: im->interpolation = filter_bell; break; case GD_BESSEL: im->interpolation = filter_bessel; break; case GD_BICUBIC: im->interpolation = filter_bicubic; break; case GD_BLACKMAN: im->interpolation = filter_blackman; break; case GD_BOX: im->interpolation = filter_box; break; case GD_BSPLINE: im->interpolation = filter_bspline; break; case GD_CATMULLROM: im->interpolation = filter_catmullrom; break; case GD_GAUSSIAN: im->interpolation = filter_gaussian; break; case GD_GENERALIZED_CUBIC: im->interpolation = filter_generalized_cubic; break; case GD_HERMITE: im->interpolation = filter_hermite; break; case GD_HAMMING: im->interpolation = filter_hamming; break; case GD_HANNING: im->interpolation = filter_hanning; break; case GD_MITCHELL: im->interpolation = filter_mitchell; break; case GD_POWER: im->interpolation = filter_power; break; case GD_QUADRATIC: im->interpolation = filter_quadratic; break; case GD_SINC: im->interpolation = filter_sinc; break; case GD_TRIANGLE: im->interpolation = filter_triangle; break; default: return 0; break; } im->interpolation_id = id; return 1; } /* Return the interpolation mode set in 'im'. This is here so that * the value can be read via a language or VM with an FFI but no * (portable) way to extract the value from the struct. */ BGD_DECLARE(gdInterpolationMethod) gdImageGetInterpolationMethod(gdImagePtr im) { return im->interpolation_id; } #ifdef _MSC_VER # pragma optimize("", on) #endif libgd-gd-2.1.1/src/gd_io.c000066400000000000000000000066531245535672000152230ustar00rootroot00000000000000/* * io.c * * Implements the simple I/O 'helper' routines. * * Not really essential, but these routines were used extensively in GD, * so they were moved here. They also make IOCtx calls look better... * * Written (or, at least, moved) 1999, Philip Warner. */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include "gd.h" /* Use this for commenting out debug-print statements. */ /* Just use the first '#define' to allow all the prints... */ /*#define IO_DBG(s) (s) */ #define IO_DBG(s) #define GD_IO_EOF_CHK(r) \ if(r == EOF) { \ return 0; \ } /* * Write out a word to the I/O context pointer */ void Putword(int w, gdIOCtx *ctx) { unsigned char buf[2]; buf[0] = w & 0xff; buf[1] = (w / 256) & 0xff; (ctx->putBuf)(ctx, (char *)buf, 2); } void Putchar(int c, gdIOCtx *ctx) { (ctx->putC)(ctx, c & 0xff); } void gdPutC(const unsigned char c, gdIOCtx *ctx) { (ctx->putC)(ctx, c); } void gdPutWord (int w, gdIOCtx *ctx) { IO_DBG(printf("Putting word...\n")); (ctx->putC)(ctx, (unsigned char)(w >> 8)); (ctx->putC)(ctx, (unsigned char)(w & 0xFF)); IO_DBG(printf("put.\n")); } void gdPutInt (int w, gdIOCtx *ctx) { IO_DBG(printf("Putting int...\n")); (ctx->putC)(ctx, (unsigned char) (w >> 24)); (ctx->putC)(ctx, (unsigned char) ((w >> 16) & 0xFF)); (ctx->putC)(ctx, (unsigned char) ((w >> 8) & 0xFF)); (ctx->putC)(ctx, (unsigned char) (w & 0xFF)); IO_DBG(printf("put.\n")); } int gdGetC(gdIOCtx *ctx) { return ((ctx->getC)(ctx)); } int gdGetByte(int *result, gdIOCtx *ctx) { int r; r = (ctx->getC)(ctx); if(r == EOF) { return 0; } *result = r; return 1; } int gdGetWord(int *result, gdIOCtx *ctx) { int r; r = (ctx->getC)(ctx); if(r == EOF) { return 0; } *result = r << 8; r = (ctx->getC)(ctx); if(r == EOF) { return 0; } *result += r; return 1; } int gdGetWordLSB(signed short int *result, gdIOCtx *ctx) { int high = 0, low = 0; low = (ctx->getC) (ctx); if (low == EOF) { return 0; } high = (ctx->getC) (ctx); if (high == EOF) { return 0; } if (result) { *result = (high << 8) | low; } return 1; } int gdGetInt(int *result, gdIOCtx *ctx) { int r; r = (ctx->getC)(ctx); if(r == EOF) { return 0; } *result = r << 24; r = (ctx->getC)(ctx); if(r == EOF) { return 0; } *result += r << 16; r = (ctx->getC)(ctx); if(r == EOF) { return 0; } *result += r << 8; r = (ctx->getC)(ctx); if(r == EOF) { return 0; } *result += r; return 1; } int gdGetIntLSB(signed int *result, gdIOCtx *ctx) { int c = 0; unsigned int r = 0; c = (ctx->getC) (ctx); if (c == EOF) { return 0; } r |= (c << 24); r >>= 8; c = (ctx->getC) (ctx); if (c == EOF) { return 0; } r |= (c << 24); r >>= 8; c = (ctx->getC) (ctx); if (c == EOF) { return 0; } r |= (c << 24); r >>= 8; c = (ctx->getC) (ctx); if (c == EOF) { return 0; } r |= (c << 24); if (result) { *result = (signed int)r; } return 1; } int gdPutBuf(const void *buf, int size, gdIOCtx *ctx) { IO_DBG(printf("Putting buf...\n")); return (ctx->putBuf)(ctx, buf, size); IO_DBG(printf("put.\n")); } int gdGetBuf(void *buf, int size, gdIOCtx *ctx) { return (ctx->getBuf)(ctx, buf, size); } int gdSeek(gdIOCtx *ctx, const int pos) { IO_DBG(printf("Seeking...\n")); return ((ctx->seek)(ctx, pos)); IO_DBG(printf("Done.\n")); } long gdTell(gdIOCtx *ctx) { IO_DBG(printf("Telling...\n")); return ((ctx->tell)(ctx)); IO_DBG(printf("told.\n")); } libgd-gd-2.1.1/src/gd_io.h000066400000000000000000000060651245535672000152250ustar00rootroot00000000000000#ifdef __cplusplus extern "C" { #endif #ifndef GD_IO_H #define GD_IO_H 1 #include #ifdef VMS # define Putchar gdPutchar #endif /* Group: Types typedef: gdIOCtx gdIOCtx structures hold function pointers for doing image IO. Most of the gd functions that read and write files, such as also have variants that accept a structure; see and . Those who wish to provide their own custom routines to read and write images can populate a gdIOCtx structure with functions of their own devising to to read and write data. For image reading, the only mandatory functions are getC and getBuf, which must return the number of characters actually read, or a negative value on error or EOF. These functions must read the number of characters requested unless at the end of the file. For image writing, the only mandatory functions are putC and putBuf, which return the number of characters written; these functions must write the number of characters requested except in the event of an error. The seek and tell functions are only required in conjunction with the gd2 file format, which supports quick loading of partial images. The gd_free function will not be invoked when calling the standard Ctx functions; it is an implementation convenience when adding new data types to gd. For examples, see gd_png.c, gd_gd2.c, gd_jpeg.c, etc., all of which rely on gdIOCtx to implement the standard image read and write functions. > typedef struct gdIOCtx > { > int (*getC) (struct gdIOCtx *); > int (*getBuf) (struct gdIOCtx *, void *, int wanted); > > void (*putC) (struct gdIOCtx *, int); > int (*putBuf) (struct gdIOCtx *, const void *, int wanted); > > // seek must return 1 on SUCCESS, 0 on FAILURE. Unlike fseek! > int (*seek) (struct gdIOCtx *, const int); > long (*tell) (struct gdIOCtx *); > > void (*gd_free) (struct gdIOCtx *); > } gdIOCtx; */ typedef struct gdIOCtx { int (*getC)(struct gdIOCtx *); int (*getBuf)(struct gdIOCtx *, void *, int); void (*putC)(struct gdIOCtx *, int); int (*putBuf)(struct gdIOCtx *, const void *, int); /* seek must return 1 on SUCCESS, 0 on FAILURE. Unlike fseek! */ int (*seek)(struct gdIOCtx *, const int); long (*tell)(struct gdIOCtx *); void (*gd_free)(struct gdIOCtx *); void *data; } gdIOCtx; typedef struct gdIOCtx *gdIOCtxPtr; void Putword(int w, gdIOCtx *ctx); void Putchar(int c, gdIOCtx *ctx); void gdPutC(const unsigned char c, gdIOCtx *ctx); int gdPutBuf(const void *, int, gdIOCtx *); void gdPutWord(int w, gdIOCtx *ctx); void gdPutInt(int w, gdIOCtx *ctx); int gdGetC(gdIOCtx *ctx); int gdGetBuf(void *, int, gdIOCtx *); int gdGetByte(int *result, gdIOCtx *ctx); int gdGetWord(int *result, gdIOCtx *ctx); int gdGetWordLSB(signed short int *result, gdIOCtx *ctx); int gdGetInt(int *result, gdIOCtx *ctx); int gdGetIntLSB(signed int *result, gdIOCtx *ctx); int gdSeek(gdIOCtx *ctx, const int offset); long gdTell(gdIOCtx *ctx); #endif #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/gd_io_dp.c000066400000000000000000000175561245535672000157120ustar00rootroot00000000000000/* * io_dp.c * * Implements the dynamic pointer interface. * * Based on GD.pm code by Lincoln Stein for interfacing to libgd. * Added support for reading as well as support for 'tell' and 'seek'. * * As will all I/O modules, most functions are for local use only (called * via function pointers in the I/O context). * * gdDPExtractData is the exception to this: it will return the pointer to * the internal data, and reset the internal storage. * * Written/Modified 1999, Philip Warner. */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include "gd.h" #include "gdhelpers.h" #define TRUE 1 #define FALSE 0 /* this is used for creating images in main memory */ typedef struct dpStruct { void *data; int logicalSize; int realSize; int dataGood; int pos; int freeOK; } dynamicPtr; typedef struct dpIOCtx { gdIOCtx ctx; dynamicPtr *dp; } dpIOCtx; typedef struct dpIOCtx *dpIOCtxPtr; /* these functions operate on in-memory dynamic pointers */ static int allocDynamic(dynamicPtr *dp, int initialSize, void *data); static int appendDynamic(dynamicPtr *dp, const void *src, int size); static int gdReallocDynamic(dynamicPtr *dp, int required); static int trimDynamic(dynamicPtr *dp); static void gdFreeDynamicCtx(struct gdIOCtx *ctx); static dynamicPtr *newDynamic(int initialSize, void *data, int freeOKFlag); static int dynamicPutbuf(struct gdIOCtx *, const void *, int); static void dynamicPutchar(struct gdIOCtx *, int a); static int dynamicGetbuf(gdIOCtxPtr ctx, void *buf, int len); static int dynamicGetchar(gdIOCtxPtr ctx); static int dynamicSeek(struct gdIOCtx *, const int); static long dynamicTell(struct gdIOCtx *); /* return data as a dynamic pointer */ BGD_DECLARE(gdIOCtx *) gdNewDynamicCtx(int initialSize, void *data) { /* 2.0.23: Phil Moore: 'return' keyword was missing! */ return gdNewDynamicCtxEx(initialSize, data, 1); } BGD_DECLARE(gdIOCtx *) gdNewDynamicCtxEx(int initialSize, void *data, int freeOKFlag) { dpIOCtx *ctx; dynamicPtr *dp; ctx = (dpIOCtx *)gdMalloc(sizeof (dpIOCtx)); if(ctx == NULL) { return NULL; } dp = newDynamic(initialSize, data, freeOKFlag); if(!dp) { gdFree (ctx); return NULL; }; ctx->dp = dp; ctx->ctx.getC = dynamicGetchar; ctx->ctx.putC = dynamicPutchar; ctx->ctx.getBuf = dynamicGetbuf; ctx->ctx.putBuf = dynamicPutbuf; ctx->ctx.seek = dynamicSeek; ctx->ctx.tell = dynamicTell; ctx->ctx.gd_free = gdFreeDynamicCtx; return (gdIOCtx *)ctx; } BGD_DECLARE(void *) gdDPExtractData (struct gdIOCtx *ctx, int *size) { dynamicPtr *dp; dpIOCtx *dctx; void *data; dctx = (dpIOCtx *)ctx; dp = dctx->dp; /* clean up the data block and return it */ if(dp->dataGood) { trimDynamic(dp); *size = dp->logicalSize; data = dp->data; } else { *size = 0; data = NULL; /* 2.0.21: never free memory we don't own */ if((dp->data != NULL) && (dp->freeOK)) { gdFree(dp->data); } } dp->data = NULL; dp->realSize = 0; dp->logicalSize = 0; return data; } static void gdFreeDynamicCtx(struct gdIOCtx *ctx) { dynamicPtr *dp; dpIOCtx *dctx; dctx = (dpIOCtx *)ctx; dp = dctx->dp; gdFree(ctx); /* clean up the data block and return it */ /* 2.0.21: never free memory we don't own */ if((dp->data != NULL) && (dp->freeOK)) { gdFree(dp->data); dp->data = NULL; } dp->realSize = 0; dp->logicalSize = 0; gdFree(dp); } static long dynamicTell(struct gdIOCtx *ctx) { dpIOCtx *dctx; dctx = (dpIOCtx *)ctx; return (dctx->dp->pos); } static int dynamicSeek(struct gdIOCtx *ctx, const int pos) { int bytesNeeded; dynamicPtr *dp; dpIOCtx *dctx; dctx = (dpIOCtx *)ctx; dp = dctx->dp; if(!dp->dataGood) { return FALSE; } bytesNeeded = pos; if(bytesNeeded > dp->realSize) { /* 2.0.21 */ if(!dp->freeOK) { return FALSE; } if(overflow2(dp->realSize, 2)) { return FALSE; } if(!gdReallocDynamic(dp, dp->realSize * 2)) { dp->dataGood = FALSE; return FALSE; } } /* if we get here, we can be sure that we have enough bytes * to copy safely */ /* Extend the logical size if we seek beyond EOF. */ if(pos > dp->logicalSize) { dp->logicalSize = pos; }; dp->pos = pos; return TRUE; } /* return data as a dynamic pointer */ static dynamicPtr *newDynamic(int initialSize, void *data, int freeOKFlag) { dynamicPtr *dp; dp = (dynamicPtr *) gdMalloc(sizeof (dynamicPtr)); if(dp == NULL) { return NULL; } if(!allocDynamic(dp, initialSize, data)) { gdFree(dp); return NULL; } dp->pos = 0; dp->freeOK = freeOKFlag; return dp; } static int dynamicPutbuf(struct gdIOCtx *ctx, const void *buf, int size) { dpIOCtx *dctx; dctx = (dpIOCtx *)ctx; appendDynamic(dctx->dp, buf, size); if(dctx->dp->dataGood) { return size; } else { return -1; }; } static void dynamicPutchar(struct gdIOCtx *ctx, int a) { unsigned char b; dpIOCtxPtr dctx; b = a; dctx = (dpIOCtxPtr) ctx; appendDynamic(dctx->dp, &b, 1); } static int dynamicGetbuf(gdIOCtxPtr ctx, void *buf, int len) { int rlen, remain; dpIOCtxPtr dctx; dynamicPtr *dp; dctx = (dpIOCtxPtr) ctx; dp = dctx->dp; remain = dp->logicalSize - dp->pos; if(remain >= len) { rlen = len; } else { if(remain == 0) { /* 2.0.34: EOF is incorrect. We use 0 for * errors and EOF, just like fileGetbuf, * which is a simple fread() wrapper. * TBB. Original bug report: Daniel Cowgill. */ return 0; /* NOT EOF */ } rlen = remain; } memcpy(buf, (void *) ((char *)dp->data + dp->pos), rlen); dp->pos += rlen; return rlen; } static int dynamicGetchar(gdIOCtxPtr ctx) { unsigned char b; int rv; rv = dynamicGetbuf(ctx, &b, 1); if(rv != 1) { return EOF; } else { return b; /* (b & 0xff); */ } } /********************************************************************** * InitDynamic - Return a dynamically resizable void* **********************************************************************/ static int allocDynamic(dynamicPtr *dp, int initialSize, void *data) { if(data == NULL) { dp->logicalSize = 0; dp->dataGood = FALSE; dp->data = gdMalloc(initialSize); } else { dp->logicalSize = initialSize; dp->dataGood = TRUE; dp->data = data; } if(dp->data != NULL) { dp->realSize = initialSize; dp->dataGood = TRUE; dp->pos = 0; return TRUE; } else { dp->realSize = 0; return FALSE; } } /* append bytes to the end of a dynamic pointer */ static int appendDynamic(dynamicPtr * dp, const void *src, int size) { int bytesNeeded; char *tmp; if(!dp->dataGood) { return FALSE; } /* bytesNeeded = dp->logicalSize + size; */ bytesNeeded = dp->pos + size; if(bytesNeeded > dp->realSize) { /* 2.0.21 */ if(!dp->freeOK) { return FALSE; } if(overflow2(dp->realSize, 2)) { return FALSE; } if(!gdReallocDynamic(dp, bytesNeeded * 2)) { dp->dataGood = FALSE; return FALSE; } } /* if we get here, we can be sure that we have enough bytes * to copy safely */ /*printf("Mem OK Size: %d, Pos: %d\n", dp->realSize, dp->pos); */ tmp = (char *)dp->data; memcpy ((void *)(tmp + (dp->pos)), src, size); dp->pos += size; if(dp->pos > dp->logicalSize) { dp->logicalSize = dp->pos; }; return TRUE; } /* grow (or shrink) dynamic pointer */ static int gdReallocDynamic(dynamicPtr *dp, int required) { void *newPtr; /* First try gdRealloc(). If that doesn't work, make a new * memory block and copy. */ if((newPtr = gdRealloc(dp->data, required))) { dp->realSize = required; dp->data = newPtr; return TRUE; } /* create a new pointer */ newPtr = gdMalloc(required); if(!newPtr) { dp->dataGood = FALSE; return FALSE; } /* copy the old data into it */ memcpy(newPtr, dp->data, dp->logicalSize); gdFree(dp->data); dp->data = newPtr; dp->realSize = required; return TRUE; } /* trim pointer so that its real and logical sizes match */ static int trimDynamic(dynamicPtr *dp) { /* 2.0.21: we don't reallocate memory we don't own */ if(!dp->freeOK) { return TRUE; } return gdReallocDynamic(dp, dp->logicalSize); } libgd-gd-2.1.1/src/gd_io_file.c000066400000000000000000000046051245535672000162150ustar00rootroot00000000000000/* * io_file.c * * Implements the file interface. * * As will all I/O modules, most functions are for local use only (called * via function pointers in the I/O context). * * Most functions are just 'wrappers' for standard file functions. * * Written/Modified 1999, Philip Warner. * */ #ifdef HAVE_CONFIG_H # include "config.h" #endif /* For platforms with incomplete ANSI defines. Fortunately, * SEEK_SET is defined to be zero by the standard. */ #ifndef SEEK_SET # define SEEK_SET 0 #endif /* SEEK_SET */ #include #include #include #include "gd.h" #include "gdhelpers.h" /* this is used for creating images in main memory */ typedef struct fileIOCtx { gdIOCtx ctx; FILE *f; } fileIOCtx; gdIOCtx *newFileCtx(FILE *f); static int fileGetbuf(gdIOCtx *, void *, int); static int filePutbuf(gdIOCtx *, const void *, int); static void filePutchar(gdIOCtx *, int); static int fileGetchar(gdIOCtx *ctx); static int fileSeek(struct gdIOCtx *, const int); static long fileTell(struct gdIOCtx *); static void gdFreeFileCtx(gdIOCtx *ctx); /* return data as a dynamic pointer */ BGD_DECLARE(gdIOCtx *) gdNewFileCtx(FILE *f) { fileIOCtx *ctx; if (f == NULL) return NULL; ctx = (fileIOCtx *)gdMalloc(sizeof(fileIOCtx)); if(ctx == NULL) { return NULL; } ctx->f = f; ctx->ctx.getC = fileGetchar; ctx->ctx.putC = filePutchar; ctx->ctx.getBuf = fileGetbuf; ctx->ctx.putBuf = filePutbuf; ctx->ctx.tell = fileTell; ctx->ctx.seek = fileSeek; ctx->ctx.gd_free = gdFreeFileCtx; return (gdIOCtx *)ctx; } static void gdFreeFileCtx(gdIOCtx *ctx) { gdFree(ctx); } static int filePutbuf(gdIOCtx *ctx, const void *buf, int size) { fileIOCtx *fctx; fctx = (fileIOCtx *)ctx; return fwrite(buf, 1, size, fctx->f); } static int fileGetbuf(gdIOCtx *ctx, void *buf, int size) { fileIOCtx *fctx; fctx = (fileIOCtx *)ctx; return (fread(buf, 1, size, fctx->f)); } static void filePutchar(gdIOCtx *ctx, int a) { unsigned char b; fileIOCtx *fctx; fctx = (fileIOCtx *)ctx; b = a; putc(b, fctx->f); } static int fileGetchar(gdIOCtx *ctx) { fileIOCtx *fctx; fctx = (fileIOCtx *)ctx; return getc(fctx->f); } static int fileSeek(struct gdIOCtx *ctx, const int pos) { fileIOCtx *fctx; fctx = (fileIOCtx *)ctx; return (fseek(fctx->f, pos, SEEK_SET) == 0); } static long fileTell (struct gdIOCtx *ctx) { fileIOCtx *fctx; fctx = (fileIOCtx *)ctx; return ftell(fctx->f); } libgd-gd-2.1.1/src/gd_io_ss.c000066400000000000000000000052121245535672000157160ustar00rootroot00000000000000/* * io_ss.c * * Implements the Source/Sink interface. * * As will all I/O modules, most functions are for local use only (called * via function pointers in the I/O context). * * The Source/Sink model is the primary 'user' interface for alternate data * sources; the IOCtx interface is intended (at least in version 1.5) to be * used internally until it settles down a bit. * * This module just layers the Source/Sink interface on top of the IOCtx; no * support is provided for tell/seek, so GD2 writing is not possible, and * retrieving parts of GD2 files is also not possible. * * A new SS context does not need to be created with both a Source and a Sink. * * Written/Modified 1999, Philip Warner. * */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include "gd.h" #include "gdhelpers.h" /* this is used for creating images in main memory */ typedef struct ssIOCtx { gdIOCtx ctx; gdSourcePtr src; gdSinkPtr snk; } ssIOCtx; typedef struct ssIOCtx *ssIOCtxPtr; static int sourceGetbuf(gdIOCtx *, void *, int); static int sourceGetchar(gdIOCtx *ctx); static int sinkPutbuf(gdIOCtx *ctx, const void *buf, int size); static void sinkPutchar(gdIOCtx *ctx, int a); static void gdFreeSsCtx(gdIOCtx *ctx); /* return data as a dynamic pointer */ BGD_DECLARE(gdIOCtx *) gdNewSSCtx(gdSourcePtr src, gdSinkPtr snk) { ssIOCtxPtr ctx; ctx = (ssIOCtxPtr)gdMalloc(sizeof (ssIOCtx)); if (ctx == NULL) { return NULL; } ctx->src = src; ctx->snk = snk; ctx->ctx.getC = sourceGetchar; ctx->ctx.getBuf = sourceGetbuf; ctx->ctx.putC = sinkPutchar; ctx->ctx.putBuf = sinkPutbuf; ctx->ctx.tell = NULL; ctx->ctx.seek = NULL; ctx->ctx.gd_free = gdFreeSsCtx; return (gdIOCtx *)ctx; } static void gdFreeSsCtx(gdIOCtx *ctx) { gdFree(ctx); } static int sourceGetbuf(gdIOCtx *ctx, void *buf, int size) { ssIOCtx *lctx; int res; lctx = (ssIOCtx *)ctx; res = ((lctx->src->source)(lctx->src->context, buf, size)); /* * Translate the return values from the Source object: * 0 is EOF, -1 is error */ if (res == 0) { return 0; } else if (res < 0) { return 0; } else { return res; } } static int sourceGetchar(gdIOCtx *ctx) { int res; unsigned char buf; res = sourceGetbuf(ctx, &buf, 1); if (res == 1) { return buf; } else { return EOF; } } static int sinkPutbuf(gdIOCtx *ctx, const void *buf, int size) { ssIOCtxPtr lctx; int res; lctx = (ssIOCtx *)ctx; res = (lctx->snk->sink)(lctx->snk->context, buf, size); if (res <= 0) { return 0; } else { return res; } } static void sinkPutchar(gdIOCtx *ctx, int a) { unsigned char b; b = a; sinkPutbuf(ctx, &b, 1); } libgd-gd-2.1.1/src/gd_io_stream.cxx000066400000000000000000000101551245535672000171460ustar00rootroot00000000000000/* ***************************************************************************** ** $Id$ ** Initial file written and documented by: ** Kevin Shepherd December 2007 ** of Scarlet Line http://www.scarletline.com/ *******************************************************************************/ /** \file gd_io_stream.cxx \brief Implementation of the methods of the gdIOCtx std stream specialization. Implements the derived specializations of gdIOCtx. These methods are not called by users of libgd, they are internal implementation. Note that half of the below methods are trivial stubs, as an input stream has no need of output methods, and vice-versa. */ #ifdef __cplusplus #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd_io_stream.h" /** Read into buffer from stream Return the number of bytes successfully read. If an error occurs, or the end-of-file is reached, the return value is a short byte count (or zero). */ int istreamIOCtx::Getbuf (struct gdIOCtx * ctx, void * buf, int size) { stream_type * _str = ( (istreamIOCtx * ) ctx )->_M_stream; _str->read((char * )buf, size); return _str->gcount(); } /** Write from buffer to stream Return the number of bytes successfully written. If an error occurs, or the end-of-file is reached, the return value is a short byte count (or zero). */ int istreamIOCtx::Putbuf (struct gdIOCtx * , const void * , int ) { return 0; } /** Reads the next character from stream and returns it as an unsigned char cast to an int, or EOF on end of file or error. */ int istreamIOCtx::Getchar (struct gdIOCtx * ctx) { stream_type * _str = ( (istreamIOCtx * ) ctx )->_M_stream; return _str->get(); } /** Write the character to stream Character is cast to unsigned char before writing */ void istreamIOCtx::Putchar (struct gdIOCtx * , int ) { } /** Seek to position offset from the beginning of the stream must return 1 on SUCCESS, 0 on FAILURE. Unlike fseek! */ int istreamIOCtx::Seek (struct gdIOCtx * ctx, const int pos) { stream_type * _str = ( (istreamIOCtx * ) ctx )->_M_stream; _str->seekg(pos); return !_str->fail(); } /** Obtains the current value of the stream position. Returns -1 on error. */ long istreamIOCtx::Tell (struct gdIOCtx * ctx) { stream_type * _str = ( (istreamIOCtx * ) ctx )->_M_stream; return _str->tellg(); } /** Deallocate the context */ void istreamIOCtx::FreeCtx (struct gdIOCtx * ctx) { delete (istreamIOCtx * )ctx; } /** Read into buffer from stream Return the number of bytes successfully read. If an error occurs, or the end-of-file is reached, the return value is a short byte count (or zero). */ int ostreamIOCtx::Getbuf (struct gdIOCtx * , void * , int ) { return 0; } /** Write from buffer to stream Return the number of bytes successfully written. If an error occurs, or the end-of-file is reached, the return value is a short byte count (or zero). */ int ostreamIOCtx::Putbuf (struct gdIOCtx * ctx, const void * buf, int size) { stream_type * _str = ( (ostreamIOCtx * ) ctx )->_M_stream; _str->write((const char * )buf, size); return _str->bad()?0:size; } /** Reads the next character from stream and returns it as an unsigned char cast to an int, or EOF on end of file or error. */ int ostreamIOCtx::Getchar (struct gdIOCtx * ) { return EOF; } /** Write the character to stream Character is cast to unsigned char before writing */ void ostreamIOCtx::Putchar (struct gdIOCtx * ctx, int c) { stream_type * _str = ( (ostreamIOCtx * ) ctx )->_M_stream; _str->put((char)c); } /** Seek to position offset from the beginning of the stream must return 1 on SUCCESS, 0 on FAILURE. Unlike fseek! */ int ostreamIOCtx::Seek (struct gdIOCtx * ctx, const int pos) { stream_type * _str = ( (ostreamIOCtx * ) ctx )->_M_stream; _str->seekp(pos); return !_str->fail(); } /** Obtains the current value of the stream position. Returns -1 on error. */ long ostreamIOCtx::Tell (struct gdIOCtx * ctx) { stream_type * _str = ( (ostreamIOCtx * ) ctx )->_M_stream; return _str->tellp(); } /** Deallocate the context */ void ostreamIOCtx::FreeCtx (struct gdIOCtx * ctx) { delete (ostreamIOCtx * )ctx; } #endif /* __cplusplus */ libgd-gd-2.1.1/src/gd_io_stream.h000066400000000000000000000072121245535672000165730ustar00rootroot00000000000000/* ***************************************************************************** ** $Id$ ** Initial file written and documented by: ** Kevin Shepherd December 2007 ** of Scarlet Line http://www.scarletline.com/ *******************************************************************************/ /** \file gd_io_stream.h \brief C++ standard library iostream specializations of gdIOCtx. Note that all of the methods defined in this header are internal to the libgd library, except for the constructors. Only the constructors are needed by a user of the libgd API. This file does not use or need gdpp.h, but if GD::Image is used, then C++ coding becomes even simpler, and the classes below become entirely hidden implementation details. Example usage, convert png to gif: #include #include "gd_io_stream.h" std::ifstream in("image.png", std::ios_base::in | std::ios_base::binary ); if (in.good()) { istreamIOCtx _in_ctx(in); gdImagePtr im_in = gdImageCreateFromPngCtx ( & _in_ctx); std::ofstream out("image.gif", std::ios_base::out | std::ios_base::binary ); ostreamIOCtx _out_ctx(out); gdImageGifCtx(im_in, & _out_ctx); } gdImageDestroy(im_in); */ #ifdef __cplusplus #ifndef _gd_io_stream_h #define _gd_io_stream_h #include "gd.h" #include /** Standard library input stream specialization of gdIOCtx */ class BGD_EXPORT_DATA_IMPL istreamIOCtx : public gdIOCtx { public: typedef std::istream stream_type; /** Construct an instance of this input stream specialization, given an input stream. For example: std::ifstream in("image.png", std::ios_base::in | std::ios_base::binary ); istreamIOCtx in_ctx(in); */ istreamIOCtx(stream_type & __stream) { init( & __stream); } static int Getbuf (struct gdIOCtx * ctx, void * buf, int size); static int Putbuf (struct gdIOCtx * , const void * , int ); static void Putchar (struct gdIOCtx * , int ); static int Getchar (struct gdIOCtx * ctx); static int Seek (struct gdIOCtx * ctx, const int pos); static long Tell (struct gdIOCtx * ctx); static void FreeCtx (struct gdIOCtx * ctx); void init(stream_type * __stream) { getC = Getchar; putC = Putchar; getBuf = Getbuf; putBuf = Putbuf; tell = Tell; seek = Seek; gd_free = FreeCtx; _M_stream = __stream; } private: stream_type * _M_stream; }; /** Allocate a new instance of the class */ inline gdIOCtx * gdNewIstreamCtx (std::istream * __stream) { return new istreamIOCtx(* __stream); } /** Standard library output stream specialization of gdIOCtx */ class BGD_EXPORT_DATA_IMPL ostreamIOCtx : public gdIOCtx { public: typedef std::ostream stream_type; /** Construct an instance of this output stream specialization, given an output stream. For example: std::ofstream out("image.gif", std::ios_base::out | std::ios_base::binary ); ostreamIOCtx out_ctx(out); */ ostreamIOCtx(stream_type & __stream) { init( & __stream); } static int Getbuf (struct gdIOCtx * , void * , int ); static int Putbuf (struct gdIOCtx * ctx, const void * buf, int size); static int Getchar (struct gdIOCtx * ); static void Putchar (struct gdIOCtx * ctx, int a); static int Seek (struct gdIOCtx * ctx, const int pos); static long Tell (struct gdIOCtx * ctx); static void FreeCtx (struct gdIOCtx * ctx); void init(stream_type * __stream) { getC = Getchar; putC = Putchar; getBuf = Getbuf; putBuf = Putbuf; tell = Tell; seek = Seek; gd_free = FreeCtx; _M_stream = __stream; } private: stream_type * _M_stream; }; /** Allocate a new instance of the class */ inline gdIOCtx * gdNewOstreamCtx (std::ostream * __stream) { return new ostreamIOCtx(* __stream); } #endif /* _gd_io_stream_h */ #endif /* __cplusplus */ libgd-gd-2.1.1/src/gd_jpeg.c000066400000000000000000001056061245535672000155370ustar00rootroot00000000000000/* * gd_jpeg.c: Read and write JPEG (JFIF) format image files using the * gd graphics library (http://www.libgd.org). * * This software is based in part on the work of the Independent JPEG * Group. For more information on the IJG JPEG software (and JPEG * documentation, etc.), see ftp://ftp.uu.net/graphics/jpeg/. * * NOTE: IJG 12-bit JSAMPLE (BITS_IN_JSAMPLE == 12) mode is not * supported at all on read in gd 2.0, and is not supported on write * except for palette images, which is sort of pointless (TBB). Even that * has never been tested according to DB. * * Copyright 2000 Doug Becker, mailto:thebeckers@home.com * * Modification 4/18/00 TBB: JPEG_DEBUG rather than just DEBUG, * so VC++ builds don't spew to standard output, causing * major CGI brain damage * * 2.0.10: more efficient gdImageCreateFromJpegCtx, thanks to * Christian Aberger */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include #include "gd.h" #include "gd_errors.h" /* TBB: move this up so include files are not brought in */ /* JCE: arrange HAVE_LIBJPEG so that it can be set in gd.h */ #ifdef HAVE_LIBJPEG #include "gdhelpers.h" #if defined(_WIN32) && defined(__MINGW32__) # define HAVE_BOOLEAN #endif /* JCE undef two symbols that we don't need anymore but which are may be defined in config.h from ./configure but which are redefined incompatibly in jpeglib.h */ #undef HAVE_STDDEF_H #undef HAVE_STDLIB_H /* 1.8.1: remove dependency on jinclude.h */ #include "jpeglib.h" #include "jerror.h" static const char *const GD_JPEG_VERSION = "1.0"; typedef struct _jmpbuf_wrapper { jmp_buf jmpbuf; int ignore_warning; } jmpbuf_wrapper; static void jpeg_emit_message(j_common_ptr jpeg_info, int level) { char message[JMSG_LENGTH_MAX]; jmpbuf_wrapper *jmpbufw; int ignore_warning = 0; jmpbufw = (jmpbuf_wrapper *) jpeg_info->client_data; if (jmpbufw != 0) { ignore_warning = jmpbufw->ignore_warning; } (jpeg_info->err->format_message)(jpeg_info,message); /* It is a warning message */ if (level < 0) { /* display only the 1st warning, as would do a default libjpeg * unless strace_level >= 3 */ if ((jpeg_info->err->num_warnings == 0) || (jpeg_info->err->trace_level >= 3)) { if (!ignore_warning) { gd_error("gd-jpeg, libjpeg: recoverable error: %s\n", message); } } jpeg_info->err->num_warnings++; } else { /* strace msg, Show it if trace_level >= level. */ if (jpeg_info->err->trace_level >= level) { if (!ignore_warning) { gd_error("gd-jpeg, libjpeg: strace message: %s\n", message); } } } } /* Called by the IJG JPEG library upon encountering a fatal error */ static void fatal_jpeg_error(j_common_ptr cinfo) { jmpbuf_wrapper *jmpbufw; char buffer[JMSG_LENGTH_MAX]; (*cinfo->err->format_message)(cinfo, buffer); gd_error_ex(GD_ERROR, "gd-jpeg: JPEG library reports unrecoverable error: %s", buffer); jmpbufw = (jmpbuf_wrapper *)cinfo->client_data; jpeg_destroy(cinfo); if(jmpbufw != 0) { longjmp(jmpbufw->jmpbuf, 1); gd_error_ex(GD_ERROR, "gd-jpeg: EXTREMELY fatal error: longjmp returned control; terminating\n"); } else { gd_error_ex(GD_ERROR, "gd-jpeg: EXTREMELY fatal error: jmpbuf unrecoverable; terminating\n"); } exit(99); } /* * Write IM to OUTFILE as a JFIF-formatted JPEG image, using quality * QUALITY. If QUALITY is in the range 0-100, increasing values * represent higher quality but also larger image size. If QUALITY is * negative, the IJG JPEG library's default quality is used (which * should be near optimal for many applications). See the IJG JPEG * library documentation for more details. */ /* Function: gdImageJpeg outputs the specified image to the specified file in JPEG format. The file must be open for writing. Under MSDOS and all versions of Windows, it is important to use "wb" as opposed to simply "w" as the mode when opening the file, and under Unix there is no penalty for doing so. does not close the file; your code must do so. If _quality_ is negative, the default IJG JPEG quality value (which should yield a good general quality / size tradeoff for most situations) is used. Otherwise, for practical purposes, _quality_ should be a value in the range 0-95, higher quality values usually implying both higher quality and larger image sizes. If you have set image interlacing using , this function will interpret that to mean you wish to output a progressive JPEG. Some programs (e.g., Web browsers) can display progressive JPEGs incrementally; this can be useful when browsing over a relatively slow communications link, for example. Progressive JPEGs can also be slightly smaller than sequential (non-progressive) JPEGs. Variants: stores the image using a struct. stores the image to RAM. Parameters: im - The image to save outFile - The FILE pointer to write to. quality - Compression quality (0-95, 0 means use the default). Returns: Nothing. Example: > gdImagePtr im; > int black, white; > FILE *out; > // Create the image > im = gdImageCreate(100, 100); > // Allocate background > white = gdImageColorAllocate(im, 255, 255, 255); > // Allocate drawing color > black = gdImageColorAllocate(im, 0, 0, 0); > // Draw rectangle > gdImageRectangle(im, 0, 0, 99, 99, black); > // Open output file in binary mode > out = fopen("rect.jpg", "wb"); > // Write JPEG using default quality > gdImageJpeg(im, out, -1); > // Close file > fclose(out); > // Destroy image > gdImageDestroy(im); */ BGD_DECLARE(void) gdImageJpeg(gdImagePtr im, FILE *outFile, int quality) { gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageJpegCtx(im, out, quality); out->gd_free(out); } /* Function: gdImageJpegPtr Identical to except that it returns a pointer to a memory area with the JPEG data. This memory must be freed by the caller when it is no longer needed. The caller *must* invoke , not free(). This is because it is not guaranteed that libgd will use the same implementation of malloc, free, etc. as your proggram. The 'size' parameter receives the total size of the block of memory. Parameters: im - The image to write size - Output: the size of the resulting image. quality - Compression quality. Returns: A pointer to the JPEG data or NULL if an error occurred. */ BGD_DECLARE(void *) gdImageJpegPtr(gdImagePtr im, int *size, int quality) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); if (out == NULL) return NULL; gdImageJpegCtx(im, out, quality); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } void jpeg_gdIOCtx_dest(j_compress_ptr cinfo, gdIOCtx *outfile); /* Function: gdImageJpegCtx Write the image as JPEG data via a . See for more details. Parameters: im - The image to write. outfile - The output sink. quality - Image quality. */ BGD_DECLARE(void) gdImageJpegCtx(gdImagePtr im, gdIOCtx *outfile, int quality) { struct jpeg_compress_struct cinfo; struct jpeg_error_mgr jerr; int i, j, jidx; /* volatile so we can gdFree it on return from longjmp */ volatile JSAMPROW row = 0; JSAMPROW rowptr[1]; jmpbuf_wrapper jmpbufw; JDIMENSION nlines; char comment[255]; #ifdef JPEG_DEBUG gd_error_ex(GD_DEBUG, "gd-jpeg: gd JPEG version %s\n", GD_JPEG_VERSION); gd_error_ex(GD_DEBUG, "gd-jpeg: JPEG library version %d, %d-bit sample values\n", JPEG_LIB_VERSION, BITS_IN_JSAMPLE); if (!im->trueColor) { for(i = 0; i < im->colorsTotal; i++) { if(!im->open[i]) { gd_error_ex(GD_DEBUG, "gd-jpeg: gd colormap index %d: (%d, %d, %d)\n", i, im->red[i], im->green[i], im->blue[i]); } } } #endif /* JPEG_DEBUG */ memset(&cinfo, 0, sizeof(cinfo)); memset(&jerr, 0, sizeof(jerr)); cinfo.err = jpeg_std_error(&jerr); cinfo.client_data = &jmpbufw; if(setjmp(jmpbufw.jmpbuf) != 0) { /* we're here courtesy of longjmp */ if(row) { gdFree(row); } return; } cinfo.err->emit_message = jpeg_emit_message; cinfo.err->error_exit = fatal_jpeg_error; jpeg_create_compress(&cinfo); cinfo.image_width = im->sx; cinfo.image_height = im->sy; cinfo.input_components = 3; /* # of color components per pixel */ cinfo.in_color_space = JCS_RGB; /* colorspace of input image */ jpeg_set_defaults(&cinfo); cinfo.density_unit = 1; cinfo.X_density = im->res_x; cinfo.Y_density = im->res_y; if(quality >= 0) { jpeg_set_quality(&cinfo, quality, TRUE); } /* If user requests interlace, translate that to progressive JPEG */ if(gdImageGetInterlaced(im)) { #ifdef JPEG_DEBUG gd_error_ex(GD_DEBUG, "gd-jpeg: interlace set, outputting progressive JPEG image\n"); #endif jpeg_simple_progression(&cinfo); } jpeg_gdIOCtx_dest(&cinfo, outfile); row = (JSAMPROW)gdCalloc(1, cinfo.image_width * cinfo.input_components * sizeof(JSAMPLE)); if(row == 0) { gd_error("gd-jpeg: error: unable to allocate JPEG row structure: gdCalloc returns NULL\n"); jpeg_destroy_compress(&cinfo); return; } rowptr[0] = row; jpeg_start_compress(&cinfo, TRUE); sprintf(comment, "CREATOR: gd-jpeg v%s (using IJG JPEG v%d),", GD_JPEG_VERSION, JPEG_LIB_VERSION); if(quality >= 0) { sprintf (comment + strlen(comment), " quality = %d\n", quality); } else { strcat(comment + strlen(comment), " default quality\n"); } jpeg_write_marker(&cinfo, JPEG_COM, (unsigned char *) comment, (unsigned int)strlen(comment)); if(im->trueColor) { #if BITS_IN_JSAMPLE == 12 gd_error( "gd-jpeg: error: jpeg library was compiled for 12-bit\n" "precision. This is mostly useless, because JPEGs on the web are\n" "8-bit and such versions of the jpeg library won't read or write\n" "them. GD doesn't support these unusual images. Edit your\n" "jmorecfg.h file to specify the correct precision and completely\n" "'make clean' and 'make install' libjpeg again. Sorry.\n" ); goto error; #endif /* BITS_IN_JSAMPLE == 12 */ for(i = 0; i < im->sy; i++) { for(jidx = 0, j = 0; j < im->sx; j++) { int val = im->tpixels[i][j]; row[jidx++] = gdTrueColorGetRed(val); row[jidx++] = gdTrueColorGetGreen(val); row[jidx++] = gdTrueColorGetBlue(val); } nlines = jpeg_write_scanlines(&cinfo, rowptr, 1); if(nlines != 1) { gd_error("gd_jpeg: warning: jpeg_write_scanlines returns %u -- expected 1\n", nlines); } } } else { for(i = 0; i < im->sy; i++) { for(jidx = 0, j = 0; j < im->sx; j++) { int idx = im->pixels[i][j]; /* * NB: Although gd RGB values are ints, their max value is * 255 (see the documentation for gdImageColorAllocate()) * -- perfect for 8-bit JPEG encoding (which is the norm) */ #if BITS_IN_JSAMPLE == 8 row[jidx++] = im->red[idx]; row[jidx++] = im->green[idx]; row[jidx++] = im->blue[idx]; #elif BITS_IN_JSAMPLE == 12 row[jidx++] = im->red[idx] << 4; row[jidx++] = im->green[idx] << 4; row[jidx++] = im->blue[idx] << 4; #else #error IJG JPEG library BITS_IN_JSAMPLE value must be 8 or 12 #endif } nlines = jpeg_write_scanlines(&cinfo, rowptr, 1); if(nlines != 1) { gd_error("gd_jpeg: warning: jpeg_write_scanlines" " returns %u -- expected 1\n", nlines); } } } jpeg_finish_compress(&cinfo); jpeg_destroy_compress(&cinfo); gdFree(row); } /* Function: gdImageCreateFromJpeg See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromJpeg(FILE *inFile) { return gdImageCreateFromJpegEx(inFile, 1); } /* Function: gdImageCreateFromJpegEx is called to load truecolor images from JPEG format files. Invoke with an already opened pointer to a file containing the desired image. returns a to the new truecolor image, or NULL if unable to load the image (most often because the file is corrupt or does not contain a JPEG image). does not close the file. You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using . *The returned image is always a truecolor image.* Variants: creates an image from JPEG data already in memory. reads its data via the function pointers in a structure. , and are equivalent to calling their _Ex_-named counterparts with an ignore_warning set to 1 (i.e. TRUE). Parameters: infile - The input FILE pointer. ignore_warning - Flag. If true, ignores recoverable warnings. Returns: A pointer to the new *truecolor* image. This will need to be destroyed with once it is no longer needed. On error, returns NULL. Example: > gdImagePtr im; > FILE *in; > in = fopen("myjpeg.jpg", "rb"); > im = gdImageCreateFromJpegEx(in, GD_TRUE); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegEx(FILE *inFile, int ignore_warning) { gdImagePtr im; gdIOCtx *in = gdNewFileCtx(inFile); if (in == NULL) return NULL; im = gdImageCreateFromJpegCtxEx(in, ignore_warning); in->gd_free(in); return im; } /* Function: gdImageCreateFromJpegPtr Parameters: size - size of JPEG data in bytes. data - pointer to JPEG data. See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegPtr(int size, void *data) { return gdImageCreateFromJpegPtrEx(size, data, 1); } /* Function: gdImageCreateFromJpegPtrEx Parameters: size - size of JPEG data in bytes. data - pointer to JPEG data. ignore_warning - if true, ignore recoverable warnings See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegPtrEx(int size, void *data, int ignore_warning) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx(size, data, 0); if(!in) { return 0; } im = gdImageCreateFromJpegCtxEx(in, ignore_warning); in->gd_free(in); return im; } void jpeg_gdIOCtx_src(j_decompress_ptr cinfo, gdIOCtx *infile); static int CMYKToRGB(int c, int m, int y, int k, int inverted); /* Function: gdImageCreateFromJpegCtx See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegCtx(gdIOCtx *infile) { return gdImageCreateFromJpegCtxEx(infile, 1); } /* Function: gdImageCreateFromJpegCtxEx See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromJpegCtxEx(gdIOCtx *infile, int ignore_warning) { struct jpeg_decompress_struct cinfo; struct jpeg_error_mgr jerr; jmpbuf_wrapper jmpbufw; /* volatile so we can gdFree them after longjmp */ volatile JSAMPROW row = 0; volatile gdImagePtr im = 0; JSAMPROW rowptr[1]; JDIMENSION i, j; int retval; JDIMENSION nrows; int channels = 3; int inverted = 0; #ifdef JPEG_DEBUG gd_error_ex(GD_DEBUG, "gd-jpeg: gd JPEG version %s\n", GD_JPEG_VERSION); gd_error_ex(GD_DEBUG, "gd-jpeg: JPEG library version %d, %d-bit sample values\n", JPEG_LIB_VERSION, BITS_IN_JSAMPLE); gd_error_ex(GD_DEBUG, "sizeof: %d\n", sizeof(struct jpeg_decompress_struct)); #endif memset(&cinfo, 0, sizeof(cinfo)); memset(&jerr, 0, sizeof(jerr)); jmpbufw.ignore_warning = ignore_warning; cinfo.err = jpeg_std_error(&jerr); cinfo.client_data = &jmpbufw; cinfo.err->emit_message = jpeg_emit_message; if(setjmp(jmpbufw.jmpbuf) != 0) { /* we're here courtesy of longjmp */ if(row) { gdFree(row); } if(im) { gdImageDestroy(im); } return 0; } cinfo.err->error_exit = fatal_jpeg_error; jpeg_create_decompress(&cinfo); jpeg_gdIOCtx_src(&cinfo, infile); /* 2.0.22: save the APP14 marker to check for Adobe Photoshop CMYK * files with inverted components. */ jpeg_save_markers(&cinfo, JPEG_APP0 + 14, 256); retval = jpeg_read_header(&cinfo, TRUE); if(retval != JPEG_HEADER_OK) { gd_error("gd-jpeg: warning: jpeg_read_header returns" " %d, expected %d\n", retval, JPEG_HEADER_OK); } if(cinfo.image_height > INT_MAX) { gd_error("gd-jpeg: warning: JPEG image height (%u) is" " greater than INT_MAX (%d) (and thus greater than" " gd can handle)", cinfo.image_height, INT_MAX); } if(cinfo.image_width > INT_MAX) { gd_error("gd-jpeg: warning: JPEG image width (%u) is" " greater than INT_MAX (%d) (and thus greater than" " gd can handle)\n", cinfo.image_width, INT_MAX); } im = gdImageCreateTrueColor((int)cinfo.image_width, (int)cinfo.image_height); if(im == 0) { gd_error("gd-jpeg error: cannot allocate gdImage struct\n"); goto error; } /* check if the resolution is specified */ switch (cinfo.density_unit) { case 1: im->res_x = cinfo.X_density; im->res_y = cinfo.Y_density; break; case 2: im->res_x = DPCM2DPI(cinfo.X_density); im->res_y = DPCM2DPI(cinfo.Y_density); break; } /* 2.0.22: very basic support for reading CMYK colorspace files. Nice for * thumbnails but there's no support for fussy adjustment of the * assumed properties of inks and paper. */ if((cinfo.jpeg_color_space == JCS_CMYK) || (cinfo.jpeg_color_space == JCS_YCCK)) { cinfo.out_color_space = JCS_CMYK; } else { cinfo.out_color_space = JCS_RGB; } if(jpeg_start_decompress(&cinfo) != TRUE) { gd_error("gd-jpeg: warning: jpeg_start_decompress" " reports suspended data source\n"); } #ifdef JPEG_DEBUG gd_error_ex(GD_DEBUG, "gd-jpeg: JPEG image information:"); if(cinfo.saw_JFIF_marker) { gd_error_ex(GD_DEBUG, " JFIF version %d.%.2d", (int)cinfo.JFIF_major_version, (int)cinfo.JFIF_minor_version); } else if(cinfo.saw_Adobe_marker) { gd_error_ex(GD_DEBUG, " Adobe format"); } else { gd_error_ex(GD_DEBUG, " UNKNOWN format"); } gd_error_ex(GD_DEBUG, " %ux%u (raw) / %ux%u (scaled) %d-bit", cinfo.image_width, cinfo.image_height, cinfo.output_width, cinfo.output_height, cinfo.data_precision ); gd_error_ex(GD_DEBUG, " %s", (cinfo.progressive_mode ? "progressive" : "baseline")); gd_error_ex(GD_DEBUG, " image, %d quantized colors, ", cinfo.actual_number_of_colors); switch(cinfo.jpeg_color_space) { case JCS_GRAYSCALE: gd_error_ex(GD_DEBUG, "grayscale"); break; case JCS_RGB: gd_error_ex(GD_DEBUG, "RGB"); break; case JCS_YCbCr: gd_error_ex(GD_DEBUG, "YCbCr (a.k.a. YUV)"); break; case JCS_CMYK: gd_error_ex(GD_DEBUG, "CMYK"); break; case JCS_YCCK: gd_error_ex(GD_DEBUG, "YCbCrK"); break; default: gd_error_ex(GD_DEBUG, "UNKNOWN (value: %d)", (int)cinfo.jpeg_color_space); break; } gd_error_ex(GD_DEBUG, " colorspace\n"); fflush(stdout); #endif /* JPEG_DEBUG */ /* REMOVED by TBB 2/12/01. This field of the structure is * documented as private, and sure enough it's gone in the * latest libjpeg, replaced by something else. Unfortunately * there is still no right way to find out if the file was * progressive or not; just declare your intent before you * write one by calling gdImageInterlace(im, 1) yourself. * After all, we're not really supposed to rework JPEGs and * write them out again anyway. Lossy compression, remember? */ #if 0 gdImageInterlace (im, cinfo.progressive_mode != 0); #endif if(cinfo.out_color_space == JCS_RGB) { if(cinfo.output_components != 3) { gd_error("gd-jpeg: error: JPEG color quantization" " request resulted in output_components == %d" " (expected 3 for RGB)\n", cinfo.output_components); goto error; } channels = 3; } else if(cinfo.out_color_space == JCS_CMYK) { jpeg_saved_marker_ptr marker; if(cinfo.output_components != 4) { gd_error("gd-jpeg: error: JPEG color quantization" " request resulted in output_components == %d" " (expected 4 for CMYK)\n", cinfo.output_components); goto error; } channels = 4; marker = cinfo.marker_list; while(marker) { if( (marker->marker == (JPEG_APP0 + 14)) && (marker->data_length >= 12) && (!strncmp((const char *)marker->data, "Adobe", 5))) { inverted = 1; break; } marker = marker->next; } } else { gd_error("gd-jpeg: error: unexpected colorspace\n"); goto error; } #if BITS_IN_JSAMPLE == 12 gd_error_ex(GD_ERROR, "gd-jpeg: error: jpeg library was compiled for 12-bit\n" "precision. This is mostly useless, because JPEGs on the web are\n" "8-bit and such versions of the jpeg library won't read or write\n" "them. GD doesn't support these unusual images. Edit your\n" "jmorecfg.h file to specify the correct precision and completely\n" "'make clean' and 'make install' libjpeg again. Sorry.\n"); goto error; #endif /* BITS_IN_JSAMPLE == 12 */ row = gdCalloc(cinfo.output_width *channels, sizeof(JSAMPLE)); if(row == 0) { gd_error("gd-jpeg: error: unable to allocate row for" " JPEG scanline: gdCalloc returns NULL\n"); goto error; } rowptr[0] = row; if(cinfo.out_color_space == JCS_CMYK) { for(i = 0; i < cinfo.output_height; i++) { register JSAMPROW currow = row; register int *tpix = im->tpixels[i]; nrows = jpeg_read_scanlines(&cinfo, rowptr, 1); if(nrows != 1) { gd_error("gd-jpeg: error: jpeg_read_scanlines" " returns %u, expected 1\n", nrows); goto error; } for(j = 0; j < cinfo.output_width; j++, currow += 4, tpix++) { *tpix = CMYKToRGB(currow[0], currow[1], currow[2], currow[3], inverted); } } } else { for(i = 0; i < cinfo.output_height; i++) { register JSAMPROW currow = row; register int *tpix = im->tpixels[i]; nrows = jpeg_read_scanlines(&cinfo, rowptr, 1); if(nrows != 1) { gd_error("gd-jpeg: error: jpeg_read_scanlines" " returns %u, expected 1\n", nrows); goto error; } for(j = 0; j < cinfo.output_width; j++, currow += 3, tpix++) { *tpix = gdTrueColor(currow[0], currow[1], currow[2]); } } } if(jpeg_finish_decompress (&cinfo) != TRUE) { gd_error("gd-jpeg: warning: jpeg_finish_decompress" " reports suspended data source\n"); } /* TBB 2.0.29: we should do our best to read whatever we can read, and a * warning is a warning. A fatal error on warnings doesn't make sense. */ #if 0 /* This was originally added by Truxton Fulton */ if (cinfo.err->num_warnings > 0) goto error; #endif jpeg_destroy_decompress(&cinfo); gdFree(row); return im; error: jpeg_destroy_decompress(&cinfo); if(row) { gdFree(row); } if(im) { gdImageDestroy(im); } return 0; } /* A very basic conversion approach, TBB */ static int CMYKToRGB(int c, int m, int y, int k, int inverted) { if(inverted) { c = 255 - c; m = 255 - m; y = 255 - y; k = 255 - k; } return gdTrueColor( (255 - c) * (255 - k) / 255, (255 - m) * (255 - k) / 255, (255 - y) * (255 - k) / 255 ); #if 0 if (inverted) { c = 255 - c; m = 255 - m; y = 255 - y; k = 255 - k; } c = c * (255 - k) / 255 + k; if (c > 255) { c = 255; } if (c < 0) { c = 0; } m = m * (255 - k) / 255 + k; if (m > 255) { m = 255; } if (m < 0) { m = 0; } y = y * (255 - k) / 255 + k; if (y > 255) { y = 255; } if (y < 0) { y = 0; } c = 255 - c; m = 255 - m; y = 255 - y; return gdTrueColor (c, m, y); #endif } /* * gdIOCtx JPEG data sources and sinks, T. Boutell * almost a simple global replace from T. Lane's stdio versions. */ /* Different versions of libjpeg use either 'jboolean' or 'boolean', and * some platforms define 'boolean', and so forth. Deal with this * madness by typedeffing 'safeboolean' to 'boolean' if HAVE_BOOLEAN * is already set, because this is the test that libjpeg uses. * Otherwise, typedef it to int, because that's what libjpeg does * if HAVE_BOOLEAN is not defined. -TBB */ #ifdef HAVE_BOOLEAN typedef boolean safeboolean; #else typedef int safeboolean; #endif /* HAVE_BOOLEAN */ /* Expanded data source object for gdIOCtx input */ typedef struct { struct jpeg_source_mgr pub; /* public fields */ gdIOCtx *infile; /* source stream */ unsigned char *buffer; /* start of buffer */ safeboolean start_of_file; /* have we gotten any data yet? */ } my_source_mgr; typedef my_source_mgr *my_src_ptr; #define INPUT_BUF_SIZE 4096 /* choose an efficiently fread'able size */ /* * Initialize source --- called by jpeg_read_header * before any data is actually read. */ void init_source(j_decompress_ptr cinfo) { my_src_ptr src = (my_src_ptr)cinfo->src; /* We reset the empty-input-file flag for each image, * but we don't clear the input buffer. * This is correct behavior for reading a series of images from one source. */ src->start_of_file = TRUE; } /* * Fill the input buffer --- called whenever buffer is emptied. * * In typical applications, this should read fresh data into the buffer * (ignoring the current state of next_input_byte & bytes_in_buffer), * reset the pointer & count to the start of the buffer, and return TRUE * indicating that the buffer has been reloaded. It is not necessary to * fill the buffer entirely, only to obtain at least one more byte. * * There is no such thing as an EOF return. If the end of the file has been * reached, the routine has a choice of ERREXIT() or inserting fake data into * the buffer. In most cases, generating a warning message and inserting a * fake EOI marker is the best course of action --- this will allow the * decompressor to output however much of the image is there. However, * the resulting error message is misleading if the real problem is an empty * input file, so we handle that case specially. * * In applications that need to be able to suspend compression due to input * not being available yet, a FALSE return indicates that no more data can be * obtained right now, but more may be forthcoming later. In this situation, * the decompressor will return to its caller (with an indication of the * number of scanlines it has read, if any). The application should resume * decompression after it has loaded more data into the input buffer. Note * that there are substantial restrictions on the use of suspension --- see * the documentation. * * When suspending, the decompressor will back up to a convenient restart point * (typically the start of the current MCU). next_input_byte & bytes_in_buffer * indicate where the restart point will be if the current call returns FALSE. * Data beyond this point must be rescanned after resumption, so move it to * the front of the buffer rather than discarding it. */ #define END_JPEG_SEQUENCE "\r\n[*]--:END JPEG:--[*]\r\n" safeboolean fill_input_buffer(j_decompress_ptr cinfo) { my_src_ptr src = (my_src_ptr)cinfo->src; /* 2.0.12: signed size. Thanks to Geert Jansen */ /* 2.0.14: some platforms (mingw-msys) don't have ssize_t. Call * an int an int. */ int nbytes = 0; memset(src->buffer, 0, INPUT_BUF_SIZE); while(nbytes < INPUT_BUF_SIZE) { int got = gdGetBuf(src->buffer + nbytes, INPUT_BUF_SIZE - nbytes, src->infile); if((got == EOF) || (got == 0)) { /* EOF or error. If we got any data, don't worry about it. * If we didn't, then this is unexpected. */ if(!nbytes) { nbytes = -1; } break; } nbytes += got; } if(nbytes <= 0) { if(src->start_of_file) { /* Treat empty input file as fatal error */ ERREXIT(cinfo, JERR_INPUT_EMPTY); } WARNMS(cinfo, JWRN_JPEG_EOF); /* Insert a fake EOI marker */ src->buffer[0] = (unsigned char)0xFF; src->buffer[1] = (unsigned char)JPEG_EOI; nbytes = 2; } src->pub.next_input_byte = src->buffer; src->pub.bytes_in_buffer = nbytes; src->start_of_file = FALSE; return TRUE; } /* * Skip data --- used to skip over a potentially large amount of * uninteresting data (such as an APPn marker). * * Writers of suspendable-input applications must note that skip_input_data * is not granted the right to give a suspension return. If the skip extends * beyond the data currently in the buffer, the buffer can be marked empty so * that the next read will cause a fill_input_buffer call that can suspend. * Arranging for additional bytes to be discarded before reloading the input * buffer is the application writer's problem. */ void skip_input_data(j_decompress_ptr cinfo, long num_bytes) { my_src_ptr src = (my_src_ptr)cinfo->src; /* Just a dumb implementation for now. Not clear that being smart is worth * any trouble anyway --- large skips are infrequent. */ if(num_bytes > 0) { while(num_bytes > (long)src->pub.bytes_in_buffer) { num_bytes -= (long)src->pub.bytes_in_buffer; (void)fill_input_buffer(cinfo); /* note we assume that fill_input_buffer will never return FALSE, * so suspension need not be handled. */ } src->pub.next_input_byte += (size_t)num_bytes; src->pub.bytes_in_buffer -= (size_t)num_bytes; } } /* * An additional method that can be provided by data source modules is the * resync_to_restart method for error recovery in the presence of RST markers. * For the moment, this source module just uses the default resync method * provided by the JPEG library. That method assumes that no backtracking * is possible. */ /* * Terminate source --- called by jpeg_finish_decompress * after all data has been read. Often a no-op. * * NB: *not* called by jpeg_abort or jpeg_destroy; surrounding * application must deal with any cleanup that should happen even * for error exit. */ void term_source(j_decompress_ptr cinfo) { (void)cinfo; } /* * Prepare for input from a gdIOCtx stream. * The caller must have already opened the stream, and is responsible * for closing it after finishing decompression. */ void jpeg_gdIOCtx_src(j_decompress_ptr cinfo, gdIOCtx *infile) { my_src_ptr src; /* The source object and input buffer are made permanent so that a series * of JPEG images can be read from the same file by calling jpeg_gdIOCtx_src * only before the first one. (If we discarded the buffer at the end of * one image, we'd likely lose the start of the next one.) * This makes it unsafe to use this manager and a different source * manager serially with the same JPEG object. Caveat programmer. */ if(cinfo->src == NULL) { /* first time for this JPEG object? */ cinfo->src = (struct jpeg_source_mgr *) (*cinfo->mem->alloc_small)((j_common_ptr)cinfo, JPOOL_PERMANENT, sizeof(my_source_mgr)); src = (my_src_ptr)cinfo->src; src->buffer = (unsigned char *) (*cinfo->mem->alloc_small)((j_common_ptr)cinfo, JPOOL_PERMANENT, INPUT_BUF_SIZE * sizeof(unsigned char)); } src = (my_src_ptr)cinfo->src; src->pub.init_source = init_source; src->pub.fill_input_buffer = fill_input_buffer; src->pub.skip_input_data = skip_input_data; src->pub.resync_to_restart = jpeg_resync_to_restart; /* use default method */ src->pub.term_source = term_source; src->infile = infile; src->pub.bytes_in_buffer = 0; /* forces fill_input_buffer on first read */ src->pub.next_input_byte = NULL; /* until buffer loaded */ } /* Expanded data destination object for stdio output */ typedef struct { struct jpeg_destination_mgr pub; /* public fields */ gdIOCtx *outfile; /* target stream */ unsigned char *buffer; /* start of buffer */ } my_destination_mgr; typedef my_destination_mgr *my_dest_ptr; #define OUTPUT_BUF_SIZE 4096 /* choose an efficiently fwrite'able size */ /* * Initialize destination --- called by jpeg_start_compress * before any data is actually written. */ void init_destination(j_compress_ptr cinfo) { my_dest_ptr dest = (my_dest_ptr)cinfo->dest; /* Allocate the output buffer --- it will be released when done with image */ dest->buffer = (unsigned char *) (*cinfo->mem->alloc_small)((j_common_ptr)cinfo, JPOOL_IMAGE, OUTPUT_BUF_SIZE * sizeof(unsigned char)); dest->pub.next_output_byte = dest->buffer; dest->pub.free_in_buffer = OUTPUT_BUF_SIZE; } /* * Empty the output buffer --- called whenever buffer fills up. * * In typical applications, this should write the entire output buffer * (ignoring the current state of next_output_byte & free_in_buffer), * reset the pointer & count to the start of the buffer, and return TRUE * indicating that the buffer has been dumped. * * In applications that need to be able to suspend compression due to output * overrun, a FALSE return indicates that the buffer cannot be emptied now. * In this situation, the compressor will return to its caller (possibly with * an indication that it has not accepted all the supplied scanlines). The * application should resume compression after it has made more room in the * output buffer. Note that there are substantial restrictions on the use of * suspension --- see the documentation. * * When suspending, the compressor will back up to a convenient restart point * (typically the start of the current MCU). next_output_byte & free_in_buffer * indicate where the restart point will be if the current call returns FALSE. * Data beyond this point will be regenerated after resumption, so do not * write it out when emptying the buffer externally. */ safeboolean empty_output_buffer(j_compress_ptr cinfo) { my_dest_ptr dest = (my_dest_ptr)cinfo->dest; if(gdPutBuf(dest->buffer, OUTPUT_BUF_SIZE, dest->outfile) != (size_t)OUTPUT_BUF_SIZE) { ERREXIT(cinfo, JERR_FILE_WRITE); } dest->pub.next_output_byte = dest->buffer; dest->pub.free_in_buffer = OUTPUT_BUF_SIZE; return TRUE; } /* * Terminate destination --- called by jpeg_finish_compress * after all data has been written. Usually needs to flush buffer. * * NB: *not* called by jpeg_abort or jpeg_destroy; surrounding * application must deal with any cleanup that should happen even * for error exit. */ void term_destination(j_compress_ptr cinfo) { my_dest_ptr dest = (my_dest_ptr) cinfo->dest; int datacount = OUTPUT_BUF_SIZE - dest->pub.free_in_buffer; /* Write any data remaining in the buffer */ if(datacount > 0) { if(gdPutBuf(dest->buffer, datacount, dest->outfile) != datacount) { ERREXIT(cinfo, JERR_FILE_WRITE); } } } /* * Prepare for output to a stdio stream. * The caller must have already opened the stream, and is responsible * for closing it after finishing compression. */ void jpeg_gdIOCtx_dest(j_compress_ptr cinfo, gdIOCtx *outfile) { my_dest_ptr dest; /* The destination object is made permanent so that multiple JPEG images * can be written to the same file without re-executing jpeg_stdio_dest. * This makes it dangerous to use this manager and a different destination * manager serially with the same JPEG object, because their private object * sizes may be different. Caveat programmer. */ if(cinfo->dest == NULL) { /* first time for this JPEG object? */ cinfo->dest = (struct jpeg_destination_mgr *) (*cinfo->mem->alloc_small)((j_common_ptr)cinfo, JPOOL_PERMANENT, sizeof(my_destination_mgr)); } dest = (my_dest_ptr)cinfo->dest; dest->pub.init_destination = init_destination; dest->pub.empty_output_buffer = empty_output_buffer; dest->pub.term_destination = term_destination; dest->outfile = outfile; } #endif /* HAVE_LIBJPEG */ libgd-gd-2.1.1/src/gd_matrix.c000066400000000000000000000176741245535672000161250ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include "gd.h" #include #ifndef M_PI # define M_PI 3.14159265358979323846 #endif /** * Title: Matrix * Group: Affine Matrix */ /** * Function: gdAffineApplyToPointF * Applies an affine transformation to a point (floating point * gdPointF) * * * Parameters: * dst - Where to store the resulting point * affine - Source Point * flip_horz - affine matrix * * Returns: * GD_TRUE if the affine is rectilinear or GD_FALSE */ BGD_DECLARE(int) gdAffineApplyToPointF (gdPointFPtr dst, const gdPointFPtr src, const double affine[6]) { double x = src->x; double y = src->y; dst->x = x * affine[0] + y * affine[2] + affine[4]; dst->y = x * affine[1] + y * affine[3] + affine[5]; return GD_TRUE; } /** * Function: gdAffineInvert * Find the inverse of an affine transformation. * * All non-degenerate affine transforms are invertible. Applying the * inverted matrix will restore the original values. Multiplying * by (commutative) will return the identity affine (rounding * error possible). * * Parameters: * dst - Where to store the resulting affine transform * src_affine - Original affine matrix * flip_horz - Whether or not to flip horizontally * flip_vert - Whether or not to flip vertically * * See also: * * * Returns: * GD_TRUE if the affine is rectilinear or GD_FALSE */ BGD_DECLARE(int) gdAffineInvert (double dst[6], const double src[6]) { double r_det = (src[0] * src[3] - src[1] * src[2]); if (r_det <= 0.0) { return GD_FALSE; } r_det = 1.0 / r_det; dst[0] = src[3] * r_det; dst[1] = -src[1] * r_det; dst[2] = -src[2] * r_det; dst[3] = src[0] * r_det; dst[4] = -src[4] * dst[0] - src[5] * dst[2]; dst[5] = -src[4] * dst[1] - src[5] * dst[3]; return GD_TRUE; } /** * Function: gdAffineFlip * Flip an affine transformation horizontally or vertically. * * Flips the affine transform, giving GD_FALSE for and * will clone the affine matrix. GD_TRUE for both will * copy a 180° rotation. * * Parameters: * dst - Where to store the resulting affine transform * src_affine - Original affine matrix * flip_h - Whether or not to flip horizontally * flip_v - Whether or not to flip vertically * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineFlip (double dst[6], const double src[6], const int flip_h, const int flip_v) { dst[0] = flip_h ? - src[0] : src[0]; dst[1] = flip_h ? - src[1] : src[1]; dst[2] = flip_v ? - src[2] : src[2]; dst[3] = flip_v ? - src[3] : src[3]; dst[4] = flip_h ? - src[4] : src[4]; dst[5] = flip_v ? - src[5] : src[5]; return GD_TRUE; } /** * Function: gdAffineConcat * Concat (Multiply) two affine transformation matrices. * * Concats two affine transforms together, i.e. the result * will be the equivalent of doing first the transformation m1 and then * m2. All parameters can be the same matrix (safe to call using * the same array for all three arguments). * * Parameters: * dst - Where to store the resulting affine transform * m1 - First affine matrix * m2 - Second affine matrix * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineConcat (double dst[6], const double m1[6], const double m2[6]) { double dst0, dst1, dst2, dst3, dst4, dst5; dst0 = m1[0] * m2[0] + m1[1] * m2[2]; dst1 = m1[0] * m2[1] + m1[1] * m2[3]; dst2 = m1[2] * m2[0] + m1[3] * m2[2]; dst3 = m1[2] * m2[1] + m1[3] * m2[3]; dst4 = m1[4] * m2[0] + m1[5] * m2[2] + m2[4]; dst5 = m1[4] * m2[1] + m1[5] * m2[3] + m2[5]; dst[0] = dst0; dst[1] = dst1; dst[2] = dst2; dst[3] = dst3; dst[4] = dst4; dst[5] = dst5; return GD_TRUE; } /** * Function: gdAffineIdentity * Set up the identity matrix. * * Parameters: * dst - Where to store the resulting affine transform * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineIdentity (double dst[6]) { dst[0] = 1; dst[1] = 0; dst[2] = 0; dst[3] = 1; dst[4] = 0; dst[5] = 0; return GD_TRUE; } /** * Function: gdAffineScale * Set up a scaling matrix. * * Parameters: * scale_x - X scale factor * scale_y - Y scale factor * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineScale (double dst[6], const double scale_x, const double scale_y) { dst[0] = scale_x; dst[1] = 0; dst[2] = 0; dst[3] = scale_y; dst[4] = 0; dst[5] = 0; return GD_TRUE; } /** * Function: gdAffineRotate * Set up a rotation affine transform. * * Like the other angle in libGD, in which increasing y moves * downward, this is a counterclockwise rotation. * * Parameters: * dst - Where to store the resulting affine transform * angle - Rotation angle in degrees * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineRotate (double dst[6], const double angle) { const double sin_t = sin (angle * M_PI / 180.0); const double cos_t = cos (angle * M_PI / 180.0); dst[0] = cos_t; dst[1] = sin_t; dst[2] = -sin_t; dst[3] = cos_t; dst[4] = 0; dst[5] = 0; return GD_TRUE; } /** * Function: gdAffineShearHorizontal * Set up a horizontal shearing matrix || becomes \\. * * Parameters: * dst - Where to store the resulting affine transform * angle - Shear angle in degrees * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineShearHorizontal(double dst[6], const double angle) { dst[0] = 1; dst[1] = 0; dst[2] = tan(angle * M_PI / 180.0); dst[3] = 1; dst[4] = 0; dst[5] = 0; return GD_TRUE; } /** * Function: gdAffineShearVertical * Set up a vertical shearing matrix, columns are untouched. * * Parameters: * dst - Where to store the resulting affine transform * angle - Shear angle in degrees * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineShearVertical(double dst[6], const double angle) { dst[0] = 1; dst[1] = tan(angle * M_PI / 180.0);; dst[2] = 0; dst[3] = 1; dst[4] = 0; dst[5] = 0; return GD_TRUE; } /** * Function: gdAffineTranslate * Set up a translation matrix. * * Parameters: * dst - Where to store the resulting affine transform * offset_x - Horizontal translation amount * offset_y - Vertical translation amount * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineTranslate (double dst[6], const double offset_x, const double offset_y) { dst[0] = 1; dst[1] = 0; dst[2] = 0; dst[3] = 1; dst[4] = offset_x; dst[5] = offset_y; return GD_TRUE; } /** * gdAffineexpansion: Find the affine's expansion factor. * @src: The affine transformation. * * Finds the expansion factor, i.e. the square root of the factor * by which the affine transform affects area. In an affine transform * composed of scaling, rotation, shearing, and translation, returns * the amount of scaling. * * GD_TRUE on success or GD_FALSE **/ BGD_DECLARE(double) gdAffineExpansion (const double src[6]) { return sqrt (fabs (src[0] * src[3] - src[1] * src[2])); } /** * Function: gdAffineRectilinear * Determines whether the affine transformation is axis aligned. A * tolerance has been implemented using GD_EPSILON. * * Parameters: * m - The affine transformation * * Returns: * GD_TRUE if the affine is rectilinear or GD_FALSE */ BGD_DECLARE(int) gdAffineRectilinear (const double m[6]) { return ((fabs (m[1]) < GD_EPSILON && fabs (m[2]) < GD_EPSILON) || (fabs (m[0]) < GD_EPSILON && fabs (m[3]) < GD_EPSILON)); } /** * Function: gdAffineEqual * Determines whether two affine transformations are equal. A tolerance * has been implemented using GD_EPSILON. * * Parameters: * m1 - The first affine transformation * m2 - The first affine transformation * * Returns: * GD_TRUE on success or GD_FALSE */ BGD_DECLARE(int) gdAffineEqual (const double m1[6], const double m2[6]) { return (fabs (m1[0] - m2[0]) < GD_EPSILON && fabs (m1[1] - m2[1]) < GD_EPSILON && fabs (m1[2] - m2[2]) < GD_EPSILON && fabs (m1[3] - m2[3]) < GD_EPSILON && fabs (m1[4] - m2[4]) < GD_EPSILON && fabs (m1[5] - m2[5]) < GD_EPSILON); } libgd-gd-2.1.1/src/gd_nnquant.c000066400000000000000000000357261245535672000163030ustar00rootroot00000000000000/* NeuQuant Neural-Net Quantization Algorithm * ------------------------------------------ * * Copyright (c) 1994 Anthony Dekker * * NEUQUANT Neural-Net quantization algorithm by Anthony Dekker, 1994. * See "Kohonen neural networks for optimal colour quantization" * in "Network: Computation in Neural Systems" Vol. 5 (1994) pp 351-367. * for a discussion of the algorithm. * See also http://members.ozemail.com.au/~dekker/NEUQUANT.HTML * * Any party obtaining a copy of these files from the author, directly or * indirectly, is granted, free of charge, a full and unrestricted irrevocable, * world-wide, paid up, royalty-free, nonexclusive right and license to deal * in this software and documentation files (the "Software"), including without * limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons who receive * copies from any such party to do so, with the only requirement being * that this copyright notice remain intact. * * * Modified to process 32bit RGBA images. * Stuart Coyle 2004-2007 * From: http://pngnq.sourceforge.net/ * * Ported to libgd by Pierre A. Joye * (and make it thread safety by droping static and global variables) */ #ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include #include #include "gd.h" #include "gdhelpers.h" #include "gd_errors.h" #include "gd_nnquant.h" /* Network Definitions ------------------- */ #define maxnetpos (MAXNETSIZE-1) #define netbiasshift 4 /* bias for colour values */ #define ncycles 100 /* no. of learning cycles */ /* defs for freq and bias */ #define intbiasshift 16 /* bias for fractions */ #define intbias (((int) 1)<>betashift) /* beta = 1/1024 */ #define betagamma (intbias<<(gammashift-betashift)) /* defs for decreasing radius factor */ #define initrad (MAXNETSIZE>>3) /* for 256 cols, radius starts */ #define radiusbiasshift 6 /* at 32.0 biased by 6 bits */ #define radiusbias (((int) 1)<network, 0, sizeof(nq_pixel)*MAXNETSIZE); nnq->thepicture = thepic; nnq->lengthcount = len; nnq->samplefac = sample; nnq->netsize = colours; for (i=0; i < nnq->netsize; i++) { p = nnq->network[i]; p[0] = p[1] = p[2] = p[3] = (i << (netbiasshift+8)) / nnq->netsize; nnq->freq[i] = intbias / nnq->netsize; /* 1/netsize */ nnq->bias[i] = 0; } } /* -------------------------- */ /* Unbias network to give byte values 0..255 and record * position i to prepare for sort */ /* -------------------------- */ void unbiasnet(nn_quant *nnq) { int i,j,temp; for (i=0; i < nnq->netsize; i++) { for (j=0; j<4; j++) { /* OLD CODE: network[i][j] >>= netbiasshift; */ /* Fix based on bug report by Juergen Weigert jw@suse.de */ temp = (nnq->network[i][j] + (1 << (netbiasshift - 1))) >> netbiasshift; if (temp > 255) temp = 255; nnq->network[i][j] = temp; } nnq->network[i][4] = i; /* record colour no */ } } /* Output colour map ----------------- */ void writecolourmap(nnq, f) nn_quant *nnq; FILE *f; { int i,j; for (i=3; i>=0; i--) for (j=0; j < nnq->netsize; j++) putc(nnq->network[j][i], f); } /* Output colormap to unsigned char ptr in RGBA format */ void getcolormap(nnq, map) nn_quant *nnq; unsigned char *map; { int i,j; for(j=0; j < nnq->netsize; j++) { for (i=3; i>=0; i--) { *map = nnq->network[j][i]; map++; } } } /* Insertion sort of network and building of netindex[0..255] (to do after unbias) ------------------------------------------------------------------------------- */ void inxbuild(nn_quant *nnq) { register int i,j,smallpos,smallval; register int *p,*q; int previouscol,startpos; previouscol = 0; startpos = 0; for (i=0; i < nnq->netsize; i++) { p = nnq->network[i]; smallpos = i; smallval = p[2]; /* index on g */ /* find smallest in i..netsize-1 */ for (j=i+1; j < nnq->netsize; j++) { q = nnq->network[j]; if (q[2] < smallval) { /* index on g */ smallpos = j; smallval = q[2]; /* index on g */ } } q = nnq->network[smallpos]; /* swap p (i) and q (smallpos) entries */ if (i != smallpos) { j = q[0]; q[0] = p[0]; p[0] = j; j = q[1]; q[1] = p[1]; p[1] = j; j = q[2]; q[2] = p[2]; p[2] = j; j = q[3]; q[3] = p[3]; p[3] = j; j = q[4]; q[4] = p[4]; p[4] = j; } /* smallval entry is now in position i */ if (smallval != previouscol) { nnq->netindex[previouscol] = (startpos+i)>>1; for (j=previouscol+1; jnetindex[j] = i; previouscol = smallval; startpos = i; } } nnq->netindex[previouscol] = (startpos+maxnetpos)>>1; for (j=previouscol+1; j<256; j++) nnq->netindex[j] = maxnetpos; /* really 256 */ } /* Search for ABGR values 0..255 (after net is unbiased) and return colour index ---------------------------------------------------------------------------- */ int inxsearch(nnq, al,b,g,r) nn_quant *nnq; register int al, b, g, r; { register int i, j, dist, a, bestd; register int *p; int best; bestd = 1000; /* biggest possible dist is 256*3 */ best = -1; i = nnq->netindex[g]; /* index on g */ j = i-1; /* start at netindex[g] and work outwards */ while ((inetsize) || (j>=0)) { if (i< nnq->netsize) { p = nnq->network[i]; dist = p[2] - g; /* inx key */ if (dist >= bestd) i = nnq->netsize; /* stop iter */ else { i++; if (dist<0) dist = -dist; a = p[1] - b; if (a<0) a = -a; dist += a; if (dist=0) { p = nnq->network[j]; dist = g - p[2]; /* inx key - reverse dif */ if (dist >= bestd) j = -1; /* stop iter */ else { j--; if (dist<0) dist = -dist; a = p[1] - b; if (a<0) a = -a; dist += a; if (distbias; f = nnq->freq; for (i=0; i< nnq->netsize; i++) { n = nnq->network[i]; dist = n[0] - al; if (dist<0) dist = -dist; a = n[1] - b; if (a<0) a = -a; dist += a; a = n[2] - g; if (a<0) a = -a; dist += a; a = n[3] - r; if (a<0) a = -a; dist += a; if (dist>(intbiasshift-netbiasshift)); if (biasdist> betashift); *f++ -= betafreq; *p++ += (betafreq<freq[bestpos] += beta; nnq->bias[bestpos] -= betagamma; return(bestbiaspos); } /* Move neuron i towards biased (a,b,g,r) by factor alpha ---------------------------------------------------- */ void altersingle(nnq, alpha,i,al,b,g,r) nn_quant *nnq; register int alpha,i,al,b,g,r; { register int *n; n = nnq->network[i]; /* alter hit neuron */ *n -= (alpha*(*n - al)) / initalpha; n++; *n -= (alpha*(*n - b)) / initalpha; n++; *n -= (alpha*(*n - g)) / initalpha; n++; *n -= (alpha*(*n - r)) / initalpha; } /* Move adjacent neurons by precomputed alpha*(1-((i-j)^2/[r]^2)) in radpower[|i-j|] --------------------------------------------------------------------------------- */ void alterneigh(nnq, rad,i,al,b,g,r) nn_quant *nnq; int rad,i; register int al,b,g,r; { register int j,k,lo,hi,a; register int *p, *q; lo = i-rad; if (lo<-1) lo=-1; hi = i+rad; if (hi>nnq->netsize) hi=nnq->netsize; j = i+1; k = i-1; q = nnq->radpower; while ((jlo)) { a = (*(++q)); if (jnetwork[j]; *p -= (a*(*p - al)) / alpharadbias; p++; *p -= (a*(*p - b)) / alpharadbias; p++; *p -= (a*(*p - g)) / alpharadbias; p++; *p -= (a*(*p - r)) / alpharadbias; j++; } if (k>lo) { p = nnq->network[k]; *p -= (a*(*p - al)) / alpharadbias; p++; *p -= (a*(*p - b)) / alpharadbias; p++; *p -= (a*(*p - g)) / alpharadbias; p++; *p -= (a*(*p - r)) / alpharadbias; k--; } } } /* Main Learning Loop ------------------ */ void learn(nnq, verbose) /* Stu: N.B. added parameter so that main() could control verbosity. */ nn_quant *nnq; int verbose; { register int i,j,al,b,g,r; int radius,rad,alpha,step,delta,samplepixels; register unsigned char *p; unsigned char *lim; nnq->alphadec = 30 + ((nnq->samplefac-1)/3); p = nnq->thepicture; lim = nnq->thepicture + nnq->lengthcount; samplepixels = nnq->lengthcount/(4 * nnq->samplefac); /* here's a problem with small images: samplepixels < ncycles => delta = 0 */ delta = samplepixels/ncycles; /* kludge to fix */ if(delta==0) delta = 1; alpha = initalpha; radius = initradius; rad = radius >> radiusbiasshift; if (rad <= 1) rad = 0; for (i=0; iradpower[i] = alpha*(((rad*rad - i*i)*radbias)/(rad*rad)); if (verbose) gd_error_ex(GD_NOTICE, "beginning 1D learning: initial radius=%d\n", rad); if ((nnq->lengthcount%prime1) != 0) step = 4*prime1; else { if ((nnq->lengthcount%prime2) !=0) step = 4*prime2; else { if ((nnq->lengthcount%prime3) !=0) step = 4*prime3; else step = 4*prime4; } } i = 0; while (i < samplepixels) { al = p[ALPHA] << netbiasshift; b = p[BLUE] << netbiasshift; g = p[GREEN] << netbiasshift; r = p[RED] << netbiasshift; j = contest(nnq, al,b,g,r); altersingle(nnq, alpha,j,al,b,g,r); if (rad) alterneigh(nnq, rad,j,al,b,g,r); /* alter neighbours */ p += step; while (p >= lim) p -= nnq->lengthcount; i++; if (i%delta == 0) { /* FPE here if delta=0*/ alpha -= alpha / nnq->alphadec; radius -= radius / radiusdec; rad = radius >> radiusbiasshift; if (rad <= 1) rad = 0; for (j=0; jradpower[j] = alpha*(((rad*rad - j*j)*radbias)/(rad*rad)); } } if (verbose) gd_error_ex(GD_NOTICE, "finished 1D learning: final alpha=%f !\n",((float)alpha)/initalpha); } BGD_DECLARE(gdImagePtr) gdImageNeuQuant(gdImagePtr im, const int max_color, int sample_factor) { const int newcolors = max_color; const int verbose = 1; int bot_idx, top_idx; /* for remapping of indices */ int remap[MAXNETSIZE]; int i,x; unsigned char map[MAXNETSIZE][4]; unsigned char *d; nn_quant *nnq = NULL; int row; unsigned char *rgba = NULL; gdImagePtr dst = NULL; /* Default it to 3 */ if (sample_factor < 1) { sample_factor = 3; } /* Start neuquant */ /* Pierre: * This implementation works with aligned contiguous buffer only * Upcoming new buffers are contiguous and will be much faster. * let don't bloat this code to support our good "old" 31bit format. * It alos lets us convert palette image, if one likes to reduce * a palette */ if (overflow2(gdImageSX(im), gdImageSY(im)) || overflow2(gdImageSX(im) * gdImageSY(im), 4)) { goto done; } rgba = (unsigned char *) gdMalloc(gdImageSX(im) * gdImageSY(im) * 4); if (!rgba) { goto done; } d = rgba; for (row = 0; row < gdImageSY(im); row++) { int *p = im->tpixels[row]; register int c; for (i = 0; i < gdImageSX(im); i++) { c = *p; *d++ = gdImageAlpha(im, c); *d++ = gdImageRed(im, c); *d++ = gdImageBlue(im, c); *d++ = gdImageGreen(im, c); p++; } } nnq = (nn_quant *) gdMalloc(sizeof(nn_quant)); if (!nnq) { goto done; } initnet(nnq, rgba, gdImageSY(im) * gdImageSX(im) * 4, sample_factor, newcolors); learn(nnq, verbose); unbiasnet(nnq); getcolormap(nnq, (unsigned char*)map); inxbuild(nnq); /* remapping colormap to eliminate opaque tRNS-chunk entries... */ for (top_idx = newcolors-1, bot_idx = x = 0; x < newcolors; ++x) { if (map[x][3] == 255) { /* maxval */ remap[x] = top_idx--; } else { remap[x] = bot_idx++; } } if (bot_idx != top_idx + 1) { gd_error(" internal logic error: remapped bot_idx = %d, top_idx = %d\n", bot_idx, top_idx); goto done; } dst = gdImageCreate(gdImageSX(im), gdImageSY(im)); if (!dst) { goto done; } for (x = 0; x < newcolors; ++x) { dst->red[remap[x]] = map[x][0]; dst->green[remap[x]] = map[x][1]; dst->blue[remap[x]] = map[x][2]; dst->alpha[remap[x]] = map[x][3]; dst->open[remap[x]] = 0; dst->colorsTotal++; } /* Do each image row */ for ( row = 0; row < gdImageSY(im); ++row ) { int offset; unsigned char *p = dst->pixels[row]; /* Assign the new colors */ offset = row * gdImageSX(im) * 4; for(i=0; i < gdImageSX(im); i++) { p[i] = remap[ inxsearch(nnq, rgba[i * 4 + offset + ALPHA], rgba[i * 4 + offset + BLUE], rgba[i * 4 + offset + GREEN], rgba[i * 4 + offset + RED]) ]; } } done: if (rgba) { gdFree(rgba); } if (nnq) { gdFree(nnq); } return dst; } libgd-gd-2.1.1/src/gd_nnquant.h000066400000000000000000000010171245535672000162720ustar00rootroot00000000000000 /* maximum number of colours that can be used. actual number is now passed to initcolors */ #define MAXNETSIZE 256 /* For 256 colours, fixed arrays need 8kb, plus space for the image ---------------------------------------------------------------- */ /* four primes near 500 - assume no image has a length so large */ /* that it is divisible by all four primes */ #define prime1 499 #define prime2 491 #define prime3 487 #define prime4 503 #define minpicturebytes (4*prime4) /* minimum size for input image */ libgd-gd-2.1.1/src/gd_png.c000066400000000000000000000755611245535672000154040ustar00rootroot00000000000000/* $Id$ */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include #include "gd.h" #include "gd_errors.h" /* JCE: Arrange HAVE_LIBPNG so that it can be set in gd.h */ #ifdef HAVE_LIBPNG #include "gdhelpers.h" #include "png.h" /* includes zlib.h and setjmp.h */ #define TRUE 1 #define FALSE 0 /*--------------------------------------------------------------------------- gd_png.c Copyright 1999 Greg Roelofs and Thomas Boutell The routines in this file, gdImagePng*() and gdImageCreateFromPng*(), are drop-in replacements for gdImageGif*() and gdImageCreateFromGif*(), except that these functions are noisier in the case of errors (comment out all fprintf() statements to disable that). GD 2.0 supports RGBA truecolor and will read and write truecolor PNGs. GD 2.0 supports 8 bits of color resolution per channel and 7 bits of alpha channel resolution. Images with more than 8 bits per channel are reduced to 8 bits. Images with an alpha channel are only able to resolve down to '1/128th opaque' instead of '1/256th', and this conversion is also automatic. I very much doubt you can see it. Both tRNS and true alpha are supported. Gamma is ignored, and there is no support for text annotations. Last updated: 9 February 2001 ---------------------------------------------------------------------------*/ #ifdef PNG_SETJMP_SUPPORTED typedef struct _jmpbuf_wrapper { jmp_buf jmpbuf; } jmpbuf_wrapper; static void gdPngErrorHandler (png_structp png_ptr, png_const_charp msg) { jmpbuf_wrapper *jmpbuf_ptr; /* This function, aside from the extra step of retrieving the "error * pointer" (below) and the fact that it exists within the application * rather than within libpng, is essentially identical to libpng's * default error handler. The second point is critical: since both * setjmp() and longjmp() are called from the same code, they are * guaranteed to have compatible notions of how big a jmp_buf is, * regardless of whether _BSD_SOURCE or anything else has (or has not) * been defined. */ gd_error_ex(GD_ERROR, "gd-png: fatal libpng error: %s\n", msg); jmpbuf_ptr = png_get_error_ptr (png_ptr); if (jmpbuf_ptr == NULL) { /* we are completely hosed now */ gd_error_ex(GD_ERROR, "gd-png: EXTREMELY fatal error: jmpbuf unrecoverable; terminating.\n"); exit (99); } longjmp (jmpbuf_ptr->jmpbuf, 1); } #endif static void gdPngReadData (png_structp png_ptr, png_bytep data, png_size_t length) { int check; check = gdGetBuf (data, length, (gdIOCtx *) png_get_io_ptr (png_ptr)); if (check != (int)length) { png_error(png_ptr, "Read Error: truncated data"); } } static void gdPngWriteData (png_structp png_ptr, png_bytep data, png_size_t length) { gdPutBuf (data, length, (gdIOCtx *) png_get_io_ptr (png_ptr)); } static void gdPngFlushData (png_structp png_ptr) { (void)png_ptr; } /* Function: gdImageCreateFromPng is called to load images from PNG format files. Invoke with an already opened pointer to a FILE containing the desired image. returns a to the new image, or NULL if unable to load the image (most often because the file is corrupt or does not contain a PNG image). does not close the file. You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using gdImageDestroy(). If the PNG image being loaded is a truecolor image, the resulting gdImagePtr will refer to a truecolor image. If the PNG image being loaded is a palette or grayscale image, the resulting gdImagePtr will refer to a palette image. gd retains only 8 bits of resolution for each of the red, green and blue channels, and only 7 bits of resolution for the alpha channel. The former restriction affects only a handful of very rare 48-bit color and 16-bit grayscale PNG images. The second restriction affects all semitransparent PNG images, but the difference is essentially invisible to the eye. 7 bits of alpha channel resolution is, in practice, quite a lot. Variants: creates an image from PNG data (i.e. the contents of a PNG file) already in memory. reads in an image using the functions in a struct. is similar to but uses the old interface. It is *obsolete*. Parameters: infile - The input FILE pointer. Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > ... inside a function ... > FILE *in; > in = fopen("mypng.png", "rb"); > im = gdImageCreateFromPng(in); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromPng (FILE * inFile) { gdImagePtr im; gdIOCtx *in = gdNewFileCtx (inFile); if (in == NULL) return NULL; im = gdImageCreateFromPngCtx (in); in->gd_free (in); return im; } /* Function: gdImageCreateFromPngPtr See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromPngPtr (int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx (size, data, 0); if(!in) return 0; im = gdImageCreateFromPngCtx (in); in->gd_free (in); return im; } /* This routine is based in part on the Chapter 13 demo code in * "PNG: The Definitive Guide" (http://www.libpng.org/pub/png/book/). */ /* Function: gdImageCreateFromPngCtx See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromPngCtx (gdIOCtx * infile) { png_byte sig[8]; #ifdef PNG_SETJMP_SUPPORTED jmpbuf_wrapper jbw; #endif png_structp png_ptr; png_infop info_ptr; png_uint_32 width, height, rowbytes, w, h, res_x, res_y; int bit_depth, color_type, interlace_type, unit_type; int num_palette = 0, num_trans; png_colorp palette; png_color_16p trans_gray_rgb; png_color_16p trans_color_rgb; png_bytep trans; png_bytep image_data = NULL; png_bytepp row_pointers = NULL; gdImagePtr im = NULL; int i, j, *open = NULL; volatile int transparent = -1; volatile int palette_allocated = FALSE; /* Make sure the signature can't match by dumb luck -- TBB */ /* GRR: isn't sizeof(infile) equal to the size of the pointer? */ memset (sig, 0, sizeof (sig)); /* first do a quick check that the file really is a PNG image; could * have used slightly more general png_sig_cmp() function instead */ if (gdGetBuf (sig, 8, infile) < 8) { return NULL; } if (png_sig_cmp(sig, 0, 8) != 0) { /* bad signature */ return NULL; /* bad signature */ } #ifdef PNG_SETJMP_SUPPORTED png_ptr = png_create_read_struct (PNG_LIBPNG_VER_STRING, &jbw, gdPngErrorHandler, NULL); #else png_ptr = png_create_read_struct (PNG_LIBPNG_VER_STRING, NULL, NULL, NULL); #endif if (png_ptr == NULL) { gd_error("gd-png error: cannot allocate libpng main struct\n"); return NULL; } info_ptr = png_create_info_struct (png_ptr); if (info_ptr == NULL) { gd_error("gd-png error: cannot allocate libpng info struct\n"); png_destroy_read_struct (&png_ptr, NULL, NULL); return NULL; } /* we could create a second info struct here (end_info), but it's only * useful if we want to keep pre- and post-IDAT chunk info separated * (mainly for PNG-aware image editors and converters) */ /* setjmp() must be called in every non-callback function that calls a * PNG-reading libpng function */ #ifdef PNG_SETJMP_SUPPORTED if (setjmp(jbw.jmpbuf)) { gd_error("gd-png error: setjmp returns error condition 1\n"); png_destroy_read_struct (&png_ptr, &info_ptr, NULL); return NULL; } #endif png_set_sig_bytes (png_ptr, 8); /* we already read the 8 signature bytes */ png_set_read_fn (png_ptr, (void *) infile, gdPngReadData); png_read_info (png_ptr, info_ptr); /* read all PNG info up to image data */ png_get_IHDR (png_ptr, info_ptr, &width, &height, &bit_depth, &color_type, &interlace_type, NULL, NULL); if ((color_type == PNG_COLOR_TYPE_RGB) || (color_type == PNG_COLOR_TYPE_RGB_ALPHA) || color_type == PNG_COLOR_TYPE_GRAY_ALPHA) { im = gdImageCreateTrueColor ((int) width, (int) height); } else { im = gdImageCreate ((int) width, (int) height); } if (im == NULL) { gd_error("gd-png error: cannot allocate gdImage struct\n"); png_destroy_read_struct (&png_ptr, &info_ptr, NULL); return NULL; } if (bit_depth == 16) { png_set_strip_16 (png_ptr); } else if (bit_depth < 8) { png_set_packing (png_ptr); /* expand to 1 byte per pixel */ } /* setjmp() must be called in every non-callback function that calls a * PNG-reading libpng function */ #ifdef PNG_SETJMP_SUPPORTED if (setjmp(jbw.jmpbuf)) { gd_error("gd-png error: setjmp returns error condition 2\n"); png_destroy_read_struct(&png_ptr, &info_ptr, NULL); gdFree(image_data); gdFree(row_pointers); if (im) { gdImageDestroy(im); } return NULL; } #endif #ifdef PNG_pHYs_SUPPORTED /* check if the resolution is specified */ if (png_get_valid(png_ptr, info_ptr, PNG_INFO_pHYs)) { if (png_get_pHYs(png_ptr, info_ptr, &res_x, &res_y, &unit_type)) { switch (unit_type) { case PNG_RESOLUTION_METER: im->res_x = DPM2DPI(res_x); im->res_y = DPM2DPI(res_y); break; } } } #endif switch (color_type) { case PNG_COLOR_TYPE_PALETTE: png_get_PLTE (png_ptr, info_ptr, &palette, &num_palette); #ifdef DEBUG gd_error("gd-png color_type is palette, colors: %d\n", num_palette); #endif /* DEBUG */ if (png_get_valid (png_ptr, info_ptr, PNG_INFO_tRNS)) { /* gd 2.0: we support this rather thoroughly now. Grab the * first fully transparent entry, if any, as the value of * the simple-transparency index, mostly for backwards * binary compatibility. The alpha channel is where it's * really at these days. */ int firstZero = 1; png_get_tRNS (png_ptr, info_ptr, &trans, &num_trans, NULL); for (i = 0; i < num_trans; ++i) { im->alpha[i] = gdAlphaMax - (trans[i] >> 1); if ((trans[i] == 0) && (firstZero)) { /* 2.0.5: long-forgotten patch from Wez Furlong */ transparent = i; firstZero = 0; } } } break; case PNG_COLOR_TYPE_GRAY: /* create a fake palette and check for single-shade transparency */ if ((palette = (png_colorp) gdMalloc (256 * sizeof (png_color))) == NULL) { gd_error("gd-png error: cannot allocate gray palette\n"); png_destroy_read_struct (&png_ptr, &info_ptr, NULL); gdImageDestroy(im); return NULL; } palette_allocated = TRUE; if (bit_depth < 8) { num_palette = 1 << bit_depth; for (i = 0; i < 256; ++i) { j = (255 * i) / (num_palette - 1); palette[i].red = palette[i].green = palette[i].blue = j; } } else { num_palette = 256; for (i = 0; i < 256; ++i) { palette[i].red = palette[i].green = palette[i].blue = i; } } if (png_get_valid (png_ptr, info_ptr, PNG_INFO_tRNS)) { png_get_tRNS (png_ptr, info_ptr, NULL, NULL, &trans_gray_rgb); if (bit_depth == 16) { /* png_set_strip_16() not yet in effect */ transparent = trans_gray_rgb->gray >> 8; } else { transparent = trans_gray_rgb->gray; } /* Note slight error in 16-bit case: up to 256 16-bit shades * may get mapped to a single 8-bit shade, and only one of them * is supposed to be transparent. IOW, both opaque pixels and * transparent pixels will be mapped into the transparent entry. * There is no particularly good way around this in the case * that all 256 8-bit shades are used, but one could write some * custom 16-bit code to handle the case where there are gdFree * palette entries. This error will be extremely rare in * general, though. (Quite possibly there is only one such * image in existence.) */ } break; case PNG_COLOR_TYPE_GRAY_ALPHA: png_set_gray_to_rgb(png_ptr); case PNG_COLOR_TYPE_RGB: case PNG_COLOR_TYPE_RGB_ALPHA: /* gd 2.0: we now support truecolor. See the comment above for a rare situation in which the transparent pixel may not work properly with 16-bit channels. */ if (png_get_valid (png_ptr, info_ptr, PNG_INFO_tRNS)) { png_get_tRNS (png_ptr, info_ptr, NULL, NULL, &trans_color_rgb); if (bit_depth == 16) { /* png_set_strip_16() not yet in effect */ transparent = gdTrueColor (trans_color_rgb->red >> 8, trans_color_rgb->green >> 8, trans_color_rgb->blue >> 8); } else { transparent = gdTrueColor (trans_color_rgb->red, trans_color_rgb->green, trans_color_rgb->blue); } } break; default: gd_error("gd-png color_type is unknown: %d\n", color_type); png_destroy_read_struct(&png_ptr, &info_ptr, NULL); gdFree(image_data); gdFree(row_pointers); if (im) { gdImageDestroy(im); } return NULL; break; } png_read_update_info (png_ptr, info_ptr); /* allocate space for the PNG image data */ rowbytes = png_get_rowbytes (png_ptr, info_ptr); if (overflow2(rowbytes, height)) { png_destroy_read_struct (&png_ptr, &info_ptr, NULL); if (im) { gdImageDestroy(im); } return NULL; } image_data = (png_bytep) gdMalloc (rowbytes * height); if (!image_data) { gd_error("gd-png error: cannot allocate image data\n"); png_destroy_read_struct (&png_ptr, &info_ptr, NULL); if (im) { gdImageDestroy(im); } if (palette_allocated) { gdFree (palette); } return NULL; } if (overflow2(height, sizeof (png_bytep))) { png_destroy_read_struct (&png_ptr, &info_ptr, NULL); gdFree (image_data); if (im) { gdImageDestroy(im); } if (palette_allocated) { gdFree (palette); } return NULL; } row_pointers = (png_bytepp) gdMalloc (height * sizeof (png_bytep)); if (!row_pointers) { gd_error("gd-png error: cannot allocate row pointers\n"); png_destroy_read_struct (&png_ptr, &info_ptr, NULL); if (im) { gdImageDestroy(im); } gdFree (image_data); if (palette_allocated) { gdFree (palette); } return NULL; } /* set the individual row_pointers to point at the correct offsets */ for (h = 0; h < height; ++h) { row_pointers[h] = image_data + h * rowbytes; } png_read_image (png_ptr, row_pointers); /* read whole image... */ png_read_end (png_ptr, NULL); /* ...done! */ if (!im->trueColor) { im->colorsTotal = num_palette; /* load the palette and mark all entries "open" (unused) for now */ open = im->open; for (i = 0; i < num_palette; ++i) { im->red[i] = palette[i].red; im->green[i] = palette[i].green; im->blue[i] = palette[i].blue; open[i] = 1; } for (i = num_palette; i < gdMaxColors; ++i) { open[i] = 1; } } /* 2.0.12: Slaven Rezic: palette images are not the only images with a simple transparent color setting */ im->transparent = transparent; im->interlace = (interlace_type == PNG_INTERLACE_ADAM7); /* can't nuke structs until done with palette */ png_destroy_read_struct (&png_ptr, &info_ptr, NULL); switch (color_type) { case PNG_COLOR_TYPE_RGB: for (h = 0; h < height; h++) { int boffset = 0; for (w = 0; w < width; w++) { register png_byte r = row_pointers[h][boffset++]; register png_byte g = row_pointers[h][boffset++]; register png_byte b = row_pointers[h][boffset++]; im->tpixels[h][w] = gdTrueColor (r, g, b); } } break; case PNG_COLOR_TYPE_GRAY_ALPHA: case PNG_COLOR_TYPE_RGB_ALPHA: for (h = 0; h < height; h++) { int boffset = 0; for (w = 0; w < width; w++) { register png_byte r = row_pointers[h][boffset++]; register png_byte g = row_pointers[h][boffset++]; register png_byte b = row_pointers[h][boffset++]; /* gd has only 7 bits of alpha channel resolution, and * 127 is transparent, 0 opaque. A moment of convenience, * a lifetime of compatibility. */ register png_byte a = gdAlphaMax - (row_pointers[h][boffset++] >> 1); im->tpixels[h][w] = gdTrueColorAlpha(r, g, b, a); } } break; default: /* Palette image, or something coerced to be one */ for (h = 0; h < height; ++h) { for (w = 0; w < width; ++w) { register png_byte idx = row_pointers[h][w]; im->pixels[h][w] = idx; open[idx] = 0; } } } #ifdef DEBUG if (!im->trueColor) { for (i = num_palette; i < gdMaxColors; ++i) { if (!open[i]) { fprintf (stderr, "gd-png warning: image data references out-of-range" " color index (%d)\n", i); } } } #endif if (palette_allocated) { gdFree (palette); } gdFree (image_data); gdFree (row_pointers); return im; } /* Function: gdImagePngEx outputs the specified image to the specified file in PNG format. The file must be open for writing. Under MSDOS and all versions of Windows, it is important to use "wb" as opposed to simply "w" as the mode when opening the file, and under Unix there is no penalty for doing so. does not close the file; your code must do so. In addition, allows the level of compression to be specified. A compression level of 0 means "no compression." A compression level of 1 means "compressed, but as quickly as possible." A compression level of 9 means "compressed as much as possible to produce the smallest possible file." A compression level of -1 will use the default compression level at the time zlib was compiled on your system. Variants: is equivalent to calling with compression of -1. and write via a instead of a file handle. and store the image file to memory. Parameters: im - the image to write outFile - the output FILE* object. level - compression level: 0 -> none, 1-9 -> level, -1 -> default Returns: Nothing. Example: > gdImagePtr im; > int black, white; > FILE *out; > > im = gdImageCreate(100, 100); // Create the image > white = gdImageColorAllocate(im, 255, 255, 255); // Alloc background > black = gdImageColorAllocate(im, 0, 0, 0); // Allocate drawing color > gdImageRectangle(im, 0, 0, 99, 99, black); // Draw rectangle > out = fopen("rect.png", "wb"); // Open output file (binary) > gdImagePngEx(im, out, 9); // Write PNG, max compression > fclose(out); // Close file > gdImageDestroy(im); // Destroy image */ BGD_DECLARE(void) gdImagePngEx (gdImagePtr im, FILE * outFile, int level) { gdIOCtx *out = gdNewFileCtx (outFile); if (out == NULL) return; gdImagePngCtxEx (im, out, level); out->gd_free (out); } /* Function: gdImagePng Equivalent to calling with compression of -1. Parameters: im - the image to save. outFile - the output FILE*. Returns: Nothing. */ BGD_DECLARE(void) gdImagePng (gdImagePtr im, FILE * outFile) { gdIOCtx *out = gdNewFileCtx (outFile); if (out == NULL) return; gdImagePngCtxEx (im, out, -1); out->gd_free (out); } /* Function: gdImagePngPtr Equivalent to calling with compression of -1. See for more information. Parameters: im - the image to save. size - Output: size in bytes of the result. Returns: A pointer to memory containing the image data or NULL on error. */ BGD_DECLARE(void *) gdImagePngPtr (gdImagePtr im, int *size) { void *rv; gdIOCtx *out = gdNewDynamicCtx (2048, NULL); if (out == NULL) return NULL; gdImagePngCtxEx (im, out, -1); rv = gdDPExtractData (out, size); out->gd_free (out); return rv; } /* Function: gdImagePngPtrEx Identical to except that it returns a pointer to a memory area with the PNG data. This memory must be freed by the caller when it is no longer needed. **The caller must invoke gdFree(), not free()** The 'size' parameter receives the total size of the block of memory. See for more information. Parameters: im - the image to save. size - Output: size in bytes of the result. level - compression level: 0 -> none, 1-9 -> level, -1 -> default Returns: A pointer to memory containing the image data or NULL on error. */ BGD_DECLARE(void *) gdImagePngPtrEx (gdImagePtr im, int *size, int level) { void *rv; gdIOCtx *out = gdNewDynamicCtx (2048, NULL); if (out == NULL) return NULL; gdImagePngCtxEx (im, out, level); rv = gdDPExtractData (out, size); out->gd_free (out); return rv; } /* Function: gdImagePngCtx Equivalent to calling with compression of -1. See for more information. Parameters: im - the image to save. outfile - the to write to. Returns: Nothing. */ BGD_DECLARE(void) gdImagePngCtx (gdImagePtr im, gdIOCtx * outfile) { /* 2.0.13: 'return' here was an error, thanks to Kevin Smith */ gdImagePngCtxEx (im, outfile, -1); } /* Function: gdImagePngCtxEx Outputs the given image as PNG data, but using a instead of a file. See . Parameters: im - the image to save. outfile - the to write to. level - compression level: 0 -> none, 1-9 -> level, -1 -> default Returns: Nothing. */ /* This routine is based in part on code from Dale Lutz (Safe Software Inc.) * and in part on demo code from Chapter 15 of "PNG: The Definitive Guide" * (http://www.libpng.org/pub/png/book/). */ BGD_DECLARE(void) gdImagePngCtxEx (gdImagePtr im, gdIOCtx * outfile, int level) { int i, j, bit_depth = 0, interlace_type; int width = im->sx; int height = im->sy; int colors = im->colorsTotal; int *open = im->open; int mapping[gdMaxColors]; /* mapping[gd_index] == png_index */ png_byte trans_values[256]; png_color_16 trans_rgb_value; png_color palette[gdMaxColors]; png_structp png_ptr; png_infop info_ptr; volatile int transparent = im->transparent; volatile int remap = FALSE; #ifdef PNG_SETJMP_SUPPORTED jmpbuf_wrapper jbw; #endif /* width or height of value 0 is invalid in IHDR; see http://www.w3.org/TR/PNG-Chunks.html */ if (width == 0 || height ==0) return; #ifdef PNG_SETJMP_SUPPORTED png_ptr = png_create_write_struct (PNG_LIBPNG_VER_STRING, &jbw, gdPngErrorHandler, NULL); #else png_ptr = png_create_write_struct (PNG_LIBPNG_VER_STRING, NULL, NULL, NULL); #endif if (png_ptr == NULL) { gd_error("gd-png error: cannot allocate libpng main struct\n"); return; } info_ptr = png_create_info_struct (png_ptr); if (info_ptr == NULL) { gd_error("gd-png error: cannot allocate libpng info struct\n"); png_destroy_write_struct (&png_ptr, (png_infopp) NULL); return; } #ifdef PNG_SETJMP_SUPPORTED if (setjmp(jbw.jmpbuf)) { gd_error("gd-png error: setjmp returns error condition\n"); png_destroy_write_struct (&png_ptr, &info_ptr); return; } #endif png_set_write_fn (png_ptr, (void *) outfile, gdPngWriteData, gdPngFlushData); /* This is best for palette images, and libpng defaults to it for palette images anyway, so we don't need to do it explicitly. What to ideally do for truecolor images depends, alas, on the image. gd is intentionally imperfect and doesn't spend a lot of time fussing with such things. */ /* Faster if this is uncommented, but may produce larger truecolor files. Wait for gdImagePngCtxEx. */ #if 0 png_set_filter (png_ptr, 0, PNG_FILTER_NONE); #endif /* 2.0.12: this is finally a parameter */ png_set_compression_level (png_ptr, level); #ifdef PNG_pHYs_SUPPORTED /* 2.1.0: specify the resolution */ png_set_pHYs(png_ptr, info_ptr, DPI2DPM(im->res_x), DPI2DPM(im->res_y), PNG_RESOLUTION_METER); #endif /* can set this to a smaller value without compromising compression if all * image data is 16K or less; will save some decoder memory [min == 8] */ /* png_set_compression_window_bits(png_ptr, 15); */ if (!im->trueColor) { if (transparent >= im->colorsTotal || (transparent >= 0 && open[transparent])) transparent = -1; } if (!im->trueColor) { for (i = 0; i < gdMaxColors; ++i) mapping[i] = -1; } if (!im->trueColor) { /* count actual number of colors used (colorsTotal == high-water mark) */ colors = 0; for (i = 0; i < im->colorsTotal; ++i) { if (!open[i]) { mapping[i] = colors; ++colors; } } if (colors == 0) { gd_error("gd-png error: no colors in palette\n"); goto bail; } if (colors < im->colorsTotal) { remap = TRUE; } if (colors <= 2) bit_depth = 1; else if (colors <= 4) bit_depth = 2; else if (colors <= 16) bit_depth = 4; else bit_depth = 8; } interlace_type = im->interlace ? PNG_INTERLACE_ADAM7 : PNG_INTERLACE_NONE; if (im->trueColor) { if (im->saveAlphaFlag) { png_set_IHDR (png_ptr, info_ptr, width, height, 8, PNG_COLOR_TYPE_RGB_ALPHA, interlace_type, PNG_COMPRESSION_TYPE_DEFAULT, PNG_FILTER_TYPE_DEFAULT); } else { png_set_IHDR (png_ptr, info_ptr, width, height, 8, PNG_COLOR_TYPE_RGB, interlace_type, PNG_COMPRESSION_TYPE_DEFAULT, PNG_FILTER_TYPE_DEFAULT); } } else { png_set_IHDR (png_ptr, info_ptr, width, height, bit_depth, PNG_COLOR_TYPE_PALETTE, interlace_type, PNG_COMPRESSION_TYPE_DEFAULT, PNG_FILTER_TYPE_DEFAULT); } if (im->trueColor && (!im->saveAlphaFlag) && (transparent >= 0)) { /* 2.0.9: fixed by Thomas Winzig */ trans_rgb_value.red = gdTrueColorGetRed (im->transparent); trans_rgb_value.green = gdTrueColorGetGreen (im->transparent); trans_rgb_value.blue = gdTrueColorGetBlue (im->transparent); png_set_tRNS (png_ptr, info_ptr, 0, 0, &trans_rgb_value); } if (!im->trueColor) { /* Oy veh. Remap the PNG palette to put the entries with interesting alpha channel values first. This minimizes the size of the tRNS chunk and thus the size of the PNG file as a whole. */ int tc = 0; int i; int j; int k; for (i = 0; (i < im->colorsTotal); i++) { if ((!im->open[i]) && (im->alpha[i] != gdAlphaOpaque)) { tc++; } } if (tc) { #if 0 for (i = 0; (i < im->colorsTotal); i++) { trans_values[i] = 255 - ((im->alpha[i] << 1) + (im->alpha[i] >> 6)); } png_set_tRNS (png_ptr, info_ptr, trans_values, 256, NULL); #endif if (!remap) { remap = TRUE; } /* (Semi-)transparent indexes come up from the bottom of the list of real colors; opaque indexes come down from the top */ j = 0; k = colors - 1; for (i = 0; (i < im->colorsTotal); i++) { if (!im->open[i]) { if (im->alpha[i] != gdAlphaOpaque) { /* Andrew Hull: >> 6, not >> 7! (gd 2.0.5) */ trans_values[j] = 255 - ((im->alpha[i] << 1) + (im->alpha[i] >> 6)); mapping[i] = j++; } else { mapping[i] = k--; } } } png_set_tRNS (png_ptr, info_ptr, trans_values, tc, NULL); } } /* convert palette to libpng layout */ if (!im->trueColor) { if (remap) for (i = 0; i < im->colorsTotal; ++i) { if (mapping[i] < 0) continue; palette[mapping[i]].red = im->red[i]; palette[mapping[i]].green = im->green[i]; palette[mapping[i]].blue = im->blue[i]; } else for (i = 0; i < colors; ++i) { palette[i].red = im->red[i]; palette[i].green = im->green[i]; palette[i].blue = im->blue[i]; } png_set_PLTE (png_ptr, info_ptr, palette, colors); } /* write out the PNG header info (everything up to first IDAT) */ png_write_info (png_ptr, info_ptr); /* make sure < 8-bit images are packed into pixels as tightly as possible */ png_set_packing (png_ptr); /* This code allocates a set of row buffers and copies the gd image data * into them only in the case that remapping is necessary; in gd 1.3 and * later, the im->pixels array is laid out identically to libpng's row * pointers and can be passed to png_write_image() function directly. * The remapping case could be accomplished with less memory for non- * interlaced images, but interlacing causes some serious complications. */ if (im->trueColor) { /* performance optimizations by Phong Tran */ int channels = im->saveAlphaFlag ? 4 : 3; /* Our little 7-bit alpha channel trick costs us a bit here. */ png_bytep *row_pointers; unsigned char *pOutputRow; int **ptpixels = im->tpixels; int *pThisRow; unsigned char a; int thisPixel; png_bytep *prow_pointers; int saveAlphaFlag = im->saveAlphaFlag; if (overflow2(sizeof (png_bytep), height)) { goto bail; } row_pointers = gdMalloc (sizeof (png_bytep) * height); if (row_pointers == NULL) { gd_error("gd-png error: unable to allocate row_pointers\n"); goto bail; } prow_pointers = row_pointers; for (j = 0; j < height; ++j) { if (overflow2(width, channels) || ((*prow_pointers = (png_bytep) gdMalloc (width * channels)) == NULL)) { gd_error("gd-png error: unable to allocate rows\n"); for (i = 0; i < j; ++i) gdFree (row_pointers[i]); /* 2.0.29: memory leak TBB */ gdFree(row_pointers); goto bail; } pOutputRow = *prow_pointers++; pThisRow = *ptpixels++; for (i = 0; i < width; ++i) { thisPixel = *pThisRow++; *pOutputRow++ = gdTrueColorGetRed (thisPixel); *pOutputRow++ = gdTrueColorGetGreen (thisPixel); *pOutputRow++ = gdTrueColorGetBlue (thisPixel); if (saveAlphaFlag) { /* convert the 7-bit alpha channel to an 8-bit alpha channel. We do a little bit-flipping magic, repeating the MSB as the LSB, to ensure that 0 maps to 0 and 127 maps to 255. We also have to invert to match PNG's convention in which 255 is opaque. */ a = gdTrueColorGetAlpha (thisPixel); /* Andrew Hull: >> 6, not >> 7! (gd 2.0.5) */ *pOutputRow++ = 255 - ((a << 1) + (a >> 6)); } } } png_write_image (png_ptr, row_pointers); png_write_end (png_ptr, info_ptr); for (j = 0; j < height; ++j) gdFree (row_pointers[j]); gdFree (row_pointers); } else { if (remap) { png_bytep *row_pointers; if (overflow2(sizeof (png_bytep), height)) { goto bail; } row_pointers = gdMalloc (sizeof (png_bytep) * height); if (row_pointers == NULL) { gd_error("gd-png error: unable to allocate row_pointers\n"); goto bail; } for (j = 0; j < height; ++j) { if ((row_pointers[j] = (png_bytep) gdMalloc (width)) == NULL) { gd_error("gd-png error: unable to allocate rows\n"); for (i = 0; i < j; ++i) gdFree (row_pointers[i]); /* TBB: memory leak */ gdFree (row_pointers); goto bail; } for (i = 0; i < width; ++i) row_pointers[j][i] = mapping[im->pixels[j][i]]; } png_write_image (png_ptr, row_pointers); png_write_end (png_ptr, info_ptr); for (j = 0; j < height; ++j) gdFree (row_pointers[j]); gdFree (row_pointers); } else { png_write_image (png_ptr, im->pixels); png_write_end (png_ptr, info_ptr); } } /* 1.6.3: maybe we should give that memory BACK! TBB */ bail: png_destroy_write_struct (&png_ptr, &info_ptr); } #endif /* HAVE_LIBPNG */ libgd-gd-2.1.1/src/gd_rotate.c000066400000000000000000000305631245535672000161070ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include "gd.h" #include "gd_intern.h" #include /* * Rotate function Added on 2003/12 * by Pierre-Alain Joye (pierre@php.net) **/ /* Begin rotate function */ #ifdef ROTATE_PI #undef ROTATE_PI #endif /* ROTATE_PI */ typedef int (BGD_STDCALL *FuncPtr)(gdImagePtr, int, int); #define ROTATE_DEG2RAD 3.1415926535897932384626433832795/180 void gdImageSkewX (gdImagePtr dst, gdImagePtr src, int uRow, int iOffset, double dWeight, int clrBack, int ignoretransparent) { int i, r, g, b, a, clrBackR, clrBackG, clrBackB, clrBackA; FuncPtr f; int pxlOldLeft, pxlLeft=0, pxlSrc; /* Keep clrBack as color index if required */ if (src->trueColor) { pxlOldLeft = clrBack; f = gdImageGetTrueColorPixel; } else { pxlOldLeft = clrBack; clrBackR = gdImageRed(src, clrBack); clrBackG = gdImageGreen(src, clrBack); clrBackB = gdImageBlue(src, clrBack); clrBackA = gdImageAlpha(src, clrBack); clrBack = gdTrueColorAlpha(clrBackR, clrBackG, clrBackB, clrBackA); f = gdImageGetPixel; } for (i = 0; i < iOffset; i++) { gdImageSetPixel (dst, i, uRow, clrBack); } if (i < dst->sx) { gdImageSetPixel (dst, i, uRow, clrBack); } for (i = 0; i < src->sx; i++) { pxlSrc = f (src,i,uRow); r = (int)(gdImageRed(src,pxlSrc) * dWeight); g = (int)(gdImageGreen(src,pxlSrc) * dWeight); b = (int)(gdImageBlue(src,pxlSrc) * dWeight); a = (int)(gdImageAlpha(src,pxlSrc) * dWeight); pxlLeft = gdImageColorAllocateAlpha(src, r, g, b, a); if (pxlLeft == -1) { pxlLeft = gdImageColorClosestAlpha(src, r, g, b, a); } r = gdImageRed(src,pxlSrc) - (gdImageRed(src,pxlLeft) - gdImageRed(src,pxlOldLeft)); g = gdImageGreen(src,pxlSrc) - (gdImageGreen(src,pxlLeft) - gdImageGreen(src,pxlOldLeft)); b = gdImageBlue(src,pxlSrc) - (gdImageBlue(src,pxlLeft) - gdImageBlue(src,pxlOldLeft)); a = gdImageAlpha(src,pxlSrc) - (gdImageAlpha(src,pxlLeft) - gdImageAlpha(src,pxlOldLeft)); if (r>255) { r = 255; } if (g>255) { g = 255; } if (b>255) { b = 255; } if (a>127) { a = 127; } if (ignoretransparent && pxlSrc == dst->transparent) { pxlSrc = dst->transparent; } else { pxlSrc = gdImageColorAllocateAlpha(dst, r, g, b, a); if (pxlSrc == -1) { pxlSrc = gdImageColorClosestAlpha(dst, r, g, b, a); } } if ((i + iOffset >= 0) && (i + iOffset < dst->sx)) { gdImageSetPixel (dst, i+iOffset, uRow, pxlSrc); } pxlOldLeft = pxlLeft; } i += iOffset; if (i < dst->sx) { gdImageSetPixel (dst, i, uRow, pxlLeft); } gdImageSetPixel (dst, iOffset, uRow, clrBack); i--; while (++i < dst->sx) { gdImageSetPixel (dst, i, uRow, clrBack); } } void gdImageSkewY (gdImagePtr dst, gdImagePtr src, int uCol, int iOffset, double dWeight, int clrBack, int ignoretransparent) { int i, iYPos=0, r, g, b, a; FuncPtr f; int pxlOldLeft, pxlLeft=0, pxlSrc; if (src->trueColor) { f = gdImageGetTrueColorPixel; } else { f = gdImageGetPixel; } for (i = 0; i<=iOffset; i++) { gdImageSetPixel (dst, uCol, i, clrBack); } r = (int)((double)gdImageRed(src,clrBack) * dWeight); g = (int)((double)gdImageGreen(src,clrBack) * dWeight); b = (int)((double)gdImageBlue(src,clrBack) * dWeight); a = (int)((double)gdImageAlpha(src,clrBack) * dWeight); pxlOldLeft = gdImageColorAllocateAlpha(dst, r, g, b, a); for (i = 0; i < src->sy; i++) { pxlSrc = f (src, uCol, i); iYPos = i + iOffset; r = (int)((double)gdImageRed(src,pxlSrc) * dWeight); g = (int)((double)gdImageGreen(src,pxlSrc) * dWeight); b = (int)((double)gdImageBlue(src,pxlSrc) * dWeight); a = (int)((double)gdImageAlpha(src,pxlSrc) * dWeight); pxlLeft = gdImageColorAllocateAlpha(src, r, g, b, a); if (pxlLeft == -1) { pxlLeft = gdImageColorClosestAlpha(src, r, g, b, a); } r = gdImageRed(src,pxlSrc) - (gdImageRed(src,pxlLeft) - gdImageRed(src,pxlOldLeft)); g = gdImageGreen(src,pxlSrc) - (gdImageGreen(src,pxlLeft) - gdImageGreen(src,pxlOldLeft)); b = gdImageBlue(src,pxlSrc) - (gdImageBlue(src,pxlLeft) - gdImageBlue(src,pxlOldLeft)); a = gdImageAlpha(src,pxlSrc) - (gdImageAlpha(src,pxlLeft) - gdImageAlpha(src,pxlOldLeft)); if (r>255) { r = 255; } if (g>255) { g = 255; } if (b>255) { b = 255; } if (a>127) { a = 127; } if (ignoretransparent && pxlSrc == dst->transparent) { pxlSrc = dst->transparent; } else { pxlSrc = gdImageColorAllocateAlpha(dst, r, g, b, a); if (pxlSrc == -1) { pxlSrc = gdImageColorClosestAlpha(dst, r, g, b, a); } } if ((iYPos >= 0) && (iYPos < dst->sy)) { gdImageSetPixel (dst, uCol, iYPos, pxlSrc); } pxlOldLeft = pxlLeft; } i = iYPos; if (i < dst->sy) { gdImageSetPixel (dst, uCol, i, pxlLeft); } i--; while (++i < dst->sy) { gdImageSetPixel (dst, uCol, i, clrBack); } } /* Rotates an image by 90 degrees (counter clockwise) */ gdImagePtr gdImageRotate90 (gdImagePtr src, int ignoretransparent) { int uY, uX; int c,r,g,b,a; gdImagePtr dst; FuncPtr f; if (src->trueColor) { f = gdImageGetTrueColorPixel; } else { f = gdImageGetPixel; } dst = gdImageCreateTrueColor(src->sy, src->sx); if (dst != NULL) { int old_blendmode = dst->alphaBlendingFlag; dst->alphaBlendingFlag = 0; dst->transparent = src->transparent; gdImagePaletteCopy (dst, src); for (uY = 0; uYsy; uY++) { for (uX = 0; uXsx; uX++) { c = f (src, uX, uY); if (!src->trueColor) { r = gdImageRed(src,c); g = gdImageGreen(src,c); b = gdImageBlue(src,c); a = gdImageAlpha(src,c); c = gdTrueColorAlpha(r, g, b, a); } if (ignoretransparent && c == dst->transparent) { gdImageSetPixel(dst, uY, (dst->sy - uX - 1), dst->transparent); } else { gdImageSetPixel(dst, uY, (dst->sy - uX - 1), c); } } } dst->alphaBlendingFlag = old_blendmode; } return dst; } /* Rotates an image by 180 degrees (counter clockwise) */ gdImagePtr gdImageRotate180 (gdImagePtr src, int ignoretransparent) { int uY, uX; int c,r,g,b,a; gdImagePtr dst; FuncPtr f; if (src->trueColor) { f = gdImageGetTrueColorPixel; } else { f = gdImageGetPixel; } dst = gdImageCreateTrueColor(src->sx, src->sy); if (dst != NULL) { int old_blendmode = dst->alphaBlendingFlag; dst->alphaBlendingFlag = 0; dst->transparent = src->transparent; gdImagePaletteCopy (dst, src); for (uY = 0; uYsy; uY++) { for (uX = 0; uXsx; uX++) { c = f (src, uX, uY); if (!src->trueColor) { r = gdImageRed(src,c); g = gdImageGreen(src,c); b = gdImageBlue(src,c); a = gdImageAlpha(src,c); c = gdTrueColorAlpha(r, g, b, a); } if (ignoretransparent && c == dst->transparent) { gdImageSetPixel(dst, (dst->sx - uX - 1), (dst->sy - uY - 1), dst->transparent); } else { gdImageSetPixel(dst, (dst->sx - uX - 1), (dst->sy - uY - 1), c); } } } dst->alphaBlendingFlag = old_blendmode; } return dst; } /* Rotates an image by 270 degrees (counter clockwise) */ gdImagePtr gdImageRotate270 (gdImagePtr src, int ignoretransparent) { int uY, uX; int c,r,g,b,a; gdImagePtr dst; FuncPtr f; if (src->trueColor) { f = gdImageGetTrueColorPixel; } else { f = gdImageGetPixel; } dst = gdImageCreateTrueColor (src->sy, src->sx); if (dst != NULL) { int old_blendmode = dst->alphaBlendingFlag; dst->alphaBlendingFlag = 0; dst->transparent = src->transparent; gdImagePaletteCopy (dst, src); for (uY = 0; uYsy; uY++) { for (uX = 0; uXsx; uX++) { c = f (src, uX, uY); if (!src->trueColor) { r = gdImageRed(src,c); g = gdImageGreen(src,c); b = gdImageBlue(src,c); a = gdImageAlpha(src,c); c = gdTrueColorAlpha(r, g, b, a); } if (ignoretransparent && c == dst->transparent) { gdImageSetPixel(dst, (dst->sx - uY - 1), uX, dst->transparent); } else { gdImageSetPixel(dst, (dst->sx - uY - 1), uX, c); } } } dst->alphaBlendingFlag = old_blendmode; } return dst; } gdImagePtr gdImageRotate45 (gdImagePtr src, double dAngle, int clrBack, int ignoretransparent) { gdImagePtr dst1,dst2,dst3; double dRadAngle, dSinE, dTan, dShear; double dOffset; /* Variable skew offset */ int u, iShear, newx, newy; int clrBackR, clrBackG, clrBackB, clrBackA; /* See GEMS I for the algorithm details */ dRadAngle = dAngle * ROTATE_DEG2RAD; /* Angle in radians */ dSinE = sin (dRadAngle); dTan = tan (dRadAngle / 2.0); newx = (int)(src->sx + src->sy * fabs(dTan)); newy = src->sy; /* 1st shear */ dst1 = gdImageCreateTrueColor(newx, newy); /******* Perform 1st shear (horizontal) ******/ if (dst1 == NULL) { return NULL; } #ifdef HAVE_GD_BUNDLED dst1->alphaBlendingFlag = gdEffectReplace; #else gdImageAlphaBlending(dst1, 0); #endif if (dAngle == 0.0) { /* Returns copy of src */ gdImageCopy (dst1, src,0,0,0,0,src->sx,src->sy); return dst1; } gdImagePaletteCopy (dst1, src); if (ignoretransparent) { if (gdImageTrueColor(src)) { dst1->transparent = src->transparent; } else { dst1->transparent = gdTrueColorAlpha(gdImageRed(src, src->transparent), gdImageBlue(src, src->transparent), gdImageGreen(src, src->transparent), 127); } } for (u = 0; u < dst1->sy; u++) { if (dTan >= 0.0) { dShear = ((double)(u + 0.5)) * dTan; } else { dShear = ((double)(u - dst1->sy) + 0.5) * dTan; } iShear = (int)floor(dShear); gdImageSkewX(dst1, src, u, iShear, (dShear - iShear), clrBack, ignoretransparent); } /* The 1st shear may use the original clrBack as color index Convert it once here */ if(!src->trueColor) { clrBackR = gdImageRed(src, clrBack); clrBackG = gdImageGreen(src, clrBack); clrBackB = gdImageBlue(src, clrBack); clrBackA = gdImageAlpha(src, clrBack); clrBack = gdTrueColorAlpha(clrBackR, clrBackG, clrBackB, clrBackA); } /* 2nd shear */ newx = dst1->sx; if (dSinE > 0.0) { dOffset = (src->sx-1) * dSinE; } else { dOffset = -dSinE * (src->sx - newx); } newy = (int) ((double) src->sx * fabs( dSinE ) + (double) src->sy * cos (dRadAngle))+1; dst2 = gdImageCreateTrueColor(newx, newy); if (dst2 == NULL) { gdImageDestroy(dst1); return NULL; } #ifdef HAVE_GD_BUNDLED dst2->alphaBlendingFlag = gdEffectReplace; #else gdImageAlphaBlending(dst2, 0); #endif if (ignoretransparent) { dst2->transparent = dst1->transparent; } for (u = 0; u < dst2->sx; u++, dOffset -= dSinE) { iShear = (int)floor (dOffset); gdImageSkewY(dst2, dst1, u, iShear, (dOffset - (double)iShear), clrBack, ignoretransparent); } /* 3rd shear */ gdImageDestroy(dst1); newx = (int) ((double)src->sy * fabs (dSinE) + (double)src->sx * cos (dRadAngle)) + 1; newy = dst2->sy; dst3 = gdImageCreateTrueColor(newx, newy); if (dst3 == NULL) { gdImageDestroy(dst2); return NULL; } #ifdef HAVE_GD_BUNDLED dst3->alphaBlendingFlag = gdEffectReplace; #else gdImageAlphaBlending(dst3, 0); #endif if (ignoretransparent) { dst3->transparent = dst2->transparent; } if (dSinE >= 0.0) { dOffset = (double)(src->sx - 1) * dSinE * -dTan; } else { dOffset = dTan * ((double)(src->sx - 1) * -dSinE + (double)(1 - newy)); } for (u = 0; u < dst3->sy; u++, dOffset += dTan) { int iShear = (int)floor(dOffset); gdImageSkewX(dst3, dst2, u, iShear, (dOffset - iShear), clrBack, ignoretransparent); } gdImageDestroy(dst2); return dst3; } gdImagePtr gdImageRotate (gdImagePtr src, double dAngle, int clrBack, int ignoretransparent) { gdImagePtr pMidImg; gdImagePtr rotatedImg; if (src == NULL) { return NULL; } if (!gdImageTrueColor(src) && (clrBack < 0 || clrBack>=gdImageColorsTotal(src))) { return NULL; } while (dAngle >= 360.0) { dAngle -= 360.0; } while (dAngle < 0) { dAngle += 360.0; } if (dAngle == 90.00) { return gdImageRotate90(src, ignoretransparent); } if (dAngle == 180.00) { return gdImageRotate180(src, ignoretransparent); } if(dAngle == 270.00) { return gdImageRotate270 (src, ignoretransparent); } if ((dAngle > 45.0) && (dAngle <= 135.0)) { pMidImg = gdImageRotate90 (src, ignoretransparent); dAngle -= 90.0; } else if ((dAngle > 135.0) && (dAngle <= 225.0)) { pMidImg = gdImageRotate180 (src, ignoretransparent); dAngle -= 180.0; } else if ((dAngle > 225.0) && (dAngle <= 315.0)) { pMidImg = gdImageRotate270 (src, ignoretransparent); dAngle -= 270.0; } else { return gdImageRotate45 (src, dAngle, clrBack, ignoretransparent); } if (pMidImg == NULL) { return NULL; } rotatedImg = gdImageRotate45 (pMidImg, dAngle, clrBack, ignoretransparent); gdImageDestroy(pMidImg); return rotatedImg; } /* End Rotate function */ libgd-gd-2.1.1/src/gd_security.c000066400000000000000000000012641245535672000164540ustar00rootroot00000000000000/* * gd_security.c * * Implements buffer overflow check routines. * * Written 2004, Phil Knirsch. * Based on netpbm fixes by Alan Cox. * */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include "gd.h" #include "gd_errors.h" int overflow2(int a, int b) { if(a <= 0 || b <= 0) { gd_error_ex(GD_WARNING, "one parameter to a memory allocation multiplication is negative or zero, failing operation gracefully\n"); return 1; } if(a > INT_MAX / b) { gd_error_ex(GD_WARNING, "product of memory allocation multiplication would exceed INT_MAX, failing operation gracefully\n"); return 1; } return 0; } libgd-gd-2.1.1/src/gd_ss.c000066400000000000000000000023671245535672000152370ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include #include "gd.h" #include "gd_errors.h" #define TRUE 1 #define FALSE 0 /* Use this for commenting out debug-print statements. */ /* Just use the first '#define' to allow all the prints... */ /*#define GD_SS_DBG(s) (s) */ #define GD_SS_DBG(s) #ifdef HAVE_LIBPNG BGD_DECLARE(void) gdImagePngToSink (gdImagePtr im, gdSinkPtr outSink) { gdIOCtx *out = gdNewSSCtx (NULL, outSink); gdImagePngCtx (im, out); out->gd_free (out); } /* Function: gdImageCreateFromPngSource See for documentation. This is obsolete; use instead. */ BGD_DECLARE(gdImagePtr) gdImageCreateFromPngSource (gdSourcePtr inSource) { gdIOCtx *in = gdNewSSCtx (inSource, NULL); gdImagePtr im; im = gdImageCreateFromPngCtx (in); in->gd_free (in); return im; } #else /* no HAVE_LIBPNG */ BGD_DECLARE(void) gdImagePngToSink (gdImagePtr im, gdSinkPtr outSink) { (void)im; (void)outSink; gd_error("PNG support is not available\n"); } BGD_DECLARE(gdImagePtr) gdImageCreateFromPngSource (gdSourcePtr inSource) { (void)inSource; gd_error("PNG support is not available\n"); return NULL; } #endif /* HAVE_LIBPNG */ libgd-gd-2.1.1/src/gd_tga.c000066400000000000000000000210231245535672000153530ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include #include #include #include #include "gd_tga.h" #include "gd.h" #include "gd_errors.h" #include "gdhelpers.h" /*! \brief Creates a gdImage from a TGA file * Creates a gdImage from a TGA binary file via a gdIOCtx. * \param infile Pointer to TGA binary file * \return gdImagePtr */ BGD_DECLARE(gdImagePtr) gdImageCreateFromTga(FILE *fp) { gdImagePtr image; gdIOCtx* in = gdNewFileCtx(fp); if (in == NULL) return NULL; image = gdImageCreateFromTgaCtx(in); in->gd_free( in ); return image; } BGD_DECLARE(gdImagePtr) gdImageCreateFromTgaPtr(int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx (size, data, 0); if (in == NULL) return NULL; im = gdImageCreateFromTgaCtx(in); in->gd_free(in); return im; } /*! \brief Creates a gdImage from a gdIOCtx * Creates a gdImage from a gdIOCtx referencing a TGA binary file. * \param ctx Pointer to a gdIOCtx structure * \return gdImagePtr */ BGD_DECLARE(gdImagePtr) gdImageCreateFromTgaCtx(gdIOCtx* ctx) { int bitmap_caret = 0; oTga *tga = NULL; /* int pixel_block_size = 0; int image_block_size = 0; */ volatile gdImagePtr image = NULL; int x = 0; int y = 0; tga = (oTga *) gdMalloc(sizeof(oTga)); if (!tga) { return NULL; } tga->bitmap = NULL; tga->ident = NULL; if (!read_header_tga(ctx, tga)) { free_tga(tga); return NULL; } /*TODO: Will this be used? pixel_block_size = tga->bits / 8; image_block_size = (tga->width * tga->height) * pixel_block_size; */ if (read_image_tga(ctx, tga)) { free_tga(tga); return NULL; } image = gdImageCreateTrueColor((int)tga->width, (int)tga->height ); if (image == 0) { free_tga( tga ); return NULL; } /*! \brief Populate GD image object * Copy the pixel data from our tga bitmap buffer into the GD image * Disable blending and save the alpha channel per default */ if (tga->alphabits) { gdImageAlphaBlending(image, 0); gdImageSaveAlpha(image, 1); } /* TODO: use alphabits as soon as we support 24bit and other alpha bps (ie != 8bits) */ for (y = 0; y < tga->height; y++) { register int *tpix = image->tpixels[y]; for ( x = 0; x < tga->width; x++, tpix++) { if (tga->bits == TGA_BPP_24) { *tpix = gdTrueColor(tga->bitmap[bitmap_caret + 2], tga->bitmap[bitmap_caret + 1], tga->bitmap[bitmap_caret]); bitmap_caret += 3; } else if (tga->bits == TGA_BPP_32 || tga->alphabits) { register int a = tga->bitmap[bitmap_caret + 3]; *tpix = gdTrueColorAlpha(tga->bitmap[bitmap_caret + 2], tga->bitmap[bitmap_caret + 1], tga->bitmap[bitmap_caret], gdAlphaMax - (a >> 1)); bitmap_caret += 4; } } } if (tga->flipv && tga->fliph) { gdImageFlipBoth(image); } else if (tga->flipv) { gdImageFlipVertical(image); } else if (tga->fliph) { gdImageFlipHorizontal(image); } free_tga(tga); return image; } /*! \brief Reads a TGA header. * Reads the header block from a binary TGA file populating the referenced TGA structure. * \param ctx Pointer to TGA binary file * \param tga Pointer to TGA structure * \return int 1 on sucess, -1 on failure */ int read_header_tga(gdIOCtx *ctx, oTga *tga) { unsigned char header[18]; if (gdGetBuf(header, sizeof(header), ctx) < 18) { gd_error("fail to read header"); return -1; } tga->identsize = header[0]; tga->colormaptype = header[1]; tga->imagetype = header[2]; tga->colormapstart = header[3] + (header[4] << 8); tga->colormaplength = header[5] + (header[6] << 8); tga->colormapbits = header[7]; tga->xstart = header[8] + (header[9] << 8); tga->ystart = header[10] + (header[11] << 8); tga->width = header[12] + (header[13] << 8); tga->height = header[14] + (header[15] << 8); tga->bits = header[16]; tga->alphabits = header[17] & 0x0f; tga->fliph = (header[17] & 0x10) ? 1 : 0; tga->flipv = (header[17] & 0x20) ? 0 : 1; #if DEBUG printf("format bps: %i\n", tga->bits); printf("flip h/v: %i / %i\n", tga->fliph, tga->flipv); printf("alpha: %i\n", tga->alphabits); printf("wxh: %i %i\n", tga->width, tga->height); #endif switch(tga->bits) { case 8: case 16: case 24: case 32: break; default: gd_error("bps %i not supported", tga->bits); return -1; break; } tga->ident = NULL; if (tga->identsize > 0) { tga->ident = (char *) gdMalloc(tga->identsize * sizeof(char)); if(tga->ident == NULL) { return -1; } gdGetBuf( &( tga->ident ), tga->identsize, ctx ); } return 1; } /*! \brief Reads a TGA image data into buffer. * Reads the image data block from a binary TGA file populating the referenced TGA structure. * \param ctx Pointer to TGA binary file * \param tga Pointer to TGA structure * \return int 0 on sucess, -1 on failure */ int read_image_tga( gdIOCtx *ctx, oTga *tga ) { int pixel_block_size = (tga->bits / 8); int image_block_size = (tga->width * tga->height) * pixel_block_size; uint8_t* decompression_buffer = NULL; unsigned char* conversion_buffer = NULL; int buffer_caret = 0; int bitmap_caret = 0; int i = 0; int j = 0; uint8_t encoded_pixels; if(overflow2(tga->width, tga->height)) { return -1; } if(overflow2(tga->width * tga->height, pixel_block_size)) { return -1; } if(overflow2(image_block_size, sizeof(uint8_t))) { return -1; } /*! \brief Allocate memmory for image block * Allocate a chunk of memory for the image block to be passed into. */ tga->bitmap = (int *) gdMalloc(image_block_size * sizeof(uint8_t)); if (tga->bitmap == NULL) { return -1; } /*! \todo Add image type support * Add support for this image type. */ if (tga->imagetype == TGA_TYPE_INDEXED) { return -1; } /*! \todo Add image type support * Add support for this image type. */ if (tga->imagetype == TGA_TYPE_INDEXED_RLE) { return -1; } /*! \brief Read in uncompressed RGB TGA * Chunk load the pixel data from an uncompressed RGB type TGA. */ if (tga->imagetype == TGA_TYPE_RGB) { conversion_buffer = (unsigned char *) gdMalloc(image_block_size * sizeof(unsigned char)); if (conversion_buffer == NULL) { gdFree(conversion_buffer); return -1; } gdGetBuf(conversion_buffer, image_block_size, ctx); while (buffer_caret < image_block_size) { tga->bitmap[buffer_caret] = (int) conversion_buffer[buffer_caret]; buffer_caret++; } gdFree( conversion_buffer ); } /*! \brief Read in RLE compressed RGB TGA * Chunk load the pixel data from an RLE compressed RGB type TGA. */ if (tga->imagetype == TGA_TYPE_RGB_RLE) { decompression_buffer = (uint8_t*) gdMalloc(image_block_size * sizeof(uint8_t)); if (decompression_buffer == NULL) { gdFree( decompression_buffer ); return -1; } conversion_buffer = (unsigned char *) gdMalloc(image_block_size * sizeof(unsigned char)); if (conversion_buffer == NULL) { gdFree( decompression_buffer ); gdFree( conversion_buffer ); return -1; } gdGetBuf( conversion_buffer, image_block_size, ctx ); buffer_caret = 0; while( buffer_caret < image_block_size ) { decompression_buffer[buffer_caret] = (int)conversion_buffer[buffer_caret]; buffer_caret++; } buffer_caret = 0; while( bitmap_caret < image_block_size ) { if ((decompression_buffer[buffer_caret] & TGA_RLE_FLAG) == TGA_RLE_FLAG) { encoded_pixels = ( ( decompression_buffer[ buffer_caret ] & 127 ) + 1 ); buffer_caret++; for (i = 0; i < encoded_pixels; i++) { for (j = 0; j < pixel_block_size; j++, bitmap_caret++) { tga->bitmap[ bitmap_caret ] = decompression_buffer[ buffer_caret + j ]; } } buffer_caret += pixel_block_size; } else { encoded_pixels = decompression_buffer[ buffer_caret ] + 1; buffer_caret++; for (i = 0; i < encoded_pixels; i++) { for( j = 0; j < pixel_block_size; j++, bitmap_caret++ ) { tga->bitmap[ bitmap_caret ] = decompression_buffer[ buffer_caret + j ]; } buffer_caret += pixel_block_size; } } } gdFree( decompression_buffer ); gdFree( conversion_buffer ); } /*! \todo Add image type support * Add support for this image type. */ if( tga->imagetype == TGA_TYPE_GREYSCALE ) { return -1; } /*! \todo Add image type support * Add support for this image type. */ if( tga->imagetype == TGA_TYPE_GREYSCALE_RLE ) { return -1; } return 0; } /*! \brief Cleans up a TGA structure. * Dereferences the bitmap referenced in a TGA structure, then the structure itself * \param tga Pointer to TGA structure */ void free_tga(oTga * tga) { if (tga) { if (tga->ident) { gdFree(tga->ident); tga->ident = NULL; } if (tga->bitmap) { gdFree(tga->bitmap); tga->bitmap = NULL; } gdFree(tga); tga = NULL; } } libgd-gd-2.1.1/src/gd_tga.h000066400000000000000000000032501245535672000153620ustar00rootroot00000000000000#ifndef __TGA_H #define __TGA_H 1 #include "gd.h" #include "gdhelpers.h" #include "gd_intern.h" typedef struct oTga_ { uint8_t identsize; // size of ID field that follows 18 uint8_t header (0 usually) uint8_t colormaptype; // type of colour map 0=none, 1=has palette [IGNORED] Adrian requested no support uint8_t imagetype; // type of image 0=none,1=indexed,2=rgb,3=grey,+8=rle packed int colormapstart; // first colour map entry in palette [IGNORED] Adrian requested no support int colormaplength; // number of colours in palette [IGNORED] Adrian requested no support uint8_t colormapbits; // number of bits per palette entry 15,16,24,32 [IGNORED] Adrian requested no support int xstart; // image x origin int ystart; // image y origin int width; // image width in pixels int height; // image height in pixels uint8_t bits; // image bits per pixel 8,16,24,32 uint8_t alphabits; // alpha bits (low 4bits of header 17) uint8_t fliph; // horizontal or vertical uint8_t flipv; // flip char *ident; // identifcation tag string int *bitmap; // bitmap data } oTga; #define TGA_TYPE_NO_IMAGE 0 #define TGA_TYPE_INDEXED 1 #define TGA_TYPE_RGB 2 #define TGA_TYPE_GREYSCALE 3 #define TGA_TYPE_INDEXED_RLE 9 #define TGA_TYPE_RGB_RLE 10 #define TGA_TYPE_GREYSCALE_RLE 11 #define TGA_TYPE_INDEXED_HUFFMAN_DELTA_RLE 32 #define TGA_TYPE_RGB_HUFFMAN_DELTA_QUADTREE_RLE 33 #define TGA_BPP_8 8 #define TGA_BPP_16 16 #define TGA_BPP_24 24 #define TGA_BPP_32 32 #define TGA_RLE_FLAG 128 int read_header_tga(gdIOCtx *ctx, oTga *tga); int read_image_tga(gdIOCtx *ctx, oTga *tga); void free_tga(oTga *tga); #endif //__TGA_H libgd-gd-2.1.1/src/gd_tiff.c000066400000000000000000000616711245535672000155450ustar00rootroot00000000000000/* TIFF - Tagged Image File Format Encapsulation for GD Library gd_tiff.c Copyright (C) Pierre-A. Joye, M. Retallack --------------------------------------------------------------------------- ** ** Permission to use, copy, modify, and distribute this software and its ** documentation for any purpose and without fee is hereby granted, provided ** that the above copyright notice appear in all copies and that both that ** copyright notice and this permission notice appear in supporting ** documentation. This software is provided "as is" without express or ** implied warranty. ** --------------------------------------------------------------------------- Ctx code written by M. Retallack Todo: If we fail - cleanup Writer: Use gd error function, overflow check may not be necessary as we write our own data (check already done) Implement 2 color black/white saving using group4 fax compression Implement function to specify encoding to use when writing tiff data ---------------------------------------------------------------------------- */ /* $Id$ */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include "gd.h" #include "gd_errors.h" #include "gdfonts.h" #include #include #include #include "gdhelpers.h" #ifdef HAVE_LIBTIFF #include "tiff.h" #include "tiffio.h" #define GD_SUCCESS 1 #define GD_FAILURE 0 #define TRUE 1 #define FALSE 0 /* I define those here until the new formats * are commited. We can then rely on the global * def */ #define GD_PALETTE 1 #define GD_TRUECOLOR 2 #define GD_GRAY 3 #define GD_INDEXED 4 #define GD_RGB 5 #define MIN(a,b) (a < b) ? a : b; #define MAX(a,b) (a > b) ? a : b; typedef struct tiff_handle { int size; int pos; gdIOCtx *ctx; int written; } tiff_handle; /* Functions for reading, writing and seeking in gdIOCtx This allows for non-file i/o operations with no explicit use of libtiff fileio wrapper functions Note: because libtiff requires random access, but gdIOCtx only supports streams, all writes are buffered into memory and written out on close, also all reads are done from a memory mapped version of the tiff (assuming one already exists) */ tiff_handle * new_tiff_handle(gdIOCtx *g) { tiff_handle * t; if (!g) { gd_error("Cannot create a new tiff handle, missing Ctx argument"); return NULL; } t = (tiff_handle *) gdMalloc(sizeof(tiff_handle)); if (!t) { gd_error("Failed to allocate a new tiff handle"); return NULL; } t->size = 0; t->pos = 0; t->ctx = g; t->written = 0; return t; } /* TIFFReadWriteProc tiff_readproc - Will use gdIOCtx procs to read required (previously written) TIFF file content */ static tsize_t tiff_readproc(thandle_t clientdata, tdata_t data, tsize_t size) { tiff_handle *th = (tiff_handle *)clientdata; gdIOCtx *ctx = th->ctx; size = (ctx->getBuf)(ctx, data, size); return size; } /* TIFFReadWriteProc tiff_writeproc - Will use gdIOCtx procs to write out TIFF data */ static tsize_t tiff_writeproc(thandle_t clientdata, tdata_t data, tsize_t size) { tiff_handle *th = (tiff_handle *)clientdata; gdIOCtx *ctx = th->ctx; size = (ctx->putBuf)(ctx, data, size); if(size + th->pos>th->size) { th->size = size + th->pos; th->pos += size; } return size; } /* TIFFSeekProc tiff_seekproc * used to move around the partially written TIFF */ static toff_t tiff_seekproc(thandle_t clientdata, toff_t offset, int from) { tiff_handle *th = (tiff_handle *)clientdata; gdIOCtx *ctx = th->ctx; int result; switch(from) { default: case SEEK_SET: /* just use offset */ break; case SEEK_END: /* invert offset, so that it is from start, not end as supplied */ offset = th->size + offset; break; case SEEK_CUR: /* add current position to translate it to 'from start', * not from durrent as supplied */ offset += th->pos; break; } /* now, move pos in both io context and buf */ if((result = (ctx->seek)(ctx, offset))) { th->pos = offset; } return result ? offset : (toff_t)-1; } /* TIFFCloseProc tiff_closeproc - used to finally close the TIFF file */ static int tiff_closeproc(thandle_t clientdata) { (void)clientdata; /*tiff_handle *th = (tiff_handle *)clientdata; gdIOCtx *ctx = th->ctx; (ctx->gd_free)(ctx);*/ return 0; } /* TIFFSizeProc tiff_sizeproc */ static toff_t tiff_sizeproc(thandle_t clientdata) { tiff_handle *th = (tiff_handle *)clientdata; return th->size; } /* TIFFMapFileProc tiff_mapproc() */ static int tiff_mapproc(thandle_t h, tdata_t *d, toff_t *o) { (void)h; (void)d; (void)o; return 0; } /* TIFFUnmapFileProc tiff_unmapproc */ static void tiff_unmapproc(thandle_t h, tdata_t d, toff_t o) { (void)h; (void)d; (void)o; } /* tiffWriter * ---------- * Write the gd image as a tiff file (called by gdImageTiffCtx) * Parameters are: * image: gd image structure; * out: the stream where to write * bitDepth: depth in bits of each pixel */ void tiffWriter(gdImagePtr image, gdIOCtx *out, int bitDepth) { int x, y; int i; int r, g, b, a; TIFF *tiff; int width, height; int color; char *scan; int samplesPerPixel = 3; int bitsPerSample; int transparentColorR = -1; int transparentColorG = -1; int transparentColorB = -1; uint16 extraSamples[1]; uint16 *colorMapRed = NULL; uint16 *colorMapGreen = NULL; uint16 *colorMapBlue = NULL; tiff_handle *th; th = new_tiff_handle(out); if (!th) { return; } extraSamples[0] = EXTRASAMPLE_ASSOCALPHA; /* read in the width/height of gd image */ width = gdImageSX(image); height = gdImageSY(image); /* reset clip region to whole image */ gdImageSetClip(image, 0, 0, width, height); /* handle old-style single-colour mapping to 100% transparency */ if(image->transparent != -1) { /* set our 100% transparent colour value */ transparentColorR = gdImageRed(image, image->transparent); transparentColorG = gdImageGreen(image, image->transparent); transparentColorB = gdImageBlue(image, image->transparent); } /* Open tiff file writing routines, but use special read/write/seek * functions so that tiff lib writes correct bits of tiff content to * correct areas of file opened and modifieable by the gdIOCtx functions */ tiff = TIFFClientOpen("", "w", th, tiff_readproc, tiff_writeproc, tiff_seekproc, tiff_closeproc, tiff_sizeproc, tiff_mapproc, tiff_unmapproc); TIFFSetField(tiff, TIFFTAG_IMAGEWIDTH, width); TIFFSetField(tiff, TIFFTAG_IMAGELENGTH, height); TIFFSetField(tiff, TIFFTAG_COMPRESSION, COMPRESSION_DEFLATE); TIFFSetField(tiff, TIFFTAG_PLANARCONFIG, PLANARCONFIG_CONTIG); TIFFSetField(tiff, TIFFTAG_PHOTOMETRIC, (bitDepth == 24) ? PHOTOMETRIC_RGB : PHOTOMETRIC_PALETTE); bitsPerSample = (bitDepth == 24 || bitDepth == 8) ? 8 : 1; TIFFSetField(tiff, TIFFTAG_BITSPERSAMPLE, bitsPerSample); /* build the color map for 8 bit images */ if(bitDepth != 24) { colorMapRed = (uint16 *) gdMalloc(3 * (1 << bitsPerSample)); if (!colorMapRed) { return; } colorMapGreen = (uint16 *) gdMalloc(3 * (1 << bitsPerSample)); if (!colorMapGreen) { gdFree(colorMapRed); return; } colorMapBlue = (uint16 *) gdMalloc(3 * (1 << bitsPerSample)); if (!colorMapBlue) { gdFree(colorMapRed); gdFree(colorMapGreen); return; } for(i = 0; i < image->colorsTotal; i++) { colorMapRed[i] = gdImageRed(image,i) + (gdImageRed(image,i) * 256); colorMapGreen[i] = gdImageGreen(image,i)+(gdImageGreen(image,i)*256); colorMapBlue[i] = gdImageBlue(image,i) + (gdImageBlue(image,i)*256); } TIFFSetField(tiff, TIFFTAG_COLORMAP, colorMapRed, colorMapGreen, colorMapBlue); samplesPerPixel = 1; } /* here, we check if the 'save alpha' flag is set on the source gd image */ if ((bitDepth == 24) && (image->saveAlphaFlag || image->transparent != -1)) { /* so, we need to store the alpha values too! * Also, tell TIFF what the extra sample means (associated alpha) */ samplesPerPixel = 4; TIFFSetField(tiff, TIFFTAG_SAMPLESPERPIXEL, samplesPerPixel); TIFFSetField(tiff, TIFFTAG_EXTRASAMPLES, 1, extraSamples); } else { TIFFSetField(tiff, TIFFTAG_SAMPLESPERPIXEL, samplesPerPixel); } TIFFSetField(tiff, TIFFTAG_ROWSPERSTRIP, 1); if(overflow2(width, samplesPerPixel)) { return; } if(!(scan = (char *)gdMalloc(width * samplesPerPixel))) { return; } /* loop through y-coords, and x-coords */ for(y = 0; y < height; y++) { for(x = 0; x < width; x++) { /* generate scan line for writing to tiff */ color = gdImageGetPixel(image, x, y); a = (127 - gdImageAlpha(image, color)) * 2; a = (a == 0xfe) ? 0xff : a & 0xff; b = gdImageBlue(image, color); g = gdImageGreen(image, color); r = gdImageRed(image, color); /* if this pixel has the same RGB as the transparent colour, * then set alpha fully transparent */ if (transparentColorR == r && transparentColorG == g && transparentColorB == b) { a = 0x00; } if(bitDepth != 24) { /* write out 1 or 8 bit value in 1 byte * (currently treats 1bit as 8bit) */ scan[(x * samplesPerPixel) + 0] = color; } else { /* write out 24 bit value in 3 (or 4 if transparent) bytes */ if(image->saveAlphaFlag || image->transparent != -1) { scan[(x * samplesPerPixel) + 3] = a; } scan[(x * samplesPerPixel) + 2] = b; scan[(x * samplesPerPixel) + 1] = g; scan[(x * samplesPerPixel) + 0] = r; } } /* Write the scan line to the tiff */ if(TIFFWriteEncodedStrip(tiff, y, scan, width * samplesPerPixel) == -1) { /* error handler here */ gd_error("Could not create TIFF\n"); return; } } /* now cloase and free up resources */ TIFFClose(tiff); gdFree(scan); gdFree(th); if(bitDepth != 24) { gdFree(colorMapRed); gdFree(colorMapGreen); gdFree(colorMapBlue); } } /* gdImageTiffCtx -------------- Write the gd image as a tiff file Parameters are: image: gd image structure; out: the stream where to write */ BGD_DECLARE(void) gdImageTiffCtx(gdImagePtr image, gdIOCtx *out) { int clipx1P, clipy1P, clipx2P, clipy2P; int bitDepth = 24; /* First, switch off clipping, or we'll not get all the image! */ gdImageGetClip(image, &clipx1P, &clipy1P, &clipx2P, &clipy2P); /* use the appropriate routine depending on the bit depth of the image */ if(image->trueColor) { bitDepth = 24; } else if(image->colorsTotal == 2) { bitDepth = 1; } else { bitDepth = 8; } tiffWriter(image, out, bitDepth); /* reset clipping area to the gd image's original values */ gdImageSetClip(image, clipx1P, clipy1P, clipx2P, clipy2P); } /* Check if we are really in 8bit mode */ static int checkColorMap(n, r, g, b) int n; uint16 *r, *g, *b; { while (n-- > 0) if (*r++ >= 256 || *g++ >= 256 || *b++ >= 256) return (16); return (8); } /* Read and convert a TIFF colormap */ static int readTiffColorMap(gdImagePtr im, TIFF *tif, char is_bw, int photometric) { uint16 *redcmap, *greencmap, *bluecmap; uint16 bps; int i; if (is_bw) { if (photometric == PHOTOMETRIC_MINISWHITE) { gdImageColorAllocate(im, 255,255,255); gdImageColorAllocate(im, 0, 0, 0); } else { gdImageColorAllocate(im, 0, 0, 0); gdImageColorAllocate(im, 255,255,255); } } else { uint16 min_sample_val, max_sample_val; if (!TIFFGetField(tif, TIFFTAG_MINSAMPLEVALUE, &min_sample_val)) { min_sample_val = 0; } if (!TIFFGetField(tif, TIFFTAG_MAXSAMPLEVALUE, &max_sample_val)) { max_sample_val = 255; } if (photometric == PHOTOMETRIC_MINISBLACK || photometric == PHOTOMETRIC_MINISWHITE) { /* TODO: use TIFFTAG_MINSAMPLEVALUE and TIFFTAG_MAXSAMPLEVALUE */ /* Gray level palette */ for (i=min_sample_val; i <= max_sample_val; i++) { gdImageColorAllocate(im, i,i,i); } return GD_SUCCESS; } else if (!TIFFGetField(tif, TIFFTAG_COLORMAP, &redcmap, &greencmap, &bluecmap)) { gd_error("Cannot read the color map"); return GD_FAILURE; } TIFFGetFieldDefaulted(tif, TIFFTAG_BITSPERSAMPLE, &bps); #define CVT(x) (((x) * 255) / ((1L<<16)-1)) if (checkColorMap(1< 0; i--) { redcmap[i] = CVT(redcmap[i]); greencmap[i] = CVT(greencmap[i]); bluecmap[i] = CVT(bluecmap[i]); } } for (i = 0; i < 256; i++) { gdImageColorAllocate(im, redcmap[i], greencmap[i], bluecmap[i]); } #undef CVT } return GD_SUCCESS; } static void readTiffBw (const unsigned char *src, gdImagePtr im, uint16 photometric, int startx, int starty, int width, int height, char has_alpha, int extra, int align) { int x = startx, y = starty; (void)has_alpha; (void)extra; (void)align; for (y = starty; y < starty + height; y++) { for (x = startx; x < startx + width; x++) { register unsigned char curr = *src++; register unsigned char mask; if (photometric == PHOTOMETRIC_MINISWHITE) { curr = ~curr; } for (mask = 0x80; mask != 0 && x < startx + width; mask >>= 1) { gdImageSetPixel(im, x, y, ((curr & mask) != 0)?0:1); } } } } static void readTiff8bit (const unsigned char *src, gdImagePtr im, uint16 photometric, int startx, int starty, int width, int height, char has_alpha, int extra, int align) { int red, green, blue, alpha; int x, y; (void)extra; (void)align; switch (photometric) { case PHOTOMETRIC_PALETTE: /* Palette has no alpha (see TIFF specs for more details */ for (y = starty; y < starty + height; y++) { for (x = startx; x < startx + width; x++) { gdImageSetPixel(im, x, y,*(src++)); } } break; case PHOTOMETRIC_RGB: if (has_alpha) { gdImageAlphaBlending(im, 0); gdImageSaveAlpha(im, 1); for (y = starty; y < starty + height; y++) { for (x = startx; x < startx + width; x++) { red = *src++; green = *src++; blue = *src++; alpha = *src++; red = MIN (red, alpha); blue = MIN (blue, alpha); green = MIN (green, alpha); if (alpha) { gdImageSetPixel(im, x, y, gdTrueColorAlpha(red * 255 / alpha, green * 255 / alpha, blue * 255 /alpha, gdAlphaMax - (alpha >> 1))); } else { gdImageSetPixel(im, x, y, gdTrueColorAlpha(red, green, blue, gdAlphaMax - (alpha >> 1))); } } } } else { for (y = 0; y < height; y++) { for (x = 0; x < width; x++) { register unsigned char r = *src++; register unsigned char g = *src++; register unsigned char b = *src++; gdImageSetPixel(im, x, y, gdTrueColor(r, g, b)); } } } break; case PHOTOMETRIC_MINISWHITE: if (has_alpha) { /* We don't process the extra yet */ } else { for (y = starty; y < starty + height; y++) { for (x = startx; x < startx + width; x++) { gdImageSetPixel(im, x, y, ~(*src++)); } } } break; case PHOTOMETRIC_MINISBLACK: if (has_alpha) { /* We don't process the extra yet */ } else { for (y = starty; y < height; y++) { for (x = 0; x < width; x++) { gdImageSetPixel(im, x, y, *src++); } } } break; } } static int createFromTiffTiles(TIFF *tif, gdImagePtr im, uint16 bps, uint16 photometric, char has_alpha, char is_bw, int extra) { uint16 planar; int im_width, im_height; int tile_width, tile_height; int x, y, height, width; unsigned char *buffer; if (!TIFFGetField (tif, TIFFTAG_PLANARCONFIG, &planar)) { planar = PLANARCONFIG_CONTIG; } TIFFGetField (tif, TIFFTAG_IMAGEWIDTH, &im_width); TIFFGetField (tif, TIFFTAG_IMAGELENGTH, &im_height); TIFFGetField (tif, TIFFTAG_TILEWIDTH, &tile_width); TIFFGetField (tif, TIFFTAG_TILELENGTH, &tile_height); buffer = (unsigned char *) gdMalloc (TIFFTileSize (tif)); if (!buffer) { return FALSE; } for (y = 0; y < im_height; y += tile_height) { for (x = 0; x < im_width; x += tile_width) { TIFFReadTile(tif, buffer, x, y, 0, 0); width = MIN(im_width - x, tile_width); height = MIN(im_height - y, tile_height); if (bps == 16) { } else if (bps == 8) { readTiff8bit(buffer, im, photometric, x, y, width, height, has_alpha, extra, 0); } else if (is_bw) { readTiffBw(buffer, im, photometric, x, y, width, height, has_alpha, extra, 0); } else { /* TODO: implement some default reader or detect this case earlier use force_rgb */ } } } return TRUE; } static int createFromTiffLines(TIFF *tif, gdImagePtr im, uint16 bps, uint16 photometric, char has_alpha, char is_bw, int extra) { uint16 planar; uint32 im_height, im_width, y; unsigned char *buffer; if (!TIFFGetField(tif, TIFFTAG_PLANARCONFIG, &planar)) { planar = PLANARCONFIG_CONTIG; } if (!TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &im_height)) { gd_error("Can't fetch TIFF height\n"); return FALSE; } if (!TIFFGetField(tif, TIFFTAG_IMAGEWIDTH, &im_width)) { gd_error("Can't fetch TIFF width \n"); return FALSE; } buffer = (unsigned char *)gdMalloc(im_width * 4); if (!buffer) { return GD_FAILURE; } if (planar == PLANARCONFIG_CONTIG) { switch (bps) { case 16: /* TODO * or simply use force_rgba */ break; case 8: for (y = 0; y < im_height; y++ ) { if (!TIFFReadScanline (tif, buffer, y, 0)) { gd_error("Error while reading scanline %i", y); break; } /* reading one line at a time */ readTiff8bit(buffer, im, photometric, 0, y, im_width, 1, has_alpha, extra, 0); } break; default: if (is_bw) { for (y = 0; y < im_height; y++ ) { if (!TIFFReadScanline (tif, buffer, y, 0)) { gd_error("Error while reading scanline %i", y); break; } /* reading one line at a time */ readTiffBw(buffer, im, photometric, 0, y, im_width, 1, has_alpha, extra, 0); } } else { /* TODO: implement some default reader or detect this case earlier > force_rgb */ } break; } } else { /* TODO: implement a reader for separate panes. We detect this case earlier for now and use force_rgb */ } gdFree(buffer); return GD_SUCCESS; } static int createFromTiffRgba(TIFF * tif, gdImagePtr im) { int a; int x, y; int alphaBlendingFlag = 0; int color; int width = im->sx; int height = im->sy; uint32 *buffer; uint32 rgba; /* switch off colour merging on target gd image just while we write out * content - we want to preserve the alpha data until the user chooses * what to do with the image */ alphaBlendingFlag = im->alphaBlendingFlag; gdImageAlphaBlending(im, 0); buffer = (uint32 *) gdCalloc(sizeof(uint32), width * height); if (!buffer) { return GD_FAILURE; } TIFFReadRGBAImage(tif, width, height, buffer, 0); for(y = 0; y < height; y++) { for(x = 0; x < width; x++) { /* if it doesn't already exist, allocate a new colour, * else use existing one */ rgba = buffer[(y * width + x)]; a = (0xff - TIFFGetA(rgba)) / 2; color = gdTrueColorAlpha(TIFFGetR(rgba), TIFFGetG(rgba), TIFFGetB(rgba), a); /* set pixel colour to this colour */ gdImageSetPixel(im, x, height - y - 1, color); } } gdFree(buffer); /* now reset colour merge for alpha blending routines */ gdImageAlphaBlending(im, alphaBlendingFlag); return GD_SUCCESS; } /* gdImageCreateFromTiffCtx ** ------------------------ ** Create a gdImage from a TIFF file input from an gdIOCtx */ BGD_DECLARE(gdImagePtr) gdImageCreateFromTiffCtx(gdIOCtx *infile) { TIFF *tif; tiff_handle *th; uint16 bps, spp, photometric; uint16 orientation; int width, height; uint16 extra, *extra_types; uint16 planar; char has_alpha, is_bw, is_gray; char force_rgba = FALSE; char save_transparent; int image_type; int ret; gdImagePtr im = NULL; th = new_tiff_handle(infile); if (!th) { return NULL; } tif = TIFFClientOpen("", "rb", th, tiff_readproc, tiff_writeproc, tiff_seekproc, tiff_closeproc, tiff_sizeproc, tiff_mapproc, tiff_unmapproc); if (!tif) { gd_error("Cannot open TIFF image"); return NULL; } if (!TIFFGetField(tif, TIFFTAG_IMAGEWIDTH, &width)) { gd_error("TIFF error, Cannot read image width"); goto error; } if (!TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &height)) { gd_error("TIFF error, Cannot read image width"); goto error; } TIFFGetFieldDefaulted (tif, TIFFTAG_BITSPERSAMPLE, &bps); /* Unsupported bps, force to RGBA */ if (bps > 8 && bps != 16) { force_rgba = TRUE; } TIFFGetFieldDefaulted (tif, TIFFTAG_SAMPLESPERPIXEL, &spp); if (!TIFFGetField (tif, TIFFTAG_EXTRASAMPLES, &extra, &extra_types)) { extra = 0; } if (!TIFFGetField (tif, TIFFTAG_PHOTOMETRIC, &photometric)) { uint16 compression; if (TIFFGetField(tif, TIFFTAG_COMPRESSION, &compression) && (compression == COMPRESSION_CCITTFAX3 || compression == COMPRESSION_CCITTFAX4 || compression == COMPRESSION_CCITTRLE || compression == COMPRESSION_CCITTRLEW)) { gd_error("Could not get photometric. " "Image is CCITT compressed, assuming min-is-white"); photometric = PHOTOMETRIC_MINISWHITE; } else { gd_error("Could not get photometric. " "Assuming min-is-black"); photometric = PHOTOMETRIC_MINISBLACK; } } save_transparent = FALSE; /* test if the extrasample represents an associated alpha channel... */ if (extra > 0 && (extra_types[0] == EXTRASAMPLE_ASSOCALPHA)) { has_alpha = TRUE; save_transparent = FALSE; --extra; } else if (extra > 0 && (extra_types[0] == EXTRASAMPLE_UNASSALPHA)) { has_alpha = TRUE; save_transparent = TRUE; --extra; } else if (extra > 0 && (extra_types[0] == EXTRASAMPLE_UNSPECIFIED)) { /* assuming unassociated alpha if unspecified */ gd_error("alpha channel type not defined, assuming alpha is not premultiplied"); has_alpha = TRUE; save_transparent = TRUE; --extra; } else { has_alpha = FALSE; } if (photometric == PHOTOMETRIC_RGB && spp > 3 + extra) { has_alpha = TRUE; extra = spp - 4; } else if (photometric != PHOTOMETRIC_RGB && spp > 1 + extra) { has_alpha = TRUE; extra = spp - 2; } is_bw = FALSE; is_gray = FALSE; switch (photometric) { case PHOTOMETRIC_MINISBLACK: case PHOTOMETRIC_MINISWHITE: if (!has_alpha && bps == 1 && spp == 1) { image_type = GD_INDEXED; is_bw = TRUE; } else { image_type = GD_GRAY; } break; case PHOTOMETRIC_RGB: image_type = GD_RGB; break; case PHOTOMETRIC_PALETTE: image_type = GD_INDEXED; break; default: force_rgba = TRUE; break; } if (!TIFFGetField (tif, TIFFTAG_PLANARCONFIG, &planar)) { planar = PLANARCONFIG_CONTIG; } /* Force rgba if image plans are not contiguous */ if (force_rgba || planar != PLANARCONFIG_CONTIG) { image_type = GD_RGB; } if (!force_rgba && (image_type == GD_PALETTE || image_type == GD_INDEXED || image_type == GD_GRAY)) { im = gdImageCreate(width, height); if (!im) goto error; readTiffColorMap(im, tif, is_bw, photometric); } else { im = gdImageCreateTrueColor(width, height); if (!im) goto error; } #ifdef DEBUG printf("force rgba: %i\n", force_rgba); printf("has_alpha: %i\n", has_alpha); printf("save trans: %i\n", save_transparent); printf("is_bw: %i\n", is_bw); printf("is_gray: %i\n", is_gray); printf("type: %i\n", image_type); #else (void)is_gray; (void)save_transparent; #endif if (force_rgba) { ret = createFromTiffRgba(tif, im); } else if (TIFFIsTiled(tif)) { ret = createFromTiffTiles(tif, im, bps, photometric, has_alpha, is_bw, extra); } else { ret = createFromTiffLines(tif, im, bps, photometric, has_alpha, is_bw, extra); } if (!ret) { gdImageDestroy(im); im = NULL; goto error; } if (TIFFGetField (tif, TIFFTAG_ORIENTATION, &orientation)) { switch (orientation) { case ORIENTATION_TOPLEFT: case ORIENTATION_TOPRIGHT: case ORIENTATION_BOTRIGHT: case ORIENTATION_BOTLEFT: break; default: gd_error("Orientation %d not handled yet!", orientation); break; } } error: TIFFClose(tif); return im; } /* gdImageCreateFromTIFF ** --------------------- */ BGD_DECLARE(gdImagePtr) gdImageCreateFromTiff(FILE *inFile) { gdImagePtr im; gdIOCtx *in = gdNewFileCtx(inFile); if (in == NULL) return NULL; im = gdImageCreateFromTiffCtx(in); in->gd_free(in); return im; } BGD_DECLARE(gdImagePtr) gdImageCreateFromTiffPtr(int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx (size, data, 0); if (in == NULL) return NULL; im = gdImageCreateFromTiffCtx(in); in->gd_free(in); return im; } /* gdImageTIFF ** ----------- */ BGD_DECLARE(void) gdImageTiff(gdImagePtr im, FILE *outFile) { gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageTiffCtx(im, out); /* what's an fg again? */ out->gd_free(out); } /* gdImageTIFFPtr ** -------------- */ BGD_DECLARE(void *) gdImageTiffPtr(gdImagePtr im, int *size) { void *rv; gdIOCtx *out = gdNewDynamicCtx (2048, NULL); if (out == NULL) return NULL; gdImageTiffCtx(im, out); /* what's an fg again? */ rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } #endif libgd-gd-2.1.1/src/gd_topal.c000066400000000000000000001561221245535672000157300ustar00rootroot00000000000000/* TODO: oim and nim in the lower level functions; correct use of stub (sigh). */ /* 2.0.12: a new adaptation from the same original, this time by Barend Gehrels. My attempt to incorporate alpha channel into the result worked poorly and degraded the quality of palette conversion even when the source contained no alpha channel data. This version does not attempt to produce an output file with transparency in some of the palette indexes, which, in practice, doesn't look so hot anyway. TBB */ /* * gd_topal, adapted from jquant2.c * * Copyright (C) 1991-1996, Thomas G. Lane. * This file is part of the Independent JPEG Group's software. * For conditions of distribution and use, see the accompanying README file. * * This file contains 2-pass color quantization (color mapping) routines. * These routines provide selection of a custom color map for an image, * followed by mapping of the image to that color map, with optional * Floyd-Steinberg dithering. * It is also possible to use just the second pass to map to an arbitrary * externally-given color map. * * Note: ordered dithering is not supported, since there isn't any fast * way to compute intercolor distances; it's unclear that ordered dither's * fundamental assumptions even hold with an irregularly spaced color map. */ /* * THOMAS BOUTELL & BAREND GEHRELS, february 2003 * adapted the code to work within gd rather than within libjpeg. * If it is not working, it's not Thomas G. Lane's fault. */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include "gd.h" #include "gdhelpers.h" #ifdef HAVE_LIBIMAGEQUANT_H #include /* if this fails then set -DENABLE_LIQ=NO in cmake or make static libimagequant.a in libimagequant/ */ #endif /* (Re)define some defines known by libjpeg */ #define QUANT_2PASS_SUPPORTED #define RGB_RED 0 #define RGB_GREEN 1 #define RGB_BLUE 2 #define JSAMPLE unsigned char #define MAXJSAMPLE (gdMaxColors-1) #define BITS_IN_JSAMPLE 8 #define JSAMPROW int* #define JDIMENSION int #define METHODDEF(type) static type #define LOCAL(type) static type /* We assume that right shift corresponds to signed division by 2 with * rounding towards minus infinity. This is correct for typical "arithmetic * shift" instructions that shift in copies of the sign bit. But some * C compilers implement >> with an unsigned shift. For these machines you * must define RIGHT_SHIFT_IS_UNSIGNED. * RIGHT_SHIFT provides a proper signed right shift of an INT32 quantity. * It is only applied with constant shift counts. SHIFT_TEMPS must be * included in the variables of any routine using RIGHT_SHIFT. */ #ifdef RIGHT_SHIFT_IS_UNSIGNED #define SHIFT_TEMPS INT32 shift_temp; #define RIGHT_SHIFT(x,shft) \ ((shift_temp = (x)) < 0 ? \ (shift_temp >> (shft)) | ((~((INT32) 0)) << (32-(shft))) : \ (shift_temp >> (shft))) #else #define SHIFT_TEMPS #define RIGHT_SHIFT(x,shft) ((x) >> (shft)) #endif #define range_limit(x) { if(x<0) x=0; if (x>255) x=255; } #ifndef INT16 #define INT16 short #endif #ifndef UINT16 #define UINT16 unsigned short #endif #ifndef INT32 #define INT32 int #endif #ifndef FAR #define FAR #endif #ifndef boolean #define boolean int #endif #ifndef TRUE #define TRUE 1 #endif #ifndef FALSE #define FALSE 0 #endif #define input_buf (oim->tpixels) #define output_buf (nim->pixels) #ifdef QUANT_2PASS_SUPPORTED /* * This module implements the well-known Heckbert paradigm for color * quantization. Most of the ideas used here can be traced back to * Heckbert's seminal paper * Heckbert, Paul. "Color Image Quantization for Frame Buffer Display", * Proc. SIGGRAPH '82, Computer Graphics v.16 #3 (July 1982), pp 297-304. * * In the first pass over the image, we accumulate a histogram showing the * usage count of each possible color. To keep the histogram to a reasonable * size, we reduce the precision of the input; typical practice is to retain * 5 or 6 bits per color, so that 8 or 4 different input values are counted * in the same histogram cell. * * Next, the color-selection step begins with a box representing the whole * color space, and repeatedly splits the "largest" remaining box until we * have as many boxes as desired colors. Then the mean color in each * remaining box becomes one of the possible output colors. * * The second pass over the image maps each input pixel to the closest output * color (optionally after applying a Floyd-Steinberg dithering correction). * This mapping is logically trivial, but making it go fast enough requires * considerable care. * * Heckbert-style quantizers vary a good deal in their policies for choosing * the "largest" box and deciding where to cut it. The particular policies * used here have proved out well in experimental comparisons, but better ones * may yet be found. * * In earlier versions of the IJG code, this module quantized in YCbCr color * space, processing the raw upsampled data without a color conversion step. * This allowed the color conversion math to be done only once per colormap * entry, not once per pixel. However, that optimization precluded other * useful optimizations (such as merging color conversion with upsampling) * and it also interfered with desired capabilities such as quantizing to an * externally-supplied colormap. We have therefore abandoned that approach. * The present code works in the post-conversion color space, typically RGB. * * To improve the visual quality of the results, we actually work in scaled * RGB space, giving G distances more weight than R, and R in turn more than * B. To do everything in integer math, we must use integer scale factors. * The 2/3/1 scale factors used here correspond loosely to the relative * weights of the colors in the NTSC grayscale equation. * If you want to use this code to quantize a non-RGB color space, you'll * probably need to change these scale factors. */ #define R_SCALE 2 /* scale R distances by this much */ #define G_SCALE 3 /* scale G distances by this much */ #define B_SCALE 1 /* and B by this much */ /* Relabel R/G/B as components 0/1/2, respecting the RGB ordering defined * in jmorecfg.h. As the code stands, it will do the right thing for R,G,B * and B,G,R orders. If you define some other weird order in jmorecfg.h, * you'll get compile errors until you extend this logic. In that case * you'll probably want to tweak the histogram sizes too. */ #if RGB_RED == 0 #define C0_SCALE R_SCALE #endif #if RGB_BLUE == 0 #define C0_SCALE B_SCALE #endif #if RGB_GREEN == 1 #define C1_SCALE G_SCALE #endif #if RGB_RED == 2 #define C2_SCALE R_SCALE #endif #if RGB_BLUE == 2 #define C2_SCALE B_SCALE #endif /* * First we have the histogram data structure and routines for creating it. * * The number of bits of precision can be adjusted by changing these symbols. * We recommend keeping 6 bits for G and 5 each for R and B. * If you have plenty of memory and cycles, 6 bits all around gives marginally * better results; if you are short of memory, 5 bits all around will save * some space but degrade the results. * To maintain a fully accurate histogram, we'd need to allocate a "long" * (preferably unsigned long) for each cell. In practice this is overkill; * we can get by with 16 bits per cell. Few of the cell counts will overflow, * and clamping those that do overflow to the maximum value will give close- * enough results. This reduces the recommended histogram size from 256Kb * to 128Kb, which is a useful savings on PC-class machines. * (In the second pass the histogram space is re-used for pixel mapping data; * in that capacity, each cell must be able to store zero to the number of * desired colors. 16 bits/cell is plenty for that too.) * Since the JPEG code is intended to run in small memory model on 80x86 * machines, we can't just allocate the histogram in one chunk. Instead * of a true 3-D array, we use a row of pointers to 2-D arrays. Each * pointer corresponds to a C0 value (typically 2^5 = 32 pointers) and * each 2-D array has 2^6*2^5 = 2048 or 2^6*2^6 = 4096 entries. Note that * on 80x86 machines, the pointer row is in near memory but the actual * arrays are in far memory (same arrangement as we use for image arrays). */ #define MAXNUMCOLORS (MAXJSAMPLE+1) /* maximum size of colormap */ /* These will do the right thing for either R,G,B or B,G,R color order, * but you may not like the results for other color orders. */ #define HIST_C0_BITS 5 /* bits of precision in R/B histogram */ #define HIST_C1_BITS 6 /* bits of precision in G histogram */ #define HIST_C2_BITS 5 /* bits of precision in B/R histogram */ /* Number of elements along histogram axes. */ #define HIST_C0_ELEMS (1<histogram; int row; JDIMENSION col; int width = oim->sx; int num_rows = oim->sy; (void)nim; for (row = 0; row < num_rows; row++) { ptr = input_buf[row]; for (col = width; col > 0; col--) { int r = gdTrueColorGetRed (*ptr) >> C0_SHIFT; int g = gdTrueColorGetGreen (*ptr) >> C1_SHIFT; int b = gdTrueColorGetBlue (*ptr) >> C2_SHIFT; /* 2.0.12: Steven Brown: support a single totally transparent color in the original. */ if ((oim->transparent >= 0) && (*ptr == oim->transparent)) { ptr++; continue; } /* get pixel value and index into the histogram */ histp = &histogram[r][g][b]; /* increment, check for overflow and undo increment if so. */ if (++(*histp) == 0) (*histp)--; ptr++; } } } /* * Next we have the really interesting routines: selection of a colormap * given the completed histogram. * These routines work with a list of "boxes", each representing a rectangular * subset of the input color space (to histogram precision). */ typedef struct { /* The bounds of the box (inclusive); expressed as histogram indexes */ int c0min, c0max; int c1min, c1max; int c2min, c2max; /* The volume (actually 2-norm) of the box */ INT32 volume; /* The number of nonzero histogram cells within this box */ long colorcount; } box; typedef box *boxptr; LOCAL (boxptr) find_biggest_color_pop (boxptr boxlist, int numboxes) /* Find the splittable box with the largest color population */ /* Returns NULL if no splittable boxes remain */ { register boxptr boxp; register int i; register long maxc = 0; boxptr which = NULL; for (i = 0, boxp = boxlist; i < numboxes; i++, boxp++) { if (boxp->colorcount > maxc && boxp->volume > 0) { which = boxp; maxc = boxp->colorcount; } } return which; } LOCAL (boxptr) find_biggest_volume (boxptr boxlist, int numboxes) /* Find the splittable box with the largest (scaled) volume */ /* Returns NULL if no splittable boxes remain */ { register boxptr boxp; register int i; register INT32 maxv = 0; boxptr which = NULL; for (i = 0, boxp = boxlist; i < numboxes; i++, boxp++) { if (boxp->volume > maxv) { which = boxp; maxv = boxp->volume; } } return which; } LOCAL (void) update_box (gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize, boxptr boxp) { hist3d histogram = cquantize->histogram; histptr histp; int c0, c1, c2; int c0min, c0max, c1min, c1max, c2min, c2max; INT32 dist0, dist1, dist2; long ccount; (void)oim; (void)nim; c0min = boxp->c0min; c0max = boxp->c0max; c1min = boxp->c1min; c1max = boxp->c1max; c2min = boxp->c2min; c2max = boxp->c2max; if (c0max > c0min) for (c0 = c0min; c0 <= c0max; c0++) for (c1 = c1min; c1 <= c1max; c1++) { histp = &histogram[c0][c1][c2min]; for (c2 = c2min; c2 <= c2max; c2++) if (*histp++ != 0) { boxp->c0min = c0min = c0; goto have_c0min; } } have_c0min: if (c0max > c0min) for (c0 = c0max; c0 >= c0min; c0--) for (c1 = c1min; c1 <= c1max; c1++) { histp = &histogram[c0][c1][c2min]; for (c2 = c2min; c2 <= c2max; c2++) if (*histp++ != 0) { boxp->c0max = c0max = c0; goto have_c0max; } } have_c0max: if (c1max > c1min) for (c1 = c1min; c1 <= c1max; c1++) for (c0 = c0min; c0 <= c0max; c0++) { histp = &histogram[c0][c1][c2min]; for (c2 = c2min; c2 <= c2max; c2++) if (*histp++ != 0) { boxp->c1min = c1min = c1; goto have_c1min; } } have_c1min: if (c1max > c1min) for (c1 = c1max; c1 >= c1min; c1--) for (c0 = c0min; c0 <= c0max; c0++) { histp = &histogram[c0][c1][c2min]; for (c2 = c2min; c2 <= c2max; c2++) if (*histp++ != 0) { boxp->c1max = c1max = c1; goto have_c1max; } } have_c1max: if (c2max > c2min) for (c2 = c2min; c2 <= c2max; c2++) for (c0 = c0min; c0 <= c0max; c0++) { histp = &histogram[c0][c1min][c2]; for (c1 = c1min; c1 <= c1max; c1++, histp += HIST_C2_ELEMS) if (*histp != 0) { boxp->c2min = c2min = c2; goto have_c2min; } } have_c2min: if (c2max > c2min) for (c2 = c2max; c2 >= c2min; c2--) for (c0 = c0min; c0 <= c0max; c0++) { histp = &histogram[c0][c1min][c2]; for (c1 = c1min; c1 <= c1max; c1++, histp += HIST_C2_ELEMS) if (*histp != 0) { boxp->c2max = c2max = c2; goto have_c2max; } } have_c2max: /* Update box volume. * We use 2-norm rather than real volume here; this biases the method * against making long narrow boxes, and it has the side benefit that * a box is splittable iff norm > 0. * Since the differences are expressed in histogram-cell units, * we have to shift back to JSAMPLE units to get consistent distances; * after which, we scale according to the selected distance scale factors. */ dist0 = ((c0max - c0min) << C0_SHIFT) * C0_SCALE; dist1 = ((c1max - c1min) << C1_SHIFT) * C1_SCALE; dist2 = ((c2max - c2min) << C2_SHIFT) * C2_SCALE; boxp->volume = dist0 * dist0 + dist1 * dist1 + dist2 * dist2; /* Now scan remaining volume of box and compute population */ ccount = 0; for (c0 = c0min; c0 <= c0max; c0++) for (c1 = c1min; c1 <= c1max; c1++) { histp = &histogram[c0][c1][c2min]; for (c2 = c2min; c2 <= c2max; c2++, histp++) if (*histp != 0) { ccount++; } } boxp->colorcount = ccount; } LOCAL (int) median_cut (gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize, boxptr boxlist, int numboxes, int desired_colors) /* Repeatedly select and split the largest box until we have enough boxes */ { int n, lb; int c0, c1, c2, cmax; register boxptr b1, b2; while (numboxes < desired_colors) { /* Select box to split. * Current algorithm: by population for first half, then by volume. */ if (numboxes * 2 <= desired_colors) { b1 = find_biggest_color_pop (boxlist, numboxes); } else { b1 = find_biggest_volume (boxlist, numboxes); } if (b1 == NULL) /* no splittable boxes left! */ break; b2 = &boxlist[numboxes]; /* where new box will go */ /* Copy the color bounds to the new box. */ b2->c0max = b1->c0max; b2->c1max = b1->c1max; b2->c2max = b1->c2max; b2->c0min = b1->c0min; b2->c1min = b1->c1min; b2->c2min = b1->c2min; /* Choose which axis to split the box on. * Current algorithm: longest scaled axis. * See notes in update_box about scaling distances. */ c0 = ((b1->c0max - b1->c0min) << C0_SHIFT) * C0_SCALE; c1 = ((b1->c1max - b1->c1min) << C1_SHIFT) * C1_SCALE; c2 = ((b1->c2max - b1->c2min) << C2_SHIFT) * C2_SCALE; /* We want to break any ties in favor of green, then red, blue last. * This code does the right thing for R,G,B or B,G,R color orders only. */ #if RGB_RED == 0 cmax = c1; n = 1; if (c0 > cmax) { cmax = c0; n = 0; } if (c2 > cmax) { n = 2; } #else cmax = c1; n = 1; if (c2 > cmax) { cmax = c2; n = 2; } if (c0 > cmax) { n = 0; } #endif /* Choose split point along selected axis, and update box bounds. * Current algorithm: split at halfway point. * (Since the box has been shrunk to minimum volume, * any split will produce two nonempty subboxes.) * Note that lb value is max for lower box, so must be < old max. */ switch (n) { case 0: lb = (b1->c0max + b1->c0min) / 2; b1->c0max = lb; b2->c0min = lb + 1; break; case 1: lb = (b1->c1max + b1->c1min) / 2; b1->c1max = lb; b2->c1min = lb + 1; break; case 2: lb = (b1->c2max + b1->c2min) / 2; b1->c2max = lb; b2->c2min = lb + 1; break; } /* Update stats for boxes */ update_box (oim, nim, cquantize, b1); update_box (oim, nim, cquantize, b2); numboxes++; } return numboxes; } LOCAL (void) compute_color (gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize, boxptr boxp, int icolor) { hist3d histogram = cquantize->histogram; histptr histp; int c0, c1, c2; int c0min, c0max, c1min, c1max, c2min, c2max; long count = 0; /* 2.0.28: = 0 */ long total = 0; long c0total = 0; long c1total = 0; long c2total = 0; (void)oim; c0min = boxp->c0min; c0max = boxp->c0max; c1min = boxp->c1min; c1max = boxp->c1max; c2min = boxp->c2min; c2max = boxp->c2max; for (c0 = c0min; c0 <= c0max; c0++) for (c1 = c1min; c1 <= c1max; c1++) { histp = &histogram[c0][c1][c2min]; for (c2 = c2min; c2 <= c2max; c2++) { if ((count = *histp++) != 0) { total += count; c0total += ((c0 << C0_SHIFT) + ((1 << C0_SHIFT) >> 1)) * count; c1total += ((c1 << C1_SHIFT) + ((1 << C1_SHIFT) >> 1)) * count; c2total += ((c2 << C2_SHIFT) + ((1 << C2_SHIFT) >> 1)) * count; } } } /* 2.0.16: Paul den Dulk found an occasion where total can be 0 */ if (count) { nim->red[icolor] = (int) ((c0total + (total >> 1)) / total); nim->green[icolor] = (int) ((c1total + (total >> 1)) / total); nim->blue[icolor] = (int) ((c2total + (total >> 1)) / total); } else { nim->red[icolor] = 255; nim->green[icolor] = 255; nim->blue[icolor] = 255; } nim->open[icolor] = 0; } LOCAL (void) select_colors (gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize, int desired_colors) /* Master routine for color selection */ { boxptr boxlist; int numboxes; int i; /* Allocate workspace for box list */ /* This can't happen because we clamp desired_colors at gdMaxColors, but anyway */ if (overflow2(desired_colors, sizeof (box))) { return; } boxlist = (boxptr) gdMalloc (desired_colors * sizeof (box)); if (!boxlist) { return; } /* Initialize one box containing whole space */ numboxes = 1; boxlist[0].c0min = 0; boxlist[0].c0max = MAXJSAMPLE >> C0_SHIFT; boxlist[0].c1min = 0; boxlist[0].c1max = MAXJSAMPLE >> C1_SHIFT; boxlist[0].c2min = 0; boxlist[0].c2max = MAXJSAMPLE >> C2_SHIFT; /* Shrink it to actually-used volume and set its statistics */ update_box (oim, nim, cquantize, &boxlist[0]); /* Perform median-cut to produce final box list */ numboxes = median_cut (oim, nim, cquantize, boxlist, numboxes, desired_colors); /* Compute the representative color for each box, fill colormap */ for (i = 0; i < numboxes; i++) compute_color (oim, nim, cquantize, &boxlist[i], i); nim->colorsTotal = numboxes; /* If we had a pure transparency color, add it as the last palette entry. * Skip incrementing the color count so that the dither / matching phase * won't use it on pixels that shouldn't have been transparent. We'll * increment it after all that finishes. */ if (oim->transparent >= 0) { /* Save the transparent color. */ nim->red[nim->colorsTotal] = gdTrueColorGetRed (oim->transparent); nim->green[nim->colorsTotal] = gdTrueColorGetGreen (oim->transparent); nim->blue[nim->colorsTotal] = gdTrueColorGetBlue (oim->transparent); nim->alpha[nim->colorsTotal] = gdAlphaTransparent; nim->open[nim->colorsTotal] = 0; } gdFree (boxlist); } /* * These routines are concerned with the time-critical task of mapping input * colors to the nearest color in the selected colormap. * * We re-use the histogram space as an "inverse color map", essentially a * cache for the results of nearest-color searches. All colors within a * histogram cell will be mapped to the same colormap entry, namely the one * closest to the cell's center. This may not be quite the closest entry to * the actual input color, but it's almost as good. A zero in the cache * indicates we haven't found the nearest color for that cell yet; the array * is cleared to zeroes before starting the mapping pass. When we find the * nearest color for a cell, its colormap index plus one is recorded in the * cache for future use. The pass2 scanning routines call fill_inverse_cmap * when they need to use an unfilled entry in the cache. * * Our method of efficiently finding nearest colors is based on the "locally * sorted search" idea described by Heckbert and on the incremental distance * calculation described by Spencer W. Thomas in chapter III.1 of Graphics * Gems II (James Arvo, ed. Academic Press, 1991). Thomas points out that * the distances from a given colormap entry to each cell of the histogram can * be computed quickly using an incremental method: the differences between * distances to adjacent cells themselves differ by a constant. This allows a * fairly fast implementation of the "brute force" approach of computing the * distance from every colormap entry to every histogram cell. Unfortunately, * it needs a work array to hold the best-distance-so-far for each histogram * cell (because the inner loop has to be over cells, not colormap entries). * The work array elements have to be INT32s, so the work array would need * 256Kb at our recommended precision. This is not feasible in DOS machines. * * To get around these problems, we apply Thomas' method to compute the * nearest colors for only the cells within a small subbox of the histogram. * The work array need be only as big as the subbox, so the memory usage * problem is solved. Furthermore, we need not fill subboxes that are never * referenced in pass2; many images use only part of the color gamut, so a * fair amount of work is saved. An additional advantage of this * approach is that we can apply Heckbert's locality criterion to quickly * eliminate colormap entries that are far away from the subbox; typically * three-fourths of the colormap entries are rejected by Heckbert's criterion, * and we need not compute their distances to individual cells in the subbox. * The speed of this approach is heavily influenced by the subbox size: too * small means too much overhead, too big loses because Heckbert's criterion * can't eliminate as many colormap entries. Empirically the best subbox * size seems to be about 1/512th of the histogram (1/8th in each direction). * * Thomas' article also describes a refined method which is asymptotically * faster than the brute-force method, but it is also far more complex and * cannot efficiently be applied to small subboxes. It is therefore not * useful for programs intended to be portable to DOS machines. On machines * with plenty of memory, filling the whole histogram in one shot with Thomas' * refined method might be faster than the present code --- but then again, * it might not be any faster, and it's certainly more complicated. */ /* log2(histogram cells in update box) for each axis; this can be adjusted */ #define BOX_C0_LOG (HIST_C0_BITS-3) #define BOX_C1_LOG (HIST_C1_BITS-3) #define BOX_C2_LOG (HIST_C2_BITS-3) #define BOX_C0_ELEMS (1<colorsTotal; int maxc0, maxc1, maxc2; int centerc0, centerc1, centerc2; int i, x, ncolors; INT32 minmaxdist, min_dist, max_dist, tdist; INT32 mindist[MAXNUMCOLORS]; /* min distance to colormap entry i */ (void)oim; (void)cquantize; /* Compute true coordinates of update box's upper corner and center. * Actually we compute the coordinates of the center of the upper-corner * histogram cell, which are the upper bounds of the volume we care about. * Note that since ">>" rounds down, the "center" values may be closer to * min than to max; hence comparisons to them must be "<=", not "<". */ maxc0 = minc0 + ((1 << BOX_C0_SHIFT) - (1 << C0_SHIFT)); centerc0 = (minc0 + maxc0) >> 1; maxc1 = minc1 + ((1 << BOX_C1_SHIFT) - (1 << C1_SHIFT)); centerc1 = (minc1 + maxc1) >> 1; maxc2 = minc2 + ((1 << BOX_C2_SHIFT) - (1 << C2_SHIFT)); centerc2 = (minc2 + maxc2) >> 1; /* For each color in colormap, find: * 1. its minimum squared-distance to any point in the update box * (zero if color is within update box); * 2. its maximum squared-distance to any point in the update box. * Both of these can be found by considering only the corners of the box. * We save the minimum distance for each color in mindist[]; * only the smallest maximum distance is of interest. */ minmaxdist = 0x7FFFFFFFL; for (i = 0; i < numcolors; i++) { /* We compute the squared-c0-distance term, then add in the other two. */ x = nim->red[i]; if (x < minc0) { tdist = (x - minc0) * C0_SCALE; min_dist = tdist * tdist; tdist = (x - maxc0) * C0_SCALE; max_dist = tdist * tdist; } else if (x > maxc0) { tdist = (x - maxc0) * C0_SCALE; min_dist = tdist * tdist; tdist = (x - minc0) * C0_SCALE; max_dist = tdist * tdist; } else { /* within cell range so no contribution to min_dist */ min_dist = 0; if (x <= centerc0) { tdist = (x - maxc0) * C0_SCALE; max_dist = tdist * tdist; } else { tdist = (x - minc0) * C0_SCALE; max_dist = tdist * tdist; } } x = nim->green[i]; if (x < minc1) { tdist = (x - minc1) * C1_SCALE; min_dist += tdist * tdist; tdist = (x - maxc1) * C1_SCALE; max_dist += tdist * tdist; } else if (x > maxc1) { tdist = (x - maxc1) * C1_SCALE; min_dist += tdist * tdist; tdist = (x - minc1) * C1_SCALE; max_dist += tdist * tdist; } else { /* within cell range so no contribution to min_dist */ if (x <= centerc1) { tdist = (x - maxc1) * C1_SCALE; max_dist += tdist * tdist; } else { tdist = (x - minc1) * C1_SCALE; max_dist += tdist * tdist; } } x = nim->blue[i]; if (x < minc2) { tdist = (x - minc2) * C2_SCALE; min_dist += tdist * tdist; tdist = (x - maxc2) * C2_SCALE; max_dist += tdist * tdist; } else if (x > maxc2) { tdist = (x - maxc2) * C2_SCALE; min_dist += tdist * tdist; tdist = (x - minc2) * C2_SCALE; max_dist += tdist * tdist; } else { /* within cell range so no contribution to min_dist */ if (x <= centerc2) { tdist = (x - maxc2) * C2_SCALE; max_dist += tdist * tdist; } else { tdist = (x - minc2) * C2_SCALE; max_dist += tdist * tdist; } } mindist[i] = min_dist; /* save away the results */ if (max_dist < minmaxdist) minmaxdist = max_dist; } /* Now we know that no cell in the update box is more than minmaxdist * away from some colormap entry. Therefore, only colors that are * within minmaxdist of some part of the box need be considered. */ ncolors = 0; for (i = 0; i < numcolors; i++) { if (mindist[i] <= minmaxdist) colorlist[ncolors++] = (JSAMPLE) i; } return ncolors; } LOCAL (void) find_best_colors ( gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize, int minc0, int minc1, int minc2, int numcolors, JSAMPLE colorlist[], JSAMPLE bestcolor[]) /* Find the closest colormap entry for each cell in the update box, * given the list of candidate colors prepared by find_nearby_colors. * Return the indexes of the closest entries in the bestcolor[] array. * This routine uses Thomas' incremental distance calculation method to * find the distance from a colormap entry to successive cells in the box. */ { int ic0, ic1, ic2; int i, icolor; register INT32 *bptr; /* pointer into bestdist[] array */ JSAMPLE *cptr; /* pointer into bestcolor[] array */ INT32 dist0, dist1; /* initial distance values */ register INT32 dist2; /* current distance in inner loop */ INT32 xx0, xx1; /* distance increments */ register INT32 xx2; INT32 inc0, inc1, inc2; /* initial values for increments */ /* This array holds the distance to the nearest-so-far color for each cell */ INT32 bestdist[BOX_C0_ELEMS * BOX_C1_ELEMS * BOX_C2_ELEMS]; (void)oim; (void)cquantize; /* Initialize best-distance for each cell of the update box */ bptr = bestdist; for (i = BOX_C0_ELEMS * BOX_C1_ELEMS * BOX_C2_ELEMS - 1; i >= 0; i--) *bptr++ = 0x7FFFFFFFL; /* For each color selected by find_nearby_colors, * compute its distance to the center of each cell in the box. * If that's less than best-so-far, update best distance and color number. */ /* Nominal steps between cell centers ("x" in Thomas article) */ #define STEP_C0 ((1 << C0_SHIFT) * C0_SCALE) #define STEP_C1 ((1 << C1_SHIFT) * C1_SCALE) #define STEP_C2 ((1 << C2_SHIFT) * C2_SCALE) for (i = 0; i < numcolors; i++) { int r, g, b; icolor = colorlist[i]; r = nim->red[icolor]; g = nim->green[icolor]; b = nim->blue[icolor]; /* Compute (square of) distance from minc0/c1/c2 to this color */ inc0 = (minc0 - r) * C0_SCALE; dist0 = inc0 * inc0; inc1 = (minc1 - g) * C1_SCALE; dist0 += inc1 * inc1; inc2 = (minc2 - b) * C2_SCALE; dist0 += inc2 * inc2; /* Form the initial difference increments */ inc0 = inc0 * (2 * STEP_C0) + STEP_C0 * STEP_C0; inc1 = inc1 * (2 * STEP_C1) + STEP_C1 * STEP_C1; inc2 = inc2 * (2 * STEP_C2) + STEP_C2 * STEP_C2; /* Now loop over all cells in box, updating distance per Thomas method */ bptr = bestdist; cptr = bestcolor; xx0 = inc0; for (ic0 = BOX_C0_ELEMS - 1; ic0 >= 0; ic0--) { dist1 = dist0; xx1 = inc1; for (ic1 = BOX_C1_ELEMS - 1; ic1 >= 0; ic1--) { dist2 = dist1; xx2 = inc2; for (ic2 = BOX_C2_ELEMS - 1; ic2 >= 0; ic2--) { if (dist2 < *bptr) { *bptr = dist2; *cptr = (JSAMPLE) icolor; } dist2 += xx2; xx2 += 2 * STEP_C2 * STEP_C2; bptr++; cptr++; } dist1 += xx1; xx1 += 2 * STEP_C1 * STEP_C1; } dist0 += xx0; xx0 += 2 * STEP_C0 * STEP_C0; } } } LOCAL (void) fill_inverse_cmap ( gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize, int c0, int c1, int c2) /* Fill the inverse-colormap entries in the update box that contains */ /* histogram cell c0/c1/c2. (Only that one cell MUST be filled, but */ /* we can fill as many others as we wish.) */ { hist3d histogram = cquantize->histogram; int minc0, minc1, minc2; /* lower left corner of update box */ int ic0, ic1, ic2; register JSAMPLE *cptr; /* pointer into bestcolor[] array */ register histptr cachep; /* pointer into main cache array */ /* This array lists the candidate colormap indexes. */ JSAMPLE colorlist[MAXNUMCOLORS]; int numcolors; /* number of candidate colors */ /* This array holds the actually closest colormap index for each cell. */ JSAMPLE bestcolor[BOX_C0_ELEMS * BOX_C1_ELEMS * BOX_C2_ELEMS]; /* Convert cell coordinates to update box ID */ c0 >>= BOX_C0_LOG; c1 >>= BOX_C1_LOG; c2 >>= BOX_C2_LOG; /* Compute true coordinates of update box's origin corner. * Actually we compute the coordinates of the center of the corner * histogram cell, which are the lower bounds of the volume we care about. */ minc0 = (c0 << BOX_C0_SHIFT) + ((1 << C0_SHIFT) >> 1); minc1 = (c1 << BOX_C1_SHIFT) + ((1 << C1_SHIFT) >> 1); minc2 = (c2 << BOX_C2_SHIFT) + ((1 << C2_SHIFT) >> 1); /* Determine which colormap entries are close enough to be candidates * for the nearest entry to some cell in the update box. */ numcolors = find_nearby_colors (oim, nim, cquantize, minc0, minc1, minc2, colorlist); find_best_colors (oim, nim, cquantize, minc0, minc1, minc2, numcolors, colorlist, bestcolor); /* Save the best color numbers (plus 1) in the main cache array */ c0 <<= BOX_C0_LOG; /* convert ID back to base cell indexes */ c1 <<= BOX_C1_LOG; c2 <<= BOX_C2_LOG; cptr = bestcolor; for (ic0 = 0; ic0 < BOX_C0_ELEMS; ic0++) { for (ic1 = 0; ic1 < BOX_C1_ELEMS; ic1++) { cachep = &histogram[c0 + ic0][c1 + ic1][c2]; for (ic2 = 0; ic2 < BOX_C2_ELEMS; ic2++) { *cachep++ = (histcell) ((*cptr++) + 1); } } } } /* * Map some rows of pixels to the output colormapped representation. */ METHODDEF (void) pass2_no_dither (gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize) { register int *inptr; register unsigned char *outptr; int width = oim->sx; int num_rows = oim->sy; hist3d histogram = cquantize->histogram; register int c0, c1, c2; int row; JDIMENSION col; register histptr cachep; for (row = 0; row < num_rows; row++) { inptr = input_buf[row]; outptr = output_buf[row]; for (col = width; col > 0; col--) { /* get pixel value and index into the cache */ int r, g, b; r = gdTrueColorGetRed (*inptr); g = gdTrueColorGetGreen (*inptr); /* 2.0.24: inptr must not be incremented until after transparency check, if any. Thanks to "Super Pikeman." */ b = gdTrueColorGetBlue (*inptr); /* If the pixel is transparent, we assign it the palette index that * will later be added at the end of the palette as the transparent * index. */ if ((oim->transparent >= 0) && (oim->transparent == *inptr)) { *outptr++ = nim->colorsTotal; inptr++; continue; } inptr++; c0 = r >> C0_SHIFT; c1 = g >> C1_SHIFT; c2 = b >> C2_SHIFT; cachep = &histogram[c0][c1][c2]; /* If we have not seen this color before, find nearest colormap entry */ /* and update the cache */ if (*cachep == 0) fill_inverse_cmap (oim, nim, cquantize, c0, c1, c2); /* Now emit the colormap index for this cell */ *outptr++ = (*cachep - 1); } } } METHODDEF (void) pass2_fs_dither (gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize) { hist3d histogram = cquantize->histogram; register LOCFSERROR cur0, cur1, cur2; /* current error or pixel value */ LOCFSERROR belowerr0, belowerr1, belowerr2; /* error for pixel below cur */ LOCFSERROR bpreverr0, bpreverr1, bpreverr2; /* error for below/prev col */ register FSERRPTR errorptr; /* => fserrors[] at column before current */ histptr cachep; int dir; /* +1 or -1 depending on direction */ int dir3; /* 3*dir, for advancing inptr & errorptr */ int row; JDIMENSION col; int *inptr; /* => current input pixel */ unsigned char *outptr; /* => current output pixel */ int width = oim->sx; int num_rows = oim->sy; int *colormap0 = nim->red; int *colormap1 = nim->green; int *colormap2 = nim->blue; int *error_limit = cquantize->error_limiter; SHIFT_TEMPS for (row = 0; row < num_rows; row++) { inptr = input_buf[row]; outptr = output_buf[row]; if (cquantize->on_odd_row) { /* work right to left in this row */ inptr += (width - 1) * 3; /* so point to rightmost pixel */ outptr += width - 1; dir = -1; dir3 = -3; errorptr = cquantize->fserrors + (width + 1) * 3; /* => entry after last column */ } else { /* work left to right in this row */ dir = 1; dir3 = 3; errorptr = cquantize->fserrors; /* => entry before first real column */ } /* Preset error values: no error propagated to first pixel from left */ cur0 = cur1 = cur2 = 0; /* and no error propagated to row below yet */ belowerr0 = belowerr1 = belowerr2 = 0; bpreverr0 = bpreverr1 = bpreverr2 = 0; for (col = width; col > 0; col--) { /* If this pixel is transparent, we want to assign it to the special * transparency color index past the end of the palette rather than * go through matching / dithering. */ if ((oim->transparent >= 0) && (*inptr == oim->transparent)) { *outptr = nim->colorsTotal; errorptr[0] = 0; errorptr[1] = 0; errorptr[2] = 0; errorptr[3] = 0; inptr += dir; outptr += dir; errorptr += dir3; continue; } /* curN holds the error propagated from the previous pixel on the * current line. Add the error propagated from the previous line * to form the complete error correction term for this pixel, and * round the error term (which is expressed * 16) to an integer. * RIGHT_SHIFT rounds towards minus infinity, so adding 8 is correct * for either sign of the error value. * Note: errorptr points to *previous* column's array entry. */ cur0 = RIGHT_SHIFT (cur0 + errorptr[dir3 + 0] + 8, 4); cur1 = RIGHT_SHIFT (cur1 + errorptr[dir3 + 1] + 8, 4); cur2 = RIGHT_SHIFT (cur2 + errorptr[dir3 + 2] + 8, 4); /* Limit the error using transfer function set by init_error_limit. * See comments with init_error_limit for rationale. */ cur0 = error_limit[cur0]; cur1 = error_limit[cur1]; cur2 = error_limit[cur2]; /* Form pixel value + error, and range-limit to 0..MAXJSAMPLE. * The maximum error is +- MAXJSAMPLE (or less with error limiting); * this sets the required size of the range_limit array. */ cur0 += gdTrueColorGetRed (*inptr); cur1 += gdTrueColorGetGreen (*inptr); cur2 += gdTrueColorGetBlue (*inptr); range_limit (cur0); range_limit (cur1); range_limit (cur2); /* Index into the cache with adjusted pixel value */ cachep = &histogram[cur0 >> C0_SHIFT][cur1 >> C1_SHIFT][cur2 >> C2_SHIFT]; /* If we have not seen this color before, find nearest colormap */ /* entry and update the cache */ if (*cachep == 0) fill_inverse_cmap (oim, nim, cquantize, cur0 >> C0_SHIFT, cur1 >> C1_SHIFT, cur2 >> C2_SHIFT); /* Now emit the colormap index for this cell */ { register int pixcode = *cachep - 1; *outptr = (JSAMPLE) pixcode; /* Compute representation error for this pixel */ #define GETJSAMPLE cur0 -= GETJSAMPLE (colormap0[pixcode]); cur1 -= GETJSAMPLE (colormap1[pixcode]); cur2 -= GETJSAMPLE (colormap2[pixcode]); #undef GETJSAMPLE } /* Compute error fractions to be propagated to adjacent pixels. * Add these into the running sums, and simultaneously shift the * next-line error sums left by 1 column. */ { register LOCFSERROR bnexterr, delta; bnexterr = cur0; /* Process component 0 */ delta = cur0 * 2; cur0 += delta; /* form error * 3 */ errorptr[0] = (FSERROR) (bpreverr0 + cur0); cur0 += delta; /* form error * 5 */ bpreverr0 = belowerr0 + cur0; belowerr0 = bnexterr; cur0 += delta; /* form error * 7 */ bnexterr = cur1; /* Process component 1 */ delta = cur1 * 2; cur1 += delta; /* form error * 3 */ errorptr[1] = (FSERROR) (bpreverr1 + cur1); cur1 += delta; /* form error * 5 */ bpreverr1 = belowerr1 + cur1; belowerr1 = bnexterr; cur1 += delta; /* form error * 7 */ bnexterr = cur2; /* Process component 2 */ delta = cur2 * 2; cur2 += delta; /* form error * 3 */ errorptr[2] = (FSERROR) (bpreverr2 + cur2); cur2 += delta; /* form error * 5 */ bpreverr2 = belowerr2 + cur2; belowerr2 = bnexterr; cur2 += delta; /* form error * 7 */ } /* At this point curN contains the 7/16 error value to be propagated * to the next pixel on the current line, and all the errors for the * next line have been shifted over. We are therefore ready to move on. */ inptr += dir; /* Advance pixel pointers to next column */ outptr += dir; errorptr += dir3; /* advance errorptr to current column */ } /* Post-loop cleanup: we must unload the final error values into the * final fserrors[] entry. Note we need not unload belowerrN because * it is for the dummy column before or after the actual array. */ errorptr[0] = (FSERROR) bpreverr0; /* unload prev errs into array */ errorptr[1] = (FSERROR) bpreverr1; errorptr[2] = (FSERROR) bpreverr2; } } /* * Initialize the error-limiting transfer function (lookup table). * The raw F-S error computation can potentially compute error values of up to * +- MAXJSAMPLE. But we want the maximum correction applied to a pixel to be * much less, otherwise obviously wrong pixels will be created. (Typical * effects include weird fringes at color-area boundaries, isolated bright * pixels in a dark area, etc.) The standard advice for avoiding this problem * is to ensure that the "corners" of the color cube are allocated as output * colors; then repeated errors in the same direction cannot cause cascading * error buildup. However, that only prevents the error from getting * completely out of hand; Aaron Giles reports that error limiting improves * the results even with corner colors allocated. * A simple clamping of the error values to about +- MAXJSAMPLE/8 works pretty * well, but the smoother transfer function used below is even better. Thanks * to Aaron Giles for this idea. */ LOCAL (void) init_error_limit (gdImagePtr oim, gdImagePtr nim, my_cquantize_ptr cquantize) /* Allocate and fill in the error_limiter table */ { int *table; int in, out; (void)oim; (void)nim; cquantize->error_limiter_storage = (int *) gdMalloc ((MAXJSAMPLE * 2 + 1) * sizeof (int)); if (!cquantize->error_limiter_storage) { return; } table = cquantize->error_limiter_storage; table += MAXJSAMPLE; /* so can index -MAXJSAMPLE .. +MAXJSAMPLE */ cquantize->error_limiter = table; #define STEPSIZE ((MAXJSAMPLE+1)/16) /* Map errors 1:1 up to +- MAXJSAMPLE/16 */ out = 0; for (in = 0; in < STEPSIZE; in++, out++) { table[in] = out; table[-in] = -out; } /* Map errors 1:2 up to +- 3*MAXJSAMPLE/16 */ for (; in < STEPSIZE * 3; in++, out += (in & 1) ? 0 : 1) { table[in] = out; table[-in] = -out; } /* Clamp the rest to final out value (which is (MAXJSAMPLE+1)/8) */ for (; in <= MAXJSAMPLE; in++) { table[in] = out; table[-in] = -out; } #undef STEPSIZE } /* * Finish up at the end of each pass. */ static void zeroHistogram (hist3d histogram) { int i; /* Zero the histogram or inverse color map */ for (i = 0; i < HIST_C0_ELEMS; i++) { memset (histogram[i], 0, HIST_C1_ELEMS * HIST_C2_ELEMS * sizeof (histcell)); } } /* Selects quantization method used for subsequent gdImageTrueColorToPalette calls. See gdPaletteQuantizationMethod enum (e.g. GD_QUANT_NEUQUANT, GD_QUANT_LIQ). Speed is from 1 (highest quality) to 10 (fastest). Speed 0 selects method-specific default (recommended). Returns FALSE if the given method is invalid or not available. */ BGD_DECLARE(int) gdImageTrueColorToPaletteSetMethod (gdImagePtr im, int method, int speed) { #ifndef HAVE_LIBIMAGEQUANT_H if (method == GD_QUANT_LIQ) { return FALSE; } #endif if (method >= GD_QUANT_DEFAULT && method <= GD_QUANT_LIQ) { im->paletteQuantizationMethod = method; if (speed < 0 || speed > 10) { speed = 0; } im->paletteQuantizationSpeed = speed; } return TRUE; } /* Chooses quality range that subsequent call to gdImageTrueColorToPalette will aim for. Min and max quality is in range 1-100 (1 = ugly, 100 = perfect). Max must be higher than min. If palette cannot represent image with at least min_quality, then image will remain true-color. If palette can represent image with quality better than max_quality, then lower number of colors will be used. This function has effect only when GD_QUANT_LIQ method has been selected. */ BGD_DECLARE(void) gdImageTrueColorToPaletteSetQuality (gdImagePtr im, int min_quality, int max_quality) { if (min_quality >= 0 && min_quality <= 100 && max_quality >= 0 && max_quality <= 100 && min_quality <= max_quality) { im->paletteQuantizationMinQuality = min_quality; im->paletteQuantizationMaxQuality = max_quality; } } static int gdImageTrueColorToPaletteBody (gdImagePtr oim, int dither, int colorsWanted, gdImagePtr *cimP); BGD_DECLARE(gdImagePtr) gdImageCreatePaletteFromTrueColor (gdImagePtr im, int dither, int colorsWanted) { gdImagePtr nim; if (TRUE == gdImageTrueColorToPaletteBody(im, dither, colorsWanted, &nim)) { return nim; } return NULL; } BGD_DECLARE(int) gdImageTrueColorToPalette (gdImagePtr im, int dither, int colorsWanted) { return gdImageTrueColorToPaletteBody(im, dither, colorsWanted, 0); } #ifdef HAVE_LIBIMAGEQUANT_H /** LIQ library needs pixels in RGBA order with alpha 0-255 (opaque 255). This callback is run whenever source rows need to be converted from GD's format. */ static void convert_gdpixel_to_rgba(liq_color output_row[], int y, int width, void *userinfo) { gdImagePtr oim = userinfo; int x; for(x = 0; x < width; x++) { output_row[x].r = gdTrueColorGetRed(input_buf[y][x]) * 255/gdRedMax; output_row[x].g = gdTrueColorGetGreen(input_buf[y][x]) * 255/gdGreenMax; output_row[x].b = gdTrueColorGetBlue(input_buf[y][x]) * 255/gdBlueMax; int alpha = gdTrueColorGetAlpha(input_buf[y][x]); if (gdAlphaOpaque < gdAlphaTransparent) { alpha = gdAlphaTransparent - alpha; } output_row[x].a = alpha * 255/gdAlphaMax; } } #endif static void free_truecolor_image_data(gdImagePtr oim) { int i; oim->trueColor = 0; /* Junk the truecolor pixels */ for (i = 0; i < oim->sy; i++) { gdFree (oim->tpixels[i]); } gdFree (oim->tpixels); oim->tpixels = 0; } /* * Module initialization routine for 2-pass color quantization. */ static int gdImageTrueColorToPaletteBody (gdImagePtr oim, int dither, int colorsWanted, gdImagePtr *cimP) { my_cquantize_ptr cquantize = NULL; int i, conversionSucceeded=0; /* Allocate the JPEG palette-storage */ size_t arraysize; int maxColors = gdMaxColors; gdImagePtr nim; if (cimP) { nim = gdImageCreate(oim->sx, oim->sy); *cimP = nim; if (!nim) { return FALSE; } } else { nim = oim; } if (!oim->trueColor) { /* (Almost) nothing to do! */ if (cimP) { gdImageCopy(nim, oim, 0, 0, 0, 0, oim->sx, oim->sy); *cimP = nim; } return TRUE; } /* If we have a transparent color (the alphaless mode of transparency), we * must reserve a palette entry for it at the end of the palette. */ if (oim->transparent >= 0) { maxColors--; } if (colorsWanted > maxColors) { colorsWanted = maxColors; } if (!cimP) { nim->pixels = gdCalloc (sizeof (unsigned char *), oim->sy); if (!nim->pixels) { /* No can do */ goto outOfMemory; } for (i = 0; (i < nim->sy); i++) { nim->pixels[i] = (unsigned char *) gdCalloc (sizeof (unsigned char *), oim->sx); if (!nim->pixels[i]) { goto outOfMemory; } } } if (oim->paletteQuantizationMethod == GD_QUANT_NEUQUANT) { if (cimP) { /* NeuQuant alwasy creates a copy, so the new blank image can't be used */ gdImageDestroy(nim); } nim = gdImageNeuQuant(oim, colorsWanted, oim->paletteQuantizationSpeed ? oim->paletteQuantizationSpeed : 2); if (cimP) { *cimP = nim; } else { gdImageCopy(oim, nim, 0, 0, 0, 0, oim->sx, oim->sy); gdImageDestroy(nim); } return TRUE; } #ifdef HAVE_LIBIMAGEQUANT_H if (oim->paletteQuantizationMethod == GD_QUANT_DEFAULT || oim->paletteQuantizationMethod == GD_QUANT_LIQ) { liq_attr *attr = liq_attr_create_with_allocator(gdMalloc, gdFree); liq_image *image; liq_result *remap; int remapped_ok = 0; liq_set_max_colors(attr, colorsWanted); /* by default make it fast to match speed of previous implementation */ liq_set_speed(attr, oim->paletteQuantizationSpeed ? oim->paletteQuantizationSpeed : 9); if (oim->paletteQuantizationMaxQuality) { liq_set_quality(attr, oim->paletteQuantizationMinQuality, oim->paletteQuantizationMaxQuality); } image = liq_image_create_custom(attr, convert_gdpixel_to_rgba, oim, oim->sx, oim->sy, 0); remap = liq_quantize_image(attr, image); if (!remap) { /* minimum quality not met, leave image unmodified */ liq_image_destroy(image); liq_attr_destroy(attr); goto outOfMemory; } liq_set_dithering_level(remap, dither ? 1 : 0); if (LIQ_OK == liq_write_remapped_image_rows(remap, image, output_buf)) { remapped_ok = 1; const liq_palette *pal = liq_get_palette(remap); nim->transparent = -1; unsigned int icolor; for(icolor=0; icolor < pal->count; icolor++) { nim->open[icolor] = 0; nim->red[icolor] = pal->entries[icolor].r * gdRedMax/255; nim->green[icolor] = pal->entries[icolor].g * gdGreenMax/255; nim->blue[icolor] = pal->entries[icolor].b * gdBlueMax/255; int alpha = pal->entries[icolor].a * gdAlphaMax/255; if (gdAlphaOpaque < gdAlphaTransparent) { alpha = gdAlphaTransparent - alpha; } nim->alpha[icolor] = alpha; if (nim->transparent == -1 && alpha == gdAlphaTransparent) { nim->transparent = icolor; } } nim->colorsTotal = pal->count; } liq_result_destroy(remap); liq_image_destroy(image); liq_attr_destroy(attr); if (remapped_ok) { if (!cimP) { free_truecolor_image_data(oim); } return TRUE; } } #endif cquantize = (my_cquantize_ptr) gdCalloc (sizeof (my_cquantizer), 1); if (!cquantize) { /* No can do */ goto outOfMemory; } cquantize->fserrors = NULL; /* flag optional arrays not allocated */ cquantize->error_limiter = NULL; /* Allocate the histogram/inverse colormap storage */ cquantize->histogram = (hist3d) gdMalloc (HIST_C0_ELEMS * sizeof (hist2d)); for (i = 0; i < HIST_C0_ELEMS; i++) { cquantize->histogram[i] = (hist2d) gdMalloc (HIST_C1_ELEMS * HIST_C2_ELEMS * sizeof (histcell)); if (!cquantize->histogram[i]) { goto outOfMemory; } } cquantize->fserrors = (FSERRPTR) gdMalloc (3 * sizeof (FSERROR)); init_error_limit (oim, nim, cquantize); arraysize = (size_t) ((nim->sx + 2) * (3 * sizeof (FSERROR))); /* Allocate Floyd-Steinberg workspace. */ cquantize->fserrors = gdReallocEx(cquantize->fserrors, arraysize); if (!cquantize->fserrors) { goto outOfMemory; } memset(cquantize->fserrors, 0, arraysize); cquantize->on_odd_row = FALSE; /* Do the work! */ zeroHistogram (cquantize->histogram); prescan_quantize (oim, nim, cquantize); /* TBB 2.0.5: pass colorsWanted, not 256! */ select_colors (oim, nim, cquantize, colorsWanted); zeroHistogram (cquantize->histogram); if (dither) { pass2_fs_dither (oim, nim, cquantize); } else { pass2_no_dither (oim, nim, cquantize); } #if 0 /* 2.0.12; we no longer attempt full alpha in palettes */ if (cquantize->transparentIsPresent) { int mt = -1; int mtIndex = -1; for (i = 0; (i < im->colorsTotal); i++) { if (im->alpha[i] > mt) { mtIndex = i; mt = im->alpha[i]; } } for (i = 0; (i < im->colorsTotal); i++) { if (im->alpha[i] == mt) { im->alpha[i] = gdAlphaTransparent; } } } if (cquantize->opaqueIsPresent) { int mo = 128; int moIndex = -1; for (i = 0; (i < im->colorsTotal); i++) { if (im->alpha[i] < mo) { moIndex = i; mo = im->alpha[i]; } } for (i = 0; (i < im->colorsTotal); i++) { if (im->alpha[i] == mo) { im->alpha[i] = gdAlphaOpaque; } } } #endif /* If we had a 'transparent' color, increment the color count so it's * officially in the palette and convert the transparent variable to point to * an index rather than a color (Its data already exists and transparent * pixels have already been mapped to it by this point, it is done late as to * avoid color matching / dithering with it). */ if (oim->transparent >= 0) { nim->transparent = nim->colorsTotal; nim->colorsTotal++; } /* Success! Get rid of the truecolor image data. */ conversionSucceeded = TRUE; if (!cimP) { free_truecolor_image_data(oim); } goto freeQuantizeData; /* Tediously free stuff. */ outOfMemory: conversionSucceeded = FALSE; if (oim->trueColor) { if (!cimP) { /* On failure only */ if (nim->pixels) { for (i = 0; i < nim->sy; i++) { if (nim->pixels[i]) { gdFree (nim->pixels[i]); } } gdFree (nim->pixels); } nim->pixels = NULL; } else { gdImageDestroy(nim); *cimP = 0; } } freeQuantizeData: if (cquantize) { if (cquantize->histogram) { for (i = 0; i < HIST_C0_ELEMS; i++) { if (cquantize->histogram[i]) { gdFree (cquantize->histogram[i]); } } gdFree (cquantize->histogram); } if (cquantize->fserrors) { gdFree (cquantize->fserrors); } if (cquantize->error_limiter_storage) { gdFree (cquantize->error_limiter_storage); } gdFree (cquantize); } return conversionSucceeded; } #endif libgd-gd-2.1.1/src/gd_transform.c000066400000000000000000000026001245535672000166130ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include "gd.h" BGD_DECLARE(void) gdImageFlipVertical(gdImagePtr im) { register int x, y; if (im->trueColor) { for (y = 0; y < im->sy / 2; y++) { int *row_dst = im->tpixels[y]; int *row_src = im->tpixels[im->sy - 1 - y]; for (x = 0; x < im->sx; x++) { register int p; p = row_dst[x]; row_dst[x] = im->tpixels[im->sy - 1 - y][x]; row_src[x] = p; } } } else { unsigned char p; for (y = 0; y < im->sy / 2; y++) { for (x = 0; x < im->sx; x++) { p = im->tpixels[y][x]; im->tpixels[y][x] = im->tpixels[im->sy - 1 - y][x]; im->tpixels[im->sy - 1 - y][x] = p; } } } return; } BGD_DECLARE(void) gdImageFlipHorizontal(gdImagePtr im) { int x, y; if (im->trueColor) { int *px1, *px2, tmp; for (y = 0; y < im->sy; y++) { px1 = im->tpixels[y]; px2 = im->tpixels[y] + im->sx - 1; for (x = 0; x < (im->sx >> 1); x++) { tmp = *px1; *px1 = *px2; *px2 = tmp; px1++; px2--; } } } else { unsigned char *px1, *px2, tmp; for (y = 0; y < im->sy; y++) { px1 = im->pixels[y]; px2 = im->pixels[y] + im->sx - 1; for (x = 0; x < (im->sx >> 1); x++) { tmp = *px1; *px1 = *px2; *px2 = tmp; px1++; px2--; } } } } BGD_DECLARE(void) gdImageFlipBoth(gdImagePtr im) { gdImageFlipVertical(im); gdImageFlipHorizontal(im); } libgd-gd-2.1.1/src/gd_version.c000066400000000000000000000012111245535672000162620ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include "gd.h" /* These functions return the version information. We use functions * so that changes in the shared library will automatically be * reflected in executables using it without recompiling them. */ BGD_DECLARE(int) gdMajorVersion() { return GD_MAJOR_VERSION; } BGD_DECLARE(int) gdMinorVersion() { return GD_MINOR_VERSION; } BGD_DECLARE(int) gdReleaseVersion() { return GD_RELEASE_VERSION; } BGD_DECLARE(const char *) gdExtraVersion() { return GD_EXTRA_VERSION; } BGD_DECLARE(const char *) gdVersionString() { return GD_VERSION_STRING; } libgd-gd-2.1.1/src/gd_wbmp.c000066400000000000000000000150631245535672000155540ustar00rootroot00000000000000/* * WBMP: Wireless Bitmap Type 0: B/W, Uncompressed Bitmap * Specification of the WBMP format can be found in the file: * SPEC-WAESpec-19990524.pdf * You can download the WAP specification on: http://www.wapforum.com/ * * gd_wbmp.c * * Copyright (C) Johan Van den Brande (johan@vandenbrande.com) * * Fixed: gdImageWBMPPtr, gdImageWBMP * * Recoded: gdImageWBMPCtx for use with my wbmp library * (wbmp library included, but you can find the latest distribution * at http://www.vandenbrande.com/wbmp) * * Implemented: gdImageCreateFromWBMPCtx, gdImageCreateFromWBMP * *-------------------------------------------------------------------------- * * Parts of this code are from Maurice Smurlo. * ** Copyright (C) Maurice Szmurlo --- T-SIT --- January 2000 ** (Maurice.Szmurlo@info.unicaen.fr) ** ** Permission to use, copy, modify, and distribute this software and its ** documentation for any purpose and without fee is hereby granted, provided ** that the above copyright notice appear in all copies and that both that ** copyright notice and this permission notice appear in supporting ** documentation. This software is provided "as is" without express or ** implied warranty. * *-------------------------------------------------------------------------- * * Parts of this code are inspired by 'pbmtowbmp.c' and 'wbmptopbm.c' by * Terje Sannum . * ** Permission to use, copy, modify, and distribute this software and its ** documentation for any purpose and without fee is hereby granted, provided ** that the above copyright notice appear in all copies and that both that ** copyright notice and this permission notice appear in supporting ** documentation. This software is provided "as is" without express or ** implied warranty. * *-------------------------------------------------------------------------- * * Todo: * * gdCreateFromWBMP function for reading WBMP files * *-------------------------------------------------------------------------- */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include "gd.h" #include "gd_errors.h" #include "gdfonts.h" #include #include #include #include "wbmp.h" /* gd_putout * --------- * Wrapper around gdPutC for use with writewbmp */ void gd_putout(int i, void *out) { gdPutC(i, (gdIOCtx *)out); } /* gd_getin * -------- * Wrapper around gdGetC for use with readwbmp */ int gd_getin(void *in) { return (gdGetC((gdIOCtx *)in)); } /* gdImageWBMPCtx * -------------- * Write the image as a wbmp file * Parameters are: * image: gd image structure; * fg: the index of the foreground color. any other value will be * considered as background and will not be written * out: the stream where to write */ BGD_DECLARE(void) gdImageWBMPCtx(gdImagePtr image, int fg, gdIOCtx *out) { int x, y, pos; Wbmp *wbmp; /* create the WBMP */ if((wbmp = createwbmp(gdImageSX(image), gdImageSY(image), WBMP_WHITE)) == NULL) { gd_error("Could not create WBMP\n"); return; } /* fill up the WBMP structure */ pos = 0; for(y = 0; y < gdImageSY(image); y++) { for(x = 0; x < gdImageSX(image); x++) { if(gdImageGetPixel(image, x, y) == fg) { wbmp->bitmap[pos] = WBMP_BLACK; } pos++; } } /* write the WBMP to a gd file descriptor */ if(writewbmp(wbmp, &gd_putout, out)) { gd_error("Could not save WBMP\n"); } /* des submitted this bugfix: gdFree the memory. */ freewbmp(wbmp); } /* Function: gdImageCreateFromWBMPCtx Reads in a WBMP image via a struct. See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromWBMPCtx(gdIOCtx *infile) { Wbmp *wbmp; gdImagePtr im = NULL; int black, white; int col, row, pos; if(readwbmp(&gd_getin, infile, &wbmp)) { return (NULL); } if(!(im = gdImageCreate(wbmp->width, wbmp->height))) { freewbmp(wbmp); return NULL; } /* create the background color */ white = gdImageColorAllocate(im, 255, 255, 255); /* create foreground color */ black = gdImageColorAllocate(im, 0, 0, 0); /* fill in image (in a wbmp 1 = white/ 0 = black) */ pos = 0; for(row = 0; row < wbmp->height; row++) { for(col = 0; col < wbmp->width; col++) { if(wbmp->bitmap[pos++] == WBMP_WHITE) { gdImageSetPixel(im, col, row, white); } else { gdImageSetPixel(im, col, row, black); } } } freewbmp(wbmp); return im; } /* Function: gdImageCreateFromWBMP is called to load images from WBMP format files. Invoke with an already opened pointer to a file containing the desired image. returns a gdImagePtr to the new image, or NULL if unable to load the image (most often because the file is corrupt or does not contain a WBMP image). does not close the file. You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using . Variants: creates an image from WBMP data (i.e. the contents of a WBMP file) already in memory. reads in an image using the functions in a struct. Parameters: infile - The input FILE pointer Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > FILE *in; > in = fopen("mywbmp.wbmp", "rb"); > im = gdImageCreateFromWBMP(in); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromWBMP(FILE *inFile) { gdImagePtr im; gdIOCtx *in = gdNewFileCtx(inFile); if (in == NULL) return NULL; im = gdImageCreateFromWBMPCtx(in); in->gd_free(in); return im; } /* Function: gdImageCreateFromWBMPPtr Parameters: size - size of WBMP data in bytes. data - WBMP data (i.e. contents of a WBMP file). See . */ BGD_DECLARE(gdImagePtr) gdImageCreateFromWBMPPtr(int size, void *data) { gdImagePtr im; gdIOCtx *in = gdNewDynamicCtxEx(size, data, 0); if(!in) { return 0; } im = gdImageCreateFromWBMPCtx(in); in->gd_free(in); return im; } /* gdImageWBMP */ BGD_DECLARE(void) gdImageWBMP(gdImagePtr im, int fg, FILE *outFile) { gdIOCtx *out = gdNewFileCtx(outFile); if (out == NULL) return; gdImageWBMPCtx(im, fg, out); out->gd_free(out); } /* gdImageWBMPPtr */ BGD_DECLARE(void *) gdImageWBMPPtr(gdImagePtr im, int *size, int fg) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); if (out == NULL) return NULL; gdImageWBMPCtx(im, fg, out); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } libgd-gd-2.1.1/src/gd_webp.c000066400000000000000000000113321245535672000155370ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include #include #include #include #include "gd.h" #include "gd_errors.h" #ifdef HAVE_LIBVPX #include "webpimg.h" #include "gdhelpers.h" extern void gd_YUV420toRGBA(uint8* Y, uint8* U, uint8* V, gdImagePtr im); extern void gd_RGBAToYUV420(gdImagePtr im2, uint8* Y, uint8* U, uint8* V); const char * gdWebpGetVersionString() { return "not defined"; } BGD_DECLARE(gdImagePtr) gdImageCreateFromWebp (FILE * inFile) { gdImagePtr im; gdIOCtx *in = gdNewFileCtx(inFile); im = gdImageCreateFromWebpCtx(in); in->gd_free(in); return im; } BGD_DECLARE(gdImagePtr) gdImageCreateFromWebpPtr (int size, void *data) { int width, height, ret; unsigned char *Y = NULL; unsigned char *U = NULL; unsigned char *V = NULL; gdImagePtr im; ret = WebPDecode(data, size, &Y, &U, &V, &width, &height); if (ret != webp_success) { if (Y) free(Y); if (U) free(U); if (V) free(V); gd_error("WebP decode: fail to decode input data"); return NULL; } im = gdImageCreateTrueColor(width, height); if (!im) { return NULL; } gd_YUV420toRGBA(Y, U, V, im); return im; } #define GD_WEBP_ALLOC_STEP (4*1024) BGD_DECLARE(gdImagePtr) gdImageCreateFromWebpCtx (gdIOCtx * infile) { int width, height, ret; unsigned char *filedata = NULL; unsigned char *read, *temp; unsigned char *Y = NULL; unsigned char *U = NULL; unsigned char *V = NULL; size_t size = 0, n; gdImagePtr im; do { temp = gdRealloc(filedata, size+GD_WEBP_ALLOC_STEP); if (temp) { filedata = temp; read = temp + size; } else { if (filedata) { gdFree(filedata); } gd_error("WebP decode: realloc failed"); return NULL; } n = gdGetBuf(read, GD_WEBP_ALLOC_STEP, infile); size += n; } while (n>0); ret = WebPDecode(filedata, size, &Y, &U, &V, &width, &height); gdFree(filedata); if (ret != webp_success) { if (Y) free(Y); if (U) free(U); if (V) free(V); gd_error("WebP decode: fail to decode input data"); return NULL; } im = gdImageCreateTrueColor(width, height); gd_YUV420toRGBA(Y, U, V, im); return im; } BGD_DECLARE(void) gdImageWebpEx (gdImagePtr im, FILE * outFile, int quantization) { gdIOCtx *out = gdNewFileCtx(outFile); gdImageWebpCtx(im, out, quantization); out->gd_free(out); } BGD_DECLARE(void) gdImageWebp (gdImagePtr im, FILE * outFile) { gdIOCtx *out = gdNewFileCtx(outFile); gdImageWebpCtx(im, out, -1); out->gd_free(out); } BGD_DECLARE(void *) gdImageWebpPtr (gdImagePtr im, int *size) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); gdImageWebpCtx(im, out, -1); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } BGD_DECLARE(void *) gdImageWebpPtrEx (gdImagePtr im, int *size, int quantization) { void *rv; gdIOCtx *out = gdNewDynamicCtx(2048, NULL); gdImageWebpCtx(im, out, quantization); rv = gdDPExtractData(out, size); out->gd_free(out); return rv; } /* * Maps normalized QP (quality) to VP8 QP */ int mapQualityToVP8QP(int quality) { #define MIN_QUALITY 0 #define MAX_QUALITY 100 #define MIN_VP8QP 1 #define MAX_VP8QP 63 const float scale = MAX_VP8QP - MIN_VP8QP; const float vp8qp = scale * (MAX_QUALITY - quality) / (MAX_QUALITY - MIN_QUALITY) + MIN_VP8QP; if (quality < MIN_QUALITY || quality > MAX_QUALITY) { gd_error("Wrong quality value %d.", quality); return -1; } return (int)(vp8qp + 0.5); } /* This routine is based in part on code from Dale Lutz (Safe Software Inc.) * and in part on demo code from Chapter 15 of "PNG: The Definitive Guide" * (http://www.cdrom.com/pub/png/pngbook.html). */ BGD_DECLARE(void) gdImageWebpCtx (gdImagePtr im, gdIOCtx * outfile, int quantization) { int width = im->sx; int height = im->sy; int yuv_width, yuv_height, yuv_nbytes, ret; int vp8_quality; unsigned char *Y = NULL, *U = NULL, *V = NULL; unsigned char *filedata = NULL; /* Conversion to Y,U,V buffer */ yuv_width = (width + 1) >> 1; yuv_height = (height + 1) >> 1; yuv_nbytes = width * height + 2 * yuv_width * yuv_height; if ((Y = (unsigned char *)gdCalloc(yuv_nbytes, sizeof(unsigned char))) == NULL) { gd_error("gd-webp error: cannot allocate Y buffer"); return; } vp8_quality = mapQualityToVP8QP(quantization); U = Y + width * height; V = U + yuv_width * yuv_height; gd_RGBAToYUV420(im, Y, U, V); /* Encode Y,U,V and write data to file */ ret = WebPEncode(Y, U, V, width, height, width, yuv_width, yuv_height, yuv_width, vp8_quality, &filedata, &yuv_nbytes, NULL); gdFree(Y); if (ret != webp_success) { if (filedata) { free(filedata); } gd_error("gd-webp error: WebP Encoder failed"); return; } gdPutBuf (filedata, yuv_nbytes, outfile); free(filedata); } #endif /* HAVE_LIBVPX */ libgd-gd-2.1.1/src/gd_xbm.c000066400000000000000000000121511245535672000153700ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include #include #include #include "gd.h" #include "gd_errors.h" #include "gdhelpers.h" #ifdef _MSC_VER # define strcasecmp _stricmp #endif #define MAX_XBM_LINE_SIZE 255 /* Function: gdImageCreateFromXbm is called to load images from X bitmap format files. Invoke with an already opened pointer to a file containing the desired image. returns a to the new image, or NULL if unable to load the image (most often because the file is corrupt or does not contain an X bitmap format image). does not close the file. You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using . Parameters: fd - The input FILE pointer Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > FILE *in; > in = fopen("myxbm.xbm", "rb"); > im = gdImageCreateFromXbm(in); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromXbm(FILE * fd) { char fline[MAX_XBM_LINE_SIZE]; char iname[MAX_XBM_LINE_SIZE]; char *type; int value; unsigned int width = 0, height = 0; int fail = 0; int max_bit = 0; gdImagePtr im; int bytes = 0, i; int bit, x = 0, y = 0; int ch; char h[8]; unsigned int b; rewind(fd); while (fgets(fline, MAX_XBM_LINE_SIZE, fd)) { fline[MAX_XBM_LINE_SIZE-1] = '\0'; if (strlen(fline) == MAX_XBM_LINE_SIZE-1) { return 0; } if (sscanf(fline, "#define %s %d", iname, &value) == 2) { if (!(type = strrchr(iname, '_'))) { type = iname; } else { type++; } if (!strcmp("width", type)) { width = (unsigned int) value; } if (!strcmp("height", type)) { height = (unsigned int) value; } } else { if ( sscanf(fline, "static unsigned char %s = {", iname) == 1 || sscanf(fline, "static char %s = {", iname) == 1) { max_bit = 128; } else if (sscanf(fline, "static unsigned short %s = {", iname) == 1 || sscanf(fline, "static short %s = {", iname) == 1) { max_bit = 32768; } if (max_bit) { bytes = (width * height / 8) + 1; if (!bytes) { return 0; } if (!(type = strrchr(iname, '_'))) { type = iname; } else { type++; } if (!strcmp("bits[]", type)) { break; } } } } if (!bytes || !max_bit) { return 0; } if(!(im = gdImageCreate(width, height))) { return 0; } gdImageColorAllocate(im, 255, 255, 255); gdImageColorAllocate(im, 0, 0, 0); h[2] = '\0'; h[4] = '\0'; for (i = 0; i < bytes; i++) { while (1) { if ((ch=getc(fd)) == EOF) { fail = 1; break; } if (ch == 'x') { break; } } if (fail) { break; } /* Get hex value */ if ((ch=getc(fd)) == EOF) { break; } h[0] = ch; if ((ch=getc(fd)) == EOF) { break; } h[1] = ch; if (max_bit == 32768) { if ((ch=getc(fd)) == EOF) { break; } h[2] = ch; if ((ch=getc(fd)) == EOF) { break; } h[3] = ch; } sscanf(h, "%x", &b); for (bit = 1; bit <= max_bit; bit = bit << 1) { gdImageSetPixel(im, x++, y, (b & bit) ? 1 : 0); if (x == im->sx) { x = 0; y++; if (y == im->sy) { return im; } break; } } } gd_error("EOF before image was complete"); gdImageDestroy(im); return 0; } /* {{{ gdCtxPrintf */ static void gdCtxPrintf(gdIOCtx * out, const char *format, ...) { char buf[4096]; int len; va_list args; va_start(args, format); len = vsnprintf(buf, sizeof(buf)-1, format, args); va_end(args); out->putBuf(out, buf, len); } /* }}} */ /* {{{ gdImageXbmCtx */ BGD_DECLARE(void) gdImageXbmCtx(gdImagePtr image, char* file_name, int fg, gdIOCtx * out) { int x, y, c, b, sx, sy, p; char *name, *f; size_t i, l; name = file_name; if ((f = strrchr(name, '/')) != NULL) name = f+1; if ((f = strrchr(name, '\\')) != NULL) name = f+1; name = strdup(name); if ((f = strrchr(name, '.')) != NULL && !strcasecmp(f, ".XBM")) *f = '\0'; if ((l = strlen(name)) == 0) { free(name); name = strdup("image"); } else { for (i=0; imru = NULL; head->size = size; head->gdCacheTest = gdCacheTest; head->gdCacheFetch = gdCacheFetch; head->gdCacheRelease = gdCacheRelease; return head; } void gdCacheDelete(gdCache_head_t *head) { gdCache_element_t *elem, *prev; elem = head->mru; while(elem) { (*(head->gdCacheRelease))(elem->userdata); prev = elem; elem = elem->next; gdFree((char *)prev); } gdFree((char *)head); } void * gdCacheGet(gdCache_head_t *head, void *keydata) { int i = 0; gdCache_element_t *elem, *prev = NULL, *prevprev = NULL; void *userdata; elem = head->mru; while(elem) { if((*(head->gdCacheTest))(elem->userdata, keydata)) { if(i) { /* if not already most-recently-used */ /* relink to top of list */ prev->next = elem->next; elem->next = head->mru; head->mru = elem; } return elem->userdata; } prevprev = prev; prev = elem; elem = elem->next; i++; } userdata = (*(head->gdCacheFetch))(&(head->error), keydata); if(!userdata) { /* if there was an error in the fetch then don't cache */ return NULL; } if(i < head->size) { /* cache still growing - add new elem */ elem = (gdCache_element_t *)gdMalloc(sizeof(gdCache_element_t)); if(!elem) { (*(head->gdCacheRelease)) (userdata); return NULL; } } else { /* cache full - replace least-recently-used */ /* preveprev becomes new end of list */ prevprev->next = NULL; elem = prev; (*(head->gdCacheRelease))(elem->userdata); } /* relink to top of list */ elem->next = head->mru; head->mru = elem; elem->userdata = userdata; return userdata; } /*********************************************************/ /* test stub */ /*********************************************************/ #ifdef TEST #include typedef struct { int key; int value; } key_value_t; static int cacheTest(void *map, void *key) { return (((key_value_t *)map)->key == *(int *)key); } static void *cacheFetch(char **error, void *key) { key_value_t *map; map = (key_value_t *)gdMalloc(sizeof(key_value_t)); if (!map) { *error = "gdMalloc failed"; return NULL; } map->key = *(int *)key; map->value = 3; *error = NULL; return (void *)map; } static void cacheRelease(void *map) { gdFree((char *)map); } int main(char *argv[], int argc) { gdCache_head_t *cacheTable; int elem, key; cacheTable = gdCacheCreate(3, cacheTest, cacheFetch, cacheRelease); if(!cacheTable) { exit(1); } key = 20; elem = *(int *)gdCacheGet(cacheTable, &key); key = 30; elem = *(int *)gdCacheGet(cacheTable, &key); key = 40; elem = *(int *)gdCacheGet(cacheTable, &key); key = 50; elem = *(int *)gdCacheGet(cacheTable, &key); key = 30; elem = *(int *)gdCacheGet(cacheTable, &key); key = 30; elem = *(int *)gdCacheGet(cacheTable, &key); gdCacheDelete(cacheTable); return 0; } #endif /* TEST */ #endif /* NEED_CACHE */ libgd-gd-2.1.1/src/gdcache.h000066400000000000000000000055221245535672000155170ustar00rootroot00000000000000#ifdef __cplusplus extern "C" { #endif /* * gdcache.h * * Caches of pointers to user structs in which the least-recently-used * element is replaced in the event of a cache miss after the cache has * reached a given size. * * John Ellson (ellson@graphviz.org) Oct 31, 1997 * * Test this with: * gcc -o gdcache -g -Wall -DTEST gdcache.c * * The cache is implemented by a singly-linked list of elements * each containing a pointer to a user struct that is being managed by * the cache. * * The head structure has a pointer to the most-recently-used * element, and elements are moved to this position in the list each * time they are used. The head also contains pointers to three * user defined functions: * - a function to test if a cached userdata matches some keydata * - a function to provide a new userdata struct to the cache * if there has been a cache miss. * - a function to release a userdata struct when it is * no longer being managed by the cache * * In the event of a cache miss the cache is allowed to grow up to * a specified maximum size. After the maximum size is reached then * the least-recently-used element is discarded to make room for the * new. The most-recently-returned value is always left at the * beginning of the list after retrieval. * * In the current implementation the cache is traversed by a linear * search from most-recent to least-recent. This linear search * probably limits the usefulness of this implementation to cache * sizes of a few tens of elements. */ /*********************************************************/ /* header */ /*********************************************************/ #include #ifndef NULL # define NULL (void *)0 #endif /* user defined function templates */ typedef int (*gdCacheTestFn_t)(void *userdata, void *keydata); typedef void *(*gdCacheFetchFn_t)(char **error, void *keydata); typedef void (*gdCacheReleaseFn_t)(void *userdata); /* element structure */ typedef struct gdCache_element_s gdCache_element_t; struct gdCache_element_s { gdCache_element_t *next; void *userdata; }; /* head structure */ typedef struct gdCache_head_s gdCache_head_t; struct gdCache_head_s { gdCache_element_t *mru; int size; char *error; gdCacheTestFn_t gdCacheTest; gdCacheFetchFn_t gdCacheFetch; gdCacheReleaseFn_t gdCacheRelease; }; /* function templates */ gdCache_head_t *gdCacheCreate(int size, gdCacheTestFn_t gdCacheTest, gdCacheFetchFn_t gdCacheFetch, gdCacheReleaseFn_t gdCacheRelease ); void gdCacheDelete(gdCache_head_t *head); void *gdCacheGet(gdCache_head_t *head, void *keydata); #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/gdcmpgif.c000066400000000000000000000035561245535672000157210ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #ifndef _WIN32 #include /* For unlink function */ #endif #include "gd.h" /* A short program which converts a .png file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ void CompareImages(char *msg, gdImagePtr im1, gdImagePtr im2); int main(int argc, char **argv) { gdImagePtr im1, im2; FILE *in; if (argc != 3) { fprintf(stderr, "Usage: gdcmpgif filename.gif filename.gif\n"); exit(1); } in = fopen(argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit(1); } im1 = gdImageCreateFromGif(in); fclose(in); if (!im1) { fprintf(stderr, "Input is not in GIF format!\n"); exit(1); } in = fopen(argv[2], "rb"); if (!in) { fprintf(stderr, "Input file 2 does not exist!\n"); exit(1); } im2 = gdImageCreateFromGif(in); fclose(in); if (!im2) { fprintf(stderr, "Input 2 is not in GIF format!\n"); exit(1); } CompareImages("gdcmpgif", im1, im2); gdImageDestroy(im1); gdImageDestroy(im2); return 0; } void CompareImages(char *msg, gdImagePtr im1, gdImagePtr im2) { int cmpRes; cmpRes = gdImageCompare(im1, im2); if (cmpRes & GD_CMP_IMAGE) { printf("%%%s: ERROR images differ: BAD\n",msg); } else if (cmpRes != 0) { printf("%%%s: WARNING images differ: WARNING - Probably OK\n",msg); } else { printf("%%%s: OK\n",msg); return; } if (cmpRes & (GD_CMP_SIZE_X + GD_CMP_SIZE_Y)) { printf("-%s: INFO image sizes differ\n",msg); } if (cmpRes & GD_CMP_NUM_COLORS) { printf("-%s: INFO number of palette entries differ %d Vs. %d\n",msg, im1->colorsTotal, im2->colorsTotal); } if (cmpRes & GD_CMP_COLOR) { printf("-%s: INFO actual colours of pixels differ\n",msg); } } libgd-gd-2.1.1/src/gddemo.c000066400000000000000000000126551245535672000154000ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include "gd.h" #include "gdfontt.h" #include "gdfonts.h" #include "gdfontmb.h" #include "gdfontl.h" #include "gdfontg.h" int main (void) { #ifdef HAVE_LIBPNG /* Input and output files */ FILE *in; FILE *out; /* Input and output images */ gdImagePtr im_in = 0, im_out = 0; /* Brush image */ gdImagePtr brush; /* Color indexes */ int white; int blue; int red; int green; /* Points for polygon */ gdPoint points[3]; int i; /* gd fonts for font test */ gdFontPtr fonts[5]; int y; /* Create output image, in true color. */ im_out = gdImageCreateTrueColor (256 + 384, 384); /* 2.0.2: first color allocated would automatically be background in a palette based image. Since this is a truecolor image, with an automatic background of black, we must fill it explicitly. */ white = gdImageColorAllocate (im_out, 255, 255, 255); gdImageFilledRectangle (im_out, 0, 0, gdImageSX (im_out), gdImageSY (im_out), white); /* Set transparent color. */ gdImageColorTransparent (im_out, white); /* Try to load demoin.png and paste part of it into the output image. */ in = fopen ("demoin.png", "rb"); if (!in) { fprintf(stderr, "Can't load source image; this demo\n"); fprintf(stderr, "is much more impressive if demoin.png\n"); fprintf(stderr, "is available.\n"); im_in = 0; } else { int a; im_in = gdImageCreateFromPng (in); fclose (in); /* Now copy, and magnify as we do so */ gdImageCopyResampled (im_out, im_in, 32, 32, 0, 0, 192, 192, 255, 255); /* Now display variously rotated space shuttles in a circle of our own */ for (a = 0; (a < 360); a += 45) { int cx = cos (a * .0174532925) * 128; int cy = -sin (a * .0174532925) * 128; gdImageCopyRotated (im_out, im_in, 256 + 192 + cx, 192 + cy, 0, 0, gdImageSX (im_in), gdImageSY (im_in), a); } } red = gdImageColorAllocate (im_out, 255, 0, 0); green = gdImageColorAllocate (im_out, 0, 255, 0); blue = gdImageColorAllocate (im_out, 0, 0, 255); /* Fat Rectangle */ gdImageSetThickness (im_out, 4); gdImageLine (im_out, 16, 16, 240, 16, green); gdImageLine (im_out, 240, 16, 240, 240, green); gdImageLine (im_out, 240, 240, 16, 240, green); gdImageLine (im_out, 16, 240, 16, 16, green); gdImageSetThickness (im_out, 1); /* Circle */ gdImageArc (im_out, 128, 128, 60, 20, 0, 720, blue); /* Arc */ gdImageArc (im_out, 128, 128, 40, 40, 90, 270, blue); /* Flood fill: doesn't do much on a continuously variable tone jpeg original. */ gdImageFill (im_out, 8, 8, blue); /* Polygon */ points[0].x = 64; points[0].y = 0; points[1].x = 0; points[1].y = 128; points[2].x = 128; points[2].y = 128; gdImageFilledPolygon (im_out, points, 3, green); /* 2.0.12: Antialiased Polygon */ gdImageSetAntiAliased (im_out, green); for (i = 0; (i < 3); i++) { points[i].x += 128; } gdImageFilledPolygon (im_out, points, 3, gdAntiAliased); /* Brush. A fairly wild example also involving a line style! */ if (im_in) { int style[8]; brush = gdImageCreateTrueColor (16, 16); gdImageCopyResized (brush, im_in, 0, 0, 0, 0, gdImageSX (brush), gdImageSY (brush), gdImageSX (im_in), gdImageSY (im_in)); gdImageSetBrush (im_out, brush); /* With a style, so they won't overprint each other. Normally, they would, yielding a fat-brush effect. */ style[0] = 0; style[1] = 0; style[2] = 0; style[3] = 0; style[4] = 0; style[5] = 0; style[6] = 0; style[7] = 1; gdImageSetStyle (im_out, style, 8); /* Draw the styled, brushed line */ gdImageLine (im_out, 0, 255, 255, 0, gdStyledBrushed); } /* Text (non-truetype; see gdtestft for a freetype demo) */ fonts[0] = gdFontGetTiny (); fonts[1] = gdFontGetSmall (); fonts[2] = gdFontGetMediumBold (); fonts[3] = gdFontGetLarge (); fonts[4] = gdFontGetGiant (); y = 0; for (i = 0; (i <= 4); i++) { gdImageString (im_out, fonts[i], 32, 32 + y, (unsigned char *) "hi", red); y += fonts[i]->h; } y = 0; for (i = 0; (i <= 4); i++) { gdImageStringUp (im_out, fonts[i], 64 + y, 64, (unsigned char *) "hi", red); y += fonts[i]->h; } /* Random antialiased lines; coordinates all over the image, but the output will respect a small clipping rectangle */ gdImageSetClip (im_out, 0, gdImageSY (im_out) - 100, 100, gdImageSY (im_out)); /* Fixed seed for reproducibility of results */ srand (100); for (i = 0; (i < 100); i++) { int x1 = rand () % gdImageSX (im_out); int y1 = rand () % gdImageSY (im_out); int x2 = rand () % gdImageSX (im_out); int y2 = rand () % gdImageSY (im_out); gdImageSetAntiAliased (im_out, white); gdImageLine (im_out, x1, y1, x2, y2, gdAntiAliased); } /* Make output image interlaced (progressive, in the case of JPEG) */ gdImageInterlace (im_out, 1); out = fopen ("demoout.png", "wb"); /* Write PNG */ gdImagePng (im_out, out); fclose (out); out = fopen ("demoout.gif", "wb"); /* Write GIF (2.0.28) */ gdImageGif (im_out, out); fclose (out); /* 2.0.12: also write a paletteized png comparable to the gif */ out = fopen ("demooutp.png", "wb"); gdImageTrueColorToPalette (im_out, 0, 256); gdImagePng (im_out, out); fclose (out); gdImageDestroy (im_out); if (im_in) { gdImageDestroy (im_in); } #else fprintf(stderr, "No PNG library support.\n"); #endif /* HAVE_LIBPNG */ return 0; } libgd-gd-2.1.1/src/gdfontg.c000066400000000000000000003334711245535672000155730ustar00rootroot00000000000000 /* This is a header file for gd font, generated using bdftogd version 0.51 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -Misc-Fixed-Bold-R-Normal-Sans-15-140-75-75-C-90-ISO8859-2 at Mon Jan 26 14:45:58 1998. The original bdf was holding following copyright: "Libor Skarvada, libor@informatics.muni.cz" */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gdfontg.h" char gdFontGiantData[] = { /* Char 0 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 1 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 2 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, /* Char 3 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 4 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 5 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 6 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 7 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 8 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 9 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 10 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 11 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 12 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 13 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 14 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 15 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 16 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 17 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 18 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 19 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 20 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 21 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 22 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 23 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 24 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 25 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 26 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 27 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 28 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 29 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 30 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 31 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 32 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 33 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 34 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 35 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 36 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 37 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 38 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 39 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 40 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 41 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 42 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 43 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 44 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 45 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 46 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 47 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 48 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 49 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 50 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 51 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 52 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 53 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 54 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 55 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 56 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 57 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 58 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 59 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 60 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 61 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 62 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 63 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 64 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 65 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 66 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 67 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 68 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 69 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 70 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 71 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 72 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 73 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 74 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 75 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 76 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 77 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 78 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 79 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 80 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 81 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 82 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 83 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 84 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 85 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 86 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 87 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 88 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 89 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 90 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 91 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 92 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 93 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 94 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 95 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 96 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 97 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 98 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 99 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 100 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 101 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 102 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 103 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, /* Char 104 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 105 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 106 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, /* Char 107 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 108 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 109 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 110 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 111 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 112 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 113 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 114 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 115 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 116 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 117 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 118 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 119 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 120 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 121 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, /* Char 122 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 123 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 124 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 125 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 126 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 127 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 128 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 129 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 130 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 131 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 132 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 133 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 134 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 135 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 136 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 137 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 138 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 139 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 140 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 141 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 142 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 143 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 144 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 145 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 146 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 147 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 148 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 149 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 150 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 151 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 152 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 153 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 154 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 155 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 156 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 157 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 158 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 159 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 160 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 161 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 162 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 163 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 164 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 165 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 166 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 167 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 168 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 169 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 170 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, /* Char 171 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 172 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 173 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 174 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 175 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 176 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 177 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, /* Char 178 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, /* Char 179 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 180 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 181 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 182 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 183 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 184 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, /* Char 185 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 186 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, /* Char 187 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 188 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 189 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 190 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 191 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 192 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 193 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 194 */ 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 195 */ 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 196 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 197 */ 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 198 */ 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 199 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, /* Char 200 */ 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 201 */ 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 202 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, /* Char 203 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 204 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 205 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 206 */ 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 207 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 208 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 209 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 210 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 211 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 212 */ 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 213 */ 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 214 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 215 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 216 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 217 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 218 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 219 */ 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 220 */ 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 221 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 222 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, /* Char 223 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 224 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 225 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 226 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 227 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 228 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 229 */ 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 230 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 231 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, /* Char 232 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 233 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 234 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, /* Char 235 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 236 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 237 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 238 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 239 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 240 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 241 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 242 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 243 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 244 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 245 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 246 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 247 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 248 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 249 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 250 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 251 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 252 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 253 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, /* Char 254 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, /* Char 255 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, }; gdFont gdFontGiantRep = { 256, 0, 9, 15, gdFontGiantData }; BGD_EXPORT_DATA_PROT gdFontPtr gdFontGiant = &gdFontGiantRep; BGD_DECLARE(gdFontPtr) gdFontGetGiant (void) { return gdFontGiant; } /* This file has not been truncated. */ libgd-gd-2.1.1/src/gdfontg.h000066400000000000000000000010511245535672000155620ustar00rootroot00000000000000#ifndef _GDFONTG_H_ #define _GDFONTG_H_ 1 #ifdef __cplusplus extern "C" { #endif /* This is a header file for gd font, generated using bdftogd version 0.51 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -Misc-Fixed-Bold-R-Normal-Sans-15-140-75-75-C-90-ISO8859-2 at Mon Jan 26 14:45:58 1998. The original bdf was holding following copyright: "Libor Skarvada, libor@informatics.muni.cz" */ #include "gd.h" extern BGD_EXPORT_DATA_PROT gdFontPtr gdFontGiant; BGD_DECLARE(gdFontPtr) gdFontGetGiant(void); #ifdef __cplusplus } #endif #endif libgd-gd-2.1.1/src/gdfontl.c000066400000000000000000003214671245535672000156020ustar00rootroot00000000000000 /* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -misc-fixed-medium-r-normal--16-140-75-75-c-80-iso8859-2 at Tue Jan 6 19:39:27 1998. The original bdf was holding following copyright: "Libor Skarvada, libor@informatics.muni.cz" */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gdfontl.h" char gdFontLargeData[] = { /* Char 0 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 1 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 2 */ 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, /* Char 3 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 4 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 5 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 6 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 7 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 8 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 9 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 10 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 11 */ 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 12 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 13 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 14 */ 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 15 */ 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 16 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 17 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 18 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 19 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 20 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 21 */ 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 22 */ 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 23 */ 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 24 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 25 */ 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 26 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 27 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 28 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 29 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 30 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 31 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 32 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 33 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 34 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 35 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 36 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 37 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 38 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 39 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 40 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 41 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 42 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 43 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 44 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 45 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 46 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 47 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 48 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 49 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 50 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 51 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 52 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 53 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 54 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 55 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 56 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 57 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 58 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 59 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 60 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 61 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 62 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 63 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 64 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 65 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 66 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 67 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 68 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 69 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 70 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 71 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 72 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 73 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 74 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 75 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 76 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 77 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 78 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 79 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 80 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 81 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 82 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 83 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 84 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 85 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 86 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 87 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 88 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 89 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 90 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 91 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 92 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 93 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 94 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 95 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 96 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 97 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 98 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 99 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 100 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 101 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 102 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 103 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, /* Char 104 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 105 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 106 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 107 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 108 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 109 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 110 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 111 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 112 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 113 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, /* Char 114 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 115 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 116 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 117 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 118 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 119 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 120 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 121 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 122 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 123 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 124 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 125 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 126 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 127 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 128 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 129 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 130 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 131 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 132 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 133 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 134 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 135 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 136 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 137 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 138 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 139 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 140 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 141 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 142 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 143 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 144 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 145 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 146 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 147 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 148 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 149 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 150 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 151 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 152 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 153 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 154 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 155 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 156 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 157 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 158 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 159 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 160 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 161 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 162 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 163 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 164 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 165 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 166 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 167 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 168 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 169 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 170 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 171 */ 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 172 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 173 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 174 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 175 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 176 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 177 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 178 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, /* Char 179 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 180 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 181 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 182 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 183 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 184 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 185 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 186 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 187 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 188 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 189 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 190 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 191 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 192 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 193 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 194 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 195 */ 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 196 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 197 */ 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 198 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 199 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 200 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 201 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 202 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 203 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 204 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 205 */ 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 206 */ 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 207 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 208 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 209 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 210 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 211 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 212 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 213 */ 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 214 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 215 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 216 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 217 */ 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 218 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 219 */ 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 220 */ 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 221 */ 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 222 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 223 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 224 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 225 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 226 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 227 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 228 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 229 */ 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 230 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 231 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 232 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 233 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 234 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, /* Char 235 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 236 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 237 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 238 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 239 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 240 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 241 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 242 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 243 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 244 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 245 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 246 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 247 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 248 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 249 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 250 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 251 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 252 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 253 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 254 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 255 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, }; gdFont gdFontLargeRep = { 256, 0, 8, 16, gdFontLargeData }; BGD_EXPORT_DATA_PROT gdFontPtr gdFontLarge = &gdFontLargeRep; BGD_DECLARE(gdFontPtr) gdFontGetLarge (void) { return gdFontLarge; } /* This file has not been truncated. */ libgd-gd-2.1.1/src/gdfontl.h000066400000000000000000000010471245535672000155740ustar00rootroot00000000000000#ifndef _GDFONTL_H_ #define _GDFONTL_H_ 1 #ifdef __cplusplus extern "C" { #endif /* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -misc-fixed-medium-r-normal--16-140-75-75-c-80-iso8859-2 at Tue Jan 6 19:39:27 1998. The original bdf was holding following copyright: "Libor Skarvada, libor@informatics.muni.cz" */ #include "gd.h" extern BGD_EXPORT_DATA_PROT gdFontPtr gdFontLarge; BGD_DECLARE(gdFontPtr) gdFontGetLarge(void); #ifdef __cplusplus } #endif #endif libgd-gd-2.1.1/src/gdfontmb.c000066400000000000000000002304551245535672000157410ustar00rootroot00000000000000 /* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -misc-fixed-bold-r-normal-sans-13-94-100-100-c-70-iso8859-2 at Thu Jan 8 13:54:57 1998. No copyright info was found in the original bdf. */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gdfontmb.h" char gdFontMediumBoldData[] = { /* Char 0 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 1 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 2 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 3 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 4 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 5 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 6 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 7 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 8 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 9 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 10 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 11 */ 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 12 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 13 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 14 */ 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 15 */ 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 16 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 17 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 18 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 19 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 20 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 21 */ 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 22 */ 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 23 */ 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 24 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 25 */ 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 26 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 27 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 28 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 29 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 30 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 31 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 32 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 33 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 34 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 35 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 36 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 37 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 38 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 39 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 40 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 41 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 42 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 43 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 44 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 45 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 46 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 47 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 48 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 49 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 50 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 51 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 52 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 53 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 54 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 55 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 56 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 57 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 58 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 59 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 60 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 61 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 62 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 63 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 64 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 65 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 66 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 67 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 68 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 69 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 70 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 71 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 72 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 73 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 74 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 75 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 76 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 77 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 78 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 79 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 80 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 81 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 82 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 83 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 84 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 85 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 86 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 87 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 88 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 89 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 90 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 91 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 92 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 93 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 94 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 95 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 96 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 97 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 98 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 99 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 100 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 101 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 102 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 103 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, /* Char 104 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 105 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 106 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, /* Char 107 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 108 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 109 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 110 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 111 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 112 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, /* Char 113 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 114 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 115 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 116 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 117 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 118 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 119 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 120 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 121 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, /* Char 122 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 123 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 124 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 125 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 126 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 127 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 128 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 129 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 130 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 131 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 132 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 133 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 134 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 135 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 136 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 137 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 138 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 139 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 140 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 141 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 142 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 143 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 144 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 145 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 146 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 147 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 148 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 149 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 150 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 151 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 152 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 153 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 154 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 155 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 156 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 157 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 158 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 159 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 160 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 161 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 162 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 163 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 164 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 165 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 166 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 167 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 168 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 169 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 170 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 171 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 172 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 173 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 174 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 175 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 176 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 177 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 178 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, /* Char 179 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 180 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 181 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 182 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 183 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 184 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 185 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 186 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 187 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 188 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 189 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 190 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 191 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 192 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 193 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 194 */ 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 195 */ 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 196 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 197 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 198 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 199 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 200 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 201 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 202 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 203 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 204 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 205 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 206 */ 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 207 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 208 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 209 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 210 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 211 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 212 */ 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 213 */ 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 214 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 215 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 216 */ 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 217 */ 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 218 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 219 */ 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 220 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 221 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 222 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 223 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 224 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 225 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 226 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 227 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 228 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 229 */ 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 230 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 231 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 232 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 233 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 234 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, /* Char 235 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 236 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 237 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 238 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 239 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 240 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 241 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 242 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 243 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 244 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 245 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 246 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 247 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 248 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 249 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 250 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 251 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 252 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 253 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, /* Char 254 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, /* Char 255 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, }; gdFont gdFontMediumBoldRep = { 256, 0, 7, 13, gdFontMediumBoldData }; BGD_EXPORT_DATA_PROT gdFontPtr gdFontMediumBold = &gdFontMediumBoldRep; BGD_DECLARE(gdFontPtr) gdFontGetMediumBold (void) { return gdFontMediumBold; } /* This file has not been truncated. */ libgd-gd-2.1.1/src/gdfontmb.h000066400000000000000000000010071245535672000157330ustar00rootroot00000000000000#ifndef _GDFONTMB_H_ #define _GDFONTMB_H_ 1 #ifdef __cplusplus extern "C" { #endif /* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -misc-fixed-bold-r-normal-sans-13-94-100-100-c-70-iso8859-2 at Thu Jan 8 13:54:57 1998. No copyright info was found in the original bdf. */ #include "gd.h" extern BGD_EXPORT_DATA_PROT gdFontPtr gdFontMediumBold; BGD_DECLARE(gdFontPtr) gdFontGetMediumBold(void); #ifdef __cplusplus } #endif #endif libgd-gd-2.1.1/src/gdfonts.c000066400000000000000000002050171245535672000156010ustar00rootroot00000000000000/* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -misc-fixed-medium-r-semicondensed-sans-12-116-75-75-c-60-iso8859-2 at Thu Jan 8 14:13:20 1998. No copyright info was found in the original bdf. */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gdfonts.h" char gdFontSmallData[] = { /* Char 0 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 1 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 2 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, /* Char 3 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 4 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 5 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 6 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 7 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 8 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 9 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 10 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 11 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 12 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 13 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 14 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 15 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 16 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 17 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 18 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 19 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 20 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 21 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 22 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 23 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 24 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 25 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 26 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 27 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 28 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 29 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 30 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 31 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 32 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 33 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 34 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 35 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 36 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 37 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 38 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 39 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 40 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 41 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 42 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 43 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 44 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 45 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 46 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 47 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 48 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 49 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 50 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 51 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 52 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 53 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 54 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 55 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 56 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 57 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 58 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 59 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 60 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 61 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 62 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 63 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 64 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 65 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 66 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 67 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 68 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 69 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 70 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 71 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 72 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 73 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 74 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 75 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 76 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 77 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 78 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 79 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 80 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 81 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 82 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 83 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 84 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 85 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 86 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 87 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 88 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 89 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 90 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 91 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 92 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 93 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 94 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 95 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 96 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 97 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 98 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 99 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 100 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 101 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 102 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 103 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, /* Char 104 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 105 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 106 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 107 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 108 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 109 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 110 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 111 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 112 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, /* Char 113 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, /* Char 114 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 115 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 116 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 117 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 118 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 119 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 120 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 121 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 122 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 123 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 124 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 125 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 126 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 127 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 128 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 129 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 130 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 131 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 132 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 133 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 134 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 135 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 136 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 137 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 138 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 139 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 140 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 141 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 142 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 143 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 144 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 145 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 146 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 147 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 148 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 149 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 150 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 151 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 152 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 153 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 154 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 155 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 156 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 157 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 158 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 159 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 160 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 161 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, /* Char 162 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 163 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 164 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 165 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 166 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 167 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 168 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 169 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 170 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 171 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 172 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 173 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 174 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 175 */ 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 176 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 177 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, /* Char 178 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 179 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 180 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 181 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 182 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 183 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 184 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 185 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 186 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 187 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 188 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 189 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 190 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 191 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 192 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 193 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 194 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 195 */ 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 196 */ 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 197 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 198 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 199 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 200 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 201 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 202 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 203 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 204 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 205 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 206 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 207 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 208 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 209 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 210 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 211 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 212 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 213 */ 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 214 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 215 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 216 */ 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 217 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 218 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 219 */ 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 220 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 221 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 222 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 223 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 224 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 225 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 226 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 227 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 228 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 229 */ 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 230 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 231 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, /* Char 232 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 233 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 234 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 235 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 236 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 237 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 238 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 239 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 240 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 241 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 242 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 243 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 244 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 245 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 246 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 247 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 248 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 249 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 250 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 251 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 252 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 253 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, /* Char 254 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, /* Char 255 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, }; gdFont gdFontSmallRep = { 256, 0, 6, 13, gdFontSmallData }; BGD_EXPORT_DATA_PROT gdFontPtr gdFontSmall = &gdFontSmallRep; BGD_DECLARE(gdFontPtr) gdFontGetSmall (void) { return gdFontSmall; } /* This file has not been truncated. */ libgd-gd-2.1.1/src/gdfonts.h000066400000000000000000000010031245535672000155730ustar00rootroot00000000000000#ifndef _GDFONTS_H_ #define _GDFONTS_H_ 1 #ifdef __cplusplus extern "C" { #endif /* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -misc-fixed-medium-r-semicondensed-sans-12-116-75-75-c-60-iso8859-2 at Thu Jan 8 14:13:20 1998. No copyright info was found in the original bdf. */ #include "gd.h" extern BGD_EXPORT_DATA_PROT gdFontPtr gdFontSmall; BGD_DECLARE(gdFontPtr) gdFontGetSmall(void); #ifdef __cplusplus } #endif #endif libgd-gd-2.1.1/src/gdfontt.c000066400000000000000000001114541245535672000156030ustar00rootroot00000000000000 /* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -Misc-Fixed-Medium-R-Normal--8-80-75-75-C-50-ISO8859-2 at Thu Jan 8 13:49:54 1998. The original bdf was holding following copyright: "Libor Skarvada, libor@informatics.muni.cz" */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gdfontt.h" char gdFontTinyData[] = { /* Char 0 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 1 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 2 */ 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, /* Char 3 */ 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, /* Char 4 */ 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 5 */ 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, /* Char 6 */ 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, /* Char 7 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 8 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 9 */ 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, /* Char 10 */ 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, /* Char 11 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 12 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 13 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 14 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 15 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 16 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 17 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 18 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 19 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 20 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 21 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 22 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 23 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 24 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 25 */ 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, /* Char 26 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 27 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 28 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 29 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 30 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 31 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 32 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 33 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 34 */ 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 35 */ 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 36 */ 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 37 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, /* Char 38 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, /* Char 39 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 40 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 41 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 42 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 43 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 44 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 45 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 46 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 47 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 48 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 49 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 50 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 51 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 52 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 53 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 54 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 55 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 56 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 57 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 58 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 59 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, /* Char 60 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 61 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 62 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 63 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 64 */ 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, /* Char 65 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 66 */ 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 67 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 68 */ 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 69 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 70 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 71 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 72 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 73 */ 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 74 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 75 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 76 */ 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 77 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 78 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 79 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 80 */ 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 81 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, /* Char 82 */ 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 83 */ 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 84 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 85 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 86 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 87 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 88 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 89 */ 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 90 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 91 */ 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 92 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, /* Char 93 */ 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 94 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 95 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, /* Char 96 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 97 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 98 */ 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 99 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 100 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 101 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 102 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 103 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, /* Char 104 */ 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 105 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 106 */ 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, /* Char 107 */ 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 108 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 109 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, /* Char 110 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 111 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 112 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, /* Char 113 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, /* Char 114 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 115 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 116 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 117 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 118 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 119 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 120 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 121 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, /* Char 122 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 123 */ 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 124 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 125 */ 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 126 */ 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 127 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 128 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 129 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 130 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 131 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 132 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 133 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 134 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 135 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 136 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 137 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 138 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 139 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 140 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 141 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 142 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 143 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 144 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 145 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 146 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 147 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 148 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 149 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 150 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 151 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 152 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 153 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 154 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 155 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 156 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 157 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 158 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 159 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 160 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 161 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, /* Char 162 */ 1, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 163 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, /* Char 164 */ 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 165 */ 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 166 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 167 */ 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, /* Char 168 */ 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 169 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 170 */ 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, /* Char 171 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 172 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 173 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 174 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 175 */ 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 176 */ 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 177 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, /* Char 178 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, /* Char 179 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 180 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 181 */ 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 182 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 183 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 184 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, /* Char 185 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 186 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, /* Char 187 */ 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 188 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 189 */ 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 190 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 191 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 192 */ 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 193 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 194 */ 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 195 */ 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 196 */ 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 197 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 198 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 199 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, /* Char 200 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 201 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 202 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, /* Char 203 */ 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 204 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 205 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 206 */ 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 207 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 208 */ 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 209 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 210 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 211 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 212 */ 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 213 */ 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 214 */ 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 215 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 216 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 217 */ 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 218 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 219 */ 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 220 */ 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 221 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 222 */ 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, /* Char 223 */ 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, /* Char 224 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 225 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 226 */ 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 227 */ 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 228 */ 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 229 */ 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 230 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 231 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 0, 0, /* Char 232 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 233 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 234 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, /* Char 235 */ 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 236 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 237 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 238 */ 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, /* Char 239 */ 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 240 */ 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 241 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 242 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 243 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 244 */ 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 245 */ 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 246 */ 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 247 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, /* Char 248 */ 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* Char 249 */ 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 250 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 251 */ 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 252 */ 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, /* Char 253 */ 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, /* Char 254 */ 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, /* Char 255 */ 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, }; gdFont gdFontTinyRep = { 256, 0, 5, 8, gdFontTinyData }; BGD_EXPORT_DATA_PROT gdFontPtr gdFontTiny = &gdFontTinyRep; BGD_DECLARE(gdFontPtr) gdFontGetTiny (void) { return gdFontTiny; } /* This file has not been truncated. */ libgd-gd-2.1.1/src/gdfontt.h000066400000000000000000000010421245535672000155770ustar00rootroot00000000000000#ifndef _GDFONTT_H_ #define _GDFONTT_H_ 1 #ifdef __cplusplus extern "C" { #endif /* This is a header file for gd font, generated using bdftogd version 0.5 by Jan Pazdziora, adelton@fi.muni.cz from bdf font -Misc-Fixed-Medium-R-Normal--8-80-75-75-C-50-ISO8859-2 at Thu Jan 8 13:49:54 1998. The original bdf was holding following copyright: "Libor Skarvada, libor@informatics.muni.cz" */ #include "gd.h" extern BGD_EXPORT_DATA_PROT gdFontPtr gdFontTiny; BGD_DECLARE(gdFontPtr) gdFontGetTiny(void); #ifdef __cplusplus } #endif #endif libgd-gd-2.1.1/src/gdft.c000066400000000000000000001424371245535672000150670ustar00rootroot00000000000000 /********************************************/ /* gd interface to freetype library */ /* */ /* John Ellson ellson@graphviz.org */ /********************************************/ #include #include #include #include #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" #include "gdhelpers.h" #include "entities.h" #include "gd_intern.h" /* 2.0.10: WIN32, not MSWIN32 */ #if !defined(_WIN32) && !defined(_WIN32_WCE) #include #elif defined(_WIN32_WCE) #include /* getenv() */ #include /* access() */ #define getenv wceex_getenv #define access wceex_access #else /* _WIN32_WCE */ #include #ifndef R_OK #define R_OK 04 /* Needed in Windows */ #endif #endif /* number of antialised colors for indexed bitmaps */ #define GD_NUMCOLORS 8 #ifdef HAVE_LIBFONTCONFIG static int fontConfigFlag = 0; /* translate a fontconfig fontpattern into a fontpath. return NULL if OK, else return error string */ static char *font_pattern(char **fontpath, char *fontpattern); #endif static char *font_path(char **fontpath, char *name_list); /* 2.0.30: move these up here so we can build correctly without freetype but with fontconfig */ /* * The character (space) used to separate alternate fonts in the * fontlist parameter to gdImageStringFT. 2.0.18: space was a * poor choice for this. */ #define LISTSEPARATOR ";" /* * DEFAULT_FONTPATH and PATHSEPARATOR are host type dependent and * are normally set by configure in config.h. These are just * some last resort values that might match some Un*x system * if building this version of gd separate from graphviz. */ #ifndef DEFAULT_FONTPATH # ifdef NETWARE # define DEFAULT_FONTPATH "sys:/java/nwgfx/lib/x11/fonts/ttf;." # elif defined(_WIN32) # define DEFAULT_FONTPATH "C:\\WINDOWS\\FONTS;C:\\WINNT\\FONTS" # elif defined(__APPLE__) || (defined(__MWERKS__) && defined(macintosh)) # define DEFAULT_FONTPATH "/usr/share/fonts/truetype:/System/Library/Fonts:/Library/Fonts" # else /* default fontpath for unix systems - whatever happened to standards ! */ # define DEFAULT_FONTPATH "/usr/X11R6/lib/X11/fonts/TrueType:/usr/X11R6/lib/X11/fonts/truetype:/usr/X11R6/lib/X11/fonts/TTF:/usr/share/fonts/TrueType:/usr/share/fonts/truetype:/usr/openwin/lib/X11/fonts/TrueType:/usr/X11R6/lib/X11/fonts/Type1:/usr/lib/X11/fonts/Type1:/usr/openwin/lib/X11/fonts/Type1" # endif #endif #ifndef PATHSEPARATOR # if defined(NETWARE) || defined(_WIN32) # define PATHSEPARATOR ";" # else # define PATHSEPARATOR ":" # endif #endif #ifndef TRUE #define FALSE 0 #define TRUE !FALSE #endif BGD_DECLARE(char *) gdImageStringTTF (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string) { /* 2.0.6: valid return */ return gdImageStringFT (im, brect, fg, fontlist, ptsize, angle, x, y, string); } #ifndef HAVE_LIBFREETYPE BGD_DECLARE(char *) gdImageStringFTEx (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string, gdFTStringExtraPtr strex) { (void)im; (void)brect; (void)fg; (void)fontlist; (void)ptsize; (void)angle; (void)x; (void)y; (void)string; (void)strex; return "libgd was not built with FreeType font support\n"; } BGD_DECLARE(char *) gdImageStringFT (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string) { (void)im; (void)brect; (void)fg; (void)fontlist; (void)ptsize; (void)angle; (void)x; (void)y; (void)string; return "libgd was not built with FreeType font support\n"; } #else #ifndef HAVE_LIBFONTCONFIG static char * font_pattern(char **fontpath, char *fontpattern) { (void)fontpath; (void)fontpattern; return "libgd was not built with FontConfig support\n"; } #endif /* HAVE_LIBFONTCONFIG */ #include "gdcache.h" /* 2.0.16 Christophe Thomas: starting with FreeType 2.1.6, this is mandatory, and it has been supported for a long while. */ #ifdef HAVE_FT2BUILD_H #include #include FT_FREETYPE_H #include FT_GLYPH_H #include FT_SIZES_H #else #include #include #include #endif /* number of fonts cached before least recently used is replaced */ #define FONTCACHESIZE 6 /* number of antialias color lookups cached */ #define TWEENCOLORCACHESIZE 32 /* * Line separation as a factor of font height. * No space between if LINESPACE = 1.00 * Line separation will be rounded up to next pixel row. */ #define LINESPACE 1.05 typedef struct { char *fontlist; /* key */ int flags; /* key */ char *fontpath; FT_Library *library; FT_Face face; } font_t; typedef struct { char *fontlist; /* key */ int flags; /* key */ FT_Library *library; } fontkey_t; typedef struct { int pixel; /* key */ int bgcolor; /* key */ int fgcolor; /* key *//* -ve means no antialias */ gdImagePtr im; /* key */ int tweencolor; } tweencolor_t; typedef struct { int pixel; /* key */ int bgcolor; /* key */ int fgcolor; /* key *//* -ve means no antialias */ gdImagePtr im; /* key */ } tweencolorkey_t; /******************************************************************** * gdTcl_UtfToUniChar is borrowed from Tcl ... */ /* * tclUtf.c -- * * Routines for manipulating UTF-8 strings. * * Copyright (c) 1997-1998 Sun Microsystems, Inc. * * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * * SCCS: @(#) tclUtf.c 1.25 98/01/28 18:02:43 */ /* *--------------------------------------------------------------------------- * * gdTcl_UtfToUniChar -- * * Extract the Tcl_UniChar represented by the UTF-8 string. Bad * UTF-8 sequences are converted to valid Tcl_UniChars and processing * continues. Equivalent to Plan 9 chartorune(). * * The caller must ensure that the source buffer is long enough that * this routine does not run off the end and dereference non-existent * memory looking for trail bytes. If the source buffer is known to * be '\0' terminated, this cannot happen. Otherwise, the caller * should call Tcl_UtfCharComplete() before calling this routine to * ensure that enough bytes remain in the string. * * Results: * *chPtr is filled with the Tcl_UniChar, and the return value is the * number of bytes from the UTF-8 string that were consumed. * * Side effects: * None. * *--------------------------------------------------------------------------- */ #ifdef JISX0208 #include "jisx0208.h" #endif static int comp_entities(const void *e1, const void *e2) { struct entities_s *en1 = (struct entities_s *) e1; struct entities_s *en2 = (struct entities_s *) e2; return strcmp(en1->name, en2->name); } extern int any2eucjp (char *, char *, unsigned int); /* Persistent font cache until explicitly cleared */ /* Fonts can be used across multiple images */ /* 2.0.16: thread safety (the font cache is shared) */ gdMutexDeclare (gdFontCacheMutex); static gdCache_head_t *fontCache; static FT_Library library; #define Tcl_UniChar int #define TCL_UTF_MAX 3 static int gdTcl_UtfToUniChar (char *str, Tcl_UniChar * chPtr) /* str is the UTF8 next character pointer */ /* chPtr is the int for the result */ { int byte; char entity_name_buf[ENTITY_NAME_LENGTH_MAX+1]; char *p; struct entities_s key, *res; /* HTML4.0 entities in decimal form, e.g. Å */ /* or in hexadecimal form, e.g. 水 */ byte = *((unsigned char *) str); if (byte == '&') { int i, n = 0; byte = *((unsigned char *) (str + 1)); if (byte == '#') { byte = *((unsigned char *) (str + 2)); if (byte == 'x' || byte == 'X') { for (i = 3; i < 8; i++) { byte = *((unsigned char *) (str + i)); if (byte >= 'A' && byte <= 'F') byte = byte - 'A' + 10; else if (byte >= 'a' && byte <= 'f') byte = byte - 'a' + 10; else if (byte >= '0' && byte <= '9') byte = byte - '0'; else break; n = (n * 16) + byte; } } else { for (i = 2; i < 8; i++) { byte = *((unsigned char *) (str + i)); if (byte >= '0' && byte <= '9') n = (n * 10) + (byte - '0'); else break; } } if (byte == ';') { *chPtr = (Tcl_UniChar) n; return ++i; } } else { key.name = p = entity_name_buf; for (i = 1; i <= 1 + ENTITY_NAME_LENGTH_MAX; i++) { byte = *((unsigned char *) (str + i)); if (byte == '\0') break; if (byte == ';') { *p++ = '\0'; res = bsearch(&key, entities, NR_OF_ENTITIES, sizeof(entities[0]), *comp_entities); if (res) { *chPtr = (Tcl_UniChar) res->value; return ++i; } break; } *p++ = byte; } } } /* * Unroll 1 to 3 byte UTF-8 sequences, use loop to handle longer ones. */ byte = *((unsigned char *) str); #ifdef JISX0208 if (0xA1 <= byte && byte <= 0xFE) { int ku, ten; ku = (byte & 0x7F) - 0x20; ten = (str[1] & 0x7F) - 0x20; if ((ku < 1 || ku > 92) || (ten < 1 || ten > 94)) { *chPtr = (Tcl_UniChar) byte; return 1; } *chPtr = (Tcl_UniChar) UnicodeTbl[ku - 1][ten - 1]; return 2; } else #endif /* JISX0208 */ if (byte < 0xC0) { /* * Handles properly formed UTF-8 characters between * 0x01 and 0x7F. Also treats \0 and naked trail * bytes 0x80 to 0xBF as valid characters representing * themselves. */ *chPtr = (Tcl_UniChar) byte; return 1; } else if (byte < 0xE0) { if ((str[1] & 0xC0) == 0x80) { /* * Two-byte-character lead-byte followed * by a trail-byte. */ *chPtr = (Tcl_UniChar) (((byte & 0x1F) << 6) | (str[1] & 0x3F)); return 2; } /* * A two-byte-character lead-byte not followed by trail-byte * represents itself. */ *chPtr = (Tcl_UniChar) byte; return 1; } else if (byte < 0xF0) { if (((str[1] & 0xC0) == 0x80) && ((str[2] & 0xC0) == 0x80)) { /* * Three-byte-character lead byte followed by * two trail bytes. */ *chPtr = (Tcl_UniChar) (((byte & 0x0F) << 12) | ((str[1] & 0x3F) << 6) | (str[2] & 0x3F)); return 3; } /* * A three-byte-character lead-byte not followed by * two trail-bytes represents itself. */ *chPtr = (Tcl_UniChar) byte; return 1; } #if TCL_UTF_MAX > 3 else { int ch, total, trail; total = totalBytes[byte]; trail = total - 1; if (trail > 0) { ch = byte & (0x3F >> trail); do { str++; if ((*str & 0xC0) != 0x80) { *chPtr = byte; return 1; } ch <<= 6; ch |= (*str & 0x3F); trail--; } while (trail > 0); *chPtr = ch; return total; } } #endif *chPtr = (Tcl_UniChar) byte; return 1; } /********************************************************************/ /* font cache functions */ static int fontTest (void *element, void *key) { font_t *a = (font_t *) element; fontkey_t *b = (fontkey_t *) key; return (strcmp (a->fontlist, b->fontlist) == 0 && a->flags == b->flags); } static int useFontConfig(int flag) { #ifdef HAVE_LIBFONTCONFIG if (fontConfigFlag) { return (!(flag & gdFTEX_FONTPATHNAME)); } else #endif { return flag & gdFTEX_FONTCONFIG; } return flag & gdFTEX_FONTCONFIG; } static void * fontFetch (char **error, void *key) { font_t *a; fontkey_t *b = (fontkey_t *) key; char *suffix; FT_Error err; const unsigned int b_font_list_len = strlen(b->fontlist); *error = NULL; a = (font_t *) gdMalloc (sizeof (font_t)); if (!a) { return NULL; } a->fontlist = (char *) gdMalloc(b_font_list_len + 1); if (a->fontlist == NULL) { gdFree(a); return "could not alloc full list of fonts"; } strncpy(a->fontlist, b->fontlist, b_font_list_len); a->fontlist[b_font_list_len] = 0; a->flags = b->flags; a->library = b->library; a->fontpath = NULL; #ifdef HAVE_LIBFONTCONFIG if (!useFontConfig(b->flags)) *error = font_path(&(a->fontpath), a->fontlist); else *error = font_pattern(&(a->fontpath), a->fontlist); #else *error = font_path(&(a->fontpath), a->fontlist); #endif /* HAVE_LIBFONTCONFIG */ if (*error || !a->fontpath || !a->fontpath[0]) { gdFree(a->fontlist); if (a->fontpath) free(a->fontpath); gdFree(a); if (!*error) *error = "font_path() returned an empty font pathname"; return NULL; } err = FT_New_Face(*b->library, a->fontpath, 0, &a->face); /* Read kerning metrics for Postscript fonts. */ if (!err && ((suffix = strstr(a->fontpath, ".pfa")) || (suffix = strstr(a->fontpath, ".pfb"))) && ((strcpy(suffix, ".afm") && (access(a->fontpath, R_OK) == 0)) || (strcpy(suffix, ".pfm") && (access(a->fontpath, R_OK) == 0)))) { err = FT_Attach_File(a->face, a->fontpath); } if (err) { gdFree (a->fontlist); free(a->fontpath); gdFree(a); *error = "Could not read font"; return NULL; } return (void *) a; } static void fontRelease (void *element) { font_t *a = (font_t *) element; FT_Done_Face (a->face); gdFree (a->fontlist); gdFree (a->fontpath); gdFree ((char *) element); } /********************************************************************/ /* tweencolor cache functions */ static int tweenColorTest (void *element, void *key) { tweencolor_t *a = (tweencolor_t *) element; tweencolorkey_t *b = (tweencolorkey_t *) key; return (a->pixel == b->pixel && a->bgcolor == b->bgcolor && a->fgcolor == b->fgcolor && a->im == b->im); } /* * Computes a color in im's color table that is part way between * the background and foreground colors proportional to the gray * pixel value in the range 0-GD_NUMCOLORS. The fg and bg colors must already * be in the color table for palette images. For truecolor images the * returned value simply has an alpha component and gdImageAlphaBlend * does the work so that text can be alpha blended across a complex * background (TBB; and for real in 2.0.2). */ static void * tweenColorFetch (char **error, void *key) { tweencolor_t *a; tweencolorkey_t *b = (tweencolorkey_t *) key; int pixel, npixel, bg, fg; gdImagePtr im; (void)error; a = (tweencolor_t *) gdMalloc (sizeof (tweencolor_t)); if (!a) { return NULL; } pixel = a->pixel = b->pixel; bg = a->bgcolor = b->bgcolor; fg = a->fgcolor = b->fgcolor; im = a->im = b->im; /* if fg is specified by a negative color idx, then don't antialias */ if (fg < 0) { if ((pixel + pixel) >= GD_NUMCOLORS) a->tweencolor = -fg; else a->tweencolor = bg; } else { npixel = GD_NUMCOLORS - pixel; if (im->trueColor) { /* 2.0.1: use gdImageSetPixel to do the alpha blending work, or to just store the alpha level. All we have to do here is incorporate our knowledge of the percentage of this pixel that is really "lit" by pushing the alpha value up toward transparency in edge regions. */ a->tweencolor = gdTrueColorAlpha (gdTrueColorGetRed (fg), gdTrueColorGetGreen (fg), gdTrueColorGetBlue (fg), gdAlphaMax - (gdTrueColorGetAlpha (fg) * pixel / GD_NUMCOLORS)); } else { a->tweencolor = gdImageColorResolve (im, (pixel * im->red[fg] + npixel * im->red[bg]) / GD_NUMCOLORS, (pixel * im->green[fg] + npixel * im->green[bg]) / GD_NUMCOLORS, (pixel * im->blue[fg] + npixel * im->blue[bg]) / GD_NUMCOLORS); } } return (void *) a; } static void tweenColorRelease (void *element) { gdFree ((char *) element); } /* draw_bitmap - transfers glyph bitmap to GD image */ static char * gdft_draw_bitmap (gdCache_head_t * tc_cache, gdImage * im, int fg, FT_Bitmap bitmap, int pen_x, int pen_y) { unsigned char *pixel = NULL; int *tpixel = NULL; int opixel; int x, y, row, col, pc, pcr; tweencolor_t *tc_elem; tweencolorkey_t tc_key; /* copy to image, mapping colors */ tc_key.fgcolor = fg; tc_key.im = im; /* Truecolor version; does not require the cache */ if (im->trueColor) { for (row = 0; row < bitmap.rows; row++) { pc = row * bitmap.pitch; pcr = pc; y = pen_y + row; /* clip if out of bounds */ /* 2.0.16: clipping rectangle, not image bounds */ if ((y > im->cy2) || (y < im->cy1)) continue; for (col = 0; col < bitmap.width; col++, pc++) { int level; if (bitmap.pixel_mode == ft_pixel_mode_grays) { /* * Scale to 128 levels of alpha for gd use. * alpha 0 is opacity, so be sure to invert at the end */ level = (bitmap.buffer[pc] * gdAlphaMax / (bitmap.num_grays - 1)); } else if (bitmap.pixel_mode == ft_pixel_mode_mono) { /* 2.0.5: mode_mono fix from Giuliano Pochini */ level = ((bitmap. buffer[(col >> 3) + pcr]) & (1 << (~col & 0x07))) ? gdAlphaTransparent : gdAlphaOpaque; } else { return "Unsupported ft_pixel_mode"; } if (level == 0) /* if background */ continue; if ((fg >= 0) && (im->trueColor)) { /* Consider alpha in the foreground color itself to be an upper bound on how opaque things get, when truecolor is available. Without truecolor this results in far too many color indexes. */ level = level * (gdAlphaMax - gdTrueColorGetAlpha (fg)) / gdAlphaMax; } level = gdAlphaMax - level; /* inverting to get alpha */ x = pen_x + col; /* clip if out of bounds */ /* 2.0.16: clip to clipping rectangle, Matt McNabb */ if ((x > im->cx2) || (x < im->cx1)) continue; /* get pixel location in gd buffer */ tpixel = &im->tpixels[y][x]; if (fg < 0) { if (level < (gdAlphaMax / 2)) { *tpixel = -fg; } } else { if (im->alphaBlendingFlag) { opixel = *tpixel; if (gdTrueColorGetAlpha(opixel) != gdAlphaTransparent) { *tpixel = gdAlphaBlend (opixel, (level << 24) + (fg & 0xFFFFFF)); } else { *tpixel = (level << 24) + (fg & 0xFFFFFF); } } else { *tpixel = (level << 24) + (fg & 0xFFFFFF); } } } } return (char *) NULL; } /* Non-truecolor case, restored to its more or less original form */ for (row = 0; row < bitmap.rows; row++) { int pcr; pc = row * bitmap.pitch; pcr = pc; if (bitmap.pixel_mode == ft_pixel_mode_mono) pc *= 8; /* pc is measured in bits for monochrome images */ y = pen_y + row; /* clip if out of bounds */ if (y > im->cy2 || y < im->cy1) continue; for (col = 0; col < bitmap.width; col++, pc++) { if (bitmap.pixel_mode == ft_pixel_mode_grays) { /* * Round to GD_NUMCOLORS levels of antialiasing for * index color images since only 256 colors are * available. */ tc_key.pixel = ((bitmap.buffer[pc] * GD_NUMCOLORS) + bitmap.num_grays / 2) / (bitmap.num_grays - 1); } else if (bitmap.pixel_mode == ft_pixel_mode_mono) { tc_key.pixel = ((bitmap.buffer[pc / 8] << (pc % 8)) & 128) ? GD_NUMCOLORS : 0; /* 2.0.5: mode_mono fix from Giuliano Pochini */ tc_key.pixel = ((bitmap. buffer[(col >> 3) + pcr]) & (1 << (~col & 0x07))) ? GD_NUMCOLORS : 0; } else { return "Unsupported ft_pixel_mode"; } if (tc_key.pixel == 0) /* if background */ continue; x = pen_x + col; /* clip if out of bounds */ if (x > im->cx2 || x < im->cx1) continue; /* get pixel location in gd buffer */ pixel = &im->pixels[y][x]; if (tc_key.pixel == GD_NUMCOLORS) { /* use fg color directly. gd 2.0.2: watch out for negative indexes (thanks to David Marwood). */ *pixel = (fg < 0) ? -fg : fg; } else { /* find antialised color */ tc_key.bgcolor = *pixel; tc_elem = (tweencolor_t *) gdCacheGet (tc_cache, &tc_key); if (!tc_elem) return tc_cache->error; *pixel = tc_elem->tweencolor; } } } return (char *) NULL; } BGD_DECLARE(void) gdFreeFontCache () { gdFontCacheShutdown (); } BGD_DECLARE(void) gdFontCacheShutdown () { if (fontCache) { gdMutexLock(gdFontCacheMutex); gdCacheDelete (fontCache); /* 2.0.16: Gustavo Scotti: make sure we don't free this twice */ fontCache = 0; gdMutexUnlock(gdFontCacheMutex); gdMutexShutdown (gdFontCacheMutex); FT_Done_FreeType (library); } } /********************************************************************/ /* gdImageStringFT - render a utf8 string onto a gd image */ BGD_DECLARE(char *) gdImageStringFT (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string) { return gdImageStringFTEx (im, brect, fg, fontlist, ptsize, angle, x, y, string, 0); } BGD_DECLARE(int) gdFontCacheSetup (void) { if (fontCache) { /* Already set up */ return 0; } gdMutexSetup (gdFontCacheMutex); if (FT_Init_FreeType (&library)) { gdMutexShutdown (gdFontCacheMutex); return -1; } fontCache = gdCacheCreate (FONTCACHESIZE, fontTest, fontFetch, fontRelease); if (!fontCache) { return -2; } return 0; } /* Function: gdImageStringFTEx gdImageStringFTEx extends the capabilities of gdImageStringFT by providing a way to pass additional parameters. If the strex parameter is not null, it must point to a gdFTStringExtra structure. As of gd 2.0.5, this structure is defined as follows: > typedef struct { > // logical OR of gdFTEX_ values > int flags; > > // fine tune line spacing for '\n' > double linespacing; > > // Preferred character mapping > int charmap; > > // Rendering resolution > int hdpi; > int vdpi; > char *xshow; > char *fontpath; > } gdFTStringExtra, *gdFTStringExtraPtr; To output multiline text with a specific line spacing, include gdFTEX_LINESPACE in the setting of flags: > flags |= gdFTEX_LINESPACE; And also set linespacing to the desired spacing, expressed as a multiple of the font height. Thus a line spacing of 1.0 is the minimum to guarantee that lines of text do not collide. If gdFTEX_LINESPACE is not present, or strex is null, or gdImageStringFT is called, linespacing defaults to 1.05. To specify a preference for Unicode, Shift_JIS Big5 character encoding, set or To output multiline text with a specific line spacing, include gdFTEX_CHARMAP in the setting of flags: > flags |= gdFTEX_CHARMAP; And set charmap to the desired value, which can be any of gdFTEX_Unicode, gdFTEX_Shift_JIS, gdFTEX_Big5, or gdFTEX_Adobe_Custom. If you do not specify a preference, Unicode will be tried first. If the preferred character mapping is not found in the font, other character mappings are attempted. GD operates on the assumption that the output image will be rendered to a computer screen. By default, gd passes a resolution of 96 dpi to the freetype text rendering engine. This influences the "hinting" decisions made by the renderer. To specify a different resolution, set hdpi and vdpi accordingly (in dots per inch) and add gdFTEX_RESOLUTION to flags: > flags | gdFTEX_RESOLUTION; GD 2.0.29 and later will normally attempt to apply kerning tables, if fontconfig is available, to adjust the relative positions of consecutive characters more ideally for that pair of characters. This can be turn off by specifying the gdFTEX_DISABLE_KERNING flag: > flags | gdFTEX_DISABLE_KERNING; GD 2.0.29 and later can return a vector of individual character position advances, occasionally useful in applications that must know exactly where each character begins. This is returned in the xshow element of the gdFTStringExtra structure if the gdFTEX_XSHOW flag is set: > flags | gdFTEX_XSHOW; The caller is responsible for calling gdFree() on the xshow element after the call if gdFTEX_XSHOW is set. GD 2.0.29 and later can also return the path to the actual font file used if the gdFTEX_RETURNFONTPATHNAME flag is set. This is useful because GD 2.0.29 and above are capable of selecting a font automatically based on a fontconfig font pattern when fontconfig is available. This information is returned in the fontpath element of the gdFTStringExtra structure. > flags | gdFTEX_RETURNFONTPATHNAME; The caller is responsible for calling gdFree() on the fontpath element after the call if gdFTEX_RETURNFONTPATHNAME is set. GD 2.0.29 and later can use fontconfig to resolve font names, including fontconfig patterns, if the gdFTEX_FONTCONFIG flag is set. As a convenience, this behavior can be made the default by calling gdFTUseFontConfig with a nonzero value. In that situation it is not necessary to set the gdFTEX_FONTCONFIG flag on every call; however explicit font path names can still be used if the gdFTEX_FONTPATHNAME flag is set: > flags | gdFTEX_FONTPATHNAME; Unless gdFTUseFontConfig has been called with a nonzero value, GD 2.0.29 and later will still expect the fontlist argument to the freetype text output functions to be a font file name or list thereof as in previous versions. If you do not wish to make fontconfig the default, it is still possible to force the use of fontconfig for a single call to the freetype text output functions by setting the gdFTEX_FONTCONFIG flag: > flags | gdFTEX_FONTCONFIG; GD 2.0.29 and above can use fontconfig to resolve font names, including fontconfig patterns, if the gdFTEX_FONTCONFIG flag is set. As a convenience, this behavior can be made the default by calling gdFTUseFontConfig with a nonzero value. In that situation it is not necessary to set the gdFTEX_FONTCONFIG flag on every call; however explicit font path names can still be used if the gdFTEX_FONTPATHNAME flag is set: > flags | gdFTEX_FONTPATHNAME; For more information, see . */ /* the platform-independent resolution used for size and position calculations */ /* the size of the error introduced by rounding is affected by this number */ #define METRIC_RES 300 BGD_DECLARE(char *) gdImageStringFTEx (gdImage * im, int *brect, int fg, char *fontlist, double ptsize, double angle, int x, int y, char *string, gdFTStringExtraPtr strex) { FT_Matrix matrix; FT_Vector penf, oldpenf, delta, total_min = {0,0}, total_max = {0,0}, glyph_min, glyph_max; FT_Face face; FT_CharMap charmap = NULL; FT_Glyph image; FT_GlyphSlot slot; FT_Error err; FT_UInt glyph_index, previous; double sin_a = sin (angle); double cos_a = cos (angle); int len, i, ch; font_t *font; fontkey_t fontkey; char *next; char *tmpstr = 0; int render = (im && (im->trueColor || (fg <= 255 && fg >= -255))); FT_BitmapGlyph bm; /* 2.0.13: Bob Ostermann: don't force autohint, that's just for testing freetype and doesn't look as good */ int render_mode = FT_LOAD_DEFAULT; int encoding, encodingfound; /* Now tuneable thanks to Wez Furlong */ double linespace = LINESPACE; /* 2.0.6: put this declaration with the other declarations! */ /* * make a new tweenColorCache on every call * because caching colormappings between calls * is not safe. If the im-pointer points to a * brand new image, the cache gives out bogus * colorindexes. -- 27.06.2001 */ gdCache_head_t *tc_cache; /* Tuneable horizontal and vertical resolution in dots per inch */ int hdpi, vdpi, horiAdvance, xshow_alloc = 0, xshow_pos = 0; FT_Size platform_specific, platform_independent; if (strex) { if ((strex->flags & gdFTEX_LINESPACE) == gdFTEX_LINESPACE) { linespace = strex->linespacing; } } tc_cache = gdCacheCreate (TWEENCOLORCACHESIZE, tweenColorTest, tweenColorFetch, tweenColorRelease); /***** initialize font library and font cache on first call ******/ if (!fontCache) { if (gdFontCacheSetup () != 0) { gdCacheDelete (tc_cache); return "Failure to initialize font library"; } } /*****/ gdMutexLock (gdFontCacheMutex); /* get the font (via font cache) */ fontkey.fontlist = fontlist; if (strex) fontkey.flags = strex->flags & (gdFTEX_FONTPATHNAME | gdFTEX_FONTCONFIG); else fontkey.flags = 0; fontkey.library = &library; font = (font_t *) gdCacheGet (fontCache, &fontkey); if (!font) { gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return fontCache->error; } face = font->face; /* shortcut */ slot = face->glyph; /* shortcut */ if (brect) { total_min.x = total_min.y = 0; total_max.x = total_max.y = 0; } /* * Added hdpi and vdpi to support images at non-screen resolutions, i.e. 300 dpi TIFF, * or 100h x 50v dpi FAX format. 2.0.23. * 2004/02/27 Mark Shackelford, mark.shackelford@acs-inc.com */ hdpi = GD_RESOLUTION; vdpi = GD_RESOLUTION; encoding = gdFTEX_Unicode; if (strex) { if (strex->flags & gdFTEX_RESOLUTION) { hdpi = strex->hdpi; vdpi = strex->vdpi; } if (strex->flags & gdFTEX_XSHOW) { strex->xshow = NULL; } /* 2.0.12: allow explicit specification of the preferred map; but we still fall back if it is not available. */ if (strex->flags & gdFTEX_CHARMAP) { encoding = strex->charmap; } /* 2.0.29: we can return the font path if desired */ if (strex->flags & gdFTEX_RETURNFONTPATHNAME) { const unsigned int fontpath_len = strlen(font->fontpath); strex->fontpath = (char *) gdMalloc(fontpath_len + 1); if (strex->fontpath == NULL) { gdCacheDelete(tc_cache); gdMutexUnlock(gdFontCacheMutex); return "could not alloc full list of fonts"; } strncpy(strex->fontpath, font->fontpath, fontpath_len); strex->fontpath[fontpath_len] = 0; } } matrix.xx = (FT_Fixed) (cos_a * (1 << 16)); matrix.yx = (FT_Fixed) (sin_a * (1 << 16)); matrix.xy = -matrix.yx; matrix.yy = matrix.xx; /* set rotation transform */ FT_Set_Transform (face, &matrix, NULL); FT_New_Size (face, &platform_independent); FT_Activate_Size (platform_independent); if (FT_Set_Char_Size (face, 0, (FT_F26Dot6)(ptsize*64), METRIC_RES, METRIC_RES)) { gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "Could not set character size"; } if (render) { FT_New_Size (face, &platform_specific); FT_Activate_Size (platform_specific); if (FT_Set_Char_Size (face, 0, (FT_F26Dot6)(ptsize*64), hdpi, vdpi)) { gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "Could not set character size"; } } if (fg < 0) render_mode |= FT_LOAD_MONOCHROME; /* find requested charmap */ encodingfound = 0; for (i = 0; i < face->num_charmaps; i++) { charmap = face->charmaps[i]; #if ((defined(FREETYPE_MAJOR)) && (((FREETYPE_MAJOR == 2) && (((FREETYPE_MINOR == 1) && (FREETYPE_PATCH >= 3)) || (FREETYPE_MINOR > 1))) || (FREETYPE_MAJOR > 2))) if (encoding == gdFTEX_Unicode) { if (charmap->encoding == FT_ENCODING_MS_SYMBOL || charmap->encoding == FT_ENCODING_UNICODE || charmap->encoding == FT_ENCODING_ADOBE_CUSTOM || charmap->encoding == FT_ENCODING_ADOBE_STANDARD) { encodingfound++; break; } } else if (encoding == gdFTEX_Adobe_Custom) { if (charmap->encoding == FT_ENCODING_ADOBE_CUSTOM) { encodingfound++; break; } } else if (encoding == gdFTEX_Big5) { /* renamed sometime after freetype-2.1.4 */ #ifndef FT_ENCODING_BIG5 #define FT_ENCODING_BIG5 FT_ENCODING_MS_BIG5 #endif if (charmap->encoding == FT_ENCODING_BIG5) { encodingfound++; break; } } else if (encoding == gdFTEX_Shift_JIS) { /* renamed sometime after freetype-2.1.4 */ #ifndef FT_ENCODING_SJIS #define FT_ENCODING_SJIS FT_ENCODING_MS_SJIS #endif if (charmap->encoding == FT_ENCODING_SJIS) { encodingfound++; break; } } #else if (encoding == gdFTEX_Unicode) { if ((charmap->platform_id = 3 && charmap->encoding_id == 1) /* Windows Unicode */ || (charmap->platform_id == 3 && charmap->encoding_id == 0) /* Windows Symbol */ || (charmap->platform_id == 2 && charmap->encoding_id == 1) /* ISO Unicode */ || (charmap->platform_id == 0)) { /* Apple Unicode */ encodingfound++; break; } } else if (encoding == gdFTEX_Big5) { if (charmap->platform_id == 3 && charmap->encoding_id == 4) { /* Windows Big5 */ encodingfound++; break; } } else if (encoding == gdFTEX_Shift_JIS) { if (charmap->platform_id == 3 && charmap->encoding_id == 2) { /* Windows Sjis */ encodingfound++; break; } } #endif } if (encodingfound) { FT_Set_Charmap(face, charmap); } else { /* No character set found! */ gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "No character set found"; } #ifndef JISX0208 if (encoding == gdFTEX_Shift_JIS) { #endif if ((tmpstr = (char *) gdMalloc (BUFSIZ))) { any2eucjp (tmpstr, string, BUFSIZ); next = tmpstr; } else { next = string; } #ifndef JISX0208 } else { next = string; } #endif oldpenf.x = oldpenf.y = 0; /* for postscript xshow operator */ penf.x = penf.y = 0; /* running position of non-rotated glyphs */ previous = 0; /* index of previous glyph for kerning calculations */ for (i=0; *next; i++) { FT_Activate_Size (platform_independent); ch = *next; /* carriage returns */ if (ch == '\r') { penf.x = 0; previous = 0; /* clear kerning flag */ next++; continue; } /* newlines */ if (ch == '\n') { /* 2.0.13: reset penf.x. Christopher J. Grayce */ penf.x = 0; penf.y += linespace * ptsize * 64 * METRIC_RES / 72; penf.y &= ~63; /* round down to 1/METRIC_RES */ previous = 0; /* clear kerning flag */ next++; continue; } switch (encoding) { case gdFTEX_Unicode: { /* use UTF-8 mapping from ASCII */ len = gdTcl_UtfToUniChar (next, &ch); /* EAM DEBUG */ /* TBB: get this exactly right: 2.1.3 *or better*, all possible cases. */ /* 2.0.24: David R. Morrison: use the more complete ifdef here. */ #if ((defined(FREETYPE_MAJOR)) && (((FREETYPE_MAJOR == 2) && (((FREETYPE_MINOR == 1) && (FREETYPE_PATCH >= 3)) || (FREETYPE_MINOR > 1))) || (FREETYPE_MAJOR > 2))) if (charmap->encoding == FT_ENCODING_MS_SYMBOL) #else if (charmap->platform_id == 3 && charmap->encoding_id == 0) #endif /* Freetype 2.1 or better */ { /* I do not know the significance of the constant 0xf000. */ /* It was determined by inspection of the character codes */ /* stored in Microsoft font symbol.ttf */ ch |= 0xf000; } /* EAM DEBUG */ next += len; } break; case gdFTEX_Shift_JIS: { unsigned char c; int jiscode; c = *next; if (0xA1 <= c && c <= 0xFE) { next++; jiscode = 0x100 * (c & 0x7F) + ((*next) & 0x7F); ch = (jiscode >> 8) & 0xFF; jiscode &= 0xFF; if (ch & 1) jiscode += 0x40 - 0x21; else jiscode += 0x9E - 0x21; if (jiscode >= 0x7F) jiscode++; ch = (ch - 0x21) / 2 + 0x81; if (ch >= 0xA0) ch += 0x40; ch = (ch << 8) + jiscode; } else { ch = c & 0xFF; /* don't extend sign */ } if (*next) next++; } break; case gdFTEX_Big5: { /* * Big 5 mapping: * use "JIS-8 half-width katakana" coding from 8-bit characters. Ref: * ftp://ftp.ora.com/pub/examples/nutshell/ujip/doc/japan.inf-032092.sjs */ ch = (*next) & 0xFF; /* don't extend sign */ next++; if (ch >= 161 /* first code of JIS-8 pair */ && *next) { /* don't advance past '\0' */ /* TBB: Fix from Kwok Wah On: & 255 needed */ ch = (ch * 256) + ((*next) & 255); next++; } } break; case gdFTEX_Adobe_Custom: default: ch &= 0xFF; next++; break; } /* Convert character code to glyph index */ glyph_index = FT_Get_Char_Index (face, ch); /* retrieve kerning distance */ if ( ! (strex && (strex->flags & gdFTEX_DISABLE_KERNING)) && ! FT_IS_FIXED_WIDTH(face) && FT_HAS_KERNING(face) && previous && glyph_index) FT_Get_Kerning (face, previous, glyph_index, ft_kerning_default, &delta); else delta.x = delta.y = 0; penf.x += delta.x; /* When we know the position of the second or subsequent character, save the (kerned) advance from the preceeding character in the xshow vector */ if (i && strex && (strex->flags & gdFTEX_XSHOW)) { /* make sure we have enough allocation for two numbers so we don't have to recheck for the terminating number */ if (! xshow_alloc) { xshow_alloc = 100; strex->xshow = gdMalloc(xshow_alloc); if (!strex->xshow) { if (tmpstr) gdFree (tmpstr); gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "Problem allocating memory"; } xshow_pos = 0; } else if (xshow_pos + 20 > xshow_alloc) { xshow_alloc += 100; strex->xshow = gdReallocEx(strex->xshow, xshow_alloc); if (!strex->xshow) { if (tmpstr) gdFree (tmpstr); gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "Problem allocating memory"; } } xshow_pos += sprintf(strex->xshow + xshow_pos, "%g ", (double)(penf.x - oldpenf.x) * hdpi / (64 * METRIC_RES)); } oldpenf.x = penf.x; /* load glyph image into the slot (erase previous one) */ err = FT_Load_Glyph (face, glyph_index, render_mode); if (err) { if (tmpstr) gdFree (tmpstr); gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "Problem loading glyph"; } horiAdvance = slot->metrics.horiAdvance; if (brect) { /* only if need brect */ glyph_min.x = penf.x + slot->metrics.horiBearingX; glyph_min.y = penf.y - slot->metrics.horiBearingY; #if 0 if (ch == ' ') { /* special case for trailing space */ glyph_max.x = penf.x + horiAdvance; } else { glyph_max.x = glyph_min.x + slot->metrics.width; } #else glyph_max.x = penf.x + horiAdvance; #endif glyph_max.y = glyph_min.y + slot->metrics.height; if (i==0) { total_min = glyph_min; total_max = glyph_max; } else { if (glyph_min.x < total_min.x) total_min.x = glyph_min.x; if (glyph_min.y < total_min.y) total_min.y = glyph_min.y; if (glyph_max.x > total_max.x) total_max.x = glyph_max.x; if (glyph_max.y > total_max.y) total_max.y = glyph_max.y; } } if (render) { FT_Activate_Size (platform_specific); /* load glyph again into the slot (erase previous one) - this time with scaling */ err = FT_Load_Glyph (face, glyph_index, render_mode); if (err) { if (tmpstr) gdFree (tmpstr); gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "Problem loading glyph"; } /* load and transform glyph image */ FT_Get_Glyph (slot, &image); if (image->format != ft_glyph_format_bitmap) { err = FT_Glyph_To_Bitmap (&image, ft_render_mode_normal, 0, 1); if (err) { FT_Done_Glyph(image); if (tmpstr) gdFree (tmpstr); gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return "Problem rendering glyph"; } } /* now, draw to our target surface */ bm = (FT_BitmapGlyph) image; /* position rounded down to nearest pixel at current dpi (the estimate was rounded up to next 1/METRIC_RES, so this should fit) */ gdft_draw_bitmap (tc_cache, im, fg, bm->bitmap, (int)(x + (penf.x * cos_a + penf.y * sin_a)*hdpi/(METRIC_RES*64) + bm->left), (int)(y - (penf.x * sin_a - penf.y * cos_a)*vdpi/(METRIC_RES*64) - bm->top)); FT_Done_Glyph (image); } /* record current glyph index for kerning */ previous = glyph_index; penf.x += horiAdvance; } /* Save the (unkerned) advance from the last character in the xshow vector */ if (strex && (strex->flags & gdFTEX_XSHOW) && strex->xshow) { sprintf(strex->xshow + xshow_pos, "%g", (double)(penf.x - oldpenf.x) * hdpi / (64 * METRIC_RES) ); } if (brect) { /* only if need brect */ double scalex = (double)hdpi / (64 * METRIC_RES); double scaley = (double)vdpi / (64 * METRIC_RES); /* increase by 1 pixel to allow for rounding */ total_min.x -= METRIC_RES; total_min.y -= METRIC_RES; total_max.x += METRIC_RES; total_max.y += METRIC_RES; /* rotate bounding rectangle, scale and round to int pixels, and translate */ brect[0] = x + (total_min.x * cos_a + total_max.y * sin_a)*scalex; brect[1] = y - (total_min.x * sin_a - total_max.y * cos_a)*scaley; brect[2] = x + (total_max.x * cos_a + total_max.y * sin_a)*scalex; brect[3] = y - (total_max.x * sin_a - total_max.y * cos_a)*scaley; brect[4] = x + (total_max.x * cos_a + total_min.y * sin_a)*scalex; brect[5] = y - (total_max.x * sin_a - total_min.y * cos_a)*scaley; brect[6] = x + (total_min.x * cos_a + total_min.y * sin_a)*scalex; brect[7] = y - (total_min.x * sin_a - total_min.y * cos_a)*scaley; } FT_Done_Size (platform_independent); if (render) FT_Done_Size (platform_specific); if (tmpstr) gdFree (tmpstr); gdCacheDelete (tc_cache); gdMutexUnlock (gdFontCacheMutex); return (char *) NULL; } #endif /* HAVE_LIBFREETYPE */ #ifdef HAVE_LIBFONTCONFIG /* Code to find font path, with special mapping for Postscript font names. * * Dag Lem */ #include /* #define NO_POSTSCRIPT_ALIAS 1 */ #ifndef NO_POSTSCRIPT_ALIAS typedef struct _PostscriptAlias { char* name; char* family; char* style; } PostscriptAlias; /* This table maps standard Postscript font names to URW Type 1 fonts. The mapping is converted from Ghostscript (Fontmap.GS) for use with fontconfig. */ static PostscriptAlias postscript_alias[] = { { "AvantGarde-Book", "URW Gothic L", "Book" }, { "AvantGarde-BookOblique", "URW Gothic L", "Book Oblique" }, { "AvantGarde-Demi", "URW Gothic L", "Demi" }, { "AvantGarde-DemiOblique", "URW Gothic L", "Demi Oblique" }, { "Bookman-Demi", "URW Bookman L", "Demi Bold" }, { "Bookman-DemiItalic", "URW Bookman L", "Demi Bold Italic" }, { "Bookman-Light", "URW Bookman L", "Light" }, { "Bookman-LightItalic", "URW Bookman L", "Light Italic" }, { "Courier", "Nimbus Mono L", "Regular" }, { "Courier-Oblique", "Nimbus Mono L", "Regular Oblique" }, { "Courier-Bold", "Nimbus Mono L", "Bold" }, { "Courier-BoldOblique", "Nimbus Mono L", "Bold Oblique" }, { "Helvetica", "Nimbus Sans L", "Regular" }, { "Helvetica-Oblique", "Nimbus Sans L", "Regular Italic" }, { "Helvetica-Bold", "Nimbus Sans L", "Bold" }, { "Helvetica-BoldOblique", "Nimbus Sans L", "Bold Italic" }, { "Helvetica-Narrow", "Nimbus Sans L", "Regular Condensed" }, { "Helvetica-Narrow-Oblique", "Nimbus Sans L", "Regular Condensed Italic" }, { "Helvetica-Narrow-Bold", "Nimbus Sans L", "Bold Condensed" }, { "Helvetica-Narrow-BoldOblique", "Nimbus Sans L", "Bold Condensed Italic" }, { "NewCenturySchlbk-Roman", "Century Schoolbook L", "Roman" }, { "NewCenturySchlbk-Italic", "Century Schoolbook L", "Italic" }, { "NewCenturySchlbk-Bold", "Century Schoolbook L", "Bold" }, { "NewCenturySchlbk-BoldItalic", "Century Schoolbook L", "Bold Italic" }, { "Palatino-Roman", "URW Palladio L", "Roman" }, { "Palatino-Italic", "URW Palladio L", "Italic" }, { "Palatino-Bold", "URW Palladio L", "Bold" }, { "Palatino-BoldItalic", "URW Palladio L", "Bold Italic" }, { "Symbol", "Standard Symbols L", "Regular" }, { "Times-Roman", "Nimbus Roman No9 L", "Regular" }, { "Times-Italic", "Nimbus Roman No9 L", "Regular Italic" }, { "Times-Bold", "Nimbus Roman No9 L", "Medium" }, { "Times-BoldItalic", "Nimbus Roman No9 L", "Medium Italic" }, { "ZapfChancery-MediumItalic", "URW Chancery L", "Medium Italic" }, { "ZapfDingbats", "Dingbats", "" }, }; #endif static FcPattern* find_font(FcPattern* pattern) { FcResult result; FcConfigSubstitute(0, pattern, FcMatchPattern); FcConfigSubstitute(0, pattern, FcMatchFont); FcDefaultSubstitute(pattern); return FcFontMatch(0, pattern, &result); } #ifndef NO_POSTSCRIPT_ALIAS static char* find_postscript_font(FcPattern **fontpattern, char* fontname) { FcPattern* font = NULL; size_t i; *fontpattern = NULL; for (i = 0; i < sizeof(postscript_alias)/sizeof(*postscript_alias); i++) { if (strcmp(fontname, postscript_alias[i].name) == 0) { FcChar8* family; FcPattern* pattern = FcPatternBuild(0, FC_FAMILY, FcTypeString, postscript_alias[i].family, FC_STYLE, FcTypeString, postscript_alias[i].style, (char*)0); font = find_font(pattern); FcPatternDestroy(pattern); if (!font) return "fontconfig: Couldn't find font."; if (FcPatternGetString(font, FC_FAMILY, 0, &family) != FcResultMatch) { FcPatternDestroy(font); return "fontconfig: Couldn't retrieve font family name."; } /* Check whether we got the font family we wanted. */ if (strcmp((const char *)family, postscript_alias[i].family) != 0) { FcPatternDestroy(font); return "fontconfig: Didn't find expected font family. Perhaps URW Type 1 fonts need installing?"; } break; } } *fontpattern = font; return NULL; } #endif static char * font_pattern(char **fontpath, char *fontpattern) { FcPattern* font = NULL; FcChar8* file; FcPattern* pattern; #ifndef NO_POSTSCRIPT_ALIAS char *error; #endif *fontpath = NULL; #ifndef NO_POSTSCRIPT_ALIAS error = find_postscript_font(&font, fontpattern); if (!font) { if (error) return error; #endif pattern = FcNameParse((const FcChar8 *)fontpattern); font = find_font(pattern); FcPatternDestroy(pattern); #ifndef NO_POSTSCRIPT_ALIAS } #endif if (!font) return "fontconfig: Couldn't find font."; if (FcPatternGetString(font, FC_FILE, 0, &file) != FcResultMatch) { FcPatternDestroy(font); return "fontconfig: Couldn't retrieve font file name."; } else { const unsigned int file_len = strlen((const char *)file); *fontpath = (char *) gdMalloc(file_len + 1); if (*fontpath == NULL) { return "could not alloc font path"; } strncpy(*fontpath, (const char *)file, file_len); (*fontpath)[file_len] = 0; } FcPatternDestroy(font); return NULL; } #endif /* HAVE_LIBFONTCONFIG */ /* Look up font using font names as file names. */ static char * font_path(char **fontpath, char *name_list) { int font_found = 0; char *fontsearchpath, *fontlist; char *fullname = NULL; char *name, *dir; char *path; char *strtok_ptr = NULL; const unsigned int name_list_len = strlen(name_list); /* * Search the pathlist for any of a list of font names. */ *fontpath = NULL; fontsearchpath = getenv ("GDFONTPATH"); if (!fontsearchpath) fontsearchpath = DEFAULT_FONTPATH; path = (char *) gdMalloc(sizeof(char) * strlen(fontsearchpath) + 1); if( path == NULL ) { return "could not alloc full list of fonts"; } path[0] = 0; fontlist = (char *) gdMalloc(name_list_len + 1); if (fontlist == NULL) { gdFree(path); return "could not alloc full list of fonts"; } strncpy(fontlist, name_list, name_list_len); fontlist[name_list_len] = 0; /* * Must use gd_strtok_r else pointer corrupted by strtok in nested loop. */ for (name = gd_strtok_r (fontlist, LISTSEPARATOR, &strtok_ptr); name; name = gd_strtok_r (0, LISTSEPARATOR, &strtok_ptr)) { char *path_ptr = NULL; /* make a fresh copy each time - strtok corrupts it. */ sprintf (path, "%s", fontsearchpath); /* * Allocate an oversized buffer that is guaranteed to be * big enough for all paths to be tested. */ /* 2.0.22: Thorben Kundinger: +8 is needed, not +6. */ fullname = gdReallocEx(fullname, strlen (fontsearchpath) + strlen (name) + 8); if (!fullname) { gdFree(fontlist); gdFree(path); return "could not alloc full path of font"; } /* if name is an absolute or relative pathname then test directly */ #ifdef NETWARE /* netware uses the format "volume:/path" or the standard "/path" */ if (name[0] != 0 && (strstr(name, ":/") || name[0] == '/')) #else if (strchr (name, '/') || (name[0] != 0 && name[1] == ':' && (name[2] == '/' || name[2] == '\\'))) #endif { sprintf (fullname, "%s", name); if (access (fullname, R_OK) == 0) { font_found++; break; } } for (dir = gd_strtok_r (path, PATHSEPARATOR, &path_ptr); dir; dir = gd_strtok_r (0, PATHSEPARATOR, &path_ptr)) { if (strchr (name, '.')) { sprintf (fullname, "%s/%s", dir, name); if (access (fullname, R_OK) == 0) { font_found++; break; } else { continue; } } sprintf (fullname, "%s/%s.ttf", dir, name); if (access (fullname, R_OK) == 0) { font_found++; break; } sprintf (fullname, "%s/%s.pfa", dir, name); if (access (fullname, R_OK) == 0) { font_found++; break; } sprintf (fullname, "%s/%s.pfb", dir, name); if (access (fullname, R_OK) == 0) { font_found++; break; } sprintf (fullname, "%s/%s.dfont", dir, name); if (access (fullname, R_OK) == 0) { font_found++; break; } } if (font_found) break; } gdFree (path); if (fontlist != NULL) { gdFree (fontlist); fontlist = NULL; } if (!font_found) { gdFree (fullname); return "Could not find/open font"; } *fontpath = fullname; return NULL; } BGD_DECLARE(int) gdFTUseFontConfig(int flag) { #ifdef HAVE_LIBFONTCONFIG fontConfigFlag = flag; return 1; #else (void)flag; return 0; #endif /* HAVE_LIBFONTCONFIG */ } libgd-gd-2.1.1/src/gdfx.c000066400000000000000000000325641245535672000150720ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include "gd.h" #include "gd_errors.h" #include /* In tests this is sufficient to prevent obvious artifacts */ #define MAG 4 #define PI 3.141592 #define DEG2RAD(x) ((x)*PI/180.) #define MAX(x,y) ((x) > (y) ? (x) : (y)) #define MIN(x,y) ((x) < (y) ? (x) : (y)) #define MAX4(x,y,z,w) \ ((MAX((x),(y))) > (MAX((z),(w))) ? (MAX((x),(y))) : (MAX((z),(w)))) #define MIN4(x,y,z,w) \ ((MIN((x),(y))) < (MIN((z),(w))) ? (MIN((x),(y))) : (MIN((z),(w)))) #define MAXX(x) MAX4(x[0],x[2],x[4],x[6]) #define MINX(x) MIN4(x[0],x[2],x[4],x[6]) #define MAXY(x) MAX4(x[1],x[3],x[5],x[7]) #define MINY(x) MIN4(x[1],x[3],x[5],x[7]) BGD_DECLARE(char *) gdImageStringFTCircle (gdImagePtr im, int cx, int cy, double radius, double textRadius, double fillPortion, char *font, double points, char *top, char *bottom, int fgcolor) { char *err; int w; int brect[8]; int sx1, sx2, sy1, sy2, sx, sy; int x, y; int fr, fg, fb, fa; int ox, oy; double prop; gdImagePtr im1; gdImagePtr im2; gdImagePtr im3; /* obtain brect so that we can size the image */ err = gdImageStringFT ((gdImagePtr) NULL, &brect[0], 0, font, points * MAG, 0, 0, 0, bottom); if (err) { return err; } sx1 = MAXX (brect) - MINX (brect) + 6; sy1 = MAXY (brect) - MINY (brect) + 6; err = gdImageStringFT ((gdImagePtr) NULL, &brect[0], 0, font, points * MAG, 0, 0, 0, top); if (err) { return err; } sx2 = MAXX (brect) - MINX (brect) + 6; sy2 = MAXY (brect) - MINY (brect) + 6; /* Pad by 4 pixels to allow for slight errors observed in the bounding box returned by freetype */ if (sx1 > sx2) { sx = sx1 * 2 + 4; } else { sx = sx2 * 2 + 4; } if (sy1 > sy2) { sy = sy1; } else { sy = sy2; } im1 = gdImageCreateTrueColor (sx, sy); if (!im1) { return "could not create first image"; } err = gdImageStringFT (im1, 0, gdTrueColor (255, 255, 255), font, points * MAG, 0, ((sx / 2) - sx1) / 2, points * MAG, bottom); if (err) { gdImageDestroy (im1); return err; } /* We don't know the descent, which would be needed to do this with the angle parameter. Instead, implement a simple flip operation ourselves. */ err = gdImageStringFT (im1, 0, gdTrueColor (255, 255, 255), font, points * MAG, 0, sx / 2 + ((sx / 2) - sx2) / 2, points * MAG, top); if (err) { gdImageDestroy (im1); return err; } /* Flip in place is tricky, be careful not to double-swap things */ if (sy & 1) { for (y = 0; (y <= (sy / 2)); y++) { int xlimit = sx - 2; if (y == (sy / 2)) { /* If there is a "middle" row, be careful not to swap twice! */ xlimit -= (sx / 4); } for (x = (sx / 2) + 2; (x < xlimit); x++) { int t; int ox = sx - x + (sx / 2) - 1; int oy = sy - y - 1; t = im1->tpixels[oy][ox]; im1->tpixels[oy][ox] = im1->tpixels[y][x]; im1->tpixels[y][x] = t; } } } else { for (y = 0; (y < (sy / 2)); y++) { int xlimit = sx - 2; for (x = (sx / 2) + 2; (x < xlimit); x++) { int t; int ox = sx - x + (sx / 2) - 1; int oy = sy - y - 1; t = im1->tpixels[oy][ox]; im1->tpixels[oy][ox] = im1->tpixels[y][x]; im1->tpixels[y][x] = t; } } } #if STEP_PNGS { FILE *out = fopen ("gdfx1.png", "wb"); gdImagePng (im1, out); fclose (out); } #endif /* STEP_PNGS */ /* Resample taller; the exact proportions of the text depend on the ratio of textRadius to radius, and the value of fillPortion */ if (sx > sy * 10) { w = sx; } else { w = sy * 10; } im2 = gdImageCreateTrueColor (w, w); if (!im2) { gdImageDestroy (im1); return "could not create resampled image"; } prop = textRadius / radius; gdImageCopyResampled (im2, im1, gdImageSX (im2) * (1.0 - fillPortion) / 4, sy * 10 * (1.0 - prop), 0, 0, gdImageSX (im2) * fillPortion / 2, sy * 10 * prop, gdImageSX (im1) / 2, gdImageSY (im1)); gdImageCopyResampled (im2, im1, (gdImageSX (im2) / 2) + gdImageSX (im2) * (1.0 - fillPortion) / 4, sy * 10 * (1.0 - prop), gdImageSX (im1) / 2, 0, gdImageSX (im2) * fillPortion / 2, sy * 10 * prop, gdImageSX (im1) / 2, gdImageSY (im1)); #if STEP_PNGS { FILE *out = fopen ("gdfx2.png", "wb"); gdImagePng (im2, out); fclose (out); } #endif /* STEP_PNGS */ /* Ready to produce a circle */ im3 = gdImageSquareToCircle (im2, radius); gdImageDestroy (im1); gdImageDestroy (im2); /* Now blend im3 with the destination. Cheat a little. The source (im3) is white-on-black, so we can use the red component as a basis for alpha as long as we're careful to shift off the extra bit and invert (alpha ranges from 0 to 127 where 0 is OPAQUE). Also be careful to allow for an alpha component in the fgcolor parameter itself (gug!) */ fr = gdTrueColorGetRed (fgcolor); fg = gdTrueColorGetGreen (fgcolor); fb = gdTrueColorGetBlue (fgcolor); fa = gdTrueColorGetAlpha (fgcolor); ox = cx - (im3->sx / 2); oy = cy - (im3->sy / 2); for (y = 0; (y < im3->sy); y++) { for (x = 0; (x < im3->sx); x++) { int a = gdTrueColorGetRed (im3->tpixels[y][x]) >> 1; a *= (127 - fa); a /= 127; a = 127 - a; gdImageSetPixel (im, x + ox, y + oy, gdTrueColorAlpha (fr, fg, fb, a)); } } gdImageDestroy (im3); return 0; } #if GDFX_MAIN int main (int argc, char *argv[]) { FILE *in; FILE *out; gdImagePtr im; int radius; /* Create an image of text on a circle, with an alpha channel so that we can copy it onto a background */ in = fopen ("eleanor.jpg", "rb"); if (!in) { im = gdImageCreateTrueColor (300, 300); } else { im = gdImageCreateFromJpeg (in); fclose (in); } if (gdImageSX (im) < gdImageSY (im)) { radius = gdImageSX (im) / 2; } else { radius = gdImageSY (im) / 2; } gdImageStringFTCircle (im, gdImageSX (im) / 2, gdImageSY (im) / 2, radius, radius / 2, 0.8, "arial", 24, "top text", "bottom text", gdTrueColorAlpha (240, 240, 255, 32)); out = fopen ("gdfx.png", "wb"); if (!out) { gd_error("Can't create gdfx.png\n"); return 1; } gdImagePng (im, out); fclose (out); gdImageDestroy (im); return 0; } #endif /* GDFX_MAIN */ /* Note: don't change these */ #define SUPER 2 #define SUPERBITS1 1 #define SUPERBITS2 2 BGD_DECLARE(gdImagePtr) gdImageSquareToCircle (gdImagePtr im, int radius) { int x, y; double c; gdImagePtr im2; if (im->sx != im->sy) { /* Source image must be square */ return 0; } im2 = gdImageCreateTrueColor (radius * 2, radius * 2); /* Supersampling for a nicer result */ c = (im2->sx / 2) * SUPER; for (y = 0; (y < im2->sy * SUPER); y++) { for (x = 0; (x < im2->sx * SUPER); x++) { double rho = sqrt ((x - c) * (x - c) + (y - c) * (y - c)); int pix; int cpix; double theta; double ox; double oy; int red, green, blue, alpha; if (rho > c) { continue; } theta = atan2 (x - c, y - c) + PI / 2; if (theta < 0) { theta += 2 * PI; } /* Undo supersampling */ oy = (rho * im->sx) / (im2->sx * SUPER / 2); ox = theta * im->sx / (3.141592653 * 2); pix = gdImageGetPixel (im, ox, oy); cpix = im2->tpixels[y >> SUPERBITS1][x >> SUPERBITS1]; red = (gdImageRed (im, pix) >> SUPERBITS2) + gdTrueColorGetRed (cpix); green = (gdImageGreen (im, pix) >> SUPERBITS2) + gdTrueColorGetGreen (cpix); blue = (gdImageBlue (im, pix) >> SUPERBITS2) + gdTrueColorGetBlue (cpix); alpha = (gdImageAlpha (im, pix) >> SUPERBITS2) + gdTrueColorGetAlpha (cpix); im2->tpixels[y >> SUPERBITS1][x >> SUPERBITS1] = gdTrueColorAlpha (red, green, blue, alpha); } } /* Restore full dynamic range, 0-63 yields 0-252. Replication of first 2 bits in last 2 bits has the desired effect. Note slightly different arithmetic for alpha which is 7-bit. NOTE: only correct for SUPER == 2 */ for (y = 0; (y < im2->sy); y++) { for (x = 0; (x < im2->sx); x++) { /* Copy first 2 bits to last 2 bits, matching the dynamic range of the original cheaply */ int cpix = im2->tpixels[y][x]; im2->tpixels[y][x] = gdTrueColorAlpha ((gdTrueColorGetRed (cpix) & 0xFC) + ((gdTrueColorGetRed (cpix) & 0xC0) >> 6), (gdTrueColorGetGreen (cpix) & 0xFC) + ((gdTrueColorGetGreen (cpix) & 0xC0) >> 6), (gdTrueColorGetBlue (cpix) & 0xFC) + ((gdTrueColorGetBlue (cpix) & 0xC0) >> 6), (gdTrueColorGetAlpha (cpix) & 0x7C) + ((gdTrueColorGetAlpha (cpix) & 0x60) >> 6)); } } return im2; } /* 2.0.16: Called by gdImageSharpen to avoid excessive code repetition Added on 2003-11-19 by Paul Troughton (paultroughtonieeeorg) Given filter coefficents and colours of three adjacent pixels, returns new colour for centre pixel */ int gdImageSubSharpen (int pc, int c, int nc, float inner_coeff, float outer_coeff) { float red, green, blue, alpha; red = inner_coeff * gdTrueColorGetRed (c) + outer_coeff * (gdTrueColorGetRed (pc) + gdTrueColorGetRed (nc)); green = inner_coeff * gdTrueColorGetGreen (c) + outer_coeff * (gdTrueColorGetGreen (pc) + gdTrueColorGetGreen (nc)); blue = inner_coeff * gdTrueColorGetBlue (c) + outer_coeff * (gdTrueColorGetBlue (pc) + gdTrueColorGetBlue (nc)); alpha = gdTrueColorGetAlpha (c); /* Clamping, as can overshoot bounds in either direction */ if (red > 255.0f) { red = 255.0f; } if (green > 255.0f) { green = 255.0f; } if (blue > 255.0f) { blue = 255.0f; } if (red < 0.0f) { red = 0.0f; } if (green < 0.0f) { green = 0.0f; } if (blue < 0.0f) { blue = 0.0f; } return gdTrueColorAlpha ((int) red, (int) green, (int) blue, (int) alpha); } /* * Sharpen function added on 2003-11-19 * by Paul Troughton (paultroughtonieeeorg) * Simple 3x3 convolution kernel * Makes use of seperability * Faster, but less flexible, than full-blown unsharp masking * pct is sharpening percentage, and can be greater than 100 * Silently does nothing to non-truecolor images * Silently does nothing for pct<0, as not a useful blurring function * Leaves transparency/alpha-channel untouched */ BGD_DECLARE(void) gdImageSharpen (gdImagePtr im, int pct) { int x, y; int sx, sy; float inner_coeff, outer_coeff; sx = im->sx; sy = im->sy; /* Must sum to 1 to avoid overall change in brightness. * Scaling chosen so that pct=100 gives 1-D filter [-1 6 -1]/4, * resulting in a 2-D filter [1 -6 1; -6 36 -6; 1 -6 1]/16, * which gives noticeable, but not excessive, sharpening */ outer_coeff = -pct / 400.0; inner_coeff = 1 - 2 * outer_coeff; /* Don't try to do anything with non-truecolor images, as pointless, * nor for pct<=0, as small kernel size leads to nasty artefacts when blurring */ if ((im->trueColor) && (pct > 0)) { /* First pass, 1-D convolution column-wise */ for (x = 0; x < sx; x++) { /* pc is colour of previous pixel; c of the current pixel and nc of the next */ int pc, c, nc; /* Replicate edge pixel at image boundary */ pc = gdImageGetPixel (im, x, 0); /* Stop looping before last pixel to avoid conditional within loop */ for (y = 0; y < sy - 1; y++) { c = gdImageGetPixel (im, x, y); nc = gdImageGetTrueColorPixel (im, x, y + 1); /* Update centre pixel to new colour */ gdImageSetPixel (im, x, y, gdImageSubSharpen (pc, c, nc, inner_coeff, outer_coeff)); /* Save original colour of current pixel for next time round */ pc = c; } /* Deal with last pixel, replicating current pixel at image boundary */ c = gdImageGetPixel (im, x, y); gdImageSetPixel (im, x, y, gdImageSubSharpen (pc, c, c, inner_coeff, outer_coeff)); } /* Second pass, 1-D convolution row-wise */ for (y = 0; y < sy; y++) { int pc, c; pc = gdImageGetPixel (im, 0, y); for (x = 0; x < sx - 1; x++) { int c, nc; c = gdImageGetPixel (im, x, y); nc = gdImageGetTrueColorPixel (im, x + 1, y); gdImageSetPixel (im, x, y, gdImageSubSharpen (pc, c, nc, inner_coeff, outer_coeff)); pc = c; } c = gdImageGetPixel (im, x, y); gdImageSetPixel (im, x, y, gdImageSubSharpen (pc, c, c, inner_coeff, outer_coeff)); } } } libgd-gd-2.1.1/src/gdfx.h000066400000000000000000000045321245535672000150710ustar00rootroot00000000000000#ifdef __cplusplus extern "C" { #endif #ifndef GDFX_H #define GDFX_H 1 /* im MUST be square, but can have any size. Returns a new image of width and height radius * 2, in which the X axis of the original has been remapped to theta (angle) and the Y axis of the original has been remapped to rho (distance from center). This is known as a "polar coordinate transform." */ BGD_DECLARE(gdImagePtr) gdImageSquareToCircle(gdImagePtr im, int radius); /* Draws the text 'top' and 'bottom' on 'im', curved along the edge of a circle of radius 'radius', with its center at 'cx' and 'cy'. 'top' is written clockwise along the top; 'bottom' is written counterclockwise along the bottom. 'textRadius' determines the 'height' of each character; if 'textRadius' is 1/2 of 'radius', characters extend halfway from the edge to the center. 'fillPortion' varies from 0 to 1.0, with useful values from about 0.4 to 0.9, and determines how much of the 180 degrees of arc assigned to each section of text is actually occupied by text; 0.9 looks better than 1.0 which is rather crowded. 'font' is a freetype font; see gdImageStringFT. 'points' is passed to the freetype engine and has an effect on hinting; although the size of the text is determined by radius, textRadius, and fillPortion, you should pass a point size that 'hints' appropriately -- if you know the text will be large, pass a large point size such as 24.0 to get the best results. 'fgcolor' can be any color, and may have an alpha component, do blending, etc. Returns 0 on success, or an error string. */ BGD_DECLARE(char *) gdImageStringFTCircle( gdImagePtr im, int cx, int cy, double radius, double textRadius, double fillPortion, char *font, double points, char *top, char *bottom, int fgcolor); /* 2.0.16: * Sharpen function added on 2003-11-19 * by Paul Troughton (paultroughtonieeeorg) * Simple 3x3 convolution kernel * Makes use of seperability * Faster, but less flexible, than full-blown unsharp masking * pct is sharpening percentage, and can be greater than 100 * Silently does nothing to non-truecolor images * Silently does nothing for pct<0, as not a useful blurring function * Leaves transparency/alpha-channel untouched */ BGD_DECLARE(void) gdImageSharpen (gdImagePtr im, int pct); #endif /* GDFX_H */ #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/gdhelpers.c000066400000000000000000000027661245535672000161200ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" #include "gdhelpers.h" #include #include #include #include /* TBB: gd_strtok_r is not portable; provide an implementation */ #define SEP_TEST (separators[*((unsigned char *) s)]) char * gd_strtok_r (char *s, char *sep, char **state) { char separators[256]; char *result = 0; memset (separators, 0, sizeof (separators)); while (*sep) { separators[*((unsigned char *) sep)] = 1; sep++; } if (!s) { /* Pick up where we left off */ s = *state; } /* 1. EOS */ if (!(*s)) { *state = s; return 0; } /* 2. Leading separators, if any */ if (SEP_TEST) { do { s++; } while (SEP_TEST); /* 2a. EOS after separators only */ if (!(*s)) { *state = s; return 0; } } /* 3. A token */ result = s; do { /* 3a. Token at end of string */ if (!(*s)) { *state = s; return result; } s++; } while (!SEP_TEST); /* 4. Terminate token and skip trailing separators */ *s = '\0'; do { s++; } while (SEP_TEST); /* 5. Return token */ *state = s; return result; } void * gdCalloc (size_t nmemb, size_t size) { return calloc (nmemb, size); } void * gdMalloc (size_t size) { return malloc (size); } void * gdRealloc (void *ptr, size_t size) { return realloc (ptr, size); } void * gdReallocEx (void *ptr, size_t size) { void *newPtr = gdRealloc (ptr, size); if (!newPtr && ptr) gdFree(ptr); return newPtr; } BGD_DECLARE(void) gdFree (void *ptr) { free (ptr); } libgd-gd-2.1.1/src/gdhelpers.h000066400000000000000000000044711245535672000161200ustar00rootroot00000000000000#ifdef __cplusplus extern "C" { #endif #ifndef GDHELPERS_H #define GDHELPERS_H 1 /* sys/types.h is needed for size_t on Sparc-SunOS-4.1 */ #ifndef _WIN32_WCE #include #else #include #endif /* _WIN32_WCE */ /* TBB: strtok_r is not universal; provide an implementation of it. */ char * gd_strtok_r (char *s, char *sep, char **state); /* These functions wrap memory management. gdFree is in gd.h, where callers can utilize it to correctly free memory allocated by these functions with the right version of free(). */ void *gdCalloc (size_t nmemb, size_t size); void *gdMalloc (size_t size); void *gdRealloc (void *ptr, size_t size); /* The extended version of gdReallocEx will free *ptr if the * realloc fails */ void *gdReallocEx (void *ptr, size_t size); /* Returns nonzero if multiplying the two quantities will result in integer overflow. Also returns nonzero if either quantity is negative. By Phil Knirsch based on netpbm fixes by Alan Cox. */ int overflow2(int a, int b); /* 2.0.16: portable mutex support for thread safety. */ #if defined(CPP_SHARP) # define gdMutexDeclare(x) # define gdMutexSetup(x) # define gdMutexShutdown(x) # define gdMutexLock(x) # define gdMutexUnlock(x) #elif defined(_WIN32) /* 2.0.18: must include windows.h to get CRITICAL_SECTION. */ # include # define gdMutexDeclare(x) CRITICAL_SECTION x # define gdMutexSetup(x) InitializeCriticalSection(&x) # define gdMutexShutdown(x) DeleteCriticalSection(&x) # define gdMutexLock(x) EnterCriticalSection(&x) # define gdMutexUnlock(x) LeaveCriticalSection(&x) #elif defined(HAVE_PTHREAD) # include # define gdMutexDeclare(x) pthread_mutex_t x # define gdMutexSetup(x) pthread_mutex_init(&x, 0) # define gdMutexShutdown(x) pthread_mutex_destroy(&x) # define gdMutexLock(x) pthread_mutex_lock(&x) # define gdMutexUnlock(x) pthread_mutex_unlock(&x) #else # define gdMutexDeclare(x) # define gdMutexSetup(x) # define gdMutexShutdown(x) # define gdMutexLock(x) # define gdMutexUnlock(x) #endif /* _WIN32 || HAVE_PTHREAD */ #define DPCM2DPI(dpcm) (unsigned int)((dpcm)*2.54 + 0.5) #define DPM2DPI(dpm) (unsigned int)((dpm)*0.0254 + 0.5) #define DPI2DPCM(dpi) (unsigned int)((dpi)/2.54 + 0.5) #define DPI2DPM(dpi) (unsigned int)((dpi)/0.0254 + 0.5) #endif /* GDHELPERS_H */ #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/gdkanji.c000066400000000000000000000274571245535672000155560ustar00rootroot00000000000000/* gdkanji.c (Kanji code converter) */ /* written by Masahito Yamaga (ma@yama-ga.com) */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include "gd.h" #include "gdhelpers.h" #include "gd_errors.h" #ifdef HAVE_ERRNO_H #include #endif #include #if defined(HAVE_ICONV_H) #include #endif #ifndef HAVE_ICONV_T_DEF typedef void *iconv_t; #endif #ifndef HAVE_ICONV #define ICONV_CONST /**/ iconv_t iconv_open (const char *, const char *); size_t iconv (iconv_t, ICONV_CONST char **, size_t *, char **, size_t *); int iconv_close (iconv_t); iconv_t iconv_open (const char *tocode, const char *fromcode) { (void)tocode; (void)fromcode; return (iconv_t) (-1); } size_t iconv (iconv_t cd, ICONV_CONST char **inbuf, size_t * inbytesleft, char **outbuf, size_t * outbytesleft) { (void)cd; (void)inbuf; (void)inbytesleft; (void)outbuf; (void)outbytesleft; return 0; } int iconv_close (iconv_t cd) { (void)cd; return 0; } #endif /* !HAVE_ICONV */ #define LIBNAME "any2eucjp()" #if defined(__MSC__) || defined(__BORLANDC__) || defined(__TURBOC__) || defined(_Windows) || defined(MSDOS) #ifndef SJISPRE #define SJISPRE 1 #endif #endif #ifdef TRUE #undef TRUE #endif #ifdef FALSE #undef FALSE #endif #define TRUE 1 #define FALSE 0 #define NEW 1 #define OLD 2 #define ESCI 3 #define NEC 4 #define EUC 5 #define SJIS 6 #define EUCORSJIS 7 #define ASCII 8 #define NEWJISSTR "JIS7" #define OLDJISSTR "jis" #define EUCSTR "eucJP" #define SJISSTR "SJIS" #define ESC 27 #define SS2 142 /* DetectKanjiCode() derived from DetectCodeType() by Ken Lunde. */ static int DetectKanjiCode (unsigned char *str) { static int whatcode = ASCII; int oldcode = ASCII; int c, i; char *lang = NULL; c = '\1'; i = 0; if (whatcode != EUCORSJIS && whatcode != ASCII) { oldcode = whatcode; whatcode = ASCII; } while ((whatcode == EUCORSJIS || whatcode == ASCII) && c != '\0') { if ((c = str[i++]) != '\0') { if (c == ESC) { c = str[i++]; if (c == '$') { c = str[i++]; if (c == 'B') whatcode = NEW; else if (c == '@') whatcode = OLD; } else if (c == '(') { c = str[i++]; if (c == 'I') whatcode = ESCI; } else if (c == 'K') whatcode = NEC; } else if ((c >= 129 && c <= 141) || (c >= 143 && c <= 159)) whatcode = SJIS; else if (c == SS2) { c = str[i++]; if ((c >= 64 && c <= 126) || (c >= 128 && c <= 160) || (c >= 224 && c <= 252)) whatcode = SJIS; else if (c >= 161 && c <= 223) whatcode = EUCORSJIS; } else if (c >= 161 && c <= 223) { c = str[i++]; if (c >= 240 && c <= 254) whatcode = EUC; else if (c >= 161 && c <= 223) whatcode = EUCORSJIS; else if (c >= 224 && c <= 239) { whatcode = EUCORSJIS; while (c >= 64 && c != '\0' && whatcode == EUCORSJIS) { if (c >= 129) { if (c <= 141 || (c >= 143 && c <= 159)) whatcode = SJIS; else if (c >= 253 && c <= 254) whatcode = EUC; } c = str[i++]; } } else if (c <= 159) whatcode = SJIS; } else if (c >= 240 && c <= 254) whatcode = EUC; else if (c >= 224 && c <= 239) { c = str[i++]; if ((c >= 64 && c <= 126) || (c >= 128 && c <= 160)) whatcode = SJIS; else if (c >= 253 && c <= 254) whatcode = EUC; else if (c >= 161 && c <= 252) whatcode = EUCORSJIS; } } } #ifdef DEBUG if (whatcode == ASCII) gd_error_ex(GD_DEBUG, "Kanji code not included."); else if (whatcode == EUCORSJIS) gd_error_ex(GD_DEBUG, "Kanji code not detected."); else gd_error_ex(GD_DEBUG, "Kanji code detected at %d byte.", i); #endif if (whatcode == EUCORSJIS && oldcode != ASCII) whatcode = oldcode; if (whatcode == EUCORSJIS) { if (getenv ("LC_ALL")) lang = getenv ("LC_ALL"); else if (getenv ("LC_CTYPE")) lang = getenv ("LC_CTYPE"); else if (getenv ("LANG")) lang = getenv ("LANG"); if (lang) { if (strcmp (lang, "ja_JP.SJIS") == 0 || #ifdef hpux strcmp (lang, "japanese") == 0 || #endif strcmp (lang, "ja_JP.mscode") == 0 || strcmp (lang, "ja_JP.PCK") == 0) whatcode = SJIS; else if (strncmp (lang, "ja", 2) == 0) #ifdef SJISPRE whatcode = SJIS; #else whatcode = EUC; #endif } } if (whatcode == EUCORSJIS) #ifdef SJISPRE whatcode = SJIS; #else whatcode = EUC; #endif return whatcode; } /* SJIStoJIS() is sjis2jis() by Ken Lunde. */ static void SJIStoJIS (int *p1, int *p2) { register unsigned char c1 = *p1; register unsigned char c2 = *p2; register int adjust = c2 < 159; register int rowOffset = c1 < 160 ? 112 : 176; register int cellOffset = adjust ? (31 + (c2 > 127)) : 126; *p1 = ((c1 - rowOffset) << 1) - adjust; *p2 -= cellOffset; } /* han2zen() was derived from han2zen() written by Ken Lunde. */ #define IS_DAKU(c) ((c >= 182 && c <= 196) || (c >= 202 && c <= 206) || (c == 179)) #define IS_HANDAKU(c) (c >= 202 && c <= 206) static void han2zen (int *p1, int *p2) { int c = *p1; int daku = FALSE; int handaku = FALSE; int mtable[][2] = { {129, 66}, {129, 117}, {129, 118}, {129, 65}, {129, 69}, {131, 146}, {131, 64}, {131, 66}, {131, 68}, {131, 70}, {131, 72}, {131, 131}, {131, 133}, {131, 135}, {131, 98}, {129, 91}, {131, 65}, {131, 67}, {131, 69}, {131, 71}, {131, 73}, {131, 74}, {131, 76}, {131, 78}, {131, 80}, {131, 82}, {131, 84}, {131, 86}, {131, 88}, {131, 90}, {131, 92}, {131, 94}, {131, 96}, {131, 99}, {131, 101}, {131, 103}, {131, 105}, {131, 106}, {131, 107}, {131, 108}, {131, 109}, {131, 110}, {131, 113}, {131, 116}, {131, 119}, {131, 122}, {131, 125}, {131, 126}, {131, 128}, {131, 129}, {131, 130}, {131, 132}, {131, 134}, {131, 136}, {131, 137}, {131, 138}, {131, 139}, {131, 140}, {131, 141}, {131, 143}, {131, 147}, {129, 74}, {129, 75} }; if (*p2 == 222 && IS_DAKU (*p1)) daku = TRUE; /* Daku-ten */ else if (*p2 == 223 && IS_HANDAKU (*p1)) handaku = TRUE; /* Han-daku-ten */ *p1 = mtable[c - 161][0]; *p2 = mtable[c - 161][1]; if (daku) { if ((*p2 >= 74 && *p2 <= 103) || (*p2 >= 110 && *p2 <= 122)) (*p2)++; else if (*p2 == 131 && *p2 == 69) *p2 = 148; } else if (handaku && *p2 >= 110 && *p2 <= 122) (*p2) += 2; } /* Recast strcpy to handle unsigned chars used below. */ #define ustrcpy(A,B) (strcpy((char*)(A),(const char*)(B))) static void do_convert (unsigned char **to_p, unsigned char **from_p, const char *code) { unsigned char *to = *to_p; unsigned char *from = *from_p; #ifdef HAVE_ICONV iconv_t cd; size_t from_len, to_len; if ((cd = iconv_open (EUCSTR, code)) == (iconv_t) - 1) { gd_error ("iconv_open() error"); #ifdef HAVE_ERRNO_H if (errno == EINVAL) gd_error ("invalid code specification: \"%s\" or \"%s\"", EUCSTR, code); #endif ustrcpy (to, from); return; } from_len = strlen ((const char *)from) + 1; to_len = BUFSIZ; if ((int) (iconv (cd, (char **)from_p, &from_len, (char **)to_p, &to_len)) == -1) { #ifdef HAVE_ERRNO_H if (errno == EINVAL) gd_error ("invalid end of input string"); else if (errno == EILSEQ) gd_error ("invalid code in input string"); else if (errno == E2BIG) gd_error ("output buffer overflow at do_convert()"); else #endif gd_error ("something happen"); ustrcpy (to, from); return; } if (iconv_close (cd) != 0) { gd_error ("iconv_close() error"); } #else int p1, p2, i, j; int jisx0208 = FALSE; int hankaku = FALSE; j = 0; if (strcmp (code, NEWJISSTR) == 0 || strcmp (code, OLDJISSTR) == 0) { for (i = 0; from[i] != '\0' && j < BUFSIZ; i++) { if (from[i] == ESC) { i++; if (from[i] == '$') { jisx0208 = TRUE; hankaku = FALSE; i++; } else if (from[i] == '(') { jisx0208 = FALSE; i++; if (from[i] == 'I') /* Hankaku Kana */ hankaku = TRUE; else hankaku = FALSE; } } else { if (jisx0208) to[j++] = from[i] + 128; else if (hankaku) { to[j++] = SS2; to[j++] = from[i] + 128; } else to[j++] = from[i]; } } } else if (strcmp (code, SJISSTR) == 0) { for (i = 0; from[i] != '\0' && j < BUFSIZ; i++) { p1 = from[i]; if (p1 < 127) to[j++] = p1; else if ((p1 >= 161) && (p1 <= 223)) { /* Hankaku Kana */ to[j++] = SS2; to[j++] = p1; } else { p2 = from[++i]; SJIStoJIS (&p1, &p2); to[j++] = p1 + 128; to[j++] = p2 + 128; } } } else { gd_error ("invalid code specification: \"%s\"", code); return; } if (j >= BUFSIZ) { gd_error ("output buffer overflow at do_convert()"); ustrcpy (to, from); } else to[j] = '\0'; #endif /* HAVE_ICONV */ } static int do_check_and_conv (unsigned char *to, unsigned char *from) { static unsigned char tmp[BUFSIZ]; unsigned char *tmp_p = &tmp[0]; int p1, p2, i, j; int kanji = TRUE; switch (DetectKanjiCode (from)) { case NEW: gd_error_ex(GD_DEBUG, "Kanji code is New JIS."); do_convert (&tmp_p, &from, NEWJISSTR); break; case OLD: gd_error_ex(GD_DEBUG, "Kanji code is Old JIS."); do_convert (&tmp_p, &from, OLDJISSTR); break; case ESCI: gd_error_ex(GD_DEBUG, "This string includes Hankaku-Kana (jisx0201) escape sequence [ESC] + ( + I."); do_convert (&tmp_p, &from, NEWJISSTR); break; case NEC: gd_error_ex(GD_DEBUG, "Kanji code is NEC Kanji."); gd_error("cannot convert NEC Kanji."); ustrcpy (tmp, from); kanji = FALSE; break; case EUC: gd_error_ex(GD_DEBUG, "Kanji code is EUC."); ustrcpy (tmp, from); break; case SJIS: gd_error_ex(GD_DEBUG, "Kanji code is SJIS."); do_convert (&tmp_p, &from, SJISSTR); break; case EUCORSJIS: gd_error_ex(GD_DEBUG, "Kanji code is EUC or SJIS."); ustrcpy (tmp, from); kanji = FALSE; break; case ASCII: gd_error_ex(GD_DEBUG, "This is ASCII string."); ustrcpy (tmp, from); kanji = FALSE; break; default: gd_error_ex(GD_DEBUG, "This string includes unknown code."); ustrcpy (tmp, from); kanji = FALSE; break; } /* Hankaku Kana ---> Zenkaku Kana */ if (kanji) { j = 0; for (i = 0; tmp[i] != '\0' && j < BUFSIZ; i++) { if (tmp[i] == SS2) { p1 = tmp[++i]; if (tmp[i + 1] == SS2) { p2 = tmp[i + 2]; if (p2 == 222 || p2 == 223) i += 2; else p2 = 0; } else p2 = 0; han2zen (&p1, &p2); SJIStoJIS (&p1, &p2); to[j++] = p1 + 128; to[j++] = p2 + 128; } else to[j++] = tmp[i]; } if (j >= BUFSIZ) { gd_error("output buffer overflow at Hankaku --> Zenkaku"); ustrcpy (to, tmp); } else to[j] = '\0'; } else ustrcpy (to, tmp); return kanji; } int any2eucjp (unsigned char *dest, unsigned char *src, unsigned int dest_max) { static unsigned char tmp_dest[BUFSIZ]; int ret; if (strlen ((const char *) src) >= BUFSIZ) { gd_error("input string too large"); return -1; } if (dest_max > BUFSIZ) { gd_error ("invalid maximum size of destination\nit should be less than %d.", BUFSIZ); return -1; } ret = do_check_and_conv (tmp_dest, src); if (strlen ((const char *) tmp_dest) >= dest_max) { gd_error("output buffer overflow"); ustrcpy (dest, src); return -1; } ustrcpy (dest, tmp_dest); return ret; } #if 0 unsigned int strwidth (unsigned char *s) { unsigned char *t; unsigned int i; t = (unsigned char *) gdMalloc (BUFSIZ); any2eucjp (t, s, BUFSIZ); i = strlen (t); gdFree (t); return i; } #ifdef DEBUG int main () { unsigned char input[BUFSIZ]; unsigned char *output; unsigned char *str; int c, i = 0; while ((c = fgetc (stdin)) != '\n' && i < BUFSIZ) input[i++] = c; input[i] = '\0'; printf ("input : %d bytes\n", strlen ((const char *) input)); printf ("output: %d bytes\n", strwidth (input)); output = (unsigned char *) gdMalloc (BUFSIZ); any2eucjp (output, input, BUFSIZ); str = output; while (*str != '\0') putchar (*(str++)); putchar ('\n'); gdFree (output); return 0; } #endif #endif libgd-gd-2.1.1/src/gdparttopng.c000066400000000000000000000023561245535672000164670ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include /* For atoi */ #include "gd.h" /* A short program which converts a .png file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ int main (int argc, char **argv) { gdImagePtr im; FILE *in, *out; int x, y, w, h; if (argc != 7) { fprintf (stderr, "Usage: gdparttopng filename.gd filename.png x y w h\n"); exit (1); } in = fopen (argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit (1); } x = atoi (argv[3]); y = atoi (argv[4]); w = atoi (argv[5]); h = atoi (argv[6]); printf ("Extracting from (%d, %d), size is %dx%d\n", x, y, w, h); im = gdImageCreateFromGd2Part (in, x, y, w, h); fclose (in); if (!im) { fprintf(stderr, "Input is not in GD2 format!\n"); exit (1); } out = fopen (argv[2], "wb"); if (!out) { fprintf(stderr, "Output file cannot be written to!\n"); gdImageDestroy (im); exit (1); } #ifdef HAVE_LIBPNG gdImagePng (im, out); #else fprintf(stderr, "No PNG library support.\n"); #endif fclose (out); gdImageDestroy (im); return 0; } libgd-gd-2.1.1/src/gdpp.cxx000066400000000000000000000146731245535672000154550ustar00rootroot00000000000000/* ***************************************************************************** ** $Id$ ** Initial file written and documented by: ** Kevin Shepherd December 2007 ** of Scarlet Line http://www.scarletline.com/ *******************************************************************************/ /** \file gdpp.cxx \brief Implements the non-trivial methods of GD::Image. Implementation of the more complex methods defined in gdpp.h. Notably includes the methods which determine the image file format of a file before reading it into memory. */ #ifdef __cplusplus #include "gdpp.h" namespace GD { /** Load an image from a file, after attempting to determine it's image file format. Invoke CreateFrom with an already opened pointer to a file containing the desired image. CreateFrom does not close the file. \param[in] in An opened FILE * pointer. \return true for success, or false if unable to load the image (most often because the file is corrupt or does not contain a recognized image format). You can call Width() and Height() member functions of the image to determine its size. */ bool Image::CreateFrom(FILE * in) { bool rtn; int c = fgetc(in); ungetc(c, in); switch (c) { /* PNG The first eight bytes of a PNG file always contain the following (decimal) values: 0x89 0x50 0x4E 0x47 0x0D 0x0A 0x1A 0x0A == .PNG\r\n.\n */ #ifdef HAVE_LIBPNG case 0x89: // PNG rtn = CreateFromPng(in); break; #endif /* GIF 0x47 0x49 0x46 */ case 0x47: // GIF rtn = CreateFromGif(in); break; #ifdef HAVE_LIBJPEG /* JPEG A JFIF-standard file will start with the four bytes (hex) FF D8 FF E0, followed by two variable bytes (often hex 00 10), followed by 'JFIF'. */ case 0xFF: // JPEG rtn = CreateFromJpeg(in); break; #endif /* WBMP WBMP Type 0: B/W, Uncompressed bitmap is the only gd supported type */ case 0x00: // WBMP rtn = CreateFromWBMP(in); break; /* GD2 0x67 0x64 0x32 0x00 == GD2\0 Starts with gd2 */ case 0x67: // GD2 rtn = CreateFromGd2(in); break; /* GD 0xFF 0xFE or 0xFF 0xFF Conflicts with Jpeg */ /* XBM #define test_width 16 #define test_height 7 */ case 0x23: // XBM rtn = CreateFromXbm(in); break; default: rtn = false; break; } return rtn; } /** Load an image from a standard input stream, after attempting to determine it's image file format. Invoke CreateFrom with an already opened stream containing the desired image. CreateFrom does not close the stream. \param[in] in An opened standard library input stream. \return true for success, or false if unable to load the image (most often because the file is corrupt or does not contain a recognized image format). You can call Width() and Height() member functions of the image to determine its size. Example usage, convert anything to gif: #include #include std::ifstream in("image.xxx", std::ios_base::in | std::ios_base::binary ); GD::Image im; im.CreateFrom(in); if (im.good()) { std::ofstream out("image.gif", std::ios_base::out | std::ios_base::binary ); im.Gif(out); } */ bool Image::CreateFrom(std::istream & in) { bool rtn; switch (in.peek()) { #ifdef HAVE_LIBPNG /* PNG The first eight bytes of a PNG file always contain the following (decimal) values: 0x89 0x50 0x4E 0x47 0x0D 0x0A 0x1A 0x0A == .PNG\r\n.\n */ case 0x89: // PNG rtn = CreateFromPng(in); break; #endif /* GIF 0x47 0x49 0x46 */ case 0x47: // GIF rtn = CreateFromGif(in); break; #ifdef HAVE_LIBJPEG /* JPEG A JFIF-standard file will start with the four bytes (hex) FF D8 FF E0, followed by two variable bytes (often hex 00 10), followed by 'JFIF'. */ case 0xFF: // JPEG rtn = CreateFromJpeg(in); break; #endif /* WBMP WBMP Type 0: B/W, Uncompressed bitmap is the only gd supported type */ case 0x00: // WBMP rtn = CreateFromWBMP(in); break; /* GD2 0x67 0x64 0x32 0x00 == GD2\0 Starts with gd2 */ case 0x67: // GD2 rtn = CreateFromGd2(in); break; /* GD 0xFF 0xFE or 0xFF 0xFF Conflicts with Jpeg */ default: rtn = false; break; } return rtn; } /** Load an image from an in-RAM memory block, after attempting to determine it's image format. CreateFrom does not de-allocate the memory. \param[in] size The byte count of the memory block. \param[in] data A pointer to the memory block. \return true for success, or false if unable to load the image (most often because the formatting is corrupt or does not contain a recognized image format). You can call Width() and Height() member functions of the image to determine its size. */ bool Image::CreateFrom(int size, void * data) { bool rtn; switch (((unsigned char * )data)[0]) { #ifdef HAVE_LIBPNG /* PNG The first eight bytes of a PNG file always contain the following (decimal) values: 0x89 0x50 0x4E 0x47 0x0D 0x0A 0x1A 0x0A == .PNG\r\n.\n */ case 0x89: // PNG rtn = CreateFromPng(size, data); break; #endif /* GIF 0x47 0x49 0x46 */ case 0x47: // GIF rtn = CreateFromGif(size, data); break; #ifdef HAVE_LIBJPEG /* JPEG A JFIF-standard file will start with the four bytes (hex) FF D8 FF E0, followed by two variable bytes (often hex 00 10), followed by 'JFIF'. */ case 0xFF: // JPEG rtn = CreateFromJpeg(size, data); break; #endif /* WBMP WBMP Type 0: B/W, Uncompressed bitmap is the only gd supported type */ case 0x00: // WBMP rtn = CreateFromWBMP(size, data); break; /* GD2 0x67 0x64 0x32 0x00 == GD2\0 Starts with gd2 */ case 0x67: // GD2 rtn = CreateFromGd2(size, data); break; /* GD 0xFF 0xFE or 0xFF 0xFF Conflicts with Jpeg */ default: rtn = false; break; } return rtn; } } // namespace GD /** Load an image from a standard input stream, regardless of it's image file format. You can call Width() and Height() member functions of the image to determine its size. Example usage, convert anything to gif: #include #include std::ifstream in("image.xxx", std::ios_base::in | std::ios_base::binary ); GD::Image im; in >> im; if (im.good()) { std::ofstream out("image.gif", std::ios_base::out | std::ios_base::binary ); im.Gif(out); } */ std::istream & operator>> (std::istream & in, GD::Image & img) { img.CreateFrom(in); return in; } #endif /* __cplusplus */ libgd-gd-2.1.1/src/gdpp.h000066400000000000000000001457021245535672000151000ustar00rootroot00000000000000/* ***************************************************************************** ** $Id$ ** Initial file written and documented by: ** Kevin Shepherd December 2007 ** of Scarlet Line http://www.scarletline.com/ ** with contributions from Torben Nielsen. *******************************************************************************/ /** \file gdpp.h \brief Object Oriented C++ wrappers around libgd functionality. Example usage, convert png to gif: #include #include std::ifstream in("image.png", std::ios_base::in | std::ios_base::binary ); GD::Image im(in, GD::Png_tag()); if (im.good()) { std::ofstream out("image.gif", std::ios_base::out | std::ios_base::binary ); im.Gif(out); } */ #ifdef __cplusplus #ifndef _gdpp_h #define _gdpp_h #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd_io_stream.h" #include /// namespace GD:: contains the C++ wrapper classes for libgd /** This namespace is primarily to avoid name clashes, and to contain all of the gd classes within one namespace. It is not recommended to use the "using namespace" directive with this namespace. Example usage: GD::Image im(64, 32, true); // Create a truecolor image 64 pixels wide by 32 pixels high GD::Point pt(10, 8); // The point at x=10, y=8. GD::Size sz(16, 8); // The size width=16, height=8. GD::TrueColor col(0xFF, 0, 0); // The colour red; R=255, G=0, B=0. im.Rectangle(pt, sz, col.Int()); // Draw a red rectangle with top left corner at pt, of size sz. */ namespace GD { /** This class GD::Point stores a point in two dimensions, somewhere on the plane of an image. */ class BGD_EXPORT_DATA_PROT Point { public: // Constructors Point(int x, int y) :_x(x), _y(y) {} Point(const Point & p) :_x(p._x), _y(p._y) {} Point() :_x(0), _y(0) {} Point & operator=(const Point & p) { _x = p._x; _y = p._y; return (* this); } // Accessors int X() const { return _x; } int Y() const { return _y; } // Updaters void X(int x) { _x = x; } void Y(int y) { _y = y; } void set(int x, int y) { _x = x; _y = y; } int & lhsX() { return _x; } int & lhsY() { return _y; } gdPointPtr as_gdPointPtr() { return (gdPointPtr) this; } protected: int _x, _y; }; typedef Point * PointPtr; /** This class GD::Size stores length in two dimensions. Giving the size of an area as width and height. */ class BGD_EXPORT_DATA_PROT Size { public: // Constructors Size(int w, int h) :_w(w), _h(h) {} Size(const Size & p) :_w(p._w), _h(p._h) {} Size() :_w(0), _h(0) {} Size & operator=(const Size & p) { _w = p._w; _h = p._h; return (* this); } // Accessors int W() const { return _w; } int H() const { return _h; } // Updaters void W(int w) { _w = w; } void H(int h) { _h = h; } void set(int w, int h) { _w = w; _h = h; } int & lhsW() { return _w; } int & lhsH() { return _h; } protected: int _w, _h; }; typedef Size * SizePtr; /** This class GD::TrueColor stores a colour as an RGBA quadruplet. It can also be read as an integer, and in other colour formats. */ class BGD_EXPORT_DATA_PROT TrueColor { public: union as_types { int as_int; struct uchars { unsigned char blue, green, red, alpha; } as_uchar; }; TrueColor() { internal.as_int = 0; } TrueColor(int c) { internal.as_int = c; } TrueColor(unsigned char r, unsigned char g, unsigned char b, unsigned char a = 0) { internal.as_uchar.alpha = a; internal.as_uchar.red = r; internal.as_uchar.green = g; internal.as_uchar.blue = b; } // Accessors int Int() const { return internal.as_int; } unsigned char Red() const { return internal.as_uchar.red; } unsigned char Green() const { return internal.as_uchar.green; } unsigned char Blue() const { return internal.as_uchar.blue; } unsigned char Alpha() const { return internal.as_uchar.alpha; } // Updaters void set(int c) { internal.as_int = c; } void set(unsigned char r, unsigned char g, unsigned char b, unsigned char a = 0) { internal.as_uchar.alpha = a; internal.as_uchar.red = r; internal.as_uchar.green = g; internal.as_uchar.blue = b; } void Red(unsigned char c) { internal.as_uchar.red = c; } void Green(unsigned char c) { internal.as_uchar.green = c; } void Blue(unsigned char c) { internal.as_uchar.blue = c; } void Alpha(unsigned char c) { internal.as_uchar.alpha = c; } protected: as_types internal; }; /* The following tags are simply empty structures which are used to tell the compiler which constructor we want when we know the image file format. */ struct BGD_EXPORT_DATA_PROT Png_tag {}; struct BGD_EXPORT_DATA_PROT Gif_tag {}; struct BGD_EXPORT_DATA_PROT WBMP_tag {}; struct BGD_EXPORT_DATA_PROT Jpeg_tag {}; struct BGD_EXPORT_DATA_PROT Gd_tag {}; struct BGD_EXPORT_DATA_PROT Gd2_tag {}; struct BGD_EXPORT_DATA_PROT Xbm_tag {}; /** This class GD::Image wraps all of the 'C' libgd functionality for the convenience of C++ users. An instance of this class corresponds to a single image. */ class BGD_EXPORT_DATA_PROT Image { public: /** Construct a null image */ Image() :im(0) {} /** Construct a blank image, of the given size and colour format type. \param[in] sx Width of the image \param[in] sy Height of the image \param[in] istruecolor Create a true colour image, defaults to false, i.e. create an indexed palette image. */ Image(int sx, int sy, bool istruecolor = false) :im(0) { if (istruecolor) CreateTrueColor(sx, sy); else Create(sx, sy); } /** Construct a blank image, of the given size and colour format type. \param[in] s Width and height of the image \param[in] istruecolor Create a true colour image, defaults to false, i.e. create an indexed palette image. */ Image(const Size & s, bool istruecolor = false) :im(0) { if (istruecolor) CreateTrueColor(s); else Create(s); } /** Construct an instance of the GD::Image class, given the internal gdImage poimter. Note that gdImageDestroy will be called on the image pointer in the destructor. \param[in] i Pointer to the internal gdImage */ Image(gdImagePtr i) :im(i) {} /** Copy constructor. Construct an instance of the GD::Image class, by making a copy of the GD::Image provided. \param[in] i Reference to the image to be copied */ Image(const GD::Image & i) :im(0) { Copy(i); } /** Construct an image by reading from \p in. This constructor will first attempt to determine the file format. \param[in] in The stream containing the image data */ Image(std::istream & in) :im(0) { CreateFrom(in); } /** Construct an image by reading from \p in. This constructor will first attempt to determine the file format. \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in) :im(0) { CreateFrom(in); } /** Construct an image by reading from memory block \p data. This constructor will first attempt to determine the image formatting. \param[in] size The byte count of the memory block \param[in] data Pointer to the memory block */ Image(int size, void * data) :im(0) { CreateFrom(size, data); } #ifdef HAVE_LIBPNG /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Png_tag()); // read a png file from input \param[in] in The stream containing the image data */ Image(std::istream & in, Png_tag) :im(0) { CreateFromPng(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Png_tag()); // read a png file from input \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in, Png_tag) :im(0) { CreateFromPng(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Png_tag()); // read a png file from input \param[in] in The io context from which to read the image data */ Image(gdIOCtx * in, Png_tag) :im(0) { CreateFromPng(in); } /** Construct an image by reading from memory block \p data. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(sz, dat, GD::Png_tag()); // read a png file from dat \param[in] size The byte count of the memory block \param[in] data Pointer to the memory block */ Image(int size, void * data, Png_tag) :im(0) { CreateFromPng(size, data); } #endif /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gif_tag()); // read a gif file from input \param[in] in The stream containing the image data */ Image(std::istream & in, Gif_tag) :im(0) { CreateFromGif(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gif_tag()); // read a gif file from input \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in, Gif_tag) :im(0) { CreateFromGif(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gif_tag()); // read a gif file from input \param[in] in The io context from which to read the image data */ Image(gdIOCtx * in, Gif_tag) :im(0) { CreateFromGif(in); } /** Construct an image by reading from memory block \p data. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(sz, dat, GD::Gif_tag()); // read a gif file from dat \param[in] size The byte count of the memory block \param[in] data Pointer to the memory block */ Image(int size, void * data, Gif_tag) :im(0) { CreateFromGif(size, data); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::WBMP_tag()); // read a monchrome WBMP file from input \param[in] in The stream containing the image data */ Image(std::istream & in, WBMP_tag) :im(0) { CreateFromWBMP(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::WBMP_tag()); // read a monchrome WBMP file from input \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in, WBMP_tag) :im(0) { CreateFromWBMP(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::WBMP_tag()); // read a monchrome WBMP file from input \param[in] in The io context from which to read the image data */ Image(gdIOCtx * in, WBMP_tag) :im(0) { CreateFromWBMP(in); } /** Construct an image by reading from memory block \p data. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(sz, dat, GD::WBMP_tag()); // read a monchrome WBMP file from dat \param[in] size The byte count of the memory block \param[in] data Pointer to the memory block */ Image(int size, void * data, WBMP_tag) :im(0) { CreateFromWBMP(size, data); } #ifdef HAVE_LIBJPEG /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Jpeg_tag()); // read a jpeg file from input \param[in] in The stream containing the image data */ Image(std::istream & in, Jpeg_tag) :im(0) { CreateFromJpeg(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Jpeg_tag()); // read a jpeg file from input \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in, Jpeg_tag) :im(0) { CreateFromJpeg(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Jpeg_tag()); // read a jpeg file from input \param[in] in The io context from which to read the image data */ Image(gdIOCtx * in, Jpeg_tag) :im(0) { CreateFromJpeg(in); } /** Construct an image by reading from memory block \p data. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(sz, dat, GD::Jpeg_tag()); // read a jpeg file from dat \param[in] size The byte count of the memory block \param[in] data Pointer to the memory block */ Image(int size, void * data, Jpeg_tag) :im(0) { CreateFromJpeg(size, data); } #endif /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gd_tag()); // read a gd file from input \param[in] in The stream containing the image data */ Image(std::istream & in, Gd_tag) :im(0) { CreateFromGd(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gd_tag()); // read a gd file from input \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in, Gd_tag) :im(0) { CreateFromGd(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gd_tag()); // read a gd file from input \param[in] in The io context from which to read the image data */ Image(gdIOCtx * in, Gd_tag) :im(0) { CreateFromGd(in); } /** Construct an image by reading from memory block \p data. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(sz, dat, GD::Gd_tag()); // read a gd file from dat \param[in] size The byte count of the memory block \param[in] data Pointer to the memory block */ Image(int size, void * data, Gd_tag) :im(0) { CreateFromGd(size, data); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gd2_tag()); // read a gd2 file from input \param[in] in The stream containing the image data */ Image(std::istream & in, Gd2_tag) :im(0) { CreateFromGd2(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Png_tag()); // read a png file from input \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in, Gd2_tag) :im(0) { CreateFromGd2(in); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Gd2_tag()); // read a gd2 file from input \param[in] in The io context from which to read the image data */ Image(gdIOCtx * in, Gd2_tag) :im(0) { CreateFromGd2(in); } /** Construct an image by reading from memory block \p data. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(sz, dat, GD::Gd2_tag()); // read a gd2 file from dat \param[in] size The byte count of the memory block \param[in] data Pointer to the memory block */ Image(int size, void * data, Gd2_tag) :im(0) { CreateFromGd2(size, data); } /** Construct an image by reading from \p in. The tag is an empty struct which simply tells the compiler which image read function to use. e.g. GD::Image img(input, GD::Xbm_tag()); // read an xbm file from input \param[in] in An opened FILE * handle to a file containing the image data */ Image(FILE * in, Xbm_tag) :im(0) { CreateFromXbm(in); } ~Image() { clear(); } /** Assignment Operator. Make this a copy of the GD::Image provided. \param[in] src Reference to the image to be copied */ GD::Image & operator=(const GD::Image & src) { Copy(src); return (* this); } /** Make this an exact copy of the GD::Image provided. Any existing iamge data is discarded. \param[in] src Reference to the image to be copied */ void Copy(const GD::Image & src) { int w = src.Width(), h = src.Height(); if (src.IsTrueColor()) CreateTrueColor(w, h); else { Create(w, h); PaletteCopy(src); } Copy(src, 0, 0, 0, 0, w, h); } /** Check to see if this appears to be a valid image */ bool good() const { return (im != 0); } // Creation: /** Create a palette-based image, with no more than 256 colors. \param sx Width of the desired image \param sy Height of the desired image \return true if it worked, else false */ bool Create(int sx, int sy) { clear(); return ((im = gdImageCreate(sx, sy)) != 0); } /** Create a truecolor image. \param sx Width of the desired image \param sy Height of the desired image \return true if it worked, else false */ bool CreateTrueColor(int sx, int sy) { clear(); return ((im = gdImageCreateTrueColor(sx, sy)) != 0); } /** Create a palette-based image, with no more than 256 colors. \param s Width and height of the desired image \return true if it worked, else false */ bool Create(const Size & s) { return Create(s.W(), s.H()); } /** Create a truecolor image. \param s Width and height of the desired image \return true if it worked, else false */ bool CreateTrueColor(const Size & s) { return CreateTrueColor(s.W(), s.H()); } // Create, determining the image format from the data /// Read an image from an open FILE * handle, after determining the image format bool CreateFrom(FILE * in); /// Read an image from an open standard library input stream, after determining the image format bool CreateFrom(std::istream & in); /// Read an image from a memory block, after determining the image format bool CreateFrom(int size, void * data); #ifdef HAVE_LIBPNG // Png bool CreateFromPng(FILE * in) { clear(); return ((im = gdImageCreateFromPng(in)) != 0); } bool CreateFromPng(gdIOCtx * in) { clear(); return ((im = gdImageCreateFromPngCtx(in)) != 0); } bool CreateFromPng(int size, void * data) { clear(); return ((im = gdImageCreateFromPngPtr(size, data)) != 0); } bool CreateFromPng(std::istream & in) { clear(); istreamIOCtx _in_ctx(in); return ((im = gdImageCreateFromPngCtx( & _in_ctx)) != 0); } #endif // Gif bool CreateFromGif(FILE * in) { clear(); return ((im = gdImageCreateFromGif(in)) != 0); } bool CreateFromGif(gdIOCtx * in) { clear(); return ((im = gdImageCreateFromGifCtx(in)) != 0); } bool CreateFromGif(int size, void * data) { clear(); return ((im = gdImageCreateFromGifPtr(size, data)) != 0); } bool CreateFromGif(std::istream & in) { clear(); istreamIOCtx _in_ctx(in); return ((im = gdImageCreateFromGifCtx( & _in_ctx)) != 0); } // WBMP bool CreateFromWBMP(FILE * in) { clear(); return ((im = gdImageCreateFromWBMP(in)) != 0); } bool CreateFromWBMP(gdIOCtx * in) { clear(); return ((im = gdImageCreateFromWBMPCtx(in)) != 0); } bool CreateFromWBMP(int size, void * data) { clear(); return ((im = gdImageCreateFromWBMPPtr(size, data)) != 0); } bool CreateFromWBMP(std::istream & in) { clear(); istreamIOCtx _in_ctx(in); return ((im = gdImageCreateFromWBMPCtx( & _in_ctx)) != 0); } #ifdef HAVE_LIBJPEG // Jpeg /** Load a truecolor image from a JPEG format file. Invoke CreateFromJpeg with an already opened pointer to a file containing the desired image. CreateFromJpeg does not close the file. \return true for success, or false if unable to load the image (most often because the file is corrupt or does not contain a JPEG image). You can call Width() and Height() member functions of the image to determine its size. The returned image is always a truecolor image. */ bool CreateFromJpeg(FILE * in) { clear(); return ((im = gdImageCreateFromJpeg(in)) != 0); } /** Load a truecolor image from a JPEG format file. Invoke CreateFromJpeg with an already opened pointer to a file containing the desired image. CreateFromJpeg does not close the file. \return true for success, or false if unable to load the image (most often because the file is corrupt or does not contain a JPEG image). You can call Width() and Height() member functions of the image to determine its size. The returned image is always a truecolor image. */ bool CreateFromJpeg(gdIOCtx * in) { clear(); return ((im = gdImageCreateFromJpegCtx(in)) != 0); } /** Load a truecolor image from a JPEG format file. Invoke CreateFromJpeg with an already opened pointer to a file containing the desired image. CreateFromJpeg does not close the file. \return true for success, or false if unable to load the image (most often because the file is corrupt or does not contain a JPEG image). You can call Width() and Height() member functions of the image to determine its size. The returned image is always a truecolor image. */ bool CreateFromJpeg(int size, void * data) { clear(); return ((im = gdImageCreateFromJpegPtr(size, data)) != 0); } /** Load a truecolor image from a JPEG format file. Invoke CreateFromJpeg with an image file in memory. \return true for success, or false if unable to load the image (most often because the format is corrupt or does not contain a JPEG image). You can call Width() and Height() member functions of the image to determine its size. The returned image is always a truecolor image. */ bool CreateFromJpeg(std::istream & in) { clear(); istreamIOCtx _in_ctx(in); return ((im = gdImageCreateFromJpegCtx( & _in_ctx)) != 0); } #endif // Gd bool CreateFromGd(FILE * in) { clear(); return ((im = gdImageCreateFromGd(in)) != 0); } bool CreateFromGd(gdIOCtx * in) { clear(); return ((im = gdImageCreateFromGdCtx(in)) != 0); } bool CreateFromGd(int size, void * data) { clear(); return ((im = gdImageCreateFromGdPtr(size, data)) != 0); } bool CreateFromGd(std::istream & in) { clear(); istreamIOCtx _in_ctx(in); return ((im = gdImageCreateFromGdCtx( & _in_ctx)) != 0); } // Gd2 bool CreateFromGd2(FILE * in) { clear(); return ((im = gdImageCreateFromGd2(in)) != 0); } bool CreateFromGd2(gdIOCtx * in) { clear(); return ((im = gdImageCreateFromGd2Ctx(in)) != 0); } bool CreateFromGd2(int size, void * data) { clear(); return ((im = gdImageCreateFromGd2Ptr(size, data)) != 0); } bool CreateFromGd2(std::istream & in) { clear(); istreamIOCtx _in_ctx(in); return ((im = gdImageCreateFromGd2Ctx( & _in_ctx)) != 0); } // Gd2 Part bool CreateFromGd2Part(FILE * in, int srcx, int srcy, int w, int h) { clear(); return ((im = gdImageCreateFromGd2Part(in, srcx, srcy, w, h)) != 0); } bool CreateFromGd2Part(gdIOCtx * in, int srcx, int srcy, int w, int h) { clear(); return ((im = gdImageCreateFromGd2PartCtx(in, srcx, srcy, w, h)) != 0); } bool CreateFromGd2Part(int size, void * data, int srcx, int srcy, int w, int h) { clear(); return ((im = gdImageCreateFromGd2PartPtr(size, data, srcx, srcy, w, h)) != 0); } bool CreateFromGd2Part(std::istream & in, int srcx, int srcy, int w, int h) { clear(); istreamIOCtx _in_ctx(in); return ((im = gdImageCreateFromGd2PartCtx( & _in_ctx, srcx, srcy, w, h)) != 0); } bool CreateFromGd2Part(FILE * in, const Point & src, const Size & s) { return CreateFromGd2Part(in, src.X(), src.Y(), s.W(), s.H()); } bool CreateFromGd2Part(gdIOCtx * in, const Point & src, const Size & s) { return CreateFromGd2Part(in, src.X(), src.Y(), s.W(), s.H()); } bool CreateFromGd2Part(int size, void * data, const Point & src, const Size & s) { return CreateFromGd2Part(size, data, src.X(), src.Y(), s.W(), s.H()); } bool CreateFromGd2Part(std::istream & in, const Point & src, const Size & s) { return CreateFromGd2Part(in, src.X(), src.Y(), s.W(), s.H()); } // Xbm bool CreateFromXbm(FILE * in) { clear(); return ((im = gdImageCreateFromXbm(in)) != 0); } // Xpm bool CreateFromXpm(char * filename) { clear(); return ((im = gdImageCreateFromXpm(filename)) != 0); } bool CreateFromXpm(std::string & filename) { return CreateFromXpm((char *)(filename.c_str())); } // Accessors, Updaters & Methods: void SetPixel(int x, int y, int color) { gdImageSetPixel(im, x, y, color); } void SetPixel(const Point & p, int color) { SetPixel(p.X(), p.Y(), color); } int GetPixel(int x, int y) const { return gdImageGetPixel(im, x, y); } int GetPixel(const Point & p) const { return GetPixel(p.X(), p.Y()); } int GetTrueColorPixel(int x, int y) const { return gdImageGetTrueColorPixel(im, x, y); } int GetTrueColorPixel(const Point & p) const { return GetTrueColorPixel(p.X(), p.Y()); } void SetPixel(int x, int y, TrueColor c) { SetPixel(x, y, c.Int()); } void SetPixel(const Point & p, TrueColor c) { SetPixel(p.X(), p.Y(), c.Int()); } void GetTrueColorPixel(TrueColor & c, int x, int y) const { c.set(GetTrueColorPixel(x, y)); } void GetTrueColorPixel(TrueColor & c, const Point & p) const { c.set(GetTrueColorPixel(p.X(), p.Y())); } void AABlend() { gdImageAABlend(im); } void Line(int x1, int y1, int x2, int y2, int color) { gdImageLine(im, x1, y1, x2, y2, color); } void Line(const Point & p1, const Point & p2, int color) { Line(p1.X(), p1.Y(), p2.X(), p2.Y(), color); } void Rectangle(int x1, int y1, int x2, int y2, int color) { gdImageRectangle(im, x1, y1, x2, y2, color); } void Rectangle(const Point & p1, const Point & p2, int color) { Rectangle(p1.X(), p1.Y(), p2.X(), p2.Y(), color); } void Rectangle(const Point & p, const Size & s, int color) { Rectangle(p.X(), p.Y(), p.X() + s.W(), p.Y() + s.H(), color); } void FilledRectangle(int x1, int y1, int x2, int y2, int color) { gdImageFilledRectangle(im, x1, y1, x2, y2, color); } void FilledRectangle(const Point & p1, const Point & p2, int color) { FilledRectangle(p1.X(), p1.Y(), p2.X(), p2.Y(), color); } void FilledRectangle(const Point & p, const Size & s, int color) { FilledRectangle(p.X(), p.Y(), p.X() + s.W(), p.Y() + s.H(), color); } void SetClip(int x1, int y1, int x2, int y2) { gdImageSetClip(im, x1, y1, x2, y2); } void SetClip(const Point & p1, const Point & p2) { SetClip(p1.X(), p1.Y(), p2.X(), p2.Y()); } void SetClip(const Point & p, const Size & s) { SetClip(p.X(), p.Y(), p.X() + s.W(), p.Y() + s.H()); } void GetClip(int & x1, int & y1, int & x2, int & y2) const { gdImageGetClip(im, & x1, & y1, & x2, & y2); } void GetClip(Point & p1, Point & p2) const { GetClip(p1.lhsX(), p1.lhsY(), p2.lhsX(), p2.lhsY()); } void GetClip(Point & p, Size & s) const { Point p2; GetClip(p.lhsX(), p.lhsY(), p2.lhsX(), p2.lhsY()); s.set(p2.X() - p.X(), p2.Y() - p.Y()); } bool BoundsSafe(int x, int y) const { return (gdImageBoundsSafe(im, x, y)?true:false); } bool BoundsSafe(const Point & p) const { return BoundsSafe(p.X(), p.Y()); } void Char(gdFontPtr f, int x, int y, int c, int color) { gdImageChar(im, f, x, y, c, color); } void CharUp(gdFontPtr f, int x, int y, int c, int color) { gdImageCharUp(im, f, x, y, c, color); } void Char(gdFontPtr f, const Point & p, int c, int color) { Char(f, p.X(), p.Y(), c, color); } void CharUp(gdFontPtr f, const Point & p, int c, int color) { CharUp(f, p.X(), p.Y(), c, color); } void String(gdFontPtr f, int x, int y, unsigned char * s, int color) { gdImageString(im, f, x, y, (unsigned char *)s, color); } void StringUp(gdFontPtr f, int x, int y, unsigned char * s, int color) { gdImageStringUp(im, f, x, y, (unsigned char *)s, color); } void String(gdFontPtr f, int x, int y, unsigned short * s, int color) { gdImageString16(im, f, x, y, (unsigned short *)s, color); } void StringUp(gdFontPtr f, int x, int y, unsigned short * s, int color) { gdImageStringUp16(im, f, x, y, (unsigned short *)s, color); } void String(gdFontPtr f, int x, int y, char * s, int color) { gdImageString(im, f, x, y, (unsigned char *)s, color); } void StringUp(gdFontPtr f, int x, int y, char * s, int color) { gdImageStringUp(im, f, x, y, (unsigned char *)s, color); } void String(gdFontPtr f, int x, int y, const std::string & s, int color) { String(f, x, y, (char *)s.c_str(), color); } void StringUp(gdFontPtr f, int x, int y, const std::string & s, int color) { StringUp(f, x, y, (char *)s.c_str(), color); } void String(gdFontPtr f, const Point & p, unsigned char * s, int color) { String(f, p.X(), p.Y(), (unsigned char *)s, color); } void StringUp(gdFontPtr f, const Point & p, unsigned char * s, int color) { StringUp(f, p.X(), p.Y(), (unsigned char *)s, color); } void String(gdFontPtr f, const Point & p, unsigned short * s, int color) { String(f, p.X(), p.Y(), (unsigned short *)s, color); } void StringUp(gdFontPtr f, const Point & p, unsigned short * s, int color) { StringUp(f, p.X(), p.Y(), (unsigned short *)s, color); } void String(gdFontPtr f, const Point & p, char * s, int color) { String(f, p.X(), p.Y(), (unsigned char *)s, color); } void StringUp(gdFontPtr f, const Point & p, char * s, int color) { StringUp(f, p.X(), p.Y(), (unsigned char *)s, color); } void String(gdFontPtr f, const Point & p, const std::string & s, int color) { String(f, p, (char *)s.c_str(), color); } void StringUp(gdFontPtr f, const Point & p, const std::string & s, int color) { StringUp(f, p, (char *)s.c_str(), color); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, int x, int y, char * string) { return gdImageStringFT(im, brect, fg, fontlist, ptsize, angle, x, y, string); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, int x, int y, char * string, gdFTStringExtraPtr strex) { return gdImageStringFTEx(im, brect, fg, fontlist, ptsize, angle, x, y, string, strex); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, int x, int y, const std::string & string) { return StringFT(brect, fg, fontlist, ptsize, angle, x, y, (char *)string.c_str()); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, int x, int y, const std::string & string, gdFTStringExtraPtr strex) { return StringFT(brect, fg, fontlist, ptsize, angle, x, y, (char *)string.c_str(), strex); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, const Point & p, char * string) { return StringFT(brect, fg, fontlist, ptsize, angle, p.X(), p.Y(), string); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, const Point & p, char * string, gdFTStringExtraPtr strex) { return StringFT(brect, fg, fontlist, ptsize, angle, p.X(), p.Y(), string, strex); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, const Point & p, const std::string & string) { return StringFT(brect, fg, fontlist, ptsize, angle, p, (char *)string.c_str()); } char * StringFT(int * brect, int fg, char * fontlist, double ptsize, double angle, const Point & p, const std::string & string, gdFTStringExtraPtr strex) { return StringFT(brect, fg, fontlist, ptsize, angle, p, (char *)string.c_str(), strex); } void Polygon(gdPointPtr p, int n, int c) { gdImagePolygon(im, p, n, c); } void OpenPolygon(gdPointPtr p, int n, int c) { gdImageOpenPolygon(im, p, n, c); } void FilledPolygon(gdPointPtr p, int n, int c) { gdImageFilledPolygon(im, p, n, c); } void Polygon(PointPtr p, int n, int c) { Polygon(p->as_gdPointPtr(), n, c); } void OpenPolygon(PointPtr p, int n, int c) { OpenPolygon(p->as_gdPointPtr(), n, c); } void FilledPolygon(PointPtr p, int n, int c) { FilledPolygon(p->as_gdPointPtr(), n, c); } int ColorAllocate(int r, int g, int b) { return gdImageColorAllocate(im, r, g, b); } int ColorAllocate(int r, int g, int b, int a) { return gdImageColorAllocateAlpha(im, r, g, b, a); } int ColorClosest(int r, int g, int b) const { return gdImageColorClosest(im, r, g, b); } int ColorClosest(int r, int g, int b, int a) const { return gdImageColorClosestAlpha(im, r, g, b, a); } int ColorClosestHWB(int r, int g, int b) const { return gdImageColorClosestHWB(im, r, g, b); } int ColorExact(int r, int g, int b) const { return gdImageColorExact(im, r, g, b); } int ColorExact(int r, int g, int b, int a) const { return gdImageColorExactAlpha(im, r, g, b, a); } int ColorResolve(int r, int g, int b) { return gdImageColorResolve(im, r, g, b); } int ColorResolve(int r, int g, int b, int a) { return gdImageColorResolveAlpha(im, r, g, b, a); } void ColorDeallocate(int color) { gdImageColorDeallocate(im, color); } void TrueColorToPalette(int ditherFlag, int colorsWanted) { gdImageTrueColorToPalette(im, ditherFlag, colorsWanted); } void ColorTransparent(int color) { gdImageColorTransparent(im, color); } void PaletteCopy(gdImagePtr src) { gdImagePaletteCopy(im, src); } void PaletteCopy(const GD::Image & src) { PaletteCopy(src.im); } /** Write out this image in GIF file format to \p out. \param out A FILE * handle */ void Gif(FILE * out) const { gdImageGif(im, out); } /** Write out this image in GIF file format to \p out. \param out A gdIOCtx * handle */ void Gif(gdIOCtx * out) const { gdImageGifCtx(im, out); } /** Allocate sufficient memory, and write this image, in GIF file format, to that memory. \param size A pointer for the allocated memory \return A pointer to the allocated memory, containing the image GIF file formatted. Caller is responsible for freeing with gdFree(). */ void * Gif(int * size) const { return gdImageGifPtr(im, size); } /** Write out this image in GIF file format to \p out. \param out An output stream, already opened. */ void Gif(std::ostream & out) const { ostreamIOCtx _out_ctx(out); gdImageGifCtx(im, & _out_ctx); } #ifdef HAVE_LIBPNG /** Write out this image in PNG file format to \p out. \param out A FILE * handle */ void Png(FILE * out) const { gdImagePng(im, out); } /** Write out this image in PNG file format to \p out. \param out A gdIOCtx * handle */ void Png(gdIOCtx * out) const { gdImagePngCtx(im, out); } /** Allocate sufficient memory, and write this image, in PNG file format, to that memory. \param size A pointer for the allocated memory \return A pointer to the allocated memory, containing the image PNG file formatted. Caller is responsible for freeing with gdFree(). */ void * Png(int * size) const { return gdImagePngPtr(im, size); } /** Write out this image in PNG file format to \p out. \param out An output stream, already opened. */ void Png(std::ostream & out) const { ostreamIOCtx _out_ctx(out); gdImagePngCtx(im, & _out_ctx); } /** Write out this image in PNG file format to \p out. \param out A FILE * handle \param level The level of compression: 0 == "no compression", 1 == "compressed as quickly as possible" --> 9 == "compressed as much as possible", -1 == zlib default compression level */ void Png(FILE * out, int level) const { gdImagePngEx(im, out, level); } /** Write out this image in PNG file format to \p out. \param out A gdIOCtx * handle \param level The level of compression: 0 == "no compression", 1 == "compressed as quickly as possible" --> 9 == "compressed as much as possible", -1 == zlib default compression level */ void Png(gdIOCtx * out, int level) const { gdImagePngCtxEx(im, out, level); } /** Allocate sufficient memory, and write this image, in PNG file format, to that memory. \param size A pointer for the allocated memory \param level The level of compression: 0 == "no compression", 1 == "compressed as quickly as possible" --> 9 == "compressed as much as possible", -1 == zlib default compression level \return A pointer to the allocated memory, containing the image PNG file formatted. Caller is responsible for freeing with gdFree(). */ void * Png(int * size, int level) const { return gdImagePngPtrEx(im, size, level); } /** Write out this image in PNG file format to \p out. \param out An output stream, already opened. \param level The level of compression: 0 == "no compression", 1 == "compressed as quickly as possible" --> 9 == "compressed as much as possible", -1 == zlib default compression level */ void Png(std::ostream & out, int level) const { ostreamIOCtx _out_ctx(out); gdImagePngCtxEx(im, & _out_ctx, level); } #endif /** Write out this image in WBMP file format ( black and white only ) to \p out. \param fg The color index of the foreground. All other pixels considered background. \param out A FILE * handle */ void WBMP(int fg, FILE * out) const { gdImageWBMP(im, fg, out); } /** Write out this image in WBMP file format ( black and white only ) to \p out. \param fg The color index of the foreground. All other pixels considered background. \param out A gdIOCtx * handle */ void WBMP(int fg, gdIOCtx * out) const { gdImageWBMPCtx(im, fg, out); } /** Allocate sufficient memory, and write this image, in WBMP file format ( black and white only ), to that memory. \param size A pointer for the allocated memory \param fg The color index of the foreground. All other pixels considered background. \return A pointer to the allocated memory, containing the image WBMP file formatted. Caller is responsible for freeing with gdFree(). */ void * WBMP(int * size, int fg) const { return gdImageWBMPPtr(im, size, fg); } /** Write out this image in WBMP file format ( black and white only ) to \p out. \param fg The color index of the foreground. All other pixels considered background. \param out An output stream, already opened. */ void WBMP(int fg, std::ostream & out) const { ostreamIOCtx _out_ctx(out); gdImageWBMPCtx(im, fg, & _out_ctx); } #ifdef HAVE_LIBJPEG /** Write out this image in JPEG file format to \p out. \param out A FILE * handle \param quality Should be a value in the range 0-95, higher numbers imply both higher quality and larger image size. Default value is -1, indicating "use a sensible default value". */ void Jpeg(FILE * out, int quality = -1) const { gdImageJpeg(im, out, quality); } /** Write out this image in JPEG file format to \p out. \param out A gdIOCtx * handle \param quality Should be a value in the range 0-95, higher numbers imply both higher quality and larger image size. Default value is -1, indicating "use a sensible default value". */ void Jpeg(gdIOCtx * out, int quality = -1) const { gdImageJpegCtx(im, out, quality); } /** Allocate sufficient memory, and write this image, in JPEG file format, to that memory. \param size A pointer for the allocated memory \param quality Should be a value in the range 0-95, higher numbers imply both higher quality and larger image size. Default value is -1, indicating "use a sensible default value". \return A pointer to the allocated memory, containing the image JPEG file formatted. Caller is responsible for freeing with gdFree(). */ void * Jpeg(int * size, int quality = -1) const { return gdImageJpegPtr(im, size, quality); } /** Write out this image in JPEG file format to \p out. \param out An output stream, already opened. \param quality Should be a value in the range 0-95, higher numbers imply both higher quality and larger image size. Default value is -1, indicating "use a sensible default value". */ void Jpeg(std::ostream & out, int quality = -1) const { ostreamIOCtx _out_ctx(out); gdImageJpegCtx(im, & _out_ctx, quality); } #endif void GifAnimBegin(FILE * out, int GlobalCM, int Loops) const { gdImageGifAnimBegin(im, out, GlobalCM, Loops); } void GifAnimAdd(FILE * out, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm) const { gdImageGifAnimAdd(im, out, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm); } void GifAnimAdd(FILE * out, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, const GD::Image & previm) const { GifAnimAdd(out, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm.im); } inline static void GifAnimEnd(FILE * out) { gdImageGifAnimEnd(out); } void GifAnimBegin(gdIOCtx * out, int GlobalCM, int Loops) const { gdImageGifAnimBeginCtx(im, out, GlobalCM, Loops); } void GifAnimAdd(gdIOCtx * out, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm) const { gdImageGifAnimAddCtx(im, out, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm); } void GifAnimAdd(gdIOCtx * out, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, const GD::Image & previm) const { GifAnimAdd(out, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm.im); } inline static void GifAnimEnd(gdIOCtx * out) { gdImageGifAnimEndCtx(out); } void * GifAnimBegin(int * size, int GlobalCM, int Loops) const { return gdImageGifAnimBeginPtr(im, size, GlobalCM, Loops); } void * GifAnimAdd(int * size, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, gdImagePtr previm) const { return gdImageGifAnimAddPtr(im, size, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm); } void * GifAnimAdd(int * size, int LocalCM, int LeftOfs, int TopOfs, int Delay, int Disposal, const GD::Image & previm) const { return GifAnimAdd(size, LocalCM, LeftOfs, TopOfs, Delay, Disposal, previm.im); } inline static void * GifAnimEnd(int * size) { return gdImageGifAnimEndPtr(size); } void Gd(FILE * out) const { gdImageGd(im, out); } void* Gd(int * size) const { return gdImageGdPtr(im, size); } void Gd2(FILE * out, int cs, int fmt) const { gdImageGd2(im, out, cs, fmt); } void* Gd2(int cs, int fmt, int * size) const { return gdImageGd2Ptr(im, cs, fmt, size); } void Ellipse(int cx, int cy, int w, int h, int color) { gdImageEllipse(im, cx, cy, w, h, color); } /** Draw a partial ellipse centered at the given point, with the specified width and height in pixels. */ void FilledArc(int cx, int cy, int w, int h, int s, int e, int color, int style) { gdImageFilledArc(im, cx, cy, w, h, s, e, color, style); } void Arc(int cx, int cy, int w, int h, int s, int e, int color) { gdImageArc(im, cx, cy, w, h, s, e, color); } void FilledEllipse(int cx, int cy, int w, int h, int color) { gdImageFilledEllipse(im, cx, cy, w, h, color); } void FillToBorder(int x, int y, int border, int color) { gdImageFillToBorder(im, x, y, border, color); } void Fill(int x, int y, int color) { gdImageFill(im, x, y, color); } void Ellipse(const Point & c, const Size & s, int color) { Ellipse(c.X(), c.Y(), s.W(), s.H(), color); } void FilledArc(const Point & c, const Size & si, int s, int e, int color, int style) { FilledArc(c.X(), c.Y(), si.W(), si.H(), s, e, color, style); } void Arc(const Point & c, const Size & si, int s, int e, int color) { Arc(c.X(), c.Y(), si.W(), si.H(), s, e, color); } void FilledEllipse(const Point & c, const Size & s, int color) { FilledEllipse(c.X(), c.Y(), s.W(), s.H(), color); } void FillToBorder(const Point & p, int border, int color) { FillToBorder(p.X(), p.Y(), border, color); } void Fill(const Point & p, int color) { Fill(p.X(), p.Y(), color); } void Copy(const gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h) { gdImageCopy(im, src, dstX, dstY, srcX, srcY, w, h); } void CopyMerge(const gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct) { gdImageCopyMerge(im, src, dstX, dstY, srcX, srcY, w, h, pct); } void CopyMergeGray(const gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct) { gdImageCopyMergeGray(im, src, dstX, dstY, srcX, srcY, w, h, pct); } void CopyResized(const gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH) { gdImageCopyResized(im, src, dstX, dstY, srcX, srcY, dstW, dstH, srcW, srcH); } void CopyResampled(const gdImagePtr src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH) { gdImageCopyResampled(im, src, dstX, dstY, srcX, srcY, dstW, dstH, srcW, srcH); } void CopyRotated(const gdImagePtr src, double dstX, double dstY, int srcX, int srcY, int srcWidth, int srcHeight, int angle) { gdImageCopyRotated(im, src, dstX, dstY, srcX, srcY, srcWidth, srcHeight, angle); } Image * CopyGaussianBlurred(int radius, double sigma) { return new Image(gdImageCopyGaussianBlurred(im, radius, sigma)); } void Copy(const gdImagePtr src, const Point & dstP, const Point & srcP, const Size & s) { Copy(src, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), s.W(), s.H()); } void CopyMerge(const gdImagePtr src, const Point & dstP, const Point & srcP, const Size & s, int pct) { CopyMerge(src, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), s.W(), s.H(), pct); } void CopyMergeGray(const gdImagePtr src, const Point & dstP, const Point & srcP, const Size & s, int pct) { CopyMergeGray(src, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), s.W(), s.H(), pct); } void CopyResized(const gdImagePtr src, const Point & dstP, const Point & srcP, const Size & dstS, const Size & srcS) { CopyResized(src, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), dstS.W(), dstS.H(), srcS.W(), srcS.H()); } void CopyResampled(const gdImagePtr src, const Point & dstP, const Point & srcP, const Size & dstS, const Size & srcS) { CopyResampled(src, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), dstS.W(), dstS.H(), srcS.W(), srcS.H()); } void CopyRotated(const gdImagePtr src, double dstX, double dstY, const Point & srcP, const Size & srcS, int angle) { CopyRotated(src, dstX, dstY, srcP.X(), srcP.Y(), srcS.W(), srcS.H(), angle); } void Copy(const GD::Image & src, int dstX, int dstY, int srcX, int srcY, int w, int h) { Copy(src.im, dstX, dstY, srcX, srcY, w, h); } void CopyMerge(const GD::Image & src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct) { CopyMerge(src.im, dstX, dstY, srcX, srcY, w, h, pct); } void CopyMergeGray(const GD::Image & src, int dstX, int dstY, int srcX, int srcY, int w, int h, int pct) { CopyMergeGray(src.im, dstX, dstY, srcX, srcY, w, h, pct); } void CopyResized(const GD::Image & src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH) { CopyResized(src.im, dstX, dstY, srcX, srcY, dstW, dstH, srcW, srcH); } void CopyResampled(const GD::Image & src, int dstX, int dstY, int srcX, int srcY, int dstW, int dstH, int srcW, int srcH) { CopyResampled(src.im, dstX, dstY, srcX, srcY, dstW, dstH, srcW, srcH); } void CopyRotated(const GD::Image & src, double dstX, double dstY, int srcX, int srcY, int srcWidth, int srcHeight, int angle) { CopyRotated(src.im, dstX, dstY, srcX, srcY, srcWidth, srcHeight, angle); } void Copy(const GD::Image & src, const Point & dstP, const Point & srcP, const Size & s) { Copy(src.im, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), s.W(), s.H()); } void CopyMerge(const GD::Image & src, const Point & dstP, const Point & srcP, const Size & s, int pct) { CopyMerge(src.im, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), s.W(), s.H(), pct); } void CopyMergeGray(const GD::Image & src, const Point & dstP, const Point & srcP, const Size & s, int pct) { CopyMergeGray(src.im, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), s.W(), s.H(), pct); } void CopyResized(const GD::Image & src, const Point & dstP, const Point & srcP, const Size & dstS, const Size & srcS) { CopyResized(src.im, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), dstS.W(), dstS.H(), srcS.W(), srcS.H()); } void CopyResampled(const GD::Image & src, const Point & dstP, const Point & srcP, const Size & dstS, const Size & srcS) { CopyResampled(src.im, dstP.X(), dstP.Y(), srcP.X(), srcP.Y(), dstS.W(), dstS.H(), srcS.W(), srcS.H()); } void CopyRotated(const GD::Image & src, double dstX, double dstY, const Point & srcP, const Size & srcS, int angle) { CopyRotated(src.im, dstX, dstY, srcP.X(), srcP.Y(), srcS.W(), srcS.H(), angle); } Image * Clone() { return new Image(gdImageClone(im)); } void SetBrush(gdImagePtr brush) { gdImageSetBrush(im, brush); } void SetBrush(const GD::Image & brush) { SetBrush(brush.im); } void SetTile(gdImagePtr tile) { gdImageSetTile(im, tile); } void SetTile(const GD::Image & tile) { SetTile(tile.im); } void SetAntiAliased(int c) { gdImageSetAntiAliased(im, c); } void SetAntiAliasedDontBlend(int c, int dont_blend) { gdImageSetAntiAliasedDontBlend(im, c, dont_blend); } void SetStyle(int * style, int noOfPixels) { gdImageSetStyle(im, style, noOfPixels); } void SetThickness(int thickness) { gdImageSetThickness(im, thickness); } void SetResolution(int res_x, int res_y) { gdImageSetResolution(im, res_x, res_y); } void SetInterpolationMethod(gdInterpolationMethod interpolation_method) { gdImageSetInterpolationMethod(im, interpolation_method); } Image * RotateInterpolated(const float angle, int bgcolor) { return new Image(gdImageRotateInterpolated(im, angle, bgcolor)); } void Interlace(bool interlaceArg) { gdImageInterlace(im, interlaceArg?1:0); } void AlphaBlending(bool alphaBlendingArg) { gdImageAlphaBlending(im, alphaBlendingArg?1:0); } void SaveAlpha(bool saveAlphaArg) { gdImageSaveAlpha(im, saveAlphaArg?1:0); } int ColorReplace(int src, int dst) { return gdImageColorReplace(im, src, dst); } int ColorReplaceArray(int len, int * src, int * dst) { return gdImageColorReplaceArray(im, len, src, dst); } int ColorReplaceCallback(gdCallbackImageColor callback) { return gdImageColorReplaceCallback(im, callback); } int ColorReplaceThreshold(int src, int dst, float threshold) { return gdImageColorReplaceThreshold(im, src, dst, threshold); } bool Pixelate(int block_size, gdPixelateMode mode) { return gdImagePixelate(im, block_size, mode) == 0 ? false : true; } Image * Scale(int new_width, int new_height) { return new Image(gdImageScale(im, new_width, new_height)); } bool IsTrueColor() const { return (gdImageTrueColor(im)?true:false); } int SX() const { return gdImageSX(im); } int SY() const { return gdImageSY(im); } int Width() const { return SX(); } int Height() const { return SY(); } int ResX() const { return gdImageResolutionX(im); } int ResY() const { return gdImageResolutionY(im); } void GetSize(Size & s) const { s.set(SX(), SY()); } int ColorsTotal() const { return gdImageColorsTotal(im); } int Red(int color) const { return gdImageRed(im, color); } int Green(int color) const { return gdImageGreen(im, color); } int Blue(int color) const { return gdImageBlue(im, color); } int Alpha(int color) const { return gdImageAlpha(im, color); } int GetTransparent() const { return gdImageGetTransparent(im); } int GetInterlaced() const { return gdImageGetInterlaced(im); } int PalettePixel(int x, int y) const { return gdImagePalettePixel(im, x, y); } int TrueColorPixel(int x, int y) const { return gdImageTrueColorPixel(im, x, y); } const gdImagePtr GetPtr() const { return im; } protected: /// Free the internal image pointer void clear() { if (im) gdImageDestroy(im); im = 0; } gdImagePtr im; }; } // namespace GD /// Read in an image from a standard library input stream std::istream & operator>> (std::istream & in, GD::Image & img); #endif /* _gdpp_h */ #endif /* __cplusplus */ libgd-gd-2.1.1/src/gdtables.c000066400000000000000000000112561245535672000157220ustar00rootroot00000000000000 const int gdCosT[] = { 1024, 1023, 1023, 1022, 1021, 1020, 1018, 1016, 1014, 1011, 1008, 1005, 1001, 997, 993, 989, 984, 979, 973, 968, 962, 955, 949, 942, 935, 928, 920, 912, 904, 895, 886, 877, 868, 858, 848, 838, 828, 817, 806, 795, 784, 772, 760, 748, 736, 724, 711, 698, 685, 671, 658, 644, 630, 616, 601, 587, 572, 557, 542, 527, 512, 496, 480, 464, 448, 432, 416, 400, 383, 366, 350, 333, 316, 299, 282, 265, 247, 230, 212, 195, 177, 160, 142, 124, 107, 89, 71, 53, 35, 17, 0, -17, -35, -53, -71, -89, -107, -124, -142, -160, -177, -195, -212, -230, -247, -265, -282, -299, -316, -333, -350, -366, -383, -400, -416, -432, -448, -464, -480, -496, -512, -527, -542, -557, -572, -587, -601, -616, -630, -644, -658, -671, -685, -698, -711, -724, -736, -748, -760, -772, -784, -795, -806, -817, -828, -838, -848, -858, -868, -877, -886, -895, -904, -912, -920, -928, -935, -942, -949, -955, -962, -968, -973, -979, -984, -989, -993, -997, -1001, -1005, -1008, -1011, -1014, -1016, -1018, -1020, -1021, -1022, -1023, -1023, -1024, -1023, -1023, -1022, -1021, -1020, -1018, -1016, -1014, -1011, -1008, -1005, -1001, -997, -993, -989, -984, -979, -973, -968, -962, -955, -949, -942, -935, -928, -920, -912, -904, -895, -886, -877, -868, -858, -848, -838, -828, -817, -806, -795, -784, -772, -760, -748, -736, -724, -711, -698, -685, -671, -658, -644, -630, -616, -601, -587, -572, -557, -542, -527, -512, -496, -480, -464, -448, -432, -416, -400, -383, -366, -350, -333, -316, -299, -282, -265, -247, -230, -212, -195, -177, -160, -142, -124, -107, -89, -71, -53, -35, -17, 0, 17, 35, 53, 71, 89, 107, 124, 142, 160, 177, 195, 212, 230, 247, 265, 282, 299, 316, 333, 350, 366, 383, 400, 416, 432, 448, 464, 480, 496, 512, 527, 542, 557, 572, 587, 601, 616, 630, 644, 658, 671, 685, 698, 711, 724, 736, 748, 760, 772, 784, 795, 806, 817, 828, 838, 848, 858, 868, 877, 886, 895, 904, 912, 920, 928, 935, 942, 949, 955, 962, 968, 973, 979, 984, 989, 993, 997, 1001, 1005, 1008, 1011, 1014, 1016, 1018, 1020, 1021, 1022, 1023, 1023 }; const int gdSinT[] = { 0, 17, 35, 53, 71, 89, 107, 124, 142, 160, 177, 195, 212, 230, 247, 265, 282, 299, 316, 333, 350, 366, 383, 400, 416, 432, 448, 464, 480, 496, 512, 527, 542, 557, 572, 587, 601, 616, 630, 644, 658, 671, 685, 698, 711, 724, 736, 748, 760, 772, 784, 795, 806, 817, 828, 838, 848, 858, 868, 877, 886, 895, 904, 912, 920, 928, 935, 942, 949, 955, 962, 968, 973, 979, 984, 989, 993, 997, 1001, 1005, 1008, 1011, 1014, 1016, 1018, 1020, 1021, 1022, 1023, 1023, 1024, 1023, 1023, 1022, 1021, 1020, 1018, 1016, 1014, 1011, 1008, 1005, 1001, 997, 993, 989, 984, 979, 973, 968, 962, 955, 949, 942, 935, 928, 920, 912, 904, 895, 886, 877, 868, 858, 848, 838, 828, 817, 806, 795, 784, 772, 760, 748, 736, 724, 711, 698, 685, 671, 658, 644, 630, 616, 601, 587, 572, 557, 542, 527, 512, 496, 480, 464, 448, 432, 416, 400, 383, 366, 350, 333, 316, 299, 282, 265, 247, 230, 212, 195, 177, 160, 142, 124, 107, 89, 71, 53, 35, 17, 0, -17, -35, -53, -71, -89, -107, -124, -142, -160, -177, -195, -212, -230, -247, -265, -282, -299, -316, -333, -350, -366, -383, -400, -416, -432, -448, -464, -480, -496, -512, -527, -542, -557, -572, -587, -601, -616, -630, -644, -658, -671, -685, -698, -711, -724, -736, -748, -760, -772, -784, -795, -806, -817, -828, -838, -848, -858, -868, -877, -886, -895, -904, -912, -920, -928, -935, -942, -949, -955, -962, -968, -973, -979, -984, -989, -993, -997, -1001, -1005, -1008, -1011, -1014, -1016, -1018, -1020, -1021, -1022, -1023, -1023, -1024, -1023, -1023, -1022, -1021, -1020, -1018, -1016, -1014, -1011, -1008, -1005, -1001, -997, -993, -989, -984, -979, -973, -968, -962, -955, -949, -942, -935, -928, -920, -912, -904, -895, -886, -877, -868, -858, -848, -838, -828, -817, -806, -795, -784, -772, -760, -748, -736, -724, -711, -698, -685, -671, -658, -644, -630, -616, -601, -587, -572, -557, -542, -527, -512, -496, -480, -464, -448, -432, -416, -400, -383, -366, -350, -333, -316, -299, -282, -265, -247, -230, -212, -195, -177, -160, -142, -124, -107, -89, -71, -53, -35, -17 }; libgd-gd-2.1.1/src/gdtest.c000066400000000000000000000214331245535672000154250ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #ifdef _WIN32 #include int unlink (const char *filename) { return _unlink (filename); } #else #include /* for getpid(), unlink() */ #endif #include "gd.h" void CompareImages (char *msg, gdImagePtr im1, gdImagePtr im2); static int freadWrapper (void *context, char *buf, int len); static int fwriteWrapper (void *context, const char *buffer, int len); int main (int argc, char **argv) { #ifdef HAVE_LIBPNG gdImagePtr im, ref, im2, im3; FILE *in, *out; void *iptr; int sz; char of[256]; int colRed, colBlu; gdSource imgsrc; gdSink imgsnk; int foreground; int i; if (argc != 2) { fprintf(stderr, "Usage: gdtest filename.png\n"); exit (1); } in = fopen (argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit (1); } im = gdImageCreateFromPng (in); rewind (in); ref = gdImageCreateFromPng (in); fclose (in); printf ("Reference File has %d Palette entries\n", ref->colorsTotal); CompareImages ("Initial Versions", ref, im); /* */ /* Send to PNG File then Ptr */ /* */ #ifdef VMS sprintf (of, "%s-png", argv[1]); #else sprintf (of, "%s.png", argv[1]); #endif out = fopen (of, "wb"); gdImagePng (im, out); fclose (out); in = fopen (of, "rb"); if (!in) { fprintf(stderr, "PNG Output file does not exist!\n"); exit (1); } im2 = gdImageCreateFromPng (in); fclose (in); CompareImages ("GD->PNG File->GD", ref, im2); unlink (of); gdImageDestroy (im2); /* 2.0.21: use the new From*Ptr functions */ iptr = gdImagePngPtr (im, &sz); im2 = gdImageCreateFromPngPtr (sz, iptr); gdFree (iptr); CompareImages ("GD->PNG ptr->GD", ref, im2); gdImageDestroy (im2); /* */ /* Send to GD2 File then Ptr */ /* */ #ifdef VMS sprintf (of, "%s-gd2", argv[1]); #else sprintf (of, "%s.gd2", argv[1]); #endif out = fopen (of, "wb"); gdImageGd2 (im, out, 128, 2); fclose (out); in = fopen (of, "rb"); if (!in) { fprintf(stderr, "GD2 Output file does not exist!\n"); exit (1); } im2 = gdImageCreateFromGd2 (in); fclose (in); CompareImages ("GD->GD2 File->GD", ref, im2); unlink (of); gdImageDestroy (im2); iptr = gdImageGd2Ptr (im, 128, 2, &sz); /*printf("Got ptr %d (size %d)\n",iptr, sz); */ im2 = gdImageCreateFromGd2Ptr (sz, iptr); gdFree (iptr); /*printf("Got img2 %d\n",im2); */ CompareImages ("GD->GD2 ptr->GD", ref, im2); gdImageDestroy (im2); /* */ /* Send to GD File then Ptr */ /* */ #ifdef VMS sprintf (of, "%s-gd", argv[1]); #else sprintf (of, "%s.gd", argv[1]); #endif out = fopen (of, "wb"); gdImageGd (im, out); fclose (out); in = fopen (of, "rb"); if (!in) { fprintf(stderr, "GD Output file does not exist!\n"); exit (1); } im2 = gdImageCreateFromGd (in); fclose (in); CompareImages ("GD->GD File->GD", ref, im2); unlink (of); gdImageDestroy (im2); iptr = gdImageGdPtr (im, &sz); /*printf("Got ptr %d (size %d)\n",iptr, sz); */ im2 = gdImageCreateFromGdPtr (sz, iptr); gdFree (iptr); /*printf("Got img2 %d\n",im2); */ CompareImages ("GD->GD ptr->GD", ref, im2); gdImageDestroy (im2); /* * Test gdImageCreateFromPngSource' */ in = fopen (argv[1], "rb"); imgsrc.source = freadWrapper; imgsrc.context = in; im2 = gdImageCreateFromPngSource (&imgsrc); fclose (in); if (im2 == NULL) { printf ("GD Source: ERROR Null returned by gdImageCreateFromPngSource\n"); } else { CompareImages ("GD Source", ref, im2); gdImageDestroy (im2); }; /* * Test gdImagePngToSink' */ #ifdef VMS sprintf (of, "%s-snk", argv[1]); #else sprintf (of, "%s.snk", argv[1]); #endif out = fopen (of, "wb"); imgsnk.sink = fwriteWrapper; imgsnk.context = out; gdImagePngToSink (im, &imgsnk); fclose (out); in = fopen (of, "rb"); if (!in) { fprintf (stderr, "GD Sink: ERROR - GD Sink Output file does not exist!\n"); } else { im2 = gdImageCreateFromPng (in); fclose (in); CompareImages ("GD Sink", ref, im2); gdImageDestroy (im2); }; unlink (of); /* */ /* Test Extraction */ /* */ in = fopen ("test/gdtest_200_300_150_100.png", "rb"); if (!in) { fprintf(stderr, "gdtest_200_300_150_100.png does not exist!\n"); exit (1); } im2 = gdImageCreateFromPng (in); fclose (in); in = fopen ("test/gdtest.gd2", "rb"); if (!in) { fprintf(stderr, "gdtest.gd2 does not exist!\n"); exit (1); } im3 = gdImageCreateFromGd2Part (in, 200, 300, 150, 100); fclose (in); CompareImages ("GD2Part (gdtest_200_300_150_100.png, gdtest.gd2(part))", im2, im3); gdImageDestroy (im2); gdImageDestroy (im3); /* */ /* Copy Blend */ /* */ in = fopen ("test/gdtest.png", "rb"); if (!in) { fprintf(stderr, "gdtest.png does not exist!\n"); exit (1); } im2 = gdImageCreateFromPng (in); fclose (in); im3 = gdImageCreate (100, 60); colRed = gdImageColorAllocate (im3, 255, 0, 0); colBlu = gdImageColorAllocate (im3, 0, 0, 255); gdImageFilledRectangle (im3, 0, 0, 49, 30, colRed); gdImageFilledRectangle (im3, 50, 30, 99, 59, colBlu); gdImageCopyMerge (im2, im3, 150, 200, 10, 10, 90, 50, 50); gdImageCopyMerge (im2, im3, 180, 70, 10, 10, 90, 50, 50); gdImageCopyMergeGray (im2, im3, 250, 160, 10, 10, 90, 50, 50); gdImageCopyMergeGray (im2, im3, 80, 70, 10, 10, 90, 50, 50); gdImageDestroy (im3); in = fopen ("test/gdtest_merge.png", "rb"); if (!in) { fprintf(stderr, "gdtest_merge.png does not exist!\n"); exit (1); } im3 = gdImageCreateFromPng (in); fclose (in); printf ("[Merged Image has %d colours]\n", im2->colorsTotal); CompareImages ("Merged (gdtest.png, gdtest_merge.png)", im2, im3); gdImageDestroy (im2); gdImageDestroy (im3); #ifdef HAVE_LIBJPEG out = fopen ("test/gdtest.jpg", "wb"); if (!out) { fprintf(stderr, "Can't create file test/gdtest.jpg.\n"); exit (1); } gdImageJpeg (im, out, -1); fclose (out); in = fopen ("test/gdtest.jpg", "rb"); if (!in) { fprintf(stderr, "Can't open file test/gdtest.jpg.\n"); exit (1); } im2 = gdImageCreateFromJpeg (in); fclose (in); if (!im2) { fprintf(stderr, "gdImageCreateFromJpeg failed.\n"); exit (1); } gdImageDestroy (im2); printf ("Created test/gdtest.jpg successfully. Compare this image\n" "to the input image manually. Some difference must be\n" "expected as JPEG is a lossy file format.\n"); #endif /* HAVE_LIBJPEG */ /* Assume the color closest to black is the foreground color for the B&W wbmp image. */ fprintf (stderr, "NOTE: the WBMP output image will NOT match the original unless the original\n" "is also black and white. This is OK!\n"); foreground = gdImageColorClosest (im, 0, 0, 0); fprintf(stderr, "Foreground index is %d\n", foreground); if (foreground == -1) { fprintf(stderr, "Source image has no colors, skipping wbmp test.\n"); } else { out = fopen ("test/gdtest.wbmp", "wb"); if (!out) { fprintf(stderr, "Can't create file test/gdtest.wbmp.\n"); exit (1); } gdImageWBMP (im, foreground, out); fclose (out); in = fopen ("test/gdtest.wbmp", "rb"); if (!in) { fprintf(stderr, "Can't open file test/gdtest.wbmp.\n"); exit (1); } im2 = gdImageCreateFromWBMP (in); fprintf(stderr, "WBMP has %d colors\n", gdImageColorsTotal (im2)); fprintf(stderr, "WBMP colors are:\n"); for (i = 0; (i < gdImageColorsTotal (im2)); i++) { fprintf(stderr, "%02X%02X%02X\n", gdImageRed (im2, i), gdImageGreen (im2, i), gdImageBlue (im2, i)); } fclose (in); if (!im2) { fprintf(stderr, "gdImageCreateFromWBMP failed.\n"); exit (1); } CompareImages ("WBMP test (gdtest.png, gdtest.wbmp)", ref, im2); out = fopen ("test/gdtest_wbmp_to_png.png", "wb"); if (!out) { fprintf (stderr, "Can't create file test/gdtest_wbmp_to_png.png.\n"); exit (1); } gdImagePng (im2, out); fclose (out); gdImageDestroy (im2); } gdImageDestroy (im); gdImageDestroy (ref); #else fprintf(stderr, "No PNG library support.\n"); #endif /* HAVE_LIBPNG */ return 0; } void CompareImages (char *msg, gdImagePtr im1, gdImagePtr im2) { int cmpRes; cmpRes = gdImageCompare (im1, im2); if (cmpRes & GD_CMP_IMAGE) { printf ("%%%s: ERROR images differ: BAD\n", msg); } else if (cmpRes != 0) { printf ("%%%s: WARNING images differ: WARNING - Probably OK\n", msg); } else { printf ("%%%s: OK\n", msg); return; } if (cmpRes & (GD_CMP_SIZE_X + GD_CMP_SIZE_Y)) { printf ("-%s: INFO image sizes differ\n", msg); } if (cmpRes & GD_CMP_NUM_COLORS) { printf ("-%s: INFO number of palette entries differ %d Vs. %d\n", msg, im1->colorsTotal, im2->colorsTotal); } if (cmpRes & GD_CMP_COLOR) { printf ("-%s: INFO actual colours of pixels differ\n", msg); } } static int freadWrapper (void *context, char *buf, int len) { int got = fread (buf, 1, len, (FILE *) context); return got; } static int fwriteWrapper (void *context, const char *buffer, int len) { return fwrite (buffer, 1, len, (FILE *) context); } libgd-gd-2.1.1/src/gdtestft.c000066400000000000000000000130301245535672000157510ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" #include #include #define PI 3.141592 #define DEG2RAD(x) ((x)*PI/180.) #define MAX(x,y) ((x) > (y) ? (x) : (y)) #define MIN(x,y) ((x) < (y) ? (x) : (y)) #define MAX4(x,y,z,w) \ ((MAX((x),(y))) > (MAX((z),(w))) ? (MAX((x),(y))) : (MAX((z),(w)))) #define MIN4(x,y,z,w) \ ((MIN((x),(y))) < (MIN((z),(w))) ? (MIN((x),(y))) : (MIN((z),(w)))) #define MAXX(x) MAX4(x[0],x[2],x[4],x[6]) #define MINX(x) MIN4(x[0],x[2],x[4],x[6]) #define MAXY(x) MAX4(x[1],x[3],x[5],x[7]) #define MINY(x) MIN4(x[1],x[3],x[5],x[7]) int main (int argc, char *argv[]) { #ifndef HAVE_LIBFREETYPE fprintf(stderr, "gd was not compiled with HAVE_LIBFREETYPE defined.\n"); fprintf(stderr, "Install the FreeType library, including the\n"); fprintf(stderr, "header files. Then edit the gd Makefile, type\n"); fprintf(stderr, "make clean, and type make again.\n"); return 1; #else gdImagePtr im; int blue; int blueAlpha; int white; int brect[8]; int x, y, sx, sy; char *err; FILE *out; #ifdef JISX0208 char *s = "Hello. ɂ Qyjpqg,"; /* String to draw. */ #else char *s = "Hello. Qyjpqg,"; /* String to draw. */ #endif double sz = 40.; #if 0 double angle = 0.; #else double angle = DEG2RAD (90); #endif char *f; if (argc == 2) { f = argv[1]; } else { /* 2.02: usage message. Defaulting to Times wasn't working well for the many people with no /usr/share/fonts/truetype. */ fprintf(stderr, "Usage: gdtestft fontfilename\n" "If fontfilename is not a full or relative path, GDFONTPATH is searched for\n" "it. If GDFONTPATH is not set, /usr/share/fonts/truetype is searched.\n"); return 1; } /* obtain brect so that we can size the image */ err = gdImageStringFT ((gdImagePtr) NULL, &brect[0], 0, f, sz, angle, 0, 0, s); if (err) { fprintf(stderr, "%s\n", err); return 1; } /* create an image just big enough for the string (x3) */ sx = MAXX (brect) - MINX (brect) + 6; sy = MAXY (brect) - MINY (brect) + 6; #if 0 /* Would be palette color 8-bit (which of course is still allowed, but not impressive when used with a JPEG background and antialiasing and alpha channel and so on!) */ im = gdImageCreate (sx * 3, sy); #else /* gd 2.0: true color images can use freetype too, and they can do antialiasing against arbitrary complex backgrounds. */ im = gdImageCreateTrueColor (sx * 3, sy); #endif /* Background color. gd 2.0: fill the image with it; truecolor images have a black background otherwise. */ white = gdImageColorResolve (im, 255, 255, 255); /* Load a pretty background and resample it to cover the entire image */ { FILE *in = fopen ("eleanor.jpg", "rb"); gdImagePtr imb = NULL; if (in) { #ifdef HAVE_LIBJPEG imb = gdImageCreateFromJpeg (in); #else fprintf(stderr, "No JPEG library support.\n"); #endif fclose(in); if (!imb) { fprintf(stderr, "gdImageCreateFromJpeg failed\n"); return 1; } if (!im->trueColor) { /* If destination is not truecolor, convert the JPEG to a reasonably high-quality palette version. This is not as good as creating a truecolor output file, of course. Leave many colors for text smoothing. */ #if 1 gdImageTrueColorToPalette (imb, 0, 128); #endif } /* Resample background image to cover new image exactly */ gdImageCopyResampled (im, imb, 0, 0, 0, 0, sx * 3, sy, gdImageSX (imb), gdImageSY (imb)); } else { /* Can't get background, so paint a simple one */ /* Truecolor images start out black, so paint it white */ gdImageFilledRectangle (im, 0, 0, sx * 3, sy, white); } } /* TBB 2.0.2: only black was working, and I didn't know it because the test program used black. Funny, huh? Let's do a more interesting color this time. */ blue = gdImageColorResolve (im, 128, 192, 255); /* Almost-transparent blue (alpha blending), with antialiasing */ blueAlpha = gdImageColorResolveAlpha (im, 128, 192, 255, gdAlphaMax / 2); /* render the string, offset origin to center string */ x = 0 - MINX (brect) + 3; y = 0 - MINY (brect) + 3; /* With antialiasing (positive color value) */ err = gdImageStringFT (im, NULL, blue, f, sz, angle, x, y, s); if (err) { fprintf(stderr, "%s\n", err); return 1; } /* Without antialiasing (negative color value) */ err = gdImageStringFT (im, NULL, -blue, f, sz, angle, sx + x, y, s); if (err) { fprintf(stderr, "%s\n", err); return 1; } /* With antialiasing, and 50% alpha blending (truecolor only) */ err = gdImageStringFT (im, NULL, blueAlpha, f, sz, angle, sx * 2 + x, y, s); if (err) { fprintf(stderr, "%s\n", err); return 1; } /* TBB: Write img to test/fttest.jpg or test/fttest.png */ if (im->trueColor) { #ifdef HAVE_LIBJPEG out = fopen ("test/fttest.jpg", "wb"); if (!out) { fprintf(stderr, "Can't create test/fttest.jpg\n"); exit (1); } /* Fairly high JPEG quality setting */ gdImageJpeg (im, out, 90); fclose (out); fprintf(stderr, "Test image written to test/fttest.jpg\n"); #else fprintf(stderr, "Test image not written; No JPEG library support.\n"); #endif } else { #ifdef HAVE_LIBPNG out = fopen ("test/fttest.png", "wb"); if (!out) { fprintf(stderr, "Can't create test/fttest.png\n"); exit (1); } /* 2.0.10: correct ifdef, thanks to Gabriele Verzeletti */ gdImagePng (im, out); fclose (out); fprintf(stderr, "Test image written to test/fttest.png\n"); #else fprintf(stderr, "Test image not written; No PNG library support.\n"); #endif } /* Destroy it */ gdImageDestroy (im); return 0; #endif /* HAVE_LIBFREETYPE */ } libgd-gd-2.1.1/src/gdtopng.c000066400000000000000000000020101245535672000155630ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include "gd.h" /* A short program which converts a .png file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ int main (int argc, char **argv) { gdImagePtr im; FILE *in, *out; if (argc != 3) { fprintf(stderr, "Usage: gdtopng filename.gd filename.png\n"); exit (1); } in = fopen (argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit (1); } im = gdImageCreateFromGd (in); fclose (in); if (!im) { fprintf(stderr, "Input is not in GD format!\n"); exit (1); } out = fopen (argv[2], "wb"); if (!out) { fprintf(stderr, "Output file cannot be written to!\n"); gdImageDestroy (im); exit (1); } #ifdef HAVE_LIBPNG gdImagePng (im, out); #else fprintf(stderr, "No PNG library support.\n"); #endif fclose (out); gdImageDestroy (im); return 0; } libgd-gd-2.1.1/src/gdxpm.c000066400000000000000000000112221245535672000152450ustar00rootroot00000000000000/* * Add ability to load xpm files to gd, requires the xpm * library. * Caolan.McNamara@ul.ie * http://www.csn.ul.ie/~caolan */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include "gd.h" #include "gdhelpers.h" #include "gd_color_map.h" #include "gd_errors.h" #ifndef HAVE_LIBXPM BGD_DECLARE(gdImagePtr) gdImageCreateFromXpm(char *filename) { (void)filename; gd_error_ex(GD_ERROR, "libgd was not built with xpm support\n"); return NULL; } #else #include /* Function: gdImageCreateFromXpm is called to load images from XPM X Window System color bitmap format files. This function is available only if HAVE_XPM is selected in the Makefile and the Xpm library is linked with the application. Unlike most gd file functions, the Xpm functions *require filenames*, not file pointers. returns a to the new image, or NULL if unable to load the image (most often because the file is corrupt or does not contain an XPM bitmap format image). You can inspect the sx and sy members of the image to determine its size. The image must eventually be destroyed using . Parameters: filename - The input filename (*not* FILE pointer) Returns: A pointer to the new image or NULL if an error occurred. Example: > gdImagePtr im; > FILE *in; > in = fopen("myxpm.xpm", "rb"); > im = gdImageCreateFromXpm(in); > fclose(in); > // ... Use the image ... > gdImageDestroy(im); */ BGD_DECLARE(gdImagePtr) gdImageCreateFromXpm(char *filename) { XpmInfo info; XpmImage image; unsigned int i, j, k, number, len; char buf[5]; gdImagePtr im = 0; int *pointer; int red = 0, green = 0, blue = 0; int *colors; int ret; ret = XpmReadFileToXpmImage(filename, &image, &info); if(ret != XpmSuccess) { return 0; } number = image.ncolors; if(overflow2(sizeof(int), number)) { goto done; } for(i = 0; i < number; i++) { /* avoid NULL pointer dereference TODO better fix need to manage monochrome/monovisual see m_color or g4_color or g_color */ if (!image.colorTable[i].c_color) { goto done; } } colors = (int *)gdMalloc(sizeof(int) * number); if(colors == NULL) { goto done; } if(!(im = gdImageCreate(image.width, image.height))) { gdFree(colors); goto done; } for(i = 0; i < number; i++) { char *c_color = image.colorTable[i].c_color; if(strcmp(c_color, "None") == 0) { colors[i] = gdImageGetTransparent(im); if(colors[i] == -1) colors[i] = gdImageColorAllocate(im, 0, 0, 0); if(colors[i] != -1) gdImageColorTransparent(im, colors[i]); continue; } len = strlen(c_color); if(len < 1) continue; if(c_color[0] == '#') { switch(len) { case 4: buf[2] = '\0'; buf[0] = buf[1] = c_color[1]; red = strtol(buf, NULL, 16); buf[0] = buf[1] = c_color[2]; green = strtol(buf, NULL, 16); buf[0] = buf[1] = c_color[3]; blue = strtol(buf, NULL, 16); break; case 7: buf[2] = '\0'; buf[0] = c_color[1]; buf[1] = c_color[2]; red = strtol(buf, NULL, 16); buf[0] = c_color[3]; buf[1] = c_color[4]; green = strtol(buf, NULL, 16); buf[0] = c_color[5]; buf[1] = c_color[6]; blue = strtol(buf, NULL, 16); break; case 10: buf[3] = '\0'; buf[0] = c_color[1]; buf[1] = c_color[2]; buf[2] = c_color[3]; red = strtol(buf, NULL, 16); red /= 64; buf[0] = c_color[4]; buf[1] = c_color[5]; buf[2] = c_color[6]; green = strtol(buf, NULL, 16); green /= 64; buf[0] = c_color[7]; buf[1] = c_color[8]; buf[2] = c_color[9]; blue = strtol(buf, NULL, 16); blue /= 64; break; case 13: buf[4] = '\0'; buf[0] = c_color[1]; buf[1] = c_color[2]; buf[2] = c_color[3]; buf[3] = c_color[4]; red = strtol(buf, NULL, 16); red /= 256; buf[0] = c_color[5]; buf[1] = c_color[6]; buf[2] = c_color[7]; buf[3] = c_color[8]; green = strtol(buf, NULL, 16); green /= 256; buf[0] = c_color[9]; buf[1] = c_color[10]; buf[2] = c_color[11]; buf[3] = c_color[12]; blue = strtol(buf, NULL, 16); blue /= 256; break; } } else if(!gdColorMapLookup(GD_COLOR_MAP_X11, c_color, &red, &green, &blue)) { continue; } colors[i] = gdImageColorResolve(im, red, green, blue); } pointer = (int *)image.data; for(i = 0; i < image.height; i++) { for(j = 0; j < image.width; j++) { k = *pointer++; gdImageSetPixel(im, j, i, colors[k]); } } gdFree(colors); done: XpmFreeXpmImage(&image); XpmFreeXpmInfo(&info); return im; } #endif /* HAVE_LIBXPM */ libgd-gd-2.1.1/src/gifanimtest.c000066400000000000000000000012521245535672000164420ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" int main(void) { gdImagePtr im; gdImagePtr last, cim; int blue; FILE *out; int i; im = gdImageCreate(100, 100); blue = gdImageColorAllocate(im, 0, 0, 255); out = fopen("gifanim.gif", "wb"); gdImageGifAnimBegin(im, out, 1, 10); last = 0; for (i = 0; (i <= 100); i += 2) { cim = gdImageCreate(100, 100); gdImagePaletteCopy(cim, im); gdImageArc(cim, 50, 50, i, i, 0, 360, blue); gdImageGifAnimAdd(cim, out, 0, 0, 0, 10, gdDisposalNone, last); if (last) { gdImageDestroy(last); } last = cim; } gdImageDestroy(last); gdImageGifAnimEnd(out); fclose(out); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/src/giftogd2.c000066400000000000000000000021771245535672000156440ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include #include #include "gd.h" /* A short program which converts a .gif file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ int main(int argc, char **argv) { gdImagePtr im; FILE *in, *out; int cs, fmt; if (argc != 5) { fprintf(stderr, "Usage: giftogd2 filename.gif filename.gd2 cs fmt\n"); fprintf(stderr, " where cs is the chunk size\n"); fprintf(stderr, " fmt is 1 for raw, 2 for compressed\n"); exit(1); } in = fopen(argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit(1); } im = gdImageCreateFromGif(in); fclose(in); if (!im) { fprintf(stderr, "Input is not in GIF format!\n"); exit(1); } out = fopen(argv[2], "wb"); if (!out) { fprintf(stderr, "Output file cannot be written to!\n"); gdImageDestroy(im); exit(1); } cs = atoi(argv[3]); fmt = atoi(argv[4]); gdImageGd2(im, out, cs, fmt); fclose(out); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/src/jisx0208.h000066400000000000000000002233271245535672000154350ustar00rootroot00000000000000#ifdef __cplusplus extern "C" { #endif #ifndef JISX0208_H #define JISX0208_H /* This file was derived from "src/VF_Ftype.c" in VFlib2-2.24.2 by Dr. Kakugawa */ /* JIS -> Unicode mapping table */ static const unsigned short UnicodeTbl[][94] = { { /* category 01 */ 0x0000, 0x3001, 0x3002, 0xFF0C, 0xFF0E, 0x30FB, 0xFF1A, 0xFF1B, 0xFF1F, 0xFF01, 0x309B, 0x309C, 0x00B4, 0xFF40, 0x00A8, 0xFF3E, 0xFFE3, 0xFF3F, 0x30FD, 0x30FE, 0x309D, 0x309E, 0x3003, 0x4EDD, 0x3005, 0x3006, 0x3007, 0x30FC, 0x2015, 0x2010, 0xFF0F, 0xFF3C, 0xFF5E, 0x2225, 0xFF5C, 0x2026, 0x2025, 0x2018, 0x2019, 0x201C, 0x201D, 0xFF08, 0xFF09, 0x3014, 0x3015, 0xFF3B, 0xFF3D, 0xFF5B, 0xFF5D, 0x3008, 0x3009, 0x300A, 0x300B, 0x300C, 0x300D, 0x300E, 0x300F, 0x3010, 0x3011, 0xFF0B, 0xFF0D, 0x00B1, 0x00D7, 0x00F7, 0xFF1D, 0x2260, 0xFF1C, 0xFF1E, 0x2266, 0x2267, 0x221E, 0x2234, 0x2642, 0x2640, 0x00B0, 0x2032, 0x2033, 0x2103, 0xFFE5, 0xFF04, 0xFFE0, 0xFFE1, 0xFF05, 0xFF03, 0xFF06, 0xFF0A, 0xFF20, 0x00A7, 0x2606, 0x2605, 0x25CB, 0x25CF, 0x25CE, 0x25C7 }, { /* category 02 */ 0x25C6, 0x25A1, 0x25A0, 0x25B3, 0x25B2, 0x25BD, 0x25BC, 0x203B, 0x3012, 0x2192, 0x2190, 0x2191, 0x2193, 0x3013, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x2208, 0x220B, 0x2286, 0x2287, 0x2282, 0x2283, 0x222A, 0x2229, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x2227, 0x2228, 0xFFE2, 0x21D2, 0x21D4, 0x2200, 0x2203, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x2220, 0x22A5, 0x2312, 0x2202, 0x2207, 0x2261, 0x2252, 0x226A, 0x226B, 0x221A, 0x223D, 0x221D, 0x2235, 0x222B, 0x222C, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x212B, 0x2030, 0x266F, 0x266D, 0x266A, 0x2020, 0x2021, /**/ 0x00B6, 0x0000, 0x0000, 0x0000, 0x0000, 0x25EF }, { /* category 03 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0xFF10, 0xFF11, 0xFF12, 0xFF13, 0xFF14, 0xFF15, 0xFF16, 0xFF17, 0xFF18, 0xFF19, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0xFF21, 0xFF22, 0xFF23, 0xFF24, 0xFF25, 0xFF26, 0xFF27, 0xFF28, 0xFF29, 0xFF2A, 0xFF2B, 0xFF2C, 0xFF2D, 0xFF2E, 0xFF2F, 0xFF30, 0xFF31, 0xFF32, 0xFF33, 0xFF34, 0xFF35, 0xFF36, 0xFF37, 0xFF38, 0xFF39, 0xFF3A, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0xFF41, 0xFF42, 0xFF43, 0xFF44, 0xFF45, 0xFF46, 0xFF47, 0xFF48, 0xFF49, 0xFF4A, 0xFF4B, 0xFF4C, 0xFF4D, 0xFF4E, 0xFF4F, 0xFF50, 0xFF51, 0xFF52, 0xFF53, 0xFF54, 0xFF55, 0xFF56, 0xFF57, 0xFF58, 0xFF59, 0xFF5A, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 04 */ 0x3041, 0x3042, 0x3043, 0x3044, 0x3045, 0x3046, 0x3047, 0x3048, 0x3049, 0x304A, 0x304B, 0x304C, 0x304D, 0x304E, 0x304F, 0x3050, 0x3051, 0x3052, 0x3053, 0x3054, 0x3055, 0x3056, 0x3057, 0x3058, 0x3059, 0x305A, 0x305B, 0x305C, 0x305D, 0x305E, 0x305F, 0x3060, 0x3061, 0x3062, 0x3063, 0x3064, 0x3065, 0x3066, 0x3067, 0x3068, 0x3069, 0x306A, 0x306B, 0x306C, 0x306D, 0x306E, 0x306F, 0x3070, 0x3071, 0x3072, 0x3073, 0x3074, 0x3075, 0x3076, 0x3077, 0x3078, 0x3079, 0x307A, 0x307B, 0x307C, 0x307D, 0x307E, 0x307F, 0x3080, 0x3081, 0x3082, 0x3083, 0x3084, 0x3085, 0x3086, 0x3087, 0x3088, 0x3089, 0x308A, 0x308B, 0x308C, 0x308D, 0x308E, 0x308F, 0x3090, 0x3091, 0x3092, 0x3093, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 05 */ 0x30A1, 0x30A2, 0x30A3, 0x30A4, 0x30A5, 0x30A6, 0x30A7, 0x30A8, 0x30A9, 0x30AA, 0x30AB, 0x30AC, 0x30AD, 0x30AE, 0x30AF, 0x30B0, 0x30B1, 0x30B2, 0x30B3, 0x30B4, 0x30B5, 0x30B6, 0x30B7, 0x30B8, 0x30B9, 0x30BA, 0x30BB, 0x30BC, 0x30BD, 0x30BE, 0x30BF, 0x30C0, 0x30C1, 0x30C2, 0x30C3, 0x30C4, 0x30C5, 0x30C6, 0x30C7, 0x30C8, 0x30C9, 0x30CA, 0x30CB, 0x30CC, 0x30CD, 0x30CE, 0x30CF, 0x30D0, 0x30D1, 0x30D2, 0x30D3, 0x30D4, 0x30D5, 0x30D6, 0x30D7, 0x30D8, 0x30D9, 0x30DA, 0x30DB, 0x30DC, 0x30DD, 0x30DE, 0x30DF, 0x30E0, 0x30E1, 0x30E2, 0x30E3, 0x30E4, 0x30E5, 0x30E6, 0x30E7, 0x30E8, 0x30E9, 0x30EA, 0x30EB, 0x30EC, 0x30ED, 0x30EE, 0x30EF, 0x30F0, 0x30F1, 0x30F2, 0x30F3, 0x30F4, 0x30F5, 0x30F6, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 06 */ 0x0391, 0x0392, 0x0393, 0x0394, 0x0395, 0x0396, 0x0397, 0x0398, 0x0399, 0x039A, 0x039B, 0x039C, 0x039D, 0x039E, 0x039F, 0x03A0, 0x03A1, 0x03A3, 0x03A4, 0x03A5, 0x03A6, 0x03A7, 0x03A8, 0x03A9, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x03B1, 0x03B2, 0x03B3, 0x03B4, 0x03B5, 0x03B6, 0x03B7, 0x03B8, 0x03B9, 0x03BA, 0x03BB, 0x03BC, 0x03BD, 0x03BE, 0x03BF, 0x03C0, 0x03C1, 0x03C3, 0x03C4, 0x03C5, 0x03C6, 0x03C7, 0x03C8, 0x03C9, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 07 */ 0x0410, 0x0411, 0x0412, 0x0413, 0x0414, 0x0415, 0x0401, 0x0416, 0x0417, 0x0418, 0x0419, 0x041A, 0x041B, 0x041C, 0x041D, 0x041E, 0x041F, 0x0420, 0x0421, 0x0422, 0x0423, 0x0424, 0x0425, 0x0426, 0x0427, 0x0428, 0x0429, 0x042A, 0x042B, 0x042C, 0x042D, 0x042E, 0x042F, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0430, 0x0431, 0x0432, 0x0433, 0x0434, 0x0435, 0x0451, 0x0436, 0x0437, 0x0438, 0x0439, 0x043A, 0x043B, 0x043C, 0x043D, 0x043E, 0x043F, 0x0440, 0x0441, 0x0442, 0x0443, 0x0444, 0x0445, 0x0446, 0x0447, 0x0448, 0x0449, 0x044A, 0x044B, 0x044C, 0x044D, 0x044E, 0x044F, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 08 */ 0x2500, 0x2502, 0x250C, 0x2510, 0x2518, 0x2514, 0x251C, 0x252C, 0x2524, 0x2534, 0x253C, 0x2501, 0x2503, 0x250F, 0x2513, 0x251B, 0x2517, 0x2523, 0x2533, 0x252B, 0x253B, 0x254B, 0x2520, 0x252F, 0x2528, 0x2537, 0x253F, 0x251D, 0x2530, 0x2525, 0x2538, 0x2542, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 09 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 10 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 11 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 12 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 13 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 14 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 15 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 16 */ 0x4E9C, 0x5516, 0x5A03, 0x963F, 0x54C0, 0x611B, 0x6328, 0x59F6, 0x9022, 0x8475, 0x831C, 0x7A50, 0x60AA, 0x63E1, 0x6E25, 0x65ED, 0x8466, 0x82A6, 0x9BF5, 0x6893, 0x5727, 0x65A1, 0x6271, 0x5B9B, 0x59D0, 0x867B, 0x98F4, 0x7D62, 0x7DBE, 0x9B8E, 0x6216, 0x7C9F, 0x88B7, 0x5B89, 0x5EB5, 0x6309, 0x6697, 0x6848, 0x95C7, 0x978D, 0x674F, 0x4EE5, 0x4F0A, 0x4F4D, 0x4F9D, 0x5049, 0x56F2, 0x5937, 0x59D4, 0x5A01, 0x5C09, 0x60DF, 0x610F, 0x6170, 0x6613, 0x6905, 0x70BA, 0x754F, 0x7570, 0x79FB, 0x7DAD, 0x7DEF, 0x80C3, 0x840E, 0x8863, 0x8B02, 0x9055, 0x907A, 0x533B, 0x4E95, 0x4EA5, 0x57DF, 0x80B2, 0x90C1, 0x78EF, 0x4E00, 0x58F1, 0x6EA2, 0x9038, 0x7A32, 0x8328, 0x828B, 0x9C2F, 0x5141, 0x5370, 0x54BD, 0x54E1, 0x56E0, 0x59FB, 0x5F15, 0x98F2, 0x6DEB, 0x80E4, 0x852D }, { /* category 17 */ 0x9662, 0x9670, 0x96A0, 0x97FB, 0x540B, 0x53F3, 0x5B87, 0x70CF, 0x7FBD, 0x8FC2, 0x96E8, 0x536F, 0x9D5C, 0x7ABA, 0x4E11, 0x7893, 0x81FC, 0x6E26, 0x5618, 0x5504, 0x6B1D, 0x851A, 0x9C3B, 0x59E5, 0x53A9, 0x6D66, 0x74DC, 0x958F, 0x5642, 0x4E91, 0x904B, 0x96F2, 0x834F, 0x990C, 0x53E1, 0x55B6, 0x5B30, 0x5F71, 0x6620, 0x66F3, 0x6804, 0x6C38, 0x6CF3, 0x6D29, 0x745B, 0x76C8, 0x7A4E, 0x9834, 0x82F1, 0x885B, 0x8A60, 0x92ED, 0x6DB2, 0x75AB, 0x76CA, 0x99C5, 0x60A6, 0x8B01, 0x8D8A, 0x95B2, 0x698E, 0x53AD, 0x5186, 0x5712, 0x5830, 0x5944, 0x5BB4, 0x5EF6, 0x6028, 0x63A9, 0x63F4, 0x6CBF, 0x6F14, 0x708E, 0x7114, 0x7159, 0x71D5, 0x733F, 0x7E01, 0x8276, 0x82D1, 0x8597, 0x9060, 0x925B, 0x9D1B, 0x5869, 0x65BC, 0x6C5A, 0x7525, 0x51F9, 0x592E, 0x5965, 0x5F80, 0x5FDC }, { /* category 18 */ 0x62BC, 0x65FA, 0x6A2A, 0x6B27, 0x6BB4, 0x738B, 0x7FC1, 0x8956, 0x9D2C, 0x9D0E, 0x9EC4, 0x5CA1, 0x6C96, 0x837B, 0x5104, 0x5C4B, 0x61B6, 0x81C6, 0x6876, 0x7261, 0x4E59, 0x4FFA, 0x5378, 0x6069, 0x6E29, 0x7A4F, 0x97F3, 0x4E0B, 0x5316, 0x4EEE, 0x4F55, 0x4F3D, 0x4FA1, 0x4F73, 0x52A0, 0x53EF, 0x5609, 0x590F, 0x5AC1, 0x5BB6, 0x5BE1, 0x79D1, 0x6687, 0x679C, 0x67B6, 0x6B4C, 0x6CB3, 0x706B, 0x73C2, 0x798D, 0x79BE, 0x7A3C, 0x7B87, 0x82B1, 0x82DB, 0x8304, 0x8377, 0x83EF, 0x83D3, 0x8766, 0x8AB2, 0x5629, 0x8CA8, 0x8FE6, 0x904E, 0x971E, 0x868A, 0x4FC4, 0x5CE8, 0x6211, 0x7259, 0x753B, 0x81E5, 0x82BD, 0x86FE, 0x8CC0, 0x96C5, 0x9913, 0x99D5, 0x4ECB, 0x4F1A, 0x89E3, 0x56DE, 0x584A, 0x58CA, 0x5EFB, 0x5FEB, 0x602A, 0x6094, 0x6062, 0x61D0, 0x6212, 0x62D0, 0x6539 }, { /* category 19 */ 0x9B41, 0x6666, 0x68B0, 0x6D77, 0x7070, 0x754C, 0x7686, 0x7D75, 0x82A5, 0x87F9, 0x958B, 0x968E, 0x8C9D, 0x51F1, 0x52BE, 0x5916, 0x54B3, 0x5BB3, 0x5D16, 0x6168, 0x6982, 0x6DAF, 0x788D, 0x84CB, 0x8857, 0x8A72, 0x93A7, 0x9AB8, 0x6D6C, 0x99A8, 0x86D9, 0x57A3, 0x67FF, 0x86CE, 0x920E, 0x5283, 0x5687, 0x5404, 0x5ED3, 0x62E1, 0x64B9, 0x683C, 0x6838, 0x6BBB, 0x7372, 0x78BA, 0x7A6B, 0x899A, 0x89D2, 0x8D6B, 0x8F03, 0x90ED, 0x95A3, 0x9694, 0x9769, 0x5B66, 0x5CB3, 0x697D, 0x984D, 0x984E, 0x639B, 0x7B20, 0x6A2B, 0x6A7F, 0x68B6, 0x9C0D, 0x6F5F, 0x5272, 0x559D, 0x6070, 0x62EC, 0x6D3B, 0x6E07, 0x6ED1, 0x845B, 0x8910, 0x8F44, 0x4E14, 0x9C39, 0x53F6, 0x691B, 0x6A3A, 0x9784, 0x682A, 0x515C, 0x7AC3, 0x84B2, 0x91DC, 0x938C, 0x565B, 0x9D28, 0x6822, 0x8305, 0x8431 }, { /* category 20 */ 0x7CA5, 0x5208, 0x82C5, 0x74E6, 0x4E7E, 0x4F83, 0x51A0, 0x5BD2, 0x520A, 0x52D8, 0x52E7, 0x5DFB, 0x559A, 0x582A, 0x59E6, 0x5B8C, 0x5B98, 0x5BDB, 0x5E72, 0x5E79, 0x60A3, 0x611F, 0x6163, 0x61BE, 0x63DB, 0x6562, 0x67D1, 0x6853, 0x68FA, 0x6B3E, 0x6B53, 0x6C57, 0x6F22, 0x6F97, 0x6F45, 0x74B0, 0x7518, 0x76E3, 0x770B, 0x7AFF, 0x7BA1, 0x7C21, 0x7DE9, 0x7F36, 0x7FF0, 0x809D, 0x8266, 0x839E, 0x89B3, 0x8ACC, 0x8CAB, 0x9084, 0x9451, 0x9593, 0x9591, 0x95A2, 0x9665, 0x97D3, 0x9928, 0x8218, 0x4E38, 0x542B, 0x5CB8, 0x5DCC, 0x73A9, 0x764C, 0x773C, 0x5CA9, 0x7FEB, 0x8D0B, 0x96C1, 0x9811, 0x9854, 0x9858, 0x4F01, 0x4F0E, 0x5371, 0x559C, 0x5668, 0x57FA, 0x5947, 0x5B09, 0x5BC4, 0x5C90, 0x5E0C, 0x5E7E, 0x5FCC, 0x63EE, 0x673A, 0x65D7, 0x65E2, 0x671F, 0x68CB, 0x68C4 }, { /* category 21 */ 0x6A5F, 0x5E30, 0x6BC5, 0x6C17, 0x6C7D, 0x757F, 0x7948, 0x5B63, 0x7A00, 0x7D00, 0x5FBD, 0x898F, 0x8A18, 0x8CB4, 0x8D77, 0x8ECC, 0x8F1D, 0x98E2, 0x9A0E, 0x9B3C, 0x4E80, 0x507D, 0x5100, 0x5993, 0x5B9C, 0x622F, 0x6280, 0x64EC, 0x6B3A, 0x72A0, 0x7591, 0x7947, 0x7FA9, 0x87FB, 0x8ABC, 0x8B70, 0x63AC, 0x83CA, 0x97A0, 0x5409, 0x5403, 0x55AB, 0x6854, 0x6A58, 0x8A70, 0x7827, 0x6775, 0x9ECD, 0x5374, 0x5BA2, 0x811A, 0x8650, 0x9006, 0x4E18, 0x4E45, 0x4EC7, 0x4F11, 0x53CA, 0x5438, 0x5BAE, 0x5F13, 0x6025, 0x6551, 0x673D, 0x6C42, 0x6C72, 0x6CE3, 0x7078, 0x7403, 0x7A76, 0x7AAE, 0x7B08, 0x7D1A, 0x7CFE, 0x7D66, 0x65E7, 0x725B, 0x53BB, 0x5C45, 0x5DE8, 0x62D2, 0x62E0, 0x6319, 0x6E20, 0x865A, 0x8A31, 0x8DDD, 0x92F8, 0x6F01, 0x79A6, 0x9B5A, 0x4EA8, 0x4EAB, 0x4EAC }, { /* category 22 */ 0x4F9B, 0x4FA0, 0x50D1, 0x5147, 0x7AF6, 0x5171, 0x51F6, 0x5354, 0x5321, 0x537F, 0x53EB, 0x55AC, 0x5883, 0x5CE1, 0x5F37, 0x5F4A, 0x602F, 0x6050, 0x606D, 0x631F, 0x6559, 0x6A4B, 0x6CC1, 0x72C2, 0x72ED, 0x77EF, 0x80F8, 0x8105, 0x8208, 0x854E, 0x90F7, 0x93E1, 0x97FF, 0x9957, 0x9A5A, 0x4EF0, 0x51DD, 0x5C2D, 0x6681, 0x696D, 0x5C40, 0x66F2, 0x6975, 0x7389, 0x6850, 0x7C81, 0x50C5, 0x52E4, 0x5747, 0x5DFE, 0x9326, 0x65A4, 0x6B23, 0x6B3D, 0x7434, 0x7981, 0x79BD, 0x7B4B, 0x7DCA, 0x82B9, 0x83CC, 0x887F, 0x895F, 0x8B39, 0x8FD1, 0x91D1, 0x541F, 0x9280, 0x4E5D, 0x5036, 0x53E5, 0x533A, 0x72D7, 0x7396, 0x77E9, 0x82E6, 0x8EAF, 0x99C6, 0x99C8, 0x99D2, 0x5177, 0x611A, 0x865E, 0x55B0, 0x7A7A, 0x5076, 0x5BD3, 0x9047, 0x9685, 0x4E32, 0x6ADB, 0x91E7, 0x5C51, 0x5C48 }, { /* category 23 */ 0x6398, 0x7A9F, 0x6C93, 0x9774, 0x8F61, 0x7AAA, 0x718A, 0x9688, 0x7C82, 0x6817, 0x7E70, 0x6851, 0x936C, 0x52F2, 0x541B, 0x85AB, 0x8A13, 0x7FA4, 0x8ECD, 0x90E1, 0x5366, 0x8888, 0x7941, 0x4FC2, 0x50BE, 0x5211, 0x5144, 0x5553, 0x572D, 0x73EA, 0x578B, 0x5951, 0x5F62, 0x5F84, 0x6075, 0x6176, 0x6167, 0x61A9, 0x63B2, 0x643A, 0x656C, 0x666F, 0x6842, 0x6E13, 0x7566, 0x7A3D, 0x7CFB, 0x7D4C, 0x7D99, 0x7E4B, 0x7F6B, 0x830E, 0x834A, 0x86CD, 0x8A08, 0x8A63, 0x8B66, 0x8EFD, 0x981A, 0x9D8F, 0x82B8, 0x8FCE, 0x9BE8, 0x5287, 0x621F, 0x6483, 0x6FC0, 0x9699, 0x6841, 0x5091, 0x6B20, 0x6C7A, 0x6F54, 0x7A74, 0x7D50, 0x8840, 0x8A23, 0x6708, 0x4EF6, 0x5039, 0x5026, 0x5065, 0x517C, 0x5238, 0x5263, 0x55A7, 0x570F, 0x5805, 0x5ACC, 0x5EFA, 0x61B2, 0x61F8, 0x62F3, 0x6372 }, { /* category 24 */ 0x691C, 0x6A29, 0x727D, 0x72AC, 0x732E, 0x7814, 0x786F, 0x7D79, 0x770C, 0x80A9, 0x898B, 0x8B19, 0x8CE2, 0x8ED2, 0x9063, 0x9375, 0x967A, 0x9855, 0x9A13, 0x9E78, 0x5143, 0x539F, 0x53B3, 0x5E7B, 0x5F26, 0x6E1B, 0x6E90, 0x7384, 0x73FE, 0x7D43, 0x8237, 0x8A00, 0x8AFA, 0x9650, 0x4E4E, 0x500B, 0x53E4, 0x547C, 0x56FA, 0x59D1, 0x5B64, 0x5DF1, 0x5EAB, 0x5F27, 0x6238, 0x6545, 0x67AF, 0x6E56, 0x72D0, 0x7CCA, 0x88B4, 0x80A1, 0x80E1, 0x83F0, 0x864E, 0x8A87, 0x8DE8, 0x9237, 0x96C7, 0x9867, 0x9F13, 0x4E94, 0x4E92, 0x4F0D, 0x5348, 0x5449, 0x543E, 0x5A2F, 0x5F8C, 0x5FA1, 0x609F, 0x68A7, 0x6A8E, 0x745A, 0x7881, 0x8A9E, 0x8AA4, 0x8B77, 0x9190, 0x4E5E, 0x9BC9, 0x4EA4, 0x4F7C, 0x4FAF, 0x5019, 0x5016, 0x5149, 0x516C, 0x529F, 0x52B9, 0x52FE, 0x539A, 0x53E3, 0x5411 }, { /* category 25 */ 0x540E, 0x5589, 0x5751, 0x57A2, 0x597D, 0x5B54, 0x5B5D, 0x5B8F, 0x5DE5, 0x5DE7, 0x5DF7, 0x5E78, 0x5E83, 0x5E9A, 0x5EB7, 0x5F18, 0x6052, 0x614C, 0x6297, 0x62D8, 0x63A7, 0x653B, 0x6602, 0x6643, 0x66F4, 0x676D, 0x6821, 0x6897, 0x69CB, 0x6C5F, 0x6D2A, 0x6D69, 0x6E2F, 0x6E9D, 0x7532, 0x7687, 0x786C, 0x7A3F, 0x7CE0, 0x7D05, 0x7D18, 0x7D5E, 0x7DB1, 0x8015, 0x8003, 0x80AF, 0x80B1, 0x8154, 0x818F, 0x822A, 0x8352, 0x884C, 0x8861, 0x8B1B, 0x8CA2, 0x8CFC, 0x90CA, 0x9175, 0x9271, 0x783F, 0x92FC, 0x95A4, 0x964D, 0x9805, 0x9999, 0x9AD8, 0x9D3B, 0x525B, 0x52AB, 0x53F7, 0x5408, 0x58D5, 0x62F7, 0x6FE0, 0x8C6A, 0x8F5F, 0x9EB9, 0x514B, 0x523B, 0x544A, 0x56FD, 0x7A40, 0x9177, 0x9D60, 0x9ED2, 0x7344, 0x6F09, 0x8170, 0x7511, 0x5FFD, 0x60DA, 0x9AA8, 0x72DB, 0x8FBC }, { /* category 26 */ 0x6B64, 0x9803, 0x4ECA, 0x56F0, 0x5764, 0x58BE, 0x5A5A, 0x6068, 0x61C7, 0x660F, 0x6606, 0x6839, 0x68B1, 0x6DF7, 0x75D5, 0x7D3A, 0x826E, 0x9B42, 0x4E9B, 0x4F50, 0x53C9, 0x5506, 0x5D6F, 0x5DE6, 0x5DEE, 0x67FB, 0x6C99, 0x7473, 0x7802, 0x8A50, 0x9396, 0x88DF, 0x5750, 0x5EA7, 0x632B, 0x50B5, 0x50AC, 0x518D, 0x6700, 0x54C9, 0x585E, 0x59BB, 0x5BB0, 0x5F69, 0x624D, 0x63A1, 0x683D, 0x6B73, 0x6E08, 0x707D, 0x91C7, 0x7280, 0x7815, 0x7826, 0x796D, 0x658E, 0x7D30, 0x83DC, 0x88C1, 0x8F09, 0x969B, 0x5264, 0x5728, 0x6750, 0x7F6A, 0x8CA1, 0x51B4, 0x5742, 0x962A, 0x583A, 0x698A, 0x80B4, 0x54B2, 0x5D0E, 0x57FC, 0x7895, 0x9DFA, 0x4F5C, 0x524A, 0x548B, 0x643E, 0x6628, 0x6714, 0x67F5, 0x7A84, 0x7B56, 0x7D22, 0x932F, 0x685C, 0x9BAD, 0x7B39, 0x5319, 0x518A, 0x5237 }, { /* category 27 */ 0x5BDF, 0x62F6, 0x64AE, 0x64E6, 0x672D, 0x6BBA, 0x85A9, 0x96D1, 0x7690, 0x9BD6, 0x634C, 0x9306, 0x9BAB, 0x76BF, 0x6652, 0x4E09, 0x5098, 0x53C2, 0x5C71, 0x60E8, 0x6492, 0x6563, 0x685F, 0x71E6, 0x73CA, 0x7523, 0x7B97, 0x7E82, 0x8695, 0x8B83, 0x8CDB, 0x9178, 0x9910, 0x65AC, 0x66AB, 0x6B8B, 0x4ED5, 0x4ED4, 0x4F3A, 0x4F7F, 0x523A, 0x53F8, 0x53F2, 0x55E3, 0x56DB, 0x58EB, 0x59CB, 0x59C9, 0x59FF, 0x5B50, 0x5C4D, 0x5E02, 0x5E2B, 0x5FD7, 0x601D, 0x6307, 0x652F, 0x5B5C, 0x65AF, 0x65BD, 0x65E8, 0x679D, 0x6B62, 0x6B7B, 0x6C0F, 0x7345, 0x7949, 0x79C1, 0x7CF8, 0x7D19, 0x7D2B, 0x80A2, 0x8102, 0x81F3, 0x8996, 0x8A5E, 0x8A69, 0x8A66, 0x8A8C, 0x8AEE, 0x8CC7, 0x8CDC, 0x96CC, 0x98FC, 0x6B6F, 0x4E8B, 0x4F3C, 0x4F8D, 0x5150, 0x5B57, 0x5BFA, 0x6148, 0x6301, 0x6642 }, { /* category 28 */ 0x6B21, 0x6ECB, 0x6CBB, 0x723E, 0x74BD, 0x75D4, 0x78C1, 0x793A, 0x800C, 0x8033, 0x81EA, 0x8494, 0x8F9E, 0x6C50, 0x9E7F, 0x5F0F, 0x8B58, 0x9D2B, 0x7AFA, 0x8EF8, 0x5B8D, 0x96EB, 0x4E03, 0x53F1, 0x57F7, 0x5931, 0x5AC9, 0x5BA4, 0x6089, 0x6E7F, 0x6F06, 0x75BE, 0x8CEA, 0x5B9F, 0x8500, 0x7BE0, 0x5072, 0x67F4, 0x829D, 0x5C61, 0x854A, 0x7E1E, 0x820E, 0x5199, 0x5C04, 0x6368, 0x8D66, 0x659C, 0x716E, 0x793E, 0x7D17, 0x8005, 0x8B1D, 0x8ECA, 0x906E, 0x86C7, 0x90AA, 0x501F, 0x52FA, 0x5C3A, 0x6753, 0x707C, 0x7235, 0x914C, 0x91C8, 0x932B, 0x82E5, 0x5BC2, 0x5F31, 0x60F9, 0x4E3B, 0x53D6, 0x5B88, 0x624B, 0x6731, 0x6B8A, 0x72E9, 0x73E0, 0x7A2E, 0x816B, 0x8DA3, 0x9152, 0x9996, 0x5112, 0x53D7, 0x546A, 0x5BFF, 0x6388, 0x6A39, 0x7DAC, 0x9700, 0x56DA, 0x53CE, 0x5468 }, { /* category 29 */ 0x5B97, 0x5C31, 0x5DDE, 0x4FEE, 0x6101, 0x62FE, 0x6D32, 0x79C0, 0x79CB, 0x7D42, 0x7E4D, 0x7FD2, 0x81ED, 0x821F, 0x8490, 0x8846, 0x8972, 0x8B90, 0x8E74, 0x8F2F, 0x9031, 0x914B, 0x916C, 0x96C6, 0x919C, 0x4EC0, 0x4F4F, 0x5145, 0x5341, 0x5F93, 0x620E, 0x67D4, 0x6C41, 0x6E0B, 0x7363, 0x7E26, 0x91CD, 0x9283, 0x53D4, 0x5919, 0x5BBF, 0x6DD1, 0x795D, 0x7E2E, 0x7C9B, 0x587E, 0x719F, 0x51FA, 0x8853, 0x8FF0, 0x4FCA, 0x5CFB, 0x6625, 0x77AC, 0x7AE3, 0x821C, 0x99FF, 0x51C6, 0x5FAA, 0x65EC, 0x696F, 0x6B89, 0x6DF3, 0x6E96, 0x6F64, 0x76FE, 0x7D14, 0x5DE1, 0x9075, 0x9187, 0x9806, 0x51E6, 0x521D, 0x6240, 0x6691, 0x66D9, 0x6E1A, 0x5EB6, 0x7DD2, 0x7F72, 0x66F8, 0x85AF, 0x85F7, 0x8AF8, 0x52A9, 0x53D9, 0x5973, 0x5E8F, 0x5F90, 0x6055, 0x92E4, 0x9664, 0x50B7, 0x511F }, { /* category 30 */ 0x52DD, 0x5320, 0x5347, 0x53EC, 0x54E8, 0x5546, 0x5531, 0x5617, 0x5968, 0x59BE, 0x5A3C, 0x5BB5, 0x5C06, 0x5C0F, 0x5C11, 0x5C1A, 0x5E84, 0x5E8A, 0x5EE0, 0x5F70, 0x627F, 0x6284, 0x62DB, 0x638C, 0x6377, 0x6607, 0x660C, 0x662D, 0x6676, 0x677E, 0x68A2, 0x6A1F, 0x6A35, 0x6CBC, 0x6D88, 0x6E09, 0x6E58, 0x713C, 0x7126, 0x7167, 0x75C7, 0x7701, 0x785D, 0x7901, 0x7965, 0x79F0, 0x7AE0, 0x7B11, 0x7CA7, 0x7D39, 0x8096, 0x83D6, 0x848B, 0x8549, 0x885D, 0x88F3, 0x8A1F, 0x8A3C, 0x8A54, 0x8A73, 0x8C61, 0x8CDE, 0x91A4, 0x9266, 0x937E, 0x9418, 0x969C, 0x9798, 0x4E0A, 0x4E08, 0x4E1E, 0x4E57, 0x5197, 0x5270, 0x57CE, 0x5834, 0x58CC, 0x5B22, 0x5E38, 0x60C5, 0x64FE, 0x6761, 0x6756, 0x6D44, 0x72B6, 0x7573, 0x7A63, 0x84B8, 0x8B72, 0x91B8, 0x9320, 0x5631, 0x57F4, 0x98FE }, { /* category 31 */ 0x62ED, 0x690D, 0x6B96, 0x71ED, 0x7E54, 0x8077, 0x8272, 0x89E6, 0x98DF, 0x8755, 0x8FB1, 0x5C3B, 0x4F38, 0x4FE1, 0x4FB5, 0x5507, 0x5A20, 0x5BDD, 0x5BE9, 0x5FC3, 0x614E, 0x632F, 0x65B0, 0x664B, 0x68EE, 0x699B, 0x6D78, 0x6DF1, 0x7533, 0x75B9, 0x771F, 0x795E, 0x79E6, 0x7D33, 0x81E3, 0x82AF, 0x85AA, 0x89AA, 0x8A3A, 0x8EAB, 0x8F9B, 0x9032, 0x91DD, 0x9707, 0x4EBA, 0x4EC1, 0x5203, 0x5875, 0x58EC, 0x5C0B, 0x751A, 0x5C3D, 0x814E, 0x8A0A, 0x8FC5, 0x9663, 0x976D, 0x7B25, 0x8ACF, 0x9808, 0x9162, 0x56F3, 0x53A8, 0x9017, 0x5439, 0x5782, 0x5E25, 0x63A8, 0x6C34, 0x708A, 0x7761, 0x7C8B, 0x7FE0, 0x8870, 0x9042, 0x9154, 0x9310, 0x9318, 0x968F, 0x745E, 0x9AC4, 0x5D07, 0x5D69, 0x6570, 0x67A2, 0x8DA8, 0x96DB, 0x636E, 0x6749, 0x6919, 0x83C5, 0x9817, 0x96C0, 0x88FE }, { /* category 32 */ 0x6F84, 0x647A, 0x5BF8, 0x4E16, 0x702C, 0x755D, 0x662F, 0x51C4, 0x5236, 0x52E2, 0x59D3, 0x5F81, 0x6027, 0x6210, 0x653F, 0x6574, 0x661F, 0x6674, 0x68F2, 0x6816, 0x6B63, 0x6E05, 0x7272, 0x751F, 0x76DB, 0x7CBE, 0x8056, 0x58F0, 0x88FD, 0x897F, 0x8AA0, 0x8A93, 0x8ACB, 0x901D, 0x9192, 0x9752, 0x9759, 0x6589, 0x7A0E, 0x8106, 0x96BB, 0x5E2D, 0x60DC, 0x621A, 0x65A5, 0x6614, 0x6790, 0x77F3, 0x7A4D, 0x7C4D, 0x7E3E, 0x810A, 0x8CAC, 0x8D64, 0x8DE1, 0x8E5F, 0x78A9, 0x5207, 0x62D9, 0x63A5, 0x6442, 0x6298, 0x8A2D, 0x7A83, 0x7BC0, 0x8AAC, 0x96EA, 0x7D76, 0x820C, 0x8749, 0x4ED9, 0x5148, 0x5343, 0x5360, 0x5BA3, 0x5C02, 0x5C16, 0x5DDD, 0x6226, 0x6247, 0x64B0, 0x6813, 0x6834, 0x6CC9, 0x6D45, 0x6D17, 0x67D3, 0x6F5C, 0x714E, 0x717D, 0x65CB, 0x7A7F, 0x7BAD, 0x7DDA }, { /* category 33 */ 0x7E4A, 0x7FA8, 0x817A, 0x821B, 0x8239, 0x85A6, 0x8A6E, 0x8CCE, 0x8DF5, 0x9078, 0x9077, 0x92AD, 0x9291, 0x9583, 0x9BAE, 0x524D, 0x5584, 0x6F38, 0x7136, 0x5168, 0x7985, 0x7E55, 0x81B3, 0x7CCE, 0x564C, 0x5851, 0x5CA8, 0x63AA, 0x66FE, 0x66FD, 0x695A, 0x72D9, 0x758F, 0x758E, 0x790E, 0x7956, 0x79DF, 0x7C97, 0x7D20, 0x7D44, 0x8607, 0x8A34, 0x963B, 0x9061, 0x9F20, 0x50E7, 0x5275, 0x53CC, 0x53E2, 0x5009, 0x55AA, 0x58EE, 0x594F, 0x723D, 0x5B8B, 0x5C64, 0x531D, 0x60E3, 0x60F3, 0x635C, 0x6383, 0x633F, 0x63BB, 0x64CD, 0x65E9, 0x66F9, 0x5DE3, 0x69CD, 0x69FD, 0x6F15, 0x71E5, 0x4E89, 0x75E9, 0x76F8, 0x7A93, 0x7CDF, 0x7DCF, 0x7D9C, 0x8061, 0x8349, 0x8358, 0x846C, 0x84BC, 0x85FB, 0x88C5, 0x8D70, 0x9001, 0x906D, 0x9397, 0x971C, 0x9A12, 0x50CF, 0x5897, 0x618E }, { /* category 34 */ 0x81D3, 0x8535, 0x8D08, 0x9020, 0x4FC3, 0x5074, 0x5247, 0x5373, 0x606F, 0x6349, 0x675F, 0x6E2C, 0x8DB3, 0x901F, 0x4FD7, 0x5C5E, 0x8CCA, 0x65CF, 0x7D9A, 0x5352, 0x8896, 0x5176, 0x63C3, 0x5B58, 0x5B6B, 0x5C0A, 0x640D, 0x6751, 0x905C, 0x4ED6, 0x591A, 0x592A, 0x6C70, 0x8A51, 0x553E, 0x5815, 0x59A5, 0x60F0, 0x6253, 0x67C1, 0x8235, 0x6955, 0x9640, 0x99C4, 0x9A28, 0x4F53, 0x5806, 0x5BFE, 0x8010, 0x5CB1, 0x5E2F, 0x5F85, 0x6020, 0x614B, 0x6234, 0x66FF, 0x6CF0, 0x6EDE, 0x80CE, 0x817F, 0x82D4, 0x888B, 0x8CB8, 0x9000, 0x902E, 0x968A, 0x9EDB, 0x9BDB, 0x4EE3, 0x53F0, 0x5927, 0x7B2C, 0x918D, 0x984C, 0x9DF9, 0x6EDD, 0x7027, 0x5353, 0x5544, 0x5B85, 0x6258, 0x629E, 0x62D3, 0x6CA2, 0x6FEF, 0x7422, 0x8A17, 0x9438, 0x6FC1, 0x8AFE, 0x8338, 0x51E7, 0x86F8, 0x53EA }, { /* category 35 */ 0x53E9, 0x4F46, 0x9054, 0x8FB0, 0x596A, 0x8131, 0x5DFD, 0x7AEA, 0x8FBF, 0x68DA, 0x8C37, 0x72F8, 0x9C48, 0x6A3D, 0x8AB0, 0x4E39, 0x5358, 0x5606, 0x5766, 0x62C5, 0x63A2, 0x65E6, 0x6B4E, 0x6DE1, 0x6E5B, 0x70AD, 0x77ED, 0x7AEF, 0x7BAA, 0x7DBB, 0x803D, 0x80C6, 0x86CB, 0x8A95, 0x935B, 0x56E3, 0x58C7, 0x5F3E, 0x65AD, 0x6696, 0x6A80, 0x6BB5, 0x7537, 0x8AC7, 0x5024, 0x77E5, 0x5730, 0x5F1B, 0x6065, 0x667A, 0x6C60, 0x75F4, 0x7A1A, 0x7F6E, 0x81F4, 0x8718, 0x9045, 0x99B3, 0x7BC9, 0x755C, 0x7AF9, 0x7B51, 0x84C4, 0x9010, 0x79E9, 0x7A92, 0x8336, 0x5AE1, 0x7740, 0x4E2D, 0x4EF2, 0x5B99, 0x5FE0, 0x62BD, 0x663C, 0x67F1, 0x6CE8, 0x866B, 0x8877, 0x8A3B, 0x914E, 0x92F3, 0x99D0, 0x6A17, 0x7026, 0x732A, 0x82E7, 0x8457, 0x8CAF, 0x4E01, 0x5146, 0x51CB, 0x558B, 0x5BF5 }, { /* category 36 */ 0x5E16, 0x5E33, 0x5E81, 0x5F14, 0x5F35, 0x5F6B, 0x5FB4, 0x61F2, 0x6311, 0x66A2, 0x671D, 0x6F6E, 0x7252, 0x753A, 0x773A, 0x8074, 0x8139, 0x8178, 0x8776, 0x8ABF, 0x8ADC, 0x8D85, 0x8DF3, 0x929A, 0x9577, 0x9802, 0x9CE5, 0x52C5, 0x6357, 0x76F4, 0x6715, 0x6C88, 0x73CD, 0x8CC3, 0x93AE, 0x9673, 0x6D25, 0x589C, 0x690E, 0x69CC, 0x8FFD, 0x939A, 0x75DB, 0x901A, 0x585A, 0x6802, 0x63B4, 0x69FB, 0x4F43, 0x6F2C, 0x67D8, 0x8FBB, 0x8526, 0x7DB4, 0x9354, 0x693F, 0x6F70, 0x576A, 0x58F7, 0x5B2C, 0x7D2C, 0x722A, 0x540A, 0x91E3, 0x9DB4, 0x4EAD, 0x4F4E, 0x505C, 0x5075, 0x5243, 0x8C9E, 0x5448, 0x5824, 0x5B9A, 0x5E1D, 0x5E95, 0x5EAD, 0x5EF7, 0x5F1F, 0x608C, 0x62B5, 0x633A, 0x63D0, 0x68AF, 0x6C40, 0x7887, 0x798E, 0x7A0B, 0x7DE0, 0x8247, 0x8A02, 0x8AE6, 0x8E44, 0x9013 }, { /* category 37 */ 0x90B8, 0x912D, 0x91D8, 0x9F0E, 0x6CE5, 0x6458, 0x64E2, 0x6575, 0x6EF4, 0x7684, 0x7B1B, 0x9069, 0x93D1, 0x6EBA, 0x54F2, 0x5FB9, 0x64A4, 0x8F4D, 0x8FED, 0x9244, 0x5178, 0x586B, 0x5929, 0x5C55, 0x5E97, 0x6DFB, 0x7E8F, 0x751C, 0x8CBC, 0x8EE2, 0x985B, 0x70B9, 0x4F1D, 0x6BBF, 0x6FB1, 0x7530, 0x96FB, 0x514E, 0x5410, 0x5835, 0x5857, 0x59AC, 0x5C60, 0x5F92, 0x6597, 0x675C, 0x6E21, 0x767B, 0x83DF, 0x8CED, 0x9014, 0x90FD, 0x934D, 0x7825, 0x783A, 0x52AA, 0x5EA6, 0x571F, 0x5974, 0x6012, 0x5012, 0x515A, 0x51AC, 0x51CD, 0x5200, 0x5510, 0x5854, 0x5858, 0x5957, 0x5B95, 0x5CF6, 0x5D8B, 0x60BC, 0x6295, 0x642D, 0x6771, 0x6843, 0x68BC, 0x68DF, 0x76D7, 0x6DD8, 0x6E6F, 0x6D9B, 0x706F, 0x71C8, 0x5F53, 0x75D8, 0x7977, 0x7B49, 0x7B54, 0x7B52, 0x7CD6, 0x7D71, 0x5230 }, { /* category 38 */ 0x8463, 0x8569, 0x85E4, 0x8A0E, 0x8B04, 0x8C46, 0x8E0F, 0x9003, 0x900F, 0x9419, 0x9676, 0x982D, 0x9A30, 0x95D8, 0x50CD, 0x52D5, 0x540C, 0x5802, 0x5C0E, 0x61A7, 0x649E, 0x6D1E, 0x77B3, 0x7AE5, 0x80F4, 0x8404, 0x9053, 0x9285, 0x5CE0, 0x9D07, 0x533F, 0x5F97, 0x5FB3, 0x6D9C, 0x7279, 0x7763, 0x79BF, 0x7BE4, 0x6BD2, 0x72EC, 0x8AAD, 0x6803, 0x6A61, 0x51F8, 0x7A81, 0x6934, 0x5C4A, 0x9CF6, 0x82EB, 0x5BC5, 0x9149, 0x701E, 0x5678, 0x5C6F, 0x60C7, 0x6566, 0x6C8C, 0x8C5A, 0x9041, 0x9813, 0x5451, 0x66C7, 0x920D, 0x5948, 0x90A3, 0x5185, 0x4E4D, 0x51EA, 0x8599, 0x8B0E, 0x7058, 0x637A, 0x934B, 0x6962, 0x99B4, 0x7E04, 0x7577, 0x5357, 0x6960, 0x8EDF, 0x96E3, 0x6C5D, 0x4E8C, 0x5C3C, 0x5F10, 0x8FE9, 0x5302, 0x8CD1, 0x8089, 0x8679, 0x5EFF, 0x65E5, 0x4E73, 0x5165 }, { /* category 39 */ 0x5982, 0x5C3F, 0x97EE, 0x4EFB, 0x598A, 0x5FCD, 0x8A8D, 0x6FE1, 0x79B0, 0x7962, 0x5BE7, 0x8471, 0x732B, 0x71B1, 0x5E74, 0x5FF5, 0x637B, 0x649A, 0x71C3, 0x7C98, 0x4E43, 0x5EFC, 0x4E4B, 0x57DC, 0x56A2, 0x60A9, 0x6FC3, 0x7D0D, 0x80FD, 0x8133, 0x81BF, 0x8FB2, 0x8997, 0x86A4, 0x5DF4, 0x628A, 0x64AD, 0x8987, 0x6777, 0x6CE2, 0x6D3E, 0x7436, 0x7834, 0x5A46, 0x7F75, 0x82AD, 0x99AC, 0x4FF3, 0x5EC3, 0x62DD, 0x6392, 0x6557, 0x676F, 0x76C3, 0x724C, 0x80CC, 0x80BA, 0x8F29, 0x914D, 0x500D, 0x57F9, 0x5A92, 0x6885, 0x6973, 0x7164, 0x72FD, 0x8CB7, 0x58F2, 0x8CE0, 0x966A, 0x9019, 0x877F, 0x79E4, 0x77E7, 0x8429, 0x4F2F, 0x5265, 0x535A, 0x62CD, 0x67CF, 0x6CCA, 0x767D, 0x7B94, 0x7C95, 0x8236, 0x8584, 0x8FEB, 0x66DD, 0x6F20, 0x7206, 0x7E1B, 0x83AB, 0x99C1, 0x9EA6 }, { /* category 40 */ 0x51FD, 0x7BB1, 0x7872, 0x7BB8, 0x8087, 0x7B48, 0x6AE8, 0x5E61, 0x808C, 0x7551, 0x7560, 0x516B, 0x9262, 0x6E8C, 0x767A, 0x9197, 0x9AEA, 0x4F10, 0x7F70, 0x629C, 0x7B4F, 0x95A5, 0x9CE9, 0x567A, 0x5859, 0x86E4, 0x96BC, 0x4F34, 0x5224, 0x534A, 0x53CD, 0x53DB, 0x5E06, 0x642C, 0x6591, 0x677F, 0x6C3E, 0x6C4E, 0x7248, 0x72AF, 0x73ED, 0x7554, 0x7E41, 0x822C, 0x85E9, 0x8CA9, 0x7BC4, 0x91C6, 0x7169, 0x9812, 0x98EF, 0x633D, 0x6669, 0x756A, 0x76E4, 0x78D0, 0x8543, 0x86EE, 0x532A, 0x5351, 0x5426, 0x5983, 0x5E87, 0x5F7C, 0x60B2, 0x6249, 0x6279, 0x62AB, 0x6590, 0x6BD4, 0x6CCC, 0x75B2, 0x76AE, 0x7891, 0x79D8, 0x7DCB, 0x7F77, 0x80A5, 0x88AB, 0x8AB9, 0x8CBB, 0x907F, 0x975E, 0x98DB, 0x6A0B, 0x7C38, 0x5099, 0x5C3E, 0x5FAE, 0x6787, 0x6BD8, 0x7435, 0x7709, 0x7F8E }, { /* category 41 */ 0x9F3B, 0x67CA, 0x7A17, 0x5339, 0x758B, 0x9AED, 0x5F66, 0x819D, 0x83F1, 0x8098, 0x5F3C, 0x5FC5, 0x7562, 0x7B46, 0x903C, 0x6867, 0x59EB, 0x5A9B, 0x7D10, 0x767E, 0x8B2C, 0x4FF5, 0x5F6A, 0x6A19, 0x6C37, 0x6F02, 0x74E2, 0x7968, 0x8868, 0x8A55, 0x8C79, 0x5EDF, 0x63CF, 0x75C5, 0x79D2, 0x82D7, 0x9328, 0x92F2, 0x849C, 0x86ED, 0x9C2D, 0x54C1, 0x5F6C, 0x658C, 0x6D5C, 0x7015, 0x8CA7, 0x8CD3, 0x983B, 0x654F, 0x74F6, 0x4E0D, 0x4ED8, 0x57E0, 0x592B, 0x5A66, 0x5BCC, 0x51A8, 0x5E03, 0x5E9C, 0x6016, 0x6276, 0x6577, 0x65A7, 0x666E, 0x6D6E, 0x7236, 0x7B26, 0x8150, 0x819A, 0x8299, 0x8B5C, 0x8CA0, 0x8CE6, 0x8D74, 0x961C, 0x9644, 0x4FAE, 0x64AB, 0x6B66, 0x821E, 0x8461, 0x856A, 0x90E8, 0x5C01, 0x6953, 0x98A8, 0x847A, 0x8557, 0x4F0F, 0x526F, 0x5FA9, 0x5E45, 0x670D }, { /* category 42 */ 0x798F, 0x8179, 0x8907, 0x8986, 0x6DF5, 0x5F17, 0x6255, 0x6CB8, 0x4ECF, 0x7269, 0x9B92, 0x5206, 0x543B, 0x5674, 0x58B3, 0x61A4, 0x626E, 0x711A, 0x596E, 0x7C89, 0x7CDE, 0x7D1B, 0x96F0, 0x6587, 0x805E, 0x4E19, 0x4F75, 0x5175, 0x5840, 0x5E63, 0x5E73, 0x5F0A, 0x67C4, 0x4E26, 0x853D, 0x9589, 0x965B, 0x7C73, 0x9801, 0x50FB, 0x58C1, 0x7656, 0x78A7, 0x5225, 0x77A5, 0x8511, 0x7B86, 0x504F, 0x5909, 0x7247, 0x7BC7, 0x7DE8, 0x8FBA, 0x8FD4, 0x904D, 0x4FBF, 0x52C9, 0x5A29, 0x5F01, 0x97AD, 0x4FDD, 0x8217, 0x92EA, 0x5703, 0x6355, 0x6B69, 0x752B, 0x88DC, 0x8F14, 0x7A42, 0x52DF, 0x5893, 0x6155, 0x620A, 0x66AE, 0x6BCD, 0x7C3F, 0x83E9, 0x5023, 0x4FF8, 0x5305, 0x5446, 0x5831, 0x5949, 0x5B9D, 0x5CF0, 0x5CEF, 0x5D29, 0x5E96, 0x62B1, 0x6367, 0x653E, 0x65B9, 0x670B }, { /* category 43 */ 0x6CD5, 0x6CE1, 0x70F9, 0x7832, 0x7E2B, 0x80DE, 0x82B3, 0x840C, 0x84EC, 0x8702, 0x8912, 0x8A2A, 0x8C4A, 0x90A6, 0x92D2, 0x98FD, 0x9CF3, 0x9D6C, 0x4E4F, 0x4EA1, 0x508D, 0x5256, 0x574A, 0x59A8, 0x5E3D, 0x5FD8, 0x5FD9, 0x623F, 0x66B4, 0x671B, 0x67D0, 0x68D2, 0x5192, 0x7D21, 0x80AA, 0x81A8, 0x8B00, 0x8C8C, 0x8CBF, 0x927E, 0x9632, 0x5420, 0x982C, 0x5317, 0x50D5, 0x535C, 0x58A8, 0x64B2, 0x6734, 0x7267, 0x7766, 0x7A46, 0x91E6, 0x52C3, 0x6CA1, 0x6B86, 0x5800, 0x5E4C, 0x5954, 0x672C, 0x7FFB, 0x51E1, 0x76C6, 0x6469, 0x78E8, 0x9B54, 0x9EBB, 0x57CB, 0x59B9, 0x6627, 0x679A, 0x6BCE, 0x54E9, 0x69D9, 0x5E55, 0x819C, 0x6795, 0x9BAA, 0x67FE, 0x9C52, 0x685D, 0x4EA6, 0x4FE3, 0x53C8, 0x62B9, 0x672B, 0x6CAB, 0x8FC4, 0x4FAD, 0x7E6D, 0x9EBF, 0x4E07, 0x6162, 0x6E80 }, { /* category 44 */ 0x6F2B, 0x8513, 0x5473, 0x672A, 0x9B45, 0x5DF3, 0x7B95, 0x5CAC, 0x5BC6, 0x871C, 0x6E4A, 0x84D1, 0x7A14, 0x8108, 0x5999, 0x7C8D, 0x6C11, 0x7720, 0x52D9, 0x5922, 0x7121, 0x725F, 0x77DB, 0x9727, 0x9D61, 0x690B, 0x5A7F, 0x5A18, 0x51A5, 0x540D, 0x547D, 0x660E, 0x76DF, 0x8FF7, 0x9298, 0x9CF4, 0x59EA, 0x725D, 0x6EC5, 0x514D, 0x68C9, 0x7DBF, 0x7DEC, 0x9762, 0x9EBA, 0x6478, 0x6A21, 0x8302, 0x5984, 0x5B5F, 0x6BDB, 0x731B, 0x76F2, 0x7DB2, 0x8017, 0x8499, 0x5132, 0x6728, 0x9ED9, 0x76EE, 0x6762, 0x52FF, 0x9905, 0x5C24, 0x623B, 0x7C7E, 0x8CB0, 0x554F, 0x60B6, 0x7D0B, 0x9580, 0x5301, 0x4E5F, 0x51B6, 0x591C, 0x723A, 0x8036, 0x91CE, 0x5F25, 0x77E2, 0x5384, 0x5F79, 0x7D04, 0x85AC, 0x8A33, 0x8E8D, 0x9756, 0x67F3, 0x85AE, 0x9453, 0x6109, 0x6108, 0x6CB9, 0x7652 }, { /* category 45 */ 0x8AED, 0x8F38, 0x552F, 0x4F51, 0x512A, 0x52C7, 0x53CB, 0x5BA5, 0x5E7D, 0x60A0, 0x6182, 0x63D6, 0x6709, 0x67DA, 0x6E67, 0x6D8C, 0x7336, 0x7337, 0x7531, 0x7950, 0x88D5, 0x8A98, 0x904A, 0x9091, 0x90F5, 0x96C4, 0x878D, 0x5915, 0x4E88, 0x4F59, 0x4E0E, 0x8A89, 0x8F3F, 0x9810, 0x50AD, 0x5E7C, 0x5996, 0x5BB9, 0x5EB8, 0x63DA, 0x63FA, 0x64C1, 0x66DC, 0x694A, 0x69D8, 0x6D0B, 0x6EB6, 0x7194, 0x7528, 0x7AAF, 0x7F8A, 0x8000, 0x8449, 0x84C9, 0x8981, 0x8B21, 0x8E0A, 0x9065, 0x967D, 0x990A, 0x617E, 0x6291, 0x6B32, 0x6C83, 0x6D74, 0x7FCC, 0x7FFC, 0x6DC0, 0x7F85, 0x87BA, 0x88F8, 0x6765, 0x83B1, 0x983C, 0x96F7, 0x6D1B, 0x7D61, 0x843D, 0x916A, 0x4E71, 0x5375, 0x5D50, 0x6B04, 0x6FEB, 0x85CD, 0x862D, 0x89A7, 0x5229, 0x540F, 0x5C65, 0x674E, 0x68A8, 0x7406, 0x7483 }, { /* category 46 */ 0x75E2, 0x88CF, 0x88E1, 0x91CC, 0x96E2, 0x9678, 0x5F8B, 0x7387, 0x7ACB, 0x844E, 0x63A0, 0x7565, 0x5289, 0x6D41, 0x6E9C, 0x7409, 0x7559, 0x786B, 0x7C92, 0x9686, 0x7ADC, 0x9F8D, 0x4FB6, 0x616E, 0x65C5, 0x865C, 0x4E86, 0x4EAE, 0x50DA, 0x4E21, 0x51CC, 0x5BEE, 0x6599, 0x6881, 0x6DBC, 0x731F, 0x7642, 0x77AD, 0x7A1C, 0x7CE7, 0x826F, 0x8AD2, 0x907C, 0x91CF, 0x9675, 0x9818, 0x529B, 0x7DD1, 0x502B, 0x5398, 0x6797, 0x6DCB, 0x71D0, 0x7433, 0x81E8, 0x8F2A, 0x96A3, 0x9C57, 0x9E9F, 0x7460, 0x5841, 0x6D99, 0x7D2F, 0x985E, 0x4EE4, 0x4F36, 0x4F8B, 0x51B7, 0x52B1, 0x5DBA, 0x601C, 0x73B2, 0x793C, 0x82D3, 0x9234, 0x96B7, 0x96F6, 0x970A, 0x9E97, 0x9F62, 0x66A6, 0x6B74, 0x5217, 0x52A3, 0x70C8, 0x88C2, 0x5EC9, 0x604B, 0x6190, 0x6F23, 0x7149, 0x7C3E, 0x7DF4, 0x806F }, { /* category 47 */ 0x84EE, 0x9023, 0x932C, 0x5442, 0x9B6F, 0x6AD3, 0x7089, 0x8CC2, 0x8DEF, 0x9732, 0x52B4, 0x5A41, 0x5ECA, 0x5F04, 0x6717, 0x697C, 0x6994, 0x6D6A, 0x6F0F, 0x7262, 0x72FC, 0x7BED, 0x8001, 0x807E, 0x874B, 0x90CE, 0x516D, 0x9E93, 0x7984, 0x808B, 0x9332, 0x8AD6, 0x502D, 0x548C, 0x8A71, 0x6B6A, 0x8CC4, 0x8107, 0x60D1, 0x67A0, 0x9DF2, 0x4E99, 0x4E98, 0x9C10, 0x8A6B, 0x85C1, 0x8568, 0x6900, 0x6E7E, 0x7897, 0x8155, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 48 */ 0x5F0C, 0x4E10, 0x4E15, 0x4E2A, 0x4E31, 0x4E36, 0x4E3C, 0x4E3F, 0x4E42, 0x4E56, 0x4E58, 0x4E82, 0x4E85, 0x8C6B, 0x4E8A, 0x8212, 0x5F0D, 0x4E8E, 0x4E9E, 0x4E9F, 0x4EA0, 0x4EA2, 0x4EB0, 0x4EB3, 0x4EB6, 0x4ECE, 0x4ECD, 0x4EC4, 0x4EC6, 0x4EC2, 0x4ED7, 0x4EDE, 0x4EED, 0x4EDF, 0x4EF7, 0x4F09, 0x4F5A, 0x4F30, 0x4F5B, 0x4F5D, 0x4F57, 0x4F47, 0x4F76, 0x4F88, 0x4F8F, 0x4F98, 0x4F7B, 0x4F69, 0x4F70, 0x4F91, 0x4F6F, 0x4F86, 0x4F96, 0x5118, 0x4FD4, 0x4FDF, 0x4FCE, 0x4FD8, 0x4FDB, 0x4FD1, 0x4FDA, 0x4FD0, 0x4FE4, 0x4FE5, 0x501A, 0x5028, 0x5014, 0x502A, 0x5025, 0x5005, 0x4F1C, 0x4FF6, 0x5021, 0x5029, 0x502C, 0x4FFE, 0x4FEF, 0x5011, 0x5006, 0x5043, 0x5047, 0x6703, 0x5055, 0x5050, 0x5048, 0x505A, 0x5056, 0x506C, 0x5078, 0x5080, 0x509A, 0x5085, 0x50B4, 0x50B2 }, { /* category 49 */ 0x50C9, 0x50CA, 0x50B3, 0x50C2, 0x50D6, 0x50DE, 0x50E5, 0x50ED, 0x50E3, 0x50EE, 0x50F9, 0x50F5, 0x5109, 0x5101, 0x5102, 0x5116, 0x5115, 0x5114, 0x511A, 0x5121, 0x513A, 0x5137, 0x513C, 0x513B, 0x513F, 0x5140, 0x5152, 0x514C, 0x5154, 0x5162, 0x7AF8, 0x5169, 0x516A, 0x516E, 0x5180, 0x5182, 0x56D8, 0x518C, 0x5189, 0x518F, 0x5191, 0x5193, 0x5195, 0x5196, 0x51A4, 0x51A6, 0x51A2, 0x51A9, 0x51AA, 0x51AB, 0x51B3, 0x51B1, 0x51B2, 0x51B0, 0x51B5, 0x51BD, 0x51C5, 0x51C9, 0x51DB, 0x51E0, 0x8655, 0x51E9, 0x51ED, 0x51F0, 0x51F5, 0x51FE, 0x5204, 0x520B, 0x5214, 0x520E, 0x5227, 0x522A, 0x522E, 0x5233, 0x5239, 0x524F, 0x5244, 0x524B, 0x524C, 0x525E, 0x5254, 0x526A, 0x5274, 0x5269, 0x5273, 0x527F, 0x527D, 0x528D, 0x5294, 0x5292, 0x5271, 0x5288, 0x5291, 0x8FA8 }, { /* category 50 */ 0x8FA7, 0x52AC, 0x52AD, 0x52BC, 0x52B5, 0x52C1, 0x52CD, 0x52D7, 0x52DE, 0x52E3, 0x52E6, 0x98ED, 0x52E0, 0x52F3, 0x52F5, 0x52F8, 0x52F9, 0x5306, 0x5308, 0x7538, 0x530D, 0x5310, 0x530F, 0x5315, 0x531A, 0x5323, 0x532F, 0x5331, 0x5333, 0x5338, 0x5340, 0x5346, 0x5345, 0x4E17, 0x5349, 0x534D, 0x51D6, 0x535E, 0x5369, 0x536E, 0x5918, 0x537B, 0x5377, 0x5382, 0x5396, 0x53A0, 0x53A6, 0x53A5, 0x53AE, 0x53B0, 0x53B6, 0x53C3, 0x7C12, 0x96D9, 0x53DF, 0x66FC, 0x71EE, 0x53EE, 0x53E8, 0x53ED, 0x53FA, 0x5401, 0x543D, 0x5440, 0x542C, 0x542D, 0x543C, 0x542E, 0x5436, 0x5429, 0x541D, 0x544E, 0x548F, 0x5475, 0x548E, 0x545F, 0x5471, 0x5477, 0x5470, 0x5492, 0x547B, 0x5480, 0x5476, 0x5484, 0x5490, 0x5486, 0x54C7, 0x54A2, 0x54B8, 0x54A5, 0x54AC, 0x54C4, 0x54C8, 0x54A8 }, { /* category 51 */ 0x54AB, 0x54C2, 0x54A4, 0x54BE, 0x54BC, 0x54D8, 0x54E5, 0x54E6, 0x550F, 0x5514, 0x54FD, 0x54EE, 0x54ED, 0x54FA, 0x54E2, 0x5539, 0x5540, 0x5563, 0x554C, 0x552E, 0x555C, 0x5545, 0x5556, 0x5557, 0x5538, 0x5533, 0x555D, 0x5599, 0x5580, 0x54AF, 0x558A, 0x559F, 0x557B, 0x557E, 0x5598, 0x559E, 0x55AE, 0x557C, 0x5583, 0x55A9, 0x5587, 0x55A8, 0x55DA, 0x55C5, 0x55DF, 0x55C4, 0x55DC, 0x55E4, 0x55D4, 0x5614, 0x55F7, 0x5616, 0x55FE, 0x55FD, 0x561B, 0x55F9, 0x564E, 0x5650, 0x71DF, 0x5634, 0x5636, 0x5632, 0x5638, 0x566B, 0x5664, 0x562F, 0x566C, 0x566A, 0x5686, 0x5680, 0x568A, 0x56A0, 0x5694, 0x568F, 0x56A5, 0x56AE, 0x56B6, 0x56B4, 0x56C2, 0x56BC, 0x56C1, 0x56C3, 0x56C0, 0x56C8, 0x56CE, 0x56D1, 0x56D3, 0x56D7, 0x56EE, 0x56F9, 0x5700, 0x56FF, 0x5704, 0x5709 }, { /* category 52 */ 0x5708, 0x570B, 0x570D, 0x5713, 0x5718, 0x5716, 0x55C7, 0x571C, 0x5726, 0x5737, 0x5738, 0x574E, 0x573B, 0x5740, 0x574F, 0x5769, 0x57C0, 0x5788, 0x5761, 0x577F, 0x5789, 0x5793, 0x57A0, 0x57B3, 0x57A4, 0x57AA, 0x57B0, 0x57C3, 0x57C6, 0x57D4, 0x57D2, 0x57D3, 0x580A, 0x57D6, 0x57E3, 0x580B, 0x5819, 0x581D, 0x5872, 0x5821, 0x5862, 0x584B, 0x5870, 0x6BC0, 0x5852, 0x583D, 0x5879, 0x5885, 0x58B9, 0x589F, 0x58AB, 0x58BA, 0x58DE, 0x58BB, 0x58B8, 0x58AE, 0x58C5, 0x58D3, 0x58D1, 0x58D7, 0x58D9, 0x58D8, 0x58E5, 0x58DC, 0x58E4, 0x58DF, 0x58EF, 0x58FA, 0x58F9, 0x58FB, 0x58FC, 0x58FD, 0x5902, 0x590A, 0x5910, 0x591B, 0x68A6, 0x5925, 0x592C, 0x592D, 0x5932, 0x5938, 0x593E, 0x7AD2, 0x5955, 0x5950, 0x594E, 0x595A, 0x5958, 0x5962, 0x5960, 0x5967, 0x596C, 0x5969 }, { /* category 53 */ 0x5978, 0x5981, 0x599D, 0x4F5E, 0x4FAB, 0x59A3, 0x59B2, 0x59C6, 0x59E8, 0x59DC, 0x598D, 0x59D9, 0x59DA, 0x5A25, 0x5A1F, 0x5A11, 0x5A1C, 0x5A09, 0x5A1A, 0x5A40, 0x5A6C, 0x5A49, 0x5A35, 0x5A36, 0x5A62, 0x5A6A, 0x5A9A, 0x5ABC, 0x5ABE, 0x5ACB, 0x5AC2, 0x5ABD, 0x5AE3, 0x5AD7, 0x5AE6, 0x5AE9, 0x5AD6, 0x5AFA, 0x5AFB, 0x5B0C, 0x5B0B, 0x5B16, 0x5B32, 0x5AD0, 0x5B2A, 0x5B36, 0x5B3E, 0x5B43, 0x5B45, 0x5B40, 0x5B51, 0x5B55, 0x5B5A, 0x5B5B, 0x5B65, 0x5B69, 0x5B70, 0x5B73, 0x5B75, 0x5B78, 0x6588, 0x5B7A, 0x5B80, 0x5B83, 0x5BA6, 0x5BB8, 0x5BC3, 0x5BC7, 0x5BC9, 0x5BD4, 0x5BD0, 0x5BE4, 0x5BE6, 0x5BE2, 0x5BDE, 0x5BE5, 0x5BEB, 0x5BF0, 0x5BF6, 0x5BF3, 0x5C05, 0x5C07, 0x5C08, 0x5C0D, 0x5C13, 0x5C20, 0x5C22, 0x5C28, 0x5C38, 0x5C39, 0x5C41, 0x5C46, 0x5C4E, 0x5C53 }, { /* category 54 */ 0x5C50, 0x5C4F, 0x5B71, 0x5C6C, 0x5C6E, 0x4E62, 0x5C76, 0x5C79, 0x5C8C, 0x5C91, 0x5C94, 0x599B, 0x5CAB, 0x5CBB, 0x5CB6, 0x5CBC, 0x5CB7, 0x5CC5, 0x5CBE, 0x5CC7, 0x5CD9, 0x5CE9, 0x5CFD, 0x5CFA, 0x5CED, 0x5D8C, 0x5CEA, 0x5D0B, 0x5D15, 0x5D17, 0x5D5C, 0x5D1F, 0x5D1B, 0x5D11, 0x5D14, 0x5D22, 0x5D1A, 0x5D19, 0x5D18, 0x5D4C, 0x5D52, 0x5D4E, 0x5D4B, 0x5D6C, 0x5D73, 0x5D76, 0x5D87, 0x5D84, 0x5D82, 0x5DA2, 0x5D9D, 0x5DAC, 0x5DAE, 0x5DBD, 0x5D90, 0x5DB7, 0x5DBC, 0x5DC9, 0x5DCD, 0x5DD3, 0x5DD2, 0x5DD6, 0x5DDB, 0x5DEB, 0x5DF2, 0x5DF5, 0x5E0B, 0x5E1A, 0x5E19, 0x5E11, 0x5E1B, 0x5E36, 0x5E37, 0x5E44, 0x5E43, 0x5E40, 0x5E4E, 0x5E57, 0x5E54, 0x5E5F, 0x5E62, 0x5E64, 0x5E47, 0x5E75, 0x5E76, 0x5E7A, 0x9EBC, 0x5E7F, 0x5EA0, 0x5EC1, 0x5EC2, 0x5EC8, 0x5ED0, 0x5ECF }, { /* category 55 */ 0x5ED6, 0x5EE3, 0x5EDD, 0x5EDA, 0x5EDB, 0x5EE2, 0x5EE1, 0x5EE8, 0x5EE9, 0x5EEC, 0x5EF1, 0x5EF3, 0x5EF0, 0x5EF4, 0x5EF8, 0x5EFE, 0x5F03, 0x5F09, 0x5F5D, 0x5F5C, 0x5F0B, 0x5F11, 0x5F16, 0x5F29, 0x5F2D, 0x5F38, 0x5F41, 0x5F48, 0x5F4C, 0x5F4E, 0x5F2F, 0x5F51, 0x5F56, 0x5F57, 0x5F59, 0x5F61, 0x5F6D, 0x5F73, 0x5F77, 0x5F83, 0x5F82, 0x5F7F, 0x5F8A, 0x5F88, 0x5F91, 0x5F87, 0x5F9E, 0x5F99, 0x5F98, 0x5FA0, 0x5FA8, 0x5FAD, 0x5FBC, 0x5FD6, 0x5FFB, 0x5FE4, 0x5FF8, 0x5FF1, 0x5FDD, 0x60B3, 0x5FFF, 0x6021, 0x6060, 0x6019, 0x6010, 0x6029, 0x600E, 0x6031, 0x601B, 0x6015, 0x602B, 0x6026, 0x600F, 0x603A, 0x605A, 0x6041, 0x606A, 0x6077, 0x605F, 0x604A, 0x6046, 0x604D, 0x6063, 0x6043, 0x6064, 0x6042, 0x606C, 0x606B, 0x6059, 0x6081, 0x608D, 0x60E7, 0x6083, 0x609A }, { /* category 56 */ 0x6084, 0x609B, 0x6096, 0x6097, 0x6092, 0x60A7, 0x608B, 0x60E1, 0x60B8, 0x60E0, 0x60D3, 0x60B4, 0x5FF0, 0x60BD, 0x60C6, 0x60B5, 0x60D8, 0x614D, 0x6115, 0x6106, 0x60F6, 0x60F7, 0x6100, 0x60F4, 0x60FA, 0x6103, 0x6121, 0x60FB, 0x60F1, 0x610D, 0x610E, 0x6147, 0x613E, 0x6128, 0x6127, 0x614A, 0x613F, 0x613C, 0x612C, 0x6134, 0x613D, 0x6142, 0x6144, 0x6173, 0x6177, 0x6158, 0x6159, 0x615A, 0x616B, 0x6174, 0x616F, 0x6165, 0x6171, 0x615F, 0x615D, 0x6153, 0x6175, 0x6199, 0x6196, 0x6187, 0x61AC, 0x6194, 0x619A, 0x618A, 0x6191, 0x61AB, 0x61AE, 0x61CC, 0x61CA, 0x61C9, 0x61F7, 0x61C8, 0x61C3, 0x61C6, 0x61BA, 0x61CB, 0x7F79, 0x61CD, 0x61E6, 0x61E3, 0x61F6, 0x61FA, 0x61F4, 0x61FF, 0x61FD, 0x61FC, 0x61FE, 0x6200, 0x6208, 0x6209, 0x620D, 0x620C, 0x6214, 0x621B }, { /* category 57 */ 0x621E, 0x6221, 0x622A, 0x622E, 0x6230, 0x6232, 0x6233, 0x6241, 0x624E, 0x625E, 0x6263, 0x625B, 0x6260, 0x6268, 0x627C, 0x6282, 0x6289, 0x627E, 0x6292, 0x6293, 0x6296, 0x62D4, 0x6283, 0x6294, 0x62D7, 0x62D1, 0x62BB, 0x62CF, 0x62FF, 0x62C6, 0x64D4, 0x62C8, 0x62DC, 0x62CC, 0x62CA, 0x62C2, 0x62C7, 0x629B, 0x62C9, 0x630C, 0x62EE, 0x62F1, 0x6327, 0x6302, 0x6308, 0x62EF, 0x62F5, 0x6350, 0x633E, 0x634D, 0x641C, 0x634F, 0x6396, 0x638E, 0x6380, 0x63AB, 0x6376, 0x63A3, 0x638F, 0x6389, 0x639F, 0x63B5, 0x636B, 0x6369, 0x63BE, 0x63E9, 0x63C0, 0x63C6, 0x63E3, 0x63C9, 0x63D2, 0x63F6, 0x63C4, 0x6416, 0x6434, 0x6406, 0x6413, 0x6426, 0x6436, 0x651D, 0x6417, 0x6428, 0x640F, 0x6467, 0x646F, 0x6476, 0x644E, 0x652A, 0x6495, 0x6493, 0x64A5, 0x64A9, 0x6488, 0x64BC }, { /* category 58 */ 0x64DA, 0x64D2, 0x64C5, 0x64C7, 0x64BB, 0x64D8, 0x64C2, 0x64F1, 0x64E7, 0x8209, 0x64E0, 0x64E1, 0x62AC, 0x64E3, 0x64EF, 0x652C, 0x64F6, 0x64F4, 0x64F2, 0x64FA, 0x6500, 0x64FD, 0x6518, 0x651C, 0x6505, 0x6524, 0x6523, 0x652B, 0x6534, 0x6535, 0x6537, 0x6536, 0x6538, 0x754B, 0x6548, 0x6556, 0x6555, 0x654D, 0x6558, 0x655E, 0x655D, 0x6572, 0x6578, 0x6582, 0x6583, 0x8B8A, 0x659B, 0x659F, 0x65AB, 0x65B7, 0x65C3, 0x65C6, 0x65C1, 0x65C4, 0x65CC, 0x65D2, 0x65DB, 0x65D9, 0x65E0, 0x65E1, 0x65F1, 0x6772, 0x660A, 0x6603, 0x65FB, 0x6773, 0x6635, 0x6636, 0x6634, 0x661C, 0x664F, 0x6644, 0x6649, 0x6641, 0x665E, 0x665D, 0x6664, 0x6667, 0x6668, 0x665F, 0x6662, 0x6670, 0x6683, 0x6688, 0x668E, 0x6689, 0x6684, 0x6698, 0x669D, 0x66C1, 0x66B9, 0x66C9, 0x66BE, 0x66BC }, { /* category 59 */ 0x66C4, 0x66B8, 0x66D6, 0x66DA, 0x66E0, 0x663F, 0x66E6, 0x66E9, 0x66F0, 0x66F5, 0x66F7, 0x670F, 0x6716, 0x671E, 0x6726, 0x6727, 0x9738, 0x672E, 0x673F, 0x6736, 0x6741, 0x6738, 0x6737, 0x6746, 0x675E, 0x6760, 0x6759, 0x6763, 0x6764, 0x6789, 0x6770, 0x67A9, 0x677C, 0x676A, 0x678C, 0x678B, 0x67A6, 0x67A1, 0x6785, 0x67B7, 0x67EF, 0x67B4, 0x67EC, 0x67B3, 0x67E9, 0x67B8, 0x67E4, 0x67DE, 0x67DD, 0x67E2, 0x67EE, 0x67B9, 0x67CE, 0x67C6, 0x67E7, 0x6A9C, 0x681E, 0x6846, 0x6829, 0x6840, 0x684D, 0x6832, 0x684E, 0x68B3, 0x682B, 0x6859, 0x6863, 0x6877, 0x687F, 0x689F, 0x688F, 0x68AD, 0x6894, 0x689D, 0x689B, 0x6883, 0x6AAE, 0x68B9, 0x6874, 0x68B5, 0x68A0, 0x68BA, 0x690F, 0x688D, 0x687E, 0x6901, 0x68CA, 0x6908, 0x68D8, 0x6922, 0x6926, 0x68E1, 0x690C, 0x68CD }, { /* category 60 */ 0x68D4, 0x68E7, 0x68D5, 0x6936, 0x6912, 0x6904, 0x68D7, 0x68E3, 0x6925, 0x68F9, 0x68E0, 0x68EF, 0x6928, 0x692A, 0x691A, 0x6923, 0x6921, 0x68C6, 0x6979, 0x6977, 0x695C, 0x6978, 0x696B, 0x6954, 0x697E, 0x696E, 0x6939, 0x6974, 0x693D, 0x6959, 0x6930, 0x6961, 0x695E, 0x695D, 0x6981, 0x696A, 0x69B2, 0x69AE, 0x69D0, 0x69BF, 0x69C1, 0x69D3, 0x69BE, 0x69CE, 0x5BE8, 0x69CA, 0x69DD, 0x69BB, 0x69C3, 0x69A7, 0x6A2E, 0x6991, 0x69A0, 0x699C, 0x6995, 0x69B4, 0x69DE, 0x69E8, 0x6A02, 0x6A1B, 0x69FF, 0x6B0A, 0x69F9, 0x69F2, 0x69E7, 0x6A05, 0x69B1, 0x6A1E, 0x69ED, 0x6A14, 0x69EB, 0x6A0A, 0x6A12, 0x6AC1, 0x6A23, 0x6A13, 0x6A44, 0x6A0C, 0x6A72, 0x6A36, 0x6A78, 0x6A47, 0x6A62, 0x6A59, 0x6A66, 0x6A48, 0x6A38, 0x6A22, 0x6A90, 0x6A8D, 0x6AA0, 0x6A84, 0x6AA2, 0x6AA3 }, { /* category 61 */ 0x6A97, 0x8617, 0x6ABB, 0x6AC3, 0x6AC2, 0x6AB8, 0x6AB3, 0x6AAC, 0x6ADE, 0x6AD1, 0x6ADF, 0x6AAA, 0x6ADA, 0x6AEA, 0x6AFB, 0x6B05, 0x8616, 0x6AFA, 0x6B12, 0x6B16, 0x9B31, 0x6B1F, 0x6B38, 0x6B37, 0x76DC, 0x6B39, 0x98EE, 0x6B47, 0x6B43, 0x6B49, 0x6B50, 0x6B59, 0x6B54, 0x6B5B, 0x6B5F, 0x6B61, 0x6B78, 0x6B79, 0x6B7F, 0x6B80, 0x6B84, 0x6B83, 0x6B8D, 0x6B98, 0x6B95, 0x6B9E, 0x6BA4, 0x6BAA, 0x6BAB, 0x6BAF, 0x6BB2, 0x6BB1, 0x6BB3, 0x6BB7, 0x6BBC, 0x6BC6, 0x6BCB, 0x6BD3, 0x6BDF, 0x6BEC, 0x6BEB, 0x6BF3, 0x6BEF, 0x9EBE, 0x6C08, 0x6C13, 0x6C14, 0x6C1B, 0x6C24, 0x6C23, 0x6C5E, 0x6C55, 0x6C62, 0x6C6A, 0x6C82, 0x6C8D, 0x6C9A, 0x6C81, 0x6C9B, 0x6C7E, 0x6C68, 0x6C73, 0x6C92, 0x6C90, 0x6CC4, 0x6CF1, 0x6CD3, 0x6CBD, 0x6CD7, 0x6CC5, 0x6CDD, 0x6CAE, 0x6CB1, 0x6CBE }, { /* category 62 */ 0x6CBA, 0x6CDB, 0x6CEF, 0x6CD9, 0x6CEA, 0x6D1F, 0x884D, 0x6D36, 0x6D2B, 0x6D3D, 0x6D38, 0x6D19, 0x6D35, 0x6D33, 0x6D12, 0x6D0C, 0x6D63, 0x6D93, 0x6D64, 0x6D5A, 0x6D79, 0x6D59, 0x6D8E, 0x6D95, 0x6FE4, 0x6D85, 0x6DF9, 0x6E15, 0x6E0A, 0x6DB5, 0x6DC7, 0x6DE6, 0x6DB8, 0x6DC6, 0x6DEC, 0x6DDE, 0x6DCC, 0x6DE8, 0x6DD2, 0x6DC5, 0x6DFA, 0x6DD9, 0x6DE4, 0x6DD5, 0x6DEA, 0x6DEE, 0x6E2D, 0x6E6E, 0x6E2E, 0x6E19, 0x6E72, 0x6E5F, 0x6E3E, 0x6E23, 0x6E6B, 0x6E2B, 0x6E76, 0x6E4D, 0x6E1F, 0x6E43, 0x6E3A, 0x6E4E, 0x6E24, 0x6EFF, 0x6E1D, 0x6E38, 0x6E82, 0x6EAA, 0x6E98, 0x6EC9, 0x6EB7, 0x6ED3, 0x6EBD, 0x6EAF, 0x6EC4, 0x6EB2, 0x6ED4, 0x6ED5, 0x6E8F, 0x6EA5, 0x6EC2, 0x6E9F, 0x6F41, 0x6F11, 0x704C, 0x6EEC, 0x6EF8, 0x6EFE, 0x6F3F, 0x6EF2, 0x6F31, 0x6EEF, 0x6F32, 0x6ECC }, { /* category 63 */ 0x6F3E, 0x6F13, 0x6EF7, 0x6F86, 0x6F7A, 0x6F78, 0x6F81, 0x6F80, 0x6F6F, 0x6F5B, 0x6FF3, 0x6F6D, 0x6F82, 0x6F7C, 0x6F58, 0x6F8E, 0x6F91, 0x6FC2, 0x6F66, 0x6FB3, 0x6FA3, 0x6FA1, 0x6FA4, 0x6FB9, 0x6FC6, 0x6FAA, 0x6FDF, 0x6FD5, 0x6FEC, 0x6FD4, 0x6FD8, 0x6FF1, 0x6FEE, 0x6FDB, 0x7009, 0x700B, 0x6FFA, 0x7011, 0x7001, 0x700F, 0x6FFE, 0x701B, 0x701A, 0x6F74, 0x701D, 0x7018, 0x701F, 0x7030, 0x703E, 0x7032, 0x7051, 0x7063, 0x7099, 0x7092, 0x70AF, 0x70F1, 0x70AC, 0x70B8, 0x70B3, 0x70AE, 0x70DF, 0x70CB, 0x70DD, 0x70D9, 0x7109, 0x70FD, 0x711C, 0x7119, 0x7165, 0x7155, 0x7188, 0x7166, 0x7162, 0x714C, 0x7156, 0x716C, 0x718F, 0x71FB, 0x7184, 0x7195, 0x71A8, 0x71AC, 0x71D7, 0x71B9, 0x71BE, 0x71D2, 0x71C9, 0x71D4, 0x71CE, 0x71E0, 0x71EC, 0x71E7, 0x71F5, 0x71FC }, { /* category 64 */ 0x71F9, 0x71FF, 0x720D, 0x7210, 0x721B, 0x7228, 0x722D, 0x722C, 0x7230, 0x7232, 0x723B, 0x723C, 0x723F, 0x7240, 0x7246, 0x724B, 0x7258, 0x7274, 0x727E, 0x7282, 0x7281, 0x7287, 0x7292, 0x7296, 0x72A2, 0x72A7, 0x72B9, 0x72B2, 0x72C3, 0x72C6, 0x72C4, 0x72CE, 0x72D2, 0x72E2, 0x72E0, 0x72E1, 0x72F9, 0x72F7, 0x500F, 0x7317, 0x730A, 0x731C, 0x7316, 0x731D, 0x7334, 0x732F, 0x7329, 0x7325, 0x733E, 0x734E, 0x734F, 0x9ED8, 0x7357, 0x736A, 0x7368, 0x7370, 0x7378, 0x7375, 0x737B, 0x737A, 0x73C8, 0x73B3, 0x73CE, 0x73BB, 0x73C0, 0x73E5, 0x73EE, 0x73DE, 0x74A2, 0x7405, 0x746F, 0x7425, 0x73F8, 0x7432, 0x743A, 0x7455, 0x743F, 0x745F, 0x7459, 0x7441, 0x745C, 0x7469, 0x7470, 0x7463, 0x746A, 0x7476, 0x747E, 0x748B, 0x749E, 0x74A7, 0x74CA, 0x74CF, 0x74D4, 0x73F1 }, { /* category 65 */ 0x74E0, 0x74E3, 0x74E7, 0x74E9, 0x74EE, 0x74F2, 0x74F0, 0x74F1, 0x74F8, 0x74F7, 0x7504, 0x7503, 0x7505, 0x750C, 0x750E, 0x750D, 0x7515, 0x7513, 0x751E, 0x7526, 0x752C, 0x753C, 0x7544, 0x754D, 0x754A, 0x7549, 0x755B, 0x7546, 0x755A, 0x7569, 0x7564, 0x7567, 0x756B, 0x756D, 0x7578, 0x7576, 0x7586, 0x7587, 0x7574, 0x758A, 0x7589, 0x7582, 0x7594, 0x759A, 0x759D, 0x75A5, 0x75A3, 0x75C2, 0x75B3, 0x75C3, 0x75B5, 0x75BD, 0x75B8, 0x75BC, 0x75B1, 0x75CD, 0x75CA, 0x75D2, 0x75D9, 0x75E3, 0x75DE, 0x75FE, 0x75FF, 0x75FC, 0x7601, 0x75F0, 0x75FA, 0x75F2, 0x75F3, 0x760B, 0x760D, 0x7609, 0x761F, 0x7627, 0x7620, 0x7621, 0x7622, 0x7624, 0x7634, 0x7630, 0x763B, 0x7647, 0x7648, 0x7646, 0x765C, 0x7658, 0x7661, 0x7662, 0x7668, 0x7669, 0x766A, 0x7667, 0x766C, 0x7670 }, { /* category 66 */ 0x7672, 0x7676, 0x7678, 0x767C, 0x7680, 0x7683, 0x7688, 0x768B, 0x768E, 0x7696, 0x7693, 0x7699, 0x769A, 0x76B0, 0x76B4, 0x76B8, 0x76B9, 0x76BA, 0x76C2, 0x76CD, 0x76D6, 0x76D2, 0x76DE, 0x76E1, 0x76E5, 0x76E7, 0x76EA, 0x862F, 0x76FB, 0x7708, 0x7707, 0x7704, 0x7729, 0x7724, 0x771E, 0x7725, 0x7726, 0x771B, 0x7737, 0x7738, 0x7747, 0x775A, 0x7768, 0x776B, 0x775B, 0x7765, 0x777F, 0x777E, 0x7779, 0x778E, 0x778B, 0x7791, 0x77A0, 0x779E, 0x77B0, 0x77B6, 0x77B9, 0x77BF, 0x77BC, 0x77BD, 0x77BB, 0x77C7, 0x77CD, 0x77D7, 0x77DA, 0x77DC, 0x77E3, 0x77EE, 0x77FC, 0x780C, 0x7812, 0x7926, 0x7820, 0x792A, 0x7845, 0x788E, 0x7874, 0x7886, 0x787C, 0x789A, 0x788C, 0x78A3, 0x78B5, 0x78AA, 0x78AF, 0x78D1, 0x78C6, 0x78CB, 0x78D4, 0x78BE, 0x78BC, 0x78C5, 0x78CA, 0x78EC }, { /* category 67 */ 0x78E7, 0x78DA, 0x78FD, 0x78F4, 0x7907, 0x7912, 0x7911, 0x7919, 0x792C, 0x792B, 0x7940, 0x7960, 0x7957, 0x795F, 0x795A, 0x7955, 0x7953, 0x797A, 0x797F, 0x798A, 0x799D, 0x79A7, 0x9F4B, 0x79AA, 0x79AE, 0x79B3, 0x79B9, 0x79BA, 0x79C9, 0x79D5, 0x79E7, 0x79EC, 0x79E1, 0x79E3, 0x7A08, 0x7A0D, 0x7A18, 0x7A19, 0x7A20, 0x7A1F, 0x7980, 0x7A31, 0x7A3B, 0x7A3E, 0x7A37, 0x7A43, 0x7A57, 0x7A49, 0x7A61, 0x7A62, 0x7A69, 0x9F9D, 0x7A70, 0x7A79, 0x7A7D, 0x7A88, 0x7A97, 0x7A95, 0x7A98, 0x7A96, 0x7AA9, 0x7AC8, 0x7AB0, 0x7AB6, 0x7AC5, 0x7AC4, 0x7ABF, 0x9083, 0x7AC7, 0x7ACA, 0x7ACD, 0x7ACF, 0x7AD5, 0x7AD3, 0x7AD9, 0x7ADA, 0x7ADD, 0x7AE1, 0x7AE2, 0x7AE6, 0x7AED, 0x7AF0, 0x7B02, 0x7B0F, 0x7B0A, 0x7B06, 0x7B33, 0x7B18, 0x7B19, 0x7B1E, 0x7B35, 0x7B28, 0x7B36, 0x7B50 }, { /* category 68 */ 0x7B7A, 0x7B04, 0x7B4D, 0x7B0B, 0x7B4C, 0x7B45, 0x7B75, 0x7B65, 0x7B74, 0x7B67, 0x7B70, 0x7B71, 0x7B6C, 0x7B6E, 0x7B9D, 0x7B98, 0x7B9F, 0x7B8D, 0x7B9C, 0x7B9A, 0x7B8B, 0x7B92, 0x7B8F, 0x7B5D, 0x7B99, 0x7BCB, 0x7BC1, 0x7BCC, 0x7BCF, 0x7BB4, 0x7BC6, 0x7BDD, 0x7BE9, 0x7C11, 0x7C14, 0x7BE6, 0x7BE5, 0x7C60, 0x7C00, 0x7C07, 0x7C13, 0x7BF3, 0x7BF7, 0x7C17, 0x7C0D, 0x7BF6, 0x7C23, 0x7C27, 0x7C2A, 0x7C1F, 0x7C37, 0x7C2B, 0x7C3D, 0x7C4C, 0x7C43, 0x7C54, 0x7C4F, 0x7C40, 0x7C50, 0x7C58, 0x7C5F, 0x7C64, 0x7C56, 0x7C65, 0x7C6C, 0x7C75, 0x7C83, 0x7C90, 0x7CA4, 0x7CAD, 0x7CA2, 0x7CAB, 0x7CA1, 0x7CA8, 0x7CB3, 0x7CB2, 0x7CB1, 0x7CAE, 0x7CB9, 0x7CBD, 0x7CC0, 0x7CC5, 0x7CC2, 0x7CD8, 0x7CD2, 0x7CDC, 0x7CE2, 0x9B3B, 0x7CEF, 0x7CF2, 0x7CF4, 0x7CF6, 0x7CFA, 0x7D06 }, { /* category 69 */ 0x7D02, 0x7D1C, 0x7D15, 0x7D0A, 0x7D45, 0x7D4B, 0x7D2E, 0x7D32, 0x7D3F, 0x7D35, 0x7D46, 0x7D73, 0x7D56, 0x7D4E, 0x7D72, 0x7D68, 0x7D6E, 0x7D4F, 0x7D63, 0x7D93, 0x7D89, 0x7D5B, 0x7D8F, 0x7D7D, 0x7D9B, 0x7DBA, 0x7DAE, 0x7DA3, 0x7DB5, 0x7DC7, 0x7DBD, 0x7DAB, 0x7E3D, 0x7DA2, 0x7DAF, 0x7DDC, 0x7DB8, 0x7D9F, 0x7DB0, 0x7DD8, 0x7DDD, 0x7DE4, 0x7DDE, 0x7DFB, 0x7DF2, 0x7DE1, 0x7E05, 0x7E0A, 0x7E23, 0x7E21, 0x7E12, 0x7E31, 0x7E1F, 0x7E09, 0x7E0B, 0x7E22, 0x7E46, 0x7E66, 0x7E3B, 0x7E35, 0x7E39, 0x7E43, 0x7E37, 0x7E32, 0x7E3A, 0x7E67, 0x7E5D, 0x7E56, 0x7E5E, 0x7E59, 0x7E5A, 0x7E79, 0x7E6A, 0x7E69, 0x7E7C, 0x7E7B, 0x7E83, 0x7DD5, 0x7E7D, 0x8FAE, 0x7E7F, 0x7E88, 0x7E89, 0x7E8C, 0x7E92, 0x7E90, 0x7E93, 0x7E94, 0x7E96, 0x7E8E, 0x7E9B, 0x7E9C, 0x7F38, 0x7F3A }, { /* category 70 */ 0x7F45, 0x7F4C, 0x7F4D, 0x7F4E, 0x7F50, 0x7F51, 0x7F55, 0x7F54, 0x7F58, 0x7F5F, 0x7F60, 0x7F68, 0x7F69, 0x7F67, 0x7F78, 0x7F82, 0x7F86, 0x7F83, 0x7F88, 0x7F87, 0x7F8C, 0x7F94, 0x7F9E, 0x7F9D, 0x7F9A, 0x7FA3, 0x7FAF, 0x7FB2, 0x7FB9, 0x7FAE, 0x7FB6, 0x7FB8, 0x8B71, 0x7FC5, 0x7FC6, 0x7FCA, 0x7FD5, 0x7FD4, 0x7FE1, 0x7FE6, 0x7FE9, 0x7FF3, 0x7FF9, 0x98DC, 0x8006, 0x8004, 0x800B, 0x8012, 0x8018, 0x8019, 0x801C, 0x8021, 0x8028, 0x803F, 0x803B, 0x804A, 0x8046, 0x8052, 0x8058, 0x805A, 0x805F, 0x8062, 0x8068, 0x8073, 0x8072, 0x8070, 0x8076, 0x8079, 0x807D, 0x807F, 0x8084, 0x8086, 0x8085, 0x809B, 0x8093, 0x809A, 0x80AD, 0x5190, 0x80AC, 0x80DB, 0x80E5, 0x80D9, 0x80DD, 0x80C4, 0x80DA, 0x80D6, 0x8109, 0x80EF, 0x80F1, 0x811B, 0x8129, 0x8123, 0x812F, 0x814B }, { /* category 71 */ 0x968B, 0x8146, 0x813E, 0x8153, 0x8151, 0x80FC, 0x8171, 0x816E, 0x8165, 0x8166, 0x8174, 0x8183, 0x8188, 0x818A, 0x8180, 0x8182, 0x81A0, 0x8195, 0x81A4, 0x81A3, 0x815F, 0x8193, 0x81A9, 0x81B0, 0x81B5, 0x81BE, 0x81B8, 0x81BD, 0x81C0, 0x81C2, 0x81BA, 0x81C9, 0x81CD, 0x81D1, 0x81D9, 0x81D8, 0x81C8, 0x81DA, 0x81DF, 0x81E0, 0x81E7, 0x81FA, 0x81FB, 0x81FE, 0x8201, 0x8202, 0x8205, 0x8207, 0x820A, 0x820D, 0x8210, 0x8216, 0x8229, 0x822B, 0x8238, 0x8233, 0x8240, 0x8259, 0x8258, 0x825D, 0x825A, 0x825F, 0x8264, 0x8262, 0x8268, 0x826A, 0x826B, 0x822E, 0x8271, 0x8277, 0x8278, 0x827E, 0x828D, 0x8292, 0x82AB, 0x829F, 0x82BB, 0x82AC, 0x82E1, 0x82E3, 0x82DF, 0x82D2, 0x82F4, 0x82F3, 0x82FA, 0x8393, 0x8303, 0x82FB, 0x82F9, 0x82DE, 0x8306, 0x82DC, 0x8309, 0x82D9 }, { /* category 72 */ 0x8335, 0x8334, 0x8316, 0x8332, 0x8331, 0x8340, 0x8339, 0x8350, 0x8345, 0x832F, 0x832B, 0x8317, 0x8318, 0x8385, 0x839A, 0x83AA, 0x839F, 0x83A2, 0x8396, 0x8323, 0x838E, 0x8387, 0x838A, 0x837C, 0x83B5, 0x8373, 0x8375, 0x83A0, 0x8389, 0x83A8, 0x83F4, 0x8413, 0x83EB, 0x83CE, 0x83FD, 0x8403, 0x83D8, 0x840B, 0x83C1, 0x83F7, 0x8407, 0x83E0, 0x83F2, 0x840D, 0x8422, 0x8420, 0x83BD, 0x8438, 0x8506, 0x83FB, 0x846D, 0x842A, 0x843C, 0x855A, 0x8484, 0x8477, 0x846B, 0x84AD, 0x846E, 0x8482, 0x8469, 0x8446, 0x842C, 0x846F, 0x8479, 0x8435, 0x84CA, 0x8462, 0x84B9, 0x84BF, 0x849F, 0x84D9, 0x84CD, 0x84BB, 0x84DA, 0x84D0, 0x84C1, 0x84C6, 0x84D6, 0x84A1, 0x8521, 0x84FF, 0x84F4, 0x8517, 0x8518, 0x852C, 0x851F, 0x8515, 0x8514, 0x84FC, 0x8540, 0x8563, 0x8558, 0x8548 }, { /* category 73 */ 0x8541, 0x8602, 0x854B, 0x8555, 0x8580, 0x85A4, 0x8588, 0x8591, 0x858A, 0x85A8, 0x856D, 0x8594, 0x859B, 0x85EA, 0x8587, 0x859C, 0x8577, 0x857E, 0x8590, 0x85C9, 0x85BA, 0x85CF, 0x85B9, 0x85D0, 0x85D5, 0x85DD, 0x85E5, 0x85DC, 0x85F9, 0x860A, 0x8613, 0x860B, 0x85FE, 0x85FA, 0x8606, 0x8622, 0x861A, 0x8630, 0x863F, 0x864D, 0x4E55, 0x8654, 0x865F, 0x8667, 0x8671, 0x8693, 0x86A3, 0x86A9, 0x86AA, 0x868B, 0x868C, 0x86B6, 0x86AF, 0x86C4, 0x86C6, 0x86B0, 0x86C9, 0x8823, 0x86AB, 0x86D4, 0x86DE, 0x86E9, 0x86EC, 0x86DF, 0x86DB, 0x86EF, 0x8712, 0x8706, 0x8708, 0x8700, 0x8703, 0x86FB, 0x8711, 0x8709, 0x870D, 0x86F9, 0x870A, 0x8734, 0x873F, 0x8737, 0x873B, 0x8725, 0x8729, 0x871A, 0x8760, 0x875F, 0x8778, 0x874C, 0x874E, 0x8774, 0x8757, 0x8768, 0x876E, 0x8759 }, { /* category 74 */ 0x8753, 0x8763, 0x876A, 0x8805, 0x87A2, 0x879F, 0x8782, 0x87AF, 0x87CB, 0x87BD, 0x87C0, 0x87D0, 0x96D6, 0x87AB, 0x87C4, 0x87B3, 0x87C7, 0x87C6, 0x87BB, 0x87EF, 0x87F2, 0x87E0, 0x880F, 0x880D, 0x87FE, 0x87F6, 0x87F7, 0x880E, 0x87D2, 0x8811, 0x8816, 0x8815, 0x8822, 0x8821, 0x8831, 0x8836, 0x8839, 0x8827, 0x883B, 0x8844, 0x8842, 0x8852, 0x8859, 0x885E, 0x8862, 0x886B, 0x8881, 0x887E, 0x889E, 0x8875, 0x887D, 0x88B5, 0x8872, 0x8882, 0x8897, 0x8892, 0x88AE, 0x8899, 0x88A2, 0x888D, 0x88A4, 0x88B0, 0x88BF, 0x88B1, 0x88C3, 0x88C4, 0x88D4, 0x88D8, 0x88D9, 0x88DD, 0x88F9, 0x8902, 0x88FC, 0x88F4, 0x88E8, 0x88F2, 0x8904, 0x890C, 0x890A, 0x8913, 0x8943, 0x891E, 0x8925, 0x892A, 0x892B, 0x8941, 0x8944, 0x893B, 0x8936, 0x8938, 0x894C, 0x891D, 0x8960, 0x895E }, { /* category 75 */ 0x8966, 0x8964, 0x896D, 0x896A, 0x896F, 0x8974, 0x8977, 0x897E, 0x8983, 0x8988, 0x898A, 0x8993, 0x8998, 0x89A1, 0x89A9, 0x89A6, 0x89AC, 0x89AF, 0x89B2, 0x89BA, 0x89BD, 0x89BF, 0x89C0, 0x89DA, 0x89DC, 0x89DD, 0x89E7, 0x89F4, 0x89F8, 0x8A03, 0x8A16, 0x8A10, 0x8A0C, 0x8A1B, 0x8A1D, 0x8A25, 0x8A36, 0x8A41, 0x8A5B, 0x8A52, 0x8A46, 0x8A48, 0x8A7C, 0x8A6D, 0x8A6C, 0x8A62, 0x8A85, 0x8A82, 0x8A84, 0x8AA8, 0x8AA1, 0x8A91, 0x8AA5, 0x8AA6, 0x8A9A, 0x8AA3, 0x8AC4, 0x8ACD, 0x8AC2, 0x8ADA, 0x8AEB, 0x8AF3, 0x8AE7, 0x8AE4, 0x8AF1, 0x8B14, 0x8AE0, 0x8AE2, 0x8AF7, 0x8ADE, 0x8ADB, 0x8B0C, 0x8B07, 0x8B1A, 0x8AE1, 0x8B16, 0x8B10, 0x8B17, 0x8B20, 0x8B33, 0x97AB, 0x8B26, 0x8B2B, 0x8B3E, 0x8B28, 0x8B41, 0x8B4C, 0x8B4F, 0x8B4E, 0x8B49, 0x8B56, 0x8B5B, 0x8B5A, 0x8B6B }, { /* category 76 */ 0x8B5F, 0x8B6C, 0x8B6F, 0x8B74, 0x8B7D, 0x8B80, 0x8B8C, 0x8B8E, 0x8B92, 0x8B93, 0x8B96, 0x8B99, 0x8B9A, 0x8C3A, 0x8C41, 0x8C3F, 0x8C48, 0x8C4C, 0x8C4E, 0x8C50, 0x8C55, 0x8C62, 0x8C6C, 0x8C78, 0x8C7A, 0x8C82, 0x8C89, 0x8C85, 0x8C8A, 0x8C8D, 0x8C8E, 0x8C94, 0x8C7C, 0x8C98, 0x621D, 0x8CAD, 0x8CAA, 0x8CBD, 0x8CB2, 0x8CB3, 0x8CAE, 0x8CB6, 0x8CC8, 0x8CC1, 0x8CE4, 0x8CE3, 0x8CDA, 0x8CFD, 0x8CFA, 0x8CFB, 0x8D04, 0x8D05, 0x8D0A, 0x8D07, 0x8D0F, 0x8D0D, 0x8D10, 0x9F4E, 0x8D13, 0x8CCD, 0x8D14, 0x8D16, 0x8D67, 0x8D6D, 0x8D71, 0x8D73, 0x8D81, 0x8D99, 0x8DC2, 0x8DBE, 0x8DBA, 0x8DCF, 0x8DDA, 0x8DD6, 0x8DCC, 0x8DDB, 0x8DCB, 0x8DEA, 0x8DEB, 0x8DDF, 0x8DE3, 0x8DFC, 0x8E08, 0x8E09, 0x8DFF, 0x8E1D, 0x8E1E, 0x8E10, 0x8E1F, 0x8E42, 0x8E35, 0x8E30, 0x8E34, 0x8E4A }, { /* category 77 */ 0x8E47, 0x8E49, 0x8E4C, 0x8E50, 0x8E48, 0x8E59, 0x8E64, 0x8E60, 0x8E2A, 0x8E63, 0x8E55, 0x8E76, 0x8E72, 0x8E7C, 0x8E81, 0x8E87, 0x8E85, 0x8E84, 0x8E8B, 0x8E8A, 0x8E93, 0x8E91, 0x8E94, 0x8E99, 0x8EAA, 0x8EA1, 0x8EAC, 0x8EB0, 0x8EC6, 0x8EB1, 0x8EBE, 0x8EC5, 0x8EC8, 0x8ECB, 0x8EDB, 0x8EE3, 0x8EFC, 0x8EFB, 0x8EEB, 0x8EFE, 0x8F0A, 0x8F05, 0x8F15, 0x8F12, 0x8F19, 0x8F13, 0x8F1C, 0x8F1F, 0x8F1B, 0x8F0C, 0x8F26, 0x8F33, 0x8F3B, 0x8F39, 0x8F45, 0x8F42, 0x8F3E, 0x8F4C, 0x8F49, 0x8F46, 0x8F4E, 0x8F57, 0x8F5C, 0x8F62, 0x8F63, 0x8F64, 0x8F9C, 0x8F9F, 0x8FA3, 0x8FAD, 0x8FAF, 0x8FB7, 0x8FDA, 0x8FE5, 0x8FE2, 0x8FEA, 0x8FEF, 0x9087, 0x8FF4, 0x9005, 0x8FF9, 0x8FFA, 0x9011, 0x9015, 0x9021, 0x900D, 0x901E, 0x9016, 0x900B, 0x9027, 0x9036, 0x9035, 0x9039, 0x8FF8 }, { /* category 78 */ 0x904F, 0x9050, 0x9051, 0x9052, 0x900E, 0x9049, 0x903E, 0x9056, 0x9058, 0x905E, 0x9068, 0x906F, 0x9076, 0x96A8, 0x9072, 0x9082, 0x907D, 0x9081, 0x9080, 0x908A, 0x9089, 0x908F, 0x90A8, 0x90AF, 0x90B1, 0x90B5, 0x90E2, 0x90E4, 0x6248, 0x90DB, 0x9102, 0x9112, 0x9119, 0x9132, 0x9130, 0x914A, 0x9156, 0x9158, 0x9163, 0x9165, 0x9169, 0x9173, 0x9172, 0x918B, 0x9189, 0x9182, 0x91A2, 0x91AB, 0x91AF, 0x91AA, 0x91B5, 0x91B4, 0x91BA, 0x91C0, 0x91C1, 0x91C9, 0x91CB, 0x91D0, 0x91D6, 0x91DF, 0x91E1, 0x91DB, 0x91FC, 0x91F5, 0x91F6, 0x921E, 0x91FF, 0x9214, 0x922C, 0x9215, 0x9211, 0x925E, 0x9257, 0x9245, 0x9249, 0x9264, 0x9248, 0x9295, 0x923F, 0x924B, 0x9250, 0x929C, 0x9296, 0x9293, 0x929B, 0x925A, 0x92CF, 0x92B9, 0x92B7, 0x92E9, 0x930F, 0x92FA, 0x9344, 0x932E }, { /* category 79 */ 0x9319, 0x9322, 0x931A, 0x9323, 0x933A, 0x9335, 0x933B, 0x935C, 0x9360, 0x937C, 0x936E, 0x9356, 0x93B0, 0x93AC, 0x93AD, 0x9394, 0x93B9, 0x93D6, 0x93D7, 0x93E8, 0x93E5, 0x93D8, 0x93C3, 0x93DD, 0x93D0, 0x93C8, 0x93E4, 0x941A, 0x9414, 0x9413, 0x9403, 0x9407, 0x9410, 0x9436, 0x942B, 0x9435, 0x9421, 0x943A, 0x9441, 0x9452, 0x9444, 0x945B, 0x9460, 0x9462, 0x945E, 0x946A, 0x9229, 0x9470, 0x9475, 0x9477, 0x947D, 0x945A, 0x947C, 0x947E, 0x9481, 0x947F, 0x9582, 0x9587, 0x958A, 0x9594, 0x9596, 0x9598, 0x9599, 0x95A0, 0x95A8, 0x95A7, 0x95AD, 0x95BC, 0x95BB, 0x95B9, 0x95BE, 0x95CA, 0x6FF6, 0x95C3, 0x95CD, 0x95CC, 0x95D5, 0x95D4, 0x95D6, 0x95DC, 0x95E1, 0x95E5, 0x95E2, 0x9621, 0x9628, 0x962E, 0x962F, 0x9642, 0x964C, 0x964F, 0x964B, 0x9677, 0x965C, 0x965E }, { /* category 80 */ 0x965D, 0x965F, 0x9666, 0x9672, 0x966C, 0x968D, 0x9698, 0x9695, 0x9697, 0x96AA, 0x96A7, 0x96B1, 0x96B2, 0x96B0, 0x96B4, 0x96B6, 0x96B8, 0x96B9, 0x96CE, 0x96CB, 0x96C9, 0x96CD, 0x894D, 0x96DC, 0x970D, 0x96D5, 0x96F9, 0x9704, 0x9706, 0x9708, 0x9713, 0x970E, 0x9711, 0x970F, 0x9716, 0x9719, 0x9724, 0x972A, 0x9730, 0x9739, 0x973D, 0x973E, 0x9744, 0x9746, 0x9748, 0x9742, 0x9749, 0x975C, 0x9760, 0x9764, 0x9766, 0x9768, 0x52D2, 0x976B, 0x9771, 0x9779, 0x9785, 0x977C, 0x9781, 0x977A, 0x9786, 0x978B, 0x978F, 0x9790, 0x979C, 0x97A8, 0x97A6, 0x97A3, 0x97B3, 0x97B4, 0x97C3, 0x97C6, 0x97C8, 0x97CB, 0x97DC, 0x97ED, 0x9F4F, 0x97F2, 0x7ADF, 0x97F6, 0x97F5, 0x980F, 0x980C, 0x9838, 0x9824, 0x9821, 0x9837, 0x983D, 0x9846, 0x984F, 0x984B, 0x986B, 0x986F, 0x9870 }, { /* category 81 */ 0x9871, 0x9874, 0x9873, 0x98AA, 0x98AF, 0x98B1, 0x98B6, 0x98C4, 0x98C3, 0x98C6, 0x98E9, 0x98EB, 0x9903, 0x9909, 0x9912, 0x9914, 0x9918, 0x9921, 0x991D, 0x991E, 0x9924, 0x9920, 0x992C, 0x992E, 0x993D, 0x993E, 0x9942, 0x9949, 0x9945, 0x9950, 0x994B, 0x9951, 0x9952, 0x994C, 0x9955, 0x9997, 0x9998, 0x99A5, 0x99AD, 0x99AE, 0x99BC, 0x99DF, 0x99DB, 0x99DD, 0x99D8, 0x99D1, 0x99ED, 0x99EE, 0x99F1, 0x99F2, 0x99FB, 0x99F8, 0x9A01, 0x9A0F, 0x9A05, 0x99E2, 0x9A19, 0x9A2B, 0x9A37, 0x9A45, 0x9A42, 0x9A40, 0x9A43, 0x9A3E, 0x9A55, 0x9A4D, 0x9A5B, 0x9A57, 0x9A5F, 0x9A62, 0x9A65, 0x9A64, 0x9A69, 0x9A6B, 0x9A6A, 0x9AAD, 0x9AB0, 0x9ABC, 0x9AC0, 0x9ACF, 0x9AD1, 0x9AD3, 0x9AD4, 0x9ADE, 0x9ADF, 0x9AE2, 0x9AE3, 0x9AE6, 0x9AEF, 0x9AEB, 0x9AEE, 0x9AF4, 0x9AF1, 0x9AF7 }, { /* category 82 */ 0x9AFB, 0x9B06, 0x9B18, 0x9B1A, 0x9B1F, 0x9B22, 0x9B23, 0x9B25, 0x9B27, 0x9B28, 0x9B29, 0x9B2A, 0x9B2E, 0x9B2F, 0x9B32, 0x9B44, 0x9B43, 0x9B4F, 0x9B4D, 0x9B4E, 0x9B51, 0x9B58, 0x9B74, 0x9B93, 0x9B83, 0x9B91, 0x9B96, 0x9B97, 0x9B9F, 0x9BA0, 0x9BA8, 0x9BB4, 0x9BC0, 0x9BCA, 0x9BB9, 0x9BC6, 0x9BCF, 0x9BD1, 0x9BD2, 0x9BE3, 0x9BE2, 0x9BE4, 0x9BD4, 0x9BE1, 0x9C3A, 0x9BF2, 0x9BF1, 0x9BF0, 0x9C15, 0x9C14, 0x9C09, 0x9C13, 0x9C0C, 0x9C06, 0x9C08, 0x9C12, 0x9C0A, 0x9C04, 0x9C2E, 0x9C1B, 0x9C25, 0x9C24, 0x9C21, 0x9C30, 0x9C47, 0x9C32, 0x9C46, 0x9C3E, 0x9C5A, 0x9C60, 0x9C67, 0x9C76, 0x9C78, 0x9CE7, 0x9CEC, 0x9CF0, 0x9D09, 0x9D08, 0x9CEB, 0x9D03, 0x9D06, 0x9D2A, 0x9D26, 0x9DAF, 0x9D23, 0x9D1F, 0x9D44, 0x9D15, 0x9D12, 0x9D41, 0x9D3F, 0x9D3E, 0x9D46, 0x9D48 }, { /* category 83 */ 0x9D5D, 0x9D5E, 0x9D64, 0x9D51, 0x9D50, 0x9D59, 0x9D72, 0x9D89, 0x9D87, 0x9DAB, 0x9D6F, 0x9D7A, 0x9D9A, 0x9DA4, 0x9DA9, 0x9DB2, 0x9DC4, 0x9DC1, 0x9DBB, 0x9DB8, 0x9DBA, 0x9DC6, 0x9DCF, 0x9DC2, 0x9DD9, 0x9DD3, 0x9DF8, 0x9DE6, 0x9DED, 0x9DEF, 0x9DFD, 0x9E1A, 0x9E1B, 0x9E1E, 0x9E75, 0x9E79, 0x9E7D, 0x9E81, 0x9E88, 0x9E8B, 0x9E8C, 0x9E92, 0x9E95, 0x9E91, 0x9E9D, 0x9EA5, 0x9EA9, 0x9EB8, 0x9EAA, 0x9EAD, 0x9761, 0x9ECC, 0x9ECE, 0x9ECF, 0x9ED0, 0x9ED4, 0x9EDC, 0x9EDE, 0x9EDD, 0x9EE0, 0x9EE5, 0x9EE8, 0x9EEF, 0x9EF4, 0x9EF6, 0x9EF7, 0x9EF9, 0x9EFB, 0x9EFC, 0x9EFD, 0x9F07, 0x9F08, 0x76B7, 0x9F15, 0x9F21, 0x9F2C, 0x9F3E, 0x9F4A, 0x9F52, 0x9F54, 0x9F63, 0x9F5F, 0x9F60, 0x9F61, 0x9F66, 0x9F67, 0x9F6C, 0x9F6A, 0x9F77, 0x9F72, 0x9F76, 0x9F95, 0x9F9C, 0x9FA0 }, { /* category 84 */ 0x582F, 0x69C7, 0x9059, 0x7464, 0x51DC, 0x7199, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 85 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 86 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 87 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 88 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000 }, { /* category 89 */ 0x7E8A, 0x891C, 0x9348, 0x9288, 0x84DC, 0x4FC9, 0x70BB, 0x6631, 0x68C8, 0x92F9, 0x66FB, 0x5F45, 0x4E28, 0x4EE1, 0x4EFC, 0x4F00, 0x4F03, 0x4F39, 0x4F56, 0x4F92, 0x4F8A, 0x4F9A, 0x4F94, 0x4FCD, 0x5040, 0x5022, 0x4FFF, 0x501E, 0x5046, 0x5070, 0x5042, 0x5094, 0x50F4, 0x50D8, 0x514A, 0x5164, 0x519D, 0x51BE, 0x51EC, 0x5215, 0x529C, 0x52A6, 0x52C0, 0x52DB, 0x5300, 0x5307, 0x5324, 0x5372, 0x5393, 0x53B2, 0x53DD, 0xFA0E, 0x549C, 0x548A, 0x54A9, 0x54FF, 0x5586, 0x5759, 0x5765, 0x57AC, 0x57C8, 0x57C7, 0xFA0F, 0xFA10, 0x589E, 0x58B2, 0x590B, 0x5953, 0x595B, 0x595D, 0x5963, 0x59A4, 0x59BA, 0x5B56, 0x5BC0, 0x752F, 0x5BD8, 0x5BEC, 0x5C1E, 0x5CA6, 0x5CBA, 0x5CF5, 0x5D27, 0x5D53, 0xFA11, 0x5D42, 0x5D6D, 0x5DB8, 0x5DB9, 0x5DD0, 0x5F21, 0x5F34, 0x5F67, 0x5FB7 }, { /* category 90 */ 0x5FDE, 0x605D, 0x6085, 0x608A, 0x60DE, 0x60D5, 0x6120, 0x60F2, 0x6111, 0x6137, 0x6130, 0x6198, 0x6213, 0x62A6, 0x63F5, 0x6460, 0x649D, 0x64CE, 0x654E, 0x6600, 0x6615, 0x663B, 0x6609, 0x662E, 0x661E, 0x6624, 0x6665, 0x6657, 0x6659, 0xFA12, 0x6673, 0x6699, 0x66A0, 0x66B2, 0x66BF, 0x66FA, 0x670E, 0xF929, 0x6766, 0x67BB, 0x6852, 0x67C0, 0x6801, 0x6844, 0x68CF, 0xFA13, 0x6968, 0xFA14, 0x6998, 0x69E2, 0x6A30, 0x6A6B, 0x6A46, 0x6A73, 0x6A7E, 0x6AE2, 0x6AE4, 0x6BD6, 0x6C3F, 0x6C5C, 0x6C86, 0x6C6F, 0x6CDA, 0x6D04, 0x6D87, 0x6D6F, 0x6D96, 0x6DAC, 0x6DCF, 0x6DF8, 0x6DF2, 0x6DFC, 0x6E39, 0x6E5C, 0x6E27, 0x6E3C, 0x6EBF, 0x6F88, 0x6FB5, 0x6FF5, 0x7005, 0x7007, 0x7028, 0x7085, 0x70AB, 0x710F, 0x7104, 0x715C, 0x7146, 0x7147, 0xFA15, 0x71C1, 0x71FE, 0x72B1 }, { /* category 91 */ 0x72BE, 0x7324, 0xFA16, 0x7377, 0x73BD, 0x73C9, 0x73D6, 0x73E3, 0x73D2, 0x7407, 0x73F5, 0x7426, 0x742A, 0x7429, 0x742E, 0x7462, 0x7489, 0x749F, 0x7501, 0x756F, 0x7682, 0x769C, 0x769E, 0x769B, 0x76A6, 0xFA17, 0x7746, 0x52AF, 0x7821, 0x784E, 0x7864, 0x787A, 0x7930, 0xFA18, 0xFA19, 0xFA1A, 0x7994, 0xFA1B, 0x799B, 0x7AD1, 0x7AE7, 0xFA1C, 0x7AEB, 0x7B9E, 0xFA1D, 0x7D48, 0x7D5C, 0x7DB7, 0x7DA0, 0x7DD6, 0x7E52, 0x7F47, 0x7FA1, 0xFA1E, 0x8301, 0x8362, 0x837F, 0x83C7, 0x83F6, 0x8448, 0x84B4, 0x8553, 0x8559, 0x856B, 0xFA1F, 0x85B0, 0xFA20, 0xFA21, 0x8807, 0x88F5, 0x8A12, 0x8A37, 0x8A79, 0x8AA7, 0x8ABE, 0x8ADF, 0xFA22, 0x8AF6, 0x8B53, 0x8B7F, 0x8CF0, 0x8CF4, 0x8D12, 0x8D76, 0xFA23, 0x8ECF, 0xFA24, 0xFA25, 0x9067, 0x90DE, 0xFA26, 0x9115, 0x9127, 0x91DA }, { /* category 92 */ 0x91D7, 0x91DE, 0x91ED, 0x91EE, 0x91E4, 0x91E5, 0x9206, 0x9210, 0x920A, 0x923A, 0x9240, 0x923C, 0x924E, 0x9259, 0x9251, 0x9239, 0x9267, 0x92A7, 0x9277, 0x9278, 0x92E7, 0x92D7, 0x92D9, 0x92D0, 0xFA27, 0x92D5, 0x92E0, 0x92D3, 0x9325, 0x9321, 0x92FB, 0xFA28, 0x931E, 0x92FF, 0x931D, 0x9302, 0x9370, 0x9357, 0x93A4, 0x93C6, 0x93DE, 0x93F8, 0x9431, 0x9445, 0x9448, 0x9592, 0xF9DC, 0xFA29, 0x969D, 0x96AF, 0x9733, 0x973B, 0x9743, 0x974D, 0x974F, 0x9751, 0x9755, 0x9857, 0x9865, 0xFA2A, 0xFA2B, 0x9927, 0xFA2C, 0x999E, 0x9A4E, 0x9AD9, 0x9ADC, 0x9B75, 0x9B72, 0x9B8F, 0x9BB1, 0x9BBB, 0x9C00, 0x9D70, 0x9D6B, 0xFA2D, 0x9E19, 0x9ED1, 0x0000, 0x0000, 0x2170, 0x2171, 0x2172, 0x2173, 0x2174, 0x2175, 0x2176, 0x2177, 0x2178, 0x2179, 0xFFE2, 0xFFE4, 0xFF07, 0xFF02 } }; #endif /* JISX0208_H */ #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/msinttypes/000077500000000000000000000000001245535672000162035ustar00rootroot00000000000000libgd-gd-2.1.1/src/msinttypes/inttypes.h000066400000000000000000000175041245535672000202420ustar00rootroot00000000000000// ISO C9x compliant inttypes.h for Microsoft Visual Studio // Based on ISO/IEC 9899:TC2 Committee draft (May 6, 2005) WG14/N1124 // // Copyright (c) 2006 Alexander Chemeris // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // // 1. Redistributions of source code must retain the above copyright notice, // this list of conditions and the following disclaimer. // // 2. Redistributions in binary form must reproduce the above copyright // notice, this list of conditions and the following disclaimer in the // documentation and/or other materials provided with the distribution. // // 3. The name of the author may be used to endorse or promote products // derived from this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO // EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF // ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // /////////////////////////////////////////////////////////////////////////////// #ifndef _MSC_VER // [ #error "Use this header only with Microsoft Visual C++ compilers!" #endif // _MSC_VER ] #ifndef _MSC_INTTYPES_H_ // [ #define _MSC_INTTYPES_H_ #if _MSC_VER > 1000 #pragma once #endif #include "stdint.h" // 7.8 Format conversion of integer types typedef struct { intmax_t quot; intmax_t rem; } imaxdiv_t; // 7.8.1 Macros for format specifiers #if !defined(__cplusplus) || defined(__STDC_FORMAT_MACROS) // [ See footnote 185 at page 198 // The fprintf macros for signed integers are: #define PRId8 "d" #define PRIi8 "i" #define PRIdLEAST8 "d" #define PRIiLEAST8 "i" #define PRIdFAST8 "d" #define PRIiFAST8 "i" #define PRId16 "hd" #define PRIi16 "hi" #define PRIdLEAST16 "hd" #define PRIiLEAST16 "hi" #define PRIdFAST16 "hd" #define PRIiFAST16 "hi" #define PRId32 "I32d" #define PRIi32 "I32i" #define PRIdLEAST32 "I32d" #define PRIiLEAST32 "I32i" #define PRIdFAST32 "I32d" #define PRIiFAST32 "I32i" #define PRId64 "I64d" #define PRIi64 "I64i" #define PRIdLEAST64 "I64d" #define PRIiLEAST64 "I64i" #define PRIdFAST64 "I64d" #define PRIiFAST64 "I64i" #define PRIdMAX "I64d" #define PRIiMAX "I64i" #define PRIdPTR "Id" #define PRIiPTR "Ii" // The fprintf macros for unsigned integers are: #define PRIo8 "o" #define PRIu8 "u" #define PRIx8 "x" #define PRIX8 "X" #define PRIoLEAST8 "o" #define PRIuLEAST8 "u" #define PRIxLEAST8 "x" #define PRIXLEAST8 "X" #define PRIoFAST8 "o" #define PRIuFAST8 "u" #define PRIxFAST8 "x" #define PRIXFAST8 "X" #define PRIo16 "ho" #define PRIu16 "hu" #define PRIx16 "hx" #define PRIX16 "hX" #define PRIoLEAST16 "ho" #define PRIuLEAST16 "hu" #define PRIxLEAST16 "hx" #define PRIXLEAST16 "hX" #define PRIoFAST16 "ho" #define PRIuFAST16 "hu" #define PRIxFAST16 "hx" #define PRIXFAST16 "hX" #define PRIo32 "I32o" #define PRIu32 "I32u" #define PRIx32 "I32x" #define PRIX32 "I32X" #define PRIoLEAST32 "I32o" #define PRIuLEAST32 "I32u" #define PRIxLEAST32 "I32x" #define PRIXLEAST32 "I32X" #define PRIoFAST32 "I32o" #define PRIuFAST32 "I32u" #define PRIxFAST32 "I32x" #define PRIXFAST32 "I32X" #define PRIo64 "I64o" #define PRIu64 "I64u" #define PRIx64 "I64x" #define PRIX64 "I64X" #define PRIoLEAST64 "I64o" #define PRIuLEAST64 "I64u" #define PRIxLEAST64 "I64x" #define PRIXLEAST64 "I64X" #define PRIoFAST64 "I64o" #define PRIuFAST64 "I64u" #define PRIxFAST64 "I64x" #define PRIXFAST64 "I64X" #define PRIoMAX "I64o" #define PRIuMAX "I64u" #define PRIxMAX "I64x" #define PRIXMAX "I64X" #define PRIoPTR "Io" #define PRIuPTR "Iu" #define PRIxPTR "Ix" #define PRIXPTR "IX" // The fscanf macros for signed integers are: #define SCNd8 "d" #define SCNi8 "i" #define SCNdLEAST8 "d" #define SCNiLEAST8 "i" #define SCNdFAST8 "d" #define SCNiFAST8 "i" #define SCNd16 "hd" #define SCNi16 "hi" #define SCNdLEAST16 "hd" #define SCNiLEAST16 "hi" #define SCNdFAST16 "hd" #define SCNiFAST16 "hi" #define SCNd32 "ld" #define SCNi32 "li" #define SCNdLEAST32 "ld" #define SCNiLEAST32 "li" #define SCNdFAST32 "ld" #define SCNiFAST32 "li" #define SCNd64 "I64d" #define SCNi64 "I64i" #define SCNdLEAST64 "I64d" #define SCNiLEAST64 "I64i" #define SCNdFAST64 "I64d" #define SCNiFAST64 "I64i" #define SCNdMAX "I64d" #define SCNiMAX "I64i" #ifdef _WIN64 // [ # define SCNdPTR "I64d" # define SCNiPTR "I64i" #else // _WIN64 ][ # define SCNdPTR "ld" # define SCNiPTR "li" #endif // _WIN64 ] // The fscanf macros for unsigned integers are: #define SCNo8 "o" #define SCNu8 "u" #define SCNx8 "x" #define SCNX8 "X" #define SCNoLEAST8 "o" #define SCNuLEAST8 "u" #define SCNxLEAST8 "x" #define SCNXLEAST8 "X" #define SCNoFAST8 "o" #define SCNuFAST8 "u" #define SCNxFAST8 "x" #define SCNXFAST8 "X" #define SCNo16 "ho" #define SCNu16 "hu" #define SCNx16 "hx" #define SCNX16 "hX" #define SCNoLEAST16 "ho" #define SCNuLEAST16 "hu" #define SCNxLEAST16 "hx" #define SCNXLEAST16 "hX" #define SCNoFAST16 "ho" #define SCNuFAST16 "hu" #define SCNxFAST16 "hx" #define SCNXFAST16 "hX" #define SCNo32 "lo" #define SCNu32 "lu" #define SCNx32 "lx" #define SCNX32 "lX" #define SCNoLEAST32 "lo" #define SCNuLEAST32 "lu" #define SCNxLEAST32 "lx" #define SCNXLEAST32 "lX" #define SCNoFAST32 "lo" #define SCNuFAST32 "lu" #define SCNxFAST32 "lx" #define SCNXFAST32 "lX" #define SCNo64 "I64o" #define SCNu64 "I64u" #define SCNx64 "I64x" #define SCNX64 "I64X" #define SCNoLEAST64 "I64o" #define SCNuLEAST64 "I64u" #define SCNxLEAST64 "I64x" #define SCNXLEAST64 "I64X" #define SCNoFAST64 "I64o" #define SCNuFAST64 "I64u" #define SCNxFAST64 "I64x" #define SCNXFAST64 "I64X" #define SCNoMAX "I64o" #define SCNuMAX "I64u" #define SCNxMAX "I64x" #define SCNXMAX "I64X" #ifdef _WIN64 // [ # define SCNoPTR "I64o" # define SCNuPTR "I64u" # define SCNxPTR "I64x" # define SCNXPTR "I64X" #else // _WIN64 ][ # define SCNoPTR "lo" # define SCNuPTR "lu" # define SCNxPTR "lx" # define SCNXPTR "lX" #endif // _WIN64 ] #endif // __STDC_FORMAT_MACROS ] // 7.8.2 Functions for greatest-width integer types // 7.8.2.1 The imaxabs function #define imaxabs _abs64 // 7.8.2.2 The imaxdiv function // This is modified version of div() function from Microsoft's div.c found // in %MSVC.NET%\crt\src\div.c #ifdef STATIC_IMAXDIV // [ static #else // STATIC_IMAXDIV ][ _inline #endif // STATIC_IMAXDIV ] imaxdiv_t __cdecl imaxdiv(intmax_t numer, intmax_t denom) { imaxdiv_t result; result.quot = numer / denom; result.rem = numer % denom; if (numer < 0 && result.rem > 0) { // did division wrong; must fix up ++result.quot; result.rem -= denom; } return result; } // 7.8.2.3 The strtoimax and strtoumax functions #define strtoimax _strtoi64 #define strtoumax _strtoui64 // 7.8.2.4 The wcstoimax and wcstoumax functions #define wcstoimax _wcstoi64 #define wcstoumax _wcstoui64 #endif // _MSC_INTTYPES_H_ ] libgd-gd-2.1.1/src/msinttypes/stdint.h000066400000000000000000000170601245535672000176650ustar00rootroot00000000000000// ISO C9x compliant stdint.h for Microsoft Visual Studio // Based on ISO/IEC 9899:TC2 Committee draft (May 6, 2005) WG14/N1124 // // Copyright (c) 2006-2008 Alexander Chemeris // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // // 1. Redistributions of source code must retain the above copyright notice, // this list of conditions and the following disclaimer. // // 2. Redistributions in binary form must reproduce the above copyright // notice, this list of conditions and the following disclaimer in the // documentation and/or other materials provided with the distribution. // // 3. The name of the author may be used to endorse or promote products // derived from this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO // EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF // ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // /////////////////////////////////////////////////////////////////////////////// #ifndef _MSC_VER // [ #error "Use this header only with Microsoft Visual C++ compilers!" #endif // _MSC_VER ] #ifndef _MSC_STDINT_H_ // [ #define _MSC_STDINT_H_ #if _MSC_VER > 1000 #pragma once #endif #include // For Visual Studio 6 in C++ mode and for many Visual Studio versions when // compiling for ARM we should wrap include with 'extern "C++" {}' // or compiler give many errors like this: // error C2733: second C linkage of overloaded function 'wmemchr' not allowed #ifdef __cplusplus extern "C" { #endif # include #ifdef __cplusplus } #endif // Define _W64 macros to mark types changing their size, like intptr_t. #ifndef _W64 # if !defined(__midl) && (defined(_X86_) || defined(_M_IX86)) && _MSC_VER >= 1300 # define _W64 __w64 # else # define _W64 # endif #endif // 7.18.1 Integer types // 7.18.1.1 Exact-width integer types // Visual Studio 6 and Embedded Visual C++ 4 doesn't // realize that, e.g. char has the same size as __int8 // so we give up on __intX for them. #if (_MSC_VER < 1300) typedef signed char int8_t; typedef signed short int16_t; typedef signed int int32_t; typedef unsigned char uint8_t; typedef unsigned short uint16_t; typedef unsigned int uint32_t; #else typedef signed __int8 int8_t; typedef signed __int16 int16_t; typedef signed __int32 int32_t; typedef unsigned __int8 uint8_t; typedef unsigned __int16 uint16_t; typedef unsigned __int32 uint32_t; #endif typedef signed __int64 int64_t; typedef unsigned __int64 uint64_t; // 7.18.1.2 Minimum-width integer types typedef int8_t int_least8_t; typedef int16_t int_least16_t; typedef int32_t int_least32_t; typedef int64_t int_least64_t; typedef uint8_t uint_least8_t; typedef uint16_t uint_least16_t; typedef uint32_t uint_least32_t; typedef uint64_t uint_least64_t; // 7.18.1.3 Fastest minimum-width integer types typedef int8_t int_fast8_t; typedef int16_t int_fast16_t; typedef int32_t int_fast32_t; typedef int64_t int_fast64_t; typedef uint8_t uint_fast8_t; typedef uint16_t uint_fast16_t; typedef uint32_t uint_fast32_t; typedef uint64_t uint_fast64_t; // 7.18.1.4 Integer types capable of holding object pointers #ifdef _WIN64 // [ typedef signed __int64 intptr_t; typedef unsigned __int64 uintptr_t; #else // _WIN64 ][ typedef _W64 signed int intptr_t; typedef _W64 unsigned int uintptr_t; #endif // _WIN64 ] // 7.18.1.5 Greatest-width integer types typedef int64_t intmax_t; typedef uint64_t uintmax_t; // 7.18.2 Limits of specified-width integer types #if !defined(__cplusplus) || defined(__STDC_LIMIT_MACROS) // [ See footnote 220 at page 257 and footnote 221 at page 259 // 7.18.2.1 Limits of exact-width integer types #define INT8_MIN ((int8_t)_I8_MIN) #define INT8_MAX _I8_MAX #define INT16_MIN ((int16_t)_I16_MIN) #define INT16_MAX _I16_MAX #define INT32_MIN ((int32_t)_I32_MIN) #define INT32_MAX _I32_MAX #define INT64_MIN ((int64_t)_I64_MIN) #define INT64_MAX _I64_MAX #define UINT8_MAX _UI8_MAX #define UINT16_MAX _UI16_MAX #define UINT32_MAX _UI32_MAX #define UINT64_MAX _UI64_MAX // 7.18.2.2 Limits of minimum-width integer types #define INT_LEAST8_MIN INT8_MIN #define INT_LEAST8_MAX INT8_MAX #define INT_LEAST16_MIN INT16_MIN #define INT_LEAST16_MAX INT16_MAX #define INT_LEAST32_MIN INT32_MIN #define INT_LEAST32_MAX INT32_MAX #define INT_LEAST64_MIN INT64_MIN #define INT_LEAST64_MAX INT64_MAX #define UINT_LEAST8_MAX UINT8_MAX #define UINT_LEAST16_MAX UINT16_MAX #define UINT_LEAST32_MAX UINT32_MAX #define UINT_LEAST64_MAX UINT64_MAX // 7.18.2.3 Limits of fastest minimum-width integer types #define INT_FAST8_MIN INT8_MIN #define INT_FAST8_MAX INT8_MAX #define INT_FAST16_MIN INT16_MIN #define INT_FAST16_MAX INT16_MAX #define INT_FAST32_MIN INT32_MIN #define INT_FAST32_MAX INT32_MAX #define INT_FAST64_MIN INT64_MIN #define INT_FAST64_MAX INT64_MAX #define UINT_FAST8_MAX UINT8_MAX #define UINT_FAST16_MAX UINT16_MAX #define UINT_FAST32_MAX UINT32_MAX #define UINT_FAST64_MAX UINT64_MAX // 7.18.2.4 Limits of integer types capable of holding object pointers #ifdef _WIN64 // [ # define INTPTR_MIN INT64_MIN # define INTPTR_MAX INT64_MAX # define UINTPTR_MAX UINT64_MAX #else // _WIN64 ][ # define INTPTR_MIN INT32_MIN # define INTPTR_MAX INT32_MAX # define UINTPTR_MAX UINT32_MAX #endif // _WIN64 ] // 7.18.2.5 Limits of greatest-width integer types #define INTMAX_MIN INT64_MIN #define INTMAX_MAX INT64_MAX #define UINTMAX_MAX UINT64_MAX // 7.18.3 Limits of other integer types #ifdef _WIN64 // [ # define PTRDIFF_MIN _I64_MIN # define PTRDIFF_MAX _I64_MAX #else // _WIN64 ][ # define PTRDIFF_MIN _I32_MIN # define PTRDIFF_MAX _I32_MAX #endif // _WIN64 ] #define SIG_ATOMIC_MIN INT_MIN #define SIG_ATOMIC_MAX INT_MAX #ifndef SIZE_MAX // [ # ifdef _WIN64 // [ # define SIZE_MAX _UI64_MAX # else // _WIN64 ][ # define SIZE_MAX _UI32_MAX # endif // _WIN64 ] #endif // SIZE_MAX ] // WCHAR_MIN and WCHAR_MAX are also defined in #ifndef WCHAR_MIN // [ # define WCHAR_MIN 0 #endif // WCHAR_MIN ] #ifndef WCHAR_MAX // [ # define WCHAR_MAX _UI16_MAX #endif // WCHAR_MAX ] #define WINT_MIN 0 #define WINT_MAX _UI16_MAX #endif // __STDC_LIMIT_MACROS ] // 7.18.4 Limits of other integer types #if !defined(__cplusplus) || defined(__STDC_CONSTANT_MACROS) // [ See footnote 224 at page 260 // 7.18.4.1 Macros for minimum-width integer constants #define INT8_C(val) val##i8 #define INT16_C(val) val##i16 #define INT32_C(val) val##i32 #define INT64_C(val) val##i64 #define UINT8_C(val) val##ui8 #define UINT16_C(val) val##ui16 #define UINT32_C(val) val##ui32 #define UINT64_C(val) val##ui64 // 7.18.4.2 Macros for greatest-width integer constants #define INTMAX_C INT64_C #define UINTMAX_C UINT64_C #endif // __STDC_CONSTANT_MACROS ] #endif // _MSC_STDINT_H_ ] libgd-gd-2.1.1/src/pngtogd.c000066400000000000000000000020361245535672000155730ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include "gd.h" /* A short program which converts a .png file into a .gd file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd format is not intended to be a general-purpose format. */ int main (int argc, char **argv) { gdImagePtr im = NULL; FILE *in, *out; if (argc != 3) { fprintf (stderr, "Usage: pngtogd filename.png filename.gd\n"); exit (1); } in = fopen (argv[1], "rb"); if (!in) { fprintf (stderr, "Input file does not exist!\n"); exit (1); } #ifdef HAVE_LIBPNG im = gdImageCreateFromPng (in); #else fprintf (stderr, "No PNG library support available.\n"); #endif fclose (in); if (!im) { fprintf (stderr, "Input is not in PNG format!\n"); exit (1); } out = fopen (argv[2], "wb"); if (!out) { fprintf (stderr, "Output file cannot be written to!\n"); gdImageDestroy (im); exit (1); } gdImageGd (im, out); fclose (out); gdImageDestroy (im); return 0; } libgd-gd-2.1.1/src/pngtogd2.c000066400000000000000000000023541245535672000156600ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include "gd.h" /* A short program which converts a .png file into a .gd2 file, for your convenience in creating images on the fly from a basis image that must be loaded quickly. The .gd2 format is not intended to be a general-purpose format. */ int main (int argc, char **argv) { gdImagePtr im; FILE *in, *out; int cs, fmt; if (argc != 5) { fprintf(stderr, "Usage: pngtogd2 filename.png filename.gd2 cs fmt\n"); fprintf(stderr, " where cs is the chunk size\n"); fprintf(stderr, " fmt is 1 for raw, 2 for compressed\n"); exit (1); } in = fopen (argv[1], "rb"); if (!in) { fprintf(stderr, "Input file does not exist!\n"); exit (1); } #ifdef HAVE_LIBPNG im = gdImageCreateFromPng (in); #else im = NULL; fprintf(stderr, "No PNG library support available.\n"); #endif fclose (in); if (!im) { fprintf(stderr, "Input is not in PNG format!\n"); exit (1); } out = fopen (argv[2], "wb"); if (!out) { fprintf(stderr, "Output file cannot be written to!\n"); gdImageDestroy (im); exit (1); } cs = atoi (argv[3]); fmt = atoi (argv[4]); gdImageGd2 (im, out, cs, fmt); fclose (out); gdImageDestroy (im); return 0; } libgd-gd-2.1.1/src/testac.c000066400000000000000000000102221245535672000154100ustar00rootroot00000000000000 #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include "gd.h" /* If palette is true, we convert from truecolor to palette at the end, to test gdImageTrueColorToPalette and see file size/ quality tradeoffs. */ void testDrawing (gdImagePtr im_in, double scale, int blending, int palette, char *filename); int main (int argc, char *argv[]) { #ifdef HAVE_LIBPNG /* Input and output files */ FILE *in; /* Input image */ gdImagePtr im_in = 0; if (argc != 2) { fprintf (stderr, "Usage: testac filename.png\n"); exit (1); } /* Load original PNG, which should contain alpha channel information. We will use it in two ways: preserving it literally, for use with compatible browsers, and compositing it ourselves against a background of our choosing (alpha blending). We'll change its size and try creating palette versions of it. */ in = fopen (argv[1], "rb"); if (!in) { fprintf (stderr, "Can't load %s.\n", argv[1]); exit (1); } else { im_in = gdImageCreateFromPng (in); fclose (in); } testDrawing (im_in, 1.0, 0, 0, "noblending-fullsize-truecolor.png"); testDrawing (im_in, 1.0, 1, 0, "blending-fullsize-truecolor.png"); testDrawing (im_in, 0.5, 0, 0, "noblending-halfsize-truecolor.png"); testDrawing (im_in, 0.5, 1, 0, "blending-halfsize-truecolor.png"); testDrawing (im_in, 2.0, 0, 0, "noblending-doublesize-truecolor.png"); testDrawing (im_in, 2.0, 1, 0, "blending-doublesize-truecolor.png"); testDrawing (im_in, 1.0, 0, 1, "noblending-fullsize-palette.png"); testDrawing (im_in, 1.0, 1, 1, "blending-fullsize-palette.png"); testDrawing (im_in, 0.5, 0, 1, "noblending-halfsize-palette.png"); testDrawing (im_in, 0.5, 1, 1, "blending-halfsize-palette.png"); testDrawing (im_in, 2.0, 0, 1, "noblending-doublesize-palette.png"); testDrawing (im_in, 2.0, 1, 1, "blending-doublesize-palette.png"); gdImageDestroy (im_in); #else fprintf (stderr, "No PNG library support.\n"); #endif return 0; } /* If palette is true, we convert from truecolor to palette at the end, to test gdImageTrueColorToPalette and see file size/ quality tradeoffs. */ void testDrawing (gdImagePtr im_in, double scale, int blending, int palette, char *filename) { gdImagePtr im_out; FILE *out; /* Create output image. */ im_out = gdImageCreateTrueColor ((int) (gdImageSX (im_in) * scale), (int) (gdImageSY (im_in) * scale)); /* Request alpha blending. This causes future drawing operations to perform alpha channel blending with the background, resulting in an opaque image. Without this call, pixels in the foreground color are copied literally, *including* the alpha channel value, resulting in an output image which is potentially not opaque. This flag can be set and cleared as often as desired. */ gdImageAlphaBlending (im_out, blending); /* Flood with light blue. */ gdImageFill (im_out, (int) (gdImageSX (im_in) * scale / 2), (int) (gdImageSY (im_in) * scale / 2), gdTrueColor (192, 192, 255)); /* Copy the source image. Alpha blending should result in compositing against red. With blending turned off, the browser or viewer will composite against its preferred background, or, if it does not support an alpha channel, we will see the original colors for the pixels that ought to be transparent or semitransparent. */ gdImageCopyResampled (im_out, im_in, 0, 0, 0, 0, (int) (gdImageSX (im_in) * scale), (int) (gdImageSY (im_in) * scale), gdImageSX (im_in), gdImageSY (im_in)); /* Write PNG */ out = fopen (filename, "wb"); /* If this image is the result of alpha channel blending, it will not contain an interesting alpha channel itself. Save a little file size by not saving the alpha channel. Otherwise the file would typically be slightly larger. */ gdImageSaveAlpha (im_out, !blending); /* If requested, convert from truecolor to palette. */ if (palette) { /* Dithering, 256 colors. */ gdImageTrueColorToPalette (im_out, 1, 256); } #ifdef HAVE_LIBPNG gdImagePng (im_out, out); #else fprintf (stderr, "No PNG library support.\n"); #endif fclose (out); gdImageDestroy (im_out); } libgd-gd-2.1.1/src/testtr.c000066400000000000000000000025151245535672000154600ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* HAVE_CONFIG_H */ #include #include "gd.h" #define FALSE 0 #define TRUE (!FALSE) int main(void) { #ifdef HAVE_LIBFREETYPE FILE *out; int transparent, green, black; gdImagePtr im; im = gdImageCreateTrueColor(100,100); black = gdImageColorResolveAlpha(im, 0, 0, 0, gdAlphaOpaque); green = gdImageColorResolveAlpha(im, 0, gdGreenMax, 0, gdAlphaOpaque); transparent = gdImageColorResolveAlpha(im, gdRedMax-1, gdGreenMax, gdBlueMax, gdAlphaTransparent); gdImageColorTransparent(im, transparent); /* Blending must be off to lay a transparent basecolor. Nothing to blend with anyway. */ gdImageAlphaBlending(im, FALSE); gdImageFill (im, im->sx/2, im->sy/2, transparent); /* Blend everything else together, especially fonts over non-transparent backgrounds */ gdImageAlphaBlending(im, TRUE); gdImageFilledRectangle (im, 30, 30, 70, 70, green); gdImageStringFT (im, NULL, black, "Times", 18, 0, 50, 50, "Hello"); gdImageSaveAlpha (im, TRUE); #ifdef HAVE_LIBPNG out = fopen ("testtr.png", "wb"); gdImagePng (im, out); fclose (out); #else fprintf(stderr, "Compiled without libpng support\n"); #endif /* HAVE_LIBPNG */ gdImageDestroy (im); return 0; #else fprintf(stderr, "Compiled without freetype support\n"); return 0; #endif /* HAVE_LIBFREETYPE */ } libgd-gd-2.1.1/src/wbmp.c000066400000000000000000000142711245535672000151020ustar00rootroot00000000000000/* WBMP * ---- * WBMP Level 0: B/W, Uncompressed * This implements the WBMP format as specified in WAPSpec 1.1 and 1.2. * It does not support ExtHeaders as defined in the spec. The spec states * that a WAP client does not need to implement ExtHeaders. * * (c) 2000 Johan Van den Brande */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include #include "wbmp.h" #include "gd.h" #include "gdhelpers.h" #ifdef NOTDEF # define __TEST /* Compile with main function */ # define __DEBUG /* Extra verbose when with __TEST */ # define __WRITE /* readwbmp and writewbmp(stdout) */ # define __VIEW /* view the wbmp on stdout */ #endif /* getmbi * ------ * Get a multibyte integer from a generic getin function * 'getin' can be getc, with in = NULL * you can find getin as a function just above the main function * This way you gain a lot of flexibilty about how this package * reads a wbmp file. */ int getmbi(int (*getin) (void *in), void *in) { int i, mbi = 0; do { i = getin(in); if(i < 0) { return (-1); } mbi = (mbi << 7) | (i & 0x7f); } while(i & 0x80); return mbi; } /* putmbi * ------ * Put a multibyte intgerer in some kind of output stream * I work here with a function pointer, to make it as generic * as possible. Look at this function as an iterator on the * mbi integers it spits out. * */ void putmbi(int i, void (*putout)(int c, void *out), void *out) { int cnt, l, accu; /* Get number of septets */ accu = cnt = 0; while(accu != i) { accu += i & 0x7f << 7 * cnt++; } /* Produce the multibyte output */ for(l = cnt - 1; l > 0; l--) { putout(0x80 | (i & 0x7f << 7 * l) >> 7 * l, out); } putout(i & 0x7f, out); } /* skipheader * ---------- * Skips the ExtHeader. Not needed for the moment */ int skipheader(int (*getin)(void *in), void *in) { int i; do { i = getin(in); if(i < 0) { return (-1); } } while(i & 0x80); return 0; } /* create wbmp * ----------- * create an empty wbmp */ Wbmp *createwbmp(int width, int height, int color) { int i; Wbmp *wbmp; if((wbmp = (Wbmp *)gdMalloc(sizeof (Wbmp))) == NULL) { return (NULL); } if(overflow2(sizeof(int), width)) { gdFree(wbmp); return NULL; } if(overflow2(sizeof(int) * width, height)) { gdFree(wbmp); return NULL; } if((wbmp->bitmap = (int *)gdMalloc(sizeof(int) * width * height)) == NULL) { gdFree(wbmp); return NULL; } wbmp->width = width; wbmp->height = height; for(i = 0; i < width * height; wbmp->bitmap[i++] = color); return wbmp; } /* readwbmp * ------- * Actually reads the WBMP format from an open file descriptor * It goes along by returning a pointer to a WBMP struct. */ int readwbmp(int (*getin) (void *in), void *in, Wbmp **return_wbmp) { int row, col, byte, pel, pos; Wbmp *wbmp; if((wbmp = (Wbmp *)gdMalloc(sizeof(Wbmp))) == NULL) { return -1; } wbmp->type = getin(in); if(wbmp->type != 0) { gdFree(wbmp); return -1; } if(skipheader(getin, in)) { gdFree(wbmp); return -1; } wbmp->width = getmbi(getin, in); if(wbmp->width == -1) { gdFree(wbmp); return -1; } wbmp->height = getmbi(getin, in); if(wbmp->height == -1) { gdFree(wbmp); return -1; } #ifdef __DEBUG printf("W: %d, H: %d\n", wbmp->width, wbmp->height); #endif if( overflow2(sizeof(int), wbmp->width) || overflow2(sizeof(int) * wbmp->width, wbmp->height)) { gdFree(wbmp); return -1; } if((wbmp->bitmap = (int *)gdMalloc(sizeof(int) * wbmp->width * wbmp->height)) == NULL) { gdFree(wbmp); return -1; } #ifdef __DEBUG printf("DATA CONSTRUCTED\n"); #endif pos = 0; for(row = 0; row < wbmp->height; row++) { for(col = 0; col < wbmp->width;) { byte = getin(in); for(pel = 7; pel >= 0; pel--) { if(col++ < wbmp->width) { if(byte & 1 << pel) { wbmp->bitmap[pos] = WBMP_WHITE; } else { wbmp->bitmap[pos] = WBMP_BLACK; } pos++; } } } } *return_wbmp = wbmp; return 0; } /* writewbmp * --------- * Write a wbmp to a file descriptor * * Why not just giving a filedescriptor to this function? * Well, the incentive to write this function was the complete * integration in gd library from www.libgd.org. They use * their own io functions, so the passing of a function seemed to be * a logic(?) decision ... */ int writewbmp(Wbmp *wbmp, void (*putout)(int c, void *out), void *out) { int row, col; int bitpos, octet; /* Generate the header */ putout(0, out); /* WBMP Type 0: B/W, Uncompressed bitmap */ putout(0, out); /* FixHeaderField */ /* Size of the image */ putmbi(wbmp->width, putout, out); /* width */ putmbi(wbmp->height, putout, out); /* height */ /* Image data */ for(row = 0; row < wbmp->height; row++) { bitpos = 8; octet = 0; for(col = 0; col < wbmp->width; col++) { octet |= ((wbmp->bitmap[row * wbmp->width + col] == 1) ? WBMP_WHITE : WBMP_BLACK) << --bitpos; if(bitpos == 0) { bitpos = 8; putout(octet, out); octet = 0; } } if(bitpos != 8) { putout(octet, out); } } return 0; } /* freewbmp * -------- * gdFrees up memory occupied by a WBMP structure */ void freewbmp(Wbmp *wbmp) { gdFree(wbmp->bitmap); gdFree(wbmp); } /* printwbmp * --------- * print a WBMP to stdout for visualisation */ void printwbmp(Wbmp *wbmp) { int row, col; for(row = 0; row < wbmp->height; row++) { for(col = 0; col < wbmp->width; col++) { if(wbmp->bitmap[wbmp->width * row + col] == WBMP_BLACK) { putchar('#'); } else { putchar(' '); } } putchar('\n'); } } #ifdef __TEST /* putout to file descriptor * ------------------------- */ int putout(int c, void *out) { return (putc(c, (FILE *)out)); } /* getin from file descriptor * -------------------------- */ int getin(void *in) { return (getc((FILE *)in)); } /* Main function * ------------- */ int main(int argc, char *argv[]) { FILE *wbmp_file; Wbmp *wbmp; wbmp_file = fopen(argv[1], "rb"); if(wbmp_file) { readwbmp(&getin, wbmp_file, &wbmp); #ifdef __VIEW #ifdef __DEBUG printf("\nVIEWING IMAGE\n"); #endif printwbmp(wbmp); #endif #ifdef __WRITE #ifdef __DEBUG printf("\nDUMPING WBMP to STDOUT\n"); #endif writewbmp(wbmp, &putout, stdout); #endif freewbmp(wbmp); fclose(wbmp_file); } } #endif libgd-gd-2.1.1/src/wbmp.h000066400000000000000000000023111245535672000150770ustar00rootroot00000000000000#ifdef __cplusplus extern "C" { #endif /* WBMP * ---- * WBMP Level 0: B/W, Uncompressed * This implements the WBMP format as specified in WAPSpec 1.1 and 1.2. * It does not support ExtHeaders as defined in the spec. The spec states * that a WAP client does not need to implement ExtHeaders. * * (c) 2000 Johan Van den Brande * * Header file */ #ifndef __WBMP_H #define __WBMP_H 1 /* WBMP struct * ----------- * A Wireless bitmap structure */ typedef struct Wbmp_ { int type; /* type of the wbmp */ int width; /* width of the image */ int height; /* height of the image */ int *bitmap;/* pointer to data: 0 = WHITE , 1 = BLACK */ } Wbmp; #define WBMP_WHITE 1 #define WBMP_BLACK 0 /* Proto's * ------- */ void putmbi(int i, void (*putout)(int c, void *out), void *out); int getmbi(int (*getin)(void *in), void *in); int skipheader(int (*getin)(void *in), void *in); Wbmp *createwbmp(int width, int height, int color); int readwbmp(int (*getin)(void *in), void *in, Wbmp **wbmp); int writewbmp(Wbmp *wbmp, void (*putout)(int c, void *out), void *out); void freewbmp(Wbmp *wbmp); void printwbmp(Wbmp *wbmp); #endif #ifdef __cplusplus } #endif libgd-gd-2.1.1/src/webpimg.c000066400000000000000000000700771245535672000155750ustar00rootroot00000000000000/*===========================================================================* - Copyright 2010 Google Inc. - - This code is licensed under the same terms as WebM: - Software License Agreement: http://www.webmproject.org/license/software/ - Additional IP Rights Grant: http://www.webmproject.org/license/additional/ *===========================================================================*/ /* * Encoding/Decoding of WebP still image compression format. * * 1. WebPDecode: Takes an array of bytes (string) corresponding to the WebP * encoded image and generates output in the YUV format with * the color components U, V subsampled to 1/2 resolution along * each dimension. * * 2. YUV420toRGBA: Converts from YUV (with color subsampling) such as produced * by the WebPDecode routine into 32 bits per pixel RGBA data * array. This data array can be directly used by the Leptonica * Pix in-memory image format. * * 3. WebPEncode: Takes a Y, U, V data buffers (with color components U and V * subsampled to 1/2 resolution) and generates the WebP string * * 4. RGBAToYUV420: Generates Y, U, V data (with color subsampling) from 32 bits * per pixel RGBA data buffer. The resulting YUV data can be * directly fed into the WebPEncode routine. * * 5. AdjustColorspace: * * 6. AdjustColorspaceBack: */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "gd.h" #include "gd_errors.h" #ifdef HAVE_LIBVPX #include "webpimg.h" #include #include #include #include #include #include "vpx/vpx_decoder.h" #include "vpx/vp8dx.h" #include "vpx/vpx_encoder.h" #include "vpx/vp8cx.h" #include "gd.h" /*---------------------------------------------------------------------* * color conversions * *---------------------------------------------------------------------*/ #ifndef inline # define inline __inline #endif static inline int clip(float v, int a, int b) { return (v > b) ? b : (v < 0) ? 0 : (int)(v); } enum { COLOR_RED = 0, COLOR_GREEN = 1, COLOR_BLUE = 2, ALPHA_CHANNEL = 3 }; /* endian neutral extractions of RGBA from a 32 bit pixel */ static const uint32 RED_SHIFT = 8 * (sizeof(uint32) - 1 - COLOR_RED); /* 24 */ static const uint32 GREEN_SHIFT = 8 * (sizeof(uint32) - 1 - COLOR_GREEN); /* 16 */ static const uint32 BLUE_SHIFT = 8 * (sizeof(uint32) - 1 - COLOR_BLUE); /* 8 */ static const uint32 ALPHA_SHIFT = 8 * (sizeof(uint32) - 1 - ALPHA_CHANNEL); /* 0 */ static inline int GetRed(const uint32* rgba) { return gdTrueColorGetRed(*rgba); } static inline int GetGreen(const uint32* rgba) { return gdTrueColorGetGreen(*rgba); } static inline int GetBlue(const uint32* rgba) { return gdTrueColorGetBlue(*rgba); } enum { YUV_FRAC = 16 }; static inline int clip_uv(int v) { v = (v + (257 << (YUV_FRAC + 2 - 1))) >> (YUV_FRAC + 2); return ((v & ~0xff) == 0) ? v : v < 0 ? 0u : 255u; } /* YUV <-----> RGB conversions */ /* The exact naming is Y'CbCr, following the ITU-R BT.601 standard. * More information at: http://en.wikipedia.org/wiki/YCbCr */ static inline int GetLumaY(int r, int g, int b) { const int kRound = (1 << (YUV_FRAC - 1)) + (16 << YUV_FRAC); // Y = 0.2569 * R + 0.5044 * G + 0.0979 * B + 16 const int luma = 16839 * r + 33059 * g + 6420 * b; return (luma + kRound) >> YUV_FRAC; } static inline int GetLumaYfromPtr(uint32* rgba) { const int r = GetRed(rgba); const int g = GetGreen(rgba); const int b = GetBlue(rgba); return GetLumaY(r, g, b); } static inline int GetChromaU(int r, int g, int b) { // U = -0.1483 * R - 0.2911 * G + 0.4394 * B + 128 return clip_uv(-9719 * r - 19081 * g + 28800 * b); } static inline int GetChromaV(int r, int g, int b) { // V = 0.4394 * R - 0.3679 * G - 0.0715 * B + 128 return clip_uv(+28800 * r - 24116 * g - 4684 * b); } /* Converts YUV to RGB and writes into a 32 bit pixel in endian * neutral fashion */ enum { RGB_FRAC = 16, RGB_HALF = (1 << RGB_FRAC) / 2, RGB_RANGE_MIN = -227, RGB_RANGE_MAX = 256 + 226 }; static int init_done = 0; static int16_t kVToR[256], kUToB[256]; static int32_t kVToG[256], kUToG[256]; static uint8_t kClip[RGB_RANGE_MAX - RGB_RANGE_MIN]; static void InitTables() { int i; for (i = 0; i < 256; ++i) { kVToR[i] = (89858 * (i - 128) + RGB_HALF) >> RGB_FRAC; kUToG[i] = -22014 * (i - 128) + RGB_HALF; kVToG[i] = -45773 * (i - 128); kUToB[i] = (113618 * (i - 128) + RGB_HALF) >> RGB_FRAC; } for (i = RGB_RANGE_MIN; i < RGB_RANGE_MAX; ++i) { const int j = ((i - 16) * 76283 + RGB_HALF) >> RGB_FRAC; kClip[i - RGB_RANGE_MIN] = (j < 0) ? 0 : (j > 255) ? 255 : j; } init_done = 1; } static void ToRGB(int y, int u, int v, uint32* const dst) { const int r_off = kVToR[v]; const int g_off = (kVToG[v] + kUToG[u]) >> RGB_FRAC; const int b_off = kUToB[u]; const int r = kClip[y + r_off - RGB_RANGE_MIN]; const int g = kClip[y + g_off - RGB_RANGE_MIN]; const int b = kClip[y + b_off - RGB_RANGE_MIN]; *dst = (r << RED_SHIFT) | (g << GREEN_SHIFT) | (b << BLUE_SHIFT); } static inline uint32 get_le32(const uint8* const data) { return data[0] | (data[1] << 8) | (data[2] << 16) | (data[3] << 24); } /* Returns the difference (in dB) between two images represented in YUV format * * Input: * Y1/U1/V1: The Y/U/V data of the first image * Y2/U2/V2: The Y/U/V data of the second image * * Returns the PSNR (http://en.wikipedia.org/wiki/Peak_signal-to-noise_ratio) * value computed bewteen the two images */ double GetPSNRYuv(const uint8* Y1, const uint8* U1, const uint8* V1, const uint8* Y2, const uint8* U2, const uint8* V2, int y_width, int y_height) { int x, y, row_idx; const int uv_width = ((y_width + 1) >> 1); const int uv_height = ((y_height + 1) >> 1); double sse = 0., count = 0.; for (y = 0; y < y_height; ++y) { count += y_width; row_idx = y * y_width; for (x = 0; x < y_width; ++x) { double diff = Y1[row_idx + x] - Y2[row_idx + x]; sse += diff * diff; } } for (y = 0; y < uv_height; ++y) { count += 2 * uv_width; row_idx = y * uv_width; for (x = 0; x < uv_width; ++x) { const double diff_U = U1[row_idx + x] - U2[row_idx + x]; const double diff_V = V1[row_idx + x] - V2[row_idx + x]; sse += diff_U * diff_U + diff_V * diff_V; } } return -4.3429448 * log(sse / (255. * 255. * count)); } /* Returns the difference (in dB) between two images. One represented * using Y,U,V vectors and the other is webp image data. * Input: * Y1/U1/V1: The Y/U/V data of the first image * imgdata: data buffer containing webp image * imgdata_size: size of the imgdata buffer * * Returns the PSNR value computed bewteen the two images */ double WebPGetPSNR(const uint8* Y1, const uint8* U1, const uint8* V1, uint8* imgdata, int imgdata_size) { uint8* Y2 = NULL; uint8* U2 = NULL; uint8* V2 = NULL; int w = 0, h = 0; double psnr = 0; WebPDecode(imgdata, imgdata_size, &Y2, &U2, &V2, &w, &h); psnr = GetPSNRYuv(Y1, U1, V1, Y2, U2, V2, w, h); free(Y2); return psnr; } /*---------------------------------------------------------------------* * Reading WebP * *---------------------------------------------------------------------*/ /* RIFF layout is: * 0ffset tag * 0...3 "RIFF" 4-byte tag * 4...7 size of image data (including metadata) starting at offset 8 * 8...11 "WEBP" our form-type signature * 12..15 "VP8 " 4-byte tags, describing the raw video format used * 16..19 size of the raw WebP image data, starting at offset 20 * 20.... the WebP bytes * There can be extra chunks after the "VP8 " chunk (ICMT, ICOP, ...) * All 32-bits sizes are in little-endian order. * Note: chunk data must be padded to multiple of 2 in size */ int SkipRiffHeader(const uint8** data_ptr, int *data_size_ptr) { /* 20 bytes RIFF header 10 bytes VP8 header */ const int kHeaderSize = (20 + 10); uint32 chunk_size = 0xffffffffu; if (*data_size_ptr >= kHeaderSize && !memcmp(*data_ptr, "RIFF", 4)) { if (memcmp(*data_ptr + 8, "WEBP", 4)) { return 0; /* wrong image file signature */ } else { const uint32 riff_size = get_le32(*data_ptr + 4); if (memcmp(*data_ptr + 12, "VP8 ", 4)) { return 0; /* invalid compression format */ } chunk_size = get_le32(*data_ptr + 16); if ((chunk_size > riff_size + 8) || (chunk_size & 1)) { return 0; /* inconsistent size information. */ } /* We have a RIFF container. Skip it. */ *data_ptr += 20; *data_size_ptr -= 20; } } return chunk_size; } /* Generate RGBA row from an YUV row (with width upsampling of chrome data) * Input: * 1, 2, 3. y_src, u_src, v_src - Pointers to input Y, U, V row data * respectively. We reuse these variables, they iterate over all pixels in * the row. * 4. y_width: width of the Y image plane (aka image width) * Output: * 5. rgb_dst: pointer to the output rgb row. We reuse this variable, it * iterates over all pixels in the row. */ static void YUV420toRGBLine(uint8* y_src, uint8* u_src, uint8* v_src, int y_width, uint32* rgb_dst) { int x; for (x = 0; x < (y_width >> 1); ++x) { const int U = u_src[0]; const int V = v_src[0]; ToRGB(y_src[0], U, V, rgb_dst); ToRGB(y_src[1], U, V, rgb_dst + 1); ++u_src; ++v_src; y_src += 2; rgb_dst += 2; } if (y_width & 1) { /* Rightmost pixel */ ToRGB(y_src[0], (*u_src), (*v_src), rgb_dst); } } /* Converts from YUV (with color subsampling) such as produced by the WebPDecode * routine into 32 bits per pixel RGBA data array. This data array can be * directly used by the Leptonica Pix in-memory image format. * Input: * 1, 2, 3. Y, U, V: the input data buffers * 4. pixwpl: the desired words per line corresponding to the supplied * output pixdata. * 5. width, height: the dimensions of the image whose data resides in Y, * U, V. * Output: * 6. pixdata: the output data buffer. Caller should allocate * height * pixwpl bytes of memory before calling this routine. */ void YUV420toRGBA(uint8* Y, uint8* U, uint8* V, int words_per_line, int width, int height, uint32* pixdata) { int y_width = width; int y_stride = y_width; int uv_width = ((y_width + 1) >> 1); int uv_stride = uv_width; int y; if (!init_done) InitTables(); /* note that the U, V upsampling in height is happening here as the U, V * buffers sent to successive odd-even pair of lines is same. */ for (y = 0; y < height; ++y) { YUV420toRGBLine(Y + y * y_stride, U + (y >> 1) * uv_stride, V + (y >> 1) * uv_stride, width, pixdata + y * words_per_line); } } void gd_YUV420toRGBA(uint8* Y, uint8* U, uint8* V, gdImagePtr im) { int width = im->sx; int height = im->sy; int y_width = width; int y_stride = y_width; int uv_width = ((y_width + 1) >> 1); int uv_stride = uv_width; int y; /* output im must be truecolor */ if (!im->trueColor) { return; } if (!init_done) InitTables(); /* note that the U, V upsampling in height is happening here as the U, V * buffers sent to successive odd-even pair of lines is same. */ for (y = 0; y < height; ++y) { YUV420toRGBLine(Y + y * y_stride, U + (y >> 1) * uv_stride, V + (y >> 1) * uv_stride, width, (uint32 *)im->tpixels[y]); } } static WebPResult VPXDecode(const uint8* data, int data_size, uint8** p_Y, uint8** p_U, uint8** p_V, int* p_width, int* p_height) { vpx_codec_ctx_t dec; vp8_postproc_cfg_t ppcfg; WebPResult result = webp_failure; if (!data || data_size <= 10 || !p_Y || !p_U || !p_V || *p_Y != NULL || *p_U != NULL || *p_V != NULL) { return webp_failure; } if (vpx_codec_dec_init(&dec, &vpx_codec_vp8_dx_algo, NULL, 0) != VPX_CODEC_OK) { return webp_failure; } ppcfg.post_proc_flag = VP8_NOFILTERING; vpx_codec_control(&dec, VP8_SET_POSTPROC, &ppcfg); if (vpx_codec_decode(&dec, data, data_size, NULL, 0) == VPX_CODEC_OK) { vpx_codec_iter_t iter = NULL; vpx_image_t* const img = vpx_codec_get_frame(&dec, &iter); if (img) { int y_width = img->d_w; int y_height = img->d_h; int y_stride = y_width; int uv_width = (y_width + 1) >> 1; int uv_stride = uv_width; int uv_height = ((y_height + 1) >> 1); int y; *p_width = y_width; *p_height = y_height; if ((*p_Y = (uint8 *)(calloc(y_stride * y_height + 2 * uv_stride * uv_height, sizeof(uint8)))) != NULL) { *p_U = *p_Y + y_height * y_stride; *p_V = *p_U + uv_height * uv_stride; for (y = 0; y < y_height; ++y) { memcpy(*p_Y + y * y_stride, img->planes[0] + y * img->stride[0], y_width); } for (y = 0; y < uv_height; ++y) { memcpy(*p_U + y * uv_stride, img->planes[1] + y * img->stride[1], uv_width); memcpy(*p_V + y * uv_stride, img->planes[2] + y * img->stride[2], uv_width); } result = webp_success; } } } vpx_codec_destroy(&dec); return result; } WebPResult WebPDecode(const uint8* data, int data_size, uint8** p_Y, uint8** p_U, uint8** p_V, int* p_width, int* p_height) { const uint32 chunk_size = SkipRiffHeader(&data, &data_size); if (!chunk_size) { return webp_failure; /* unsupported RIFF header */ } return VPXDecode(data, data_size, p_Y, p_U, p_V, p_width, p_height); } /*---------------------------------------------------------------------* * Writing WebP * *---------------------------------------------------------------------*/ /* Takes a pair of RGBA row data as input and generates 2 rows of Y data and one * row of subsampled U, V data as output * Input: * 1, 2. rgb_line1, rgb_line2 - input rgba rows * 3. width - image width * Outout: * 4, 5, 6: Output Y, U, V row */ static void RGBALinepairToYUV420(uint32* rgb_line1, uint32* rgb_line2, int width, uint8* Y_dst1, uint8* Y_dst2, uint8* u_dst, uint8* v_dst) { int x; for (x = (width >> 1); x > 0; --x) { const int sum_r = GetRed(rgb_line1 + 0) + GetRed(rgb_line1 + 1) + GetRed(rgb_line2 + 0) + GetRed(rgb_line2 + 1); const int sum_g = GetGreen(rgb_line1 + 0) + GetGreen(rgb_line1 + 1) + GetGreen(rgb_line2 + 0) + GetGreen(rgb_line2 + 1); const int sum_b = GetBlue(rgb_line1 + 0) + GetBlue(rgb_line1 + 1) + GetBlue(rgb_line2 + 0) + GetBlue(rgb_line2 + 1); Y_dst1[0] = GetLumaYfromPtr(rgb_line1 + 0); Y_dst1[1] = GetLumaYfromPtr(rgb_line1 + 1); Y_dst2[0] = GetLumaYfromPtr(rgb_line2 + 0); Y_dst2[1] = GetLumaYfromPtr(rgb_line2 + 1); *u_dst++ = GetChromaU(sum_r, sum_g, sum_b); *v_dst++ = GetChromaV(sum_r, sum_g, sum_b); rgb_line1 += 2; rgb_line2 += 2; Y_dst1 += 2; Y_dst2 += 2; } if (width & 1) { /* rightmost pixel. */ const int sum_r = GetRed(rgb_line1) + GetRed(rgb_line2); const int sum_g = GetGreen(rgb_line1) + GetGreen(rgb_line2); const int sum_b = GetBlue(rgb_line1) + GetBlue(rgb_line2); Y_dst1[0] = GetLumaYfromPtr(rgb_line1); Y_dst2[0] = GetLumaYfromPtr(rgb_line2); *u_dst = GetChromaU(2 * sum_r, 2 * sum_g, 2 * sum_b); *v_dst = GetChromaV(2 * sum_r, 2 * sum_g, 2 * sum_b); } } /* Generates Y, U, V data (with color subsampling) from 32 bits * per pixel RGBA data buffer. The resulting YUV data can be directly fed into * the WebPEncode routine. * Input: * 1. pixdatainput rgba data buffer * 2. words per line corresponding to pixdata * 3, 4. image width and height respectively * Output: * 5, 6, 7. Output YUV data buffers */ void gd_RGBAToYUV420(gdImagePtr im2, uint8* Y, uint8* U, uint8* V) { int y_width = im2->sx; int y_height = im2->sy; int y_stride = y_width; int uv_width = ((y_width + 1) >> 1); int uv_stride = uv_width; int y; gdImagePtr im = NULL; int free_im = 0; if (!im2->trueColor) { /* Todo: Replace the color/YUV functions with our own and simplify that should boost the conversion a bit as well, not only for palette image. */ im = gdImageCreateTrueColor(im2->sx, im2->sy); if (!im) { gd_error("gd-webp error: cannot convert palette input to truecolor"); return; } gdImageCopy(im, im2, 0, 0, 0, 0, im->sx, im->sy); free_im = 1; } else { im = im2; } for (y = 0; y < (y_height >> 1); ++y) { RGBALinepairToYUV420((uint32 *)im->tpixels[2 * y], (uint32 *)im->tpixels[2 * y + 1], y_width, Y + 2 * y * y_stride, Y + (2 * y + 1) * y_stride, U + y * uv_stride, V + y * uv_stride); } if (y_height & 1) { RGBALinepairToYUV420((uint32 *)im->tpixels[y_height - 1], (uint32 *)im->tpixels[y_height - 1], y_width, Y + (y_height - 1) * y_stride, Y + (y_height - 1) * y_stride, U + (y_height >> 1) * uv_stride, V + (y_height >> 1) * uv_stride); } if (free_im) { gdImageDestroy(im); } } /* Generates Y, U, V data (with color subsampling) from 32 bits * per pixel RGBA data buffer. The resulting YUV data can be directly fed into * the WebPEncode routine. * Input: * 1. pixdatainput rgba data buffer * 2. words per line corresponding to pixdata * 3, 4. image width and height respectively * Output: * 5, 6, 7. Output YUV data buffers */ void RGBAToYUV420(uint32* pixdata, int words_per_line, int width, int height, uint8* Y, uint8* U, uint8* V) { int y_width = width; int y_height = height; int y_stride = y_width; int uv_width = ((y_width + 1) >> 1); int uv_stride = uv_width; int y; for (y = 0; y < (y_height >> 1); ++y) { RGBALinepairToYUV420(pixdata + 2 * y * words_per_line, pixdata + (2 * y + 1) * words_per_line, y_width, Y + 2 * y * y_stride, Y + (2 * y + 1) * y_stride, U + y * uv_stride, V + y * uv_stride); } if (y_height & 1) { RGBALinepairToYUV420(pixdata + (y_height - 1) * words_per_line, pixdata + (y_height - 1) * words_per_line, y_width, Y + (y_height - 1) * y_stride, Y + (y_height - 1) * y_stride, U + (y_height >> 1) * uv_stride, V + (y_height >> 1) * uv_stride); } } static int codec_ctl(vpx_codec_ctx_t *enc, enum vp8e_enc_control_id id, int value) { const vpx_codec_err_t res = vpx_codec_control_(enc, id, value); if (res != VPX_CODEC_OK) { return webp_failure; } return webp_success; } static void SetupParams(vpx_codec_enc_cfg_t* cfg, int QP) { cfg->g_threads = 2; cfg->rc_min_quantizer = QP; cfg->rc_max_quantizer = QP; cfg->kf_mode = VPX_KF_FIXED; } /* VPXEncode: Takes a Y, U, V data buffers (with color components U and V * subsampled to 1/2 resolution) and generates the VPX string. * Output VPX string is placed in the *p_out buffer. container_size * indicates number of bytes to be left blank at the beginning of * *p_out buffer to accommodate for a container header. * * Return: success/failure */ static WebPResult VPXEncode(const uint8* Y, const uint8* U, const uint8* V, int y_width, int y_height, int y_stride, int uv_width, int uv_height, int uv_stride, int QP, int container_size, unsigned char** p_out, int* p_out_size_bytes) { vpx_codec_iface_t* iface = &vpx_codec_vp8_cx_algo; vpx_codec_err_t res; vpx_codec_enc_cfg_t cfg; vpx_codec_ctx_t enc; WebPResult result = webp_failure; vpx_image_t img; *p_out = NULL; *p_out_size_bytes = 0; /* validate input parameters. */ if (!p_out || !Y || !U || !V || y_width <= 0 || y_height <= 0 || uv_width <= 0 || uv_height <= 0 || y_stride < y_width || uv_stride < uv_width || QP < 0 || QP > 63) { return webp_failure; } res = vpx_codec_enc_config_default(iface, &cfg, 0); if (res != VPX_CODEC_OK) { return webp_failure; } SetupParams(&cfg, QP); cfg.g_w = y_width; cfg.g_h = y_height; res = vpx_codec_enc_init(&enc, iface, &cfg, 0); if (res == VPX_CODEC_OK) { codec_ctl(&enc, VP8E_SET_CPUUSED, 3); codec_ctl(&enc, VP8E_SET_NOISE_SENSITIVITY, 0); codec_ctl(&enc, VP8E_SET_SHARPNESS, 0); codec_ctl(&enc, VP8E_SET_ENABLEAUTOALTREF, 0); codec_ctl(&enc, VP8E_SET_ARNR_MAXFRAMES, 0); codec_ctl(&enc, VP8E_SET_ARNR_TYPE, 0); codec_ctl(&enc, VP8E_SET_ARNR_STRENGTH, 0); codec_ctl(&enc, VP8E_SET_STATIC_THRESHOLD, 0); codec_ctl(&enc, VP8E_SET_TOKEN_PARTITIONS, 2); vpx_img_wrap(&img, IMG_FMT_I420, y_width, y_height, 16, (uint8*)(Y)); img.planes[PLANE_Y] = (uint8*)(Y); img.planes[PLANE_U] = (uint8*)(U); img.planes[PLANE_V] = (uint8*)(V); img.stride[PLANE_Y] = y_stride; img.stride[PLANE_U] = uv_stride; img.stride[PLANE_V] = uv_stride; res = vpx_codec_encode(&enc, &img, 0, 1, 0, VPX_DL_BEST_QUALITY); if (res == VPX_CODEC_OK) { vpx_codec_iter_t iter = NULL; const vpx_codec_cx_pkt_t* pkt = vpx_codec_get_cx_data(&enc, &iter); if (pkt != NULL) { *p_out = (unsigned char*)(calloc(container_size + pkt->data.frame.sz, 1)); memcpy(*p_out + container_size, (const void*)(pkt->data.frame.buf), pkt->data.frame.sz); *p_out_size_bytes = container_size + pkt->data.frame.sz; result = webp_success; } } } vpx_codec_destroy(&enc); return result; } WebPResult WebPEncode(const uint8* Y, const uint8* U, const uint8* V, int y_width, int y_height, int y_stride, int uv_width, int uv_height, int uv_stride, int QP, unsigned char** p_out, int* p_out_size_bytes, double *psnr) { const int kRiffHeaderSize = 20; if (VPXEncode(Y, U, V, y_width, y_height, y_stride, uv_width, uv_height, uv_stride, QP, kRiffHeaderSize, p_out, p_out_size_bytes) != webp_success) { return webp_failure; } else { /* Write RIFF header */ const int img_size_bytes = *p_out_size_bytes - kRiffHeaderSize; const int chunk_size = (img_size_bytes + 1) & ~1; /* make size even */ const int riff_size = chunk_size + 12; const uint8_t kRiffHeader[20] = { 'R', 'I', 'F', 'F', (riff_size >> 0) & 255, (riff_size >> 8) & 255, (riff_size >> 16) & 255, (riff_size >> 24) & 255, 'W', 'E', 'B', 'P', 'V', 'P', '8', ' ', (chunk_size >> 0) & 255, (chunk_size >> 8) & 255, (chunk_size >> 16) & 255, (chunk_size >> 24) & 255 }; memcpy(*p_out, kRiffHeader, kRiffHeaderSize); if (psnr) { *psnr = WebPGetPSNR(Y, U, V, *p_out, *p_out_size_bytes); } return webp_success; } } void AdjustColorspace(uint8* Y, uint8* U, uint8* V, int width, int height) { int y_width = width; int y_height = height; int y_stride = y_width; int uv_width = ((y_width + 1) >> 1); int uv_height = ((y_height + 1) >> 1); int uv_stride = uv_width; int x, y; /* convert luma */ for (y = 0; y < y_height; ++y) { uint8* const Yrow = Y + y * y_stride; for (x = 0; x < y_width; ++x) { /* maps [0..255] to [16..235] */ Yrow[x] = ((Yrow[x] * 55 + 32) >> 6) + 16; } } /* convert chroma */ for (y = 0; y < uv_height; ++y) { uint8* const Urow = U + y * uv_stride; uint8* const Vrow = V + y * uv_stride; for (x = 0; x < uv_width; ++x) { /* maps [0..255] to [16..240] */ Urow[x] = (((Urow[x] - 127) * 7) >> 3) + 128; Vrow[x] = (((Vrow[x] - 127) * 7) >> 3) + 128; } } } void AdjustColorspaceBack(uint8* Y, uint8* U, uint8* V, int width, int height) { int y_width = width; int y_height = height; int y_stride = y_width; int uv_width = ((y_width + 1) >> 1); int uv_height = ((y_height + 1) >> 1); int uv_stride = uv_width; int x, y; /* convert luma */ for (y = 0; y < y_height; ++y) { uint8* const Yrow = Y + y * y_stride; for (x = 0; x < y_width; ++x) { /* maps [16..235] to [0..255] */ const int v = ((Yrow[x] - 16) * 149 + 64) >> 7; Yrow[x] = (v < 0) ? 0 : (v > 255) ? 255u : v; } } /* convert chroma */ for (y = 0; y < uv_height; ++y) { uint8* const Urow = U + y * uv_stride; uint8* const Vrow = V + y * uv_stride; for (x = 0; x < uv_width; ++x) { /* maps [0..255] to [16..240] */ const int ru = (((Urow[x] - 128) * 73) >> 6) + 128; const int rv = (((Vrow[x] - 128) * 73) >> 6) + 128; Urow[x] = (ru < 0) ? 0 : (ru > 255) ? 255u : ru; Vrow[x] = (rv < 0) ? 0 : (rv > 255) ? 255u : rv; } } } WebPResult WebPGetInfo(const uint8* data, int data_size, int *width, int *height) { const uint32 chunk_size = SkipRiffHeader(&data, &data_size); if (width) *width = 0; if (height) *height = 0; if (!chunk_size) { return webp_failure; /* unsupported RIFF header */ } /* Validate raw video data */ if (data_size < 10) { return webp_failure; /* not enough data */ } /* check signature */ if (data[3] != 0x9d || data[4] != 0x01 || data[5] != 0x2a) { return webp_failure; /* Wrong signature. */ } else { const uint32 bits = data[0] | (data[1] << 8) | (data[2] << 16); if ((bits & 1)) { /* Not a keyframe. */ return webp_failure; } else { const int profile = (bits >> 1) & 7; const int show_frame = (bits >> 4) & 1; const uint32 partition_length = (bits >> 5); if (profile > 3) { return webp_failure; /* unknown profile */ } if (!show_frame) { return webp_failure; /* first frame is invisible! */ } if (partition_length >= chunk_size) { return webp_failure; /* inconsistent size information. */ } else { const int w = ((data[7] << 8) | data[6]) & 0x3fff; const int h = ((data[9] << 8) | data[8]) & 0x3fff; if (width) *width = w; if (height) *height = h; return webp_success; } } } return webp_failure; } #endif /* HAVE_LIBVPX */ libgd-gd-2.1.1/src/webpimg.h000066400000000000000000000160461245535672000155760ustar00rootroot00000000000000/*===========================================================================* - Copyright 2010 Google Inc. - - This code is licensed under the same terms as WebM: - Software License Agreement: http://www.webmproject.org/license/software/ - Additional IP Rights Grant: http://www.webmproject.org/license/additional/ *===========================================================================*/ /* * Encoding/Decoding of WebP still image compression format. * * 1. WebPDecode: Takes an array of bytes (string) corresponding to the WebP * encoded image and generates output in the YUV format with * the color components U, V subsampled to 1/2 resolution along * each dimension. * * 2. YUV420toRGBA: Converts from YUV (with color subsampling) such as produced * by the WebPDecode routine into 32 bits per pixel RGBA data * array. This data array can be directly used by the Leptonica * Pix in-memory image format. * * 3. WebPEncode: Takes a Y, U, V data buffers (with color components U and V * subsampled to 1/2 resolution) and generates the WebP string * * 4. RGBAToYUV420: Generates Y, U, V data (with color subsampling) from 32 bits * per pixel RGBA data buffer. The resulting YUV data can be * directly fed into the WebPEncode routine. * * 5. AdjustColorspace: * * 6. AdjustColorspaceBack: */ #ifndef THIRD_PARTY_VP8_VP8IMG_H_ #define THIRD_PARTY_VP8_VP8IMG_H_ #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ typedef unsigned char uint8; typedef unsigned int uint32; typedef enum WebPResultType { webp_success = 0, webp_failure = -1 } WebPResult; /* Takes an array of bytes (string) corresponding to the WebP * encoded image and generates output in the YUV format with * the color components U, V subsampled to 1/2 resolution along * each dimension. * Input: * 1. data: the WebP data stream (array of bytes) * 2. data_size: count of bytes in the WebP data stream * * Output: * 3. p_Y/p_U/p_V : pointer to the Y/U/V data buffer (this routine will * allocate memory for the buffer, fill the buffer with * appropriate data and transfer owner ship of the buffer * to caller. Caller is reponsible for freeing the memory). * Note that the memory for Y, U, V buffers is alloacted * in one chunk, hence one should call free(*p_Y) only. * Do not try to free the U and V buffers. * * 6. p_width: this routine returns the width of the decoded image here * 7. p_height: this routine returns the width of the decoded image here * Return: success/failure */ WebPResult WebPDecode(const uint8* data, int data_size, uint8** p_Y, uint8** p_U, uint8** p_V, int* p_width, int* p_height); /* WebPEncode: Takes a Y, U, V data buffers (with color components U and V * subsampled to 1/2 resolution) and generates the WebP string. * Input: * 1, 2, 3. Y, U, V: The input YUV data buffers * 4, 5. y_width, y_height: The width and height of the image whose data * is in Y, U, V. This matches the Y plane. The U * and V planes typically have 1/2 width and * height. * 6. y_stride: The width (in bytes) of one row of Y data. This may not * match width if there is end of row padding (e.g., for 32 * bit row aligment). * 7. QP: the quantization parameter. This parameter controls the * compression vs quality tradeoff. Use smaller numbers for better * quality (compression will be lesser) and vice versa. 20 is a * good optimal value. * Output: * 8. p_out: the output array of bytes corresponding to the encoded WebP * image. This routine allocates memory for the buffer, fills it * with appropriate values and transfers ownership to caller. * Caller responsible for freeing of memory. * Return: success/failure */ WebPResult WebPEncode(const uint8* Y, const uint8* U, const uint8* V, int y_width, int y_height, int y_stride, int uv_width, int uv_height, int uv_stride, int QP, unsigned char** p_out, int* p_out_size_bytes, double* psnr); /* Converts from YUV (with color subsampling) such as produced by the WebPDecode * routine into 32 bits per pixel RGBA data array. This data array can be * directly used by the Leptonica Pix in-memory image format. * Input: * 1, 2, 3. Y, U, V: the input data buffers * 4. pixwpl: the desired words per line corresponding to the supplied * output pixdata. * 5. width, height: the dimensions of the image whose data resides in Y, * U, V. * Output: * 6. pixdata: the output data buffer. Caller should allocate * height * pixwpl bytes of memory before calling this routine. */ void YUV420toRGBA(uint8* Y, uint8* U, uint8* V, int words_per_line, int width, int height, uint32* pixdata); /* Generates Y, U, V data (with color subsampling) from 32 bits * per pixel RGBA data buffer. The resulting YUV data can be directly fed into * the WebPEncode routine. * Input: * 1. pix data input rgba data buffer * 2. words per line corresponding to pixdata * 3, 4. image width and height respectively * Output: * 5, 6, 7. Output YUV data buffers */ void RGBAToYUV420(uint32* pixdata, int words_per_line, int width, int height, uint8* Y, uint8* U, uint8* V); /* This function adjust from YUV420J (jpeg decoding) to YUV420 (webp input) * Hints: http://en.wikipedia.org/wiki/YCbCr */ void AdjustColorspace(uint8* Y, uint8* U, uint8* V, int width, int height); /* Inverse function: convert from YUV420 to YUV420J */ void AdjustColorspaceBack(uint8* Y, uint8* U, uint8* V, int width, int height); /* Checks WebP image header and outputs height and width information of * the image * * Input: * 1. data: the WebP data stream (array of bytes) * 2. data_size: count of bytes in the WebP data stream * * Outut: * width/height: width and height of the image * * Return: success/failure */ WebPResult WebPGetInfo(const uint8* data, int data_size, int *width, int *height); #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* THIRD_PARTY_VP8_VP8IMG_H_ */ libgd-gd-2.1.1/src/webpng.c000066400000000000000000000142661245535672000154230ustar00rootroot00000000000000#ifdef HAVE_CONFIG_H #include "config.h" #endif /* Bring in the gd library functions */ #include "gd.h" /* Bring in standard I/O and string manipulation functions */ #include #include /* for atoi() */ #include #ifdef _WIN32 #include int getpid () { return _getpid (); } #else #include /* for getpid(), unlink() */ #endif int main (int argc, char **argv) { FILE *in; FILE *out; char outFn[20]; int useStdinStdout = 0; /* Declare our image pointer */ gdImagePtr im = 0; int i; /* We'll clear 'no' once we know the user has made a reasonable request. */ int no = 1; /* We'll set 'write' once we know the user's request requires that the image be written back to disk. */ int write = 0; /* C programs always get at least one argument; we want at least one more (the image), more in practice. */ if (argc < 2 || !strcmp (argv[1], "--help")) { no = 1; goto usage; } /* The last argument should be the image. Open the file. */ if (strcmp ("-", argv[argc - 1]) == 0) { /* - is synonymous with STDIN */ useStdinStdout = 1; in = stdin; } else { in = fopen (argv[argc - 1], "rb"); } if (!in) { fprintf(stderr, "can't open file %s.\n", argv[argc - 1]); exit (1); } /* Now load the image. */ #ifdef HAVE_LIBPNG im = gdImageCreateFromPng (in); #else fprintf(stderr, "No PNG library support.\n"); #endif fclose (in); /* If the load failed, it must not be a PNG file. */ if (!im) { fprintf (stderr, "Error: %s is not a valid PNG file.\n", argv[argc - 1]); exit (1); } /* Consider each argument in turn. */ for (i = 1; (i < (argc - 1)); i++) { /* -i turns on and off interlacing. */ if (!strcmp (argv[i], "--help")) { /* Every program should use this for help! :) */ no = 1; goto usage; } else if (!strcmp (argv[i], "-i")) { if (i == (argc - 2)) { fprintf(stderr, "-i specified without y or n.\n"); no = 1; goto usage; } if (!strcmp (argv[i + 1], "y")) { /* Set interlace. */ gdImageInterlace (im, 1); } else if (!strcmp (argv[i + 1], "n")) { /* Clear interlace. */ gdImageInterlace (im, 0); } else { fprintf(stderr, "Error: -i specified without y or n.\n"); no = 1; goto usage; } i++; no = 0; write = 1; } else if (!strcmp (argv[i], "-t")) { /* Set transparent index (or none). */ int index; if (i == (argc - 2)) { fprintf (stderr, "Error: -t specified without a color table index.\n"); no = 1; goto usage; } if (!strcmp (argv[i + 1], "none")) { /* -1 means not transparent. */ gdImageColorTransparent (im, -1); } else { /* OK, get an integer and set the index. */ index = atoi (argv[i + 1]); gdImageColorTransparent (im, index); } i++; write = 1; no = 0; } else if (!strcmp (argv[i], "-l")) { /* List the colors in the color table. */ int j; if (!im->trueColor) { /* Tabs used below. */ printf ("Index Red Green Blue Alpha\n"); for (j = 0; (j < gdImageColorsTotal (im)); j++) { /* Use access macros to learn colors. */ printf ("%d %d %d %d %d\n", j, gdImageRed (im, j), gdImageGreen (im, j), gdImageBlue (im, j), gdImageAlpha (im, j)); } } else { printf ("Truecolor image, no palette entries to list.\n"); } no = 0; } else if (!strcmp (argv[i], "-d")) { /* Output dimensions, etc. */ int t; printf ("Width: %d Height: %d Colors: %d\n", gdImageSX (im), gdImageSY (im), gdImageColorsTotal (im)); t = gdImageGetTransparent (im); if (t != (-1)) { printf ("First 100%% transparent index: %d\n", t); } else { /* -1 means the image is not transparent. */ printf ("First 100%% transparent index: none\n"); } if (gdImageGetInterlaced (im)) { printf ("Interlaced: yes\n"); } else { printf ("Interlaced: no\n"); } no = 0; } else if (!strcmp (argv[i], "-a")) { /* Alpha channel info -- thanks to Wez Furlong */ int maxx, maxy, x, y, alpha, pix, nalpha = 0; maxx = gdImageSX (im); maxy = gdImageSY (im); printf ("alpha channel information:\n"); if (im->trueColor) { for (y = 0; y < maxy; y++) { for (x = 0; x < maxx; x++) { pix = gdImageGetPixel (im, x, y); alpha = gdTrueColorGetAlpha (pix); if (alpha > gdAlphaOpaque) { /* Use access macros to learn colors. */ printf ("%d %d %d %d\n", gdTrueColorGetRed (pix), gdTrueColorGetGreen (pix), gdTrueColorGetBlue (pix), alpha); nalpha++; } } } } else printf ("NOT a true color image\n"); no = 0; printf ("%d alpha channels\n", nalpha); } else { fprintf(stderr, "Unknown argument: %s\n", argv[i]); break; } } usage: if (no) { /* If the command failed, output an explanation. */ fprintf (stderr, "Usage: webpng [-i y|n ] [-l] [-t index|none ] [-d] pngname.png\n" " -i [y|n] Turns on/off interlace\n" " -l Prints the table of color indexes\n" " -t [index] Set the transparent color to the specified index (0-255 or \"none\")\n" " -d Reports the dimensions and other characteristics of the image.\n" " -a Prints all alpha channels that are not 100%% opaque.\n" "\n" "If you specify '-' as the input file, stdin/stdout will be used input/output.\n"); } if (write) { if (useStdinStdout) { out = stdout; } else { /* Open a temporary file. */ /* "temp.tmp" is not good temporary filename. */ sprintf (outFn, "webpng.tmp%d", getpid ()); out = fopen (outFn, "wb"); if (!out) { fprintf(stderr, "Unable to write to %s -- exiting\n", outFn); exit (1); } } /* Write the new PNG. */ #ifdef HAVE_LIBPNG gdImagePng (im, out); #else fprintf(stderr, "No PNG library support.\n"); #endif if (!useStdinStdout) { fclose (out); /* Erase the old PNG. */ unlink (argv[argc - 1]); /* Rename the new to the old. */ if (rename (outFn, argv[argc - 1]) != 0) { perror ("rename"); exit (1); } } } /* Delete the image from memory. */ if (im) { gdImageDestroy (im); } /* All's well that ends well. */ return 0; } libgd-gd-2.1.1/test/000077500000000000000000000000001245535672000141545ustar00rootroot00000000000000libgd-gd-2.1.1/test/gdtest.gd2000066400000000000000000000677651245535672000160710ustar00rootroot00000000000000gd25h I<CR "* 5z&:C nMqTt `lcfSi knd sr@@x:i $@@5@@0t@`s @@s@Fp`z$@@Ph@~,@`@s@`q@@r@$@] @@lfV< @@xs@@`$@z@`rq@@< @r@pz@P$@@@A@ @ss@@(`r$@@z@ @ @pzz@@P}@@ @A @@s@}s@@~,`@@~`,@@pz`@@s @@E@; @@~ ,@@`t@@s@@X@ @@9͙ V@p&z@@~P , @@@`@xڱ C46r=͟A/¶}e+ġ?>>>>>>>>>>>>>>MM %m}@_+/EH} } V$roJ =܉AD|||y~.ge]eD||||2Qx @I@GʢmsC[r.|я?j#?.?~_|`/SZpoqZhO 0௘/ @?+@ϟ6&f-GI>;gHژlH\7PX1F 3ˑu??|1dRX3 s*͌' ?FIj6!_7$p޳<1=[(ڥ,+G>kY\%Vԛ-]l,p1g<,A5&*/_nd3k,c*GK_x'S,U7|};Յ+yN|x{Y~n_+%_5r3[ ,q> [O9} ;r]%Uba5>pJ ^bI3R8)7Q=`%i0ϥ>Z.kYh}m\s?[loEPCP eexVgOŐ`hlj*{\=DI([.6jY9bɩj¹!=(|[J!A`͏|yE&G vcẼ ?Rt|r{ S''_`怜1;'A.?2el< _"FAWx1c~ S* jO8@XԃrE#ѭ4;Nez kQK0g~= X$x]vMXe;H]N:|(Sc u&K(RcRņ?R@sƫ~p{`s:!/XyJcu?@Nso6<|4TxJ7㣷- @:VHqM]C<b6|82'Gm`: :40Zk|v+Tobɘ_鐤>͞o={fzb'ALw_Ix5X7#:>:^?vh"OM$|ԩ~˽W7 Yw| 3 ϯ>įxxc1e_MW"7e W/A4!<㗕iE Oh^z~g-8@o)?w8={ 1]/w n{>~ `ٶi?'W".6|tȃ[}oVc~!>~Qgƿ]]߾y@U139uӿ >w|.ϛ MQI`#oN΃/r:INfforzU e)+0fkĸWs 9(e#Gkj_;lP߾)lx~t ¥|ΘyJp[0s~.m"/"+_wne], r,n9;~wY|r(wrƧ*},&j1aU3^oɌ!<yЉR&T0y*9|~Gk:yKiU Z} ֿ0Qv qu xCV_~ h8 Svםc|IٯFoFL.# xW,sRN????}r?/__*ZXŨWRm;_ܛj&U˽?]iGu .FMO gӂtj6hQ}m1٪3>} 2HW'RZ2r(L]>3=nu>g{:%vLK..?BNP4CK 4 m@Fm}i~2{rw~ݩRLN1R$1h@U'brW³/[66 9# W|:-;)sg[ɽfx~*N"Z4tCb#uCAOxKşU1^*ڐsN%Xu3GX6>ǿ`ܡWA8+0gcO/Wdzh!|e{7Dԓ at451@ Y]mG{aؔ 9:Ba6dǠ^VF@43xٮPZR:iXEC3c?8ls09ɪR]F'bF<n1MMB.ӲW5B#)k6%Å'k/QC]usQ#t iAtLDaz<E9@X LU6^4lJQ&dj5ϴ]5(iР]X صbb-Jշ*?.3 ȅӟPȇ,&@c_%kfI3D˭df@z ^vHƬ ~//P@o$d `ZD*}#__D`dG`dkb=dIXذ!DP>,xn0P xtj4?uc//Ǥ~駟~駟~駟~? اP} 9Eğ׻~=x?t[?SW/@1~xM?0O?&' |||ɞ> 9 u&=% "xG{r_ky~t5?߿-߷:GZ_ku1R}WaJևվ} 0{D&oLAkV_ tn}U?hy;?@/6'D9T-͗.3GǗ[F؝yt'? /~M HZc p}r@.߈>>o5)˒h ]'"H|d<P&Լ?0Y%ØMbSt~jV 1;;X_t!|4p֟/Ӂ'2r ?۬ޠs`Wc~nM}ne1Ls@^>02_`ͤ["UI4{, qf 67pxdtٲl]Dh 04_Ϳ?kvPLO|D$3{ 9?YƐY0M9]t,c#_vɅ!QfPX| eggo7?Zr_p x8Ɵ +TM +@CVr:i|U{Xw|#vWN%S<ۭ 20o7xx y\b2M@5-8>@3Aʏ&ބ/  F 96>^ay/r$_nJ5¡EQ=w;#G&j8>F> JFrPH?cV{5J$UEv)AjC}Gd&9#$U$Q[# !~ƿUa~$P䞐}<%~_"YhSTօ}|k4xS#O%[{CPP|>k^_,ܧt'Gu;w/rTu?.z ^F_q!]'|;5y$Hn-kcქ^}]([]FQ-l+?LfFnսӹ.h#Ҫ?kRv_oqʏLT741&G5|D}>ࠁ.m|C^qXv#YNG]Nt'LOYޖ$ޓZ> o/ۢnd,_ wlj_?ol ~\'ׯ] g&̇ozS" $~^}&'[X' */Oo+? 8Izi;40ewxހԤmܻ+^5"~p߯0 >X֠oH~)?ֈV#I{/)˞d/;j{$a󭆯?(%~ wҨXNo_]Ѱ>{+V Nϻ+GRUjT4[{㶚x"~q7֟#ʣU,gY*WvvPo+*8̄ɐ $qP-QRyvw ܮ/N6!/L*|iwݚ@YB5o~&x P$mT6wWhW O>b:w76s3UEF)jJ`z4o>ߠ)sEuB]ogMl֋ ƞ j+ߡD1WkRZاuֵfs [zNo)qd`c xo*1q-u{4]6UC廴fqʶ$8ᐮEn\O+>_S Ӯ~!BWrʏT]Ү9Db$1BWbA'8BD*ҭI_0=s(Sd>łV?ov6_o;ޱ6O%H Oݕ>p㣪˷L19_KFߏ`iLb=bS R5ƗY~<H@ Qj3廊YkjZJQj}=?YOC/}e̅u]lH?.&01BZOt$V6RQ5{|4(wokU}S>z әx0@f͛Y9>R^~77N^Kqy!Co^(X"h\7m6ğv3õwRO`ۤǃп{Ew\>+uRym{;kWcWa'o|hi742+xĚ ~ԛ ֪osI:X-s elsp ɳ{ֻ~xKp87g?3.iLH1}B]K,[ ?3?vP ڗr@y!^@;.-P }$8:4Dl8mܚH{zjR{A͗[[_&X9H%ivhlUHF6hORwS=D-03NC'>n|.v#>%b S'YSM%8*>?JL;G`|f '9uX>~ nG|7xvwAK;%ff|!|ukt~|rOXC>=v|kBFqƆs/mZOU 5R8~K,jsJH$YQ h"IJnh_KT*BF&9_:P떿6Gú*>[lDxhH]poph%'$n(7Wqj<ʇRtakZONJ_v0:hbjևSQ!SԌQq[:MpFTI_@A;M _nt6g_p3mMNcGL>ǯs/ s?~UkęÜ|gx[K: =K+Mt&7Yb0Mo@@ĪH^ߩ!Z]| +8d^EA+$c~=m#|~+F?V],! mV}{>M=)0{ a+"9a׆gZſoV $?{V aUp?(Q >:6[7,sӆ/P/劏c&M~7bYJ5Rih,WI@j lh?T|A DqM@RP%3xpqXP,(PzYV |)BtP7|Ruji8]Qd'(ҫ4ߒ3P`^Nl#n1;eG 0O4ـǞ\aŽ"QqwgtbxguҤbI[9[6< ؀*[X}sɜCgBBږ<3ȚygqV1HOo#*ek CJn&9&`쎖vKLb+&2'%$3g }!QLggvWQ`J,]c-W "sqez#UW?o&^]V/H#/Gmbuw:chH~MKKϚ6F8RlZVP5FGh? O/\GXG$aeMr͡@Ѽwpq,kW4㔏 ? ^>ր$T|De-o_@Zq uD0K4hԈC#̟-oIg!TkcࣟM6| a'j\:#f1:E07o]vnWFs]>wx).W؎{5"rΘ-ޮXkӖR~>]xҪbh<tᒂW6a $)10񴹮x!zݤcxoLOU兩5/1f#TtJ $J76D~&JT:=\Ca{ $qV[Eǯyʇr?E8Aw9 ѯ?ˣ|Wb֝,sn8B\?k1k<`y;E/L61o^z_~t%<-Ģ #ԉ;ѦF!KK}ݤ@evTUe x .]>7%AVs%Arޯ$'oe[ yi'+9Զ99}C~ 73-q}n `_koǛ87܂MuGy_^ /SxJzʙ1 y ^|YJ\@~{026"y3x+*&6a_XʺxAG;f|*'?# ~}B޺q_XrhSqW0G)|V ,V/I6 ƺ[le{3leS܀WZ;\<8=6,97 "Ȉߍ/p ^b=|AIyd@wEr+~bę/~Bgo?瞾'jԄsV;7Yb |Ty-i;3d}f\ S:uFKėRK*-fב8rU %chi%j'p☻NZZCǸp'Xr;-da}'NqjWvr>pǽ~7p(u 5CI`:(O{p{aB_;n>ʰ#"dybֺw3A%6tCM8`+n?eVjï/Yq yH{y ]'xZK lvJ󜕔EŪG(WϹW, J`2_#Qe QuFLvj% ye <*2W:/KT8iA 嵭[VZ .:=hkсO\,Ͽ,흢9=p( ;>]yT+| cیdKs}{MQ*Gn{jA{5TŮJ',) vbS*].#d[ m0#? Nxٶ0 E}siʅ,(im  "*s.  X%B+uF)  "E%9`„8Ijׂؚw*p,~s%4W!i{ODC^Uy猔tUۂ3ݔ){gmCa8kIYTIÈ0a{JH%NӹWݠxq2"~,!pN#3P]]+5(t(LҪ#T-*IQ X v1UΨtIgE~ؔ=7CIQk1%,0M54Vi'oDAtR=RCȻ:&ʯN0(ֽT;mvk GJgww*`SA9׾| vP֦=l6 юePF| Xд$Üla1B Yb)eJ$fdy@x,U*3Ӑ6ç/w BZr% ,Sr:fiCTjW %*C h-"§X( T-::I!.`VmB2k< |'43:B@4(~8s5ENА7\^ԫ{] >Kz2oP[Bms2|czhvn/#@g5z^ʊfdӛAC=P EݯwGZbZOEzohl%{AuzS_9Mq m SH7T/KT__"*G&S^$Ko/Չ\u˗_#d7_eRF><?_6y/'|h0e>!͹2 {' mh<D~(zXkE]~l]'υJ|ֲ}ͥEP#6[]e!6[8|4:̞痘p ) 0J!pf^ 6“*Hc_< ⯒`[“Pז~:K}FD.r\LɦZ'IƟ'f@(oBj`YFIwסU^1 mw>ñJ||iDa @'4v,&-l/Bi aěF(7Th)3يW|"Lgn.׼hT'ױgwm~OCmcYݍS ǁE6@ΊλJxvc $Wϙ.(?ᔑo;q"5?1RC3uTnz/\0uhOU7_k|3/G",`kݣ&`^2?u\8kffYw&>܊hl;@O|64\!GkN_!-5Zݽxv^域g뾗RS ? O* iCeǙpg3(6Z%&̘掠]_L.Q{970#>u. n>_'hHC\-y[d>ҿP>ԳK%0~{|l0:'vmg6g0*Aȧwbd񧁞@CV s":;Q4`O ˊY28W\c婳R2;֙YP1oZ0N<>LJm$^_K]Bt+}Zk^Z;N|}EeVe nv8(''9qe߾a,v]Ci*!{~1|K0.͆?Jiw[׶c/3/X]3teDWL!G, o)O r;t07﵌9 vJŵUZ#hPvq5;ga'zRIE6#滙׹"=9h@st/𫲆0˯JsCp,~m*G/U.I>k__)޵5A17Ss6_& `c໎1~}*~/ ȇeJv{ A24¾+5=ΤT<4ἇ:\C0{\7[`þֿb|,+-Xnڎqר !br `|w 1|ޙP(R)"e-YGsa?cUQLX:gz09n7FC(~.}.nI{׿4(qJ+?Ĉ\F_V^GRw_+W;?$A |2y+&.]dJio x[I6 _l%T]ZH&vzx}(È3`_s꺌Tx%U7x.=Qz~yP9BUঊ #JtTp85BDI9OH煀n5i[x'/X7R:ɋ39G/PsmG犲|;| "w.(:@w_ c _F炿wTo#7E' _-Yzy~z+2y b$xud+U2+H¨ I!;: ، )uf;o.Tr2/?dKQ~Lya( ,O;8K?Lկ]$|Y7Oڌ2BTy 9Bixʳ_BVG|_/Q<7 ޘ$C'Y"[]/`ׁ_+ArAcN!YB^U ¾+mQ\/zlw^R Rxk(U1S/EQ˧C OkUQRiҐ^#ؿ؜$C[Qwpy3D_|/(GIvB5Op;sMC\1Q9\޵O.g?`ܢK|yQ[` 3d!Zfo4a4V`,V=d߿>1v!j/ozPRl^~tM+G~  ,%Mk_fJIMYIκy%ۖPD^yR{ L0K} @aG06ka?g܎sZMG >F7KOcPI;da oX$|4[53+?%f3.:xc_Cdrk&cFlqH%SbNk G6g6a r̕[0PT^v m;*.RxҦ+>8 +dD|)F$& ]ӀIR؊<ſ Xo=A_%|!wyğ?ヘiAsz$0hQ+Zr N"$,0fsWT?h[6=pMcXu+/3RYϑ;#Pdh'|BS)1WeRQ:Z >P@M$2R/Kj >QO3:8K\e 4>‰ڣ7| Mzwx;QGkAg"Շjz@ } rټz E +67OÆ~fŊ\^8`?D޻rG}{z/Po o8XdXV ,kNTގ~ޅ,W[Tį$/O睓Οj8js,%q,u/u۪JL?\t}"k )R[I i5q<VxŚے @ y7Q F{3rѤ]% l;._POl=Pr_Hnr`#w IMU' _ "԰b>OeV0[o IcQhеv3?EoMڿ`^=Fh~kaPX 9@RŔ _1>ssjD"E fq9vg/M{t}')֨Եp>;hN"_N)MN}x)h˵q *#*5\*D@Dfk<>)pc_o~]BH x`CZ|7QJ)U~-K& _ 2UcB; _9+:w:$&,hc]ػMM)ޚU|/u0L|wz&m|D~2@a_[ aOU蒏Vx.V˶|/4R Lm+E s}7Oi>zP&Y=' #,( :' 5~`@tI㏅U^L]gwii{ Fw֠G-oޤÒ<|*k, #>?(&~y4h(+<(%KOZ:2Bqy)tՍqڢ'g_Ol3Ț;QUmiJ/|N/}g9un[j~͐<ۆa#C IA:ZƁrLS#; 5 Sȣ@ڭtLgT^3 cS`I'|#?h%ݾ>?qKgoB\Ag큿k=I&s]CN6vU'' >b*z$Is[_~Pz,x643'?z0E5N'Kz)`(k[{ʧoAf?U?*9>=xlwo:0 N#iyW %ؼ,.LV_±&[>ӎ]EqG7fs<.5>=()UsO柶أzd[h9`{2ծ1K[ã|կ%:w{Tc7Pk;n-&Xn`_k<0됱kQuf|┯\~ϑQ kqL?m{|Z4ep˽i+O!7sYΛxv֍ͥgGx~Z6ZPP_Fݲi@[t { ,?G\XlIxptQkh=3|"NSf}匮+0Ϸ}8 tqXRc+O0k-ڸ< ?slYzG7|hI*@@ǯ`ş(3 7eoߛ~k jo_xeF(”x[ٲǷL /㈙Se%@%/}^?O=c~d/ɉ ^p-%!Fi |UE& 2 UAݎ6#֗-GUqʫ,!~SO7#_ ~PC@ 7R!!Xau$cxmqQՐR9~S^2*b/)/GEAs0hc_/*}qXIw:#1k7^2 *o$⫀c]_pMD s2e<"H 7&௞ hAɉ=U3^_\kZR`8!ZN3!_`c Sk߼1a<' T.@{ywxsR\{ǩfj.t!r2+LQT@v2$ Lfn[r6BaGJA2iOṇHTC 2iAvB_z5C}n' ״$'$]6cO1XQT3]s|=$>K[ QLm_K5:6ي\oM|h~%Jd&[ OkN'zyOpUiW=M{⛖I2ntdɳX _=wF-}yF>qN[SNV6Sc>2_!xEԸQ?c?K@K&>W3U70)&3sJ@h9J& l2Or5mdmw~Qg˶MeMzb\X>sH^-DC@Z~Б =}_LVQŸ1xu)]lSZ3;?ڏïG+D}+~_^*Y0r[ΪDHUe]]KF>0%?w# փBAQ@31J;d 2ƃo|H6'H%0#X&w(KⷠAL">{=~D2(ҧ^ʃZH8s#vzX _̳X_)v[,32Rj˛X{Wm+<ϵ2鷼?t3OU>\RXZ#c[ಲ B6VaÞ.v WH.: X/ a 7uR{'?R kahSpѭN@,Ry=WnQ5@KCL7|K_9ȶ#sX#ZkE2$]̓`ϥh¦IG09qZӠGU>e`&8?)k?7f,x Rm.rSc~Nӝ2j?KBYu%+~}B=OfM`Kck"h _#+B9r*6:+PW6ZyUcà}_-@h SZI7|4^ U̓&J<é?<eR2IւnU 7C;r Pmz]Y$ >B@IrY0 Tcx?ָgva袋1=5W|lv\OL?av۵_Ow2S9V%&>=X%~‰ѷ/8iė|}/Rd&a`K0v2OO6c.?RqI~+h,ߏxNS@ƞ;*'߄_~0(Z]ص+TTgøfmB`XXɜ?X'%a£ {#(B%?]NX(2 +-xjA&G?jB Sfμ(]2 MmB8JZ F Q Gt+J'df3f ~pƷ],S BbDG QՄo\kvb ,Yv?6~ٷx||)_Ǥ,q0?| 8R?,Y#ݨq7S2t_՚I86 ?H3]Ŀ$_Fėˬ_R?dq _-K̰gݷ,xp #oÿG|rV#|JZb!ZV H}r 2+>wf¯+~o͠/Ǥ)8NAdՀg~'q .YGMM/,/ -!P1x߆OgC(_#;zC{P+e!v߅%c{Sl(Niؗh*9΀ yd׌_ufφxn `B[U$|@0i ?}l\?H|R<6!1R $Jj^d<9s9y$b=SНDzBPs 9}٧R^ }*JAoB&nAWh?WPI;,7|CS)<:}G4 7w@9†|r0+xC&DW/_Bh[b9E {d%4/}tI!22F0&G8sH~ ^!=[# yk(z*"й/cqKFJӎ~̀U> M ҏScD{D!+mT랿S/>2?CIu`Cʐݹ?aa{3Z%;#8 8;9J7UJ/6Զ{Tb^ϚKFyx%l"#Z\ϥmzTdEЖ7 аn! :m&2PϏHjF*EYU^[5"IMUs쳿#(a 4ZcBeO֭ѸW5)/a#f7]XΐTߌ-NHtS%hetC.WxBH#\:Z bޓ!@!X2@\%5@6MRpf+}IJH4E?Wz`Ɵexj=kdŽ4ZHp3ZNQ]ħ` e.xv0E <8c]E3^]ـ,HH8^4s eGʼ$!NL ǟʿ CDA`jپ$#\9+)|Q#ҁ`k:.4%7 O~y=wh loY H=g 9?xo #gbY-aP0} (HS})>׉??f"tY'K~NuyGg_ed`i~BQ8Ȕ9љo~ȟv{\L ~_AF|O[12¥l53w&[q- 8SK ʤhċ}}/o)}Ew~'!׿#m] o>=7oo9}x-ЊϹ͢cX o?, RE0jz;?73>_Dt^I_3paEpvg|LpEp,ѡM_PzuI i Af{+|+J ׿7xc o0`e*/_;ÑįZ)5]ڕ,|o'5>ekBaf)ZѦUÒK|mJr"h!9 O ЩS Zc\b328Ck$? 䱟5-x%I,c쇌b2-xXYR0GmXR͌6ig^yq,%|~ڸkUmUЄDB /?ĬxW  >ZFv?##ԟ`aVA56zOR7=9H&/LC]JDw1t%T ,pӿ w϶`=Nb}s@ K()R[PeK: |R^^q BFuPg^ ~L_G??h![sLF,Mԯh˻*Al #ogfHg0i~cOwk &QZkyJ yAM WtH }[Ee/y?%GcҜG ɪh?(l.](%ȫ0 9 цŭpfR0PD1@~yI6b|iBC,xŗK Eϓ뗨Ĵ=e&FCd.IU#qS}>p ˌԨqn?H"g /1 Ms~W@_N Wx7h?zO;{RSl|RiƸ`_#{90+!?9* Ĝ'kܞ<Le.o(ׁ/i?\änMi? =h*_iZ(rr:`v9z[7Ư[LlIvx=6'x)J#7r ^YN/N1%y>'$R5n&˟FT=[H~?s >~9)I )  h'| f0|*]lY*j@K'b!@y,ҷ,F"UV@U8q=E|ԭx=;eRƟp*ԼW@Zl,tl|o]Fى$9Gg*{LT99+~ `}i|t4 rEs*< Rc /*i;+{p&[5*sCzg'?V'K>M͞]O,|j^_D>NJ/廝q}o|uѬmOO /] /`y1x[!E|W< 51NxB1H;k|QR= {vCD|: -L4YeGF!YL5njFs#儔ON^v T%X@ \0Pv;Px6{N6\1sDڶpRȣ+]aIgv~-(*2__l3/@cS~W Q*A~ۗh;=k8\Cr'O<6R:.p l^it'ϣ7#Sr+yx?A7ϥ^\Sܬ55\Hl1p^?o#dɄ\)8P{pC݃af)v~=ױvo[t#=аNP 6 ܻh|p݃yp ˻;zh|R΃km=Z5OfptӕP9o^{F6ؼ?_װؐ:B$ ͈ĕy9ok͕p[C/"I6#FObzo8Ow?C,4{KQKCQT/Ol)6Kx83_\d,l(upjcfnT% F7$J=lqAbOy 7)4M-(6rfQds~Qul~-oǏr@zDJ# F1"a6$0;~N?R/ J" 'MPlՇΉwؤY9 w;C~jWkL s:6q>6ztj\3}L_]SB'`5suVҋ60byXSFw.v5w\dhdC|Macan4Oు^}vlT;;fw\꣗>$w"Nf%Ed#{UM> '26@ tɑMSUy8G1#f5 f;s}~eel2!0À1!?xA!Y7(RIu"G<>*nTEr~?v$BQ+ERdžtq)\@6H)3Q()# Rl]xd^/{l*k @(t|6sNfO} +n ך2Ly%ӥ> cËlhd Ftlgz6MO G]Σ:6W"9xblt _YS8?T{l/p,&ˉ6y%v;]Ѱ)ßsqirlics/5{lH9`suwt3eM~wA=~5+MI y8Z"G]Yn3 dlp~~5B-?4%,(hasqKp~ A3+ؐfrE=X+ qK*ʱ~uL+ ^ __:6MdUQ-!l`$, _u5t 5h{'>G/=l~}w6zTdD* vC}ʢMr 7?|5Ʀ$M# q:Py.|p(uMʢl`肋+T痸Mqͯ^Qw/ⱡV;leJ)3`%4$obŦJ: 6ʹ<]$99s?Wz|~Ѓ %>QKQM 7*RޥyW|G%lS>6;:I] 4봏MDΙWʐ͟Ɔ~&66;6 ə*B7MKx1ޮJ񭁲Ki`k<4aS%WS`#S\%aB|ji5 יίYrWΤ_ 5{-FQ5 gř3팮bC Wؼ =6pIƃ#2(^nc dQzMcX) 7@ ϯI<@qq\{,Gx4Жݢ+6lIF/y`s|LpͽnGjĆҲd>11'6M?|\XHH]4-]ׇ|56}Iج31KxJZ LxAr'XfW96CaⰃM 1Eg@婥v&<;,a~D} l.9v=6bOIyL҈%`4ܽ$^Xӱ0h%rNE0m[\ 9hyRgK"fRQ vbG.wsgzLƔeǿM8JڗÆ\<簙4pmQQ|Pkتj Ѱ|ܰzO&>yz!sSl֙z%V__c~,~=YdԅMK}Q6 6?Bl2J`Ӕ2@ZM /=hoDwdl2g٘æfr1n #YRmW(%w2tƞVzlbR38??>j{^TO9D<4RE}+6r F)OL-5Ɩ], _ cClAk{$6$%6T+ ΂Е t btʄy#{(i6Yw/G\.&M/f &tlJ&BR\_DK Mp8CC%n "Z&LDMVl,&92Q.EW3w?mcVpӁeBTbi~*?c*M8+$viD)z2}fMuʼn(DEidlH$6(ָg| uv mJ72W~}M 6#}Hpm_~;~k:FXMo2&7nwSMQlˆE,U[M)jS%װ|gcsUBl.U֔ao.bz[pI#6 `tV) =Ph;E4,37.@e:41 4OU3q ANZVTblxd!CwX3 -iǣ7+A$(r\HG3|g jM]gKc@c/xOB69MgOǞ]= +Sincfr)-1} F7if힠TAM(&G.巒">.PIqfl~6߄U,4gLg~I2)aˇJ!碿3/#L06.RvWrذ5l4HŒaDUQ` "}6zɦz0q!YLUaQ3*litأJ3SoH)q6^H%'BQLJ 6o)7d06w:a##T¬ҩsQ 6NOeGfҒbk WCoY*̱=SS`e1ەtR&Wլ;B.&9?4 :z1BSʹ%IEK)E Gg3s6a[ 0ҰEmܤdvoYaCش}=< ¤y NYBemݔ|.C{l$dC,\t鵩J..INfzWj#FLpQGY`ChY9 %ܭGaǘņ-MQ$ l,6LqؔDl z8\j)7!aF YBT`GǙ_GQH֥BM?VJhI")|)+Ԯ<9E }OE3Sj-^L+9TQ00ȹcS >lٱ_g7ğiF[ˈ}+72ѻo,;`tKOSt)]M4r%z$.3D\D DUfÏGˡNYb|ˤ=L}_nKTOt$Z2`Ëf.ed/ٮ*T$=E`ʌWʓ q(h3ӰIލ{=wf1U؈{lR鋁߱_qaط.2Kt%~+Q賰9jx2ÅQה~Ʉb9 "&kcl$PjǁS@Q4]ZZlQcg?;Mja3-.6ۜ$k(ʍR.hYTg [SͅZі%u.}Մ8\*@34{l钿cS9i0_KF`'*b)̀&o$+8_\xBXob] #Ux %zW@8j,*XV ֔~#H4JqK*J\ĞqȀcfpY)#)=x‘Ф-6"\ qdF!@`?}@9k_2Wy)F,7C*`#aæv5 "qnAhT ڦb_/&-xO ‰K/)7 VlS߆MV8t;}&]UaY~әM^.d"R8`)[!YenRv GMK)+Kc6lKO{ؔ Zey"R ZXwB)*tc[`#/8{3j MFk\6Ƨ1A.C%%.3c >BeHHDXu?M7RvW^AASZf:H3#=E}VE2(IJMգ9-Dl"7q`"pnIoru~)ӄdt"޴$9&B#sD39V7VZ$<Dfd(1SMe(%% 6)#Bj)Eg906ea3nVuB&hQ7^fulLy)G4qI){t3Uc⚔nC9UU}[S X<,XbĞbSb m%X07iFmGE,VЁFt;l դi%~޲pLYC%<JEۊ `ֻ(w=ɼ26d#4}j]gȹ9tއ KN15p]nulؘ/ Džald}`tl Y=6r.Rn)6aNK8NŨYz wllf &יY]Z}$YU`6MQL9Plź.= IDATEI!{lr;m Ee3(r-&^m_燈&-={xA{clzIgpG]hO890]ƆLU#א"3<4l&I{ˋPPi-b9fcNs8¢lT=PKtTW29I,kZU̩!Ii+C^+P.Ʀ&{lxsoA )-> 8a ^._+Fذa(\icl~tegî#l*Cx0ydCa-t鈆_a籹S=M2l3csrwKjpGUɢ`#LCgT%y!#4l):ߧcXj *qT<`rXOWņl dO6ldE vgM|6hY MA5lvǜAD9J<بVyNˑ[l˻&'̹3T3 VAzAp if4rNv 7!8JRlrKh( JPߐBr^׈^_Ŧe({ۚi$RFso w/[<Ԓ# w`: dll $̲ .X9geVDk(j͗p|B1-i.6[P<(2m%16漈?x5KFMc7M]Qlz} 6qb]l0hoͬimb}Rl$ag%鹉:wͰsrnFf{_fڼt|^Ty$gI@8l6뻼')Ek*<~|F<}:E>'CDxhTXJ? 6ۇ*ckc#ޭ&!kuO3|%C_Eqoǭ6ϖC@f cbX&6v砱NO;pjȭB㿧Y`l 'a3 c#tFl(X#f*†&o| o% :֋2R*J(RvV)A"[=v 6:n$.-9&dX&ӕH,9Y٪{ Nus3 h2EvYcO 27[Qf5]y^[F<`n jWH9ͅS}OS.R$-X䯱1h:n>v'.ʝ> viq'`sԽpi#ƍOUn[lSQ tSg9%U˹yύKM29\7׀ul?GMlhcLK6[aрUJ>Kȕ/J/αY<4.)Æ21 mW]nZ{P%P BL7{E̸Rs3)X.'ޣQ~谉Q7؜kk$xV6v&l%K=;5!~Mt/8~8sxF3xcϷ޴Yn-ظ]wyg{*k(6+$ V^gz1b,6ʴ 0& F9͹Ɔ+OrGXi&ƶT5VY G l>K';N?ݷb&ec .bX2Ks脕zhuRlh^|{H*6YMɮsriIQx;bxn2*Nԛlni~#ظlhi0cft zINi8}q=C,ĚM1/v O|;+ Or9/l `æJ-+v ͸C [nr>.ED&ʵ6̛<bUO@5c޿FY62+ \6T! S®@%[8 p\msFD|tSlJ֎~*~,ͰLg0M"mfȭAc8 e'l ga9þ| sa뗰W} #Z.s^`^ai.΃)YqHV-Ǝ͢fKEByE4y`1Gu)% M,ҏ{stl&p&ش)1.uˆ*|O\YS֓[n̺sRǎnMU\ */!5Čø ĝWCd:#6z~w=QX|noƚKkmbâ{)Q8dd?cd8acY|?LtdvScn|;6^@b bG#t6ƨm<|fۖN$"檕z 7Cv7&b%dp.఑nVF!(qY^كmyc}Hfkl>nl񊻈U(a# * 8RioBXCF;a[׈jez<5E6<6b)Dy N)ɮyK3!(z<8ǔXPJl$\z^ c=6(\eA٭`oYV@WI'&X/6qStEͅt:*VGl W1pvGQ(+&le+@$?=q7=L;cc7CZ *})>eܰy9ٌF l*u 6&~)9 -%}ߌ㱡[`rSٵp,'Y3/6vl\Fn3:"Y2|䰱5ZJ5QJ:6y+ؼ1$W,liNvMȆef"wdDx6<8pD"(tն?bnhz=(L$C>KqaDC')T˹ d.طLXpg:z]'aB=8lt'UC9HcL>~Vk3N. X KfeX;:P>a1S@"NCU[ɂb}Koq6aCK=Dˬ11E^Iԯ{`o 𛡒TٜE;ظD!]l-8|n)eYɲŪlqJ ç9`<^OD"v;cAXia>~V- Kö#WT׎yuIlf ~9JTnͭig(6tƌHRTg;sFVoRFrF>6) ;?{>4l7n.EeeUw1G+eҰ_rj4MwZT`sPl{u*trxűe',Wv9%]F> W!p9oUUH\[4O#!찙>U$&166tĜ30Ko cUO#jl23,t|Q<6,kŻ",8O4c͗Ο[XA؜8ɤڣPs< V}zbʖEj0sl0°hD|d iTljn^l50LE)_I\${@";"OR9b6Y4}m ZTpĢ%Eܗr2{lĩ]V-rNځFAO DžGlӗm+[p U4/WAߔ| {lrr='&aX9';@d|6f".nڛY7h . >uӫڣ m%2=+ FhP ^M|=~ض'D)*w-XcKny] -nփĖNSf, @GJ*fǯa4;ʩƂ%MKz)5#'K6 $9<ѽ li\TR}T;=`͊ѷCǃC=;<($ !T1$m6xg~ټ,H })4ױ&\з>`4p)}=Ʃtlُ:^q $.3iP.[lk#> 9* (䙱ac!Vݔhg&n$ Lמ}HUpR^F9َg,6S/vf'fNl).% I[E)"тu]p5эKIeM;ѷ k*[lJ\kОnJ)*Q}(PW[SNg&WIƈ[O Q4±dZSl'Qm4B~9\&Ĺ T`(3v؜$, 6b#b8fXp?ྴtZyttՍU[LԪE3_{޺/ }tu)¦{QDۢf,R|GMFa3;Ź ]8Vg9YS\bMؠ]MoB<o6yƭ8\CF 7ZК!ҡrzAZ,FaM[U6oGTFCKAڼ]~jܿ=3ub6 bX@Gd*70_uE&$$gfmӡ͚VƌK2Mr-C*hÆwMRMPI(;WݰRB00M+擦'+~ `M"ڎN#"}B33 }HBTưϰƓ`i*GʫWhB" ;ՅռF%j -^?JIŞ70TOh^]0+'kDC$?>vq$uv c?S4f:{DaMaO9 &/fP<`,1{l†z RA7q[_m'gjoq6;S@Yf{KsѮ:u9i=~2چ?Mc‡&t 3fϪ0`}M6Z)V ueO"A -؈iF 2V<9N7yoaٽ6+y 0*%ͼ\՜A/GFsADZ9Ș9Fl;uR XV3yZ.(2ZgG5y#unIAwI`μt 6z'Vo~e3E$H@۬+Z^"S6րDF]? ?aCklsYDyZM7(4ܶO_(i16%֒ B4נ@|n0LS'NQ _٩gyM &VBpvJ|+5:NfQ(m?t;6ٕ^ ! E)nav|ꜜId-QҐr?'lX4cXz?O]_-{ڐ%ۺ1HRm83K:3A,]d=휼fa ׌+IrL"l8^dmK}&@hFՉFWnDQEѼeQcC0]PtSz'{nռC Kb 6ߦ$iLzk{b+^P+LaCcSؑQl1HoZ0Ṳ[,bXV )pMxY/X K^Q`UCM'YD§ҸgC.*\2FHyНt%s$!,lMҙΡt#ӧ,RM -"!0ZToM+Ubγz X0җGX#Idfؔ>}nQYU`,jXtD~vV9:ft,e&=eZ̠oTuC辆ĿK2=aTl0 l Ϫ]̡7.Bĝ@Ok`.rt 7LIC=|/Bm*9m,˄&.TfUJ}۬jMd?*&ÆG%l"g-2W,46q6)sD^^x iZby>O7x+(]b2o!oA=Ѹ+ o p^:h1p*6V)B+LLtj6z?Pn=<Ae(s;WϤb^9B*MU)ro3fT)_~·n~rf OΪdhh@*]u>4ĪE$6ưIkT,SElobُdž*_!YcѳY"M#:lU!Aů 6;.bI!VBbkؠUYfbyٱq?̩WH6z'v9M\|Q? Uu%rV5E~S6HY6ؤow0 h cK\r+ |,uSbe| QLâLf20XCuPx'lSpj{<n*9P0zݴ'5ɫ,i6dsU $[4w-QqNW6e)fP#In>#TɃ9"v`g03'@GQ.^۩_{99֓tѬ:eafܮ)rCDFձar0ld}aRly <r<l4=T9}eNStсnT,TD};=; H`λf?eڰ9ɖTb&&06EIM]A۠lP@e㣛('$A@.;[OYLYyٞ-e6(;6 v^ ;W 5B31,eletlY32 Sl|B`0ϦyC;ͦT+i_] ;'!`CPilljW'*SQf3VCP2fKd7^ 0gY2:pN&0E6*ᔎVRb4]YTRo.IQ߹m~ 4/vP̲E.v]M7:c¬z $64sP)3S͗9\Iblt{ILƊkCD*߀::l3k~DuάK0=cMҏ鰵a6aSfMzo]D IDAT5m'xN~ 0˚` v!5ej:y'樄C0gy78͙M%ݬ*CMOJSaB=B.#6WQgٰV}Mojƃ/ʔY&PPR[`#sʲ.Puܤ,u^l) hW'KiC7HSlbzeGw,/Xƚk5M ϰQ!CԚ"tŐ4S$sYC X9~-9AAe:*6ƆIJeLp!_:kc{nZ-nW*{Θ[,t[5޳ļjD4)丼*{piogN>DcI2wjV6d#a(>u_ IJ?AdPPM6WC7W[THđlB;E䡌x86Pl&A;v6taw#ldr1Z)Jȋ֝HҺôK7scHX<)6GjŰ[ Y2r,s P:^LJ/hQ3֗X)sL򲬊Mbl$mLðͥ35]@2bz‹{~|&`qY3A=%l \6b+ Xf - >QbyL 1`gxl.;K@KJsNMky5Lcل0߳(I?Q rD hi .G4єl#kZ.6UH\6~lC>v[{l҄ FD^DeflĒc~%v%ؘÆ:Wwxq#Cc;:ua˽y{KVdа<0z5lpvfZFPu(]7b3ADžDJ؜22/{nJhН. wO16E$Ie88fؠS/M$;g) ,QR!)M'e6Y2TƬ$΀Mb.# B+?>R!}DrpZ8S9ƅCk|qTEʞ4:bN&La8:]]D嬖?/KSUadM!2 %T|tF"bb?ťյ16wǑ!WdtFk`&Tda3ZO>y >©T.ngG9P-1ee+:zfa6:ǩ$/cPˡPeE]3s\nkPIS[wL,XՉW ؠKWx \R[l6=b 7󶂥T>~T mpL7Tհa>$kヤFbFFtpwFwXZ1ͬ_:66x鳢*&ڦ{8WjfpWO%Oq890 ua9~'2*Oܯ'F)dzxveN <Qҋ:>yڂcSu#)6ӀdkJR_WUi%YMO!б2bd+z+A%{JmIZ⋌jov׈lۉef=p!ؼ$ PQJcՊŅ[Λ=>twf-|uhC3Zj6E 12vףaC؈sAxqظDi#6o(WlMvl`W1GsL;Æ}Vf16j+\y<>4fvؤN7<\MJЋ qv>fJIQTF'\c9 !$Ŭr^{"zGlƒæٙGHN`6d#=arZQ}$" Me"5fzqz eH=y1&`ˉ.6qa\*cmfY(>ݹ l`-DB=6\l~Bbhl&܂d_F mG]b29VaCR_pMKzNh=ILu?0`Mclq 6z͈d1 q+R:6/˅t=YČUl+ #ňxDGG `14)k})FFi.TJJj=կ2 [ePD¢b6H&5dRxt:b61>-EbC~WB/="\(]C뱱iNe֢͒ f|l5w"~C̭csOC7(]Hڒ@̉- LR udSp6cCs$T7" t"0\Z)t7ܷZix!)c#52vUЖ zﮩlOpL| n;0Rl )/帇7!Tc&:{ {n,бI+@F+؍)~{L68)[M~8Nrng}Y5/=m d̛ 2C!wD9VrЙE<&mۡJ5FY9`GSer@DYJ&u6Yf􋳺s|ڇ2,w%i7l5Y{`qC}3!OjAd)Y$^جFFG'dsHl5L&HÀb{87M@lt?Z%5ܐ:gU"CH~g*OMمN7<6o`!bRrs̢+|o@g`#eHF p8SCDB*9lH$4~B *<hf e ى=78Bu~eĆ[k 5.%[K+x)tU}pӈͼؐZGl^x67(uxͺUÆ31Mn ~ 蚓;?`9dr>YJA7E{)?`QGzRMR֜6͋P)pE@s*)E,vpSL\ٺ/cHZ7Jk*EZ2xr0Ӫ3/nXBc*S!ߴla Wɺ896wa~WUoQ=$A&=?xI[b,2eA˙}5 ϻOWH8N^VJ#w<]'$r`7Fnu4/>&urK|$2€ ҝ#rѿ[ʢuts}i-6QR}c# PV7LTy;Qu=9q?Wgt`5-M"|^zɊyw.Æ<93|؈hWo44T͛[OBB xJ Bx|:agОt\e'(Y:KIj"s9>NMi|'WO5zs})D,*qUnXy+NJ}\l}cCwF"n7rF,aScI14>+ui\Rڳ"e\H5.YMS˙zlNÆno-Τl7e:O[Tn28jϊ8 4$1S:_JQCPo(:@766G'l)BͬN>MӉ1LJ φ!FmuHZ*3M|T Y.]lf{A™g 긣Mj:iG,9<)rԈM2X^όn9;dlFϮ&Ŧasuc5ix EiZ? :lmR4^b/SҀΒ 톆Ͱ=6';AUNc@Z7 eK]N|uoczѥcڳ ;h*5W)#lѱI%/$J\EӒoQœ$x2~MtWpMƦ Ӣ IHd؈W<6 caDՠ.)X&iSϓ' 7,fkj&jÞx m4+ T:V?((ݘ&0Hn͞C#vŬQqT^)Q;G[lY"L¸Iѭ$ a#}տw%XwSkm/-`5=upK84dNcl6 QoPnILeE@`"~UA 6ƘESOIfo"=oε7HKeP>PW%Eb4Δy،Z@l2 ,+?Fl89G F"MY 2͌FE4i.6m6sƋÆ#9q6;PD4,a#FM 6w"o ?:'湣 ܈t˪puF"C~UC81G)u\2]K] At%wqKqoVX^ znF=(^zN|嘼l$?H6=qSZda%׿O Nu,˾6+6¦17yTs-޵~֙u$L=Lҥ@CL]Huͧ.EFhjǮQU&?ʁ#< 6gtίXR<+cCKw|Uߝ=ȫOE)nd//a$Bcy' 6,DasHbTqb#4Ŷa:7d.qb|*b/W5s/] =jοC76dbG?wT{(o͒/Ld/™+RVqذ[hH탩 -\6-߯b44L;&srـM m/jY Ds$$)"tY{~HVG3鿈 gM桔4FR7 %7ؤ?=N7J Rc_ [}Q$yrٻο6Æq8nzu2mย`C֊SΥ=hKӓܿL)vI݈௹6.ipf<3㙝B백{נJ0`2+mYH4%鶨+aݥ# 88^PX 5Xώ8`n@Ap@;1"PS$LUO}S?93[P#*uMN*"lnf.)F `cT*cM \d,qЍȔ sP;l4G>:%m&w}{lzF%nI]9zdz0aAC 6lVl6:O҉ņy)yKhN($/pĆdoN^ߌ{C=эuV5flcl: Ճ3dȋ 6]p 5X &sw*=*i,5U M^4K ?,sW-ִ<,}AuI=6/*s ب7ac XG j!4RN}ɳB L#MYIGS2`+NȆٳ5{.6ڰGpxIa5 5|6ccÌIz5%M},J|Z{Ʒr&Ӵ-{[lFK\7ܱktq07սM~R؝G6hZhh%BⅢ]itf& CFFn=HaID- w^ߴB8YqH83&-:]P:&q=_cNͰ~Q.۠x?&6/7nA_vIENDB`libgd-gd-2.1.1/test/gdtest_200_300_150_100.png000066400000000000000000000033601245535672000200660ustar00rootroot00000000000000PNG  IHDRduPLTE*'IDATxq* = Hi@#5kz {cl+>KB{S""&,Wۀ`2E~ցYW,x ߌOsٲB8k^ o,:ۜ6Hf;HYxgBœJg`R,:⬒eW:yYI܂gp4]I/:+?YIF!7AYJwjRYd,,jQ/ơFS&\o2OjcU[#xŪ^?cQu(aVq5/ddk1kd-bZTKYc}CnɩΐDZZ,ɐu뿹ƥZ/f-cU`K+Ȱ>6du.HS_C"BMDЮXkPEjo,Z77gV).*i+FV85qrֽȇ˚G zEmP̑=bd;Pr0E yQ5kSꄰ{aZc,*dcՒVgmwjk`юXe](-!I_!gDyCK#.ciÒ>!%''V=lH<~ +ؗbZ ć,J?^E8MXm*ڿ4VVVjH*^lX`Kc%kh-֯uTFKO{tgUs6lZLwogk2VL_ ԁ:zJj6\hZ`3nm"o/X}Aq 0I=X2+ōcwT,rjP+R[gte硶[܉9#84x>t&dee%ikk:,*Zuҩ,z⥚-sx&_|^v30\2M/l 5ޱ'<4EsOyg_7,=@J"7+qj*idY>dd, ĝHiXnce|iGs'kYGTLJ8QkflowV.ɹ;j>s<|$x>H|P#9AGr烚5ɹ?j>s<|$x>H|P#9AGr烚5Ϙm8Wyh|PECAS.3K烚'Fjf .YϼgYB4\Hw>yx.PsȔmV:Լd<y@す5rpJrAKs%LPMLl ˚vNͫ%Rl5}RS%ON~P /v'r5KaoԨleFYA"'Z4+xUYYBeiLԿ!2y\&sYTms8Mk^IԬ{ҐLMyԈHjGA"'Z4e<5apcNH gt[nj<ע2JXٶ[96AEw L@`A {ol(1n$ΨQ!e:UL# *~5|QƜnπFjyPT'ԘCj?YD_F*Sl fm_gf9FOMQ;j pnm6QnӞe {c1f9e3%^0DͶm(kԈ}1w5BLgLAn71lYYG?S".BwDƿ5h5u}R12oŰ\mHQC\=EMͶjiVRv5/b$}-VݜѳCG(b}uKLشFmij^4!kj@oȬн{jz{E!Rozȧj^4!)jkJuw<yM;7PCAK'$:?zuic:zC-RA D&'α9HfpB=A$GsaBIRIM5[6߶w-O-8EA ƒ6b5<4%ݣ_[:4rN?TPGYrZy~$CS2As<1ԨAxhe̓w oLq0a >ԠI.M *Dk'S ^NP E^- ~0Xz6j>FGL)'?mAMf2YJ0t~B>Q#A$,1g?q5Z \5Aƿ6v=Xĥ3p?UcMcU:65F7BYѱB2XVw\LNFN=' &5[}Yy L4'R摣)GPSԁpNͥ&6 !_clִԘL(e#F7J4Ί? 6Hj67D1Z)Bs;uT/d #4mEj n~o}nfWf= nΣwzg0 횂` 5:}Gr,kp\f /Gg\V>wB4c5=Qc# 穹RSހ:26 ,o. y{jЬa>{Sn'[rJBI˱l9Rc%p9w%~=O ~=\4j>`W|?rG lmpԠM֋ە uち\ y 5I&PspPb EjD9jX!M~B~x`'!5̿?MblS߿Ԩy,4P>l/mC wųmnBϝ>1j~51s@y:50*ރռ*t=<ډ!-aQCE|_S˂;F ̥Ә-K4;36ꧪ=&!p5w,BQ(455I= Ejlf5WhIW穅|o< Lޚ)U"o3nD͡l\ n߁i>(2]5T;&ޘwĠ04%5A5\`Q=Q3!4'l8yZWss!\FG$aDLf&nj6XÊHMPNmgBF ӏܵgN5jl~w t:É7/5_[1W<ǐtS 5x8[Q2]_Ĵ5%a>\RHh&'2?_H~P`ek)4+Ԯ1Ǫ'S3qsjLt2/Tj6GM Ĕ/ζ M|hfP68 j24ʆQBlװ K zk摚' s'5 B M^,{'lgG/@!VVH/M,j jV}|%<)IMFrGq+5O4{Mfp!?ޕytl_ʿ%C}yh5 q5Q05.BD2So/JScE/5 Mry]oJj';!@ }.y45P7gK"lx"n.=a~n=Si~3j;;[<|2u95$bPx7.Y9K]KS; j Ԥ%[ ([ypĜvIH`O恛/JjM=xI jM$WfJyO{Dj]R/aTʲGxVv|Pl]gxoPC7\UVFڝqmbuN›ȚF#kYSQs.MXbaYLԐ Fe겗ȺuI=Qd^5C[6]({fPdC)%5k'8Iw޹U(K{Nz!3 ȱ&b!-n'kl(QRGg"N>[hY*.|~ 5ʚ`jrtFI/$S3ޥ6^a3uJn]>7#/vLY{e]P@_Ok<5kJBuT2F-!kĻ[ꨉ5qOwcCC-V-뮽3ACR5&5#AmlЂkTq6qӂxZr)gV5:nUaH\Epឫ3Ox 5_F"v[3毱M[TP4ASj޴=@>L磆x͂dϖPf F/*+~V#סg毚)"6!h5 ٫'޵Z&3L t.k e׏9<睩YAhHQۗ!B׌jgfCk td`ϦG;/ͯFw=l5+k(I&n Puij ۍ /%537wHROT&@%[E5/:Hfv5025^N޻}Wl"=7@ &yGg朖rB~c՛ظIx%5S,"XP3gc&( '6jٙ;f\9H}o'ش븉D]K5/6 5RR˳Zw|&utKz39zGjơ^z[?|hY[UU+o8R3{vitA~SL>|P45F۷p,W7iPM 3s(_ pg9=ix Ps'{p=0|׷O>Mj9~H5K]  ˆ2R bʑLjPD$_W6"t~ܦ65c 104ck8#r vCȥo%jղT{-t/μڦBD8+IءX=lӫ &"\?5$jxR O(6Mx_ţ+]DEV<KԼE kS#;x j6?@LbρR&PS 35Nu^!"CfeEms\rv1q"@& ?m~}㏠{_G KjPR+ *:Tbg K,=c 睺>} 77x@٩yhx26G`I:S9.! - 1a{Ƽ5hR4{ek>K%2Uvxhd?DbBbQ?5klܩ7tZlsE# ҸHˉ^Ԑ0Ϡf#qœ5[ Ghjx޽@^1ۖU(ƒe/*4#PL`W+Dgw~hTE̜9LYs7=%hj(d~Bߋ(-$`3dѹZݨ!3?dK)#U[$ʝ:}N66Klyh`kx,qE95KKxe]tK=4> DhH4fH!|>D{gf뺈-m@CmVBhμ-hh+(CyjZR\fYӱHWL:w{FJ"A 7W7 A*?~{1{%+$Tfe9tFXrvg;B鼶 XD$->65^~F j=j9񠆳Z3` U*֞E}J>RPjN5ƏACD@U̍X$@ʌ3Bvs&Gő]v5~CYg-4[>c-:23"vhD7j uPt#cSԨJbi##f}Xf>' u0K>Ds(<`"LtѲ %nc̎.Ԑ)tL8w2URn;kn W]3*fydVQ_]MV? .2Wxjn`xF} q?j+5`J0Hc@ #5K2Y3)/NW56,o\ΉV (G8Fg\8ar/5뺖5'7#5%%i搂L7M%F,EVdvB=ü(rQ[ k£':pR5[=:Ԁ^/Cj6RxHdLMZ=3Z@أ;ԡH ݠFN'588?lfSM~ Ԉ)x.Cxwkި"Ay]zO ڰI!3l&ruUB [FҫRyiu<@#MLSքN{5蔑&!:BY, B6W#9R'/TS8bL?60 5ǚqV)e&$+[N| iON.xwIX?&N7.sF [JoVZkvfhO-M$9`%l|5ܺDTE׺Ső0[h% Ԉ`ɋwuh8 R5Y𛳣%`E  uɡUos.se o슳-{2!Lpkd|a^3ΨtbngZeC˭YzΩ!rИ k$bo\\^޵CRдd~}G @zD9듨o`~8-Y>)Lq᲋qŪ;lPbZ46/Z4/G :k,A QpYfWޝ>lF1Ae\t'V†@K$@K8r'J|ruh/D֮a|9UFx Ndq+j2C i+<.xHO`]:&i.8~W\&hrueJڙ=xjz˽09W35G 9ɜv6)u®!% *NS,w :Db`}[u׵9t A{75G(\fs7jBnL0JRr/,1%6RQ+jP!ϖ-/{ WoM܌x Ss64fjlD=ؐ5֑80~PU%lq8e~Rna[@:kM"'rm ^cLGD`S3t~Bi NgFrDj̙ Hr k47a^oo kuHMހuQ_`Nxl`1qEj+|/@Scm@,u'kΰW4fu*9DͼanԹTgĨ5>cM3rkX6'zڽbI 1%:ԵI!{5ȑp^%{dP3L]چ[qaD%5!7?E]^a"eE bn'Q[AoRWw^fd}zxEe  }Sӱ5fԌ5FM/;PjÏXKE:0^Vl*$/D7~q yegBN}gZKBX8ISۂO\Vn,^uE A_wOI cgHMBvGjfPk&rSHfe~]RS} %9mZE7"'knMz_\tVS 1TˋX1 IDATWjǶ 02~I2RCoȋGjm87NT*"5dwʴx9p5IXcٟD>XBzw*ڠfCjxxҷP\`5,L{6 g~'?S~'hTՋs`@uc7gJVgԺJ IT<_EfH\΂7ƦXIN[P%͵3Zx'S355 % TZ1NY1G>|~R<g([fz UjfAͯꂄ'+ɡ \Ԍæmj8K49O oMM׏K +ٓ%tԠ˯KS[iWv5I94jnFMιYn8k(Y55yEpS۔BsA._S율&Z` oRk$jg@Tϙƀ5凩V]lj6Fy7H b$ TҸduOaΩrBhK}@|Rި qCgs4+'P>'\zCvʤ?5ZItSjݨqDEG!J$"X;FNZU(?,sMd ]ΐFE<^Vʽ0EeDFZ NYR $gEb_zoNB*rad xop9gjRyhN9&`(j@~Li$t~:=TP#e_|Ը.fe=Zs1Hͯ%5?q5|"Mfpk=R3Ο'`RQBD5Zzh P^oSoEdRsiEX"HWҋj4#'pΤD>sMqfԌP-bhfDz5Pp+>};Acظ!3jTV:fN(<-'ٽ5Ԩ\ &ʶЮᨙ?Aܢ&L<:숀"WH+P3=9係,T+Lurב_5?OB:ÿ| )@L ŪneX\ClX0桟)W]sJ %5}25CzNְ*Y g?Ț;2&_%] 1`5]c}qQsjE~Ů 1hk5l8 nR7hh(sJ PM"E5oҡrԈmWq |<թ@F5dҖu1"&l)]Pc Pk9+^SCa̎Ԓi'6nnRjo3N&U`j9'YPCw/ jٮZJb06q_,Rħ>♇WZ~`5ٓ.Q:Ù25b eSFjR3ͭW%ܠ5%kxDK߿M,tSI jr(􆹶؏4,' Ґ6G)i]P#W Fu5=[yq-Heϻva1?g5<rm.L=)jMûUSV{fsYXj.oa,s lJtػ[g=eqdB- k,mUGj.B9b\GzudMjXI6噛b"ȴR)"7nF0z2Vޞ*ԄfWsD)Ķֲ&;}wP_Eg8hL# (6X')+usPJx\J+}^S 5U.i1y>B=MDatӦFjHM kj`xeqs5vppTWnibv# ΖpeC3т267inJUk[zHʹkxoƦ P??| hL9F5eo J)? ]Wo'ATP:gޓoU2ڶZ/!!"ˏkβF9q<'3'<Ț@ mq|GuSŽE aJ'~5FͶ(әIMDŎ'&_,?tFQ~+/_\J~58 )ԗ-n}BJ5o%jGMG5~ M2QIfEkf5Zm#ٹBq9=Qcaj`m1V|R&wA;B;jf958gSㄚ4]3+QJGrVfN w&Q"@H<ټR4灩[nR33u_)? XRcU C@n.F^YACD|B)IЫP5<:TSβITPQ@r.VөĘn!5l9o0F"2mJ6.q Zm)m8Ԕ5?oي Ok6C\s(4C+u駹]x:J5KP4d&^W 'ϢHt*E\[@<E LvܔZƠ_ 9BbaafE#Ke ߋn0an MUM"I21->Pݚ~VuQWf:tFQ0B?ad?}3Z [$1xCga1;䎉g5s+i㍚r8VjtlI4*?o3'yI{5L+TudL(%F:{G#i3NaC}.ع5tZ{=kD{A; esdkw5LD.OF=sn䟷q~U}[TZP4ޙ5c3+Q|rUv|_$hF˧ Ęj$Λ[$mW ~~MA\"``Xx5`Hb|U4Ԕt7AI&U,|d恚YdPoL` ߞ3Ԑ||*R 84y韵j뜧w_%.Ej溧 l7Y>zԔV&vG7+/_ٷ 9(8(˗F͘O$S'Q_nG@& .ܢoC{dOs}cտ{' "J;³%5zF]|l4fj7tF7g~N)|!j jZnƽK΃n1b]bRk+ Ayqj@(EdW&5߾kyݿzØq+bzOUk/ůGOb.2.x; G K#-uoHfxj yrT{3Oc()rݪQ++i,&)G3'Y*j ZAaܼ"5"NE9%5QI jL7SYȴ06854n֭87z+fjU3UY)P ;MmN،P#_cHFl~ɷO/ody(6w_F#0f/XGEa Q.tQòf9o3y泓%3"`!.}EFEv}VLEuܭz?Ʒڥ:} 5IAI/AZ),k|.UԸ^eˍX-"ѴB ':DFM*fTфM7;R'˰5l,VQ#o&,@ _^)>xbm&c$E)\r,+(L_ 5#?bԥrӢ ! +q|rY֔tlԡԹR|%lV ʼmGڦ3sR&XE,(Rńo8?5ypYbSQ3_ߤQlf j[;pz02]IPDϵ=zpJH}\=B!#nN wۉ-&,7וpV&억 ¼n(T-xL@LȑE*S5b #5CTFEM5¨,*[oyzґbL:&~G[YJSS3QaSQS[62 ]ioC<%5NT88g'*iTxϣŻG\<ų08j¿SfZԲF7>+*ɦʊiwv$%Nɵ}hROښ/4%QvvHvjp&a3 "N9%L.դgdh|VictmRu: ^Ry]RYihD 47Y j֤8SS, i_Y.QV2-G+W>PM +(xfDz{nMebΩY3Koe-O02&574T]'Ӫpj(uHOCEbծM1+(.[u25rSs p<.QܐT%>5=EhS(NPBͧil>I[AIEoU1r`IzBV0t UWn7H. 2L9zej茚ф85x_kԘ]IJ$~23jL PB45veen:4tIeiVVWEVw{EjD,tTg͝|hůAlA_҇i欥y fH@)1S}5/-M9e2KѮ ,؈1;{ 7&Ҥ58 ÿ'lgCrJPfhO~r0^)T ;xjSz&?~uԠ yBx>l8r:Y:XpSU?MX0Y )#5U>;5h>aaʻ*dqĒy 2x-GjXGF 6cTp5x[+ѼZm?X4ֻӹV!;Ss\ٞ/(mArFM.hw*5!H֔5Ftp bb05cHKSJ)(^hCRCQ ud;9}kn䯥^wP25_LML9QՏKLYb[sΩIqlw u%7SP &8並ۊH$ZHhTa`iR%zUuϐ jWZ=[@$&6,еQxtƜqfѕsh]T{ӼY.(WBڸj@ͥ.k :ZƐk`ߛ#ǁ%IMV=ZeY;e\]HHyi$~1;RT3V_n[ Ab*P>{6 AǬ-![bژ!3Pp IDATEjJ SRǐjU9Pu9䔚T_,WvMP09kEne^$rXdVSc*\ByM اY9({QYSkUMޢ&_j5EaSejj'JlHX6u*>?.Fs;:5{]L>fGMWXVYw ]WMYB5]󍌚)z|Ma.ܑƂ['.NK?2O*59$'5Ӎ OcEKjd{Rx5QcwV$fR17'-jjG;LxX`Gd,s՛R+)͜4ޓsmXjb{0>jnj!ڈ4kz%<*Ē3=5|(X{A*&'{ uq7k- ^t)ڭ]eWԡЮ^@I{ㅵz1,nOnA\tz?^D%Tlk ݗ M{DXJI?fukC]\.a)NFQcc1H/ _FFтb6i'z5hfe-;Sfyk_s`Rv6'G lgzC 9s#M<%H2 E+1e|qN6uG-7f~c%~<5+lԌ\XTT %j*Yڎ]CFpE5l 럩q2SϘuXY(\^'Hf\=X)_sfI| g^BcoN@ޘs ' s[eXԤ\<}pgZxjpMC'|)JP=}cg[}|*awIqD8df(*r\A&[rؕd S9vaj4%jz h`g:S#e&{|cjء"BêϨ!jh(5B'K(+M<k>} mS[3zyl<5Nn,ܢبɞѐ-+.&&פՇwq? mQGx-VrrɉLj^I鵷x=@CS,W,bCpdךyCjRL'gxj^c>RSbA?D(oH j,HRjûHM^wG|vRǼqYnpF NV, (o>|i:9<7&xo/-559H.B˘ {R6K9HwF`%$ʷTRl;Mxghʙ>'Kj49gx WHt2Ϳ3'ّ! zd5"jzr(94lEw$l¼b&`:yы]?Z41I>A d4^ lx܇K&iˇz]k RrtM-.sPm"ѝh!5egYn^ E uRl G%~di/cC龇4>w>Rr(Zb zA8߉Kjha9$vfM C\u2xZ*8́OMEjXwF͈ }KpLߧmBxX5;455Mӭ!ܷDC˒Xº_ʅXx0ϩnXzap%|L=5BFSQQuJ$eݗ*ٲaӮO|ܮ3lؠTKfER2zXkY((56 sZtfkxӈӑJI 5B.=&Z±7uR䳡B&ƕ39mY|< W(d~$j4X6GW kq(#-hiL [qqnu|jO90J%|&}*gC WϔhgsȪMTTꞚ aC<`E-̫Nq$U.]1ɽ[g-A%5c3JQZd̀m&;3Ďmh>JQ߰v6ԸMX..,.9iLnA4i E«gQGWaGl;s=NwvOHUCmmCbѬ+e G K[Acg-T71kᢷpD!ױ/'rj#-$bҜ kn4MO=~[/k25Dqiʈ)J ˄LroMNj3t.}]?!\ң㮄q KH g 6DͲmrԔĝQlBzlhm;:D_U5䅚=DZF FLXZ\'LCrCWu!5bIXYs? '/IofTApC&3lHLbF5Za{&hh8-!{j:Q!n1йP6Մ[7hMzy*uSi >h1v4O6mcPIx(F ]R ='t DM%jn%иCXRUtnKXl2:bI|W< 5M(.6Dy=oVo 8S=) &Qh`u)Z=A_kx:fiuf4Z0#tFwՋԌf~# M-hMXaYX"DB[hTwŝ{fnkl/}g$ls㎕ 5'wMQ [%j*WβQ!l*Q \EPA tBЪ(ghaJJ]zŖl>fڀ8s ifd2/y*8KÆ&5|Rj6@z*ܳ*D7);ݫ*2ֶQrY'.H*EvVRˈ V>Ie xi lz+\h- )p9UD%a.+t08@Ԩ)Sve!?6CXv i2`%Vi[5\bD?=Qx`$AjR&AH3_`|$ 8ϻuk&f=j79Cf6I o؈e:]}%5}MMQJq#1}4mSkԸR ]={G9T$yTpߤӳw5,{4>ܞ/|NMGWj_ҴU+ѪU*w+ubBTm W]dbA I4^C%HfsOME p3-8C[dHFA-I|lq jq0@M/"dE|rnUz'Ƙ SY/5M\~+%GdF >_bIUp.PMm%QYMR+8LO寁vWE`O4}^5l\9`CgLjV!+ldk,LN "3VYQIj\N/n@w!jB ;P7j:%QC5g oO?,bʲJs!(.6%5W?G8 '٩a((jwR Y!lP lGDKu% -(Y!u}0i.>ԙb(x g9 }VbP="#nw,9ymQ.qM!i/RL>c/H͈)l6Qy#T f,Q#6 >NrZnPϚs }oC eKɬ2L͋^Ɛ;P=Xʠްn06Z*{^n ,FMi&8/I׾s}_uj Ҡs.pl(uiFt$u9eIQ. F[wGM.y//*”wЛ<%5Y5H^Yr|.[e v _K-X<5NUA<`j6[`h0ˊ;&%@3KeIUQ™|ws)baGz/lSPK x@Cj@yT< CK4Pǧ]7+$%j0F9|H &$g_:#A5(k헨I7&xcb̛%"abঽ`ۺ4rs'xx\|=Rc70I je2Kx?${D>;5!'$s5jM\)vŗL*jf3L aXϚNiukQ?MC,& >5.iz{v`./L|ɝ<Y*WKEbF-agH"ej!_ΐUXJ\ fr98е-Z&\83jfW?q`pl]i]莪Ī&Q!{,&vanB-UvYxOr-Ө67p59U8rBUm,Ho KCe8|‚ ʹ.#MjTE kw+J5G[5Zu˦6|$y5jElh1Ӹ 5iXOMhXww$:R[@_Ț:j+ZJ7Ճ`_ƴM%F|$cjË\p6u%(ϯ&D)WD.U$Zv,9.@ת{;U}=Ҏҵ)dC{~SHwjdvlN:,,D oF-fioxK A-*jz.t'OMExՆ\;)["aiiF\/|=;>eq%1ōҽ:5rgCjL Z}>E瀅[AcɁ3P<= 鉚` ;J$Ψq~!QޑۯfviP6)5ׄ -٧7e~$+edL3Odd3ҟф8=Blv& y)#@ ;;k*59{'*K$8bݱleiEvPӚ+VQҜ($\ bj=1NlEJ $)qAt4kuBU}hphZ7&A1uOh:.a(wx-lg>P3;RX"zB;Mc[en1^IhrLQ%"5?8lRߢVWu]>ftQLv @>IDv]5P vh`&yuXS[P5#x- Aj\Ԓ BUJ=55?!A A5„ ] P %}fd5td.+צGIFFVѪ{muٲjRC %E _NM*۞9_^r 5X;޹5#"1*wVrKT?Q|YA]/LBMmnS?x̸35~pVǃ0o23pd #`6d'k؆ Wƀj:ձQ >JEJ0k]*gj acm)AMZizѸŦ-ePu΂rH6vzi(*q/y=#Rsy%jj;:jƄK(ZC~H*G]'r4ecQ$Pd1 Enٹ? ǢTPv3'Tcw$9[ŅpRU]>JtEQzd$R[<+whKZ'so+.kjjs"!Sd̈g%v)RɕѨUsܫ]}j 5hs! TOw[V{J5.RCZtQ:[pMy+ѨIU3HuqH\A7Z+b}S$gIDAT05"!9<<6uug{OWP]dM=%*5$ؾwb{J-c&ud2' 5~ӵ*4\9^2i]K%.imJ߬ng1+hj[dis񔾎h]]9jW#Nf}哻3,O\lB*:|k'_1Rg"puvWd/!ׅBj⭒eww6Oa3@yF2έ=U<>rt'6{"0@ȢS54 ?B YsBMJBNDEnhdGӡd '!'QYhI jJ" {T7@A+2|cҮ 'la#9?{9{7cPyF&jԜrjQ *QZE^RSz-#X;|-ǣrTd͂}ph[Ћsy-55,$Xh Z)Њ5Nw׏Igjqiv݁Db8G'Ӭ|c'3# \d"#8&*_ EM 5XIM&u@MLM|db6։ooEj$-dw-cjKԸ4XLϩ-d&]SVj*]{FX[Ljk#gF68D]xFM*5TAQ{7/Dc!]xMw&@r=3X @RPғO&c^}tj*E"j&CDqb4m0$)fV1WPXnj&¯ڳ Gr1GN dԮ4-ϖ7E㷣Hۃ[FUY#;Taq唚МS_PI0JѠɊ5qVi%xBW_ `jl^o,CnGI:DvJM'/v7P{Yᔚ%5OEDQSBcbk<+o&]76dw=!GyŚչim> 곦& ؤ*xx$ uWJIISy} ձADFrJYpwe9gԘm.q߾9uE{e4Q3. K 4!kefԄ]"꫄,#53 LHw` )C,z߶poHȲh[pOm:Jb؂]뉭1h‹&>iAF)W|6YSfȄ|4T=Ղx''ɉjlmH,]*A7 5 C.Ȃf;9ZUpj$-P7R1ςGҘ0K猚œZlEM?{^9lړ65ܺmgCvx=zoLMYdN gf vqԤډ1g|:׵ȘޯTٙMyҎgS Rcsy2Wm#IrJl&m5,DTOxBЈ[\c&λh\ EP[iL̈Z!evr 5; Ur prG~>Gוr_ڑ&ߤ&ijrwV,3o&%3X.ji,+Ԁ2.x+H-[K81uv\hxԬeM;3iM4fY]}=Rw\;/mfUߠFlY5s>BcvS]05t,+ D9~+EM`@`IfZ3 6bjjvsVk[5,g35y$52|B.lɭԅ j׽pjk :5I${dDOuG'-hi”ͬJxƂiR&5pԔQ|,ecus+ַ8wp--I#zaBN$evB R2cIF艅W[7'=GUC6ý̪!rpڮɹ; obfIMǖX:2A*E[[ގL!bh X\!PT}MJkBa[r'knvv1\&3']1֤YPÖg!,m\?&HMbQC`ĒJ R.dqx{֬Sog^{mjn ,~crTV}Nx/f Eus^H- 5ӊ$))B~D7Mz"jN{FNWn}\hUps5(5MKQA$UIx̂:خO:4լ_R zZK|zBgVD:5^)AJы(S C:f)EK;럎*^j(`?rQ"ɥ3yLp&bs_WSj҂Pbz4Į  ;l]*VP9;'ju~·|N c:^qn*0$R 1X 9gF qKdPC0%ƛl!K G6Mt5Of'[R̪ɾk#GZugȷȞ B֜=5'$ظjLe ^SzC,fp/B?5P=NYd9F65OYvrJZPiYEt9ՔXw/Ԭ`!5^h1#(>wr[|r骩4\e9( Xpq"o^|/ jzRfVUT95.*!gI -ļem6.忒E񷹛yj|*o.ָ2Y7%LMCMg[XWmqI3jYek?VԒ&j(I yy'l ߉FS a鷄v͹keh!INkaTT)m(i5/5ȹDJ?tOk̛.j6w s}~(yyz S:&v ZQ3NR܈{VkwScuP,tGBIwKŤjvQ,"\i]h0h-z# 񰵘2KĸrYB9I.՚B.G^бt9Iy&l6U]#q?&D55ub&iGPK Ə`S@Vs]zEa +mn %6Jb޶% 9閔нܞV(fc uC Pۗ)"OD͓Z8"w< }J7M#@quɄUhYwQ9{fnOMpdEI]5Aڰ1jLJJ><ĔJEj ;ogonPuجsXUI yzLU *jX g VI3svcp# ZҲfnlBc, Q% Psb $d5Epf;\z(iGQsڭ,S#59$aӇ \>b4 2u4RҞ/yjhVzUP]EtQ+8Yb`T 2mrdY WF¨@˅ vQ{=ntvy uAsN2m&~r;Qv7t{zX*n󥚜9\lX;bnԈLdLGcSWbO-,\!or̽k;ҶyjVY )9&9fHǻF܁Ȏ26/6 ]CfN2W[jofĻ~'5 z_]@IY/JߝBsRԦSQxcحS `Cɚ:i Γ+X1}&ͫꗡCW&ښYf"|O&nD{OئTǖIdjGdDp]BJ }35A%tƹx)C ŻIENDB`libgd-gd-2.1.1/test/gdtest_wbmp_to_png.png000066400000000000000000000004361245535672000205520ustar00rootroot00000000000000PNG  IHDRPLTEU~IDATxR1 4Vԉ#CC/*IA`Η?F3ǔ%,QG 9gyktdK{n:u=06bV MQ?Lon7t[ G0|SdpswJE4L)p-Mz8CA"8qa`?~ m G ,IENDB`libgd-gd-2.1.1/tests/000077500000000000000000000000001245535672000143375ustar00rootroot00000000000000libgd-gd-2.1.1/tests/CMakeLists.txt000066400000000000000000000030511245535672000170760ustar00rootroot00000000000000 if (BUILD_TEST) SET(DART_TESTING_TIMEOUT 5) INCLUDE(Dart) set(GDTEST_SOURCE_DIR ${GD_SOURCE_DIR}/tests/gdtest) IF (ENABLE_GCOV AND CMAKE_COMPILER_IS_GNUCC) SET(CMAKE_BUILD_TYPE TESTINGGCOV) SET(CMAKE_CXX_FLAGS_TESTINGGCOV "-g3 -O0") SET(CMAKE_C_FLAGS_TESTINGGCOV "-g3 -O0") endif (ENABLE_GCOV AND CMAKE_COMPILER_IS_GNUCC) message(STATUS "gd include dir: ${GD_INCLUDE_DIR}" ) message(STATUS "gd libs dir: ${GD_LIBS_DIR}" ) include_directories (BEFORE ${GD_INCLUDE_DIR} "${GDTEST_SOURCE_DIR}" "${CMAKE_BINARY_DIR}" "${CMAKE_BINARY_DIR}/tests/gdtest") SET(TESTS_DIRS gdtest bmp gd gd2 gdimagearc gdimagecolorclosest gdimagecolordeallocate gdimagecolorexact gdimagecolorreplace gdimagecolorresolve gdimagecolortransparent gdimagecopy gdimagecopyrotated gdimagefill gdimagefilledellipse gdimagefilledpolygon gdimagefilledrectangle gdimagefilltoborder gdimageline gdimageopenpolygon gdimagepixelate gdimagepolygon gdimagerectangle gdimagerotate gdimagescatterex gdimagesetpixel gdnewfilectx gdtiled gif tga wbmp ) IF(FREETYPE_FOUND) LIST(APPEND TESTS_DIRS freetype gdimagestringft gdimagestringftex) ENDIF(FREETYPE_FOUND) IF(JPEG_FOUND) LIST(APPEND TESTS_DIRS jpeg) ENDIF(JPEG_FOUND) IF(PNG_FOUND) LIST(APPEND TESTS_DIRS png) ENDIF(PNG_FOUND) IF(TIFF_FOUND) LIST(APPEND TESTS_DIRS tiff) ENDIF(TIFF_FOUND) IF(XPM_FOUND) LIST(APPEND TESTS_DIRS xpm) ENDIF(XPM_FOUND) FOREACH(test_dir ${TESTS_DIRS}) add_subdirectory (${test_dir}) ENDFOREACH(test_dir) endif (BUILD_TEST) libgd-gd-2.1.1/tests/Makefile.am000066400000000000000000000231721245535672000164000ustar00rootroot00000000000000noinst_LIBRARIES = libgdtest.a libgdtest_a_SOURCES = \ gdtest/gdtest.c \ gdtest/gdtest.h \ ../src/gdhelpers.c check_PROGRAMS = \ gd2/gd2_empty_file \ gdimagesetpixel/bug00186 \ gdimagestringftex/gdimagestringftex_returnfontpathname \ gdimageline/gdimageline_aa_outofrange \ gdimagerectangle/bug00003 \ gdimagerectangle/bug00106_gdimagerectangle \ gd/gd_null \ gd/gd_num_colors \ tga/tga_null \ gdimagepixelate/gdimagepixelate \ gdimagecopy/bug00007 \ gdnewfilectx/gdnewfilectx_null \ gdimagefilledrectangle/bug00078 \ gdimagefilledrectangle/bug00004 \ gdimagefilledrectangle/bug00106_gdimagefilledrectangle \ gdimagecolordeallocate/gdimagecolordeallocate \ wbmp/wbmp_null \ gdimagecolortransparent/gdimagecolortransparent \ gif/bug00005_2 \ gif/gif_null \ gif/bug00181 \ gif/bug00227 \ bmp/bmp_null \ gdinterpolatedscale/gdTrivialResize \ gdinterpolatedscale/gdModesAndPalettes \ gd/gd_versiontest \ gdimagefilter/gdCopyBlurred \ gdimagefile/gdnametest EXTRA_PROGRAMS = \ gdimagestringft/gdimagestringft_bbox \ gdtiled/bug00032 \ gd2/gd2_im2im \ gd2/gd2_null \ gd2/gd2_read \ gdimagearc/bug00079 \ gdimageline/gdimageline_aa \ gdimageline/bug00072 \ gdimageline/bug00077 \ gdimageline/bug00111 \ gdimageline/gdimageline_bug5 \ gdimageline/gdImageAALine_thickness \ gdimageopenpolygon/gdimageopenpolygon2 \ gdimageopenpolygon/gdimageopenpolygon1 \ gdimageopenpolygon/gdimageopenpolygon0 \ gdimageopenpolygon/gdimageopenpolygon3 \ gd/gd_im2im \ gdimagecopy/bug00081 \ gdimagecopyrotated/bug00020 \ gdimagepolygon/gdimagepolygon0 \ gdimagepolygon/gdimagepolygon3 \ gdimagepolygon/gdimagepolygon1 \ gdimagepolygon/gdimagepolygon2 \ gdimagecolorresolve/gdimagecolorresolve \ gdimagefilledpolygon/gdimagefilledpolygon0 \ gdimagefilledpolygon/gdimagefilledpolygon3 \ gdimagefilledpolygon/gdimagefilledpolygon2 \ gdimagefilledpolygon/gdimagefilledpolygon1 \ gdimagefilledpolygon/bug00100 \ gdimagecolorreplace/gdimagecolorreplace \ gdimagefill/bug00002_2 \ gdimagefill/bug00002_1 \ gdimagefill/bug00002_4 \ gdimagefill/bug00002_3 \ gdimagecolorclosest/gdimagecolorclosest \ gif/bug00005 \ gif/gif_im2im \ gif/bug00066 \ gif/bug00006 \ gif/bug00060 \ gdimagecolorexact/gdimagecolorexact \ gdimagefilledellipse/bug00191 \ gdimagefilledellipse/bug00010 \ xpm/bug00185 \ xpm/color_name \ xpm/bug00166 \ jpeg/jpeg_empty_file \ jpeg/jpeg_resolution \ jpeg/jpeg_im2im \ jpeg/jpeg_null \ jpeg/jpeg_read \ png/png_null \ png/bug00033 \ png/bug00193 \ png/bug00011 \ png/bug00088 \ png/png_resolution \ png/bug00086 \ png/png_im2im \ wbmp/wbmp_im2im \ tiff/tiff_null \ tiff/tiff_im2im \ freetype/bug00132 \ bmp/bmp_im2im \ gdimagescatterex/bug00208_1 \ gdimagescatterex/bug00208_2 \ gdimagefilltoborder/bug00037 \ gdimagerotate/php_bug_64898 \ gdimagerotate/bug00067 if HAVE_LIBXPM check_PROGRAMS += \ xpm/bug00185 \ xpm/color_name \ xpm/bug00166 endif if HAVE_LIBJPEG check_PROGRAMS += \ jpeg/jpeg_empty_file \ jpeg/jpeg_im2im \ jpeg/jpeg_null if HAVE_LIBPNG check_PROGRAMS += \ jpeg/jpeg_resolution \ jpeg/jpeg_read endif endif if HAVE_LIBZ check_PROGRAMS += \ gd2/gd2_null endif if HAVE_LIBPNG if HAVE_LIBZ check_PROGRAMS += \ gd2/gd2_read \ gd2/gd2_im2im \ gdtiled/bug00032 endif check_PROGRAMS += \ gdimagestringft/gdimagestringft_bbox \ gdimagearc/bug00079 \ gdimageline/gdimageline_aa \ gdimageline/bug00072 \ gdimageline/bug00077 \ gdimageline/bug00111 \ gdimageline/gdimageline_bug5 \ gdimageline/gdImageAALine_thickness \ gdimageopenpolygon/gdimageopenpolygon2 \ gdimageopenpolygon/gdimageopenpolygon1 \ gdimageopenpolygon/gdimageopenpolygon0 \ gdimageopenpolygon/gdimageopenpolygon3 \ gd/gd_im2im \ gdimagecopy/bug00081 \ gdimagecopyrotated/bug00020 \ gdimagepolygon/gdimagepolygon0 \ gdimagepolygon/gdimagepolygon3 \ gdimagepolygon/gdimagepolygon1 \ gdimagepolygon/gdimagepolygon2 \ gdimagecolorresolve/gdimagecolorresolve \ gdimagefilledpolygon/gdimagefilledpolygon0 \ gdimagefilledpolygon/gdimagefilledpolygon3 \ gdimagefilledpolygon/gdimagefilledpolygon2 \ gdimagefilledpolygon/gdimagefilledpolygon1 \ gdimagefilledpolygon/bug00100 \ gdimagecolorreplace/gdimagecolorreplace \ gdimagefill/bug00002_2 \ gdimagefill/bug00002_1 \ gdimagefill/bug00002_4 \ gdimagefill/bug00002_3 \ gdimagecolorclosest/gdimagecolorclosest \ gif/bug00005 \ gif/gif_im2im \ gif/bug00066 \ gif/bug00006 \ gif/bug00060 \ gdimagecolorexact/gdimagecolorexact \ gdimagefilledellipse/bug00191 \ gdimagefilledellipse/bug00010 \ png/png_null \ png/bug00033 \ png/bug00193 \ png/bug00011 \ png/bug00088 \ png/png_resolution \ png/bug00086 \ png/png_im2im \ wbmp/wbmp_im2im \ bmp/bmp_im2im \ gdimagescatterex/bug00208_1 \ gdimagescatterex/bug00208_2 \ gdimagefilltoborder/bug00037 \ gdimagerotate/php_bug_64898 \ gdimagerotate/bug00067 endif if HAVE_LIBTIFF check_PROGRAMS += \ tiff/tiff_null \ tiff/tiff_im2im endif if HAVE_LIBFREETYPE check_PROGRAMS += freetype/bug00132 endif LDADD = libgdtest.a ../src/libgd.la AM_CPPFLAGS = -I$(top_srcdir)/src -I $(top_srcdir)/tests/gdtest TESTS = $(check_PROGRAMS) EXTRA_DIST = \ gdtest/test_config.h.cmake \ xpm/bug00166.xpm \ xpm/bug00185.xpm \ xpm/bug00185_damaged.xpm \ xpm/color_name.xpm \ gdtiled/bug00032_exp.png \ jpeg/conv_test.jpeg \ jpeg/conv_test_exp.png \ jpeg/empty.jpeg \ gd2/conv_test.gd2 \ gd2/conv_gd2_exp.gd2 \ gd2/empty.gd2 \ gd2/conv_test_exp.png \ gdimagearc/bug00079_exp.png \ png/bug00088_2.png \ png/bug00088_1_exp.png \ png/bug00033.png \ png/bug00088_2_exp.png \ png/bug00088_1.png \ png/emptyfile \ gdimageline/gdimageline_aa_b_0_exp.png \ gdimageline/gdimageline_aa_c_0_exp.png \ gdimageline/gdimageline_aa_d_1_exp.png \ gdimageline/gdimageline_aa_a_1_exp.png \ gdimageline/gdimageline_aa_d_0_exp.png \ gdimageline/bug00111_exp.png \ gdimageline/gdimageline_aa_c_1_exp.png \ gdimageline/gdimageline_aa_a_0_exp.png \ gdimageline/gdimageline_aa_b_1_exp.png \ gdimageline/bug00072_exp.png \ gdimageline/bug00077_exp.png \ gdimageopenpolygon/gdimageopenpolygon0.png \ gdimageopenpolygon/gdimageopenpolygon1.png \ gdimageopenpolygon/gdimageopenpolygon2.png \ gdimageopenpolygon/gdimageopenpolygon3.png \ gd/crafted_num_colors.gd \ gdimagecopy/bug00081_exp.png \ gdimagecopyrotated/bug00020_exp.png \ gdimagepolygon/gdimagepolygon1.png \ gdimagepolygon/gdimagepolygon3.png \ gdimagepolygon/gdimagepolygon0.png \ gdimagepolygon/gdimagepolygon2.png \ gdimagefilledpolygon/gdimagefilledpolygon0.png \ gdimagefilledpolygon/gdimagefilledpolygon1.png \ gdimagefilledpolygon/gdimagefilledpolygon3.png \ gdimagefilledpolygon/gdimagefilledpolygon2.png \ gdimagefilledpolygon/bug00100.png \ gdimagefill/bug00002_3_exp.png \ gdimagefill/bug00002_2_exp.png \ gdimagefill/bug00002_1_exp.png \ gdimagefill/bug00002_4_exp.png \ gif/bug00005_0.gif \ gif/bug00005_1.gif \ gif/bug00005_3.gif \ gif/bug00005_2.gif \ gif/bug00060.gif \ gif/bug00066_exp.png \ gif/bug00005_2_exp.png \ gif/bug00066.gif \ gdimagefilledellipse/bug00191.png \ gdimagefilledellipse/bug00010_exp.png \ gdimagescatterex/bug00208_2.png \ gdimagescatterex/bug00208.png \ gdimagescatterex/bug00208_1.png \ freetype/bug00132_exp.png \ freetype/DejaVuSans.ttf \ gdimagestringft/CMakeLists.txt \ gdtest/CMakeLists.txt \ xpm/CMakeLists.txt \ gdtiled/CMakeLists.txt \ jpeg/CMakeLists.txt \ gd2/CMakeLists.txt \ gdimagesetpixel/CMakeLists.txt \ gdimagearc/CMakeLists.txt \ png/CMakeLists.txt \ gdimagestringftex/CMakeLists.txt \ gdimageline/CMakeLists.txt \ gdimageopenpolygon/CMakeLists.txt \ gdimagerectangle/CMakeLists.txt \ gd/CMakeLists.txt \ tga/CMakeLists.txt \ gdimagepixelate/CMakeLists.txt \ tiff/CMakeLists.txt \ gdimagecopy/CMakeLists.txt \ CMakeLists.txt \ gdnewfilectx/CMakeLists.txt \ gdimagefilledrectangle/CMakeLists.txt \ gdimagecopyrotated/CMakeLists.txt \ gdimagepolygon/CMakeLists.txt \ gdimagecolordeallocate/CMakeLists.txt \ wbmp/CMakeLists.txt \ gdimagecolorresolve/CMakeLists.txt \ gdimagefilledpolygon/CMakeLists.txt \ gdimagecolorreplace/CMakeLists.txt \ gdimagefill/CMakeLists.txt \ gdimagecolorclosest/CMakeLists.txt \ gdimagecolortransparent/CMakeLists.txt \ gif/CMakeLists.txt \ gdimagecolorexact/CMakeLists.txt \ gdimagefilledellipse/CMakeLists.txt \ bmp/CMakeLists.txt \ gdimagescatterex/CMakeLists.txt \ gdimagefilltoborder/CMakeLists.txt \ freetype/CMakeLists.txt \ gdimagerotate/php_bug_64898.png \ gdimagerotate/php_bug_64898_exp.png \ gdimagerotate/remirh128.jpg \ gdimagerotate/bug00067_000_exp.png \ gdimagerotate/bug00067_015_exp.png \ gdimagerotate/bug00067_030_exp.png \ gdimagerotate/bug00067_045_exp.png \ gdimagerotate/bug00067_060_exp.png \ gdimagerotate/bug00067_075_exp.png \ gdimagerotate/bug00067_090_exp.png \ gdimagerotate/bug00067_105_exp.png \ gdimagerotate/bug00067_120_exp.png \ gdimagerotate/bug00067_135_exp.png \ gdimagerotate/bug00067_150_exp.png \ gdimagerotate/bug00067_165_exp.png \ gdimagerotate/bug00067_180_exp.png \ gdimagefile/img-ref.tga \ gdimagefile/img-ref.xbm \ gdimagefile/img-ref.xpm \ gdimageline/gdImageAALine_thickness_exp.png CLEANFILES = \ a.png \ bmp_im2im_dst.bmp \ bmp_im2im_src.bmp \ bug00132.c_35_diff.png \ bug00132.c_35_out.png \ bug00181.gif \ bug00181a.gif \ bug00227.gif \ gd2_im2im_dst.gd2 \ gd2_im2im_src.gd2 \ gd_im2im_dst.gd \ gd_im2im_src.gd \ gdimageline_aa.c_38_diff.png \ gdimageline_aa.c_38_out.png \ gdimagestringft_bbox.png \ gif_im2im_dst.gif \ gif_im2im_src.gif \ jpeg_im2im_dst.jpeg \ jpeg_im2im_src.jpeg \ jpeg_read.c_25_diff.png \ jpeg_read.c_25_out.png \ png_im2im_dst.png \ png_im2im_src.png \ tiff_im2im_dst.tiff \ tiff_im2im_src.tiff \ wbmp/wbmp_im2im_dst.wbmp \ wbmp/wbmp_im2im_src.wbmp \ wbmp_im2im_dst.wbmp \ wbmp_im2im_src.wbmp libgd-gd-2.1.1/tests/bmp/000077500000000000000000000000001245535672000151155ustar00rootroot00000000000000libgd-gd-2.1.1/tests/bmp/CMakeLists.txt000066400000000000000000000003711245535672000176560ustar00rootroot00000000000000 SET(TESTS_FILES bmp_im2im bmp_null ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest ${GD_LIB}) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/bmp/bmp_im2im.c000066400000000000000000000025311245535672000171350ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int r, g, b; void *p; int size = 0; int status = 0; CuTestImageResult result = {0, 0}; src = gdImageCreate(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } r = gdImageColorAllocate(src, 0xFF, 0, 0); g = gdImageColorAllocate(src, 0, 0xFF, 0); b = gdImageColorAllocate(src, 0, 0, 0xFF); gdImageFilledRectangle(src, 0, 0, 99, 99, r); gdImageRectangle(src, 20, 20, 79, 79, g); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_BMP(name) do { \ FILE *fp; \ \ fp = fopen("bmp_im2im_" #name ".bmp", "wb"); \ if (fp) { \ gdImageBmp(name, fp, 1); \ fclose(fp); \ } \ } while (0) OUTPUT_BMP(src); p = gdImageBmpPtr(src, &size, 1); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromBmpPtr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_BMP(dst); gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/bmp/bmp_null.c000066400000000000000000000003021245535672000170640ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromBmp(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImageBmp(im, NULL, 0); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/freetype/000077500000000000000000000000001245535672000161625ustar00rootroot00000000000000libgd-gd-2.1.1/tests/freetype/CMakeLists.txt000066400000000000000000000003441245535672000207230ustar00rootroot00000000000000SET(TESTS_FILES # bug00132 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/freetype/DejaVuSans.ttf000066400000000000000000021272601245535672000207160ustar00rootroot000000000000000FFTMHd<GDEF%XPGPOSytGSUB2OS/2 PVcmap e6cvt i9fpgmq4vjgasp glyf)|**Dheadr6hhea $hmtx1m8Mrkern\$<loca;`Mmaxp j4 nameoMT=post_\prep;HhŽI55 N}~    +,,-/045ST_`                / 0 1 2 J K K L [ \ h i   45^  | DFLT>arabHarmnhcyrlrgrekhebrlao latnnko tfngKUR SND URD MKD SRB (ISM (KSM (LSM (NSM (SKS (SSM (kern2mark8markFmarkNmarkVmkmk\mkmkdmkmkj     (08@JRZbjrzn. & T/ 021335CrV0&:  VY^VY^ &,28>DJPV\bhntz::::r 4 4 `,TUWXZ[\]_,TUWXZ[\]_JPV\bhntz$ l N>X  &,lwfTftfn &,28l`l~l~l`l~l`L "FLRX^djpv| '''tt ;888 - T !    $*06<6 2flrx~ &,28>DJPV\bhntzhhh=DhhhDhh=DDhh  %)*+  %)4 &,28>DJPV\bhntz{{{{{{{{{{{{{{{{{{{{{{{{{{{{{ $6HZl~ cj cj cj cj c c cj cj VY^>DJPV\bhntz*  &,28>DJPV\bhntz "(.4:@FLRX^djpv| $*06<BHNTZ`flrx~ &,28>DJPV\bhntz "(.4:@FLRX^djpv|     $ * 0 6 < B H N T Z ` f l r x ~      & , 2 8 > D J P V \ b h n t z     " ( . 4 : @ F L R X ^ d j p v |     $ * 0 6 < B H N T Z ` f l r x ~      & , 2 8 > D J P V \ b h n t z  "(.4:@FLRX^djpv| $*06<BHNTZ`flrx~{U:t!N8'Qn ppjjj,v,,vjj  XXXXD[j[j, 8 8>>j pjjj^jj,,,,,,,     8 8 8 j j>>, ppjI^`k/#eYYYcP`{U:tii!NQnU!Q{++++++jj++jj++jj++ 8 8jj 8 8jj,,X X ,,XX,,X X ,,X X      j j,j,j j j,j,j>  ++pp++,,,, ,,,,,,,,,,2  pp++pp++jjjj++jj++,,XX,,XX,,XXjjjj    XXjjXXjjXX&j&jXX&j&j[j[jSjSj[j[jSjSjXX 8 8jjjj 8 8,j,j>>SS&j&j>++jjj  pp++j++ 8jjjj++^++j++,XX,XX,XX,X X   >SSp++ jIII^^^```kkk///###eeeYYYYYYYYY (0SnoBqDc zs~^ VY^BHNTZ`flrx~F 'PV\bhntz "(.4U0+0008q00800i00E0 0100000P=i0v00v00d000UU8000U    !%  04"0 $6HZl~ cr cr cr cr cr cr cr cr,TUWXZ[\]_RX^djpv|``& b lrx~ &,28>DJPV\bhntz "(.4:@FLRX^djpv| $*06<BHNTZ`flrx~ &,28>DJPV\bhntz "(.4:@FLRX^djpv|     $ * 0 6 < B H N T Z ` f l r x ~      & , 2 8 > D J P V \ b h n t z     " ( . 4 : @ F L R X ^ d j p v |     $ * 0 6 < B H N T Z ` f l r x ~      & , 2 8 > D J P V \ b h n t z R``S`4rrLRLX X X X [r[r~x,LLRLLRLxLLLxx4RI^`n#YYY`R``S`++++++LL++LL++++LL@LL@XXXXXXXXxxxxxx++XV++,,,:,,,,:,:,,,,,:,:LrrX+F+Frr++L&LRR++LL++XXXXX~X~X X X X RRX X & & X X &&[r[rSrSr[r[rSrSr~~x~x~LLFLRFSrSrR&R&R++R&RL XVX++++LLRL++R++++XXXxXxXxXxX~X~4S4S4++&RIII^^^```nnn###YYYYYYYYY  0Sno'q)Hfg$$h**i5zj4?QZ^[,TUWXZ[\]_rx~`{{{{{{{{` <BHNTZ`flrx~]xx@[")@>E"~~x2x::"> @FLRX^djpv|]kxyyyxyz[f"w)h>yEy`P["~[~t`Yxy2{`uxJJ::  28>DJPV\bhnttbbbbt`~~`~` T R  !" &,28>DJPD6L  $Js}- {{~ .^djpv| $*06<BHNTZ`flL/'s.}////////s}/////.$&(,268DFHLRVX-* R S  ^ F J &,28>DJPV\bhntz "(.4:@FLRX^djpv| $*06<BHNTZ`flrx~ &,28>DJPV\bhntz "(.4:@FLRX^djpv| $*06<BHNTZ`flrx~      & , 2 8 > D J P V \ b h n t z     " ( . 4 : @ F LL\/.Rs''}srJf;RRsRR%}^Gb`R////}}J////Rs}f7R/'z`RR///.RR'}r`RTTRTcRRJ@@RjRjRbRb}RRRRRRRR}R555RRaRt;Q'RRRRRRR}}^G^dRRR::R'aHRR_R:RGR R~RJ}'/'}'}^TTT@X}Tg^GX^//LBRRf,4$R'_zRf4L}`ReT^/'^<\R&Rx9\RH$= D]$>BCHIJKRT  UV--WEEXNNYTTZYY[aa\ll]vv^{{_`bf iJqLm??BBEE**--st  R S     " % % ( - 4 4 8 8 < = ? A C C E I L O 3 3 "-.p0CDEGHI  !" &,28>DJPl&  $*06<BHNTZ`fltz $*06<BJPV\bhntz "(.4:@FLRX^djpv| "(.4:@FLRX^djpv| $*06<BHNTZ`flrx~     " ( . 4 : @ F L R X ^ d j p v |     $ * 0 6 < B H N T Z ` f l r x ~      & , 2 8 > D J P V \ b h n t z     " ( . 4 : @ F L R X ^ f l r x ~     " ( . 4 : @ F L R X ^ d j p v |  $*06<BHNTZL\/.*s''}srJ{#{{;j{//{{s{ {o{{'{}{^{G{b{`{{'{{}}{Q{{{{}{\LX;\//''{ssr`{{{'{{{./'}{r`{{T{{{{c{R{R{J|@{@{{{jj{{b{b{}{/{{{{{{{{}{{{3{33{^{a{p{{;{Q{'{{{}{}{^{G{^d{{{{{::'a{H{{/{{j:{G{ J{~^{}J|E{}{{{{E}{p{{t{}{j{{{b{{^{~~{}{t{^{{{{/'{{{H/O'oYNsT{a{E{{{{@{{t{{{{}{{{{T{`{kb{{K{{{{{{{{t{{'{///{{4{'}{{{O{t{t{e{sK{{{{'}{E{b{{^{{{T{{TT{{@{{{{{}{{{{{{{{{T{g{b{^{G{{{{^{{LBRf,4${' _zf4DL}1{`{e**}T{{^{{{/'^{<\&Rx9{\{{{{{{i$= D]$>?ABCDFG  HI55JBBKEELHIMNNOPPPRVQXYV[]X__[aa\ff]ij^lp`txe{{jkl pJxLm>V\]aacceeggoo|   -568<!">%-@77IDDJOOKUULYYMstNPQST ]gl!!s  t  u "y % %| ( -} 4 4 8 8 < = ? A C C E I L O 3 3p  "# )-8 "(.4<BHNTZ`flrx~ &,28{{{{{{{{{{{{{{{{{{orr{r{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{&!0#5PKr9KD &&K9a}au9aauaau/&DaDDkkDDDDkDD)ak}/DDa9}D}&&9}k}k}&D aDY}aaauNaaau}}k}ka aakkAk&k}}DHVaD)kkDN9a}au9aau/9a}au9aau/9a}au9aau/&kD&9a}au9aau/9a}a9aa/D?}DVD aDKr9KD &&Kk}k&/<&O$$%%&&''))**++-- .. // 22 33 445566778899::;;<<==HHIINNQQRRUUYYZZ[[ \\!mm"}}#$%&%'( )*+!!,,-((. /  0  ""&&100::?? } }2 3 4$$%%&&''))** ++-- ./22 3344 5566 778899::;;<<==DDFFGGHHIIJKLLOOPPQQRRTTUUVV WW!XX"YY#ZZ$[[%\\&mm'}}()* ++,,-../"/&&010101234352678888393:;;  3<3<=<;    !! "" ## $$>%%5&&''!((?++@--@//@0011"33@55@66A77B88C99D::??4EFEF G43H4IJ  A  K  L  B  A  B | |C } }D M N O^$%&')*+-./23456789:;<=HINQRUYZ[\m}  "&0:? }  R DFLT>arabLarmncyrlgrekhebrlao latnnko ,tfng> KUR SND (URD (  MKD SRB  (ISM 8KSM 8LSM 8NSM 8SKS 8SSM 8   aaltaaltaaltccmpccmpccmpdligdligdligfinafinafrachlighliginitinitligaligaloclloclmedi"medi(rlig.rlig8salt@saltFsaltL    !DLT\dlt| $,4<DTdh l  R  : ~ " V     8    F V f  \ ` d        B  >9LM *_ U    X Yi$=EEGGIIKKLMNOWW      ""$$&&((**,,..0022446688:;==??AAHHRRTTVV  **__ U U  X Y&   &v6Pblv",6PZd 1 0 ! "# 2$%&'() 3*+,-./     !"#$%(. = B  #&),/258;>ADGJMPSVY\D  JB6:F>ZV^bhfNRjnrtx0HJSno#q%B  !$'*-0369<?BEHKNQTWZ]l3vLD8<H@\X`dPTlpz 44668<AHJPRSnoq)1B  "%(+.147:=@CFILORUX[^l3u KC7;G?[W_cOSkoy 44668<AHJPRSnoq)12  ZZ YVVYZ~&8JlZZ ]Z ]Z XWUT XWTUWXZ] > $Rl$*06<[ZYXWVUT3^1]0\ &,[ZYXWT2]4]5IQS4 6 , WVWA(:FPZfr "   " K$; V 00 1(/ F X R")567DFZD&.6>FNV^fnv~ d  d b  b ^  ^ \  \ ~ ~ h h " _  _ ]  ]&.6 e  e `  `  a  a " f  f c  c g  g  _^`\]ba28?EMS_^`\]ba28?EMS D ,-DO  ,-O    ! LM *_ U X Y33f .  (PfEd@ m,,, ~OSXbu~V_ :UZot?5JR>PjGv#.[jx{EMWY[]} ' c q ! !I!K!N!"""###!#(#,#u#z#}######$#$i&&'' '''K'M'R'V'^'''''()) )A))))***/***++#,l,w-e-o_6<>ADOt QW\tz1Ya !@Z`ty? 7LT@RtFn&0]w{ HPY[]_ * j t !! !K!N!S!"""###$#+#s#z#}######$"$`%&''' ')'M'O'V'X'a''''')) )@))))** */*}**++ ,`,t-0-o_8>@CFRpvnlkjEC;6 POMLJDCBA@>=<:9864rhdcba`_]\TSRIE< ~|{zyxvutrqonmkecbW=9 aNMnmkjihedb_^=84.,nYKG>,NG 5{{ H ~bOQSWX\btu z~0\1VY_a  &  +,-.!:/@UIZZ_`o`ttpyq??8e l57JLRTH>d@PRjtFGnv#&.0[%]jQwx_{{abc *   E HM PW YY [[ ]] _}   + : H N a d ' m * c j q t !! ! !I !K!K Z!N!N [!S! \!" "" "" "# ## ##! #$#( #+#, #s#u #z#z #}#} ## ## ## ## /## 1## 2$"$# 3$`$i 5%& ?&&\''o'' s' ''w')'K'M'M'O'R'V'V'X'^'a''''''''''($))4) ) 6)@)A8)):))<))D))E**G* *J*/*/[*}*\****+++ +#,`,l,t,w-0-e-o-o__68<!>>&@A'CD)FO+R5eqsuw{ptvV89p;>r@DvFF{JP|Rk   !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`a rdei xpk 2vj ^ s b cgw  M )l|6cn T F m} b :   y qz5fqu-J3T99NR7s`s3VV9s3D{o{RoHT3fs +b-{T#\q#H99`#fy```{w``b{{Rffw;{J/}oo5jo{-{T7fD)fs, %Id@QX Y!-,%Id@QX Y!-,  P y PXY%%# P y PXY%-,KPX EDY!-,%E`D-,KSX%%EDY!!-,ED-,%%I%%I` ch #:e:-ff@ /10!%!!fsr)5 5@ K TX8Y<2991/0 P ]%3#3#5qeB@KTKT[X8Y1<20@0 @ P ` p ]#!#o$++`@1      91/<<<<<<<2220@   ]!! !3!!!!#!#!5!!5!T%Dh$ig8R>hggh`TifaabbNm!(/@U" '&( /)/))/B" ) *!#*- ) " & 0K TX8YK TKT[KT[X@8Y<<<1/299990KSX99Y"#.'5.546753.'>54&dijfod]SS\dtzq{---@A$*.U# jXV`OnZXhq) #'3@6$%&%&'$'B .$ &($4'!%   ! + 1 4K TK T[K T[KT[KT[K T[X18Y9912<0KSXY""32654&'2#"&546"32654&%3#2#"&546WccWUccUVcbWWcd1Zܻۻa ۻۼ 0@      !         B  (('+'$ .  .'.'!!199999991/9990KSX99999999Y"2]@ " ) **&:4D ^YZ UZZY0g{ "-  ' (   2'') #**(/2; 49?2J LKFO2VZ Y UY\_2j i`2uy z 2229]]3267 >73#'#"5467.54632.#"[UԠ_I{;B h]hΆ02޸SUWDi;#QX?@Yr~YW׀c?}<$$/1oX3go7@ KTKT[X8Y10@ @P`p]#o+{ 7@  KTX 8YKTX @8Y29910#&547{>;o @ <99103#654<:=JN@,       <2<2991<22990 %#'-73%g:r:g:PrPbybcy #@   <<1/<<0!!#!5!-Ө-Ӫ--@ 1073#ӤR@d10!!d1/073#B-@B/9910KSXY"3#m #@  10"32'2#"  P3343ssyzZ @@B  KTX@8Y1/20KSXY"]7!5%3!!JeJsHHժJ@'B   KTKT[KT[X8Y91/20KSX9Y"@2UVVzzvtvust]]%!!567>54&#"5>32Ls3aM_xzXE[w:mIwBC12\ps(p@.    #)&  )KTKT[X 8Y99190@ daa d!]!"&'532654&+532654&#"5>32?^jTmǹSrsY %Đ%%12wps{$& Ѳ|d @   B    K TK T[X 8Y<291/<290KSXY"@* *HYiw+&+6NO O Vfuz ]] !33##!55^%3`d^@#    KTKT[X8YKTX@8Y190!!>32!"&'532654&#",X,$^hZkʭQTժ 10$& $X@$  "% " !%190@]]"32654&.#">32# !2 LL;kPL;y$&W]ybhc@B991/0KSXY"KTX@878Y@X9Hg]]!#!3V+ #/C@% '-'0 $*$ !0991990"32654&%.54$32#"$54632654&#"HŚV г "Əُattt$X@# %!"" %190@]]7532#"543 !"&2654&#"LK:lL>$& V\s[#@<21/073#3### %@  <2103#3#ӤR#٬@^M@*B$#29190KSXY" 5Ѧ`@ #<210!!!!^O@+B$#<9190KSXY"55//m$e@+$     &%K TX8Y99991/9990y z z ]%3##546?>54&#"5>32ſ8ZZ93lOa^gHZX/'eVY5^1YnFC98ŸLVV/5<4q L@2  L4307$7CM34( (+(I+*(I,=M<9912990K TK T[KT[KT[KT[XMMM@878Y@ NN/N?N]32654&#"#"&5463253>54&'&$#"3267#"$'&5476$32|{zy!orqp ˘s'6@   0210].# !267# !2'ffjzSb_^^_HHghG.@   2 99991/0`]3 !%! )5BhPa/w.,~ .@   21/0 ]!!!!!!9>ժF# )@ 21/0 ]!!!!#ZpPժH7s9@ 43 1990%!5!# !2.# !26uu^opkSUmnHF_`%; ,@ 8  221/<20P ]3!3#!#"d+9.KTX@8Y1/0@ 0@P`]3#+f B@  9 KTX@8Y991990@ 0 @ P ` ]3+53265M?nj @(B  291/<290KSXY"]@ ((764GFCUgvw    (+*66650 A@E@@@ b`hgwp  ,]q]q3! !#3wH1j%@ :1/0@ 0P]3!!_ժ @4  B    >  91/<290KSXY"p]@V   && & 45 i|{y   #,'( 4<VY ej vy ]]! !###-}-+3 y@B6 991/<2990KSXY" ]@068HGif FIWXeiy ]]!3!#j+s #@  310"32' ! ':xyLHH[[bb:@   ? 291/0@ ?_]32654&#%!2+#8/ϒs R@*  B     39991990KSX9Y""32#'# ! '? !#y;:xLHHab[T@5  B    ?  299991/<9990KSX9Y"@]@Bz%%%&'&&& 66FFhuuw]]#.+#! 32654&#A{>ٿJx~hb؍O'~@<    B %( "-"(9999190KSX99Y")])/)O)].#"!"&'532654&/.54$32Hs_wzj{r{i76vce+ٶ0/EF~n|-&J@@@1/20K TX@878Y@  @ p ]!!#!ժ+)@@   8AKTX8Y1299990]332653! ˮ®u\*$h@'B91/290KSXY"P]@b*GGZ} *&&))% 833<<7HEEIIGYVfiizvvyyu)]]!3 3J+D {@I      B     91/<2290KSXY"]@  ($ >>4 0 LMB @ Yjkg ` {|      !   # $ %  <:5306 9 ? 0FFJ@E@BBB@@ D M @@XVY Pfgab```d d d wv{xwtyywpx   []]3 3 3# #D:9:9+=; f@  1 ]@ /<20KBPX@   @    Y3 3 # #su \Y+3{@(B@@ 91/290KSXY" ]@<5000F@@@QQQe &)78@ ghxp ]]3 3#f9\ @BB K TK T[X8Y991/0KSXY"@@ )&8HGH    / 59? GJO UYfio wx ]]!!!5!sP=g՚oX;@CK TX@8YKTKT[X8Y210!#3!XB-@B/9910KSXY"#mo0@CKTKT[X@8Y<10!53#5oXޏ@ 91290 # #HHu-10!5f1@ D10K TKT[X@878Y #ofv{-{ %@'   #   E&22991/9990@n0000 0!0"?'@@@@ @!@"PPPP P!P"P'p' !"'''000 0!@@@ @!PPP P!``` `!ppp p! !]]"326=7#5#"&5463!54&#"5>32߬o?`TeZ3f{bsٴ)Lfa..'' 8@  G F221/0`]4&#"326>32#"&'#3姒:{{:/Rdaadq{?@  HE210@ ].#"3267#"!2NPƳPNM]-U5++++$$>:#qZ8@G E221/0`]3#5#"3232654&#":||ǧ^daDDaq{p@$   KE9190@)?p?????,// , ooooo ]q]!3267# 32.#" ͷjbck)^Z44*,8 Cė/Y@     LK TX @8YKTX 8Y<<991/22990@P]#"!!##535463cM/ѹPhc/яNqVZ{ (J@#  &#' & G E)221/990`***]4&#"326!"&'5326=#"3253aQQR9||9=,*[cb::bcd4@  N  F21/<90`]#4&#"#3>32d||Bu\edy+@F<21/0@  @ P ` p ]3#3#`Vy D@   O  F<2991990@ @P`p]3+532653#F1iL`a( @)B F 291/<90KSXY" ]@_ ')+Vfgsw    ('(++@ h` ]q]33 ##%kǹi#y"F1/0@ @P`p]3#{"Z@&   PPF#291/<<<290@0$P$p$$$$$$$ ]>32#4&#"#4&#"#3>32)Erurw?yz|v\`gb|d{6@  N  F21/<90`]#4&#"#3>32d||Bu\`edqu{ J@  QE10@#?{{   {  {]"32654&'2#"s98V{>@ GF2210@ `]%#3>32#"&4&#"326s:{{8 daaqVZ{ >@   GE2210@ `]32654&#"#"3253#/s:||:/daDDadJ{0@    F21/90P].#"#3>32JI,:.˾`fco{'@<  S  SB %( R"E(9999190KSX99Y"']@m   . , , , ; ; ; ; $( ( *//*(() )!$'      '/)?)_))))))]]q.#"#"&'532654&/.54632NZb?ĥZlfae@f?((TT@I!*##55YQKP%$78@  F<<2991/<2990]!!;#"&5#53w{KsբN`>X`;@    NF921/290o]332653#5#"&||Cua{fc=`@'BK TX@8YKTKT[X8Y91/290KSXY"@Hj{  &&)) 55::0FFIIFH@VVYYPffiigh`ut{{uz>]]3 3#=^^\`TV5` @IU U U U   B     K TKT[KT[KT[K T[X@8YK TK T[KT[X8Y91/<2290KSXY"@" 5 IIF @ [[U P nnf yy          %%#'!%""%' $ ! # 9669 0FHF@B@@@D D D @@VVVPQRRPS T U cdejejjjn a g ouuy}x}zzxy  { v } @/   y]]333# #V`jjj;y` C@F      B   K TKT[KT[KT[X@8YKTX8Y91/<290KSXY"@   & =1 UWX f vzvt        )&% * :9746 9 0 IFE J @ YVYYWVYVV Y P o x  /]] # # 3 dkr))`HJq=V`@C        B     K TKT[X @8YKTX 8Y9129990KSX2Y"@     # 5 I O N Z Z j        '$$  )( % $ $ ' ** 755008 6 6 8 990A@@@@@@@@B E G II@TQQUPPVUVW W U U YYPffh ii`{xx   e]]+5326?3 3N|lLT3!;^^hzHTNlX` @B K TK T[X8YKTX@8Y2991/0KSXY"@B&GI  + 690 @@E@@CWY_ ``f``b ]]!!!5!qjL}e`ۓ%$w@4 %   !  % $  C %K TX@8Y<<29999999199999990&]#"&=4&+5326=46;#"3>l==k>DV[noZVtsݓXX10#$@6%   #%#C %K TX8YKTX@8Y<2<9999999199999990&]326=467.=4&+532;#"+FUZooZUF?l>>l?VWstݔ1#@  1990#"'&'&'&#"5>32326ian ^Xbian ^V1OD;>MSOE<>L5 b@ <2991/0K TX @ 878YKTKT[KT[X  @878Y P ]#53#3+e#!Q@+     "  "<<<221<9990%.'>7#&73JDFHAMf fIX⸹)**'# 32!b`@!    <<1/2<2990K TX@878Y66].#"!!!!53#535632NL=ty-=))׏/я^R#/@I -'! - -'!0 *$0* $ $(st*(s099999999919999999907'#"&''7.5467'7>324&#"326{r%$&(r;t=:x=q%%&&s7t@?s9q(&%%s>v:@t8s'%$|pprR@F  B     fe f e<2299991/2<2<290KSXY"K TX@878Y@(' ' ')((79  ]]!#!5!5'!5!3 3!!!c`Tþ{yT9{3{JD{3@ <210##  \= >@54&.#"#"&'532654/.5467.54632{?>?>S8alӃ\]>9̭IXW:fqր][;;ȦI.Z.L-[.K''PGZsweZ54m@''TLf{xf[1,pEF)@dd1<20K TK T[X@878YK TK T[KT[KT[X@878YKTKT[X@878Y@````pppp]3#%3#^y/IC@&=>:A$104G$ 7aD=0^* D^ J21/02#"$'&5476$"3267>54&'..#"3267#"&54632mmllmmmmllmm^^``^^⃄^]]^\^BB@zBCFInmmmmnnmmmmng^^^傁^^__^]⃅]^^! "s;)_@3(%%  * "(kl"k *22999199990!!#5#"&546;54&#"5>32"326=P,]uu>DIE~bRhP{@p?Dq[[""CO@Mr%# @I    B   o o n<2991<2990KSXY" 5 5%-+#-+#RR^@ 10!#!^d10!!d/8L`@6EBC?2H09JC 9 $HE301B54&'.'2#"$'&5476$#32654&'2#'.+#^^``^^⃄^]]^\^ㄘmmllmmmmllmm}{{nWXfi`C.;I6Bf^^^傁^^__^]⃅]^^gnmmmmnnmmmmnb>KL?gwyVpMI`3Db+/10K TKT[X@878Y!!Vu=  @  Z[Z10"32654&'2#"&546PnnPPnoO@v+..ooPOmmOOp1.-rB .@     <2<21/<<0!!#!5!!!-Ө-}}^J@$}}B ~9190KSX2Y"!!56754&#"5>32 "?XhU4zHM98rn81^BQ##{l0b(H@'    #)~&~ )999190#"&'532654&+532654&#"5>32 \e9}F4wCmxolV^^ad_(fQI7Z`mR|yOFJLl?<:=svcE`sRf1@ D10K TKT[X@878Y3#fV` M@%  !   NF!2912<990"`""]3326533267#"&'#"&'#% )I#ER2bf*V H<9 NPOONN;9 %@]] 91290!###.54$yfNݸHF103#F#u@  ' 1/90!#"&'532654&'T76xv.W+"J/;<+->i0Y[ 0.W= ,@   |]|| 12035733! c)t'+n`d.@  klk 9910!!2#"&546"32654&PXγгi~hi}|P{ݿܾsH# @I  B   o op<<991<2990KSXY"5 %5 +-+-#^R^  ^R^  &{' d 5?&{'td 5b&u' d 5 $@/  !# #%" " "!& %999919990KTKT[KT[X%%%@878Y@ ttttv]33267#"&546?>7>5#537ZZ:3mN`^gIYX0&DeWX5^1YnFC98ŸLVV/5<6hk&$uhk&$uhm&$u  +@ ]1h^&$u #+@ @O# /#]1hN&$u  +@ 0?  ]1hm !@T   !!  ! !!!B     !  VV!"2299999991/<9990KSXY" #]@  s P#f iu {yyv v!# ]]4&#"326!.54632#!#TY?@WX??Y!X=>sr?<҈_Z?YWA?XXN)sIsrFv)H@9  B     <291/<0KSXY"]@gww  ]!!!!!!#!59=qժF՞su'&&z-k&(uk&(um&(u@@ ]1N&(u @@ @]1;k&,/uk&,/u`m&,/u +1XN&,/u +1  g@    2  y<291/220@(   ]]! )#53!!3 !iP`P5~.,3^&1u"+@ 0?""]1sk&2'usk&2'usm&2'u+@]1s^&2'u!0 +@ 0!?0 !/0!0]1sN&2'u +@ @O]1? @M    B   <291<290KSXY"  ' 7 7w55v8vL57y5yy5f +@< +,  )&  *&& &,+,* # )#3,99999999199999990@*WZWU!je!{vu! FYVjddj(|svz( ]] 324&'.#"&5!27!"&''3>_'y=_''NOy;WfNPƀ[gX@CHp@CpDfbMKYg[KKX)k&8u)k&8u)m&8u +@ / ]1)N&8u +@P_@O /]1k&<su =@   ? 2291/0@ ?_]332+#32654&#'ђ/@0-'!  **.  !' $'$-F099991/990@@'(     ! "&  : :!MM I!I"jj  ]]4632#"&'532654&/.5467.#"#:A9`@IPAtx;e\`Wqqs`/Q*%jd_[?T>7;[gp{-f&DCR @?&/&&]1{-f&DvR @?&/&&]1{-f&DR (,+1{-7&DR.< +@ ./<.<]1{-&DjR -( +@(o(P-_(@-O(0-?(-( ]1{-&DR%@&,,& 2882 ++1@ ?5?/5/]0{o{3>@C'-%= 4%:.-*1 %?47&%7& =&-7"E?<9999912<<29990@0+0,0-0.0/00@+@,@-@.@/@0P+P,P-P.P/P0+0@@@@@@@@@??? ??0,0-0.0/@,@-@.@/P,P-P.P/ooo oo`,`-`.`/p,p-p.p/,-./]q].#">32!3267#"&'#"&5463!54&#"5>32"326=DJԄ ̷hddjMI؏`TeZ߬o0Z^Z55*,ywxx..''`f{bsٴ)qu{&Fzqf&HCqf&Hvqf&H"+1q&Hj@@ ]1f'Cof'v\f& +1F&j +1qu('@^%{&%#${##{#({'(#&'('%$%(('"#" ! B('&%"! ## #)&' ! (%#" QE)999999919990KSXY"?*]@v%+("/#/$)%-&-'*(6%F%X X!` `!f"u u!u"%#%$&&&''(6$6%F$E%Z Z!b b!z{     {zzv v!x"**']].#"32654&#"432''%'3%F2X)6 ~r4*!M!ü޼z&77kc\̑oabd7&Qquf&RCsquf&Rvsquf&Rs+1qu7&Rs .+@ /. .]1qu&Rjs +@ @O0?]1o )@ r <<103#3#!!oAH +@<+,&  )&  *&& &,+,* # #Q)E,22999999199999990@p(?-YVUV jf!{    { z{ {!"#$%{&%--&YVUZ(ifej(ztvz($$]] 32654&'.#".5327#"&'')gA\*g>}66]C_56`?`!*(Ou))Hn.Mw834OMx43NXf&XC{Xf&Xv{Xf&X{ +1X&Xj{ +@ @O0?]1=Vf&\v^V>@ GF2210@ `]%#3>32#"&4&#"326s:{{8daa=V&\j^+@ 0? /]1h1'q;$ +@@O]1{-&qJD+@o]1h'J$+1@oo]0{-&OD"+1u&${u{&Ds'k&&-uqf&Fvs'm'Lu& <=/1qf&Fs'P&&Luq&Fs'm&&-u@]1qf&F&'q&G @_?]1 q$J@$ "    GE%<<1/<20`&&&]!5!533##5#"3232654&#"F:||ǧN}}daDDa3&(q=q'qH@p]1m'u(@@]1qH'H@p]1P&(uq&Hu&(qu{&Hxg&(o@@ ]1qa&H!+@!]1sm'\u* <=/1qVZf&hJ  <=/1sm&*uqVZH&JsP'\u*@?]0qVZ&hJs'^*qVZ4' J;m'u+ +@ / ]1dm'uK*+1KQX88Y@ @@]:@    8 22221/<2222203!533##!##53!5qʨ"ʨ9Qx>@!   N  2221/<2290#4&#"##5353!!>32||}}`Bu\zzedx^'.u, +1g7'+1Y1'q.;,+1H'q+1gm'.u,+1VH'+1u%'d,u 'JLP&,/u<<1??]0y`,@ F91/0@4D@P`p]3#\`{f'-\,@1V'M8L@F1f_m'.u-+1V\f'+1j' .' N` @(B F 291/<290KSXY" ]@_ ')+Vfgsw    ('(++@ h` ]q]33 ##%kǹ`!jl'nv/Jl'ZvO<1KQX@8Y@O]0j' /' O@@]1j'/'9O @]1j'y1w/'ysOK QKSKQZ[X@8Y1u ?@   : y<<991/900P]3%!!'79Pw^Mo;jnH ^@  z z <<991/90KTX @ 878Y@ @ P ` sz p ]37#'7Ǹ}Lɸ{JZjXj3l'v1@O]1dm&vBQ @?O]13' 1d{' Q3_&1g +@ /  ]1df&Q +@]1'QU~V;@  AKTX8Y21@ /0!"#367632+53265PͳNijQRW1fOCCoa`ZVd{;@  NF 21/90`!!]+5327654&#"#367632dRQi&&||BYZuccH``01`e22wxs1'q';2 +@]1qu&qsR+1sm''u2+@]1quH&sR#+1sk''u2quf'Rs ;@   299991/220!!!!! !# !39OAg@AժF|pm|q{'3@1 . ("%4"1 K1 Q+E499912<2290@%?5_5p55555????? ooooo ]q].#"!3267#"&'#"32>32%"32654& H ̷jbdjQGьBN5Z44*,nmnm98olkp݇Tl'v5m&vBUT' 5J{' UT_&5}g@_]0Zf&U +@]1l'v6om&vBVm'u6  ))Ic:1of&%V  ))Ic:1u&6zou{&Vzm&6u + ""Ic:1of&V + ""Ic:1u&zP77u&zW_&7sg +1@_]07&W7p@]1F@   @ @ <<1/2<20@@p ]!!!!#!5!!  ժA@7C@  F<<2<<2991/<<<20]!!3#;#"'&=#535#53w{%&sQQ''PO>)^'u8 '+@ ]1X7'X&+1)1'q;8 +@ / ]1X'qX+1)m'u8+@]1XH'X+1)K&8E @@@]1X&X| @@@!]1)k'u8^f'Xe)&8u`&X'Dt'|:+1V5m'EZ+1t'r|< +1=Vm&^\+1N&<su +1\l'v=Xm&vB]\N's=X&]\m&=uXf&] +@ ]1/#@  L<1/0!##53546;#"c'&яN()g ,D@% ")%,$'".EG* ,(%#'F-<2221/<204'&#"327667632#"'&'##5353!!STTSSTTS:YX{{XY:E/tssttsstRd0110d}}P)C@#   . *29991/90"]!2654&#!2654&#%!2#!"#546D+ |v݇f>orqp ˘0_i1F&8@# (EGF'221/067632#"'&'#!%4'&#"3276s:YX{{XY:NkrSTTSSTTSd0110dtssttsst 3@  . /21@  / 9/04'&#!!276!2#!#ONDNO|N8DCDCD>@  G /221@  /ij9/0>32#"&'##34&#"326s:{{:"QrdaadDs'0@  0 <10>3 !"&'53 !"shSzjffbGGaaHH_^9'(9^_sZd$D@"! %  %  0%210&&].# !267# !2676;#"'ffjzS` SfM?nb_^^_HHgh$bzq"N@$ ## HE#210@ $$$$$].#"3267#"!2546;#"NPƳPNM]-GFE0iL~++++$$>: a .@   2 99991/0`]3 !%! )"#5465BhPav/w.,~0_i1F.@  .21@   /0)!"!!"$54$3!!@DNN|#+qZ?@G E221/0` ]5!#5#"3232654&#" M:||:ndaDDadqVuc'T@ )E Q E(]99@   (99@%S 910%!"'53254%&'&326&#">kGxfu'~@3cnBOFFu\0%p9 *E +@    21@ /0!5!!5!!5E>9+uD@& 39190!!"56$3 ! 7327upo^   2`_FHg[{(@@$ )) #)* &)190.54$32.#";#"3267# $546؃ YsrSǾmTj^У%!| &${spw21%%ݐf#A@  2991990 ]!!!!+53265ZpPM?nժHVe@#   LK TX@8YKTX8Y<<9912299990@P]#"!!+53265#535463cM/ѮcMPhc뻫Ph*Nsd&I@43! F'1@'$$'990%!5!# !246;#".# !26uu^[DM?npkSUmnꪖ_`%Rv%@ 'P $&]ĵ 91@ %$&222990@ #%$$<<$#$%#@$"! #9927654'&'3#"'&5476736,3,,3,6hC.KddK.Ch B9Iy\\yI9B z^ȮwBAWWABw1G*O@, *&NF+291@ '&&  #/<<9990%27654'&'5+"&54&#"#3>323LTWJ>ymoF||BuLibep_!edg .@  KTX@8Y991/9903;#"&n?M-– R E@   >f3@)B 6  999991/299990KSXY" ]@068HGif FIWXeiy]]!3!+53265jG?n+Vd{Ds 1@ 3221@   0! ! "!&32sy:;x Vb[[z=g&24v'X Rs3@ !  <1/0!4&#! !2!2"327&nzy;pa'Xܯ–bb-LgFqVY{!:@ """# E"9104'&##"3232"327&&&idRصRQ@TVt1098``:6:@   ? 291/0@ ?_]32654&#%!2+#"#5468ʄv/ϒ0_i1FV$O@$#% %G  F%22991990@ `&&&&]%#46;#">32#"&4&#"326siL:{{8(adaaT#.+#33 326&#A{>ٿJx~hb؍Oђ E`.>323267# '&5476?67654'&#"ri{CDr{xwj璑klz<;YZ_s&&rrƫ->>n~FE/ppٶlm+23cv@@67d{'@  !! RE(99991@ '$$(90@S !S BKSX99Y"]@/)?)_))))))]@% '$&((*//*( ( ))$]@.,,,;;;; q>323267#"&546?>54&#"Lf@eaflZ?bZN?$%PKQY55##*!I@TT((0V!&'&#"3;#"'&5# 54!23!n|wx'%dQW/R5-0A3=g)(V\`@o7V !!;+53276=#"'&5#53w{%&sF0j&&QQ''01PO`>X@ @  991/2990K TX@878Y@@p ]!!##"#546;^vժ+Zi1F7I@  F<<2291@  /<299990]!!;#"&5#53546;#"w{KsբcMcN`NQfT@ @@ 120K TX@878Y@@p ]!!;#"&!n?Nժ=–_&84i' XN:@!3   1@   <2220!! 47!5!3254'5!X ƱXw>*a"Lav-@   /<91@ 0%254'&'5!'&'&33cAnMagn"ʦmWDtz–d@  @ @99/1@  /9990@        BKSXY""#3 632#54&9%NZUUIG9\[ny6P=V{j@  K TKT[X @8YKTX 8Y9991@:        B    9990KSX2Y"@      '$$  )( % $ $ ' 755008 6 6 8 A@@@@@@@@B E G TQQUPPVUVW W U U ffh { F]@%     # 5 I O N Z Z j ]+5326?3 67632#54&#"N|lLT3!;^0XQ99) hzHTN43`rr:T*\@5    B  B K TK T[X 8Y9991/<20KSX<<<323#L:s_%'ST_ijxzX"Jh0@umHLIwKK!!C12\RI`1](2! '&/&53 7654'&#!#!!hcUQ;-ܘ-;dc|cd\])Q8+lhU)$yy$)UKKKKIJ-%hL?`%2!"'&'5327654'&#!53!!LicUQ;-^cdjTmcd\]8+lhU)$y%12KKIJ&X$!"'&'5327674'&+#5333!plnUQQLITNPc9:V>}ws}#(rAbLrV{#36763254'&#"s4QҸMNr98xܭz BR1pqWBAV&@ F10@ @P`p]3#V''V:@    <<2<<219/<2<203!!!!#!5!5!5!s____,Ԫ m'?' f'@'qf'@Gf$'-/V'Me/V'MvOf'-_1V'M>1V'MeQhm&$u<1{-f&DZ +'+1`m&,/u  Ic:1^f&  Ic:1sm&2'uquf&Rv <1)m&8u<1Xf&Xv  Ic:1)3&08X1'q{;)Z&86X"&X)Z&80X"&X)`&80X"&Xq{h3&${-1&qR;h3&${-&DH4'q>{o'qs%T@!$"43 &<1@"#%&99ܰ KTX"@8Y<203## !2.# !2675#535!5yyuu^opkC XSUmnHF_`%'XqV{ 4X@"2% G,E5221@ #% ) 2/3 &)/99<20`666]4&#"3263#!"&'532767!5!6=#"3253:aQQRZ9||9=nXF]@,*_EG^[cb::bcsm&*Ju!<@!T!$!]1qVZc&JJjm'u.m&Nu* +1KQX88Y@ @@]se'42qeu{'Rse1'q';qeu&qsm'uyXL/f&TVdf'%  Ic:1 '=' ']'q']Gsl'v*qVZc&Jv-5@8221@ /203!327653! '&5!#>=B>d`gd"dPNOKZ߀xxv 9V%#3676324'&#"8WST=<HW5xz7 GF3k'u1dd&QChs&\}{s&}Hl'\v{oc&vefl'vHc&vhp&$z{-d'Dh6&$>{-H'eDp&(zqc'H6&(>qH'Hsp&,Yzc'fw6&,>>UH'$sp&2Azqud'Rs6&2>quH'RTp&5yzJc'%UT6&5>^H'-U)p&8zXd'X)6&8>XH'X'v6o{',V'S77'WRs16767654&#"5767654'&"567632¥~b[?FjOQ_ciqYxw`eGRxQYڵ@XKy^qjj=vX{5?:.PB*8hicqMmwqڎ{\(GO{26767654'&#"5767654'&#"567632GrXBAR9?|cGIN`\hOm`bs[yx@Il|IPxģ3H2#PQ̝qpD(4%3254'"632!"'#67&5#"'&76323 76'& %44nI5"C0:XY|ˀ|YX:ST$TTTTT- H:E<$d0110d^jtssttssq% ;" 7654&327654'&'52 '&54767&'&5476!˸jkkjpkk_;̨_`Lm䖋_``aCUtMMMMMN'|OEH-AA+Mdha "ccttttُcc"FYXSJqq/ 4" 7654'& '&5467&'&547327654'qSRRS SSSR:4IRQ=4?+IHIJ,MMMMMNMMjRp@Y "ccttttُ"#VKjX AAAAAtw>\V+53276=!5!5!!Hri&&gPP%01oXV`+53276=!5!5!!۞Hri&&5ejLP%01%hP&$@{-&D_u&(zqu{&Hz{s3&2bqu1&qs;s3&2iqu&RsO''t2qu&sRs3&2jqu1&qs;1'qr;<=V&q^\p\%3254'"632!"'#67&73%44nI5"C1- H:EVy` 8@   OF 991990@  @ P ` p ]3+53265F1iL`aq 1= 76'& %67632#"'&'+5#"'&7632;'&  7/ST$TTTTT:YX{{XY::XY|ˀ|YX:rSTTSST$TjtssttssHd0110dd0110d^PtsstjtssqV{ 1='&  7+#"'&76325;67632#"'& 76'& STTSST$T:XY|ˀ|YX::YX{{XYST$TTTTTdtsstjtssHRd0110dd0110jtssttss|3 #!#'#7'7 3!Jafp|҈2F;R/o]jY'FF8O ",'&76!27&'!2767# '#&# rfuSv=:efc.1 tsfjwv9tFXh$xYv+!f //_H$$\/ح ]"+'7&576!27&'32767#"'&#"i`UUQ.-Y_vcPNONMRS]7GGcc^N lOU ^q+$Vqrg j ;@   : <<1/<20@ 0P]33#!!#53ʿ_w1##'!5!7 !4" gZ8f,i> XRBY bo{=4'&/&'&54632.#"3#"'&/&'&'&'53276 23@LLfLNZDE11?PS{W*L'TrGY$alfccaFF'K((%$JK((**T@%$!,KL[@~$=&[#5-,X3`!;#"'&/&+=!qjN\1*LlTrGY=Z^e`1~$=&[? %P6@ 9991@  /0##32654&+"56;2'񍚚EOZ*,FP{7@   991@  /032654'&#"5632##/dLUIVVN}AH+Fnt  (\@ #  . &%)<229991@(% #/99/<20*]!!!2654&#!2654&#%!2#!#53[D+ |迿ɐʇf>orqp ˘p _@ 8AKTX8Y<2<21@   29/<<2299990]3!33#! 5#53!3265˥ߦ®j*$}h)B33#!!!!#7#!#!AX .AA<VF㪾FqB&-1&'&'!3267#"'#&'&3273&#"#So+Jajbck{cPm!)81G\9/Zo Z 6Z44*,!  C "2JcfRY@    9 KTX@8Y<2991<2990@ 0@P`]#+53265#5333RM?nʿwHVS@$   OF<<22991<2990@ @P`p]33#+53265#533#F1iL`(aؤsf$C@$  %" %  %2299199053;#"&5# !232#"nEMMT–\\xEEqV@{$H@"%"%G E%229910`&&&]#"&=#"3253;32654&#"@F:||:Li1戮VּdaDDada= T @  ?  !<299991@!  B  /<229990KSX9Y"@"]@Bz%%%&'&&& "66FFhuuw]]#.+##53! 32654&#A{>ٿJxʿ~hbw؍OJ{=@ F<<<1@  /<20P]###533>32.#":.I,h<ĤfcΡ3!733!#!53!ٗ ٗwјv9 V`+5326?!533!33!+N|lLT3!øLùmhzHT33`{ ,@ .% F-22991@-&%"*-%  9990@1?$?%?&?'O$O%O&O'_$_%_&_'o$o%o&o'$%&'$%&']@+?#?$?%?&?'?(?)O#O$O%O&O'O(O)_#_$_%_&_'_(_)]2654'&#"367632#!3267#"&߬A@o\]?^^fe~ST`Te__Z+f{b:9ml)Lf01a```FE..'qZ{8@G E221/0`]53#5#"3232654&#":||ǧdaDDa{ 8@  G F221/0`]4&#"326>32#"&'#3姒:||:/Rdaad` $C@  !G! F%22991/0`&&&]4&#"326>32#"&'#46;#"姒:{{:Z[/Rdaad~Ӝ}}{ 0@ ! !"EH!<106763 #"'&'5327654'&#"LQQU]SRMNONPccccPNON5#$+qrrq+qs{'/O@( ,,H"E02991@.*%00@ 11111].#"67632#"'#47&'&!23254#"NPc'>IjJ?_SPI 9/-U:Me5++rQ,3H=Y}/)9DhQ#3 :#:9KqV@$K@$%"%OG E%221990`]#"&=#"323;32654&#"@F:||:Li1戮VּdaDDad^ؙa=q$=@" %%  GE%2210`]546;#"#5#"3232654&#"iL:||ǧadaDDaq{"r@ KE#91@  #90@)?$p$$$$?????,//,ooooo ]q]47632!"&'532767!7&'&#"qkcbdcjfg ]\RS^,*4cdWWZZq{A@$  KE91905!.#"5>3 #"73267qN ͷjbck 9Z44*,#ė|{ 4w@6.('4 KE5<Ķ&  91@/.'""5 5@  &"90@ 4 &'<<<<<%6'6'32#"'&'&'&5>3 73;#"'&5Nf  R`\Lladbck $˸&&i+@WR֊>8E#Z`vg'#d4*,#)u10`Z|B|*|>i@@603273;#"'&5|PUTZGUU]UTNHtCDFEwGQPabLq_&&i+@WR@\l%88ZX83,-F@.. NBj10`ZȦFq|/;@ 1 &,E01@00)0#90"327654'&+5327654'&'2# 76`cchҗUTNHtCDFEhqr<V`K@   OF<<22991<2990@ @P`p]33#+53265#53F1iL`(aؤqV 0U@)  &#-* *-+& G E122991/990`222]4&#"326!"&'5326=#"32546;#"aQQR9||9iL=,*[cb::bcaqVZ` #C@ # GE$21/990`%%%]!"326!"&'5326=#"43!aQQR9|=ͻ,*[cb:*qO{8@4 E1990%#5!#"!2.#"326Ae{-h]_cƳO|$$>:77>>`Rd`#y@ %  $ĵ 91@  $222  990<<<<< 3#"&54767327654'&'bB_j&;;&j_BC(::(xܱSccS$-EIdccdIE-`d`#y@ %  $ĵ 91@  $222  990<<<<< 3#"&54767327654'&'b)rG,EE,Gr)C'88'bLx>>xLb-!@2FF2@!-VX`9@     NF21290`]332653##"&||Cua{VfcdC@!   N  F2991/<9990`]#4&#"#46;#">32d||iMBu\~aedVd!J@%  " NF"2991/9990`#]+53265#"#46;#"632diLiMHa=~a >@    F<<<2221/<20@ @P`p]33###533#¸`<Ĥn`Ft` '@   221@   /2205!#3!53t褤K#<@ % V V$<<1@#! !//2<903327673#"'#&'&#"#67632= &}33[ &}33[ %$RIJ %$RIJLT5@  <2<1@ /9/<2033##4'# 7632&#"3=5*7M\TK9V_ (@  F 1@   990;#"&5y=x1F|t(L6$@#&#" F%<̲#91@B""  " /9/ 990@$#@  **8;ILT[q ]@$$%$$5$7E$FT$\ ]@    ]2!"'&'5327654'&+5!#3!CicUQ^cdjTmcd\[je8+lh%12KKKJ3Lb&^@PP F'<91@  #''<<<290@0(P(p((((((( ]%#"&5332765332653#5#"'&Cb`ruSSrw=ZXyzVUy=<b`^zbze32>>Vb&a@PP F'<91@  #''<<<290@0(P(p((((((( ]%#"&5332765332653##"'&Cb`ruSSrw=ZXyzVUy=<b`^zbzZe32>>V{0c@PP)%'F1291@ %*!*-(&/<<290@02P2p2222222 ]>32+5327654&#"#4'&#"#3>32)E__RQi&&ru99wSS?yzUV|v{zH``01NM_``gb>>Vk{Q@N O F2991@ /9@   990`]#4&#"+532653>32k||F1iLBu\satedVJ{;@ N  F21@   /  90&54&#"#3>32;#"R||Bu&&i1F``edH10d` y@BNF 991/<2990KSXY" ]@068HGif FIWXeiy ]]!3!##`ylqu{ ,@  Q E2210"!.265!2#"qt蔔98q$`I@  E2ij 991@   /<<@ 9/0!!!!! '&76!#";:E*%xxxx%`ݛlklm>|032>5#"326=4>32#"&'#".H`83L##L38`U։סW:]k4j i4ob?ģ_E1E_RSll:uy32JI,:.˾ fcVJ{:@  F2190P].#";#"&53>32JI,Li:.˾atfc~{%@ 21@  /29903!5346;#"iLAat~{3!5376'&+532ʴ'&irH20%P`@4  B      F299991/<9990KSX9Y"@]@Bz%%%&'&&& 66FFhuuw]]#.+#!232654&#0s2âJ{Qpwu t]:'`iVNM``E@  F299991@  /29990332673#!32654&#Q{Jî2s0jp|Ɓuw`':]t i`MNVoV{0@C  S('  S'('B1 '(!.1' ($R$+E19999190KSX99Y"0].#"#"/;#"&=32654&/.54632NZb?ĥdXLie@f?((TT@I!* ajYQKP%$V4@ O F<22991@  99046;#"+5326cMF1iK»Ph)aV O@ !O F!<<229921@! ! !99<20546;#"3#+53265#53#5cMF1iK`NPh(aؤi7V3e;#"'&74'&+532M&&i1FRR'&cQ]10`a(h((VaYV!#"327673## 54!3476;#"w|n!̵5RWQîd%'3A0Ǜo@`\V()g7^3@   /<<2991@  /<2990]!5!4&+5323#{Ksբ>`N7V=@   F<<2991<2990]!!;#"&5#53w{Liൣa>`C@     NF2221/222220` ]3!33##5#"&=#5!326:CuȮ||h=$#^lfk`8@   91/20@ 3 3#f%.]`8XV`@"B  OK TK T[X8YKTX@8Y2991/0KSXY"@B&GI + 690@@E@@CWY_``f``b]]!!;#"&=!5!qjLLi/F7e`ۧa%X`!@  "KTK T[X8YKTX@8Y299<21@  /<0@ BKSXY"@:&GI #+ #690#@@ECWY_#``fb###]]!367632+#47!5!3254qjL"TA`:&>R~ie8FX`ۢG7W9W`/=3<;4%6]XL/` @ "!̲91@B!  !9/ 990@ @  **8;ILT[q ]@  %$ 5 7E FT \ ]@    ]2!"'&'5327654'&+5!5!`q|/=@1 %,%E01@0 0"0( 90";#"327654'&% !"$5467&'&5476EwEFDCtHNTUhcc`a|p<:!a>>`V.9@ F<<991@   /<203#33## 54!3#"32767Ku_+xG`͋BA0 L` ## 33R9L T#`@ F1/03!!`3qV $C@  #%% "GE%2210@ `&&&&]32654&#"#"32546;#"#/s:||:iM/daDDadaX$L@ & %<<ij#1@  $! /<2KPXY032765&'&#"56763 3###53T?V:9cPONNLQQUmlprLbAr+#}swԤX$M@ &"#E%<<ij "#1@ $!# ##/<2KPXY0535&'&5476!2&'&#";3##plnUQQLNONPc9:V>ws}#+rAbLrq &) 76'& %3!!!+5#"'&7632/ST$TTTTT iL:XY|ˀ|YXjtssttssH^Lۓd0110MqL4@#5#"'&76323!2!"'&'5327654'&+5 76'& Z:XY|ˀ|YX:jejbVQ^cdjTmcd\]:ST$TTTTT3d0110d^L$8*mh%12KKKJjtssttssq 3: 76'& %%!332!##47!#5#"'&763233254#/ST$TTTTTghL<):XY|ˀ|YX:FXjtssttss_ 3<;4d0110d^6[7@F.#"#"'&'#"'&5#533!!;5327654'&/&'&54632NZED11?QR|{Za]gQQ{%&sfccaFF3,@LLf?((**T@%$!,KL[[!&PO`>''M5-,QK($)$JK7V%.!5476;#"+53276=#"'&5#53!3wxWQîc&'QRF1i&&QQ3%&sN[V((h)``01PO`>''7p-9D!6!2&'&#"63 #"'47!"'&5#533276'&#"&57!3w{UQQLNONPcccO+eKTIQQ;BS_r(ր%&sz#+qrfr v)2LOAPO`> 'KV ''/Vo5+5327654&#"#!##535476;#"!;67632oRQi&&||ӹWWc'&-BYZuccH``01/яNUV((hce22wx#5.#"#"'&'#34632327654'&/&'&NZDE11?PS{|Zb]hf8b_caFF2-@LL?((**T@%$!,KL[[!&2-,QK($)$JK 3!!!+iLLۓ6 333# #333# #6ttttU=63@    <2<21@  220!#!#!#!#6kkUXrXJ!32653##"'&554'&+532||BYZucc&&i1FQRybe22wx 10`` Vv,!5#"'&554'&+53232653;#"'&'BYZucc&&i1FQR||*&h2FRKe22wx 10`` by60`Yu0@ 32tNN^luu)qJy}wYYk\g88u:KSX@ 32tNN^lugrB0)qJy}wYYk\xkW6Vr88 #@<<1@03+5327653#zt43r,Bttx66XVru@ 1@ /0.#"#3>32.biuu$uT  qksa97G327653#5#"'&'Gc45tt%:;T  98kJa9Gu 327653;#"&=#5#"'&'Gc45t0B,rf%:X@?X=>POPPu"'&4763"3sPOOPs@XX@PPOP>=X?@X>u32765&'&#"567632#'y7$#?q22110335WDDFk[@*7K$@ ` XFh_@Cu#&'&547632&'&#"3kGDEW53301212q>$%6y[AmC@_hFX ` @$K7*@ 2% % g 25-5g'|?f3# #fg|?f33|g?f7@ u91290K TKT[X@878Y3#'#f?f7@ u91<90K TKT[X@878Y373x^@1@/0#^+b+qsRf3#ff #ofv^@1@/0%#^++Tq^#onvsR3#lo#E@ j,5!##–, 533##5#5j!5!>j)9H W@ VV1<0K TX@878YKTKT[KT[X@878Y332673#"&v aWV` v HKKJLDfN@ d10K TK T[X@878Y KTKT[X@878Y3#  @ V xV104&#"3267#"&54632X@AWWA@Xzssss?XW@AWX@sssLu @   '1/90!33267#"&546w-+76 >&Dzs5=X.. W]0iJ7c@$   VwVv99991<<99990K TK T[X@878Y'.#"#>3232673#"&9! &$}f[&@%9! &$}f[&@Z7IR!7IRfB@991<20K TKT[X@878Y3#3#߉fx%3;#"'&5&&i+@WRd10`ZȢf '#7'373\\]]\aa``u # 5473733254/MMz /1/03#zttu/2&'&#"#"'&'532654'&/&'&547632j1549W++](}24NM9>=D@?>=RX o(l00GF@99 a /$*+MW33 k2-*)*IX01 u! #'#37 ͉H+u#&'&547632&'&#"3kGDEW53301212q>$%6y[AmC@_hFX ` @$K7*@X@ 1/0!!5!AGЈX'@??//21/]0!!5!3A4X@ 21/0!!5!3AhhX'@pp0021/]0!!5!3A4X@ 1/0%3!5?p+v'qqf3#3#@fx.SMvJ!'&'&#"#67632327673#"&9 &}33[&@%9 &}33[&@7 %$RIJ!7 %$RIJf6@ D910K TKT[X@878Y # mXfvqPf6@ D910K TKT[X@878Y3#fs?f<@u991290K TKT[X@878Y3#'#?fsH7b/q|  )1H+d%@ 910@4D]3#hF)I@ dd 91<20@#4D`````````ppppp]3#%3#^y)7{"@ V@ V /1@@ /0632#546?654&#"7pihX,#w3-.>GZdH3UC=A   (6%""($4fCf<@u991<90K TKT[X@878Y373NxsD#DD'4]fB@991<20K TKT[X@878Y#!#͇fxx)1')1H #.#"#> v aWV` v ")KKJLD( @0#3Ӥ?#55#53pp{53#7"op{y3#@uUCqPUv &D53#5#5_&3##3D_U?p!5!#Ik{1@V/K TK T[KT[X@8Y21@ /0532654&'3#"&=X.. W]0iw-+76 >&Dzs5V @  V21@ /0"&5463"3VZ||Z(55(}ZY|x5'(5 3!5353D_ #5!##걈 & #53533##׈ 5! zV '+53276=0RQi&&``01wV %3;#"'&5w&&iQR10``fSC'SjC( @V xV1@ /04&#"3267#"&54632[6'(55('6y|ZZ||ZZ|&65'(56&Z}}ZY||jT @03#Ӥ#uzLuDT#DD T#5!#뉬Jc9X#"4533273273" v aWV` v "6KKJL9HS/TB  #"'&'.#"5>32326SKOZq Mg3OINS5dJ t]F ;73 !;?<6 7=xh!5xhh5!Ĥh'`_^NO'ygfFXY @  V21@ /02#52654&#Z||Z(55(B}ZY|x5'(5[3!53[J.T!!&bc9X632#&#"#&'"#72;tv gfv ifvtR+ '7'77}`}}`}}`}}`p}`}}`}}`}}` .54675>54'&'C!RI 7!RI 0PQn +0PQn : '  fCqPfvH7FbV+I#5!#!Ֆ֖V,2!5!5!5!>>2xx3#3#@tx!#!–*>,Jf'73327673#"'&'#7&'&#"#67632Bmk  &}33[& !Bnk  &}33[& g  $%RJI g $%RJI J%3#3#'.#"#4632326=3#"&HҖ9 $(}gV$=09" (}gT";C! 2-ev 3)dwJ"c( 7!#'73!'3p~(͛3#557'2d͛~~x&'&4767@*,,*@rNPPNr*,@A++{OPPN1'+Ubx5567654'&xrNPPNr@*,,*{NPPO{++A@,*.Dp pk Ppk!!p kpT!!p ଔ*7#'&'&#"#67632327673#"'&O,$e5Fqp[?9ZO,$a9Gqp[?9Z7  $0GJI "7  $,KJI pn w(5!'3#7ws~~d͛tf@103AntVH@10%#AnHV #"'&=3; #V!. {q{'yOF{'y#sRf1@ D10K TKT[X@878Y3#fFR&jl@_]@_q0hf'HFyuf't#f'%}f'z'f'-(f'n2f'h66'.Fh$%j@ 1/03!!)ժh=@ B1/0KSX@Y !3f5:9+(\=;+s!2@"" "#3"10!!"3276'&' ! '&76>b܁܁:xżp[bb,j.h<@ B1/<0KSX@Y3#3#:9&+031b *@    <<1/0!!!!!!29iggqs2;3 F@B   <<1/220KSX@   Y%!!5 5!!>!8ߪp7<s'<@) !%(<<<<1@' %'/<<<<0367654'&'&'&76753#–bbʖbbWssWWssW=;;s.@ <<1/22<20!6'"'&336763#ּՂnʊnhg椌gHN&3@ &("3'1/<2220%!567654'&#"!5!&'&576! cccd?IH1/GGaʦa>”XN'/u' +1N'qu2 +1qf&>nf&PBVdf'Df&FF*&Rqy *@ ,%E+99@ ?/]q@ ) !/99@<<10@  ]@IIIJN LNIK ]@:9:88? <>]@ + +*))]@  ]@++]'&#"3273;#"'&'#"'&763 N,-=MKLyHc( #) Xn^T).^,ru7 nik%1)0T*XoW)&V!7@E F21@  90%#! !"3 5 4# yYo 0kEdZ&J:@ V`@@ 1@ /<20@ 993#&+532i^;,_1FLdVD~qu-T@(/E( Q!E. ]99@%%.99@S910&#"#"'&4767&5!232654'&'&fu5KxD7VUV[a~@Fu\0%p̥@$OF(Iqrs`g |2=@" 33'(#,34 '0E310&'&547632&'&#";#"32767#"'&546p<@ KQX@8Y1@ 20%#457654'&# !5!ʄOTJPE* :;f,KOxsPWKL,#%5,*3Y'iVd{1@  FN  F21/0@]#4&#"#367632d||BYZuccH`e22wxqu$!O@ """#E QE"2]21@?]0@ w##]!3276'&#"2#"'&76EVSI 6VQ@=񈉉d~uvn` @ F1@ /0;#"'&5c"$lYoRR`+.0`b` I@   F 21@ /<20@    <<33 ##Gb`/ZFB?= F@ 1@ /<0@  # #'&+5z~J/k`ue<2~V`wJ`B@1@ /20@ 99!367676'&'31!xdLjE.*{`T|p5dwY|rNįtkR&@@ (" %'1@ '#"'<90%#457654'&# %$47#5! $ڄOTJPE* :MKOxsPWKL,#%5,*,X$Rݿ qu{RJ`/@  1@ /220!#3267#"&5!##J117,#J%x\c`PH? XV{1@ EQ F]1067632#"&'#44&#"326=;{:+fZ#adqR{$6@ !& HE%1@% %0 !2.#"32#457654'&-ULNPƯPTJPE* >:##++LOxsPWKL,#%5,*q` 1@  QE]1@ 0"32654'&'!##"'&76sRVVOcm񈉉qnsȷzn휝dm`#@  1@ /20%;#"'&5!5!!$lYoRR\ W0`b*`+@ E F@?? ?]1@ /<0327676'&'31'"'&5R27ki;jF-*eb`+@EvfwZ{sxvpVh )=@+E(#E*<<1@ *'*<2<20"27654'&'2##"'&7673=A__UVF6˷džfB:VVMpˑRh]p[nmNssg.;Uda@    <<91@  <<90%KSX@   99  9 9Y#&+53;'$ܕ11FA3N11F~0)~pV`6@   <<1@  <2<<0&'&53367653#EkUJ|CUvܷ%aw~LB,BTxnc#n'`8@E  E1@  /<2<0 433233243! &aƏ˪ޏƛa!)R@O@+}&Fj.*&jRquf&}L*f&"R'f&VYM% %52767654'&'&#"'&76#327674'&iPTwDy$2uz]6`;[;~oxҤko7&C]JN:PWO^p=lW5I pAKu_ըoskKꀰ-V{HVqu$ *4'&#" '&47632#"'&32761BS@8yJ̃hh~w[UPUp~GBZZ7Ai6np}TL󨛜WQ%#4''&#"5632%632#"'&FR**RMO((4;UCHk&!>*SKVHv H# 0r{C @[)/Bf'n^PWQN'u^pV'A@)   $E(<<<<1@ (  (<<<<02##"'&76327676'&#"DžǷdžǷqMTVMqqLWULc휙owgsugHgusgAm`5!#%$! 47)323764A,Ma")aM:GϤ*RѧOp[g9&'&47#"54654'&#"563277632327"'532! `7"7$>9[@[`7"7>9[&F]_I I5l|"O z:6hl0'[Ml |"Oz:6hlf$11sX#&'&76!   76';:{HpҳI椤qVu{ "32654'&#&'&7632sVVUVVV9kjstntstu n}{R$ 32#457654'&# '&76)F`{[mzYTJPE* :xe+wTOxsPWKL,#%5,*eNqRQa#"32#457654'&#"476!>cccnPTJPE* 9֗h4HqrqLOxsPWKL,#%5,*>#)@VF'347632&'&#"!!#"'&'53276`1213$)),x:KAb933.1220W@Rd >Qoɏ?s K_7"'&76'&526n 'BQ_'BQ_[~,`*l#FR`*l#FR #!3&pM]rV`!#56! #'#64?!"QhRR_@0:IKiXL}/M4!wx#&'#&' #'nd2Fb.-t`4#M!P^sK='6767&'&'#"'&46733276=332764''3=D۴vayͤgDd''dey{d;]TCHI}rHGFFtAGCT_8d榈d*0QA^^^Fkmihhimw'AFU(`%!$! 4337643'676#aڏޏڇ9iŚkp[Q 5@+h@ф{I%l +?sVH32763## '&6%`nbbcDhh(J @?G6qV{ 7653##"'&54763Pr^SLTT:XYڅcнtst1Rd01ȢK% '676767654'&#"#3676L'Pe^Ґ8*7D ! ! 12԰.#AL.#^Yq4+& "H4B;;=/?"+VhPOV !! 7654'&#"#676! 3 7llc^#,V)ۄe]6?fضdVj{ # 7654'&#"#67632327\B\\TP%I/yYk}oSKu,2R¤ຐs5%! &'&#"567632 67632'&#" ;!53276n"?E! rK,/ 4'Kr !D<&tEGGH h=" C(FK#C "&E !!6{5%! &'&#"56763267632'&#";!53276[96:@%((%@:6-:IkI:8=3553gs%+$67632! '&76!2767&#"327*W8QU{2Τ|sK^lȺhiieb-sJV"1Pһ '$Astxssq[/&67632#"'&76!27674'&#"3276I,)e[xtgO_\SG]EZSTVXXTRS7xJF61𢢜Pһ ''rsstxsst,V#5!#!#!3`d`du7U#5####!3_pzpppg3#"54654'&#"563277632327#"'$47(`7"7$>9[@[`7"7>9[@[|"O z:6hl0%[Ml |"Oz:6hl0%?[MV{$4767632#"'&')! $'&  7Z6;x[Y: +STTSST$T%Уb^#10dX4tsstjtssq{FVyMsaq{!&'&#"!!32?# '&76!2%%cjf_[_fMJOhk en(' c\\c( +{!56763 !"/532767!5!&'&#"'(ne khOJMf_[_fjc% ؜c\\c Vs'& ! !###-}-!+V` !!###`{`UV{'4767632#"'&'!!#5#5'&  7Z=;{XY:eSTTSST$TfZ#10dȪpptsstjtsss'Hs'&y3s''yk&uN&uf4@  <1@/20%+532654&#!#!5!!!2L>o||Rh"9+Fjk&us'N@  2<1@  IIPX@8Y0! ! &! !!! 'zOFӐhgս6,XNf-T/3@   <1@  /<20!565!32#!% 4&+pٕxL@+8/Xڦ5@ 2<21@   /<2<20!!#3!332#4&+326 z6࡟9d݇,@   <1@    /<202#4&#!#!5!!||Rqf9+Fk&u3k&u#m'ru; )@   1  /<20)3!3!#++h$.@  . 21@  /04&#!!26!!2)DlN݇@%j@ 1/03!!)ժe4@ <1@  /2220%!!67!3#!#p&axު D+?x4&A((v@   <2991@B   /<<2290KSX@    <<Y@ I:I:I:I:I:I:@  <<<<33 # # # 3DDxM(?@ * %)21@  %&" )02#"$'532654&+532654&#"5>I8z,|йԳƆ\qѲ|!ĐBY+wps{M("3 y@ B  6 991/<2990KSXY" ]@068HGif  FI WX ei y   ]]#!33j+3m&u# + KT KT[KT[X@ 88Y1 Y@   2991@ B  /<290KSX@    <<Y3! # #_yT:%@   1@  /<035675!#!T>Wxfb/X++0;+s2;@ 1/<0#!#;"++3s'&7#> 1B /20KSX@   Y%+53276?3 3 OM?w.-!suٵ2&]*jklyj =@!   <<<<1@ /<2<203>54&'$%53# W==U+  -=;; )@  <1@ /2<0)3!33#;ʪ+$@  21 /20!!"&533!3_||xdv+ *@    1@ /2<<0%!3!3!3OOʪ+++o2@  <1@   /22<<0)3!3!33#OOʪ++< *@  21/0!!5!!2#4'&#!!276GN6ONDPO+DCDCF&, $@   21/04'&#!!2763!2#!ONDNONDCDCo#N@ <21@   IIPX@8Y0! 7!5!&! 56! ! 'oOzFՎaa0&8@''!&$#(  !%$'2<1/0"3276'&76! ! '&!#3~܂܀s;:ŴL椤kj@@  21@ B  /<0KSX  Y3!!" &$54$)#!:ƒdv'V+w{-{Dp7):@+E'Q! E*21@*$ *9902#"'&5476$%676"32654&}:[;z631-~LӔ{0w)v ,u8w>` /@ " F!21@  /0!2654&#32654&#%!2#!r~~hhVlj9_ZZ^SJJOgyr`F1/03!!`3k`4@  <1@  /2220%!!6765!3#!#}v[(bt:d6(U3Rq{HF`@   <2991@B   /<<2290KSX@    <<Y@ I:I:I:I:I:I:@  <<<<33 ##'# 3?nn`QO6m|(N@ &* )1@ #)) ) KQXY KQXY0#"&'532654&+532654&#"5>32|PZG]twGabLx\l%%pZXkYF@\]y` ?@B  F F 991/<2990KSX@  Y##3y`}`y&# +KTKT[KT[X@ 88Y1` Y@  F 2991@ B  /<290KSX@    <<Y33 ##Tsŷ`OQ5Ls`$@ F  1  /<0356765!#!L8D{X^~ŷoPO` M@B   F F 1/<290KSX@   Y! !### >? ˸ʹ`'P` '@  F F 221/<203!3#!#U`7qu{R`@ FF1/<0#!#`3`V{Sq{F<m` 1/20!!#!<1BB`3=V`\pVg (3B@5E)! '.E4<<<<1@,41$ 4<2<20327&#"#"323>32#"&'4&#"326/{brrb{9SS99SS9{brrb{/Ǩ<9^N5=L^^LN^Ǩ;y`[` (@ F <1 /2<0)3!33#9U`33R`"@ F21/20!!"'&533!3Hf\45h)_Vu;;` )@ F  F 1 /2<<0%!3!3!3ڹ"ٹ`3+`2@  F<1@   /22<<0)3!3!33#"ٹڹ`333R>.` ,@ E  21@   /02#!!5!!!2654&q8$~͓7_ZZ^`'">`%@ E  F21 /04&#!!263!2#!z~~@9LZ^_n7q{M@ H<21@   IIPX@8Y073267!5!.#"563 !"'q2 ǚ-VړiVFHL{ :@ E  F2<1@/0"32654&632#"'##3Jq и¾.`At"`<@  21@ B  /<0KSX  Y;#" .5463!##zwwVtS^a\'qk&CZq&j/V?@N F <221@ /<20#533!!>325654&#"#߰Bvz||яLmedY).ПĞm&vq{N@ HE221@  I IPX @8Y02&#"!!327# ǟ 2ғ-{FViګVH>=o{VyLFVyML`6@!E  <1@ /<0356765!32#!!%2654&+L8DثX^x~~~ŷ7oPv_ZZ^`8@E   F2<21@    /<2<2032#!!#3!2654&+N޹"\~~`7`73_ZZ^/:@N F<221@ /<<20#533!!>32#4&#"#߰Buʸ||яLmed*m&voyk&C]=V&^` )@ F F 1  /<20)3!3!#TfUf`3s43276=332764''3#"'&'#"'&4673I}rHGFFtAGCT_8d{{ђed''dey{d;]TCZmihhimw'AFf^^^^F'`V!2#!!5!53!4'&#!!276XNpqONDNOQQfDCDC$4&#!!2!5!3!!!2##~~EE^͓uʣ+#3376!2&'&# !!!2767# '&SvwhfstgFtsfjwvú 9$#G_//wƪ//_H$$O{#2&#"!!327# '&'##33676>\" , Ux{ z{FVAW^3VH`3ʀ !#!#!#3 73` !#####3 Ñkk`_ !#!#!#!#3!3  o_<9d7`!#####!#3!3 kÑkk`_s##767!#'&'!ʓdսxQPtՀ`>YY~b҆12z(k{`! #4'&'##767E]kKV:VS8V‰Jl&VtO\KtU'4! !#'&'##767!#3!PtՀ`ʓdսUn>qd2z Y~b_49n(.`! !#4'&'##767!#3!7kKV:VS8V‰]w&VtO\Kt`?sVszS#"&#"3276&#"#"'&54763!27654'4327654!"567376767632'&#"ssD#`At bTDt;<}J5?u_hFAXVRuťޠsj#B#' "2ZbrRUgr %',azQ^XRj7&6J- @' WoWdE\`[tO#"&#"32632&#"#"'&53!2654'&'"#5223 54'&#"5673767632&#"vmDPb!',-cX;b12i?,ZnN .rr. >._- > ^ >‘  tӪ ҫ q{&P%327654'&+"&'&'#";67>2# '&5476!36767623 !#"'&'&r-HVV?- ,4, -GVUH- ,4 .xt. 4 .wt. 4 `ta  _tp_   颈   袉   vt M#&#"56763 #5765#53#"'&'&#"#"'&547673!27676323 4'&'39vZ^Nzz%G!ft[na`zxz{n[tfCGo~[U]LKfdKJ]U[~oFCP/L&+CYg,'ID@@DDDk63366336Fk :#&#"56763 '5765#53!"$"# 33276762324vZ^Ozz$F"vrTRrƒ>IxddyI?В/L&+CYg,'IP8[ 77 [8Gs3 @#'##'##'3276=332764''3#"'&'#"'&4673~d2222222dhI}rHGFFtAGCT_8d{{ђed''dey{d;]TC3dddd'mihhimw'AFf^^^^F' &#'##'##' 433233243! d2222222daƏ˪ޏƛa!)ddddR@O@+sV'!# '&76!2&'&# 3!#SvwhfstkSh$#G_//ӂqV{! '&576!2&'&#";#UQQLNONPccccɖ#+qr͹rq;'''7'77'77did}}didii}}}d}}}}dBz/!"'&'&'&547676763!476767623 8  8 g    ) M #&#"56763 v][Jw}$)/K'*Ca"53#7 a#55#53gF` &3@MZg#.#"#> #.#"#> #.#"#> #.#"#> #.#"#> #.#"#> #.#"#> #.#"#> v aWV` v "8v aWV` v "v aWV` v "fv aWV` v "v aWV` v "v aWV` v " v aWV` v "v aWV` v "AKKJLQKKJLKKJLKKJLKKJL)KKJLKKJLKKJLX- #)/'7'7'7%'%53-#%5#53 3#kyo\wyo\zV\Ly[`@¬@_ӤRӤRZy\yW\zn[wyo\ԤRԤR߬@¬@Vm!#!3!3#332673#"&3jv cSRav ժV 6978w{zV8!##333#332673#"&{v aWV` v }`9VKKJL!!2#!#535334'&#!!276N訨ʨONDNOQQfDCDC&E 4'&#!!276!2#!#5333>CB>ytts9L^*..+URRRя>'+#!2'674&+327'7Uj~ rGj#u~{Sqrے-,9/~V{)%'7654'& 32'#"'&'#367632*nOSTTSSTFoWl{XY::YX{ ]ststsjts].01d d01j@ 1/03!3!)2$ F1/03!3!`:33G )@  <<1/<20!!5!!!!!N)#l8U` +@  <<1@  /<20!!5!!!!!?`۪ f#!!!2+5327654&#)qmL>87||9ժFwrKK"V `#!!3 +5327654'&#rFRRQn!&&1`GQ``07 )(33 3## # # 3׈)D"AMF`33 3###'# 3?nfz!n`QL6mu&z9u|&z3! 3## #E#A`33 3###Tw8sŷ`OL5373! ###ʭd_dTy%u`37533 ##5#`eBTse``avFOQ5a!33#! # ##53ʨ_ʨye=3!!3 ###53dTsŷ}}z}5OQ5}2 !5!! # #=_+y*` !5!3 ##8TsŷƚOQ56@    8 22<1/<20P]3!33##!#"dA9@`1@  F   F2<21/<203!33##!#W`39L -@   8 221/<203!!!#!#)"d9` +@    F221/<203!!!#!#W`3ͪJft#!#!!2+5327654&#;"rqmL>87||9+wrKK"V!`#!#!3 +5327654'&FRRQn!&&1:`GQ``07&.s-'1?%&47632327#'#$'&76!2.# 32767654'&#"Ed`_fJxuTGIRDLżSu^\yI0a++IJ++}}֝s?] bh$">7^覤.$?xEGEFyqR{ ?%67654&#"&54763327#"'# '&76!2&'&#"3W!V0),3MNNM'8HeZ>FR5<UQQLCZIUccUTqHT*.N›WXXW,4#qrtssu''z-qu{'z %3##!5!!A+6` %3##!5!!xB1BL<=V`o@  K TKT[X @8YKTX 8YI:9120@BKSXY"%#3 3;^^DNl!#!5!53 3!ssf=V` !!#5!5!53 F;^^`XXNl=;%3## # 3 3p\Y/su A{+3;y`%3## # 3 3q!r))kLHJqG%!33#!!5!!+A+B`%!33#!!5!!xZ9B1B9L|%3##!"'&533!3_qm||x˪Awr7ٟd`%3##!"'&=33!3f\45h)L _Vu;;#"'&53;333###;qm||֐wr7ٟ9d+`5333###5#"'&=3f\4+ _Vu;0$@  21 /<0!2#4&#!#z||f9dK"*76! !!267# '&'&=3%!&'& ":Cppoż vzKB@bHam`_F$$UgkL>D9||f{%."'&=33676!2!32767'$'&&'&#"XY`09Jt⃄ fgjdcbchneNRS]\RZF1!&łZdc4*ZZWWu'Guf{'H,(vm'[uFH'f532+5327654&#!#3!qmL>87||qwrKK"9wV`3 +5327654'&#!#33^HRRQn!&&,%wGQ``07$)`6V!#!567!3#:bCux+8.%5ժV.V+`%3##!56765!s{{v^̳;bVdžf;%!#3!3+53276q"L>87h_9dKKV`!#3!3+53276WRQn!&`3``07V!#!#3!33#;"9dժVV@`!#!#3!33#W{`39V%!"'&533!3##_qm||xɪwr7ٟd+`%!"'&=33!3##Hf\45h)p_Vu;;V%3####! !+-}-VV`%3####! !H{˸ʲ>?V'P`yOh'J+1@oo]0{-&O"+1hN&u  +@ 0?  ]1{-&jR -( +@(o(P-_(@-O(0-?(-( ]1H{o{m'u@@]1qH'@p]1uQq{uN' ucq&jTd(vN'QuF'jN'u&j:yXL/`T31'q;y'q3N'uy'jsN&'u +@ @O]1qu&js +@ @O0?]1saqu{7sN&s'uqu&tjso#N'guq&j#1'qr;=V&q^#N'ru=V&j^#k'ru=Vf&^N'u&j^j %3##!!)Aժ` %3##!!rL`FN&u&jGV!!!!+53265!!5!!)#iGRiL+`na8VU`!!!!+53265!!5!!U`nFRjK۪`na=f+%+532767 # 3 3*SfL>7( ^Y/su bzK5sx+3;Vd` +527>5 # 3 dkkCQO5r))`&9as mHJq=;3 3!!# #!5!suNt\Y+wD{;y` 3 3!!# #!5)) ~q4H 3!!"!"$54$3!fONDNONNCD#CD+fq` 3!!"!"'&763!5>BC>9sttyLZ+.i.*RRPRUC 0!"32765#"'&54$3!3327653#"'&NOO_KV! 3j^nN?4pi;?nhf1CDP_m}`61f[JJOZxx9qs` 0!"32765#"'&54763!3327653#"'&=C>A@j\-1C]^fety>dhd.*^\:9m4l01a`RUaPOORAsxx%74'&+5327654'&#"567632327653#"'&'&\]OOQRSrsdeY憆GGRQ?4pi;?nhf0!JK;$& hi|UV!bb[JJOZxx8PaF|54'&+5327654'&#"5>32327653#"'&NHtCDFEwGQPabLqr<=ih<>dhpb8f83,-F@.. NO]@AHOHXDEORAsxueV<)!#4'&+5327654'&#"5676323#s\]OOQRSrsdeY憆GGRQJK;$& hi|UV!baV|)%3##4'&+5327654'&#"5>32ȻNHtCDFEwGQPabLqr<dhpb{v^̳;b`WORAsxue{-`327653#"'&=!#3!zgh<>dhpbW`WORAsxue{`3s# '&76! &! !2653d-|e'%{9!Ҏ׿qF{76!2&#"3253# '&q кĽbZZb/n||r|r|>禞f327653#"'&5!5!?4oi;?nhin+[JJOZxx}q`327653#"'&5!5!x>=ih<>dhpbB1VFEORAsxue{~{R|BTf:!56765!+532765pfb:WxM?77+80dKLLVs`!56765!+532765{X^̻3DF1a.&oP}з0) F@   8A!p] 991@  /2  9033265332#54&+! '&ˮ® ,gQ]*-呐u\GCF1l[R.$)K@  8Ap]2<991@  /Ĵ`]0 ]376! #54&#"!2#54&#!$ˮîXgQ$9 𝶫F1l[%D@   8!&p]<2991@    /<<0O']32#54&+#!"'&54! 4&#"3)GgQG*ɟn(!ˮî5ZrF1l[=ó|#ӢI|H@   8Ap] 91@   /90O ]32#54&+#4&#"#576! YgQGˮîːZ`F1l[O 9$\)#3!2#54'&#!3276=3! '&X_`07QWWWWˑ呐1[[F1l*1jiij 9㒕$2%!67#"'&543 2#54'&#!3 7654'& f<0I|q4_`07Q5˧OPPOOPP'.ƪV][[F1l*1LL]]]^^]])D@8 :  2]99991@  /0%!2#54&#!3!2#54&#!}gQXgQF1l[F1l[)@@  8Ap]<991@  /0]376! #54&#"!2#54&#(ˮìXgQ$9 $F1l[-:#'&'&763!&'&#"#76! 32#54'&!#"327654:gimINK(*WWWː\!%_`05л9:E5:. rs TfLQR2jjiu$[[[F1j,1i--Q@+#! '&4763!332#54'&)"32765pG혐nG_`07TZ5WWWWܕ.|n[[F1l*1}Hijji):@ 8Ap]21@ /09]363 #54&#"#ˠ(ˮ;dK2V 3@ : ]991@ /0@0P]!2#54&#!}gQڶF1l[327653#"'&!#3|%3x*%qXdq`>WWK7}bbpiOA$3! '&7#'&=33!2#54'&#%" 76'&ɼżg``07Q_`07Q|y&bc\[F1l*1[[F1l*1 椤)!## '&33276=3)ˠ혐WWYWd+&jiih) !2#54'&#!5 uw _`07Q1k,[[F1l*1f'1?%#"'&543267#"'&543 327%&#"32 7654'& oUIeβr0I|q9I9~dX/? 9.YOPPOOPP@$2iw'.ƪdkWM( ]]]^^]]?@  8Ap]1@    /90O]%32#54&#!4&#"#576! )GgQìː!F1l[ 9$\,3276=4'&#!#5354763!!"!2#5# '&WWYW07Q `_# Q70X_`ˠ璐ijjgl*1[[1*k[[Fd%!! '&332765!2#54'&#)呐WWWW_`07Q& ܕ$ujiij[[F1l*1S" $53 6&#!5!2654& #4$ 5JRS覥A ++.WHNMItYa[J\n@@  81@   9/0326=3! #"&=33®ìGœgQm 9-!F2lZ) 3276=3! '&576%7%5zZ[WWˑz=s9W/hiik 9ψ&dAU)7@  8Ap]1@   /<90]376! #4&#"!ˮî$\uB)4'&#"#576! %5%$76aZ[îː 1y=\gW/ίgj 92dAU##576! #4'&ˈKuˮ9)uBGlP| 9\̍P0%&'&43 2#54'&#!3!767654'&'& Eq4_`07Q5e, 7OOPܪƪV][[F1l*1L,@B@^^]t~H@   8Ap] 91@   /<90O ]32#54&+#4&#"#76! YgQGˮîːZ`F1l[Ou$\)8!!# '&5332765332#54'&#^혐WWYWG_`07Qd)jiih [[F1l*16).@  8Ap]1@ /0]376! #54&#"(ˮî$9 uS0@ '&53 7654'&#""#6767&'&5476! "327654'&RQJRSSSSRefg#RHJIIPacIJIJcaW"ccttstNMMNMMM *c" Y[`XX^[Y01YtAAAAtY10 =@ 8  Ap]21@  /0 9]54&#"#363 3^ˠu2;dss3\,<47632#"'!2#54'&#!##"'&=337654'&В􄑑I_`07Q _`07Q*]WW]_WW_rsppzzpS[[F1l*1=[[F1l*1A>T]=BD=[V>Cs2167654'&4'"!"'&'5&'&547632qG^CC95+<&0kljxw{vEB[eK[ 4D~n>=>@%c3A +mlpp/E# ,,W`aru~^#33vx%"#476327653[RBhj[RBhjTDDjlTDDjl}fC^7#47! !"33254'&'#" q3U7a\ "9S A5z\&NZ%3!Z}4bb&^@PP F'<91@  #/<<<290@0(P(p((((((( ]%#"&5332765332653#5#"'&E``ruSSrw?XXyzVU|:<b`^zbzh02>>Vd{?@    N  F22<1/90`]54&#"!!#3>32||Buܟ6V edqV{ <@" GE!<221@  !032654&#"##"3253!!/+:||:Z/\RdaDDadOV{=@ N  F2<1@   /<  90!#4&#"#3>32!d||BuZVH`ed X?@ NF2<21/90`]3!!327653#5#"'&>>|TVCuddZL PO_b;fcxxqV/{<@ G E221@ 03!#"325332654&#"Zs:||:էRdaDDad,@ F<1@  /0)3!!32#54'&S[zM`01LI[F1i&&Vd{>@   N  F2<1/90`]!4&#"!!3>32||VBu ed\V6{ )u@ +G  F*2ij$!!$ISX $<323#'&5476#"3276#§:{5`4xBdBJ4/' daZ+h|{Nvqq<q/ 4@ ! GE <21@  <<0!"32765#"4763!33ƈbOMSK}<zaksC+D߫LVd5@  N  F21/90`]#4&#"#3>32d||Bu\edV` @F1@0!!3y^ VI@  NF221@  /< 90@]32653#5#"&5!#3||Cu`a{fcLq0\@ 2 $G,E1Ĵ,1@ 011(1<<0!""<<!<<#"327676''&5476;#&!!'&'&4763[AS].SD81N/Vɮ!qZsIR\++(VL-%)$?뮘VX:@     NF2190`]332653##"&||CuZ{VfcdKqZ 4e@ GE5<@ (''*%%*39/ 91@. '/ 90@ `6666]32654&#"#5#"325&+"'&5473;2/nD:|WCv>!%7)/kPըdaDE<6pG5P0,!K7V9{;@ N  F21@   /  90!4&#"#3>329s||BuH`edTX-b@ (N  F.<<2 -9   /1@%/<<! (90#5#"'&=47#5367$732%326=4'&#XCubdzzp>BiO>AycW fcx{Iʪ`&$%8vJMO;) +?@-% $NF,21@ &$&)$/90332654'&/&7676;#"#5#"&|| M.=<(`Cua p0.- */(fcVy`2Z#G@%  N!$21@  !   /<90;32653#5#"&5#"'&5476;#"||Cu;^PZl}YYa{fc^PzKWV{!<@ #E F"<2<1@ ""0!  3!!"'&547654'&#"#4632/Q@'$C#@l;qsDE E+G56dZY0Y^cԫeed{QFV;`%X@##'  &9/1@#&&990%   ! 3!!"'&547676/&5476;#&(3W:'$F[L2se`6g+! E/>A/(32||BuƯ`ed X`XV-=@    NF21@   903326533!#"&||sCua/Vfc{%i@  PPF&<<1@ "  /<<9  90@0'P'p''''''' ]3>32#4&#"#5#"&533276BYƸ||zUVCdȸ||XW{ed\_`fca_\Vd{7@  N  F21/90`]#4&#"#3>32d||Bu\ edqVZ{J`@F1@/0%!!3y&"`V%k@  PPF&<<1@ "  /9  90@0'P'p''''''' ]3>32#4&#"##"&533276BYƸ||vYVCdȸ||XW/ed\_\Vfca_\V{$U@&E  G/<2221@"%%<<IPX32#"&'!!#54&#"326չ:{{:+Īdaad)qu{RzV*"-6u@83 .# *E7<<<<<1@&7/  "7<2#99#93.  90#,<<. #"'&'53&'&547632##4#"27654'&,Dd%Kcfep_{5S#al~EU@<%I]7_E8BQ-a`ta2N-bliZn!vFDs:#+IJ>8@    NF21@   /90332653!!5#"&||^CuZ{OfcR@<21@//073#3#R` 27#"'&'3U oo,rrONcAUUWDC <21I:03#3#D-dC'KRX@8<1YC %  <<1@  <5G.i=dB]Gg`":T)yX` 1  /204&#!5!23!5!&nZͦy–1CZ`E 1B /<0KSX@      Y4&+532##n̒[^ޕ<S"Xh` 1/20#!5!t/яd`"@  NF<1 /<0!#3#4&#!5!2snvy–t`F1/0!#3t`X`   1/205!"#7XNrXGяy Kd` @  NF1 /<0!#4&#!#!2dny–/``(@ E1@  <0332654&+532! w`ҏ/t`F10#3tXV` NF 1 0#4&#!5!2nV#–X` @  NE<1 /035!26&#!5! #Xt뒦X&@  N F1 /04=!3!#T[CLzld` @ N F1 /03!2%!4&#!6n`–X`W@ F991@ B /<990KSX@     99Y"#673632!5!4&WWHFdaxѧȠ˨Vt`F10#3tV X`   F1 /04&+532!5!ny–X(` (@  E1@  20#5! %&>6&+" я0D_ЎNO`U@  F991B/2990KSX@  9999Y%67676535673VGu",:pΈLƒ4U}*p>1=!"$Vd`'@ NF1@ 0#4&#!;#"&5!2dn\pTQV#–U;zdd`)@  N E<1@  /0! )5!2676&+;#"&5*4{\Lwuq`U;zCVp`@@   F91@ B 290KSX@  Y#3>=3#q_V`}՛C!`H@   F991B /<0KSX@      <=3!5!CcMgXC"`ԛ:V`'@  E<1 /0!#76654&#!5!2#3l)WzB'*˺u,/HVv.4X` NF 1/0!#4&#!5!2ny–`,@ F21@   /<<033$763 76763) :0nLaT`Sl+7`'@ F1@  /<20!#4&#!+53265#5!2ndDrL~y–a; `' `' `'`3#`n`3#3#`|!#53ӤR@ 327654'&+5336767N5G4pQf$h?FA@6b ! eI(R[2* #53 3#ӤR%@-$%#5754&'./.54632.#"'/XZH߸g^aOl39ZZ8{4<5/VVL89CFnY1^5YVeU"756767&'&54767632&767/SD435gcbnZdF31`9:H:ZU!LOTAKv?=0ps2#Ql '^5']>Ry3#&n9&P &n&n (f&; (f$3  !27# '&5767"$JKԖ^`e~h'?6`vc–e4- (&;?}R%67654'&'3#"'532# b&?q  ?%#&'$473327676'&/3327653323#"'&'TPxmil_Qb_y^@@$;sR,%@n\Kf% I01_2F,k>GHܳ&%0l}=J"5^.327654'&'&#"&#4763&547632#bzL,5;(.;Dn2KxAZM\MObxX'*9:X DD(NOf7*(?$S-8APH&? "327654'&'2#"'&5476B!799[]KB{ƶ`Q%T*WE{R,,9.UMAx|KU#JN @ &"34'&!5 767"'&'&547632?,3/V%._]g>v-(tYhYH9!$3/,;̠X*VL_ !"bWg3ZfJ6%#"'$47376767654'&'&'&'4762#&'&'&VfxH?Ba=~T;~BrC:@_` B(EN><}9M I&huqc- !P85J.39sJ%*==!'&"7*S@UYD J&R $5%5%HHnnnn$&567&'&54763233"/#"'&5332767654&#" %!lE?I(7 /4KU^r8Z #08 " -d$* 9^W4'6O'&n=NV)qaK" %$5%%5%HHnnnnn$5%Hnn$-&'&5476323"'&'#5276767654&#") lE?I(7$# +EȓV " - 8_W4'6O -n=*{nmp" %$5%Hnn8(#"'&54737676533254'3'&!9EO)"a 2=`YG g -SGL(E?4mmb}8T"RY$6îs9It6Y ! 4&#"32>"&462X@AWWA@Xz柟?XW@AWX栠h732767#"'&'gC*6:)kXZZC5"LMD6{S )L}@FOwpO p 4373ËF3# !#'3%1yI !nR#'337673#" %1BR{6)coajr!nUPymL%#'37676537653#"' %1/(/H/; 'G 44.5WY9!nr|> @2%,*;l>3  *"2767#"'&54767&'&'&76#zf\MOYp0;JcX~VI|eepdkAXH,7p 4C@#90L@rRiUZhsBBsǮuu5aU#'#"'532N%bU`DK*22<!&'3673b~ĚZ00ZĥxU:Ũ ;6I<3#&'#6̴UxĚZ00Z~bI6; :d#"'&'&547632#54'&#"=:i_{\ %Z[,,G\O98<SGU37e{a}UwnWl42@B^!x$%-`+-!d! M fM&n,&n9 &n9 &n'&n &n&n &n (&;]8 (&;? (f&; (f&; (&; (f&; (f&; /',>? r'_>? &'_? &? :654'&32! '$&73! 76767#"'&54767632)B,4((7(*Hnق@AZAd#?zKbNLZB`.+M;3*)3P&ڴF=)d \^tL"9;l&NKCW4,E$2Hf6&x~&xx)-%2767654'&54767#"'$473$62 #dGf>5?AhXPA7.EB|=Q#!w*6(  %{{qeVUI&b \^~B")+&&M_H#"'$47332767654'3HdnaPm/1]]LGL"fh8D%jdQ45b`ޜ ('&;? @r'_>QJRr&R_>P`aRbLcR%'&547632&767#"'#'3X\lTX\D8/0E= %1Bx:=$!"4'Qjr!n8j$(327654'&#"327#"'&5732#"-2!WZWXZV%2-Z(.5__52ZJkV0B7,g`p5oU%mao3/AbM3))I<g<hdi "32$  h P3343ssyzZ %!5!3%=Je+HH= 3!#3ulh= )5!!5!3=lȪ= %!!!3!l =!#3!=l*=!#!3!=lcr8A#3ASuNA %!3!#N{ 2>4."#&'.4>329[ZZ_PGr䆇䄄rEMp`77`p_88 1ŧbbŧ1 y3#+q! 6&    z>z='3#36Q*=q33# =qCq)3!39Uq"q!5!!59qKqO!%!!5!&'.4> 2>4.":RJr 惃sKRQ[ZZ{ 1ũbbŨ1 p`88`p`88 3"3#!5!p9 fq!#!##"&5463254'&"3qvC^]8m;7^:<֜fɃ]8j\D?D #!!!y5!Փ/= 3!!!}5!Փ/ !!27654'&'2#!3,R4,,=iXXXlι]Oz}I__ҭ$#4'&'5!4B 5McAq_9V= 3#T!!3432>324&#"!4&#"!}x5%^ZHZlK--Xh&|ŕnc= !5!3!!#KK?=!!5!3!3!!#!KøL=??q!!9UqqK=! #tFC00B~+n 327654'&+!2/!!m]%i ;@ED\TqQE=4."XErrJSRJrCEoJ[ZZO{ 2Ʀ1 { 1SV/p_88_p`88}#!#}+B} #!#3}Om !%!!5!!z;  TKѓ+qO $2>4."%#&'.4767673 [ZZTXErrJSRJrCEoJR"p_88_p`88 2Ʀ1 { 1SV/ qO(#&'.4767675!5!!2>4."XErrJSRJrCEoJRNQ[ZZP 2Ʀ1 { 1SV/ p_88_p`88b/!!VBf#"&/#332?E=9Qct2 %xf" %/x $Dp3#=f3#'#f[f!5'3{Bf3326?3#'#"&'Bx% 2tcQ9=Ef$ /% "[f5%3%[{fS3#̭F'3#%3#\yu#527#53gu3"3#  gd3#!!Mdd 3#3#!!Mޒ'!! '(033!!3'#67654'&67654&udruxtNMddx>DD>xIIv! RTxXY`aw,0dc1-!:;z{t{*L@$% E+<<<<@!#91@$+<@ (+0%"3254"3254#"54!#"543263 #4#"h??AA??A'+,LW@@@@@@@@pطQQ9/@@1(. #E0<<1@!0%* 00"3254"54$3  !2632&#"# 54-654!"`@@@CvBըiUv˫:knL?o@@@@N;Ejfae:.88U8327&'"254"%47&5476! #4'&# 63 #"'632# i60IKhh*)7!o^RX;*:9u`/'"6OfqAtqLI $\9.ȶlQ!6@   E"1@"  "0463 #"&'7325#'&&7'6met "xCBCquЍ h! ACBB )"32654& 4''&5432#5476$ % U%|{e6Lj` %"%:yx~)RhKK>  8"32654&"5454763  !27632! 54-654!"`$ % #琺By#xJi:OknL?$o %"%yKqjPbfDQcwiC|87Vr ,2654&'&3%$4567&7'7$!% |l݁6ZA $! $?=Qm-G4 {1@ F1@ <@0%"32544!  #"54$32@@@)@@@@Pvv .%"32654&672#4#"#"'&#" #"53232l$ % L 7*>(z*M#6&8"$ %"%3|0ۯqiPWu|+?@-$'+ ,<1@ )!,&,<0%"3254"3254 #"5#&767663 #4!" @@@@@@!Ӣ7y-^@@@@@@@@edm%W ,"32654&4323254#4%$7"@$ % 쐋'(uj %"%@կ̰Xsjf\_"9@ $ E#1@# #<0254#"53265$54767653!"'#W@@>z]U]iTrs@@@@pegu/ssHs|2@  E<1@  0"325447&763! 3%$5@@@ԶMg@@@@R&Ѩ'LBHs2@  E<1@  0"325447&76! 3%$5@@@ԶMg@@@@<%Ҩ'hBY E"32654&!"32654&&''"&5623253765$7465&'7$ % $ % Kfg饤IJ %"% %"%IKbv4ˋ42@7-]fn9h%?@$ F&1@&<<@" &0!"'# 432!32533253"3254hfg襤>@@@ JJ=|\@@@@@h} -"32654&2533253!"'# 47&5432d$ % AfgB %"%4˩/JJ=%܉Mh -"32654&2533253!"'# 47&5432d$ % AfgB %"%4˩JJ=%܋L@`$@1@  <<03!23! '#"543225O)3Ɯ)`,88{r +2654&'&%$3%$4567&7'$$!% |l݁6Z$ $! $&=Qm-Z$ ,"32654&4! ! &# ! ! '&54323 c$ $ 6buUKX $ $8${nE{N%N 0%"32654&&'&'&7! 765! '676%&4% $  ,D (={{+@  E1@   <0 ##"2#"53254#"n=;C>@{jVR777r&@ji! ! !5 74! %&?%~?>~@i! ! 3!= 74! %&>%~?>wJ~@ji#5! ! !5 74! %&?w~?>~@i#5! ! 3!= 74! %&>q~?>wJ~3"36654'#"5432AA\(DeN[̼o[$N[u%@ /1@ /0"3254"547&54323253r>Juum@s> [yu?{EBXF_ '656%"'&76! 4"3YVA!. {x9322674&#"CCjFPH OQ$!%!p'(FnJv-O!3] $ $z{&01, ("32654&&3 #"4/&5432N$ % s $ˌeqɘzm %"%82y,v\#"6@ E#@! 1@ ##04$54%&&5! $#"57"3254ix@@@X4|`Pٳ ?@@@@ ""32654&5&'7!$#"47#$ % dt.; %"%Ȉ_p 8>u%t/;4#"#"'&#"$#&532327632! '&57"32654&"3C2z7J,"/IN\=0BWTO3H$ % Xt\DD\t] 5<\UCfwpv  gH %"%V@/1/03#V~!'@ /1@  /<0'6"%)56574 65+*+UGm++),}݅.p\(>.4"!27676327673!#5654#"'&'&#";&543.%2~*&IHHܝBOg(LBC]i%>e>.`h>3A?~= h\$kb8:;-F_Zkf2)N !@ /<<1@ /<<053533##5N؎؎؎ P>r@ /1@ /0432#"73254#"ЄLTPPHHH` " 7654&' ! '&476^L:NbX1coqoh`WĒcg&24764'&#"676'&'&5476  pHgc/5pIu upHECle\gUܚsuϨcy\$24"27#&5432# '&5?$5+r%3]f́|pHFPfouTapH/%24'$5432327#"'&#"%$'#"54322533]L/|tkZ1AQf(3Ɯ)DjR:jTh8KOpt$68{cW%24"$'&5?$532&'&32!r|T9lc ~x?LvTamY<KcW-224"7&5&326532&'&32$'&324!B}b$|T9lc ~xr=Ch(筭 ?fXmY<KLvttY4@'&''"&54323253765'$543227#"$#""32654&fg饤u ^|uISL\>$ % ,IKbv4ˋjEaTW8ҋ %"%{ &%"324"324#"54!#"543263 #4#"h??AA??A'+,LWpطQQ%Rpt MU"32654&254"#&76767%4#"#"'&#"$#&3232763276'767$ % nnvp+-"2D2z7J,"0IN\=0J%.3?5xv'Q %"%933hk//3wt\DD\t 5<\UCrTF-2bG;"b,i $5354#" #"524"m~ŶejsX\|9~ KW"327$"3273253!"''&76324%$7&76%$5+&76262654&'&A?A?fxԅ$8$+Rb,7Hu Ӣ5r$!% @@@@@@@mӔJce$3- /ԋu cd $! $~ H"327$"3273653%"'%5254%$7&76%$5+&7626A?A? Tcb*@RX6&$Hu Ӣ5r@@@@@@@mo6J,/7'- /ԋu cdPi.".54>7!5!!"32>54&'7i7eȬd7&KlGqǔVXxyӚYlūc66clJ7^sz֟\[{6yEr2b\TZ@#!#".54>7332>53!w!KNM#hN&?Q*nq-Nj=8kT3$ KfWxc*s@nQ/+Lk?Z 5!4.#".54>2!/A%'B/+(=B=if:y'D33D( R0oCEOc88cO'MP.4.#"32>7#".54>7!5!!"@YmEgLLfjJkoX؁q؝XGxdI(YjiMKkii۫uuZ8!4.#".54>32i+Kg<>lP-7:p0M6NifL>@kK*0Rp?>?1ill3eMF}gZ,#!#4.#".54>32!|/@%&@0&%BE;hRPg;(C03F(#P/MCOe96`PFZ(4.#"32>7".5!5!>32&/Oj=kOOδMEHHjMoP.)NpF@pR00RfLLfan0/IP- %#"3!!"$&546$3!!J׉@@ט`a( ]wxԟ\Fww2P:G!!3!n!.x1Z+(4.#"32>#".53>32`+Li=?jM*,Ni=>hL+iJEMfLK{W06\xCKxT.4XwA_bKr62NpZ+4.#"32>#".5##!>32*+Lk?AlM+/Pj<@jM*KihNIHk?pR0,PpEBnO--OnβKKgcBvj12KZ+"32>5!#".54>3!!5!!Q@lO--Ol@>iL+MghONiL.QoA@nQ//Qn@/eMMehJ{PS$!4.#"#4>3!!"632,Mh<>e-PKhr>iM,fL?nR0*'R} gM1Tr@aKfPc K4.#"32>2>73#".5#".54>2*LjOwϙYVz|՚X0/':Yr?DsU0 E nǬc67dȭe7><qU'!RkL)[z{֝[W.>#K]59_|D 6clkǬd77dk{Z'kE"1%P#".5!5!2>53KeiL*-Nj|fH'eMOfXAqT12Vq>P&!#"&'.5467!5!32>534JEp=AB7D4+! )#$+e;:iP/05IGHeLJ )RpEn),/,Nj=Z""!#".54672>53!`NgiMNL6--Nk|jN,+eMKgV[@n6@nQ//Qn@]S#".5332>54&'7SLfiJ,Mi>=iL+>5{-H3eMKg@nQ//Qn@6|>/dfdS 4.#!!2>7##!!!2/Oj;;jO/JGHܓ.gM@qR0,Nl?dEHCMPbF4.#"32>5>54.#"#".4>32YywКYXxԗR6aO"?/$/ .@KZj>mȬd78ekoɭc5[])D0z֞[[z{֞[WwAoV5'//!6cǫc66clv?GOPb 14.+32>#";+##".4>3!2>mTEETmFUl>>lUFk\܀EFޥ^^ހWܢ\YqA@n@oWVn?~ٟ[][ڟ[]F!#!3!3!3FS!4.#"#4>32/Oj;53`EIgJ,Mg<:iO/02Kf>mQ0,Mi=nB-#".'332>=#".533267653BLi`R0Lc8;jO/FIiJ,Ni=:c'YgKSkFzZ40Sm>1/Jg@mQ.+(P|S!4.#"#3632+Kh<7g4QɑeL|?nR0++N|uaKfPk*!5#".54>32.#"32673YUlǬd77dlps[.\YS$wЛYXy^Pr2@6clkƫc6JH,Z՞Z;;xXZ)"32>5!#".54>3!3!Q@mO--Om@>iL+MgiNNi.QoA@nQ//Qn@/eMMehJ35S !4.#!!2>7#!!#!#!2 )4)2VsA4(AsV2*=&$;,S~U+ 9/XZ.?#".'332>54.'.'.54>32#6.#".KfbT1Ng:jN-VU^]4R8eMRlHzY3/Qn@72*63UeMTkH|Z4/Rn@)D BFRZS#"'!!332>53SLf,Ni=53 KihN/Pj732>54.'.54>32#.#"]~|ۤ_-H3K7>kTSj==jS8mV4/Rn@8gQ6';#w٥aL~מY[{:omn:vQNVl=53 ,T,Pf:l #D;%?.a=4.#"32>7+!!#".4>;5!5!54>2-  -)//?%&@.%?/:fPW2WvCDwX22XwDp=  @xY9lY|PW!%! %674#"&5! % %1,lշ._z+,S.+RLo ۤTn8d`'675$!2363 ! ##&!"#"32CxuM6sc*rE) PlaؕyZdX!&732#"&5 ][*8F e]N/I3^@[7rr2dX'!&732=6+537#&5! nN ggGVzkB3L.ķ@JKW~Xq\,d!$75&7! &324'"6Z^,CH!IJ:QU,X\$d56#"! !2363#"32UTcD>0R^<]td'6#"$! +.!TueudY! 473254+5365!5 Wb 퇇2mNEIJ(bC+d`3675$%2363363 565&#'#"#'#&#4%"fDjPQUOR Tg@! 5y<O-6d! !234#"#!#"2mLC{%  }>e~! )!363#"7Y`PlB   ry_d56#"#'#"$!2363 H LDVza!t#rd!! 4732+53274'$53X`4"gzҶ/c7Qib6ȕ!6G))=HdY2! 3325 '%5%Uc| CGko 4Y_nd9$5$#"#'#"$%7367 > B)oQT7-ngDP5kn1w5! 3324&547cTɜW\wؠ?c-'9dY: %3! ! %#d6*Q&q)QGFޕd$! %35#$ 3#3%#" 5;54 X`dHrrr44OfkQؔcdX2&!"'#!525#"3$%2363 #"321ZG\KVOvBppdY_!! %$54#"'! ! 4'7_GD `U6I@bYsrg8A:ԃM){6\lY(3324'7%#"'#723! ߫fB߻cV̿0?7YpdW $!6=3! 47$$5! eڞòkHuLL8TWJ&)*d54&#"'675&%'%"t_CCt?h]|KytJfqI8=ۣ&*d2 3#3#3#dѺ/㰽d 2"4;%"4#"32;ѹF|pux$LRQ´h=@ B1/0KSX@Y %##.d+hK'Egh"hO'tg@1B/990KSX@Y sNO')tiN')ui'eiw^?1B/990KSX@Y 5](&xyw^O'1tm'e56'e&g56'gO'h56O&hE'iE'iEO'jEO&jO'0j'mwE&mO'nwEO&nw^O'?0n 3#!38Ygg`nC^^n7]^7nn7]]0d"&533265453zWA@XzCss!AWX@+!U#454&#"#462zX@AWzB+@XWA!s0U!5!2654&#!5!2@XX@s0{X@?X{0U 4&#"32>"&4623X@AWWA@Xz柟C?XW@AWX栠H> %'111 ]]1<203!3CC~K3#K!5!${1V #5#53533zz{{1##5!z$ %{{:'Ue'g"'=iwq'mh9hK'Eh)hO'tw^:<1B/0KSX@Y7 5wM40w^O')tw^N')uw^'w^:21B/0KSX@Y%5^xyw^O'1t'56&9'56&O'56O&'wE&O'wEO&O'wE&O'wEO&w^N'1u<291B0KSX@}}}}Y5`sbbs]103C)8)K'E)*@ 8AKTX8Y1  /<03! #4&#"!!ˮî$*\u)O'tw^ 2 <1 /07! )5! )w5BhPa.,~w^O'tw^N'uw^'y` 2<1 /0%! )! !`aPhB5jiy`O'"t&''&O'O&'w'(O'wO&('y'(O'yO&(' ~21@  0# $54$!3#"3nn͙ nn{'|'|w}'dy'F> %@ 21@  /90"32654&"$54$32#Bz_̀#R3IK'E %@  21@  /90"32654&#4$32#&f̲_ȭT#R3{O'tF> (@  21@  90%2654&#"3#"$54$3Bf̲_ȭ벃F>O'tFN'u (@  21@  90%2654&#"672#"$53z_̀ʃIO'5t'F'?'~'|?O&~O&|'F&O'FO&?'~&|?O'~O&|?&~  $~ ]21@ 02654&#"632#"&53XP^J\TaaQ_VFTHUGQK})~J8 2654&#"3#"&54632xOaT\J^P_KQGUHTFV}i~F'x'F'x'F> 1 /0#4$32#4&#"#fK'E 1 /04&#"#4$32f#O'tF> 1 032653#"$5fF>O'tFN'u 1 03#"$53326f餗O'5t'F&?'~&|?O'~O&|'F&O'FO&?'~&|?O'~O&|?&~ ] ]1 03#"&53326yaO\T~JPML 32653#"&5T\OaQLMPJ~w:1/0!#!5!)+jK'Ej@ :1/03!!)ժjO'tw:1/0!5!_++wO'twN'uj/jO'5t 5&w'&'O'O&5'w&6O'wO&' & O' O& & ]10!!3 nC ~21@  0! $54$)!"3͙ nn{3!5 nw} (@  91@  20"32654&'2#"$547!5__ȘLӦnjFY 'iFY} )@  91@  20"32654&'!!#"$54$C`^ȋMӑnj 'i<w "@  91 /20%2654&#"!5!&54$32__ȋfLnjw'<!w'<!FY #@  91 /20%2654&#""$54$32!C^`șMgnjFY'T<$H}'w}';3'$FY'y$3'%FY&%yFY'T<$\ 2654&#""&546 !j>_IEcI_(0MJBSKFXCIn~|Q;n."&5332653ܨabaaJPMMPJ\ 2654&#"!5!&546 _IcEI_>jm0(MICXFKSBJnn;Q|~w 1 /0%2654&#!5!2#bŘ쥒FY '2FY 1 /0%"$54$3!!"Cꏙƥ᪑FY'<2w  1 /052#!5!2654&᪑w'<4w'<4FY 1 /0"3!!"$54$3CbƙFY'<7H'0w&0;3'2F&213'3F&31H'4w&4;H'5w&5;3'7F&713'8F&81\"3!!"&5463RiPYnvDZHCn~}w^ %5-5 ^j22F  ? 1 /0!3#$53TCc Xon2K' EK @ ? 1 /053#3  cCT-ncCO' tKF   ? 1 /0%#5%3# c--noXF O'tMFN'uM @  ? 1 /0%!#3#c-gCcnO'3tP'IF'I'K'KO'LO&L'MF&MO'NFO&N'P&PO'QO&Q&P  ] ] 1  04&+3#XHǜV+.#"#"&'532654'&/&'&54632Cw7Bh#-8GC>=JGBAm'./G?;=~ÇH)@@V\`RʺªV\`RʺªhZ·%XhZ·Fl632#4&#"#"&3326tҪºR`\VҪºR`\VX%Zh۷ZhFlO'teF'32654 !"/.#"3"54!2!rz|K٬42 swUҤ'4X˧|`í~pX˧|`J3~F'<gF'763 #52654&#"# '4!"326(24׬'Uvr!24֭٣K|zsp~ȕ`|Xp~8=`|F'<i&dF&d'eF&eO'fFO&f'gFU'g'hFU&h'iFU&i'jFU&j'>72#52654&#"#"&'463"326[*'sobI=J>",BR\*$jt_UV) '2654&"#"'&54632! 33265,B:d:B0<~JIjˮîB,">>",BVU_tjN*$u) '"2654&'632#"&5! #4&#",B:d:B0<~JIj!!ˮîUB,">>",BVU_tj$*\) '"2654&74&#"#! #"&547632(B:d:BB®!!jIJ~<UB,">>",Bu$*Njt_UV)O't)O'tS^$264&"&546; )5! '&Vhf# fw_:@ 91@ B /90KSXY%4$32#4&#"!7g#ʲfhXdfF.=@ 1@ B 90KSXY#"$533265!>ʲf"fw_?@  91@ B 90KSXY '!32653#"$5g"ffd餗 K'  '  O' ;';O' '  O' ( (2654&""&546323326=3#"&=bFntnPX/Q,CEmaZT:KMMKFHn|ppX;oBGj9$ 3>2654&"!&546323326=3#"&=!"&54632!2654&"bFntnP?+/Q,CEmaʔ/bFntnPZT:KMMKFH;XppX;oBGj9|ppX;T:KMMKFHFY<@   91B /0KSX@ Y!"3"$54$3!7YꏙbXhUFY'<w8  91B /0KSX@ Y!26544#!wb gXw'\<FY:@  91B /0KSX@ Y'!"$54$3"3!YhbƙXiU𥒥FY'i<\'%!"&5463"3!\=.̞RiPYB~}nDZHCw%#535!53!3##q=ԭ-!%#5#53!3!3=~0Ԥ!O'tw533#!#5!5#5q=-ЭԤwO't!5##3!35!535=-ЭԤ!O'Vt 33#!#!5#53m unfy~n ,@  221@  /990%2654&#"672#"'"#3z_̀ٷ{O{ʃIH+'sZ@  21  /0# !3! !5aPh//+jiN !!!5!;VnVN#5!5!5!53!!75$i2$i*mւVxnVnՆu!s #'#37 ͉sH+'Y &s & O& 7& 7O& & O&=` !#!#3!ff`G [`3!!!!!!!! j /t`Ӕ&{o{4=J%#"'&=!.#"5>32>32#!3267#"'&32767%2654'&#"JԄ℄N ̷hddddj||MI؏ii~ST`Te__ZjkSR\]i߬A@o\]Z^Z5*,=>` #% 54)3#4+327#!5#53!2x9||ԙf_ڪrĐq{Fg`32654&#%! )s7F0Ǔ$g` ! )#53!#32654&+7F0ɖzٍ`` !!!!!! /`Ӕ|1#"&'5327654'&+5327654'&#"567632p<54& #.54! ì++f++$$>:#tNPƳPNM]*U3MY + 3267>54&#"'>3 '# 5467'7*(Ou))Hn.Mw834OMx43N)gA\*g>}66]C_56`?`q{&/=5!&'&#"5>3267632#"'&'#"'&732767276'&#"qN ffjbdjQGhi񈉉ijBN℄RR\]VVUVVVZdc44*,nmn67윜78lkpĘZYWWsttstuq/u{ 4&#"#32/8qu/ 32653#"4/8`!264&#%!2#!#N[cc[H^^>2`!.54763!##"#676#";jpkla;;?î545w?@@?w iQP%$q2^66**TS++2`!&'&'3;3!"'&546#"37545â?;;a|lkp w?@@?wS66^2q$%PQicQ++ST**<m``$ 653 &53sXٹ};ML+%!5!2654&#!5!#TZ`fcL||BtN5353!5!2654&#!5!#Z`fcxzʤ||Dv/{&#!5!2654&#!5!27654'&#!5!#|vz{\MN`_`gb>> E__ru99wSS?yzVU=`YV5`ZX`]x`73264&+5%5!2 'Ӏ{n Fo}ɽBdd>Jm7{3!!I{/=`N`#!#`I``Z^`367653#5&'&3U9VˆmmV9S`1Ms,}},uMLs` h !3#'!#ZgVXVq`!!!!!5!#!.AeW"___DXI &327654'&#327654'&#%!2#!g1221g̼^-..-^EOO)(N^h+&&MO%%X@? ]65dL.- rUpz 327654'&#%! )[ZZ[vNONN]eefe !!!!!!R-@___S !5!!5!5!5@-_/__H~$5#5!#"'&547632&'&#"326NJYXe|}}|\SRFFPOWWVVWCj]/rssr'y5UVVUL 3!3#!#΀2Wr3# 3+53265A@1(TFDE`Tli 33 ##-<azBm3!!_ 33###|{9="G 33##|_{EEG ##3G|_{EDEH"327654'&$  '&RQQRQQQQwvvwtww[\\[[\\[\vvvvuvG>@"327654'&327654'&'52#"&54767&'&54763sCDDCstDCCBR65<%j<=0ER^X65`l<=ca==ll*6RI)++LK,++,KL++5##,&)$%LY+8:6iG2278PyAAyP87'21I.* 32764'&#%!2+#Y0110YQQQQ))))]?@@?[ #'&'&+#!232654&#=)&''y.,,LPO)*s\^^\$ )(GTD<32#"&'#3t4554455$pMPPPPMp$uuc@AA@@AA86Z[[Z68^gG3#5#"'&76322764'&"Jtt%78NPQQPN874555555S^8Z[([Z@AA@@AAG#!32767#"'&547632&'&#"@AsC?>>>BADbc^]SSt44Va:: 2j88a WW[ZQRmT3210YGMK SX@ 2KSKQZKT[X888Y1@   /0Y5!.#"5>32#"&73267GsC}>?CŻthVau2koamTebXTb2&'&547632.#";#"32767#"&5476G&%HG{065>=f,K,,+*Ib]W-155_;65-9553+,$$4O,, ^$'U13 `fa<))R`1#"'&'532654'&+5327654'&#"5>32FLHG{065>=23-KX+*Ib]V.156_:65-9j2RQ,+ H4O-+]4$'U 12  `33a<))G 14'&#"327#"'&'53276=#"'&763253J44^]4444]^4PP=7633223r99$88NOPPON88$tm=>>==>>FNO e 45k37XX"XX7_z3#53ztttu 33 ##uuZu2u{"4@ $ #32>32#4&#"tHKYhuu'oMLl+yRowtHJZiw[Wk\sa97EBEB~wZXku4@ zx66X6VYYk\sa8BDG 6@ KSKQZKT[X 88Y1@ /0"32654&'2#"&546]ml^]ll]ǁqqpoWGu 67632#"'&'532764'&#"G0336^_]^:5311213p?>>?p3121 XXYY _ ?@@? G4'&"#4632T6667zWVoBAA@qWWG27653#"'&56667zVWoBAA@qWWu#3>32#"&$4'&"27uu$pMPPPPMpf4554455b_86Z[[Z6@AA@@AA#3#;#"'&5#5350Hww33UUPM,V-,vTPn3327653#5#"&nt''N^67tt+78Jy~{Y,-65\c`9nA!5!27654'&#!5!#Ue22<KLg#"FS10gg%dAl88u{(#"&53327653327653#5#"&Q+<=Rnxu$$IZ54t$$KY45tt(78LMlE!"z[+,64\c[+,66Zcb;F&33#&{{y #! !&'3254554#"t nυ9F}攥^ؙ83a _{3#5&+532{t<,||GXG+&#" '&54767&54!232654'&'&yAJZVWVWW!/bL+"766^]l9=P(r(B4?KWXXWr]$,O'(@?Ajp69G  )"27654'&'2##5"'&5476734 )=;67-!XQVVQs~SVV@h)%661FQ:5}t?3XJOZUUXR=\ ,Ajq@:%'#&+53;'&^sa,(^ra,GX]:DFYzg duudnsMd&sPdyoQdsRdGSSdG xTd%tUdV{(!2.#">32#"&'#32654&#"aQQR9||9F,*[cbbc#L)t`5!#3#3!53#53t𰰰त TV/%+53276'7#3/F0j&*06G#367632#"'&$4'&"27tt%87NPQQPN78f5455554_s^8Z[[ZA@@AA@@Gu&'&#"32767#"&54632u1122q>??>q22110h;533` @??@ _ GKv+325&#"47&'&54632&'&#"632#"Z%0\R@5`$^4412/412q>??5{3 * &;/Z ` ?@@biG.&'&#"32654'&7#"&54632''7'37 i:;n\[nO$$ZY drP =67Tb1#"'&'5327654'&+532654'&#"5>32N+,QR2658-56:_651.V]aIV-+K-32==l/|GHL ))unn77wU:8P#P,i/0\+53276=1#533343r,Brrtn x66XU P#PG ,5#"3276#"'&'53276=#"'&54763J]4444]^44tPP=7633223r99$88NOPPO>==>>=۠NO e 45k37XXXXn3327653##"&nt''N^67tt+87Jy~{Y,-65\cO9I 5333##53#Irtggttt\\jz~ ;#"&5C,rfpUWlwI 5!#3!53IMjjo\\E\\I5!#3#3!535#535IMjjjjooo\\\\\\V`3#"54;33#'#"3276ztteztry "3rKNB ,|ssW?#5$ z~3;#"&5ztC,rfSVXlx[`+53276'7#3`34r,Bttax66XS gq3!!q_u{467632+53265&7454&#"#4'&#"#367632+=32#4'&#"43r,B0t*pJz>?t'(N^66x66X6V~a88BDwY,-56\uU 4'&#"#367632;#"'&5P''N^66uu)89Jy?>0B,r34Y,-56\sa8BDzV6X66xq 33##q-{{~G 2#"'&5476"!&'!3276WVVWUWWU6//1w &6^]6&WWWXXWWWW@9\[8E-AA.G&.#5!#3!535&'&5476767654'&OpFVVFp^nCWWCnt6%66%4#76$\\FWWG\\FWWE[*,ApoA-9*A@+Fa:.#"#"/;#"'&=32654'&/.547632;1j8W*,]({44MN9> 0Br34@?>=RX l)k`GF@rb/$+*MW33 V6X66x"j2-*TIX00476;#"+5326z73zno>43r,B0]Me30U:Jx66X6#3#;+5326=#"'&5#5350Hw43r,B033UUPM,ax66X6V -,vTP^!533!33##5#"&=)3276^ntgtuut+87Jy~''N^61\\`9Y,-6/G&5!327654'&'5!# '&54767GE()78Z[78*,?G$"ZYYZ!"J\{':?KY7667YR8>#{\8?>LRRQRR<=:u2653#"'&53QHuDEEDuHPZs{>??>{}ZPz31+"&53?27654'&'&gH#"YZ,rftA Z87)2:08?>LRRlwpU67YQ8C&# #3{{ s7n !!!5!G'L\^=R^7!!#;#"&=!5!G'LC,rf>\^=R VXlx ^7^n#47#5!5!3632#'3254#|`\'Ln& m,7!!^R^=jR37!2#"'&'5327654'&+5!5!hCQ>63``;??C5~Ex>?::hn\& =;M|CD m**PJ*)]R^G !32767&'&"2#"&76So/6^]6/ +66,ǗWVVWVV*MWXMmGYXFovw^wwwv[f!5!73[f3!Px[f#'!5f[f!!#PU騋fBf 3#'#35fxBf 73#'#˴fxh'${-{'TDN's%N'>E&%&E&%&Esu'l'Lvquf&vCO't'qbN'>G''qZ'zG&'qZ&GOw&'z[quZ&Gz'&'qZ'^&GZ&(q^'HZ&(q^&H&(7q{&H7v&(qv{&Hum'u&(zquH&H'zK#O'vt)/P&I @s&*2"qVZ&JI;N's+dN'>K;'+d'K;P&+j@dN'>Kt;&+ztd&Kz9;&+ 9d&Kv&,Jvg'LYZ&,tF&ajl'v.l'ZvNj&.&Nj&. &Nvj'/''O jk'*u'/S1'q(;j&/J'Oj'&/\'&Ol'sv0f&PvO'wt0'FP't0{'P3N's1d'Q3'1d{'Q3&1d{&Q3'&1d{'&QsZ&2fqu &RsV&2lqu&R'jorsZ&2jqu^&RsZ&2hqu^'Rl'v3Vf&Sv2O't3V'STN's5J&UT'}5J{' UT1'q};J&qT&5TJ{&UO't6o&%V'6o{'Vm'v'6of&V&VvW&6o&#"O'to&*O'rt77N&W#>'q77'W&7b7&W'r&77''&W)'8X`'{Xv)&8vX`&X)&87X`&Xu7)Z&.8X&+v)4&28X'Xh}&9F=7&Ymh&9=`&Y^Dr'|:V5k'C ZDr'|:V5m'vZDN'j>:V5'jEZDN's:V5&ZGD&:V5`&ZJ=;O's;;y&[g=;N&;j>;y&[jfO'ps<=V&\f\m'u=Xf&]\&=X`&]1\&=X`&]d&KfN&Wj->V5&ZB=V&\{a&D/P&A@h'${-{'!Dh&$u{-{&DTh:&${'Dh:&${-&Dh[&${'Dhu&${-'Dhm&{-f&"hZ&${-'DhZ&${-'Dh&${-5'DhY&${-&Dh&{-&3&(q{&H&(uq{&H^'u(q7'H:&(q'H:&(q'H[&(q&Hu&(q'Hm&qf'& CZ&,#uD|& &,.&Ls&2'qu{&Rss&2'uqu{&R}s:&2lq'Rs:&2jqu'Rs[&2jq'Rsu&2equ'Rsm&'quf's& Wsgk''ubvf&vscgk''ubvf&Cscg&b'uv{&c}g^''ubv7&scg&b'v&cs)&8X`&X{)&8uX{&X}_k'uqif&v{r_k'uqif&C{r_&qui{&r}_^'uqi7'r_&qi&r{r&<r|=Vk&\C!'v<=V`'t\&<r|=V&\`^'ru<=V7&w\qa&> 4pqa&> lHqf&> Aqf&> Nqf&> Bqf&> Oqm&> Cvqm&> PDha& 4#ha& lf' A|f' Nf' BSXf' Oom&1 CQm&x PNa&B 4Da&B l9f&B A f&B N%f&B BOf&B OR-a'# 4-a'# l7f'# A|If'# Nf'#" BSf'#^ OoVda&D 4Vda&D lVdf&D AVdf&D NpVdf&D BVdf&D OVdm&D CVdm&D Pa'% 4a'% lf'% A|f'% Nnf'%3 BSf'%d Oom'%t CQm'% PNna&F 4na&F l f&F A'f&F N<f&F BQf&F O=nm&F Cnm&F PAa'' 45a'' lKf'' A|Kf'' Nf''4 BSf''p Oo"m'' CQ)m'' PNqua&L 4xqua&L lnquf&L Aequf&L NTquf&L Bquf&L Oa&-# 4Va&-} lOf'-v A|Yf'- Nf'-6 BSPf'-w Oo*a&R 4=*a&R l*f&R A'*f&R N!*f&R B`*f&R OW*m&R C8*m&R PIa'2b lf'2 Nf'26 Oo3m'2L PN'a&V 4^'a&V lT'f&V AY'f&V N^'f&V B'f&V O'm&V Cc'm&V P^a&6N 4qa'6 lif'6 A|uf'6 NCf'6t BSyf'6 Oom'6B CQPm'6 PNqf&> `tqf9f&B `Tf:Vdf&D `Vdf;nf&F `f<quf&L `{qufY*f&R `0*fZ'f&V `M'f[qVa& HqVa& HqVf& HqVf& HqVf& HqVf& HqVm& HqVm& HVha&  3Vha&  3Vf&  3FVf&  3FVf&  3hVXf&  3Vm&  3Vm&  32Vda& 8Vda& 8Vdf& 8Vdf& 8Vdf& 8Vdf& 8Vdm& 8Vdm& 8Va&  3Va&  3Vf&  3Vf&  3Vnf&  3#Vf&  3TVm&  3dVm&  3V'a& YV'a& YV'f& YV'f& YV'f& YV'f& YV'm& YV'm& YVa&  3\Vqa&  3Vif&  3Vuf&  3VCf&  3Vyf&  3Vm&  3PVPm&  3qH&>zq&>qyqVf& HqVy&>HqVf&9Hq7&> 5nqV7& +Hhm&uh1&q;f&B `RhfVh& 3xa 4VxaH <ܲ?]1 Դ?_]KPXY̲?]90IIPX@@88Y#55#53xgJ7FJm'jVdf& 8Vd{&D8Vdf&;8Vd7&D 5Vd7& :8f'#b `Ruff'%n `RfV;&% 3f' 4 ` f' 4. kBJm' 4nH&F$n&Fqn&F ^.x7&F 5.zm&F 60gm&'.uY1&'q.;f''q `R}f~f' l `f' l k_Jm' l*H&R'*&Rq$*&R ^*=Va&N 4Va&N l*7&R 5'*m&R 6m&2vu1&2q;f'2 `Rf5a'/ lF)&j `lFRfCV'f& YV'`&VYV'f&[Y'7&V 5OV'7& dYf'-; `Rff'6D `RfNV&6 3sRfvxaH ܲ?]<1 Դ?_]KPXY̲?]90IIPX@@88Y53#7"͔gd10!!dd }dy/10!!dOydy/10!!d8ydy/10!!d8yy/10!!y&__J&BBB@ 10#53ӤR?@ 103#ӤR՘?@ 10%3#ӤR@#5R՘?m '@   1<20#53#53ӤRӤR??m '@   1<203#%3#ӤRӤRլ@@m '@    1<20%3#%3#ӤRfӤR@@m #5!#5RmRխ??9; '@  YW Y <<1<203!!#!5!oo\]9;>@   Y W Y <<2<<2122220%!#!5!!5!3!!!oooo\\3!   \ 104632#"&3~|}}||}3q373#k%3#%3#V #@   1/<<220%3#%3#%3#ki3#iq L #'3?K@D$%&%&'$'B@ .(F4 :&$L%IC'1+C =  1 =I 7+ ! L9912<<2220KSXY"KTK T[K T[K T[K T[KT[XL@LL878Y"32654&'2#"&5462#"&546!3#"32654&2#"&546"32654&WddWUccUt%ZVcbWWcdWccWUccܻۻۻۼܻۻ q r "-7;EP\"32654&'2#"&546"32654&'2#"&546  &54%3#"26542#"&546"32654& WddWUccUyWddWUccU<¹ߠZucbcNWccWUccۻۻۻۼ5ۻ(`3(`u(`&  ,(`' ,&  X(`#3W`u(`&  ,(`& ' X , #'#Rs#G@%Bon29190KSXY" 5s-+#R#I@&Bop<9190KSXY"5 +-#^R^  &K'N''=NO'^O$#5>323#7>54'&L Za^gHZX/'-93A% #C98ŸLVV/5<4BR-5^1Y7| B_ % ij991@  <202$7#"$'56:<hh~vvuw~ign % ij991@  <202&$#"56$6;>nvv~hhgi~wuI3 # #bbc$$v=' {' { 3_!!V_+@B10KSXY"3#-\X 3!!#3hX^#"#JX 53#5!!53X^JݏޏJ&""gJ&"JJ'^"d] 327#%dp](; 2###׎辸( 3+"&5463yv}~}|( ';2+v~}O|}=k {B# #5#5R#۬@n&  =o'  BC''H1a~ 8| #'7!5!'737!!qaqqaq)`rrbqr2 535353,(`$' ,& '  XfN 53!535353fXp fN 5353535353,p  3#3#'d 3#%3#3#3#dipD %53535353#!5!3!,|f  feP> 3#3#3#>w 3#3#3#3#W "27654/2#"&5462332233VVVVVVVz@ <<1@03#3#zttttg? @   ] <291<290KTKT[KT[KT[K T[K T[X@878YKTKT[X@878Y@T /9IFYi       "5GK S[ e]] !33##5!55bf]myf !!67632#"&'53264&#"y^^a`<~B9>>Eoo4h6_ MLKJq ff\/"327654'&&'&#"67632#"&547632X3333XW33331221DD &9:DTTXWll122m45[Z4554Z[54bg KL1LMONuv l!#!liH30Y *:"32764'%&'&546 #"'&54767327654'&#"55j]\655T./RQ./SZ85UVUV56-/.UQ100/SS0/*,+KLV,++]12Hdt::dJ01:7PyAAAAyN98?&%%$A?&%%$S.532767#"&547632#"'&2654'&#"1220DC #<9EWXWXkl122Xf33XU5443g KK/MNoouv rh\Z4554Z\44k !!#!5!Q_i_k_8_83!!'3_a!!!!''^_o #&'&4767TRRTe^///._~g3#676'&ge_/../_eT)**)~~~u0@ 32tNN^luu)qJy}wYYk\sa88WT dC{d^TtdbTud?C dfC d\T dlC dYT dST d d8 d  doif dgif dM8dG>dGGdu!sdG?dV##"32.#"3267!!!!!!Oc%eNLbbL:/667756GFDFG ks9'.473&'3267#"'#7&'#7&'&76%73&'hA>/(%:@w]ayA9&AX}R4>C5Ai<)^_HH?WghйKp(`,%6767# !2.#"3>32.#".aXj]aye6{_]w|^0n&<$'/_HGghGG_^ٜu]\Y!!!!3###5qZpP~WHE9Eb#!!53#535#535632.#"!!!5-쿿=OL=tyB_))HB+#&'&#"#3676323632#4&#"#̪m49wSS>YXyzU6%X\xruxGM_a`f21>&>E3\u"&)''#!333#3#!###535#53355KO8~8~OO4&{{&&{{{ P32654&#+#!233!!;532654&/.54632.#"#"&'5#"&5qzzWQeGl`[z_<`HJU];Ufɘ/ϒjqqR>N#55YQKP%$((TT@I!*##`3E326&##.+#! 32654&/.54632.#"#"'&ٿJx}A{>[b`cae@fLNZb?ĥZa,/b؍$~3YQKP%$((TT@I!*;"&)-1'#53'3!73!733#3#####5!73'!!7]:1000019]zu }Luuguuguuuu_ % #4&#!#)"33!3_SV*$oN&1@: "+ /) 2+"!)#&  , & &*!/<29999999999122<20K TK T[K T[KT[KT[KT[X222@878Y@z  1Ti lnooooiko o!o"o#n$l%i'i-  !"#$%&'()*+,-2   USjg ]].#"!!!!3267#"#734&5465#7332[f A78 ʝf[Y`(77(6bbiZȻ{.# .{ZiHH"{/ #/{"G(33!!###5uX_Tws1s!5!!77#'%5'&PPM4Mo؈onوn9 -bw'67>32#"'&'"326767654'&'&67'>7632#"'.'&/#"'&54632326767654'&'&&#"32">1aJ{%A01Q[W7>/W1   >$<  . #dCw-^URB$`>DL_K>.3b @N\uLMiI(S395l9,8G(/&  -9)ЗiRm:3Xwdg7? 2j7#=5(6$ 629T/ (2M !:5S}$@{mbq~Es/4 -& "TAB`]|@8nRkcd]aC".)5'632327&547632#527654'#"'&#"%654'&#"o|@X"07PYtaTk~j[IwmqJ2530D#24!`NkBX``S㫣†qJ323!!!3267# $547#5\J5 ;_srigCS1r{jJ,{ +kv67&&UB{\* {;^~FE/0K?{w!,&'&#2767#&'&576753w[TUeeUT[Y\Y[dsye]Y\[CvlCi----iH$"u9Bt"#BuflC3!~d=!5!'3 G~d=z!#'73!5~~͛=z5!'3#7=~~d͛C $(B"326=7#5#"&54634&#"5>32%3#.#"3267#"&54632pSHfmƩogDc\GD^o8yy8o^IICBRCI M >OW\ 7$44"C +EI.46'&#"#&'53254&'"326=7#5#"&54634&#"5>32%3#VNz$p;i0ʪ%={pSHfmƩogDc\GD}|49d$, !5Lf,1BRCI M >OW\ 7$s'!.#"3267# !2'Y藣yyYjzS #bvAZ4-4ZBuHHghG[!!m&r&F+,/-/ܸܸ,(и(/A&6FVfv ]A] и ии# /!"+!0153&'&'6767!!5&'&76wI3cc3I86QLNN7887NNMR48_ki:rq;zn #++$ * rn<(2.#"3267#"&54632%3#"326&$  &54^o8yy8o^IICDkavva`ww~44"K <M-1332653#5#"&.#"3267#"&54632%3#\QPcu`^o8yy8o^IICDLriuD P44"K{Ro#&&r)Io!6767632#"'&#"32767#"'&'&547!#"'&54632327676"#"'&'&54767632l(9BKc{=&%%03!((!,739%7`lG;7 25]hB4,'5  'B[QF$%]c'G  %! }Kr~,1ьIg)*!&!(D;w},75;!_']7:y}[Ϟ\@4>#,!, 'QFj(JG4$$,*)/9yK#%P73276767654'&'&#"&'&"'632654'&'&54767767#"'&'672#"*i(X%# 1FSE/ O.55FuPU[QF[00rl~"KI}!;IFs;n;_T^͌Q79}w^l.Gyr\[4O9%#i#^MX;yv@c}e.ID\7I;>2V秉uӰ3!3%!!!!!!nnq  dx+%H#>54&#"#3>32u j_ y/wFx \/HT^Ȧ^m$R#a"67632#654'&#"##7373!!UcduL/ .| {@e22wKwGW\?3L0O}};t9#"'&5476323276765"#"'&54767632thn<7# ;KQ>!|Za,4(XM!},‚<7D9#7.M=.1?@ '(MXI(' jF!2?632327654'&54?#"'&#"632327#"&#"jou9!ydG>PPPP5ʺ68^nm{z}}ȋo֏zZ'PVaK~pmdykb^OP681/::b:DnJ327654'7#"'&'$#5"'47676766767632#"'&'&'&#"32nZS_n0VBRny#HB?X!$9BMw>7l. ;7%,;(ӧuy,D0&3273#"'#67&5477632654#0)W:K32#"&'####53&  O:{{:ܧ$}daad}j %# !3!# dX0dd q+6)2"&$"2654!!!463"!#525cΐΐ)d99d9j+hMNhiML{̀k@4k "-! ! ! ! '32654&#%!2+# JR12)uyӲckkc?L00ey wXQPXdn;C0<67632#"'67327654'&#"#"'&57&547276545[ۄFIyeL )qz]E& JEYq:?.蔁0.A ƂMkeLPק<+(h|H=y|n=B {u.F/4_NT 33!27&#%!2+!67654'&,d.@nX<-]\,q jdZ)VV)s!)%#'# ! % 7& 676'&B 3y;:x+lllli$ #ab[ 2222jT%%5$c$B2 _327654'&'&'#"'&5476323276765""'&5476!6?232767#"'&B=]iS\ZV30Fn7;#FfS9!!< #5,h";<2XngZR{,##9>;K!QIag£S D5@7*'S:y}*7H0 5#!,Il @3Xnh0{(2r:=OSlIX&54'&#"#"'&527654'&#"3"'&547632763227767654'&#"R(O*\xggfg-.@@?@@?\QA@@@S6fggfeӻp/$~AB}:1$ -*MJJ@f[+8vuuv zVWWWXWWVVW\uvuuu# bW1W{|^1$h{vC[SK\GChfy /2 &.2&'&+3!.+!! !27&#676'&%3LDEx-Me5q>HJxnu1EA+ZY*01/O~hbb)j)V>U)-  /!/ и/ ܸи!ܸA]A)9IYiy ] и /9 ///+ +0132654&#+#!273 # #s sNCI/ϒ_6۬kk%T$+.3&##&'&''7#!27%7 67654#?\A>:AٿKE6ToF^~_ ,8~|T3Jۏ/HDh0& ,ok؍]-Dbg('4.#"#"&'532654&/.54632733###UW'AG/E8pi4sG[d/EK7?8pc|3iиY"*/( VAO[`*,2,* M=H\T(l0`!!#!!!!!!!3!!rso+` `ffff'F >@!    b b cbc91<<2<<903#######5Jq7rqr/B^^"h %73# ' 3,o-MoF+,\ %#!!!5!8kO8d qddd XL/ 654&#!5!5!5!!2!"'X $''ߦԧc̆eeaԊfJN6NsDU767654'&#"#"'&5733272632632!"'4'&'&#"'6763232767654'&'&#"_}yj#1Q\$####,TGG\n#?QY>kDM4giMqE#"'&'&5476?&'&547632#"'&547654'&#"3"32767'_ilE_ml=Oc{T3-2") %+fa@aP/Z_|{w:maZu> IhA"%@_l$=PczS2VN-2!$+%$+@e}N069na[u>_T M#"'&'!#!"'&547632327676=!7!&#"#"'&5476!27327#X':'7?<=**M_4. B^l{>!'Ba>nG#&#w4$B00!K=DcK_4B( 03B{>ceDInFT=I,Fw7K. 0# )5!!5!3#Pʪ9Bk32767"'&'&47'&'&'#"'&547632326765&#"6767632377632#"'&'&'&#",5(.'*'E`97y{7a;f7;>F3.^PeMD*#7@,j!HhH<=.%_yipp3 T}B',$ *5܀/,,@!;Da97TVM;nwF^O?/,%!;>jytX<;}f?E'_n H''#  .hJ) 4&#"322#"&54WOmVPm˜ݢt}t{أأg4 4'+5654/&4?'&547 '&5474/c2>Bd=VE/b5c2ltc2c2uc1LS2?Bd,>8?]/c6c1LS2tc1LS2c1LS2903#!".54?>3!4'.#!".54>323!2O,""$%@;5H *Y[#$"x2 1[G(  WA,!2#"&/#!"54?>3!!"&5462TPl 0%= -d,mF"$mG- .7#*(/ $"Sae(!q~B;V&!"&54>323!2#"&'&5 mG * 5G 0%9 . q~( 0 (/ &Js!S'DQIF 4632#"&3!53#5!pQOooOQpoTQooQOonuyy5yZR; ! ! ! ! HH#[[breH !#y;:x L`  !!!!#!3#'!#33 # #DjwZDZ֏R``C5MR.}$z`-1%5"'&'&5#2327#"'&5#!#"#463!#3#, 9Yl(Ht*=Z2dr!Z4@'!8 ֦zEB bLs{dYsZ{3#"#4763 3׮UEEl4FũdGQnCF\xB*WbOZ=0 3%!!,:*nq dd3!3!!!! nn8q  qwS ! ! !!5 5Y*dccS!!6$3 !"$'53 !"kJu^uopkoSUggHF_`2/.2%!#!5!)+!5!_++!# #3bef9WJ " )327&#!3676654'&|tK"P"coAfյ|cv~dAA xPfUmZ #2!7#"547632!3 32767654'&#"* 6B8wx!Nbb|˞"#>|OO'vN 2wx87tKsO=  =d01 PD10d^dTd6Jthi[{ (232767# '&5477632!7!654'&#" N&#G_yZ\klmk}Z5fF 9NJC0<7h:J(u*oDMcFPZd82vRsO 3#3#!!ɸ.Ԇ$N9`V 3##676#732767!ɸ.fʆ#5H2K1i0/N)deеT0Hd01``;&0 #473>32#"&'532654&7>54&#";Ht]h202޸SUWDi;2[UԠ_I@Yr~YW׀c?}<$$/1oX3gQX?@Q` $@   F 21@/0!5!!5!`oX&{' 5ud^X&t' 5ud^&{' 5 d^^&t' 5 db^&u' 5 d?^& ' 5 d~&{' 5 df~& ' 5 dw&{' 5 dbw&u' 5 dfw& ' 5 dlw& ' 5 d&{ 5,'&,,&,',,(Q&,9h9&9,,&9',, &9',',,-&,;=;;=&;,=B&;',,j/s'&'0yL&LLpY&L'LpLA&LY=`Y=&YLD=-&Y'LDL=&Y'LD'LL$J&L[;y`[;&[L[;D&['L[LyOq{FqZG{Py }  ) !3 !## !5hPPh55~ji.,w# + ++ A]A)9IYiy ] A]A)9IYiy ]%"+++ + 013 !#3 #32654&#! )5HHNhPaY.,职~y }(1C3 +3 !32654&+! ) #"35# !35#"&546!`HH5NNPhthNN5H/ó., ji~s'H{d?8   2@ @@ 00 ]1@   990@   <<@ <<KSX << Y5!!dx=xUZxx @   991  2@ OO ?? ]0@   <<@ <<KSX << Y3'#'-Zxxvx<xuP8   2@ OO __ ]1@  990@   <<@ <<KSX << Y'7!5!'7Pwx=xZwxx @  991  2@ @@ PP ]0@   <<@ <<KSX << Y#737Zvxxx76767632&'&'&#"#"'&/#7!#/)85,0F"<;NJX[GR7<"#!2)85,/$#?2WG[XJN;?,!F0O<:" %7xxUZxaxxaxuP8 '7!' 7!'7Pwxx>xaxUwxx>>xxwd?8 !5!3#xwx-xZxY %'3'!!5xZxZxvx檪uP8 #3!'7'7xwx-\xwZwx !5!!7#7\xxZxx+xvx7!!5!7'3'xxxxxZxxvxxvxd>%52#!5! 767>54&'&'&>42/+-+-':1 Hxwxܪ-)o=  xwZwx(.46<=69)-d>>3276767654'&'&'&"5476767632+#5!5 6 +/24>A1:'-+/24>xwx  =69)-(.46=<69)-xZxvP>54'&'&'&"3)'7'7!#5#"'&'&'&5476767632# 6 +lxwx>42/+-':1A>42/+ׂ  xwZwx-)96<=64.(-)96=dP8X#532267676767632267676;'7'7#""'&'&'&'&'&""'&'&'& xwx 0$#$   "%'-0$' !  ' '- xwx  ('Z&("  "(&Z'( -xZx$ -#%"&* 'xwZwx ""&*  *&"" dPF%'!5!!'7'7!pxwxpdxwx^:5xZxo:xwZwx* %'7 !^ b9YXxbZ  #!5 xwxoxZx[ !'7'7!#xwxxwZwxZ  !5!3 ixwxDxZx[ 3!'7'7xwxDxwZwx 7#7!5xwZwx=xwxd? !5!3?=xwx-xZx,-eX&7#754767676 #4&'&'&"9xxZvx.-\ZnllnZ\-.BB54'&/#7!!#"'&'&'&54767D !BB54'&x\-..0YXplgtTY0../Z#,@#B"!BB@RNJV]xwx]TQ>]xwx]xLii `iiT4]xZx]4]xwZwx]JiiiiuP8!7'!7!5!7!'7'7!'7!5giiyYuI0]xwx]uIiixK]xwZwx]Kxd?8!!5!!]xwx]7Qix]xZx]xi#'3'#'x\xZx^xhP8^xvx^huP87'!5!'7'7!5$iiQ7]xwx]iix]xwZwx]x737#73jhx^xvZxx\x%hh^xvx^8dP8!7'!!5!'7'iili\]xwx]]xwxiii]xZx]]xwZwx7''3'7#7iii]xZx]]xwZwxliii{]xwx]\]xwx  #7!##PU?,UvU,?UP5#'#5!#5'U,?UvU?ԄU4 753!5373U?ԃUPqPU?U 433!'3ɕPU?UqPU?,Ud?8!!!!5!!c$R&xwxxxxZxxuP8!5!'!5!7'!5!Q$܊xwx&RFxxxwZwxxd?8#''''#53777?(FncxwxFn-FnxZxFnuP8577773'7'7#'''unFxwxcnF-nFxwZwxnF3'!!!!#!5!5!5!'-Zx((ت&&xvxTrx#7!5!5!5!3!!!!7Zxx((&&xxrTxd?8 5!!5!35!dxqxUZxxa 3'#'3#3#-ZxxbvxrxVuP8  '7!5!'7%!#'#5PwxqxUwxxw( 737533-vxxvxrxv4k?9 !#3?xvxתx~\xuI9 !'73#'7!uxvxxvvx7?~ 5!! !!  d }*^V 3! !!d}*p  d HP~ !! !!    ^V #!# !!!d e n ^V !! !3 3!!!E*dr*r$| \d^V )3! !3#!5#3 3 ȃ\Pdx @t %#!5#3'!3!3! !33'ȡdxd:tZdd\nt^V%#!3!3! !3!5#3ĹtIt\Px^V%3 3!!! !!3 37r*kd d| ^V %#!5#3 3!3!! !!33 37ȃ:͊` \h u}~ 7!! !5#35! u\Pdx f:bȃ  zM!#7!!#Mc"?,^xc?x^zM35!3!5!73zpc?Jx^cr+a?^xJ^V 3 3# '! !! !  e   dCuP8)5A '7!"'&'&'&'#5367676762!'7$"!&'&'!27676Pwx 21@=:C.2  21@=:C.2 _x_R#)l$h$#R#$Uwx@21.2@@21.2@xw#w;' , utP'7!5!'7!5!'7!5!'7Pwx===xUZwxתתxwZd?D5!3!!#!dx3xUZxmmxuPD '7!#!5!3!'7Pwxͪ3xUwxmmxwdPD3!'7'7!#!5xwxwwxwxmxwZwxmxZxd?D5!333!!###!dx⪪YxUZxmmmmxuPD '7!###!5!333!'7PwxYxUwxmmmmxwdPD333!'7'7!###!5d xwxdxwxmmxwZwxmmxZx7?@  !JBJAu}@ 7'!5! PJBł}BB7}@7'! ! 6BB A}BBh %!3!3۠ՈR+nm+A&6FVfv ]A]+ +0132#&'&#"327673#" B!OO!BzcI7͙7Ich-)b@'! '!* $$*9991990K TK T[KT[KT[KT[X*@**878Y>54&#"#"&54632#"&54324&#"32IH7$$0e՘ݢe WOmVPmmWKt,>bFأ[t}t{ !5!!5!!5>+5!#7#53!5!!5!733!Kcd04+^^``k](673#"'&'#7&'&$32 '&#" 32$767&'&YjiEd80~i?/c`RQQ$g'-"SRR:;nSz_'BTc_ N@DROg`8@91/90@cmpxyvn]] !3!^DC?`%! !3f<?I!!"$54$3!!!W?JGcGK@ sJxNL``ȟMOx]I&/!!!!3!!"''&'&54$;7#"ؖI$$$GA?d`,,cFU;}YI7ʟ 7c``JxH NGx]g% $54$)!!3!+*(FiNv%FrO:0QI&'&'&'!5!2#!5!676767!5?JGcGK@ 'JxNLȟMOx]I&/'7!5!!5!&#!5!2+4'&'&'3276765 I^Q$$GA?d`,,#FT;}YI7ʟ 7c;JxH HNGx]g )5%2767!5&'&!5(*FiNv%FtFgP:1R, //01!!,wq@gg120!#!# }wq@gg1<03!3wJ}w; ]@    91990@0QVPZ spvupz  Z pp{ t  ]]!! !!5 7AJI3!-10!!ת !#!5!3!!5!--+}ת W+и и и / + +и 01!!#!5!3#-Ө-5+@B10KSXY"3#-\<%?P%73% %#'TUUTUTTUDGrHF103#F=} *@    91903##'%\sB}}`s-Pb;=& us=&  s %.#"326"&'#"&54632>3"31UfvYRIOF^_HDa+J1CXXjewߦ~XZ /@- !$'!!0 $*0999919990@     $$$   $$ $ ***///***55500055 5 :::???:::EEE@@@EE E JJJOOOJJJV !"&'()]]32654&#".#"326#"&54632>32#"&1TevYR1UfvYRF^_HDa^/XZie7XXjeߦ~᧯wI%!3!~,I%!3IfIA//+к99к901%&'&'3!!#4'!&'7`'JAW`LqR]+X* Pʋs^(Rs57756u5 +  // 9 9 901 7&'7%%'6 676r{EG%y44RW!L!$Ҿ &!L {JP+3#+fJ+ 7+и//9 90137#'PMVo)gnJ+3#3#@+fJ+{//и/ܸи ܸܸ и и// // 9 9 9 9013737##'[P]ME+qd @oxpAn!3# ih^T3 3##"T^32#4&#"#P(*7332653#"RP7*uM>2&#""&'7327~9GA~9G⧅}}uM& ) )%uM& )' )% )JuM-6?67632&#"#"'&'7327&'&5476767654'&'SOJMG79GcBnnVsSOJMG79G]InoSu=,EG%,=,HK%DAF7K|oUDAF71IosV/HgjG$4.JhgH$uMMQZc67632&#"!67632&#"#"'&'7327!#"'&'7327&'&54767!!67654'&SOJMG79G~SOJMG79GcBnnVsSOJMG79GSOJMG79G]InoSu~=,HK% =,EG%DAF77DAF7K|oUDAF7$çDAF70IosV!.JhgH$+/HgjG$uMmqu~67632&#"!67632&#"!67632&#"#"'&'7327!#"'&'7327!#"'&'7327&'&54767!)!67654'&SOJMG79G~SOJMG79G~SOJMG79GcBnnVsSOJMG79GSOJMG79GSOJMG79G]InoSu,~=,HK%2=,EG%DAF77DAF77DAF7K|oUDAF7$çDAF7$çDAF70IosV!.JhgH$+/HgjG$uL.3&#"7#'754'&'#"&'7327#4767>32";EY?w^H6H\O3,,HO;E+@/VfmVmHO?u]HH]sM3 gz.VrmV_zuM<%4'>7'7&#"7"&'7327&'&54767>2=,HK%=Q Hl;EYLmHH7'&#"'"&'7327&'&54767>2=,HK%m#6,=iSH;EcHKs;E]InoSuJ.JghH$6B0+@TH?HK|z1IosV32326ian ^Xbian ^V2NE;=LTNE;=K23276767632.#"#"&'gV^ naibX^ nai2UK=;ENTL=;EN1).#"3".54>323265.#72#"&:QHRdhNi\dnx>@HRdhNi\dnx.ttlH=YOHL\}X[lH=YOHL\}W#"'"#322{dfftX{dfftX#*$0!#.5476767654&'30ND:323267#"''cDXbia]yeEVgia`yS LTNE+~F KUNE,F #"/&'&#"5>32326!!ian^Xbian ^VeoNE;=LTNE;=K`#"/&'&#"5>32326!!ian^Xbian^VeOE;=LSNE; =Kkb%&32767#"'!!'7!5!7&#"5>32%H\ iaBP﹉lZXbian3}o -X"OEd8LSNE;I"#"/&'&#"5>32326!!!!ian^Xbian^VeOE;=LSNE;?Kk˪.#"/&'&#"5>32326#5!7!5!7!!!!'ian^Xbian^VLoKɦoOE;=LSNE;?KL˪s˪sB.32767#"'!!!!'7#5!7!5!7'&#"5>327b K`Jqia'+\+zlh>Tm?u2^Xbianc"%]OE˪Nt˪=LSNE;%N;?@.9*-" *19" <-<<219999990#"'&'&'&#"5>32326#"'&'&'&#"5>32326ian ^Xbian ^Vgian ^Xbian ^VoNE;=LTNE;=KڲOE;=LSNE;=K43267#"'3267#"/'&#"5>327&#"5>29+Vgia@LJZVgia}9+Xbia@MHZXbi a KUOE8KUNE; @^ LTNE8LSNE;f@59#"/&'&#"5>32326#"/&'&#"5>32326!!ian^Xbian^Vgiaq^Xbian3VeLOE;=LSNE;?KҲOE;=LSNE;?Ky5P#"/&'&#"5>32326#"/&'&#"5>32326#"/&'&#"5>32326ian^Xbian^Vgian^Xbian^Vgiaq^Xbian3VײOE;=LSNE;?KҲOE;=LSNE;?KҲOE;=LSNE;?K"32?632.#"#"&'!5!5gV^naibX^naiUK?;ENSL=;EOȪ+  %5 % $%5$[g&Y%ZhӦ69%676767!!"'&'&'!5!!5!676762!!&'&'&[C-87VYYW6 8.CC.8d 6WYYV7 e8-,CE[<0[2332[39\DD+N+DD\93[2332[0<[EC,` !5!676762!!&'&'&!![C.8d 6WYYV7 e8-;++DD\93[2332[0<[EC,`'  ' &  ' &  0' &  .62' '  W63& '  ` 3654'!!5!&547!5!!4434w~0IG00GG2?8>;_8`  "264&'2#"&546!!!!^HdddeH;k'**z{bFE``bq+((d:svv`K  &!56!!!![yKW`  3# !!!!6c'@` 33#!!!!'c@` !!'!!!!+]^*^]䰰` !3!!!!![Np!N NfQ`07GO!!!!#"3###535463!3267#"&546324&#"'53#5#"&4632264&"?$mmC???DNB&H#$J'`qk[Q_C<17HBB@,I\\I,@p`ctiG6B?9i=$#tu#gSSS`*!!!!>32#4&#"#4&#"#3>32!]?U\Z79EPZ7:DPZZV:;S==:xoHOM]QHPL^P%U20=` ,!!!!3#7#546?>54&#"5>324eeb_--B6'Z0/`4\o$-,N2A+,/-7#!^aO&E++ '>@"     <291<2<<990!!!!!'7!5!7!}/H{};fըfӪL !@  <<<<10!!!!!!ת4!5!7!!!!!!'7!5!7!5!DQ"rn遙RoLT˪˪T˪  )@    <<10!!!!!!!!K T@.B $# <2291/90KSXY" 5 !!@po V@/B$ # <<291/90KSXY"55 !5AǪV 3!! 5 !!@poV !!555 !5BkǪ!5!7!5!7!!!!' 5'`ȉ)P"_=6@ss1stFpo!5!7!5!7!!!!'55'`ȉ)P"_=6ss1stF. 5 5:6:6pr pr . 55556:86:'!67&'&54767&'676'&'{)#Y4JJ4Y#))#Y4JJ4Y#)AAAAGF㞢GGGG➣FG2;;;<<;2;5$?$%5%67$'W eĔd?NĔ])]o& bR)`q% Rd%'%5% >zmzF<˶@6 o@hGp%5'75%7-孈m%˶C@ʴ@hGp/V !5!%5%%%!!'/xvH-rf5LOlUrC@=Vlь=/V%'!5!75%7%5!!' GWb[mmNL>ߪwe=ت=$%#"'&'&'&#"5>32326 5jbn ^Xbh`n ^Vg@ND:3232655jbn ^Xbh`n ^VfNF<>LTNF<>L>)P14%&#"5>32%5%%%3267#"'&'&/' k Xbh`'+kuE%sk ^Vhjbn "Pv1-LTND9ATj͊LTNF<= &TN#wf=J;N} 55 58@'poN} 5 55@'pom`!-%5%%%'5%%5 MM`ZDOA@FZDt@m*_TW&o}䎲w&-r~bUm`!7/%5%%'%5%75%Jvad",,V`bL"_D2,/*/&O{¸[&}P %5$r osaa^~||P 55%$so a||^a)W!%5%5$gV$}]]x|)W3%55%$Vg}$BW|]]RW(%#"'&'&'&#"5>32326%5$ian ^Xbian ^Vg$}NE;=LTNE;=K$]]x|RW(%#"'&'&'&#"5>3232655%$ian ^Xbian ^Ve}$NE;=LTNE;=K$|]]&%5$%67%'Et֋$k}uU)?eKtuu" K 9''567$'567&'%=⃹t֋~}uRU)?Kuu,ަK9'_%!"54763!!"3!슊@^`@ƍ^`_75!27654&#!5!2#@`^@Ȋʣ`^; #";3!!!!#"54763^`0rrndflppꊊ^`&pphƍ3 32654'&+ #!5!!5!32#^`0rrpp9^`phƍ7!!!"'&54763!!"3!Ɋ@_`@,ƍ^`7!!5!27654&#!5!2#@`_@Ȋɖ,`^ȋ '!";!!!!'7!5!7&'&54763!7!!ʉ_`'}E=aLT>scL0R^`5ƍ7 '327654'&/!5!7+!!'7!5!7!5!^`__BV 5cTpX?bLm>U`^`C 7 Xȋ5j )5!7!!'!"'&54763!!"3!.Bqx-qxDɊ@_`@Z54&'&'$  &'&'&547676!!#!5!]\LMLLML\]]\LMLLML\bc1111cbbc1111cbdd''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcbee$7!!"2767>54&'&'$  &'&'&547676r$]\LMLLML\]]\LMLLML\bc1111cbbc1111cbתa''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcb$3?"2767>54&'&'$  &'&'&547676''7'77]\LMLLML\]]\LMLLML\bc1111cbbc1111cbxyx''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcbxyx$7 "2767>54&'&'$  &'&'&547676pxg]\LMLLML\]]\LMLLML\bc1111cbbc1111cbpx''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcb$37"2767>54&'&'$  &'&'&5476763#]\LMLLML\]]\LMLLML\bc1111cbbc1111cb''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcbA$3?N"2767>54&'&'$  &'&'&547676"32654&'2#"&546]\LMLLML\]]\LMLLML\bc1111cbbc1111cbxPnnPPnoO@v+..''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcboPOmmOOp1.-rB$+E %#'-73%"2767>54&'&'$  &'&'&547676C4f4C4/f/]\LMLLML\]]\LMLLML\bc1111cbbc1111cb1XSXYS''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcb$!;!!!!"2767>54&'&'$  &'&'&547676]\LMLLML\]]\LMLLML\bc1111cbbc1111cbj''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcb$37"2767>54&'&'$  &'&'&547676!!]\LMLLML\]]\LMLLML\bc1111cbbc1111cb8''LMmjML''''LMjmML'dbcwvwvcbddbcvwvwcb$!%!!!!#!5!QX>ddYee$ !!!%!!rPX>ת\$   ' 7 %!%!!=kyykyjjX>xjyjjyk$$ !%!!3#QX>5J@ <1<033!!upJ!#!5!3JI!#!5IssI35!3!|33!!Nup| !#3!!!!.NN$J !#3!!!!.$J !3!!!#3GupJ !#33!!!#3.GVfupJ!#3#3!!!!.cGGf$J33!!!'!'Ssj\s=u5Y6pJ!!!!'!#3!7!sjshxj56$$J!!'!#3!#3s6s=5Y6puJ!#3!!!!!'!#37!s:jsjG$-56$ 51  ^ bb:d 5! 5bd 5! ^bbb:yg62"'&'!"&462!6"264S몧Q3Q3TW4drOOsOOSQ3CB3RU4CDPrOOqyg"&462!6762"'&'!$264&"aS몧Q33TW4QrOOsOSQ3CB3RU4CDPrOOqbgR 7!6762"'&'$&"26b1[륢S4OsPOtO.D/YR3BPQqOOy;d 3#!!#3%!5!( 󀨨 ds <!##5!#T~N 35!3 3#K#"T^ !!3# K@ih^T !!3 3#K@#"쪠T^~ )3!!&'.'&ZVF%,E=Ώ?~%FVZDA?=~ !53*,Ԫ֪w # #}}wJw 3 3!#wJww@ 1@ 0"# #4$H̭9B( w@ 1@ 02$53 3H4CC1 (B9#u HF 1  !!'+]^*^]䰰'B  ' ''ٛ>PNq^D^'B %  !'''tNP^D'B 5  5!''6bNP'B5 5tN>]P'B 5 'Nt>P`32?632.#"#"&'!5gV^naibX^naiUK= ;ENSL=;EOȪ^ 5 3#ѦZ^ 55%3#^//m.   5 5 5 :6:6:6pr pr pr .  5555556:86::6:.  5 !5! 5?@Npo. 5 5!55?ްop9 %5 5!@op9 7 5 !5!?)W5$%5$Ti}$_|x]])W5$%$5iT$}B!]]|!&!%'&'57&%5$%67&%7*?;i@]0qw^%KA6#(AF+3273267#"'' 5cCXbh`^xnieEVhjb_zl]@LTND*F JVND+Fpo"%&#"5>3273267#"''55cCXbh`^xnieEVhjb_zl[LTND*F JVND+FͰW&&#"5>3273267#"''%5$cDXbia]ymieEVgia`yl]$}. LTNE+F KUNE,F]]x|W&&#"5>3273267#"''55%$cDXbia]ymieEVgia`yl[}$3 LTNE+F KUNE,F|]] 7%'%5 '瞃۞L О  @Y8@\9@a ' 7%͞G۞О@?Y@<9@}5!%57%!!'71|Iv\' :qߦ[@Z8@_}7!!'7#5!7%%%9Jpv\]FGjq8@ǹ@. !!#!#5! !'7'7!!5!5!xwxFbxwZwx# %! ! ! l(+R[SrvvP #53sàȖ0kTs*3#*P- #5sȠ-Tk0P 53ȠP*#P*.P- 3#àȖ-P#!!s#s*3#*P,!!s`,P!5!#UP*3#*P,3!5!`,X #4763!!"]oeD9יfV],#'&%'53 763<(enK==Pne(!<  _AE_  <X> 3!!"'&5]9Deo>ܚVf]>#3]J] 4'&#!5!29Deo$VfX,&'&3!3#76l<(enP==Kne(!< _EA_ <]> 3#!5!2765oeD9>יfVu(3(7@% !!!5 5!!37d  hrv! !! $<Ff +   276764'&'&">  &vvrn66\]]\6666\]]\65kk\SS]\6666\]]\6666\! p>32#"&'#'%53%&  s:{{:!8#!rܧ$daad]chaam@j.!3!3:^ &ۺ+#+#+A&6FVfv ]A]A]A)9IYiy ]+ + $%+$01! 4$32! 4$#"35%33!??qqW|A?rpG~+/ 8?+3&+3+A&6FVfv ]A]A]A)9IYiy ]3и/A&&]A&)&9&I&Y&i&y&&&&&&& ],9+ + +0)+001! 4$32! 4$#"!!56$7>54&#"5>32??qqWO\R!>/_N;sa=0>A?rpGM"?U(?N&:$}:iF D+B5+B+A&6FVfv ]A]A]A)9IYiy ]A55]A5)595I5Y5i5y5555555 ]5B9,5B9,/A,,]A,),9,I,Y,i,y,,,,,,, ]ܺ&9;9+ + )"+)?8+?2/+2/2901! 4$32! 4$#"#"&'532654&+532654&#"5>32??qqW v@X[}DuskcZX\[4yk_=hA?rpG]0OLGN<:,+>2+201! 4$32! 4$#""32654&.#"632#"&5432??qqWN\\NN\\Ta/w N 5jA?rpGb[ZbbZ[b#P =  "#/$/ܸ#и/A&6FVfv ]A]A]A)9IYiy ] 9!9+ + !+01! 4$32! 4$#"!#!??qqWkQ1A?rpGK '?K +=+1F+1+A&6FVfv ]A]A]A)9IYiy ]A&6FVfv ]A]AFF]AF)F9FIFYFiFyFFFFFFF ]%F19%/A%%]A%)%9%I%Y%i%y%%%%%%% ]+=9+/4F19%7ܸ+@+ + ":+".I+.C+C4C901! 4$32! 4$#""32654&%.54632#"&546732654&#"??qqWT__TT__jivvWQMKRRKMQA?rpGPIIPQHIPIvSttSv\\=BB=>BB 4@+>)+>+/8+/A&6FVfv ]A]A]A)9IYiy ]A>&>6>F>V>f>v>>>>>>> ]A>>])>9A88]A8)898I8Y8i8y8888888 ]+ +  2+ ,;+,5&+501! 4$32! 4$#"532676#"&54632#"&2654&#"??qqWUa.w O 5kN[[NN\\A?rpG$O <b[[bb[[b &2>+#+#*<+*60+6+A&6FVfv ]A]A]A)9IYiy ]A00]A0)090I0Y0i0y0000000 ]A<<]A<)<9<I<Y<i<y<<<<<<< ]+ + -9+-$%+$3'+3$01! 4$32! 4$#"35733!"32654&'2#"&546??qqW͞u>@EE@?FF?A?rpG>>'*6ޗ{;( C;!O;!O ;!O;!O;!O;!O;#!O#;(!O(q(!((!((!((!'(I(!]((!((3(:( K' q( #'+/3!33!33!33!33!33!3mnmnm 4('/7?GOW_gow5'#3%5'#3%5'#3%5'#35'#3%5'#3%5'#3%5'#35'#3%5'#3%5'#3%5'#35'#3%5'#3%5'#3%5'#35'#3%5'#3%5'#3%5'#35'#3%5'#3%5'#3%5'#35'#3%5'#3%5'#3%5'#35'#3%5'#3%5'#3%5'#3(;(!%)-13#3#3!3!##!#3#3#3#3#3#3#^^(ll(lm#;( @#q:( N!&9 U'( U9(& U& V W9(& V W9(& U& W \9(& V& W \9( U'9(& U \9(& U& V \$! $!!!,7r+uv ))xxp) )$7632#"'327$%&#"%632#"'~~~~eMM>yJJJJJ6````qq|qq#u"@91990  9%-p) 327$%&#"%632#"'MM>y````qq|qqr' '/7?G%&'&'6767&'&'7%'676727"'64'7&"'62&47\+;.81F9K58.42d;E9G,:.80G9J6&8.;+d1O9FLL&_`JnLL'`_n<1& j(0=Ju &,A=N:0('<1& j(0=Ju &1<>EB0(n_II'[[JnII'[[p) %/36%632#"'327&#"6767&'&6py AAAA,+-,,-+A@@Rqq|qq%%mܱ[0$ %@%|"p) )73276'&#"7632#"'327$%&#"%632#"'r99:9rr9:99XWXXXXWXMM>yB!!BB!!oe33eje33````qq|qqp @ 104767632#"'&'&pihѵhiihҵhiѶiiiiѶiiiip $32#"$27$%&#pkk<MAk^a``p $32#"$"3pkk<MAk^``p $32#"$327$pkk\MMAk^>``p $32#"$%&#"pkkAk^>``p $  $"327$!pkk]<MMgAk^```p $  $"!pkk]<Ak^`p})6%63"'pRqq)#2y|q*q( 2654&#"!|~}}|v< ( $%632#"'327$%&#"!IMM>y_O````|qqqqH( ( !#%&#")%632OyyMMqq>~``  3327$3!#"'$@1>qq``) %63"æqv`) 2#%&#u)q>` 527$3Muyv`>q "'$33yuMq`p)%632#%&#"puqq>``p3327$3#"'$puMMuyy``>qq!$ !$ !$! !$!$3! 2654&#"4632"&nȊce;~|ddcc||}$!%!!d r<$!%!!We r<$!%!W7 r<$!%!W7 r<$ !%!!!!+c,b r<<!$ 462"! W|VV} ,|VV|V !$! c  !$! b  p(  7& $  %;<*X֖$ !!!!!!,7,rWb<)) Ie$ !!!!%!!,crWbM)MM^??@7`d?\gOOOOy>*<?v^h"3263#!5276;'4?'4?26u'6"gP39.4! '*C0.xV#m14He '1l1 Z+dd?33 #&'&+"'&#"/573;2?"#'57#&'#"#5676!5:+#9,p!j[%+ > 7VCCc":8}V .e3B=Se` e9*=9 3@=}k %C`:d;emu}'S3273&'3327&'67&'67&'67'32654'&'2327654&#"3672 $54767&'&47'&327632#"/#"57#"54?'&5432'&27632#"/#"57#"54?'&5432'&327632#"/#"57#"54?'&5432'&27632#"/#"57#"54?'&5432'&327632#"/#"57#"54?'&5432'&27632#"/"57#"54?'&5432'4327632#"/#"57#"54?'&5432'&27632#"/#"57#"54?'&5432'&27632#"/#"57#"54?'&5432'&27632#"/#"57#"4?'&54327'4327632#"/#"57#"54?'&54327'&27632#"/"57#"54?'&5432&'67&'67&'67'&327632#"/#"57#"54?'&5432'&27632#"/"57#"54?'&5432'&27632#"/"57#"54?'&5432'&27632#"/"57#"54?'&5432'&327632#"/#"57#"54?'&5432B~ %<z*+')+(@&'$||e<-A}]\B-71SLoWj\vLL)(0/ (( .1(%%,* # $ )*f$% +) $ #*+f%%,* $ $ )*  \o  [ %)#&'%&)#`#$ *) $ #+,U  Q  0 E%% +) $ $*+&EC&V*,)-)-*,%&%&fБfU 3HhfeefhH2pu^QFs棥sKQGh!99!  !77!  4 4 22 K44 22 22  11                   7        %&%&%'%&%'%&22  //  g               44 22  ->O`q +&'&54?632332?654/&#"2#"/54762#"/54762#"/54762#"/54762#"/54762#"/54762#"/547672#"/54762#"/54762#"/5476%2#"/5476%2#"/5476%2#"/5476D.2`{4&/<) e>O ,4H3R 07K $   $   #  #  #  $   #  $   $  U $   # " $   #  7Q=KG<s-8PZy9z _e""#/2dt0&2j ,: . 4 . = ,  ,   -  -  -  -   .  .   ,   -   !! WV9`8 !! 7 ! !WVDu9`8N I 7%7&54769 }V&7A 6$ 8'^4? !2 7%7&547!&'6I@Y%14HFS"="l-2DC[9 &! 4$32 4$ #"&54>2JJhhq0^mNMn2Z^Z2K7iwBNmmN1Z00Z} C"32654%"32654&%#"&54767654$ #"&767&54! ggJIhIhhIJgg[ZQoy y}WZ[zADgJIggIJggJIhhIJgU\\Q srW\\^} A4&#"26%4&#"326! 547&'&632 $54'&'&632hIJgggMgJIhhIJg#@@z[ZW}yOOyoQZ[sIhhIJggJJggJIgg ][[Xrq Q\\} "32654&7#"32ɏǾ/`T_ȐɎ;P12Y}1"264&"3264#"54327&5432#"'&'3xyx& کZTdIU  k#5AMYer3#"'%&547654'!#"'4%$53!76=332654&#"#"&54632'#"&54632#"&54632&'&67632#"&'&676'.547>'.76$6&'&54%6&'&6>#"'.54>32#"'.54 [$gi< D""D =if%LW쥨驧r^]]^ !! !! . . *)X,),*))+. } +G  G+vKK9__9KKݧꧦ]]_""""s!!""W&. - . - a)," "  ))    !) /     p%-5AMYdp|5#!4'&'5#2#"&546"264"264"2647>'.7>'.676&'&>&'&7>'.%7>'.676&'&676&'&53!76=3%#"'676%27+%&547654'7327&'$%'#327%654'&54718楣. . . .  - -Y - -))G))))U*)>- - ~- - VK; yA C0B Ax ;K'6FJ> $06# >JF6&@@1AeA1@@H磤椣筁 . . . .E - -- ,1))),(9)())u- , - - G77W6 W77G D&& ee˥ &&D "(=pp=("u !!'!Pn8hv "!!'!##+572367676MoL)>u eI3?ba8hA:F;/Itxv !!'!  ##' Mo_h[ei[i8hi[ef[l[@36273 ##'5) U.WW1@ US Vdv#,5>~3+&=43+&=4%3+&=43+&=43+&=43+&=43+&=4%33 #&'&+"'&#"/573;2?"#'57#&'#"#5676!5\:V\9\:\:]:&]9[\::+#9,p!j[%+ > 7VCCc":8 #8d#7$6$8;$7i$7 #9pPL  )Z. ;6ZV Z3%Y63 .87p  3DMy!674#!!6?676545&#'323276767654#3#&'&'454632767!672!&=75$/563&43!32+'!67#>54&53# ? I :W0 96;E,Q 2:&l6x0 bm! o۸"\>%Ef~e2U6g!6V#p5C+ C ? P9 @7H4XmM7RV /M(=H: ,qLUD)8Wqke-Pex NW =$ U  /0c)H?2@[nDF8T$.J? !' !T4XKGwL5_K !'7W4Z~wDS&5476322632%632#"'&'#64'#"'&'&54654&'&54767632xJX%&XA,B:\8 [EMH95##Fl% !9@!#jL p_Mi#"?8" %lF##58HN4hok@RRr*%te BB9'7*$%) "fXS5EIf" )%#,7'9CB >E3#"'4332327$'#"$4727%672567654&5&oJ7.b9M D ,B3 qY 5**]d=HN9% sW$,J ]T-MMm@ed: ,'Z M'cM&T)$$ < I2%!"&54676737#&'&54>;7!"&546767!7!"&54>3!6763!26P+=6/2D>R+>2,+v*>>+2  ,2 =,2  =,3>,2463!2!2#!!#!32#3#!>*v+,1>+R=D206=+P#,>3,=  2,= 2,  2+>{!C%4&#!"!#"3!!"3!#";#"3&'6737#&'6737!"'67!7!&'63!67!2I0!6OS SS: SS>SS]]J]]]]h\\, Bv*>K%39LKIOKHLKIhghghghgE?-L!D72654'6#"'4#"'54#"'54#"'675674767#%$4:JILLHOKHLKIhghgighgD>-sJ1 b6'SS cRR SS?SS\\K\\;\\]]!A*>K{!C%254+'3254+'!254#!'!24+!&#!"463!!2!!#!3#3SS?SS *vA!,]]j\\\\K\\IKLHKOIKL93%N-?EghghghgiL!C32=732=7325732'654&#'%2&'&5&'5&'IKLHKOHLLIJ:4$N->DghgighghSS=SS SSb SS'6a!0J)K>*B \\]]:]]J]]}O &*.26:> 3656;2#'7+"/#"'+"5&54775%"'5476;25'7&56%635&56;374765'75'76=4'&+ +"'4!#"'4543$365&5&#%#754'&5&&547'5367&547+&'&'735&2?"5%75537'7'3533553535'32767&5%2?&#%55'5757757751:e,$?F?Y>F_LA3ELH3,8LYLlEF'!0< k#gF  EeY!! Gp&iq.8ZN$%`BCf F4"4._?ee3&{E(1-+$Kt8 -  $Gs sM rEF"2 >_plTErf^5.>=9|5"-l)d ,&>vv]cccWpC-+ d8 Bpp>W]oaxvuPp82,D ^8, ^B$K+ "1R[+e*; 2 W QP I&? gpo% w ^SA$ 2 9i-5n02 Ai&IY^P]D%\??\OWC ,,1 /211/=;7777=321811{908hN%b\Dh,)h?17I21!122223 21&2%2#"'&=477654'#"'5473Bq4|l anN ilm b 9 b؍MOb>YaYƮ58l7P P@ $0<FX + &=6&# 3 6=%&#"';27!5%67%!&'&'2+"'&=476r cR~UY082.ԍ_W_V"+}IR8D).P9H'S]ٱZYHYoX(I_ ;.2lOP%.G6R%&I8d)Nl>54'67&54&#"&'632.547#"'&'#"'3267654'7327323.#'654'567654&&5476;'&'%&+"#"8DH$$yU ?L[>!WtJ([Fho*m.2\=w\`|UP7:/E" @7?EP]Eix pF@T5ym,"&eB@q(A _% #+B7!N &".OS$XE/K(Aa]dLP*'FCaYr=C44mo C (FKWYFvbph'UD'R< $d#+?Vm#327&"#"'7'632&'$54#&73254'&#"'5&567#&''5$'67'654'6'5$'67'654$'67&'654'''5$56732#"'&#"&'$'63&47"7&'7&'7&'7&'54'6546767675477&545?&''5&#" '6%35&'.54>23#67!&#"W  OB7[l#> F_Vh " "@.,=6tJ4Vp1EQJqMi vhpHI!:JJJ =4m\8B*?o v!"t,`s&*_~P1>5='g=>24<+-s[,*&sd1PT>3J@='h<42J-H#*YT_Y)*)X^TY*$D  ?>}>  *0t"J.  &b54CUE ''!`9 !,(MTE *! }q~=/+)f[4f !B" <@0&9c?"V+GoMK~a? }b9e\ P&0@k"?c*GEJX ?e}9 \4 \6 '''' 6\ N(&'65&'67327&+!65+"3yyys{w ccޱqXeXc6 6 c ,35'533#3!'#'5!5!5#53!5!5#!!-ʷ}} ckvG G @<<3ffX苜qXGccGJ 326&#!2+73 ### 3(ttvgnؐB(33#!!#'!'57!5#'5735׫$"q~q+!#!573#'5!3!'573!#'73!#'5;jjŠJss<wѡIjj8/w{,32#' 3%+ &5%6323'#57'53^VQ6>ѨABؒ6ʞG2k >Y3~||~Obs32732753"'#"'4323$4'5;+"'#"'53275'&'&5?5572%#&'&5%634%476=%@.!%,BE,#!-Q2" $nL/PuHED832#"&546324&"26%! !  Őb{=&*<<*(;E;R::R;KJ67Ϛ{ɬ)::)*<<**<<*):<'L67I&I'II &I'IJ &I'JI &I'JJ &J'II &J'IJ &J'JI &J'JJ  @FLRX^djp3264'&#"&47367'676756273#'#'5&'&'7&'677&'67'%%&'&'%6767%&'0/CB^0/AC/pkTcR|'N(OfUippqUfO''NQaQh!$ b)dLQk KRt!% c'd&//^000'N'|P_PfppoQ`Qy'N'P\ QgppmQ \Py,  M N>&`7" bK*V&"g{ M M %1=! !  54 #&'&#"#46324632#"&%4632#"&67KJ]_EASvwSAF͒D10EE01DD10EE01D7IL6a]U@SS@U1DD10EE01DD10EE %1=! !  54 3327673#"&4632#"&%4632#"&67KJ]_F@SwvT@E͑D10EE01DD10EE01D7IL6a]U@SS@U1DD10EE01DD10EE %1! !  5# '&'32654&#"32654&#"67KJ;lWPihQV<=UU=-1\ H0e%FKSwZGr=;=NN$E| 1 ?'_>?@7`d@\hPPPPy?+<>w_VG{?,rCA+ +"'5$76%&'547327676=&#~jt1/Q}](+VRxbO P >nS]] =fP+! &56;2'5$%75#"3ui1.P~N](7P,VSZycOpO >S\^ f0:1>7#'#53'&'&54767&'&=33676=3#326'&i($lm$(($[Uu&tU[$&uU[[UV$|ddb e|$% ZSSZ %_TYYT* $4&#"326&5432!!##53&w衤礡PP䤣L~||* $32654&#"%#"54767!5!33#b衤礡7䤣L~|| $&$76+"'&5'476!7!ttsstEus pid5s qttrtt<֤ꧦg\ulS5264&#"#43233#!5 z{ym㗗y{(|j#53533#632#4654&#"#*jjoon}mZyH{zF2 1"32654'#"&4767!!53#5!!3!!#3!!pOO87O:=0LmkL/>Λ2  1O79NN970LؙL1KӘJJ-'<%#5#535&'&'5'73'3#'73'676=35'73'33◰zhNgeMjzzTThOʍ7NjYYӖy?! #!!!'!27674'&#.d ;6zFH%QM_\ǃ$P<]$!#"#&5463 67!2#654&#"V⩁"T]ts]U"X"1((1"u." 6&'67>3"#"54767&'&#52&͕LVa{.+ؔ)0zHUM\&ϖ=Bll)'ҕ*l8lB=j&'5 %$ 56?63#'[Wtutu4ZZ//[[5  @Eo&<"3264,'532'&54632264&" &$#"#"&547>B_^^l;͓hI^9l:͓hI (+|TlgMLx)+{TlϔgMM M>54'.#"32463227#"&5454&#"#"&'&54767632254&K2q'$#K1o'#0ߴGdAoc.% 3t88bWDs-Kx68<32>32#&'567'45'#&+"#4'3>$4&+"?w(K>R0D32>32gYYYD,.:?#)v$E?w(K>Ro}vvxJvaAjtAO]ƀwϧ!5!3##'!5!~2k<@i8080k<j)127632#"'#576&#"4'5267>327&'"SkQmyz,~zi2@:$(.-)zW] ݾgvx-aX[&ŝ9{'Q32263227632&#""'&#"#"'&#"#'3232762327632&#"#"'&#"#"'&"#'Es- p86rV+)|m^?_354.#"!&'.54>325467675#53533#63232>54.#"P#3JTRJWVJQSOMJ4"?*&ElnhPL$ llill %LOhnlD')----+)QPQ((QPQ)+/ 6klj$?6FWWF6?$jlk6 }++--JHNRh|&'4>32"'4>32&'4>32&54>32&54>32#!5!'!567>54.#"32767>4.#"327732>4.#"327>54.#"732>54.#"M_ 6694S55.+C55C&.66 V\+55 c$M##$ 6$#$s`%#$d0"%)h #"#_33@]22-"40446/*33UJ"+33^1/K=0T* ####  #&$$&##&$$&#  B #### *"$$" U!'-2!35!#3!53573#'5#5!35!75!!5'57!s\\ss]]s JRRIJ~֛E77__vtt4!v7CQ^&54767&'&'5676767&'&54>32! 535#5##3654."!2>4.#"  <$))+N-N*)N-M,**%:  @ v<-MTM-?K5:66459<5&?HPPIK* ')+K**K+)' *KIPPH>&5<:6uN|l||l|-I+N))N+@6:55:5Q)5>o654&547!&54='&'654'67.5476;+"'5#"=6&'76767%25#654&'Fz-6 Z8. ,N0H!h6%`+EH )#M ;,Jga#iR k' M +1^hgo8:(@s.Pmz nx?.#1p#41`&>%!ac,,LHJ x}647| + OJJ)!0 P[32>4.#"32>54.#"!5&54767&'&546767&'&4>32'&'.#":e79e89f76e`[S &(*UM,N)(N-KV)&& \@ECApd88dpg669:%N&KRS* 'TM**MT' *SRK&N۠:9}qyyq}c $Tdhy67&'&"!3!67>54.#"!&'.54>325467675#53533#63232>54.#"!57!&'.54>3234'67632!P#3JTRJWVJQSOMJ4"?*&ElnhPL$ llill %LOhnlD')----s=BDw@>=))==AwDB=+)QPQ((QPQ)+/ 6klj$?6FWWF6?$jlk6 }++-- !yCB{C!$$!C{BCy! JHLP&'4>32"'4>32&'4>32&54>32&54>32#!5!5!M_ 6694S55.+C55C&.66 V\+55 c$))_33@]22-"40446/*33UJ"+33^1/NNOOU%)5!5!!35!#3!53573#'5#5!35!s\\ss]]s ^^/oo#E77v4@4767&'&'5676767&'&54>32!&535#5##3  <$))+N-N*)N-M,**%:  @%v<5&?HPPIK* ')+K**K+)' *KIPPH>&5<:6n5|l||l|L3?HN654&5473#!&5454'+#"#7&'654'67654&547;2547#";65'"3%:U"-6 Bu Zg0krX0c-h8E+`%s H>4wM-'9.QY / o8:qhPSmh #%Bz1"0@)5"@YR0.&54767&'&546767&'&4>32; &(*UM,N)(N-KV)&& 9:%N&KRS* 'TM**MT' *SRK&N۠:9C##"'##56'##"/547?^'5@_*SU&/UL ;Yԧ9UP(` XI.s222732#&547636=4'&# #4'&#"*t pz&=<xQ>hG:V Hek%PF5NP B|-&pA&NFX &&5 <F:^;" V gdG7236;2"##'65##"'&5476;235&'&=476e x<JT`(GeRUdfB3 VNTMT,P$ 66$0_ u3dUdt_}s*$"Rt0XX__/ik=ZG8*F 1 . ъf)MC =g9EkO 9!(-);&  ]t!y" & 2| ba$ U+  #8M35733!&54?'7'327!!"'&%#'7367654'77'7'&#"'676ի,&T>=c#]K9.U:1ʈ%`T?7>54&#"5>32&54?'7'327!!"'&%#'7367654'77'7'&#"'676]T@1$J=c#]K9.U:1ʈ%`T?32&54?'7'327!!"'&%#'7367654'77'7'&#"'676Z _3lFHe5^\VOosHGJI)`VKm1Sj,&T>=c#]K9.U:1ʈ%`T?=c#]K9.U:1ʈ%`T?=c#]K9.U:1ʈ%`T?=c#]K9.U:1ʈ%`T?=c#]K9.U:1ʈ%`T?=c#]K9.U:1ʈ%`T?32#"&e|e(<X<ħñ"32#"&$2#".46e|e(<X<ħñ"@<#"4.#"e|e:<#"< !<"#;zch =B4.#"$32>4."e|e:<#"< !<"#;"< !<"#<@;zch =B54.#"##"'5##"$'&'!5!5&'.4>32!!676767'%''H&(G()G'%H(%'V W3WImuw>DE}AB|GE=md^JW4W Vs'H''H'(H''H`XAK|@X1(ԁ3"|}DD}|" 2/ "1X@|AX1# / 673&/'67 &'"&'6?&'3 ' K[]><+Gg['fBBe&\h?(K?]\K !;32T $ #AC,MMMv A5p_9D-M**  B@0"@R//>wA&oc/D&3.YaQ/5"1'"uE62/u= =!m- .... y 7%  %  32+#".=!"&'&'#&=4;7337_% 8)0/_^^M^1/ 9534<&&<&*(D>?GGzB6C{GG?>D9/C}&632#"&'.#"'#!#!#Ҹ62K#+~KF0R!9'/Nx_TV_T 'NQ9;:#8HL"CD|))Z) 532>4.#";267#&=&$32735&'.4>22[02[24Z1/[)'5*+X A54.#"%2#".54>''#/'7''7''7/5?'77'77'7?3777''H)(H('H((I\Hs=]SH$e$HR^323#67#&"#"/&'&547&#""'6%676V n*[n%'ZxL0<{2;&b;0&8a>!U*~EmLK}`? {a7c[ O&0>j!>a)E~CKW ={d{7 [+M57LL75M-Z '*''*' Y (5[ J5( \d (5J [4 ''/7O_2#".54>&'32367&%2327654'&''67&'&'&'676765467654'&#"7>326323#"'##"'&'#"&'&54767&'&54767232&'&#"6&%6767&'&'&#"676&5467&'&6732767&$$$$OG3%V cc V%4GL944m/122102/.303112.OF}6&V e"w?>v"pt #87! vn":;@A<:"nx !66# sp%./13/.UVT\<>"$!! !"#">kc V &6|FO 93399 <>#"#><  "$ZTU./43..V5$##$59gT;&'9Z^^Z9'':Tg9'(''&()I8:9889: Z_59eU;'( :8.>euvc>-7:bccb;7-?cwud?/8KWZZW **D@@D+8(':Te95^&)(&''(DA:AD.*!Y[[Y!& !-x67&'67&'4&6%67.'%4'6&#"&'6767&54?67&'&#"#&'#&'5&'"'67&'&47632>4.#"%2#".4>'7,3 3%/0),7=*#0*+3.22'8  YfT,1'').UfY >98 "2 B2;F_ XB?2C 3" 894ihgikce"S[XVWXZ#ejpMcNTvJKrZ1VlLWMI p jk%nA V{ww[11[ ww{V @#fd-#JM 7B/""0C7 NK",df#νhhοggQUXXUd %3!'#!52#"62#".54>" h9|M463%&$$5 O Dn; $$$$33'554#$/[QwGSGUW GJGX .5CK&5432632!!#!##53&4&#"326!&&#"327&54654'XP}}P~C;7?_Xej;A>7'sssLFF~||ב-  䤣lrrq)-5DL&'&6767&'"'&'&'&5'476!7!! 76'&'&'6'&utss-5 l&kpid=pDi/tEust,2}ts5sqtt-ԛ1 k&iꧦ g\}ul  An?\27/rtts,͓}qt)8GO'"'!!##53&'&54326!7!&'&36'&&5'47&#"327674'U`P}zpidu>7;C˂;C>xtsK) ||LGD g\uls螝՞䤣hkrr .4&#"326&54762!7!!!##53&w衤礡ᩨhn&䤣羚 o[tꝇ|| +D#"'&'&'&47>76327'7'%'27>764'&'."(F3"D"&%#}bV`ZZ^;D"&&$[X]:3G9:]:F=~=HS]^X&% iiD^29i\=<<92-1X?:<91*=X62'%'!!#5!5!5&'&'.546767''7'''7"2767>54&'&'&4p69].(EGGE@Z-<81VDEGFF'19T]9T:G5>+.11./:95>+.11./:9 \2:a(Eb_E@( %CE_bG(Hij:ο\ij+.wBAw./+.wABw./4+F!!#"'&'.546767675!5!' 2767>54&'&'&"<-Z@EGGEDVRbfNZ@EGGEDV18kbbjC9:/.11.+>59:/.11.+>5疑 (@E_bEC%##(@Eb_EC% kajP/.wBAw.+/.wABw.+ +F####"&'&'&54767>32333'7 '%32676764'&'.#"ܖU (@E_bEC%##(@Eb_EC% Uܭkaj/.wBAw.+/.wABw.+<-Z@EGGEDVRbfNZ@EGGEDV18kjC9:/.11.+>59:/.11.+>55 @  10432#"732654&#"陽…5 @  10432#"K +@kk k kKTX8Y104632#"&732654&#"ϑϑϘuSSuuSSu͒ΐSuuSSvvdPK!)7eK RX@ *.,&"($ k3,k($kk8991@&"6k0k 8<2<299990Y4632632#"'#"&7323&547&#"%6547232654&#"dϑRDDRϑRDDRϘuS?>Su^222Z>?SuuS ͒!!ΐSuXqpWv28ML88LM{WpqXuSSvTZ`z8Rm3#"2767>54&'&/2"'&'.5467676"2767>54&'&/2"'&'.5467676R#)$#R#$ $LK:C.25521@=:C.25521@=R#)$#R#$ $LK:C.25521@=:C.25521@=zZF)(JG()K.2IF21.2FI21F)(JG()K.2IF21.2FI21 J7Qk>767632"'&'.'!"'&'.546767632$"2767>54&'&'$"2767>54&'&'#61@=HK:C.25521@=:C.5%'21@=:C.25521@=HK:C.6#R#$$#R#$$R#)$#R#$ $5[51.2IF21.4`]21.2FI21.5[F)(GG()FF)(JG()KR 5%%%xr6׊eMM^xxV)7654'&'575#!&54767'5!s_vR$N::N$Rv_{aT,X@X,Ta{4b\)1%==%1)\b4ߴ:`\KDDK\`* 4&#"326&'&5432#w衤礡$PP䤣L~{lPj'#"'&#"'&'&'&47>7632327>76&'&'&/&'&'&47>762!2!%327>764'&'.#"&#"327>764'&'&s* 0$+$$$ 1#*# ZaZ%% NT12 4 #HH  ")mROeb  , 0  +   ) . $J . %'.D"&B 1 $C mR )Ky    !   V!Edz267>54&'."#"'%"'&'.5467676;27>4.'&+"'&'.54676762%632$"267>54&'&.&&.&m,mQjP(!N!"(! aVf&&bZ55!("!N!(PjoQm,.&&.&q    l?W,>&#< A#"< " (( " <"#A <#&>,W?~    lOOj3!#!"'.'&47676?6767>'.'&#"#"'.'&47>763276;%32676764'.'&#"676764'.'&#"32eOuRd2!  HH# 7   ZTN +Za21#+$0 4$$$+$0 's  *   * OK) Rd#!>& 3"9*$"D. ' - D! 2 . , T% #: & (  IZx-4H67&'&'&+"'&'&'&476767632%632 #"'%#"'&'&'&54767676;276276767654'&'&'&"276767654'&'&'&""'&'&'&547676762"'&'&'&547676762'&'&'&547654'&'&'&";276-&#"+"276767654'&5476%327%&"'&'&476762I  Q\C--%("(/*0.,+"( /X]\9<\X/"$)0*3')"* %1*0CR[        22 2 2 2 %'   &J  &%C\d#_*]OhXC%&  J&   O]*       ")&`&"'$"/' <%ZS  % SZ%< /'* "%5"-($# ;8\= !  !  " /VC "  !  !  [uV/+    V^au 767>54&'&'&#"&54767632 '.5467&54732#"#"676767#"'&#"'67654 ozwbda_f_zx|wbdaM,krnulspsnunNJ*D$ lQ$" 6*D?"5'K(2- # >   :72 331cd툍i`4331cd퍇>mwn<;;8ro졘wp:;;BV0/M8:D@*|sa  -F(7 "*=8&0!2  1-5$& 6:B4V^ (B\w.'%&'&"632%6767>54$2"'&'.546767" 767>54&'&'&'2 '&'&547676?'*&$ 1$-+h+-$F3782**?1 $&>>9|wbdabc`zwbda_f_zxspsnunˎspsnulwI_"2[$  "" gI $[2!v 55 55 31cd퍅caf31cd툍i`43d;8ro졘wp:;;8rown<;x,A-57'36%33#3#!2#!3#3##$'#7$@d5{sVd]F0 0F]dVs{5⒒d@( jPP,PP` 0 ")- !676762!"'&'&'&54!X$#R#+/RFF$#R#$1Sh,  k-"s!}P476?6763&'&'&547632676767654'&547632!54'&'&54'&&#"'&/&'&'&#"#"'&'&/&'&#"&'&'&?6'&'#"'&'&#"!'476='654'&545454'327654'&'&327654'&/%4-)"$0JK&  )7    %0'# #6 +-L __^/s4* 1( .266 |/(1   \   #:7  lS&   x71]/~[#<$  o_%@,: $";vR $X$+|!5DX&PY;9Do6 b'n2  83eF] 4T&  &  /50$?- 1@& 3l K  C"P1 :03<D:5XI.)D&[+-1:   q/A8   g+jl9Lp{7654'"'&#"+"'&54?67676763276323273#5%6767'&#"6"/67#"27632327654'73654'676547&p/l0&J!cS%YE]{@C"$4>-;% ,(6Y>m!N$X6"/,(4sS?X$U>"sJ?K(`./4+2K2.0>S Zp0+1^' ;cs  /^"|Y/ 428ۇϕl%%ot5oA='Y$ aT* ''G+- %_kj~r}jL`І|\gK@/.85c($ (2LS>54/##326?%%3254'654'3>7632#"&547>32'% ;66I   }g ?6qn   -> 9@ H67;  zh| 8 >6!q    B5>%+?F4&'&/76765'7! !'!654'!4'!!$467>2"&'&!654' 33 ^^^RXI#J2VlP# ~!88!~ Kppph,p<(##(#id (2LS.#"227654&'''%'654+.#"65.'&54632#"'.6#"%  I66; o |>?%6!q   9  ;76H   |h> 86qm    BX{[%G'23 %%.'&"27>7%$!"#232%"'&'.4676762%#"#2%k      A>>dIID`nS   SnGYn 5>5 n)(%$#"#64'232%%&'&'&"27676&22k**!n``n!##3W 2327632#"'&'&5476'( > !~GH ".4F+@xH )0$'*' 23277632#"'&'&54763'( e` }{*279HF`0@xJL 1 ,A  ' 7 Ɏ877Ɏ77ɍ8ɍ? tt7tt7t7tt7uB2632#"'&'#"'&54767'&54763267632676 Q   x L$3 z(   6X3  6*=P*> "#  R26#"'#"'&'+"'&'#"'&547&'&54767&&5476326763276T 디% $$YyX$ zc0 + j :  (̢1#: _$ #- Խ =1 '2ĺ pD #!!!!!%!!!!!!!!#!5!36HVBBXBBUHVPBXyBpD !!!!!!""p"p"#pD35#7!!#!5!3rrsrspD!!%!!!!!!r"p"#p"#Rb !!#!5!3ppEU l3!!'#'!!#!!3!5@,r,,_ r,,_>v #!!!!!'!!!!!!!!#!5!3hm_|P_H_pDK#";54&'&'&#'!326767657'&'&'.+3!76767>5{dIB,$2$*DEh{LGC_RQ|66R_CIJ{hED*$2$,BFd{LGC_RQ66R_CIJKIB`OT|87O\FGKzdGB+%2%+BIdzKGF\OT87O`BHL{dGB+%2%+BId  #!! !!! 373#'7#ZAA:Llحmllmzlmllm|}}|d d}cT`C54'&54762327632#"'&+"'&5476=#"#"'&476323(L,68x86,L zFvd0000dvFz L,68x86,L zFvd0000dvFz zFvd0000dvFz L,68x86,L yFvd0110dvFy L,68x86,LV^&'##"&'&'&4767>32367675&'&'.5467676236767>32#"&'&'&'#"'&'.546767675&   R.-R  R-.R "  *!""! ((\(( !""!#%   " R.-R  R-.R    %#!""! ((\(( !""!**!""! ((\(( !""!#%    R.-R  R-.R "   %#!""! ((\(( !""!*  " R.-R  R-.R   Sa4&'&'&'.546767622676767>32#"&'&'&'.#"'&'.54676767>5"#"&'&'&4767>32(,$ ((*& :.r06$&**& )'De!  'd8:b&$$&b:8d'  )a@/!  ')*&$6/r/6$&*)'  ')?c'  &d8:b&!$&b:=_& (bCc"  &d8:b& $&b:=_& (a?/!  ')*&$6/r/6$&*)'  ')De!  'd8:b&$$&b:8d'  )a@)' ((*& :.r06$&**& ((T`0267632#"'&'&'!&'&'&54676763267632#"'&'#"'&'&'&5476767!6767632#"'&'"'&'&'&54767#"'&'&'&5476767632!#"'&'&'&54767#"'&'&'&476767632&'&5476767632!#"'.'&5476767632&'&54767676Z   ( &            <   4          % (      (   2     6           %    <    %  (   W_2767653"4'&'&Wspsnullunsps;8rown<;;j>-'O^__^Oq44H4"hdd0!% %!-@jjjk**37'73 #'xxxx.xx.x..x  pD #'!5!73!GFdFGrEGdGErFGqFGdGFqGEd@L     - FOFc,OO,cFd,PO,dGOP T` '%%%%%% % -wD{wwe#w%f{wwy||y{xxe#w%f{wwxEy||y % %  Zp/AppA/}}ET`     - Zq NqqN  NrqN qrT`% % -ZyllylyyT`%% %% -ZtGcVGttGVcGGstGWcGtsGcpD/3%!!%#'''%!5!%777xo:U.cF.d;UǩoxoU:e.Ec.U9oE.f:UūoxoU9g.Ff.U:oxo9U. 54'&5476276767632+"#"32;2#"'&'&/"'&5476=&'&'#"'&'&547676;232?&547'&#"+"'&'&54767632676'K,68x86,L qA'C<4GW>L d  f L>WG4L d  d L>WG454&'&/54'&5476276767632+"#"32;2#"'&'&/"'&5476=&'&'#"'&'&547676;232?&547'&#"+"'&'&54767632676o**YK,68x86,L qA'C<4GW>L d  f L>WG4L d  d L>WG42#'"372"'&'&/"'&476="'&547>Q!//VZ *nN+G80j@6RR6@j0/P1N TP#00VZ ,lO@W+G80j@6RN6@j03L/N  ]H,`,H Yc!77\4OO4VA7gU3',H^ ]H,`,L&3c!77\4OO7VA7fV4&,H^67654'&"327632#"'&'&/#"'&5476=#"'&'&5476763232?'&#"#"'&'&5476763254'&5476276767632#"'&#"#"'&#"327676%32767654'&'&#"#"Z8%1T1%85e %ZF\ +m8BS/?JV@6RTXN6@VGB1QB8n* \FZ% e53e!&ZFZ *n8BS/?JV@6RR6@VGB1QB8m+ \FZ&!e3DA 5<; > +F$H$F+ > ;<5 AcJ2QD++DQ2J (5H,'9,J&0f) T|\`j4OO7g`\|T 'g/& H,9',I4( (3J,&9-H &0f) T|\`j4OO4j`\|T 'g/&J,9',H5(""'!$(:UJJU:($!'""nFw"2767>54&'&'767632"'"'&'.'"'&'.546767"'&'.546767632.546767632=>343343>==>343343>x>%85670-),(-%8/[0!-(,)-02y/8%0%)-02y/8%-(.'&$W/:#-(,)-02;>/;),)-02;>/8%-( 06{IF{6006{FI{605+'g>:c.&".c;=g'+&1N%&W'+&.c:>k#"$.c:>g'+,B:>g'+&.c;=?nF\v%"'&'.546767"'&'.546767632.5467676267632"'"'&'.27654&'&'&"67&'&'&'276767&5467'&'&#"32767>54&/76767>54&'&'&#"Z0%8/y20-),(-!0[/8%-(,)0-<1:3%>(-%8/|/8%-(>%85670-),(-%8/[0!-(,)-02y/8%0M=  H C# B/g H /*x#$  8## H g/B PP  $#x*/%N1&+'g=;c."&.c:>g'.5 ?=;c.&&.c;=? 5+'g>:c.&".c;=g'+&1N8GG$> >$ c.,bB$#>  Ir0C >'#> LM >#$Bb,.$ >#'> C0rI T`)T:e&'#"&'&'&4767>3267'&#"327%32676764'&'.#"7632#"#.4767676324676762>322##"&'"'&'.5#"'.'&467"&'&'&4767>&'&'.'&'>76?&'326767767>5&'&'.#"767>7.'&/32>7674&'&'67'&'.#"67'&'.'67676767"2767>54&'&'"'&'.54?&'2767>54'7654&'&'&"67'&54676762:    $4 4$ww4 4 xy   %" !()-+U$"! ((\(( !"&S+-)(! '7M"# V2% A()-.R$"! ((\(( !"(O-,*(A"#2P"# "M    ! *4 2 kk  4 2 uKK        i2 4* !== 2 4  `_  wR#$$#R#$$  8 < c !<>     8 < d!!<>   "%UV*) !!$3R  R3&!-(-%Z& "#%(.2$( &&S+,))A!$3R  R3'A))XT$""#%(`$( "      i3+!x== 3 _`        !+3 kk 3 uKJ   F)(GG()F$    %3 3%ww3 3 xy   V^3N^"2767>54&'&/2"'&'.4676762 '&'&547676% %-z35++++++53z35++++++5pWDM69?=;9JHDM69?=;9JHSspsnunˎspsnul}}(.h<;h.((.h; +F$$> +F$H ;<5 A~ ;<5 A+DQ2J (5H,'9,J&0f) T|\`j4OO7g`\|T 'g/& H,9',I4( (3J,&9-H &0f) T|\`j4OO4j`\|T 'g/&J,9',H5(G+DQ2J$(:U$(:U3!'""!'""A''7'753'75377537'7'#5''#5'7#5'7'7<B-DH2#"2767>5!"&54$3!57!#"'&'.5467676#_>I-743TP>CPNDG-2.1/&D9 88 '.* !-8D_2{j@F'%.3r@Md7+4V/2&'&54676762"'&'.546767Zy*,&''&%1]~|45,-++-,54|45,-++-,5(+&a4|d΃fz4a&$(F*.j=3"&'&'&54767>32rJ6464NN4646Jp`684F@NLBD64:866D@NLBD668^~* i654'&#"632327632!"'&5!267&'&#"#"'&54763247632327654'&547632#" 6+Jo.^V|;-˙it36?̺fQMeEJS?(*$ s]vh2K)*NL13^v:Mc*ZeC03N35%&-Kt\K%9S >BWN=!$?$8(F!5{^?Z Q67654 547&'&+327#"'#536767&'&'&5432&5476323254'&5432?-BO>=v06&%K`dC+(k$'eM?$#=Hb B=)+8=.m9eb PB>$3g:84!EB7WPfG+1KHP<Ff#&T'0P+A'<}DC/' 5276767654'&'4rceNS((((`hm@DDF/CD}>C/GFCG !&547>2; !!6P<:! !$ ! "#{! !{54&#">32!5!>??qq>0ţ=as;N_/>!RL}A?rFi:}$:&N?(U?"Mt 6+A]A)9IYiy ]1.+. + !'+!+9*'!901! 4$32%4&#">32+32#"&'32654&'26??qq|=_ky4[\XZcksuD}[X@v hA?rs ?<:32#"&'32654&#"75!5!??qqYe2hvvhDw_X@ϰ?A?r%aVUa/  23/4/3и/4ܸA]A)9IYiy ]A&6FVfv ]A] +  + +,&+,/&,901! 4$32#"&54632"32654&#"7>325.??qq\NN\\NN\qºN w/aTJjA?rZbbZ[bb*= P# + + 01! 4$32%!35!??qqlUA?rv]K 1=++ +A]A)9IYiy ]A&6FVfv ]A]A ]A ) 9 I Y i y ]/9;9;/A;;]A;);9;I;Y;i;y;;;;;;; ]5+ )+ +28+201! 4$32#"&5463232654&'>54&#"2#"&546??qq_TT__TT_⾭vijvkKRRKMQQA?rlHQPIIPPI\vSttSvB>=BB=>B &23/4/ܸA]A)9IYiy ]3'и'/-A-&-6-F-V-f-v------- ]A--]+ +  +*0+*# 901! 4$32254&#"326#"&'4632#"&??qq鿹ºO w.aUJk<\NN[[NN\A?rK < O$[bb[[bb $0Ӻ%+%+++A]A)9IYiy ]A++]A+)+9+I+Y+i+y+++++++ ]+ .+ (01! 4$32!5##7##"&5463232654&#"??qq$ŸuF?@EE@?FpA?r*'$ =$>  767654'&'!5%3!!  '&'&54767̆mommom4mommomP\|~{{~||~{{~|96oooo6996oo  oo6}9:݈@>}~Ա~}>@@>}~,,~}> =6P  767654'&'!!567>54&#"5>32  '&'&54767̆mommom4mommom)4 \=)N=kP`aF7I׺\|~{{~||~{{~|96oooo6996oo  oo6_A.Xx;_x55'(IZV@>}~Ա~}>@@>}~,,~}> =B\  767654'&'#"&'532654&+532654&#"5>32  '&'&54767̆mommom4mommomttLUDWx~zB\RGr=\|~{{~||~{{~|96oooo6996oo  oo6yt'(xrjw_Z\bd @>}~Ա~}>@@>}~,,~}> ='A  767654'&'!33##!5  '&'&54767̆mommom4mommomh*˪+\|~{{~||~{{~|96oooo6996oo  oo6 @>}~Ա~}>@@>}~,,~}> =7Q  767654'&'!!>32#"&'532654&#"  '&'&54767̆mommom4mommomz#G#KSLVAC\|~{{~||~{{~|96oooo6996oo  oo6c ۻ)%}|X@>}~Ա~}>@@>}~,,~}> =%>X  767654'&'"32654&.#">32#"32  '&'&54767̆mommom4mommomllm=|< /Vڵ =|^\|~{{~||~{{~|96oooo6996oo  oo6EKۼ>-O@>}~Ա~}>@@>}~,,~}> = :  767654'&'!#!  '&'&54767̆mommom4mommom\N\|~{{~||~{{~|96oooo6996oo  oo6`E#@>}~Ա~}>@@>}~,,~}> =#9E_  767654'&'"2654&%.546  &54632654&#"  '&'&54767̆mommom4mommoms慄htdthutԄ9tihvvhit0\|~{{~||~{{~|96oooo6996oo  oo6,{{|kl{Eggss\hh\]hh@>}~Ա~}>@@>}~,,~}> =2>X  767654'&'53267#"&54632#"&2654&#"  '&'&54767̆mommom4mommom=|< .Vڴ=}mmlJ\|~{{~||~{{~|96oooo6996oo  oo6DJټ@>}~Ա~}>@@>}~,,~}> =+8Ca  76767654'&'&'"32654'.  735733!  '&'&'&5476767̆mo5885om4mo5885omT,+VUVV++2QPPQΠP3p\|~-,g%&݈@>}~~}>@@>}~~}> = $!5!#%  '&'&54767{\|~{{~||~{{~|#:9q @>}~Ա~}>@@>}~,,~}> =6>7>54&#">32!5  '&'&54767I7ݺFa`Lk=N)\\|~{{~||~{{~| ZI('55x_;xX._@>}~Ա~}>@@>}~,,~}> =(B>54&#">32+32#"&'32654&  '&'&54767ir׸G\\Bz~xWDUL2\|~{{~||~{{~|db\Z_wjrx('°t=@>}~Ա~}>@@>}~,,~}> = '! !335#$  '&'&54767hno\|~{{~||~{{~|  @>}~Ա~}>@@>}~,,~}> =7>32#"&'32654&#"!5  '&'&54767CAVHSK#G#\|~{{~||~{{~|=|}'' %@>}~Ա~}>@@>}~,,~}> = $>2#"&546.#"32654&#">32  '&'&54767PmmlC|=ϵѴV/ <|=\|~{{~||~{{~|+޸KE@>}~Ա~}>@@>}~,,~}> = !35$  '&'&54767>h\|~{{~||~{{~|@fE@>}~Ա~}>@@>}~,,~}> = +E2"&46' 654&'>54& 74632#"&  '&'&54767Yt愄/tԃuhtt-tihvvhit0\|~{{~||~{{~|{lk|{{Essgg]hh]\hh@>}~Ա~}>@@>}~,,~}> =$>%32#"3267#"&'"&54632  '&'&54767!C}= дѳV. <|=Allm\|~{{~||~{{~|Q/=޸JDg@>}~Ա~}>@@>}~,,~}> =  :2#"&546$  !5##7  '&'&54767eddedddB¡\|~{{~||~{{~|>-/#&%q @>}~Ա~}>@@>}~,,~}>uPj !!5!!Pp#@pppt 7%FN4NGuP85 zD<22pJJt '-ZKFGNuP!!u\lE>~~>uu+"&'.546?!".4>3!'.5467>2p4,,$$,,42.p ,.".2."., puP8!5! %JZPJJuP8!5! %JHJJuP8 #3#3#3!!5 xx<<oJpppJJuP8 55!#3#3#3oPxx<<΄ΊXXXXuP8!!5 %JJJPD! 6>l>>PD ! DR>l>>P  BlvvuPb3!5 5! '&'.u$##+* ZJMM*+##$0U%!JJ!%UuP84676763!5 5! u$##+* ZJMM*+##$0U%!JJ!%U0!! ^r{VXeoouP855!Dq΄Ξ0uj%5!!53  !<9h9>uj%5!!53  !<9h9>+Z !73#57!!+ Id&+ъ2&+Z 5!'53#'!!!+dI|&22 !'!'!53 !Odcndh 2 3#5!7!!! ndnd;ch dd !53#'5!'! !]n2n22r-hJdc;dJdd 7!573#5!! !2+2n2nr-hLJd;cdJ<6767632"'&'&'! <'CZmo~yti^Z\X^Vqoti^?)X6nGCZ.//+]Y݀z_X0//+]>Iʞ BP "&*.37#37#37#37#5!!!!3'#3'#3'#3'#<<< 7&#"7'7 !%*BF8WU{FC*9oX:WubP 55!5!!'!XXddPRt '327'' !!iFB*8X:*CF9XUpt>*%&#">7'&'&">327&5467>7tBEH#&NKX$W/,0$" D5Hp*G6$"!0,0Y"W!F&'&#GGCuaP'467#"!4676?'&'.5!3!.5P5#$%"//"%X$# 5eeJ(0Y! "X0(Jet*.'.54?'#"&'2767.'32t)H5 X"$ #0,0X"KN&#EHEBCGG&'&KW"Y0,0$"E6GsPX'<6%"'&'.54676$4676762"'&'&&'.54676762$/+z >_ $#R#af#R#)>xbQu 88RK68# 88  vc<*676767632#"'&'&'&%.5467.546A ''+/54<3o8n23'9%%%%bb%%%&:?$ fLLf#&#/:&'X23X'rr'X32XV2c"'&'.54?654&'&'&#!"#!".4?64/&4676763!23!2767>54/&546767622 Z ;:td Z   c   uu  c  2c"'&'.54?654&'&'&+"#!".4?64'&4676763!2;2767>54/&546767622pW\xj IJ \W   8  uP^'#76767&'&/3#>7!5!!5!.'PSJl..&GG&GlHSi7*nK Kn**7OUnm'66'1U=Hd)dH=#u ! ! j.u-10 3%!#3!Zddd/ #3!53#5ddZd{3 #pph # 3hp&  T&!!T[[ '#'#'##'x\xxjjxx\x,x\ehhP8\xYY73373737+.x\xxjjxx\x.x\8Phhe\x,OlD<72767>54'&'&'&"7#7676767632#"'&ew@RNJV !'7$"!3!&'&'&'!#!2767676wx !1cbbc1! "1cbbc1" `x]\LM&  &ML\;RR &ML\]]\LM&ZwxZQvcbddbcvQZ[RwcbddbcwR[xV''LM\7=e=7\ML'e;6\ML''''LM\6d 8   2@ @@ 00 ]1@   990@   <<@ <<KSX << Y5!!dx yxUZxxu 8   2@ OO __ ]1@  990@   <<@ <<KSX << Y'7!5!'7 wxy xZwxxd 8ڶ 22@ PP_ _O O]1@    9220@   <<@ <<@ <<@ <<KSX <<<< Y5!'7'7!dxxwxxUZxxwZwxxd 8!!5!! s]xwx]ix]xZx]xiu 87'!5!'7'7!5 ii]xwx]iix]xwZwx]xd 8!7'!!5!'7'XiiiI]xwx]h]xwxiii]xZx]]xwZwxd 8 !5!3# Y#xwxݪ-xZxYu 8 #3!'7'7xwx-\xwZwxd 8 !5!53#5! Y]xwx]Q7ii]xZx]Eiiu 8 !'7'7!#3!7'Q]xwx]iic]xwZwx]\iiu 8%77777773'7'7#'''''''uFFxwxcnFFFxwZwxnF,X@,,X ,,X@',,,X,,X@',,,X ',,,X@',',,@,@',,@',,@',',,@',,@',',,@',',,@',',', ,@',, ',,@',',, ',,@',',, ',',,@',',',@',@',',@',',@',',',@',',@',',',@',',',@',',',',@',, ',,@',',,',,@',',, ',',,@',',',@',@',',@',',@',',',@',',@',',',@',',',@',',',' ',@',', ',',@',',', ',',@',',', ',',',@',',','@'',@','',@','',@',','',@','',@',','',@',','',@',',','',pX,p,pX@',,p,pX ',,p,pX@',',,p,pX',,p,pX@',',,p,pX ',',,p,pX@',',',,p,p@',p,p@',',p,p@',',p,p@',',',p,p@',',p,p@',',',p,p@',',',p,p@',',',',p,p ',p,p@',',p,p ',',p,p@',',',p,p ',',p,p@',',',p,p ',',',p,p@',',',',p,p@'',p,p@','',p,p@','',p,p@',','',p,p@','',p,p@',','',p,p@',','',p,p@',',','',p,p',p,p@',',p,p ',',p,p@',',',p,p',',p,p@',',',p,p ',',',p,p@',',',',p,p@'',p,p@','',p,p@','',p,p@',','',p,p@','',p,p@',','',p,p@',','',p,p@',',','',p,p '',p,p@','',p,p ','',p,p@',','',p,p ','',p,p@',','',p,p ',','',p,p@',',','',p,p@''',p,p@',''',p,p@',''',p,p@',',''',p,p@',''',p,p@',',''',p,p@',',''',p,p@',',',''',ppp,p@',p,p ',p,p@',',p,p',p,p@',',p,p ',',p,p@',',',pp@'p,p@','p,p@','p,p@',','p,p@','p,p@',','p,p@',','p,p@',',','pp 'p,p@','p,p ','p,p@',','p,p ','p,p@',','p,p ',','p,p@',',','pp@''p,p@',''p,p@',''p,p@',',''p,p@',''p,p@',',''p,p@',',''p,p@',',',''pp'p,p@','p,p ','p,p@',','p,p','p,p@',','p,p ',','p,p@',',','pp@''p,p@',''p,p@',''p,p@',',''p,p@',''p,p@',',''p,p@',',''p,p@',',',''pp ''p,p@',''p,p ',''p,p@',',''p,p ',''p,p@',',''p,p ',',''p,p@',',',''pp@'''p,p@','''p,p@','''p,p@',','''p,p@','''p,p@',','''p,p@',','''p,p@',',','''p,p',pp,p@',',pp,p ',',pp,p@',',',pp,p',',pp,p@',',',pp,p ',',',pp,p@',',',',pp,p@'',pp,p@','',pp,p@','',pp,p@',','',pp,p@','',pp,p@',','',pp,p@',','',pp,p@',',','',pp,p '',pp,p@','',pp,p ','',pp,p@',','',pp,p ','',pp,p@',','',pp,p ',','',pp,p@',',','',pp,p@''',pp,p@',''',pp,p@',''',pp,p@',',''',pp,p@',''',pp,p@',',''',pp,p@',',''',pp,p@',',',''',pp,p'',pp,p@','',pp,p ','',pp,p@',','',pp,p','',pp,p@',','',pp,p ',','',pp,p@',',','',pp,p@''',pp,p@',''',pp,p@',''',pp,p@',',''',pp,p@',''',pp,p@',',''',pp,p@',',''',pp,p@',',',''',pp,p ''',pp,p@',''',pp,p ',''',pp,p@',',''',pp,p ',''',pp,p@',',''',pp,p ',',''',pp,p@',',',''',pp,p@'''',pp,p@','''',pp,p@','''',pp,p@',','''',pp,p@','''',pp,p@',','''',pp,p@',','''',pp,p@',',','''',ppd?8 !5!53#5!s]xwx]ii]xZx]EiiuP8 !'7'7!#3!7']xwx]siic]xwZwx]\ii 3'#'##-Z-x\xxx\.x\n #\733737#x\xxx\xZ'x\# n\xO'<%"'&'&'&76767327676764'&'&'&pk_V1..1Vbrx`Xk_V1..1V_kpIxXE?#!!';B]YQS@?#!!';BQ9.-\ZnllnZ_.x$-\ZnllnZ\-.)xF!F@RNJV>l5UU5D>/#B0G 47stݔdXЎW37&54'5&'6765!2;#"#!532654&+C6002$'l>>l5UU5D>/#B0G 47stݔdXЎW2  5 1Vd22h' %#3 5' :' 73 ٪L^8bb:'B 7''ٛ>PNq'B '''ٛ>PNq^D'B ''>PN'B%  '''tNP'B5  5''bNP#u  u-3!3!!#!#!5 L3ͨ--Ӫ--333333#######5Ϩ---Ӫ---:k7!!  767654'&'$  $'&'&547676h08rtrrtr@rtrrtr VGFFGrGFFG;:rs죟sr:;;:rssr:Ŭɪ:k3?  767654'&'$  $'&'&547676!!#!5!rtrrtr@rtrrtr VGFFGrGFFGssB;:rs죟sr:;;:rssr:ŬɪKss:k3?  767654'&'$  $'&'&547676   ' rtrrtr@rtrrtr VGFFGrGFFG]x3w32x3B;:rs죟sr:;;:rssr:Ŭɪ3x23w3xuM %' )o& )' )% )JuM327!5!>2&#"!!"&' ;E 2&#"!!!!"&' ;E $;E Ϊ@z٨zuM&#"%"&'73275%>2";EC;EJ綠mzzuM*3&#"&'67"&'7327&'&54767>2";EIq(P >6D;E]InoSu=,HK%)AH!+p$ z1IosV2";E+@/V]H6H\nUm;D [>wfP3,,I6x/Ur]HH]lVzM>wrN3 F4uM!3#!!>2&#"!!"&'732w~9F 9 }9Gr0}}uM+3#>2&#""&'73273264&c)~9GcBnnVs~9F (6o~ç|K|oU}uMp.3#327264&#">2&#"632#"'"&'z;E-8pƖqS;E;DܛWI3>6я]z!zuM 13#64&"327&'&767>2&#""&'˔֐;E]InoSu;EcBnnVszяϐ-1Io7sV2&#"!!"&'73273!#3;~9G9G ūI}ޭ{ tMm-&#"!2#567&'!"&'7327!5!>2";Ed_``!;D ܻ`;`*I6ƌebIz`:H:`*F4uM#&#"7'"&'7327'7'7>2";Exx;EzxXyxzyxإzuM*327#467>2&#"#4'"&' ;E-A 4yy;E Z>Vy|-2PIϼ+zEa82JzuM'&#"63"&'7327&'&53>2";E*y;E\?Vy~+&8'zLFaI1zuM>32&#"#"&'7327!5KL~9GALK~9G⧅}}gkb>32&#"#"&'73275!KL~9GALK~9G⧅}}Р? 5 5FѶeѦ 55FѶ///m' /\& ]'' \'' ]' /\ ' ]N:A%#"'&'&'&#"5>32326#"'&'&'&#"5>32326 5jbn ^Xbh`n ^Vhjbn ^Xbh`n ^Vg@PNE;=LTNE;=KPD:32326#"'&'&'&#"5>3232655jbn ^Xbh`n ^Vhjbn ^Xbh`n ^VePNE;=LTNE;=KPD:327&#"56767326 5jbDS4WVhjbm\Y@/Xbh`ES3VXbhZmMp[Y@1Vg@PD4KUNE;@LTNE4LRN"*,@J^po_N5<#"'3267#"/'7&#"5>327&#"5>32732655jbDS4WVhjbm\Y@/Xbh`ES3VXbh`n[Y@1VePD4KUNE;@LTNE4LRND:@J^T 5!5!-5 !5!uu/0\^ҲЪ~T -55!55!usҲЪ᪪/0N%#"/&'&#"5>32326!! 5jan^Xbh`n^Vf@PD:32326!!55jan^Xbh`n^VfPD:323265-5ian^Xbian^VgsuOE;=LSNE; =KJ/0:ҲЪ !(#"/&'&#"5>32326-5 5ian^Xbian^VeuOE;=LSNE; =KJҲЪ/0, -55!55!us%ҲЪ᪪(/0٪, 5!5!-5 !5!uu%/0\~ҲЪ^6 5 5 -55uu/0V/ҲЪа/6 -555 5uuҲЪ۰/'/0K/& 55p/ѦѶ& 5 5p/om//&' /t&' u{ 5!5 5!@Ѫop9{ !5! 5 !5!@Ѫ555@pNpop 55 5@p pU(".#"#"&'5327>76325hV^ n`hbX^ nbj@TL>7632 5hV^ n`hbX^ nbj?TL>֪VJ<:DNTL<:DNDop$+5!5!.#"#"&'53276767632 5hV^ n`hbX^ nbj@>֪VJ<:DNTL<:DNDf $!!!5!676762!!&'&'&!!C.8d 6WYYV7 e8-;Z{+DD\93[2332[0<[EC,W7!!%5$$}y]]x|W%!555%$}$y|]]W !!'7!5!%5$ZZ N$}qPP]]x|W !!'7!5!55%$ZZ N}$qPP|]] K75!5!%5$!:[]3֪k-QtXVv K75!5!55$%$][:!3֪kVXQ-qK!5!7!5!7!!!!'%5$&`ȉ)P"_=6!:[]ss1st-QtXVvqK!5!7!5!7!!!!'55$%$&`ȉ)P"_=6][:!ss1stVXQ-y:E#"'&'&'&#"5>76326#"'&'&'&#"5>32>%5$ian ^Xbib` ^Vgian ^Xbian g!:[](NE;=LTN9 A=KOE;=LSNE;C E-QtXVvy:E#"'&'&'&#"5>76326#"'&'&'&#"5>32>55$%$ian ^Xbib` ^Vgian ^Xbian e][:!(NE;=LTN9 A=KOE;=LSNE;C EVXQ-6A#"'3267#"/'7&#"5>327&#"56767326%5$jbDS4WVhjbm\Y@/Xbh`ES3VXbhZmMp[Y@1Vg!:[]$PD4KUNE;@LTNE4LRN"*,@J-QtXVv6A#"'3267#"/'7&#"5>327&#"5676732655$%$jbDS4WVhjbm\Y@/Xbh`ES3VXbhZmMp[Y@1Ve][:!$PD4KUNE;@LTNE4LRN"*,@JVXQ-7 5@pppo%5555òi ' '!]#\e#N\#]x#L   !77 ! \ݿ##N]##4 !7 7:\#]x#L]ݿ#\eL#1 4  %''' !]ݿ#\eL#1\ݿ#]j#7P~ % ! !!5 5!3!   7?~% !!3 *^V !!^*  ^V!!!^ ' '!##L  !  ##4%7 7#L4L#1 4  ! L#1#7P~ % ! !3!߆^V ! !! !ECuR #7!5!7Zxx/{xx:xu-R '!5!'xx vx:xH% 7!!7vx{/xxxƪxvH-% 3'!!'Zxx vxx$!%!!W7 r$!!!W7 $!!,7r32 &}f[_ &}f[, %$R/ %$R !2+##5332654&+!ʿ[qrqqϐђАfT$@  $ !? %29999991@&  B  $/999990KSX9Y"@&]@Bz%%%&'&&& &66FFhuuw]]#.+;#"&! 32654&#A{>ٿJxn?M~hb–m؍OH#(07#5#"''7&546;7&'&#"5>327354326=-?\g`n;) T`TeZx_958>cc3Vfa<}NV{ E..''rOs+Ax.ٴ) 3{ B333#;#"'&'##53w1ѪKsQ fև3͏oNP r>-!#4&#"#3676323#d||BYZucce22wxLj%3###3!E3A1wH33 3###%̟8ǹiEL#\ !!#!5!sP=g՚oAX` !!#!5!qjLl}e`R%h%6323#56?65&#"T^\Ѩ1<-M21]@/2UPn44%q!#3!q"9`!#3!W`3ph '"27654'&'2#"'&7673=A__UVF6˷ȅeB:VVMpˑRh]p[mNssg.q $@ E E1@ 0"32654&'2#"$54$,,g}ss}}ss}s+2@ -! ,221@ &,046$32#"$&%!327676%!&'.#"s~&&~~ڢ~YNwwk]~Nwwk]zz❞zzIʑS`0aJɒR`0aIs"'I@"$$#) #(229/<21@"#!%(22<2046$32#"$&7)6&')s~&&~~ڢ~ & \ڵzz❞zzI!!t!!@5 c@    1/<990@    BKSX@   Y"5! # #7!v(vuyTW+FC8 c@  1/2990@    BKSX@   Y"%!5 3 3!kxqF2@j@    <<1/99990@   BKSX@   Y"! !7!5 5!WXwk/+W(L? #@   1/<<203#3#3#zD+h)h9(EP #/3H@5E1-0 !'E4<2<21@300* 4*$49/02654&#""$54$322654&#""$54$32!!,,,,7`s9448844994488449\}:@   22221@  /<2220!!!!!!!!5!!  AuAd9\R T@    291/<0@  BKSX<<Y"!#! #!&,Ps՚vO~ -@   <2̴? ?]1/03#3#3#QI\R T@    291/<0@  BKSX<<Y"3 !3%!cTsOvs+7@ &-& ,9/1@ ! ,22046$32#"$&767>54'&'&s~&&~~ڢ~.]=@N\N\.]=zz❞zz}qa !SM!R}|pas?#-n@.  '&$ /$ .9999991@ .'& ) )./9999999046$327#"''7&7&#"4'32>s~&Ġn~ڢĠnՑꏧw֜\w֜\zvijޝzwkj!^`|g^` .@   <<<2221/03#3#3#3#):@  1/<0@22 # #3.]F; -@    1@  /<<03!#!#!"9q><@  9/1 ]@ /<220KBPX@     @     @ Y333 # # \Xds3{ 1@   <2<2??]1/<2<20%3#3#3#3#\ 7@  91/0@ BKSXY" !!!!&TdD՚ohh $@    1/<<2203#3#3#hhh0o !@  /221/220!!!!5!!o&.-ժo1/,@! ',01*$ 022122<20!"'53 !"563 676!2&# !27# '&%4rmyymrO4%%4Trmyymr4*B6!*:'(8) 6AB6 )*!6oP@   <<222<<<<21@   /<2<<22<<2203!3!!!!#!#!5!!5!!n""xxyyrr3@21/03!!!ժ,o7@   /<<2<<21@ /<2<203!!!!#!5!!5!CCPPxyr7@ KTX@8Y221/0@ 0 @ P ` ]73#3#>@ 10@ BKSXY"47!5!32654'3! $x˿ßwNetwc #/9@1E- !'E0<2<21@ 0*$002654&#""$54$322654&#""$54$32,,,,PIIPPIIPPIIPPIIPs'(@ ) (1@ #(046$32#"$&732>54.#"s~&&~~ڢ~\ww֜\\ww֜\zz❞zz}``}|``s,P@  ! #.# -9991@ ! ((-99046$32'#"$&73277654.#"s~&&~l~\wj\ww֜\zz➞ikwz|`^jI|``; -@   1@   /2203!3!#,dq9d (@   <<<<1/03#3#3#QIh ?@     <2<2??? ]1/<2<20#53#533#3#3#h+Is'+>@- )(( ,9//)]1@+(#,046$32#"$&732>54.#"3#s~&&~~ڢ~\ww֜\\ww֜\zz❞zz}``}|``s>,P@  %$#& !.! -9991@ #&$%((-99046$327#"$&732>54''&#"s~&Ġn~ڢ~\ww֜\pw֜\zvikzz|``|?l^`sr%1=G@8&,20><2<21@/; 5 )##>9//0! #"&547 !&54632! 32654&#"4&#"326sS_  _mz,,,,,,,,gs'O;H66H;O'sz<11<;22<11<;//d #@   <<1/<203!!#!5!IIjk=;;sr3?Kf@F4%+6:0L2<2<29/<<1@=(I C (7##11L9///<20! #"&547"333###3&54632! 32654&#"4&#"326sS_ ̻A;z,,,,,,,,gs'O;H6ߊ6H;OO4z<11<;22<11<;//;@   2<21/220]!!!33##!!!>ժFh";@ 1/<0)3!3;+y=@ B <1/20KSX@Y!# 5!!!8ks#O@%$!  /<<22<2<21@  /<<<2<<<2032653#2#4&##"#3"3ʊyʊy+VVF%F.@ KTX@8Y1/0!##u-s+f@- ,&'  #+ /<<<222<2<21@+*   #*'"/<<<2<<<29/<205!5"3332653#!!2#4&##"#35ʊAyʊy>FV>=VF=6-@ 1/20!3!3M-: #'+/37ڷ/$0(7,48<<<<<#+ 3'<<<<< <<<<< <<<<<9̰XKRX8K bf TX30<32#4&#"#9`M1Cuȸ||MM 7BuƸ||e,'"xMfca?'Gzed\V5<!"'&76763!!32653#5#"&5#3!#"&5332765!"3ە^SWsv||CusCuȸ||WVۃ^SBWLa{fcBVfcf__{{V H!&#5#"&5332654/&763!6763232653#5#"'&=4&#"#9`M1Cuȸ||MM 7c%Zk>8nClbd||xe,'"xMfca?'Gz2XO{fcx{䟞[t`&V 332673 &Vv aWV` v ޞKKJL[`&(SN~`6@  F991B /2<0KSXY%2767653)5!3$Wq2!dj±/8s4tVg` ##4673>=3|u˷d7<T "yX`#!5!e/я`!#3#4&#!5!2snJvy–X`35!26&#!5! #X-뒦yX4=!3!#T\[CLzl` 3!2%!4&#!Wn`–X` !#4&#!5!2nKy–X`!#4&#!+5265#5!2nã rLy–a;- 1 <05!3!----Ӫ&$&$&.&.`& u`& `& \X`& BCZ`& Xh`&d`&Q`'ZX`&`&&Q`&ZXV`&X`&:X&X`&%X`&X(`&Vd`&Id`&{C!`&!nV`&"X`&#I`&$`&%<t&X& X&d&X3>=3##67'#3x]GgG.i=dB`ԛ":T)C '9n '9 X& ~X' 'n ' X&c ~X&c 'n ' X&c ~X&c'9n'9&L~&L'n&&cL~&cL',n&,0a&,+p~a&,+p'x~\F&x?&,~ x&>'xx\F&x?&,x x&> (f'; >f'}>\/& 8>>/& 8 (f'; >f'&8\/&88>/&8 (f'; >f'2>\/&8>>/&8 (f'; >f'2>\/&8>>/&8 ' ? ~& /&?,> ~/&,>)7%#"'$47332767654'&54767;#"'&/cͷ?Ahž#62 #dGG&+@XA:g!axLQ 6r'_>X %+53276=3+HZ#c,1VV,1jٻ~X%+53276=3;#"+MZ#c,11,c7nVV,1jj1,JR X&uc~X&vcPT,l&IT,PU,i,k ;#"'&=3!1,cK\WL71,\W+PV,PW,l'W,IPX,l'X,IPY,l'Y,IdZ,l'Z,I<[,l&I[,U/'\5&\l9']5l9&] @']>Q 6&]>l '^5l &^']>R& ]XD&u]+p~&v]+py5 3;#"'&1,cKPWskj1,\e'9n&9X&~X&'P^&^ 'n &&cR~&cR'n&&cR~&cR (f'; >f&\/& >/& (f; >f0%3#"'&'&'!27# '&5767"#"5$3 "(1{R=IrbJIԖ^` __&m3HZdP^vc–e4)?6 [_w\/&'&'&5672+5327676SSgURHKLXJKݣdht^#4b4bBPH:jV>/);#"'&'+53276767&'&'&5672~AI2hrBV~(;E)Kݣdht^eSgURHK 4b)N"w6a.%PH:jV# ('?; >&?\L& >L& }R=}GR &'3;#"'#"'532767654"9aRQS,cKa].-fgsT!"#?zNuIS,!&* 1p*D}'E=}G&E b&? ~&3;#"'!5 767654x I*eK2D0# &pgM,>ꅗ:H~ b'q ? ~&q A GF%7653323;#"'#"'&''&'#&'$473327676'&/3N0%@nS,cKvDm% I01_@8'TPxmil_Qb_y^@@$:|_2&aS,`[ F{GHܳ&%0l}=J<~ 1%+53276=3327653763#"'&'#"'&+8LcKc,P,+hm,%@n\Kf%#?70`DAbH<;!.,Pd@dczg2&q\ =!1(78#"'&'#"'&'+53276=3327653763;#"'%#?70`DAbH<)+8LcKc,P,+hm,%@nS,cKvD =!1(I;!.,Pd@dczg2&aS,`Z ' A G&  & 7& C <I)"'&5#&'$47332767654'367676;#"/"3276'&'&u&4-JXPxmil_Qf[+!' (s{lHX}a*=RKgL~큻%MGHܳ&%Dl7(2l^F"%GMF ,\v7Ql?[F2 .327654'&#"!"'&'+53276=36767632Ш큺%0LJNA'fKc,P-e_KUskl?[F*#=,PdrNP2T?!'Dmx+8)"'&'+53276=36767632;#"/327654'&#"JNA'fKc,P-e_KUqm*=RKg਑큺%0L*#=,PdrNP2T?!'DKH ,\vl?[F ' C & 2& & E))5!3%632;#"/%3276'&'&#"@o\Dui*=RKg큻%0Pz\?c!'EMF ,\v?]DQx %3276'&'&#")5!3%6329큻%0Pzu \Duiʸ?]DQx\?c!'Emx))5!3%632;#"/%3276'&'&#"8 \Dui*=RKg큻%0Pz\?c!'EMF ,\v?]DQx'RE&R&R&Ru *Gu %+! '&7.54762;# '!2764"[b=D}a_[9^DU)k_1ocz2t*n@00@p[C+ @Mkl=v8`3$*727&'&5763"327%+5SF7J \X];d}M4F!Ť$/%+532767&'&5476762;#""654'v`kB;(aD hYYh MXD=p`vʨ4/gg/($'UZ'-)74--47)-'bM,(U __ u F'wGu L&F&wL&'~\L&?&~ ~&kG'R~ok &k?&,~ ~&8L!D#"'5327654'&'&7676'&'$54733276763;#"'J&P DfXRNB8D-<9_h$$EB|=Q#!v+6(  %{{qe))5!27654'&54767;#"'&/66-62 hGG&+@XA:g!a_h$$EB|=Q#!v+6(  %?+)x.M#$%653;#"'#"'$&733276N1,cKpNyUcE@A(IPmI~jkj1,3.(B"[\ss~B"5 +5327653WPKc,1se\,1j%+5327653;#"SMKc,11,cKVV,1jkj1,^Ngt5%327654'&'&#"#"'&#4763&547632;#"bzL,5;(.;D K2KxAZM\HT((&iK*9:X DD(PNNOmf7*(?$GC,,m$%#"'+5326767632%327654'&#"dan@ht4W^Q[a>/4(*X.[4fb0G1P8TYNE5EK&)/4:''5)24fb0$#1P8S1>,E5EX !a%H'?  +&r?&'R~'RP^ $&'&'&'3;#"'&'#"'&5476 xRot$8pKZI-&8:m*12e CY>)2'+eO,3;I0D-=67654'&#"27&'&5476&'5#"'+5327654'&$"':A4N--0M,Q@(Jxb 41}! @H=.%4-+#%v iEN@TSZ 'D49g=ql)D%'i.C!v-3j  ;AWE L9P)8K6(S/VL_+Y9K1\SJR765&'&'&54767632;#"'&#"#"'$4733276L[/,4PT*uW ##rpl$-AIqYhu?AB[M!3!+ (;=A<^ĸ#0{bV` )gZZrN J' R '  X&uc~X&vc.&\,.&\,&],&], &^ &^T#"'53273676537M͞jK`Uq%BUG FA+7T#"'5327367653;#"'&4;IʡjK`Uq%"@Pif<[A FA+7DT)TL* 35'5467676?67654&#">32,X\"$߸g^aOl39ZZ8L{4<+VZ@EL89CFnY1^5YVe !5!5!)5!S2SR7'XJF: 'bI:= ']IC; 'J<b= ']bH'I&I'IIH'I'I'IJH' 'I'IIH'I&I'IJH'J'I'IJH'J'I'I H&I&'IIH&J&'IIH' 'I'IH'J'I&IIH'J'I'IJH' 'I'IJH&I'J'JIH&J'I'JJH' 'J'JIH&'I'JIH&&J'IJH&'I'J H' 'I&IIH&J'I'I H' ' 'IIH'J'I&I H' &J'IJH' ' 'IJH' 'I&IH' 'I&JH' &'I H'J'I'IIH'J&J'IIH'J'I'I H'J'J'IIH'J&J'IJH'J' 'IJH'J'I&IH'J'I&JH'J&'I H'J&I'IJH'J&J'IJH'J'J'I H'J'J'JIH'J'J'JJH'J'J'J H'J&I'JH'J'J&JH'J' 'JH'J&I'I H'J' 'IJH'J'I'  H'J' &IJH'J'J&J H'J'J'  H'J&I& H'J&J& H'J' & H'&I'IIH''I'IJH'' 'IIH'&I'IJH''J'IJH''J'I H'&I&IH'&J&IH'' 'IH''J'IIH''J'IJH'' 'IJH'&I'JJH'&J'JJH'' 'JJH'&'JIH'&&JJH'&'J H'' 'IIH'&J'I H'' ' IH''J&I H'' &JJH'' ' JH'' &IH'' &JH'' &   3%!#!! !Y9w\{8q d+_N  %*!2#!327&#363&#!3654/654'f;33;$ $#>]a{w DD663! )327&#!36'hPcp~qAA k{qS3%!!!!!!-x9vq dddsd !!!!!#3#oQn.ddqs&&$#"32767!5!# !2deVRuu^oRaG@;@&5dSUmnHFcIf3%!#3!53#.nXddddq dddd fY6765%!#!53265-V?O?nqd J^ dd0 !3 #!3pdw@1q 2 !!!3ddo o !#!! !3!3_Gbn}qR+q  r'( ! '&76 7& 676'&&:żGlllli$ #ab2222jT%%5$c$-6&/.4%&  %5 64&/.$ Pdo&nŢmngzoʷ-[ʚ)'NXd''pui$2Xf| / 3%!!!!rpq ddq $!&%! 65! X!!Y fqba@`|gd5\*$ 3%! 3!dq d+D 3!3%! ! 3! !D5D:9:9d|q  d+l 3%! 3 ! #(\~vbL:H|dq d22{ 3!! #3ndp29V{{",34&'3!5#"&5463!54&#"5>3 5!">76a=Kd?`Twj6/^;:5Czӆ]YfaH..t''UNHGgwt-!>32#"&'!4'&'676763&#"327N:||:^,<<,9RKM_]daadt= z =OsKTdihtJq{#%#"!2&'&#"3276%M]-ULEmGJXHCQRHV,${z$d$$>:##dWS%&-!!5#"323327654'&'&#"N:||v9,<<,^(]_MK^daDDaZKsO=  =Td6Jthio}{!327# 32!.#"}K_mk)#i̩J@b]u-)8 CqzӾ/ 3476%#"!!!#5354763g.9:9|WX -8J_D8d97ddddTVqV{#.=65326=#"325!!"&32767654'&#"jlQR:||:Nry^,<<,9/KM_]=ʌo,*qdaDDad-w=  =OsKihtJH "34'&3'!>32!4&#"! GS5‡OIƁkk h@[:Lded\ПU5 33#!!JKOhV #676#532765!3#%G(=1l$%OQRaеT0Hd01``2 !3 #!3OHіmdi#L&5#"'&5!3J=(G%RQOLiH0T0Z``~J^d{"&1<!>32>32!4&#"!4&#"!3%34'&%34'&OIƁԝTށkkkkd[ GS5 GS5`edJv\П\ПUh h@[: h@[:H{ "34'&%3'!>32!4&#"! GS5‡OIƁkk h@[:hded\ПUqu{ #2#"27&"676'&s3x33x3d4'pp'3(pp({98  kp-$-R-ۀ-qV{-%!!>32#"&4'&'&'676#&#"32N:||9,<<,^؆]_MKdaaKsO= z =oHJthiqV{-%!!.#"326476767&'&3632#"N:||v9,<<,^(]_MKdaaKsO= z =oHJthi{3'!>32.#"!N:4I,hdfc˾zo{E67654'&/&'&5432654&/.54632.#"#"&'i'K&'q4=B%%U+.39GSOjqL4vfLJ\_opPx3Zl=vf03"3;@{R?Bsl37'*7CoT78^UNO,, z1$YXDL#/%%7%&7#!!;!"&5#53*\{KsբjU|7N(dUNdudTD` "%&'&5##!5#"&5!3265! GS5CIƁTkkTS hl[:hded0=` 3%! 3!YT^^d\hdTV`3!3%!!3! !bTNdhhdjjjL` 3%! 3 ! #U|p|[hd-s=V`7%! 3+53267>^]_lP|XQ+ۙdi8{dCYXb` 3%!!!5!\vwhddhdd @03#u)@ dd1<20KTKT[X@878YKTK T[KT[X@878YKTKT[X@878YKTX@878Y@````pppp]3#%3#^ys@B10KSXY"K TX@878YKTX@878Y@ %%6FVjg //]]3#7Ju@!  VV 99991<2990K TX@878YKTX@878Y ]'.#"#4632326=3#"&9 $(}gV$=09" (}gT";9! 2-ev 3)dw @B10KSXY"K TX@878YKTX@878Y@*$$5CUU//]]#ę1w@ 91<90K TX@878YKTX@878YKTX@878Y@ //- ]3#'#Ӌ1@ 91290K TK T[K T[K T[X@878YKTX@878YKTX@878Y@ "  ]373Ӌ 9 #.#"#>32v cSRav 6978w{z9 j@ VV120K TX@878YKTX@878YKTKT[X@878Y332673#"&v cSRav 6978w{zfGd10KTKT[X@878YKTX@878Y3#@1<203#3#䙋N#!#ęę53#73#'3# 3#3#'3#}}d 3#3#'3#}}d3#3#d 3#3#3#3#dd&;#"'&'#"'$&733$767654'3F??7KXu~Xv\,>%!$'$&73!2%7&'&547676323!!"'654'&'&#"xhn}@AQ+"R:4RQP ioh4"(=)1$+<'g\^sM6,|y$K2S%jAzG' <8BN?0654'&323276767'&54767632#!V)B,4((7(*HTO<?aNbNLZB`.NJ|m+M;3*)3P& ]027EW4,E$2Hf3Џ,' !5;#"'+5327&'&54767632"67654'&'&f$'و'$A??8 D?$ 9P2*I1C299(M.L,0W 5+5DE2.4! k .@%&'&'&547676323!!#'$'&5473!2766'&'&#"B.y9()Wp8c20-=^E>><l/"'"3 9Ld/  #+m=E2X:zFNV}`kL:DbZzWK# :<,; ? &R~&R %4'&"2>"'&4762<R8R8z?@?@@?@(8)*8@@@@@?? ''&'cRP~&'cRP' &cL~&cL >&]8\K&]X>K&]X >&?\F& >F&  >&\F&>F& >&'?>\L&'8 >>L&'8 3_+ 5__bV'J@!B  6991/<2990KSXY"]33+532765#ոRQi&&}``01}` 2@  F <<221/<20@  @ P ` p ]33###53ø`<ĤV.` 54!333##"3276!5R w{i&V`p?`3A0c3'q=Ua4'q[^3'Pq=cZ'dUcZ'dUaZ'dqaZ'dqvj 3'\q=cZ'bUvj V'}\cW'u|vj0Z'@d\c:'u(Dcm:'Duvc u'uvV Y'PpVZ'PdVZ'PdV'Pc['uPj&Z,,!!,,O=32653#"&[hq`=QQ, &&_ &3;#"'!5 767654x I*e2D0# &pgM,>ꅗ:H~#'_`'_S'_SF'_ 8@'_+ 'cu~@'_+ 'cv ~r'_>9 9F KSKQZX8Y1/0@  @ P ` p ]3;#"&5Li a^q%qq/u `&JOw`73#!!dž$Nd`Vw`#676#732767!5ʆ#5H2K1i0/N)deеT0Hd01``vg`'`&3#3## !#3!53#^ժ ?!5 ?8'TXZ8 U'UXZ8'ZT8'WXZ8 U'XXZ8 'Z,W$'W]$'X]N333N%3!533yոBy)533ysոBq 6& #" 3 *NYh> é 6& "'!53&54 3 *NNJhh> é! 6& &54 #"'!5 hYNJ>z=x )33!x³j*]Qix %!5!33xtj³瓓]Qi' #5!33j³]Q=q) #33mCq"q )5333!mm"q)533#mOq )3!33OkUq""Oq )533!33OιUΓ""q )533!3kιU"Oq 35!!5!3ΓK"Oq #5!!5!3ΓK"q!5!!5kqKq!&'.4> !2>4."RJr 惃sKR9[ZZ 1ũbbŨ1 p`88`p`88!#5!&'.4> !2>4."RJr 惃sKR9[ZZ{ 1ũbbŨ1 p`88`p`88O#5!&'.4> 2>4."RJr 惃sKRQ[ZZ{ 1ũbbŨ1 p`88`p`88O 3"3#!5!>k fO 3"3#!5!>c f 3"3#!5!pk fq!!!##"&54632!354'&"3.C^v ]8m;7^<֜f"qɃ]8j\D?##5!!##"&54632!354'&"3BC^v ]8m;7^K<֜f"qɃ]8j\D?!#5!!##"&54632!54'&"3BC^v]8m;7^K<֜fqɃ]8j\D? 3!!!!!55Փ/ #53!!!!!55B/D )53!!!!ys55B/= !!5!!5!355ߒѓ #5!!5!!5!355ՓLѓ )5!!5!!5!,55Lѓ !!27654'&3!23,R4,,=ٹUiXO]Oz}I_"_Ҥ#533!23!!27654'&ιUiXO,R4,,=B_Ҥ]Oz}I_ !!27654'&533!2#,R4,,= ιUiXXXl]Oz}I_"B_ҭ!4'&'5!!5Mc4B_9V@9#5!&'&'&'5!! 5Mc4BX]9V@9$#5!&'&'&'5! 5Mc4B X]9Vq=!533T9 #5!533hՓL9 #5!53hL9+#3432>3234&#"!4&#"!}x5%^qZHZlK--Xh|ŕnc%#53432>3234&#"!4&#"!}x5%^qZHZl[K--Xh|ŕnc##53432>324&#"!4&#"!}x5%^ZHZl[K--Xh&|ŕnc= !!5!3!!!KK?#5!!5!3!!!KK? )5!!5!3!!@KK?=X%!!5!3!3!!!=KøL??X#5!!5!3!3!!!%!KøL=??)5!!5!3!3!!!0KøL=??Oq 3!3!$Uq"KOq #53!3!$U"Kq )53!!kUޓK=!!!tFs0hB~ !5!!!tFlhhB~B!5!!tFlh0B~B+ 327654'&+!!2/!m]%i ; @ED\qQE=4."RJrCEoJRXErrJS9[ZZ 1SV/ { 2Ʀ1 "p_88_p`88*#5!5&'.4767675!5!!2>4."RJrCEoJRXErrJS9[ZZ 1SV/ { 2Ʀ1 "p_88_p`88O(#5!5&'.4767675!5!2>4."RJrCEoJRXErrJSQ[ZZ 1SV/ { 2Ʀ1 {"p_88_p`88Q !!#!3BQ #5!!#!3ԓ} #5!!#!+Q !!#3!3OQ #5!!#3!3ԓ} #5!!#3!B !!!5!3z;  K"qѓB!53!!5!3z;7 K"ѓm !53!!5!z;7 K"ѓ+q &2>4."&'.4767673! [ZZRJrCEoJRXErrJS"p_88_p`88~ 1SV/ { 2Ʀ1  (2>4."!5!5&'.4767673 [ZZlRJrCEoJRXErrJS"p_88_p`88 1SV/ { 2Ʀ1 O &2>4."5&'.4767673!5 [ZZRJrCEoJRXErrJS0"p_88_p`88 1SV/ { 2Ʀ1 {q*!&'.4767675!5!!!2>4."RJrCEoJRNXErrJS9[ZZ 1SV/ 2Ʀ1 "p_88_p`88 ,%!5!5&'.4767675!5!!2>4."RJrCEoJRNXErrJSQ[ZZ 1SV/ 2Ʀ1 p_88_p`88O*)5!5&'.4767675!5!!2>4."0RJrCEoJRNXErrJSQ[ZZ 1SV/ 2Ʀ1 p_88_p`880](_<55& r Um Q rZf55q=3=dd?y}s)3s\\?uLsLsyD{={\{fqqq/q999qqJ+o#7=V;=3X55^R\sd5^5bs#5`b?yyyyyys\;\\\3 LsLsLsLsLsLf {{{{{{{fqqqqq9999qqqqqqH==y{y{y{sfqsfqsfqsfq)q3 qqqqqq3sq3sq3sq3sqTx\9\9\9\9\9r\9?uXu9uuFLsqLsqLsqs/qJJJ+o+o+o+o#7#7#7DV={\3X{\3X{\3X/ }}ssfq3 }qqLu3s~\ 9 =LsNgvsq7E+d#7#7N={\3XTT\h3qT]hX\] ` d <qKsday{\9Lsqqy{y{{3sq3sq?LsqLsqTX9 ` d <q3squy{{LfHy{y{qq\9\9LsqLsqJJ+o#7,Gqqq{\3Xy{qLsqLsqLsqLsq=79qqy f u +o3XPP}  yq\9@sq J qefqqqqq|SA4Pq9qq q``9t*KL:+#qqGpPPOJI~>t+o7#7#7q=V=f3X3XXmXXXXLsPqq;VVqXXqvqq77:7/ <66O<u1ufu]G^G 6&:uuuuuu  3s3soouuuuMLhuTzuuuq7]yq U zw(j#Lcxhc+qc3x+x.pppp*pw::efqesDy}uy{\Ls\?yLsLs{=LsN\Fqc<Fq qSZkq=xJvkqJqqdGp;GpqqWWGpAOpLsq0q@GGrwxssFqU-~Od$s6sq,J7Opfq9Lsqs5UsssJs\\\T\J#y}}@e(!TLss#y{=6|<}o{p4kq5FA33L ;q;fq<=p;rR>Qdqtqq/4dq+o9998L07/3=;xs*` D3 GLsk7sS[2Lsq@R2@R2s<qsq pv9xssfq;XXX.j}!&4fG8=(5F!A!=2*IS^s6qsfq;=={=;yt|||\(5F?56].I6r|29y{y{{qLuqLuq(5F!ATX33LsqLsqLsqodq#=#=#=|uQfGs8{=;{=;}q -qn6.3sGq/STL&tuA&7\\S&esR\Lsuu^x"6^Zq"qDq;' qqF92 F &q/qzw`DDcc/NDdc\\fcXCX.X0.XsXXEX.XXN*CCMXwBS(?99l9lC91***}} ffuuXK5k1CCOOLLLRLLLLLUL<L<LdL\W5kVz*******KKK))*CC1LLLRLLLRLjLL<L<Ld9qd==;;q;q=x==D=;==p==q==.qqB[B[{d{d7]xlxr[")>WE_HHY"~h~h@rx2NsN~sxMn`P{P@@@@`NzBza\d>N c c]ccY]dji:~:~PZ"ZPZ|ZPZ}PPZPZXZPPP|ZPP*FZnP\ZZZFdZWPPWFZdZddDPGd.d#ddadd%dvd-d/Cd$d/dWd/?d1<Nd/dBd/d-d-d/d/F.Z#d{ddddddd.ndmd?dndyyyy'''''w'w'ww'w Xc^c^%H Ewyyyywwwwwwwwwwwwwwwyy^^^l4wl4w4y4yywyFFFF*F*F*FAA8F3F3FFFF*F*F*Fzzwuuuw.wwuu&w&w&wwFF wwwFFGwyFyFFwFFFwwwFFGwy=Fy=FGwGw=F=FwFFJFFFV+V+FFV+V+VY]YFFF"F"F"F"FGFGFGF F F F F wwWww?w?w?wYSSwSwSSSFFFFYwyyyyMMwwdwSSyy4yFwwFFww```````FwFw     FFwwFF%w%!%!%w%w%!%!Y )#su` z    = {>fq$S9( 3qfyqyqy3/qqq222</=V3X5x=2ZLr u//SH||NYHG p+"M"M>G/Mmu>GVGVGTR>GnzhuuEuOGGOGOGmu\#=nnuV&7yGSG%nzu=nV&7yGSG%t9>GGGOGT_>G=nIzIIVz[quuIuEqOGOGFK\#^YGu@zV&7~77#7OG[[[[BBy{}}}sfq)q)q)q)q)qqqqqq/3sq\9\9???uMuMu9u9LsqLsqLsqLsqJJJJT+o+o+o+o+o#7#7#7#7y=y=DVDVDVDVDV{=;{=;={\3X{\3X{\3X#V={/y{y{y{y{y{y{y{y{y{y{y{y{qqqqqqqq\Z9D\9LsqLsqLsqLsqLsqLsqLsqNgvNgvNgvNgvNgv====FqFqFqFqFqFqFqFqyy'iSSSSSS0l7hx qqqqqqoE.k_FqFqSc<qqFqFqFqFqFqFqFqFqyy'i7hxk_FqFqFqFqFqFqFqyyy<pr\\D~{aNsVddddd%%%%9933W q q(()((()( 33?nn=V`Jd=n=n8N(ffadp5Wnz5?5f5\5l5Y5S999og0u5W55^5b5?5f5\5l5Y5S999og"MVGOGuVGVs`u .;F_( ..D]1u!===&C&Cs#&<<oI H#;jDN hR6nLsbBSV,y('y\XNND?yJ\}WJT9hgd(V FhZ $<|3uuWZ[O=;6Q^^b?fbfl\bya W{=w= =us)9~=}== ]=;;;9fqq y) ysedud    du,dudududvdvdd*ZZd-Opdduudwddxvxddddudud  dududuku7^H^^^@^^^uzz^uwududdud7u7y#hZZ,dVD===j,,ff+uPuuu+uPuuu+u+u+uyyy``**yyby* a aXXJr;xxdxxd++* 8 8 P 8 x PFq 8#+7',,,,,,,,,,''''''''''''''''''''''q''''''''''llgg'''''''''''''''''pprppppppppp7p7Tpp''''3'''ppppp'''',h,d,,,,+,}}_}} ,,,B,d,,,,,,,,,,},,,dZd2E\,,,,,,,,,,,,,,,,,,,,,,,S,,,,,],,,,,m,,E,,,,A,,,U,,Q,0,,,U,,L,0,C,,X,,B,,X,,,x, ,,,,,,,,,,,,,,1,,,,,,,,,,,X,X,j,, T},y,},),,,,,d %6  dT VIVVx+5X3ppppR >pTVSTWW/V0/0002p@TTTTpnnTVaaTT,f,z,z,z,z,xNNx>NnX~#9Uwlf,,,,,,,,,,                    uuuuuuuuuuuuuu++<uususs[YOO Bu xd xu xd xd xu xd xd xu xd xu xu,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,duwOwO::: u+u+u+u+u+u+u+u+u+u+u++u+u+u+u+k  77^^  7^uuHH''''$"u 9 u H#?{\3Xh<Gp,qssu@xC@~yyv{\{\ssg)?>8{\(oo:o\:o\csssss$d{=syNsNs6@s=q/ / ///}/o } <^VN1X?,XXuXXeeeeNNN>XCXQ~XwQ"XTXXXX,X6TC"Xe.>XTXTX:j:j:j:j:j:jKH KH ************jj))k))k":jC:jXXXiXXXXXXXXXXX9p9lpl"9lplC:j9p:j1J:j:j*********}3}}3}jj 3# 3#  f^f^uBuuBu/KH 5kk kpSI:j1J8"CC:j..TT4,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,c3s$f"=3LrDrl{fqo/q5 "qqq+o7=HVhL=Xs N:jH k :j:j:j********_9xxxxxxxxvxxvxxvxxxvxvxxxx,p:jj9Jqq9O99:::qd=dd=;;;;;;q;;;q=xxx==D=DD;;;====p==q======...qq< 0 $%*K-r294K7D9:;< R&Y\99999 &&&&&K&D: $$$$$9$&$*$2$4$7a$9}$:$>?@<@<@ABPChDDFFGHIIJKPKLLM$MN0NO@OlOP$PQ|QQQRRSS0S`STUUUUVV8VPVhVVW|WWWXX<XlY4ZlZZZ[[[\\]]4]`]]____``$`<`T`x`bLbdb|bbbc chdde e,e\etffDfpffffgg,gDghggggghh,h<hii4iXi|iiiijj,jPjtjjjjjkk@kl lllm m0mTmxmmmn$nHnlnnnnoop$p<p`pxpppqdqrr<rTrlrrrsxtt@t`ttttu|vvvvww(wPwhwwwwwx$xHx`xxxxyLyzz4zdzzzz{ {8{P{h{{{{| |0|H|`|x|||}(}~~ Dd`l$\(< hPLd|$h(dt@l(`4 L$4Ld| ,Lt0H`x0H`xL@l(@Xp0H`x 8Ph(@Xp0H`d`(@Xp0H t| x`D\„`Ŕ,ǀ` ʴXẍ̘ʹ΀Ф@4(Ӥ<\llLtD۰D݀,8ߠ,,`T@0\\l< @Tx P$h(8Hl<<$4Pp\Hd X  $  P    0   `   lt($  4D`$8Lp(x8h| 4Hd @Th|$DdH|  4DXl|@hh(<Pl8h   l     !!0!L!d!|!!!"@"P"`"p# #0#@###$$$4$D$T$$$%%&T''('L'd'|'''))*0++,--../ /0/0|0112H23<3456(666777478l8999:P:;p;L>?h?@T@A0BBCCDdDEEFFGG,G<GLGH(H8HHHXHHIPI`IxIIIJLJdKK K0K@KPKLxLMMM0MMNN(N`NNOPQTQR(RRRRSSS S0SThTxTU,UUVtVWWXlYYYZ|Z[<[L\<]]p]^@^_(_____`<`La4aDaabXbc@cXcdleeeeftfg0g@gPg`gph hi0iHi`ixijpjjk<kl<llmmtmnDno8p$qqdqqqr4rrs st4u,vwwxyydyzzz{{,|p},}}~T~(@d|hH< l0 <L0t@| \@Xp pPX8Ht @dt$4Ld|(@Xp0\ ` ph4L8pp8DTP40x|p\x@P,<@xldxTHXDdt@P8øL$ŠŰǐǠȼ<|ɸ(|0˰@P̰$Pl͘X\$ЄаPHҨ dDԔ4ּ8<؄ـٰ٘0ڌڼ,ۜ۴0H`xܐܨ(|ݔްߌߤ($0\t@h,4H\(((x$d $<Tl4Ld|t$<Ldt4(8H,Xl,Px 0t4|Dt(48TLp$XtT,L$h         h0H|TH p0X0,x\`H !("8# #$ $p$%X%&@&&'P'(X())*\*+(+,P,- -p-.D./ //011H1123 3l44445h56T67P788h99p9:8::;;<(<=(=>>p>?T?@@AAlABTC ClCDLDE8EF F|FG G\GGGHHtHHHI,IDI\ItIIIIIJJJ4JLJdJ|JJJJKK(KHKKKL@LtLLLMM@MXMpMMMMMMNTNlNNOOO0OHO`OxOOOOOPP P8PPPhPPQQ$Q<QQR(R@RXRpRRSS S8SPShSSSSSSTT(T@TXTTTTUUUV$V<VVVWlWWWWWWXX,XDX\XtXXXXXYdYYYZZZlZZZ[L[d[|[[\\\4\L\d\|\\\\\] ]$]<]T]]^^4^l^^^^^__,_D_\_t_____```4`L`d`|`aa8aabLbdbbc ccccccdd,dDdde(e|eeffTflfffgg g8gPghgggggghh(h@hxhii ixiiijjljjjjjjkk,kDk\ktkkkkkl<llmHmmn4nLnnnoo,oDo\otoooooppp4pqqqtqqrrrtrrrrrsss4sLsds|ssssstTtdtu uxuuvXvpvvwXwwx<xTxlxyyyzz{d{||0|H|`|x|}`}~X~~0H`< 8$4Ld|tx0H`xH`t H`DHx(@XpX4P4pP8,dth,<p8X(` (8@Lh Dx,h@D|(<Pdx \`tH`00$$tT$Th<\0H`x 8Ph(@Xx(@Xp0H`x(@Xp0H`x 8Xpˆ ¸0H`xÐè 8XxĐĨ 8PhŀŘŰ(@XpƈƠƸ0H`xǐǨ 8PhȀȘȰ(@XpɈɠɸ0H`xʐʨ 8Phˀ˘˰(@Xp̸̠̈0Ph̀͘Ͱ(@XpΈΠθ 8PhπϘϰ(@XpЈРи0H`xѐѨ 8PhҀҘҰ,Hd|ӔӬ $@\xԐԬ(@XpՈդ,Hd|֔֬ $@\xא׬0H`xؐب,D\tٌ٤ټ <Xpڈڠڸ0Lhۀۜ۸0@Xh܀ܐܨܸ 8Ph݀ݘݰ(@Xpވޠ޸0H`xߐߨ 8Ph(@Xp0H`x0@Xp(@\t,D`p,D\t$<Tl HpPt, 0(8Xpx8(<lT,P`t$dt4xxP,T<Pdx,@Th|@(0 `       T x   8l|(4T<Ld` ( !p!"\""#\#l#|$p$$$%&''(L),)X**+,$,-(-p-.h./p//08000112L23$34$4t44445545T5t55556 6646T6l6|6666777<7L7\7l7|7777788$8L8d8t8888889p:;;;<=L=>?@A APAAABHBCCD0D|DEE\EEFFLFG GHpI4JHJJK(K`KKLL@LMDMMNO<O`OOOPP(PLPpPPPQ QTQQRRRSSlSST,TlTU$UdUUV$VdVWW\WX XTXXY4YpYYZ4ZtZ[[l[\,\]]l]]^P_,_H__`4``aDaabblbc|d`ddef fPfgXghhii0itijPj|jkLkkkll4lllm<nno opdppqqrr,rlrrss4tu8vwxHyy4yXytyyyzz<zz{x{| ||}T}~H~l` d  0P`4xXhL4|$\4,tP0,$PtL$||LPT,h,\Lh4 \0d@$XHxHh,hddTd<``Dd4Dp @@h,(LpÐð(Āpp$TϠ8pШ8\рќѼHҀҜ,`|ԤԴ(PTT0 <Xt8Th$@Xt tDPl(H| Lh$@lDdl( L\<dlDt4Ld,T(T        8 T      <P$ ##$8$%&d((X()*T*+,H--.2 235`89H9:D:;,;=>4>?d@@8@X@x@@@@ABC\D,DEFGGHDHI@IIJK4KLLM MNO|OPPQ|RhRTV<VWY<ZP[\]\^$_ _``aabhbbdde<eef\ffghPi8kDl8m\nopqrstuwPxTxy`z{|@}|@(@Xp@hHtHX8L(x8<p04p(P`ldT($`DT¼HĘ$Ť ƐLǰhɸ(̐΄ϰ@ո DޔX xXpH|\th, Lt L<|$ppDH`<<T L d      l P,,\|Hx\Hd` h L  H |    !T!"h#($$$%&&'$'''(D()))()<)X)l)))))**8*T*x****++8+T+x+++,,,,X,|,,---8-T-x---..$.H.l...//H/d////0(0T0001181d1122282T2x22233$3H3l33344H4d44445(5T5556686d6677$7H7l77788H8l8889$9X999::D:x::; ;H;t;;<>$>H>l>>>??H?d????@(@T@@@AA8AdAABB$BHBlBBBCCHClCCCD$DXDDDEEDExEEF FHFtFFGGLGGHH$HHHlHHHIIHIlIIIJ$JXJJJKKDKxKKL LHLtLLMMLMMNN,NXNNNOOLOOOPPXPPQQHQtQQRRLRRSS<SxSST4TxTUUTUUV,VWXTXY8YtYYZZ@ZtZZ[[h\(\]^^p^_X``aab<bcdcdxeeefDfTffffgg(g@gXh(hiDijXkkxklXlmhmnTno ooopp,pppqqPqrDrspst<ttuDuuvdvwxyhz8zz{{\{{|H|p|||}}D}p}}~~L~~~<d$ Px,4@P T8,(8HXhxdxh8@ l4 hxP`0,<txXp\HH ,$4D,t0H`x 8Ph(@Xp0H`x 8Ph(@Xp0H`x 8Ph4D\l| 4H`t 8Ph€˜°(@PÄÜô,D\tČĤļ4D@ $4ǘǰ,D\l@pʈʠʸ˼H4L\L0@ а(@XpшѠѸҬӠӰ$XԜԬLռLd|ּ֔֬4؀ؐ$4 8PhڀژڰۄۄHd܀ܜܸ$PxݠDlޔ<dߌߴ0X$LtDl8`,T$Lt@l 4`,T| Lt LPlPH4H\8$T|d0<@t$@l,d\d $<Tl  $ D d  T      0 L h       , H d       @ X     ,Ld<0H`x 0P`0`8`d8l@ <l$xpD0 @4d4h L  !(!\!"0"""# #T##$D$%P%|%%&&<&l&&'$'((()0)*D_T+h @h>2   : `   (Z4;b ;; 0    " F m " : %: h: ; ;Copyright (c) 2003 by Bitstream, Inc. All Rights Reserved. Copyright (c) 2006 by Tavmjong Bah. All Rights Reserved. DejaVu changes are in public domain Copyright (c) 2003 by Bitstream, Inc. All Rights Reserved. Copyright (c) 2006 by Tavmjong Bah. All Rights Reserved. DejaVu changes are in public domain DejaVu SansDejaVu SansBookBookDejaVu SansDejaVu SansDejaVu SansDejaVu SansVersion 2.19Version 2.19DejaVuSansDejaVuSansDejaVu fonts teamDejaVu fonts teamhttp://dejavu.sourceforge.nethttp://dejavu.sourceforge.netFonts are (c) Bitstream (see below). DejaVu changes are in public domain. Glyphs imported from Arev fonts are (c) Tavmjung Bah (see below) Bitstream Vera Fonts Copyright ------------------------------ Copyright (c) 2003 by Bitstream, Inc. All Rights Reserved. Bitstream Vera is a trademark of Bitstream, Inc. Permission is hereby granted, free of charge, to any person obtaining a copy of the fonts accompanying this license ("Fonts") and associated documentation files (the "Font Software"), to reproduce and distribute the Font Software, including without limitation the rights to use, copy, merge, publish, distribute, and/or sell copies of the Font Software, and to permit persons to whom the Font Software is furnished to do so, subject to the following conditions: The above copyright and trademark notices and this permission notice shall be included in all copies of one or more of the Font Software typefaces. The Font Software may be modified, altered, or added to, and in particular the designs of glyphs or characters in the Fonts may be modified and additional glyphs or characters may be added to the Fonts, only if the fonts are renamed to names not containing either the words "Bitstream" or the word "Vera". This License becomes null and void to the extent applicable to Fonts or Font Software that has been modified and is distributed under the "Bitstream Vera" names. The Font Software may be sold as part of a larger software package but no copy of one or more of the Font Software typefaces may be sold by itself. THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL BITSTREAM OR THE GNOME FOUNDATION BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM OTHER DEALINGS IN THE FONT SOFTWARE. Except as contained in this notice, the names of Gnome, the Gnome Foundation, and Bitstream Inc., shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Font Software without prior written authorization from the Gnome Foundation or Bitstream Inc., respectively. For further information, contact: fonts at gnome dot org. Arev Fonts Copyright ------------------------------ Copyright (c) 2006 by Tavmjong Bah. All Rights Reserved. Permission is hereby granted, free of charge, to any person obtaining a copy of the fonts accompanying this license ("Fonts") and associated documentation files (the "Font Software"), to reproduce and distribute the modifications to the Bitstream Vera Font Software, including without limitation the rights to use, copy, merge, publish, distribute, and/or sell copies of the Font Software, and to permit persons to whom the Font Software is furnished to do so, subject to the following conditions: The above copyright and trademark notices and this permission notice shall be included in all copies of one or more of the Font Software typefaces. The Font Software may be modified, altered, or added to, and in particular the designs of glyphs or characters in the Fonts may be modified and additional glyphs or characters may be added to the Fonts, only if the fonts are renamed to names not containing either the words "Tavmjong Bah" or the word "Arev". This License becomes null and void to the extent applicable to Fonts or Font Software that has been modified and is distributed under the "Tavmjong Bah Arev" names. The Font Software may be sold as part of a larger software package but no copy of one or more of the Font Software typefaces may be sold by itself. THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL TAVMJONG BAH BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM OTHER DEALINGS IN THE FONT SOFTWARE. Except as contained in this notice, the name of Tavmjong Bah shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Font Software without prior written authorization from Tavmjong Bah. For further information, contact: tavmjong @ free . fr.Fonts are (c) Bitstream (see below). DejaVu changes are in public domain. Glyphs imported from Arev fonts are (c) Tavmjung Bah (see below) Bitstream Vera Fonts Copyright ------------------------------ Copyright (c) 2003 by Bitstream, Inc. All Rights Reserved. Bitstream Vera is a trademark of Bitstream, Inc. Permission is hereby granted, free of charge, to any person obtaining a copy of the fonts accompanying this license ("Fonts") and associated documentation files (the "Font Software"), to reproduce and distribute the Font Software, including without limitation the rights to use, copy, merge, publish, distribute, and/or sell copies of the Font Software, and to permit persons to whom the Font Software is furnished to do so, subject to the following conditions: The above copyright and trademark notices and this permission notice shall be included in all copies of one or more of the Font Software typefaces. The Font Software may be modified, altered, or added to, and in particular the designs of glyphs or characters in the Fonts may be modified and additional glyphs or characters may be added to the Fonts, only if the fonts are renamed to names not containing either the words "Bitstream" or the word "Vera". This License becomes null and void to the extent applicable to Fonts or Font Software that has been modified and is distributed under the "Bitstream Vera" names. The Font Software may be sold as part of a larger software package but no copy of one or more of the Font Software typefaces may be sold by itself. THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL BITSTREAM OR THE GNOME FOUNDATION BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM OTHER DEALINGS IN THE FONT SOFTWARE. Except as contained in this notice, the names of Gnome, the Gnome Foundation, and Bitstream Inc., shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Font Software without prior written authorization from the Gnome Foundation or Bitstream Inc., respectively. For further information, contact: fonts at gnome dot org. Arev Fonts Copyright ------------------------------ Copyright (c) 2006 by Tavmjong Bah. All Rights Reserved. Permission is hereby granted, free of charge, to any person obtaining a copy of the fonts accompanying this license ("Fonts") and associated documentation files (the "Font Software"), to reproduce and distribute the modifications to the Bitstream Vera Font Software, including without limitation the rights to use, copy, merge, publish, distribute, and/or sell copies of the Font Software, and to permit persons to whom the Font Software is furnished to do so, subject to the following conditions: The above copyright and trademark notices and this permission notice shall be included in all copies of one or more of the Font Software typefaces. The Font Software may be modified, altered, or added to, and in particular the designs of glyphs or characters in the Fonts may be modified and additional glyphs or characters may be added to the Fonts, only if the fonts are renamed to names not containing either the words "Tavmjong Bah" or the word "Arev". This License becomes null and void to the extent applicable to Fonts or Font Software that has been modified and is distributed under the "Tavmjong Bah Arev" names. The Font Software may be sold as part of a larger software package but no copy of one or more of the Font Software typefaces may be sold by itself. THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL TAVMJONG BAH BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM OTHER DEALINGS IN THE FONT SOFTWARE. Except as contained in this notice, the name of Tavmjong Bah shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Font Software without prior written authorization from Tavmjong Bah. For further information, contact: tavmjong @ free . fr.http://dejavu.sourceforge.net/wiki/index.php/Licensehttp://dejavu.sourceforge.net/wiki/index.php/LicenseDejaVu SansDejaVu SansBookBookZ_  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghjikmlnoqprsutvwxzy{}|~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                           ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~        !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\] sfthyphenAmacronamacronAbreveabreveAogonekaogonek Ccircumflex ccircumflex Cdotaccent cdotaccentDcarondcaronDcroatEmacronemacronEbreveebreve Edotaccent edotaccentEogonekeogonekEcaronecaron Gcircumflex gcircumflex Gdotaccent gdotaccent Gcommaaccent gcommaaccent Hcircumflex hcircumflexHbarhbarItildeitildeImacronimacronIbreveibreveIogonekiogonekIJij Jcircumflex jcircumflex Kcommaaccent kcommaaccent kgreenlandicLacutelacute Lcommaaccent lcommaaccentLcaronlcaronLdotldotNacutenacute Ncommaaccent ncommaaccentNcaronncaron napostropheEngengOmacronomacronObreveobreve Ohungarumlaut ohungarumlautRacuteracute Rcommaaccent rcommaaccentRcaronrcaronSacutesacute Scircumflex scircumflex Tcommaaccent tcommaaccentTcarontcaronTbartbarUtildeutildeUmacronumacronUbreveubreveUringuring Uhungarumlaut uhungarumlautUogonekuogonek Wcircumflex wcircumflex Ycircumflex ycircumflexZacutezacute Zdotaccent zdotaccentlongsuni0180uni0181uni0182uni0183uni0184uni0185uni0186uni0187uni0188uni0189uni018Auni018Buni018Cuni018Duni018Euni018Funi0190uni0191uni0193uni0194uni0195uni0196uni0197uni0198uni0199uni019Auni019Buni019Cuni019Duni019Euni019FOhornohornuni01A2uni01A3uni01A4uni01A5uni01A6uni01A7uni01A8uni01A9uni01AAuni01ABuni01ACuni01ADuni01AEUhornuhornuni01B1uni01B2uni01B3uni01B4uni01B5uni01B6uni01B7uni01B8uni01B9uni01BAuni01BBuni01BCuni01BDuni01BEuni01BFuni01C0uni01C1uni01C2uni01C3uni01C4uni01C5uni01C6uni01C7uni01C8uni01C9uni01CAuni01CBuni01CCuni01CDuni01CEuni01CFuni01D0uni01D1uni01D2uni01D3uni01D4uni01D5uni01D6uni01D7uni01D8uni01D9uni01DAuni01DBuni01DCuni01DDuni01DEuni01DFuni01E0uni01E1uni01E2uni01E3uni01E4uni01E5Gcarongcaronuni01E8uni01E9uni01EAuni01EBuni01ECuni01EDuni01EEuni01EFuni01F0uni01F1uni01F2uni01F3uni01F4uni01F5uni01F6uni01F7uni01F8uni01F9 Aringacute aringacuteAEacuteaeacute Oslashacute oslashacuteuni0200uni0201uni0202uni0203uni0204uni0205uni0206uni0207uni0208uni0209uni020Auni020Buni020Cuni020Duni020Euni020Funi0210uni0211uni0212uni0213uni0214uni0215uni0216uni0217 Scommaaccent scommaaccentuni021Auni021Buni021Cuni021Duni021Euni021Funi0220uni0221uni0222uni0223uni0224uni0225uni0226uni0227uni0228uni0229uni022Auni022Buni022Cuni022Duni022Euni022Funi0230uni0231uni0232uni0233uni0234uni0235uni0236dotlessjuni0238uni0239uni023Auni023Buni023Cuni023Duni023Euni023Funi0240uni0241uni0242uni0243uni0244uni0245uni0246uni0247uni0248uni0249uni024Auni024Buni024Cuni024Duni024Euni024Funi0250uni0251uni0252uni0253uni0254uni0255uni0256uni0257uni0258uni0259uni025Auni025Buni025Cuni025Duni025Euni025Funi0260uni0261uni0262uni0263uni0264uni0265uni0266uni0267uni0268uni0269uni026Auni026Buni026Cuni026Duni026Euni026Funi0270uni0271uni0272uni0273uni0274uni0275uni0276uni0277uni0278uni0279uni027Auni027Buni027Cuni027Duni027Euni027Funi0280uni0281uni0282uni0283uni0284uni0285uni0286uni0287uni0288uni0289uni028Auni028Buni028Cuni028Duni028Euni028Funi0290uni0291uni0292uni0293uni0294uni0295uni0296uni0297uni0298uni0299uni029Auni029Buni029Cuni029Duni029Euni029Funi02A0uni02A1uni02A2uni02A3uni02A4uni02A5uni02A6uni02A7uni02A8uni02A9uni02AAuni02ABuni02ACuni02ADuni02AEuni02AFuni02B0uni02B1uni02B2uni02B3uni02B4uni02B5uni02B6uni02B7uni02B8uni02B9uni02BAuni02BBuni02BCuni02BDuni02BEuni02BFuni02C0uni02C1uni02C2uni02C3uni02C4uni02C5uni02C8uni02C9uni02CAuni02CBuni02CCuni02CDuni02CEuni02CFuni02D0uni02D1uni02D2uni02D3uni02D4uni02D5uni02D6uni02D7uni02DEuni02DFuni02E0uni02E1uni02E2uni02E3uni02E4uni02E5uni02E6uni02E7uni02E8uni02E9uni02ECuni02EDuni02EEuni02F3uni02F7 gravecomb acutecombuni0302 tildecombuni0304uni0305uni0306uni0307uni0308 hookabovecombuni030Auni030Buni030Cuni030Duni030Euni030Funi0310uni0311uni0312uni0313uni0314uni0315uni0316uni0317uni0318uni0319uni031Auni031Buni031Cuni031Duni031Euni031Funi0320uni0321uni0322 dotbelowcombuni0324uni0325uni0326uni0327uni0328uni0329uni032Auni032Buni032Cuni032Duni032Euni032Funi0330uni0331uni0332uni0333uni0334uni0335uni0336uni0337uni0338uni0339uni033Auni033Buni033Cuni033Duni033Euni033Funi0340uni0341uni0342uni0343uni0344uni0345uni0346uni0347uni0348uni0349uni034Auni034Buni034Cuni034Duni034Euni034Funi0351uni0352uni0353uni0357uni0358uni035Cuni035Duni035Euni035Funi0360uni0361uni0362uni0374uni0375uni037Auni037Buni037Cuni037Duni037Etonos dieresistonos Alphatonos anoteleia EpsilontonosEtatonos Iotatonos Omicrontonos Upsilontonos OmegatonosiotadieresistonosAlphaBetaGammauni0394EpsilonZetaEtaThetaIotaKappaLambdaMuNuXiOmicronPiRhoSigmaTauUpsilonPhiChiPsi IotadieresisUpsilondieresis alphatonos epsilontonosetatonos iotatonosupsilondieresistonosalphabetagammadeltaepsilonzetaetathetaiotakappalambdauni03BCnuxiomicronrhosigma1sigmatauupsilonphichipsiomega iotadieresisupsilondieresis omicrontonos upsilontonos omegatonosuni03D0theta1Upsilon1uni03D3uni03D4phi1omega1uni03D7uni03D8uni03D9uni03DAuni03DBuni03DCuni03DDuni03DEuni03DFuni03E0uni03E1uni03E2uni03E3uni03E4uni03E5uni03E6uni03E7uni03E8uni03E9uni03EAuni03EBuni03ECuni03EDuni03EEuni03EFuni03F0uni03F1uni03F2uni03F3uni03F4uni03F5uni03F6uni03F7uni03F8uni03F9uni03FAuni03FBuni03FCuni03FDuni03FEuni03FFuni0400uni0401uni0402uni0403uni0404uni0405uni0406uni0407uni0408uni0409uni040Auni040Buni040Cuni040Duni040Euni040Funi0410uni0411uni0412uni0413uni0414uni0415uni0416uni0417uni0418uni0419uni041Auni041Buni041Cuni041Duni041Euni041Funi0420uni0421uni0422uni0423uni0424uni0425uni0426uni0427uni0428uni0429uni042Auni042Buni042Cuni042Duni042Euni042Funi0430uni0431uni0432uni0433uni0434uni0435uni0436uni0437uni0438uni0439uni043Auni043Buni043Cuni043Duni043Euni043Funi0440uni0441uni0442uni0443uni0444uni0445uni0446uni0447uni0448uni0449uni044Auni044Buni044Cuni044Duni044Euni044Funi0450uni0451uni0452uni0453uni0454uni0455uni0456uni0457uni0458uni0459uni045Auni045Buni045Cuni045Duni045Euni045Funi0460uni0461uni0462uni0463uni0464uni0465uni0466uni0467uni0468uni0469uni046Auni046Buni046Cuni046Duni046Euni046Funi0470uni0471uni0472uni0473uni0474uni0475uni0476uni0477uni0478uni0479uni047Auni047Buni047Cuni047Duni047Euni047Funi0480uni0481uni0482uni0483uni0484uni0485uni0486uni0488uni0489uni048Auni048Buni048Cuni048Duni048Euni048Funi0490uni0491uni0492uni0493uni0494uni0495uni0496uni0497uni0498uni0499uni049Auni049Buni049Cuni049Duni049Euni049Funi04A0uni04A1uni04A2uni04A3uni04A4uni04A5uni04A6uni04A7uni04A8uni04A9uni04AAuni04ABuni04ACuni04ADuni04AEuni04AFuni04B0uni04B1uni04B2uni04B3uni04B4uni04B5uni04B6uni04B7uni04B8uni04B9uni04BAuni04BBuni04BCuni04BDuni04BEuni04BFuni04C0uni04C1uni04C2uni04C3uni04C4uni04C5uni04C6uni04C7uni04C8uni04C9uni04CAuni04CBuni04CCuni04CDuni04CEuni04CFuni04D0uni04D1uni04D2uni04D3uni04D4uni04D5uni04D6uni04D7uni04D8uni04D9uni04DAuni04DBuni04DCuni04DDuni04DEuni04DFuni04E0uni04E1uni04E2uni04E3uni04E4uni04E5uni04E6uni04E7uni04E8uni04E9uni04EAuni04EBuni04ECuni04EDuni04EEuni04EFuni04F0uni04F1uni04F2uni04F3uni04F4uni04F5uni04F6uni04F7uni04F8uni04F9uni04FAuni04FBuni04FCuni04FDuni04FEuni04FFuni0500uni0501uni0502uni0503uni0504uni0505uni0506uni0507uni0508uni0509uni050Auni050Buni050Cuni050Duni050Euni050Funi0510uni0511uni0512uni0513uni0531uni0532uni0533uni0534uni0535uni0536uni0537uni0538uni0539uni053Auni053Buni053Cuni053Duni053Euni053Funi0540uni0541uni0542uni0543uni0544uni0545uni0546uni0547uni0548uni0549uni054Auni054Buni054Cuni054Duni054Euni054Funi0550uni0551uni0552uni0553uni0554uni0555uni0556uni0559uni055Auni055Buni055Cuni055Duni055Euni055Funi0561uni0562uni0563uni0564uni0565uni0566uni0567uni0568uni0569uni056Auni056Buni056Cuni056Duni056Euni056Funi0570uni0571uni0572uni0573uni0574uni0575uni0576uni0577uni0578uni0579uni057Auni057Buni057Cuni057Duni057Euni057Funi0580uni0581uni0582uni0583uni0584uni0585uni0586uni0587uni0589uni058Auni05B0uni05B1uni05B2uni05B3uni05B4uni05B5uni05B6uni05B7uni05B8uni05B9uni05BAuni05BBuni05BCuni05BDuni05BEuni05BFuni05C0uni05C1uni05C2uni05C3uni05C6uni05C7uni05D0uni05D1uni05D2uni05D3uni05D4uni05D5uni05D6uni05D7uni05D8uni05D9uni05DAuni05DBuni05DCuni05DDuni05DEuni05DFuni05E0uni05E1uni05E2uni05E3uni05E4uni05E5uni05E6uni05E7uni05E8uni05E9uni05EAuni05F0uni05F1uni05F2uni05F3uni05F4uni060Cuni0615uni061Buni061Funi0621uni0622uni0623uni0624uni0625uni0626uni0627uni0628uni0629uni062Auni062Buni062Cuni062Duni062Euni062Funi0630uni0631uni0632uni0633uni0634uni0635uni0636uni0637uni0638uni0639uni063Auni0640uni0641uni0642uni0643uni0644uni0645uni0646uni0647uni0648uni0649uni064Auni064Buni064Cuni064Duni064Euni064Funi0650uni0651uni0652uni0653uni0654uni0655uni065Auni0660uni0661uni0662uni0663uni0664uni0665uni0666uni0667uni0668uni0669uni066Auni066Buni066Cuni066Duni066Euni066Funi0674uni0679uni067Auni067Buni067Cuni067Duni067Euni067Funi0680uni0681uni0682uni0683uni0684uni0685uni0686uni0687uni0691uni0692uni0695uni0698uni06A1uni06A4uni06A6uni06A9uni06AFuni06B5uni06BAuni06BFuni06C6uni06CCuni06CEuni06D5uni06F0uni06F1uni06F2uni06F3uni06F4uni06F5uni06F6uni06F7uni06F8uni06F9uni07C0uni07C1uni07C2uni07C3uni07C4uni07C5uni07C6uni07C7uni07C8uni07C9uni07CAuni07CBuni07CCuni07CDuni07CEuni07CFuni07D0uni07D1uni07D2uni07D3uni07D4uni07D5uni07D6uni07D7uni07D8uni07D9uni07DAuni07DBuni07DCuni07DDuni07DEuni07DFuni07E0uni07E1uni07E2uni07E3uni07E4uni07E5uni07E6uni07E7uni07EBuni07ECuni07EDuni07EEuni07EFuni07F0uni07F1uni07F2uni07F3uni07F4uni07F5uni07F8uni07F9uni07FAuni0E3Funi0E81uni0E82uni0E84uni0E87uni0E88uni0E8Auni0E8Duni0E94uni0E95uni0E96uni0E97uni0E99uni0E9Auni0E9Buni0E9Cuni0E9Duni0E9Euni0E9Funi0EA1uni0EA2uni0EA3uni0EA5uni0EA7uni0EAAuni0EABuni0EADuni0EAEuni0EAFuni0EB0uni0EB1uni0EB2uni0EB3uni0EB4uni0EB5uni0EB6uni0EB7uni0EB8uni0EB9uni0EBBuni0EBCuni0EBDuni0EC0uni0EC1uni0EC2uni0EC3uni0EC4uni0EC6uni0EC8uni0EC9uni0ECAuni0ECBuni0ECCuni0ECDuni0ED0uni0ED1uni0ED2uni0ED3uni0ED4uni0ED5uni0ED6uni0ED7uni0ED8uni0ED9uni0EDCuni0EDDuni10A0uni10A1uni10A2uni10A3uni10A4uni10A5uni10A6uni10A7uni10A8uni10A9uni10AAuni10ABuni10ACuni10ADuni10AEuni10AFuni10B0uni10B1uni10B2uni10B3uni10B4uni10B5uni10B6uni10B7uni10B8uni10B9uni10BAuni10BBuni10BCuni10BDuni10BEuni10BFuni10C0uni10C1uni10C2uni10C3uni10C4uni10C5uni10D0uni10D1uni10D2uni10D3uni10D4uni10D5uni10D6uni10D7uni10D8uni10D9uni10DAuni10DBuni10DCuni10DDuni10DEuni10DFuni10E0uni10E1uni10E2uni10E3uni10E4uni10E5uni10E6uni10E7uni10E8uni10E9uni10EAuni10EBuni10ECuni10EDuni10EEuni10EFuni10F0uni10F1uni10F2uni10F3uni10F4uni10F5uni10F6uni10F7uni10F8uni10F9uni10FAuni10FBuni10FCuni1401uni1402uni1403uni1404uni1405uni1406uni1407uni1409uni140Auni140Buni140Cuni140Duni140Euni140Funi1410uni1411uni1412uni1413uni1414uni1415uni1416uni1417uni1418uni1419uni141Auni141Buni141Duni141Euni141Funi1420uni1421uni1422uni1423uni1424uni1425uni1426uni1427uni1428uni1429uni142Auni142Buni142Cuni142Duni142Euni142Funi1430uni1431uni1432uni1433uni1434uni1435uni1437uni1438uni1439uni143Auni143Buni143Cuni143Duni143Euni143Funi1440uni1441uni1442uni1443uni1444uni1445uni1446uni1447uni1448uni1449uni144Auni144Cuni144Duni144Euni144Funi1450uni1451uni1452uni1454uni1455uni1456uni1457uni1458uni1459uni145Auni145Buni145Cuni145Duni145Euni145Funi1460uni1461uni1462uni1463uni1464uni1465uni1466uni1467uni1468uni1469uni146Auni146Buni146Cuni146Duni146Euni146Funi1470uni1471uni1472uni1473uni1474uni1475uni1476uni1477uni1478uni1479uni147Auni147Buni147Cuni147Duni147Euni147Funi1480uni1481uni1482uni1483uni1484uni1485uni1486uni1487uni1488uni1489uni148Auni148Buni148Cuni148Duni148Euni148Funi1490uni1491uni1492uni1493uni1494uni1495uni1496uni1497uni1498uni1499uni149Auni149Buni149Cuni149Duni149Euni149Funi14A0uni14A1uni14A2uni14A3uni14A4uni14A5uni14A6uni14A7uni14A8uni14A9uni14AAuni14ABuni14ACuni14ADuni14AEuni14AFuni14B0uni14B1uni14B2uni14B3uni14B4uni14B5uni14B6uni14B7uni14B8uni14B9uni14BAuni14BBuni14BCuni14BDuni14C0uni14C1uni14C2uni14C3uni14C4uni14C5uni14C6uni14C7uni14C8uni14C9uni14CAuni14CBuni14CCuni14CDuni14CEuni14CFuni14D0uni14D1uni14D2uni14D3uni14D4uni14D5uni14D6uni14D7uni14D8uni14D9uni14DAuni14DBuni14DCuni14DDuni14DEuni14DFuni14E0uni14E1uni14E2uni14E3uni14E4uni14E5uni14E6uni14E7uni14E8uni14E9uni14EAuni14ECuni14EDuni14EEuni14EFuni14F0uni14F1uni14F2uni14F3uni14F4uni14F5uni14F6uni14F7uni14F8uni14F9uni14FAuni14FBuni14FCuni14FDuni14FEuni14FFuni1500uni1501uni1502uni1503uni1504uni1505uni1506uni1507uni1510uni1511uni1512uni1513uni1514uni1515uni1516uni1517uni1518uni1519uni151Auni151Buni151Cuni151Duni151Euni151Funi1520uni1521uni1522uni1523uni1524uni1525uni1526uni1527uni1528uni1529uni152Auni152Buni152Cuni152Duni152Euni152Funi1530uni1531uni1532uni1533uni1534uni1535uni1536uni1537uni1538uni1539uni153Auni153Buni153Cuni153Duni153Euni1540uni1541uni1542uni1543uni1544uni1545uni1546uni1547uni1548uni1549uni154Auni154Buni154Cuni154Duni154Euni154Funi1550uni1552uni1553uni1554uni1555uni1556uni1557uni1558uni1559uni155Auni155Buni155Cuni155Duni155Euni155Funi1560uni1561uni1562uni1563uni1564uni1565uni1566uni1567uni1568uni1569uni156Auni1574uni1575uni1576uni1577uni1578uni1579uni157Auni157Buni157Cuni157Duni157Euni157Funi1580uni1581uni1582uni1583uni1584uni1585uni158Auni158Buni158Cuni158Duni158Euni158Funi1590uni1591uni1592uni1593uni1594uni1595uni1596uni15A0uni15A1uni15A2uni15A3uni15A4uni15A5uni15A6uni15A7uni15A8uni15A9uni15AAuni15ABuni15ACuni15ADuni15AEuni15AFuni15DEuni15E1uni1646uni1647uni166Euni166Funi1670uni1671uni1672uni1673uni1674uni1675uni1676uni1D00uni1D01uni1D02uni1D03uni1D04uni1D05uni1D06uni1D07uni1D08uni1D09uni1D0Auni1D0Buni1D0Cuni1D0Duni1D0Euni1D0Funi1D10uni1D11uni1D12uni1D13uni1D14uni1D16uni1D17uni1D18uni1D19uni1D1Auni1D1Buni1D1Cuni1D1Duni1D1Euni1D1Funi1D20uni1D21uni1D22uni1D23uni1D26uni1D27uni1D28uni1D29uni1D2Auni1D2Buni1D2Cuni1D2Duni1D2Euni1D30uni1D31uni1D32uni1D33uni1D34uni1D35uni1D36uni1D37uni1D38uni1D39uni1D3Auni1D3Buni1D3Cuni1D3Duni1D3Euni1D3Funi1D40uni1D41uni1D42uni1D43uni1D44uni1D45uni1D46uni1D47uni1D48uni1D49uni1D4Auni1D4Buni1D4Cuni1D4Duni1D4Euni1D4Funi1D50uni1D51uni1D52uni1D53uni1D54uni1D55uni1D56uni1D57uni1D58uni1D59uni1D5Auni1D5Buni1D5Duni1D5Euni1D5Funi1D60uni1D61uni1D62uni1D63uni1D64uni1D65uni1D66uni1D67uni1D68uni1D69uni1D6Auni1D77uni1D78uni1D7Buni1D85uni1D9Buni1D9Cuni1D9Duni1D9Euni1D9Funi1DA0uni1DA1uni1DA2uni1DA3uni1DA4uni1DA5uni1DA6uni1DA7uni1DA8uni1DA9uni1DAAuni1DABuni1DACuni1DADuni1DAEuni1DAFuni1DB0uni1DB1uni1DB2uni1DB3uni1DB4uni1DB5uni1DB6uni1DB7uni1DB8uni1DB9uni1DBAuni1DBBuni1DBCuni1DBDuni1DBEuni1DBFuni1DC4uni1DC5uni1DC6uni1DC7uni1DC8uni1DC9uni1E00uni1E01uni1E02uni1E03uni1E04uni1E05uni1E06uni1E07uni1E08uni1E09uni1E0Auni1E0Buni1E0Cuni1E0Duni1E0Euni1E0Funi1E10uni1E11uni1E12uni1E13uni1E14uni1E15uni1E16uni1E17uni1E18uni1E19uni1E1Auni1E1Buni1E1Cuni1E1Duni1E1Euni1E1Funi1E20uni1E21uni1E22uni1E23uni1E24uni1E25uni1E26uni1E27uni1E28uni1E29uni1E2Auni1E2Buni1E2Cuni1E2Duni1E2Euni1E2Funi1E30uni1E31uni1E32uni1E33uni1E34uni1E35uni1E36uni1E37uni1E38uni1E39uni1E3Auni1E3Buni1E3Cuni1E3Duni1E3Euni1E3Funi1E40uni1E41uni1E42uni1E43uni1E44uni1E45uni1E46uni1E47uni1E48uni1E49uni1E4Auni1E4Buni1E4Cuni1E4Duni1E4Euni1E4Funi1E50uni1E51uni1E52uni1E53uni1E54uni1E55uni1E56uni1E57uni1E58uni1E59uni1E5Auni1E5Buni1E5Cuni1E5Duni1E5Euni1E5Funi1E60uni1E61uni1E62uni1E63uni1E64uni1E65uni1E66uni1E67uni1E68uni1E69uni1E6Auni1E6Buni1E6Cuni1E6Duni1E6Euni1E6Funi1E70uni1E71uni1E72uni1E73uni1E74uni1E75uni1E76uni1E77uni1E78uni1E79uni1E7Auni1E7Buni1E7Cuni1E7Duni1E7Euni1E7FWgravewgraveWacutewacute Wdieresis wdieresisuni1E86uni1E87uni1E88uni1E89uni1E8Auni1E8Buni1E8Cuni1E8Duni1E8Euni1E8Funi1E90uni1E91uni1E92uni1E93uni1E94uni1E95uni1E96uni1E97uni1E98uni1E99uni1E9Auni1E9Buni1EA0uni1EA1uni1EA2uni1EA3uni1EA4uni1EA5uni1EA6uni1EA7uni1EA8uni1EA9uni1EAAuni1EABuni1EACuni1EADuni1EAEuni1EAFuni1EB0uni1EB1uni1EB2uni1EB3uni1EB4uni1EB5uni1EB6uni1EB7uni1EB8uni1EB9uni1EBAuni1EBBuni1EBCuni1EBDuni1EBEuni1EBFuni1EC0uni1EC1uni1EC2uni1EC3uni1EC4uni1EC5uni1EC6uni1EC7uni1EC8uni1EC9uni1ECAuni1ECBuni1ECCuni1ECDuni1ECEuni1ECFuni1ED0uni1ED1uni1ED2uni1ED3uni1ED4uni1ED5uni1ED6uni1ED7uni1ED8uni1ED9uni1EDAuni1EDBuni1EDCuni1EDDuni1EDEuni1EDFuni1EE0uni1EE1uni1EE2uni1EE3uni1EE4uni1EE5uni1EE6uni1EE7uni1EE8uni1EE9uni1EEAuni1EEBuni1EECuni1EEDuni1EEEuni1EEFuni1EF0uni1EF1Ygraveygraveuni1EF4uni1EF5uni1EF6uni1EF7uni1EF8uni1EF9uni1F00uni1F01uni1F02uni1F03uni1F04uni1F05uni1F06uni1F07uni1F08uni1F09uni1F0Auni1F0Buni1F0Cuni1F0Duni1F0Euni1F0Funi1F10uni1F11uni1F12uni1F13uni1F14uni1F15uni1F18uni1F19uni1F1Auni1F1Buni1F1Cuni1F1Duni1F20uni1F21uni1F22uni1F23uni1F24uni1F25uni1F26uni1F27uni1F28uni1F29uni1F2Auni1F2Buni1F2Cuni1F2Duni1F2Euni1F2Funi1F30uni1F31uni1F32uni1F33uni1F34uni1F35uni1F36uni1F37uni1F38uni1F39uni1F3Auni1F3Buni1F3Cuni1F3Duni1F3Euni1F3Funi1F40uni1F41uni1F42uni1F43uni1F44uni1F45uni1F48uni1F49uni1F4Auni1F4Buni1F4Cuni1F4Duni1F50uni1F51uni1F52uni1F53uni1F54uni1F55uni1F56uni1F57uni1F59uni1F5Buni1F5Duni1F5Funi1F60uni1F61uni1F62uni1F63uni1F64uni1F65uni1F66uni1F67uni1F68uni1F69uni1F6Auni1F6Buni1F6Cuni1F6Duni1F6Euni1F6Funi1F70uni1F71uni1F72uni1F73uni1F74uni1F75uni1F76uni1F77uni1F78uni1F79uni1F7Auni1F7Buni1F7Cuni1F7Duni1F80uni1F81uni1F82uni1F83uni1F84uni1F85uni1F86uni1F87uni1F88uni1F89uni1F8Auni1F8Buni1F8Cuni1F8Duni1F8Euni1F8Funi1F90uni1F91uni1F92uni1F93uni1F94uni1F95uni1F96uni1F97uni1F98uni1F99uni1F9Auni1F9Buni1F9Cuni1F9Duni1F9Euni1F9Funi1FA0uni1FA1uni1FA2uni1FA3uni1FA4uni1FA5uni1FA6uni1FA7uni1FA8uni1FA9uni1FAAuni1FABuni1FACuni1FADuni1FAEuni1FAFuni1FB0uni1FB1uni1FB2uni1FB3uni1FB4uni1FB6uni1FB7uni1FB8uni1FB9uni1FBAuni1FBBuni1FBCuni1FBDuni1FBEuni1FBFuni1FC0uni1FC1uni1FC2uni1FC3uni1FC4uni1FC6uni1FC7uni1FC8uni1FC9uni1FCAuni1FCBuni1FCCuni1FCDuni1FCEuni1FCFuni1FD0uni1FD1uni1FD2uni1FD3uni1FD6uni1FD7uni1FD8uni1FD9uni1FDAuni1FDBuni1FDDuni1FDEuni1FDFuni1FE0uni1FE1uni1FE2uni1FE3uni1FE4uni1FE5uni1FE6uni1FE7uni1FE8uni1FE9uni1FEAuni1FEBuni1FECuni1FEDuni1FEEuni1FEFuni1FF2uni1FF3uni1FF4uni1FF6uni1FF7uni1FF8uni1FF9uni1FFAuni1FFBuni1FFCuni1FFDuni1FFEuni2000uni2001uni2002uni2003uni2004uni2005uni2006uni2007uni2008uni2009uni200Auni200Buni200Cuni200Duni200Euni200Funi2010uni2011 figuredashuni2015uni2016 underscoredbl quotereverseduni201Funi2023onedotenleadertwodotenleaderuni2027uni202Auni202Buni202Cuni202Duni202Euni202Funi2031minuteseconduni2034uni2035uni2036uni2037uni2038uni203B exclamdbluni203Duni203Euni203Funi2040uni2041uni2042uni2043uni2045uni2046uni2047uni2048uni2049uni204Auni204Buni204Cuni204Duni204Euni204Funi2050uni2051uni2052uni2053uni2054uni2055uni2056uni2057uni2058uni2059uni205Auni205Buni205Cuni205Duni205Euni205Funi2060uni2061uni2062uni2063uni206Auni206Buni206Cuni206Duni206Euni206Funi2070uni2071uni2074uni2075uni2076uni2077uni2078uni2079uni207Auni207Buni207Cuni207Duni207Euni207Funi2080uni2081uni2082uni2083uni2084uni2085uni2086uni2087uni2088uni2089uni208Auni208Buni208Cuni208Duni208Euni2090uni2091uni2092uni2093uni2094uni20A0 colonmonetaryuni20A2lirauni20A5uni20A6pesetauni20A8uni20A9uni20AAdongEurouni20ADuni20AEuni20AFuni20B0uni20B1uni20B2uni20B3uni20B4uni20B5uni20D0uni20D1uni20D6uni20D7uni2100uni2101uni2102uni2103uni2104uni2105uni2106uni2107uni2108uni2109uni210Buni210Cuni210Duni210Euni210Funi2110Ifrakturuni2112uni2113uni2114uni2115uni2116uni2117 weierstrassuni2119uni211Auni211BRfrakturuni211D prescriptionuni211Funi2120uni2121uni2123uni2124uni2125uni2126uni2127uni2128uni2129uni212Auni212Buni212Cuni212D estimateduni212Funi2130uni2131uni2132uni2133uni2134alephuni2136uni2137uni2138uni2139uni213Auni213Buni213Cuni213Duni213Euni213Funi2140uni2141uni2142uni2143uni2144uni2145uni2146uni2147uni2148uni2149uni214Buni214Eonethird twothirdsuni2155uni2156uni2157uni2158uni2159uni215A oneeighth threeeighths fiveeighths seveneighthsuni215Funi2160uni2161uni2162uni2163uni2164uni2165uni2166uni2167uni2168uni2169uni216Auni216Buni216Cuni216Duni216Euni216Funi2170uni2171uni2172uni2173uni2174uni2175uni2176uni2177uni2178uni2179uni217Auni217Buni217Cuni217Duni217Euni217Funi2180uni2181uni2182uni2183uni2184 arrowleftarrowup arrowright arrowdown arrowboth arrowupdnuni2196uni2197uni2198uni2199uni219Auni219Buni219Cuni219Duni219Euni219Funi21A0uni21A1uni21A2uni21A3uni21A4uni21A5uni21A6uni21A7 arrowupdnbseuni21A9uni21AAuni21ABuni21ACuni21ADuni21AEuni21AFuni21B0uni21B1uni21B2uni21B3uni21B4carriagereturnuni21B6uni21B7uni21B8uni21B9uni21BAuni21BBuni21BCuni21BDuni21BEuni21BFuni21C0uni21C1uni21C2uni21C3uni21C4uni21C5uni21C6uni21C7uni21C8uni21C9uni21CAuni21CBuni21CCuni21CDuni21CEuni21CF arrowdblleft arrowdblup arrowdblright arrowdbldown arrowdblbothuni21D5uni21D6uni21D7uni21D8uni21D9uni21DAuni21DBuni21DCuni21DDuni21DEuni21DFuni21E0uni21E1uni21E2uni21E3uni21E4uni21E5uni21E6uni21E7uni21E8uni21E9uni21EAuni21EBuni21ECuni21EDuni21EEuni21EFuni21F0uni21F1uni21F2uni21F3uni21F4uni21F5uni21F6uni21F7uni21F8uni21F9uni21FAuni21FBuni21FCuni21FDuni21FEuni21FF universaluni2201 existentialuni2204emptysetgradientelement notelementuni220Asuchthatuni220Cuni220Duni220Euni2210uni2213uni2214uni2216 asteriskmathuni2218uni221Buni221C proportional orthogonalangleuni2221uni2222uni2223uni2224uni2225uni2226 logicaland logicalor intersectionunionuni222Cuni222Duni222Euni222Funi2230uni2231uni2232uni2233 thereforeuni2235uni2236uni2237uni2238uni2239uni223Auni223Bsimilaruni223Duni223Euni223Funi2240uni2241uni2242uni2243uni2244 congruentuni2246uni2247uni2249uni224Auni224Buni224Cuni224Duni224Euni224Funi2250uni2251uni2252uni2253uni2254uni2255uni2256uni2257uni2258uni2259uni225Auni225Buni225Cuni225Duni225Euni225F equivalenceuni2262uni2263uni2266uni2267uni2268uni2269uni226Auni226Buni226Cuni226Duni226Euni226Funi2270uni2271uni2272uni2273uni2274uni2275uni2276uni2277uni2278uni2279uni227Auni227Buni227Cuni227Duni227Euni227Funi2280uni2281 propersubsetpropersuperset notsubsetuni2285 reflexsubsetreflexsupersetuni2288uni2289uni228Auni228Buni228Cuni228Duni228Euni228Funi2290uni2291uni2292uni2293uni2294 circleplusuni2296circlemultiplyuni2298uni2299uni229Auni229Buni229Cuni229Duni229Euni229Funi22A0uni22A1uni22A2uni22A3uni22A4 perpendicularuni22A6uni22A7uni22A8uni22A9uni22AAuni22ABuni22ACuni22ADuni22AEuni22AFuni22B2uni22B3uni22B4uni22B5uni22B6uni22B7uni22B8uni22B9uni22BAuni22BBuni22BCuni22BDuni22BEuni22BFuni22C0uni22C1uni22C2uni22C3uni22C4dotmathuni22C6uni22C8uni22C9uni22CAuni22CBuni22CCuni22CDuni22D6uni22D7uni22D8uni22D9uni22DAuni22DBuni22DCuni22DDuni22DEuni22DFuni22E0uni22E1uni22E2uni22E3uni22E4uni22E5uni22E6uni22E7uni22E8uni22E9uni22EAuni22EBuni22ECuni22EDuni22EEuni22EFuni22F0uni22F1uni22F2uni22F3uni22F4uni22F5uni22F6uni22F7uni22F8uni22F9uni22FAuni22FBuni22FCuni22FDuni22FEuni22FFuni2300uni2301houseuni2303uni2304uni2305uni2306uni2307uni2308uni2309uni230Auni230Buni230Cuni230Duni230Euni230F revlogicalnotuni2311uni2318uni2319uni231Cuni231Duni231Euni231F integraltp integralbtuni2324uni2325uni2326uni2327uni2328uni232Buni232Cuni2373uni2374uni2375uni237Auni237Duni2387uni2394uni239Buni239Cuni239Duni239Euni239Funi23A0uni23A1uni23A2uni23A3uni23A4uni23A5uni23A6uni23A7uni23A8uni23A9uni23AAuni23ABuni23ACuni23ADuni23AEuni23CEuni23CFuni23E3uni23E5uni2422uni2423uni2460uni2461uni2462uni2463uni2464uni2465uni2466uni2467uni2468uni2469upblockuni2581uni2582uni2583dnblockuni2585uni2586uni2587blockuni2589uni258Auni258Blfblockuni258Duni258Euni258Frtblockltshadeshadedkshadeuni2594uni2595uni2596uni2597uni2598uni2599uni259Auni259Buni259Cuni259Duni259Euni259F filledboxH22073uni25A2uni25A3uni25A4uni25A5uni25A6uni25A7uni25A8uni25A9H18543H18551 filledrectuni25ADuni25AEuni25AFuni25B0uni25B1triagupuni25B3uni25B4uni25B5uni25B6uni25B7uni25B8uni25B9triagrtuni25BBtriagdnuni25BDuni25BEuni25BFuni25C0uni25C1uni25C2uni25C3triaglfuni25C5uni25C6uni25C7uni25C8uni25C9circleuni25CCuni25CDuni25CEH18533uni25D0uni25D1uni25D2uni25D3uni25D4uni25D5uni25D6uni25D7 invbullet invcircleuni25DAuni25DBuni25DCuni25DDuni25DEuni25DFuni25E0uni25E1uni25E2uni25E3uni25E4uni25E5 openbulletuni25E7uni25E8uni25E9uni25EAuni25EBuni25ECuni25EDuni25EEuni25EFuni25F0uni25F1uni25F2uni25F3uni25F4uni25F5uni25F6uni25F7uni25F8uni25F9uni25FAuni25FBuni25FCuni25FDuni25FEuni25FFuni2600uni2601uni2602uni2603uni2604uni2605uni2606uni2607uni2608uni2609uni260Auni260Buni260Cuni260Duni260Euni260Funi2610uni2611uni2612uni2613uni2614uni2615uni2616uni2617uni2618uni2619uni261Auni261Buni261Cuni261Duni261Euni261Funi2620uni2621uni2622uni2623uni2624uni2625uni2626uni2627uni2628uni2629uni262Auni262Buni262Cuni262Duni262Euni262Funi2630uni2631uni2632uni2633uni2634uni2635uni2636uni2637uni2638uni2639 smileface invsmilefacesununi263Duni263Euni263Ffemaleuni2641maleuni2643uni2644uni2645uni2646uni2647uni2648uni2649uni264Auni264Buni264Cuni264Duni264Euni264Funi2650uni2651uni2652uni2653uni2654uni2655uni2656uni2657uni2658uni2659uni265Auni265Buni265Cuni265Duni265Euni265Fspadeuni2661uni2662clubuni2664heartdiamonduni2667uni2668uni2669 musicalnotemusicalnotedbluni266Cuni266Duni266Euni266Funi2670uni2671uni2672uni2673uni2674uni2675uni2676uni2677uni2678uni2679uni267Auni267Buni267Cuni267Duni267Euni267Funi2680uni2681uni2682uni2683uni2684uni2685uni2686uni2687uni2688uni2689uni268Auni268Buni268Cuni268Duni268Euni268Funi2690uni2691uni2692uni2693uni2694uni2695uni2696uni2697uni2698uni2699uni269Auni269Buni269Cuni26A0uni26A1uni26A2uni26A3uni26A4uni26A5uni26A6uni26A7uni26A8uni26A9uni26AAuni26ABuni26ACuni26ADuni26AEuni26AFuni26B0uni26B1uni26B2uni2701uni2702uni2703uni2704uni2706uni2707uni2708uni2709uni270Cuni270Duni270Euni270Funi2710uni2711uni2712uni2713uni2714uni2715uni2716uni2717uni2718uni2719uni271Auni271Buni271Cuni271Duni271Euni271Funi2720uni2721uni2722uni2723uni2724uni2725uni2726uni2727uni2729uni272Auni272Buni272Cuni272Duni272Euni272Funi2730uni2731uni2732uni2733uni2734uni2735uni2736uni2737uni2738uni2739uni273Auni273Buni273Cuni273Duni273Euni273Funi2740uni2741uni2742uni2743uni2744uni2745uni2746uni2747uni2748uni2749uni274Auni274Buni274Duni274Funi2750uni2751uni2752uni2756uni2758uni2759uni275Auni275Buni275Cuni275Duni275Euni2761uni2762uni2763uni2764uni2765uni2766uni2767uni2768uni2769uni276Auni276Buni276Cuni276Duni276Euni276Funi2770uni2771uni2772uni2773uni2774uni2775uni2776uni2777uni2778uni2779uni277Auni277Buni277Cuni277Duni277Euni277Funi2780uni2781uni2782uni2783uni2784uni2785uni2786uni2787uni2788uni2789uni278Auni278Buni278Cuni278Duni278Euni278Funi2790uni2791uni2792uni2793uni2794uni2798uni2799uni279Auni279Buni279Cuni279Duni279Euni279Funi27A0uni27A1uni27A2uni27A3uni27A4uni27A5uni27A6uni27A7uni27A8uni27A9uni27AAuni27ABuni27ACuni27ADuni27AEuni27AFuni27B1uni27B2uni27B3uni27B4uni27B5uni27B6uni27B7uni27B8uni27B9uni27BAuni27BBuni27BCuni27BDuni27BEuni27E0uni27E6uni27E7uni27E8uni27E9uni27EAuni27EBuni27F0uni27F1uni27F2uni27F3uni27F4uni27F5uni27F6uni27F7uni27F8uni27F9uni27FAuni27FBuni27FCuni27FDuni27FEuni27FFuni2800uni2801uni2802uni2803uni2804uni2805uni2806uni2807uni2808uni2809uni280Auni280Buni280Cuni280Duni280Euni280Funi2810uni2811uni2812uni2813uni2814uni2815uni2816uni2817uni2818uni2819uni281Auni281Buni281Cuni281Duni281Euni281Funi2820uni2821uni2822uni2823uni2824uni2825uni2826uni2827uni2828uni2829uni282Auni282Buni282Cuni282Duni282Euni282Funi2830uni2831uni2832uni2833uni2834uni2835uni2836uni2837uni2838uni2839uni283Auni283Buni283Cuni283Duni283Euni283Funi2840uni2841uni2842uni2843uni2844uni2845uni2846uni2847uni2848uni2849uni284Auni284Buni284Cuni284Duni284Euni284Funi2850uni2851uni2852uni2853uni2854uni2855uni2856uni2857uni2858uni2859uni285Auni285Buni285Cuni285Duni285Euni285Funi2860uni2861uni2862uni2863uni2864uni2865uni2866uni2867uni2868uni2869uni286Auni286Buni286Cuni286Duni286Euni286Funi2870uni2871uni2872uni2873uni2874uni2875uni2876uni2877uni2878uni2879uni287Auni287Buni287Cuni287Duni287Euni287Funi2880uni2881uni2882uni2883uni2884uni2885uni2886uni2887uni2888uni2889uni288Auni288Buni288Cuni288Duni288Euni288Funi2890uni2891uni2892uni2893uni2894uni2895uni2896uni2897uni2898uni2899uni289Auni289Buni289Cuni289Duni289Euni289Funi28A0uni28A1uni28A2uni28A3uni28A4uni28A5uni28A6uni28A7uni28A8uni28A9uni28AAuni28ABuni28ACuni28ADuni28AEuni28AFuni28B0uni28B1uni28B2uni28B3uni28B4uni28B5uni28B6uni28B7uni28B8uni28B9uni28BAuni28BBuni28BCuni28BDuni28BEuni28BFuni28C0uni28C1uni28C2uni28C3uni28C4uni28C5uni28C6uni28C7uni28C8uni28C9uni28CAuni28CBuni28CCuni28CDuni28CEuni28CFuni28D0uni28D1uni28D2uni28D3uni28D4uni28D5uni28D6uni28D7uni28D8uni28D9uni28DAuni28DBuni28DCuni28DDuni28DEuni28DFuni28E0uni28E1uni28E2uni28E3uni28E4uni28E5uni28E6uni28E7uni28E8uni28E9uni28EAuni28EBuni28ECuni28EDuni28EEuni28EFuni28F0uni28F1uni28F2uni28F3uni28F4uni28F5uni28F6uni28F7uni28F8uni28F9uni28FAuni28FBuni28FCuni28FDuni28FEuni28FFuni2906uni2907uni290Auni290Buni2940uni2941uni2983uni2984uni29CEuni29CFuni29D0uni29D1uni29D2uni29D3uni29D4uni29D5uni29EBuni29FAuni29FBuni2A00uni2A01uni2A02uni2A0Cuni2A0Duni2A0Euni2A0Funi2A10uni2A11uni2A12uni2A13uni2A14uni2A15uni2A16uni2A17uni2A18uni2A19uni2A1Auni2A1Buni2A1Cuni2A2Funi2A7Duni2A7Euni2A7Funi2A80uni2A81uni2A82uni2A83uni2A84uni2A85uni2A86uni2A87uni2A88uni2A89uni2A8Auni2A8Buni2A8Cuni2A8Duni2A8Euni2A8Funi2A90uni2A91uni2A92uni2A93uni2A94uni2A95uni2A96uni2A97uni2A98uni2A99uni2A9Auni2A9Buni2A9Cuni2A9Duni2A9Euni2A9Funi2AA0uni2AAEuni2AAFuni2AB0uni2AB1uni2AB2uni2AB3uni2AB4uni2AB5uni2AB6uni2AB7uni2AB8uni2AB9uni2ABAuni2AF9uni2AFAuni2B00uni2B01uni2B02uni2B03uni2B04uni2B05uni2B06uni2B07uni2B08uni2B09uni2B0Auni2B0Buni2B0Cuni2B0Duni2B0Euni2B0Funi2B10uni2B11uni2B12uni2B13uni2B14uni2B15uni2B16uni2B17uni2B18uni2B19uni2B1Auni2B20uni2B21uni2B22uni2B23uni2C60uni2C61uni2C62uni2C63uni2C64uni2C65uni2C66uni2C67uni2C68uni2C69uni2C6Auni2C6Buni2C6Cuni2C74uni2C75uni2C76uni2C77uni2D30uni2D31uni2D32uni2D33uni2D34uni2D35uni2D36uni2D37uni2D38uni2D39uni2D3Auni2D3Buni2D3Cuni2D3Duni2D3Euni2D3Funi2D40uni2D41uni2D42uni2D43uni2D44uni2D45uni2D46uni2D47uni2D48uni2D49uni2D4Auni2D4Buni2D4Cuni2D4Duni2D4Euni2D4Funi2D50uni2D51uni2D52uni2D53uni2D54uni2D55uni2D56uni2D57uni2D58uni2D59uni2D5Auni2D5Buni2D5Cuni2D5Duni2D5Euni2D5Funi2D60uni2D61uni2D62uni2D63uni2D64uni2D65uni2D6FuniF000uniF001uniF208uniF25FuniF6C5uniFB00uniFB03uniFB04uniFB05uniFB06uniFB13uniFB14uniFB15uniFB16uniFB17uniFB1DuniFB1EuniFB1FuniFB20uniFB21uniFB22uniFB23uniFB24uniFB25uniFB26uniFB27uniFB28uniFB29uniFB2AuniFB2BuniFB2CuniFB2DuniFB2EuniFB2FuniFB30uniFB31uniFB32uniFB33uniFB34uniFB35uniFB36uniFB38uniFB39uniFB3AuniFB3BuniFB3CuniFB3EuniFB40uniFB41uniFB43uniFB44uniFB46uniFB47uniFB48uniFB49uniFB4AuniFB4BuniFB4CuniFB4DuniFB4EuniFB4FuniFB52uniFB53uniFB54uniFB55uniFB56uniFB57uniFB58uniFB59uniFB5AuniFB5BuniFB5CuniFB5DuniFB5EuniFB5FuniFB60uniFB61uniFB62uniFB63uniFB64uniFB65uniFB66uniFB67uniFB68uniFB69uniFB6AuniFB6BuniFB6CuniFB6DuniFB6EuniFB6FuniFB70uniFB71uniFB72uniFB73uniFB74uniFB75uniFB76uniFB77uniFB78uniFB79uniFB7AuniFB7BuniFB7CuniFB7DuniFB7EuniFB7FuniFB80uniFB81uniFB8AuniFB8BuniFB8CuniFB8DuniFB8EuniFB8FuniFB90uniFB91uniFB92uniFB93uniFB94uniFB95uniFB9EuniFB9FuniFBD9uniFBDAuniFBE8uniFBE9uniFBFCuniFBFDuniFBFEuniFBFFuniFE00uniFE01uniFE02uniFE03uniFE04uniFE05uniFE06uniFE07uniFE08uniFE09uniFE0AuniFE0BuniFE0CuniFE0DuniFE0EuniFE0FuniFE70uniFE71uniFE72uniFE73uniFE74uniFE76uniFE77uniFE78uniFE79uniFE7AuniFE7BuniFE7CuniFE7DuniFE7EuniFE7FuniFE80uniFE81uniFE82uniFE83uniFE84uniFE85uniFE86uniFE87uniFE88uniFE89uniFE8AuniFE8BuniFE8CuniFE8DuniFE8EuniFE8FuniFE90uniFE91uniFE92uniFE93uniFE94uniFE95uniFE96uniFE97uniFE98uniFE99uniFE9AuniFE9BuniFE9CuniFE9DuniFE9EuniFE9FuniFEA0uniFEA1uniFEA2uniFEA3uniFEA4uniFEA5uniFEA6uniFEA7uniFEA8uniFEA9uniFEAAuniFEABuniFEACuniFEADuniFEAEuniFEAFuniFEB0uniFEB1uniFEB2uniFEB3uniFEB4uniFEB5uniFEB6uniFEB7uniFEB8uniFEB9uniFEBAuniFEBBuniFEBCuniFEBDuniFEBEuniFEBFuniFEC0uniFEC1uniFEC2uniFEC3uniFEC4uniFEC5uniFEC6uniFEC7uniFEC8uniFEC9uniFECAuniFECBuniFECCuniFECDuniFECEuniFECFuniFED0uniFED1uniFED2uniFED3uniFED4uniFED5uniFED6uniFED7uniFED8uniFED9uniFEDAuniFEDBuniFEDCuniFEDDuniFEDEuniFEDFuniFEE0uniFEE1uniFEE2uniFEE3uniFEE4uniFEE5uniFEE6uniFEE7uniFEE8uniFEE9uniFEEAuniFEEBuniFEECuniFEEDuniFEEEuniFEEFuniFEF0uniFEF1uniFEF2uniFEF3uniFEF4uniFEF5uniFEF6uniFEF7uniFEF8uniFEF9uniFEFAuniFEFBuniFEFCuniFEFFuniFFFDu1D300u1D301u1D302u1D303u1D304u1D305u1D306u1D307u1D308u1D309u1D30Au1D30Bu1D30Cu1D30Du1D30Eu1D30Fu1D310u1D311u1D312u1D313u1D314u1D315u1D316u1D317u1D318u1D319u1D31Au1D31Bu1D31Cu1D31Du1D31Eu1D31Fu1D320u1D321u1D322u1D323u1D324u1D325u1D326u1D327u1D328u1D329u1D32Au1D32Bu1D32Cu1D32Du1D32Eu1D32Fu1D330u1D331u1D332u1D333u1D334u1D335u1D336u1D337u1D338u1D339u1D33Au1D33Bu1D33Cu1D33Du1D33Eu1D33Fu1D340u1D341u1D342u1D343u1D344u1D345u1D346u1D347u1D348u1D349u1D34Au1D34Bu1D34Cu1D34Du1D34Eu1D34Fu1D350u1D351u1D352u1D353u1D354u1D355u1D356u1D538u1D539u1D53Bu1D53Cu1D53Du1D53Eu1D540u1D541u1D542u1D543u1D544u1D546u1D54Au1D54Bu1D54Cu1D54Du1D54Eu1D54Fu1D550u1D552u1D553u1D554u1D555u1D556u1D557u1D558u1D559u1D55Au1D55Bu1D55Cu1D55Du1D55Eu1D55Fu1D560u1D561u1D562u1D563u1D564u1D565u1D566u1D567u1D568u1D569u1D56Au1D56B dlLtcaronDieresisAcuteTildeGrave CircumflexCaron uni0311.caseBreve Dotaccent Hungarumlaut Doubleacute arabic_dot arabic_2dots arabic_3dotsarabic_3dots_aarabic_2dots_a arabic_4dots uni066E.fina uni066E.init uni066E.medi uni06A1.fina uni06A1.init uni06A1.medi uni066F.fina uni066F.init uni066F.medi uni06BA.init uni06BA.medi arabic_ring uni067C.fina uni067C.init uni067C.medi uni067D.fina uni067D.init uni067D.medi uni0681.fina uni0681.init uni0681.medi uni0682.fina uni0682.init uni0682.medi uni0685.fina uni0685.init uni0685.medi uni06BF.fina uni06BF.init uni06BF.mediarabic_gaf_barEng.altuni0268.dotlessuni029D.dotless uni03080304 uni03040308 uni03070304 uni03080301 uni03080300 uni03040301 uni03040300 uni03030304 uni0308030C uni03030308 uni030C0307 uni03030301 uni03020301 uni03020300 uni03020303 uni03060303 uni03060301 uni03060300 uni03060309 uni03020309 uni03010307 brailledotJ.alt uni0695.finauniFEAE.fina.longstart uni06B5.fina uni06B5.init uni06B5.medi uni06CE.fina uni06CE.init uni06CE.medi uni0692.final.alt uni06D5.finauni0478.monographuni0479.monographiogonek.dotlessuni2148.dotlessuni2149.dotlessuni1E2D.dotlessuni1ECB.dotlessdcoI.alt arrow.base uni0651064B uni0651064C uni064B0651 uni0651064E uni0651064F uni064E0651 uni0654064E uni0654064F uni07CA.fina uni07CA.medi uni07CA.init uni07CB.fina uni07CB.medi uni07CB.init uni07CC.fina uni07CC.medi uni07CC.init uni07CD.fina uni07CD.medi uni07CD.init uni07CE.fina uni07CE.medi uni07CE.init uni07CF.fina uni07CF.medi uni07CF.init uni07D0.fina uni07D0.medi uni07D0.init uni07D1.fina uni07D1.medi uni07D1.init uni07D2.fina uni07D2.medi uni07D2.init uni07D3.fina uni07D3.medi uni07D3.init uni07D4.fina uni07D4.medi uni07D4.init uni07D5.fina uni07D5.medi uni07D5.init uni07D6.fina uni07D6.medi uni07D6.init uni07D7.fina uni07D7.medi uni07D7.init uni07D8.fina uni07D8.medi uni07D8.init uni07D9.fina uni07D9.medi uni07D9.init uni07DA.fina uni07DA.medi uni07DA.init uni07DB.fina uni07DB.medi uni07DB.init uni07DC.fina uni07DC.medi uni07DC.init uni07DD.fina uni07DD.medi uni07DD.init uni07DE.fina uni07DE.medi uni07DE.init uni07DF.fina uni07DF.medi uni07DF.init uni07E0.fina uni07E0.medi uni07E0.init uni07E1.fina uni07E1.medi uni07E1.init uni07E2.fina uni07E2.medi uni07E2.init uni07E3.fina uni07E3.medi uni07E3.init uni07E4.fina uni07E4.medi uni07E4.init uni07E5.fina uni07E5.medi uni07E5.init uni07E6.fina uni07E6.medi uni07E6.init uni07E7.fina uni07E7.medi uni07E7.init@%2%%A:B2SAS//2ݖ}ٻ֊A}G}G͖2ƅ%]%]@@%d%d%A2dA  d   A(]%]@%..%A  %d%@~}}~}}|d{T{%zyxw v utsrqponl!kjBjSih}gBfedcba:`^ ][ZYX YX WW2VUTUBTSSRQJQP ONMNMLKJKJIJI IH GFEDC-CBAK@?>=>=<=<; <@; :987876765 65 43 21 21 0/ 0 / .- .- ,2+*%+d*)*%)('%(A'%&% &% $#"!! d d BBBdB-B}d       -d@--d++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++libgd-gd-2.1.1/tests/freetype/bug00132.c000066400000000000000000000015701245535672000174740ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" #include "gdfontl.h" int main() { gdImagePtr im; int error = 0; char path[2048]; const char *file_exp = "bug00132_exp.png"; char *ret = NULL; im = gdImageCreateTrueColor(50, 30); if (!im) { printf("can't get truecolor image\n"); return 1; } gdImageAlphaBlending(im, 0); gdImageFilledRectangle(im, 0, 0, 200, 200, gdTrueColorAlpha(0, 0, 0, 127)); sprintf(path, "%s/freetype/DejaVuSans.ttf", GDTEST_TOP_DIR); ret = gdImageStringFT(im, NULL, - 0xFFFFFF, path, 14.0, 0.0, 10, 20, "ϑ θ"); if (ret) { error = 1; printf("%s\n", ret); } else { sprintf(path, "%s/freetype/%s", GDTEST_TOP_DIR, file_exp); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; printf("Reference image and destination differ\n"); } } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/freetype/bug00132_exp.png000066400000000000000000000003311245535672000207040ustar00rootroot00000000000000PNG  IHDR2nQMIDATXQ Cx+!H0m}5*! j EDH*\om!4Ұ޳5D3ɺƚėѦI|#8-+=R)򀢍 lc-~t!Z5jT Z~ !XķaIENDB`libgd-gd-2.1.1/tests/gd/000077500000000000000000000000001245535672000147315ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gd/CMakeLists.txt000066400000000000000000000004141245535672000174700ustar00rootroot00000000000000 SET(TESTS_FILES gd_im2im gd_null gd_num_colors gd_versiontest ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gd/crafted_num_colors.gd000066400000000000000000000020171245535672000211150ustar00rootroot00000000000000ޭlibgd-gd-2.1.1/tests/gd/gd_im2im.c000066400000000000000000000024671245535672000165750ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int r, g, b; void *p; int size = 0; int status = 0; CuTestImageResult result = {0, 0}; src = gdImageCreate(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } r = gdImageColorAllocate(src, 0xFF, 0, 0); g = gdImageColorAllocate(src, 0, 0xFF, 0); b = gdImageColorAllocate(src, 0, 0, 0xFF); gdImageFilledRectangle(src, 0, 0, 99, 99, r); gdImageRectangle(src, 20, 20, 79, 79, g); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_GD(x) do { \ FILE *fp; \ \ fp = fopen("gd_im2im_" #x ".gd", "wb"); \ if (fp) { \ gdImageGd(x, fp); \ fclose(fp); \ } \ } while (0) OUTPUT_GD(src); p = gdImageGdPtr(src, &size); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromGdPtr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_GD(dst); gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/gd/gd_null.c000066400000000000000000000002751245535672000165250ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromGd(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImageGd(im, NULL); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/gd/gd_num_colors.c000066400000000000000000000005201245535672000177240ustar00rootroot00000000000000#include "gd.h" #include #include "gdtest.h" int main() { gdImagePtr im; char path[1024]; FILE* fp; sprintf(path, "%s/gd/crafted_num_colors.gd", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { return 1; } im = gdImageCreateFromGd(fp); fclose(fp); if (im) { gdImageDestroy(im); return 1; } return 0; } libgd-gd-2.1.1/tests/gd/gd_versiontest.c000066400000000000000000000010551245535672000201350ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { char buffer[100]; gdTestAssert(GD_MAJOR_VERSION == gdMajorVersion()); gdTestAssert(GD_MINOR_VERSION == gdMinorVersion()); gdTestAssert(GD_RELEASE_VERSION == gdReleaseVersion()); gdTestAssert(strcmp(GD_EXTRA_VERSION, gdExtraVersion()) == 0); sprintf(buffer, "%d.%d.%d%s", GD_MAJOR_VERSION, GD_MINOR_VERSION, GD_RELEASE_VERSION, GD_EXTRA_VERSION); gdTestAssert(strcmp(GD_VERSION_STRING, gdVersionString()) == 0); return gdNumFailures(); } libgd-gd-2.1.1/tests/gd2/000077500000000000000000000000001245535672000150135ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gd2/CMakeLists.txt000066400000000000000000000004111245535672000175470ustar00rootroot00000000000000 SET(TESTS_FILES gd2_read gd2_empty_file gd2_im2im gd2_null ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gd2/conv_gd2_exp.gd2000066400000000000000000000000001245535672000177540ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gd2/conv_test.gd2000066400000000000000000000006471245535672000174240ustar00rootroot00000000000000gd2 libgd-gd-2.1.1/tests/gd2/conv_test_exp.png000066400000000000000000000001271245535672000204010ustar00rootroot00000000000000PNG  IHDR PXIDATc`!`e3M4MoS>TuIENDB`libgd-gd-2.1.1/tests/gd2/empty.gd2000066400000000000000000000000001245535672000165350ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gd2/gd2_empty_file.c000066400000000000000000000006461245535672000200560ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main() { gdImagePtr im; FILE *fp; char path[1024]; sprintf(path, "%s/gd2/empty.gd2", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { printf("failed, cannot open file (%s)\n", path); return 1; } im = gdImageCreateFromGd2(fp); fclose(fp); if (!im) { return 0; } else { gdImageDestroy(im); return 1; } } libgd-gd-2.1.1/tests/gd2/gd2_im2im.c000066400000000000000000000027361245535672000167400ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int r, g, b; void *p; int size = 0; int status = 0; CuTestImageResult result = {0, 0}; src = gdImageCreate(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } r = gdImageColorAllocate(src, 0xFF, 0, 0); g = gdImageColorAllocate(src, 0, 0xFF, 0); b = gdImageColorAllocate(src, 0, 0, 0xFF); gdImageFilledRectangle(src, 0, 0, 99, 99, r); gdImageRectangle(src, 20, 20, 79, 79, g); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_GD2(x) do { \ FILE *fp; \ \ fp = fopen("gd2_im2im_" #x ".gd2", "wb"); \ if (fp) { \ gdImageGd2(x, fp, (GD2_CHUNKSIZE_MIN+GD2_CHUNKSIZE_MAX)/2, GD2_FMT_COMPRESSED); \ fclose(fp); \ } \ } while (0) OUTPUT_GD2(src); p = gdImageGd2Ptr(src, (GD2_CHUNKSIZE_MIN+GD2_CHUNKSIZE_MAX)/2, GD2_FMT_COMPRESSED, &size); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromGd2Ptr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_GD2(dst); gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/gd2/gd2_null.c000066400000000000000000000003171245535672000166660ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromGd2(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImageGd2(im, NULL, 0, GD2_FMT_RAW); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/gd2/gd2_read.c000066400000000000000000000011321245535672000166230ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main() { int error; gdImagePtr im; FILE *fp; char path[1024]; sprintf(path, "%s/gd2/conv_test.gd2", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { printf("failed, cannot open file\n"); return 1; } im = gdImageCreateFromGd2(fp); fclose(fp); sprintf(path, "%s/gd2/conv_test_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; gdImageDestroy(im); } else { if (im) { gdImageDestroy(im); error = 0; } else { error = 1; } } return error; } libgd-gd-2.1.1/tests/gdimagearc/000077500000000000000000000000001245535672000164225ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagearc/CMakeLists.txt000066400000000000000000000003431245535672000211620ustar00rootroot00000000000000SET(TESTS_FILES bug00079 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagearc/bug00079.c000066400000000000000000000007531245535672000177500ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int error = 0; char path[1024]; im = gdImageCreateTrueColor(300, 300); gdImageFilledRectangle(im, 0,0, 299,299, 0xFFFFFF); gdImageSetAntiAliased(im, 0x000000); gdImageArc(im, 300, 300, 600,600, 0, 360, gdAntiAliased); sprintf(path, "%s/gdimagearc/bug00079_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { printf("%s failed\n", path); error = 1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagearc/bug00079_exp.png000066400000000000000000000041171245535672000211640ustar00rootroot00000000000000PNG  IHDR,,"IDATxQ#IRo ,e@ A AzxAR13ڜ9&b:`vg!0_#zuuu}}s!!]cl!4 u8!Z_2I!E6)!`y/Bvn? ^uժЄdZVU%!$/u\BP5owBUyD2y!3iy(s??KovetCo}~*N;/]i¦hF./B؜3O{aCۭg Y΄~^eqZo/2 +dPMX,F/qlOOOF/ӄl6Οӄv \J˳yY$^D2x{]1YVOfLYC)0;фyzzy||~hYYpm& -0 a [x޸pVFM/i9sNGIpBp*oqt0= d!LiFĝ0фiXE0&0\H/Gs% M80"cC`HZB8k&Nx O`R&Ǹ2oI ¯I CV̝ YEBaAMu]w{{+DnSq=@m#qTA!@2h%|B $+ͅpZ V䩡ۑ yj8*dJ 9?H*Ch%H sOh%HA2 R  R %8*J !HъRCh%H  u(uOh%H5JP R"Ԥ Rԧ )8^?$VL~ZEHAjUFr\.+caC hBy{^zyZ]U{uUvx't)9^\iJvQhM^!JB5H2 Wڴ)y mʥ 7}YY4eYeM6 CmbGPz obBM@=ԆF#1Mn]#!`YCoHdo5 |iz"ߙ)j3G=#昔7/q&(5MۄjN 4azB6UiA8T#8$M|B҇HIB5 cQ*qkA*eA!eqA!Y*''M}!&jFKBhH0J1K\ڄ}@B0!`B..jB?:B6>B5I@#P B*BƄHB5 @BP BZBHB5 @r !B6`b*S8 -'`"B 20Ba:gZd`:f&%L!BSԉ&T05!`BԎ5'0!`߆Џ/< y|;w1y|݄60!`B}=}1|фj$L!B/020&|}} (Ц\__|h&` !;>5 !O!B0!`020&TB!B0!`Sq◄SB&L!B?!(B !Jsb:  !B&G@?4!ӄL!by( B0!`B !B&L!B0!`B !B&Eh?]z w[@qp IENDB`libgd-gd-2.1.1/tests/gdimagecolorclosest/000077500000000000000000000000001245535672000203705ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecolorclosest/CMakeLists.txt000066400000000000000000000003561245535672000231340ustar00rootroot00000000000000SET(TESTS_FILES gdimagecolorclosest ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecolorclosest/gdimagecolorclosest.c000066400000000000000000000024471245535672000245740ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int error = 0; int c, i; im = gdImageCreateTrueColor(5, 5); c = gdImageColorClosest(im, 255, 0, 255); gdImageDestroy(im); if (gdTestAssert(c==0xFF00FF) != 1) { error = -1; } im = gdImageCreate(5, 5); c = gdImageColorClosest(im, 255, 0, 255); if (gdTestAssert(c==-1) != 1) { error = -1; } gdImageDestroy(im); im = gdImageCreate(5, 5); c = gdImageColorAllocate(im, 255, 0, 255); c = gdImageColorClosest(im, 255, 0, 255); c = gdTrueColorAlpha(gdImageRed(im, c), gdImageGreen(im, c), gdImageBlue(im, c), 0); gdImageDestroy(im); if (gdTestAssert(c==0xFF00FF) != 1) { error = -1; } im = gdImageCreate(5, 5); for (i=0; i < 255; i++) { c = gdImageColorAllocate(im, 255, 0, 0); } c = gdImageColorClosest(im, 255, 0, 0); c = gdTrueColorAlpha(gdImageRed(im, c), gdImageGreen(im, c), gdImageBlue(im, c), 0); gdImageDestroy(im); if (gdTestAssert(c==0xFF0000) != 1) { error = -1; } im = gdImageCreate(5, 5); for (i=0; i < 256; i++) { c = gdImageColorAllocate(im, 255, 0, 0); } c = gdImageColorClosest(im, 255, 0, 0); c = gdTrueColorAlpha(gdImageRed(im, c), gdImageGreen(im, c), gdImageBlue(im, c), 0); gdImageDestroy(im); if (gdTestAssert(c==0xFF0000) != 1) { error = -1; } return error; } libgd-gd-2.1.1/tests/gdimagecolordeallocate/000077500000000000000000000000001245535672000210115ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecolordeallocate/CMakeLists.txt000066400000000000000000000003611245535672000235510ustar00rootroot00000000000000SET(TESTS_FILES gdimagecolordeallocate ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecolordeallocate/gdimagecolordeallocate.c000066400000000000000000000010031245535672000256210ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int c; im = gdImageCreate(1, 1); /* test for deallocating a color */ c = gdImageColorAllocate(im, 255, 255, 255); if (c < 0) { gdImageDestroy(im); return 1; } gdImageColorDeallocate(im, c); if (!im->open[c]) { gdImageDestroy(im); return 1; } /* just see whether it is OK with out-of-bounds values */ gdImageColorDeallocate(im, gdMaxColors); gdImageColorDeallocate(im, -1); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/gdimagecolorexact/000077500000000000000000000000001245535672000200205ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecolorexact/CMakeLists.txt000066400000000000000000000003541245535672000225620ustar00rootroot00000000000000SET(TESTS_FILES gdimagecolorexact ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecolorexact/gdimagecolorexact.c000066400000000000000000000030271245535672000236470ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int error = 0; int c, c1, c2, c3, c4, color; im = gdImageCreateTrueColor(5, 5); c = gdImageColorExact(im, 255, 0, 255); c2 = gdImageColorExactAlpha(im, 255, 0, 255, 100); gdImageDestroy(im); if (gdTestAssert(c == 0xFF00FF) != 1) { error = -1; } if (gdTestAssert(c2 == 0x64FF00FF) != 1) { error = -1; } im = gdImageCreate(5, 5); c1 = gdImageColorAllocate(im, 255, 0, 255); c2 = gdImageColorAllocate(im, 255, 200, 0); c3 = gdImageColorAllocateAlpha(im, 255, 0, 255, 100); c1 = gdImageColorExact(im, 255, 0, 255); c2 = gdImageColorExact(im, 255, 200, 0); c3 = gdImageColorExactAlpha(im, 255, 0, 255, 100); c4 = gdImageColorExactAlpha(im, 255, 34, 255, 100); if (gdTestAssert(c1 == 0) != 1) { error = -1; } if (gdTestAssert(c2 == 1) != 1) { error = -1; } if (gdTestAssert(c3 == 2) != 1) { error = -1; } if (gdTestAssert(c4 == -1) != 1) { error = -1; } color = gdTrueColorAlpha(gdImageRed(im, c1), gdImageGreen(im, c1), gdImageBlue(im, c1), 0); if (gdTestAssert(color == 0xFF00FF) != 1) { error = -1; } color = gdTrueColorAlpha(gdImageRed(im, c2), gdImageGreen(im, c2), gdImageBlue(im, c2), 0); if (gdTestAssert(color == 0xFFC800) != 1) { error = -1; } color = gdTrueColorAlpha(gdImageRed(im, c3), gdImageGreen(im, c3), gdImageBlue(im, c3), 0); if (gdTestAssert(color == 0xFF00FF) != 1) { error = -1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagecolorreplace/000077500000000000000000000000001245535672000203275ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecolorreplace/CMakeLists.txt000066400000000000000000000003561245535672000230730ustar00rootroot00000000000000SET(TESTS_FILES gdimagecolorreplace ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecolorreplace/gdimagecolorreplace.c000066400000000000000000000071031245535672000244640ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" static int callback(gdImagePtr im, int src) { int r, g, b; r = gdImageRed(im, src); g = gdImageGreen(im, src); b = gdImageBlue(im, src); if (b & 0xFF) { return gdImageColorResolve(im, 0x0F & r, 0x0F & g, 0); } else { return -1; } } static void run_tests(gdImagePtr im, int *error) { int black, \ white, \ cosmic_latte, \ cream, \ ivory, \ magnolia, \ old_lace, \ seashell, \ yellow, \ c, d; int src[2], dst[2]; int n; #define COLOR(name, r, g, b) name = gdImageColorAllocateAlpha(im, r, g, b, gdAlphaOpaque) COLOR(black, 0, 0, 0); COLOR(white, 0xFF, 0xFF, 0xFF); COLOR(cosmic_latte, 0xFF, 0xF8, 0xE7); COLOR(cream, 0xFF, 0xFD, 0xD0); COLOR(ivory, 0xFF, 0xFF, 0xF0); COLOR(magnolia, 0xF8, 0xF4, 0xFF); COLOR(old_lace, 0xFD, 0xF5, 0xE6); COLOR(seashell, 0xFF, 0xF5, 0xEE); COLOR(yellow, 0xFF, 0xFF, 0); #undef COLOR #define CHECK_VALUE(n, expected) do { \ if (gdTestAssert((n) == (expected)) != 1) { \ printf("%d is expected, but %d\n", expected, n); \ *error = -1; \ } \ } while (0) #define CHECK_PIXEL(x, y, expected) do { \ gdImageSetClip(im, 0, 0, 4, 4); \ c = gdImageGetPixel(im, (x), (y)); \ if (gdTestAssert(c == (expected)) != 1) { \ printf("%d is expected, but %d\n", expected, c); \ *error = -1; \ } \ } while (0) c = gdImageColorAllocate(im, 0xFF, 0, 0xFF); gdImageFilledRectangle(im, 0, 0, 4, 4, white); gdImageFilledRectangle(im, 0, 0, 3, 3, black); n = gdImageColorReplace(im, white, c); CHECK_VALUE(n, 9); CHECK_PIXEL(0, 0, black); CHECK_PIXEL(2, 3, black); CHECK_PIXEL(4, 4, c); gdImageSetClip(im, 1, 1, 3, 3); n = gdImageColorReplace(im, black, c); CHECK_VALUE(n, 9); CHECK_PIXEL(0, 0, black); CHECK_PIXEL(2, 3, c); src[0] = black; src[1] = c; dst[0] = c; dst[1] = white; gdImageSetClip(im, 0, 0, 4, 4); n = gdImageColorReplaceArray(im, 2, src, dst); CHECK_VALUE(n, 25); CHECK_PIXEL(0, 0, c); CHECK_PIXEL(2, 3, white); CHECK_PIXEL(4, 4, white); n = gdImageColorReplaceArray(im, 0, src, dst); CHECK_VALUE(n, 0); n = gdImageColorReplaceArray(im, -1, src, dst); CHECK_VALUE(n, 0); n = gdImageColorReplaceArray(im, INT_MAX, src, dst); CHECK_VALUE(n, -1); gdImageSetClip(im, 1, 1, 4, 4); n = gdImageColorReplaceCallback(im, callback); CHECK_VALUE(n, 16); CHECK_PIXEL(0, 0, c); CHECK_PIXEL(0, 4, white); d = gdImageColorExact(im, 0x0F, 0x0F, 0); if (gdTestAssert(d > 0) != 1) { *error = -1; } CHECK_PIXEL(2, 3, d); CHECK_PIXEL(4, 4, d); #define INITIALIZE_IMAGE() \ gdImageSetClip(im, 0, 0, 4, 4); \ gdImageFilledRectangle(im, 0, 0, 4, 4, black); \ gdImageFilledRectangle(im, 1, 1, 3, 3, white); \ gdImageSetPixel(im, 1, 1, cosmic_latte); \ gdImageSetPixel(im, 1, 2, cream); \ gdImageSetPixel(im, 2, 1, ivory); \ gdImageSetPixel(im, 2, 2, magnolia); \ gdImageSetPixel(im, 3, 1, old_lace); \ gdImageSetPixel(im, 3, 2, seashell) INITIALIZE_IMAGE(); n = gdImageColorReplaceThreshold(im, white, yellow, 2.0); CHECK_VALUE(n, 9); CHECK_PIXEL(0, 0, black); CHECK_PIXEL(1, 1, yellow); CHECK_PIXEL(2, 2, yellow); CHECK_PIXEL(3, 3, yellow); #undef INITIALIZE_IMAGE #undef CHECK_VALUE #undef CHECK_PIXEL } int main() { gdImagePtr im; int error = 0; gdSetErrorMethod(gdSilence); /* true color */ im = gdImageCreateTrueColor(5, 5); run_tests(im, &error); gdImageDestroy(im); /* palette */ im = gdImageCreate(5, 5); run_tests(im, &error); gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagecolorresolve/000077500000000000000000000000001245535672000203735ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecolorresolve/CMakeLists.txt000066400000000000000000000003561245535672000231370ustar00rootroot00000000000000SET(TESTS_FILES gdimagecolorresolve ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecolorresolve/gdimagecolorresolve.c000066400000000000000000000031061245535672000245730ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int error = 0; int c, c1, c2, c3, c4, color; im = gdImageCreateTrueColor(5, 5); c = gdImageColorResolve(im, 255, 0, 255); c2 = gdImageColorResolveAlpha(im, 255, 0, 255, 100); gdImageDestroy(im); if (gdTestAssert(c == 0xFF00FF) != 1) { error = -1; } if (gdTestAssert(c2 == 0x64FF00FF) != 1) { error = -1; } im = gdImageCreate(5, 5); c1 = gdImageColorResolve(im, 255, 0, 255); c2 = gdImageColorResolve(im, 255, 200, 0); c3 = gdImageColorResolveAlpha(im, 255, 0, 255, 100); c4 = gdImageColorResolveAlpha(im, 255, 34, 255, 100); if (gdTestAssert(c1 == 0) != 1) { error = -1; } if (gdTestAssert(c2 == 1) != 1) { error = -1; } if (gdTestAssert(c3 == 2) != 1) { error = -1; } if (gdTestAssert(c4 == 3) != 1) { error = -1; } color = gdTrueColorAlpha(gdImageRed(im, c1), gdImageGreen(im, c1), gdImageBlue(im, c1), 0); if (gdTestAssert(color == 0xFF00FF) != 1) { error = -1; } color = gdTrueColorAlpha(gdImageRed(im, c2), gdImageGreen(im, c2), gdImageBlue(im, c2), 0); if (gdTestAssert(color == 0xFFC800) != 1) { error = -1; } color = gdTrueColorAlpha(gdImageRed(im, c3), gdImageGreen(im, c3), gdImageBlue(im, c3), 0); if (gdTestAssert(color == 0xFF00FF) != 1) { error = -1; } color = gdTrueColorAlpha(gdImageRed(im, c4), gdImageGreen(im, c4), gdImageBlue(im, c4), 0); if (gdTestAssert(color == 0xFF22FF) != 1) { error = -1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagecolortransparent/000077500000000000000000000000001245535672000212555ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecolortransparent/CMakeLists.txt000066400000000000000000000003621245535672000240160ustar00rootroot00000000000000SET(TESTS_FILES gdimagecolortransparent ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecolortransparent/gdimagecolortransparent.c000066400000000000000000000005661245535672000263460ustar00rootroot00000000000000#include "gd.h" #include #include "gdtest.h" int main() { gdImagePtr im; int error = 0, pos; pos = gdMaxColors; im = gdImageCreate(1,1); gdImageColorTransparent(im, pos); if(im->transparent == pos) { error = -1; } pos = -2; gdImageColorTransparent(im, pos); if(im->transparent == pos) { error = -1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagecopy/000077500000000000000000000000001245535672000166275ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecopy/CMakeLists.txt000066400000000000000000000003551245535672000213720ustar00rootroot00000000000000SET(TESTS_FILES bug00007 bug00081 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecopy/bug00007.c000066400000000000000000000011671245535672000201440ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr dst_tc, src; int c1; src = gdImageCreate(5,5); gdImageAlphaBlending(src, 0); gdImageColorAllocate(src, 255,255,255); /* allocate white for background color */ c1 = gdImageColorAllocateAlpha(src, 255,0,0,70); gdImageFilledRectangle(src, 0,0, 4,4, c1); dst_tc = gdImageCreateTrueColor(5,5); gdImageAlphaBlending(dst_tc, 0); gdImageCopy(dst_tc, src, 0,0, 0,0, gdImageSX(src), gdImageSY(src)); /* CuAssertImageEquals(tc, src, dst_tc); */ /* Destroy it */ gdImageDestroy(dst_tc); gdImageDestroy(src); return 0; } libgd-gd-2.1.1/tests/gdimagecopy/bug00081.c000066400000000000000000000016211245535672000201410ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main() { gdImagePtr im, im2; int error = 0; char path[2048]; const char *file_exp = "bug00081_exp.png"; im = gdImageCreateTrueColor(5, 5); if (!im) { printf("can't create the src truecolor image\n"); return 1; } gdImageFilledRectangle(im, 0, 0, 49, 49, 0x00FFFFFF); gdImageColorTransparent(im, 0xFFFFFF); gdImageFilledRectangle(im, 1, 1, 4, 4, 0xFF00FF); im2 = gdImageCreateTrueColor(20, 20); if (!im2) { printf("can't create the dst truecolor image\n"); gdImageDestroy(im); return 1; } gdImageCopy(im2, im, 2, 2 , 0, 0, gdImageSX(im), gdImageSY(im)); sprintf(path, "%s/gdimagecopy/%s", GDTEST_TOP_DIR, file_exp); if (!gdAssertImageEqualsToFile(path, im2)) { error = 1; printf("Reference image and destination differ\n"); } gdImageDestroy(im); gdImageDestroy(im2); return error; } libgd-gd-2.1.1/tests/gdimagecopy/bug00081_exp.png000066400000000000000000000001371245535672000213600ustar00rootroot00000000000000PNG  IHDRZ&IDAT8c`IbtDyQ"I/IENDB`libgd-gd-2.1.1/tests/gdimagecopyrotated/000077500000000000000000000000001245535672000202125ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagecopyrotated/CMakeLists.txt000066400000000000000000000003441245535672000227530ustar00rootroot00000000000000 SET(TESTS_FILES bug00020 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagecopyrotated/bug00020.c000066400000000000000000000012751245535672000215220ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include "gdtest.h" #define width 50 int main() { gdImagePtr im, im2; int error = 0; char path[1024]; sprintf(path, "%s/gdimagecopyrotated/bug00020_exp.png", GDTEST_TOP_DIR); im = gdImageCreateTrueColor(width, width); gdImageFilledRectangle(im, 0,0, width, width, 0xFF0000); gdImageColorTransparent(im, 0xFF0000); gdImageFilledEllipse(im, width/2, width/2, width - 20, width - 10, 0x50FFFFFF); im2 = gdImageCreateTrueColor(width, width); gdImageCopyRotated(im2, im, width / 2, width / 2, 0,0, width, width, 60); if (!gdAssertImageEqualsToFile(path, im2)) { error = 1; } gdImageDestroy(im2); gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagecopyrotated/bug00020_exp.png000066400000000000000000000006221245535672000227330ustar00rootroot00000000000000PNG  IHDR22]tRNSGIDATXՙ[ E5 uqn0#3/!cly_`td\E,IYDŽJNX 0aL kBx*(F>P!oaX~ !X tȦszvնjާZ<.ĖJsvͬB 5q[Is+S,zf,,3dzܲqXu[Bn؛`W@;~[ˢC%Z/5W]GIK>^XIVI*nQ;4XGy``uu1 `9<Lz"IENDB`libgd-gd-2.1.1/tests/gdimagefile/000077500000000000000000000000001245535672000165745ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagefile/gdnametest.c000066400000000000000000000111651245535672000210770ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" #include "../test_config.h" #define WIDTH 60 #define HEIGHT 50 #define LX (WIDTH/2) // Line X #define LY (HEIGHT/2) // Line Y #define HT 2 // Half of line-thickness gdImagePtr mkwhite(int x, int y) { gdImagePtr im; im = gdImageCreateTrueColor(x, y); gdImageFilledRectangle(im, 0, 0, x-1, y-1, gdImageColorExactAlpha(im, 255, 255, 255, 0)); gdTestAssert(im != NULL); gdImageSetInterpolationMethod(im, GD_BICUBIC); // FP interp'n return im; }/* mkwhite*/ gdImagePtr mkcross() { gdImagePtr im; int fg, n; im = mkwhite(WIDTH, HEIGHT); fg = gdImageColorAllocate(im, 0, 0, 0); for (n = -HT; n < HT; n++) { gdImageLine(im, LX-n, 0, LX-n, HEIGHT-1, fg); gdImageLine(im, 0, LY-n, WIDTH-1, LY-n, fg); }/* for */ return im; }/* mkcross*/ void do_test() { gdTestAssertMsg(strchr("123",'2') != 0, "strchr() is not functional.\n",1); gdTestAssertMsg(strcasecmp("123abC","123Abc") == 0, "strcasecmp() is not functional.\n",1); int n; struct { const char *nm; // Filename unsigned maxdiff; // Maximum total pixel diff int required; // 1 -> image type always supported, -1 -> skip it int readonly; // 1 -> gd can only read this type } names[] = { {"img.png", 0, 0, 0}, {"img.gif", 5, 1, 0}, // This seems to come from tc<->palette {"img.GIF", 5, 1, 0}, // Test for case insensitivity {"img.gd", 0, 1, 0}, {"img.gd2", 0, 0, 0}, {"img.jpg", 25, 0, 0}, {"img.jpeg", 25, 0, 0}, {"img.wbmp", 0, 1, 0}, {"img.bmp", 0, 1, 0}, {"img-ref.xpm", 0, 0, 1}, // These break the test so I'm skipping them since the point // of this test is not those loaders. {"img-ref.xbm", 0, -1, 1}, {"img-ref.tga", 0, -1, 1}, {"img.webp", 0, -1, 0}, {"img.tiff", 0, -1, 0}, {NULL, 0} }; for (n = 0; names[n].nm; n++) { gdImagePtr orig, copy; int status; char full_filename[255]; /* Some image readers are buggy and crash the program so we * skip them. Bug fixers should remove these from the list of * skipped items as bugs are fixed. */ if (names[n].required < 0) { printf("Skipping test for '%s'. FIX THIS!\n", names[n].nm); continue; }/* if */ /* Skip this file if the current library build doesn't support * it. (If it's one of the built-in types, *that* a different * problem; we assert that here.) */ if (!gdSupportsFileType(names[n].nm, 0)) { gdTestAssertMsg(!names[n].required, "GD doesn't support required file type: %s\n", full_filename); continue; }/* if */ orig = mkcross(); #ifdef GDTEST_TOP_DIR snprintf(full_filename, sizeof(full_filename), GDTEST_TOP_DIR"/gdimagefile/%s", names[n].nm); #else /* Prepend the test directory; this is expected to be run in * the parent dir. */ snprintf(full_filename, sizeof(full_filename), "gdimagefile/%s", names[n].nm); #endif /* Write the image unless writing is not supported. */ if (!names[n].readonly) { status = gdImageFile(orig, full_filename); gdTestAssertMsg(status == GD_TRUE, "Failed to create %s\n", full_filename); }/* if */ copy = gdImageCreateFromFile(full_filename); gdTestAssertMsg(!!copy, "Failed to load %s\n", full_filename); if (!copy) continue; /* Debug printf. */ //printf("%s -> %d\n", full_filename, gdMaxPixelDiff(orig, copy)); gdTestAssertMsg(gdMaxPixelDiff(orig, copy) <= names[n].maxdiff,"Pixels different on %s\n", full_filename, full_filename); if (!names[n].readonly) { status = remove(full_filename); gdTestAssertMsg(status == 0, "Failed to delete %s\n", full_filename); }/* if */ gdImageDestroy(orig); gdImageDestroy(copy); }/* for */ }/* do_test*/ void do_errortest() { gdImagePtr im; im = mkcross(); gdTestAssert(!gdImageFile(im, "img.xpng")); gdTestAssert(!gdImageFile(im, "bobo")); gdTestAssert(!gdImageFile(im, "png")); gdTestAssert(!gdImageFile(im, "")); gdImageDestroy(im); }/* do_errortest*/ int main(int argc, char **argv) { do_test(); do_errortest(); return gdNumFailures(); } libgd-gd-2.1.1/tests/gdimagefile/img-ref.tga000066400000000000000000000214721245535672000206250ustar00rootroot00000000000000<2libgd-gd-2.1.1/tests/gdimagefile/img-ref.xbm000066400000000000000000000050321245535672000206320ustar00rootroot00000000000000#define foo-ref_width 60 #define foo-ref_height 50 static char foo-ref_bits[] = { 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0F, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xE0, 0x01, 0x00, 0x00, 0x00, }; libgd-gd-2.1.1/tests/gdimagefile/img-ref.xpm000066400000000000000000000064101245535672000206510ustar00rootroot00000000000000/* XPM */ static char *img_ref[] = { /* columns rows colors chars-per-pixel */ "60 50 2 1 ", " c gray100", ". c black", /* pixels */ " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", "............................................................", "............................................................", "............................................................", "............................................................", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... ", " .... " }; libgd-gd-2.1.1/tests/gdimagefill/000077500000000000000000000000001245535672000166035ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagefill/CMakeLists.txt000066400000000000000000000004111245535672000213370ustar00rootroot00000000000000 SET(TESTS_FILES bug00002_1 bug00002_2 bug00002_3 bug00002_4 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagefill/bug00002_1.c000066400000000000000000000014571245535672000203350ustar00rootroot00000000000000#include "gd.h" #include #include "gdtest.h" #define TMP_FN "bug00002_1.png" int main() { gdImagePtr im; FILE *fp; char path[1024]; im = gdImageCreateTrueColor(100, 100); if (im == NULL) { gdTestErrorMsg("Cannot create image.\n"); return 1; } gdImageFill(im, 0, 0, 0xffffff); gdImageFill(im, 0, 0, 0xffffff); fp = fopen(TMP_FN, "wb"); if (fp == NULL) { gdTestErrorMsg("Cannot create image from <%s>\n", TMP_FN); gdImageDestroy(im); return 1; } gdImagePng(im,fp); fclose(fp); sprintf(path, "%s/gdimagefill/bug00002_1_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { gdImageDestroy(im); return 1; } gdImageDestroy(im); if (remove(TMP_FN) == -1) { gdTestErrorMsg("Cannot remove temporary file: <%s>\n", TMP_FN); return 1; } return 0; } libgd-gd-2.1.1/tests/gdimagefill/bug00002_1_exp.png000066400000000000000000000004411245535672000215430ustar00rootroot00000000000000PNG  IHDRddIDATx w>V /dOeǙvK 6ʦhIENDB`libgd-gd-2.1.1/tests/gdimagefill/bug00002_2.c000066400000000000000000000021741245535672000203330ustar00rootroot00000000000000#include "gd.h" #include #include "gdtest.h" int main() { gdImagePtr im, tile; int im_black, tile_black; int x,y, error = 0; char path[1024]; /* fputs("flag 0\n", stdout); */ im = gdImageCreate(150, 150); tile = gdImageCreate(36, 36); gdImageColorAllocate(tile,255,255,255); /* allocate white for background color */ tile_black = gdImageColorAllocate(tile,0,0,0); gdImageColorAllocate(im,255,255,255); /* allocate white for background color */ im_black = gdImageColorAllocate(im,0,0,0); /* create the dots pattern */ for (x=0; x<36; x+=2) { for (y=0; y<36; y+=2) { gdImageSetPixel(tile,x,y,tile_black); } } gdImageSetTile(im,tile); gdImageRectangle(im, 9,9,139,139, im_black); gdImageLine(im, 9,9,139,139, im_black); gdImageFill(im, 11,12, gdTiled); /* fputs("flag 1\n", stdout); */ gdImageFill(im, 0, 0, 0xffffff); /* fputs("flag 2\n", stdout); */ gdImageFill(im, 0, 0, 0xffffff); /* fputs("flag 2\n", stdout); */ sprintf(path, "%s/gdimagefill/bug00002_2_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } /* Destroy it */ gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagefill/bug00002_2_exp.png000066400000000000000000000006111245535672000215430ustar00rootroot00000000000000PNG  IHDRPLTEU~>IDATHiP a TJr YibTBJRhd}7-ղŹ\e'd!{#=[Wp%8WwKp 9n.t%8Ww7|g+pBλ n.  p.)'伻Kp 9n. g+pBλް8\r. Kp 9uHL. Kp 9\3p N8!};1Lqe^IENDB`libgd-gd-2.1.1/tests/gdimagefill/bug00002_3.c000066400000000000000000000023731245535672000203350ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include "gdtest.h" int main() { gdImagePtr im, tile; int im_black, tile_white, tile_black; int x,y, error = 0; char path[1024]; /* fputs("flag 0\n", stdout); */ im = gdImageCreate(150, 150); tile = gdImageCreateTrueColor(36, 36); tile_white = gdImageColorAllocate(tile,255,255,255); tile_black = gdImageColorAllocate(tile,55,0,0); gdImageColorAllocate(im,255,255,255); /* allocate white for background color */ im_black = gdImageColorAllocate(im,0,0,0); gdImageFill(tile, 0,0, tile_white); gdImageColorTransparent(tile, tile_black); gdImageColorTransparent(im, im_black); /* create the dots pattern */ for (x=0; x<36; x+=2) { for (y=0; y<36; y+=2) { gdImageSetPixel(tile,x,y,tile_black); } } gdImageSetTile(im,tile); gdImageRectangle(im, 9,9,139,139, im_black); gdImageLine(im, 9,9,139,139, im_black); gdImageFill(im, 11,12, gdTiled); /* fputs("flag 1\n", stdout); */ gdImageFill(im, 0, 0, 0xffffff); /* fputs("flag 2\n", stdout); */ gdImageFill(im, 0, 0, 0xffffff); /* fputs("flag 3\n", stdout); */ sprintf(path, "%s/gdimagefill/bug00002_3_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } /* Destroy it */ gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagefill/bug00002_3_exp.png000066400000000000000000000006321245535672000215470ustar00rootroot00000000000000PNG  IHDRPLTEٟtRNS@fBIDATHm0 aoz"x]"#dHMHy1ҴLOO㼬Ś! dg 8\ p . "ݍo8\wgKpyw3pN%8W伻]3pN%8W伻G3pN%8W伻w.)'w-+r} 8\nGtt.)'w;8\pEλ$8\~n \Sp N9n}tgKpȽu^_fWYlIENDB`libgd-gd-2.1.1/tests/gdimagefill/bug00002_4.c000066400000000000000000000017261245535672000203370ustar00rootroot00000000000000/*ImageFill Pattern fill */ #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int red, blue, white, black, error = 0; char path[1024]; im = gdImageCreate(50,100); red = gdImageColorAllocate(im, 255, 0, 0); blue = gdImageColorAllocate(im, 0,0,255); white = gdImageColorAllocate(im, 255,255,255); black = gdImageColorAllocate(im, 0,0,0); gdImageFill(im, 0,0, black); gdImageLine(im, 20,20,180,20, white); gdImageLine(im, 20,20,20,70, blue); gdImageLine(im, 20,70,180,70, red); gdImageLine(im, 180,20,180,45, white); gdImageLine(im, 180,70,180,45, red); gdImageLine(im, 20,20,100,45, blue); gdImageLine(im, 20,70,100,45, blue); gdImageLine(im, 100,45,180,45, red); gdImageFill(im, 21,45, blue); gdImageFill(im, 100,69, red); gdImageFill(im, 100,21, white); sprintf(path, "%s/gdimagefill/bug00002_4_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } /* Destroy it */ gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagefill/bug00002_4_exp.png000066400000000000000000000003001245535672000215400ustar00rootroot00000000000000PNG  IHDR2d PLTEacfr pHYs+ZIDAT8ӱ 0@FtƣJL H/cNXPD|r Pu.wYpTμvI{,g5_|U)[/&_IENDB`libgd-gd-2.1.1/tests/gdimagefilledellipse/000077500000000000000000000000001245535672000204725ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagefilledellipse/CMakeLists.txt000066400000000000000000000003561245535672000232360ustar00rootroot00000000000000 SET(TESTS_FILES bug00010 bug00191 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagefilledellipse/bug00010.c000066400000000000000000000005761245535672000220040ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int error = 0; char path[1024]; im = gdImageCreateTrueColor(100,100); gdImageFilledEllipse(im, 50,50, 70, 90, 0x50FFFFFF); sprintf(path, "%s/gdimagefilledellipse/bug00010_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagefilledellipse/bug00010_exp.png000066400000000000000000000007371245535672000232210ustar00rootroot00000000000000PNG  IHDRddIDATxAj0F|.fCqȓF#Ko[(ۋ˯$iK??qw:ϳܙC;͉jձR2]U&+^**5(UAX^c C{U\*5*֔LW# 5TH*+9֣J^X*dJR!7x gYUWB%J^^@UܬB\оEg岀e-=0. h 7]`,Xgms cfw=e 0`,Xc 0`,~ ceRe|hpY:. Le>P,sW O9IENDB`libgd-gd-2.1.1/tests/gdimagefilledellipse/bug00191.c000066400000000000000000000007261245535672000220130ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int error = 0; char path[1024]; im = gdImageCreate(100, 100); (void)gdImageColorAllocate(im, 255, 255, 255); gdImageSetThickness(im, 20); gdImageFilledEllipse(im, 30, 50, 20, 20, gdImageColorAllocate(im, 0, 0, 0)); sprintf(path, "%s/gdimagefilledellipse/bug00191.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagefilledellipse/bug00191.png000066400000000000000000000002171245535672000223500ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~DIDAT8c`4߀̳? #include "gd.h" #include "gdtest.h" /* This is a quickie test program to show a bug in gd. * There is a red line that is drawn across the bottom of * the image that shouldn't be there. */ int main(void) { gdPoint pointy[5]; gdPoint diamond[4]; int d, x, y, top, bot, left, right, r; /* R G B */ int white = gdTrueColorAlpha(255, 255, 255, 10); int black = gdTrueColorAlpha( 0, 0, 0, 10); int red = gdTrueColorAlpha(255, 0, 0, 10); int green = gdTrueColorAlpha( 0, 255, 0, 10); int blue = gdTrueColorAlpha( 0, 0, 255, 10); int yellow = gdTrueColorAlpha(255, 255, 0, 10); int cyan = gdTrueColorAlpha( 0, 255, 255, 10); int magenta = gdTrueColorAlpha(255, 0, 255, 10); int purple = gdTrueColorAlpha(100, 0, 100, 10); gdImagePtr im = gdImageCreateTrueColor(256, 256); if (!im) exit(EXIT_FAILURE); gdImageFilledRectangle(im, 0, 0, 256, 256, white); /* M (bridge) */ top = 240; bot = 255; d = 30; x = 100; pointy[0].x = x; pointy[0].y = top; pointy[1].x = x+2*d; pointy[1].y = top; pointy[2].x = x+2*d; pointy[2].y = bot; pointy[3].x = x+d; pointy[3].y = (top+bot)/2; pointy[4].x = x; pointy[4].y = bot; gdImageFilledPolygon(im, pointy, 5, yellow); /* left-facing M not on baseline */ top = 40; bot = 70; left = 120; right = 180; pointy[0].x = left; pointy[0].y = top; pointy[1].x = right; pointy[1].y = top; pointy[2].x = right; pointy[2].y = bot; pointy[3].x = left; pointy[3].y = bot; pointy[4].x = (left+right)/2; pointy[4].y = (top+bot)/2; gdImageFilledPolygon(im, pointy, 5, purple); /* left-facing M on baseline */ top = 240; bot = 270; left = 20; right = 80; pointy[0].x = left; pointy[0].y = top; pointy[1].x = right; pointy[1].y = top; pointy[2].x = right; pointy[2].y = bot; pointy[3].x = left; pointy[3].y = bot; pointy[4].x = (left+right)/2; pointy[4].y = (top+bot)/2; gdImageFilledPolygon(im, pointy, 5, magenta); /* left-facing M on ceiling */ top = -15; bot = 15; left = 20; right = 80; pointy[0].x = left; pointy[0].y = top; pointy[1].x = right; pointy[1].y = top; pointy[2].x = right; pointy[2].y = bot; pointy[3].x = left; pointy[3].y = bot; pointy[4].x = (left+right)/2; pointy[4].y = (top+bot)/2; gdImageFilledPolygon(im, pointy, 5, blue); d = 30; x = 150; y = 150; diamond[0].x = x-d; diamond[0].y = y; diamond[1].x = x; diamond[1].y = y+d; diamond[2].x = x+d; diamond[2].y = y; diamond[3].x = x; diamond[3].y = y-d; gdImageFilledPolygon(im, diamond, 4, green); x = 180; y = 225; diamond[0].x = x-d; diamond[0].y = y; diamond[1].x = x; diamond[1].y = y+d; diamond[2].x = x+d; diamond[2].y = y; diamond[3].x = x; diamond[3].y = y-d; gdImageFilledPolygon(im, diamond, 4, red); x = 225; y = 255; diamond[0].x = x-d; diamond[0].y = y; diamond[1].x = x; diamond[1].y = y+d; diamond[2].x = x+d; diamond[2].y = y; diamond[3].x = x; diamond[3].y = y-d; gdImageFilledPolygon(im, diamond, 4, cyan); /* M (bridge) not touching bottom boundary */ top = 100; bot = 150; x = 30; pointy[0].x = x; pointy[0].y = top; pointy[1].x = x+2*d; pointy[1].y = top; pointy[2].x = x+2*d; pointy[2].y = bot; pointy[3].x = x+d; pointy[3].y = (top+bot)/2; pointy[4].x = x; pointy[4].y = bot; gdImageFilledPolygon(im, pointy, 5, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagefilledpolygon/bug00100.png", im); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagefilledpolygon/bug00100.png000066400000000000000000000041141245535672000223700ustar00rootroot00000000000000PNG  IHDR?1 pHYs+IDATx]rFEa0pXHlBi y0ӷ829U0DInI<_|YVG,t>ËsL`PӇ0}Ӈ&>$(K>"jG\U0}Dw~x"FH 5@jR#FH 5@jR#FH 5@j$'y{ጯt| ?+2PC@! |2BBȠ?C=(25 @d`! $2h#z|?@`A@ [!`~[ӷ@0}; [#QL{"!L?30} kn73nFH 5@jR#FH 5@jR#FH 5@jR#FH 5ß=ϳ݃Y+R#FH 5@jR#FH 5@jR#FH›!ZVO@`s ҧQ!>!!7 / s˦ 6hsO/'ptu^֌/|zOr)8uG1^ `Ͼn~4A=VۥOtoO zⶫ-+@l_pJOhݸ XoivNS 6k➻䞸XTU:0)g xmK|W/R)Mnu 2pjw +|O6S (Ll†zkNmqm'69ulG]n  Z4wy*SFmmjdw z((B,_{eoVe @͂Y6܎Y kf{@$7w"`,GlB!}Z9?z:?{\ s _d`p^[w! a)O `L:9[0 ͩFsm`0;TF\# 9 `j&uZOjO;:|ڝ[?sY]0X ]?7Dz0jֿP_zFV1;hƤӀ}[0,_|^`x^ Y#7sC)lkӀO?v~luve=x_xK{2mj?\o V h3| Bo@y;Ӡdyv`5e?Wo`3wmX_;=7w>" \?zǧ/p pɠ[w9Fxl9s#m`$(e`@ݿx'`/JB2hjr{CXU.4dGI͙<Zw6{IENDB`libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon0.c000066400000000000000000000011511245535672000251330ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); gdImageFilledPolygon(im, NULL, 0, black); /* no effect */ gdImageFilledPolygon(im, NULL, -1, black); /* no effect */ r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagefilledpolygon/gdimagefilledpolygon0.png", im); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon0.png000066400000000000000000000001371245535672000255000ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT8c``Q@Ox^IENDB`libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon1.c000066400000000000000000000013571245535672000251440ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; gdImageFilledPolygon(im, points, 1, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagefilledpolygon/gdimagefilledpolygon1.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon1.png000066400000000000000000000001371245535672000255010ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT8c``Q@Ox^IENDB`libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon2.c000066400000000000000000000014251245535672000251410ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; points[1].x = 50; points[1].y = 70; gdImageFilledPolygon(im, points, 2, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagefilledpolygon/gdimagefilledpolygon2.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon2.png000066400000000000000000000002141245535672000254760ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~AIDAT8Ρ  PZJGfޜFܺ)hh(tA\\CIũy,IENDB`libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon3.c000066400000000000000000000014731245535672000251450ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; points[1].x = 50; points[1].y = 70; points[2].x = 90; points[2].y = 30; gdImageFilledPolygon(im, points, 3, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagefilledpolygon/gdimagefilledpolygon3.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagefilledpolygon/gdimagefilledpolygon3.png000066400000000000000000000004151245535672000255020ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT81 R?ɗR?҅c8vɵ\7bGct ѓȭH6#Ͳ|IPB)$=IO%( YP6 r5@:qNaHa5ҷD3-\ չtA* (Y0WBa$f'-/nIENDB`libgd-gd-2.1.1/tests/gdimagefilledrectangle/000077500000000000000000000000001245535672000210015ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagefilledrectangle/CMakeLists.txt000066400000000000000000000004161245535672000235420ustar00rootroot00000000000000SET(TESTS_FILES bug00004 bug00078 bug00106_gdimagefilledrectangle ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagefilledrectangle/bug00004.c000066400000000000000000000011061245535672000223040ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int c1,c2,c3,c4,c5; im = gdImageCreateTrueColor(100,100); gdImageFilledRectangle(im, 2,2, 80,95, 0x50FFFFFF); c1 = gdImageGetTrueColorPixel(im, 2, 2); c2 = gdImageGetTrueColorPixel(im, 80, 95); c3 = gdImageGetTrueColorPixel(im, 80, 2); c4 = gdImageGetTrueColorPixel(im, 2, 95); c5 = gdImageGetTrueColorPixel(im, 49, 49); gdImageDestroy(im); if (0x005e5e5e == c1 && 0x005e5e5e == c2 && 0x005e5e5e == c3 && 0x005e5e5e == c4 && 0x005e5e5e == c5) { return 0; } else { return 1; } } libgd-gd-2.1.1/tests/gdimagefilledrectangle/bug00078.c000066400000000000000000000017551245535672000223310ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int c1,c2,c3,c4,c5; im = gdImageCreateTrueColor(100,100); gdImageFilledRectangle(im, 2,2, 80,95, 0x50FFFFFF); c1 = gdImageGetTrueColorPixel(im, 2, 2); c2 = gdImageGetTrueColorPixel(im, 80, 95); c3 = gdImageGetTrueColorPixel(im, 80, 2); c4 = gdImageGetTrueColorPixel(im, 2, 95); c5 = gdImageGetTrueColorPixel(im, 49, 49); if (!(0x005e5e5e == c1 && 0x005e5e5e == c2 && 0x005e5e5e == c3 && 0x005e5e5e == c4)) { return 1; } gdImageFilledRectangle(im, 0, 0, 99, 99, 0x0); gdImageFilledRectangle(im, 80,95, 2,2, 0x50FFFFFF); c1 = gdImageGetTrueColorPixel(im, 2, 2); c2 = gdImageGetTrueColorPixel(im, 80, 95); c3 = gdImageGetTrueColorPixel(im, 80, 2); c4 = gdImageGetTrueColorPixel(im, 2, 95); c5 = gdImageGetTrueColorPixel(im, 49, 49); if (!(0x005e5e5e == c1 && 0x005e5e5e == c2 && 0x005e5e5e == c3 && 0x005e5e5e == c4 && 0x005e5e5e == c5)) { return 1; } gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/gdimagefilledrectangle/bug00106_gdimagefilledrectangle.c000066400000000000000000000007671245535672000270450ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int c1,c2,c3,c4; im = gdImageCreateTrueColor(10,10); if (!im) { return 1; } gdImageFilledRectangle(im, 1,1, 1,1, 0x50FFFFFF); c1 = gdImageGetTrueColorPixel(im, 1, 1); c2 = gdImageGetTrueColorPixel(im, 2, 1); c3 = gdImageGetTrueColorPixel(im, 1, 2); c4 = gdImageGetTrueColorPixel(im, 2, 2); gdImageDestroy(im); if (0x005e5e5e == c1 && 0x0 == c2 && 0x0 == c3 && 0x0 == c4) { return 0; } else { return 1; } } libgd-gd-2.1.1/tests/gdimagefilltoborder/000077500000000000000000000000001245535672000203445ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagefilltoborder/CMakeLists.txt000066400000000000000000000003431245535672000231040ustar00rootroot00000000000000 SET(TESTS_FILES bug00037 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagefilltoborder/bug00037.c000066400000000000000000000010631245535672000216570ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int bordercolor, color; im = gdImageCreateTrueColor(100, 100); gdImageAlphaBlending(im, 1); gdImageSaveAlpha(im, 1); bordercolor = gdImageColorAllocateAlpha(im, 0, 0, 0, 2); color = gdImageColorAllocateAlpha(im, 0, 0, 0, 1); gdImageFillToBorder(im, 5, 5, bordercolor, color); color = gdImageGetPixel(im, 5, 5); gdImageDestroy(im); if (gdTestAssert(color==0x1000000)) { return 0; } else { printf("c: %X, expected %X\n", color, 0x1000000); return -1; } } libgd-gd-2.1.1/tests/gdimagefilter/000077500000000000000000000000001245535672000171425ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagefilter/gdCopyBlurred.c000066400000000000000000000123461245535672000220610ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" #define WIDTH 300 #define HEIGHT 200 #define LX (WIDTH/2) // Line X #define LY (HEIGHT/2) // Line Y #define HT 3 // Half of line-thickness #define CLOSE_ENOUGH 0 #define PIXEL_CLOSE_ENOUGH 0 void save(gdImagePtr im, const char *filename) { #if 0 // set TRUE to write out some intermediate images FILE *out; out = fopen(filename, "wb"); gdImagePng(im, out); fclose(out); #else im, filename; #endif }/* save*/ /* Test gdImageScale() with bicubic interpolation on a simple * all-white image. */ gdImagePtr mkwhite(int x, int y) { gdImagePtr im; im = gdImageCreateTrueColor(x, y); gdImageFilledRectangle(im, 0, 0, x-1, y-1, gdImageColorExactAlpha(im, 255, 255, 255, 0)); gdTestAssert(im != NULL); gdImageSetInterpolationMethod(im, GD_BICUBIC); // FP interp'n return im; }/* mkwhite*/ /* Fill with almost-black. */ void mkblack(gdImagePtr ptr) { gdImageFilledRectangle(ptr, 0, 0, ptr->sx - 1, ptr->sy - 1, gdImageColorExactAlpha(ptr, 2, 2, 2, 0)); }/* mkblack*/ gdImagePtr mkcross() { gdImagePtr im; int fg, n; im = mkwhite(WIDTH, HEIGHT); fg = gdImageColorAllocate(im, 0, 0, 0); for (n = -HT; n < HT; n++) { gdImageLine(im, LX-n, 0, LX-n, HEIGHT-1, fg); gdImageLine(im, 0, LY-n, WIDTH-1, LY-n, fg); }/* for */ return im; }/* mkcross*/ void blurblank(gdImagePtr im, int radius, double sigma) { gdImagePtr result; result = gdImageCopyGaussianBlurred(im, radius, sigma); gdTestAssert(!!result); if (!result) return; gdTestAssert(gdMaxPixelDiff(im, result) <= CLOSE_ENOUGH); gdImageDestroy(result); }/* blurblank*/ void do_test() { gdImagePtr im, imref, tmp; gdImagePtr same, same2; im = mkwhite(WIDTH, HEIGHT); imref = mkwhite(WIDTH, HEIGHT); /* Blur a plain white image to various radii and ensure they're * still similar enough. */ blurblank(im, 1, 0.0); blurblank(im, 2, 0.0); blurblank(im, 4, 0.0); blurblank(im, 8, 0.0); blurblank(im, 16, 0.0); /* Ditto a black image. */ mkblack(im); gdTestAssert(gdMaxPixelDiff(im, imref) >= 240); /* Leaves a little wiggle room */ blurblank(im, 1, 0.0); blurblank(im, 2, 0.0); blurblank(im, 4, 0.0); blurblank(im, 8, 0.0); blurblank(im, 16, 0.0); }/* do_test*/ /* Ensure that RGB values are equal, then return r (which is therefore * the whiteness.) */ int getwhite(gdImagePtr im, int x, int y) { int px, r, g, b; px = gdImageGetPixel(im, x, y); r = gdImageRed(im, px); g = gdImageGreen(im, px); b = gdImageBlue(im, px); gdTestAssert(r == g && r == b); return r; }/* getrgb*/ int whitecmp(gdImagePtr im1, gdImagePtr im2, int x, int y) { int w1, w2; w1 = getwhite(im1, x, y); w2 = getwhite(im2, x, y); return abs(w1 - w2); }/* whitediff*/ void do_crosstest() { gdImagePtr im = mkcross(); gdImagePtr blurred; const int RADIUS = 16; gdTestAssert(!!im); save(im, "cross.png"); blurred = gdImageCopyGaussianBlurred(im, RADIUS, 0.0); gdTestAssert(blurred != NULL); save(blurred, "blurredcross.png"); /* These spots shouldn't be affected. */ gdTestAssert(whitecmp(im, blurred, 5, 5) <= PIXEL_CLOSE_ENOUGH); gdTestAssert(whitecmp(im, blurred, WIDTH-5, 5) <= PIXEL_CLOSE_ENOUGH); gdTestAssert(whitecmp(im, blurred, 5, HEIGHT-5) <= PIXEL_CLOSE_ENOUGH); gdTestAssert(whitecmp(im, blurred, WIDTH-5, HEIGHT-5) <= PIXEL_CLOSE_ENOUGH); // printf("%d %d %d %d\n", whitecmp(im, blurred, 0, 0), whitecmp(im, blurred, WIDTH-1, 0), // whitecmp(im, blurred, 0, HEIGHT-1), whitecmp(im, blurred, WIDTH-1, HEIGHT-1)); /* Ditto these, right in the corners */ gdTestAssert(whitecmp(im, blurred, 0, 0) <= PIXEL_CLOSE_ENOUGH); gdTestAssert(whitecmp(im, blurred, WIDTH-1, 0) <= PIXEL_CLOSE_ENOUGH); gdTestAssert(whitecmp(im, blurred, 0, HEIGHT-1) <= PIXEL_CLOSE_ENOUGH); gdTestAssert(whitecmp(im, blurred, WIDTH-1, HEIGHT-1) <= PIXEL_CLOSE_ENOUGH); /* Now, poking let's poke around the blurred lines. */ /* Vertical line gets darker when approached from the left. */ gdTestAssert(getwhite(blurred, 1, 1) > getwhite(blurred, LX - (HT - 1), 1)); gdTestAssert(getwhite(blurred, LX - 2, 1) > getwhite(blurred, LX - 1, 1)); /* ...and lighter when moving away to the right. */ gdTestAssert(getwhite(blurred, LX + 2, 1) >= getwhite(blurred, LX + 1, 1)); gdTestAssert(getwhite(blurred, LX + 3, 1) >= getwhite(blurred, LX + 2, 1)); gdTestAssert(getwhite(blurred, WIDTH - 1, 1) > getwhite(blurred, LX + 1, 1)); /* And the same way, vertically */ gdTestAssert(getwhite(blurred, 1, 1) > getwhite(blurred, 1, LY - (HT - 1))); gdTestAssert(getwhite(blurred, 1, LY - (HT - 1)) > getwhite(blurred, 1, LY - (HT - 2))); gdTestAssert(getwhite(blurred, 1, LY) <= getwhite(blurred, 1, LY + 1)); gdTestAssert(getwhite(blurred, 1, LY + 1) < getwhite(blurred, 1, LY + 3)); gdTestAssert(getwhite(blurred, 1, LY + 3) < getwhite(blurred, 1, HEIGHT-1)); gdImageDestroy(blurred); }/* do_crosstest*/ int main(int argc, char **argv) { do_test(); do_crosstest(); return gdNumFailures(); } libgd-gd-2.1.1/tests/gdimageline/000077500000000000000000000000001245535672000166045ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimageline/CMakeLists.txt000066400000000000000000000004421245535672000213440ustar00rootroot00000000000000SET(TESTS_FILES gdimageline_aa gdimageline_aa_outofrange bug00077 bug00072 bug00111 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimageline/bug00072.c000066400000000000000000000012761245535672000201240ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; const char *exp = "bug00072_exp.png"; int error = 0; char path[1024]; im = gdImageCreateTrueColor(11, 11); gdImageFilledRectangle(im, 0, 0, 10, 10, 0xFFFFFF); gdImageSetThickness(im, 3); gdImageLine(im, 5, 0, 5, 11, 0x000000); gdImageLine(im, 0, 5, 11, 5, 0x000000); gdImageLine(im, 0, 0, 11, 11, 0x000000); gdImageSetThickness(im, 1); gdImageLine(im, 5, 0, 5, 11, 0xFF0000); gdImageLine(im, 0, 5, 11, 5, 0xFF0000); gdImageLine(im, 0, 0, 11, 11, 0xFF0000); sprintf(path, "%s/gdimageline/%s", GDTEST_TOP_DIR, exp); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimageline/bug00072_exp.png000066400000000000000000000002051245535672000213310ustar00rootroot00000000000000PNG  IHDR &qLIDAT10 2ܦP632 lKjkO%h'LGs3uiOP1iN.Z}&A|IENDB`libgd-gd-2.1.1/tests/gdimageline/bug00077.c000066400000000000000000000010721245535672000201230ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; const char *exp = "bug00077_exp.png"; int error = 0; char path[1024]; im = gdImageCreateTrueColor(11, 11); gdImageFilledRectangle(im, 0, 0, 10, 10, 0xFFFFFF); gdImageSetThickness(im, 1); gdImageLine(im, 0, 10, 0, 0, 0x0); gdImageLine(im, 5, 10, 5, 0, 0x0); gdImageLine(im, 10, 5, 0, 5, 0x0); gdImageLine(im, 10, 10, 0, 10, 0x0); sprintf(path, "%s/gdimageline/%s", GDTEST_TOP_DIR, exp); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimageline/bug00077_exp.png000066400000000000000000000001411245535672000213350ustar00rootroot00000000000000PNG  IHDR &q(IDATcd``? 022"s _3 t\IENDB`libgd-gd-2.1.1/tests/gdimageline/bug00111.c000066400000000000000000000012031245535672000201040ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main() { gdImagePtr im; int error = 0; char path[2048]; const char *file_exp = "bug00111_exp.png"; im = gdImageCreateTrueColor(10, 10); if (!im) { printf("can't get truecolor image\n"); return 1; } gdImageLine(im, 2, 2, 2, 2, 0xFFFFFF); gdImageLine(im, 5, 5, 5, 5, 0xFFFFFF); gdImageLine(im, 0, 0, 0, 0, 0xFFFFFF); sprintf(path, "%s/gdimageline/%s", GDTEST_TOP_DIR, file_exp); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; printf("Reference image and destination differ\n"); } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimageline/bug00111_exp.png000066400000000000000000000001171245535672000213250ustar00rootroot00000000000000PNG  IHDR PXIDATc?f [)IENDB`libgd-gd-2.1.1/tests/gdimageline/gdImageAALine_thickness.c000066400000000000000000000013101245535672000233650ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main(int argc, char **argv) { gdImagePtr im; char path[2048]; const char *file_exp = "gdimageline/gdImageAALine_thickness_exp.png"; im = gdImageCreateTrueColor(100, 100); gdImageFilledRectangle(im, 0, 0, 99, 99, gdImageColorExactAlpha(im, 255, 255, 255, 0)); gdImageSetThickness(im, 5); gdImageSetAntiAliased(im, gdImageColorExactAlpha(im, 0, 0, 0, 0)); gdImageLine(im, 0,0, 99, 99, gdAntiAliased); sprintf(path, "%s/%s", GDTEST_TOP_DIR, file_exp); if (!gdAssertImageEqualsToFile(path, im)) { printf("comparing rotated image to %s failed.\n", path); gdImageDestroy(im); return 1; } gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/gdimageline/gdImageAALine_thickness_exp.png000066400000000000000000000010261245535672000246070ustar00rootroot00000000000000PNG  IHDRdd pHYs+IDATx;0 1vH #SեiI3y^8,{ ]yz{e/^8,{qXaًòe/^8,{qXv&vzan7zae[ya=4®^ؘU {j{a{ba/C%p.J^(ㅘ^k*Ȳ^Kʼ^Қ 3zbw:/ܭ'HCd9RxA(^u^P{/({a){)bzbizb zIcycIy%ʁ%K+udXwa]Ju++X^cEzU *U+ijXG buȫ, X۽cѫ..X[a{Zjkګ)֜W_ XWw,X/c^"Ex Cq5\}Exc,0 IENDB`libgd-gd-2.1.1/tests/gdimageline/gdimageline_aa.c000066400000000000000000000046161245535672000216650ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" #ifdef _MSC_VER # define snprintf _snprintf #endif int gen_image(const char* filename, int idx, int reverse_x, int width, int height, int bgd) { double gradient = height / (width*2.0); int offset = idx*width; int x1,y1,x2,y2, error = 0; gdImagePtr im = gdImageCreateTrueColor(width,height); if (bgd==1) { gdImageFilledRectangle(im,0,0,width-1,height-1, gdTrueColorAlpha(255, 255, 255, 0)); } else { gdImageFilledRectangle(im,0,0,width-1,height-1, gdTrueColorAlpha(255, 255, 0, 0)); } gdImageSetAntiAliased(im, gdTrueColorAlpha(0,0,0,0)); /* test for potential segfault (introduced with AA improvements, fixed with the same patch - but I didn't notice it until later).*/ gdImageLine(im,-1,-1,-1,-1,gdAntiAliased); x1 = floor(reverse_x * -width + 0.5); y1 = (offset-width) * gradient + 0.5; x2 = floor(reverse_x * width*2 + 0.5); y2 = floor((offset+width*2) * gradient + 0.5); /* draw an AA line */ gdImageLine(im, x1, y1, x2, y2, gdAntiAliased); gdImageLine(im, 0, im->sy - 1, im->sx, im->sy - 1, 0x40FF0000); if (!gdAssertImageEqualsToFile(filename, im)) { gdTestErrorMsg("gdAssertImageEqualsToFile failed: <%s>\n", filename); error = 1; } gdImageDestroy(im); return error; } int main() { int error = 0; char path[1024]; snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_a_0_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,0,1,10,100, 1); snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_a_1_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,1,1,10,100, 2); snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_b_0_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,2,-1,10,100, 1); snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_b_1_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,1,-1,10,100, 2); snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_c_0_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,0,1,100,10, 1); snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_c_1_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,1,1,100,10, 2); snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_d_0_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,2,-1,100,10, 1); snprintf(path, sizeof(path)-1, "%s/gdimageline/gdimageline_aa_d_1_exp.png", GDTEST_TOP_DIR); error |= gen_image(path,1,-1,100,10, 2); return error; } libgd-gd-2.1.1/tests/gdimageline/gdimageline_aa_a_0_exp.png000066400000000000000000000003061245535672000236120ustar00rootroot00000000000000PNG  IHDR d06IDATHA 7?>7՘H/xQvQ$"gp) &!"ώ B#qPvSo]Son]Ro&fudL 208888?|\o-efzoIENDB`libgd-gd-2.1.1/tests/gdimageline/gdimageline_aa_c_0_exp.png000066400000000000000000000003101245535672000236070ustar00rootroot00000000000000PNG  IHDRd ~l)IDATHA @F+ ]q@ y,;q\J֚?|4Moy?L7küш*!yefޕYreWƚQkUn]>pgx/dB-TZIENDB`libgd-gd-2.1.1/tests/gdimageline/gdimageline_aa_c_1_exp.png000066400000000000000000000003021245535672000236110ustar00rootroot00000000000000PNG  IHDRd ~l)IDATH1 E "HӡZ dG ,' 3!ѷ A"֠#!9~G̊vK)ˑv!;6ZLgr*BJ%;}tEԃ IENDB`libgd-gd-2.1.1/tests/gdimageline/gdimageline_aa_d_0_exp.png000066400000000000000000000003101245535672000236100ustar00rootroot00000000000000PNG  IHDRd ~l) pHYs+zIDATH핱 Dk)|sqO7iQQ PȻ`fǦs+rrrp^`4)%UUǰo6:s(E¹e禲Vn!H[ "9DtGnYMvIENDB`libgd-gd-2.1.1/tests/gdimageline/gdimageline_aa_d_1_exp.png000066400000000000000000000003301245535672000236130ustar00rootroot00000000000000PNG  IHDRd ~l) pHYs+IDATH DGIɏP^Zs j SqwHũF,+gmrH8*ݦ5GiUVycDԅ6c{PN9oV_{2䃗_ l}օfO IENDB`libgd-gd-2.1.1/tests/gdimageline/gdimageline_aa_outofrange.c000066400000000000000000000006431245535672000241120ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; im = gdImageCreateTrueColor(300, 300); gdImageSetAntiAliased(im, gdTrueColorAlpha(255, 255, 255, 0)); gdImageLine(im, -1, -1, -1, -1, gdAntiAliased); gdImageLine(im, 299, 299, 0, 299, gdAntiAliased); gdImageLine(im, 1,1, 50, 50, gdAntiAliased); /* Test for segfaults, if we reach this point, the test worked */ return 0; } libgd-gd-2.1.1/tests/gdimageline/gdimageline_bug5.c000066400000000000000000000023111245535672000221340ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { /* Declare the image */ gdImagePtr im, ref; /* Declare output files */ /* FILE *pngout; */ int black, white; im = gdImageCreateTrueColor(63318, 771); /* Allocate the color white (red, green and blue all maximum). */ white = gdImageColorAllocate(im, 255, 255, 255); /* Allocate the color white (red, green and blue all maximum). */ black = gdImageColorAllocate(im, 0, 0, 0); /* white background */ gdImageFill(im, 1, 1, white); /* Make a reference copy. */ ref = gdImageClone(im); gdImageSetAntiAliased(im, black); /* This line used to fail. */ gdImageLine(im, 28562, 631, 34266, 750, gdAntiAliased); gdTestAssert(gdMaxPixelDiff(im, ref) > 0); #if 0 { FILE *pngout; /* Open a file for writing. "wb" means "write binary", * important under MSDOS, harmless under Unix. */ pngout = fopen("test.png", "wb"); /* Output the image to the disk file in PNG format. */ gdImagePng(im, pngout); /* Close the files. */ fclose(pngout); } #endif /* Destroy the image in memory. */ gdImageDestroy(im); gdImageDestroy(ref); return gdNumFailures(); } libgd-gd-2.1.1/tests/gdimageopenpolygon/000077500000000000000000000000001245535672000202265ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimageopenpolygon/CMakeLists.txt000066400000000000000000000004551245535672000227720ustar00rootroot00000000000000SET(TESTS_FILES gdimageopenpolygon0 gdimageopenpolygon1 gdimageopenpolygon2 gdimageopenpolygon3 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon0.c000066400000000000000000000011411245535672000243360ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); gdImageOpenPolygon(im, NULL, 0, black); /* no effect */ gdImageOpenPolygon(im, NULL, -1, black); /* no effect */ r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimageopenpolygon/gdimageopenpolygon0.png", im); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon0.png000066400000000000000000000001371245535672000247040ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT8c``Q@Ox^IENDB`libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon1.c000066400000000000000000000013511245535672000243420ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; gdImageOpenPolygon(im, points, 1, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimageopenpolygon/gdimageopenpolygon1.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon1.png000066400000000000000000000001371245535672000247050ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT8c``Q@Ox^IENDB`libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon2.c000066400000000000000000000014171245535672000243460ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; points[1].x = 50; points[1].y = 70; gdImageOpenPolygon(im, points, 2, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimageopenpolygon/gdimageopenpolygon2.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon2.png000066400000000000000000000002141245535672000247020ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~AIDAT8Ρ  PZJGfޜFܺ)hh(tA\\CIũy,IENDB`libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon3.c000066400000000000000000000014651245535672000243520ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; points[1].x = 50; points[1].y = 70; points[2].x = 90; points[2].y = 30; gdImageOpenPolygon(im, points, 3, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimageopenpolygon/gdimageopenpolygon3.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimageopenpolygon/gdimageopenpolygon3.png000066400000000000000000000003551245535672000247110ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT81!  rAWIyx$q銸As2잽"O*H 'd Fp@FKX=7=,:ò >;hljQn=:ruɑ2 XbǺ"P+}a.ޠ sy; y++) { \ for (x = 0; x < (im)->sx; x++) { \ int p = gdImageColorResolve(im, i, i, i); \ gdImageSetPixel(im, x, y, p); \ i++; \ } \ } \ } while (0) #define CHECK_PIXELS(im, expected) do { \ int x, y; \ for (y = 0; y < (im)->sy; y++) { \ for (x = 0; x < (im)->sx; x++) { \ int p = gdImageGetPixel(im, x, y); \ int r = ((expected)[y/BLOCK_SIZE][x/BLOCK_SIZE]>>16)&0xFF; \ int g = ((expected)[y/BLOCK_SIZE][x/BLOCK_SIZE]>> 8)&0xFF; \ int b = ((expected)[y/BLOCK_SIZE][x/BLOCK_SIZE] )&0xFF; \ if (r != gdImageRed(im, p)) { \ printf("Red %x is expected, but %x\n", r, gdImageRed(im, p)); \ return 0; \ } \ if (g != gdImageGreen(im, p)) { \ printf("Green %x is expected, but %x\n", g, gdImageGreen(im, p)); \ return 0; \ } \ if (b != gdImageBlue(im, p)) { \ printf("Blue %x is expected, but %x\n", b, gdImageBlue(im, p)); \ return 0; \ } \ } \ } \ } while (0) static int testPixelate(gdImagePtr im) { if (gdImagePixelate(im, -1, GD_PIXELATE_UPPERLEFT) != 0) return 0; if (gdImagePixelate(im, 1, GD_PIXELATE_UPPERLEFT) != 1) return 0; if (gdImagePixelate(im, 2, -1) != 0) return 0; SETUP_PIXELS(im); if (!gdImagePixelate(im, BLOCK_SIZE, GD_PIXELATE_UPPERLEFT)) return 0; CHECK_PIXELS(im, expected_upperleft); SETUP_PIXELS(im); if (!gdImagePixelate(im, BLOCK_SIZE, GD_PIXELATE_AVERAGE)) return 0; CHECK_PIXELS(im, expected_average); return 1; } int main() { gdImagePtr im; im = gdImageCreate(WIDTH, WIDTH); if (!testPixelate(im)) { return 1; } gdImageDestroy(im); im = gdImageCreateTrueColor(WIDTH, WIDTH); if (!testPixelate(im)) { return 2; } gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/gdimagepolygon/000077500000000000000000000000001245535672000173445ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagepolygon/CMakeLists.txt000066400000000000000000000004351245535672000221060ustar00rootroot00000000000000SET(TESTS_FILES gdimagepolygon0 gdimagepolygon1 gdimagepolygon2 gdimagepolygon3 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon0.c000066400000000000000000000011211245535672000225700ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); gdImagePolygon(im, NULL, 0, black); /* no effect */ gdImagePolygon(im, NULL, -1, black); /* no effect */ r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagepolygon/gdimagepolygon0.png", im); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon0.png000066400000000000000000000001371245535672000231400ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT8c``Q@Ox^IENDB`libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon1.c000066400000000000000000000013351245535672000226000ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; gdImagePolygon(im, points, 1, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagepolygon/gdimagepolygon1.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon1.png000066400000000000000000000001431245535672000231360ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT8c`L@a0 F(4!ԆIENDB`libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon2.c000066400000000000000000000014031245535672000225750ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; points[1].x = 50; points[1].y = 70; gdImagePolygon(im, points, 2, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagepolygon/gdimagepolygon2.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon2.png000066400000000000000000000002141245535672000231360ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~AIDAT8Ρ  PZJGfޜFܺ)hh(tA\\CIũy,IENDB`libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon3.c000066400000000000000000000014511245535672000226010ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" int main(void) { gdImagePtr im; int white, black, r; gdPointPtr points; im = gdImageCreate(100, 100); if (!im) exit(EXIT_FAILURE); white = gdImageColorAllocate(im, 0xff, 0xff, 0xff); black = gdImageColorAllocate(im, 0, 0, 0); gdImageFilledRectangle(im, 0, 0, 99, 99, white); points = (gdPointPtr)calloc(3, sizeof(gdPoint)); if (!points) { gdImageDestroy(im); exit(EXIT_FAILURE); } points[0].x = 10; points[0].y = 10; points[1].x = 50; points[1].y = 70; points[2].x = 90; points[2].y = 30; gdImagePolygon(im, points, 3, black); r = gdAssertImageEqualsToFile(GDTEST_TOP_DIR "/gdimagepolygon/gdimagepolygon3.png", im); free(points); gdImageDestroy(im); if (!r) exit(EXIT_FAILURE); return EXIT_SUCCESS; } libgd-gd-2.1.1/tests/gdimagepolygon/gdimagepolygon3.png000066400000000000000000000004171245535672000231440ustar00rootroot00000000000000PNG  IHDRddJ,PLTEU~IDAT8폱 Co0BFL\dЌb0w6p >2pzTV]&pxMNWXAp5R^4J&^+UɰE^0ɯwS#$sMhs*;/BoL(tczӥ"#]BTHkU!I:$[n~ZIENDB`libgd-gd-2.1.1/tests/gdimagerectangle/000077500000000000000000000000001245535672000176215ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagerectangle/CMakeLists.txt000066400000000000000000000003761245535672000223670ustar00rootroot00000000000000SET(TESTS_FILES bug00003 bug00106_gdimagerectangle ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagerectangle/bug00003.c000066400000000000000000000007621245535672000211320ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int c1,c2,c3,c4; im = gdImageCreateTrueColor(100,100); gdImageRectangle(im, 2,2, 80,95, 0x50FFFFFF); c1 = gdImageGetTrueColorPixel(im, 2, 2); c2 = gdImageGetTrueColorPixel(im, 80, 95); c3 = gdImageGetTrueColorPixel(im, 80, 2); c4 = gdImageGetTrueColorPixel(im, 2, 95); gdImageDestroy(im); if (0x005e5e5e == c1 && 0x005e5e5e == c2 && 0x005e5e5e == c3 && 0x005e5e5e == c4) { return 0; } else { return 1; } } libgd-gd-2.1.1/tests/gdimagerectangle/bug00106_gdimagerectangle.c000066400000000000000000000007621245535672000245000ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int c1,c2,c3,c4; im = gdImageCreateTrueColor(10,10); if (!im) { return 1; } gdImageRectangle(im, 1,1, 1,1, 0x50FFFFFF); c1 = gdImageGetTrueColorPixel(im, 1, 1); c2 = gdImageGetTrueColorPixel(im, 2, 1); c3 = gdImageGetTrueColorPixel(im, 1, 2); c4 = gdImageGetTrueColorPixel(im, 2, 2); gdImageDestroy(im); if (0x005e5e5e == c1 && 0x0 == c2 && 0x0 == c3 && 0x0 == c4) { return 0; } else { return 1; } } libgd-gd-2.1.1/tests/gdimagerotate/000077500000000000000000000000001245535672000171535ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagerotate/CMakeLists.txt000066400000000000000000000003621245535672000217140ustar00rootroot00000000000000SET(TESTS_FILES bug00067 php_bug_64898 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagerotate/bug00067.c000066400000000000000000000023201245535672000204660ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im, exp; char path[2048]; const char *file_im = "gdimagerotate/remirh128.jpg"; const char *file_exp = "gdimagerotate/bug00067"; FILE *fp; int color; int error = 0; int angle; sprintf(path, "%s/%s", GDTEST_TOP_DIR, file_im); fp = fopen(path, "rb"); if (!fp) { gdTestErrorMsg("opening Jpeg %s for reading failed.\n", path); return 1; } im = gdImageCreateFromJpeg(fp); fclose(fp); if (!im) { gdTestErrorMsg("loading %s failed.\n", path); return 1; } color = gdImageColorAllocate(im, 0, 0, 0); if (color < 0) { gdTestErrorMsg("allocation color from image failed.\n"); gdImageDestroy(im); return 1; } for (angle = 0; angle <= 180; angle += 15) { exp = gdImageRotateInterpolated(im, angle, color); if (!exp) { gdTestErrorMsg("rotating image failed for %03d.\n", angle); gdImageDestroy(im); return 1; } sprintf(path, "%s/%s_%03d_exp.png", GDTEST_TOP_DIR, file_exp, angle); if (!gdAssertImageEqualsToFile(path, exp)) { gdTestErrorMsg("comparing rotated image to %s failed.\n", path); error += 1; } gdImageDestroy(exp); } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagerotate/bug00067_000_exp.png000066400000000000000000000727631245535672000223050ustar00rootroot00000000000000PNG  IHDRL\ pHYs   IDATxTMl[4ƜswDs}/ebStl Q h $@ >th!dD?tF 0. $A.*/ZkIc{+ Eg֚s1:oTZ53+|*cdQF>\~O7ԋ}ORz^o>=1Ty|ꦋ[vJ 9~9 u(,{swzKI-cD[c)L0#LQ`zkK"@ETjSٷͻGH*h#mYU1A@LE֙ @fH1=bRD4TU_gϘ*\D42kixdR czH9Ed]N~6pD=)jD-3,Q2&VXhZRRJ UKC>[jZ2sιm[ff>g_fRtղ왷cY9!x3}9'FCA]ۓ#"Wj;,<&ֺ ORI2Ŵ8Vq D&!tI1FDm ^*OjGBP9ZEϭ=n.gFl.T E!f&ȥ =#b ܵH\z]mdHpd<2Tњq"3R3H= 0Ѣ1G:)ȱGL4J^U`>ޮBFf]H"Zk"3332'31Ȝ8D$c +`):[kSE2MDtv3,; ESZ2ÃRLS`foCQcf&waI ZcWb>[k=memS(=]O9}LLT@“m^OE;3#c 9-sW)cQTI( V朄dR!">R#wQ(sj2}]>'RʜtX20"Ps쀘 ,mU 8"9stUg-3dߒBR!})-2#>SGpe܆|z|V>{oϿ>1S ebx,tOkk5G?5`̢R[1ӌptI^D$fFPJP}>KiG>QӊVx|"뜽afEDؗe* 8|F[vé^2qj)qLySGU}NP!"J K)ߝOuYJݮV~xϯu%  h8F`>ӯm+?«\O6O_tDĺ+vjns,x,dD&<@  RkVjgҬqT3Ӥ*5"|PV3dVݱ;²Z!}2qr iK.f{[KFY}6n&:کޖ⢁DZ^khpt22Edt#!]$8N۰}~߿_ƿVo>4KX!z_ښ&u]NɲOۮUkB\4%R8Lhu#DBU1}^} pXiDfh`|>f]WY-.-J6fJ)SYg=]^u탾l 3 Ix&HD{RLqSf0s1e!4O 3 $c11@TA c'P)sgj]o"Aϟf2FDfe`<>=3BOY&uTɭo;ћe+  "<.J j #LC2ᑑL [؆o0g񻼎gZBF3<8=sNU=tF1`d|!}GATd@bkkg|溞A 3PzG,"Bӈᗺ|svm?ƯG.s*RԶz n#p dB`Bp<,!#Pőy)쬎onM"XZT&uⱀ'Hf""j""gBg.3;ϱ,"sFc.zT)fVJR=('AO#hs׃dqzL)["#9ƨ;M=qY|Gt ""5RIZ)t:m__ܵ*ۿ>{\s^eeăőqIG:r24*wY 5QUe| r0d6)jiUXT)zХ#ߊȲ,FG{=U&\综D/r~{1mdwgfN'`ֺgG> 3c"}ߛ[ߍr^։ovy@:vGPZn1&$H|wB3*PFLd*%`3C@·V,XZs5R 1() ffZ<)gv#1ߋf6g?Vz}b>F9X634ֶf(L4SURi}DX *猧Eufg*1 d& seG|  9;3F%:Έp *BNJD{wˋj+ʲ޽|XZPJ) ;P"zL*H+E)$hZL$eP-K+ŀIL!cܞՅXu YpVDQV;Vܾ#`@A1jY}|ZI d9Wd⨾Id Nd '1FG4" @MK=Pg<^eǦfq]"m*Gȇ_ALdl,m>׀c9|JQND80)bIbf|N#XrXJmiYOftBZ>],i~h1bV*С33gzhZ;}TA(HUU͠Y-eErN RvTNHO6""g2 r0IK%%}Gx?n<'9C0@#Rt}m_鑪vI5X15^q ,@fzLI g&~Bs >R!f.SXmU@DLmeIJ]LΌg;|]&L*&ᔄ89q~PP3zA#!‘yN=(L09QGFYIR4+uY[k"2)ZjCriԁ sYZ-cp@(Hˡ1mgrP).*r2(σ%L)U$DL#XjyGH"AXkFP$#߇>'O!̟@'$ÀJ[]$0.ğrc.x}P1~ -#z$ڿ|V$<13=3S@-ϥ:w-ȟB@gxWD23Ȭ"+e%K F̙ϭO"#O_OUr4h-39;Bz>ffZk=UR&<~ڲ`$e),?8Uju)f.`֒edx7{ܒ}YN+Z)8~":}Вܴ8URB9]/ۍy.gEC4` ј*QH oɷwUF cI0*E_ \2P,%S 7&,C"#b";WHL;-(ܒnɜZb* LN+cѧ[k>ܧw[߯o{kU}g%;;Jt-\O1ƶZVݯ9""D.]v*V7\`9"P,?9ڑ*S$IT*~LIZ']ίyxEIw "%`3]\׺~qՅUku}1jj>Y۶i#ᙢRJ5/^xk,v8̓PE|nӨFRRB𘙥V3ۇçӺDbx,3L=_^3%%B3y@߲ӷ|q*N9Pif9I w3eB C'[ E3q/|]w",i?WS^z4m)v7h>.09“ZN}Ζ>OjPgP0C453;iwD$# w ,v>_pҥ؜V:38-=vLR(s7:cq,C(>#jD愄@SPCGgaqGɵ@ 4NxB1 h`>1ݢ{ff?Ǟ,NVoo/^h0H71ƺ{5Zj Dk]o")5zܮs9x {nCF{g)2sau RNits^~*$p;߶@:R(aL'EތAh+;!x\DPyAObvB_dYӿ_gƒx.=5+cL@͐IB2pňNP~4"bff+ ,-ww!\.R3gKQc)1J){N[)B3r?KA:2(_7B**Ff󵺸KLa ˔ %'\ `Q$2#F$UȐHĮl!Ia [I&~koOO/o%Ԛ>R̖c̱&o]Q}#t: ھjY!B{LNڌJvx6%HkmιrZku)VjK!or-W7x=UȘq vq CR8)L/3rWd&鐬Ku2`L3eB3“q-qzH/'1_ۘ!;23%TK9$/w?&R܏OI%1gs\mCROT1YQSgam)㬘2v9Z뺎++`AH=ɤmu6QU//F=բJ]i1~|>m]s"r裏}Q&O=ɹ$ѣgkw2ƠTlCJGp6S-][&$iGLA@c4q%\22ڞ|XG ӲkR[Z?|vZ>/Ӡlm-N}Zk;\y1qTk6<""eYUǜeqZ)S")"0O422 #AK%.4AWqը4#):;'5Q<6[Deo~ɬƻ9] iePNM_bQ!wIj-rywy҇R޻պl[RV~Q=nZ{庮55;@x׀gm%&d۶}'['coU#)),3Hi-3ꎜ@OIvj)&źƲC\a f1*94vMԑe8a6NϿ_Ϗ]:鷹iU)r~Y¥D9*Ֆwy}ڌpxyyq&4-,a3RJUAJ~>%V۶m4@ֈ@1]NX)>SJj-)#foݖ7ࡤx@$1T03$'[e X@ xfl$!$8NP řHHQV@zfBRҊWcL_?k޾砪V")ZMӵYy駭~S:=Xr^zvx5kb**R8 [iH iLz4zG\ڊ<$Aݮ˲<ŨP/=fL\IUU].5k'z^<'Q6#]U'bS:bB%R#\j}Gb$[/_?-r`~mOO>{ͼ-P0HĜ?oՋWOkQUe` }╙==n IDATZ$#"k@\a{橽Z"cqPB>]/ˑJ1L1$N-r{ZDfHd:j//|D1.HGLD"hx 4jRR*._) 1}f.s +L$&# F‰-D2=~?^}[5ήX]Nocα>6'#US|ZZȜiGVp/$r~qmύ1u_?73>`s~D0PҐ%ñ"@NRDd@AE(8lXatٓ]dW2=^=" s:ngcQgR13M`Ľ>lhYL-Ã3Ug:琥fzOV$]5ϱ,mMj(er7AYk~Kq>2'gvhd2C{X6PQ!3sOG0,@U@GS&ӃΣ/ GG\̙2c"ӻcpKv{xyh3ğ|JghW?vĞx=DJﳵ3nZwGAedvQ+Ÿ=ۛ7?F1[)}~QBO-G._q_}]mm1ς dY `5i"EUSJY93@|BĆ"o nņ>'wA+LDV?q  xM GsȪIY麕 YU>NsJ)6 ,[`w={?u]Gߛ_|.ݫ-XOM ۟>m[/*ĺxȄg8=JmF@|#w#|؁*dž,m]e1ˇTg^}|rˇOx}[x\YΑf~ڄ?o%g]ꜥRNv=˲>"2"JF+XF;s2bt}q&ʌC]&6;e3%o>y8:7 тuV PRP<6r7o}N)kD/fy*Zk]OWG˪K=6$=3ccBo+,ԻDR=_U)n᳊wO'%"VN _ >XK@J1 ZoCJ1cYm_]3ED< ў<YBA2SDDKGx9'onjdB"`VH($ HFGD-|멽VԖӲ,i]W)ÇI9޽{Fx ͙}=&tPJZZ>{x< Ԕcuy2T~go|݋vZS 5sΪvZ1 TӈQ"B>wˍ9 dSm}f,eYK|/KY_3k‘'& Fyr|g) !"O_ng32,oOzq:-O>~o|]ߞ>i sSܢVUcM,UbF!3vXPq'W\oc(!ae)я.֢/.糢EYZSNgx(Z$hRVE4bQBuL2"c$)ETX̑`D@dXTb{UIŶDŽH;C%Q25+_|EV,H"VwRH} U^zVO|߉zad")s>;ƒ$d97bE^/|y]]^mcYK$TQU!}gFf-j۶EN*"cFp_uOI-DJp$'F<"NM?c am^4p}ykOdau[,YQ>\L-ռW <¯#D3,vplޅDǂ\!ǖ#~1fݜ_[ U4*J+@aˆF!RGo'2@n($;DeK!EU}ۜf7k1r"s1017Uj4,8S1#!N%14 !lgRM֡ugmmMִ-8Z!F,ZfR5RXnA}LN_~?Ͼ'NϠ$Ɛj+#ANM@8L3|z 35XTVorJ)Եf!H1Y/x>sL /P4*4;71BK>>.)KLW?]>!`CL3 e4JgliQA;uLJ*D#c'&q(F,̃A_|oۧ㺮 !f:_qkkFSs:&f!t:'`P'.~7G9ֹrr25 pH-5B%K)EHr+9hCJN\zΗ^b1\ZA !kڜXeo>Y^TBFfPgUF\};g?/~~8ާ@jZ>x#Q 6DfP|8`D u]AS?cm/@<7&% Mgo)nW8k#;|H1yx{t8c$r[s2&j l5 r3XJȭ1PZ552_#]/s*":cnw1*bL)%ʹU*Ո0vQԮ/WN7++EN ^:o~Wrцs1+sȜESWqχJR6d71BR:>ǿo˽?l (T'ϦQJi;%+J%FPŵ }ՆJenmP0aIsB9fLU] JKK{o|-0LV#5vҘRΊ^QJ*Њbr3:˵D7BGW>r9SJaxֺ+-C*nw:riBJ &Da+)RJJɹr~JwBRX͛ۏ^քU/??cRO_']7OӐVBMcS9^dSX?#8NaYj"5JfX2\ZrR@XB|?7˩<*X+'UNڜ$(eZeK|niTBY h`]{~RJlww_RtCH R̠pqpB(vz5nFD؞bOo!_KѿqlZa~uWф $tZJFG?㓧_?'uʘ&׺sI-!i)E`Zu~ȒS?8As6u꽔i~K˲Z(; )ť;K_~hT7n>d䣵6z]1)ߕr}׏V"N,l߽~8>]Ku]7!Fk3jFB= G_O,ĩrTQrSNJ"K ȇ(>~xsw|_@-kn~Zu׃$^w#vxG^~p<2_'B(S Q{v3={=uhPOݗ3?苟wC.!M{z`QQ(x-/=5wUkguEh*5qawe[ne]nnn lP[!u7ai2y^5&x,Z)mOnx7C3)-RU:wtV^ɿv3gC~RhM]?9Vʹk!h%ꂏҺv$$E0YNזp8]g@BJlJ?n;ʲ?0<ǿb~:TT(v@ 1*w 뢵>19>R5k.83s)2ג7FZwYfÃR07V!Fyz׋dVq׭KZh%~hQc\H*׷\O4xj:+P\rk%Tr Į?> !yQHҹ2Ng!p#. djX/~[@5\ $lDv;L$tmE!s]H8\n1 %CJ0"jɯ LҺ[1nzU&4Lc{hJ8=!g/@iI֐Fc>g9SD@H [E duPkeZs%%0 \7U]iVPu rHc4u>ڕ?a׷'hs!.rOV3ƾJ)xBv)x^.FBQ@on ֚.qvP)OwLŬQdhu}6B|ΐK!T_k7G;M S- Q*%gy 0 ڐVM2kڰqv92@Z+X@ISrD\+t%r&LaHٕQֱvN!THn0eMd;nCVǷõ.'ݩ5C7RFq=?e1 ri:N~kr-ptu#`ݺ^RS\THq?vJK"1K)~@0HQMr*\}`mZS[(1-˲,6<򝣊%H: ΜsJΆeRǾo1Cr(a`T[5 2)#sn40D|"ffkm6r]%sBe~ l9r)%gRa]~a@ZbT544MD{eFCZ͛pq| !%!1Ot8RIˮjq;.t6v(3K\˲^ښ{QK)Z](%F jJ6JHޭ\}4,4A+zg~3VKlk@*7770LAk9O[ki.)8R؅ښ,1\N3?}ܺRJI 9rha%iMI0j;kmiŋ^} @3i-KiH\sA53J]S4݁ ZqVy{/hRa0ZC[R5jO4t*ÍcLLP}/ZF*"ڶhan08mRfr-ab^jTh֍9'6pB[V|AD&ܰRJ!MɟZH@d̏=i,VAMJs\DdnWmUYָa ~ҼJ*1+%k.41הR-tBU ZQY[ 3JCr]v-.E:)fn8̵0B%(Fc>rZ7vST3nQֹ]%v}WZU;BϻL)%*oooΙn)Nq m/15Dy%t&K,2|9pz|L. 62 l}Z:/1ưaY(eu謕-E Fb^.1Z T)vY/̌)+ g:3YK#R%9aja{LyN)s[Gj @)m{rNTr [̜J9s9xXieYSZ<>>P nMy]ref=`Ȼx ]jBmy]vk*!7Fxk2dT[mĸ.fRJL[ﺮ7.:;NAJl\ښrA\ m1ak0Uj}ys!&?)ݕV7>Fe2)Dƺ|HJA9G%1!B~m(%;DtQy0XuݰhVR3k):Ȼs{s "9?>>w/o_c|n7 ÉQJaz-@?Qwhը(#3s{{#a=<kaqZcnJ)!d+pYJ)rOUF{c)E o0|\~[k}X71DU;h@𾔴s)JL[׶)|),0:gt}{[.L.W=Ϗ^JWk/~u]QNaLVkHIZb5V^} AiRhm+⹬qC !PMҹE2F[XiSJ~7|u֒"ʮ\_ PZ%࿄43C߻wL{3ψ}'E,rIɳ~O_XgrM^I$Ʊ_fڀ7Ƽ rn 8y))4 sw˿Ovb>_XbUk-J"Y4 DU8}هy#%1z̔r 6DԨV !B)!1!CC\R:0_R9pD,IARƝR !rNY&%RB\aCg*YZ+iYc"*rtI!\f$Z+R!ZRι~R/r5V~߶em.`+ www%Eku]֐zY})Lܸ*V!\} OOi{.gW>.eIE]?6|-%0u]BYbvI-nv} ^.cBVSJJ)-5䜺5eFRQRJ(˅2Qݽ2sj癸[zmkZJkzѲ, 3,},1pصVιa^/3&Gp|lDI3JmR[z}G'b"9/הR {/kTO>D2]~MÈ9GxHkKUJin'[E&xK R8"Hk-"U|m32Ɣq1a4J9_ @9⑰FO5q 5*̕ cvjxku>}%Ssr V~ZkYRZaU{Z̛7V3c-JJJSjކ%xu|䗪}5_}]n &0o1PԖ|cehOzzx~Ë/60.YCapq[̫4LcJɧV!@-k.Wj\k9県RZKX=媶 sD6 0vۮԗ˩6Di[R_.rVicNwB+.(xBz"VUSZ+M`c"x<_jc", C̳o tҸ].i^;^ݻ:K9?}ُ?tc^}=gϾ\L˥;^JQkhBg*QNߺ˺TAk]JF)qB̠P\r(XZZJrLZv:-'e z=^}]\vTUJ60<_HJy UrM>QVpc\Aw=_x.JʭaB)-U((;O߼y-I+"jzYD@\RV ?o^W6>jVZ'>T p}u|Z) rHeM1̕k1:qx~wo> _}Sva<q=}gY O}j.%mB-8><>"X}?'<>>PrtFyðuĩӃj4IOS+$ 9D`ֺ.sk]Y){!nzDB?}zݻt_9G'ZJ4_Xު8{1:/|RJD|||}z)>ntzl▞+pJjm+M9gZdyͤGTRkQw2_R=FHNĵrZۀCNպhr}$4k_[^:)jID~Mg4y?W|cU#vG-ԥpa4Zj!,Yr咵Ӎ9ہH^I/}z\N(PُџZ+ |]7$M(0vo'L( !JRJnTk]iclF &Fgk]WDLrZrn%Wh$AU 1Xdũ|LR.\J\AIk FZawᆙ_/אի7]g)*)bHZ@dohh:{L{+^ {P!? ) R޿s"W|`ܐ+\浶;wQJRZ%RkZ|r ή~"h5Y ^Jh-#NkMeKz5ЙyFDk-F/QDJ{wwwsmH0/wwwuQfD !(C MJ* Rah't>i)i D%Zڄ꒲VX) @!\JL[6DD\(̈ZZK)E/tw[| wK1@!H-7Kn>)Z2Ik.~!"p\a=J%[Z+$Ow͡"Hbgq콏9Bj)Z @d B[Kq=qoi;(ytZZR÷Zq 1P֟~g<߻F J}ƇhT q$&j]ƭiz5c+Qz׹nk}J벌C蘲RRk%V8R4jU}-]juo_, CF)! phF!E܌T%W-R2wBw'x3_BsC>}z>_>>><^JSmd" 'O<)5 B'MgB e "ZKQ6LP5er,W*+!$i1Cƕ>'YkW:+d s2և úExZk˲& TJ)RkT[HJR~s )R ZlιSƚSֹA^H?k  UBR*q 25d՜ђqH4 [ CHcO>;sJ"QRh#ZU+e]gm[c5~8/eIpKέa/d5ooϗٺ^)CRX"dh Xk@[K=\gS1x`RJ{kuKMXkv\R I;q1圥֭UD|r \JIqT֊v)Rl<Ds *oc f]N** >jӇ a\%~swzB&V$>./TJ5!|C1Ҵ,;}3*0{/o^}pX.P+9J*:+RfeBaRcBK3rL$r؂Oyס !bݽAK)R?V)]s`6>U"KgQM2{)ܰ;( KBh8_nRBjĒ+HϾ/Z;}\.el"M.5sa!s>\H |ɛNi (װvpMAM} ܄^^3=Ԝks;u:/ޛl~KJ05Rl(Uʥ6*0J@%g#UyuBl{J5L((EB %n1FԶl>i]WZJI1FUX5k-mbV-4?|*51s[}e6G;ME@l@-ZB^'rӡ;+2)MI$[^Ә7UVf 4$*$9 $ 9 ټ|ݸzcixP6p8Ƕsow?> i(`3XJ |>֮eYn[*rżr=%Rmc$k-9)B ,1r-kRVRwmRZ^ I(q7dfmV0'CSH,t9һ|?aa Y`7~+ %8@io|vS7E& 1ǧ^x޶Rӧ[kB"[}~`Z״ 9UJZK q8ݾjLjJ qk!EX5FfFvf2kSFAR)'Ð֭KkCεV!!b1 !"B"3ByhZuAOAb?_|qk=]e7"z"B-y`-5j~4LKfZ|4>eۏwwo~A01Mr_rs&a+Kιr,x;l1[k%Zѕ-LUՖu"ZS oEҼ댈Q~Z6b"!^N9S5 YcúnDӗחeVQp8ba18ûu4M˼dhj[-ôu^BXJ}so[S [@}jwSp7D2'.OcU8?W1  m!ܨW۟^qw[ 3k~Wem[mS5ȱwӺ/#/<6/3s U{bZkm @Sm]͛~rB̦N,"1@A u[lfn|v^1ӺnCm:]R׷z#z]r> lw=ixM4O Y mR$緷<_U{ MR;q pt ښixDJ٘[9g3ĭ40;v!Άǿ1&&カZTIbrz5H ykJP%m[,!y~~>mjk]msiv} cuۆ()А Гpm;c1O9(9cayٶZ5oK바mY[ 1ږuVHA|?UՄ׭20㮵$^`?2/s8hUWuӮfn1V+3Xp]ymDZfnVE޴͵MhޛcLq˭QU[3V4eY+Jk_Oos>V\~xu%聹^6MٻnCCl0iD>;x^uI98륎@/뛤<|߁vw$9"[ֵNƻiz>$MaSݐnNniq1&D )5;]m%$8ADM//al*anhz`7P37QMZahuuY[&17wtG5@yj?ϋ̆Zs]{ww}c U4Bo6ou݈Y2GgJ@!NSvPk-PDStS gcG)MOO>1c\e܁UsRݿRvF?<܍J$) 1־>{}}SUwv3m6tRUMQ?VU:Zwn+5 SSmZkSym_^N3d:eEj~za7,3!%7KFkk:obxZUDg s8`B|cnEv9Cx:a"#;N?]kp|mƜIA5ly+[ۏ?q؟,n>vә% غ miQnlS7j1-vŜ^e!'}i|n1껰8wQn'NZTb;ǩ̭<l\H0q){ӾQwi ;^%䤪n޴HkՑ)DP4EsL"H544Ï7Gc9lK9qop(ۛwq)>Nz]bfm R0LD뺊ouE6 ݙ(d8oE=D$$'z0.nӇw;D )_~O)߸ n|,"DL("HoG}i@ br/PM[1콕L/'|8^֭ S^€-Lȯ?|R$ d~|t̙yӘj'I4 pk<&HA`@99 L L pkL{ɂx}x|חZkRe3)#Vkur6$|` +1b~~мK6nnop6E$$ G"xSZ7mçW>~rk}}vP;:vDdKwt@]1"P1Ӽmȱ٪1LAof$EnDdEaS(@ѡ9#JȀݡk7! e;5x*8rY\1{eZwC&]à z7SvZڞQd5ix[w;# |g׫fn ~alӁݲ(ZkNHtnkr:33*ں뼵N90vFW1ش.}|{7nUo pD56ESRwͯbjkW]䮵AܣT,*y ~x~ʹ1vu溬%FsyzMD+v ix~{$Kyst2l}V+# "01h3X:lhifaO<ՍJ][W„}} H~ǽ?~<~i^ZV&2G@6rrRPC0 NuܖA^K35awmk綒`tCPjPj^j?L8ḏPkJ䤠(M&1O;=@phZOߧ\[֭,k%1&]Sx );[\Kn ")V])Ʉ̠Wݕ6~#Kۍ ɍ A8/E$S7FWw0膷|5?>X8,r2q7w"b:!iI8b*Nҕ()2k+LHZuYk+s`_|~HɖunM [v՘y7g@u?\==A̴! ywQm7G@k-3q^8\ΛzuWR78#8TWCg h7?7Haƌ%V)Tk}~~f!q7(}lͪA#ytKΕʹzaZ? ˯u4]-~Lnl߬75sCgooHՂTkWNvr.ww 9~7lnPRR*/./,m)_b(acH^ ͟c]bvfm>ݽ5uF!1sgU*#W58܉;n@,u=bjj%qȡރ)۶FJH6G Z$fEDSp&bRa"ra7<<Vf$ a9xaTLEpf"nXԭmf$ )r`A?} .9N4%QVTJy )p)KT6Nđ 2]0dnc :!dIRJhz|xE[q(phF^rK[˺l3ݶmvwЉ\A ;" ioK`=-0[[W߅o$ t@r1۔ ݂sVVf@!W|9RVw_)ܶ!粮,(9 "S@^.__~Pbl[f!S03WUn!j,0Ե̒ŵjϧ|B4qgǣןbjI Ӳn9-P{H؅z%YΈ5p"ސSjJGCR*{5Ft2 "5)-1y^JDw^0O0$fq 4C vpWSG &<>=nu>xh$.r(Uqʫ2 {389 , $?m;0}ޚr9$%K[zHz%2C@̼!msc bjFH!Zҗe{|nw̜#}yio?B<|1p* Ej7ֵ.)>aRlۜr2r"jLwB Fd:cIx!z|̀}]WuGjAu:H 3تAT LSGo֫w|!^8֋3FD'"8 (KL0Zq]KR\or<rjNrnڬt$Z5j}0LhqDfJ=>-/gN.}͡ݶօ9mֵQy,RJpjJ2WBץzIp)Mޒwa$ޔ`NMA͙ItwvF#P@~@'Θ!V`x~Lt7Ė?3"솄rIENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_015_exp.png000066400000000000000000001036531245535672000223040ustar00rootroot00000000000000PNG  IHDR8 pHYs+ IDATxymyVYϹͯz̃`D&lY B!vl%8+V9& D$bFD؉Ilt3PU]5w9g߰Wt߻wϰ뷾Z?777 yܻ7׿9\ o[ o{o{?BLn }8.o;{3~CdY & * Z|~ٗwf;O'3K(h3*XiD}2o h0lF. 1D4kD!Ĉ5cG5=OoRf<~;D)RjFmJ`P[A0TiYJ!Ā&)\<\lo#u@B5s0 AV4*& *j`HD="aibtn ׎O ›<~& T!H.F\1Qy!QKn J΍̳_mkyabo~343BL`j̃QD* #bBk4 ARJ%M+,g< 5@XL!v {tjD"H@C$QњyUTQ#,&`L2Vb iQPÚh-̊_BP`p JkU0èD3bR" FkƔ688A T3YVVCDiRgփ r)*…ÉGo9zf<~;e +/FwW+RTEvH67rmӄPJF`3FCT!!URw 냑fPl YWvl/?I5PED=P@ "@U4D hHfhhT ˲ԟ_CYGBD0R*!( ຨ QK{C? $(ь@ccճv3FRL"&ꜘ"B-P[CQ%nJ JTJ-fU FZ@3 @LL޿B\$2\`{#"5Cd[3\5A]BfAkTj@X KAc$BŪaLĈ a !^Vj@B pjgA#TlJl{8' QYVl7[2˲jCRDԨV-7rޡDZa͘bJNqh`1 fi3+#ebX1W@9 &Bh&lTFX%G^} 2ۏ|KPBJ*V6ˌI(%5Z^TCΉ*)E1bT!jmRi NRJE|1K&8 j"T`\Qj A99.KQa 2*4kX!>f݋7DJm\0\)*ԆJ#ĝZ kL`9:ŋXJ-#M@]HHDC`ɅJ'qPh(2VeUbXhY FWTҪp{RhVwT9r-~?FhUy1Eklw,-7ܹuѮv v1 \xVh̙H#D3ϒ!t*J MC3Z(:BYWbPX.WAN<{jh 40/[d@.!E\^}C7k.R5U"n,r&8by&'zv(HT5lEλ˜AWa@z>l 12 #K3VXRhvϑBYBD(yuB%7T! R(!XFtc` nvt\vzjtED yz~[fOmjDUef+fj% S בoQμ٠ #xf'?UgG{Q]&d,5+GL| K30m=B0 "N #hB}$@^ iY#)0(QU HmSfF۝ˍ+O_nG(5ᅛG(A0-0Ŝ3pkA02ݞ9^?FI+AQjuth*Ďct@5;bPboTV@N%,'CRtD:c'^JI\x_^ߒC7,ap"@ R’:1op+,{N6Hm$!Ah10_L|Id 0sz6#Y9/I`\ȕvHF1ۀ@UhHR3+zfQZmCPb (4Q58xMdޏТ`!HREMӐ-0["~/!D'5 yfLڝfFm=hRR/S? u%3"D1B$Fۓ"pLEbj;WhX&kwOry)M!m:Z#QeFDP y6 tZCTN4`_!8Q湐RbY *h(L@G^N7,~/X3ʂ O*{Zgc`pɗяByL[fW1GvMtE`#QNGj3/E. -QJ`1x_ޏ *UD5!Zu/[#W)L)E%wQ5μT i@ k^F CT;Ő( C(-\xߡ}h )9)sCىǐԗZ'^fi$tGp 7z w e?1FޱE5:&B1C,z0z?1.~ޓk* #& UJ+ SgX㮛&rPk%vٳBL^׉E>LHRRߏjP[E[]SFUZk sFLF4FBmy'wf3>؆B Y7w[g̳Rq_hHG'r᩷.zu 8[ -C] B n !!@cЬF"ncFFSj|K.a@KbHsߝh-W/_loz oIq@T(E\$^irS!2Di(ΗEUv~iG?tEz=el5 }%bƈ#SKd9,\ʲ4 hpP\ r~{.^DZ˷k! 4+,K%3PuT JGS"®TnUάMPJ%H)a SaHG[3?e,[81k^zUMŋZ2dZTHCd[ cRn6LO}uSEگ]-C[ū5>N  ҵJoޙPȟZDp;wwHeɬ0z]k팔XY aгNh AqRӅ4̯^c 0~Ubr5ik=]_xS8"VfX9DH_b_u0As`b@`A 79}9Vo}6vJf, i-;bCLk"N<`Cm\00$oxgi)>?g|B`?Ř6*#J " j`0WyG΀BBq% a2oL֘煶d 7;3bϾgNM1Z cH3aF#9CVdOފ0"8(uT@+TuaA gX{KذVA AYLP 0n% #aТv4]Ev0zW8Ccr[Tf7j=.>~뗰ܤV}&(M1 $M 77[8 1[C["n @C4ffP?,Ӆ ŖJTA#k!z8"΂ #ͩo'zrV#hrUK?Y wĺ 3u^Ϩe.O?կ܊4uk& YvDYvx&ڧKBC6A4ԨVb 0+(!F312!W'^/z"Ƒ@C%hi" )%j#ÃhpܒY_$(%g9˂5cu&7wc  J`hƒEy,pQ ˁr)Xǵ[}Ԍa0W![.vwΐɧ^egufIf 4 wjȥRJ#H|!j͜!aHq$J" *aX'}Ð 4?xzgB2 YܹCj"M 8dtʯ>C<ڒhTVI4,2&™#YuT]NAsX#$~="%1pPv܅P5㙋E58GD4&!&s[L,Ate;>eX zoX i v)˹xּ"!$VQDɵtCb#R"N\ 4S_(OHB9VJNKl^A鲎k곞\JXkgJ`.LT*j&b@eKDmFNI4,-Pp֞}ۧw8,ژT#9D1 4;U!8$ĔQ&.8XIt@4M4uP沸Ɍϣ1pὌ3?/t'(!ѵ=ޑ-P1k>ҫ\peTΕa(޲I]J)KR$p0ָ->EQ>^ˠD&kbvwp׊~)pNF^  5 7/[. m`d µ=;.4䌦@^v3o=f 4"y%a5 1f0@Je.q=QZ! ɹgIL˳ jP*Oxo6/̰EXJRr(K5 y&Cr8´Z{׊TEgiz1B5 e[';xNiؓ10" c>C²ܙ|BϩpC! UnցM $'M NdFm ʌɔfv0繹_E H ͲCÀXCc:DW*'pKɄ)TZ ; i &̘70fj/~5= 6U_[pBY )5 SAq%ea)#aw-/"3w A>\%F^qɅhd_[&X'ws !]%탻uIyFg%:ͱ낫V#a_{7@5b5Y w>]2L3)m;yeKv[/x"' 8|wyE@BVU?jdG}gŶDs;!b> z#[7o,q˯@¼lH;+3-B$Ƅ.5%g{OA RGKqMב5R% x߀ZW ,m&T4L۹L,SU(6rw/0|翝HF37VS < vMvϿȭ_˧^ܾ6Ϝ`P Kp+s>12~ʹU"ս6+yW\fԢAɥ8:C^ JɄE*zYњۈv'L T]G*gm3VD§dT+dQ[L~?*MrEhr ՔPP*28kgN`XTv:W/чFk.w0\Sn|~W>+>)ȅ:/Zill; '? ~[Yz~hŖYF x՛Ccp3zx#OɅ*1A! dsCD2!X eN*>AP#˽ w[Fi/~ /}DNilqX:l9<ޗrA- 8jk};,RL%WbJK& DIÀV>87qz]5ջgǨ_\zQ,JiXڧމ Cg/0TYq*Cս_H&^ " bWԃUG6D?O3ʉwPN+=+>OkK] `W8^,%۷?B$1Nx/e荷iZ! ݭ'өVGi(|A9X2O䂵Fm$Hv!ė0iMHΚF%oD~ij+ 5QGڹCih:!bA5aJkGg%~Cس|iv7o`өYy_tN19㯧JhE 7^C!ѩ" U.^^Mý6 *oiS1,E щ,^)7NkڮЀ\*!$mr5`g4V̄]gn%Kӊ߷|x%wY8UT!T-9=FPq=0l6;Պzѝ{337J~BG[וDB--"uh\L#\:JlJðBCq>6/kJ"4d04EpS`u0(Q8i"\,b-H"{I/{ ~5jŗzu j*C0XPjBS6x&4\;>~>U/ݖOӵf؄b}kvU,b\ q4Mw{lٜcJ)bGz)ќ1챙 $VGG֬)Qc0BPj #qHkSЂkpyQh<ה O#5yOs>TJs ne8+Kx{v$1L}{ IDATq07Z[m 2<*[1NJq0NlU̵3ޡ٧w`8^PUXִ}?_kw?yo۾@ k꧟fFRz͵kYD^61ɳQ<6IHq Hh,d+|/O`} 4m}Y>:؇x;q_h,p,Ũ]?ҌZڸ S)ZON+@.ls'qZX푵:A-3zԎ#"rj V#oϥ⎚..FfJDkR20wگ 6c3XJ!Dpӧ!Ҧ]…sjX) bbť ´JW}`w.5(NBGɡ6}-x7M4_-HSL,VXlrn\q pT_TH1j5^I= _!k3j[-ۨ\yx;]|oK yqgȒ+fGeɜ;w8$J&MDH1y9Do QbCnu<\_V8 ʰjU2В0LkBQFl adIxNG7vb L@㞄%2Fp:gg{)`e+ UK<L`f,iG$3ފP [ 7MaUVQbTb=dM#sTEw 6OQۙqgOm5Le!Tk[?>6휛y!ܶcP U .rMv0 >q1 *P6 X adRh >fݛts+D)<i }ZhkJ\b:0X+KuC-qI!$wTjJĸ]ƫ1JrJԖIs8K_ PS3,H\AUԄ$BF6c [8_3Zki"u,RL9A|ξcGt(:@B8^u5w\yRs1J5*NSv-JKq(6vfMld Stܸ;ZXp*a0N>|: dq"zu@N#Kɴf|缓vBYr!iSscT \ iXJau>Uo}%ҐNyU& B% }U Ƅr>W*A" %, }(*&Pa6zj|"\_a))!2N̔t*&7Y6*> q+W|;UG7Raؖ00"2a' bU_\p[G6J#m$/RC$%z6YEZ`ՅBҕ+lܡ,[59#VR}uR /9-Df{=IxﮕSLVTYt̘4Ad1nFpW| W22Q؂ՂHѝPBe Qid ']ZY3FAzy*2>_狾+9͕P+,!Mn7\v5$,3V53Ds{3O>(?|oOtiMF}2j߯}F-HWPyޑseij~0Sj-%Ӳ\._ r}O_nhC+W+4E&ml[`{1RsoWMM8LʁFV껴hۡq{\~|-\ysBɴPP`$]q^n.?J t!dQ"KVN>Y”ݲKe_los6ԇ.}~sTZ)k!@ 1%&[ .`0SZḨ6x= @k1<}n| ]b^ôJJȶ,`6k\N@w|A>-i5RV̻,C`*+CWp*0\,WM*\xᇹL |lw 7!v-őJ b Re=  FCY`TCs`%8_#^Či@얮RFbWˎfBL,>W 9x۟ڿ0\τMζƉ T3Y.04: 1t#_i`GĘx ZP4T BZ%MCTXkdF^8JʥY;dVSdѰ3ێ$(#6Vj,hɽ"eּ) &k_mb ,f0h0ߺr$Rq1D5bSo[tDZc~a\SFΕ#V=]NJUio RɹP@`ZGk[\y[mnq;3RRҔ `}x;4sےHXd'rΔf w @moz\S`yFpV2*hfd+7* (TDYib bvC=t?W.p%0Pa2ǿk?wRs*(l ~GY* 1e:=8z5Cwh Qf.'nS6dp&~|7|-(8Ln;Z78:''3ta>;ۜ No 晚3k}->cBMCQq7:88pm8@8w2^z޷]O}X-3Ӹvvns#~^v+ޑ+nutObh0!eRe6U;U.> O=16fhhH jX>]H= !^La1hqգc<.v0j!00S@|'wH;k&\r;>L\5OL )i`\XwË7hT%>w!SJam҈FRB̉G~ Y'kA|)ջsr5r];TS8>) Wh`P" m14؝4?|ȡr9d>b5K{\]]3=l2q!ȉ@n""MB("q@n"ħx3wt qi5(k@;m+#s@Dm\ Ҫ\jJ䜉rÁ#w3L!'r'Nn3ndghs  Co]]| OQ1szyB z:CEN jh{KY)M=*8 AD\?~/_y5b\4~Pޒ-+f5Nu/.lX vkiB%?dy/'<2hrT[ ۠W{q0pR>Ӻ9,p=w$ՔDuNU9TUPJI&/)rn91hMsw'J)D揾Dl]n3(GD78_Zǣ|c4GgSs;8k)4rfmIƱgg jtfGqTKaYCH1S~W~[l CI zK4hv (ntځiVa@M @G/ڲG,_xKU2j^SpT{*| O?}GW\6N茮?M3EMk-ݭ9K^+:#;:2Z\H]iYșdNip"-M =/",~L?Ar^eT^(:eqh_9M޸|O~??ZQr4r힠24d\C^_`jN"W,VZ@"$С'H"-G?=?/K׷r)%)ci3zK_ӻ_#f\VrVX!ƻ[Z:co}:!1 Ns2HԊZEJ3L3,ps ,R4(:0diy[E<njҍVh݈ibØ N5UT4&S gOSB7j5ܟ1[V'_gQơXJv̲2n>gVxSsbiZPڰL&cH,jhkXg-)g+a[Pz#%b"+ P/}S~ŦcTJ~?QwGT)1gQ-sSD(.C"5V!fvX+%:9oMNRɥ(.{AC"Vh9Cjj&Irjg_39Rl݆W]4[)NQa1mGQ $:[D Q/ s`]G͠mTqYi܌X+cyA[M<)EIp*ȼ,E;AIR5bY"HݪIws}&)"a(gѹR9wVnt4ADѪA蜰ϚFMYog4wViv)D\uWd6losJZTΥ1'Ei^']gU%e|o#V/O-JkM:OiWJ oԔкIR %[k~AxJ{>s>)onG:]*I%C};,= dOL6ԫgd;`- i.>Yo<~⊋+yU>JDap+kNq n(} ;ʶu{P}8_ܢI w ',,WEH [ڏZf%o-l6k$uo9C׉(*،Ѡ սy[ IDAT8t$51W vS$%$DcZTAxu ɶ FL|GWж-CcH߷<5/;p};ia D[jF"%̔ൡ7),p4ZL] j1la-V'L)s#^~}kN5G&7V_EeYX똗EMBu&(%i()r{s6Z =P}];n^NO ?/~=OGV=~vG} cyu^x<8凴ifÆuȹ;d;M%EiV+݈4ܭnGΙ02 m,W+b-'7E"^N$Ծ΢aAP")% t{ J% uhS^Q((m/_?ӤҨe D3]q=rB5 9'8o(IRKɨQ|]QKeڗ=5L²+1a?~{wR,1T(9x9c~x >Ns UY~2E~n4le?,2L a^;4VTc:uZ{=WHwp2D:"qnmSD&&SՈwVqV0Fc+C}뿑~]a1٣6G&*Rb![ 2ëlU3 7&c<{|RXMS 5D+7NfU(b@U0 }'n~CJ]ҫw!q:O31rJkah;@5T%dV_Q3QS /b>΄0 dʚKZ׌W1h-*i 2OYi"Wr3PkyG#QMŭC\yc(;g}3oغ .SR0c4UrˌV~OsKw>r uZк |h5gR ^Ɗma8xm͖)BPkסcz%g:95NNh+C쬈eVMÒߚܺucEx8Lә\&ɉjUhk@$R`;P7w'tve|)9]Z˲5eokHBT_l`jrDJe>'y_l?,@]R7acz~/:, hL W n1,ڰ#t=!&4 <vCG 3K+zJYYdšic<]u=ޯ\O4fKY<*Jm躎2X]Q58mE DDʒ"4JE\NƲ#rFly%sYH[cŠ~()3M)F^'6+%;ԇüLLKk.Xiǟ ѣ'~S2XsJ)l[y8z99Lw{TgYQ锸x6a 9apP ,Y%o`YPhP~j;6z݃Og:gU#ZL?mCG"LMQJo{wk(M{ɖͲL$7ڰ*%L?zY㨵NOm(pD~aoyeVqܬ%դZ>;e.%քlǞ)qzG(ubNFqα7(ff`)!%ơ7#zG=)J,)0<ړ{V $.6<*i_~#WaJ茡KUkrrBHos`I"N/YG.K4n tr\3X)&:#)A,V%&p0 -;Z8Gn3Ve!,RXtnH1:ڐA d?M34|g۾o|'40ys9v&3Z )FҼ`ByM%Pj9AmD.뷞?%R\ }x卫K\9q!V,w2ND9%r>;8XУhQc|8#2*(E#)*=O)+IN&j ˙$ca+!Y#uֳ )JMu=$)ڼN Y[qY9TM,Flh|~IP!ҳf}r<%k\_pGb\[%VX RJ#Dux/+BUJND;ǟ?k랳Z3GH? _Y21$:߱3ZWZU# jԘ/;>xC..GR,N'l?@qpbK^}:tް fb.#*2+;T a JoȹAKRt+U%R23}ON,pwN/&N)2 zIsdP[&ՀM8{CQB.b#'QX8&qw` -j#^.s"&iy19-5 |12(I I;Q+)`n%V@Joq،qW77X'/lF(f0轓KwL~x,a鼣d RCHNV*'y\\xYa<ps_Mr9%FZ\"7-s.'q,)f6Kb *n@xDu9qJmzOrEׅ.HF 4hYbX`&_ɢJ--q 5Q"URbhҨ*8ʼn17/in.fz6vp-~0K..;)9"^,ZtiEiR+å)5MldE(7PyݟcrWփO=%GQ !)`as\XJ&0V'4f5a˜+39G3/3ShCbOmܸ9Mgʉqdt+RRusy1mEk5cZ82"Ujn;~WLe4ZBC-i&$?eR!r{ȉ(7ܒ2B.O.z}n|DF.3*jmTH%3a39NgoqgA/">a54?O| (*7K89$+H,L1ʵdJ&OEQ[e==yuIn^1¹4ԚytyGWlvK{a[KIs$4hU172,0f E̅єD|/!7REWDǔVeHyPR\gtO*k4'#Ho=9%୥wG_[}SQR*әȾvHJ ;BX؎+uɳw0rH3ΈQ%Ƅ"GWUWO'胏p,C齇v"94b!BbHnJL񇦮q.M3k#ֆ=ijq+Hqƴ6[[N42,R( Cnû3} !\g(I3 ir15+*O,$X+$irNZ$y$"ۑrU wUf3K7ut]O aFaEbEc,Re) ij} j䴎T!|dbV߇~|'H)rZSL\1r  }܄«i̋%ad3t% "mY:v˳K޼|e7PG2xɨ*OƎ_rU=%driv X0ܺ!$-F]I?S@Y4qϿL썵BrkiH)ÊVPJpi!&y&&Y]e|'vsm\\\S ֜$*^G eay'yk?oLOE :בXȴ&]?zz_o~׏12YR4߉}:@i%se^2K̜4GΩ`:w%8:culМ8E31zrbtIUe"+vpЬT*x/7Qn21%j\S"VP%L''73aCA $ k6MF+<(+ؓkr7rwC_,¿'0f*9F,Vl6;9Ox?Gq@ ЖR2gԪ>КvãXO7Y扖FV(Jak V7Y84sngN!R4հi[㆝eJpt8 l[A4Nq n}ǼDS &82fk*u%,*&k*$BZOL ԈV2)Tk$\0:uN*jJVW/: >awJ$fj)tf6JiM tc ("c aYV NVAO~&x"\TZ "أk1%ZxƁׅO};=zڊr#FNy8Α?O yaZcxp}5rs1c --qGDu:AAR 3 9f. !gjHgi,/¯ /?DSy9Ps"'<CPCu''l(=XקbL LaU$rM0u-)64ƲmDDիefV}tٰyeڠ7ӜM"if),qã:Ʈy:JӴDQ1K#K9zgtrlZ9N)(ER(x*ina:ZF+B_ZR TjΫ[PaƟS?Uk[ҳ u"Al[N#xb.}mE $\ Wh8o9cC06%OO8|>C+ HL*.2F (^Reh+Y{KPgb+k,$WeQ<ή#JN(Rr<R*Ŷ7qFl^J Iޗ\)R#Z"5:Iة!Zeh][{Ygkk\{-YNPZ| d|ӣ kN"Ϯ\ThUNMrm TIlN錵#a_ˁ$ U}Erw<ͼ%YFy*mG"cwiE4~P(|Ρ+t3h Q ymܜ"g 3%ȚJG#Ӫc# |f nIzPr++(-(cbW$uQƮ"p+E?P}oRj IDAT_o[vjEk+mt3R潉OtaT>yݔPXe:'w25)תDh歷/x PB[HJ(GQNȌ#VC31.FϠ`贠^B f 34)JY7˼dB(ω)?X"cW7blh^) XD rQHk gJYHO6tŖ₳Nx0Ͳ`Utsһa8(KOFsy UwSj,41Z%Ajq3R(ĝo7b[3O|cȏ04x5ؤ!6"yxOZtunLrkˈ\i;Q4A2@DAyu?R!.3VijIN7;ebt  1M7F/[lxL׏|"n3^0ưzKm_c'WoK{=6Bڬoz4Uȇ9 E5,K@YC4=n']kqFiFb7xP-j`^۝K4w*pBb,<7NLK"e!FMK i<陕l.w)<8 ܿqpΡhGUG֬XBYqU+ *KP HRKG]F1/Z "%9X/*JEBώV*s:ɸ^@D.I׶J!ՂLE$ܟ~îRJcuhMI쇖\:q|(EJ,SLKeh h'i.bz.X2Ve [9RX i{if?cU4rҔXC~=V2_;k!nҊVzSTj14_l(A,5Β{iHƵ9HQkI 5('D#q qem~`Vn#OYHNHhNk̂-SX]ә:1O\Kd]xpg]FiF}֘k؎/i-Z8 C2t?5$JeR`=:<voCĻ3N4Y[8BHMaA5gSk;.w鄲 (Vl1 KK)H0{o3[;Z_+ĩNRu"ZH/؀nrh 7M<lTD@ch B^k͆:qk0ZXZ iwK ߐqBCߊ9;˅8 1T;k̀9%@D85WbulnZ5w癶I$#-3zoHr}}K5Hրs[. S`jŷ=pJxLqJq qkjP5u"ڂ*o-c8bi\^|H9zg5i{1V@|뺲Y:MZ!Cư]b%81ӄJAjRLʣ7LnI}FagtI! ;f:eS LJ@q10D Ei^ >Q(rj75zS k;¢p3̔y./-kh%GZF<)Q ;JfRo C%G+9-5tmCU!ganM+Qҋs\m.s>I r\+v m_opYd1yaLׄ5a}Rjao ƮFTEUKٜtޫ ʬSؠuJ8c߅P4B5/Evte4Tb1QUV-iUt:q}\sus1OSUv爹FV~f,9bXׄ;tx+˧,b)zO˲%m6Nt{m 5JZj4%&Nnp:g*?B UQɄ)UaBO2㼈p]\ /qڶҺs|.Yt|NQ9T#1tZU#utĴRQ$-R[R1mmr1tCB\FF5 k [n[ZSh fgV4Vn6hK$2,@ȊT u)JZ;t2c}У+ށs.D-+D֜g4V'BK _|?_\/i*M\E:E!sXRW0,rN[&9TVϼLR}R:Z甶!2:NS%,{OnնR )l#q6SIhHitm5IzC*;5U4)dT1 j ȣXr YBd=_z)SE=Wr֒)PТ^uJmyNy4 L$֒#ysb}/cbˀ޲4=.ikЮAYK`M5]x.i5bLMeIA5Bg-1o6FV-IDAT谾btE E܅<BRx%fYqYl{RE(a-P @5@5+Ӽ^PUZlJA(gly!mS2x$%H-ry6д2x7poC/ .w;- :R#*q?x DvCP8tjP$⺐L*LZG^s3Pp3-Gpi¤JԊw&'nN#^j} X4m1EE38#EQk,#UYRTmi:m:Pkz;kEqhд{|1*EW)E̚wqYJNw3]JxS^s7Vη=2tt}Qgw|0<:ytj]jbp{XUb@XM z. ~M!R5k*]x&K"X&1s<9SK[xpaXBk-*Ț‚ ZGYݫe{₢R^Lێu<9goF:ҋ-9*R8Q˦kQh/ԆCS+rD"z4ڊ1-Uyb,UBߊ1)CkD$%h9 !IQ@U,+K _x}~wxx iy_+uo~' UAN 7B.4l 9UCeF)M/>ot8KRV $p5ZSWɷsФ5o2Z 4ElA\Vŧ[O[oz^/}g9GLXD2GK]$wi&DV᭦S5EsSVBJќ#}Emjؠ˂ATQ[4޲aYJNgKURx/ɰ̼ȧ~_oT?|W^IBo)|`ivˎ;nooЪ }K΁"YGa(XqړRerGiȄ\L/JI8[B<]tt]!OOFWUQ}WSlc~@Bb27Ҥ8ib9 JXeG\y|zUD`Z`%Py<~z"]cU7sMXLMH}ku/d~?7\y-|pe#o>Z/nb#e5(K@c`aI`.q,!?3 )еtEg 7|kcW^ٝ ~wq=|4'\1QB8|ujf]Wҵ-JWvBIY7~<_?GˬWKh?_"@Jf5j#H hD4s!t Bk )*RPU;^})~ˑ17kȥbf_Y5CLmLH=1rQqC(*hV=n].E{(S)hA38a h"h534(!$JmF RiW^{nğѷˑQ_$%׆;+`]JAb@ VU4>!b ֈ!P?N"c..GGWDJ֌!D qǑ뙗=v9=؛~PZV !FSѬ;C cݲ*Dmb E'lGRAY XC"AMhMŎqhxa LLʰ䩲 F;7~JEd?_Nkmn 1Dȹ j1.QJagwX7 JPo͆q0*BVItQ Р " Ӕ麞1h.D!0WΎyQFGRwz )~ʵ÷] !*BZl6LӖGD y7 !DɅY oERhdn!.ThՇ#4 B DH  fȭ藽#m杵 ?[_1v9ï!Zcͭ-*ET،bF F@Ւ`^b"" h:ѻUR%Lf3;kTLCȭ50RDpX@W< O OMk)(!TFJɅ( ޻Um"h;(!04/j4kY[*~O9F!$*4 J#@㰐KT󈝢"Y =Q_'^i%fU;j b:Q%PUn&'OMW<6ƈ(a0AX.w9SwD"3HjkD 6O_qˉcV>b ,w~r`soòO?Z!@4LssW 7i!L؞j0,ކ R+]!B@4b?H?,)c"^<5bTj+腚bURbRXoG4 4QM</{s.$&ҾGE{t#1()ԄE-aV(Rt"up3]("!j D-np4 :y8?6zFU J4ĎVaR$u,KTՈZmX,z#:1yI'8Xo/-S+y5n]UeRsM&X6d5&vz=U{p|BDfGK RӖ:3bI.DHLRh C$猩sa, FiX`)]BSs!A=?.y)i뿍2PZ3R+8N{2OQڱ%ecIO`'p5r`5nIqA̍3huD6z6JAgFJ5X.fBS9vljbsvzڲ[躀К"9 .>n4q$:sf9W.\w+e" #B*;{ J 4$;KZEAv'_)iRQ=olΜ'»>B;}}3Bu6V( m)P X%79bY.磌7M'N >)P͜D XmsTb1qU@#SXm@pg?g<%]Jlkb I41t[n8[k }Ki:!ЊN ] T#=iqJL!D{2|.\ Z^ñ_ムwZæY3GXݤ3 "R8,@k\Vlzd@3k(!lEGݡH"Hfm/DiBGo2JJ1v!`]7reb56aIq@@ v;ꓸ2 srSᎻX߶eoQ;6o3t'^G`DҨW4 Lf!jF8z5A z -I LO8Ƶ_SOjt~ۮ1 iDUy膞'05 `jec;yNMI>?DU]`;MĘM)⃓.qq֟D,OHs{ }g>[ݧi~7tR EQ: sv5Lw`sXm37[* =;7!FL$BR2C)0Tb`;9" "hyԬ2m[2IE 212n՚&u"ĢKX0?һ?}&z}D_xkB$R4R6?(} t@BxQ ajcc$ӄ;Tw!#:F@(*UFqIO$`BÔ L 4m#*{{KJR"b1r..)bh66-gp;ICOyӹ˞NuLH \Vxh{#h[ۗU"뾞.uL, l۩oy7D(B?QnjBGU.泘G'!xB#9W4D`jȭ2Z*&DLU[DRO<&?z'gq}8wĩkd"F Z]Ry~ {8=Nf^/|(bwSWh3y{>8,dD9|D;({\9/kyk+]SnoE12OB2p̷ h-[ABQjx~k2Ca2Ea1RU6S@Y"WDKBP}/1|mϯ͚3q 3F.^(js' %1FEf!ń6f;حo9M~|,Er`3rvƏ?~aڢ>䢎aHsYĻ^Cf^v# Us39*`&X#\ZPL4Ʃ`M9q$ӔU+R*y%oxݫiuUE#'K"6VIoTM6{-;T##?S M8 "L͸7Ĩ%([kGXud\xpM7su/x%D+ăoxYsvɵ#x6kHex0fK!p$۱`T6]rwoW9o+co\{*Q 4B-rz~QUy3a/áX͎a=Eٹƾ6>7Q(T*%5@xsF_BQƇ?| |=/x?t mu#[s⸿o]rpF<p %L-ZެY=͖RG8ʢK^ΛM1q_0tV)}!R?B#t=nXvX4a# Vڜ 5liE?,PcIk1q(7gHkc9 59Ea)H/@"yəRL-oCNy|EGiC6!DLf/RE@SE }wfd/CHi' Z!,*sk:+hʻr[TƎ(o0! (ڄP9~{&+&^ϓ7Q[*L&s5gG jL^|9gRD+Jۑ'N^o@S%zKK^~h_5}^E-6/1VGRb+=V'Z5j}Fo}CⰞ" 9_5o(zޑ-p$*JH#=#9U5j,^tۂGX E54EkqE1*g 8cm:s8,yz+@U BcTv`5hD6o "Kᅖy556~5Nl'4IvMS<yf(d Y.cDMX7S)SYcpZ 3DΝGiJnmXF*xv4@45L_g&vD9J=.68thP &{]{CϾ(d@1ĕ ֊oY|O(4Q4hicuyy3Z x4N7x0xLQ3I̸^qUR]4 Ӗa'a5`RuvF!y3 V3eRRדgѽo[_p$4t"}/oy;>q{io2}jp >-)Mc1tZ K,<ul{8BzMg=-  rw>5uu7?J9ZC[ ef% e@# Ϫ/nnh}QAĸ5 uuyFr4ZTKcbT3!5ȇ 3Wf$|'Ҭ҅\H+շWMhyKa :V`Th]ĦLS"\fa]^ؔʻğ@͋^`[k{"G $NX:qS[%JkZ`8hJa=!plm)T Զ&CT\c>caira,J/~hR'\;vĜ1K.:,LUHo'Ncdup:^?ozhi4KN+0STڠRd%'v9}1N#Q#Rvv|tUǠL_-T8q.FqBLX]kS9I1 bJ`QqX6|g6CB4C8I$O>s:(˙ps3nޓz*.Z&gÆ{'NJϐL|f񫟢kRX~/\8{3ȵ(" Abfr#٣!<`p*Rlxx-C&.@(W1íqprO;kEUmYhjO TI 3  x]!'^_ n/vgaG1hWL pjs`:`; Cz"hK)fYN?GASZ(o0T~zv5 'Og?]@ h(T:>)S軎CΖnRf^FHQ_ab0egn]FH^ĭSMgDa6Q9?/MQPGNZa1 ǏCc@ys{c$7x g,wv|b$HС*A;Ǫ!yut4X$kέț-ͯՙ^+irt(fhF)2U/r%&%~%w.?M"D56-8e_R?zc5'ƻ{Wp iiZ"Wq{g׋T* t]y(ďZv\3H2 )֔`9pwI% LnJ|LDi%!+\.xQ^Y[ 3 h08&NIヱ|~ \{ZF8'Pv܂r:[m\|^Kqʈ$(B ;0,D;ز+^u/W/Rx4(m ZY5LDiNVڱzZk< }ꨥ,/fXs LX X{GZcY1zn5)Eͫ`uI* êw:SK8alǛRobT W'i+*O?'d^캥3XI7U$rM(w[ܱyzOcX GK[m<_/Ԙ/WqiyAۑDKe70;!< ^79gB L 1DJ\th2+F䌪%dX.^_#֋fir101#" J5%Kx!hf<'gly  C]Eܖ`+yo)rDVL1:pb̽sϙ N.9Xpbs@ rѳ"$.^+DZ 잺ןb >rzM m:-!*KfRrl)9'ƙtاWT)y1 f=[â#Oj O޾tau!Yu7ӧ{q1BJ([#)vMUr)U~\!OI!v|rޱ"qa4 ʕъSYo˺x7v-Dt^*+ANv]5ea䝋v{L Zzk 4%4Dc GgAYi|c$c?L*~SUs4s||J2xu1Ƞm1(RuqlI9B I)EVEiŝiEvm.'Ho oJ\lvGmhc d'o^vÞV]}afI 6[X_[q3Tɼh~9as[Pa a $۴`1IXJN4MC\MJVz\Giyvi -M#½`: &gE{,)q((%T//sMUxN`;,s=# mOYks]i.|4fT3KLap T& EX;zxMy??<7≱x|д NBefY&i` #40!r50}H`tS{l5K"w,f5lC,'7aHyf3#8b j4 !k1Eibt]9[_-afG|'nxI"R3ͦC7XMkhZk齓͝Wy0l3/}.X23]p^Ei"MIxf1kZuq0ְod.ϘbFf^"Z'EfjKr}Rhhە]J(?\ Dd I VXi'.qFiclw߻^g?\ V[B0ieo4W8wX]+cd2ڐsĢs{w7ĐH9R"F?*>z%'7+^q~o2b E t?ƑyXQN9bx;C3!Fi݂ȇ RH.cuxCc-$Zw=!g)\b@7.Fac-Ig,X 歷[{%! 1%eY}>=]ӂʩwN+>rFV. Āry(%g?'pSVGL{)9S=pa ŵdRu, Jioq"\S~˯s1. Qr4qdSp hZxh07ܒ8u!2[.;9%b,a~ ^$6zwо$I 3TIE$GKʒ2dP,nKLSdL#^;>%E2K\Xp,yK), qq&דXCk jáe)Yo[b\BiK_+O^ ;O *W/P[w]FѰqZNK򆑴yҥX+:5鹊fīMs iQЩ±k]9:>!&O.p₳{mk<\E0K(ț5TT3*Z@ mbuM#/G6eYg7%RٜX)ST{*k4#׸q&!eη.Ƒ7g;N1,90#p :raWm mɴ!@=2,r3iڦ6BvZPL12 Ez}pag1֚wLZ%cd6hsar%Xj;b] O\B.B Z^0yd_UH)c@+y❳-osF鏩p?QB ]$ rV5M)#}m)rB;\1 #a)bl-ֹd~u2g5 xE_"ߧ 8Bqj [ ̛m#Yݾ[7Mp>laiږR28r70bA$kb(961Eb F%c^3^k4]|g]͕g6)2OAŜ g\q_?3rYvR{%J/+a9drt홵rL$ZoJŸK)")lmd`&NX=ӭgϧ~J{U3_*X‚1تSRo(;(U i)% *$+ӏa6bJ|׼8w899&LH9vn9,VcJ@ N+< 5B<9w]r&DgDVcX$1&qj٧>饗ͅWjM4xgYӵGiYpL2pF+TlljN\S5O|{Ӹa[9EA&N6B^"9$J 1JVPPUrSV0BA,4r ̋41Uf2zikNZijbB,t۪JO`J`E ֛3.Qf +sLX4OJRD"6 1J(*c$!YVS~/鄐O+OK^΄%2 _yh~ǟxGmD'd"!h|4ɇ἗"Z3_HGCZ*(|3oKv)l1"_@JCH8ZXq3[`4k3aMWdjVQ)lU+J K *-Ӻ<JTWn"r!F aa?MbV.6q9c3#$~lCMYI4J 3$!`a %%VL(%~'?Z--@ϐj6F" V4ޣuA;C;)װo|v0!b* :eXKԚB2V\*۬Т9>jjB\*-F)µGqsbs掃NV;v|eJk&8æ+$H]uv.Kfw\ߓ ?$o8{uƘX[(PBmx /3߽YQ "NÑRHҠzcr-)IQٴU+#BDM8R71LDV:G6X VfH".*@)E4XWwk\TT=i wqӘE81EBsŖɈS+SO=NtS }Ց}0\95M%'$DK.V1+`Tm()eB!,49pȒoS>>W+@`ڑL˒85,4Eq39w$:qXrF g^63mc_2cT.H`U*~rzG-o&:'L&g~[AiՒr"L\Z(W|-*˅ƛ dRBpNI (AuX_b,IHGY`B*Ԭ" i\)(j|T1c`y.7o=T[$)ҹBۮXjN1%SrB%s/ #dogEqڕ!}0JH9EuƀcoqNj[uP9'L5]kZɜqpRIXACtz*DJz' !.ĜBb;O ̲$byUG)0D\>ܓ\Q6 z~&]߲$ 9eiT%&@h*؀Km1( "(BCt)\Yk煸8p{?i]/ҏ9qwzv3>oO\8CN%5Qդ HSmR8˜0Ӷ-GL Unk齭9q8'+d.*WZVhM:h!JBUZ->k)=qBK c0 12nZ8Fei꥙'Omu(m^71yX-49BX(Jxkǫ&RVC@qs˂3]xK]Ȕ2WحB0.}?Q}bFS{0U# {G/|ᅯs`Z Q epFLb$"Jǘ扜3sL!oxkb@`߱w>Cnxy_"Pja 6ܱ#IA5R+\kfG ]cXE 0΢ 4 TKB65r3ۮ%,'8l+()L<&{2 #cׇQdRxX1@(E@%2)q9g*.j襩 U<;@'iBTE6ÎŹJJJ,KkZScRm qYbb߳?XBbwu-_ԟEkKn A\c*E/QH% "(ٱ4[q%kZS!uhOn{}õn-mhqdIXoPjBz(j9Eռ2F(Ɗ3tuJ)`Y&! =hL a~8p1LQѬ:e[úێ7 ֻ+?ضmha (<"g\5G''z2QP1yAE@LfڅV;V-u-x+14s`^vGݖ%"=y^y|7;^H~B:?q|EBʘ +X*Զ qGSVEkZ6G\QS:Cos[lNoНn^Ӹ N8Fpvy͉o㏎8q Wr%dt)" Jbm]&\]9{Dƒa.{ -`tcմxc9\}q MYh7=wJڂQHe>pz|~Պp{nb1cH8kgeI$8TN )EafY%@\`=x;&M%Rʂu i#7}c>4.x\{Y0AxQt}͊iIjCڳ=Mo--GqcbeDٲ22HWH1Kg!zdJz)u(xb^Xfw(2sC߭Y7-82< {VrwGsX iPay@1⃴%so5<o/bk`;f"+o`bb*˕"VG]9 ;$Wr $8y!Ü22UiGNoBfw~XhUO+u,L Akǐ%-#:yIΡRdNNh8[w# 914xWɥpv~A HsƷ\sX R39;JX0Pkd]^Bw b(NmQ }7#8WwT%C_wSz8DvXm|_| GG8۰Dm>X| x+ʾV (v<|.;go"b jŰŁaZcub:5ⵐ 13BPqʉS"$d%y;k+(!2N)Zgh[r1d51-nȩBdZfrL9:ieuzoЯ,R,b,H'qi,8ݬʲ&sDY.k+ ]b 2 23d˜ b<Ĝΰ]جW֨9~bk;NN7 zK U*QDaaD;D̐cÜMkp`߯{XCbw+~iƅvqh LS|mR uS ވqS8Ʊ?(`R57\b785$I -^Opr׾WB1PW )5 q' bs|,JuiYxgy_fӷ:HVQO ;=F暴Gn#7_{G, xV]SxC#Tw}%K[UJ \#ˍ!T|w`?N,J d֫ׯca:Injɵږ(֠¨LJqqxpq`)fvȴRQi:T"k dnN \[G̚ ƶ:Ǫ]jBGӭ7-z64 S87㌂QJ,]U+Os_wyk=g}%dEBݸΗ_zݻ4բ۟DW=aI(o})%FbJҳjmV+4vK\om(G .m,N`qRIZVJ8O߲8kQVU%LjKbv?gBhi6}11mGH3ܺqn=]>i_oI:#+b 1X'z}j"mtPx6/}\_clKNe0Fs؏tG{l_JT5zqe5!%90ΑaOX6l0zGӵa!ȸa q(n?If hDaeḳ oމ\k#̪ki:eϚ@ʡR8"].+( "hT2OBYW؅o*I^ZR1Xp"ZE᳟?]ʛ7k%: 0ѯzarƉdô*x`_3Ts4Av6ѵ|o^ O?ÍwHEɒVĔ5π%Tl1r1VeT)(Pʈ5h4Eg(!1##¢ Yibأe90HIVnnZn_?s #hO)m0N#Vެq8/B F-`gt--jZ 1CX`A;o-͚ (MCӝ݁38b;/~<83u_>/ωd:O+q.7Uۊvdڮ\2!.?љv'!DuU xU9-iYo_{okYv}k{[CwsjE/1A1 Ab?$qDaKV#I,KQYj%N@Ldd)R[fwWWWݺ<]e!,2"K[Uk}oxIIԿg7?9_˧syYF$[8(]wQJW.̥id5XH.)DH"#0MQa0f?%&?Ve. 7 6k|r t!HYL3kjk:ͱB)iU= Fh=gj]$Hɉ["dnPZu$㘘]S( ZJqlϢd9Y:-Ok+GRiЦRk XkB {ј[—cwUTCZ)eFjKfO~Qn,K3pFvMj{msǫ>5QɃVKdi.N׽2!dB,dzĔ!FT(c[vKT \]5\YhQt%SHf9= VޛW>%(LcDh7kV]$%* tFm(RO\nch)ĕ᭿^k+"g^s)׮]Ν=6a3 Wy}`.#9'ӯ~)o44}*Xi*9B ^3NJ)Dq򜗞KiYJWF 2Se1Lbhc7 ۞hJC7SU{ >ea`1P@F)F_M~M@? 3߬hI`DpFB+e5% 1dr5c@Q]S^4 joRsrqB6#ٚoϽ#ڴ,?Ƈ?gJ?w_?L퓅0дӼX,) ptz^)P( 7~9Se$%!TcߓgV5[5RSqoNN=KR9bdFGK~M#0Ը"È՝Cu#$C_#V-Rc{Rfw 3XKYtm, $jҌ>c\K%@ͺX J -+WIs% rk C[HkRNI)),Y9`5)"% L,{mj \iyKes6 R32ߓaF7>̒9g5'^OZrzzC-* ,]:,ږ]|bb?8qݑ`L>$ 1qC{\]~zsiqjE=⟾8:Y9 8_4u{pwǮ?^nLim؝_9^acjMЭ;UM]YMfbYaDudQ7)5(!qu rqɺc4Qc/0Jf\jUi * HJ.'%/{_Đ8^8֭ah?Ysehr6][B@.}CH([ t=90VWdе9 +7KƐ9*YF (51H"1ĦyBR}O뗾<OW'*oVFM3S-Ĕj{;ΑB"tOlO6WcI2 i)i k4s$Re.wi%6ǎV-d 5SwFמV$֊dXv5VsmʪcpZmX- mۡuZQRB\JVc\[ %Eଢu&0JB(u -H,($7n4g)|=sߎciچ+kabr]_sц˳ ^a{E*MLWސ#+ g4+PVLÀz19'XFDqe$.oݢuFA |JIbUu1L@X9 ,yh@RJZ*hYFb]òmigL©GSFVcms6&zpBs-HUHtͩg@֣\;?TLfnrzbǃY@=(E2kYlv(W_qB*A!b S,_|Gu&@ʅEX(j"</ܸ2_8dx[ HQQJULS`DE [BR9mtaŌȰ }p`޳X-J$psu#iCy=kf4TE}|/|şf{pwf8X>R׳i$۳X.H) ;LWN˓4#4Іf4Շ5[[bLHhێP˂U\}3SrjR\F J3bױ;чFR %ggX]jX6-'+U\"TC=sNQr:R(qF#żO57wmPH:-qNΚØ0R C$9V|uk٣؍4W XO#f$V%[y_WnuT⡏բq?RUR&Y2e0pxo HG*"JIiuk4Cj9Z%7\{Pg&~C]Y/H /yZq"U JYMZ̪2B(9ʔln J֯zT8̭1p C$Uu\y&hq] g$]"Bh\b'O} R@eR -a'K͉!CQJ ˌvkoٝu ­YU〚%tZ R6;-^2+;A+3IvcO<º no+lT=9E")lvF4R*Γ@.g$r֝aZatBB6<]t)1!g=>y .ּݿwFWv8iU%M"Zkau1KAH"/nأRs9CXZZTu)z"qCmڶRnjhJsK&kkcy&~1E(م,$fS%5 'hRqB1od$ ES$j@#Ez%b?z+>n~1j̰],k#Ƅkiڲhr=f>cLbLaU|n?‹/1٦$Ss KUdp(Gwk7ZHa~{m>#mK? (%R-**^0Ԛ J,gyz/yWZi,Mc %yg1DqV %jITĢJ٤ Jf(FV{ W8=n?Ҵ-hYBΡå@{n55AH &aD0UTEcI8Ev٭yk`K@I8h%9&\ӰPՍ+"LN#%"%TѪ1 ~g~wv 772J?o4cz]*ƈq(s1@Lq8 c**URa#8!r*hiRSJ=v#RGŢQ8[`+3s㜢u=#Ii)Ѷ5 ڴ($+a3*rIȜhF Y?]?W~%i82b}dgxn':IDAT+~_y(VZi)BZTߏL4nG!R 6 =k! ϡ)E`#A<(Td:WsۃHR]4c9VI\2 .ШDR]zF8A*Aʚ~[DQ{6M!Hj<J#RTlPɧ?5~S?=H))0 9C656'1 GB.py9@Tvl,J0D21f` F?ᧄ,3J u@&uK< J„m7MR sdY%eFhz2!2xrJm v5Ę >кS"YiȒ))KbGڲtiHz#"1'}I|hYuː%t4 idcky?~o,K8B0==ЏrF,~p|Ė $γCqN8ތI)jQP)sϣB))G`*(9LLS ax)qb5QXY(r zUD'OS!ekjm*.VE]J~I"$ 1@|k~?,u?PnNb 4c qBK)W4W6sq8Y:ilC;6+i3}2 t#(%S0D+#yg68q;ga3ZZѩPHL8C\\;ǡ%QlaC=;o2*+[uݢj1MІ0ոOd($F|, 5{FdqW|חK#l̊|B" zӢd!#Jk$5ˣ I(qdIa 0R떳 !=)%i4%gwC|ޝ~w?6ffi͹}Ę]TSxT*$n8]0P!e4 Jd-0n0QJ{Փ9-EAC?HYU䧿o}>/|My`F]}!jg1 0AJX2iB²,]kU+Z2o|lU5OB"Z"Ah]걦2hde l'ú͘z_,W0C;?} $* 3C'J)4݊"-COA% V@—qR#H(c͒=e$LM[Lmu *RZ"D*1Q/qsů??C ֿ)3T#0yV a@+lTv$`8%  g7t^x~<ۃ3NsNn*ܮ(J()GKf䌒 K؍5!=nzTDYt8 e@-il'8v²/wx?}?j'_j;fi("}]9R@QFITVE"HhQwx#qBkЪ Y~,kb?\ !c߯yVZi.SB)"4I{=*#5DMHU4 M w.ׯtvDڬ]Y/ >Uy$4x湛<'h#}Dv-YB T/^r EU_[Fb⚣`!i5 HHT٪.wSPy$WZj#b0rg%5kA>㪽{Hư4 1]X,1gBL+Ȣ(*5;Quqzm+͜GWЈzMVth@jsܶ`oX+%˝ 5BFT[~nxWWdGr{pw`Y<#hIa(V1Nh G-)y. IkzG.w#V9X?[ng>×ŧ>O^i.MY(R|V`)1UPHѬk-%VUf0\}y?d%c7\~=Pڠ ZXl5n޾0wka(&G2}_i~9^L~Pe沗L㎦),V-a/i5-::'",%[E*_ǿ9Ͼp~^uxh=tF&Qpζ*{Z]P  ;?'~Я+;']F@Pv2[?`d J"ZWDYi~,Ui:|h8dxmN֖6"xT,zؾ|U_\^?bZs~j7vܾGu GYϿ/~ ͫj{Z \ǍC51:1Z~Ce׊ܼVZC丣g 'V1vw~ٳ9w0_KI5C@1"m !rrk'.jW)8f%!*m`Gg5_~яz_nD~ǿՀ )EBL`B) 3!•~ Q>7~2ѵ Md}mA) 4(D3B*o{l.9]7<)WhD'O+!JT#8B@>Χ:wsnD֏C1PRJk""0<2faZbj|19y]snD?Vb$L "(R1M  oѤH5(r./&c.=WFQ'#KE#4@\ G+X1J=ʧ* V#Ռ7 /n_ލbfB#5E !RkҶ !(C?qEfJ }x[7 /nD/>w4b@CB5wjkAD1 #r i9gDm[x[^ͱtuz݈LGW]90PRG꜉AiD\BH͈ @)_N?NQ(FQǰ_w#"9BlBtg29O !bTLR !(15*y2 Ar=0qn{s wڍ~'i1%EE \ȵbO!f hvW >HJb{j΍Bi7">coMS'%BArP& TR(0#2SP<5T&7rl7">{rp1T*y )\AK8ݹk5JJ#b]Ѷ ` ĶKՙ0ewzvڍڦ%B MJr5ρ"#9+"8Ѷv,ZAMېbjd2:r"m QoyW7-v#B~]*TMTG%ċ=G3E.`H!SHs'y3׃,՜X[S is(e";uq)>/\[$k.ʼH!h`#*0ȕj 8M4MBC  1R%b:*p^LI,+Bl!R@$c/ti2Q ?~)&&yq7GZ H qƑL`̅Z+kGä89牶k *ZACKJHQK!")u +]Gl"J`1E2/5BnDh>cV@'cFJv4MbZܹN**T,soGB6KqN9bщ( ИR~I)Xёq'#6 EjR|ug#~䭘9/CE)Ҥg|bQڮc*dJ.iiͿ/Gm0Ҷ1&i@TI!lPJui.ݏ:чqbM(8U6֩V1qhڮ~#v?#߆yolµܸT4(!ȹ"hPbiKZJLJ-1$TiDL1LƉaUԀAS" DL]Mt8/] +5P)e¬2 &-hb܍Ai"0PkAU躖"!+3DYui$(<ږbTOQ)4-fr8ƶ] *BOr)cR̞sk;Rr\5F!CD r1TsۖRJGs)Q#q4R@?qB@"!J'\ݝ]7sHPORmKVm[ x۟K\gg&D۝63TSaTG(0 #1FB/5*H$H0T3L4D. Q]5z<ǔ9qЀ iMh0'TKJ#@1(cAfD01S@lll!PrEI9{^"ƒ*BaIMCr.mC_z P|F_&1T⼊RyrD58F*FMa.'J)i ǔb欻T99ɋq*@ iY uB>G)jJ tox2qGC`bmjdX,}=ɏ$4=/#~Xm\%TшH*T&sUiD1M-8Nci=}3LhARUiZ4Nyāj$ 4Brp r~}V@PXfc{vBJ`b4-16OJ-'iL9s&{9/}=G*Htg&{T+y̘ C(1Bs^]` mOϣ lmÔ7[L{@R&EbDۄU;%'X">e^A^N%(g'رcS&ț~k,ϯC.RKHP֥aCYVe LKd5ш6!$LР!RJz4 J@0Իv3Tgb4 (hB AD􅫟 7ۻnЛjFB\43|\7pyq* ФȘ'Bݜ9u%=qz~lO=oXZqRƉcGsгWȗqw+ʒ.:sj!uE[LY[TL)O4yЅ^__D=&$h:mCKįWəٙjJkKx^ͷED$$pdbMry^ R\}~ ?#f¸lg瑫esL %=rs{(Ķz!iHElQrc);zN_@҄TeK/o;N\41BYܶж5&5 j)z&(C?m$a7{w㣎<9?hEӱCCa3*8;kSfm@% E X_c1OŔr.H&w׾uMysʡ?]byÚ0皇( (H_e 8*"@B6l9ۜ;gV.61TB @B-l>'EitQ 9Hs!9*A{8Oqa˘+)5HTGiݑaEq#>py3q?~LD=ʧ`W5OXq9C00Z/U9l*zd5@k0;Asx4gΞ}{]jQ1=;9yb^r+/;C^ ?d3eB8oFosOuȓ,T_gՈQIUel 8+8Ѳ][aPY#&!,S*`< o:|{'U{nL?'"++a!we=8J wl`Π w~-/x â<*&J sy|  \zCvJ!YIRg$G zS1[y՛HΤER~:X:SL{хq c{ ifM۲3~sgY/dRWw{D>~m !:LfgC`ݸ 8'~vcf%T_0 (0-?zΟJؔ9S sf/5g>B6D:Vn} K{O7;V*a(l 'VDGpcss6N۠_Zyw|;o:ŅKO˷gu?>U*B_R}}40/$⹦Q/UWGHbl7 42;}%'g;jDeTQPG^ mP 7[9.ٜ75"˵;7VJ rͯWksegayٳ.[?]`Q?y,g?r 3vD+ ӣvjuvC#P^B7k5*T=թ $v7[V9WK&4 0)=KI}Oony+yV2Մ&oroDTK_bTjem䉶)K L+C?{ŵIpnUקћ-@gE֜3=~xGajO$];]C{8f㱷C\q} LCPOa*ę%$@U"멼ی8k F(@VCOO/S)p"(77mgۤ U.ZUߧi.b$i4#0S MLL8N\Dަi\/&qp³xVD"Jɏܽcj@gB1Gi ŒGJbO;TGvXe?~73>P0I<25 3i"bRaN .Xa84ZxTOr΄U n,~ :&1v o`kchUmbs'OPq;iB$EeD|"\5L͙iy_8MOs|v#/΋,}Q% 㟃sHGQʝ#N@@9"0n`G |*E>$~/,,ě.fEl0*jxxdށq < eocӝ`RePzdeC#_"s{8|Q;J^W7y-*}t+&T6H1v4bA~c0Ţ}S]o} {םq]W~\:>59g?J}1ty5 D3H$x8d!07 : IjZ "jr5IyW5wzP3,eʙonpՌDb oCP*b, BQBj0QM1o BVjriu$6NX-W'[U2c&Pzg*lnnͧRGsiPI" IDATa EuI)Zpuw3ؾlz "Zxi޵מDZ+;`j0Ga82Lfvl' #3!9S,FcP Kh4|h[WxU IagmͷފulCC1EMTq8ԂGj) *lv5LC&6RM5J u(/AcT*1A-8looF/њΫ9m,X,vfkga: D^PK”'tơc"2U{l>:~;i!UI BZq)aC(,83KX{Xa-VVc)q[9s&֣kwT48zR0Hdzi D+$*u*[!||{ƉS8B2tBkJHic}A-)gq2cTi;<*λ5Gf,U%u-a.s?=Sv\b-GͲPuւ3o*)53ЋPixRqD GS?M USN~n2\2$ˬ ]?oQs{L MR* ܏qewpI%DsOˡưZ1e>'7:N޴t{N dƛg8~ iL{_,OllM\̎Ӵ1TГDh)|`J΅3V 0Tl|M͔{5Q=o:~~[n:;3?Q+R%)aUX}^&G\ˁA&"F0zYjc7D*eNO)u/yrS~L=Ra=V&|:gNRn}m,_W!g4m㪥8:{̺T^t)N[gG1raSa/{Jwд(R1y#j%5k >푺O X[b;fƑEס79;{Zof>{#mϘCjӡ62tMK%XQ.y|T6JKя1,(Z~-vK((S"ҋTz "N+R32r mP:Qz>Y zK6C4 e&>cw⠐zh+\V}|TӦT#OeN)S !44)q_Bi*BAƉPa{RB2yFaPR<6*G@3S?#|7P}^GNC ?E@<\rm4l0N\cO!$ )ȫ*r-R4fL&IeWqU&3k!z8dSԠL)%L{FQX6: p5_m:}+y ;lnmRbYqa^1FaCёUK| ê6 3 2aYC5yC!:b|~5cdzt?vQ1BTVtԅd,x8|89:17OkIšR3{S"&wk#Y{˦4(Di/Ze8u/3/:HpQoxH0Ó+mx~JvhןZh \W~]|ݻI%\'G%ږF$r쓊SD'S>1&E4 8l{:s;42 DfRP]K8l\~warbïM&qgdV'Yq8Ƣ JzXo駞C1{l44Ц^Z T ~4y.pzҼ%OhȔRjvّ.bmoq|]i9Nr$ (ʋϜ~^;x|rЏjFjr 4zmCF@B'_:]؞sCLyx,MkpHx,$A2L2~̭z;J="7r,=oX1cRLjS֛D@ |;D :ds}5mֵ.BJ *]Dg/FV7} r(+LʣMCLwW#HyWXR  )5U՛,brG-rcT8a'rE#.1u gG)e>ADɄWۇaFjfy{ӛ5Bª7.B!"+=?v4n;qFhS`Kl.Zֻ@ńo1&ңNb~d8? gkss4Υ:V yh)>á9ui.*PNF(G%@6\)%3,WV]a'b4)\_QJS)܏Ð+c.R}%BJJ Eјe*#P# vH'T5wP}O!2wdqX*TTg@s„W扷,1ynVXNcOl׿MېB2Ͳ!&H FS]o^c-&~rbIzW-F*.RrZxPk%[nKsEx&-fi k)L8k>cU9</,KҥmwXH+voF1bt?Hj1HȘCTc ?|&sG=G}[6_|LT>n@l1j U&s (j4f :6ŌAf`)lGK_K_j6Ng7y(2Xz~SZ-,= D}.yp5|SLJk~J-3t /^ :–%kkkLyR%3'1 =49z^tܹ 2LyL)KoghjJ+s>':GϛC mK-k(e"OP: 4]GԙXgy  ZQ'OTθs*|&t|:,(1:_rT\qv䂒.+wWHX͂%ڻټ.'KҦAQ]-;tmƆMsK_-yo2CwmCla)ssS,,b:ͲVM|!4>s%4 {Wv_&~3 ?{RTS̐(/0}Ѱk4€0< Mڀۡrn5oy 'nջmU\B+v>gv_0!M<@h99< Bۺ((z|Q}r_aR-/y1 Dz2K:=ql6SnF:G;g."3MH}cD#3fC,Ի\ȨSGoB #s=A~m񒧟y[OZ}rαK FVW LyǜqQ4j (Kw%A*2~g}y4ɕ8 2N)%$MQ [4M*ykąnPNmU;kWZ:5\b%2RdGv=a xgq!S-ߑ|FkL\0(ّ1B^h(x6g]rSُ3mꂛ'~ f,uJ1h1 %~?Wx}먐q׊) 1*K)IT,jBQ:RΌLL@Hy&_z>(/߇rKVmdW],)0XL mH1e*F(V:&/7eU9$!8uG11Y.WϢ*"N _s%alDD.) $]kQG!Gi6~=ƫ{c;lEAt )ER ])1s8CnzK85]  {X׉Vk2$z9a82I;rìoZpU)?&WyTxjyh=s_]"@Qq+ h|Su%y [bLk:qs[pVKpM6;Dǜ%KH[9"]1-9t__9c|y\M-YP2>eāl<Z,iDɏ>o{8+BDfơg{bUީi{< d"OC"Pc=MeuB.EZ"'9R%+C?NhYR'tӌZzX034YW_jAX'|ΩZe~,WRc/2?iFpY2b)[oZ@smtP{Wc gUbPFg ;h |(xMG/~w%r#wÖv<)Pi[9]dÌ7a} Jw?s8U OމJ0bKHI+J ZkYYyI)bDtchI,E!䯔 $$ G x._ҙWGl.jʪGn/5I.ݻ`."EJ1Z71Z6rEB~9}egRV,Ĉ1F4A\ȅܻ ߹G3JlQUR݇ I%YEBmbνheJ.xsP m|~9$Yп;/z*dtPF,,@*!zr*V^;6G2 (\ TC&[ r)siLB6ʚ&ex+@Fsr~I+]8{S,6GrB+wwl6i:Dl9̠58NNNqՒR!%Q\~.dH'ka&"EnJņ+捂Z ̙bYe&CJV%~W>/~iz}=ɬvYv+vP#Lk1jhPŒJ>GpPN1!'5Cy#ah2^J1DmMVμ9+6lYk zƭrsov#mE>OX^R6SM-0S*\]ÙMIhcX`T q"ŰR6^ GdVa.S0,j4y^%y&9 MBMG*Ym{lf|v/e2 ޕbʖy 9r' M)ӭWDcsb\]ui0Ebƌ-^ՑK/~L_u)_xmvhe+_uܸd-Jh|CRZi<:9%)& TiR“R̵*<%k84gyn*圈%GL|RP ߐ(fI˪ki Ĉ ;K䞰,7DŽXs P,mPPlf>env}H /ՑFXzEւdX+V7NBAINZv"m${NiCA@ UJaJkN<[|s/1O ͐`=kNIJ*8V/XE=HZaL~0̈́ie8]Kc !lg[CO_SoVIaj(0rd#L1H[) y2)4Ɏ!dvH49+bݳP"\G=8Q/(3|YA\mJ!Lxq H?"3/9vn.MK6,W&4Cf;v!EC\J[OH)$B.(9ab[q~[akXD_2wW0h)4LSYtlf}4 Py˱KP0fM!΅yRXeh;Mxl06c]k6<9GV O3Ͻ ѹ,ޏ|Wdj%]#uWV-jKʳXv8/rFQrk,sm,kPFvgYQxPLLZ65XPQHHJ qq1Ԝf%2a i8?QzO\bfxNKnm.(Ѳ⅔IX&TI⌵fZVX?C]m,McoY,788 9FaƁbb0΢,5 1UNvXqY$L[!QA2,7kq2ǶCҙuމZ '"w}4眇3YŰ4+0VY ݴΊ&$w`4%MѶдg@N`ShV]FH(cbMi(dq L#-,E1'V,[frX2\\0tֱYuXg*2~L0D̅ JbVjYZe HRH8Y.I)T9m֠ *mdY'NN LTȱXt0#rМ"NQeɟw>y9|MZo=Ǐ(F^eou]|ub1&4C)Qqv+a fsr)0\S5!g֋ O=>wyeL6|:$ΝFYKRAB̅!FlQ]xZj$]۠ieZc0.. @vx~z:x%Xy0C28~5l˦1i?0owTtkVIaNLSb'1LNѪͣKѥmJZ.J%'|]u8Ns,(CZDC fE#XGHҪ`4>__c ?#$VtdJJkWȅ16na$vXՎE Y efbu$1Z[WҺ$%9>'U(cUMˆ/OSt3 Js5 F!+|EDI!96Aficl=Y i_*HHBU\K.gqD+ Rȡ(bmsy)9c`zT,㡣~vV݂[uC B8g=!q 觙RehxcE՚Latm+6$AZR9QZ c@7ihAb@=gb_[u>ڊo8 z{hc*!"B!gr$.aUwkYݲ/:O`l@!H [2=g9?è&^Hg JVC;RsbH4:shl%_3Z9tΉ.CۺC\*οNxYm6`_&Ɛk{...qǷ\YoY,N 90%ψ%qZ|%>t K,+t^p`j8vI(,Jɮ*"2倱-]djTIhXql/}5ߒ|xiYQ l Fײ 7n?9ӟ< Ⅲr*lط*uI q'r)R"pVq(*AHTVgЦ`~ܮ4Z[TŚY1*K)ĽK4^sqz¸=i99Y\tx븟'&1ΰjtB.˶?̍0K&UQkxhz hBm`0@k}+s)X墛" $zCVz.%w8yז)"R矿Kw5X߲~wA0ʶ"hGF@;+Y]SЅB*|';NKM~P9Tbx1)N"T@4u9\zx;X,tddlZOȢ'.Ea|%R2_ZSʾ-[}*@.݁ k),ndzɢ"OٺQmf¾kh)0kZMԚ3(8骲q?keJ5TeP4`4AiB)2̶8FpM4V[''mcHFU=Rs&1: ^k- ME3Na߳^y,ybW#~?Act׿?6˥cz, | 84G- Y,RwP" H ÐY%?nzͼ廾4ˆ$Qa L0=<(s*9M:{=Ohk瑅Y6 Uf_00z&5e 0t:%v_n/X0VrV;T-bg%Ch%1'R1FHQplXwKVv%"3:+55ň7EE\5֢FZP{?/]ͼ;럽%<=Oh%t2el ^zJQ,3D14pi5)7<֧xۿ'zjH.ɂ8 3c ZYQ:aNnݠ;>baw8!R咚_J8ءqmsk=!$ȅ8ҏ1eq"FmYt]-8)J\ !" z Es&j%m wZvg{stҫdAZŦ (ȊUe/+LF!T!H!.cOd+ w)t£Q>1qM\'ۊ̜a[?+UB\|ի"GTyMn;Yc1ni*TUkX#RHVgȜիP54LIc; bM Ei&bp.LŪ]`O$Brt$I"`5Nnz˨ 6֜לFgϼ4;,fuU&nVRv TH0 1@viL!f0EjR_}3<})K  3UŸZ@QE@v-ez!6 ϸ3"*Ǽ_ [[R <إhyWg?Ն$2b-qцv(OiZ{5|~՛,\?:7^z~ߗB`Ɓ;_Pྼ/haa;%82yOHa*'F 1sj"IpYлيfC;;-rCuhh/e+O ;Ò sn޸z})I y]c?~\?|qo3X=dw'~"FU D23בRZmg2(U_Zn3|v>thlі_"U˘KH!đ8ztR5 Ds! 1"L)>|_}Ƙ_ͿO|iz7ɲLK!hچ&pZWnFh [ל{|*p着Ĺi L'{OmHArF ںpaQs3;9uem#v)q帇nab VefMh /0:2}w|'µ[/=Zoed¹4ϱ>]3f-c8b`V m #j@JG/QhiYΘ/ t88~,_YVP&sLc:pzx 4MFkwX0fh#Z'za Ű{|Ol02oޖzTN4boV?؟״MbbNSXmк|K%K?"8hN嶧,-ܚyW@W-a#\yw_ܕ-~\8_MgS@ ͬ'7 ~]WVm# #Z+|qrtz6gX-bU'"[ȣ,?rt254Vw@rS!b@ۊ~$eak,7l<09&\H .O'n'P'_0۝:BrHm̑Ff:-X_n˅E|VPƻ9ubTqIҳ-`#e3&OS4:?ЇXS$;yOp]/hWi5bt2Z[-9ZSUU!ĜcM }kpHN q+z_QH(#E) cTvIĀh"'D#wp@FqꋆBS Lz!Fcf𞣓36S`e=TF$ں:y.\9{,kkH +wl [Elh߿HU% b;:b~gz+׏F-?:@"uyN92:[)3'gKvvvA)z,켪bowMtG?D́ՠ+N@ݶ{OCu#1JAc_$ASE;\8NL>WyO>;dzXbҍaJ(}N[_v8BJM(*Xmm0o;VUβ3 JƦm1 df4@l!֤ p<58y05 "UUL1-(X/|5TA|g~0v3泎yJ7efly.\PbJ4me1_{ϲ;#&J˦Q0ۙRwnB+10N݃/I:wHʽ4Mh~ ]ن[=iև7n"kEq X!cM w%*Guμ-\aLfV7h)ISIk+T E,o>e|TCCnh o߯oԳ^6 .``VtУ$Ьg'RK>PD5dib%l`ϰG^ːn,xFLݖe5{LULua*JX ]D5I}`\RW5!Dg>1=Mt.>'2lV1ZrqgFT9h#ID!-Iiʔt[ԪFY۵؞qLSuLEO@r|VVgd.֪#oF/Uɂx[~,!'.@pMZ.˕xr>e{jHl|tyj Tzի(td&XkhA3@[O2}/A|G7$ŸHW̔#ibx3|i{5opxڭw{Po{[Bk,];CrlQwq7K6]U\|>6uEմEJyZw8$h~4 ~Mۏ-s;E܈ !m`a3$T[E[xz[vIQf d.wiB>FQRdZBW"'Vb ((t-D&rQܳ+?'/TɰetLr|c=J݀O~M;k~,0Hpo+]M.ׅ)G8iw9b5V)&d2Leʚ:6A"[3dA.֌12#CyU4 RUM!J$qnb [J[[-_~*&D?gnݛی/=_PcGvvvޓTUCj֛ m_˶GCbRD)E E($ԋ yST B.U@2Hˬ^W1`U1[;ޔkn:'Adb2cmeJ1K&rYށL֕eBXLt$EU/ un#ї{E _!𫾌z4mݱHeQgJe :,kDԦfD!E>/SmhdovRF2 fFrMzunƁOr<)~SҶjD(]BqrZS\"&d2%ޟSyMR;l G\͘kA%TAA <&K~ǟm^_SYNTb&nUU Nh.:^%%Q!֓뇤>;AQnoF6g'j~j#$q !:+IZoBp7R"HΥ-FoABɄt\5t  IijWo8;;b K2)a I Ng [ zN  ӝ_z_V /v>4qʵUx7`cipnY e}f<<"kEGV5!f>_`oN3[pOHUb~\S71^B1rڶ< 3h c%9Y)1,Kr+ZV#+wr.{F)D._$$RÍ#79t%.k:݄KNi)()6s>, 7C+uFuCU[i ą ^p-R ^#yI-iay2HLQJ`ET+ i *J 2'RRu }FY(.t'hUe՗;aSlZu~>{?>~-h_ş"H!#"怱39MVvaypS^uÆ3P~$}ꝃR1TXJr@ ";{{i,+VXma6q=y34E]SGʌ[4,Cbg1. e4᳂ZUА)/,1C\YK4;~YSq"^,n9XOo "/?R,2o B#b7xؙH")%-!KAZŔ8=-h'x}ƐI KNv%I*{Qf0l "TI#M]VR\%2R6a"O_Q%4u!Xn<)Ba@R)9*z1[DHȬQ N/h/ٌa4]͸T6CN,5JHbѱ3#2?w's_4ܙ2!Cb M m֧' #XJ?,Ov[Ub%NJNNY.۸3rh)BMB39;]M;a^rv6!F-:kfdv( }?Qe2  YrҸ HEG˻H~d{dɭ|;/kWO%R*7yTB+y}ߗuQ$˯C 2mHn9S,`9oG IJE iX.WXچ \mਵeIyrT$13Hb"\ƨT*S&΅=mY"GdQyƾ_v>(z!3 a{8JSUz./5 *&M]0,ly1V5Qovk0J ?9&7'-9]\m>CglG`QB5N0N*>g|.Km [|X HIҒ75>dd%'E7wSvcIDATP؆@h8E;aSJ2sctRï(Ir=cO#lo9Pkmt$U%R )4NIvJ2CslX.7 }O#1'JT9XBҨ mGegq3܇ ORDa¹bAպ(BÀ6 ]Z0 =~ ҄47 )h.<|!"5i艣gxHFHS7 BS9BX`Lln(cQ(.t\ܝq4:etj918<בqѠT.Fo/{)ݖ 2hM% MOKӑե?04MT3{!F[W] fEw>G,&YDɐ-*)4+ EFB%--4&"@ Hc&rLRgB&Ef}?7<{q3^ܗ+[i23N3=~P4)/*ESP&4"r*& DBgbab3l#@Jd&w]S  m3R"w:TYx>)¢+VF;@Slkvl 8y63r딏}>_o}o~9Eb,qVkٌÝainBe*!H'ϒF U\Vqz|󎌢_F-U؟Qi9Ril  `)Iv-4ml d{ZR\#D;'Y/zv!R$x5=T:b}uNu}`YCh-£CjA8!B %̸^1*OL4#O͐ubV&j*ʁ'E?)|PU| zE3BVưٌmS\їUWeQf3жV)R@h5iQ[oc&eM~3}Y)yijn>w̅St:@h\ʜ/.9Ȧp)8Y .0!$2!Iщґ|ӷ'F/U^Q VlU1C H)cT"bj+8_D֤,U.1AX1 #S$aH\0 MuJaL`& k2";,!,mmpCRL nctfSU57⽿k<ܽxr|aa!7)%b 87Z,7/!2D #dEaT |BLնm.hm`xgg 00ZIa}R*z :4JMun*M-OY![LJ)MU<,ą*fH[e{,׏^ཞW };.R(!u-ueZZ/qӈșy]^H1PYSLYq ;Ǧ_!UK̉K8 S4awkk˘fQBR)I Q^&JPقQ>Ղ4ph`pO~&JWl1+x{)G90ཧ ubi4RR# )"DI%}"pv\?u#!e&hFdLBK:M$ 4ѫ1(Q?ܼ2n3X^+ٿ}LcrTp fHXcHJ)>o$8N7)ѹ-k gVDJ 21H\p8=;cg.Z5d)Tˉ>qwo=mep.4 f K R, .b !wJ/ 9TH2 'KG nFmaW=Rk €΅Hx1&N~=o?OHA}1"M$P YI0QRDHQPIlfAhݚgs֐Äi8< A{?H _JG) ^L)q`b ;:OAMe+*=hU֠ʖ抺T`ՏxW3[HSq8 BUzǯ|ǟ:?~o9~|=դ4ᦉ|Q UY"QY@q'./((k2ѯN9zMmM?9}x}+̵-s^п}=J)أH1#MM $v E ,(.l_`gwһa7zfG|`OG>sm?_8vw漠QMq@#9RWH)@$AS[2 9Ku`h¯VeUTnjn7<2ѷxN}=2oM#!)&Ґ>c{OΦ3LI.^ -OYMEθ~dϬ*O6TA._?/C FVXPx.)|mM.3ϙ$/IB*ꧯ]'@VDIs8_ Wݼ͗eη#?VJ k'ECS%GG~ar=J*ml"IUЛɊk~ye5l}{p6-SO a1T t<o| ϋE ";oFIx5.I>;^ "&ʯ}΋E "囈~麆9yA_7vǚ{s^繯r>}l_ uoIENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_060_exp.png000066400000000000000000001076271245535672000223110ustar00rootroot00000000000000PNG  IHDRD; pHYs+ IDATxyvU9yeь.!# 0H"b1N) #1qBIˎm0ER XI dHb@ьfwg?q\@мz꧗s@ys< hRk9J#WpfU'Ͽw06@q8 !9G62|3{zK<+> X.ux6Djs*7]woxŋ&.nsO }Aux%R*{P|L[j@! xm7/;.mzžpGherB UUg^@ =`)z[_Aʛ/mǫqiMB#`s$pMD)Faoy~s<~߫1 )uL!)nOLnkuR2)u솑R'{Gp$>kʫ" {bl=>8fs3- Ua ":)/V=>x!]|c Pu˜G;y>t^y\OԹ% TmDCUQYSkM(U N12c*\+|G#]Gw'YoĻqivlJU\Ri1Q\(Mq"]7qCAZ#O| ERH1|-zM<7]qqwoy7ZJUhQau3pQ(/="N !} gA yj1})&#xr.nѣqsl'fBm)G\GbFk 9jg>pj ڟWp)΁ {j+ m mJPJ+] ňEHABH41u8ȥ1xKs . 4mCGkzCRyw8]Q}A7} 'ij-VMI1cԴ1Uo͹H1W#\:9Ʊ0 # e\ M֍[/86Bi8O.m:k"LKoh= L?{Zy۰s&vZ,wҫ")9C N"1H` ü t]o ɱzrfbg|<9qĠJ |{!'Νv_Gy;pPeVbI^Pj6%F[LZI}G-f| ĀR*"h4`?Hm>SfZc"Dmnb'kD&(TWewnG'1 #ߌ8wR ԓ,C4 UIRLmM&BSe̅ŒZ*S@JŁZLh#",Hkこ Ux *Dm0M!uyP[*,Kb 4UnНͿLS/U?L? tǒT+ pD4dŮP!XVEZsTՂZg2K3iV(> &0 Y-Tb겮GrI Gu89::V;M7_y78\o c6? F>usa[k!Rju mbJfS5y `kkix/)wT`|o LwϓBQH}4i r-% =>!c6ho @ (ff@b"H.ښaR GJ]Xek,@1lbZf[ra'%@={aF/119<cӾ˞l_@TZ)ګe=1*P 1 0"=ڔXqE qBֲa8ͬDcw9Zs_}/%4#w:u~*>vIy|TD gp ŋ'D1'7w}ɹp7o1o}Fnp"ɵfLZ`j7"Y.Rɵ.]xX cX*mSax ~=׬B.-7vہSg:\OVEb3G8V+ e!ra 3_E_'gp_!c _X^Ŋ)2RgXT.DhJUlKLj֔is6 :oD6J-v=Dz^GɅ͹K\4r & 'x8׼V?V{h]æ}5GmlmLt>r#5ZU6s2_jyLh[ïCn$f\S$̴r}5EiW뒅X8;ThT :XU4wEZUL?e&m4i' \ 9g-NSJ)E9[#vSXƉf4D)"*[ʢ?Ϩ7ȏ?TdxW'[icSIki[,6Q`[|&523ϗBH䩥(ysX * A"^$-}qoxbRRZ#-:8{KRĐ(MSwZ(Ũ[nzb7 J+V2]כv Gm<{\:hSpb %yCZ*Ӄ9'ȑ¤j/ jb8;Ua8r{xSoe=N8 s#nhLީ=ni8옦 M\>1s$>:dХ1\x_*c"Ӿ_c-Ydr jl6L"_͚M8SBxjEQBx1B Z H0#$vJE!~ɇ'^-g֧-0>COݬZkRZR D)E4}G f FJ/_ l}Ld;@VDZ*]cG.q)!(ihZVպV!P[o J+Y' @Qw^꘹Bfβv5sm|qqJ3gi(nUǰдdZop?uR+S*19hft(ZAO/oǟzY?3[uhbOnVutֆqnXgyoB`jrQRy*'a7b( L)(}⦅ VbUf ^xNYrtrd0ٔ.byx',=4lNؑR2Sx7W7q]`Guը*%gj`$ E=S87Qo q<.$'$7?֋W!hL=%WoJVAr.Sᝬ EآzVم&i7sͷ[! yRj-c' @b"P-d}h28Yq TkqW|翐~. <?yTÃ"SΌH 6%kp»2DT{*͎_&DB2઀ )AH-gT^VKk4Gml:t]m4s5|)@uڱ1c5[ĕ/pttew :"B-9G<T.lr٢7ނ7Skѫ"{foarj-UA},VP-8Qeۘ\`/F egJ+1.&7cf5`2Exhラ%$fIé}O/Pe ٩l,GhxN-͋V܈ARblpSS6H>Z-ZnAK6^ 5z>Q0eƢ#q۩2fe̍!7G[-KwBC*4}F-]JTxlM{sGpx"oQٰ>n mƷ*@2O*ұ9r뉡C\Ʃ%9.m #P)N<18X.+X ĐD5>2-gm_XF^-{>9R, \y+^Ư?_e)Jxsof(M Nq ziC&6^F&]/lpNISe#{6+ ͚ G8_o|32 AѼu5Ib3qݚ+ 4u ]y>yϣcQC+t)֟͝SY Q^Ί{7}ݰ; L#ݩHv ^83gdyD"5g pUBELJȜ]1xp3r&ssS1KZHn`oB4Kd6G wf'R"Ĉ 9%g5EZ`_yd'|k_ɷ~+8+\e)Ls?MhqZ(ޡ78Rl*f0I6ph7ɛ{BN- ]D,yzbw qf7 \r@X?Ùӧ8CtqA^yVwK MN2~+X1 N T0!:qeR4"n# ZeYH\AQr:R6G#.\doo">TK\sY.\@.%4^OĖ]eU_"e/;y߇>[>z:U. ay(jpU5i3σوmrynxGMv82## n7l\WѶv:9 ^sWRK9NDS8 {U>"?:Xs$&>Vqꄋ+F́SĦ!/Ɔa0u4{ MvMe\8:v-\"HĨv8Oע%9'v8MP c;(,pPbjh989ssVƺ5YsLo8=NC`8n1^>d}Lxsη:5ߖX/?^ёQWͦ)<3I|@:>,V?K3I"Dq>\`U3p XQF Q3Pg.6t N_sqڱXD*xRы0wc,& ޓg¥5eboE"aɦf+NF<9qoyJB(K&"~*܏e߹:kBmo&SSic/.8?b~t;YRBR!tۺfĊ},J$8ojnX1ѥ<_yQx(+*6F/2)86ođzt=_ .TaGO/P\qb;DҪiQJ%"Z2e0g4ZAf6Rw 1DB FhK<3>W=hcZ)JnfGhBI2CQQ5(*PJ))9#([\7Z380M"5fy8{!Jkj[= Xep%—|UTF+qY'\z И˶ 1<)NjW"SLJiyzudRM\ RMPqV*)Kڸp(0-JNb^9p]QdfYQc&DƘ'4Q<TlbI Hɴ]n׳ %)6yvl (6Y4њqILûngI:8a7LY4c-L޿;g4~U?FL+ʣ7XyXXU[N@HA x<YYbETCEp+)|=ʂʃ!qYFT'44!DJRM8|^`j۾w|]>CGA|"O yRx {{N1J4h;Sd<`)V(!W9g~=Ä2us4<?YwjQ v x%B{eΪ 'sh`KVrbTSܞz>BOsj:7*pJlҜa(/UG5΅.,V݆i H4UikUV)Jaww407t,rf _LʰpqXsrz3#a{c3)pt |$-LnHPUR>S45)Wu͎BxG<ޙR±OI%O8WZc^jBRK16?K]ihx5<_ >zr&@WNOڧ0X6[,}uf69 fX,)%d\*)~6&[wk2ͺdAެQ5-c=FZ敭fdXafDJ|ŋ /<*ֳ6?~oy=NVq8stDA,@B ^,(;+3xy>;~;. #cO[̩{9sjvLK8uL%@LU3#̺iwG}iH$46r'}X<1l]Uws22ω=TiĈ6sRUI]+'0O`T&"<7q.r?C8l;w'c64ܔ(<sa64ej1׉PRS@U؍#._nuia5tS*_BKdzor A-_|kr9{?BAYo:gAD91A>`OK6B "?F[NٮSyn@8G)9%C\[Ih[%kJ>z|0pJeJUÎq}*^|pgMO<@)YoZvnjKIL#oEb Wf 1HHif#'vk<qթf!ӥfOi4ڠ6zp}x;?ugef/̹њ}~y=͟N\9Z3M\V#2fwbMd[9zY?v+~?l4ή.jSZՔ*ǍZzx4ӎ"x<3ϸ3ל;ohe̅T2TJi\t1\;Ez8BZa*0|kI%v#cV+R8D)">[`!59vD#B+e\Nqk]@f7GZ=]؟@c6H&MD) BLZQʅK,{ûX~+^y;~nS czA=`ZÏcJqGf츟/*67ffN֚aKȡ;8>G9_Q,Ī *0)2Lìڰ3{)pfB 5KctVt1wz߀85-ByŔsR-t]u7Gsb0v<m>l7[jɚ )YPۖv[vNN0Ns.SB"yOZƯYIT%W+*PsCW8оڷ*sz1zVé0x8˞1|8󊜼ӂϸZظI}tLT/tsVXr#=F\Jxы}7R,[UmؙS)4 NER]J>ѻp%rbO)Bh'} r8qa&|Lv@J؈r 9f5f2Cdj'ʱcfY:ZiE\tnEӂLn,6L,Nov&%.3@[|/]y̛~w(G[u=YGDbtYAzgEgf+qNmN H#h,|qXIAs8Pe{zS57^GU>Rg#.Xw}?zg\sMR\@-@Pkb K.f=V[ ;o2;Zpn:37`3Nfz\$1T["] xp BM\Fo9>sNyu]8NlL. +You,hY`U D~-9G xu7 7xQԹe^5nXyecEnF8zW[*"JspŋLD"gnefw}|͎8֮E6:L#ݕ=KKGe_Vods吖+&im:y{aGċWiҘ BXRijٵ5i5]יZ9W6ÖK/wK n FdGs1ީ%8;&%ʀֆ@m)7,b[λxd?t'`=-0̀Ad}C&fޡU翩|TGspF BkΡFOj&q XXo:Y#$(iY}O5LSa#nFKG8կ?1%_:ZTiћd;6 v3)Ekf+Nfg#Gk=j'{Ua8\0\&eI%&OiڈQDJrlN|e^ٌ OKMED}.;q9 0Wɍr1qGձ,b"Lvz]z*õme| 1r"ыp~= @ܲ[~}\wxƳ8VrL SiYsckkL8o1LFZGmVWm`p-8ysf^sENxQnV{4ɠn!Պ7߸˙]&TMdF}%y/soѿS3v3 #Yov'I_'8~5tlĬ8Tf!99k|YќañU8|!pVl^k}MYt1[hX(ʀ6k!{oo#zoo3Tڧ4\]p]Q\WR=z3{TGV ;̭WmZ}1,麞tI<ρ͏m{ū5ju:e#ʞz*Qg喧|2^uMߚĤheq,<ܔn S.Yn3.g !Ƈz]),+B |#O+ ^A4[">PimiVbnF'́ڔд͒Lm&:T+W.]f]u{K>m2!(W=Omq?imi~{Lwv݃ƆƱ D,HH|PH 1 PV$ DBLlnC]]Uδ^;-GvwORV}g}{na+#<}]Sw8Ws 7eh?#RhTS8(ӂ}~b~O7m0:wLmS3cVz]îI\Z^7U-ur ߓ&2Gt(1ZhlRdЫnZnpQV%%ByZ Q#/FݮWJ%4]S4HOjirZo~oߨ|ӆvYD\ xn!8]#UE"5E##L+gUMtit59YCmĜ w쏊q>^~T*Ze=1/* :M5O:!bӥЉi%"Ve}%TA[.pY+Ӄ .>A?'sx/R [/2WTeBbJj[]MJfV`U^ւ*?dr MnE.RhJ,KG ah)qF6Ep dy啕`&. ;AKG_8.òp"X#!w*jѴӁt>F1N3iB;Mk_a{uipq8a\ƃhYJBkϲ éeLeQ8{80J*~Wo5wuh?Ht^c@UM)r=2?~NR+ugX%FR+XõbR1ygjZTEF1T8UJS*lyL,98cͬv9߱Y'R1{.PM{kc'J,D͙DV8.RPCfA[^)4T8q)Bi cKMOst84E?aɔO'89T/~sNmnGjNmƙaJwv}2=77t8'~a)GGn{;?],]HIOՀ i\l Gn1Kv۞xܘ2_}_%wehOkkZwc8Ѫ8R5Q~{OnHLV8j/3wg\-AnFS\C1A|)lU|{kH9Q#kR Ov/Э5Z2OYB.buα?CǶV"N[V* R)S"qt]@)X,7G5-M)r=enYhk[3q9yV`N2܎Mw,39(Mn8#)398v8 Lh-kf]5DlLI3.{C繼~qv<&-XcPb/Bʃ{[T]謌ԣ'q~ޯ9iO0[_I;J-ruT԰LRҔUM7 16ʛ٭47i^!f+ fMQוPZU$2ARlh#*s3:|ýRy*ۋ\8q{{ 2cV,DIlC-"1Le RF䣵ȑI+2^mY#RiIEz~MRf({Y p>8iRS$=RLQ[S 1qO8{[@+2?.N0xO`JX x%UZ5 UgQHr~~/74M9ACuJ k/U(E)ixQ>V㥖=sҳޏqKohF|F6bIɚTŤ=nv0-+]jDlئKCe$+*Ky$3r6WN2gLiaGI6:!S:b!EN)Q7^+L_{Lcӆ8%W%fHU8qpoyƛTnRF{o#iFrI9Q*a)Ĝ>*xb\](U3iZ(b'Fp 1-9GZ] 4eS!#NT 1aOx'm..taFF2Ym V>~͎KsW7{4M!7yVz(JI)7GXW IUvr8xꦣ;Pck牘"9Flmr=<~LV ME/LP4է|_u Au-֮,ŹkY (X֞UF03V6 "Wkn] iQ+ EB˸"ZҊDBR7MWp6 c(V+xoFqm ~d:%4,%႔ѵV%iYgf| M°UVMJ3t+>0^bMSs߄QCb70ʳ@64cƛ@[; Ql^yֲ/UC߉B2cam6W+LYq?6=-(6[cx3A(wԠfT22_۟)JciDJ^S E"(#{Ց%(kyBZ{gvGxC),Tnl x+Fr3UCOYְEnP E)>[>Q~aZU5/l@{K{\5Y+^P#Fd4}/[ -*H\ҳ J`4Oya8o8Ź% ,=;-XV[casqCjŶla go Tet^F;Gʑq'WU`YI0ks<]j\?k]u_-RɣBnBH郬?cI ) y(9PxD_{gAYu.a=nsJJiӔ9za+UZnQ,ޚxj l ^ ӗq3y!Dp]18jmP:}߸+1NXUЪ@,)}יB癚+=L3W7)3XZeJ3JA:IXۡ{E녡B"ƆR%fRia5;8:ΣAkK0)Yc%y%D6W$EgsGx(-^4`}d¡x ~ۡrS-BOS#6JZ5.U-@+;MJU.1Ajݍi,[iq*l?~D5WXnGgmUZ y7̑x1 1S m} lYd$Y%+PBa[_ n'ГKA!pXJ& v;Ғ8^I1q~4-&8GnqԒH6'^>@γdH <٤Y]+5'_"h\srz7y)&Uwڊ@T4 JտߔIgCSkҐ.-ZIǽ8VdRbn%Phr.UqJIősvE~:V~>o1aW F>\ /(1|5~rϺmźhX2dvN8TZ5|pƠ$h6`Gq5+5hV7dEK, U5yjGI(\?c`40;9kpeiCԦ[1ڨg~mMZ+k]b"f+-F3. _ 1x>R8δVE@-nŧ/".cwq{~(H|Sh7h|:@RSpќ1WFJhM ۡn~X'M/>x Gv5Jˌ~0acq^;slv 96}Gy.\ (oT-3Ѡҳ9tozwaFRh|?riYsdC۞-ti R#Z\H9Kjܱb/ ]8PjfZw)#kֆ*1-R+&ކWMh"{s/%V^iOU Tfgۡ:aXv,il^"++rcbS28wUwXznr45Em8¶:*>3!`G9rX$"JpdΉ6{yŽl;zt1Y(1c^0- Vh k=umI%gzYL+ys2drj dc=HXw^z*pS?ّa ^nNR )gs<(-*]a#5m Q Qz'W_yg~XBO1WT2Eߢ4c$G۵&OQ*ʋSWŸpRF!-9 ሲFW8r6l:G?xM:I (nr?,QZA[ xX 攘s&JRrbMb:263dqf@=R+Cסl MESK׾|Wݿ {g )RjeE*rHiFk/Q1bԆf5 kqgMmyϹ'VVJ x'uT,Li_,Z,IǜfůU(GVi9gƔD_2η ެOOM)uEj5`W|VDk(cR@kx*60¼LLH.mU--BX-W%9 fJ~*{,cD5Jc3 x cIKb@љn S<2Gqes¯թDZ+.ih`tśH*5rItSZy9R.e!t9TKjAK=`򱏟S=~İ`qR\ θpVVfI0w'Q>G}%f63r-dm(b$))8hu gCF@JPˌ JVE54q2+@:`5QJ`u봊urYͦl<]h A ~jX)]kd\bV2Ll"s]7mʲpo9[8'9FNY{N *{La])rb୧W|kھS(h`4H1^)5Jl.iS,.iUV,ֿ1q.ιvϴ,u;CZzABiKR6rA02 E7k?QϯRU<ҕ^k>hOJ` *A[0oP8!ъ+y2K @wH%㜑BVibx"tEE}F[,] :J)4x(MU%WK hC2.1s[邦=tB IDAT*.=v nA(QMq7=m_p#Jΰ;9>1o?7wkEvൈm-FE)yXcݞ htDֲ𡣭&pYMeGwX:21%:3s?f8\q CM(0xω1l ˭᭣g,j+F^T9⚗$ V,dr"KBi4aMQ JsMSZCK"UI*RtJ*erz27)7n'W7Ɖf?G\^1.Lo8vlg'NN۵~]dE2VS%9,ϭ6 Wgٻ/; k+UwS4\pZ' xG"m\1ZVni=X'A<;9=?p8#ǣ B7hm9$X,‰v'iSaVE1HJ#6tpjq>'Bpk58;#x8,>5U!My52MЎ-CМl &ЫUAY?,@2RM1qkVBXt Cϼ,l5SodŕM Bm湙37Dž9bLXYiX 3;yflv[tְ'5weJ#U-q[c<<7K\{LkZ, r)Hζ%'qly1 c䲔SîmAnѥ6t8gyKheSq\[qJsqQKY<&WO3k͠Ma64>^^>s;i$ nn:M nDbAl%K@4k\ZnդJ፣*m-UK\V)e)ӼpsyM,㼾 g.) 2RK5%LVqTvKy)ޛk}g=˻hF$b*ecL&QR P&!2T0q Ae P"ZF Fh4Kܾ}9w ĄU<]/WY̍\beon,I &x-vFB,}<~*~E{uw!;_65<*b _ړS[]9M<R*VӔfS&iyTh%IdvN͹~!;L jb7.y~^z9K 4j, >s\~7/a۠BhNpI~Oލʂ4!fBHUGM]k $u1]GO89*]lPJb5-M +;v9BErT)z#mw n?ˬX#hXT4֖eqHȅ-rES?rb$"`$>w?3Ƹ|;$dE9o2M@x2w ;q-ey}SYdz+Pچ!GHZ'3|t?ľOQ>O5SB3"qsrgc*[4UM &g*pn 've^7$$BÈ*l;B#>dF\(cl\>ptfGn@+Ez9GہCjYqי2e6!֢tQXh-l!`.XVbFK4/{^nn#i[ Ui]~M(L}r͞F<5`cN>x2|bu+R 6"&cPF3!r^s!BRW}?gY#+Y$ae_+Df6]rjg8Z{?ȸ(9P~08\LXlU=+TJn:DۆbTMGBr20(#H[Y ;NyzŢ.3kX][Q'Jk"jXRI}=5RҲXo*,oGW}I%9glUam\ 2ӯe{pl.lKO2Tr[MgDiղPzl1gO<B)ӓɎ) !L 8Z@@ng/|ιxБ] J^@/3pb^籣mZx)t2>em70:Gח{6ޑgt(&\pۗl(FԐ,jm;sw9uN0gTNeaU:0dP,HOHJ`QSȁ[Vj'~.]z*3@a10QRLͬ䳆8͂ng ÈҧRL>DҘ*kq>bz"VIKV .b-ڻ~纂GBIIlT1RT:>2sQ ZYּ[^͗Wp49dpͅ?U**)cHX-gNp.zm9wCYm$02Ur#iޗIŶbtF A7&9g;&|.SsYc`wpjrۉw-eR`D -QZC*$* 1r S҂SI)6YL8Čw;ӢHLY"}'kBHtۮ2.uc,cR\UQ.KM -8REʒ;Wp]#qJAD|q (!(R!|} Ͼʴ#TZYK_ .]5670Z`Fb䬦KN?jW'!s;?*SD)Ib#CxeESB)L2kjO^bN-[a֘Ĩ"a- >)/aӚTF@k4;9Ȣ(Ԑ'A,|+ƿ m*eju]Ft5%+U5\z~,N{uMU͔b-8|,W>.9/XRc 7.ibH(ogU|ї~ͼ.iohh5G79~ⱏ}ղMa46dƑG^O>[~ٳ5m%:{Fb#JB5Jz,i%imvhږ H#2RhiJE'BD1 Y A`m"|Qڲ4Zjt*ӿ0 70>p#~so*7mAiF$2KOc-]}ɚդLɛJn<9UkUܵzÛpіKBeɒPd J)J⭡._|.QdYE5I[B,>׮ܠ#W/`} 77Yqٶ|y~5%>9q cU][oy'isofP"\e,5>T,]7TdQ v$'(Ubh0u[ d2DH`nd#hfU5J)YɈ] OE}^ooƅn}`t!%֖ymv>%6AJA Z̵)s#"CH @&xLf^/W_9b ZB!T9˝~1wmS,q#1 G.V4H+1ⶎZgޢKخ0ڰinj!hL̦JBxla;f6d" (614&CS!HE;SHH!|`U7ꖔb X> -/ Ňf% R- :&PI8[="J< O˝9.Ebp<,M AND h'E"5}z"u]Ft2{783sJmBbdː#IJHm]!Dޑ&9Ӓ˜H;[]<36@}ש⇛r$%>C!-£?󬯧Oi \Ư*/# K6$)[JOЍ$wY VGAJKZȤ,'ElIؾ#_?jIyQZ,Q 3vvuMuY9OUɔU1-F9z4eڪ&梚 'rB!=b(J[qxcg{ VIRvTaG.fˇ;GJ ;b2Kȩ5 n(c;a9u4,p"”uitg7W9קRxui(Űrs}(Hdl]»)d.F\w"G<]dB̔!uxɟ:"_Iv|2lX:3(a| ƒ"Y,;sx7LvLl X=hea݈V;;;BplK.w,UkȌQ@]r hHa$+s"ƀG$ %[z\!+ΖAӻ'e L[y~7cy%6~:{?_/SJO,\ܺ2[ Ee$FKs<8 ЍĴW *%嗾o{w5/z闱9ɕ7G[n6˂!m=1O$X ARl7#yq@ A4hq#fwxTBB"B ZR4%][oQR! |c 6L4V`ªrhM#s+Y앲,J8#A Y!!e;GʒhcM=1aYZxǽ%h)hZMN0Lle %y7x)W!1cX~ВKO?on[VZ,"qoY,v_r\8cߡuEն,8:ܔܤ)!uEU78瞴zrIYqcQ?rlUZHapcG%Nܥ+P. C˄$$#NbgLI" ~ Nb5UxD Mmū7xׯ?}+w{w{kf5) BS !B;9pn)X)09!k_ɟ;,{P2.8F?2Y:×+7.>|)h*vNŔĚ"%yM]RfQR!xmT̕bL=*ML|` ~kyO_ 9)C"!e&7A+<̕~'b"-qwqj׼ꕼ_M5V+2$h0]]rQ/:.Da$'jwGҐDDIo'm@ سh[-!^] *R"U, BKMʒ1j ~ "e{h砭 91de's4RU (Drヌn)M/ZwwO2lMa9Dg-*[G K\7[vNgITMl6'b Dٔ׵14MUakBZ~w݅Db8K;~l)cXQs9ơAYH˱'O<9h]leJ4)[ PF/hg-Vd &u<]H]Ϫ=ƯҒHC=RKꦐtܘIR^BckVu]3#P9'Op89(Pvт2(;gجyÿEƙ;dCDb"'RH1O&.@c Ȭ)ukXJV~sXnsfK+M402k$- ٘E6%$[gElE=¶5_xSóh+oA1S@Lu]9hY@Hڵp>8)F햪gIh0;g;-sT͜våG{uY>O(tJH=yЖ`):#bjE#>8,7;9{3uQ",Vn7%&j `$2SdCŹ2y2jPqUdZ"rbE:{ޛ?<_x->S5q8unc㉱4mö?8Sg`[4Y-Ŝ|EX(ya 4 Cʣs Aiwuu@ #E0햺!ҳlܥq$dx:pU|L#XktUYSH8ߣTiB+βBWOt@mcG5cׁ@E* _塳όg}_|1IˌuEf 3w UE4mp>Bbïq6¤ul 꺦jBN$$j+?]/v6`Ӂ* R8}3֡j+B"rJ9AOP>\BRKNONX ǹY6 (֙Z2MPLb(%[8dVΒuaf6)'BB7I_g3sh~0k%UU}`,H%2ZպYIDATZȥzYcꊦ7wӷ5Dd7c,Ihc`s n$l5>f)|919[w1FRY0DUx^ZC7 ʀ"~1PR(\(7}zi7f6=HۢZ&퀌0R(>p'oy3nm9]3x_^M4 IɣŲ[1-9区iǀ<1zvN@ȆC\1U4ŻOTEtWoKѺƇX=J³"̍CGGcbw5' jPb["LEȒ8tl^$.%'qS+v JTra[ o>[\ECfnXXk.\@A{URBAP ->1C ejS*Y)d%brp1|Aٺ*n;JI)X)RjBklzH 3JckM:H\Ev:eBlw`lPq$h+:2 7ۛ>k<#y1uGXk9l6G$PmsF[1fd# e5n]SKw,:2Xͤ 뫸+B㣠-˿(\*W.Q0̉-JihSӈ,>+ͬ6c}%D6pbxxs7}x1w?&N>xnm{zz4>oa* uCit )LYu^JJhX"fg3xbR ݔ 0"׮^' Qd,S;f؎*FQhif5 LЍ #cJ Kx3MyYu R,CB}p8EHmQI6ybr zyra1V jI CHVeT h%^ƄsFrp &]rsr iDTI;'&pcGN Ί1Ghe6 cFYI#9cIE|q>]Մ!]PĤFwrM};g oȢ Pf$ڙnJxFã#MvqnDJ~ "Gj[8#GGqZ-՝GdIaZh[e<\p*E1abৠ,bq@dAه?~ǟ|wP^6b¨"R@m8x$% M1p{Wfd?ѣ 6LV(13 {(}WYSA*7%)GtŸSJRpb9Փ=[zc+˙qΕ3ۮc i*)~ֹ-B'RVfw Ed2sMk >&l~O &rY5*m >tT&UJ*YYs҆qSB-[&=\Ӊ/㞟b{wNJ樣Fڶb/#]AlCߖhԢ*L,;?b;x>ixŬȌ8tkfs7 ͊z9k {+;|Ϗ S7ڪ"D3T)l6"'s C_iu6}%O q*Tuw“lLLO gdMGMf4, RL4-#_9dwe8sBŸY Ko7[V~,드&j*m{TMMJpfDLj: îg VM@ IL6g[--U^1ʢD&Cj+YFs1IO;,O[Ei"tcr*F439xW5UU3(ՒAX3g,V$RhJd GY4J;P؂e܈UBr/x[Eg9D+{ON=}c.΃,.)!(#FrlGOVBc("Rj6Cpnj$s %2 E\F6X} NJjSol?O nOhSFXCC&IKVCd9)VIqNJaS9lj. oy/?Z\[E㧾 @L ee!2ZJڶ%"B;98DHdiw41+bnhZvƠ=s'D#3+@ӻ,?ٷiŭ}pwh$߄Q9Ɓ#RW`3rJ5Bbl;G`%}?[U(@D'0ni&8 S=akBp$S .H+ T ڶoێ=1ލ)":GHO/X>#FC $@< L0 'LUĠLʼnz1ӏ"T!iŏ=~w7>a^/XRZ#P#} ۛ}8nb~m3g9}bi3x~o;ě[Eagn83!9oV97pj7By{/؂=Fn5ma#ɯ(IENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_075_exp.png000066400000000000000000001037271245535672000223140ustar00rootroot00000000000000PNG  IHDRM pHYs+ IDATx{eyvY{oUW?f=gy oC !WOvn\{Gx=܏Þ FmJhAoe^*R9L Km}Cp :FN S1ESQ3Jm̥a[< ?1l} !b1sBZ+50b03k |C C)B$Bm 3H1bf4Uf @Ƀϔ"ܼś+wyۼ|hopjL㌙c@B"HLJgxW%-qJ?FEȡCZ+"HTS#F!V )%bĐ(JS K m1F|1%bH|)1 ZI)TW+/Fϒ}pb?×^z/>{K?K<) bΟSUf F E,8/vC `Lj V*JԠX`#]Τ(/LH<!UIb$v]D0UU$.–ք>b R&ɧ\Keއ*ԪHLHIفlR֔*aUD)F6BΈjƲiz_[rx?BuQb?Pu#EHk1gb"w!jU031>;21 6^Dx7:Z麎AԢ['0Ŏ #RS1/%2OĐ1P[F0jYBdZ~3_?U[<Ѐ?PJsv9RL4Ն fk !Sk]> ظN} 1Ԉ[3GCէāM70rFKFy6/W;=iѯy7}{y>#TZĘV&r#!J 7ggO$rf3)eY֞`+TkKUK Cǧ?Ee܋<D?~P/5[K݊uYVq!g3lI+P#d0/R[;BpVb[وeog9'v1+&8:v1w`B3]{`FΑuĮze&Ze}w6BLH)3Tgr{ZbtRm4_shkn |w|Qzc]b}?6ڌ4y BίzLC!дQk%uHY0R#lE&n/s25f&/g!_ j]&9+]ESfK{bJ)<3{U,4OB+ͬ6EH)r8<؃s}1]!Ԍo\CD8M">}8`<0 H"J\nen)u5rLњg5~!D̙Lw(ҨTK.ŝkAKY0kT-4Z>Txw!;ڷ*o0 g={Ӄ>3aFټ:&~q-sam^HUj-7ԎR T.E~`3輻*FU QS4謱g_䛿9yqڵk 0lH]G)'j%&IcAL-F\iX{#J4j-,Q5D Ya%@ h]+A2QSsS(_c.y.y"oy`7mL EQN( g ./R*HdPj]zb#}?@ ҌmV( ̕Rj`of3~G9~1E_ '''{܁ hNɅ)D7iI)16kFVux|gGO>> ~G+S1!V2&(!DBHFʙތZ 1rtaUWTJ3c$\4ZNlBEq䞫SzSV%eW䮣>u.K!HYj׊1КO1G,@ $amnE &qDV2Ϳ!fqY黾=N6 6SۂHpXs1H(um[*<aݲ,^"͌]25/3U7lE8Lf\ZmL|BN[@KMݺ٭x]"[&]Hc r/A:k3,7g:""釞fj+ĘXUBdBŚRjYKJ Aۊ]U+,.aQo q !Ъu90ϠwW^cpxKNW/ZZŊk8H}c@)/!U&45 &FFΙ!jAuAM(т8G9ƛ#k]ƚppKaZ hW}#:Hc1p:riB7HȄ45Ԕe^8&Bt2M#ܫ!VR ^r W"me,`s#O RL̙.e耸6] V\3)RX!pك 8fhPm蔂 CO@Se&Zmh>S;H0Fi I`Q1ČJ#$qbf4$˯b"+vYހm @3Y 1hk9?g.{l}C4R@-wUQ>ya%Uc5[o29,1SMi4qܪ^nVR $ !r)\(z*VOe3ů]i.uRܾ٥¯vTR!;UKE!3꒲f fJ;ɤplOqbt-@!,$$KL/B UlWYd# bF`P^X[F]et H@\1a:D8bk[Zy r!;gjYE %r?0.KEkqe+rȹ_썸 Zw4SϨJ)!@rq26}-Jt=Vx_k|/ocuO[+X+lC_B:6JdB(QUDŸؼK"-:h M8 055xL]k]3I! ^|۷yL7cL|zN^) eq*r&o~ڰFT%+oJ\]y90lzPPʂ5?LկcX\*r5%|2F.en*g{'؋exGp8Q6G{͠|鵻&.޲cV ~QZU-dT𬰔JmPB)ǀCzЮ'V5=_5=y6d%+$3pDZڋ/_FƸ,X3t*.wIvd78oga'Zԕ K|VOꪨِseqՉbV*qҲ,WPA [U׵URN躞aC[bPB2'']JyadK"};MyW- 8\Tz%Qɧ2 2!fh >BJBcɰJc>yWy._~&F`D1 SP/|Z] 3jՈBmEa]Jdgq!g) V&-8FG Ua.S+Z0PjJ]Mӷ@+a1svCeZ]OeʼPny~sވ j{:RؚrQnѠ+QH IUN0urUSZVm7~5hn݁|΍7Gn<%0%HSDΙZRQQfjLv@E̲瀏i IDAT1}!7VRe`ݍ BĪIB-{g7Ʃtt;GimldɈVܛ\eҺWQ2ϻa@+/Ncw.LƉR Crpi3@!j]1fD !.E1²bp*B%pno H$DF]`ivTRױr|m#R\Ҕup~~]?HuYt seLk#+jm< qr0NeeZ1$*)[gq"l!]hARDjvo~H .HC'>wDjDG5[QX`rE *!Y !vιBކwbf3NcN@XXwB=*ds(cp}svv`YqV{LY PģTr̫oL׭4^9g鯲@ljn]]劔צP+4.i, )ej-1تS"v^CYZ\+֝}ߍĄ¦͑^{+-6_Ɨb~ʭO>K{C. D#ÆN0ѫF /Z`̒'7L@@QALLy%`LQ٫p?LǤr,gܟK}$'xû0x3=M(ȍ)9E ,˶hm{ /|G^4 i%K1DDepFnj1G.> 3F7\p34CsS740 `ܔOr?z4qyYPu"A'P/v)!ÖkہF&:TS/bAZ;~d[xOD{^'yɧx=Os'鎮Q87I $h4 Z󪫪ù2WXe`\zbU6ۭtnI-E&xgʘl\ԴJ. Xhk? M KI ۿy5EP;ښ W BM+&KKR pϣ&q*GJH-@HB 3];&DYy0kc{2KCCb8m2>e>Qf;$.8?ܻs͵__!{= '7GXK.&`CH`W{q?aByUhͷLǷSﺓ}zTZfB˂st BD1Y[3q 3Y!ɕau|oji!&QG'WR^x`U]k; |JuGF (Lx!*!d.iFL/1 (+Wy_OX2.,ȼW@k]F1T6-f ȹ#!LFk Gc?mj]Y%몋v@d ؁666.#C/+ vP/xԀU]6Wcs{u!,dJ;3}dPªʭFZ֧TL Q )@p;.fKY{Rl(|)".+w< ѳ꾀TB 1J*"K\+IgcZu!r :rN\{8}_~ʍ~{w6i=9x!HehKsCSDAO+!ʏ6BLaS^dY -X1[*jKQZ6}Rſ4?c?țp9eE1p)^ N7NqȚJ RuPbf`&h"*>F$xJ#rɌ"£'[6QɉZu]$>Q,:HA\m?]\Ȥs֠56CO"In<+zC1/˜)l~؀) M[J-j57[8F6,ya'nߺ~碀qӆݡp8,"ǀDyp?~]ǰ(r'O9zG=*R8wr <{D⪎LsEi6#-ou&%`p ۍ+2XW/Vqa.L D'wE%JJ?t,|ZؕT J%D% O|][oEmBjC䍯2s~vaˎڜJ1ӝۄ(eww+_ wn!%BOǔR#Bb7R:a:G6C"ݡ2- }0]#w5g0i7/wxuS$ Tt~һH)P!!Tdz K1JV_z[qmH 7ޘaeVw ȍn`½PLnJZ<__w5O>~N{/L_{Zu1n^V|5m-&g88^쌔CEBnlx㣁2OU}<ҥy4G|S0+8ͼc;01!~oZ]/B\W_:dE0M|耭 +%ġϧswO4ej0T21|ʆUdidCX 吉F@i=U`?Μ?x Ǜ, YŒ|úH`LV3tM8/4b ǎO_<|;xv~w| W|5UIsq)ƴJ]bb;ZgS;=(=׎;6GD2DafRȴ:gR:B)SZh xpށ08O ])dl˯}c,"]ܫuF Jgޫu*23*)jP 낣+Ha<@壭93!>We{%19Dk|W4q1ho<1LLz7tL@ڔfҔG 7=1syS>gy{??<ΧMfK::#();DSȭ۷{@Dìb–BHҨ(X|a7xZGAT"oUM Z|B1U|݈{xr.3>*l6K(s(*H|5RY/Z]c﭅`M7ƭoT$$1Lp9Gц\9ϑ:!GOlr[ُ.zBϙڔ6D Qa#w>8gJ3qN; :k?wrrQ1nXnUs\,C*x[?QUq}@?Rp~1,)}n'q҄ן#}*l{UlQۛʺfY#b}6y3+3UYR HBbb#$&HO` DS%3 PIQue=n"f1X웅]}ՑnN+f}M '_lUilڋ+J#`A Cpb3SfS j]xdZW}*d'wуsGVJQ8vӻGjͼuuXr[ Vs{v5FkJrg7aÙ"4OΕ}|Ͻ+/B_FK5- DHۤljoy@SA|<q\M+e4YT,N =ksopK=yJBV9kD ah-y#x"bn/B@KOl Rԇ,M+9:T3RC 1WrVX]„Z_x 'Ɛs#!`3/|wnvçלƗ\_y&vcrᷞ6?Ղ2ghJ5ՙ-=3 ^\QMuSlM5(@xTE\Qî G ~dbtgzo67o]U`3ŢTq!K.oa&Җ0]x]Ctɹl&G'НKl؆a8|o?dw>'8`  EuEII:x:'p iw+VyibY ^@c\pBme/Ic!$2M6HlJbh·BCeJpU5QPvϗ"Cة[ψ2wEὠx3_; ׄ:%UuEE{J(5{$vyx>kkJ%d+@ϲ L)Wʳh+xuyu]}Ϟq^ 8#ՎAڔe&ZF<ESuk,{O^6XH !&0]w< OD Ds[]8di5sʆ\xL'|]"3~"֌t9+@6B+8/Lb7^`QEysy$')wBri8-*yLesCp4/ήa3TQRÕbb`H/v{75)4Nejʾe<# 4yx)}$ ݞ@(DrB.TtIKmYʏ8UBXRBКfؠ|?MOmZmb)S0  |{k 6 ޴IVb+ |{f &Ĵ ~Oٿ`TVTYl.վ,p{cV|Rg~|CNGO UW?wEj^ `:B4֭!!%ZVV]bbFFdy^9Ӽ\ z>ÙO~P)7ϮQ},t}MJ=RvO#ք(ysy30AJw|ϨJ^.Y u/@? /1O6jV pXΚ7~HVIdF »W1C$dnecڲD{7K_fW*ٶ]6NV7mR)<]DlieKqT,q8扜WD=5Iggʼ%*O> M3 ?jђ3W4} EsX5g} ,OVS| o/ۯǶyi|Vim@ut}O"{ڱM }:XDeĿ.R ByZj7N⡆X᝽Yio&!n<-yiy\;5=njT!y3/ 8V/8?9su}0gbH =-Sڦ+#~G#t1&9~現<~S'O?+OU uZMȓ;|6WB|k Q5/v;Tˍ4kR Z0`oe\R쇞ef-3][/Z]J3 E &>=8RPEK.vi)L27޿6Y):o9д&uXr?n] 9|f ]eSQ9Su"g}UL{Xl_ղ'Z+;'^pͯM(F4ʵ ,/>Ҫa7gli 6?u;v! r\dvzm[3G'O&:ӂ~gl&.L"lƩaX3Zws1RX;Oy|E[),eBe5oQ>qT.}l%gFypaPHɣm%8M<ʫ7"K1ЍV >p?w.¶++xpchmut3): csݔ8*Kfo؃[!>|)8|Tݏ@[x`Иd(]1PvES.Eyڞo&ھ ;Z)*OYBum۸&kjkAhDC ˲O,ȼ6N-2ų,o wgP[7o(=aH&Lʺ..K+ژ*R=NΧOXlJhk,L<"!vȏUpYhX4 =fkHAL:lEOg/p7^Cy.VQNM!{*?lm.\@0`D@';8 u](憖"RےqP!̥qE e8J-[yhxva06,j@y_asZ!m5l*6s?iyneB HvGC|C8y;>zu:6 .CC6xG$JDž્B =4SZ%t.^ׅ8쯙0hGG*8њ^=J˲nBJs([Ղfv6dߖB/T@ؚQYd@u]^z0;X˂R0q)ˬJ.PDGC$tO,E0룏p b@:XXb\R&K"" 8:goT=+k<ͬ-͹03.6]FdΜ#RZa:7xy>MZ-RS!ӰJѠ4cGKh/n=nfF/f0rƀ+`&Z.ۧA.KXm &[[fm=Х`[+t_Wyf&e<3vcVL!% ǩcmExSjkIHn1 JXb8g{#! .HޔE *{| 3]pNd[ h,d} P}umDBġS&\ Z h$lϹV3ݖZ9KqZ8GrqMt]Om:kkZj>{bPVɐ %SDp9Ϟ_tEszq>!8D\¢+/_yf5v8Z(BUi4Y #6B=Ϯ#M/qO8Kyӹqʈ=|dY+ݾ 1ϤDm>fB h հȧ^vݎHRrUy)-x^J=IdSk#UX 3s,ݜpJ Y;|| m I+=>,@ Is] y^x8ͤq <.[ҧyF7 tGqniGvq>yx<Pi]WJ4mki .Fژ%sx&&ˢ]hᰏHO,O^I>E+s{ J]Ԥg,Vj uUrEC/X\&0ͱj^1mD -YTc\V<>2iYи#M—B#eM!6R҅2-8x:qg\pz>g~ jr3x$kC6WQojc\%\KR H.=j%m1E9O)}y8`ޅ~?[RG 'K4q&_%}oYT]?K%lŻ owZ4дf][S.%kRD*As- ݦh)J 1K ½yw>7m?\Lp5og 4bv`CS TKrNc͙7``Ղ87*K&jӌ1;4O pys SqO&MxaoZu8EyQ5ZqfU=~a zCm,(4cnc*/|%s.< Tmdr"k~ GnZFBO jke:DSK&!73tif>zrOz+5p"0H QW(e ;D$0 ]l[6$pu8PClJ=n ƜWzsnH$ҖJ =YBss5ۑqҖ.4`~ vKu7 zgY`UU U\ ieYV7Ͱ.%yq њef֋d:Q**FN"ѧnPIV 0egm8w">xf}3}.fOxۭJ!b MVfRO8t\ ~Oq̹{f. :">F}O䚩Ͳ6Rh9)xnv=7W;R6H#.\0ī޺n48:(s2x~_/'RpE:\UC_'X25.bWKΤmkV'DJq Hţ4gx켧Ma XUԶ` K1y=2cZG'zgvc!n+c Y܉/ ]~sofYtxb'U;T i6<󸲔I|Ԅq:J CH]pZ|oZ m#Om'/.x:Hu<>~b .WZmf2̬ e\l8| ߸}R}Sn=ZquUvYZZ &]*A)(BYL+17c."Lk6EI^f.p ݮ32=QZ '<0~+ {O9 زicr}E B2#UXJ4ef( awIqdusXb=PcBX"=L0OiZJVmwگҽY\b,MJC.Dttl</8ֶm%Z&KlMZyn )߻?w/JGG2L#e])/tZ,6:Wso4ӧ&,]DȘ⤢4Z9,p^Vljuq(>ps0Pzր)\`ofApfɂsh+D/l E[re{_>~9kZ-3jDވZHC#-ͩ|2pU"T %edJᓉj)NHOӊۊ5Yn}VWT6lUOju'Nse.ກu>rpaZ9q\\)}yw^z>L+Zƻ-{{jtmJBgYe/[m:׋'E݀Ǣgs\א ^'4 BSe-mFԤ)1[ៜgB)&UN4[OoR>xc( U+ޘ$ 4PX8PC-mȫGp>>]Cv]dQSR >YQܦsa,@e]7g>M`RxUgsicbf%STxg%3i& E)5_xq{owFV)|wҊqi-6@S& wpVcuɔx v@vT{Y;5Wr]oL։3:qWLލ^Q?;܍̾rUXDl[h%TA#KApZcA^*%nCk[<]H118Ǒ=]ER4)E,p ܫfgRj0ء VTu̥q^&?$ExW\PlF x߹ =]`BM8.+uFճh`%1h`9hk תԺ2'?[R6\,BU)1 r?8@Jzi}^=G}K3~cOG~ZqMv+2@x-NFp/ʷZҘ畮 $l{AIia9FBkV)pnfhQVeX3!JnR x8jJLL _ ^>2GDLœgs¸,![׼-_zG)&:UK1+9v RVCJ0UOJLZ93ԺLE MxQ7\&Ӗ朒)2Ҟ< {[Sp$iP=o||u.෦%e^x5\[i>p?DYOͳSҦHC‹*BBB9sfH ͶUk9#!VLteHݨQ!X|uiXYF\lX0Zx >;E saʨvr%FϴVqV1\j%!ּ8p?4piڶ%)9u=[NJUkl| `Ӵ!DJ i&&a=~K_|o8~1JBlh5_I m-tx43|︊뫎ot.#sh-flyK+}gy|2|ΔyL{C^L4;t},m"|@Qt3,GL"BŹnC"! "7&RSd;SR2f~__I?o5qbb^=wuHx(jmr53-n'Da\Lٲn/N }99QK)[Re1.qW\UU]GzΣ%ǬUWhkcJmn+6O ‹_zm^Qcx[^@s^\3ږѧ<þ'u myx5>$~{>{`9֪ԱCd]FSbJȟ(["J"s)1nahQh$50U!YiL~]t387V ^9^ó* =)si{{ / ybfs8|`JidID-]?UIBo\fm,BqC78_M+0lRfǯ =y8`Pˊ/}}v߲6FXaU~oÁGzms3X >>ԕ뫁W'{my`-TWMѪR*lj1~~)'JBV n."sˌJD+ʴqOiى! ]46̙ 5 5_c9¸@štUpW7p1, )bXi^x}wO΅~G;X]ӳ|3VaFoym"(Pr+"ZI%bE$_hRdQJ˹Jek)y^<֡HƗu &nǔuyd FEvo<ǔhdβXv8ksK8p;.J^.1qXdsjuIM?;/ZW-NC e*+r98aSQ׊T-!Uc=aF M+šUь--G;Y8G_üW~_pm2gRbK-ӳ-0sa#KQ0PƒsR QR/췘vv:sT2 %FƉ_mRE@ Jy36oR=݇;<qi;Mm=+Behβ4Xxϻb/y٧'_J 9;c9RXiWkx'gLajq)N4x佴VI?d,\_,}O2hhܢ)ɜ qc 'JIpUTzV#rL{xrNFX!fJOL28k9s'D*x( 14Qo~9UBnavvsȤ4PjzK_y>Lj"~ <#ׂֆwLAD Te4L ({6QZrĚZַK8Q1uWh3q[[#?AxX/pz5'].'[e4ݞ}HB~ɗW;0a˕Cj&" ^ŒR"1JphMy&E@[zkDe% 6v&!Ѷ#U%1SR h]fZ i;ёP WT\fBH3Rjeb)@af{y]Dil0 U !ȢUZ|ݭ7 UVE-oEL88fwTPlY8liQ _j^i\z2*hv }LK'[] TvgnwNdU|SRXcnI9OV KK_ZÍW$IZ 0%K m5TaƭcVC7C؍ 81cjx Xmϥ+ŜSZ$:E9f4v K)5cF]+f9-V\8gg%F+~U)$jm ڊM/5>VN"4JT7z;%,,}'?٤8r*Rm9Grnvd(!t0AnSK@́>tѴ5a1PbdMޣfw(C/65gTI,ۆkLIL(#$Mx NWB~ȭJ 5X.\$H,$*ǩG[pC*LqVQ"FL҈aQƠ4lAC) Sci [gkRtT.qW\ 5W6gӄbJ0QTG6,|Gؿ1R?W})8C"JV$5c3U|y+_Kiݒ %%tJ́1^-fWS*ރqI[!BjfGJ8))rdJ%ʔS*c2SMҺZ2I*JrHxd&Ri)%ёrZw֓Zpfh#E,*QzR\~,#IEo#dٶÕwݞb׏t G}+D*&cm"HQk^Ð8[ISjCDEqjƀ9k ӄ(^u w*:R=S!jNV)CSdNNoZSv q؍g3g e'xUTִr5xQvfF5^WBRA1'%/ϐG8ew(jvi+9|gEYfq8jͤDok:#?EgOd~sl(Ѹcux ;Yyd{|qO7NjB'qZq E/λ寧X8Jy8xn`3{HBxg%;@c:iV0_ND֑R*FT) 7ڥeJmKdwE X]𫖦fPM 2j[(ur }ƶ Ar)pU,i[hv'E-8CP%"o4K¶kxU?(sJIzXA/k7(5Sд%E;rkg`?Ug_-"U.<v=y駾;d eN3r :ajbTaKd%@*a?`B*9'c,٘h\ 0%&b x %C~ޏV 5GL,G8 J0IfZŷ,Uy\rB¢j蔀 xC}܂ `ErTZK* EɫTGNEfRDŊ* J3Tc1VQu9QUGqb S;9-B)7:-p+>%</]CXQqitFbf9+ ]-1͛ hTa=!inL٪* q9Pc OLqӢ8Zb1;DtKAy kPOM,f"UE-:7}$4/7_!(*Y8& P7kOH*UZ˅ S\ %Gb-5b(B`n4;68%rj`jZ("!DI4Fgv%/xu71o!`ZҞ֯8=INJ%lҘ(U)C.f ݎ*)'w;8hҐw-1)BК[¹Ұ1ZQJa>bn%#e|Mu$B)at8mrl[e4(ӒFȕ] m, eUuПy,FFZˣ(uJKN9Lg12yά2*8RDi00 nX،6g 709>s`|?^uN>.\uw"1|{\ :\1>0Smo10c:1'=*'r#!S B*7Z90s2gT!L׵XSYus=Ld[RX#GXfwE}䭦NpG]3aJ*,;U}gfIJTp^tF++U@XYJi4D1NT#fB"ZLuheXƈ:H)AUcRύfL`)&ѠDeJRE/{O?=7qU}:veqalpay&Wh8NLC0FQ)5kCu)+l|Zy׵aȕסP(x8z/^/g,"!hʠ9l6jyyDYŏ{e)(L+! ImZp=ƈRD)AX)!~f)B-GV94[EѰ_x_%L,טH8ݝ hmy7y?7}7뷹t\ ,0}Vպ%$gZ9L"I|$8Ew8v╨q$4B-^Ț!]0BAŊʴ@kA`QXHsSiX.7oy?62 ,2F,;+CeoR*j6:SHTFg!KcXAE(U%0D^UγcY˟UEJ*VZ-c9zE|ҫ_M.4NJk[TYea 4KwpݼUK7quX\X @'knE] a;ЋtXΗs;+f+-qڰ^wL1R#a* 4U 0N羨X05+ѳLiԬY7gU]Eh?[ C+B5r1FD\a" Vnڙyp|ILcueeVLPbf28C2)$kRCi\zQVmq@Jr Ĥ-miq{p%;n<?=4G[ZXMϥ],Y.^hk ;hr((M*w?jH\_=o)O&@H1bo(8seRJ(ą\TĕFe|ޫ^ΟzK؜\Eح"9۳\/i5ݖR+Viđ fz̙5;_0.]i5G-!d|2IZI1 Cb{>gQsh-Sb,П]'O44 s,)TtehVLam[tPZS[8E$ơrJcf7 [mh[8X)L1t#mrf"n2I3>^Mn4mZ`4Ui>NZI;y%L[bh!ҭVZfGr&fJVR ehr6aGVbB -1ȷc3=)IQBMB@1e Z7!C4Mv dp,ҏ8L85bMaZ.y4Ϥ ~w._Ali$=" we1 >'Qq0Kt?熧 B1Ѵ-Ɖ(Xׂ+bO[,qMFl<Ͱ(36LA%.t`dxRIaGI#Z iØSgVFC SKuL`9l '1NnnְX@F;_ӼWf}h:7Wm9F;i`&I4,m$L 5 XBn_X6BZ/ʰ*J @ #Sҵ·Vqǔ%1=fV0ƞZ2zb=qSȄNN{Q S g,WZ\!X J6ܸ5`(Rra]pZozeKʅk8P izko3=~,LΐBK c$m:bciX-3^5%EY``0#}q^Q4 2sY50 8V01Mr1[gQh}81 !bRRŷb"!( c.^h*Lf7Dc͏Wx/Oq=mg>˿_~!g1 tcՊ5Nđ9|K"욥H"(z T0h2覥10lIq$ ZK\$ZrLbPi:qR=QTZ-ֲ*1󭾱 =cưhţbYIDAT5h0FO+L(luºA!o;܇_בHcLК8<@̉[ǷFwv c?C8DS")I.B,)̆K8g-!L2cӴ}(nBB: ̹R+'ہPSuc9$yn3Ɉ1W4 q8Tr5rzvw-qV8#:>\}ǽ7a À(s^b9hX.,7Vm)#!fajs9u#L99gt!Rd/6 b~]%ejY' gg,CֶkUl%rn0LPB%Zt}\ps+t<_`p )G#H=1EAHT`_En%ER*`b,2%EPHc!bf 3i2.AEx,!ŋ [ _Z3%+Ϳ/۞rp|޿q@1 El+H1o5= 3XFi4k-~m) IC4hhONMU+)žgEAƵQ8@W*Ϭ+Ո/Ҭ+ ]Q*c[X=-Lឨj߃Rtm0rGZP"4"J㌘Wsb1(!I" k9SE_*C,I ;U ԥ n5L"]. þծrwe2|WϞD/ˏ{ o|-9%E-q-1GYkbCOiI"Եehqs#PS)u%(.Ibt'X_ {B1N3RkEINEpid6Q$VEi0&c*ri/95^Xs -?y!TZwE\"9dfFje B#!WJQҏîZxR/\}2g~rn ֵ01 m afO oy;s;GIǽb&4%lSi SS\FZp$Bʤ3Ge 7o>38W-ۯ_wh YynV+y)bNS e"֭oLaUKQ[g=R?&[Y7 mFWE:e&L bokX}_ɥK,[=!j_p>"̣7s;a}7|%'Ԥpy=yu?i3xIENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_090_exp.png000066400000000000000000000743531245535672000223130ustar00rootroot00000000000000PNG  IHDRL\ pHYs+ IDATx<ٯm[Zusvs=*0` (bE׼!/QHKI^VZ[iĖ LaU\֭{j朣/K[Z[{Oi1u${qj vE 3(h(DB@B1ZԈh79CXq]븛ݝDBZݾ,y)"IITE[ǵ4sDi+ ,ŵ0j/u+3ZRs wWsa\R})" ZAHc޻˶> ARU$"x3#m;"kN[sBB1;jȐk [[Ofuy3;N"BPycDTkd 4vrsi݀qBK)nz|xЫ֚]ͻZ͈ "r?a0 wE"3 &\.CέڴRJι۟IU̐Zc!Zaz{w<j7C#!Z(w)8~Ci' <_֫+UȽ|Yv{n]Nqa`^WSĻ;B$N|24$J)x!8ZBS>\֊|uSjH!Bwv$Fhffb&b!H QB B ׶DIlJєb7B5۶XWEj7Sp„@,)Sqtr3Zfwvna2jMViJ1yf:uѮ:"{/HuNh`\k%$pg"_.&!V², 莭)Ry%n$hYDVCHDDbJUU" ۔º[J]9D>/S@,νd1fpz <ږ`r=e.$aBGe>ny!8R{-@y^=q""!yj-AY R("2ј#$$'zqzij4 BݍBT)"mzsCU3laBH,( bfwwp'tDW7Eb!{WU$C !2sL ݽE񐑄Y3OarQ;"jZsB9{ri>RRӐ[kHO0t^yf@f<3ZbmYΗ,u^bܵ|זs6~mCD舂h"^ Omkw5"RnW 333nGRJdfkmޝ[O;^]t:͔{1byM͝ULA׵WmEt:ܝKL\k}[뺎i[}R˗/SC][·Z{ιp8t37g!9n8;vWTCڨNB8kpwzók3wk ނ@xp1F"ӣͻ#0yYݨva. ¶dޑQ!@岆0ߕbL9mA̜E8F)`$1PB #$/һ)]#U 6ˇ;;pZ݌9J6Meb쭫a+sډe^kQByqҙp 1{kuyڍ݉ Ԕr08"L$Dj1֪YGM*iwy^Z0d;b5 G#Ua':sߍ$@LioT+99:a۰X]љА"*mž2Myxzx /ǵ4>9B1e7q&q7yzz1oT5t UH$m2""pD4Ff^C4^ZvٵƯwww4LwB^?]lh"aCz#GRj/1$Ђnx8ڝrݗe1jZ9h8Mt3s)EUCZ[9t."bީad "4nt͗Km_K/?!V; "nnQ (]4Ęr9gC q}z??x]ׅ:vcL(FϿ}pxw]Bz L0Nq]d= @)nb)i ԵZiRu6' |\ܼzn#;,kA&Wor OOakmi=\NeOE+puZYDoo?P.kjnIXJ ) Ff^6V]Vjk;x:yO󗾲j+z"BPFtK3_x/sS(P9HD!ӲƐ 48,z:y̦j;Os8;ҽy(\%4IJϗP 0zi8t0߽zOz7\ Bzs#c90?c_!Yh31bܜ[s'b$DRZ[1aKi!<Ęb9Gug\z?ojX ACr^x)tC$;0~#9W@DD8|4˩j۩"jS(e5wf.e1nR ,ہj+j$1nLM "@$>OLL1Ɯs1 9!!N)<q1iSJYD M1@,H=NգC@$wt0`ܢ`P,`[_L Ӻ.˺ڗ)y32"vswvB1Nծa`iC,A[6UwTa(f T rpmBornkꪻ}`/@00FppRݿAHAUw5[o#[75I5wu 13ҺVtY 7~Zyt| =%˗7;`v;*@n='\M8R?9viLô<IiPru]Bav㸛o?! v InnC]613zkw}wwje |8L *nfY Uֵ@H)uf1""۾k"{ZW&kmfVZQ<zY>_ǹ>4CP!8%h@ McHa]ZL% 1#1J)fY&$+s-zm80N enCZm&̵{OQ8ˬW `1#@@D6w WDzj9ֆ(Dm'l֊x  %ll! w9IF[rwfnȱ5??C;uau;%]:9K>[zo9:O|9(Ļ,!1XQ( Hf. 9Bc4w)1D@ 8Gi xO_B@ q3\ :8Xޏ]i"y_/W^Z]zi%T|iu묽10_y]f"1r,眇y>31 aJiEd2"]ǜѷ]0hEs`@>q79)z7Usw C@A\1{IDr֜XACD{ZY)[j}OG|%ٜ򏗥Q~ 2sY[cJ S"1XK;.!‹/:" :LT˺~,˚R^̴hk702/~+D)޾{}u5vͱ{ba\)ֺS&)Dޑ: ͥ;jkMZgfFrz7'5#K4қv;52%tsuo) ߨBwmn +c?׮n~1 8Z420ݐW+*i|^ca]\ߐ\D$dU U͚wb-x>\b@Dd^QmMUuN@U[4eDHп]#@DED47pG7<:ߘ[rMa;B}Sck0x ,in^?AHN燧i HQk!hosޞ5HTU/-A7=n}k L E8 8^'0"#899zm1MpaDWky+o|}:\e9=_?[U{iYqHzx8vtJ)l=-a] Q9z9H6tY.]Zux{w[1r<󨽢iژ{3|V7v3XH,A"wfs3)HRRV]B(du-E0ɯ+[ ݜ)!:8U1fkٟ"tSx4i˺_ 㰬+#/Tu+" kr9#""Zb"Mc>=="#uL)0oxW.Q4uW[! g1r,z1p1nc"J"X#r$AVnsT܆cf=zٍ*ږG@@o40(96. !;8bAm_C(i>=J)/J)wƑi]ՃqO͋1u9=Mc2ǥi C7e9>՚nz{f*zbC>.qwh^8w6 " еw"(0:o|o)X%P1-s)yX0q,?% E}Yˢ4v` i !hm˗<-ȴ헹:E|^e)@=Zwؗ#:g >~~;" @0o֚.eS<BLlpL Dc51w#C& !:˿? ^8 )@y;u-JoMقtMG꧎ S-Ɓ9Nak-4iD*Lj-Vhc! WQj-"Kץ98W48uwhF1,n ̓9BL)D4p0wzj)`f!Uնat#!c(=ꊂܽB$"JDߑ,=P<܎/ Mٺa86Zز]Àh`(]Moǜw޿:N.L}?k!QaiM "o_ssC?%s ~}z$+Lsi?q1o=Gtw{z_va0$4ef zqS>wWkJo؝Ժ#nh+q<_ΈHDNq$a)a@|L1M3mu_}.X8 OH N+#;G&4G:ӧ R/>u_./%?t<~Ɲ|&K mmi,{ WWWmE ô?zZKp5r|1un)s0M4zS];pd"DF_ϛ۶5Ps@w "n1J!0!q ͱԦMMus?o )I{l=bx# p7Se~,C Wh=w9 Dq8g~Bv8Z CYݘ{"k)_#X lR~N0MnS\)BYJERJӜ1Cw7\ 79$)h@+նK `N~2>T狙ER_>9A~Ku"Qb hD~qjH}iUR[p.5rzX^ݥ%d:L\Ʒy__oVø{bǾ u~:gZ!\S=H-uG6D@ljW"Z]JXfx6@VeTCp$wGaY31bWK)0 [Zj3`:pk_گ֏?7>;\q4: ֬Hl86H<$ ;VՄ69@tF9-MJ+~.k^k7yYc+p~oѻgRU{!eY7W<O֫۫5uVvjq-s"y$TkW+18Wx*+8o($h86oݷ0Z{V#EhHEДRi|7?y*JBVع{搻E`plL!bBRc!lt[ML|)KvZWE̘4W㋛ͭ ~'o|P8+`Z,f wkDx*1L̋2/kj1>*iM/(0yKbhZk#8G D.5||5:rh*b/OhW=!@8"I$zD`H@"[D2S8]3gip wpuZi.EKZ[w>ps_ѧW?ݯ|\ arCetx}bʵ<ܽZjlmY@/đKYRb 1F"jXQ@jWk?/ilVfřhxon"f" -q1(˺^\aSfp! ̑:" _z}5ϗEUqYs_Es~ˋ>ۥn>yh XAH<>~wNc) >b]m|;|!b!zoq!n!"f,K)*[{SiyÏ\zd NH;= 29pmDQQ2!LL( " 53 fn[xSԝ"C#t;8/&wNj/T>~yoGy~x0J_޽tq1>PZD0^|5 )'C-S})0'bݺ 8s !Tˀ9?gN#.[w}teA #pͭL,6興 ylAw=@c a^J{MQq 1Z.bF(["u\qgBA<^`-,xr髇ga7ĩ>Cf~:}r<<{۷ù^. ""8‡~Mn9Gv t9:!?ywغڥV$e^1 ~?9rtJ;v %hݑcuĆA+:"~׿H'?"|/|ǐB"RlU=LJ8=DhֳY!ǐb !" c6뵖@aYzL?S#_˾[DnMR6(Ӱde@ @~G ؐaQ$l5%u]U]efD8}YkypȎA2Z߲Mm?UZS9nO}ȁJCp7]L}"ZUM7ð3UqclloaW7_<UXh wV6!w윱lw*q}ś~n˲^.seVBVrah"`N|ZvA9EhbDTM& ؊KN N(jq05C0ͣhf Ha`O,xDƀDȕvZY6< 9< xOām.s=ݾk Uz@) 1c'"H@*6!U2ʱ{r<t 5vz("c㈺s^a8$5Fj3UMH4Phl:`&{3 F(9F/ 1kTa@Bs>2K?י8@qK,{|C[2RRQU2@GjV%嬖|6,j>v ?'$\У)yDR=<_kzꛛ]4^w5pi&@LjF. NME c}tGR0eB3$@5Afc G95M};/ !8Bѹ 4.-˲lQ^ӂu(!U Ml] T1iUBSULkϯxe^T-061l0^ZՇH . Sd߷MpqNSu}AReYeVE6IUJj^Zqٙg,d֘ 3d4-!* h*˪Y !)0klf L! D#2jR K@*lN @J1ozo}yu&F갛U~8;w/ӿ˰t4P\9o~ɫƯZurDcv t:|w>-mh)Nphkˡ9,sҩϿ }KD#W~;ZM3t\M̹05~ YkqC PoXpݰвdI5A@l߶ٲ7}p<<wnv)-l\;MzdFZdQ ĊUFqN .76.kU.˚jEZK;R~x%>WB WcLTg/?AJncXiVC78}@s30"wՌP8q/. LuBj  j Fxg7BT@PSshNl;0{GMUAq\ʁ1mg k5݇ͅZ0ten\ETV)UjUk|SiYҶ͖sH]ӯK)k Д G!zZڶ#j_}&W5hyI'֫kq&F%T!8}!2{SY]!T\jQqcADpWȴ< T3!cB1DǀD e>A 2 m(W~m@DF͉hf!V"C`$K*THC(L Kvi ** #8Cc(` ͆2mF VçBM:WSLذqt/"ŽDUUG*mײ}>}쐺}B?\MRU@ZZū2^شMg5xww;)cʱ{~qE\ 314M77M76AME 6@VAu2)W0OH#82c 4v􀌠[Q<6'?ylDħUbP眵 tQxI9<{&t:y&-ZMY hHshڇkY*JkI#cծXZi9%fy?rQ:Os==w6nTmmٶi @LkݐPUf3A!WݺV) +-6٢d"(F@f- C5姚ӊ#5F ` TWˢӍƌXW%TUpfJc(y-T%fqۛE=.y,G> t. ꂈf/ >;Vv$tO띕DM2Slj>؂y63H6$ar0%)w x""VCЍE@OoOd'S@O!"ؒ`4dmbPtYvH P*J|9/ˢ:@) T'uM&|%[ֺ%2qa/<]c\L{V4Mm t=fϋ*KdépYDWh߾pæjFOyfFR"LF% 1\eIJhOLLE;?˫d |v@[j[ŅԶhjafoF2s=9PEUkUya+H.r HQA)Xhe_5@*ت5"EG$s]MffksR|iDEDk @aV Y-[}]W)~8\^9$rƸ af`t_ ƾڠՐHmPE23 aح6jK%/KbF7 mӄq?O~7:w!(=Gp֋3eȤZR]i)]ׁQ<^]0xOlv}5in1[aeSsW>)Du-xd@S5E `6Yo_ [ ) o+!K V159kΩ.ڶqJUeZuwx IDAT2@$DSu@*II4jڸ򺮡k8$ZjWTe 9J@j6.물\4m`>9#D@e+8D% i\Aɕ̞ >[}XϪotmN"BT0!0PiF;uVDQ`f5KNkJQ.mUq? "2k^Uv}ȵjy,KN`TBz M[WW|*DD)%O=!À[I /~w/޾O<ޟeۭ||۶wHދqLݓitm PM5mӔ5A[&p(Z@zdimWdjƆ, bV6fETJ`fhME!@a<{JVIN{q7 e:gC# n!kxRs1{0cOnܸ"yZhݼ|9{9rz UUƄFZ7fu^O#]#D&T@\-qs TkPpT3 64(f Jfζl6(TST+)AsuMk.@b˺ îȬjiYnn攖i>" QHP&f≆Ea?A Z\] EԬ˴iIe)E !CćCW:ȓzӼ!UO;_?^r >0/eCP˿<¤%MQbp,B34:/.xb &plU2^+$WHf"Id,øu:.%g':0 nG7leۦis5=>~C =p|u=\s Ǿ;/oɧjVUW0AhAB53s{ OL'`k϶yVq@ysΑk&^Ő6r~~믿ۺpoÊb 3icr\*Zj5dr5&91ۮ3&NET?<i:~8ŐD 1@J&?xS~v>t1u*! Y m}lY&KB1mZgl6!Ӧ(0Vdos+j%n2B2=pyyF{,?_k*Vz6|7f~8~suTaQ3)R 6M orP Wv" Q'м٭"l/{DVx ހ@{tfi̵T94Kh:1s1]/uM5'y ㊈sny Ic:]~x8$<<*_yMiYRVzh~w^H yz{on$"BW&2 T:UcRJ1jWE ?MVDk| %OgRԧV[#4J| +ڷ/!(1{ oe53>~nLEmML R><޾NR n>{ * "8&`f/_*i'9CpU 9̨Zo𯿼ޥ5c*p`Fi aZzpkk=V4I{Uکd׵^ !($P@%بb V[UT^Za@ B44!dP6xr)xL8K }CXޯ=?/*ơ b:{7(!HhlbEDLlh^]]!x\.KʵW?O\Lob݋P xye)IaJ%J)MӔagWW6; 5jN6 [E5j¼^fal?z$xJO/nD7P64V nNReSUg,dfA S H s~y)`˒a8 FGbaBr@}zj]k~x/㘦iZ+"kU }|/FTG<=gϭ2)jMSѮ n B@+-b;|z7_cTX[0֓ZkȆpK4DЉmF = ΀7sf"g/meZUR"Az:ݑDrcu9ZE2MbjHM:[Y IUq)9U)K`TQfuu6^\xc%W*F'J^}Ru ېh6lӺ·'_>/@,kC2>)m]i5"+UJ1dB(EiYv|&J˲TUFh.8ޑ"w93bBfb'"sTK%Ͳ,1yιwoޒ ӼNs]]޾C[Rf/n>ǮKqwn]_!w_C@H%j k9ZʲHdC4US+ض3]y7DzDi“W sc(XR6ªضfbbG?;}ӶbvYRii38&9"rhH,: U$y]{S5ݒr\rFyi֪@T_> ,!7&w=C*wKrA}J$R?4/VKvͶ v"䳗OB; r`HkzgÒT%I`X>QUсV 6ouBl,MRr߶kɡV >xVU4R3UdC!u]wk"Re^SMhrj(7΅u458S3o߹vbbcÙfhn?; \1輅ܳW ;5IK^v? :(YJ5ceJbC{Z<^\`PL ١S835,6/n=Ј'Ņs*POew>K9<~xf}׊sj,%/ҔHia&# Cx\R5Q "֢>|)8;Ϯ3ŹnQLR^WW}١c|:g8Z `34@&؄xC0MpUSU Y4/x%tn\&Ei7><- Wq\LKbRRr9<C|l/6]ٺ>:YG[@3J/^41]_^G5ݗ_?~[fޑ'Kk@ ؙQv H̦03mqZ\<_ߘ?"z!h?t`lf-T!Gv?q$hDs" 0pOm LjQ* J ," bKΧisQtCjqUeYy1tk/>~׾Nryk sqMw_^ "u8-ieR^xhQu/aVM fv.3Rn]7/v5c|hAuh5"!?3ATI!~wG9bj$6˴,ΓC(Ƥ'H9PKڢ/O%rιRJ%eJE9&МV *`hRS`TySq9BĔk{p$ Dz6WT3`BMwݿw>&WOy˷&jy>e)Z >m+[ s|p\*16eqH;G.fػ&}B?7B{Qib (F '?=|y*-b4 ?ÀVLմ8݁SR 5M5:6EL 2_}b"Sw06!c]Bd041W%/P.zY MkZ39}Vr4S ѧ޼x~'~Kfnm=1SPy\,&D\p.TaIi[~C ǰoPOٳf.D=2ׂ4QDjQTJB^Ԉ Eګ}^rMvT??,WTgXto|\-GZZ.%U2Zm^_Z08O9g&Y C&D@5=3sΩraO]q>48]6~ק4綿=ū>z:O-5u~N5D.)ȩO}R"朇U]H5bJ@xηMgovPMcĈHRVxa7>~o~gX RՓ(i |T1"8R!ŸvqVbr4ijGez G3-VM"5OiN0FIuYAкwMt޷f^u){o߼g;>N,yK))-D4,;3I˔t΁pةVEԂ ;ͩaQ՜16(lw[:e;@B!&Z2& Dې8/ 7mç}o_|UߟhK#H .\v";^NԶs.eN<)EIˌΒ#b6` EX3J{wlw7p>|>47W{2M"q|ڍI_\kM!|J"s"mIi$-U0OoH$˲\/ϸ:u\okޖ/o!ð&Z.p~ 1lؙC 㐸WC|3ŷo7ޏnCBt'O2/N}%G-#|x*󼻻aspJ r/<2S:XX͙`twQÉ11"8~YH[Wwa$<0Ch٧]k \L`w wvQZ/w_s??G[>:X˃8ÃQ~T"?s.8(P{-'^s j폯ג%3޽z ,x_|y&). %~nݩ*" ~d>ıuk1Fdn`OWUs\~j4qMG]Kbc`S ZM%r'` nHe2)m[s4{}%W8?'siW_w!xӡK+́S\ʚoF^W??/=u^$a7˺XZj>)N\bښ`4_ ;_}b-7lc"oe5raB1*JkEsGFrH% @ X@Hq}Z!1l+][*$`+K+!D˒DDCf!>;Os`Xko;Y~W=Pk=}9>}|]ҏ7x< AE*Z$6 ,!Ām]\[_ŇaveF4LlB(P00 M{i[@B,JZlJ[á3uI) ;8 9jjB^^Y{KCua""J)-BDd$Z%uE_s6ZKft}zyן~{wJlxp_zA tjy~}?xn\Unqv.y-՝&5u<\{S?驴 c Xv$U{µH&;8˧\ё\nj e%INܐȈ(EA-j f ZZ H j͌Dp'q98RdܚYm(nl&SOҕ~<%wwf 5q ݾ̷3ؼCﵵLHxoᵶR\kݏpXueω֒YVU̶3;cR:vyaaJCoZIA*La<]QS 2 `DU"ж-RrˮNfHz%l)qC[VQB`0`h%ش!b 1nMʦZ~cKϽn&H&:~0\[[|z\^N///h M׶ۏӘ^y|x ,bLZ ϗƄ`[3D"c<֏q7N`w)b#GR ='  B $@A"rȌ1R H̹_"E$HL(A`흈ݴGHj1B=笀ARu].#oׇ_U90#b R~Q~w/o۴s]\.!33/ryyN)#\3眑nYonD$ڻgwD!힟.G)1J^*$, o'僛fx[Rֺ({! CtG"20DLS" GIp-jBv-Dd[kqHdh:o:Gk `bwco1FrеŭtP3nt_iyIDATw)S7ߌzF }Y4 CkmʚݝΗf: 8 Zy'څcDBBA :c+%qǵTwLi|Zj7go2Aw]@P |[*)ziE̼yHqy Ys\Fͨ"rҤMT7J$:Q %"q 9RC@ćiWV` ۚAvΏu|< ]@J㛇D{ϵu^0 0M˲4mQqw˜iJ)oŴ弈ךq2 ZP$ȲU$ʻUcWxTK~D~%ESL>i @Uлޅٻ;(umNBPu@fKnE$躖UD;:T*m7t}%wA Xq"W4C! ƕ _.B`y-|y_o;q~oOKWi]/Z[oE_nUB$ t@JqP+w½f&'qx춃1q@;EĔջRhDHB:!.{W0apۍX`Av+vBpwPLih34-hFhZc@!:ea-W@j*-_8~x\i:LPсFf$0$6Lq,k͌f GC?g%t\n䇇Szx:By nۼ!-眻֊ ^6@iJD!PEdy[7?Yv!np՚ xkF{`FD$ zP$""XrN1FEnq:x.MDR':DLDK)2oJ=eͲ+Q PbWp} g]^^ݫӭ|/xx:߼&< Zy!PD9k_~zzNCHx^+~_a" 8RDH[7l2l-_0  zdNVkR3"G$Rr\ݝ>qEM"eͻ{k6EbkmZkMBn4C)ݠ#jB͑b>v$`7!`Hߢѿ+ 2/O=| tӴ;}ҚF_/5n7fFow'?" 8يUi/Hb41 eC80&D Cc=FqG5#\0{/ZaBdGr!M2bw>~sM jq5R) q c͹s;! {:|kmǻrI)REn]AZ+uSu>Y*z#׎z+-WΗ^|>yC-$@܀VC<d+{#pCBpqQDRHZSU[ w'8Y$ 5l d= U9sH0Z ㎇f#AI~7~B{`N򒥙Z#5uw60f \WwÀ!hif} LreYzk,AuǔP=NAO)!;7{<< 2x:1nFȡBcXh8b[GD3cZ !HSD]USJZABP0F}An,Vﰜ^ ;̱c%tƿ?  x.\?(KDY })E[i'ьNOIsέ"r^^=m)áwӴ 3F'e V_ڋ<wћCspfq*jm3bf )[ 82 ے`N5DX{#7anKLp]zM l#V汯 ‘Ϛ*;,E۫8Xy﮹?~~f9~[u{XfVcqke56Hp<ǏACjf ?lWr?USYWD,"c}: 涺Ձ,լݫ"zcl\Zt%$0 Z㎉Vps!pn1\z1YxCDDvi1||xzP#1 = u )jEp076^jyx`~och":RA֗[QvciNDju@\ jzc@<CDTd]Qn]r]kYuKqq)aj΋vi׬4[kZ76/ 眉ښJ7\oQx+X5 U[1>•=<q4=<iw뺬%X08q¯:kbj; ?Gg4x~yrzAq \WppcZ_n̛y ݡD0&&ZzbV뺮53^onCB"4S05D'ZY{WW>S <BȰWqaHs [j̬yVZc8Yd "^a~*q(0bn9X[Ya )?D9??|&hmu}y>~|[;Yr~˯y~fUֶz B Xk7G"9]a.lAeɌI|Ι(!'+J$inFs]g3 [qo4 j[ 3 C 5g 0#aJɬ#"Pk}&b&alư%S )ի'{#\b9ُy88V|48Ð@t9r {a !3 pԇȺ"˶WV9^겮ۥ\rh5ݵRr.VWw$u)Э#`r2G5qv7޿G1]ک+2_Ns9xwqC{RJ]-/@KV꺂uBPm{!%}3 2sJI1I(H⯵k& q.k5jryub|9_g9¯?RqwM"k,."Zd e-9^qh+1 o<4 4uw$fFȢf͇a0kJ|+wΑ iB숥iKdf+9| !.NU{Jig 7@[!p"L䝈]z6yGշ6] 19SlKAdԛ}> x-C5Vq("iZ:Q3_{F8D"-/H!_9n38͔;p*zΡ*Ks.!\DpGvCRj^qȔR4d.]HNDR ګu]3AP V&~{` @Ea=ކİΰzlEXcfǁ@ Ѷ0*Y*B7{3 VV[)6O @)Y"8 aG1I-ƨV)fu;23s-#x|~$EXvn3<˻wJq/?{Bw@ rl~^lPZ QPU638YL.;qX)DC5[(." Fh9!4@„,zR[g"iH0zF"j굔qPzu1c~8:Z~ϥ u 3c`83odRxv;֚߮oȲٺZ/5eH[D[qd@$pW 1 ^r6F q ek5!a5" lH{?Mg4B "_wG`U;V{;20zֺC43Bjak$LˆHDHD!͗h=֖7iDBHH/V2mr;aa]~_k^C IUkw3#w-y!uג\j|N D7eq._{zcm ywb"rw4!f1 D@(ZQ" 9' bDN˒BL4M}0088ZkĒ6z/6a// t> < }!WoTj]MaS$ފ-"b1#VAF ąYV4H)9"v襦ȨFAph%IENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_105_exp.png000066400000000000000000001043021245535672000222740ustar00rootroot00000000000000PNG  IHDR pHYs+ IDATximiZ{wX;[] HbG6i88pHI(qd)dE!(DcY6Qpcc9A 2tCQծ;az'un6D@Cnܵz3g `??997yv֍+<|*WNmQe:yGn^O>ǟE:{HrGnc7xoa>Dhhuwt7+/߼^r}|xkpo%(A)MU\9R0\82!DQpfJ( Áej{.mFy><-7-Tc'jMxUJt!Ps8'>r8jd,WDuԁ(>DR^03 A*spQ[|~'8!x>|k>4~gYN9Fw=}BaDJa^fJ^7'?1{ WRJi;BG#<<3|)%%y"zϸ݀e@yQTR2#gcgJt1|@oR \+1T,(&ki#SJ9D9R16-.xld \dԲu=T tzOʀnF>̓|Cu_[?AwRIpsv~Ɯh$?]p^I˞l28u]ߵ3N0 T M)!J*-c'T9gJIjywLiBJF3/e -tr4zr* ]ˀop[s=ǿ9_ͷ~WT!ypJ݁\ !DHuJN8X]yHwV*%grZ88CLf 'F C@-2τc!"Bʅ X`j}ZP+,Kfْ1ݎ!_ dSUҒ 8UUJ{^Ye+6>S||x~?G|;<'rk_Q $}C J(ĝN B~Pkuv{DZqN#R+!^Ku !Pri,(; M"%Q FūRk~[t >R[ tQS! {2apª6ywW%<,2 fb*K*u:B،C+Wr%YaxJ^fqV8PRj}"ͪ(JQ^cfFΙ,p7+FəjmyHsƌas%*lF'ũp"+ JJa Q !~ǕMD?  "CvtÿDgYdw`Y]cDw8T*]j[y; u-pJi6ClBҲT oPRj}YVYJ*\!ƈZa^: &4sTA\&j G,c*  Rª(x߾T"gӻv_Gܕ Wܺy?HR+*r8eG6-2Qr&Ħr\\3 G 9Ϡ*dtD0 =S&OÈ}DD84>QJaIK"\ԒYEՃpG)\ %7CXdF p∝>&TD AaJJ5]"_tQc} {$NF~*ߺn'qM.tM*0/K+[a(}p^Pqx]Lׄ4ὣzہeIkFͤe\+*8 ʞx ľzrX)!J<@ת`) " N;k|R1Ṙ>ChdI2O k2$uYi08-~G@CB=>pgGD[yQjaϘUaD@ʙnaMGb[Z)*Xs+c"mZtRQXe?;jlP⼒SjexiFLjG3X+aN~߾LZ KJL}f"@ &a2T0 eb( \LfqJU\=ynoꙵ ekYG ,5jl=W;V~A#C=4kJ  T W0B)2}?HUkPsG-NXJוKJJk2#9bw@.!D0#- 4 qNIYi 5"D} V=%k94 ܱ ɠr4[v=vFD0=ӴSb8¹uKѓrfɕ]߯﵂4ʨb4m7e!֛z!PKfI }J dMb8CڴFmז+}dwG YJ W:e`Vf54%yz/缘6cv\\=@xB]WOQjY9sB\:O"&Rʤ NR :w=`HmO*a9L~QjSpqgw65).2~.P<Ԑ!îMΓY }as|SJEh8 U45F x"Ox櫟=lH CAt}*S%^9; 8>0AUdi^%WKPDXr"/y-Y=i)k}Y_KS^K2cݖy6j\zD~//ǤlWi Cw>7oóZA~/.02M7%b"4ikæA޷?Rޭ  8 Jau'R@gR ]ST@:/c]*{|)7|'lr `4*:#aء#׊#I6|LYN\!=hKdjx8:L=9Ji+a=Ia /Jsxǒ*f&ib4j?P0<1E 'RZ]1-tѓ A*B# ,w<?,['$PZ?!#YI[ߵ.jc RY8 Mx߰8 VbsvKPgy9\E@+& (~˯_yO6ѩb2ՄI\M̘KeYRRW-Қ:1W U41/GˡM957\RSSmXYj%믿N"{7,)dȋ0-4-̇={WN752jX0W^ˋ8O}1q+! fXӮ4U*m*!Ү#R@mvkEGI!6 kSBi, ЪdU Ng;=VY.iSbfe`^7xg z:nf8up82.FRIˌ)5ܪRQ"}:؄w!&9ѯ&gi(-ߊzeI'0;T eIe*VLyZ/[ ¤̜2K:)'ǫc:o AWfD"C!F4/ Æ9VHr;2w@hh=P0ZbBY2F7U(}&w,d8O}M%!޵ y],[w[JnjUY74խ4Cp4")7Zs75s*PCOœ2uʤ_"Յ uZ|Y3kkGq/_{T?أ%#PȲLxˁ̤pvzUVijSDZSf~miVXeNbeyiA=!Jf^y"soܾhksrgx"ZhZZ S̩B䴴>Yڮ툨Ş*=M~^dwߑ '4(FX\.OXKc֤VO|w=IX~Ѡ("L1v16qP1ɔRZHgJ6'W!q8`bDJܼΛwߙJ_OwJ,L^KJ*/WV5u8jaI`H"}ߡ5^ 8 U?e伐a筷zƁf.rM XL(E爡4RJe3xԀ}u\IL g;e7;k_}g+\ja&ίGE <@o?nZa:iߢ*Ң/يKơZ#']soȭ.%%#A s8>OL +sت c_!%RZp],X mx辴8Pj8/a#ԯzeRT 1] -zDJ&*8?PoKUX*DGtgt] 0kC;lI8[6E1 meծ Uc?IňvsB3usjm;޺#3NJ]P "\rw榀:疁j ]'*6@w;U R\.ԑ2HɪJ^ǎ.&Bߣ=3O?vU+kƲtڤل%gT; _!#bdV ICGÍklx6sbP͗@c!ոԀ]*km'r3Ƨ~|ܺE6pm߮pBSdk[B{>h*妍]nMY}cL9WiZewqR[/fF󟧚ٌ틮@ `j MK #{>)T|hĶ 8Փ&ιE[?BKl 㬰&9Urn R] m u\j D 1.t43}u{@q_9L&m]ԺOVSRN]{qt yiVl^f;8:|jU"`l]s,QZ$?י8~)N [7IF̶oT+~7 Sa.ad=VB93cIL>t5'23xs/rVJMxR)D4wo]@EQeɪnFT =Q%wm#BklޭhK5jM8Boɿ<>ѵ(U؝'Ğ h*fd{)Z:ɡrHWpDPR`u;i[,/Jy7^obNUy84e<(]av@f.3!tmߐ'Ԛb&B}y]{ʣt3/ov0Է ̵ =2R t k;[kFV8#ZVJAMkYjaNga#%pyҠO[t:]1?~Wb.L=} ]GtsaГG)?g:\|J}٦`0k_6+FtaeSR ] /w5wժjH95:&f@VC\ji uEE Js}FkMF<&mW汛 ΌrA>4'EKrk &-Z0dNX/r؞\a>}/ɴ?LMqWIo]d=yb_8?wmTVU ޯUjP`Ś<=rmAwVڴW 躮氦"ZA}Ve^fB5un/VfJ0mf ){\h=m"oZR@ d*)٘*02n:v=g uĜе dơlMS r_5@Ts(H%cH;jiJԖ8ʘRtgܳyS91Bűp 7nĭx{q)7_ wns8` EL=Ӂ>eK#Ҟ8scӜg rn3<ijpgɭWmw= .*ٗzO7tHnA]XtYmqGMNtGi;r1Ӿ 0s˭ GGtbĀ+}!v̍kd1uab.svqʋ|׈p\j ,^;*LNY֦].Lٽ]OrE*Q '09FIF1 N fe:6V ' ]Q*X K{fQ& &rX*U,v,6T1 rCvӏ=B+qekdu|2W69N8W%#_'UP9vQqlc6F:ex{_۲7末ioSb'K.e1,(@( F$Hbc<$p? v`Hp,9CJbQd*V4Ykna}NYE՜[c9\bsz[BqMZoEΎQ("M8Nm=[ϔyE>xulKw`^R!Tq[?| U 5*,j6V j@^z$|K%Så124_ՋRT*RNH]cv>L>Cp m`wCԒ 臁Pf48 ee{g9.;᷷O.i"Hu0l0Gj8ݶd:noQ)FltL0xbT:&͑& &~E͙-4Qq6W (RdIF|O{W/@y0if#UYbnDX<Λ΅Bi2-Ǝ,:mT-o7~K蟲nm3iQ;I-UV gkN9; OaakBpq~v3r fЫ_;GN}m}˲'VdCgţjSj7]IHʉcж) pNC@\ˤg$M|kw Rzwgνp]I =MpXlȡ% 96&82#ͺǷ-4ł3w yx, f3kqBe*GoJ5[Z/;cpT dqxtax'^J%LdaϱN&ׂ+PI*ge]C/8 2[+3Ϧ{H3q,93,\װ#ڡXCM#~k%3dƫP D j`R8q%S\6ہu#vZPbpL8c!#Z/. kHKl^H\JJɨiɚij\FV7ag#(C,ȉ)~CRd>'yM k/7 :O%RcʙP\M5mx3,0x _Lf@FFAe't݆8fVE\AW?XS#5p֖ s13 dRg\r{;WATH HQ /ƑǫZp`X/9& %9 aWfQ%t{pws66.-C#&)qՑQV'ZAZO EiǩR1Ovke3;VB.zBxiM!%/r);Vjζg6YHs-8EqխL&pIJSkd=,Ȱ9'\3;}h慲n^Fk.2=1"W-*寲?&^p[}J-ZF~Gg+r1Kq79~۔_DZ^'˗I(Euf'Uenخyyݫ8VAPI"gR|EL*}[s.n?f{#ŃDfN1r<iqj?'gi2l4rѯD#~f  mBѕ;~ H~ }9_(gN4si%1Ղϕ6T4?"Nu%*)341+ -)g|rW:|l#'k%']mkR)J!S -y t&f:uZ wPQTN5I7*JSUdV^xK ͆G#6\7Ȱp=5/`%ڒ}Q䲐洀r#Á $ÝM-sjLuké',q+uHNF3{g?4li{o;=rULCK1XHq/8kY k̅zO*6Gf=OZ1FTXx[oc͊wv],|sD`ٗD3)(:' )1펜4!%9vWgF=c*g88'4|xP 8Od"XQa4"oүW$>* ewmqmD~L:tc?Mfz4:5ӯZ4QɀY8^ևAtӶrsaX]wh-Ͼ/\]^tUZ D e* 㷞[޳ʀl40FL֬F`OY}*ΒNx8*tZ9NyX`6hXl'gę'6]zGgk%ߧC@(L f@>ƙЯ A'/K:%..8y$l4zMAEg4)w3$<ٍmE En/PO/on4 FZ #wx| ˠdZlďř?Y"j(UO'3fqWv%pY^".xZC}sqIƉ>"%qݴ43+H<ЮPH&0ʜgIu\" y#!! ]:d>Ef gRIq$zsȫO[vvе5=7&ɲ 'j) JӵТK;R͑ő1+6eBi}qIq-1"g>:,?q_o|.MgxW*1bzݗ<;{]UI""մdIʊ*SyWx,/;?sO̓ZH8pW+uxڣEbۛ' 'v۔Ř#iD卛Q)OA()&rʤd9[oazad?̤yLm;q9SkXj*1ERd9lQI)\;x|wt]ж; ϏG^35m@0e{ncT~o@}?D "jո$E y IDATޡy^MCYRkAT\Y9~kdc N1`QNIaRJȋ!HCZ }ׁ@9RF iri$M7Ǚ2'\Vֿ5]C]%mC%,/pk.n{(p\~ޜ^Svhyp@%&ф 'LmvT ~b 4*nQ+=y;; 9Cv軞6xSJA]@G+%)"O֬^irT)?7f3)'l"-a@joF4r=(t8P[SY&t Պ gV@E UWSEDʫS\ckXe]vجxtu9Wkgp}}+g{_dLE)T8s8]sY9UT)wLLJh@̬xsdc#3g*yR::Ǹb~69^7h4) =lv-|YOr>3r{M)VY'm VSe8QZ#\ 4UiR?0,S\}Ȃ IaKu<;_0 5uuf;# m"(C.Ιu:OMxd!lC1}Ќųj"ݾm^Dڶ%Sn_fW11<80Mbi2ͲGuK\/{ ]m}>=Ey15]D<փחɹ%XNC"8*Q󧏜]_r:OGw}U+V-3M/x'R(qkU0Fքհ%vCaJ(vkt*/ޢKĜR q8O)sdhͪ!gƜlfq?/܎yLԚn{BkFwL'gJ϶J#q&{8oC ΢%HQ.œG;2惴4N)O ZZU.Ԣ&zl P݂捭 ATq|R(<@yu݋69sYm3po,ȶmù9+[^w}aT47%t-%D%N._✫Ǝ$≹w]o*9Y"q=/nw;s'es.k/V-T+wS4W7[y}`N*^^Ю64mz7S9%`@!V󹽽; մkVS'g7/FlDi_Hvv9U0NT7z4sُܽ>ȉn 3mĖ)R-{=/=8jEۆfum˪pRhY #54Zx|AZQ#43)$Ι&4qa `F&9Gh|%gX J-ֻu1~k:]d(kļZyS,bވ <3+ x"i[~?6b,ԉ)&v4aխQ$"Ql h!s !48%h) PMƳRe{#3)CfhpN/ qwbXo\\ゝ SnE!qwki5ia!8" mhcBBz4w=@NJ-Z " TexU2V9: |H%a\0VV6khUY2 v잩|}̼PO)vTKɹRMzj3)fn`VL3Md맾nF]RP!h=KW֫7=U+.s~vA44<}tEJ }xŚG+O¾:ngbC%7%4@wl/Wt[bcMn09ؠ$q垐mXj%9?O*kc=7H%Ǘ{J'T#BQKYiѫžpB]frVQQ.fSr2BsE0" dܭ$จwe}}Nwԁpbr)b&0Ua#Lh2F1Z-t5.q2K.q&55eqgsTZ0ZfKAqf7q'Z)1PFdx|mZzQ٩WmfY<rZ-FiW +7+^ܼDPb2p60=G~'_=Հ@):"6rXwB8x0WNJ峚hiHlF8Vj.+Q໾cuzj.:J-E>ɛL1qn`9eB_J#͙D- 4M!7eHu88bȮsvvF׵L8qmg3/nyb]VǑͻ.\ղPN耕(N-y%F>jYE|k|Ƿt_. xH1Rr˃*JR%UTH5[ǯ39JR R[lf)tW*FXIa;V}Gxtd?;L" ~ e7Un'?_^Z{:Q;&d1(۵g߰;Nf%;O &e*N ݊DReZbQ}ðBKp~nw 5(>f%c'k''ɻ.咝zM"J,bJɔj)&s0gbV#R"DNce<75?볆zf?p(g4 х@ʶ1)fд8@2bX܏~?4nګ3׿U -X=z!-k׸Mfxsh<20X/XOuR <:٫??A+s)s*e-`۶<ͺl5s|֊T+,90uy*(A.ڒʡfV1xXXi9&gW]a҆fb L<%\͇ ܳSfʙCJ̵2D,12#܏iƘ Q3$mzt'c.\]1qu)4-6e5@tZ^ϼ=7{G6+z>o-Kdx ,c%{rkFkXOUkˆ9kREٕL+~<[۟6|U)3g|ۑ ozᵷ.9;왦=ID+ж ώqu ȱ`RnIdjR SDLC۞GOf4Rx)W\*Z(~Tvd3Z Sc͍I\I㈔}Iz˧A[])Rԑ3 >RdrB~ʿ-o+?iY;l˛pjN&ഢ'=馺ʷd֑xu-QE͒9 U uʹ=pW笶o{x~ɪ뾧 eC_%3\XzBp4mc%ɉj1!fʶhB goyY9 cfqaL ,o~/~'xt}ɣ UC?Vk>~ē V!ps{ǜ+Vm֛mCKJmz FU,JqC ǫ)qr51k]DnO QKSbĢlq_rMZN72[t CՉגfñ*n$UxZVBQ"SU9My@yP+8RxM߱]tsy48<ɇ`* V~SI)SI*(w7{G^c?Fr獷?/ϱ^EnVM8yr}?%5B!,qEUp|HAm J2\̢Fx~DT4Dq' -"GQ]ݓM%|J'>_|wڼH28{A|;/|wLt9VH"TQ ?xOIV<5gǙmv-M0$4 !U[}JWZ~}^)sNR9gn#91B\%_Oqw'NZ*J\]sbJ:OtBIyXd/1R@{ S5S5㴂,̛OY&ȑ W_LHjέJ@BIA"\i;L;e?b\m(>MN b1.Hg,M  Px\`b4l6:6M`Xlv)gr-R1ۍ7#sJab ^2f:i~_Y>v&RJ'r&rJ&Dа??EU! TVrQR*te)Stʶ} :p,RxtsgKY‍3f,59ڇkC%(U o?v+G]"vt$]>ͪr*o%_cR+`ȥp؃[фVR0D`\Y\.b12ɾa,5~VZ/^]q|x50Ḥ'DƤs&g\lg^qtkJ9| 5Ldk:Q%"!0~&#M0O3kX"6+vr$. ~ f`Ul%*J%󵚸$nKQJ&Q?.z1_jQ>x۳5۳39s6SRf*<*LBN#uRrRrdڍ!̣7??EZW)"Y0LHg./mıHX&]i9<}rɫ[J.c[h@MG6CC,@"gP #Fj5kMK(WW?|<>_]~$c2q1L>Կzžl #VE\a sz.Z*Z E ʦ )T(qL3o醞y6e׶ }K4Z 3CA-"h1ge,IgxG:f}45۴iXn ,b0 IDATAmYj_ vGR,h_T(;ocR2Wh1U>^"v0=a"o{bdV'aʞW{ <~tK/8[e#AB~w෾?F>'#ܻķ{|xi}f^zg-PdyÑ%R<ǖD@A{g{vM{sh#OlOZp-^5Pxow8qٶ4jRmCVUhc:;CGMyO1R/^ޠzb+Rꕩƣ'y1)uYW=j8fȉ;>Gau?􏬏OL0~W#N>M"tÈUG:Α(hQkQO*!,58Hr89WZ݁sϒiJ6|L#b)Ǚcg9O׼mbzJJZx~' k~ZoHQA.FqKjl) sw[BΑ&fl1pPkYZンsꜪL3`F@d1(K"#84`Q\(hHQ#:pfLwWչ]W?<뜞5UJStW׻e99ܱ%oL[`.6,2r(4Lݞ2iXXXkN//н'LYo6n/RQ $ɯ_gn~x1F@SrT^)71NY4(bٳkRIߔƴnD]y,KiiL2N%h 0Eb)+&ji@iΡbZV5NՒ_E[/fK?4z a"r@!Q;w{n 9jB)ZJix\ h1;r9Orx83Vٍg-ӈIU*^Z6+yp8߳4rl&v?j `Eycsk6%3(%;ZiOJSzi*ץѼ,?o=hBŁTZUTO;I3"T4;̇^z@5 cMXG)Pp5[ 2N)z}|ӯj{J8 jyy_uZu,U;!;82x~dF_Xۮ_PVe*\:a>%!F,cPjS+C tbuګ_>R62 u7B6% SQcJ]U;ES*DU rg)k˕BE"Et.CU9ӵ8\ۉ{9lǙX5իzǼMs.Y+H=bkyo浐EO/Ωb"L!tF HrX+)΋y'Jh+&Z(sF:V-/(b>sz1ۋ rtB+lAW~g?RCQJ%_`.g.*=&'7kinR4W d*ޜ'^ToC m>4*ȺE뎍|f8Ԃa*AP"h.d\sBecO<7!.ɻ Dł2deû婷~6G''}GjSi»;<11$Rt 1F$r.fp@<̜ҜP+'HЃyz 22LQqpE׌kM-L+s2otWe'??}:U_y;Y2}b@/L^@+aQ=c5CؕGմ$u4cت#eXҼT2U1J!JVܷQ=>ᚧN99\:VAKy-so<P !F1?8i?bBj!D)2J)S~5g )I2"9%22OB!:H.t2|K5S 08Ko,}nW)@AhHO#qptFIhfg$O_?=L=WvWj^IgAQ4^.36Hj2SkHO $yO% EpdW,@,cx+<\r=KݓC l>Uʄ*asHÒoq'lp}_w$(%X$/3 5I[uxI!sb88BfwCCEL9!4Q"SRS k'65xkӌNUR9JfnHD 3T frZ>~*;W}I-7R w)3ё(IZ>#w_ԵD(C.X^!tQV$ #-ghƒʅUń`Rw<&Opp<~r+sf3~LF8bf 3Wr.s^8J΂A0ϒ: 1qBJU{r%3E ;21qR0~FZh&(DZ4"1r] W1X[_&d.;J 0Ρa<8p?~?o} F[s1((Ҙd~)1T+i$pWtE&fHJ۟kgXՖl'-]ҔRyLsNOzܿǽ/^?4oq;h؏;&ASsDish~AdMQklGNq%E~B)Ӗ&MjDH #9q$m ~CnDxorULQCoiր U 1]3)&v=)tcO_rJwb#'cK̽9fPw{\D`=S(HCJ$nU/jr]-{ae-[;|igB͙U..yƋ=)e+wx1m/()M'@Uk`-qQƁ2̱PFJXSkBU䜖LGUy$3D {ȑN\+!ŀQoFctOF 7jG*@y W xK<9 +UmOEf{U x/" %( n`yx|H5VpS.*X(Z1iIp˞Ǎ$^8Ń*9̍#s=<~uVS๻s11"[wJeAԗ w$˵/kyGR.T9=H|d{yiNX ЕBiڄ‘[o:+M3Ų,67#QFa mKn %%R,h-#Z+F[BqYrd-K7n0n8&} h%7JɁ„*Z"$cEL r(yK #ȃo'x͟O;jBA?|y%0t sQS 9jnJ|ab^5ZK-ile?zjaZYUdٍ#{r1ei$ذlw~WZb)!DRTFwȕH+ݚ’gT)Vt'wKk+ J_k*0rL%3;6_|w8YDdhdH۠X, %a=BitQ"1F}9n>=rMɁ'RQe's2C R9q6^2895eb1FE G*QXJA׹kQQ 5)'yZFMP5B +ffM7Y$1&i,gA:ށyʕ~vx0"S mEۗ+U%L5Z9,&~''O<>yLL̻+Β!L#qydgBTC`g@Z7%'ZʎXE`Mɑ' X iq(y]*x%WX^K9CFEpԪ0~\&BHL1p8y\ƿk24Uʵ*Jn7RLeX-McJԔX Jo_u94Гsa¬& wƶdd v "Ŗ~Y"y>C*L4{3_g'^,O>\#SJXͮ ;2`3%6Pr{I\eFL92ϑ$]+*0i9qqq6JhUJ&Ia rmLKJeέGY,υ0|J1~۾P"c#c@@I|R)0DJ>&X`F+|_-R9!̑#}s $>Rc@KTe-Z3JCN !K*`Uԣ /V{W P%^͢2hӸR9׾9>MY22sq 3GqxU.giE.#4݃g,nr˸ݱZ[#P\$O)JR$+QJvU$Iԑ)HE-ILNJ ozPEpqj 9F=W] b22W.F1-)F9pD6,q48fs8e1&S$(l ICablӖyѓ{OW kUh3ZEDn)f|@q1URIvN솻yH0qm|ksxxF&aƙ^r-VF"Olk1 D;'RIMn(!qϥa3(wL%-_s<+RcѪ1]8s!Xpl(.)ͤPZc'RǑu uB<j≸ s+1^W$ΩI ]A.@c1IO0@.?, 4A)R9[ {1lVV+B%W[V)5",#@IE̱@ΉD4$Rt/giF)a(*A7|C+8tSG#咜!BIJ}VL ְ^zwNz])S$JI9Jބ5, ic(0Ovtf~$L30+կDQ39J$1#V5V8N$mSdy?}Uܻ_ۉQ,7t]O2ӺQiN^h?WUcqTQpV 8&KgfI!CZ-ZyOX\oC|># .h=*҄RO{B,,V$e[X.HGJaf)o-)LsD[p8 LL J0i$L8'PYFl)l(6ODW}_Z7̫ *y_@*ͦ9"ւsgQ5h#Ӯc_2 n$Q P7BI)12w8+_jsiړ8:|4癚5GrIG$GYֆjWzOJcDF+pLe&qsU4eJ ;q,&䌧5*l, ~QlSƫ"4t#w,VK4NXv00v{In_0凌1ZC*)Y<($ifQX"I_к3".Qxr %Sj"g Id q܁ <]m͆rZkf9`^uG\&L,͒a]Sfuc՚;7or1iFql+r󐊒WsaXEA3#q@UhIjb jr<2ZCK1H9U=UZp5.7Rp`6 i Ga{YtW7nPzTkver`*n0uK%GZ 7oRS¨B1O0ꎏ΁/{d3X#iF+БSh\juR,_05YQ7#4g~{'gp9Ras"~CjQPAy;hSjIRq2JK~ӯb )qy1rppzqrnes1L}_x'p=+%R!Dra-9qqC) 1g|wzi&*U;L-dlV3WWJ)J+v'z։X_G==ey&Q&c'?oz5^9*JdJ0`ggiO j'Y6g8;OU,ċίKzy}߻FEIp XWt\ZȵMcTs5\}i}-e|l*c;N ZU:hZ}d{ؾ}|ˡczq>˾=ԣX,hckhe4!%9a0xX/}8zTxYWbjz6 k:el{Ԩ2Yh.G!%wi?aYG1(p,Qnɇ~8~I̓w;8o0Э#?7.̒PZ fM6{ͣq?~p iĔɵۿoG}j}'ES&3c-~ϧ7_)Z\rIENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_120_exp.png000066400000000000000000001100431245535672000222700ustar00rootroot00000000000000PNG  IHDR)D@ pHYs+ IDATxyeu[{<ޫݜDC؜IIMj L !E%ERp8ACFİ$#+,QD$졺7{ϰ^;[%g5&khUu9묽Tnxp;tqn%ҸOMV_- w/v\׼vގg\xĻ&28kpGxkYLCT 9Z"8k0"Ԫ\Zbϒℂc }/ ~uD3MXQ:_Y!-y,7>VCdoٟ051 믴Zu-RBJ3qշ++ ^7wsA%tR )-*}ׁ~6v-ejA Rv8W5%蔤/-b r*`[$sL0T<vc}ϸw.T 1Py"1qCsYhޏn+1ziBkY 慔 Ʒ%tu YNk*"k,U-]AleJK*zKՄ_\շ++"z|ۃRkK=9ӌsc)'mX,SN}}Emm,y^>w"E3"eV^+Zk,jkK\c1q]aրaTRJd%REp n P+t15ĸkIXvEΝ[4& ?UnSUŽyG~DP]ВqjMВI1ƑS"1 shƳV0c!Ē `! ZJ#P ޣ9 sQ|8c@Lӟ *c._#:3;u!y;amǧLe-/yOP@Xc{~e"8 @_ g%3Fj~5cP|SԊ=]"RX2#O1ZoZ-"k`mRti1cۆ@K)4㼥ʼd8+16^ + z]b7JS?M|Mw\8jC6:0ζ*ͦ޴I3Z=Ъ}o NDZM|vTIocXgBG \)i&-M90gYg8Yrn!13Uv;`QVEH^;9沰,Kkg+_ B^au\}qQ%P Wkr!J<}"H=yHT ]pmf@҄z8A0qyZ&nEc&6J;x礖Q@+]GBc1F4ymR }eI810/`Đ1RZZfRp!XBh6QQ#Rm8u0Xb}Ltsk4pyaG+7oJENO#RsqBbfVb5 ;yB Ѐ,yfw,sO<8XyݫB mA &Uq5Pg5e&Bʭ4so-ȇy cX>"&Ïu 8AHflfp:z3TׯQC ]a`xS{Fwy.ΑR֦.pxq%k`ʅz)O՘ [6ڼiGc4B6c`l~JщTT[  8YJ4a#!Z:& UTw- LzWߺ$#)Uqy^6=9#FN8gIyy/"]DK"yxUfbp=Y Z3F a8wT&>iv׮cX@ւ>< L.q,MgziZ)9rS C¼}Ӗ#b Dl]8\GDŽ3" 1B.f>mN6`OT)hM 9r) ux.I>%ww^۰cGJk wmC)T 6\ ޳wnp.ptfʴ[va8E 4) ch \yKg 8RuCg5Fe !K&LN ԊV=23M#i1 F]t 4o6␠L Gu3g #V@z ]d&! I4(9s1!tGT[C W>秦-þ;^K=?qQ-xO^fqPr:9s8;ݎR.9+]*B3`"0m=Yf498k箻"FO\VL4-+DgCDx`uKpQE؜b]׈q>\ {6ZC%a0ϑԱ$& ]߲:^xxw72c׌`L#l7g8g9::\Q: 1RT-\|B"U9| v R-7Zg=ֶT{&ۓSd3n7\897̙ Ә 0(iڒJE;` Uv).Ɠ6з~'BтNiچ(BJ +]:4L['qgVɿ4t8pג(Zgqq`!@"a^`MKEpV y^0&D\xo؍#Fr.XےF,M yocM36ti+=k\d8՛G6\PmJhi ZK)J¼$6Ds noojXa0H qfdj9c0- )BԱm[\+UiZ=Ye>OfU\,oyK~ b!vd)T FX"]hmn1УՐCXo$X RP &h}@VZqlI6h4JY18'B`YC߷뫕%)[4^f!`M!a2Cr#{{Ek6Ul!ĦHSpDPjdd2K1fȧybqYXr޻y%sBhKn5kɺ Ca=_|읽A ơ3=%+׮6kOQД㪙, ԒI܅<1uTdDgbQZgms1~_=p!"!bj5vL˂=9/,˄hB'*82Mg䔸zyVrnJƙnj9Seb@V0>0v*vUJݘ& _|cUmV}Ͼ7c]D}O|X:0Mm x5f{TicW-MKjHy¸ib ;UH0}aB? TCUB\cĹ҂AísmPM3<Th95PK#9cI#JK{!Ԡ:c-P-Uf@ZcɵITRSq:ri*烃=#h/\ O >=?oi )k5aߖ$XCkD="˔Fh:e\u^9³ɅGXu=a - az.̥Jfyb(Lؼ| ge^bl=rvL7U0:Ǵ,"TytAR {VC@HS-Oهky, 5Wi`قZֻ&dQ¸(U58~st 6{"k@DpqIʌefJT=2 rĹ1DG@jL@It }!Hu˴%L 9tsz ~O~q~*=qH Nx.bmE:؜ٴ8,zX2G$3B,V*w^Zaj o6 IDATIx]M9;=%ˮCYw7%9bX+pSb XAC!Zix X׸42*D1{LiZaJ2B!;Xu'ϼ=p?AC`RT5f8{a^qy-˲r=k]k vYW{ՀL2vgԲpV&x?>εCvg', fڰ B.&0[.7P]gI4`%WGAqF {Ab*vBPmGLT-*E>/~eşFx &ށ(aKrj}43.=+Pq'<灗7=pex je Tg̛냁a9==eYfBS[n 2X /3l 8)̛hN$ 3_>:+W`hL~[qy];!ض;ɜXFp:Dh&q8q!l;{M\Eiv5bMǗ3xƝO},?WOC;n쮛g뀪RD"}\O78ƢUUԔJ&XzX1)y` ǵK;R3VJ읊rWϸvIƥO='4Yvc3Lədk^fJ0X7#o uQEG#}t>ݓt] յm7u%səj %XgsNj}'ǫP)*l#agkEkiiR$|4{KΊ>DRmS8ϹǕ1ik÷oXm`AkeҊ76ZC_>V^ Ê4.T}F5Y~ma ֯et((.qr|⋏Ňڦ2%p"l6bzVÊQM>`Dg,ݎvC)T f!3!zEpZ:A ]ϰ:zA+XXo>\'=ߡM˚L}k!m9׌)N;.޲WNά5EmEl1e_e1g>q:yg̞68:,yXOhsyځ?QFu_LVjZBWڑ͙ҏǮqpx֢1պM,mUE/aCW_0Cqه^K3gS.ptSJJaC;OhU*8PmR"ݔ8g63qf﷭uhmx D!Ҵ7=jR -1HQJE,Ol7/ßz'K?һlp1X!rCj875*T>iԪ:z\"C?Pӓ+{{G:)1>;_O+>Osu~aUȕ=tf5޹ g8Z9abhɜR#vOK@vCVe3cT2dVBʦ1jcy5c,ֶ_F,UgfӴV#g9Wk~'$wgu7ݯ !4Z{ 9+c6UY٫ccnJVeO#MҰHsT?<$?٠,@_ĕ}R {I+'F`_k?KѪUJx߱>X1]O'4_J-u 8 QzO,%'fm1e&8˺o,Z#ChjrVn`J6ܩB*4[PJ;f9MbМi4m/Hi dD8˙35KO\?'\go}s̾oo皿5suZzx'=w퍜ut7Eٻ'b Huӟ煱B憂Zawb*]T )Pn7CȢʥ{>[{D5ĵ3VYe/?ZG.pׅs\8\y 0918hq&xU9ޜcdpG tsK.1 Fع~5x(]cn 톥ԎbŶ-aJ0We*ʕݖ+Z+.D>Or7k^|/Vθƈ%Km 4Ei3BEI˄{&\h);tus$)D3lEs/}Ïpn&#[0kmΣi՗}o{3+W0 !bx=>\Xi`Ja8NT2%@0Cqc .J"X>!fIҪPN`HLcu3^#]B9=e#-v*\ٌ\]&g.DxÎsm5q'Θ3p'`pw"Jgkd[υsB`M3],˂a7n@-Jua=6c 7M^E6.<ݲ-#zvbqL|^?GIOM8,ngqjL,mGZYfbJ%kmc*)BnۘV,Yk0!9(0Pbg{;'~7x*oTNdo {X ے HT*j[,\쉇=w}wq0,I6QH:6^k3p4(tJ{׳wa(֒%YZfcƲ8?8=qϪU.ox17d.Qm=36^jR1Lxwv]{` x)KL)a'}ݓ,kaw\6캎LRN#BJ[7TR k[JJl@ zaXKpl:RC1\K=1d\ FXɦ-n'>¯|F~zOKycm=!8ڠ5C BVcHQ_X];Z*9'*vuoAqÃ3Yo3r=b^{&u~’" Ggx,78h/)1x\Y\K4 cRA˽]O O߷4jj-mhtg sJ,R].JՄ_7,i|Kɕf;t8Whc=7YI MfRjpJseEV\Fش+B|ko}ca4rQM@6jK[ZQfs:&ɀAVCAfdYӿӑu:5,U4M xC^o/5G+zs\^b L"dǏFEc$0OvF'a ʶiy;e CcK.!8:K۷4AZ \YOmhmVvfd9DT QwI xujO qx}Mpj=a7mjpFrUY3uP gIy&-3،q9%$\MX ]]㝧ħOK/]}_%K(t.ŸFFHreu#c`hBa7. s鍭P ZS6пy/;T,FۼY;51!:C* !7bp9ѵ|bQ2EvoT&X n-Ҍ~%:"3('Ą+`@c)X* q!. if]Cjaɉüp8NjJ5η.8kmwZJajtp1p'#8Rri?}?c^˘D05Ag<S\7G*1M9Rb2RtkTk ZdskDI zaDV(sBr4OwYUl뚑[FkXT.*meivKD,C,8C(yĨqS1RSՊph' ūOs9 1BtkUc%. 7#3aG*œ :\VE`M0NE3κZcVQ2[A3y&Ӱh1H 7JwGܭlc\Ib\Gc8|k點s ڐPr%&Mgv'Z'=xG0\Hnaa<\_]0.S5ӆVa9?=~rEٞ i,~CGk 9LC-nnT0&V}C``%K&aLzuV 8.4mwΩq:O 1t\p'V1z3/qu$c-Vԑx~!{p Yi,b["`<$)H+_;!D~glmV\RQlR2hYWA6t>v'y9{jx<'Cqۘ IDATes:)'6V6JRuE< g=mtUE~51D7n(,K+E,ηx,ld\F K'%r~x>T# dg9:E,lgg?1)q,\ϒ+,%rϤN̙iYJdprr2l8ߝr]햰pFtK6>NǪZ<^ 8ryCI?8d()enpkx ByX"6Ng'y f53C 6'[s| M!%9꺪|îلkW}3 8oKQzL5q֮8MMx8kb<4V3M XJx*w!Ą8eD,ˌ`9, X:u53|psq9ĔbX@trutKRIc0s=&.,0Nquǝ^rQGMFQl=lMICpBEW¥Ҝv ހ!8%7 ӒaM= :qB˛9~[2A#^V}z8k>:Ef!RR(>EDR9oG} s"Xu>HE'Kb4p$5q8qr}sWyN\g 'qtpЧ<ӗix-)wg_ W0hX~0c)*<,\950xK4}&R)\S&8;hnҬstbJb")PC!#C:ke<k8$޳_jϽ;=w)q,WLW%I3/{*e|h(Ba&ZU,VU]V+Brk=`V,inCyWo>&Y#+aw(q&g$x.j8g? ֲZڶû[>mRND({fsqn4(̴(iKŒj }[fXUT*ɵڞh4vĒglazpvɦAXw"p0h Ѕ$H9W뎷* mHV5$F՜Ko==mӅAo7UjTxӎ7-'|P<^|MU,{^kM[zG,HY)o w83B؝ljQ\Q8|BGzGv ;w؝ VkY`\fIĩ\IS$sqvnkظkקS,6WYt9Jv-yfEa:r^rka6=avTr-,%ZցbeVTjɈێ4;4 %[m >xco>3~'?A.Ygg3ueTII)UT0.vRʲpxϸϑ޺!8 Ex2[+"`,?3Z01&}9*~ o;8Y6s~J3~<sVxw#(x6SZN1V BXQke{́$pgnBk{w-ڊ-BuP"KJ6\Zڶ*Q1>2 =8hWHE X˓Ñ/Ϳ߃ G#Z7GLΙiwC)iUT.G?J(rX&ﱢ_ɊY]:pXoV_21<0PY"cjOiTE~; }K״Ipѓ)Q7*^͟Y 6æǵ Z_+Sc!Xk|z@]IՒm`^"p统VҞqv> 9Q@ayLLӢ:d_pA ybL_AHKƻ`J=_yovx~%~ǿK9)aW^+q1Rq֫Q TQkKk3Ws7VhĒj֍@7 \YX Jv8Nˈ 1\X%Ͼ9nQWo-Ӭx$skqX*ÁWWq-"Bh4"ůi60wwNԧ(Um_ij,4G9k:QXb!;cZ°a{L넭3*-o?\iLZu^8cJS UY-2x+ >}}{5˥PD㡨tUR1ĸvصR2ε6Chnn!`v:8x]d[#!- D o;|,"\"l{b@^K|~жH.uFoWIXddD=tґ++AMCn0[xjY߲ \Huz#e59TB*ɢ1'7 OHcXꁲjl|E6R*Nb}BNeRT/+rۜӔyQ:|ӱ?Ns尨qw w9,9&$Zzo!VA"ڮeh=NEDPD_ֆK!QY/q HģG~7p =#OK_}ogY/s?FsaYUkEֿ/ƉhU}slp"Ǿ';mTo' Gİ'r7Œ!Zbyg3qz.x՝R+uhױjO94OLD@(ܯ]?M@{X)V$F#M.+JJ2aωxh\U΢n)nw<>|Ev%a;'[ Ǚ)&LN) F{P͒b]H1j" F45\b9$̰xj4NhmR᏿?ytƴIh3:}K.:M#o6_j> .8}ʬ \+1RTƤ\qaNB'sD,ȋva=Q&58q{"Z%iY@U/⑲PD!LzBvc0\p,ps 3HXKŎi^9o__{_+܏~puS%,50ٿo|\|j-O(݈qaq=_Yy ci;Ɛ{9gK]B۩bECªym:ljyL<.x*F>5A[Z>LJFo马uivc*̱!WOEM4??3N+fSJ)P8mvPIV\oRlƇ[opɕ(0e8.q"(Uxze|ݝS0r6j({qY<+9s} ]?a6h8~V)flPdbsV\<szO.aTI6'%rG%jFFfG/ V<9!neo(0{(UKd1V[gL˽b?"y4`l#9pk3'JZoJ{k\_!xW՘5+'B\Uz[:?U7@IT3*5|N|PhjBKc4r ap{a_O6Ag)Tqc93iU`r퇏yY|3`2ضH¯[6y]ECSݰȊX׾Ed5B }_{瓜mV}uzcMFqq:,}#Fp^18? ;=Y؝w }&8!27.IPp<~#|A1Q s2`xww6D%&ׇȲ5ʒpy6̮Y(R^9jk9#DIͫV؏7'79**I xS?i>cƬ:ZfU9K]5gdn@ʙsBs )td 'c"Εb^o쏙31Ӡ]J”ggwXb&$o};o\)QeI }kZ}!ݔuuTĺ֠Cg ~; 3.^xc C6{pf,d4ba?OdQ.0uD欢pA\Ysau}q.4 vu$B8PFcRU}BGG>BVe:W^c:0 PsV֙X˪3KTQ~*)p*>|hpaq-y:QjԳ<4N߇%Ji.\kͪ.O|4O_F\MBs VATZ1kЈZV,V+:H5ϗ q0۠]] y&"T.N0 ǵaœ3h:7k譇Ԕ+:6V8O]L߱j4qN/m,i!兔sfΙȔ+c.zsΝ{|؏s}ah[L ڶӧ:Sצa\бEW6U )а{Nvܹs0ڒ]T;鸼:2Mac9?om-2 3}Sˈ5¦k96=g-}Go}Yk [Y=e`L̅jJƕ1޸"P81Z~⬁*| W^ vpR1iRj#4a'ҞQb ,fBk7{3~]sQ@rXr¯λ' c]X޹&\xs&K)"Qc*:ͥsfɑ㜸G:~)bE|p}|g~) L)2E6 mu&1m!HJ Y 2^^Z+yz g)4F{ J5rB*(Ѵ=4߰#C?8r_wowVݾT:!kێPuD0xhPE8V5s|ʩ)ͬO~tOJdc _}bjE7\hAmbNx^eVLbw53ȴ,#K,Kb1QM 丐k΃gɟi>ZCZ*s0\bhځ%XRYbbf̬"xsI:)@Xa@R<Ÿu (XF08COpM uG)z.=߃ __!gyMյZ $[65eR-ńTQ* If]GiScYk_# |i li lmћ Or폼գKcd&VƉ}& IDATcha8k*'cpaL%,Q/K&n8'CpXHLg=\qtC#FPUچGkvy,>TXzj9b°}R΋akb 8l yYXôՓk޷lΙaDl?wٷ~>5KV,<[<у[BBYXIDH.U<RTP )c 204KV꾷aox}-iUuߡ{wwz~LB0FܻD 1`rtFRx^ *QwMP̐UTe,F(>n*:m)$Lq+%Z]yqTNk^:&Y,x 㡫{RjmmϲSPWƙ^d:AJc; ;1zi{/)sgDȊCv;slqvs1y׼n8dDϞ&FYOIJAk+@F)%{J9afHEPl3ek6Mo9s5kx>W ӵ9(%ݜ,"#fz' 9(!`qc$ǀ=BGO=kB1,kk]blhu Upx[B0[k !uU?kyz~S/{B} >'S/$eEQVTHàkAt8 Z|¨5(e\̨"3V5cqsJlfQry%=X2#гksR*D1(F|j:1)/r9eb2R./WΣaw>3֘Njk9zz]|-V-B|ZK۵# NaFs2f);Tj&]z.rEWhR*IЉ(イ&(4 kpfrcpvNSOX {\-˔Y5$]1}헿;#tW0MtFXIG-&))hEchTKYͿ$KPcpZM[yR(Vd-"T̾x͐kFja] ~8mg>|g[>p\$ mʄF66!-Ja=>L\zSݘqn{Ƥq3 =ՙk;ƛJQLk+vKqur9-9vb9H*" ~ +9M% : r$U_ZJ\AI'Ps&g8Q9:çJ۷O3C?~GO #{uw 9uzWDTikyr 3ugn+iYMOzxmq3xܖ(A+T\a7e6 h"T&ZFFgxbkf4Uͤ+8mU2 YT`667a>+3n`,ٸN^7MY.vcOv>_7BViEUUf{bT(I|@=FrɡC7Yqt5>AHQܗLތTxv,>a D,u^*-B6J52UEX8&P%3[ 1dװBʍ\3pt.,PYnq0c9k: Zږ@2 cbR75fI#c)jJ̴М^ Bw-{{e˜"0]Milyib 2;fO=a7Nc5T Qr ,<ic{G2HV yD6Uњ _cg0m @4&]ҕozKUt cp7En/XJ}Px.*y?  @/]2S;#5:R+>i #f91$M  dSbí>NJn5/Lb :Ģ醞Gb,(%p&7lm,L%&|9kV85r1%t&=F+4G1-ѓc:ޗFRB"7F[eUYp918װiE(Abdh:Kzo?'rₜ{F{z,?(%FA70PH||M>+>jZ&k:&ߠ[hydyP7ԥ3JRaW&k6bH\8UA)aK.t!#X-7?õw؜LH(gټNny8uYFc rʉ1-x(6a MqU[n` L&A.a%A~RByTHa%;БB lS2(bIRAnff+?G~N\W"4i{k<SR<5R/Jֱ;&z)U"/V-G ~UOqJ9W):~u݀)RE~>υl#"#p2,\ kU *szpI_Y*fV1ߘrS?Cmdk+o>Ca[8M7bt]6mOhTeէDStvqd,oO@"'m "vB4ӵ-2|+QZo1VdB9PJ>[Ӡm:ϕ?sb'.Oo 3դM>⁣c'UO٢8F?)c) I^`uE; % "DbG. !':Y1E1))<)袙 <F9!opQq70Zvk78|6fh` 97­]%4JEMUOEaa(ENJ+GuefXrw ؼ6\ɓ()+>dRZJ 4 I'0ꮅBYro+;n@13Y|_*wN5UKh kU’m^VYcmMr@!8o ~vh(X v4oJ7Z־M(ּ,IcCԎgrK{|D-8ţ!*-(jU89ڔ3~ӪȲYÝ:_qgOJpAGqb!BC)Ic#jOJvqJiێ }?$JCf+/)%FybiU]Q;#\}G~_ys'.Oo7#;3tQhHD*~ꕰ Qd%Wa,'[ݜJZ<$2d:qL]q tp(9^YU2R2Ģ#0Tsnq'8[bg[~TM#;zI7%%a'|*=(C70_4*:#{x8c(K"'HN0FCv-)sll ~mK#!hEU6t*"iQwg~'Jfu7?G(CGwf+E,-k O!׸(c`)ŲX~\AW2QG/T9*b zE8poQ,fv+gKxHixP4Y[\Iܼ1ƭ9S ל칳h?5ub9(eX4%'O3b)dR RDc&v8,ؿ|+.{3C*{i1eyx@.G)wdZtm2c /\eDGah?_|9RaTn;O~1@+u|-&-y׭R]}?}Ky(Ss}hz_RYG)a$KX2锜"CבJkR=h|.ÕaO'r*G~.V8g)5MWjZXMVWWRd f'O,"J2ȆT&s,SE=jE<=90-i((bJDVT$Zr]poz}A>G|+YcU6 14rI/LVkG vh k'Ciğ?{_xƝ?㭯FKO!%ց$ʸ#xU6䑫a.@цZVl6{ 9b)M%kYw56y?{dΝbO2],YrUje"x<7[u-m8{ML֦,Z70$'X\Ï}=¸:uJk[aYeY,|wiʊ/g B1Y7yڠo>$>.*3L..d#h h4܉|ԜґO⹐YNX|E]Ul׹ /kvicB-9+ëx勖Z\WV Ex#k4cy".3_ L7h-f9 gRqxx8ibsg&^0@M&W C;RakZaᇞt3oH)츔8W}qQ+ZE+骟 _ԣ*X܏ZaQ$-۽:*PԅBƳ@6Sϟc^|/v*[*CRF<?xUl^`DX_cWoy'Ď/r21|--С4vy[+*5C`6F@׷xIa`& ȶ3xx=qAV=z"ؠuŷg/hOBze?@a|% 9JYP2eݛwيɽqp9rǭg9gf.Eǂ;J{lbu4MTX Ag\.9j;&GW{38cyG륯{^J̑+WGi&W)3L!O,WYN9?LXܦH\w~xF g8L"9y,Oo@ɑj\Q')L XHJtM0M[8s jsB5mF#BQFVuǃףCL( Tފħ85Tڸ"T2.xCd4.-jD;N 8I!=[[TME k-{Rj\BI1\ J-_9ɗv .<0mMaaK] 惂!*׊4f/٫_4SGU!@zOQѲ*q VBa^HS>y(pT4dV46 ezG䕯{-)QY5st:q{"ҞNjRNm3vC&|dj)%ѵ=X&_gɉ Ҫ:ceF[UΘ]>w#rJ UarzifvBkl-ed7B;. 朩plq5+3!1d[nd㓟<E<=61pJ>#|<[ mK^RL\]L{O]7TUEwߣi&LIC ZK!F-IDATw ot/25*KI ԍ3})v0>siNmbd9'Ğ=C9K`Y %EIZg\51đ[`h!&kZG/ / +%P6|Ef_loo3 GGG" +A5ԵNv͒t/RulJICߡ5=?65'.7@ZQƕAQ7J?4;sM&w^(i0ZsFQךq F)%cy Ws͛+dEIIqu3r)d3H]Cϱf`XzE(exe>3lnmXq6Yr CߋBbE[TawwSvٿzHm{3aWqW{ oR"V9!gJ8gIQh/9I0VcDN"Vk!!AFƠ zj4г\R"z歷U._aX, hVRH .X]yӛHb`ksk5a).2md;5!pqÍ7h'x/NOgՉ m_F0G)7'A!zf_ŬCqvDi8膞M!iq]$6AZaŎrR*h%5H)so9tI߬S.<"gR,3zsч* dOJ"t}B4bD3 k^{ M=e%Pbo{K\CZ%R(0BSB _ uT U9S;唀:2@a%BGBNNB^F[2:@-aݳ=@4\짙]9F PbvW hHޏo6Nf"4N~> {W/XdiF.;fhQ0Rqtx#!f\wkG˒-9{*Qkj#JT2YDJ,_Gw\z2CRD#qXca[h뮿9,=qAڈG1ah\Ux,^ejT%3xUZ %=(mQF-zT@ m`JQXWS5NgJh]Q&/%6pR m*&fְ1%m釁+WqUEUht oy雟uϪvPIs#rLTb6CBˆ"LcP*b*Ѯ&B=:"F!DV!DvvwݡLGXTIY%e&L7}I$O[<SeF=i>Up#BJc hb9BbG( JApȹ ؉̩3g:#-$U'!`%(\VO,,fA!P86{~^ Umi;g%KYQ7 dk~)x֖ ZQa!'oK=ZEWbr<ͦ3/DΊڹ0"L ]bk{sE PR*E>d1, 7€)b8&/C'=qjNjFf uc1rt'NXnoﲹm'"@bH$:Þ gϞe >%Qjt;(-XbxqΉ='̤(C @$@4( !is !BX-uO3('.raQJZI+e.a PF9SԎВKD&p)À2f)\ʐDH 1L12iÐ)` ԓZC(a]9d2kXߨyݻ^HڧsCwC# 9}ŇVϝtދ;*B?Upif91RXEW0"%[!Po/q2HWc; u] 4&R'B-qNoOi}Fs*q>"1b@MISaAjYe|]tln3XlQʑsBi1KcxjTX[4h'ɤACJv̌ Ύ4O3:3“!fUehv5".жB*9Ћ1g &&7Q >QnX1P9CS'uZaUX{ *# (dUgTŐCiuNFȥ=MY5+35f4+D~5tس/'.`EaĤ9Z 9[ raHNr/7%H%Ik^îeu݈GXb4~d2!.{_>J)Ӊ .N9dmFk9bB 4~ʒSZ2E)sX8? ٓD W ?ϭxΖ e:J.d%WA 0/+B&oDX\ rqC81S¨3Ue<hxp~99|_RF oXS"+H1b֚Yƹtl*YbeDn3/E d3'=yQ*2 ZDqDRvbr9gRIXx^z ))H9cRz\K80' OQ:qP f0Fam}^e!/OB<o?/rroSq݇L!O*hJɐ#O8BҼC{/%VqB Y|Q^ƀ 'L)k ?ɯ|3S8˿-NB K̿q.,Q"d K gJ*Vdo*4b*ʍ󾍷|i9DqZpB%D)dRS@vn8>݂S\؛-qBcomzC((Qᆐ7- 'AZfߠizZ1y[6T?@ދ(xW9FDdH`a5a )bnY1Ŗ1M p޷;_0f?~', )D1gKiY6oFR eaLҧ>lo-w_ ǿ=*6fQZӴ )'" %3gҙ偻Y5<(ֽphbV1̏O+vRq}Vջ.!ń>#)A+MAv\!ZqŎ2n9;Eu$-6Rb[;Rr޷;|Ϸ!z%JNb'hg99#ƘyFspz37 Z6Su ^GDܩ?=\w%'ƾgX,01z0,@qL8\`e)SIdLVwm,1rmx"pfŬyCQ)"ZSP J0 J@DƐsi6 P3Dah,(rB[GEߏX _󡇈9 7B<;vC~7BڶmZ 8D#!  ej$nlGvż-%dv=rjXf %WAĽN>ǿqD1ErA!:햛Ǵ]-%'VM&N$jgܺk Vh0`u-8SdhH> ??ͯ|;w\:si(qb&@!gJNX%c ǧkp͌,K0 E)1sEI-`  1q0D,5?;܏0}oxQJ]00RhcPr(օJm2Lq(2!ctZ J%RL(BHD e=43pY-f-g|/zSŝC#|~%'HLAݬ껍1RB@L!R t]"̜a0: h;R(%! bJD6 Q:+Lpy`I24~ӿwŝCGBN?0JV\(HJ!X+Օ5JHaZ`"o`wJ$R BHXJ gC@ن&HJ1gnx))d5xHqVnQhvq5ggIHEѵ+R%GJMPRA+)e7lzT ^3VѺM |[ĔYΡ4V9H)DRiRŲ#84!@ə"3>Qtt"%L(M7IbtۓYˌ.ZU+)Ks˴xPD 3R k128նѵLYCʙmS>NZ4XVҴm#@`"gBJ  Oի%mXGi|*7oYoor~Adm]+^~B)oЗ/g7/{%-a-SkI9 )Fbہv6Gv&bn:c[D<ӘY,"K:!Id I7zb.r|R‹yBJg}?ϭӷHm{(|{ArΔ"m6k-7L1%ʀ(Jc J)R\/WheHc&gENЂHQ\:DQ,$ SaoBȍ93[\`9%1 %e(Be=pY&[ Zk"JiR1 ;~Nk,")ڦCiCL)FRhQ0~Zb 2J +R*#4c6o0:c@̂)+9V{䜙cPPR!FR̬5HL ߶h(Qy=78V-w=x X91ka ƈm%gB;a  d4 FQT2)` ہ0%R֤ɩpzY͘,&f!cJ8E&aӔH1zRQ7ѿai9r&O`@۴'hBOru4!Y|ٗy=7,.V9=pm Z!Fi$LL, 5m}:13(ReD0 "w8&01AyNNYL=Rk(H 0ZRUDiDJA*^-(%c!TY_D`״ݬJZ3LY4e4 ;Cc5VዒZS mcZAF39Z+x-@ 5VqN+{7O>?/mܖ\+w]b k %Yq$Bm)0r(EpQ"B$c%P:eBH_$LN)D 4֓Rf !T`i'#]gp4\!̼OSߴ*1ʚْʖ2_9v %g s^~{n }!?']25ie0M뿉R@5I1swcpBeB$o:q 1WcsMM\vFm KӓSFT" )ev(mY[3(#($)6HVK{ %b)( ꃏp!t{؎6?n1|ZCH)c-͖"8o[|ӼưB=lUa6D  Fl(Vk@7kh0 RZ)mV{+V8Pr&Ɖ~;=8+3@/ 9yBԿcp3 PZ*PТ)w?sa[J0Eջp!-Zb>8cʐ3N;ze`صΠlK)kr(X)JC_"ezs8g ÆPRz.ж-wsnq(i9v@Κ29 D(%3s(mA`&\E2R*_(bNC}Mc]]0;_S6[R<?3y0lAc Ŵ Qb1zLS 0 1R̗K}h)dJЧ0Rhr ljwoȥ0I1lǁg}-1*Zu &1 ǢU@P3N[ڻkC.CPLYĐT7|-rcxU} (7䌥m`3Yeى*֚+Ti6x}kfX)Z|EѐuA#ImZvR9T`[`fMtnK9Stm52ɥд-9%b(յTT LcҚi!Gb T!iiC mn#JO8߶g6B(I-՚,Za:P<eDS oof~f˷| BIdjc(9svvJ)ql{8Sd|Q(m 1KX[- r!9o1ڠ:[;$"LTPN!0l7B1 %kvTrPw\}WMճي5OQqrnl8;9~}|fQ* ǞoX6 gBk)E#K*wZ@iQj`~u?r݇~-3Xi0?(A[C)NT9%lpPr[P1[NNN9cfX'g6,ZŁ!c:Gɵ6΢"ŀuٺNj"{v4 " 9GrLlgg mzGD)TIh, +n}h+afZֱpxZVQJAD2ckcMҫ|܏ġw\?{ʐDaak}iS?YPJ㛊ѲcmvnG;k !B`Ւ2gV1D(;BI1vjo)*sdm;}"DFi7>_P21M)Y!dJ*^#9Wk 8cТ0Y6-dh3,E2%fRZv~삐3;$&%Q2*ᕳ3m[o⛾~w]HK44ȴ#{9pzzqR5tD;Sa)$h90N]@LH"! V{u.'z##Eb.gXO-Repΰ^o(yb؜TZBꙦhz);Du93-8VU^R(1H;UZEHwHFDa Jb'ixAg G_G@.ն6ʼn& v>k" #BRk~ cZ !D}|>%Ĕ96cUi-ecLA~1apv|2Zw0" }nFBĔ9 h-xS R&fNcZGh E ZiA17XNv|08KrO5/zzs{Ǜ6x|p)l4 8nXgUDٖbHDl}1ghkD۶qd\B}B™Lj[Qr뺊3HΉ4w)`fֵLC_Xֱ\XP ml6&UnE?џI5LZMxJJLPUXP[UUߒ"b4E\vKQzYIWkwg3V.(HMy(:c?SЬu)ݮiB!u-ig@TCUs=يFCNBŪKa*"L18Nc51&Z/[kֆRi11&2,W{ubK~{/ijϽ7X#7cSfRTf@D (@c%.j;Nj@z$e_iDJ "XtM5Τ=) #_(t/߬&yB (]؜MWZIg;)oγc$q-/*M*UJ{{sͥDvUBJFBsϿ/ -WӪ¶T \Ia@.uE?R)XouE;c niCq|9M8۠B2T#^|nA3#Fd^y'_צ..y MS|}=g[/0=lVPt%z3gGk=kA9_PL)ku56OUUKLSU`[J}ѧ]U(Ӽܸq@\>9e"S,0VTIX1ZzG #38"k -g5rZ\̙̺* (QalB5 D"9%&w,'B̦• p N MQwrػd'Ҏn_j%L͆v1#Sh9a= 2ń٩!T IDATl/V1Xi3FB."JQ Ba9yc٢p3$gLӶ12gnpv&^@BEr/z % qSrˆKZC…Ռllj iv !adR) lb"eť! D,RuE6){/hsk.{B3>䛿ka$l֡eFB׵8qzvUFcmC;\ v;\vYweQL4hX.8aIzD|;lUp+ sUxU!*%tmn %qM#G7^>O\vaPڢ[v͆0MEIDQl6[DZf1fe/h-SB$3S@){=R+SSq@;&'*Px#82EEz~{_x g(=ׄ~{x'' 9WqOV\, MTjr s hJ__S u|`ݸvd4U!lǑH%Yz)i֍o&/|E>3\1f6r*er:Do5Z<@1ڐmEla>ai;BƱZn7d̵ k#g1VI5ԂNL5>Sf C{lٿ!GDNǞ'u'QqEԹv}fu@H K!8 Xgk*B7S,(q1cڍBFtAfU7h(&ug5Nhwڿ:PQZ1M( 8kU-q8y'<~i{tsc3HN B!hEb5̽+9cӘ:10@!c|[ۡ!'QhU;r.Fg&Nck %0[N*ʱ"R-Vf&N3בIq||cߺ[ƹ$ˇ}'_SOdw,n[ߢwHުmΒS&B.qg%(nq/Vh)E!9 %Pp!8TiFk2hg%0M#aͣk3OO~'?/`]G={r@ZpZ%UN+qad84?-P"u <]VZyu;4k-w8W6 S>`zyMJձcJdZ2f,/xZqC$-fBE uk1,#W K9(f1ռ3ӳ1X:3نvlvpJDu 9-)d e-V,u5^6-M Jr8b` ]")ƨ|!8`lߟϼ9ѯcyRVV?[HɄi@!Fr KƊzC?Cb`ΘJ,k=J,Woc- g ԑ"Ō3׮bq0I!Utŋ|_ӿO~خ3NJJA!KĊXC#|9X-x-Zo^ !,:ӎ4X>b^|ȢS~B͓-!Ba 0mEvG.I"mY*0LR%aL~AW|7g񅗏XoH Kw=p//z~Qr5v}Ƭk@F#&2)֩hFbYϼFtHXw kEr"b]4)d S3* jIdV+5/X*K,ǛMgC-WX#bYڶ%F2i @cK,}-ޜF:鬧"nD;rՌ$lpz~v똋s*3R3*˜I .qV0JVU^P &Tct3R]43{RJ\r_z!7$w?_KnDxKճbƣ-C`;Ήq;olƝb њA Xf#qM$Кbc`ִ(] E)|a#5]\aXggWK4ݒ̶p:zEN/o8:reh$sq5Òƣ]SahL:bTd3Ly9VlbX%fs<)N StFrZ&&bPT8=Aob(i D<1=?[ on/nbk{B_ ˎaYpTϷq(9)$(%l8~97xQ«d@ʑ/>l-wrxnڃC~{gLFB`V ^{c:25 ˃$?Lə+w_e {%{+ZoFtIx8+Ҷ@6/4p]X،Ju7A#F0aQ|v[[3,^ }x]h)fuyhsraJLBLSBHeNL1alҺv|j ø>7SaiF$Zᬦk2>~՟i^|{B}a 9XHN]w2Hx?ɍϿӟzcTq[)`E8:IC5Ël^0Dwx/}}{YsS+[s4J"-g/tm+`-TZBhLc_׼T( `vV)$3Y=f|2BYoQ9h7Ĕ#q2T1'拎b s} 1яgOVU3@11+ ri}1 rdo[3W3{|1qbmW_q9f˜vp\f#BMsG{<w.uy n /<\3< Eiϵ5;3s:+zvhH 2SD1PT!40 #Ӏ`w=8HF2sU ":jO'dryK()krxa3Cl>'XTtPB Xz13v,Lrq$oP pBk %k/_zC?|2c|׷~kJIhvvHDCIt[ǧ\74~{3[͈E :`YCd F Ab $y2CIJ N'#HRqH GER"d7duups71Eɚ8uPU瞳ТLirJҐ*Y-{|׾Wh*ϼ9ք$<go?~3|w>K5o<,&{˭[Ǭ;Cc%-oHjEYG.[S! ŁyX0UѠj,6SHG_im)1py 3) >k]qzo;gi"VcPj,FɐreNl7knGM1׎[..fU!%dԊeqX;7E]/uC|/g~k j+f!n,TPbs/?iPtKUeO RdE!BT/5T8R/£s< hKN ɫ4Ox]ZAyۘjU )d9,P]!'M1-2E7tfPE|z-RKQW(J eGUIVD@)Uq~+<[klēCjJĮul)E4BEChjhkQc[mPQ-5X\p\w눻È_oIsCuD qFc;fPPV0L8TPuc S`^TBM NX¹3ƯI8IeC%k>Ovx8zT-O.GY8݆eQ0Jf?sο+ߕɆI~/c*hE3N83 Wv<~rEb 7[x/Kshaea tNZSJ \!RYHIޣuhbpZq(8J5]fc*-^+9^RY.2$]¤`_EAFQUHk[!GQ ʴV?so*ho 5FeY4p4]׊n<`TMqg)wer]uQ9#'sԚb qΝS|[|"+7[zOg H{QZTT-\Хlew9$vW\_r*)UUϺ_X˭[ WÎalנ1gv*J-)3̑'W{vcFurV4m˭4js: G-U*HJnəZ4I*wCFYrgJTP%`axa UMyzZ^x+o1?zMϜ0ΑN0Tk3+EΉE-[3ఈR,~"ƻVf΋kQԣi:"!*8`;< TyЪbP&eL%*qEK)WgXW:3ybFBH s!\~QӈZT%́8 Vº_zf{tz])Lf>bL(Rb3͚Y`M8O_)`j.Ua4Gi4.C1bѶB$8_(@1,ƔRP#!B7_)nl89j_\R+DΕժ]+h SW<9Ôn#6ݟ~"Bܿ3xu KPh)EbϮ[NK5u%ҡkW:CB+Cuk l'WE'S-b IDATfViMцRLVP]g$2FzEhF4J1W:º5xVhcI@"SN.cbӯYo=o0Xp`Zz'J1( (1Q4Fp)fx"MӯLڐRbsZ0nQU6mP[1#sR帱X *Jr<>6jz1¯ZJL9l8Xi<=|K3+~s S=/ܑb6iͲGW'˝T!kZ $Y "\^+Q`@1jDW+ AOBTӟk8O*Z9˕%5-Q-wc*X:]pxKs{s1&..(y~hgoRm( Rh'.!#sIҏі"FAxn;AFj䙡80Fo[RLܞ5gBLLH3& )y)ӿCL<{YmnpxC jNO_"R@)ϴ1Uc=c5t5_{p[[nl']dEUSF  [O5 Cd]`^syuI 4Ѧ'C fyw.$?tBZEʏԇ0}ci8aҒ-Ğ) K\rw ƮmI{k+%/7WU-]5J`~W^g (Nb0v4^8mJXt׸yI2jf?ba*h iWkJplzݻj'Q\ijC߶V !E$jL8>>hQh] #Jm5ZUw l(?b!\ֲ?PS_qgwݸͽgp-6EFHXR t0 *Q)Y8 U98z+:1FHUqv0][XUQVChKu Ӂ+F7 ɐfTzg^BL~_{뒏kRKyO Agg7x$l*)e]5Tv\j!˒E֪ficVr XqevЮK__Qs5זwU0RR*uQItO4gedqk S̴ZTWr.ھvj@׶%ھX>@\H;'9`eZKhU~F|`m8"*cuOsWJXfnHŲn M1zfRj˃!%= ίOJ9cNXOa0ُ#gZMKc4KvJZ#YK RTE91RS4~Ýr8XDr[qeN k Z5|qސİ;bX7 .aW37O&9f.jPVi-MEHI3+r?T,>% kC ^)琈4?mKV~]뫽kjK^!{4gRNt֎ U \+T5O⑩(ݪR %GA,ֺ1%)|uk151R*eR^.BDjc*]ebȣ :GPuXu쀈2 f ݿZ~|c/1댢ZZ\$l4>T ѩYXgΉEkk E%& FY6Ĝ8BIA ~uPZUd%Xxhp57i Gk5kHR)Z/j[?fDF8|`FRYg9JER%')$'i JaCQ.esfʙ4TƉ9& ͅ)$b6[|#MIIwW)E ?Y)ER+!NLRαsSb?_JV}㌒xR$}RBW<)KSQ%İ,f$UmKM!J\’ƉKb7\A8T$Z}5LVpfi*VT>h c._:_/!Q}KjO.y % mm+o0V4yb'B黎͂zTg!1PzȔ%,D*blB2+CѬ,.Y/jCc,Qn1,@"1Ib,eZd1'RrĖF2 -~KJaXG>ZkEk\= JLMؚqm0F_;j~S|_/i XKrkAO7e9aE+`ic-mB'9l dn0EjSg:I_+"e+HZSU%.'^qT^M*(m 8w#zAdbL.Ē6 09* ZYbXVYlJˬ €\B-v,#8|ʧrg.X}v>fb^.R ZBHOۿJ9m81,m&t"H'}+Xc4Xke%V̉3XXdPZ"F[y5JQ aw? qr_]5Ҽ-/DOjE )jC2Þ=_i,)E/)aB`wGIEQvVnҍ{Gy-Ρ녰)1s1DIQ5*9{wHdFv8 Ȧ{/ @E#L^E0 q RbDJҲ䒈)r;k$.XO.-}¯`= 坴"9%8wΈT^.R n)c9b7^XDhPB=*/g¨*jm.R)V#vXZ qPK2u=6/?g׌~pt0XLG>x[gsܢy8Wq{18xh.TQm~$lN`Xw !pS[9Q['dA7# (Sl NJ)]S:Nƅl6\QÆ('CN~&'Ֆ[˃hY 7ZwIgPbWn BET.&F(6#f"{E|q+@i75aTYP75USUb<@[)+!~pQ1wǷqQI semwr+_%1hbogS[߉⢱6v ʤ廓at]t:2i\=EV}O;SUGP"k?~RwoEэLU#9+:ep!r?`DH(')UI`;ڲ*H9*)$ tJ5wO #Dk'SE+͡f1l sBs+sXlnN뚪] m5UӖ 5烰}K3S;sBtlOG>MmXv =̫d46iۚbAe !sQVmS`1,v/Cйb)psK(öm)wQ @J ?{v| ?wB1p}apX[I[#iGzs'Q<'Jo51g)X8IY(ax>(r)2Xњ'r%͑1lۊLgpEeBJu7̺,ObSY.%VU tm'3#H:Ɖ{^L]݀11Rr"9r`Z3߹rqe6 pCO!1[ =XcY^kn}?{v~Q$s]1 lEL;1Uq;"]c/Q]$y!,{v{]ՆqJL/ؚ-P&R$ }t%kJYL˽GmҊ!yj8`+svKF@șx²X=qZ-ZWږTqɕ.{b9~1gt_FnSb$HRH|R,"@1t\<8˕{ T&\,\nR_}21hTt #n7F3+R |Ϗ³v^B|S޵_cZr}#MS1B1kgS<;HNiRIԨxk#L1p4G>j\seݎBZUNUڣLSNvu=dG$y"2ey|jk1(QtwS wcXB*dv=^wr!(A8|тSrԣ>fд m[AY>~,v/֖ݽ]wV yO#x4Xt]Gr2lܳ (_o'2N*gPǰyc;QSe]$be'"SN8'LUc(%bcN>i Ymlj5b4 hUZqF\a6_{ gƔH'P8xt2+ W@pINȫNW7Lz)}cHE,=ʈuKJ ֢b.r+He5[\bbB BZ)!?,ke#Ol6驿5wVb%c4[<гXb3K+,Jp PfB*2uԀ%%cH+?_%j C-H mhkH=#6k:2~t9l!o3 n䋗/2ޘbxl׌v`txh42B9[9ٜ˳މ"~$F7 t{8~$ad\G9W}75%*Eb8iZqy[?#w22L fT 2& "|25VԞexR]"p0w\4GtJ Q2j2P̔ pBN%XfLT>KD ! ,z_UaŊ W]qAOZNm愺$YF88~PL= SccSY.d\y<;s^m߉ * _#@3Ҭf 62l.eӭaTE`4wO_ "o6`-BL]i*+h!1|IԼ+u%,ICY,|GTa'$F)K*-MDAE|]c' _*S͙1ɼZiAeMLЄS;{#4)'%O\ΌyDz|`9:qj{ 8xۜWp⮳#VEaX}OU)V QGLFL*ŕ%8'uPX qӲ_"p8L!.J:QR4JC̙$vƏhf2G=T?Q (lL@>[JJ"I+:Q/V<|i`q6Ho>lqlsÇ8};~_k=|!1cղǴM5ڊ f.p7Efe$dٽpd-R )F#Et2K!kf<=kB|SC+R QbXMs:) *Q0RoOBlLeFU넼Fڙ\'aרⶅ\k5-;b5SUOūW 4cdKYfՅp1QN=ȴyч|~K\iȭEYMnQb ٥h4/~ݷ2x` rEB$#*ٽ#* aeTMeJZ.˄L hzڶ?j0`2 ^_a⑷o`!3Q4$t*SZ UH9d,\2O(1eQ)[ieiGQUl2Q}65 K qR Ӝy<"&G/lT30m {ǿ hpێrتbBĐmVٻp<& WL[Y,릨i\tIS[@ĻxL:uD ywaʒCW$T_t9am$]t{}*ª @t4%)R }OkI9qG mHT,"PF~ ` btVq̓ .cQc |lMYZ:z6R䨅7.>${wi(msλN4 1;.׿0"tK;ƹ^d ,[ U7#@F}0_1 >f"9OSxyӻ?|27LB|aEY Q@Lvsp i٣k- NqRAlղׇe49< >\1 *& =7G\@'Pe}̔b(Z9ё!U#>#[h((g+:T3w! ;gR4vL>0[[j")x6,Sy[»D7ðUtN9ئ֊n_7 ]s8i1q1x盿GKJh_+, XF/FQd1"3Rh7k[Oj8=9=eP" }S )n6Iǜdd4Dtn26aBf2f81\B޿%1'֭'hF#Lp1ݧؽp4oZ3[uت _70 }Ⱥ.1MiZ]7ж ?t37\BʯCB ЊԌ\&pu24HnOy:׿a+'sx|IU dѶ3LJ<蘨1Qvq3d8j:3%Vi(^U ,V|/;W_b17~ŪQl $^xAcA.>7=ݪ acs42׼^|qC&4'~|_D6HFU.PYdYyTi>k}pPCj_7LӜʉssQK;+"' !(H1E"!T&XM1D*rW4{Z3j#LEάT䊂*ak6gMN󬖒)X+Vnع&SYb`&hџ׭*&c&9)wx[R+6>,[FMS 3aPK2%>I=!o$$ɓRM:͑II)E+\KSRNˁ2crY1hTrցjj5ƏjW,R`+S|l6L# ^r J C/K' 2|>j*r,w`s0lڷk_Y oKh+?`7ƨb(7 jQ"+_(P3 ZhLlgOD'òxG!uA 7̱G4J'SLc~{_t{p{(?z Ps9B(:?'kQJ*L.yEǁI|&$L|шEKeO HH dG/@{ٵjOh{PnNPuMEj2 Je}<3WU QiB)k9gD3=Ae%͛+:)UK(5x(ų.\28 vo4!+nYzԤ3D r kh"*bU,j"E'MnjTR'cn/}ϛC }FTh?=rſ4,6ɗYkX2)EF|wؙ8+>)ދ!xѨanj.]LpfW+LB8 H4ض*fr5+"4 @fP,2;(4.i7}mNdז[9qĽɡRd Hɖ[DUVLۖ[qbcMRdl29}>M2Jg.DhŐ t21Jc/pK!8fb`ww񨥮,QC\QՖDŽ(JǏTo~5_K<W~wyk^,T)fcL, bs V\!_ ,_0ōJA55:q2N%ϑSW 4 cMlؙc|緾3':SD͑C۟V4OE3Mٖ%T}m*E;s;xHH/]&j- bL8lnNݽkxux%4>{㛾AUCޞG5'b)HJDFIuJAw}kVn꫊F'垠9 n9soxx+-RhU[6tfЕAYMh+F}Q({9B˒%id tC0jP9}tj4&cD[x:"E :b7|f9_bH!omE|"() )!8~j%< ?׿o5$*j- LD*G,:eNX85宯o|Ǜ9t1JeUqU|XvcQ+&=EE$̥$tbBFScx|>cI{KUmh-|jڊѹŧ=7z?ل'>S  \ >O]r9re5mIOixzU ]:5Jg)^ vm:CjáWK`3TVv7妪*s΋E UboNP Q)"Qr`3(P:ɻ虜5(dl6,辪<^K"~W^ th9yOO[HJUTIt?*L>ؗQ[VCpUuw39MUAʢ0ZըtAY"Z(&jNдSq;Βsf^a@)g02o !j;-D|%iͪ_Kt0ݘk}ɞ-)nKm3btϭW߅}TGnւB jZgp5랹t1JҨM&wR:ikRԜXEUhQ!dsaAԹ0A|=[/*G )d,{llLJi%Œv\㢣-\KBW~ykEe!Ms0=2+LA˨2e_ (dL}]'OFT 2JmE,V'O+e9t JY 3 } (1裇9ڜ0XU5鄾Lop3ϻ'?[W;G1lQ".+Fdt6 bI*K8tUYMښR,)s 41@U!rnD .\e,nma-[i8sKk`ZF33rI&.aѲO Vyx_Bӊ@L"m|wR=t/ϳ/' XG{sVO^aZ(D{Q8ͭz)Q X+bMS,J1eATm u="d![8rX#'{,ր-{XB8^tsC,ARf h=N'MǴNG RUeXb>s&DۊSGܐh'B0P#JTB faT8#Ȧbw"ƤBzn+L%}z]WŢnkޗYDB_}|PhR7 c:ŀDbp$O}C̨TF`9R5)ZSej IfxUuSG]D %q]}mT4hRF :fs.D.O>cl ʠRv0ԭM-`mQsO཈TkRg =q*:WAeg9u"FOEĈB۷B):*l]Um΋_LkZb`\1t7cc-')RG}b>'ϨmV1.7@  7Mh JaA+irhAiMXQ[qpR(YZye n)`c 7JGR1s1ڶ{E;tJ$gX*|IdbW੭Cz%^-wS @;R2t]2]UhkKL-EIf ޥBWMK)W*hږnHtlI ;<'~EQi-GA#)КVÚsݽa2x臯Aύ/{?NN8J;↪DV2NT;m`&1|3UTMMJ=e~_kYsNŤ4ŀ^)ӑ6P[C20FtZȼ?y]fB{~71)dCs 1$f9 0kEpVD Ų#sĠ9{6T[B@)E m#uSSѐ8hq.2ir|ׇ}7HL/;Q'H[LUV)1/b+êO@2Յ`HɰE6e[oǥM!ڕU4 !|V4MCM)i w?Kϵ,~ކC&D]R 9e!6LkZBS\6bTM%  }əxc2[{V>(F./n~Ѕۗ t,u8/$לEúi,!J:c-ʖ[RnRMnn!Xk)hkH1uc̈́dB&ńRZRJ\bdp!:fpgrѢddR<8j1w(`<zL7\`ZQ$b()D"RqS@b֭<يlsv3 C ^f(Fs ц=hzBp77+|+C˹Ja+#j Rtȕ90p]c&%ȓ\]AT((qb #|?6nV?%-T(%}kNA)AV,b ;<6 #nIɓG܀Vi㨵0eYݓ׎G CBt3YR;4VC]+r8\|>Б،)G֤,̑`0u靍1mZq~Ż?+cfBw?!gD3cǎX+3iĦwM]IŵVڍ^*E]5YO}HL0}'l1[.q)C)LYiѮ4I9aʤ;Y7] }^ UX;K|=~TT" 1`&D]1@ UhԐQ>qs*n&W?]!15!*kZS @NJՊƘ3R+k܀2z\L!~߄2gH/5XmW3CbT$RZ A֘5-\C&ϯ{̈́Z2E0F%).GVVH+-ʧƈVh!vo97~h2qBs]簕AE4xPZE7d|ou~7P{k-A܅ȣhh#P%DIgnV5n&3?W&e` 0t`J*Azhޟ?^̈́~,I(.khFUVfe~fB? > *ˆTՈFbLg~ϫRH[gni6T` {_^ ,o2qJȲ} }_2nGoI$0, } ]wz}_Ͻkx!|lq5?IENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_150_exp.png000066400000000000000000001076431245535672000223070ustar00rootroot00000000000000PNG  IHDRD; pHYs+ IDATxiu[{sv[j)VZjd5<ȃر !26Ā$@ US!R@A>PT@HLAIx"9gϾTCغ=[u[wxZxU'vn%xU'_wp+R^BҞ ?OatK~W۟E|}iOhO{0\c>[xuwS.7We{{iIձ GzN7W]J9Rg Ő+Ĝ=!nݗZKڻ~7ڀ %%:HU}ZDڃ#컾3K엌(Ai!njU6S3DžAS\9OZЃ'&SmUTWS!Wj$YJV +#'noyƫ=x1dR)SB)᜸G Zps7|m8gMk(mWM~J'^,J R3@z((cl@d2l7^cy+#ϟ^_xU\1J3z7iq_{TJVV+y- U "EC|F+NxWZg5?=_wc u"(՞[*\0qaGȆi7c\آf *hm'?Ͻp~K]U+|AiRh@`Ͱixݖ]Ԋ(Wk:R,kR+o{u|G@i4OʍWtҾ~𻿞3Vj-(P*4JRyf<ǃ ye͕>lb!eb̈Orw~%\̍vߊWT{Gx/5t֐S"Jk6Z)k[rS$S1P(iU8cT<(~TR5ll|?}ߊwf[i|?P))#@ǶVA+M)@^FqDH`+P}"-@(5₈ Tw+H*_'ҳ710s+6i;OBQ3&-,0pc<xļDmF+*R<Jۙ1Ʋ_N1xUI9SE!#o g鵖Ȥ O㇠dbX@l(+P@*>@`+TP-g{^()%+ 11h d*ET4[/ 9=cta,_k|kw5;PbX[YQ 9?;-G+RWp96BJ.Taal6=^WR9]\ݲ?;Jb{eSbZ! Rk_fR^Q_j*op] %0=1%eEP(QEbӂV  RP"xkI1#cqrseoPRicO3)0- ,J7w'?߄тЪbADo-!&J΀FnX V iPYDeYw 钵w ĵ=hjz@ΙT ?_wyó7.׆Z}C'Vs|`"焈BjR΂(C !P8;j]H%QJAD \PZѱF(A*cS8]X֌PԒPJ(%r92PeOggMSi?/}JcT!׊6A x@cn6ĔɩPJfY&Xk$mP3fj.TF8emyy 5sw~jTF,BNj: {N~KOVbʷ4Z)S;OVSJ%l#nڸ{rJ˂6Qe4JC2 E) PԌ9w[Ue͸ᄧI/hb*KHZ*R!@zyU,0n:J䉷>b=k-ËH+G#M {Mj՘Y*1"J;KknXׅZ*a ցHӑ)VBL܆¶w$B]PM5-p,RV(e o~|[rs5eW7?b"D[r9 9Rh6׷4" k[ q~qVj X5VD:D ZZ53-GJ.f{ct%ńgt]OnĬ:WR&rZ7W- |9R.߾x'@cei=Z D 1FaLעmTH~5U"Rf(ջF+pΑJ` Z=khסD1gB*\̂(T)%ᬥZa5Po.x)b76:i{r2tT&irJX2 Tbhpc& c5*jXSRA+Eɑ.ptr*u4JAR#9gGX'cWv0:̌4=[ͼ3M@|:i{mbL 9jA&Lʅ)b. %xߖѢ<%jT)QZ2(Ӵ`Lbw@1*5gb.x2 k5Ch "ӛ3JļREUny ox~5:eKM~W~^~*R@-iAiM}(m1Σ:˸; u*JN. ZP%1/H9N#D hJ+Pzd+ !@E,'gb(Xzk>ΏBV_񲬴YŸ )PK#xo@1hT(]OH1;fjI)9(-`uA[0xJ (ւb6i3ӼseTKx5UN0~ú()ce^`Y2";1\qm>|^2i>Ɠ՚Hp ȥzxukэxЋҪ$d5)ZEE5"RDUJIm~fI9bAT!QSX3KhmLHi p~q5#Ah@)|=F/\M_.i_w~?>j:ji4mz1 Xm2jR9VmhoijTՈdt݈sy((f^9)9RBm"ζւR @NuɄ(\KXTzD؊fk4 (AӚ'?#gn^A]OohOƐK!6-sJs/rt}OAJԶrΑi$qlR q <:5_%J98稵JJ 1 H͑f<vz!+>56bqnl=|s pl GZqZaF@o7W7H/J'۟FkEM]kEbuPͦ0uQ@Bt]"Tm ]:W%b(m]Bd8Zlæ.N/񝢵UQeh5"炨J ֕UibΔRLq8b(}K:tX3ky ?OG^V,~*hmWъZ3t(úl,!F k-!R-m鰮*-15;8=;cYw7Q)@ZpBf]fRX9CfISMq|y^K4(UPP"P*dD dT"WQJo_r#{TZk M[Fui {DK/:GJ*nFSD5h,| j^=9NNieޟSkC J BNm`E1sDiA&={#../Xr[b,v;瞭gP/T['k4nFZo)(n8Ka}-Vҳ/"iǡw6kM)\RK̚Iqr)Ae (n ]KßQj~mŹ%JSJ*sP׌Қ"Ji $ºC+68k^yKALHBLBJ kcbѰ4ޯ6vrBQK`DA 9p$qH.>/1MˊHPJuJj{ku]a s)jRmh &s݈q=%Gmy4mY+ V kTʚ5J@뀢PXaɡȥ/v3˼pvqL`PA2:7m৫2JSW"b)K5mV"]lGfCqi}Y/=_O}D4#KCu ΀M%_{?K(T 1fJ.Q)eB|QP5K#u 9-!q<-Y-XPڐsZ׈-23Z+²J3Ԍ!en5H-) ZJZ[˱tAI٦mQUPR MĂӴUśJV8SR"oܓ/%J OikZjl]hBL8 8Mphȹ0JV6(UH) X ( ?`b,ymbwP1J% xZ=gF#U $%TTEՖi*\(J#gbPr!h /p^XVh* 1b, 漳HMmNxü]%K/>K6iOU 瀱{b o-AV1%n !Dȇ )j܅U@44wXT7;60(jp$XV@\DW ZJ&V9erJ̹](imA R 7U9b!2'XVG+[nUD{ajIXᝥL=aĜ"%1-384U m xSKe]Y*sĜeYH)KY{c4)%js(XY慰,TšyLJK )$5bXR*zr\+5AɹyJ%RS&PE18\0'c9Qhm+)kt<UQRUQk&ĉYh:R F's_90֛Syߌŏ/ߵ&^2I݌1 "l0s3PX hcv8nkkH:J,Bu=sPլ)sO^QZ utp hV +hTJ&4#RYQyƯ #I-vj Z 5Zk _M$;/ kwB)atZ=aYʴWa4kHfWۣ-h0Tpo9ٌ(7!$IwrLJ"B-?$?'Wi?qbᅥ5A<8 e%0 톡o:u,1j1pDS+Q*KKr18);z׊A즕^z2; iEw< 6dI ?vߤUHAkO?;//JG)a]]=FN1FsG/O&X8pYY@GBkL$601GBgLmq30O+w\'DIR(\26Cbe 1Uk?3|=oɧ-mKa/L jPqJr7g7v942tΣl\Y^]~Sj{H|֊XY8qJr~?gyƎ$jiz1w{Ǖa$r2X>re)nڠ2-')4͙њp.o=V،uqJDB@Yb1H۶R։fR^mRAŰEahJ2zL˞/D- ^Tefr<467ws%%3sےΫWoԋz(HamײgYA:R\ m#bUzw0Uև)#$&u99λ1/V\JiMI 5Lx uh5SDC;Q;sp|~GOq~1MGPs@W)pv`c*w߹oØw8c|G_R -˼ux)|*K,!_kHæs`"Kl?cZT9CY oXs!9?83 99W !*$ܼ vh21+R skuP#}|Gϝw7~ 4X-Oy~-Z5 МbJ=金)kMfVk=;Z+κz 9cfwvg~se?B[[]O.(j+hK6`ԢArsp5'J[eHu9@{k^X+bYvK`:Ξ?.JAjkd8;<+7t{នA* *CKD;P]sE1C*qք* ]會:oZEM!3͜;Ӥ"d*ME Rf7g6cAׂuXZ;fŴ~U# 1~`Z¤.Kf<:d{~ -wis7|C?_eUmHZ۾mbhu0M{w>Mɍh=%b} "8|f‘s"%30#|0G'vhz~MϿ <}}GBxNᥰkW6x[g6TqC-kwu 'EP2f\*K̤f)%6G(80F\ CClH-F.tp(UX"mnI8'-kZH1s+ 8]C^귊&%xm ׶t:Bx$?pt;AHΉLZl9 g(M9j;EwO~mgRp8ǽec4W7Wˈu` %)DZ 5*R8tEJwRRcyo؎o"GeHybbMy^PsӼqkQ j%T;0}0bDOҗ/irL5eQ8#γ{Mu_q} ւ sL1NI48JSӚL'8:WiT&/Oαٶt4_1b[R1<ޟ{!oJ{K/? b$Q xNiNR58/]P8'Ɓ2`14=B`Td(0Ϭ=@E6Xc+Śn?I~~ƅqRvŽ gUcpR;Ocln 8":;w.a@G1,Ԃ5P1`,sΤ(_ )g˯ebݰj[Yqn2BUb(jyp9VZk\ FH5-"-蘢{=t*qȌsftڠTA"ANTr%GڮŘ4A=;y*jIڃW^~A.\,.Z)&h}CY6/:~Czh,PGx0~CFIs,\%.b,_~]g[y>(1Xw=_sg᭢$`LevXO9"oa$7"$oe=MבCw+jG(jTy'(()¢hۆ&[\pp9NJJ1v4zṛ(`0ǑR5u{ڦ%_ -جM[\E;bж*9Rjޟ4*MAs:ߴ8O6=j(:n{[?]7{ZOw˥aկR AJExבJ0>4Cchp:C:G ׶8Ӛ')bK GZb hc٬:+17k|~Z3id8`wvV fJk0kS59Lh4ywHzBJ\6Ħ_1#Gֻy] 74Sj&"̸K0J&1x^u5SJ@G 75۶vϕxag:qIUF;rZ@EF8RQL,Xj\Gx_UBY[)C7Nn*ZL%p};(ء-)oW^[Pٙh=jKPu1V@9?_==lAiP0ΕWZ)c$Dc@;Sbs0Ge}$Dze k8m[QC@ia()t5)M\Z+|B*|yx\6:ԧ㷮XxiZ}0e%RtH1MXKa3Vf5W0 R"%ŸJLVf7-sj<0嬵rACrk?u/?ßZ-(Q(-F TЍp|C||җ>>ͤS )sIS3o)g΋|΍ YZfEY{>4Ȉz>me0E+:*a 5W+֫Os{Vb:AkNZ \kMI_YQ $ 〳Bh84%WVMgްڵܺӟ,sib6x赢_d((5REaThsD\@(Izbp֮Y9OJh]))Xm*iݽXlR 4`c^>-vXm69p`)\^_q~q9U'Yۗa'Vg( a$WzOқQb\qVQZB FBDŶQRJM0L4q׭h>?&]\g`2bE W|__ְ% 6TEf26a ŐY{eUOQQ3B@+ΞEO |+Bz^xJG H asmE?Y4!gRc G tdRtx؜=A0i(]ZB$$$%Ra3#VZIճݒ(&8;A-5{(9IZ3/}rBSo5a`"BJ#ވ\Ҹ3tIf'k5=qS O1(Y[j—)xa,u %S@)!J#et01*a5%<,Laf3ӞiaT5RZe|9^X 劈 4MҞx-n[#w~18-R<qsopo- ﷢DRALi_]KJXR!˨ %'r.YU}]kl_yWZzLAC|ʉcs1/x MOOSyߌ]E,--T]AYƪJ"-j%8ݮy^nAi6qÑ7zYs&~/U;u>4 8RBW ao\%R$k<#] {% p%@R%gb)%3#{!q}8rr-i /}cYK>RUD;0(%R ,8S뼈aФ%HOt*{JO#1JEӶ sNF82sL4]'\(1__I]y?gZ)**h0NK(ÈEs Ѿ.O7dC\*DU]ɂI/3Z1/pF |yb <Ŷ)qyyu۰n[tb35h6ڡ8J\U^%%YM8GN & $p襟ǰB9PeN|s!5Jx/R$J;E5ϼy*,clQ~L<SDSvsVE8 EƐB$fe8iGkkF T5J}GxZ0Ƒ]aGamc%FSf2S{=qږz09H $[N]SԒk(ȥLQ+= 8Fj) ܭVZseݡua 2c4sDaZZ8m@{h 6BIQ$z9G)LW ?M"0gƘPPs>i*%2eh6MK,Y%K΃ **ϐg^;GJWHRpbgyYa:IlZ>i?ᏽrwws<$dYOF%@NC,B{*;y%_enœK vr\PBJڷ) IG:cTEMCo=Y*=. &oJ0`Hꊮdcr<)qڎ_/i:2L;bQNdgׯQ,3W"LN@ 5&W@$PWRVwڬPf +Dȡ4Xڶ#Wk(Usc<}n6ܹ} 5!<|Crzj_ XUǮ %{ RFDB VkJqs wrV"zKA94 {iA.C #WOx05 ģddDYB4~4HNe [{*گQX"(Yc7TƑS0SdNdVS," J.g^r[\/1<|G2.'pZB4⫡jO-N#F;E/Ojno{08MO-$A:1J͊,81@!_$۰.,rMXzE3+)A/y?S<5ւgypN4i eexps+a>ZoՋQTr~4e! f\/={#R3AOΉZ4U,r0V,1ng-ix 1gJVhC;/q;~~y3y*\¾>iUSNk&'(v5-en4Fu&2eVDW`*254q%LiyZ*g ֶbG@52{, %zR 1˪Zf2b_SP5D(x/Wy OQZZOJn|ZI{<4W4Iw090%F7bTsyO 0~%a1-B ?gG׵h9_SS$kێÀ6-9Uj>0ϓd>34 5JUBV2JRk|?eΦYq {]*c (kgX74F dQibX*M- / zqjM5)0 r4債P-c?WVs?954u_Pd)QXkljmQZH2ZY:*" s l}?_ܴ|'!ZYM®Y\*et81mdJQjd-VRPP꡵-uI% $׊b,%.z2sp}$Z5X+"qc , JjE>GI˙ }ص|w}J+TуwAMPH. Ul3?",IR- ),,[PpP5X*bZg/JkBY4HP%W̻JjD|g~ib-bA? cK|\Thh10#[A8]1- ʸ0cJӵԒHL) s$q_;;wv9$y뛧F̮o{ER\"^]tyfsq i~Ҳwf&@(bGXZoJ-^EQ9Wq'FufJ @Ј!272n,4/P*-kYe#sp28˯+ŗSKJ21ड़by2W:k_3oͭw؜o8;߱=ǘ(R<8d&^2yֵ&BLgnq}swiζ҃hdM^JY.EFkdܗ %KXFmT2q9C=Ve5'߲N)<8+Z\Q2昱N.)4F9¤<1ehkDo~5e24'#Ǐycc0ֱl #KXU@3y~j׵`E KV$]K\ʼ,1\RZJQ6΢(/y<鄾eJ*GzĺXd hRѼ55d ;(tf[ /([ěi}?{-n={?XPMPPb%eIݠ1^ 4J?n d U#;Hb\Ζaa#V54PrjĆ2jBOug;<Z1V=+L.jVT[D,]BN\=zDnj Z %I 4=U90/[_= JUIN*oJ2J3*ͥU(eW#\%2i8CqͪV^;FXV)?J,,%*`ZKlVMRXidz^6UB$'Ẏ1sy vgk>X)G ;gG&!1K5q75ͼ/ӟovqWp1 jFxM5*afoHSJyO]CF/%Z@;!|M˼ɛ-`1N–16r"/竨kbR0Grt2vs.aą@Sؒu,NE \ߗgT UIkUa^6\>xSn]{>󴫕\8MD"-Ny*l*K%D*9Ϧi)+؆aNrȕɤ ĬTY]p63h*sugwߏIbw$eI U 4ƖBMz~2!%P $%DۯAirIu-q1Oo[QaJ8bcΨ($fK[a՜;;ZVU2U` 7 vS7ma.눢p_y8cګ5|oX^S,u0r?6d%yO% Lx<0M3F[B̵pgFiw{Wqw_!JU,}Պv4qd^bm/%59J"ĉ8I2GY>? IDATOVAA*qsLs -tҮ{/{vQe.09"KT, QQ1,ͮ١KZA)IVJQbC1}jajra$B<[.am>#A%Q*F߳hX28WqhcvSq0GO]an(75˖F~5xy2FL[`!2n$ĩiuH k* RBkOk}-o~ > . ɮֵBR:|f]QjlFIsV+W*60qN')i##Bjivq`Cj$DܲgYc _LY ɑhUPJ2's%i"x%-T*1q$g/q'9kSHAP)+\!{8C kUȣGQu&Mt:CBJ,ȅeN;P|Ґ'@߶^؛/xCێ9)j`h1!NRf.w!A[C-il>hMP7F)])4O$,n0_he2(ùՈ*>~H 4+GA'ḆI0)X̓{:gY ( cX$,C4G2] 16/jIV : ]QRYd8g+>SWXQ"w>Dvf0nh&eE%zc@BT'Gk-kʾmʌa tښ^#gƑ8߱>pd6|FcqMnl?o,gmc"᪊fZ,.ULgaP@蹰l6%8qi&n{wMi&Jԇc]%iky#Ơ/"fH:_T0L:QYV5BFqXWᜐr5!%reװ¬ACRiԌEģ̃ƌBCYRͧ\d%\HVOdQ~YR 8>8k^1v!HRfR`0&e!^j.\g]?kn#[b V5eH!13jHqvޒEie1Ê2ǾICuh7\j˔}Wxrvw'o`1رYU9is Ԯb:YC[ I5r Pz/zړ/uֱYSNnY}`6cVN-BcK@TR*(Y*X1(qJ>`Y,,rٔBDUi\HGƳg;KwJd7V|F"ڋ2XȥSR@9v0RXn5/;NK̐#!1 Was=n![)GO^C=>&̵2FdˁmI:+>00+>)G=H}7o"倈vn8I)N+Y+ ,a8|Z1}DQ*\F'.[>t yX$|D\hA&2#H#&L_Kklw|GIJLRV:ucdw̭cf N g:,Xغ$Ǯq DeDc!G>⍐5W)YcXp ;u*/x2xB$0.p^rFes.6D(ţeRT3_kurY "4- T]H 0*JLQST"ނRʏB3\6DV;'UODlTj㣍g/}17Z1nNڽ 8sb#>gᤱ aw9Mz0"Yg12}1$<,p|::7ǧ?iuKlGTi&s;ϐ|#NabPjP>^1g}}^Ȗk ~ f-mn1 /?ygx{y_(0Zu8&&e5:RY2D稫IJ0JJEνVqnioi@mssQ1&sZ1c!V(z&HjrY)gQUb?ǧi5eƑ#o9Gȱ;T:8h[葜pFϦ,-TeMi7f:>Ɨ=7>>{Wܪ:48ǪQ׍CFU,=zOUڈU.r@bb"j2䟐D]>L,I&s$& #,5L/!-㨤)^Uq`3eDql(` \[t ZB QE=*4]Kb7mLi,m-u L'e~BXn} Ź 0&LF}Pbd.\kٜY?zCOqM, sժ(cgij6^a1p1RtV5VU)gf~L( XZCߗ冂%CLl珱T[6;cFVI@eq)05"NV*-GAkPZԃ ,Y2(i0K i[q^J>Ev,3!#Zi1HUӇkpR3HPUm0l/[f>,ʆƨu[Qgh& )f咣[Ga:[k^ןl\xJI zGMMapOҴsJ9Pxb q(-E)!^hC-  ͢]VEN@5Pr[V1a%0bŐd". UR`5р\jG]$)!th5g,Mf ?v |Dv {Xh̄ Iər"S ؤc ɂK]8G{!t-ś.\`:\,jXd##2h7SIKO9iW>9/ Ũ"oxǖfU*J"0=UEXt׵%OKh0\ڐ/ T\|-&sb溜X=%&z 4yV5JsPjDlŋK5B3g\2Yx˙l<` WMsXLj:?ATF^ We #p9Nt3m#d&MC-Y_RRJUr`k0?ku))%KUֿmЌW:5)ʊm[(+<ͤbi]bbggqg$1paDG(Uűdrɳ3Q7u3A'\6EʝQ|˫ko=IU<#HTjJIB"fr0 owp/9\=BT!@=-ꅩtU(zL\g9U מdS;vQ]l8Re4)L^o|Oyr=?VƘ0CCR&BS\MӐR>H+PTf]1Cy\KV0TDu&_[uN+ŁOcv9>>G;_O:1upkqU<DlƐ!u=Gvi*El%)USJ ~ת8:۴dn;6iF|r$VI)b5~^z29$0TR1C%@w|ʼno:Iȣ4Y{A B%Z2FTg!L ^.X:qߡ20^&*mlvň9|ePU*ij֮b]cRH̪T( OXM(c6+LvNdMDc~xK02֖9G( ̐ %#9Ę9|zVޤq00N]Ǹ SWĪmmp˛ƑMe8xwsmş2!\:31'ǯMTS%IDATј)'3{Lڶʙde&)H/ T=ZFfKXu1J/*ǻhY̶֠|i(^*rv~9v0}3=b+nvbA.(scwT5zJ%G&Ϫb |ӻ~~.IqEbRwЬW8 #Ȥ*Kƈz8^-)?*fsRaY.{˥ꪥP7J&PhC1S#7]7)3<7l2cQ c 6LTTYk D@/uMz\)ŅA?^%Ik2h] ek?6jR,z2aU*zBbI ,yx[Jvy{&))+ 1(`xӻ/gly;{s#O&SlcV }b K%e[MSWx\9ئ dTԷ_֝kgmF*@w吔LA]:#g}G !@b:m1Y4 >1[!^7WIz(Kr'}ZR$_3@*$4+JNB2Cr3eEcY{_p3'}ڼfzZh&1vwz\PU)RԷmO̙n.u3!8`ǏfSu{~`:mHUA Ԫp}MU|-D O~c$cc8NrfoIEdL\ &B30^ <~= ̧Y`(V1h}ǀFCG=e}9vDv9Ck$@tJ&1 =UY]_?[>iW?$58a{BIcQ'n/0݈d:(8l+-]e&V"73Қ9D|qYG0=VT#b<{ GoM,!'r,R19GFue >3X>PY{+yCH 1+>s?bKef$a *2"3 ZM'n=Es)TDM!CZQ&CJX=H59&US_l;Z66Đ+V TZ*R7Ws̄gaTx]YM eŀ;M?Tɐ{3gLHCsMܵ9~ۍckkU4z[Si'2j*kY,ѳksʃ+PAI)Ȥv4uM(L$03%WNƳ2iWO!*%Ǒ@/{*R#N* {zhAg FX[T7S>0k&DɣX-1QտEQښչ|:%Ov,=.m[h^\J>JKD-#=L@B{+W?y=xvukRZV XrsԕcaAPd91r !`!BRJuM߫CPȊZ.[GN' @=+@)+tCQ"'tpbtEgI?] @ja@O1x$%'3]#5>DNzU7DBj LGc,LԤdmp>OM"ڑ'CE*eP:W1gW2?xƯq/e|uAfe%Qc?$B5qDYtKW3Z.KrR"q 4Mb1"7zơN]WxaD|/ň5D *Rp L'_o)2 QRc\'L& ˡSQ ЃuȩXU#tÒYSed=Í7"xO0# 8#&OU a@4zf)!zHo^zIj~~Acr4H2LjЏ;SU fH%#R60B^c{,!&_stNJM8VbdrҎVdo~e/%_'͎ c]Qj~So;j޷)% Z.1j4&zvdJ3+IIs j.XF2F9HA6}GKϤz>NC`:sTo=!D$`MI=ޫ'XU;^yl1TUH^wXGbP^0@IJ.XZ6#o/@z>x ~SUp0ԵED3B&= "ʐvVYdZcw#&S""?^o߷)zF8(@ ,O!~ムL"G-S!U)Eި W9bN&UEJ#"al,-7z#1FB ;GQ̮i+|:cB XkxOJ_K_}ewocSGJg*SY*YFcΊDZb;{;lĘMUY0,1&`ExՕ%sH~/z^"_$B5:8>bRbTTe^Dzxnb(nFrv49+K,M]oy/W?ル2lU1#9Y0 9[wZˎ#3LUT:vmi&!SWb,1 Fx+|%xVc/~C{ 0^7i^˄f:a0Ѝi@=nb0d)@AW*۱jbN H]9b㈐pƐs$1T39Gսз_,UWk?7`:]ΒeIڴJN0R{VzY\;weW˃?C k[^֡ r x?@ 8CKeU?F!T|#Q;HXZ\xa~;9\r-Wҍ٢q=WSihբKl J\-pZB,1@d6!)[7T)t2?=;NYz^d1 /L^MC٤ZҁJ_n\=ignXc݄,`$`H4uC]MhjJƨΗoGKq 'ϾnleI5V!g"C]W}IWx LD&&]vjTĕ~=&3 E%٤i,Y+ҮH\>o*z }Sgk\=ian.W:&M6IENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_165_exp.png000066400000000000000000001034411245535672000223050ustar00rootroot00000000000000PNG  IHDRhd4 pHYs+ IDATxYuiv[ϴsmw7im2DDH0\"+&!H" HXLɲ"_(D  8!vOUU眽3sXQBW}ŧY?Gz{~Y۷~U/}xy7^y!jS\^}+ H!qw}' qDkwŷ7˾%WG~"!`VVps8 ]e=<_;|gR_>Kl?r xRQ@iFRkCS( .x/|*zv}5!fx1ScOj|My o~ħ?i {Nkf+ZZz"\0A0 3W-̄%7AyC0?O̺>_z^{Hkƚe+DGB5SrT؈#ב#N<< &9D~' ;=7G+AG_KjkhQB q)XeeL qN @0m4?V.>5_)Gny~ͬlrM !p@FΕ\<)Ex8%DuPa )|5E%#!zg>V~vn4gW~[Oo;/]/-^']9#9G8GiúyM.T332 ?B)R+% wFs0Ⱥl<~1g>%~o; |^Z}#O+0@L^Fϣ*byf '035DoSvs gÁx0sxGoy40/~[OoWFmt 7A N'BLFƳCaKBsVIA< P\` 啋yDϟܹ S~[?Wy!. _yW7yYWziL{LUsN0fg +h(wyXf;?~A.p#@j "R[ $m5>Wp6#?_5WZm?K 6>Rp"{sljj'+9k)2  VKx0a k(`ޏ/3w_}Ϋ>$5T)!ksZ0s8?iRc!4 pr{{Gͅ.DF+u$iqqBoNraǖ+m(UA{1%3e  !GC  yO>MCokoo fR~󯧵C y1%...ӚRjvn|¬Uc"Esp@L`˙yvDӵ7q\6i DzX")zL+fFp^\Ead?pf׏)%3 1r# .x!QhQ Z)(>&u%ā|^}'@nc5yz<{BJB1K !r\JDh !S׬9A+8pZx_@ϔH~Dy )ji!Fθc+\ߨ Z)yv\c!`P)fXixqLB{?@Y+#!E?_-WB~`([uyb-{ZAQKUeisi8EY \7\&,+qtÀjQ BCt( )9ӪRj!ƫUL\D)!Fwlej b X;ح _>)G-O#iͿ,%Tk Cy:OԬkؼG hSXH4{OR%Zs8TޔRM'|E~+77{c߂jc#fJl<}/]'7UjUv O Ӵy{F[Xʺ.43#4B]φ8:% [1fR6yf# s cJ!g3k8o ʊihp,QԈ$;rZ 2>`A >Ԃ` npk#8sݙi@ń'OJ卷_~7~oot8jmJJkFCbL뷯;adG0gn(7TWZZa8p'jn Nʺ؉0@P"[AkJiiLJȘiHQY[xwX0pFcD8Y̽5;ZV$x\nk 1PohP 3)Df7z62XpI=nO΅xV! ^7(zZߥ!Z=>^{=)q T҃{G.ۻ8ν.g%HJ"4;q3fۍCb6W ~g -x0V=ZZk8)i&+0O# ˶Vrd2% DʘNfTNǍXx~x1Sr 1F.fNka6BNy0NLÈw]a<\ :C!UYՂ ZvlWftz / /0/n`Jb砝᠂6V2(JL8l"kSn;Xa ,[%kOiCȹ5J0΅GVDCؚ\iq~@,d;dz[~nqS[cYDLO|+YfVHΓ okʹqX[+`w=w["W*8iک6  2pZ3Z OQ" 1(Mp1s9FpuUxto>=V{зVsZ CNY[jEI'J.ٶWa=$ gg7qN)Ɣh`&L!~>˴iq/3ee; 8G̓ $x:ڡ{-.] wkU W sssKTR">1&|:c`mkR8~C U n"3H; xڱ0]Y²tnHáXF>؅ŴRu4$>>[yMzPR*!8N8LUǁ{L5cLb KkT |$8ߵa RNߴ0 m'Zh¶nR>܌,kqsX=fvipqXS)MD%jmN}!=ڳe[R Lb@u$CSF MRH h.XBv(}S),j ucR NebbӮCUY2%o='ʲ"hieW|ςï=ߍ_c4'JL3V+1E!w16=j LύZ =S3$i ʆ]ӴJxR$'n-q(3֒I<1lBtЁfq1&!%ujƛ꣈ `tq SnZH1jPI?{N1V;()f+JxTβjZXWϫZ6UN9rӊ)Xʓ'77%~HlN0M<{vۧɹ|׳I.4/޳4i.ٞbX֊zw)ҡZ+/г+*QkԊ8G#۶](znNgһ8l~xujeލ\`<$n[&D.:f='8!&G9޾AT ZCMtX߮vWZ+J6Uv8X̼w)v?`je>Fr*R8"ySٟy*)UcjttTG !:5.eAmظ%42R. PZùF!PP`.|D a $+U/jF-kA}gY)?O͉_mvQkJ -n PԆ腿Rs뒢f Ì)0bpSsIiPT1m ^ؖRӼcYWRp8 ā4{r`[nKW:9[`18q<{GWRypu3iHXٸ#[2eaJZ3 ~BBl043ذ@CYڱZhU=l\]<ǥ *>TE0{ǩ4B{O( h\ a~M zQz̆^.d6mvVbFmmx1WA9gT;?HS*Zx"tTQ=Z ))qt}ÃmGԻ>]'0vR Yo'f$v3Qga8w][NsPKf&V==~a &sx x0/!p99Ax㋉)tӲ8J a@ J(4uyvZ3n)| 7S#WZb3"C{Zk{kZ ? y:u49j= a`HC-g&].nֆy$@ 8m;-x1U.HHd=2Ƅӌ;9*n \ X=ǭkhBGW bw`N3/>z.r:b~ev`SŀŊjCfq6jGZb n}Tq0FZҠ}Dywۉ>؜{<5bHly%HY76HX'okƱZ#T4Z#ΨŌÑq:*}tU# #P/fȸx/!RhRb/&SG ߸%jhΨTBf!Hf FFy`U01a'aB5&xW*j$eMWS&4߻1Me!M@[!XKB0Եg.-oniI CX#Fkjkⴝa3G+O{l1~iϴhi{?#C{`wi#!xbJ8viѶ'ȶDZ0;bF.ahXוVV~|ԠnLɳۍ +.w\ \'aJ 3ASl+<ÔI3GhF.A' O_8^x<_$\aVTPH+!x']D'4^Zƶ-&Ą5{vq)(C 1gZ74ɭvs-ҙObOS{WߴamJ.sBN֝xFjFCq~9Z?_qW'{Q\͜Je"OcJkTͧϙCK)9G_C>0^hH)>-@q@:D"}B P3y~[Oyy&o'f ƄgwL<\fv#NT4R-5ulfHSO?ϧ2O#0c]5Kβre1d0r]q~Cy{X[ߴnCVd" !AHPH,"  ."E !qr $mK餭nwTSu=xbIg{{3biE- Uf0mr>ѬMveUmm:RkB~͟+KİTWI ~u UK)$A#Eq;RfQiȶ`_+HI>N)Ѵ0%`gZaYs,:2`O>z90`%KkRf9W'fOZ2qĹPCOcr!k Q* EWVd]>ViڶbG=r{g[4F9qip+>+!ƅuEIBi-Dfn9RzjۆQ1R>}n6a}K۶X/^zG\5'ly=[Qvҫ6bY&zޚsNhZpuqisZη{?a2MZ%7*vf;8.|%8KiaQSc<4^Yz F J(SrKձ)+wEHY~Dv1-7Á?<-kl7F !}O뙭e:,`oϯ߬H|8JއM;@9"E X~]Ad%3(cJc+P d9beRu,+axg0N4i8&~zNƣ`Gvhү5˲(Ej@,#wxq@2CЩsmvP-7#1`=&J^PE?eׄZd#c\hKi-ʀU9:ifхvbt:"VKk c<88v{b7h`!$x߳- Z)53/ R41ڮ9k.a_i WTD\6 J7]lJY*>kN%²gζ5tBkiњKAiM۴ |Rh+JŔ'2w[.?~w((,F3lak tZ2cZ#VK*QnƳo n )chüp8M -t C$ov\猳Ĭ8M ^}<|h.%%q- +m;P&itӆKXaw,gśrJn]QbWv;ж-xآaz2zCXX1R䦙R5眠HԲXkqmۦQI1awΣ@kemŴ:VSD@Z9Gb*,.nJ=C7  8s " jdscvɄb`Zc{ ,'!%Re,<|{w,{%7vci2I ,b$TGiɛņx۬枌Fk x(-0 i|GJeY?cL ]+p7pض Jq8Z~dA RN?w[?Y_)zвrt?X+Oe)/E%BəNΉ,瀵r}_Z9ẝ-e.sq~68ժVFVZXm%Q*eκ{-[k|h;869n1SX8,X.*L-4Vs =4VӵgzT 5ӑo}[]C34XI!XiVps {ܽn|) lJq}eՈi²L5r+ޜw8t S )P0Kr02(Y뀲j)R9%1xgBl[fb{YO#{œ 10GY10gtz/ճPR⯰F Pl]B*qVжf|)Ys>-K3p:+4.8qN7v90Mm01f|'ˋ~K"J"wc e,VH$5Ru Dvh14-g{a%'YyⒻ X赢sF-iՔ% Q0 h5MC; Kb[ 9g +Ʒpc0t`o4u%CTB]} :qV%3N.)G>pup66]G]ˊ6Ȕ\c|q2Zz~(YgV@Fs;Dp8Q s\Y5[nM/ 1[+sgF 8kd*SSB!  ܀_O>ཡL7rΙv#<ضVL΅#BZCHT/iZ;юn%kPZޠQ# *u-'4'G6]Gj c'(dTR" @d/(B DcNئL y"Ӽ5) [t"pk,JHvYwżqV3bizڮݴ'+o\fC*KRr J닗ZqNBs1-}ӥWJL<}_ڿ>b3@kh]YW= aȭ/WO,ykgYfx9',[ϡ?G*65}>Z+`6[~u82lriѶjme.J:ZpkҼ>ۜGxcv#FN/ٵ)'1V:ߐ7-g彤@c ZR6rfRUrb]51I2;M!y "VJ"*oq֬m%bZG.%Y5RcމE1DUikMOAkۿ׾>Onc9ƷrW0<1g^{fe<]tR^]Sp tQRNwd~~\A,\]]eME C &g239paYNTw"}yw Ob35mBK: ؠa;Ng=cA C(!0'i"WsQv{i&CZB//B*,!RJW#Q"2b1 (g`<㘡VOp?G_ Zhrn,FAʼiӈւd݃7(USd CjK]6+S_'ǀnX cē1y%!N:E'4:*-\"YGPxv33<9)(/.1ZPNX2IҘB8ht3th+תEAaE{ 䜨"H ڀU7"LWӖ9PiLB|߰k:yΞ<~싲=R=a eImѴ4.R럣k=X+h  91cHEC`؈*7,3yҿ_~Ŧ~iY畖y kHY녡*2U*Ms0$,-G*6Qhr5 '愪-rtTTdz~/W3D еPd53b}.Q(bgz$$Lߣ T i=sN^y0myyGsЕ,+ZlR5䔙ǑP2<kQKL(AkQIk/Q*!yE\T&]k: k,6\j8mZX(R[8O z ZOڬ獣D\MӴWwwCZ5yLYn>S)ˑ\Qі P p%UI )W-[iELA)Bո9ęsdƬJh@D kp'Ϟω54֐>~GHS"1xyqy;͖vq֑KfNb+1ⵣ{Te*JTV ^SsJ9#ݵ/‚2ņ!Ê689\q 1eBئ#ٞC\XY!pC%bEu*OgڍGNM88m;t^U9Gamtjbh !DS<ޯ\,lc]CV-3+R[nZQQ4I`ҊK9U{IԬbXj#KEBEi%8])w:CQlDxBH@ ]0+ejÒp̌l;0T0)U@ԥVtQr>f* Uq\[1H4O點O -&GJТJ2iXI|+ƅl|f26N/+n6(`-iDr~6*V<5] y#kI:sjVEo[7i7 uHJ3iŢ5 SPTydW9RLZ5Wѷ VJYәU%W$4MӰl軖Wªi@%*&l5+&Wh#M#wIeaNVɬ9!93 kJP}gv&/OAHC~Y&Y^qYylD"1Dn1 <ҿwV|uv6^VbO|կۏ4\BU7+Z&},]1E\fڄԿ\s B09DtMj&t5^Ʊү "RUKԺ^ж `i=O3]>p"i+m'R ڊbFXsyl;wb+4j;v[QV(4o!x_SǚB(,h'ř .1mouFUklRMYx@v늌b]Xdk12?wX+i]UשDGk0VFp]E 칞&U*5t:QzkW͛8Zm^Êj@io7~l)Gh\NkJ ƄUazPVjF-;c@a'@Fi 8P Lv,t.mr-:gM'jU+%b *1\(aڈ :tݵ#X_\z%IUD)7)z2KLs`Yͪ>95c{Q5zH\d]NԅHBgd2,oڹ$jC)"Èu4OUl??_&'8+]oU@JKf1',W>#"ՊT!TRpVSdr|%nH^|V HF㕿-,e5޸ )F|-M"pK P&HZ ! [P\JS)$B\@8NDQoh[j7,4iS\8# ecwyEV>*gR%%ۻ(%1%Df{æoIQ/^`zqsg4V\lll]%oJZJe$~}[_ }ľ)Rt]Cba"+ {!Bq/-Q1Tž@1j,FWT,R U F1USJ$D}9mֹZor&SZNF;MvB3gqd.43ZYT%JP0*ْ_ͅS9LX&|E㹳9?2 ; %H/p˪mXP+jUXRōnQO- P+sg{68xŵcJ ]+F)v q 8̼e05aǒ*Soo_z_sp%۳D*HʳRJҒEK='eA:ۢb3\]\yr=VEEUdSB4SS XCb Ki !J[G/[MXfƧ/KAHK#>d~g/!T8w\""9%PH& cvCOӵTiZf7pv*bRicV*mU2 5BIEV6PKrA9~Ժs$,cע"Lq<ƅRqc^ ׾2?[?GUI>-̤yهNGtB#ߴx9n1%,lve!.ݎ^_8 VVUp,cT5EC<8꒤c SYNjUSkƞ"ʬU&l~K`+_xosn {]h5la_2je($YnjeU'͉S-DBXͽw8?fi[|=n+ UP 7Z5 MXjVI8n//yy}MHy͹,M׬}E)8k%[m8yXj%}yŇϙrv//?q[ty"FLzrڍ%'+nm{xbuSuE]ӂQ~g{,i{1ed]5,rII=e qT+#ozQ깧-]X])1p} + R RUj͹RjPU1LDXC|Q+\7>/_?O֙{xp7p_ȝ;g(*(lv['j8~Ҥ˜3֡*Xq er%엗/_XPbDujNwwہ?+Biz^y 1',xi 핻;bL1d\#*mgY}g_Us}L 3`2&@HL%c2"$ OfbCL,rb8R$BX?'JEFQDL=SU{v"6}gposoSU뻾s#'mRVVӛRh_v v@Tب}|99뿎o6Wy+L:VaV%w65m^jeȇh0Og9R$N"ځA*EjK{AHgn5,$X 0Ezi "9/{/g{4 en҂ƎiqYwq0s}|fg'{K0ଓ™ TjО!W hFCԧQlʠD{6K" ܞl~q>Rr>ӜW4JbawÕ;dPCV-7n`,#495yQ7.5'-o#AS|1:*#q8d2R tL{sV8w;^}9_*Y{]lX7>bTs[Ѵj}Z+uUHy͚1wY0Oݸ8<0J)$X6d ޻SYef(G#!dF$\A]iB8LxxPwG2勺◙Hqk^X{'8Kamun դlN«qVh>Sv{><7~S5q6)lnx0fVAÊD̚`#fsO??OR4 A +|-6??jN<!<˱t˰ (X&N\{bpsh&EIu:nsMknG'~] }A%AFx>RMA7Zo3_i"ž` +7NZ[ij8vw(PKX{xfNɗ=OsqqgQavliFwZ$xr ܂%|g7~b &hW4 @EzacH$1sa {b&qѬnB\ZPKX n*x6d[q=N, eQٝ$ޕZ(dcytA֑806!ܔn L B,k:jߊ]# ia*'>P[&UƇ~S_ay%~seklnq^54q:b罯6]܆e7ې-ʲ"8 솺 @Vpg^"'ԡ3zA} W[ve)4t5ǫSP@㟹{_LZ~i|?_gp+r2*VÓ!w5w]&c2e]"{g~\__{lNk! {1o>rқ6}7GG׽TuH1n2#itT,!F1=ZCL\w}j`EznU[^ĕQ?F/ 5I:ź% hA@g=>r2X*N%EEDq{_ Ʉ'>^@ѰļBji: d%oK<`dNjW]kݎR j $c5mX\t唫r.>~ϽNkz ?ȹ'0$J-L)awϋm9 aAIH0=jqFl:pcX\E89I)*a4S¢5=+R@>RpDX&~PW X!w>OttO*m],rLbw:npG^^U/]:!%,)B2ö>YЃ"FaNqOCPg$g]Lʾ4˗\sGtK' àbj̴HSBoԴ}dPŶX2[$DqtȔYop>>o,3޳P%ܸɸǜEnߐ`=ty1g̯sPdWVs8b6q+O8L&DhX^;iG,tjY89]qK[e1m{zYyRxaN+g3P0UPݜ#oFFhʠa R?cئ1P܏8>[' Y{FDRjX$MaۣZRznq(CX9y&R1WZIDf OQY)X(6'  -Tʼ@溍5|gJI@;ɢAS`{Df΍ťЎ{0niSOT#|˘2Ug8eJv =tDJX*!+Exb[Xe`,",Vќ`Xvo+w\l_Ɖ~8T$9݋GS( oH] tN/H8TK ͅqR>#5ZSF"ԝKƗi噔 %3#Tb=^Eh,$/l+j vS~iոx2 JPKYMΙ2S s?W&I,!tNc=_)J{`A9fXNm"Dv$(zF0|TJkF\_yw4)Ōf!̳Ա24ws>/g5IzJ2ijS[Hcu x(&h,(∢s9{7iD87 +K]c~޲a 8#A l 3 [g&_VV_{yJY’v=V+.V*߽vΎabL% )qGLC2YO.yR5:ؔսcj-DGf}w.>O4˼Ý wJfI#C!dpAe\$pN~ɤw֓[܋pNM3Zw;mc_%V]pciFvKĩU#$Ya7Q8YIY[fK {2!4 Rc5P cLC([tW.R j@(]HryʝLְf5 [h (S7xB5?oHݺEśߏ>8gt?vmNH2DC`&ĎD.dT.94~"&D¥Am5 㨵4TyG(w}oƮnT8g88*=18֢T RCt7.&ۿO-7_ ڗI )g\B.ph8*}Ѣ"u6;,c&턀QO1ӏY=8Qa1<L&ԝ1 ¥0ƑRh_w1cR!sj@DS\i Srv{{o!R?'[ɺj;#֜{n[>G%FӃvZD'D`k~ cƫHv8ħҳ<`6: 6]/fwmFJqFX?2w83t֮n_n{zؾh%䇯.mHZi9mHghKaY`V*u0R5l:}wt5V!Q1uIqL?f ??{>J=N#Yjzi1T\ÐŜqFRZ)qDQjqBqngm RݺIPS xp9:#fQ!C$9_8āMz7l̈́#Ț9uaZ - ,%ۭuJ=k;&GL^#;?};DD"pDJBF/KA4QZ Ƈ8iT\@,Y5};38v#ds2c;^-rSXK׭rԥ!t(b?^̥߅uk[W8!9\= Ð#nJY1$40>vlX+5 ]|4 aӄH3vR[XtZ/ą8ڜ/b)GLJ h wC*dhЌ<"&Wa쀱?BkRj4[s&ya^fe) (ÜHG^q'Ȥ7?ozˊc?rԟVʁR6flUoBmB'^E.|W3噗g R`'u¥:an>up|=r;Z/2Sȭw¬fƥ/ޗ}-SkM} Gqh✜l:-Z ;Ō8[`BzEKHߢ*ӸO0cUt*F=?q?=*_{W(ϐ$ ҁ$ڛ]Ag㮿S .r<&]`hޏˠ=wF7g%]rtM-K$Ȥp)JCsbYKdb;w!ej-9V *eltև]YEؗwEq}/w=?M.I@n]#7aX5#<| W5XL8:+NS]gHM:dwv! .:&NX[z-@QdeeV_~֏^aYY*9W3FOყqtx0j~D[`>nVnӐn ^/b{_~S ]k aZ.qcϰ{%~%;9w&ʝ18qG{u<$wYǁ}_1pH;욚ch ~G!2a':ZNTBhZXiz^(*~O bF1U,qfA=~7iϿʸބFBcZ ;K]i2;;#D̸\C;?A5{N5DYv!FC-K & oo[T> Yʲx0?1,(`hd>?^7w}Il_h}' }!9lI 5v8| 啛_şc)RhNUGŒ!IDAT6#~nrB/gu}Wֱ!4Ten`PKܱmȠ 6k%TV 8 rйn ~%VgʼTRHiD7¼݇'h]_9Ko:w CZ+2/ؕ 8fC|pf}2s#j#fQt `nXvB-{YJ0`n| N"呲DRpoH?>SdgH0}w[3߁4yY>ÐKe7c׷w*IͦLfP؂ ۩uZa.AƉvvis9j`- Z[/ׯ?s8 qHYgEH~B`sAń4*2SڂznŶLU5[י:ua=,mYi> wXܚ5n]G0 q{?Q]?rwN@ K,7 : mDL&Ն1BjNǁ!Z ` i[ ˼p兵@ ͂/nX #$ǐDŽ,"?Wb{?w=. ϐ;L+iB2} 8 %̥ƅz4g#;5`'o0Sٖ= 3U+BVj ;,ݤְ<޸)/!~-drCF& Z8aNNnW)|@%fVk%stM*­i2SyA@fFbRVC; e\щ٧ '$N|{zw>f-|;-fCRs@VeI23M '|rRXf40UJ]t<~G!r o$*ڂ`k I롏j}Fxk=%-D.8z(lw ؜ndiYM9ys͛[.\:0iTz\V#9{kw=\ HS!uX"auka\R7MYX0/[̔~| !T.JgpO&>{vwO'w?Jn:`-G^PCuyHEnb\5TR09w-Yố .Z@hGjcGi-TcKLVCnWd <ǨZ-LߦΝ`XJv;q36dm+ŕkW]0LU 7jg!y0J<پ~_?ps{zfB!4"0ɮޫ޿zؾ׿wgZhn 1Zy5}J a&TRYSl_{~'ͯ rdgp:cQٺ+<אN;ۗKD3Ra58qby.:}[wv/'~z}#^i۹)e>'G=]Y{-ĊIENDB`libgd-gd-2.1.1/tests/gdimagerotate/bug00067_180_exp.png000066400000000000000000000731331245535672000223060ustar00rootroot00000000000000PNG  IHDRL\ pHYs+ IDATxLInv4Y-bs={mcb;( !2 #%  ~ D/-n8=+jcn"fch5Vg43F"S0Kܟ`]q̪hdff,?:?wz̚麮{ٷo.yi~.x`]mMC]2׎u~*Eֵ[ }__Ngi|yyOyzߣO smnce?_|'xW4~l }PU6(X  7x7އB\JygPżb>yج>|o_ˬ9YxkQI"TGƈhm233! IDZD!zFEhT 7tll!ucm뽈$VԻntl)SB39BR.>~yy%vi#4mq]MյҼ T[+jZctԤ):" ObHHUWC"g Ј]#BD/sº -w}G *˶miM g\s΀E5!0s\kU5*2o;5Fr@Tnk!`\ܶ^v0vV0sN SG`.M1׳OV1,Vqݞ= 1?kUKnfҘToZP80:U -ՓրF -q9gŁC#z85X 2VUE{<:OH"0"ܧwmc)5>58*"aQ@EוMщ!kR52F!!~+9ֵ,> S^i7\.X:f=;3J-@8>n[ viݲ9DE$}_^cUa`fI8նjIBS0C0bB@ATD7eUVcp&%.HTNjnX DUD\&+ ~ cc}̈XNZ%i.[몍̓53PfFD2`@}mkε0 7O~Q5\_s}ش:gb$Z \VqJ\ft==5wll/e[6-JpV)m- {' fFL*-}5Yl_]ʭB J^=BһDeК)[c@tTS3E2}/UKֶ%'03"i53Ev@s Ȯ8V@1,3*ڲ<`_ou\i.^jC0)8fCE4135okk ̬ [ ]7q[,Tsq ԙ6ԠytҲQc0T@ª`̾I[ K؏Ö{pSҶ+Tꎇ#9z:N/y+qX,0sأz;)GxqUFR0Z/|z̼7Fk!vn7rzǮKvl_ӧKcL!#gRf !ڼ)ip>m D]WVZ]d 驙5Q#"034Vj/Yʲ; Cp iZ[)0W|t]]ݖg{9R2"F׫qyͫ)qRj"6τH3;䌊ܲ͗cuյe^T鶅~׋6hK->[\5oetLSAG5h MU@pҷ?ջEFnu*Fur.1 |D/w]7ٜO|E* 4Td A!kPG*LS ts%Fg!O֚:v,'8azRSQ'90ؤH˅}rCW׀̵R=1]( [Uj ʙsSwO/A_{evHD 1;bh*,(oB뷯8\!_|闇 UfK>RyV"'.!457(\Yb om (섮n0ۃ19bZ\Om]ڑ{Yj}GD`@f``df"BL̶7P=,u <Y3vwޏkkY"{bIܿGfC*3:=.k""VAMTT0Px?뒷vrM\Oq}9׬2RRJMtYnDm:H##`"C$pD#C.ŅCpߠ{{nORJZȳAOꁠWnB_2S@˲$ki+~ ;m` ̈3;}$FshKubV;JLTT v- #i(\M y0aaǎzUd^^Q. }=:,xΗi[YSdF"!"ѯ+'F&wly~zK!O# 4*\nk\h3m{~m+/U<9~7Hz34pѡ{stcv b`[K#C6D5TU3u]!"DD缙1ssTKm;IAe[DfLܛc}SyTkk>v󩛸5Fkظ1<ώ|eCrC 1!XN @UUAMDZk@T ٿ{zy:mwe."҄Z˜a~ܧ.tAS3Fr ZKf疪e qemLZ#LIQTf f 6'cwDhJ,k)ms3"V$ 0E 5UUQ0C* "֍|3XukJ?~grDYU,US(J:]b`;"*EK19u FqwoQHTcBǗiMdc?PCPC52RU֊"[xHSkfL 4ȢLՀ!0~70iq}[k1(]Kqo(Z.[y5DZUӼwNt} Ӈߏ-6PA+ykM̠6Y慐d ClBn8VsͭouLC|١ כ|kq }2S"ohq Y_Tɱc4i)R-dLWZk!tb\%କ ͧSg+ W# n7uUJs 3Qeoq"ӶXw~lErcKiw>M *Djbs0Hu1z~ FGwyge9/뵔LJmfjչZKn>\ ڶm ҅PuhEwPԔ150VAOإǃ^N߫[X%! Rdb$2f`f1Y+m١ּ& %?C$ڤfh~M[ձWQ d9r]\5uwU os) i'Rwݧ׮ \oioه߶[J`Xv3h{ UDZmKݶZݬ*(331y%f4g[V8Ͱ z413΄vçW1Й61"i^M]Hoy'VrqEr~jk֔R 5{Pk%Cr$BLm*-р=^^^JdUYu>8oh /ꛏ^7ba(osȷ UϟCkz2-b(\tjhJfҶRʲt91{|&gOZx:[n`(um'v(9ђmetr0Ow~^ sj ڐ<#@y, ~ !RD@fML{?[@L C*2_enn?cB>_ɇf[a7Tn{yko)uu)2岚mTmrzY>"۪fJ^#S8_g#}\r}=}x?L0-<|$u{nד Ȥa{k[]oCͷkJ}Lnjd`%`fx8Q]|]1Фt&m)6}nyY/Tlw>Ʈ"z0Ø4WkDZml?>i9/un^%[Q1:411e[4ziѓTyw.e5`C9@NԜÔ@*|c.Q!DDHhhZn]֮0~Y"1?/N @Tّc" v)$`U]qMy~˥l5F34/FȻ+9=Ԫ!=}1aT_.?<]~㥞rZk5>/[n0Z-=Oz\*cX睡~zz! ?lc_4jl)tEѥWH=%yܻq$[beX~r CiNPAm&Lj·&#TVsM!yUG6y&}?1.ײ5@dޡI{4o;iUjZu:eFb"ȨYK6y~>_Oeـ |Cu]m[DDDB%V wx|Oy"iف4J0$wX,@Ј8QQn5o;w^|meZmQ`;Iul'쀜 ȱ.՚!D}`RZmZU|AR ?}>˘ח+@c,55ۼyE.tDDr_}wm.g/4t8ӇݥW.Fk?(Ɛs!nT_5HDuK '&B@Įjj>pꫯ=ZkC?WOXH1xb&7Fiο\ϧǗ!.u84Sa`+xT:y+)E.mۆ!u%p)F\6||>6Ѡd'{&,KN] cn Ѥ6f.0HZ:#q9!?LR\R<[T~hfy1@(ŘD%H yOj^Tʶb꼮bo/tbminF>"c]]xc>E?rBr\Z}=_m!xLm}]~pcYs2mV9[n[ I>uRw8캔3bru8LQU41*Dڧ^ v*͑4~sݖ}ݏ wϋDnN){."anlKys ԧۜo~VC./?wm{R<{R5[yG&Ͼ酈tqy%G`XU&CJ~Ƒl[W13Қt],!cL}w[6OhD4/FH uSYUB)5E }_U)7OUiFhc\Jߍuۏ}w<~۾Dsɋ)9O׭||^ݪݶ?~s/_>>: ~.]CQŤz5SqNknV] rKӤv+tbnOԱR2"zsL[)b0aͫM,. @hoȺ6D(`]VJR˒ AD9 osn1F$*yfff>cZ+u]WUјҲ1uk-Ҳ1ۧ*m5o+jAܮw;&JX@r>M-sޅ΀"r=. s.:q~wƿM8R*f!$fV4"";@ azG"Q)msDG.ŒWCBP޽{0y0$"VJkRRu˪ZJ_69^̬JDR.v9:즪~.YiZZ5ÐX;}]{yÞWwaE*u[v_ɟ-kctv~Bb9O1vU$~+ Dn>tHWurUZLILsm.3sSJl HDD[Sb&g).\ۺm[UUR >hf1i~mM;U%xKWx1=~鯓}clK5/~x:}mj32nx<8z#Imwc1u^򂵢B/Pkr=}HCPGt^o{jRFh-o("k\pͶmK)yŀs.־q<}7Ae%㛃ZK)3X")9Sy]~RKZSJ "2tSDD5tqؔ rLdգ90|d %omۤQi}>2x)`-4ƈ(SwZ*!{v:O{EnWs?.,|ZMqwwDL]6.9yr]TzSCu藛\uGg,sV*R)T ys58oX R[9G"]> IDATBPq7VBZr$"hH&&4=~/AP.Rcr}p}) em֒ZJ)<*r;oޣMoԲx}n @`wW c-}$68J"3mXUbeU0#r3uFD !hf옙c.L RJ{/jj:UhMcMao"u)RE)of$>v 1RB> ߿Rr9>\.;)-? _. 9V4_Ogi( Jc ;˹{8B nmYUL ;BحkaH3Pi%ޏ).Lj޻eRwZw`ؤcpms.RbSk-OK}G9@5HqwZn@g9mBPU%tb]5쉞/}=c-[ԧ>~}TVu8~l(.UƆ&R%&eղ9С18g>uZr530Uڶ,˲ #y9: #۲3fv!c&gf!$")RnRJam>~ *ML, }hιz"ڶ S?B ޚRTkiRЬbեǸ-%1y_|Y rZ2/K>%Umx>n6/{S1Hku[;&2CU}=oTRdv[J콊}/`;],u]qY3C,U՘PxD4tfmgu6vLzw|I~ݻ) V* U (y KS HE>;5op\RULJaJKbr>7S:3j b uO-!xWlȱ\@33[MU"@cvEڒ7`2ﻮKCBpblf]-RJ{c }Z#m^Hq Pu.9c/" F(E >ǻxѩ'Ӳz˖6gnG_T/Unzj:>fغ.0t!1_/"SJ]ךn2a||{BH˲)t8":DH)ܚ^"ICot0MB7Q퇩iw8^>{St#TesQc."=1ԍ>E$w)5Jyr^5;@ȷ-]T|jBp׷Xn:-v$t\yMVID<;& J)-g$n~r@ƹzs/ǡj~>X˻GҪ蚵Zl*E@ [>e[zs ע\lsi^>|?OӪ tPB,%ΧQ\v]noQs"Lb9eY13ORyFV0%*Zj.Z{K[MXȅ41 "~YWzz*j!o?v59o4/:WB]?.4>E^;.k+FVUuSJdv|CSI)m%;$3W?vΈPK}}}1*38eO?FYU"˲D\ּ{m?ΈwOGnu^Rw.=}I-l@$q !B @r7!c$n'>}?Mﰦ֖]VU=CѴ.`ZSe-z9?~;>9׆6)sʞsvu]FVND~&k|VǦiv֢d'}j8ˬkR|ZkD$RbJ}CD4M7 FHYbuBhwtp>HqQJ`$=Ok9\ p͔K>HiYա߼xvC*D1i5QSy]}]jiz 3s)zyV0 ,l.qߗRnnn777x8xwA9>>~JU֣Ŷ$,ތSs9u]ś0en&W8\YO2Ō9$N b6Ra؏5wkVUk_{'Η mێO;v7)5\JhڦiB}x<ˀ-X|vCS28uM4]дQq{̼)%glJilz%B$3s]vmhJ)zD|7t<_s%-{onva}g;Fݛwo󱰜0m U<%K<n7swu t3vrew}Zg ^:ӰMcQͫy2+T GcKnؽRM[¯BMsK\mZ|ιoyi{*kze!ulQm*FD`;J)윫ESZwcQmڍ>DD%}OǹX9.;?)y}j.\)N;ww׏:vt!r9c>Hw]hlA6*l AcL ZN8k譱ڑ UJEѦii#cHT>P|BsXBk%clVDȘ{ k6p,yo\))}7}c}w8u1 z״}d1xl.0ˮ?`$B4Mh ȷIpTw^ls\֐A^s3hMp䆦}ڏt܍8rur0ou:{M7<퓮}w7*M5nSiXMqk%.$ٳ}WR5d]8&1j\ 5cn> R|ryjgU6 hdm:%[-%ȳg:o.ˮsΕR\sx<2&B{W/K`!RJ5h5.ryvmzJ- %BTZFDqߙwOdt:v؍k5fZCU¿B VIY& stXWmL`RzO?>>]H)e^Bxo06qۡ)Ƙjvyl!dҶmun?֚i9 !]!b12 ar)ۭK>@Rk !lF!kT47>.qGtxYHqhк}#H"YoC-Z\2CpOau}ӻkZ]*( 8AKԶmþC߷a)%_/O?OdT1LG8Y{̗5ZB"ֆRK))%UEkڦg5~!zZuTfnۖ7b9fE41&&Zk]HK1Zk@x7~cZBkT[$ 1HDբ6"3_Wn~lZup3=XDOx9\sQB4X8g%# iRslu u"#~ҘUjE_9.x#¬{ Ka"n'ʬ"\e|"sslRVrߒwo:v\JKE}w7rĂ~Ǔ/mnoo]ש=( |Z!:+ "}7wHD@XV9ntD"i)DDMrQc# Y*b!z+vΥ7GQ1@27M㽿\Nur\J)U+vc5]2]}oAAgT@@@YZe%T%Dq]r-i漬 *UĒqZ")g4PJq9k.jPAAQԛ04xzԶmo֐6M&Tsmw{8P9BQBv@7Xj_㽡Pbon%1s\s9;8綳 Fe)qޙV"2dN>Xg,~/Zn֘Z붧x%NӺ\p)%Tm%4גTZCΙ-R%VETr*95EE#n7""\/9ǴzNfw^C?t1渮ku+]?J5T JDJ)GY׵ias[S)e]WDӵakom7AU8oiao,C{z:U5缁3]L%XS%jeMe,x譫1ÔRjy]yuM)K.8+˲Te$hS͂pu&ۤ\EQ*!\<ϙ+3ZkxK,d1;B\Ny:ϋ ^4mPE:gJg}S/^:ƢQsR/ {Hs*ׯ_"͍7aKuK6<֘ -N,[c!u-t<+xԪj4\B*u]KYj]rBu&#ۮqƆj©\j ֳTV),UMVT)̼[2n^brLy- m}Ǫm&p]W@%p:]ƎjCv]c={QRJzS ]:MS[[j·Z<4OCh;E#gq޹1&Do޼Gb,Q4MLJ AdC)%ƘYf܃9EZTc9l NBζøISʩpْR q͵2RCDaa\SϞofm:H-0eaYffn_3oڼK-|:];5ĕBhǾOSB;^i١%0PzǫAmӶѴp(*.tru{e d:׵᎓xsT>+TJ:gӓ3 K.%N2Օ Jmѓj]iprf{?% q؍)JƢˆI2bIU*CCs}pmڮ\Ovp<)/JcBPNU^nBג/߀|i&@ ZD))}k͆m1[h)QչFN ]wM7C-ޠ/SR}VKZS9'N*rs _$:SuFDA$7.ed621sTl.ӺΗIq3Zkh6gl|mZTɾ IDATꔎSey8)\᮳nU4}zSmEvi!o*sTFΩznMp0W]56X. d)IŨhZ#R{ ,//ϿO(eRԵHP䨢9i~ڨV#fΪؑtYɳvZX :Jeɩ*7[*q1DJEƇT Wؔ-\D22Nr)EƹĹ~h[ - [x>iZ5-5m뽷{jkCJ)hz?K_C'}y.BUk9 u~x)X2]~TB8΋pNRJ1Ɣ<( DӮq1,"",gc*Faʺp8|sSwmsu5rDIJ9JNc^~/!{0Zy{We%'9K5Y߶\NTj{gwܳח|.M _9w] H38mۦyye昸p˿}M=~ow/y` ʪp @M^%ΙUDN{txnBWQq9tCK(C~Ywn/C%zmr=J)mۜBr>szhRlTK;Wׇ`$_{?++W/ ARn-P78g%'.stbs]%<;r=_䷟o.eT^zk-<UiJo|(pӋ_ԏXh5hAe)ˋק®5޼C?v{˺k||tB6McTn4+k-ZR۶ww|ty ͛j8mAc~lRtm@oe|.vv`Bc/eMK9 zM 5rfXv]o/o^%SG~d=y֘\;ϞIb,LU "G6S5FUa)df?zBN\Rͩ8]׉y-҄jn /7fgC9/ֺ -3?ۿc./.rwJ#lXQKh`?wqh6j]ΓDT8,].,Ym؜|~?c?muɨp]ݾjXm{`9p[D~LV D,EQ~qBiC C3˵y?_?tZiĪAPUDE2CB/ZR+Ծq5]p 7'V1i~]w}ۡ 3DhPE@8dRs!DȺ+D5eeY׵Jdjձ,u S\[f\Y*ۛyUHŀ:GUIE9w+Y B߾{?v{w%W'i]yVt:ylQPi{8Qi>+VvZ0\b,ZPouODuf&lj(&$^ zߡ'oZiD#u &ܴv9B!"46jBM[њiVE:]/.2tDiœƃ`!)VxIybnua2hE! 悈]gҚ_//~wOzv,Kh!p9_r}:۵AD.FBjqnnxÕ*׿?/7zÊc3޶u UPφΊYd̕5ǜJ׉H4D'cƥmqokvsm9̻HcmJuZVorYp9cEyxt_IV$ ')!"0jA(o,.`Ia)5EY .휻RKؒ c="ciH  ~FvkBD\jfvkqR5 ??^Xj +~Wn^Tꨲw"EGۂ6ǾﻥVk! eurXkw}l jJ{Z( MfAע@E TUuSY \ؚSU *\7,|03ECX4t,5p)5eZK@=6H&8ZXjyrIUR" XE#(A͓mVXCNx֛6??ߗRB64SR;#U pqb\uZ$gc%^^KxZZ *伉9R GA<354)+ ƣ q2W)o;F[*2JX7x8@XZ:DkF"?CDTY[rbᇇi<͹/æBTK'`!h R`F .Y9G*;OO|<<<<Ͽ>vL!-$U!"ZJ %Gޖ۶眱TFK̂ Z @6>nFf%@cEMm,i!͛נj*SaGGhb[d,$C"I Q+ [Q@ӪJ 0(*\॥?l-_휛|Z%ƛstk<Օ ˊn?pMh1C8'F)Zc\Z+XXYUXP S[RPؽ 6[im&h1p Vg]Պ QTU5*"DªY՚7sk n()۹DUղ2ƙ6Q ~/XٸHSZOrN)8_j.󴬭ZKcA%[# ˊ^bjȚ3rJMDO)%@|+ڔU=t5WhP1TaDH_ADe-6ыZAȣF*XBF( jQTak(0Fq, = nc S"=9;p߳vȳj`N9K "Ea -uAPRZZn$FJҤFDк v,2&$0L,ԺB__Ɵ_)@f(X-{" @U «:A"LNR.#j|A Uz.S4(zPT6@ZX@&(h Sp+"h 4>8Yy%@D؊^!uM@!6IDӜuM3aq`(NǸm- 46kv$[VDd{Μ yxE"%^$S.$, Ȁe6_ ~3!@~$Y R"yLwW흙C}-Q䵚yӯ0}6wի{A^m))13GN3yvږ1zWS}ִzt _pg쭊h?Ҏ|.gTJ7ٯ}\IEl[r&ۿ7lgsE_Y]84'%&qդԐ%+Q V2)/q pz D+4Ld"S-*&KB,&Gpq߿Œc9g{ sww˲ZLɾ&\ungR;̗q\?:m̭>8 "F{vDŇ0KƠYَd4a("Z~KA\Ǖ6ڗ?X?oλPJ]HiӒ+$,)PI8 RjRrm\&SMQ4䀤2{wWuys.i:NAfv|񢰠 m? ZONDAU{=1BP\pg(D AoqЗWc284k}KYxsOs~o j.%D FzXTSETF))RT F"(IyY74SRADD^2BcURx~GmpG0Qe1|5(ŶK@DJ)3GaYJF!Sf뺮e #S#U5/}1{KsT{#ŀ"G?}-EVy Z5JD5EPe=LN&Xj:z&Ej3gQUzZ;F%ֺ}\/}O{ Sbi|RbOReHL[(T!K6r JB*0.\ g_9י"zOrCWb$ E壨1u]˓D8.v RP|4]DhHcݽҏt3)&N,Gg7 )FmXOXK53#Ѯթ7a!2ɀp~yB>\O}d](5|#\02\1,C'bozZR N-{ėG{JȠa:&Q (D5M|QGA/A%s\RhG}mfN5̘#uYn p$l>3tyxu,z>3(V~:V(`)ꞣm|Nfg; ̷۽~*i<< t3)1 3"@Q(r /!I /&<넪JQ⹜^}pYe=öǵ.wy$ljqܕJC'Sՠ{-URK)̪ԗ"`ft<'G#Gxw_ZnnÁyI.ńE!6"bekQ*YgUɡɝ3I /&Z.GMn/uV^&lߜ"bjm.?gFz)by%0pu)or~^ԕ)JqVW̉j-d:FsEDIbNfE#H2@'1!c*}!uʅ|W×?U{2I6f!"r:FSe)@@t]Z]#7  !mՒB,jٟ5 ISÊ̟ueu 9JUnu9 ?f'cjMP!S 2扉NeVGo(fާ)|̈&f_ UE*j !jT (҈+xlK+|XJ(o_Ǐ^# L(`L jB0|} &bu)QG,08Lҽ[Iv5N݅UzD!2URL^QhRs 2 *娖I18HNmw̦s p2N5bʶū ń+)iQ(dA E\1\ n%M +HR Jm q#jҪ|?d } i^DI\FJk\'NŰKc@b.FS.K ['iߟtcUUf7` fs;ߑL#\kI~q@)9&] 2ߊC5]`*ę{sz٫dvE3XqD< .d"o<I H |ϋ `;C-/ORGutd̕rx[li}-c˲{&i1FOT%BD7U ct>L32sBҗ}ue}wI{e-]O@P3&i޺ BϾise rfWB,5P a\S'_7`t& nBǫ;//b'ގIާ$&?@{wRhm\=NyQɈqrq4T#/+FĨE#c82mx N=dL"HEV g*4U'Oo1[?4 *tYTiL{\TU1Jnx }SP &~CĤ?椻mg  q^SE_|ϊyݎw"h_ݯ4Hrk.=R2mo&"]4N[~Ef=E:ܭ C\)v'q$# xc6VdCrW ,SB AzTHp%'̞@&tF|߂LQP/0U4xﲚTK~ǿ r9vg:3Te¹EmjBD묊HާJX=KILd9?/bb lq+xk}I.w>3)8f&v9zio^RZPJJZ#__1 {ƞ2ni`B { ޠ z[}pͪh=׎Z; `kN:dLSh>ܝ&Zt zY}V 3SmED'scKy!@Q1VD2,G<9!'iF2Jupjغԇ~a~!TEULw5:сO Ĭmn]iĦ ïf?~~=8!|;-ڧϏsNg3/."I3;c)unMl2Rxm/~les."s^ mR Ȉh}uV!r Z[k,CL1v~ \) U [ɪ 2HB%_*HclFx,~߲oǿ//r(jJx )߸{}M#_Hm)cL*M1Rrs4/HFpYKw1j.L3D 3 od&yW1LxW?XVM 0+/JrV8xgșg|ZO@I/~e[jϖLp;' 1LsCއ(3g9TA H3YMԺNO֚j1#, jȖ"Im33-E9Gxa4Q`kMuئѼjxs7??gi\kRu[ JJ IQ[nAG|Q.3*ȿ*~sOziXD+ m A]4E,uUHHeM25+:< QiY{ Od_X wy9¤ UfP1Mvt/|}ߏޖx}>Ѯӯ{ox%-Tѥ ɸ̈́r Y$T* nZojoKg/~?x~|2bYJjwE+>&{_Bdp,edS}Q(r)|v>W'VKVdܼps<"^$7"ʌ/dH[CHL$>BDj83L9ȋM!#/mo굽_c-MPeRo?-E?|U~^>|m ۶}լtdwL|m~g1%R*wDq Ykܶu9fUIUFDLx>vvRJcK]%"}PENY@(E#bԥLVD&3^J37yӶxbZ0 GBJUp2G}}ϟj}ξHn= &&KUDFݹ13ߘc&*u] I0DiYz?T%"zw3vb em/<㴖pO3+wP.r>RZ݃ȾwY+(˅[}3s1$2c0ƶmu;0kJ&Tdk-: 52)c1Zfq#r&EǕͽkvzD{w93G~:L3u]g ^&uB 1‡p vzH͂z`D ztoͣdm~y!ZҒ\jopvזRFoHޟέHӉDN:/LͰ =vg~9| 21<{]DNPMbS IENDB`libgd-gd-2.1.1/tests/gdimagerotate/php_bug_64898.c000066400000000000000000000022161245535672000215260ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im, exp; char path[2048]; const char *file_im = "gdimagerotate/php_bug_64898.png"; const char *file_exp = "gdimagerotate/php_bug_64898_exp.png"; FILE *fp; int color; sprintf(path, "%s/%s", GDTEST_TOP_DIR, file_im); fp = fopen(path, "rb"); if (!fp) { gdTestErrorMsg("opening PNG %s for reading failed.\n", path); return 1; } im = gdImageCreateTrueColor(141, 200); if (!im) { gdTestErrorMsg("loading %s failed.\n", path); return 1; } gdImageFilledRectangle(im, 0, 0, 140, 199, 0x00ffffff); /* Try default interpolation method, but any non-optimized fails */ /* gdImageSetInterpolationMethod(im, GD_BICUBIC_FIXED); */ exp = gdImageRotateInterpolated(im, 45, 0x0); if (!exp) { gdTestErrorMsg("rotating image failed.\n"); gdImageDestroy(im); return 1; } sprintf(path, "%s/%s", GDTEST_TOP_DIR, file_exp); if (!gdAssertImageEqualsToFile(path, exp)) { printf("comparing rotated image to %s failed.\n", path); gdImageDestroy(im); gdImageDestroy(exp); return 1; } gdImageDestroy(exp); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/gdimagerotate/php_bug_64898.png000066400000000000000000000022471245535672000220740ustar00rootroot00000000000000PNG  IHDR9$iCCPICC Profile8UoT>oR? XGůUS[IJ*$:7鶪O{7@Hkk?<kktq݋m6nƶد-mR;`zv x#=\% oYRڱ#&?>ҹЪn_;j;$}*}+(}'}/LtY"$].9⦅%{_a݊]hk5'SN{<_ t jM{-4%TńtY۟R6#v\喊x:'HO3^&0::m,L%3:qVE t]~Iv6Wٯ) |ʸ2]G4(6w‹$"AEv m[D;Vh[}چN|3HS:KtxU'D;77;_"e?Yqxl+ pHYs  PLTEIDAT ~7`p, UIENDB`libgd-gd-2.1.1/tests/gdimagerotate/php_bug_64898_exp.png000066400000000000000000000143331245535672000227470ustar00rootroot00000000000000PNG  IHDR3 pHYs+IDATxilUƟJ iP,A6 b!Fc>AwbhD1|PH }t_^/.sΙ93s<Μy@qīn/&LP0H000}!>`'vՍ29s===hiiQ*@ 7H||<ˑE"LWC @iiiASS0r^P233G&"Bɰ~?vލs na*$^ 7Ȇ LA-"L͒*x JJJ`ha(@FFֆ&# W0NJJJ Nz O@gg'v؁M#\9 x 7"ԠN@HR9=P32 (--Eww7-'̇#ZӦMC{{fB  =j(444 @ $DJnn.:;;QWWRC JKKs./=n4anW^3gΠBX=xmsaܹR X pn,@zz:Z[[ڊFir!絈Ύ;t .VP넦&;3gzBˈI; JuSxp*\G__vU x8nhJ&MGGGv Q=UxMX;9P*"qEOY+Yf m !r0Nf*mar!Ȉ*.:u }%73 XbI0iyχ'O36N)//ǬY٩)y^N)cƌAWW)7AxyU W'&Nk׮ hEq!cߝR]]]vPh=<丑Yt)~M!I.\~(?{JADs+݅ z„ իW{`MX5|rr2hXC<Rn(с^{ gvt-?p^᝻uuuL#\/^Ӆ+VXA4+ &źLϣށ5K+jL>)ƕvv`KII%7SՉ)SW-vG9a8/9:V^g˪)\!^D3Ξ="Jn&VA ZrSzz:FKh1?3f `w  ;881#qM8YtLF:/K~\rD/XUUUL Ɖ5|`&\8|0,Yk׮n+1*`ee9(2\eggg,c:.9z0zhJn#VN6`D bUlݺJ6w^^;ȁ3c Rr3NhmI<@X;LBa [ʕ+qyO'7.^ 7 'Ә?gq XXUu.1 w6hhhlr3n[!m̘1[~ k׮u iT2?ӁSf/_|Cb:/9.r_tgii)̙.MBT=Lԯ ?f%FF~\7a?: ƿ;ww߭Nyqfr?/^rTVVn-n/Ry?r-Zddr+SU6ow܁*#*6III9rQ ?7":Ê[ǿ*f͚)&KS"Gcc#jjjË+b>.8pW SYPرc(++Sڎh\Fz].PG^^nB屎/Q㟝_|3gttQD<ˎ;lh1Cğ8툊emT,#&\_QQ={Hm ܿ% KP W'/_/j܌u`GS^RRbk+L`K/rS,С͛1m4maA鑢pZ+PHLLDKK vXx2Jܸ <4z[[|MpmeL{L*OU/**Buuf2:v@WW:e˖_j^L::mU=-둓 &\瓖OнQ+x^Łe:gdd`˖-ZOX" W>“q)M︱^p>ps zׄk֬SPQQ! :0ΝCaafBBSy@3`鎮!Dz/צ?~x }W:PN&TD񯫫{5|:A!`s6mˆ#0qD. 6BQh+s8r>9)꽭"H7NMyaƍ:uHs |eذa5jl.B{|?mf;t B ^I|477[Nnl;w n'Ob߾}ۡy[CSgݺu8~8sr3Bpn/OLʹ/^UpXSh/Ygeenj3b-7{D___fZ8oHA,7RA-ؽ{7Ν3BA7wY]hX} 6 55aմ9GuzKJJ`iAt>KF}FZ);~gϞ'|>$PtmۈvSRR0| ׾\$Hǿ;v츞L{l:_lBE:@h?mE)4)iSR꿚9#F0g.A,/?6`g}'O!Q΅^*i5+$!!ZkCy8@YYM 6wiSHؙB붎Q7ߠ /_w#͡bM ŭ }8q"0N`q`Y۶m7n\T.p ;W+ }|2F bЁ.Gʼn' y" ^{pxCa?3z!K5$ԁMYscyHN7̙3j.V!?[qwz Ug]v!))̀ ͡P~`5P4ګv @Fpm3":7o-\;p,Xǥ?/vup  SU]H=… QYYX˧͡lpJ8f/׮]Cee%z=1mwk^徱cܸqHHH@cc#]x t9i:g-[o*\ĩ9Tc}dm PXX.mD*NBN?0Ξ=+D7U)?ymZuB7?77W5^h`:Tu~mgis(8<իZER j"`vlܸG&\7,=0RСCXlmer0$$$ =[;=.Np XE$..Nu#{/N{Uf~ ݤд9Ud֓$477 oS$ֵ~̲ =  eXD90uO<ⰹdC+Ft>ZD2-[K.i!\͖%o" <Ьoс .6u`o4iQ__o.@s3fq뭷j'\˂~1 K˪$\Z[%%%  }8UVi#Gs=# Uhii^2pN%*&\U{aP]]-y\i3gtx&/XV&&&"55Q x'Yυ"ܧz SN5J90ȁGŢE riuX7-Zop6 EUkU / /y\i(?^vm;H6::app/2&L`pr^zl)--Ŝ9sd3$"*ͬ]f Μ9$^Xɍ *VkIU^Xx:::\'\Vp{i{YbԨQR~VX`ncc#rssY?.^h/;px ,\y8:߱tR\vMBB+MDq3o}4ϟn  XiB;U˗/Giig x^X=w} k)x ^X=nVVV"24m&ĞB 7-- Æ CSS %D_FbK/I&p%AKPf3g0ohg}Y?'<6G҄sˎs 7I**]ʷaugNzN*Twu9` zԸZ=qb@OϿS>:- J:;1OoΌJ8[5iV)RHU#oAaF:䩮4_x %Mj^}:C3|=%^ SUݜP,Vm {QmSK3ⱦxڛw\͎D]RJWQ - %hzq٩aNiva \`Ws}~('GpOjL^kJ|Tj:-Wī VL-i.v'!#"$1=H'|+ʻݵӟ¾ 1^ EUN2q c:O*YˍSn^pINƎM3d-1 [ѥ2;9G\Y<1\{=sTyA?nPh+(\xHUriBVO(IvR\M\Y|϶֎u[_aBEczLAGLVڀJ䉧 YY3LƹE.#Y[G>CZ7P"`#z̕&H,|^ŏq Jwg[-E)a]t]Qcp=w%K6E|6XͮAޡk_S릆I}kkh9х&i]a:7,f8X~Suzׇܴ_s4zE4>FϑAr_U>m8 Gl~?@乏YEe[кhQͤ Hղ6Yԕ-Q;hSjgW+׹QD#{%o[}kDS>%,:pkL9OcH @Es? { .0ʈٹ(Plp@TFGFϑ|[Іqѡds=H1hB|5!1"AQ2aq#3B4?(7WEw(h+j?n2P]G:6}Bx?qt_Uӊqw*jyj3ZPs{T;IuղFpZޖu'G$zS+i򟂑Ͽr f6FاЛD*r=˹9a ӌ84_W,xfp=~n4dqsR$ף7/Muþ *^5A=|/Έݤ_(JN(+WS4c ڡvS{/پvFo|Y]:iQ9ln#StMw U<VnD3YXZpmC~O3Tht- RL';].CUgj,n'7K'7؄W9[ƴ2 t{ wxဣ5ʽ4lEPM$Pe]_ |JYmɥZEV$5䈟)GQOl#n=܊Y~}$ǪqTF)r%&̓6De-ldOb9@WFYfiII,mķْӁ(n,r3,R“FT$͋gǦE`PTEM2j"Př،ɟ$FRmwFOMf^HF95-$S7Mz QC  !1"AQaq#2B$Rb34CrsDcd?# ӒcnY;50rόN/b*'*Q]N ^[MKj &/5Qc$06OT&BǴ0ǚ\¯"#hUCopV(T谻:oH䴏 LNGW2UδQMTr>2!G A`JJ/ҟ+7wIV.ЅRpȻsD:z]g-U)WU ߫9JuGY0}ʅ ,;8LxFWOA0CHk_lseBVC*eWڜ0Gdi>jIٲ5#Xݮ#$[K*ux%pseMTo?xYp1u9CѺsbxak5富gbq>O+DpC $2c2z f T"0i&`#nfݣjcFeA#gdӺBv*ܚJa6|DF;|IEqnG?NGMv%sʚvCvײ=^ypM> eҕ('M Q|T ]^e51 gpڞ: 7֜$xl݃i&JִqLl E V#4hm\xD+Ju^_Pw8( 7XB3P$zTX[Z)رgM,RTOg@-ޡ'i,Ncz-{r5n+clc%{N-|! eTM:U5ZTŴb4;hj*}~qw_XR.QVG_M#:vZ\oJ^ |LsWf]]u PuMwim y44cb` iNk5:rEM3V֤(t f~3LؠYDɘUK0L,4Ʋ`sBFJ+ob1]J#(6>AeH:6d7cQ190Z+C5J +{V4ҜׄԊډ%UF\vr#>ͨ:BH&6U24tM-hrНLՍzU$ );1Z8 A¾')]zeԝ[Ra{k%kis]ֺ||d[ݢ"EozTs]Z۟0u1p47rտ޽$}Tf2͢]/1,H;Ҝlvi#ALΊ"$0*8VƋ(O%!1AQaq?!HzS7A% t:7>aMVkKL,&R8iX5n__0o@vڲm~4xe`\{VL_c_&m?)\k0Ttx,L(+.^ !+,ᓈ(51Fפ!C8b|nJZwOu({?j.NCJrkGٿ0Wb{v@oAbƐ^<1*Bz[m*L&@WHzj#P Q3dbISX_A\:wnic/PzV+cFwF ∆\`?+&X;A4(mil1ssv_0`::0ڰr"ӎ#.a(ƛYL$\3OX?95H~X=#zskеJ4r\<[BV++(Cq +8/퉍]5G>PZh=hm݋˃wB9  *dɕbbTpXel\ҏMrt*/*[~! /l9Y~+z_rbR<  5F4/:r_ r F#3 UM]rWx7!.hD)WOѥiE8]qaj("ffa=ǺC|+BHR͙=@/a35Vd|E7YC NAWXyU-b|VJ^ g䯍^#S"h.W]{ԃ_dý[ű}P&!1AQaq?e7n;e% AV5GDtl;Cز]2T wCx`FIr z܂=ea=ϘрFNMSypXgoPiMw~HyZI_+Ŋ2Cڇ,k`9|뤎|A^Ґ˧33PLRJR< [^k9/t]~r`41S~RԗHv*a1Qi5_Ɣܹ^? wd31B!$xj`tQ"!bŤ*n"fY" ֭AzKќ$4x *n2J`J"*ߚ1P!t . F?]EGEc1h-ἲFn7h8׈m釣'͛eO\"imX۲ ۿAD$řЎe%Ҧnb5N7u*5ʺamvaGID^1fDƂY~h/PqS5]EXIdT R(cGDFT&!1AQaq?ֹp񂗄*{er8LR #rty@Etio S)]ȅci[_+ û`i:o1\IiPgZM Xe7{Q ^?L~K0h 4,y0hrpkh )Gc>ROX-}`u%j>B8Ϝ&]^wQ17q(-K}iҝ?ܤV>&)c%XRq}YFFѫRPD-KbAS"^< @km@j3&zm'IBqjde3{D(j3' \IoN ~04|&S.u"i]՗5P|\I`')YXn0( dUL@4o x0g"o %< YV{#( Fc&Nq',B;ﴨCuFPYޝ؜8m&jn^>b,a߂^0U,#5N%EZ4kMz6B4L@߬1>b5m[@O+(4bXijSY6E.8r%~fq 2BY3 'tnZ#42-) e``/ժ+OT#l{1.>@mKV>ී%!1AQaq?u,f\P>NOXU?@tq^ޫp 狼_A6`GE!k J>!_X$hNUae(H&I&: |iBQgzqB9& Bx95׼I"_f=Z5<Bd. ::S,1O-#$WQ,ܮ%"h{n\{9͖4t7Gwvϊe_HGWWwM͇o?Xe_=D(,o'GsBN *|~ &V_eFl"3+`א;*Q/0>7˃}iOg{Ew)J4`, _ySj5gM | `UT>\w7D[ j|b.?%U?ϛy\8b>Ш x$H;SOf6% ФA]ʄBMp@ 6D -lBoJ71-r*E)vG.|]! Ĺ,\tEP`&u —0O$B# eN DaW%6@)Hߵ0q0wjüS*YŁTd#mI fRJ;=C'PCiȉL7)m"W9,R Do浜XB4v ܆5s+^fÜ@ C* A(45W\yC)$v\愠 ~26H](Յleq%#~3Ik㔝@m \NUxy@ 8 JQvv/"7bPZ)W+eҠzpL!Qu|U5.hprIkl$*-up܀o Y F9%7~S&IF(z׉7]ぞX4Κ3JܒPtUAo*6Y$qp u.wPD4>m#;^&4D6Pm]*#7$x"̤9`y0z_hja b 47.sܷpWq$[$2r=N"l<[>~N6 qGLj*HcbFSASq"|A~7R2uMuYAH xx4Dɺ!xФ mF:3O] fyOU~z8nRd*U?X#ˊSVN+zHjYTCRD H[{f+夼9R py9Mv. nJǔذJ( MIA1[hUOD%I`g/Z4h! eUiҙ-k auМqTkAHT'+k0&{Ȇτq4+(PГN"@* ,0Z; }CϺQxQv^8pLEpt5e Z:o5NM:PpfVp"$Zoc?^u?ȓߤrXCt~ BNW` +1tx;D()o˜DclF<ʶp3G!1Gpt*yn%'9֏hrI^F%<<ܦ4>-Z{1*$*@? NjnXXi/9C;a &),ulr[/իށ_VJrY1\ƴnlibgd-gd-2.1.1/tests/gdimagescatterex/000077500000000000000000000000001245535672000176575ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagescatterex/CMakeLists.txt000066400000000000000000000003611245535672000224170ustar00rootroot00000000000000SET(TESTS_FILES bug00208_1 bug00208_2 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagescatterex/bug00208.png000066400000000000000000000335431245535672000215440ustar00rootroot00000000000000PNG  IHDRqz`"0sRGB pHYs  tIME2"֨X IDATxH\W]Țb(##hlܒD,.22TX/^P{4gKSReMх<\Ni/++8G_s;O?&$gpN'jjM4{g#(˯Ax8v,NٳFqr,^XW.D)@XOSwx(½Uݾӧw-0\.45qm4iCWWT8bÇY[Ӹ};*~rrFD1p 8/55(*F]Y%(|>|=~kgE8}ɍ6r5em Ǐj@g?o̩g9"3gXV"TSm=\bx/L̙H^geMLd ^YAke/T,jeooD--܀#b '8qƗ_\H)԰C 22O?;;&ZZZ42?װ^ll]Y,(ך,t,(wqh`Wj$Nic46 O=|-+8hiw]vjgGLMv$Z[/bu Ԏcc=>r>w5ֺOK p(|>I<\.(G#=ΐDq^MLL<2?r5%)vqw}eߏ+W !?ĴfÛ7p:e|dl GpxU>Z3 *p6}손Spg( IjINłay!Go,(b'amCOSxPSSo;{q&/h1MwRDrZ[+NǡQOG<`rrp~EɄQ\SndAσRc# & W8ec}%#5ϟ?$vl6LNjeO46hEk+;h_8H1Ǐq::QxF+ZՅl`p`s™$"$zے09wukNvnƠԞKVJbvS ަ yXC9O k7q @Z9ȹ.|;) ɼm2ý8|g x > mU5o5 Bg[|; Z |P*yc.D2v;fg|?!e b~ R Ք)|!uL'.d S'q%Zn!f"Ӹ/gи_QNPl`|tW|1)z\^ñ9i} l|[ѪwdMa [z V^+hez670ɄEJ4+|tX߷>!&*Z֏?iַńS:KX2KF40 |5}`pS8v:U(B;| 39zi 2уE~o(D]G> Un ,/3ӈ8R_=Mh>NaAa =$NW':d{.ߨ` SHWh4k Ú"5 'z^tC u5E$[JYS(C˭{O84 XS(cAԯE%ໍ۬) Қr⃻˚0)wq;|CTPDK} ֡ k e챁8~;AJe&8>/5\ S7L`¿_*k èCx>QnHB4*͚Dv{8[9Ӕo2& %w#<3&(T_c#<׼_Rʚ0*Xes/^=ȓK&rYǒ 𽷯uqo ? Ď@ S |lEC"[Gv 0=xY`cw#s6ȚDRY ĤNdFWGXPBFEg0'ƽ\D10:4w`,=Z @>j`M# ֔PaTaIIAr2;Q}MY;Q}MZW?`T3á kN._f0*x>R᫯o F9Cq8Wfϵk8}eŊ#}eOp".(‹8N9Wq,;τ='8Nyܸc+,x2)x~ Y|։..qJ`HCS%NjHgAGr2:;>e`!6㔠o){ ʄ 8N9MMp=5H jM|n: XS$v\蔳;C6kׇ=^ES͡새tfBavcl6f/DCJJw"Dz9꿱8NQ2憲.?13?x4Sbp8BS^d1:xFnj-| ST*, <"RSit/P {lCssHUΉ9 &zl~ Ojk9b uqЀ0D5o~ts dP&pZZ(6X'IKC_B>xV9xwpG;(.Na]͂b*,Rkz,Ų8Nђ9 >@*R{#2#< #7wׯOBO%&&ih l<'Ts_x$huv,&l}˰f*+ }Gq/ࠜS~_E[.%%'ӛ7AUZMTnx)bxlҠOttǣ@.t%C h[ ))"󈍥&9ܤ* }rϞٟPl'&JCO^J :i>Rɱ$9yݸ,󓓔#7!C':d/[w-M>.xsɂS]=^NܿQ;~D@Qst=fRޅ%&++\AuSy9Y%]' .R\C}}2Lf~zG^B%jJA)DDÔ`QC*󰧣y1%>Z@Ң)YU"USʂ<[*:r8 n8\YJmd'4%/76ي !USjj\)UU3 Xb}~N$,d_x)yN&H?0ك$a8jfEGxn9Oq>Re=Hbd*MdVf%kP7捤 7Vې6v{ı+EJ?Ű?\5%w6 bKd'C9"(j)N&CJO3:J}1\k¦uP"}XD2 ayE%QCz(N{ ne?`nve.{Z0\Nvn~fNro5%`Ac*N6;_"AP>n驱\")AҔrOUBDV +(L$\S1H2yڨMM[S :8H HС³i됫sϑ*2d ?lTQ&mlzk)!{/nюyžŨ9R*V#Z}iG@( iySͦ(nmmtîj2_kâ MNI)HtQ}xb)t:n{F!`CaTjŋr;9cF|nmh i^KD6<*,)>@=T]*(5GDM{q)lw7NR{j0;=;( P~n==Ȑ|t/B"jTg Ca k{n%ܾWU]̌;.=v ;5p~pl K#|H#gXz?*jS 5g,.FK v1%b^Jnd |>|riS{ +\ߢU-* ըV)F %(+CF)`;TJm j JFd֏EZi3Q(2Fjfe=Hk+CQ:_M~Aܪtt(mn`k|ݏ~~GqE' hnSSNyT) VXs\GzYeiڴ !bciqQީU''&e}`vY'&eʯc'sH˥\M!0 9936XS+ܾYTM >IoBs3VSOůMH4O hk-.9#KהZP{y&wd}ʼn%5̟su%zZRW`Vy'm#㧰Pq&&|>1g\Ebg1b|t2.]Rs8=m܎̾,L~%s.)5~P LQUh $!\aJH>捘sM#w|.5Aj)ܾdG&yqX D&Ĝhq ~FgM&S;O--ByLM!S+V4?oLiŲ/C?AUq36ˣՔ;wDxMEoԄw4l%+(4EBES67'zzԔv$ Zv-ZuԚ,BD3Y~?[|ߥ_ 0 G,.MZ KX 8T""Ӂgq^[, P"*+'3pḟ )\QgJh*zF45$yWK)ر-1^bC[s=)qjŋZ]HV~"+C%%jVVIrQ2@QJfUE)7h67%4M!jkS8(0nXލrς.6>.2HbyoQsr^܈I@K}M+ةcIT_/?Bh U^.l xbɅ "~aGT]y.t`Q;CQ_֟GWY)Zv: ʷ5VљȭmPuɷnw] RY4>~+P9)TnHYsܼg!ml}/ցU|R憂>=-rfTY\."ŕe<[ YyC5훫DARfdJK"(`mz:8Ҁ̭IQ穨Hp zۯ-t($bb |JJ~ͥׯ]L޶NzdJWMYttIZŜE*.V5']T$([NԯuTb.rkaYM@Эt;w.pWVؤ)7}lzv,s\\F.׻e1C{ԷJosL}q\V\ͫX⒲ +-5LTV|V'5Wa)m0np$l^zk! {C\dzaXGG/!"|o\YDs: Y(*کj_j) mSȽMGG5.tl[LւlG)mƐAw2-KdJM^,_&UT)*Y#G xi~^pI(ѽJb*X}Lf'gpiRؗ0D e|p%!)tPwm5"Z]s f11Vh7\Rb\iX,T*iNyOQL[El6J R:ul,}v:jY!JiǕTX/`mLyz'͘Y7Eo^РKeW3%4K3LJS#,a0tyfҥKOPKT=?/eҋ<:o&j[S6*-7wn-EELRB%vS&m)[|Z=*-!90PL,r WV?MgSW5 f5P룲v4HAQ K):iP,S5."l"tG'\R+"*Yc4e{PA+Z5), 0tr.̪KrH\kiNHMٚ|V%)[˲fOX BNРj" X}6T4evIW[,"+f48{0$oްQ<T=DI2*"Nlєd   JKizZM:}0Hϣh@C&2e,=ȍ5lh¥H2jPmQ@S@Hf YL f4!-46GN@B':GfSG}Vݵ*( 6Yɚ&B\jГűs)“eZӍ;Κf%u~R!K-F0 k vKQS~G!/ye8F?]&e_¦Qfl&+AV/H+iB nn6Ѝ: GE5M>z5" BXSBTLšY@%kOȚ¦Q묬ZBnp&i2-Wx75MQ^e^衞JѢɚ&4?NYd`YL(d5M.ó1"p >78T`cOOyu($ A/Kz/2II[jbVIc c Xf8?L;,CY! uF+ `b~WZY7p >02'O04T|<23raaܜ;cbr!!p8O<@d8]<,R al 0aaAYK;jZ <8p64qS]PPPBnedF~1o](K nwg =ܻ/BqL0#=6H) ae%K^C=y+Wu7Vz:ΝC2A #0vFJIe)Y[ݻr%29xprs9j0ׅWxՅ, EvL^xk8i׮JI a3xM¯]w V磴tkaXSR~͛6HebAa!JKm~0)z:796E 1);q*e).ƅ ,Ltk~ ׮;fCI .\`OSnO?ml1qprsLhJw7NFWZCRRP] =!~h΋8zOciD|z7:5|1]cg0imř3`FBjjĞ`g*N'Ǐ#(4P\YAq1Y$cc?q,,gA[xP pgQOf@TTdX;ͥyJHr^/SVa`6|3)jXX(//v(( ""ŰkHOYӔύnx<48HDT[~ܹCDgd?(&gBFS*+* Y)6RA 0Fj*9Դu%a3%&'Ͱ+),|w% k()) A/\XGv9atҔ>r: ,rdw}Zkk|atҔ6F.NRLO!jrjjav!H8v̀,̘ף~oI~Ytu!338uj_N45΀ K46r(qmu1ͼm#MJKvܤFFl(l~XN}ePV`yg/#9Nw<{Z%%C HI& ?11go'ef ȕOY()(jS66?HCx%ԮITWB LQѮY^T麶6!Y|'H[ձ*HDjup}][:9Ygge*a%)EE" RILT{̴]|ZpPOB[!:`%è47 {{fQ`sSW)'G;5JHRji*+ =L{1hTv`sEp%|/9.@j"IbYY̔),Dm?bcCaɓx@ؕ;٬gfڊFtw**BM Oo0 )qqHH J&Sb0νUBGٰ ia|®:y~i ]]Fw7z{HɄׯ͇ )\p:r1R).opp ޝ:)T9^LL`fcc[66߿jr204BR)v;v㯮nedj LիBI ߥL8q(Dce!EI98N'JK묨 fҔ۷EzPX(C ߸ɹs{Gp05{.eXSϫWE&SքV1 U5E"kdd #ȯdaGӧ|2)=-7PPaMіWꕰ6ޭ pAZ[*Ú" n7Ν鲃%dMYZ^[~rV{.3L$kRPrnv6CQ|F; Σ=r]Ny#)‡ 8c<6EV@b":;e8Nٟ.1 Q! C^bԔw'?邵@ArrZc|t \.^ڳA2?3#G,>p0:*2a"'NyTL'(ɣܹ#i"sy&4c)/W~:YdB5%pG$'EAHSQ!6ړ'|2)ڎݎ:# >ʎ`6}Ox[5Edp~\}nŪ'``5aM).!-MǷ7N6YYjkqaMQ;i(/WUE}ϑa"JSԄnR{ < \qM/^˰3t8 66VԗhР|o]5eG讬>.@k$0J|^_Ɍxo/SaXS]]JvuKpm5/J23Q]-S>eXS|jtAޯEEJfB-ÚŢh8OElYaMaXSLHPBXVeB]|_.ZYa|$M&,. +>_N|3Hjmwp:q4娨΅}WehєX!5ee+Ji)nݒ4]-pCXLM&lIJSrGKKhbo`5entv"1QQv"./%A9H&5ejjߗ٩V Ni EF0Ѯ)WL@Kke('&C:11how+0Ѯ)KK{rMm"7dm}hdҔ=23ӣ" S=={/@ ^b=58% p:% 0 k4rrļa>N zg1 )d5'aXSPXxЫ!ᾏ|>>IBzzC #tv|IENDB`libgd-gd-2.1.1/tests/gdimagescatterex/bug00208_1.c000066400000000000000000000020631245535672000214130ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im, ex; FILE *fp; gdScatter s; CuTestImageResult r; fp = fopen(GDTEST_TOP_DIR "/gdimagescatterex/bug00208.png", "rb"); if (!fp) { fprintf(stderr, "could not open file\n"); return 1; } im = gdImageCreateFromPng(fp); fclose(fp); if (!im) { fprintf(stderr, "could not create image\n"); return 1; } s.sub = 1; s.plus = 3; s.seed = 0; s.num_colors = 0; if (!gdImageScatterEx(im, &s)) { gdImageDestroy(im); fprintf(stderr, "could not scatter\n"); return 1; } fp = fopen(GDTEST_TOP_DIR "/gdimagescatterex/bug00208_1.png", "rb"); if (!fp) { fprintf(stderr, "could not open file\n"); gdImageDestroy(im); return 1; } ex = gdImageCreateFromPng(fp); fclose(fp); if (!ex) { fprintf(stderr, "could not create image\n"); gdImageDestroy(im); return 1; } r.pixels_changed = 0; gdTestImageDiff(im, ex, NULL, &r); gdImageDestroy(ex); gdImageDestroy(im); if (r.pixels_changed > 10000) { fprintf(stderr, "too much diff: %d\n", r.pixels_changed); return 1; } return 0; } libgd-gd-2.1.1/tests/gdimagescatterex/bug00208_1.png000066400000000000000000000542771245535672000217730ustar00rootroot00000000000000PNG  IHDRqz`"0 pHYs   IDATxhW}{]"))MoJzDK$K!%⒒bDRXkIqqX,.KJbIqkIQkokoQ"H$7y8>{gycP(,NYX6s᧟p4 oah_74,[qK?azxeXߢ4x7]`:[gQk쳸(jb718Mi][""b?k-FqK/al 8~MM;0O׿n[p%'zE9qahpKOi~ˡgϲ.EhogU=hοu74׬!^JQĮSI33^#u\T7^ܱRl&$֦- iϳ"]CۻHrd$T$Elhד$ l*7S5Mpree/ex;vdE;+"'۳GGx=㏢Dl)g }X U('$pzѿ ]R6>7o⭷p횡P_h;ZRtz4>W^޿ÃU_K4P(2(s^pv8=?dzG(J[B^,ۍ8 eE[r>e"ߺY{V`:e*2Sf`1:j9,/O@W47iϝccQtaRR-H'Bf!yr)*hU.>}}z k<~^ ux:rMsD}DI<ܯQ߷t):WX|l^Rim{/I, =ܩ#Y-)} @)b iÇ]6jU^3]Æ $UvGhCooґP71>nS~1[ܹkfY|}~R(6z{Im<~~opMC+4ouu{c铖}!ի}SNM͟EPR) sS q'N\o@#䰶Rr@,7#1 m`-AW:~LvcwvJB#aSs3ǫ2 8}ZOC@ݕy+==z)#;}RqQΟVEh!6oƫ5?%M]UY,WNNy%Z[F˒]ǎA 4$jf"Pzzj*<<78\X[F-$RnRO>n* zR˿Ee^&Yrx|yp! Epj*t$T$y'SH.2`S"s3o$Ȇc3p >X)uj*He?XAn/ėr{P6Y,  wNcK%|¥?u/ 0/`mY–XxP> _=e\#4b cݰ=MWV- Xayr%V}τ7M3,Edٌ>gWcup֕Jء;̾t˚M 1~ݧnowՎ/n@-kr$~8 zd3|.+f&ŔvJd)3iҡVn1盆 O\\$DEr dTH`q3G+Qq"0bfsg<ԯadQϱ+p0j?" EʃT> YHYx) `X7l=xuŋZ ѩF(8[୳&Kf/\#yٷ!k:f1 JمlS%ms-Gpdv72kETiIZ0hsIE4xA[ؤ_cj_ XըS)%%.Y4Kǀ=28t '*)IcV(H6ZExZxh@A\YY䭭!H#]rsT{P=Fg `j1u6ȿs>KMx'wpg_QEύxjȕ%anT}ɊBqNw'k&\5J@h TGQ8~׳^"ä?wp"._3WVuEAjZIIE,ldJq_D&MD'A|&H/ag@vsw+!XS()5wpw+IDvswVoQ(>c/< >[v [el؀-[}[**>S=2Um"kOY7qӘ- J.\HSeR# [IQ(G[2Lk{(G0Nve^v9=mS_PɢX 6_6OIRMtq(ݤ~/%^}M'i6QI$4 B/ԲyM}^)/U(CpasґPJ 6O_\JQlOP9*:KOšgOb_ /:Ҋm\1Q'ȹoV2c?,{+YNJ S@kŲg[[tNIH1PA-l^ʈ`hȳV* ,{@D۠E_JK\[gATBH=Eo4AW( o& Etl {Z$^}5)JY0Zd֊8E.Z"[R4, r446Л~\Y[&2 q*x2S,_O#b*mQS;%Ed1FBY:8tJ}=>mEu|Ӂ˷ϪOiVy鴥_Yu0+rmix/L$E\#hD1x({/]P_cLٷ b墨Oik^RF.5| }.ܹ"(5VSTK"$S֮͛dyqj"Ǐz5<(||%9}C5v)lrcdQ&s1NґPE0"ذ4:: "$i$V\f< k9|s˱2~jI:*Bq#i=TJ)E;4̬H:*B"K<~?,L|r((-gȑU(vE$%?]S4 )VLQQJ,Bɔ';;YV1 v^Hk+O$ˡg*5NH Z!0ģW rT%]4w%i%%Y.\`ww$jG ̡(L'iNQTJt$Y::83CCC~>+1WfN3-.mmDFc=VV\=gggO> = -)RN]\$lN._Y06B$xinifAi rT&4Ӯ__@I,X)o=M4fgP*~e}alSB>_~q6ŀ(lۆ; MvCTeO^BG&W>ġnB:?QiTxG4\A%F,+ |êUƝѧmC8"`sؤIk]0*Yr'SpWmlc&uJJCbIiqp0=$y Bl{8PB:0 H%Nc[ E- EҸ}Cw=",g7r#FIJdrC.)}; ANj/F}+x@k dhcQ,`9)j64>jQ @,oZ`|Y` E*T 55 jU/ac X/ԟlya~.5V"UYoдk_K4]8*fFamȳRMua K]DeU҆A{ *esFr'oY~b&jCYB?zT|FT˙Ns|#eY,hUpus,9s:?pY[^Xe[HL:eN4& Bwjj>$9/fih xG%2J:L!<݈S46rdDxxf&6N0RСM,R`$O"Zȋ>蔱1nْK"p/E1SVcUΛ11ҷF&+xz{_̾}$y"Iap^EcI.׃_$~[p萸D7n p kY<5Zqcg.Ƨ-jLȧcvA<-x/ Gu$/gMT &̓ (IVYŮK,+֭>wFPss"]d4@+Qqr%II67'sI3e\"VݥOXO)gy?QW ѣ2Ws)mN|:4#>SOFqgb'K?{O궳]B19hU'Gx33kwyD׽x1kpWUۜs"&b9[P:S2ؔC  Q÷飤8 9_$ qOit$GFxl!CCllSŠp"~EgMrq)Gtj^ӢF/S˻zAᐽ z+mz1RWG^**sfrӬ_҉~C]ȣ+0파ף$ߘ0UyİX.&8=Y(Fpku'^`[pxJMS>9*̻<7`k]V99ckWq=%s[Y\=q'x?щB@Ÿt0?"f0E=s,#jpBd z,/דR&hK9tĄ-5r^IAe Tr: 9;]V&q;HȑӃPS.ܧz\0y# DM_A%+mP龙IbE!7\!ր%,nުâTX#p ce`CldE5NX4 UxaCY*Y;;46OS(ehntsoGNO.RFN9 LDRzŲ̾E!S?{ n*Ic]B7[*}!ԜxM@,{}S %o]5xYXv8@e]hqr;}_$)xFmix0*.VR6N=ȓ|pQTSi42?"f Syv#S18TWS~_zʶ#?PJWTRBc)V[;DxoMGMMrȑr+V"fBYk^ccFRl|5q7)JVq%fؼ4 ;w<}4A:s 6f%- z >z"ړ`+n-r,7"WJ8[GR*iė6>b?_QX>4O)LN7lIx&^Rqz֭z-u|x.M6s\J 3$)]]$X…@µCH,6m_c1+!{64:b( IJN+IDeHN"e07LO>YP&\`Sz(/|۬d&rVAFAċy.U(Jxm-aF7Krs89J>hm8zY3ҤPhgļCd'Ib & Jn8=]u$N,ffSǍ| ׬ԇ.= ڂ?HYٷxY(gtYNG9GRJEt[;d3A43CZӰOp9=cXG©29;Ge K@g?4 '^D+bhyS.˾@,hvrN, prY.qԈ##Ms'wD^<}?_zn)F4|@IDFBof)ׯ's8;=2UqSr*#dߦYfSh)ȼDZ3xRGF}]y\2EhL():։v@#ʸwq*F(a{%|AGyZHQtC67"T~ca{4I3>xWR8aYٲ)zRyb&W`aA<R3׃JJ9N4Tsk1G9YȾ}dn=ɒDG۷Y_: 8:7])[rJHIIeaoG=I$7n trPwIyim3B{%MBz\.=̋-Qmζ"JWDGv *R.v 2u1e,\-Do)vB/*2۷I|b^½#0mk#UCv::q%lB|.|*v )7mbsC% pUoQ/ӭ[u[ 9jVJCC/x˗ Yl+8}ۼPmxY%K@/KS$ołh[ 1AIJ@r-nYѕc '/50n0b;TI 6]΢SNs-&Vփl.:izeann!AEwSj:P&p8F1T'kj?gfxQBHyyfqJK¶ y<%_*Ħ&6%E$^"qg9?ϖX_J+3+S ug'OX`rbsϵ҄y Y $9}s1,ZfX)Jc8E̯ai"6LB)ܭ3C^Vƶ< BnSc.A&bL: }PD89ɶ6"Ԕ}h^is2NŤgѧ.]ka4C%RL:l 1АKE(/cmHF@NbWҒC͢vĩ8W:XG~)a6 KFF8=:EC\)Rnv-JHƍCYnm3Vt&gxF]`37X &+ri^SbhJ_`p7;$DΙg5$Y?4)I1%5-뼅`V73%Į]v"whm5| 24cvEi_͚yp40q5?΋y M$Bs1XP>RľBxA?i)yи%8L=}݉{"xp_XJhLӜnaKAb)9tksyR_?fY5OB#(]Ƙ֪-gh+C3Y.pB$4v=''|8%"XK,(L壚|-)bSpINϴȥDκؕxR bM[ӽ`5Lsgi K$CP13S"D߁)OmܘeV0ũJV& 1Xڹ#1 UσJ%&DX|4y{ e-ź3ɿ\rW=UbJ)Ue\)Җb>5 ɼ[kݻ$1KA[phFG_N8{S-b, PUZUI%x"%`zۺپ]-2[evd#^`VgHN rPơ$EiD35ndG>%} E`'~ n%wFZيLռR`#3g_$rsJU{y9isRfcR3f{:9SȘWXS=3'gx*E+۹v!9v0ܳDFļGQ =YW&&,g+*Գ?pdS؆1O<9yʙ>i|Ɨ_T^{_Nw9& M28v ~txZZC*x+};H\ׯCpڅNhjғΜ FhikuϪFϻOwQ$hibv'j-h$hiFHmqh ՈFl:f.=XPWKL$"6!ļ\33FCyt/TWNNr665̒zf1~"6sȏKg?@ t`F/;@`>tx MU (G]9cC,x*E6&/H޸avOSB3_Sk@gbR. 8<<->^u[+bȥk7G}F9:ydڒYD^{zl4sdht,Co }U7J<-1_9*tFŶa4A`sS8ԁ3ؐɝX΄28p =;zAtwsޤ89C ügtsBvc;N8XŬP8ǹJVS0$[gA#30Ivvz^zY[EIm"=Oih?Cy9Jyi׻;sapY^)KášcX'"|waR5~,"}@^YXgv yad-.9SAWrxA"y)$RfTO}l/T6qhxL?8GW^] VAB&]S23߳?Lͨ/D]!2tÞM$ޥI첅[Dkêk&QԼ@RGm ;1wMy1XvLm]a }\ ]9yrk苕Nt䜮>@4ؔ+<]$rT,(DF򰂖YX捓d)'J Vqx gl9>_Y54>ɰ;))Vn2%Q` &lUz$O( M\*0zrg!o\jrdq.8Cۤ!hR0g I1((N-1mf rP(f0Q4&*Jʇ9vUaE= xVl rwE0rGl{fE)>w?5L>oW(U؄MVluSEP Uy+sOW[BJ` 6;kEQn4Y$8P <,c9ɢS\' 7$9a(dph_ZYLƬyzpGb~0?##y/x<^0i{bھ>Z|+Ԏ_ܬ0ggIbqc:A sX~jeQ%=K9+p02l;?MX"ofV~ki!5ަ&]k9}s͋ܲG:|XON}p^]ͦ&65ևXT) h8q*]ޅ'1X/Ddk&ܔbm"v'zFi2QUKMMYsgYIDAT#:נl٢R_iS=6.p2O Ζ2ͥؽuKG[[ZH܂2k@t:OS|'a8U"rXJG)'WHMOz=;Y$ADd'I:힞fLvנ>Bś=>#{_{/X$'99}ܷ z)b3F.K8K-5X"uV՜$IB wk+IAD[R{Y1IO^]ѵ+^1.po]Z%9q̓f6e~#̬YEL]Iܿ8%BfR,ŋwwstyݽU`{z" ._tlF9aOf ׍;HƯipu^۱icv 5}.*X]q MuXhl۶P?vbg$rn:E i/`*S=GoJ?[VfT3=sar}C,EYʣ_"> KW"nöH.kr%vB+_ZY2KVqBee[_x_/}d"HeU(P%_QlDΛT@S4RkR4:z-6rJrޭ5 ˖o 3WZ8)(Q;-9>@/ՕXXsK:ىx=ڗ_Fw74 >kϬ'NnLE8>ƍPjOB(1uV{mlD_֯1B b~bnmmn= Bx5h~{StEDS<(yrh{\RݝåK4|ݔ2F1֮Ž{$~nF8p!BA*9edkZ|ffohl,x S>q.`mB b>?{NGա ~ŋ̄*6` XE RM;q"`ooVin9lh' =g!ׯcN|>*Dj8~%+&)?M%qknHMw7obZ01=Ge%&&~bINyg0?x`im5+8Ƨ ڻggi+-)**Lt;w̙X#x/Ʋ5 E\nvoxRyVCYՓ1n91b @uupN0?d3=숮ld;ύlݴbIEB޿^Cy(ȊB%*ghVCeV˃ďpޝQWA +*yZr0VN)+3Ȉ!6VU[;)f[m_*][)Fi8y8lh1z(3]S$HTUwCܾ4d _B,o09T'Ol EULj61o/y-Oo#y69ڂ$.rڳg#R,i\tzxhArseʘ/ܲ{>9lΎ^ٻOMYޔh+_ KN9r31j;%LSђcq#GxƈapÀ. ۶ EXS4M_Q4gd*GYalތ.LM+bSă>lQgqn _\:|ulޒ"1O n܈qAX~QQV"9W9ϙ3 q~e3CKG<"&/P28͊\%F2QKR)#pšg]]zh7np T^r(o1Œܼ=̯MMYw&#V)ݻ;:}GIAmiɒnoHTÎVaOP1 Vl~dK66xD)2NpM!XL(|*HĶo1s&UU. p83Wp^fO67f9Q T-]J c[D_U"dȊN۷Ob Bwa/d#dlZɳ&ì7Y;3?BgP zH XEFNV ~XdSV"SH.xdw>pk?ȔbC2Su'ѡP].- )梷KRQy!-dFBe>!FCkVFf~>dPٶB=%I #d*}ԓU8p7fء޸A@+ ~(&4d7ҲկrlT3zkjp.ʢ ͕_ƭ[[nS+ºE/X'V⹳:`^0\ۻųܟkP(24;w cGHJ=2'5+O?xˣ ͉T($[_oO:4[W؈)5C&^f3qoEǏU"&׳>i-+W_ۅ}gRZ3==l pD4AeEfhtTO:OXEx͞ 'LrY dYZ%rQg\24[4ͼ.FBEJebђ(LZV33X"|hζ#al MH|w1FLe_|ZR9aG,6~[wyEABw,e/Bik}E[p K/Y) ֖ʹs8r8,BA0GC(W&N f0lG-z.Rs>1kAe--!&6%<$}>~]{B;sss/DW<|v-FFvm"ĜJ/} }}ӂ.}UHaSĐW= u3`v37oAOۊP+Wbt~w TT`b"mUá"8%ǐ_\N|tŋ_PqG8Bبa#_Y+ɹ'*D5$r2=+ OG}p0sGPYͶ͸zxA?]N+CF!SUk\ft0"1ʟd rMM23; d2|o4B5ݑuDbT~$[HN1n@pZ[N =³G. 1}gD`믱fĂ'&Cزޘc&Z(:M/55ݏVMĄ7kh%5qb&;%.d9Duj =sW:yF/oyF\" ޞO `/k^X@o/HTVZ88 %!WM.)P q)c+yRWrk8k0R~Rӑ|!> 0O4c~qNIUQs.ەXL맟\ %_y4Ѯmm WW#L;w|\ſ ?>$P ?ѧNz%{apP(i,gzc^1~fd^tuahi BQPh5N˧a[~֧A}zr%L/`OGPL2vK)xntY̧S ̕ dwR`.kM E1N==O@ /"CoJSxႋ_T h t)D7ڵK/voC>?( 5ɓ@SV᭷pNZM*EE)䛩GFC>UZJ&:JbU e#c3{ )jY];q6Ⱥ\d&tV ܟ"Y)X6Y&/_vKa5@lN+Ycvs$28{0Y\˗P#,61 1Ɖ5?h{zOһl$x,7ػO&\;[/رcظ1{B 1u-XYN5&:uJ$CTB 4]Xy]lsjSDQFO.k3iics zr*aVgɧB7?kh+ϖj7*&9\搿׿Or~,iƎ>=Rv舯/-!٨Hr-Z>m%CCfYv>rD)E_/Be}56s;Eve2`EY>գ$)tsT묢8N2eIݓF9{8an H@'dlP$HLvӧe`~p=|>0RkO"vR)me(G`ahH?tcM 4}8`bafV]M)(b).KNs|Dʕ~:Y] GTu5z{m1SN9q"()מ"&vw#<$׿B0:j\,/mma#?y#sl }ܽA P\ x miovx"ɨ؁DqJ(S_;/,4MnjYӘ72g&F^'ǎYN)EBvav|чoxW-8{Vw6Qvu|'Ok˾H$55ho{m(u^`ZI?؞Wk BL>v A6PO{eH G2vsKqe|P(*QES٠/m<իFߊ7õS$6O%Hbɿe3hi'BEd$ͨ Q@{=@ٽ{]0 FQ0 Fu7p 10000) { fprintf(stderr, "too much diff: %d\n", r.pixels_changed); return 1; } return 0; } libgd-gd-2.1.1/tests/gdimagescatterex/bug00208_2.png000066400000000000000000000435701245535672000217660ustar00rootroot00000000000000PNG  IHDRqz`"0 pHYs   IDATxhnlٲ_lo>wKْ)lIC$K<)?XRRRR,{`Is-)bIQRXQ")zEē܈$GoB$$7!!ބc6=3E;μ5yvD"H$yD")D$RS$HH$HMH$""HD"5E"DjD"D")D$RS$HH$HMH$""HD"5E"DjD"D")D$RS$HH$HMH$""HD3n 'p:|{Guݰ#Gl Ӕy|AMޱvvq>FGms.::bt,.b˖}ÞKߺw-DA_~ I:SAzU?Ʈ]VW^Ň>&k[NS)(PTۺ]-[ ]P| IrtS)tɊnq:l$h/\7\My6>@ ++xUbenW$1h,wl8{׬`q?L xv!YCK9e~}$%9++x]Sf>{-[$=|NHbТ)_|!`2݋۷C2?U p==:Oz)*a  =ܩЄDovI[?[IޡLrӪȏop hjBCm%2}>&g H+dD[o*)r̕"|S~0)۞29)pÁ_b"{HAXM9}Zv!o//#՛|8 *i$hTy>_O9.tI>(/)ϓ Wv8v{S8 },&|H$06[ߞe\[p <; UFu%*4 Q"rZ),%G*;q(ùyd^s_=[R st&-߬G0YB;X&X71o"̪tuI3ɲ.vMzig^jkiI"1 /kp])>Ǹ1ۈƓ2j{o#{]H̅L2#&V;HL5`rR $!qNXVRa@ILO|pH\ /=<P[R:LlZ$[[oE&T#97ӖnkE%^_73N8X>f +q|f(2^yE.b sF(5Kf˸!>\Z9oMPxHA?*>*D'i(_ZyEV^R" E Qxwʙu\ߊ\9YRTW"(X((^ū;a"j/ʒ`t֏y ?!>\rܹc$I%(h;|'5 V^fr`8}[ڌ-(01H J\h^ NE,8ӔEj`u fŗ?Ӗ *3H ZNLZvf*d!Sx83s#WQox'0#}1$${ {SV WNA`^KH XՑCTҶ:x_/E ~7/qYN$^}SSybc|| e .GdI!XX0 VѾ#gJaΤo#)$uO:ชTrEPW6b)KMnw|Jj{ʆҜB{x/1 -ZH07aJp{); W_{ ^;xg sggnT\Zv8VL[28o͏qEyrx^5e H+l;ވdfhل& §(go bk+ " )d0'2mpy^ Bp.XW&|{7zƤXh`m".brkA3| 5RSMzC#%5AB !7K­BhMP{)Gpx{8ĎX5]QP#(ǧVOIϡ>x lF+15QO;?#(N49tgm^PH~aމ /ǼIL ixX_#jJCySIڌY?RS$Zv⧞X=QSvH,I!cj:%weHoQɺ,I#8+k_~Ə\] J*( H9Aq&|M6AK(zL~@SLD_KpO ,rfJLG $kc.%##>Peݯm5 */m@P14*JAIzlA^Z٩o.>F1z K%J(I|@x%DpKzB+|tx )eʼnuc=t}|%^HAc8 ~: wBRH"$YB!/xZI4׫i%nKAV*`f/N% {Ri{لM?g'c>q8ƿׯI.npoI~4)?k0XN`&nI$}xq*o%XuTF03.Q4ѷn(7bcDP8Hul4%k4@4` ^%Jnw>$?2~!I з9mQ"%V[1#?E|}*RShn5izUXUzسY2dG"O:YaBmqX"]$qsSy+QmB/;ItD JUNy ]J,Q唢"ln'| !(*zg/B->@uo@IpiM,rW&UV| b.k=\5̵$I֞訵HQ1 XKuntvZ$hMPRŵ) ;wUH Y)42iYTGA] :L9d ?N@FZV~tWk@ 0O*'zO67K\J'V\W/aA8f'܁Ѕ%p e摾,JT 0ٳS/uhgӦxM 98P$+Z+͛Ғ5{T(øC*/Ryd \ %DuKVŪ.U1K5e۶$\ʬw-(ovVᚦm->צpDoD';]tY4+Ko?OdC;Ru+4&72B?E]CU_\Vt@;beЊ!*DTWq{bw$M*ꏔf]$hwo:96=Q$o`YܨA/T KI4Ylwc!24NF(ؔrD!ksHX!%!J] A[+@-kbH 9r$ׁ@X&.-q~5Shӑ>5%~Tf<[Mg~./=ZPF)z4My+Yy'R<} 9>{{|TrÇ/Eʆ|SbKOi$0 s"@u$A!')Ko@Iv#<~ԫ{ҽ>WAܽ&p`0m('tgC;wV*#fRM43VJ۷o-?t>!m]5gyIe:[=! ,Ք%:U7qFjC955IӍ/]\rbY;hNĿH T3 FG8Rro4[Qb}6NI;)+ gOZfĠeG'v LhR9fdC n$ePQI::2^YYV#‚ʭZSQIcDMqnhPNqB؋t)\<3UY{\< B)iaMK9%ֲoVZAutpi).&t3}K+6v$Ggǚ&߰HNb H^j,ľݭN$YQ+W>LyP},Bu 2KH~NLE{TơdUT:~ifɇ|Vc=7v,k`ᛎ-P]A9U@/fxTWِ#"H%롼asf-4!0{!i†8oi#EwwJI39lp~9qw `62LdUUlJV pd1 <.jNN2O@\M%*}iu|&KWM8 4vi+:  ?ħ}4<#t$M9vL6BkucQj竿Jr +㑑\˔K>%E:HYT ?sџ?u%QַmF0Vwl^(e8Mc A1v,,ԽXKk>و0AlmRz/ c,F7%vb'U*fN'[&rj*I' ҥ,Mq*-|WuIn܈'O ]3D@YL)['ŬL:ROO,3*#j&(7_5usƔKcP긢"" ($ALp":]B}H"*=5~[YvLmڤjV"F.HaoC/bnR"e!xm)%bk9m}Nlf4˗zN,+G(AIY1e6IZDWu֭w$dw k:y6}u8 '(V+@r].kt `eP hI"m[[|=^#bg=RPVzk`4h8++x5LOMz39;>嗱h袚 p *yc IDAT cS#1˰2VVr0)d&StN@:oTF+Sy"тQ3[tC%{|DINDQmǏ㯿J+ᕌ|I7p]gJ`NeRܹsZKJqY=f'vG1w%xRb" L$$ٗAj\ۑGU?$={t?jI`2uF'i~YS[MM/Ɨ^+:v܉ZՌ#ʉǐl5% Oӄl-3xl1BڵW)ǬWj `nuu yl$Yo&a9/UTdr=Y'(& OLc:HܓH1 HNp"28QEYd*45 KjhᘕL&*y䝵AǷJktk"inlPe,/'ϖt|@\m1W>F}9-oh@[fMLJ|T IJvGLY]98rJܹZHWxF'MRH~"+4IYܜZ4%5e FvP$! ^@pDFOcyI4)%JSET!5MH5 }2Zu!&Yp:",|U_nόX?_kdģha*b3͈2.-,\JH6]ѫFF1ngŘ33 ]P\`MDT_rx k(mGA悌m<ƱH^pv;4o o棯%#Y{_U_ES,H>V8ڹ9SE&[G®֎lm%RĻWCY{SZ];Ms@I[Y~Pb\75(GB^TikK~! 'RǑ׮ _đf8v;QB`Z:l ZSWids3L&t<*,/I9@@A1FV+"WV$W)s 0]֮yB]`.b[n2.7l‚e`fF@Lh۵+UcSc%B28X{slGR̵ۚz4f'7s~/J(x' `0Ҥg Fv/+:R]FFDsZ9$96&%Ń 82B+(AVb˜Te֫!-lCSj ɉ ]-a5ˊ2Ծ%bG"\zIۥa 6rώ@pO]AZY Kv Â'S"_}}FR?iAz3+VǺrp&rȺF+)cjeYVj C*'Ї{>>: WsR^@eWVbd(D**Զl.ee$97?*\\^G* ecǺ&ZeYȧSrxvgR F,m[L/oR?9 :Kq1I9cԓ:Q6cTVriujrMvYy5i9dU"ja2Ųv-*Ԑ4ڮIglMC*SSln^]Йɍ"-9<j5# ,JR_W&ĈGZlh I k8J9KRzYXQ731AOuڞ=li}lnSSqbv${{5u"=f>aiyb7CM;YkWPg~C]6ǎR7?*8:xo_+D+׶J(4%-]H& &9"rz+)As# qm+z`ꢩ$b^9 :%"1fMdS؎ff$Ji<׮ԄS{2reinI]V5![ gwfuu~x6 1'aS=i+lĪ:cZo1&sT-w_){Ԭ B3*A@b#<\C!̾J>ɤ#4|USBWZKzȯ N6kg5^1A^zALrfHV mv+N' @48h$}r>%&>ĉth;3lZ֞IsjY=cG,N+xXbwNXjyC gÔA0KSӿP247S;[ۥK !mrp/؝ V[8I [F/".o*K,2]|wx gR&* 5U決X4τI`|J*q% =!*gyw;1ɜN7Ĺv,˓:wn$+T{"bS1M1eŒ,z{ dI ~K3RqouR0.sɊYQ]a׋JOϟcvֆ3e ܉a9tXAURV8"Jp{ "͜gʆ%#MX{YZׯmGwҹvtЃrS>C)ILThvq[3}r4oڵOcޙkE,^WoM%^-2-s9}6XZZF#W'9Ù =i|ڝ 2Vs2S$cۚE%ޥEIAvSdI0R|&7xcsl=+,0%09tM!l䗑zyHxT*r:\-Cy~+>8dAL\R K2f)7=jbs32d{1oH1>b|E%D2<1~r,dSS4`7*8쐘Rڞ'f]=FFhw&54iٚT1N2p~̨ iq Us>N66?01Vv@t;ê7|˶gIvHV0mG* l{W*K:snVZ KB#Rȥm3 ZsX|ݔ ccؽ>؍2Xg=y7f+Z yg SIGǷq`w<)4Mn,,1VT-v[e%O mj gN(P(sz\_;: ON=؞KbMMqݬg1ӯ]c]]u\lh`?I<3<MU>'AdskZ2@JOɈvj&' <;Eܻ@@0>JJPV;|' S{---hj3?0:YLOoԄq\n7U\^+r:wbg';(}k̶KXr!|bCn/Ѓت5p$єqp(FG: EtA(/χ˗q暖P]g04gS+z&S{jAnp`YT]q`bͤIƊQ%<,( ^BW QkQ+I+^C( PUxG%(QEnv!݃G7f.sjp֠.| o= bA$GDWwZhJK %%z1: >XCYnEq11>;wx='()Aq1JKc"'Tgop s+0Qzw`G'<В\C9q~)?9)/Ǯ]\~$ Ubcr5erS\%+x؈pSN換emRQzM_s|&5er?HFS?o#[x=Ǐ˲6<47cY*PY,Vkʳg8pGJ5яǃ-EC6,?єMxhmxvEX/1mk4![c~GΒ ۍ dL0]SnƗ_-S/RTWv!mz_|wޑb:Wbz|%fgvE/-1#Mє3xǏ$ ++8zoGvE0's2 ۖ觢G`C.S%1 ݋Ed9e~;w|MVw )BM4ZBdlԃVNx_|I!ix^m%%8q\]R((œ-[eF6MϣŞQ$Y]`ؓ7nĜX*}}ls@t9PZAZ up4?tsjK 85mls^$9 tj7mpyI64/m<|nm>iqy$ zKvV7y>Ivv/ZITTkׄD|B!z¡CvwZ[ܿO~j^/>$Ʌa.W'MYX`}mÞ,-L3JUVr)PISӚ' LԄ\c(d_SǏלim_1kcԆ 1@~ K`x=/ˮgz{tҥ촭R\n* )-'Wrm[|'ldL8EE61Z{_$$Lq>afQ/,adO`Θ=ΟGW !8wJ4zaϟ͆$I1{<|X=6>6dNA$LrO?᫯7ۋ'ZU MMŶmb<$S~=nJVVs y#1LR1g\wСt]tsV745a44Иu?UݍI.o8lnT:/]$ˍ pLdMR?at܉:'I!} NMH{zH[PRBk$o?fpՖ>)+}hJOul0nU.662 %rҒHkjRgϲآtf(@I$IYӔ~|<|Xp#ܔI.MG{.ҷQpXXz9<8aM3,|'OSxIa={XV153 $ ͹Dm-6m$yȑ2MMKxP~?>'wCFC\L\spq@8r4$9NrM)-EEB!Bnә ##bvbf&rTIDAT~(z ++Fсagvnmܾ tb`&-MMQ^n+ )w8vį H\J0>'OQ8ps'kUDZGN q0ab )>FFv}#[ow0Z[&X@ז1?`{{`[RҧML ?(aES~MdMMj7ٵ+8}ZXjdE&x?-.D ˕boHԑrȘQU%,{p Ґ-CVh?nwVGtt,(@UsҐ#k͛ySXj{"n**{._А$BΉ "ڦ p@G0]FD6 %Tl֔Y;;3"-&NY ;}ZXDb*6kOel$&)Qlߎ$%V|%yo 6B wUA&'tm"Ϟ᭷,J HGR=rʭ[bcj+5C~)KRȘk:%&FԨ=XL۶ (Db8lT 18|jO*^~h#N ?y0"1\L,)/ ]]||"Z;pы9Gb&(QSS@"o;YG 55bF),MYY)UUسGω5E_I]@l  =rъχ.- >Rppюq\n(TlN9bӭ[JK4HMd39)cfGN%mیƂI6cUWg^Mo/kyؠ)F8q¨Ƨ LAaeWr@"14寿tG@ؒ)GFHLM7jťK5 }}:%R|d-Vkг.-f UY3g p*,jMuK'NbDl݊g-nH$ZStU=x0 ~mnӻ,#J)8xPdF4El9E]HMd'Vk)& AܻgA,_VC&Ǎ`q{UG|2 DVZA0wU@@眝b}hoWutU%z}G2vYƃd 'N D")5Õ+֯Hφ ֝Fe.[D*GeE軐eUWƍ Ԕ$TS&'Sy3-]XGI:MP^t%#YNd!jJN'' &|>=ʕbPOQ]K,#HK5ev6~Oq1\1H7Z۲vjDs$Db;jJܴ[18" 3w@eǼDb%jJPֻ鱺ǦM2>E>(*B_:;עHMdV%+唖ܿ+[Cu&+ljÇhl}Xݗ\QttXaG +'N5fI$Fm,arevcb暚Dضij$޼Y DBuubH$uxt^/?zDr | uuRP$HMta p8 zb$LP}`eo<IE-wH" jpŝ!Ifkq vIENDB`libgd-gd-2.1.1/tests/gdimagesetpixel/000077500000000000000000000000001245535672000175125ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagesetpixel/CMakeLists.txt000066400000000000000000000004061245535672000222520ustar00rootroot00000000000000SET(TESTS_FILES bug00186 gdeffectoverlay gdeffectmultiply ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagesetpixel/bug00186.c000066400000000000000000000015321245535672000210330ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; gdImagePtr tile; int red, green, blue, other; int i, r = 0; im = gdImageCreateTrueColor(100, 100); tile = gdImageCreate(10, 10); red = gdImageColorAllocate(tile, 0xFF, 0, 0); green = gdImageColorAllocate(tile, 0, 0xFF, 0); blue = gdImageColorAllocate(tile, 0, 0, 0xFF); other = gdImageColorAllocate(tile, 0, 0, 0x2); gdImageFilledRectangle(tile, 0, 0, 2, 10, red); gdImageFilledRectangle(tile, 3, 0, 4, 10, green); gdImageFilledRectangle(tile, 5, 0, 7, 10, blue); gdImageFilledRectangle(tile, 8, 0, 9, 10, other); gdImageColorTransparent(tile, blue); gdImageSetTile(im, tile); for (i=0; i<100; i++) { gdImageSetPixel(im, i, i, gdTiled); } if (gdTrueColorGetBlue(gdImageGetPixel(im, 9, 9)) != 0x2) { r = 1; } gdImageDestroy(tile); gdImageDestroy(im); return r; } libgd-gd-2.1.1/tests/gdimagesetpixel/gdeffectmultiply.c000066400000000000000000000012611245535672000232250ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int x, y, c; int r=0; im = gdImageCreateTrueColor(256, 256); gdImageAlphaBlending( im, gdEffectReplace ); for (x=0; x<256; x++) { for (y=0; y<256; y++) { c = (y/2 << 24) + (x << 16) + (x << 8) + x; gdImageSetPixel(im, x, y, c ); } } gdImageAlphaBlending( im, gdEffectMultiply ); gdImageFilledRectangle(im, 0, 0, 255, 255, 0xff7f00); if (gdTrueColorGetGreen(gdImageGetPixel(im, 0, 128)) != 0x40) { r = 1; } if (gdTrueColorGetGreen(gdImageGetPixel(im, 128, 128)) != 0x5f) { r = 1; } if (gdTrueColorGetGreen(gdImageGetPixel(im, 255, 128)) != 0x7f) { r = 1; } gdImageDestroy(im); return r; } libgd-gd-2.1.1/tests/gdimagesetpixel/gdeffectoverlay.c000066400000000000000000000013161245535672000230300ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; int x, y, c; FILE *out; char path[1024]; int r=0; im = gdImageCreateTrueColor(256, 256); gdImageAlphaBlending( im, gdEffectReplace ); for (x=0; x<256; x++) { for (y=0; y<256; y++) { c = (y/2 << 24) + (x << 16) + (x << 8) + x; gdImageSetPixel(im, x, y, c ); } } gdImageAlphaBlending( im, gdEffectOverlay ); gdImageFilledRectangle(im, 0, 0, 255, 255, 0xff7f00); if (gdTrueColorGetGreen(gdImageGetPixel(im, 0, 128)) != 0x00) { r = 1; } if (gdTrueColorGetGreen(gdImageGetPixel(im, 128, 128)) != 0x80) { r = 1; } if (gdTrueColorGetGreen(gdImageGetPixel(im, 255, 128)) != 0xff) { r = 1; } gdImageDestroy(im); return r; } libgd-gd-2.1.1/tests/gdimagestringft/000077500000000000000000000000001245535672000175155ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagestringft/CMakeLists.txt000066400000000000000000000003571245535672000222620ustar00rootroot00000000000000SET(TESTS_FILES gdimagestringft_bbox ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagestringft/gdimagestringft_bbox.c000066400000000000000000000043101245535672000240470ustar00rootroot00000000000000#include "gd.h" #include #include #include #include "gdtest.h" #define PI 3.141592 #define DELTA (PI/8) static int EXPECT[16][8] = { {498, 401, 630, 401, 630, 374, 498, 374}, {491, 364, 613, 313, 602, 288, 481, 338}, {470, 332, 563, 239, 544, 219, 451, 312}, {438, 310, 488, 189, 463, 178, 412, 300}, {401, 303, 401, 171, 374, 171, 374, 303}, {365, 310, 314, 188, 289, 199, 339, 320}, {334, 331, 241, 238, 221, 257, 314, 350}, {313, 362, 192, 312, 181, 337, 303, 388}, {306, 398, 174, 398, 174, 425, 306, 425}, {313, 433, 191, 484, 202, 509, 323, 459}, {333, 463, 240, 556, 259, 576, 352, 483}, {363, 484, 313, 605, 338, 616, 389, 494}, {398, 490, 398, 622, 425, 622, 425, 490}, {432, 483, 483, 605, 508, 594, 458, 473}, {461, 464, 554, 557, 574, 538, 481, 445}, {481, 435, 602, 485, 613, 460, 491, 409}, }; int main() { char path[2048]; gdImagePtr im; int black; double cos_t, sin_t; int x, y, temp; int i, j; int brect[8]; int error = 0; FILE *fp; sprintf(path, "%s/freetype/DejaVuSans.ttf", GDTEST_TOP_DIR); im = gdImageCreate(800, 800); gdImageColorAllocate(im, 0xFF, 0xFF, 0xFF); /* allocate white for background color */ black = gdImageColorAllocate(im, 0, 0, 0); cos_t = cos(DELTA); sin_t = sin(DELTA); x = 100; y = 0; for (i = 0; i < 16; i++) { if (gdImageStringFT(im, brect, black, path, 24, DELTA*i, 400+x, 400+y, "ABCDEF")) { error = 1; goto done; } for (j = 0; j < 8; j++) { if (brect[j] != EXPECT[i][j]) { printf("(%d, %d) (%d, %d) (%d, %d) (%d, %d) expected, but (%d, %d) (%d, %d) (%d, %d) (%d, %d)\n", EXPECT[i][0], EXPECT[i][1], EXPECT[i][2], EXPECT[i][3], EXPECT[i][4], EXPECT[i][5], EXPECT[i][6], EXPECT[i][7], brect[0], brect[1], brect[2], brect[3], brect[4], brect[5], brect[6], brect[7]); error = 1; goto done; } } gdImagePolygon(im, (gdPointPtr)brect, 4, black); gdImageFilledEllipse(im, brect[0], brect[1], 8, 8, black); temp = (int)(cos_t * x + sin_t * y); y = (int)(cos_t * y - sin_t * x); x = temp; } fp = fopen("gdimagestringft_bbox.png", "wb"); if (!fp) { error = 1; goto done; } gdImagePng(im, fp); fclose(fp); done: gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gdimagestringftex/000077500000000000000000000000001245535672000200525ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdimagestringftex/CMakeLists.txt000066400000000000000000000003771245535672000226210ustar00rootroot00000000000000SET(TESTS_FILES gdimagestringftex_returnfontpathname ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdimagestringftex/gdimagestringftex_returnfontpathname.c000066400000000000000000000007021245535672000277340ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdFTStringExtra strex; char path[2048]; sprintf(path, "%s/freetype/DejaVuSans.ttf", GDTEST_TOP_DIR); strex.flags = gdFTEX_RETURNFONTPATHNAME; strex.fontpath = NULL; gdImageStringFTEx(NULL, NULL, 0, path, 72, 0, 0, 0, "hello, gd", &strex); if (!strex.fontpath) { return 1; } if (strcmp(path, strex.fontpath) != 0) { return 2; } gdFree(strex.fontpath); return 0; } libgd-gd-2.1.1/tests/gdinterpolatedscale/000077500000000000000000000000001245535672000203545ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdinterpolatedscale/gdModesAndPalettes.c000066400000000000000000000024021245535672000242250ustar00rootroot00000000000000/* Exercise all scaling with all interpolation modes and ensure that * at least, something comes back. */ #include #include "gd.h" #include "gdtest.h" #define X 100 #define Y 100 #define NX 20 #define NY 20 int main() { int method, i; for(method = GD_BELL; method <= GD_TRIANGLE; method++) { /* GD_WEIGHTED4 is unsupported. */ gdImagePtr im[2]; // printf("Method = %d\n", method); im[0] = gdImageCreateTrueColor(X, Y); im[1] = gdImageCreatePalette(X, Y); for (i = 0; i < 2; i++) { gdImagePtr result; // printf(" %s\n", i == 0 ? "truecolor" : "palette"); gdImageFilledRectangle(im[i], 0, 0, X-1, Y-1, gdImageColorExactAlpha(im[i], 255, 255, 255, 0)); gdImageSetInterpolationMethod(im[i], method); gdTestAssert(im[i]->interpolation_id == method); /* No getter yet. */ result = gdImageScale(im[i], NX, NY); gdTestAssert(result != NULL); gdTestAssert(result != im[i]); gdTestAssert(result->sx == NX && result->sy == NY); gdImageDestroy(result); gdImageDestroy(im[i]); }/* for */ }/* for*/ return gdNumFailures(); }/* main*/ libgd-gd-2.1.1/tests/gdinterpolatedscale/gdTrivialResize.c000066400000000000000000000043201245535672000236260ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" /* Test gdImageScale() with bicubic interpolation on a simple * all-white image. */ gdImagePtr mkwhite(int x, int y) { gdImagePtr im; im = gdImageCreateTrueColor(x, y); gdImageFilledRectangle(im, 0, 0, x-1, y-1, gdImageColorExactAlpha(im, 255, 255, 255, 0)); gdTestAssert(im != NULL); gdImageSetInterpolationMethod(im, GD_BICUBIC); // FP interp'n return im; }/* mkwhite*/ /* Fill with almost-black. */ void mkblack(gdImagePtr ptr) { gdImageFilledRectangle(ptr, 0, 0, ptr->sx - 1, ptr->sy - 1, gdImageColorExactAlpha(ptr, 2, 2, 2, 0)); }/* mkblack*/ #define CLOSE_ENOUGH 15 void scaletest(int x, int y, int nx, int ny) { gdImagePtr im, imref, tmp, same; imref = mkwhite(x, y); im = mkwhite(x, y); tmp = gdImageScale(im, nx, ny); same = gdImageScale(tmp, x, y); /* Test the result to insure that it's close enough to the * original. */ gdTestAssert(gdMaxPixelDiff(im, same) < CLOSE_ENOUGH); /* Modify the original and test for a change again. (I.e. test * for accidentally shared memory.) */ mkblack(tmp); gdTestAssert(gdMaxPixelDiff(imref, same) < CLOSE_ENOUGH); gdImageDestroy(im); gdImageDestroy(tmp); gdImageDestroy(same); }/* scaletest*/ void do_test(int x, int y, int nx, int ny) { gdImagePtr im, imref, tmp; gdImagePtr same, same2; im = mkwhite(x, y); imref = mkwhite(x, y); same = gdImageScale(im, x, y); /* Trivial resize should be a straight copy. */ gdTestAssert(im != same); gdTestAssert(gdMaxPixelDiff(im, same) == 0); gdTestAssert(gdMaxPixelDiff(imref, same) == 0); /* Ensure that modifying im doesn't modify same (i.e. see if we * can catch them accidentally sharing the same pixel buffer.) */ mkblack(im); gdTestAssert(gdMaxPixelDiff(imref, same) == 0); gdImageDestroy(same); gdImageDestroy(im); /* Scale horizontally, vertically and both. */ scaletest(x, y, nx, y); scaletest(x, y, x, ny); scaletest(x, y, nx, ny); } int main(int argc, char **argv) { do_test(300, 300, 600, 600); do_test(3200, 2133, 640, 427); return gdNumFailures(); } libgd-gd-2.1.1/tests/gdnewfilectx/000077500000000000000000000000001245535672000170225ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdnewfilectx/CMakeLists.txt000066400000000000000000000003541245535672000215640ustar00rootroot00000000000000SET(TESTS_FILES gdnewfilectx_null ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdnewfilectx/gdnewfilectx_null.c000066400000000000000000000001261245535672000227020ustar00rootroot00000000000000#include "gd.h" int main() { if (gdNewFileCtx(NULL) != NULL) return 1; return 0; } libgd-gd-2.1.1/tests/gdtest/000077500000000000000000000000001245535672000156315ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdtest/CMakeLists.txt000066400000000000000000000002721245535672000203720ustar00rootroot00000000000000SET(GDTEST_TOP_DIR "${GD_SOURCE_DIR}/tests") CONFIGURE_FILE(test_config.h.cmake test_config.h ESCAPE_QUOTES) add_library (gdTest STATIC gdtest.c) target_link_libraries(gdTest ${GD_LIB}) libgd-gd-2.1.1/tests/gdtest/gdtest.c000066400000000000000000000155361245535672000173010ustar00rootroot00000000000000#include #include #include #include #include #include #include #include "gd.h" #include "gdtest.h" #include "test_config.h" /* max is already defined in windows/msvc */ #ifndef max static inline int max(int a, int b) {return a > b ? a : b;} #endif void gdSilence(int priority, const char *format, va_list args) { (void)priority; (void)format; (void)args; } gdImagePtr gdTestImageFromPng(const char *filename) { gdImagePtr image; FILE *fp; fp = fopen(filename, "rb"); if (!fp) { return NULL; } image = gdImageCreateFromPng(fp); fclose(fp); return image; } /* Compare two buffers, returning the number of pixels that are * different and the maximum difference of any single color channel in * result_ret. * * This function should be rewritten to compare all formats supported by * cairo_format_t instead of taking a mask as a parameter. */ void gdTestImageDiff(gdImagePtr buf_a, gdImagePtr buf_b, gdImagePtr buf_diff, CuTestImageResult *result_ret) { int x, y; int c1, c2; # define UP_DIFF(var) result_ret->max_diff = max((var), result_ret->max_diff) for (y = 0; y < gdImageSY(buf_a); y++) { for (x = 0; x < gdImageSX(buf_a); x++) { c1 = gdImageGetTrueColorPixel(buf_a, x, y); c2 = gdImageGetTrueColorPixel(buf_b, x, y); /* check if the pixels are the same */ if (c1 != c2) { int r1,b1,g1,a1,r2,b2,g2,a2; unsigned int diff_a,diff_r,diff_g,diff_b; a1 = gdTrueColorGetAlpha(c1); a2 = gdTrueColorGetAlpha(c2); diff_a = abs (a1 - a2); diff_a *= 4; /* emphasize */ if (diff_a) { diff_a += 128; /* make sure it's visible */ } if (diff_a > gdAlphaMax) { diff_a = gdAlphaMax/2; } r1 = gdTrueColorGetRed(c1); r2 = gdTrueColorGetRed(c2); diff_r = abs (r1 - r2); /* diff_r *= 4; /* emphasize */ if (diff_r) { diff_r += gdRedMax/2; /* make sure it's visible */ } if (diff_r > 255) { diff_r = 255; } g1 = gdTrueColorGetGreen(c1); g2 = gdTrueColorGetGreen(c2); diff_g = abs (g1 - g2); diff_g *= 4; /* emphasize */ if (diff_g) { diff_g += gdGreenMax/2; /* make sure it's visible */ } if (diff_g > 255) { diff_g = 255; } b1 = gdTrueColorGetBlue(c1); b2 = gdTrueColorGetBlue(c2); diff_b = abs (b1 - b2); diff_b *= 4; /* emphasize */ if (diff_b) { diff_b += gdBlueMax/2; /* make sure it's visible */ } if (diff_b > 255) { diff_b = 255; } result_ret->pixels_changed++; if (buf_diff) gdImageSetPixel(buf_diff, x,y, gdTrueColorAlpha(diff_r, diff_g, diff_b, diff_a)); } else { if (buf_diff) gdImageSetPixel(buf_diff, x,y, gdTrueColorAlpha(255,255,255,0)); } } } # undef UP_DIFF } /* Return the largest difference between two corresponding pixels and * channels. */ unsigned int gdMaxPixelDiff(gdImagePtr a, gdImagePtr b) { int diff = 0; int x, y; if (a == NULL || b == NULL || a->sx != b->sx || a->sy != b->sy) return UINT_MAX; for (x = 0; x < a->sx; x++) { for (y = 0; y < a->sy; y++) { int c1, c2; c1 = gdImageGetTrueColorPixel(a, x, y); c2 = gdImageGetTrueColorPixel(b, x, y); if (c1 == c2) continue; diff = max(diff, abs(gdTrueColorGetAlpha(c1) - gdTrueColorGetAlpha(c2))); diff = max(diff, abs(gdTrueColorGetRed(c1) - gdTrueColorGetRed(c2))); diff = max(diff, abs(gdTrueColorGetGreen(c1) - gdTrueColorGetGreen(c2))); diff = max(diff, abs(gdTrueColorGetBlue(c1) - gdTrueColorGetBlue(c2))); }/* for */ }/* for */ return diff; } int gdTestImageCompareToImage(const char* file, unsigned int line, const char* message, gdImagePtr expected, gdImagePtr actual) { unsigned int width_a, height_a; unsigned int width_b, height_b; gdImagePtr surface_diff = NULL; CuTestImageResult result = {0, 0}; (void)message; if (!actual) { _gdTestErrorMsg(file, line, "Image is NULL\n"); goto fail; } width_a = gdImageSX(expected); height_a = gdImageSY(expected); width_b = gdImageSX(actual); height_b = gdImageSY(actual); if (width_a != width_b || height_a != height_b) { _gdTestErrorMsg(file, line, "Image size mismatch: (%ux%u) vs. (%ux%u)\n for %s vs. buffer\n", width_a, height_a, width_b, height_b, file); goto fail; } surface_diff = gdImageCreateTrueColor(width_a, height_a); gdTestImageDiff(expected, actual, surface_diff, &result); if (result.pixels_changed>0) { char file_diff[255]; char file_out[1024]; FILE *fp; int len, p; _gdTestErrorMsg(file, line, "Total pixels changed: %d with a maximum channel difference of %d.\n", result.pixels_changed, result.max_diff ); p = len = strlen(file); p--; /* Use only the filename (and store it in the bld dir not the src dir */ while(p > 0 && (file[p] != '/' && file[p] != '\\')) { p--; } sprintf(file_diff, "%s_%u_diff.png", file + p + 1, line); sprintf(file_out, "%s_%u_out.png", file + p + 1, line); fp = fopen(file_diff, "wb"); if (!fp) goto fail; gdImagePng(surface_diff,fp); fclose(fp); fp = fopen(file_out, "wb"); if (!fp) goto fail; gdImagePng(actual, fp); fclose(fp); } else { if (surface_diff) { gdImageDestroy(surface_diff); } return 1; } fail: if (surface_diff) { gdImageDestroy(surface_diff); } return 0; } int gdTestImageCompareToFile(const char* file, unsigned int line, const char* message, const char *expected_file, gdImagePtr actual) { gdImagePtr expected; int res = 1; expected = gdTestImageFromPng(expected_file); if (!expected) { _gdTestErrorMsg(file, line, "Cannot open PNG <%s>", expected_file); res = 0; } else { res = gdTestImageCompareToImage(file, line, message, expected, actual); gdImageDestroy(expected); } return res; } static int failureCount = 0; int gdNumFailures() { return failureCount; } int _gdTestAssert(const char* file, unsigned int line, const char* message, int condition) { if (condition) return 1; _gdTestErrorMsg(file, line, "%s", message); ++failureCount; return 0; } int _gdTestAssertMsg(const char* file, unsigned int line, int condition, const char* message, ...) { va_list args; char output_buf[GDTEST_STRING_MAX]; if (condition) return 1; va_start(args, message); vsnprintf(output_buf, sizeof(output_buf), message, args); va_end(args); fprintf(stderr, "%s:%u: %s", file, line, output_buf); fflush(stderr); ++failureCount; return 0; } int _gdTestErrorMsg(const char* file, unsigned int line, const char* format, ...) /* {{{ */ { va_list args; char output_buf[GDTEST_STRING_MAX]; va_start(args, format); vsnprintf(output_buf, sizeof(output_buf), format, args); va_end(args); fprintf(stderr, "%s:%u: %s", file, line, output_buf); fflush(stderr); ++failureCount; return 0; } /* }}} */ libgd-gd-2.1.1/tests/gdtest/gdtest.h000066400000000000000000000037441245535672000173040ustar00rootroot00000000000000#ifndef GD_TEST_H #define GD_TEST_H #include #include "test_config.h" #define GDTEST_STRING_MAX 1024 typedef struct CuTestImageResult CuTestImageResult; struct CuTestImageResult { unsigned int pixels_changed; unsigned int max_diff; }; /* Internal versions of assert functions -- use the public versions */ gdImagePtr gdTestImageFromPng(const char *filename); void gdTestImageDiff(gdImagePtr buf_a, gdImagePtr buf_b, gdImagePtr buf_diff, CuTestImageResult *result_ret); int gdTestImageCompareToImage(const char* file, unsigned int line, const char* message, gdImagePtr expected, gdImagePtr actual); int gdTestImageCompareToFile(const char* file, unsigned int line, const char* message, const char *expected_file, gdImagePtr actual); unsigned int gdMaxPixelDiff(gdImagePtr a, gdImagePtr b); int _gdTestAssert(const char* file, unsigned int line, const char* message, int condition); int _gdTestAssertMsg(const char* file, unsigned int line, int condition, const char* message, ...); int _gdTestErrorMsg(const char* file, unsigned int line, const char* string, ...); /* public assert functions */ #define gdAssertImageEqualsToFile(ex,ac) gdTestImageCompareToFile(__FILE__,__LINE__,NULL,(ex),(ac)) #define gdAssertImageFileEqualsMsg(ex,ac) gdTestImageCompareFiles(__FILE__,__LINE__,(ms),(ex),(ac)) #define gdAssertImageEquals(tc,ex,ac) CuAssertImageEquals_LineMsg((tc),__FILE__,__LINE__,NULL,(ex),(ac)) #define gdAssertImageEqualsMsg(tc,ex,ac) CuAssertImageEquals_LineMsg((tc),__FILE__,__LINE__,(ms),(ex),(ac)) #define gdTestAssert(cond) _gdTestAssert(__FILE__, __LINE__, "assert failed in <%s:%i>\n", (cond)) #define gdTestAssertMsg(cond, message, ...) _gdTestAssertMsg(__FILE__, __LINE__, (cond),(message),__VA_ARGS__) #define gdTestErrorMsg(...) _gdTestErrorMsg(__FILE__, __LINE__, __VA_ARGS__) void gdSilence(int priority, const char *format, va_list args); int gdNumFailures(void); #endif /* GD_TEST_H */ libgd-gd-2.1.1/tests/gdtest/test_config.h.cmake000066400000000000000000000002161245535672000213640ustar00rootroot00000000000000/* Define the full path to the top src dir, required to get the path * of each input data */ #cmakedefine GDTEST_TOP_DIR "@GDTEST_TOP_DIR@" libgd-gd-2.1.1/tests/gdtiled/000077500000000000000000000000001245535672000157535ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gdtiled/CMakeLists.txt000066400000000000000000000003431245535672000205130ustar00rootroot00000000000000SET(TESTS_FILES bug00032 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gdtiled/bug00032.c000066400000000000000000000014671245535672000172710ustar00rootroot00000000000000#include "gd.h" #include #include "gdtest.h" #define exp_img "bug00032_exp.png" #ifdef _MSC_VER # define snprintf _snprintf #endif int main() { gdImagePtr im, tile; char path[GDTEST_STRING_MAX]; gdSetErrorMethod(gdSilence); snprintf(path, GDTEST_STRING_MAX - 1, "%s/gdtiled/%s", GDTEST_TOP_DIR, exp_img); tile = gdImageCreateTrueColor(10, 10); gdImageFill(tile, 0, 0, 0xFFFFFF); gdImageLine(tile, 0,0, 9,9, 0xff0000); gdImageColorTransparent(tile, 0xFFFFFF); im = gdImageCreateTrueColor(50, 50); gdImageFilledRectangle(im, 0, 0, 25, 25, 0x00FF00); gdImageSetTile(im, tile); gdImageFilledRectangle(im, 10, 10, 49, 49, gdTiled); if (!gdAssertImageEqualsToFile(path, im)) { gdImageDestroy(im); gdImageDestroy(tile); return 1; } gdImageDestroy(im); gdImageDestroy(tile); return 0; } libgd-gd-2.1.1/tests/gdtiled/bug00032_exp.png000066400000000000000000000003511245535672000204760ustar00rootroot00000000000000PNG  IHDR22]IDATXI0 pEH8Ls5RD61fX`-"Z)[H2-"E*i[^fg&sKYAg&%g{kwM{tYg6ofnyIӖ|564plƱfmo86،c3TG<IENDB`libgd-gd-2.1.1/tests/gif/000077500000000000000000000000001245535672000151045ustar00rootroot00000000000000libgd-gd-2.1.1/tests/gif/CMakeLists.txt000066400000000000000000000004671245535672000176530ustar00rootroot00000000000000 SET(TESTS_FILES gif_im2im gif_null bug00005 bug00005_2 bug00006 bug00060 bug00066 bug00181 bug00227 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/gif/bug00005.c000066400000000000000000000016121245535672000164120ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; char * giffiles[4] = {"bug00005_0.gif", "bug00005_1.gif", "bug00005_2.gif", "bug00005_3.gif"}; int valid[4] = {0, 0, 0, 0}; char *exp[4] = {NULL, NULL, "bug00005_2_exp.png", NULL}; const int files_cnt = 4; FILE *fp; int i = 0; int error = 0; char path[1024]; for (i=0; i < files_cnt; i++) { sprintf(path, "%s/gif/%s", GDTEST_TOP_DIR, giffiles[i]); fp = fopen(path, "rb"); if (!fp) { gdTestErrorMsg("<%s> Input file does not exist!\n", path); return 1; } im = gdImageCreateFromGif(fp); fclose(fp); if (valid[i]) { if (!im) { error = 1; } else { sprintf(path, "%s/gif/%s", GDTEST_TOP_DIR, exp[i]); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } gdImageDestroy(im); } } else { if (!gdTestAssert(im == NULL)) { error = 1; } } } return error; } libgd-gd-2.1.1/tests/gif/bug00005_0.gif000066400000000000000000000162441245535672000171630ustar00rootroot00000000000000GIF89aa8IYiy9UGƶi)I s!5z{+UFLtȉ *ݖ젌T,|jmb `JˠcͽƇ\]NǨ?KЍ$͝-cV^ >^ VFvapI CU&W2%{kF%sXVޗ\ +FD3$!56Kb٧Џ/{ RL啤bk; u Zά$ l+l~~RKgM.5yA8|8A.Ǽ9F w4yr͉CM=[bx}i# >JTo|Hv_R-UT~R\8:6aiaTL:!8u䬧y/yM6q51rhդ^AْB)JX6{*v'ҘW fV"%I; uhYs`ZMt֖zű7'ے9ڶ~B+'(ՙh VG* b(^N Y7rΙb^ݚ-:P/3^ 9y#FF ܞ.NaM"neU%9t޹u'@ۭ (3fmHpH S"|]rTjCC9 Y kM4} *3_-xiIq\g̬(,0:߸Չ\4<5M(2]~f95QLA7-^/òX(Mһ:,^u{x)M-r ěW Dt'>ЮsX}&O-bdc5"X2 y:>uꙞu#;y:/ڹ+Rb}>.\jDSFo'yoV2cj)>ddm3 \_ S!Pt6bXmc0o$6e`sDBgc9T r!>:! ecp=(5S@ÑCܱ "b\xϲ5 :KOx?7B+8;QF5"%4)T d*يgRl^XAmOR?901lSjHS-B!Kdx2B;Ba15^`,AcRĽ|iYL q:Vc27o9a4H̕3u3l/iۋ$%eiNOҧ%103 $>alABh['rIs[݄O.TU$'2H*Vsy)$zéc1q1>IMְϨ SUT]Q霢ldb) >縺ULkXt kq"](m`GT`KmIU^\_`ԑYRpُATġN12UO_U~Ƿ&?I"5/Ƈ4=UڭyY{>PMVsOĊ*Ie2?j-K2ua|WKlhmn[+Ѵu)\p6S=xuK kz4\cOZ Jj5jj;s!~96è=]0wCV\kX5!m>"CB,}L GxZ~Jdc*LoEf-c}JXYo),qc)4jsƽ~'kC X\2{'I$+Hg`Eh5BMzO¬wS歠/C}jNKp_Vv[>c5gG6'5 ͡S&jPT%6vF4ec @hlF6|c)Xz4@x/XQdWĤ8hggW~W~%GeK~!fU`kxgh7eZjŁ6rd3tywV5<Z(}*G5WUX.f~:}pN>scqp&y!X(04NV}GG(l*DmQk%v}Y$p\ߖ)hVNwVt'zv3e1^ycyqW$>tW]4T6sPaFyv}䂊eYo#neGG(Nz^'pfnMD{jAq=#vHLB58ǍXpX}prhs狪'P}d1:77vaqLԊ(Sls(gQwi]vXbEsaXi)iwu{c-9f{ŀisI'"Y&hy-9~ W&EQ;I>9ibywuFB98 sbvLn۳~;y`4KølOY}QR#3<ԁxk'fu+nwh[F|Hq$AVg8 xgzMF~ocju/mh =I-VqhT?v{?ejt\M2kX[dhjg{։#iw174GF"n9 q4VRxi7{YH'wD `ɋk%x~f{Sv㉖I\G^淁\ȋ7qل Ltl znh5urR; pNxa~&S 砨sIYnyE/uN)%Ő\)h :lաPX[Whٗ8H5eP83&rwFYBjPʔIuoȈ` dd)rڋ}ĎSej#yڦUX62F6"fJ<*8e@cnhttOZ]Ȅl3gDvUQJ>Xs gLD D:tn+I4?F?W)ɝt>"\:ںVA=Pj^ۢx*[+C oY?Cr󻛤OH);ʘqZvW*k{FZ dX8Z'*)J-Rv>j*Plǻץ9A(HYۊ,~D[s3PZ`($|o˺UGOˢ ۚKho^uszn'ģPЛ>Af{ؑufu@5ܺCX{ ieP, jKVCRj*vj}+ls<1q[b f.'D{J<8'(O|g*>{B}(ƍf!.ΞjzC:=PN\nT*a N&rXYMX)qnw4= ^¦mV+e+ӛF~nnPS~ű DP^@!|}3U:È߫@M7Ծ*.BKLsYV-"7{'SB>U,:<[^) iV6:t L RyߟcRˁ=WJ7D:ײ(yq(.Af+9Ot Wn) Mšf?W-۫jީzOB||μONZ$Ehq]*p?ϴF@W5Ԣȫb8^ %}0=5PXLfKʏ  S# +ѕmK:_حhSyy#M4 QΌ& ,AjDe]Hzɷ51*s9[SD;2Kl ip1hI'ePG0P&O 44H10d5U 5nJ+RX7nlي96rMUs8Y<|\Sz5;nJsV)ޭW ߭velL/"xq„ !uRaE1-2d-;B2gWzZvZA4+m$Il;2z%4(7ހF(\ |tJ8u`'xB\Id=TIѕt{}vkS>tB 遙Qs"yxX1a(n_7# )KUje]N9)y_-.*wϏˊ] l+ἩlqYvG\XMC>zM3n_O~qoȋ裫KxA0;]Ϳ9D 9$aa=.- /0)-|&0!4 g >NƷQȗ^*F_Ӯ3z dJ3~l-DH|$+C< * K6ːq; |ECd pjt Q}JJ|r%>BnOBK)(SFMb*KTDiBSsP1QL-8~ū 3(oQ zaO]Ks4BʤSZH_7rtZq9 vÜ>їX:uWݷ6iVVgKu4}U3OԯNbmUDhOLd`'Sӻd?u M 9nk#=Wex8D1#9b{첓NJ9wm\Jz4ɽx奟Nz*t=ұj=_7gan.;)}TG,,%Oc+~A0@Qdb̔X ȫ繯(|0@)yM"V]21teOPc BⰃ]a&7$Ҏ"2-)KHeNHN'(Qp3U&M-IMC*^Pz-$" !iPVxrb#cF3FLĶmHI< \1l)&_6|& *Dž1|$/Lє4IrW+!IMo~898R f|v[LNRiFYժ ;libgd-gd-2.1.1/tests/gif/bug00005_1.gif000066400000000000000000000000431245535672000171520ustar00rootroot00000000000000GIF89a < , Ҷ˵˲libgd-gd-2.1.1/tests/gif/bug00005_2.c000066400000000000000000001046551245535672000166460ustar00rootroot00000000000000#include #include #include "gd.h" static const unsigned char gifdata[8994] = {71,73,70,56,55,97,20,1,110, 0,247,0,0,247,247,247,255,251,255,231,231,231,214,211,214,239,235,239, 206,203,206,173,20,0,222,219,222,24,69,173,24,73,181,16,52,132,16,60, 148,198,24,0,181,178,181,247,243,247,140,16,0,198,190,189,189,186,189, 24,77,198,231,227,231,239,239,239,198,195,198,247,243,239,189,190,189, 198,199,198,8,81,8,206,207,206,8,36,99,33,89,214,214,36,8,214,215,214, 24,81,206,156,158,156,239,186,0,222,223,222,0,101,0,214,174,0,99,150, 239,49,101,214,74,125,231,8,60,165,181,182,181,156,154,156,115,162,239, 222,223,231,57,113,222,107,12,0,0,125,8,255,207,0,189,182,189,173,166, 173,165,162,165,231,73,49,41,81,181,255,117,99,189,150,0,90,138,239,165, 166,165,16,69,181,173,170,173,198,158,0,173,174,173,247,105,82,231,60, 33,253,253,253,239,89,66,99,211,99,222,48,24,90,203,90,181,36,16,132, 170,247,249,249,249,148,121,0,16,150,24,181,142,0,132,105,0,99,81,0,41, 73,148,173,134,0,189,44,24,107,44,33,49,182,57,165,130,0,173,199,247, 206,60,41,165,190,239,173,170,165,198,215,255,189,227,189,99,121,164, 107,211,115,247,134,115,255,239,8,90,105,124,140,32,16,148,65,49,132, 134,148,247,150,132,148,146,140,115,121,140,198,146,140,165,166,173,189, 207,239,206,213,214,41,65,107,132,125,115,217,215,203,234,234,234,123, 77,66,239,242,247,148,174,222,203,206,214,74,97,148,132,154,214,222,219, 214,247,251,255,123,134,173,165,134,123,23,64,154,140,146,148,57,186,66, 181,178,173,165,170,173,24,162,33,107,105,107,66,195,74,218,229,255,82, 109,173,198,199,206,156,101,90,123,101,82,73,85,115,59,89,147,123,219, 132,132,146,181,247,223,90,231,235,239,206,174,165,89,129,214,214,182, 181,165,182,214,210,210,210,247,186,173,222,227,231,57,97,181,247,166, 156,148,158,181,231,231,239,194,194,195,181,182,189,217,217,217,181,69, 49,255,247,255,247,247,255,198,117,107,214,219,231,214,219,221,225,225, 225,173,150,140,206,199,198,132,117,57,33,170,41,181,186,198,244,244, 244,156,134,66,181,195,222,255,235,231,231,228,222,206,235,206,231,219, 222,173,178,181,247,215,41,181,162,99,168,167,167,90,117,90,181,166,140, 255,203,198,115,142,206,192,191,191,239,231,231,170,146,49,247,215,206, 189,158,16,255,247,132,241,241,241,255,255,247,206,211,231,185,184,185, 181,89,74,25,57,127,222,203,140,239,199,41,13,55,146,206,195,165,214, 101,90,255,239,49,222,203,198,165,174,189,231,235,255,206,174,41,222, 186,66,12,50,133,201,201,201,255,243,181,178,177,178,181,170,165,239, 247,239,255,243,239,255,255,239,156,211,165,255,247,247,180,179,178,247, 231,214,140,203,140,239,227,148,222,239,222,165,164,163,173,142,16,239, 235,231,255,251,222,214,215,222,247,247,239,10,45,119,90,170,99,25,77, 189,140,174,140,222,215,214,162,160,160,123,150,123,146,148,154,66,142, 66,22,74,190,41,93,49,24,121,33,154,153,153,197,196,193,157,154,153,166, 163,160,215,212,209,3,26,76,11,34,87,148,147,149,42,62,109,152,155,165, 43,98,218,155,153,151,155,182,242,145,172,230,154,155,159,209,221,243, 247,235,247,133,133,139,184,181,176,24,46,97,243,244,246,255,255,255,44, 0,0,0,0,20,1,110,0,0,8,255,0,255,9,28,72,176,160,193,131,8,19,42,92,200, 176,161,195,135,16,35,74,156,72,177,162,197,139,24,51,106,220,200,177, 163,199,143,32,67,138,28,73,178,164,201,147,40,83,170,92,201,178,165, 203,151,48,99,202,156,73,179,166,205,155,56,115,234,220,201,179,167,207, 159,64,131,10,29,74,180,168,81,154,136,190,41,253,70,132,136,22,45,133, 162,22,194,114,180,170,213,151,156,204,141,120,241,34,73,168,62,66,158, 106,9,75,245,170,217,133,153,140,93,49,51,165,138,219,42,83,204,92,49, 54,231,236,193,0,0,48,233,213,218,245,43,212,168,66,250,68,193,19,205, 153,221,179,20,116,85,41,113,194,4,7,9,9,18,232,152,28,57,129,4,14,38, 20,25,49,147,233,48,94,11,4,38,16,168,144,97,107,146,40,78,11,85,139, 198,186,90,181,178,135,137,226,221,196,72,145,227,15,184,63,64,78,128, 162,183,111,223,146,117,124,48,81,98,138,49,179,1,28,8,56,160,161,64,1, 116,165,95,236,193,211,52,154,62,76,177,171,78,114,211,130,195,7,14,224, 193,75,255,144,160,163,55,130,38,132,224,252,249,3,135,80,147,5,11,80, 32,184,204,225,196,138,43,86,147,11,240,128,33,70,10,232,35,140,224,21, 30,120,84,147,138,0,22,0,144,221,80,186,196,226,29,110,225,237,38,31,33, 89,72,82,9,6,26,168,225,129,28,28,14,0,136,36,89,16,2,95,13,152,181,80, 2,126,71,129,118,64,5,13,244,0,93,116,123,12,166,197,1,44,16,160,224, 130,63,109,162,200,120,16,122,183,219,121,89,148,1,65,5,16,64,112,193, 145,69,14,137,161,28,34,28,32,74,22,35,154,208,130,125,126,24,21,0,5,34, 176,40,131,43,25,192,136,71,31,90,164,82,227,141,56,234,132,151,33,8, 160,96,89,110,227,241,134,64,144,41,52,32,103,4,116,214,105,231,5,69,98, 48,128,8,128,100,161,192,2,53,76,137,67,21,157,17,165,220,0,41,108,217, 229,86,95,17,81,8,1,20,56,64,102,153,56,29,208,132,2,10,200,103,217,143, 40,16,162,130,156,13,164,144,39,6,164,146,58,100,157,49,248,119,164,6, 114,84,66,136,2,8,152,255,112,2,14,43,84,57,84,0,251,37,202,101,116,95, 9,81,136,3,120,81,154,19,94,19,192,177,193,6,127,34,96,153,155,89,88,33, 231,5,21,96,56,192,1,7,136,96,237,1,26,14,208,28,4,254,197,217,64,12,24, 142,177,193,2,144,204,90,130,25,183,98,201,98,26,139,190,208,107,33,216, 9,155,19,104,44,12,48,200,177,201,78,86,195,29,161,66,160,193,180,19,32, 8,105,130,160,81,0,218,181,26,96,112,65,139,45,70,160,1,24,200,6,90,66, 113,66,1,96,193,1,16,52,192,46,175,96,193,43,47,78,42,42,156,199,189, 200,198,87,131,10,162,22,224,129,104,145,254,19,64,0,46,199,236,50,0,22, 19,32,128,28,3,84,16,129,156,50,52,128,193,29,17,155,88,66,21,62,189, 236,50,150,25,111,204,104,199,147,126,252,146,209,120,9,48,192,5,59,204, 0,2,201,10,52,33,195,5,42,215,40,233,66,80,31,189,92,1,25,91,145,195, 214,226,42,80,195,9,19,79,1,84,114,44,96,208,0,24,237,190,27,175,211,52, 29,74,181,10,124,223,255,155,117,4,123,18,240,181,68,120,133,54,64,198, 85,231,16,65,23,17,179,77,113,209,14,28,32,247,29,117,119,236,0,222,53, 133,220,192,12,124,131,192,184,2,89,8,222,52,225,14,16,112,64,1,41,88, 61,67,15,104,140,107,2,14,19,219,218,19,0,19,20,208,0,229,48,130,165, 133,5,152,215,164,220,138,155,131,48,67,30,116,16,82,67,41,26,93,57,118, 10,57,204,144,3,208,27,196,10,251,10,133,238,132,215,233,41,136,209,238, 30,186,243,222,251,76,250,1,111,197,14,128,159,178,201,38,28,209,139,65, 234,32,200,224,247,218,19,27,209,19,177,168,107,159,123,88,163,127,239, 82,114,166,235,44,234,0,4,216,8,212,126,87,129,30,88,77,12,199,90,192, 235,86,80,2,217,233,132,118,168,83,193,246,116,103,24,253,129,175,116, 204,193,64,1,0,152,63,140,232,205,10,237,123,159,137,86,32,63,235,65,48, 5,18,188,159,22,42,104,193,153,28,140,90,19,160,64,7,47,2,183,245,89,13, 98,174,163,213,125,120,162,28,13,196,32,133,91,153,78,88,255,88,216,66, 23,18,224,136,51,164,33,6,11,168,2,16,180,78,109,38,50,130,17,234,114, 16,0,240,65,4,120,225,3,11,60,192,135,46,34,4,106,212,112,68,36,194,176, 133,45,132,33,18,142,160,134,68,148,19,193,237,225,97,136,63,217,198,50, 110,113,136,58,214,241,22,203,216,6,52,72,98,10,88,140,177,140,101,12, 131,35,106,241,12,1,210,76,36,81,211,64,240,62,167,64,28,24,161,86,8, 153,0,31,48,240,15,8,240,225,0,22,136,1,31,12,134,144,89,132,65,24,52,8, 101,40,127,240,131,33,144,50,8,97,168,133,67,162,214,70,47,57,229,26,5, 97,68,44,98,17,135,90,74,81,138,111,129,203,20,118,201,203,43,248,161, 13,31,209,134,47,126,1,131,98,194,32,4,200,76,102,8,126,113,136,91,236, 177,35,169,248,100,16,70,73,202,33,116,160,3,67,24,2,13,124,16,9,83,240, 4,102,87,90,81,213,210,144,192,181,145,144,104,7,145,36,4,2,144,134,28, 76,224,31,23,224,195,93,0,64,6,107,254,64,148,165,236,64,17,246,201,255, 128,107,254,192,6,170,100,8,0,4,208,202,32,82,71,11,176,140,217,149,36, 177,128,76,169,105,60,37,50,215,196,38,134,131,19,88,116,86,70,184,66, 245,44,114,10,100,32,179,152,200,36,1,9,120,96,139,146,222,224,6,60,32, 65,8,96,112,136,109,104,36,21,194,200,230,61,105,144,207,34,60,225,166, 69,48,64,63,181,185,5,53,242,132,118,138,228,220,19,17,16,69,35,28,199, 32,26,224,3,1,26,112,201,119,90,242,32,169,184,196,78,171,217,129,39, 240,130,12,137,88,68,34,200,112,137,125,242,212,155,10,233,97,12,64,224, 198,87,202,44,88,19,160,67,67,227,51,31,204,152,139,129,37,168,168,99, 30,3,209,19,24,149,34,201,241,133,74,149,41,82,91,176,34,24,159,200,144, 26,130,193,138,108,40,129,7,43,61,196,51,35,2,78,10,104,162,3,12,48,37, 85,159,160,137,172,106,128,24,159,72,132,38,114,138,77,26,132,1,172,53, 129,217,204,164,118,1,25,56,17,89,210,147,34,186,12,162,177,127,8,143,0, 148,204,129,60,11,66,140,39,255,48,160,159,216,132,236,37,154,113,6,78, 208,8,17,109,64,68,34,190,80,4,42,252,192,7,176,80,200,64,7,16,1,32,118, 229,160,9,197,139,114,2,102,129,62,101,225,186,116,128,132,4,164,116, 209,22,56,230,15,113,96,4,35,36,241,135,182,158,160,10,84,132,200,41, 142,33,82,190,242,128,21,16,56,131,7,6,48,45,22,76,2,75,175,200,198,13, 72,0,131,97,44,131,34,226,160,194,109,177,105,77,125,6,226,2,103,72,48, 181,30,1,220,3,144,193,11,197,61,110,114,135,69,129,21,153,205,111,11, 224,0,173,140,128,206,130,16,160,80,162,13,86,65,82,241,4,157,226,22, 178,129,16,5,145,134,228,28,149,33,226,17,129,48,0,21,104,16,4,71,36, 100,185,99,109,87,18,14,138,138,129,76,87,91,27,164,47,171,36,161,172, 203,152,192,49,18,128,68,49,6,112,138,89,12,236,13,229,149,18,36,31,162, 6,91,164,116,175,125,125,133,145,144,84,129,22,79,139,0,106,160,133,19, 248,203,133,91,72,100,17,69,184,237,137,25,80,4,79,108,121,255,72,16,32, 213,6,15,208,134,79,124,65,198,52,142,196,3,107,215,0,25,48,210,156,82, 188,156,68,44,118,9,3,232,244,154,144,229,197,183,184,76,36,57,31,0,198, 50,14,130,15,108,124,144,67,69,128,172,209,217,177,83,80,209,216,45,22, 64,97,17,136,65,3,46,64,135,100,141,103,60,58,248,3,215,228,252,175,3, 32,136,14,177,98,27,138,24,162,6,148,94,89,164,36,176,133,226,34,16,231, 82,193,217,209,7,32,197,152,97,80,102,176,129,243,31,139,48,244,128,33, 203,102,79,48,58,206,43,150,115,147,238,76,5,73,235,153,38,33,6,0,1,166, 182,131,180,41,32,1,81,156,50,67,178,77,207,7,60,224,208,215,164,194, 168,53,248,175,230,232,12,79,16,208,16,113,183,137,220,42,74,237,210,58, 230,177,64,146,131,165,109,249,103,110,152,90,0,2,116,16,153,84,167,128, 215,165,234,242,156,181,81,222,22,192,110,214,9,81,131,126,121,112,235, 145,190,2,90,210,202,150,187,35,0,111,109,129,66,10,100,54,115,67,62,97, 104,19,171,153,1,110,255,134,64,1,254,165,241,156,113,188,72,30,40,0,20, 188,80,109,110,230,164,194,5,244,182,244,86,176,130,213,62,36,57,7,240, 130,185,15,157,77,50,204,57,96,4,176,214,0,200,230,31,135,205,224,1,79, 144,180,13,64,235,227,123,99,218,52,250,222,183,182,39,0,100,12,148,97, 173,69,30,79,13,122,112,1,118,107,43,97,120,170,0,198,0,197,54,113,27, 132,118,180,80,2,74,113,45,82,248,22,128,70,162,57,162,0,4,192,117,166, 167,32,5,111,104,198,18,156,16,2,46,20,219,32,80,11,0,137,149,125,114,6, 104,194,57,129,59,98,192,248,190,116,110,249,231,13,79,47,194,54,109,64, 233,208,226,124,110,200,130,213,2,87,224,182,159,59,160,13,117,112,129, 234,207,221,89,181,67,74,82,52,163,151,203,229,4,8,54,60,128,10,62,176, 65,24,246,173,245,123,59,87,211,66,232,241,64,94,182,117,230,192,33,89, 155,26,143,36,156,67,35,190,55,233,211,23,56,184,6,224,208,200,18,76, 241,46,14,96,133,20,228,94,241,99,64,192,3,53,74,208,255,141,10,183,28, 13,64,192,91,128,0,197,18,110,64,108,46,252,119,158,0,8,196,185,77,126, 219,75,0,98,101,71,28,156,116,199,118,126,57,97,192,246,81,103,3,0,101, 19,112,195,34,16,131,41,8,80,31,60,215,97,227,134,65,80,160,122,46,96, 110,69,208,1,52,48,38,5,17,123,82,131,56,162,144,6,46,240,4,52,32,128, 201,149,109,86,167,99,168,17,124,136,7,0,20,48,11,197,128,124,18,144,27, 89,160,50,175,39,41,178,231,63,16,0,6,106,227,56,165,71,16,201,17,12,82, 224,4,135,69,119,36,144,8,43,51,56,5,129,23,203,133,56,217,195,4,32,71, 108,195,128,16,52,147,8,67,71,127,12,208,12,156,48,1,68,168,131,52,115, 111,13,176,3,49,144,122,52,151,123,91,112,55,50,81,128,160,23,112,245, 81,2,43,192,128,11,97,49,181,35,8,16,24,129,58,53,4,226,160,92,164,213, 34,98,224,2,95,104,3,91,112,129,190,71,130,68,96,130,111,71,1,197,130, 124,185,193,1,162,112,10,54,130,133,203,85,64,183,227,58,104,255,184,2, 192,52,124,14,48,1,180,208,131,115,183,87,200,192,9,8,178,134,22,112, 111,59,96,54,76,176,126,133,119,120,4,97,49,143,240,5,243,183,108,12, 192,11,154,40,104,9,1,55,220,102,54,80,0,117,65,32,128,157,55,134,3,229, 67,7,248,39,28,224,112,214,247,16,203,117,1,61,32,6,130,240,128,112,200, 0,52,16,9,133,116,23,234,210,0,32,52,139,1,104,3,19,38,16,203,133,111, 153,86,130,194,119,129,181,131,6,132,136,27,138,96,129,136,23,57,114, 195,57,17,163,67,83,0,53,218,22,1,72,96,137,41,149,76,193,176,137,227, 102,1,181,195,60,101,32,8,131,71,102,195,176,88,51,67,0,205,16,133,39, 214,1,137,208,50,13,40,57,155,147,3,108,224,2,154,167,135,91,64,117,49, 1,65,23,144,54,2,183,93,22,181,2,192,40,0,65,197,55,42,144,6,108,240, 128,15,208,79,158,197,144,212,120,111,57,80,6,179,152,144,54,112,109,33, 57,0,63,228,135,128,88,138,88,162,7,1,55,31,223,241,1,110,144,136,243, 180,109,84,255,131,64,55,72,66,70,112,35,218,22,108,235,232,4,251,181, 87,199,16,67,192,136,147,86,80,143,76,128,4,60,208,126,214,144,109,4,0, 99,254,136,104,84,128,73,171,68,59,83,35,3,6,137,135,213,182,5,156,87, 19,16,180,56,37,51,31,82,98,34,15,161,55,50,128,145,159,210,0,117,128, 138,6,224,79,91,48,141,251,134,115,61,144,3,15,88,92,185,103,3,203,248, 15,213,120,117,93,81,130,176,161,117,245,2,52,166,6,30,38,112,6,135,244, 69,23,99,59,132,73,84,214,183,2,44,64,141,19,128,1,75,176,142,63,152,76, 190,96,147,13,113,37,89,178,57,105,176,148,55,48,138,77,56,16,160,81,1, 66,119,110,184,85,116,9,242,115,4,16,55,73,233,134,180,168,144,153,115, 111,198,82,152,142,161,8,171,132,65,253,97,54,86,195,133,52,178,8,154, 224,5,68,55,105,227,71,59,114,67,146,231,86,109,54,224,3,1,197,151,219, 214,92,44,25,152,46,115,49,26,0,145,9,120,100,138,160,153,78,56,153,101, 184,115,43,160,11,206,41,2,175,255,80,153,62,216,142,200,164,6,233,229, 16,185,232,153,161,168,4,100,198,5,62,165,109,44,224,9,17,136,154,216, 68,74,196,144,68,149,38,53,41,160,7,176,153,144,94,153,10,23,52,143,220, 152,44,223,1,30,184,153,155,229,215,31,91,216,51,42,87,35,14,86,104,135, 246,145,2,97,145,49,96,151,231,22,128,62,176,8,3,81,141,191,7,152,23, 184,109,16,224,109,9,208,139,45,16,7,210,32,80,22,154,54,222,233,54,180, 115,6,117,64,158,251,245,81,191,48,9,250,249,118,56,185,3,159,121,143, 78,41,153,103,16,8,245,25,135,167,36,0,233,217,16,193,216,3,255,137,123, 94,121,139,79,35,143,5,192,58,127,178,0,9,112,160,31,16,11,16,161,31,19, 32,2,27,71,39,101,231,98,136,0,156,57,213,79,63,176,5,106,208,6,44,112, 1,200,105,0,209,136,146,125,25,157,5,193,70,15,137,47,177,118,2,140,208, 16,108,36,150,176,114,134,67,147,11,166,147,126,50,186,87,48,224,11,55, 138,120,21,6,1,58,26,138,195,70,108,135,192,151,21,255,86,0,7,57,116, 157,69,3,154,48,7,131,202,123,225,4,1,170,0,155,145,38,128,187,55,134, 88,242,51,49,41,28,224,241,1,113,64,56,218,38,0,34,16,115,239,150,36, 255,210,96,92,101,114,87,213,159,66,167,166,31,168,123,90,247,156,31, 250,135,129,25,0,78,10,122,168,37,43,56,240,6,70,90,59,35,131,128,189, 56,49,85,16,140,234,135,4,66,9,168,190,64,17,22,32,2,73,131,168,77,73, 108,171,192,151,247,198,145,172,55,83,137,48,17,1,208,6,24,147,169,112, 24,141,91,224,61,45,1,53,141,58,6,49,57,165,163,234,6,20,17,123,20,176, 28,49,71,54,44,182,65,44,16,92,192,169,9,188,208,85,95,32,8,179,234,129, 185,215,169,206,201,92,185,42,4,187,234,164,121,0,61,162,135,3,56,0,158, 2,85,59,48,153,44,189,104,81,165,0,65,13,176,4,127,186,82,48,160,6,208, 26,174,203,234,4,136,101,173,124,201,103,218,90,4,218,20,4,65,64,12,29, 139,169,143,170,166,181,40,128,149,74,18,1,32,162,175,2,31,50,255,25,30, 62,135,87,0,240,99,219,82,175,46,166,32,203,165,49,67,7,176,62,32,176, 218,166,146,5,187,171,205,120,90,209,3,172,232,3,54,253,102,131,127,50, 165,101,105,6,210,32,57,57,16,138,204,138,88,43,245,11,218,176,178,170, 240,177,33,11,3,171,208,13,224,138,1,50,80,178,39,235,3,167,0,182,45, 235,129,2,104,3,230,186,63,71,91,6,235,218,130,222,97,2,147,144,17,159, 17,26,204,81,0,141,166,65,3,80,133,173,153,51,242,151,161,244,102,180, 125,120,141,186,170,141,5,228,103,229,52,43,14,171,16,225,84,0,53,59, 112,7,106,2,2,32,142,89,75,173,26,251,11,174,120,165,14,16,55,97,75,158, 99,187,10,22,80,168,118,89,159,69,240,3,82,71,1,222,42,142,105,59,174, 155,231,3,1,244,15,180,193,75,114,113,5,188,219,187,188,187,187,14,132, 17,64,87,157,81,90,100,51,153,160,2,228,0,178,215,28,142,118,45,5,32,10, 182,199,122,137,123,171,72,235,166,195,7,84,155,131,64,65,131,3,200,3, 54,166,3,147,54,255,219,130,222,40,13,20,144,149,76,16,138,82,112,186, 49,171,131,72,147,3,24,139,4,135,165,177,168,91,190,165,85,178,174,235, 3,229,122,165,224,52,186,24,128,161,210,155,123,182,43,16,143,240,42, 109,229,139,60,199,64,21,213,2,10,76,37,201,131,115,151,18,190,120,75, 147,31,65,124,161,145,170,243,53,45,56,131,182,167,249,150,52,22,4,108, 186,184,166,1,162,165,200,159,86,195,56,227,210,139,238,74,185,218,166, 6,199,39,112,201,39,1,21,155,163,130,224,185,197,116,8,27,101,122,113, 163,2,149,41,5,51,90,76,191,208,137,204,181,186,17,216,186,62,128,191, 120,197,191,119,8,169,247,107,3,192,162,32,4,112,124,100,105,31,183,196, 24,222,101,152,82,22,188,222,106,58,134,80,188,145,33,190,31,48,185,2, 164,117,228,55,121,56,83,1,117,16,133,29,224,186,65,192,161,212,184,109, 43,201,184,6,91,132,133,186,3,125,19,49,175,19,186,132,58,11,134,96,179, 4,87,112,127,96,1,64,28,1,59,48,195,149,25,154,53,188,190,195,135,115, 49,255,202,172,61,12,3,200,144,139,49,160,10,7,57,196,199,85,180,239, 138,37,128,0,164,74,140,178,54,0,0,202,115,49,151,146,128,14,71,66,60, 23,11,127,0,9,53,144,202,36,242,29,43,112,84,20,193,70,151,219,197,185, 209,2,136,236,173,158,172,188,130,120,56,168,104,159,51,213,156,71,11, 157,112,44,157,188,90,59,99,213,68,34,164,134,23,104,1,21,208,4,190,161, 44,147,1,195,52,35,162,135,10,154,26,187,168,89,124,56,203,202,195,206, 250,15,22,138,164,171,71,196,150,124,205,16,176,203,134,150,198,161,20, 6,115,144,116,204,33,7,140,35,165,245,1,59,56,224,6,64,182,114,9,118,6, 111,80,10,140,80,10,55,188,153,71,163,199,92,204,35,184,145,194,40,161, 28,243,57,149,167,116,187,3,11,204,33,220,184,69,40,162,156,19,66,39, 124,2,16,87,16,185,240,6,53,208,204,205,44,9,54,130,130,30,32,140,98, 112,190,75,224,158,53,92,164,14,113,40,23,107,153,230,25,2,79,185,31,73, 243,205,53,39,176,87,106,177,27,60,85,63,255,176,8,115,192,127,120,186, 0,219,53,37,39,10,1,28,167,65,154,184,151,22,161,109,5,240,30,46,124, 106,120,123,0,41,65,44,103,224,150,38,70,96,154,0,149,4,107,189,46,179, 191,243,168,58,49,160,174,177,86,5,120,44,16,140,112,209,240,17,31,190, 65,7,53,226,50,145,115,1,32,4,210,75,200,82,181,60,178,103,224,9,59,124, 153,200,116,10,87,114,166,207,168,122,145,102,196,166,58,1,48,58,149,50, 149,10,3,181,34,59,243,57,121,90,150,113,112,1,162,134,39,119,23,67,93, 125,165,41,232,39,2,167,44,47,28,7,109,125,17,22,48,9,158,224,143,59, 213,1,139,32,213,10,253,151,12,93,132,139,201,60,171,83,0,146,32,122, 108,51,5,126,48,9,147,64,27,138,80,30,97,13,31,127,98,8,106,176,185,71, 35,78,178,117,190,76,185,82,171,80,203,188,122,0,111,64,10,204,42,119, 237,21,2,200,144,9,223,42,57,175,185,122,0,107,3,251,60,110,224,250,6, 228,140,110,29,32,12,117,97,177,59,64,216,215,105,81,110,64,54,165,255, 178,65,34,176,185,149,141,23,20,192,80,145,253,194,151,49,0,149,93,17, 40,216,212,169,184,108,84,32,0,165,232,198,126,121,26,161,29,162,30,192, 34,73,153,2,226,0,147,53,32,43,143,184,2,56,208,2,31,144,0,178,141,41, 10,0,7,101,240,9,7,96,163,211,201,103,32,240,209,237,201,219,221,32,17, 124,122,0,121,128,4,140,124,101,200,20,12,51,3,225,119,56,196,155,135, 208,21,121,0,253,248,222,136,214,173,216,202,92,144,107,172,190,200,8, 77,50,45,213,34,2,140,93,17,188,250,6,239,49,112,149,113,106,58,16,7, 171,121,18,223,138,8,242,87,114,106,6,89,100,48,41,191,156,180,9,241,59, 114,211,3,61,16,1,114,80,106,255,189,97,70,80,2,45,32,1,40,128,224,104, 0,7,119,144,7,16,192,65,189,135,40,86,51,195,76,48,108,238,183,70,2,192, 13,172,48,220,151,72,2,199,176,183,255,112,40,236,51,201,52,39,105,205, 121,150,2,240,163,154,125,91,84,128,8,251,102,58,131,29,122,9,136,131, 169,75,1,20,112,68,175,255,135,200,217,38,2,144,32,31,58,158,124,58,0,9, 7,176,222,239,74,79,37,39,133,29,32,7,103,117,180,57,22,204,202,213,63, 59,147,2,71,130,6,128,18,110,113,32,9,116,48,6,170,126,7,32,96,5,162,82, 219,161,139,130,7,128,214,17,14,210,161,201,5,214,48,104,19,160,142,219, 103,107,184,22,12,55,66,190,89,25,225,204,157,103,186,30,1,179,42,133, 137,64,69,156,201,34,218,125,134,61,87,132,151,35,98,131,70,0,127,224, 232,143,222,38,9,32,10,218,73,18,52,67,6,151,222,120,12,112,228,177,62, 130,158,78,135,7,192,92,114,146,2,161,172,167,56,240,45,102,211,60,61, 224,229,3,128,32,162,181,111,189,202,57,159,169,132,252,53,12,235,27,0, 173,173,125,189,78,113,41,133,12,54,57,204,79,106,53,124,160,122,117, 110,3,176,203,154,44,192,11,243,71,127,188,112,240,159,247,236,109,151, 179,26,49,11,89,32,31,125,220,199,193,97,8,70,137,18,150,206,120,141, 119,9,44,128,199,109,122,238,148,219,168,49,96,54,220,8,40,178,255,114, 2,45,96,8,13,112,54,174,174,114,154,104,1,247,94,117,135,243,208,132, 172,4,133,151,235,185,41,92,61,200,125,4,111,11,159,64,132,71,248,208, 143,170,121,53,54,110,251,219,6,153,29,238,183,85,4,75,63,126,88,82,0, 121,128,241,104,168,241,24,97,237,106,82,112,149,17,28,89,0,230,20,241, 12,176,176,190,179,32,12,226,126,114,69,176,8,221,206,233,32,128,14,1,2, 218,113,60,110,251,113,1,121,32,181,238,44,37,38,96,8,17,32,42,26,116,0, 53,206,140,157,201,57,42,192,6,160,217,95,46,181,153,14,160,1,217,224, 131,39,85,249,55,144,8,246,158,200,34,96,59,15,253,128,94,0,176,62,37, 80,0,240,9,57,117,233,37,247,10,240,40,16,209,202,245,140,52,232,95,207, 17,220,0,9,32,47,25,149,145,38,127,80,0,143,64,68,140,133,108,194,224,8, 55,74,79,182,213,120,166,79,6,35,63,223,42,9,2,1,98,26,141,34,157,95,52, 186,5,160,7,70,221,86,101,233,6,233,94,45,49,52,183,246,54,53,61,208,68, 139,255,191,148,77,57,154,95,4,78,115,112,0,180,96,249,150,255,10,155, 48,247,164,149,150,124,227,249,79,240,79,41,106,108,81,101,250,37,87,7, 162,113,239,205,222,0,94,31,237,25,145,11,110,64,30,0,145,64,160,14,129, 2,17,160,128,164,108,2,174,35,255,28,62,132,24,81,226,191,0,255,22,21, 161,18,6,214,179,136,1,28,16,35,67,133,193,72,146,6,76,158,172,195,137, 0,0,137,1,4,28,192,64,110,196,204,17,47,246,68,193,131,101,98,75,0,22, 42,213,64,129,64,168,4,14,45,78,224,56,99,129,194,82,7,59,37,90,152,160, 161,193,12,21,32,100,128,98,34,133,71,136,67,208,156,62,60,64,75,201,88, 178,99,95,157,153,64,97,162,5,17,5,166,170,152,145,131,141,11,47,79,126, 216,48,245,213,33,177,75,39,253,26,168,163,70,128,131,138,14,3,80,56,80, 33,79,151,13,27,20,44,144,96,2,71,9,51,122,45,59,228,166,136,160,4,9,6, 133,30,68,241,103,157,28,10,13,47,79,12,0,64,245,63,98,69,12,48,24,18, 196,198,255,150,45,154,132,253,232,64,114,228,95,148,7,88,168,149,136, 233,0,132,112,233,104,214,124,145,100,143,150,211,185,220,36,64,64,48,1, 231,162,39,226,56,0,48,135,229,233,127,0,8,36,158,106,85,84,154,37,72, 182,174,90,230,212,129,47,91,55,200,58,145,226,36,219,171,2,7,40,52,149, 152,235,123,133,240,59,98,4,114,225,129,39,98,115,196,41,0,200,112,237, 175,7,188,168,163,62,236,10,163,136,2,17,20,99,172,49,5,16,168,193,168, 202,184,155,232,145,56,58,227,172,32,161,236,88,160,196,44,40,57,128,33, 14,121,178,160,197,127,196,249,226,1,147,116,99,32,183,221,20,124,96,65, 79,222,56,96,37,136,60,248,198,28,115,210,121,129,166,12,142,156,41,185, 61,116,210,11,128,88,164,43,72,7,162,76,104,65,151,21,33,2,64,0,15,32, 152,106,134,30,0,105,6,20,36,148,32,33,132,85,110,217,198,171,0,44,160, 198,151,99,120,112,207,9,248,164,144,130,20,43,0,241,192,71,212,178,220, 178,129,28,188,124,35,135,24,139,232,32,182,72,255,106,49,37,53,10,106, 33,163,47,191,114,124,224,139,28,240,20,96,187,135,214,156,112,177,198, 44,196,208,4,35,44,229,16,0,93,98,225,64,74,17,71,44,81,129,38,192,88, 199,62,32,174,236,200,2,2,4,152,96,130,44,235,240,34,71,222,78,130,20, 82,47,2,185,211,131,74,33,236,46,26,227,140,60,50,217,12,144,219,227, 154,175,8,200,2,133,129,10,74,64,202,15,220,128,245,82,7,4,24,128,63,25, 100,104,160,128,1,94,161,69,138,27,120,40,243,151,95,144,121,19,78,37, 232,68,34,94,82,196,168,164,130,1,6,251,202,35,45,185,252,182,129,55,60, 240,228,139,25,97,251,129,6,42,68,98,128,87,72,191,168,163,222,123,241, 131,8,83,10,55,232,167,226,13,122,233,20,135,42,252,152,195,178,0,8,48, 35,142,22,62,248,160,51,207,16,40,113,129,199,224,104,229,147,20,129, 120,53,91,135,84,19,64,4,15,6,24,224,128,73,52,168,3,138,94,127,206,49, 64,47,216,80,193,97,124,47,245,8,19,1,194,33,135,28,87,158,134,218,149, 52,255,200,9,39,156,106,80,113,106,19,72,164,165,246,51,161,106,136,195, 141,82,204,240,163,141,43,83,211,178,130,20,122,232,33,5,12,88,152,32, 24,86,196,26,235,6,187,223,149,34,94,36,64,153,87,15,135,39,176,96,39,8, 245,237,118,237,182,223,158,32,145,64,4,222,181,215,161,235,240,219,94, 91,81,99,171,130,29,64,0,163,139,65,228,217,192,27,199,16,152,242,132, 18,140,152,194,140,43,78,191,194,140,42,220,136,229,4,14,72,54,217,179, 84,21,160,157,144,59,248,81,166,147,81,96,150,249,210,44,69,24,160,128, 10,134,23,183,2,79,2,97,3,10,229,151,87,158,141,52,64,136,220,3,192,35, 246,238,165,3,14,40,224,130,30,64,224,158,123,25,98,208,64,207,157,184, 1,170,218,83,83,46,17,5,41,57,160,18,135,21,170,184,34,147,203,2,208, 215,131,236,27,104,160,94,13,88,160,245,147,68,88,153,27,45,72,49,64,82, 212,65,12,42,208,67,219,240,4,56,80,57,165,126,24,136,0,254,26,0,129,1, 76,0,17,44,88,4,25,52,193,139,255,47,116,176,131,108,8,68,29,160,215,54, 201,137,47,98,22,96,1,6,122,48,14,22,178,176,28,119,232,2,33,154,176,0, 105,113,134,100,55,196,33,103,98,7,29,161,204,142,118,10,32,4,24,100,16, 1,119,76,96,119,189,235,200,182,14,112,134,236,69,80,130,107,147,1,8, 196,48,69,49,112,175,12,57,248,158,189,6,3,42,125,97,111,120,92,178,66, 92,196,8,46,12,244,168,129,15,97,65,249,160,212,67,149,53,193,141,110,4, 141,64,36,240,1,19,156,192,8,87,56,35,79,190,163,129,10,68,192,143,16, 168,128,6,6,240,136,71,176,128,27,76,188,64,10,84,161,135,43,238,32,15, 23,168,15,1,28,32,191,211,172,233,59,221,242,99,4,32,128,1,113,17,242, 17,156,176,31,4,42,177,200,111,57,18,146,121,194,142,224,28,48,129,2, 196,64,6,227,192,7,11,119,176,139,64,106,64,20,134,248,131,12,105,136,2, 94,122,237,51,40,72,217,15,127,136,134,65,140,65,12,173,96,134,50,236, 115,132,152,33,49,98,74,196,36,254,174,216,61,106,206,255,224,138,89, 212,192,4,36,217,18,11,188,100,0,124,244,227,5,36,136,191,71,70,242,140, 31,219,26,2,186,134,178,5,172,42,7,110,27,192,25,0,81,12,67,100,129,16, 7,73,0,251,90,80,130,41,228,49,34,0,160,192,4,14,160,129,2,64,0,144,21, 192,64,66,49,80,129,11,56,81,6,59,192,31,4,196,165,77,179,93,9,0,171,28, 40,4,15,186,73,225,49,52,130,15,77,96,10,32,89,65,19,114,147,0,246,107, 64,10,118,176,210,29,200,96,23,178,40,128,7,78,113,10,17,216,82,18,245, 132,131,12,103,104,135,94,8,147,118,104,32,102,23,140,217,138,86,76,67, 22,141,48,98,51,157,217,17,239,28,192,126,16,196,95,75,165,138,69,252, 213,139,71,218,204,163,162,190,227,1,13,116,213,171,94,21,215,1,182,248, 207,110,208,65,1,210,90,35,48,225,160,2,44,198,0,2,255,146,233,44,180, 113,10,64,208,97,134,53,168,163,251,174,224,177,139,78,0,120,5,40,232, 240,134,151,201,24,252,241,173,30,224,31,196,96,133,182,9,200,33,120, 255,5,61,104,31,35,16,131,6,24,246,95,218,12,156,199,182,197,9,75,20,64, 25,178,216,69,104,35,32,11,89,172,163,2,202,168,0,32,148,161,1,119,104, 0,181,160,101,36,8,94,88,142,122,196,227,128,112,105,197,44,97,42,14,1, 80,0,0,74,93,170,68,104,38,208,199,106,212,160,195,227,100,206,4,48,86, 193,1,84,0,179,90,46,116,103,53,43,192,89,160,129,169,121,67,137,212,41, 34,96,102,97,7,84,141,193,5,18,138,208,133,106,64,14,90,162,67,137,32, 113,148,18,84,193,159,212,163,192,5,157,10,86,192,214,247,95,34,208,102, 73,23,155,26,232,94,15,103,245,5,240,101,171,251,94,158,224,98,13,107, 152,64,39,14,48,128,70,104,224,19,148,128,64,4,82,192,15,102,228,33,15, 204,96,219,52,26,48,13,102,236,192,10,173,120,40,51,68,204,140,93,68, 160,2,141,176,132,54,71,193,76,224,6,151,39,14,144,21,11,68,32,130,235, 249,70,4,112,163,85,139,8,252,79,213,88,183,39,63,78,13,0,136,69,63,7, 64,235,49,66,49,255,8,10,86,149,135,240,138,55,161,29,189,64,132,53,9, 73,17,92,160,9,10,168,129,232,70,7,28,203,92,52,198,19,128,155,140,113, 60,96,23,35,13,198,212,149,241,140,225,134,95,2,172,36,59,30,235,72,0, 128,112,81,0,224,130,2,4,56,176,0,58,161,96,6,23,128,18,159,56,109,5,40, 97,218,10,144,150,120,26,240,192,1,58,177,6,10,172,152,119,101,230,142, 106,122,162,148,165,244,88,53,29,131,52,83,119,118,229,5,108,23,58,53,0, 65,12,2,153,179,26,115,181,171,24,128,192,5,26,58,89,225,161,1,203,90, 94,1,166,231,7,227,158,220,71,210,214,205,116,75,104,61,233,251,248,56, 53,217,42,12,16,88,12,51,97,31,193,216,71,24,133,172,160,75,43,22,88, 162,19,44,224,196,1,68,208,9,1,172,129,0,163,0,192,176,31,157,107,110, 67,122,77,44,40,6,237,58,45,37,29,212,160,12,35,213,230,82,238,76,128, 52,131,178,0,78,132,40,4,202,176,129,5,64,98,50,163,235,118,190,245,189, 111,126,247,123,177,124,186,131,99,255,58,61,29,9,72,66,162,34,112,51, 245,176,67,0,191,14,0,170,223,138,0,99,154,176,207,21,148,96,175,254, 198,120,198,53,190,113,103,42,10,123,96,16,248,116,62,64,135,79,220,203, 183,249,2,232,119,178,183,61,25,4,252,213,43,88,129,17,56,62,115,154, 215,220,230,221,225,86,5,198,32,240,57,154,224,2,98,125,51,95,17,163, 129,8,244,64,5,42,112,53,2,246,105,132,21,88,233,230,79,135,122,212,93, 172,180,236,129,252,49,68,81,132,28,8,144,89,238,28,6,123,111,65,3,189, 37,3,243,42,72,221,236,103,71,187,94,82,195,202,20,184,28,50,28,136,195, 74,100,205,157,109,121,192,114,72,167,119,150,97,142,173,180,247,221, 239,102,95,187,91,64,16,118,200,152,192,13,210,216,177,97,34,230,17,86, 54,96,240,143,201,80,9,98,158,248,191,87,222,242,249,6,64,227,101,48,8, 199,224,149,239,176,162,25,209,85,32,238,200,76,38,14,151,71,125,234, 251,157,121,183,228,192,234,8,48,193,233,101,150,165,110,141,225,200, 145,49,138,236,85,191,255,123,222,79,93,0,173,228,30,231,23,192,129,19, 84,244,108,124,178,242,237,217,103,120,138,244,222,249,207,95,17,218,60, 112,129,63,169,160,243,38,96,196,236,5,32,135,44,104,215,90,31,224,64, 101,136,5,125,242,151,63,86,41,148,42,200,23,144,33,63,0,155,0,134,8, 138,167,57,163,136,110,152,223,254,247,55,204,182,6,224,202,33,238,28, 50,39,104,191,232,35,128,88,240,26,243,17,136,82,192,191,4,44,63,143, 115,11,47,41,0,179,130,140,22,152,2,14,201,133,82,128,132,83,249,37,67, 176,0,197,82,192,14,84,61,194,209,158,6,136,1,53,208,131,25,34,10,28, 152,2,14,140,136,110,120,4,55,104,1,9,32,8,175,225,37,20,200,2,17,224, 50,15,196,193,212,251,54,162,139,168,5,235,62,20,152,163,22,192,1,35, 168,2,211,73,29,70,96,157,22,120,29,147,97,163,148,161,131,135,201,193, 40,212,65,196,40,168,63,242,0,109,16,5,56,160,33,130,195,161,46,44,25, 30,242,33,66,0,1,151,209,47,41,52,67,180,243,58,225,113,43,255,72,154,0, 1,168,171,25,10,138,130,208,33,29,2,67,149,89,0,56,0,131,6,208,34,202, 59,195,62,164,57,180,169,41,201,2,36,243,210,146,91,250,131,26,168,1, 161,224,26,207,112,35,56,24,131,59,176,2,81,147,30,174,243,195,74,4,60, 231,178,187,40,251,35,192,26,0,174,194,0,81,40,134,155,50,4,58,32,69,48, 184,131,3,186,162,72,172,128,73,180,196,86,68,59,154,89,48,53,84,53,63, 106,50,90,76,169,30,8,163,63,137,11,83,18,151,163,113,197,95,140,58,69, 105,172,224,25,44,9,115,162,6,144,1,61,40,165,135,2,23,77,154,168,74,1, 198,104,148,58,254,178,158,255,242,168,201,74,129,108,100,178,40,3,44, 196,202,47,62,148,198,112,244,55,213,152,21,26,115,42,156,65,71,116,244, 0,233,249,70,112,20,199,119,236,54,8,185,53,165,104,179,233,98,56,2,80, 55,10,192,53,120,228,199,202,147,180,95,235,199,128,20,200,129,36,200, 142,107,190,230,27,191,130,84,200,124,57,200,133,116,200,135,132,200, 129,172,136,194,152,200,8,136,180,200,139,196,200,128,0,59 }; int main(void) { gdImagePtr im; if ((im = gdImageCreateFromGifPtr(8994, (char*) &gifdata[0])) != NULL) { gdImageDestroy(im); return 0; } else { return 1; } } libgd-gd-2.1.1/tests/gif/bug00005_2.gif000066400000000000000000002001561245535672000171620ustar00rootroot00000000000000GIF89aK+wױ⾱c BsȼԾǼ䒐j2ȴħ¹ȭOIsŦ*ƶï;k-fݺ޲ڛવ󘞳0սӲXixQվtڷ0Æʼõ˽ֵƳĝ˳$Qx,\ƹ4-42󶹾$m✆~%}ѹa9˰ȷϯش2ƹ|Ƹ25Є=1=HCןz]߬Έ54/ᒧ?6ջ! NETSCAPE2.1! , H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳhӪ]˶۷pʝKݻx˷߿ nÈN̸ǐ#KL˘3k̹ϠCMӨS^ͺװc˞M۸sͻ Nȓ+_μУKNسkνËOӫ_Ͼ˟OϿ2j("x00(xLc:Ԓ`}>@C& ;e X4,]*:N$)$ H ,2 Kh a1i<Hr14"07wưR# iަZsŀ֢3\do!kJ?H#fqnĬ<4re0m5 ]:޲'(O"#``ahؑii oSD1G|2^$f` fP )$+P>0"eHHe2瑀&$@ p~B5!U@ 0A W_3l TQ$ ``.P~`Q Ƞ(!4id){`!3?0 !t!6(؀@`&E1S(z0Q)dЉg, A >,lE%D @cV8R& 6q A0XCB,lPB0y|kPRC8`Nx?`H PAaJPY'iԹR#PB:␋fP >c0 -Be ,8W E+d0lE(;$ Hl?Xc'BE0HY(X5@3pO H H.ـFH]^0DiH 2JUjUA.ѱ1Kg@* ڊ? @Tb~xM7 I8A &Qa CA0HG@gZ0@qT L)p&mpZ6ax 2&bY6@8.DUzY(ߨ0aA N PЁa-ʔJ a&@8`p y\LHP #t鐀17B@9%yS 4]!&bAx)@DBm*; gۀ5=I*g ! r @Xf X# Bq$4 h3`f-ٶ5հ 7h1vP p 8f n3N@:`.R LC;P5O`N&G:% 3F8֙6Lr'`AbL_dzU$׾6[f{HCwfo mg@G9Q k d8$nr8k- kfHx -D@k)" 3ii Ѐj؉=P P f~2( Y"0-p TВ `qȖډIu- ) !zy@S i @oЃް~IJ uT V- p@0Zv|pT0p' Tؑ` |eXS{ 4w@i2܀0n\װ k Ay1 QUD T` 1Q T>Xei.iGxtAop Qw S~Ot*z` 逕EpP`o0s8 R`} I߰x`q։ Z gm{wP  UP YhPI. {r @ )Ug6* YqV4UjfK0R J @P Er0 a#.h؟#AV .py@@ LZp >I}H a @@@NwwJ(G,Pn~Nj0 Q m LX@D@ 5`}z XM  ˖G 0,4qZ@Qf>h)@L `@g{  W&@ˈ0 7 \xB .@<H mJf0`ooSC Mpf;uʤp,y  О|~xhƌp=i ̌O q@t֢ L:-Pg ZpHQ cA6J 7B B^|m0pJs+iPDpu  J0?dlcq-骵LP 0u6mP݀Po H 少Q Tpfu`̠P<`rПTͅg4 LypX]n>0 ql)0AgKЅ9vp~No Pi=O mM!U`lh}P+/<〒@qk ~zoGP ԪꃞpsQEl`Z:ȝ}KfV[{·=0P i`YW h-k)s* .ٓkȸ.@.p b dJ L"]UXr3 zmr7[L@Yk|m^x@ :g0y0*]0>_p-C?F FGv.6L MKLpm~VPX pY\A9CoE?'Pے`x }~{\M` - `%` ՛  7btπ\ymUkMJM߲Nhg`-} n-ʝ $< virKxRA &IIQLW_ 4cBE!EvIR8cٲ%AFΤYM9uOA~LR48C7g6d{B+9"Ba۴0b7BFHQ_y,+]IK_&\pE2FqBen4,-a7 hװ:@,DMԄdVc1UfXusa'N,T堲 ,Ki܁`$Mݻ$+Et'좢F8%7")R0){ocp@ 4"#xg98a(Xʅ5l;rX X 8[H}HO(b=".ܜ!-¹@$Trɜ $RA*0^Ă"VYG!$q`ʒpMD6(DD -8*NIFut8"n(gـ, yA) RDV 1z 1" Gab뭀:Zl`qX&2]Ԩ6঑ $Tp:Zm @br+$wC!qf# y4j`b ?m+G łcggTrƅ tA\` ˰*x5y]Tc;` 1xa $KBYRA  k5qiLaz* 7h-W@y W3|V)qFG۞q޸`) $l;GL r=H fθۆ !#y&6j"%x J馱<~xaA:(\FʯNsxWm p"fVC mr廁< #`P(QXJ7.6g48N<-xԧ: PC H5` @`i$ A@}ÜBY l $,4U3A- EMq4`d xǐr=B):NР%Hpk"1&h$<4\P(V PrT h><3 - pk(-ե̚DHx\fc@'$-P<`l~+{P9`zcn" \Naײӻ`nԃmTgИ SZF0ӗ`ǕB:q xaCNo؂ޕK)>7X3;jԦ@l[`H̟!ْ&@6gj#v=]NC+)qtFnrc=}2_ZäjpQ{cSyH"N-*@'HvG QN@%`|ы`/y/) 5,>[,q$b77^ GKpo4F+p<5;k tI\WZ ?* [ָi/l0()_\:7 ł@H?l?zwB?yY؁p:-83NH"? .p@KPK$WaXh70 @;z#`. "[ P&V.gP -7hB 4g؁ K.q N@I ):X-yl X & =h#39;Ba #(GÂ&ɣ(XDF @ {l*x3D(Eqp< Z{iC +h:ul( '`ҝ+˧ ( HR. !ig58qr* (. ,{g0 t-U &h9MRfHsМ $i(PDITNP0`9 >Vr+| HT$F1{X PCl ˄U$E2?B.0|-Խ#8"hJbP(Ι)X3U3(PVn4 4 "rHQɷwTW]h<[- 0`ʩ#x*VMOis(+epЉENTG#w@H ڀ֓eL+L9 *6Y(NҝUО518IL6 o0xըo85_6P0+, @X) F/l#=3`]hR("|mFR9\x91 x̛AY \F,(]]PV!6hɦ)S*30؝"B65peL!@٢$o \^g;eyFȝ `_l8P]2]?8T'*`k&MJ^m]]Z ~`w^ l|饊j@Tf<;E ]Xpۨn=d&=>a%^Z(#51w)1h=Rɡ"\“hq-;ĨXJ`ec,"i% d5؞(c\`-/Xk1-M XQ I>S5µ^|taeQ/;Va^0P#F; [,(Z6:t;]!T7"i>"vuWBbR"#PJ_]hY$E> Hj8aa8ţpȃA؀jh..Sx㷸 8`eW^s5Tk+8; f@1T1kÄ^L+_o-%sc6.:S*P pU"konnղ> hm*0`l*쌃ˍ;/;(#`j/L &!d<#~z=S@䞞C` vqfVx#*en#  ă["Wn'P Xݖ7)mf ҽRP+l!Ѐ nB Z6,>!6ws5l 9os:aЖ@= $/th;tD?g۽pG=t50%tntN{uWG} WTf7V?WW8ėZf`\]g`^cd0ČJo]0vj8hlmgxɼpd7X<`s?w6/pwlRzHc,Eplx/x?xOx_xox ! , H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳhӪ]˶۷pʝKݻx˷߿ LÈ>K̸ǐ#KL˘3k̹ϠCMӨS^ͺװc˞M۸sͻ Nȓ+_μУKNسkνËOӫ_Ͼ˟OϿ(=3(x:ࡃ+KL3RP8p(Ň޵ܰ;3&d&RlP򢆏>PI$A7*=sCK,dڈ 0N>PS<<#?<(P& 'fs&N-!s`D\OJ^d Ϣ6}#>QGKc,,ejL@*MBA03$#& (vDrJ Ϙ#3 mZd  <r3$L7L !QȢ$SP͔K`)tj@Mm^t!'IBkt B$u-KD XL kDq 4 В Y77@:%8@#7nj/pm/B\J 31` ݼmӏZIDV+ P2BHL1Vq$? ;ÌU TNr`е@sS@  FPy$J&_Bd9F TBް@R.8X# -#riW @ '0XHFFQQˠTԨJĴ8<[D$эRh!f0m@vh &^xFe=!*Hc2P3b#A5 vUWР'ZNrTURrqC9]̕s4Ak jUS`wZ !X0 4[ˈI4zH@> 6EX>"` >TM. \,OQJX=V 1039N 7Åhi uN`m`BiFwSaP%0m;=X'(߅> 9dzbrƾAFc\pִp7@nР)N' 5%@ {G%Psw&pp0|0qW/7Iw 5yp97%}p?62PF2?@ok0Syn#ZSjBU p62 [ /pv`v  zpEբ>5 q  ,2 ="h# Z *opjk_ΰC?Q~u7PTWX@0-Yg{C=@ `& |"303=^1-u9@u(RTPkmD,QF6C9@\oLy? vN0 ? Y v { H Y &P Iq*pQ@ݤ(nJ oDcxVnUCDwW GB19JP-N+ 3f`_0* Y(h0w"P% t("P^`jX=jp)D)@߰V9e4'@NJhty4<DP)@Dp T0 #P*h@ 0wl Pe8s(I(qRmd=cyx(ntKp !߰uB8p<%eN4 'H\tT}> \`@ hvl1ղ& @@($00KdL)ZӛްOsmnqsV&Rney.4`W 0 `G)0"`_pk2 hpdp6(p@2vxTpR Q@@߀D(B@zj4d'Rk~Eޔh)Z d  ,phoARZ ( 8y7W)@y=&O(}ť/1DP EB0@Ry9ɣR G7.ped @( I* p" ]0 :38xcU,*HpgNHМVV7tgdWV ?.Z[1c*s@NJf.`LyN0v`i ceGM L^+{giPuHuHBL@"hf"i!tRKsڴRcRpV'LN?C P9Y;vGvG`g[ScP-Ёs.]*OJTt7Z9^6V`/ ؛Gg5G p㨰c@C@x I`{*Pp0{֐P|O( ֆup4E 3z{xݠc%3K N8eFx3Czd#R~L T^^p8w`k * Pl8,@VnʤB@hɫzxԩ {j#RZN.G &s3o kyz }yF;R s*15 P,p7f3gzrVRA` z4tx sjL!|9Qؤ.CsRpz-oyЭx4Јjtΐ  .js0j `0?{3P MuC01th8~ 3zlDkn؁9R,e58J.~kx?p)XB'PVpv@@lʯְ@A } BR u9PwTd/ QcoIhVÜч ea n[/yَo Gw`j?vJ` ϐUp^@l \ -u2Hƻ,CXp}wkLз2$!Q,nGd@8CXq[TnXDnLp*) vHJcČ4[zxݐn ϰ6һӧ@j_M5;[baiv 0% P` iDZ`Jcu8J*nk=vR.7fsJlSܹsj`Jy04`2 FD6npOWFUmp} 'ТQLc `@L3A8cvm/Lolg vqIst@1Tiny ߀4P| P]úPt6@@G⺽,pXl~*ZV&'ԋ6gUQV"#@qP PϰqUPh3pN} fukpGڥ$(@xn5PוIZg4 I<͍hקNs,u40C $3dmC E`@00f.R&4vu5"U6nȨ_WE5{y8?pˁ1o@p*/~VJ[Z4@CTRy~}=ۦ!p\SvhIZ~hG'm4LP :Gdg.F  ].p #[4~YTлi-RH ?RUV,kBSvD10Pi=Z@P!VU_;T"nFn&tI'n pv¥(D(@?:4G VLh#@]H-hfh hp.j٢A醊@p(G`(C=x B(Rg8uW^{o!nh$6p" s &(s y @PPE\ |Bn01!,`x Ҹ8ܜdɨA!N./op *SM7H= gwj-1 hb۳Wc yƊ$+@W=kimk I\a꩟, * % (x f*7 |UڨH4րggF$ Z1˝¡eS9l{fC}C`ALF+\-nr1*@d2D[$%!UU 48<+ Tyg`P %ot* z& 8Ƀm`X!*Z0p]e$ 0 B3pnt@qc`a"'D6VA9`BQ8Gʴ;m#0iBH1t@ 4!"&t HA74pm@P@   e5o*ߨCܬ⏲s8P\`EQH ndMYBRs`(h9K``A !&oa (`Ӗ$# * (0]ꀁA 0j=hq8\Bd*XB˻G !(#4'H@p&wZgGXfH-ᐈ3iNkC*g B4 Ѓ Հ? ` 0eD|f-H8hIO\@݃v)QHܰYnݤiM4B rJ|h@K 3@ D\L =.<XgyЂ* 0lƩj rq3%5XM|ÚK h,&P&(뮪DHRba'fD9 poT*3r@֪8 aB}3"u3x#2lqijgHpcTeID& ]b٧j (QNYiU^$E#CT!9t", @A ('ݕ)0!d@񆗸V]h_X.@l"g D) <ވBX;bJ"yZh7NA*A7*|-HMxUTS39&$g*0JAr{%p"  4W lLPUƣ!ܼ'"n36p g܁=ZN j3:D4/k s")?A Tyh$+xWy7R >=u*Tb&9=܄}ŌoH@@"PkULQS ALm^/ @co<8[a>} 03P @n?ۍR}(3"pƣX= G Auz  'Vao:!>$`i). Zu>%AS&b@E\1`! {O1 Q&%$utכ&`H` |Ɛ?C`pQ< HYl0mǾϐ3BJqtc 3H:4n~>B*{AwYD |D5{ﵗHTC XA+Db O "`ƚSx[!XT=mCH+[ %H?S9 Kz/;0 ϪK<ʀPJ"H f(CoCx6؀ Bx * Hqr'. cu$I8g8;P;BX> )C p595ZQ.ȁe=87KY*`pb(hrŀCQ8!* X P5{5 ꛙ ,GdXϲx0%)8DTIړ ii9DYB ^7P]LF|3&Pac\  03'a (GHg(50R`HG + &3  1Rm1Y#0ȃn#HXP$KFTzW*Hz1Đ<MmIm iSM'9FuCӂsXͳP!h3ΐIQaH[ !( ў2D\UDSR*ȃC3ܥZfh(X:1@G`t-'`0PP(.,ޙA53.L:[(M+Ї,m HS( Yl_o2m.^ ,AǪ4pT2gpt \gʐ8i. MH(R"-ġa;=f 3pN2v".HU8õFC"(%(#bm@fڅNpS74UoեD[hK߆oVc]PpFbdW@('@& Ʋ-[gV+5eaHnqm0>N;IP~7xr!Icpæbx&p;u&+q&-r1Vg4kƠbѦ_胰sm<^_ц]HʡրRE*(p .c027i7xn!NC=pH쉞`b PuVoU&-*Cg辠Su` vƞ_fG*sy_ 8j_˖-hlO?P(nzxiE~Jw9􇆎oW.ZohȝeKŽgXv˅VA JCx($~wWtog[OV&˸c .daBSz abX!2M(d;>&:zV(80l"I=߻Oo8xw~FANP4 :^gȁȊ{c8H?(Ũoo{_o8thȉ.>P>] y/Pq N?9O)6CyI9ȷ}|(j1NdG?/m`vG?t~ e&Wh7؀':Lgab}KF8o  2l!Ĉ'Rhg89Ɛ"G,i$ʔ*Ia,@ 8&Μ⬛:-j(RP9LIRC7g).<+ذHAh*1IJ5zHK7,Lzk.ޅb HI0+<.IJ#,n-8U@G L7Gtä[fG.P( Na6Eܺ)"^~m3g\3o^EgEȱ0#y^=&. yr;H'~b]()~ Ч@4ۀSݓm;48ax1@haSA#4!}Sh]GH8cs"fXl2Av_ f y7ǒQf_`.h"eJ-AW\Y2 Q IR/50&lPr,VEԠ k,`sGZTy brp)DB*Fei!G`:+G++uxt|*,͊t J,JdJ5&( Lڪ" Ey&@{(Ԁq@{0];P0&0Ŵ LX `I!j JP"`¨"l)J/\g:uF;2%XڰQygeg"',,5-Rԙ"[w}9SWR/h>*Ep07dmv߅_ %fEnψ!Dzk-M m>zlGrX*MG6:a݉  &%;9|^h2?}[}|kV2qEۋ)? e)RǙ 0fD*H9{-1NȟG.M 8p$ψC/x CZ{R*rC<:%2N|"()RV"-r^"(1f<#Ө5n|#(9ұv#=~# )A<$"! , H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳhӪ]˶۷pʝKguew߿ LÈ+^̸ǐ#KL˘3k̹ϠCMӨS^ͺװc˞M۸sͻ Nȓ+_μУKNسkνËOӫ_Ͼ ~!(_f] >B/` f (FCaUd(]$·A`,Hd7U|!G#8# B ژ0xhA3D,԰e N ]B0@Dr5A`1  4@3$;DU$D)8HpE8)01HANG@d$=#~҂}@ 9l bAEtM `˄QE#fI_t@] D4&X DB8^ ~,aC "xDIHܵ3)tD \P-G||p=cD .!$,]H0D80"-:ރE X0 WYtLt͕TSJk@ bT]XH 1)B;gD8)4$tEAvC`0[8'9=W0 q{耇{ A7|CG0 Bw7BoPyopP2AҒnH0727g # 8Pߗ!~ c:T0îH),3i V .`.,U :@@@0@.q %, 'U`OG5cϋX#nET`RƍFLlu`mJXX se Z`©(H8xl[؂!F@ԪaĊoW(* ̀( 2TB3xȴalZ@oZfĺmZBWS" H9t ~jj`(@ Џ. @/,\庑 ,@ E@@j Қa%4qQ#  >J  IHRX}.tT8жP4"T_ fܥ{`pV`M_D-k7y ‹dh5*`$n=A@G5 8vA*#B)zrr:#-uQB q ga98IP3DV[)6"Iఈ `#^M`6@Ÿ u-(DAРWX4 ZK%'HB2YG4,P2#P tOL(BIڄU csmgpu7޻XRJsFrl{ W$^ ܃& H]֔o pWIi~:qXj4sy1͉d>+   R8qpEN!caQ͡FfAQ{aB3BނԈ>W,oν:'敂W $|S:sa5A:8O |:&ڗņFqrP ֙ skZ:Kg[b`1a.5xrA"+7F6yDm-ac"O}@ \P/Yчy ݀lK paJaH,s"H#,uycͲ)@,V 0u}$P}3PG3Q"5p c~ ZF:0p DppA +BkzlBTR=Zk@Vt%p/TzXx U\*B:U 0-Y7 ~.GLUX~@_q7pv74 RV1YFT/4kmZ nZ &  R}P6}i1Q6z-XߦʷGt3wSaUAQ,ݰ& Zv35{Cv^_ P$epBe k4 e( nS0m &QH'a`< nqyP_#4wZUU&bsVp 0G|eK?* HPZoYLQtȉF]4p!% T6t\Uo Y4%gqlP# Om$ `2pl03ie050 0R0PO=li(Q"qU0sG80Z@vև.ɔ+Dp'jpwa$ w E++_|sR/ # ]0 >eM > `c P3P :C&7I5pV PKGF7̠w)v'K;/Soji&1Es@R.L04 ? `@  `0# _" l`  S=@#!:DPzr/J4@ ]~E3MzekT4Dp6iCB"-XTa@AŔrexJYH!) ~b9 k EȺExR*5Ы0`p Pś%W`0+ +r%Lw;t)@~@.PS Q@ SxcW \`{0Dj']1X?X0Gp.Lua4RWdT2 [ '`v P,ؐf c l ߷O$ T85@KPx""vJX? יđb`bBQKxQZUX`A9UT0zR p=dT- @ngπ @ _`30T $*h{r Upbߦ8Q@Ɲܾ F V^'+B^3WQ:Ps2Qb] Z s =0PfͰ0=@ =E![ 쀆{u d6m1ȳX8ZZ ,˸(Qpgw0{9 _Ϡԅ\1 ;`6g kP"/N%Е0 F{P-=0x{r 5jF;㨃?pyuPy`4G8T@)[.UK* `  #0S``ϰUp?)Le$>,@sv!WL@};{e G" dG[ZN n^Z> 0dL󽰕Pl @"t tS  ;`!K._|A\%?.b(D޳b bPAG5vT1 =@+  8@ I Č=L"ŋh%` g)Ud'NPT[ 4̛dR*ox3JpI)=,)jYiծe[q IF:@ɭoTпNR =s7s1>A*4h;6l @p&k$TqbQ S35 QBj֞4K1B!I+m\3ܔ˲haŠtH.S,Saf`KgkF.㺔`Bc h-Ha"L{q"atQA0!^ǚ0y@*i~gN( loBg8dHpAÞC8zL5[ @K6Ϥ"3S"žFGD@tg@y80lFo A1g2c@9 (lBqV 懈ͣ%(@ - jIbt HA,)  x  "@H@B rʁ:y87B^|"Q(`\Aq‚zK7$N:j @$qbTX]ck(8"`hnb{r!&i놑08oC?k) @$:HyF(\ l$ VJ! ,(E:_=䃬ib$14M NV0QA )g TH:xq&B)Њ+[n(6i@9$%lU`w=hn9!pC E$" a80ȯg(9QA)38\pC8o \@x$37doTYNx@@Ē&؀aW aJ0 8 vCLT H4a8AK90d4lbul< \ (I̼7܃ÜLJ@ I {A((љp"2U̥ Q +~) 45?Ѐ) C@kق:&M`QDxЂ oK@\1 4"sm ɬ(~A97H̫QN&<-i0!SޠZ [ 1aT9!RPky﵃&8ԻYAFh9#1 (F\ 5&(#`@  Ϲ pF:ukB uyF9]F UXnjQ[3'DPi@YF̡0\#I3dprph!XYnχ|<l 9w H+ B@ޕ-0DPaYQldnR+vh8$5c88P&haJA6??- ^@C"/P [|`sFsÎ^x'!-rh Ǯξr =X 8.{E hLaun@ ρA{(SP|.)޻<0C'l ys&:@o  KolfYD ?C*@޺E؀ɪE>J!79ѓ$aFD7 ʡ>@ӣ?]K>^{1P  ]x=;t:Ѐ@6;!AB[*:9kp)<7X5:(`/s,X@@%@4 @N{*XCdR~ yĕKh 7rۄ+tn(.5S5s5Cj]|("J OŲѷJ*{  mQƕ3Km `A,S5= << ),+%P@(7F q/(#C%~5291  x%Nl[u$3 XGy)Plh0AU {0!Jy(wਔ:> ( d\Qq؆'5"脏CӂC^|Gh8P10!IP M䕔(K:<7@PSp Y̵E`M(<xl0ɬlSH6>rp[9g}Z N@C885T<l3+Ѐ`hD'@E%_S9-ė@H͕1!.l70ȪL*ġH&LCZP{.pDÄ"ЀbY@<9$oX!뼇L,(PZӂ( @(x0Pz}τ?+p&PE?Є8-R:(ʴ| YֱTD`z@8?*Ӱ_@sD]T`KXNPUI$ʌ8ФpX%(SyDQP@Hń;\C(yO9+::Ђwb:д΋T|y؂nDfSyܼ:IE?N-bUAyXZBҔH?F `x 4edo2`[7/]J8,]D'GسPp_ м{Xp(A(h ͍ ZXVC@٥u_XAO'h=Օ 7 ڐQ/8gm^I`7s V] "`&^<T0 M!X^ GNc!Y`f17'5=j_1#+??@yDD D(}`[@%SXI"p܀5h|M@+L,H,|"~a}H55\TX9c8]D=} E-rՍc$ x 6XuVIǭ 0gh8Uc>N ZСpw8ݠI[C`4I%h5T3GF] OV8'J$(Y"Rf+؀mE 7Shd-]^N{p g.P5I`εWuL%qe4fZ0d`(Uv%@YET@1{^ E~ ddMh~hՁ&RA&X$9Tx 4 K^ jTJJ鞼68]d68t}!Eir @{ hoViH .^0P`3F: =qLkH-j+ЇMe\sp UI,,$^~)Ul Jb@0C'` x|f*#l),6bGDrX} Xf` 틨 8R7a5'f .xD`؇NCF-o[n*Vȥj'苘GXaΈ"Cݿ[#m\%x_ ~v2mA11 EX ӽ W256`H8g-UT˲1OhK{Pc po~I f-ސPN]K lqy(f.FT+LoԮqB 5(^r%r r,/O4Æ S䮃M>>X570&mR>bTvo8 7gF85o@U+s-".rq+t,IRktp3> S_1.WY(pRp`F"'c/ F&'{(c/N;4gtZރ8owQӄyP w_p}+X~fO+RB]PH (tuUA8``qÌХxz ,u))@vSq~p;u݋wCPƊt'%UYG| σ(X)(M1Pw8FzR805oR\.(`()0Ѵ0098 7 K(0s؀0 63f_@y;:5W8e&|PX)aI%@05+d 0D➄P[E"8f5!={Gwe WM.Li(BPķ 2l!Ĉ'Rh"ƅ*0,#Ȑ"G,idF(h"lyր˜ )'> `',l7U4j*֬Z+H3Q̙B, 9"ࠠB 80ּzKpd0BlKwUXEE +SWLТ>x4Ԫ)b !'<@,AOT&L`Zm8ʭ~vRPj+[tDK[JCǓ/o4_Fw2L_]0N uk9` YC BeuF"7!Z8QD 1eQp)"y|hc\"=(?'h1h("Ww*'֏QJ9U}xSb ـ6HeyE }dP[""@E`&h'sQ E !*:!RŢZZ)d@ `ɥzfW* v1&9*bK肘Yy1ڟ?jA 4D,A:le1Z{q}Rd6b;.Uݮ)EpP.j IpIϜВ& 0u~,L0C Ūv(|%"̑-1c< ؠd=@1IN,eIVčJ[)$KAR^=6zء.1$ " d=jiB|o97ߡF`-6k7 +%>y@x)0eŞn <3̒e0. ܺ bKK[3D*?@^8ȔD%' @BLp8"߰z`bX~E|D|!*(r!XWK F,C؅ D0+fok,"4Qa@uG(2-'{A0> UH!sE `I%$b2ID`Q&2E> m,  Gl0*e&Q3؀2WLY o1IVERQ.A/UmcK,PX"q Y%>'iD` P~2T˅ O5R4_ ZDp9hs–J(E%bdL}S@5IfY5wQj7T 2.!ԩvJfCBqq1X3uqҲܐVYЀc\$5:CY+ӯ{FI>o`j9k>]H .a|VJLHfR `!vz <` md2}.t+Rֽ.vr.x+񒷼=/zӫ}/|+ҷ/~/lހ! ,K H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH* (KJJuf*$!Yկ` ٳoq1M۷pa>cϬoh߿!TKZ+^p…C̸e-Ck١ˠCmafhVFكpڬ B>#-hN< uk?P?BTkтGk8ʟ_ڨ1G@m=2 (=7v =H3U<83]$hBP$QE~F dwhiE7Th R"70~ Y|MwSJo^l ݀-zrY C QV;wp#_} K50rf`M"lQC_V ڀgaD3g<,pF)'@|ֵnP}9΅0A&`$ 0A2hD0BX؀C` sF H@   h((5H1(X(0"~v9-`~ppAEp&#֠FЂ+D.Aby? 70#$X M1Q6) uE*IG XɃ Q#6p]Fk SE4myE #@ 0 &~F@7+>D6҂AZ\X1Yc P,yX `h8ChX(o &`4VԢĂOc`waƻPt'PI%E87 ^,T4Y>c@TRSo#&@Qf_pA@~EWY9s٥ ݠxȹ  Vb npb Q *kZT`ٖBW6hB7`lୁ@`-lzxYSIT04HMI;+` AįT0P Zs f3BX[#+3܃8.{[ " uR"m8̲@6&V{`lIhoW{#D JkOd_ f Rڲf%B^P` iXR)hPef݁%) m.вr u@op\o0"c"6!T;QCc[Aí7fBeB@3R`!8ՋAqx*\i2X8@,V 4^vO=a QC(\a!DM]Qq1,h^Qmgr⽺ЀWBA$(@jW$7 8Py{['5Рg89&uyuk4#`z}ЬZp?ΈRPa4XCM(rh\0ޣx@EF x]5^Z  h3ր/v#smbRDA CKܝ8L =)&A֝0ba (,2'm--'F3(1 ha0HA7b9K_kD 1D@e! {w'Qu]gJ'} +WB5q * U`Ey LpwZw4J(<GmfSʥn``kQS10.@-H#?4qpU@Mpw (XP+蹠 K݀#߷yiv )asXV:ٜ5JGq@V >2Pv{1(ĥtQXq Yl˕ B@3OxDK\*֗z baZ9 T ~1Lc Zp>+bq@YfTeFfPp^/{ dʫŠP6WŤ ՘YPi+d$'ڭAzWFC1TO4%Kߠj%)@;y溣pa Rh ~T}0p- 5+?k)x 0# @;p 0 #0 P YQّEivL1+@gP\xX@0kj P#0 F GRc X Zp6  ]"D$ $  28ap]Z('W#w%8aA2.@/0K8Ϋ [=[ 9K@GTTU &KrCɄ£oRgdfm }a c{eP  ohQ;p X-wtRƮukdPF> c ˛{ @ =`,!F.I0̪" [i2)]CUL$[zsq95@:4X)qXvZS  #v,| e${TqJwoP |Q.rR"v :˗ І1Qy`F,w@mu.jeH:@ -S=7XfLP?-:wh|rz  ;/ XS>$ м =% @@y] (pJGp5q} wƷ1)˟04!BfrP9 ٙ =0L ]@䭀)No}7m @MҋF<` xu8fXS &ԃ0Cސj P  ߆ !d#u&Nj  oB# e  R[ ``([p;~\D - NNP*=nR0 e[p `|_Xfn;痐  pГ^ p *a*1Q}x`ՇNor?p r| ?0R際 es p@&G8-:uZ|tT!ֱ.A`d88N> }w> hkKI` >`054/tQL,Kq2S# KN3ՠ ~ ? R ِPkYj@Q} DVGSH@/N 0$K2@Ae; #[0.UIeKw{7#,#XKH(oO57qV  #@ @ 2p p˶eP c ԋ0XZMX< _XP\. 33   G _P n;~ Y0_= AjoqbwG9 Ҡ  f  IFoʮ1@L.3J0&==G %̤I"qK1eΌ #&TH} OA%ZQI.eڴh dค]_ k4,@@iو +"K K A@&=D_2mbF*otcȑ%O>4@kT񪀀1dˮfl oy0[`g& hxCѥO^:g\ Ǽ:Ҩ +4eǰ8%6W)R="# 3耓Fs & (RD Ĩ :CC̟$T1NkJ0Jb8ࢸz0ÜH?+"8)H4`)@C- K!o ED24L3 )\ #Cf1OTi(BvQM>0*䐡ᡤԀ! l28,2ISM9% o8Ѣ64SUuUVzs Z!B(Bzh0/!/6 .%8Z[pERh  CT("`FVtQ\jAN(ZkIu h#q+`F4&^j@H,6.A4QC ^x I)ῸAEcvz7 %q;9!Һje|FLb_ zj!MRc(`ۅR;F8(2(hiw(r9x T4 ;dՈ⎞¿(g R0F,sv 7Xc -(o |x ƙF0-DJV YfU2D e12 }`Kmrヘo6S,xPd N0#Jp<"8 0@ 8`% '(phc4P$ #@"W{UPtP=чc ad \@0@ )P7C0qUR8R O^@`(dG: 3 (Y_8 _c#Io\A ,`4Xd z 7sAD8T {d/}!' #0X@!;W"X3P(`R)ES+6 dg;2< \r,3"kDF6&R.&( *DT7SP *htxt(p& "h ?h .d)\:S:P6Xa \Tk4 (M l 0 jWjN,8j9(Z P;\M@,{P:qt (Y`HYLSS( )-Tp&G xE WԢV.D6yJ`@8SAd8*a` 4$9:02ӝ.&v ז b0'n}0GX6"MoS{N;` kVfz_y[ϙ ViqAExpg8mǮ\? pll@qf1j! *fl?ӨT]$ i[|!N34߸k(6% v"4"Y?e$Zbp]j`LĶ {sRsZoHukhh7R ϛ7*6 zm$ "C(X(F9}~C 7̀@ bx0PD?']#u%hׅuIp70B!ؠ Pk] V7 B<[#0^Z'al+ @W0I '9-Q l d+hA 8P킫% 5q 'p#q+JƇQ('BWDϭ>CTz"^6`&7ڠ% 3 WQ >Hfg@آ #\ }~G 2`u<ƾ TL4b؂Fx?!@ +Xo\0ahhN9` 4):!; g~Ӻ=eu FtLTG~'xЂ V6@Kw_2&5ȸ8脏x;?\S?R`mԸ@h@4*Є.X:4}>C(AOs,a@f 4x|H01x@BЃ$*X `_8@8={g>Ȁ1B8*8>Zp.8DpAj_xl:L@CH„*7.1`ALK'1XH\ƀ>x$`[5xL0"}.*x9Xg7dEe\ L8 ' ?87 *@F02'6?IXFt<.0pBQs2d=G(4HG S!(++XH`:Sx(ȟ KH&ڀAҀP|ɏsn[bD< J2pw0A${o1$+Є3AL:.ʗl=rAp KL$smsADLT(?Sˌ4tX`[l?DpA>1g`L&ۮ6d;#Sh1L+J D-()td;7K;"H\FO4E%"(m _'ǎ1rD(e hLnSNL&Db'pKgA\EXl2;ɤ$dώ0H5Bٹ{O#tD}OC<#6`D,8D5 |%6N 8;+0> gjȔ݌Py1K_ CX7L%*y C@IDLAΑ ELY L=PPS<8{]!`nX[35­>5^i:PCgX(/35 CBϑTAhF%40QH8Ҏ3s( XPMȘ[SܐtRNa%A=hv*J|THE(8 P/@(d5dV`Tf .x<`5DW/AE nUSFHJ"A->UKEDQ8`+й(+Μ33؅hN#hC)9YYm>L({=X( 2L?d WUMZCG3` 0Y1( X1`%[ˑSvs h#@><R=S [( ~dc ^=J1hՐW7^ypys)݅ 7\:0 ڼ'eӰ `QqZH~)@;/S ^Nݮ=<4ah{87S8؅*K0  X8Q ~&Q$s\R7(4Ңx5yۅ, T %Vch 80bx4W=:Mx߼ 𧕁KEo䩂 ~YI"ͣ0oY. g__T@U,La8e8~hEPL*Zdd=z ff f+XffN1o*G^4E(=bP۠k^a(*gZ{1h^=K3v,EZi`1(8w`4H]hh^2 3c'ϵjw2H[8k]w `s_vwGwo+ds zm G~o*.P8b,J5 w^"{N9wg\oy:Fywe~wyvJfywZ<z_ZtMR6_DH4Be_gvDF/8F. KH{{{{{{{{||/|?|O|_|o||ȏ|ɟ|ʯ|˿||ͯ! ,K H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳhӪ]˶۷pʝKݻx˷߿S}L #^̸ǐ#KL˘3k̹ϠCMӨS^ͺuC®cT,۸sͻ Nȓ+_μУKNسkνËOӫ_Ͼ˟O}PAeB @? ЂF$3a ?AA2""aϸ!."<⌂=s-#I#=CJ?U!}jHbePq]z 7͘AL D p -܂w Ig_ l7XHR 'Z ræ7)o' Itm(w.Kj @FP'55d4'h7=s%jd ̤=T-D(N-$) RD9:0< x"'_4S[@ĤR&a 1 SԜBԢ}9[p hyp^¥~ruHZ7>t0,})]X$%L'K!l|$xWc4\ $&. ?C @x$"EIf5*Ra92Ry3q PqKc Ѽ=;ZmcȰW--/$Tk *iH Lj`X[3w XC!EDTFb<)x0f({  t!@j_.5FL p@b7@,.lp!xx~i8^ r#aǬf!- D{;עo[;H3@ @!8l21RXH5PDP̰1JC["reG9HCt(}cl!"yPgTaQ͟M{ =  yx8 Pm|@D'"L/PB !e[Qln E0~( `5 3vBda3RJ@ ⫹9Dy´3 Skt6N)?W2A`l# Y0i(@ ;= GL9 3rۗq "#bmS"UPoVPf@q 0FvPht ilP;-4KPїu #01YZŌ ("81PtfptpE@ U`X8P3 YV^<+D®l p*`v ]A@82}+"ppW8mb{U qn a wˍd* B@IV!P$+l +m` '>KxceE`G9K]04ūNj +l g gk0鎕$#6\ЁB0wߋ j㋵P}P6IPZtDk}e)¦;js!P \$ `m+(((pr uJ0@ :&4L` k=8{mplO<P @@xӲH+!w& Z3 ;jj } 0 l*r+ mJkl% B ߐ1Lj?< r!0 -[8#ZI*+z4@,|倱019,0A'%0 c T#`"/' /D N`́IHHmtڂ0q9L@(HjB%T]ìjF E2}%$X8qńN@€0@L!K TO -` * CP 4p!}B Lz&O6 &A2$$%M$Ld@< 59(] =-(B]`JpϠ v F p9x<`HJә#P&'+ 9IPsIq@1ԁ c=VS`đ(p -k`&fN&K)] VF"6(Lʲ L.oLW f&-59;ۗ~ q P@4 rK s#@LcAx% B(l;S2p`p9|0na ݂l %g@ζ`+";P dpe0 ahQpئ ٌ(%xW % k"3x $Cd*yΈQ(P;~0àʢ&P<'֪&⪔zR$S$ n @n`O=ӻ `Ȍ-Po.xWkw0 4]Is7 ǁT|@p͡<ʦ`Xlh | -I[`&"gaqF 1 a PխrUR22}L@K$Qa`PV}OPG`0c(F PoKﭽ`N"1 K`@DP.LML`d NC @DN_4x/P[X%!Ȳb ϼp q m@@ ~P !Hl qgЂnO k\ ]a82\ .An;`#6R/̸| $XA .dC%NTTZKʕ悃!E)wA@9L< 1yրCVA^ K %ZQx/QAcLCOnzP!U0!$H 8³qΥ[.. @YH$΁P <a`gLTZj[\>whO7s;dݷ8C0R{Cy_ "E臠.#G:ge㢖\{%CLhLbޑvgJ 0Qv.$;Pv1:2n8(t{CXwƧ~ &z#I"# ',k1 v 57 ּ]w*nuZ9 *uCڜƨלmʹ@b%`C#by`` $g %'tw _%*Hq_I`%:pj`mA σfxHBe ` x@:X` шnt t-`PRL8X@<<@Z`Nۂ!AŰC N+l Jx/\7uJ҂HaEQ P!K@&x@& G@B$ a 468VU/B<o  7y@Ocl ~NEV(+u 10o0#ҢC,z=#U0}r8 tF&l Q@h^ЂZ4Tt.C;&{`a\Gf.Z@6B_d-L&'8 X=y0K2΀AQ(`؍PYg&Nj*4L fE# "IZ A A b '` 1o$ =Sn4b77$]Y,T#@tC"}" ЩLJ Xa K&@pԁD) +jBA̠ CT }elB@r>{B,C1D4?q0&"AF#&P D *aB-B/]3asH!C^V`*g|Q cE7h H ZC(P]7~9 "Ap9e2V Z9[498Q'I.1@Pq*,pjܓMlq:"ԀE0% `}Yqq$/iXE +f &$v=G"AgIK AJ pB(v &ev3jݶ;PzaCB Ox`Z ϲGօ4 F*pY:$0ဃB%JPeg["q8P:ux1Oh':k.[Pкn'|WB @  g9%Ѻ͢e @*\#7Q[S``e?b vq`0}XWZ6ha&I3;Ep[:E  EP8 PYp 1{B&(H6̺P Р~^#V'z޵wg޳]N/9Ƀ@*p]ts\5! a|m0 ";514@n {Pݴm X;G>6' H\?w?S6鼴^>(d c *v 'a}K?h?i!8;CzUS?t;;t @]34H߻?  |Ae ?TAC80 0X,LBI K;NK8 TB03q<!BA_ C9I1!c0PK9 A;HCCıg>l3(/࿃@Z􎖲9PEg&A@Q"@+V<'|FoojlDSlFxPāt46ԭwG~3~DLM|K 4NLŚddlN4*fH[Dw„ O) x켇c ODaL*dI`Ot[D.ONt{C4fP΋tP1 8do`?D@m>H \,Qd0HQHeQ=QDSH)D1N0t]!EM=HJI^\Ĺ<F)LR,EЅ#1P/L<+3=L'-u|, (xS24Q?uJ<3`,=Ԭ|2_8;](TGE݅F+Aԏ`N`^`n`~`` ` ` ` ` ```aa.a>aFۀ!,K H*\ȰÇ#JHŋ3jȱǏ CIɓ(S\ɲ˗0cʜI͛8sɳϟ@ JѣH*]ʴӧPJJիXjʵׯ`ÊKٳhӪ]˶۷pf|Lݻ5˷߿ LÈ+^̸ǐ#KL˘3k̹ϠCMӨS^ͺװc˞M۸sͻ Nȓ+_μУKNسkνËOӫ_Ͼ˟OϿ(O=#+7 x E`H8 RHQeѡ8t8^w^^;PԨ) Tp |X+`658E ,Bkk}ݕgv{Yz džy0Ȋ@9c 숕y[ ׄvW'd u @T<[n@gq0ndz%}fHfj LИF x 'Y@u"pSHPu%ZE gpHvGffmVp`*xy Y459 @CpetpShEp&y<VP k)Pyٝ'dXXמW ,ڢG b"ti0TUEoz+0 t {;A}X$ GR}Ét! `p.J pU" gD pn0aA؅d`}Zb)(!}whjmЭ!%@Scp gjH@H < lvipްUP@oע+G؎O ! mߤAjА[s@LP Pp)~ 0  ]Z@؊BhiJ J0 hpUuY^Ho w+Q@n t&ӈ 0N۠nPܺu(pZHW*F[V798p5h#p pU- .YiU ` x!mgPXh^Kzݐ^ffj op N@DKz`_M( @zZtSpa{P 0Y0X@F^Hг. ګi X) +@5 K Se L̠*T`)Jf^0L0 APu\ PT - xJJPu5'ƅ 0k@T GՐ\P 7!1Ģj 0$SP p Lp@a.)9 9QpV M+(pYhpym ppm}p(K S,5@]Z\xy T0YAe5, \JPZUSjKʿj* ʃ*\Uy\r^v4) a Bs +ŰV j a a [,uiiQPZp8v |O  nК ѯ~Y HIV@DMOд(`U` `Qgp,!;Ωt J  P-@Э- 5pP(=<` |HPPr&() n` dA |0i`KXɥEh<L y PZP?' (OQXuOjAXIP:iʎܝoŀޏE߄{dPipL4U@跦 ʀJ 4HpO sKgђ`ݭM~P L;,:mΥ0ׅj ݐJ,M@ mLmw,O@ u pQhy7)M' C@n)B^=y0 Eu&b cJIjP&nͫ* p j; P 'KiyQP혋J^쒰S, FـrpQgDP IF@Ig Z0O+Ucn؅#P MZ d.Zp~2OzpSPaj>I Ncʼnώ-- `]`>]9=0M0ͱ rc! L x +PGQ!nV` #}KVpمyu`, ۭNǢG %U, "!ع/~ ̿Z(2K?+ L`ߠKK|H*W6~=yk]ƒ$O!ϰI)UMg1eΜCHqZF") u{,.eSQNZU(݀"s5HO0^|IB6sTV=fB$1 A9Ѣ)@[e̙5ooEYH:t,UKS*B*3*MdTǎ@y6[oO^u 0rڻW*e;$0 B&*:wf@ PQFy ; 4@ɁI4+""0ɒB"@kB 4tEcj" uT0#FLD*! CD&g IF,RFJ"-QdzXmB01fS`&vhq&,  ha- 5Pa"Je$6~9s'\;BK3!aPjF\s 7!Q\sՕ)]UЂth<Բ>+f`>Z I" XI6rgĀvu]] E~-Hi;Q'1*]Ι ^hڙ&pܡLw ܹ^Cv@J{gѢBيAM"TDDBa@p$˜=]`Xdm"W((@ҳ9S',\M7@P hZ >N2>tQo3~ar4G1Y@R%S8\0galoZ $c]ƅ5hcs׽_a7() %~[ @cm +D2Pw@Rp\*Ђ3f,Hb !C%&g*ϣΊ)Ny 6T@7z ؕ(i^s& =}bH}`ʳij /M97v"L GI=I.: /Av 0v5St)Zgpc}/#FpB swś $ }hcQͨT7<PO0A50Xlq ~nJ?7*EWpZBa9J2H@sԉ~ߴ BE6r8܊r Hasނk /to[<3>$tk ;,W{ş7 ihΠ@rd?eAJF0;|#5 :+ yJ'8BJA|.Y@G%./Mg-+~X`@L6kKSh @ XF:@bJh:#s4Nx)* 7b$B&IMk  (1b;Hb1:ɌBw HP7ĉ 8-C$# $/Qb?+:pF/ڍC$L8:(+ʨ,$n(Eo-̌(`ţHCˢp!lMHߢMDECAJLj&$L:F,|\N/A{5 5PĂ(pjF_ ONKZiMOC FD' ˟b "@8P 0KlPНĂ `M 1Ȁ:ODK;R1ؿvnU|]M؅ oXIMuSHy&} O\l\1;(.j<9e $4.%O*5ŕNk@EP6LSC+ö;4F;B5<;DTL0d!|8ȁ̯+a&b+hb-I_1_0A)&c 4v-Iܥ""J8c=>; @n4HFaD.]1E怨I>.d @1Ѕ=%&eW~eXeYeZe[e\e]e^e_e`fafb.fc>fdNfe^ffnfg~fhfifjfkflfmfnfofpgqgr.gs>gtNgu^gvngw~gt;libgd-gd-2.1.1/tests/gif/bug00005_2_exp.png000066400000000000000000000244231245535672000200560ustar00rootroot00000000000000PNG  IHDRKϘ*PLTE6Պ?ْ/45ˈ]zC1=H=Ä5Ƹɞ|2ưشϯȷ簮9˨aѹ%}~▢$m붹24-4Κ弴ƹ,\$Qx泷ȝٳֵ̇˽õʼ0ڷtռQXixӲս0ݺ-f;k綺*仡IsO鏲ȭ񕙨¹ħȴ2j䧫Ǽȼ Bsc⾱+wȳctRNS@f IDATx{\SWaNc)8y=$eZ>tvlcϩmǚ^e:; ZS#:b/R"6MA Ѧ@X @ L M !@h¥~>f粞VPBP( BP( BP( BP( eb' AP( BP( BP( BP( BP( BP( BP( BP( BP( BP( BP( Bswޑ?(Pz+w_Ǐ\K' h/\xy]túCCBCz%?Lڗ.׬:w,@~z)4k"_{TFq5Pn x˻OY 2ӏp?r0A:Y} L?_F0 iI63KN~؊u6'HtКNrt/?ɛM٧א`47ԋLȃ"4zHE)}m2x0 KϑVK™~̀axK9f5D;f9/Qu :R-gM+~/qS<Z ~]9ŗ={Wѝ&'4b+s3_=.|naC!U6zݯS>M<ޅ /EGyIGO|A~@+^juk.k?3ٿ[zuDu!]-e0 -L=[ms\mqͿl6~)d WCt/}eY;}j+j3?<7$-WRL?h/ww_RiZj;KC yrP~Ar-?p@Izt"=Jd@+]nXqdi'oKߩMVꩊc: Twi~} f˿zʓVs5fhف:$듥^ICc!ަ_zrCC4f"s~|eIfu '>XaXxl%{WI?5ainDo˗i/ Nh}t~W/:#ww-qGYHܷT׼ιYo^(-ӏ0v-bL=Ļ}-ݥR5|m}6m/oY=t?Ov4ӏH·lӑl`[HobC>B%LKƏ⟉ImO8p]-Ov33+doJfIW@4<^c٩DWb I(ɔ#,@m1v$ZHx]Ha:u32L?#3УcؖDko bٖ5PFd*i2aO,1>z RusOl>ZS ׁ~h?bz0  !Kٞj<\l_¬~l"`$Bbzz69Fk p[SK!Љ,~, A7K?`]("tX!&SY p'1`iE}}-1<܄1G,NKSC9.toZtETc-qyX3|o sT/aQŲ*ZȢ:0 N쐜ܨ}9[U؉"%ԑLqADsU(X֙.f|lG"P H"EkRQNƂ$ZqlBX$e"b<^Ӌ}IXiKj'#O&6Ruڈw2kD#Q"%_-z3!RPlq&q6$H~iŪQCiS^QV2\ -D`rMJUvkDkј33 AjOӺ{ӎHX1X T)Fr#BbMw¼"tgeϸ1+ey=sjkшU !Z)K7sj !%H\ XaDr&'OM| w"=g[Ϸkk}uق#ߌ)#5^+r6"wnQ_>`DȉҦ>JujJ&jkK%<{Q.1#S|(r1N\Eʂo/D"^Ėsw3k wAVҡA8v:ctm2b%2ԤbMnoq L$%ib!7Qќ؅XӪZiDVBOO,D"=UuxBjoFkv~ٻV#JMXa{!Q$Q-4$Uȡ*Iƹ߫薡Ul6 "UG>úyЧ*)'lѲL "aLw0M? FKڅ_ !IcRξ f굵or8k=Ph^,kEzVU)(rc$Vn:>jELЈuFN7i"z[/ 1ٍ S;+WaA`jtbwbyKk%HPn>U hu rʰ{7|UTZk=yPPaF)4iEqD2Wgw>Pc &e!:孋WCLf$ :bB3oEWW ٽg=m6q&S7h^|fsr4)%6@ IP 7ҟeYb2{bO<=ə|zuvؤWq,RD Ud<.$nR9 aDeJ=&+t͞="QkGoN%vF`AS-qAɪ$5;qHyB.#N0bWI'˸Su, & f(p WWHͮ019ϓ tX͇4`ppb5ȉ& U c70q'o^6rnϪa?³Dm Z!^UjXQB4RӨssZD|FU mK$陼-G@(VUČȨb5B"B|C'=$ hN ٝ5*.Ҋ!H"(A-?@]|Akɨ ; Mx0*2l׽d۞MI-٧Ax9-aUFY+%oq~hIHܠ#NcA"FC&aYJmI rplkK?0_})H GBEUx-UwXJ%&;TN  @EB YԆŪDY6v>#D@"R(<Ȋaq'pwNdgjtW3@+E6E-`J*6RAtutͩ袬 $Y9ЉS{3_$Fڥ4@&4 xD7|3<:tΙ{8|=lr ׃¡sU@ju0ʵrצ`F=ʊ1p=p:^Ǭ11METLac.,1ZUFzQ[Mmpײ z/:l^֭MCH#g!5k܀E{ϰ/r M9Fq/D߭i ڡw-ɢN cĂx_d ƦG7+6_^A[?{KyAh' z@7 !hزUtBߎH~;ST;Ǹ=;>ia;a$jɍb˪ CЄEw\גC+Ъ݋_^|JZPXwE}vp!]Xb*c9^oC\XZ/%p$Hz/F*telH`/ՉQs ګiܝIPܛ9C"?{^u5g+t]-QA^}F#La "U@$MDZ'!݃\jq\r$2O{csDxI0:h Ȁ r9tlG 7f"s6r]`Hc-7Jr C8?tVJN>_dGCKБUS+ {!\&pj$a,a&!*YvJzkIη rYkp=w[ d.kOsFXu%UYbdXr;1 Y7*mKAB,TnÓU2hZSH3kDjfm~sB?leZ8Ԅt0L|] X h3 ju̐rY9镚ıﮧtnJ0Ue$,eXYCHku]y/ -P:,\ QP.1bxϝd̲4q# B,LDXYbڎ4RSB $Zh qwK 1+%H푗}g*TRN V yQ1(JŊd RjU-E~Ov%H9\kjw4*%aM?xAvv!(7llwA.?h_$$`JyHYu$:6\2!.TS1Ō[n=k Ydib%2ND:8oʇ@/JEL鸲-eVeߪ,c.#joǁ}tqf{ٻl_>)ǃxXJdõ 0bFeqā˾lz/ F<"J/'Fej!sJO4r)_,AΩ髽rXɧ"rs#ر;YY0<8Dwt̓ne5(˖1IrkZ2.nDnH*p[D*5hU[F'y"iK*qI Iص~EݑΉ*ld6rV2 $2ɬҏ)B[Si7*|6yh#mm3޺NpH*%4l r<k)t9nmRC+U\IK8a"wEمxy~OV{=?p〞 Zm{ > ZFx:XZ/qppr/{uȓLU B&њ*Pr`BtG؜jf}Pr~7!*e>?eM_=NL3UjҾ(6A_Y!=+|mu]kn}X;1Oǭ|Vu]T~@u%0Φeo^^](ܲXDWl0:1ڡQS Es`;x^_6.nn 痝?Q LQKm6oN(; @ c0hvUS\ b9g66ʼnC"B1*/C%sރ^(+&M.s&:h[V96ɁC|˪|L~T?*CmRR4U0V n=V);u !cC! :FDL(;njL̎|0! &b֔*e퀏c{@JȨF hZdeწkѤZ.?єLmp"}E VREDttFS[8^  +mĘۋ&|g/;%պX=jT9 s^D\33+2eQ%v0dV*bFGǬ"ɅY:w`&S԰,CC1aT NdB:OUm,/Љ@+R"v63WSIDATưLCC`{[plUTD'Lû[K᷐m.,޷ԇdB&"wr}McyI"m"zh[ƭq3MO ^p b+n1KHܹZ:jY”p bdνހȺH[co%Yx7m(_ZvX&I-mlQd=:2ࠥm ꌔY'&Kjt6@өe;s2duUm#vvxA &rG %4a V|@.X|K!]ki6[E=TDO>VdWԯ/O0rH 8Y!}K}c,k?XH5tClcPP w!?O?]}>xfXΉ5"~A׆Yxڦ_9&ww`8A@t/&7k*'ۙi>N^[_͇ ׄB3f <.2^޲K}j%a<)"6ןWY>%'h!HY!lv"_u'/+0rKMyq<,$O_}p1?ٛU(.4\E}SxhOv>*hw9؄f*ϗk\ 3Хl<-jJ>\91d""yA BfR lKTs''O{N͉N:!2.6nRONXˇY"A̚$!# tY;(d"G\"ʻ 0Ya~5-."Fo$n,`!ȤzWQ{uUK'` ⨟hr">;z 0$]J} Mqat2p_kkn)~uرg#|}QI'ZjjC0c)@x>$NO/*h'lpk'慳vP ƙ~ }4BAk¸<f-yT9]2Rs^]{*l@7GI 2Nlc 젤8pD*8*Ȭp[ f x .dPE6Bd7 z,q9KJ-$X*l"I2?[0cX  G.RAfK"&J#vfqN)d6RAfX*,")2OM2KGP=5L ,LF^ur~NFj85B4+%ERNf*%K&"ALHe  >&"F!E\Zn>53W"!<43J3$$L&&F&&@MMU~+,Egh= "G+-L<=M CEcKMkSUmhiu"A3};KV6=C%=O*>N.BR,:EKbp6JVq~( #%%@CCvzvXVHtsmnmibR.ڕfyd<4,y{zy2'sfZʮXTQc]Z}mg&{vuutt! NETSCAPE2.0!d,}~pnojTIUzv{jTqr^F>M2KGP=5L ,LF^ur~NFj85B4+%ERNf*%K&"ALHe  >&"F!E\Zn>53W"!<43J3$$L&&F&&@MMU~+,Egh= "G+-L<=M CEcKMkSUmhiu"A3};KV6=C%=O*>N.BR,:EKbp6JVq~( #%%@CCvzvXVHtsmnmibR.ڕfyd<4,y{zy2'sfZʮXTQc]Z}mg&{vuuttq]sH6U~F7Jػ|[rEwЫ*4;W(ƺj Ȗ֨_x֚hyvVyxc-%Bak(XF(yv aϑ@HZkhڊ'M )Zk[0K\G%y,l [6%F2 >ǾUI?6N>MhغCJ JmڶiIeʑ%~!T"2ZU 禅^@-BAYVY0KTFXLs)rR+0l-BV%UrÜ Jmy@-QYŦm1%ΤOjvr3hm!1`0WDJj%To4Qə%)0 *Ƌ%LTt9sWKș#D(Qѧ_NGPHx#{ 1He{"˥Z\U+Mf#HPB B}1wV$.[zsJ'MN("Os$R'D!EA=#L!`0[S6wL`AxPN* Q+9DŽ"X=R\20Z-ٕ hLRK 8R,QEX:$< @p&$ x d\ݵ@HyD5C*sY: auc%l!F!Zr9BH  eP# Q !EG}Apk)lĞzZYn,A~*nY( ׌ƨ*1&r\gb*TS%~ZP}DÐhk;`BAkF.g- G!X` DD+8PA\0 ";_BeI-ൂZ8A6 Mgv͚JG:Rױ` `څ,Ȁ-3bZ5A 7ÈR e!0/Jl!@tuACj< P>[[%^:uph ꀄ:`!XY, x/T†{33@46jX`!B0A/h^G) d{c4<J0q+*"ȼZPNaA,7;PHs7x1y 1@XTUnEX"$Q-jJM C@I܀ HD& :d" `G*`VgP`CXѰl3_ώ=𙛔f'}K1 F&`GFbL*0ف. @^0d';IPTd0|a˟*R6WpfF&UE_()=pOԻ [KS-Y&KG)$[UB%+Up/*1t5%[¡P ]y^"ZM8uX1Yb}C&mJP W9n2чzjTax9́,8R  Lp p"TUf %o,l(kPW$> ;Pp@ :>=#^db "Vxq?e+ﶓNCHK؁ l"?a @AOK*G:K!ƎƊ'8HB])ƞD?TVp \b1Fᰔ4ӨH7߹"mW~9 E.cM[F/W b׮WƤm335 PssP( TH;cyQr Đ'`1dS(m({frK Me D :  s%x 0' 3cSyp' vYao78yd0L zB-I qz=Cy0;9>d=`Fk^0@cƒ9Wpw03 ..@ )03f\@@阽 "o9 з l臙 S9gl e+c0S5_G0G9CZ@%P6E9@‖:=lD 03 i3EG0P!d05B#o 919ڐӣP:+WK*_' =ß5 &`~S vF= C8 1 sIp#PΖ@p̝X3WA`\=,ࢤT3 0l x@@ X m 0x茎 ^qP鸪Epk Y8P0  oXS벎 Hc|i. +l?+\ I@ܐ   lѠ1/=0ݮv@O_n\ݾ@*֖-K Ќ g) : \ފ Nm^` h @_RK Z Mc5 a ΀ l0x > ? OVG c<^>N` -@`_R Pc@8ofmO?/)@T`r񒰻c^PHM VP{P, c0 UiDbb Њ/\mbT]0#U(a0 Yij j25_Oߗ?`V{q mysm᮪t1OseXtk~> Q̖ەT;,tؗjzNUHYPIaSsZ*-)6:$NJHP>2Tšd2Z2^Q"XfRrS[p ./4:yd_Z[QP>4HTpwws>ȨNB!s7Q@ ,~G ocC\pC' /%_"RLDvDBK7;13nC}~dkTA  Ê@|3*A2L EA &D;rC2մ!E=a 7ފSm#HOIC]y3RcorKXO$՚kD +zk#ˀ.ɂ" 7]{tL)[G-w -8E^ۂt@!0#őd ȉ#a"!"$C7 5B fN u&P~ 4 ex|%+փNE["W[(hALv9T0PaG#,?~ r&,Ra$\2љi\,Q3x惆EeVCѶI.CAh$,I%r9lA3)yws8uV`K(Oѭܭ m=Z8ڀ9}1? >)S\zA UV`d`h'57Za| 4_ҧ "blD4]h,PXnfAR"`@؉ ( R.@E4 m8B `m!J}CL np r6]aÞiF(DuB,q8aQrxceO@E`xa yM88(b f\6xE 6AD"r3_N!%(hu:D2I0ґ+4IJZh,@av{8 zs-Sqb!Ѕ I,?[:C.`n` @ b@Ϙ6JiJy387X͐t \KS ⴆ+ЇKAPEpP,s{ =eO|^"i;BJ#A9}TchX1qxD$Jno{DK\I2BQ ?Bf-,6?VS@/B5=V@or umD0 %^ vs;DRja kF/vS>ܓ/X5?M+ H#lpH Hhwu 3;X+X} 9x!4 $ [uجg7)k08D1-bq@# ~#pacMF=a%9,nWF^|n7._6P0bw/#L!؄z]jj~ԕ_Uz`ЈFCXtI!d,կιǩUXuًȫȣdr*/>ç-Qȫ6AXIRbg *лۭΚʱțyۤsȑ炎ϯ운ΐë›랼ػࢮ柫ֳܐӢȜz;HPҩߟ^hkٟڧԢW^^nqq쮰ɭvzy7D@޹痛خHJ>zilTοȣĘþסϰHp?! OEQ2Zl%*D CII JMD% '>ɳ'Ot+JԪRDV"A|JJU!eC-[֠A4'V V]˶ ʔQLUZ$ ,%+yռ5+&b!*. #2Ԗk<Bd+է')H]s!zѠ#TT Ÿ \9ViDK/sn ڵ+ z8zdb$ ,,DpJ >Vp:v Tn+M?b׿ gԒL7Ǝ6`2 Q\r, ^rtb+G $ZP3H86hc  hO+&LMp0BG刘XÄsM; g`lӎ)OL)h` }x$g d NCS1,M.#;: qTS©z~&X'|( B1nin&PB ,w\RB3*Ab¶ά`0 A|x!#IrW.fB8D`0 7`> l60 R # |ĻRRK-,.@8Ks7HPp hL/C ;|S, \J@^0 =QC&5/1VvD @ќ ? =0=G~"Jd[xm 5US! ,7D =| 1C6x(nB|*Mᆧ"!Ik,B+Ov݁Ag08?Km?LfJdL S0_,Ъ>PX ĥ'LO~:唑 eBiA,Ε?aKaWO*[(*G-`C8+TP0ZV: q&-,@MY>` 0 ۝$(5gD٪4<0G5!]0Ġ:"08P D>PX)UĀ @{ `uXwe`pu !w9Wɶf> Vǀ` -|XFטroi  !"MuP~oƚ5 } OL0&khnk}X  JP!D͸" @w `|wlوo tls{jmښ5igugLو&GPAř Z5H8v|EH"/,eG  Zz q@ ` $ Pʉ Jn>#RzcPj?Z ` ZVpiC 500}z?i !| Z>==%X1k1 *=YFcT=SE `0((vN mQ;ziPYY+U1v fp0ԝ Н{P 0~ Q5`;|%μʵA ۻ{&ߪ0Xg Fc`NPό>IJR)Іhp@Q-0+sݚ 4f#L&,J 0 t̆Z@1] [}K} @ in`*'` (geWf`0ˌ@g uW͘ P,x- ƀWΓ[ˆ -b,i `?{  $p ix KA @`Гp݈ɻoSKPѱ=ؙjnDFS/dL$GG@, o FO4 ߭4qݩݽ-4M00p ,k p  }0U02ߥ Q_P˻Kr@m%fY  P =[Y՗  @ ; VJ@z, xݭ=^ބI,HC 0 x PJNH*Pt q 0j>\ڭ u -h *@Ϡ }XQ  @ 劮 _^ 6]i~ݞ;`p ,v P  R j 0^ h400uR "!`0 ^խuY @ 티 ޾ P߾z@8| y @5S~ > _nm{ n%  훀R H@8 L P[Dp'~`EɀV %P [ k  BLS? ^x! dPž_]0O%Udpp & jPP& y QY L0x]- _Qd =h S .> ppS@uk`bQ͏Ⱥyb6,\\ *eR#Y]PR叢:&}4)Dx>TPE- !kգ'iɱUp%!e&O J.3rϠTɲ̘4 F'OH FlSy@`ҭSh,W,DYDB`9I4FZ8[vK)WiIa Cpbő2m[Yٛg71& yȸE6TPcŴb)1*I^܊\;𞴌pk z FgyXt tl x .aDKJRJi7] Kd?"%21 4o>4@yF:nitx-MDeE1U|/1ы0jizܱBG ,)ďg&n@^|>>J!J`@`R\F9adH X N(>)Er9 "XÏ5@@MW 7Ƌ/@Xj֦HVXT f 5>‚qa|e@B )ָcK\c pj=E 9(bi|GtcU)=m8cYc>?ذd $\>PKreP& 45WL!v(`x?06W,=Qfy wB aM61 $`.ÎH`H vCjԏ^UjkX%k>f)= 0) X@fo^Jo-(e!ዖM߂{G%lܝayrH<#Lp e#H@EuBqtl/Ekd%]Gs#'>;LЂ(a 8d! w$;x `}R L~8 >f?# {8hD#d|%";XCB0~  ą1*l,5P_lYXyr*pz'b$|pEQ X@&mX0v` gFIr;F#$y-. Qz K(=/yUHMZ(>^s?sE0x84%{D@!KAtXk8 H }[)Bb>"G0*tPCE8hQ9xZ(Z# ~H[Y2x`P?;@5BB*A0kF\2k4̃U}@7C@Z(\!W`x`opGxH:͢)Bp70#_a8CXd dDP;0/C(Gkdl`4 1Ss obX̃kFq?`TȪ8X #include "gd.h" #include "gdtest.h" #define TMP_FN "_tmp_bug0006.gif" int main() { gdImagePtr im; FILE *fp; const int r = 255, g = 0, b = 0; int r_f,g_f,b_f, trans_c_f; int trans_c = gdTrueColorAlpha(r,g,b,0); int error = 0; im = gdImageCreateTrueColor(192, 36); if (im == NULL) { gdTestErrorMsg("Cannot create image\n"); return 1; } gdImageColorTransparent(im, trans_c); gdImageFilledRectangle(im, 0,0, 192,36, trans_c); fp = fopen(TMP_FN, "wb"); if (!fp) { gdTestErrorMsg("Cannot open <%s> for writing\n", TMP_FN); return 1; } gdImageGif(im,fp); fclose(fp); gdImageDestroy(im); fp = fopen(TMP_FN, "rb"); if (!fp) { gdTestErrorMsg("Cannot open <%s> for reading\n", TMP_FN); return 1; } im = gdImageCreateFromGif(fp); fclose(fp); if (!im) { gdTestErrorMsg("Cannot create image from <%s>\n", TMP_FN); return 1; } trans_c_f = gdImageGetTransparent(im); if (gdTestAssert(trans_c_f == 1)) { r_f = gdImageRed(im, trans_c_f); g_f = gdImageGreen(im, trans_c_f); b_f = gdImageBlue(im, trans_c_f); if (!gdTestAssert(r_f == r) || !gdTestAssert(g_f==g) || !gdTestAssert(b_f==b)) { error = 1; } } else { error = 1; } /* Destroy it */ gdImageDestroy(im); if (remove(TMP_FN) == -1) { gdTestErrorMsg("Cannot remove file: <%s>\n", TMP_FN); } return error; } libgd-gd-2.1.1/tests/gif/bug00060.c000066400000000000000000000005271245535672000164170ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; FILE *fp; char path[1024]; sprintf(path, "%s/gif/bug00060.gif", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { printf("cannot open <%s>\n", path); return -1; } im = gdImageCreateFromGif(fp); fclose(fp); gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/gif/bug00060.gif000066400000000000000000000406651245535672000167510ustar00rootroot00000000000000GIF89ac!,c <)F\ԊDNƌ T \$GD\\Pu/D:$&o qľ $vj fLfD"D@tL4lilKTBW,.$!4 )F|4(Db,f<`+4j,(o1&l>^<|btL|>lttd\dDzd7W4U1-)\/,Zn=HARqk2qßthJQ PJ@]󘘚BDjG)eSWQ&jg+H4Z þSd,E&Rl=-;T5+ Ib$NaDtnqA+:]>ꙶ:Ar008 ؗ+y0)+J/K] OFhld;Y:,ֽ\ Wl3`|׺ Y{a>/etcJdG[0 EN퓍IPpi&'TM5VlrLdF ]|3o9A4eW8R,Wdk"2]N/% R<&*,@{2Qc{s&|eISRsgDy(Da0F!,cK ִD QDBTB4D$TΤRp|4,LbHHn'LBD| 6D T4,k66TbT޼L,̪71 bd<✼l<\~0tȬ|~TDDj̊|7l&82ZL2F||frDtJrdtq4dHY|n|!ĴFxWxP~,>d\ҤF D^4T /wd~ tltބ!1d,|T4\v@{n/O'r.KfسkUٚ `8r"_It>F? ەB(p 1_B/)v<(!v0LhNdOB $D(EQ@GeчbT5X^<2 r78PN#S (&BYqBIMB$fIrѓHA.sin4F4L1fCj Gqf|yȥHCbM$PVqBH1ܥ \bΧLeU`\'СVJR êW@G2QӓcJF,S& :DRAD *#M[Tvޚ%u*A:t.c+w=#xE/79d`ۨ""p[kTDfDG%|Mio;u{25򄈙l08DLBr ݬy@ B BfMbS]Po6-]U}̤`|m-,j v/60[Afe,iS|:s ϋV0Eb.h0~PR9ޓ[AJ/O}-[SUJoW3=<}@UЖëAKJFh |w}֑rn~~oV> UzQ`*fޏQDg `p%VL27^vyCVqȅGGi@nH ^ą21z&GB ~x R,Bnx=D\HGDH&"S(,m~ڀ $BD鐙օ2/vԦ8,4ΧG(cDa6a{ Ρ,b $$#6T%k"N*$UJ.!*W FvZj3NGKU;ڒ%^`ٞe,3U#+RGM5ˈ\$r{Fd0%I7˃KtA.d Iϓi}k@y`,9hG&Pخg2%T?QLW=bC)\jTAV*8vk'(*_gC7uMF%tHbؿli6*}[?iF1ɅMF%hQ6ɨlr|#pg rMLrW8(=nQFKĨ@ktyf6E< $ZU@hNZaR?v H6hRU GOg$EHeN}|Zp[phƱeCä{cĘ&Ɣ-bJ3!pBAB0V5#HsVc:r8rQNT[v$ɐ"9Iu)v3f zRM2Yn˖;fc"\Du( 9ә;QG$|<ϘJ#hSXtLB4A^lĽpB,ݾi$tAK#ISQVd^7ADv [KlAX+Wc2uflR/Z<^ųlٌ0p<6Z"kja&O2BXmsS܉G];$& _2KbKAsA'~h#qBKNii@ WAx,n[E6"wfUGLg@̐+Dٴ6 #s0h!,c(0L,dҤZĤ^| T \~$|Ld\DB<8T$2<*u­AGgxYY}){{N,Go9ȝFp=V)0# wgPWƹǜRhW _-Xir,YҸ/_'\4PyHPMɔ?xR6 MmuBZb~c \ Z`3hWuEx(ASjnA5߭xktD=p )A'dx 6%_9?iejy_y\eSYCqQ;}橱?d{1.m*Iť̥QʮG/ iLwPoC'Ľ to4%}6ys ɯr`:6}XS! )@9b_.XxgZUA Ԋ oB -)tI rh# HԱ!)"I*D.1{2nb--^ t•0z)d<#\/FDd#2\mmjJłǹ .\9zDF3%l8Eđ !ÜM2aZ:YzQ7B'V]JK !.]cL~KF.9Ÿ`EcsWJVeV"l%sPp> s̙G&=~\<@[= Y!DBɄ.CgE#B'JQÍ=Q8F̅dOj<}A!hXĤaDf%0CL)Bӊt)7{ PRA%CPcM]Jժ^LQG&w."VH٘C(,Qvb LrDj:*V;> "ت ִ2M">Zb`Ғ"d ]"䂔WMГ2eT9~Qgn$ u73Q \xnbҋ<~ULi_fqY'0 Hs#HsK͑ 8t4z%+F1Rҹa5H*P}H[*43C+EuJRسňm|w(-i#&Ȟ9rn;,.I>gD*<y[v[|kߢK)-%9*v#i$TD23Emr5"?#˳m\=ĸ!Bۼ!9ÖG:H(Ҡ=7~2.KgJG!, c <L ,N,Z<NT*< <>&zeLA4 o*]ى~`%@~WHj(E(\ȣ#Hi`-6w@mI稀2$.Z:)ߊݺЦ}ZPM'(= U[1:Ӷ: *a;R ­C ņ+nUt>;P ',"›VR9eBvUFvǣI(z>l^[,Je)VIy)p),!Ƭ(՛er;$tCq&}j, T,%ňyԯ#r;KIP+'t G;%מ]P&I 0 ( )G}(Z 3P8ϳ).yAd2̢j6bLqdxjߥn*@Gk$m;KLq#I5 Nh./w5 C7,tUC'IyB-v_x"4jHHO F'cM <(v0 )Fp /$B0)x0:m'+K!S(-A bx>Pmc, IgdB`rj$Ji>ˣJx4I8L&Azi7"C4¤ bCVP'Uv^bBR8GW:!jr= Hʉ!)H!r-d0L#} +VNVd&]%/KLxp  Y! QBd$M`+e@24(-jςܓA6O~zo=@f®b1&3Ud٤"pMEp;j`wVm@Toِ:ֵjUXE.mx8.f)]hӢo܊_/ ℨad2% /߷8[K=.K 00i >4(X2ҮaX#/yOďz d >I<̂pz ~^var_ħq_S$%~T.(\ŭ|!Sk1L۰ttFKHV7Դgy 5r(&Z㓒KGp2EREddٹ@uRP_`494S!5MΖ EZ?mZk02)J6i;fyc0ǹ@X}{qh׆aDɕD"!`ԍWz$@H$w4=3qJl@rV8CkKR i|˼ Kii<(ntE'17`gpK ;ph~>3!N$7oP=]X֊C6"OrukMy E;;!0u W(HJr;/U<tt<d !Y?ϮP|10fiC];$^ȇ'}{J'D4%4偄2WܞٻR""Dr" u~OS}]Æ>0owB?K8OܛB Gv~}m{g~ (~ Xz !ee9P8xqt=H~w~{ЧW} kR-GNbȀ+p46r 78 d0e|aBv7KzQR0v X)VHzm68gho{coX~\H|uQN{8)Xgo66BTqTE(my^ Zyz}8(^Pq:R"P!,c2$,dJ V, Z$ d^$,ƬĔ~ޜTdF℔J,b4&Ăt\Jt t"nl|\BTjTd촂\|xS\iDHʓM%ɒʞ@JKestL,R;j(5hrq ,!W)TϺ@YFlc}bPZr @H1LvIK ‰4R8.!ĬccXȔ3׭Ih&pu!tI]8BAAnO)GkHo%5ԐMFyЋ&B 4*푄Z[ț/!4.wiR&|dDd2Ǹ P\!tMmJFz':7 ElCRӜR)H! zN%D !,c= ,dTlJ\LJҬ\DLTJDT֜DFl"Nd L$d&DlF,t \B.,lN>t$t,ftN<ڬҜ2d||,"|T|>4R|´dnT"$64*$t|*i ai.++ûη@2kϴʝˣ߭=ؑӵՅY)O߽LI;( Ç@tܲ2z8"IR6|ҶJ\ˀA#(%s>dkI"EMd3 B8I4RvfWK}iYG"RJNeYJ ӸƕTFE#8vMzd㰹uve.?:,ʂo:> s z5^=»ʃ<h'c DbU(]7l&߿.H^? Ζ[?3ZgcuCy>Щ !`et}UQPne\ bb;3܃De @O\̵2\ (,"]cgJU1)Np5H FR\oIN BBdA%S~.Zf!5Dx!yyRE @y^(h.J\pHZh~Eji "i R駓ZU M*먂,*a ;!뱗Zz*ZmLɧ,$Ҧآ Mq>B"#zl m$ ʮҮnn!F{į$5ܣ. K1 ;k$32q" ,.Pv+0 _3Ɯ/۲6'-#33GtL*DCԂ㱫2CSMorhqSRE;]DsqA`{T,Ui+F '} XG1ѐHCb0D&y"gO{AH$9,mq(,!J*#я9sɤAM4Oz(@PL^.If!LBkf!0@;libgd-gd-2.1.1/tests/gif/bug00066.c000066400000000000000000000007441245535672000164260ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; FILE *fp; char path[1024]; int error = 0; sprintf(path, "%s/gif/bug00066.gif", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { printf("cannot open <%s>\n", path); return -1; } im = gdImageCreateFromGif(fp); fclose(fp); sprintf(path, "%s/gif/bug00066_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { error = 1; } gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gif/bug00066.gif000066400000000000000000000616211245535672000167520ustar00rootroot00000000000000GIF89a=3f3333f333ff3fffff3f̙3f3f3333f3333333333f333333f3f33f3ff3f3f33333f33̙33333f3333333f333ff3fffff3f3f33ff3f3f3fffff3fffffffffff3ffff̙fff3fffffff3fffff3f3333f333ff3fffff3f̙̙̙3̙f̙̙̙3f3f̙3333f3̙33ff3fff̙ff3f̙̙3f̙3f̙3f3333f333ff3fffff3f̙3f3f! NETSCAPE2.0!,=Y H*\p T #JHŋ ȱǏ (ɓ(SԨQ˗0#d͚QɳgHhJtHXAw]ԠWI lJӨSj9ӕWYkT-c^TŲ[P]*O!OKL(w~}O2k&.U#-[AG P:81K[FfȴFOS]mw~eڶ/âV ڷU͚jV*vu׵-*5V׮}_MyyA}]_6! !-nϑנAȟf!uZxVb`ZX0qFl+Fg6#K7VyhlE jėC6|٠ <6$ZQV@OG{L.G Z(g&尠GzXam̊i5+TE` P(:BP,:UVh먢Jn>zko{~z&TS mwjgܓ.WlL * ,3G jE1s'LkbsCSH/ZΡF_O< ( iEmҼ kk)}[l|) +ܬp1 7lqë*Z6ʊJ:UK\xHƢ \/>1.GăCN7(l>ȡbxP^{D>z l++jl3H^ p-:IJ_&+ 0V*WT=X9~ǀ܊S[Z)8 V`6* * >Aa`*(<  =  %ؾqRAKհ IK)Xld B6~hh${Sڷ3=e~ Ń<ΉI g*K P#`eFu5Pa/b4$ auekœ\ExK#AuY̸yRTVV :qPړ,.l"#543G 1aO '_&`.j~,[A.`ReJ[av ɴ4V]J1}6v`)2Rf4娭{?SJء:eOY-Zՠ|2/Фnl`!# `;Hu K(tm\$fWm{\uU=ypOrDA iB_( WT'Eq+4Xe*l [@eZ6z'9G gBmT%0 ,{٥/}""AH@isʓSJ=Hz' :hmMT܂b,*PnqTϘ:ʨ*u{]>f&2%p!5JC)qxUK\:r*į6~ c-#X,ظmrĕ`,\x}G}ͯ_樱4V{ j刅s=7{(HXfUMU Te3$fwZMŗ[)uybSz"[I3OX0m9n. ɳ1}!ua2b%w~~"ja{6w+EyuhO w&SznRh]t c=TMEeD}rIheƄWX') 4) Gv1qtGinA Tsge эRZ59v&j"[*(W.rq3^b+d/f|`Gk/I~Pd ;]g)0Ddg}aJ*,%lU'^)%PP f% j7+uHf69zhwp wW5 5ճ1¢ w=WTiuceW5>n{BVֺdaqM'ǚVy=ɵ:WgS=yy Ou%Phy@Yz,U g\3KdS]tM,} 4E_%;Dd|r";Vx=lkRh5,cEY&]uD/թH/'ivXX1%jd[h?6W;PWuQX_/ E\H`KkT0Vc!:ɋ@o;g1הB/ד&m1p7Lr-osi҇pcaO7؛Oiw<Җܙ:7@89m$k1UR$iv҆zUjsx'1$ŽEq G[9IYh$X>r2"!S,OD+)dw|`zċs<178_egBOZl"X6zMT$EW<`$"}ebAcz1֐ -6yfT}@>Q̙+8#Pp9k˃sviy&)yS_U7wi̙(N#X*LZp>SHq&(;Yⵐ:)@+Z)Xh"E/<xip?G,Iml=%D!6[%*s0n^ܟkpX-Rhsh⥰eщ.B ^.0*AL %+ q Z/ds.1FzJӢZ*C #d `B۱sŁ,A9p'-7P:NY6bA9BGvy,:i>ҫnZP>Pd/#?gJ^s0l f/>u勿5ͳM2cKK8'Ccd\A3F"k=D 6&{Q/DDWoc76k[]pl, &1JK9!2  B .|$О*4RO ~̸""EAftH ' DD L'Fh"+xThP \q`˃dp@ 1bLdDŽ'W@mT%PC]M64hڱTuWO K1nכ/2aɋz:]:Z!+=C+R6 cՖBW5Q-9aNM VVoāuD %N%yH HB~듧E7Hh34J$7v+$,JTg!A-O@r |۬={N&$! K̪0ʪ҃X^i? 0<d(6V ڻro% ?Z Tr=z$Jƅr鉊Ú2"BdR5r7ېk)RsIԛh8? -Lr%޳"V89m!$*dlNb1$ I#GEAVZ!f 4X%!nW+*:L pG[P_<_{E)cv yK9_Kbe`b e(rmri>$:U؝7̚^#K'@*ea~%P9=2 Rl$۹E@*0`@טG>ōn&1P?7~W:)+K8#+a)3(QQky tH$Y4AVGv-62qIS=8$&Ž+4)|x=!(ʑqP{fu4]( ѱJ&"STRAby̅[QH&27x>kɚ(<+cEH g̒i8+BPH. &GS*w ,r6n *l0Srr ;0ަsBR|sOj$hFbQlZ -u%D  H` ެAJlɏlk@JM(9%钻&s`y,p@$`(1c j$F{le^ DάB*};unRQ4Ϧr`Aųjk5Y3RE̬0@c~$Gf\J55MRI;iAڈ* yL2S=<`@d2 Dւji;\Lr"KT@!#+[p`$B|69`U  Rg:+wҩ ܈RB1mkM+FUTy"%k@+|ZDJg&HQZ; c>j]1T:e<7 `Yt)" ŠkE݆+5qGΥбTĖLRv{v^Q'kޱdjMgb}J {D/H"k_ 5/(v<1 -k +(k?x&?3 az.Ģ"ۉUB(廁&UHѸVǛ!?5܈ 20=Aؐ{B(Ǣ=Y)г9ӯ"T&H"PҬ? 8?'+(ك0wq ֓~3B (ڒ@?5⡳Z;6+ #SRÃ[-Dx)+s5YS$?/"PII`ˋ=*Ek[J aj 1̞$"b+.9*4@ Jo-*HrDl[IF" 8"Tڬry8 /C&, /FL+F= 4(z:ā87qY2uK(aI.5cJ(DVrzÏ8*#J x7)"l"YQ%Yx+f(PR"=+:5C{f !La?A3"Ȥ*o8递fܲd15213ឰciLYBɂ1x:;A)mi(h;DٛS/ܱ[V퉪\$Jև[eJ'Iy<+!aÞ it(P4Ɉa*Iץҥ2@qʼ8ǵlJ5a]Bi=.ZT-9 ЀEWkKQ8VaF+ah" 9Ax2=E1EBda{v7 P:n-0c1r)ưH͵1`i^CX&@@|*8B0iCxBk.)li.$Ys =0=颂-ykƎi9 =B06U.hVkXջރEn6mmB0iM3C Xm։lx  10 hfEk@Pmւ\;W(CE1 PPna&F])WF=nfkp6kh H1xj %.]q.0oW Apі/^C Po-B?XgP0`Ws"jώ0m.p,bl002EY0o6k젦EX9=Qap(ھr?_v&YEq)B.0 1x0`ut-t(Wm'rQNۖpR-xg?(^A-nWh/`.FB@TqB:Ow`+Xhvg@؂Tx&v-xunlnn-1DawuwTW1=,V)Sr~AGsv `mvtGuWIcr+?Xbuo?@ri9Ajty#XA(o.y* kxz2q@b֑(jrimw0bTw>̕^_TACxo'Ov 0p>-A\ s@B[dT_|?T\bv';_@OϟZD@?ZkאN>$?_z(ɫ*Т֯Gep a`Æ<aTpÝ[9Ցnf*Hu ,OLaua͑X^Y1Y$}1.~ñ~+EJyp>FIYt7r 9Hs% ia.!a~2wCu ёO uZ&GS<( &pu}UHewejgbQ vCi4bnH|Eʺj۬"H%0%@ VL!װ $  "A mOs:<Q!< A.W.:"~h& &,ѯ!qT - BD0.ub"NZd܃!Y l 1[1,U!B ?zL ^rV< 9Ĺ>}t2xd^L@ o͖NE<15Da=qNJ/Q R!aPW[m`+K|ͅ9[ama.~(w?w=trʬ+; .5U|uN`lnCB'@Y8\b ,l+\ި{/<{_!d<̟>x!Z+pUζ]9>;l&#u5}rg筂~3VQ e 506XAѴ p"cIp8PVtfQ5e+`3H ؀Y fB-=0DTC I@' q_c _r۴&*Xaz-E'BQSl4p,BT (T 0Nq e1gZªE%6~#Cua)E(Ʌ(PX%g H`m+%2d. 1+\!%_ 2 O䦐(2 4-1+͖ N%h"|!,=Y H*\pW #JHŋaBǏ C*Xȓ(S$!+cʜQ4sْC; M0@*]JQBJz諣Hjj&!0]ԕWBIǪYԨYBpakWT}BqK0!W*.XU^v}Jpɷ]ypdm_Y0̹3Eˆ%`06TMP]NUTWeKXY .WUN[B̵DêfZ5j |y_JEյk&s[g@aBHaww=ƄZvVU&ț&؃`UFIVucեeP:H"ޒLer٠ <ZYu6x z< U2`j՚OVQŜ$Jb&zj : OgRUE$X $*gzH!hah!HOAh T*PZĠbE)zط AX:(zXa̪ePmfSjOx {+T@1,B1d_ i$0t* pljA LU`PPק W2Nm#5&\*h`/ jzT `i lXKp ]5eo;P@|ɈGTXӔ( bc&-T@ẽKa!F%Ƙ9 g҈_Q+`EtcS>gѺCieu1S` S“3 ;-XiL;,-SYhV01fH5($+a yl%/0yv$BOk_+ue T+3 |mߒIq1G($ي 3J&GIa+@&?rBF4R`%dxм[{|*`)\JjtI9 \6j(0vP”mj>W=$Fg}J7Po[U. WS̽pJN+mk]M`JR٩X%mbWů_ X`^+8v/8^@p+cwJaY x22WMRf)J3QAajkpUzp%7Z CRmIBY'Z$ MWP螪xʲzntyY2tZEt SYI9>-cYKvc@&\A0kgݍNm8,.\=tc[\!Oӡ Wza-X13<6P>I.* w.H02  hdQz*iܥ Se4aEVj3*-$A P4*f5A7k秀rO3㯢\%$'YqقCZ{ZmsD+yK5\O{N )l żZδFbWuV 2m^⌦4E.))3rBZ+U-ROrL$\d=V滠a7w,U&7$;猥bZPMpZ_tbҤ\EER+%E0dRLx;.>ooC&*|3ޮ޾ay.yI"U>AqKVkTDNzٜ@of83,EjUځp}K$D%PP YLE{ҩ"UĖ,]devũ}kbN*S&pptu663xa*njLZCfXEW.*&"5*Ť0Ql*`t}uU'7SXK[O3p$ba) ~ R$s{iaGV}eJ4GhkI&zHsQiQcO*+:x^%\:Qvv |ES盗AȈ?#43ylW]ԗ\{%C+8 Wcv>kVj4}{T#6dA EUDhwVs+t-bEQjEjźF#z`{[VS֘F0\N14r&YZ'] H(SD&owtRLUB뤇׵:1lT'{PMsD7w%_Z .;L$ۻVZ&ɥ넘\e8b8'l ,L4h ѓZ;=@5L( 0҅ie*0ƌ-kx6|82Ż2Y-U0*9?2(%@$?_#4dv[-n$PlF@(>4I[#=OUT8%3ܼ3.${'S*/rځBKA8=&>V Z.*>K~֝|#d='+ 023*6c1O`;!S֡c+"Ye-/YR>~I,h,+0PtM;ړ7ǴA}?HyHޣh{4)(;z<8=x- >0 C;` #ʄM|Ǽ.sM5I \<;KdDw8uOqZ|x3Hr4s RU0->#3\fYr--Y 4ǶW`o4)g}S z:!d\T$+A X+a"o fm ej+I[K_Y^?ϗHZ4?tGTT*^Ćg.\G),8 ˫L@}V'~{=#5=1Y}rC$W[[X;G+"ː|؝9k{?yZh+[Y8|,)Z= +;kvPxZ7Tz"5$+DapueKcdK|2#> Yl Lso=/[m>$ 1IEDh/7UBN,,#zԺY;7`XTu2ڌĢ,-9x'WIm{mLJ۶:jvsɰT=yBl̇VQCLsrX^EЍvZ8ŏ.TIy3-8In1LNȼd-dÏh{6,'oDwV[MA$T9jumIJ@ ,=+2| IJ8n8o5CIB I 쬓;P=j 0KÈ9CO"1$DŽXA)̏~r!>ïIn+Ƕs鴍,R+3孉X^?4s@X - Ћj+:T( T"Jʲ @QGWHt~ ?gӪ+E>mJ3ր&V{R"llr&TL@,C"mc`^H4Uz-úf-}) Xe,LX vjD@%A(J>ԟT?RBO|2RƀYHS;,\.U4 BϔTx rT` l+ 5J5 pys5FԬ,Rsj)!)Xk$޳w9,̡ OQ*!CG.Br0k JhV}\$0 i٬B5늳.dXy(2ɥ {0H i2;mpPp,fmH`Dda71 e_p5*CB/}L+,m?&|gB:4Ykio)g%xp5E0TAejRF.y R}iv +w#)Zݤf5&zskш[Kj]:PL =SA;uu4M^{Cb=*8%x(@.eNkLR^5k\3),n~J^$rU4IY-Lt=#"YeřC{T(Md$'eYϳ0SZjTIJ+DAPjYe5Y) Mk5 Mn C:8Sr' T6X4Q(3MWD;/'֎Z5:^} |0p0e lrP ٠T Q-'9"M}[ޑ*Z$8Q, sr- Qr|Ė%s.m3C$? =tfVg@3~S)uٖd0COc~乙EB$p`3đ6VV $%=$4|QL%-*KckFћR4R9> XHU^V8N#usօ˝SD,[D!ĩ?--ڠo=R\A1GHjhTШsO *gӥ%X=Մ585}v[;tMAg_+CJ昔P1vJ2:(|CAJ b^qD%OpQ6!1IO3d6k+4 ZГ= t;SQ,T!I-ղ)Y5$;}2W#PdI"|!^SԕT1(ySD?S%v,S0݊tһ 1z/JZ>ITW1︨lNl^D7-ߔu[S[s~ "Qḷj+o q|F? u Uv uT`)('`C(%ӝQH ak;Ô2 >X@?Xb*ib1>k((q.'ѫf9T(? 48Pr}!MAV? zvi*3- 8`AH)j**K7{90CBT .-1 h@0@DNz-9 sCYC0-  b&l=(92 C?ЂYR9i{ Bj(s@ ⺰͐"1#kFE-V 2;QTj,,"⸉P/QBCbʀsB؋Bpn*T:N=P+Ǥb8!/h.-`*;Y8)jc+OCL! я탉BK21(H:äA*0jt /HWʓ`F^V{o;Ss A>qJ٘+tzbP k{US): !a#D˽ 0H¢RK%kˉH6{|U ;(N,lr1}+" !݌[K3::4:4+)Fk{"w?QȊQ@? S{3̈(r@3#$DžE;!xYlhZJI˫ E\5O׹h8H0խ5s^cKb &Y}̱#i&‹)/7LZzYO^$z% [:t& 1  ߝ݇8mں7bSRJm;#%7{l/̼v$a(k:Ȁ0\ܹAGFdH ۍeP)I Fƴ=k8 a՛Y2:9yʍ HpՈ SZ'6KPEl= ,, ݫ6 Jr P$廪J )ɟ ѓA _F1<BC\(`Z Bu&@ƒɥi4I8'Z꼈X0Td~!hX¢D`<ɍa%]38=D@8 [ H *Hhh(g!&2S\PV)ckCX`YXiXXNRe=ͥY,pZpj ^$B`iʅi1piCj9kjΜc=v7.R-`ɠ-@(U vl.wVU^_*𩾶cm=[aZf֖.pBi-bs*؂JH|&vy pCvyqv-0(UUikUFo~n- fkO3CU 6pIW`0vFn1Ƒpo>^-XsBxyhqOn? pVaCj'n[\mWPrXq,7pV!*`!'rD0Xq/0x.E RC1 P?/2oG,EPBRfpI XNn^+.O.rEi@y3@(0M*?(Zw[0xrN1pWq?XT@WH`gn{Q/uGyAkj݂BJx-rm@t1HqׂmnwTX0f@B7"t[klXl?-x]B0wHq1ATw7Q> ??F@{b@x?ITxG_~_0Rrw7k&B.zC kч|3A<tׅ[lƛ*@(Cz||w FA{_Iv *%G<@\wyO??k-P 2l!Ĉ+BPB  JC<`|!WФ9 W 3"E*ZP!-qH+2㪄-beİb>\1]Ң0YCu姯_?nPU̵{=85YB@xB\Ä&*Xaz-01y* 3cu4 +̥ Rn'F2 oΒCnC#H27De1ۃY Wp3.1!B04$T,U1T[F0*yp!)'>Tɖ4[N%dZ;C|Rc!This GIF file was assembled with GIF Construction Set from: Alchemy Mindworks Inc. P.O. Box 500 Beeton, Ontario L0G 1A0 CANADA. This comment block will not appear in files created with a registered version of GIF Construction Set! GIFCONnb1.0C:\blueva\mouse2\tree3.GIFC:\blueva\mouse2\tree4.gif;libgd-gd-2.1.1/tests/gif/bug00066_exp.png000066400000000000000000000277271245535672000176560ustar00rootroot00000000000000PNG  IHDR=/x0PLTEff̙f3̙f3̙̙ff̙3̙̙f̙3̙f3ffff3f3333fff3ffff3ffffffff3ff3f3ff3f33ffff33333333f33f33333333f333f3/tRNS@f IDATx}kC) 6;ocabx!a>!t@Ѹ.pRHGS  Ch(gC@xPr 7dW=Za޼`.1b;v?NrV}'lDqEuV@:ԠhMYp7;0>`Y8XFu@6~@WeWzt0ο,6v-,g2z4,FJ;W5Q%iR3Vz U ^ZAqDQXZ?=@5@3 Y;klf]kd2i`7RϿRj`Xʶɔ%Z] Dd7 IX*0v@ǦV/;?E~e^@5Z 2!\Vb%kc L Z(OFƺژrߨPᣮdIMNNO׺45xMGlV[G#M&Wj|8kY&%rtw IQNEU(djE6#hj=2>ISZDdqٶ!V߶|p#eZ̵̧Qߎi߭-+Z;P,M(h[Bxu !P/ul%~ ٷ ZfGu]L2,Pz>202d"PKW*-z%7E7ywA/B'W!jc` TO\ov~u+Y@2Ocݘ~]}޽DΙk(;G1zk!v}-@5!?& Ѩ([򒊉Ruq>7&rxc/ R𼫕1[ vXF`11:PȯˋXۚ6Z/ENh^K*77APKTwXV#>(0]:Ѫ"a(039x':Nd2@# LT09鄸ë+_dx9h-V,dΤ3\ 3*,s}Hꉪц9ʿMX0IeJk2<^`⏵M:ybDNk>J7΂$hqlTME:Ro1;jSVP*B&Tlpeh u]cE -6r.AN)tvD6$ȼڀ̊ʒH)@`sbYjd,Gޖ = ~1ԓ[,I0zn bA# ߒ9ȘqB.cY-˶q!6BeC#Mmc`/KEbI|ݬI#Yi)h'vW;3 ۲ uH0 q Q57!"5`h~ ;=c*UX],"\ KGzS9*Yb`QІzk0 ygֵQ,ơT-Hl (S9d @ Bq][( 5?(R|Y:͌ Hkd+ qVEЩު R1 I3Z[)*gu{[n(R# Q"hMFdxG;6+iR"0 UTB<=1oVIQ`h UII_t"73Ѭ*FjH%7> e֋{^`[r6g2bDo0+^![l;vwq($#:Tc >3&$2s5ߘ$8/Ge'SDC&6?O7!4` my' $><[<`ݞfXi9dƇC$hᡑ*,RXpq\˺Vd$'%ZVd$b>2@"h7(DeDւ N/2+*R*Wð4hJͯ p @rڝts$EIgOyUڰ gm}0[Fzk!h(axX25謥{ cS'ˬ#c64,PEC>iʒB@Gmʵ"cx4G- nO{ !Cr6>\c05fyFuFkj `kJi#d+L4 Y N5QE:)hu]ߚ[<'1w7TJ0A0av7nǬxQ ѷ)ek /O1Q04ӮQ+xgi:W"z3 ξ + HR߃Rb/jSD<.…c8-_:|b,#tv$+Y8L{[tRYo`fq'8#eN^, PlC8|yzCwu(D]txX'~:yX~D'\SB$Ƃ@OjUm% #&آ!kDY-iϺF{H:>dh;TT3XR7 QYۉtpb02^ e쳬$EY3F Zb{懍~0;3CQe격 Qg(Mhg ^`iJ\g7更FMm)p6#Y uWňBB_a~9zc԰V 0!yrTʆ$m00uf(Z$ۇ8,h\stBhO5m?`,^.OZ#mT Fj~7d]0V4A@>QKJ*^>p93ųR -yz臱HMzcX.VpnˇrKMӱ*PDgO*6S2Kum1*r$JMVOx v+%G5%b ?02.$z 3<=K4&fTy'fsH#Z32xgi72h4]ESȖܠ@>|iؙ'LMcm#Jۤ;)1Zg*fiPCx{k&77{- l-Ss8§]JX "kSndMWǧa\ 2 / 3ab.Q]t]N8da#uP5 {!qQdg {}IklL({ ͨԂ2U2(DmI;"YtArCJȝVf(,D떦!o8g!j]{LP $Kl4]1`\7 EzMehЅ98N )TnQ6Ub+%X8_n_[>pMaק}Z`Kxnjzt߹a ,V>:1> mKPxAB1HLʷ&B g&`(/>Oqb  luLٖf6Dƚ7v=tk:t0~sKZ #j4PgQ@bE 0{ Ҙh`p(\2C5-wnk._fJ4VG2=[@l6EpTR5z~Z}*S^T37Dd CXRSN+bćelK>h{?@-*ۘ2w2>\ /;{Cn~j?ov%s"[Cjdwᤂ,rG8!ahkކP}BI5mcc;`}#MԂsG~WOw hMW bY# ~^;yE4vQvMje$qrb85nF2Ո(&n^ő!UM@*)WY]kōeJ 6X0RN,5?jx_5كs !OH.*&pPAӟTEQX262y2KaBv^KBĿSfX6^n5P MVIbFT: Zs YkACqxT1 CvyA &qg1S[g턊rfRu-PXߤh׏?p1Nt횮:Z".E7u5;5}qTʍ\HATD'7P@sw9ΓI|Wuzly ѫ6Z"o]2x:Nd|xZ*q!(Uwd(Q$Um:ڐAigd>`yre].C|6ᇷ=kCDEFM@HNhpopܺ1.i b]w@-G+jsDA1ܶ (ն_na)\N^K];h)}]'F\opLZg!@ Ϥߐ ]8nqKƲl]6 Q#_Cvc_UN/??Nܼ\r]TѴ#" ~|@. 'CԼ9WN62HVvK >߉D8M^8s9zi|bfV5*M?.0H.![2V9ϋ6 Qc#66a<n|wHΐWe #U.\XxE`-|OBήK|ĹF0IMj;ޘb2umPqBH HÇ!SɃp ݏ4^` 6^O(9__Vmc"55O>%th8 t^o-#nߣduNj?q8hio .b"pׯ?oxH⿸;I6l1[6l \mf lȹicf/Fv<驧ETÆE#=}_m"#s Y餭}sLh>Hg# kіj)oZ߄ze?A<|g4$q,wR5hMo|2TYg-iDU#Ք59iqgu%zgg7WDdb5WaڔC<%/hlY@#D}B?ExlXG Y3,5U7% /C@dVYK%)nn? ̇1kdI3,VLWHeWr-mcrX sWs|Z.-ZRq.>lȯ>4Gf_ܞ0Б'lq:J\¯ۈ"D[j\*Tc TSJ) y[ U b&TǼd}'>#&hdǻ\iM8=#r * ?e=nq2 \0u+r+!he2I&LA_m D݀vQ[Ohhy?~\4& 7aޥF7l|Ώe`e3} _/@jfJ%@ 9EQX߭M\_ahlu` &hbM  KzXHEK.~ἲYxbdw\g@>#Sޒ{2\zo<'[,|pϧ)Icb ."2?XV_&qOQv3ZH>жËu-&6Ħ)kzRuVrQpL)NWg3JW o I&"L޸EtwjȤ7Ö6D:: IDAT|K:>g#;~/P{e-y{k,@<_׉`t,ýp kRS/JC44J\W4LcTNHwm.// 8b˲⅔(+*l\Vqf<['1P&y6}Pzgh[yOE/pTה=rzSA9rk4̧}1v2ёHQU_n\R5M{YsźDd~{YywS˩ovibЙ,Zg5Gppb3f͉|l_GX.Bup? qYq+m$kTb߬tP`[vpr/n*`3UL]NY{Gkj%Du q&]FS¥N> (iLT|gÜi<ܩ!YmMb3mRy%VD>DS0a" g&+&777V4k%!ŎdD2xr3hH~%@0x7:yoBt!I,V5U4W5urY+m w{xh^;߮kzA_ -"C}e:Tj3/nBa B=4&}*!yzcflkXY*TcAx>H V ̴Q]][ C.hY%ztQem=@ AI8$K`3V~6ź53$N 䑟HDfT]gLXΓ‰t0@SY߼V&:;)xIGGKا6A: wrp 3 25A3Q @H(>D ^) RtwR0YM:JQq]ٹx]W=)ԫsh[)Ws:ˉsRzܔ #E|X+u9~m酏Dg&M<[WBwO{/mQmqm9>=D׎7}fhc;9\faPʬ_oME5q^S?6]9 `}vq8؝٨gvQoy*wlm 1IpS~bHAUf D\ڸ%qaI lE 'GwO)4K-J`_) y|uIWK[aa-, [kiRF5E^Q]"ŽYJ9!BϾ5FC'zGZ\!2b/Pq@ӧ mNl J/4d/2iFcCO?}_tJ]`k]B£ɱ82K{+TeGq/ZiPėڕVSp hgIU9a6R3EFcl[׵7aqF3oK9> a<Ǖ6 _( 1E~\,f9Atƣu0AgYg`\ kt5˟VA pn0t}Ը٨ܷZÙð>u9u!ް'é4Ol=-;l:nǏ-Ύt:}rORNAqO;E{7,;)(BcxmȪj<?G9AifnvzCu۶MFd\U^oxÇS0a#U3% h6 `u _VGhgYӥ og5KrpW3Af@ͤ]nŴlW._WN7٢m+%L-j(dϋx63v|u;+D䌘 ^dͨMdU XEJ i#~Q/_{9 7a]!M_xXUhʫbUCT<_+_/MhϞfX M0/`cs1ahNd|Y>- c)4i6"{{]6Eq|^&rX ]yoX_DL vlB$[[O LԤ(Wp0Rz:p?) xEUO {f.MdIdq\VU>IJا򼪊cd +^,<^ZV8W`=:SLvFj\q\~]Î_E{ 4_M$|E{dlx}:#YYq@:| &v {{{!GG|x@i pOnzzd|8k͗W' 29X\4e5RyZ/s;sKx/}ppzR @1k0KªVp|Q|: P @wP@6{jӒ >NQ0Y!F+ %k>?>΀bfW˫~>_hh7V3B !7 Ѵ*PWC?.ouqYjüwpd ɔ8aDsUX\^cDP^1Rƨ.k@V @Gν{7B ?UJl9߅~]^db/x d'O?alH.o_3 ٲQF<`02u⢝:ӯfTj{DV< Yvhw!Cj`WuۋVt&@13tʼ7`݉l.d&A6. ;@Q׫(|%2#tf@2ԥ6dgN'w3Ȟww?~] ͘Z#rwX _ z6 #K;̨TïRj~)wlđ}  lI{"r/gWd?@VU{Pa4>( ZFTFk/7m Ҹrوu,Ҭ:f?a:hc5 zV3x^=3$a&;3o{7glW փUj?՟ DT >>_j4N 5P C@ '@`IENDB`libgd-gd-2.1.1/tests/gif/bug00181.c000066400000000000000000000045711245535672000164260ustar00rootroot00000000000000#include #include "gd.h" #include "gdtest.h" int main() { gdImagePtr im, im2, im3; FILE *fp; int black, trans; int error = 0; /* GIFEncode */ im = gdImageCreate(100, 100); if (!im) { gdTestErrorMsg("Cannot create image.\n"); return 1; } im->interlace = 1; fp = fopen("bug00181.gif", "wb"); if (!fp) { gdTestErrorMsg("Cannot open <%s> for writing.\n", "bug00181.gif"); return 1; } gdImageGif(im, fp); gdImageDestroy(im); fclose(fp); fp = fopen("bug00181.gif", "rb"); if (!fp) { gdTestErrorMsg("Cannot open <%s> for reading.\n", "bug00181.gif"); return 1; } im = gdImageCreateFromGif(fp); fclose(fp); if (!im) { gdTestErrorMsg("Cannot create image from <%s>\n", "bug00181.gif"); return 1; } error = !im->interlace; gdImageDestroy(im); if (error) return error; /* GIFAnimEncode */ im = gdImageCreate(100, 100); im->interlace = 1; gdImageColorAllocate(im, 255, 255, 255); /* allocate white for background color */ black = gdImageColorAllocate(im, 0, 0, 0); trans = gdImageColorAllocate(im, 1, 1, 1); gdImageRectangle(im, 0, 0, 10, 10, black); fp = fopen("bug00181a.gif", "wb"); if (!fp) { gdTestErrorMsg("Cannot open <%s> for writing.\n", "bug00181a.gif"); return 1; } gdImageGifAnimBegin(im, fp, 1, 3); gdImageGifAnimAdd(im, fp, 0, 0, 0, 100, 1, NULL); im2 = gdImageCreate(100, 100); im2->interlace = 1; (void)gdImageColorAllocate(im2, 255, 255, 255); gdImagePaletteCopy (im2, im); gdImageRectangle(im2, 0, 0, 15, 15, black); gdImageColorTransparent (im2, trans); gdImageGifAnimAdd(im2, fp, 0, 0, 0, 100, 1, im); im3 = gdImageCreate(100, 100); im3->interlace = 1; (void)gdImageColorAllocate(im3, 255, 255, 255); gdImagePaletteCopy (im3, im); gdImageRectangle(im3, 0, 0, 15, 20, black); gdImageColorTransparent (im3, trans); gdImageGifAnimAdd(im3, fp, 0, 0, 0, 100, 1, im2); gdImageGifAnimEnd(fp); fclose(fp); gdImageDestroy(im); gdImageDestroy(im2); gdImageDestroy(im3); fp = fopen("bug00181a.gif", "rb"); if (!fp) { gdTestErrorMsg("Cannot open <%s> for reading.\n", "bug00181a.gif"); return 1; } im = gdImageCreateFromGif(fp); fclose(fp); if (!im) { gdTestErrorMsg("Cannot create image from <%s>\n", "bug00181a.gif"); return 1; } error = !im->interlace; gdImageDestroy(im); return error; } libgd-gd-2.1.1/tests/gif/bug00227.c000066400000000000000000000026321245535672000164230ustar00rootroot00000000000000#include #include #include "gd.h" #include "gdtest.h" #define WIDTH 150 #define HEIGHT 1 #define DELAY 100 #define PROBE_SIZE 11 int main() { FILE *fp; gdImagePtr im0, im1, im2; int i; char *buf; /* generate a GIF animation */ im0 = gdImageCreate(WIDTH, HEIGHT); if (!im0) return 1; for (i = 0; i < WIDTH; i++) { int c = gdImageColorAllocate(im0, i, 0xff, 0xff); gdImageSetPixel(im0, i, 0, c); } fp = fopen("bug00227.gif", "wb"); if (!fp) return 1; gdImageGifAnimBegin(im0, fp, 0, 0); gdImageGifAnimAdd(im0, fp, 1, 0, 0, DELAY, 1, NULL); im1 = gdImageCreate(WIDTH, HEIGHT); if (!im1) return 1; for (i = 0; i < WIDTH; i++) { int c = gdImageColorAllocate(im1, i, 0x00, 0xff); gdImageSetPixel(im1, i, 0, c); } gdImageGifAnimAdd(im1, fp, 1, 0, 0, DELAY, 1, im0); im2 = gdImageCreate(WIDTH, HEIGHT); if (!im2) return 1; for (i = 0; i < WIDTH; i++) { int c = gdImageColorAllocate(im2, i, 0xff, 0x00); gdImageSetPixel(im2, i, 0, c); } gdImageGifAnimAdd(im2, fp, 1, 0, 0, DELAY, 1, im1); gdImageGifAnimEnd(fp); fclose(fp); gdImageDestroy(im0); gdImageDestroy(im1); gdImageDestroy(im2); /* check the Global Color Table flag */ fp = fopen("bug00227.gif", "rb"); if (!fp) return 1; buf = malloc(PROBE_SIZE); if (!buf) return 1; if (PROBE_SIZE != fread(buf, 1, PROBE_SIZE, fp)) return 1; if (buf[PROBE_SIZE-1] & 0x80) return 1; free(buf); fclose(fp); return 0; } libgd-gd-2.1.1/tests/gif/gif_im2im.c000066400000000000000000000025241245535672000171150ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int r, g, b; void *p; int size = 0; int status = 0; CuTestImageResult result = {0, 0}; src = gdImageCreate(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } r = gdImageColorAllocate(src, 0xFF, 0, 0); g = gdImageColorAllocate(src, 0, 0xFF, 0); b = gdImageColorAllocate(src, 0, 0, 0xFF); gdImageFilledRectangle(src, 0, 0, 99, 99, r); gdImageRectangle(src, 20, 20, 79, 79, g); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_GIF(name) do { \ FILE *fp; \ \ fp = fopen("gif_im2im_" #name ".gif", "wb"); \ if (fp) { \ gdImageGif(name, fp); \ fclose(fp); \ } \ } while (0) OUTPUT_GIF(src); p = gdImageGifPtr(src, &size); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromGifPtr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_GIF(dst); gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/gif/gif_null.c000066400000000000000000000002771245535672000170550ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromGif(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImageGif(im, NULL); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/jpeg/000077500000000000000000000000001245535672000152645ustar00rootroot00000000000000libgd-gd-2.1.1/tests/jpeg/CMakeLists.txt000066400000000000000000000004361245535672000200270ustar00rootroot00000000000000 SET(TESTS_FILES jpeg_im2im jpeg_null jpeg_read jpeg_empty_file jpeg_resolution ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/jpeg/conv_test.jpeg000066400000000000000000000044151245535672000201430ustar00rootroot00000000000000JFIFHHC    $.' ",#(7),01444'9=82<.342C  2!!22222222222222222222222222222222222222222222222222"&!1QA"aqR! ?I]iEA(!֨ZkTVj4ttZZ.%:VkTRXCQEaE:VWVTrIaEZtZ-5"j$2 j4tJQkUVU:-.ad":VTRXEQEaxO֠ZU#ZR(!֪B-j+uGKA::XCAZ: CAZ:XDQXDꖊXCVjΉ EAEaE:Z]?ZXCTH:XCT(!֨!jF+3-Hԋ5:o갋Zut꺬!֮}OWNK\['VIXCQEaZihd":WQjatUFXCT(!֨"jnE#r,!֪F27! j&-LLŹjŮSKuS?n‚'W.Qa4,XF`ӭ%h"֩h:i5@ZRjF5@v2*u("֫M$nE:܂GIkS#RpIZxS^kS:yũcEdKs}r1ר՞-l}cn{raslfńNV&gD(!֫H:՝@ZsP.L*:hZ$g! j1FqńվeyУ0_?%;?us}d]2sϒ59Uד۝.Huf!ufHkTXEB x@cT kS AF(Vstis㿋nxPD|kic]q(>yd|q߱rQF-gu*LZ`m+3FwSP|+jHkVk5 EAHE"ZkWb-P.L"5:jaZGHuWۄʠn5+9nOdvTf7W^˳f-jݬk_~Oa6۝ij4ij+4@Z'TXCBDxN֦#Qa *Z-jnV#R!u\nU+tt+R"uvSNWW=Zջ-jvSk5ZT B+D ֨@{xN֨VDj,"֨jenV PD+Rԫu{;bS*-j'VS@Z'TQXCRHI"+I=J-X.AEa Z("u%DZ-j+u;EaD.$VkTQ CRIaI"+I=LMd.QEaE: -j1'RAXDH1A$ZHTXDKu@!֩${I'IRI^aEkTQ CR)aEZVT`+Ia "֤Z jK),"^I$e$e$elibgd-gd-2.1.1/tests/jpeg/conv_test_exp.png000066400000000000000000001153761245535672000206670ustar00rootroot00000000000000PNG  IHDR?1 IDATx̽ۖ8%z[nk5zo}M>2;w|[f|G^B:mJ)4f(?4YN~O(\d!u}#E;=J;>g9mΑ|w:FƮz}E]?sߵ査_4R{7oSB݅2B\2=)B3P㍆H.&SA[PHڨ #NMELBJ9[0$A9l^'2Uh۽U?`}zGo 9(]':mB_,mGI'AOkF]ڴQi#V箣?]T`0ۈLzN(>`-Fv PK J(z q +U5H6v"K  ~T(J5;4pCNiaKyqRl/65jXĉX~&r^wtH щ:i,ц)HDDPuDAmGAy|[WH/`s=YU;v6G֚x_%Jznˁ[ax~jğNųNӛLB$0ڛ$CtL~-EIp;ZZa菮Ael:Y\G?9l|" WO, XycBs͕P꜅EOА'&/FBf]'zg!0}A6:Xfl8j8M$G1ku:޽0 0W*uņ~{(Ө i;2X<KKZ|^x<O>O)JfG&z=ۇ$ L'wdt{ڱ_& C#2;HdV,xXfmBwp|#:pdDsii <,"h{y9&*&+ۋ]H]xO-i[A9%;G{S[]t4Wٿpި9gG?ճgɻg:o- K蔦oJ哲4vdm'ٟ: ({Di~|%- z&iQE?_ >ʫ骊"5 O3{S0ؔV5ӄ HUc.'$hKU< ( `PزJDPsӫE&S[oe+!  1'Pit*7Z5IQ`+F5͒(P2p?x򝍚Oتh =:!T[|f\6OR)hI&RKK4Ư"?QiMX:ӛPJ6-nm!{ȋL ]xbje&4t/ﶏzF G[ -TZ+Mymx֪/5oiX@{a{O;Lh;5ypyWNUMn÷6C?_ǹV]ie0yF%h}Csl^ٗ$(X"^ &6:G} ʮWQSu*%1t(<' r:q.v.Wl'Xةv/ͯbR/6?EԽ˷bQۺ٢8VX#%sdW$UĽ!s&.b+Q -*37Xl 2OwBw=xN+Y0m{FB=?07!al?Gkܜ]xn6G؁2EZU (s(9jFNfmqz#ː5QGv6S\ik7۞TS%of)OHy,xxU;Gۻ+ :{ilHfrKI&Ԭ@ꇇHKRة꨼MdX-m$I$K1&1Fl-=l'_֬y;!ەuD& Մ3N|!}P{BSÄ {CZدS8#^W%M* o@B~^h<^|k'T褊v-rD/ )͖%УPYDE̺s)z4*D'W_mC>Xx|yP04v-v]y?m琧9'o.d<Mbwou?%Ʀ7r$8k+Oa'SAnN >*Rzc5ٚ@s!+j(t긭MݪD-G҉mlޣb$P8Q =G~*MbgߊjDR73_hFE ojYI4wiqn6@,Faցł Pނk A 0 &?ѳ'پi&AO4V&GY2,_?f G;I?=sy=bc#O 6TG@؟䀕uMie I{!BI6>r6j+{߭zԊqI({iHy~<:jb=5?uwiO\h@y%7 xz=^]q|o:'mkO*HgBYowHݵSUfL❂l{?9;4 +?WseY:s(Kz \o]_hk\+eܠ2͞?kEKHXJ B3 Z_d8Zqy<]ϑ?A™Q!L8?YR3|t0 Qp^{LJxB \76@;K1Yq\MD=p^gҭ !=''zE0.#EТIslz{Lz]w󯍀T,(tSm*A5*=C7~qİIoKyT>ywAz\ڪo=2Ym[~"8C nm^Fӟ>"gWތ&=b&k|UݹeSs{͔dD=NÁ#2 nO;OުޥJk{8T3);BPwQzX%&keH3F[9)sozUJh<0픦ϹF5lT=0͒yݨaNU쟔]qB:N{1"OֻnMnT.PBhY=-tߝ6F@27P+o~^C(*o!w6a{> EbQ&߾+KY4Ou>j* j#'Bۻr5$:~Q:ҁHlFSP C.:MDʮg?![io$F՛ӯ0.Q9 Fm%FH9+ͦ~'{߲-z]m/TDWLw|oMaueэ߆tMCP jB3q ߼HDCLxXoʚ(hMqF q@3q3OSb߾5cE8eJcvh>Qxlj/ZTz=_/ Q'W7?*] ʕM}ǕZɷ~J ؋0r6?IU+E8ߵlݼ1gA)CǺd>%1%$E)g/[VѮmgvHT(*xnE#Pj{/ SDI+O\kӯ9!omIN4>+BiP=W~3fk-ǯ]4.Jo^ʞ9zC~M~^4f'Yf˷^*`RA8f/A܍9!?O3dnܟd8ߔPNQK5:ZMVϾὩw0K;xǓ]sJ>TascKW7 y~7/ s$^3:Flיoe{ ]_[^OltfqsB6lQM*٢BwzGe ia~萝ځۤwSOFۼ%{?tzg7!>A·6csEeOo|+6վ~v+ز:60Er7lT}b^-%Ea« lz; hھ+c~?@&<4^{O6FwMy[7";]]o?`u|2y7]@B8?VcYPtDIG8m+ 'Tԙ߯#~߿U..sQ~?\)fP$3ޠon0)0(5@a)[e1PNIĒ;vQvVޒCHmdxgq=rw&OJlJF|zF:Bnz7'i}cW7=eg_[%v,yNpgoi2]y, nW 7hGڿ%NQzl+ :Aٚ٫͗T*hƗٴtp]לa!MV='FAC,ڞ7OBm(˶zG3 6ؿɱzXNt X=4e?MY%ߍ7f>?ﵯx0Ƈj ;}]:;\mѭ݋2H=9ݰ?PH]TدBmqN+]VTI?`T>EXkdn1 uidy5#+i8eJ┐S,Ii(o"ד_и_ ( ;Nai-D(uoj}mʉH:+:g?)CS(R{ {jX~^SA@m#%QSOG-fswg5u3'S2R+dEVI0oo%=:%yyX2ݧ}R^]>ӭ`ه_PVPV5nګ\ē;ot epl5l7#73H djA eJO8TW wCO\Pyv> Tk.ѶZBQqgA}QH{B Pߛz_CLĶ>A:j+ݐ 2-<]RrCqf64j]r>H?o`ҏ rsE?7̡M۷}zm0lEخmgHQ< ҬVѠ!"(A4=*5N:h`DM׎Q"}s< O>i#vi?/nvI~; %7J?OX}+0+JW灞zq4iB;=9` #UKkV~i5S 'hoMDֈ`%nwU(4Z]{+ ld6J{EtПԏmt߁OoJzoԸMK}(:{mqwabE+wNPR )~m].@"b ibv<0lvl5Sq +ٖV;Ϝz ZPR۹soʉT,SV*H5~/d)V<Ӯo%+O iCx%ߝ9/YHQ*'dI+V IDATTfmɋRM9ehV[q,?F.=luk 燘Vg 8Ѩ) 4eaNvJX'5:l3Q_G~B]6eyu(ߦP~EJrJR?KȗPU4 5B6H6Xdװ|k! ]͕Lx\דw wN-6WJÿS(iZ_FX0}D.-gUHB=j_)[{ќ^R(3+5:gdkHL "0eD=L4jY~0m e=i4n 1nY|\)LQ-D @Kt Bd͆~oR_!.Dzk?ۿ+9X{~xoi/.Z:`ɞ 곶QjuvV{'}*֧b}մ:fD_@.5\ݒZ9v#/kCPWƎ"hov%ƛZn@pmQyQph7QMҹ >̘Y?W!M%a-TlI %ݳ>/\ԏ9l/PlCz+vQ+d*͝n5:Q>nK\G%%`D EܿDdb8>R@;r'~²; {*Rzֽ*Q2u[BԲ&@dv|CnRhMPs@P#(lbx,qObMmJlHujP,p%cU(ߖ(h:15)h79s'A+T홳 wK߉nl(rtf*CPFr[J}Kp~GGMx\BfE?.CkmRA][–ݞT?)D1URs)0]sXm;?&o?E~nJ򞁻?~>@><1HJSSUrIO>0f4WgFol,i4@He* Cn^*"D$wSFLIL3u'lki M2Fͳ&#cͶٴ!a?|#Ha:{ΰcƘݷ:UH{H4beT:}+֚v{5ih^? ҟf7,{ í#IJV #C&L~f7Ox'o)TTrѡNCV7Jbkc/Jqdl$&OwG@V[ن)2̃w- 3-}"zf Ő&qY)[Sn^g]Ӌ4e>onS ^0]–:7QMHn<:C-AIu䷎_cɑr;h'#QSPDiєILp3H i 4~DDOaeVh;R/ƃ8xF\Z7:^nڔ ,Q'{x2kz=ə}v=ǻ$QFu-{C6}9,%1 `([lSد=΄HA~+PEa9L/Sk-2qpvJT*ADTl^uB H_*QOU~@(SÙ_QӦ6}c&tv}om?nYXhlEmMe1+\i6 -O@3 Few,q:t#A-ٽ2$OȐְvs8})-fU*kBT&jDX\ċY<8* J4uJOTfV8lcH ߅  * 7?tWpZƐ;X5]=SgNQ*?:BPAi΋.J3x.#C(о8ǻZXxLU5 \c$Ĕ7 Vv%oXYIp+-@DС40L@DvD!Bh :{nR^يQ5X3jxzRl6M>8MՀIզ~8i*pGb8ڢݢH"lo,PU7mrY#/ U ېK}bʨ-U;ʺ$e7"7 lyfvix?*9rN̴=r/iáwn) #dݷC_Qg@1yf˷=LU]︘I8Rjj6 +"if2B9xȭ KBxæom YHȼѬ4ކ*)#LJ`$b5-C8ر %uj~7r썓~,I'efhLS]@Dk"k6Ѹ>`Ě52D@nPu1VM"{$%zxn=c*%4s 3@y:SoGmޙOYGУ}kxM6$hig$Y] N#d@0֢Rǻ`߬MzZ@UEMA)FFonRJLP&.* 3%.S2ܫ!4B P%"_XxI "z$㱍xb:Jp`&riĿ7Kqq3|sPJ=|ߏ X$GbO A= 2(idF{7%/=22g2gf6*/:&!fDZI5\~?ج&x&k-"Z6QE!LVڃ$;|sonbu?8\W=T~0g=n0vZ{+Y>LyP1Ͻ2cYWlߺCQh9! 7P \ W=i/Qn-Щm6ki#ƾ~Tnȕꝶ&?"]N$>EHMm[׺>imaE<0ti ) ?Y񵤷pѴZK{[ l9۴k(T `6@Gz}bLҬ#Jɓ [9]~nY搪݉l. 3 3wz]}2Jذ+TAO x_ej/*O@l|n]3"S5[9@H\.sϊkD9z3Ȕ~4K %EY/ocmPx Zi䤦D)HB&ː7иO֠2мX[5U#oHHX?B_%JMHXß0x{y偒[%2y>#L\d y =_yY!IvR0TazIT܀~~w?Wzٕ}x\c$`I_hPM&GÆN&#"@TEo(-4Ec#>p#=[AʁmnK176Dk#oMZ>I~__JWhϛ ,N˽.ھ+?ߟ$}>V333#q-CiLXR'ӡs'X_vO>z95U3Oyf0TYIZAg~ïm-+Y#[ďܠ}&c=W>`w~~` 3lS%˧Δk3Su+HG$OWZDLl_W+h067\0#"cu|lI,,s qf,]n@(3%gsutUspXtl9̎ϖ{| &g{fjK Oc?,+bON4J qeBguD>i׮E>}acHٸ?,]n( U3n?+Cy[iisHsWcۯaߔ$ ;mI~mZ 2߉ZJuB-n}@C 8\dʃcqk4!TstlQw~[VJ6*4gSnz _\RD]|P56 +iuŐxc}c1o5\MHG %ӎ֎9G7OT}H7JU4Q%",K2SJɁcB )\pM>hSn !xV?*;)PA by1ƌ 'ԹņaF+Jm{uKLc:MW|m4Ҳ;4İ0̗J D-W$@ж߿M Z'aTH-h=Ӧ*E ` # !T< =kŸkZ߯:14H k2wpBˍ~֯H+:iHlL%(:NoU,K[rw3-.UTV"Bl[vnxhupnif(wsW9cpfc\v~ J9rFrh8)8X}?rĆR$E#Q]ۦǙෞ@h;p~1TTV`4XSVb,HEb"R^1Rb{.kǴr"(3 T[L6UB*"+f%LvɭD>)A[D"JPRriy`3Fd(*3)T(Â]@ٱ;Wgxu.$Q{-?!b9Ycʍ *Y|~r <]tD6,z3M]kyJ<f3CsFje"`A4WU߾cmeZ\|7 X2-~ԏ=\wT,mDbkڎ:[qVG[\6|x˔-=M HB3kiCqM?[PrwP¢%|U(3YsnZ"=@ b[l LJˎVҸnU?),xV^"ZjV Yދ3,Z[3PK .~^w& v(4\go`&EtQݞoxڟ!MQeSUD76 ́}3]I] V$;FBo|iwRJV&v=t'Ff q.}Ed?x+k~z[~ItZv l5[1_ϹvIɖMkʏ(cZ~D"LD ED Dž%|] g[yl!S,YA"_LU"eN9LxA<({Ԍս "bhYi?(D^J3<5m:V"?+? Ől9tm~#+6oiWf6RUcPcN) fBeQY96mEZ>[[U/^u}@l`evX$*",NC. ىh]tߟ/bؖ!Cfj[}4R\\Grǿ;҆b 3u@i^mZJ+>-h|ܥAmU7Qgz`R/V<ͅNOHqWlFݽgh̥W;0`u]u"E@zR!r?S7ŢتzJ,ۦYK)lrFcAy;|@B$sD *G$&hXhs{w:ә3x/&?ޣכmlT {.Ï{bY{1[,Z,%-x dSg}u*5$=+Hh{r7'_D|}ސZuZ"QYsf WeQ![NLKp.)dă}WhhDIpb͡F`&I(bMm]"<Ʌiȶ7\7U,B(Uy6@=Kb`?PQPa?QxW#R"fg=11fx{za' a[%?õDTD>x&%2/"!BjF(DʷB hP%׭"bZ*BDL9u"a3gXV#/kdjxՔ#ںVOspt=a?Ao5d2m5ad S+j3̚^ 'iI -P&yG@uJx(.U>tT,X^tEnbX["zzA}CD|FZ]ץ[Iz7GM϶pŠUP+G*BZn';[ʆ4tJk+A~3KsQ"S􋭞s^i;劰'{lCuVuwm!|l_%-n2tMǷՉ MM#7ׯ_qۇxU[(N sJD hWKp/ZoX@AM&ƞHsѬW‡ΠMdCnyu2"?ߜ9c/LmF~:߈$` NO T֐&m{:.8a-HFSܿ\w 1ar%qqͱLm]-0h31 k/ŸX-z~>[?_ĹM ׯ_ѵ֯_^f#gj(`oՅ:F H%WlRai-Āǧ.u_Ek i-|ڡg08b?vn3ԛ3Mecزb-\}\~>ׅZעu-񺅈TYJ1$)bu9 (`Fwg 4 ׀ڽ4O[Ͱf?y`(vܔ3Cj\h('NEErN1)=<J`w{qu}_&.\X2b|,>x-Ko} >wP??a2҆1[5guZڽ3a'}zSP=]J cW8!丮w׎mSRw}7SVDgxCCp0+k4k "H V2¡o\Z-^>>}A/o8z\/|,n.EŹPZ[:wIl ~!KiMk//]!)|yWⒹjAʟ }E`/Y 0{1  %1%HK9)Wf؉ XXh_Et]"1ס) 8*PwzURNz?5S={ @g65ze֎ܗ0bɃb;w*F#2&akB4tuB,=4pqGoеD Ʋ,"Pߌ1x2X%\&4h.zHȅRZJ.f^E`p+/(tAIha}-P"d+_*Jz ~O#(ƚ}[()1(1wn)SMVt>-U}Y5x1h钨=3 /~vurg'l#렏:&.C~F&V(x>`#yx%KHE^;#5uy`%,[JKU;4/A͡5or'q̬`FcoWXzl7mdeއKlۗQVc= $jp9Q A;_#VaQ[uz y^7^nXztd"Fa +>FV޴g՟mϛ_365cwqq1ΓD)֜$oESIS;v<6Rk`tu07?-?ue71<=}oapʍ}is@p{d4I7TJLDp۞ʞo!xk8[j[o1oTl!x }8(1i[y'YW}TEaQҼ ($=5)븪QwZ6s-Էͷ\HPA]I#+.j!r2]Ma* re'GB"r+>TD^7>o|uoOQ[&JBd;Ĺ2 bKi2wgkw7v-tʟj{ Q~?)Dn2 5<aՓyZZ>w 9T猧{9!'B3TGK-xųb~">Kd} ۮ׍OD^z K>_zFX`ºqߢdm$ U&1JcvX^f]Au).P#G&' 7Di .m< 9wYQA$%hԪjml`奐[MSW%%Kk'$k4`{W2zU M h}VG+s!+`疏~YG ,X*%8$!1VDcπgOK[]1/L|ֺ ;8|bQ?a~N޽n}}~/%"t-%z]>x-e#T,T_|U_rM!KTVuݪ}ꧼuE(PHb3oZKEP&T6Q૲Bj C#ݦV[EjqOM)4~"#l0 ӊ~u 뿶%'NRwGSf鿊n.O s@+!uֶ2n?ŜTmM/n%R"/ebcTUGVV5(/?o57WBNu݀٫POh!n>pَ&167X h*gN_XT֮ۯVs![s&}FL1gD*Vb|MDcݷ/.()-&XpVRn[E0]L}~[$SW%1]H5[? tȩC+KFF(+,`1Άt ZpV'c>l.Y˩WiRC!VWb\>+,vV#^c#A_ \J;3Z=EJ}NCMDmfsUy>_[D,qj%IuGGfeDnlē| 7 ¢yR8&o:?53wZȽi @$J,Jrʄ vpq]`%0ѬW$7ߌ%KnyzH -T^tƶGLSo(em.?na#"vYky{=BX` 5~NI)Hϧwc(NAd@!sCU5k@.[[¦CNj4]DdcXhl[{[9"0@4 [r@E!?E$`ܪ̗U=P3_}~dM__o_ˌdߟ7/3B2d`R8@z}Knu]DqYRKTI4"rDqi"^̯jk*^E'J T~SlajGQBtcj]0u͖r?|ݖyrWٴ}*26s#HN/'yE& pHd.;j[>o,]*X"&oߟ-+*px)cuzܿ>?m~]7Fue־T[w((p1̱_*>mX4Dl0%N?us@DeMSTΨֈk F}]q)W(Bq@5 im5ޯK Ҽw,9m -w9ft>7덭Zx}>xC mMn>̕d^_|ܟjnXZژDdG IDATΠAmP" ڡM W1F8$>a}bԹEkvHRnk7D4hۣDAk@ܨ?9 'ѩ@LN:40x]em;I;R@[>>>MhzؖL,]{~~{o7Ԋ*pnA!ت;̿-8(~qeH53?A!1v{|tEk5:=kNRm۵BHSkJ|wF6cr!xiX75X)oIӓl;+~cZvxQ]\P a.|~~~n vK)D0a]+b},آ{Cݑ]D$UdlUN2 Sm˴ůWV4dVp"qg1:;AwLEj(lڿդ7G~r!_mPYlhdJD`UC%*oXXd.o}+{ãe-oUNm^-iIWj)moh@,a27O6 >0(zߡyeU2oJp(t(|xˬ^D2a(D Pq"NʸMq!vAUxV#㏭ޯZǯo;j"yD.%$%% y|Rz_ֽua'vƔv(Py)y[": ] l1<^9E\Sۗ0]ҩ}AӺߊ+>RN_cZ"'};i]T6+/k)%OkiW^uj?7!~Y KO 8Y%(7/qȲjJ>2Z`> 1*x%P߰9iq< ;)Pu`7k|_+VbE,՜|,'_A牰I v?@^XO|ZۂhmQlJ@[L1 cZk}_ #-bL,~ b~r#$0d/ȶ 5do2 ]]ص`gXnm![.fiU"*]>tSAk!v\r'IWGX߱fۗa(Hy~~t$^G:CjMi8k)[?sJQ< 1į 5 nxcA[Ğ!-0"~gdΈVcw+l I.O`Kr{E0otTyY?ý-wA.~ 3!|~/i{}C;d{ԋIOd**>AJAonL7B m Uw|B28,c3"/@f 09CVfA *z!tӥ0y=e!bgZ+j2-M8 vsͨ}пXi8Uͪ+za2ZQ BPOLw!; ʫ|VΛ}[ AK^10Ä`X U 3#u0rnn W!_sDJU& QMfPKxVhv狙{D<k)>MBZ|RP!FZ'sk*(?V  G$ I䯕"/ 5 -;vftzrlplIl3W$6d8Sj@'B^?O9h$\g;9䟛P<?J10%2`52$مV/XWkO 9q Uo ӪP*Xv6\_.C_?/2ev~ߪՌ;VBN努Dw lʉvYH)%Co;%pxXK/Y_?4򙘨 ˆg[ T=\Hfp>ƽDJz9.ː!I> >3 kXW,`P6Sy}BAe'aQ fyGb%J-gk)Ҙ/ARMJOׄzj_8)8tv]TЅFtw/}%KLׂF-c  UjBsaW|dƗ=@6Ԕ'ɌF~ڦs痧F K%x[N޵ziQTz3j8!ȁvYVώϽȘǭ n;YUi?Uɍ7C^ZY._Oq@]#RQ͔SrAS2;HW싴cfXc} RY"*jǕw;CNJ3V|N'zG+R,2mϳ>HsO>:7fg3/V'3Lo`ekRz"Uژ%~Ē:F<nÝ̹("k˖mk/!Gr״xsԈEٺ6xQiΆH}BO0/#,]Tx%+K=!G/J5ASr68SRi`4Idq57`1G1!GS [=}=ޮh؞=di?FPwL0ź65$-*ҵVdZàvVegU:-S)7[sEHF!.E0h}o煄>k=7گ1׺p9\^we9_`0p(Ӟ'l>e&waQ R{K3cʠ\|{%0P(:{!x 2D}%v 8eX"0}#Xďtit[HK⌽yCf6~T=BK+ vO -?3tgmgua5191VٳhJ8&T 'pب)ds<*˂.Q_ Z__$R@iCG7B3Vܿ)7iirpcA;lKŞu'-fb_ϴZSu)hA5?m6UhͿMVZ̻cP~J+BPqU`.Dch쵖gca](n|{},-ܢKD,̚ 7 ~.^ĠcQ$g V(`o?%2=|zkܼfxN}~mْ=j)5߯@Xf3s[kxL& mƖ!ѿ >*<-!ۡñ{Wbz\oC~'>IůN3r{[Ų`mr~6V:2a[]\HTQM@Tm[8L=f=cڬV|R}¯}fc\'-AyF-S?h%]%$\fɭb}6̈JX<(u܅+2}\z.*̄ӴјD12?M-ZKS|p 5C"[:Al-js<6t!Lo/]RDx:%p26х3S# NRRŖ-TegT. .R20JVafvvUf6;E:Vr#N qCZkfl;o~Y-1:{dw _zL$c|Xi\j `fa}'Sf~law: =W}պmY0o"FKxG< 7Ǹ i-mTS&@6ߟd*BwEZbdW o%7wKƏWm,=[o׻gq|oIZv=g5q==hu':bs+~H1)sP } (a1nZ Lހ-3XgiIK-ǖڸj&`NykɥJa& Ch(KO+2BR`X|a(BQڼD \WdX5(z;&@`Qݺ"=gmvuEUwTco N{G2W3B;Fw?kh9p1wI~ĞvR:*:!5З \:&Ǩ(|Uod !MGW>u~I(MP*, B|7*Gf(;o)G=)L[EPaA])Geb!<7~ZWq>5%?FXNr58yU=~$/0} 7c-n7z$čOW2=Ep鵶&qþ1%ۇ)d𱷶y펺x;`ݠ+\cf4>~++"?>Ny?S]^ (~0v xo|t@^ Ql+cw]~$#S YH F u?4\]WWv>@Nkr,Cޖ0y 7l*DpFYKRז (a%ȯxy' 9N8-&"yMJTIX AkNT 1`S+KW8f#R8{1'?,Ulo@1}cc/3l5C4V!lcϱ?=Qx?ZӍR~;#jدdžI.5HzPΈdPFߠ8Q}ݦuY~QpRS nj<_ ,)'-inuQ/dahEAaJVLn"kbi}ɞ34U!!?kqfXOr~&̷#B)Hu$ GoQ<2(nDp?E徏TJ}CrH+B.ءiPyFԑ߀[ϩ_CRD?9:ؿ)njx!T<oMs+Dd8KgR)2>%E)DG*ݫFUK3oZ* [+,M$ȶ̈ lMF3-!=g2~.Zm|? m} ` }Ʈeb͍*.jLp3A؎څ8 ܣ9Ip7wf7 O=Z'N)P;II ҼE?c@ܾ0co?7}s}njC{0WK8H`VpP81+U֗5Eh7]V=a%LxJcmD' cj2V\_;K-Ԓ_;>h%󺤞W:CT%"е_x/-adAOr?y0Dt6d)2P4?^1P6+żZy:{U,gtWl٦,[#F 轳-u5נdb!cd~obEV.1bs嗀g4EYo:|\Dʖ\B>s +SK'1PFm<A+4BsUt~cnAO]''s%wEEэT߿ BůUo>[4h{n:BviEDȯf`n=gN.Ldo&IETy0]p*Yk~2#i;0;V+"Ģ,!1.=S>w MkKGv޺VJ=} >o_c(@}f,O-)K\R@jjv"O@l?e'j, =?G`m?^xo~(f<*Զ@%y^ [ό3R-ui#իsAfu{is<!a| [y.47ici4)Y Qby:'HVn:c{?ˈ*) C W#;p=6Ic "^C#"zc'`9M̵t6ee'W S-G͓M~Hy|(ӝ[aTVS (*9oԳ7"O>_yΥUDַQi{E= _yTk'a7-YS\dEmg?!\"@v$0qҕ.h.۬k:?V$lQ­VU8= t :K1v7;$=#Iwh7B?F}!|#^6O6h{я ۍ kO Dd1asD4Q"  F"&О11| ВՏ{ ưt[7em")|.r!۳j;T l5;Q {;/)z5BٱU+VYfiބSyCaϕc}ƆҮ!pm~ L>io3{Q"GջRz18b61 ׹ٺm=qtߡV9I>sFO[esgxo1.WQVV:~]IlNB83:kYWMɚo 3;*.uMs/UJ\]=?ה<@t;8R֣ .I_6=hGw.pʶh͹3o'=xNX11PFZ=b`|yOpҼ]>|CI0ݷ<N"L?NIDATߵJ C#aׇ#NDKU@' wۅ!HJЦ_<7z߾jwgE0=o wxlq܎\렑+\IMkIь:Rg|{oUSqk @U|Z+)nHl.9BbT| ߉jPc5琡g9[4_l>T_Xm_s0>(-i5e{T}e/ ZD"Lѣ~ +@eYꨨGiF@fX<`jfsp V}Ksk(89ƾeJƼ9\2_~9Ŏ ݯ:ZYA u@jMR~ ;Yʨh"=@ctsZjSlSuL6 ta>WgjΫ>O@?-~O0H:+@l\< &HAߌ&:|j1뼔%x/" !#.`?ZҢ@(@(G[(HpvRw%(OTSq8_D8[قި~SS|?gC X>ƻLj]g<(\1+[twdTٶxO%\PFYv#E".GTF}p.B-PpXw">^D&Ni>Fܔ^17g4?_#=VajijTio+<.4;lݐR6Þ<+#UCZԤEym>ۋ}C9-.:`wm|](:J}1z TO?-- Vףd#t*7{bpXRBm5zSV~)BЖɪϤ2!}pv>Ÿ[`@=-|Ox~jy-]^B!,T3E_'.Bَ0%aBEVFi )4K{Pla+D}y*_j~Y>J.m0MpꅈX!$p9[vSta?6Eyl. `lsR@?}%UVeg H'j? ݥxn%SiOZhqLd<^^2hЯQ|, sΚÉ[9c~;ZM|OK Ga,M>ڀ f砋vZF,M\۪c~ "b &z魝ToݵGPFX/mӋp!`r]#}9bAcߘBݑJk~)A[;qWUT=a=hNxgoӳa2mL}+^{5hFGZ>/{];7t:NrhMd!; g8e9۴`1:_:5zBMBc rn&jM$;i7cW8<ߎ1!NPyOs2<@P@i;%{#L _?"8w^sK "X@H'\ ycSw %`:X M%vZKh īOr9fz{RrnEݤYovh~2zɸdM}:'e}<3'8i~dNur+T_|KjBVa[m pf @R?)Jz| ޻mnM4.n6>8 xq4ݍ' ;+m/֋JvZ|\T Wƻ58 *EIo=|iDA/QFՔL8!x62:c9QNBrls l~C3Z.١f}"G=%tԯF>ope_*0tD +0o-SLgࡄU@x_Xr'Bmp_C`7y?Mߤ}¥Ѽ8إ.aK 1m%ܹvsSw/۵ߺu4d!zI[-׬{wp+ZM "aj}#<$i\hIHLx pHwmFz~t pzfj^^7qTeZFfu3S}k!Nb'|-XbORz][@eBj=h^[% wp9mw4=;gl# /QJ?-ddt8Eq_ӳ(:cC$A#/2 HP1^l岩捃CX<@Uئ7F+9!~Nf6ȓcGEFC$/F8?D~~b5(t;˻ PH]XDPFz1#O[7xv1`9hPE_rz{5@>-kF[|hl*W 'A?t\2aw'.+fX#Xv[纾hD<<~MHL$Ow)@{\g~3vgp 9P3ȼCQZ :VĤ},c~h~[e`?l8M/rz񶚼LĿ+ES`pnzQmrIne*rr>s% `n }c>#'W'x;UP a&Sb+MZ>05߳$:G{ӛ!$3qhF֦^w+lS^pSFp-9_!8v#W8Hjxpx"VB?BLUR%ٍdbx%il.cQANhrsV3ݴ m%NJXcJra|2c|OKZxܮ XieH jgl v>otEm5}5s+yFzjl`Ixj׷Z{vM/}7z10J]72.cif/P"d$/ғWZlW19j7sjyE]7a_)K~msR2UܧHs<3Vh-Pb;ӈPp\6bt2F RxlfK:&KlL53] }J)Q\b32Qo_ q[㖫fC ( ٤t|{&QO> (ԯ[–kzo,߰L?QK =*?`5>fG˴,Mjh _(5&`V  ^<}y|ѭWdW>GIC~q4~R\oy?)6*s \IQ3d800=%%O)ti|&GcZ/X,.cƈ:O8w?Wߍ[ 8~7hZK!< ]aii Y?Ee_QNRmq`bbrP_ap[4^y~cxEG/AUe@'LJsoh_)yPk/:u~ѩ<8ا1z}˨Mqkl9rZt7O|ZOJ@Pl9g<:#7m9jkK|Zt*C ︝k\T˳=*lRV34EKc 6o?%z-y_'_ :Q8aqFGJpo߄*2 C˹0δ _C #include #include "gdtest.h" int main() { gdImagePtr im; FILE *fp; char path[1024]; gdSetErrorMethod(gdSilence); sprintf(path, "%s/jpeg/empty.jpeg", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { printf("failed, cannot open file\n"); return 1; } im = gdImageCreateFromJpeg(fp); fclose(fp); if (!im) { return 0; } else { gdImageDestroy(im); return 1; } } libgd-gd-2.1.1/tests/jpeg/jpeg_im2im.c000066400000000000000000000026101245535672000174510ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int r, g, b; void *p; int size = 0; int status = 0; #if 0 CuTestImageResult result = {0, 0}; #endif src = gdImageCreateTrueColor(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } r = gdImageColorAllocate(src, 0xFF, 0, 0); g = gdImageColorAllocate(src, 0, 0xFF, 0); b = gdImageColorAllocate(src, 0, 0, 0xFF); gdImageFilledRectangle(src, 0, 0, 99, 99, r); gdImageRectangle(src, 20, 20, 79, 79, g); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_JPEG(name) do { \ FILE *fp; \ \ fp = fopen("jpeg_im2im_" #name ".jpeg", "wb"); \ if (fp) { \ gdImageJpeg(name, fp, 100); \ fclose(fp); \ } \ } while (0) OUTPUT_JPEG(src); p = gdImageJpegPtr(src, &size, 100); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromJpegPtr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_JPEG(dst); #if 0 gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } #endif gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/jpeg/jpeg_null.c000066400000000000000000000003061245535672000174060ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromJpeg(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImageJpeg(im, NULL, 100); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/jpeg/jpeg_read.c000066400000000000000000000016641245535672000173570ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" #include #ifdef _MSC_VER # define snprintf _snprintf #endif int main() { #if defined(JPEG_LIB_VERSION_MAJOR) && JPEG_LIB_VERSION_MAJOR >= 8 printf("skip, JPEG Major version too high (%i)\n", JPEG_LIB_VERSION_MAJOR); return 0; #else gdImagePtr im; FILE *fp; char path[1024]; snprintf(path, sizeof(path)-1, "%s/jpeg/conv_test.jpeg", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { gdTestErrorMsg("failed, cannot open file: %s\n", path); return 1; } im = gdImageCreateFromJpeg(fp); fclose(fp); if (im == NULL) { gdTestErrorMsg("gdImageCreateFromJpeg failed.\n"); return 1; } snprintf(path, sizeof(path), "%s/jpeg/conv_test_exp.png", GDTEST_TOP_DIR); if (!gdAssertImageEqualsToFile(path, im)) { gdTestErrorMsg("gdAssertImageEqualsToFile failed: <%s>.\n", path); gdImageDestroy(im); return 1; } return 0; #endif } libgd-gd-2.1.1/tests/jpeg/jpeg_resolution.c000066400000000000000000000013151245535672000206400ustar00rootroot00000000000000#include "gd.h" #include #include #include "gdtest.h" int main() { gdImagePtr im; void *data; int size, red; im = gdImageCreate(100, 100); gdImageSetResolution(im, 72, 300); red = gdImageColorAllocate(im, 0xFF, 0x00, 0x00); gdImageFilledRectangle(im, 0, 0, 99, 99, red); data = gdImageJpegPtr(im, &size, 10); gdImageDestroy(im); im = gdImageCreateFromJpegPtr(size, data); gdFree(data); if (!gdTestAssert(gdImageResolutionX(im) == 72) || !gdTestAssert(gdImageResolutionY(im) == 300)) { gdTestErrorMsg("failed image resolution X (%d != 72) or Y (%d != 300)\n", gdImageResolutionX(im), gdImageResolutionY(im)); gdImageDestroy(im); return 1; } gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/png/000077500000000000000000000000001245535672000151235ustar00rootroot00000000000000libgd-gd-2.1.1/tests/png/CMakeLists.txt000066400000000000000000000004611245535672000176640ustar00rootroot00000000000000 SET(TESTS_FILES png_im2im png_null png_resolution bug00011 bug00033 bug00086 bug00088 bug00193 ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/png/bug00011.c000066400000000000000000000006261245535672000164320ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main() { gdImagePtr im; FILE *fp; char path[2048]; sprintf(path, "%s/png/emptyfile", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { fprintf(stderr, "failed, cannot open file: %s\n", path); return 1; } im = gdImageCreateFromPng(fp); fclose(fp); if (!im) { return 0; } else { return 1; } } libgd-gd-2.1.1/tests/png/bug00033.c000066400000000000000000000007071245535672000164360ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main() { gdImagePtr im; FILE *fp; char path[1024]; gdSetErrorMethod(gdSilence); sprintf(path, "%s/png/bug00033.png", GDTEST_TOP_DIR); fp = fopen(path, "rb"); if (!fp) { printf("failed, cannot open file <%s>\n", path); return 1; } im = gdImageCreateFromPng(fp); fclose(fp); if (im) { gdImageDestroy(im); return 1; } else { return 0; } } libgd-gd-2.1.1/tests/png/bug00033.png000066400000000000000000014000001245535672000167670ustar00rootroot00000000000000PNG  IHDR}SsBIT|d IDATx|oeuy'M-RlǁIy[ I$؎%,u9ϼ=[Y,{ϩSUN__Wr9eX,Q*b\F\br9rVX.Q*\.Q.Rt:rj5yT*(J1͢T*jjUnX#"VU:W_VQTR?uƠ""JRKT :T*E^dV}W.T*bH2=t\.\. g곮+JQT,ɑ*J1Stoɩ\.l6Z*j%Y?:Z>/ԝ!4yOuST v@yW*V1LҘ( k46ݮkɬZ[*mk L:q[ҵJ%fYjJ:Q vvi9v,{1P>}$cڸImx?6ev'җdZ c)c!1zuH;h.wծB젾)ړԹO}f\܈_o.#m6u #4ztn2NOOc8ΗgYeLG>~iV8<")X?Fd/deXHyL`A% Ƴ\. AvE;4,*J%}&_V)ѐPPL."1zRZVl3KV}ۍ|1L B߻dw(=#"ZVa|¢r۸7/hĻww]$=ڊ8;;rf`n7j||It8<,ih FY?HH% I#@q0 (j0'Y?IĄ;)׃g.p`iN'{%\i .d"޾}b0LJb<bo&|؈f~?d2d8::*myI7qDUrwbIltn~9,?g̚N3%/$Y,pT*fM  I=Y}%)cƣt?N9ɨXd@b{Z- IT"3>mY*h$GqasGDDHcrHf2 ; Վ)ɘ,NIV ޙ1xhjPeC 9"#ap6&=*ȪuQ2cc$;D*)a݇R'JvOq|Kґ({dbUD;L)V/]3#gNfKIg$Lt?$ݺ+^5KKx\Bwݎ""aX,b8$H6JRKHc<1q2dKtk#dI:Lsqb|_"96ͤFZ-"Uծqvv~FFQr4ىfo믿NvDR,(yf޽/fE_r'9),0f(oH2<眜 5ZxbtWi'o 8N |ڃL\ޯT*$e[CVƫ;s~Olj(8-CQ "쿓~8+E4U +UKqb@$D߱NFi>է9"v$NI99Q 9a ^VDnΰFs}86.[x'y x&\nlctIdJ -}R(p;hCS>B+8>pzƬ91&bITraZٓ ql\բ^xNn0r8Ƨ~|M BܟfiUJ/$dܮǏqss1m:L:uNnq|p>wY .˔D(J!Dψq~|TUo 7!;ip|H@^Bar$ZƧ. @ DѩDC\U7d)JRC1hxtHtF)ӻ$j7G :}qN2i^ʁ}$ѵlbbGVo>կˑd~F'"ąD}+Pיca^Gi+.o績ƣ ' CR~~ (g6h'Asbx>Nspbq҇;Ʉ2T*0 G݃S ~?"="~(N AdWqY̦ZNW'LcɒA,TKRB\`VբkZVT8;;GID}*wf5gcL4>+qZh4tۿ_  gy_*dzqww}пKS~M pSF\}3yָA$z39^}.92;j遮\~o4A0I w>]5'NFNC&K"d3jAX/2#GXP2'Xo-XYkUt/Aru'64~E] LsD]݋rf5#H=^zTIlT3`,|tDғ7'oԻd>3ɤNy/D0}dgFI~Gӧ:tqB9}Kb縍w#k;A_#f{G㥽7uM^/$`X\բZ%6iZH`R^?I$3I1mKto>{c~ FDz8==-@yFh6dP߿m1L4N" m~X,l%$/^899իGZ`0b$z4FQ*b2Y (˱\#A-IIPcrvx'``ltH}2@AS֗}'cGpJ5 4b38|C1t蟓Ioǝ#S# Q:?w\6B#'$LL||3Ar%n@`)}E;$VTثRe^I{VxVCϔ/2%ai^2ոWBw$N iXTI%{KJzf#=u۱넉6pD7BUT*eGOVHVHMOXx:m: 'nC;|=1FDU9\.j)""vLӴ$CK~? "IVÄHku|[n'z1ヒկ~U6OOZ؈xep8L{ЦX LR?*rLUR8.jHGb9H޹ۚ+2v3'$T Dw,Y r8qg'=$7V1hLV(_Vy]VTs|(} Ժ'FRg@r%k#$NQY:lϥR)fBFHP&NʌLc-a`IT$cږro/Z{~~^$N'=\.ccc#FQ|1}."*b81+)G4ng=1FL&Qb}}=fG59`Rvkkkqyy~mwϣfH+v&ŇvC$ _ө;nO.p+ =QU>[Ra9=ջBES:FaSv5yFB!iɃ*"T*[Vi ~uJhRJ9xRINds*cVijE_M*hT*V4nUd4>Aҹ%,٩M9ߧ(IDtEwτYENRh@Y=l(%#&$ZlĖd _)e;`+mklܾN2X]=4='!(V} fX}JKNSLh_ɑruRlE86(L}Rۅ >-%0FLv wvvb2p8,'?Lh~\\\&فWvᰰg|aCO6Bu$e뜒X'na҅fTi҅1gU_^AmXVQ=n[΅䁑CT$A2ˌtg@ 4h^~@p˕VG0 @kND {BeW@8$J$=LXh4u.=SLD=Uy7gI eIdhN#X0h80uڥuò I2}I~r2=5u9 (9]DDlJWv^R NFD4>7#A!S:d SLܜp=ZױCj͊yē6'yS*޿WU(vnp2@~{b~mzV;9dGi lS5t:izZ7_JP.//Äg1~2`_bx䓸Fh4bww7z^:Ul E:CTv?#ZW7sXDK ?X$#4VB53W777 'A+jHu42^VO#xXY{@~рD  pT.)%jBPx $cDDL)s@bP RG4&UH(Xa/JM.rEN (d-J.뾞4)mA- }  \dԗd,;+i3@$1^)q6%#A{' * IDATjD`y86*m310A)S_'#^"zdœd\Pe$q.?`vhS"= \.<={ϟ?O2Gk8&>f7awMRDӉ~''' s'$.//0^ uqqw(3TR0L4VyƋ/Z/~ꫯb0x<訐KV+Ҭh8d8*9eF~P1}OL,zlKWcPrء>J|y.q@I/Av~xڿ˿E(+3Sǵ~HdqoZ.M$BZYl𘍩mU; 0{(N/ŭ B r_䮷+0!= \sݰ N`t&fى5$XTN%}Iy_ʃHcZ,i Q$&.|@Jc@gؾ ĉڊ_`g]ٻnʘ2xdӾIh|6^`r"R#e>kكI b0aƱ'+\^JJ"דAO7 m2i'(bv1ȒII'D;}q8Ƈbss3a+ :5BlWqwy0}O0hS,q&6/=kZz,l){Kovv6(ƫ#^?d1){!Kqv|_N|qqr9h46~_YVя~i=/^8rL,?`ӫ?XdwcƞdQ>+Nb I^;96sj4?8m noCb5P>Ee83 %'a̔0: & U A@i=l67itPOXHr_="$A`wlpPgV+u%SwbK$YI_ˇ2Λ13 an6"aLfX[[r*c' `IORǬU4&S:&l~T*`/ҡ=+EL"]i? jaTa2i$QĝÉ'B>^> AB299q]rv{3!8t$& S#2,.gxA|LhϲQm%[bc'>Q$l׸-p&}m\__sk.]z`~2DՊzux߿~ 91܆W7̈́lWsogIfN':N T*qqq[[[,믿xY|g7ߤ("Ljim뗱ܿg1Ac"S6FvD$cM1Wd 92$o#Deܥ}gu>s M&,*z'\a*rPc̃BU?r ٢KT2ldH"Js ?!)]&'/MD#%R4.9X@t0I3'׃)}G#^yNB_U6< NjI@h\V.DaLld!jXD%$n3qqPI>TmKa4-\)zD,.2\,iw Vc#yتn_)& V2%fw"+egF$A҃TP+#7;6h+M,ccc#^zqJ"kkkiL[gҮ3?I.t ^lR,d>!qW!m'gVs9q$WPcGOUVex9bP;ȱgeۗKN7XN2|mzFd#PN`"3g4:Dp3PD+Q$O3kkkv?:(+.??ԣK!./S7ꇰ֧Z/ȯt.ّ|C}a#ɬ??_1ӦIeSn6$gpK'((vx<8:s-I"ą'4A:8r%6-? A|~+vX.480a՗~ J8񑺦8plS?[ңG^&zh4l6ٳg˸),?FÇxmԇav`qE;g7PVO)[r٘ $#uN$BS3ߴstOr;7uaBA`(0 @~;1*uZMY~TU7Ӕ|ݤZc=Eg[$u9m$ɋ%n判9 Q'D6tN=?ELg:63xg$G :At39́G W}<WMY΍Ry+ʹ/:s/8p ~r9ɣ5oCۦ]k$"BjH\Uh"0t b6K9 .S3loDD\ OD*~,lX{m!61$O7mȋI۟ck(71K̖em< T qttPݫ͠\c˧0FDž%&nE1ETZ:99IdV`0󸺺W^alJX)51șubcBюjU_ε$ 䎘Y꙾=xH:U ЍH'f wetd!2ĘmјㄗS}jSu,ۓh$-D(o*(p\bqP,HBNr[*=TdtE%}9H(3P܌ e%yN!#9* 8IAבz5"+< .#F':K':KΞ藒]DDۍO1Âe Dr(ϋ0iSHڣV*G5qNSwzMW_;Y؈lh<68gɢ=hS͹DVcpdvB7. ^xOP\dӡ{{݉bɂWcu}.v$h,.//WwKȆjzNi&F63(bss)gN$!}+}zNek^OvDIBy=o߾d/^T*i?hv;vL8==7os""f1)ɀD2$e|E`H2qj3&|F_.~f3mssYr`r@?qNaT7Vi~8@D~FG&0C4rĝ=๊ɡg$]>~O "\4)>+h"Wb8e| ^>8UIfX61A/⡪ӵ\jcT*=p˗ WYFT-uSV 'IL&d'H6vh_$QܵH`I'^(.'Idi, LHhGuM(5!,GD,‹+j߫͒1u6ٱK+zk2Ǐ?#wV3 ҵ^p+RZ{||*yl[} 8ZVTոzj=c{.V\/O=AW$o?Q.C'''qtt^/v~:&rlnnMlmmnnnƇ%؈7o_\X&Ib&Kt=\pQr*蜘.Cvw6ʓ#P/W:gO0i *!@I`,G=-"lS`ǨsY7A):%h|j3G<|/IWdüu$azԱ/|wM3eHDvt|#a CM9t㸥=DžYB2)W{2aJZV|ovxڈDX@SS?.;bEs` '; db,WP<z*gҳpOm%7F\^ b$=XVidͪ}v L9f(%mT,i t: :NT*czGUT:n\jɅ~*hDghSL& T_}U,*JmcZ˗/c6Eݎ뤫ڊ~1˗/6nooc\^|g믿.`L)X$/x tͪt.tJAdK[.]f̆<Q6 [|9c{T2\fAzСz&H}X?^}"0 Ӱ-/9W{I8:t:Q>uO_B-)a(M&Q*TID`uŝH Ei4` SN+>e&9m]vJrȀ]گwb>Ꞓ7M@,_IV({;Zڃe W.! (KKAY1au8 1kmml{NUMh,JrԦiaȦY2%p˂t]g$ƑĚ>&>xB9;R;+uK 5$$iXH;fāKz}sqqQx,1X$ReɐNSG'ۣN/$H+&;R)퉬 FDza }9>>t^{3ɓ h^Y-1!Fϟ? dGzRT؈^;u}c4ŋ/Ǐl6ccc#JR}6NNNj6ccɉsx5+<%}`C}p8^.?O>W/9u;dϞxS82Y ITjB8w]ğFcN=x2+}|1c2DN7͘ϋob&LeV%KIV}XHp8uı VU"E4rIfNsOR Gê$<t(HyV/6? ;F`tB`4&%Qt~|-mdMwde[3HP9 dKr&N{%6 SI$T[3֪/8)C5c/gtt-W3cKH4Cj6>~X((NOO.jEI$uh7IQhf3ZV!1,Jquu*1eN-xE+θ彽Zwwwqwwo޼Io0$kr)[v͸ɢ&eFy"bq|ޜ'h޶'T;0QR`qڸ>w`tre҉u_焙t~ w2 sݹr"q@ 1nu=0h2_24 +Թ~LX$ $K7ږ9-'%b[ԥEV["&4=~e2rHyd[!r,ҪHw?qRy/rc0\վ\HJ$b1)ِ۞+I&axsNt9!#QdI:u"7kC;~{^q4%$Gk__A_fb"Rg$GIbh;O_b}:c8;G?s%VIlM$8<'2jYg*^/zg=t ~OH%OH)Sh$RYaVS`0?Oe\vccc#nnnb}}=UQyw}Ϟ=bv;V6778ߏ&|S%- R)=K9Դw{aجi;% ڍD}=_t|/F03R\Je¤5D OEf-: r18Иx>5~+sy$ ~J DVU5͘NtM312XC'hT>jB̧4z^~d2\.?8::m>Ai o&]hc$g5dCidNbYL音Wjr'oeտꃡi.003x֢k:Jپm2:Ȳk?S IDAT A&Pjth:‰@rP;\Brd\ 'ت ~'.O4}=xsJɂqȹiK~8]U~sI,Α>'M%h vr'V'ʖB{LTX!;&C$.I Ǯ뜠=y6׺nO&_+mXIc'LI"8Q$5ޏXy8"\GL#6f]"'׹KHDW "&tv!%J|hP"iobڢVӉr q|| [Q\^^&|VtP^6:lFIrޖB,@mmmmh4W^E^S*ݯގ`VN;;;qxx}kk+...O?.b}}=vvv $ȋarك#7ն*\ :/q.E}NQsC.p8!yňA9w'M~~GRHLh9IDMJ<:7-A3W[J[1;dPM=gOlpW : # pې>PJšP|V  4)7m}/^->s9DLup |0:$[0C2T]KW"ќ.[\OrD'bnsZ@;d.OϾ8 ,% Nh 2{er?b .usyna'":+&NPh#$c/a=!^BA:Il*=^.TcaC]+lt:qOFEAORCz[ȳ'mY",Tў/"www1 c}Yothh4(޽{WhSrPNNq{{{{{qyy{{{q||Z-U?w4 PٖÝr$ 'T 9*2ug7Eaи$TٲpD~*_8x4$40TKe<y :x{0a)7~.h2bUF9<]%KW͗HkϱRg"^yꋮnIPs;sϧprM?еnC9Lo/gg'GL8iuo+e{X++7ʏ;"_Y@O٪lJ1qc`vQ|pW:SGu>K;+) {kfuM>=Qqppwww_T/// =,K6{s(7={V`c9[!fCrabRp1q_6m[R3C+tR-89.<+QƺF2zaPS#R -Ȝ\($|LI6ɧ>}>Lh $/ShGnfa%pIC"{e-Kݐ+⹌>S:"y$ _=:wjK22 -ʂDf]p 0G$ -?'$Ŭ0Pw?>1xI $n岰҃zmovMqouU1gphg~wb1vOqPqLH/ݸ]:tY^N=!r#pRk /bV9mv5)#3gbۤ⍮Twi,";2hvHP>|P0y_.qxx^RcmmѶs7[ {^lnnd)[RR6Ftz!jlbHUx=iWZ-b8${L`;N\__'viju?[󸸸H4899W^QFrV~s i:G>6SX苴ɊI|(_:qˊlc09r.wR@OLibj~-AVy:rS^S{N~ B5@\OY99fu^Ƨ{+q؜PA<ItONǞА切#[Dlr;+L$%Iv8-S!?8$0R9?|IiGă>5[.a>J`i|Ps'NQIkioz$wa/]jC'%NuPOQ+ۤ~8R,v%_2y11)JLJYl}fw|3Г\N8>'L~yBË "1͉t 1_@Ś,`1l&l^χig<T_c̪x^zN;xL[V'J%666Ҿ^yQ.ӛ%n*ȵZ-u} _凣(ɲ^ǏCqttv; qFzގ>DzyH깑dPɇUXIMg%X}(>W-qdXrQY 8:}XVQԍ> BE6k # ^!2sѰOKjgr$גHq*uԋ:8r$R^]9fcd H5bJ8.OxJ'=QҚBڱNdsYigN`yp[rpr2| ^ѡ_V}nl~O>Fĉ]]7?{JGQwP7(?Ky\,W5^ʜM-b4JczlXj5h888~BV+<>;vwwI(ӈZ}K`0(PF;)q}}rL^V!Biv2Ǔ#O>>|}}=c{{;NNNVZA g\?1;V,$/CDY'Oًlʷ$ab*?88딴{?z-+{ 1|9K.(HR0ݑ U8޾WOwsjVaߩ00zEAFS>@䁘zwJ:RN;N/}AҶyF/ƒWUG~Je$I׽=8g'Uv@H#3}OThgjUx54666 S~~~ݗ$ػ)J OYGV|v]Odoe;z[>1 Twb;fe:o˾3f1NLBʧ{t_?((>DBd"b$m0C#VTR%qyyd+Y,wHjqvvʫ ~(Jӟh(G'Kf7*R%TIV `0Hю SDk.1`__e#8%q|>/ݻ#VGU#*S &jL|*&S~Obo6J0\U#081I"-CJ2bKgvr`NnuU+V},NOCALPsJZ}p; ypО|ց6%]xzkXWQxKOjWxOS.ޱ5"NZwٹ +9lj2D9({`bA`H<$M=$Rqɼ&lÓqΘJJl6djᰰBn7ZA C|Q.ӛJc9*o/a$W[a4&Iƥum\]]uD<{//t/m߶\.ٳg1O>)/JO?h۩//Jqvvϟ?fFs9'+8٣_i)\䳳$Jdt.$ =gG >_O qe?)>iRn㆜ ,N?w` aSt:b(0'(NAځ:t'q5ux̪5>ڦ 00? Gb?=@CU-A.\(cc >3ډ%XƖK$T!crMcU4u:h4J|mnn>"jKzL; Ity<9yaWD{@^T-qȮ);ڿWàCt_ϵ#нtmͫd3qֽM&y@TÓQ݋˛8#*a9c'XGŗ~ۉ0;2Z)x;OC=?<@  N9c~Pi\ 2`q4մdmRN8EIBup:%Cv ';:i~4Šz Z'[퍕y th|e<$׹]9,3R.ɢl%w\A^Ag.Ko/b̜]Pԩ,#_K]2= O666Rh6 Щ?Z{ppȶ:qKXkt}/x>1k}}=-o]V=|'Uf3mŧg/5b[_xvttϟ?ԏ/`WWW鍆?1*JzKmWkddO$K\ |Ar͚"Ny۬ɝ;JRx4a˟rk/KUҗ)d2FX,ҔD-$QI):sr \.9>7OX~StP'c\_MG1|*\>T 9p}.ۢ2ӑh  .gf3[ycVj#Az"AN4-mmXũ4"Oft*AС$dvk]G? -GT%DKgY2IcWP*t6<H̘1Eɜۖ_k>$z/ٍct}/qH:r}%re,Jn7R;t_>~-".Cٗ0>v?r1S㝞yxR':;;U5BwŇ[oܶ&o4&EV(*9korv͛8<<jPV?Nl8-'ގx\x(677l6t:qzz_bF<;;gϞqJwvT[™W[e7L|S6~N(e0Cڠ?oe$Cޣ1H*e'դxWWWq~~v;={^ _ɛSPTރǵ=_ n<qyO)DZD{N< D<뤃{eĆm|>Nk錬SĄa>>(&Ahp;7`R@=\7ۃdQ6}O$(% L9 ϯT*)xA2d_ /wۋ8==GOZ4@p >Қ>\mD?'?~]X3hZw;qZ԰hD,Sة{WUJ[,q{{?C6rww7~󟧗l U6v11G<^"ILM1#߯U5ޓ),yTz777ݻ8??O/uȋ\677c_~r{{*%Z˾X,n]ڭCy?YJ%T*WuGMVo\ڊJ'''^R)޼y?l/~񋸼FLylmm% ڬd۫=[.{}E)/LkF;t :ˋ_>fKRz;'rNsMk!W=: IrE777qsstb}}=9̌$>Tb6b IDAT 倈' mVN؏OONG(p$SZ{Cm WXtBr!2}<1! %>~ޛI1T#XQ Ȓdt3P.{t=2 PVٚlvB"Zɽ|777SKTJ/>. 񀉿ێ6N6H>Eqa;MN#[:qt;e>IhG֓nnn&bd;QJtu-9yPEuggTU^,qtt)j8;;pX(Fhǟn!XDA¤qKhV+JMt:iLZ0677Ӷw5wb1k6xy#wD>kL<ߒƪguazbv7M/˗qqqWq}}V+v>iKG89ЦqS΃TLK$=4#.dmʘ>|-%'1WPdXt`"\9N5(dg ~/}Ɇ (ɃcuR?r^cgA{/3#?ұAk~~^wMfhD~1d!Ad7:g m4JYeo4iu%ivγm=GV,lg^6!/)hW䙤Tpxxr#=www5==%z‚:N:ijY6f0l#Hف(Z\\L%f />=N8m5lp8T) @\ֻᆱ/_NCΎ,SV۷G5A#  #H(l/f6#qcf'v sFpEҎ-8}L&,)i)%i`Hp7~fݾJ#@^esGJffO!DM03nǴ5<5ɺe}b{6XΘ,<==ׯ˗̌dOyI'K:Hs+C=7̃<gtv3mdhc~DYa?cüӎvssst钪ժVVV)/^tv‚ժnݺ@@;i@҆wfk N]LbоFٗ` Bڦn0Lh^~H`| b.I>zʙ=;;uݴs}g|^Zhh k8p֘e_Rr)U*dgfffT/RSҍ7Q^,옾L07.ѠץR)6=Cg 62Mb9Lv5h't>"bZj ~&''Z7nP(W^֭[ y4:ѐ|4<`, H4PeGHQȝpJer; m2Ὄ"%vTF5}\Sd&>mpR+`ȅ1SmAek8%]]^-h5gK$YRy.].HI]rEkkk,^tK]~6qXVM0" +٬<6em]XQGy%9޹ BA|vwwQt:T*`JjY˺y~ƀz{.CL|<:QN : ݠlXƢjssSN'ц~rr2ٻ*Ԕt=mnnIxExK8P1NvHޞ B.Jj4iq4g]ᶣrٗ6!P>el~? eg{k{{[+++/~%?ݻwurrFl5my,0o"(A/e/{+:^[Ϣ|3QvGb_}+Cbzcjj*-z&&&9&''Gz}tmo3jY;K)hD}iv{I䉉p}47===x`d83C{?Gt|ȳNg2ҦIKf]>g[eYLC ͳ`0͛7S%---iuuU?h44==>Hw$倴5I4jz3Pg]FfcbT>m4gJ,g;6| gɢ}mu4^ˏE%>p`5[dY{ayϵ]]r% |=H3/E۔'*"; K"1!3~Z`TzLϓ1yp-:BG(6zNBNĨ6lޑ,7#x.R0oX2C^\ =">M 8d>ϝNo,/侇4/"pzQL{ڤcGeSyeiiIGGGիWvS+32e#'=|cghwDϩ+niCwcۦ}#ٗ{ 'fRQe)U.UV\&)@1==bhpwG !3/{#>rb!iT=wiT5G%e^Ttw=z41p?h!~ @""a+yL`pVvRN޽{ 6QWBA333#( ZXXHX,ݻj4/_${?pįx1\0g6uGCQ~)mNg xK}~'&Y~nJ4/8qUM_&ɛcvp:88ܜz-?5[oi8j~~^FC{{{|][\\LSt4Lg&F4j" PpEnSМ6m0Q`,}qI1) r@*At=K +=̬1+sֹsn"fG"͹A%iFi4L4"h `-щG d뭩옟~?ݖ/(w~Iɾ\m4W?Qi<~ΐ0.st:wF wOcʸǖʣ-r@9 1.rZy Ŵ[BE =~F}1DPIs%sC]5bI[eͦvvvFʭl'˲LnWz}dMؘkeee&}aim e3SSS)x0H426n511j,Rv\.%/i:$E:[x-]zUY^⋴@֭[,mĶABO?٘BlgYǏk{{[Z^^NnJJ[JiF.Hsfv)eN5˲z[YgᰀQH/+.xZ//ZfM ^,Qqӌ2 d02'%/񎁛?'0 D%]2qʞ0tEN~FGȠ2m8nxe2ʟz9C]~]Ϟ=ޞkS\VI43݇(|?7r{t6q|g͵=D>R)Qʁn3_)T(J@Rv~`8G\ ES>w0g9}J쓯u#]XB%)eW2mnҍ:88?~<p ΏB|ř73p/7;(c~uj8HVicZ(R4hb0{'&&Fj tR^:])u:?^x7nH~w>]V|/c+Ϗr0aF`I`L^rBQgHk2{n',1mR0㊄땆a~qqQB!ezӑb1й&" 6GlRQ#8 e{ :ON9S`}๯QH:5>l8OG̚>7:a7NGG:Ƃ~*-AFAi-71Qu^i( iwXaـyDΔmF`1<@1GNA eQ,_\L08EKYu=y$,JUGKeOgV9:) g_ޓ t y}|DbAi~~SX<;,.4q#Ҕ#=9KK "g? Nv ?, IDATd9f|vpvJGv!O<Я >-}&,KtGGGjj.L\U󸼫dzOOONz}:==OTW^#m%8==v332(,JG q,̵ߖ+us7n=ߴ,k$͈{lOQ'd.+\Hn '$1 g{[Jjuyx}rrR^/~ u]J%wճgtM1>*9SΌ/k(2]qfYbZbe|Ox13y Eq윶$\hY#Astxt8Iذ3, z^|=}m699ZF1b#gk M<1 p8DStM,Ήv4 jillLFCz]RIwM{XIMMMT*%eH`ĩ`D' g/}߱3bLx7}{||t=zHGf (Oy;hDH;Hcϳ](\|r>99\Z(q=3H%gڎk_fS_ݻ{~[NGZ-:>|bbBz]/ݺuKJE333i"4;Ny6c<<Ί~&[s3ʶ(tX}\ؘ^z%鼜vc+g m *Ͽ&Ď$ŋ*j4z?grHtGB5!}q VX N$!p_AW}3 &xk:#+۠+G #8'Cbn,˴N4逼#h\hLXF`2|./F%~5񊎑r3P M3Hp ^THu:@GMINCL]}]?k˲ҫ IRS&fqq1hkA|px^eĠcZ~;N9HYͲgA?(M㾒.vizӧOG #6!=Š/ώP?.o,L@7~ng~eYO\8tͦSvWә ,^;`2&&CE?A%]i˧4Yn/\Vp||<zA)}z-i x+ UUjcccDn#p fr8[X{MsJ POc 8˧A =q%LE;֕8`#p6M%Hܣ#jrrRcccUӧOZy?t(2!*QL`T^T?KOfSgCQn ӧOurrʋF! ).JMS34Zcg~@zŨ4t4y-AiƾEm>G@༶?ʓF{4әEEǫj.rl1x1q:/fo\F<:I].t`*Ji||\ӚO;<Ig-gh 2p1cD:: `tb:Uf23fvwO<Ghw|ro;ןY,coGq6(eO3M|ŲY(:ug{{[V+c=|0Po6998yQ^7R_h&d[@\oMLMM Gf@c@cm>|7n??0pr]q)ᡞ?Oꭷޒ$]r%/e:zCW`Ӗ~6GJgtn gk="n 9ou8qLvcáR l||\W\ޞ.]"2A@T f3vV=F+3 J/gh8"8irG@6I?̾ɬ$ԁ%4xnP(@0>ಏBejul$N%QZ-q999acӕg(/ frG FZFpWe7[""۔E:BwjiV~ }sQ3mFA9e _b1`{~rrئ;R*>oI<zY-] w(oSp8LTxL1cKADD{t$}$%j=k۩ӼwąuwX~jvvV>Y933}ߪjiXRIԕ+Wl6L7# 9ke'*K d)|c`Ciڲ߁{lqd d-oc})`e?6-%*vif l\f08;&mѹYJ $F̈ZH$I4Q7 `0H(F8N6ȷCvOSBtd mL 7#y/O;1af43Q4=>"fj_ C)C:sdp0sڇ<JA#9-tɴḇIC:[+w8 nQAu )/Q&8F˨2LfYd:trr2ٿk mG:NjϺmX>YiwI㠙Gƙ::Tu:bp&;N:XڊhݧTTtk4;;d5_g~u6 \hK#giƠ`ooo< ;qNVK# jZONbQSSSN:ıDݍ^sVgDYe?18˓`βicnnNvv>k9,;;;y>|VJ:GGGё$>H0cZ,h1npܑu)UӉ|:@L`N]Iպ1Ɇ; hylD ׎% 7Hs90eґr`>bt5۵!a=#n:<s)y>X ^i_L%KttvpdSo4*#zLO1s@:99 U*7`dkd3Qn{Mۨ}n#muM]}tn'''-W!=")cgM~5m k4i,R9N;CGV׵=bK?M,SRI B#HkgIDZnFy Lb$ǺfvRjp^˗gyt^e޽8&&&RB~immMKKKzT.3u/grLl?&Y|<6&3sy{=&.<==MxD ^._qrr'O::dm 4 >}9zaɄLtj1P8 m6JvújFܜܹǚeY'*2c&PBmv 5y#5 - 1`$i$a@KDNgBYT6X puG#`zߖiGuߺ666&||||dE1rbFbK=c^љpl Lw|^t1~Pv)oBP(^sK9 =u^VMy6o&6:><?{QS%_bnf|u/~OR'CMLLLo& ~:ʈ}{cyJWG䫳+v{dolk=::xڱkؘ+=x 'Fh_H%{\#iH[fb6P"l'9Q /!>fs_%ʝs >Nн|NtTF'pxx6 V0 3OdD}SSS looѣGmllheeE|Ao}Kj5-:O_2-3Ώ' yF; A ̘t1wQ1H2:s[1cN@> P4Yvx&f5,EHK_lؙe[Nca5-Lӊ@,:|ƅF46P?:: XOFRMCjxr$V41XiYӛ3ikLUJMLL5??dƋSHe32tBQ"Cԫ"8Fݾ}[/^Ћ/ЃtFa)d`[h!@c{Ѥ=idvTﶜ5>>>N)S/)mg˗I6x }q~ei|q5&tt1ηɋt$/0xn7Ckzz: -mmeg3}fffY6gd8R#mzmY3x;<[D! -s01w{z6664byLP7~G=fcpbPA=v:̀m=,JJ 䭭*)sFӀuc0ri-sm{w2AGvɄ(gԃ(׾^k?M廯>..H҆?z]~" /ַ7x#%cNNN4??x=99^361p4x< LF1ޖAt2!gx={EAr A*)K{t‹8hLBffr"3vSV2{]"֮T*`"M2zzfggS p-//] kt7Sl 6f;NWG%S!&8/?5(uܾ0"b. :I}'P'g&8/kNpC' S΢᱓<-/̌iq2`'lhh}Zة\H>3qrr7yccct:iZ._LӁAǖ)'1tfzSͥ`3P v)t~>.#HF8B`;. mݮ77+Wj(K[~K:XvS>gb*qLٻoޞ>&䤎h44664ŐtQqiXBaEsAeNQ \nf#)LGV,m3z&#b9 7щΟmA7 Lۨ,4!bb͵e0+=Ǵ$mxE_|I>FNry5vWB!LCnz4T~ߥKtʕ(ri5TEl+ʎ]v kwnnN/_Nc8<A@^LYl}qi?w9 ],#4{9f5Myt̶]>kmFsٞ}/t?Sdft6K?e i.xLr˗/##EОeͦ>|tV_Zrmrppz[eY:tv)s~yAm'S2Ȉ+ˎ1{[,ʐ3[QQ9g1[Hy㚄N'>OHg 岦c͛'OngϞΝ;>ֳgbA>Lz]B!~^Z:/33 Wi̷iv\Ik=~2J &LG oukyyYɄZMjă4pvyw`?UP8EIg'MC'Y>XgȣߛOcm',`EYn:8'EM@+̔ Vr>j|TԾ x^,Nq'@4Ynd- #Nue-,,۩-ӁE3-}-..jmmM?dߦth4T(477۷o~vX[[˗/lm"`]fELs>ỴXn@Y{|btb `f0 <.>+W/.2v*ڬϴrMZ>0S lwwW_uȻ<}T,K~ٴ f]feV*Tvbsi&yL,̦Y%jmmMsssjFt{ccczoVGI=z4qmnnDuٳg @z'LGfϦL2$Yɚ73]24^_0X`? ?^_G /C8#Q-RIK.lLOO@Ku{&?\'''j4Z\\L[z=UՑL_v`aR,*i% E=LkQA]OOT*#% }NNt@Sq6NM[ Ģ(E` 1[sLy`8t)4J4!:#*- }4 A3i7Gk[h@6 *f͢}?F.f1\,g4(.m}nW8鼌.iwMLLZJt||uZ8޳pK.Y^^N*3fSVK;;;inzzZj5q0o_=|]S!Ў T#QH mk18 }\#}yo^`8<-vX,jkk+m)ke>s=z(EQ }͛]rRN#/=F&h) SXLG?~V=kd|OhNOOj˚IXass3pVj-oퟲ,KAD5[[[z뭷txxEݾ}[P/_֧~Yv$={LnRg}_:99ч~ZEL2iS69Œ`r6ǡ{~718|~l?PurbfM^f4 xňWtbf=Ƽ|F@+SPڠ^]tzqn2_i^I? 2YEظ1f.4h68.uy}cv\5nME9?/MpgYFl?_ycJ%]vm3駟iJPH/E ŢyL KN:lf6STTG4<\E0b0u2:Wb5MmlleW_|O?To\DEz00g|~vbb",2@n2iV~DZM'''|Ϊ\.kkk+}yM6Ƙ' m-..=}rUUT*`Al}￟ҹVwllL{{{֖]xP}{v#}$ ˘\ʀ/Yӌpۦ;(J^x:>/.2?/҈;sq&!}O?4,˒%GKbIg M+ `0H{/:Eo:c¬ v& fGnTh4fVNFp9h3KrTtGgbb"foAM&Zۢ3eFe8,r{+|D<C:}¨pT<#or8h~`6TtXD?$d8a~15$/<lg XcicnG]srozEdVf8Tb)?z뭷t}/忤AT׵v?,k  0+]:_%o;h2[(wM-˲Tf6@(CnYz>Vs_q6쭮LG\N'i @|9' -Xx, "w1]Vڌ Lfv|jj*DІЎR~[h4RtVt-|Mbi133k׮ áNŋ￯T*T5333θؔi7qe3ab2%L"ѝ]˚yxppJ~P3D~ K{lzп6fґJP^ji/D ; ujVr~R=tA$oZ dҹIgӁV++*IPҼΝ s&:>4 fM̩%*4"h􌄧Y "a@T풗. m,{-[g[ =V&ՁC'DzOfYd=gtn $5sq Qw^66d-҇:$;r陋gy. lo N=u. X_H+kssSjUinOO&4===haaA_ƍ){E Htƍ8w1pxV77uֈSs˩;;i796c';o^iS (\q?|p$e>SLx'r=gLc\=իWSJȸ 8`9cFq6 4m}l=iww7w%u:B$Գ馥y~x`0H.owW^z7G%>99tBnj޸q'ʲ9#b^?0ӧ~s2Z?ovI%LҸ}?a/8Ik)A:"b<1/9h4===~6 |,KYVGzVHSP(D.62ҙ2c<( *9DE%d]W4q5!mDLFNtyVK@pԦtJ샃#45ȣPI,P4/nncb@aPm-O;xq;+l|MsF42ym F7x08/ɲl6'@<0}I/be&ԁH7!&A]M'Eۗ )#)8S]y3+9:NZ^J`h0i]T^tW*$933I.]io?h$Dzgffft =x@cccvZXX£dNT08v4fO6y %|믿NAu-ĿcR? gr@M]OrYKKKj4vEh1O-tLPVt{jEhҥK4/RJES-Z~m'?QbxvRhiiI~?^R(mW: .KE]|9-.Bjj B9˲[ RѣGя~?B!%'? sf̩g݆)iFW:'v@QJAg$Rک4szq+ˎh) zJ,-..&Yu|Rl3iBQo333iiHLozSSSlE/#p謪I$dGQ@Q5.˂E#B G&SAx0)i(o*j\:TǺfO>$P m4߉R޸hȻ?;_+ϰ-#۠~HR'gGYicc# A덣4rZR[I[(Y5 ʫufڦ&N P+29HO_XXH{H҆Fۯ3&h1Hq)yA8uut5}ZYYџ0-4 IDAT{޽Orvvv_jzzZׯ_O@իWҵkt}IVWWu][ϴjuu5^4󷷷,uմ & VWWG7oڵk뒤K.ibbBϞ=SN'>֛FSq B㬟7=:::Jq"]4rA6[<jj5.L.VYVNZg3LRte7A)mիW|GU.U(Nv[?jҾ>'#VF>tf~~^j5%>icLL˅/&D[v*`,?oΜRo9G/6󅶍"$|ʟkJ:;0βnWKKK)ǩ /,F*)f6tY6^111,K Cx- NbׁwKJ|:<X+))f8)1+g ;(s[eGӝZb"* A*4)%Nw6X,iM3(6z)=/0F;_v-F9 C]M@33Hw<-y:WeO{VrE&_~&W^HvtB! 35rAz0Z_ʲLwտ7& ^Oo]7 R`0o*5M}Ą677g;HZYYQ~ӧ:::ҳgtujnn.prttzc˗/nU(TD~_F#-eO3hT*ɾ{mZf]%EMlND103ΚKJ_1v횞>}XxȌ>jɝm<Θ*Ns)IC:\֍JxF^؎e]~=yn߾f~Oj8H㶢Pѡ1+L!˻Dv d3_#{s=1olo-A>wpOpEv9^ 3T4˼#rLBBa$/g&&iH  ly(Lr6fQC2N;f݋brvnvt3,Sxh?X7~UPkOyOU,oHpxdz72s;z}$tzzzO 0án߾۷o(_YvԾgdZ>|K.=mnniuuUoV*nXY@CݸqCJE}޽{Oޞ:._f.]m/$@255jt%kffFyHBzōN4 iq`>G{תPb%aFyl)Qeq9v]_뚜Խ{ϫlj8=&&&T&#Lu~TnWDm9JrN&X"g:&\tF*>Ӽ$ӟz9쳏74|߃zh[97~'&'724ZQe9f:QJF6uH7 z0{zV˗֠x%%aezTZ u/~;vzO>dҀ~F2ĕ+Wh4P,ycpa9y>>G}deBQ,c_~V?!:>677W_}h4V+d`J) Bf x <2h|(O;M v=Xy@a KU*}dB4$wpUxii rv{$?YBRB2c .\,CѰT&k:^ [b HO+X|2^rla.CRA0D6p8<DUULMMamm ~H.10o4 g`ԿjUFc4sy)Iq~rWD7>~ECu1MsU('Tym qpZVHˣԓhP5J5-;gjɶsuS˗;I8(:999@S"xPpB~?QS'*_־h߼c϶ЉG?MrsIW{ ) Nm"8Js=fT3 4P&qrNT~2"8 1Wz>^)x7Gqڞ_fA_ U__{zzھ^#bT-=hXbhF^<<߿L&iS??Aƻヒt:\~xwDpMT*B!8/#??n1==}c釘Bj}4M D{\ )2\S[+xyS,2 2% :vU}zGRpI@HmQJ 9g9Uo<#3<~?99A*瓓n[:1:VWW 3kX^^F>"_Bt)vѧS``hK*UѕxO1}=o~}/X"}ɴaKq\v3S)x" Ȓ3d٬  FEPšnSّv`08NJDTʘo>javvF6pPT~#;LqQXH w^c"MyjY]ߣ 0 ,l/t};+ʧJg?w N=S뻩ʨr ǁf~WM*oܣ޳^ސ)z"^4ӋA*/ߩL( Ud^1~Uwu|ۭhoeCĈQ:_;/}2jo$rZ PNfD"XZZ£Gl{&e-޽{Ɣqy"ү:8_/x/`[TCr94MdY,..)˄Z,qxx\.s!ɠ\.[9c$IK9uR@2`@\+0Nwpp`XS7*H}|O4E,2ָ`tFZLWC7nN5@#Jaee.,J&FO /`0ЩI 0\}Jر H$$$3VQVnGd1 {+ytxyX,6B)plX|:?4-Oxggj7dpvt̐Ϭ 3cH-:q`FL\^3+ ٬)O#'"jt2n?G"\1V//zM 9hrۥJi ʼA˥~ꤡkd(0c$E]Ǖ祹:11:]|渉 2Ǒ啥ܮ@ `:*NtwDjQu@SΚMJJ]qePhRʔ:7iKǪ3{9|8p_Y 尿mS[?  CcfggJp=}$I055bwyPKKK(J㘚20??|{__6ݻMA˿ tP,199->99~zYX2S8:z.]4Rgg8>>.qu,,,ԫs%3<U;F9+\mp:g9"JCժqe3fhiC%}l9z8)"6>ѣGX\\DR1ʹVeUh錰1RR]!Eƍd %O5ﺢ^f.5 ƥY1l|_X8qbbH$2r,˟S&A.3 &d@`XB&tj ?i|_(4,͝@TBӱI333VHO^%;'WpeT8ʴi*#~6nyƧh[(Wo`)3jY y_^: |Mʜjk7>Y>:63jP4yrzKVvm,U oe0(e}NAUP]eH//z72; UxjUhH$gK}c\.g`&Bfggqmz=,--a`7n`zzD 0kH$W^y[[[BjzrxP(nb>]`0T*|~l68|Svb^7@#|>BFVmUmI}}y4Mr9_~vvçBgl5h10z:jAP@ݻw{YN|:|^ug?&G7<'!8Q|Wyרo^c:W{5)VW#ɱVEI=$PN4rLiԪc(PfڂnRVYu뷶mU[m}>4Tj } ࿯`s^^HeΟWyޥzwnm?7 rY xrggT*!֭[(8s \.*.\@ 릛\E]]]ERA4;Jj.\ TU,//T*^cmm8usno ؊  j7@/} P~),vww-OV HtϧdK+E3*D->8T~oJ?u\Tʞy^M ә<}7 YTJJС8UN1|#X]c)g~j5^uLT\#@ݳ>Bu]<U^_ Gujci@yi~Av Bx?WZ識Tw9;y>A^gGGGdX% m\^O5ejċA"vvvn/" YED"12_;Ξ=h4gbqqV @03ܹsj٩qL=åtn߷X,)G?ݻ˗/cbb/^R\w/֭[v8OeK? ; Z%3Idz:t*< wxP[E(&@*">9X ziQs Tz5UϱT*X__kf`aa(dP(˗/[xֱS0,HЬӠBh6x H@BAUޯԧz ^GVu["#۫>xeYLLLX' ?xoDl/n0d}h>H6:@,] {꺫 T3:"+ QF;/zDE 0)""]?S<©!:i(*PM5v?:~ =?#󨬞5Pj˾xЪJu@st̕uWâm>C71j@Ku:I}e}y ?lXߥS]QMeFg<+cL7O(k)h>x}ܥ+sgӱ2 gabb,`0[oz <|ЎP֕\.h4t:mgkx1]wy.]:vwwU$sdpTU͡^>b`kZo&&&_|TT*=DQ=z9ц @A0TδU[S&zx}`s4E>i W jOPia{{f;;;V:XB޿Ǚ3g077g͊S96 A?F:ꪡq懰+cҍn~f9RylTLsPAPJ0hv* w(lA\6UJd<(N9:~K$߭7p<*K.- IDAT`Qh'^k_tzͶѠ|֥nՁ獽q:mМC{q:@⍅}Wexy}QEǠ=>%1ꉮS1L?5ci199b`p  <Ϗ, Br oƘ//bss*:?~}<}b6771 9j5ĬL&qppjFL&۷ocii JJr9ء_>(YmL}<;pz@ `[}gi=|qēOAQ{AC&''vM}m>BI+I);= X,~-] IxyvYWW^q1U=DniDF)P^ާDW5{m0.W}0CGҮj! Ϗ6ʂf?z)-˶eɤEro}SYt<8o;}@OGtSp]q͕ I̶͔ezMC??0==#;g]D #~LOT^2RC\<ĺ40<ȍ;pw*QV3)X]!QEJHQVSХFU%Ré12pI:.Uz0:}g`ONNypRFgD2\GYw4dܥVS-߭3>P`̟U,] bFc»w U(B@459JJ/lѥiSzoϿ9mċv||lyC>T*O;wH$AXIe<0omm ǸwQ.QT üm}˝NV>occRFt#Z.fggŰT*l6zJ%y̠Iߣ="B!#QU?gPA>ŕK# 0b3Ծ)x*`R {$4-S%L`'IurrVտVA줎#Gz1Kw>f'tnJ\Ν<٬<>>fxV #+|-hJ40yICJL{n֛@XDD,C:fffL& pmR);ibbž:{ -o:H[e<B6Z+BݻZ SSS#6]6WGw|^QgTzf{63j0}ѵ9g%.*7$l3ёzz [\ï_R'gɏRrd2CyP()z}h6FVC*BV,߿j Wzn>/[)˭jA6E\6VTUa;jxJrhJ̌mzZ租j 'FHR<1K1X1geuީ3o o^c{{t:#%TL 0r`FA#?WAyww*c\?8xJ/:$]#S-%ra*ёi|h-:-a;LbrrҖA&.]7x|`0<#, &''efqE,//[}Dw\"2҈j $&Dpz+MRNE8N (ԃe0v㎵Qe`dO4|oh4r]2gxFYeOimVt:u! NT]zK^Yr):. d;02U; U:F>ND"aNR`0TY|'3]Ԕ eCu,RPVMT~뗹}u@ 0o_Ç6ܻ x)޽`0hQwÇF177}ÊNA^Ɔ`n"ɤ,s`e>iLNNT*X,`$Td괲:gF^:TX9gYzUS(c"i*y^}ZlZ4W(=ӗiVá888jDH||}Tgy}5eF8GǛrcͿ?o 4`bl6l6k,\A Ià`8 HGxqq: ;`wwϟ$Gzf8lX2?~j^z dZ dCDz T2N._L*ᡥ}[.\354y FQ8|Yq&tg|tˉ.{y遭N(=@%g>w钋@efS /5Tg^vaP #AQ t||)HFjD|5wi@6n,U4E`G?=5$Ӹq@Q"H?Lڮr4%I4V= p||lR ~&&&bBRrgxA# Xck ˶ un+ UXp]]޹omm:ffflcnnΈb|gq.]V[nY1+$ ۟dp}lnnhR9u1yssӂ>;wW:i?yм_ec\(mf7Õ(nJ>r08%oì!!cwwRhI \~dBa$1ÍT J#Q6橄B!c"Xn%¼1f;GAt}*ѴGA ҩ `0h2SۢXXe7A' SwSԥ(ϔ8+xd[.76^Y U<@W/3:*'uV "KY* ፰ϣ`ln# ^T vFR{FQdY4M]'''j`iwrr҂|and2+sj42 20Q3 =6̟^L*W 0\Y,&I50޼y>kf%٬U  NzA&"}]#X1F~Eg?!fggīBc~~FH&@DP&i+o{6O^[(-c1ֶj|l;擓KQ`6ȷm>@W_l+t`0]RLmڟP(zJbJ$h8>MP۬{n2a3W;XmԓqDՇp(W +W(d2%[aCÙ|+Dcq VHQB裏0 ,OjT*SX 'Jnd2(JHRX^^ܿ=B<%I;ם(Hu,[4 j59sPVl6ms-8+2V8͙AzD,/oh ^5B{wR>{}3uYH22wke oT!HXi L_5k5::ٴ:9|7L`6'MV7[9"3mi}ccY:`BuNcCT*GGGX\\D6E S~vrrBL&f}}dYbrrl6|hZ_K[]Vu]t:#s6:ȪBJEGGGHӨH&#z]p}dÃci{3m]ٱi>w-//#Jakk r.wCL岝vY |͞ᅬJ9̘àhp*vvv011ylnnK/FLLL`rrtwE"@ѰݻT*e J&Yoo^~usnFqMꢎ2㳨gϞŽ{nz #@Vaooq~ޟR籰l6k)K'7ꟀaehX >Ku)8<,ؑLo mAt܂`0JNVsΙO~`X ҥKr-q)=Q &fggDZe#fgZq MO%` Mh6wcU6>裑esU> /^DXJ mПDiGf tB%*}QGA7k4BGl2h>P h8:*P1g_հ~:!B c<7R ^D"h6Hpw5pИ2TpN1OfX-{34kرX B}!Z~2 cR)szѨQe(Mܽ{GGGH$8>>6N reOVᒴ$(JMI^CVWWJlNpS;`0K.h4p5Ǎ7hp8?vݧR)TU}Fx<>2??IҥK899^۷qt:Aloo^Lm$ 䊈d ^]{9:uݑ,#lK6-;A[^^^Ç-m"LZ"LM1i_zi?Գy;+LKS\Y{{{*(=eip*AEKJ^UMzo3SK 9z4ud;x9^YYKp [Mz߬zMak#A'OlLk4EV#TEdHo߶B:KKKz**666l'? ls.=nzLF`LBīfx<>2TD̉djwpdILhx'"-]2R`}^>xR |ߵ}~b ʱQC3`j,q̘Nbun?ѽ\C| \{ʅ}P{:EGR5J:o@.?.:ڨ 5Cw|c>pX4+YKVrii J q΃ϟeRl6)c XV!HXN?VpuooπNT2'IyplONN,u" |j֞X,iecl&5M۷J0==m ;3B{uY ˙`QôJp1 El3 <:&ժiM<4DL&- BX\\20jRۧ@ՕLF{FzbbX__7ܹs `iDP*Ƃu%}d29s( 6onʟ?d8-N_ŋjHDr'NTD#\eNMtm:ueb[z*OpSA]ۦ/ j[WY ǵO[uIgj:KZ򸾪vMF (ad29>D;d1u^cvvJbfjj!wnmKH&f改U.1 P(,GFx,Vxnoo3}^rٖ )><7n^#˙+++fV֭[裏V/}Kt:x x |#NݻW ^xnzh+^:~~އB!jV@QU stCvR,R  buuV jՂ0Ot(Xbwd"1??o z@Nm=u8KUDRA/&{_wQ޴ :/PW/Jq佴=O} h4ηp~*~D2!L3ĬW_3KZK/0x@}$ }~Ӧ'&&̐`͡^#رt`xNU*d|<ӧOgsssr|2vwwQհl0G0 =5͕fB57k 0L`O͟;9\V*#ִi[* IDAT]4F* F=xQ gD={8nyI 6i=x&4H^'Fʖxcgd4QE睎-oϤ9T1k^*(3B#̵\w=wVU[6|f?Zt:m (qttdTN/LPۖJe)wsݜnMi6.XzY:2xGGGV޹ULYO8cȁꤦiax`0ޞU2yAY2vQm۬!NjM{8絭J^\GϾ?^[[[X{Ь* #6Fm/\.,//#ϛmaʥj!z۳4ZfWImRVO# ,Q;d.~Wm3,YsK=7c{Oۣ:3 O%T5J_ݮmU@ D"a(U(OQ;?S@r2R9 FB|^2#z76ꜙG撕e;w6Wj5[UK; q_#CX t#%ާ;:iĩOU@Net*~3 FV3}+}͕R7.i1BR G7Fx1l6L&NGRΝ;gi덍 V.C6Y2m}5a߯l67o1-\.[29A*0dŢVn#1=3$[>mdj NNN`0u\x/_DQz#5x(fggvbUcgg~W_}gϞE,í[,J7oĹs簳3L%gt^*6Ǡ-RC/oO>Γce3~.\@榍1vP~QcB`-hkS(wt]e[U\w%14P@{XAeK-#~ oxՕXUǁmJHRϜ^AO~UXM۵Chr2YGGG8s ~~SSSfF1 B}c l&y;n]}o8Lbkk аFm@x.sM"|'&&p8r~9cjjJ1@Flj\.gJn@)CಆNq&AN .{dTfBAG/d+ Y O2 ̓FA4W.^0 pTt,}0xӜ{Ǟc PGeu.EeY (K_ .eq2&5 Rpղ@,j3={*lP}mh(Kk*6@Xio\M3ozXǁm@Q@ /$ILfy.]¥Kl`09W+i~ p M~j)it:f!A^ Ԕ c^K۵RQX j,Ed08]:\~C#@Rh4l $V'Cc3@2=( QNE*2 0N*N>:ax2kͳTPee5Ut*HY~M)'嘪ws3'*[u"*'`ȳOy\&(K۪zK :2@+Lg)Sʾ*Ƞ~l<(NK$#L2(ۤnS[BFJWTXjrb@ `rN7R-y@ʯ1` Mj`X,ZfA30ՌVݻwm3]*BYEx1鴕)t Q{J2VýᩄkkkX]]wܻwt:H899AT)+ƔB`RΟ?`u<}SSSX]]E"׿uΝ;zvdIܽ{lR7:wt>Jouj=Jhv3 } @KCaNkZu\[[ $<6qxxcuurF3s>MlpY r.JȪ"eiH", Ξ=H$D";wiVaԆD?LUFC2q_ޣog5A0f% H` ojKܙtbews'̥^3g`rrv'SŢ?DT.n"Ϗ Q$nViJUC,(;eՉ$PǢ(?kL>G'>{\ѷ3::~ذ6zvsi>D ^|, VB4ѓh?._<"]-"sKƋ8MC%L0yvl',85.{7dҜj3GʥId2j9,. L\ y0sSW7NNNq KpK f8<XPyQyIGC0.P.iPu(L7ʂ-MH$[Ф~@ŋ&?2V+d/q>'Hn6h6#%\6&C:Eb bb|ނlnS4 0JeD̃ ~m+#S:6 S\#KΚ(,39@64) I8C_у2;4 <~7{Yu`}tt|>ckk j~^xܿ"Ϲ\PJO<޽^Rz'Oã(nܸt:mcL&q2#E}KRio>99#X4V;ϋϧwy;zewwwL .p!X +++x1555bǥCR'{dYIbb{{F")@Utxii LV|{鉏?F4 ޽󬾐L$ (K/nVDmb h z=ammi@&* *j,Hজm|aSWÔk׮!9oOvܳF28 9uҚ<iX,'OQ%vv_iwNˎi-̭#2nLE# WA0!KU=(X=fK%l.+k;t+h,Na_'$Tp`@ ԨjDZz?0n9QeS~>8RGY_ELw0~?|:*d \Fꇎ[uY^6jޫz.5Pv-},'I#dM$tjt@2&;mUG9i];tɘV&Cyُ|>?~G^g% KqcnwX2jagg0dղ F!4<$spa4'H4Jʝl.\ylmm帾  p=baa 177C|_Ç +Kݺu V kkkq^~e={vM@.CP@\2V<k۶P2OM9}j7G%ɘNOOR؜M&\ NJy\5R{ܣ@333xWP,,%=H`zzvVa`0SVmoAPkfE0D@T2}*9}ǍFLdOT,`_v ?F$}WX,G! G?VWWo}n\.7r6 =STFG '&8!z#\NZQK۵En{hdEd\R@Go*~OAʑm|EyyFWYcPgyiz/ۡ`KI|n/or R'LmN\qK>zRp5z} ʐNΧx8~Gl(k}RR L&cm'H MAR,:Ǟm^5x"seTD#]sLcB>Smlll|u:\pH ˯zfXY Ό켮S;Rw4A1{( ?^|Ed2lmmY9$2*VVVP(P(JRx޽3g`{{/^Ļヒw"N}T z 4133-Aܽ{`~D!ׯ#[5WK }vi56Lo<+Ca{-Ak<6 pC'{I"luud\z`ImZx16663r6I, Km0,!WժiR`{{ۘRE۵U-]j`K0;;_˖:~ׯ/X sppǏӧvj,?Z PT',~\ S[\sC/ZЖжg+&Kj)'%]}Jņg2GցQgsV@@me`5|oH =??Ϗ8rJND{饗FNJbG1ߣG e6TN#|>U;.eA H8!?q7}.5 :=L5^/8<}g=3QxvHAVQY> C Rұ֥\#2VQw.jGlhN zi~K?&|^Oql8}`6J|R郹qPDv/H`rrN#H$8::tcjCdQH v(+#5/rCfݻ?Gd+ϼ@ l6Jin֭[v? >C(۷'X,|mtX[[C ͛7quLOOjT*… X__# (zb[!=99[췷qRr=|> ?}`{})a@(>Z2 *bΟ? lmm!#`iiN+R%XR@]ƆUʁ.ʏ K/ڵkV7"ϣT*!H`ssΝ9Ν;Vdx(P`C QۥmQ0,.{6nHU GV (XI*eL{pK$e;s? ꄎsue% .:`&ޫcߣ|=;cWh&qAX~gԙ3zKyp:IumV0ÍjtUO=׹.I>.F"۰ m#g*oP(d+#j2(}7*ˣ˯Ա~o>>vwwGr KV}EAb$EC L6$͢V|hN(YV,:tHhrre=uH12c źӈ_uo`J@ 0g+Mc >)|є(H> 1ԾRޫSS4]?~|L@O)M9'ѶjZ$/]ovss+-ȴ}i#)߷ +XɱX SSS4177geZ"*$>|#( hZD"+WX,⣏>2fncc0c#^n߾R/~xwBP{ Ys_use#ZtDm<waj:'g{{/Ξ=)d۔O0Pհel3S:y#ѠN}$rgD_pYc%YIlY(k?OJOGPJsN۬UF(4hL&} tz$?[S+09y: PT K1+Z!L}O׳ <~ Z-B!d2K)`54ń`?F` -~bU=VK?x9lzKW2:VT`Đi>UR8w~9W5nl/ou] 9@# ̑8--;R7Gr˥W.dHJ" ͐ntn4N޵G}O @9ggW҈@ ܹk1AWq윫vcRPɍlu\h|z S333 }sØ9vXZZh Tvww-t022b}W_ >dYayesq.{ ++U+Ydf $鯺AyY3Ӭr*Wrg#]x@|>kaHwv]awwݵhTx<T"{8^u,,,X,DQD0??e\.s2FL5(H p~~nMWI:a_{7122b&u:^gQm# !ڦEm%nJgggV&D&QfK>s;1N#HhP(׋X,d2ѯJܦAx yH72z=ݽ{sss2L"#b EݶȰ *ⓓȑ "+N$ y"xܔSlsG3O{Q'Ɂt"H ZDWѰ###jd2~漕yPBk$^I0kXF])8.TrQ 70EQGA2Hޟp DE)U2iy=0ao]W7A|YOEtֈ.zADjdLIYzV3fH$,sn5ڪ<7l\P=, u>t,^nl)5nh4:p]]ñR\F kW&5]G9,uxHoUx<{.vvvP׭/~eDQku?C,C4{! Zb~~~߭[ޚz-x<ܹs[[[Oǭ#ɉu]*:1kJh4"ҟr%򯮩J߷ taaFb)'ufYyo:f榥3na7A d2A,CѰ97obbbي/G&.2$|!\#Jb2<֭[GZE2dv6X:֖=3! Y֠l:eGq;n@ 7nX,2:*<腁U /=ub-7V. rD( >]8ƽ{prr)TUAcccjZZY,qxxhVDa#cQن^.%#YlIG`2ϟvsư߿(zXYY6oc\46M#x86iPÅa[)UF5UʮUμ47R:(hvUԜk4U[֒ޟk t,.pA*@7(?iD]yD_H Gut ݈-CRWUq&''vm9N)A-91*YքЕQ;ήssM^Ҁ{oqK0:Z^g|zk+3J_uƕ^;a.Q1xBFosѰMk6T*e`hgg)4ď?XY,qu[㘙Çx~mO;7AAWJEy8Lm PܺkHL@WBt#pS7":q&|]kEs6rJ" 5LY=*;7;lS˷Üa:Y ]S^ v+ʯ.v;&:zj\H\.. Q4ܲ2|>N^ot?D0333u`$ TU΢VYkUv^H$v o`0?@[FGG@UG@DN$ILyT<:|'uqI u3iZD"4\beԥ. TKǃgϞZ~řw/W\PI=vr y$Illl؉|sssd2èj8==ёa >ŢcVBy]IiH[nqct!.[9bee7nիW }XArpp}|>T{3qV@͎"HF?FjY&jVFK֡z]sSfThub?bz5y +*< S(LZ+@ U):Az$+U(pÕ+WlX N+(Jf3EH$Ak;EGFFLr)KNOOƼnYt5NQ p* p0WH% C7 8 5*CsIqU* +hСQ%5A%:vШ ̨ti=I]kV:_W9QfIp*#gY LZQ#ZgiWKVWTV5ugבv C+WCſYK{+hvkXqוWl]^QG Kye]E2Oerbbbz6[ ]bhYs}I>Zi~+`bbvJ^F9rx@}Vt;kHG2==wbrrrM2]+ɭV X__GZ;3e8 &cA*>{.(/sƨFFFbh:_\~\.wڲR7P\\By-T{to>-nw333h4],crrҞ9==m%"N[]v$1STf AI%s<46D3;qO2NNNPliVloPX6Hݤ6tOn~v PVc=z~ 7M ЌNsf,0ؽ^Ϣrba,(5`*F%ɤE>o;B'_,=yFe\ -_z a)7~Yއ htms/D7HE1Q9fdBy_:OBSKPDϩWA@[0c=Ly\jF'4 鮁 (x\F߿_1xݵy\ix9_T\JD"aʱ߿8_0:H ujKgeZ=tNQ?nF}ʤ;>]N:90hh_9-pcLu."JLH$V:xvvf=T L^ZCkQg&I;M~=>CSV}fQ[u;G([u\]?W>#ҳj7ް֘*v>˚ (~oDZ<LE,,, fVCVC50RO @]33;ypm( }#8@`TA)T0ܘx\.[=T/Ux~E4z;wsqKyQKej \=X}3!Mt4TfUxc{(ps+*Q>[ǭ9i5 ȗ{5H׈ 4j@9F]+V^ѹ4ulU T s~&O8U`'};=xi k ;~#4p`m6_S:I5P:n^纗n5.1AqK xu\>tT_pza1w˕ixevD,2 qttdQux^탇^&G_zǓ'Oprr1X,B`}T/j ueuD"amVS0|% ]`ʫWݻx.\XrR@{xx-ZꞘ  iwgWwG "PkQōqr׾fh?8n߾4MJ%;=#^a}.F_.H ]tEV򍹹9,..bddĂx Z3r $c{ɑF DI~ - ھS +bYTku:]_ޓ|ElKKou/bwV^n_4VeG&~r9k^l^}tѰ ޅQ4JvL;bScvUk[|]UJFG v;l9(qqx[[5jZzx]F@Ft J3J 񄞩z*ya\縕V:)PŚ_]kBձuqs.0w۪(G̍LiDx^Sϸ P.U'Kꦌum!r/ձ.͇}^rNk}ɕw5uX]#&-=t]xt:3R)b^l&/l6L&fͰ2:??V$iDQ>>x|x)~_x_ YPR`w.VQцǯ>Z Zd:71==`0 iնecgg[8u\LAkS|~H^Wnt:mtڔmM7J* $_Jv^ezW'FpZ2#Q3jz=K?iD׍²vfX\ܰ>.t#NojJU&GAFUftA]uT 22,k2xZ?L?b*RԨ0yssi>X(0աR1r#ծtA 7? _yWe ~^]I,J4)JE2BsD"H\0ҕLUKpי]> }'"Ќ:I U7)&"~@B0/5WQ1 0ƀK*2wrrH$Jt:mmXJ L&qrrX,q{899Ύ"# PmS0-)`Ԟ u@osj5njl0"߿%նv:J%ŋ۳fewnԏ`x>GuL0&c|N5l6kN|:" 9uό6}iÜdJ,Jdpzzve|N%iǍW\A6E׳GelR@O={ᆟj ,s"yVt^i680xBSP, |ju:\n >0 i( B"hQVEbQ=1@sqa<bpy{.3Noggg{ɝlST3,Q%Aaa?A0 <~-yp py<1\.&M9Nv Q'P:|F5"{ޗBFQU$MԺ MgK 渁YTΓQEձz'Z2΃aBzu,znDYo NtKw3*ߌr]&׀zA4(픆W}ҀawF_CByIʺ;^wmUvZ<;aNSe_KOC,xa6FUwngݙhc/A'~cvvJkkkCl?v׮]Ǐ677XgO .uaU"2 : Z:=KLmayy˘;D'ґ cYda}֢Rzذi'''a:̕/ՃFyas5ʕ+x* fgg$FmKh_4j" jRo9hdd$ IDAT9^_N 6xq=j5sT[3*_|t @P@A2D4E6Eղ(=) ۳W&(`}7m˰O`L쫗:/ò?==EX1"666xEk&b;Fa<(J%.,4C2Z"Ofc9ޛ ʞL:b_g+T#KF4 UsR}U"F6`j!#X%@D7*h'hi&~9)#TYz}r7 pnRd 25ndo7J멙t_8ZqM}˳1s|&7X~/X Xl`c%Sq<<\G9)ϫL1JmONN,װ,[ǢmR]@i/W)Ig]H,N9Qksy5>csnn,F1::^g\v T6P(  a߂57o~_Xx~$ |v$Gn/"ЬE Hne~uLPRF2c3%APP!HP(w$ԩq!TjtN: kE^=x^dPwѕ4Eԉ`4:%:5cA0 122bkH$P(1y(5i*tѝc87{ ]hTx |AP\g5xgt=ܨʁFBg~JcΑ4BmQ!j y4Pg(=8Xh躨5. =Jó4N*.oh~F2YY-yuR(xy*ܿ:2JwV#z;AZKo9o),PC~v#_.\C,h&hS{@*fOspuZ_]pV0ģGc C)?+hVTH̲eu1*m3׳ۉƕJJ X^H$fiݻ^{5;T w[zttdUO4 FϷm4 Η򲻻 k@u k׫ANcmQ*>g@\ʵU>|帞, ?r~5ZW+vuLӥbӔT*4M3`JC2XEAQMF 9YM F(Ta2DՅ&J<LXC < pu2za`5 q:[R"]ƿDEQK҃7>>>n-$<:Wz-LZjֹ̫*1ȍC4i *֖Z IA?uH]Kl\ak9Z*~Wy+DZaN<7r< Vjn4չKAFDyo@+vXg*?.Xv+C'aW09xFfu-Qz4Wpy];TNgjeJNOOL'z^+'A n 7?1...\.ȂBKu^###ـѦҨt7p],,,XD`ZכONNP(WO?4\:UWtڼX,H$b3X,"XuSޮqu.6q]t: q~~Ikh4 0ONNƍ(z888@.٭Cc||jiKHNh4j='xp{{{7bGvrT3$P%5 Pq|V>/)!5"}zYGr&f4c͗뵝\w {tR!9#qOW6"'eoo>**Ϳc\F@tVkH9q * Zt#}͖OޛsH5O>KKk9}ΞUB* EThbb߾xfD22,chMi\kHG39ם7gsu~O'>f&{V:讯;'+eZi/t\F";ib4^r1tK>h|v( c7K:%RvA/ǭr?OJ317ըUl6Fu:FHd`*k$u'\.# brrr@ɷZ ÈFX[[:p<}i6AQ\]ES>pa H:vY;h |d{{{<~O/yQ.̚ΎXPTLnϑH$011@ `P&j|>߿T*/^X6-LNN%Uz]wh4j츯xqUb1t~~nvO Y*UEsѨE*w.f'ܬU*B>e Ѧ5-Og l̰ [nazzh4&''' w]j5T*@.3nfDx?[Yv@0nԱkk]Pv1==m=5_ PV8==v^\7Ιfݓ`k+sCA$[qmD׉U\]A^%O)e) 6Xjaqq[[[@!Tj-,2 3mB٨Vs]1ȗ5ףvpY#;́#ٳ;XUexg߷ղ 25Ժx@1) r \ h$ /!" e9&(Tgq f^g_FGFFc[CD"Rdߝ;e~V;n~#lsss888Ɔ‚ɲ{QNߏLNN[vww3D"[/^Zbjj bq.W'Y QYkZ+۷ocll ~|Ґvp}}8<W3#|6LO>u&| QׂE8蚩RΆV{ԅcΗ;,8ǹȝXFdE -egS@@.Bh @~t%.(CX HI#T 2ЭY.vzV L 06u;cvvtZ$iTk(Ǯ{Qy@e_fg]vy&޽G&d,ig `_: [ɪs y5ld) l]S n%08+oӤN6ǭ]^PrpvvOVabbE哓<~\T afff,Z ַàkZ΍΂vNrX#\?aq](uƍi] mo뵒 w:&s/w Չxs<{ R dSSSy& t:ܺu zӟJP.*k?GGG.N,"2wu_Vjprr nܸP(dRȺ% ^&5accj܊οfu Ցr =gfqbb333Cl^&(?nXup8(rr 6^xa{sEMgggc>==mde)KnŢG31i2A6y~sA;ŋ('8:e FA^cipYK#b:tG΃Eվ)fe?ZΥaIS8TYdʿV!ԠP ʋĴ:LNNbjjʀ.v%7ex$2wsYV!n$[ ﷓{ԸP)17!FԩД 5:4j4 5,-Pa̱}kǭLgyy7oD"kJS>˭ȆΙﻼF3[WP}u}4Q09Fטeܸq?ƿۿamm ~ 3;Ǹ^C]ۗ,ir\ZhF#3F xid<~Ngp 8w҄#]~o}Nto]0U:W8nRx4)1??h4:PoK>C8&h)X^^ OziuHXb,UG򫮹Ғ3yzzo|OjuzݢpN~!V:dqr7>&`H&8<j W7^&Z\lx99'qㆍEz^\C͛73BRZ@ [S=f4&'hg(Cܹsm4 J%H;9/Yשt\gLk3~mQgtN;.SA| +WBEJ\C.oʤҁ[^*'+,Z-;haqq>EbJm/N,AD*B0d,7::W];>QҜ:׌y^iamm h4jGz=J%|'XXX(::U)S"QUGs ?S7ȝbll ׮]C6c;?~lp5lmmHR:nVܚP΋qnܸaeB,ޜgְo( =`hȵg. |X¥x٫s{t.N{wd033D"3J~g?PT&1 C^4ʒKG#DÝ;w0==muL-6F[[[ֲtǝ;w{H$P.i [b1$ ;e%'ԝEn=\n㚙u?[Qq},F\ Mu%Su 6#t,Hb-}k3\{K0 X//x.6a뗫*|> 0;;=<~rx<`0l6k}, ^]`O#*fZ h׿n#˙.6]}4z677@ 5x<yK#* ԩa "- Fӭ [(򋦗Y q-C#|pp> BJd#"(G!-cn7ҁs21(D( 3CnCJ%kkx<Xl\F.bb1ksHu!5$?}ym&5:H^u:_VWWSVY@y[W8OinPVgSSS;ӧ1) x^xD" LLL`ii+z='''~d T*aii sssBVCP0{ȌA^H$bcƲn{f', "N##L" bttt@;Nvu-iy\hҟqhk$'k5J̉'gƋRCI̗eO\}Hz߹swZœ'O @vvζ8 Ņa[[[V{G7==I uըRŮ0bbR#v.p՘kErjT/0 k :( +^7n䤥8gw ,SJ3 xxqD>^L& "؀ Kw@#UPK0 Fi` U yF~ xx^keZD׀s>FC> ma;/īZ};Nߞ`ttj y@[dATU]__G0)sw=U>Y mʹS\iQ#VkcT=蚮z/YXXQzHǪ('KFTF zh4o~X,Ob~~n.&&&PQ?88~#|(vAud]'byyd267 mZӧOe Bd2H֏&8 O3$*Zk?C Esvv;w?1i.# 6bFFFh4,ډ'ORFW VWWv76J~W Ǯn݂C*FqttT*]>qMk8nҕ@W ,Lpy&G ]/=FǬp؂Zc6X&Z:EYr7*>s3[/նX,bll x\VUKE8z.l#X5 4M<}yH(e\WTSnڥC666 CQ CeLNc)^ʂ:aHS>L"Hӧwqrryloo#N E*P(q$ TULNNR E,CV* M'h0 L~C&qz ~](F&lQN^K ZD-0Xg}߰#8e*LjbBh6vlkܸq###FiP(෿-^ZΝ;8;;> ܹꜳL.ý{pu큶nz‹/shIU*3x6Rps-uvaX,۽d2>-RnJ066-D"d2kx1:,>+Ғ(׋D"yAYQ^{ /QTLkpvvfQ@ `'tzQs0P(LܫTK뼯vuxޟߣ~S{i9U?WΥA.f(J 2^yE>>hh4 H&t$/Pfn2LZBF#,l/`k=1X{h0<4qNskg3Kmf=Cm|H p7D}ߊ x_;YW=8Յ\>C=vZex~I,--/DP@}j5|GVDopppH$7n N#Yuz|rvlq>Ĩ$iuQiD4G{̠v]<}t@*`_!!MU)8:2*X| Sp8l^q`ww[Q2M,ZZ{'~JsssF-td*@Vv VތZSh| 򗮡F UIyc'2})}7|sssE"@",vfi'u:<E4occ8;;t{TƆsǃcn#`sslbVݵ v(mTb1b1K aFN|F>U:$O}Wv>Ou\ZNG LpÇm#G};w b||f{{{}u< + ކOΝ;h|l6ܻw|X˫ ^ϟcooϢRgAVZיez`AjӹK^ʊ=jT*_|:,//X,buuLNN__q=X֛:p &_htspl_G{#XY9Ţ%s T)&͛ͦu(XI3F[ uNa0z|Dz ~9;;(;;;3e#&uӑzUpRLخ< 5{40LQ4*z0l1e2QTT QwuN,3ȘnXALaSq*wGEQd z|.rnɓ 7"*kTu"&t:f, Ph޽ dAaUP5T:=?ajbt#A ؘozz;;;5C|>|>ׯX,n?Eꫯ㏭]YRAZn6hX^^,ա0>>nG~onnbbb>R `uuhs '2 1==mk AdFk h8Y'40WGcY)7 F3hP@u5y9#a{{zb14MB!<籺۷oJ5V3l\?4 Fu>pa+XKypeEZϪիn:n[VH=f Go}&DЙNn1==VBMp}NOOQTP,'ƍ899}x!" @~\w RNT*Jǃ}R)UƳx^π.3Af{5@)iEBe-KVx:^$W x6*_Li0 ̈tMTSNq_ _guQKuz'(M9|w4~m<Z o6 D" F7oڃ<~{qR1gղE*SVQUL-Y2C7p{^|=Hh4 SS=6}2 #sTP*hÀMTzfHRb8==ŝ;wp-9RWJT3-1h&3-iDZ,uTj)5hdS#W0Q4҅|HZqW+{d$ ,QבdA}5.ĻF| #.p!w u %d {SBW\ͬ㱓rEq^}|>looaoou;෿yE3EȰ&sjj hX[[C8 2  &?;;vvvF099RxS'QSLl=BRd+GRTa@)e\@e4UCx|P(k׮jaoopX >D22xo48֏p1Ga}2^ϲG+مN"kχuyZ-TU1Bqrr/^X΃xNu,,,\ZZt 4kn^\'Wy Dt:B$ݮ1l6\w}׀'ΣPGpN0I|~ppfHϬ`J1dY:H<[3t8o{n_Iw(ɒ%ٲَc;čNi :}L}ɴ3NN'&Iv|/mw$@ q=kk0 wseه@>}zx }%~|iצq},sI%/Hʱ284׀ϠxS3.zgmg9C # )nkuq"y;R()ov :j hzƎ# d0ը 7Nct2D ?xZl,Lw}]{Nu:׆ GG5sF{kTuJ?#C(u ~DfG_ _H*>N{i$5ԲʻLn*#Nf%:Xei IDAT"^<ʕ+g u|>_Y]3~O~YgҔ5ReF5أ ILT,!rammͺ_ GGGF$}4MD"\~N23],d,;<,Cʴnvq v㻵t3<8_f$h+ONNPV-ݞH$tlxXę3gpE`ZKӸNc6dݮwc.Oj5˸ym(z*P.q ܿF`Gݵ5+?,VtA3mI+WrG MOOwh6rƾ^'d Xo͛֯Z3RS^wGL3x1YJ"S ծQ8h.zϋT5" $H`kk6k0>>P(d]t ,j P~N#.Hh95˥~j<0 U~ys^1x^X9'?O[G?kظ? 8g.`(::vwwjꪝsxxhu:34tyqB] ʼnwhN x^W'r!xe\֌(sLǡ]QS:_ P4!)N׾RէS ]SzjUuP*ʴ22%JvKj\փ瑱qKa\֟곹NdIئ&vjPCcנCY  ̕Hu.|f|^:ݸO g(BT2zc\v lGGGٳgJR T*V>p]?d\.[G2XZBQDP(F尶fm<ɃJ1.^ZfF[ *b}}CT2;KPx9؁.ʑv#hХxJk/(u>d%E@Szh J* t>:E]lb/j[3gw:vT4t"ܽxpYhXZA U|-Ojh4,= f$ȺXN#X,J2B.\0rޛR7Uzh]N65j8]C@O pn륗^58zeT^U&&ΟӺ`{mOSC/U~u,.Tti Zt&)ȸ 륩Bǃ14M[iAT ׎Kt ~ub y֠AǥTlStdәNNNb}}6<xBكcwؼ~:J1t>3D"ϣ`ffFL@/h _o}a.--ayyzt:=j5ܿN fqakkkvf's `Idirr&t:+o 8Jnq=edL#+ er].8FP<} kaIh4FaY *NZLT*[XX@~h~L&^d^1)j@ǭ D3Qʎv%k\H`~~>jz)cwwZQl`k^2[I#\q=o(ub䤝 z=4 \~.\@ZR=#- l1p{_:Im,RQ7ߒg@QI6No2*ןEy,$Q&3+ V8wp\ZcO@: i5R\B`Ƃ`RɌ;ZR)Z-ܿv} 9CE^(V6ﲴTN6S~ )$D\gg&biz^ ôFhX#vcvv:z4+p2XIge(TR}vnwdƈ27 5:F/Ν^p Y52ʘ* <ɭ@"?c1)KQ7΁pr:{7` qw7pd}w>cqqѺ_R`hhlW1\Tp-B!y[˸z*nݺ׋ׯ /<-Aٳ OZͺ1зk\P(jloolbrr\>Ili;~OJ";p =0kD۵NM!=͐hZT9ښ1B!f':g~7՛8%^ k,UrK4E&GXD.C\BeVIt:B cʲH.]岇7|n[C0w];wnܜ ivHC> (b "1;;T*e)%d9R7}3.J+P2[mhzčJRJm7 @U[r >aw7OI ; ~ӎ0@78. |c}&4 >SFIj]W=Q?!XM_4n!&sNq-K wXo/}K{.._l%`Vfu6LgDaSa.vxvwwԍlGǑH$:ymƒ \0ta+E%X\( .* Ry?Mmq5uO?^xaF eEG (U@( R8o \ח* ϯoQ}n5DZ#M \Nvu:Mu>Y1veM;/7urZ*_֔+?kneejig.]rxsssncaaH&ve=]l~Ο??)owwD2sgzfq;`ppj-e5p޼]$ɤs;VIM>t[Y:?i琌7b9Z>e\7('zClmmall 'ba2sh4pttdrD"=:!ny^:gב9V xs5oZ(ffffۼV.Ѷkhh67VO@-c~~333HӈD"VL|rrb$dNc96>d 鯘M?<<}>jt/}v2H!QRϫ9N-P>̠*8 ܫv}1i E:n7$|18w{>mT*YW{C_ -P[G0n%2)&aqq7qElmmFqQ5 g'xEea V?%|}u0l@5A*L&k>zCT*$}>xɎ꧴|}$"/ZZGB BPnkh^3:.~WH,( Xf=-umu}kP}EYa};e] !6g2Z-DQ,XWwttdm[ءC{&G"ہyi JYB>0mUg{.JE>dιلYi*0l +B8JfU>tD2n*Lo.í,n]feU8F*6Z@n0=vAߙ.t݀;̞sAZ;fΥQ'x].ktǠF_jԩGl6166p8}(v1 t.kg\j@U툣zDyli=C:744dO>A }YX,ƍJ޽{h6V8w&&&ic.bh6x!:ƐH$G}`]> j>Sd2\t n9ÇG<7f0_Qp-! ڵk, Ѧpá_|U5UNUzH.}{C86 666P.z 9T*FiAjQ%Jiͳ,KZR&''iD"'G}mVCV#}ڝnRdiq\NvZ3@ӯQNFcDm43m &@bEbj^SׂDyc6z-dnPW>rrZy#Fl9suHzrΩK\k XަXk ٬8Nzdd)$ xw_$,Ο?ox-3@kBR 4g;JYmAR%9lV6BR8Y>fv&''-0,h9 [ /N7|s@NYjų*eV$QWLSbBN垴X̲$\jfzv{ӟuRLAbG`+B=>e^7m(of3~Qh]?b@ON?õRfU($\$2*z/~O(۵xAe3Xda.lEex7+Xy֊QXˉC.^ԔeҨUND"|H$8>>RdxiL,5eDf)\. h3eX{@ `+smW.3y%qd̉u#z&&& .#ߏd2iϸվx ")qm*sYܺu @e:S6KL մ3@o6xd:4n޼h4+W`aaDHlfi%?ZH-%B6k #Zv8gĉ!z TkJЦSWtt,T~pI;G\dy~G3xK>~`<MdB2}#5nNKԩOsMaZQx< R@QlZ5fil+sucjj@3UBHS ###2X#x^E vb*H3QYŠDN2\Z 1PHeT*GȢ=X\\gnZT*6gH* #_ʒP_k5\W L '_:{?7MFY i*^[G fyjRԀtɆ ^8FMs1@֔k(7+M's٣kɱa,//spu࠮Дp8Mz7O04?%駟Ɔf>xD׮]Vylvbb( * fggIdZ}/vBcccD"h6s&''Q*_X KKK~!KjpyLMMOCx^;̊Y4bp8l XNVsxBu|_`tr\nւUHzGêTNǞvzqpp\.X,7o?D4ؘeFFFvmeY]:б 5Gvm EؚSdflZOs]XXZP(9;%3L<::B\^y zJE!πFaL3G[__A.囌85 yYAW IDATeBP%4Rx}~PFTz:QXϤӴԇ!Ȣ2`s173SE2_K8x%)U7|``<SE=x-5 4 c |677Nrdd/^}||lS*?H^sssT*xꩧnsw>sVyy4 " YVoggpAb~~BC"@&A7oQߔ-@rmPAۜeZFm鴕ghʖߣ`CH։uܫA @:@8}VaIexqkY3@(gZŽ{077g>}fa .|* E8獬™3g{c;wjc-kz>ϣ̽^F+VJē;Y"${xZ(k_Y}c(+z)^0#B`9"𢟥ROcC5StsF[j D}H׋rl%ԦkIf1)ڷ[rvmA1I;x`3̆[Z)U8g]O2YNz=C3Bl:33w}R#LGx>#!H`p;9e366f')Ũ*Qbfffۂ:vB`< arr@ `H͍4H)j> |~ ;)@SO=em4;PZ"J!`rrZ /^D>GZ<8/)@ΝRme $m72 VpX lHBcԩ(X,]ހp8H$bMPVMu`YDd+cggض+W?60n@HIZSb!Lgksᩧs#u*~_[9 hohL`6=cbb333̌p[!g $e7ް^ \soFoPJ0=ROƕפM\)@җ91 \[& p~Cܼn.T?sU/^HZDFLkK?+:\YBKg%(+Yn;Z\y*`>A24߿oF= 077o-tF?P`ʁh$F @sf֭-[ ܾ}T ?"z_W&''MuwJ%{Xh*gT9Wp|k E{w^u,..˸|mc DP&\*Y>\$rΝJeJ\V-Z^[[ Dſq\]/*aWDAQ/Cծ3qro`p K&` Ghzx^@ x K 9ϱX,@ `m/߿$Iy={ڰm>qucē$jm|R 7oބ0v kZxFGG]##FGG~H&XYY6an;;;xru#d7YzVjk̒8n d$~\V<{,O_2 gz%,-eVPoU3ʚF$ LNN_7bVZf ~TS~'W⣏>0 Z=>>68t+f'''133;B^[g nΐTa`fR^D?rlIO v[m(OL0ѹT_D9ОT7;|ZўM b/ߑX~JWUcYU\M.ǫeՏPGA%0iJijkj{lw:K(8::2愧o1 t1PjJt:CKU!,JX^^UOɱq[(7b)Lq!dP*pM@_~Ve 6,B ,WnUӯW@28vwwT*+W`ii;TYFxFN㺸 ,TVٙzL&cFap_б0852r]넵.Xn ^4W `5p\CA#LG9ձܪcϡPX }2&&&, &PV={6b1ܾ}^8>>F4E,$޽kܒ$bh `eePSSSH$XXX GG0<sKAd2+ b72AǕ+WP,qttd?􏮽,mu}&@/m||>8u3 (A@zSS):\Bg r40BR@j^"j9%MRbC>[}5b X,fO`(Is>kPIxPh*oz@+p 59g \BJ3J@q݈y8WBV^1jjK5KıC&H6T>ۊ4 DQ [F1uBޮ>J>:95Xl4T*V3Ȗ=&̹z<9sv+Q;5o߾BBjKX,fFBIŸ]uC`RH_,* Na"@(k>|l6Wb|| }*GRW,5JymҔ(_*k{5ޣu^Ǎk^B=84eŰox=u.{l6 dY\G`t.gUU+8wC;fc0DP@>7 Q'|J?^Í7P(j6Bnܸ5ܹsf8ŋw.\`eۘs==ܾ}sssz( |2~?׍ypmeet:DQ͙SԽ$ԣ|+X^^6&1~e#yjʻ:-򟟟}XL&=:ecS |>I֙M^<y2ֽ^bJ43@PF|*>GGGOaWty+E{gӂzWV܂}.* 0=="%6pXN#sΒ-JdYK>22]X,nS[LA}7= _MVi5fFZ W}إnM|yc)gWα*͟j*"s|rixme͵!&sLx.cLDIFmLio\ߩJߺ.,hK ~WY2D0Ie`ɉL]`tœ Px9aHVT`}}Z0xY ZI'\i׳alb{{R /_N)=.=T [sʿ) |[ )GB!P(7dpXgvJ%,,,n[m" 2dɤ1Y)sɸ!t RG;::FB`|HRƐakãixiDF''v4p Yp*p8fӝ3K\^/Tn|j _t {{{XMx^b X[[! 8VWW 7Mr9x<Ҋd2}ڵkW^y >3lll#kaddLGGGx's/X,[owFz8s 677O>$>3#'r@mf{,[oղ,R&T)ly-C^mgW 4m|GGG166fz1 !fYԆ0Uu{nzyk/X`10fX+_ɊAfDQcWWWq92/3nqrDbHR`VYh!sClsnuT O7x=nQov#?eT{\q ZIiI({|OG(b@`d4֞O Oó5b ZDsȹqk_}*íHr/h~FO!VfFGGE "xS?d*~ " *rhZtjBDZɉ elnnڢjJJ# zniL&C|t5t:()HpTu5: kQw)((gt>@f2̘q Ѩsnnnbvvޣܽ=ڰ:g7ӗ x9_ߣ3ҍNjT 6x-k`Çzv;V_LQ֒e)s7brY|֨j[7e9P|}geT8}x+Ȅl\[naaaXWgǃl6ZD"aN{6xٌׯG\ؘL&Mm|26,^x8w*޽7xNJjlCCCYwᅬ@ o~X\\sذV~{{{O0::h4jȦ=35ǺRxqҥ&. "ZBaWg/3w]o4HXYYHsYlB:pD_=Of(ɤm$$3F9'6Pmk;UՖu3GV@dddsss{.zHEcѨei9_rQG Z-lmmٺ! k_f'0$8> _t̷0b366h4jϬLwIZ$K{{@a`2%%$ Ll?c5KDYiʑij}7gk l{<+1%q3hSLg!Mpn,Jӈbֹr@ -.E2P.Jf7?i[};cqhh'?sG-Q^0LZY70<>>]^IL Qnj6M$H`gr @+ (F@jhhRa/ (**)k* F]OE: ~?[:@ ]LMM1DL2R uR봹:o n(!JassgϞE8 j^3enk4 :@ `gy'''X]]Z̮*ii؇4`ggjF<:&ޗBҺE .<M+pUapYFQW6hκNx<>OQ5bzzy 5:7tWS&ѳF4 ؚQuǿSʲ54Q^\{8yɦ1s+Bcccf(ug6h/k||R xpqe۔ƲW_}|[[[ "f)VƁ)]vLX__ǃ Yʣ<}]LMMT*ڵkzř3gln?#y&rΝ;\. #666 )jΜ9 B!+/ ] ՙqNv36.N[D"a x\2g &P&=xT }m%ۦ25N:=/=4KԨ@ `yTUJ%r9$`rroF0"VVVDtPKk~i+keЭ%}MQ5mOY*NjI]A<`||ܲ[v Jw4uQA}^o@W*zjz`3wZʹ|v-Pt=~Jbr,0Z0>>rl'W1eV GGGkwsE u}*}~]C"$d X5%?]@ƆdFvl-*-*Vx#sR) IDATk-ccciYM2@1?#lYwjj wPڠBlη(T 4iϨq$RY\M# ǠϬkk {tnugp$٩kA k(#/_lmm 0 E> ܹ@ Rl6k@ `ZOjo|zw5s{;4籽LNN"N2Jbf'xߚ==fr^uks'Y( H'̙3V j!LZf+=S??oN2wBe͹8k..IL X齹.k 5PC 'Džۙg ./ fD&8H$8XF4B\xSSSxn[q*J}˧Nl> "wAx=5\ 'AdTEz5zM,RbƞbqCn2shhml qJCWU9NtNI8g~N, q~u}ݵWA3 \8RF^A;O.hw灟Uш e`Ο|>;"(;zI,--O?Fb,`rrrlւ$B8\rT >* qcYvvFkN :|Mur/4JfjY vTX <(X} i+EYKDש~V]2 nˈ[z-?*:by"{NsAm3],伾>kĘQc(trN /HS~j9X*#1yŋr ^u (^O>>>xsj`zbkGS>ا\.ŋv z&@3YN'&UUFlҥKV{Q;4'`bf>uAK`(di ~;j;]@~SO_T: *rXM/A8Ԕ:R%8XL׳]ਁ>+՝ eSA}tuQR11 pGshp|)"WO4P0So;;;VDfbs ؂hmٴ]']@c! >..Tޘn P 4"T&䳑)WPNcnUqxm>#FS(0%rQhJ~֍a>񸕰tuiUq5$ ~XZZ™3g0??7x8<<1F H(dހCYr4MYHY= 4R`My` cY52r^w4Yd9f-[! -bqd2y;7! ˸}6>sawwjq`0!NA6\W:v'A fYQ,3 *z l>S>/ m/8 "]3Jm9ẫ}b?iczzΎ# ἖J% ߣa), u@G \;1Nd'&&TQ+V'?pzzƣ#eF2ws@>'׈zLR13UD Xf1\?{e`H3:~'ڵk**'__fX dRIG|޺lV<ՆNOI‚E>z< >v+(sh_XL84h D NGJI#VVB#VW=OL&iYTtCU.σ#C$ ͹t:xg3Ϙ)k6 1UGPOL#JV/U O GP2@CiU^8&Y"^/v(^24X!TytBW'08a)##GֈAp&AX9s7O>G06ZRFGGfQTF/˿KR)h4SO=+++x llkՀi'{nkrcx^dY )?n._|jSl}Vwz||lx<+W୷?{5tcaX MHNqBRA:Z g=;j ub-3KvwwON$޶N5d)@cАӶ_njKu]tztGQLMMt %Yz}[)ʎ[αK$6WfܵQZb+iJǮݗ I=ti@ny衋J ܏āGccc'''jzEtfLq1hxs FF744d|Ic﹌khiT5pv4msKQ`jVk\VSH(!!W)GgW*!7,XR6G62ChHip5xƺ֚`߼&68N%'`tUE΍fQn25 X6KsyѴʙQͫ0T>Guنaڡ׵x0:: kK711Bx<χo}[xM6򕯘,\p/2$dPT0??oaϞ=qb>H$(8>>nzr@ )e>C(B"?7opD"4M1Xl`M(*r u @ ETUݻ899A4شS~?ppp`s/lZL&3PS)y-,q^)K N "O#'(R~|G\Əckz=׿8`O0{0=PE9ǤzBFxddVjthh< >c}rrzj^ lՖѾY0\xGVޞgʬ=pC)LP.i8Nxt:\nq"vvii֊.7sԠs~V׻… 8µT&<곊"5qMxr1k՟hS:KU*=aQK7XkBZ C7AU\iXWn`YRD (wN *iMԡzOn3mlnnÇH׋F_h?2 (߿^A)J7E_~ZID*":fL&5nSS,;]*^;)FFF7nܰ#l6ƖUK`A"iW#ul.:>>NNN줻CD";fH,7?mccN $cwtҜs $x/ԸM} ) ?1>>O8|'QTjkOb0}Y̒ Z@BI^zn*Xl"Y A-p yq oٔ%^jj>@FQ92jGmn&A($Ybǭ jcX@X?58::ƒk 2Mh4P*ls8|hCR֖gfA8vg@}VG ĉU;@C PG$:kkkh42`G) ,O"EsR 4|^?^TnFt9!~B**sY:NvsJŧiq*JrZdxs8oGGU]ѐqGKP&Z2RatdLά$ qڸ)u:%[[[xfq3,E\DReI%˱;N)61ZEU/zѻE[Eܵii֮c$qȑER!9pJrș_LW@DΜs{3SN,a MղPYs?\)*N\(ȇνٷY*UgJS ?g廫r5]Cr^[z;u`m㱱?A5>>ܻwvO=xY%P3yB5/b||@JX"/n߾G!N^*>C$IR)t:\B_ & ŢEJvww/jX,ŋh6r 0<7%==U`jѣD("GP(011~ DяT×r#{tkeԹB~d}i?C\e0πtEΜ9vۿ/rx2ݦX,Zܕ[!lIt!H ޽{AD"=B9q"d26-8 PWNJÊ_:GRÇ(˘N-0FFFPTMug~5egT,yBd:^r"g 1PDb-ҭYn###Ri. q's0ҩ!Sm(ڧԍПqD n8qe޽{B¸vOkD JPR"qu+r_^z0,\*Q@9[F__RT:o/wa,XTOEAd@GGi;N*C9t{r :n͓8>I`̌Ydtz3UH80?=F#[BG}P^=oUq IDATttlH˘ @*B:6=Ј Xꚱ1  ,-- H@yX*7ygHs__MEg~gFKy@ub u9Cc-$VGH:S 4ιvk ###Vuyݮ1wA__^x[cZō7 nL&c " scÖ_8 ո".$٨")_;1Ts{ğ{^x޶.D,`ጦ0ҧF~֊^ C#>}J{HAZ Fwu-ѽ:Av4 l:<OH:&ZNkQ3 Nrs8y3̤p3LBb^SEg 7a^1;Nj/#L^v>,//X?쁁k833c]x333XXXv<$AT*TU c*)gJYm9}P/B=ƧU5wjx[[[V=jULȝK-b_4@vwwqmD"!`aaNH@FR1fx055@ l6kF?iֹeYLMMYwm\8v:ˆi;рѩN2-qZ .\Qv?iOo :6E2Qwz*_PWbسG;pT) uj4DnGRzHz=Z?zq5j8J-MpRҵ HhRƘ$=z|742wcA|k_) R <Ƀ<\"ϸn1צ4vu~wA.əVBS=Jj`^z.[gAÎN5*wGWVC ;zh\.MĩS/cnnr&8l!Zkv;)8<0cmQ*fh4c+|.}n { }``(_iԫR CXD KKٱ ZLŐJ,ʟQ%ǿױ'OZi4 loodooxkkk(˖Mé魡P9p|<Ӫ\.F",..WXe&C{gwwzsssH1+=eN![5gt4MqDQKG65Eƿ1ߍ}ѵӑVE$IݻV}%.b&\. |T*X[[\3=YLuM]=;ߚ>٩'?dɓ %iSy|a>;;;b4&W M aXI pá|nY$URqxQE<\7a$zU u;*2=|>a:sM TasTa0SF>*Vs(._ 5>>ի ыR-LL/~]V¥K{{wxi0oSφfggmCT٬ɐVYx<)U#]FQCKzqm=;Hz}԰ȍ>CA҉j~8uPޞyf U*zVpF?pmj5e;h4q:u ccc!<lx&FFFZ@*26oRAM#/޳Q:YI>o.D333xOX]]ůگ!͛ĆQVn3j5̘lW/;SP=@KvJVeykUUQ,U8{N^u^6ISu|'yN*Cu̙3g011|>ӧOT*zb||~\M:wS|#E|Q(1??r`0;Q#Nc~?$:ݻNc#}E&A4fu[Q_:n[+0&ͪSMmJS8r:(G=W^ŋh4,gHsk`=WOoUt~OjE+&'΢XMM|(BNP*U  ֖ T*D"p\D\sgzoV7J]Wܽ{:$2Uaqƍ8<<N8;wXƼҒF5,RrM^Dz]F4Z=#ZvwwP&NxcZi@ۑKST(`Z[[ݻwٱ!7JCCCX__rBͩpq9Z3zHBV#Ati΢\.or")X܁ +{.\jjC*[wao+F А驾>BfggGaaaG}d톇B`}WD"'NI q\lx1x2H>D"d2t:###&tJjEɩ'Uq4:gt1??ׯ[$pV@}.8)lʠё_^^եG\F$A$Ԕ,3@Y}}nRSYtpZ:pTP/s {8NJ#vRLw{ck6Ewlkkˊ(I@d,Z MK:C$Fa!\nnOb<:[x<Sʐ z Yp4*OqWTzc+ǟs> \3B@>ԪEt{^|S<;N(#{vwSA,o~7HĄ}TJm^0|'Dpႁg>'@5$hq,av M">Þ|^˩ШQZNEG9 i5d|]ЕNcSyF[Lᡥ`q2ϛ0K{޼y p<aoq]nPTO}ʺf4 bppzG"LLLڵkի`0hBwjj m<'']J}av^GTG 155e@t P.sM,&OjSS>L!\c׮]>9LLL`ii rx?F$AR~ڌRr J%$ S\0y# `Ǐ:h`uu^}U$IB!Ӱ9::\Nu[O3Aj@r@ `^t:mx HGޞ<|lj,P֐4 i9,#m/N By2Wѫl.$2L:SF('<NbCLS'?t:1gffdv/[t666pEKl66DY NJ<6@=8:7&bZN7H3yL{{{fiP(xisVso/'N4^//_F  SX8.|>pON-oʜN22ʄRAemgtԃtqss!iUxi˶]a#p3ZGdz'ekHbbAS(T:}Gb8_sD+;ge.{}=QpH|/~w^G?S@3JNcbx~z>l6mRQ1T*SD+gӘL&{zR1Q5Uq@t=¤ ` ^>_ykהUZq&>4MeT*x<`\Tk YŞ=h jҢC&\X*zH$,{lve2}188hL9<iLA#h6H&( Vh}`*qd2|VsY鏀H[/"}={Xd3"tsPȢZFtjZcFGGh4dP,{hPhX0H"J@Y!Xѭ:t/)ՑS=FnghScIP.%T*H=-薿r vvv̥OPP,<W)v`SSS= ApD:(9޹X׍"p4!4t XA @Z DIˬ֕=QPX{V= xQȑН):Nϋo``[nۊRKVcNc]ݎVPru+Ϝ9Àv7u(to`wxxhUb;lC{ྏ//zYϝ?)nݺ1!1|T7zNACߛ뢲e 2ޏ{g9'SӰ/J7=dC&;w0??UZ-lll;j5B!cΐhQg2C tFqzHפ-m"AC4ޞLaG;A+C&Q@SeUd2xwb(J@8FѰc4E&ΎqEM? ߻wC^xT*|X__7C``Dd8uo} ?ONt= IDAT 1kkk)X[[z g䈲b3 pxxz >xX+ xX,7obyy٢4 VPǩU=Q M=fHM:Ѣr) G4Ņ?zj iS r}4|xnw~ƩB!`ffh:Zq ׹9 Ν;x y@j̠Lojpxxjj/--YFRWUx3==yJ%`ttOGmJa(||+iUɿ, gxoKxj:q݆WsTcL&q%{=x2MvW^6O59ZQ2MV}q\v|WU@2 ɃefɸNE@L떕UU֎ZsCP@B8  -ohff)rus۫r!9>;SӀЈ/8ҵ K ;w^zO>Y\lU2팠QzXX+ X,MP8͝n=T-I/^5㥅p O侐wbd2JbQ(lť^Q镽fD"T?u i`@SߏVe.Ww2dQ( 4azV4h,~(˖7˽y5xwaQpA^ ~D" nmpH<8>|FrMQ( `eeŀl.oW^AٴT[nT* "c||X..]k׮ڵkxW DQNPB=Э?C۶'GO ̝j[OޛS"O{<1133V\t tKKK=|t4S3ݕNFdkV wEV6i|,,q)A˟X[[Cݶ&v3`<3; :tO4* 5:ȊTyD Rre9[h R  )Pxt:Qs*nU&C$:n"MԐt5$GNgε!j?G@Rq9¨j6`'~vʗ9~ ́kZXXX@^G>۷vqUx^'=d|}{rqWWW188hH}Ӑ]03s9 2. tOEUp :>lyN8A7yDPit()xVccsY9RY[HU:u<,D:ljcR1SհO}SCOY:.Å Ѝg *r@O5_\.T*VKMkQ(X\\FT2Ȱj^X>p՝=QzϮk_Xr5 aB!loo#鶹\YYŋQVsrC,--!Nܹshy?(ruG-kvvvzNHʟrf0M(qރlc hu.]0oj6xuX]]EZQ*Ա ԟʗ)3>}}}GSx/9~2 fff,8G9e>FXZZB$12qvvvsΝ;g:;ͦ0! auu< S"T*e1̀szNkbK'q:[iKYcQøKqu:p2𰵉XX2g@x&ݞ =nȊ Ae0Z̚AȔ*0pzD)T4PO-f,V2*=GGGõң5 gOr3⻩VnZ˖w1 Ç8)g}nv7?RrT*aeeŦ)#9 12%%͢nT*aaa#,,,X諯ڣTr?飧yieekn?ib82*4qLUJC8ZD>GVVJZN166k6T~wp%T* g+B8LNN?ŋo#[LhB`L4b tag`F'6ǃ}sݵb>r9 мf/߿ǏZK.arr߷.#N=Y^^iKFRub.q(3G:D/ߩ)ܿhg5hd~}S?qDIzĴmKMǩSPp+lsL:㞫N7hy|6M=uJpGFFŰiߙL:88QD֖0gϞ퉺r9I{^$I>x<bnvS)ZNbxNKh L /gdY<SHK+|It:%l%nM !#k5+prI`OwTXldBuݓUظdJA"jr jT~NZLs / HZ9j0OF;1I^'twHdh|>axxE0D,U`*Y Pi_x aܾ}~7q =y$4vww/|Z>)3Tdp7oD?N_w4y@2DEц088۷oV666NǏG^O?mŀ|xxh-pKi>\wNcLuq=::SO=e@sGn7,%Q^8!թx###61%Mq()~FΝ;]ܾ}GG{ޞyI~CCC=weeSSS=sV E LGgYb1r9K!FH&pbv;y>f椤!)>פ NN"}祺듰<\?Ʃ ]_pвVs%0&V@%*+d#U8`lhS2wH_zd 4LaFL Q"Ҫ;k> _8J@pi  "!Ԧ,ȸ{)"zyrRkpggOO{uun2Kphh> ^tأz*qu~J%//=!mhi4rpp`b/p8l-<}AOc{[n4~HD%^VcT|0U:P3MuTN|W[040FViwX) ̡iBΓT-7Q[Ocaa@k&%\zDr 2O:*(owޢ-^4u dmLLL`}}j[[[p}YܻwnrN*9AF򽸏{{{|~ZT+WR`ll?x\.FN=~2tHCn̙3vLO=[KY3sWI|_n=B˦Ki*x_ heaxxd2H |D8nZ'kaNoυBP1 8/}*lۂnv{(i'`{rpe\zFNNNux{K<!֬&jii >,BBϧ Œn:c[~`Lg1Dᅬd2H$bzaaڟițrv[=szyFsZplvGhOMM7&P(H$bZJ׋_Ϟ=Ve H&1::|>o.:')N{'N`vv=u(HRD088Ex< j1_D&v[D"u3(2C%rNcLFACc' giFw__huө^r'NIG.Q:\L0d3H- cnn?Hdʭj7n|ee{{{t钁h|N'K?FhaXˋƧz(8N>bhLrRCVA+TN ~FqR=r4x X[[fggb]4OvP T*PdHA-=+ 8P(^cIt;Z<.sCˣ Uw>Z4 r@PKy$.Exjp=\'1P@ R+3Z-T&&T|xaF-']iDOtc ITuA@O0as*=.JVKGakk`SaȓC[>ζzTv/ ҂Ӌ六2|cC&1==mBl|O%nݶ1ܹszKu;d@ߏtBDaB^{ wRHaG4tIc9)md-D=Z{MGPc:f3#IML҇ZZjU>.foX4)Lbccccc~:Jl6166f)VVVJW6=@f`__ φMH>_wŃaaց\|F"sR&AZE*20 # Z* =/݅1Cu8 ee+ZXUN{LRy[:88hN3^NHz,p˅mAk###(wzժPshqpqNugGGGO?m ԿL_ѳ"Rn3rT*e~χX,bس*T>yd2#` ʣP(X,ZFղ ;^czO 'B~>g:Mϗ3QS*O\w]J%DQ4 ͡VptHn 0CVHP٩z*$H+cO4b KTk i&` }rRFqnQDW-p>{z뿎T*Vt@!k7t;~N̦4nΝ׿uf|udȟU#-Rׯ_ yE$*h9g;9CP*tVɵ*1TfJ;00M>9nPcTU{7z,($mmmY HF\.$I@ Fs_'φLSx2g Nqfݶ..W7ņF{56UG]WIȂҥKC:-݆΄u \.X,HR933myьr2lLkkk|cFz>޽k?;|K_>vvvn IDATH$733fGA.”/"P+'Q]N:c݅~91xlhzTP֩D&''j`}JCa/EȤ5y@O#M%^c[=X*x+.`hj)nRϷv@`VٳgQլR;HTQMFx5 B&k&ך# :'7QS(NLA-'RTd.%~=(@Ӑ(/5$4NQ ?wރHfX "*aagglVPF-Hz4bB~Fk@% կ~ WgΜ.}#xȏ;+e\ ֈ~ii  b1K n'< |Ƙ^ʕl롐4$@g54GחBT*}̃F0MHP"<-cnnΆ\.[J~ߌT)Қ_*_* 5Թm\NrBYʳ+Jvæt4{L5^}s._vX#VZͼ. (H$^*̾,eDv122b27ǏjcccǍ7#0 !N|LP*̩gtzFANN[ 29wuZ#=w,~%=PVUnTǙ5Qt\t6̍uF(QN???d2vzt={Op&?2C k8ɏ\I5.1b@0岵cʓEzBe ju}k{{{68r!tĸ3o^QQ28/=izS O<uNU:S\ ^ӁE^ `@QWyT2k9[|JA@Z 5pCI|}gmUŋWhhJ{ΰ- 'r_Up:8N(3\Bk ^9 V2e @*1+CNϓg^YVGv% ?88hB-駟BN,DQƕ+Wf@[А >t]Vٻ2^x( )P yVi#i&,l"`Q #͢^3=t}4ѨMA K{">*PX,yܹsz ӻ699Ǐ[Gz 333wc!R5ϵe(Xs*d*?//7#0Bi4xljF~tFJ˥VCgA7v,.>pR[wN G:y$;Ν;:ygAFk@p񩧞0>#,//lO[N[e^!"Ykr3K挠!sgbrrҼΫHpB4kt9JVi_zUb:/4*=T% yWzF+:S$<XWkJ jqsZkZܜYhŅ*&XQԐ(6㜛D外Zy

QqUmXߧ~8<yaK;ذT<##5Ug=yøAezIjX0HN҂1Vs.W7gypD"V!ݻ(&G~m;ŋvyln7ѨE#044Cu,,,DKŢ)M- ŷ-d2K~fϟܻwFFh cqqsss8y$~#"`ttGGGGX4o1|s[N‡~)ld|˅gyŪ":NYĚ`0:7yBZFo7L@9GY1gn#H`bb+++cEFodg 677l6Q,m J>lmm󙣊@8<<>ndzCwvvLVBwg "); : \?[MCz̝Q=oV!=D}}}fDp?YdNO*z&&&zq3%3`ffKKKxq_(\4o4=Kmt=m~^ilq0yzD穮]G bҪ.7_`4LFZaYb%C {cpM4-H :::B,3 qJ%˕%xZZZ.^`0 4 LNNvW~W homm!!cddœ,`Qw`-8q !@DInۢ>~@yIUp//L`f' wvvL&g(fuRxqf< G}9iT9ҀE\MKz6}mL }8ACXvA.1<.}>)Pk 0o.׭ΑT4?M Cf&Ɩb3߼Z)0K/.^5'V aaKA!{A-2a$}\8gj.Iso2M=dT%90wt>U*E  6}׽t:/_jgg@)nTs|/X+6\CCC*Qhsȳ8677=_5寣#===TSZVWWHbO^7rzBQǩel\X~ύk1d&&Nc3$QXoF8)$GҒ^{p9@`tt43#^7z^kccC쬪ժuMNN z{irrRϟ?^VGr8r2lY/fL&o|ZXXP^[皝SIKRzU,(٫[@]1Np ۓ{<LݞXH}kyy9?wRTRVX2^.cMEcSwx >i!CVH$ԯ$Z2J\,yQ?t-i.0!#\nKzRkkr1c===|?P269V*ifTb_cBAz>S-..Q\)UcccQm#Wy- zwkw6$8ꫯtݽ{WRժ^xzat:gggze8z9Y0q'Sr//m #`FGGuuMOOGiii)B]y4#4zwVk7$977>(Y68,#D}q¹\Nϟ?Cǵѫt:666__ieeEb\.kooOnYti៚R{{ Bafgg|VyeYU*UNrAujAn$z,HC.\?IMMM)mh' jBK fw6s8I;i ; ©#k'~Aj5mnn6=;;|?izzZ* zw"!wus~m9Qxk"zm500Nv !?ᦓZ. 㾾rt!b81逗QsXd"yv/9x1 #_ U ikk$٫cH,YP#1ԐrܴCcPR)EFMXOzL{9n|@܅qW(XgH\\;t&7?ΐI 0L3\.0τ)HݻwU*ק7oqFT}sE SSSS|^dɍ"{ŢNOO511G̞innNannN?ȯENLooo횞 {=icc#o?ڵkq>̀v+g'ȑ1rY L>yD8T5!BM6mbժ+ kttT/_9y$E0c"uppSTt`UT488ϋ4;;>={L&''K-DMDO[7nƆ" a`=gQ+jΑJ5,kkyr\U yJ ;L$ ˁ9 WU=~X}Yܧ^kxxX###$ ǤW}Y.cN-//磀3~^ݻZ\\ Pvww`xe*q?G( ѐ=?z)_0/`g0=m+yիvvvAWKK^ mmm411u ]]]ў3JminSy; |ZM6$Iv9. q kV5NI>;;SPںٳgzs=|Pt:Q#@{= IAlҫ rltۋh0Vnܸ5SR=yMBt1S2Z?a=at:L3ZXQ1l/d4>>>~2i=9dܛk8h$ڙ? BǏݭpL( XVBu;W$)I6vEt֜B0XN  My~8nxJcpp0oZ ff-jz688y>W&ӨPo$)9w19РVittTwg}ZQ|rr G l8ȾBp|^\\ѣGԽ{kyy9ZXMzU{ 8[\: `ľtǍ੻>;;B|K֦3?P0AIGN&cqq17rONN_j||\oV ޽^-,,haaA+++?4 IDATN{1\w+heevB{6s@y:==[o6---[hI///GN/LX^]cl=gL^Tӣ|>chiiIGԍS;;;ǏG$e$z"?׵k״/>pX٬_}zAZwwn߾ϟSXX;ץ I+;9r=9s{VM^8 \_٬r\Ax#rL䏓E<$, }|4j 'щ\.h4::.%GtvvwyGbQO>կ`?2'މ { oJQ^miff&N$ -n}^677#Ega;::@Jި[ EM+++WWWW+'xV`q;̟Gg e\wrWfbb ]f`_*f(R ~|#&/t. o71!Rg%E4 / Ze.&''(a>|QS"pEdr&9$T+xx Cɩ]'cKnmmieeEMszAp9lj{e \RwޒufÖ=yD}{^}?22 >iSd!Fi*Vr@x ѣH̽0g2ʺz<>a͒{>De/`qb x+"8wz*ÇU__666blpz 3Jޞ666rtS LQoo^Z^^˗ ŦR~qАW_kk,f|Dŝd_r(rheeEd2% J(H7oF%>||:== ¥Zs]>&r(SzUw7|???E+++ ڵk=Nrק("e_CCC/M=8ᛛML# ׭N>氇pd˗$' hx4OI^x`\)ڄr;522j΍ #O^"^w|pk=ϝb,j_|qވ<뫯jja\e]N }sʕFs\?W:ᬭidd$~@ZNi_ˣuY455N^.A2O@V\>\WFG>7\, yoFoL!Cx/B۔ Uޞ6#J`@+vYxq^&/"$<3v% ;@9K2 {7{Q<dX{gJ Dn rեbOM?փK:&?CT*EގkRD>\<$)r5ud_W*4::eR)ݺuKׯ_W[[~Dd E2ܹ|f|֙0g}}\25u8E'L`rnnNw#zrQq c)4LFbQGGGۚӧOuttn˗/uttBLؘFFF477pYtCH ._+NiNN7Ikii1/rP %??K_Co{W'˗/U/ԓ'O 9$'}caaAFÑ M/δ59U.Z.uӧ6g2\.橳3hg+qJ\Iiq"Fj嵶FzУqEPЃoSGGG:::̌\Jk׮u=$GZ\.?Ï\˫F~|2B˱|hc^hKK>}LщȉIU+#>׬A2$;iǏE E&e2LUըe<ϖG>q<@`Os6߁ߟu5ѯگiccCBA{{{!gggz7cȀ9pUT;FFFTv]~]|^KKKq6^'ҫ:=zG7a Fk}Qdqc&' ̑K8'/m ctrp~E輯O}666f^)"TJ_|EU C !,n5<<4>>w}7~ӟ*ϫ;n E63t'dط$?X澫KØo@&QHn\OڵkZYY\oz-c/8(!z@3F"GdsRh600Z^^V:r38ygg'3xafzYm8!/JЦ]M`9q%)䜜atzӋHy8RM |iiIyߝrdqtt4t|*֤D7YGf#~d2p&m?O%}H3誤VKPk% '@3䪐&| o6 G3 =AO!&ߙhK6]P:Ml6|>(A '+z/seŦd=߿l NcQ.,GtP1;;`.ʆ>(K1SX,jggGqOW^PoKj?{{{M$(,1&/}OZ\\l*b>GGG[߬Q1OX_d}ssS'''/\.krrR_ otc] d|.qߟǕO~MWp6yymH!:>>Ύ5|^w|LF|>XhHW6=moo5RGvޥЕyR(8kŋwvv0T*sj=z9|0Pl6vvvơ J%a---* z䉾oiF8$c?RdNOO;vW(F0YD9X; @h"CVPg̽x"=6Q h6mllLс@jADro}[cwuuirrRbQSSSzq3NGrnWt`w?yqqVT#݊)ds␟CjssS333zj||z':Yl9p9kꖖg];888xAWp2f)8y=퇓gg|> D{[ZOh'CaHOaNI Ŗ#HgrD!Z>dIsqq=<8{n&9eN``G(Coo/:x̝I 0JJW8l߈>1xlVW^յkvi$ۚ>67Qs36fËOC9xqALRe"1t:ey76OS(XONϪ?0+a;mC;::4??mnn^T*ivvi\s}gh/ f29 u2Lo Dd*T*4<<~hnn%Av|ޓ,/W&\Ǖ>2D%=vC,wJ5;Q!܇ؓHݍNHcn)D~lyggg*J`s{Q;ϸe#{ukkkt(a@n~zzzTT466%x><<ښǚ>C:::r!p*w<Q>T=pHS"aqD#@xx&y!%#'$=" ^kddDz䉆"mT}}} `gOzYMG.#>l"8YǵZ#Mkkk:88"Uϟ?|$c]vq^zzz DR6ݻw{]]]*ZXXЕ+WXT8#,+szqqݤ:s:m``@vk;%zOOOt% Vk]ny:Ev);^ctFZ-LP( rI.wQ6_|Ǵ=O7kq@bgI>sC}f||#H o.,I|nز~,H20^A3πgő˴39 cmտWRA"_E+xa.䗍.5hPuͦ#STrhrvCq-,.XYcښRThMfnll\cccz<<\!1\Ѡ+"\kM1 )D9ަFVk: gttT?"1˗zg@7|S>=tta_׳gOMh#{ "ߧn!$b/--X,jxx8ɓ'ѽ{zcHObp,(,C<\{{{9q{#n~ΐ`׳3Ę`vSfp!KǏC\O\';< |\mpҋgA^"9+eQ$ 1|DƙoWg~ 0}`@dzɹjPd\ ^:B̓^‚„dCQqI/XF1I=Jz.}GGG*:<<ԗ_~MLL\ Lz$Ёߌ|A?wW`aOO;838p<pheeEؘ|& !@ j5GNNNt"vN\.u0r^a.|Mi}'*1ﰁ|ܣ cmnn69M(zӹ%ukttT'''*JMybnsyd|_; FOX[g1>b(v...7x#'x*ܹ iooO> EST5`=7J5OS\ 0@V=)~jO&;򮯯/0²cKˬHKK!>L--2؇9`ss3NOU_mz3GGG?PrY++:==KEa/sO: ۆ??l˱ =4퍨c. q S֚×a&'yYsDžDutܶ96pAOpd`|a<=dhxrtNOOC36Фb1|>Qѡ5[ZGp/w.M(X^C~?'#pż;`e#16"fxxX;q 0~MƂd2zDNq"r39`Ȱ3geJR뛚`=E1#i9xԀ/z@|sH8jssSKKK L7|nt}mN`~rYO;cu@jΪ^kss3B.9j/RbQMYazRT{ Y*T,AFoqP===qH.LfNCܨ:JTv ק`.}xSLwKKU.#DK!]PF>.z=xvvV_k?qbQ---1nU;MH0yϫ;1tuuippPѭI^22S߁1sm'{$)"ZMB!ȠCK.S+(b^bUWGdz‚NNNtʕsoqpv9H$0l9@7'tAOH0G{I^^D!qwwW{{{MmnnnIoIFI-4 5, I G}=OT*D~uuu5u8r;CwrI"' ;C$/..OȠBl@/t oK fCspa~$'syT8hwV(OOؕ+Wr.+,߅=\%d:9sጙ_T v\$0R\.G)// Aq;䙼=mooBYj`U*w) epGkkVWW#WlggG333ۣ%0(PO1aT% k\㔻BД'FNk eN~N;p$ zc< "9`Hfsrr.ŤKKKKrݭME<N 4iI&A4FX5XIu• ."HRף5`R\G+^-jrr2dvzzZq}֚t4yD+~~OikkKw[ SeY=x@RI@Ha}g!.ȍ7gϞ>NJM-pm-..jqqQ CSEGnܸ9ݹsG}Qg嶃} ʼn#ߓO IDATh*HVhիWz&Ys>h__>|맣i` |[7Iq@L& y;)k{fxfҙ8`ȿ:9{}Y)ڪA7{GhB~>S}zu֭uf/QXRhhhX_p6ۙpez3?rJ%[bQ_Kq'I<1ډ$<LvJ:1 J WVC}@".g<Tz:f%nt Ct-\6AX,jaa!&Ցzjx $A~Q(LK/ V:298F!'9Ozdm]giii>Q.TUGZ)SA0>Y IёǞ|߬ƒ77ZXXлᆱ% kggG[[[~ժvvvLqd}>P NqSZ[[&W0"4 hNF\xfM\//˨e$ۯ#8q0ݫ}8HPq}O@:&ѝ;w8 ѥ?t#"TzŒ2V&jggGz]o849Ms1| 镣!0::offf_T*i?8CV,Ņfgg?ܜNʳ5Uq;=LwHb%|$E}E8uaK|^zmsp`θ\f=;oTJ|IQ(07:- eㆇ %F}$%̙Ag ҁcOxΤ#Cu+JM'2poKH.^5\Tb#+)?IG?[oR)5;;'qz=N""?f4RCjz{{U*ڔoĢ|ݻ{ہ;1CIϞ{90 "W5`訮\^u G2Oџ<YkgR^ܸ=o+h)h&ibmÑ"u(;KKKynݺgϞWqpL|ش7}|ȷ?GN:kWN566i]'s_*Mx ~¾fff444?\7ԄOItZW^ H擹uœ8sJdYwe`8Kh]un (9({dy|QjE"{(f(2q€9<< o pd ؽa`6cL:0xKv17|kDF12a%J2@D Eu% Vuޭ#IKN*w1g(룏>B=IzŢѡ>T*Ҋ ދfW8ũVikk+zzSk0u(\W,+C|ƕerdjR 58LWRgggMaB=A;]|H1} Hs;WIgvZ u<]OkF-! /niiIor###QÚ9D[VE^#3ݾ}[UTtvv( Vccܱ-HAf$EN޽1=~Xz533q /v]Gær!7ٙ?~zX}}}*Jz7`]vM_~׵w}d(|u4iӐW'8Z\WC;NGq%}a&&:Hr'z]}}}T\j|1Q3C4}z@j8ćjoo(sʚ e]RDp`BƼ|2?BǐjK*Ip|Mstѝ8d! =N a%=_g[`'=bӰb ew̱ //$KKKMye$sor60wF:9^+ɪ'^"] ˄+8ENXCΈeYMNNFoH2W`j5B[܃x6% YR'hssS@v횦tR)-//GT*U0ZSSSgb n|9+]U*7U8 +ZZH+*W>=jFHcPvt:Z|þ^⸵h{{;FkR>kRKR٬]LdBD{zUbIB3szqq^e2bDž1=HV JR '!W^hYOqP\rtAݼy3 _^^Bt LFkkǩݻl6ӧ7M]L&]\\CL^~=zzg2x>R=Ƚ瀦@駟j? ?z/Rz.Mzz} KFv\]N|~jFoiU*N/O:ϩԫ5_/..488u7zC'z]Xy 9h6:fr;Izǀ.>+wwwN555G}ooo500/_jppP;;;Md>hrrRRI݋ Ir4#>_r spL&)M- `Ԑyb$Ns1')Ip=>~tGdr9OҫD:#=`KKKSsa](6=bLއL3YC.>ׁUrx(|gӣ-9v{lu৯Y^K4i8|x]\\ 9ӁM{,_xϟg?^|]~]?яҢĄFGGd#=zHjHS뱩%kD NzyW{{{7778 sfp\N|߹|$A缹u#O$S[[ "/jJsqYu!Ł %I-2zsG]V}Β,]Ù9rւC4z>4@ʣ\d{DDQ...?;lVM Eu Rh~~^Q4R:00/"!Ɛd"JsGz"Q.>(jpZ777Xt1KsssqjVVV┸t:7oʕ+zFGG*Iyf=::Os5^sv?=e]3wvvHqr=Bw=?22.|R===:;;J^r)e p[=/h]Ž)rDŽk$ןyJ6 )=ӧumݻ:::H;gy ŋ+WhhhI]'R4#&1BȎˣ8혻L&[n&m1q&;*v, ˈ /L:p}y !#I?yB6wD$~$b{A}{㽽' WDBk#,qCarrd$0GQ(VEGGG>B_({qO h\_>ƾLڱZ-59Xqfɓ'zvww rZXX[oK[\\Nyل()- QLM*d^o k``c@T `t* @wF9ĠPpiZ|LONNX,V" 1{;`ggU*¸tN]H*^_pU ;Kv|s9Ҟ(b/:{rr(j_,tNAÑFEch߯ׯ;aP(qŤ7ptiG17ņѣŸB!V4a iyyYM3r鬞x||b\.8 p&hK/,I@[n5τ=,`\322|>8CepD hwВ{> Fݎ1wc/}wWj_W^gϞill,RojddDK~~)ڵkqwݦ49dgggQS-_ ϡ}~\_VWW:S7_Y#קgwIX1빣ÙC %,ykB^7^Ȥ []]]T*B<0www$S6uEg V.+poAe p{{{9>^`Ո'ͅx$3Jɟ#52>WXxF߿'ODjx(" 344x#<ӣOr]_d|WFJR>ÂQ{d﹡Ea$/ $[^~wcգ>ggg'(gbQIϟkryw@Uztz.s|=̙Ttx* ԋȤVt%E[:V.S.A;}\r`_x&499j}}]---Tp$s~^CZpP$kNH=y^IM݇:Mb*? 5a4;z*1$i*}!3Oe>.(s||ܤ|}ӺJxxG{VEx@ac: `1Q(a7 ~_؊!mnnFU6 ߧg*ѢiI +Wҫp^D}5@WwuppgϞ//G80ceW&BJ:5󍔔^"lYJӚҒvww533J_-H 㯵Ӎ'''g} ѻ{!^.<<<ښz{{599*'HNɉ޻q]OWS:>s{>vu!]I\8#xyNWO*$`E/+J\.kaaAlVQ7<<#---ibbBZXXXx˦hkhс; AFB@1n<3k9 jP`Ri0蕝XT*{B{{{OgHdp ;뗱 IDATc/O13ݸqCM 6dB-N5d2kܑrG<лh"5鼎o+J>ޞOO:;;4!TIn:::9 yttdj~ӟF*(5"lىt7R)uM=yDBA\NZXXP[[?n:s9㤃,--5=GI>dR^p8[<$_J%}駑I,Pk3݁GB}}}*4M䆹J6RZOӦCCCMՇ~7xC{{{V\֍7]~]J%Jk!ƍܾjmmoM| ^\Ù㖖utt4 ٜі0]j$iF!f98qRhk~乃hc91ouwX[ȉPw0]> }e|3Q(vg`}pgggrMaZU{3>cCRC=<< >G=R:VE_|RW<9 +uvvjgg'IjooO?Ewsɽj_@ME'5XO?T7nOTcccַ"p7@碥%_R@d|ZZZ#dw@eJ-gT*T.U6 b|zz:醝NӧQ(ڳyˆ20aȒ԰nl\#G#jntfEt kZc-ȸ+:U3 9@N T*q 00BA?_"}s\t`cL+rqɣ.Oz>@Bf{ ytte'''{=FWTTRww*$5 ˖o~SGGG֝;wt~hy Eg<&IG݁w0Q0z=z}K8 uŢ>Xzq{sիWہ-/6/j5"}}}v\.:+}HFsRT*tʕ8钴Ѓ\. u-U*ݿ_JRk=}T cr]43!>jR4Fz "y/^*ٳ8jxx8ERp2rrr_T{qL^q >^9sfc\;B7!uQa]gjSW,J `lgGGGN(2¨WO 9brTDA!o# peT0(p7Igt3܃k{z}}]}~~IyfS."v*ŋ0$sT**J6$WEK~qD=RQnkkSooVVVק\.JhF.ᮮ.uww^oN #`RYvW6+{^IVyn2.;LEH%Cv`䓬x ~/wnɃFtI81:3͜/..rX{s@IGWHB *QkR׃v:h0gyZcjjJl6@a$IӀUrܟ\.G䌾0I@,GRDYO}}:Ԕ洴8y{{[ҒσI/_:|>J9ᤉG!(sN4{I;jw3$Hrqhc絶EmooVEWij&6I&Ƕ7gϞ)ng\]3W~E㚟znhqqiggg![__huuU'xvuuE$sa9UT7RDΎ?FcccZW*8eqX,6ٶN  tҒNNNL; {MWR\gxmˬ˭G~@j//_FdPd2( ƐA13Fmm GK@M[[[CF7m& a"=Ci~=`}ߍT*E4Bxs-..j?Xt:t #¿`# !'_/$LE>vww z;N*{7h8=}{%y cMw&((L%'Ó< -K |AOy`9㙒9舽z1r`x.ࠚ|>sy499^\\Ğ%R| 3zӉ3RR {{{7g3^tdFz*+++ضU,#)|#嘟m$9벍=}zz:kvvvJ5Z0kŢ&''F]5'c,8#9 N:ǣFC[[J֧}S’:󾳽͛7N7:/T*͛!kkkqF!d_ҡL_}C!!0{zz422;?Tݢ|9EJc4c9|y.Igp&=^6>;883qŕ0X0fZ__֖5990)UULCI! E/?OlQOOޮ>-,,5zvww}}}a1p…r'ҝ(>Uٳ(L衸\V0rwR"7͙dZUg( Rȵlii v? D}4N  L&G Cg( sqzzzГN))8t:u!v]\\DEPF0 JMc}oYS]e\{g33tOf$!Q")H!?@qHH (4ID2I3=3Mv{wUٵ[]NIX.~nsλ<=ƞw|>_:O}Sfwww-{ Xu  tTO:qD򬎓2O&BXJCD2XF100j+W{Ӊ ; >˗B`m``s h?꼕qqꪂ݇¹p^PTN)6k˿ġ/Lo~OY?'|>ePao y _HwO[G&ᅬOX\\|ֽVZ߭Di #tc]f˸͌[1R76hdP(H$H$l3,UMPh3hFGG\< 'EK|BQ4(gUs*OZ'n\YYA$A2D($&''QTp=|ތ=NwӧV䠸+ 45 ZH,=I+cF( iX,f+n!a`~~f?я?4\TAi6 Ke*2U@޺u j5;$N888*G(wcc qi@}0c``r(drlJVU"NT*ek* hۍi2k(@2ZAp *4렁T~9.WY %M4V4P8jޗ2=ՙg }/ bet\:|^dtxڵkT04'I;U}єQSvL:Y-p LP0d!Ӄ\.g}}}X[[CV lw y lZga,--Ys]Sݹ㜹 Z0[pm6۝s Ֆ(YD"ODAY_=1Wy-& Q3ծqY333>y,.."L^ B?XVˈͮ쏂G^1?ju@y#"6vvvLtIVh?jz`ooocttTkr}3B^VlPZqR5׹, ٚSw booZq+xWsaaaB1K5ٮywb]O$1)L   B2-ʲvPtuhl5T D=ǝ"]iT©Q lԠqQyo,gHg˿ >} ] ^z% !0UAk)Q|Zb 4"?YzC(ܹc*[3-7Eؘ=cxxE<G\X~䫫], vQ1KyH  (Հ*SKp`~q\<cUG4* WM+ʹ sy||bhVs,r/7ܲKO㻆a IbvukDևg>dNRXs@E{{{6lhhS. &Rfff!QT}km8>rpp`k3{X PƔ8eP*j?x(؆M>c||o!Yz뭷accFKKK:L6ǭ1et}8&?A7ϵpT9Fels?sprrbA? ~ꏨQl% (sssxg 0;;k$ VԒW%~ \?Tvr NNNƽ{077hu_gG*זL6|rކB!j5x^wo-yelbbbi;;;f`n0{VV*Nyf5`@f4x8P}2rn ۧu1 000^xJ>b:ivvv ;IV3100`ǟ`i6xwL&cKME/* nFȕ΢ja}}R𲵵FaӵH3iN>'ukt4_r[W'CaWk׮[H$ xt_WMDRwF?ڱNJg5pZW}!YT*Veuڹ\UOb+@ A sرX ;;;V OTId?,S$]5r]h(rʦkZLZ *%' puhy숡ӃR)ib1;2k̢^t.Ν3fjY6nkGf)I__ǍʈщiK#(Ct4j78rt  Z^|Exl6k>O^C&[h49RXkhh@MP+6)BK4<\t ###ڲCF2...ǃߏ!J%<|FO{-]nt( ]F'@$( NIp v,}g=wua;>>noܸ@ ]{^.^)z]ډp8lc$hu(ZDXoo/^|EB!.~~ڛ7oZ֛oM diɋ**9jߨJBmBOOe_{zzLFhYĎq 5Hl47,w]2#AYy8JI^>KW TkhV(7!=88l7g<Ǎ7尾zn8Q( jr&L3ms@~h~61#[Drҩ,,,`bbDfAiD"'jZ<*,JWcɧQ37k:9 RPQh*p:fggWcɤ)E,--P( `vvD"9hixcRxq`cc _|333H5@̛*Ǐ-̲b&A9lhh6y;wj.B$7`D^I6yD ZWhDVcFFY]O֏>4տROxP(d640666Y__r-K /_ tcޞmjG"0@u3y2:v~4tR,v ySŴ6w9FiȆa#yY__CP0ZXuuJʺQS޸+t:v˿K?ei[J8҆1/ X]]$^]Z"Ld2LNNF#$aTt9K獲̤ i{5YA}VK>e;:x}ʕ+H$fv*EJׅN߅4>|9kʓox-h4v###f8991xtt\.Ep>]%t6]oٮ.500YmlnnZځL߁'jGSIv]{I1[IcTfZ(s|C,UW\1ǧ?'1C `R){Q;Vrmm F0r;چđ8(2$155eQ)}䌦|0G2D*+o8>>S|W A:*:f]@\Ssnt+uB/+ru{\.X,W^ŋ/wz8=9vwwMYk6aii P?GnLP,2dGC/%a]%[3uWS'1~^KgySʚ"jy|3<{dl6k;= 8i6T߱3ARczzloocee{ddƨs<} ԴkW000~mlmmarrX =宭OO1|*Ѧ`vC 4ݏq>&˓xF LNNZ>^3*3:6-bƂ n[a ASt)3pJSIoD sSeψO o ommapp]`sss3tBBHTvpzWQ4ċF+BF8F*ba8=Ӽ3MJ AfX,R`T*]Lp8&mҫsS]ր Q'FT* 5pV5fٗ_~/_\9akk [[[p}5zg΃JfffNbkVS?K&΂?y}zR[H@WVM`{ׯcuuF\v.]1ܹcs)f**} x-E 0::zncp=$bVVVcATn _Ľ{,۶n~Ph'A]?A ;1E(jg\{AySlŋ*nN 㝟7pL}dn7쐬9y\+j/UXzv]nB=n@vbs|#/[u-bCyjM=<+.)BG$ёa tPP2 m:E,FGG- øt1{{{jHLss4j ZޙXjFEdZq2ᄻ޽c,TҒР@F\h}SL >[l $QpU{]~g 2 p.LнΟ?!?}NOb]py6ᥗ^£Gun{qN7@w:Գ*7,ì.^~Wk4Qe\\DK@^,EӶ;U]Tq)P XA62Y;3=A1^u2̄Ez5Pd/~#'Xs pELNNZK.Y4Q-|Hs?O\X +J!akk |6f$8:: eOѡ`ع8d2i]YAV=2Nc;^n&{IV PFQ jT\P4ع8 *YYs0uܻ\>_vyyXJ2Ue+2PX099fcmmK^7ˋWun$x:j5!?QoSנFFm?Kuxxhvs!M,`M.׌FzQeZ+(?~*Zmwjg $&3ZN4!s$ u>>>}:###O臋ItnTu|.\AddH=]fYmqS* 58R i?;̕ ;k4Ttry% \zXZZ2͓fggf9f:O-xg Xyt@W-d@0z{{166ߏuS4H\C `) x,FpNtNNNpyX͈{9<ϳLpZjJ̃|@xleaiwIA'99+`8t3DquM.h׵sV r}\Y;kق}S;T*6GlO_R]Tb'v|VJ{@s6zݕ,@'ibAʴ1EP}IT YyJ֬dB# BHRba\pڗ<ϳbs EC4yvcʣrU@Y >KQ@*6M;FQ+7Bt5*/{x:v ;AYex1FGGQT>Oݻ)D[VA ,:&*;c`+{ t,ykXe 8Jg{ T&𐉢q07w8oѢH&Dzwh 8hѨj} [ML6TR>d~߂y n{6$`1B0N eFFFp5q\~Hf{T*١m888YAʟu9* m{'^p/^͛7ׇQdYaLLLsssxwP(~v<;5>>e\vHh4T*ET* `i$vDhL^);u1f[F:7Z=j G;rթ;Eχ-@iJP2=Sxg2l=%w\Ю+Kϴɺ6c#eݹ0IȡЦZ-[2Y }-Fuz)e<33k׮v}`p1rߍ,LOO^{5\~{{{VR.-´:^7wPBms4N D@":We+[V`U_rE}뭷pC )F@ `,7}t6tשz*>î2>Ki .NוSk Y,+U?g4Z6CQB]*a0-ȣCb-- jNKFBQAnWh 5`iQn\lVK{n|e |yD87q *2s8:8xRɜn4WWWD8 0:6e5PӹWj (I{PVm}) 9׫X,Z) OnmmԆ Ncmm /2QD099cnnX__իWnw6.;wJrV `@CkDh A Vg}^duO-Q޽s!&RH$bY_eZ teRr:akk .\ᅬ^z|yvex7 <;ᙟw+mg4ۦQ[K3jG˽`3-^0xfcbYА6E[Knc A.CU`?cP2h)[JbjPĉ,koNOl.ml1ĉ:#J(ā@ a0`鑾>3wWVR#r2=Y;>곗ooX]]E ^ &jm۹LG__\%DQlllXۢIK٣WƇA:}:<}_eX$ϱi@ʴ2.`v >XǨgh 8<<(~uajTX\\''' G?}'Iۈj1-e.js\,!v4FJT4a̠ri˹4Q'?[[[6$;|Ӯ.GGGx"L_ͦ>00`Y>kll +++²137w2?We C "Y@X)׼2,Ţduc~~(Jz{{}VZ@P155e}H}9FaN^T[2Zz[(.U Q.T*eu}}CCCbLD2:n2s-qs6뿎zn70jX^^q5lll<|Ύ~3338::J3#j}t|}oo/ŢP(dY.]oga3|F|5O~J.vR ݔtd2 >ZQ/+7֭[O~UIf<4AW#wC?>>jOµf Ů2G0pZ_w5uVv2DDDjxN}ZGxk^kߑi48wpM<|Иvs2;͡4^hcccX\\D6m"%I*:䔥8ɖZ-k avmժ1ú1)@[q;5e4≚d|>_W`6Uv #kRUsfp\֌7#(Ěfyy8u'7>|{{{v;A[,$* 6N<>>ƹsp-qciiVÞkG[JHpsLG^;Ĩ3(z{^ rm<3VĄef%81JDԖx[۲"J+$n1ɘ?8ONN /`hhRɞqbi剿]8jvv,0$̵mZAۘ)s( 7'~"Nkxܲ a "(o꜒0v]lt-h)į{9iXFpN~&>Rz FHW@v dkh݃v.T>To!?GG]OE* IDATp=? |}6~mcbbz[[[6m(H' ZK:ֆU*֌\MDj~nd7 Ƽh51)OKjF[uή쩳uA8wcwޱ"I7VU J[oY4[ k= 1wfi%<zccT6*FT2l'r>_' e(Ag?ښmm:x/Zg ?` e ppp`fiJ]yݭ40N[@o&&&JPVˈyv)Щ1Ο?MX nqm A\zls=R;wW_5spp2C?d` ܌A;dٝ[C u?VL2>wA4E4N}l3wx<$IX7L#ϙ8<>'? >O͛V^}n9qҥKhj4wq]vބyMi~zR#Z-V6bommu51Yv1c& (˖<;+8,C@߳$Fwhok맕0.Q/{?vqSLtZX]]EX4k) h7z[ 2C@0SΔ^KP4 AWǢLӂhVUE2d2v?q=>^Cf' ؆Nn'g}YP*N㸔TOg p3P B r<ϳ*n߾L&5lnQ,JVC05{3e\7)!@l6-SD}y,wFVfd2r99zGGG1֌AݣGWbll̺ ܼyBX\\r4;u\_m7yÆa{'e((xvm3(I}'p5嚨 Ο?ouGGGv "HW_s-bll .D0??o5 z{{qm<~L@,!XqǍ7l}=s3G.qS[u=6rY[ 8ibVz:44d [+ J&f{{{C 7tjmFr/󰲲7oZ;6" 4GFF} ?m6 v`uu 6@k>J'RZFC㱻aeeR(!\.[ϢTFRayiekP8':OY,;@w+H]^uFp9F{5kzN@ # P*000`ɽ=DQAkeNMh(d2vR<Oڗp8rlh4X`ˠ΅m8bh:ȀLM ޫhX\\vJ&VX[[C":{2W*c{zzEuz zBf'&vy4vmlbx"}]| :4&''q]h4fQ*p xEmT*ف)r ѨPv ӧ'7+NS&^{&))nYo.sڈRQr9tNk$._D)BυB!baa OZ e A{x"Z'G|~,r6SbBuO[ /SS ˎT&yfffL9{K k)O NWZࠕ XOzzgLT*sV"ekh4pM<~W\A"8Mg&* {s U)ΒZb{{===bcr ɤ|> p=L!2v~p(k8[ɸҙ{nm꠻ QޛA-︺Zu:@`C'GրD6~c> |Yn~MQmb1;wXl{fB2_z_.28`)DѰn*! 7(Mfb\FZE:۷rddpzhXYY L:O^{2k޳ڍ p9T`w )3 kz,Chο|2VWW111r%yelnnbvv]\ ڎVO~xprrA:y7M$ a /Q?woo/677q֭vH%gt$2MMfZuh<`jjkMth~:w]R~EƂ% [3.+q<2h4h4lGnq[wΫd_ױ܈\.[y% Ke[e}oo{{{ƕ+Wptt c)j5B!DQvvF899!f+%:4]R͎vnwNK$D\1SSSss尶>ZN퇂.:{e9?ZO9D"fttpwr9s|jL&c|ނ~a||T oVVV &/,O`sC\ S]\SXzI]m}o.᥺jf.ZmdƵR[ɉ"_h4dX]]EF&A$A&*~mQ1;;koUsh2 Ct IPӃ{<~ؔWOpExg[[xgz>7?Kj8ޙd2?޳.XiDTP4QU 7TǠ,FlHQ2B:'Zz,)@*h kǤc(\{40E@֘sT6,rw~ܻwe@0ͱ*\esFL֜K˅6wwwi:c:+:;u:. rvl6xR)`dF(4`vͭ tժmcM2 COZQPuc||`-Ymfܓ_Ph(ܙN{w^' TU_N+`0I #aaa%{bOOO[z ~]Hre 0({|?mt钱^"-YPfgJb7Q,޵Z 7nm[#[-+G^35%glZ@:o5]_vU2MJ}˾h'j87Q=D$}-~kju$QO">4D"]}Ieީ]ShW9K-_j]ɵ%QJnZZ:];:(0:]Ujޓio}[׿g nh4 (p>zfw"կK_ƄLUYԚV^$u9oVP C6T^Mwj7I. ߫SwT"A9^gͧn4zYFļApڋRk.nH#? ·X+_l4b.UkudIeO8&''qttdwttdb&;,Zfu$=iJxV rpp-sl`M|]䍎xfVz4;k͕%Ϋz?U*2r""/.RIv7uu"ʾ$kIL&L&Pa7Z }4M$ ;LAxw-b[]L[>jIj?9G{ `lJf'q>iVYO899v ߙu,nYgPV R5 . vZWYT*kZC4ꪥ'W]̙~c:Xf@GKr\?2d[)r.\@6Eu[ .5) (=zu+cݲJFJ\[rȺJf Tԉq=XR)+nݲZ[DQ;9rP*ӃK.!޽{lrþ>_']JٕM8׀ nX=4ZV~kC.eXDmcղVk.+vmA77RݹPӝG}l61==m+VOì̡xN,SbZapRD3&Ν;gU\ ʿbpʃwdc_os`C.Ӆt*up~oo,aTNq iuc]\L0ytto|HxgP4^g9^笋i2.,5%v y%KD+x: AQ&CEEa߫UFyQVC =A ˍ)l~BV󼮴~L =yOX:/ʮuЉwpt+5X9w 6D7`s,׀X\o)T#p=YRƫjuw&Gk~6L} Y9/AfR@V'͟ӵq>̺gzPOoH 4Kc9Ozdˮ)˥s 6=ˡVYp2l:AĀJ畽 x:߇DDT2655}#l kׇq D"{!|H(0NNNߴy]sR=ukz1/: T ׂ0X,l]_[6A2ZQ"ͦQF.--u^vpD0>>n +M%@O[gppl6Gp:>yfst=|333y3Fh:e岼$#!%π5H&(JVs],y^W0#}>nOyz蚸DA1*^RQYvd,`pV䥟?<<h6(xlc355|3h6X__vvvF1;;kC:iIp̰zrht:>U\KǮƋ5B#V#Wr ie1UVHw5= FNw4+ECѴ+^3L' 8XՈA;Ҟ)IYl6NqrrbMK 000`Ru|A\pfOxU)n0CPƍe|:Ns|dku,H$Dɘ꠹Yr e1贳c hmm\]2Pn?d!_E|>;mNvmH$,cyppp8l}|K_ƒ:666/""`qqka:FOO, bhA֣SwᰍI}$[2 Znা3jccc1R] t sJ`SڅV+W`tt8< W\W']l"oec:kk E\rFx l';ݾ}nܸZNu/&N IDATXE!wHLX'PE?)p.Q^t64ꢺ 4,8p,jD\+;hdxwjx dn[GN9!Kכ쿦h\Gװ+Wyh;QGA'^Ρjh';fZiKܹ`-.Mp~<e$;WNù/J40ec,=8~[' 2:3 uLD"SÕ~Xޓ"Cib1cNjgVʿva82ujڸL2L\sֲ+(ܪ}f]\%(EǸ{o;P*D\.D"#VΝ;2ll,C@ ټX,t:h4jLNN"٦qױr:7~mT,u0SsJ͢`X,>:Q 9 \oZ$ KT*2 /[2t9ahhx뭷zQYl3@G1"Z5"wM#6H)gXEǿrT;V5\?]w~OT4*%[:F_@B k._ǹZwyq]ϥ/2sp9c%sg<κG׸n׮]ý{t,Cs LֹYxhhPklkŢo"0xZ-DQwc-"KH$j:t\r>_3E.9:.VNT9 >A(etpp`68Z2a<ϳwݶϹA[ztR˝JQwSYG=5ΝdY]Fpu|[­[͛888@^kfmڼ"czzڂjRd2g}mY͞CAHp{xxh՞ӖN USG} eO3G. ?38#.١IeDQDd7)OHR|4<W3H lDZh>u;0ikhhG.CZT׾-Jd2JPպN.y`ۜ{W4g6QsLRA(`VYRuA׈sexcU.Ё@~!677U{!ێoݻx077H&XZZ>__ѣGQ9qYEI,-|ttdG\~m~$ KqrgS5J|W~sS 4jvkv[k4h8p6@׈P'iT5 $RBL{>TEVןQyPiTVxoO-w=jݻOU,u|oA~Fu BvWbh]7~Ώ גeO ^4,E;88@TlrvvvȠzzñ?vۜ# uQBaJT/dJB}tk-<Nwij2`8Bu:74sl Nÿ́\C:6%)Ȗ^@6Ǐ1??󰱱ajrr1>/^}Uloo&ݻg###H&G\q||Bd2 $ jW2p8=J%9f=i)YCB%jgAK2hƖrLR\e)訁Jbu J8j͒* 奺@zz Y>=d2|>n%^*ynZVEz_e]2L3u^[fY2`ԟdW\F*BB>G& SY")J$(t]?f{%jT9ӟTLk3\jcBt#\UF870ҡ=zEehh[[[(/~񋘘k_:ϯox~>.]%|7\모T';Ch40>>~`(X xZ4(d(TPJN}ȹ`H,BAյ/]6=c{l3'DJ"BDQ !@p{.*"aqH 1؞8Y_{9V~릎Lb:jx|`_׫P(  n?vj17޿V򐬝̠^[9S>VVX Ʃ#N~="s.=RDeC])~pWAQёm2l6Qh4pDQlll`~~/">b^z%|G\F6E"ŋq5ܻwju`3h] QլކQ?(wxx>nݲ3\p/Wtt:5;\f}Lpח:I 9.)V502, |ntp71\sWAS%Doruu<U^:6{Pxy0 \G [70)w9^>j1GGa[mNROYW}In6/,zzSJk{D"aGt'  P(0;;Nd2(˘Q/ZvDuɰL((Ü/_PԬ6v*7b+"|VkHP$AZ"^z%ܾ}-:RoYN8::B,Ã0==T*3gCQ T*!YNy^;ؠX,bOqF^Y@`eYFS!$iԈKTy~ltTL/ *Lp]K5*NuymG_(W] c} 59zǥ~#0Z7Ѱ2Jk3P.Q PPɻ)P>m\ǃy}槦l<,// JR͹韔yM:u P*L&fcP<쭭->}z`ʀ {D2ւ4p5ۦWXmʡv\M~avBu  s#RqW=} >"JYONMF#E;5Qkst2^EKU&2ފwT*pN@XƠՆ\ d"H⩙l1F\gߏI;5x~9bV611B`N0B`h4:v MG*?(+=n@]wչ;:^?o#Qi]zX,6Яu}>199x!_B;o=WFGGŰ;wSSSt:{."TLW˗-=0::jkRE4ߏl6 K׺XaJ .\|Lt]&/>ֽ[s@F͟t!CU RH;us 練GA*H);v (swٶKǪF3 vѱkK#4a:Qq 2\k1*n6@ ǣRzu{9k)ʩʦ^[w53cfgOH}5MkKj6OuZhC=LisA<ӧqUGDFΔb`ydSSS6^l#~QNT*YP^22 $<,--+++Pu:οy$m'ORnT42L+=tHD|͡n^oD$ +s]YW2^'azzl֢Nb ?NnW~ҿ.'={֠҇Wj:;fIa'lVgf[WZ !;fy<(rPV^rh4jJuA@4k@U=RlN)uVNx2#Ĵ  Fg(ÀgR20ә0)(JxG{[z򗿌`0gbkk <7 |+_AZō7,C>7ENBаkfXjp]аnjj=CyBb t2AVF$[6L5ÔlU^Q#)}T9v/(?)!mGa'\Ogܴ[SM׆@Di`WѪTy F^vkĄby"SnkSFUyuQT>JϹ.Z'ˈ {GhV:5T6u]; tR*k4$53ÿ {9+.uTpNGGGo,/|h49P(~mTdԗN e-!R> ̙3z9/%Y5a\.g3666p=nki鴭1* NNNNf F pQޯr${= `{{v!w_]]5 @4e*TWZvWCxG]( yӵ=:=U jPQ*,N4CJ%Po^Qx0f(txf><9ptth4j@#ihTu Zʺ糚^Fj5+OcI#fCT-//VX,n$ R{k-1uOfVZh4jHČ"k[E\P@`vvڲ851뮭:n8s ABBT*j&Unfq%H&z*x !NXp)ܿ|.\cjCbQ[t;:g5T'U'=Jo~LuךXu8RbhiتU=qQ[Wr^gx<"SMk0kE:Rg ( 4TJe\K@x/ruf&Ǣ:U=@fd: РVU\t ` bdnt5jvvv077{arr"7nXY"mOɥA,h4iS2X׃% W5jǨ 0hTeXONNlЃǑd^`a-S*/YNnW<圥 vJ̌hIk\FD0Ԕo*BT2ݳFULOOɟ*qfq}`+O+]* eu+f3b_!b-)pׯiSFG p8lFZo/T IDATo`0ӧO_vG۵^7P<td\xO=366|>7|^8um^JlJ_׋k׮Ym` S0666TPN&&\z>ң@#U`Ê~UІTxN=?Fr_Ah6B\9CҔ4Es E5®MuR5kG=QgZtZ:窓ĈF98'Ut:)RZϩ'&niiɌOP^lrvm<ͨ/וϬ#Y"/sw*g;9[KHOjlR9 BVkȺ쥥% L~:>۬k/wE5Z~Ȳ `+P*bggN7o6z)\|~JB=3~d2C3Ѹu|" Õ+W%LSF FX防'@P%h$W#.1VƔTwF\*]OR#{1=#LCè**LfWXz-ɒT\pT):.nɇF5Cޟuj$=ut9?*T]ΟHF|BeKl6k-\ B5,|@v֢ :(6 LOO\.h1`&NXXXEFFFhiE!禍NVɤ9.w~~`yy9L&k UMNNXYYSY+.hF:y"ɘ _s#mLwְdt'x&߶ء^hk+|OeEuq-U0u֨<{ 8އ*:kR(022x&'' T&xӬiS_H&ՅTeʗn *+VcQ05 h3ͦN7Wի#c+s#)K|G>QpM*&\3U.*4\CM**`uBsTQ3xlcSP@ *.]86*ORX}&kF׹\=[2SțW4477H$b5K.\{vnjmbbAi7, WZeDuK;Z6 {h4/費kCǾ0?hXwH$bٳO?|>o7fYylooG)Kz2A1wKfT??'+pf_<n :&v]J%yd2h6sk7 8i$7/M:z h2y.A:*8::26IAKngE^aIyN&l[fffP(PլSȠ\*G\,!AjYq\qO|TLW={{D+Yʣw_6n0<|ty~~jFFF,HE;?VVV ⳟ,1223gŋsVWW033^+W`ll ;;;H$H&;t]zR … H$V7. EF&ym  U9Q%Tғ^6]M- z]f2F*W1⽇X}D)U 2KU-VAtn:GטsqH/-VC{3uf,58T2 @ R;}x||l|tf3n+ @)Rӹc'TArM9oҝ'U\/=$DfOkKwvv7`8)T u}yov3:<Ϻ2@"@\6ZrDdS商u5fcth0 \7.e`S WǻFw,`F|;{0DNJ6~7USI8s=c4MJ%kginM곕. W`EOla`rrp뵒WC+IRDMY[[CVC*tC;qO<}6K_- t͉/ߵ)ߒۺNr^^xz)z'iYSs yfVa3B~??‚D"gϢ^Çd2X\\D$=NhFQ_WdCLOO[oiUZ,'QPՐm!8(SC&nxFx=Ef!hTH0L糔4|`[cUo]Abz@;QEJQMAk\ Ft_G);>[k5Cu<jn߾=P5M:s⳵@_}rrNs ;]pex-vmÜC`~>6/)bi$[^rFkkk `0s\f-& mI\߽=;wIfggvkuك7 X,"^|VeYa:zJHXkL]#ٌctt><|>_n$OX'|XzU/#X,rfBI`ܺu'8joo>]U9Nu Ԍbf\P2`F"fggMf6ea`dw}m# a*>4٦`:.HTԖ hz֦'s;??3>ߣg\:.W:K}M;y^  yT*Ν;7uXa`C28nܸx<Qf۳e Jj+]t0զ X[ufvSzS h,g>c=NONN=[sj#1+LiDQ@)1vm?ajj xFP@86H?3>cFÁ\C&1M.D^Rp12%^~ߎUIW2zd20FbCSƌ)g0jĜǽݮ~JaZǪNFSXRuΑ*@u<s1뀴Fc FX8CBd2Fʈ8;-,,Ν;X[[éSNjբKKK{!x1>Sٳgi{~DI*?SCS{a& S TrM=k['ǬLg*,^: `G۞X+)i!s_TȚٕelmmҥKxgfO'x/~\.^b]XX榥HAR2^׎vx-t,733Z6jz 5ȈF!% u7~.)K[:OU@=4{.^P]E㖍= nкn~_Au?N\Щ5Lh}*}5Pzr󵌃L;ws}$EY:ZFh{hݶt1өn.h'ݴ3Ϻe9"tמzOuEP+A ݑHwwwh*<i ;jXQ鹹9o&]#MGQvmXgYTUky5999fvNf~)vwwm G7ewVei6׭% ;1Xzeno} @ ~O~LOOlJH$=z0 iRghkD}ǃϛ1 G>E8]f/Kx9::.dDfc3]p}>Jj:x_7!҄|S)8::&''^yss< ,>;;kS1i<122gytX^\.H$boo+6_[VKյzOzʀQ7(c|ўϛi#y6֏Z`0_X[[y&d;;;֕/n޼n޽{oYLLL`ttFMNLL`aahÝ;wPVLI@iTrY_tQLqw#0RMMj\\Ow |&%9^#48P!TKik]WJG샬Rhh4ҪQ~Oi^?]*7 (k,kt/O*>ssST4HTʪ`H f8fҋ4b}$ɱvjȟ<$1^N )ڝD`ɵbRӺkTE:s~{rm6(/_SV1@yOL+a=rGGV_]G'!^ZZBOr9d2םz^uhz]߻w@ó>7nB!_p-Hw:ut/a}}Nc*V:ig~;ι9+x7n㭭-]X ~l fffoRXЉkwZtZTf5rF۫UT+߫Q.=;Μ9[Dr]8F"73ϠT*=c:Nꏾ4B] * ƕ& ONNP*= "! xPF\[<ʂ$ sy'O}~]Ci{,wXOa4Msxh`ff'''x0;;;`#ܽ{[[[H&pprrqSk68wcMA0>UYRQ9Fu*T4N`IZۅZʃQA$H`ttdZ% jf!m22_j-tE.G}dGhԴ+޳,^㘛nqxx .0z=,//cbb qAalnnw5Aphɍ@ߪ,*"hظ@LCsz3ƹSgF|ZZ5sSi47q *]ΗWӗm{>|(tCbdz!ҏY,Ԧ<1P xN{q-\joTD:s=AtP&Git'''r Ncepf󱌏}ut<4V*mKX,ލ~7o޴8D"yY]0,%x^|3{g… X^^lsfa`H{<v!T^Z #U28D#sԩSO֍F&(gM9ĄϠsLڧk|Ĺs~ؠ.t/*HLh o~ppgеQЧSVGv*\M0w~vbiww>4{ 6A,SnY8s(!l1y7M$IarrSSSG:gfY|>S$ DQl6QPVSNZvnE$1HhQ[@mwVpQ7.n}L(qǤzIC~fc3TeO%H?[wz=}d`>[F{<dj7h zg6.&&&pҥǢd2ccc6N*v\オTh4(VE4J4@t0 beLJ3iB^S By8NQͣ xG}9s\# 9NtW*qҰ EGsNjuz-~ZúWԱIw@ `z`߉bVG KcHFu{EJ^ 6t (S;7A N'''xꩧpi[{)F\{|Vh^u."ɧO"n޼o~x饗KKK(H& LLT7q݃ \?яPTp~iS p }Y?bdbmVe5,I2bGԩSrfX:׭-LMM l"/6,穳`kGjxݔ|JuF(+p؀P(d=عiQun@T*?APPi}àrkϿ+ * Q#Zz}uV{Π${sOѠ t |u~Ks||JjP*yB.CTހfejj X Bo6mxϝ;gM"] h|g IDAT(Fȱb\IAoמ<|LU+?H0Bz.q xVF>#֐H$022Rqd2*U.*S)q=%תUfU 7uT|:4 44 *;W;]Q}iJFrRz;#D*рoL6-::Cio5wi9rt~E UouRHx V]ޱ^Cün>/$7MW777y<.WJksNN&Xe:HiΞn>|_ KS011a)^gek؞ uiC>G>twnT1)Nz3@tpy|}6.^7n`jj gΜo}sr.G2DXp(cȃg!O _*PqEYg&(5wpp|;V_?"%];ug㖍eKӸ{u\b1k~oZxSOakk RɺX{U=]T]{sN^oSF0ďcmooSP. w:Y;:i ( rT}̍Ay׵wW}s ' Kٴ0iIյ>U?fWnzvd7@ݦk;YM(Js08鴵SpVeX U$~j_M|юp$wtݮ/1'֭[bVBύu(G0DZE,qgh=հ(HEv"-9Lʏj|QǢY]s.LS Q7^ \$P\~ejW!R`PCI5U|Ǫ/*VA]U7+ӪsT:~|nb󕑕U hduǮSà/ǤnTSDˀQ*Kns Mܺ-\Ĩr<ʂ+{{ tΑH?_5F4H0keq e*T;7sٿ.2 #ZoΡ߼FQҥK8>>֖E97g5ʿ:Nl3^ȤI#ʒ_@׾5|K_,N>=I/:h^o)uԅuÜbgg(P(d]* |>nJ8c-7, \ F`cE٧>2"?;;zl6́R6V.UAa7PvmNP(^z nΎ[VqMLNNbbbNXk(W@GY!F٬[uk P`T8wWm%uj5  "Zd΅bSSG7{N=1;z2V3QgG6Jk#apLa:RtYnQ( .ڦi|˔8?ʹ ]z G&A^֖Wncoo>,BM<>>2.^hj|>۠^Զ:>U!o\~EguߵZqu 6Ű1`Ԇh/ga AW_PS't:ֻ{^kǺgӟ.]B"@*E>k|>s4,:c$I;(-NUw)$jk1KbFJ% A e^.t::zԟ,3ڥ5ORXXX?y%jШ%a NLiyy2,s:/ }>_+&S!PNtA|ֱ&#׵nzBu:W:n3l6 3 lmmazz1PWp &&&D"1`XnH$Ŭ$NcssJ,Pmk\`ZUKSF{bX[mSeTp?e}SDQq χ-*M8 V7ˍgPӀs]d~1A>@zz`= c2>OS ݮ J 0]+ 2BT@Jk.ZB3666PKI$??u;aJwI/uSF\8w/WG!]s7J:d\gu Y+p||O>/^2z~m;xKKK>gm+b~@iԀ`_kz=\D..O<vwwq]LOOw؎mccJ`4T>]PO`@^@֗":iy45WWx7կ~.]Z4ffiqN$A=rWr|>onUuȈuH&}z__x'099i=Y*@=M$HD֟4߷ws\Ԕlll H`eeenD"xʶ)u^Ifi0… r9(aF888m<X^^Ư~+lnn֊Pmcd^eM8޵k066ӧO[ בP^w,=n0BMuEP{ɤ#oeMΑZ:u fgbPmuuf?J>!w]d2+řB ͛7qrr'|JJs"HSů]U&9"]mxVYVVF QרSuo6>~8022LӸp +)pF9NMk< aqqD"pOF@ yQ<#WˋT7wVQ] \.#1JGP(.ŋxWqEϛC@]Aow]7o?FP(&&&lb,Q!CMZa yD"YS& ی .3rq;Z"c*b޽k X̜ ::.PpKHkG:?quŋoۗNL&{LF79^:Mt<.ꫯb||F#~GuʄnBt)\###ivL 7:^b'rS_E;F"J\B9Kvq-੧ёe)8,JҀn&OiY _iar$uu3쇕pHʸlw`Iv P EjUQ! \f^w`2! 8dp%6O ~z"*0WO>._\.z'ٱ'zFW'|r?_:aFJEHA8FF>sk*>|kCL)bvvkkky@F9N2>y@[5bSU>W~:&(=s> :*T0L5zn%籾>pM(2-:ydgϞER7.tHcO'''fTTNϝ;g>>F<ӧh4gf1vK?_h loo[ƃT@vCV ^Rf+ €CNkKu9:lq򊖄|>|G(Vj=s/..Ӹs1?? R)޽{f404f`ii +++20;ฏU68'Wg[ҋXDϸIAN z;`wwx<8wB9eG1EFʄ u?i1#*Z@jLTVHuoΗFh5ݶ,Sx4;@zXvzr"\Ό z78.FE x0/_YZjj2?H;Ҙ̭c䳘i(]w=u.p[ֽRJ'}GT4g?CѰ#wvvnqZ-ٟ 6t?c31nth"~"!T*Yu{{>O>$|>*VWWm;wkZxꩧp%&FGGgck߷﫬!UEZh~LRh &I Ӹd޶ )O'|x!# ont]ZxhG0DPH&12cvvv)g&ݸ p}c~~SD"}Vatt6j1~t$cX] ט4Y1!*.wݗY1zFq;w9`T~bbb4s 6Ν;s%ǽ{p cqqhJ:h//csK7 ]#2zo];c..tZtuǬ< lH犡33[XV{{{jH$v>0N:d2itf 66sm]Q@ܓi,1(Yv]sp`|_!=:mmbea AGQJH$2rw=JDjьaf*&zU|a`uu69B!4*+z tL$RIo׃W@5Lqlnn7:ݻ>N/"/"N7DT[o7|NS;r9\xB|`a,N#t֒ -HÇ lZ?<:ZΔ<).-q^/FiQ>467`{*9ΫodWFGv"^w`76ǧ)A}ύhq1JVa||lv`s <>O 1D#vq_lE JpèrĵfY @i'_l69ZC8XR,ϠhTʎhxύ 0,U@B)s%*w*h]1ӗ6]#b? V F5@HFd]A{J3\)܈B q5D4:J}Y,//cmm o\.T*@ `dyoχJ%|>|ikNbI 3 E((4?ד. 4P=ML`dnH렞=~O4Un*KӞmx_|G}yZN5L lttie!󘚚?ě7oZZZUQ099x>Exi3H/E\.lZb*fY7|>9V!ytwwj2w=v7#nsss2 `p(PljCAʾtAJ\F @ZœO>Zf8::j;Ve}~Wo)xQ*p]dY#G(`rCUDv3R֮]:/0TF py<7#A$IqI:.>Q|2asYurrjjh(HnoR.q`U+8^.ZiS(]nZTL^SSSVOq'u_@IPMA @UO}ojt:B[=6MSuS".bS=ꩪ9nXv70Wi7xt2 DUJên (y?>Slnnn?ƵkאJpy\r011at 1#FQp`"PUKGeNWϨ!] YњxUj g4)u:Yz+{H*XOCYTg1B`F#糨f"&&&RcӭuFH[ky^sckLnc >bjjje~?fffiNi\0xZ*c} hVeHGʺW3nscTcO^^~ݎ'^x+ThV-cooD~).__|HZ2ɊVҹ҃67P0crPbNcQ`jPu ۵.UљӌIVCB<{q/+魼wW^t1)[b1s^CAlL24QA,\m1I vcbJkqgHJRjxfǎ <=0 _"ɝ$@$A `< [%.ŵS_RS|˻ŃΗF *E|1mootrŕZ07̽(!0ov@6, wxxZFy~wg6gDzY+r}*h}M!y?M/+e<.1}㧟~O?T<٬VWWDRVTǏt,&&&zK.iee﹇~=(Ub(%Z^NNf3_䌹G=q~:`t 8<{ↁӁ[\VJ.x.Jq8SEF#FwZg>O1hij'y j j9^\.ljy# .D!Ύ"lF{RnsE@<rHkΐVݭJ{l`;?3OOUz3qww&''ե_|Q)~@ ͍FC/_r8pbKjooO:88PPн{۷o۱6 *ˡp$wR^FGG[Ro~# z~?F?;GjxxXfS=z*BD<~mD;C0~A/~꣏>ؘFGGUTӟToߎBVlgub=hāH37SӜBsu=._(~wFry ( jqДq:ve.=eT;Ngwۀ cÙ)&wpDfrl F'X>8X;@Ns{cݺu+7/PPn†eT*[=99~QP:tS:w>S}{Ç%y_r4Mͅ077P(lp닂Kj(YZZR!a8Zp @Ϟw_HS|Uxe](8?Z;3&;HN-T;hqޔ4wye v>5#`nfp0P -}kk+ x8i_*-ޠ;wڑi Cl]]]moܛ5?? xōzR5)@=gy@WWW(8&mAZr7nڵk* Ѷe̅T.U.# _Bt}TgggܹsG555o"Pe0JX,F|͞. )3\ϡE:o`;w߿ ]z5r{zzb~Du0݃l$6??@GGGu>|7|SwK/4"=9#b{{[R)Fi+- <2wc,Wu7Is3b@@/T;W߳l4D빚7 n @RIf,yڵ}s\xPnUcuZ[^TŢ#d8ms"Y{'4n| |̉cߋ!g}% 'h}}]ۺ~ru}uttoI+BAF#uG:}zfXn6y*o6-9|! yʆ{=CRsVrq?ʩNnqPfj7J/<.˽k.|wuu>Vwww |xpX~MOOk}}="'r_7nPWW?~Ƈӂt;j)XpxAr /|wf9RLT*(/ 7N+q}_ёܹ7|S:>>ȑs{{[׮]//f5<<p(JZ惃T.\ǏtV*B\rEj5 /129:z@g\CE*}㰫KΝJR@#P۪T*![Ӕ#/)E=~X]]]q ۷544{7ֿSW^գGt޽a@Dcѹ =!܋貕8qToy.wkMuuu^лᆱZ__.\=䧧 naw:8'/}___ ̀᨝xy/o> ғP "BCap U|/9@݁$k}>{:vF5GCmRO[pX. Ԫtoz7n$\o>677uΝ9qvww533kaaAGGGŋU.GCȞF`p2t#n1S^` 怀'+ Dٺ -BO(hZ8x:]8o>Е].|ܠfȂ4rsX07_v-%xX>l6՜cd2p+$XlW,o]!ƭ~^Rχ eL佾#qxqDWWWRR)z9v擼qKZ[[O D݋".NFٳZ|Iq(Ed)KT$Kjz᠚S7ioӺv>8V~iyyYkkkښƴ*AV"2d“٩Ehbb"Ze6s)ϥ%y.S}}}:<996͸Ls紹 .@e*]Ȓ+ﲈ%gbˉ0B4xv]OxjFQ -y1JQ>j~;;;3118jBABA/_֧~BYhhhH7nPTݻw۫K.iooOlV zekbbB|}6z\BG`BV{q,*0(utuiz|N%tKC MLLDܹͦ5:nDnG7X1 Ν;֋/=ziN; r o*|퉾8`vr^|E}+_޽J譑moo[~aUJ%^ӣGl6599Z3LݣNO^Q666 8&<-ue)o 3ud2CJR\^DNzWxݚkܑ6ͳTPccc-_4! ; =fY`666Zwn7< nllļ@!h@!@uzziMOO)\nX9A?bPRZPu4229x]9?x =\Z@=:̏p>7<{S˚YP@z{{B.SYR h9 PJ qrG| F[Iٌ98F1 Bw>ƴ*uٍg QCvuu=jקkeeE{\.˿Fɉ#?<<9W\7MIgH PXS]|YZ-+"mT#IogG܀w^z twםǺ{)|DzRwwwK_Թ)6|.g|.]҃9uj}}]ZC*JvwwWWK/ PNRӋYѽDa9{7Q Huwc^@~Ki10unL {||!}A30cu+y^rC'܌8arOMo6!==%:;5.|pg?ٳ:;;UT"]*" )9. 6:skxx8{xxxwdr;8_> `Y'O. fzpppႺF7uttҥKիҷm---illLJ%NIr-ׯ_W\V.^|&{!i+x FrxxjrrR'''bZ45Px́@]. IDATwzr+1by\a `{||F>~\訮\ǏG4Z鑮it-Y$d:jp:F]Fߝb76Ct0ŭnD9u.J%%v'繑tܭʓHԭ ҾO'LIQBFO`vW;`;Eypp\U;|gъ-R{h<xZ b'\팰z'瞻0`̼ӕr\q:a6.p*3]Α^|yJ~!}}}j{ӺtŖm^׍7Li౿(zw~@qll,Qk155j utthqqQ03ߍYFA@_ote 4NC ZH0 <|D#ȕݍ)PAa1οU&/xQݻwO_Wupp{g2ǻkЪѡ PHoxYc@()w``@n ?ݻ#]|Y_~YQ[l6R˗/k||\GGGzwBCOe?uGSW񉳓&䍯fj:Ct4g&zqpqkƃvʳS\Q$ϋ{ N KO%y<)0q r>3ų B|>rsl6RL=l ȓvwF@ AwggGWZܼj]!aYPfggJ׌Nθ)[BPV({Hޙ>dpq"܋"rc潌ŽJnnT4Kr/N'xOz[Hal|>֌}1Q-//q yf4^T#?u` !fȑڤ8@OX@6%WI;uHH*q12$3''!kY}GZ^^zzT(﫳Sj(xU K琞U*I6nnn.)˪>99Q___*z tLJS,RwX;|Q7OitjEA6#\.3  h4"/9yZ-#Uk78BE 2Lk4vvvh4T*[Z]]'|l,'?677uzz]xQՍ7Z\\ҫw^ryΒԋstIH6FTi]W wtkuiZFiM%"l8/):::" i#z;FNݍǘzH/ɄG7ŭf l:!z9>tPxr<$=td|u!*5>~ZUP=xwNy98SSSo*xUkh}E ֜xd2"( ye@ I^4ݍ7#OK DbSx1L,=[Э~HT1f(Ja<,2X.\|V>0O삙lF0r\%7X$ x9@g+:7^ggFGGF)*n8`Sq*$Rg~mmMÚ湹<6p4w| ^z5rRTק]FBhtffFzQR_t)J{ASJo鼙ҁMDFz.|S~jr*#jWժvvv+Ivr={ィSl6I kyyY=^쓧vg9TNa:=q ^gfggT˗/GǗuz7x#:`=|P빸]:s*w#hS.]VVС4ԝ=.:؝4=D桷9/5|>h|k$ޞ*J2WA003P ]@P|QPުIR j<KX,dzzz8t6na}}h$p?!r &500K# 3fyxrd.Cٻw1cC i099rỷ8uO=;zLFEI^=rmm-DA[i)to3kQ}oo/zL"ȥ'a᭭-ߙ?9W^bi@F>EpAxwtt?#endn(WҠ[YKQV~X Qg^9( '68ӧ`;Yp {faa7:Ν;* hRENN6-rO BA-3Zq+JKiS_C}!TJj򍍍}/VJSàzI!#4'tû#OpGe}ш^jpp0Nl@ Kbrw ۙ?n&sߋ瘽jqJ%]xQ}}}Z^^'hiiIF#<Q___Е0xZףv\ܟgӕ+W$=Soo533?Xܹsq(//j{{[xs7N#/wD^yЉQN,ܩ؃|,&Un0Djdj ݃ʃMZ k9xLl6 }1Ґ{_ PO owAL%J^!LL+ͪX,lo+O7$ܳ' i*DS/C#SEWg: 4Ƙ}O] pvʙuN;xf!'Nw(8ww T %ex'lRȳH  ̜&&& >ԧxfs݌4U,5>>U ̨?ܬ33}K_h: D+rj"%w0~Yk鞦/RkM~ p~M )|=0b!:a}w:2VjIa{'_+5(JގC(|>Bqo 5PFL O/yW~qˌc,8T7>dpBխ]ų̂X,G'4,φ<25|T__666|'huЗ^ԃsP E({k"d/|Ac&=@/L&=!ks`놖)i*wt576Pxqiϕ9== pd5}?fZ;=GSzjκ3W&QP`3T.599AnljbbB;;;o ^1'7ͦ/Q!3ú໾>: 88D-.]Jq|GBoon]xQZM 4'mnnO*J&kfff:::raeYU*U*iggGR) 3^ |dd$RV,uܹ8 B/"ϳ\vν*W^y%Z%޽{Wwލ;whiiI===w"T*)]]]q2#ѝ`é]2wwp:|| .@.^"[esjO|.Pqg_kyt׫kx "sk潽 XgfIt RO吆vs.|]vqɼOP鉧#xӀ.}m 1;0bSfԺ{|~s(krrR?npІ{';cN`@O@%9e2Z CsG:ܹ؅9)g;C xRAK Ԁfc6Gm( Co===΁%Q1<<9̃N  9蟥 4>swpLX SZv]s=\#9Z:}@Gxaŧ"9| #:z(Po .xSOOO[*SkCΊ!KR(BZݔ.PSAvД1"9Rݓ)q{Kֽ >vZn GsL,ܷ)24I++dI-z^|{/o}[qsJ}\R=7O)dWn9@Iq#OPVޅ:#{r(V7:3LꙷRZxa"Sl6#ON/^o}Qx, rUe펏}K_j1+c/Zk6zrܒ -:ixx8Ӧ(R$7xll,H`G^B"\.(4-!j۫kuuUW^2*FFF488)":<>K:F^߯>-,,haa!T__ rL&rGXo7 <*42a]pe}; 9''jҗU_dǜU,CDKI'?I4iH)dǞXOL1I ;uT,Icl,C7z\9M4=>>q*=х^zaN/D8\/G }G^bfrr7. X(E;R`(ĺv6yԿX"fm8Nˉl(;8wubNjuE[A ͦʽ;>>.~JJ!D(umnnFO{9}{ (}n4-E n8>r sO9TiSe/P) M;3\ٳNK<q?ʞ5BY[+^DyX'o ;::"}ËGrᩄ.ȑ&{ё*;66?Xyf!en߾^xAzqX(T*TRQ\׿.zgg'Y7\.={l?GҍHeƷ!MMMO0gfft= H F \.kllL<АBftʕ$!fS @+21'qn,--WfQ>I?9Ef[Y!⢺IATʊc.W٦F1f :@4?0" … ѣGS⋒:ggVzZ &ݸ3^]vdǽW_$;@v{GեOwq1F% IDAT44֚pl*OJXwE d2avvvZyS.SZ L&R(D(6j4 ?sA^^W&!!_֬+bw+WD->Dg[hgJω@̄uFn&vCCC `h]GKFhqqQ7c_%)h%@1p4xxxER|l!U.fel2M ԢG9yo\>@˳Xʍ@"l vzVx+ RwseA ֝`txOHwT7www#]/F?!WX\ r98rޝ}( s&|rY*+, Q@" sRWWFFFY8$H'7i`rp EW {`ϷPoë湜t; HZ#rg$ۭ#Yr_1fzU޾X ! W^oo?__Avvv]RWvJ Oe\Eĺ'ga=~!ܐte^rq)UЩ?#{;==a% 52}^h ZKj 2&^Q0'=9(ʄW]1RCy]pA<El6|+:<<C* j6-|7Rf=']^19xZ333zg?Ӎ7n)_ZM ݂iL,bggG_׵.mnn$xGGGw y᙮. khhH ;FZ ]ox{ܹsZZZj90yy3QɔĹz= ]>%j5T*I:lu@棻r#r x?DNU ]Xy3 +k1Z,, g~CzX"rIƒ˝5XON ,tM*5kll%ĂJj r{|#S0;!<{RS{RpjgH^TsxuCT6ð=@AAj(65 X,7P>WRiRfy&YgNAPr31PFфBgւz({:d2] .@{i˕tR/f‹{8r>NKp/+}텲n:c?J5g(urPwwtppArh622_~YFCoVIAt)iHoasEqxx-޼;L*֭[äQ1o%H.wG{hٕf8:::կ~UzwU( z}ӭccW{{{Ƣё#i]{pppX٩R2Ai`gzZdjL67_{n90a\Jժ499!xrIɉ79*  h G˗#T*iuu5tSʕ+:<a.{Ȏ mll(hpp0<I~Gkkk-###Axiz p9Nw洣!<Ҙ{n`J)?c1DZ&D$G%u/Յ)SƢkgg'`;R`<biRYn;CQځ;vO+4,׮؄v<  c5DEI W!LZSk TcʌD}uEeFE}}}\\Pdg!0vvv͛_U&&&4::z[ w_+++j AaV)e#w螇Xr~ Wh)y4BL& ǣڞQ (8viR(|/G`3.oH(B>D0Бˊ}MNNFBvwwkqqQRI_o\.{|V455/?<kգȕ(qd fgg𛘘PR ><33[ni{{;ݖ\g@$E{ypp??cVPJ"}ll,\#ﵻ;qaaAF#ۡ>Ou>cO7SD@֠}<ǟ4ph4rqG~yZ "h``@m. zI=x@:|l8ippPjUj5">eg֏>pႾohggG?'ɟoW^ݻwXBA=*+WX,jvvVlV~SБBϾBw.}I 7?ۥ7߽ߣIBqwj|7@k {ϝ;ʈ:4 4W \^j}SO?c<g ^L&^4WoGhP.A}1C:7̭KgNp)q"sBI >% _tN)CSV===tR'hD# .i꿾b}Iѝ__}W7|SߏX<$P֍ϹXo >^ngT4 O[l9ARr# 9x.izg^!0(qJ%cdzsXIР2dbhh(ƀG9kyyY+++j4D)ޞկ~URIkkk֯+[[8<- wB%Hd./j5'?oo@/_?\R8umccCFϫX,O>0x DC<~,r'6NؿGގ8Jzrr2MPACOo2Ru&>T9=\>^emnna>B!d*Ga0Ekuu5[dBWl_[虽:812WzRW!nJEo-,,޽{謹_!3vvvǏkrrRQK_R3}8Hl>~rgaJ>VɔhDJ(w[Ƞt\ N3Sy^(l6ֵ+v@/u=L6m炁4;l =)g2PX!V*Z<0s'' _>b(Q l47?ΔYy5'' X (H=Ծy!4W6 /죷hQ>˜1dXR?::OSW_UVӵkK/ikkK} rxӕdO1xrr${Ɯh">a`9a|i9{|7*R n0!B쭨NNNLn(E_nH]ٞJ&)҂rD2L*~zR= B𔡡H1%IН;w׾L&]Pw%g,IpϬݻwC^{Mۿm=Mˉl6B>c=|PlVkkkpƈ| UU}g xNRף{<#666411!G/--gcyFewW RJ(d}_G Xe~s{JRi`EߋJRvQppp !zY("=77d1.M}[ O?mq4 mnnjkkKsssyinn 9^]py>b ]?x'|Fj.9еD5'wk٩| h4ݕ2h<9tIj6aVUND.\<a!Cxf=<,*aEVLPYO-~3lx @;4`?wc~c`1N}rrvvvvT.#h||<"GGGڊBw}7OHwwȞ8foIzax̩se@GGGo;﨣C>C]xQccc-lw{`NOO#mu&u? 5*3p)@A4yDjg)yhv5݋c2Tfrpk0y>C6n}ލ[[ytӽaq}=|•z{ ir; 1Vkj/\.5|^,555'cי Wn'XٳW^{-$ra=TNOO+J&?x}!<J%[+Uvʙw0GW)C.R"+axn铓 Of,nd@*tgY# ||y m67[ִI$vmmM7n܈hslookaaAw܉bޠ{B.C=Rh~||\˿I)\ __]?|k0o~hj*2Sh5w}}֭[$I^zt==z(RQ"|xy~ggÁZx5886??ĨХKhfDRKݔЕN3RC؁4]yE(MJ uu>p^>,Nl=q@á=4HPoooK5DUx`hY Bu8󚞞^_W!}OS`R 4԰Ę|OA+caŸ)HN3i:]x'2 M%^^R+I&to ]A9LqzESZHi |8S hQJN|L|.1@w$D0 Yn)O-: _gԐI=rѺ:rffi`)IgF !3?^k}}]ZMZ-R{`bvЬ{#-6 +߼y3B(Kf[oE+D[jOtЊ zօS(L&e JƘR:q>Bݦ+c$n<ᇏhU*mmmi_>l)p4l!aWԔ/E9J#4ȇto驦@ ]:_:}3ׯ^4s`|̓uvvݻp='''˿hU&)&&###rr5U7͖G#A###ZYYQ;;;xVѣG{R}NOsF)k50ݰy \)_JjIk4Qg k6"A>͛7CN@.+<萴r2#IK1)6A kb=9bO]H1 ~BrB$KHJX%V&$7ەً|~=7Gy=~o12_gʈ<%4T*s:;;u( "rwwO¹mS^⢲٬[t}}R"'߽5.xvm}YU*e>]G}F}}+I 3bqps0@~M=Y32Lhq3\.^?WWtR'}_'|b3> =qx H' x&Ʊ_Ec,t<Ԉ@e}_VXtp qYſl6{TަE+/^}U-//7&MݸqCcccjRf[M>ãWouwwAUxCEU*R ￯WW߳;'z{{k8gʊvwwn[KKK-=ud8H \Q p2 Ԡv=%C:{\3rā-v~(q ಻[GGGzQȦT15Q'l_3<|;z뭷0e``@ ?9OwIXO0~wNgqgחiTsw2!o]^m;oz@~n߾ DKUCPN|ߕ]Py-=Puww\*v֦_71@;w> @wnL&R-0( D} IDATwٌP_D3Gh4Z<b'x_xiCw'8N#!%9iZ<xںcfQ۫jCQ쓾%v߯NPcxi[yVAI 稶Y@ǩ81>G:G]Kn;T>޸zUJ_FKſ1@ t?Pv˔䈷)i?'F,I>ţ(݃ NfQ F> P92z^7!i_#B=F"`00F _o;c߉F( o:i%>OSj*@ ۿ/T*"'Q[AY0ҕGBT(O|?g҉CSєkXI5%֮&<;c~~RX999iF7T*Y--CC'T%4kQn!z3FR1sx Ou#SfbVC\~ߢf !"$)b 5f2nzBVC<74! amm=byǏGNd dKKKy{{\JyD:|QyAMk>{%Q_h+/Yh  l]>+S7PfhW7oP(`ii f9#c_f199ZM;d+Yg^ R lv:"tyϛWհp8l=x ;e{iCK}A@TyG߫JN{yZ>KuPK3Ot#iA[ODI8֏jY5 <1j7O$>kjjy$T?$ԍB!ۨ RyoЃUU4#>cTtA i>p|N7*q||l5QVHpB25FԠBQʊ~c3a4(^ k_ׯ[e/5kV=a_cҨiY騽^ܴ155JbD`sss$j1а:Nׯ[v_"/Ndq(888@X4gy0=\ 52IyS>&''-Kb59lǨ$pttdcHRVC|||l44b1\z[[[#<@ɒ1ܻw?>ҦLvD"d2Bv.\h4-X,V94MD"a-Zf2ȠJ$=B0kaloo+++CZ,L&47q3KԫS2ǵuaX#^,\j ?# BD^] DuׇcUVQVuRMOOcbbbNr p5zI[nR7mHӸp;[[[g>__=ܸq:}5 a||:yAa(4?B.ty%S`FAi@q]ji|t HrBBȲ$;#Hd#B GKӺV)FåQ%#HgE>ݻwG'5xX,bcc>,NNNL 9oN kyk=̢qR_U]5@T(OAb5Jޡ rБ ԙqʙjT%_GGGVևJuSzF /}kkkxR0NMaT*}K23A~i_DP@A^1:2xrrE?!ozL] AlzzG?m'''X]]'fJX&V 󎭏ruפjl%?3h4p=<۷ u4쩮b9gggX[[~rPȢzuG6JNOOa5tތ 1Znrk&H#|RQU_S}O,ʯ|v x@̋%vv f n*(3scvvvDt\M[D9N#cmm R {{{]i-I .1d2xgQհK.YvwC,‚y j ;R'|4i`[*LԮkN퍾Sw'uʗ*8ˆzZx^=˧x)O4ЯB!YDVk42 ƐL_Tm~Oy|Ty*vFqgff~wlɋNS*>5ں=i3xv'b8>: QJG7*`ip}N,xE߹'mXrJlD]3'հzO]%}x?\Gb>`X J{T'm><_H8HX"Ve| J%73NOOT*!}{ 7׿(L&^g6}a@x>>SP( 9b2`5VxgjF$аgkkd|髺@RPYӠ% ;/:8rpx,LQV#QuA;>>Ƈ~l6ۗD𺇎&7B!;qrmm2'''d2DݶtԧL ֡'crrjN|wqtt`BbVK.>llj=xÿuw[|<坼YF+y|z/j?Jg?gTT'vV tl 'H1b!hd2O6>GMB^ Jc1 SLw`^*?2!4 ƈ>C#n hFteh4jZ ÇSx Ku #w b$z=KGm̠ﱺׯ޽{xV mxց긔^~ p/AF>簞Mk}W.$e*^nT>Y8<ڎ.3n09?cV j:$jDlo>| \p#REZ2+ݻwDZl6k~ll (۳?m½]FÜJ;w`0`vvtk[n޼bh6]YUa*)  O54rug*W>ˢc,򝷛|~)0OT%.X(&:Yæ 3O~\iAUF!X=Ո2MKR>_ʟ>RF>N.Xi^gG@c.TLy;66h4J7|/^DÃpvvf'h`1z𙺡C$8q0ɚ_Pi ?}y@/?ըy~2Ԥ Fؓ<5<@YNCiO9 '>|/r ylnnbll̺^?MPA$^4zNڒW?\.Y\\q\YZDߩ+H4I9 ,-O~k=Z-LMMR)ۓq' {}-$ +maУlZ>P(^]\xvѤR gY+, ^vz;;;XXXԔq3H&AT£G-+A;;;V^׭Afʭ8*z-LMMY*#`~~;;;暙4@+Pkf\>tQ=ku{#X!( ºJ둀tqr>" ?qJdRy&G'敌.U@_Z!qi0u.z* 0#SVǨc]Z tjD _P(d=W@\۔tp0eNeiIEKPb&2>㓟$&>яbuu}Fwٺzi]=beeT*HRVx!VWWG~Z9I*_ (r4H2*V~+ptt4һ4t:gw[[[ڮѬyfgX,znz+ vn߾mc>*2M9A @mmV@;ōX̲V5ӧ`o҅BSDkr氰02F+ Vqpp=r9Ln||F8>>F.YZ-;q7h4t{Yŋ/b}}R4VH*fkVb>ئ{]:!\:FY>We#H&@N~eO#T PpG5.bz=}N\m;IX"hEj42 +c:J+U1%دR#x%z~o944Ќ.5cccV[(:\.Iۈ20;TɫW鳷gG FCA L?+|>^z #MLA @,w~o:*w: NA_4mH8m}p~ju0 -`0KmS702OW=Źr}oo|pHR :`䈎"I#ú LHӈw_jʑ^TW&t:x MIWO0V o8::B(ݻwvQ(,0666PVJWseHpx IDATF=џjώeLMM!=x5(Z>nJeid-:&-yt[i/74 G}CrՑӵ5,H:waˢ\p'''x׌*vwwH$׳Df?ٳyDEh4jQ8$dF|1 P*kccx=dprrl6kl\[n?VWWm ƬH<G:kzffl@ F+ "j``%!Om8yC %5ԌGhɭAH.jWgi%-V]5Sy rHkH9BSrNOOg@zffӦ$I\xFC8T2!077X>U],S!0jk<< jjXCk ;C.nQ((Cʘ#kll fI5K+~oT8V1LB`BTiʒuԒU|Ww{ŧkS7n(˗ tf"E<5*flk^}Uomi}}r#NntslV1JG@~؇n#%B[n ^}[Ԟzv`ʧ9{#ˈD"ںe+6&&&0??qt@1K}*},,, Y D%R K#MĪ'0kBe<~%y|:Aʽ Ϩ?;c*.}UGROeub]Ab5J%Q:xOPX^iL'Gu3\1 ]H΍޻Wh;K ~G︀|FX|U^]| \.g5x9yuHAwvv)Ç#!|Uοs*TO{vv]kvXP@&1c;Hs1e{zzjb+iFa}4F4荱ʂ P(/d %1jf?ʂ?^^H&c]tG{ OG=>>F@$\}{x.w-]vٕ$!TzQ<GӃ{ʆ!ՍtN d}<^y?u=ԎAvq5ml$ {vT2doZiʕ+x!2f+I{:tJ_!AQfy 쁸Gu*#KIH 2)`C2jc+!-<&.hZͦG - paa(J888 fggu8FP@.C@VvvvmTy&Oԥ|&''qeLLLVhXV%vd:=򬮵Kt tm<FgW>`gq]%o*/L8꿬 X_CcH~X.rp,~s*)0w߷ 4tJ[cM/rzzjXzW ן?ONN}6#*8Ѳx<7oWP ?;}AU &D"%$Ij5BN4 oΝ;h4~SSS OSZ+p`R᪐{ӵ4^>>QxiFGL[0r0|yg2|ooayyJ}tfp%-4"*Ae>b1{/@ׁWCXDX-h?frB.XwFp8lQSacvQx#u= ^t GGG,:ͣEY͍e 5P{%ƨ>Vu\#|~I4#R6M)H`eekkkH&&'' ݻf7|Rvl6ocbbkkk( lsl:'ƐNh4pxx ٞd2i`̌򎏏{\ƣG,nm?Y3VבJ[ Y{eQSL+ycb |B!k=C?h^:iʗ>2uұkJS༱>ozZ')`qq333۳(SiV7а^x[=$l΁ OiAC:$foZ*hX>F~V=тty|FHe 'HĢ8==kX aPqCP0]~@>NLLj5ܽ{hhѰ5vV 8ߟY>4P@1b1^c~~аW ,vS'hĞkN~uى3?}'Zwp8luNvfFh\{@vQ=111J2),Ved4666PT6<[ M*B^2qk766JZl6]su -iN'ަ 2`T:/fԞЩqhXuGTkkkxpxqummx$Ht&&&ОmO}/7MLLX~FP} q&Ԕ9{{{T*H&ՃkVױ73nV3;9MMMY@Nt\jc57VU'@s^N)??ik04 58q=('8T,1b4CAczSnjIS89^>ʩFU)QwlHyD8-SETC@q\(O6hnPyvv6o8Rs2mF oPXձW*loo… }P@-4B3QE t!uP,Dђ >^[_?_= ONN = L?{5ʣ"1GF"@Vs ERC #=9L\7aѶ~ޟ2:WZ:`~~~d3yJGux~ԡvw^{5KϷϟRg5|8Wegggqmp3 3i}v7n@6aX>:oaa^0@*w{ (h{Рr(ߪuAoC L(kJ~_C&''MF}vWyp=99P(C,,,ѣGV(=cwwL(8y@2&ieRɲJp!ˉ8B`|̝.<氷ZD"a^gYv=Rua[E;i5S:4WpQ|S-(Qe\Mo*aVo+a SgggC=o QN6(B4 /\;!y`FGǤ)(/:NW7hRe*kd=3+;kصS:h5saRR4b,4IAA*z__/ .~:2 nݺEǤ"g'D@OxT\(/*YGtm80;}QHo}'A`0ȆlK˳s9HLKnooOxr"vTb_A-ycuua.666lU+ ~7|EiHq\^^{?[nfggHvvàzN)G0 p=E$ Ö37P)?|b1lnn0"ճ JQ*9YWj)W`:Ch9OO[4+tLXuF׳RZjԖB!\rdr`gT*|>J˗/w}"K'4P^6`_rCLMMa}}qP(dQ^҅sJ$)bmq fff> 609ڍl6k*mVuVC8"2z\ԙF: ,Cyy;z5]A+H>S 5W͹HQ% Nҍ0n~"L3հ[} B8p_So>wiR/HUpz?3jxHFXU{:X5ꨴCc$2%0K&Vtw**sQu^ )lP ! Ay7߿zVU9àR 77~7tpU;؆c\tc89ӝ?ιQјpުnU**|'3.``ά uuBVpU[Oӱ :=Rfffp||l}ONNl#.uɯb1;$&aoo$i0޽kQX}'KJyNz0?D65uS%y2ST{766099iFvwwWy}_2aR`Q#<1HMNNZcoZXYY8<;?Bɱ7fT*# IDATt#nA}i%h===E*M&xIg?Y33XŐNn&''qzz)uRXXNP. ʌS0M!eޗpKUGz mb ZѰȰ "t\cp8l-Զ( "RH9rlj֝gj5,--agggkʣϜ,"177周-/U~_yNqO\Ύd2iE=^'YS?D#m #g4 [W}h[ {mc]R3#j/5:]1iVǃf>椃f:_Y$Ḍc{ev@/X'{ճ%+jQo{®BQU>MB(*S=dBF-E:Q~ņ=r/_gFwy~P]47W=BV699H$b"0iO `LucKyT kkk4]ͱ_rl֌ʚ*(=3tH[`x^gp=Pn:ֺQS#́Q̨FɉPɃ|>}c7>nwܱC}Fo\h2p&k- Awtt4" vIPc 'VGy בf ׆uNFJ!vh4x,:|>S3~Oe` u4T*h%O7,J kԋt@5?/,Gï4S AuH8F>:(J~SHpw;LMM:i BLݫc!dN& /7nG:J3-!ѵFRAP)>jGH^lȹ2וNunduY.šo:sss#u5CȍޱW]C(övQu0ieGiI+e PvA8y JTN~3Or ^U95T%QA>֨5j sXL8Fkyt7|U?a;JbE f|I O̓4RjYeˋ&-[,d{uSCH=5 +`h}#?0aE,--͟Q`9ȗ|1/0˙h8ݰ<ꦹn6V~Hd) <;x،:, {U)o(sc*z&OK%_ҀPfU AbCYV`H$Pl>tus%0P(k׮vvvpppI홁`ml+kLeT&E5zv:AF˸}6't F#aW_}uDqD"e˲|kpE$ J% OLtzDj~nхcU`@ZkI G4E.j0NV3yi JKA<:[[C3+j֤ʪ'eLkg.S 3Ν;xmݺݮe8/:"V /_ƍ7F:yB{'N=ey ˍp~"Lz=ŌɃ #tT6>lyadYy 0[&IZ-%sf.|MN k:HAeC/ʴ6P^I2+K5kwq_H g t!P^ЋƁQ *B7|HpxU!dy )3>JǑqU|;A7lD"0%jdQ7w^7:i\_H9 354fҘ3ENoZnH[֭[#9sv2( x,Z-̗L&|W^E\6ړĴFa"؃WeXA'O+(|uxn~D"&:javv|wrZ ex^h,j0F:fo:w bh .ϣ^[+4frV7s*_{4(A^q,!c?I "`5`0,GRA>Ғ%9u-Cݶ͐l_eY7ZNR.jL&"ұjZ|ɤpza5n}x[k`ec_ Nf ||G2195L UOGp)޸+r'1FNS@ 2VP`B= + i?0"Ȕ.*DU?2.GxIjDTaPOW&z)=BRWWW%Qn$S e<Ǐ-Mo^2@GsEk^ǔH\3 z-|[oom|ޑ ;cHcTjJy)p89b CzhC>G4BH\b]s=E_^l6Bq/gt 5D[o^{mĉ!(iZƓZE"T*|[B^z:^*nF_0;;k=5UJ>$`gj+?#oᡁҵlZɇ:@dZ:*'I r$^)&FBsss}m"h O)O%R r}X7/?鿣!O#~JazX|486Ҋ$)k C.\, A4Ymu,$E`zz6H$b97w蚱(j He:t|>?2Wg2BSokkGGG> sm%*ݥEAAH];GT6= 9.^joyB!DTF`iIBK}kBh*9t3~x μUbTqؔtmҥK899A{g[nYS`ze@iyU}ڙR~+Wذ9yNg䀑jΏY:4pD"r (mȓ~v]LMMlX,Z$`-uYU0mc(֍:oF+uǽ^6RA9yyܾ}``hYv&~`ׅM0^.DPլD;/26666jF1l|=1<bT#冲8<Km#3J)qeAU}G6eHfKId2+ϠΘ:677G,f,bᎏ[*?~q6 Og &l6d2ie\ԣ[FY.1 kZP(P(ظQ,H$`鹹9loo#QjZ(VG`Y1 Ϫ;w4}{YY?ʧZBL Ve{Q!3yæ/ ^ ^O]^x *@1$΅轼AhPHzߏ*賔aI WFIj 9OJ9}kkktn޼i5`F89PrLmQd*'k>B_~ׯ_ X /E<obmm Gq ܼy[[[V;F:Ӄ $j*/-rF>f>f"%9SC?em4v?\k*.^|+A/Ȍ,,,~F"uj tޡаkE4Ço+++ -c}}wERA*2N d` |Nyu|vv9\xէrm$ãU+m9V]܃o~/` v= `{= w.Fn߾ȟ?i#>B^t:s._lǣ2G(HrCW5RҥK?cܸq/b޽{U^2i#mLF>^jشt@{ڵkh47c[#f)E#yPTTln&aoǏ^*p5žfQ*L86FLx(h Pb8BeU]OajjʎB皓4܇h4ւ `ff{{{˿K|+\.gq@IK-lx**\ X0<Љ]DF9Abii nzgّo\gҖ`Dy HGUǡO> ̐N 9n}+.|ı1VY "2 񸝦GT2K^eKU+ȽҕόD"d2b$>2O=S1B>t"7NNN_:2 fffpᅬ|>o0KȷjyMRHRfj&Rʚ@>*>_7}&v|PX\ׅH$2r4z>\.gPlk;HxL(Fd4(H3ұLGXcyFZofK9Pz@8Ff9r!u B`z݅h{ H fgpN<뵰U8*T.O3K`qb1ܿDkkkx7F'''֣N- #-ᩓɉ%IL&3r?M\ױ[y|7!HX,\. #;s||:g/5uя~d"&&&pzzc$ y}|eή<@u]X]t:"qcccik{#vPRq̘6 2H0N,圲5"hE0SцZ9in&j]yXuS|;>>F˗qmZmr VVVmQ`FL3Du vLu4YcY ‹@cX6033c4 73V#tǛC΃ze0_\,ZR޺nʇ(S>SԱeY]?iN5W s"N( .MKK ~ܥ~UbX*^^wk@l08H/{5FI9 FNjO]_WSwL&őhM$ie׾X,mmY?az+ l6O~?\k׮;vwwGnΝ7V^r06>=QnjJ;fmq<G:6CtxxZf 0ičl#ܘYMD"TU|_şgA@^7HG"D@NeZzulCCZȴ>כ27&Y8 ,5'l6 u7a2(Ӽlw622 l??ͨ&% IDATkۖ2|]_ׄsx<`0d2]?\Q$޽ ܢ^7D@:N:B'I4 X'ښRiUבL&111aa||:;VKD嬫:DZh4DQXpHIJt:FaĵdGn裓7DLbҁ3Tp"ɤ elR{͟=KAm/<(<Ȯ3w=z F#өJ(_k"PD❝!LP(bt÷VWW1111x?35l}#c6L"ˡnjp%XB]C.Rg]miXE5$j4PL]ʚ`׭g0 ca`00O)#QNJ 8(T4Lliz^э3ȣDzhe3B3 7`3@y kAʔ?*Jf̛&* h/E@`Ab7x#bVt:?73"/JYyJJt5@ eEky~k.u:HX R6CEQc],tΨsTkdC[3;j5P9{~#넹jTw;9/,҈]"P;u^IܹszD:o߾mH` m?4MjFtz=ː8zAq#:B[[[r&,cccVF]|O{H"Mt$xС-ԧ P1S^sjX©{%BۃbsjD}Q)x~q%}yӢB4MݶŒf0}l6-]䕈> Dh$I82 IavAqU,6MiJnI׿t?o{ոݹsǢC4T I T24EQppyuams#K~hheӧO)ʋ |T*'z BI7uhitk|O >S'k@g$JZtbgg᜷`FA@^@(t!`}µ5soB'/uFt3E<74)p`?~l;;;d2AQUnT=Ȁ7yz$;ntuL\˻wP( `nnD>C^hJb|xJ,2%:|=kչ5[~Weojj(? H65Ce@1q@ڵk%{ 29PxM`AR&VWWl6t2ݼiLzi}p~шzۜ*c,5 MiD#Ɨ 1Տ ggG+ YP(yuIG*ҔJtVZEGAw*ԩqUӽ^Ge|[BV@ ĿUƔOؼBU!Qe:x[Qq:WZW_ޝ!B7Mr9K5!=fӉvLx]k'&&4;qD :C[&B3rUs~86|AJ^G{x,/AΝ/f烂 ^(LQ``Mҝ:C+!L(Lݿ-dYX+H[ qu 0G $Y}X^(}_J;_ב26xb']S#mj"cgV|KӬ|1]4`ީkBUkK zYh=ޛL(W=0L;0H~Mj/>U@ RT9eIK>^VA {=~UsZR!ޞ|wGNh*gk&mpSŤPW^g#z?^~e|'V 75StgD1\~S0:nӧOp`(֙}w&10B6&~sjvvxƆtɨ ,e`vJ._ K!^4NtSf.47 S6#GִZbzzڪSmZ8>,O$` nܸoF;eѵb/Ae'riDAm#4h((EUٳ}ٟ:q ƍ<"ۼJ˟7OL(qXpHyT'Jmn6^OSF`Έ+4[K!VM.^h΁'.,,ڵkVϹPftկP ]} *~F|6mB>/xg^&Zkrr6}%S]4DAD5Ƴ@ h De "xq_SO+;kkucz?=]i~kS)TWE:qpPbttT ׮]ݻw/0# ˡ޺~WW9Q.$yڧUitKS>EQh4pusL:GێVBIa)y2ͣti졡!,--zB!AWFH~ B!O[s"_#fdkkE}3Z|>o@e,kvZfYN?~###!eaǵjC&A(BP@T2 BpsS#@/&''kѣxqY|EZi)eΝ;x饗GY2s5zW/ǭ+=m+ӎ&>:8ݹsBd2AtRg̠ZVY*k%>x7e9S}DP&@\Tr.,iGnJ&Yva}D6>cpغgjj xn<;JLHiGPT022PWFs4"JAA5.6k^2rXCJtH՚5~VkԳTs|>wR*7h2kx݃frJCe2uhe?~hXX. ~>#J )læ(T+ϨñjBջH&SLK#9 .5QbA* 5 F 4Ql-Rk&6荏]@tғd 000jz z=\~@Zs}~~ZR:Dx s0tN8]"㘟 4F1>>nJ:aff.]giB! xgF-rL&dƯm?Ո'LXdA$^|E 9'SP}Q4 E1?N";;;f&sssAѰ"èx.2'dpIB!?6> 8u,2 ݻg+ 49rr/E|* (_)eF*:8 Xy4{6vXj m?~hJ.]2|IkB'NA&nD7^>')]/>^##Jف$a%g|"( ^r7zDGjI@yc⥁H$bZ>?'[5xyqv]˖ikՑ(Bd2v0- 8s * _YXX@4 N:xnd퓭<|g_.CgennRh ;E>>>퀾e/{>vwwq $ r9LMM! PzNS'}9?e )Sucf# ulء4gb3:ȼqށB靺n[_E eqP( T* dYLLL֭[Q-399QܻwbX̎vA,֌yُn0SŬɽb7o֭[$ʅEB"~޾ ^^HT(@(7?KE%sp,q]LOOz_;CiCן~޲[wbxxG Dѽy-?a9W"SW)ʶ\|!S9jDD%1==AF#Z;G^Tѱ5&j:)y'ҜCl2(j @q~u8 nbtF@Ylnn=(!HӸwbv*)K\'F҆`Q7F,VLk>CшF݁Y76J ~<;iGSMszξi:>8uFTP2#uΉg=4VĨ78SeNx<Hqk#y(LWVROiւr]/FT'z\.g{T^"FGGvW~iqqZ%Ov]#NڵkVF]㩧 8#_Ҡιp[22KKKAҠ7Б[umPԔ A~ }fKNOO\ϟ|.eZf@^3׆ P#gT 麖J%4 LNN"Jӣk̚l)G'&&0==ml9hΝ;B#B;f&FGGH$mxښӳ ζR{D.r8=|>r|?8~龀 eA.PYQT]*4&P|ZqTUJ%p޻xSpϨRj֐N/* 6#y_X6hB=jҀIߺr|nyXXC`HBUViAΟ;|x~͝V ՔSoas|Yݞ#666 A^GPlb6>80LZW3}?ΗGQ<3( 2=>>neRpt*uFQUҋ,M[ZZѣGGiBFR!#~qp~̞?UnO6ҋ)M|DK%uF:IC|"Շ|6&(OOO}~NL:qx6>pcJh.CCC ñhǗex7La;###ɤz'8Pj5Lຳ `tth'n{,:[8M&5=QǨ_Hy p\sSvJ;O\]J+:(a{nƽ&UǨzVyQ*яnkd4Z4l"Й3gJ0;;Qf@gTq+(c,޺u)i(=5J;f8z(FFFPP. Tz.25YwP̔6REnll֭[(<caa>ÿ*xS0{Tw?RK? PKucg2Ľ{h4lǠ o_׳0NV0F5:F5 7eKl17??ꫯZFc5޸:_'_jI \ux-IQZ*8tصR?EPXy]v}9ftc1uȈutbovnd2rfu/1 ;hpZ|'ˏ4NP:&0iI+kD5MFFFlS Ll2=c}14 ܼy|_җ{{J% ckk W\E /+/>p:t:6a&]ժ9~7&wTOK6PՐJ:͠/hWDtqqV DSSSH&X__t"h+j###d2ٳgq|'?'?AR1Lj)5Y->v`dgϞ\;ӋGOտUc N=(@9QF|>T*e5Ǐi zy*c+mzŲ#{ޖa!ЌFPI{Șz:gG9_~N& *_t:ў>z=Joaa'OOS,H҉ho{5tXՐkĈ2@ݺu>3<ͷd7{=_ՉZzquf1::j{0Ţmj4@:[{>5[Tb~~KKK_?y! #`mm:#KӔoBR} 2FZұ`ܐj5~MucfH4aA];8rZd2 kDmu"C?]h4\.g42[?mېv]wb #=H+sļյƝV'}"FFF0::y;lQ,y&JN8a [LMMͅv### e+H&Z.Ps-hh [dʝʢ׉{{{f48FԑQ4-KZcwwǎ33 |/EZy/lEzNյԥb(Jz˗qq]}r6773Xd凤w1166#GVg}=ҕz]^xWo߰wbER1tFȱDR1v1|gPn=0l@=AwtCm:^Kg )^7 :L&uׁ'ĽW>PF!L&iM|UNj5gD"aA0.:[^ӧ9rG 0aK707g`4.]wgXu0Ld`P+3}I4zxn;?<T8.ʔ#Sr'.#w!De.jH xBF/(jP ;s{{{8}4r}W4Tɓ' X'#'Zgi*-)Xzq]7;hjuUesɑH"dGO?)+Ћs hfC7~׃Qikf9HSN8aQ߼Oܴ oa$njy/- x'PV!+#ji}۷ockk ċ/VO?é ].},--᭷޲9F`ll O?42 $2^{5urʒʻ^. &N8n>d\.[H`ʏetv]|sC֖3~)\7%x<-P " m/^ģ>j=Cqܹʠ<&"(-*)< Rh{89+Y/ u^>®ĿC&ĄkM9 Svbm}PP-Qf#΅N'ir6EoH?b/i^T z:G 8"_HK[SFE!S)aoN#ThTy?Zf=1[0??(*0?g9sN8]A,..brr2Д6E+Zy6F̨tp=h(xꩧ oν^Ǐ vwwJǽ+SYʋ5{,Fh6߽)?GcT*p ;v̜3N?ezN?CP~iC_^^9&eFtP0Óf"7Ockk | 0779[Cq 8)HSC:P?x BCT*(A.CRlmES<~hhT`$X,P(^R6o[D{||<$CW^S駟\.cgg'p;1ʐcW33/<&*,s?X,w}6z2X7yCSvG&`{kk˂;;;.[-}I9G+/-Z{ʚMճKp xv@Ǧ@Z_cU#D42cTH˜ґȂ@_7!J@ǁOH$b/3/ vM05 hC)SM# eccjL(v؀NfG9~4ګѿyj`p=`k/M\#*PTgʅ^3bEâʤX,/j@8B!3'O#{jx[Mq)xK 4*0U#)Pd䐵lADZj"H'$鴕LƏIAF3Ux_*y_F96,oey}D Y&BM#IJ K+GS{*7p D"<#GѰ#wN>j|>o`Nb1|Gx'FBTB6zoFa&wFAﹹ9qܼyVfqieLLL ߑJ̉8zmVӨ+Y2/brrLNNZ6FZ">\QT̙bfQT0S 22(<׭V!W^ /q?נǡ%5UJNs$|)&VK&^vYfĵAlʣbD砥JʼpEBHޟ)rFPԀ7С!,//c]'LbNgbg<43 @\v O"*ݮulڲ`_|EA҂s&~?OOs,FX__v5J..̩JQǨf2.ҍkJQ@iU={du IDAT8z9)THcǎz=X]]EV3/? 4DWK*4`N 766Y~΁+P(dmyk殲cuuhtRTTn9s \ٳg1QVvbh-c5Tgr :>̌({]}`DI|.S^(]3y1Wo^///#cll \Kvɓ渄B!ˀD MV0>S<}cgve~~6qLw̤X,^[Gb> p8q0VVVi%]x%k1כ__cssvۂlf(h۸w&''njɤqd_]ݔFz}\UA8s挝R^z |ՄWUz=~cg-R]動Jwm{_ѰREd8333w^@^ɇNHX@Q&}k|GKH8S}U#5Qfuj Ѓ~D餴z1sH$ /˃o @ ^NgŒ(GrmX^lھVbBVn^tdTk_dRHixi:BB`*(_(oΕǝD"׀T "MUc#eRb1(7UhN"`$[4 Y7iFMyS婆 R1RH$>/Fr*IcԩS\r\tJ SuLR@r5֞I+n\.>8894 ܽ{׌4׊8="1<MN VWWM69r9!IxoT lZwxcQSNcPP۷կ~ZO{Y$eCt5ꭶWԩSj53Zޥ64F~}9sb$ :*k8nE1CZ-[fT/kA8Dս@>G|5x/,7އz^\/}~e91҆ tk5Lզi&Mi_7B򳔋f(DFQyh4 6?K7\e* ʟ 2jEc~W/Lg$|_2zGo6v;D" lll`zzڞц=z4f*^H{3ܨ>*gz4fJ,Be>}:@t=l^X kkkfș 'FXYYz=d2!֤{>U=88wbiiɺxyRD{@+"ԍj!T(3b988xpj\sc[vJ m^ֻ+v똘qy{ЩP=Fz]M_sURyбq$vHk9smpn^B'1Jtݧ#r!~ fmAav<tӰ6?]4]t]4r\,|]y{udzαih]5ꧩuBhI;} 5& ju\~(LS~}|瑱bԺߥNR}qLNN֭[f([њH1LT*Ydzggmz=|< q)P駟0޽h4jÏ?bցH,iaa{{{r Q*066Iն\IJ2JOz?~7h4-hiiɜ-(F'h.\7 D";v ׮]cTzxJ1jiDw-cN$IC#:-ĮؘM`EGAnTPIb;:f $*ntFFFmHSy},Gj5GL쎂X-% #px01Kd1e#LiiUGLr/2.=65 *d  H1SF\;{ }CQP5Z^^,,ݻ%<:4MhĉHR) ]_AzZpUXiAGUq;ǭ%=LA*_v˗/7ʟ[x̢ܤ|iԗ9+JǧsV9CesgT*!Jf)tt>Rŭ$xx*iS>YI$#>sʸ&6~nյr,4~F孟󝘘*ݻVt:ґUF~X K'HKO4 H эc|'-Ĩu2 @vqqrٜZf|V{y [sNF2xB߬cPGT*!a||<*xuVCT29> sT]l5*פֿʯ#VDNNN̙3h60o4@CBi= $y ڑo߶ pȳ|Ҟ32;; >`,]@'(e : Ûog}H"֭[<2 R600Rd}GFF, іm77UzL+L? V  m۷NqIT*ܺu rvW߻wtjumPǫ}Oy+LbffҺ JO k.>WPKmt3;#e?@/X=X?|FaCH4CH$b`.7u:,..b``7oDV +I;n˗֖Nke(R \(?*v];~… x199i'5M,,,X$:Z4O׀%S[] *8 y?ods|n!}S?vGF5Rؕ|We|pM͕J%`u~O(yfi5/\Z*6M[`z-" u-ѽ 9`xCR+b1LOO= FЬ>(Njamm#AGq'u(v4DŽjk| ʼṉaY:b*{nTdblBT7U)b>BB 8}dZ z h8aB]<7Nd .FH$MRE>t04R#:o_SG!ȄʧY\XŋfH$ ĉVe5*] n|I?}VG:m:V+ŵMeͣ<]zz8HC7({Gʘy;wޯߺKtThnn<iNҖeF0akQ.;J2:[9g4gʝ:a+<pv [!iD]hllWFf,ѿ GfxtF1g0fg!cIЙ3gp%=ctTO;lQO q}o/| X\\ZvL&cǎVVyU˾]a|?۾(ئli 9جdc<`K}JCʬ1\P_ ZVeWn- I: 8 I7Αbbttx&8U H$`eP|&yY {vi`jy#t) ^PZ3~F>̅|@fzr|m1xVg8!*H|IQN2=(_[[[o__5ݵ^z= DpǑJ044r0U>AN^@9(500 |;[h4, WH_w5gy$ LMMN#jj}xʞw>ܸ4ۆPY碭 E9pv1bHR[iH|:w9/&[FaM֚+T9=t]A;7ؖQ$\+A Ovp{|k!*X9cRJy#AGZ9Љb`:wsjTGKB26Q*rt`L%_Asr{d,okDJ1R8g=M=TX=? zThtȔã#ܾ}/^oo^'T>}NӱyBa@Ys5Y73Rcŵ|6S4rSޟ VyDku79|;tݻNc-w@+@9*hAɈhU xzA  ,ʨ uPzeeRɀ!0 4O{VzPcԵTU/&˜z^cC^S4b642LޗLKdxkt^Bym>?ʫ |tnu𘞞VVVn166s?D$1 m4{ZN~zxwnqر@TVN]y nլ uw:`}P<Ν;{cZRT`,Ѩ:{Voα3C8CbFFFPP(*}jd2}`kKBQב+@mF=Jb@ aXfHcDnUVĬAtZ5@WLsWg6jMof,4` Q jPŠAA t5":5~JVSgPq>> ǡJ_35>d2@&s= ,--!bqqzD{^ީy{]{ UղhMV2z@w5 O{>jTHO d{^{5|uC=_\Z Uii}=SʿLAtNt:HRKAZ$rPcXMeֻ^ݻtUѴ5.ڪ8ՇJ~V=VǣkP(d8k|-Fu_+Mg#y甇}S{x:pqjݸHcf?U IDATҟ@ΗyQV'N\.ckk nǎC\ |B 3G]2끕8N(jaaa% \Νí[eBA]Sտ> ͋`Sysh;;;xwxo%6j\vi6V"CVYy``T tX j%V'?*O5iu:Tlcyws,H&jrЪω5 }OP0 w\cF+CD^9e,#H}TT+Q 5rSS{*U%OC(*Sz#RAVECOBV Ε |fӃ0%4S 1) d/=6̏5WhVӑ4W{;+=&*G8?Q/ ;Fά΅"G$29_ҒeLY `G-J{l5Kƍux(˗>_<}A`jOʱL ZG͵vUexpƨ%= <4,.7moocwwzH|~$HXف0yI-v_} 4eQ:,QQ'7= XiI1:wԆb~$g2$Iq=9s||J2Z:v'%a@Y Kާ>,Ba*:Yf*>2K'&~C3$|*2gމE7pu賵;2~#4.~A3OÐN1 jo#h69sr1+9oaR ^48Kƃy#a՚L>*2ԻヒWFfysEeIJ]`P?دu:+K<>=[TA09ꙇpT/wAVZyt3<@-zl2yj7LG̐1>DV&/oǭ49WoU'棶@=MusssxgGٸ߶rJNT=S:j tL^j, Ν;9Y?\v@wA g&3 QD"S%ymٱMelåwCyH;L|0|7f)p8Dղh5ѪZVz`KA* j5TU;̙3r++}z=_nRib0ѹ\x|I xw]4:< 73 [fHRVb96v بdՀ+Skif`u F~ ax*|<uF65.zXhHF#T9L>ϣIo&NNNo} Z <0DRGQΖ40FcDD:(VceLf4 X4Uybf }]G?;wP0{@4ӖsUH١!t~z)<أfd2K!/ʓmlooO0HdŠ,};5`QGeyVǣ]qQs'vϋ]91{ QuM@S9$:Z_a| 0z@W5f p\ŋqMF#ᥗ^oa4RS̠?^pdoy"W򕩬_ղO?tVy@} Wka)]f`R[o!u  7z=#T=v!5HZݱq4S[ ҏX,nCZ-d2\x2W71gҐ/yZgv>7,+56N/RGD<GP@6 s^n*Hd}dԜI\{?ql2; ~.R5 liV,:%ZIOM:u~>Z+RVRA鍢 "KAF2899!JYw0`yyy*S^xGzܬu\JBaVNS&ت[oǸ>M&Ԫ{{XVXXVHjg=`S GH$x7OPތF#TUd5 Nf4nݺmvHRePF;a#ll 3/aWLPvKmG5[8ޯTʟ_&A4!CG-L|Q}WcH{p_@L&N3gΠjakk H^z }0Pߡ2~ʛAVefj$=^*t&GY4j=D*ߤ=Ǖpttd <" DwhԎVH\o*SG"t:DQa^ٗQ/Y&Ġevŋf\vV^BzD"mkh4ioI3'$;G93|Edx!We5 }ް{Tx#R43?W!Ek(LJ} 1yCpwE=dYj5An5[f`+OU(މy'2&Rܔ<>CFU V%ڲ:?h4_?Op}T*)FzJˡtg2>} <aV ]..]+n$7,Fh۸qㆁc: 9==5wxcf4kڈL~N:R48vgpyg?vuNac6r.oқGǩW9&5']4AMҿoca>z8::B.]7oNmD*oiHPyRY98T~)z)J%n:">:Ux׶y f)7eY.+賕_orYN:F#OWZ-x=@TBP@.#}@ÍڪZf }uury*zGGG&SY۴ND|Jl6k؟?&YtStWf[/>zGpߓbmOܩݣ0բXWS IZ] `ttgRc F{ [REсsT̿{p9B ATX * Kx>"R7 iFГ- '''z*6bmm ~ׯ_GT̃ K #EY x?.[i֝P~b1;Y* Eѩ{ 6ߝ?[oI?fY)`j,b{{Sf̬I.0y&ժr) RM¨h=>D:j&u+LC=ՀFVWTѠ_A:OTU:v,;P~;j-<<Hy'|F6{9|'ֵٳzwݓNw-`I? lv/t>M:,,,W_G}dο wYlllL`:L!2cRc L Sj}2I F|7/ϦyW%>G]F$ >߯%]N|O?+pE GG2*y&j*J1P.Q(JB0Ŀ?Ɂ@ N `y5$% }f4ȳS_[n7į~+Xݙ:0K,t.kG*=hcFB<f<~!{9[VF8::|7;AUYwx]u:[U{V)ʐKW<Z[=y>LWz>KWuQ+} yޞz@܃vKzSWrktRYp>8H`oo.^Fa˗/agg333h67D!L$CHܣr_:Bk6(׾+W^[}Vfo!ڣPa5Z a`+ Fh_ٳ8yt ]:)ZjnY\pmf]Y*lr@;nbsC 9oWדnCk# >묺-M{3~#SԔ*PkUV8FF#F|efffvNmt'''g]' 9TCBU( U00m($2SJ~G' +8PRL& LC. 3΍F} ՐiJeCP7M,,,hnX,*MUr;Q(+35>XY:mQT1i,>* qpp?nܸ]stJ-5 рta__A8k+OI{ x?~CRMafU쐿jqu+ǣW7Ҍ'΁GFEi>mˁWc|;A0 `*AZWV9F:&[;}Fk^TLjm/]W"l{ @jS]!U ^XXX SX 3ƚ_xא L}_l~,褄@f&>-LZOF?g>lK4S9b  LMc:ThXviX sssSJڍx]v (5R?|ʍ2+/ϠeH|&7U?ZIy{#?Ϧ=$8IK1ZB!U$@!,(Dp | AƠBd29S+㥳R+)MgT̷30)0#(n }4 hjYHst#Pc{{nQ*P*f[r=cj?LX]]EZʩϬ0h4p5Y2YJ/Wz3yz=&A(%pPwy}t$-}`PX Aj|2+adUAgޣ{y"J&S]ybI;>_W.54Mr9꫸z?5o^&z=A?<ר<&K%͡nO6жxJŲKߡ\QF^XLu(J6`jD"afrb]Nm۵=*8/bާ% A,C9IuLUV}ꋃ @sNiNq0+JAEBS1b4slFue{T x ܜrjKE|eFߺ?3,S䝒7bf\}_Kv|<997n7 \x6p8zz(OH03B`KU+7RFXo®++!.n {h={:kkko.oQFZ9/H/_k0Nŗ} Btd^w}[y4b{4`> V3NQ,5R坛7 OW찎*|ޞz{}6V}w':Nɦg=h*ټza@Av2 xZ}WRA4… hZ{/7 XP(L͏~Pi6ŋ/L&c<(&`_&\_~Bhh4Nr p嚴bm2C D >4M|'N۪*\b o ֙-ʭ쬭z=[aS_6RΟ?oG^A`ZG g QXX xJ3䅷^Ou<H|QqA}&*S:q, >>*i0lNL3Z*8L */zʱF#]FBZN3 IDAT(`A__/baaGGGeg >5a4cup !졾;-MtRɗZ[[[xcyyȔgRt(:. T3 rYeިJ/ ҐcKX,%j5t]z^Ë/R-?իWqttdOszbIAϤ+5K2k%͈>fahw_wcۆK.mzGFq-<|F[ 09͚yٳ)`6//ʽ/u؃g<UT_iC ƆO:oG]iZ4jWv~^ DnE>l&CkڵkD"v1*P^_xt:V0 +<==իW /`aaajCW2 /7n`1p)HP)& L鵶JbgB?{লGg +u>{}GKܸ˳`0@X1_Kitw<[ |< tNHRXYYv{MwBd yo22(vvvv-Ny|{6PuHA ':FsݻDN%pD"W@ `bN{\ Iq"̔jƙi3;(o3M׫sX$<'9/G_%>fggQ(ƨsU%qaK<JkOsSs kf?y+c{{{q^~eX]]E$A$2E)O|9d2a͋FRhصxQi$X,"annޛfWTtv,l(Q9zvqe|[&rg=R>߻wׯ_72ג/ݥ;uuJ0޼l_}5~5~zj bb_|fZ-..b}};;;`kX?2vtG<>93N[K+٭@t?99o[+( F^d2g}AXK53%5W}?eC# XN^ԃ@(N̤{/}F#Z-;J!> }iȲ=M`0x].`';FKKKXZZB2UրQGpecc &Cx<)ˋb L:hW LodW6J]wŃ}8Z{C~bGyQ>8!fb-IqQ`Eѹ]F#{*7҄VoRP|ֳzës{o7cJB䝊}|gg jN*W0 9,1X煗^zv 3+M`nuJqCkVes+qy?n\/^O?E$ 4 ܸqW^_|jNNc 3G}j:[;p+*[8ȫktFbVZG?VVVbNj<xfNA3?bT*O1%\ڼO9cS@⁹-#c:FoT&AcW۪>@y?a0>u(d~_[o^psa0ГXlrpSݞh4!VVVe>A7I'''kkڪl$@܃2BPpJF1VK>롽,~ G%eL"m9Go6SPPۂyAUGYXǫ G:wUPbߟ"JB~BR;#+W`cc.]³>kM;a]0j,(:STT]h49Վ]CPYX(P*RdRV/ĭ[zng:jSYYY1#`u ^+WnORgK8Lߣ?-GP>)yA |3g,``\A۷ocffrˬnL5駸|2ŢvD,%)tXDJ!| Ҝt@G1Ѣ 8/CN@q1w/g2ޡh4fԖOW_q||l~8\.X)Rܹs#吏pE[82 133Nc{XXRӋft1-&wy_LV:v"6]*̍&hoPNTIUFYagTQ]:ZAERߕz`An2n&_w ZޱyPJk̪R^pN=Ku޾xN ߫aQ fׯ֭[x .੧n,Tȟo~x׍\q+`$W/$t}ܹsݻwQPRnAg%my.Pȟ0'F\XyRIg;GѼf ,scAT*!L9' fo}۬:|`JH&$ xSҀ7iʍq΅{ǃe0PA?q~;~}:NC ]J'kMi9` ,+Â=s󁁗)ʹ=tF333U.˸|2~bmX^^FT¯~+.ǬGQD"L&fi_ i bu VY ǜ3i3Ab .P%0??o8phǢslSvіzl@ X,6U5] 8Tg)p0C,͈F^>jn,eS±Qq"B %.u-`)L|2ձԱ(8*̠v_~B`;wFuhIIcR9{@3s =h44{.{Tʫ lFRR>C*2ְ%ے9 F c/i0kJGcRVh$AVA`4Ey [aQp,a_Mme6!}i7yT(,@C߭z>;;?ݛ^7p8!/ae AԱ3j@@Iwa`E92?kNο[(]buoc9N>Jɿ#Z9q||- +++TUfXzM ,..N-]32LZ0^3p8ė_~H$bK 藖u`p``&HXYt:K^D۷oOF UWuD&T` Bο^*Z__SN"鶽0|;w)Np1fffP*sD"R)kffS-u:,42 ٬Նk_ н:kS /҈sW>J2~`UxR%OԚwi,L2ިxE!`P~׷i=壑lLT94CD&PONNښnY1۩;"Ik\S]-`<>R_w\iYtp8e5Xn6{.8P(P.Q. Ȱ/1.e)ԐA0_'''G.\GYA#L7f^+W9Qy Y?#j*7k>_uꭗcʈ:o $>| ,..N(W9' %ͺҥE\ATٖS* y)R,+`_ ?Y ڝ^}gΜв؁) 3T0(*({OT7h=Qӿ{ a{x`0@T_4}_$TOIAyfIcC?0#fn:W^>syJ WA`җt{{z.\=l d44B|O$:Jw 3LC*۷}Q.C۵6*+48yye5>G !/|D^u ^} L;xf,C^ǯk|T)P)3|g.Cղ]/ǯ3Sd0M-p&Efdʊfpf 9h42?A0F]0ew>43~֚ɚ#oKT@Z$ǧY0*c"]O+W:oP}{ ٞa[~*./2}]kFfYT)r8l6fd29%W#TɋgYTO_f9s 4fw>_&HeUFlUU)&e ԃ`Rr3tp]c8booO=ђvLꈎs8h`vv{{{vXʙ3g0???U%]{^-#=D6e?gOt,ȪL1(al<Ƞ{WprrFSl駟Z1w!Z02V@YґeQiғTw=H f kVB!l G,Nhd'oтd`=L@ Y T*屬jXq(\hԖΏ@Ny^Z ZY>kR@?y|JLTU ;l ;'Ǥvq:lZB/_j^tĴwC]N: 0{GDCYá(|&CDNŦ@[0rld? }FN&0@iV*](S*}M*{IX Rڶ OeUug۲jbnT*^x~>mRP0S8Zf6M[i5޶sQ>޽SZVnSFyTZZ-<3h6e;;;8[ ̀*X᪢E3 TFQVqrrbq@M/8PFf8' RVQVI7;,--U\ c577FaGSͦӗ@T}&hs5DGϹ=d+up84_x|%._ʸNJ\ FX",g9A_㝷~Ws01T쳮.;PTwwgf z$b},S ґ;Du-Z`ѩq QG +#\8&w7iKO:"J2fx/wxoR@R dk&"F岽jz2¥'shyn#LZat:S<|Bct"tM`Wz25"aA_#ВfRoIAX<?j18٩PjRA`XlRtP,OڵkFhRu*Dcr[[[FXZZGA`aaDºПT7oZckk6d)vKtNZAZID؊ښm.dS|e@*7JWc"VVVhIX ( f9gR ^V%6G1J>Rn ,xTm\mKGL%>yKxߣ=`u,M0hHQ5KS#Ƙ7.LJ[ǯF*H*ܜ):3.|>t: ۛ2,|37L|f7@<@!(MNERAZLy4[?ΞB<6y!Y9p,Y%J_#[fvGL=>>FRAAZ:\.7UHWn`jhZHS WP@P@R _CϺiPNYVࣀV"ꪂ u8M8|pPչxzr J{>i_xy+=uiUYg]=PrKh)tdEC;r9ɟɔLy}z&zDPٳgQױe)۷C=d2b0ٽ{j5m})J>?΍.\.S6Fvm{avv7c0`kkVKtϒ hJuTO}W⽴z<[IKF;?$>x<^qȤ\f8s持]里+<bqq!u1coooJW}k`2TIܧM ,;UT}'}uy J9UPxiɚIiY w3T}d:]ehIed2B`+eYr@@qu,D' d晑 >@f.]S.vvvJpS,zԍq9V*:RHn?LQAG"y]ʌ`0@Ѱ@899<>UK2q =6I IDAT;w  DA}n.:!2 DQ XMeaH+~R=Q@C~I]B>3z.?}QkFVAq4C%^?G5j7oTGF{grYOKia:L3Gx~^)P% X{߰,'?;ts~Gʉʟ]? ( )n׀5S/⸼3z~i?ץa~sՅT*c>bssٱ<ک@>OJ* ?Do?K>/OxMԏUI<:Tzn*%r4{cNl$5tJt]&]ΝNǘS,T XG\BC+\V&X?:ph}@RIZf˶u > S(0*DC>8g( Kx6CP`j՚{CFZ7cdY[r .Er9>|hǎ?x@&G"I9uoaaZ͖^yln"@`0@><ݻglbaaan=ђ>aK~YVh(B _'D߭΄.j;d91 KӖƛcSV碵O

A+ΑZWTWE h=`%آ>qbuuV.^NZf2jvS9k.D"c G+JW߷Lz^bbD[[[V>DoZbgghx^nT>4SJFBy~TW5tT*XZZBXÇC۾8}5yvlFL&˗/[)6MN<ŢɡҟV+*,{нG:0L+,geJP}~i9V'i̠g4Ylm$AFȕ&Q )dސgFW))@,igᨌ386>|h&ܹFaʥ%۴DgNF0"! %B :[=Omo+~O?6=p[Rw\Uvt{y8G]E }F^,u,,XgVcP`ju Ws9==ޞ%|^|E|H&rhn iMbV oFT ]?F4Tbؔ&vqvvQz>x[#XZT;H`vOC;σ`ڠo&2J*$k)X>o9ssLfCj5ن>Q{F-iQ.2>s@0]1k@Q? HRWXs+$sTg*w*+ ,arrOe]?@-. LeUb5P jZ-/NΝ;X__GXS1,ǡ`,, c6 n^Faˎ6Bwޓg ;chOGAC6Ņ pttCYGY2N})Jʉ1ͿXVp_7c@`MuzYu >[erC^+H卷K6CLH:P8<<^iҥF^-~uЦi0Pe[7*W:'Agϕv=ox0Gyϵx@՗x[}OuM=`faτr\Bxi罧ʌ.ӎ2Xt:t>s[)Jh42pL:gOwl=m^XnNLN8<<꿯vJ埴cRc<[֡RWi33}mx< υBaj5sP` 6 *hۨjX^^s.q9; Gl6L7RTJ1/M0D]ʫ<2f ,qY@jgW9vvmtzz:@̌GA0+o gffPV177gUNe[2b^+WX&saasssH$EPevuٕ̠d&[ki2n-{! 677m lujp 8p?)# BAHs#u ;xLC422f{{~ttdpgϞ6ݼE%%~m萹\G<==Eٴe8Fylnn}8>N&vV͹PƵC yg~^[M5j\y̖Q CP:vu**+{o5̌: ŃDti'(r|6 #1HiPrrU'h)_fsxuT0o|듀W>4V'wSnW@bCŢm$ bhe&vۖ$L&cLA7Grt8憙iL3ϠZڵkF'KYf*BEZE.3z4h4D۵- Ҹcg=CO fKUϞ1;?'MG-e_u+;)S CC& XwzzzznB z9҄7^7MH0RgPyAKuTOA eC?)}Xa{Y.z{{#K#ڲ0:yGPW߿hE,X]]E,ޞ p|h49ɕbH$۷oOj+. gggVtiM[A$? pttdXA)jZbIn\.g}LnW1Z-+=чjҏP:n'?y$/yzb<x؉೘'( 1>tfakFO |>??ĹsqF"O?m4ZPr2P41΢^ի~:Ը\Xjpd[H$9aT`oYlxSKTVV133)FfYLv 5d(k9v`ɊS] 4^Uh4cp}T*aDmQqzh6dmb,͙?3x(`mkWXMӠfީ1F/*b CQkށ$?4yM>/?Y;ldtՓ Q%YJ#D!Dwzz(i.3{rz= JnOmVS%!7} 1f }2mؾQiqrrDQkW\A&kT*e Eܽ{6@k^^ /ݒ* 3 a h ~uE}X rʿb1ۻ.<,1y;N]i7I?:ng4uBo<`W$[} l6L-,,Lh-z4| t7@6E2W*pSD}­](2&ٯ]fțm I3IEpt+ RV<*fggqYk7F#bsf0hTa:9J%Z˃PױL&cA ~tR|>o[q닫%lHy c_htU=mXmqs{0XIJZEʊL*v`VCoX/fTH 5;; .Xc;TQ>T4͌He:n޼i=UYC09,Si#G2sj H _GuFu@-,3r9ifc*YiR$eGz*gs@DZr\*s}ЫP4|*NPh}kxDli⩧pV#ꁛ:k+d2C\r>,-SnP(`aagϞdd2-(t`ARJ8::3>h4N HĖ$qttdsYn{ZL&yovkuRL&mTv*/U5b2{=f}EKe2}xԀjYom:t:mǮ~Z ݉D|FÌ:0??Jb˅BV'HO0 c:J^d^ղr 6//˙p8ܜuX\\DXt|D3_?;i9q)HfPSt3Kޠ*R2OO' aVvh4 Tv_s_L9M>+B:c"*T@e_~gZCZv >AkjՉ޹s[[[ScC NԖi K3 ]Vt(|˒:dòbs{a@uqN.-wRPx1~ν4a$G{8F-VNߛdPTl+y*gMn]-eVhtRnQV*FTkWDZhr<ɴt:E[ktiJ.AEpYD g<5|h9LbwwFcjYYkts"LEPPXЇ#ayy666dF* T@x7bfff6~#kG,;| ڲy2D$\'y0mGmSFXQTPqy?j˹Aօ{ eK3nd/kfYoL u2D&0Y&u!H#{9Ǐ6(h\LeGuh55mS7Uw՘y0Tn|=Ьf,9N{AFC4g(z[K֬~^ $}vW0Fei(P3)2-riW.m wH$)@FJlL+rwwgϞ& VH<vwwm m`^G@&1vVP Lf\zy2HcxLz*5h?芙1 \V\#e.AC6K/gm.\)22/K;aff qn*n޼J#T*+P(X,}\~ݖ/|Yoq_pgM PJ4 @A. E*~/"ױǾ"؎ YG3Irp'{aws]?AysNZUN+Wwz%?L[~_Ǿy󶻻k[[[qmxx؏T*Q̃ϟN$mڃPP,X,А]|نz dN>3{wk6uҜE IԏrlCCCNϓ_~ě-)\nɏjw>55%r9޶RdN$׍Ƕnj- gh8`l0|¿H$ٱA:88hf,zz yi FyF3=(F ,|:oBYWo)1D$HUi< 窿+btZf+++>**\6+{(hF08:Eq| (?4G:)׶&s:*"?p}uԨ*8H~v8zoŝVtG(1JN\u}555ej666̬ơbcurrb>շ#OU$%JW8$]/Hi.H4!<55eng#hZ(t4CT5tA hF__J%SA(oKA7u*TVS]t|sJlIjH*k 6UosHIĉJs5c+szI:FWމuCځ†j{ws{{{JC瓓|;655eؼvU_(0ɉmmm/]?|K?0fmjjn޼i600}VY~Ύ!'Q$M644VRΎy_nT*[.k;pĚ+O<:NOOmee>C޶zKFBW J{"٫j###^D*$Ц(DgQ{\RԖ=l6f}j^Ecll=a%bc###GMl}}VVV y̪5"2dҽzrBx `VLX.mww<ߞJد-,,xJ2#Yzyq@|={[* `mh"cqEawJ9ViH݀F8 5oyyk3VzktVFF)F#+ιΕY{3 U >}G+:F'UF] jB|N ~;'>hh;NX3 ƹ4fͨ9!ETfisssVV]46jvHdp]*, Q83NKȚͦG5^o(鱍 _S0;h@H_N6mK~8쬭x www =c=r_ FEVǟ D'VenL`#<~3߬" fYy6W S333vmRdv5xTx=zȶnZϏeҥKo;jXTb۵5+J h'N[ڣGlvv#f f1wٕ+WW^eS(QF)%/^/eH$׿X.s/ ^omR{{DP2hN_^{F&Ph[ٴ+WإKV6E+J6<,J^]*u~",fӆnZ͗ONNQEAJ GyT9;;k;.:wU|j Dp)F 64P%hi4JU;9ǭcPPJzo AC-y` *ۨ|"x4IHLw|^߃o'1@HB:h04wrl=헶0҆V>&T%VsO<,:4tt/7VXs&G<,2:<<|M+pbߣD~e:@[ .ΎoSi6nٛm6/ Κͦ,9>>bcbAK x\.7 x&Hi󶷷P ISUڪ>n+D( H3#׮V 5@($jFJ2F*!4\奥%W h @*oGe#.CŌQmh)T>QХN^}N@'d:8h@4xYqmFۧh_ӣQU}[eH)4S|':1W*B`/^p@<6"z&hʝ̌_Çюc |ɉ333cccffn|AFd-ͤgggOϤ,}}}~x%oY݌s}"0@X`vv֦P(XP`M)|u#'$:g|ܙRԥO>x%@ՋQUDN=PߩV{R^ټ; &B55< A ({砐qrW|6HJ%zMNNzDexTsB|?yľ OU2qzݞ>}€$z ;zMNN˗=,He6Zfve?aazqh2F;x []]wz!O#5VyKeE) |PgϞY"hLfс'f#67 @V T zF|9} Chգ#?L԰ht,Fd1 ,EQh6^O1v ,bDB)*U dË"3OZ^^~ pSmS[d"]U#{*`޸FeKAq'@)ɹQګ q)(/FS~\i72q"V9(mtKy0N ^ۄwNxe}'d %jm3.^*}[Q}31TT~y9== .Qx~`f}?(OccBofm@SsÙ˕``6u}&_M|7d~Z>e4" ===^ c›&J<2 flFG1̔?ɱ23`C+D$Af'UAd^7O zp OL0yF#PC£ghh;rM $&5MΣQ'{=#^(F,u\Wu.~}'W˧GE47@>]D@Ιtڌ5w t#eAks]EJy ~iRC^?f5CJ<]|h3 }{߳Ǐ[**h5Ze'T:Domm~7NSJOtG]S`^Vy>' O)]XXϟ{̈́ꬨSʏ:ii?JSݧ-HVS9giӮfDWdTfu|Z:ǺSYch$?uZ˞\x.\)Hx]ċ/\.ۏ~#{/YR)d$2G XL֖}%MLL˗mnn| (Q\(/A@=O HBsEk4IO#У:φzuaZu%mssӁ&IjκыS完^[6v5{}嗶NcMߨMם.ӍFk O@Ȉ}~XLTjH(l;}R WE h9PE!>k4VEF8"b׹R3f柑2ŘH#RE9tt okO Yl``W]ۀ.QcÇ}a =0%: ?t׈[Hgʠ^*fK?5(cu#@)m\T* U?c#cyp;|Qu&u XuPG!SI>S(SQG3]|ٞl6k7mgg߿odlttݻgmLLLx"h cuSuCmNtVHt6ug#4WGE?Z)ʋjrRАpQgT';k5YБ ʟA8;:?:"N'v+d!М` VHԱGGGV.v\+Aqجh}#OjKKKf]ɒәJ|'LYOOGŢΎ=x׽ݾ!ڵk^W#"2FԐ﩯L& GvRR*\ir>,X wvvSQ)^;i (1pyS>Zux 9;`C ,5Qqao7|ɓ'U<3H$ٰG Kpw# ̦9t>*%pvvf^RnkkJR[Rrдt&R}gg En,b4z!V d)M5:rpD0@V8}сVCAmF~1<;Sx@7)6/IW#b$k4+xH|ıF]KOVqxW2<\:_oEϟ[R9ߏDTtnYA&ļ˔%ڭA3k;XW ʟL0le2/?h4|P72m+Rg0:GuʫNOu Y_J?ޣ`qhFmG@AʣO1\  E8L`cҠ(rt6$’Nƍ&I/SjYZ]mooݿs]W^[nuww{ Tx=}?~mͦ/7M+5ZÉPvb]P  zTʁIaAɩffffxzU#O|Ʀ@F[#) z DTzp` }]gؘ<$Z!|DLK +Hf E Xw0'iPlQ t9::?QQLԩag|Zm!&"We1dR~'VeQ!SvDc }Db^??H 9PĞ?4R9Υe~:N9>:ڪJ5$蛸G?P3}5Jڣ uARf'C4q'1r(FLGO3s`UЁ. m[L+Wuo6nͬtlR 9[ZZO>koӀ\.畸m~~># [^^{eu^Lffflbb좮vwwlzh/ AHe * ~v 0r&G+_>t&J۪k^uqhO#<c>P!ƢJ=ͬ GEe;U}J:06k7::jyщzO>q18Ј2V^޽{vttdk믿n<Zh$B!xÏ?vvv"Eq4ެ}SVFN$mp4H ݀(yl;6_ IDAT<}jqLFD8AA.oBefm61ZǼ*: YlТ2ЍD('whh]`2Nc^;lR5U & %*?vS al`Su~y<=wd'vssWG;#^SUEGN4J$mFϑd:Aߩ)I8<}yhSѠJ8lUj6LuY9suF=E"Rz8M8FZLӭEuNKYKww]|c/>?!RC'u0;sT 0zˀ 6nUZ-;M9o|h=`+s-F52ʦ^{^/%2>0o撨:Aa2 qECeU VFFFlss%e}Ao(E:q4VRZ'GE#!y uRiQHNZǭ:0dоN]5I/#PWF:>ݾ>EFUefUlT4:GX(} ֩Lr50LW|bԒꞸ9F6OOOmllٳg^, 6u[YY{vzzjϞ=ׯؘ= Z6u߷GYWW]x7FЩ1t钕e/ߚluuR񱍍f+0&K+.`wXPkԖ=M]:D\ØR-T*+ 0;at&1%!:G@3 uX ~N .5 .7G~4 m,D"aV(dy\ZuppxJb633ct 4͛7>p%3nymwwnܸQB`O<[-ʊŢ[>r(EtǃAbB#j䣷;F @ C#/ڲyA1c@ QS.P(qkHnJm@SYOC(('6d2VN\<|``m ^ЅE*ҾNuc0'T)XԈ i\Q>FW:B :E:sM`bSM)mͦ{H0h0zWSpҡ5Q2_o|Rmoo[\v{8::jSSSC 'd2ي?yĖlzz.\`z1)rI.*lZ.>rdclbbsiZr``Ue&&&̼ {xx& u:Ummmy݇Q l 'I_M1Շȡ*B#4ޞU]MB])}ǻ5{$֓ N6I'pȩAT"7zF| flwwVVVllddOd2֜Pf02]q)cRF/@LɎP$ + <4I{* dDژ}߰a'}Mi4Ãok'''~D"EuIA׹ѥ//t:fzl A]022>B#3㾘)„wwŻ"Vnsz?)ʁO QPT&,Fy^8a:GziiJM@>^^<̘X!#ЦC^_N(u:v02&!+(`:J@K!h_.`EyfٖEe3T`s ENJ{Ivc|SԳx{4 ι>r=|Ў39@NRd/^d2i^ҥKvU߷7 C]h6dݾ}ۖ>Gd0VƏذ﷩)8CV( >ԀАzV[0D8PCW=2M6X2ԩ)3.FFF\.IT?̍p4JM^W>Οy: ۩82pYXl; l#H$|2ʸ5hV#ЫhXR~q^RO&?D*2%rNAW^}hMPìFB<)rSQk[T@L%̟d<$UziѣGN Bg0 &a=uW(/uGP0}Y@4 1FGx ~@(hT*unڏzR@@(JGi)#COS#y (T&Q˓ > [__o30k/ TG|1VP˥ß<bYV}DpIsycT3T `PY{;d#wJ&C?hT>P(;.fLR^!.R0G$Yt$11 ټwE{\.Km-//[66Hm۫Nomb~oaWe엿y: R,-[__]~ukAV;TG5 ߃}XJ Lz,6UyVvxx) f7du4Ԕye?d7ZLQf+4*ܯ)P^_/%BE_A t9dl䝓v*V6Wy~J85X 6D–?=m#T U)D0V1 5Fj;e 3Ž 2n xç̂!-=NzG|13A}Q3djtkd:1*zaPּXehyӜHarhj@TjtyTC5Ǒ3ZUӶ8AԼ+*7.NHqtNԀDRi'Η*W#+kCy@!TШ5Q9\YYrm[A.Ej4WB`gA|hCtvTvT_~P.g>՟<?:YW{Җ:GMzD蛂Ǹ[.=@Е$+.tWCM7L'IO8>>\.熙EZ3"-%u;Fffmlln y?efi699i7o|bh_~---,N ȟӧO^Ɔݼyz-ߖۂ4Qa8/-ڥKlwwם)l/ۣjxxX@H?u@6::mtt,m&E2V2'y?l@2X(,l;ڵkNk]yMp+zʧ938qb'x}oLD:ݪ]29lZ6Z5r̥Oe?8OY#-LKk^KZ20"H[2uWy4LF'BNr'e4 H+uE=Ī"U"ާJ… (ԫ{ރQg))ᲹRpQKX8gK Tt;MйSgJkKQ -o>:̟F#,>~jя %D"zRtJPc@3:5jo?|/..څ qLw cQk[P#(U9jCAFPբ {Ώd2uU@W'5@"xm3*KԽUyAmk7nܰ?vwwmzzxrljJVTl``*mnnȈEk6[Q>jHnԱip3m/͛^zRiQ#ORɲ٬MMMcccjVUВzB L&iL7a'mddixVW{s |L&}`bbŋV*,l<<Ei@ hTE%υAHaG:DMܣLDDeF… 611ṲaӾ o~cOF#JEP|Dx`@HMAx0N0\dHouBAMe+xJXt7›1/9FUj*>Sq*zzzlaa-HXXa߰ىVu9ujusG@f WVGVۊzAߧ<4NRϟ43OEꮯA0j_fKtT3 @1feX}3ޏ ?hNQUnL!Vj.4 IDATEapjDJZ"R=cK[Ą#kDwʙs:'''688'Y.D"QԾ>߼FMNOOm}}X,:#pi6Ȉ}%I{hllzR###mN^'T*-XwwMLL ~J-X2a[YYek6+u9BJX,榍5LV,mwwfff=SKG7K#1?VV}LlC']"2 j5߀@ c&UVjhp$~QߥyP7 ʼn5+{=;99!7QL@UtdmkKKK/!R^FUak?1Ո(e,L h"#_Ҿ6/e+մ!QI.s>6ihKubta*7λidy83_ `zA#.(!PiIQy,FY=,ɸ|U8uS o7IO5Z " tW Š:OWc MH#dDrܩKyVҹU~V@ΜJN2GSYݹsO%E}}Kufѡ;ƫUx""Cvvvf=nd2h4;JhY2 ܴ/^XR Qp)V*lppІz2O:gW֖MOO; g.$E;t L6Wj% =44dCCCx;>j^^[>Rd###Fa6FaLƏ{*B?hf0GFd)Qt5Xf0LHmOmigzN@:Y@Qus\P`hu\F΂H﷧OÇƍvtt6We 'Hu!s@m Ѷj5pU*p].*lyaNMM%Itpurl600HRC?c}t>g?VjҒoRWh:X׭P(핊&z^oD## 2YPh+G8իWmiin6[ijT+cyyٮ^ڶ-  (qkDDǡWcԡLutTGavnޥ9xpt1l^|xw4#󪰙L9ښ?}m`K3*F5LFѢǢ2-..'?G3$E# oKKKvՎ2"vrrb/^qk H|T7*-UTvߪ40ef~U*K&^Zz岧휞z:v9{-,,l!\+0S^bPHQZ;N y׮]wAgggvtt䴠g6i`C(Rݺu˞>}j|677=t5wk{w??OOOx|R9:J%o+G'''_ح[ʇz*omm_r.u~=xfggv2MG{jVVVL*>VL8*HUǶUkPZjArNԂ&`d===~Vo73kS[ oGE!TG@A.q $eΘPd7nj`2ƓNc־'F8 L F47~sj\w% ?I46;[U6q.S"7пhOB*]ռN?)=PC<=; #{pxt\|V#+`cQT;A1+FYȁKuBƯƑKk4+DF% dhӨܣw1N x.4GriSuITpR CK Z׈FT5~z۾uqh(L&_G[\0Fr@+/GU1L'>U7LB@Hڪv->#jc::ɪX!*2U4RRXm9L`'ֲ̌ aшJG]E(&Fx7ߑ:T@H%"%h;LcޡL;v#_*9Qn؏mggǎmvvFGG`36_Ǫi{诂x:6*.JY`$>F 4>O=%PeGuVҒo065nE(qLPB* :ȵ"fkO -uy:褎v49jߕJ4뢃>vL677mhh-L;gsrμ|/ !QֺLX=6qB r3}wlXd2hf@ M;'''V,_8#W^ jTUe>Pǂ#0jxM#ĺtƏwN}e`'F.\NAZe!.CG@MuRQEРVGurDJ-L1Px|*ӞIZbFMzA8>>nϪsEZ#J*L&VWWt_*UŮFV%ʕx G@tFv^zz{{ZN# E@ID\.{gTrU|]L#f֥yNAt IP06p\^~Qz\\MR mkAt_aYV~R,^QW*DgRW&q\w ~ pef:ډN {{{=u||u2T;x/qTUJ(z;3` MOO[Ѱ%{4Ķ-HX&D"a_} ~VzDuCR$n~HomIF rqqъŢ_\r.]Q'Sgέ2+˶dZ,|hb ÉR:GƊ:ܯTTVHvζ>G9fAFa&2x58(Q8TЎ‚]~ҥK6>>@.˗/[.pB4;w.]/4j&2 2#e;:?\QxiU?B~e&NKliJFU }rᇇ=B#gbëw^!G^].k0YLPF_~^sWyHRvppжD>l,JÂB[yq/^b/.F ن'%l6/8GGGvttdbю\.[>C;==#XpACMw#t\Qo WVPF/:ڎKڊ{2A;:("77ʁnטc^̽C\)U(t_u~蜪i@()ƭQ+vTG&:X,‚cGu`g#VE4tQHFa{{{V,-ɸ~[LT`ceY5 sȈݺu=HA"?·.|ۘ[&+f688hJͬujc6msX9Q]nuS;y:+- V(܎+TVBVqN+6Ӎ񺇆d26~cύ( mCCC;*Ug*~3K&[!Z~I:(p(#W YZ^q㸿kuu=1v=~666lޞ=ܚf[E:)|t>+z+n{7N[oeW^})ZK}Q..O$Z_q<BiFn67 7cyeJW^B`Lz{{mnnOO۶n/ږ\Jg]iP!Ue*1Tm*#jyyrMMM@5 I?QQAUY$M^QRL}Ԯ_b] ~:^uLtzҞN|+Ǐё{CV\.`Ť]r#F݉ [^^D"a׮]fuٙݿ߾{d*lzzұ*eٗ"+JYozh-,,8_ښ8ok:N#kK=c`&&&lX2]ذ7zŊ)F0H- IDATx=ybHS۬N ?HS.S8:477繼oX:B`>+d2^2'Nؘۍ7ܫ43{׿vMDڡPQ+Q@R':Fs_7yQ˜tuuٛoio~f0&2~.(ӆ NiL~`@L]&V\_ȪSYgj^ ~i[77R)wMNNzYضʡMA:д}$} _+++1 ʎWa$J @srqпkGv'Z`jj\8qZ3#3#.`5 YYݸq#ooׯ_fY ӧxYn?yڵk\n6/6h_]]-;99/O?Gr;!GvTNkT7xw߭{ ^fp*Gh+5Duyie;/f/^?2U=}o=V/G7;{m3[Պw} j6;c `,C>.r@0 b:󾣣F:LZVop; nM L坁A;t`31N4.m,p %-ķ.nXmXFd,..Bŕ+W֭[qڵ(S{^lmmgϞE-@D;ANHK Y\\????xQlnnAo|155UWu2wA;ke#U_k'66N=8`PgU\Shtܖ x߮`4b0 2-{l9۩y!h0oolȾ"gݹ{777籺땄 1t]^c9^Pf>9Q˽N{}~~^vfv;2bggК{Ӛ333111QKQ<2ge믿/"666 av5QQTzc?yRgLb`(+WDZկJ'$ 1P93j_[oo]8=6pq$#8:Nf6i+O/ϼi6F8 :LsEVBלּ_ӈˠ`yy9~DvfE∉4;eب&e6@QUàNiq6(saq9a }9x,39k3^.@2xgq*4~Y l #t 7p6vWA/ 6i]&^~,nݺDZq~~Ӆ6ѨnO'34'tiLOOwOJfIrf2Mg`{l >>doffq[ފ-3a~!_|jEӉvq֭X^^p;;;1~ՊÊb]dt_rJK L`jj*߿Nټ}ww7~`0(ƙ; M+*Bomxrg#j!$`O?ggYc䷍3blxr;}vpv|\n ;W; 0\Y9}ve6J̵1|p563$l믗#sofffsn޼W\,+#D{ø2wމo}[177W23]W//WqaibT d:F|q=oP6g5?wW^w:R = B cdtl6KF1dGAuDzc× z '3,G|F0,34!Y gO:퐐VU@e>G.0(sݱvPM?3h$.fPh4^7:;p{ y@ov#Gd_dwl22K Y{dyvv ooh4PEJx"8<塇qttTvب6l/0o:XM{~?ꂡP@vޗj{U}i266Ϟ=X[[_v9]Ν;tr.ٗf<9$x2æCoNؐ~b)* Sgyaasʶ@1FE!ǏV[ ̈́ɘ-g׫rfƗ_~~rjEp1wѣGӟs5-BetV{4 "hq9l6?[Z,DvPp[Y2|/Hpp匠yAz8#tgn:`d;om:[3".ˆ5"!S΄^0ahgbk=#:2M@346 3<[F.nÀ@qr9FMϙp,0:Pw9ry!cwߍ{rRm3JuAj?FpNP& ^/?fI&-4|k6PfbzD=eTFQ@?Aoan`~s199Y ;mH/΁o,;p݋ҿFO>X__ׯ^c%(qe;= ףּud䤬CIv:[nHz?;tLEHџQtr$VlooA'#?_ގJhO/͸qFܽ{7caaRH0oyL7:+C3`u?ߎo~󛥦C<S0s͗;_ڠoh 6B>j-{ڹNy 򔛍8[qrFrglx(R}zzZf;\R3C[V|  aq:ȅ%Y󲀰.onyl[ϭ+@Q~Yuu1@u;L >lL)9v|gPͽL) +8Ngm/N.=y@3gSiMr9cہ 2SCa??[oU2eY#:e{i+ﲭNYrǝs0իW锅ivcgg'A,//\EuY[}EDtr299kkk8>4쫍|9g-h4zehĝ;w /믿^vp 5sPcAv}Dć~GGGY0Μq.A7 x>j۠`0;A ٺ9oƠ=9; 3 {Xq8i'HgJ w&m);\{2@] e}ul)oZ,1^@go3a-@{9́g#;;3;;q%R7,<~ p*i/8wdp8ށ7rbp1GD;r ġ'O__Ty?۔ Rhv4d6Ƙmd^ݻqttX|^ӉbKX?vt:ewfJ]8X9˾}Ep)4+wzz'ls^-{5Qۖfqڵ뉉v_GՊwTU߶fa]I'иI.d}p8,t~~N'crr2-WVV*E\QJ_?LÌhBEYU%d@׎ @@Wj H _x/^bիssso&xgb[mb66sN|ߎR|8F>Fўx<<b 0/F&e]éa'a}6G $x|7@uPŽ.,[됁,m.}{' 7Anq<@+6 gSiz`S=nZG3> y_Y }~8mw#>o6`ŵ,ޖWxe`|Nٌo~133SfpwY xo=R:'"͢h.rB_ M:NlDj[P6l}~~>sH+P{g0h4 8yڶ=ݷ.7/} ZnvvnŋXXX7nTܧ| 9;;OEu<@<tl1??_Zr efyzz2VNtDDieοI%IT855UjF0G+|uQxiaܻw L:>>?==r7EO>'O۷oL bwweʑI9(/%e"+6Ns;Q '|R#( wVZ, LX:t}2iMOOB /p˱. HY!80@"d'%^ IDAT#πv]i<9-.@hDhld`d?f[_* Pkve߼y3~g177W . a-ϰ9F&zvv6^Ǟn/ēZN {qq1Z677coo/ƍZk φo$hƾP>Qn&qݎR_ C_dowwl32VdƫRf3fggQ<&¢SJ𩩩raQΖ^jff&z^Mُ\!px1ѣ;wv p8+')H\ IVʕ+9Ken'km>"Ď= c嵰ԍ%+`qF)gI53-gΙ]ˀ<899ݒE.rǁ ;i'I L+z=o4*;\ hmy4yLyAeܴС耳szq"~-VPvv(ebpHrN?x%`>"(1>l𻳳; 1+S.iZI9,z^e3Lz{a*}EY/ $?~q hm:(33RA޲?zwy'>ىRksr' b0\4 .hen8vC˄h4pmm̊`0xiiErQu6+Éj],|i<{,7ވ؈œ'Obwwݲpn7n#V}1J+c&''cyy9=޵cccӗJ""ڿ[>L%(l.Or1cccͱC$VRA J޽{qrrO>-5,tcs>??ofZ1;g Ssbzz:~n=tm( .hzh4̇9sf(3 ZaςئY픲x%ƶ-4`Ƌ.nxvv_=մvu :X1m.0&ún7>|~?ˮ[^EfYh4*'vZrZ]cX$|Ɍ 97Ip˒H`=Zf3>|gggqڵ[F}vģGboo N>XGH䗶޴n[A ܰ{|wnn.޽^/^xQJFld00`or<Q 8==-=@H E"^>xY*Àq bܸq#VWW˂V^Ǝpeb(~߼ X^Go/O{ew}β[x RLW; Ɩ#Bl%4OXY T3hBŋQ9B };#Zr`tmc9t_#i^̵mH^|kOg4XF xfg yֲJ@ki/rNӠ{ky;'Vn=>M g,̺,hhQg<_}ЋeGŁ8VEƑ[!/5888}%lfgff*tV, YPj^iDܾ},CN155z4 &ឧOF)}qbtfj~a8\763M~ Z =>>vKz .Ѹ:~3̀}gffJDXݎ֟ɟ|!sz\OM98׮]o}[1??_`@8udh4bnn.߿xAx[X猻Ǐp~GqF埚OYa#qG?O?/cvf-=GU)+hv;:̗{3ӎ>sZ2a177:AD\̺=::*[&&&Jyrr_Kt`2s:x?S [) G ΋~af,[v, R6Sx2?}Yr/fF夽<Ѝs)3CNG<,g=˗mf Th[~o wueݍoە2}h'\l@3~qӦt30\kݎ;wji>?!ad~309 vT{qVj'!xqewˠ,gW< ͽuV\zL%.ώ.@8.NOZ6ϊ\Ȋo+;^>3/u9g@vYYN6L:/ ЙY^ ?l;H;Npxy24#ǵD@zfzmwV5t2hC-d>5Xm san+ YzlEI˟e͛|tbee%^ZYlllA˾l`Uܶ:'`ӢcwiT\q5x }rrR֫W۷_Z ["gP5ל ^=iC3& F0:N:ogg'buuxdęۋǏǏcssDy'\/U6҇XXX({Rӿ2det0}rfE~'''/e P 6v(\g2sAμx<TbdPlUfAYK?T.e2 lt'ڴ^t:g/J\3F2서eY5@w r\!#qYCrVU٫-;DL˟4q*}34 v9O,9 .КrgdȎwd7@׊[>rf=6s8&g>\e3^ O~ߏk׮UJk@1Kgc۶ěoSSS/1h<99oV|vK|r8x~x4܌~8>>pKKK?u6V+;~DDIXn]IC*YV3ϡYVzj9+8YQL^[[+\`xyY26셷صLכlx=q=4bjj<: /"Af1==];>>>BoYߏWƝ;w*?rnn.*L8t#bF[VI㘆ae/jbww7AٳgS~祣,j\\\J<xqAEl\rr2byylR16U>wzxONNQ򗿌ϟJf qV| - mGPVpmaO#mgzY`?VB~z\2A."GtvFv7̻|/e.5r_v);mO,嗿MH(Ŵ`wWhNBhE5`-VȨ1s'by?󮏮%Bk7,44@ ́l*uX?=Riez o9y,ėkвo>xA;?j[{||oW_}UJ+*p8mLwf#">v177W;9AW/~v;\R= 8mRfff^c|+m7"駟p8,;%{~I>okͰ[/ Fi]Ǖf,--AD(x;ggg{7;;׮]+cigffbkkIeBdR=y8NOmYrNOQީYsY"C >A7;X3t8`Pe 799Y}˶;ol1?DX_Lk$gG}~y˰u PbX Ʋor&b۷ov\v4]^\v-ѣG%Y777W-d#]*E*_ue: ONNbuu5sC899)3n$Ê:99)Ayd 9M7p=*xlYӧWѝlM_Uگ`b3Q:>>.P=;y!8[ ǜ}vLMMh] %Ki[DDi91!(2==^eF& G.>c=}hf9mπphў~zVVp&ϑ祽eFؙ(]ռrv{l\< gkM$fbAx"_^QdlYO7y'h=Ⱥa`̔BLdP~7?y:A!e4OϢ3*\;REusHY'{8Aa~˥llW ,2pa]g;m}xض2t+HYp(9bgN?7~E%XɴX]Lp8g0 7Rځl'= T:d2hfrnZQ8a%8}shi[oދ?9??ى'gge[;l :ށDDn05r:7ߌ_W1k2ӥ$reʕ+o|#>+ F񗇇-,c땅a!KKKKqttTFr t2lO.M3ϳ-R:V8>>.|UW`qJ`Rd`A |~?b}}$XXA\z5NNNʶ{mV:l%|(hN;@[8v3I-Ө)' Qz>.| >X\\311N'f,,,(Vf5,3//7еoXXX(%^?:N<~R`)hdlozgl!VU )r}s)}č^VQh@``ҢΖ^S8 4B| |  D[VDDLY8(9d@"G?i:;p:eGn޼oVgu ?.2٩ejL&+Jg"<6 IDAT؁e Ƴwr1xv r\&`0#q;,F*Gzw4ęeZY0 ƃY C7/Jt ų|0 #.2pi~A6h~,JO[7h c6]/a@#@mut(z"}a6mw9Y~l)y?fgldY6wG?Q+:T,l7'9ajq||\29oׯMLLl_L/,,TX_~etkIΖl# _dpss3Zn;;;q޽rLVʙ(+e(a4Ȅ]G ,#Yى+þgڵk:ϟ? ڧg2_Z611Qv7q466Vvo!9'Y֗vjcooA6hkoo/VVVl #c*&''͞{vѨl+B =c#Г@pSqѨa"lgar d!8ٰ .{L:dpyf#ʽ. 0`0[oUn11xit6\H[Y. 6ȹ}yAG\[xq ^6V3|u:BOPNQt湃 'e~gd3oxZp^{,Eh?XBhu[# 5hI]pB 5YxB=` !n.`sfo/ ѣ}t:ߏ?l;K'ﴏ=#lR<;<|0&&&b?oƽ{>'ODۍvZxylnn-ߎ00677#" vfnZi2KV{#+z_ʨ"$4`#类eƫpd$nϳT|&[?\vKP4;;;b/(8qIw0\pPr?E =FT9zp.g=i#&B{!Ti'Z9W6.:eyn[v,w`ⱶ8<"A{,[CBxu%u>#'f+-9q|wv7Ǡ0"J k6eLF˝;\\Qh Pm4E". q w}nj+5#Fe2s6Ѷ Z,?я͛7YV-g|n?e;dY 9˺"S.r77MDܿ?v,--|<|0:Nw|| 'ٮ!suS˦eŸϟ4sshk՞9q`~ݹs'~tȠwߏ}vLNNFӉRK5h9@p8ƭ[J}vۍ:޽Z,--kq<{R׫r gNFH?<=zӱ;gggӧOcbb"VVV~E\ov'?)A 6+ok؂#]>?c8<>998::z2=;6"N+ٶ16q{^E E˲5ۇ, oD?W.;lO׆ey]ϴDl#`*z|Rߏٲm faYx|WW_ݻwKV=*'!M_l'fZ˃5(, 0lln4$whq{0nЦtb4X \6=c_OV~{{;^xǕ$]'gYx8X"˼ߓG&v;JF?t/+Nc e@9އ*%ЯVwK 47qfbSI8:LY/܏\@1;ddqndž-i=Y܀ϳq,7]l|gL 9~ngߦS] )4,8cqYXMCd,۷K-K]ˠl@G_ :[`~ P ri`pݛ |P m7\/̱Ǜ36.Oˁu {'f<=y<'ùeqvNpIuϭ :c׬u1[ h [Wƍ;;;+;S=Y搓hTc(;nܸQڃQWʁm1ыS ի1;;[3ö(b'@*cff|oY+e ^IZ܌R&j ~<|0ϣr'Qlww~w+3 ˩h\B63998??_xzzO>- 3?mN%lOlǬy9`B-dE@ݾ3 UXvv)t$"w9·*""?~\=lrjZ5cdjUOW\9d%;?ucC.o;ҡЍ~1 @M;#.Ohf<=Z·Nyzh4Dw`Ccr3u{06OvneǠH :K[u1sXgM°V9g- /ƒk2FcwQ7lxǫhtΆ$_u2?h{4syyEQ?>{LZF3L,`{?vЌvc#5ȃ?!*9b54 !_YO 2r;`}9H3s F_ry`P*cdm/.ض~W7΢,ž~}?pgAiN+8}3>Ud]yyܺucm8cZ9df[u>,r+`$7͒]e:S=GXt˻fffJyvvymm677/^gϞ]A8^ }{{{`Crwe1|Όm6%y|sy)c/%;N06"`K'9  %!mp(x+0^_|Et:+3$f"@8gd sV{fC6&ٰdl5̶Aˆ:79dGvc3uvvT|+?s[ ʠ.-; ^=Vk^gƕ{^2 x=>gH\9K[,cʂdž+69\bcc#z^ 蚍yU7M{g*4q=t-15ǔA7@g2?yƟC뜅t@}3VLrk5hl{\ th3PC.Y/xnҵ ;H~Ǡi݄%(ʀn[f@￴ӕuO=G릕}e 4(9۝}}NѨ,jmZ>dټsvv6&&&Uv XYYxQ%axppP,5:>>^Wj+of qyf>1sR}&e=쯌mYm]m㽮#o6%82'Xaq0{svvVxkqՈP?tڷǿgCj+?WV@ XuY,ocRg$^3wu.;X_Ev]ǀ>=?cAe`%!X7Ɣy{ BdZW?+$@3A_[]pXyOw^U_7"DG񌓣c9`0˙0ޗg ~L~OY 53FlGK@,4`icXVHb0LW;A ihT}@+hio`0l=6Uqr $pC- /}?tw}չoNԲlZ)@Jarv#+NߏZoC0JS0襯0ѾX2yYh(gl%roL ,Q;"N?+S6D)KAu28s?>-ܦ` v܌\ڐֶJ ( \=h:LZ.{4,A\bfKAg ty'_!X|o'm 3vOgB3S,3Β'3+,3]Ch4 9~ko^N0N#cF&4w1eoyݍ;wTf]^52}!_3=sd˴eW8==v Q411Q<n`>~qDߏۋ2N^s~͕Ͼ+VگKR:q嶲<8 d^X7!:ƔSݶݜTf/ Pz3 J Lf$XWDs=l-Z JYJ 2 e̢";g0}19:[pr3ȵb ٠egh#dnP aU.;3s~p>X.9Ϳ\{іǑ雿3]X=^CMd× ː6{_7 ?hp],[<{iY4 f=18ʠ̨!Fc ggtv6வ`fla@=aٯ֛,uuW,YyAvޅƀ^C{^zce Νv|+ͳzO?@02<+B&/φIĎYs1,yFuKq]ٟN;w*{h[26yg +ɀ̲C;SSSv".k۽;n陙hZ_g-E*;18KI[+ʾ{199?ϣĭ[Jpxʕ܌fb+ѥ?kf`P! u:m_͠/9%`p1@Ymݠ}x1-|w`AfEmww0)d.,~Q:lٝAVj2>;;]"\Awĥw]A:wϻ1gy6;r=#}TygPl3t3o^,eTy?kga1tv?6vA#g+3/.*8v9:w_NLqA۲cL1 Yn} f/pj~K{c#fff}lq^&ZDcGoxSz!ؐD*QF0+/am4emAes _03׎=g2xlh`=$Rޕn~'kE-#W"{q[sPO 8Q| ˲!6?gj~ }aEnM>[gf2cgXtlkkRx =g˝"pj69@6wvٹxc~~>^{/3 *%}@3$5=y]m 3l>FQb/AUf'c~h4ʑ "&ЁRr>&h4܅JYx 2ȅ!H& T<X) No3>Py5DP"⥝0<9̅F'בѾಮǠ:߇#^g{/sV{$Ȗw{>fd\}ܛ3&>@cʥNe!$={Vq@BVz i?LϬk\ow=~EkpGػZz眙s={f;{~wg=~`k hA,[!k>&-M?nÀ4'«9r]~֒ZW ik{{/:$@zω-m3 'ޘz 3(u1K'S78˵:~ %bu~e%u8gYڮr6>.󵾾޶;|pU5kcccl&ǶjPUe`nnݷf:vXvmuС0/07Loi۟en" ]B1 rO b[NJ 9;Jcz411Qc38[|*JfiMw'& r6jnuUM~1@r,]-NnL=ʕ%<݆5SM =8锻-9uLN>2P8s*/ q, M3}@. l<._|)L[&_lmO&YLgedp̩8p.e˯F_8 6cgYdžNGأA9kY_333cO%-YWV'&&ުU0h+ZqP0=yDTiG2 LJkT<%~uO%9ȑR~}>WOLַU'Olc/@h~yyy\RV>zhڵk5==]{jrr!`bܿnXy5 sQcm 0sv(vbg_]$u։ԠCpXsssmձ"[짦nU%4qԩ5??_5??_o߾k/,,:0Mɩ!L(PHe]Eu\}ɐdAM)!l#s*:#fvo*&=qwtÁ`iZC2wy2lI((( ̯/кjrrN<9u%L]<,~Y֎S7s_51fW_:vX%^C;;;; Ae<^:qD:t駟:zh]vm (/..֥KZ{aaI%/cLW-#/%r",0Mi2ʸN{`GdKP%3Q.= 4$v4]\v0m(6^048 nzU;+'68tR3@dlTᇗ Wx{ڼ ?vV#+)밯 zfrXr:Рf9:=9n h`ž?u|ovC)OOb+oN ]#z4C/kϑ`@?M5/ =^ k?Xa^:̠-O5qrr.\POMx/܏c-&J?v?sطz3yÇv_UʸVkն/0t>99Y/B-,,_Z>}?^W^m/mg}XِI} [vWFx8k3 {߮]WKFhTKKKb̘mll4ů?wkk&Maf nBmh޵ e׀j0@,Yt ,HWC R{ :.u2e#bL: "ٳhsyyhgjj$@|1IXl xss/c2؝99Am@_&\;,Zs{ h4{!ɡCj{{.^XO=T9s+>55UlxofffL6`޽O޽{} oZ[[;SŋϏUe9ub&uh4NI>G\];,1 K}zm9U|vpܻrɅ g.a(^]~&qW͝pcΣ[țڰ-_h'SaА`A%O0ru:RyW3Ik0ѕP gqZBA`ʎ{hG\Nl(o>u}V`9e6Z7I}κ~V<rKK/T.]׽um7Wv[f Tğzꩧܷo_y睵T/r+7o3Y}o&β/ghBu[Ag,+39ɲ)oK.|OR|ӿw޶`0h֛h cl:kȐW{ "ٹL-ƲmgU,1P\ʑJphn`30:@Rd4x <c^>ٰuFM;֏褓'@`5rsKּYK*940_N68ؾ5TVl1ore`nKѨU2Z~ItN%zz666JJZL.M(}Liy7As{{?=_lyuٶ 3ɮb/kKSᜓ}f<:m[D?;Q>}ZSVu m9KYKmh0v{h4[w ѣG;((&pqr4;`U&hpށ am+up;,۬ެcM@rx,(U"R|]OԔ9` nAg7ۻwo{ cdl3D5Lk3;;; 9mfffƶ?LߡP pu̺K\Z D*AAY']v@1gk .^w"~ZO9iqr)w/>ô\7g(]-@L\(zEl [_tuNpy_go VVL{3`v\EF)ڪ#G=ڲ @`mffy!Qkkk.]Tw 'k~| Zr>]@xj܀<8iI`dڐ~Y7@5{ bp:SC&>wZ~Cq~A+9dC]!H?7>Z72(A5mPgٕ,Xڞ 8kۄg>Ywɶ1Ke3B;}5/+lH=9[¸mYbm˩U5YJ%ϒ^@ڌyznY7^Zv[͍;vߖeN_wD^c:192n9bwv|r :x s͙f"|-`z3{3gR]zu}h4j= ]ƱDNlõ{s8V' 38fkmxW&kx06+8ٳmOON#@0F) "h;/!#R IDATjIXM0xCfiv0xv(iD9haۘ͆2&24@Vֵt*Ay:1(H{0?5| ǃW_}۩t0؃9V|7O$"kmAFc8r7CC“>2c>U~_Qcm|yY<=nbY 8|yɮNx l`UpHCծS5] S䬘I'|/*=x{+M`cgR܏"$oxd0`6308Mnn?101hX .m r r 芁Tp**ٿyUauT+LXvp?u'T4zIi@r"q2A`"iMc=f@^:Oj33Y^s(Ju9"v,[sPxkО+m?J\zA>?KI m> *W<~YGWloʕ[СCm qKMѴpms.9 4@wB ˚uh@4︰?h)h5߁o{իWkqqÝ-☡E'8ζy'Ծ6'-ώݞ5JXV.vwE"ILp?ةQNO:'O; &''kccclg_ɛkt. ܓJ8}S]>;>g=eo"95Mߑ iݠ?݉X.@om n~aᇑ(rFXh- #Xe907 )KbŮoܮI8Ęa86=??N7[:Wht㺶\s \ r۩!@?+MStl ` }}0FVQ 쐻ct<'%LMOO<===6xl}7w,+@ls{;^m'^fƞDZo~76al{0SNP:11Q?x8q.vŌێ7e#0{n܌D333u-TU=O:uú7 lRc/ÏݮyIrȊ<7ۉ? >w%p25tL˜u]p/9)>Xx1R3R"U3~Mzϙg(D*OzR[V4!a.U*ޙeCC'RaEl9"N6JZ x,\gg}曁(r0y\@4PHf[=O'vN쮴گ|selayH d Jv <@h:hHH͎݀غtm:g?  *!vt,3~sJs8ye1I1['K%oăF@:[ϊVn,zہuYdk[Nnٳ2~zPh_mbN,'2P7o[]]]'x~53c j ]%6O-s >qyt13~뭷`0˗//\'Nd8pvUV^y3mӵR.][nن϶;'1_|6?3ys`fggNJjnݲuop|YxLLLmGG|7 ?c/,2e AMNN֑#GjyyR{Z 5i@`5P6^6dZD۲@ \8>vVv;-~c-':AJ-=q JNðCA^<60vJ t0158U]hYrwN iܴ67j~@ k1 O!ZO5SfwpZmX3tp9aA?N\TBvзu"djjU2Y,z7^BA9B:낃}}wrS}[E\|i?@˯N^vvlvg;;V`,!6=wˇ <|i2xӾ;NßVU[qwʕ+gϞ:~x}}=4&]joVVVݶc%ЉaζF/d: :/uNu>h+GQ333m)@w,Bv~ؿ{ʕ+ٶ]]]cp3d:;%\xK0, 0h2߀jb!p<]aG@G-t9y/e`E5yDnU<0L7*LWy G ?w>߳S^E3wpb櫫*ۙF  L/:HzXj(cH>w% әlzݝa|m+y;?Ӄ 2m̶<2qh?e˝5)xf677[e ?!'2Y0q,C=zWx^ `/3ؒq4 >Sy:AsL;Fd<7iG… uС1_73A=e.ٷ;1tGcm0G|}_=3ꫯVUՉ'j}}:orSyqg=f}pw7qO&qqmmݺe=}:3CH&iyT׮Y௯L+&@t{p~~ lě]2pWBm|h\+JQ*&Jf늀a,Lsp~3(G}Ѷiq3>ăoa-o}$85|-+%$u:A/zS'F.8!z5ӖO*\c0 ]ZhSXJg?5[ج+Ȫ˾[kd$a?|w_\$X^^:r ?϶~28׮]`,=!>LXGGg=q]wOdb4f.eƜ`M΀oJs6lߟJZ00VIyx {rY5M> zK|bK|d>'*C>{y9~OOO秐Qwuy Yn++4<}uMar>V\*}s|ngJlEOq{µe2@'v& Bk0J `@o߾F`ӳKN8Xv%MPilS(;8m9dXw]Mp1ABlŶJ]&#ۺS)v'~^}edG W]:Wpp'NeӮc~ _IR tځ]"J?mF`s>3{ڧV dzgڶ-۴ej#ƀM%`IMMok:G]|=* iA~AJ`bYُ?]<7pKBMLLK/TkkkuСMNN.v .^hhM~RΩ捿>@buż3 ˜n5`$?e< $_9mKQWU-+lzÖH8HMƈѨ&70Ifƻ{ ̹%o$.dW2!+Gb ]`~+8DT4"++ bS$?%A)uն\7Fyi^19 u6Ae=x 7H劬NIhrh'ۃu˿abW9SuBoyK8Rni+qtى;53%Gt{mpUUmg<ՉZc/ӱl(vcm˯'YOڟǓO;1mkʴ~Ƈ"N<9tcuwaC|7'űcjuuk{{OImI3nЩvbx]fݮvsdkqrʰ)^dܗ~<ڪׯꘓa Օ^#;w:/:3ܻj[vͯ7h3EynO& >\)^ %ߝ8qүCS 6ŵMmqrrU׳,܆ò35 m]K 'x>/Z ofJ[7+ꤏzuʕ:|ppγ&>8qʕ+u-ٳgkuȑ:zh?~_]YSw=V2smʙtևzA[Ey AڅKT}d~~|oo qh4V7 hY?𛃯}tl n $p؉ {K8h8ܶ m , sHwe].+ANX!3 t 6[c0}$3k'4oo0k,Y|@,>xjK Mg2 #^hSjǓ:|=l{ped5&p&fLt0 {fGl{O'W(Fݝ|o*Lx^B<1-ӯ-oj?*.y|zߠqÆ h }cG V9f_e=zt,Nٮ9॓uj"y4q٫ 9a1ٺ;#Hvmu7ɓuԩ?_?s?v[ۮY9}. >Y*|ql\Y?vOA\!Bc5]{p9 v ᅃpwNR 8u"Au:L, eP| .rpL'ډpXP/|gggO@.~ځ`| ok'Sou!Aebb\L,SV~8m`.~iss=&tdҚV>wUAvI'79@o.8hJwRt2Mq6i`o˃.mY/T]|xo~'f}c`=.+ n:=ZwqG={Μ9SsO-..֣>Z.\ߩch}comjϙ4bhs$}qm̌}``ж(uip@Nztycy g':eJ qu/c*4OHW iR2 ͵*5sNEr"! Kg/}NǕ;&+V(mvaN%04Ma=KwVgוqYO*l浐v>v9ud9(؁жs L|`.ᤃ~: ~lKx=w8s> g< HNeh_ h-,c ٷ0^x51vm N^]Gh|ڵ#'~+Oa-wi'Ү]G Iuqѿ9Y|~Kn24lť|3 JBh4|;uwԾ}Zz=tv^Uqr0r`s5 s&ij-SɄ` #+HEY1$džL'teH5}ނ;&Ǎ1o;tP?~w{>Wgڵkuĉ@1:] Y{|8/qڌ}Bm]t;v.X w'a*VU') Cۈݮgd=f+v^4 ;S:l' ^4eL/sR@zF;8lokd]vUjV)uK0&6lgM2E3J[q%%ȃ1 Hwyȵ0V0~:qD8qbi~:mY$PL[\s,wygoSN]wUsssׅ  _B}m[~zyȑG?Z^>3<ӮcǎN}qNnvw}{~_NjO~:yX_?zGSN'>W_UU׿_ԇ>~_XX?סCUU /Թsmo{[;wx≪zX_v?חڿXx;ԩS[[c///_>`-o}gg5h}{^xܠڵklgϞsjW;\__{N1Dd-PN$xA4F #C}\~vf Y٠] >ʘI9)vµ6O164o=.X-[v~慃{N_Rp 1hP{<3cC9= &?19,G3=ܝ~Ȥ foG/l#[ڜ :hXΦ;\pRYUkm0Y 9ys 5xN@ b.(SV='':oOs&  o&r~hʼnV0cڃcw5ϴใڵOL[7h벻|_V^~] vYl=f,..3=~]?p9mnn;uT]j>O//C=Tokyy~W]3?_kiiΝ;WO>d/bUU}ߪ߮wAOO/\QgϞKKG>f߿a&"OtʼnlUP_ݺ=4 `GlԕNm;S^MLq`m<ͪX4Ag:ݔo21`#昻3Ap`rR㽣SMG j 1@|{8 -U?g:\) dx$]8 &rt>χ^tz`8Юq2F?jY933SuʕY9h\cMx(J ׺]xf &G7 +'$>I?oYsz.߭7uѡ+^XOkԧ>hdk_Z_bo~UPUUKKKg쟍%U;U}ώ`kK.ŷ-UUc?cz^?PѨ;;!ݿwuܹD_b?7Y׮]{>O=-xC'MozS~}fggkuucOvbQ @\L!gU JB/㰳 8ypwPiw*ۈ=né]6W2P{MQ>+"U䱺 O҆OSDRnw<2  eYdp`1N0Oh:c5`m`48}$`rfT<6n}=TxLȶj}%Ay1wjʂSQ ߠY dFD,3Ю+ BMWo/J`0݄m hvYWu{F;q͸`tbSG\Ƙ@9ɠ/cYߕ:.}mgqpKUիWjkK:-6 f3; /p_zW3L}cz\Vdd411QW\G}kyyFv]ploowo|MSSS;_^yvW_VζTUW:{l;ww5.]~{Ǫ[Z^^jIO>YRӝ_zW~WlckkT~'OtR\h$+:ĵ]`vt&ȊJrmAzA0a|'ߖg>=m7FA`>Gre3S걁(YtDڼfپԾs lh/o3eBA;v.}F /?^UؚKdjo޽SO^:|pn57߇oUI&(ׯ_}k''||?׾6<:umizz~g~~G/֗F}ջ?A-,,7ᰞ|ַU۵V/rT} _i|OvΙ_||&[nnkjjΝ;Wl\paO~~Wv}S/˭O4{^}_x>Oׯگ#<d|~ӟtVê{ oxC[-_?___k:p8~6FY__MLLB˿<o& OBά1A$MUە';{Y)} jc1tPurǎ*+J P\AzSp}fU:1o& ɩh;h˿ }/8LىA_RfߕYϞV=de=O1FC}W_Wo~CP-..>zg^ȏH=zN>]w۸AΎiHgffȑ#t}$v~X/`P/bMOOT8ptv[z᪝GGy~OOcV>_YwqGoOc<o}kwUU#>Y']UO}>W~#t~vv0]dͺmoooW4Vf~ P ;4Z+NXe~hyr5j곝f)cvG7{؁e]6RLа i6<~a:dc:zx=33SJ5;;[ׯ_WfmllUdf>CcLyg ,1qp@@αi -+;.PAK 8'$gT: e $=wd4HǶseg x9 kIJ;mP '(۷0Oβ}vy[̡ %*`AD&E9N@$ȓdKmk?}Bhg\GqX'୓yٺZ__`0r,J$9ro{ oh/.я93 N|c>xb}_'xb,3fև>z''W_}[U;cXlZ}߾}M677kssի7ߓSkQn]g]u2(ۅ|(3~.S%T|OYld`oyZ=_v5%h5:|ydoY'/ y.ykYF`ge+`z v6<^?uG] k'2tߙP$']5ۢ=-IX/)'D5xwcȼ?33@$ 3'a_1 vgO3F䕓'vc[gc0`JN~Ǿ v̱ʹҶ  |]wqybbVVVjjjN:ȕ㚴;㝓'|ַ~g~v/N6ȑ#??uzꩧ{/~uZ\\_|&''ҥK8Vy0ЉqssソUWL;f*cKlk~-p- .?̤ Y O ? uf}}G^ҮڳgOKPۖONW)t0NP\aNagcg3]I N+V4dWL+f`@"yIG:_w5 A>=L0 ܷAi7N@_}s0_0yP {s_ڇ[^hdiٱƒ?x`ƶs>2`qg~'c !K&''O=k;0PdabZ5I+f wkx om0F[> {io3^p8u%D;S]UxG `f<}_+'-;"#GO$ z"}b|/hkьC L'>|';j:|#{:j?U5sW^=SЇڶvXwqGя~^x]O>d]p&&&ƒ`ЖٳU8}[СC8:@%XֽMЅ$`P=F匝ԱcjnnN Q౹L':nfhبjKðNkQı~ O677,m#\>svٹX!l㩺񵩴Oy0g^&Aوiێbs$g&{z${Nyݕ@ g}ڵZ^^n) {6gϞxhm&&&:_o &Ov.in#rm3E :õvNy`%Q 9>~UmK;V.1.ިIpMtK:~Lb} )BЗ>_(8?gY bONN/Lj0iom Q]m0uȄt̲}M<>;:&hݿw*zD?1ꢕ=^|yk~3>u1jUf)TZXXh<"omm\]vmlyp8lN"f,Bud0`0cǎՁ:m< mcvt|x% ,ylGYSXKvlex&y!i'W~I=sƽZlh^pCkiDI+vnimdsEy̘YJK w+y|,׹%NO=:uzWQj0ܬ՚iN%AgN/O?֯wamƵ،,pwMМ&+Z%f|gMq֥'N>u%b93 !={ZC6;کd8vZfffڵT }Сvh˻?F-dH?NIj0̜mEiݾջ̸ ;6}$t],m+[VNFyOtʕ+PGiVOyا{]cȒyb_u]|^|:Lme|DN5irL)}YmllJ]ϹОDlꓱ2 غ@h{N_dc?B{~6s^oly'Rp>k~(zrrrld>|Mozy;4ƹ~jߎь: teYK1 yU.h#$iI\k s$+M:S I 4 wݖ reeẻw%) $)d^$&0bW]r)Fi.fe9g~&sM>,.J``T0L=3. 0gO.pDj->ȕWpg;NdjϜ3@w˟uE\ lee#vhvrMC뙆6(rΔ/O;7== }zOjgݾqr4>[/t۾m>"|&pLZ|at!C/u8@1f>v}Ѩ^ZgΜaV(ۅW۸AjN}D]Z%X39:4D+3<+=/Fv*555Usssc3dhJۯv%}D^_ K7hXf۳jNb.m.nij湌|w~zMo>AtJ;d·Rț4ˠ<`̤22PȠN.1 r*v4vG[n>g`Г1~G\LCA]ti~Y]]mk@6@fAǿgu n'nyMw-<=Xڵk533ó蔫i?w>dvw'[%rƗ6ls g$΀kuS{]N^Հv}ߺR{쩓'O6]~GT[*TF.}%lx3SSS uѵ'%^rvtM㹪] 7$G Wa'1ـ>X~qbbbl;8 ةifJ=zmɋdά8Ow{Ftgdwh9|.grqcOJ\ƽ*8pdvSa9kY_fԥC'e/R---6 `a{h2OYⷛB:?is@̑KNZw2ܠ<񘨊 o ݉c7NK@ ˳qjjmB^ݕp9ϲچ~ ɝ|j~~~@=saj-ƘL7j/}_@wp`gl^kt"u;1Dp:6g:Wo&렫 k']9^ZǏo 0.E~w̱Bg}yck~ cS ZeؗvoI\_{wi5\3zcUzCGBѕquIq&/-~YX.VŅĆLýyxz61` U4 ۑIh%X05+&H1s t` lde vUoYNV8NU _k[r\  >r/; /Y?lTv]-r۲d?IK:|-R%3-M u +ѮR@ CӒm+넹w'M'ޞ/֣%@Kp8&&&5;;(VCk唕1-롃{Sc ;KuYM?Nr]$D>:'XPUc zbD:^!KAIہﵨ?uvʌ̙3g=X-'}c}VS(yVUɿ?nnn}%577$?% Z[[kk=&Xx[SlK~Kۋ ]6^-e9ׯ_CxP\&p`i("u_y]Vm6j?i(>INØl d ΃\+A~g *]`)={R-..mEKKK7<$x lLUMv0vSn~ku:%W3i^K#/.9fʵ! jUe' Mv>\=?޼|F$ )^W󵰰В#-Nϛ836p( kllj 'JReT v$QrĊĤ H=glJEػ5kThek mcyi5a5P1`G2C0L^]] t-$` ^6G$ٓrXOd:ӈOΰ̛^El1rj~{O2<"r ]iߗA\ɟ76lWcD\< ͅoaͬA+Vh;H_Y86ѓ;n?ejg2Pccp_9923t{@ÊϸMc~l"h?YWWW N߰نy2>xb]pv̎.FF+l8@d,wwW3^tՙk]7HdgGy3 tmwux6 ٧.`v8 z\2bQd:S><x~ƴtqdUe#y蚟s0h<4h࠽:NІ뺼Rkݷx j\y4Cw>#ͿlVfi@_lN %`RV-WO od {<zXn :#Cz( &Hɽ @m)vm;}ӑ'8A,Ԃ*sgx~Xw}7럯r ?摅@c79$߆v3{`1yfFoJٵSI I A/xHY*˔Q?gyy` 2dU6 V`G7x5e Ne2fߴgC!di`pK ߝύdߘK}bӺNՀ ~B7R>;e%%So19 Dggrw̦%=v? 9*EE[mj f` |Ofk^ӧyr|bܓH/:?;;vۂpVWlx\ͤAAf챰6n;v7M[}Ki qpgʙm?'`̓HlNU7%pYP3LKŌ@/@6 $zbQX,j4%99hd#At/3i6ٸAFc6}/7q[G3t!s [Rν(/m,m[v8X{QhdFvJX/ -3? r sf)0Hף6q|vNf`=s`Iq<`o| [/r퓖>}+Idyb?eem3 +/@Yp@s,Z,7Zpu'mDK>ݾ~։ R=f؝ Kl 20NI@itR[_L?,A{;Il!"}5厳٬qT펷D~ ɚԓiw?oe"3.2ݸGOd`2[GV0nlj_#1*1) ( #include #include "gd.h" #include "gdtest.h" static const unsigned char pngdata[93]; int main(void) { gdImagePtr im; gdSetErrorMethod(gdSilence); if ( ( im = gdImageCreateFromPngPtr(93, (char*) &pngdata[0]) ) == NULL) { return 0; } else { fprintf(stderr, "failed!\n"); gdImageDestroy(im); return 1; } return 0; } /* PNG data */ static const unsigned char pngdata[93] = {137,80,78,71,13,10,26,10,0,0, 0,13,73,72,68,82,0,0,0,120,0,0,0,131,8,6,0,0,0,70,49,223,8,0,0,0,6,98, 75,71,68,0,255,0,255,0,255,160,189,167,147,0,0,0,9,112,72,89,115,0,0,92, 70,0,0,92,70,1,20,148,67,65,0,0,0,9,118,112,65,103,0,0,0,120,0,0,0,131, 0,226,13,249,45 }; libgd-gd-2.1.1/tests/png/bug00088.c000066400000000000000000000014171245535672000164470ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main() { int error; gdImagePtr im; FILE *fp; char path[1024]; const char * files[2] = {"bug00088_1.png", "bug00088_2.png"}; const char * files_exp[2] = {"bug00088_1_exp.png", "bug00088_2_exp.png"}; int i, cnt = 2; error = 0; for (i = 0; i < cnt; i++) { sprintf(path, "%s/png/%s", GDTEST_TOP_DIR, files[i]); fp = fopen(path, "rb"); if (!fp) { printf("failed, cannot open file <%s>\n", path); return 1; } im = gdImageCreateFromPng(fp); fclose(fp); if (!im) { error |= 1; continue; } sprintf(path, "%s/png/%s", GDTEST_TOP_DIR, files_exp[i]); if (!gdAssertImageEqualsToFile(path, im)) { error |= 1; } gdImageDestroy(im); } return error; } libgd-gd-2.1.1/tests/png/bug00088_1.png000066400000000000000000000035441245535672000172340ustar00rootroot00000000000000PNG  IHDR}9@ pHYs  tIME 5×IDATh?oc2Ё~)\$ ] ( _Tjm!} lէMZ )Y H/lAg)?! c3{fzSxw? 6E%9o<'f:ǘ>擘@)?cWJҫ|Ohm*{JW^A ( GJy-G |>*j$il@zw`r,gS;lZ#)J+-k"yLBmkw*;Ǻ|gBn>=ghFJ}ccJpHX+1v`8m[;Gn>MawWw̞ սu/Onnj+9ĊKtLGeLkocZ(ɋs7] rt%F-O~D h+* NV iCQ8V衜8]aM=%6A6_O!m3,z w6)(eС 0'Y[}yc|- JQ0vd8%.]!e¬!^ NnQi|̋r]7,Y&8q -I1m<|`^ 9O<0Q)Yg[0dfP LZ֦Kb}FK(9un3s[TAfNks!vJd.w nzKf 3HF#&x7dw 13ƛDcY=U6}m3᭮[l/eiq93Ө=*4d L3sCȘl!:oάNCmq|&6=B+=ET^tI:e0hP| %v;-,qq]VT,{*נ[٫,[ԫ&r'|Yk`DT:ۼuh6tuvrwqM7|2:<Ӈb%W&f`9SD|Y\Uuj"vuN&bMfζ*?._DC7i"ѥD.i)]#>ecU?pdE=~耝d';}=@]|8b=,\ו/ODD퀿O" "_MT+YnTX5MK0]]]V3 4MC(+%MS|W9Ii|vK눌i5MSsdF!`&AqoYV*x}o߾a6Ç0 c)iڶ ]חA\4K3VMHdqΉsNYu8tu:T օsNBB^ֶ9 ð.Mvҟ]Ge 4M6޴- ՅxMy{.SM^4ee-,JF kc^ UE䅦i2pZ!˲GXn&iVx6ƙڴ$h#9%uþ5jM 7njSGߋcifA^4ES.CPj$]f j[t)sM4]~I@Wif$ <'I ض].~eY  cT3Mӥ4MVtf[C#~QRKrttZG0 Wh48PjA ֖oҼt:]uL& hiR#"cl0`ƭ`08,k/I*7xm8ajUKHvyyYd (!ng,y$)p}5Mok]̮8 +Q*2U`0XzQ0BQ !(&o\y_~ewtM%7ٕi,˪usqy^#Ѓ p8 قji& FQB4 B0ON83VY&穩M#I(U%I9L, ykbY8<[b iK@]?~gggvKGQT8dxzz*5P;K)),(0 |_ 뻮0Mmk[[UI#_N\@TAE+j6r&wM: vMBМe>Œw%E<σ#ݤIM~Y*/Qߺ#h"$>t]G=O٭=ǠJ$.k {! f#q*oix(ubeZ( 0sneYxݺL{șt~ L0M'''Fi" CXEϟ?1NNN1hXY8$ FQih4j%kUu !Am.q\Y!;ϭHkeM TI[SD1[8Y8KirIecB,11,n.XZ7]GNgV=s6^~]XXVѪR6s}ЫZUeZoYV.$hKB,_-)e9q)iSŪ:V$~Vt~~^:yFtL<~cɖ\WפBzA-}{}hb>k-?#KV qyڶ X;ȓJr; 9H3KM#HYj!"D!B"D!B"D.K:=IENDB`libgd-gd-2.1.1/tests/png/bug00088_2_exp.png000066400000000000000000000004341245535672000201040ustar00rootroot00000000000000PNG  IHDRddpTsRGBbKGD pHYs  tIME ' ~^CtEXtCommentCreated with The GIMPd%nsIDATxQ Ei1q~ `E͍㙹~UUk'AADAAAAADAADA8XW:1r9IENDB`libgd-gd-2.1.1/tests/png/bug00193.c000066400000000000000000000012601245535672000164400ustar00rootroot00000000000000#include #include "gd.h" #include "gdhelpers.h" #include "gdtest.h" static gdImagePtr im; #define TERMINATE(ctx, status) do { \ free(ctx); \ gdImageDestroy(im); \ exit(status); \ } while (0) static void failPutC(gdIOCtxPtr ctx, int c) { (void)c; TERMINATE(ctx, 1); } static int failPutBuf(gdIOCtxPtr ctx, const void * data, int size) { (void)data; (void)size; TERMINATE(ctx, 1); return -1; } int main() { gdIOCtxPtr ctx; gdSetErrorMethod(gdSilence); im = gdImageCreate(100, 100); ctx = (gdIOCtxPtr)malloc(sizeof(gdIOCtx)); ctx->putC = failPutC; ctx->putBuf = failPutBuf; gdImagePngCtx(im, ctx); TERMINATE(ctx, 0); return 0; } libgd-gd-2.1.1/tests/png/emptyfile000066400000000000000000000000001245535672000170320ustar00rootroot00000000000000libgd-gd-2.1.1/tests/png/png_im2im.c000066400000000000000000000025241245535672000171530ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int r, g, b; void *p; int size = 0; int status = 0; CuTestImageResult result = {0, 0}; src = gdImageCreate(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } r = gdImageColorAllocate(src, 0xFF, 0, 0); g = gdImageColorAllocate(src, 0, 0xFF, 0); b = gdImageColorAllocate(src, 0, 0, 0xFF); gdImageFilledRectangle(src, 0, 0, 99, 99, r); gdImageRectangle(src, 20, 20, 79, 79, g); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_PNG(name) do { \ FILE *fp; \ \ fp = fopen("png_im2im_" #name ".png", "wb"); \ if (fp) { \ gdImagePng(name, fp); \ fclose(fp); \ } \ } while (0) OUTPUT_PNG(src); p = gdImagePngPtr(src, &size); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromPngPtr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_PNG(dst); gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/png/png_null.c000066400000000000000000000003621245535672000171060ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr im; gdSetErrorMethod(gdSilence); im = gdImageCreateFromPng(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImagePng(im, NULL); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/png/png_resolution.c000066400000000000000000000013131245535672000203340ustar00rootroot00000000000000#include "gd.h" #include #include #include "gdtest.h" int main() { gdImagePtr im; void *data; int size, red; im = gdImageCreate(100, 100); gdImageSetResolution(im, 72, 300); red = gdImageColorAllocate(im, 0xFF, 0x00, 0x00); gdImageFilledRectangle(im, 0, 0, 99, 99, red); data = gdImagePngPtr(im, &size); gdImageDestroy(im); im = gdImageCreateFromPngPtr(size, data); gdFree(data); if (!gdTestAssert(gdImageResolutionX(im) == 72) || !gdTestAssert(gdImageResolutionY(im) == 300)) { gdTestErrorMsg("failed image resolution X (%d != 72) or Y (%d != 300)\n", gdImageResolutionX(im), gdImageResolutionY(im)); gdImageDestroy(im); return 1; } gdImageDestroy(im); return 0; } libgd-gd-2.1.1/tests/test_config.h.in000066400000000000000000000002001245535672000174110ustar00rootroot00000000000000/* Define the full path to the top src dir, required to get the path * of each input data */ #define GDTEST_TOP_DIR "@srcdir@" libgd-gd-2.1.1/tests/tga/000077500000000000000000000000001245535672000151125ustar00rootroot00000000000000libgd-gd-2.1.1/tests/tga/CMakeLists.txt000066400000000000000000000003441245535672000176530ustar00rootroot00000000000000 SET(TESTS_FILES tga_null ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/tga/tga_null.c000066400000000000000000000002261245535672000170630ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromTga(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } return 0; } libgd-gd-2.1.1/tests/tiff/000077500000000000000000000000001245535672000152675ustar00rootroot00000000000000libgd-gd-2.1.1/tests/tiff/CMakeLists.txt000066400000000000000000000003611245535672000200270ustar00rootroot00000000000000 SET(TESTS_FILES tiff_im2im tiff_null ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/tiff/tiff_im2im.c000066400000000000000000000025661245535672000174710ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int r, g, b; void *p; int size = 0; int status = 0; #if 0 CuTestImageResult result = {0, 0}; #endif src = gdImageCreate(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } r = gdImageColorAllocate(src, 0xFF, 0, 0); g = gdImageColorAllocate(src, 0, 0xFF, 0); b = gdImageColorAllocate(src, 0, 0, 0xFF); gdImageFilledRectangle(src, 0, 0, 99, 99, r); gdImageRectangle(src, 20, 20, 79, 79, g); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_TIFF(name) do { \ FILE *fp; \ \ fp = fopen("tiff_im2im_" #name ".tiff", "wb"); \ if (fp) { \ gdImageTiff(name, fp); \ fclose(fp); \ } \ } while (0) OUTPUT_TIFF(src); p = gdImageTiffPtr(src, &size); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromTiffPtr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_TIFF(dst); #if 0 gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } #endif gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/tiff/tiff_null.c000066400000000000000000000003011245535672000174070ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromTiff(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImageTiff(im, NULL); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/wbmp/000077500000000000000000000000001245535672000153045ustar00rootroot00000000000000libgd-gd-2.1.1/tests/wbmp/CMakeLists.txt000066400000000000000000000003611245535672000200440ustar00rootroot00000000000000 SET(TESTS_FILES wbmp_im2im wbmp_null ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/wbmp/wbmp_im2im.c000066400000000000000000000024511245535672000175140ustar00rootroot00000000000000#include "gd.h" #include "gdtest.h" int main() { gdImagePtr src, dst; int b; void *p; int size = 0; int status = 0; CuTestImageResult result = {0, 0}; src = gdImageCreate(100, 100); if (src == NULL) { printf("could not create src\n"); return 1; } gdImageColorAllocate(src, 0xFF, 0xFF, 0xFF); /* allocate white for background color */ b = gdImageColorAllocate(src, 0, 0, 0); gdImageRectangle(src, 20, 20, 79, 79, b); gdImageEllipse(src, 70, 25, 30, 20, b); #define OUTPUT_WBMP(name) do { \ FILE *fp; \ \ fp = fopen("wbmp_im2im_" #name ".wbmp", "wb"); \ if (fp) { \ gdImageWBMP(name, 1, fp); \ fclose(fp); \ } \ } while (0) OUTPUT_WBMP(src); p = gdImageWBMPPtr(src, &size, 1); if (p == NULL) { status = 1; printf("p is null\n"); goto door0; } if (size <= 0) { status = 1; printf("size is non-positive\n"); goto door1; } dst = gdImageCreateFromWBMPPtr(size, p); if (dst == NULL) { status = 1; printf("could not create dst\n"); goto door1; } OUTPUT_WBMP(dst); gdTestImageDiff(src, dst, NULL, &result); if (result.pixels_changed > 0) { status = 1; printf("pixels changed: %d\n", result.pixels_changed); } gdImageDestroy(dst); door1: gdFree(p); door0: gdImageDestroy(src); return status; } libgd-gd-2.1.1/tests/wbmp/wbmp_null.c000066400000000000000000000003041245535672000174440ustar00rootroot00000000000000#include "gd.h" int main() { gdImagePtr im; im = gdImageCreateFromWBMP(NULL); if (im != NULL) { gdImageDestroy(im); return 1; } gdImageWBMP(im, 0, NULL); /* noop safely */ return 0; } libgd-gd-2.1.1/tests/xpm/000077500000000000000000000000001245535672000151435ustar00rootroot00000000000000libgd-gd-2.1.1/tests/xpm/CMakeLists.txt000066400000000000000000000003721245535672000177050ustar00rootroot00000000000000 SET(TESTS_FILES bug00166 bug00185 color_name ) FOREACH(test_name ${TESTS_FILES}) add_executable(${test_name} "${test_name}.c") target_link_libraries (${test_name} gdTest) add_test(NAME ${test_name} COMMAND ${test_name}) ENDFOREACH(test_name) libgd-gd-2.1.1/tests/xpm/bug00166.c000066400000000000000000000007661245535672000164720ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main(void) { gdImagePtr im; char path[1024]; int c, result; sprintf(path, "%s/xpm/bug00166.xpm", GDTEST_TOP_DIR); im = gdImageCreateFromXpm(path); if (!im) { return 2; } c = gdImageGetPixel(im, 1, 1); if (gdImageRed(im, c) == 0xAA && gdImageGreen(im, c) == 0xBB && gdImageBlue(im, c) == 0xCC) { result = 0; } else { result = 1; } gdImageDestroy(im); return result; } libgd-gd-2.1.1/tests/xpm/bug00166.xpm000066400000000000000000000002331245535672000170410ustar00rootroot00000000000000/* XPM */ static char * a[] = { /* width height colors cpp */ "4 4 3 1", " c None", "@ c #abc", ". c #def", /* pixels */ " .. ", ".@@.", ".@@.", " .. "}; libgd-gd-2.1.1/tests/xpm/bug00185.c000066400000000000000000000007631245535672000164700ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" /* To check memory leaks, run such as 'valgrind --leak-check=full ./bug00185' */ int main() { gdImagePtr im; char path[1024]; sprintf(path, "%s/xpm/bug00185.xpm", GDTEST_TOP_DIR); im = gdImageCreateFromXpm(path); if (!im) return 1; gdImageDestroy(im); sprintf(path, "%s/xpm/bug00185_damaged.xpm", GDTEST_TOP_DIR); im = gdImageCreateFromXpm(path); if (!im) return 0; gdImageDestroy(im); return 2; } libgd-gd-2.1.1/tests/xpm/bug00185.xpm000066400000000000000000000002411245535672000170410ustar00rootroot00000000000000/* XPM */ static char * a[] = { /* width height colors cpp */ "4 4 3 1", " c None", "x c #ff00ff", ". c #ff0000", /* pixels */ " ..x", ".xxx", "xxx.", "x.. "}; libgd-gd-2.1.1/tests/xpm/bug00185_damaged.xpm000066400000000000000000000002271245535672000205070ustar00rootroot00000000000000/* XPM */ static char * a[] = { /* width height colors cpp */ "4 4 3 1", " c None", "x c #ff00ff", ". c #ff0000", /* pixels */ " ..x", "xxx.", "x.. " libgd-gd-2.1.1/tests/xpm/color_name.c000066400000000000000000000007671245535672000174370ustar00rootroot00000000000000/* $Id$ */ #include "gd.h" #include #include #include "gdtest.h" int main(void) { gdImagePtr im; char path[1024]; int c, result; sprintf(path, "%s/xpm/color_name.xpm", GDTEST_TOP_DIR); im = gdImageCreateFromXpm(path); if (!im) { return 2; } c = gdImageGetPixel(im, 2, 2); if (gdImageRed(im, c) == 0xFF && gdImageGreen(im, c) == 0xFF && gdImageBlue(im, c) == 0x0) { result = 0; } else { result = 1; } gdImageDestroy(im); return result; } libgd-gd-2.1.1/tests/xpm/color_name.xpm000066400000000000000000000002511245535672000200050ustar00rootroot00000000000000/* XPM */ static char *color_name = { "3 5 6 1", " c None", "A c AliceBlue", "b c blue", "c c cyan", "w c wheat", "y c yellow", " A ", "AbA", "yby", "ycy", "wcw", }; libgd-gd-2.1.1/thumbs.bat000066400000000000000000000014651245535672000151750ustar00rootroot00000000000000@echo off rem thumbs wrapper for windows; see main file for details rem find bash from git rem assumes git is in [gitdir]\cmd rem and msys in [gitdir]\bin for %%i in (git.exe) do set gitexe=%%~$PATH:i pushd "%gitexe%\..\..\bin" set bashdir=%cd% popd set path=%bashdir%;%path% rem copy all known env vars to bash setlocal enableDelayedExpansion set exports= for %%i in (tbs_conf tbs_arch tbs_tools tbs_static_runtime) do ( if not [!%%i!]==[] ( set exports=!exports!export %%i=!%%i!; ) ) rem copy dep settings for %%i in (zlib libjpeg_turbo libpng libtiff freetype libiconv) do ( for %%j in (repo incdir libdir built) do ( if not [!tbsd_%%i_%%j!]==[] ( set exports=!exports!export tbsd_%%i_%%j=!tbsd_%%i_%%j!; ) ) ) bash -c "%exports%./thumbs.sh %*" libgd-gd-2.1.1/thumbs.sh000077500000000000000000000164361245535672000150500ustar00rootroot00000000000000#!/bin/bash # THe Ultimate Make Bash Script # Used to wrap build scripts for easy dep # handling and multiplatform support # Basic usage on *nix: # export tbs_arch=x86 # ./thumbs.sh make # On Win (msvc 2013): # C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall x86_amd64 # SET tbs_tools=msvc12 # thumbs make # On Win (mingw32): # SET path=C:\mingw32\bin;%path% # SET tbs_tools=mingw # SET tbs_arch=x86 # thumbs make # Global settings are stored in env vars # Should be inherited [ $tbs_conf ] || export tbs_conf=Release [ $tbs_arch ] || export tbs_arch=x64 [ $tbs_tools ] || export tbs_tools=gnu [ $tbs_static_runtime ] || export tbs_static_runtime=0 [ $tbs_gd_png ] || export tbs_gd_png=1 [ $tbs_gd_jpeg ] || export tbs_gd_jpeg=1 [ $tbs_gd_freetype ] || export tbs_gd_freetype=1 [ $tbs_gd_tiff ] || export tbs_gd_tiff=1 # tbsd_* contains dep related settings # tbsd_[name]_* contains settings specific to the dep # name should match the repo name # deps contains a map of what should be built/used # keep the keys in sync ... no assoc arrays on msys :/ # targ contains a target for each dep (default=empty str) # post is executed after each thumbs dep build # ^ used for copying/renaming any libs you need - uses eval zname=zlib.lib jname=jpeg.lib pname=png.lib tname=tiff.lib fname=freetype.lib if [ $tbs_tools = gnu -o $tbs_tools = mingw ] then zname=libz.a jname=libjpeg.a pname=libpng.a tname=libtiff.a fname=libfreetype.a fi deps=() targ=() post=() [ $tbsd_zlib_repo ] || export tbsd_zlib_repo="https://github.com/imazen/zlib" [ $tbsd_libpng_repo ] || export tbsd_libpng_repo="https://github.com/imazen/libpng" [ $tbsd_libjpeg_turbo_repo ] || export tbsd_libjpeg_turbo_repo="https://github.com/imazen/libjpeg-turbo libjpeg_turbo" [ $tbsd_libtiff_repo ] || export tbsd_libtiff_repo="https://github.com/imazen/libtiff" [ $tbsd_freetype_repo ] || export tbsd_freetype_repo="https://github.com/imazen/freetype" if [[ "$OSTYPE" == "darwin"* ]]; then cp="rsync" else cp="cp" fi deps+=(zlib); targ+=(zlibstatic) post+=("$cp -u \$(./thumbs.sh list_slib) ../../deps/$zname") if [ $tbs_gd_png -gt 0 ]; then deps+=(libpng); targ+=(png16_static) post+=("$cp -u \$(./scripts/thumbs.sh list_slib) ../../deps/$pname") fi if [ $tbs_gd_jpeg -gt 0 ]; then deps+=(libjpeg_turbo); targ+=(jpeg_static) post+=("for lib in \$(./thumbs.sh list_slib); do [ -f \$lib ] && $cp -u \$lib ../../deps/$jname; done") fi if [ $tbs_gd_tiff -gt 0 ]; then ttarg="libtiff/tiff_static" [ $tbs_tools = gnu -o $tbs_tools = mingw ] && ttarg=tiff_static deps+=(libtiff); targ+=($ttarg) post+=("$cp -u \$(./thumbs.sh list_slib) ../../deps/$tname") fi if [ $tbs_gd_freetype -gt 0 ]; then deps+=(freetype); targ+=("freetype_static") post+=("$cp -u \$(./thumbs.sh list_slib) ../../deps/$fname") fi # ----------- # dep processor process_deps() { mkdir build_deps mkdir deps cd build_deps for key in "${!deps[@]}" do dep=${deps[$key]} i_dep_repo="tbsd_${dep}_repo" i_dep_incdir="tbsd_${dep}_incdir" i_dep_libdir="tbsd_${dep}_libdir" i_dep_built="tbsd_${dep}_built" [ ${!i_dep_built} ] || export "${i_dep_built}=0" if [ ${!i_dep_built} -eq 0 ] then git clone ${!i_dep_repo} --depth 1 cd $dep || exit 1 thumbs="./thumbs.sh" [ ! -f $thumbs ] && thumbs=$(find . -name thumbs.sh -maxdepth 2) $thumbs make ${targ[$key]} || exit 1 # copy any includes and do poststep $cp -u -r $($thumbs list_inc) ../../deps eval ${post[$key]} # look in both local and parent dep dirs export "${i_dep_incdir}=../../deps;deps" export "${i_dep_libdir}=../../deps;deps" export "${i_dep_built}=1" cd .. fi done export "${i_dep_incdir}=../../deps/freetype;deps/freetype" cd .. } # ----------- # constructs dep dirs for cmake postproc_deps() { cm_inc= cm_lib= for dep in "${deps[@]}" do i_dep_incdir="tbsd_${dep}_incdir" i_dep_libdir="tbsd_${dep}_libdir" cm_inc="${!i_dep_incdir};$cm_inc" cm_lib="${!i_dep_libdir};$cm_lib" done cm_args+=(-DCMAKE_LIBRARY_PATH=$cm_lib) cm_args+=(-DCMAKE_INCLUDE_PATH=$cm_inc) } # ----------- if [ $# -lt 1 ] then echo "" echo " Usage : ./thumbs [command]" echo "" echo " Commands:" echo " make - builds everything" echo " check - runs tests" echo " clean - removes build files" echo " list - echo paths to any interesting files" echo " space separated; relative" echo " list_bin - echo binary paths" echo " list_inc - echo lib include files" echo " list_slib - echo static lib path" echo " list_dlib - echo dynamic lib path" echo "" exit fi # ----------- upper() { echo $1 | tr [:lower:] [:upper:] } # Local settings l_inc="./src/gd.h ./src/gd_io.h ./src/gdfx.h" l_slib= l_dlib= l_bin= list= make= c_flags= cm_tools= cm_args=(-DCMAKE_BUILD_TYPE=$tbs_conf) cm_args+=(-DBUILD_TEST=1) cm_args+=(-DENABLE_PNG=$tbs_gd_png) cm_args+=(-DENABLE_JPEG=$tbs_gd_jpeg) cm_args+=(-DENABLE_FREETYPE=$tbs_gd_freetype) cm_args+=(-DENABLE_TIFF=$tbs_gd_tiff) target= [ $2 ] && target=$2 # ----------- case "$tbs_tools" in msvc12) cm_tools="Visual Studio 12" [ "$target" = "" ] && mstrg="GD.sln" || mstrg="$target.vcxproj" make="msbuild.exe $mstrg //p:Configuration=$tbs_conf //v:m" l_slib="./build/Bin/$tbs_conf/libgd_static.lib" l_dlib="./build/Bin/$tbs_conf/libgd.lib" l_bin="./build/Bin/$tbs_conf/libgd.dll" list="$l_bin $l_slib $l_dlib $l_inc" ;; gnu) cm_tools="Unix Makefiles" c_flags+=" -fPIC" make="make $target" l_slib="./build/Bin/libgd.a" l_dlib="./build/Bin/libgd.so" l_bin="$l_dlib" list="$l_slib $l_dlib $l_inc" ;; mingw) cm_tools="MinGW Makefiles" make="mingw32-make $target" c_flags+=" -fkeep-inline-functions" # allow sh in path; some old cmake/mingw bug? cm_args+=(-DCMAKE_SH=) l_slib="./build/Bin/liblibgd.a" l_dlib="./build/Bin/liblibgd.dll.a" l_bin="./build/Bin/liblibgd.dll" list="$l_bin $l_slib $l_dlib $l_inc" ;; *) echo "Tool config not found for $tbs_tools" exit 1 ;; esac # ----------- case "$tbs_arch" in x64) [ $tbs_tools = msvc12 ] && cm_tools="$cm_tools Win64" [ $tbs_tools = gnu -o $tbs_tools = mingw ] && c_flags+=" -m64" ;; x86) [ $tbs_tools = gnu -o $tbs_tools = mingw ] && c_flags+=" -m32" ;; *) echo "Arch config not found for $tbs_arch" exit 1 ;; esac # ----------- if [ $tbs_static_runtime -gt 0 ] then [ $tbs_tools = msvc12 ] && c_flags+=" /MT" [ $tbs_tools = gnu ] && cm_args+=(-DCMAKE_SHARED_LINKER_FLAGS="-static-libgcc -static-libstdc++") [ $tbs_tools = mingw ] && cm_args+=(-DCMAKE_SHARED_LINKER_FLAGS="-static") fi # ----------- case "$1" in make) process_deps postproc_deps mkdir build cd build cm_args+=(-DCMAKE_C_FLAGS_$(upper $tbs_conf)="$c_flags") cm_args+=(-DCMAKE_CXX_FLAGS_$(upper $tbs_conf)="$c_flags") cmake -G "$cm_tools" "${cm_args[@]}" .. || exit 1 $make || exit 1 cd .. ;; check) cd build ctest -C $tbs_conf . || exit 1 cd .. ;; clean) rm -rf deps rm -rf build_deps rm -rf build ;; list) echo $list;; list_bin) echo $l_bin;; list_inc) echo $l_inc;; list_slib) echo $l_slib;; list_dlib) echo $l_dlib;; *) echo "Unknown command $1" exit 1;; esac libgd-gd-2.1.1/windows/000077500000000000000000000000001245535672000146675ustar00rootroot00000000000000libgd-gd-2.1.1/windows/Makefile.vc000066400000000000000000000173201245535672000167410ustar00rootroot00000000000000# To build locally get a copy of the dependancies (https://github.com/imazen/gd-win-dependencies) # Then run 'nmake /f windows\Makefile.vc' in MS dev console # To build tests as well 'nmake /f windows\Makefile.vc all' # To build tests and execute them 'nmake /f windows\Makefile.vc check' CC=cl LD=link LB=lib !IFNDEF PLATFORM PLATFORM=x86 !ENDIF # detect x64 cross-compiler env !IF "$(PREFERREDTOOLARCHITECTURE)" == "x64" PLATFORM=x64 !ENDIF PLATFORM=$(PLATFORM:X=x) BUILD_DIR=build_msvc12_$(PLATFORM) GD_DLL=libgd.dll GD_LIB=libgd_a.lib SDR=$(BUILD_DIR)\obj^\ TDR=$(BUILD_DIR)\tests^\ TARGETDLL=$(BUILD_DIR)\$(GD_DLL) TARGETLIB=$(BUILD_DIR)\$(GD_LIB) OBJECTS=$(SDR)gd.obj $(SDR)gd_color.obj $(SDR)gd_color_map.obj $(SDR)gd_transform.obj $(SDR)gdfx.obj $(SDR)gd_security.obj $(SDR)gd_gd.obj $(SDR)gd_gd2.obj $(SDR)gd_io.obj $(SDR)gd_io_dp.obj $(SDR)gd_gif_in.obj $(SDR)gd_gif_out.obj $(SDR)gd_io_file.obj $(SDR)gd_io_ss.obj $(SDR)gd_jpeg.obj $(SDR)gd_png.obj $(SDR)gd_ss.obj $(SDR)gd_topal.obj $(SDR)gd_wbmp.obj $(SDR)gdcache.obj $(SDR)gdfontg.obj $(SDR)gdfontl.obj $(SDR)gdfontmb.obj $(SDR)gdfonts.obj $(SDR)gdfontt.obj $(SDR)gdft.obj $(SDR)gdhelpers.obj $(SDR)gdkanji.obj $(SDR)gdtables.obj $(SDR)gdxpm.obj $(SDR)wbmp.obj $(SDR)gd_filter.obj $(SDR)gd_nnquant.obj $(SDR)gd_rotate.obj $(SDR)gd_matrix.obj $(SDR)gd_interpolation.obj $(SDR)gd_crop.obj $(SDR)webpimg.obj $(SDR)gd_webp.obj $(SDR)gd_tiff.obj $(SDR)gd_tga.obj $(SDR)gd_bmp.obj $(SDR)gd_xbm.obj $(SDR)gd_color_match.obj $(SDR)gd_version.obj $(SDR)gd_filename.obj TESTS=bmp\bmp_im2im bmp\bmp_null freetype\bug00132 gd\gd_im2im gd\gd_null gd\gd_num_colors gd\gd_versiontest gd2\gd2_empty_file gd2\gd2_im2im gd2\gd2_null gd2\gd2_read gdimagearc\bug00079 gdimagecolorclosest\gdimagecolorclosest gdimagecolordeallocate\gdimagecolordeallocate gdimagecolorexact\gdimagecolorexact gdimagecolorreplace\gdimagecolorreplace gdimagecolorresolve\gdimagecolorresolve gdimagecolortransparent\gdimagecolortransparent gdimagecopy\bug00007 gdimagecopy\bug00081 gdimagecopyrotated\bug00020 gdimagefile\gdnametest gdimagefill\bug00002_1 gdimagefill\bug00002_2 gdimagefill\bug00002_3 gdimagefill\bug00002_4 gdimagefilledellipse\bug00010 gdimagefilledellipse\bug00191 gdimagefilledpolygon\bug00100 gdimagefilledpolygon\gdimagefilledpolygon0 gdimagefilledpolygon\gdimagefilledpolygon1 gdimagefilledpolygon\gdimagefilledpolygon2 gdimagefilledpolygon\gdimagefilledpolygon3 gdimagefilledrectangle\bug00004 gdimagefilledrectangle\bug00078 gdimagefilledrectangle\bug00106_gdimagefilledrectangle gdimagefilltoborder\bug00037 gdimagefilter\gdCopyBlurred gdimageline\bug00072 gdimageline\bug00077 gdimageline\bug00111 gdimageline\gdImageAALine_thickness gdimageline\gdimageline_aa gdimageline\gdimageline_aa_outofrange gdimageline\gdimageline_bug5 gdimageopenpolygon\gdimageopenpolygon0 gdimageopenpolygon\gdimageopenpolygon1 gdimageopenpolygon\gdimageopenpolygon2 gdimageopenpolygon\gdimageopenpolygon3 gdimagepixelate\gdimagepixelate gdimagepolygon\gdimagepolygon0 gdimagepolygon\gdimagepolygon1 gdimagepolygon\gdimagepolygon2 gdimagepolygon\gdimagepolygon3 gdimagerectangle\bug00003 gdimagerectangle\bug00106_gdimagerectangle gdimagerotate\bug00067 gdimagerotate\php_bug_64898 gdimagescatterex\bug00208_1 gdimagescatterex\bug00208_2 gdimagesetpixel\bug00186 gdimagesetpixel\gdeffectmultiply gdimagesetpixel\gdeffectoverlay gdimagestringft\gdimagestringft_bbox gdimagestringftex\gdimagestringftex_returnfontpathname gdinterpolatedscale\gdModesAndPalettes gdinterpolatedscale\gdTrivialResize gdnewfilectx\gdnewfilectx_null gdtiled\bug00032 gif\bug00005 gif\bug00005_2 gif\bug00006 gif\bug00060 gif\bug00066 gif\bug00181 gif\bug00227 gif\gif_im2im gif\gif_null jpeg\jpeg_empty_file jpeg\jpeg_im2im jpeg\jpeg_null jpeg\jpeg_read jpeg\jpeg_resolution png\bug00011 png\bug00033 png\bug00086 png\bug00088 png\bug00193 png\png_im2im png\png_null png\png_resolution tga\tga_null #tiff\tiff_im2im tiff\tiff_null wbmp\wbmp_im2im wbmp\wbmp_null xpm\bug00166 xpm\bug00185 xpm\color_name LIBS=kernel32.lib ole32.lib user32.lib advapi32.lib shell32.lib ws2_32.lib Dnsapi.lib Gdi32.Lib LIBS_GD=turbojpeg-static.lib freetype_a.lib libpng_a.lib libiconv_a.lib zlib_a.lib INCLUDES=/Isrc /Igd-win-dependencies\$(PLATFORM)\include -Igd-win-dependencies\$(PLATFORM)\include\libjpeg-turbo -Igd-win-dependencies\$(PLATFORM)\include\libpng15 -Igd-win-dependencies\$(PLATFORM)\include\freetype /Itests /Itests\gdtest LDFLAGS=/nologo /nodefaultlib:libcmt /libpath:gd-win-dependencies\$(PLATFORM)\lib /MACHINE:$(PLATFORM) CFLAGS=/nologo /O2 /Qvec-report:1 /MD /TC\ /DWIN32=1\ /D_WIN32=1\ /DMSWIN32=1\ /DBGDWIN32=1\ /DHAVE_FT2BUILD_H=1\ /DHAVE_GD_H=1\ /DHAVE_PNG_H=1\ /DHAVE_ICONV_H=1\ /DHAVE_GD_BUNDLED=1\ /DHAVE_LIBFREETYPE=1\ /DHAVE_LIBJPEG=1\ /DHAVE_LIBPNG=1\ /DHAVE_LIBZ=1\ $(INCLUDES) # /DHAVE_LIBXPM # These flags are not present in this fork of libgd (they may be used in php's): # /DHAVE_GD_WBMP # /DHAVE_GD_GIF_READ=1\ # /DHAVE_GD_GIF_CREATE=1\ # /DHAVE_GD_GD2=1\ # /DHAVE_GDIMAGECOLORRESOLVE=1\ # /DHAVE_GD_IMAGESETBRUSH=1\ # /DHAVE_GD_IMAGESETTILE=1\ # /DHAVE_GD_FONTCACHESHUTDOWN=1\ # /DHAVE_GD_FONTMUTEX=1\ # /DHAVE_GD_STRINGFTEX=1\ # /DHAVE_GD_STRINGTTF=1\ # /DHAVE_GD_FREETYPE=1\ # /DHAVE_LIBGD13=1\ # /DHAVE_LIBGD15=1\ # /DHAVE_LIBGD20=1\ # /DHAVE_LIBGD204=1\ # /DHAVE_COLORCLOSESTHWB\ # /DUSE_GD_IMGSTRTTF\ # /DUSE_GD_IOCTX\ # /DHAVE_GD_JPG\ # /DHAVE_GD_PNG\ # /DHAVE_GD_DYNAMIC_CTX_EX=1\ # /DHAVE_XPM\ # /DHAVE_GD_XBM\ # /DHAVE_GD_XPM\ # /DHAVE_XPM_H=1\ # These flags may be set wrong; not sure of precise purpose # HAVE_GD_BUNDLED # NDEBUG TEST_CFLAGS=$(CFLAGS) /FItest_config.h TEST_LDFLAGS=$(LDFLAGS) $(SDR)gdtest.obj $(BUILD_DIR)\libgd.lib TEST_CONFIG=tests\test_config.h TEST_LIST=$(TDR)testlist.txt TEST_MK=$(TDR)Maketests.vc # generate test makefile from TESTS macro !IF [if not exist $(BUILD_DIR) mkdir $(BUILD_DIR)] !ENDIF !IF [if not exist $(TDR) mkdir $(TDR)] !ENDIF !IF [@copy NUL $(TEST_MK) > nul] !ENDIF !IF [@for %F in ($(TESTS)) do @echo TEST_EXES=$(TDR)%~nF.exe ^$(TEST_EXES) >> $(TEST_MK)] !ENDIF !IF [@for %F in ($(TESTS)) do @echo $(SDR)%~nF.obj: tests\%F.c; @^$(CC) ^$(TEST_CFLAGS) /c ^$** /Fo:^$@ >> $(TEST_MK)] !ENDIF !IF [@for %F in ($(TESTS)) do @echo $(TDR)%~nF.exe: $(SDR)%~nF.obj; @$(LD) $(TEST_LDFLAGS) ^$** /out:^$@ >> $(TEST_MK)] !ENDIF TEST_OBJS=$(TEST_EXES:tests=obj) TEST_OBJS=$(TEST_OBJS:exe=obj) # pseudotargets build_libs: make_dirs $(TARGETDLL) $(TARGETLIB) all: build_libs build_tests check: all run_tests clean: @if exist $(SDR) rd $(SDR) /s /q @if exist $(TDR) rd $(TDR) /s /q @if exist $(BUILD_DIR)\*.exe del $(BUILD_DIR)\*.exe /q @if exist tests\test_config.h del tests\test_config.h /q # helpers make_dirs: @if not exist $(BUILD_DIR) mkdir $(BUILD_DIR) @if not exist $(SDR) mkdir $(SDR) run_tests: @windows\run_tests # libgd $(TARGETDLL): $(OBJECTS) @$(LD) /DLL /OUT:$@ $(OBJECTS) $(LIBS_GD) $(LIBS) $(LDFLAGS) $(TARGETLIB): $(OBJECTS) @$(LB) /OUT:$@ $(OBJECTS) $(LDFLAGS) {src\}.c{$(SDR)}.obj:: @$(CC) $(CFLAGS) /c $< /Fo$(SDR) # tests !INCLUDE $(TEST_MK) build_tests: $(TEST_LIST) $(SDR)gdtest.obj $(TEST_EXES) $(SDR)gdtest.obj: $(TARGETDLL) $(TEST_CONFIG) tests\gdtest\gdtest.c @$(CC) $(CFLAGS) /c tests\gdtest\gdtest.c /Fo$(SDR)gdtest.obj $(TEST_CONFIG): @echo #define GDTEST_TOP_DIR "$(MAKEDIR:\=\\)\\tests" > tests\test_config.h @echo #define snprintf _snprintf >> tests\test_config.h $(TEST_LIST): $(TARGETDLL) @if not exist $(TDR) mkdir $(TDR) @copy $(TARGETDLL) $(TDR)$(GD_DLL) @copy NUL $(TDR)testlist.txt @for %%F in ($(TESTS)) do @echo %%F >> $(TDR)testlist.txtlibgd-gd-2.1.1/windows/libgd.rc000077500000000000000000000030531245535672000163020ustar00rootroot00000000000000/* This is a template RC file. * $Id$ * Do not edit with MSVC */ #ifdef APSTUDIO_INVOKED # error dont edit with MSVC #endif #include "winres.h" #include "../gd.h" LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US #pragma code_page(1252) #ifdef WANT_LOGO 0 ICON gdlib.ico #endif //Version VS_VERSION_INFO VERSIONINFO FILEVERSION GD_MAJOR_VERSION,GD_MINOR_VERSION,GD_RELEASE_VERSION,0 PRODUCTVERSION GD_MAJOR_VERSION,GD_MINOR_VERSION,GD_RELEASE_VERSION,0 FILEFLAGSMASK 0x3fL #ifdef _DEBUG FILEFLAGS VS_FF_DEBUG #else FILEFLAGS 0x0L #endif FILEOS VOS__WINDOWS32 FILETYPE VFT_DLL FILESUBTYPE VFT2_UNKNOWN BEGIN BLOCK "StringFileInfo" BEGIN BLOCK "040904b0" BEGIN VALUE "Comments", "Thanks to Thomas Boutell" "\0" VALUE "CompanyName", "LIBGD Development Team\0" VALUE "FileDescription", "LIBGD" "\0" VALUE "FileVersion", GD_VERSION_STRING "\0" VALUE "InternalName", "bgd.dll" "\0" VALUE "LegalCopyright", "Copyright 1997-2008 Thomas Boutell, Pierre A. Joye and contributors, see COPYING\0" VALUE "LegalTrademarks", "Thomas Boutell, Pierre A. Joye and contributors\0" VALUE "OriginalFilename", "bgd.dll" "\0" VALUE "PrivateBuild", "\0" VALUE "ProductName", "LIBGD dynamic link library" "\0" VALUE "SpecialBuild", "win32" "\0" VALUE "URL", "http://www.libgd.org/" END END BLOCK "VarFileInfo" BEGIN VALUE "Translation", 0x409, 1200 END END #ifdef MC_INCLUDE #include MC_INCLUDE #endif libgd-gd-2.1.1/windows/msys/000077500000000000000000000000001245535672000156625ustar00rootroot00000000000000libgd-gd-2.1.1/windows/msys/Makefile000066400000000000000000000073101245535672000173230ustar00rootroot00000000000000 # Simple makefile for building and testing libgd under MSYS/MinGW on # Windows # The version LIBVER=3.0.1 # Misc. config flags. CDEFS=-DHAVE_ERRNO_H -DHAVE_ICONV -DHAVE_ICONV_H \ -DHAVE_ICONV_T_DEF -DHAVE_INTTYPES_H -DHAVE_LIMITS_H -DHAVE_STDDEF_H \ -DHAVE_STDINT_H -DHAVE_STDLIB_H -DHAVE_VISIBILITY -DICONV_CONST # GnuWin32 libs should all be installed in one place. GNUDIR=/c/tools/GnuWin32 GNUINC=-I$(GNUDIR)/include GNULIB=-L$(GNUDIR)/lib GNUDLL=$(GNUDIR)/bin/ # Various optional components. Comment-out the ones you don't have # and edit the paths and options as needed if you do. The default # assumes GnuWin32 packages installed in /c/Program Files/GnuWin32. JPEG_D=-DHAVE_LIBJPEG JPEG_L=-ljpeg JPEG_I=$(GNUINC) JPEG_LIBDIR=$(GNULIB) JPEG_DLLDIR=$(GNUDLL) PNG_D=-DHAVE_LIBPNG PNG_L=-lpng PNG_I= #$(GNUINC) PNG_LIBDIR= #$(GNULIB) PNG_DLLDIR= #$(GNUDLL) TIFF_D=-DHAVE_LIBTIFF TIFF_L=-ltiff TIFF_I= #$(GNUINC) TIFF_LIBDIR= #$(GNULIB) TIFF_DLLDIR= #$(GNUDLL) LIBZ_D=-DHAVE_LIBZ LIBZ_L=-lz LIBZ_I= #$(GNUINC) LIBZ_LIBDIR= #$(GNULIB) LIBZ_DLLDIR= #$(GNUDLL) # LIBXPM_D=-DHAVE_LIBXPM # LIBXPM_L=-lxpm # LIBXPM_I= #$(GNUINC) # LIBXPM_LIBDIR= #$(GNULIB) FREETYPE_D=-DHAVE_LIBFREETYPE -DHAVE_FT2BUILD_H FREETYPE_L=-lfreetype FREETYPE_I=$(GNUINC)/freetype2/ FREETYPE_LIBDIR= #$(GNULIB) FREETYPE_DLLDIR= #$(GNUDLL) # FONTCONFIG_D=-DHAVE_LIBFONTCONFIG # FONTCONFIG_L= # FONTCONFIG_I= # FONTCONFIG_LIBDIR= ALL_D=$(FREETYPE_D) $(JPEG_D) $(PNG_D) $(TIFF_D) $(LIBZ_D) $(LIBXPM_D) ALL_L=$(FREETYPE_L) $(JPEG_L) $(PNG_L) $(TIFF_L) $(LIBZ_L) $(LIBXPM_L) ALL_I=$(FREETYPE_I) $(JPEG_I) $(PNG_I) $(TIFF_I) $(LIBZ_I) $(LIBXPM_I) ALL_LIBDIR=$(FREETYPE_LIBDIR) $(JPEG_LIBDIR) $(PNG_LIBDIR) $(TIFF_LIBDIR) \ $(LIBZ_LIBDIR) $(LIBXPM_LIBDIR) ALL_DLLDIR=$(FREETYPE_DLLDIR) $(JPEG_DLLDIR) $(PNG_DLLDIR) $(TIFF_DLLDIR) \ $(LIBZ_DLLDIR) $(LIBXPM_DLLDIR) # We need libiconv for internationalization. We default to static # linking because that reduces the number of dependencies. However, # libiconv is released under the GNU GPL which may impose extra # restrictions on redistribution. LIBICONV=/c/MinGW/lib/libiconv.a #LIBICONV=-liconv DEFS=$(CDEFS) $(ALL_D) INCLUDES=$(ALL_I) CC=gcc CFLAGS=-g -O2 -I. -std=gnu99 -fvisibility=hidden -static-libgcc \ -D_WIN32 -DBGDWIN32 $(DEFS) $(INCLUDES) LD=gcc LDFLAGS=-g -O2 -fvisibility=hidden -static-libgcc $(ALL_LIBDIR) LIBS=$(ALL_L) $(LIBICONV) ZIP=zip -j9 DIST=libgd-win.zip # Get this list from c files in libgd_la_SOURCES in Makefile.mk SRC=gd.c gd_color.c gd_color_map.c gd_transform.c gdfx.c \ gd_security.c gd_gd.c gd_gd2.c gd_io.c gd_io_dp.c gd_gif_in.c \ gd_gif_out.c gd_io_file.c gd_io_ss.c gd_jpeg.c gd_png.c gd_ss.c \ gd_topal.c gd_wbmp.c gdcache.c gdfontg.c gdfontl.c gdfontmb.c \ gdfonts.c gdfontt.c gdft.c gdhelpers.c gdkanji.c gdtables.c gdxpm.c \ wbmp.c gd_filter.c gd_nnquant.c gd_rotate.c gd_matrix.c \ gd_interpolation.c gd_crop.c webpimg.c gd_webp.c gd_tiff.c gd_tga.c \ gd_bmp.c gd_xbm.c gd_color_match.c gd_version.c gd_filename.c OBJ=$(SRC:.c=.o) TARGETBASE=libgd TARGET=$(TARGETBASE).dll TARGET_A=$(TARGETBASE).a all: (cd ../../src; make -f ../windows/msys/Makefile $(TARGET)) # BUG: this sucks in all the DLLs in the lib installation directory, # including those you may not need. dist: all (cd ../..; $(ZIP) $(DIST) src/*.dll src/*.a $$(for d in $(ALL_DLLDIR); do echo $$d/*.dll; done | sort -u) ) clean: -rm ../../$(DIST) (cd ../../src; rm -f *.dll *.a $(OBJ) deps.mk; true) check: all bash run_tests.sh "$(GNUDIR)/bin" "$(INCLUDES)" deps.mk: [ -f gd.h ] # Sanity check: we're in src/, right? gcc -MM $(DEFS) $(INCLUDES) $(SRC) > deps.mk $(TARGET): $(OBJ) gcc -shared -o $(TARGET) $(LDFLAGS) -Wl,--out-implib,$(TARGET_A) \ $(OBJ) $(LIBS) include deps.mk libgd-gd-2.1.1/windows/msys/README.MSYS.md000066400000000000000000000042571245535672000177430ustar00rootroot00000000000000 # MSYS Fallback Makefile This is a simple, straightforward Makefile for building LibGD with MinGW on MSYS (or possibly Cygwin). It is here for anyone who doesn't want to deal with autotools or CMake on Windows or who can't get either of them working on their particular setup. Note that this Makefile only builds the library and test cases; the standalone utilities are ignored. If you need those, you'll need to use one of the other build systems (or add them yourself.) ## To build LibGD: 1. Install MinGW and MSYS (see ). You will need to install zip and unzip as well as the 32-bit C compiler and related tools. 2. Install LibJpeg, LibPng, LibTiff, Zlib and FreeType from and install them all in `c:/tools/GnuWin32/`. (You can get these libraries from other places and/or install them in different locations, but you'll need to edit the Makefile accordingly if you do.) 3. Skip ahead to the next step. If that doesn't work, edit the Makefile to fix what went wrong. Things to try include: * Ensure SRC contains an up-to-date list of source files. (Take a look at libgd_la_SOURCES src/Makefile.am for a reference.) * Ensure that the paths and #defines for unsupported libraries are commented out. They're nicely grouped into clusters to simplify that. 4. `cd` to this directory and type: make make check If both commands succeed, you're done. (Note that some of the testcases will fail, just because they test features not enabled here. This is fine. As long as most tests pass, you're probably okay.) 5. Type make dist This will create libgd-win.zip, a zip file containing the new library and its dependants. Note that this step may pick up extra DLLs; it sweeps up all of the DLLs in the directories pointed to by *_DLLDIR Makefile variables. Alternately, you can copy the lib (in src/) to wherever it needs to go. ## Stuff that Doesn't Work * LibXpm: It's probably nothing serious, just more trouble than it's worth. * LibFontconfig: I couldn't find Windows binaries for it anywhere reputable. libgd-gd-2.1.1/windows/msys/deps.mk000077500000000000000000000000601245535672000171450ustar00rootroot00000000000000# Nothing to see here. (But it shuts up make.) libgd-gd-2.1.1/windows/msys/run_tests.sh000077500000000000000000000025241245535672000202520ustar00rootroot00000000000000#!/bin/bash set -e # Parameters DLLPATH_EXTRA=$1 # Path to supporting DLLs CFLAGS_EXTRA=$2 # Extra C flags LOG=run_tests.log CFLAGS="-g -Igdtest/ -I. -I../src/ -D_WIN32 $CFLAGS_EXTRA" LDFLAGS='-L../src -llibgd' DLLPATH=../src:$DLLPATH_EXTRA function run_gcc { if msg=`gcc $* 2>&1`; then true else echo "COMMAND: gcc $*" >> $LOG echo $msg >> $LOG false fi } # Switch to the working directory export PATH=$PATH:$DLLPATH cd ../../tests # Initial setup echo "Setting up..." [ -f $LOG ] && rm -f $LOG [ -f test_config.h ] || echo '#define GDTEST_TOP_DIR "."' > test_config.h run_gcc -c $CFLAGS gdtest/gdtest.c echo "Running tests:" count=0 failures=0 compile_failures=0 for test in `find . -name \*.c | grep -v '^./gdtest'`; do count=`expr $count + 1` exe=${test%.c}.exe if run_gcc -o $exe $CFLAGS $LDFLAGS $test gdtest.o; then true; else echo "COMPILE_FAIL: $test" compile_failures=`expr $compile_failures + 1` continue fi echo "Running $exe:" >> $LOG if $exe 2>&1 >> $LOG; then echo "PASS: $test" else failures=`expr $failures + 1` echo "FAIL: $test" fi echo >> $LOG done echo "$failures failures and $compile_failures compile failures out of $count tests." echo "Error messages in $LOG" libgd-gd-2.1.1/windows/readme.md000066400000000000000000000005441245535672000164510ustar00rootroot00000000000000# Building on Windows with Visual Studio 2013 Open the VS2013 x64 Native Tools Command Prompt. 2012 will *not* work. Change to the gd-libgd folder. git clone https://github.com/imazen/gd-win-dependencies into the folder. Run nmake /f windows/Makefile.vc all nmake /f windows/Makefile.vc check Before rebuilding, run: nmake /f windows/Makefile.vc clean libgd-gd-2.1.1/windows/run_tests.bat000066400000000000000000000020351245535672000174050ustar00rootroot00000000000000@echo off setlocal EnableDelayedExpansion if [%PLATFORM%]==[] set PLATFORM=x86 if [%PREFERREDTOOLARCHITECTURE%]==[x64] set PLATFORM=x64 set PLATFORM=%PLATFORM:X=x% if exist build_msvc12_%PLATFORM%\tests (cd build_msvc12_%PLATFORM%\tests) else ( if exist ..\build_%PLATFORM%\tests (cd ..\build_msvc12_%PLATFORM%\tests) else ( echo unable to find test dir exit /b 1 ) ) for /f %%T in (testlist.txt) do ( set test=%%T set output=test: !test!.................................................................... set target=%%~nT.exe if not exist !target! SET result=NotFound call !target! && (SET result=Passed) || (SET result=Failed) rem > last_test.out 2> last_test.err rem set /p testerr=