shithub: freetype+ttf2subf

ref: d490e3734d6e4b0ef46888f6f55776b36073d4bd
dir: /src/base/ftxf86.c/

View raw version
#include <ft2build.h>
#include FT_XFREE86_H
#include FT_INTERNAL_OBJECTS_H

 /* XXX: this really is a sad hack, but I didn't want to change every     */
 /*      driver just to support this at the moment, since other important */
 /*      changes are coming anyway !!                                     */

  typedef struct
  {
    const char*  driver_name;
    const char*  format_name;

  } FT_FontFormatRec;


  FT_EXPORT_DEF( const char* )
  FT_Get_X11_Font_Format( FT_Face    face )
  {
    static const FT_FontFormatRec  font_formats[] =
    {
      { "type1",    "Type 1" },
      { "truetype", "TrueType" },
      { "bdf",      "BDF" },
      { "pcf",      "PCF" },
      { "type42",   "Type 42" },
      { "cidtype1", "CID Type 1" },
      { "cff",      "CFF" },
      { "pfr",      "PFR" },
      { "winfonts",   "Windows FNT" }
    };

    const char*  result = NULL;


    if ( face && face->driver )
    {
      FT_Module  driver = (FT_Module) face->driver;

      if ( driver->clazz && driver->clazz->module_name )
      {
        FT_Int  n, count = sizeof(font_formats)/sizeof(font_formats[0]);

        result = driver->clazz->module_name;

        for ( n = 0; n < count; n++ )
          if ( ft_strcmp( result, font_formats[n].driver_name ) == 0 )
          {
            result = font_formats[n].format_name;
            break;
          }
      }
    }

    return result;
  }